From 77ea262666912f7abba82c7da3c514bfc46f8448 Mon Sep 17 00:00:00 2001 From: Hanieh Arabzadeh <60711755+arabzade@users.noreply.github.com> Date: Tue, 23 Nov 2021 10:19:38 -0800 Subject: [PATCH 1/2] added readme --- .DS_Store | Bin 0 -> 6148 bytes README.md | 42 ++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 42 insertions(+) create mode 100644 .DS_Store create mode 100644 README.md diff --git a/.DS_Store b/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..d9206307ac7537906e102a6c3e691483350f61c2 GIT binary patch literal 6148 zcmeHKyH3ME5S)b+kx-rTKIBgtZjIOD(I z5pSo%>+n1d$GqYE5z0ydDIf);fE17dzfiz?FKvC5s3--bfE4&vz`qZT?${MhiSg-R zh!KFeVmgfLm?enK6U44?N@Rv+NhK!LYQ(UlGvBJNE1VLO4y)nA>Sn76#o~6J-=ZAW zB`Qh*DKJ;yGPhgr|9kom^Z%TrofMD)|4IQ{?GC%1uT;Ht@p9g48~vW{HJ@}hu7ko5 m?U)$tm>X}$*HM&p&DVV16;6pkXFlje{S3G+GAZ!a3VZ=q`W8q4 literal 0 HcmV?d00001 diff --git a/README.md b/README.md new file mode 100644 index 0000000..63c82d6 --- /dev/null +++ b/README.md @@ -0,0 +1,42 @@ +Follow the below steps to run the application and use the APIs through Postman + +- Intsall MongoDb - https://docs.mongodb.com/manual/installation/ + +- Run the app with Visual Studio + +- Run the APIs via Postman + +Here is some examples of APIs: + +URL: https://localhost:5001/books +POST +Body: +{ + "Title" : "The stranger version 2", + "Authors" : "Matthew Ward", + "AverageRating" : "4.3", + "NumPage" : "85", + "RatingCount" : "450000", + "TextReviewCount" : "32000", + "PublicationDate" : "01-05-2021", + "Publisher" : "Local book store" +} + +URL: https://localhost:5001/books +GET + +# Search by Id + +URL: https://localhost:5001/books/fa19dcf3-17c8-438a-b4f9-58788cac97b4 +GET + +#Search by: +- title +- authors +- min number of pages +- max number of pages + +URL: https://localhost:5001/books/search?Title=ha&Authors=ha&MinNumPage=1&MaxNumPage=500 +GET + + From 43cd98a532292da725e0a43c81b40fcb8eefa9d8 Mon Sep 17 00:00:00 2001 From: Hanieh Arabzadeh <60711755+arabzade@users.noreply.github.com> Date: Sat, 27 Nov 2021 01:32:41 -0800 Subject: [PATCH 2/2] added front-end --- .DS_Store | Bin 6148 -> 6148 bytes .../MongoBookApis}/.DS_Store | Bin .../.vs/MongoBookApis/xs/UserPrefs.xml | 34 +- .../xs/project-cache/MongoBookApis-Debug.json | 2 +- .../Controllers/BooksController.cs | 3 + .../MongoBookApis}/Dtos/BookDto.cs | 0 .../MongoBookApis}/Dtos/CreateBookDto.cs | 0 .../MongoBookApis}/Models/Book.cs | 0 .../MongoBookApis}/Models/OwnerClass.cs | 0 .../MongoBookApis}/MongoBookApis.csproj | 2 + .../MongoBookApis}/MongoBookApis.sln | 0 .../MongoDbSettings/MongoDbSettings.cs | 0 .../MongoBookApis}/Program.cs | 0 .../Properties/launchSettings.json | 0 .../MongoBookApis}/Repositories/.DS_Store | Bin .../MongoBookApis}/Repositories/Extensions.cs | 0 .../Repositories/IBooksRepository.cs | 0 .../Repositories/MongoDbBooksRepository.cs | 3 +- .../MongoBookApis}/Startup.cs | 16 +- .../appsettings.Development.json | 0 .../MongoBookApis}/appsettings.json | 0 .../bin/Debug/net5.0/DnsClient.dll | Bin .../bin/Debug/net5.0/Microsoft.OpenApi.dll | Bin .../bin/Debug/net5.0/MongoBookApis.deps.json | 2234 ++++- .../bin/Debug/net5.0/MongoBookApis.dll | Bin 0 -> 33280 bytes .../bin/Debug/net5.0/MongoBookApis.pdb | Bin 25008 -> 25368 bytes .../MongoBookApis.runtimeconfig.dev.json | 0 .../net5.0/MongoBookApis.runtimeconfig.json | 0 .../bin/Debug/net5.0/MongoDB.Bson.dll | Bin .../bin/Debug/net5.0/MongoDB.Driver.Core.dll | Bin .../bin/Debug/net5.0/MongoDB.Driver.dll | Bin .../Debug/net5.0/MongoDB.Libmongocrypt.dll | Bin .../bin/Debug/net5.0/Newtonsoft.Json.Bson.dll | Bin 0 -> 90624 bytes .../bin/Debug/net5.0/Newtonsoft.Json.dll | Bin 0 -> 639488 bytes .../bin/Debug/net5.0/SharpCompress.dll | Bin .../net5.0/Swashbuckle.AspNetCore.Swagger.dll | Bin .../Swashbuckle.AspNetCore.SwaggerGen.dll | Bin .../Swashbuckle.AspNetCore.SwaggerUI.dll | Bin .../net5.0/System.Net.Http.Formatting.dll | Bin 0 -> 178824 bytes .../bin/Debug/net5.0/System.Web.Cors.dll | Bin 0 -> 27768 bytes .../bin/Debug/net5.0/System.Web.Http.Cors.dll | Bin 0 -> 39352 bytes .../bin/Debug/net5.0/System.Web.Http.dll | Bin 0 -> 455096 bytes .../Debug/net5.0/appsettings.Development.json | 0 .../bin/Debug/net5.0/appsettings.json | 0 .../bin/Debug/net5.0/ref/MongoBookApis.dll | Bin 0 -> 15360 bytes .../runtimes/linux/native/libmongocrypt.so | Bin .../runtimes/osx/native/libmongocrypt.dylib | Bin .../net5.0/runtimes/win/native/libzstd.dll | Bin .../net5.0/runtimes/win/native/mongocrypt.dll | Bin .../net5.0/runtimes/win/native/snappy32.dll | Bin .../net5.0/runtimes/win/native/snappy64.dll | Bin ...CoreApp,Version=v5.0.AssemblyAttributes.cs | 0 .../net5.0/MongoBookApis.AssemblyInfo.cs | 0 .../MongoBookApis.AssemblyInfoInputs.cache | 0 ....GeneratedMSBuildEditorConfig.editorconfig | 0 ...Apis.MvcApplicationPartsAssemblyInfo.cache | 0 ...ookApis.MvcApplicationPartsAssemblyInfo.cs | 0 ...ongoBookApis.RazorTargetAssemblyInfo.cache | 0 .../Debug/net5.0/MongoBookApis.assets.cache | Bin 0 -> 45543 bytes ...ngoBookApis.csproj.AssemblyReference.cache | Bin 0 -> 11 bytes .../net5.0/MongoBookApis.csproj.CopyComplete | 0 ...ngoBookApis.csproj.CoreCompileInputs.cache | 1 + .../MongoBookApis.csproj.FileListAbsolute.txt | 6 + .../obj/Debug/net5.0/MongoBookApis.dll | Bin 0 -> 33280 bytes .../MongoBookApis.genruntimeconfig.cache | 0 .../obj/Debug/net5.0/MongoBookApis.pdb | Bin 25008 -> 25368 bytes .../obj/Debug/net5.0/ref/MongoBookApis.dll | Bin 0 -> 15360 bytes ...ngoBookApis.StaticWebAssets.Manifest.cache | 0 .../MongoBookApis.StaticWebAssets.xml | 0 .../MongoBookApis.csproj.nuget.dgspec.json | 4 + .../obj/MongoBookApis.csproj.nuget.g.props | 1 + .../obj/MongoBookApis.csproj.nuget.g.targets | 0 .../MongoBookApis/obj/project.assets.json | 6024 ++++++++++++ .../MongoBookApis/obj/project.nuget.cache | 143 + Front-end/.DS_Store | Bin 0 -> 6148 bytes Front-end/Config/Config.py | 6 + Front-end/Models/BookModel.py | 28 + Front-end/__pycache__/app.cpython-38.pyc | Bin 0 -> 2323 bytes Front-end/apis-env/.DS_Store | Bin 0 -> 6148 bytes Front-end/apis-env/bin/Activate.ps1 | 241 + Front-end/apis-env/bin/activate | 76 + Front-end/apis-env/bin/activate.csh | 37 + Front-end/apis-env/bin/activate.fish | 75 + Front-end/apis-env/bin/easy_install | 10 + Front-end/apis-env/bin/easy_install-3.8 | 10 + Front-end/apis-env/bin/pip | 10 + Front-end/apis-env/bin/pip3 | 10 + Front-end/apis-env/bin/pip3.8 | 10 + Front-end/apis-env/bin/python | 1 + Front-end/apis-env/bin/python3 | 1 + .../__pycache__/easy_install.cpython-38.pyc | Bin 0 -> 337 bytes .../python3.8/site-packages/easy_install.py | 5 + .../pip-19.2.3.dist-info/INSTALLER | 1 + .../pip-19.2.3.dist-info/LICENSE.txt | 20 + .../pip-19.2.3.dist-info/METADATA | 81 + .../site-packages/pip-19.2.3.dist-info/RECORD | 668 ++ .../site-packages/pip-19.2.3.dist-info/WHEEL | 6 + .../pip-19.2.3.dist-info/entry_points.txt | 5 + .../pip-19.2.3.dist-info/top_level.txt | 1 + .../python3.8/site-packages/pip/__init__.py | 1 + .../python3.8/site-packages/pip/__main__.py | 19 + .../pip/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 210 bytes .../pip/__pycache__/__main__.cpython-38.pyc | Bin 0 -> 462 bytes .../site-packages/pip/_internal/__init__.py | 77 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 1755 bytes .../__pycache__/build_env.cpython-38.pyc | Bin 0 -> 7531 bytes .../__pycache__/cache.cpython-38.pyc | Bin 0 -> 7143 bytes .../__pycache__/configuration.cpython-38.pyc | Bin 0 -> 10694 bytes .../__pycache__/download.cpython-38.pyc | Bin 0 -> 25981 bytes .../__pycache__/exceptions.cpython-38.pyc | Bin 0 -> 12542 bytes .../__pycache__/index.cpython-38.pyc | Bin 0 -> 37782 bytes .../__pycache__/legacy_resolve.cpython-38.pyc | Bin 0 -> 10601 bytes .../__pycache__/locations.cpython-38.pyc | Bin 0 -> 2990 bytes .../__pycache__/pep425tags.cpython-38.pyc | Bin 0 -> 8389 bytes .../__pycache__/pyproject.cpython-38.pyc | Bin 0 -> 3216 bytes .../__pycache__/wheel.cpython-38.pyc | Bin 0 -> 27542 bytes .../site-packages/pip/_internal/build_env.py | 218 + .../site-packages/pip/_internal/cache.py | 224 + .../pip/_internal/cli/__init__.py | 4 + .../cli/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 285 bytes .../__pycache__/autocompletion.cpython-38.pyc | Bin 0 -> 5143 bytes .../__pycache__/base_command.cpython-38.pyc | Bin 0 -> 8318 bytes .../cli/__pycache__/cmdoptions.cpython-38.pyc | Bin 0 -> 20060 bytes .../__pycache__/main_parser.cpython-38.pyc | Bin 0 -> 2223 bytes .../cli/__pycache__/parser.cpython-38.pyc | Bin 0 -> 9026 bytes .../__pycache__/status_codes.cpython-38.pyc | Bin 0 -> 414 bytes .../pip/_internal/cli/autocompletion.py | 152 + .../pip/_internal/cli/base_command.py | 346 + .../pip/_internal/cli/cmdoptions.py | 931 ++ .../pip/_internal/cli/main_parser.py | 98 + .../site-packages/pip/_internal/cli/parser.py | 261 + .../pip/_internal/cli/status_codes.py | 8 + .../pip/_internal/commands/__init__.py | 81 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 2604 bytes .../commands/__pycache__/check.cpython-38.pyc | Bin 0 -> 1346 bytes .../__pycache__/completion.cpython-38.pyc | Bin 0 -> 3125 bytes .../__pycache__/configuration.cpython-38.pyc | Bin 0 -> 7189 bytes .../commands/__pycache__/debug.cpython-38.pyc | Bin 0 -> 3397 bytes .../__pycache__/download.cpython-38.pyc | Bin 0 -> 4751 bytes .../__pycache__/freeze.cpython-38.pyc | Bin 0 -> 3044 bytes .../commands/__pycache__/hash.cpython-38.pyc | Bin 0 -> 2094 bytes .../commands/__pycache__/help.cpython-38.pyc | Bin 0 -> 1265 bytes .../__pycache__/install.cpython-38.pyc | Bin 0 -> 13092 bytes .../commands/__pycache__/list.cpython-38.pyc | Bin 0 -> 9033 bytes .../__pycache__/search.cpython-38.pyc | Bin 0 -> 4480 bytes .../commands/__pycache__/show.cpython-38.pyc | Bin 0 -> 5877 bytes .../__pycache__/uninstall.cpython-38.pyc | Bin 0 -> 2727 bytes .../commands/__pycache__/wheel.cpython-38.pyc | Bin 0 -> 4933 bytes .../pip/_internal/commands/check.py | 41 + .../pip/_internal/commands/completion.py | 94 + .../pip/_internal/commands/configuration.py | 258 + .../pip/_internal/commands/debug.py | 114 + .../pip/_internal/commands/download.py | 168 + .../pip/_internal/commands/freeze.py | 101 + .../pip/_internal/commands/hash.py | 57 + .../pip/_internal/commands/help.py | 37 + .../pip/_internal/commands/install.py | 580 ++ .../pip/_internal/commands/list.py | 311 + .../pip/_internal/commands/search.py | 139 + .../pip/_internal/commands/show.py | 168 + .../pip/_internal/commands/uninstall.py | 78 + .../pip/_internal/commands/wheel.py | 181 + .../pip/_internal/configuration.py | 417 + .../pip/_internal/distributions/__init__.py | 23 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 874 bytes .../__pycache__/base.cpython-38.pyc | Bin 0 -> 1669 bytes .../__pycache__/installed.cpython-38.pyc | Bin 0 -> 1009 bytes .../__pycache__/source.cpython-38.pyc | Bin 0 -> 3106 bytes .../__pycache__/wheel.cpython-38.pyc | Bin 0 -> 1073 bytes .../pip/_internal/distributions/base.py | 33 + .../pip/_internal/distributions/installed.py | 15 + .../pip/_internal/distributions/source.py | 80 + .../pip/_internal/distributions/wheel.py | 17 + .../site-packages/pip/_internal/download.py | 1177 +++ .../site-packages/pip/_internal/exceptions.py | 305 + .../site-packages/pip/_internal/index.py | 1508 +++ .../pip/_internal/legacy_resolve.py | 457 + .../site-packages/pip/_internal/locations.py | 142 + .../pip/_internal/models/__init__.py | 2 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 273 bytes .../__pycache__/candidate.cpython-38.pyc | Bin 0 -> 1507 bytes .../__pycache__/format_control.cpython-38.pyc | Bin 0 -> 2301 bytes .../models/__pycache__/index.cpython-38.pyc | Bin 0 -> 1195 bytes .../models/__pycache__/link.cpython-38.pyc | Bin 0 -> 6334 bytes .../__pycache__/search_scope.cpython-38.pyc | Bin 0 -> 3304 bytes .../selection_prefs.cpython-38.pyc | Bin 0 -> 1645 bytes .../__pycache__/target_python.cpython-38.pyc | Bin 0 -> 3249 bytes .../pip/_internal/models/candidate.py | 36 + .../pip/_internal/models/format_control.py | 73 + .../pip/_internal/models/index.py | 31 + .../pip/_internal/models/link.py | 213 + .../pip/_internal/models/search_scope.py | 113 + .../pip/_internal/models/selection_prefs.py | 47 + .../pip/_internal/models/target_python.py | 106 + .../pip/_internal/operations/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 209 bytes .../__pycache__/check.cpython-38.pyc | Bin 0 -> 3715 bytes .../__pycache__/freeze.cpython-38.pyc | Bin 0 -> 5779 bytes .../__pycache__/prepare.cpython-38.pyc | Bin 0 -> 5796 bytes .../pip/_internal/operations/check.py | 159 + .../pip/_internal/operations/freeze.py | 253 + .../pip/_internal/operations/prepare.py | 287 + .../site-packages/pip/_internal/pep425tags.py | 384 + .../site-packages/pip/_internal/pyproject.py | 171 + .../pip/_internal/req/__init__.py | 78 + .../req/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 1749 bytes .../__pycache__/constructors.cpython-38.pyc | Bin 0 -> 8021 bytes .../req/__pycache__/req_file.cpython-38.pyc | Bin 0 -> 9426 bytes .../__pycache__/req_install.cpython-38.pyc | Bin 0 -> 25779 bytes .../req/__pycache__/req_set.cpython-38.pyc | Bin 0 -> 5742 bytes .../__pycache__/req_tracker.cpython-38.pyc | Bin 0 -> 3274 bytes .../__pycache__/req_uninstall.cpython-38.pyc | Bin 0 -> 17401 bytes .../pip/_internal/req/constructors.py | 349 + .../pip/_internal/req/req_file.py | 399 + .../pip/_internal/req/req_install.py | 1035 +++ .../pip/_internal/req/req_set.py | 193 + .../pip/_internal/req/req_tracker.py | 96 + .../pip/_internal/req/req_uninstall.py | 633 ++ .../pip/_internal/utils/__init__.py | 0 .../utils/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 204 bytes .../utils/__pycache__/appdirs.cpython-38.pyc | Bin 0 -> 8083 bytes .../utils/__pycache__/compat.cpython-38.pyc | Bin 0 -> 6979 bytes .../__pycache__/deprecation.cpython-38.pyc | Bin 0 -> 2875 bytes .../utils/__pycache__/encoding.cpython-38.pyc | Bin 0 -> 1296 bytes .../__pycache__/filesystem.cpython-38.pyc | Bin 0 -> 675 bytes .../utils/__pycache__/glibc.cpython-38.pyc | Bin 0 -> 2306 bytes .../utils/__pycache__/hashes.cpython-38.pyc | Bin 0 -> 4193 bytes .../utils/__pycache__/logging.cpython-38.pyc | Bin 0 -> 9169 bytes .../__pycache__/marker_files.cpython-38.pyc | Bin 0 -> 815 bytes .../utils/__pycache__/misc.cpython-38.pyc | Bin 0 -> 29900 bytes .../utils/__pycache__/models.cpython-38.pyc | Bin 0 -> 1973 bytes .../utils/__pycache__/outdated.cpython-38.pyc | Bin 0 -> 4260 bytes .../__pycache__/packaging.cpython-38.pyc | Bin 0 -> 2657 bytes .../setuptools_build.cpython-38.pyc | Bin 0 -> 1066 bytes .../utils/__pycache__/temp_dir.cpython-38.pyc | Bin 0 -> 4924 bytes .../utils/__pycache__/typing.cpython-38.pyc | Bin 0 -> 1334 bytes .../utils/__pycache__/ui.cpython-38.pyc | Bin 0 -> 11859 bytes .../__pycache__/virtualenv.cpython-38.pyc | Bin 0 -> 927 bytes .../pip/_internal/utils/appdirs.py | 268 + .../pip/_internal/utils/compat.py | 293 + .../pip/_internal/utils/deprecation.py | 100 + .../pip/_internal/utils/encoding.py | 39 + .../pip/_internal/utils/filesystem.py | 30 + .../pip/_internal/utils/glibc.py | 120 + .../pip/_internal/utils/hashes.py | 128 + .../pip/_internal/utils/logging.py | 394 + .../pip/_internal/utils/marker_files.py | 20 + .../site-packages/pip/_internal/utils/misc.py | 1201 +++ .../pip/_internal/utils/models.py | 40 + .../pip/_internal/utils/outdated.py | 178 + .../pip/_internal/utils/packaging.py | 94 + .../pip/_internal/utils/setuptools_build.py | 36 + .../pip/_internal/utils/temp_dir.py | 155 + .../pip/_internal/utils/typing.py | 29 + .../site-packages/pip/_internal/utils/ui.py | 424 + .../pip/_internal/utils/virtualenv.py | 34 + .../pip/_internal/vcs/__init__.py | 12 + .../vcs/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 480 bytes .../vcs/__pycache__/bazaar.cpython-38.pyc | Bin 0 -> 3456 bytes .../vcs/__pycache__/git.cpython-38.pyc | Bin 0 -> 9012 bytes .../vcs/__pycache__/mercurial.cpython-38.pyc | Bin 0 -> 3743 bytes .../vcs/__pycache__/subversion.cpython-38.pyc | Bin 0 -> 8396 bytes .../__pycache__/versioncontrol.cpython-38.pyc | Bin 0 -> 17126 bytes .../site-packages/pip/_internal/vcs/bazaar.py | 101 + .../site-packages/pip/_internal/vcs/git.py | 358 + .../pip/_internal/vcs/mercurial.py | 103 + .../pip/_internal/vcs/subversion.py | 314 + .../pip/_internal/vcs/versioncontrol.py | 600 ++ .../site-packages/pip/_internal/wheel.py | 1125 +++ .../site-packages/pip/_vendor/__init__.py | 109 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 2875 bytes .../__pycache__/appdirs.cpython-38.pyc | Bin 0 -> 20486 bytes .../_vendor/__pycache__/distro.cpython-38.pyc | Bin 0 -> 36590 bytes .../__pycache__/ipaddress.cpython-38.pyc | Bin 0 -> 64831 bytes .../__pycache__/pyparsing.cpython-38.pyc | Bin 0 -> 220254 bytes .../__pycache__/retrying.cpython-38.pyc | Bin 0 -> 8055 bytes .../_vendor/__pycache__/six.cpython-38.pyc | Bin 0 -> 26445 bytes .../site-packages/pip/_vendor/appdirs.py | 604 ++ .../pip/_vendor/cachecontrol/__init__.py | 11 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 562 bytes .../__pycache__/_cmd.cpython-38.pyc | Bin 0 -> 1589 bytes .../__pycache__/adapter.cpython-38.pyc | Bin 0 -> 3088 bytes .../__pycache__/cache.cpython-38.pyc | Bin 0 -> 1795 bytes .../__pycache__/compat.cpython-38.pyc | Bin 0 -> 769 bytes .../__pycache__/controller.cpython-38.pyc | Bin 0 -> 7709 bytes .../__pycache__/filewrapper.cpython-38.pyc | Bin 0 -> 2188 bytes .../__pycache__/heuristics.cpython-38.pyc | Bin 0 -> 4747 bytes .../__pycache__/serialize.cpython-38.pyc | Bin 0 -> 4260 bytes .../__pycache__/wrapper.cpython-38.pyc | Bin 0 -> 678 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-38.pyc | Bin 0 -> 306 bytes .../__pycache__/file_cache.cpython-38.pyc | Bin 0 -> 3304 bytes .../__pycache__/redis_cache.cpython-38.pyc | Bin 0 -> 1578 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 | 367 + .../pip/_vendor/cachecontrol/filewrapper.py | 80 + .../pip/_vendor/cachecontrol/heuristics.py | 135 + .../pip/_vendor/cachecontrol/serialize.py | 186 + .../pip/_vendor/cachecontrol/wrapper.py | 29 + .../pip/_vendor/certifi/__init__.py | 3 + .../pip/_vendor/certifi/__main__.py | 2 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 269 bytes .../__pycache__/__main__.cpython-38.pyc | Bin 0 -> 272 bytes .../certifi/__pycache__/core.cpython-38.pyc | Bin 0 -> 485 bytes .../pip/_vendor/certifi/cacert.pem | 4618 ++++++++++ .../site-packages/pip/_vendor/certifi/core.py | 15 + .../pip/_vendor/chardet/__init__.py | 39 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 862 bytes .../__pycache__/big5freq.cpython-38.pyc | Bin 0 -> 27191 bytes .../__pycache__/big5prober.cpython-38.pyc | Bin 0 -> 1146 bytes .../chardistribution.cpython-38.pyc | Bin 0 -> 6232 bytes .../charsetgroupprober.cpython-38.pyc | Bin 0 -> 2263 bytes .../__pycache__/charsetprober.cpython-38.pyc | Bin 0 -> 3495 bytes .../codingstatemachine.cpython-38.pyc | Bin 0 -> 2922 bytes .../chardet/__pycache__/compat.cpython-38.pyc | Bin 0 -> 367 bytes .../__pycache__/cp949prober.cpython-38.pyc | Bin 0 -> 1153 bytes .../chardet/__pycache__/enums.cpython-38.pyc | Bin 0 -> 2660 bytes .../__pycache__/escprober.cpython-38.pyc | Bin 0 -> 2645 bytes .../chardet/__pycache__/escsm.cpython-38.pyc | Bin 0 -> 7486 bytes .../__pycache__/eucjpprober.cpython-38.pyc | Bin 0 -> 2463 bytes .../__pycache__/euckrfreq.cpython-38.pyc | Bin 0 -> 12075 bytes .../__pycache__/euckrprober.cpython-38.pyc | Bin 0 -> 1154 bytes .../__pycache__/euctwfreq.cpython-38.pyc | Bin 0 -> 27195 bytes .../__pycache__/euctwprober.cpython-38.pyc | Bin 0 -> 1154 bytes .../__pycache__/gb2312freq.cpython-38.pyc | Bin 0 -> 19119 bytes .../__pycache__/gb2312prober.cpython-38.pyc | Bin 0 -> 1162 bytes .../__pycache__/hebrewprober.cpython-38.pyc | Bin 0 -> 3035 bytes .../__pycache__/jisfreq.cpython-38.pyc | Bin 0 -> 22147 bytes .../chardet/__pycache__/jpcntx.cpython-38.pyc | Bin 0 -> 37620 bytes .../langbulgarianmodel.cpython-38.pyc | Bin 0 -> 23644 bytes .../langcyrillicmodel.cpython-38.pyc | Bin 0 -> 29108 bytes .../__pycache__/langgreekmodel.cpython-38.pyc | Bin 0 -> 23602 bytes .../langhebrewmodel.cpython-38.pyc | Bin 0 -> 22229 bytes .../langhungarianmodel.cpython-38.pyc | Bin 0 -> 23633 bytes .../__pycache__/langthaimodel.cpython-38.pyc | Bin 0 -> 22208 bytes .../langturkishmodel.cpython-38.pyc | Bin 0 -> 22231 bytes .../__pycache__/latin1prober.cpython-38.pyc | Bin 0 -> 3415 bytes .../mbcharsetprober.cpython-38.pyc | Bin 0 -> 2278 bytes .../mbcsgroupprober.cpython-38.pyc | Bin 0 -> 1143 bytes .../chardet/__pycache__/mbcssm.cpython-38.pyc | Bin 0 -> 16766 bytes .../sbcharsetprober.cpython-38.pyc | Bin 0 -> 3031 bytes .../sbcsgroupprober.cpython-38.pyc | Bin 0 -> 1641 bytes .../__pycache__/sjisprober.cpython-38.pyc | Bin 0 -> 2499 bytes .../universaldetector.cpython-38.pyc | Bin 0 -> 5843 bytes .../__pycache__/utf8prober.cpython-38.pyc | Bin 0 -> 2004 bytes .../__pycache__/version.cpython-38.pyc | Bin 0 -> 451 bytes .../pip/_vendor/chardet/big5freq.py | 386 + .../pip/_vendor/chardet/big5prober.py | 47 + .../pip/_vendor/chardet/chardistribution.py | 233 + .../pip/_vendor/chardet/charsetgroupprober.py | 106 + .../pip/_vendor/chardet/charsetprober.py | 145 + .../pip/_vendor/chardet/cli/__init__.py | 1 + .../cli/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 208 bytes .../cli/__pycache__/chardetect.cpython-38.pyc | Bin 0 -> 2709 bytes .../pip/_vendor/chardet/cli/chardetect.py | 85 + .../pip/_vendor/chardet/codingstatemachine.py | 88 + .../pip/_vendor/chardet/compat.py | 34 + .../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 | 228 + .../pip/_vendor/chardet/langcyrillicmodel.py | 333 + .../pip/_vendor/chardet/langgreekmodel.py | 225 + .../pip/_vendor/chardet/langhebrewmodel.py | 200 + .../pip/_vendor/chardet/langhungarianmodel.py | 225 + .../pip/_vendor/chardet/langthaimodel.py | 199 + .../pip/_vendor/chardet/langturkishmodel.py | 193 + .../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/sbcharsetprober.py | 132 + .../pip/_vendor/chardet/sbcsgroupprober.py | 73 + .../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-38.pyc | Bin 0 -> 456 bytes .../colorama/__pycache__/ansi.cpython-38.pyc | Bin 0 -> 3241 bytes .../__pycache__/ansitowin32.cpython-38.pyc | Bin 0 -> 7750 bytes .../__pycache__/initialise.cpython-38.pyc | Bin 0 -> 1717 bytes .../colorama/__pycache__/win32.cpython-38.pyc | Bin 0 -> 3993 bytes .../__pycache__/winterm.cpython-38.pyc | Bin 0 -> 4677 bytes .../pip/_vendor/colorama/ansi.py | 102 + .../pip/_vendor/colorama/ansitowin32.py | 257 + .../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-38.pyc | Bin 0 -> 1077 bytes .../distlib/__pycache__/compat.cpython-38.pyc | Bin 0 -> 32220 bytes .../__pycache__/database.cpython-38.pyc | Bin 0 -> 42117 bytes .../distlib/__pycache__/index.cpython-38.pyc | Bin 0 -> 17424 bytes .../__pycache__/locators.cpython-38.pyc | Bin 0 -> 38322 bytes .../__pycache__/manifest.cpython-38.pyc | Bin 0 -> 10246 bytes .../__pycache__/markers.cpython-38.pyc | Bin 0 -> 4510 bytes .../__pycache__/metadata.cpython-38.pyc | Bin 0 -> 26657 bytes .../__pycache__/resources.cpython-38.pyc | Bin 0 -> 11021 bytes .../__pycache__/scripts.cpython-38.pyc | Bin 0 -> 10803 bytes .../distlib/__pycache__/util.cpython-38.pyc | Bin 0 -> 48154 bytes .../__pycache__/version.cpython-38.pyc | Bin 0 -> 20380 bytes .../distlib/__pycache__/wheel.cpython-38.pyc | Bin 0 -> 25567 bytes .../pip/_vendor/distlib/_backport/__init__.py | 6 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 496 bytes .../_backport/__pycache__/misc.cpython-38.pyc | Bin 0 -> 1107 bytes .../__pycache__/shutil.cpython-38.pyc | Bin 0 -> 21500 bytes .../__pycache__/sysconfig.cpython-38.pyc | Bin 0 -> 15899 bytes .../__pycache__/tarfile.cpython-38.pyc | Bin 0 -> 62756 bytes .../pip/_vendor/distlib/_backport/misc.py | 41 + .../pip/_vendor/distlib/_backport/shutil.py | 761 ++ .../_vendor/distlib/_backport/sysconfig.cfg | 84 + .../_vendor/distlib/_backport/sysconfig.py | 788 ++ .../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 | 1295 +++ .../pip/_vendor/distlib/manifest.py | 393 + .../pip/_vendor/distlib/markers.py | 131 + .../pip/_vendor/distlib/metadata.py | 1096 +++ .../pip/_vendor/distlib/resources.py | 355 + .../pip/_vendor/distlib/scripts.py | 403 + .../site-packages/pip/_vendor/distlib/t32.exe | Bin 0 -> 92672 bytes .../site-packages/pip/_vendor/distlib/t64.exe | Bin 0 -> 102912 bytes .../site-packages/pip/_vendor/distlib/util.py | 1760 ++++ .../pip/_vendor/distlib/version.py | 736 ++ .../site-packages/pip/_vendor/distlib/w32.exe | Bin 0 -> 89088 bytes .../site-packages/pip/_vendor/distlib/w64.exe | Bin 0 -> 99840 bytes .../pip/_vendor/distlib/wheel.py | 1004 ++ .../site-packages/pip/_vendor/distro.py | 1216 +++ .../pip/_vendor/html5lib/__init__.py | 35 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 1329 bytes .../__pycache__/_ihatexml.cpython-38.pyc | Bin 0 -> 13801 bytes .../__pycache__/_inputstream.cpython-38.pyc | Bin 0 -> 21953 bytes .../__pycache__/_tokenizer.cpython-38.pyc | Bin 0 -> 39671 bytes .../__pycache__/_utils.cpython-38.pyc | Bin 0 -> 3359 bytes .../__pycache__/constants.cpython-38.pyc | Bin 0 -> 66366 bytes .../__pycache__/html5parser.cpython-38.pyc | Bin 0 -> 95188 bytes .../__pycache__/serializer.cpython-38.pyc | Bin 0 -> 10837 bytes .../pip/_vendor/html5lib/_ihatexml.py | 288 + .../pip/_vendor/html5lib/_inputstream.py | 923 ++ .../pip/_vendor/html5lib/_tokenizer.py | 1721 ++++ .../pip/_vendor/html5lib/_trie/__init__.py | 14 + .../_trie/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 438 bytes .../_trie/__pycache__/_base.cpython-38.pyc | Bin 0 -> 1617 bytes .../_trie/__pycache__/datrie.cpython-38.pyc | Bin 0 -> 2050 bytes .../_trie/__pycache__/py.cpython-38.pyc | Bin 0 -> 2274 bytes .../pip/_vendor/html5lib/_trie/_base.py | 40 + .../pip/_vendor/html5lib/_trie/datrie.py | 44 + .../pip/_vendor/html5lib/_trie/py.py | 67 + .../pip/_vendor/html5lib/_utils.py | 124 + .../pip/_vendor/html5lib/constants.py | 2947 ++++++ .../pip/_vendor/html5lib/filters/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 213 bytes .../alphabeticalattributes.cpython-38.pyc | Bin 0 -> 1335 bytes .../filters/__pycache__/base.cpython-38.pyc | Bin 0 -> 883 bytes .../inject_meta_charset.cpython-38.pyc | Bin 0 -> 1889 bytes .../filters/__pycache__/lint.cpython-38.pyc | Bin 0 -> 2647 bytes .../__pycache__/optionaltags.cpython-38.pyc | Bin 0 -> 2776 bytes .../__pycache__/sanitizer.cpython-38.pyc | Bin 0 -> 16318 bytes .../__pycache__/whitespace.cpython-38.pyc | Bin 0 -> 1381 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 | 896 ++ .../_vendor/html5lib/filters/whitespace.py | 38 + .../pip/_vendor/html5lib/html5parser.py | 2791 ++++++ .../pip/_vendor/html5lib/serializer.py | 409 + .../_vendor/html5lib/treeadapters/__init__.py | 30 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 952 bytes .../__pycache__/genshi.cpython-38.pyc | Bin 0 -> 1558 bytes .../__pycache__/sax.cpython-38.pyc | Bin 0 -> 1493 bytes .../_vendor/html5lib/treeadapters/genshi.py | 54 + .../pip/_vendor/html5lib/treeadapters/sax.py | 50 + .../_vendor/html5lib/treebuilders/__init__.py | 88 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 3337 bytes .../__pycache__/base.cpython-38.pyc | Bin 0 -> 11363 bytes .../__pycache__/dom.cpython-38.pyc | Bin 0 -> 9470 bytes .../__pycache__/etree.cpython-38.pyc | Bin 0 -> 11857 bytes .../__pycache__/etree_lxml.cpython-38.pyc | Bin 0 -> 11825 bytes .../pip/_vendor/html5lib/treebuilders/base.py | 417 + .../pip/_vendor/html5lib/treebuilders/dom.py | 239 + .../_vendor/html5lib/treebuilders/etree.py | 340 + .../html5lib/treebuilders/etree_lxml.py | 366 + .../_vendor/html5lib/treewalkers/__init__.py | 154 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 4018 bytes .../__pycache__/base.cpython-38.pyc | Bin 0 -> 7018 bytes .../__pycache__/dom.cpython-38.pyc | Bin 0 -> 1747 bytes .../__pycache__/etree.cpython-38.pyc | Bin 0 -> 3532 bytes .../__pycache__/etree_lxml.cpython-38.pyc | Bin 0 -> 6631 bytes .../__pycache__/genshi.cpython-38.pyc | Bin 0 -> 1905 bytes .../pip/_vendor/html5lib/treewalkers/base.py | 252 + .../pip/_vendor/html5lib/treewalkers/dom.py | 43 + .../pip/_vendor/html5lib/treewalkers/etree.py | 130 + .../html5lib/treewalkers/etree_lxml.py | 213 + .../_vendor/html5lib/treewalkers/genshi.py | 69 + .../pip/_vendor/idna/__init__.py | 2 + .../idna/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 270 bytes .../idna/__pycache__/codec.cpython-38.pyc | Bin 0 -> 2924 bytes .../idna/__pycache__/compat.cpython-38.pyc | Bin 0 -> 642 bytes .../idna/__pycache__/core.cpython-38.pyc | Bin 0 -> 9058 bytes .../idna/__pycache__/idnadata.cpython-38.pyc | Bin 0 -> 21394 bytes .../idna/__pycache__/intranges.cpython-38.pyc | Bin 0 -> 1822 bytes .../__pycache__/package_data.cpython-38.pyc | Bin 0 -> 224 bytes .../idna/__pycache__/uts46data.cpython-38.pyc | Bin 0 -> 174197 bytes .../site-packages/pip/_vendor/idna/codec.py | 118 + .../site-packages/pip/_vendor/idna/compat.py | 12 + .../site-packages/pip/_vendor/idna/core.py | 396 + .../pip/_vendor/idna/idnadata.py | 1979 ++++ .../pip/_vendor/idna/intranges.py | 53 + .../pip/_vendor/idna/package_data.py | 2 + .../pip/_vendor/idna/uts46data.py | 8205 +++++++++++++++++ .../site-packages/pip/_vendor/ipaddress.py | 2419 +++++ .../pip/_vendor/lockfile/__init__.py | 347 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 9817 bytes .../__pycache__/linklockfile.cpython-38.pyc | Bin 0 -> 2325 bytes .../__pycache__/mkdirlockfile.cpython-38.pyc | Bin 0 -> 2693 bytes .../__pycache__/pidlockfile.cpython-38.pyc | Bin 0 -> 4897 bytes .../__pycache__/sqlitelockfile.cpython-38.pyc | Bin 0 -> 3752 bytes .../symlinklockfile.cpython-38.pyc | Bin 0 -> 2214 bytes .../pip/_vendor/lockfile/linklockfile.py | 73 + .../pip/_vendor/lockfile/mkdirlockfile.py | 84 + .../pip/_vendor/lockfile/pidlockfile.py | 190 + .../pip/_vendor/lockfile/sqlitelockfile.py | 156 + .../pip/_vendor/lockfile/symlinklockfile.py | 70 + .../pip/_vendor/msgpack/__init__.py | 65 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 2042 bytes .../__pycache__/_version.cpython-38.pyc | Bin 0 -> 231 bytes .../__pycache__/exceptions.cpython-38.pyc | Bin 0 -> 1865 bytes .../__pycache__/fallback.cpython-38.pyc | Bin 0 -> 26361 bytes .../pip/_vendor/msgpack/_version.py | 1 + .../pip/_vendor/msgpack/exceptions.py | 48 + .../pip/_vendor/msgpack/fallback.py | 1027 +++ .../pip/_vendor/packaging/__about__.py | 27 + .../pip/_vendor/packaging/__init__.py | 26 + .../__pycache__/__about__.cpython-38.pyc | Bin 0 -> 746 bytes .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 584 bytes .../__pycache__/_compat.cpython-38.pyc | Bin 0 -> 1020 bytes .../__pycache__/_structures.cpython-38.pyc | Bin 0 -> 2802 bytes .../__pycache__/markers.cpython-38.pyc | Bin 0 -> 8927 bytes .../__pycache__/requirements.cpython-38.pyc | Bin 0 -> 4025 bytes .../__pycache__/specifiers.cpython-38.pyc | Bin 0 -> 19776 bytes .../__pycache__/utils.cpython-38.pyc | Bin 0 -> 1477 bytes .../__pycache__/version.cpython-38.pyc | Bin 0 -> 12107 bytes .../pip/_vendor/packaging/_compat.py | 31 + .../pip/_vendor/packaging/_structures.py | 68 + .../pip/_vendor/packaging/markers.py | 296 + .../pip/_vendor/packaging/requirements.py | 138 + .../pip/_vendor/packaging/specifiers.py | 749 ++ .../pip/_vendor/packaging/utils.py | 57 + .../pip/_vendor/packaging/version.py | 420 + .../pip/_vendor/pep517/__init__.py | 4 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 295 bytes .../__pycache__/_in_process.cpython-38.pyc | Bin 0 -> 5553 bytes .../pep517/__pycache__/build.cpython-38.pyc | Bin 0 -> 2809 bytes .../pep517/__pycache__/check.cpython-38.pyc | Bin 0 -> 4778 bytes .../__pycache__/colorlog.cpython-38.pyc | Bin 0 -> 2965 bytes .../pep517/__pycache__/compat.cpython-38.pyc | Bin 0 -> 1017 bytes .../__pycache__/envbuild.cpython-38.pyc | Bin 0 -> 4297 bytes .../__pycache__/wrappers.cpython-38.pyc | Bin 0 -> 5557 bytes .../pip/_vendor/pep517/_in_process.py | 207 + .../site-packages/pip/_vendor/pep517/build.py | 108 + .../site-packages/pip/_vendor/pep517/check.py | 202 + .../pip/_vendor/pep517/colorlog.py | 115 + .../pip/_vendor/pep517/compat.py | 23 + .../pip/_vendor/pep517/envbuild.py | 158 + .../pip/_vendor/pep517/wrappers.py | 163 + .../pip/_vendor/pkg_resources/__init__.py | 3286 +++++++ .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 100197 bytes .../__pycache__/py31compat.cpython-38.pyc | Bin 0 -> 661 bytes .../pip/_vendor/pkg_resources/py31compat.py | 23 + .../pip/_vendor/progress/__init__.py | 177 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 5630 bytes .../progress/__pycache__/bar.cpython-38.pyc | Bin 0 -> 2654 bytes .../__pycache__/counter.cpython-38.pyc | Bin 0 -> 1486 bytes .../__pycache__/spinner.cpython-38.pyc | Bin 0 -> 1413 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 | 6493 +++++++++++++ .../pip/_vendor/pytoml/__init__.py | 4 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 389 bytes .../pytoml/__pycache__/core.cpython-38.pyc | Bin 0 -> 966 bytes .../pytoml/__pycache__/parser.cpython-38.pyc | Bin 0 -> 10163 bytes .../pytoml/__pycache__/test.cpython-38.pyc | Bin 0 -> 1268 bytes .../pytoml/__pycache__/utils.cpython-38.pyc | Bin 0 -> 2178 bytes .../pytoml/__pycache__/writer.cpython-38.pyc | Bin 0 -> 3609 bytes .../site-packages/pip/_vendor/pytoml/core.py | 13 + .../pip/_vendor/pytoml/parser.py | 341 + .../site-packages/pip/_vendor/pytoml/test.py | 30 + .../site-packages/pip/_vendor/pytoml/utils.py | 67 + .../pip/_vendor/pytoml/writer.py | 106 + .../pip/_vendor/requests/__init__.py | 133 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 3516 bytes .../__pycache__/__version__.cpython-38.pyc | Bin 0 -> 563 bytes .../_internal_utils.cpython-38.pyc | Bin 0 -> 1333 bytes .../__pycache__/adapters.cpython-38.pyc | Bin 0 -> 16996 bytes .../requests/__pycache__/api.cpython-38.pyc | Bin 0 -> 6520 bytes .../requests/__pycache__/auth.cpython-38.pyc | Bin 0 -> 8342 bytes .../requests/__pycache__/certs.cpython-38.pyc | Bin 0 -> 646 bytes .../__pycache__/compat.cpython-38.pyc | Bin 0 -> 1625 bytes .../__pycache__/cookies.cpython-38.pyc | Bin 0 -> 18847 bytes .../__pycache__/exceptions.cpython-38.pyc | Bin 0 -> 5257 bytes .../requests/__pycache__/help.cpython-38.pyc | Bin 0 -> 2743 bytes .../requests/__pycache__/hooks.cpython-38.pyc | Bin 0 -> 1005 bytes .../__pycache__/models.cpython-38.pyc | Bin 0 -> 23941 bytes .../__pycache__/packages.cpython-38.pyc | Bin 0 -> 515 bytes .../__pycache__/sessions.cpython-38.pyc | Bin 0 -> 19555 bytes .../__pycache__/status_codes.cpython-38.pyc | Bin 0 -> 4201 bytes .../__pycache__/structures.cpython-38.pyc | Bin 0 -> 4443 bytes .../requests/__pycache__/utils.cpython-38.pyc | Bin 0 -> 22212 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 | 158 + .../pip/_vendor/requests/auth.py | 305 + .../pip/_vendor/requests/certs.py | 18 + .../pip/_vendor/requests/compat.py | 74 + .../pip/_vendor/requests/cookies.py | 549 ++ .../pip/_vendor/requests/exceptions.py | 126 + .../pip/_vendor/requests/help.py | 119 + .../pip/_vendor/requests/hooks.py | 34 + .../pip/_vendor/requests/models.py | 953 ++ .../pip/_vendor/requests/packages.py | 16 + .../pip/_vendor/requests/sessions.py | 770 ++ .../pip/_vendor/requests/status_codes.py | 120 + .../pip/_vendor/requests/structures.py | 103 + .../pip/_vendor/requests/utils.py | 977 ++ .../site-packages/pip/_vendor/retrying.py | 267 + .../site-packages/pip/_vendor/six.py | 952 ++ .../pip/_vendor/urllib3/__init__.py | 91 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 2138 bytes .../__pycache__/_collections.cpython-38.pyc | Bin 0 -> 10788 bytes .../__pycache__/connection.cpython-38.pyc | Bin 0 -> 10581 bytes .../__pycache__/connectionpool.cpython-38.pyc | Bin 0 -> 23893 bytes .../__pycache__/exceptions.cpython-38.pyc | Bin 0 -> 10081 bytes .../urllib3/__pycache__/fields.cpython-38.pyc | Bin 0 -> 8146 bytes .../__pycache__/filepost.cpython-38.pyc | Bin 0 -> 2783 bytes .../__pycache__/poolmanager.cpython-38.pyc | Bin 0 -> 12959 bytes .../__pycache__/request.cpython-38.pyc | Bin 0 -> 5637 bytes .../__pycache__/response.cpython-38.pyc | Bin 0 -> 20148 bytes .../pip/_vendor/urllib3/_collections.py | 329 + .../pip/_vendor/urllib3/connection.py | 417 + .../pip/_vendor/urllib3/connectionpool.py | 897 ++ .../pip/_vendor/urllib3/contrib/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 212 bytes .../_appengine_environ.cpython-38.pyc | Bin 0 -> 1140 bytes .../__pycache__/appengine.cpython-38.pyc | Bin 0 -> 8453 bytes .../__pycache__/ntlmpool.cpython-38.pyc | Bin 0 -> 3279 bytes .../__pycache__/pyopenssl.cpython-38.pyc | Bin 0 -> 14984 bytes .../securetransport.cpython-38.pyc | Bin 0 -> 19912 bytes .../contrib/__pycache__/socks.cpython-38.pyc | Bin 0 -> 5598 bytes .../urllib3/contrib/_appengine_environ.py | 30 + .../contrib/_securetransport/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 229 bytes .../__pycache__/bindings.cpython-38.pyc | Bin 0 -> 10384 bytes .../__pycache__/low_level.cpython-38.pyc | Bin 0 -> 7581 bytes .../contrib/_securetransport/bindings.py | 593 ++ .../contrib/_securetransport/low_level.py | 346 + .../pip/_vendor/urllib3/contrib/appengine.py | 289 + .../pip/_vendor/urllib3/contrib/ntlmpool.py | 111 + .../pip/_vendor/urllib3/contrib/pyopenssl.py | 485 + .../urllib3/contrib/securetransport.py | 853 ++ .../pip/_vendor/urllib3/contrib/socks.py | 205 + .../pip/_vendor/urllib3/exceptions.py | 246 + .../pip/_vendor/urllib3/fields.py | 272 + .../pip/_vendor/urllib3/filepost.py | 98 + .../pip/_vendor/urllib3/packages/__init__.py | 5 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 326 bytes .../packages/__pycache__/six.cpython-38.pyc | Bin 0 -> 24486 bytes .../urllib3/packages/backports/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 223 bytes .../__pycache__/makefile.cpython-38.pyc | Bin 0 -> 1327 bytes .../urllib3/packages/backports/makefile.py | 53 + .../urllib3/packages/rfc3986/__init__.py | 56 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 1060 bytes .../rfc3986/__pycache__/_mixin.cpython-38.pyc | Bin 0 -> 10661 bytes .../__pycache__/abnf_regexp.cpython-38.pyc | Bin 0 -> 4164 bytes .../rfc3986/__pycache__/api.cpython-38.pyc | Bin 0 -> 3725 bytes .../__pycache__/builder.cpython-38.pyc | Bin 0 -> 8167 bytes .../rfc3986/__pycache__/compat.cpython-38.pyc | Bin 0 -> 1162 bytes .../__pycache__/exceptions.cpython-38.pyc | Bin 0 -> 4801 bytes .../rfc3986/__pycache__/iri.cpython-38.pyc | Bin 0 -> 4516 bytes .../rfc3986/__pycache__/misc.cpython-38.pyc | Bin 0 -> 2281 bytes .../__pycache__/normalizers.cpython-38.pyc | Bin 0 -> 3594 bytes .../__pycache__/parseresult.cpython-38.pyc | Bin 0 -> 9908 bytes .../rfc3986/__pycache__/uri.cpython-38.pyc | Bin 0 -> 4289 bytes .../__pycache__/validators.cpython-38.pyc | Bin 0 -> 13049 bytes .../urllib3/packages/rfc3986/_mixin.py | 353 + .../urllib3/packages/rfc3986/abnf_regexp.py | 267 + .../_vendor/urllib3/packages/rfc3986/api.py | 106 + .../urllib3/packages/rfc3986/builder.py | 298 + .../urllib3/packages/rfc3986/compat.py | 54 + .../urllib3/packages/rfc3986/exceptions.py | 118 + .../_vendor/urllib3/packages/rfc3986/iri.py | 147 + .../_vendor/urllib3/packages/rfc3986/misc.py | 124 + .../urllib3/packages/rfc3986/normalizers.py | 167 + .../urllib3/packages/rfc3986/parseresult.py | 385 + .../_vendor/urllib3/packages/rfc3986/uri.py | 153 + .../urllib3/packages/rfc3986/validators.py | 450 + .../pip/_vendor/urllib3/packages/six.py | 868 ++ .../packages/ssl_match_hostname/__init__.py | 19 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 567 bytes .../_implementation.cpython-38.pyc | Bin 0 -> 3340 bytes .../ssl_match_hostname/_implementation.py | 156 + .../pip/_vendor/urllib3/poolmanager.py | 455 + .../pip/_vendor/urllib3/request.py | 150 + .../pip/_vendor/urllib3/response.py | 760 ++ .../pip/_vendor/urllib3/util/__init__.py | 56 + .../util/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 1032 bytes .../__pycache__/connection.cpython-38.pyc | Bin 0 -> 3205 bytes .../util/__pycache__/queue.cpython-38.pyc | Bin 0 -> 1077 bytes .../util/__pycache__/request.cpython-38.pyc | Bin 0 -> 3359 bytes .../util/__pycache__/response.cpython-38.pyc | Bin 0 -> 2002 bytes .../util/__pycache__/retry.cpython-38.pyc | Bin 0 -> 12953 bytes .../util/__pycache__/ssl_.cpython-38.pyc | Bin 0 -> 9831 bytes .../util/__pycache__/timeout.cpython-38.pyc | Bin 0 -> 8833 bytes .../util/__pycache__/url.cpython-38.pyc | Bin 0 -> 7898 bytes .../util/__pycache__/wait.cpython-38.pyc | Bin 0 -> 3126 bytes .../pip/_vendor/urllib3/util/connection.py | 134 + .../pip/_vendor/urllib3/util/queue.py | 21 + .../pip/_vendor/urllib3/util/request.py | 125 + .../pip/_vendor/urllib3/util/response.py | 87 + .../pip/_vendor/urllib3/util/retry.py | 412 + .../pip/_vendor/urllib3/util/ssl_.py | 392 + .../pip/_vendor/urllib3/util/timeout.py | 243 + .../pip/_vendor/urllib3/util/url.py | 289 + .../pip/_vendor/urllib3/util/wait.py | 150 + .../pip/_vendor/webencodings/__init__.py | 342 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 9752 bytes .../__pycache__/labels.cpython-38.pyc | Bin 0 -> 3850 bytes .../__pycache__/mklabels.cpython-38.pyc | Bin 0 -> 1946 bytes .../__pycache__/tests.cpython-38.pyc | Bin 0 -> 5112 bytes .../__pycache__/x_user_defined.cpython-38.pyc | Bin 0 -> 2680 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 + .../site-packages/pkg_resources/__init__.py | 3295 +++++++ .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 100394 bytes .../__pycache__/py31compat.cpython-38.pyc | Bin 0 -> 656 bytes .../pkg_resources/_vendor/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 213 bytes .../__pycache__/appdirs.cpython-38.pyc | Bin 0 -> 20566 bytes .../__pycache__/pyparsing.cpython-38.pyc | Bin 0 -> 201690 bytes .../_vendor/__pycache__/six.cpython-38.pyc | Bin 0 -> 24486 bytes .../pkg_resources/_vendor/appdirs.py | 608 ++ .../_vendor/packaging/__about__.py | 21 + .../_vendor/packaging/__init__.py | 14 + .../__pycache__/__about__.cpython-38.pyc | Bin 0 -> 763 bytes .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 601 bytes .../__pycache__/_compat.cpython-38.pyc | Bin 0 -> 1037 bytes .../__pycache__/_structures.cpython-38.pyc | Bin 0 -> 2819 bytes .../__pycache__/markers.cpython-38.pyc | Bin 0 -> 8975 bytes .../__pycache__/requirements.cpython-38.pyc | Bin 0 -> 3934 bytes .../__pycache__/specifiers.cpython-38.pyc | Bin 0 -> 19843 bytes .../__pycache__/utils.cpython-38.pyc | Bin 0 -> 522 bytes .../__pycache__/version.cpython-38.pyc | Bin 0 -> 10690 bytes .../_vendor/packaging/_compat.py | 30 + .../_vendor/packaging/_structures.py | 68 + .../_vendor/packaging/markers.py | 301 + .../_vendor/packaging/requirements.py | 127 + .../_vendor/packaging/specifiers.py | 774 ++ .../pkg_resources/_vendor/packaging/utils.py | 14 + .../_vendor/packaging/version.py | 393 + .../pkg_resources/_vendor/pyparsing.py | 5742 ++++++++++++ .../pkg_resources/_vendor/six.py | 868 ++ .../pkg_resources/extern/__init__.py | 73 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 2462 bytes .../site-packages/pkg_resources/py31compat.py | 23 + .../setuptools-41.2.0.dist-info/INSTALLER | 1 + .../setuptools-41.2.0.dist-info/LICENSE | 19 + .../setuptools-41.2.0.dist-info/METADATA | 77 + .../setuptools-41.2.0.dist-info/RECORD | 186 + .../setuptools-41.2.0.dist-info/WHEEL | 6 + .../dependency_links.txt | 2 + .../entry_points.txt | 65 + .../setuptools-41.2.0.dist-info/top_level.txt | 3 + .../setuptools-41.2.0.dist-info/zip-safe | 1 + .../site-packages/setuptools/__init__.py | 228 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 7824 bytes .../_deprecation_warning.cpython-38.pyc | Bin 0 -> 572 bytes .../__pycache__/archive_util.cpython-38.pyc | Bin 0 -> 5184 bytes .../__pycache__/build_meta.cpython-38.pyc | Bin 0 -> 8551 bytes .../__pycache__/config.cpython-38.pyc | Bin 0 -> 17832 bytes .../__pycache__/dep_util.cpython-38.pyc | Bin 0 -> 875 bytes .../__pycache__/depends.cpython-38.pyc | Bin 0 -> 5344 bytes .../__pycache__/dist.cpython-38.pyc | Bin 0 -> 42203 bytes .../__pycache__/extension.cpython-38.pyc | Bin 0 -> 2017 bytes .../__pycache__/glibc.cpython-38.pyc | Bin 0 -> 1586 bytes .../__pycache__/glob.cpython-38.pyc | Bin 0 -> 3789 bytes .../__pycache__/launch.cpython-38.pyc | Bin 0 -> 880 bytes .../__pycache__/lib2to3_ex.cpython-38.pyc | Bin 0 -> 2467 bytes .../__pycache__/monkey.cpython-38.pyc | Bin 0 -> 4700 bytes .../__pycache__/msvc.cpython-38.pyc | Bin 0 -> 34496 bytes .../__pycache__/namespaces.cpython-38.pyc | Bin 0 -> 3672 bytes .../__pycache__/package_index.cpython-38.pyc | Bin 0 -> 33017 bytes .../__pycache__/pep425tags.cpython-38.pyc | Bin 0 -> 7259 bytes .../__pycache__/py27compat.cpython-38.pyc | Bin 0 -> 840 bytes .../__pycache__/py31compat.cpython-38.pyc | Bin 0 -> 1247 bytes .../__pycache__/py33compat.cpython-38.pyc | Bin 0 -> 1464 bytes .../__pycache__/sandbox.cpython-38.pyc | Bin 0 -> 15592 bytes .../__pycache__/site-patch.cpython-38.pyc | Bin 0 -> 1530 bytes .../__pycache__/ssl_support.cpython-38.pyc | Bin 0 -> 6911 bytes .../__pycache__/unicode_utils.cpython-38.pyc | Bin 0 -> 1207 bytes .../__pycache__/version.cpython-38.pyc | Bin 0 -> 348 bytes .../__pycache__/wheel.cpython-38.pyc | Bin 0 -> 7110 bytes .../windows_support.cpython-38.pyc | Bin 0 -> 1045 bytes .../setuptools/_deprecation_warning.py | 7 + .../setuptools/_vendor/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 210 bytes .../__pycache__/pyparsing.cpython-38.pyc | Bin 0 -> 201687 bytes .../_vendor/__pycache__/six.cpython-38.pyc | Bin 0 -> 24483 bytes .../setuptools/_vendor/packaging/__about__.py | 21 + .../setuptools/_vendor/packaging/__init__.py | 14 + .../__pycache__/__about__.cpython-38.pyc | Bin 0 -> 760 bytes .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 598 bytes .../__pycache__/_compat.cpython-38.pyc | Bin 0 -> 1034 bytes .../__pycache__/_structures.cpython-38.pyc | Bin 0 -> 2816 bytes .../__pycache__/markers.cpython-38.pyc | Bin 0 -> 8969 bytes .../__pycache__/requirements.cpython-38.pyc | Bin 0 -> 3925 bytes .../__pycache__/specifiers.cpython-38.pyc | Bin 0 -> 19840 bytes .../__pycache__/utils.cpython-38.pyc | Bin 0 -> 519 bytes .../__pycache__/version.cpython-38.pyc | Bin 0 -> 10687 bytes .../setuptools/_vendor/packaging/_compat.py | 30 + .../_vendor/packaging/_structures.py | 68 + .../setuptools/_vendor/packaging/markers.py | 301 + .../_vendor/packaging/requirements.py | 127 + .../_vendor/packaging/specifiers.py | 774 ++ .../setuptools/_vendor/packaging/utils.py | 14 + .../setuptools/_vendor/packaging/version.py | 393 + .../setuptools/_vendor/pyparsing.py | 5742 ++++++++++++ .../site-packages/setuptools/_vendor/six.py | 868 ++ .../site-packages/setuptools/archive_util.py | 173 + .../site-packages/setuptools/build_meta.py | 257 + .../site-packages/setuptools/cli-32.exe | Bin 0 -> 65536 bytes .../site-packages/setuptools/cli-64.exe | Bin 0 -> 74752 bytes .../site-packages/setuptools/cli.exe | Bin 0 -> 65536 bytes .../setuptools/command/__init__.py | 18 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 794 bytes .../command/__pycache__/alias.cpython-38.pyc | Bin 0 -> 2448 bytes .../__pycache__/bdist_egg.cpython-38.pyc | Bin 0 -> 14234 bytes .../__pycache__/bdist_rpm.cpython-38.pyc | Bin 0 -> 1840 bytes .../__pycache__/bdist_wininst.cpython-38.pyc | Bin 0 -> 1010 bytes .../__pycache__/build_clib.cpython-38.pyc | Bin 0 -> 2493 bytes .../__pycache__/build_ext.cpython-38.pyc | Bin 0 -> 9951 bytes .../__pycache__/build_py.cpython-38.pyc | Bin 0 -> 8697 bytes .../__pycache__/develop.cpython-38.pyc | Bin 0 -> 6557 bytes .../__pycache__/dist_info.cpython-38.pyc | Bin 0 -> 1417 bytes .../__pycache__/easy_install.cpython-38.pyc | Bin 0 -> 65318 bytes .../__pycache__/egg_info.cpython-38.pyc | Bin 0 -> 21820 bytes .../__pycache__/install.cpython-38.pyc | Bin 0 -> 4047 bytes .../install_egg_info.cpython-38.pyc | Bin 0 -> 2459 bytes .../__pycache__/install_lib.cpython-38.pyc | Bin 0 -> 4180 bytes .../install_scripts.cpython-38.pyc | Bin 0 -> 2329 bytes .../__pycache__/py36compat.cpython-38.pyc | Bin 0 -> 4666 bytes .../__pycache__/register.cpython-38.pyc | Bin 0 -> 811 bytes .../command/__pycache__/rotate.cpython-38.pyc | Bin 0 -> 2576 bytes .../__pycache__/saveopts.cpython-38.pyc | Bin 0 -> 945 bytes .../command/__pycache__/sdist.cpython-38.pyc | Bin 0 -> 6863 bytes .../command/__pycache__/setopt.cpython-38.pyc | Bin 0 -> 4593 bytes .../command/__pycache__/test.cpython-38.pyc | Bin 0 -> 8296 bytes .../command/__pycache__/upload.cpython-38.pyc | Bin 0 -> 5259 bytes .../__pycache__/upload_docs.cpython-38.pyc | Bin 0 -> 6196 bytes .../site-packages/setuptools/command/alias.py | 80 + .../setuptools/command/bdist_egg.py | 502 + .../setuptools/command/bdist_rpm.py | 43 + .../setuptools/command/bdist_wininst.py | 21 + .../setuptools/command/build_clib.py | 98 + .../setuptools/command/build_ext.py | 327 + .../setuptools/command/build_py.py | 270 + .../setuptools/command/develop.py | 221 + .../setuptools/command/dist_info.py | 36 + .../setuptools/command/easy_install.py | 2342 +++++ .../setuptools/command/egg_info.py | 717 ++ .../setuptools/command/install.py | 125 + .../setuptools/command/install_egg_info.py | 62 + .../setuptools/command/install_lib.py | 121 + .../setuptools/command/install_scripts.py | 65 + .../setuptools/command/launcher manifest.xml | 15 + .../setuptools/command/py36compat.py | 136 + .../setuptools/command/register.py | 18 + .../setuptools/command/rotate.py | 66 + .../setuptools/command/saveopts.py | 22 + .../site-packages/setuptools/command/sdist.py | 221 + .../setuptools/command/setopt.py | 149 + .../site-packages/setuptools/command/test.py | 271 + .../setuptools/command/upload.py | 196 + .../setuptools/command/upload_docs.py | 206 + .../site-packages/setuptools/config.py | 656 ++ .../site-packages/setuptools/dep_util.py | 23 + .../site-packages/setuptools/depends.py | 186 + .../site-packages/setuptools/dist.py | 1280 +++ .../site-packages/setuptools/extension.py | 57 + .../setuptools/extern/__init__.py | 73 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 2463 bytes .../site-packages/setuptools/glibc.py | 86 + .../site-packages/setuptools/glob.py | 174 + .../site-packages/setuptools/gui-32.exe | Bin 0 -> 65536 bytes .../site-packages/setuptools/gui-64.exe | Bin 0 -> 75264 bytes .../site-packages/setuptools/gui.exe | Bin 0 -> 65536 bytes .../site-packages/setuptools/launch.py | 35 + .../site-packages/setuptools/lib2to3_ex.py | 62 + .../site-packages/setuptools/monkey.py | 179 + .../site-packages/setuptools/msvc.py | 1301 +++ .../site-packages/setuptools/namespaces.py | 107 + .../site-packages/setuptools/package_index.py | 1136 +++ .../site-packages/setuptools/pep425tags.py | 319 + .../site-packages/setuptools/py27compat.py | 28 + .../site-packages/setuptools/py31compat.py | 32 + .../site-packages/setuptools/py33compat.py | 59 + .../site-packages/setuptools/sandbox.py | 491 + .../setuptools/script (dev).tmpl | 6 + .../site-packages/setuptools/script.tmpl | 3 + .../site-packages/setuptools/site-patch.py | 74 + .../site-packages/setuptools/ssl_support.py | 260 + .../site-packages/setuptools/unicode_utils.py | 44 + .../site-packages/setuptools/version.py | 6 + .../site-packages/setuptools/wheel.py | 211 + .../setuptools/windows_support.py | 29 + Front-end/apis-env/pyvenv.cfg | 3 + Front-end/app.py | 72 + Front-end/config.py | 0 Front-end/request.py | 30 + Front-end/templates/createbook.html | 27 + Front-end/templates/home.html | 52 + Front-end/templates/index.html | 31 + Front-end/templates/search.html | 32 + .../bin/Debug/net5.0/MongoBookApis.dll | Bin 32768 -> 0 bytes .../bin/Debug/net5.0/ref/MongoBookApis.dll | Bin 15360 -> 0 bytes .../Debug/net5.0/MongoBookApis.assets.cache | Bin 7394 -> 0 bytes ...ngoBookApis.csproj.AssemblyReference.cache | Bin 138058 -> 0 bytes ...ngoBookApis.csproj.CoreCompileInputs.cache | 1 - .../obj/Debug/net5.0/MongoBookApis.dll | Bin 32768 -> 0 bytes .../obj/Debug/net5.0/ref/MongoBookApis.dll | Bin 15360 -> 0 bytes MongoBookApis/obj/project.assets.json | 701 -- MongoBookApis/obj/project.nuget.cache | 25 - 956 files changed, 155797 insertions(+), 1117 deletions(-) rename {MongoBookApis => Back-end/MongoBookApis}/.DS_Store (100%) rename {MongoBookApis => Back-end/MongoBookApis}/.vs/MongoBookApis/xs/UserPrefs.xml (64%) rename {MongoBookApis => Back-end/MongoBookApis}/.vs/MongoBookApis/xs/project-cache/MongoBookApis-Debug.json (58%) rename {MongoBookApis => Back-end/MongoBookApis}/Controllers/BooksController.cs (94%) rename {MongoBookApis => Back-end/MongoBookApis}/Dtos/BookDto.cs (100%) rename {MongoBookApis => Back-end/MongoBookApis}/Dtos/CreateBookDto.cs (100%) rename {MongoBookApis => Back-end/MongoBookApis}/Models/Book.cs (100%) rename {MongoBookApis => Back-end/MongoBookApis}/Models/OwnerClass.cs (100%) rename {MongoBookApis => Back-end/MongoBookApis}/MongoBookApis.csproj (81%) rename {MongoBookApis => Back-end/MongoBookApis}/MongoBookApis.sln (100%) rename {MongoBookApis => Back-end/MongoBookApis}/MongoDbSettings/MongoDbSettings.cs (100%) rename {MongoBookApis => Back-end/MongoBookApis}/Program.cs (100%) rename {MongoBookApis => Back-end/MongoBookApis}/Properties/launchSettings.json (100%) rename {MongoBookApis => Back-end/MongoBookApis}/Repositories/.DS_Store (100%) rename {MongoBookApis => Back-end/MongoBookApis}/Repositories/Extensions.cs (100%) rename {MongoBookApis => Back-end/MongoBookApis}/Repositories/IBooksRepository.cs (100%) rename {MongoBookApis => Back-end/MongoBookApis}/Repositories/MongoDbBooksRepository.cs (96%) rename {MongoBookApis => Back-end/MongoBookApis}/Startup.cs (82%) rename {MongoBookApis => Back-end/MongoBookApis}/appsettings.Development.json (100%) rename {MongoBookApis => Back-end/MongoBookApis}/appsettings.json (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/DnsClient.dll (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/Microsoft.OpenApi.dll (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/MongoBookApis.deps.json (58%) create mode 100644 Back-end/MongoBookApis/bin/Debug/net5.0/MongoBookApis.dll rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/MongoBookApis.pdb (69%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/MongoBookApis.runtimeconfig.dev.json (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/MongoBookApis.runtimeconfig.json (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/MongoDB.Bson.dll (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/MongoDB.Driver.Core.dll (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/MongoDB.Driver.dll (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/MongoDB.Libmongocrypt.dll (100%) create mode 100755 Back-end/MongoBookApis/bin/Debug/net5.0/Newtonsoft.Json.Bson.dll create mode 100755 Back-end/MongoBookApis/bin/Debug/net5.0/Newtonsoft.Json.dll rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/SharpCompress.dll (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/Swashbuckle.AspNetCore.Swagger.dll (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/Swashbuckle.AspNetCore.SwaggerGen.dll (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/Swashbuckle.AspNetCore.SwaggerUI.dll (100%) create mode 100755 Back-end/MongoBookApis/bin/Debug/net5.0/System.Net.Http.Formatting.dll create mode 100755 Back-end/MongoBookApis/bin/Debug/net5.0/System.Web.Cors.dll create mode 100755 Back-end/MongoBookApis/bin/Debug/net5.0/System.Web.Http.Cors.dll create mode 100755 Back-end/MongoBookApis/bin/Debug/net5.0/System.Web.Http.dll rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/appsettings.Development.json (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/appsettings.json (100%) create mode 100644 Back-end/MongoBookApis/bin/Debug/net5.0/ref/MongoBookApis.dll rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/runtimes/linux/native/libmongocrypt.so (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/runtimes/osx/native/libmongocrypt.dylib (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/runtimes/win/native/libzstd.dll (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/runtimes/win/native/mongocrypt.dll (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/runtimes/win/native/snappy32.dll (100%) rename {MongoBookApis => Back-end/MongoBookApis}/bin/Debug/net5.0/runtimes/win/native/snappy64.dll (100%) rename {MongoBookApis => Back-end/MongoBookApis}/obj/Debug/net5.0/.NETCoreApp,Version=v5.0.AssemblyAttributes.cs (100%) rename {MongoBookApis => Back-end/MongoBookApis}/obj/Debug/net5.0/MongoBookApis.AssemblyInfo.cs (100%) rename {MongoBookApis => Back-end/MongoBookApis}/obj/Debug/net5.0/MongoBookApis.AssemblyInfoInputs.cache (100%) rename {MongoBookApis => Back-end/MongoBookApis}/obj/Debug/net5.0/MongoBookApis.GeneratedMSBuildEditorConfig.editorconfig (100%) rename {MongoBookApis => Back-end/MongoBookApis}/obj/Debug/net5.0/MongoBookApis.MvcApplicationPartsAssemblyInfo.cache (100%) rename {MongoBookApis => Back-end/MongoBookApis}/obj/Debug/net5.0/MongoBookApis.MvcApplicationPartsAssemblyInfo.cs (100%) rename {MongoBookApis => Back-end/MongoBookApis}/obj/Debug/net5.0/MongoBookApis.RazorTargetAssemblyInfo.cache (100%) create mode 100644 Back-end/MongoBookApis/obj/Debug/net5.0/MongoBookApis.assets.cache create mode 100644 Back-end/MongoBookApis/obj/Debug/net5.0/MongoBookApis.csproj.AssemblyReference.cache rename {MongoBookApis => Back-end/MongoBookApis}/obj/Debug/net5.0/MongoBookApis.csproj.CopyComplete (100%) create mode 100644 Back-end/MongoBookApis/obj/Debug/net5.0/MongoBookApis.csproj.CoreCompileInputs.cache rename {MongoBookApis => Back-end/MongoBookApis}/obj/Debug/net5.0/MongoBookApis.csproj.FileListAbsolute.txt (94%) create mode 100644 Back-end/MongoBookApis/obj/Debug/net5.0/MongoBookApis.dll rename {MongoBookApis => Back-end/MongoBookApis}/obj/Debug/net5.0/MongoBookApis.genruntimeconfig.cache (100%) rename {MongoBookApis => Back-end/MongoBookApis}/obj/Debug/net5.0/MongoBookApis.pdb (69%) create mode 100644 Back-end/MongoBookApis/obj/Debug/net5.0/ref/MongoBookApis.dll rename {MongoBookApis => Back-end/MongoBookApis}/obj/Debug/net5.0/staticwebassets/MongoBookApis.StaticWebAssets.Manifest.cache (100%) rename {MongoBookApis => Back-end/MongoBookApis}/obj/Debug/net5.0/staticwebassets/MongoBookApis.StaticWebAssets.xml (100%) rename {MongoBookApis => Back-end/MongoBookApis}/obj/MongoBookApis.csproj.nuget.dgspec.json (94%) rename {MongoBookApis => Back-end/MongoBookApis}/obj/MongoBookApis.csproj.nuget.g.props (93%) rename {MongoBookApis => Back-end/MongoBookApis}/obj/MongoBookApis.csproj.nuget.g.targets (100%) create mode 100644 Back-end/MongoBookApis/obj/project.assets.json create mode 100644 Back-end/MongoBookApis/obj/project.nuget.cache create mode 100644 Front-end/.DS_Store create mode 100644 Front-end/Config/Config.py create mode 100644 Front-end/Models/BookModel.py create mode 100644 Front-end/__pycache__/app.cpython-38.pyc create mode 100644 Front-end/apis-env/.DS_Store create mode 100644 Front-end/apis-env/bin/Activate.ps1 create mode 100644 Front-end/apis-env/bin/activate create mode 100644 Front-end/apis-env/bin/activate.csh create mode 100644 Front-end/apis-env/bin/activate.fish create mode 100755 Front-end/apis-env/bin/easy_install create mode 100755 Front-end/apis-env/bin/easy_install-3.8 create mode 100755 Front-end/apis-env/bin/pip create mode 100755 Front-end/apis-env/bin/pip3 create mode 100755 Front-end/apis-env/bin/pip3.8 create mode 120000 Front-end/apis-env/bin/python create mode 120000 Front-end/apis-env/bin/python3 create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/__pycache__/easy_install.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/easy_install.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/INSTALLER create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/LICENSE.txt create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/METADATA create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/RECORD create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/WHEEL create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/entry_points.txt create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/top_level.txt create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/__main__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/__pycache__/__main__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/build_env.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/cache.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/configuration.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/download.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/exceptions.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/index.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/legacy_resolve.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/locations.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/pep425tags.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/pyproject.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/wheel.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/build_env.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cache.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/parser.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/autocompletion.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/base_command.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/cmdoptions.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/main_parser.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/parser.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/status_codes.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/check.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/completion.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/debug.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/download.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/hash.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/help.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/install.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/list.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/search.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/show.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/check.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/completion.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/configuration.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/debug.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/download.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/freeze.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/hash.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/help.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/install.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/list.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/search.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/show.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/uninstall.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/wheel.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/configuration.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/base.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/installed.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/source.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/wheel.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/base.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/installed.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/source.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/wheel.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/download.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/exceptions.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/index.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/legacy_resolve.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/locations.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/candidate.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/format_control.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/index.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/link.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/selection_prefs.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/target_python.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/candidate.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/format_control.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/index.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/link.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/search_scope.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/selection_prefs.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/target_python.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/check.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/check.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/freeze.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/prepare.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/pep425tags.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/pyproject.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/constructors.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_file.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_install.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_set.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_tracker.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_uninstall.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/constructors.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_file.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_install.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_set.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_tracker.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_uninstall.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/appdirs.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/hashes.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/logging.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/marker_files.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/misc.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/models.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/outdated.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/typing.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/ui.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/appdirs.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/deprecation.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/encoding.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/filesystem.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/glibc.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/hashes.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/logging.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/marker_files.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/misc.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/models.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/outdated.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/packaging.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/setuptools_build.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/temp_dir.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/typing.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/ui.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/virtualenv.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/git.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/bazaar.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/git.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/mercurial.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/subversion.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/versioncontrol.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/wheel.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/appdirs.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/distro.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/ipaddress.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/pyparsing.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/retrying.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/six.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/appdirs.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/cache.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/controller.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/serialize.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/_cmd.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/adapter.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/cache.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/controller.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/filewrapper.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/heuristics.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/serialize.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/wrapper.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__main__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__pycache__/__main__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/cacert.pem create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/core.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/escprober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/euckrprober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/gb2312freq.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/hebrewprober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/jpcntx.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langcyrillicmodel.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/latin1prober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/mbcssm.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/sjisprober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/universaldetector.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/utf8prober.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/version.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/big5freq.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/big5prober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/chardistribution.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/charsetgroupprober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/charsetprober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cli/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cli/chardetect.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/codingstatemachine.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cp949prober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/enums.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/escprober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/escsm.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/eucjpprober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euckrfreq.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euckrprober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euctwfreq.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euctwprober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/gb2312freq.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/gb2312prober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/hebrewprober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/jisfreq.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/jpcntx.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langbulgarianmodel.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langcyrillicmodel.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langgreekmodel.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langhebrewmodel.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langhungarianmodel.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langthaimodel.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langturkishmodel.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/latin1prober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/mbcharsetprober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/mbcsgroupprober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/mbcssm.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/sbcharsetprober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/sbcsgroupprober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/sjisprober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/universaldetector.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/utf8prober.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/version.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/ansi.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/ansitowin32.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/ansi.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/ansitowin32.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/initialise.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/win32.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/winterm.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/database.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/index.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/locators.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/manifest.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/markers.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/metadata.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/resources.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/scripts.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/util.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/version.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/wheel.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__pycache__/misc.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__pycache__/shutil.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__pycache__/sysconfig.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__pycache__/tarfile.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/misc.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/shutil.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/sysconfig.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/tarfile.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/database.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/index.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/locators.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/manifest.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/markers.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/metadata.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/resources.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/scripts.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/t32.exe create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/t64.exe create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/util.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/version.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/w32.exe create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/w64.exe create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/wheel.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distro.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/_ihatexml.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/_inputstream.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/_tokenizer.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/_utils.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/constants.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/html5parser.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/serializer.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_ihatexml.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_inputstream.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_tokenizer.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__pycache__/_base.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__pycache__/datrie.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__pycache__/py.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/_base.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/datrie.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/py.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_utils.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/constants.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/alphabeticalattributes.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/base.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/inject_meta_charset.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/lint.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/optionaltags.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/sanitizer.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/whitespace.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/base.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/lint.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/optionaltags.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/sanitizer.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/whitespace.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/html5parser.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/serializer.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/genshi.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/sax.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/sax.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/base.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/dom.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree_lxml.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/base.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/dom.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/etree.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/base.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/dom.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree_lxml.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/genshi.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/base.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/dom.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/etree.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/codec.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/core.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/idnadata.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/intranges.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/package_data.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/uts46data.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/codec.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/core.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/idnadata.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/intranges.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/package_data.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/uts46data.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/ipaddress.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/linklockfile.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/mkdirlockfile.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/pidlockfile.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/sqlitelockfile.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/symlinklockfile.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/linklockfile.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/mkdirlockfile.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/pidlockfile.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/sqlitelockfile.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/symlinklockfile.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__pycache__/_version.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__pycache__/exceptions.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__pycache__/fallback.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/_version.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/exceptions.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/fallback.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__about__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/_compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/_structures.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/markers.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/requirements.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/utils.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/version.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/_compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/_structures.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/markers.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/requirements.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/specifiers.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/utils.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/version.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/_in_process.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/build.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/check.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/colorlog.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/envbuild.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/wrappers.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/_in_process.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/build.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/check.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/colorlog.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/envbuild.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/wrappers.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pkg_resources/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pkg_resources/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pkg_resources/__pycache__/py31compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pkg_resources/py31compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__pycache__/bar.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__pycache__/counter.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__pycache__/spinner.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/bar.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/counter.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/spinner.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pyparsing.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/core.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/parser.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/test.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/utils.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/writer.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/core.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/parser.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/test.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/utils.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/writer.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/__version__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/_internal_utils.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/adapters.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/api.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/auth.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/certs.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/cookies.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/exceptions.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/help.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/hooks.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/models.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/packages.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/sessions.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/status_codes.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/structures.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/utils.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__version__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/_internal_utils.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/adapters.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/api.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/auth.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/certs.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/cookies.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/exceptions.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/help.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/hooks.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/models.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/packages.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/sessions.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/status_codes.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/structures.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/utils.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/retrying.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/six.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/_collections.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/connection.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/connectionpool.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/exceptions.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/fields.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/filepost.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/poolmanager.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/request.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/response.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/_collections.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/connection.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/connectionpool.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/appengine.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/securetransport.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/socks.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/exceptions.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/fields.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/filepost.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/__pycache__/six.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/backports/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/_mixin.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/abnf_regexp.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/api.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/builder.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/exceptions.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/iri.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/misc.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/normalizers.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/parseresult.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/uri.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/validators.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/_mixin.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/abnf_regexp.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/api.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/builder.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/exceptions.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/iri.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/misc.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/normalizers.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/parseresult.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/uri.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/validators.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/six.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/poolmanager.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/request.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/response.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/connection.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/queue.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/request.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/response.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/retry.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/timeout.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/url.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/wait.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/connection.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/queue.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/request.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/response.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/retry.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/ssl_.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/timeout.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/url.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/wait.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__pycache__/labels.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__pycache__/tests.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/labels.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/mklabels.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/tests.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/x_user_defined.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/__pycache__/py31compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/appdirs.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/pyparsing.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/six.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/appdirs.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__about__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__about__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/_compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/_structures.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/markers.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/requirements.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/utils.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/version.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_structures.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/markers.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/requirements.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/specifiers.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/utils.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/version.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/pyparsing.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/six.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/extern/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/extern/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/py31compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/INSTALLER create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/LICENSE create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/METADATA create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/RECORD create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/WHEEL create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/dependency_links.txt create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/entry_points.txt create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/top_level.txt create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/zip-safe create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/_deprecation_warning.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/archive_util.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/build_meta.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/config.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/dep_util.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/depends.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/dist.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/extension.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/glibc.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/glob.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/launch.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/lib2to3_ex.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/monkey.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/msvc.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/namespaces.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/package_index.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/pep425tags.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/py27compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/py31compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/py33compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/sandbox.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/site-patch.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/ssl_support.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/unicode_utils.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/version.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/wheel.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/windows_support.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_deprecation_warning.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/pyparsing.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/six.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__about__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__about__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/_compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/_structures.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/markers.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/requirements.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/utils.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/version.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/_compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/_structures.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/markers.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/requirements.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/specifiers.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/utils.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/version.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/pyparsing.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/six.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/archive_util.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/build_meta.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/cli-32.exe create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/cli-64.exe create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/cli.exe create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/alias.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_egg.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_rpm.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_wininst.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/build_clib.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/build_ext.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/build_py.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/develop.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/dist_info.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/easy_install.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/egg_info.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/install.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/install_egg_info.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/install_lib.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/install_scripts.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/py36compat.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/register.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/rotate.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/saveopts.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/sdist.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/setopt.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/test.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/upload.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/upload_docs.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/alias.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/bdist_egg.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/bdist_rpm.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/bdist_wininst.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/build_clib.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/build_ext.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/build_py.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/develop.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/dist_info.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/easy_install.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/egg_info.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install_egg_info.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install_lib.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install_scripts.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/launcher manifest.xml create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/py36compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/register.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/rotate.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/saveopts.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/sdist.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/setopt.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/test.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/upload.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/upload_docs.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/config.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/dep_util.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/depends.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/dist.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/extension.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/extern/__init__.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/extern/__pycache__/__init__.cpython-38.pyc create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/glibc.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/glob.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/gui-32.exe create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/gui-64.exe create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/gui.exe create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/launch.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/lib2to3_ex.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/monkey.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/msvc.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/namespaces.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/package_index.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/pep425tags.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/py27compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/py31compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/py33compat.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/sandbox.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/script (dev).tmpl create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/script.tmpl create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/site-patch.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/ssl_support.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/unicode_utils.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/version.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/wheel.py create mode 100644 Front-end/apis-env/lib/python3.8/site-packages/setuptools/windows_support.py create mode 100644 Front-end/apis-env/pyvenv.cfg create mode 100644 Front-end/app.py create mode 100644 Front-end/config.py create mode 100644 Front-end/request.py create mode 100644 Front-end/templates/createbook.html create mode 100644 Front-end/templates/home.html create mode 100644 Front-end/templates/index.html create mode 100644 Front-end/templates/search.html delete mode 100644 MongoBookApis/bin/Debug/net5.0/MongoBookApis.dll delete mode 100644 MongoBookApis/bin/Debug/net5.0/ref/MongoBookApis.dll delete mode 100644 MongoBookApis/obj/Debug/net5.0/MongoBookApis.assets.cache delete mode 100644 MongoBookApis/obj/Debug/net5.0/MongoBookApis.csproj.AssemblyReference.cache delete mode 100644 MongoBookApis/obj/Debug/net5.0/MongoBookApis.csproj.CoreCompileInputs.cache delete mode 100644 MongoBookApis/obj/Debug/net5.0/MongoBookApis.dll delete mode 100644 MongoBookApis/obj/Debug/net5.0/ref/MongoBookApis.dll delete mode 100644 MongoBookApis/obj/project.assets.json delete mode 100644 MongoBookApis/obj/project.nuget.cache diff --git a/.DS_Store b/.DS_Store index d9206307ac7537906e102a6c3e691483350f61c2..f6d94bc3fe9dd170f5b567d4e1cb2b102e55d72d 100644 GIT binary patch literal 6148 zcmeHKy-veG4F0ZkXoZkE!j>6{AyOsQGzx4?c>!pP3Zm_m@-ydkcn)3ziRWPB^PL4P z2^AAm$d-KH#j)?4FX_1k;PQuY3iJSUsDiC7hX#@RqBUu$MdDmo;|Q0SV?3RtWzE|R z+sJ^tyAE<(V1yg2yuXp3Emjh)`OJJ#45xl5@wacU{e!3HLDO0@KmL*5;wmk_?AgUB zmhk+d?l)xC;I*1t|M2Blb8Gbc%x<%1LwkRC~%bwK# zlkfZg^&q=428@A!#ei!UWs&odw6@kBPHJsJJ*SF@Uls8qgp*K;=_{pppBjYrL?*;c Tv5H6w#r_Bc8f-8IewBfDU(Hr+ delta 88 zcmZoMXfc=|#>CJzu~2NHo}wrt0|NsP3otO`GdKZpK0`Kx - + - - - - - - - - - + + + + + + + + + + + + + - - - + - + @@ -47,8 +49,8 @@ - - + + diff --git a/MongoBookApis/.vs/MongoBookApis/xs/project-cache/MongoBookApis-Debug.json b/Back-end/MongoBookApis/.vs/MongoBookApis/xs/project-cache/MongoBookApis-Debug.json similarity index 58% rename from MongoBookApis/.vs/MongoBookApis/xs/project-cache/MongoBookApis-Debug.json rename to Back-end/MongoBookApis/.vs/MongoBookApis/xs/project-cache/MongoBookApis-Debug.json index e1d4e67..956387b 100644 --- a/MongoBookApis/.vs/MongoBookApis/xs/project-cache/MongoBookApis-Debug.json +++ b/Back-end/MongoBookApis/.vs/MongoBookApis/xs/project-cache/MongoBookApis-Debug.json @@ -1 +1 @@ -{"Format":1,"ProjectReferences":[],"MetadataReferences":[{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/dnsclient/1.4.0/lib/netstandard2.1/DnsClient.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Antiforgery.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Authentication.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Authentication.Cookies.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Authentication.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Authentication.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Authentication.OAuth.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Authorization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Authorization.Policy.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Components.Authorization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Components.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Components.Forms.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Components.Server.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Components.Web.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Connections.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.CookiePolicy.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Cors.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Cryptography.Internal.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Cryptography.KeyDerivation.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.DataProtection.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.DataProtection.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.DataProtection.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Diagnostics.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Diagnostics.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Diagnostics.HealthChecks.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.HostFiltering.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Hosting.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Hosting.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Hosting.Server.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Html.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Http.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Http.Connections.Common.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Http.Connections.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Http.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Http.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Http.Features.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.HttpOverrides.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.HttpsPolicy.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Identity.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Localization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Localization.Routing.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Metadata.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.ApiExplorer.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.Cors.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.DataAnnotations.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.Formatters.Json.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.Formatters.Xml.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.Localization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.Razor.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.RazorPages.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.TagHelpers.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.ViewFeatures.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Razor.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Razor.Runtime.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.ResponseCaching.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.ResponseCaching.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.ResponseCompression.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Rewrite.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Routing.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Routing.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Server.HttpSys.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Server.IIS.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Server.IISIntegration.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Server.Kestrel.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Server.Kestrel.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Server.Kestrel.Transport.Sockets.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Session.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.SignalR.Common.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.SignalR.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.SignalR.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.SignalR.Protocols.Json.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.StaticFiles.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.WebSockets.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.WebUtilities.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/Microsoft.CSharp.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Caching.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Caching.Memory.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.Binder.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.CommandLine.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.EnvironmentVariables.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.FileExtensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.Ini.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.Json.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.KeyPerFile.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.UserSecrets.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.Xml.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.DependencyInjection.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.DependencyInjection.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Diagnostics.HealthChecks.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Diagnostics.HealthChecks.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.FileProviders.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.FileProviders.Composite.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.FileProviders.Embedded.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.FileProviders.Physical.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.FileSystemGlobbing.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Hosting.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Hosting.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Http.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Identity.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Identity.Stores.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Localization.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Localization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.Configuration.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.Console.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.Debug.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.EventLog.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.EventSource.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.TraceSource.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.ObjectPool.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Options.ConfigurationExtensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Options.DataAnnotations.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Options.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.WebEncoders.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.JSInterop.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Net.Http.Headers.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/microsoft.openapi/1.2.3/lib/netstandard2.0/Microsoft.OpenApi.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/Microsoft.VisualBasic.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/Microsoft.VisualBasic.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Win32.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Win32.Registry.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/mongodb.bson/2.13.2/lib/netstandard2.1/MongoDB.Bson.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/mongodb.driver.core/2.13.2/lib/netstandard2.1/MongoDB.Driver.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/mongodb.driver/2.13.2/lib/netstandard2.1/MongoDB.Driver.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/mongodb.libmongocrypt/1.2.2/lib/netstandard2.1/MongoDB.Libmongocrypt.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/mscorlib.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/netstandard.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/sharpcompress/0.23.0/lib/netstandard2.0/SharpCompress.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/swashbuckle.aspnetcore.swagger/5.6.3/lib/netcoreapp3.0/Swashbuckle.AspNetCore.Swagger.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/swashbuckle.aspnetcore.swaggergen/5.6.3/lib/netcoreapp3.0/Swashbuckle.AspNetCore.SwaggerGen.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/swashbuckle.aspnetcore.swaggerui/5.6.3/lib/netcoreapp3.0/Swashbuckle.AspNetCore.SwaggerUI.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.AppContext.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Buffers.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Collections.Concurrent.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Collections.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Collections.Immutable.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Collections.NonGeneric.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Collections.Specialized.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ComponentModel.Annotations.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ComponentModel.DataAnnotations.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ComponentModel.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ComponentModel.EventBasedAsync.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ComponentModel.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ComponentModel.TypeConverter.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Configuration.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Console.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Data.Common.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Data.DataSetExtensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Data.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.Contracts.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.Debug.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.DiagnosticSource.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.EventLog.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.FileVersionInfo.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.Process.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.StackTrace.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.TextWriterTraceListener.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.Tools.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.TraceSource.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.Tracing.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Drawing.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Drawing.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Dynamic.Runtime.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Formats.Asn1.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Globalization.Calendars.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Globalization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Globalization.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.Compression.Brotli.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.Compression.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.Compression.FileSystem.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.Compression.ZipFile.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.FileSystem.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.FileSystem.DriveInfo.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.FileSystem.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.FileSystem.Watcher.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.IsolatedStorage.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.MemoryMappedFiles.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.IO.Pipelines.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.Pipes.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.UnmanagedMemoryStream.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Linq.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Linq.Expressions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Linq.Parallel.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Linq.Queryable.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Memory.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Http.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Http.Json.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.HttpListener.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Mail.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.NameResolution.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.NetworkInformation.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Ping.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Requests.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Security.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.ServicePoint.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Sockets.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.WebClient.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.WebHeaderCollection.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.WebProxy.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.WebSockets.Client.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.WebSockets.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Numerics.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Numerics.Vectors.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ObjectModel.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.DispatchProxy.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.Emit.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.Emit.ILGeneration.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.Emit.Lightweight.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.Metadata.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.TypeExtensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Resources.Reader.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Resources.ResourceManager.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Resources.Writer.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.CompilerServices.Unsafe.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.CompilerServices.VisualC.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Handles.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.InteropServices.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.InteropServices.RuntimeInformation.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Intrinsics.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Loader.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Numerics.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Serialization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Serialization.Formatters.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Serialization.Json.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Serialization.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Serialization.Xml.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.Security.AccessControl.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.Claims.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.Cryptography.Algorithms.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.Security.Cryptography.Cng.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.Cryptography.Csp.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.Cryptography.Encoding.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.Cryptography.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.Cryptography.X509Certificates.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.Security.Cryptography.Xml.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.Security.Permissions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.Principal.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.Security.Principal.Windows.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.SecureString.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ServiceModel.Web.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ServiceProcess.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Text.Encoding.CodePages.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Text.Encoding.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Text.Encoding.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Text.Encodings.Web.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Text.Json.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Text.RegularExpressions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Channels.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Overlapped.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Tasks.Dataflow.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Tasks.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Tasks.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Tasks.Parallel.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Thread.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.ThreadPool.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Timer.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Transactions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Transactions.Local.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ValueTuple.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Web.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Web.HttpUtility.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Windows.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.Windows.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.Linq.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.ReaderWriter.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.Serialization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.XDocument.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.XmlDocument.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.XmlSerializer.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.XPath.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.XPath.XDocument.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/WindowsBase.dll","Aliases":[],"Framework":null}],"Files":["/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Controllers/BooksController.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Dtos/BookDto.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Dtos/CreateBookDto.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Models/Book.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Models/OwnerClass.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/MongoDbSettings/MongoDbSettings.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Program.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Repositories/Extensions.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Repositories/IBooksRepository.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Repositories/MongoDbBooksRepository.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Startup.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/.DS_Store","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Repositories/.DS_Store","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/appsettings.json","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/appsettings.Development.json","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Properties/launchSettings.json","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/obj/Debug/net5.0/MongoBookApis.AssemblyInfo.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/obj/Debug/net5.0/MongoBookApis.AssemblyInfo.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/obj/Debug/net5.0/MongoBookApis.AssemblyInfo.cs"],"BuildActions":["Compile","Compile","Compile","Compile","Compile","Compile","Compile","Compile","Compile","Compile","Compile","None","None","Content","Content","Content","Compile","Compile","Compile"],"Analyzers":["/usr/local/share/dotnet/sdk/5.0.403/Sdks/Microsoft.NET.Sdk.Web/analyzers/cs/Microsoft.AspNetCore.Analyzers.dll","/usr/local/share/dotnet/sdk/5.0.403/Sdks/Microsoft.NET.Sdk.Web/analyzers/cs/Microsoft.AspNetCore.Mvc.Analyzers.dll","/usr/local/share/dotnet/sdk/5.0.403/Sdks/Microsoft.NET.Sdk.Web/analyzers/cs/Microsoft.AspNetCore.Components.Analyzers.dll","/usr/local/share/dotnet/sdk/5.0.403/Sdks/Microsoft.NET.Sdk/analyzers/Microsoft.CodeAnalysis.CSharp.NetAnalyzers.dll","/usr/local/share/dotnet/sdk/5.0.403/Sdks/Microsoft.NET.Sdk/analyzers/Microsoft.CodeAnalysis.NetAnalyzers.dll"],"AdditionalFiles":[],"EditorConfigFiles":[]} \ No newline at end of file +{"Format":1,"ProjectReferences":[],"MetadataReferences":[{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/dnsclient/1.4.0/lib/netstandard2.1/DnsClient.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Antiforgery.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Authentication.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Authentication.Cookies.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Authentication.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Authentication.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Authentication.OAuth.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Authorization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Authorization.Policy.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Components.Authorization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Components.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Components.Forms.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Components.Server.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Components.Web.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Connections.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.CookiePolicy.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Cors.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Cryptography.Internal.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Cryptography.KeyDerivation.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.DataProtection.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.DataProtection.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.DataProtection.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Diagnostics.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Diagnostics.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Diagnostics.HealthChecks.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.HostFiltering.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Hosting.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Hosting.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Hosting.Server.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Html.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Http.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Http.Connections.Common.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Http.Connections.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Http.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Http.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Http.Features.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.HttpOverrides.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.HttpsPolicy.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Identity.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Localization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Localization.Routing.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Metadata.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.ApiExplorer.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.Cors.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.DataAnnotations.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.Formatters.Json.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.Formatters.Xml.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.Localization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.Razor.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.RazorPages.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.TagHelpers.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Mvc.ViewFeatures.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Razor.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Razor.Runtime.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.ResponseCaching.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.ResponseCaching.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.ResponseCompression.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Rewrite.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Routing.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Routing.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Server.HttpSys.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Server.IIS.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Server.IISIntegration.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Server.Kestrel.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Server.Kestrel.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Server.Kestrel.Transport.Sockets.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.Session.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.SignalR.Common.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.SignalR.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.SignalR.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.SignalR.Protocols.Json.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.StaticFiles.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.WebSockets.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.AspNetCore.WebUtilities.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/Microsoft.CSharp.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Caching.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Caching.Memory.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.Binder.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.CommandLine.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.EnvironmentVariables.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.FileExtensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.Ini.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.Json.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.KeyPerFile.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.UserSecrets.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Configuration.Xml.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.DependencyInjection.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.DependencyInjection.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Diagnostics.HealthChecks.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Diagnostics.HealthChecks.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.FileProviders.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.FileProviders.Composite.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.FileProviders.Embedded.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.FileProviders.Physical.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.FileSystemGlobbing.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Hosting.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Hosting.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Http.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Identity.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Identity.Stores.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Localization.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Localization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.Abstractions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.Configuration.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.Console.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.Debug.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.EventLog.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.EventSource.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Logging.TraceSource.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.ObjectPool.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Options.ConfigurationExtensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Options.DataAnnotations.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Options.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Extensions.WebEncoders.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.JSInterop.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Net.Http.Headers.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/microsoft.openapi/1.2.3/lib/netstandard2.0/Microsoft.OpenApi.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/Microsoft.VisualBasic.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/Microsoft.VisualBasic.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Win32.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/Microsoft.Win32.Registry.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/mongodb.bson/2.13.2/lib/netstandard2.1/MongoDB.Bson.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/mongodb.driver.core/2.13.2/lib/netstandard2.1/MongoDB.Driver.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/mongodb.driver/2.13.2/lib/netstandard2.1/MongoDB.Driver.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/mongodb.libmongocrypt/1.2.2/lib/netstandard2.1/MongoDB.Libmongocrypt.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/mscorlib.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/netstandard.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/newtonsoft.json.bson/1.0.1/lib/netstandard1.3/Newtonsoft.Json.Bson.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/newtonsoft.json/10.0.1/lib/netstandard1.3/Newtonsoft.Json.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/sharpcompress/0.23.0/lib/netstandard2.0/SharpCompress.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/swashbuckle.aspnetcore.swagger/5.6.3/lib/netcoreapp3.0/Swashbuckle.AspNetCore.Swagger.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/swashbuckle.aspnetcore.swaggergen/5.6.3/lib/netcoreapp3.0/Swashbuckle.AspNetCore.SwaggerGen.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/swashbuckle.aspnetcore.swaggerui/5.6.3/lib/netcoreapp3.0/Swashbuckle.AspNetCore.SwaggerUI.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.AppContext.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Buffers.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Collections.Concurrent.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Collections.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Collections.Immutable.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Collections.NonGeneric.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Collections.Specialized.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ComponentModel.Annotations.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ComponentModel.DataAnnotations.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ComponentModel.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ComponentModel.EventBasedAsync.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ComponentModel.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ComponentModel.TypeConverter.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Configuration.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Console.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Core.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Data.Common.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Data.DataSetExtensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Data.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.Contracts.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.Debug.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.DiagnosticSource.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.EventLog.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.FileVersionInfo.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.Process.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.StackTrace.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.TextWriterTraceListener.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.Tools.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.TraceSource.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Diagnostics.Tracing.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Drawing.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Drawing.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Dynamic.Runtime.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Formats.Asn1.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Globalization.Calendars.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Globalization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Globalization.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.Compression.Brotli.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.Compression.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.Compression.FileSystem.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.Compression.ZipFile.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.FileSystem.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.FileSystem.DriveInfo.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.FileSystem.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.FileSystem.Watcher.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.IsolatedStorage.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.MemoryMappedFiles.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.IO.Pipelines.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.Pipes.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.IO.UnmanagedMemoryStream.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Linq.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Linq.Expressions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Linq.Parallel.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Linq.Queryable.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Memory.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Http.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/microsoft.aspnet.webapi.client/5.2.7/lib/netstandard2.0/System.Net.Http.Formatting.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Http.Json.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.HttpListener.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Mail.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.NameResolution.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.NetworkInformation.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Ping.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Requests.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Security.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.ServicePoint.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.Sockets.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.WebClient.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.WebHeaderCollection.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.WebProxy.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.WebSockets.Client.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Net.WebSockets.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Numerics.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Numerics.Vectors.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ObjectModel.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.DispatchProxy.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.Emit.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.Emit.ILGeneration.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.Emit.Lightweight.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.Metadata.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Reflection.TypeExtensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Resources.Reader.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Resources.ResourceManager.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Resources.Writer.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.CompilerServices.Unsafe.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.CompilerServices.VisualC.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Handles.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.InteropServices.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.InteropServices.RuntimeInformation.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Intrinsics.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Loader.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Numerics.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Serialization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Serialization.Formatters.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Serialization.Json.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Serialization.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Runtime.Serialization.Xml.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.Security.AccessControl.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.Claims.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.Cryptography.Algorithms.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.Security.Cryptography.Cng.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.Cryptography.Csp.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.Cryptography.Encoding.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.Cryptography.Primitives.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.Cryptography.X509Certificates.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.Security.Cryptography.Xml.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.Security.Permissions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.Principal.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.Security.Principal.Windows.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Security.SecureString.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ServiceModel.Web.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ServiceProcess.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Text.Encoding.CodePages.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Text.Encoding.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Text.Encoding.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Text.Encodings.Web.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Text.Json.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Text.RegularExpressions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Channels.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Overlapped.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Tasks.Dataflow.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Tasks.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Tasks.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Tasks.Parallel.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Thread.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.ThreadPool.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Threading.Timer.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Transactions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Transactions.Local.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.ValueTuple.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/microsoft.aspnet.cors/5.2.7/lib/net45/System.Web.Cors.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Web.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/microsoft.aspnet.webapi.cors/5.2.7/lib/net45/System.Web.Http.Cors.dll","Aliases":[],"Framework":null},{"FilePath":"/Users/hanieharabzadeh/.nuget/packages/microsoft.aspnet.webapi.core/5.2.7/lib/net45/System.Web.Http.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Web.HttpUtility.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Windows.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.AspNetCore.App.Ref/5.0.0/ref/net5.0/System.Windows.Extensions.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.Linq.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.ReaderWriter.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.Serialization.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.XDocument.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.XmlDocument.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.XmlSerializer.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.XPath.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/System.Xml.XPath.XDocument.dll","Aliases":[],"Framework":null},{"FilePath":"/usr/local/share/dotnet/packs/Microsoft.NETCore.App.Ref/5.0.0/ref/net5.0/WindowsBase.dll","Aliases":[],"Framework":null}],"Files":["/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Controllers/BooksController.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Dtos/BookDto.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Dtos/CreateBookDto.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Models/Book.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Models/OwnerClass.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/MongoDbSettings/MongoDbSettings.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Program.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Repositories/Extensions.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Repositories/IBooksRepository.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Repositories/MongoDbBooksRepository.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Startup.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/.DS_Store","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Repositories/.DS_Store","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/appsettings.json","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/appsettings.Development.json","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/Properties/launchSettings.json","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/obj/Debug/net5.0/MongoBookApis.AssemblyInfo.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/obj/Debug/net5.0/MongoBookApis.AssemblyInfo.cs","/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/obj/Debug/net5.0/MongoBookApis.AssemblyInfo.cs"],"BuildActions":["Compile","Compile","Compile","Compile","Compile","Compile","Compile","Compile","Compile","Compile","Compile","None","None","Content","Content","Content","Compile","Compile","Compile"],"Analyzers":["/usr/local/share/dotnet/sdk/5.0.403/Sdks/Microsoft.NET.Sdk.Web/analyzers/cs/Microsoft.AspNetCore.Analyzers.dll","/usr/local/share/dotnet/sdk/5.0.403/Sdks/Microsoft.NET.Sdk.Web/analyzers/cs/Microsoft.AspNetCore.Mvc.Analyzers.dll","/usr/local/share/dotnet/sdk/5.0.403/Sdks/Microsoft.NET.Sdk.Web/analyzers/cs/Microsoft.AspNetCore.Components.Analyzers.dll","/usr/local/share/dotnet/sdk/5.0.403/Sdks/Microsoft.NET.Sdk/analyzers/Microsoft.CodeAnalysis.CSharp.NetAnalyzers.dll","/usr/local/share/dotnet/sdk/5.0.403/Sdks/Microsoft.NET.Sdk/analyzers/Microsoft.CodeAnalysis.NetAnalyzers.dll"],"AdditionalFiles":[],"EditorConfigFiles":[]} \ No newline at end of file diff --git a/MongoBookApis/Controllers/BooksController.cs b/Back-end/MongoBookApis/Controllers/BooksController.cs similarity index 94% rename from MongoBookApis/Controllers/BooksController.cs rename to Back-end/MongoBookApis/Controllers/BooksController.cs index 84b3994..fac188d 100644 --- a/MongoBookApis/Controllers/BooksController.cs +++ b/Back-end/MongoBookApis/Controllers/BooksController.cs @@ -6,11 +6,13 @@ using MongoBookApis.Repositories; using MongoBookApis.Dtos; using System.Threading.Tasks; +using System.Web.Http.Cors; namespace MongoBookApis.Controllers { [ApiController] [Route("books")] + [EnableCors(origins: "*", headers: "*", methods: "*")] public class BooksController : ControllerBase { @@ -22,6 +24,7 @@ public BooksController(IBooksRepository _repository) } // GET /books [HttpGet] + [EnableCors(origins: "*", headers: "*", methods: "*")] public async Task> GetBooksAsync() { var books = (await repository.GetBooksAsync()) diff --git a/MongoBookApis/Dtos/BookDto.cs b/Back-end/MongoBookApis/Dtos/BookDto.cs similarity index 100% rename from MongoBookApis/Dtos/BookDto.cs rename to Back-end/MongoBookApis/Dtos/BookDto.cs diff --git a/MongoBookApis/Dtos/CreateBookDto.cs b/Back-end/MongoBookApis/Dtos/CreateBookDto.cs similarity index 100% rename from MongoBookApis/Dtos/CreateBookDto.cs rename to Back-end/MongoBookApis/Dtos/CreateBookDto.cs diff --git a/MongoBookApis/Models/Book.cs b/Back-end/MongoBookApis/Models/Book.cs similarity index 100% rename from MongoBookApis/Models/Book.cs rename to Back-end/MongoBookApis/Models/Book.cs diff --git a/MongoBookApis/Models/OwnerClass.cs b/Back-end/MongoBookApis/Models/OwnerClass.cs similarity index 100% rename from MongoBookApis/Models/OwnerClass.cs rename to Back-end/MongoBookApis/Models/OwnerClass.cs diff --git a/MongoBookApis/MongoBookApis.csproj b/Back-end/MongoBookApis/MongoBookApis.csproj similarity index 81% rename from MongoBookApis/MongoBookApis.csproj rename to Back-end/MongoBookApis/MongoBookApis.csproj index 9ed78d8..b21db30 100644 --- a/MongoBookApis/MongoBookApis.csproj +++ b/Back-end/MongoBookApis/MongoBookApis.csproj @@ -7,6 +7,7 @@ + @@ -15,6 +16,7 @@ + diff --git a/MongoBookApis/MongoBookApis.sln b/Back-end/MongoBookApis/MongoBookApis.sln similarity index 100% rename from MongoBookApis/MongoBookApis.sln rename to Back-end/MongoBookApis/MongoBookApis.sln diff --git a/MongoBookApis/MongoDbSettings/MongoDbSettings.cs b/Back-end/MongoBookApis/MongoDbSettings/MongoDbSettings.cs similarity index 100% rename from MongoBookApis/MongoDbSettings/MongoDbSettings.cs rename to Back-end/MongoBookApis/MongoDbSettings/MongoDbSettings.cs diff --git a/MongoBookApis/Program.cs b/Back-end/MongoBookApis/Program.cs similarity index 100% rename from MongoBookApis/Program.cs rename to Back-end/MongoBookApis/Program.cs diff --git a/MongoBookApis/Properties/launchSettings.json b/Back-end/MongoBookApis/Properties/launchSettings.json similarity index 100% rename from MongoBookApis/Properties/launchSettings.json rename to Back-end/MongoBookApis/Properties/launchSettings.json diff --git a/MongoBookApis/Repositories/.DS_Store b/Back-end/MongoBookApis/Repositories/.DS_Store similarity index 100% rename from MongoBookApis/Repositories/.DS_Store rename to Back-end/MongoBookApis/Repositories/.DS_Store diff --git a/MongoBookApis/Repositories/Extensions.cs b/Back-end/MongoBookApis/Repositories/Extensions.cs similarity index 100% rename from MongoBookApis/Repositories/Extensions.cs rename to Back-end/MongoBookApis/Repositories/Extensions.cs diff --git a/MongoBookApis/Repositories/IBooksRepository.cs b/Back-end/MongoBookApis/Repositories/IBooksRepository.cs similarity index 100% rename from MongoBookApis/Repositories/IBooksRepository.cs rename to Back-end/MongoBookApis/Repositories/IBooksRepository.cs diff --git a/MongoBookApis/Repositories/MongoDbBooksRepository.cs b/Back-end/MongoBookApis/Repositories/MongoDbBooksRepository.cs similarity index 96% rename from MongoBookApis/Repositories/MongoDbBooksRepository.cs rename to Back-end/MongoBookApis/Repositories/MongoDbBooksRepository.cs index 727864c..57be379 100644 --- a/MongoBookApis/Repositories/MongoDbBooksRepository.cs +++ b/Back-end/MongoBookApis/Repositories/MongoDbBooksRepository.cs @@ -49,7 +49,7 @@ public async Task> SearchAsync(string title = "", string autho var titleFilter = filterBuiler.Regex(book => book.Title, "/.*" + title + ".*/"); var authorsFilter = filterBuiler.Regex(book => book.Authors, "/.*" + authors + ".*/"); var minNumPageFilter = filterBuiler.Gt(book => book.NumPage, minNumPage); - Console.WriteLine(maxNumPage); + if (minNumPage == "" || minNumPage == null) { minNumPageFilter = filterBuiler.Gt(book => book.NumPage, "0"); @@ -57,7 +57,6 @@ public async Task> SearchAsync(string title = "", string autho var maxNumPageFilter = filterBuiler.Lt(book => book.NumPage, maxNumPage); if (maxNumPage == "" || maxNumPage == null) { - Console.WriteLine("yes"); maxNumPageFilter = filterBuiler.Lt(book => book.NumPage, double.PositiveInfinity.ToString()); } diff --git a/MongoBookApis/Startup.cs b/Back-end/MongoBookApis/Startup.cs similarity index 82% rename from MongoBookApis/Startup.cs rename to Back-end/MongoBookApis/Startup.cs index 0ecf7e3..6183d6c 100644 --- a/MongoBookApis/Startup.cs +++ b/Back-end/MongoBookApis/Startup.cs @@ -20,6 +20,7 @@ using MongoDB.Bson; using MongoDB.Driver.Core.Operations; + namespace MongoBookApis { public class Startup @@ -43,6 +44,19 @@ public void ConfigureServices(IServiceCollection services) var client = new MongoClient(settings.ConnectionString); return client; }); + var MyAllowSpecificOrigins = "_myAllowSpecificOrigins"; + + + + //services.AddCors(options => + //{ + // options.AddPolicy(name: MyAllowSpecificOrigins, + // builder => + // { + // builder.WithOrigins("http://localhost:3000" , + // "https://localhost:3000"); + // }); + //}); services.AddSingleton(); services.AddControllers(options => { @@ -65,7 +79,7 @@ public void Configure(IApplicationBuilder app, IWebHostEnvironment env) app.UseSwagger(); app.UseSwaggerUI(c => c.SwaggerEndpoint("/swagger/v1/swagger.json", "MongoBookApis v1")); } - + app.UseHttpsRedirection(); app.UseRouting(); diff --git a/MongoBookApis/appsettings.Development.json b/Back-end/MongoBookApis/appsettings.Development.json similarity index 100% rename from MongoBookApis/appsettings.Development.json rename to Back-end/MongoBookApis/appsettings.Development.json diff --git a/MongoBookApis/appsettings.json b/Back-end/MongoBookApis/appsettings.json similarity index 100% rename from MongoBookApis/appsettings.json rename to Back-end/MongoBookApis/appsettings.json diff --git a/MongoBookApis/bin/Debug/net5.0/DnsClient.dll b/Back-end/MongoBookApis/bin/Debug/net5.0/DnsClient.dll similarity index 100% rename from MongoBookApis/bin/Debug/net5.0/DnsClient.dll rename to Back-end/MongoBookApis/bin/Debug/net5.0/DnsClient.dll diff --git a/MongoBookApis/bin/Debug/net5.0/Microsoft.OpenApi.dll b/Back-end/MongoBookApis/bin/Debug/net5.0/Microsoft.OpenApi.dll similarity index 100% rename from MongoBookApis/bin/Debug/net5.0/Microsoft.OpenApi.dll rename to Back-end/MongoBookApis/bin/Debug/net5.0/Microsoft.OpenApi.dll diff --git a/MongoBookApis/bin/Debug/net5.0/MongoBookApis.deps.json b/Back-end/MongoBookApis/bin/Debug/net5.0/MongoBookApis.deps.json similarity index 58% rename from MongoBookApis/bin/Debug/net5.0/MongoBookApis.deps.json rename to Back-end/MongoBookApis/bin/Debug/net5.0/MongoBookApis.deps.json index b4c2618..6aa7553 100644 --- a/MongoBookApis/bin/Debug/net5.0/MongoBookApis.deps.json +++ b/Back-end/MongoBookApis/bin/Debug/net5.0/MongoBookApis.deps.json @@ -33,6 +33,7 @@ ".NETCoreApp,Version=v5.0": { "MongoBookApis/1.0.0": { "dependencies": { + "Microsoft.AspNet.WebApi.Cors": "5.2.7", "MongoDB.Driver": "2.13.2", "Swashbuckle.AspNetCore": "5.6.3", "Microsoft.AspNetCore.Antiforgery": "5.0.0.0", @@ -112,7 +113,7 @@ "Microsoft.AspNetCore.StaticFiles": "5.0.0.0", "Microsoft.AspNetCore.WebSockets": "5.0.0.0", "Microsoft.AspNetCore.WebUtilities": "5.0.0.0", - "Microsoft.CSharp": "5.0.0.0", + "Microsoft.CSharp.Reference": "5.0.0.0", "Microsoft.Extensions.Caching.Abstractions": "5.0.0.0", "Microsoft.Extensions.Caching.Memory": "5.0.0.0", "Microsoft.Extensions.Configuration.Abstractions": "5.0.0.0", @@ -160,80 +161,80 @@ "Microsoft.Net.Http.Headers": "5.0.0.0", "Microsoft.VisualBasic.Core": "10.0.6.0", "Microsoft.VisualBasic": "10.0.0.0", - "Microsoft.Win32.Primitives": "5.0.0.0", + "Microsoft.Win32.Primitives.Reference": "5.0.0.0", "Microsoft.Win32.Registry": "5.0.0.0", "mscorlib": "4.0.0.0", "netstandard": "2.1.0.0", - "System.AppContext": "5.0.0.0", + "System.AppContext.Reference": "5.0.0.0", "System.Buffers.Reference": "5.0.0.0", - "System.Collections.Concurrent": "5.0.0.0", - "System.Collections": "5.0.0.0", + "System.Collections.Concurrent.Reference": "5.0.0.0", + "System.Collections.Reference": "5.0.0.0", "System.Collections.Immutable": "5.0.0.0", - "System.Collections.NonGeneric": "5.0.0.0", - "System.Collections.Specialized": "5.0.0.0", + "System.Collections.NonGeneric.Reference": "5.0.0.0", + "System.Collections.Specialized.Reference": "5.0.0.0", "System.ComponentModel.Annotations": "5.0.0.0", "System.ComponentModel.DataAnnotations": "4.0.0.0", - "System.ComponentModel": "5.0.0.0", + "System.ComponentModel.Reference": "5.0.0.0", "System.ComponentModel.EventBasedAsync": "5.0.0.0", - "System.ComponentModel.Primitives": "5.0.0.0", - "System.ComponentModel.TypeConverter": "5.0.0.0", + "System.ComponentModel.Primitives.Reference": "5.0.0.0", + "System.ComponentModel.TypeConverter.Reference": "5.0.0.0", "System.Configuration": "4.0.0.0", - "System.Console": "5.0.0.0", + "System.Console.Reference": "5.0.0.0", "System.Core": "4.0.0.0", "System.Data.Common": "5.0.0.0", "System.Data.DataSetExtensions": "4.0.0.0", "System.Data": "4.0.0.0", "System.Diagnostics.Contracts": "5.0.0.0", - "System.Diagnostics.Debug": "5.0.0.0", - "System.Diagnostics.DiagnosticSource": "5.0.0.0", + "System.Diagnostics.Debug.Reference": "5.0.0.0", + "System.Diagnostics.DiagnosticSource.Reference": "5.0.0.0", "System.Diagnostics.EventLog": "5.0.0.0", "System.Diagnostics.FileVersionInfo": "5.0.0.0", "System.Diagnostics.Process": "5.0.0.0", "System.Diagnostics.StackTrace": "5.0.0.0", "System.Diagnostics.TextWriterTraceListener": "5.0.0.0", - "System.Diagnostics.Tools": "5.0.0.0", + "System.Diagnostics.Tools.Reference": "5.0.0.0", "System.Diagnostics.TraceSource": "5.0.0.0", - "System.Diagnostics.Tracing": "5.0.0.0", + "System.Diagnostics.Tracing.Reference": "5.0.0.0", "System": "4.0.0.0", "System.Drawing": "4.0.0.0", "System.Drawing.Primitives": "5.0.0.0", - "System.Dynamic.Runtime": "5.0.0.0", + "System.Dynamic.Runtime.Reference": "5.0.0.0", "System.Formats.Asn1": "5.0.0.0", - "System.Globalization.Calendars": "5.0.0.0", - "System.Globalization": "5.0.0.0", - "System.Globalization.Extensions": "5.0.0.0", + "System.Globalization.Calendars.Reference": "5.0.0.0", + "System.Globalization.Reference": "5.0.0.0", + "System.Globalization.Extensions.Reference": "5.0.0.0", "System.IO.Compression.Brotli": "5.0.0.0", - "System.IO.Compression": "5.0.0.0", + "System.IO.Compression.Reference": "5.0.0.0", "System.IO.Compression.FileSystem": "4.0.0.0", - "System.IO.Compression.ZipFile": "5.0.0.0", - "System.IO": "5.0.0.0", - "System.IO.FileSystem": "5.0.0.0", + "System.IO.Compression.ZipFile.Reference": "5.0.0.0", + "System.IO.Reference": "5.0.0.0", + "System.IO.FileSystem.Reference": "5.0.0.0", "System.IO.FileSystem.DriveInfo": "5.0.0.0", - "System.IO.FileSystem.Primitives": "5.0.0.0", + "System.IO.FileSystem.Primitives.Reference": "5.0.0.0", "System.IO.FileSystem.Watcher": "5.0.0.0", "System.IO.IsolatedStorage": "5.0.0.0", "System.IO.MemoryMappedFiles": "5.0.0.0", "System.IO.Pipelines": "5.0.0.0", "System.IO.Pipes": "5.0.0.0", "System.IO.UnmanagedMemoryStream": "5.0.0.0", - "System.Linq": "5.0.0.0", - "System.Linq.Expressions": "5.0.0.0", + "System.Linq.Reference": "5.0.0.0", + "System.Linq.Expressions.Reference": "5.0.0.0", "System.Linq.Parallel": "5.0.0.0", "System.Linq.Queryable": "5.0.0.0", "System.Memory": "5.0.0.0", "System.Net": "4.0.0.0", - "System.Net.Http": "5.0.0.0", + "System.Net.Http.Reference": "5.0.0.0", "System.Net.Http.Json": "5.0.0.0", "System.Net.HttpListener": "5.0.0.0", "System.Net.Mail": "5.0.0.0", "System.Net.NameResolution": "5.0.0.0", "System.Net.NetworkInformation": "5.0.0.0", "System.Net.Ping": "5.0.0.0", - "System.Net.Primitives": "5.0.0.0", + "System.Net.Primitives.Reference": "5.0.0.0", "System.Net.Requests": "5.0.0.0", "System.Net.Security": "5.0.0.0", "System.Net.ServicePoint": "5.0.0.0", - "System.Net.Sockets": "5.0.0.0", + "System.Net.Sockets.Reference": "5.0.0.0", "System.Net.WebClient": "5.0.0.0", "System.Net.WebHeaderCollection": "5.0.0.0", "System.Net.WebProxy": "5.0.0.0", @@ -241,42 +242,42 @@ "System.Net.WebSockets": "5.0.0.0", "System.Numerics": "4.0.0.0", "System.Numerics.Vectors": "5.0.0.0", - "System.ObjectModel": "5.0.0.0", + "System.ObjectModel.Reference": "5.0.0.0", "System.Reflection.DispatchProxy": "5.0.0.0", - "System.Reflection": "5.0.0.0", - "System.Reflection.Emit": "5.0.0.0", - "System.Reflection.Emit.ILGeneration": "5.0.0.0", - "System.Reflection.Emit.Lightweight": "5.0.0.0", - "System.Reflection.Extensions": "5.0.0.0", + "System.Reflection.Reference": "5.0.0.0", + "System.Reflection.Emit.Reference": "5.0.0.0", + "System.Reflection.Emit.ILGeneration.Reference": "5.0.0.0", + "System.Reflection.Emit.Lightweight.Reference": "5.0.0.0", + "System.Reflection.Extensions.Reference": "5.0.0.0", "System.Reflection.Metadata": "5.0.0.0", - "System.Reflection.Primitives": "5.0.0.0", - "System.Reflection.TypeExtensions": "5.0.0.0", + "System.Reflection.Primitives.Reference": "5.0.0.0", + "System.Reflection.TypeExtensions.Reference": "5.0.0.0", "System.Resources.Reader": "5.0.0.0", - "System.Resources.ResourceManager": "5.0.0.0", + "System.Resources.ResourceManager.Reference": "5.0.0.0", "System.Resources.Writer": "5.0.0.0", "System.Runtime.CompilerServices.Unsafe.Reference": "5.0.0.0", "System.Runtime.CompilerServices.VisualC": "5.0.0.0", - "System.Runtime": "5.0.0.0", - "System.Runtime.Extensions": "5.0.0.0", - "System.Runtime.Handles": "5.0.0.0", - "System.Runtime.InteropServices": "5.0.0.0", - "System.Runtime.InteropServices.RuntimeInformation": "5.0.0.0", + "System.Runtime.Reference": "5.0.0.0", + "System.Runtime.Extensions.Reference": "5.0.0.0", + "System.Runtime.Handles.Reference": "5.0.0.0", + "System.Runtime.InteropServices.Reference": "5.0.0.0", + "System.Runtime.InteropServices.RuntimeInformation.Reference": "5.0.0.0", "System.Runtime.Intrinsics": "5.0.0.0", "System.Runtime.Loader": "5.0.0.0", - "System.Runtime.Numerics": "5.0.0.0", + "System.Runtime.Numerics.Reference": "5.0.0.0", "System.Runtime.Serialization": "4.0.0.0", - "System.Runtime.Serialization.Formatters": "5.0.0.0", + "System.Runtime.Serialization.Formatters.Reference": "5.0.0.0", "System.Runtime.Serialization.Json": "5.0.0.0", - "System.Runtime.Serialization.Primitives": "5.0.0.0", + "System.Runtime.Serialization.Primitives.Reference": "5.0.0.0", "System.Runtime.Serialization.Xml": "5.0.0.0", "System.Security.AccessControl": "5.0.0.0", "System.Security.Claims": "5.0.0.0", - "System.Security.Cryptography.Algorithms": "5.0.0.0", - "System.Security.Cryptography.Cng": "5.0.0.0", - "System.Security.Cryptography.Csp": "5.0.0.0", - "System.Security.Cryptography.Encoding": "5.0.0.0", - "System.Security.Cryptography.Primitives": "5.0.0.0", - "System.Security.Cryptography.X509Certificates": "5.0.0.0", + "System.Security.Cryptography.Algorithms.Reference": "5.0.0.0", + "System.Security.Cryptography.Cng.Reference": "5.0.0.0", + "System.Security.Cryptography.Csp.Reference": "5.0.0.0", + "System.Security.Cryptography.Encoding.Reference": "5.0.0.0", + "System.Security.Cryptography.Primitives.Reference": "5.0.0.0", + "System.Security.Cryptography.X509Certificates.Reference": "5.0.0.0", "System.Security.Cryptography.Xml": "5.0.0.0", "System.Security": "4.0.0.0", "System.Security.Permissions": "5.0.0.0", @@ -286,21 +287,21 @@ "System.ServiceModel.Web": "4.0.0.0", "System.ServiceProcess": "4.0.0.0", "System.Text.Encoding.CodePages.Reference": "5.0.0.0", - "System.Text.Encoding": "5.0.0.0", - "System.Text.Encoding.Extensions": "5.0.0.0", + "System.Text.Encoding.Reference": "5.0.0.0", + "System.Text.Encoding.Extensions.Reference": "5.0.0.0", "System.Text.Encodings.Web": "5.0.0.0", "System.Text.Json": "5.0.0.0", - "System.Text.RegularExpressions": "5.0.0.0", + "System.Text.RegularExpressions.Reference": "5.0.0.0", "System.Threading.Channels": "5.0.0.0", - "System.Threading": "5.0.0.0", + "System.Threading.Reference": "5.0.0.0", "System.Threading.Overlapped": "5.0.0.0", "System.Threading.Tasks.Dataflow": "5.0.0.0", - "System.Threading.Tasks": "5.0.0.0", - "System.Threading.Tasks.Extensions": "5.0.0.0", + "System.Threading.Tasks.Reference": "5.0.0.0", + "System.Threading.Tasks.Extensions.Reference": "5.0.0.0", "System.Threading.Tasks.Parallel": "5.0.0.0", "System.Threading.Thread": "5.0.0.0", "System.Threading.ThreadPool": "5.0.0.0", - "System.Threading.Timer": "5.0.0.0", + "System.Threading.Timer.Reference": "5.0.0.0", "System.Transactions": "4.0.0.0", "System.Transactions.Local": "5.0.0.0", "System.ValueTuple": "4.0.3.0", @@ -310,10 +311,10 @@ "System.Windows.Extensions": "5.0.0.0", "System.Xml": "4.0.0.0", "System.Xml.Linq": "4.0.0.0", - "System.Xml.ReaderWriter": "5.0.0.0", + "System.Xml.ReaderWriter.Reference": "5.0.0.0", "System.Xml.Serialization": "4.0.0.0", - "System.Xml.XDocument": "5.0.0.0", - "System.Xml.XmlDocument": "5.0.0.0", + "System.Xml.XDocument.Reference": "5.0.0.0", + "System.Xml.XmlDocument.Reference": "5.0.0.0", "System.Xml.XmlSerializer": "5.0.0.0", "System.Xml.XPath": "5.0.0.0", "System.Xml.XPath.XDocument": "5.0.0.0", @@ -337,8 +338,84 @@ "lib/netstandard2.1/DnsClient.dll": {} } }, + "Microsoft.AspNet.Cors/5.2.7": { + "runtime": { + "lib/net45/System.Web.Cors.dll": { + "assemblyVersion": "5.2.7.0", + "fileVersion": "5.2.61128.0" + } + }, + "compile": { + "lib/net45/System.Web.Cors.dll": {} + } + }, + "Microsoft.AspNet.WebApi.Client/5.2.7": { + "dependencies": { + "Newtonsoft.Json": "10.0.1", + "Newtonsoft.Json.Bson": "1.0.1" + }, + "runtime": { + "lib/netstandard2.0/System.Net.Http.Formatting.dll": { + "assemblyVersion": "5.2.7.0", + "fileVersion": "5.2.61128.0" + } + }, + "compile": { + "lib/netstandard2.0/System.Net.Http.Formatting.dll": {} + } + }, + "Microsoft.AspNet.WebApi.Core/5.2.7": { + "dependencies": { + "Microsoft.AspNet.WebApi.Client": "5.2.7" + }, + "runtime": { + "lib/net45/System.Web.Http.dll": { + "assemblyVersion": "5.2.7.0", + "fileVersion": "5.2.61128.0" + } + }, + "compile": { + "lib/net45/System.Web.Http.dll": {} + } + }, + "Microsoft.AspNet.WebApi.Cors/5.2.7": { + "dependencies": { + "Microsoft.AspNet.Cors": "5.2.7", + "Microsoft.AspNet.WebApi.Core": "5.2.7" + }, + "runtime": { + "lib/net45/System.Web.Http.Cors.dll": { + "assemblyVersion": "5.2.7.0", + "fileVersion": "5.2.61128.0" + } + }, + "compile": { + "lib/net45/System.Web.Http.Cors.dll": {} + } + }, + "Microsoft.CSharp/4.3.0": { + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Dynamic.Runtime": "4.3.0", + "System.Globalization": "4.3.0", + "System.Linq": "4.3.0", + "System.Linq.Expressions": "4.3.0", + "System.ObjectModel": "4.3.0", + "System.Reflection": "4.3.0", + "System.Reflection.Extensions": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Reflection.TypeExtensions": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Threading": "4.3.0" + } + }, "Microsoft.Extensions.ApiDescription.Server/3.0.0": {}, "Microsoft.NETCore.Platforms/2.1.2": {}, + "Microsoft.NETCore.Targets/1.1.0": {}, "Microsoft.OpenApi/1.2.3": { "runtime": { "lib/netstandard2.0/Microsoft.OpenApi.dll": { @@ -350,6 +427,13 @@ "lib/netstandard2.0/Microsoft.OpenApi.dll": {} } }, + "Microsoft.Win32.Primitives/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + } + }, "MongoDB.Bson/2.13.2": { "dependencies": { "System.Runtime.CompilerServices.Unsafe": "5.0.0" @@ -443,6 +527,156 @@ "lib/netstandard2.1/MongoDB.Libmongocrypt.dll": {} } }, + "NETStandard.Library/1.6.1": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.Win32.Primitives": "4.3.0", + "System.AppContext": "4.3.0", + "System.Collections": "4.3.0", + "System.Collections.Concurrent": "4.3.0", + "System.Console": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Diagnostics.Tools": "4.3.0", + "System.Diagnostics.Tracing": "4.3.0", + "System.Globalization": "4.3.0", + "System.Globalization.Calendars": "4.3.0", + "System.IO": "4.3.0", + "System.IO.Compression": "4.3.0", + "System.IO.Compression.ZipFile": "4.3.0", + "System.IO.FileSystem": "4.3.0", + "System.IO.FileSystem.Primitives": "4.3.0", + "System.Linq": "4.3.0", + "System.Linq.Expressions": "4.3.0", + "System.Net.Http": "4.3.0", + "System.Net.Primitives": "4.3.0", + "System.Net.Sockets": "4.3.0", + "System.ObjectModel": "4.3.0", + "System.Reflection": "4.3.0", + "System.Reflection.Extensions": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Runtime.InteropServices.RuntimeInformation": "4.3.0", + "System.Runtime.Numerics": "4.3.0", + "System.Security.Cryptography.Algorithms": "4.3.0", + "System.Security.Cryptography.Encoding": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Security.Cryptography.X509Certificates": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Text.Encoding.Extensions": "4.3.0", + "System.Text.RegularExpressions": "4.3.0", + "System.Threading": "4.3.0", + "System.Threading.Tasks": "4.3.0", + "System.Threading.Timer": "4.3.0", + "System.Xml.ReaderWriter": "4.3.0", + "System.Xml.XDocument": "4.3.0" + } + }, + "Newtonsoft.Json/10.0.1": { + "dependencies": { + "Microsoft.CSharp": "4.3.0", + "System.Collections": "4.3.0", + "System.ComponentModel.TypeConverter": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Dynamic.Runtime": "4.3.0", + "System.Globalization": "4.3.0", + "System.IO": "4.3.0", + "System.Linq": "4.3.0", + "System.Linq.Expressions": "4.3.0", + "System.ObjectModel": "4.3.0", + "System.Reflection": "4.3.0", + "System.Reflection.Extensions": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Numerics": "4.3.0", + "System.Runtime.Serialization.Formatters": "4.3.0", + "System.Runtime.Serialization.Primitives": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Text.Encoding.Extensions": "4.3.0", + "System.Text.RegularExpressions": "4.3.0", + "System.Threading": "4.3.0", + "System.Threading.Tasks": "4.3.0", + "System.Xml.ReaderWriter": "4.3.0", + "System.Xml.XDocument": "4.3.0", + "System.Xml.XmlDocument": "4.3.0" + }, + "runtime": { + "lib/netstandard1.3/Newtonsoft.Json.dll": { + "assemblyVersion": "10.0.0.0", + "fileVersion": "10.0.1.20720" + } + }, + "compile": { + "lib/netstandard1.3/Newtonsoft.Json.dll": {} + } + }, + "Newtonsoft.Json.Bson/1.0.1": { + "dependencies": { + "NETStandard.Library": "1.6.1", + "Newtonsoft.Json": "10.0.1" + }, + "runtime": { + "lib/netstandard1.3/Newtonsoft.Json.Bson.dll": { + "assemblyVersion": "1.0.0.0", + "fileVersion": "1.0.1.20722" + } + }, + "compile": { + "lib/netstandard1.3/Newtonsoft.Json.Bson.dll": {} + } + }, + "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": {}, + "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": {}, + "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": {}, + "runtime.native.System/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0" + } + }, + "runtime.native.System.IO.Compression/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0" + } + }, + "runtime.native.System.Net.Http/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0" + } + }, + "runtime.native.System.Security.Cryptography.Apple/4.3.0": { + "dependencies": { + "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple": "4.3.0" + } + }, + "runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "dependencies": { + "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0" + } + }, + "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": {}, + "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": {}, + "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple/4.3.0": {}, + "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": {}, + "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": {}, + "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": {}, + "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": {}, + "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": {}, "SharpCompress/0.23.0": { "dependencies": { "System.Text.Encoding.CodePages": "4.5.1" @@ -504,339 +738,990 @@ "lib/netcoreapp3.0/Swashbuckle.AspNetCore.SwaggerUI.dll": {} } }, + "System.AppContext/4.3.0": { + "dependencies": { + "System.Runtime": "4.3.0" + } + }, "System.Buffers/4.5.1": {}, - "System.Runtime.CompilerServices.Unsafe/5.0.0": {}, - "System.Text.Encoding.CodePages/4.5.1": { + "System.Collections/4.3.0": { "dependencies": { "Microsoft.NETCore.Platforms": "2.1.2", - "System.Runtime.CompilerServices.Unsafe": "5.0.0" + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" } }, - "Microsoft.AspNetCore.Antiforgery/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Antiforgery.dll": {} - }, - "compileOnly": true + "System.Collections.Concurrent/4.3.0": { + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Diagnostics.Tracing": "4.3.0", + "System.Globalization": "4.3.0", + "System.Reflection": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Threading": "4.3.0", + "System.Threading.Tasks": "4.3.0" + } }, - "Microsoft.AspNetCore.Authentication.Abstractions/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Authentication.Abstractions.dll": {} - }, - "compileOnly": true + "System.Collections.NonGeneric/4.3.0": { + "dependencies": { + "System.Diagnostics.Debug": "4.3.0", + "System.Globalization": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Threading": "4.3.0" + } }, - "Microsoft.AspNetCore.Authentication.Cookies/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Authentication.Cookies.dll": {} - }, - "compileOnly": true + "System.Collections.Specialized/4.3.0": { + "dependencies": { + "System.Collections.NonGeneric": "4.3.0", + "System.Globalization": "4.3.0", + "System.Globalization.Extensions": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Threading": "4.3.0" + } }, - "Microsoft.AspNetCore.Authentication.Core/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Authentication.Core.dll": {} - }, - "compileOnly": true + "System.ComponentModel/4.3.0": { + "dependencies": { + "System.Runtime": "4.3.0" + } }, - "Microsoft.AspNetCore.Authentication/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Authentication.dll": {} - }, - "compileOnly": true + "System.ComponentModel.Primitives/4.3.0": { + "dependencies": { + "System.ComponentModel": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0" + } }, - "Microsoft.AspNetCore.Authentication.OAuth/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Authentication.OAuth.dll": {} - }, - "compileOnly": true + "System.ComponentModel.TypeConverter/4.3.0": { + "dependencies": { + "System.Collections": "4.3.0", + "System.Collections.NonGeneric": "4.3.0", + "System.Collections.Specialized": "4.3.0", + "System.ComponentModel": "4.3.0", + "System.ComponentModel.Primitives": "4.3.0", + "System.Globalization": "4.3.0", + "System.Linq": "4.3.0", + "System.Reflection": "4.3.0", + "System.Reflection.Extensions": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Reflection.TypeExtensions": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Threading": "4.3.0" + } }, - "Microsoft.AspNetCore.Authorization/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Authorization.dll": {} - }, - "compileOnly": true + "System.Console/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.IO": "4.3.0", + "System.Runtime": "4.3.0", + "System.Text.Encoding": "4.3.0" + } }, - "Microsoft.AspNetCore.Authorization.Policy/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Authorization.Policy.dll": {} - }, - "compileOnly": true + "System.Diagnostics.Debug/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + } }, - "Microsoft.AspNetCore.Components.Authorization/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Components.Authorization.dll": {} - }, - "compileOnly": true + "System.Diagnostics.DiagnosticSource/4.3.0": { + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Tracing": "4.3.0", + "System.Reflection": "4.3.0", + "System.Runtime": "4.3.0", + "System.Threading": "4.3.0" + } }, - "Microsoft.AspNetCore.Components/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Components.dll": {} - }, - "compileOnly": true + "System.Diagnostics.Tools/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + } }, - "Microsoft.AspNetCore.Components.Forms/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Components.Forms.dll": {} - }, - "compileOnly": true + "System.Diagnostics.Tracing/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + } }, - "Microsoft.AspNetCore.Components.Server/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Components.Server.dll": {} - }, - "compileOnly": true + "System.Dynamic.Runtime/4.3.0": { + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Linq": "4.3.0", + "System.Linq.Expressions": "4.3.0", + "System.ObjectModel": "4.3.0", + "System.Reflection": "4.3.0", + "System.Reflection.Emit": "4.3.0", + "System.Reflection.Emit.ILGeneration": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Reflection.TypeExtensions": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Threading": "4.3.0" + } }, - "Microsoft.AspNetCore.Components.Web/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Components.Web.dll": {} - }, - "compileOnly": true + "System.Globalization/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + } }, - "Microsoft.AspNetCore.Connections.Abstractions/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Connections.Abstractions.dll": {} - }, - "compileOnly": true + "System.Globalization.Calendars/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Globalization": "4.3.0", + "System.Runtime": "4.3.0" + } }, - "Microsoft.AspNetCore.CookiePolicy/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.CookiePolicy.dll": {} - }, - "compileOnly": true + "System.Globalization.Extensions/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "System.Globalization": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.InteropServices": "4.3.0" + } }, - "Microsoft.AspNetCore.Cors/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Cors.dll": {} - }, - "compileOnly": true + "System.IO/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading.Tasks": "4.3.0" + } }, - "Microsoft.AspNetCore.Cryptography.Internal/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Cryptography.Internal.dll": {} - }, - "compileOnly": true + "System.IO.Compression/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "System.Buffers": "4.5.1", + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.IO": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading": "4.3.0", + "System.Threading.Tasks": "4.3.0", + "runtime.native.System": "4.3.0", + "runtime.native.System.IO.Compression": "4.3.0" + } }, - "Microsoft.AspNetCore.Cryptography.KeyDerivation/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Cryptography.KeyDerivation.dll": {} - }, - "compileOnly": true + "System.IO.Compression.ZipFile/4.3.0": { + "dependencies": { + "System.Buffers": "4.5.1", + "System.IO": "4.3.0", + "System.IO.Compression": "4.3.0", + "System.IO.FileSystem": "4.3.0", + "System.IO.FileSystem.Primitives": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Text.Encoding": "4.3.0" + } }, - "Microsoft.AspNetCore.DataProtection.Abstractions/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.DataProtection.Abstractions.dll": {} - }, - "compileOnly": true + "System.IO.FileSystem/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.IO": "4.3.0", + "System.IO.FileSystem.Primitives": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading.Tasks": "4.3.0" + } }, - "Microsoft.AspNetCore.DataProtection/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.DataProtection.dll": {} - }, - "compileOnly": true + "System.IO.FileSystem.Primitives/4.3.0": { + "dependencies": { + "System.Runtime": "4.3.0" + } }, - "Microsoft.AspNetCore.DataProtection.Extensions/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.DataProtection.Extensions.dll": {} - }, - "compileOnly": true + "System.Linq/4.3.0": { + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0" + } }, - "Microsoft.AspNetCore.Diagnostics.Abstractions/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Diagnostics.Abstractions.dll": {} - }, - "compileOnly": true + "System.Linq.Expressions/4.3.0": { + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Globalization": "4.3.0", + "System.IO": "4.3.0", + "System.Linq": "4.3.0", + "System.ObjectModel": "4.3.0", + "System.Reflection": "4.3.0", + "System.Reflection.Emit": "4.3.0", + "System.Reflection.Emit.ILGeneration": "4.3.0", + "System.Reflection.Emit.Lightweight": "4.3.0", + "System.Reflection.Extensions": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Reflection.TypeExtensions": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Threading": "4.3.0" + } }, - "Microsoft.AspNetCore.Diagnostics/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Diagnostics.dll": {} - }, - "compileOnly": true + "System.Net.Http/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Diagnostics.DiagnosticSource": "4.3.0", + "System.Diagnostics.Tracing": "4.3.0", + "System.Globalization": "4.3.0", + "System.Globalization.Extensions": "4.3.0", + "System.IO": "4.3.0", + "System.IO.FileSystem": "4.3.0", + "System.Net.Primitives": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Security.Cryptography.Algorithms": "4.3.0", + "System.Security.Cryptography.Encoding": "4.3.0", + "System.Security.Cryptography.OpenSsl": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Security.Cryptography.X509Certificates": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading": "4.3.0", + "System.Threading.Tasks": "4.3.0", + "runtime.native.System": "4.3.0", + "runtime.native.System.Net.Http": "4.3.0", + "runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0" + } }, - "Microsoft.AspNetCore.Diagnostics.HealthChecks/5.0.0.0": { - "compile": { - "Microsoft.AspNetCore.Diagnostics.HealthChecks.dll": {} - }, - "compileOnly": true + "System.Net.Primitives/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0", + "System.Runtime.Handles": "4.3.0" + } }, - "Microsoft.AspNetCore/5.0.0.0": { + "System.Net.Sockets/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.IO": "4.3.0", + "System.Net.Primitives": "4.3.0", + "System.Runtime": "4.3.0", + "System.Threading.Tasks": "4.3.0" + } + }, + "System.ObjectModel/4.3.0": { + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Threading": "4.3.0" + } + }, + "System.Reflection/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.IO": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Runtime": "4.3.0" + } + }, + "System.Reflection.Emit/4.3.0": { + "dependencies": { + "System.IO": "4.3.0", + "System.Reflection": "4.3.0", + "System.Reflection.Emit.ILGeneration": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Runtime": "4.3.0" + } + }, + "System.Reflection.Emit.ILGeneration/4.3.0": { + "dependencies": { + "System.Reflection": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Runtime": "4.3.0" + } + }, + "System.Reflection.Emit.Lightweight/4.3.0": { + "dependencies": { + "System.Reflection": "4.3.0", + "System.Reflection.Emit.ILGeneration": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Runtime": "4.3.0" + } + }, + "System.Reflection.Extensions/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Reflection": "4.3.0", + "System.Runtime": "4.3.0" + } + }, + "System.Reflection.Primitives/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + } + }, + "System.Reflection.TypeExtensions/4.3.0": { + "dependencies": { + "System.Reflection": "4.3.0", + "System.Runtime": "4.3.0" + } + }, + "System.Resources.ResourceManager/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Globalization": "4.3.0", + "System.Reflection": "4.3.0", + "System.Runtime": "4.3.0" + } + }, + "System.Runtime/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0" + } + }, + "System.Runtime.CompilerServices.Unsafe/5.0.0": {}, + "System.Runtime.Extensions/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + } + }, + "System.Runtime.Handles/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + } + }, + "System.Runtime.InteropServices/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Reflection": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Handles": "4.3.0" + } + }, + "System.Runtime.InteropServices.RuntimeInformation/4.3.0": { + "dependencies": { + "System.Reflection": "4.3.0", + "System.Reflection.Extensions": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Threading": "4.3.0", + "runtime.native.System": "4.3.0" + } + }, + "System.Runtime.Numerics/4.3.0": { + "dependencies": { + "System.Globalization": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0" + } + }, + "System.Runtime.Serialization.Formatters/4.3.0": { + "dependencies": { + "System.Collections": "4.3.0", + "System.Reflection": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Serialization.Primitives": "4.3.0" + } + }, + "System.Runtime.Serialization.Primitives/4.3.0": { + "dependencies": { + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0" + } + }, + "System.Security.Cryptography.Algorithms/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "System.Collections": "4.3.0", + "System.IO": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Runtime.Numerics": "4.3.0", + "System.Security.Cryptography.Encoding": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Text.Encoding": "4.3.0", + "runtime.native.System.Security.Cryptography.Apple": "4.3.0", + "runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0" + } + }, + "System.Security.Cryptography.Cng/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "System.IO": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Security.Cryptography.Algorithms": "4.3.0", + "System.Security.Cryptography.Encoding": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Text.Encoding": "4.3.0" + } + }, + "System.Security.Cryptography.Csp/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "System.IO": "4.3.0", + "System.Reflection": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Security.Cryptography.Algorithms": "4.3.0", + "System.Security.Cryptography.Encoding": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading": "4.3.0" + } + }, + "System.Security.Cryptography.Encoding/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "System.Collections": "4.3.0", + "System.Collections.Concurrent": "4.3.0", + "System.Linq": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Text.Encoding": "4.3.0", + "runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0" + } + }, + "System.Security.Cryptography.OpenSsl/4.3.0": { + "dependencies": { + "System.Collections": "4.3.0", + "System.IO": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Runtime.Numerics": "4.3.0", + "System.Security.Cryptography.Algorithms": "4.3.0", + "System.Security.Cryptography.Encoding": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Text.Encoding": "4.3.0", + "runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0" + } + }, + "System.Security.Cryptography.Primitives/4.3.0": { + "dependencies": { + "System.Diagnostics.Debug": "4.3.0", + "System.Globalization": "4.3.0", + "System.IO": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Threading": "4.3.0", + "System.Threading.Tasks": "4.3.0" + } + }, + "System.Security.Cryptography.X509Certificates/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Globalization": "4.3.0", + "System.Globalization.Calendars": "4.3.0", + "System.IO": "4.3.0", + "System.IO.FileSystem": "4.3.0", + "System.IO.FileSystem.Primitives": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Runtime.Numerics": "4.3.0", + "System.Security.Cryptography.Algorithms": "4.3.0", + "System.Security.Cryptography.Cng": "4.3.0", + "System.Security.Cryptography.Csp": "4.3.0", + "System.Security.Cryptography.Encoding": "4.3.0", + "System.Security.Cryptography.OpenSsl": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading": "4.3.0", + "runtime.native.System": "4.3.0", + "runtime.native.System.Net.Http": "4.3.0", + "runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0" + } + }, + "System.Text.Encoding/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + } + }, + "System.Text.Encoding.CodePages/4.5.1": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "System.Runtime.CompilerServices.Unsafe": "5.0.0" + } + }, + "System.Text.Encoding.Extensions/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0", + "System.Text.Encoding": "4.3.0" + } + }, + "System.Text.RegularExpressions/4.3.0": { + "dependencies": { + "System.Runtime": "4.3.0" + } + }, + "System.Threading/4.3.0": { + "dependencies": { + "System.Runtime": "4.3.0", + "System.Threading.Tasks": "4.3.0" + } + }, + "System.Threading.Tasks/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + } + }, + "System.Threading.Tasks.Extensions/4.3.0": { + "dependencies": { + "System.Collections": "4.3.0", + "System.Runtime": "4.3.0", + "System.Threading.Tasks": "4.3.0" + } + }, + "System.Threading.Timer/4.3.0": { + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + } + }, + "System.Xml.ReaderWriter/4.3.0": { + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Globalization": "4.3.0", + "System.IO": "4.3.0", + "System.IO.FileSystem": "4.3.0", + "System.IO.FileSystem.Primitives": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Text.Encoding.Extensions": "4.3.0", + "System.Text.RegularExpressions": "4.3.0", + "System.Threading.Tasks": "4.3.0", + "System.Threading.Tasks.Extensions": "4.3.0" + } + }, + "System.Xml.XDocument/4.3.0": { + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Diagnostics.Tools": "4.3.0", + "System.Globalization": "4.3.0", + "System.IO": "4.3.0", + "System.Reflection": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading": "4.3.0", + "System.Xml.ReaderWriter": "4.3.0" + } + }, + "System.Xml.XmlDocument/4.3.0": { + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Globalization": "4.3.0", + "System.IO": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading": "4.3.0", + "System.Xml.ReaderWriter": "4.3.0" + } + }, + "Microsoft.AspNetCore.Antiforgery/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.dll": {} + "Microsoft.AspNetCore.Antiforgery.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.HostFiltering/5.0.0.0": { + "Microsoft.AspNetCore.Authentication.Abstractions/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.HostFiltering.dll": {} + "Microsoft.AspNetCore.Authentication.Abstractions.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Hosting.Abstractions/5.0.0.0": { + "Microsoft.AspNetCore.Authentication.Cookies/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Hosting.Abstractions.dll": {} + "Microsoft.AspNetCore.Authentication.Cookies.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Hosting/5.0.0.0": { + "Microsoft.AspNetCore.Authentication.Core/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Hosting.dll": {} + "Microsoft.AspNetCore.Authentication.Core.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Hosting.Server.Abstractions/5.0.0.0": { + "Microsoft.AspNetCore.Authentication/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Hosting.Server.Abstractions.dll": {} + "Microsoft.AspNetCore.Authentication.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Html.Abstractions/5.0.0.0": { + "Microsoft.AspNetCore.Authentication.OAuth/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Html.Abstractions.dll": {} + "Microsoft.AspNetCore.Authentication.OAuth.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Http.Abstractions/5.0.0.0": { + "Microsoft.AspNetCore.Authorization/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Http.Abstractions.dll": {} + "Microsoft.AspNetCore.Authorization.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Http.Connections.Common/5.0.0.0": { + "Microsoft.AspNetCore.Authorization.Policy/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Http.Connections.Common.dll": {} + "Microsoft.AspNetCore.Authorization.Policy.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Http.Connections/5.0.0.0": { + "Microsoft.AspNetCore.Components.Authorization/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Http.Connections.dll": {} + "Microsoft.AspNetCore.Components.Authorization.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Http/5.0.0.0": { + "Microsoft.AspNetCore.Components/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Http.dll": {} + "Microsoft.AspNetCore.Components.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Http.Extensions/5.0.0.0": { + "Microsoft.AspNetCore.Components.Forms/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Http.Extensions.dll": {} + "Microsoft.AspNetCore.Components.Forms.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Http.Features/5.0.0.0": { + "Microsoft.AspNetCore.Components.Server/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Http.Features.dll": {} + "Microsoft.AspNetCore.Components.Server.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.HttpOverrides/5.0.0.0": { + "Microsoft.AspNetCore.Components.Web/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.HttpOverrides.dll": {} + "Microsoft.AspNetCore.Components.Web.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.HttpsPolicy/5.0.0.0": { + "Microsoft.AspNetCore.Connections.Abstractions/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.HttpsPolicy.dll": {} + "Microsoft.AspNetCore.Connections.Abstractions.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Identity/5.0.0.0": { + "Microsoft.AspNetCore.CookiePolicy/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Identity.dll": {} + "Microsoft.AspNetCore.CookiePolicy.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Localization/5.0.0.0": { + "Microsoft.AspNetCore.Cors/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Localization.dll": {} + "Microsoft.AspNetCore.Cors.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Localization.Routing/5.0.0.0": { + "Microsoft.AspNetCore.Cryptography.Internal/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Localization.Routing.dll": {} + "Microsoft.AspNetCore.Cryptography.Internal.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Metadata/5.0.0.0": { + "Microsoft.AspNetCore.Cryptography.KeyDerivation/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Metadata.dll": {} + "Microsoft.AspNetCore.Cryptography.KeyDerivation.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Mvc.Abstractions/5.0.0.0": { + "Microsoft.AspNetCore.DataProtection.Abstractions/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Mvc.Abstractions.dll": {} + "Microsoft.AspNetCore.DataProtection.Abstractions.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Mvc.ApiExplorer/5.0.0.0": { + "Microsoft.AspNetCore.DataProtection/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Mvc.ApiExplorer.dll": {} + "Microsoft.AspNetCore.DataProtection.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Mvc.Core/5.0.0.0": { + "Microsoft.AspNetCore.DataProtection.Extensions/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Mvc.Core.dll": {} + "Microsoft.AspNetCore.DataProtection.Extensions.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Mvc.Cors/5.0.0.0": { + "Microsoft.AspNetCore.Diagnostics.Abstractions/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Mvc.Cors.dll": {} + "Microsoft.AspNetCore.Diagnostics.Abstractions.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Mvc.DataAnnotations/5.0.0.0": { + "Microsoft.AspNetCore.Diagnostics/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Mvc.DataAnnotations.dll": {} + "Microsoft.AspNetCore.Diagnostics.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Mvc/5.0.0.0": { + "Microsoft.AspNetCore.Diagnostics.HealthChecks/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Mvc.dll": {} + "Microsoft.AspNetCore.Diagnostics.HealthChecks.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Mvc.Formatters.Json/5.0.0.0": { + "Microsoft.AspNetCore/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Mvc.Formatters.Json.dll": {} + "Microsoft.AspNetCore.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Mvc.Formatters.Xml/5.0.0.0": { + "Microsoft.AspNetCore.HostFiltering/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Mvc.Formatters.Xml.dll": {} + "Microsoft.AspNetCore.HostFiltering.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Mvc.Localization/5.0.0.0": { + "Microsoft.AspNetCore.Hosting.Abstractions/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Mvc.Localization.dll": {} + "Microsoft.AspNetCore.Hosting.Abstractions.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Mvc.Razor/5.0.0.0": { + "Microsoft.AspNetCore.Hosting/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Mvc.Razor.dll": {} + "Microsoft.AspNetCore.Hosting.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Mvc.RazorPages/5.0.0.0": { + "Microsoft.AspNetCore.Hosting.Server.Abstractions/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Mvc.RazorPages.dll": {} + "Microsoft.AspNetCore.Hosting.Server.Abstractions.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Mvc.TagHelpers/5.0.0.0": { + "Microsoft.AspNetCore.Html.Abstractions/5.0.0.0": { "compile": { - "Microsoft.AspNetCore.Mvc.TagHelpers.dll": {} + "Microsoft.AspNetCore.Html.Abstractions.dll": {} }, "compileOnly": true }, - "Microsoft.AspNetCore.Mvc.ViewFeatures/5.0.0.0": { + "Microsoft.AspNetCore.Http.Abstractions/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Http.Abstractions.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Http.Connections.Common/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Http.Connections.Common.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Http.Connections/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Http.Connections.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Http/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Http.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Http.Extensions/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Http.Extensions.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Http.Features/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Http.Features.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.HttpOverrides/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.HttpOverrides.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.HttpsPolicy/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.HttpsPolicy.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Identity/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Identity.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Localization/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Localization.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Localization.Routing/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Localization.Routing.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Metadata/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Metadata.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Mvc.Abstractions/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Mvc.Abstractions.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Mvc.ApiExplorer/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Mvc.ApiExplorer.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Mvc.Core/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Mvc.Core.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Mvc.Cors/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Mvc.Cors.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Mvc.DataAnnotations/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Mvc.DataAnnotations.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Mvc/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Mvc.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Mvc.Formatters.Json/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Mvc.Formatters.Json.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Mvc.Formatters.Xml/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Mvc.Formatters.Xml.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Mvc.Localization/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Mvc.Localization.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Mvc.Razor/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Mvc.Razor.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Mvc.RazorPages/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Mvc.RazorPages.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Mvc.TagHelpers/5.0.0.0": { + "compile": { + "Microsoft.AspNetCore.Mvc.TagHelpers.dll": {} + }, + "compileOnly": true + }, + "Microsoft.AspNetCore.Mvc.ViewFeatures/5.0.0.0": { "compile": { "Microsoft.AspNetCore.Mvc.ViewFeatures.dll": {} }, @@ -974,7 +1859,7 @@ }, "compileOnly": true }, - "Microsoft.CSharp/5.0.0.0": { + "Microsoft.CSharp.Reference/5.0.0.0": { "compile": { "Microsoft.CSharp.dll": {} }, @@ -1262,7 +2147,7 @@ }, "compileOnly": true }, - "Microsoft.Win32.Primitives/5.0.0.0": { + "Microsoft.Win32.Primitives.Reference/5.0.0.0": { "compile": { "Microsoft.Win32.Primitives.dll": {} }, @@ -1286,7 +2171,7 @@ }, "compileOnly": true }, - "System.AppContext/5.0.0.0": { + "System.AppContext.Reference/5.0.0.0": { "compile": { "System.AppContext.dll": {} }, @@ -1298,13 +2183,13 @@ }, "compileOnly": true }, - "System.Collections.Concurrent/5.0.0.0": { + "System.Collections.Concurrent.Reference/5.0.0.0": { "compile": { "System.Collections.Concurrent.dll": {} }, "compileOnly": true }, - "System.Collections/5.0.0.0": { + "System.Collections.Reference/5.0.0.0": { "compile": { "System.Collections.dll": {} }, @@ -1316,13 +2201,13 @@ }, "compileOnly": true }, - "System.Collections.NonGeneric/5.0.0.0": { + "System.Collections.NonGeneric.Reference/5.0.0.0": { "compile": { "System.Collections.NonGeneric.dll": {} }, "compileOnly": true }, - "System.Collections.Specialized/5.0.0.0": { + "System.Collections.Specialized.Reference/5.0.0.0": { "compile": { "System.Collections.Specialized.dll": {} }, @@ -1340,7 +2225,7 @@ }, "compileOnly": true }, - "System.ComponentModel/5.0.0.0": { + "System.ComponentModel.Reference/5.0.0.0": { "compile": { "System.ComponentModel.dll": {} }, @@ -1352,13 +2237,13 @@ }, "compileOnly": true }, - "System.ComponentModel.Primitives/5.0.0.0": { + "System.ComponentModel.Primitives.Reference/5.0.0.0": { "compile": { "System.ComponentModel.Primitives.dll": {} }, "compileOnly": true }, - "System.ComponentModel.TypeConverter/5.0.0.0": { + "System.ComponentModel.TypeConverter.Reference/5.0.0.0": { "compile": { "System.ComponentModel.TypeConverter.dll": {} }, @@ -1370,7 +2255,7 @@ }, "compileOnly": true }, - "System.Console/5.0.0.0": { + "System.Console.Reference/5.0.0.0": { "compile": { "System.Console.dll": {} }, @@ -1406,13 +2291,13 @@ }, "compileOnly": true }, - "System.Diagnostics.Debug/5.0.0.0": { + "System.Diagnostics.Debug.Reference/5.0.0.0": { "compile": { "System.Diagnostics.Debug.dll": {} }, "compileOnly": true }, - "System.Diagnostics.DiagnosticSource/5.0.0.0": { + "System.Diagnostics.DiagnosticSource.Reference/5.0.0.0": { "compile": { "System.Diagnostics.DiagnosticSource.dll": {} }, @@ -1448,7 +2333,7 @@ }, "compileOnly": true }, - "System.Diagnostics.Tools/5.0.0.0": { + "System.Diagnostics.Tools.Reference/5.0.0.0": { "compile": { "System.Diagnostics.Tools.dll": {} }, @@ -1460,7 +2345,7 @@ }, "compileOnly": true }, - "System.Diagnostics.Tracing/5.0.0.0": { + "System.Diagnostics.Tracing.Reference/5.0.0.0": { "compile": { "System.Diagnostics.Tracing.dll": {} }, @@ -1484,7 +2369,7 @@ }, "compileOnly": true }, - "System.Dynamic.Runtime/5.0.0.0": { + "System.Dynamic.Runtime.Reference/5.0.0.0": { "compile": { "System.Dynamic.Runtime.dll": {} }, @@ -1496,19 +2381,19 @@ }, "compileOnly": true }, - "System.Globalization.Calendars/5.0.0.0": { + "System.Globalization.Calendars.Reference/5.0.0.0": { "compile": { "System.Globalization.Calendars.dll": {} }, "compileOnly": true }, - "System.Globalization/5.0.0.0": { + "System.Globalization.Reference/5.0.0.0": { "compile": { "System.Globalization.dll": {} }, "compileOnly": true }, - "System.Globalization.Extensions/5.0.0.0": { + "System.Globalization.Extensions.Reference/5.0.0.0": { "compile": { "System.Globalization.Extensions.dll": {} }, @@ -1520,7 +2405,7 @@ }, "compileOnly": true }, - "System.IO.Compression/5.0.0.0": { + "System.IO.Compression.Reference/5.0.0.0": { "compile": { "System.IO.Compression.dll": {} }, @@ -1532,19 +2417,19 @@ }, "compileOnly": true }, - "System.IO.Compression.ZipFile/5.0.0.0": { + "System.IO.Compression.ZipFile.Reference/5.0.0.0": { "compile": { "System.IO.Compression.ZipFile.dll": {} }, "compileOnly": true }, - "System.IO/5.0.0.0": { + "System.IO.Reference/5.0.0.0": { "compile": { "System.IO.dll": {} }, "compileOnly": true }, - "System.IO.FileSystem/5.0.0.0": { + "System.IO.FileSystem.Reference/5.0.0.0": { "compile": { "System.IO.FileSystem.dll": {} }, @@ -1556,7 +2441,7 @@ }, "compileOnly": true }, - "System.IO.FileSystem.Primitives/5.0.0.0": { + "System.IO.FileSystem.Primitives.Reference/5.0.0.0": { "compile": { "System.IO.FileSystem.Primitives.dll": {} }, @@ -1598,13 +2483,13 @@ }, "compileOnly": true }, - "System.Linq/5.0.0.0": { + "System.Linq.Reference/5.0.0.0": { "compile": { "System.Linq.dll": {} }, "compileOnly": true }, - "System.Linq.Expressions/5.0.0.0": { + "System.Linq.Expressions.Reference/5.0.0.0": { "compile": { "System.Linq.Expressions.dll": {} }, @@ -1634,7 +2519,7 @@ }, "compileOnly": true }, - "System.Net.Http/5.0.0.0": { + "System.Net.Http.Reference/5.0.0.0": { "compile": { "System.Net.Http.dll": {} }, @@ -1676,7 +2561,7 @@ }, "compileOnly": true }, - "System.Net.Primitives/5.0.0.0": { + "System.Net.Primitives.Reference/5.0.0.0": { "compile": { "System.Net.Primitives.dll": {} }, @@ -1700,7 +2585,7 @@ }, "compileOnly": true }, - "System.Net.Sockets/5.0.0.0": { + "System.Net.Sockets.Reference/5.0.0.0": { "compile": { "System.Net.Sockets.dll": {} }, @@ -1748,7 +2633,7 @@ }, "compileOnly": true }, - "System.ObjectModel/5.0.0.0": { + "System.ObjectModel.Reference/5.0.0.0": { "compile": { "System.ObjectModel.dll": {} }, @@ -1760,31 +2645,31 @@ }, "compileOnly": true }, - "System.Reflection/5.0.0.0": { + "System.Reflection.Reference/5.0.0.0": { "compile": { "System.Reflection.dll": {} }, "compileOnly": true }, - "System.Reflection.Emit/5.0.0.0": { + "System.Reflection.Emit.Reference/5.0.0.0": { "compile": { "System.Reflection.Emit.dll": {} }, "compileOnly": true }, - "System.Reflection.Emit.ILGeneration/5.0.0.0": { + "System.Reflection.Emit.ILGeneration.Reference/5.0.0.0": { "compile": { "System.Reflection.Emit.ILGeneration.dll": {} }, "compileOnly": true }, - "System.Reflection.Emit.Lightweight/5.0.0.0": { + "System.Reflection.Emit.Lightweight.Reference/5.0.0.0": { "compile": { "System.Reflection.Emit.Lightweight.dll": {} }, "compileOnly": true }, - "System.Reflection.Extensions/5.0.0.0": { + "System.Reflection.Extensions.Reference/5.0.0.0": { "compile": { "System.Reflection.Extensions.dll": {} }, @@ -1796,13 +2681,13 @@ }, "compileOnly": true }, - "System.Reflection.Primitives/5.0.0.0": { + "System.Reflection.Primitives.Reference/5.0.0.0": { "compile": { "System.Reflection.Primitives.dll": {} }, "compileOnly": true }, - "System.Reflection.TypeExtensions/5.0.0.0": { + "System.Reflection.TypeExtensions.Reference/5.0.0.0": { "compile": { "System.Reflection.TypeExtensions.dll": {} }, @@ -1814,7 +2699,7 @@ }, "compileOnly": true }, - "System.Resources.ResourceManager/5.0.0.0": { + "System.Resources.ResourceManager.Reference/5.0.0.0": { "compile": { "System.Resources.ResourceManager.dll": {} }, @@ -1838,31 +2723,31 @@ }, "compileOnly": true }, - "System.Runtime/5.0.0.0": { + "System.Runtime.Reference/5.0.0.0": { "compile": { "System.Runtime.dll": {} }, "compileOnly": true }, - "System.Runtime.Extensions/5.0.0.0": { + "System.Runtime.Extensions.Reference/5.0.0.0": { "compile": { "System.Runtime.Extensions.dll": {} }, "compileOnly": true }, - "System.Runtime.Handles/5.0.0.0": { + "System.Runtime.Handles.Reference/5.0.0.0": { "compile": { "System.Runtime.Handles.dll": {} }, "compileOnly": true }, - "System.Runtime.InteropServices/5.0.0.0": { + "System.Runtime.InteropServices.Reference/5.0.0.0": { "compile": { "System.Runtime.InteropServices.dll": {} }, "compileOnly": true }, - "System.Runtime.InteropServices.RuntimeInformation/5.0.0.0": { + "System.Runtime.InteropServices.RuntimeInformation.Reference/5.0.0.0": { "compile": { "System.Runtime.InteropServices.RuntimeInformation.dll": {} }, @@ -1880,7 +2765,7 @@ }, "compileOnly": true }, - "System.Runtime.Numerics/5.0.0.0": { + "System.Runtime.Numerics.Reference/5.0.0.0": { "compile": { "System.Runtime.Numerics.dll": {} }, @@ -1892,7 +2777,7 @@ }, "compileOnly": true }, - "System.Runtime.Serialization.Formatters/5.0.0.0": { + "System.Runtime.Serialization.Formatters.Reference/5.0.0.0": { "compile": { "System.Runtime.Serialization.Formatters.dll": {} }, @@ -1904,7 +2789,7 @@ }, "compileOnly": true }, - "System.Runtime.Serialization.Primitives/5.0.0.0": { + "System.Runtime.Serialization.Primitives.Reference/5.0.0.0": { "compile": { "System.Runtime.Serialization.Primitives.dll": {} }, @@ -1928,37 +2813,37 @@ }, "compileOnly": true }, - "System.Security.Cryptography.Algorithms/5.0.0.0": { + "System.Security.Cryptography.Algorithms.Reference/5.0.0.0": { "compile": { "System.Security.Cryptography.Algorithms.dll": {} }, "compileOnly": true }, - "System.Security.Cryptography.Cng/5.0.0.0": { + "System.Security.Cryptography.Cng.Reference/5.0.0.0": { "compile": { "System.Security.Cryptography.Cng.dll": {} }, "compileOnly": true }, - "System.Security.Cryptography.Csp/5.0.0.0": { + "System.Security.Cryptography.Csp.Reference/5.0.0.0": { "compile": { "System.Security.Cryptography.Csp.dll": {} }, "compileOnly": true }, - "System.Security.Cryptography.Encoding/5.0.0.0": { + "System.Security.Cryptography.Encoding.Reference/5.0.0.0": { "compile": { "System.Security.Cryptography.Encoding.dll": {} }, "compileOnly": true }, - "System.Security.Cryptography.Primitives/5.0.0.0": { + "System.Security.Cryptography.Primitives.Reference/5.0.0.0": { "compile": { "System.Security.Cryptography.Primitives.dll": {} }, "compileOnly": true }, - "System.Security.Cryptography.X509Certificates/5.0.0.0": { + "System.Security.Cryptography.X509Certificates.Reference/5.0.0.0": { "compile": { "System.Security.Cryptography.X509Certificates.dll": {} }, @@ -2018,13 +2903,13 @@ }, "compileOnly": true }, - "System.Text.Encoding/5.0.0.0": { + "System.Text.Encoding.Reference/5.0.0.0": { "compile": { "System.Text.Encoding.dll": {} }, "compileOnly": true }, - "System.Text.Encoding.Extensions/5.0.0.0": { + "System.Text.Encoding.Extensions.Reference/5.0.0.0": { "compile": { "System.Text.Encoding.Extensions.dll": {} }, @@ -2042,7 +2927,7 @@ }, "compileOnly": true }, - "System.Text.RegularExpressions/5.0.0.0": { + "System.Text.RegularExpressions.Reference/5.0.0.0": { "compile": { "System.Text.RegularExpressions.dll": {} }, @@ -2054,7 +2939,7 @@ }, "compileOnly": true }, - "System.Threading/5.0.0.0": { + "System.Threading.Reference/5.0.0.0": { "compile": { "System.Threading.dll": {} }, @@ -2072,13 +2957,13 @@ }, "compileOnly": true }, - "System.Threading.Tasks/5.0.0.0": { + "System.Threading.Tasks.Reference/5.0.0.0": { "compile": { "System.Threading.Tasks.dll": {} }, "compileOnly": true }, - "System.Threading.Tasks.Extensions/5.0.0.0": { + "System.Threading.Tasks.Extensions.Reference/5.0.0.0": { "compile": { "System.Threading.Tasks.Extensions.dll": {} }, @@ -2102,7 +2987,7 @@ }, "compileOnly": true }, - "System.Threading.Timer/5.0.0.0": { + "System.Threading.Timer.Reference/5.0.0.0": { "compile": { "System.Threading.Timer.dll": {} }, @@ -2162,7 +3047,7 @@ }, "compileOnly": true }, - "System.Xml.ReaderWriter/5.0.0.0": { + "System.Xml.ReaderWriter.Reference/5.0.0.0": { "compile": { "System.Xml.ReaderWriter.dll": {} }, @@ -2174,13 +3059,13 @@ }, "compileOnly": true }, - "System.Xml.XDocument/5.0.0.0": { + "System.Xml.XDocument.Reference/5.0.0.0": { "compile": { "System.Xml.XDocument.dll": {} }, "compileOnly": true }, - "System.Xml.XmlDocument/5.0.0.0": { + "System.Xml.XmlDocument.Reference/5.0.0.0": { "compile": { "System.Xml.XmlDocument.dll": {} }, @@ -2225,6 +3110,41 @@ "path": "dnsclient/1.4.0", "hashPath": "dnsclient.1.4.0.nupkg.sha512" }, + "Microsoft.AspNet.Cors/5.2.7": { + "type": "package", + "serviceable": true, + "sha512": "sha512-r7qTj8SKzHT32F2mbB3qgE+6VUd2xILkGaq4LtMW+KP3dDAQmI//j+8Ku01I3D1GKZvB9PU8HTJPkaw7sxSLtQ==", + "path": "microsoft.aspnet.cors/5.2.7", + "hashPath": "microsoft.aspnet.cors.5.2.7.nupkg.sha512" + }, + "Microsoft.AspNet.WebApi.Client/5.2.7": { + "type": "package", + "serviceable": true, + "sha512": "sha512-/76fAHknzvFqbznS6Uj2sOyE9rJB3PltY+f53TH8dX9RiGhk02EhuFCWljSj5nnqKaTsmma8DFR50OGyQ4yJ1g==", + "path": "microsoft.aspnet.webapi.client/5.2.7", + "hashPath": "microsoft.aspnet.webapi.client.5.2.7.nupkg.sha512" + }, + "Microsoft.AspNet.WebApi.Core/5.2.7": { + "type": "package", + "serviceable": true, + "sha512": "sha512-gM2QzApnHdy1FbKUJ/ROGJSm69P2G+HMoVd/t5Vq1O/zZ5TI4IKC9PX6nUfRt/NHgebZOIWHpB4/4K4inuy4yQ==", + "path": "microsoft.aspnet.webapi.core/5.2.7", + "hashPath": "microsoft.aspnet.webapi.core.5.2.7.nupkg.sha512" + }, + "Microsoft.AspNet.WebApi.Cors/5.2.7": { + "type": "package", + "serviceable": true, + "sha512": "sha512-LUY5ufoiYLHKZXdrrNe7GlAwmu9WlyrX5iUtBSLwFZ31/tvPobyU7j1E31OWVdGZMBvRCxKbfyB7unxgrjTRpA==", + "path": "microsoft.aspnet.webapi.cors/5.2.7", + "hashPath": "microsoft.aspnet.webapi.cors.5.2.7.nupkg.sha512" + }, + "Microsoft.CSharp/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-P+MBhIM0YX+JqROuf7i306ZLJEjQYA9uUyRDE+OqwUI5sh41e2ZbPQV3LfAPh+29cmceE1pUffXsGfR4eMY3KA==", + "path": "microsoft.csharp/4.3.0", + "hashPath": "microsoft.csharp.4.3.0.nupkg.sha512" + }, "Microsoft.Extensions.ApiDescription.Server/3.0.0": { "type": "package", "serviceable": true, @@ -2239,6 +3159,13 @@ "path": "microsoft.netcore.platforms/2.1.2", "hashPath": "microsoft.netcore.platforms.2.1.2.nupkg.sha512" }, + "Microsoft.NETCore.Targets/1.1.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-aOZA3BWfz9RXjpzt0sRJJMjAscAUm3Hoa4UWAfceV9UTYxgwZ1lZt5nO2myFf+/jetYQo4uTP7zS8sJY67BBxg==", + "path": "microsoft.netcore.targets/1.1.0", + "hashPath": "microsoft.netcore.targets.1.1.0.nupkg.sha512" + }, "Microsoft.OpenApi/1.2.3": { "type": "package", "serviceable": true, @@ -2246,6 +3173,13 @@ "path": "microsoft.openapi/1.2.3", "hashPath": "microsoft.openapi.1.2.3.nupkg.sha512" }, + "Microsoft.Win32.Primitives/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-9ZQKCWxH7Ijp9BfahvL2Zyf1cJIk8XYLF6Yjzr2yi0b2cOut/HQ31qf1ThHAgCc3WiZMdnWcfJCgN82/0UunxA==", + "path": "microsoft.win32.primitives/4.3.0", + "hashPath": "microsoft.win32.primitives.4.3.0.nupkg.sha512" + }, "MongoDB.Bson/2.13.2": { "type": "package", "serviceable": true, @@ -2274,6 +3208,139 @@ "path": "mongodb.libmongocrypt/1.2.2", "hashPath": "mongodb.libmongocrypt.1.2.2.nupkg.sha512" }, + "NETStandard.Library/1.6.1": { + "type": "package", + "serviceable": true, + "sha512": "sha512-WcSp3+vP+yHNgS8EV5J7pZ9IRpeDuARBPN28by8zqff1wJQXm26PVU8L3/fYLBJVU7BtDyqNVWq2KlCVvSSR4A==", + "path": "netstandard.library/1.6.1", + "hashPath": "netstandard.library.1.6.1.nupkg.sha512" + }, + "Newtonsoft.Json/10.0.1": { + "type": "package", + "serviceable": true, + "sha512": "sha512-ebWzW9j2nwxQeBo59As2TYn7nYr9BHicqqCwHOD1Vdo+50HBtLPuqdiCYJcLdTRknpYis/DSEOQz5KmZxwrIAg==", + "path": "newtonsoft.json/10.0.1", + "hashPath": "newtonsoft.json.10.0.1.nupkg.sha512" + }, + "Newtonsoft.Json.Bson/1.0.1": { + "type": "package", + "serviceable": true, + "sha512": "sha512-5PYT/IqQ+UK31AmZiSS102R6EsTo+LGTSI8bp7WAUqDKaF4wHXD8U9u4WxTI1vc64tYi++8p3dk3WWNqPFgldw==", + "path": "newtonsoft.json.bson/1.0.1", + "hashPath": "newtonsoft.json.bson.1.0.1.nupkg.sha512" + }, + "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-HdSSp5MnJSsg08KMfZThpuLPJpPwE5hBXvHwoKWosyHHfe8Mh5WKT0ylEOf6yNzX6Ngjxe4Whkafh5q7Ymac4Q==", + "path": "runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "hashPath": "runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512" + }, + "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-+yH1a49wJMy8Zt4yx5RhJrxO/DBDByAiCzNwiETI+1S4mPdCu0OY4djdciC7Vssk0l22wQaDLrXxXkp+3+7bVA==", + "path": "runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "hashPath": "runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512" + }, + "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-c3YNH1GQJbfIPJeCnr4avseugSqPrxwIqzthYyZDN6EuOyNOzq+y2KSUfRcXauya1sF4foESTgwM5e1A8arAKw==", + "path": "runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "hashPath": "runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512" + }, + "runtime.native.System/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-c/qWt2LieNZIj1jGnVNsE2Kl23Ya2aSTBuXMD6V7k9KWr6l16Tqdwq+hJScEpWER9753NWC8h96PaVNY5Ld7Jw==", + "path": "runtime.native.system/4.3.0", + "hashPath": "runtime.native.system.4.3.0.nupkg.sha512" + }, + "runtime.native.System.IO.Compression/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-INBPonS5QPEgn7naufQFXJEp3zX6L4bwHgJ/ZH78aBTpeNfQMtf7C6VrAFhlq2xxWBveIOWyFzQjJ8XzHMhdOQ==", + "path": "runtime.native.system.io.compression/4.3.0", + "hashPath": "runtime.native.system.io.compression.4.3.0.nupkg.sha512" + }, + "runtime.native.System.Net.Http/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-ZVuZJqnnegJhd2k/PtAbbIcZ3aZeITq3sj06oKfMBSfphW3HDmk/t4ObvbOk/JA/swGR0LNqMksAh/f7gpTROg==", + "path": "runtime.native.system.net.http/4.3.0", + "hashPath": "runtime.native.system.net.http.4.3.0.nupkg.sha512" + }, + "runtime.native.System.Security.Cryptography.Apple/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-DloMk88juo0OuOWr56QG7MNchmafTLYWvABy36izkrLI5VledI0rq28KGs1i9wbpeT9NPQrx/wTf8U2vazqQ3Q==", + "path": "runtime.native.system.security.cryptography.apple/4.3.0", + "hashPath": "runtime.native.system.security.cryptography.apple.4.3.0.nupkg.sha512" + }, + "runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-NS1U+700m4KFRHR5o4vo9DSlTmlCKu/u7dtE5sUHVIPB+xpXxYQvgBgA6wEIeCz6Yfn0Z52/72WYsToCEPJnrw==", + "path": "runtime.native.system.security.cryptography.openssl/4.3.0", + "hashPath": "runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512" + }, + "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-b3pthNgxxFcD+Pc0WSEoC0+md3MyhRS6aCEeenvNE3Fdw1HyJ18ZhRFVJJzIeR/O/jpxPboB805Ho0T3Ul7w8A==", + "path": "runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "hashPath": "runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512" + }, + "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-KeLz4HClKf+nFS7p/6Fi/CqyLXh81FpiGzcmuS8DGi9lUqSnZ6Es23/gv2O+1XVGfrbNmviF7CckBpavkBoIFQ==", + "path": "runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "hashPath": "runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512" + }, + "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-kVXCuMTrTlxq4XOOMAysuNwsXWpYeboGddNGpIgNSZmv1b6r/s/DPk0fYMB7Q5Qo4bY68o48jt4T4y5BVecbCQ==", + "path": "runtime.osx.10.10-x64.runtime.native.system.security.cryptography.apple/4.3.0", + "hashPath": "runtime.osx.10.10-x64.runtime.native.system.security.cryptography.apple.4.3.0.nupkg.sha512" + }, + "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-X7IdhILzr4ROXd8mI1BUCQMSHSQwelUlBjF1JyTKCjXaOGn2fB4EKBxQbCK2VjO3WaWIdlXZL3W6TiIVnrhX4g==", + "path": "runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "hashPath": "runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512" + }, + "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-nyFNiCk/r+VOiIqreLix8yN+q3Wga9+SE8BCgkf+2BwEKiNx6DyvFjCgkfV743/grxv8jHJ8gUK4XEQw7yzRYg==", + "path": "runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "hashPath": "runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512" + }, + "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-ytoewC6wGorL7KoCAvRfsgoJPJbNq+64k2SqW6JcOAebWsFUvCCYgfzQMrnpvPiEl4OrblUlhF2ji+Q1+SVLrQ==", + "path": "runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "hashPath": "runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512" + }, + "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-I8bKw2I8k58Wx7fMKQJn2R8lamboCAiHfHeV/pS65ScKWMMI0+wJkLYlEKvgW1D/XvSl/221clBoR2q9QNNM7A==", + "path": "runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "hashPath": "runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512" + }, + "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-VB5cn/7OzUfzdnC8tqAIMQciVLiq2epm2NrAm1E9OjNRyG4lVhfR61SMcLizejzQP8R8Uf/0l5qOIbUEi+RdEg==", + "path": "runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "hashPath": "runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512" + }, "SharpCompress/0.23.0": { "type": "package", "serviceable": true, @@ -2309,6 +3376,13 @@ "path": "swashbuckle.aspnetcore.swaggerui/5.6.3", "hashPath": "swashbuckle.aspnetcore.swaggerui.5.6.3.nupkg.sha512" }, + "System.AppContext/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-fKC+rmaLfeIzUhagxY17Q9siv/sPrjjKcfNg1Ic8IlQkZLipo8ljcaZQu4VtI4Jqbzjc2VTjzGLF6WmsRXAEgA==", + "path": "system.appcontext/4.3.0", + "hashPath": "system.appcontext.4.3.0.nupkg.sha512" + }, "System.Buffers/4.5.1": { "type": "package", "serviceable": true, @@ -2316,6 +3390,258 @@ "path": "system.buffers/4.5.1", "hashPath": "system.buffers.4.5.1.nupkg.sha512" }, + "System.Collections/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-3Dcj85/TBdVpL5Zr+gEEBUuFe2icOnLalmEh9hfck1PTYbbyWuZgh4fmm2ysCLTrqLQw6t3TgTyJ+VLp+Qb+Lw==", + "path": "system.collections/4.3.0", + "hashPath": "system.collections.4.3.0.nupkg.sha512" + }, + "System.Collections.Concurrent/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-ztl69Xp0Y/UXCL+3v3tEU+lIy+bvjKNUmopn1wep/a291pVPK7dxBd6T7WnlQqRog+d1a/hSsgRsmFnIBKTPLQ==", + "path": "system.collections.concurrent/4.3.0", + "hashPath": "system.collections.concurrent.4.3.0.nupkg.sha512" + }, + "System.Collections.NonGeneric/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-prtjIEMhGUnQq6RnPEYLpFt8AtLbp9yq2zxOSrY7KJJZrw25Fi97IzBqY7iqssbM61Ek5b8f3MG/sG1N2sN5KA==", + "path": "system.collections.nongeneric/4.3.0", + "hashPath": "system.collections.nongeneric.4.3.0.nupkg.sha512" + }, + "System.Collections.Specialized/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-Epx8PoVZR0iuOnJJDzp7pWvdfMMOAvpUo95pC4ScH2mJuXkKA2Y4aR3cG9qt2klHgSons1WFh4kcGW7cSXvrxg==", + "path": "system.collections.specialized/4.3.0", + "hashPath": "system.collections.specialized.4.3.0.nupkg.sha512" + }, + "System.ComponentModel/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-VyGn1jGRZVfxnh8EdvDCi71v3bMXrsu8aYJOwoV7SNDLVhiEqwP86pPMyRGsDsxhXAm2b3o9OIqeETfN5qfezw==", + "path": "system.componentmodel/4.3.0", + "hashPath": "system.componentmodel.4.3.0.nupkg.sha512" + }, + "System.ComponentModel.Primitives/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-j8GUkCpM8V4d4vhLIIoBLGey2Z5bCkMVNjEZseyAlm4n5arcsJOeI3zkUP+zvZgzsbLTYh4lYeP/ZD/gdIAPrw==", + "path": "system.componentmodel.primitives/4.3.0", + "hashPath": "system.componentmodel.primitives.4.3.0.nupkg.sha512" + }, + "System.ComponentModel.TypeConverter/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-16pQ6P+EdhcXzPiEK4kbA953Fu0MNG2ovxTZU81/qsCd1zPRsKc3uif5NgvllCY598k6bI0KUyKW8fanlfaDQg==", + "path": "system.componentmodel.typeconverter/4.3.0", + "hashPath": "system.componentmodel.typeconverter.4.3.0.nupkg.sha512" + }, + "System.Console/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-DHDrIxiqk1h03m6khKWV2X8p/uvN79rgSqpilL6uzpmSfxfU5ng8VcPtW4qsDsQDHiTv6IPV9TmD5M/vElPNLg==", + "path": "system.console/4.3.0", + "hashPath": "system.console.4.3.0.nupkg.sha512" + }, + "System.Diagnostics.Debug/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-ZUhUOdqmaG5Jk3Xdb8xi5kIyQYAA4PnTNlHx1mu9ZY3qv4ELIdKbnL/akbGaKi2RnNUWaZsAs31rvzFdewTj2g==", + "path": "system.diagnostics.debug/4.3.0", + "hashPath": "system.diagnostics.debug.4.3.0.nupkg.sha512" + }, + "System.Diagnostics.DiagnosticSource/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-tD6kosZnTAGdrEa0tZSuFyunMbt/5KYDnHdndJYGqZoNy00XVXyACd5d6KnE1YgYv3ne2CjtAfNXo/fwEhnKUA==", + "path": "system.diagnostics.diagnosticsource/4.3.0", + "hashPath": "system.diagnostics.diagnosticsource.4.3.0.nupkg.sha512" + }, + "System.Diagnostics.Tools/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-UUvkJfSYJMM6x527dJg2VyWPSRqIVB0Z7dbjHst1zmwTXz5CcXSYJFWRpuigfbO1Lf7yfZiIaEUesfnl/g5EyA==", + "path": "system.diagnostics.tools/4.3.0", + "hashPath": "system.diagnostics.tools.4.3.0.nupkg.sha512" + }, + "System.Diagnostics.Tracing/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-rswfv0f/Cqkh78rA5S8eN8Neocz234+emGCtTF3lxPY96F+mmmUen6tbn0glN6PMvlKQb9bPAY5e9u7fgPTkKw==", + "path": "system.diagnostics.tracing/4.3.0", + "hashPath": "system.diagnostics.tracing.4.3.0.nupkg.sha512" + }, + "System.Dynamic.Runtime/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-SNVi1E/vfWUAs/WYKhE9+qlS6KqK0YVhnlT0HQtr8pMIA8YX3lwy3uPMownDwdYISBdmAF/2holEIldVp85Wag==", + "path": "system.dynamic.runtime/4.3.0", + "hashPath": "system.dynamic.runtime.4.3.0.nupkg.sha512" + }, + "System.Globalization/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-kYdVd2f2PAdFGblzFswE4hkNANJBKRmsfa2X5LG2AcWE1c7/4t0pYae1L8vfZ5xvE2nK/R9JprtToA61OSHWIg==", + "path": "system.globalization/4.3.0", + "hashPath": "system.globalization.4.3.0.nupkg.sha512" + }, + "System.Globalization.Calendars/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-GUlBtdOWT4LTV3I+9/PJW+56AnnChTaOqqTLFtdmype/L500M2LIyXgmtd9X2P2VOkmJd5c67H5SaC2QcL1bFA==", + "path": "system.globalization.calendars/4.3.0", + "hashPath": "system.globalization.calendars.4.3.0.nupkg.sha512" + }, + "System.Globalization.Extensions/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-FhKmdR6MPG+pxow6wGtNAWdZh7noIOpdD5TwQ3CprzgIE1bBBoim0vbR1+AWsWjQmU7zXHgQo4TWSP6lCeiWcQ==", + "path": "system.globalization.extensions/4.3.0", + "hashPath": "system.globalization.extensions.4.3.0.nupkg.sha512" + }, + "System.IO/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-3qjaHvxQPDpSOYICjUoTsmoq5u6QJAFRUITgeT/4gqkF1bajbSmb1kwSxEA8AHlofqgcKJcM8udgieRNhaJ5Cg==", + "path": "system.io/4.3.0", + "hashPath": "system.io.4.3.0.nupkg.sha512" + }, + "System.IO.Compression/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-YHndyoiV90iu4iKG115ibkhrG+S3jBm8Ap9OwoUAzO5oPDAWcr0SFwQFm0HjM8WkEZWo0zvLTyLmbvTkW1bXgg==", + "path": "system.io.compression/4.3.0", + "hashPath": "system.io.compression.4.3.0.nupkg.sha512" + }, + "System.IO.Compression.ZipFile/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-G4HwjEsgIwy3JFBduZ9quBkAu+eUwjIdJleuNSgmUojbH6O3mlvEIme+GHx/cLlTAPcrnnL7GqvB9pTlWRfhOg==", + "path": "system.io.compression.zipfile/4.3.0", + "hashPath": "system.io.compression.zipfile.4.3.0.nupkg.sha512" + }, + "System.IO.FileSystem/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-3wEMARTnuio+ulnvi+hkRNROYwa1kylvYahhcLk4HSoVdl+xxTFVeVlYOfLwrDPImGls0mDqbMhrza8qnWPTdA==", + "path": "system.io.filesystem/4.3.0", + "hashPath": "system.io.filesystem.4.3.0.nupkg.sha512" + }, + "System.IO.FileSystem.Primitives/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-6QOb2XFLch7bEc4lIcJH49nJN2HV+OC3fHDgsLVsBVBk3Y4hFAnOBGzJ2lUu7CyDDFo9IBWkSsnbkT6IBwwiMw==", + "path": "system.io.filesystem.primitives/4.3.0", + "hashPath": "system.io.filesystem.primitives.4.3.0.nupkg.sha512" + }, + "System.Linq/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-5DbqIUpsDp0dFftytzuMmc0oeMdQwjcP/EWxsksIz/w1TcFRkZ3yKKz0PqiYFMmEwPSWw+qNVqD7PJ889JzHbw==", + "path": "system.linq/4.3.0", + "hashPath": "system.linq.4.3.0.nupkg.sha512" + }, + "System.Linq.Expressions/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-PGKkrd2khG4CnlyJwxwwaWWiSiWFNBGlgXvJpeO0xCXrZ89ODrQ6tjEWS/kOqZ8GwEOUATtKtzp1eRgmYNfclg==", + "path": "system.linq.expressions/4.3.0", + "hashPath": "system.linq.expressions.4.3.0.nupkg.sha512" + }, + "System.Net.Http/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-sYg+FtILtRQuYWSIAuNOELwVuVsxVyJGWQyOnlAzhV4xvhyFnON1bAzYYC+jjRW8JREM45R0R5Dgi8MTC5sEwA==", + "path": "system.net.http/4.3.0", + "hashPath": "system.net.http.4.3.0.nupkg.sha512" + }, + "System.Net.Primitives/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-qOu+hDwFwoZPbzPvwut2qATe3ygjeQBDQj91xlsaqGFQUI5i4ZnZb8yyQuLGpDGivEPIt8EJkd1BVzVoP31FXA==", + "path": "system.net.primitives/4.3.0", + "hashPath": "system.net.primitives.4.3.0.nupkg.sha512" + }, + "System.Net.Sockets/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-m6icV6TqQOAdgt5N/9I5KNpjom/5NFtkmGseEH+AK/hny8XrytLH3+b5M8zL/Ycg3fhIocFpUMyl/wpFnVRvdw==", + "path": "system.net.sockets/4.3.0", + "hashPath": "system.net.sockets.4.3.0.nupkg.sha512" + }, + "System.ObjectModel/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-bdX+80eKv9bN6K4N+d77OankKHGn6CH711a6fcOpMQu2Fckp/Ft4L/kW9WznHpyR0NRAvJutzOMHNNlBGvxQzQ==", + "path": "system.objectmodel/4.3.0", + "hashPath": "system.objectmodel.4.3.0.nupkg.sha512" + }, + "System.Reflection/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-KMiAFoW7MfJGa9nDFNcfu+FpEdiHpWgTcS2HdMpDvt9saK3y/G4GwprPyzqjFH9NTaGPQeWNHU+iDlDILj96aQ==", + "path": "system.reflection/4.3.0", + "hashPath": "system.reflection.4.3.0.nupkg.sha512" + }, + "System.Reflection.Emit/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-228FG0jLcIwTVJyz8CLFKueVqQK36ANazUManGaJHkO0icjiIypKW7YLWLIWahyIkdh5M7mV2dJepllLyA1SKg==", + "path": "system.reflection.emit/4.3.0", + "hashPath": "system.reflection.emit.4.3.0.nupkg.sha512" + }, + "System.Reflection.Emit.ILGeneration/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-59tBslAk9733NXLrUJrwNZEzbMAcu8k344OYo+wfSVygcgZ9lgBdGIzH/nrg3LYhXceynyvTc8t5/GD4Ri0/ng==", + "path": "system.reflection.emit.ilgeneration/4.3.0", + "hashPath": "system.reflection.emit.ilgeneration.4.3.0.nupkg.sha512" + }, + "System.Reflection.Emit.Lightweight/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-oadVHGSMsTmZsAF864QYN1t1QzZjIcuKU3l2S9cZOwDdDueNTrqq1yRj7koFfIGEnKpt6NjpL3rOzRhs4ryOgA==", + "path": "system.reflection.emit.lightweight/4.3.0", + "hashPath": "system.reflection.emit.lightweight.4.3.0.nupkg.sha512" + }, + "System.Reflection.Extensions/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-rJkrJD3kBI5B712aRu4DpSIiHRtr6QlfZSQsb0hYHrDCZORXCFjQfoipo2LaMUHoT9i1B7j7MnfaEKWDFmFQNQ==", + "path": "system.reflection.extensions/4.3.0", + "hashPath": "system.reflection.extensions.4.3.0.nupkg.sha512" + }, + "System.Reflection.Primitives/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-5RXItQz5As4xN2/YUDxdpsEkMhvw3e6aNveFXUn4Hl/udNTCNhnKp8lT9fnc3MhvGKh1baak5CovpuQUXHAlIA==", + "path": "system.reflection.primitives/4.3.0", + "hashPath": "system.reflection.primitives.4.3.0.nupkg.sha512" + }, + "System.Reflection.TypeExtensions/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-7u6ulLcZbyxB5Gq0nMkQttcdBTx57ibzw+4IOXEfR+sXYQoHvjW5LTLyNr8O22UIMrqYbchJQJnos4eooYzYJA==", + "path": "system.reflection.typeextensions/4.3.0", + "hashPath": "system.reflection.typeextensions.4.3.0.nupkg.sha512" + }, + "System.Resources.ResourceManager/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-/zrcPkkWdZmI4F92gL/TPumP98AVDu/Wxr3CSJGQQ+XN6wbRZcyfSKVoPo17ilb3iOr0cCRqJInGwNMolqhS8A==", + "path": "system.resources.resourcemanager/4.3.0", + "hashPath": "system.resources.resourcemanager.4.3.0.nupkg.sha512" + }, + "System.Runtime/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-JufQi0vPQ0xGnAczR13AUFglDyVYt4Kqnz1AZaiKZ5+GICq0/1MH/mO/eAJHt/mHW1zjKBJd7kV26SrxddAhiw==", + "path": "system.runtime/4.3.0", + "hashPath": "system.runtime.4.3.0.nupkg.sha512" + }, "System.Runtime.CompilerServices.Unsafe/5.0.0": { "type": "package", "serviceable": true, @@ -2323,6 +3649,111 @@ "path": "system.runtime.compilerservices.unsafe/5.0.0", "hashPath": "system.runtime.compilerservices.unsafe.5.0.0.nupkg.sha512" }, + "System.Runtime.Extensions/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-guW0uK0fn5fcJJ1tJVXYd7/1h5F+pea1r7FLSOz/f8vPEqbR2ZAknuRDvTQ8PzAilDveOxNjSfr0CHfIQfFk8g==", + "path": "system.runtime.extensions/4.3.0", + "hashPath": "system.runtime.extensions.4.3.0.nupkg.sha512" + }, + "System.Runtime.Handles/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-OKiSUN7DmTWeYb3l51A7EYaeNMnvxwE249YtZz7yooT4gOZhmTjIn48KgSsw2k2lYdLgTKNJw/ZIfSElwDRVgg==", + "path": "system.runtime.handles/4.3.0", + "hashPath": "system.runtime.handles.4.3.0.nupkg.sha512" + }, + "System.Runtime.InteropServices/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-uv1ynXqiMK8mp1GM3jDqPCFN66eJ5w5XNomaK2XD+TuCroNTLFGeZ+WCmBMcBDyTFKou3P6cR6J/QsaqDp7fGQ==", + "path": "system.runtime.interopservices/4.3.0", + "hashPath": "system.runtime.interopservices.4.3.0.nupkg.sha512" + }, + "System.Runtime.InteropServices.RuntimeInformation/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-cbz4YJMqRDR7oLeMRbdYv7mYzc++17lNhScCX0goO2XpGWdvAt60CGN+FHdePUEHCe/Jy9jUlvNAiNdM+7jsOw==", + "path": "system.runtime.interopservices.runtimeinformation/4.3.0", + "hashPath": "system.runtime.interopservices.runtimeinformation.4.3.0.nupkg.sha512" + }, + "System.Runtime.Numerics/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-yMH+MfdzHjy17l2KESnPiF2dwq7T+xLnSJar7slyimAkUh/gTrS9/UQOtv7xarskJ2/XDSNvfLGOBQPjL7PaHQ==", + "path": "system.runtime.numerics/4.3.0", + "hashPath": "system.runtime.numerics.4.3.0.nupkg.sha512" + }, + "System.Runtime.Serialization.Formatters/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-KT591AkTNFOTbhZlaeMVvfax3RqhH1EJlcwF50Wm7sfnBLuHiOeZRRKrr1ns3NESkM20KPZ5Ol/ueMq5vg4QoQ==", + "path": "system.runtime.serialization.formatters/4.3.0", + "hashPath": "system.runtime.serialization.formatters.4.3.0.nupkg.sha512" + }, + "System.Runtime.Serialization.Primitives/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-Wz+0KOukJGAlXjtKr+5Xpuxf8+c8739RI1C+A2BoQZT+wMCCoMDDdO8/4IRHfaVINqL78GO8dW8G2lW/e45Mcw==", + "path": "system.runtime.serialization.primitives/4.3.0", + "hashPath": "system.runtime.serialization.primitives.4.3.0.nupkg.sha512" + }, + "System.Security.Cryptography.Algorithms/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-W1kd2Y8mYSCgc3ULTAZ0hOP2dSdG5YauTb1089T0/kRcN2MpSAW1izOFROrJgxSlMn3ArsgHXagigyi+ibhevg==", + "path": "system.security.cryptography.algorithms/4.3.0", + "hashPath": "system.security.cryptography.algorithms.4.3.0.nupkg.sha512" + }, + "System.Security.Cryptography.Cng/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-03idZOqFlsKRL4W+LuCpJ6dBYDUWReug6lZjBa3uJWnk5sPCUXckocevTaUA8iT/MFSrY/2HXkOt753xQ/cf8g==", + "path": "system.security.cryptography.cng/4.3.0", + "hashPath": "system.security.cryptography.cng.4.3.0.nupkg.sha512" + }, + "System.Security.Cryptography.Csp/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-X4s/FCkEUnRGnwR3aSfVIkldBmtURMhmexALNTwpjklzxWU7yjMk7GHLKOZTNkgnWnE0q7+BCf9N2LVRWxewaA==", + "path": "system.security.cryptography.csp/4.3.0", + "hashPath": "system.security.cryptography.csp.4.3.0.nupkg.sha512" + }, + "System.Security.Cryptography.Encoding/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-1DEWjZZly9ae9C79vFwqaO5kaOlI5q+3/55ohmq/7dpDyDfc8lYe7YVxJUZ5MF/NtbkRjwFRo14yM4OEo9EmDw==", + "path": "system.security.cryptography.encoding/4.3.0", + "hashPath": "system.security.cryptography.encoding.4.3.0.nupkg.sha512" + }, + "System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-h4CEgOgv5PKVF/HwaHzJRiVboL2THYCou97zpmhjghx5frc7fIvlkY1jL+lnIQyChrJDMNEXS6r7byGif8Cy4w==", + "path": "system.security.cryptography.openssl/4.3.0", + "hashPath": "system.security.cryptography.openssl.4.3.0.nupkg.sha512" + }, + "System.Security.Cryptography.Primitives/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-7bDIyVFNL/xKeFHjhobUAQqSpJq9YTOpbEs6mR233Et01STBMXNAc/V+BM6dwYGc95gVh/Zf+iVXWzj3mE8DWg==", + "path": "system.security.cryptography.primitives/4.3.0", + "hashPath": "system.security.cryptography.primitives.4.3.0.nupkg.sha512" + }, + "System.Security.Cryptography.X509Certificates/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-t2Tmu6Y2NtJ2um0RtcuhP7ZdNNxXEgUm2JeoA/0NvlMjAhKCnM1NX07TDl3244mVp3QU6LPEhT3HTtH1uF7IYw==", + "path": "system.security.cryptography.x509certificates/4.3.0", + "hashPath": "system.security.cryptography.x509certificates.4.3.0.nupkg.sha512" + }, + "System.Text.Encoding/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-BiIg+KWaSDOITze6jGQynxg64naAPtqGHBwDrLaCtixsa5bKiR8dpPOHA7ge3C0JJQizJE+sfkz1wV+BAKAYZw==", + "path": "system.text.encoding/4.3.0", + "hashPath": "system.text.encoding.4.3.0.nupkg.sha512" + }, "System.Text.Encoding.CodePages/4.5.1": { "type": "package", "serviceable": true, @@ -2330,6 +3761,69 @@ "path": "system.text.encoding.codepages/4.5.1", "hashPath": "system.text.encoding.codepages.4.5.1.nupkg.sha512" }, + "System.Text.Encoding.Extensions/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-YVMK0Bt/A43RmwizJoZ22ei2nmrhobgeiYwFzC4YAN+nue8RF6djXDMog0UCn+brerQoYVyaS+ghy9P/MUVcmw==", + "path": "system.text.encoding.extensions/4.3.0", + "hashPath": "system.text.encoding.extensions.4.3.0.nupkg.sha512" + }, + "System.Text.RegularExpressions/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-RpT2DA+L660cBt1FssIE9CAGpLFdFPuheB7pLpKpn6ZXNby7jDERe8Ua/Ne2xGiwLVG2JOqziiaVCGDon5sKFA==", + "path": "system.text.regularexpressions/4.3.0", + "hashPath": "system.text.regularexpressions.4.3.0.nupkg.sha512" + }, + "System.Threading/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-VkUS0kOBcUf3Wwm0TSbrevDDZ6BlM+b/HRiapRFWjM5O0NS0LviG0glKmFK+hhPDd1XFeSdU1GmlLhb2CoVpIw==", + "path": "system.threading/4.3.0", + "hashPath": "system.threading.4.3.0.nupkg.sha512" + }, + "System.Threading.Tasks/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-LbSxKEdOUhVe8BezB/9uOGGppt+nZf6e1VFyw6v3DN6lqitm0OSn2uXMOdtP0M3W4iMcqcivm2J6UgqiwwnXiA==", + "path": "system.threading.tasks/4.3.0", + "hashPath": "system.threading.tasks.4.3.0.nupkg.sha512" + }, + "System.Threading.Tasks.Extensions/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-npvJkVKl5rKXrtl1Kkm6OhOUaYGEiF9wFbppFRWSMoApKzt2PiPHT2Bb8a5sAWxprvdOAtvaARS9QYMznEUtug==", + "path": "system.threading.tasks.extensions/4.3.0", + "hashPath": "system.threading.tasks.extensions.4.3.0.nupkg.sha512" + }, + "System.Threading.Timer/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-Z6YfyYTCg7lOZjJzBjONJTFKGN9/NIYKSxhU5GRd+DTwHSZyvWp1xuI5aR+dLg+ayyC5Xv57KiY4oJ0tMO89fQ==", + "path": "system.threading.timer/4.3.0", + "hashPath": "system.threading.timer.4.3.0.nupkg.sha512" + }, + "System.Xml.ReaderWriter/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-GrprA+Z0RUXaR4N7/eW71j1rgMnEnEVlgii49GZyAjTH7uliMnrOU3HNFBr6fEDBCJCIdlVNq9hHbaDR621XBA==", + "path": "system.xml.readerwriter/4.3.0", + "hashPath": "system.xml.readerwriter.4.3.0.nupkg.sha512" + }, + "System.Xml.XDocument/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-5zJ0XDxAIg8iy+t4aMnQAu0MqVbqyvfoUVl1yDV61xdo3Vth45oA2FoY4pPkxYAH5f8ixpmTqXeEIya95x0aCQ==", + "path": "system.xml.xdocument/4.3.0", + "hashPath": "system.xml.xdocument.4.3.0.nupkg.sha512" + }, + "System.Xml.XmlDocument/4.3.0": { + "type": "package", + "serviceable": true, + "sha512": "sha512-lJ8AxvkX7GQxpC6GFCeBj8ThYVyQczx2+f/cWHJU8tjS7YfI6Cv6bon70jVEgs2CiFbmmM8b9j1oZVx0dSI2Ww==", + "path": "system.xml.xmldocument/4.3.0", + "hashPath": "system.xml.xmldocument.4.3.0.nupkg.sha512" + }, "Microsoft.AspNetCore.Antiforgery/5.0.0.0": { "type": "referenceassembly", "serviceable": false, @@ -2715,7 +4209,7 @@ "serviceable": false, "sha512": "" }, - "Microsoft.CSharp/5.0.0.0": { + "Microsoft.CSharp.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -2955,7 +4449,7 @@ "serviceable": false, "sha512": "" }, - "Microsoft.Win32.Primitives/5.0.0.0": { + "Microsoft.Win32.Primitives.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -2975,7 +4469,7 @@ "serviceable": false, "sha512": "" }, - "System.AppContext/5.0.0.0": { + "System.AppContext.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -2985,12 +4479,12 @@ "serviceable": false, "sha512": "" }, - "System.Collections.Concurrent/5.0.0.0": { + "System.Collections.Concurrent.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Collections/5.0.0.0": { + "System.Collections.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3000,12 +4494,12 @@ "serviceable": false, "sha512": "" }, - "System.Collections.NonGeneric/5.0.0.0": { + "System.Collections.NonGeneric.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Collections.Specialized/5.0.0.0": { + "System.Collections.Specialized.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3020,7 +4514,7 @@ "serviceable": false, "sha512": "" }, - "System.ComponentModel/5.0.0.0": { + "System.ComponentModel.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3030,12 +4524,12 @@ "serviceable": false, "sha512": "" }, - "System.ComponentModel.Primitives/5.0.0.0": { + "System.ComponentModel.Primitives.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.ComponentModel.TypeConverter/5.0.0.0": { + "System.ComponentModel.TypeConverter.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3045,7 +4539,7 @@ "serviceable": false, "sha512": "" }, - "System.Console/5.0.0.0": { + "System.Console.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3075,12 +4569,12 @@ "serviceable": false, "sha512": "" }, - "System.Diagnostics.Debug/5.0.0.0": { + "System.Diagnostics.Debug.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Diagnostics.DiagnosticSource/5.0.0.0": { + "System.Diagnostics.DiagnosticSource.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3110,7 +4604,7 @@ "serviceable": false, "sha512": "" }, - "System.Diagnostics.Tools/5.0.0.0": { + "System.Diagnostics.Tools.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3120,7 +4614,7 @@ "serviceable": false, "sha512": "" }, - "System.Diagnostics.Tracing/5.0.0.0": { + "System.Diagnostics.Tracing.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3140,7 +4634,7 @@ "serviceable": false, "sha512": "" }, - "System.Dynamic.Runtime/5.0.0.0": { + "System.Dynamic.Runtime.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3150,17 +4644,17 @@ "serviceable": false, "sha512": "" }, - "System.Globalization.Calendars/5.0.0.0": { + "System.Globalization.Calendars.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Globalization/5.0.0.0": { + "System.Globalization.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Globalization.Extensions/5.0.0.0": { + "System.Globalization.Extensions.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3170,7 +4664,7 @@ "serviceable": false, "sha512": "" }, - "System.IO.Compression/5.0.0.0": { + "System.IO.Compression.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3180,17 +4674,17 @@ "serviceable": false, "sha512": "" }, - "System.IO.Compression.ZipFile/5.0.0.0": { + "System.IO.Compression.ZipFile.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.IO/5.0.0.0": { + "System.IO.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.IO.FileSystem/5.0.0.0": { + "System.IO.FileSystem.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3200,7 +4694,7 @@ "serviceable": false, "sha512": "" }, - "System.IO.FileSystem.Primitives/5.0.0.0": { + "System.IO.FileSystem.Primitives.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3235,12 +4729,12 @@ "serviceable": false, "sha512": "" }, - "System.Linq/5.0.0.0": { + "System.Linq.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Linq.Expressions/5.0.0.0": { + "System.Linq.Expressions.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3265,7 +4759,7 @@ "serviceable": false, "sha512": "" }, - "System.Net.Http/5.0.0.0": { + "System.Net.Http.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3300,7 +4794,7 @@ "serviceable": false, "sha512": "" }, - "System.Net.Primitives/5.0.0.0": { + "System.Net.Primitives.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3320,7 +4814,7 @@ "serviceable": false, "sha512": "" }, - "System.Net.Sockets/5.0.0.0": { + "System.Net.Sockets.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3360,7 +4854,7 @@ "serviceable": false, "sha512": "" }, - "System.ObjectModel/5.0.0.0": { + "System.ObjectModel.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3370,27 +4864,27 @@ "serviceable": false, "sha512": "" }, - "System.Reflection/5.0.0.0": { + "System.Reflection.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Reflection.Emit/5.0.0.0": { + "System.Reflection.Emit.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Reflection.Emit.ILGeneration/5.0.0.0": { + "System.Reflection.Emit.ILGeneration.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Reflection.Emit.Lightweight/5.0.0.0": { + "System.Reflection.Emit.Lightweight.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Reflection.Extensions/5.0.0.0": { + "System.Reflection.Extensions.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3400,12 +4894,12 @@ "serviceable": false, "sha512": "" }, - "System.Reflection.Primitives/5.0.0.0": { + "System.Reflection.Primitives.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Reflection.TypeExtensions/5.0.0.0": { + "System.Reflection.TypeExtensions.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3415,7 +4909,7 @@ "serviceable": false, "sha512": "" }, - "System.Resources.ResourceManager/5.0.0.0": { + "System.Resources.ResourceManager.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3435,27 +4929,27 @@ "serviceable": false, "sha512": "" }, - "System.Runtime/5.0.0.0": { + "System.Runtime.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Runtime.Extensions/5.0.0.0": { + "System.Runtime.Extensions.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Runtime.Handles/5.0.0.0": { + "System.Runtime.Handles.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Runtime.InteropServices/5.0.0.0": { + "System.Runtime.InteropServices.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Runtime.InteropServices.RuntimeInformation/5.0.0.0": { + "System.Runtime.InteropServices.RuntimeInformation.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3470,7 +4964,7 @@ "serviceable": false, "sha512": "" }, - "System.Runtime.Numerics/5.0.0.0": { + "System.Runtime.Numerics.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3480,7 +4974,7 @@ "serviceable": false, "sha512": "" }, - "System.Runtime.Serialization.Formatters/5.0.0.0": { + "System.Runtime.Serialization.Formatters.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3490,7 +4984,7 @@ "serviceable": false, "sha512": "" }, - "System.Runtime.Serialization.Primitives/5.0.0.0": { + "System.Runtime.Serialization.Primitives.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3510,32 +5004,32 @@ "serviceable": false, "sha512": "" }, - "System.Security.Cryptography.Algorithms/5.0.0.0": { + "System.Security.Cryptography.Algorithms.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Security.Cryptography.Cng/5.0.0.0": { + "System.Security.Cryptography.Cng.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Security.Cryptography.Csp/5.0.0.0": { + "System.Security.Cryptography.Csp.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Security.Cryptography.Encoding/5.0.0.0": { + "System.Security.Cryptography.Encoding.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Security.Cryptography.Primitives/5.0.0.0": { + "System.Security.Cryptography.Primitives.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Security.Cryptography.X509Certificates/5.0.0.0": { + "System.Security.Cryptography.X509Certificates.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3585,12 +5079,12 @@ "serviceable": false, "sha512": "" }, - "System.Text.Encoding/5.0.0.0": { + "System.Text.Encoding.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Text.Encoding.Extensions/5.0.0.0": { + "System.Text.Encoding.Extensions.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3605,7 +5099,7 @@ "serviceable": false, "sha512": "" }, - "System.Text.RegularExpressions/5.0.0.0": { + "System.Text.RegularExpressions.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3615,7 +5109,7 @@ "serviceable": false, "sha512": "" }, - "System.Threading/5.0.0.0": { + "System.Threading.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3630,12 +5124,12 @@ "serviceable": false, "sha512": "" }, - "System.Threading.Tasks/5.0.0.0": { + "System.Threading.Tasks.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Threading.Tasks.Extensions/5.0.0.0": { + "System.Threading.Tasks.Extensions.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3655,7 +5149,7 @@ "serviceable": false, "sha512": "" }, - "System.Threading.Timer/5.0.0.0": { + "System.Threading.Timer.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3705,7 +5199,7 @@ "serviceable": false, "sha512": "" }, - "System.Xml.ReaderWriter/5.0.0.0": { + "System.Xml.ReaderWriter.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" @@ -3715,12 +5209,12 @@ "serviceable": false, "sha512": "" }, - "System.Xml.XDocument/5.0.0.0": { + "System.Xml.XDocument.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" }, - "System.Xml.XmlDocument/5.0.0.0": { + "System.Xml.XmlDocument.Reference/5.0.0.0": { "type": "referenceassembly", "serviceable": false, "sha512": "" diff --git a/Back-end/MongoBookApis/bin/Debug/net5.0/MongoBookApis.dll b/Back-end/MongoBookApis/bin/Debug/net5.0/MongoBookApis.dll new file mode 100644 index 0000000000000000000000000000000000000000..62f912aa89494fe9780157bcbbb7cf31c3edadc0 GIT binary patch literal 33280 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 N&i#Kr|NSEHe*xbNOJD#1 literal 0 HcmV?d00001 diff --git a/MongoBookApis/bin/Debug/net5.0/MongoBookApis.pdb b/Back-end/MongoBookApis/bin/Debug/net5.0/MongoBookApis.pdb similarity index 69% rename from MongoBookApis/bin/Debug/net5.0/MongoBookApis.pdb rename to Back-end/MongoBookApis/bin/Debug/net5.0/MongoBookApis.pdb index 43d3578e843597a31f38c2b107549a7a0680ef9f..b994243900882368527168781f4083cf477d07ba 100644 GIT binary patch delta 3566 zcmai$3vg8B701ta_nFPc#IVtn60#5y$Quw59IYD?5)#W&6n|zb$On34> z_x#TJ?zvyS``vTz(Q{(|yJB!bi!Gg~U>lL%O0-_aKIKBmLX$CLp47Y->bgy}RZO=!p_}?Bsb#mLye(S)Y&-M+@72oW8+n2#bG9fcm zrp^#Qj(xGhNPmS!pxaQk6Dcy0$z`Hk7yD)kxzfqzPNx!R9@Gt;c5_btS;+2@nSBfO zYB3!RcyzQA+6V22UVvWm=w{Q;;k*I837v(`Lzked&~@k*^e2xRR7yRh(BC}@{Tmv9 zc0$6dkQvH^?t=25Sx_l7A6g7KpgPC}`Joo54cg>QR@GCtS5M!AV$cp~5A+;#06GXA zfsR5api@vC^bT~@qsJWen4=zZ)YAuuUFNEDat-vU*Fe99eh+==<<$_h*oS0p%tReN z4)8CX9`~iwF6epakQTSl8{>Hk{c+q+p25pHt7*dT9QQdUXu4lep+D)DX~(1=N%?nT z(1$62|Ltbgp+6eifnj%38dh2G353l^xe^zH^T>*wn9ScJaW?!J&~)StWBG@``4TSz z+a>1wj0uhrPif{v0K1TA7L+Q;TqrT`;v$JTKU-qX&ykq({78po2mng;~6K$3X?_tjKE&bLX-`F4pp zACj2!8zkoZMu|E92y<-gvEcz7lLl;(nDdWH%mq3n=KN-fIo~BQ=fe_nehU6n{zc)huYU>%+tu+<*Y8>kl6NXtET_#RjzwR#*`25R&xW(M8`9!K zh`0JE+dwyAO>`yZ3jn4z1pw(yG{rzcSQFL5n(5)D03zxB03w&+o9Q=A4x52C`5iVB zd11{I^ba9&7S=?sz?$i#pK=V8)l4}i`X_udnVJKLZ1M*Xse*4NH$I^7Yp)DOgRQ|x zh$5kARQvjJ_EmLuhI@TmLTw!zI@%h0IyQE6MX0T_Bh(e8#GO`yC|Y3^|M=q3OBKV7 zyL(!0Pk+97xcv|BTAuC?omAI;(Dz=0z9t%uSk$c$m*S$xr8PxP@Z6>Sk~B?;5r`DK;&Ru2gK#oedc{N1k> zeKT#73z(KyCUHY(Tavh zxT|6boAyrh3UT43`m1zC&@Wfdd27dISKUvhjhL3z2>s+!lA{X>I)=$^p)b$>`J+(j z>7_qAY!ce|26s*k&cG#uYK!AXWi1oXpSZG`{i|s z-s%O}1=Zo6$k@QWw{Ne(b3%t+O#7zzcgvO@Ii6WPdhn0 zi+R~_^ z??0|6PJs(ha zpTPxO&#^hi$faBt*h|)99AV>tY0P4e>o%6Nd4SDIHrv?j%E5*#o0euG!5?JP6*GH% zc&ZynKclh&Ek_ik393`fR>GIC)nHW6AMUe~k(Nv)lg_B8BAwBKFC<~^(~0=KHcX;H^dAv%tB4;H+q1>?UkI(yR3~n>^oe@g72z8l*0 zlUL>Y;{BS}VnL3&Yn`LyJ97oiQ>x7*^nLs$5j7ct+={t)Y;~y0JzI;fR=-+zPHa$5 zuFq3S_3G#AXY1A~X4M*)88Bk;ilF`jb5Mb}egD5>_B4?rNQpa??TcyVz_S?74c3}p mtR1|?g?9l>{3r6%y@6U$q<#`uCFZM@L8ox5TZ8wYLH`%Rm@NeW delta 3196 zcmai$d2Ccw6voeev%JT2+Cmp7(9%L%=&-hI0g=!aC`)HLTPq+IW{PDki_ioJ$h1>Y z3`>9)QUsJjY{Wn!aRL|(5kye@qk;sZq#7ay7Z3v~kuCV0H+|)Xkl6G)@BYqr-+A}l zx%bZOJ|~Wz5!*+;q$LpLZXo&>*Gxh?Sif@7vIVQqq%+39cq?+M z+)iIWZO~=tw{lpd(vNPH{&aI&qvt&dbfY4Hgg1dSXacm=%bxt_pj*$#P4;mg3;BH( znhDK?=0i)NdY@$gtwSRUy$NlHnxS`~R_F*6gFg1@VP%k?6gurw=u5~C&4j*&zJ-2( zeui#9cc6O^`4v*3Bq$xqgmR&QP!Tl7AFpbq34SY;K^~|Qnhn)Ji=Y+IYG?zr5!wQ! zLps#zvto=^jM0iQT4@h*2e@iMhK&ySZS(kEJn(Z*aglaCqB%$KSJUZwEIGR;9EQV3E*sr$AEJrX20(fju2Kc z^?Q=QDkRE-%!17M67wqVFERTABxb)rV)pqZ%zEq(?Bob9du)r&M0}eJmYDq^5_5r} z60<){V)hFqX1_>c_J^B{=NkjyX_ZIF(_}IiD3+KDlt|2esl@D0l$d=!G|YPJPwrrT zzA=EZjs!Dzm?AM3m?|;*(Z3^agCp@(%^kuI^i`%5Kef0@MWFPE786;MQe!&jc_uwG&=@T$aI zfX@o~e*Q2`X1@_%J0^DpMRboD@wn@zQZ>PwUlj{T$x^xh=fp<$>gr%`p;_LWc-7gK0XQ<^VJ}B`+_^lEr zq28fdDRB&m!xE>(*CGynKHyUk`5KSc%JEePI_9<-*TEjUac!*Ni5GO%%XcLh?a%%C z1;?1k{qh{ePIuiQ#YXqbPoX{Bdll^lL_0Nk$%3yhZwq3Q?R*r>WExQKRh27GxR_Ra%Is(dtS{M^QwTjw5Px zwlaiF0isHe5j9HUC4+q$t`FCQSLse?f_+}yqS|Hku~AN&=%2lB+w1uu@9L^St=U@p zc~>xW`1-2Uw?E6YB;7pi&hl6%)h}P=&<`YL#MUI{D>+BkuRActzVp{U{!tgIZ(nl! zRde%5bM4s3L>V3XB`uN27 zk34tYjonSQS(M3<*rOC@Zfx=BgNd=plk!sZ<`;&<@@KrKDCO;X+pG)uV_ zS~08ucgJ6p=fbEHpGsrC`Mr$?xbyf$N2clz<`xeuEW{5gWuivHx|R<#F*;F@PtjZ* zuTCYU1B|>|uMM3MD|A;lOYMV~r$LH7H9SD;so)oXwL<#JaKBI%4v_Is!`=eaB0f+4 z@0yY+(gi7vbCl=|>eqA;{dwOzGhN2T>&ovARQX@@(*F*ZiCleL%`7oY-&Nxg9{pO) Gi2ne!D6Xae diff --git a/MongoBookApis/bin/Debug/net5.0/MongoBookApis.runtimeconfig.dev.json b/Back-end/MongoBookApis/bin/Debug/net5.0/MongoBookApis.runtimeconfig.dev.json similarity index 100% rename from MongoBookApis/bin/Debug/net5.0/MongoBookApis.runtimeconfig.dev.json rename to Back-end/MongoBookApis/bin/Debug/net5.0/MongoBookApis.runtimeconfig.dev.json diff --git a/MongoBookApis/bin/Debug/net5.0/MongoBookApis.runtimeconfig.json b/Back-end/MongoBookApis/bin/Debug/net5.0/MongoBookApis.runtimeconfig.json similarity index 100% rename from MongoBookApis/bin/Debug/net5.0/MongoBookApis.runtimeconfig.json rename to Back-end/MongoBookApis/bin/Debug/net5.0/MongoBookApis.runtimeconfig.json diff --git a/MongoBookApis/bin/Debug/net5.0/MongoDB.Bson.dll b/Back-end/MongoBookApis/bin/Debug/net5.0/MongoDB.Bson.dll similarity index 100% rename from MongoBookApis/bin/Debug/net5.0/MongoDB.Bson.dll rename to Back-end/MongoBookApis/bin/Debug/net5.0/MongoDB.Bson.dll diff --git a/MongoBookApis/bin/Debug/net5.0/MongoDB.Driver.Core.dll b/Back-end/MongoBookApis/bin/Debug/net5.0/MongoDB.Driver.Core.dll similarity index 100% rename from MongoBookApis/bin/Debug/net5.0/MongoDB.Driver.Core.dll rename to Back-end/MongoBookApis/bin/Debug/net5.0/MongoDB.Driver.Core.dll diff --git a/MongoBookApis/bin/Debug/net5.0/MongoDB.Driver.dll b/Back-end/MongoBookApis/bin/Debug/net5.0/MongoDB.Driver.dll similarity index 100% rename from MongoBookApis/bin/Debug/net5.0/MongoDB.Driver.dll rename to Back-end/MongoBookApis/bin/Debug/net5.0/MongoDB.Driver.dll diff --git a/MongoBookApis/bin/Debug/net5.0/MongoDB.Libmongocrypt.dll b/Back-end/MongoBookApis/bin/Debug/net5.0/MongoDB.Libmongocrypt.dll similarity index 100% rename from MongoBookApis/bin/Debug/net5.0/MongoDB.Libmongocrypt.dll rename to Back-end/MongoBookApis/bin/Debug/net5.0/MongoDB.Libmongocrypt.dll diff --git a/Back-end/MongoBookApis/bin/Debug/net5.0/Newtonsoft.Json.Bson.dll b/Back-end/MongoBookApis/bin/Debug/net5.0/Newtonsoft.Json.Bson.dll new file mode 100755 index 0000000000000000000000000000000000000000..22d4c123b6a63f15108d9ae7af7e4b6b00a25e52 GIT binary patch literal 90624 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 bjjR9p`+s189*LI5`Ufla|M~m>&jSAku3nEX literal 0 HcmV?d00001 diff --git a/Back-end/MongoBookApis/bin/Debug/net5.0/Newtonsoft.Json.dll b/Back-end/MongoBookApis/bin/Debug/net5.0/Newtonsoft.Json.dll new file mode 100755 index 0000000000000000000000000000000000000000..d6e3d9d3d0c13daa1f68e25e244bd427012dfb02 GIT binary patch literal 639488 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

U8>tT zg5YffPORJ73;GCu?bE$ay3OYVRNk$JQ!ah#M5y5QI60*}PjS0gY0(t`x8-=;R;t0= zwidnj<2I{lc@L{lQtaA!f7qaI%2D&Sbid|iGI2JqF%Ly(=* z*|Pb{f+$X9fJaVW7ZQYQZI6S#?w60ak3pZy+W`PKa`TKf8jdIGLLrN-+Cpw;N#wMO1ttDA1{)QsZSdg z6#y&cc&t>aL9Fb)*(lqSkWLl{Q<7))TueYrl@%fm6!|fgJ;PC{Zfk8Sr;LrtuqfuX zU}lX#7EGWar8OGIeS4jmW&Vcd?hT`Wg$;ahe*^Ez6hDZ0!=02c^8OxV3KPdq{hO4@P>a&<~y>r6G)_QlJ2Vb|nmvcJGec|8v z(kbF;U%52IR#R19xvYR=@vNFl(l|zUBYE=}s%uYHGr=Kn@^dDuA0!A_-4};%5&TZ| zO8tG9S0|tQ;dAd!DCf7wZ$nDtdP&;PQp@eL;SHFn-jcspAEKwKKK7%&IK+-F9Y_%M zaVSn~J3dIAY)JZ_@#lJ10=Vp&r^f`9T|5|cMZa*N?@Q&B4&o_&r%7+`|GnW-0QxS+ zV}nwm@5YAsihj_wXUxc&7L!Si4bf@y;a1b)T9mZbwXz%jB@T^I80@B zb-^7Bbl%$s4hxHd>H-G2p5?WgsJ`(Y%V3wp8$QERbxC{$>?F}2lTJg%)aUc$P%;tA zVOL+jy6hhTl6Kj1bmU(}tXBPvM+%)XmzqT;7b35dgSFG>E6&W>dBA$Xf-jgH9|

o9Kr2DnmBu|)hMi`* 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%0DE(Fo;N~TYy{p7Y5-(j$9=!c;hZ)b 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 dRfH^-kQ_UK0@yA;gF8 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 o|K-P&SWMb`1-x~-sk(C`@hlY?yBytuCA`G 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 literal 0 HcmV?d00001 diff --git a/Back-end/MongoBookApis/bin/Debug/net5.0/System.Web.Http.dll b/Back-end/MongoBookApis/bin/Debug/net5.0/System.Web.Http.dll new file mode 100755 index 0000000000000000000000000000000000000000..136113c75e7f84803bf8c174f165fe5a26541d4c GIT binary patch literal 455096 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 literal 0 HcmV?d00001 diff --git a/MongoBookApis/bin/Debug/net5.0/appsettings.Development.json b/Back-end/MongoBookApis/bin/Debug/net5.0/appsettings.Development.json similarity index 100% rename from MongoBookApis/bin/Debug/net5.0/appsettings.Development.json rename to Back-end/MongoBookApis/bin/Debug/net5.0/appsettings.Development.json diff --git a/MongoBookApis/bin/Debug/net5.0/appsettings.json b/Back-end/MongoBookApis/bin/Debug/net5.0/appsettings.json similarity index 100% rename from MongoBookApis/bin/Debug/net5.0/appsettings.json rename to Back-end/MongoBookApis/bin/Debug/net5.0/appsettings.json diff --git a/Back-end/MongoBookApis/bin/Debug/net5.0/ref/MongoBookApis.dll b/Back-end/MongoBookApis/bin/Debug/net5.0/ref/MongoBookApis.dll new file mode 100644 index 0000000000000000000000000000000000000000..8cdf386cd3e1cb8dc15669857fd73bcc32145719 GIT binary patch literal 15360 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 N&i#Kr|NSEHe*xbNOJD#1 literal 0 HcmV?d00001 diff --git a/MongoBookApis/obj/Debug/net5.0/MongoBookApis.genruntimeconfig.cache b/Back-end/MongoBookApis/obj/Debug/net5.0/MongoBookApis.genruntimeconfig.cache similarity index 100% rename from MongoBookApis/obj/Debug/net5.0/MongoBookApis.genruntimeconfig.cache rename to Back-end/MongoBookApis/obj/Debug/net5.0/MongoBookApis.genruntimeconfig.cache diff --git a/MongoBookApis/obj/Debug/net5.0/MongoBookApis.pdb b/Back-end/MongoBookApis/obj/Debug/net5.0/MongoBookApis.pdb similarity index 69% rename from MongoBookApis/obj/Debug/net5.0/MongoBookApis.pdb rename to Back-end/MongoBookApis/obj/Debug/net5.0/MongoBookApis.pdb index 43d3578e843597a31f38c2b107549a7a0680ef9f..b994243900882368527168781f4083cf477d07ba 100644 GIT binary patch delta 3566 zcmai$3vg8B701ta_nFPc#IVtn60#5y$Quw59IYD?5)#W&6n|zb$On34> z_x#TJ?zvyS``vTz(Q{(|yJB!bi!Gg~U>lL%O0-_aKIKBmLX$CLp47Y->bgy}RZO=!p_}?Bsb#mLye(S)Y&-M+@72oW8+n2#bG9fcm zrp^#Qj(xGhNPmS!pxaQk6Dcy0$z`Hk7yD)kxzfqzPNx!R9@Gt;c5_btS;+2@nSBfO zYB3!RcyzQA+6V22UVvWm=w{Q;;k*I837v(`Lzked&~@k*^e2xRR7yRh(BC}@{Tmv9 zc0$6dkQvH^?t=25Sx_l7A6g7KpgPC}`Joo54cg>QR@GCtS5M!AV$cp~5A+;#06GXA zfsR5api@vC^bT~@qsJWen4=zZ)YAuuUFNEDat-vU*Fe99eh+==<<$_h*oS0p%tReN z4)8CX9`~iwF6epakQTSl8{>Hk{c+q+p25pHt7*dT9QQdUXu4lep+D)DX~(1=N%?nT z(1$62|Ltbgp+6eifnj%38dh2G353l^xe^zH^T>*wn9ScJaW?!J&~)StWBG@``4TSz z+a>1wj0uhrPif{v0K1TA7L+Q;TqrT`;v$JTKU-qX&ykq({78po2mng;~6K$3X?_tjKE&bLX-`F4pp zACj2!8zkoZMu|E92y<-gvEcz7lLl;(nDdWH%mq3n=KN-fIo~BQ=fe_nehU6n{zc)huYU>%+tu+<*Y8>kl6NXtET_#RjzwR#*`25R&xW(M8`9!K zh`0JE+dwyAO>`yZ3jn4z1pw(yG{rzcSQFL5n(5)D03zxB03w&+o9Q=A4x52C`5iVB zd11{I^ba9&7S=?sz?$i#pK=V8)l4}i`X_udnVJKLZ1M*Xse*4NH$I^7Yp)DOgRQ|x zh$5kARQvjJ_EmLuhI@TmLTw!zI@%h0IyQE6MX0T_Bh(e8#GO`yC|Y3^|M=q3OBKV7 zyL(!0Pk+97xcv|BTAuC?omAI;(Dz=0z9t%uSk$c$m*S$xr8PxP@Z6>Sk~B?;5r`DK;&Ru2gK#oedc{N1k> zeKT#73z(KyCUHY(Tavh zxT|6boAyrh3UT43`m1zC&@Wfdd27dISKUvhjhL3z2>s+!lA{X>I)=$^p)b$>`J+(j z>7_qAY!ce|26s*k&cG#uYK!AXWi1oXpSZG`{i|s z-s%O}1=Zo6$k@QWw{Ne(b3%t+O#7zzcgvO@Ii6WPdhn0 zi+R~_^ z??0|6PJs(ha zpTPxO&#^hi$faBt*h|)99AV>tY0P4e>o%6Nd4SDIHrv?j%E5*#o0euG!5?JP6*GH% zc&ZynKclh&Ek_ik393`fR>GIC)nHW6AMUe~k(Nv)lg_B8BAwBKFC<~^(~0=KHcX;H^dAv%tB4;H+q1>?UkI(yR3~n>^oe@g72z8l*0 zlUL>Y;{BS}VnL3&Yn`LyJ97oiQ>x7*^nLs$5j7ct+={t)Y;~y0JzI;fR=-+zPHa$5 zuFq3S_3G#AXY1A~X4M*)88Bk;ilF`jb5Mb}egD5>_B4?rNQpa??TcyVz_S?74c3}p mtR1|?g?9l>{3r6%y@6U$q<#`uCFZM@L8ox5TZ8wYLH`%Rm@NeW delta 3196 zcmai$d2Ccw6voeev%JT2+Cmp7(9%L%=&-hI0g=!aC`)HLTPq+IW{PDki_ioJ$h1>Y z3`>9)QUsJjY{Wn!aRL|(5kye@qk;sZq#7ay7Z3v~kuCV0H+|)Xkl6G)@BYqr-+A}l zx%bZOJ|~Wz5!*+;q$LpLZXo&>*Gxh?Sif@7vIVQqq%+39cq?+M z+)iIWZO~=tw{lpd(vNPH{&aI&qvt&dbfY4Hgg1dSXacm=%bxt_pj*$#P4;mg3;BH( znhDK?=0i)NdY@$gtwSRUy$NlHnxS`~R_F*6gFg1@VP%k?6gurw=u5~C&4j*&zJ-2( zeui#9cc6O^`4v*3Bq$xqgmR&QP!Tl7AFpbq34SY;K^~|Qnhn)Ji=Y+IYG?zr5!wQ! zLps#zvto=^jM0iQT4@h*2e@iMhK&ySZS(kEJn(Z*aglaCqB%$KSJUZwEIGR;9EQV3E*sr$AEJrX20(fju2Kc z^?Q=QDkRE-%!17M67wqVFERTABxb)rV)pqZ%zEq(?Bob9du)r&M0}eJmYDq^5_5r} z60<){V)hFqX1_>c_J^B{=NkjyX_ZIF(_}IiD3+KDlt|2esl@D0l$d=!G|YPJPwrrT zzA=EZjs!Dzm?AM3m?|;*(Z3^agCp@(%^kuI^i`%5Kef0@MWFPE786;MQe!&jc_uwG&=@T$aI zfX@o~e*Q2`X1@_%J0^DpMRboD@wn@zQZ>PwUlj{T$x^xh=fp<$>gr%`p;_LWc-7gK0XQ<^VJ}B`+_^lEr zq28fdDRB&m!xE>(*CGynKHyUk`5KSc%JEePI_9<-*TEjUac!*Ni5GO%%XcLh?a%%C z1;?1k{qh{ePIuiQ#YXqbPoX{Bdll^lL_0Nk$%3yhZwq3Q?R*r>WExQKRh27GxR_Ra%Is(dtS{M^QwTjw5Px zwlaiF0isHe5j9HUC4+q$t`FCQSLse?f_+}yqS|Hku~AN&=%2lB+w1uu@9L^St=U@p zc~>xW`1-2Uw?E6YB;7pi&hl6%)h}P=&<`YL#MUI{D>+BkuRActzVp{U{!tgIZ(nl! zRde%5bM4s3L>V3XB`uN27 zk34tYjonSQS(M3<*rOC@Zfx=BgNd=plk!sZ<`;&<@@KrKDCO;X+pG)uV_ zS~08ucgJ6p=fbEHpGsrC`Mr$?xbyf$N2clz<`xeuEW{5gWuivHx|R<#F*;F@PtjZ* zuTCYU1B|>|uMM3MD|A;lOYMV~r$LH7H9SD;so)oXwL<#JaKBI%4v_Is!`=eaB0f+4 z@0yY+(gi7vbCl=|>eqA;{dwOzGhN2T>&ovARQX@@(*F*ZiCleL%`7oY-&Nxg9{pO) Gi2ne!D6Xae diff --git a/Back-end/MongoBookApis/obj/Debug/net5.0/ref/MongoBookApis.dll b/Back-end/MongoBookApis/obj/Debug/net5.0/ref/MongoBookApis.dll new file mode 100644 index 0000000000000000000000000000000000000000..8cdf386cd3e1cb8dc15669857fd73bcc32145719 GIT binary patch literal 15360 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 /Users/hanieharabzadeh/.nuget/packages/microsoft.extensions.apidescription.server/3.0.0 + /Users/hanieharabzadeh/.nuget/packages/newtonsoft.json/10.0.1 \ No newline at end of file diff --git a/MongoBookApis/obj/MongoBookApis.csproj.nuget.g.targets b/Back-end/MongoBookApis/obj/MongoBookApis.csproj.nuget.g.targets similarity index 100% rename from MongoBookApis/obj/MongoBookApis.csproj.nuget.g.targets rename to Back-end/MongoBookApis/obj/MongoBookApis.csproj.nuget.g.targets diff --git a/Back-end/MongoBookApis/obj/project.assets.json b/Back-end/MongoBookApis/obj/project.assets.json new file mode 100644 index 0000000..54ce99e --- /dev/null +++ b/Back-end/MongoBookApis/obj/project.assets.json @@ -0,0 +1,6024 @@ +{ + "version": 3, + "targets": { + "net5.0": { + "DnsClient/1.4.0": { + "type": "package", + "compile": { + "lib/netstandard2.1/DnsClient.dll": {} + }, + "runtime": { + "lib/netstandard2.1/DnsClient.dll": {} + } + }, + "Microsoft.AspNet.Cors/5.2.7": { + "type": "package", + "compile": { + "lib/net45/System.Web.Cors.dll": {} + }, + "runtime": { + "lib/net45/System.Web.Cors.dll": {} + } + }, + "Microsoft.AspNet.WebApi.Client/5.2.7": { + "type": "package", + "dependencies": { + "Newtonsoft.Json": "10.0.1", + "Newtonsoft.Json.Bson": "1.0.1" + }, + "compile": { + "lib/netstandard2.0/System.Net.Http.Formatting.dll": {} + }, + "runtime": { + "lib/netstandard2.0/System.Net.Http.Formatting.dll": {} + } + }, + "Microsoft.AspNet.WebApi.Core/5.2.7": { + "type": "package", + "dependencies": { + "Microsoft.AspNet.WebApi.Client": "5.2.7" + }, + "compile": { + "lib/net45/System.Web.Http.dll": {} + }, + "runtime": { + "lib/net45/System.Web.Http.dll": {} + } + }, + "Microsoft.AspNet.WebApi.Cors/5.2.7": { + "type": "package", + "dependencies": { + "Microsoft.AspNet.Cors": "5.2.7", + "Microsoft.AspNet.WebApi.Core": "[5.2.7, 5.3.0)" + }, + "compile": { + "lib/net45/System.Web.Http.Cors.dll": {} + }, + "runtime": { + "lib/net45/System.Web.Http.Cors.dll": {} + } + }, + "Microsoft.CSharp/4.3.0": { + "type": "package", + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Dynamic.Runtime": "4.3.0", + "System.Globalization": "4.3.0", + "System.Linq": "4.3.0", + "System.Linq.Expressions": "4.3.0", + "System.ObjectModel": "4.3.0", + "System.Reflection": "4.3.0", + "System.Reflection.Extensions": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Reflection.TypeExtensions": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Threading": "4.3.0" + }, + "compile": { + "ref/netstandard1.0/Microsoft.CSharp.dll": {} + }, + "runtime": { + "lib/netstandard1.3/Microsoft.CSharp.dll": {} + } + }, + "Microsoft.Extensions.ApiDescription.Server/3.0.0": { + "type": "package", + "build": { + "build/Microsoft.Extensions.ApiDescription.Server.props": {}, + "build/Microsoft.Extensions.ApiDescription.Server.targets": {} + }, + "buildMultiTargeting": { + "buildMultiTargeting/Microsoft.Extensions.ApiDescription.Server.props": {}, + "buildMultiTargeting/Microsoft.Extensions.ApiDescription.Server.targets": {} + } + }, + "Microsoft.NETCore.Platforms/2.1.2": { + "type": "package", + "compile": { + "lib/netstandard1.0/_._": {} + }, + "runtime": { + "lib/netstandard1.0/_._": {} + } + }, + "Microsoft.NETCore.Targets/1.1.0": { + "type": "package", + "compile": { + "lib/netstandard1.0/_._": {} + }, + "runtime": { + "lib/netstandard1.0/_._": {} + } + }, + "Microsoft.OpenApi/1.2.3": { + "type": "package", + "compile": { + "lib/netstandard2.0/Microsoft.OpenApi.dll": {} + }, + "runtime": { + "lib/netstandard2.0/Microsoft.OpenApi.dll": {} + } + }, + "Microsoft.Win32.Primitives/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/Microsoft.Win32.Primitives.dll": {} + } + }, + "MongoDB.Bson/2.13.2": { + "type": "package", + "dependencies": { + "System.Runtime.CompilerServices.Unsafe": "5.0.0" + }, + "compile": { + "lib/netstandard2.1/MongoDB.Bson.dll": {} + }, + "runtime": { + "lib/netstandard2.1/MongoDB.Bson.dll": {} + } + }, + "MongoDB.Driver/2.13.2": { + "type": "package", + "dependencies": { + "MongoDB.Bson": "2.13.2", + "MongoDB.Driver.Core": "2.13.2", + "MongoDB.Libmongocrypt": "1.2.2" + }, + "compile": { + "lib/netstandard2.1/MongoDB.Driver.dll": {} + }, + "runtime": { + "lib/netstandard2.1/MongoDB.Driver.dll": {} + } + }, + "MongoDB.Driver.Core/2.13.2": { + "type": "package", + "dependencies": { + "DnsClient": "1.4.0", + "MongoDB.Bson": "2.13.2", + "MongoDB.Libmongocrypt": "1.2.2", + "SharpCompress": "0.23.0", + "System.Buffers": "4.5.1" + }, + "compile": { + "lib/netstandard2.1/MongoDB.Driver.Core.dll": {} + }, + "runtime": { + "lib/netstandard2.1/MongoDB.Driver.Core.dll": {} + }, + "contentFiles": { + "contentFiles/any/any/_._": { + "buildAction": "None", + "codeLanguage": "any", + "copyToOutput": false + } + }, + "build": { + "build/_._": {} + }, + "runtimeTargets": { + "runtimes/win/native/libzstd.dll": { + "assetType": "native", + "rid": "win" + }, + "runtimes/win/native/snappy32.dll": { + "assetType": "native", + "rid": "win" + }, + "runtimes/win/native/snappy64.dll": { + "assetType": "native", + "rid": "win" + } + } + }, + "MongoDB.Libmongocrypt/1.2.2": { + "type": "package", + "compile": { + "lib/netstandard2.1/MongoDB.Libmongocrypt.dll": {} + }, + "runtime": { + "lib/netstandard2.1/MongoDB.Libmongocrypt.dll": {} + }, + "contentFiles": { + "contentFiles/any/any/_._": { + "buildAction": "None", + "codeLanguage": "any", + "copyToOutput": false + } + }, + "build": { + "build/_._": {} + }, + "runtimeTargets": { + "runtimes/linux/native/libmongocrypt.so": { + "assetType": "native", + "rid": "linux" + }, + "runtimes/osx/native/libmongocrypt.dylib": { + "assetType": "native", + "rid": "osx" + }, + "runtimes/win/native/mongocrypt.dll": { + "assetType": "native", + "rid": "win" + } + } + }, + "NETStandard.Library/1.6.1": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.Win32.Primitives": "4.3.0", + "System.AppContext": "4.3.0", + "System.Collections": "4.3.0", + "System.Collections.Concurrent": "4.3.0", + "System.Console": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Diagnostics.Tools": "4.3.0", + "System.Diagnostics.Tracing": "4.3.0", + "System.Globalization": "4.3.0", + "System.Globalization.Calendars": "4.3.0", + "System.IO": "4.3.0", + "System.IO.Compression": "4.3.0", + "System.IO.Compression.ZipFile": "4.3.0", + "System.IO.FileSystem": "4.3.0", + "System.IO.FileSystem.Primitives": "4.3.0", + "System.Linq": "4.3.0", + "System.Linq.Expressions": "4.3.0", + "System.Net.Http": "4.3.0", + "System.Net.Primitives": "4.3.0", + "System.Net.Sockets": "4.3.0", + "System.ObjectModel": "4.3.0", + "System.Reflection": "4.3.0", + "System.Reflection.Extensions": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Runtime.InteropServices.RuntimeInformation": "4.3.0", + "System.Runtime.Numerics": "4.3.0", + "System.Security.Cryptography.Algorithms": "4.3.0", + "System.Security.Cryptography.Encoding": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Security.Cryptography.X509Certificates": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Text.Encoding.Extensions": "4.3.0", + "System.Text.RegularExpressions": "4.3.0", + "System.Threading": "4.3.0", + "System.Threading.Tasks": "4.3.0", + "System.Threading.Timer": "4.3.0", + "System.Xml.ReaderWriter": "4.3.0", + "System.Xml.XDocument": "4.3.0" + } + }, + "Newtonsoft.Json/10.0.1": { + "type": "package", + "dependencies": { + "Microsoft.CSharp": "4.3.0", + "System.Collections": "4.3.0", + "System.ComponentModel.TypeConverter": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Dynamic.Runtime": "4.3.0", + "System.Globalization": "4.3.0", + "System.IO": "4.3.0", + "System.Linq": "4.3.0", + "System.Linq.Expressions": "4.3.0", + "System.ObjectModel": "4.3.0", + "System.Reflection": "4.3.0", + "System.Reflection.Extensions": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Numerics": "4.3.0", + "System.Runtime.Serialization.Formatters": "4.3.0", + "System.Runtime.Serialization.Primitives": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Text.Encoding.Extensions": "4.3.0", + "System.Text.RegularExpressions": "4.3.0", + "System.Threading": "4.3.0", + "System.Threading.Tasks": "4.3.0", + "System.Xml.ReaderWriter": "4.3.0", + "System.Xml.XDocument": "4.3.0", + "System.Xml.XmlDocument": "4.3.0" + }, + "compile": { + "lib/netstandard1.3/Newtonsoft.Json.dll": {} + }, + "runtime": { + "lib/netstandard1.3/Newtonsoft.Json.dll": {} + } + }, + "Newtonsoft.Json.Bson/1.0.1": { + "type": "package", + "dependencies": { + "NETStandard.Library": "1.6.1", + "Newtonsoft.Json": "10.0.1" + }, + "compile": { + "lib/netstandard1.3/Newtonsoft.Json.Bson.dll": {} + }, + "runtime": { + "lib/netstandard1.3/Newtonsoft.Json.Bson.dll": {} + } + }, + "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "runtimeTargets": { + "runtimes/debian.8-x64/native/System.Security.Cryptography.Native.OpenSsl.so": { + "assetType": "native", + "rid": "debian.8-x64" + } + } + }, + "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "runtimeTargets": { + "runtimes/fedora.23-x64/native/System.Security.Cryptography.Native.OpenSsl.so": { + "assetType": "native", + "rid": "fedora.23-x64" + } + } + }, + "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "runtimeTargets": { + "runtimes/fedora.24-x64/native/System.Security.Cryptography.Native.OpenSsl.so": { + "assetType": "native", + "rid": "fedora.24-x64" + } + } + }, + "runtime.native.System/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0" + }, + "compile": { + "lib/netstandard1.0/_._": {} + }, + "runtime": { + "lib/netstandard1.0/_._": {} + } + }, + "runtime.native.System.IO.Compression/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0" + }, + "compile": { + "lib/netstandard1.0/_._": {} + }, + "runtime": { + "lib/netstandard1.0/_._": {} + } + }, + "runtime.native.System.Net.Http/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0" + }, + "compile": { + "lib/netstandard1.0/_._": {} + }, + "runtime": { + "lib/netstandard1.0/_._": {} + } + }, + "runtime.native.System.Security.Cryptography.Apple/4.3.0": { + "type": "package", + "dependencies": { + "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple": "4.3.0" + }, + "compile": { + "lib/netstandard1.0/_._": {} + }, + "runtime": { + "lib/netstandard1.0/_._": {} + } + }, + "runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "dependencies": { + "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0", + "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0" + }, + "compile": { + "lib/netstandard1.0/_._": {} + }, + "runtime": { + "lib/netstandard1.0/_._": {} + } + }, + "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "runtimeTargets": { + "runtimes/opensuse.13.2-x64/native/System.Security.Cryptography.Native.OpenSsl.so": { + "assetType": "native", + "rid": "opensuse.13.2-x64" + } + } + }, + "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "runtimeTargets": { + "runtimes/opensuse.42.1-x64/native/System.Security.Cryptography.Native.OpenSsl.so": { + "assetType": "native", + "rid": "opensuse.42.1-x64" + } + } + }, + "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple/4.3.0": { + "type": "package", + "runtimeTargets": { + "runtimes/osx.10.10-x64/native/System.Security.Cryptography.Native.Apple.dylib": { + "assetType": "native", + "rid": "osx.10.10-x64" + } + } + }, + "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "runtimeTargets": { + "runtimes/osx.10.10-x64/native/System.Security.Cryptography.Native.OpenSsl.dylib": { + "assetType": "native", + "rid": "osx.10.10-x64" + } + } + }, + "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "runtimeTargets": { + "runtimes/rhel.7-x64/native/System.Security.Cryptography.Native.OpenSsl.so": { + "assetType": "native", + "rid": "rhel.7-x64" + } + } + }, + "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "runtimeTargets": { + "runtimes/ubuntu.14.04-x64/native/System.Security.Cryptography.Native.OpenSsl.so": { + "assetType": "native", + "rid": "ubuntu.14.04-x64" + } + } + }, + "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "runtimeTargets": { + "runtimes/ubuntu.16.04-x64/native/System.Security.Cryptography.Native.OpenSsl.so": { + "assetType": "native", + "rid": "ubuntu.16.04-x64" + } + } + }, + "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "runtimeTargets": { + "runtimes/ubuntu.16.10-x64/native/System.Security.Cryptography.Native.OpenSsl.so": { + "assetType": "native", + "rid": "ubuntu.16.10-x64" + } + } + }, + "SharpCompress/0.23.0": { + "type": "package", + "dependencies": { + "System.Text.Encoding.CodePages": "4.5.1" + }, + "compile": { + "lib/netstandard2.0/SharpCompress.dll": {} + }, + "runtime": { + "lib/netstandard2.0/SharpCompress.dll": {} + } + }, + "Swashbuckle.AspNetCore/5.6.3": { + "type": "package", + "dependencies": { + "Microsoft.Extensions.ApiDescription.Server": "3.0.0", + "Swashbuckle.AspNetCore.Swagger": "5.6.3", + "Swashbuckle.AspNetCore.SwaggerGen": "5.6.3", + "Swashbuckle.AspNetCore.SwaggerUI": "5.6.3" + }, + "build": { + "build/Swashbuckle.AspNetCore.props": {} + } + }, + "Swashbuckle.AspNetCore.Swagger/5.6.3": { + "type": "package", + "dependencies": { + "Microsoft.OpenApi": "1.2.3" + }, + "compile": { + "lib/netcoreapp3.0/Swashbuckle.AspNetCore.Swagger.dll": {} + }, + "runtime": { + "lib/netcoreapp3.0/Swashbuckle.AspNetCore.Swagger.dll": {} + }, + "frameworkReferences": [ + "Microsoft.AspNetCore.App" + ] + }, + "Swashbuckle.AspNetCore.SwaggerGen/5.6.3": { + "type": "package", + "dependencies": { + "Swashbuckle.AspNetCore.Swagger": "5.6.3" + }, + "compile": { + "lib/netcoreapp3.0/Swashbuckle.AspNetCore.SwaggerGen.dll": {} + }, + "runtime": { + "lib/netcoreapp3.0/Swashbuckle.AspNetCore.SwaggerGen.dll": {} + }, + "frameworkReferences": [ + "Microsoft.AspNetCore.App" + ] + }, + "Swashbuckle.AspNetCore.SwaggerUI/5.6.3": { + "type": "package", + "compile": { + "lib/netcoreapp3.0/Swashbuckle.AspNetCore.SwaggerUI.dll": {} + }, + "runtime": { + "lib/netcoreapp3.0/Swashbuckle.AspNetCore.SwaggerUI.dll": {} + }, + "frameworkReferences": [ + "Microsoft.AspNetCore.App" + ] + }, + "System.AppContext/4.3.0": { + "type": "package", + "dependencies": { + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.6/System.AppContext.dll": {} + }, + "runtime": { + "lib/netstandard1.6/System.AppContext.dll": {} + } + }, + "System.Buffers/4.5.1": { + "type": "package", + "compile": { + "ref/netcoreapp2.0/_._": {} + }, + "runtime": { + "lib/netcoreapp2.0/_._": {} + } + }, + "System.Collections/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Collections.dll": {} + } + }, + "System.Collections.Concurrent/4.3.0": { + "type": "package", + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Diagnostics.Tracing": "4.3.0", + "System.Globalization": "4.3.0", + "System.Reflection": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Threading": "4.3.0", + "System.Threading.Tasks": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Collections.Concurrent.dll": {} + }, + "runtime": { + "lib/netstandard1.3/System.Collections.Concurrent.dll": {} + } + }, + "System.Collections.NonGeneric/4.3.0": { + "type": "package", + "dependencies": { + "System.Diagnostics.Debug": "4.3.0", + "System.Globalization": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Threading": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Collections.NonGeneric.dll": {} + }, + "runtime": { + "lib/netstandard1.3/System.Collections.NonGeneric.dll": {} + } + }, + "System.Collections.Specialized/4.3.0": { + "type": "package", + "dependencies": { + "System.Collections.NonGeneric": "4.3.0", + "System.Globalization": "4.3.0", + "System.Globalization.Extensions": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Threading": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/_._": {} + }, + "runtime": { + "lib/netstandard1.3/System.Collections.Specialized.dll": {} + } + }, + "System.ComponentModel/4.3.0": { + "type": "package", + "dependencies": { + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.0/System.ComponentModel.dll": {} + }, + "runtime": { + "lib/netstandard1.3/System.ComponentModel.dll": {} + } + }, + "System.ComponentModel.Primitives/4.3.0": { + "type": "package", + "dependencies": { + "System.ComponentModel": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.0/System.ComponentModel.Primitives.dll": {} + }, + "runtime": { + "lib/netstandard1.0/System.ComponentModel.Primitives.dll": {} + } + }, + "System.ComponentModel.TypeConverter/4.3.0": { + "type": "package", + "dependencies": { + "System.Collections": "4.3.0", + "System.Collections.NonGeneric": "4.3.0", + "System.Collections.Specialized": "4.3.0", + "System.ComponentModel": "4.3.0", + "System.ComponentModel.Primitives": "4.3.0", + "System.Globalization": "4.3.0", + "System.Linq": "4.3.0", + "System.Reflection": "4.3.0", + "System.Reflection.Extensions": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Reflection.TypeExtensions": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Threading": "4.3.0" + }, + "compile": { + "ref/netstandard1.5/System.ComponentModel.TypeConverter.dll": {} + }, + "runtime": { + "lib/netstandard1.5/System.ComponentModel.TypeConverter.dll": {} + } + }, + "System.Console/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.IO": "4.3.0", + "System.Runtime": "4.3.0", + "System.Text.Encoding": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Console.dll": {} + } + }, + "System.Diagnostics.Debug/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Diagnostics.Debug.dll": {} + } + }, + "System.Diagnostics.DiagnosticSource/4.3.0": { + "type": "package", + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Tracing": "4.3.0", + "System.Reflection": "4.3.0", + "System.Runtime": "4.3.0", + "System.Threading": "4.3.0" + }, + "compile": { + "lib/netstandard1.3/_._": {} + }, + "runtime": { + "lib/netstandard1.3/System.Diagnostics.DiagnosticSource.dll": {} + } + }, + "System.Diagnostics.Tools/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.0/System.Diagnostics.Tools.dll": {} + } + }, + "System.Diagnostics.Tracing/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.5/System.Diagnostics.Tracing.dll": {} + } + }, + "System.Dynamic.Runtime/4.3.0": { + "type": "package", + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Linq": "4.3.0", + "System.Linq.Expressions": "4.3.0", + "System.ObjectModel": "4.3.0", + "System.Reflection": "4.3.0", + "System.Reflection.Emit": "4.3.0", + "System.Reflection.Emit.ILGeneration": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Reflection.TypeExtensions": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Threading": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Dynamic.Runtime.dll": {} + }, + "runtime": { + "lib/netstandard1.3/System.Dynamic.Runtime.dll": {} + } + }, + "System.Globalization/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Globalization.dll": {} + } + }, + "System.Globalization.Calendars/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Globalization": "4.3.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Globalization.Calendars.dll": {} + } + }, + "System.Globalization.Extensions/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "System.Globalization": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.InteropServices": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/_._": {} + }, + "runtimeTargets": { + "runtimes/unix/lib/netstandard1.3/System.Globalization.Extensions.dll": { + "assetType": "runtime", + "rid": "unix" + }, + "runtimes/win/lib/netstandard1.3/System.Globalization.Extensions.dll": { + "assetType": "runtime", + "rid": "win" + } + } + }, + "System.IO/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading.Tasks": "4.3.0" + }, + "compile": { + "ref/netstandard1.5/System.IO.dll": {} + } + }, + "System.IO.Compression/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "System.Buffers": "4.3.0", + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.IO": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading": "4.3.0", + "System.Threading.Tasks": "4.3.0", + "runtime.native.System": "4.3.0", + "runtime.native.System.IO.Compression": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.IO.Compression.dll": {} + }, + "runtimeTargets": { + "runtimes/unix/lib/netstandard1.3/System.IO.Compression.dll": { + "assetType": "runtime", + "rid": "unix" + }, + "runtimes/win/lib/netstandard1.3/System.IO.Compression.dll": { + "assetType": "runtime", + "rid": "win" + } + } + }, + "System.IO.Compression.ZipFile/4.3.0": { + "type": "package", + "dependencies": { + "System.Buffers": "4.3.0", + "System.IO": "4.3.0", + "System.IO.Compression": "4.3.0", + "System.IO.FileSystem": "4.3.0", + "System.IO.FileSystem.Primitives": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Text.Encoding": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.IO.Compression.ZipFile.dll": {} + }, + "runtime": { + "lib/netstandard1.3/System.IO.Compression.ZipFile.dll": {} + } + }, + "System.IO.FileSystem/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.IO": "4.3.0", + "System.IO.FileSystem.Primitives": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading.Tasks": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.IO.FileSystem.dll": {} + } + }, + "System.IO.FileSystem.Primitives/4.3.0": { + "type": "package", + "dependencies": { + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.IO.FileSystem.Primitives.dll": {} + }, + "runtime": { + "lib/netstandard1.3/System.IO.FileSystem.Primitives.dll": {} + } + }, + "System.Linq/4.3.0": { + "type": "package", + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0" + }, + "compile": { + "ref/netstandard1.6/System.Linq.dll": {} + }, + "runtime": { + "lib/netstandard1.6/System.Linq.dll": {} + } + }, + "System.Linq.Expressions/4.3.0": { + "type": "package", + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Globalization": "4.3.0", + "System.IO": "4.3.0", + "System.Linq": "4.3.0", + "System.ObjectModel": "4.3.0", + "System.Reflection": "4.3.0", + "System.Reflection.Emit": "4.3.0", + "System.Reflection.Emit.ILGeneration": "4.3.0", + "System.Reflection.Emit.Lightweight": "4.3.0", + "System.Reflection.Extensions": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Reflection.TypeExtensions": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Threading": "4.3.0" + }, + "compile": { + "ref/netstandard1.6/System.Linq.Expressions.dll": {} + }, + "runtime": { + "lib/netstandard1.6/System.Linq.Expressions.dll": {} + } + }, + "System.Net.Http/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Diagnostics.DiagnosticSource": "4.3.0", + "System.Diagnostics.Tracing": "4.3.0", + "System.Globalization": "4.3.0", + "System.Globalization.Extensions": "4.3.0", + "System.IO": "4.3.0", + "System.IO.FileSystem": "4.3.0", + "System.Net.Primitives": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Security.Cryptography.Algorithms": "4.3.0", + "System.Security.Cryptography.Encoding": "4.3.0", + "System.Security.Cryptography.OpenSsl": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Security.Cryptography.X509Certificates": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading": "4.3.0", + "System.Threading.Tasks": "4.3.0", + "runtime.native.System": "4.3.0", + "runtime.native.System.Net.Http": "4.3.0", + "runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Net.Http.dll": {} + }, + "runtimeTargets": { + "runtimes/unix/lib/netstandard1.6/System.Net.Http.dll": { + "assetType": "runtime", + "rid": "unix" + }, + "runtimes/win/lib/netstandard1.3/System.Net.Http.dll": { + "assetType": "runtime", + "rid": "win" + } + } + }, + "System.Net.Primitives/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0", + "System.Runtime.Handles": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Net.Primitives.dll": {} + } + }, + "System.Net.Sockets/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.IO": "4.3.0", + "System.Net.Primitives": "4.3.0", + "System.Runtime": "4.3.0", + "System.Threading.Tasks": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Net.Sockets.dll": {} + } + }, + "System.ObjectModel/4.3.0": { + "type": "package", + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Threading": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.ObjectModel.dll": {} + }, + "runtime": { + "lib/netstandard1.3/System.ObjectModel.dll": {} + } + }, + "System.Reflection/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.IO": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.5/System.Reflection.dll": {} + } + }, + "System.Reflection.Emit/4.3.0": { + "type": "package", + "dependencies": { + "System.IO": "4.3.0", + "System.Reflection": "4.3.0", + "System.Reflection.Emit.ILGeneration": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.1/_._": {} + }, + "runtime": { + "lib/netstandard1.3/System.Reflection.Emit.dll": {} + } + }, + "System.Reflection.Emit.ILGeneration/4.3.0": { + "type": "package", + "dependencies": { + "System.Reflection": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.0/_._": {} + }, + "runtime": { + "lib/netstandard1.3/System.Reflection.Emit.ILGeneration.dll": {} + } + }, + "System.Reflection.Emit.Lightweight/4.3.0": { + "type": "package", + "dependencies": { + "System.Reflection": "4.3.0", + "System.Reflection.Emit.ILGeneration": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.0/_._": {} + }, + "runtime": { + "lib/netstandard1.3/System.Reflection.Emit.Lightweight.dll": {} + } + }, + "System.Reflection.Extensions/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Reflection": "4.3.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.0/System.Reflection.Extensions.dll": {} + } + }, + "System.Reflection.Primitives/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.0/System.Reflection.Primitives.dll": {} + } + }, + "System.Reflection.TypeExtensions/4.3.0": { + "type": "package", + "dependencies": { + "System.Reflection": "4.3.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.5/_._": {} + }, + "runtime": { + "lib/netstandard1.5/System.Reflection.TypeExtensions.dll": {} + } + }, + "System.Resources.ResourceManager/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Globalization": "4.3.0", + "System.Reflection": "4.3.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.0/System.Resources.ResourceManager.dll": {} + } + }, + "System.Runtime/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0" + }, + "compile": { + "ref/netstandard1.5/System.Runtime.dll": {} + } + }, + "System.Runtime.CompilerServices.Unsafe/5.0.0": { + "type": "package", + "compile": { + "ref/netstandard2.1/System.Runtime.CompilerServices.Unsafe.dll": {} + }, + "runtime": { + "lib/netcoreapp2.0/System.Runtime.CompilerServices.Unsafe.dll": {} + } + }, + "System.Runtime.Extensions/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.5/System.Runtime.Extensions.dll": {} + } + }, + "System.Runtime.Handles/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Runtime.Handles.dll": {} + } + }, + "System.Runtime.InteropServices/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Reflection": "4.3.0", + "System.Reflection.Primitives": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Handles": "4.3.0" + }, + "compile": { + "ref/netcoreapp1.1/System.Runtime.InteropServices.dll": {} + } + }, + "System.Runtime.InteropServices.RuntimeInformation/4.3.0": { + "type": "package", + "dependencies": { + "System.Reflection": "4.3.0", + "System.Reflection.Extensions": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Threading": "4.3.0", + "runtime.native.System": "4.3.0" + }, + "compile": { + "ref/netstandard1.1/System.Runtime.InteropServices.RuntimeInformation.dll": {} + }, + "runtime": { + "lib/netstandard1.1/System.Runtime.InteropServices.RuntimeInformation.dll": {} + }, + "runtimeTargets": { + "runtimes/unix/lib/netstandard1.1/System.Runtime.InteropServices.RuntimeInformation.dll": { + "assetType": "runtime", + "rid": "unix" + }, + "runtimes/win/lib/netstandard1.1/System.Runtime.InteropServices.RuntimeInformation.dll": { + "assetType": "runtime", + "rid": "win" + } + } + }, + "System.Runtime.Numerics/4.3.0": { + "type": "package", + "dependencies": { + "System.Globalization": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0" + }, + "compile": { + "ref/netstandard1.1/System.Runtime.Numerics.dll": {} + }, + "runtime": { + "lib/netstandard1.3/System.Runtime.Numerics.dll": {} + } + }, + "System.Runtime.Serialization.Formatters/4.3.0": { + "type": "package", + "dependencies": { + "System.Collections": "4.3.0", + "System.Reflection": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Serialization.Primitives": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Runtime.Serialization.Formatters.dll": {} + }, + "runtime": { + "lib/netstandard1.4/System.Runtime.Serialization.Formatters.dll": {} + } + }, + "System.Runtime.Serialization.Primitives/4.3.0": { + "type": "package", + "dependencies": { + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Runtime.Serialization.Primitives.dll": {} + }, + "runtime": { + "lib/netstandard1.3/System.Runtime.Serialization.Primitives.dll": {} + } + }, + "System.Security.Cryptography.Algorithms/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "System.Collections": "4.3.0", + "System.IO": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Runtime.Numerics": "4.3.0", + "System.Security.Cryptography.Encoding": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Text.Encoding": "4.3.0", + "runtime.native.System.Security.Cryptography.Apple": "4.3.0", + "runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0" + }, + "compile": { + "ref/netstandard1.6/System.Security.Cryptography.Algorithms.dll": {} + }, + "runtimeTargets": { + "runtimes/osx/lib/netstandard1.6/System.Security.Cryptography.Algorithms.dll": { + "assetType": "runtime", + "rid": "osx" + }, + "runtimes/unix/lib/netstandard1.6/System.Security.Cryptography.Algorithms.dll": { + "assetType": "runtime", + "rid": "unix" + }, + "runtimes/win/lib/netstandard1.6/System.Security.Cryptography.Algorithms.dll": { + "assetType": "runtime", + "rid": "win" + } + } + }, + "System.Security.Cryptography.Cng/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "System.IO": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Security.Cryptography.Algorithms": "4.3.0", + "System.Security.Cryptography.Encoding": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Text.Encoding": "4.3.0" + }, + "compile": { + "ref/netstandard1.6/_._": {} + }, + "runtimeTargets": { + "runtimes/unix/lib/netstandard1.6/System.Security.Cryptography.Cng.dll": { + "assetType": "runtime", + "rid": "unix" + }, + "runtimes/win/lib/netstandard1.6/System.Security.Cryptography.Cng.dll": { + "assetType": "runtime", + "rid": "win" + } + } + }, + "System.Security.Cryptography.Csp/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "System.IO": "4.3.0", + "System.Reflection": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Security.Cryptography.Algorithms": "4.3.0", + "System.Security.Cryptography.Encoding": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/_._": {} + }, + "runtimeTargets": { + "runtimes/unix/lib/netstandard1.3/System.Security.Cryptography.Csp.dll": { + "assetType": "runtime", + "rid": "unix" + }, + "runtimes/win/lib/netstandard1.3/System.Security.Cryptography.Csp.dll": { + "assetType": "runtime", + "rid": "win" + } + } + }, + "System.Security.Cryptography.Encoding/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "System.Collections": "4.3.0", + "System.Collections.Concurrent": "4.3.0", + "System.Linq": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Text.Encoding": "4.3.0", + "runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Security.Cryptography.Encoding.dll": {} + }, + "runtimeTargets": { + "runtimes/unix/lib/netstandard1.3/System.Security.Cryptography.Encoding.dll": { + "assetType": "runtime", + "rid": "unix" + }, + "runtimes/win/lib/netstandard1.3/System.Security.Cryptography.Encoding.dll": { + "assetType": "runtime", + "rid": "win" + } + } + }, + "System.Security.Cryptography.OpenSsl/4.3.0": { + "type": "package", + "dependencies": { + "System.Collections": "4.3.0", + "System.IO": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Runtime.Numerics": "4.3.0", + "System.Security.Cryptography.Algorithms": "4.3.0", + "System.Security.Cryptography.Encoding": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Text.Encoding": "4.3.0", + "runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0" + }, + "compile": { + "ref/netstandard1.6/_._": {} + }, + "runtime": { + "lib/netstandard1.6/System.Security.Cryptography.OpenSsl.dll": {} + }, + "runtimeTargets": { + "runtimes/unix/lib/netstandard1.6/System.Security.Cryptography.OpenSsl.dll": { + "assetType": "runtime", + "rid": "unix" + } + } + }, + "System.Security.Cryptography.Primitives/4.3.0": { + "type": "package", + "dependencies": { + "System.Diagnostics.Debug": "4.3.0", + "System.Globalization": "4.3.0", + "System.IO": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Threading": "4.3.0", + "System.Threading.Tasks": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Security.Cryptography.Primitives.dll": {} + }, + "runtime": { + "lib/netstandard1.3/System.Security.Cryptography.Primitives.dll": {} + } + }, + "System.Security.Cryptography.X509Certificates/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Globalization": "4.3.0", + "System.Globalization.Calendars": "4.3.0", + "System.IO": "4.3.0", + "System.IO.FileSystem": "4.3.0", + "System.IO.FileSystem.Primitives": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.Handles": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Runtime.Numerics": "4.3.0", + "System.Security.Cryptography.Algorithms": "4.3.0", + "System.Security.Cryptography.Cng": "4.3.0", + "System.Security.Cryptography.Csp": "4.3.0", + "System.Security.Cryptography.Encoding": "4.3.0", + "System.Security.Cryptography.OpenSsl": "4.3.0", + "System.Security.Cryptography.Primitives": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading": "4.3.0", + "runtime.native.System": "4.3.0", + "runtime.native.System.Net.Http": "4.3.0", + "runtime.native.System.Security.Cryptography.OpenSsl": "4.3.0" + }, + "compile": { + "ref/netstandard1.4/System.Security.Cryptography.X509Certificates.dll": {} + }, + "runtimeTargets": { + "runtimes/unix/lib/netstandard1.6/System.Security.Cryptography.X509Certificates.dll": { + "assetType": "runtime", + "rid": "unix" + }, + "runtimes/win/lib/netstandard1.6/System.Security.Cryptography.X509Certificates.dll": { + "assetType": "runtime", + "rid": "win" + } + } + }, + "System.Text.Encoding/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Text.Encoding.dll": {} + } + }, + "System.Text.Encoding.CodePages/4.5.1": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "2.1.2", + "System.Runtime.CompilerServices.Unsafe": "4.5.2" + }, + "compile": { + "lib/netstandard2.0/System.Text.Encoding.CodePages.dll": {} + }, + "runtime": { + "lib/netstandard2.0/System.Text.Encoding.CodePages.dll": {} + }, + "runtimeTargets": { + "runtimes/win/lib/netcoreapp2.0/System.Text.Encoding.CodePages.dll": { + "assetType": "runtime", + "rid": "win" + } + } + }, + "System.Text.Encoding.Extensions/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0", + "System.Text.Encoding": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Text.Encoding.Extensions.dll": {} + } + }, + "System.Text.RegularExpressions/4.3.0": { + "type": "package", + "dependencies": { + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netcoreapp1.1/System.Text.RegularExpressions.dll": {} + }, + "runtime": { + "lib/netstandard1.6/System.Text.RegularExpressions.dll": {} + } + }, + "System.Threading/4.3.0": { + "type": "package", + "dependencies": { + "System.Runtime": "4.3.0", + "System.Threading.Tasks": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Threading.dll": {} + }, + "runtime": { + "lib/netstandard1.3/System.Threading.dll": {} + } + }, + "System.Threading.Tasks/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Threading.Tasks.dll": {} + } + }, + "System.Threading.Tasks.Extensions/4.3.0": { + "type": "package", + "dependencies": { + "System.Collections": "4.3.0", + "System.Runtime": "4.3.0", + "System.Threading.Tasks": "4.3.0" + }, + "compile": { + "lib/netstandard1.0/_._": {} + }, + "runtime": { + "lib/netstandard1.0/System.Threading.Tasks.Extensions.dll": {} + } + }, + "System.Threading.Timer/4.3.0": { + "type": "package", + "dependencies": { + "Microsoft.NETCore.Platforms": "1.1.0", + "Microsoft.NETCore.Targets": "1.1.0", + "System.Runtime": "4.3.0" + }, + "compile": { + "ref/netstandard1.2/System.Threading.Timer.dll": {} + } + }, + "System.Xml.ReaderWriter/4.3.0": { + "type": "package", + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Globalization": "4.3.0", + "System.IO": "4.3.0", + "System.IO.FileSystem": "4.3.0", + "System.IO.FileSystem.Primitives": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Runtime.InteropServices": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Text.Encoding.Extensions": "4.3.0", + "System.Text.RegularExpressions": "4.3.0", + "System.Threading.Tasks": "4.3.0", + "System.Threading.Tasks.Extensions": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Xml.ReaderWriter.dll": {} + }, + "runtime": { + "lib/netstandard1.3/System.Xml.ReaderWriter.dll": {} + } + }, + "System.Xml.XDocument/4.3.0": { + "type": "package", + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Diagnostics.Tools": "4.3.0", + "System.Globalization": "4.3.0", + "System.IO": "4.3.0", + "System.Reflection": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading": "4.3.0", + "System.Xml.ReaderWriter": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Xml.XDocument.dll": {} + }, + "runtime": { + "lib/netstandard1.3/System.Xml.XDocument.dll": {} + } + }, + "System.Xml.XmlDocument/4.3.0": { + "type": "package", + "dependencies": { + "System.Collections": "4.3.0", + "System.Diagnostics.Debug": "4.3.0", + "System.Globalization": "4.3.0", + "System.IO": "4.3.0", + "System.Resources.ResourceManager": "4.3.0", + "System.Runtime": "4.3.0", + "System.Runtime.Extensions": "4.3.0", + "System.Text.Encoding": "4.3.0", + "System.Threading": "4.3.0", + "System.Xml.ReaderWriter": "4.3.0" + }, + "compile": { + "ref/netstandard1.3/System.Xml.XmlDocument.dll": {} + }, + "runtime": { + "lib/netstandard1.3/System.Xml.XmlDocument.dll": {} + } + } + } + }, + "libraries": { + "DnsClient/1.4.0": { + "sha512": "CO1NG1zQdV0nEAXmr/KppLZ0S1qkaPwV0kPX5YPgmYBtrBVh1XMYHM54IXy3RBJu1k4thFtpzwo4HNHqxiuFYw==", + "type": "package", + "path": "dnsclient/1.4.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "dnsclient.1.4.0.nupkg.sha512", + "dnsclient.nuspec", + "icon.png", + "lib/net45/DnsClient.dll", + "lib/net45/DnsClient.xml", + "lib/net471/DnsClient.dll", + "lib/net471/DnsClient.xml", + "lib/netstandard1.3/DnsClient.dll", + "lib/netstandard1.3/DnsClient.xml", + "lib/netstandard2.0/DnsClient.dll", + "lib/netstandard2.0/DnsClient.xml", + "lib/netstandard2.1/DnsClient.dll", + "lib/netstandard2.1/DnsClient.xml" + ] + }, + "Microsoft.AspNet.Cors/5.2.7": { + "sha512": "r7qTj8SKzHT32F2mbB3qgE+6VUd2xILkGaq4LtMW+KP3dDAQmI//j+8Ku01I3D1GKZvB9PU8HTJPkaw7sxSLtQ==", + "type": "package", + "path": "microsoft.aspnet.cors/5.2.7", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "lib/net45/System.Web.Cors.dll", + "microsoft.aspnet.cors.5.2.7.nupkg.sha512", + "microsoft.aspnet.cors.nuspec" + ] + }, + "Microsoft.AspNet.WebApi.Client/5.2.7": { + "sha512": "/76fAHknzvFqbznS6Uj2sOyE9rJB3PltY+f53TH8dX9RiGhk02EhuFCWljSj5nnqKaTsmma8DFR50OGyQ4yJ1g==", + "type": "package", + "path": "microsoft.aspnet.webapi.client/5.2.7", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "lib/net45/System.Net.Http.Formatting.dll", + "lib/net45/System.Net.Http.Formatting.xml", + "lib/netstandard2.0/System.Net.Http.Formatting.dll", + "lib/netstandard2.0/System.Net.Http.Formatting.xml", + "lib/portable-wp8+netcore45+net45+wp81+wpa81/System.Net.Http.Formatting.dll", + "lib/portable-wp8+netcore45+net45+wp81+wpa81/System.Net.Http.Formatting.xml", + "microsoft.aspnet.webapi.client.5.2.7.nupkg.sha512", + "microsoft.aspnet.webapi.client.nuspec" + ] + }, + "Microsoft.AspNet.WebApi.Core/5.2.7": { + "sha512": "gM2QzApnHdy1FbKUJ/ROGJSm69P2G+HMoVd/t5Vq1O/zZ5TI4IKC9PX6nUfRt/NHgebZOIWHpB4/4K4inuy4yQ==", + "type": "package", + "path": "microsoft.aspnet.webapi.core/5.2.7", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "Content/web.config.transform", + "lib/net45/System.Web.Http.dll", + "lib/net45/System.Web.Http.xml", + "microsoft.aspnet.webapi.core.5.2.7.nupkg.sha512", + "microsoft.aspnet.webapi.core.nuspec" + ] + }, + "Microsoft.AspNet.WebApi.Cors/5.2.7": { + "sha512": "LUY5ufoiYLHKZXdrrNe7GlAwmu9WlyrX5iUtBSLwFZ31/tvPobyU7j1E31OWVdGZMBvRCxKbfyB7unxgrjTRpA==", + "type": "package", + "path": "microsoft.aspnet.webapi.cors/5.2.7", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "lib/net45/System.Web.Http.Cors.dll", + "lib/net45/System.Web.Http.Cors.xml", + "microsoft.aspnet.webapi.cors.5.2.7.nupkg.sha512", + "microsoft.aspnet.webapi.cors.nuspec" + ] + }, + "Microsoft.CSharp/4.3.0": { + "sha512": "P+MBhIM0YX+JqROuf7i306ZLJEjQYA9uUyRDE+OqwUI5sh41e2ZbPQV3LfAPh+29cmceE1pUffXsGfR4eMY3KA==", + "type": "package", + "path": "microsoft.csharp/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/netcore50/Microsoft.CSharp.dll", + "lib/netstandard1.3/Microsoft.CSharp.dll", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "microsoft.csharp.4.3.0.nupkg.sha512", + "microsoft.csharp.nuspec", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/Microsoft.CSharp.dll", + "ref/netcore50/Microsoft.CSharp.xml", + "ref/netcore50/de/Microsoft.CSharp.xml", + "ref/netcore50/es/Microsoft.CSharp.xml", + "ref/netcore50/fr/Microsoft.CSharp.xml", + "ref/netcore50/it/Microsoft.CSharp.xml", + "ref/netcore50/ja/Microsoft.CSharp.xml", + "ref/netcore50/ko/Microsoft.CSharp.xml", + "ref/netcore50/ru/Microsoft.CSharp.xml", + "ref/netcore50/zh-hans/Microsoft.CSharp.xml", + "ref/netcore50/zh-hant/Microsoft.CSharp.xml", + "ref/netstandard1.0/Microsoft.CSharp.dll", + "ref/netstandard1.0/Microsoft.CSharp.xml", + "ref/netstandard1.0/de/Microsoft.CSharp.xml", + "ref/netstandard1.0/es/Microsoft.CSharp.xml", + "ref/netstandard1.0/fr/Microsoft.CSharp.xml", + "ref/netstandard1.0/it/Microsoft.CSharp.xml", + "ref/netstandard1.0/ja/Microsoft.CSharp.xml", + "ref/netstandard1.0/ko/Microsoft.CSharp.xml", + "ref/netstandard1.0/ru/Microsoft.CSharp.xml", + "ref/netstandard1.0/zh-hans/Microsoft.CSharp.xml", + "ref/netstandard1.0/zh-hant/Microsoft.CSharp.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._" + ] + }, + "Microsoft.Extensions.ApiDescription.Server/3.0.0": { + "sha512": "LH4OE/76F6sOCslif7+Xh3fS/wUUrE5ryeXAMcoCnuwOQGT5Smw0p57IgDh/pHgHaGz/e+AmEQb7pRgb++wt0w==", + "type": "package", + "path": "microsoft.extensions.apidescription.server/3.0.0", + "hasTools": true, + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "build/Microsoft.Extensions.ApiDescription.Server.props", + "build/Microsoft.Extensions.ApiDescription.Server.targets", + "buildMultiTargeting/Microsoft.Extensions.ApiDescription.Server.props", + "buildMultiTargeting/Microsoft.Extensions.ApiDescription.Server.targets", + "microsoft.extensions.apidescription.server.3.0.0.nupkg.sha512", + "microsoft.extensions.apidescription.server.nuspec", + "tools/Newtonsoft.Json.dll", + "tools/dotnet-getdocument.deps.json", + "tools/dotnet-getdocument.dll", + "tools/dotnet-getdocument.runtimeconfig.json", + "tools/net461-x86/GetDocument.Insider.exe", + "tools/net461-x86/GetDocument.Insider.exe.config", + "tools/net461/GetDocument.Insider.exe", + "tools/net461/GetDocument.Insider.exe.config", + "tools/netcoreapp2.1/GetDocument.Insider.deps.json", + "tools/netcoreapp2.1/GetDocument.Insider.dll", + "tools/netcoreapp2.1/GetDocument.Insider.runtimeconfig.json" + ] + }, + "Microsoft.NETCore.Platforms/2.1.2": { + "sha512": "mOJy3M0UN+LUG21dLGMxaWZEP6xYpQEpLuvuEQBaownaX4YuhH6NmNUlN9si+vNkAS6dwJ//N1O4DmLf2CikVg==", + "type": "package", + "path": "microsoft.netcore.platforms/2.1.2", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "LICENSE.TXT", + "THIRD-PARTY-NOTICES.TXT", + "lib/netstandard1.0/_._", + "microsoft.netcore.platforms.2.1.2.nupkg.sha512", + "microsoft.netcore.platforms.nuspec", + "runtime.json", + "useSharedDesignerContext.txt", + "version.txt" + ] + }, + "Microsoft.NETCore.Targets/1.1.0": { + "sha512": "aOZA3BWfz9RXjpzt0sRJJMjAscAUm3Hoa4UWAfceV9UTYxgwZ1lZt5nO2myFf+/jetYQo4uTP7zS8sJY67BBxg==", + "type": "package", + "path": "microsoft.netcore.targets/1.1.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/netstandard1.0/_._", + "microsoft.netcore.targets.1.1.0.nupkg.sha512", + "microsoft.netcore.targets.nuspec", + "runtime.json" + ] + }, + "Microsoft.OpenApi/1.2.3": { + "sha512": "Nug3rO+7Kl5/SBAadzSMAVgqDlfGjJZ0GenQrLywJ84XGKO0uRqkunz5Wyl0SDwcR71bAATXvSdbdzPrYRYKGw==", + "type": "package", + "path": "microsoft.openapi/1.2.3", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "lib/net46/Microsoft.OpenApi.dll", + "lib/net46/Microsoft.OpenApi.pdb", + "lib/net46/Microsoft.OpenApi.xml", + "lib/netstandard2.0/Microsoft.OpenApi.dll", + "lib/netstandard2.0/Microsoft.OpenApi.pdb", + "lib/netstandard2.0/Microsoft.OpenApi.xml", + "microsoft.openapi.1.2.3.nupkg.sha512", + "microsoft.openapi.nuspec" + ] + }, + "Microsoft.Win32.Primitives/4.3.0": { + "sha512": "9ZQKCWxH7Ijp9BfahvL2Zyf1cJIk8XYLF6Yjzr2yi0b2cOut/HQ31qf1ThHAgCc3WiZMdnWcfJCgN82/0UunxA==", + "type": "package", + "path": "microsoft.win32.primitives/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/Microsoft.Win32.Primitives.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "microsoft.win32.primitives.4.3.0.nupkg.sha512", + "microsoft.win32.primitives.nuspec", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/Microsoft.Win32.Primitives.dll", + "ref/netstandard1.3/Microsoft.Win32.Primitives.dll", + "ref/netstandard1.3/Microsoft.Win32.Primitives.xml", + "ref/netstandard1.3/de/Microsoft.Win32.Primitives.xml", + "ref/netstandard1.3/es/Microsoft.Win32.Primitives.xml", + "ref/netstandard1.3/fr/Microsoft.Win32.Primitives.xml", + "ref/netstandard1.3/it/Microsoft.Win32.Primitives.xml", + "ref/netstandard1.3/ja/Microsoft.Win32.Primitives.xml", + "ref/netstandard1.3/ko/Microsoft.Win32.Primitives.xml", + "ref/netstandard1.3/ru/Microsoft.Win32.Primitives.xml", + "ref/netstandard1.3/zh-hans/Microsoft.Win32.Primitives.xml", + "ref/netstandard1.3/zh-hant/Microsoft.Win32.Primitives.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._" + ] + }, + "MongoDB.Bson/2.13.2": { + "sha512": "qY9271GFCYLA8OB3MdQC8clJh9wnh65gcxUa5Skwh2xYryv21YAHx/VOvv4ILpkb1NhIVgy3LBQhVBldwLaqNg==", + "type": "package", + "path": "mongodb.bson/2.13.2", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "License.txt", + "lib/net452/MongoDB.Bson.dll", + "lib/net452/MongoDB.Bson.xml", + "lib/netstandard1.5/MongoDB.Bson.dll", + "lib/netstandard1.5/MongoDB.Bson.xml", + "lib/netstandard2.0/MongoDB.Bson.dll", + "lib/netstandard2.0/MongoDB.Bson.xml", + "lib/netstandard2.1/MongoDB.Bson.dll", + "lib/netstandard2.1/MongoDB.Bson.xml", + "mongodb.bson.2.13.2.nupkg.sha512", + "mongodb.bson.nuspec", + "packageIcon.png" + ] + }, + "MongoDB.Driver/2.13.2": { + "sha512": "4+fczDJxxx7HPWY1n75hzHCOZiAhpb1Tjpkvj+c3lAeBGmSCvh5THcadxZ7b97F6OdHxz4xy07mIiwfZlPuQVQ==", + "type": "package", + "path": "mongodb.driver/2.13.2", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "License.txt", + "lib/net452/MongoDB.Driver.dll", + "lib/net452/MongoDB.Driver.xml", + "lib/netstandard1.5/MongoDB.Driver.dll", + "lib/netstandard1.5/MongoDB.Driver.xml", + "lib/netstandard2.0/MongoDB.Driver.dll", + "lib/netstandard2.0/MongoDB.Driver.xml", + "lib/netstandard2.1/MongoDB.Driver.dll", + "lib/netstandard2.1/MongoDB.Driver.xml", + "mongodb.driver.2.13.2.nupkg.sha512", + "mongodb.driver.nuspec", + "packageIcon.png" + ] + }, + "MongoDB.Driver.Core/2.13.2": { + "sha512": "VY1ayl9yXcZZ0VoXftZD3quHBgdn2EEMmuKlz4V6z2+8grN2svdASwX9E4p0DmOAAX8Wd5B5lYsUifrbo4M5xA==", + "type": "package", + "path": "mongodb.driver.core/2.13.2", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "License.txt", + "THIRD-PARTY-NOTICES", + "build/MongoDB.Driver.Core.targets", + "content/Core/Compression/Snappy/lib/win/snappy32.dll", + "content/Core/Compression/Snappy/lib/win/snappy64.dll", + "content/Core/Compression/Zstandard/lib/win/libzstd.dll", + "contentFiles/any/net452/Core/Compression/Snappy/lib/win/snappy32.dll", + "contentFiles/any/net452/Core/Compression/Snappy/lib/win/snappy64.dll", + "contentFiles/any/net452/Core/Compression/Zstandard/lib/win/libzstd.dll", + "contentFiles/any/netstandard1.5/Core/Compression/Snappy/lib/win/snappy32.dll", + "contentFiles/any/netstandard1.5/Core/Compression/Snappy/lib/win/snappy64.dll", + "contentFiles/any/netstandard1.5/Core/Compression/Zstandard/lib/win/libzstd.dll", + "contentFiles/any/netstandard2.0/Core/Compression/Snappy/lib/win/snappy32.dll", + "contentFiles/any/netstandard2.0/Core/Compression/Snappy/lib/win/snappy64.dll", + "contentFiles/any/netstandard2.0/Core/Compression/Zstandard/lib/win/libzstd.dll", + "contentFiles/any/netstandard2.1/Core/Compression/Snappy/lib/win/snappy32.dll", + "contentFiles/any/netstandard2.1/Core/Compression/Snappy/lib/win/snappy64.dll", + "contentFiles/any/netstandard2.1/Core/Compression/Zstandard/lib/win/libzstd.dll", + "lib/net452/MongoDB.Driver.Core.dll", + "lib/net452/MongoDB.Driver.Core.xml", + "lib/netstandard1.5/MongoDB.Driver.Core.dll", + "lib/netstandard1.5/MongoDB.Driver.Core.xml", + "lib/netstandard2.0/MongoDB.Driver.Core.dll", + "lib/netstandard2.0/MongoDB.Driver.Core.xml", + "lib/netstandard2.1/MongoDB.Driver.Core.dll", + "lib/netstandard2.1/MongoDB.Driver.Core.xml", + "mongodb.driver.core.2.13.2.nupkg.sha512", + "mongodb.driver.core.nuspec", + "packageIcon.png", + "runtimes/win/native/libzstd.dll", + "runtimes/win/native/snappy32.dll", + "runtimes/win/native/snappy64.dll" + ] + }, + "MongoDB.Libmongocrypt/1.2.2": { + "sha512": "pKrlKJk4wem4MyfkaMqj+sqJ+RwUDnqnt76/Xwm5DDjMzEU5QtDkzQOLq5bVwFhNgC8LMn6Hr22tl5WsmN5+AA==", + "type": "package", + "path": "mongodb.libmongocrypt/1.2.2", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "License.txt", + "build/MongoDB.Libmongocrypt.targets", + "content/libmongocrypt.dylib", + "content/libmongocrypt.so", + "content/mongocrypt.dll", + "contentFiles/any/net452/libmongocrypt.dylib", + "contentFiles/any/net452/libmongocrypt.so", + "contentFiles/any/net452/mongocrypt.dll", + "contentFiles/any/netstandard1.5/libmongocrypt.dylib", + "contentFiles/any/netstandard1.5/libmongocrypt.so", + "contentFiles/any/netstandard1.5/mongocrypt.dll", + "contentFiles/any/netstandard2.0/libmongocrypt.dylib", + "contentFiles/any/netstandard2.0/libmongocrypt.so", + "contentFiles/any/netstandard2.0/mongocrypt.dll", + "contentFiles/any/netstandard2.1/libmongocrypt.dylib", + "contentFiles/any/netstandard2.1/libmongocrypt.so", + "contentFiles/any/netstandard2.1/mongocrypt.dll", + "lib/net452/MongoDB.Libmongocrypt.dll", + "lib/netstandard1.5/MongoDB.Libmongocrypt.dll", + "lib/netstandard2.0/MongoDB.Libmongocrypt.dll", + "lib/netstandard2.1/MongoDB.Libmongocrypt.dll", + "mongodb.libmongocrypt.1.2.2.nupkg.sha512", + "mongodb.libmongocrypt.nuspec", + "runtimes/linux/native/libmongocrypt.so", + "runtimes/osx/native/libmongocrypt.dylib", + "runtimes/win/native/mongocrypt.dll" + ] + }, + "NETStandard.Library/1.6.1": { + "sha512": "WcSp3+vP+yHNgS8EV5J7pZ9IRpeDuARBPN28by8zqff1wJQXm26PVU8L3/fYLBJVU7BtDyqNVWq2KlCVvSSR4A==", + "type": "package", + "path": "netstandard.library/1.6.1", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "netstandard.library.1.6.1.nupkg.sha512", + "netstandard.library.nuspec" + ] + }, + "Newtonsoft.Json/10.0.1": { + "sha512": "ebWzW9j2nwxQeBo59As2TYn7nYr9BHicqqCwHOD1Vdo+50HBtLPuqdiCYJcLdTRknpYis/DSEOQz5KmZxwrIAg==", + "type": "package", + "path": "newtonsoft.json/10.0.1", + "hasTools": true, + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "lib/net20/Newtonsoft.Json.dll", + "lib/net20/Newtonsoft.Json.xml", + "lib/net35/Newtonsoft.Json.dll", + "lib/net35/Newtonsoft.Json.xml", + "lib/net40/Newtonsoft.Json.dll", + "lib/net40/Newtonsoft.Json.xml", + "lib/net45/Newtonsoft.Json.dll", + "lib/net45/Newtonsoft.Json.xml", + "lib/netstandard1.0/Newtonsoft.Json.dll", + "lib/netstandard1.0/Newtonsoft.Json.xml", + "lib/netstandard1.3/Newtonsoft.Json.dll", + "lib/netstandard1.3/Newtonsoft.Json.xml", + "lib/portable-net45+win8+wpa81+wp8/Newtonsoft.Json.dll", + "lib/portable-net45+win8+wpa81+wp8/Newtonsoft.Json.xml", + "newtonsoft.json.10.0.1.nupkg.sha512", + "newtonsoft.json.nuspec", + "tools/install.ps1" + ] + }, + "Newtonsoft.Json.Bson/1.0.1": { + "sha512": "5PYT/IqQ+UK31AmZiSS102R6EsTo+LGTSI8bp7WAUqDKaF4wHXD8U9u4WxTI1vc64tYi++8p3dk3WWNqPFgldw==", + "type": "package", + "path": "newtonsoft.json.bson/1.0.1", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "lib/net45/Newtonsoft.Json.Bson.dll", + "lib/net45/Newtonsoft.Json.Bson.xml", + "lib/netstandard1.3/Newtonsoft.Json.Bson.dll", + "lib/netstandard1.3/Newtonsoft.Json.Bson.xml", + "newtonsoft.json.bson.1.0.1.nupkg.sha512", + "newtonsoft.json.bson.nuspec" + ] + }, + "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "sha512": "HdSSp5MnJSsg08KMfZThpuLPJpPwE5hBXvHwoKWosyHHfe8Mh5WKT0ylEOf6yNzX6Ngjxe4Whkafh5q7Ymac4Q==", + "type": "package", + "path": "runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl.nuspec", + "runtimes/debian.8-x64/native/System.Security.Cryptography.Native.OpenSsl.so" + ] + }, + "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "sha512": "+yH1a49wJMy8Zt4yx5RhJrxO/DBDByAiCzNwiETI+1S4mPdCu0OY4djdciC7Vssk0l22wQaDLrXxXkp+3+7bVA==", + "type": "package", + "path": "runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl.nuspec", + "runtimes/fedora.23-x64/native/System.Security.Cryptography.Native.OpenSsl.so" + ] + }, + "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "sha512": "c3YNH1GQJbfIPJeCnr4avseugSqPrxwIqzthYyZDN6EuOyNOzq+y2KSUfRcXauya1sF4foESTgwM5e1A8arAKw==", + "type": "package", + "path": "runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl.nuspec", + "runtimes/fedora.24-x64/native/System.Security.Cryptography.Native.OpenSsl.so" + ] + }, + "runtime.native.System/4.3.0": { + "sha512": "c/qWt2LieNZIj1jGnVNsE2Kl23Ya2aSTBuXMD6V7k9KWr6l16Tqdwq+hJScEpWER9753NWC8h96PaVNY5Ld7Jw==", + "type": "package", + "path": "runtime.native.system/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/netstandard1.0/_._", + "runtime.native.system.4.3.0.nupkg.sha512", + "runtime.native.system.nuspec" + ] + }, + "runtime.native.System.IO.Compression/4.3.0": { + "sha512": "INBPonS5QPEgn7naufQFXJEp3zX6L4bwHgJ/ZH78aBTpeNfQMtf7C6VrAFhlq2xxWBveIOWyFzQjJ8XzHMhdOQ==", + "type": "package", + "path": "runtime.native.system.io.compression/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/netstandard1.0/_._", + "runtime.native.system.io.compression.4.3.0.nupkg.sha512", + "runtime.native.system.io.compression.nuspec" + ] + }, + "runtime.native.System.Net.Http/4.3.0": { + "sha512": "ZVuZJqnnegJhd2k/PtAbbIcZ3aZeITq3sj06oKfMBSfphW3HDmk/t4ObvbOk/JA/swGR0LNqMksAh/f7gpTROg==", + "type": "package", + "path": "runtime.native.system.net.http/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/netstandard1.0/_._", + "runtime.native.system.net.http.4.3.0.nupkg.sha512", + "runtime.native.system.net.http.nuspec" + ] + }, + "runtime.native.System.Security.Cryptography.Apple/4.3.0": { + "sha512": "DloMk88juo0OuOWr56QG7MNchmafTLYWvABy36izkrLI5VledI0rq28KGs1i9wbpeT9NPQrx/wTf8U2vazqQ3Q==", + "type": "package", + "path": "runtime.native.system.security.cryptography.apple/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/netstandard1.0/_._", + "runtime.native.system.security.cryptography.apple.4.3.0.nupkg.sha512", + "runtime.native.system.security.cryptography.apple.nuspec" + ] + }, + "runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "sha512": "NS1U+700m4KFRHR5o4vo9DSlTmlCKu/u7dtE5sUHVIPB+xpXxYQvgBgA6wEIeCz6Yfn0Z52/72WYsToCEPJnrw==", + "type": "package", + "path": "runtime.native.system.security.cryptography.openssl/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/netstandard1.0/_._", + "runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "runtime.native.system.security.cryptography.openssl.nuspec" + ] + }, + "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "sha512": "b3pthNgxxFcD+Pc0WSEoC0+md3MyhRS6aCEeenvNE3Fdw1HyJ18ZhRFVJJzIeR/O/jpxPboB805Ho0T3Ul7w8A==", + "type": "package", + "path": "runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl.nuspec", + "runtimes/opensuse.13.2-x64/native/System.Security.Cryptography.Native.OpenSsl.so" + ] + }, + "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "sha512": "KeLz4HClKf+nFS7p/6Fi/CqyLXh81FpiGzcmuS8DGi9lUqSnZ6Es23/gv2O+1XVGfrbNmviF7CckBpavkBoIFQ==", + "type": "package", + "path": "runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl.nuspec", + "runtimes/opensuse.42.1-x64/native/System.Security.Cryptography.Native.OpenSsl.so" + ] + }, + "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple/4.3.0": { + "sha512": "kVXCuMTrTlxq4XOOMAysuNwsXWpYeboGddNGpIgNSZmv1b6r/s/DPk0fYMB7Q5Qo4bY68o48jt4T4y5BVecbCQ==", + "type": "package", + "path": "runtime.osx.10.10-x64.runtime.native.system.security.cryptography.apple/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "runtime.osx.10.10-x64.runtime.native.system.security.cryptography.apple.4.3.0.nupkg.sha512", + "runtime.osx.10.10-x64.runtime.native.system.security.cryptography.apple.nuspec", + "runtimes/osx.10.10-x64/native/System.Security.Cryptography.Native.Apple.dylib" + ] + }, + "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "sha512": "X7IdhILzr4ROXd8mI1BUCQMSHSQwelUlBjF1JyTKCjXaOGn2fB4EKBxQbCK2VjO3WaWIdlXZL3W6TiIVnrhX4g==", + "type": "package", + "path": "runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl.nuspec", + "runtimes/osx.10.10-x64/native/System.Security.Cryptography.Native.OpenSsl.dylib" + ] + }, + "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "sha512": "nyFNiCk/r+VOiIqreLix8yN+q3Wga9+SE8BCgkf+2BwEKiNx6DyvFjCgkfV743/grxv8jHJ8gUK4XEQw7yzRYg==", + "type": "package", + "path": "runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl.nuspec", + "runtimes/rhel.7-x64/native/System.Security.Cryptography.Native.OpenSsl.so" + ] + }, + "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "sha512": "ytoewC6wGorL7KoCAvRfsgoJPJbNq+64k2SqW6JcOAebWsFUvCCYgfzQMrnpvPiEl4OrblUlhF2ji+Q1+SVLrQ==", + "type": "package", + "path": "runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl.nuspec", + "runtimes/ubuntu.14.04-x64/native/System.Security.Cryptography.Native.OpenSsl.so" + ] + }, + "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "sha512": "I8bKw2I8k58Wx7fMKQJn2R8lamboCAiHfHeV/pS65ScKWMMI0+wJkLYlEKvgW1D/XvSl/221clBoR2q9QNNM7A==", + "type": "package", + "path": "runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl.nuspec", + "runtimes/ubuntu.16.04-x64/native/System.Security.Cryptography.Native.OpenSsl.so" + ] + }, + "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl/4.3.0": { + "sha512": "VB5cn/7OzUfzdnC8tqAIMQciVLiq2epm2NrAm1E9OjNRyG4lVhfR61SMcLizejzQP8R8Uf/0l5qOIbUEi+RdEg==", + "type": "package", + "path": "runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl.nuspec", + "runtimes/ubuntu.16.10-x64/native/System.Security.Cryptography.Native.OpenSsl.so" + ] + }, + "SharpCompress/0.23.0": { + "sha512": "HBbT47JHvNrsZX2dTBzUBOSzBt+EmIRGLIBkbxcP6Jef7DB4eFWQX5iHWV3Nj7hABFPCjISrZ8s0z72nF2zFHQ==", + "type": "package", + "path": "sharpcompress/0.23.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "lib/net35/SharpCompress.dll", + "lib/net45/SharpCompress.dll", + "lib/netstandard1.0/SharpCompress.dll", + "lib/netstandard1.3/SharpCompress.dll", + "lib/netstandard2.0/SharpCompress.dll", + "sharpcompress.0.23.0.nupkg.sha512", + "sharpcompress.nuspec" + ] + }, + "Swashbuckle.AspNetCore/5.6.3": { + "sha512": "UkL9GU0mfaA+7RwYjEaBFvAzL8qNQhNqAeV5uaWUu/Z+fVgvK9FHkGCpTXBqSQeIHuZaIElzxnLDdIqGzuCnVg==", + "type": "package", + "path": "swashbuckle.aspnetcore/5.6.3", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "build/Swashbuckle.AspNetCore.props", + "swashbuckle.aspnetcore.5.6.3.nupkg.sha512", + "swashbuckle.aspnetcore.nuspec" + ] + }, + "Swashbuckle.AspNetCore.Swagger/5.6.3": { + "sha512": "rn/MmLscjg6WSnTZabojx5DQYle2GjPanSPbCU3Kw8Hy72KyQR3uy8R1Aew5vpNALjfUFm2M/vwUtqdOlzw+GA==", + "type": "package", + "path": "swashbuckle.aspnetcore.swagger/5.6.3", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "lib/netcoreapp3.0/Swashbuckle.AspNetCore.Swagger.dll", + "lib/netcoreapp3.0/Swashbuckle.AspNetCore.Swagger.pdb", + "lib/netcoreapp3.0/Swashbuckle.AspNetCore.Swagger.xml", + "lib/netstandard2.0/Swashbuckle.AspNetCore.Swagger.dll", + "lib/netstandard2.0/Swashbuckle.AspNetCore.Swagger.pdb", + "lib/netstandard2.0/Swashbuckle.AspNetCore.Swagger.xml", + "swashbuckle.aspnetcore.swagger.5.6.3.nupkg.sha512", + "swashbuckle.aspnetcore.swagger.nuspec" + ] + }, + "Swashbuckle.AspNetCore.SwaggerGen/5.6.3": { + "sha512": "CkhVeod/iLd3ikVTDOwG5sym8BE5xbqGJ15iF3cC7ZPg2kEwDQL4a88xjkzsvC9oOB2ax6B0rK0EgRK+eOBX+w==", + "type": "package", + "path": "swashbuckle.aspnetcore.swaggergen/5.6.3", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "lib/netcoreapp3.0/Swashbuckle.AspNetCore.SwaggerGen.dll", + "lib/netcoreapp3.0/Swashbuckle.AspNetCore.SwaggerGen.pdb", + "lib/netcoreapp3.0/Swashbuckle.AspNetCore.SwaggerGen.xml", + "lib/netstandard2.0/Swashbuckle.AspNetCore.SwaggerGen.dll", + "lib/netstandard2.0/Swashbuckle.AspNetCore.SwaggerGen.pdb", + "lib/netstandard2.0/Swashbuckle.AspNetCore.SwaggerGen.xml", + "swashbuckle.aspnetcore.swaggergen.5.6.3.nupkg.sha512", + "swashbuckle.aspnetcore.swaggergen.nuspec" + ] + }, + "Swashbuckle.AspNetCore.SwaggerUI/5.6.3": { + "sha512": "BPvcPxQRMsYZ3HnYmGKRWDwX4Wo29WHh14Q6B10BB8Yfbbcza+agOC2UrBFA1EuaZuOsFLbp6E2+mqVNF/Je8A==", + "type": "package", + "path": "swashbuckle.aspnetcore.swaggerui/5.6.3", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "lib/netcoreapp3.0/Swashbuckle.AspNetCore.SwaggerUI.dll", + "lib/netcoreapp3.0/Swashbuckle.AspNetCore.SwaggerUI.pdb", + "lib/netcoreapp3.0/Swashbuckle.AspNetCore.SwaggerUI.xml", + "lib/netstandard2.0/Swashbuckle.AspNetCore.SwaggerUI.dll", + "lib/netstandard2.0/Swashbuckle.AspNetCore.SwaggerUI.pdb", + "lib/netstandard2.0/Swashbuckle.AspNetCore.SwaggerUI.xml", + "swashbuckle.aspnetcore.swaggerui.5.6.3.nupkg.sha512", + "swashbuckle.aspnetcore.swaggerui.nuspec" + ] + }, + "System.AppContext/4.3.0": { + "sha512": "fKC+rmaLfeIzUhagxY17Q9siv/sPrjjKcfNg1Ic8IlQkZLipo8ljcaZQu4VtI4Jqbzjc2VTjzGLF6WmsRXAEgA==", + "type": "package", + "path": "system.appcontext/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.AppContext.dll", + "lib/net463/System.AppContext.dll", + "lib/netcore50/System.AppContext.dll", + "lib/netstandard1.6/System.AppContext.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.AppContext.dll", + "ref/net463/System.AppContext.dll", + "ref/netstandard/_._", + "ref/netstandard1.3/System.AppContext.dll", + "ref/netstandard1.3/System.AppContext.xml", + "ref/netstandard1.3/de/System.AppContext.xml", + "ref/netstandard1.3/es/System.AppContext.xml", + "ref/netstandard1.3/fr/System.AppContext.xml", + "ref/netstandard1.3/it/System.AppContext.xml", + "ref/netstandard1.3/ja/System.AppContext.xml", + "ref/netstandard1.3/ko/System.AppContext.xml", + "ref/netstandard1.3/ru/System.AppContext.xml", + "ref/netstandard1.3/zh-hans/System.AppContext.xml", + "ref/netstandard1.3/zh-hant/System.AppContext.xml", + "ref/netstandard1.6/System.AppContext.dll", + "ref/netstandard1.6/System.AppContext.xml", + "ref/netstandard1.6/de/System.AppContext.xml", + "ref/netstandard1.6/es/System.AppContext.xml", + "ref/netstandard1.6/fr/System.AppContext.xml", + "ref/netstandard1.6/it/System.AppContext.xml", + "ref/netstandard1.6/ja/System.AppContext.xml", + "ref/netstandard1.6/ko/System.AppContext.xml", + "ref/netstandard1.6/ru/System.AppContext.xml", + "ref/netstandard1.6/zh-hans/System.AppContext.xml", + "ref/netstandard1.6/zh-hant/System.AppContext.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/aot/lib/netcore50/System.AppContext.dll", + "system.appcontext.4.3.0.nupkg.sha512", + "system.appcontext.nuspec" + ] + }, + "System.Buffers/4.5.1": { + "sha512": "Rw7ijyl1qqRS0YQD/WycNst8hUUMgrMH4FCn1nNm27M4VxchZ1js3fVjQaANHO5f3sN4isvP4a+Met9Y4YomAg==", + "type": "package", + "path": "system.buffers/4.5.1", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "LICENSE.TXT", + "THIRD-PARTY-NOTICES.TXT", + "lib/net461/System.Buffers.dll", + "lib/net461/System.Buffers.xml", + "lib/netcoreapp2.0/_._", + "lib/netstandard1.1/System.Buffers.dll", + "lib/netstandard1.1/System.Buffers.xml", + "lib/netstandard2.0/System.Buffers.dll", + "lib/netstandard2.0/System.Buffers.xml", + "lib/uap10.0.16299/_._", + "ref/net45/System.Buffers.dll", + "ref/net45/System.Buffers.xml", + "ref/netcoreapp2.0/_._", + "ref/netstandard1.1/System.Buffers.dll", + "ref/netstandard1.1/System.Buffers.xml", + "ref/netstandard2.0/System.Buffers.dll", + "ref/netstandard2.0/System.Buffers.xml", + "ref/uap10.0.16299/_._", + "system.buffers.4.5.1.nupkg.sha512", + "system.buffers.nuspec", + "useSharedDesignerContext.txt", + "version.txt" + ] + }, + "System.Collections/4.3.0": { + "sha512": "3Dcj85/TBdVpL5Zr+gEEBUuFe2icOnLalmEh9hfck1PTYbbyWuZgh4fmm2ysCLTrqLQw6t3TgTyJ+VLp+Qb+Lw==", + "type": "package", + "path": "system.collections/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Collections.dll", + "ref/netcore50/System.Collections.xml", + "ref/netcore50/de/System.Collections.xml", + "ref/netcore50/es/System.Collections.xml", + "ref/netcore50/fr/System.Collections.xml", + "ref/netcore50/it/System.Collections.xml", + "ref/netcore50/ja/System.Collections.xml", + "ref/netcore50/ko/System.Collections.xml", + "ref/netcore50/ru/System.Collections.xml", + "ref/netcore50/zh-hans/System.Collections.xml", + "ref/netcore50/zh-hant/System.Collections.xml", + "ref/netstandard1.0/System.Collections.dll", + "ref/netstandard1.0/System.Collections.xml", + "ref/netstandard1.0/de/System.Collections.xml", + "ref/netstandard1.0/es/System.Collections.xml", + "ref/netstandard1.0/fr/System.Collections.xml", + "ref/netstandard1.0/it/System.Collections.xml", + "ref/netstandard1.0/ja/System.Collections.xml", + "ref/netstandard1.0/ko/System.Collections.xml", + "ref/netstandard1.0/ru/System.Collections.xml", + "ref/netstandard1.0/zh-hans/System.Collections.xml", + "ref/netstandard1.0/zh-hant/System.Collections.xml", + "ref/netstandard1.3/System.Collections.dll", + "ref/netstandard1.3/System.Collections.xml", + "ref/netstandard1.3/de/System.Collections.xml", + "ref/netstandard1.3/es/System.Collections.xml", + "ref/netstandard1.3/fr/System.Collections.xml", + "ref/netstandard1.3/it/System.Collections.xml", + "ref/netstandard1.3/ja/System.Collections.xml", + "ref/netstandard1.3/ko/System.Collections.xml", + "ref/netstandard1.3/ru/System.Collections.xml", + "ref/netstandard1.3/zh-hans/System.Collections.xml", + "ref/netstandard1.3/zh-hant/System.Collections.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.collections.4.3.0.nupkg.sha512", + "system.collections.nuspec" + ] + }, + "System.Collections.Concurrent/4.3.0": { + "sha512": "ztl69Xp0Y/UXCL+3v3tEU+lIy+bvjKNUmopn1wep/a291pVPK7dxBd6T7WnlQqRog+d1a/hSsgRsmFnIBKTPLQ==", + "type": "package", + "path": "system.collections.concurrent/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/netcore50/System.Collections.Concurrent.dll", + "lib/netstandard1.3/System.Collections.Concurrent.dll", + "lib/portable-net45+win8+wpa81/_._", + "lib/win8/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Collections.Concurrent.dll", + "ref/netcore50/System.Collections.Concurrent.xml", + "ref/netcore50/de/System.Collections.Concurrent.xml", + "ref/netcore50/es/System.Collections.Concurrent.xml", + "ref/netcore50/fr/System.Collections.Concurrent.xml", + "ref/netcore50/it/System.Collections.Concurrent.xml", + "ref/netcore50/ja/System.Collections.Concurrent.xml", + "ref/netcore50/ko/System.Collections.Concurrent.xml", + "ref/netcore50/ru/System.Collections.Concurrent.xml", + "ref/netcore50/zh-hans/System.Collections.Concurrent.xml", + "ref/netcore50/zh-hant/System.Collections.Concurrent.xml", + "ref/netstandard1.1/System.Collections.Concurrent.dll", + "ref/netstandard1.1/System.Collections.Concurrent.xml", + "ref/netstandard1.1/de/System.Collections.Concurrent.xml", + "ref/netstandard1.1/es/System.Collections.Concurrent.xml", + "ref/netstandard1.1/fr/System.Collections.Concurrent.xml", + "ref/netstandard1.1/it/System.Collections.Concurrent.xml", + "ref/netstandard1.1/ja/System.Collections.Concurrent.xml", + "ref/netstandard1.1/ko/System.Collections.Concurrent.xml", + "ref/netstandard1.1/ru/System.Collections.Concurrent.xml", + "ref/netstandard1.1/zh-hans/System.Collections.Concurrent.xml", + "ref/netstandard1.1/zh-hant/System.Collections.Concurrent.xml", + "ref/netstandard1.3/System.Collections.Concurrent.dll", + "ref/netstandard1.3/System.Collections.Concurrent.xml", + "ref/netstandard1.3/de/System.Collections.Concurrent.xml", + "ref/netstandard1.3/es/System.Collections.Concurrent.xml", + "ref/netstandard1.3/fr/System.Collections.Concurrent.xml", + "ref/netstandard1.3/it/System.Collections.Concurrent.xml", + "ref/netstandard1.3/ja/System.Collections.Concurrent.xml", + "ref/netstandard1.3/ko/System.Collections.Concurrent.xml", + "ref/netstandard1.3/ru/System.Collections.Concurrent.xml", + "ref/netstandard1.3/zh-hans/System.Collections.Concurrent.xml", + "ref/netstandard1.3/zh-hant/System.Collections.Concurrent.xml", + "ref/portable-net45+win8+wpa81/_._", + "ref/win8/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.collections.concurrent.4.3.0.nupkg.sha512", + "system.collections.concurrent.nuspec" + ] + }, + "System.Collections.NonGeneric/4.3.0": { + "sha512": "prtjIEMhGUnQq6RnPEYLpFt8AtLbp9yq2zxOSrY7KJJZrw25Fi97IzBqY7iqssbM61Ek5b8f3MG/sG1N2sN5KA==", + "type": "package", + "path": "system.collections.nongeneric/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.Collections.NonGeneric.dll", + "lib/netstandard1.3/System.Collections.NonGeneric.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.Collections.NonGeneric.dll", + "ref/netstandard1.3/System.Collections.NonGeneric.dll", + "ref/netstandard1.3/System.Collections.NonGeneric.xml", + "ref/netstandard1.3/de/System.Collections.NonGeneric.xml", + "ref/netstandard1.3/es/System.Collections.NonGeneric.xml", + "ref/netstandard1.3/fr/System.Collections.NonGeneric.xml", + "ref/netstandard1.3/it/System.Collections.NonGeneric.xml", + "ref/netstandard1.3/ja/System.Collections.NonGeneric.xml", + "ref/netstandard1.3/ko/System.Collections.NonGeneric.xml", + "ref/netstandard1.3/ru/System.Collections.NonGeneric.xml", + "ref/netstandard1.3/zh-hans/System.Collections.NonGeneric.xml", + "ref/netstandard1.3/zh-hant/System.Collections.NonGeneric.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.collections.nongeneric.4.3.0.nupkg.sha512", + "system.collections.nongeneric.nuspec" + ] + }, + "System.Collections.Specialized/4.3.0": { + "sha512": "Epx8PoVZR0iuOnJJDzp7pWvdfMMOAvpUo95pC4ScH2mJuXkKA2Y4aR3cG9qt2klHgSons1WFh4kcGW7cSXvrxg==", + "type": "package", + "path": "system.collections.specialized/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.Collections.Specialized.dll", + "lib/netstandard1.3/System.Collections.Specialized.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.Collections.Specialized.dll", + "ref/netstandard1.3/System.Collections.Specialized.dll", + "ref/netstandard1.3/System.Collections.Specialized.xml", + "ref/netstandard1.3/de/System.Collections.Specialized.xml", + "ref/netstandard1.3/es/System.Collections.Specialized.xml", + "ref/netstandard1.3/fr/System.Collections.Specialized.xml", + "ref/netstandard1.3/it/System.Collections.Specialized.xml", + "ref/netstandard1.3/ja/System.Collections.Specialized.xml", + "ref/netstandard1.3/ko/System.Collections.Specialized.xml", + "ref/netstandard1.3/ru/System.Collections.Specialized.xml", + "ref/netstandard1.3/zh-hans/System.Collections.Specialized.xml", + "ref/netstandard1.3/zh-hant/System.Collections.Specialized.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.collections.specialized.4.3.0.nupkg.sha512", + "system.collections.specialized.nuspec" + ] + }, + "System.ComponentModel/4.3.0": { + "sha512": "VyGn1jGRZVfxnh8EdvDCi71v3bMXrsu8aYJOwoV7SNDLVhiEqwP86pPMyRGsDsxhXAm2b3o9OIqeETfN5qfezw==", + "type": "package", + "path": "system.componentmodel/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/netcore50/System.ComponentModel.dll", + "lib/netstandard1.3/System.ComponentModel.dll", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.ComponentModel.dll", + "ref/netcore50/System.ComponentModel.xml", + "ref/netcore50/de/System.ComponentModel.xml", + "ref/netcore50/es/System.ComponentModel.xml", + "ref/netcore50/fr/System.ComponentModel.xml", + "ref/netcore50/it/System.ComponentModel.xml", + "ref/netcore50/ja/System.ComponentModel.xml", + "ref/netcore50/ko/System.ComponentModel.xml", + "ref/netcore50/ru/System.ComponentModel.xml", + "ref/netcore50/zh-hans/System.ComponentModel.xml", + "ref/netcore50/zh-hant/System.ComponentModel.xml", + "ref/netstandard1.0/System.ComponentModel.dll", + "ref/netstandard1.0/System.ComponentModel.xml", + "ref/netstandard1.0/de/System.ComponentModel.xml", + "ref/netstandard1.0/es/System.ComponentModel.xml", + "ref/netstandard1.0/fr/System.ComponentModel.xml", + "ref/netstandard1.0/it/System.ComponentModel.xml", + "ref/netstandard1.0/ja/System.ComponentModel.xml", + "ref/netstandard1.0/ko/System.ComponentModel.xml", + "ref/netstandard1.0/ru/System.ComponentModel.xml", + "ref/netstandard1.0/zh-hans/System.ComponentModel.xml", + "ref/netstandard1.0/zh-hant/System.ComponentModel.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.componentmodel.4.3.0.nupkg.sha512", + "system.componentmodel.nuspec" + ] + }, + "System.ComponentModel.Primitives/4.3.0": { + "sha512": "j8GUkCpM8V4d4vhLIIoBLGey2Z5bCkMVNjEZseyAlm4n5arcsJOeI3zkUP+zvZgzsbLTYh4lYeP/ZD/gdIAPrw==", + "type": "package", + "path": "system.componentmodel.primitives/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/System.ComponentModel.Primitives.dll", + "lib/netstandard1.0/System.ComponentModel.Primitives.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/System.ComponentModel.Primitives.dll", + "ref/netstandard1.0/System.ComponentModel.Primitives.dll", + "ref/netstandard1.0/System.ComponentModel.Primitives.xml", + "ref/netstandard1.0/de/System.ComponentModel.Primitives.xml", + "ref/netstandard1.0/es/System.ComponentModel.Primitives.xml", + "ref/netstandard1.0/fr/System.ComponentModel.Primitives.xml", + "ref/netstandard1.0/it/System.ComponentModel.Primitives.xml", + "ref/netstandard1.0/ja/System.ComponentModel.Primitives.xml", + "ref/netstandard1.0/ko/System.ComponentModel.Primitives.xml", + "ref/netstandard1.0/ru/System.ComponentModel.Primitives.xml", + "ref/netstandard1.0/zh-hans/System.ComponentModel.Primitives.xml", + "ref/netstandard1.0/zh-hant/System.ComponentModel.Primitives.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.componentmodel.primitives.4.3.0.nupkg.sha512", + "system.componentmodel.primitives.nuspec" + ] + }, + "System.ComponentModel.TypeConverter/4.3.0": { + "sha512": "16pQ6P+EdhcXzPiEK4kbA953Fu0MNG2ovxTZU81/qsCd1zPRsKc3uif5NgvllCY598k6bI0KUyKW8fanlfaDQg==", + "type": "package", + "path": "system.componentmodel.typeconverter/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/System.ComponentModel.TypeConverter.dll", + "lib/net462/System.ComponentModel.TypeConverter.dll", + "lib/netstandard1.0/System.ComponentModel.TypeConverter.dll", + "lib/netstandard1.5/System.ComponentModel.TypeConverter.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/System.ComponentModel.TypeConverter.dll", + "ref/net462/System.ComponentModel.TypeConverter.dll", + "ref/netstandard1.0/System.ComponentModel.TypeConverter.dll", + "ref/netstandard1.0/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.0/de/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.0/es/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.0/fr/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.0/it/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.0/ja/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.0/ko/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.0/ru/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.0/zh-hans/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.0/zh-hant/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.5/System.ComponentModel.TypeConverter.dll", + "ref/netstandard1.5/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.5/de/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.5/es/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.5/fr/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.5/it/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.5/ja/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.5/ko/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.5/ru/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.5/zh-hans/System.ComponentModel.TypeConverter.xml", + "ref/netstandard1.5/zh-hant/System.ComponentModel.TypeConverter.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.componentmodel.typeconverter.4.3.0.nupkg.sha512", + "system.componentmodel.typeconverter.nuspec" + ] + }, + "System.Console/4.3.0": { + "sha512": "DHDrIxiqk1h03m6khKWV2X8p/uvN79rgSqpilL6uzpmSfxfU5ng8VcPtW4qsDsQDHiTv6IPV9TmD5M/vElPNLg==", + "type": "package", + "path": "system.console/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.Console.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.Console.dll", + "ref/netstandard1.3/System.Console.dll", + "ref/netstandard1.3/System.Console.xml", + "ref/netstandard1.3/de/System.Console.xml", + "ref/netstandard1.3/es/System.Console.xml", + "ref/netstandard1.3/fr/System.Console.xml", + "ref/netstandard1.3/it/System.Console.xml", + "ref/netstandard1.3/ja/System.Console.xml", + "ref/netstandard1.3/ko/System.Console.xml", + "ref/netstandard1.3/ru/System.Console.xml", + "ref/netstandard1.3/zh-hans/System.Console.xml", + "ref/netstandard1.3/zh-hant/System.Console.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.console.4.3.0.nupkg.sha512", + "system.console.nuspec" + ] + }, + "System.Diagnostics.Debug/4.3.0": { + "sha512": "ZUhUOdqmaG5Jk3Xdb8xi5kIyQYAA4PnTNlHx1mu9ZY3qv4ELIdKbnL/akbGaKi2RnNUWaZsAs31rvzFdewTj2g==", + "type": "package", + "path": "system.diagnostics.debug/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Diagnostics.Debug.dll", + "ref/netcore50/System.Diagnostics.Debug.xml", + "ref/netcore50/de/System.Diagnostics.Debug.xml", + "ref/netcore50/es/System.Diagnostics.Debug.xml", + "ref/netcore50/fr/System.Diagnostics.Debug.xml", + "ref/netcore50/it/System.Diagnostics.Debug.xml", + "ref/netcore50/ja/System.Diagnostics.Debug.xml", + "ref/netcore50/ko/System.Diagnostics.Debug.xml", + "ref/netcore50/ru/System.Diagnostics.Debug.xml", + "ref/netcore50/zh-hans/System.Diagnostics.Debug.xml", + "ref/netcore50/zh-hant/System.Diagnostics.Debug.xml", + "ref/netstandard1.0/System.Diagnostics.Debug.dll", + "ref/netstandard1.0/System.Diagnostics.Debug.xml", + "ref/netstandard1.0/de/System.Diagnostics.Debug.xml", + "ref/netstandard1.0/es/System.Diagnostics.Debug.xml", + "ref/netstandard1.0/fr/System.Diagnostics.Debug.xml", + "ref/netstandard1.0/it/System.Diagnostics.Debug.xml", + "ref/netstandard1.0/ja/System.Diagnostics.Debug.xml", + "ref/netstandard1.0/ko/System.Diagnostics.Debug.xml", + "ref/netstandard1.0/ru/System.Diagnostics.Debug.xml", + "ref/netstandard1.0/zh-hans/System.Diagnostics.Debug.xml", + "ref/netstandard1.0/zh-hant/System.Diagnostics.Debug.xml", + "ref/netstandard1.3/System.Diagnostics.Debug.dll", + "ref/netstandard1.3/System.Diagnostics.Debug.xml", + "ref/netstandard1.3/de/System.Diagnostics.Debug.xml", + "ref/netstandard1.3/es/System.Diagnostics.Debug.xml", + "ref/netstandard1.3/fr/System.Diagnostics.Debug.xml", + "ref/netstandard1.3/it/System.Diagnostics.Debug.xml", + "ref/netstandard1.3/ja/System.Diagnostics.Debug.xml", + "ref/netstandard1.3/ko/System.Diagnostics.Debug.xml", + "ref/netstandard1.3/ru/System.Diagnostics.Debug.xml", + "ref/netstandard1.3/zh-hans/System.Diagnostics.Debug.xml", + "ref/netstandard1.3/zh-hant/System.Diagnostics.Debug.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.diagnostics.debug.4.3.0.nupkg.sha512", + "system.diagnostics.debug.nuspec" + ] + }, + "System.Diagnostics.DiagnosticSource/4.3.0": { + "sha512": "tD6kosZnTAGdrEa0tZSuFyunMbt/5KYDnHdndJYGqZoNy00XVXyACd5d6KnE1YgYv3ne2CjtAfNXo/fwEhnKUA==", + "type": "package", + "path": "system.diagnostics.diagnosticsource/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/net46/System.Diagnostics.DiagnosticSource.dll", + "lib/net46/System.Diagnostics.DiagnosticSource.xml", + "lib/netstandard1.1/System.Diagnostics.DiagnosticSource.dll", + "lib/netstandard1.1/System.Diagnostics.DiagnosticSource.xml", + "lib/netstandard1.3/System.Diagnostics.DiagnosticSource.dll", + "lib/netstandard1.3/System.Diagnostics.DiagnosticSource.xml", + "lib/portable-net45+win8+wpa81/System.Diagnostics.DiagnosticSource.dll", + "lib/portable-net45+win8+wpa81/System.Diagnostics.DiagnosticSource.xml", + "system.diagnostics.diagnosticsource.4.3.0.nupkg.sha512", + "system.diagnostics.diagnosticsource.nuspec" + ] + }, + "System.Diagnostics.Tools/4.3.0": { + "sha512": "UUvkJfSYJMM6x527dJg2VyWPSRqIVB0Z7dbjHst1zmwTXz5CcXSYJFWRpuigfbO1Lf7yfZiIaEUesfnl/g5EyA==", + "type": "package", + "path": "system.diagnostics.tools/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Diagnostics.Tools.dll", + "ref/netcore50/System.Diagnostics.Tools.xml", + "ref/netcore50/de/System.Diagnostics.Tools.xml", + "ref/netcore50/es/System.Diagnostics.Tools.xml", + "ref/netcore50/fr/System.Diagnostics.Tools.xml", + "ref/netcore50/it/System.Diagnostics.Tools.xml", + "ref/netcore50/ja/System.Diagnostics.Tools.xml", + "ref/netcore50/ko/System.Diagnostics.Tools.xml", + "ref/netcore50/ru/System.Diagnostics.Tools.xml", + "ref/netcore50/zh-hans/System.Diagnostics.Tools.xml", + "ref/netcore50/zh-hant/System.Diagnostics.Tools.xml", + "ref/netstandard1.0/System.Diagnostics.Tools.dll", + "ref/netstandard1.0/System.Diagnostics.Tools.xml", + "ref/netstandard1.0/de/System.Diagnostics.Tools.xml", + "ref/netstandard1.0/es/System.Diagnostics.Tools.xml", + "ref/netstandard1.0/fr/System.Diagnostics.Tools.xml", + "ref/netstandard1.0/it/System.Diagnostics.Tools.xml", + "ref/netstandard1.0/ja/System.Diagnostics.Tools.xml", + "ref/netstandard1.0/ko/System.Diagnostics.Tools.xml", + "ref/netstandard1.0/ru/System.Diagnostics.Tools.xml", + "ref/netstandard1.0/zh-hans/System.Diagnostics.Tools.xml", + "ref/netstandard1.0/zh-hant/System.Diagnostics.Tools.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.diagnostics.tools.4.3.0.nupkg.sha512", + "system.diagnostics.tools.nuspec" + ] + }, + "System.Diagnostics.Tracing/4.3.0": { + "sha512": "rswfv0f/Cqkh78rA5S8eN8Neocz234+emGCtTF3lxPY96F+mmmUen6tbn0glN6PMvlKQb9bPAY5e9u7fgPTkKw==", + "type": "package", + "path": "system.diagnostics.tracing/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/net462/System.Diagnostics.Tracing.dll", + "lib/portable-net45+win8+wpa81/_._", + "lib/win8/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/net462/System.Diagnostics.Tracing.dll", + "ref/netcore50/System.Diagnostics.Tracing.dll", + "ref/netcore50/System.Diagnostics.Tracing.xml", + "ref/netcore50/de/System.Diagnostics.Tracing.xml", + "ref/netcore50/es/System.Diagnostics.Tracing.xml", + "ref/netcore50/fr/System.Diagnostics.Tracing.xml", + "ref/netcore50/it/System.Diagnostics.Tracing.xml", + "ref/netcore50/ja/System.Diagnostics.Tracing.xml", + "ref/netcore50/ko/System.Diagnostics.Tracing.xml", + "ref/netcore50/ru/System.Diagnostics.Tracing.xml", + "ref/netcore50/zh-hans/System.Diagnostics.Tracing.xml", + "ref/netcore50/zh-hant/System.Diagnostics.Tracing.xml", + "ref/netstandard1.1/System.Diagnostics.Tracing.dll", + "ref/netstandard1.1/System.Diagnostics.Tracing.xml", + "ref/netstandard1.1/de/System.Diagnostics.Tracing.xml", + "ref/netstandard1.1/es/System.Diagnostics.Tracing.xml", + "ref/netstandard1.1/fr/System.Diagnostics.Tracing.xml", + "ref/netstandard1.1/it/System.Diagnostics.Tracing.xml", + "ref/netstandard1.1/ja/System.Diagnostics.Tracing.xml", + "ref/netstandard1.1/ko/System.Diagnostics.Tracing.xml", + "ref/netstandard1.1/ru/System.Diagnostics.Tracing.xml", + "ref/netstandard1.1/zh-hans/System.Diagnostics.Tracing.xml", + "ref/netstandard1.1/zh-hant/System.Diagnostics.Tracing.xml", + "ref/netstandard1.2/System.Diagnostics.Tracing.dll", + "ref/netstandard1.2/System.Diagnostics.Tracing.xml", + "ref/netstandard1.2/de/System.Diagnostics.Tracing.xml", + "ref/netstandard1.2/es/System.Diagnostics.Tracing.xml", + "ref/netstandard1.2/fr/System.Diagnostics.Tracing.xml", + "ref/netstandard1.2/it/System.Diagnostics.Tracing.xml", + "ref/netstandard1.2/ja/System.Diagnostics.Tracing.xml", + "ref/netstandard1.2/ko/System.Diagnostics.Tracing.xml", + "ref/netstandard1.2/ru/System.Diagnostics.Tracing.xml", + "ref/netstandard1.2/zh-hans/System.Diagnostics.Tracing.xml", + "ref/netstandard1.2/zh-hant/System.Diagnostics.Tracing.xml", + "ref/netstandard1.3/System.Diagnostics.Tracing.dll", + "ref/netstandard1.3/System.Diagnostics.Tracing.xml", + "ref/netstandard1.3/de/System.Diagnostics.Tracing.xml", + "ref/netstandard1.3/es/System.Diagnostics.Tracing.xml", + "ref/netstandard1.3/fr/System.Diagnostics.Tracing.xml", + "ref/netstandard1.3/it/System.Diagnostics.Tracing.xml", + "ref/netstandard1.3/ja/System.Diagnostics.Tracing.xml", + "ref/netstandard1.3/ko/System.Diagnostics.Tracing.xml", + "ref/netstandard1.3/ru/System.Diagnostics.Tracing.xml", + "ref/netstandard1.3/zh-hans/System.Diagnostics.Tracing.xml", + "ref/netstandard1.3/zh-hant/System.Diagnostics.Tracing.xml", + "ref/netstandard1.5/System.Diagnostics.Tracing.dll", + "ref/netstandard1.5/System.Diagnostics.Tracing.xml", + "ref/netstandard1.5/de/System.Diagnostics.Tracing.xml", + "ref/netstandard1.5/es/System.Diagnostics.Tracing.xml", + "ref/netstandard1.5/fr/System.Diagnostics.Tracing.xml", + "ref/netstandard1.5/it/System.Diagnostics.Tracing.xml", + "ref/netstandard1.5/ja/System.Diagnostics.Tracing.xml", + "ref/netstandard1.5/ko/System.Diagnostics.Tracing.xml", + "ref/netstandard1.5/ru/System.Diagnostics.Tracing.xml", + "ref/netstandard1.5/zh-hans/System.Diagnostics.Tracing.xml", + "ref/netstandard1.5/zh-hant/System.Diagnostics.Tracing.xml", + "ref/portable-net45+win8+wpa81/_._", + "ref/win8/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.diagnostics.tracing.4.3.0.nupkg.sha512", + "system.diagnostics.tracing.nuspec" + ] + }, + "System.Dynamic.Runtime/4.3.0": { + "sha512": "SNVi1E/vfWUAs/WYKhE9+qlS6KqK0YVhnlT0HQtr8pMIA8YX3lwy3uPMownDwdYISBdmAF/2holEIldVp85Wag==", + "type": "package", + "path": "system.dynamic.runtime/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/netcore50/System.Dynamic.Runtime.dll", + "lib/netstandard1.3/System.Dynamic.Runtime.dll", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Dynamic.Runtime.dll", + "ref/netcore50/System.Dynamic.Runtime.xml", + "ref/netcore50/de/System.Dynamic.Runtime.xml", + "ref/netcore50/es/System.Dynamic.Runtime.xml", + "ref/netcore50/fr/System.Dynamic.Runtime.xml", + "ref/netcore50/it/System.Dynamic.Runtime.xml", + "ref/netcore50/ja/System.Dynamic.Runtime.xml", + "ref/netcore50/ko/System.Dynamic.Runtime.xml", + "ref/netcore50/ru/System.Dynamic.Runtime.xml", + "ref/netcore50/zh-hans/System.Dynamic.Runtime.xml", + "ref/netcore50/zh-hant/System.Dynamic.Runtime.xml", + "ref/netstandard1.0/System.Dynamic.Runtime.dll", + "ref/netstandard1.0/System.Dynamic.Runtime.xml", + "ref/netstandard1.0/de/System.Dynamic.Runtime.xml", + "ref/netstandard1.0/es/System.Dynamic.Runtime.xml", + "ref/netstandard1.0/fr/System.Dynamic.Runtime.xml", + "ref/netstandard1.0/it/System.Dynamic.Runtime.xml", + "ref/netstandard1.0/ja/System.Dynamic.Runtime.xml", + "ref/netstandard1.0/ko/System.Dynamic.Runtime.xml", + "ref/netstandard1.0/ru/System.Dynamic.Runtime.xml", + "ref/netstandard1.0/zh-hans/System.Dynamic.Runtime.xml", + "ref/netstandard1.0/zh-hant/System.Dynamic.Runtime.xml", + "ref/netstandard1.3/System.Dynamic.Runtime.dll", + "ref/netstandard1.3/System.Dynamic.Runtime.xml", + "ref/netstandard1.3/de/System.Dynamic.Runtime.xml", + "ref/netstandard1.3/es/System.Dynamic.Runtime.xml", + "ref/netstandard1.3/fr/System.Dynamic.Runtime.xml", + "ref/netstandard1.3/it/System.Dynamic.Runtime.xml", + "ref/netstandard1.3/ja/System.Dynamic.Runtime.xml", + "ref/netstandard1.3/ko/System.Dynamic.Runtime.xml", + "ref/netstandard1.3/ru/System.Dynamic.Runtime.xml", + "ref/netstandard1.3/zh-hans/System.Dynamic.Runtime.xml", + "ref/netstandard1.3/zh-hant/System.Dynamic.Runtime.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/aot/lib/netcore50/System.Dynamic.Runtime.dll", + "system.dynamic.runtime.4.3.0.nupkg.sha512", + "system.dynamic.runtime.nuspec" + ] + }, + "System.Globalization/4.3.0": { + "sha512": "kYdVd2f2PAdFGblzFswE4hkNANJBKRmsfa2X5LG2AcWE1c7/4t0pYae1L8vfZ5xvE2nK/R9JprtToA61OSHWIg==", + "type": "package", + "path": "system.globalization/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Globalization.dll", + "ref/netcore50/System.Globalization.xml", + "ref/netcore50/de/System.Globalization.xml", + "ref/netcore50/es/System.Globalization.xml", + "ref/netcore50/fr/System.Globalization.xml", + "ref/netcore50/it/System.Globalization.xml", + "ref/netcore50/ja/System.Globalization.xml", + "ref/netcore50/ko/System.Globalization.xml", + "ref/netcore50/ru/System.Globalization.xml", + "ref/netcore50/zh-hans/System.Globalization.xml", + "ref/netcore50/zh-hant/System.Globalization.xml", + "ref/netstandard1.0/System.Globalization.dll", + "ref/netstandard1.0/System.Globalization.xml", + "ref/netstandard1.0/de/System.Globalization.xml", + "ref/netstandard1.0/es/System.Globalization.xml", + "ref/netstandard1.0/fr/System.Globalization.xml", + "ref/netstandard1.0/it/System.Globalization.xml", + "ref/netstandard1.0/ja/System.Globalization.xml", + "ref/netstandard1.0/ko/System.Globalization.xml", + "ref/netstandard1.0/ru/System.Globalization.xml", + "ref/netstandard1.0/zh-hans/System.Globalization.xml", + "ref/netstandard1.0/zh-hant/System.Globalization.xml", + "ref/netstandard1.3/System.Globalization.dll", + "ref/netstandard1.3/System.Globalization.xml", + "ref/netstandard1.3/de/System.Globalization.xml", + "ref/netstandard1.3/es/System.Globalization.xml", + "ref/netstandard1.3/fr/System.Globalization.xml", + "ref/netstandard1.3/it/System.Globalization.xml", + "ref/netstandard1.3/ja/System.Globalization.xml", + "ref/netstandard1.3/ko/System.Globalization.xml", + "ref/netstandard1.3/ru/System.Globalization.xml", + "ref/netstandard1.3/zh-hans/System.Globalization.xml", + "ref/netstandard1.3/zh-hant/System.Globalization.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.globalization.4.3.0.nupkg.sha512", + "system.globalization.nuspec" + ] + }, + "System.Globalization.Calendars/4.3.0": { + "sha512": "GUlBtdOWT4LTV3I+9/PJW+56AnnChTaOqqTLFtdmype/L500M2LIyXgmtd9X2P2VOkmJd5c67H5SaC2QcL1bFA==", + "type": "package", + "path": "system.globalization.calendars/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.Globalization.Calendars.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.Globalization.Calendars.dll", + "ref/netstandard1.3/System.Globalization.Calendars.dll", + "ref/netstandard1.3/System.Globalization.Calendars.xml", + "ref/netstandard1.3/de/System.Globalization.Calendars.xml", + "ref/netstandard1.3/es/System.Globalization.Calendars.xml", + "ref/netstandard1.3/fr/System.Globalization.Calendars.xml", + "ref/netstandard1.3/it/System.Globalization.Calendars.xml", + "ref/netstandard1.3/ja/System.Globalization.Calendars.xml", + "ref/netstandard1.3/ko/System.Globalization.Calendars.xml", + "ref/netstandard1.3/ru/System.Globalization.Calendars.xml", + "ref/netstandard1.3/zh-hans/System.Globalization.Calendars.xml", + "ref/netstandard1.3/zh-hant/System.Globalization.Calendars.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.globalization.calendars.4.3.0.nupkg.sha512", + "system.globalization.calendars.nuspec" + ] + }, + "System.Globalization.Extensions/4.3.0": { + "sha512": "FhKmdR6MPG+pxow6wGtNAWdZh7noIOpdD5TwQ3CprzgIE1bBBoim0vbR1+AWsWjQmU7zXHgQo4TWSP6lCeiWcQ==", + "type": "package", + "path": "system.globalization.extensions/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.Globalization.Extensions.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.Globalization.Extensions.dll", + "ref/netstandard1.3/System.Globalization.Extensions.dll", + "ref/netstandard1.3/System.Globalization.Extensions.xml", + "ref/netstandard1.3/de/System.Globalization.Extensions.xml", + "ref/netstandard1.3/es/System.Globalization.Extensions.xml", + "ref/netstandard1.3/fr/System.Globalization.Extensions.xml", + "ref/netstandard1.3/it/System.Globalization.Extensions.xml", + "ref/netstandard1.3/ja/System.Globalization.Extensions.xml", + "ref/netstandard1.3/ko/System.Globalization.Extensions.xml", + "ref/netstandard1.3/ru/System.Globalization.Extensions.xml", + "ref/netstandard1.3/zh-hans/System.Globalization.Extensions.xml", + "ref/netstandard1.3/zh-hant/System.Globalization.Extensions.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/unix/lib/netstandard1.3/System.Globalization.Extensions.dll", + "runtimes/win/lib/net46/System.Globalization.Extensions.dll", + "runtimes/win/lib/netstandard1.3/System.Globalization.Extensions.dll", + "system.globalization.extensions.4.3.0.nupkg.sha512", + "system.globalization.extensions.nuspec" + ] + }, + "System.IO/4.3.0": { + "sha512": "3qjaHvxQPDpSOYICjUoTsmoq5u6QJAFRUITgeT/4gqkF1bajbSmb1kwSxEA8AHlofqgcKJcM8udgieRNhaJ5Cg==", + "type": "package", + "path": "system.io/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/net462/System.IO.dll", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/net462/System.IO.dll", + "ref/netcore50/System.IO.dll", + "ref/netcore50/System.IO.xml", + "ref/netcore50/de/System.IO.xml", + "ref/netcore50/es/System.IO.xml", + "ref/netcore50/fr/System.IO.xml", + "ref/netcore50/it/System.IO.xml", + "ref/netcore50/ja/System.IO.xml", + "ref/netcore50/ko/System.IO.xml", + "ref/netcore50/ru/System.IO.xml", + "ref/netcore50/zh-hans/System.IO.xml", + "ref/netcore50/zh-hant/System.IO.xml", + "ref/netstandard1.0/System.IO.dll", + "ref/netstandard1.0/System.IO.xml", + "ref/netstandard1.0/de/System.IO.xml", + "ref/netstandard1.0/es/System.IO.xml", + "ref/netstandard1.0/fr/System.IO.xml", + "ref/netstandard1.0/it/System.IO.xml", + "ref/netstandard1.0/ja/System.IO.xml", + "ref/netstandard1.0/ko/System.IO.xml", + "ref/netstandard1.0/ru/System.IO.xml", + "ref/netstandard1.0/zh-hans/System.IO.xml", + "ref/netstandard1.0/zh-hant/System.IO.xml", + "ref/netstandard1.3/System.IO.dll", + "ref/netstandard1.3/System.IO.xml", + "ref/netstandard1.3/de/System.IO.xml", + "ref/netstandard1.3/es/System.IO.xml", + "ref/netstandard1.3/fr/System.IO.xml", + "ref/netstandard1.3/it/System.IO.xml", + "ref/netstandard1.3/ja/System.IO.xml", + "ref/netstandard1.3/ko/System.IO.xml", + "ref/netstandard1.3/ru/System.IO.xml", + "ref/netstandard1.3/zh-hans/System.IO.xml", + "ref/netstandard1.3/zh-hant/System.IO.xml", + "ref/netstandard1.5/System.IO.dll", + "ref/netstandard1.5/System.IO.xml", + "ref/netstandard1.5/de/System.IO.xml", + "ref/netstandard1.5/es/System.IO.xml", + "ref/netstandard1.5/fr/System.IO.xml", + "ref/netstandard1.5/it/System.IO.xml", + "ref/netstandard1.5/ja/System.IO.xml", + "ref/netstandard1.5/ko/System.IO.xml", + "ref/netstandard1.5/ru/System.IO.xml", + "ref/netstandard1.5/zh-hans/System.IO.xml", + "ref/netstandard1.5/zh-hant/System.IO.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.io.4.3.0.nupkg.sha512", + "system.io.nuspec" + ] + }, + "System.IO.Compression/4.3.0": { + "sha512": "YHndyoiV90iu4iKG115ibkhrG+S3jBm8Ap9OwoUAzO5oPDAWcr0SFwQFm0HjM8WkEZWo0zvLTyLmbvTkW1bXgg==", + "type": "package", + "path": "system.io.compression/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/net46/System.IO.Compression.dll", + "lib/portable-net45+win8+wpa81/_._", + "lib/win8/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/net46/System.IO.Compression.dll", + "ref/netcore50/System.IO.Compression.dll", + "ref/netcore50/System.IO.Compression.xml", + "ref/netcore50/de/System.IO.Compression.xml", + "ref/netcore50/es/System.IO.Compression.xml", + "ref/netcore50/fr/System.IO.Compression.xml", + "ref/netcore50/it/System.IO.Compression.xml", + "ref/netcore50/ja/System.IO.Compression.xml", + "ref/netcore50/ko/System.IO.Compression.xml", + "ref/netcore50/ru/System.IO.Compression.xml", + "ref/netcore50/zh-hans/System.IO.Compression.xml", + "ref/netcore50/zh-hant/System.IO.Compression.xml", + "ref/netstandard1.1/System.IO.Compression.dll", + "ref/netstandard1.1/System.IO.Compression.xml", + "ref/netstandard1.1/de/System.IO.Compression.xml", + "ref/netstandard1.1/es/System.IO.Compression.xml", + "ref/netstandard1.1/fr/System.IO.Compression.xml", + "ref/netstandard1.1/it/System.IO.Compression.xml", + "ref/netstandard1.1/ja/System.IO.Compression.xml", + "ref/netstandard1.1/ko/System.IO.Compression.xml", + "ref/netstandard1.1/ru/System.IO.Compression.xml", + "ref/netstandard1.1/zh-hans/System.IO.Compression.xml", + "ref/netstandard1.1/zh-hant/System.IO.Compression.xml", + "ref/netstandard1.3/System.IO.Compression.dll", + "ref/netstandard1.3/System.IO.Compression.xml", + "ref/netstandard1.3/de/System.IO.Compression.xml", + "ref/netstandard1.3/es/System.IO.Compression.xml", + "ref/netstandard1.3/fr/System.IO.Compression.xml", + "ref/netstandard1.3/it/System.IO.Compression.xml", + "ref/netstandard1.3/ja/System.IO.Compression.xml", + "ref/netstandard1.3/ko/System.IO.Compression.xml", + "ref/netstandard1.3/ru/System.IO.Compression.xml", + "ref/netstandard1.3/zh-hans/System.IO.Compression.xml", + "ref/netstandard1.3/zh-hant/System.IO.Compression.xml", + "ref/portable-net45+win8+wpa81/_._", + "ref/win8/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/unix/lib/netstandard1.3/System.IO.Compression.dll", + "runtimes/win/lib/net46/System.IO.Compression.dll", + "runtimes/win/lib/netstandard1.3/System.IO.Compression.dll", + "system.io.compression.4.3.0.nupkg.sha512", + "system.io.compression.nuspec" + ] + }, + "System.IO.Compression.ZipFile/4.3.0": { + "sha512": "G4HwjEsgIwy3JFBduZ9quBkAu+eUwjIdJleuNSgmUojbH6O3mlvEIme+GHx/cLlTAPcrnnL7GqvB9pTlWRfhOg==", + "type": "package", + "path": "system.io.compression.zipfile/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.IO.Compression.ZipFile.dll", + "lib/netstandard1.3/System.IO.Compression.ZipFile.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.IO.Compression.ZipFile.dll", + "ref/netstandard1.3/System.IO.Compression.ZipFile.dll", + "ref/netstandard1.3/System.IO.Compression.ZipFile.xml", + "ref/netstandard1.3/de/System.IO.Compression.ZipFile.xml", + "ref/netstandard1.3/es/System.IO.Compression.ZipFile.xml", + "ref/netstandard1.3/fr/System.IO.Compression.ZipFile.xml", + "ref/netstandard1.3/it/System.IO.Compression.ZipFile.xml", + "ref/netstandard1.3/ja/System.IO.Compression.ZipFile.xml", + "ref/netstandard1.3/ko/System.IO.Compression.ZipFile.xml", + "ref/netstandard1.3/ru/System.IO.Compression.ZipFile.xml", + "ref/netstandard1.3/zh-hans/System.IO.Compression.ZipFile.xml", + "ref/netstandard1.3/zh-hant/System.IO.Compression.ZipFile.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.io.compression.zipfile.4.3.0.nupkg.sha512", + "system.io.compression.zipfile.nuspec" + ] + }, + "System.IO.FileSystem/4.3.0": { + "sha512": "3wEMARTnuio+ulnvi+hkRNROYwa1kylvYahhcLk4HSoVdl+xxTFVeVlYOfLwrDPImGls0mDqbMhrza8qnWPTdA==", + "type": "package", + "path": "system.io.filesystem/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.IO.FileSystem.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.IO.FileSystem.dll", + "ref/netstandard1.3/System.IO.FileSystem.dll", + "ref/netstandard1.3/System.IO.FileSystem.xml", + "ref/netstandard1.3/de/System.IO.FileSystem.xml", + "ref/netstandard1.3/es/System.IO.FileSystem.xml", + "ref/netstandard1.3/fr/System.IO.FileSystem.xml", + "ref/netstandard1.3/it/System.IO.FileSystem.xml", + "ref/netstandard1.3/ja/System.IO.FileSystem.xml", + "ref/netstandard1.3/ko/System.IO.FileSystem.xml", + "ref/netstandard1.3/ru/System.IO.FileSystem.xml", + "ref/netstandard1.3/zh-hans/System.IO.FileSystem.xml", + "ref/netstandard1.3/zh-hant/System.IO.FileSystem.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.io.filesystem.4.3.0.nupkg.sha512", + "system.io.filesystem.nuspec" + ] + }, + "System.IO.FileSystem.Primitives/4.3.0": { + "sha512": "6QOb2XFLch7bEc4lIcJH49nJN2HV+OC3fHDgsLVsBVBk3Y4hFAnOBGzJ2lUu7CyDDFo9IBWkSsnbkT6IBwwiMw==", + "type": "package", + "path": "system.io.filesystem.primitives/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.IO.FileSystem.Primitives.dll", + "lib/netstandard1.3/System.IO.FileSystem.Primitives.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.IO.FileSystem.Primitives.dll", + "ref/netstandard1.3/System.IO.FileSystem.Primitives.dll", + "ref/netstandard1.3/System.IO.FileSystem.Primitives.xml", + "ref/netstandard1.3/de/System.IO.FileSystem.Primitives.xml", + "ref/netstandard1.3/es/System.IO.FileSystem.Primitives.xml", + "ref/netstandard1.3/fr/System.IO.FileSystem.Primitives.xml", + "ref/netstandard1.3/it/System.IO.FileSystem.Primitives.xml", + "ref/netstandard1.3/ja/System.IO.FileSystem.Primitives.xml", + "ref/netstandard1.3/ko/System.IO.FileSystem.Primitives.xml", + "ref/netstandard1.3/ru/System.IO.FileSystem.Primitives.xml", + "ref/netstandard1.3/zh-hans/System.IO.FileSystem.Primitives.xml", + "ref/netstandard1.3/zh-hant/System.IO.FileSystem.Primitives.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.io.filesystem.primitives.4.3.0.nupkg.sha512", + "system.io.filesystem.primitives.nuspec" + ] + }, + "System.Linq/4.3.0": { + "sha512": "5DbqIUpsDp0dFftytzuMmc0oeMdQwjcP/EWxsksIz/w1TcFRkZ3yKKz0PqiYFMmEwPSWw+qNVqD7PJ889JzHbw==", + "type": "package", + "path": "system.linq/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/net463/System.Linq.dll", + "lib/netcore50/System.Linq.dll", + "lib/netstandard1.6/System.Linq.dll", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/net463/System.Linq.dll", + "ref/netcore50/System.Linq.dll", + "ref/netcore50/System.Linq.xml", + "ref/netcore50/de/System.Linq.xml", + "ref/netcore50/es/System.Linq.xml", + "ref/netcore50/fr/System.Linq.xml", + "ref/netcore50/it/System.Linq.xml", + "ref/netcore50/ja/System.Linq.xml", + "ref/netcore50/ko/System.Linq.xml", + "ref/netcore50/ru/System.Linq.xml", + "ref/netcore50/zh-hans/System.Linq.xml", + "ref/netcore50/zh-hant/System.Linq.xml", + "ref/netstandard1.0/System.Linq.dll", + "ref/netstandard1.0/System.Linq.xml", + "ref/netstandard1.0/de/System.Linq.xml", + "ref/netstandard1.0/es/System.Linq.xml", + "ref/netstandard1.0/fr/System.Linq.xml", + "ref/netstandard1.0/it/System.Linq.xml", + "ref/netstandard1.0/ja/System.Linq.xml", + "ref/netstandard1.0/ko/System.Linq.xml", + "ref/netstandard1.0/ru/System.Linq.xml", + "ref/netstandard1.0/zh-hans/System.Linq.xml", + "ref/netstandard1.0/zh-hant/System.Linq.xml", + "ref/netstandard1.6/System.Linq.dll", + "ref/netstandard1.6/System.Linq.xml", + "ref/netstandard1.6/de/System.Linq.xml", + "ref/netstandard1.6/es/System.Linq.xml", + "ref/netstandard1.6/fr/System.Linq.xml", + "ref/netstandard1.6/it/System.Linq.xml", + "ref/netstandard1.6/ja/System.Linq.xml", + "ref/netstandard1.6/ko/System.Linq.xml", + "ref/netstandard1.6/ru/System.Linq.xml", + "ref/netstandard1.6/zh-hans/System.Linq.xml", + "ref/netstandard1.6/zh-hant/System.Linq.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.linq.4.3.0.nupkg.sha512", + "system.linq.nuspec" + ] + }, + "System.Linq.Expressions/4.3.0": { + "sha512": "PGKkrd2khG4CnlyJwxwwaWWiSiWFNBGlgXvJpeO0xCXrZ89ODrQ6tjEWS/kOqZ8GwEOUATtKtzp1eRgmYNfclg==", + "type": "package", + "path": "system.linq.expressions/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/net463/System.Linq.Expressions.dll", + "lib/netcore50/System.Linq.Expressions.dll", + "lib/netstandard1.6/System.Linq.Expressions.dll", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/net463/System.Linq.Expressions.dll", + "ref/netcore50/System.Linq.Expressions.dll", + "ref/netcore50/System.Linq.Expressions.xml", + "ref/netcore50/de/System.Linq.Expressions.xml", + "ref/netcore50/es/System.Linq.Expressions.xml", + "ref/netcore50/fr/System.Linq.Expressions.xml", + "ref/netcore50/it/System.Linq.Expressions.xml", + "ref/netcore50/ja/System.Linq.Expressions.xml", + "ref/netcore50/ko/System.Linq.Expressions.xml", + "ref/netcore50/ru/System.Linq.Expressions.xml", + "ref/netcore50/zh-hans/System.Linq.Expressions.xml", + "ref/netcore50/zh-hant/System.Linq.Expressions.xml", + "ref/netstandard1.0/System.Linq.Expressions.dll", + "ref/netstandard1.0/System.Linq.Expressions.xml", + "ref/netstandard1.0/de/System.Linq.Expressions.xml", + "ref/netstandard1.0/es/System.Linq.Expressions.xml", + "ref/netstandard1.0/fr/System.Linq.Expressions.xml", + "ref/netstandard1.0/it/System.Linq.Expressions.xml", + "ref/netstandard1.0/ja/System.Linq.Expressions.xml", + "ref/netstandard1.0/ko/System.Linq.Expressions.xml", + "ref/netstandard1.0/ru/System.Linq.Expressions.xml", + "ref/netstandard1.0/zh-hans/System.Linq.Expressions.xml", + "ref/netstandard1.0/zh-hant/System.Linq.Expressions.xml", + "ref/netstandard1.3/System.Linq.Expressions.dll", + "ref/netstandard1.3/System.Linq.Expressions.xml", + "ref/netstandard1.3/de/System.Linq.Expressions.xml", + "ref/netstandard1.3/es/System.Linq.Expressions.xml", + "ref/netstandard1.3/fr/System.Linq.Expressions.xml", + "ref/netstandard1.3/it/System.Linq.Expressions.xml", + "ref/netstandard1.3/ja/System.Linq.Expressions.xml", + "ref/netstandard1.3/ko/System.Linq.Expressions.xml", + "ref/netstandard1.3/ru/System.Linq.Expressions.xml", + "ref/netstandard1.3/zh-hans/System.Linq.Expressions.xml", + "ref/netstandard1.3/zh-hant/System.Linq.Expressions.xml", + "ref/netstandard1.6/System.Linq.Expressions.dll", + "ref/netstandard1.6/System.Linq.Expressions.xml", + "ref/netstandard1.6/de/System.Linq.Expressions.xml", + "ref/netstandard1.6/es/System.Linq.Expressions.xml", + "ref/netstandard1.6/fr/System.Linq.Expressions.xml", + "ref/netstandard1.6/it/System.Linq.Expressions.xml", + "ref/netstandard1.6/ja/System.Linq.Expressions.xml", + "ref/netstandard1.6/ko/System.Linq.Expressions.xml", + "ref/netstandard1.6/ru/System.Linq.Expressions.xml", + "ref/netstandard1.6/zh-hans/System.Linq.Expressions.xml", + "ref/netstandard1.6/zh-hant/System.Linq.Expressions.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/aot/lib/netcore50/System.Linq.Expressions.dll", + "system.linq.expressions.4.3.0.nupkg.sha512", + "system.linq.expressions.nuspec" + ] + }, + "System.Net.Http/4.3.0": { + "sha512": "sYg+FtILtRQuYWSIAuNOELwVuVsxVyJGWQyOnlAzhV4xvhyFnON1bAzYYC+jjRW8JREM45R0R5Dgi8MTC5sEwA==", + "type": "package", + "path": "system.net.http/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/Xamarinmac20/_._", + "lib/monoandroid10/_._", + "lib/monotouch10/_._", + "lib/net45/_._", + "lib/net46/System.Net.Http.dll", + "lib/portable-net45+win8+wpa81/_._", + "lib/win8/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/Xamarinmac20/_._", + "ref/monoandroid10/_._", + "ref/monotouch10/_._", + "ref/net45/_._", + "ref/net46/System.Net.Http.dll", + "ref/net46/System.Net.Http.xml", + "ref/net46/de/System.Net.Http.xml", + "ref/net46/es/System.Net.Http.xml", + "ref/net46/fr/System.Net.Http.xml", + "ref/net46/it/System.Net.Http.xml", + "ref/net46/ja/System.Net.Http.xml", + "ref/net46/ko/System.Net.Http.xml", + "ref/net46/ru/System.Net.Http.xml", + "ref/net46/zh-hans/System.Net.Http.xml", + "ref/net46/zh-hant/System.Net.Http.xml", + "ref/netcore50/System.Net.Http.dll", + "ref/netcore50/System.Net.Http.xml", + "ref/netcore50/de/System.Net.Http.xml", + "ref/netcore50/es/System.Net.Http.xml", + "ref/netcore50/fr/System.Net.Http.xml", + "ref/netcore50/it/System.Net.Http.xml", + "ref/netcore50/ja/System.Net.Http.xml", + "ref/netcore50/ko/System.Net.Http.xml", + "ref/netcore50/ru/System.Net.Http.xml", + "ref/netcore50/zh-hans/System.Net.Http.xml", + "ref/netcore50/zh-hant/System.Net.Http.xml", + "ref/netstandard1.1/System.Net.Http.dll", + "ref/netstandard1.1/System.Net.Http.xml", + "ref/netstandard1.1/de/System.Net.Http.xml", + "ref/netstandard1.1/es/System.Net.Http.xml", + "ref/netstandard1.1/fr/System.Net.Http.xml", + "ref/netstandard1.1/it/System.Net.Http.xml", + "ref/netstandard1.1/ja/System.Net.Http.xml", + "ref/netstandard1.1/ko/System.Net.Http.xml", + "ref/netstandard1.1/ru/System.Net.Http.xml", + "ref/netstandard1.1/zh-hans/System.Net.Http.xml", + "ref/netstandard1.1/zh-hant/System.Net.Http.xml", + "ref/netstandard1.3/System.Net.Http.dll", + "ref/netstandard1.3/System.Net.Http.xml", + "ref/netstandard1.3/de/System.Net.Http.xml", + "ref/netstandard1.3/es/System.Net.Http.xml", + "ref/netstandard1.3/fr/System.Net.Http.xml", + "ref/netstandard1.3/it/System.Net.Http.xml", + "ref/netstandard1.3/ja/System.Net.Http.xml", + "ref/netstandard1.3/ko/System.Net.Http.xml", + "ref/netstandard1.3/ru/System.Net.Http.xml", + "ref/netstandard1.3/zh-hans/System.Net.Http.xml", + "ref/netstandard1.3/zh-hant/System.Net.Http.xml", + "ref/portable-net45+win8+wpa81/_._", + "ref/win8/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/unix/lib/netstandard1.6/System.Net.Http.dll", + "runtimes/win/lib/net46/System.Net.Http.dll", + "runtimes/win/lib/netcore50/System.Net.Http.dll", + "runtimes/win/lib/netstandard1.3/System.Net.Http.dll", + "system.net.http.4.3.0.nupkg.sha512", + "system.net.http.nuspec" + ] + }, + "System.Net.Primitives/4.3.0": { + "sha512": "qOu+hDwFwoZPbzPvwut2qATe3ygjeQBDQj91xlsaqGFQUI5i4ZnZb8yyQuLGpDGivEPIt8EJkd1BVzVoP31FXA==", + "type": "package", + "path": "system.net.primitives/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Net.Primitives.dll", + "ref/netcore50/System.Net.Primitives.xml", + "ref/netcore50/de/System.Net.Primitives.xml", + "ref/netcore50/es/System.Net.Primitives.xml", + "ref/netcore50/fr/System.Net.Primitives.xml", + "ref/netcore50/it/System.Net.Primitives.xml", + "ref/netcore50/ja/System.Net.Primitives.xml", + "ref/netcore50/ko/System.Net.Primitives.xml", + "ref/netcore50/ru/System.Net.Primitives.xml", + "ref/netcore50/zh-hans/System.Net.Primitives.xml", + "ref/netcore50/zh-hant/System.Net.Primitives.xml", + "ref/netstandard1.0/System.Net.Primitives.dll", + "ref/netstandard1.0/System.Net.Primitives.xml", + "ref/netstandard1.0/de/System.Net.Primitives.xml", + "ref/netstandard1.0/es/System.Net.Primitives.xml", + "ref/netstandard1.0/fr/System.Net.Primitives.xml", + "ref/netstandard1.0/it/System.Net.Primitives.xml", + "ref/netstandard1.0/ja/System.Net.Primitives.xml", + "ref/netstandard1.0/ko/System.Net.Primitives.xml", + "ref/netstandard1.0/ru/System.Net.Primitives.xml", + "ref/netstandard1.0/zh-hans/System.Net.Primitives.xml", + "ref/netstandard1.0/zh-hant/System.Net.Primitives.xml", + "ref/netstandard1.1/System.Net.Primitives.dll", + "ref/netstandard1.1/System.Net.Primitives.xml", + "ref/netstandard1.1/de/System.Net.Primitives.xml", + "ref/netstandard1.1/es/System.Net.Primitives.xml", + "ref/netstandard1.1/fr/System.Net.Primitives.xml", + "ref/netstandard1.1/it/System.Net.Primitives.xml", + "ref/netstandard1.1/ja/System.Net.Primitives.xml", + "ref/netstandard1.1/ko/System.Net.Primitives.xml", + "ref/netstandard1.1/ru/System.Net.Primitives.xml", + "ref/netstandard1.1/zh-hans/System.Net.Primitives.xml", + "ref/netstandard1.1/zh-hant/System.Net.Primitives.xml", + "ref/netstandard1.3/System.Net.Primitives.dll", + "ref/netstandard1.3/System.Net.Primitives.xml", + "ref/netstandard1.3/de/System.Net.Primitives.xml", + "ref/netstandard1.3/es/System.Net.Primitives.xml", + "ref/netstandard1.3/fr/System.Net.Primitives.xml", + "ref/netstandard1.3/it/System.Net.Primitives.xml", + "ref/netstandard1.3/ja/System.Net.Primitives.xml", + "ref/netstandard1.3/ko/System.Net.Primitives.xml", + "ref/netstandard1.3/ru/System.Net.Primitives.xml", + "ref/netstandard1.3/zh-hans/System.Net.Primitives.xml", + "ref/netstandard1.3/zh-hant/System.Net.Primitives.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.net.primitives.4.3.0.nupkg.sha512", + "system.net.primitives.nuspec" + ] + }, + "System.Net.Sockets/4.3.0": { + "sha512": "m6icV6TqQOAdgt5N/9I5KNpjom/5NFtkmGseEH+AK/hny8XrytLH3+b5M8zL/Ycg3fhIocFpUMyl/wpFnVRvdw==", + "type": "package", + "path": "system.net.sockets/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.Net.Sockets.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.Net.Sockets.dll", + "ref/netstandard1.3/System.Net.Sockets.dll", + "ref/netstandard1.3/System.Net.Sockets.xml", + "ref/netstandard1.3/de/System.Net.Sockets.xml", + "ref/netstandard1.3/es/System.Net.Sockets.xml", + "ref/netstandard1.3/fr/System.Net.Sockets.xml", + "ref/netstandard1.3/it/System.Net.Sockets.xml", + "ref/netstandard1.3/ja/System.Net.Sockets.xml", + "ref/netstandard1.3/ko/System.Net.Sockets.xml", + "ref/netstandard1.3/ru/System.Net.Sockets.xml", + "ref/netstandard1.3/zh-hans/System.Net.Sockets.xml", + "ref/netstandard1.3/zh-hant/System.Net.Sockets.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.net.sockets.4.3.0.nupkg.sha512", + "system.net.sockets.nuspec" + ] + }, + "System.ObjectModel/4.3.0": { + "sha512": "bdX+80eKv9bN6K4N+d77OankKHGn6CH711a6fcOpMQu2Fckp/Ft4L/kW9WznHpyR0NRAvJutzOMHNNlBGvxQzQ==", + "type": "package", + "path": "system.objectmodel/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/netcore50/System.ObjectModel.dll", + "lib/netstandard1.3/System.ObjectModel.dll", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.ObjectModel.dll", + "ref/netcore50/System.ObjectModel.xml", + "ref/netcore50/de/System.ObjectModel.xml", + "ref/netcore50/es/System.ObjectModel.xml", + "ref/netcore50/fr/System.ObjectModel.xml", + "ref/netcore50/it/System.ObjectModel.xml", + "ref/netcore50/ja/System.ObjectModel.xml", + "ref/netcore50/ko/System.ObjectModel.xml", + "ref/netcore50/ru/System.ObjectModel.xml", + "ref/netcore50/zh-hans/System.ObjectModel.xml", + "ref/netcore50/zh-hant/System.ObjectModel.xml", + "ref/netstandard1.0/System.ObjectModel.dll", + "ref/netstandard1.0/System.ObjectModel.xml", + "ref/netstandard1.0/de/System.ObjectModel.xml", + "ref/netstandard1.0/es/System.ObjectModel.xml", + "ref/netstandard1.0/fr/System.ObjectModel.xml", + "ref/netstandard1.0/it/System.ObjectModel.xml", + "ref/netstandard1.0/ja/System.ObjectModel.xml", + "ref/netstandard1.0/ko/System.ObjectModel.xml", + "ref/netstandard1.0/ru/System.ObjectModel.xml", + "ref/netstandard1.0/zh-hans/System.ObjectModel.xml", + "ref/netstandard1.0/zh-hant/System.ObjectModel.xml", + "ref/netstandard1.3/System.ObjectModel.dll", + "ref/netstandard1.3/System.ObjectModel.xml", + "ref/netstandard1.3/de/System.ObjectModel.xml", + "ref/netstandard1.3/es/System.ObjectModel.xml", + "ref/netstandard1.3/fr/System.ObjectModel.xml", + "ref/netstandard1.3/it/System.ObjectModel.xml", + "ref/netstandard1.3/ja/System.ObjectModel.xml", + "ref/netstandard1.3/ko/System.ObjectModel.xml", + "ref/netstandard1.3/ru/System.ObjectModel.xml", + "ref/netstandard1.3/zh-hans/System.ObjectModel.xml", + "ref/netstandard1.3/zh-hant/System.ObjectModel.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.objectmodel.4.3.0.nupkg.sha512", + "system.objectmodel.nuspec" + ] + }, + "System.Reflection/4.3.0": { + "sha512": "KMiAFoW7MfJGa9nDFNcfu+FpEdiHpWgTcS2HdMpDvt9saK3y/G4GwprPyzqjFH9NTaGPQeWNHU+iDlDILj96aQ==", + "type": "package", + "path": "system.reflection/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/net462/System.Reflection.dll", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/net462/System.Reflection.dll", + "ref/netcore50/System.Reflection.dll", + "ref/netcore50/System.Reflection.xml", + "ref/netcore50/de/System.Reflection.xml", + "ref/netcore50/es/System.Reflection.xml", + "ref/netcore50/fr/System.Reflection.xml", + "ref/netcore50/it/System.Reflection.xml", + "ref/netcore50/ja/System.Reflection.xml", + "ref/netcore50/ko/System.Reflection.xml", + "ref/netcore50/ru/System.Reflection.xml", + "ref/netcore50/zh-hans/System.Reflection.xml", + "ref/netcore50/zh-hant/System.Reflection.xml", + "ref/netstandard1.0/System.Reflection.dll", + "ref/netstandard1.0/System.Reflection.xml", + "ref/netstandard1.0/de/System.Reflection.xml", + "ref/netstandard1.0/es/System.Reflection.xml", + "ref/netstandard1.0/fr/System.Reflection.xml", + "ref/netstandard1.0/it/System.Reflection.xml", + "ref/netstandard1.0/ja/System.Reflection.xml", + "ref/netstandard1.0/ko/System.Reflection.xml", + "ref/netstandard1.0/ru/System.Reflection.xml", + "ref/netstandard1.0/zh-hans/System.Reflection.xml", + "ref/netstandard1.0/zh-hant/System.Reflection.xml", + "ref/netstandard1.3/System.Reflection.dll", + "ref/netstandard1.3/System.Reflection.xml", + "ref/netstandard1.3/de/System.Reflection.xml", + "ref/netstandard1.3/es/System.Reflection.xml", + "ref/netstandard1.3/fr/System.Reflection.xml", + "ref/netstandard1.3/it/System.Reflection.xml", + "ref/netstandard1.3/ja/System.Reflection.xml", + "ref/netstandard1.3/ko/System.Reflection.xml", + "ref/netstandard1.3/ru/System.Reflection.xml", + "ref/netstandard1.3/zh-hans/System.Reflection.xml", + "ref/netstandard1.3/zh-hant/System.Reflection.xml", + "ref/netstandard1.5/System.Reflection.dll", + "ref/netstandard1.5/System.Reflection.xml", + "ref/netstandard1.5/de/System.Reflection.xml", + "ref/netstandard1.5/es/System.Reflection.xml", + "ref/netstandard1.5/fr/System.Reflection.xml", + "ref/netstandard1.5/it/System.Reflection.xml", + "ref/netstandard1.5/ja/System.Reflection.xml", + "ref/netstandard1.5/ko/System.Reflection.xml", + "ref/netstandard1.5/ru/System.Reflection.xml", + "ref/netstandard1.5/zh-hans/System.Reflection.xml", + "ref/netstandard1.5/zh-hant/System.Reflection.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.reflection.4.3.0.nupkg.sha512", + "system.reflection.nuspec" + ] + }, + "System.Reflection.Emit/4.3.0": { + "sha512": "228FG0jLcIwTVJyz8CLFKueVqQK36ANazUManGaJHkO0icjiIypKW7YLWLIWahyIkdh5M7mV2dJepllLyA1SKg==", + "type": "package", + "path": "system.reflection.emit/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/monotouch10/_._", + "lib/net45/_._", + "lib/netcore50/System.Reflection.Emit.dll", + "lib/netstandard1.3/System.Reflection.Emit.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/net45/_._", + "ref/netstandard1.1/System.Reflection.Emit.dll", + "ref/netstandard1.1/System.Reflection.Emit.xml", + "ref/netstandard1.1/de/System.Reflection.Emit.xml", + "ref/netstandard1.1/es/System.Reflection.Emit.xml", + "ref/netstandard1.1/fr/System.Reflection.Emit.xml", + "ref/netstandard1.1/it/System.Reflection.Emit.xml", + "ref/netstandard1.1/ja/System.Reflection.Emit.xml", + "ref/netstandard1.1/ko/System.Reflection.Emit.xml", + "ref/netstandard1.1/ru/System.Reflection.Emit.xml", + "ref/netstandard1.1/zh-hans/System.Reflection.Emit.xml", + "ref/netstandard1.1/zh-hant/System.Reflection.Emit.xml", + "ref/xamarinmac20/_._", + "system.reflection.emit.4.3.0.nupkg.sha512", + "system.reflection.emit.nuspec" + ] + }, + "System.Reflection.Emit.ILGeneration/4.3.0": { + "sha512": "59tBslAk9733NXLrUJrwNZEzbMAcu8k344OYo+wfSVygcgZ9lgBdGIzH/nrg3LYhXceynyvTc8t5/GD4Ri0/ng==", + "type": "package", + "path": "system.reflection.emit.ilgeneration/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/netcore50/System.Reflection.Emit.ILGeneration.dll", + "lib/netstandard1.3/System.Reflection.Emit.ILGeneration.dll", + "lib/portable-net45+wp8/_._", + "lib/wp80/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netstandard1.0/System.Reflection.Emit.ILGeneration.dll", + "ref/netstandard1.0/System.Reflection.Emit.ILGeneration.xml", + "ref/netstandard1.0/de/System.Reflection.Emit.ILGeneration.xml", + "ref/netstandard1.0/es/System.Reflection.Emit.ILGeneration.xml", + "ref/netstandard1.0/fr/System.Reflection.Emit.ILGeneration.xml", + "ref/netstandard1.0/it/System.Reflection.Emit.ILGeneration.xml", + "ref/netstandard1.0/ja/System.Reflection.Emit.ILGeneration.xml", + "ref/netstandard1.0/ko/System.Reflection.Emit.ILGeneration.xml", + "ref/netstandard1.0/ru/System.Reflection.Emit.ILGeneration.xml", + "ref/netstandard1.0/zh-hans/System.Reflection.Emit.ILGeneration.xml", + "ref/netstandard1.0/zh-hant/System.Reflection.Emit.ILGeneration.xml", + "ref/portable-net45+wp8/_._", + "ref/wp80/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/aot/lib/netcore50/_._", + "system.reflection.emit.ilgeneration.4.3.0.nupkg.sha512", + "system.reflection.emit.ilgeneration.nuspec" + ] + }, + "System.Reflection.Emit.Lightweight/4.3.0": { + "sha512": "oadVHGSMsTmZsAF864QYN1t1QzZjIcuKU3l2S9cZOwDdDueNTrqq1yRj7koFfIGEnKpt6NjpL3rOzRhs4ryOgA==", + "type": "package", + "path": "system.reflection.emit.lightweight/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/netcore50/System.Reflection.Emit.Lightweight.dll", + "lib/netstandard1.3/System.Reflection.Emit.Lightweight.dll", + "lib/portable-net45+wp8/_._", + "lib/wp80/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netstandard1.0/System.Reflection.Emit.Lightweight.dll", + "ref/netstandard1.0/System.Reflection.Emit.Lightweight.xml", + "ref/netstandard1.0/de/System.Reflection.Emit.Lightweight.xml", + "ref/netstandard1.0/es/System.Reflection.Emit.Lightweight.xml", + "ref/netstandard1.0/fr/System.Reflection.Emit.Lightweight.xml", + "ref/netstandard1.0/it/System.Reflection.Emit.Lightweight.xml", + "ref/netstandard1.0/ja/System.Reflection.Emit.Lightweight.xml", + "ref/netstandard1.0/ko/System.Reflection.Emit.Lightweight.xml", + "ref/netstandard1.0/ru/System.Reflection.Emit.Lightweight.xml", + "ref/netstandard1.0/zh-hans/System.Reflection.Emit.Lightweight.xml", + "ref/netstandard1.0/zh-hant/System.Reflection.Emit.Lightweight.xml", + "ref/portable-net45+wp8/_._", + "ref/wp80/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/aot/lib/netcore50/_._", + "system.reflection.emit.lightweight.4.3.0.nupkg.sha512", + "system.reflection.emit.lightweight.nuspec" + ] + }, + "System.Reflection.Extensions/4.3.0": { + "sha512": "rJkrJD3kBI5B712aRu4DpSIiHRtr6QlfZSQsb0hYHrDCZORXCFjQfoipo2LaMUHoT9i1B7j7MnfaEKWDFmFQNQ==", + "type": "package", + "path": "system.reflection.extensions/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Reflection.Extensions.dll", + "ref/netcore50/System.Reflection.Extensions.xml", + "ref/netcore50/de/System.Reflection.Extensions.xml", + "ref/netcore50/es/System.Reflection.Extensions.xml", + "ref/netcore50/fr/System.Reflection.Extensions.xml", + "ref/netcore50/it/System.Reflection.Extensions.xml", + "ref/netcore50/ja/System.Reflection.Extensions.xml", + "ref/netcore50/ko/System.Reflection.Extensions.xml", + "ref/netcore50/ru/System.Reflection.Extensions.xml", + "ref/netcore50/zh-hans/System.Reflection.Extensions.xml", + "ref/netcore50/zh-hant/System.Reflection.Extensions.xml", + "ref/netstandard1.0/System.Reflection.Extensions.dll", + "ref/netstandard1.0/System.Reflection.Extensions.xml", + "ref/netstandard1.0/de/System.Reflection.Extensions.xml", + "ref/netstandard1.0/es/System.Reflection.Extensions.xml", + "ref/netstandard1.0/fr/System.Reflection.Extensions.xml", + "ref/netstandard1.0/it/System.Reflection.Extensions.xml", + "ref/netstandard1.0/ja/System.Reflection.Extensions.xml", + "ref/netstandard1.0/ko/System.Reflection.Extensions.xml", + "ref/netstandard1.0/ru/System.Reflection.Extensions.xml", + "ref/netstandard1.0/zh-hans/System.Reflection.Extensions.xml", + "ref/netstandard1.0/zh-hant/System.Reflection.Extensions.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.reflection.extensions.4.3.0.nupkg.sha512", + "system.reflection.extensions.nuspec" + ] + }, + "System.Reflection.Primitives/4.3.0": { + "sha512": "5RXItQz5As4xN2/YUDxdpsEkMhvw3e6aNveFXUn4Hl/udNTCNhnKp8lT9fnc3MhvGKh1baak5CovpuQUXHAlIA==", + "type": "package", + "path": "system.reflection.primitives/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Reflection.Primitives.dll", + "ref/netcore50/System.Reflection.Primitives.xml", + "ref/netcore50/de/System.Reflection.Primitives.xml", + "ref/netcore50/es/System.Reflection.Primitives.xml", + "ref/netcore50/fr/System.Reflection.Primitives.xml", + "ref/netcore50/it/System.Reflection.Primitives.xml", + "ref/netcore50/ja/System.Reflection.Primitives.xml", + "ref/netcore50/ko/System.Reflection.Primitives.xml", + "ref/netcore50/ru/System.Reflection.Primitives.xml", + "ref/netcore50/zh-hans/System.Reflection.Primitives.xml", + "ref/netcore50/zh-hant/System.Reflection.Primitives.xml", + "ref/netstandard1.0/System.Reflection.Primitives.dll", + "ref/netstandard1.0/System.Reflection.Primitives.xml", + "ref/netstandard1.0/de/System.Reflection.Primitives.xml", + "ref/netstandard1.0/es/System.Reflection.Primitives.xml", + "ref/netstandard1.0/fr/System.Reflection.Primitives.xml", + "ref/netstandard1.0/it/System.Reflection.Primitives.xml", + "ref/netstandard1.0/ja/System.Reflection.Primitives.xml", + "ref/netstandard1.0/ko/System.Reflection.Primitives.xml", + "ref/netstandard1.0/ru/System.Reflection.Primitives.xml", + "ref/netstandard1.0/zh-hans/System.Reflection.Primitives.xml", + "ref/netstandard1.0/zh-hant/System.Reflection.Primitives.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.reflection.primitives.4.3.0.nupkg.sha512", + "system.reflection.primitives.nuspec" + ] + }, + "System.Reflection.TypeExtensions/4.3.0": { + "sha512": "7u6ulLcZbyxB5Gq0nMkQttcdBTx57ibzw+4IOXEfR+sXYQoHvjW5LTLyNr8O22UIMrqYbchJQJnos4eooYzYJA==", + "type": "package", + "path": "system.reflection.typeextensions/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.Reflection.TypeExtensions.dll", + "lib/net462/System.Reflection.TypeExtensions.dll", + "lib/netcore50/System.Reflection.TypeExtensions.dll", + "lib/netstandard1.5/System.Reflection.TypeExtensions.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.Reflection.TypeExtensions.dll", + "ref/net462/System.Reflection.TypeExtensions.dll", + "ref/netstandard1.3/System.Reflection.TypeExtensions.dll", + "ref/netstandard1.3/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.3/de/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.3/es/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.3/fr/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.3/it/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.3/ja/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.3/ko/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.3/ru/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.3/zh-hans/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.3/zh-hant/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.5/System.Reflection.TypeExtensions.dll", + "ref/netstandard1.5/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.5/de/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.5/es/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.5/fr/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.5/it/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.5/ja/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.5/ko/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.5/ru/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.5/zh-hans/System.Reflection.TypeExtensions.xml", + "ref/netstandard1.5/zh-hant/System.Reflection.TypeExtensions.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/aot/lib/netcore50/System.Reflection.TypeExtensions.dll", + "system.reflection.typeextensions.4.3.0.nupkg.sha512", + "system.reflection.typeextensions.nuspec" + ] + }, + "System.Resources.ResourceManager/4.3.0": { + "sha512": "/zrcPkkWdZmI4F92gL/TPumP98AVDu/Wxr3CSJGQQ+XN6wbRZcyfSKVoPo17ilb3iOr0cCRqJInGwNMolqhS8A==", + "type": "package", + "path": "system.resources.resourcemanager/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Resources.ResourceManager.dll", + "ref/netcore50/System.Resources.ResourceManager.xml", + "ref/netcore50/de/System.Resources.ResourceManager.xml", + "ref/netcore50/es/System.Resources.ResourceManager.xml", + "ref/netcore50/fr/System.Resources.ResourceManager.xml", + "ref/netcore50/it/System.Resources.ResourceManager.xml", + "ref/netcore50/ja/System.Resources.ResourceManager.xml", + "ref/netcore50/ko/System.Resources.ResourceManager.xml", + "ref/netcore50/ru/System.Resources.ResourceManager.xml", + "ref/netcore50/zh-hans/System.Resources.ResourceManager.xml", + "ref/netcore50/zh-hant/System.Resources.ResourceManager.xml", + "ref/netstandard1.0/System.Resources.ResourceManager.dll", + "ref/netstandard1.0/System.Resources.ResourceManager.xml", + "ref/netstandard1.0/de/System.Resources.ResourceManager.xml", + "ref/netstandard1.0/es/System.Resources.ResourceManager.xml", + "ref/netstandard1.0/fr/System.Resources.ResourceManager.xml", + "ref/netstandard1.0/it/System.Resources.ResourceManager.xml", + "ref/netstandard1.0/ja/System.Resources.ResourceManager.xml", + "ref/netstandard1.0/ko/System.Resources.ResourceManager.xml", + "ref/netstandard1.0/ru/System.Resources.ResourceManager.xml", + "ref/netstandard1.0/zh-hans/System.Resources.ResourceManager.xml", + "ref/netstandard1.0/zh-hant/System.Resources.ResourceManager.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.resources.resourcemanager.4.3.0.nupkg.sha512", + "system.resources.resourcemanager.nuspec" + ] + }, + "System.Runtime/4.3.0": { + "sha512": "JufQi0vPQ0xGnAczR13AUFglDyVYt4Kqnz1AZaiKZ5+GICq0/1MH/mO/eAJHt/mHW1zjKBJd7kV26SrxddAhiw==", + "type": "package", + "path": "system.runtime/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/net462/System.Runtime.dll", + "lib/portable-net45+win8+wp80+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/net462/System.Runtime.dll", + "ref/netcore50/System.Runtime.dll", + "ref/netcore50/System.Runtime.xml", + "ref/netcore50/de/System.Runtime.xml", + "ref/netcore50/es/System.Runtime.xml", + "ref/netcore50/fr/System.Runtime.xml", + "ref/netcore50/it/System.Runtime.xml", + "ref/netcore50/ja/System.Runtime.xml", + "ref/netcore50/ko/System.Runtime.xml", + "ref/netcore50/ru/System.Runtime.xml", + "ref/netcore50/zh-hans/System.Runtime.xml", + "ref/netcore50/zh-hant/System.Runtime.xml", + "ref/netstandard1.0/System.Runtime.dll", + "ref/netstandard1.0/System.Runtime.xml", + "ref/netstandard1.0/de/System.Runtime.xml", + "ref/netstandard1.0/es/System.Runtime.xml", + "ref/netstandard1.0/fr/System.Runtime.xml", + "ref/netstandard1.0/it/System.Runtime.xml", + "ref/netstandard1.0/ja/System.Runtime.xml", + "ref/netstandard1.0/ko/System.Runtime.xml", + "ref/netstandard1.0/ru/System.Runtime.xml", + "ref/netstandard1.0/zh-hans/System.Runtime.xml", + "ref/netstandard1.0/zh-hant/System.Runtime.xml", + "ref/netstandard1.2/System.Runtime.dll", + "ref/netstandard1.2/System.Runtime.xml", + "ref/netstandard1.2/de/System.Runtime.xml", + "ref/netstandard1.2/es/System.Runtime.xml", + "ref/netstandard1.2/fr/System.Runtime.xml", + "ref/netstandard1.2/it/System.Runtime.xml", + "ref/netstandard1.2/ja/System.Runtime.xml", + "ref/netstandard1.2/ko/System.Runtime.xml", + "ref/netstandard1.2/ru/System.Runtime.xml", + "ref/netstandard1.2/zh-hans/System.Runtime.xml", + "ref/netstandard1.2/zh-hant/System.Runtime.xml", + "ref/netstandard1.3/System.Runtime.dll", + "ref/netstandard1.3/System.Runtime.xml", + "ref/netstandard1.3/de/System.Runtime.xml", + "ref/netstandard1.3/es/System.Runtime.xml", + "ref/netstandard1.3/fr/System.Runtime.xml", + "ref/netstandard1.3/it/System.Runtime.xml", + "ref/netstandard1.3/ja/System.Runtime.xml", + "ref/netstandard1.3/ko/System.Runtime.xml", + "ref/netstandard1.3/ru/System.Runtime.xml", + "ref/netstandard1.3/zh-hans/System.Runtime.xml", + "ref/netstandard1.3/zh-hant/System.Runtime.xml", + "ref/netstandard1.5/System.Runtime.dll", + "ref/netstandard1.5/System.Runtime.xml", + "ref/netstandard1.5/de/System.Runtime.xml", + "ref/netstandard1.5/es/System.Runtime.xml", + "ref/netstandard1.5/fr/System.Runtime.xml", + "ref/netstandard1.5/it/System.Runtime.xml", + "ref/netstandard1.5/ja/System.Runtime.xml", + "ref/netstandard1.5/ko/System.Runtime.xml", + "ref/netstandard1.5/ru/System.Runtime.xml", + "ref/netstandard1.5/zh-hans/System.Runtime.xml", + "ref/netstandard1.5/zh-hant/System.Runtime.xml", + "ref/portable-net45+win8+wp80+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.runtime.4.3.0.nupkg.sha512", + "system.runtime.nuspec" + ] + }, + "System.Runtime.CompilerServices.Unsafe/5.0.0": { + "sha512": "ZD9TMpsmYJLrxbbmdvhwt9YEgG5WntEnZ/d1eH8JBX9LBp+Ju8BSBhUGbZMNVHHomWo2KVImJhTDl2hIgw/6MA==", + "type": "package", + "path": "system.runtime.compilerservices.unsafe/5.0.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "Icon.png", + "LICENSE.TXT", + "THIRD-PARTY-NOTICES.TXT", + "lib/net45/System.Runtime.CompilerServices.Unsafe.dll", + "lib/net45/System.Runtime.CompilerServices.Unsafe.xml", + "lib/netcoreapp2.0/System.Runtime.CompilerServices.Unsafe.dll", + "lib/netcoreapp2.0/System.Runtime.CompilerServices.Unsafe.xml", + "lib/netstandard1.0/System.Runtime.CompilerServices.Unsafe.dll", + "lib/netstandard1.0/System.Runtime.CompilerServices.Unsafe.xml", + "lib/netstandard2.0/System.Runtime.CompilerServices.Unsafe.dll", + "lib/netstandard2.0/System.Runtime.CompilerServices.Unsafe.xml", + "ref/net461/System.Runtime.CompilerServices.Unsafe.dll", + "ref/net461/System.Runtime.CompilerServices.Unsafe.xml", + "ref/netstandard1.0/System.Runtime.CompilerServices.Unsafe.dll", + "ref/netstandard1.0/System.Runtime.CompilerServices.Unsafe.xml", + "ref/netstandard2.0/System.Runtime.CompilerServices.Unsafe.dll", + "ref/netstandard2.0/System.Runtime.CompilerServices.Unsafe.xml", + "ref/netstandard2.1/System.Runtime.CompilerServices.Unsafe.dll", + "ref/netstandard2.1/System.Runtime.CompilerServices.Unsafe.xml", + "system.runtime.compilerservices.unsafe.5.0.0.nupkg.sha512", + "system.runtime.compilerservices.unsafe.nuspec", + "useSharedDesignerContext.txt", + "version.txt" + ] + }, + "System.Runtime.Extensions/4.3.0": { + "sha512": "guW0uK0fn5fcJJ1tJVXYd7/1h5F+pea1r7FLSOz/f8vPEqbR2ZAknuRDvTQ8PzAilDveOxNjSfr0CHfIQfFk8g==", + "type": "package", + "path": "system.runtime.extensions/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/net462/System.Runtime.Extensions.dll", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/net462/System.Runtime.Extensions.dll", + "ref/netcore50/System.Runtime.Extensions.dll", + "ref/netcore50/System.Runtime.Extensions.xml", + "ref/netcore50/de/System.Runtime.Extensions.xml", + "ref/netcore50/es/System.Runtime.Extensions.xml", + "ref/netcore50/fr/System.Runtime.Extensions.xml", + "ref/netcore50/it/System.Runtime.Extensions.xml", + "ref/netcore50/ja/System.Runtime.Extensions.xml", + "ref/netcore50/ko/System.Runtime.Extensions.xml", + "ref/netcore50/ru/System.Runtime.Extensions.xml", + "ref/netcore50/zh-hans/System.Runtime.Extensions.xml", + "ref/netcore50/zh-hant/System.Runtime.Extensions.xml", + "ref/netstandard1.0/System.Runtime.Extensions.dll", + "ref/netstandard1.0/System.Runtime.Extensions.xml", + "ref/netstandard1.0/de/System.Runtime.Extensions.xml", + "ref/netstandard1.0/es/System.Runtime.Extensions.xml", + "ref/netstandard1.0/fr/System.Runtime.Extensions.xml", + "ref/netstandard1.0/it/System.Runtime.Extensions.xml", + "ref/netstandard1.0/ja/System.Runtime.Extensions.xml", + "ref/netstandard1.0/ko/System.Runtime.Extensions.xml", + "ref/netstandard1.0/ru/System.Runtime.Extensions.xml", + "ref/netstandard1.0/zh-hans/System.Runtime.Extensions.xml", + "ref/netstandard1.0/zh-hant/System.Runtime.Extensions.xml", + "ref/netstandard1.3/System.Runtime.Extensions.dll", + "ref/netstandard1.3/System.Runtime.Extensions.xml", + "ref/netstandard1.3/de/System.Runtime.Extensions.xml", + "ref/netstandard1.3/es/System.Runtime.Extensions.xml", + "ref/netstandard1.3/fr/System.Runtime.Extensions.xml", + "ref/netstandard1.3/it/System.Runtime.Extensions.xml", + "ref/netstandard1.3/ja/System.Runtime.Extensions.xml", + "ref/netstandard1.3/ko/System.Runtime.Extensions.xml", + "ref/netstandard1.3/ru/System.Runtime.Extensions.xml", + "ref/netstandard1.3/zh-hans/System.Runtime.Extensions.xml", + "ref/netstandard1.3/zh-hant/System.Runtime.Extensions.xml", + "ref/netstandard1.5/System.Runtime.Extensions.dll", + "ref/netstandard1.5/System.Runtime.Extensions.xml", + "ref/netstandard1.5/de/System.Runtime.Extensions.xml", + "ref/netstandard1.5/es/System.Runtime.Extensions.xml", + "ref/netstandard1.5/fr/System.Runtime.Extensions.xml", + "ref/netstandard1.5/it/System.Runtime.Extensions.xml", + "ref/netstandard1.5/ja/System.Runtime.Extensions.xml", + "ref/netstandard1.5/ko/System.Runtime.Extensions.xml", + "ref/netstandard1.5/ru/System.Runtime.Extensions.xml", + "ref/netstandard1.5/zh-hans/System.Runtime.Extensions.xml", + "ref/netstandard1.5/zh-hant/System.Runtime.Extensions.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.runtime.extensions.4.3.0.nupkg.sha512", + "system.runtime.extensions.nuspec" + ] + }, + "System.Runtime.Handles/4.3.0": { + "sha512": "OKiSUN7DmTWeYb3l51A7EYaeNMnvxwE249YtZz7yooT4gOZhmTjIn48KgSsw2k2lYdLgTKNJw/ZIfSElwDRVgg==", + "type": "package", + "path": "system.runtime.handles/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/_._", + "ref/netstandard1.3/System.Runtime.Handles.dll", + "ref/netstandard1.3/System.Runtime.Handles.xml", + "ref/netstandard1.3/de/System.Runtime.Handles.xml", + "ref/netstandard1.3/es/System.Runtime.Handles.xml", + "ref/netstandard1.3/fr/System.Runtime.Handles.xml", + "ref/netstandard1.3/it/System.Runtime.Handles.xml", + "ref/netstandard1.3/ja/System.Runtime.Handles.xml", + "ref/netstandard1.3/ko/System.Runtime.Handles.xml", + "ref/netstandard1.3/ru/System.Runtime.Handles.xml", + "ref/netstandard1.3/zh-hans/System.Runtime.Handles.xml", + "ref/netstandard1.3/zh-hant/System.Runtime.Handles.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.runtime.handles.4.3.0.nupkg.sha512", + "system.runtime.handles.nuspec" + ] + }, + "System.Runtime.InteropServices/4.3.0": { + "sha512": "uv1ynXqiMK8mp1GM3jDqPCFN66eJ5w5XNomaK2XD+TuCroNTLFGeZ+WCmBMcBDyTFKou3P6cR6J/QsaqDp7fGQ==", + "type": "package", + "path": "system.runtime.interopservices/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/net462/System.Runtime.InteropServices.dll", + "lib/net463/System.Runtime.InteropServices.dll", + "lib/portable-net45+win8+wpa81/_._", + "lib/win8/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/net462/System.Runtime.InteropServices.dll", + "ref/net463/System.Runtime.InteropServices.dll", + "ref/netcore50/System.Runtime.InteropServices.dll", + "ref/netcore50/System.Runtime.InteropServices.xml", + "ref/netcore50/de/System.Runtime.InteropServices.xml", + "ref/netcore50/es/System.Runtime.InteropServices.xml", + "ref/netcore50/fr/System.Runtime.InteropServices.xml", + "ref/netcore50/it/System.Runtime.InteropServices.xml", + "ref/netcore50/ja/System.Runtime.InteropServices.xml", + "ref/netcore50/ko/System.Runtime.InteropServices.xml", + "ref/netcore50/ru/System.Runtime.InteropServices.xml", + "ref/netcore50/zh-hans/System.Runtime.InteropServices.xml", + "ref/netcore50/zh-hant/System.Runtime.InteropServices.xml", + "ref/netcoreapp1.1/System.Runtime.InteropServices.dll", + "ref/netstandard1.1/System.Runtime.InteropServices.dll", + "ref/netstandard1.1/System.Runtime.InteropServices.xml", + "ref/netstandard1.1/de/System.Runtime.InteropServices.xml", + "ref/netstandard1.1/es/System.Runtime.InteropServices.xml", + "ref/netstandard1.1/fr/System.Runtime.InteropServices.xml", + "ref/netstandard1.1/it/System.Runtime.InteropServices.xml", + "ref/netstandard1.1/ja/System.Runtime.InteropServices.xml", + "ref/netstandard1.1/ko/System.Runtime.InteropServices.xml", + "ref/netstandard1.1/ru/System.Runtime.InteropServices.xml", + "ref/netstandard1.1/zh-hans/System.Runtime.InteropServices.xml", + "ref/netstandard1.1/zh-hant/System.Runtime.InteropServices.xml", + "ref/netstandard1.2/System.Runtime.InteropServices.dll", + "ref/netstandard1.2/System.Runtime.InteropServices.xml", + "ref/netstandard1.2/de/System.Runtime.InteropServices.xml", + "ref/netstandard1.2/es/System.Runtime.InteropServices.xml", + "ref/netstandard1.2/fr/System.Runtime.InteropServices.xml", + "ref/netstandard1.2/it/System.Runtime.InteropServices.xml", + "ref/netstandard1.2/ja/System.Runtime.InteropServices.xml", + "ref/netstandard1.2/ko/System.Runtime.InteropServices.xml", + "ref/netstandard1.2/ru/System.Runtime.InteropServices.xml", + "ref/netstandard1.2/zh-hans/System.Runtime.InteropServices.xml", + "ref/netstandard1.2/zh-hant/System.Runtime.InteropServices.xml", + "ref/netstandard1.3/System.Runtime.InteropServices.dll", + "ref/netstandard1.3/System.Runtime.InteropServices.xml", + "ref/netstandard1.3/de/System.Runtime.InteropServices.xml", + "ref/netstandard1.3/es/System.Runtime.InteropServices.xml", + "ref/netstandard1.3/fr/System.Runtime.InteropServices.xml", + "ref/netstandard1.3/it/System.Runtime.InteropServices.xml", + "ref/netstandard1.3/ja/System.Runtime.InteropServices.xml", + "ref/netstandard1.3/ko/System.Runtime.InteropServices.xml", + "ref/netstandard1.3/ru/System.Runtime.InteropServices.xml", + "ref/netstandard1.3/zh-hans/System.Runtime.InteropServices.xml", + "ref/netstandard1.3/zh-hant/System.Runtime.InteropServices.xml", + "ref/netstandard1.5/System.Runtime.InteropServices.dll", + "ref/netstandard1.5/System.Runtime.InteropServices.xml", + "ref/netstandard1.5/de/System.Runtime.InteropServices.xml", + "ref/netstandard1.5/es/System.Runtime.InteropServices.xml", + "ref/netstandard1.5/fr/System.Runtime.InteropServices.xml", + "ref/netstandard1.5/it/System.Runtime.InteropServices.xml", + "ref/netstandard1.5/ja/System.Runtime.InteropServices.xml", + "ref/netstandard1.5/ko/System.Runtime.InteropServices.xml", + "ref/netstandard1.5/ru/System.Runtime.InteropServices.xml", + "ref/netstandard1.5/zh-hans/System.Runtime.InteropServices.xml", + "ref/netstandard1.5/zh-hant/System.Runtime.InteropServices.xml", + "ref/portable-net45+win8+wpa81/_._", + "ref/win8/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.runtime.interopservices.4.3.0.nupkg.sha512", + "system.runtime.interopservices.nuspec" + ] + }, + "System.Runtime.InteropServices.RuntimeInformation/4.3.0": { + "sha512": "cbz4YJMqRDR7oLeMRbdYv7mYzc++17lNhScCX0goO2XpGWdvAt60CGN+FHdePUEHCe/Jy9jUlvNAiNdM+7jsOw==", + "type": "package", + "path": "system.runtime.interopservices.runtimeinformation/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/System.Runtime.InteropServices.RuntimeInformation.dll", + "lib/netstandard1.1/System.Runtime.InteropServices.RuntimeInformation.dll", + "lib/win8/System.Runtime.InteropServices.RuntimeInformation.dll", + "lib/wpa81/System.Runtime.InteropServices.RuntimeInformation.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/netstandard1.1/System.Runtime.InteropServices.RuntimeInformation.dll", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/aot/lib/netcore50/System.Runtime.InteropServices.RuntimeInformation.dll", + "runtimes/unix/lib/netstandard1.1/System.Runtime.InteropServices.RuntimeInformation.dll", + "runtimes/win/lib/net45/System.Runtime.InteropServices.RuntimeInformation.dll", + "runtimes/win/lib/netcore50/System.Runtime.InteropServices.RuntimeInformation.dll", + "runtimes/win/lib/netstandard1.1/System.Runtime.InteropServices.RuntimeInformation.dll", + "system.runtime.interopservices.runtimeinformation.4.3.0.nupkg.sha512", + "system.runtime.interopservices.runtimeinformation.nuspec" + ] + }, + "System.Runtime.Numerics/4.3.0": { + "sha512": "yMH+MfdzHjy17l2KESnPiF2dwq7T+xLnSJar7slyimAkUh/gTrS9/UQOtv7xarskJ2/XDSNvfLGOBQPjL7PaHQ==", + "type": "package", + "path": "system.runtime.numerics/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/netcore50/System.Runtime.Numerics.dll", + "lib/netstandard1.3/System.Runtime.Numerics.dll", + "lib/portable-net45+win8+wpa81/_._", + "lib/win8/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Runtime.Numerics.dll", + "ref/netcore50/System.Runtime.Numerics.xml", + "ref/netcore50/de/System.Runtime.Numerics.xml", + "ref/netcore50/es/System.Runtime.Numerics.xml", + "ref/netcore50/fr/System.Runtime.Numerics.xml", + "ref/netcore50/it/System.Runtime.Numerics.xml", + "ref/netcore50/ja/System.Runtime.Numerics.xml", + "ref/netcore50/ko/System.Runtime.Numerics.xml", + "ref/netcore50/ru/System.Runtime.Numerics.xml", + "ref/netcore50/zh-hans/System.Runtime.Numerics.xml", + "ref/netcore50/zh-hant/System.Runtime.Numerics.xml", + "ref/netstandard1.1/System.Runtime.Numerics.dll", + "ref/netstandard1.1/System.Runtime.Numerics.xml", + "ref/netstandard1.1/de/System.Runtime.Numerics.xml", + "ref/netstandard1.1/es/System.Runtime.Numerics.xml", + "ref/netstandard1.1/fr/System.Runtime.Numerics.xml", + "ref/netstandard1.1/it/System.Runtime.Numerics.xml", + "ref/netstandard1.1/ja/System.Runtime.Numerics.xml", + "ref/netstandard1.1/ko/System.Runtime.Numerics.xml", + "ref/netstandard1.1/ru/System.Runtime.Numerics.xml", + "ref/netstandard1.1/zh-hans/System.Runtime.Numerics.xml", + "ref/netstandard1.1/zh-hant/System.Runtime.Numerics.xml", + "ref/portable-net45+win8+wpa81/_._", + "ref/win8/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.runtime.numerics.4.3.0.nupkg.sha512", + "system.runtime.numerics.nuspec" + ] + }, + "System.Runtime.Serialization.Formatters/4.3.0": { + "sha512": "KT591AkTNFOTbhZlaeMVvfax3RqhH1EJlcwF50Wm7sfnBLuHiOeZRRKrr1ns3NESkM20KPZ5Ol/ueMq5vg4QoQ==", + "type": "package", + "path": "system.runtime.serialization.formatters/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.Runtime.Serialization.Formatters.dll", + "lib/netstandard1.4/System.Runtime.Serialization.Formatters.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.Runtime.Serialization.Formatters.dll", + "ref/netstandard1.3/System.Runtime.Serialization.Formatters.dll", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.runtime.serialization.formatters.4.3.0.nupkg.sha512", + "system.runtime.serialization.formatters.nuspec" + ] + }, + "System.Runtime.Serialization.Primitives/4.3.0": { + "sha512": "Wz+0KOukJGAlXjtKr+5Xpuxf8+c8739RI1C+A2BoQZT+wMCCoMDDdO8/4IRHfaVINqL78GO8dW8G2lW/e45Mcw==", + "type": "package", + "path": "system.runtime.serialization.primitives/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/net46/System.Runtime.Serialization.Primitives.dll", + "lib/netcore50/System.Runtime.Serialization.Primitives.dll", + "lib/netstandard1.3/System.Runtime.Serialization.Primitives.dll", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/net46/System.Runtime.Serialization.Primitives.dll", + "ref/netcore50/System.Runtime.Serialization.Primitives.dll", + "ref/netcore50/System.Runtime.Serialization.Primitives.xml", + "ref/netcore50/de/System.Runtime.Serialization.Primitives.xml", + "ref/netcore50/es/System.Runtime.Serialization.Primitives.xml", + "ref/netcore50/fr/System.Runtime.Serialization.Primitives.xml", + "ref/netcore50/it/System.Runtime.Serialization.Primitives.xml", + "ref/netcore50/ja/System.Runtime.Serialization.Primitives.xml", + "ref/netcore50/ko/System.Runtime.Serialization.Primitives.xml", + "ref/netcore50/ru/System.Runtime.Serialization.Primitives.xml", + "ref/netcore50/zh-hans/System.Runtime.Serialization.Primitives.xml", + "ref/netcore50/zh-hant/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.0/System.Runtime.Serialization.Primitives.dll", + "ref/netstandard1.0/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.0/de/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.0/es/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.0/fr/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.0/it/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.0/ja/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.0/ko/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.0/ru/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.0/zh-hans/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.0/zh-hant/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.3/System.Runtime.Serialization.Primitives.dll", + "ref/netstandard1.3/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.3/de/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.3/es/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.3/fr/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.3/it/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.3/ja/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.3/ko/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.3/ru/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.3/zh-hans/System.Runtime.Serialization.Primitives.xml", + "ref/netstandard1.3/zh-hant/System.Runtime.Serialization.Primitives.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/aot/lib/netcore50/System.Runtime.Serialization.Primitives.dll", + "system.runtime.serialization.primitives.4.3.0.nupkg.sha512", + "system.runtime.serialization.primitives.nuspec" + ] + }, + "System.Security.Cryptography.Algorithms/4.3.0": { + "sha512": "W1kd2Y8mYSCgc3ULTAZ0hOP2dSdG5YauTb1089T0/kRcN2MpSAW1izOFROrJgxSlMn3ArsgHXagigyi+ibhevg==", + "type": "package", + "path": "system.security.cryptography.algorithms/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.Security.Cryptography.Algorithms.dll", + "lib/net461/System.Security.Cryptography.Algorithms.dll", + "lib/net463/System.Security.Cryptography.Algorithms.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.Security.Cryptography.Algorithms.dll", + "ref/net461/System.Security.Cryptography.Algorithms.dll", + "ref/net463/System.Security.Cryptography.Algorithms.dll", + "ref/netstandard1.3/System.Security.Cryptography.Algorithms.dll", + "ref/netstandard1.4/System.Security.Cryptography.Algorithms.dll", + "ref/netstandard1.6/System.Security.Cryptography.Algorithms.dll", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/osx/lib/netstandard1.6/System.Security.Cryptography.Algorithms.dll", + "runtimes/unix/lib/netstandard1.6/System.Security.Cryptography.Algorithms.dll", + "runtimes/win/lib/net46/System.Security.Cryptography.Algorithms.dll", + "runtimes/win/lib/net461/System.Security.Cryptography.Algorithms.dll", + "runtimes/win/lib/net463/System.Security.Cryptography.Algorithms.dll", + "runtimes/win/lib/netcore50/System.Security.Cryptography.Algorithms.dll", + "runtimes/win/lib/netstandard1.6/System.Security.Cryptography.Algorithms.dll", + "system.security.cryptography.algorithms.4.3.0.nupkg.sha512", + "system.security.cryptography.algorithms.nuspec" + ] + }, + "System.Security.Cryptography.Cng/4.3.0": { + "sha512": "03idZOqFlsKRL4W+LuCpJ6dBYDUWReug6lZjBa3uJWnk5sPCUXckocevTaUA8iT/MFSrY/2HXkOt753xQ/cf8g==", + "type": "package", + "path": "system.security.cryptography.cng/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/net46/System.Security.Cryptography.Cng.dll", + "lib/net461/System.Security.Cryptography.Cng.dll", + "lib/net463/System.Security.Cryptography.Cng.dll", + "ref/net46/System.Security.Cryptography.Cng.dll", + "ref/net461/System.Security.Cryptography.Cng.dll", + "ref/net463/System.Security.Cryptography.Cng.dll", + "ref/netstandard1.3/System.Security.Cryptography.Cng.dll", + "ref/netstandard1.4/System.Security.Cryptography.Cng.dll", + "ref/netstandard1.6/System.Security.Cryptography.Cng.dll", + "runtimes/unix/lib/netstandard1.6/System.Security.Cryptography.Cng.dll", + "runtimes/win/lib/net46/System.Security.Cryptography.Cng.dll", + "runtimes/win/lib/net461/System.Security.Cryptography.Cng.dll", + "runtimes/win/lib/net463/System.Security.Cryptography.Cng.dll", + "runtimes/win/lib/netstandard1.4/System.Security.Cryptography.Cng.dll", + "runtimes/win/lib/netstandard1.6/System.Security.Cryptography.Cng.dll", + "system.security.cryptography.cng.4.3.0.nupkg.sha512", + "system.security.cryptography.cng.nuspec" + ] + }, + "System.Security.Cryptography.Csp/4.3.0": { + "sha512": "X4s/FCkEUnRGnwR3aSfVIkldBmtURMhmexALNTwpjklzxWU7yjMk7GHLKOZTNkgnWnE0q7+BCf9N2LVRWxewaA==", + "type": "package", + "path": "system.security.cryptography.csp/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.Security.Cryptography.Csp.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.Security.Cryptography.Csp.dll", + "ref/netstandard1.3/System.Security.Cryptography.Csp.dll", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/unix/lib/netstandard1.3/System.Security.Cryptography.Csp.dll", + "runtimes/win/lib/net46/System.Security.Cryptography.Csp.dll", + "runtimes/win/lib/netcore50/_._", + "runtimes/win/lib/netstandard1.3/System.Security.Cryptography.Csp.dll", + "system.security.cryptography.csp.4.3.0.nupkg.sha512", + "system.security.cryptography.csp.nuspec" + ] + }, + "System.Security.Cryptography.Encoding/4.3.0": { + "sha512": "1DEWjZZly9ae9C79vFwqaO5kaOlI5q+3/55ohmq/7dpDyDfc8lYe7YVxJUZ5MF/NtbkRjwFRo14yM4OEo9EmDw==", + "type": "package", + "path": "system.security.cryptography.encoding/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.Security.Cryptography.Encoding.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.Security.Cryptography.Encoding.dll", + "ref/netstandard1.3/System.Security.Cryptography.Encoding.dll", + "ref/netstandard1.3/System.Security.Cryptography.Encoding.xml", + "ref/netstandard1.3/de/System.Security.Cryptography.Encoding.xml", + "ref/netstandard1.3/es/System.Security.Cryptography.Encoding.xml", + "ref/netstandard1.3/fr/System.Security.Cryptography.Encoding.xml", + "ref/netstandard1.3/it/System.Security.Cryptography.Encoding.xml", + "ref/netstandard1.3/ja/System.Security.Cryptography.Encoding.xml", + "ref/netstandard1.3/ko/System.Security.Cryptography.Encoding.xml", + "ref/netstandard1.3/ru/System.Security.Cryptography.Encoding.xml", + "ref/netstandard1.3/zh-hans/System.Security.Cryptography.Encoding.xml", + "ref/netstandard1.3/zh-hant/System.Security.Cryptography.Encoding.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/unix/lib/netstandard1.3/System.Security.Cryptography.Encoding.dll", + "runtimes/win/lib/net46/System.Security.Cryptography.Encoding.dll", + "runtimes/win/lib/netstandard1.3/System.Security.Cryptography.Encoding.dll", + "system.security.cryptography.encoding.4.3.0.nupkg.sha512", + "system.security.cryptography.encoding.nuspec" + ] + }, + "System.Security.Cryptography.OpenSsl/4.3.0": { + "sha512": "h4CEgOgv5PKVF/HwaHzJRiVboL2THYCou97zpmhjghx5frc7fIvlkY1jL+lnIQyChrJDMNEXS6r7byGif8Cy4w==", + "type": "package", + "path": "system.security.cryptography.openssl/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/netstandard1.6/System.Security.Cryptography.OpenSsl.dll", + "ref/netstandard1.6/System.Security.Cryptography.OpenSsl.dll", + "runtimes/unix/lib/netstandard1.6/System.Security.Cryptography.OpenSsl.dll", + "system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "system.security.cryptography.openssl.nuspec" + ] + }, + "System.Security.Cryptography.Primitives/4.3.0": { + "sha512": "7bDIyVFNL/xKeFHjhobUAQqSpJq9YTOpbEs6mR233Et01STBMXNAc/V+BM6dwYGc95gVh/Zf+iVXWzj3mE8DWg==", + "type": "package", + "path": "system.security.cryptography.primitives/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.Security.Cryptography.Primitives.dll", + "lib/netstandard1.3/System.Security.Cryptography.Primitives.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.Security.Cryptography.Primitives.dll", + "ref/netstandard1.3/System.Security.Cryptography.Primitives.dll", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.security.cryptography.primitives.4.3.0.nupkg.sha512", + "system.security.cryptography.primitives.nuspec" + ] + }, + "System.Security.Cryptography.X509Certificates/4.3.0": { + "sha512": "t2Tmu6Y2NtJ2um0RtcuhP7ZdNNxXEgUm2JeoA/0NvlMjAhKCnM1NX07TDl3244mVp3QU6LPEhT3HTtH1uF7IYw==", + "type": "package", + "path": "system.security.cryptography.x509certificates/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.Security.Cryptography.X509Certificates.dll", + "lib/net461/System.Security.Cryptography.X509Certificates.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.Security.Cryptography.X509Certificates.dll", + "ref/net461/System.Security.Cryptography.X509Certificates.dll", + "ref/netstandard1.3/System.Security.Cryptography.X509Certificates.dll", + "ref/netstandard1.3/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.3/de/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.3/es/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.3/fr/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.3/it/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.3/ja/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.3/ko/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.3/ru/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.3/zh-hans/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.3/zh-hant/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.4/System.Security.Cryptography.X509Certificates.dll", + "ref/netstandard1.4/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.4/de/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.4/es/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.4/fr/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.4/it/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.4/ja/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.4/ko/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.4/ru/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.4/zh-hans/System.Security.Cryptography.X509Certificates.xml", + "ref/netstandard1.4/zh-hant/System.Security.Cryptography.X509Certificates.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/unix/lib/netstandard1.6/System.Security.Cryptography.X509Certificates.dll", + "runtimes/win/lib/net46/System.Security.Cryptography.X509Certificates.dll", + "runtimes/win/lib/net461/System.Security.Cryptography.X509Certificates.dll", + "runtimes/win/lib/netcore50/System.Security.Cryptography.X509Certificates.dll", + "runtimes/win/lib/netstandard1.6/System.Security.Cryptography.X509Certificates.dll", + "system.security.cryptography.x509certificates.4.3.0.nupkg.sha512", + "system.security.cryptography.x509certificates.nuspec" + ] + }, + "System.Text.Encoding/4.3.0": { + "sha512": "BiIg+KWaSDOITze6jGQynxg64naAPtqGHBwDrLaCtixsa5bKiR8dpPOHA7ge3C0JJQizJE+sfkz1wV+BAKAYZw==", + "type": "package", + "path": "system.text.encoding/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Text.Encoding.dll", + "ref/netcore50/System.Text.Encoding.xml", + "ref/netcore50/de/System.Text.Encoding.xml", + "ref/netcore50/es/System.Text.Encoding.xml", + "ref/netcore50/fr/System.Text.Encoding.xml", + "ref/netcore50/it/System.Text.Encoding.xml", + "ref/netcore50/ja/System.Text.Encoding.xml", + "ref/netcore50/ko/System.Text.Encoding.xml", + "ref/netcore50/ru/System.Text.Encoding.xml", + "ref/netcore50/zh-hans/System.Text.Encoding.xml", + "ref/netcore50/zh-hant/System.Text.Encoding.xml", + "ref/netstandard1.0/System.Text.Encoding.dll", + "ref/netstandard1.0/System.Text.Encoding.xml", + "ref/netstandard1.0/de/System.Text.Encoding.xml", + "ref/netstandard1.0/es/System.Text.Encoding.xml", + "ref/netstandard1.0/fr/System.Text.Encoding.xml", + "ref/netstandard1.0/it/System.Text.Encoding.xml", + "ref/netstandard1.0/ja/System.Text.Encoding.xml", + "ref/netstandard1.0/ko/System.Text.Encoding.xml", + "ref/netstandard1.0/ru/System.Text.Encoding.xml", + "ref/netstandard1.0/zh-hans/System.Text.Encoding.xml", + "ref/netstandard1.0/zh-hant/System.Text.Encoding.xml", + "ref/netstandard1.3/System.Text.Encoding.dll", + "ref/netstandard1.3/System.Text.Encoding.xml", + "ref/netstandard1.3/de/System.Text.Encoding.xml", + "ref/netstandard1.3/es/System.Text.Encoding.xml", + "ref/netstandard1.3/fr/System.Text.Encoding.xml", + "ref/netstandard1.3/it/System.Text.Encoding.xml", + "ref/netstandard1.3/ja/System.Text.Encoding.xml", + "ref/netstandard1.3/ko/System.Text.Encoding.xml", + "ref/netstandard1.3/ru/System.Text.Encoding.xml", + "ref/netstandard1.3/zh-hans/System.Text.Encoding.xml", + "ref/netstandard1.3/zh-hant/System.Text.Encoding.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.text.encoding.4.3.0.nupkg.sha512", + "system.text.encoding.nuspec" + ] + }, + "System.Text.Encoding.CodePages/4.5.1": { + "sha512": "4J2JQXbftjPMppIHJ7IC+VXQ9XfEagN92vZZNoG12i+zReYlim5dMoXFC1Zzg7tsnKDM7JPo5bYfFK4Jheq44w==", + "type": "package", + "path": "system.text.encoding.codepages/4.5.1", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "LICENSE.TXT", + "THIRD-PARTY-NOTICES.TXT", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.Text.Encoding.CodePages.dll", + "lib/net461/System.Text.Encoding.CodePages.dll", + "lib/netstandard1.3/System.Text.Encoding.CodePages.dll", + "lib/netstandard2.0/System.Text.Encoding.CodePages.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/win/lib/net461/System.Text.Encoding.CodePages.dll", + "runtimes/win/lib/netcoreapp2.0/System.Text.Encoding.CodePages.dll", + "runtimes/win/lib/netstandard1.3/System.Text.Encoding.CodePages.dll", + "runtimes/win/lib/netstandard2.0/System.Text.Encoding.CodePages.dll", + "system.text.encoding.codepages.4.5.1.nupkg.sha512", + "system.text.encoding.codepages.nuspec", + "useSharedDesignerContext.txt", + "version.txt" + ] + }, + "System.Text.Encoding.Extensions/4.3.0": { + "sha512": "YVMK0Bt/A43RmwizJoZ22ei2nmrhobgeiYwFzC4YAN+nue8RF6djXDMog0UCn+brerQoYVyaS+ghy9P/MUVcmw==", + "type": "package", + "path": "system.text.encoding.extensions/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Text.Encoding.Extensions.dll", + "ref/netcore50/System.Text.Encoding.Extensions.xml", + "ref/netcore50/de/System.Text.Encoding.Extensions.xml", + "ref/netcore50/es/System.Text.Encoding.Extensions.xml", + "ref/netcore50/fr/System.Text.Encoding.Extensions.xml", + "ref/netcore50/it/System.Text.Encoding.Extensions.xml", + "ref/netcore50/ja/System.Text.Encoding.Extensions.xml", + "ref/netcore50/ko/System.Text.Encoding.Extensions.xml", + "ref/netcore50/ru/System.Text.Encoding.Extensions.xml", + "ref/netcore50/zh-hans/System.Text.Encoding.Extensions.xml", + "ref/netcore50/zh-hant/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.0/System.Text.Encoding.Extensions.dll", + "ref/netstandard1.0/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.0/de/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.0/es/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.0/fr/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.0/it/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.0/ja/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.0/ko/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.0/ru/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.0/zh-hans/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.0/zh-hant/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.3/System.Text.Encoding.Extensions.dll", + "ref/netstandard1.3/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.3/de/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.3/es/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.3/fr/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.3/it/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.3/ja/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.3/ko/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.3/ru/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.3/zh-hans/System.Text.Encoding.Extensions.xml", + "ref/netstandard1.3/zh-hant/System.Text.Encoding.Extensions.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.text.encoding.extensions.4.3.0.nupkg.sha512", + "system.text.encoding.extensions.nuspec" + ] + }, + "System.Text.RegularExpressions/4.3.0": { + "sha512": "RpT2DA+L660cBt1FssIE9CAGpLFdFPuheB7pLpKpn6ZXNby7jDERe8Ua/Ne2xGiwLVG2JOqziiaVCGDon5sKFA==", + "type": "package", + "path": "system.text.regularexpressions/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/net463/System.Text.RegularExpressions.dll", + "lib/netcore50/System.Text.RegularExpressions.dll", + "lib/netstandard1.6/System.Text.RegularExpressions.dll", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/net463/System.Text.RegularExpressions.dll", + "ref/netcore50/System.Text.RegularExpressions.dll", + "ref/netcore50/System.Text.RegularExpressions.xml", + "ref/netcore50/de/System.Text.RegularExpressions.xml", + "ref/netcore50/es/System.Text.RegularExpressions.xml", + "ref/netcore50/fr/System.Text.RegularExpressions.xml", + "ref/netcore50/it/System.Text.RegularExpressions.xml", + "ref/netcore50/ja/System.Text.RegularExpressions.xml", + "ref/netcore50/ko/System.Text.RegularExpressions.xml", + "ref/netcore50/ru/System.Text.RegularExpressions.xml", + "ref/netcore50/zh-hans/System.Text.RegularExpressions.xml", + "ref/netcore50/zh-hant/System.Text.RegularExpressions.xml", + "ref/netcoreapp1.1/System.Text.RegularExpressions.dll", + "ref/netstandard1.0/System.Text.RegularExpressions.dll", + "ref/netstandard1.0/System.Text.RegularExpressions.xml", + "ref/netstandard1.0/de/System.Text.RegularExpressions.xml", + "ref/netstandard1.0/es/System.Text.RegularExpressions.xml", + "ref/netstandard1.0/fr/System.Text.RegularExpressions.xml", + "ref/netstandard1.0/it/System.Text.RegularExpressions.xml", + "ref/netstandard1.0/ja/System.Text.RegularExpressions.xml", + "ref/netstandard1.0/ko/System.Text.RegularExpressions.xml", + "ref/netstandard1.0/ru/System.Text.RegularExpressions.xml", + "ref/netstandard1.0/zh-hans/System.Text.RegularExpressions.xml", + "ref/netstandard1.0/zh-hant/System.Text.RegularExpressions.xml", + "ref/netstandard1.3/System.Text.RegularExpressions.dll", + "ref/netstandard1.3/System.Text.RegularExpressions.xml", + "ref/netstandard1.3/de/System.Text.RegularExpressions.xml", + "ref/netstandard1.3/es/System.Text.RegularExpressions.xml", + "ref/netstandard1.3/fr/System.Text.RegularExpressions.xml", + "ref/netstandard1.3/it/System.Text.RegularExpressions.xml", + "ref/netstandard1.3/ja/System.Text.RegularExpressions.xml", + "ref/netstandard1.3/ko/System.Text.RegularExpressions.xml", + "ref/netstandard1.3/ru/System.Text.RegularExpressions.xml", + "ref/netstandard1.3/zh-hans/System.Text.RegularExpressions.xml", + "ref/netstandard1.3/zh-hant/System.Text.RegularExpressions.xml", + "ref/netstandard1.6/System.Text.RegularExpressions.dll", + "ref/netstandard1.6/System.Text.RegularExpressions.xml", + "ref/netstandard1.6/de/System.Text.RegularExpressions.xml", + "ref/netstandard1.6/es/System.Text.RegularExpressions.xml", + "ref/netstandard1.6/fr/System.Text.RegularExpressions.xml", + "ref/netstandard1.6/it/System.Text.RegularExpressions.xml", + "ref/netstandard1.6/ja/System.Text.RegularExpressions.xml", + "ref/netstandard1.6/ko/System.Text.RegularExpressions.xml", + "ref/netstandard1.6/ru/System.Text.RegularExpressions.xml", + "ref/netstandard1.6/zh-hans/System.Text.RegularExpressions.xml", + "ref/netstandard1.6/zh-hant/System.Text.RegularExpressions.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.text.regularexpressions.4.3.0.nupkg.sha512", + "system.text.regularexpressions.nuspec" + ] + }, + "System.Threading/4.3.0": { + "sha512": "VkUS0kOBcUf3Wwm0TSbrevDDZ6BlM+b/HRiapRFWjM5O0NS0LviG0glKmFK+hhPDd1XFeSdU1GmlLhb2CoVpIw==", + "type": "package", + "path": "system.threading/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/netcore50/System.Threading.dll", + "lib/netstandard1.3/System.Threading.dll", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Threading.dll", + "ref/netcore50/System.Threading.xml", + "ref/netcore50/de/System.Threading.xml", + "ref/netcore50/es/System.Threading.xml", + "ref/netcore50/fr/System.Threading.xml", + "ref/netcore50/it/System.Threading.xml", + "ref/netcore50/ja/System.Threading.xml", + "ref/netcore50/ko/System.Threading.xml", + "ref/netcore50/ru/System.Threading.xml", + "ref/netcore50/zh-hans/System.Threading.xml", + "ref/netcore50/zh-hant/System.Threading.xml", + "ref/netstandard1.0/System.Threading.dll", + "ref/netstandard1.0/System.Threading.xml", + "ref/netstandard1.0/de/System.Threading.xml", + "ref/netstandard1.0/es/System.Threading.xml", + "ref/netstandard1.0/fr/System.Threading.xml", + "ref/netstandard1.0/it/System.Threading.xml", + "ref/netstandard1.0/ja/System.Threading.xml", + "ref/netstandard1.0/ko/System.Threading.xml", + "ref/netstandard1.0/ru/System.Threading.xml", + "ref/netstandard1.0/zh-hans/System.Threading.xml", + "ref/netstandard1.0/zh-hant/System.Threading.xml", + "ref/netstandard1.3/System.Threading.dll", + "ref/netstandard1.3/System.Threading.xml", + "ref/netstandard1.3/de/System.Threading.xml", + "ref/netstandard1.3/es/System.Threading.xml", + "ref/netstandard1.3/fr/System.Threading.xml", + "ref/netstandard1.3/it/System.Threading.xml", + "ref/netstandard1.3/ja/System.Threading.xml", + "ref/netstandard1.3/ko/System.Threading.xml", + "ref/netstandard1.3/ru/System.Threading.xml", + "ref/netstandard1.3/zh-hans/System.Threading.xml", + "ref/netstandard1.3/zh-hant/System.Threading.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "runtimes/aot/lib/netcore50/System.Threading.dll", + "system.threading.4.3.0.nupkg.sha512", + "system.threading.nuspec" + ] + }, + "System.Threading.Tasks/4.3.0": { + "sha512": "LbSxKEdOUhVe8BezB/9uOGGppt+nZf6e1VFyw6v3DN6lqitm0OSn2uXMOdtP0M3W4iMcqcivm2J6UgqiwwnXiA==", + "type": "package", + "path": "system.threading.tasks/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Threading.Tasks.dll", + "ref/netcore50/System.Threading.Tasks.xml", + "ref/netcore50/de/System.Threading.Tasks.xml", + "ref/netcore50/es/System.Threading.Tasks.xml", + "ref/netcore50/fr/System.Threading.Tasks.xml", + "ref/netcore50/it/System.Threading.Tasks.xml", + "ref/netcore50/ja/System.Threading.Tasks.xml", + "ref/netcore50/ko/System.Threading.Tasks.xml", + "ref/netcore50/ru/System.Threading.Tasks.xml", + "ref/netcore50/zh-hans/System.Threading.Tasks.xml", + "ref/netcore50/zh-hant/System.Threading.Tasks.xml", + "ref/netstandard1.0/System.Threading.Tasks.dll", + "ref/netstandard1.0/System.Threading.Tasks.xml", + "ref/netstandard1.0/de/System.Threading.Tasks.xml", + "ref/netstandard1.0/es/System.Threading.Tasks.xml", + "ref/netstandard1.0/fr/System.Threading.Tasks.xml", + "ref/netstandard1.0/it/System.Threading.Tasks.xml", + "ref/netstandard1.0/ja/System.Threading.Tasks.xml", + "ref/netstandard1.0/ko/System.Threading.Tasks.xml", + "ref/netstandard1.0/ru/System.Threading.Tasks.xml", + "ref/netstandard1.0/zh-hans/System.Threading.Tasks.xml", + "ref/netstandard1.0/zh-hant/System.Threading.Tasks.xml", + "ref/netstandard1.3/System.Threading.Tasks.dll", + "ref/netstandard1.3/System.Threading.Tasks.xml", + "ref/netstandard1.3/de/System.Threading.Tasks.xml", + "ref/netstandard1.3/es/System.Threading.Tasks.xml", + "ref/netstandard1.3/fr/System.Threading.Tasks.xml", + "ref/netstandard1.3/it/System.Threading.Tasks.xml", + "ref/netstandard1.3/ja/System.Threading.Tasks.xml", + "ref/netstandard1.3/ko/System.Threading.Tasks.xml", + "ref/netstandard1.3/ru/System.Threading.Tasks.xml", + "ref/netstandard1.3/zh-hans/System.Threading.Tasks.xml", + "ref/netstandard1.3/zh-hant/System.Threading.Tasks.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.threading.tasks.4.3.0.nupkg.sha512", + "system.threading.tasks.nuspec" + ] + }, + "System.Threading.Tasks.Extensions/4.3.0": { + "sha512": "npvJkVKl5rKXrtl1Kkm6OhOUaYGEiF9wFbppFRWSMoApKzt2PiPHT2Bb8a5sAWxprvdOAtvaARS9QYMznEUtug==", + "type": "package", + "path": "system.threading.tasks.extensions/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/netstandard1.0/System.Threading.Tasks.Extensions.dll", + "lib/netstandard1.0/System.Threading.Tasks.Extensions.xml", + "lib/portable-net45+win8+wp8+wpa81/System.Threading.Tasks.Extensions.dll", + "lib/portable-net45+win8+wp8+wpa81/System.Threading.Tasks.Extensions.xml", + "system.threading.tasks.extensions.4.3.0.nupkg.sha512", + "system.threading.tasks.extensions.nuspec" + ] + }, + "System.Threading.Timer/4.3.0": { + "sha512": "Z6YfyYTCg7lOZjJzBjONJTFKGN9/NIYKSxhU5GRd+DTwHSZyvWp1xuI5aR+dLg+ayyC5Xv57KiY4oJ0tMO89fQ==", + "type": "package", + "path": "system.threading.timer/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net451/_._", + "lib/portable-net451+win81+wpa81/_._", + "lib/win81/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net451/_._", + "ref/netcore50/System.Threading.Timer.dll", + "ref/netcore50/System.Threading.Timer.xml", + "ref/netcore50/de/System.Threading.Timer.xml", + "ref/netcore50/es/System.Threading.Timer.xml", + "ref/netcore50/fr/System.Threading.Timer.xml", + "ref/netcore50/it/System.Threading.Timer.xml", + "ref/netcore50/ja/System.Threading.Timer.xml", + "ref/netcore50/ko/System.Threading.Timer.xml", + "ref/netcore50/ru/System.Threading.Timer.xml", + "ref/netcore50/zh-hans/System.Threading.Timer.xml", + "ref/netcore50/zh-hant/System.Threading.Timer.xml", + "ref/netstandard1.2/System.Threading.Timer.dll", + "ref/netstandard1.2/System.Threading.Timer.xml", + "ref/netstandard1.2/de/System.Threading.Timer.xml", + "ref/netstandard1.2/es/System.Threading.Timer.xml", + "ref/netstandard1.2/fr/System.Threading.Timer.xml", + "ref/netstandard1.2/it/System.Threading.Timer.xml", + "ref/netstandard1.2/ja/System.Threading.Timer.xml", + "ref/netstandard1.2/ko/System.Threading.Timer.xml", + "ref/netstandard1.2/ru/System.Threading.Timer.xml", + "ref/netstandard1.2/zh-hans/System.Threading.Timer.xml", + "ref/netstandard1.2/zh-hant/System.Threading.Timer.xml", + "ref/portable-net451+win81+wpa81/_._", + "ref/win81/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.threading.timer.4.3.0.nupkg.sha512", + "system.threading.timer.nuspec" + ] + }, + "System.Xml.ReaderWriter/4.3.0": { + "sha512": "GrprA+Z0RUXaR4N7/eW71j1rgMnEnEVlgii49GZyAjTH7uliMnrOU3HNFBr6fEDBCJCIdlVNq9hHbaDR621XBA==", + "type": "package", + "path": "system.xml.readerwriter/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/net46/System.Xml.ReaderWriter.dll", + "lib/netcore50/System.Xml.ReaderWriter.dll", + "lib/netstandard1.3/System.Xml.ReaderWriter.dll", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/net46/System.Xml.ReaderWriter.dll", + "ref/netcore50/System.Xml.ReaderWriter.dll", + "ref/netcore50/System.Xml.ReaderWriter.xml", + "ref/netcore50/de/System.Xml.ReaderWriter.xml", + "ref/netcore50/es/System.Xml.ReaderWriter.xml", + "ref/netcore50/fr/System.Xml.ReaderWriter.xml", + "ref/netcore50/it/System.Xml.ReaderWriter.xml", + "ref/netcore50/ja/System.Xml.ReaderWriter.xml", + "ref/netcore50/ko/System.Xml.ReaderWriter.xml", + "ref/netcore50/ru/System.Xml.ReaderWriter.xml", + "ref/netcore50/zh-hans/System.Xml.ReaderWriter.xml", + "ref/netcore50/zh-hant/System.Xml.ReaderWriter.xml", + "ref/netstandard1.0/System.Xml.ReaderWriter.dll", + "ref/netstandard1.0/System.Xml.ReaderWriter.xml", + "ref/netstandard1.0/de/System.Xml.ReaderWriter.xml", + "ref/netstandard1.0/es/System.Xml.ReaderWriter.xml", + "ref/netstandard1.0/fr/System.Xml.ReaderWriter.xml", + "ref/netstandard1.0/it/System.Xml.ReaderWriter.xml", + "ref/netstandard1.0/ja/System.Xml.ReaderWriter.xml", + "ref/netstandard1.0/ko/System.Xml.ReaderWriter.xml", + "ref/netstandard1.0/ru/System.Xml.ReaderWriter.xml", + "ref/netstandard1.0/zh-hans/System.Xml.ReaderWriter.xml", + "ref/netstandard1.0/zh-hant/System.Xml.ReaderWriter.xml", + "ref/netstandard1.3/System.Xml.ReaderWriter.dll", + "ref/netstandard1.3/System.Xml.ReaderWriter.xml", + "ref/netstandard1.3/de/System.Xml.ReaderWriter.xml", + "ref/netstandard1.3/es/System.Xml.ReaderWriter.xml", + "ref/netstandard1.3/fr/System.Xml.ReaderWriter.xml", + "ref/netstandard1.3/it/System.Xml.ReaderWriter.xml", + "ref/netstandard1.3/ja/System.Xml.ReaderWriter.xml", + "ref/netstandard1.3/ko/System.Xml.ReaderWriter.xml", + "ref/netstandard1.3/ru/System.Xml.ReaderWriter.xml", + "ref/netstandard1.3/zh-hans/System.Xml.ReaderWriter.xml", + "ref/netstandard1.3/zh-hant/System.Xml.ReaderWriter.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.xml.readerwriter.4.3.0.nupkg.sha512", + "system.xml.readerwriter.nuspec" + ] + }, + "System.Xml.XDocument/4.3.0": { + "sha512": "5zJ0XDxAIg8iy+t4aMnQAu0MqVbqyvfoUVl1yDV61xdo3Vth45oA2FoY4pPkxYAH5f8ixpmTqXeEIya95x0aCQ==", + "type": "package", + "path": "system.xml.xdocument/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net45/_._", + "lib/netcore50/System.Xml.XDocument.dll", + "lib/netstandard1.3/System.Xml.XDocument.dll", + "lib/portable-net45+win8+wp8+wpa81/_._", + "lib/win8/_._", + "lib/wp80/_._", + "lib/wpa81/_._", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net45/_._", + "ref/netcore50/System.Xml.XDocument.dll", + "ref/netcore50/System.Xml.XDocument.xml", + "ref/netcore50/de/System.Xml.XDocument.xml", + "ref/netcore50/es/System.Xml.XDocument.xml", + "ref/netcore50/fr/System.Xml.XDocument.xml", + "ref/netcore50/it/System.Xml.XDocument.xml", + "ref/netcore50/ja/System.Xml.XDocument.xml", + "ref/netcore50/ko/System.Xml.XDocument.xml", + "ref/netcore50/ru/System.Xml.XDocument.xml", + "ref/netcore50/zh-hans/System.Xml.XDocument.xml", + "ref/netcore50/zh-hant/System.Xml.XDocument.xml", + "ref/netstandard1.0/System.Xml.XDocument.dll", + "ref/netstandard1.0/System.Xml.XDocument.xml", + "ref/netstandard1.0/de/System.Xml.XDocument.xml", + "ref/netstandard1.0/es/System.Xml.XDocument.xml", + "ref/netstandard1.0/fr/System.Xml.XDocument.xml", + "ref/netstandard1.0/it/System.Xml.XDocument.xml", + "ref/netstandard1.0/ja/System.Xml.XDocument.xml", + "ref/netstandard1.0/ko/System.Xml.XDocument.xml", + "ref/netstandard1.0/ru/System.Xml.XDocument.xml", + "ref/netstandard1.0/zh-hans/System.Xml.XDocument.xml", + "ref/netstandard1.0/zh-hant/System.Xml.XDocument.xml", + "ref/netstandard1.3/System.Xml.XDocument.dll", + "ref/netstandard1.3/System.Xml.XDocument.xml", + "ref/netstandard1.3/de/System.Xml.XDocument.xml", + "ref/netstandard1.3/es/System.Xml.XDocument.xml", + "ref/netstandard1.3/fr/System.Xml.XDocument.xml", + "ref/netstandard1.3/it/System.Xml.XDocument.xml", + "ref/netstandard1.3/ja/System.Xml.XDocument.xml", + "ref/netstandard1.3/ko/System.Xml.XDocument.xml", + "ref/netstandard1.3/ru/System.Xml.XDocument.xml", + "ref/netstandard1.3/zh-hans/System.Xml.XDocument.xml", + "ref/netstandard1.3/zh-hant/System.Xml.XDocument.xml", + "ref/portable-net45+win8+wp8+wpa81/_._", + "ref/win8/_._", + "ref/wp80/_._", + "ref/wpa81/_._", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.xml.xdocument.4.3.0.nupkg.sha512", + "system.xml.xdocument.nuspec" + ] + }, + "System.Xml.XmlDocument/4.3.0": { + "sha512": "lJ8AxvkX7GQxpC6GFCeBj8ThYVyQczx2+f/cWHJU8tjS7YfI6Cv6bon70jVEgs2CiFbmmM8b9j1oZVx0dSI2Ww==", + "type": "package", + "path": "system.xml.xmldocument/4.3.0", + "files": [ + ".nupkg.metadata", + ".signature.p7s", + "ThirdPartyNotices.txt", + "dotnet_library_license.txt", + "lib/MonoAndroid10/_._", + "lib/MonoTouch10/_._", + "lib/net46/System.Xml.XmlDocument.dll", + "lib/netstandard1.3/System.Xml.XmlDocument.dll", + "lib/xamarinios10/_._", + "lib/xamarinmac20/_._", + "lib/xamarintvos10/_._", + "lib/xamarinwatchos10/_._", + "ref/MonoAndroid10/_._", + "ref/MonoTouch10/_._", + "ref/net46/System.Xml.XmlDocument.dll", + "ref/netstandard1.3/System.Xml.XmlDocument.dll", + "ref/netstandard1.3/System.Xml.XmlDocument.xml", + "ref/netstandard1.3/de/System.Xml.XmlDocument.xml", + "ref/netstandard1.3/es/System.Xml.XmlDocument.xml", + "ref/netstandard1.3/fr/System.Xml.XmlDocument.xml", + "ref/netstandard1.3/it/System.Xml.XmlDocument.xml", + "ref/netstandard1.3/ja/System.Xml.XmlDocument.xml", + "ref/netstandard1.3/ko/System.Xml.XmlDocument.xml", + "ref/netstandard1.3/ru/System.Xml.XmlDocument.xml", + "ref/netstandard1.3/zh-hans/System.Xml.XmlDocument.xml", + "ref/netstandard1.3/zh-hant/System.Xml.XmlDocument.xml", + "ref/xamarinios10/_._", + "ref/xamarinmac20/_._", + "ref/xamarintvos10/_._", + "ref/xamarinwatchos10/_._", + "system.xml.xmldocument.4.3.0.nupkg.sha512", + "system.xml.xmldocument.nuspec" + ] + } + }, + "projectFileDependencyGroups": { + "net5.0": [ + "Microsoft.AspNet.WebApi.Cors >= 5.2.7", + "MongoDB.Driver >= 2.13.2", + "Swashbuckle.AspNetCore >= 5.6.3" + ] + }, + "packageFolders": { + "/Users/hanieharabzadeh/.nuget/packages/": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/MongoBookApis.csproj", + "projectName": "MongoBookApis", + "projectPath": "/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/MongoBookApis.csproj", + "packagesPath": "/Users/hanieharabzadeh/.nuget/packages/", + "outputPath": "/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/obj/", + "projectStyle": "PackageReference", + "configFilePaths": [ + "/Users/hanieharabzadeh/.config/NuGet/NuGet.Config" + ], + "originalTargetFrameworks": [ + "net5.0" + ], + "sources": { + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net5.0": { + "targetAlias": "net5.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net5.0": { + "targetAlias": "net5.0", + "dependencies": { + "Microsoft.AspNet.WebApi.Cors": { + "target": "Package", + "version": "[5.2.7, )" + }, + "MongoDB.Driver": { + "target": "Package", + "version": "[2.13.2, )" + }, + "Swashbuckle.AspNetCore": { + "target": "Package", + "version": "[5.6.3, )" + } + }, + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.AspNetCore.App": { + "privateAssets": "none" + }, + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "/usr/local/share/dotnet/sdk/5.0.403/RuntimeIdentifierGraph.json" + } + } + }, + "logs": [ + { + "code": "NU1701", + "level": "Warning", + "warningLevel": 1, + "message": "Package 'Microsoft.AspNet.Cors 5.2.7' was restored using '.NETFramework,Version=v4.6.1, .NETFramework,Version=v4.6.2, .NETFramework,Version=v4.7, .NETFramework,Version=v4.7.1, .NETFramework,Version=v4.7.2, .NETFramework,Version=v4.8' instead of the project target framework 'net5.0'. This package may not be fully compatible with your project.", + "libraryId": "Microsoft.AspNet.Cors", + "targetGraphs": [ + "net5.0" + ] + }, + { + "code": "NU1701", + "level": "Warning", + "warningLevel": 1, + "message": "Package 'Microsoft.AspNet.WebApi.Core 5.2.7' was restored using '.NETFramework,Version=v4.6.1, .NETFramework,Version=v4.6.2, .NETFramework,Version=v4.7, .NETFramework,Version=v4.7.1, .NETFramework,Version=v4.7.2, .NETFramework,Version=v4.8' instead of the project target framework 'net5.0'. This package may not be fully compatible with your project.", + "libraryId": "Microsoft.AspNet.WebApi.Core", + "targetGraphs": [ + "net5.0" + ] + }, + { + "code": "NU1701", + "level": "Warning", + "warningLevel": 1, + "message": "Package 'Microsoft.AspNet.WebApi.Cors 5.2.7' was restored using '.NETFramework,Version=v4.6.1, .NETFramework,Version=v4.6.2, .NETFramework,Version=v4.7, .NETFramework,Version=v4.7.1, .NETFramework,Version=v4.7.2, .NETFramework,Version=v4.8' instead of the project target framework 'net5.0'. This package may not be fully compatible with your project.", + "libraryId": "Microsoft.AspNet.WebApi.Cors", + "targetGraphs": [ + "net5.0" + ] + } + ] +} \ No newline at end of file diff --git a/Back-end/MongoBookApis/obj/project.nuget.cache b/Back-end/MongoBookApis/obj/project.nuget.cache new file mode 100644 index 0000000..6947a2a --- /dev/null +++ b/Back-end/MongoBookApis/obj/project.nuget.cache @@ -0,0 +1,143 @@ +{ + "version": 2, + "dgSpecHash": "eParisEW6i9o+EmfzHTmo3dktuwsjVrCl7WwIL0kKvycJPmHr1zpPlEQSxj2RpJNnpU0qUOD4uDSFEL6se9I/g==", + "success": true, + "projectFilePath": "/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/MongoBookApis.csproj", + "expectedPackageFiles": [ + "/Users/hanieharabzadeh/.nuget/packages/dnsclient/1.4.0/dnsclient.1.4.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/microsoft.aspnet.cors/5.2.7/microsoft.aspnet.cors.5.2.7.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/microsoft.aspnet.webapi.client/5.2.7/microsoft.aspnet.webapi.client.5.2.7.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/microsoft.aspnet.webapi.core/5.2.7/microsoft.aspnet.webapi.core.5.2.7.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/microsoft.aspnet.webapi.cors/5.2.7/microsoft.aspnet.webapi.cors.5.2.7.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/microsoft.csharp/4.3.0/microsoft.csharp.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/microsoft.extensions.apidescription.server/3.0.0/microsoft.extensions.apidescription.server.3.0.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/microsoft.netcore.platforms/2.1.2/microsoft.netcore.platforms.2.1.2.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/microsoft.netcore.targets/1.1.0/microsoft.netcore.targets.1.1.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/microsoft.openapi/1.2.3/microsoft.openapi.1.2.3.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/microsoft.win32.primitives/4.3.0/microsoft.win32.primitives.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/mongodb.bson/2.13.2/mongodb.bson.2.13.2.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/mongodb.driver/2.13.2/mongodb.driver.2.13.2.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/mongodb.driver.core/2.13.2/mongodb.driver.core.2.13.2.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/mongodb.libmongocrypt/1.2.2/mongodb.libmongocrypt.1.2.2.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/netstandard.library/1.6.1/netstandard.library.1.6.1.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/newtonsoft.json/10.0.1/newtonsoft.json.10.0.1.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/newtonsoft.json.bson/1.0.1/newtonsoft.json.bson.1.0.1.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.native.system/4.3.0/runtime.native.system.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.native.system.io.compression/4.3.0/runtime.native.system.io.compression.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.native.system.net.http/4.3.0/runtime.native.system.net.http.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.native.system.security.cryptography.apple/4.3.0/runtime.native.system.security.cryptography.apple.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.native.system.security.cryptography.openssl/4.3.0/runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.apple/4.3.0/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.apple.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/sharpcompress/0.23.0/sharpcompress.0.23.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/swashbuckle.aspnetcore/5.6.3/swashbuckle.aspnetcore.5.6.3.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/swashbuckle.aspnetcore.swagger/5.6.3/swashbuckle.aspnetcore.swagger.5.6.3.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/swashbuckle.aspnetcore.swaggergen/5.6.3/swashbuckle.aspnetcore.swaggergen.5.6.3.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/swashbuckle.aspnetcore.swaggerui/5.6.3/swashbuckle.aspnetcore.swaggerui.5.6.3.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.appcontext/4.3.0/system.appcontext.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.buffers/4.5.1/system.buffers.4.5.1.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.collections/4.3.0/system.collections.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.collections.concurrent/4.3.0/system.collections.concurrent.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.collections.nongeneric/4.3.0/system.collections.nongeneric.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.collections.specialized/4.3.0/system.collections.specialized.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.componentmodel/4.3.0/system.componentmodel.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.componentmodel.primitives/4.3.0/system.componentmodel.primitives.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.componentmodel.typeconverter/4.3.0/system.componentmodel.typeconverter.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.console/4.3.0/system.console.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.diagnostics.debug/4.3.0/system.diagnostics.debug.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.diagnostics.diagnosticsource/4.3.0/system.diagnostics.diagnosticsource.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.diagnostics.tools/4.3.0/system.diagnostics.tools.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.diagnostics.tracing/4.3.0/system.diagnostics.tracing.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.dynamic.runtime/4.3.0/system.dynamic.runtime.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.globalization/4.3.0/system.globalization.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.globalization.calendars/4.3.0/system.globalization.calendars.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.globalization.extensions/4.3.0/system.globalization.extensions.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.io/4.3.0/system.io.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.io.compression/4.3.0/system.io.compression.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.io.compression.zipfile/4.3.0/system.io.compression.zipfile.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.io.filesystem/4.3.0/system.io.filesystem.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.io.filesystem.primitives/4.3.0/system.io.filesystem.primitives.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.linq/4.3.0/system.linq.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.linq.expressions/4.3.0/system.linq.expressions.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.net.http/4.3.0/system.net.http.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.net.primitives/4.3.0/system.net.primitives.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.net.sockets/4.3.0/system.net.sockets.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.objectmodel/4.3.0/system.objectmodel.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.reflection/4.3.0/system.reflection.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.reflection.emit/4.3.0/system.reflection.emit.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.reflection.emit.ilgeneration/4.3.0/system.reflection.emit.ilgeneration.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.reflection.emit.lightweight/4.3.0/system.reflection.emit.lightweight.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.reflection.extensions/4.3.0/system.reflection.extensions.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.reflection.primitives/4.3.0/system.reflection.primitives.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.reflection.typeextensions/4.3.0/system.reflection.typeextensions.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.resources.resourcemanager/4.3.0/system.resources.resourcemanager.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.runtime/4.3.0/system.runtime.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.runtime.compilerservices.unsafe/5.0.0/system.runtime.compilerservices.unsafe.5.0.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.runtime.extensions/4.3.0/system.runtime.extensions.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.runtime.handles/4.3.0/system.runtime.handles.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.runtime.interopservices/4.3.0/system.runtime.interopservices.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.runtime.interopservices.runtimeinformation/4.3.0/system.runtime.interopservices.runtimeinformation.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.runtime.numerics/4.3.0/system.runtime.numerics.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.runtime.serialization.formatters/4.3.0/system.runtime.serialization.formatters.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.runtime.serialization.primitives/4.3.0/system.runtime.serialization.primitives.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.security.cryptography.algorithms/4.3.0/system.security.cryptography.algorithms.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.security.cryptography.cng/4.3.0/system.security.cryptography.cng.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.security.cryptography.csp/4.3.0/system.security.cryptography.csp.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.security.cryptography.encoding/4.3.0/system.security.cryptography.encoding.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.security.cryptography.openssl/4.3.0/system.security.cryptography.openssl.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.security.cryptography.primitives/4.3.0/system.security.cryptography.primitives.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.security.cryptography.x509certificates/4.3.0/system.security.cryptography.x509certificates.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.text.encoding/4.3.0/system.text.encoding.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.text.encoding.codepages/4.5.1/system.text.encoding.codepages.4.5.1.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.text.encoding.extensions/4.3.0/system.text.encoding.extensions.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.text.regularexpressions/4.3.0/system.text.regularexpressions.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.threading/4.3.0/system.threading.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.threading.tasks/4.3.0/system.threading.tasks.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.threading.tasks.extensions/4.3.0/system.threading.tasks.extensions.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.threading.timer/4.3.0/system.threading.timer.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.xml.readerwriter/4.3.0/system.xml.readerwriter.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.xml.xdocument/4.3.0/system.xml.xdocument.4.3.0.nupkg.sha512", + "/Users/hanieharabzadeh/.nuget/packages/system.xml.xmldocument/4.3.0/system.xml.xmldocument.4.3.0.nupkg.sha512" + ], + "logs": [ + { + "code": "NU1701", + "level": "Warning", + "warningLevel": 1, + "message": "Package 'Microsoft.AspNet.Cors 5.2.7' was restored using '.NETFramework,Version=v4.6.1, .NETFramework,Version=v4.6.2, .NETFramework,Version=v4.7, .NETFramework,Version=v4.7.1, .NETFramework,Version=v4.7.2, .NETFramework,Version=v4.8' instead of the project target framework 'net5.0'. This package may not be fully compatible with your project.", + "libraryId": "Microsoft.AspNet.Cors", + "targetGraphs": [ + "net5.0" + ] + }, + { + "code": "NU1701", + "level": "Warning", + "warningLevel": 1, + "message": "Package 'Microsoft.AspNet.WebApi.Core 5.2.7' was restored using '.NETFramework,Version=v4.6.1, .NETFramework,Version=v4.6.2, .NETFramework,Version=v4.7, .NETFramework,Version=v4.7.1, .NETFramework,Version=v4.7.2, .NETFramework,Version=v4.8' instead of the project target framework 'net5.0'. This package may not be fully compatible with your project.", + "libraryId": "Microsoft.AspNet.WebApi.Core", + "targetGraphs": [ + "net5.0" + ] + }, + { + "code": "NU1701", + "level": "Warning", + "warningLevel": 1, + "message": "Package 'Microsoft.AspNet.WebApi.Cors 5.2.7' was restored using '.NETFramework,Version=v4.6.1, .NETFramework,Version=v4.6.2, .NETFramework,Version=v4.7, .NETFramework,Version=v4.7.1, .NETFramework,Version=v4.7.2, .NETFramework,Version=v4.8' instead of the project target framework 'net5.0'. This package may not be fully compatible with your project.", + "libraryId": "Microsoft.AspNet.WebApi.Cors", + "targetGraphs": [ + "net5.0" + ] + } + ] +} \ No newline at end of file diff --git a/Front-end/.DS_Store b/Front-end/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..4acc1ff4b80d49fd553c2ba84315741e1017dbc5 GIT binary patch literal 6148 zcmeHKKT88K9R0->X)T3{3LPBI58zM-5vQ|OH>d8_{?S&r^D0$AaJUcQtedEl=;|Oi z_(dH201i&#`z6s{+Pi{_h~@{$%Ox+#yLU~}5RoV!wn{_=BFZ2!rYDfa1h;biD!Ijq(ib?F#ux4(XCUb|Fn27Xsb&Q2vW{h(55 zctHb<%*p1$OY!P)WfZ&h4R*H^Rl)ldHlsS!?oyBDvD56)k)iZ#{V9$U)%bRIzWjPA zH4csC2Yq#;c!sX~kadmIDh1H918r?X6Vd5ldsNTdZR&dILh3Qbh-yjV7&_!W4jmiN z(SkP~^-LY98>u7G9@Q~9>*g0fbr_t!CrO+b9a%bn1|Q$b!x!W7fSUY1)Woo&n%hdjb@tqTul7$17|izCa2Km)&c8)b>PbZ-X9z!Mpt8~P;MQ_E3>BgVAyikO>MHaVL#XbkcQnt{7%EiVNywQoj-FZQ8;X##qu!Bp60Sm< zTL-KIrUNPUSm5)2E&2X$cCt^_0qek@azLaj)k+z!q|er&m*cb6LE1v%U|y(Dc0s0( hV_D#%xQHYJZ4MWJuEtOyY7q91fV9D8)`1^&-~&BJw)Fr2 literal 0 HcmV?d00001 diff --git a/Front-end/Config/Config.py b/Front-end/Config/Config.py new file mode 100644 index 0000000..8948a9e --- /dev/null +++ b/Front-end/Config/Config.py @@ -0,0 +1,6 @@ +class Config: + + def __init__(self) -> None: + self.url = "https://localhost:5001/" + def returnUrl(self) -> str: + return self.url diff --git a/Front-end/Models/BookModel.py b/Front-end/Models/BookModel.py new file mode 100644 index 0000000..e69dc79 --- /dev/null +++ b/Front-end/Models/BookModel.py @@ -0,0 +1,28 @@ +from _typeshed import Self + + +class BookModel: + + def __init__(self,json) -> None: + super().__init__() + if json is not None: + self.title = "" + self.authors = "" + self.averageRating = "" + self.numPage = "" + self.ratingCount = "" + self.textReviewCount = "" + self.publicationDate = "" + self.publisher = "" + self.createdDate = "" + def map_data(self,json): + if json is not None: + self.title = json["title"] + self.authors = json["auhors"] + self.averageRating = json["averageRating"] + self.numPage = json["numPage"] + self.ratingCount = json["ratingCount"] + self.textReviewCount = json["textReviewCount"] + self.publicationDate = json["publicationDate"] + self.publisher = json["publisher"] + self.createdDate = json["createdDate"] diff --git a/Front-end/__pycache__/app.cpython-38.pyc b/Front-end/__pycache__/app.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4ee5e164e7b5855baf3d6b4766d2c227d5370291 GIT binary patch literal 2323 zcmZuz$!^?65M^^8ayBiN_e6%XO%jW;oehQ&#F3*QKrj|$`NGS9nr>-0;+F0n+ZsqG zPF9+CJmTO41ZE!y5Cv~z6IE}i?`0Q*&KpQmlQuxsj>MS4lkT+=g4=PNGLE82b? z-f?x${DW{4JZ{iy^g6w9j3>388oiruFhf0}e40om)12Y>NhQ;=NU}aEn@m(?Az05< z&U%)JJ>?F|Vkg~IK4&!LY$%mC;n`rP3)7z{~ z({Lp^^Aj-NIa6S#3^qBvF_N+p527e5heL!D}8( zu1C)V<02X*Mao7APqwECWuxdZ6MM3( z;Q5?oWtFo+ifCgW@>E1W0-QiH`Do)85hYc%Qtc~8hrR?`iY^Gl^hrQ`_@Qi@ya%>v zGa71mkPnfvH=aD*dMD==IJt1^oc{v@X^aUadnW%AM&^lyd8ZcYsd0$2Cbh334)()Z zbF}8nG*@fxO!Ktn%`{(Y{!D9VtufOAtpzhJ)LQt^piSCJ5nX%i(6)3>JVcvz0N?Jh zeP|w-W1r4JbbreRokye#Uj}sH9P`CK{~S&ghhnmwr*eRKh}~M@m^MC#Vjjf;ibW7{ zXN$d*ZxsN)gj1O6)8<-PNPy;!+^^Va7qB=hj0kDK+u*d`vy}zq&OZc2xlnEC&c5=H zTmbx=zi_k5Af}xQa5M#bA;1BnM<{Qx80TmCgy& z@7RN?Hlkq`P__heUGxdQ3`Pjz0-;aP^<9|wcVK$}_pH>rP~u%cqX~r$rH-@89}My&Ee3Y%l<~s!}en8*2r7 zCclLa4lgH?>HejeRv*velj5zc==^8~`w#PyPBQjA9#0_fO~?y2LLZ*X_1J9MP2jW* P{B4t<3AtOsXF&b~&Vo#4 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/.DS_Store b/Front-end/apis-env/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..8d65797237b4a595637b0f42c60362dacd2627ec GIT binary patch literal 6148 zcmeHKy-veG4E8mZ2!f#!3*)^)SA;~Uf&_C{29yRtrG|9ro)bNLZgJCoe<$yarzq1jTa+0rvA;M!{#d`Bw!Qf`-sNq3*Jq^B4p*ZYEoenK zU3cqpz-C0d{=xd;Nb7IxQ9P9!Yy^@8P)Ddgv9Dh2tv0It3S@6(g2g@gXz_?4B=x UiDD%P3&ef|0u8np13${ZCnGUrumAu6 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/bin/Activate.ps1 b/Front-end/apis-env/bin/Activate.ps1 new file mode 100644 index 0000000..90af274 --- /dev/null +++ b/Front-end/apis-env/bin/Activate.ps1 @@ -0,0 +1,241 @@ +<# +.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: +ttps:/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" diff --git a/Front-end/apis-env/bin/activate b/Front-end/apis-env/bin/activate new file mode 100644 index 0000000..b64552a --- /dev/null +++ b/Front-end/apis-env/bin/activate @@ -0,0 +1,76 @@ +# 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 + 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="/Users/hanieharabzadeh/Desktop/Developments/Python/BookRestAPIs/apis-env" +export VIRTUAL_ENV + +_OLD_VIRTUAL_PATH="$PATH" +PATH="$VIRTUAL_ENV/bin:$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:-}" + if [ "x(apis-env) " != x ] ; then + PS1="(apis-env) ${PS1:-}" + else + if [ "`basename \"$VIRTUAL_ENV\"`" = "__" ] ; then + # special case for Aspen magic directories + # see http://www.zetadev.com/software/aspen/ + PS1="[`basename \`dirname \"$VIRTUAL_ENV\"\``] $PS1" + else + PS1="(`basename \"$VIRTUAL_ENV\"`)$PS1" + fi + fi + 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 +fi diff --git a/Front-end/apis-env/bin/activate.csh b/Front-end/apis-env/bin/activate.csh new file mode 100644 index 0000000..faa82c7 --- /dev/null +++ b/Front-end/apis-env/bin/activate.csh @@ -0,0 +1,37 @@ +# This file must be used with "source bin/activate.csh" *from csh*. +# You cannot run it directly. +# Created by Davide Di Blasi . +# Ported to Python 3.3 venv by Andrew Svetlov + +alias deactivate 'test $?_OLD_VIRTUAL_PATH != 0 && setenv PATH "$_OLD_VIRTUAL_PATH" && unset _OLD_VIRTUAL_PATH; rehash; test $?_OLD_VIRTUAL_PROMPT != 0 && set prompt="$_OLD_VIRTUAL_PROMPT" && unset _OLD_VIRTUAL_PROMPT; unsetenv VIRTUAL_ENV; test "\!:*" != "nondestructive" && unalias deactivate' + +# Unset irrelevant variables. +deactivate nondestructive + +setenv VIRTUAL_ENV "/Users/hanieharabzadeh/Desktop/Developments/Python/BookRestAPIs/apis-env" + +set _OLD_VIRTUAL_PATH="$PATH" +setenv PATH "$VIRTUAL_ENV/bin:$PATH" + + +set _OLD_VIRTUAL_PROMPT="$prompt" + +if (! "$?VIRTUAL_ENV_DISABLE_PROMPT") then + if ("apis-env" != "") then + set env_name = "apis-env" + else + if (`basename "VIRTUAL_ENV"` == "__") then + # special case for Aspen magic directories + # see http://www.zetadev.com/software/aspen/ + set env_name = `basename \`dirname "$VIRTUAL_ENV"\`` + else + set env_name = `basename "$VIRTUAL_ENV"` + endif + endif + set prompt = "[$env_name] $prompt" + unset env_name +endif + +alias pydoc python -m pydoc + +rehash diff --git a/Front-end/apis-env/bin/activate.fish b/Front-end/apis-env/bin/activate.fish new file mode 100644 index 0000000..28a297d --- /dev/null +++ b/Front-end/apis-env/bin/activate.fish @@ -0,0 +1,75 @@ +# This file must be used with ". bin/activate.fish" *from fish* (http://fishshell.org) +# you cannot run it directly + +function deactivate -d "Exit virtualenv and return to normal shell environment" + # reset old environment variables + if test -n "$_OLD_VIRTUAL_PATH" + set -gx PATH $_OLD_VIRTUAL_PATH + set -e _OLD_VIRTUAL_PATH + end + if test -n "$_OLD_VIRTUAL_PYTHONHOME" + set -gx PYTHONHOME $_OLD_VIRTUAL_PYTHONHOME + set -e _OLD_VIRTUAL_PYTHONHOME + end + + if test -n "$_OLD_FISH_PROMPT_OVERRIDE" + functions -e fish_prompt + set -e _OLD_FISH_PROMPT_OVERRIDE + functions -c _old_fish_prompt fish_prompt + functions -e _old_fish_prompt + end + + set -e VIRTUAL_ENV + if test "$argv[1]" != "nondestructive" + # Self destruct! + functions -e deactivate + end +end + +# unset irrelevant variables +deactivate nondestructive + +set -gx VIRTUAL_ENV "/Users/hanieharabzadeh/Desktop/Developments/Python/BookRestAPIs/apis-env" + +set -gx _OLD_VIRTUAL_PATH $PATH +set -gx PATH "$VIRTUAL_ENV/bin" $PATH + +# unset PYTHONHOME if set +if set -q PYTHONHOME + set -gx _OLD_VIRTUAL_PYTHONHOME $PYTHONHOME + set -e PYTHONHOME +end + +if test -z "$VIRTUAL_ENV_DISABLE_PROMPT" + # fish uses a function instead of an env var to generate the prompt. + + # save the current fish_prompt function as the function _old_fish_prompt + functions -c fish_prompt _old_fish_prompt + + # with the original prompt function renamed, we can override with our own. + function fish_prompt + # Save the return status of the last command + set -l old_status $status + + # Prompt override? + if test -n "(apis-env) " + printf "%s%s" "(apis-env) " (set_color normal) + else + # ...Otherwise, prepend env + set -l _checkbase (basename "$VIRTUAL_ENV") + if test $_checkbase = "__" + # special case for Aspen magic directories + # see http://www.zetadev.com/software/aspen/ + printf "%s[%s]%s " (set_color -b blue white) (basename (dirname "$VIRTUAL_ENV")) (set_color normal) + else + printf "%s(%s)%s" (set_color -b blue white) (basename "$VIRTUAL_ENV") (set_color normal) + end + end + + # Restore the return status of the previous command. + echo "exit $old_status" | . + _old_fish_prompt + end + + set -gx _OLD_FISH_PROMPT_OVERRIDE "$VIRTUAL_ENV" +end diff --git a/Front-end/apis-env/bin/easy_install b/Front-end/apis-env/bin/easy_install new file mode 100755 index 0000000..b2b2b8d --- /dev/null +++ b/Front-end/apis-env/bin/easy_install @@ -0,0 +1,10 @@ +#!/Users/hanieharabzadeh/Desktop/Developments/Python/BookRestAPIs/apis-env/bin/python +# -*- coding: utf-8 -*- +import re +import sys + +from setuptools.command.easy_install import main + +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/Front-end/apis-env/bin/easy_install-3.8 b/Front-end/apis-env/bin/easy_install-3.8 new file mode 100755 index 0000000..b2b2b8d --- /dev/null +++ b/Front-end/apis-env/bin/easy_install-3.8 @@ -0,0 +1,10 @@ +#!/Users/hanieharabzadeh/Desktop/Developments/Python/BookRestAPIs/apis-env/bin/python +# -*- coding: utf-8 -*- +import re +import sys + +from setuptools.command.easy_install import main + +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/Front-end/apis-env/bin/pip b/Front-end/apis-env/bin/pip new file mode 100755 index 0000000..090f6c6 --- /dev/null +++ b/Front-end/apis-env/bin/pip @@ -0,0 +1,10 @@ +#!/Users/hanieharabzadeh/Desktop/Developments/Python/BookRestAPIs/apis-env/bin/python +# -*- coding: utf-8 -*- +import re +import sys + +from pip._internal import main + +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/Front-end/apis-env/bin/pip3 b/Front-end/apis-env/bin/pip3 new file mode 100755 index 0000000..090f6c6 --- /dev/null +++ b/Front-end/apis-env/bin/pip3 @@ -0,0 +1,10 @@ +#!/Users/hanieharabzadeh/Desktop/Developments/Python/BookRestAPIs/apis-env/bin/python +# -*- coding: utf-8 -*- +import re +import sys + +from pip._internal import main + +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/Front-end/apis-env/bin/pip3.8 b/Front-end/apis-env/bin/pip3.8 new file mode 100755 index 0000000..090f6c6 --- /dev/null +++ b/Front-end/apis-env/bin/pip3.8 @@ -0,0 +1,10 @@ +#!/Users/hanieharabzadeh/Desktop/Developments/Python/BookRestAPIs/apis-env/bin/python +# -*- coding: utf-8 -*- +import re +import sys + +from pip._internal import main + +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/Front-end/apis-env/bin/python b/Front-end/apis-env/bin/python new file mode 120000 index 0000000..386168e --- /dev/null +++ b/Front-end/apis-env/bin/python @@ -0,0 +1 @@ +/Users/hanieharabzadeh/opt/anaconda3/bin/python \ No newline at end of file diff --git a/Front-end/apis-env/bin/python3 b/Front-end/apis-env/bin/python3 new file mode 120000 index 0000000..d8654aa --- /dev/null +++ b/Front-end/apis-env/bin/python3 @@ -0,0 +1 @@ +python \ No newline at end of file diff --git a/Front-end/apis-env/lib/python3.8/site-packages/__pycache__/easy_install.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/__pycache__/easy_install.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b95369a06cc9fe8db988216875604ec6ecdfa4e3 GIT binary patch literal 337 zcmYk0y-LJD6oqG!s6pH(5H#4O*i5uo2#DBN*jV_}q`8bcvzzGrgqb94QrPU1SlanK zX{~$#3o9qO;2ya5aNzQt`!Jd8Bd4$TSNh`oV+`B!T)1>&PuyZCM;tT!?3p9xF<*Gn z&wY%zzeX6b;10z*{o!q+qPpPG6}8>9vNaVVnrkVkVnYZZX{i7{9S+5K2*!952g4o! z({q6FL{Z5B@?*>ErmD3THrW6Y?x0ZqQH}2yZ^-OA`(57!sZ80@nv<3qve1HYV@b9m zOUPOydv&&WN{eFE_aL&_V_{OKr6TvFDy!)RJ5AGB+qI_+`R^y&y-C##;kneT5&QzX Mayxzycp*N(KR#(;Z2$lO literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/easy_install.py b/Front-end/apis-env/lib/python3.8/site-packages/easy_install.py new file mode 100644 index 0000000..d87e984 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/easy_install.py @@ -0,0 +1,5 @@ +"""Run the EasyInstall command""" + +if __name__ == '__main__': + from setuptools.command.easy_install import main + main() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/INSTALLER b/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/LICENSE.txt b/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/LICENSE.txt new file mode 100644 index 0000000..737fec5 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/LICENSE.txt @@ -0,0 +1,20 @@ +Copyright (c) 2008-2019 The pip developers (see AUTHORS.txt file) + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/METADATA b/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/METADATA new file mode 100644 index 0000000..45e28ec --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/METADATA @@ -0,0 +1,81 @@ +Metadata-Version: 2.1 +Name: pip +Version: 19.2.3 +Summary: The PyPA recommended tool for installing Python packages. +Home-page: https://pip.pypa.io/ +Author: The pip developers +Author-email: pypa-dev@groups.google.com +License: MIT +Keywords: distutils easy_install egg setuptools wheel virtualenv +Platform: UNKNOWN +Classifier: Development Status :: 5 - Production/Stable +Classifier: Intended Audience :: Developers +Classifier: License :: OSI Approved :: MIT License +Classifier: Topic :: Software Development :: Build Tools +Classifier: Programming Language :: Python +Classifier: Programming Language :: Python :: 2 +Classifier: Programming Language :: Python :: 2.7 +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3.5 +Classifier: Programming Language :: Python :: 3.6 +Classifier: Programming Language :: Python :: 3.7 +Classifier: Programming Language :: Python :: Implementation :: CPython +Classifier: Programming Language :: Python :: Implementation :: PyPy +Requires-Python: >=2.7,!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,!=3.4.* + +pip - The Python Package Installer +================================== + +.. image:: https://img.shields.io/pypi/v/pip.svg + :target: https://pypi.org/project/pip/ + +.. image:: https://readthedocs.org/projects/pip/badge/?version=latest + :target: https://pip.pypa.io/en/latest + +pip is the `package installer`_ for Python. You can use pip to install packages from the `Python Package Index`_ and other indexes. + +Please take a look at our documentation for how to install and use pip: + +* `Installation`_ +* `Usage`_ + +Updates are released regularly, with a new version every 3 months. More details can be found in our documentation: + +* `Release notes`_ +* `Release process`_ + +If you find bugs, need help, or want to talk to the developers please use our mailing lists or chat rooms: + +* `Issue tracking`_ +* `Discourse channel`_ +* `User IRC`_ + +If you want to get involved head over to GitHub to get the source code, look at our development documentation and feel free to jump on the developer mailing lists and chat rooms: + +* `GitHub page`_ +* `Dev documentation`_ +* `Dev mailing list`_ +* `Dev IRC`_ + +Code of Conduct +--------------- + +Everyone interacting in the pip project's codebases, issue trackers, chat +rooms, and mailing lists is expected to follow the `PyPA Code of Conduct`_. + +.. _package installer: https://packaging.python.org/en/latest/current/ +.. _Python Package Index: https://pypi.org +.. _Installation: https://pip.pypa.io/en/stable/installing.html +.. _Usage: https://pip.pypa.io/en/stable/ +.. _Release notes: https://pip.pypa.io/en/stable/news.html +.. _Release process: https://pip.pypa.io/en/latest/development/release-process/ +.. _GitHub page: https://github.com/pypa/pip +.. _Dev documentation: https://pip.pypa.io/en/latest/development +.. _Issue tracking: https://github.com/pypa/pip/issues +.. _Discourse channel: https://discuss.python.org/c/packaging +.. _Dev mailing list: https://groups.google.com/forum/#!forum/pypa-dev +.. _User IRC: https://webchat.freenode.net/?channels=%23pypa +.. _Dev IRC: https://webchat.freenode.net/?channels=%23pypa-dev +.. _PyPA Code of Conduct: https://www.pypa.io/en/latest/code-of-conduct/ + + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/RECORD b/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/RECORD new file mode 100644 index 0000000..2872f00 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/RECORD @@ -0,0 +1,668 @@ +../../../bin/pip,sha256=yO_OSgfjhWI7MPuGSSg0kLWf9_k05A2ZHlOR0j3dUsM,282 +../../../bin/pip3,sha256=yO_OSgfjhWI7MPuGSSg0kLWf9_k05A2ZHlOR0j3dUsM,282 +../../../bin/pip3.8,sha256=yO_OSgfjhWI7MPuGSSg0kLWf9_k05A2ZHlOR0j3dUsM,282 +pip-19.2.3.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +pip-19.2.3.dist-info/LICENSE.txt,sha256=W6Ifuwlk-TatfRU2LR7W1JMcyMj5_y1NkRkOEJvnRDE,1090 +pip-19.2.3.dist-info/METADATA,sha256=uA6603UkWcOVSlssH5-xiouxIBqVvzVkNDCHNkzsJs4,3195 +pip-19.2.3.dist-info/RECORD,, +pip-19.2.3.dist-info/WHEEL,sha256=8zNYZbwQSXoB9IfXOjPfeNwvAsALAjffgk27FqvCWbo,110 +pip-19.2.3.dist-info/entry_points.txt,sha256=S_zfxY25QtQDVY1BiLAmOKSkkI5llzCKPLiYOSEupsY,98 +pip-19.2.3.dist-info/top_level.txt,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +pip/__init__.py,sha256=DY1edKuavmOCGCG4RY236CTl5tiT71KY6-ewGOCDIJU,23 +pip/__main__.py,sha256=L3IHqBeasELUHvwy5CT_izVEMhM12tve289qut49DvU,623 +pip/__pycache__/__init__.cpython-38.pyc,, +pip/__pycache__/__main__.cpython-38.pyc,, +pip/_internal/__init__.py,sha256=uGzk4m-m6lYf1mnYIRjjsvO35Qf6iAFatbY4oa9ifOU,2797 +pip/_internal/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/__pycache__/build_env.cpython-38.pyc,, +pip/_internal/__pycache__/cache.cpython-38.pyc,, +pip/_internal/__pycache__/configuration.cpython-38.pyc,, +pip/_internal/__pycache__/download.cpython-38.pyc,, +pip/_internal/__pycache__/exceptions.cpython-38.pyc,, +pip/_internal/__pycache__/index.cpython-38.pyc,, +pip/_internal/__pycache__/legacy_resolve.cpython-38.pyc,, +pip/_internal/__pycache__/locations.cpython-38.pyc,, +pip/_internal/__pycache__/pep425tags.cpython-38.pyc,, +pip/_internal/__pycache__/pyproject.cpython-38.pyc,, +pip/_internal/__pycache__/wheel.cpython-38.pyc,, +pip/_internal/build_env.py,sha256=jZHTbyb4XqoaIoPaOJP2uOp1Hnmh0HfplXBgY0TBWyM,7405 +pip/_internal/cache.py,sha256=MzHv-Z0h8_n6XfBMxIatHcoiyAmzvX1zKtDGoJBWHk0,7658 +pip/_internal/cli/__init__.py,sha256=FkHBgpxxb-_gd6r1FjnNhfMOzAUYyXoXKJ6abijfcFU,132 +pip/_internal/cli/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/cli/__pycache__/autocompletion.cpython-38.pyc,, +pip/_internal/cli/__pycache__/base_command.cpython-38.pyc,, +pip/_internal/cli/__pycache__/cmdoptions.cpython-38.pyc,, +pip/_internal/cli/__pycache__/main_parser.cpython-38.pyc,, +pip/_internal/cli/__pycache__/parser.cpython-38.pyc,, +pip/_internal/cli/__pycache__/status_codes.cpython-38.pyc,, +pip/_internal/cli/autocompletion.py,sha256=ptvsMdGjq42pzoY4skABVF43u2xAtLJlXAulPi-A10Y,6083 +pip/_internal/cli/base_command.py,sha256=KF1S58E8yilcKkqPyeJKU-jqQBSxBI25b_sBoq3uEAo,13029 +pip/_internal/cli/cmdoptions.py,sha256=cILKSj3jrwpQY3Xl76erVPhxnWuAIOoeJUcVjxttyaE,27543 +pip/_internal/cli/main_parser.py,sha256=J_gG7JnoAeUhSDy2PFGqMEZLNm9oNYnuZunjVz94Lyw,2817 +pip/_internal/cli/parser.py,sha256=VZKUKJPbU6I2cHPLDOikin-aCx7OvLcZ3fzYp3xytd8,9378 +pip/_internal/cli/status_codes.py,sha256=F6uDG6Gj7RNKQJUDnd87QKqI16Us-t-B0wPF_4QMpWc,156 +pip/_internal/commands/__init__.py,sha256=KF-mqzngZMtbOxkX9M6ayyGyroCNz5xdlZEc4lItUMI,2295 +pip/_internal/commands/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/commands/__pycache__/check.cpython-38.pyc,, +pip/_internal/commands/__pycache__/completion.cpython-38.pyc,, +pip/_internal/commands/__pycache__/configuration.cpython-38.pyc,, +pip/_internal/commands/__pycache__/debug.cpython-38.pyc,, +pip/_internal/commands/__pycache__/download.cpython-38.pyc,, +pip/_internal/commands/__pycache__/freeze.cpython-38.pyc,, +pip/_internal/commands/__pycache__/hash.cpython-38.pyc,, +pip/_internal/commands/__pycache__/help.cpython-38.pyc,, +pip/_internal/commands/__pycache__/install.cpython-38.pyc,, +pip/_internal/commands/__pycache__/list.cpython-38.pyc,, +pip/_internal/commands/__pycache__/search.cpython-38.pyc,, +pip/_internal/commands/__pycache__/show.cpython-38.pyc,, +pip/_internal/commands/__pycache__/uninstall.cpython-38.pyc,, +pip/_internal/commands/__pycache__/wheel.cpython-38.pyc,, +pip/_internal/commands/check.py,sha256=liigNVif0iz2mBfhvsajrLZT5zM5KIvgmKvhAW91EzA,1430 +pip/_internal/commands/completion.py,sha256=hqvCvoxsIHjysiD7olHKTqK2lzE1_lS6LWn69kN5qyI,2929 +pip/_internal/commands/configuration.py,sha256=c22362Rk7dAwvHFja9py4sSaV0Sryqo_PzuadI1mm0w,8156 +pip/_internal/commands/debug.py,sha256=0NJZT3Zz9vjqUqeKdPPbr_jUZubnHYp7Cmk--zlZiPs,3360 +pip/_internal/commands/download.py,sha256=zAyNBo0zwHixos6O-S6Kd9SAH1L_74filOoR83_Fa7U,6375 +pip/_internal/commands/freeze.py,sha256=lDrob-AG-qT2DyZTNWlYa9F4BqJQTy_F9h9KakBMnG0,3441 +pip/_internal/commands/hash.py,sha256=K1JycsD-rpjqrRcL_ijacY9UKmI82pQcLYq4kCM4Pv0,1681 +pip/_internal/commands/help.py,sha256=MwBhPJpW1Dt3GfJV3V8V6kgAy_pXT0jGrZJB1wCTW-E,1090 +pip/_internal/commands/install.py,sha256=cGXbByOjrJWKIv5myy7ZflX4jYMyjT6-w85tGhnI-Nw,22646 +pip/_internal/commands/list.py,sha256=MMiJnQJCfMwA1Qf0lSru7Nzm19otm49MFmbx8y01rwA,10497 +pip/_internal/commands/search.py,sha256=R2N1-r3RaxZqX5YeNL9QaYWnILsUn4MtPKZ1ji1i1sU,4972 +pip/_internal/commands/show.py,sha256=bE-ucu8fAjTTENpRRKhwD3QSWR8Rss7YgKAbMJoxock,6273 +pip/_internal/commands/uninstall.py,sha256=h0gfPF5jylDESx_IHgF6bZME7QAEOHzQHdn65GP-jrE,2963 +pip/_internal/commands/wheel.py,sha256=G2dOwQkDCH0-x6nlf9MvbMY2GUf-pqAG5epV4fjMGM0,6977 +pip/_internal/configuration.py,sha256=dKsnJZN9r4jVsl9IcoKTU0iI9s6XZQu3FzOsqTNElk0,14076 +pip/_internal/distributions/__init__.py,sha256=ydMdQRMM1DV6BdomjeP1em-YKikg90LZ9Tg5sJRhNF4,861 +pip/_internal/distributions/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/distributions/__pycache__/base.cpython-38.pyc,, +pip/_internal/distributions/__pycache__/installed.cpython-38.pyc,, +pip/_internal/distributions/__pycache__/source.cpython-38.pyc,, +pip/_internal/distributions/__pycache__/wheel.cpython-38.pyc,, +pip/_internal/distributions/base.py,sha256=Js_vmU-MKOONF_u-k5vmu3vTJnrOk3cLD_rPRB8r7-w,1000 +pip/_internal/distributions/installed.py,sha256=uwB2CPqseB8rPv0ICBCIB1LMs8yQnd8h-JZe9B9oOB0,434 +pip/_internal/distributions/source.py,sha256=L4SEZsTtqx6F3D39P7yJDgqqrnc4dGMZr3BTWgA05jg,3514 +pip/_internal/distributions/wheel.py,sha256=lWaa9l-REefNSL9E3A0zf8h2bZRLBOlTSBqHhPTYE7M,508 +pip/_internal/download.py,sha256=Zd5EtNjqJct5tOzZ5DfmiR9zaWV2UbE24omoZcNsLd4,43323 +pip/_internal/exceptions.py,sha256=_mDPdvO9EFMxUX4VEjzw3qic0PRqPH8EPOx__-MBNb4,10168 +pip/_internal/index.py,sha256=RE8HCh8MjJPgO2EhW7hww4Jr0QWFaA3GiUgxhTPs59c,56017 +pip/_internal/legacy_resolve.py,sha256=GDWmB6KtWAIcTX4gvwFrU8Xc2w4X0KBEkbW8fGU24Fk,17303 +pip/_internal/locations.py,sha256=Tv1TotkC1brrTgqG8pvLhJGvwRfiDwAlXTOdzk7hYio,5045 +pip/_internal/models/__init__.py,sha256=3DHUd_qxpPozfzouoqa9g9ts1Czr5qaHfFxbnxriepM,63 +pip/_internal/models/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/models/__pycache__/candidate.cpython-38.pyc,, +pip/_internal/models/__pycache__/format_control.cpython-38.pyc,, +pip/_internal/models/__pycache__/index.cpython-38.pyc,, +pip/_internal/models/__pycache__/link.cpython-38.pyc,, +pip/_internal/models/__pycache__/search_scope.cpython-38.pyc,, +pip/_internal/models/__pycache__/selection_prefs.cpython-38.pyc,, +pip/_internal/models/__pycache__/target_python.cpython-38.pyc,, +pip/_internal/models/candidate.py,sha256=IV7B5Rj-FjQKh5Shbv8CenuNekxdpb_chrJMEID4ouU,1169 +pip/_internal/models/format_control.py,sha256=ap8Swa26ocSXBxIuCvaDBRZjxdKUFuwC-bfqXQHWtKw,2250 +pip/_internal/models/index.py,sha256=K59A8-hVhBM20Xkahr4dTwP7OjkJyEqXH11UwHFVgqM,1060 +pip/_internal/models/link.py,sha256=fj3Hg4xrPo8ucOVyJvYrq1AgJjh56D2Z8F1liDoW-TM,6553 +pip/_internal/models/search_scope.py,sha256=JxPlngW2ecVoYrF8dr2b0oYf8XrZ-yAQ1U19uEM8Lgo,3875 +pip/_internal/models/selection_prefs.py,sha256=rPeif2KKjhTPXeMoQYffjqh10oWpXhdkxRDaPT1HO8k,1908 +pip/_internal/models/target_python.py,sha256=d66ljdpZZtAAQsuOytiZ7yq6spCa8GOmz5Vf7uoVZT0,3820 +pip/_internal/operations/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +pip/_internal/operations/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/operations/__pycache__/check.cpython-38.pyc,, +pip/_internal/operations/__pycache__/freeze.cpython-38.pyc,, +pip/_internal/operations/__pycache__/prepare.cpython-38.pyc,, +pip/_internal/operations/check.py,sha256=EkjtpXpOCTvt_VG0gRnlSBBj5SGWsoVYzbAMpepI8JU,5224 +pip/_internal/operations/freeze.py,sha256=rKAeXdh1HbK92Z5YtmLyil8IYkcC076lahNJMyxqbVM,9680 +pip/_internal/operations/prepare.py,sha256=z27rAvMEtlpake5OI1-SIzp-EBjjwyf8PEikO0KmJ8w,11728 +pip/_internal/pep425tags.py,sha256=e3VijBWZOCLV1_iqXuCvlCswbJ16Ug4eYhR3Vz5MAmk,13220 +pip/_internal/pyproject.py,sha256=OlCw7pSqST68hUF_eV-YVaqJ4I7z_ROJwvgra-2C_5I,6464 +pip/_internal/req/__init__.py,sha256=Y2SjAuMFsSt3dkiK8kkiQAfv8sHrjl0PAT63FKFT0tM,2364 +pip/_internal/req/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/req/__pycache__/constructors.cpython-38.pyc,, +pip/_internal/req/__pycache__/req_file.cpython-38.pyc,, +pip/_internal/req/__pycache__/req_install.cpython-38.pyc,, +pip/_internal/req/__pycache__/req_set.cpython-38.pyc,, +pip/_internal/req/__pycache__/req_tracker.cpython-38.pyc,, +pip/_internal/req/__pycache__/req_uninstall.cpython-38.pyc,, +pip/_internal/req/constructors.py,sha256=tC7fNxKrvF3gbxI2IcA6uQiXJ5sPFQvulHPQnM5Ldgg,11858 +pip/_internal/req/req_file.py,sha256=VNC-G_JYy6JmGipezb9n5hAzZ470mvesSx3DBFtfIVM,14180 +pip/_internal/req/req_install.py,sha256=i21e6wHfTko7mQGziFoXqPbdByZ9Bnrz_bC6ZIJOwl8,40296 +pip/_internal/req/req_set.py,sha256=PaDc5EswLQhxBMFbuKbJ0frZbMNKocmA8OGqIWT-9EY,7860 +pip/_internal/req/req_tracker.py,sha256=wBpDzSDSYwpUfW4K43NrEOCCp1r6stuubfLc65Y95EM,3129 +pip/_internal/req/req_uninstall.py,sha256=rVOk8BRM_L9rsUUr9lmkV6Lm9N1Os7TEIDir6tT1Q7U,23105 +pip/_internal/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +pip/_internal/utils/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/utils/__pycache__/appdirs.cpython-38.pyc,, +pip/_internal/utils/__pycache__/compat.cpython-38.pyc,, +pip/_internal/utils/__pycache__/deprecation.cpython-38.pyc,, +pip/_internal/utils/__pycache__/encoding.cpython-38.pyc,, +pip/_internal/utils/__pycache__/filesystem.cpython-38.pyc,, +pip/_internal/utils/__pycache__/glibc.cpython-38.pyc,, +pip/_internal/utils/__pycache__/hashes.cpython-38.pyc,, +pip/_internal/utils/__pycache__/logging.cpython-38.pyc,, +pip/_internal/utils/__pycache__/marker_files.cpython-38.pyc,, +pip/_internal/utils/__pycache__/misc.cpython-38.pyc,, +pip/_internal/utils/__pycache__/models.cpython-38.pyc,, +pip/_internal/utils/__pycache__/outdated.cpython-38.pyc,, +pip/_internal/utils/__pycache__/packaging.cpython-38.pyc,, +pip/_internal/utils/__pycache__/setuptools_build.cpython-38.pyc,, +pip/_internal/utils/__pycache__/temp_dir.cpython-38.pyc,, +pip/_internal/utils/__pycache__/typing.cpython-38.pyc,, +pip/_internal/utils/__pycache__/ui.cpython-38.pyc,, +pip/_internal/utils/__pycache__/virtualenv.cpython-38.pyc,, +pip/_internal/utils/appdirs.py,sha256=r9i0BZLK9KcvrzI5tqlw8ehRTtSehWGERFLy7YppG3g,9398 +pip/_internal/utils/compat.py,sha256=4mi-czTysz5Ocuq-5K6BvISCii6_agyNwkBPNtKgYfM,9596 +pip/_internal/utils/deprecation.py,sha256=zcC388qvHnBLY1GalWEYnHyh3MXHQRe4-fOoyyZeQNQ,3209 +pip/_internal/utils/encoding.py,sha256=tudXCoAPe9fZvNK4cmWQs2frREZ-QuGCwF_SlTyz6cI,1218 +pip/_internal/utils/filesystem.py,sha256=ojaIDvOFOtkpKme5se6X2N8ARmQxu8cxvaaI-NFqVtk,990 +pip/_internal/utils/glibc.py,sha256=di3treHUThyeXCxqgRgp-72nTizWpC8skE7RLbewKv4,4295 +pip/_internal/utils/hashes.py,sha256=lF1VlTk2hOqnbmbiMN6GxJHTNQEDI9RzkBCUqBgSHok,3904 +pip/_internal/utils/logging.py,sha256=k-7sr-yFTLDCgcrmrErlwBp2dYMhq157vT3P-xzrB0U,12883 +pip/_internal/utils/marker_files.py,sha256=B-xFm0JZnrDStnA1jbQgKfDaMdXn53PqpZhtOJ-FWCc,595 +pip/_internal/utils/misc.py,sha256=3tmhB5Zojxswgg1zGdPgAdGvu2sYU6g0BLiAbc2vhZY,38796 +pip/_internal/utils/models.py,sha256=b7vdfIZrobxERktz8xZ7BqYnFLxoJzkWSeuq0JO9JYI,1041 +pip/_internal/utils/outdated.py,sha256=C7TK-XuCmBQ5DUpHBzq2jL-1p7DQft84foQziUyX2Ms,6292 +pip/_internal/utils/packaging.py,sha256=VtiwcAAL7LBi7tGL2je7LeW4bE11KMHGCsJ1NZY5XtM,3035 +pip/_internal/utils/setuptools_build.py,sha256=Jjf0MRzSG60UvDnWwWixg1rWM5dEuQ5sE8kb-5KwYFI,1239 +pip/_internal/utils/temp_dir.py,sha256=0Xq5ZlOd2OOeHwKM6hGy66gnMGAbyhio7DtjLHd7DFg,5339 +pip/_internal/utils/typing.py,sha256=bF73ImJzIaxLLEVwfEaSJzFGqV9LaxkQBvDULIyr1jI,1125 +pip/_internal/utils/ui.py,sha256=I2F3wRhWE9aere-cpCE0g9VPvgJRRLL8OC3FxXdj6_k,13768 +pip/_internal/utils/virtualenv.py,sha256=oSTrUMQUqmuXcDvQZGwV65w-hlvhBAqyQiWRxLf8fN0,891 +pip/_internal/vcs/__init__.py,sha256=9p9dzJZy7PR6TkHhqr-DnJTFIo6JopLgtHjHNrt85h4,597 +pip/_internal/vcs/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/vcs/__pycache__/bazaar.cpython-38.pyc,, +pip/_internal/vcs/__pycache__/git.cpython-38.pyc,, +pip/_internal/vcs/__pycache__/mercurial.cpython-38.pyc,, +pip/_internal/vcs/__pycache__/subversion.cpython-38.pyc,, +pip/_internal/vcs/__pycache__/versioncontrol.cpython-38.pyc,, +pip/_internal/vcs/bazaar.py,sha256=wI5WdFt_Mmnqcm0c7zn5wM3R44s7s28DNx5Yg7CJlSw,3182 +pip/_internal/vcs/git.py,sha256=pgTaCyWNBBfz6d0AxVnsLhft2i4XRe_hSTI_Xs7nkZg,12814 +pip/_internal/vcs/mercurial.py,sha256=YzJx76Q4Nveqf8s80g-AocnfpKwCoVeHy77c95aTBO4,3335 +pip/_internal/vcs/subversion.py,sha256=RuQJeToLicFp2itahUftlHKjyvDFWuCWuhHfdsP9oGs,11697 +pip/_internal/vcs/versioncontrol.py,sha256=NifBlL90ovO8WNzlt4r6HGlGbPqxNI5fUMfwLC-gMkE,19010 +pip/_internal/wheel.py,sha256=H3bdufsutvlXcLV0t3prIOTvq9m_Uc0JkLDoISZelD8,42309 +pip/_vendor/__init__.py,sha256=iip2nWwH_riYqnDnM0q4BJFrWE-XWjYfxCejJKct0WM,4654 +pip/_vendor/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/__pycache__/appdirs.cpython-38.pyc,, +pip/_vendor/__pycache__/distro.cpython-38.pyc,, +pip/_vendor/__pycache__/ipaddress.cpython-38.pyc,, +pip/_vendor/__pycache__/pyparsing.cpython-38.pyc,, +pip/_vendor/__pycache__/retrying.cpython-38.pyc,, +pip/_vendor/__pycache__/six.cpython-38.pyc,, +pip/_vendor/appdirs.py,sha256=BENKsvcA08IpccD9345-rMrg3aXWFA1q6BFEglnHg6I,24547 +pip/_vendor/cachecontrol/__init__.py,sha256=6cRPchVqkAkeUtYTSW8qCetjSqJo-GxP-n4VMVDbvmc,302 +pip/_vendor/cachecontrol/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-38.pyc,, +pip/_vendor/cachecontrol/__pycache__/adapter.cpython-38.pyc,, +pip/_vendor/cachecontrol/__pycache__/cache.cpython-38.pyc,, +pip/_vendor/cachecontrol/__pycache__/compat.cpython-38.pyc,, +pip/_vendor/cachecontrol/__pycache__/controller.cpython-38.pyc,, +pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-38.pyc,, +pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-38.pyc,, +pip/_vendor/cachecontrol/__pycache__/serialize.cpython-38.pyc,, +pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-38.pyc,, +pip/_vendor/cachecontrol/_cmd.py,sha256=URGE0KrA87QekCG3SGPatlSPT571dZTDjNa-ZXX3pDc,1295 +pip/_vendor/cachecontrol/adapter.py,sha256=eBGAtVNRZgtl_Kj5JV54miqL9YND-D0JZPahwY8kFtY,4863 +pip/_vendor/cachecontrol/cache.py,sha256=1fc4wJP8HYt1ycnJXeEw5pCpeBL2Cqxx6g9Fb0AYDWQ,805 +pip/_vendor/cachecontrol/caches/__init__.py,sha256=-gHNKYvaeD0kOk5M74eOrsSgIKUtC6i6GfbmugGweEo,86 +pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-38.pyc,, +pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-38.pyc,, +pip/_vendor/cachecontrol/caches/file_cache.py,sha256=8vrSzzGcdfEfICago1uSFbkumNJMGLbCdEkXsmUIExw,4177 +pip/_vendor/cachecontrol/caches/redis_cache.py,sha256=HxelMpNCo-dYr2fiJDwM3hhhRmxUYtB5tXm1GpAAT4Y,856 +pip/_vendor/cachecontrol/compat.py,sha256=kHNvMRdt6s_Xwqq_9qJmr9ou3wYMOMUMxPPcwNxT8Mc,695 +pip/_vendor/cachecontrol/controller.py,sha256=U7g-YwizQ2O5NRgK_MZreF1ntM4E49C3PuF3od-Vwz4,13698 +pip/_vendor/cachecontrol/filewrapper.py,sha256=vACKO8Llzu_ZWyjV1Fxn1MA4TGU60N5N3GSrAFdAY2Q,2533 +pip/_vendor/cachecontrol/heuristics.py,sha256=BFGHJ3yQcxvZizfo90LLZ04T_Z5XSCXvFotrp7Us0sc,4070 +pip/_vendor/cachecontrol/serialize.py,sha256=GebE34fgToyWwAsRPguh8hEPN6CqoG-5hRMXRsjVABQ,6954 +pip/_vendor/cachecontrol/wrapper.py,sha256=sfr9YHWx-5TwNz1H5rT6QOo8ggII6v3vbEDjQFwR6wc,671 +pip/_vendor/certifi/__init__.py,sha256=phsMyKTQP7MMe1wAHfhXPbQVxL3wXixOomxzNh5Cwa4,52 +pip/_vendor/certifi/__main__.py,sha256=NaCn6WtWME-zzVWQ2j4zFyl8cY4knDa9CwtHNIeFPhM,53 +pip/_vendor/certifi/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/certifi/__pycache__/__main__.cpython-38.pyc,, +pip/_vendor/certifi/__pycache__/core.cpython-38.pyc,, +pip/_vendor/certifi/cacert.pem,sha256=DddOv7pQyMB8zNNgiXSSFrPVn7EN8qbe7P6h_IYyuek,282085 +pip/_vendor/certifi/core.py,sha256=EuFc2BsToG5O1-qsx4BSjQ1r1-7WRtH87b1WflZOWhI,218 +pip/_vendor/chardet/__init__.py,sha256=YsP5wQlsHJ2auF1RZJfypiSrCA7_bQiRm3ES_NI76-Y,1559 +pip/_vendor/chardet/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/big5freq.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/big5prober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/chardistribution.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/charsetprober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/compat.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/cp949prober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/enums.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/escprober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/escsm.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/eucjpprober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/euckrfreq.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/euckrprober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/euctwfreq.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/euctwprober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/gb2312freq.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/gb2312prober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/hebrewprober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/jisfreq.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/jpcntx.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/langcyrillicmodel.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/langthaimodel.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/latin1prober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/mbcssm.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/sjisprober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/universaldetector.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/utf8prober.cpython-38.pyc,, +pip/_vendor/chardet/__pycache__/version.cpython-38.pyc,, +pip/_vendor/chardet/big5freq.py,sha256=D_zK5GyzoVsRes0HkLJziltFQX0bKCLOrFe9_xDvO_8,31254 +pip/_vendor/chardet/big5prober.py,sha256=kBxHbdetBpPe7xrlb-e990iot64g_eGSLd32lB7_h3M,1757 +pip/_vendor/chardet/chardistribution.py,sha256=3woWS62KrGooKyqz4zQSnjFbJpa6V7g02daAibTwcl8,9411 +pip/_vendor/chardet/charsetgroupprober.py,sha256=6bDu8YIiRuScX4ca9Igb0U69TA2PGXXDej6Cc4_9kO4,3787 +pip/_vendor/chardet/charsetprober.py,sha256=KSmwJErjypyj0bRZmC5F5eM7c8YQgLYIjZXintZNstg,5110 +pip/_vendor/chardet/cli/__init__.py,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1 +pip/_vendor/chardet/cli/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-38.pyc,, +pip/_vendor/chardet/cli/chardetect.py,sha256=DI8dlV3FBD0c0XA_y3sQ78z754DUv1J8n34RtDjOXNw,2774 +pip/_vendor/chardet/codingstatemachine.py,sha256=VYp_6cyyki5sHgXDSZnXW4q1oelHc3cu9AyQTX7uug8,3590 +pip/_vendor/chardet/compat.py,sha256=PKTzHkSbtbHDqS9PyujMbX74q1a8mMpeQTDVsQhZMRw,1134 +pip/_vendor/chardet/cp949prober.py,sha256=TZ434QX8zzBsnUvL_8wm4AQVTZ2ZkqEEQL_lNw9f9ow,1855 +pip/_vendor/chardet/enums.py,sha256=Aimwdb9as1dJKZaFNUH2OhWIVBVd6ZkJJ_WK5sNY8cU,1661 +pip/_vendor/chardet/escprober.py,sha256=kkyqVg1Yw3DIOAMJ2bdlyQgUFQhuHAW8dUGskToNWSc,3950 +pip/_vendor/chardet/escsm.py,sha256=RuXlgNvTIDarndvllNCk5WZBIpdCxQ0kcd9EAuxUh84,10510 +pip/_vendor/chardet/eucjpprober.py,sha256=iD8Jdp0ISRjgjiVN7f0e8xGeQJ5GM2oeZ1dA8nbSeUw,3749 +pip/_vendor/chardet/euckrfreq.py,sha256=-7GdmvgWez4-eO4SuXpa7tBiDi5vRXQ8WvdFAzVaSfo,13546 +pip/_vendor/chardet/euckrprober.py,sha256=MqFMTQXxW4HbzIpZ9lKDHB3GN8SP4yiHenTmf8g_PxY,1748 +pip/_vendor/chardet/euctwfreq.py,sha256=No1WyduFOgB5VITUA7PLyC5oJRNzRyMbBxaKI1l16MA,31621 +pip/_vendor/chardet/euctwprober.py,sha256=13p6EP4yRaxqnP4iHtxHOJ6R2zxHq1_m8hTRjzVZ95c,1747 +pip/_vendor/chardet/gb2312freq.py,sha256=JX8lsweKLmnCwmk8UHEQsLgkr_rP_kEbvivC4qPOrlc,20715 +pip/_vendor/chardet/gb2312prober.py,sha256=gGvIWi9WhDjE-xQXHvNIyrnLvEbMAYgyUSZ65HUfylw,1754 +pip/_vendor/chardet/hebrewprober.py,sha256=c3SZ-K7hvyzGY6JRAZxJgwJ_sUS9k0WYkvMY00YBYFo,13838 +pip/_vendor/chardet/jisfreq.py,sha256=vpmJv2Bu0J8gnMVRPHMFefTRvo_ha1mryLig8CBwgOg,25777 +pip/_vendor/chardet/jpcntx.py,sha256=PYlNqRUQT8LM3cT5FmHGP0iiscFlTWED92MALvBungo,19643 +pip/_vendor/chardet/langbulgarianmodel.py,sha256=1HqQS9Pbtnj1xQgxitJMvw8X6kKr5OockNCZWfEQrPE,12839 +pip/_vendor/chardet/langcyrillicmodel.py,sha256=LODajvsetH87yYDDQKA2CULXUH87tI223dhfjh9Zx9c,17948 +pip/_vendor/chardet/langgreekmodel.py,sha256=8YAW7bU8YwSJap0kIJSbPMw1BEqzGjWzqcqf0WgUKAA,12688 +pip/_vendor/chardet/langhebrewmodel.py,sha256=JSnqmE5E62tDLTPTvLpQsg5gOMO4PbdWRvV7Avkc0HA,11345 +pip/_vendor/chardet/langhungarianmodel.py,sha256=RhapYSG5l0ZaO-VV4Fan5sW0WRGQqhwBM61yx3yxyOA,12592 +pip/_vendor/chardet/langthaimodel.py,sha256=8l0173Gu_W6G8mxmQOTEF4ls2YdE7FxWf3QkSxEGXJQ,11290 +pip/_vendor/chardet/langturkishmodel.py,sha256=W22eRNJsqI6uWAfwXSKVWWnCerYqrI8dZQTm_M0lRFk,11102 +pip/_vendor/chardet/latin1prober.py,sha256=S2IoORhFk39FEFOlSFWtgVybRiP6h7BlLldHVclNkU8,5370 +pip/_vendor/chardet/mbcharsetprober.py,sha256=AR95eFH9vuqSfvLQZN-L5ijea25NOBCoXqw8s5O9xLQ,3413 +pip/_vendor/chardet/mbcsgroupprober.py,sha256=h6TRnnYq2OxG1WdD5JOyxcdVpn7dG0q-vB8nWr5mbh4,2012 +pip/_vendor/chardet/mbcssm.py,sha256=SY32wVIF3HzcjY3BaEspy9metbNSKxIIB0RKPn7tjpI,25481 +pip/_vendor/chardet/sbcharsetprober.py,sha256=LDSpCldDCFlYwUkGkwD2oFxLlPWIWXT09akH_2PiY74,5657 +pip/_vendor/chardet/sbcsgroupprober.py,sha256=1IprcCB_k1qfmnxGC6MBbxELlKqD3scW6S8YIwdeyXA,3546 +pip/_vendor/chardet/sjisprober.py,sha256=IIt-lZj0WJqK4rmUZzKZP4GJlE8KUEtFYVuY96ek5MQ,3774 +pip/_vendor/chardet/universaldetector.py,sha256=qL0174lSZE442eB21nnktT9_VcAye07laFWUeUrjttY,12485 +pip/_vendor/chardet/utf8prober.py,sha256=IdD8v3zWOsB8OLiyPi-y_fqwipRFxV9Nc1eKBLSuIEw,2766 +pip/_vendor/chardet/version.py,sha256=sp3B08mrDXB-pf3K9fqJ_zeDHOCLC8RrngQyDFap_7g,242 +pip/_vendor/colorama/__init__.py,sha256=lJdY6COz9uM_pXwuk9oLr0fp8H8q2RrUqN16GKabvq4,239 +pip/_vendor/colorama/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/colorama/__pycache__/ansi.cpython-38.pyc,, +pip/_vendor/colorama/__pycache__/ansitowin32.cpython-38.pyc,, +pip/_vendor/colorama/__pycache__/initialise.cpython-38.pyc,, +pip/_vendor/colorama/__pycache__/win32.cpython-38.pyc,, +pip/_vendor/colorama/__pycache__/winterm.cpython-38.pyc,, +pip/_vendor/colorama/ansi.py,sha256=Fi0un-QLqRm-v7o_nKiOqyC8PapBJK7DLV_q9LKtTO0,2524 +pip/_vendor/colorama/ansitowin32.py,sha256=u8QaqdqS_xYSfNkPM1eRJLHz6JMWPodaJaP0mxgHCDc,10462 +pip/_vendor/colorama/initialise.py,sha256=PprovDNxMTrvoNHFcL2NZjpH2XzDc8BLxLxiErfUl4k,1915 +pip/_vendor/colorama/win32.py,sha256=bJ8Il9jwaBN5BJ8bmN6FoYZ1QYuMKv2j8fGrXh7TJjw,5404 +pip/_vendor/colorama/winterm.py,sha256=2y_2b7Zsv34feAsP67mLOVc-Bgq51mdYGo571VprlrM,6438 +pip/_vendor/distlib/__init__.py,sha256=SkHYPuEQNQF2a2Cr18rfZ-LQyDqwwizn8tJE4seXPgU,587 +pip/_vendor/distlib/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/distlib/__pycache__/compat.cpython-38.pyc,, +pip/_vendor/distlib/__pycache__/database.cpython-38.pyc,, +pip/_vendor/distlib/__pycache__/index.cpython-38.pyc,, +pip/_vendor/distlib/__pycache__/locators.cpython-38.pyc,, +pip/_vendor/distlib/__pycache__/manifest.cpython-38.pyc,, +pip/_vendor/distlib/__pycache__/markers.cpython-38.pyc,, +pip/_vendor/distlib/__pycache__/metadata.cpython-38.pyc,, +pip/_vendor/distlib/__pycache__/resources.cpython-38.pyc,, +pip/_vendor/distlib/__pycache__/scripts.cpython-38.pyc,, +pip/_vendor/distlib/__pycache__/util.cpython-38.pyc,, +pip/_vendor/distlib/__pycache__/version.cpython-38.pyc,, +pip/_vendor/distlib/__pycache__/wheel.cpython-38.pyc,, +pip/_vendor/distlib/_backport/__init__.py,sha256=bqS_dTOH6uW9iGgd0uzfpPjo6vZ4xpPZ7kyfZJ2vNaw,274 +pip/_vendor/distlib/_backport/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/distlib/_backport/__pycache__/misc.cpython-38.pyc,, +pip/_vendor/distlib/_backport/__pycache__/shutil.cpython-38.pyc,, +pip/_vendor/distlib/_backport/__pycache__/sysconfig.cpython-38.pyc,, +pip/_vendor/distlib/_backport/__pycache__/tarfile.cpython-38.pyc,, +pip/_vendor/distlib/_backport/misc.py,sha256=KWecINdbFNOxSOP1fGF680CJnaC6S4fBRgEtaYTw0ig,971 +pip/_vendor/distlib/_backport/shutil.py,sha256=VW1t3uYqUjWZH7jV-6QiimLhnldoV5uIpH4EuiT1jfw,25647 +pip/_vendor/distlib/_backport/sysconfig.cfg,sha256=swZKxq9RY5e9r3PXCrlvQPMsvOdiWZBTHLEbqS8LJLU,2617 +pip/_vendor/distlib/_backport/sysconfig.py,sha256=JdJ9ztRy4Hc-b5-VS74x3nUtdEIVr_OBvMsIb8O2sjc,26964 +pip/_vendor/distlib/_backport/tarfile.py,sha256=Ihp7rXRcjbIKw8COm9wSePV9ARGXbSF9gGXAMn2Q-KU,92628 +pip/_vendor/distlib/compat.py,sha256=xdNZmqFN5HwF30HjRn5M415pcC2kgXRBXn767xS8v-M,41404 +pip/_vendor/distlib/database.py,sha256=-KJH63AJ7hqjLtGCwOTrionhKr2Vsytdwkjyo8UdEco,51029 +pip/_vendor/distlib/index.py,sha256=SXKzpQCERctxYDMp_OLee2f0J0e19ZhGdCIoMlUfUQM,21066 +pip/_vendor/distlib/locators.py,sha256=bqzEWP3Ad8UE3D1rmzW1pgzVTKkY4rDUA_EWIVYli54,51807 +pip/_vendor/distlib/manifest.py,sha256=nQEhYmgoreaBZzyFzwYsXxJARu3fo4EkunU163U16iE,14811 +pip/_vendor/distlib/markers.py,sha256=6Ac3cCfFBERexiESWIOXmg-apIP8l2esafNSX3KMy-8,4387 +pip/_vendor/distlib/metadata.py,sha256=OhbCKmf5lswE8unWBopI1hj7tRpHp4ZbFvU4d6aAEMM,40234 +pip/_vendor/distlib/resources.py,sha256=2FGv0ZHF14KXjLIlL0R991lyQQGcewOS4mJ-5n-JVnc,10766 +pip/_vendor/distlib/scripts.py,sha256=W24OXnZUmgRX_XtDrVZdfc-Frf4X4_cybvhP87iR-QU,16290 +pip/_vendor/distlib/t32.exe,sha256=y8Yu3yao6zZrELYGIisxkhnQLOAOvpiXft8_Y9I8vyU,92672 +pip/_vendor/distlib/t64.exe,sha256=qt1MpKO2NLqU8t1lD1T0frfFm5zwHm3mz7pLvmJ2kMI,102912 +pip/_vendor/distlib/util.py,sha256=TvdqcwncBHaQbNw0jkXRvSZvt1fbdgE8HQW5wJwzvv4,59790 +pip/_vendor/distlib/version.py,sha256=_n7F6juvQGAcn769E_SHa7fOcf5ERlEVymJ_EjPRwGw,23391 +pip/_vendor/distlib/w32.exe,sha256=f98Etq_1giFgIQxrEh-sOAeO8qVtWqpDbGxdUucJ6pw,89088 +pip/_vendor/distlib/w64.exe,sha256=6Hs-Wn0vXBHA6Qd76IlalqYXqrN80DCPpdoeIQzPRms,99840 +pip/_vendor/distlib/wheel.py,sha256=2lviV6L4IvTP5DRkKE0HGpClvdoTJQHZJLfTQ6dfn2A,40437 +pip/_vendor/distro.py,sha256=X2So5kjrRKyMbQJ90Xgy93HU5eFtujCzKaYNeoy1k1c,43251 +pip/_vendor/html5lib/__init__.py,sha256=Ztrn7UvF-wIFAgRBBa0ML-Gu5AffH3BPX_INJx4SaBI,1162 +pip/_vendor/html5lib/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/html5lib/__pycache__/_ihatexml.cpython-38.pyc,, +pip/_vendor/html5lib/__pycache__/_inputstream.cpython-38.pyc,, +pip/_vendor/html5lib/__pycache__/_tokenizer.cpython-38.pyc,, +pip/_vendor/html5lib/__pycache__/_utils.cpython-38.pyc,, +pip/_vendor/html5lib/__pycache__/constants.cpython-38.pyc,, +pip/_vendor/html5lib/__pycache__/html5parser.cpython-38.pyc,, +pip/_vendor/html5lib/__pycache__/serializer.cpython-38.pyc,, +pip/_vendor/html5lib/_ihatexml.py,sha256=3LBtJMlzgwM8vpQiU1TvGmEEmNH72sV0yD8yS53y07A,16705 +pip/_vendor/html5lib/_inputstream.py,sha256=bPUWcAfJScK4xkjQQaG_HsI2BvEVbFvI0AsodDYPQj0,32552 +pip/_vendor/html5lib/_tokenizer.py,sha256=YAaOEBD6qc5ISq9Xt9Nif1OFgcybTTfMdwqBkZhpAq4,76580 +pip/_vendor/html5lib/_trie/__init__.py,sha256=8VR1bcgD2OpeS2XExpu5yBhP_Q1K-lwKbBKICBPf1kU,289 +pip/_vendor/html5lib/_trie/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/html5lib/_trie/__pycache__/_base.cpython-38.pyc,, +pip/_vendor/html5lib/_trie/__pycache__/datrie.cpython-38.pyc,, +pip/_vendor/html5lib/_trie/__pycache__/py.cpython-38.pyc,, +pip/_vendor/html5lib/_trie/_base.py,sha256=CaybYyMro8uERQYjby2tTeSUatnWDfWroUN9N7ety5w,1013 +pip/_vendor/html5lib/_trie/datrie.py,sha256=EQpqSfkZRuTbE-DuhW7xMdVDxdZNZ0CfmnYfHA_3zxM,1178 +pip/_vendor/html5lib/_trie/py.py,sha256=wXmQLrZRf4MyWNyg0m3h81m9InhLR7GJ002mIIZh-8o,1775 +pip/_vendor/html5lib/_utils.py,sha256=ismpASeqa2jqEPQjHUj8vReAf7yIoKnvLN5fuOw6nv0,4015 +pip/_vendor/html5lib/constants.py,sha256=4lmZWLtEPRLnl8NzftOoYTJdo6jpeMtP6dqQC0g_bWQ,83518 +pip/_vendor/html5lib/filters/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +pip/_vendor/html5lib/filters/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/html5lib/filters/__pycache__/alphabeticalattributes.cpython-38.pyc,, +pip/_vendor/html5lib/filters/__pycache__/base.cpython-38.pyc,, +pip/_vendor/html5lib/filters/__pycache__/inject_meta_charset.cpython-38.pyc,, +pip/_vendor/html5lib/filters/__pycache__/lint.cpython-38.pyc,, +pip/_vendor/html5lib/filters/__pycache__/optionaltags.cpython-38.pyc,, +pip/_vendor/html5lib/filters/__pycache__/sanitizer.cpython-38.pyc,, +pip/_vendor/html5lib/filters/__pycache__/whitespace.cpython-38.pyc,, +pip/_vendor/html5lib/filters/alphabeticalattributes.py,sha256=lViZc2JMCclXi_5gduvmdzrRxtO5Xo9ONnbHBVCsykU,919 +pip/_vendor/html5lib/filters/base.py,sha256=z-IU9ZAYjpsVsqmVt7kuWC63jR11hDMr6CVrvuao8W0,286 +pip/_vendor/html5lib/filters/inject_meta_charset.py,sha256=egDXUEHXmAG9504xz0K6ALDgYkvUrC2q15YUVeNlVQg,2945 +pip/_vendor/html5lib/filters/lint.py,sha256=jk6q56xY0ojiYfvpdP-OZSm9eTqcAdRqhCoPItemPYA,3643 +pip/_vendor/html5lib/filters/optionaltags.py,sha256=8lWT75J0aBOHmPgfmqTHSfPpPMp01T84NKu0CRedxcE,10588 +pip/_vendor/html5lib/filters/sanitizer.py,sha256=4ON02KNjuqda1lCw5_JCUZxb0BzWR5M7ON84dtJ7dm0,26248 +pip/_vendor/html5lib/filters/whitespace.py,sha256=8eWqZxd4UC4zlFGW6iyY6f-2uuT8pOCSALc3IZt7_t4,1214 +pip/_vendor/html5lib/html5parser.py,sha256=g5g2ezkusHxhi7b23vK_-d6K6BfIJRbqIQmvQ9z4EgI,118963 +pip/_vendor/html5lib/serializer.py,sha256=yfcfBHse2wDs6ojxn-kieJjLT5s1ipilQJ0gL3-rJis,15758 +pip/_vendor/html5lib/treeadapters/__init__.py,sha256=A0rY5gXIe4bJOiSGRO_j_tFhngRBO8QZPzPtPw5dFzo,679 +pip/_vendor/html5lib/treeadapters/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/html5lib/treeadapters/__pycache__/genshi.cpython-38.pyc,, +pip/_vendor/html5lib/treeadapters/__pycache__/sax.cpython-38.pyc,, +pip/_vendor/html5lib/treeadapters/genshi.py,sha256=CH27pAsDKmu4ZGkAUrwty7u0KauGLCZRLPMzaO3M5vo,1715 +pip/_vendor/html5lib/treeadapters/sax.py,sha256=BKS8woQTnKiqeffHsxChUqL4q2ZR_wb5fc9MJ3zQC8s,1776 +pip/_vendor/html5lib/treebuilders/__init__.py,sha256=AysSJyvPfikCMMsTVvaxwkgDieELD5dfR8FJIAuq7hY,3592 +pip/_vendor/html5lib/treebuilders/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/html5lib/treebuilders/__pycache__/base.cpython-38.pyc,, +pip/_vendor/html5lib/treebuilders/__pycache__/dom.cpython-38.pyc,, +pip/_vendor/html5lib/treebuilders/__pycache__/etree.cpython-38.pyc,, +pip/_vendor/html5lib/treebuilders/__pycache__/etree_lxml.cpython-38.pyc,, +pip/_vendor/html5lib/treebuilders/base.py,sha256=wQGp5yy22TNG8tJ6aREe4UUeTR7A99dEz0BXVaedWb4,14579 +pip/_vendor/html5lib/treebuilders/dom.py,sha256=22whb0C71zXIsai5mamg6qzBEiigcBIvaDy4Asw3at0,8925 +pip/_vendor/html5lib/treebuilders/etree.py,sha256=aqIBOGj_dFYqBURIcTegGNBhAIJOw5iFDHb4jrkYH-8,12764 +pip/_vendor/html5lib/treebuilders/etree_lxml.py,sha256=9V0dXxbJYYq-Skgb5-_OL2NkVYpjioEb4CHajo0e9yI,14122 +pip/_vendor/html5lib/treewalkers/__init__.py,sha256=yhXxHpjlSqfQyUag3v8-vWjMPriFBU8YRAPNpDgBTn8,5714 +pip/_vendor/html5lib/treewalkers/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/html5lib/treewalkers/__pycache__/base.cpython-38.pyc,, +pip/_vendor/html5lib/treewalkers/__pycache__/dom.cpython-38.pyc,, +pip/_vendor/html5lib/treewalkers/__pycache__/etree.cpython-38.pyc,, +pip/_vendor/html5lib/treewalkers/__pycache__/etree_lxml.cpython-38.pyc,, +pip/_vendor/html5lib/treewalkers/__pycache__/genshi.cpython-38.pyc,, +pip/_vendor/html5lib/treewalkers/base.py,sha256=ouiOsuSzvI0KgzdWP8PlxIaSNs9falhbiinAEc_UIJY,7476 +pip/_vendor/html5lib/treewalkers/dom.py,sha256=EHyFR8D8lYNnyDU9lx_IKigVJRyecUGua0mOi7HBukc,1413 +pip/_vendor/html5lib/treewalkers/etree.py,sha256=sz1o6mmE93NQ53qJFDO7HKyDtuwgK-Ay3qSFZPC6u00,4550 +pip/_vendor/html5lib/treewalkers/etree_lxml.py,sha256=sY6wfRshWTllu6n48TPWpKsQRPp-0CQrT0hj_AdzHSU,6309 +pip/_vendor/html5lib/treewalkers/genshi.py,sha256=4D2PECZ5n3ZN3qu3jMl9yY7B81jnQApBQSVlfaIuYbA,2309 +pip/_vendor/idna/__init__.py,sha256=9Nt7xpyet3DmOrPUGooDdAwmHZZu1qUAy2EaJ93kGiQ,58 +pip/_vendor/idna/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/idna/__pycache__/codec.cpython-38.pyc,, +pip/_vendor/idna/__pycache__/compat.cpython-38.pyc,, +pip/_vendor/idna/__pycache__/core.cpython-38.pyc,, +pip/_vendor/idna/__pycache__/idnadata.cpython-38.pyc,, +pip/_vendor/idna/__pycache__/intranges.cpython-38.pyc,, +pip/_vendor/idna/__pycache__/package_data.cpython-38.pyc,, +pip/_vendor/idna/__pycache__/uts46data.cpython-38.pyc,, +pip/_vendor/idna/codec.py,sha256=lvYb7yu7PhAqFaAIAdWcwgaWI2UmgseUua-1c0AsG0A,3299 +pip/_vendor/idna/compat.py,sha256=R-h29D-6mrnJzbXxymrWUW7iZUvy-26TQwZ0ij57i4U,232 +pip/_vendor/idna/core.py,sha256=JDCZZ_PLESqIgEbU8mPyoEufWwoOiIqygA17-QZIe3s,11733 +pip/_vendor/idna/idnadata.py,sha256=HXaPFw6_YAJ0qppACPu0YLAULtRs3QovRM_CCZHGdY0,40899 +pip/_vendor/idna/intranges.py,sha256=TY1lpxZIQWEP6tNqjZkFA5hgoMWOj1OBmnUG8ihT87E,1749 +pip/_vendor/idna/package_data.py,sha256=kIzeKKXEouXLR4srqwf9Q3zv-NffKSOz5aSDOJARPB0,21 +pip/_vendor/idna/uts46data.py,sha256=oLyNZ1pBaiBlj9zFzLFRd_P7J8MkRcgDisjExZR_4MY,198292 +pip/_vendor/ipaddress.py,sha256=2OgbkeAD2rLkcXqbcvof3J5R7lRwjNLoBySyTkBtKnc,79852 +pip/_vendor/lockfile/__init__.py,sha256=Tqpz90DwKYfhPsfzVOJl84TL87pdFE5ePNHdXAxs4Tk,9371 +pip/_vendor/lockfile/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/lockfile/__pycache__/linklockfile.cpython-38.pyc,, +pip/_vendor/lockfile/__pycache__/mkdirlockfile.cpython-38.pyc,, +pip/_vendor/lockfile/__pycache__/pidlockfile.cpython-38.pyc,, +pip/_vendor/lockfile/__pycache__/sqlitelockfile.cpython-38.pyc,, +pip/_vendor/lockfile/__pycache__/symlinklockfile.cpython-38.pyc,, +pip/_vendor/lockfile/linklockfile.py,sha256=C7OH3H4GdK68u4FQgp8fkP2kO4fyUTSyj3X6blgfobc,2652 +pip/_vendor/lockfile/mkdirlockfile.py,sha256=e3qgIL-etZMLsS-3ft19iW_8IQ360HNkGOqE3yBKsUw,3096 +pip/_vendor/lockfile/pidlockfile.py,sha256=ukH9uk6NFuxyVmG5QiWw4iKq3fT7MjqUguX95avYPIY,6090 +pip/_vendor/lockfile/sqlitelockfile.py,sha256=o2TMkMRY0iwn-iL1XMRRIFStMUkS4i3ajceeYNntKFg,5506 +pip/_vendor/lockfile/symlinklockfile.py,sha256=ABwXXmvTHvCl5viPblShL3PG-gGsLiT1roAMfDRwhi8,2616 +pip/_vendor/msgpack/__init__.py,sha256=TF3o2_Ao3xbsvpOlmVZdthtsb7TkMW9seSJkXlW0dHE,1630 +pip/_vendor/msgpack/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/msgpack/__pycache__/_version.cpython-38.pyc,, +pip/_vendor/msgpack/__pycache__/exceptions.cpython-38.pyc,, +pip/_vendor/msgpack/__pycache__/fallback.cpython-38.pyc,, +pip/_vendor/msgpack/_version.py,sha256=ldul7tIj_IHxvYxbEiEX1QhElrhQsA2ikYSM987iw1U,20 +pip/_vendor/msgpack/exceptions.py,sha256=dCTWei8dpkrMsQDcjQk74ATl9HsIBH0ybt8zOPNqMYc,1081 +pip/_vendor/msgpack/fallback.py,sha256=-FKXOBCF4CUs9QEOqAlssI-IZA0jBRa27VieFCngMC4,37491 +pip/_vendor/packaging/__about__.py,sha256=Wg0-hNgTU2_lBZcGBh5pm1R9yroQ3rv-X0rig8KjA6o,744 +pip/_vendor/packaging/__init__.py,sha256=6enbp5XgRfjBjsI9-bn00HjHf5TH21PDMOKkJW8xw-w,562 +pip/_vendor/packaging/__pycache__/__about__.cpython-38.pyc,, +pip/_vendor/packaging/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/packaging/__pycache__/_compat.cpython-38.pyc,, +pip/_vendor/packaging/__pycache__/_structures.cpython-38.pyc,, +pip/_vendor/packaging/__pycache__/markers.cpython-38.pyc,, +pip/_vendor/packaging/__pycache__/requirements.cpython-38.pyc,, +pip/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc,, +pip/_vendor/packaging/__pycache__/utils.cpython-38.pyc,, +pip/_vendor/packaging/__pycache__/version.cpython-38.pyc,, +pip/_vendor/packaging/_compat.py,sha256=Ugdm-qcneSchW25JrtMIKgUxfEEBcCAz6WrEeXeqz9o,865 +pip/_vendor/packaging/_structures.py,sha256=pVd90XcXRGwpZRB_qdFuVEibhCHpX_bL5zYr9-N0mc8,1416 +pip/_vendor/packaging/markers.py,sha256=-QjvJkhSJBxBogO9J_EpPQudHaaLV3rgVYsBDqn-ZLc,8234 +pip/_vendor/packaging/requirements.py,sha256=grcnFU8x7KD230JaFLXtWl3VClLuOmsOy4c-m55tOWs,4700 +pip/_vendor/packaging/specifiers.py,sha256=0ZzQpcUnvrQ6LjR-mQRLzMr8G6hdRv-mY0VSf_amFtI,27778 +pip/_vendor/packaging/utils.py,sha256=VaTC0Ei7zO2xl9ARiWmz2YFLFt89PuuhLbAlXMyAGms,1520 +pip/_vendor/packaging/version.py,sha256=Npdwnb8OHedj_2L86yiUqscujb7w_i5gmSK1PhOAFzg,11978 +pip/_vendor/pep517/__init__.py,sha256=nOY747zTld3oTdEetBG6DWxEcZXTeOQk0aHvbR-sa5w,84 +pip/_vendor/pep517/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/pep517/__pycache__/_in_process.cpython-38.pyc,, +pip/_vendor/pep517/__pycache__/build.cpython-38.pyc,, +pip/_vendor/pep517/__pycache__/check.cpython-38.pyc,, +pip/_vendor/pep517/__pycache__/colorlog.cpython-38.pyc,, +pip/_vendor/pep517/__pycache__/compat.cpython-38.pyc,, +pip/_vendor/pep517/__pycache__/envbuild.cpython-38.pyc,, +pip/_vendor/pep517/__pycache__/wrappers.cpython-38.pyc,, +pip/_vendor/pep517/_in_process.py,sha256=xMY2kLutkjCti5WqTmKOLRRL3o8Ds_k-fObFyuMv1tk,6061 +pip/_vendor/pep517/build.py,sha256=-n8PT-ugS1TdqoTUY1vatDQjrLtx48K_-Quu2MuQBiA,2699 +pip/_vendor/pep517/check.py,sha256=Lu7nMdYu1JVV58fE3hv-d_avTy5h0yO9LsIzAt82Clk,5885 +pip/_vendor/pep517/colorlog.py,sha256=Tk9AuYm_cLF3BKTBoSTJt9bRryn0aFojIQOwbfVUTxQ,4098 +pip/_vendor/pep517/compat.py,sha256=4SFG4QN-cNj8ebSa0wV0HUtEEQWwmbok2a0uk1gYEOM,631 +pip/_vendor/pep517/envbuild.py,sha256=9-u4KffexPMEm52rTaIjEOxsCAd2DMByxzv5H566QLw,5763 +pip/_vendor/pep517/wrappers.py,sha256=9dZn-q7F5KyQKUJMie2uKwur2FG0CLXz_kLZzkJOhZc,5912 +pip/_vendor/pkg_resources/__init__.py,sha256=ZVHzk7ZiFIIgE2RTJj8F7wwjdMGrAngMWtQo-rGNsm4,107910 +pip/_vendor/pkg_resources/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/pkg_resources/__pycache__/py31compat.cpython-38.pyc,, +pip/_vendor/pkg_resources/py31compat.py,sha256=CRk8fkiPRDLsbi5pZcKsHI__Pbmh_94L8mr9Qy9Ab2U,562 +pip/_vendor/progress/__init__.py,sha256=fcbQQXo5np2CoQyhSH5XprkicwLZNLePR3uIahznSO0,4857 +pip/_vendor/progress/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/progress/__pycache__/bar.cpython-38.pyc,, +pip/_vendor/progress/__pycache__/counter.cpython-38.pyc,, +pip/_vendor/progress/__pycache__/spinner.cpython-38.pyc,, +pip/_vendor/progress/bar.py,sha256=QuDuVNcmXgpxtNtxO0Fq72xKigxABaVmxYGBw4J3Z_E,2854 +pip/_vendor/progress/counter.py,sha256=MznyBrvPWrOlGe4MZAlGUb9q3aODe6_aNYeAE_VNoYA,1372 +pip/_vendor/progress/spinner.py,sha256=k8JbDW94T0-WXuXfxZIFhdoNPYp3jfnpXqBnfRv5fGs,1380 +pip/_vendor/pyparsing.py,sha256=sxGUe_YcWBB5ZoHec0m1iJtgcj4iKv_SGfdA_zVCYII,245385 +pip/_vendor/pytoml/__init__.py,sha256=W_SKx36Hsew-Fty36BOpreLm4uF4V_Tgkm_z9rIoOE8,127 +pip/_vendor/pytoml/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/pytoml/__pycache__/core.cpython-38.pyc,, +pip/_vendor/pytoml/__pycache__/parser.cpython-38.pyc,, +pip/_vendor/pytoml/__pycache__/test.cpython-38.pyc,, +pip/_vendor/pytoml/__pycache__/utils.cpython-38.pyc,, +pip/_vendor/pytoml/__pycache__/writer.cpython-38.pyc,, +pip/_vendor/pytoml/core.py,sha256=9CrLLTs1PdWjEwRnYzt_i4dhHcZvGxs_GsMlYAX3iY4,509 +pip/_vendor/pytoml/parser.py,sha256=2tDXkldqPQJhyadXzL2rGhVbjUyBNeXXhaEfncHl2iQ,10326 +pip/_vendor/pytoml/test.py,sha256=2nQs4aX3XQEaaQCx6x_OJTS2Hb0_IiTZRqNOeDmLCzo,1021 +pip/_vendor/pytoml/utils.py,sha256=JCLHx77Hu1R3F-bRgiROIiKyCzLwyebnp5P35cRJxWs,1665 +pip/_vendor/pytoml/writer.py,sha256=WbNNQg3sh_V-s3kt88LkNNbxEq6pPDdhRE-daJzArcI,3198 +pip/_vendor/requests/__init__.py,sha256=ONVsH6kJuPTV9nf-XVoubWsVX3qVtjCyju42kTW6Uug,4074 +pip/_vendor/requests/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/__version__.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/_internal_utils.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/adapters.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/api.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/auth.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/certs.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/compat.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/cookies.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/exceptions.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/help.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/hooks.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/models.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/packages.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/sessions.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/status_codes.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/structures.cpython-38.pyc,, +pip/_vendor/requests/__pycache__/utils.cpython-38.pyc,, +pip/_vendor/requests/__version__.py,sha256=Bm-GFstQaFezsFlnmEMrJDe8JNROz9n2XXYtODdvjjc,436 +pip/_vendor/requests/_internal_utils.py,sha256=Zx3PnEUccyfsB-ie11nZVAW8qClJy0gx1qNME7rgT18,1096 +pip/_vendor/requests/adapters.py,sha256=e-bmKEApNVqFdylxuMJJfiaHdlmS_zhWhIMEzlHvGuc,21548 +pip/_vendor/requests/api.py,sha256=fbUo11QoLOoNgWU6FfvNz8vMj9bE_cMmICXBa7TZHJs,6271 +pip/_vendor/requests/auth.py,sha256=QB2-cSUj1jrvWZfPXttsZpyAacQgtKLVk14vQW9TpSE,10206 +pip/_vendor/requests/certs.py,sha256=nXRVq9DtGmv_1AYbwjTu9UrgAcdJv05ZvkNeaoLOZxY,465 +pip/_vendor/requests/compat.py,sha256=FZX4Q_EMKiMnhZpZ3g_gOsT-j2ca9ij2gehDx1cwYeo,1941 +pip/_vendor/requests/cookies.py,sha256=Y-bKX6TvW3FnYlE6Au0SXtVVWcaNdFvuAwQxw-G0iTI,18430 +pip/_vendor/requests/exceptions.py,sha256=-mLam3TAx80V09EaH3H-ZxR61eAVuLRZ8zgBBSLjK44,3197 +pip/_vendor/requests/help.py,sha256=SJPVcoXeo7KfK4AxJN5eFVQCjr0im87tU2n7ubLsksU,3578 +pip/_vendor/requests/hooks.py,sha256=QReGyy0bRcr5rkwCuObNakbYsc7EkiKeBwG4qHekr2Q,757 +pip/_vendor/requests/models.py,sha256=6s-37iAqXVptq8z7U_LoH_pbIPrCQUm_Z8QuIGE29Q0,34275 +pip/_vendor/requests/packages.py,sha256=njJmVifY4aSctuW3PP5EFRCxjEwMRDO6J_feG2dKWsI,695 +pip/_vendor/requests/sessions.py,sha256=DjbCotDW6xSAaBsjbW-L8l4N0UcwmrxVNgSrZgIjGWM,29332 +pip/_vendor/requests/status_codes.py,sha256=XWlcpBjbCtq9sSqpH9_KKxgnLTf9Z__wCWolq21ySlg,4129 +pip/_vendor/requests/structures.py,sha256=zoP8qly2Jak5e89HwpqjN1z2diztI-_gaqts1raJJBc,2981 +pip/_vendor/requests/utils.py,sha256=LtPJ1db6mJff2TJSJWKi7rBpzjPS3mSOrjC9zRhoD3A,30049 +pip/_vendor/retrying.py,sha256=k3fflf5_Mm0XcIJYhB7Tj34bqCCPhUDkYbx1NvW2FPE,9972 +pip/_vendor/six.py,sha256=h9jch2pS86y4R36pKRS3LOYUCVFNIJMRwjZ4fJDtJ44,32452 +pip/_vendor/urllib3/__init__.py,sha256=dW1kWCz7bYGr-1q7xbDvJ_0_GwfyJtWq4VaLIzMcviA,2721 +pip/_vendor/urllib3/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/urllib3/__pycache__/_collections.cpython-38.pyc,, +pip/_vendor/urllib3/__pycache__/connection.cpython-38.pyc,, +pip/_vendor/urllib3/__pycache__/connectionpool.cpython-38.pyc,, +pip/_vendor/urllib3/__pycache__/exceptions.cpython-38.pyc,, +pip/_vendor/urllib3/__pycache__/fields.cpython-38.pyc,, +pip/_vendor/urllib3/__pycache__/filepost.cpython-38.pyc,, +pip/_vendor/urllib3/__pycache__/poolmanager.cpython-38.pyc,, +pip/_vendor/urllib3/__pycache__/request.cpython-38.pyc,, +pip/_vendor/urllib3/__pycache__/response.cpython-38.pyc,, +pip/_vendor/urllib3/_collections.py,sha256=-CAKsDE-WdubAjlBSZLx7b0e7WKenaNGwWvGLDEF1TM,10746 +pip/_vendor/urllib3/connection.py,sha256=hdUK2hwFNWlKxpm7JbY_YxGYJWbe6s0AYUSt9wguHk0,15001 +pip/_vendor/urllib3/connectionpool.py,sha256=jkmLBXUD8wB0exYjDoEsg_cXVZUv-iDbhC3vAUUH82Q,35307 +pip/_vendor/urllib3/contrib/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-38.pyc,, +pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-38.pyc,, +pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-38.pyc,, +pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-38.pyc,, +pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-38.pyc,, +pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-38.pyc,, +pip/_vendor/urllib3/contrib/_appengine_environ.py,sha256=lhYXvB5_oGKSeurX7za3XhcGyERvNjXRQ3eJp2GmQ3M,717 +pip/_vendor/urllib3/contrib/_securetransport/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-38.pyc,, +pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-38.pyc,, +pip/_vendor/urllib3/contrib/_securetransport/bindings.py,sha256=6ZRejHBpquHtJaXPDm0cBsEwOBe2l9bTnDvVzd0HwJw,17576 +pip/_vendor/urllib3/contrib/_securetransport/low_level.py,sha256=Umy5u-3Z957GirdapnicXVOpHaM4xdOZABJuJxfaeJA,12162 +pip/_vendor/urllib3/contrib/appengine.py,sha256=VvDpkc5gf9dTXNxXmyG1mPdON_3DrYG_eW4uOqN98oQ,10938 +pip/_vendor/urllib3/contrib/ntlmpool.py,sha256=5ZpMF7N9B6NEjVU-r-xjDOV_-hkNvsDoNc84J2yqauI,4459 +pip/_vendor/urllib3/contrib/pyopenssl.py,sha256=raR9jRVPK485CjBp9emmWfoZIyMA1b3vcYJ2-CLg03A,16468 +pip/_vendor/urllib3/contrib/securetransport.py,sha256=IfPZ2wA3x3NXxHjKr--Q7Xz4A37ZSyWHn_1WvGxvTKQ,32826 +pip/_vendor/urllib3/contrib/socks.py,sha256=ZJ7lEUlErvAgQkd4xo_xvfx-acym2tDtJqyE0It4VRI,7012 +pip/_vendor/urllib3/exceptions.py,sha256=rFeIfBNKC8KJ61ux-MtJyJlEC9G9ggkmCeF751JwVR4,6604 +pip/_vendor/urllib3/fields.py,sha256=0EYvHsgnUflhb-UhMMVjAwiRp1InCe-uy1McDD6nhPU,8575 +pip/_vendor/urllib3/filepost.py,sha256=40CROlpRKVBpFUkD0R6wJf_PpvbcRQRFUu0OOQlFkKM,2436 +pip/_vendor/urllib3/packages/__init__.py,sha256=nlChrGzkjCkmhCX9HrF_qHPUgosfsPQkVIJxiiLhk9g,109 +pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/urllib3/packages/__pycache__/six.cpython-38.pyc,, +pip/_vendor/urllib3/packages/backports/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-38.pyc,, +pip/_vendor/urllib3/packages/backports/makefile.py,sha256=so2z9BiNM8kh38Ve5tomQP_mp2_ubEqzdlCpLZKzzCI,1456 +pip/_vendor/urllib3/packages/rfc3986/__init__.py,sha256=Y2dGb08ZJuqIrAqfmrGMpNi2zjzKVTxfeZ8iF-Db338,1562 +pip/_vendor/urllib3/packages/rfc3986/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/urllib3/packages/rfc3986/__pycache__/_mixin.cpython-38.pyc,, +pip/_vendor/urllib3/packages/rfc3986/__pycache__/abnf_regexp.cpython-38.pyc,, +pip/_vendor/urllib3/packages/rfc3986/__pycache__/api.cpython-38.pyc,, +pip/_vendor/urllib3/packages/rfc3986/__pycache__/builder.cpython-38.pyc,, +pip/_vendor/urllib3/packages/rfc3986/__pycache__/compat.cpython-38.pyc,, +pip/_vendor/urllib3/packages/rfc3986/__pycache__/exceptions.cpython-38.pyc,, +pip/_vendor/urllib3/packages/rfc3986/__pycache__/iri.cpython-38.pyc,, +pip/_vendor/urllib3/packages/rfc3986/__pycache__/misc.cpython-38.pyc,, +pip/_vendor/urllib3/packages/rfc3986/__pycache__/normalizers.cpython-38.pyc,, +pip/_vendor/urllib3/packages/rfc3986/__pycache__/parseresult.cpython-38.pyc,, +pip/_vendor/urllib3/packages/rfc3986/__pycache__/uri.cpython-38.pyc,, +pip/_vendor/urllib3/packages/rfc3986/__pycache__/validators.cpython-38.pyc,, +pip/_vendor/urllib3/packages/rfc3986/_mixin.py,sha256=fnxYtuAQwo6RlGZzsawcICxUhLqQ_Tyob_Kamy-92QU,13214 +pip/_vendor/urllib3/packages/rfc3986/abnf_regexp.py,sha256=0cPq-UrpihByHkDsZd_7p6ruqYh2MuqCqIjc67PFHCs,9081 +pip/_vendor/urllib3/packages/rfc3986/api.py,sha256=5wYJ3IvszICEY5cgeLTtLRWCyc9mJhgZ_4QZVtYoSKI,3887 +pip/_vendor/urllib3/packages/rfc3986/builder.py,sha256=BFbuFFZUcAnGJzvtQ0n7ffHqgG-CBf-Xi_6aU68n-OA,9577 +pip/_vendor/urllib3/packages/rfc3986/compat.py,sha256=jnSGxU4M13w5vuLldgKmXmpxcZBxmUwg8dBzNQEWzYc,1513 +pip/_vendor/urllib3/packages/rfc3986/exceptions.py,sha256=dadexlPfwsYbcbFdbR1lp5WyuF8PMsSmx2gA3nrger4,3775 +pip/_vendor/urllib3/packages/rfc3986/iri.py,sha256=UWHdKI_aOiK_SC3oE_nTrxsgiS8shJQRkmKn_AAxyms,5483 +pip/_vendor/urllib3/packages/rfc3986/misc.py,sha256=MbL7MgqbTef5VddkaaPKkLpe0hPRNCEx0-kKhJfRyk8,4094 +pip/_vendor/urllib3/packages/rfc3986/normalizers.py,sha256=L6DOXDi7vZ_BDoXS8IUl9CW21E-siDJluK2mmImljtY,5259 +pip/_vendor/urllib3/packages/rfc3986/parseresult.py,sha256=cdmsiBExo5o2A2jWI-TtGFeXTPenyXQbGf5Nmv7nh6M,14654 +pip/_vendor/urllib3/packages/rfc3986/uri.py,sha256=r_KhSNmvWfoBGRPBf1dnlwWnCwuM-JHFtGa-6DH_jH4,5227 +pip/_vendor/urllib3/packages/rfc3986/validators.py,sha256=jbJGdqUcoeSD2E_gmuFbrujLsVtEpjhJg7oxpiFeyY4,13854 +pip/_vendor/urllib3/packages/six.py,sha256=A6hdJZVjI3t_geebZ9BzUvwRrIXo0lfwzQlM2LcKyas,30098 +pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py,sha256=WBVbxQBojNAxfZwNavkox3BgJiMA9BJmm-_fwd0jD_o,688 +pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-38.pyc,, +pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py,sha256=E-9J-kAaUn76WMZ4PpzKUxM4C3yjY7mopOpbPIy3Dso,5700 +pip/_vendor/urllib3/poolmanager.py,sha256=GrUSFRcQbhxPMRlePxOUbXvmsOgGTiNrxQpICmXd30I,17050 +pip/_vendor/urllib3/request.py,sha256=OfelFYzPnxGlU3amEz9uBLjCBOriwgJh4QC_aW9SF3U,5991 +pip/_vendor/urllib3/response.py,sha256=GxiW6sI0NZgdlDL4hzPfKDZmH7OFTiGZosaXu2DMG7k,27171 +pip/_vendor/urllib3/util/__init__.py,sha256=P-VlwgBFaga7i1BTWPNHGK4TN-SES0VoexbeIPIKs_0,1082 +pip/_vendor/urllib3/util/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/urllib3/util/__pycache__/connection.cpython-38.pyc,, +pip/_vendor/urllib3/util/__pycache__/queue.cpython-38.pyc,, +pip/_vendor/urllib3/util/__pycache__/request.cpython-38.pyc,, +pip/_vendor/urllib3/util/__pycache__/response.cpython-38.pyc,, +pip/_vendor/urllib3/util/__pycache__/retry.cpython-38.pyc,, +pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-38.pyc,, +pip/_vendor/urllib3/util/__pycache__/timeout.cpython-38.pyc,, +pip/_vendor/urllib3/util/__pycache__/url.cpython-38.pyc,, +pip/_vendor/urllib3/util/__pycache__/wait.cpython-38.pyc,, +pip/_vendor/urllib3/util/connection.py,sha256=-AyqcRTuNUHuo5ndtsU0Og_nMyCGATC-kYqOUdBHwIQ,4639 +pip/_vendor/urllib3/util/queue.py,sha256=myTX3JDHntglKQNBf3b6dasHH-uF-W59vzGSQiFdAfI,497 +pip/_vendor/urllib3/util/request.py,sha256=_pmOHJWpOHk7w8BDz6WZkmMunNmplEPBmh2-5bl3Do4,3832 +pip/_vendor/urllib3/util/response.py,sha256=028PNXDZhwBtnm2uXvnAHi_l9_AAGrAMH2Igh2AbgWg,2586 +pip/_vendor/urllib3/util/retry.py,sha256=1m-XI9_LORj1FLbwOzgWC6pTt2deycyGl4BWRI9r4Zc,15150 +pip/_vendor/urllib3/util/ssl_.py,sha256=bYkkcBpWIbtFL3WCiX2pgTRjS2Ukdpv0oTtHHK0g8Mw,13798 +pip/_vendor/urllib3/util/timeout.py,sha256=dTF-iEp8DZiPd-8g2X7CVucDoBWJBn221T8ghg-tjkQ,9768 +pip/_vendor/urllib3/util/url.py,sha256=DyEkFjkLo4C82N1elJgpePfccgLb6IHMjBTnPgs9QmU,9827 +pip/_vendor/urllib3/util/wait.py,sha256=p4BZo_Ukp5JF0Dn6jro7cUfqIjnU6WFtuoA6poaV5Jk,5403 +pip/_vendor/webencodings/__init__.py,sha256=qOBJIuPy_4ByYH6W_bNgJF-qYQ2DoU-dKsDu5yRWCXg,10579 +pip/_vendor/webencodings/__pycache__/__init__.cpython-38.pyc,, +pip/_vendor/webencodings/__pycache__/labels.cpython-38.pyc,, +pip/_vendor/webencodings/__pycache__/mklabels.cpython-38.pyc,, +pip/_vendor/webencodings/__pycache__/tests.cpython-38.pyc,, +pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-38.pyc,, +pip/_vendor/webencodings/labels.py,sha256=4AO_KxTddqGtrL9ns7kAPjb0CcN6xsCIxbK37HY9r3E,8979 +pip/_vendor/webencodings/mklabels.py,sha256=GYIeywnpaLnP0GSic8LFWgd0UVvO_l1Nc6YoF-87R_4,1305 +pip/_vendor/webencodings/tests.py,sha256=OtGLyjhNY1fvkW1GvLJ_FV9ZoqC9Anyjr7q3kxTbzNs,6563 +pip/_vendor/webencodings/x_user_defined.py,sha256=yOqWSdmpytGfUgh_Z6JYgDNhoc-BAHyyeeT15Fr42tM,4307 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/WHEEL b/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/WHEEL new file mode 100644 index 0000000..8b701e9 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/WHEEL @@ -0,0 +1,6 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.33.6) +Root-Is-Purelib: true +Tag: py2-none-any +Tag: py3-none-any + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/entry_points.txt b/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/entry_points.txt new file mode 100644 index 0000000..f5809cb --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/entry_points.txt @@ -0,0 +1,5 @@ +[console_scripts] +pip = pip._internal:main +pip3 = pip._internal:main +pip3.7 = pip._internal:main + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/top_level.txt b/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/top_level.txt new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip-19.2.3.dist-info/top_level.txt @@ -0,0 +1 @@ +pip diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/__init__.py new file mode 100644 index 0000000..0803e00 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/__init__.py @@ -0,0 +1 @@ +__version__ = "19.2.3" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/__main__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/__main__.py new file mode 100644 index 0000000..0c223f8 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/__main__.py @@ -0,0 +1,19 @@ +from __future__ import absolute_import + +import os +import sys + +# If we are running from a wheel, add the wheel to sys.path +# This allows the usage python pip-*.whl/pip install pip-*.whl +if __package__ == '': + # __file__ is pip-*.whl/pip/__main__.py + # first dirname call strips of '/__main__.py', second strips off '/pip' + # Resulting path is the name of the wheel itself + # Add that to sys.path so we can import pip + path = os.path.dirname(os.path.dirname(__file__)) + sys.path.insert(0, path) + +from pip._internal import main as _main # isort:skip # noqa + +if __name__ == '__main__': + sys.exit(_main()) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7c37cae4d5ac33a7d85b734bcd764471d733c382 GIT binary patch literal 210 zcmWIL<>g`kf^QoZCW-^;#~=04Ilr^j2C73Egt z8Kq?zWMouSRmJC6nk8iv82~|go_>gaL1uw&W?pegVor{(fq_|BWtm|qNDz$U<1_Oz aOXB183My}L*yQG?l;)(`f!z5Sh#3IU0XUoh literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/__pycache__/__main__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/__pycache__/__main__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0961381ed425efb84e92595ef1f1f03c24b967f8 GIT binary patch literal 462 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 X#Z{F0n*nS(saK7PIpfW|GBfu-OmFHI literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/configuration.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/configuration.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2e45a7f55f81bcb10e2affb30d828ac46efdb1a2 GIT binary patch literal 10694 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

~BCjK*KYs$ar}5KKj|}X_eO?mReC=LuXoH71cZF z7lPCw>N+u}_|SxQv0hjcjW2+QhJ47v=L*++@eIN2Z+LUCG+E{=1DiC+B54A(O3GwO zHkUO7h%XfuS-yh`U9S1UVolkBZ?e1rRWZe6WdohoX5I?DsF4*?mOiEsm$J8@a#qLJ z9T%=Aln+_r1}=fJhH{DWH(jXHr!iGpOcpgjym}wBSa<-6&=4xQ0*oK9UOujEZzt*Y zFsE$0)9nc(31TX&IfS2rt=VA|Dxp1Ilu94{^3n8 zv*E7es8Z=b|<5C{L^e?#1RiW~2{@hp9gMP6a;7;Phga^l;@} z9^RbPv-8WGTga}<BaEJ0X`(qjs~l$okMUzX((@bYug$Aycs3P9Cq z{Vw2Nb`m-(q_T=-|KZc!x8Sbo$%LcDhx5snZ|OjoaP;OpR{)p+@PD9a--%N)jOY(! z-RFBSNbpH`o!o7Jnpo|Z(p+mn%==FaA DW8Pgc literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/pep425tags.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/pep425tags.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..cf4ebd64e4dc94fc7e2b0980f4553efc35e70412 GIT binary patch literal 8389 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 DyyO*v literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/pyproject.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/pyproject.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..70e9f0eba3f4c13e52949805e593f6ce1a5dda9f GIT binary patch literal 3216 zcmb7H&2JmW72la%E|*JEk`<@5jRKuE2bn-b$wrgfhU+G9jK-+SsE(7?1cJqiJ0zFd zugnZ7kzQURUxVfk@IlV4m!jt$d+)v2YkKKF&_jU6d2g1aB-c4~iJhH~H*eniy^neP zq}g;0c>eR(7yf%!4dWXeoPQ_`-h)>@gC;Nn5*ab+5`uji(Js|rvuo6-+GTe>2w};e$%oF^ZjI6R34ABh!@UB8E){S!rBX^ z>JdC~@nGMC_ddMxC(tM(HxxOc=`}?I63}Nb{=hgPCj^8wI~O)1nig)v_Zl?0@!95_ z01KkXh@Q|-4Ptx_n8H@lX_DRk=u8pwC6|iUVF8nWr{j#WFc8$f|bBFW_mEvdX&uu60E<%3n!%wjbXZE z<2&&t^j?dyHqlL3RmO;%(j2_^1qHOtktN!y0+^d4`-F;iPEM=JIjy}gUXVG-(Qvdg zTRYPfeX8XaG?j&w`D$2LqcluPiKIZ9B|bSBMyBq zlwJW7g7F%Xt8wOKQ!faG_%TTOs_t*Z{vii~1>_zceg){H1C2q~%uTXJ#ZRH%L+qDN z6FN0`H3FZ4%PtTgpr5tqQ|MQ6OY9*YIYHO`lKyF9ZmY_vo!hWl{e$t2@q6Qu@kb-C zo>l`B=A6U|thodGL|%~sFtrYABFYUJDJQ6$kS|DJ&yD16?uf60YVI7`;_C&~bD(+- zRDg8u1l6m6_KLotX&mvF+?qpFAXoV}<$gh6&));3Ij;q4aANfpI`6a4cr2VV);{)2sn1YrLjmyinvzh<2@;VUM{ zX!XS0PtLI!`ZC#448k)Cd!dS^OlG_n_Cp@DR}5A%ds^mgwg-WV*^j0DQmHc9x8&>8 zTd`SsGN|&y3^Wm>4UNodD`@K_fDUYZ3?S<6;%o#W6c{s#9q}yz5U+q>*ZZkhF!4uoDBXAq1>p&Bj#ymf~?72KC;G8bEOi_A2Xi;5AUD)Nh zvl~Ce3%H==e1`Wlf?8G}vfXNkAAzj;-YV=+V!A76m=;!=@kE%g2A4bJ#=?XPP*iYi zL(Im$D%ReYkmy!bnZCnY&B8s)iN)FVt20yKXtTjxs4bu~M$rU}&Thw|hC@wOkUprG zl{-uK^-A|G)^vXG;3m$XF60{TqPlRJqM`%qf39IvCrX z9@jOlEbVgb;__I9k!(Ya2{A6P)GF-7po*tq@gcCj5cuao8&B6DTE=tOVL>W%4d>jA c(_kF&dsse8l(s<~0zbMzOZ2Xoj^ot72Pq$wDgXcg literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/wheel.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/__pycache__/wheel.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..379baca17d249704c38d14c1f35c28f845c4298d GIT binary patch literal 27542 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/build_env.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/build_env.py new file mode 100644 index 0000000..a060cee --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/build_env.py @@ -0,0 +1,218 @@ +"""Build Environment used for isolation during sdist building +""" + +import logging +import os +import sys +import textwrap +from collections import OrderedDict +from distutils.sysconfig import get_python_lib +from sysconfig import get_paths + +from pip._vendor.pkg_resources import Requirement, VersionConflict, WorkingSet + +from pip import __file__ as pip_location +from pip._internal.utils.misc import call_subprocess +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.ui import open_spinner + +if MYPY_CHECK_RUNNING: + from typing import Tuple, Set, Iterable, Optional, List + from pip._internal.index import PackageFinder + +logger = logging.getLogger(__name__) + + +class _Prefix: + + def __init__(self, path): + # type: (str) -> None + self.path = path + self.setup = False + self.bin_dir = get_paths( + 'nt' if os.name == 'nt' else 'posix_prefix', + vars={'base': path, 'platbase': path} + )['scripts'] + # Note: prefer distutils' sysconfig to get the + # library paths so PyPy is correctly supported. + purelib = get_python_lib(plat_specific=False, prefix=path) + platlib = get_python_lib(plat_specific=True, prefix=path) + if purelib == platlib: + self.lib_dirs = [purelib] + else: + self.lib_dirs = [purelib, platlib] + + +class BuildEnvironment(object): + """Creates and manages an isolated environment to install build deps + """ + + def __init__(self): + # type: () -> None + self._temp_dir = TempDirectory(kind="build-env") + self._temp_dir.create() + + self._prefixes = OrderedDict(( + (name, _Prefix(os.path.join(self._temp_dir.path, name))) + for name in ('normal', 'overlay') + )) + + self._bin_dirs = [] # type: List[str] + self._lib_dirs = [] # type: List[str] + for prefix in reversed(list(self._prefixes.values())): + self._bin_dirs.append(prefix.bin_dir) + self._lib_dirs.extend(prefix.lib_dirs) + + # Customize site to: + # - ensure .pth files are honored + # - prevent access to system site packages + system_sites = { + os.path.normcase(site) for site in ( + get_python_lib(plat_specific=False), + get_python_lib(plat_specific=True), + ) + } + self._site_dir = os.path.join(self._temp_dir.path, 'site') + if not os.path.exists(self._site_dir): + os.mkdir(self._site_dir) + with open(os.path.join(self._site_dir, 'sitecustomize.py'), 'w') as fp: + fp.write(textwrap.dedent( + ''' + import os, site, sys + + # First, drop system-sites related paths. + original_sys_path = sys.path[:] + known_paths = set() + for path in {system_sites!r}: + site.addsitedir(path, known_paths=known_paths) + system_paths = set( + os.path.normcase(path) + for path in sys.path[len(original_sys_path):] + ) + original_sys_path = [ + path for path in original_sys_path + if os.path.normcase(path) not in system_paths + ] + sys.path = original_sys_path + + # Second, add lib directories. + # ensuring .pth file are processed. + for path in {lib_dirs!r}: + assert not path in sys.path + site.addsitedir(path) + ''' + ).format(system_sites=system_sites, lib_dirs=self._lib_dirs)) + + def __enter__(self): + self._save_env = { + name: os.environ.get(name, None) + for name in ('PATH', 'PYTHONNOUSERSITE', 'PYTHONPATH') + } + + path = self._bin_dirs[:] + old_path = self._save_env['PATH'] + if old_path: + path.extend(old_path.split(os.pathsep)) + + pythonpath = [self._site_dir] + + os.environ.update({ + 'PATH': os.pathsep.join(path), + 'PYTHONNOUSERSITE': '1', + 'PYTHONPATH': os.pathsep.join(pythonpath), + }) + + def __exit__(self, exc_type, exc_val, exc_tb): + for varname, old_value in self._save_env.items(): + if old_value is None: + os.environ.pop(varname, None) + else: + os.environ[varname] = old_value + + def cleanup(self): + # type: () -> None + self._temp_dir.cleanup() + + def check_requirements(self, reqs): + # type: (Iterable[str]) -> Tuple[Set[Tuple[str, str]], Set[str]] + """Return 2 sets: + - conflicting requirements: set of (installed, wanted) reqs tuples + - missing requirements: set of reqs + """ + missing = set() + conflicting = set() + if reqs: + ws = WorkingSet(self._lib_dirs) + for req in reqs: + try: + if ws.find(Requirement.parse(req)) is None: + missing.add(req) + except VersionConflict as e: + conflicting.add((str(e.args[0].as_requirement()), + str(e.args[1]))) + return conflicting, missing + + def install_requirements( + self, + finder, # type: PackageFinder + requirements, # type: Iterable[str] + prefix_as_string, # type: str + message # type: Optional[str] + ): + # type: (...) -> None + prefix = self._prefixes[prefix_as_string] + assert not prefix.setup + prefix.setup = True + if not requirements: + return + args = [ + sys.executable, os.path.dirname(pip_location), 'install', + '--ignore-installed', '--no-user', '--prefix', prefix.path, + '--no-warn-script-location', + ] # type: List[str] + if logger.getEffectiveLevel() <= logging.DEBUG: + args.append('-v') + for format_control in ('no_binary', 'only_binary'): + formats = getattr(finder.format_control, format_control) + args.extend(('--' + format_control.replace('_', '-'), + ','.join(sorted(formats or {':none:'})))) + + index_urls = finder.index_urls + if index_urls: + args.extend(['-i', index_urls[0]]) + for extra_index in index_urls[1:]: + args.extend(['--extra-index-url', extra_index]) + else: + args.append('--no-index') + for link in finder.find_links: + args.extend(['--find-links', link]) + + for host in finder.trusted_hosts: + args.extend(['--trusted-host', host]) + if finder.allow_all_prereleases: + args.append('--pre') + args.append('--') + args.extend(requirements) + with open_spinner(message) as spinner: + call_subprocess(args, spinner=spinner) + + +class NoOpBuildEnvironment(BuildEnvironment): + """A no-op drop-in replacement for BuildEnvironment + """ + + def __init__(self): + pass + + def __enter__(self): + pass + + def __exit__(self, exc_type, exc_val, exc_tb): + pass + + def cleanup(self): + pass + + def install_requirements(self, finder, requirements, prefix, message): + raise NotImplementedError() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cache.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cache.py new file mode 100644 index 0000000..894624c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cache.py @@ -0,0 +1,224 @@ +"""Cache Management +""" + +import errno +import hashlib +import logging +import os + +from pip._vendor.packaging.utils import canonicalize_name + +from pip._internal.models.link import Link +from pip._internal.utils.compat import expanduser +from pip._internal.utils.misc import path_to_url +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.wheel import InvalidWheelFilename, Wheel + +if MYPY_CHECK_RUNNING: + from typing import Optional, Set, List, Any + from pip._internal.index import FormatControl + +logger = logging.getLogger(__name__) + + +class Cache(object): + """An abstract class - provides cache directories for data from links + + + :param cache_dir: The root of the cache. + :param format_control: An object of FormatControl class to limit + binaries being read from the cache. + :param allowed_formats: which formats of files the cache should store. + ('binary' and 'source' are the only allowed values) + """ + + def __init__(self, cache_dir, format_control, allowed_formats): + # type: (str, FormatControl, Set[str]) -> None + super(Cache, self).__init__() + self.cache_dir = expanduser(cache_dir) if cache_dir else None + self.format_control = format_control + self.allowed_formats = allowed_formats + + _valid_formats = {"source", "binary"} + assert self.allowed_formats.union(_valid_formats) == _valid_formats + + def _get_cache_path_parts(self, link): + # type: (Link) -> List[str] + """Get parts of part that must be os.path.joined with cache_dir + """ + + # We want to generate an url to use as our cache key, we don't want to + # just re-use the URL because it might have other items in the fragment + # and we don't care about those. + key_parts = [link.url_without_fragment] + if link.hash_name is not None and link.hash is not None: + key_parts.append("=".join([link.hash_name, link.hash])) + key_url = "#".join(key_parts) + + # Encode our key url with sha224, we'll use this because it has similar + # security properties to sha256, but with a shorter total output (and + # thus less secure). However the differences don't make a lot of + # difference for our use case here. + hashed = hashlib.sha224(key_url.encode()).hexdigest() + + # We want to nest the directories some to prevent having a ton of top + # level directories where we might run out of sub directories on some + # FS. + parts = [hashed[:2], hashed[2:4], hashed[4:6], hashed[6:]] + + return parts + + def _get_candidates(self, link, package_name): + # type: (Link, Optional[str]) -> List[Any] + can_not_cache = ( + not self.cache_dir or + not package_name or + not link + ) + if can_not_cache: + return [] + + canonical_name = canonicalize_name(package_name) + formats = self.format_control.get_allowed_formats( + canonical_name + ) + if not self.allowed_formats.intersection(formats): + return [] + + root = self.get_path_for_link(link) + try: + return os.listdir(root) + except OSError as err: + if err.errno in {errno.ENOENT, errno.ENOTDIR}: + return [] + raise + + def get_path_for_link(self, link): + # type: (Link) -> str + """Return a directory to store cached items in for link. + """ + raise NotImplementedError() + + def get(self, link, package_name): + # type: (Link, Optional[str]) -> Link + """Returns a link to a cached item if it exists, otherwise returns the + passed link. + """ + raise NotImplementedError() + + def _link_for_candidate(self, link, candidate): + # type: (Link, str) -> Link + root = self.get_path_for_link(link) + path = os.path.join(root, candidate) + + return Link(path_to_url(path)) + + def cleanup(self): + # type: () -> None + pass + + +class SimpleWheelCache(Cache): + """A cache of wheels for future installs. + """ + + def __init__(self, cache_dir, format_control): + # type: (str, FormatControl) -> None + super(SimpleWheelCache, self).__init__( + cache_dir, format_control, {"binary"} + ) + + def get_path_for_link(self, link): + # type: (Link) -> str + """Return a directory to store cached wheels for link + + Because there are M wheels for any one sdist, we provide a directory + to cache them in, and then consult that directory when looking up + cache hits. + + We only insert things into the cache if they have plausible version + numbers, so that we don't contaminate the cache with things that were + not unique. E.g. ./package might have dozens of installs done for it + and build a version of 0.0...and if we built and cached a wheel, we'd + end up using the same wheel even if the source has been edited. + + :param link: The link of the sdist for which this will cache wheels. + """ + parts = self._get_cache_path_parts(link) + + # Store wheels within the root cache_dir + return os.path.join(self.cache_dir, "wheels", *parts) + + def get(self, link, package_name): + # type: (Link, Optional[str]) -> Link + candidates = [] + + for wheel_name in self._get_candidates(link, package_name): + try: + wheel = Wheel(wheel_name) + except InvalidWheelFilename: + continue + if not wheel.supported(): + # Built for a different python/arch/etc + continue + candidates.append((wheel.support_index_min(), wheel_name)) + + if not candidates: + return link + + return self._link_for_candidate(link, min(candidates)[1]) + + +class EphemWheelCache(SimpleWheelCache): + """A SimpleWheelCache that creates it's own temporary cache directory + """ + + def __init__(self, format_control): + # type: (FormatControl) -> None + self._temp_dir = TempDirectory(kind="ephem-wheel-cache") + self._temp_dir.create() + + super(EphemWheelCache, self).__init__( + self._temp_dir.path, format_control + ) + + def cleanup(self): + # type: () -> None + self._temp_dir.cleanup() + + +class WheelCache(Cache): + """Wraps EphemWheelCache and SimpleWheelCache into a single Cache + + This Cache allows for gracefully degradation, using the ephem wheel cache + when a certain link is not found in the simple wheel cache first. + """ + + def __init__(self, cache_dir, format_control): + # type: (str, FormatControl) -> None + super(WheelCache, self).__init__( + cache_dir, format_control, {'binary'} + ) + self._wheel_cache = SimpleWheelCache(cache_dir, format_control) + self._ephem_cache = EphemWheelCache(format_control) + + def get_path_for_link(self, link): + # type: (Link) -> str + return self._wheel_cache.get_path_for_link(link) + + def get_ephem_path_for_link(self, link): + # type: (Link) -> str + return self._ephem_cache.get_path_for_link(link) + + def get(self, link, package_name): + # type: (Link, Optional[str]) -> Link + retval = self._wheel_cache.get(link, package_name) + if retval is link: + retval = self._ephem_cache.get(link, package_name) + return retval + + def cleanup(self): + # type: () -> None + self._wheel_cache.cleanup() + self._ephem_cache.cleanup() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__init__.py new file mode 100644 index 0000000..e589bb9 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__init__.py @@ -0,0 +1,4 @@ +"""Subpackage containing all of pip's command line interface related code +""" + +# This file intentionally does not import submodules diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..bc97696e535e48c5138ac5b2c2ec5b682fc301a0 GIT binary patch literal 285 zcmYjMu};G<5OumxRq8)@Lmi3(L#0R+Vq;?|EG#ECb`n$PY&nkAX68p2+4!EWd;$^! z6PHYV(tD@(?xeeWSuPih@cZ>4->H6&<`Nm12VyrTQS6neY{yo!;c?gRy(|y1*1U8W zr9p!=m)3Guac}%}M|s;yRNNZW++ft9lBMQBTN$;Yw$h8IRd&7tP_6{{WMM{ICi!#1 z2a{+}BpF2ItkR(q#ZlByq|gp{SH0y;a~uY+#b)1xoKT~97PNeAu#0rdI?p%hly3Vm goCwn$D6J^15kS^NfE#~0&$q2pz18>Q%RfZ+4>@U7ng9R* literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e7e5e38b139befe24be8c154af75bcbfe66fc125 GIT binary patch literal 5143 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 LDn{w|r8EBpex>e% literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8fedf1cdca2bf2b445d89eba1edb514931eaa719 GIT binary patch literal 8318 zcmbVRNo*WvcCM|ftDD`;MIuFNEz6e8mZhdd+mfyEB8e1j+A_r*l1>gp%Ng$$fM&VnINQ*%iIzKaTWvta?2s-94bIAK@J9T4l>@9@BP(Wr2&F; zqh9^%`?vSM_q|sO<#JKN@4x?I+xgFNN%{}U?Eh)VT*njtqby0TWJ#{jmJ+Cz zDpOwdHA@rkT=%V8y2$6Pym%XyA>IY6Al^l*h_~kV1SP8^c;x(YP_Zf^t^2(}pVb%i zTm2%R_XmO_){)?-bu<{X27@7MC^%*v6Lp3^9E?~aB35~6aaLzg>(q;eU;1%nYVAL8F`HEi+&Rge2y4Qa- zxL{on=|2BrP_t^mm^CKy{r;ukvUNEax5h<&z<(`x-FjW5kN9r{SF9@{ebm1iylK5D zOYF)Mng1bnV9fvF;9cuokv`_X7hJcli}bL6Be-eZ zM0#XNwkDXiHOX#m%huHUl6%}8d4zKI{-$bufcy#fB=RTO2gpym>bz7v)gHa+#LS$C zg1`w~v+g@_e8Hq7XTFm#yrWj)g)IJxWT2{~z0P7B`K^T6UeJtql2)4B3lqE13hRj% zg)>z-E!G1!YEmvnu0L>AnH@8S*O%?M9yJ-*3`|5}!&|x|TFp8DdzUnNoDKB)f z6gfRQ&wM5}415}lv#`!+vr2azzQmH*^<)`yQqqwwH=DEjc7sQO&0H^W7JZfuK2zo6 zpul6GN&87XS{`Qs3lrj8bXk+LIvpzb4&UU_DhuZm7w3CBT3W)kXDcYjENL}uKPy91 z1M{()JX%UCAsvSAwVB;?l4UUMZ+cC8jd9vRyS~iot2F+{_h#?e6Cd1~_{g4Hn3a+9|hZ)sk(yK&M$|A zfoB3w%t1QR3N&LPZ&FHWC__@BZc45~IXqeiTJx9r4JFAnq>l2r+>vbE)u?tWzby?( z8){-~6_D3E>Na}V#iVDel=Q5Wscc)>ptkx}rK4@j&;}AFmYZqk&c)`rc&eIDbFCQi zmuli53yqyyh5PKf_A)M-o!!_}3!Q+aJuZvu+!NO`H9TB-5}bAs{Iau(tG&F6b@7u# zE)vOuq1xuCNv}zrn|dK_MI3UVV_3(Mqte#o8dyp&02`5`PCxzmCVC z!`86Cu{DQ}H6kAZ8jrp8aBRtbYmEo(aJ;c{X?gi!yKVb#U0Gb_m+)H($L@|n{4aK| z;l)druB@%EU2ajKcx>oJ#zV&+tNY&AA{4D%&lGK~xtb=Ca-^3JR6GT!qxgu+_ zf(P{1da;N+v!>-$=>-<8YVdtIg-6Z`Y9xRUiy_xO8Ll4luQS> zR-_P^D=vFgx-o82q z)x<;7F@0zWGisQmP9K^r?#Cu6N3#VxauFiF=DDz4-Bs06BaE=wXgZY^#M?%fnY52R zOt_QPP)S@>(>$~t>NbCz(A z#c2iihSgh~*~?LkTTk**RXC~WG)H~n>HsfOt{{5auE+T)$}15Bl?+g-twdhP=curp z@Ky}D?sB_BWm=s9py;qqUSmD&!7YU7+oCX^cmadyOLLHxhwEvcUNo&tRGO&KoEC;C zpdx@43YV%maan`}h%xz(X^?!J0f@t=U$GYn836bQd{IZ+_&kWDD5~~!NLG|S2!Qcx zy+@Y~m7b!~_f*U23f*=?FDdPzU7nOmcUdAge zX0U*6IEv`rbLwwe(U7tppBkC?!}Vmc5ph~>8YBV|L` zkUPo>J<2f3Z8ae)r6Qlh1CQV_6hV?-FhM;-WrBhxz?8&i@43RFac!FKSM0DsCU7Pw(hI$J&z99lfJ$Vok*D zhteGQCTF(HZLAroD^O)4Gq4T?=#s@K_7d1{*pzzY!#gOG)gi!aH$0zxMK=-`%){#| z($?*Nx?wh2FkH;+B4x5%014&;&-YE2M@=(sHOZMWfy>Mc`@oRv?oMV*|cky9@Ybu!nU_tP!=9b8*`g{^~Vz)@w2|iOg8|VdevD z!J=@?&_g3>YM;2%1m-0aOb1+NzK@wLt_!5oF7A$Zt$I~x?lhlCC`)tj{$OewG`SN* zmOxS!Vw$S)dYqQJ!YC${8rZ{xW}FUYhfnT(h84x&e1us1Hjz(=Pack&$D=SUvxmT9 zu}#|+h5R$BEOmDao?*C_9`TmoH}3kQqL7=^PA4Z5j=upWhWLu zY{d0qa(HbB@qfeH!@^@+aY`R79#I_W{^e6na;b z0j;D|zE$#q4}6>AcY02jkAh!&C&*Hxsa55vsxmWEEt6+NewuBkMcWP{w}rE}(~@o9 zN5CMf$sEoq*1>;5u-_IpLM`}-KduVu$K5l(;|3YkfO7wQ;V)qq0B6jv~Lak7&R#G#E$4DGqDqCVJC(e^C4=pV=qLgGOcuZ*f0Rg@W_gE z6t-B9P{OI^di6wDnrctlyKhAJT1n>9i2WBQL1&j~i!B<;AfqaxKt*)4lgLIC2@wu< zKh+Q}c*chxZbr=(L8krTR2t`NaEn6_sjmpFhQEYA(eH|y4!vh|%Sf3hLg$r~tfeUV zR)>z=De3l=wQq~ijTO~UhGYYO@KXl9SDxxQF~U>jY5Uc=JrUmZ%znchXX=Ddc7CL6 z=n)F$3KA4O*pxSN31SBD+~M}XHIosFL`)RQLQist8RP(rDQ=)33ZOpDkx$?Lx7}+q z0r;0djLl{i-xeqe5Dl>tz*_E6B}6${_TmHLUGMso#a&L<;9fd`c@Qhab_PbSnF#y> zV*>j{-6puvV1g)s2WYU%g>=B#?heHlGpu^nTodtQ^dN<>8rRI74-CX^%JE}%P!W_e z1H0~otISO+8IS|m2VRK$bTF$0MN}M-djV+Uw2TY_`Szk00`jIq&tD1DOlkk8khB*O z%j`n{acji<9!@6HIORlq3+V1a)!=lRoJ*aY6cebDDncML>nJPV=mrEEe?h-#k3L5* zpUY5Kd7b|e&ESuT{0Rtl1<=K-cMbPnQu#j+*_)$C33L6YsQ4c|F~KGSD5f|CKkXY% z<<$@QCAqWBTPL3>ukC&D5~q|7KiedWM~k?47AimeY?}$Q>cC zB|Y)HR$Unoh+gBNE8SOyP!l#lwe901%ihqf)GGb;_6rr_6-(G?Cz}I z%#y?k^dZWz+?uVEG_{@B4(TLL*v7Hzrp?hL&fPXm>hy@)PVb~?t2RB7wmE43r2hZk zo7n@P6x%z0ap(F%>Js zR9q#h@mivgh%=w8CJRaVO%+n|n=YjBo2q7NeT6=0ldfiK{e^zXXQ~6W!NOo|s4!F; zE(}XqUo}-5DU3)yTisOKT-Yr6{_2+6*231>O@*7}d7!$jc5~ro$q!by*LD{B-wYv&;#beH$ zACK!@SozlK-L>6?-L-oP_teG;W3@enJ+<+|xU{|rtG~B!Z|%Oqee%4mI#J6Na_F7B zl6NMr#tVDZ&1(B=vBLdohq?v752*j8cB);k#S8n?|5mrDcOmzn)9(za+tnS)!rz^0 z^m3-~kd)n}?pC|it?C{%hO&pHY>ygO_p;O(L}_1Pzm(pmCR9%4vEE53eMCz4s{5t? z1JeIdDch$WR1cx_VVP%2%J!>A)T7dSN_xLrO5d#xsK=ZG&Rtg?yBfO`SC6ars3)#G zZl15kcf`~|e4oS`-Xra&)gd*b4yz;Ts5*wyC#3Yf>Z$f>Glhdv_Ov>#X4MHbr=G#S zo|LkAwV+O_Q|h#oO-tFc>N#~r71Z2kJkNXm=qee4eiu>Xv*)goYfSn5hj zq3(!s)Dr5BNLg7eqb!NiiaLvx9hK4*RaG@rSFW?;>@n3)FJt`oDy=+>^^~;mRa4-1 zPT=>nIY{o-e&^H&)CckVjQWsz6~FT`$|d!h`mp*g z^%3>DbJL}m`Y2}VFD$6Pp#CD-oKzoEm+^Z_{U!C6@q1c*TzxlwpH<(Zz8AmG$ryh{ zeINdk>aU`2rf^1mLVXf-1@$TQ{rG)e+Wdg}H2yy0JkPy4BkHp_vmeAvFG%ebbrpX} z^*I^gMJf9s^~3l}svnWEm(=Igk7Bf<`Z0A4zwc9jP5pKJ+S2yN)fb$t>UH%K>Wf&x zqWY5h8>lNu-IvuDFmFlyP4$zgQ&RS~)ZbP=CD8k6!6`>de@6YR`aA09)X!t2UjUY5 z3rkY|74?f~`%A#dbfGLIzpQ>m{i^yk_3HxrW%YN}-@|+rsr&otH_$q%{(;n;m9pPN z*=L*zc0Q*PQFW|kM>|%Ow=t7O;l)q2&!sJ=6>==kRyr*1WD?KxiFYE&9w-YPqFN88o* zc>eiH32UzVj;?e53E7^v>^7^aKIRWJY|pc>6d5>gopiA%s{}AqJm0DNXkP6McD{m# zCAV62&tug9gmSz}xt<>wc!Q#FJRWSa7d^My^qpd*)^N2yi?V*t*S@>xx>Y>%Va)(b zbvzjiFPxg2o1a-&C?1`8dM?PE5cmg!=JyCs039;mS6B#gL(^`phQpcB+STKUVC2-o z%zSbB;Pla%;-O>n!ARNhi=HkO8ybgm0X>EfySirk({A0@GJ9%nb?z7{1{WM#mzEbw zZo}coCvA<+bF2QcTW7z8lk+ELj}(s{TsS(ja4jC(0{pQJTR2U)XE zyBefVHi2E((U2*cbK0&p9gkCB2TPT5cWo(2h=(8MGx$#9>*bNC_?6gNd@XS` zaWUb?uOw9BN^&i6C3Q7+HGVaIF|iiAl16PDvYB*{YJFkA!e`#Dcn%OG#2&#ZVyHui zTTPF7!8x6mqCMj{dUiah%ifgatgyiphv{B$ND?I{AGUMlxVzeIXi@XZQ>317e&4y^ zo6fDFS1y{uDeIMs*W=dgcqYg!$zcaswmYxwMvz(pz6PnYZlxZiy+*a-2WeS1kS}BQ z5oF9Vf+Qxp7Sm$@-u0I!LGtH7Xp`q`JqdhQj`k)Wy)aoWK6*~qTJ;B(&hA}azR+qF ztB*dsxUBc$Q?5^*oCG1}g!HS`+}^zppIbe5f0KpsEk;y0S*lhhOEqPt_VSI@V5=tR zi>9O~i{w%~o@%UrD84PO$B`=~_#A#x_~lnleF7PuXO6Sq8M}mYM=r55b}07Z=8HW0 z_*(K3PCp)ddHY%dXP#_*#GJX~H+8*pT0(c0yLi?q`O-jGp=ITA7LdPL1EU1{1Cvld zVoTW7SlzBUW5QU*!aa>yE6%DX{SBa{zaW-8TXTZr(jZ8&f6y0p9Z%>!Y$h16l?nke zo(j^k41G6ihC(ozqTMKxb2G^vw%Ag$SK82&W)Gp*%OZ*Ojl_rIBXK>6d=EUKw+lQ; zP2L=m*8$6wtR7m6eKhuw*b?-4m3%FGF`-f_tup20#iSqeL1ln!;!<2cy%sy0xR_c? zT}fVz#bbWzY+CiHtm?lk764#A(E943iboz`onLmGs%KS}tcIg=9uA=aJOG#PVz-b= z7HUEon*!kMTEy6=EQ+QRLPG|YQ4No$*-$`VLo8vx(y~)p3E}CP-XXx*L24(s9EdN= zYc@bFIB7^ZyIJ)q@#LsT>tQc5_-qLRwEbb87v$6NQA#vz3j7n_x;DjLa}KTvf6Jn!***e@71)!}j> z9Yg|05C}F!ql67wjyW3gI37Y1oX}m0&Pg>P$6aAYVMQ({_mpHSnwv!^Mga!IW9S76pW%z%4FT>b9;pUXVR+>pGU{ z1u5pn)A~M)sUKuQG!N2*n-}zjV;G?BW3>>+uD6HclW62^M-t0sH5IKI@&p^eGFUP^0Sl+jmTuHhQ zBbObDfou}`=vqo2_4^fw>DBmJT)%{}mry_8y@b*vOH~SFly3dv;bvWQBxoZVSPJc? zRv}D?!KJ3>yEUs(wS59JLRgFBB%pNEw@6YqAS7QjhAHdWWd{;UTUZ7uCn6=TBbPIc zs4*H%52%BwNkpym6qYj8`XltOLmh;Q1a>O&HCi^+P>~o=XRtp}%6y24I>^z8;#{sF z8cXgRi|KWhfeNfuQ_hvXIv87eXr!8VYoUu>VF zTQ6eNV9-FPNLU8DJZaNCcrirB_2O&08GHShXRs9S9wf281SnGezLDu00hMOnOn_oR zqi?0MsrZ28^a-?VC34HHOfI+VRG|i9o`Qz#^lfxd#wQ=477Mi z5ETqZxnj*#4%rqVT9|Lb1cB*M5%nQzXt5zg31P{ja_Z+Q+N~4&Ea+1eia%py z;rs=yq1raJU}pYWN&#fUQLlH08NtwTpD=NzmTjKOXCjiwLlOe88v7V1aEN4>F_Xo3N^ zNx_h=#OHmMUjduV6I>vpl3R6kkgdC5-N?0eEI^0?Av_Q+o@rmo6j;;ga80CHSrap@ z?Q$$3<_dv17b<=p?O$&7<#O0LFe)uStxK|SA&PH%;ntp#tFgd_TUR_MZ0Xs9^E6*3 zteN@w6Z2-{)APqp9-BV+v{iM>WwsNU<$;a?`i6GP++%Lh*1=HpROC~pwCuw43=-Jd zy$eFotCqjo5UCoq4u59z?>?mAlpE<+fI7SI=El8^{*Pz1N;kJ}e2wPww#H*1TONlTC{ z(%N$D(lRAT9a=q*%`y%E3!0cyYxr$&x1nut8;6V;iRQqv)|MP(h3JD(5qW1R=nESJ z>7}Y``)_RGS{_(%APuoy&n>MmYX-T&Oc(+f2!z4`JKU}?fOQ++nag=AFs?%CCNuHy zPr?1ha&V zOfOFrZXmU4nIWgFJ>EFXsnYUm7^589L5N+ChEQ!XwW6sYpLjw|a1>6eFblRH2Fo|zny-9I%GslJEY|xZpAi9HEoi!$M6*7wo#QudG z{5s?!jnzhl`Ji8l>Fx=Vr{$#aZ>!H2-tUW?XqP}#uJ_v6XH9Q;K8Eg(V zxdwrAoT^ZJ`x_BU34)LLt%@oC-x<=aRP| zCE>cnRzfc%I1IO@o1#^CJ&mIimyHT#w0EmlxhA28P9o;frgh7Ik~Fdztz!{onBVLA z1Kg33{<48kCScpGgU5t`dp8KJ7>Xc{%3UD_!|R)an5wH>wNhX43{a@!f-8*YHyj5Q zQ8|w7$gDpO)pxlM2a=tIy0Fw5>K->3;2cGnLk=NG62X7;*pg*i$Ps^pA5k3Et!2Lk zA1{b)f~Xz(n29--StVP+bqd7@j%OLepq>nYR_r=8IVmI4vpoh)s)Lu|pag-884VSo zX%_;6?E*^qYa!Kkj;~F%Z+nLNLjchkp4(Prz}w=9Sjg3QcGsnTgBeS&lK}W6GB7)1 zWty?L&7&{vY(hV>7WW?UlUI0qo4Asu?07AXEX)W}%FQQ;di_j!$J7YwifGa}fXd3&G zjH1iC9eVOYt8<&6C6P}?bKnTt?Ol&g^muU+*nSdUk6$9&TI|Juzz-dE$jHdUV5g960SR z@C5Q8g8^Bru#)k9y~b(Y&*X!w%s{Iv!&{zK&SJBy?_>pg=@F?dLB{$H7y*4G!Iljm z*B^;G1Vi1+S-%nEQS5F}=7x5mcPujki;EtTt#77MspLQc`B>tuOiEuyZHY~~Ki?Ez zg>sD}1usy!Wfun8aQIZ@lV|8Sd-TM@$=QR)XIf7kxAh881=5A}@YGsid)WH0giz%+ z%ga{9w{WTJiS@l~!}d96S1BhTL12d;J$Z6&p)Dqb;Ce;G+Y($b)V;h95Hi9sL!Ba| zz3ckpfWroOeAA4rM8;;2oo)3}N}CM1qBSQoC-q9*XB zuu~|Tjhjv`+#+kQ1_!9z{uy&mU&0>V77+ToQTs9O|7|!A>%V;n=oXZzE>*W}?uy}pXx7ia1600`X9c?zx0bCee%z)mImB|4%RwBrwst=m?Jnr!H76>A zBwKv)P+RST+z{UpoeiCRhnt`W&3B3ExV;JO5~^D8rbYe~IzC1Z(03v_!Q+#dXtcKn zRRQDZ#&CjU7?-_DO}G=FxME3Rza9}AiIr*WIlLTLgGf0Ge=tO2ymi|Vn2C0%qelMk zNPIyQ+>d@@@<7~Vz_)NUs&}(&oyfVVh#P<+t!&$mhWQH5fD4Ev^{0@QD2Sp@8X10N zVWY@E(k1D_hNC*=%gyOp>MZVc&Ze&>abp_EzVVEVr9X)-#+A5z8BW`(Q>-=Vo+`oy ztv2Ca3;H48jVmx1qzV{5K(*lpaQ!`~9sOuJd!~UBb8hL919>Ch)?K zw``Z>ixY|Y31hkY(7$lEL|cTaFKiJQaB$BUKpT&47DiEZ5k`hy#yIvohCbxBeb1rq zIy6F{&eAarw%@+~>Sg`LA10m@iUOJ_VzE%DM2AIz+5~$!SSmRUh?daNZXD6!!$5C_O^-xafF8TBf3!Xng`8KELm)-WdvitjwfbkgLwW8f*%?IMNVrB?5#$d$6wYC3>u^Gvp3jp*Ol)Zz^9mI zGTU>M36yZWZ^qgkk86Z}bLtP{hj$6uU(dk43pKZ3(2lKpFSQUJM6vgF^2QdgZ0c^2 zGTnP=-=;!D;Y{G*)*z@+E+dJHupli55)7QC{F#vmxupI6ty^@k<877* z-W&67!zi(ADv`oHBlHVI1!VEN4Yu8OL6>Fl12DgfXu1ZK0%wKqFNCzw0o|C zpg=g!dau7j*(C16EO(?5Y+(BH;#%~94vcYCC<^`8G71g@Bg=^=p8I1LhSCDJ1a{bdZ(+Pr@0 znhOyTWq$~m%s_&Z&=ErSGtoka!2%KLK#r3gQfC*IDAYDOZ!Sx`oas3#Ad7fq1#xol zLo-|mDp5C=?C=o;#KDS&7dEmkLuM%hb*;l#4$)%5JJj%cAKgtDgSk#MY8kD2DTo%5 z+ec#=3(pDpBcs|V0)V6wC$+w z1Ix=pA$P{ZpEFcCX4;92DbLeH*xqiQIv){`Z- zTMv=BOHuAs87O%uXM`s*R*R|v?Ha~pNLQdL z@a)7aWYY{<1)FemJ%Wd*pt)YKT3!@)?V?kaFy7kXp4G13&sK3E_cSSUBlP>y<=+XA z(LaTf5{tV(6jHJsvf$2riWrn>V^HGy7yNVy0h&e`4u;KRXuoS-6dZ0nGAC^;i4%_0 z=C-lrV*9|c^GMg}@Oga-{ome|_|vGR)1tkj_7%q0HS1{amT<4{&`lKdOO{Td*6j-n z(h>7f3M~YK+Rz%T19Z)_uW98jOjsAKv>pMTMnU_!ob8}nQfR-oHDpA2JO(}VLFl1z z=%GjBh~JCHsI5|r`^hy#{HX**`LnTyaM6A-_5Rdz&{OM)=MZoX;hri&2@v7_QDLNW z+AT3u1`>w)OGn02aFI`$5SwVT;Vnq0m&&CoNF16G5E`<>bMhxl7*AyWi^zC~amdVP z^_Q^G!|>`P@vDEFiKqay28|x@GsppNcjG5WVy=!J5G3L3S&yOHBDv3?Ag-OK^EywI z_Hb-43oIRqZ;s#HuYV5D45(osQMAj})UKgl z>ztr%EmLLX?V>`c0AhCW*zKJVl@_s9xWG2mkRf2qK4Q2%1_x5m&`rr$6<6DOwR4|n z6b#-#N>~f;<2N)y6kp`fha%3X+A28yB3`C(d^i2#W=f18z-sAi zY2pqr-?{~INA8Rx|GpQhx50K(9)-Agp&8K{lgm6q=j${&Oko_LFxvAiM9$GK#&v~( zeJBn#NkP$s?Xh6c#P%&gFLF+{J`o{byMYmN(u;PPE&g)6IuNq8Zbw1hdeT6lE0VIK ze-QQ(*l_Nyy4KH9zv3j+Yi`{d+0 z^G^u3WG~>~B0P!oc8HN|0(yzbbI0b2vnPspIjRUCbJ6hTZ-~Hb4-_)kQD8`Co>AV9 zAuQ8G-Ix=|i~a{%?LvOD=+0PSI1E0K3NC{XfCn9<=V-7su{k;tK;*cH0a_Y{ zzlZN2=tl^E3ru+bZI1%eOauV1crE+!N6q$;y_wI z*<+)f60f8y&_N%YYdr^-hP7%FT}~O5RLtx9qA|zcev$sLqqm z8gekI0GOKbj&}v1fVg}_*vXEmBN_WRdTUW?dxdOULE=gDyx^ht^ZZX5c!oD(UCVqY zpi(cv8bINOeXj#@JEoWdqjjf|+#)>~dn^dnEnpa}D(KL`1Q=dWRa<9{)#VBb?81Ru z!Ek^+#c+7#NeqZwW-#`jgk&}Mf)f(hEp9nR4GWD70dFXAc|i>>2}xl56qpV(1wi zcrE3pSNim_)TQ7JPG8CR>8tUjglT2wxze|mD#xxSu4LgPi{s)^Lhf2CjQy5dTTzu^ zwu(M8YFEqdl&X{w&JUNa2|^W8Hf4k?F16v!7d|V|hX4^uMYoc-`5>1``y9#Q87 zd`kbAU^(9K?C^`-ofk%IYuWaer8T%8WAZR4#tAj~3CsvzGu}TytH-O!B^6L`b3Uv%&w!?w8k9mTSYl71I+o0;5+ z1g|JKeu%}w`Jm8KVb{HmyCB8s@OH5PY`x~bH4+Ln2QLQW!CQV$5)wheeNtJx5S73y znRqoSk$7_`nZ+woLvLjg`Zq9-yljE?`q#ObjPWS7%BO+vO9U_6)r4`Ve=|DHMAN}l zh1g$ci=y-hKtcu)G6#tHyft&drgLKIMi5;BNHLm2)cr-6Ivk?>hI=yWV$v_n$Uwb|k%8V;i3{9?n`m6k;N>(#2Eg~xdI0yx zqVKyk2tD}B%(BM}Kf)7q06ixDx$ymjG5AXq#tu@f3eqAm<<%oxImp|6W2iM)x`*w; zH-xw^yp--Qhp#m@iKL>oB)0PA^ez2Wv~Fz*-Cp6_Egmi~?&WwKxpnhgcoN4XZ25#( z&Uot_Z)+arzty0xSX6GQSPTY=#U+F`;02(fCQO1p2Hyd&`VJ2F9u|$z4!~_;)yp## zV>;+x;`@4xw$Ujz$^tROP}kJn&80B?F`8=+Zh_Rux8Ih|!?MO*I)r)nGS-gX>d5%> zG(8r2kR#mH+k|fznm+9qH%TvcTkdCNHpEis&7r_$IlD>wJ+_B_>Nu%1q8OsWW+*iDuGb@(L0N199du zcGLupet=aUWbz><4A7LQL{Ww7%>_NI~^v|>M7mx&78P7wjxnq)x(II9=Fx+E6 z8oi$Srx}xaVvvNAr+c@@Y%I*qr*hu}WmEP3NbmNb!x-^S9!Kr%a$9Uj;* zFd=@-C?NamnQYsy8OKW~f0h}-bD}F?`_D21Jv|V>o$2rD(|KM$X7tQahdVv+dL%t> zZ=vL^#Gi&WCdh(>{@d@So8V=%k9Jt9Y1KMMN{N{jYNa3gp< zGo0;Ox%3;zjttzAMLGZ4J;J?8pP_6f%g^Qwa}H&1&u)=E(Qc$)=1((QdrGfoM%F!V z!gxbjv%;wF^~^x_wsq~y$wZLv?325SO1~~=9F5Y80qil9y=C2~2EtK~2)>}04cJ4BW0;W{5A|6CjbwYwKiL2e(&YAyTeL+$*#>B5~mF;7^zU{Ke!u5^)M~jJw156Q z2~k7S{+5&1n+}uDq4Vb;u;yzRVVxo$si*Gi@HD8An7)bRnn`Pk>Z>h0O+sT5zkSzL(YVOdbWZ7Rv8d+vPg1l&if&yoaA;{lHQh3G`22zZ>tG-Sc)l4vRI2n<clYk@m$0SwaFkOb%zH5} z#B!gJupoiFWl-HxwAAzTCHnHtr>zD93;GUpJ_aFETxiD{HVOpNd|sPsg+9w3^87u~fSqT_AN zW4!HsH&5h~+ro-ywinWFP1Hs_jEGnWF%I@2b3tV!>HwH3g~Ck31i~o2Jrr6WK{QUA z0RtJT2hjN?5D^6AN#}cgil#b-P?Y*WU(tTme=y-PXyUA`U;Bi6Yy5W&kfCpE3KR=8 zWanY4692MZ&f+m-sy7Z_x$iF-s=twZU+6fB$eY3FwXMd;4q?T9o!4 z_Tc{OF#tTIbbWL4`uJ%4(MT#)58@Qin1;01r*ZE!5NzZ}!rh_(5r|X1{jt1=3BrQk z6|b-8ZOfy`u8 z5lcyUK<2RzB9@JENr{xOkj|%zGDB5z<{DF8gV}PsIn3fzG%(?P7Atl_YU>rugM+8S znj;=alS(ICEX`pN@Ke&UHSqK*6YO0%ZG%{a&OH#Cr6V1gvj1l}E^>6oXd~CK3=4Ho zQ-1>*4%o|(Chz#dyNrZ8rXWL9Y~ zzcesf)v$h`vtdy$jbkXcat!=(75iS=O1r69nnmNlW`7jGsbe&)VbH8-5t>?Mjr~?y zvlj5NwgPVh=d`gkTPUp)bc}w2H^lJ!SqCq6Y0nlVC*d8;(jLh2YVR`10%1zVypY35 zXOteK+0zt?tg3e2nf@BQGIgT2xxYTlcz4Dz?I{YLLRk`_iYukGQaS zfwNH|YEM~Q5TR#W*fdTFC%G`mVO$7<5bWwP-{*7e>OPN~;{ausZnT)n$0>>$8dKM2?+Y+~ym{3YP)#!Iel09Pw| zTzE^rQ6XA!O;Jy*oUxgIbzTLgqRJUps8iXeYSANmK(TiYiAea?dmwEdlXXP3L=)-AH& z+`0G8{XF-a-}$(FGBZ=w@caGmPQ2f|rfL69h0&jd!aY3VpOG+aU1K^kLcL?G8#?99 z&|Ej=+gi8eyRcr6@8Wt9Z!0Wy>~&kVEre5@@_Je3i{W&qvR;w-QaID8u2(y=>$9?K zhjX3z^?6mYrZO{1p7Dr^RCn^oB?-cxLj&Es8WHFg2-X|@1jEM^xz z=6;gwf9QwZ4`SZ&5-ccv>s_Zy)q&5KLthAI*XJ8Ch_;DlPHWJPazsZ-!$wob8V5gG zI6V*Xh!rGE?;Ffm)tHI5wW=lBp~ebVG*-N;Gu(r>5H-2qL5@@POM|`@_5zk{)-7&R$sQ~= zyZDjp5Q)SK!&|p+e`|Mt z_fC&0<%79FeK5mvGYpm$XEwU~yoNbxUO}7C3|qJLnx0;paB_{o`kS=-!H@CaG(y@J_9Ta4LqhFxX zq8yi*$5ValLnCr@TEUnE%} zjQ4z=SzB=s)r*oB`8ArRlrL9uCKi-gG#S5+Z)cd4UqzjRN02;ewq+FcIh~%0UV&iE z=`|yLV-lNA7Kw9WMw~9iYylY(v2BA_nDLnM<|RTiYb`51l)6W7g0<9GDa%#XbMY!| z`W}OJIkWVvnoCOl`EB$SBoG?lz|zxKC#`zC%h+lOovFKAEs+HX4OmF@W23L15HuKz z+5vEw03uC?$NPRHdfa!CO&@6>oHz>ik@!yJ?}Y*08-B9q`;pTVUfY*kj*6Bb|?BJN2Jdng`4BMpB&1eS(4dI$uiwv0FI(LxV3e z8N>&U>=0PhQ2;TfQdht7y zyoqE$y6KU#faG}_et4E4YdHx=THeP9f>>WOEQnOmu#B={8#UxDBYpiV2s<*!7T8ehKhbS2;*~yK9jFleWk-v5`@KKd4Kd3%Tqm?Bs7B` z@e4gvCtgMJ0;UV;)aO{=F$|p({l0dnADB=XI@F9*8Ea!!5^au#AhjyV)&}1^tsLk_ z*ybhem&T6ucm%>=SQ?GnnMGXxg-)1B%&v|_s^Ib}=^E&t?%f~JkTiBtGqm)rNn0D0 zp~h+$H@#5YMP@Jre+S($XF+tsAmKNuWGTV2NaFYhsL7@v_pX#fwUGBw$!Rr`v7REM zBul^izev{TGS&csL)BlekUbW89p81KG2BkfdLiX2uDjFo!u(6gby?hWU1=t9vNt5k z^9JR2%j<=S7&AK4-@exqN!*!aT=!se2a%)P2c1$`nf$16Vp(p{Cs+=TtpriLN3Tzk7{bmA4 z$Fww>wD^f7&_iMJIq@Velj2Dn0^EaGZco7?Lk^6Obju)%EHSsN<3b;teL^}#UxN<+ z6ZFXDT(x|6u=30vz$25%Y2}RM-)!KKJPy7oa;iDUDTERCsF{Q0lv98e+PdjOIWX%v zumXNu0i-FyVU#Q}dg5bbCxt^~m+sYo>`)x$&vh8YP(8=S31Cy^%)SnTm5f|~NnKCh z_(+;s(9Dh+{{fG2@?PS2PCM9z<{r3Ljk=Z1d5jJGfHpPEW@4$JU0D*D*^RsW8(0fS zC*1=xV9z+|0DcikR*>yRh$oTig0lC=7-m(M#CUZAG0t=% zkvhY^KcpqtT^@H~Uhi{K3nNpXGV)`5h-pr;32nokGIUOLO*~`2A?V#h^(iY)2uT!K z3G7{zfe8vosKA7s2PURi6%?Nx#6})Urc&URiX0Ku_69MUz0IJxIfS|(5hGBy?=(04 z=5~&9655)hAsE=72xLfW)Q@%p9!C@?@InV}QQ&Rh+ZYoO0}bWtJ_>yU8XabFUvm-2 zKpycIm}_PNnLDIf1TMC8v6NVUr6+~0;#O%wAOohqMM^8P1H_le*ZQDt^G`55_b4IK zXGOK{top7Xj|fo?884DZm{mr}Bo$t+kxvDV6C8~kv4knoYDaj4jQPRUspw^hSo+EY z%`yxj5CH~10vzi59v(rEm{!TiA;>u~K7|=($@tB7nSZFmC)c&~YJ%us-&zE$0sDdc z@Fj&BowaEAZO5g)?Eq&wN$nhyO=ETir4{C@xtVdxsD5a5L8o2>4 zNyq_{)AG=jx2Om-rwH^3`HzxrSplJ%D9KE*FEY!279=@NDc8~5_V+Ur?q+8C&zfh* zmd&W~b8YlX+Pfm4p;r-tslcL{K)|t1V{BEz2t-K|D)IM7$maq&8Eq4mzf=N!pc9Nn zLqaz|99VV#&%tPbbxYh$OvEe-DrT|sTHgd!A!R29S`-e7{X$>gF7nrKDu}GXt0?xZ zmZUn`V%(<=A{z1=@-_4+VpQ4Y6DW(FbSD~k8pU=PZ+Kx^Sb?;xjO~HspE!fSK@eXB zWV4pZTWM>5cg|wv#4(D!$CY(fUS&a38LR(5V-fe0u?lnb!33(h6fKQ8B5gi%$2h_b z62BuxEZE_=>DwQ*qxd`zIXHFa#&vPSL98Q4ZXm!(3`3Tb-{~g%jZAOI2u8i6mQDwj z734hdpW=2Kafkx*H+pUUA??pWg0>f^Sv5wqln2aLtIcKv3@V7RT4pvqC}It~Lmf(a z4G&Q|%Yx4TweMe{lb}F?W>lamYUIo4hHm_qWf{gCVgm~%#Wm7D{sU+_W^>q>g3M%+ zJpn042=`b&GRU|)GF&sU4iPRmGANLCU;Bmr6ioTKc3`3g*8xY`B`Dg@^&<+t+5GO# zwIc-Cmmf@Q1rn3REw4XBvXKqpXy*q07seH!5uOWAp#g{nu2e74js|o%26x? zS$+#)sKBK*UuZA%7e>ou5Dj=@rt-m}P1&-vZTy1#N8@+~Va&s$x|ON93}ZC+30KhrLB(uWCEj z`UV7T@pCP?2s)WZ+96!~BW)Gb*?FCTR?r$`c1)$ekw$86z$+tcU;;aPL9(g%Q#dUS zKY`40B><;dZ5S<~kGY0xIQL`Hd9Y@Z1TjR>^_u}y-X`1uIBabhzHdUuAgbWVs|~Rh-2>3`i1O=L; zlUsw63q307rk|K2u5MlDWQf2MBY^p%kSm5&V0!mZF3S*u1zd;$)#^Wr<4Cc0q7c$~h+i z$;z^yQbE^(2pxj~Y`Id)xgA`rAgq-YWKrTsX2RO$uT%eOK5!m;oU?69aVD)>(^h9qNF!ax-Nfu%twpf)l^)`v?WUj;!^`I1CCE8*a2(h-Y70{34~ zXG!yqk^3DUaSw@BtRl=)GpYq!H(*j2(27;079sh6TV@S)Hhh1?SMeshzN}w0ss=?{ z7Z7<(zw!S#uQ7fiJux&z{s{$Ap`s=Om)e$$v%omf$k`+x2$=FFFr^4gc?8o05}Pg{ z>{d$bWU8+p!Wqqt5`^V`q7RG`v?yZ?^LY9MxJBxi&;`=`79yQARV1P>5ux&FQZ~ z5fTFuD=z5i^$9F@exxzwM^+DQmLN$w@n8sP@sbKb9_kOaoQ^vpx*b==GZ!#wuS-@?~3o8)A-|DL9m_BeKtUY@XiDZp#>@>%~+hA+rW zlV~78OP&?~HPzABBlAf?moolie0YvWUKb*+VcJuOh+Vet*cUl{8;gVz;L+knh=Yrd zB41!Ycu0W^_#g^8%-5~-d+NH3)DtcYh|lE?aNi_R(b?NXAR@=jaR(shd8w#iuz`Db zVQjGmX!scx!TU(k__NywWX?q~x$_cza~lsaG3T>82l*&V4sO@z-vOj@Z0*x>aL4Z> zID$?v3Bv&5x$leRC|+_%=`Blb=U|jO%eSR);<~1h{@EWsVbtsRJOF}^PB}U_u4IcU za*ZIu&uEX*QY7PX;}*) z=?R$Z2=Obxc;!r^QTI+d!4hGztK-eo0!UYTiMr08g3x|f8sm!V6I$^+C1j_{NF4Vm z_n49&Q$qV6q1lk(GkaBqm+!)`RT7R140+W~*X?ka;W7h6jIvpKI5$(fIJfsdQmikb literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..50344a690fc3ee87e0ff4715fd9a2e81fc3e56a8 GIT binary patch literal 414 zcmYk2%SyvQ6o!*Dy--@}LeNLBi#pLop&(*SBL?e4a;cEbkap5GGPy95gtpJ(#-%%- zCtFu}0T-^EvuXFS#53_-(2cZLHe#p#o& z&2+=D(5<6SCupLZzxg9*pvSST-fPw&`!3KP|7VYH1`-{A9t8?Zv7 zoQAvTa`~dH*PGoAkVY>U=a7~_oi*VSHFhod9O;@|lJaG7yp literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/autocompletion.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/autocompletion.py new file mode 100644 index 0000000..0a04199 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/autocompletion.py @@ -0,0 +1,152 @@ +"""Logic that powers autocompletion installed by ``pip completion``. +""" + +import optparse +import os +import sys + +from pip._internal.cli.main_parser import create_main_parser +from pip._internal.commands import commands_dict, get_summaries +from pip._internal.utils.misc import get_installed_distributions + + +def autocomplete(): + """Entry Point for completion of main and subcommand options. + """ + # Don't complete if user hasn't sourced bash_completion file. + if 'PIP_AUTO_COMPLETE' not in os.environ: + return + cwords = os.environ['COMP_WORDS'].split()[1:] + cword = int(os.environ['COMP_CWORD']) + try: + current = cwords[cword - 1] + except IndexError: + current = '' + + subcommands = [cmd for cmd, summary in get_summaries()] + options = [] + # subcommand + try: + subcommand_name = [w for w in cwords if w in subcommands][0] + except IndexError: + subcommand_name = None + + parser = create_main_parser() + # subcommand options + if subcommand_name: + # special case: 'help' subcommand has no options + if subcommand_name == 'help': + sys.exit(1) + # special case: list locally installed dists for show and uninstall + should_list_installed = ( + subcommand_name in ['show', 'uninstall'] and + not current.startswith('-') + ) + if should_list_installed: + installed = [] + lc = current.lower() + for dist in get_installed_distributions(local_only=True): + if dist.key.startswith(lc) and dist.key not in cwords[1:]: + installed.append(dist.key) + # if there are no dists installed, fall back to option completion + if installed: + for dist in installed: + print(dist) + sys.exit(1) + + subcommand = commands_dict[subcommand_name]() + + for opt in subcommand.parser.option_list_all: + if opt.help != optparse.SUPPRESS_HELP: + for opt_str in opt._long_opts + opt._short_opts: + options.append((opt_str, opt.nargs)) + + # filter out previously specified options from available options + prev_opts = [x.split('=')[0] for x in cwords[1:cword - 1]] + options = [(x, v) for (x, v) in options if x not in prev_opts] + # filter options by current input + options = [(k, v) for k, v in options if k.startswith(current)] + # get completion type given cwords and available subcommand options + completion_type = get_path_completion_type( + cwords, cword, subcommand.parser.option_list_all, + ) + # get completion files and directories if ``completion_type`` is + # ````, ``

`` or ```` + if completion_type: + options = auto_complete_paths(current, completion_type) + options = ((opt, 0) for opt in options) + for option in options: + opt_label = option[0] + # append '=' to options which require args + if option[1] and option[0][:2] == "--": + opt_label += '=' + print(opt_label) + else: + # show main parser options only when necessary + + opts = [i.option_list for i in parser.option_groups] + opts.append(parser.option_list) + opts = (o for it in opts for o in it) + if current.startswith('-'): + for opt in opts: + if opt.help != optparse.SUPPRESS_HELP: + subcommands += opt._long_opts + opt._short_opts + else: + # get completion type given cwords and all available options + completion_type = get_path_completion_type(cwords, cword, opts) + if completion_type: + subcommands = auto_complete_paths(current, completion_type) + + print(' '.join([x for x in subcommands if x.startswith(current)])) + sys.exit(1) + + +def get_path_completion_type(cwords, cword, opts): + """Get the type of path completion (``file``, ``dir``, ``path`` or None) + + :param cwords: same as the environmental variable ``COMP_WORDS`` + :param cword: same as the environmental variable ``COMP_CWORD`` + :param opts: The available options to check + :return: path completion type (``file``, ``dir``, ``path`` or None) + """ + if cword < 2 or not cwords[cword - 2].startswith('-'): + return + for opt in opts: + if opt.help == optparse.SUPPRESS_HELP: + continue + for o in str(opt).split('/'): + if cwords[cword - 2].split('=')[0] == o: + if not opt.metavar or any( + x in ('path', 'file', 'dir') + for x in opt.metavar.split('/')): + return opt.metavar + + +def auto_complete_paths(current, completion_type): + """If ``completion_type`` is ``file`` or ``path``, list all regular files + and directories starting with ``current``; otherwise only list directories + starting with ``current``. + + :param current: The word to be completed + :param completion_type: path completion type(`file`, `path` or `dir`)i + :return: A generator of regular files and/or directories + """ + directory, filename = os.path.split(current) + current_path = os.path.abspath(directory) + # Don't complete paths if they can't be accessed + if not os.access(current_path, os.R_OK): + return + filename = os.path.normcase(filename) + # list all files that start with ``filename`` + file_list = (x for x in os.listdir(current_path) + if os.path.normcase(x).startswith(filename)) + for f in file_list: + opt = os.path.join(current_path, f) + comp_file = os.path.normcase(os.path.join(directory, f)) + # complete regular files when there is not ```` after option + # complete directories when there is ````, ```` or + # ````after option + if completion_type != 'dir' and os.path.isfile(opt): + yield comp_file + elif os.path.isdir(opt): + yield os.path.join(comp_file, '') diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/base_command.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/base_command.py new file mode 100644 index 0000000..90830be --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/base_command.py @@ -0,0 +1,346 @@ +"""Base Command class, and related routines""" +from __future__ import absolute_import, print_function + +import logging +import logging.config +import optparse +import os +import platform +import sys +import traceback + +from pip._internal.cli import cmdoptions +from pip._internal.cli.cmdoptions import make_search_scope +from pip._internal.cli.parser import ( + ConfigOptionParser, UpdatingDefaultsHelpFormatter, +) +from pip._internal.cli.status_codes import ( + ERROR, PREVIOUS_BUILD_DIR_ERROR, SUCCESS, UNKNOWN_ERROR, + VIRTUALENV_NOT_FOUND, +) +from pip._internal.download import PipSession +from pip._internal.exceptions import ( + BadCommand, CommandError, InstallationError, PreviousBuildDirError, + UninstallationError, +) +from pip._internal.index import PackageFinder +from pip._internal.models.selection_prefs import SelectionPreferences +from pip._internal.models.target_python import TargetPython +from pip._internal.req.constructors import ( + install_req_from_editable, install_req_from_line, +) +from pip._internal.req.req_file import parse_requirements +from pip._internal.utils.deprecation import deprecated +from pip._internal.utils.logging import BrokenStdoutLoggingError, setup_logging +from pip._internal.utils.misc import get_prog, normalize_path +from pip._internal.utils.outdated import pip_version_check +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.virtualenv import running_under_virtualenv + +if MYPY_CHECK_RUNNING: + from typing import Optional, List, Tuple, Any + from optparse import Values + from pip._internal.cache import WheelCache + from pip._internal.req.req_set import RequirementSet + +__all__ = ['Command'] + +logger = logging.getLogger(__name__) + + +class Command(object): + name = None # type: Optional[str] + usage = None # type: Optional[str] + ignore_require_venv = False # type: bool + + def __init__(self, isolated=False): + # type: (bool) -> None + parser_kw = { + 'usage': self.usage, + 'prog': '%s %s' % (get_prog(), self.name), + 'formatter': UpdatingDefaultsHelpFormatter(), + 'add_help_option': False, + 'name': self.name, + 'description': self.__doc__, + 'isolated': isolated, + } + + self.parser = ConfigOptionParser(**parser_kw) + + # Commands should add options to this option group + optgroup_name = '%s Options' % self.name.capitalize() + self.cmd_opts = optparse.OptionGroup(self.parser, optgroup_name) + + # Add the general options + gen_opts = cmdoptions.make_option_group( + cmdoptions.general_group, + self.parser, + ) + self.parser.add_option_group(gen_opts) + + def run(self, options, args): + # type: (Values, List[Any]) -> Any + raise NotImplementedError + + @classmethod + def _get_index_urls(cls, options): + """Return a list of index urls from user-provided options.""" + index_urls = [] + if not getattr(options, "no_index", False): + url = getattr(options, "index_url", None) + if url: + index_urls.append(url) + urls = getattr(options, "extra_index_urls", None) + if urls: + index_urls.extend(urls) + # Return None rather than an empty list + return index_urls or None + + def _build_session(self, options, retries=None, timeout=None): + # type: (Values, Optional[int], Optional[int]) -> PipSession + session = PipSession( + cache=( + normalize_path(os.path.join(options.cache_dir, "http")) + if options.cache_dir else None + ), + retries=retries if retries is not None else options.retries, + insecure_hosts=options.trusted_hosts, + index_urls=self._get_index_urls(options), + ) + + # Handle custom ca-bundles from the user + if options.cert: + session.verify = options.cert + + # Handle SSL client certificate + if options.client_cert: + session.cert = options.client_cert + + # Handle timeouts + if options.timeout or timeout: + session.timeout = ( + timeout if timeout is not None else options.timeout + ) + + # Handle configured proxies + if options.proxy: + session.proxies = { + "http": options.proxy, + "https": options.proxy, + } + + # Determine if we can prompt the user for authentication or not + session.auth.prompting = not options.no_input + + return session + + def parse_args(self, args): + # type: (List[str]) -> Tuple + # factored out for testability + return self.parser.parse_args(args) + + def main(self, args): + # type: (List[str]) -> int + options, args = self.parse_args(args) + + # Set verbosity so that it can be used elsewhere. + self.verbosity = options.verbose - options.quiet + + level_number = setup_logging( + verbosity=self.verbosity, + no_color=options.no_color, + user_log_file=options.log, + ) + + if sys.version_info[:2] == (2, 7): + message = ( + "A future version of pip will drop support for Python 2.7. " + "More details about Python 2 support in pip, can be found at " + "https://pip.pypa.io/en/latest/development/release-process/#python-2-support" # noqa + ) + if platform.python_implementation() == "CPython": + message = ( + "Python 2.7 will reach the end of its life on January " + "1st, 2020. Please upgrade your Python as Python 2.7 " + "won't be maintained after that date. " + ) + message + deprecated(message, replacement=None, gone_in=None) + + # TODO: Try to get these passing down from the command? + # without resorting to os.environ to hold these. + # This also affects isolated builds and it should. + + if options.no_input: + os.environ['PIP_NO_INPUT'] = '1' + + if options.exists_action: + os.environ['PIP_EXISTS_ACTION'] = ' '.join(options.exists_action) + + if options.require_venv and not self.ignore_require_venv: + # If a venv is required check if it can really be found + if not running_under_virtualenv(): + logger.critical( + 'Could not find an activated virtualenv (required).' + ) + sys.exit(VIRTUALENV_NOT_FOUND) + + try: + status = self.run(options, args) + # FIXME: all commands should return an exit status + # and when it is done, isinstance is not needed anymore + if isinstance(status, int): + return status + except PreviousBuildDirError as exc: + logger.critical(str(exc)) + logger.debug('Exception information:', exc_info=True) + + return PREVIOUS_BUILD_DIR_ERROR + except (InstallationError, UninstallationError, BadCommand) as exc: + logger.critical(str(exc)) + logger.debug('Exception information:', exc_info=True) + + return ERROR + except CommandError as exc: + logger.critical('%s', exc) + logger.debug('Exception information:', exc_info=True) + + return ERROR + except BrokenStdoutLoggingError: + # Bypass our logger and write any remaining messages to stderr + # because stdout no longer works. + print('ERROR: Pipe to stdout was broken', file=sys.stderr) + if level_number <= logging.DEBUG: + traceback.print_exc(file=sys.stderr) + + return ERROR + except KeyboardInterrupt: + logger.critical('Operation cancelled by user') + logger.debug('Exception information:', exc_info=True) + + return ERROR + except BaseException: + logger.critical('Exception:', exc_info=True) + + return UNKNOWN_ERROR + finally: + allow_version_check = ( + # Does this command have the index_group options? + hasattr(options, "no_index") and + # Is this command allowed to perform this check? + not (options.disable_pip_version_check or options.no_index) + ) + # Check if we're using the latest version of pip available + if allow_version_check: + session = self._build_session( + options, + retries=0, + timeout=min(5, options.timeout) + ) + with session: + pip_version_check(session, options) + + # Shutdown the logging module + logging.shutdown() + + return SUCCESS + + +class RequirementCommand(Command): + + @staticmethod + def populate_requirement_set(requirement_set, # type: RequirementSet + args, # type: List[str] + options, # type: Values + finder, # type: PackageFinder + session, # type: PipSession + name, # type: str + wheel_cache # type: Optional[WheelCache] + ): + # type: (...) -> None + """ + Marshal cmd line args into a requirement set. + """ + # NOTE: As a side-effect, options.require_hashes and + # requirement_set.require_hashes may be updated + + for filename in options.constraints: + for req_to_add in parse_requirements( + filename, + constraint=True, finder=finder, options=options, + session=session, wheel_cache=wheel_cache): + req_to_add.is_direct = True + requirement_set.add_requirement(req_to_add) + + for req in args: + req_to_add = install_req_from_line( + req, None, isolated=options.isolated_mode, + use_pep517=options.use_pep517, + wheel_cache=wheel_cache + ) + req_to_add.is_direct = True + requirement_set.add_requirement(req_to_add) + + for req in options.editables: + req_to_add = install_req_from_editable( + req, + isolated=options.isolated_mode, + use_pep517=options.use_pep517, + wheel_cache=wheel_cache + ) + req_to_add.is_direct = True + requirement_set.add_requirement(req_to_add) + + for filename in options.requirements: + for req_to_add in parse_requirements( + filename, + finder=finder, options=options, session=session, + wheel_cache=wheel_cache, + use_pep517=options.use_pep517): + req_to_add.is_direct = True + requirement_set.add_requirement(req_to_add) + # If --require-hashes was a line in a requirements file, tell + # RequirementSet about it: + requirement_set.require_hashes = options.require_hashes + + if not (args or options.editables or options.requirements): + opts = {'name': name} + if options.find_links: + raise CommandError( + 'You must give at least one requirement to %(name)s ' + '(maybe you meant "pip %(name)s %(links)s"?)' % + dict(opts, links=' '.join(options.find_links))) + else: + raise CommandError( + 'You must give at least one requirement to %(name)s ' + '(see "pip help %(name)s")' % opts) + + def _build_package_finder( + self, + options, # type: Values + session, # type: PipSession + target_python=None, # type: Optional[TargetPython] + ignore_requires_python=None, # type: Optional[bool] + ): + # type: (...) -> PackageFinder + """ + Create a package finder appropriate to this requirement command. + + :param ignore_requires_python: Whether to ignore incompatible + "Requires-Python" values in links. Defaults to False. + """ + search_scope = make_search_scope(options) + selection_prefs = SelectionPreferences( + allow_yanked=True, + format_control=options.format_control, + allow_all_prereleases=options.pre, + prefer_binary=options.prefer_binary, + ignore_requires_python=ignore_requires_python, + ) + + return PackageFinder.create( + search_scope=search_scope, + selection_prefs=selection_prefs, + trusted_hosts=options.trusted_hosts, + session=session, + target_python=target_python, + ) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/cmdoptions.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/cmdoptions.py new file mode 100644 index 0000000..c5c6c22 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/cmdoptions.py @@ -0,0 +1,931 @@ +""" +shared options and groups + +The principle here is to define options once, but *not* instantiate them +globally. One reason being that options with action='append' can carry state +between parses. pip parses general options twice internally, and shouldn't +pass on state. To be consistent, all options will follow this design. + +""" +from __future__ import absolute_import + +import logging +import textwrap +import warnings +from distutils.util import strtobool +from functools import partial +from optparse import SUPPRESS_HELP, Option, OptionGroup +from textwrap import dedent + +from pip._internal.exceptions import CommandError +from pip._internal.locations import USER_CACHE_DIR, get_src_prefix +from pip._internal.models.format_control import FormatControl +from pip._internal.models.index import PyPI +from pip._internal.models.search_scope import SearchScope +from pip._internal.models.target_python import TargetPython +from pip._internal.utils.hashes import STRONG_HASHES +from pip._internal.utils.misc import redact_password_from_url +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.ui import BAR_TYPES + +if MYPY_CHECK_RUNNING: + from typing import Any, Callable, Dict, Optional, Tuple + from optparse import OptionParser, Values + from pip._internal.cli.parser import ConfigOptionParser + +logger = logging.getLogger(__name__) + + +def raise_option_error(parser, option, msg): + """ + Raise an option parsing error using parser.error(). + + Args: + parser: an OptionParser instance. + option: an Option instance. + msg: the error text. + """ + msg = '{} error: {}'.format(option, msg) + msg = textwrap.fill(' '.join(msg.split())) + parser.error(msg) + + +def make_option_group(group, parser): + # type: (Dict[str, Any], ConfigOptionParser) -> OptionGroup + """ + Return an OptionGroup object + group -- assumed to be dict with 'name' and 'options' keys + parser -- an optparse Parser + """ + option_group = OptionGroup(parser, group['name']) + for option in group['options']: + option_group.add_option(option()) + return option_group + + +def check_install_build_global(options, check_options=None): + # type: (Values, Optional[Values]) -> None + """Disable wheels if per-setup.py call options are set. + + :param options: The OptionParser options to update. + :param check_options: The options to check, if not supplied defaults to + options. + """ + if check_options is None: + check_options = options + + def getname(n): + return getattr(check_options, n, None) + names = ["build_options", "global_options", "install_options"] + if any(map(getname, names)): + control = options.format_control + control.disallow_binaries() + warnings.warn( + 'Disabling all use of wheels due to the use of --build-options ' + '/ --global-options / --install-options.', stacklevel=2, + ) + + +def check_dist_restriction(options, check_target=False): + # type: (Values, bool) -> None + """Function for determining if custom platform options are allowed. + + :param options: The OptionParser options. + :param check_target: Whether or not to check if --target is being used. + """ + dist_restriction_set = any([ + options.python_version, + options.platform, + options.abi, + options.implementation, + ]) + + binary_only = FormatControl(set(), {':all:'}) + sdist_dependencies_allowed = ( + options.format_control != binary_only and + not options.ignore_dependencies + ) + + # Installations or downloads using dist restrictions must not combine + # source distributions and dist-specific wheels, as they are not + # guaranteed to be locally compatible. + if dist_restriction_set and sdist_dependencies_allowed: + raise CommandError( + "When restricting platform and interpreter constraints using " + "--python-version, --platform, --abi, or --implementation, " + "either --no-deps must be set, or --only-binary=:all: must be " + "set and --no-binary must not be set (or must be set to " + ":none:)." + ) + + if check_target: + if dist_restriction_set and not options.target_dir: + raise CommandError( + "Can not use any platform or abi specific options unless " + "installing via '--target'" + ) + + +########### +# options # +########### + +help_ = partial( + Option, + '-h', '--help', + dest='help', + action='help', + help='Show help.', +) # type: Callable[..., Option] + +isolated_mode = partial( + Option, + "--isolated", + dest="isolated_mode", + action="store_true", + default=False, + help=( + "Run pip in an isolated mode, ignoring environment variables and user " + "configuration." + ), +) # type: Callable[..., Option] + +require_virtualenv = partial( + Option, + # Run only if inside a virtualenv, bail if not. + '--require-virtualenv', '--require-venv', + dest='require_venv', + action='store_true', + default=False, + help=SUPPRESS_HELP +) # type: Callable[..., Option] + +verbose = partial( + Option, + '-v', '--verbose', + dest='verbose', + action='count', + default=0, + help='Give more output. Option is additive, and can be used up to 3 times.' +) # type: Callable[..., Option] + +no_color = partial( + Option, + '--no-color', + dest='no_color', + action='store_true', + default=False, + help="Suppress colored output", +) # type: Callable[..., Option] + +version = partial( + Option, + '-V', '--version', + dest='version', + action='store_true', + help='Show version and exit.', +) # type: Callable[..., Option] + +quiet = partial( + Option, + '-q', '--quiet', + dest='quiet', + action='count', + default=0, + help=( + 'Give less output. Option is additive, and can be used up to 3' + ' times (corresponding to WARNING, ERROR, and CRITICAL logging' + ' levels).' + ), +) # type: Callable[..., Option] + +progress_bar = partial( + Option, + '--progress-bar', + dest='progress_bar', + type='choice', + choices=list(BAR_TYPES.keys()), + default='on', + help=( + 'Specify type of progress to be displayed [' + + '|'.join(BAR_TYPES.keys()) + '] (default: %default)' + ), +) # type: Callable[..., Option] + +log = partial( + Option, + "--log", "--log-file", "--local-log", + dest="log", + metavar="path", + help="Path to a verbose appending log." +) # type: Callable[..., Option] + +no_input = partial( + Option, + # Don't ask for input + '--no-input', + dest='no_input', + action='store_true', + default=False, + help=SUPPRESS_HELP +) # type: Callable[..., Option] + +proxy = partial( + Option, + '--proxy', + dest='proxy', + type='str', + default='', + help="Specify a proxy in the form [user:passwd@]proxy.server:port." +) # type: Callable[..., Option] + +retries = partial( + Option, + '--retries', + dest='retries', + type='int', + default=5, + help="Maximum number of retries each connection should attempt " + "(default %default times).", +) # type: Callable[..., Option] + +timeout = partial( + Option, + '--timeout', '--default-timeout', + metavar='sec', + dest='timeout', + type='float', + default=15, + help='Set the socket timeout (default %default seconds).', +) # type: Callable[..., Option] + +skip_requirements_regex = partial( + Option, + # A regex to be used to skip requirements + '--skip-requirements-regex', + dest='skip_requirements_regex', + type='str', + default='', + help=SUPPRESS_HELP, +) # type: Callable[..., Option] + + +def exists_action(): + # type: () -> Option + return Option( + # Option when path already exist + '--exists-action', + dest='exists_action', + type='choice', + choices=['s', 'i', 'w', 'b', 'a'], + default=[], + action='append', + metavar='action', + help="Default action when a path already exists: " + "(s)witch, (i)gnore, (w)ipe, (b)ackup, (a)bort.", + ) + + +cert = partial( + Option, + '--cert', + dest='cert', + type='str', + metavar='path', + help="Path to alternate CA bundle.", +) # type: Callable[..., Option] + +client_cert = partial( + Option, + '--client-cert', + dest='client_cert', + type='str', + default=None, + metavar='path', + help="Path to SSL client certificate, a single file containing the " + "private key and the certificate in PEM format.", +) # type: Callable[..., Option] + +index_url = partial( + Option, + '-i', '--index-url', '--pypi-url', + dest='index_url', + metavar='URL', + default=PyPI.simple_url, + help="Base URL of the Python Package Index (default %default). " + "This should point to a repository compliant with PEP 503 " + "(the simple repository API) or a local directory laid out " + "in the same format.", +) # type: Callable[..., Option] + + +def extra_index_url(): + return Option( + '--extra-index-url', + dest='extra_index_urls', + metavar='URL', + action='append', + default=[], + help="Extra URLs of package indexes to use in addition to " + "--index-url. Should follow the same rules as " + "--index-url.", + ) + + +no_index = partial( + Option, + '--no-index', + dest='no_index', + action='store_true', + default=False, + help='Ignore package index (only looking at --find-links URLs instead).', +) # type: Callable[..., Option] + + +def find_links(): + # type: () -> Option + return Option( + '-f', '--find-links', + dest='find_links', + action='append', + default=[], + metavar='url', + help="If a url or path to an html file, then parse for links to " + "archives. If a local path or file:// url that's a directory, " + "then look for archives in the directory listing.", + ) + + +def make_search_scope(options, suppress_no_index=False): + # type: (Values, bool) -> SearchScope + """ + :param suppress_no_index: Whether to ignore the --no-index option + when constructing the SearchScope object. + """ + index_urls = [options.index_url] + options.extra_index_urls + if options.no_index and not suppress_no_index: + logger.debug( + 'Ignoring indexes: %s', + ','.join(redact_password_from_url(url) for url in index_urls), + ) + index_urls = [] + + # Make sure find_links is a list before passing to create(). + find_links = options.find_links or [] + + search_scope = SearchScope.create( + find_links=find_links, index_urls=index_urls, + ) + + return search_scope + + +def trusted_host(): + # type: () -> Option + return Option( + "--trusted-host", + dest="trusted_hosts", + action="append", + metavar="HOSTNAME", + default=[], + help="Mark this host as trusted, even though it does not have valid " + "or any HTTPS.", + ) + + +def constraints(): + # type: () -> Option + return Option( + '-c', '--constraint', + dest='constraints', + action='append', + default=[], + metavar='file', + help='Constrain versions using the given constraints file. ' + 'This option can be used multiple times.' + ) + + +def requirements(): + # type: () -> Option + return Option( + '-r', '--requirement', + dest='requirements', + action='append', + default=[], + metavar='file', + help='Install from the given requirements file. ' + 'This option can be used multiple times.' + ) + + +def editable(): + # type: () -> Option + return Option( + '-e', '--editable', + dest='editables', + action='append', + default=[], + metavar='path/url', + help=('Install a project in editable mode (i.e. setuptools ' + '"develop mode") from a local project path or a VCS url.'), + ) + + +src = partial( + Option, + '--src', '--source', '--source-dir', '--source-directory', + dest='src_dir', + metavar='dir', + default=get_src_prefix(), + help='Directory to check out editable projects into. ' + 'The default in a virtualenv is "/src". ' + 'The default for global installs is "/src".' +) # type: Callable[..., Option] + + +def _get_format_control(values, option): + # type: (Values, Option) -> Any + """Get a format_control object.""" + return getattr(values, option.dest) + + +def _handle_no_binary(option, opt_str, value, parser): + # type: (Option, str, str, OptionParser) -> None + existing = _get_format_control(parser.values, option) + FormatControl.handle_mutual_excludes( + value, existing.no_binary, existing.only_binary, + ) + + +def _handle_only_binary(option, opt_str, value, parser): + # type: (Option, str, str, OptionParser) -> None + existing = _get_format_control(parser.values, option) + FormatControl.handle_mutual_excludes( + value, existing.only_binary, existing.no_binary, + ) + + +def no_binary(): + # type: () -> Option + format_control = FormatControl(set(), set()) + return Option( + "--no-binary", dest="format_control", action="callback", + callback=_handle_no_binary, type="str", + default=format_control, + help="Do not use binary packages. Can be supplied multiple times, and " + "each time adds to the existing value. Accepts either :all: to " + "disable all binary packages, :none: to empty the set, or one or " + "more package names with commas between them. Note that some " + "packages are tricky to compile and may fail to install when " + "this option is used on them.", + ) + + +def only_binary(): + # type: () -> Option + format_control = FormatControl(set(), set()) + return Option( + "--only-binary", dest="format_control", action="callback", + callback=_handle_only_binary, type="str", + default=format_control, + help="Do not use source packages. Can be supplied multiple times, and " + "each time adds to the existing value. Accepts either :all: to " + "disable all source packages, :none: to empty the set, or one or " + "more package names with commas between them. Packages without " + "binary distributions will fail to install when this option is " + "used on them.", + ) + + +platform = partial( + Option, + '--platform', + dest='platform', + metavar='platform', + default=None, + help=("Only use wheels compatible with . " + "Defaults to the platform of the running system."), +) # type: Callable[..., Option] + + +# This was made a separate function for unit-testing purposes. +def _convert_python_version(value): + # type: (str) -> Tuple[Tuple[int, ...], Optional[str]] + """ + Convert a version string like "3", "37", or "3.7.3" into a tuple of ints. + + :return: A 2-tuple (version_info, error_msg), where `error_msg` is + non-None if and only if there was a parsing error. + """ + if not value: + # The empty string is the same as not providing a value. + return (None, None) + + parts = value.split('.') + if len(parts) > 3: + return ((), 'at most three version parts are allowed') + + if len(parts) == 1: + # Then we are in the case of "3" or "37". + value = parts[0] + if len(value) > 1: + parts = [value[0], value[1:]] + + try: + version_info = tuple(int(part) for part in parts) + except ValueError: + return ((), 'each version part must be an integer') + + return (version_info, None) + + +def _handle_python_version(option, opt_str, value, parser): + # type: (Option, str, str, OptionParser) -> None + """ + Handle a provided --python-version value. + """ + version_info, error_msg = _convert_python_version(value) + if error_msg is not None: + msg = ( + 'invalid --python-version value: {!r}: {}'.format( + value, error_msg, + ) + ) + raise_option_error(parser, option=option, msg=msg) + + parser.values.python_version = version_info + + +python_version = partial( + Option, + '--python-version', + dest='python_version', + metavar='python_version', + action='callback', + callback=_handle_python_version, type='str', + default=None, + help=dedent("""\ + The Python interpreter version to use for wheel and "Requires-Python" + compatibility checks. Defaults to a version derived from the running + interpreter. The version can be specified using up to three dot-separated + integers (e.g. "3" for 3.0.0, "3.7" for 3.7.0, or "3.7.3"). A major-minor + version can also be given as a string without dots (e.g. "37" for 3.7.0). + """), +) # type: Callable[..., Option] + + +implementation = partial( + Option, + '--implementation', + dest='implementation', + metavar='implementation', + default=None, + help=("Only use wheels compatible with Python " + "implementation , e.g. 'pp', 'jy', 'cp', " + " or 'ip'. If not specified, then the current " + "interpreter implementation is used. Use 'py' to force " + "implementation-agnostic wheels."), +) # type: Callable[..., Option] + + +abi = partial( + Option, + '--abi', + dest='abi', + metavar='abi', + default=None, + help=("Only use wheels compatible with Python " + "abi , e.g. 'pypy_41'. If not specified, then the " + "current interpreter abi tag is used. Generally " + "you will need to specify --implementation, " + "--platform, and --python-version when using " + "this option."), +) # type: Callable[..., Option] + + +def add_target_python_options(cmd_opts): + # type: (OptionGroup) -> None + cmd_opts.add_option(platform()) + cmd_opts.add_option(python_version()) + cmd_opts.add_option(implementation()) + cmd_opts.add_option(abi()) + + +def make_target_python(options): + # type: (Values) -> TargetPython + target_python = TargetPython( + platform=options.platform, + py_version_info=options.python_version, + abi=options.abi, + implementation=options.implementation, + ) + + return target_python + + +def prefer_binary(): + # type: () -> Option + return Option( + "--prefer-binary", + dest="prefer_binary", + action="store_true", + default=False, + help="Prefer older binary packages over newer source packages." + ) + + +cache_dir = partial( + Option, + "--cache-dir", + dest="cache_dir", + default=USER_CACHE_DIR, + metavar="dir", + help="Store the cache data in ." +) # type: Callable[..., Option] + + +def _handle_no_cache_dir(option, opt, value, parser): + # type: (Option, str, str, OptionParser) -> None + """ + Process a value provided for the --no-cache-dir option. + + This is an optparse.Option callback for the --no-cache-dir option. + """ + # The value argument will be None if --no-cache-dir is passed via the + # command-line, since the option doesn't accept arguments. However, + # the value can be non-None if the option is triggered e.g. by an + # environment variable, like PIP_NO_CACHE_DIR=true. + if value is not None: + # Then parse the string value to get argument error-checking. + try: + strtobool(value) + except ValueError as exc: + raise_option_error(parser, option=option, msg=str(exc)) + + # Originally, setting PIP_NO_CACHE_DIR to a value that strtobool() + # converted to 0 (like "false" or "no") caused cache_dir to be disabled + # rather than enabled (logic would say the latter). Thus, we disable + # the cache directory not just on values that parse to True, but (for + # backwards compatibility reasons) also on values that parse to False. + # In other words, always set it to False if the option is provided in + # some (valid) form. + parser.values.cache_dir = False + + +no_cache = partial( + Option, + "--no-cache-dir", + dest="cache_dir", + action="callback", + callback=_handle_no_cache_dir, + help="Disable the cache.", +) # type: Callable[..., Option] + +no_deps = partial( + Option, + '--no-deps', '--no-dependencies', + dest='ignore_dependencies', + action='store_true', + default=False, + help="Don't install package dependencies.", +) # type: Callable[..., Option] + +build_dir = partial( + Option, + '-b', '--build', '--build-dir', '--build-directory', + dest='build_dir', + metavar='dir', + help='Directory to unpack packages into and build in. Note that ' + 'an initial build still takes place in a temporary directory. ' + 'The location of temporary directories can be controlled by setting ' + 'the TMPDIR environment variable (TEMP on Windows) appropriately. ' + 'When passed, build directories are not cleaned in case of failures.' +) # type: Callable[..., Option] + +ignore_requires_python = partial( + Option, + '--ignore-requires-python', + dest='ignore_requires_python', + action='store_true', + help='Ignore the Requires-Python information.' +) # type: Callable[..., Option] + +no_build_isolation = partial( + Option, + '--no-build-isolation', + dest='build_isolation', + action='store_false', + default=True, + help='Disable isolation when building a modern source distribution. ' + 'Build dependencies specified by PEP 518 must be already installed ' + 'if this option is used.' +) # type: Callable[..., Option] + + +def _handle_no_use_pep517(option, opt, value, parser): + # type: (Option, str, str, OptionParser) -> None + """ + Process a value provided for the --no-use-pep517 option. + + This is an optparse.Option callback for the no_use_pep517 option. + """ + # Since --no-use-pep517 doesn't accept arguments, the value argument + # will be None if --no-use-pep517 is passed via the command-line. + # However, the value can be non-None if the option is triggered e.g. + # by an environment variable, for example "PIP_NO_USE_PEP517=true". + if value is not None: + msg = """A value was passed for --no-use-pep517, + probably using either the PIP_NO_USE_PEP517 environment variable + or the "no-use-pep517" config file option. Use an appropriate value + of the PIP_USE_PEP517 environment variable or the "use-pep517" + config file option instead. + """ + raise_option_error(parser, option=option, msg=msg) + + # Otherwise, --no-use-pep517 was passed via the command-line. + parser.values.use_pep517 = False + + +use_pep517 = partial( + Option, + '--use-pep517', + dest='use_pep517', + action='store_true', + default=None, + help='Use PEP 517 for building source distributions ' + '(use --no-use-pep517 to force legacy behaviour).' +) # type: Any + +no_use_pep517 = partial( + Option, + '--no-use-pep517', + dest='use_pep517', + action='callback', + callback=_handle_no_use_pep517, + default=None, + help=SUPPRESS_HELP +) # type: Any + +install_options = partial( + Option, + '--install-option', + dest='install_options', + action='append', + metavar='options', + help="Extra arguments to be supplied to the setup.py install " + "command (use like --install-option=\"--install-scripts=/usr/local/" + "bin\"). Use multiple --install-option options to pass multiple " + "options to setup.py install. If you are using an option with a " + "directory path, be sure to use absolute path.", +) # type: Callable[..., Option] + +global_options = partial( + Option, + '--global-option', + dest='global_options', + action='append', + metavar='options', + help="Extra global options to be supplied to the setup.py " + "call before the install command.", +) # type: Callable[..., Option] + +no_clean = partial( + Option, + '--no-clean', + action='store_true', + default=False, + help="Don't clean up build directories." +) # type: Callable[..., Option] + +pre = partial( + Option, + '--pre', + action='store_true', + default=False, + help="Include pre-release and development versions. By default, " + "pip only finds stable versions.", +) # type: Callable[..., Option] + +disable_pip_version_check = partial( + Option, + "--disable-pip-version-check", + dest="disable_pip_version_check", + action="store_true", + default=False, + help="Don't periodically check PyPI to determine whether a new version " + "of pip is available for download. Implied with --no-index.", +) # type: Callable[..., Option] + + +# Deprecated, Remove later +always_unzip = partial( + Option, + '-Z', '--always-unzip', + dest='always_unzip', + action='store_true', + help=SUPPRESS_HELP, +) # type: Callable[..., Option] + + +def _handle_merge_hash(option, opt_str, value, parser): + # type: (Option, str, str, OptionParser) -> None + """Given a value spelled "algo:digest", append the digest to a list + pointed to in a dict by the algo name.""" + if not parser.values.hashes: + parser.values.hashes = {} + try: + algo, digest = value.split(':', 1) + except ValueError: + parser.error('Arguments to %s must be a hash name ' + 'followed by a value, like --hash=sha256:abcde...' % + opt_str) + if algo not in STRONG_HASHES: + parser.error('Allowed hash algorithms for %s are %s.' % + (opt_str, ', '.join(STRONG_HASHES))) + parser.values.hashes.setdefault(algo, []).append(digest) + + +hash = partial( + Option, + '--hash', + # Hash values eventually end up in InstallRequirement.hashes due to + # __dict__ copying in process_line(). + dest='hashes', + action='callback', + callback=_handle_merge_hash, + type='string', + help="Verify that the package's archive matches this " + 'hash before installing. Example: --hash=sha256:abcdef...', +) # type: Callable[..., Option] + + +require_hashes = partial( + Option, + '--require-hashes', + dest='require_hashes', + action='store_true', + default=False, + help='Require a hash to check each requirement against, for ' + 'repeatable installs. This option is implied when any package in a ' + 'requirements file has a --hash option.', +) # type: Callable[..., Option] + + +list_path = partial( + Option, + '--path', + dest='path', + action='append', + help='Restrict to the specified installation path for listing ' + 'packages (can be used multiple times).' +) # type: Callable[..., Option] + + +def check_list_path_option(options): + # type: (Values) -> None + if options.path and (options.user or options.local): + raise CommandError( + "Cannot combine '--path' with '--user' or '--local'" + ) + + +########## +# groups # +########## + +general_group = { + 'name': 'General Options', + 'options': [ + help_, + isolated_mode, + require_virtualenv, + verbose, + version, + quiet, + log, + no_input, + proxy, + retries, + timeout, + skip_requirements_regex, + exists_action, + trusted_host, + cert, + client_cert, + cache_dir, + no_cache, + disable_pip_version_check, + no_color, + ] +} # type: Dict[str, Any] + +index_group = { + 'name': 'Package Index Options', + 'options': [ + index_url, + extra_index_url, + no_index, + find_links, + ] +} # type: Dict[str, Any] diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/main_parser.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/main_parser.py new file mode 100644 index 0000000..6d0b719 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/main_parser.py @@ -0,0 +1,98 @@ +"""A single place for constructing and exposing the main parser +""" + +import os +import sys + +from pip._internal.cli import cmdoptions +from pip._internal.cli.parser import ( + ConfigOptionParser, UpdatingDefaultsHelpFormatter, +) +from pip._internal.commands import ( + commands_dict, get_similar_commands, get_summaries, +) +from pip._internal.exceptions import CommandError +from pip._internal.utils.misc import get_pip_version, get_prog +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Tuple, List + + +__all__ = ["create_main_parser", "parse_command"] + + +def create_main_parser(): + # type: () -> ConfigOptionParser + """Creates and returns the main parser for pip's CLI + """ + + parser_kw = { + 'usage': '\n%prog [options]', + 'add_help_option': False, + 'formatter': UpdatingDefaultsHelpFormatter(), + 'name': 'global', + 'prog': get_prog(), + } + + parser = ConfigOptionParser(**parser_kw) + parser.disable_interspersed_args() + + parser.version = get_pip_version() + + # add the general options + gen_opts = cmdoptions.make_option_group(cmdoptions.general_group, parser) + parser.add_option_group(gen_opts) + + # so the help formatter knows + parser.main = True # type: ignore + + # create command listing for description + command_summaries = get_summaries() + description = [''] + ['%-27s %s' % (i, j) for i, j in command_summaries] + parser.description = '\n'.join(description) + + return parser + + +def parse_command(args): + # type: (List[str]) -> Tuple[str, List[str]] + parser = create_main_parser() + + # Note: parser calls disable_interspersed_args(), so the result of this + # call is to split the initial args into the general options before the + # subcommand and everything else. + # For example: + # args: ['--timeout=5', 'install', '--user', 'INITools'] + # general_options: ['--timeout==5'] + # args_else: ['install', '--user', 'INITools'] + general_options, args_else = parser.parse_args(args) + + # --version + if general_options.version: + sys.stdout.write(parser.version) # type: ignore + sys.stdout.write(os.linesep) + sys.exit() + + # pip || pip help -> print_help() + if not args_else or (args_else[0] == 'help' and len(args_else) == 1): + parser.print_help() + sys.exit() + + # the subcommand name + cmd_name = args_else[0] + + if cmd_name not in commands_dict: + guess = get_similar_commands(cmd_name) + + msg = ['unknown command "%s"' % cmd_name] + if guess: + msg.append('maybe you meant "%s"' % guess) + + raise CommandError(' - '.join(msg)) + + # all the args without the subcommand + cmd_args = args[:] + cmd_args.remove(cmd_name) + + return cmd_name, cmd_args diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/parser.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/parser.py new file mode 100644 index 0000000..e1eaac4 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/parser.py @@ -0,0 +1,261 @@ +"""Base option parser setup""" +from __future__ import absolute_import + +import logging +import optparse +import sys +import textwrap +from distutils.util import strtobool + +from pip._vendor.six import string_types + +from pip._internal.cli.status_codes import UNKNOWN_ERROR +from pip._internal.configuration import Configuration, ConfigurationError +from pip._internal.utils.compat import get_terminal_size + +logger = logging.getLogger(__name__) + + +class PrettyHelpFormatter(optparse.IndentedHelpFormatter): + """A prettier/less verbose help formatter for optparse.""" + + def __init__(self, *args, **kwargs): + # help position must be aligned with __init__.parseopts.description + kwargs['max_help_position'] = 30 + kwargs['indent_increment'] = 1 + kwargs['width'] = get_terminal_size()[0] - 2 + optparse.IndentedHelpFormatter.__init__(self, *args, **kwargs) + + def format_option_strings(self, option): + return self._format_option_strings(option, ' <%s>', ', ') + + def _format_option_strings(self, option, mvarfmt=' <%s>', optsep=', '): + """ + Return a comma-separated list of option strings and metavars. + + :param option: tuple of (short opt, long opt), e.g: ('-f', '--format') + :param mvarfmt: metavar format string - evaluated as mvarfmt % metavar + :param optsep: separator + """ + opts = [] + + if option._short_opts: + opts.append(option._short_opts[0]) + if option._long_opts: + opts.append(option._long_opts[0]) + if len(opts) > 1: + opts.insert(1, optsep) + + if option.takes_value(): + metavar = option.metavar or option.dest.lower() + opts.append(mvarfmt % metavar.lower()) + + return ''.join(opts) + + def format_heading(self, heading): + if heading == 'Options': + return '' + return heading + ':\n' + + def format_usage(self, usage): + """ + Ensure there is only one newline between usage and the first heading + if there is no description. + """ + msg = '\nUsage: %s\n' % self.indent_lines(textwrap.dedent(usage), " ") + return msg + + def format_description(self, description): + # leave full control over description to us + if description: + if hasattr(self.parser, 'main'): + label = 'Commands' + else: + label = 'Description' + # some doc strings have initial newlines, some don't + description = description.lstrip('\n') + # some doc strings have final newlines and spaces, some don't + description = description.rstrip() + # dedent, then reindent + description = self.indent_lines(textwrap.dedent(description), " ") + description = '%s:\n%s\n' % (label, description) + return description + else: + return '' + + def format_epilog(self, epilog): + # leave full control over epilog to us + if epilog: + return epilog + else: + return '' + + def indent_lines(self, text, indent): + new_lines = [indent + line for line in text.split('\n')] + return "\n".join(new_lines) + + +class UpdatingDefaultsHelpFormatter(PrettyHelpFormatter): + """Custom help formatter for use in ConfigOptionParser. + + This is updates the defaults before expanding them, allowing + them to show up correctly in the help listing. + """ + + def expand_default(self, option): + if self.parser is not None: + self.parser._update_defaults(self.parser.defaults) + return optparse.IndentedHelpFormatter.expand_default(self, option) + + +class CustomOptionParser(optparse.OptionParser): + + def insert_option_group(self, idx, *args, **kwargs): + """Insert an OptionGroup at a given position.""" + group = self.add_option_group(*args, **kwargs) + + self.option_groups.pop() + self.option_groups.insert(idx, group) + + return group + + @property + def option_list_all(self): + """Get a list of all options, including those in option groups.""" + res = self.option_list[:] + for i in self.option_groups: + res.extend(i.option_list) + + return res + + +class ConfigOptionParser(CustomOptionParser): + """Custom option parser which updates its defaults by checking the + configuration files and environmental variables""" + + def __init__(self, *args, **kwargs): + self.name = kwargs.pop('name') + + isolated = kwargs.pop("isolated", False) + self.config = Configuration(isolated) + + assert self.name + optparse.OptionParser.__init__(self, *args, **kwargs) + + def check_default(self, option, key, val): + try: + return option.check_value(key, val) + except optparse.OptionValueError as exc: + print("An error occurred during configuration: %s" % exc) + sys.exit(3) + + def _get_ordered_configuration_items(self): + # Configuration gives keys in an unordered manner. Order them. + override_order = ["global", self.name, ":env:"] + + # Pool the options into different groups + section_items = {name: [] for name in override_order} + for section_key, val in self.config.items(): + # ignore empty values + if not val: + logger.debug( + "Ignoring configuration key '%s' as it's value is empty.", + section_key + ) + continue + + section, key = section_key.split(".", 1) + if section in override_order: + section_items[section].append((key, val)) + + # Yield each group in their override order + for section in override_order: + for key, val in section_items[section]: + yield key, val + + def _update_defaults(self, defaults): + """Updates the given defaults with values from the config files and + the environ. Does a little special handling for certain types of + options (lists).""" + + # Accumulate complex default state. + self.values = optparse.Values(self.defaults) + late_eval = set() + # Then set the options with those values + for key, val in self._get_ordered_configuration_items(): + # '--' because configuration supports only long names + option = self.get_option('--' + key) + + # Ignore options not present in this parser. E.g. non-globals put + # in [global] by users that want them to apply to all applicable + # commands. + if option is None: + continue + + if option.action in ('store_true', 'store_false', 'count'): + try: + val = strtobool(val) + except ValueError: + error_msg = invalid_config_error_message( + option.action, key, val + ) + self.error(error_msg) + + elif option.action == 'append': + val = val.split() + val = [self.check_default(option, key, v) for v in val] + elif option.action == 'callback': + late_eval.add(option.dest) + opt_str = option.get_opt_string() + val = option.convert_value(opt_str, val) + # From take_action + args = option.callback_args or () + kwargs = option.callback_kwargs or {} + option.callback(option, opt_str, val, self, *args, **kwargs) + else: + val = self.check_default(option, key, val) + + defaults[option.dest] = val + + for key in late_eval: + defaults[key] = getattr(self.values, key) + self.values = None + return defaults + + def get_default_values(self): + """Overriding to make updating the defaults after instantiation of + the option parser possible, _update_defaults() does the dirty work.""" + if not self.process_default_values: + # Old, pre-Optik 1.5 behaviour. + return optparse.Values(self.defaults) + + # Load the configuration, or error out in case of an error + try: + self.config.load() + except ConfigurationError as err: + self.exit(UNKNOWN_ERROR, str(err)) + + defaults = self._update_defaults(self.defaults.copy()) # ours + for option in self._get_all_options(): + default = defaults.get(option.dest) + if isinstance(default, string_types): + opt_str = option.get_opt_string() + defaults[option.dest] = option.check_value(opt_str, default) + return optparse.Values(defaults) + + def error(self, msg): + self.print_usage(sys.stderr) + self.exit(UNKNOWN_ERROR, "%s\n" % msg) + + +def invalid_config_error_message(action, key, val): + """Returns a better error message when invalid configuration option + is provided.""" + if action in ('store_true', 'store_false'): + return ("{0} is not a valid value for {1} option, " + "please specify a boolean value like yes/no, " + "true/false or 1/0 instead.").format(val, key) + + return ("{0} is not a valid value for {1} option, " + "please specify a numerical value like 1/0 " + "instead.").format(val, key) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/status_codes.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/status_codes.py new file mode 100644 index 0000000..275360a --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/cli/status_codes.py @@ -0,0 +1,8 @@ +from __future__ import absolute_import + +SUCCESS = 0 +ERROR = 1 +UNKNOWN_ERROR = 2 +VIRTUALENV_NOT_FOUND = 3 +PREVIOUS_BUILD_DIR_ERROR = 4 +NO_MATCHES_FOUND = 23 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__init__.py new file mode 100644 index 0000000..9e0ab86 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__init__.py @@ -0,0 +1,81 @@ +""" +Package containing all pip commands +""" +from __future__ import absolute_import + +from pip._internal.commands.completion import CompletionCommand +from pip._internal.commands.configuration import ConfigurationCommand +from pip._internal.commands.debug import DebugCommand +from pip._internal.commands.download import DownloadCommand +from pip._internal.commands.freeze import FreezeCommand +from pip._internal.commands.hash import HashCommand +from pip._internal.commands.help import HelpCommand +from pip._internal.commands.list import ListCommand +from pip._internal.commands.check import CheckCommand +from pip._internal.commands.search import SearchCommand +from pip._internal.commands.show import ShowCommand +from pip._internal.commands.install import InstallCommand +from pip._internal.commands.uninstall import UninstallCommand +from pip._internal.commands.wheel import WheelCommand + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List, Type + from pip._internal.cli.base_command import Command + +commands_order = [ + InstallCommand, + DownloadCommand, + UninstallCommand, + FreezeCommand, + ListCommand, + ShowCommand, + CheckCommand, + ConfigurationCommand, + SearchCommand, + WheelCommand, + HashCommand, + CompletionCommand, + DebugCommand, + HelpCommand, +] # type: List[Type[Command]] + +commands_dict = {c.name: c for c in commands_order} + + +def get_summaries(ordered=True): + """Yields sorted (command name, command summary) tuples.""" + + if ordered: + cmditems = _sort_commands(commands_dict, commands_order) + else: + cmditems = commands_dict.items() + + for name, command_class in cmditems: + yield (name, command_class.summary) + + +def get_similar_commands(name): + """Command name auto-correct.""" + from difflib import get_close_matches + + name = name.lower() + + close_commands = get_close_matches(name, commands_dict.keys()) + + if close_commands: + return close_commands[0] + else: + return False + + +def _sort_commands(cmddict, order): + def keyfn(key): + try: + return order.index(key[1]) + except ValueError: + # unordered items should come last + return 0xff + + return sorted(cmddict.items(), key=keyfn) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1a65f88d9d247f2d6348d11ad7627311f34c9945 GIT binary patch literal 2604 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e0b1d6aeb19a4799f1913ebc5644859fbd09a2d7 GIT binary patch literal 7189 zcmbVRO^_SMb)N1S3sJt215a zb&fX=&5l*K7=1ItLdUM#onpPH>sIJ=O7&8wTrYR#>T|lS5LP<#^?6;k!-dXbeNmT- z;Zo;R{gf^{;d1A6{WLRt<7mZy=9tybylse*D1TyzvTq%l^=Ad!G^%r-V{OJpm8s&b zxYKDwqRLfa{ocKI@2TSEgIl-OH#e)Mn!goCt)ShLjWmcO^=#Wuz2P)Hyf!h=nIYQ%D9d4S=o!CAZmNPNchs*3uM}BgnqQwq*aao z%t0mTqu?8KemFZ;HwCX-!mJmBRkwd+w3sLe`xB>L6h+~DV$_{{&-Id+6BX3UVqPrZ zJtr2$65bVYN-X0&FHVaUycfhX;tbx4;#qMP?UF2@M?YoU; z8tnO#G~COvbXzj+=pJV z?dOB`8etD>NRqf25C`3lf^^%B8XbSsKcW7cgZ}j8n|jdbdoR*G9?(lK{_7Y!S!FzC=bh4|fNswY;(s#R9oiDDq4R;_wBO;KbK*mwWkJ730%Xgo+ zpe)>=<=*NhGHb{cB9+%BaqYM z(^$V~`T2Qo?T^R_zt!l4X-zjMJ7-SzU!(6ANk`m=H)sv3ahJ&7eB_dB{GKikS66d} zx;OIoYPXSYV=UE9q--{Q@P3lHv%3)|iPP>Rr)PK8{6C?ZUHWQj(qv-*K>A-qT0}~I zhAcHw);A9M4)3!*|1l%f>l>cgH+HO@f?$FR6L@Ng!lwm>FS^wxR3Jo{XazFp*7=Fn z1t0|VU7BbGTIkl(qgMNEA)eXDoFNaCo%28y5~!G;eYmc5&4pw@D(FSu zN5WQfA0&R_e(%oagSYOw(DC)#ckaJ?&m9-!y@m`LTR>Zq+bB+52+Cd{d{L`f$`XE( zDw{9^I9(hFnXY$>ZD+ljJwKce?%OqD#Z83N-x?=$0z z{k5(P_JG7|kb|{W9KvuWYuBEvwY_V5vXez$Z|z*&-hPs0UU=<|t!;S~zjm~Cf2|vI zS21l0&|1BE^^Lv#y;pkFs1tUP`Z8*SYeR#C!kEdgb@%0S*zg)sau=DwmbuMs#`A~s zFYLKdjqzXE&R44GaoL~T8lP)mQES7aZ4Qk;O-mp^Zr3fO)uRM302CNI8UO_Q z$HIZx=kldK7yO*jH+PHjowRUd3lr*U9XV;KZyvH^{V*dfZyI^e11mcNDsuo8K*z2v z>`(bY;e8{zZW(E1w=9pCabPne`x;T}+dK0_{}}L-mTlvG?9vi*Smmj0THLWX+PPsrEt^YhiJdo5H~3S> zETeRuEmIrM&d$^dOfaDkv|`$nR*0XY0AVxaRpczWn({+KUKXs+JeI;&hD{`kXfh*m zQcKu}?1wD(l+(hFjWNX*N6A5{q)TO@)8Z}jwsFXyQfBg#K2NsE&ZTp?Z=F^S4U8$D zGpNrYlYd7wdq(H$~+fjkUzQo}29D!p8mV(tWsFtE&X#Zhq`= zr4o0`hck5&KGfv1*kES8a;^3%w6v6OkX8V3yEp%d=-S9^!?vvd%if&H{3*Gv-O!;%aubCip@~%^CPCZ+ z%9PF{!mgHI8he)i*Q`Dzgy+%!x{d=e*@*Tf@kyBoQ~`_x6_T`Fu2O4-mNu~K$$RJGCink?BEVB|HiRw4)kCSr#{(*uX3gnC_xB8tJWw%v%?6H$|c?zau{rhpJAChbN^!& z=C}4fLP)Y+lY0lM!BN3Wvo-;jnoVio=+9*{mvO#9{Ase#Vqc5=oIx0G+BZxCY#;fb}8 zEmQoKZ^(V9m;C5+f(l6+gG`TYitMrOp-y{AW6z(w_L;fA*FfYKNQ3>Yumzs|*-Va2 z8vBV|5`K)BM&dTP%WV7sVb@vzyDy@4Da8wZd-VeC5c0&F%c>JM4AOqxh~*yiMH!a;lu z4x+VV!zJB;gNPV6TOkX7RP4ikAL~)?8?TcqTKGX>=!$CnH8--0x8hzXbo4m#lw4e0 z$QaQD0V<(bEqiGYt>T^vpPGJ>xUdSNTOcYU#6y4xpRuG)jajGMvC9=>iNsjLVj63Y zPlGMO&Jk5rZf^U{T@Tl0p<2F$+!ycV6Y5Ju`6kXum8GBdWJD8I?P>g2pdN)5DXIJx z%F{~sb+r9ElD6FjEAukkF@n=&Jmij9PXVm6#dOkJZIWmXeW!(SOM3eTFAcp4gz%q&aiEr#x8F4dbr@C ztEfR(=C%>=Q(Xq_ZQQ~1I$P+COEMsCkNluybUT!N_igm;kxllS#IqTluYjL}uOA=O z+{>`Boo?t~cVGPYU=X~6w=Y&tjPVB4a$xEl{v{wkW?&{f9SSqZhHC>y<~Um*#5iJvdr+5` zpe`KB@+Lza=FZ%)2F4HZRth6WjLGA*fsxCuKZxj_g?K^8H+h*+bKeX725uMNgCg<( zPw4uP+{>+AyQa?z@sZ;{X~HLM#o6MWL4fUQiLOC{^RRIp%CHK{~#qx$P5Gx3wRJxF#a3c$}Z2uqZ#nsB+wuJs7y(p;B6G(`U5_8OLB=y z5K)%09lmP=mhcvgL|5=Z+nc%#@hhBrQ^4UzV1aVg+E8|Wou%yjGAny=7Wm|VL1&GN zBiv+3QfT=OGKf=tjhi0`AJhD)Q~7K3{sJkXvCwfiSK5_=wr7`SpUDXQ2BB#6G+pWF z0Mt`ukK)4~{5elmJnu37n;3j4dY*`zXtt;U@pOWFe^pF+_zOkmHzo2dtU-Hx+J%v1 z^(C1`NhU-R9_4nHcqwV=YJPCh)AYm8^Tu@M0(H^e5M4SgBPGuxbC|UR;3`?X^1Ab~ zQ+06ZqMt=)(W&SQs_I!)q_7!(vgpH6Pc7PySreUcVxD?XJF1kR5C{*E>4iv2)k*Mdz-Z8@VLhB%INx U1&jhpRS>GLm=(C@czD_Tf4RPXfdBvi literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/debug.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/debug.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f46787f5b7f82768787a5d3cdb9feeb1257cc54b GIT binary patch literal 3397 zcmZt}O>Y~=b!T?DyQD}-)|aE$b+>67lxR$gBWNUppe z^vo<}(IiknE^=!77bu{YT!J2Z=r5UTPyPcv6e!&HhAUaJy~MnEGjHb2oA)`q-)c21 z`2O>c(>Q2Z*1vIZ@pEACOK4I9U=|~(m64DT#A!-HYI-}gP49#b^mbay+|V^^oYc$w z&^LH3t!Is}VQ@EH%9>%*;9lCwmcwO(`{_!y8m=0=o?gk;!Zm|8()Da3+#nWT6Mu&@ zmeS2^E8NPihF1-}nZA*2huc86=Wp_BrzE`2T5S2L6@G`UuvO@9uq$j0`tN>Xv30ib z)M6XlKe5Ar(S57E`3&x7wTWJd4`h*+ibqK{DumjDxkfKz#YiPZE@9;D7FibO4A8YK ze#j#givd^B=vWPl92e~0-`)Lqe;;=yIpevC(qaIk6|*cEMPn``a6=Bi{p$0tqTOGA zy!&bN#r?g#-|T&Y+xmsbVg;NBZK~~$@?-6MmPiF8_scjfx$IGtxB3uwq3uGGTL6?b zCydPL)S8l0dTPuCm!x|W_sQ&o;K{6QYZqi1aG{+f?-$x#oCv2md7N=w8{;wGSYjR6 z{r6FKB$9Egcy}C&ZofzwT%ddFad!~i8jEa_|FnO&GaNpiOrrGGdj~_Y1K%L;-s_H% z(aj{6Do)dzJ3H@h)QzZANm3*)yWt6YFo_X3AsEl$=mv z{oZ=l`knQK^#^cm&{b`3vM!Hh2fQHV8Q3sJ`+uO9FHdMoT!BN|zF3A%tN_s7FqW}W zLfgPVpgqhQ;UR_>Xj3z**Dv#mQ1eFN3$TIAt{Oc6BlO1$l3WL(#4|10APwRYpE}eh z;u_5K2+mg@D(755|AGM{aD7n537OF;os&~*WYotg^yp7hPkhV#LwibC{V(L=DKD9&vG)uUmO!7Fw1OWkV$ZnrWD^2& z1ZFx&c>s|karVjV87kx6-N`RHolfJAcM~C1@C3+Fnq-NZnUw)5Iqw9Y$5IA2Z$fw; z6cU&eh7f@Bb{;_N)z7!J8=?kmwT}^vXX$1YvV&yIbFqp$T1v@WF*?HJCh3(ktOD${6Jmi>P6SlgK#=q4^&T!u4k!{}ufsv8%=Wo;U}Lc%O41_TNLg(6^w z;5ebnYN7YF)hEnl-cu+8%x85-!S$~##|j$|WewfDgAre))X5JT0ep87IZET>z$AkJ z^Al!62)~XY>zW}0cKPZ_gkY=C!F^1%NyE7=aPw50f?Mo{a~JDpq0Z~g*$+|6I+KnN?u)sVv$##Nl8@|^(aJ>0A%7CCS=g-D=Bh;0DctEAG6 z7ZT~USEbRLF!!n?_?$pV^v3H%(f*kjraqaBBJjo1wgtwT_&$Pn5#W2{h3{%xl=%ag zk^un7T7*7#+$O=_GW;l^miyeXo5ZC)ovdE+Y1rCc!r;TY3c=TiqO4$Lig+`M9+h!g zQM@Q(MGt}oYq_qKG9Ga4$r9dq;uu13kQahSf-9a$ZZ@S6Bg(d(BN91S^71=dULR?C)PAeuPiLqskzCH#A_ zbRE3!GxM$$zrr=9`r?!8g5RMrF1VR76VEHl}d-Hh?C)sNhEz4tEa0bgQIE M8@6BbTmD=B2fUu0F#rGn literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/download.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/download.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..beaa959464cc6c341a9ee568e3c9addcf4e0cc7c GIT binary patch literal 4751 zcmbVQOOGVQ5w2HvRln!4kJ%S4W0qww)3YE0Uc4G%FT!A>6=v73La0>k&lRs_#&!* z-s`nB`2F(_$HCt=H0`fQoc>urybgu`2`ZuyJ=PN4({*ecvEdo&ZF(lW&DcsBUPFyp zaWkn_GUP)HHRn>0CYstE|uG*dW zTyow!pIq=RD7qV8Og6j?U8Ba)C3^W-_pba{BR$f8sF6Ok4^8hXG45%bgTKSswM|_P zf?b})g`j?v?7m;yz z!(p}hlPhhprNt`Q{-1?z?}hy2D&UfK-2c7l?Re?p(8Rxyy}mEJ`|T6v`PvgEHw-~# zC%*=?5Xc5l_+1zgn$Sz_(3l#fUK+mzz$&$=d0>|2ktG^O&13Bt`zp#_qMRkFwM4a- zsLm4AU7~tRRDX#YEKw^<)anwownVKjQRkMZ^9yQf5uF&sBo_L%xG=qlzWvD2HIRFw zG*ND7T@sDyWzfl$W8=WW_t90-Dy?HfX{w@3q=*J+(7ro2w#dA>wM8fw^VRAdr2zux z7I@?Q;uBpJG|BG5$Q6>A$b0RH+XRdNAGr;KJHt&&TDXg}6DoqefJvLsQBcG}S`!-Q z3@?83nrwgzQ^xv0Nyqo2G!niq9l&!RoPo=BKvWA($Pf=@Cj^ieEP%bZ?4EKfE?c`r z6ccqqJI#DTb1wViINJ?kTnwXwY{9@Th|FfPlcn)&LG*G)N0co{le18o&?g<35XLk} zWxw9cp9FkDVRQ6xMmhI)LA*6wSnVG{Kv61{?Scc=)BNQZUzI%=KSdfDm(8$Xpe%U_ zWn2nOC&yh?L905vKW15x%Z`GInrK3h;*`ntD211(=T(E74QX*2kE8`Lk4xjhK7-^y zlkI8&RPX1yZ22Hw07CemYhQ}(oJD(qpxba`+oLQd0P5SfKH47pxAs^vPhT2MZ%!s3 z&F6l6>y_OJy9vK>x_y5eAQ>=>iy)4-Zr*%lZ?^Yhft{+rwF=78Al?qEaLl(C_B70A z>>`}%yHNO>P-*&_(KPz{H$H}?8=87_10JCM)pXj>3(tS7Mqi(AEUdGRd&7log^Q?) zd-b5KLb(Hlmtc}aFLhrVYf$ULI5JCJd73o^v?=weeT?I_aG>2f#CA)xt2TPvQ3v@y z)jxUuz!cq5Kh%|1_5i)i(jvwq^PmCT{XB+x(A5rb%@y{USjG3D&OZ}tN9zQ3ovu_~ z3p=ccbBEd|e?G9qd7M=?5fdJnpZxK_5f`B6B56L-4_dJMM%gM6DI2hxHoZi&V@Tb^ z<TX4>g*?Q`e#VL?BdyBZvRuAdu8kB`mv^KztmpV zex|*r{pxF5C1xvwyZ1LuX)j#W=HOf4w6eG48}q;1pFkL1WKHgk>->fb8AAkV0H$mZ zsUHtU+)Xp#Vme0LT?p|o6}(Pyfj2T26Pz%B>;e*p{RyQpcfq|O(9;x_;lXYUf!KY+tx z*A4D&z2%PLU_4|P{UCE}5*kxMrS$;ZbyH{8vD;=>;U#TACxkh+g4CKix4-ZxHSjDB z49?u^*?dN8JOFSSL+T4jFwH3}nud_@$w5BzA??Ns26z}{ z@Mf{bzxwi8 zT)pfq?$S>(LZuC2JWcPq)5mnl-25hxQj%8-p7@)!X=@2|deC zH45YZX!hH<=2wo{)VrpmKWog_zs6cO+n8yg{X?eJ_EGUgjP0)Pe^>-@J!1Qy@X+_w zg~~?3;TsWf>KK@Iil1R|ty4BY5nRrNBq(3wUp7{*cMFHb$uKimxfo$4%uq0@R-pJaOc zZ$afEXINr74#F9Fp!#P3jaMRspE^PYaX{sGe7Jy2H2Je9MPNank=K@|L;n!U0*jT0 z$urVGXu_0pZY(cUF+oHM6#^(gkY~iHcwmKG`8YbVY{8!(?i*PCDll|zS2nVPNjpc-=o*gh7+rn&Q6_Kx7qMxFj{pDw literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f99ceb4c49fe35ca8d246c0f04c21dd7c13ee45c GIT binary patch literal 3044 zcmb7GOONBm5#~#j#F6H?p7DDL#EV41NE#clku{9Kz^=UrY^;OW8wU&wg2Qe}oM}F` zyEzX+bD9NwTK|F^W{$q)cjPDVnp6IO59uY1M@o#8g z49t2XIuto8B@L6b$hmwBnfL9CQuZK@=T!DevqeWlo7D~&vTwe@`FflaKyA$HIrPT-PO(Ei?-n8YRRXRrY~#a0INxg2;~} zL5J9lW+IWv3H1dGiNTx`%13%FZ{r-*uI7FJUcvLJ|F?xzzpLK=zcm_IFE;6!{CGST z=VAnFQ_lH1{t=rC%c+mDVi&Xl68}Ua4QbAeOY6v*n{(?2Aa8CQ*+&jBiA8MUObyaf z)_mT+8G%iKB{c#(-5LR^$OhRYTV$K;JO@e_d)*|#U5{ycQE?yjjVg+k-KW_+EPe|Z~e!WHRM%)I9%~q-COC1 z+Kq~WW~6o|38U4;6G44Bqm5sb>r`h7hrQ}`%=UqCKLG?{;9X+@K+XIq%_xs#l1=?w zqiE!RGfRZuxDrUn{6p%O0^UzcCX)g?$t0y>G-%Zhp+Z8bSOrtvCUg>EPTfwaj7}n6 zJ2T1(oN7|_hQmpcks(X6W5kQ%!-lt?{Q1l36Eq5&z8X-vETOsYpU#qa=AR~vDMcbe zpoz?zV>b%p2drujhb)gHR=1juCuGiPD0xXgub%vI(g6D;;j)Yv%}%gEB>h<={3**1 zBj!hOOoiC@N$zL4To_|9$j((Xyb@cZfy1`}LB6A!JF3}5Q@O(-%!R|Nw%Y$HW9Q4= zmZyR;%iZ8KHE)POqob-d93p^WA06Z&_-g-QqmVdG3Uz9@d}W&zJACZl6P2~^59}4S zv_{**Aw7#(N$8N0L`H{<)(AE&373-U-e--(UrLt$@h3b_m+0Us90zN4OOypd6h*

H zN2MGt7t6va&&y(9*N&iUQacex>a~tfe>CfE7{)9TA`E{tUhr|jlaol&F(5adtihlcR&#?5wIncK@Tp89%@?&Bou1k;a#P9UdHfbaH<3eyN0-a3o22 z7O}Ak7zB?PH(nVP=lm{C^cF}EG={ltxu#`U=FR)U?fyd2xh478ZKJ<@e|FtX^JTyD zU+X`vd(#JB?cU1!qou{;WnEEvbU;1O1CaPT8kHR{HCPG%s3^ zw8RH<&%{Jy0LC4%z^1g0|+)T&>+E=5z1Dt=^M&CdSm6iWS_12pz9>&c@ zh5t_J@Sz&%FA~S`sg4#0DVFkmHLRPVnq%`a`vQzmBEwuadu9jN^DNJ@Oy}0C@ag>I z_ASiXwW_V#7{oqE1PJ~tN-2Wh3)Rs|rubeMK1HHkjI_g$9nA~rKoqH#|B$U zt4S$K)Pj&(YR#u;>K%mn=qAKR8WS2H!PYAyENKAo?l0t{LtK;K1f3mtOKtnB+mn>1 znHas|E)B@Lw`b-^rl`WWl8zb|HjsGp_N-DS*baXL)Ee|^z^Wv?VxE_-?tIcX$hWJ$KSZ)(o3j zD{R$kH*IH~u!9k|ju!ahF%FmRAm%auF=9S<53TSG)?m%YC_KZ+7V5VC0v}Kp>&0kC z7HOq8O|r5OY6JGXTSb;dIfJQldvo*NW|!#BS2usSxB2z%HDR2Pa$W3 zYe8RxF28|6A%&;tknEBvo|2~^o+;Y3c5Q|kVU_|Q6#&WHBTqTUco`({t5@6jM-Ap1 z+hbw`18_DrCS)y|wAR+5bXW*LA=8alQ%9;o@X190YzFPiBLfE@cQq(-Zem!K6Y^2e zb+pa6RN9M2MG|wV-6%E~XpiwhRHX_K;%O;Ne88n6tC9=h!%F*3-0IBL6Z15s^pw+Y!KpBw z*D|h?bOBaAwmloXhaYLT>$8}^{z>~Ei3+lq;Y0G1RUDkhu zq>Y=njhC@7``xpKpFss)0zbmwA&jl|jDV7SC<3#(0O{0wnM%DlO?o?#!X(4% zjGz{)N`e{Gpjw@J<=-z=DuG&U!UhAwKwVYz`PW%xiHv8UG=^M#TMJwmVT$+6U}{z! j)2aAhiP*n36XA7J=xQami4Pj~0gpCb!fn#DmM;DSJxMRs literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/help.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/help.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8d2dcf3c53709e4dcb22a042e5a769bb867ecd3f GIT binary patch literal 1265 zcmZuwPjA~c6esmRnv)h-;3mK@2n7l(hgj(_6bMih#oS`ur5Cr@rVBxvw5&v;R8n$d zLB1?K>|-Ry-u8KT?Wtd2hn@B)$AdTY5%2Nwk$n8UKYY8tA0nW?{=B6>ItYC-i(LX6 zdJe2!fMAH>92Gdh*yvVn6?S6xx}7_Po4CF1c`W~ICGH+^5vZ5+w4JLnF76lc|sFSzj@yp2s)WMzgrIe+dncKT$!Qwfv`VIs~ z31%p<7*1?vB@VL_mpO^Y+{9-d^FJU!5dexk{naa;S9hM<;bc+1j}~Bw=B12g8yHGE z#?%hOsHaDjEYs-e-R`sY!Iy81-pp*kvZXyx0^l*Q`U3>RkUB`?+AgfMgHb!^0Przd zyT2fDTj%tafx7orHQ=Wz~peqUKW2e6)2X zO+KVaj1GSmj9>Mom8RLWN2`hpCS9{|F3L=3ucA_Msl!TwD`IK_1#}e8=h`o;Ix7W~ zipo^&I1Xk7BZ3xOyJ^Ff(srRz?cYK8h~xu!;O{C1pG#Wvcu8eEFLTDFiqEg&l$G;L3Q@iX*u78iEc;9}^)uB%~-= zlXK7qguH8LZlZ;iPY5e#pg5cG8%0yDebvC(f@6%U pO)nh%*Au^*@lCb+?&uNh;57x62DA>IZc_8iw6`+w2aseK_CF;WRwe)d literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/install.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/install.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..db1b444c2ee4276c91bc4351958dfa379c248890 GIT binary patch literal 13092 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/show.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/show.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..990cb455263eaef01bc14b0f6d4368beec54d31d GIT binary patch literal 5877 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] list + %prog [] [--editor ] edit + + %prog [] get name + %prog [] set name value + %prog [] unset name + """ + + summary = "Manage local and global configuration." + + def __init__(self, *args, **kwargs): + super(ConfigurationCommand, self).__init__(*args, **kwargs) + + self.configuration = None + + self.cmd_opts.add_option( + '--editor', + dest='editor', + action='store', + default=None, + help=( + 'Editor to use to edit the file. Uses VISUAL or EDITOR ' + 'environment variables if not provided.' + ) + ) + + self.cmd_opts.add_option( + '--global', + dest='global_file', + action='store_true', + default=False, + help='Use the system-wide configuration file only' + ) + + self.cmd_opts.add_option( + '--user', + dest='user_file', + action='store_true', + default=False, + help='Use the user configuration file only' + ) + + self.cmd_opts.add_option( + '--site', + dest='site_file', + action='store_true', + default=False, + help='Use the current environment configuration file only' + ) + + self.cmd_opts.add_option( + '--venv', + dest='venv_file', + action='store_true', + default=False, + help=( + '[Deprecated] Use the current environment configuration ' + 'file in a virtual environment only' + ) + ) + + self.parser.insert_option_group(0, self.cmd_opts) + + def run(self, options, args): + handlers = { + "list": self.list_values, + "edit": self.open_in_editor, + "get": self.get_name, + "set": self.set_name_value, + "unset": self.unset_name + } + + # Determine action + if not args or args[0] not in handlers: + logger.error("Need an action ({}) to perform.".format( + ", ".join(sorted(handlers))) + ) + return ERROR + + action = args[0] + + # Determine which configuration files are to be loaded + # Depends on whether the command is modifying. + try: + load_only = self._determine_file( + options, need_value=(action in ["get", "set", "unset", "edit"]) + ) + except PipError as e: + logger.error(e.args[0]) + return ERROR + + # Load a new configuration + self.configuration = Configuration( + isolated=options.isolated_mode, load_only=load_only + ) + self.configuration.load() + + # Error handling happens here, not in the action-handlers. + try: + handlers[action](options, args[1:]) + except PipError as e: + logger.error(e.args[0]) + return ERROR + + return SUCCESS + + def _determine_file(self, options, need_value): + # Convert legacy venv_file option to site_file or error + if options.venv_file and not options.site_file: + if running_under_virtualenv(): + options.site_file = True + deprecated( + "The --venv option has been deprecated.", + replacement="--site", + gone_in="19.3", + ) + else: + raise PipError( + "Legacy --venv option requires a virtual environment. " + "Use --site instead." + ) + + file_options = [key for key, value in ( + (kinds.USER, options.user_file), + (kinds.GLOBAL, options.global_file), + (kinds.SITE, options.site_file), + ) if value] + + if not file_options: + if not need_value: + return None + # Default to user, unless there's a site file. + elif any( + os.path.exists(site_config_file) + for site_config_file in get_configuration_files()[kinds.SITE] + ): + return kinds.SITE + else: + return kinds.USER + elif len(file_options) == 1: + return file_options[0] + + raise PipError( + "Need exactly one file to operate upon " + "(--user, --site, --global) to perform." + ) + + def list_values(self, options, args): + self._get_n_args(args, "list", n=0) + + for key, value in sorted(self.configuration.items()): + logger.info("%s=%r", key, value) + + def get_name(self, options, args): + key = self._get_n_args(args, "get [name]", n=1) + value = self.configuration.get_value(key) + + logger.info("%s", value) + + def set_name_value(self, options, args): + key, value = self._get_n_args(args, "set [name] [value]", n=2) + self.configuration.set_value(key, value) + + self._save_configuration() + + def unset_name(self, options, args): + key = self._get_n_args(args, "unset [name]", n=1) + self.configuration.unset_value(key) + + self._save_configuration() + + def open_in_editor(self, options, args): + editor = self._determine_editor(options) + + fname = self.configuration.get_file_to_edit() + if fname is None: + raise PipError("Could not determine appropriate file.") + + try: + subprocess.check_call([editor, fname]) + except subprocess.CalledProcessError as e: + raise PipError( + "Editor Subprocess exited with exit code {}" + .format(e.returncode) + ) + + def _get_n_args(self, args, example, n): + """Helper to make sure the command got the right number of arguments + """ + if len(args) != n: + msg = ( + 'Got unexpected number of arguments, expected {}. ' + '(example: "{} config {}")' + ).format(n, get_prog(), example) + raise PipError(msg) + + if n == 1: + return args[0] + else: + return args + + def _save_configuration(self): + # We successfully ran a modifying command. Need to save the + # configuration. + try: + self.configuration.save() + except Exception: + logger.error( + "Unable to save configuration. Please report this as a bug.", + exc_info=1 + ) + raise PipError("Internal Error.") + + def _determine_editor(self, options): + if options.editor is not None: + return options.editor + elif "VISUAL" in os.environ: + return os.environ["VISUAL"] + elif "EDITOR" in os.environ: + return os.environ["EDITOR"] + else: + raise PipError("Could not determine editor to use.") diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/debug.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/debug.py new file mode 100644 index 0000000..eb4f8c4 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/debug.py @@ -0,0 +1,114 @@ +from __future__ import absolute_import + +import locale +import logging +import sys + +from pip._internal.cli import cmdoptions +from pip._internal.cli.base_command import Command +from pip._internal.cli.cmdoptions import make_target_python +from pip._internal.cli.status_codes import SUCCESS +from pip._internal.utils.logging import indent_log +from pip._internal.utils.misc import get_pip_version +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.wheel import format_tag + +if MYPY_CHECK_RUNNING: + from typing import Any, List + from optparse import Values + +logger = logging.getLogger(__name__) + + +def show_value(name, value): + # type: (str, str) -> None + logger.info('{}: {}'.format(name, value)) + + +def show_sys_implementation(): + # type: () -> None + logger.info('sys.implementation:') + if hasattr(sys, 'implementation'): + implementation = sys.implementation # type: ignore + implementation_name = implementation.name + else: + implementation_name = '' + + with indent_log(): + show_value('name', implementation_name) + + +def show_tags(options): + # type: (Values) -> None + tag_limit = 10 + + target_python = make_target_python(options) + tags = target_python.get_tags() + + # Display the target options that were explicitly provided. + formatted_target = target_python.format_given() + suffix = '' + if formatted_target: + suffix = ' (target: {})'.format(formatted_target) + + msg = 'Compatible tags: {}{}'.format(len(tags), suffix) + logger.info(msg) + + if options.verbose < 1 and len(tags) > tag_limit: + tags_limited = True + tags = tags[:tag_limit] + else: + tags_limited = False + + with indent_log(): + for tag in tags: + logger.info(format_tag(tag)) + + if tags_limited: + msg = ( + '...\n' + '[First {tag_limit} tags shown. Pass --verbose to show all.]' + ).format(tag_limit=tag_limit) + logger.info(msg) + + +class DebugCommand(Command): + """ + Display debug information. + """ + + name = 'debug' + usage = """ + %prog """ + summary = 'Show information useful for debugging.' + ignore_require_venv = True + + def __init__(self, *args, **kw): + super(DebugCommand, self).__init__(*args, **kw) + + cmd_opts = self.cmd_opts + cmdoptions.add_target_python_options(cmd_opts) + self.parser.insert_option_group(0, cmd_opts) + + def run(self, options, args): + # type: (Values, List[Any]) -> int + logger.warning( + "This command is only meant for debugging. " + "Do not use this with automation for parsing and getting these " + "details, since the output and options of this command may " + "change without notice." + ) + show_value('pip version', get_pip_version()) + show_value('sys.version', sys.version) + show_value('sys.executable', sys.executable) + show_value('sys.getdefaultencoding', sys.getdefaultencoding()) + show_value('sys.getfilesystemencoding', sys.getfilesystemencoding()) + show_value( + 'locale.getpreferredencoding', locale.getpreferredencoding(), + ) + show_value('sys.platform', sys.platform) + show_sys_implementation() + + show_tags(options) + + return SUCCESS diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/download.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/download.py new file mode 100644 index 0000000..5642b56 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/download.py @@ -0,0 +1,168 @@ +from __future__ import absolute_import + +import logging +import os + +from pip._internal.cli import cmdoptions +from pip._internal.cli.base_command import RequirementCommand +from pip._internal.cli.cmdoptions import make_target_python +from pip._internal.legacy_resolve import Resolver +from pip._internal.operations.prepare import RequirementPreparer +from pip._internal.req import RequirementSet +from pip._internal.req.req_tracker import RequirementTracker +from pip._internal.utils.filesystem import check_path_owner +from pip._internal.utils.misc import ensure_dir, normalize_path +from pip._internal.utils.temp_dir import TempDirectory + +logger = logging.getLogger(__name__) + + +class DownloadCommand(RequirementCommand): + """ + Download packages from: + + - PyPI (and other indexes) using requirement specifiers. + - VCS project urls. + - Local project directories. + - Local or remote source archives. + + pip also supports downloading from "requirements files", which provide + an easy way to specify a whole environment to be downloaded. + """ + name = 'download' + + usage = """ + %prog [options] [package-index-options] ... + %prog [options] -r [package-index-options] ... + %prog [options] ... + %prog [options] ... + %prog [options] ...""" + + summary = 'Download packages.' + + def __init__(self, *args, **kw): + super(DownloadCommand, self).__init__(*args, **kw) + + cmd_opts = self.cmd_opts + + cmd_opts.add_option(cmdoptions.constraints()) + cmd_opts.add_option(cmdoptions.requirements()) + cmd_opts.add_option(cmdoptions.build_dir()) + cmd_opts.add_option(cmdoptions.no_deps()) + cmd_opts.add_option(cmdoptions.global_options()) + cmd_opts.add_option(cmdoptions.no_binary()) + cmd_opts.add_option(cmdoptions.only_binary()) + cmd_opts.add_option(cmdoptions.prefer_binary()) + cmd_opts.add_option(cmdoptions.src()) + cmd_opts.add_option(cmdoptions.pre()) + cmd_opts.add_option(cmdoptions.no_clean()) + cmd_opts.add_option(cmdoptions.require_hashes()) + cmd_opts.add_option(cmdoptions.progress_bar()) + cmd_opts.add_option(cmdoptions.no_build_isolation()) + cmd_opts.add_option(cmdoptions.use_pep517()) + cmd_opts.add_option(cmdoptions.no_use_pep517()) + + cmd_opts.add_option( + '-d', '--dest', '--destination-dir', '--destination-directory', + dest='download_dir', + metavar='dir', + default=os.curdir, + help=("Download packages into

."), + ) + + cmdoptions.add_target_python_options(cmd_opts) + + index_opts = cmdoptions.make_option_group( + cmdoptions.index_group, + self.parser, + ) + + self.parser.insert_option_group(0, index_opts) + self.parser.insert_option_group(0, cmd_opts) + + def run(self, options, args): + options.ignore_installed = True + # editable doesn't really make sense for `pip download`, but the bowels + # of the RequirementSet code require that property. + options.editables = [] + + cmdoptions.check_dist_restriction(options) + + options.src_dir = os.path.abspath(options.src_dir) + options.download_dir = normalize_path(options.download_dir) + + ensure_dir(options.download_dir) + + with self._build_session(options) as session: + target_python = make_target_python(options) + finder = self._build_package_finder( + options=options, + session=session, + target_python=target_python, + ) + build_delete = (not (options.no_clean or options.build_dir)) + if options.cache_dir and not check_path_owner(options.cache_dir): + logger.warning( + "The directory '%s' or its parent directory is not owned " + "by the current user and caching wheels has been " + "disabled. check the permissions and owner of that " + "directory. If executing pip with sudo, you may want " + "sudo's -H flag.", + options.cache_dir, + ) + options.cache_dir = None + + with RequirementTracker() as req_tracker, TempDirectory( + options.build_dir, delete=build_delete, kind="download" + ) as directory: + + requirement_set = RequirementSet( + require_hashes=options.require_hashes, + ) + self.populate_requirement_set( + requirement_set, + args, + options, + finder, + session, + self.name, + None + ) + + preparer = RequirementPreparer( + build_dir=directory.path, + src_dir=options.src_dir, + download_dir=options.download_dir, + wheel_download_dir=None, + progress_bar=options.progress_bar, + build_isolation=options.build_isolation, + req_tracker=req_tracker, + ) + + resolver = Resolver( + preparer=preparer, + finder=finder, + session=session, + wheel_cache=None, + use_user_site=False, + upgrade_strategy="to-satisfy-only", + force_reinstall=False, + ignore_dependencies=options.ignore_dependencies, + py_version_info=options.python_version, + ignore_requires_python=False, + ignore_installed=True, + isolated=options.isolated_mode, + ) + resolver.resolve(requirement_set) + + downloaded = ' '.join([ + req.name for req in requirement_set.successfully_downloaded + ]) + if downloaded: + logger.info('Successfully downloaded %s', downloaded) + + # Clean up + if not options.no_clean: + requirement_set.cleanup_files() + + return requirement_set diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/freeze.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/freeze.py new file mode 100644 index 0000000..9fc5b04 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/freeze.py @@ -0,0 +1,101 @@ +from __future__ import absolute_import + +import sys + +from pip._internal.cache import WheelCache +from pip._internal.cli import cmdoptions +from pip._internal.cli.base_command import Command +from pip._internal.models.format_control import FormatControl +from pip._internal.operations.freeze import freeze +from pip._internal.utils.compat import stdlib_pkgs + +DEV_PKGS = {'pip', 'setuptools', 'distribute', 'wheel'} + + +class FreezeCommand(Command): + """ + Output installed packages in requirements format. + + packages are listed in a case-insensitive sorted order. + """ + name = 'freeze' + usage = """ + %prog [options]""" + summary = 'Output installed packages in requirements format.' + log_streams = ("ext://sys.stderr", "ext://sys.stderr") + + def __init__(self, *args, **kw): + super(FreezeCommand, self).__init__(*args, **kw) + + self.cmd_opts.add_option( + '-r', '--requirement', + dest='requirements', + action='append', + default=[], + metavar='file', + help="Use the order in the given requirements file and its " + "comments when generating output. This option can be " + "used multiple times.") + self.cmd_opts.add_option( + '-f', '--find-links', + dest='find_links', + action='append', + default=[], + metavar='URL', + help='URL for finding packages, which will be added to the ' + 'output.') + self.cmd_opts.add_option( + '-l', '--local', + dest='local', + action='store_true', + default=False, + help='If in a virtualenv that has global access, do not output ' + 'globally-installed packages.') + self.cmd_opts.add_option( + '--user', + dest='user', + action='store_true', + default=False, + help='Only output packages installed in user-site.') + self.cmd_opts.add_option(cmdoptions.list_path()) + self.cmd_opts.add_option( + '--all', + dest='freeze_all', + action='store_true', + help='Do not skip these packages in the output:' + ' %s' % ', '.join(DEV_PKGS)) + self.cmd_opts.add_option( + '--exclude-editable', + dest='exclude_editable', + action='store_true', + help='Exclude editable package from output.') + + self.parser.insert_option_group(0, self.cmd_opts) + + def run(self, options, args): + format_control = FormatControl(set(), set()) + wheel_cache = WheelCache(options.cache_dir, format_control) + skip = set(stdlib_pkgs) + if not options.freeze_all: + skip.update(DEV_PKGS) + + cmdoptions.check_list_path_option(options) + + freeze_kwargs = dict( + requirement=options.requirements, + find_links=options.find_links, + local_only=options.local, + user_only=options.user, + paths=options.path, + skip_regex=options.skip_requirements_regex, + isolated=options.isolated_mode, + wheel_cache=wheel_cache, + skip=skip, + exclude_editable=options.exclude_editable, + ) + + try: + for line in freeze(**freeze_kwargs): + sys.stdout.write(line + '\n') + finally: + wheel_cache.cleanup() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/hash.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/hash.py new file mode 100644 index 0000000..423440e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/hash.py @@ -0,0 +1,57 @@ +from __future__ import absolute_import + +import hashlib +import logging +import sys + +from pip._internal.cli.base_command import Command +from pip._internal.cli.status_codes import ERROR +from pip._internal.utils.hashes import FAVORITE_HASH, STRONG_HASHES +from pip._internal.utils.misc import read_chunks + +logger = logging.getLogger(__name__) + + +class HashCommand(Command): + """ + Compute a hash of a local package archive. + + These can be used with --hash in a requirements file to do repeatable + installs. + + """ + name = 'hash' + usage = '%prog [options] ...' + summary = 'Compute hashes of package archives.' + ignore_require_venv = True + + def __init__(self, *args, **kw): + super(HashCommand, self).__init__(*args, **kw) + self.cmd_opts.add_option( + '-a', '--algorithm', + dest='algorithm', + choices=STRONG_HASHES, + action='store', + default=FAVORITE_HASH, + help='The hash algorithm to use: one of %s' % + ', '.join(STRONG_HASHES)) + self.parser.insert_option_group(0, self.cmd_opts) + + def run(self, options, args): + if not args: + self.parser.print_usage(sys.stderr) + return ERROR + + algorithm = options.algorithm + for path in args: + logger.info('%s:\n--hash=%s:%s', + path, algorithm, _hash_of_file(path, algorithm)) + + +def _hash_of_file(path, algorithm): + """Return the hash digest of a file.""" + with open(path, 'rb') as archive: + hash = hashlib.new(algorithm) + for chunk in read_chunks(archive): + hash.update(chunk) + return hash.hexdigest() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/help.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/help.py new file mode 100644 index 0000000..49a81cb --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/help.py @@ -0,0 +1,37 @@ +from __future__ import absolute_import + +from pip._internal.cli.base_command import Command +from pip._internal.cli.status_codes import SUCCESS +from pip._internal.exceptions import CommandError + + +class HelpCommand(Command): + """Show help for commands""" + name = 'help' + usage = """ + %prog """ + summary = 'Show help for commands.' + ignore_require_venv = True + + def run(self, options, args): + from pip._internal.commands import commands_dict, get_similar_commands + + try: + # 'pip help' with no args is handled by pip.__init__.parseopt() + cmd_name = args[0] # the command we need help for + except IndexError: + return SUCCESS + + if cmd_name not in commands_dict: + guess = get_similar_commands(cmd_name) + + msg = ['unknown command "%s"' % cmd_name] + if guess: + msg.append('maybe you meant "%s"' % guess) + + raise CommandError(' - '.join(msg)) + + command = commands_dict[cmd_name]() + command.parser.print_help() + + return SUCCESS diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/install.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/install.py new file mode 100644 index 0000000..ebeceac --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/install.py @@ -0,0 +1,580 @@ +from __future__ import absolute_import + +import errno +import logging +import operator +import os +import shutil +from optparse import SUPPRESS_HELP + +from pip._vendor import pkg_resources + +from pip._internal.cache import WheelCache +from pip._internal.cli import cmdoptions +from pip._internal.cli.base_command import RequirementCommand +from pip._internal.cli.cmdoptions import make_target_python +from pip._internal.cli.status_codes import ERROR +from pip._internal.exceptions import ( + CommandError, InstallationError, PreviousBuildDirError, +) +from pip._internal.legacy_resolve import Resolver +from pip._internal.locations import distutils_scheme +from pip._internal.operations.check import check_install_conflicts +from pip._internal.operations.prepare import RequirementPreparer +from pip._internal.req import RequirementSet, install_given_reqs +from pip._internal.req.req_tracker import RequirementTracker +from pip._internal.utils.filesystem import check_path_owner +from pip._internal.utils.misc import ( + ensure_dir, get_installed_version, + protect_pip_from_modification_on_windows, +) +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.virtualenv import virtualenv_no_global +from pip._internal.wheel import WheelBuilder + +logger = logging.getLogger(__name__) + + +def is_wheel_installed(): + """ + Return whether the wheel package is installed. + """ + try: + import wheel # noqa: F401 + except ImportError: + return False + + return True + + +def build_wheels(builder, pep517_requirements, legacy_requirements, session): + """ + Build wheels for requirements, depending on whether wheel is installed. + """ + # We don't build wheels for legacy requirements if wheel is not installed. + should_build_legacy = is_wheel_installed() + + # Always build PEP 517 requirements + build_failures = builder.build( + pep517_requirements, + session=session, autobuilding=True + ) + + if should_build_legacy: + # We don't care about failures building legacy + # requirements, as we'll fall through to a direct + # install for those. + builder.build( + legacy_requirements, + session=session, autobuilding=True + ) + + return build_failures + + +class InstallCommand(RequirementCommand): + """ + Install packages from: + + - PyPI (and other indexes) using requirement specifiers. + - VCS project urls. + - Local project directories. + - Local or remote source archives. + + pip also supports installing from "requirements files," which provide + an easy way to specify a whole environment to be installed. + """ + name = 'install' + + usage = """ + %prog [options] [package-index-options] ... + %prog [options] -r [package-index-options] ... + %prog [options] [-e] ... + %prog [options] [-e] ... + %prog [options] ...""" + + summary = 'Install packages.' + + def __init__(self, *args, **kw): + super(InstallCommand, self).__init__(*args, **kw) + + cmd_opts = self.cmd_opts + + cmd_opts.add_option(cmdoptions.requirements()) + cmd_opts.add_option(cmdoptions.constraints()) + cmd_opts.add_option(cmdoptions.no_deps()) + cmd_opts.add_option(cmdoptions.pre()) + + cmd_opts.add_option(cmdoptions.editable()) + cmd_opts.add_option( + '-t', '--target', + dest='target_dir', + metavar='dir', + default=None, + help='Install packages into . ' + 'By default this will not replace existing files/folders in ' + '. Use --upgrade to replace existing packages in ' + 'with new versions.' + ) + cmdoptions.add_target_python_options(cmd_opts) + + cmd_opts.add_option( + '--user', + dest='use_user_site', + action='store_true', + help="Install to the Python user install directory for your " + "platform. Typically ~/.local/, or %APPDATA%\\Python on " + "Windows. (See the Python documentation for site.USER_BASE " + "for full details.)") + cmd_opts.add_option( + '--no-user', + dest='use_user_site', + action='store_false', + help=SUPPRESS_HELP) + cmd_opts.add_option( + '--root', + dest='root_path', + metavar='dir', + default=None, + help="Install everything relative to this alternate root " + "directory.") + cmd_opts.add_option( + '--prefix', + dest='prefix_path', + metavar='dir', + default=None, + help="Installation prefix where lib, bin and other top-level " + "folders are placed") + + cmd_opts.add_option(cmdoptions.build_dir()) + + cmd_opts.add_option(cmdoptions.src()) + + cmd_opts.add_option( + '-U', '--upgrade', + dest='upgrade', + action='store_true', + help='Upgrade all specified packages to the newest available ' + 'version. The handling of dependencies depends on the ' + 'upgrade-strategy used.' + ) + + cmd_opts.add_option( + '--upgrade-strategy', + dest='upgrade_strategy', + default='only-if-needed', + choices=['only-if-needed', 'eager'], + help='Determines how dependency upgrading should be handled ' + '[default: %default]. ' + '"eager" - dependencies are upgraded regardless of ' + 'whether the currently installed version satisfies the ' + 'requirements of the upgraded package(s). ' + '"only-if-needed" - are upgraded only when they do not ' + 'satisfy the requirements of the upgraded package(s).' + ) + + cmd_opts.add_option( + '--force-reinstall', + dest='force_reinstall', + action='store_true', + help='Reinstall all packages even if they are already ' + 'up-to-date.') + + cmd_opts.add_option( + '-I', '--ignore-installed', + dest='ignore_installed', + action='store_true', + help='Ignore the installed packages (reinstalling instead).') + + cmd_opts.add_option(cmdoptions.ignore_requires_python()) + cmd_opts.add_option(cmdoptions.no_build_isolation()) + cmd_opts.add_option(cmdoptions.use_pep517()) + cmd_opts.add_option(cmdoptions.no_use_pep517()) + + cmd_opts.add_option(cmdoptions.install_options()) + cmd_opts.add_option(cmdoptions.global_options()) + + cmd_opts.add_option( + "--compile", + action="store_true", + dest="compile", + default=True, + help="Compile Python source files to bytecode", + ) + + cmd_opts.add_option( + "--no-compile", + action="store_false", + dest="compile", + help="Do not compile Python source files to bytecode", + ) + + cmd_opts.add_option( + "--no-warn-script-location", + action="store_false", + dest="warn_script_location", + default=True, + help="Do not warn when installing scripts outside PATH", + ) + cmd_opts.add_option( + "--no-warn-conflicts", + action="store_false", + dest="warn_about_conflicts", + default=True, + help="Do not warn about broken dependencies", + ) + + cmd_opts.add_option(cmdoptions.no_binary()) + cmd_opts.add_option(cmdoptions.only_binary()) + cmd_opts.add_option(cmdoptions.prefer_binary()) + cmd_opts.add_option(cmdoptions.no_clean()) + cmd_opts.add_option(cmdoptions.require_hashes()) + cmd_opts.add_option(cmdoptions.progress_bar()) + + index_opts = cmdoptions.make_option_group( + cmdoptions.index_group, + self.parser, + ) + + self.parser.insert_option_group(0, index_opts) + self.parser.insert_option_group(0, cmd_opts) + + def run(self, options, args): + cmdoptions.check_install_build_global(options) + upgrade_strategy = "to-satisfy-only" + if options.upgrade: + upgrade_strategy = options.upgrade_strategy + + if options.build_dir: + options.build_dir = os.path.abspath(options.build_dir) + + cmdoptions.check_dist_restriction(options, check_target=True) + + options.src_dir = os.path.abspath(options.src_dir) + install_options = options.install_options or [] + if options.use_user_site: + if options.prefix_path: + raise CommandError( + "Can not combine '--user' and '--prefix' as they imply " + "different installation locations" + ) + if virtualenv_no_global(): + raise InstallationError( + "Can not perform a '--user' install. User site-packages " + "are not visible in this virtualenv." + ) + install_options.append('--user') + install_options.append('--prefix=') + + target_temp_dir = TempDirectory(kind="target") + if options.target_dir: + options.ignore_installed = True + options.target_dir = os.path.abspath(options.target_dir) + if (os.path.exists(options.target_dir) and not + os.path.isdir(options.target_dir)): + raise CommandError( + "Target path exists but is not a directory, will not " + "continue." + ) + + # Create a target directory for using with the target option + target_temp_dir.create() + install_options.append('--home=' + target_temp_dir.path) + + global_options = options.global_options or [] + + with self._build_session(options) as session: + target_python = make_target_python(options) + finder = self._build_package_finder( + options=options, + session=session, + target_python=target_python, + ignore_requires_python=options.ignore_requires_python, + ) + build_delete = (not (options.no_clean or options.build_dir)) + wheel_cache = WheelCache(options.cache_dir, options.format_control) + + if options.cache_dir and not check_path_owner(options.cache_dir): + logger.warning( + "The directory '%s' or its parent directory is not owned " + "by the current user and caching wheels has been " + "disabled. check the permissions and owner of that " + "directory. If executing pip with sudo, you may want " + "sudo's -H flag.", + options.cache_dir, + ) + options.cache_dir = None + + with RequirementTracker() as req_tracker, TempDirectory( + options.build_dir, delete=build_delete, kind="install" + ) as directory: + requirement_set = RequirementSet( + require_hashes=options.require_hashes, + check_supported_wheels=not options.target_dir, + ) + + try: + self.populate_requirement_set( + requirement_set, args, options, finder, session, + self.name, wheel_cache + ) + preparer = RequirementPreparer( + build_dir=directory.path, + src_dir=options.src_dir, + download_dir=None, + wheel_download_dir=None, + progress_bar=options.progress_bar, + build_isolation=options.build_isolation, + req_tracker=req_tracker, + ) + + resolver = Resolver( + preparer=preparer, + finder=finder, + session=session, + wheel_cache=wheel_cache, + use_user_site=options.use_user_site, + upgrade_strategy=upgrade_strategy, + force_reinstall=options.force_reinstall, + ignore_dependencies=options.ignore_dependencies, + ignore_requires_python=options.ignore_requires_python, + ignore_installed=options.ignore_installed, + isolated=options.isolated_mode, + use_pep517=options.use_pep517 + ) + resolver.resolve(requirement_set) + + protect_pip_from_modification_on_windows( + modifying_pip=requirement_set.has_requirement("pip") + ) + + # Consider legacy and PEP517-using requirements separately + legacy_requirements = [] + pep517_requirements = [] + for req in requirement_set.requirements.values(): + if req.use_pep517: + pep517_requirements.append(req) + else: + legacy_requirements.append(req) + + wheel_builder = WheelBuilder( + finder, preparer, wheel_cache, + build_options=[], global_options=[], + ) + + build_failures = build_wheels( + builder=wheel_builder, + pep517_requirements=pep517_requirements, + legacy_requirements=legacy_requirements, + session=session, + ) + + # If we're using PEP 517, we cannot do a direct install + # so we fail here. + if build_failures: + raise InstallationError( + "Could not build wheels for {} which use" + " PEP 517 and cannot be installed directly".format( + ", ".join(r.name for r in build_failures))) + + to_install = resolver.get_installation_order( + requirement_set + ) + + # Consistency Checking of the package set we're installing. + should_warn_about_conflicts = ( + not options.ignore_dependencies and + options.warn_about_conflicts + ) + if should_warn_about_conflicts: + self._warn_about_conflicts(to_install) + + # Don't warn about script install locations if + # --target has been specified + warn_script_location = options.warn_script_location + if options.target_dir: + warn_script_location = False + + installed = install_given_reqs( + to_install, + install_options, + global_options, + root=options.root_path, + home=target_temp_dir.path, + prefix=options.prefix_path, + pycompile=options.compile, + warn_script_location=warn_script_location, + use_user_site=options.use_user_site, + ) + + lib_locations = get_lib_location_guesses( + user=options.use_user_site, + home=target_temp_dir.path, + root=options.root_path, + prefix=options.prefix_path, + isolated=options.isolated_mode, + ) + working_set = pkg_resources.WorkingSet(lib_locations) + + reqs = sorted(installed, key=operator.attrgetter('name')) + items = [] + for req in reqs: + item = req.name + try: + installed_version = get_installed_version( + req.name, working_set=working_set + ) + if installed_version: + item += '-' + installed_version + except Exception: + pass + items.append(item) + installed = ' '.join(items) + if installed: + logger.info('Successfully installed %s', installed) + except EnvironmentError as error: + show_traceback = (self.verbosity >= 1) + + message = create_env_error_message( + error, show_traceback, options.use_user_site, + ) + logger.error(message, exc_info=show_traceback) + + return ERROR + except PreviousBuildDirError: + options.no_clean = True + raise + finally: + # Clean up + if not options.no_clean: + requirement_set.cleanup_files() + wheel_cache.cleanup() + + if options.target_dir: + self._handle_target_dir( + options.target_dir, target_temp_dir, options.upgrade + ) + return requirement_set + + def _handle_target_dir(self, target_dir, target_temp_dir, upgrade): + ensure_dir(target_dir) + + # Checking both purelib and platlib directories for installed + # packages to be moved to target directory + lib_dir_list = [] + + with target_temp_dir: + # Checking both purelib and platlib directories for installed + # packages to be moved to target directory + scheme = distutils_scheme('', home=target_temp_dir.path) + purelib_dir = scheme['purelib'] + platlib_dir = scheme['platlib'] + data_dir = scheme['data'] + + if os.path.exists(purelib_dir): + lib_dir_list.append(purelib_dir) + if os.path.exists(platlib_dir) and platlib_dir != purelib_dir: + lib_dir_list.append(platlib_dir) + if os.path.exists(data_dir): + lib_dir_list.append(data_dir) + + for lib_dir in lib_dir_list: + for item in os.listdir(lib_dir): + if lib_dir == data_dir: + ddir = os.path.join(data_dir, item) + if any(s.startswith(ddir) for s in lib_dir_list[:-1]): + continue + target_item_dir = os.path.join(target_dir, item) + if os.path.exists(target_item_dir): + if not upgrade: + logger.warning( + 'Target directory %s already exists. Specify ' + '--upgrade to force replacement.', + target_item_dir + ) + continue + if os.path.islink(target_item_dir): + logger.warning( + 'Target directory %s already exists and is ' + 'a link. Pip will not automatically replace ' + 'links, please remove if replacement is ' + 'desired.', + target_item_dir + ) + continue + if os.path.isdir(target_item_dir): + shutil.rmtree(target_item_dir) + else: + os.remove(target_item_dir) + + shutil.move( + os.path.join(lib_dir, item), + target_item_dir + ) + + def _warn_about_conflicts(self, to_install): + try: + package_set, _dep_info = check_install_conflicts(to_install) + except Exception: + logger.error("Error checking for conflicts.", exc_info=True) + return + missing, conflicting = _dep_info + + # NOTE: There is some duplication here from pip check + for project_name in missing: + version = package_set[project_name][0] + for dependency in missing[project_name]: + logger.critical( + "%s %s requires %s, which is not installed.", + project_name, version, dependency[1], + ) + + for project_name in conflicting: + version = package_set[project_name][0] + for dep_name, dep_version, req in conflicting[project_name]: + logger.critical( + "%s %s has requirement %s, but you'll have %s %s which is " + "incompatible.", + project_name, version, req, dep_name, dep_version, + ) + + +def get_lib_location_guesses(*args, **kwargs): + scheme = distutils_scheme('', *args, **kwargs) + return [scheme['purelib'], scheme['platlib']] + + +def create_env_error_message(error, show_traceback, using_user_site): + """Format an error message for an EnvironmentError + + It may occur anytime during the execution of the install command. + """ + parts = [] + + # Mention the error if we are not going to show a traceback + parts.append("Could not install packages due to an EnvironmentError") + if not show_traceback: + parts.append(": ") + parts.append(str(error)) + else: + parts.append(".") + + # Spilt the error indication from a helper message (if any) + parts[-1] += "\n" + + # Suggest useful actions to the user: + # (1) using user site-packages or (2) verifying the permissions + if error.errno == errno.EACCES: + user_option_part = "Consider using the `--user` option" + permissions_part = "Check the permissions" + + if not using_user_site: + parts.extend([ + user_option_part, " or ", + permissions_part.lower(), + ]) + else: + parts.append(permissions_part) + parts.append(".\n") + + return "".join(parts).strip() + "\n" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/list.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/list.py new file mode 100644 index 0000000..cf71b13 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/list.py @@ -0,0 +1,311 @@ +from __future__ import absolute_import + +import json +import logging + +from pip._vendor import six +from pip._vendor.six.moves import zip_longest + +from pip._internal.cli import cmdoptions +from pip._internal.cli.base_command import Command +from pip._internal.cli.cmdoptions import make_search_scope +from pip._internal.exceptions import CommandError +from pip._internal.index import PackageFinder +from pip._internal.models.selection_prefs import SelectionPreferences +from pip._internal.utils.misc import ( + dist_is_editable, get_installed_distributions, +) +from pip._internal.utils.packaging import get_installer + +logger = logging.getLogger(__name__) + + +class ListCommand(Command): + """ + List installed packages, including editables. + + Packages are listed in a case-insensitive sorted order. + """ + name = 'list' + usage = """ + %prog [options]""" + summary = 'List installed packages.' + + def __init__(self, *args, **kw): + super(ListCommand, self).__init__(*args, **kw) + + cmd_opts = self.cmd_opts + + cmd_opts.add_option( + '-o', '--outdated', + action='store_true', + default=False, + help='List outdated packages') + cmd_opts.add_option( + '-u', '--uptodate', + action='store_true', + default=False, + help='List uptodate packages') + cmd_opts.add_option( + '-e', '--editable', + action='store_true', + default=False, + help='List editable projects.') + cmd_opts.add_option( + '-l', '--local', + action='store_true', + default=False, + help=('If in a virtualenv that has global access, do not list ' + 'globally-installed packages.'), + ) + self.cmd_opts.add_option( + '--user', + dest='user', + action='store_true', + default=False, + help='Only output packages installed in user-site.') + cmd_opts.add_option(cmdoptions.list_path()) + cmd_opts.add_option( + '--pre', + action='store_true', + default=False, + help=("Include pre-release and development versions. By default, " + "pip only finds stable versions."), + ) + + cmd_opts.add_option( + '--format', + action='store', + dest='list_format', + default="columns", + choices=('columns', 'freeze', 'json'), + help="Select the output format among: columns (default), freeze, " + "or json", + ) + + cmd_opts.add_option( + '--not-required', + action='store_true', + dest='not_required', + help="List packages that are not dependencies of " + "installed packages.", + ) + + cmd_opts.add_option( + '--exclude-editable', + action='store_false', + dest='include_editable', + help='Exclude editable package from output.', + ) + cmd_opts.add_option( + '--include-editable', + action='store_true', + dest='include_editable', + help='Include editable package from output.', + default=True, + ) + index_opts = cmdoptions.make_option_group( + cmdoptions.index_group, self.parser + ) + + self.parser.insert_option_group(0, index_opts) + self.parser.insert_option_group(0, cmd_opts) + + def _build_package_finder(self, options, session): + """ + Create a package finder appropriate to this list command. + """ + search_scope = make_search_scope(options) + + # Pass allow_yanked=False to ignore yanked versions. + selection_prefs = SelectionPreferences( + allow_yanked=False, + allow_all_prereleases=options.pre, + ) + + return PackageFinder.create( + search_scope=search_scope, + selection_prefs=selection_prefs, + trusted_hosts=options.trusted_hosts, + session=session, + ) + + def run(self, options, args): + if options.outdated and options.uptodate: + raise CommandError( + "Options --outdated and --uptodate cannot be combined.") + + cmdoptions.check_list_path_option(options) + + packages = get_installed_distributions( + local_only=options.local, + user_only=options.user, + editables_only=options.editable, + include_editables=options.include_editable, + paths=options.path, + ) + + # get_not_required must be called firstly in order to find and + # filter out all dependencies correctly. Otherwise a package + # can't be identified as requirement because some parent packages + # could be filtered out before. + if options.not_required: + packages = self.get_not_required(packages, options) + + if options.outdated: + packages = self.get_outdated(packages, options) + elif options.uptodate: + packages = self.get_uptodate(packages, options) + + self.output_package_listing(packages, options) + + def get_outdated(self, packages, options): + return [ + dist for dist in self.iter_packages_latest_infos(packages, options) + if dist.latest_version > dist.parsed_version + ] + + def get_uptodate(self, packages, options): + return [ + dist for dist in self.iter_packages_latest_infos(packages, options) + if dist.latest_version == dist.parsed_version + ] + + def get_not_required(self, packages, options): + dep_keys = set() + for dist in packages: + dep_keys.update(requirement.key for requirement in dist.requires()) + return {pkg for pkg in packages if pkg.key not in dep_keys} + + def iter_packages_latest_infos(self, packages, options): + with self._build_session(options) as session: + finder = self._build_package_finder(options, session) + + for dist in packages: + typ = 'unknown' + all_candidates = finder.find_all_candidates(dist.key) + if not options.pre: + # Remove prereleases + all_candidates = [candidate for candidate in all_candidates + if not candidate.version.is_prerelease] + + evaluator = finder.make_candidate_evaluator( + project_name=dist.project_name, + ) + best_candidate = evaluator.get_best_candidate(all_candidates) + if best_candidate is None: + continue + + remote_version = best_candidate.version + if best_candidate.link.is_wheel: + typ = 'wheel' + else: + typ = 'sdist' + # This is dirty but makes the rest of the code much cleaner + dist.latest_version = remote_version + dist.latest_filetype = typ + yield dist + + def output_package_listing(self, packages, options): + packages = sorted( + packages, + key=lambda dist: dist.project_name.lower(), + ) + if options.list_format == 'columns' and packages: + data, header = format_for_columns(packages, options) + self.output_package_listing_columns(data, header) + elif options.list_format == 'freeze': + for dist in packages: + if options.verbose >= 1: + logger.info("%s==%s (%s)", dist.project_name, + dist.version, dist.location) + else: + logger.info("%s==%s", dist.project_name, dist.version) + elif options.list_format == 'json': + logger.info(format_for_json(packages, options)) + + def output_package_listing_columns(self, data, header): + # insert the header first: we need to know the size of column names + if len(data) > 0: + data.insert(0, header) + + pkg_strings, sizes = tabulate(data) + + # Create and add a separator. + if len(data) > 0: + pkg_strings.insert(1, " ".join(map(lambda x: '-' * x, sizes))) + + for val in pkg_strings: + logger.info(val) + + +def tabulate(vals): + # From pfmoore on GitHub: + # https://github.com/pypa/pip/issues/3651#issuecomment-216932564 + assert len(vals) > 0 + + sizes = [0] * max(len(x) for x in vals) + for row in vals: + sizes = [max(s, len(str(c))) for s, c in zip_longest(sizes, row)] + + result = [] + for row in vals: + display = " ".join([str(c).ljust(s) if c is not None else '' + for s, c in zip_longest(sizes, row)]) + result.append(display) + + return result, sizes + + +def format_for_columns(pkgs, options): + """ + Convert the package data into something usable + by output_package_listing_columns. + """ + running_outdated = options.outdated + # Adjust the header for the `pip list --outdated` case. + if running_outdated: + header = ["Package", "Version", "Latest", "Type"] + else: + header = ["Package", "Version"] + + data = [] + if options.verbose >= 1 or any(dist_is_editable(x) for x in pkgs): + header.append("Location") + if options.verbose >= 1: + header.append("Installer") + + for proj in pkgs: + # if we're working on the 'outdated' list, separate out the + # latest_version and type + row = [proj.project_name, proj.version] + + if running_outdated: + row.append(proj.latest_version) + row.append(proj.latest_filetype) + + if options.verbose >= 1 or dist_is_editable(proj): + row.append(proj.location) + if options.verbose >= 1: + row.append(get_installer(proj)) + + data.append(row) + + return data, header + + +def format_for_json(packages, options): + data = [] + for dist in packages: + info = { + 'name': dist.project_name, + 'version': six.text_type(dist.version), + } + if options.verbose >= 1: + info['location'] = dist.location + info['installer'] = get_installer(dist) + if options.outdated: + info['latest_version'] = six.text_type(dist.latest_version) + info['latest_filetype'] = dist.latest_filetype + data.append(info) + return json.dumps(data) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/search.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/search.py new file mode 100644 index 0000000..5802711 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/search.py @@ -0,0 +1,139 @@ +from __future__ import absolute_import + +import logging +import sys +import textwrap +from collections import OrderedDict + +from pip._vendor import pkg_resources +from pip._vendor.packaging.version import parse as parse_version +# NOTE: XMLRPC Client is not annotated in typeshed as on 2017-07-17, which is +# why we ignore the type on this import +from pip._vendor.six.moves import xmlrpc_client # type: ignore + +from pip._internal.cli.base_command import Command +from pip._internal.cli.status_codes import NO_MATCHES_FOUND, SUCCESS +from pip._internal.download import PipXmlrpcTransport +from pip._internal.exceptions import CommandError +from pip._internal.models.index import PyPI +from pip._internal.utils.compat import get_terminal_size +from pip._internal.utils.logging import indent_log + +logger = logging.getLogger(__name__) + + +class SearchCommand(Command): + """Search for PyPI packages whose name or summary contains .""" + name = 'search' + usage = """ + %prog [options] """ + summary = 'Search PyPI for packages.' + ignore_require_venv = True + + def __init__(self, *args, **kw): + super(SearchCommand, self).__init__(*args, **kw) + self.cmd_opts.add_option( + '-i', '--index', + dest='index', + metavar='URL', + default=PyPI.pypi_url, + help='Base URL of Python Package Index (default %default)') + + self.parser.insert_option_group(0, self.cmd_opts) + + def run(self, options, args): + if not args: + raise CommandError('Missing required argument (search query).') + query = args + pypi_hits = self.search(query, options) + hits = transform_hits(pypi_hits) + + terminal_width = None + if sys.stdout.isatty(): + terminal_width = get_terminal_size()[0] + + print_results(hits, terminal_width=terminal_width) + if pypi_hits: + return SUCCESS + return NO_MATCHES_FOUND + + def search(self, query, options): + index_url = options.index + with self._build_session(options) as session: + transport = PipXmlrpcTransport(index_url, session) + pypi = xmlrpc_client.ServerProxy(index_url, transport) + hits = pypi.search({'name': query, 'summary': query}, 'or') + return hits + + +def transform_hits(hits): + """ + The list from pypi is really a list of versions. We want a list of + packages with the list of versions stored inline. This converts the + list from pypi into one we can use. + """ + packages = OrderedDict() + for hit in hits: + name = hit['name'] + summary = hit['summary'] + version = hit['version'] + + if name not in packages.keys(): + packages[name] = { + 'name': name, + 'summary': summary, + 'versions': [version], + } + else: + packages[name]['versions'].append(version) + + # if this is the highest version, replace summary and score + if version == highest_version(packages[name]['versions']): + packages[name]['summary'] = summary + + return list(packages.values()) + + +def print_results(hits, name_column_width=None, terminal_width=None): + if not hits: + return + if name_column_width is None: + name_column_width = max([ + len(hit['name']) + len(highest_version(hit.get('versions', ['-']))) + for hit in hits + ]) + 4 + + installed_packages = [p.project_name for p in pkg_resources.working_set] + for hit in hits: + name = hit['name'] + summary = hit['summary'] or '' + latest = highest_version(hit.get('versions', ['-'])) + if terminal_width is not None: + target_width = terminal_width - name_column_width - 5 + if target_width > 10: + # wrap and indent summary to fit terminal + summary = textwrap.wrap(summary, target_width) + summary = ('\n' + ' ' * (name_column_width + 3)).join(summary) + + line = '%-*s - %s' % (name_column_width, + '%s (%s)' % (name, latest), summary) + try: + logger.info(line) + if name in installed_packages: + dist = pkg_resources.get_distribution(name) + with indent_log(): + if dist.version == latest: + logger.info('INSTALLED: %s (latest)', dist.version) + else: + logger.info('INSTALLED: %s', dist.version) + if parse_version(latest).pre: + logger.info('LATEST: %s (pre-release; install' + ' with "pip install --pre")', latest) + else: + logger.info('LATEST: %s', latest) + except UnicodeEncodeError: + pass + + +def highest_version(versions): + return max(versions, key=parse_version) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/show.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/show.py new file mode 100644 index 0000000..a18a902 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/show.py @@ -0,0 +1,168 @@ +from __future__ import absolute_import + +import logging +import os +from email.parser import FeedParser + +from pip._vendor import pkg_resources +from pip._vendor.packaging.utils import canonicalize_name + +from pip._internal.cli.base_command import Command +from pip._internal.cli.status_codes import ERROR, SUCCESS + +logger = logging.getLogger(__name__) + + +class ShowCommand(Command): + """ + Show information about one or more installed packages. + + The output is in RFC-compliant mail header format. + """ + name = 'show' + usage = """ + %prog [options] ...""" + summary = 'Show information about installed packages.' + ignore_require_venv = True + + def __init__(self, *args, **kw): + super(ShowCommand, self).__init__(*args, **kw) + self.cmd_opts.add_option( + '-f', '--files', + dest='files', + action='store_true', + default=False, + help='Show the full list of installed files for each package.') + + self.parser.insert_option_group(0, self.cmd_opts) + + def run(self, options, args): + if not args: + logger.warning('ERROR: Please provide a package name or names.') + return ERROR + query = args + + results = search_packages_info(query) + if not print_results( + results, list_files=options.files, verbose=options.verbose): + return ERROR + return SUCCESS + + +def search_packages_info(query): + """ + Gather details from installed distributions. Print distribution name, + version, location, and installed files. Installed files requires a + pip generated 'installed-files.txt' in the distributions '.egg-info' + directory. + """ + installed = {} + for p in pkg_resources.working_set: + installed[canonicalize_name(p.project_name)] = p + + query_names = [canonicalize_name(name) for name in query] + + for dist in [installed[pkg] for pkg in query_names if pkg in installed]: + package = { + 'name': dist.project_name, + 'version': dist.version, + 'location': dist.location, + 'requires': [dep.project_name for dep in dist.requires()], + } + file_list = None + metadata = None + if isinstance(dist, pkg_resources.DistInfoDistribution): + # RECORDs should be part of .dist-info metadatas + if dist.has_metadata('RECORD'): + lines = dist.get_metadata_lines('RECORD') + paths = [l.split(',')[0] for l in lines] + paths = [os.path.join(dist.location, p) for p in paths] + file_list = [os.path.relpath(p, dist.location) for p in paths] + + if dist.has_metadata('METADATA'): + metadata = dist.get_metadata('METADATA') + else: + # Otherwise use pip's log for .egg-info's + if dist.has_metadata('installed-files.txt'): + paths = dist.get_metadata_lines('installed-files.txt') + paths = [os.path.join(dist.egg_info, p) for p in paths] + file_list = [os.path.relpath(p, dist.location) for p in paths] + + if dist.has_metadata('PKG-INFO'): + metadata = dist.get_metadata('PKG-INFO') + + if dist.has_metadata('entry_points.txt'): + entry_points = dist.get_metadata_lines('entry_points.txt') + package['entry_points'] = entry_points + + if dist.has_metadata('INSTALLER'): + for line in dist.get_metadata_lines('INSTALLER'): + if line.strip(): + package['installer'] = line.strip() + break + + # @todo: Should pkg_resources.Distribution have a + # `get_pkg_info` method? + feed_parser = FeedParser() + feed_parser.feed(metadata) + pkg_info_dict = feed_parser.close() + for key in ('metadata-version', 'summary', + 'home-page', 'author', 'author-email', 'license'): + package[key] = pkg_info_dict.get(key) + + # It looks like FeedParser cannot deal with repeated headers + classifiers = [] + for line in metadata.splitlines(): + if line.startswith('Classifier: '): + classifiers.append(line[len('Classifier: '):]) + package['classifiers'] = classifiers + + if file_list: + package['files'] = sorted(file_list) + yield package + + +def print_results(distributions, list_files=False, verbose=False): + """ + Print the informations from installed distributions found. + """ + results_printed = False + for i, dist in enumerate(distributions): + results_printed = True + if i > 0: + logger.info("---") + + name = dist.get('name', '') + required_by = [ + pkg.project_name for pkg in pkg_resources.working_set + if name in [required.name for required in pkg.requires()] + ] + + logger.info("Name: %s", name) + logger.info("Version: %s", dist.get('version', '')) + logger.info("Summary: %s", dist.get('summary', '')) + logger.info("Home-page: %s", dist.get('home-page', '')) + logger.info("Author: %s", dist.get('author', '')) + logger.info("Author-email: %s", dist.get('author-email', '')) + logger.info("License: %s", dist.get('license', '')) + logger.info("Location: %s", dist.get('location', '')) + logger.info("Requires: %s", ', '.join(dist.get('requires', []))) + logger.info("Required-by: %s", ', '.join(required_by)) + + if verbose: + logger.info("Metadata-Version: %s", + dist.get('metadata-version', '')) + logger.info("Installer: %s", dist.get('installer', '')) + logger.info("Classifiers:") + for classifier in dist.get('classifiers', []): + logger.info(" %s", classifier) + logger.info("Entry-points:") + for entry in dist.get('entry_points', []): + logger.info(" %s", entry.strip()) + if list_files: + logger.info("Files:") + for line in dist.get('files', []): + logger.info(" %s", line.strip()) + if "files" not in dist: + logger.info("Cannot locate installed-files.txt") + return results_printed diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/uninstall.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/uninstall.py new file mode 100644 index 0000000..0cd6f54 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/uninstall.py @@ -0,0 +1,78 @@ +from __future__ import absolute_import + +from pip._vendor.packaging.utils import canonicalize_name + +from pip._internal.cli.base_command import Command +from pip._internal.exceptions import InstallationError +from pip._internal.req import parse_requirements +from pip._internal.req.constructors import install_req_from_line +from pip._internal.utils.misc import protect_pip_from_modification_on_windows + + +class UninstallCommand(Command): + """ + Uninstall packages. + + pip is able to uninstall most installed packages. Known exceptions are: + + - Pure distutils packages installed with ``python setup.py install``, which + leave behind no metadata to determine what files were installed. + - Script wrappers installed by ``python setup.py develop``. + """ + name = 'uninstall' + usage = """ + %prog [options] ... + %prog [options] -r ...""" + summary = 'Uninstall packages.' + + def __init__(self, *args, **kw): + super(UninstallCommand, self).__init__(*args, **kw) + self.cmd_opts.add_option( + '-r', '--requirement', + dest='requirements', + action='append', + default=[], + metavar='file', + help='Uninstall all the packages listed in the given requirements ' + 'file. This option can be used multiple times.', + ) + self.cmd_opts.add_option( + '-y', '--yes', + dest='yes', + action='store_true', + help="Don't ask for confirmation of uninstall deletions.") + + self.parser.insert_option_group(0, self.cmd_opts) + + def run(self, options, args): + with self._build_session(options) as session: + reqs_to_uninstall = {} + for name in args: + req = install_req_from_line( + name, isolated=options.isolated_mode, + ) + if req.name: + reqs_to_uninstall[canonicalize_name(req.name)] = req + for filename in options.requirements: + for req in parse_requirements( + filename, + options=options, + session=session): + if req.name: + reqs_to_uninstall[canonicalize_name(req.name)] = req + if not reqs_to_uninstall: + raise InstallationError( + 'You must give at least one requirement to %(name)s (see ' + '"pip help %(name)s")' % dict(name=self.name) + ) + + protect_pip_from_modification_on_windows( + modifying_pip="pip" in reqs_to_uninstall + ) + + for req in reqs_to_uninstall.values(): + uninstall_pathset = req.uninstall( + auto_confirm=options.yes, verbose=self.verbosity > 0, + ) + if uninstall_pathset: + uninstall_pathset.commit() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/wheel.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/wheel.py new file mode 100644 index 0000000..97f3b14 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/commands/wheel.py @@ -0,0 +1,181 @@ +# -*- coding: utf-8 -*- +from __future__ import absolute_import + +import logging +import os + +from pip._internal.cache import WheelCache +from pip._internal.cli import cmdoptions +from pip._internal.cli.base_command import RequirementCommand +from pip._internal.exceptions import CommandError, PreviousBuildDirError +from pip._internal.legacy_resolve import Resolver +from pip._internal.operations.prepare import RequirementPreparer +from pip._internal.req import RequirementSet +from pip._internal.req.req_tracker import RequirementTracker +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.wheel import WheelBuilder + +logger = logging.getLogger(__name__) + + +class WheelCommand(RequirementCommand): + """ + Build Wheel archives for your requirements and dependencies. + + Wheel is a built-package format, and offers the advantage of not + recompiling your software during every install. For more details, see the + wheel docs: https://wheel.readthedocs.io/en/latest/ + + Requirements: setuptools>=0.8, and wheel. + + 'pip wheel' uses the bdist_wheel setuptools extension from the wheel + package to build individual wheels. + + """ + + name = 'wheel' + usage = """ + %prog [options] ... + %prog [options] -r ... + %prog [options] [-e] ... + %prog [options] [-e] ... + %prog [options] ...""" + + summary = 'Build wheels from your requirements.' + + def __init__(self, *args, **kw): + super(WheelCommand, self).__init__(*args, **kw) + + cmd_opts = self.cmd_opts + + cmd_opts.add_option( + '-w', '--wheel-dir', + dest='wheel_dir', + metavar='dir', + default=os.curdir, + help=("Build wheels into , where the default is the " + "current working directory."), + ) + cmd_opts.add_option(cmdoptions.no_binary()) + cmd_opts.add_option(cmdoptions.only_binary()) + cmd_opts.add_option(cmdoptions.prefer_binary()) + cmd_opts.add_option( + '--build-option', + dest='build_options', + metavar='options', + action='append', + help="Extra arguments to be supplied to 'setup.py bdist_wheel'.", + ) + cmd_opts.add_option(cmdoptions.no_build_isolation()) + cmd_opts.add_option(cmdoptions.use_pep517()) + cmd_opts.add_option(cmdoptions.no_use_pep517()) + cmd_opts.add_option(cmdoptions.constraints()) + cmd_opts.add_option(cmdoptions.editable()) + cmd_opts.add_option(cmdoptions.requirements()) + cmd_opts.add_option(cmdoptions.src()) + cmd_opts.add_option(cmdoptions.ignore_requires_python()) + cmd_opts.add_option(cmdoptions.no_deps()) + cmd_opts.add_option(cmdoptions.build_dir()) + cmd_opts.add_option(cmdoptions.progress_bar()) + + cmd_opts.add_option( + '--global-option', + dest='global_options', + action='append', + metavar='options', + help="Extra global options to be supplied to the setup.py " + "call before the 'bdist_wheel' command.") + + cmd_opts.add_option( + '--pre', + action='store_true', + default=False, + help=("Include pre-release and development versions. By default, " + "pip only finds stable versions."), + ) + + cmd_opts.add_option(cmdoptions.no_clean()) + cmd_opts.add_option(cmdoptions.require_hashes()) + + index_opts = cmdoptions.make_option_group( + cmdoptions.index_group, + self.parser, + ) + + self.parser.insert_option_group(0, index_opts) + self.parser.insert_option_group(0, cmd_opts) + + def run(self, options, args): + cmdoptions.check_install_build_global(options) + + if options.build_dir: + options.build_dir = os.path.abspath(options.build_dir) + + options.src_dir = os.path.abspath(options.src_dir) + + with self._build_session(options) as session: + finder = self._build_package_finder(options, session) + build_delete = (not (options.no_clean or options.build_dir)) + wheel_cache = WheelCache(options.cache_dir, options.format_control) + + with RequirementTracker() as req_tracker, TempDirectory( + options.build_dir, delete=build_delete, kind="wheel" + ) as directory: + + requirement_set = RequirementSet( + require_hashes=options.require_hashes, + ) + + try: + self.populate_requirement_set( + requirement_set, args, options, finder, session, + self.name, wheel_cache + ) + + preparer = RequirementPreparer( + build_dir=directory.path, + src_dir=options.src_dir, + download_dir=None, + wheel_download_dir=options.wheel_dir, + progress_bar=options.progress_bar, + build_isolation=options.build_isolation, + req_tracker=req_tracker, + ) + + resolver = Resolver( + preparer=preparer, + finder=finder, + session=session, + wheel_cache=wheel_cache, + use_user_site=False, + upgrade_strategy="to-satisfy-only", + force_reinstall=False, + ignore_dependencies=options.ignore_dependencies, + ignore_requires_python=options.ignore_requires_python, + ignore_installed=True, + isolated=options.isolated_mode, + use_pep517=options.use_pep517 + ) + resolver.resolve(requirement_set) + + # build wheels + wb = WheelBuilder( + finder, preparer, wheel_cache, + build_options=options.build_options or [], + global_options=options.global_options or [], + no_clean=options.no_clean, + ) + build_failures = wb.build( + requirement_set.requirements.values(), session=session, + ) + if len(build_failures) != 0: + raise CommandError( + "Failed to build one or more wheels" + ) + except PreviousBuildDirError: + options.no_clean = True + raise + finally: + if not options.no_clean: + requirement_set.cleanup_files() + wheel_cache.cleanup() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/configuration.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/configuration.py new file mode 100644 index 0000000..437e92e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/configuration.py @@ -0,0 +1,417 @@ +"""Configuration management setup + +Some terminology: +- name + As written in config files. +- value + Value associated with a name +- key + Name combined with it's section (section.name) +- variant + A single word describing where the configuration key-value pair came from +""" + +import locale +import logging +import os +import sys + +from pip._vendor.six.moves import configparser + +from pip._internal.exceptions import ( + ConfigurationError, ConfigurationFileCouldNotBeLoaded, +) +from pip._internal.utils import appdirs +from pip._internal.utils.compat import WINDOWS, expanduser +from pip._internal.utils.misc import ensure_dir, enum +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import ( + Any, Dict, Iterable, List, NewType, Optional, Tuple + ) + + RawConfigParser = configparser.RawConfigParser # Shorthand + Kind = NewType("Kind", str) + +logger = logging.getLogger(__name__) + + +# NOTE: Maybe use the optionx attribute to normalize keynames. +def _normalize_name(name): + # type: (str) -> str + """Make a name consistent regardless of source (environment or file) + """ + name = name.lower().replace('_', '-') + if name.startswith('--'): + name = name[2:] # only prefer long opts + return name + + +def _disassemble_key(name): + # type: (str) -> List[str] + if "." not in name: + error_message = ( + "Key does not contain dot separated section and key. " + "Perhaps you wanted to use 'global.{}' instead?" + ).format(name) + raise ConfigurationError(error_message) + return name.split(".", 1) + + +# The kinds of configurations there are. +kinds = enum( + USER="user", # User Specific + GLOBAL="global", # System Wide + SITE="site", # [Virtual] Environment Specific + ENV="env", # from PIP_CONFIG_FILE + ENV_VAR="env-var", # from Environment Variables +) + + +CONFIG_BASENAME = 'pip.ini' if WINDOWS else 'pip.conf' + + +def get_configuration_files(): + global_config_files = [ + os.path.join(path, CONFIG_BASENAME) + for path in appdirs.site_config_dirs('pip') + ] + + site_config_file = os.path.join(sys.prefix, CONFIG_BASENAME) + legacy_config_file = os.path.join( + expanduser('~'), + 'pip' if WINDOWS else '.pip', + CONFIG_BASENAME, + ) + new_config_file = os.path.join( + appdirs.user_config_dir("pip"), CONFIG_BASENAME + ) + return { + kinds.GLOBAL: global_config_files, + kinds.SITE: [site_config_file], + kinds.USER: [legacy_config_file, new_config_file], + } + + +class Configuration(object): + """Handles management of configuration. + + Provides an interface to accessing and managing configuration files. + + This class converts provides an API that takes "section.key-name" style + keys and stores the value associated with it as "key-name" under the + section "section". + + This allows for a clean interface wherein the both the section and the + key-name are preserved in an easy to manage form in the configuration files + and the data stored is also nice. + """ + + def __init__(self, isolated, load_only=None): + # type: (bool, Kind) -> None + super(Configuration, self).__init__() + + _valid_load_only = [kinds.USER, kinds.GLOBAL, kinds.SITE, None] + if load_only not in _valid_load_only: + raise ConfigurationError( + "Got invalid value for load_only - should be one of {}".format( + ", ".join(map(repr, _valid_load_only[:-1])) + ) + ) + self.isolated = isolated # type: bool + self.load_only = load_only # type: Optional[Kind] + + # The order here determines the override order. + self._override_order = [ + kinds.GLOBAL, kinds.USER, kinds.SITE, kinds.ENV, kinds.ENV_VAR + ] + + self._ignore_env_names = ["version", "help"] + + # Because we keep track of where we got the data from + self._parsers = { + variant: [] for variant in self._override_order + } # type: Dict[Kind, List[Tuple[str, RawConfigParser]]] + self._config = { + variant: {} for variant in self._override_order + } # type: Dict[Kind, Dict[str, Any]] + self._modified_parsers = [] # type: List[Tuple[str, RawConfigParser]] + + def load(self): + # type: () -> None + """Loads configuration from configuration files and environment + """ + self._load_config_files() + if not self.isolated: + self._load_environment_vars() + + def get_file_to_edit(self): + # type: () -> Optional[str] + """Returns the file with highest priority in configuration + """ + assert self.load_only is not None, \ + "Need to be specified a file to be editing" + + try: + return self._get_parser_to_modify()[0] + except IndexError: + return None + + def items(self): + # type: () -> Iterable[Tuple[str, Any]] + """Returns key-value pairs like dict.items() representing the loaded + configuration + """ + return self._dictionary.items() + + def get_value(self, key): + # type: (str) -> Any + """Get a value from the configuration. + """ + try: + return self._dictionary[key] + except KeyError: + raise ConfigurationError("No such key - {}".format(key)) + + def set_value(self, key, value): + # type: (str, Any) -> None + """Modify a value in the configuration. + """ + self._ensure_have_load_only() + + fname, parser = self._get_parser_to_modify() + + if parser is not None: + section, name = _disassemble_key(key) + + # Modify the parser and the configuration + if not parser.has_section(section): + parser.add_section(section) + parser.set(section, name, value) + + self._config[self.load_only][key] = value + self._mark_as_modified(fname, parser) + + def unset_value(self, key): + # type: (str) -> None + """Unset a value in the configuration. + """ + self._ensure_have_load_only() + + if key not in self._config[self.load_only]: + raise ConfigurationError("No such key - {}".format(key)) + + fname, parser = self._get_parser_to_modify() + + if parser is not None: + section, name = _disassemble_key(key) + + # Remove the key in the parser + modified_something = False + if parser.has_section(section): + # Returns whether the option was removed or not + modified_something = parser.remove_option(section, name) + + if modified_something: + # name removed from parser, section may now be empty + section_iter = iter(parser.items(section)) + try: + val = next(section_iter) + except StopIteration: + val = None + + if val is None: + parser.remove_section(section) + + self._mark_as_modified(fname, parser) + else: + raise ConfigurationError( + "Fatal Internal error [id=1]. Please report as a bug." + ) + + del self._config[self.load_only][key] + + def save(self): + # type: () -> None + """Save the current in-memory state. + """ + self._ensure_have_load_only() + + for fname, parser in self._modified_parsers: + logger.info("Writing to %s", fname) + + # Ensure directory exists. + ensure_dir(os.path.dirname(fname)) + + with open(fname, "w") as f: + parser.write(f) + + # + # Private routines + # + + def _ensure_have_load_only(self): + # type: () -> None + if self.load_only is None: + raise ConfigurationError("Needed a specific file to be modifying.") + logger.debug("Will be working with %s variant only", self.load_only) + + @property + def _dictionary(self): + # type: () -> Dict[str, Any] + """A dictionary representing the loaded configuration. + """ + # NOTE: Dictionaries are not populated if not loaded. So, conditionals + # are not needed here. + retval = {} + + for variant in self._override_order: + retval.update(self._config[variant]) + + return retval + + def _load_config_files(self): + # type: () -> None + """Loads configuration from configuration files + """ + config_files = dict(self._iter_config_files()) + if config_files[kinds.ENV][0:1] == [os.devnull]: + logger.debug( + "Skipping loading configuration files due to " + "environment's PIP_CONFIG_FILE being os.devnull" + ) + return + + for variant, files in config_files.items(): + for fname in files: + # If there's specific variant set in `load_only`, load only + # that variant, not the others. + if self.load_only is not None and variant != self.load_only: + logger.debug( + "Skipping file '%s' (variant: %s)", fname, variant + ) + continue + + parser = self._load_file(variant, fname) + + # Keeping track of the parsers used + self._parsers[variant].append((fname, parser)) + + def _load_file(self, variant, fname): + # type: (Kind, str) -> RawConfigParser + logger.debug("For variant '%s', will try loading '%s'", variant, fname) + parser = self._construct_parser(fname) + + for section in parser.sections(): + items = parser.items(section) + self._config[variant].update(self._normalized_keys(section, items)) + + return parser + + def _construct_parser(self, fname): + # type: (str) -> RawConfigParser + parser = configparser.RawConfigParser() + # If there is no such file, don't bother reading it but create the + # parser anyway, to hold the data. + # Doing this is useful when modifying and saving files, where we don't + # need to construct a parser. + if os.path.exists(fname): + try: + parser.read(fname) + except UnicodeDecodeError: + # See https://github.com/pypa/pip/issues/4963 + raise ConfigurationFileCouldNotBeLoaded( + reason="contains invalid {} characters".format( + locale.getpreferredencoding(False) + ), + fname=fname, + ) + except configparser.Error as error: + # See https://github.com/pypa/pip/issues/4893 + raise ConfigurationFileCouldNotBeLoaded(error=error) + return parser + + def _load_environment_vars(self): + # type: () -> None + """Loads configuration from environment variables + """ + self._config[kinds.ENV_VAR].update( + self._normalized_keys(":env:", self._get_environ_vars()) + ) + + def _normalized_keys(self, section, items): + # type: (str, Iterable[Tuple[str, Any]]) -> Dict[str, Any] + """Normalizes items to construct a dictionary with normalized keys. + + This routine is where the names become keys and are made the same + regardless of source - configuration files or environment. + """ + normalized = {} + for name, val in items: + key = section + "." + _normalize_name(name) + normalized[key] = val + return normalized + + def _get_environ_vars(self): + # type: () -> Iterable[Tuple[str, str]] + """Returns a generator with all environmental vars with prefix PIP_""" + for key, val in os.environ.items(): + should_be_yielded = ( + key.startswith("PIP_") and + key[4:].lower() not in self._ignore_env_names + ) + if should_be_yielded: + yield key[4:].lower(), val + + # XXX: This is patched in the tests. + def _iter_config_files(self): + # type: () -> Iterable[Tuple[Kind, List[str]]] + """Yields variant and configuration files associated with it. + + This should be treated like items of a dictionary. + """ + # SMELL: Move the conditions out of this function + + # environment variables have the lowest priority + config_file = os.environ.get('PIP_CONFIG_FILE', None) + if config_file is not None: + yield kinds.ENV, [config_file] + else: + yield kinds.ENV, [] + + config_files = get_configuration_files() + + # at the base we have any global configuration + yield kinds.GLOBAL, config_files[kinds.GLOBAL] + + # per-user configuration next + should_load_user_config = not self.isolated and not ( + config_file and os.path.exists(config_file) + ) + if should_load_user_config: + # The legacy config file is overridden by the new config file + yield kinds.USER, config_files[kinds.USER] + + # finally virtualenv configuration first trumping others + yield kinds.SITE, config_files[kinds.SITE] + + def _get_parser_to_modify(self): + # type: () -> Tuple[str, RawConfigParser] + # Determine which parser to modify + parsers = self._parsers[self.load_only] + if not parsers: + # This should not happen if everything works correctly. + raise ConfigurationError( + "Fatal Internal error [id=2]. Please report as a bug." + ) + + # Use the highest priority parser. + return parsers[-1] + + # XXX: This is patched in the tests. + def _mark_as_modified(self, fname, parser): + # type: (str, RawConfigParser) -> None + file_parser_tuple = (fname, parser) + if file_parser_tuple not in self._modified_parsers: + self._modified_parsers.append(file_parser_tuple) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/__init__.py new file mode 100644 index 0000000..fdf332a --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/__init__.py @@ -0,0 +1,23 @@ +from pip._internal.distributions.source import SourceDistribution +from pip._internal.distributions.wheel import WheelDistribution + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from pip._internal.distributions.base import AbstractDistribution + from pip._internal.req.req_install import InstallRequirement + + +def make_distribution_for_install_requirement(install_req): + # type: (InstallRequirement) -> AbstractDistribution + """Returns a Distribution for the given InstallRequirement + """ + # If it's not an editable, is a wheel, it's a WheelDistribution + if install_req.editable: + return SourceDistribution(install_req) + + if install_req.link and install_req.is_wheel: + return WheelDistribution(install_req) + + # Otherwise, a SourceDistribution + return SourceDistribution(install_req) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b543a67eba4da74aeccc17600d566aaf457eb403 GIT binary patch literal 874 zcmaJF#XaHtfiLPY^V1w<&JLbZfePP|FBT|4RS+B8vb z@JBdu}0f%Ey`5H`w zBFs^Y1B|tAa3eMYv+zxB#dct0L~U^lF^gB?YEUg=Hh1D$Py@dbRX?Mk9yufA)qcQ@ z$iw;mXpxEuea55`Y@8~#NC4e?Kc|%60{7pXy*(rSm(TmJ$nbP9I2pVE>fNVf_%)oU z+w7A>s*v*`y-b;)F-_D2>!dfLecfLlR6YcAjn0v{qwqEQgh%>hh&EVLw3W5NwlNQ{ zkA_sGB9U(Bmh-yPg>coJx-*v1#QnE~x(njjxkDqS!ZD{p*N|JBB^SBFB>AWt7w{N* zI1RSxfe3o}6^RC*zgGTIuq;&6&qCo(7d)au`n@ZEMtYfu*U97Qd3Qd)TCWN39ggRs z3o=Xmcm9$s4{k0z=yngYRrV;=V4;L1ii#xUepGr2=@SSrMM!74%Dp(eprjlp&@T{* zLF*#7lh&2WVz=xHc8n%=Owj^t;5G6#r0o1j*C}5oJF?h@%}^fvkN9^^`Mq5p>=2h7 zwOX=dCM-yrySs$ljN?#JVFN9=ze|I5I-uM3La{5H?mDErZ MH;txYVfdQA0VyK>z5oCK literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/base.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/base.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2b7dd12b84dacd5af2a8bbdef7fac37cb858ddae GIT binary patch literal 1669 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 bool + """ + Return whether it looks like pip is running under CI. + """ + # We don't use the method of checking for a tty (e.g. using isatty()) + # because some CI systems mimic a tty (e.g. Travis CI). Thus that + # method doesn't provide definitive information in either direction. + return any(name in os.environ for name in CI_ENVIRONMENT_VARIABLES) + + +def user_agent(): + """ + Return a string representing the user agent. + """ + data = { + "installer": {"name": "pip", "version": pip.__version__}, + "python": platform.python_version(), + "implementation": { + "name": platform.python_implementation(), + }, + } + + if data["implementation"]["name"] == 'CPython': + data["implementation"]["version"] = platform.python_version() + elif data["implementation"]["name"] == 'PyPy': + if sys.pypy_version_info.releaselevel == 'final': + pypy_version_info = sys.pypy_version_info[:3] + else: + pypy_version_info = sys.pypy_version_info + data["implementation"]["version"] = ".".join( + [str(x) for x in pypy_version_info] + ) + elif data["implementation"]["name"] == 'Jython': + # Complete Guess + data["implementation"]["version"] = platform.python_version() + elif data["implementation"]["name"] == 'IronPython': + # Complete Guess + data["implementation"]["version"] = platform.python_version() + + if sys.platform.startswith("linux"): + from pip._vendor import distro + distro_infos = dict(filter( + lambda x: x[1], + zip(["name", "version", "id"], distro.linux_distribution()), + )) + libc = dict(filter( + lambda x: x[1], + zip(["lib", "version"], libc_ver()), + )) + if libc: + distro_infos["libc"] = libc + if distro_infos: + data["distro"] = distro_infos + + if sys.platform.startswith("darwin") and platform.mac_ver()[0]: + data["distro"] = {"name": "macOS", "version": platform.mac_ver()[0]} + + if platform.system(): + data.setdefault("system", {})["name"] = platform.system() + + if platform.release(): + data.setdefault("system", {})["release"] = platform.release() + + if platform.machine(): + data["cpu"] = platform.machine() + + if HAS_TLS: + data["openssl_version"] = ssl.OPENSSL_VERSION + + setuptools_version = get_installed_version("setuptools") + if setuptools_version is not None: + data["setuptools_version"] = setuptools_version + + # Use None rather than False so as not to give the impression that + # pip knows it is not being run under CI. Rather, it is a null or + # inconclusive result. Also, we include some value rather than no + # value to make it easier to know that the check has been run. + data["ci"] = True if looks_like_ci() else None + + user_data = os.environ.get("PIP_USER_AGENT_USER_DATA") + if user_data is not None: + data["user_data"] = user_data + + return "{data[installer][name]}/{data[installer][version]} {json}".format( + data=data, + json=json.dumps(data, separators=(",", ":"), sort_keys=True), + ) + + +def _get_keyring_auth(url, username): + """Return the tuple auth for a given url from keyring.""" + if not url or not keyring: + return None + + try: + try: + get_credential = keyring.get_credential + except AttributeError: + pass + else: + logger.debug("Getting credentials from keyring for %s", url) + cred = get_credential(url, username) + if cred is not None: + return cred.username, cred.password + return None + + if username: + logger.debug("Getting password from keyring for %s", url) + password = keyring.get_password(url, username) + if password: + return username, password + + except Exception as exc: + logger.warning("Keyring is skipped due to an exception: %s", + str(exc)) + + +class MultiDomainBasicAuth(AuthBase): + + def __init__(self, prompting=True, index_urls=None): + # type: (bool, Optional[Values]) -> None + self.prompting = prompting + self.index_urls = index_urls + self.passwords = {} # type: Dict[str, AuthInfo] + # When the user is prompted to enter credentials and keyring is + # available, we will offer to save them. If the user accepts, + # this value is set to the credentials they entered. After the + # request authenticates, the caller should call + # ``save_credentials`` to save these. + self._credentials_to_save = None # type: Optional[Credentials] + + def _get_index_url(self, url): + """Return the original index URL matching the requested URL. + + Cached or dynamically generated credentials may work against + the original index URL rather than just the netloc. + + The provided url should have had its username and password + removed already. If the original index url had credentials then + they will be included in the return value. + + Returns None if no matching index was found, or if --no-index + was specified by the user. + """ + if not url or not self.index_urls: + return None + + for u in self.index_urls: + prefix = remove_auth_from_url(u).rstrip("/") + "/" + if url.startswith(prefix): + return u + + def _get_new_credentials(self, original_url, allow_netrc=True, + allow_keyring=True): + """Find and return credentials for the specified URL.""" + # Split the credentials and netloc from the url. + url, netloc, url_user_password = split_auth_netloc_from_url( + original_url) + + # Start with the credentials embedded in the url + username, password = url_user_password + if username is not None and password is not None: + logger.debug("Found credentials in url for %s", netloc) + return url_user_password + + # Find a matching index url for this request + index_url = self._get_index_url(url) + if index_url: + # Split the credentials from the url. + index_info = split_auth_netloc_from_url(index_url) + if index_info: + index_url, _, index_url_user_password = index_info + logger.debug("Found index url %s", index_url) + + # If an index URL was found, try its embedded credentials + if index_url and index_url_user_password[0] is not None: + username, password = index_url_user_password + if username is not None and password is not None: + logger.debug("Found credentials in index url for %s", netloc) + return index_url_user_password + + # Get creds from netrc if we still don't have them + if allow_netrc: + netrc_auth = get_netrc_auth(original_url) + if netrc_auth: + logger.debug("Found credentials in netrc for %s", netloc) + return netrc_auth + + # If we don't have a password and keyring is available, use it. + if allow_keyring: + # The index url is more specific than the netloc, so try it first + kr_auth = (_get_keyring_auth(index_url, username) or + _get_keyring_auth(netloc, username)) + if kr_auth: + logger.debug("Found credentials in keyring for %s", netloc) + return kr_auth + + return username, password + + def _get_url_and_credentials(self, original_url): + """Return the credentials to use for the provided URL. + + If allowed, netrc and keyring may be used to obtain the + correct credentials. + + Returns (url_without_credentials, username, password). Note + that even if the original URL contains credentials, this + function may return a different username and password. + """ + url, netloc, _ = split_auth_netloc_from_url(original_url) + + # Use any stored credentials that we have for this netloc + username, password = self.passwords.get(netloc, (None, None)) + + if username is None and password is None: + # No stored credentials. Acquire new credentials without prompting + # the user. (e.g. from netrc, keyring, or the URL itself) + username, password = self._get_new_credentials(original_url) + + if username is not None or password is not None: + # Convert the username and password if they're None, so that + # this netloc will show up as "cached" in the conditional above. + # Further, HTTPBasicAuth doesn't accept None, so it makes sense to + # cache the value that is going to be used. + username = username or "" + password = password or "" + + # Store any acquired credentials. + self.passwords[netloc] = (username, password) + + assert ( + # Credentials were found + (username is not None and password is not None) or + # Credentials were not found + (username is None and password is None) + ), "Could not load credentials from url: {}".format(original_url) + + return url, username, password + + def __call__(self, req): + # Get credentials for this request + url, username, password = self._get_url_and_credentials(req.url) + + # Set the url of the request to the url without any credentials + req.url = url + + if username is not None and password is not None: + # Send the basic auth with this request + req = HTTPBasicAuth(username, password)(req) + + # Attach a hook to handle 401 responses + req.register_hook("response", self.handle_401) + + return req + + # Factored out to allow for easy patching in tests + def _prompt_for_password(self, netloc): + username = ask_input("User for %s: " % netloc) + if not username: + return None, None + auth = _get_keyring_auth(netloc, username) + if auth: + return auth[0], auth[1], False + password = ask_password("Password: ") + return username, password, True + + # Factored out to allow for easy patching in tests + def _should_save_password_to_keyring(self): + if not keyring: + return False + return ask("Save credentials to keyring [y/N]: ", ["y", "n"]) == "y" + + def handle_401(self, resp, **kwargs): + # We only care about 401 responses, anything else we want to just + # pass through the actual response + if resp.status_code != 401: + return resp + + # We are not able to prompt the user so simply return the response + if not self.prompting: + return resp + + parsed = urllib_parse.urlparse(resp.url) + + # Prompt the user for a new username and password + username, password, save = self._prompt_for_password(parsed.netloc) + + # Store the new username and password to use for future requests + self._credentials_to_save = None + if username is not None and password is not None: + self.passwords[parsed.netloc] = (username, password) + + # Prompt to save the password to keyring + if save and self._should_save_password_to_keyring(): + self._credentials_to_save = (parsed.netloc, username, password) + + # Consume content and release the original connection to allow our new + # request to reuse the same one. + resp.content + resp.raw.release_conn() + + # Add our new username and password to the request + req = HTTPBasicAuth(username or "", password or "")(resp.request) + req.register_hook("response", self.warn_on_401) + + # On successful request, save the credentials that were used to + # keyring. (Note that if the user responded "no" above, this member + # is not set and nothing will be saved.) + if self._credentials_to_save: + req.register_hook("response", self.save_credentials) + + # Send our new request + new_resp = resp.connection.send(req, **kwargs) + new_resp.history.append(resp) + + return new_resp + + def warn_on_401(self, resp, **kwargs): + """Response callback to warn about incorrect credentials.""" + if resp.status_code == 401: + logger.warning('401 Error, Credentials not correct for %s', + resp.request.url) + + def save_credentials(self, resp, **kwargs): + """Response callback to save credentials on success.""" + assert keyring is not None, "should never reach here without keyring" + if not keyring: + return + + creds = self._credentials_to_save + self._credentials_to_save = None + if creds and resp.status_code < 400: + try: + logger.info('Saving credentials to keyring') + keyring.set_password(*creds) + except Exception: + logger.exception('Failed to save credentials') + + +class LocalFSAdapter(BaseAdapter): + + def send(self, request, stream=None, timeout=None, verify=None, cert=None, + proxies=None): + pathname = url_to_path(request.url) + + resp = Response() + resp.status_code = 200 + resp.url = request.url + + try: + stats = os.stat(pathname) + except OSError as exc: + resp.status_code = 404 + resp.raw = exc + else: + modified = email.utils.formatdate(stats.st_mtime, usegmt=True) + content_type = mimetypes.guess_type(pathname)[0] or "text/plain" + resp.headers = CaseInsensitiveDict({ + "Content-Type": content_type, + "Content-Length": stats.st_size, + "Last-Modified": modified, + }) + + resp.raw = open(pathname, "rb") + resp.close = resp.raw.close + + return resp + + def close(self): + pass + + +class SafeFileCache(FileCache): + """ + A file based cache which is safe to use even when the target directory may + not be accessible or writable. + """ + + def __init__(self, *args, **kwargs): + super(SafeFileCache, self).__init__(*args, **kwargs) + + # Check to ensure that the directory containing our cache directory + # is owned by the user current executing pip. If it does not exist + # we will check the parent directory until we find one that does exist. + # If it is not owned by the user executing pip then we will disable + # the cache and log a warning. + if not check_path_owner(self.directory): + logger.warning( + "The directory '%s' or its parent directory is not owned by " + "the current user and the cache has been disabled. Please " + "check the permissions and owner of that directory. If " + "executing pip with sudo, you may want sudo's -H flag.", + self.directory, + ) + + # Set our directory to None to disable the Cache + self.directory = None + + def get(self, *args, **kwargs): + # If we don't have a directory, then the cache should be a no-op. + if self.directory is None: + return + + try: + return super(SafeFileCache, self).get(*args, **kwargs) + except (LockError, OSError, IOError): + # We intentionally silence this error, if we can't access the cache + # then we can just skip caching and process the request as if + # caching wasn't enabled. + pass + + def set(self, *args, **kwargs): + # If we don't have a directory, then the cache should be a no-op. + if self.directory is None: + return + + try: + return super(SafeFileCache, self).set(*args, **kwargs) + except (LockError, OSError, IOError): + # We intentionally silence this error, if we can't access the cache + # then we can just skip caching and process the request as if + # caching wasn't enabled. + pass + + def delete(self, *args, **kwargs): + # If we don't have a directory, then the cache should be a no-op. + if self.directory is None: + return + + try: + return super(SafeFileCache, self).delete(*args, **kwargs) + except (LockError, OSError, IOError): + # We intentionally silence this error, if we can't access the cache + # then we can just skip caching and process the request as if + # caching wasn't enabled. + pass + + +class InsecureHTTPAdapter(HTTPAdapter): + + def cert_verify(self, conn, url, verify, cert): + conn.cert_reqs = 'CERT_NONE' + conn.ca_certs = None + + +class PipSession(requests.Session): + + timeout = None # type: Optional[int] + + def __init__(self, *args, **kwargs): + retries = kwargs.pop("retries", 0) + cache = kwargs.pop("cache", None) + insecure_hosts = kwargs.pop("insecure_hosts", []) + index_urls = kwargs.pop("index_urls", None) + + super(PipSession, self).__init__(*args, **kwargs) + + # Attach our User Agent to the request + self.headers["User-Agent"] = user_agent() + + # Attach our Authentication handler to the session + self.auth = MultiDomainBasicAuth(index_urls=index_urls) + + # Create our urllib3.Retry instance which will allow us to customize + # how we handle retries. + retries = urllib3.Retry( + # Set the total number of retries that a particular request can + # have. + total=retries, + + # A 503 error from PyPI typically means that the Fastly -> Origin + # connection got interrupted in some way. A 503 error in general + # is typically considered a transient error so we'll go ahead and + # retry it. + # A 500 may indicate transient error in Amazon S3 + # A 520 or 527 - may indicate transient error in CloudFlare + status_forcelist=[500, 503, 520, 527], + + # Add a small amount of back off between failed requests in + # order to prevent hammering the service. + backoff_factor=0.25, + ) + + # We want to _only_ cache responses on securely fetched origins. We do + # this because we can't validate the response of an insecurely fetched + # origin, and we don't want someone to be able to poison the cache and + # require manual eviction from the cache to fix it. + if cache: + secure_adapter = CacheControlAdapter( + cache=SafeFileCache(cache, use_dir_lock=True), + max_retries=retries, + ) + else: + secure_adapter = HTTPAdapter(max_retries=retries) + + # Our Insecure HTTPAdapter disables HTTPS validation. It does not + # support caching (see above) so we'll use it for all http:// URLs as + # well as any https:// host that we've marked as ignoring TLS errors + # for. + insecure_adapter = InsecureHTTPAdapter(max_retries=retries) + # Save this for later use in add_insecure_host(). + self._insecure_adapter = insecure_adapter + + self.mount("https://", secure_adapter) + self.mount("http://", insecure_adapter) + + # Enable file:// urls + self.mount("file://", LocalFSAdapter()) + + # We want to use a non-validating adapter for any requests which are + # deemed insecure. + for host in insecure_hosts: + self.add_insecure_host(host) + + def add_insecure_host(self, host): + # type: (str) -> None + self.mount('https://{}/'.format(host), self._insecure_adapter) + + def request(self, method, url, *args, **kwargs): + # Allow setting a default timeout on a session + kwargs.setdefault("timeout", self.timeout) + + # Dispatch the actual request + return super(PipSession, self).request(method, url, *args, **kwargs) + + +def get_file_content(url, comes_from=None, session=None): + # type: (str, Optional[str], Optional[PipSession]) -> Tuple[str, Text] + """Gets the content of a file; it may be a filename, file: URL, or + http: URL. Returns (location, content). Content is unicode. + + :param url: File path or url. + :param comes_from: Origin description of requirements. + :param session: Instance of pip.download.PipSession. + """ + if session is None: + raise TypeError( + "get_file_content() missing 1 required keyword argument: 'session'" + ) + + match = _scheme_re.search(url) + if match: + scheme = match.group(1).lower() + if (scheme == 'file' and comes_from and + comes_from.startswith('http')): + raise InstallationError( + 'Requirements file %s references URL %s, which is local' + % (comes_from, url)) + if scheme == 'file': + path = url.split(':', 1)[1] + path = path.replace('\\', '/') + match = _url_slash_drive_re.match(path) + if match: + path = match.group(1) + ':' + path.split('|', 1)[1] + path = urllib_parse.unquote(path) + if path.startswith('/'): + path = '/' + path.lstrip('/') + url = path + else: + # FIXME: catch some errors + resp = session.get(url) + resp.raise_for_status() + return resp.url, resp.text + try: + with open(url, 'rb') as f: + content = auto_decode(f.read()) + except IOError as exc: + raise InstallationError( + 'Could not open requirements file: %s' % str(exc) + ) + return url, content + + +_scheme_re = re.compile(r'^(http|https|file):', re.I) +_url_slash_drive_re = re.compile(r'/*([a-z])\|', re.I) + + +def is_url(name): + # type: (Union[str, Text]) -> bool + """Returns true if the name looks like a URL""" + if ':' not in name: + return False + scheme = name.split(':', 1)[0].lower() + return scheme in ['http', 'https', 'file', 'ftp'] + vcs.all_schemes + + +def url_to_path(url): + # type: (str) -> str + """ + Convert a file: URL to a path. + """ + assert url.startswith('file:'), ( + "You can only turn file: urls into filenames (not %r)" % url) + + _, netloc, path, _, _ = urllib_parse.urlsplit(url) + + if not netloc or netloc == 'localhost': + # According to RFC 8089, same as empty authority. + netloc = '' + elif sys.platform == 'win32': + # If we have a UNC path, prepend UNC share notation. + netloc = '\\\\' + netloc + else: + raise ValueError( + 'non-local file URIs are not supported on this platform: %r' + % url + ) + + path = urllib_request.url2pathname(netloc + path) + return path + + +def is_archive_file(name): + # type: (str) -> bool + """Return True if `name` is a considered as an archive file.""" + ext = splitext(name)[1].lower() + if ext in ARCHIVE_EXTENSIONS: + return True + return False + + +def unpack_vcs_link(link, location): + vcs_backend = _get_used_vcs_backend(link) + vcs_backend.unpack(location, url=link.url) + + +def _get_used_vcs_backend(link): + # type: (Link) -> Optional[VersionControl] + """ + Return a VersionControl object or None. + """ + for vcs_backend in vcs.backends: + if link.scheme in vcs_backend.schemes: + return vcs_backend + return None + + +def is_vcs_url(link): + # type: (Link) -> bool + return bool(_get_used_vcs_backend(link)) + + +def is_file_url(link): + # type: (Link) -> bool + return link.url.lower().startswith('file:') + + +def is_dir_url(link): + # type: (Link) -> bool + """Return whether a file:// Link points to a directory. + + ``link`` must not have any other scheme but file://. Call is_file_url() + first. + + """ + link_path = url_to_path(link.url_without_fragment) + return os.path.isdir(link_path) + + +def _progress_indicator(iterable, *args, **kwargs): + return iterable + + +def _download_url( + resp, # type: Response + link, # type: Link + content_file, # type: IO + hashes, # type: Optional[Hashes] + progress_bar # type: str +): + # type: (...) -> None + try: + total_length = int(resp.headers['content-length']) + except (ValueError, KeyError, TypeError): + total_length = 0 + + cached_resp = getattr(resp, "from_cache", False) + if logger.getEffectiveLevel() > logging.INFO: + show_progress = False + elif cached_resp: + show_progress = False + elif total_length > (40 * 1000): + show_progress = True + elif not total_length: + show_progress = True + else: + show_progress = False + + show_url = link.show_url + + def resp_read(chunk_size): + try: + # Special case for urllib3. + for chunk in resp.raw.stream( + chunk_size, + # We use decode_content=False here because we don't + # want urllib3 to mess with the raw bytes we get + # from the server. If we decompress inside of + # urllib3 then we cannot verify the checksum + # because the checksum will be of the compressed + # file. This breakage will only occur if the + # server adds a Content-Encoding header, which + # depends on how the server was configured: + # - Some servers will notice that the file isn't a + # compressible file and will leave the file alone + # and with an empty Content-Encoding + # - Some servers will notice that the file is + # already compressed and will leave the file + # alone and will add a Content-Encoding: gzip + # header + # - Some servers won't notice anything at all and + # will take a file that's already been compressed + # and compress it again and set the + # Content-Encoding: gzip header + # + # By setting this not to decode automatically we + # hope to eliminate problems with the second case. + decode_content=False): + yield chunk + except AttributeError: + # Standard file-like object. + while True: + chunk = resp.raw.read(chunk_size) + if not chunk: + break + yield chunk + + def written_chunks(chunks): + for chunk in chunks: + content_file.write(chunk) + yield chunk + + progress_indicator = _progress_indicator + + if link.netloc == PyPI.netloc: + url = show_url + else: + url = link.url_without_fragment + + if show_progress: # We don't show progress on cached responses + progress_indicator = DownloadProgressProvider(progress_bar, + max=total_length) + if total_length: + logger.info("Downloading %s (%s)", url, format_size(total_length)) + else: + logger.info("Downloading %s", url) + elif cached_resp: + logger.info("Using cached %s", url) + else: + logger.info("Downloading %s", url) + + logger.debug('Downloading from URL %s', link) + + downloaded_chunks = written_chunks( + progress_indicator( + resp_read(CONTENT_CHUNK_SIZE), + CONTENT_CHUNK_SIZE + ) + ) + if hashes: + hashes.check_against_chunks(downloaded_chunks) + else: + consume(downloaded_chunks) + + +def _copy_file(filename, location, link): + copy = True + download_location = os.path.join(location, link.filename) + if os.path.exists(download_location): + response = ask_path_exists( + 'The file %s exists. (i)gnore, (w)ipe, (b)ackup, (a)abort' % + display_path(download_location), ('i', 'w', 'b', 'a')) + if response == 'i': + copy = False + elif response == 'w': + logger.warning('Deleting %s', display_path(download_location)) + os.remove(download_location) + elif response == 'b': + dest_file = backup_dir(download_location) + logger.warning( + 'Backing up %s to %s', + display_path(download_location), + display_path(dest_file), + ) + shutil.move(download_location, dest_file) + elif response == 'a': + sys.exit(-1) + if copy: + shutil.copy(filename, download_location) + logger.info('Saved %s', display_path(download_location)) + + +def unpack_http_url( + link, # type: Link + location, # type: str + download_dir=None, # type: Optional[str] + session=None, # type: Optional[PipSession] + hashes=None, # type: Optional[Hashes] + progress_bar="on" # type: str +): + # type: (...) -> None + if session is None: + raise TypeError( + "unpack_http_url() missing 1 required keyword argument: 'session'" + ) + + with TempDirectory(kind="unpack") as temp_dir: + # If a download dir is specified, is the file already downloaded there? + already_downloaded_path = None + if download_dir: + already_downloaded_path = _check_download_dir(link, + download_dir, + hashes) + + if already_downloaded_path: + from_path = already_downloaded_path + content_type = mimetypes.guess_type(from_path)[0] + else: + # let's download to a tmp dir + from_path, content_type = _download_http_url(link, + session, + temp_dir.path, + hashes, + progress_bar) + + # unpack the archive to the build dir location. even when only + # downloading archives, they have to be unpacked to parse dependencies + unpack_file(from_path, location, content_type, link) + + # a download dir is specified; let's copy the archive there + if download_dir and not already_downloaded_path: + _copy_file(from_path, download_dir, link) + + if not already_downloaded_path: + os.unlink(from_path) + + +def unpack_file_url( + link, # type: Link + location, # type: str + download_dir=None, # type: Optional[str] + hashes=None # type: Optional[Hashes] +): + # type: (...) -> None + """Unpack link into location. + + If download_dir is provided and link points to a file, make a copy + of the link file inside download_dir. + """ + link_path = url_to_path(link.url_without_fragment) + + # If it's a url to a local directory + if is_dir_url(link): + if os.path.isdir(location): + rmtree(location) + shutil.copytree(link_path, location, symlinks=True) + if download_dir: + logger.info('Link is a directory, ignoring download_dir') + return + + # If --require-hashes is off, `hashes` is either empty, the + # link's embedded hash, or MissingHashes; it is required to + # match. If --require-hashes is on, we are satisfied by any + # hash in `hashes` matching: a URL-based or an option-based + # one; no internet-sourced hash will be in `hashes`. + if hashes: + hashes.check_against_path(link_path) + + # If a download dir is specified, is the file already there and valid? + already_downloaded_path = None + if download_dir: + already_downloaded_path = _check_download_dir(link, + download_dir, + hashes) + + if already_downloaded_path: + from_path = already_downloaded_path + else: + from_path = link_path + + content_type = mimetypes.guess_type(from_path)[0] + + # unpack the archive to the build dir location. even when only downloading + # archives, they have to be unpacked to parse dependencies + unpack_file(from_path, location, content_type, link) + + # a download dir is specified and not already downloaded + if download_dir and not already_downloaded_path: + _copy_file(from_path, download_dir, link) + + +class PipXmlrpcTransport(xmlrpc_client.Transport): + """Provide a `xmlrpclib.Transport` implementation via a `PipSession` + object. + """ + + def __init__(self, index_url, session, use_datetime=False): + xmlrpc_client.Transport.__init__(self, use_datetime) + index_parts = urllib_parse.urlparse(index_url) + self._scheme = index_parts.scheme + self._session = session + + def request(self, host, handler, request_body, verbose=False): + parts = (self._scheme, host, handler, None, None, None) + url = urllib_parse.urlunparse(parts) + try: + headers = {'Content-Type': 'text/xml'} + response = self._session.post(url, data=request_body, + headers=headers, stream=True) + response.raise_for_status() + self.verbose = verbose + return self.parse_response(response.raw) + except requests.HTTPError as exc: + logger.critical( + "HTTP error %s while getting %s", + exc.response.status_code, url, + ) + raise + + +def unpack_url( + link, # type: Link + location, # type: str + download_dir=None, # type: Optional[str] + only_download=False, # type: bool + session=None, # type: Optional[PipSession] + hashes=None, # type: Optional[Hashes] + progress_bar="on" # type: str +): + # type: (...) -> None + """Unpack link. + If link is a VCS link: + if only_download, export into download_dir and ignore location + else unpack into location + for other types of link: + - unpack into location + - if download_dir, copy the file into download_dir + - if only_download, mark location for deletion + + :param hashes: A Hashes object, one of whose embedded hashes must match, + or HashMismatch will be raised. If the Hashes is empty, no matches are + required, and unhashable types of requirements (like VCS ones, which + would ordinarily raise HashUnsupported) are allowed. + """ + # non-editable vcs urls + if is_vcs_url(link): + unpack_vcs_link(link, location) + + # file urls + elif is_file_url(link): + unpack_file_url(link, location, download_dir, hashes=hashes) + + # http urls + else: + if session is None: + session = PipSession() + + unpack_http_url( + link, + location, + download_dir, + session, + hashes=hashes, + progress_bar=progress_bar + ) + if only_download: + write_delete_marker_file(location) + + +def sanitize_content_filename(filename): + # type: (str) -> str + """ + Sanitize the "filename" value from a Content-Disposition header. + """ + return os.path.basename(filename) + + +def parse_content_disposition(content_disposition, default_filename): + # type: (str, str) -> str + """ + Parse the "filename" value from a Content-Disposition header, and + return the default filename if the result is empty. + """ + _type, params = cgi.parse_header(content_disposition) + filename = params.get('filename') + if filename: + # We need to sanitize the filename to prevent directory traversal + # in case the filename contains ".." path parts. + filename = sanitize_content_filename(filename) + return filename or default_filename + + +def _download_http_url( + link, # type: Link + session, # type: PipSession + temp_dir, # type: str + hashes, # type: Optional[Hashes] + progress_bar # type: str +): + # type: (...) -> Tuple[str, str] + """Download link url into temp_dir using provided session""" + target_url = link.url.split('#', 1)[0] + try: + resp = session.get( + target_url, + # We use Accept-Encoding: identity here because requests + # defaults to accepting compressed responses. This breaks in + # a variety of ways depending on how the server is configured. + # - Some servers will notice that the file isn't a compressible + # file and will leave the file alone and with an empty + # Content-Encoding + # - Some servers will notice that the file is already + # compressed and will leave the file alone and will add a + # Content-Encoding: gzip header + # - Some servers won't notice anything at all and will take + # a file that's already been compressed and compress it again + # and set the Content-Encoding: gzip header + # By setting this to request only the identity encoding We're + # hoping to eliminate the third case. Hopefully there does not + # exist a server which when given a file will notice it is + # already compressed and that you're not asking for a + # compressed file and will then decompress it before sending + # because if that's the case I don't think it'll ever be + # possible to make this work. + headers={"Accept-Encoding": "identity"}, + stream=True, + ) + resp.raise_for_status() + except requests.HTTPError as exc: + logger.critical( + "HTTP error %s while getting %s", exc.response.status_code, link, + ) + raise + + content_type = resp.headers.get('content-type', '') + filename = link.filename # fallback + # Have a look at the Content-Disposition header for a better guess + content_disposition = resp.headers.get('content-disposition') + if content_disposition: + filename = parse_content_disposition(content_disposition, filename) + ext = splitext(filename)[1] # type: Optional[str] + if not ext: + ext = mimetypes.guess_extension(content_type) + if ext: + filename += ext + if not ext and link.url != resp.url: + ext = os.path.splitext(resp.url)[1] + if ext: + filename += ext + file_path = os.path.join(temp_dir, filename) + with open(file_path, 'wb') as content_file: + _download_url(resp, link, content_file, hashes, progress_bar) + return file_path, content_type + + +def _check_download_dir(link, download_dir, hashes): + # type: (Link, str, Optional[Hashes]) -> Optional[str] + """ Check download_dir for previously downloaded file with correct hash + If a correct file is found return its path else None + """ + download_path = os.path.join(download_dir, link.filename) + if os.path.exists(download_path): + # If already downloaded, does its hash match? + logger.info('File was already downloaded %s', download_path) + if hashes: + try: + hashes.check_against_path(download_path) + except HashMismatch: + logger.warning( + 'Previously-downloaded file %s has bad hash. ' + 'Re-downloading.', + download_path + ) + os.unlink(download_path) + return None + return download_path + return None diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/exceptions.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/exceptions.py new file mode 100644 index 0000000..096adcd --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/exceptions.py @@ -0,0 +1,305 @@ +"""Exceptions used throughout package""" +from __future__ import absolute_import + +from itertools import chain, groupby, repeat + +from pip._vendor.six import iteritems + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional + from pip._vendor.pkg_resources import Distribution + from pip._internal.req.req_install import InstallRequirement + + +class PipError(Exception): + """Base pip exception""" + + +class ConfigurationError(PipError): + """General exception in configuration""" + + +class InstallationError(PipError): + """General exception during installation""" + + +class UninstallationError(PipError): + """General exception during uninstallation""" + + +class NoneMetadataError(PipError): + """ + Raised when accessing "METADATA" or "PKG-INFO" metadata for a + pip._vendor.pkg_resources.Distribution object and + `dist.has_metadata('METADATA')` returns True but + `dist.get_metadata('METADATA')` returns None (and similarly for + "PKG-INFO"). + """ + + def __init__(self, dist, metadata_name): + # type: (Distribution, str) -> None + """ + :param dist: A Distribution object. + :param metadata_name: The name of the metadata being accessed + (can be "METADATA" or "PKG-INFO"). + """ + self.dist = dist + self.metadata_name = metadata_name + + def __str__(self): + # type: () -> str + # Use `dist` in the error message because its stringification + # includes more information, like the version and location. + return ( + 'None {} metadata found for distribution: {}'.format( + self.metadata_name, self.dist, + ) + ) + + +class DistributionNotFound(InstallationError): + """Raised when a distribution cannot be found to satisfy a requirement""" + + +class RequirementsFileParseError(InstallationError): + """Raised when a general error occurs parsing a requirements file line.""" + + +class BestVersionAlreadyInstalled(PipError): + """Raised when the most up-to-date version of a package is already + installed.""" + + +class BadCommand(PipError): + """Raised when virtualenv or a command is not found""" + + +class CommandError(PipError): + """Raised when there is an error in command-line arguments""" + + +class PreviousBuildDirError(PipError): + """Raised when there's a previous conflicting build directory""" + + +class InvalidWheelFilename(InstallationError): + """Invalid wheel filename.""" + + +class UnsupportedWheel(InstallationError): + """Unsupported wheel.""" + + +class HashErrors(InstallationError): + """Multiple HashError instances rolled into one for reporting""" + + def __init__(self): + self.errors = [] + + def append(self, error): + self.errors.append(error) + + def __str__(self): + lines = [] + self.errors.sort(key=lambda e: e.order) + for cls, errors_of_cls in groupby(self.errors, lambda e: e.__class__): + lines.append(cls.head) + lines.extend(e.body() for e in errors_of_cls) + if lines: + return '\n'.join(lines) + + def __nonzero__(self): + return bool(self.errors) + + def __bool__(self): + return self.__nonzero__() + + +class HashError(InstallationError): + """ + A failure to verify a package against known-good hashes + + :cvar order: An int sorting hash exception classes by difficulty of + recovery (lower being harder), so the user doesn't bother fretting + about unpinned packages when he has deeper issues, like VCS + dependencies, to deal with. Also keeps error reports in a + deterministic order. + :cvar head: A section heading for display above potentially many + exceptions of this kind + :ivar req: The InstallRequirement that triggered this error. This is + pasted on after the exception is instantiated, because it's not + typically available earlier. + + """ + req = None # type: Optional[InstallRequirement] + head = '' + + def body(self): + """Return a summary of me for display under the heading. + + This default implementation simply prints a description of the + triggering requirement. + + :param req: The InstallRequirement that provoked this error, with + populate_link() having already been called + + """ + return ' %s' % self._requirement_name() + + def __str__(self): + return '%s\n%s' % (self.head, self.body()) + + def _requirement_name(self): + """Return a description of the requirement that triggered me. + + This default implementation returns long description of the req, with + line numbers + + """ + return str(self.req) if self.req else 'unknown package' + + +class VcsHashUnsupported(HashError): + """A hash was provided for a version-control-system-based requirement, but + we don't have a method for hashing those.""" + + order = 0 + head = ("Can't verify hashes for these requirements because we don't " + "have a way to hash version control repositories:") + + +class DirectoryUrlHashUnsupported(HashError): + """A hash was provided for a version-control-system-based requirement, but + we don't have a method for hashing those.""" + + order = 1 + head = ("Can't verify hashes for these file:// requirements because they " + "point to directories:") + + +class HashMissing(HashError): + """A hash was needed for a requirement but is absent.""" + + order = 2 + head = ('Hashes are required in --require-hashes mode, but they are ' + 'missing from some requirements. Here is a list of those ' + 'requirements along with the hashes their downloaded archives ' + 'actually had. Add lines like these to your requirements files to ' + 'prevent tampering. (If you did not enable --require-hashes ' + 'manually, note that it turns on automatically when any package ' + 'has a hash.)') + + def __init__(self, gotten_hash): + """ + :param gotten_hash: The hash of the (possibly malicious) archive we + just downloaded + """ + self.gotten_hash = gotten_hash + + def body(self): + # Dodge circular import. + from pip._internal.utils.hashes import FAVORITE_HASH + + package = None + if self.req: + # In the case of URL-based requirements, display the original URL + # seen in the requirements file rather than the package name, + # so the output can be directly copied into the requirements file. + package = (self.req.original_link if self.req.original_link + # In case someone feeds something downright stupid + # to InstallRequirement's constructor. + else getattr(self.req, 'req', None)) + return ' %s --hash=%s:%s' % (package or 'unknown package', + FAVORITE_HASH, + self.gotten_hash) + + +class HashUnpinned(HashError): + """A requirement had a hash specified but was not pinned to a specific + version.""" + + order = 3 + head = ('In --require-hashes mode, all requirements must have their ' + 'versions pinned with ==. These do not:') + + +class HashMismatch(HashError): + """ + Distribution file hash values don't match. + + :ivar package_name: The name of the package that triggered the hash + mismatch. Feel free to write to this after the exception is raise to + improve its error message. + + """ + order = 4 + head = ('THESE PACKAGES DO NOT MATCH THE HASHES FROM THE REQUIREMENTS ' + 'FILE. If you have updated the package versions, please update ' + 'the hashes. Otherwise, examine the package contents carefully; ' + 'someone may have tampered with them.') + + def __init__(self, allowed, gots): + """ + :param allowed: A dict of algorithm names pointing to lists of allowed + hex digests + :param gots: A dict of algorithm names pointing to hashes we + actually got from the files under suspicion + """ + self.allowed = allowed + self.gots = gots + + def body(self): + return ' %s:\n%s' % (self._requirement_name(), + self._hash_comparison()) + + def _hash_comparison(self): + """ + Return a comparison of actual and expected hash values. + + Example:: + + Expected sha256 abcdeabcdeabcdeabcdeabcdeabcdeabcdeabcdeabcde + or 123451234512345123451234512345123451234512345 + Got bcdefbcdefbcdefbcdefbcdefbcdefbcdefbcdefbcdef + + """ + def hash_then_or(hash_name): + # For now, all the decent hashes have 6-char names, so we can get + # away with hard-coding space literals. + return chain([hash_name], repeat(' or')) + + lines = [] + for hash_name, expecteds in iteritems(self.allowed): + prefix = hash_then_or(hash_name) + lines.extend((' Expected %s %s' % (next(prefix), e)) + for e in expecteds) + lines.append(' Got %s\n' % + self.gots[hash_name].hexdigest()) + prefix = ' or' + return '\n'.join(lines) + + +class UnsupportedPythonVersion(InstallationError): + """Unsupported python version according to Requires-Python package + metadata.""" + + +class ConfigurationFileCouldNotBeLoaded(ConfigurationError): + """When there are errors while loading a configuration file + """ + + def __init__(self, reason="could not be loaded", fname=None, error=None): + super(ConfigurationFileCouldNotBeLoaded, self).__init__(error) + self.reason = reason + self.fname = fname + self.error = error + + def __str__(self): + if self.fname is not None: + message_part = " in {}.".format(self.fname) + else: + assert self.error is not None + message_part = ".\n{}\n".format(self.error.message) + return "Configuration file {}{}".format(self.reason, message_part) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/index.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/index.py new file mode 100644 index 0000000..a1aaad5 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/index.py @@ -0,0 +1,1508 @@ +"""Routines related to PyPI, indexes""" +from __future__ import absolute_import + +import cgi +import itertools +import logging +import mimetypes +import os +import re + +from pip._vendor import html5lib, requests, six +from pip._vendor.distlib.compat import unescape +from pip._vendor.packaging import specifiers +from pip._vendor.packaging.utils import canonicalize_name +from pip._vendor.packaging.version import parse as parse_version +from pip._vendor.requests.exceptions import HTTPError, RetryError, SSLError +from pip._vendor.six.moves.urllib import parse as urllib_parse +from pip._vendor.six.moves.urllib import request as urllib_request + +from pip._internal.download import is_url, url_to_path +from pip._internal.exceptions import ( + BestVersionAlreadyInstalled, DistributionNotFound, InvalidWheelFilename, + UnsupportedWheel, +) +from pip._internal.models.candidate import InstallationCandidate +from pip._internal.models.format_control import FormatControl +from pip._internal.models.link import Link +from pip._internal.models.selection_prefs import SelectionPreferences +from pip._internal.models.target_python import TargetPython +from pip._internal.utils.compat import ipaddress +from pip._internal.utils.logging import indent_log +from pip._internal.utils.misc import ( + ARCHIVE_EXTENSIONS, SUPPORTED_EXTENSIONS, WHEEL_EXTENSION, path_to_url, + redact_password_from_url, +) +from pip._internal.utils.packaging import check_requires_python +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.wheel import Wheel + +if MYPY_CHECK_RUNNING: + from logging import Logger + from typing import ( + Any, Callable, FrozenSet, Iterable, Iterator, List, MutableMapping, + Optional, Sequence, Set, Text, Tuple, Union, + ) + import xml.etree.ElementTree + from pip._vendor.packaging.version import _BaseVersion + from pip._vendor.requests import Response + from pip._internal.models.search_scope import SearchScope + from pip._internal.req import InstallRequirement + from pip._internal.download import PipSession + from pip._internal.pep425tags import Pep425Tag + from pip._internal.utils.hashes import Hashes + + BuildTag = Tuple[Any, ...] # either empty tuple or Tuple[int, str] + CandidateSortingKey = ( + Tuple[int, int, int, _BaseVersion, BuildTag, Optional[int]] + ) + HTMLElement = xml.etree.ElementTree.Element + SecureOrigin = Tuple[str, str, Optional[str]] + + +__all__ = ['FormatControl', 'FoundCandidates', 'PackageFinder'] + + +SECURE_ORIGINS = [ + # protocol, hostname, port + # Taken from Chrome's list of secure origins (See: http://bit.ly/1qrySKC) + ("https", "*", "*"), + ("*", "localhost", "*"), + ("*", "127.0.0.0/8", "*"), + ("*", "::1/128", "*"), + ("file", "*", None), + # ssh is always secure. + ("ssh", "*", "*"), +] # type: List[SecureOrigin] + + +logger = logging.getLogger(__name__) + + +def _match_vcs_scheme(url): + # type: (str) -> Optional[str] + """Look for VCS schemes in the URL. + + Returns the matched VCS scheme, or None if there's no match. + """ + from pip._internal.vcs import vcs + for scheme in vcs.schemes: + if url.lower().startswith(scheme) and url[len(scheme)] in '+:': + return scheme + return None + + +def _is_url_like_archive(url): + # type: (str) -> bool + """Return whether the URL looks like an archive. + """ + filename = Link(url).filename + for bad_ext in ARCHIVE_EXTENSIONS: + if filename.endswith(bad_ext): + return True + return False + + +class _NotHTML(Exception): + def __init__(self, content_type, request_desc): + # type: (str, str) -> None + super(_NotHTML, self).__init__(content_type, request_desc) + self.content_type = content_type + self.request_desc = request_desc + + +def _ensure_html_header(response): + # type: (Response) -> None + """Check the Content-Type header to ensure the response contains HTML. + + Raises `_NotHTML` if the content type is not text/html. + """ + content_type = response.headers.get("Content-Type", "") + if not content_type.lower().startswith("text/html"): + raise _NotHTML(content_type, response.request.method) + + +class _NotHTTP(Exception): + pass + + +def _ensure_html_response(url, session): + # type: (str, PipSession) -> None + """Send a HEAD request to the URL, and ensure the response contains HTML. + + Raises `_NotHTTP` if the URL is not available for a HEAD request, or + `_NotHTML` if the content type is not text/html. + """ + scheme, netloc, path, query, fragment = urllib_parse.urlsplit(url) + if scheme not in {'http', 'https'}: + raise _NotHTTP() + + resp = session.head(url, allow_redirects=True) + resp.raise_for_status() + + _ensure_html_header(resp) + + +def _get_html_response(url, session): + # type: (str, PipSession) -> Response + """Access an HTML page with GET, and return the response. + + This consists of three parts: + + 1. If the URL looks suspiciously like an archive, send a HEAD first to + check the Content-Type is HTML, to avoid downloading a large file. + Raise `_NotHTTP` if the content type cannot be determined, or + `_NotHTML` if it is not HTML. + 2. Actually perform the request. Raise HTTP exceptions on network failures. + 3. Check the Content-Type header to make sure we got HTML, and raise + `_NotHTML` otherwise. + """ + if _is_url_like_archive(url): + _ensure_html_response(url, session=session) + + logger.debug('Getting page %s', redact_password_from_url(url)) + + resp = session.get( + url, + headers={ + "Accept": "text/html", + # We don't want to blindly returned cached data for + # /simple/, because authors generally expecting that + # twine upload && pip install will function, but if + # they've done a pip install in the last ~10 minutes + # it won't. Thus by setting this to zero we will not + # blindly use any cached data, however the benefit of + # using max-age=0 instead of no-cache, is that we will + # still support conditional requests, so we will still + # minimize traffic sent in cases where the page hasn't + # changed at all, we will just always incur the round + # trip for the conditional GET now instead of only + # once per 10 minutes. + # For more information, please see pypa/pip#5670. + "Cache-Control": "max-age=0", + }, + ) + resp.raise_for_status() + + # The check for archives above only works if the url ends with + # something that looks like an archive. However that is not a + # requirement of an url. Unless we issue a HEAD request on every + # url we cannot know ahead of time for sure if something is HTML + # or not. However we can check after we've downloaded it. + _ensure_html_header(resp) + + return resp + + +def _handle_get_page_fail( + link, # type: Link + reason, # type: Union[str, Exception] + meth=None # type: Optional[Callable[..., None]] +): + # type: (...) -> None + if meth is None: + meth = logger.debug + meth("Could not fetch URL %s: %s - skipping", link, reason) + + +def _get_html_page(link, session=None): + # type: (Link, Optional[PipSession]) -> Optional[HTMLPage] + if session is None: + raise TypeError( + "_get_html_page() missing 1 required keyword argument: 'session'" + ) + + url = link.url.split('#', 1)[0] + + # Check for VCS schemes that do not support lookup as web pages. + vcs_scheme = _match_vcs_scheme(url) + if vcs_scheme: + logger.debug('Cannot look at %s URL %s', vcs_scheme, link) + return None + + # Tack index.html onto file:// URLs that point to directories + scheme, _, path, _, _, _ = urllib_parse.urlparse(url) + if (scheme == 'file' and os.path.isdir(urllib_request.url2pathname(path))): + # add trailing slash if not present so urljoin doesn't trim + # final segment + if not url.endswith('/'): + url += '/' + url = urllib_parse.urljoin(url, 'index.html') + logger.debug(' file: URL is directory, getting %s', url) + + try: + resp = _get_html_response(url, session=session) + except _NotHTTP: + logger.debug( + 'Skipping page %s because it looks like an archive, and cannot ' + 'be checked by HEAD.', link, + ) + except _NotHTML as exc: + logger.debug( + 'Skipping page %s because the %s request got Content-Type: %s', + link, exc.request_desc, exc.content_type, + ) + except HTTPError as exc: + _handle_get_page_fail(link, exc) + except RetryError as exc: + _handle_get_page_fail(link, exc) + except SSLError as exc: + reason = "There was a problem confirming the ssl certificate: " + reason += str(exc) + _handle_get_page_fail(link, reason, meth=logger.info) + except requests.ConnectionError as exc: + _handle_get_page_fail(link, "connection error: %s" % exc) + except requests.Timeout: + _handle_get_page_fail(link, "timed out") + else: + return HTMLPage(resp.content, resp.url, resp.headers) + return None + + +def _check_link_requires_python( + link, # type: Link + version_info, # type: Tuple[int, int, int] + ignore_requires_python=False, # type: bool +): + # type: (...) -> bool + """ + Return whether the given Python version is compatible with a link's + "Requires-Python" value. + + :param version_info: A 3-tuple of ints representing the Python + major-minor-micro version to check. + :param ignore_requires_python: Whether to ignore the "Requires-Python" + value if the given Python version isn't compatible. + """ + try: + is_compatible = check_requires_python( + link.requires_python, version_info=version_info, + ) + except specifiers.InvalidSpecifier: + logger.debug( + "Ignoring invalid Requires-Python (%r) for link: %s", + link.requires_python, link, + ) + else: + if not is_compatible: + version = '.'.join(map(str, version_info)) + if not ignore_requires_python: + logger.debug( + 'Link requires a different Python (%s not in: %r): %s', + version, link.requires_python, link, + ) + return False + + logger.debug( + 'Ignoring failed Requires-Python check (%s not in: %r) ' + 'for link: %s', + version, link.requires_python, link, + ) + + return True + + +class LinkEvaluator(object): + + """ + Responsible for evaluating links for a particular project. + """ + + _py_version_re = re.compile(r'-py([123]\.?[0-9]?)$') + + # Don't include an allow_yanked default value to make sure each call + # site considers whether yanked releases are allowed. This also causes + # that decision to be made explicit in the calling code, which helps + # people when reading the code. + def __init__( + self, + project_name, # type: str + canonical_name, # type: str + formats, # type: FrozenSet + target_python, # type: TargetPython + allow_yanked, # type: bool + ignore_requires_python=None, # type: Optional[bool] + ): + # type: (...) -> None + """ + :param project_name: The user supplied package name. + :param canonical_name: The canonical package name. + :param formats: The formats allowed for this package. Should be a set + with 'binary' or 'source' or both in it. + :param target_python: The target Python interpreter to use when + evaluating link compatibility. This is used, for example, to + check wheel compatibility, as well as when checking the Python + version, e.g. the Python version embedded in a link filename + (or egg fragment) and against an HTML link's optional PEP 503 + "data-requires-python" attribute. + :param allow_yanked: Whether files marked as yanked (in the sense + of PEP 592) are permitted to be candidates for install. + :param ignore_requires_python: Whether to ignore incompatible + PEP 503 "data-requires-python" values in HTML links. Defaults + to False. + """ + if ignore_requires_python is None: + ignore_requires_python = False + + self._allow_yanked = allow_yanked + self._canonical_name = canonical_name + self._ignore_requires_python = ignore_requires_python + self._formats = formats + self._target_python = target_python + + self.project_name = project_name + + def evaluate_link(self, link): + # type: (Link) -> Tuple[bool, Optional[Text]] + """ + Determine whether a link is a candidate for installation. + + :return: A tuple (is_candidate, result), where `result` is (1) a + version string if `is_candidate` is True, and (2) if + `is_candidate` is False, an optional string to log the reason + the link fails to qualify. + """ + version = None + if link.is_yanked and not self._allow_yanked: + reason = link.yanked_reason or '' + # Mark this as a unicode string to prevent "UnicodeEncodeError: + # 'ascii' codec can't encode character" in Python 2 when + # the reason contains non-ascii characters. + return (False, u'yanked for reason: {}'.format(reason)) + + if link.egg_fragment: + egg_info = link.egg_fragment + ext = link.ext + else: + egg_info, ext = link.splitext() + if not ext: + return (False, 'not a file') + if ext not in SUPPORTED_EXTENSIONS: + return (False, 'unsupported archive format: %s' % ext) + if "binary" not in self._formats and ext == WHEEL_EXTENSION: + reason = 'No binaries permitted for %s' % self.project_name + return (False, reason) + if "macosx10" in link.path and ext == '.zip': + return (False, 'macosx10 one') + if ext == WHEEL_EXTENSION: + try: + wheel = Wheel(link.filename) + except InvalidWheelFilename: + return (False, 'invalid wheel filename') + if canonicalize_name(wheel.name) != self._canonical_name: + reason = 'wrong project name (not %s)' % self.project_name + return (False, reason) + + supported_tags = self._target_python.get_tags() + if not wheel.supported(supported_tags): + # Include the wheel's tags in the reason string to + # simplify troubleshooting compatibility issues. + file_tags = wheel.get_formatted_file_tags() + reason = ( + "none of the wheel's tags match: {}".format( + ', '.join(file_tags) + ) + ) + return (False, reason) + + version = wheel.version + + # This should be up by the self.ok_binary check, but see issue 2700. + if "source" not in self._formats and ext != WHEEL_EXTENSION: + return (False, 'No sources permitted for %s' % self.project_name) + + if not version: + version = _extract_version_from_fragment( + egg_info, self._canonical_name, + ) + if not version: + return ( + False, 'Missing project version for %s' % self.project_name, + ) + + match = self._py_version_re.search(version) + if match: + version = version[:match.start()] + py_version = match.group(1) + if py_version != self._target_python.py_version: + return (False, 'Python version is incorrect') + + supports_python = _check_link_requires_python( + link, version_info=self._target_python.py_version_info, + ignore_requires_python=self._ignore_requires_python, + ) + if not supports_python: + # Return None for the reason text to suppress calling + # _log_skipped_link(). + return (False, None) + + logger.debug('Found link %s, version: %s', link, version) + + return (True, version) + + +def filter_unallowed_hashes( + candidates, # type: List[InstallationCandidate] + hashes, # type: Hashes + project_name, # type: str +): + # type: (...) -> List[InstallationCandidate] + """ + Filter out candidates whose hashes aren't allowed, and return a new + list of candidates. + + If at least one candidate has an allowed hash, then all candidates with + either an allowed hash or no hash specified are returned. Otherwise, + the given candidates are returned. + + Including the candidates with no hash specified when there is a match + allows a warning to be logged if there is a more preferred candidate + with no hash specified. Returning all candidates in the case of no + matches lets pip report the hash of the candidate that would otherwise + have been installed (e.g. permitting the user to more easily update + their requirements file with the desired hash). + """ + if not hashes: + logger.debug( + 'Given no hashes to check %s links for project %r: ' + 'discarding no candidates', + len(candidates), + project_name, + ) + # Make sure we're not returning back the given value. + return list(candidates) + + matches_or_no_digest = [] + # Collect the non-matches for logging purposes. + non_matches = [] + match_count = 0 + for candidate in candidates: + link = candidate.link + if not link.has_hash: + pass + elif link.is_hash_allowed(hashes=hashes): + match_count += 1 + else: + non_matches.append(candidate) + continue + + matches_or_no_digest.append(candidate) + + if match_count: + filtered = matches_or_no_digest + else: + # Make sure we're not returning back the given value. + filtered = list(candidates) + + if len(filtered) == len(candidates): + discard_message = 'discarding no candidates' + else: + discard_message = 'discarding {} non-matches:\n {}'.format( + len(non_matches), + '\n '.join(str(candidate.link) for candidate in non_matches) + ) + + logger.debug( + 'Checked %s links for project %r against %s hashes ' + '(%s matches, %s no digest): %s', + len(candidates), + project_name, + hashes.digest_count, + match_count, + len(matches_or_no_digest) - match_count, + discard_message + ) + + return filtered + + +class CandidatePreferences(object): + + """ + Encapsulates some of the preferences for filtering and sorting + InstallationCandidate objects. + """ + + def __init__( + self, + prefer_binary=False, # type: bool + allow_all_prereleases=False, # type: bool + ): + # type: (...) -> None + """ + :param allow_all_prereleases: Whether to allow all pre-releases. + """ + self.allow_all_prereleases = allow_all_prereleases + self.prefer_binary = prefer_binary + + +class CandidateEvaluator(object): + + """ + Responsible for filtering and sorting candidates for installation based + on what tags are valid. + """ + + @classmethod + def create( + cls, + project_name, # type: str + target_python=None, # type: Optional[TargetPython] + prefer_binary=False, # type: bool + allow_all_prereleases=False, # type: bool + specifier=None, # type: Optional[specifiers.BaseSpecifier] + hashes=None, # type: Optional[Hashes] + ): + # type: (...) -> CandidateEvaluator + """Create a CandidateEvaluator object. + + :param target_python: The target Python interpreter to use when + checking compatibility. If None (the default), a TargetPython + object will be constructed from the running Python. + :param hashes: An optional collection of allowed hashes. + """ + if target_python is None: + target_python = TargetPython() + if specifier is None: + specifier = specifiers.SpecifierSet() + + supported_tags = target_python.get_tags() + + return cls( + project_name=project_name, + supported_tags=supported_tags, + specifier=specifier, + prefer_binary=prefer_binary, + allow_all_prereleases=allow_all_prereleases, + hashes=hashes, + ) + + def __init__( + self, + project_name, # type: str + supported_tags, # type: List[Pep425Tag] + specifier, # type: specifiers.BaseSpecifier + prefer_binary=False, # type: bool + allow_all_prereleases=False, # type: bool + hashes=None, # type: Optional[Hashes] + ): + # type: (...) -> None + """ + :param supported_tags: The PEP 425 tags supported by the target + Python in order of preference (most preferred first). + """ + self._allow_all_prereleases = allow_all_prereleases + self._hashes = hashes + self._prefer_binary = prefer_binary + self._project_name = project_name + self._specifier = specifier + self._supported_tags = supported_tags + + def get_applicable_candidates( + self, + candidates, # type: List[InstallationCandidate] + ): + # type: (...) -> List[InstallationCandidate] + """ + Return the applicable candidates from a list of candidates. + """ + # Using None infers from the specifier instead. + allow_prereleases = self._allow_all_prereleases or None + specifier = self._specifier + versions = { + str(v) for v in specifier.filter( + # We turn the version object into a str here because otherwise + # when we're debundled but setuptools isn't, Python will see + # packaging.version.Version and + # pkg_resources._vendor.packaging.version.Version as different + # types. This way we'll use a str as a common data interchange + # format. If we stop using the pkg_resources provided specifier + # and start using our own, we can drop the cast to str(). + (str(c.version) for c in candidates), + prereleases=allow_prereleases, + ) + } + + # Again, converting version to str to deal with debundling. + applicable_candidates = [ + c for c in candidates if str(c.version) in versions + ] + + return filter_unallowed_hashes( + candidates=applicable_candidates, + hashes=self._hashes, + project_name=self._project_name, + ) + + def make_found_candidates( + self, + candidates, # type: List[InstallationCandidate] + ): + # type: (...) -> FoundCandidates + """ + Create and return a `FoundCandidates` instance. + + :param specifier: An optional object implementing `filter` + (e.g. `packaging.specifiers.SpecifierSet`) to filter applicable + versions. + """ + applicable_candidates = self.get_applicable_candidates(candidates) + + return FoundCandidates( + candidates, + applicable_candidates=applicable_candidates, + evaluator=self, + ) + + def _sort_key(self, candidate): + # type: (InstallationCandidate) -> CandidateSortingKey + """ + Function to pass as the `key` argument to a call to sorted() to sort + InstallationCandidates by preference. + + Returns a tuple such that tuples sorting as greater using Python's + default comparison operator are more preferred. + + The preference is as follows: + + First and foremost, candidates with allowed (matching) hashes are + always preferred over candidates without matching hashes. This is + because e.g. if the only candidate with an allowed hash is yanked, + we still want to use that candidate. + + Second, excepting hash considerations, candidates that have been + yanked (in the sense of PEP 592) are always less preferred than + candidates that haven't been yanked. Then: + + If not finding wheels, they are sorted by version only. + If finding wheels, then the sort order is by version, then: + 1. existing installs + 2. wheels ordered via Wheel.support_index_min(self._supported_tags) + 3. source archives + If prefer_binary was set, then all wheels are sorted above sources. + + Note: it was considered to embed this logic into the Link + comparison operators, but then different sdist links + with the same version, would have to be considered equal + """ + valid_tags = self._supported_tags + support_num = len(valid_tags) + build_tag = tuple() # type: BuildTag + binary_preference = 0 + link = candidate.link + if link.is_wheel: + # can raise InvalidWheelFilename + wheel = Wheel(link.filename) + if not wheel.supported(valid_tags): + raise UnsupportedWheel( + "%s is not a supported wheel for this platform. It " + "can't be sorted." % wheel.filename + ) + if self._prefer_binary: + binary_preference = 1 + pri = -(wheel.support_index_min(valid_tags)) + if wheel.build_tag is not None: + match = re.match(r'^(\d+)(.*)$', wheel.build_tag) + build_tag_groups = match.groups() + build_tag = (int(build_tag_groups[0]), build_tag_groups[1]) + else: # sdist + pri = -(support_num) + has_allowed_hash = int(link.is_hash_allowed(self._hashes)) + yank_value = -1 * int(link.is_yanked) # -1 for yanked. + return ( + has_allowed_hash, yank_value, binary_preference, candidate.version, + build_tag, pri, + ) + + def get_best_candidate( + self, + candidates, # type: List[InstallationCandidate] + ): + # type: (...) -> Optional[InstallationCandidate] + """ + Return the best candidate per the instance's sort order, or None if + no candidate is acceptable. + """ + if not candidates: + return None + + best_candidate = max(candidates, key=self._sort_key) + + # Log a warning per PEP 592 if necessary before returning. + link = best_candidate.link + if link.is_yanked: + reason = link.yanked_reason or '' + msg = ( + # Mark this as a unicode string to prevent + # "UnicodeEncodeError: 'ascii' codec can't encode character" + # in Python 2 when the reason contains non-ascii characters. + u'The candidate selected for download or install is a ' + 'yanked version: {candidate}\n' + 'Reason for being yanked: {reason}' + ).format(candidate=best_candidate, reason=reason) + logger.warning(msg) + + return best_candidate + + +class FoundCandidates(object): + """A collection of candidates, returned by `PackageFinder.find_candidates`. + + This class is only intended to be instantiated by CandidateEvaluator's + `make_found_candidates()` method. + """ + + def __init__( + self, + candidates, # type: List[InstallationCandidate] + applicable_candidates, # type: List[InstallationCandidate] + evaluator, # type: CandidateEvaluator + ): + # type: (...) -> None + """ + :param candidates: A sequence of all available candidates found. + :param applicable_candidates: The applicable candidates. + :param evaluator: A CandidateEvaluator object to sort applicable + candidates by order of preference. + """ + self._applicable_candidates = applicable_candidates + self._candidates = candidates + self._evaluator = evaluator + + def iter_all(self): + # type: () -> Iterable[InstallationCandidate] + """Iterate through all candidates. + """ + return iter(self._candidates) + + def iter_applicable(self): + # type: () -> Iterable[InstallationCandidate] + """Iterate through the applicable candidates. + """ + return iter(self._applicable_candidates) + + def get_best(self): + # type: () -> Optional[InstallationCandidate] + """Return the best candidate available, or None if no applicable + candidates are found. + """ + candidates = list(self.iter_applicable()) + return self._evaluator.get_best_candidate(candidates) + + +class PackageFinder(object): + """This finds packages. + + This is meant to match easy_install's technique for looking for + packages, by reading pages and looking for appropriate links. + """ + + def __init__( + self, + search_scope, # type: SearchScope + session, # type: PipSession + target_python, # type: TargetPython + allow_yanked, # type: bool + format_control=None, # type: Optional[FormatControl] + trusted_hosts=None, # type: Optional[List[str]] + candidate_prefs=None, # type: CandidatePreferences + ignore_requires_python=None, # type: Optional[bool] + ): + # type: (...) -> None + """ + This constructor is primarily meant to be used by the create() class + method and from tests. + + :param session: The Session to use to make requests. + :param format_control: A FormatControl object, used to control + the selection of source packages / binary packages when consulting + the index and links. + :param candidate_prefs: Options to use when creating a + CandidateEvaluator object. + """ + if trusted_hosts is None: + trusted_hosts = [] + if candidate_prefs is None: + candidate_prefs = CandidatePreferences() + + format_control = format_control or FormatControl(set(), set()) + + self._allow_yanked = allow_yanked + self._candidate_prefs = candidate_prefs + self._ignore_requires_python = ignore_requires_python + self._target_python = target_python + + self.search_scope = search_scope + self.session = session + self.format_control = format_control + self.trusted_hosts = trusted_hosts + + # These are boring links that have already been logged somehow. + self._logged_links = set() # type: Set[Link] + + # Don't include an allow_yanked default value to make sure each call + # site considers whether yanked releases are allowed. This also causes + # that decision to be made explicit in the calling code, which helps + # people when reading the code. + @classmethod + def create( + cls, + search_scope, # type: SearchScope + selection_prefs, # type: SelectionPreferences + trusted_hosts=None, # type: Optional[List[str]] + session=None, # type: Optional[PipSession] + target_python=None, # type: Optional[TargetPython] + ): + # type: (...) -> PackageFinder + """Create a PackageFinder. + + :param selection_prefs: The candidate selection preferences, as a + SelectionPreferences object. + :param trusted_hosts: Domains not to emit warnings for when not using + HTTPS. + :param session: The Session to use to make requests. + :param target_python: The target Python interpreter to use when + checking compatibility. If None (the default), a TargetPython + object will be constructed from the running Python. + """ + if session is None: + raise TypeError( + "PackageFinder.create() missing 1 required keyword argument: " + "'session'" + ) + if target_python is None: + target_python = TargetPython() + + candidate_prefs = CandidatePreferences( + prefer_binary=selection_prefs.prefer_binary, + allow_all_prereleases=selection_prefs.allow_all_prereleases, + ) + + return cls( + candidate_prefs=candidate_prefs, + search_scope=search_scope, + session=session, + target_python=target_python, + allow_yanked=selection_prefs.allow_yanked, + format_control=selection_prefs.format_control, + trusted_hosts=trusted_hosts, + ignore_requires_python=selection_prefs.ignore_requires_python, + ) + + @property + def find_links(self): + # type: () -> List[str] + return self.search_scope.find_links + + @property + def index_urls(self): + # type: () -> List[str] + return self.search_scope.index_urls + + @property + def allow_all_prereleases(self): + # type: () -> bool + return self._candidate_prefs.allow_all_prereleases + + def set_allow_all_prereleases(self): + # type: () -> None + self._candidate_prefs.allow_all_prereleases = True + + def add_trusted_host(self, host, source=None): + # type: (str, Optional[str]) -> None + """ + :param source: An optional source string, for logging where the host + string came from. + """ + # It is okay to add a previously added host because PipSession stores + # the resulting prefixes in a dict. + msg = 'adding trusted host: {!r}'.format(host) + if source is not None: + msg += ' (from {})'.format(source) + logger.info(msg) + self.session.add_insecure_host(host) + if host in self.trusted_hosts: + return + + self.trusted_hosts.append(host) + + def iter_secure_origins(self): + # type: () -> Iterator[SecureOrigin] + for secure_origin in SECURE_ORIGINS: + yield secure_origin + for host in self.trusted_hosts: + yield ('*', host, '*') + + @staticmethod + def _sort_locations(locations, expand_dir=False): + # type: (Sequence[str], bool) -> Tuple[List[str], List[str]] + """ + Sort locations into "files" (archives) and "urls", and return + a pair of lists (files,urls) + """ + files = [] + urls = [] + + # puts the url for the given file path into the appropriate list + def sort_path(path): + url = path_to_url(path) + if mimetypes.guess_type(url, strict=False)[0] == 'text/html': + urls.append(url) + else: + files.append(url) + + for url in locations: + + is_local_path = os.path.exists(url) + is_file_url = url.startswith('file:') + + if is_local_path or is_file_url: + if is_local_path: + path = url + else: + path = url_to_path(url) + if os.path.isdir(path): + if expand_dir: + path = os.path.realpath(path) + for item in os.listdir(path): + sort_path(os.path.join(path, item)) + elif is_file_url: + urls.append(url) + else: + logger.warning( + "Path '{0}' is ignored: " + "it is a directory.".format(path), + ) + elif os.path.isfile(path): + sort_path(path) + else: + logger.warning( + "Url '%s' is ignored: it is neither a file " + "nor a directory.", url, + ) + elif is_url(url): + # Only add url with clear scheme + urls.append(url) + else: + logger.warning( + "Url '%s' is ignored. It is either a non-existing " + "path or lacks a specific scheme.", url, + ) + + return files, urls + + def _validate_secure_origin(self, logger, location): + # type: (Logger, Link) -> bool + # Determine if this url used a secure transport mechanism + parsed = urllib_parse.urlparse(str(location)) + origin = (parsed.scheme, parsed.hostname, parsed.port) + + # The protocol to use to see if the protocol matches. + # Don't count the repository type as part of the protocol: in + # cases such as "git+ssh", only use "ssh". (I.e., Only verify against + # the last scheme.) + protocol = origin[0].rsplit('+', 1)[-1] + + # Determine if our origin is a secure origin by looking through our + # hardcoded list of secure origins, as well as any additional ones + # configured on this PackageFinder instance. + for secure_origin in self.iter_secure_origins(): + if protocol != secure_origin[0] and secure_origin[0] != "*": + continue + + try: + # We need to do this decode dance to ensure that we have a + # unicode object, even on Python 2.x. + addr = ipaddress.ip_address( + origin[1] + if ( + isinstance(origin[1], six.text_type) or + origin[1] is None + ) + else origin[1].decode("utf8") + ) + network = ipaddress.ip_network( + secure_origin[1] + if isinstance(secure_origin[1], six.text_type) + # setting secure_origin[1] to proper Union[bytes, str] + # creates problems in other places + else secure_origin[1].decode("utf8") # type: ignore + ) + except ValueError: + # We don't have both a valid address or a valid network, so + # we'll check this origin against hostnames. + if (origin[1] and + origin[1].lower() != secure_origin[1].lower() and + secure_origin[1] != "*"): + continue + else: + # We have a valid address and network, so see if the address + # is contained within the network. + if addr not in network: + continue + + # Check to see if the port patches + if (origin[2] != secure_origin[2] and + secure_origin[2] != "*" and + secure_origin[2] is not None): + continue + + # If we've gotten here, then this origin matches the current + # secure origin and we should return True + return True + + # If we've gotten to this point, then the origin isn't secure and we + # will not accept it as a valid location to search. We will however + # log a warning that we are ignoring it. + logger.warning( + "The repository located at %s is not a trusted or secure host and " + "is being ignored. If this repository is available via HTTPS we " + "recommend you use HTTPS instead, otherwise you may silence " + "this warning and allow it anyway with '--trusted-host %s'.", + parsed.hostname, + parsed.hostname, + ) + + return False + + def make_link_evaluator(self, project_name): + # type: (str) -> LinkEvaluator + canonical_name = canonicalize_name(project_name) + formats = self.format_control.get_allowed_formats(canonical_name) + + return LinkEvaluator( + project_name=project_name, + canonical_name=canonical_name, + formats=formats, + target_python=self._target_python, + allow_yanked=self._allow_yanked, + ignore_requires_python=self._ignore_requires_python, + ) + + def find_all_candidates(self, project_name): + # type: (str) -> List[InstallationCandidate] + """Find all available InstallationCandidate for project_name + + This checks index_urls and find_links. + All versions found are returned as an InstallationCandidate list. + + See LinkEvaluator.evaluate_link() for details on which files + are accepted. + """ + search_scope = self.search_scope + index_locations = search_scope.get_index_urls_locations(project_name) + index_file_loc, index_url_loc = self._sort_locations(index_locations) + fl_file_loc, fl_url_loc = self._sort_locations( + self.find_links, expand_dir=True, + ) + + file_locations = (Link(url) for url in itertools.chain( + index_file_loc, fl_file_loc, + )) + + # We trust every url that the user has given us whether it was given + # via --index-url or --find-links. + # We want to filter out any thing which does not have a secure origin. + url_locations = [ + link for link in itertools.chain( + (Link(url) for url in index_url_loc), + (Link(url) for url in fl_url_loc), + ) + if self._validate_secure_origin(logger, link) + ] + + logger.debug('%d location(s) to search for versions of %s:', + len(url_locations), project_name) + + for location in url_locations: + logger.debug('* %s', location) + + link_evaluator = self.make_link_evaluator(project_name) + find_links_versions = self._package_versions( + link_evaluator, + # We trust every directly linked archive in find_links + (Link(url, '-f') for url in self.find_links), + ) + + page_versions = [] + for page in self._get_pages(url_locations, project_name): + logger.debug('Analyzing links from page %s', page.url) + with indent_log(): + page_versions.extend( + self._package_versions(link_evaluator, page.iter_links()) + ) + + file_versions = self._package_versions(link_evaluator, file_locations) + if file_versions: + file_versions.sort(reverse=True) + logger.debug( + 'Local files found: %s', + ', '.join([ + url_to_path(candidate.link.url) + for candidate in file_versions + ]) + ) + + # This is an intentional priority ordering + return file_versions + find_links_versions + page_versions + + def make_candidate_evaluator( + self, + project_name, # type: str + specifier=None, # type: Optional[specifiers.BaseSpecifier] + hashes=None, # type: Optional[Hashes] + ): + # type: (...) -> CandidateEvaluator + """Create a CandidateEvaluator object to use. + """ + candidate_prefs = self._candidate_prefs + return CandidateEvaluator.create( + project_name=project_name, + target_python=self._target_python, + prefer_binary=candidate_prefs.prefer_binary, + allow_all_prereleases=candidate_prefs.allow_all_prereleases, + specifier=specifier, + hashes=hashes, + ) + + def find_candidates( + self, + project_name, # type: str + specifier=None, # type: Optional[specifiers.BaseSpecifier] + hashes=None, # type: Optional[Hashes] + ): + # type: (...) -> FoundCandidates + """Find matches for the given project and specifier. + + :param specifier: An optional object implementing `filter` + (e.g. `packaging.specifiers.SpecifierSet`) to filter applicable + versions. + + :return: A `FoundCandidates` instance. + """ + candidates = self.find_all_candidates(project_name) + candidate_evaluator = self.make_candidate_evaluator( + project_name=project_name, + specifier=specifier, + hashes=hashes, + ) + return candidate_evaluator.make_found_candidates(candidates) + + def find_requirement(self, req, upgrade): + # type: (InstallRequirement, bool) -> Optional[Link] + """Try to find a Link matching req + + Expects req, an InstallRequirement and upgrade, a boolean + Returns a Link if found, + Raises DistributionNotFound or BestVersionAlreadyInstalled otherwise + """ + hashes = req.hashes(trust_internet=False) + candidates = self.find_candidates( + req.name, specifier=req.specifier, hashes=hashes, + ) + best_candidate = candidates.get_best() + + installed_version = None # type: Optional[_BaseVersion] + if req.satisfied_by is not None: + installed_version = parse_version(req.satisfied_by.version) + + def _format_versions(cand_iter): + # This repeated parse_version and str() conversion is needed to + # handle different vendoring sources from pip and pkg_resources. + # If we stop using the pkg_resources provided specifier and start + # using our own, we can drop the cast to str(). + return ", ".join(sorted( + {str(c.version) for c in cand_iter}, + key=parse_version, + )) or "none" + + if installed_version is None and best_candidate is None: + logger.critical( + 'Could not find a version that satisfies the requirement %s ' + '(from versions: %s)', + req, + _format_versions(candidates.iter_all()), + ) + + raise DistributionNotFound( + 'No matching distribution found for %s' % req + ) + + best_installed = False + if installed_version and ( + best_candidate is None or + best_candidate.version <= installed_version): + best_installed = True + + if not upgrade and installed_version is not None: + if best_installed: + logger.debug( + 'Existing installed version (%s) is most up-to-date and ' + 'satisfies requirement', + installed_version, + ) + else: + logger.debug( + 'Existing installed version (%s) satisfies requirement ' + '(most up-to-date version is %s)', + installed_version, + best_candidate.version, + ) + return None + + if best_installed: + # We have an existing version, and its the best version + logger.debug( + 'Installed version (%s) is most up-to-date (past versions: ' + '%s)', + installed_version, + _format_versions(candidates.iter_applicable()), + ) + raise BestVersionAlreadyInstalled + + logger.debug( + 'Using version %s (newest of versions: %s)', + best_candidate.version, + _format_versions(candidates.iter_applicable()), + ) + return best_candidate.link + + def _get_pages(self, locations, project_name): + # type: (Iterable[Link], str) -> Iterable[HTMLPage] + """ + Yields (page, page_url) from the given locations, skipping + locations that have errors. + """ + seen = set() # type: Set[Link] + for location in locations: + if location in seen: + continue + seen.add(location) + + page = _get_html_page(location, session=self.session) + if page is None: + continue + + yield page + + def _sort_links(self, links): + # type: (Iterable[Link]) -> List[Link] + """ + Returns elements of links in order, non-egg links first, egg links + second, while eliminating duplicates + """ + eggs, no_eggs = [], [] + seen = set() # type: Set[Link] + for link in links: + if link not in seen: + seen.add(link) + if link.egg_fragment: + eggs.append(link) + else: + no_eggs.append(link) + return no_eggs + eggs + + def _log_skipped_link(self, link, reason): + # type: (Link, Text) -> None + if link not in self._logged_links: + # Mark this as a unicode string to prevent "UnicodeEncodeError: + # 'ascii' codec can't encode character" in Python 2 when + # the reason contains non-ascii characters. + # Also, put the link at the end so the reason is more visible + # and because the link string is usually very long. + logger.debug(u'Skipping link: %s: %s', reason, link) + self._logged_links.add(link) + + def get_install_candidate(self, link_evaluator, link): + # type: (LinkEvaluator, Link) -> Optional[InstallationCandidate] + """ + If the link is a candidate for install, convert it to an + InstallationCandidate and return it. Otherwise, return None. + """ + is_candidate, result = link_evaluator.evaluate_link(link) + if not is_candidate: + if result: + self._log_skipped_link(link, reason=result) + return None + + return InstallationCandidate( + project=link_evaluator.project_name, + link=link, + # Convert the Text result to str since InstallationCandidate + # accepts str. + version=str(result), + ) + + def _package_versions(self, link_evaluator, links): + # type: (LinkEvaluator, Iterable[Link]) -> List[InstallationCandidate] + result = [] + for link in self._sort_links(links): + candidate = self.get_install_candidate(link_evaluator, link) + if candidate is not None: + result.append(candidate) + return result + + +def _find_name_version_sep(fragment, canonical_name): + # type: (str, str) -> int + """Find the separator's index based on the package's canonical name. + + :param fragment: A + filename "fragment" (stem) or + egg fragment. + :param canonical_name: The package's canonical name. + + This function is needed since the canonicalized name does not necessarily + have the same length as the egg info's name part. An example:: + + >>> fragment = 'foo__bar-1.0' + >>> canonical_name = 'foo-bar' + >>> _find_name_version_sep(fragment, canonical_name) + 8 + """ + # Project name and version must be separated by one single dash. Find all + # occurrences of dashes; if the string in front of it matches the canonical + # name, this is the one separating the name and version parts. + for i, c in enumerate(fragment): + if c != "-": + continue + if canonicalize_name(fragment[:i]) == canonical_name: + return i + raise ValueError("{} does not match {}".format(fragment, canonical_name)) + + +def _extract_version_from_fragment(fragment, canonical_name): + # type: (str, str) -> Optional[str] + """Parse the version string from a + filename + "fragment" (stem) or egg fragment. + + :param fragment: The string to parse. E.g. foo-2.1 + :param canonical_name: The canonicalized name of the package this + belongs to. + """ + try: + version_start = _find_name_version_sep(fragment, canonical_name) + 1 + except ValueError: + return None + version = fragment[version_start:] + if not version: + return None + return version + + +def _determine_base_url(document, page_url): + """Determine the HTML document's base URL. + + This looks for a ```` tag in the HTML document. If present, its href + attribute denotes the base URL of anchor tags in the document. If there is + no such tag (or if it does not have a valid href attribute), the HTML + file's URL is used as the base URL. + + :param document: An HTML document representation. The current + implementation expects the result of ``html5lib.parse()``. + :param page_url: The URL of the HTML document. + """ + for base in document.findall(".//base"): + href = base.get("href") + if href is not None: + return href + return page_url + + +def _get_encoding_from_headers(headers): + """Determine if we have any encoding information in our headers. + """ + if headers and "Content-Type" in headers: + content_type, params = cgi.parse_header(headers["Content-Type"]) + if "charset" in params: + return params['charset'] + return None + + +def _clean_link(url): + # type: (str) -> str + """Makes sure a link is fully encoded. That is, if a ' ' shows up in + the link, it will be rewritten to %20 (while not over-quoting + % or other characters).""" + # Split the URL into parts according to the general structure + # `scheme://netloc/path;parameters?query#fragment`. Note that the + # `netloc` can be empty and the URI will then refer to a local + # filesystem path. + result = urllib_parse.urlparse(url) + # In both cases below we unquote prior to quoting to make sure + # nothing is double quoted. + if result.netloc == "": + # On Windows the path part might contain a drive letter which + # should not be quoted. On Linux where drive letters do not + # exist, the colon should be quoted. We rely on urllib.request + # to do the right thing here. + path = urllib_request.pathname2url( + urllib_request.url2pathname(result.path)) + else: + # In addition to the `/` character we protect `@` so that + # revision strings in VCS URLs are properly parsed. + path = urllib_parse.quote(urllib_parse.unquote(result.path), safe="/@") + return urllib_parse.urlunparse(result._replace(path=path)) + + +def _create_link_from_element( + anchor, # type: HTMLElement + page_url, # type: str + base_url, # type: str +): + # type: (...) -> Optional[Link] + """ + Convert an anchor element in a simple repository page to a Link. + """ + href = anchor.get("href") + if not href: + return None + + url = _clean_link(urllib_parse.urljoin(base_url, href)) + pyrequire = anchor.get('data-requires-python') + pyrequire = unescape(pyrequire) if pyrequire else None + + yanked_reason = anchor.get('data-yanked') + if yanked_reason: + # This is a unicode string in Python 2 (and 3). + yanked_reason = unescape(yanked_reason) + + link = Link( + url, + comes_from=page_url, + requires_python=pyrequire, + yanked_reason=yanked_reason, + ) + + return link + + +class HTMLPage(object): + """Represents one page, along with its URL""" + + def __init__(self, content, url, headers=None): + # type: (bytes, str, MutableMapping[str, str]) -> None + self.content = content + self.url = url + self.headers = headers + + def __str__(self): + return redact_password_from_url(self.url) + + def iter_links(self): + # type: () -> Iterable[Link] + """Yields all links in the page""" + document = html5lib.parse( + self.content, + transport_encoding=_get_encoding_from_headers(self.headers), + namespaceHTMLElements=False, + ) + base_url = _determine_base_url(document, self.url) + for anchor in document.findall(".//a"): + link = _create_link_from_element( + anchor, + page_url=self.url, + base_url=base_url, + ) + if link is None: + continue + yield link diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/legacy_resolve.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/legacy_resolve.py new file mode 100644 index 0000000..1d9229c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/legacy_resolve.py @@ -0,0 +1,457 @@ +"""Dependency Resolution + +The dependency resolution in pip is performed as follows: + +for top-level requirements: + a. only one spec allowed per project, regardless of conflicts or not. + otherwise a "double requirement" exception is raised + b. they override sub-dependency requirements. +for sub-dependencies + a. "first found, wins" (where the order is breadth first) +""" + +import logging +import sys +from collections import defaultdict +from itertools import chain + +from pip._vendor.packaging import specifiers + +from pip._internal.exceptions import ( + BestVersionAlreadyInstalled, DistributionNotFound, HashError, HashErrors, + UnsupportedPythonVersion, +) +from pip._internal.req.constructors import install_req_from_req_string +from pip._internal.utils.logging import indent_log +from pip._internal.utils.misc import ( + dist_in_usersite, ensure_dir, normalize_version_info, +) +from pip._internal.utils.packaging import ( + check_requires_python, get_requires_python, +) +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import DefaultDict, List, Optional, Set, Tuple + from pip._vendor import pkg_resources + + from pip._internal.cache import WheelCache + from pip._internal.distributions import AbstractDistribution + from pip._internal.download import PipSession + from pip._internal.index import PackageFinder + from pip._internal.operations.prepare import RequirementPreparer + from pip._internal.req.req_install import InstallRequirement + from pip._internal.req.req_set import RequirementSet + +logger = logging.getLogger(__name__) + + +def _check_dist_requires_python( + dist, # type: pkg_resources.Distribution + version_info, # type: Tuple[int, int, int] + ignore_requires_python=False, # type: bool +): + # type: (...) -> None + """ + Check whether the given Python version is compatible with a distribution's + "Requires-Python" value. + + :param version_info: A 3-tuple of ints representing the Python + major-minor-micro version to check. + :param ignore_requires_python: Whether to ignore the "Requires-Python" + value if the given Python version isn't compatible. + + :raises UnsupportedPythonVersion: When the given Python version isn't + compatible. + """ + requires_python = get_requires_python(dist) + try: + is_compatible = check_requires_python( + requires_python, version_info=version_info, + ) + except specifiers.InvalidSpecifier as exc: + logger.warning( + "Package %r has an invalid Requires-Python: %s", + dist.project_name, exc, + ) + return + + if is_compatible: + return + + version = '.'.join(map(str, version_info)) + if ignore_requires_python: + logger.debug( + 'Ignoring failed Requires-Python check for package %r: ' + '%s not in %r', + dist.project_name, version, requires_python, + ) + return + + raise UnsupportedPythonVersion( + 'Package {!r} requires a different Python: {} not in {!r}'.format( + dist.project_name, version, requires_python, + )) + + +class Resolver(object): + """Resolves which packages need to be installed/uninstalled to perform \ + the requested operation without breaking the requirements of any package. + """ + + _allowed_strategies = {"eager", "only-if-needed", "to-satisfy-only"} + + def __init__( + self, + preparer, # type: RequirementPreparer + session, # type: PipSession + finder, # type: PackageFinder + wheel_cache, # type: Optional[WheelCache] + use_user_site, # type: bool + ignore_dependencies, # type: bool + ignore_installed, # type: bool + ignore_requires_python, # type: bool + force_reinstall, # type: bool + isolated, # type: bool + upgrade_strategy, # type: str + use_pep517=None, # type: Optional[bool] + py_version_info=None, # type: Optional[Tuple[int, ...]] + ): + # type: (...) -> None + super(Resolver, self).__init__() + assert upgrade_strategy in self._allowed_strategies + + if py_version_info is None: + py_version_info = sys.version_info[:3] + else: + py_version_info = normalize_version_info(py_version_info) + + self._py_version_info = py_version_info + + self.preparer = preparer + self.finder = finder + self.session = session + + # NOTE: This would eventually be replaced with a cache that can give + # information about both sdist and wheels transparently. + self.wheel_cache = wheel_cache + + # This is set in resolve + self.require_hashes = None # type: Optional[bool] + + self.upgrade_strategy = upgrade_strategy + self.force_reinstall = force_reinstall + self.isolated = isolated + self.ignore_dependencies = ignore_dependencies + self.ignore_installed = ignore_installed + self.ignore_requires_python = ignore_requires_python + self.use_user_site = use_user_site + self.use_pep517 = use_pep517 + + self._discovered_dependencies = \ + defaultdict(list) # type: DefaultDict[str, List] + + def resolve(self, requirement_set): + # type: (RequirementSet) -> None + """Resolve what operations need to be done + + As a side-effect of this method, the packages (and their dependencies) + are downloaded, unpacked and prepared for installation. This + preparation is done by ``pip.operations.prepare``. + + Once PyPI has static dependency metadata available, it would be + possible to move the preparation to become a step separated from + dependency resolution. + """ + # make the wheelhouse + if self.preparer.wheel_download_dir: + ensure_dir(self.preparer.wheel_download_dir) + + # If any top-level requirement has a hash specified, enter + # hash-checking mode, which requires hashes from all. + root_reqs = ( + requirement_set.unnamed_requirements + + list(requirement_set.requirements.values()) + ) + self.require_hashes = ( + requirement_set.require_hashes or + any(req.has_hash_options for req in root_reqs) + ) + + # Display where finder is looking for packages + search_scope = self.finder.search_scope + locations = search_scope.get_formatted_locations() + if locations: + logger.info(locations) + + # Actually prepare the files, and collect any exceptions. Most hash + # exceptions cannot be checked ahead of time, because + # req.populate_link() needs to be called before we can make decisions + # based on link type. + discovered_reqs = [] # type: List[InstallRequirement] + hash_errors = HashErrors() + for req in chain(root_reqs, discovered_reqs): + try: + discovered_reqs.extend( + self._resolve_one(requirement_set, req) + ) + except HashError as exc: + exc.req = req + hash_errors.append(exc) + + if hash_errors: + raise hash_errors + + def _is_upgrade_allowed(self, req): + # type: (InstallRequirement) -> bool + if self.upgrade_strategy == "to-satisfy-only": + return False + elif self.upgrade_strategy == "eager": + return True + else: + assert self.upgrade_strategy == "only-if-needed" + return req.is_direct + + def _set_req_to_reinstall(self, req): + # type: (InstallRequirement) -> None + """ + Set a requirement to be installed. + """ + # Don't uninstall the conflict if doing a user install and the + # conflict is not a user install. + if not self.use_user_site or dist_in_usersite(req.satisfied_by): + req.conflicts_with = req.satisfied_by + req.satisfied_by = None + + # XXX: Stop passing requirement_set for options + def _check_skip_installed(self, req_to_install): + # type: (InstallRequirement) -> Optional[str] + """Check if req_to_install should be skipped. + + This will check if the req is installed, and whether we should upgrade + or reinstall it, taking into account all the relevant user options. + + After calling this req_to_install will only have satisfied_by set to + None if the req_to_install is to be upgraded/reinstalled etc. Any + other value will be a dist recording the current thing installed that + satisfies the requirement. + + Note that for vcs urls and the like we can't assess skipping in this + routine - we simply identify that we need to pull the thing down, + then later on it is pulled down and introspected to assess upgrade/ + reinstalls etc. + + :return: A text reason for why it was skipped, or None. + """ + if self.ignore_installed: + return None + + req_to_install.check_if_exists(self.use_user_site) + if not req_to_install.satisfied_by: + return None + + if self.force_reinstall: + self._set_req_to_reinstall(req_to_install) + return None + + if not self._is_upgrade_allowed(req_to_install): + if self.upgrade_strategy == "only-if-needed": + return 'already satisfied, skipping upgrade' + return 'already satisfied' + + # Check for the possibility of an upgrade. For link-based + # requirements we have to pull the tree down and inspect to assess + # the version #, so it's handled way down. + if not req_to_install.link: + try: + self.finder.find_requirement(req_to_install, upgrade=True) + except BestVersionAlreadyInstalled: + # Then the best version is installed. + return 'already up-to-date' + except DistributionNotFound: + # No distribution found, so we squash the error. It will + # be raised later when we re-try later to do the install. + # Why don't we just raise here? + pass + + self._set_req_to_reinstall(req_to_install) + return None + + def _get_abstract_dist_for(self, req): + # type: (InstallRequirement) -> AbstractDistribution + """Takes a InstallRequirement and returns a single AbstractDist \ + representing a prepared variant of the same. + """ + assert self.require_hashes is not None, ( + "require_hashes should have been set in Resolver.resolve()" + ) + + if req.editable: + return self.preparer.prepare_editable_requirement( + req, self.require_hashes, self.use_user_site, self.finder, + ) + + # satisfied_by is only evaluated by calling _check_skip_installed, + # so it must be None here. + assert req.satisfied_by is None + skip_reason = self._check_skip_installed(req) + + if req.satisfied_by: + return self.preparer.prepare_installed_requirement( + req, self.require_hashes, skip_reason + ) + + upgrade_allowed = self._is_upgrade_allowed(req) + abstract_dist = self.preparer.prepare_linked_requirement( + req, self.session, self.finder, upgrade_allowed, + self.require_hashes + ) + + # NOTE + # The following portion is for determining if a certain package is + # going to be re-installed/upgraded or not and reporting to the user. + # This should probably get cleaned up in a future refactor. + + # req.req is only avail after unpack for URL + # pkgs repeat check_if_exists to uninstall-on-upgrade + # (#14) + if not self.ignore_installed: + req.check_if_exists(self.use_user_site) + + if req.satisfied_by: + should_modify = ( + self.upgrade_strategy != "to-satisfy-only" or + self.force_reinstall or + self.ignore_installed or + req.link.scheme == 'file' + ) + if should_modify: + self._set_req_to_reinstall(req) + else: + logger.info( + 'Requirement already satisfied (use --upgrade to upgrade):' + ' %s', req, + ) + + return abstract_dist + + def _resolve_one( + self, + requirement_set, # type: RequirementSet + req_to_install # type: InstallRequirement + ): + # type: (...) -> List[InstallRequirement] + """Prepare a single requirements file. + + :return: A list of additional InstallRequirements to also install. + """ + # Tell user what we are doing for this requirement: + # obtain (editable), skipping, processing (local url), collecting + # (remote url or package name) + if req_to_install.constraint or req_to_install.prepared: + return [] + + req_to_install.prepared = True + + # register tmp src for cleanup in case something goes wrong + requirement_set.reqs_to_cleanup.append(req_to_install) + + abstract_dist = self._get_abstract_dist_for(req_to_install) + + # Parse and return dependencies + dist = abstract_dist.get_pkg_resources_distribution() + # This will raise UnsupportedPythonVersion if the given Python + # version isn't compatible with the distribution's Requires-Python. + _check_dist_requires_python( + dist, version_info=self._py_version_info, + ignore_requires_python=self.ignore_requires_python, + ) + + more_reqs = [] # type: List[InstallRequirement] + + def add_req(subreq, extras_requested): + sub_install_req = install_req_from_req_string( + str(subreq), + req_to_install, + isolated=self.isolated, + wheel_cache=self.wheel_cache, + use_pep517=self.use_pep517 + ) + parent_req_name = req_to_install.name + to_scan_again, add_to_parent = requirement_set.add_requirement( + sub_install_req, + parent_req_name=parent_req_name, + extras_requested=extras_requested, + ) + if parent_req_name and add_to_parent: + self._discovered_dependencies[parent_req_name].append( + add_to_parent + ) + more_reqs.extend(to_scan_again) + + with indent_log(): + # We add req_to_install before its dependencies, so that we + # can refer to it when adding dependencies. + if not requirement_set.has_requirement(req_to_install.name): + # 'unnamed' requirements will get added here + req_to_install.is_direct = True + requirement_set.add_requirement( + req_to_install, parent_req_name=None, + ) + + if not self.ignore_dependencies: + if req_to_install.extras: + logger.debug( + "Installing extra requirements: %r", + ','.join(req_to_install.extras), + ) + missing_requested = sorted( + set(req_to_install.extras) - set(dist.extras) + ) + for missing in missing_requested: + logger.warning( + '%s does not provide the extra \'%s\'', + dist, missing + ) + + available_requested = sorted( + set(dist.extras) & set(req_to_install.extras) + ) + for subreq in dist.requires(available_requested): + add_req(subreq, extras_requested=available_requested) + + if not req_to_install.editable and not req_to_install.satisfied_by: + # XXX: --no-install leads this to report 'Successfully + # downloaded' for only non-editable reqs, even though we took + # action on them. + requirement_set.successfully_downloaded.append(req_to_install) + + return more_reqs + + def get_installation_order(self, req_set): + # type: (RequirementSet) -> List[InstallRequirement] + """Create the installation order. + + The installation order is topological - requirements are installed + before the requiring thing. We break cycles at an arbitrary point, + and make no other guarantees. + """ + # The current implementation, which we may change at any point + # installs the user specified things in the order given, except when + # dependencies must come earlier to achieve topological order. + order = [] + ordered_reqs = set() # type: Set[InstallRequirement] + + def schedule(req): + if req.satisfied_by or req in ordered_reqs: + return + if req.constraint: + return + ordered_reqs.add(req) + for dep in self._discovered_dependencies[req.name]: + schedule(dep) + order.append(req) + + for install_req in req_set.requirements.values(): + schedule(install_req) + return order diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/locations.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/locations.py new file mode 100644 index 0000000..5f843d7 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/locations.py @@ -0,0 +1,142 @@ +"""Locations where we look for configs, install stuff, etc""" +from __future__ import absolute_import + +import os +import os.path +import platform +import site +import sys +import sysconfig +from distutils import sysconfig as distutils_sysconfig +from distutils.command.install import SCHEME_KEYS # type: ignore + +from pip._internal.utils import appdirs +from pip._internal.utils.compat import WINDOWS +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.virtualenv import running_under_virtualenv + +if MYPY_CHECK_RUNNING: + from typing import Any, Union, Dict, List, Optional + + +# Application Directories +USER_CACHE_DIR = appdirs.user_cache_dir("pip") + + +def get_src_prefix(): + if running_under_virtualenv(): + src_prefix = os.path.join(sys.prefix, 'src') + else: + # FIXME: keep src in cwd for now (it is not a temporary folder) + try: + src_prefix = os.path.join(os.getcwd(), 'src') + except OSError: + # In case the current working directory has been renamed or deleted + sys.exit( + "The folder you are executing pip from can no longer be found." + ) + + # under macOS + virtualenv sys.prefix is not properly resolved + # it is something like /path/to/python/bin/.. + return os.path.abspath(src_prefix) + + +# FIXME doesn't account for venv linked to global site-packages + +site_packages = sysconfig.get_path("purelib") # type: Optional[str] + +# This is because of a bug in PyPy's sysconfig module, see +# https://bitbucket.org/pypy/pypy/issues/2506/sysconfig-returns-incorrect-paths +# for more information. +if platform.python_implementation().lower() == "pypy": + site_packages = distutils_sysconfig.get_python_lib() +try: + # Use getusersitepackages if this is present, as it ensures that the + # value is initialised properly. + user_site = site.getusersitepackages() +except AttributeError: + user_site = site.USER_SITE + +if WINDOWS: + bin_py = os.path.join(sys.prefix, 'Scripts') + bin_user = os.path.join(user_site, 'Scripts') + # buildout uses 'bin' on Windows too? + if not os.path.exists(bin_py): + bin_py = os.path.join(sys.prefix, 'bin') + bin_user = os.path.join(user_site, 'bin') +else: + bin_py = os.path.join(sys.prefix, 'bin') + bin_user = os.path.join(user_site, 'bin') + + # Forcing to use /usr/local/bin for standard macOS framework installs + # Also log to ~/Library/Logs/ for use with the Console.app log viewer + if sys.platform[:6] == 'darwin' and sys.prefix[:16] == '/System/Library/': + bin_py = '/usr/local/bin' + + +def distutils_scheme(dist_name, user=False, home=None, root=None, + isolated=False, prefix=None): + # type:(str, bool, str, str, bool, str) -> dict + """ + Return a distutils install scheme + """ + from distutils.dist import Distribution + + scheme = {} + + if isolated: + extra_dist_args = {"script_args": ["--no-user-cfg"]} + else: + extra_dist_args = {} + dist_args = {'name': dist_name} # type: Dict[str, Union[str, List[str]]] + dist_args.update(extra_dist_args) + + d = Distribution(dist_args) + # Ignoring, typeshed issue reported python/typeshed/issues/2567 + d.parse_config_files() + # NOTE: Ignoring type since mypy can't find attributes on 'Command' + i = d.get_command_obj('install', create=True) # type: Any + assert i is not None + # NOTE: setting user or home has the side-effect of creating the home dir + # or user base for installations during finalize_options() + # ideally, we'd prefer a scheme class that has no side-effects. + assert not (user and prefix), "user={} prefix={}".format(user, prefix) + assert not (home and prefix), "home={} prefix={}".format(home, prefix) + i.user = user or i.user + if user or home: + i.prefix = "" + i.prefix = prefix or i.prefix + i.home = home or i.home + i.root = root or i.root + i.finalize_options() + for key in SCHEME_KEYS: + scheme[key] = getattr(i, 'install_' + key) + + # install_lib specified in setup.cfg should install *everything* + # into there (i.e. it takes precedence over both purelib and + # platlib). Note, i.install_lib is *always* set after + # finalize_options(); we only want to override here if the user + # has explicitly requested it hence going back to the config + + # Ignoring, typeshed issue reported python/typeshed/issues/2567 + if 'install_lib' in d.get_option_dict('install'): # type: ignore + scheme.update(dict(purelib=i.install_lib, platlib=i.install_lib)) + + if running_under_virtualenv(): + scheme['headers'] = os.path.join( + sys.prefix, + 'include', + 'site', + 'python' + sys.version[:3], + dist_name, + ) + + if root is not None: + path_no_drive = os.path.splitdrive( + os.path.abspath(scheme["headers"]))[1] + scheme["headers"] = os.path.join( + root, + path_no_drive[1:], + ) + + return scheme diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__init__.py new file mode 100644 index 0000000..7855226 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__init__.py @@ -0,0 +1,2 @@ +"""A package that contains models that represent entities. +""" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e447431400aedf5316c52c16ee5ea01d2beefb3d GIT binary patch literal 273 zcmYk1Jx&8L5QV*I5=F`#+@?spP(-YR__+WL(9n#`da`Tcc&)KxC3_o6I?j`pBOp;w zF`G0z>6_7e#r!dlX`Fz*6+`k6%Uj>^xCQi5*@ghv|DCVR7>Rtw2Z*+q)wK~bV z^GRDD<+d~E;yEM?gb{s`j7=8fa{4eYj$;7R)c_xYMm+XZen|zgStnFklUjGqAVpQ} zRRdL~ZSODFZ)Mx=`yO1idTps>HC{cbV8en}C+*y#ELZuEFLpzC0<2F+UORQZOaUi0 T0W8DeIJxF<=kR8D^P3TW(oIoK literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/candidate.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/candidate.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..497f0be36a4145ea6d077fd6b55a6bb2e3c8e387 GIT binary patch literal 1507 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/link.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/link.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..39d0b0b523454101668491efe9faf16b9944f645 GIT binary patch literal 6334 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..721aedfe86492c16c3baf961e5b723fef38cd7f8 GIT binary patch literal 3304 zcmbVOOLH5?5#HGs7E6#6C0bH!A2ycb2#E~PNlLL4mdYu~@r!0Df}NC6ajloT17OM7 z2WJK#iGaR{RdxzpQ0EWf`*eJ8^fH z5_8YwAIrvcIkE5`_>1p zwOkPoXhxOGihiGRRXd1y4(@5zlod0%O2vg8)V2R&^{2S&>rfe{P1XVGE5v^0J+p0h zp*_Cw1N;{w=4KDJ@mTfI2GID1^hiPy^Thj$@r?m(#F{t5nvT!^d_?7t>uj@_dwRt% zPl8bzL9SuF);!$#^LRd>@m`g)z(G1S2M{_jre+Y+f}6dR3yDzFX$`_)vjSxh<;l5} zp`b7i@%CH>1W(wGA0q&c;u{cXi46Ie)qX}}Y4 za{?Z@hP*`1nA=ZDyXmTWS%~xyBQ|e?41NtN$1sl9#V}NU7*-h`+Kn*W zA4cqKrWS@t5yS9O%;0{QQON!Yzky0(ZsPA?br-9-=X47-=6KhB1&U}u<(al^691-G z_g3{x^G6&fRSk1D1ZBPkJ^o7^dJVE=D;xo)3f?NCcrU^Qt)WaIr)#{uzPJLQ*~*F$ z6)k`gToX7Fyu#?KdfhDN!Ya(U6$?7t4{do!1f-DuWzRKv>uU;xd z0=B^_OnAyY>(sGRhlAYG_Z9vdRPn+a literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/selection_prefs.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/selection_prefs.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c2d1de0b14c0e4d58e957ac44d7fcd6b098e184d GIT binary patch literal 1645 zcmZuxL5~_Y6t-sumaZU&w&@{KB`duIsXMcc)JVIEs#bJKs;UGfT~*;?nX!S%dhCg9 zU_tbh{E;4e%kP1$_$xq}!?QInV$R21VVsdHg9ku}nki2X= zu>hdebCUuzmR_+b=$epmrkGjnJjoNHbM7YNgsb1jYGu%El@Fk}__nZk?lNg(w<_Sw8~+fM&Fv)glWz{cu4#x5 m#WeoiEt~Z#Q|+^d%HuE|TG@J9SM>vine`ysL4@159sUm;Qr(dN literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/target_python.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/__pycache__/target_python.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..fa4bb21ad577d71803222ac906b7841ceb72f597 GIT binary patch literal 3249 zcma)8&yU;273K^niPCCqw~c?LtuXY6FI=8A;rw zNM<`#0Qy?VxIONQ{dGC8~zBiw2Z#NuV z|M}<3@ZXml=U?=(etG!#HJ*G3AsxwLr%P`hvk~v|k=u0{eY>$Ys&p&1?Zwqmty^P` zs_6stRbqcs@770+Zez67-LhkG9ib)pU-?aE!4u!ObAHMe zT)HnjQ!!N~pl=&HB3GgA4FM4Oy!1Ff*F@UPFf=06N}T76IGkE| zdt?!<0N% z64+2^g5U1ZzA5LrtI4#SBOu}TJJDBjr-cXuer?~0S5N+|y)kyLUub(tFB zVf1ZTVU` z_%4_tzU%UxSJ)d)!P>7l-mUH8S}=$vDhaa9xE3yOFPiJXYvQNEJ4&OZa7ST=Ax0N2 z&?_!&x>NXPyRB%f^cI&_ZOgC4Rxkmj%774URSPdyabI7W$)g5wmS&!P4sA%-0dIj4TsNWvmn0r-r-R1;Tj~n2fJC6 z-C5GtoxQ#HCez6~WBO?ySOf+HRqu{csp5RMBthUpoQilCetM@$JyeJ67m6jX3Xh^mIgB{_0T-QI5`~|a=@6f-;&M5-} zG6}vr;(acwa|T(%my5TLx7X(b58PSDyaq}IShk#n@~|~~e4aYLwVTY6iw*mZNYdmE zv7iV|Nf1l+17RSDYx}>Wo3L}k3rZpKB&UY}nLD3dS}^0x*(v*z!<;X;bYKDNw3sH; zP;hyBukb+0#zwOgKSEbge=tyqdY0*j78FW0k8x+Vvw>#G5@pV|A6SygAGXh@mf3R! zb645(6%!j)pJ8vU{wapS>RW%|3)CLe90&NL^1Of#bN-UAdBHog+Lw!8efgGNppI8d zOIohJMb^8=YFbo~&SQ1KF)h&l5uTh1qK7o`U$-h6hapFQkAzM5^IV6*H}SW)ybQn@ z+ZGM1K>KB^@(U{z&2>~BV0KO_oQlU9xV_hY#iwPN|BY8|F#dXW^Z#PHffU7njJ5&! zJsOmawt7ECi!zp#wH(>YlZN3G_W{~e%PA}IP|o6*@;7hc+6r!UASc|}-_Nu1sWM|- zmb_J2-G8z#a8SZwWPlS%Do~eu$He3+CaRZ_v?rTz5YnD*H_o-8LY9-LOygVw)wXt` z6o4wII-xA}6^eBaMP`)dX8A)?t&DVT)~ZXVb5UEJW@SlZCdlfI%QeLe^BD_kk~k None + self.project = project + self.version = parse_version(version) # type: _BaseVersion + self.link = link + + super(InstallationCandidate, self).__init__( + key=(self.project, self.version, self.link), + defining_class=InstallationCandidate + ) + + def __repr__(self): + # type: () -> str + return "".format( + self.project, self.version, self.link, + ) + + def __str__(self): + return '{!r} candidate (version {} at {})'.format( + self.project, self.version, self.link, + ) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/format_control.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/format_control.py new file mode 100644 index 0000000..53138e4 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/format_control.py @@ -0,0 +1,73 @@ +from pip._vendor.packaging.utils import canonicalize_name + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional, Set, FrozenSet + + +class FormatControl(object): + """Helper for managing formats from which a package can be installed. + """ + + def __init__(self, no_binary=None, only_binary=None): + # type: (Optional[Set], Optional[Set]) -> None + if no_binary is None: + no_binary = set() + if only_binary is None: + only_binary = set() + + self.no_binary = no_binary + self.only_binary = only_binary + + def __eq__(self, other): + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + return not self.__eq__(other) + + def __repr__(self): + return "{}({}, {})".format( + self.__class__.__name__, + self.no_binary, + self.only_binary + ) + + @staticmethod + def handle_mutual_excludes(value, target, other): + # type: (str, Optional[Set], Optional[Set]) -> None + new = value.split(',') + while ':all:' in new: + other.clear() + target.clear() + target.add(':all:') + del new[:new.index(':all:') + 1] + # Without a none, we want to discard everything as :all: covers it + if ':none:' not in new: + return + for name in new: + if name == ':none:': + target.clear() + continue + name = canonicalize_name(name) + other.discard(name) + target.add(name) + + def get_allowed_formats(self, canonical_name): + # type: (str) -> FrozenSet + result = {"binary", "source"} + if canonical_name in self.only_binary: + result.discard('source') + elif canonical_name in self.no_binary: + result.discard('binary') + elif ':all:' in self.only_binary: + result.discard('source') + elif ':all:' in self.no_binary: + result.discard('binary') + return frozenset(result) + + def disallow_binaries(self): + # type: () -> None + self.handle_mutual_excludes( + ':all:', self.no_binary, self.only_binary, + ) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/index.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/index.py new file mode 100644 index 0000000..ead1efb --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/index.py @@ -0,0 +1,31 @@ +from pip._vendor.six.moves.urllib import parse as urllib_parse + + +class PackageIndex(object): + """Represents a Package Index and provides easier access to endpoints + """ + + def __init__(self, url, file_storage_domain): + # type: (str, str) -> None + super(PackageIndex, self).__init__() + self.url = url + self.netloc = urllib_parse.urlsplit(url).netloc + self.simple_url = self._url_for_path('simple') + self.pypi_url = self._url_for_path('pypi') + + # This is part of a temporary hack used to block installs of PyPI + # packages which depend on external urls only necessary until PyPI can + # block such packages themselves + self.file_storage_domain = file_storage_domain + + def _url_for_path(self, path): + # type: (str) -> str + return urllib_parse.urljoin(self.url, path) + + +PyPI = PackageIndex( + 'https://pypi.org/', file_storage_domain='files.pythonhosted.org' +) +TestPyPI = PackageIndex( + 'https://test.pypi.org/', file_storage_domain='test-files.pythonhosted.org' +) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/link.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/link.py new file mode 100644 index 0000000..d42be28 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/link.py @@ -0,0 +1,213 @@ +import posixpath +import re + +from pip._vendor.six.moves.urllib import parse as urllib_parse + +from pip._internal.utils.misc import ( + WHEEL_EXTENSION, path_to_url, redact_password_from_url, + split_auth_from_netloc, splitext, +) +from pip._internal.utils.models import KeyBasedCompareMixin +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional, Text, Tuple, Union + from pip._internal.index import HTMLPage + from pip._internal.utils.hashes import Hashes + + +class Link(KeyBasedCompareMixin): + """Represents a parsed link from a Package Index's simple URL + """ + + def __init__( + self, + url, # type: str + comes_from=None, # type: Optional[Union[str, HTMLPage]] + requires_python=None, # type: Optional[str] + yanked_reason=None, # type: Optional[Text] + ): + # type: (...) -> None + """ + :param url: url of the resource pointed to (href of the link) + :param comes_from: instance of HTMLPage where the link was found, + or string. + :param requires_python: String containing the `Requires-Python` + metadata field, specified in PEP 345. This may be specified by + a data-requires-python attribute in the HTML link tag, as + described in PEP 503. + :param yanked_reason: the reason the file has been yanked, if the + file has been yanked, or None if the file hasn't been yanked. + This is the value of the "data-yanked" attribute, if present, in + a simple repository HTML link. If the file has been yanked but + no reason was provided, this should be the empty string. See + PEP 592 for more information and the specification. + """ + + # url can be a UNC windows share + if url.startswith('\\\\'): + url = path_to_url(url) + + self._parsed_url = urllib_parse.urlsplit(url) + # Store the url as a private attribute to prevent accidentally + # trying to set a new value. + self._url = url + + self.comes_from = comes_from + self.requires_python = requires_python if requires_python else None + self.yanked_reason = yanked_reason + + super(Link, self).__init__(key=url, defining_class=Link) + + def __str__(self): + if self.requires_python: + rp = ' (requires-python:%s)' % self.requires_python + else: + rp = '' + if self.comes_from: + return '%s (from %s)%s' % (redact_password_from_url(self._url), + self.comes_from, rp) + else: + return redact_password_from_url(str(self._url)) + + def __repr__(self): + return '' % self + + @property + def url(self): + # type: () -> str + return self._url + + @property + def filename(self): + # type: () -> str + path = self.path.rstrip('/') + name = posixpath.basename(path) + if not name: + # Make sure we don't leak auth information if the netloc + # includes a username and password. + netloc, user_pass = split_auth_from_netloc(self.netloc) + return netloc + + name = urllib_parse.unquote(name) + assert name, ('URL %r produced no filename' % self._url) + return name + + @property + def scheme(self): + # type: () -> str + return self._parsed_url.scheme + + @property + def netloc(self): + # type: () -> str + """ + This can contain auth information. + """ + return self._parsed_url.netloc + + @property + def path(self): + # type: () -> str + return urllib_parse.unquote(self._parsed_url.path) + + def splitext(self): + # type: () -> Tuple[str, str] + return splitext(posixpath.basename(self.path.rstrip('/'))) + + @property + def ext(self): + # type: () -> str + return self.splitext()[1] + + @property + def url_without_fragment(self): + # type: () -> str + scheme, netloc, path, query, fragment = self._parsed_url + return urllib_parse.urlunsplit((scheme, netloc, path, query, None)) + + _egg_fragment_re = re.compile(r'[#&]egg=([^&]*)') + + @property + def egg_fragment(self): + # type: () -> Optional[str] + match = self._egg_fragment_re.search(self._url) + if not match: + return None + return match.group(1) + + _subdirectory_fragment_re = re.compile(r'[#&]subdirectory=([^&]*)') + + @property + def subdirectory_fragment(self): + # type: () -> Optional[str] + match = self._subdirectory_fragment_re.search(self._url) + if not match: + return None + return match.group(1) + + _hash_re = re.compile( + r'(sha1|sha224|sha384|sha256|sha512|md5)=([a-f0-9]+)' + ) + + @property + def hash(self): + # type: () -> Optional[str] + match = self._hash_re.search(self._url) + if match: + return match.group(2) + return None + + @property + def hash_name(self): + # type: () -> Optional[str] + match = self._hash_re.search(self._url) + if match: + return match.group(1) + return None + + @property + def show_url(self): + # type: () -> Optional[str] + return posixpath.basename(self._url.split('#', 1)[0].split('?', 1)[0]) + + @property + def is_wheel(self): + # type: () -> bool + return self.ext == WHEEL_EXTENSION + + @property + def is_artifact(self): + # type: () -> bool + """ + Determines if this points to an actual artifact (e.g. a tarball) or if + it points to an "abstract" thing like a path or a VCS location. + """ + from pip._internal.vcs import vcs + + if self.scheme in vcs.all_schemes: + return False + + return True + + @property + def is_yanked(self): + # type: () -> bool + return self.yanked_reason is not None + + @property + def has_hash(self): + return self.hash_name is not None + + def is_hash_allowed(self, hashes): + # type: (Optional[Hashes]) -> bool + """ + Return True if the link has a hash and it is allowed. + """ + if hashes is None or not self.has_hash: + return False + # Assert non-None so mypy knows self.hash_name and self.hash are str. + assert self.hash_name is not None + assert self.hash is not None + + return hashes.is_hash_allowed(self.hash_name, hex_digest=self.hash) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/search_scope.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/search_scope.py new file mode 100644 index 0000000..6215244 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/search_scope.py @@ -0,0 +1,113 @@ +import itertools +import logging +import os +import posixpath + +from pip._vendor.packaging.utils import canonicalize_name +from pip._vendor.six.moves.urllib import parse as urllib_parse + +from pip._internal.models.index import PyPI +from pip._internal.utils.compat import HAS_TLS +from pip._internal.utils.misc import normalize_path, redact_password_from_url +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List + + +logger = logging.getLogger(__name__) + + +class SearchScope(object): + + """ + Encapsulates the locations that pip is configured to search. + """ + + @classmethod + def create( + cls, + find_links, # type: List[str] + index_urls, # type: List[str] + ): + # type: (...) -> SearchScope + """ + Create a SearchScope object after normalizing the `find_links`. + """ + # Build find_links. If an argument starts with ~, it may be + # a local file relative to a home directory. So try normalizing + # it and if it exists, use the normalized version. + # This is deliberately conservative - it might be fine just to + # blindly normalize anything starting with a ~... + built_find_links = [] # type: List[str] + for link in find_links: + if link.startswith('~'): + new_link = normalize_path(link) + if os.path.exists(new_link): + link = new_link + built_find_links.append(link) + + # If we don't have TLS enabled, then WARN if anyplace we're looking + # relies on TLS. + if not HAS_TLS: + for link in itertools.chain(index_urls, built_find_links): + parsed = urllib_parse.urlparse(link) + if parsed.scheme == 'https': + logger.warning( + 'pip is configured with locations that require ' + 'TLS/SSL, however the ssl module in Python is not ' + 'available.' + ) + break + + return cls( + find_links=built_find_links, + index_urls=index_urls, + ) + + def __init__( + self, + find_links, # type: List[str] + index_urls, # type: List[str] + ): + # type: (...) -> None + self.find_links = find_links + self.index_urls = index_urls + + def get_formatted_locations(self): + # type: () -> str + lines = [] + if self.index_urls and self.index_urls != [PyPI.simple_url]: + lines.append( + 'Looking in indexes: {}'.format(', '.join( + redact_password_from_url(url) for url in self.index_urls)) + ) + if self.find_links: + lines.append( + 'Looking in links: {}'.format(', '.join( + redact_password_from_url(url) for url in self.find_links)) + ) + return '\n'.join(lines) + + def get_index_urls_locations(self, project_name): + # type: (str) -> List[str] + """Returns the locations found via self.index_urls + + Checks the url_name on the main (first in the list) index and + use this url_name to produce all locations + """ + + def mkurl_pypi_url(url): + loc = posixpath.join( + url, + urllib_parse.quote(canonicalize_name(project_name))) + # For maximum compatibility with easy_install, ensure the path + # ends in a trailing slash. Although this isn't in the spec + # (and PyPI can handle it without the slash) some other index + # implementations might break if they relied on easy_install's + # behavior. + if not loc.endswith('/'): + loc = loc + '/' + return loc + + return [mkurl_pypi_url(url) for url in self.index_urls] diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/selection_prefs.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/selection_prefs.py new file mode 100644 index 0000000..f58fdce --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/selection_prefs.py @@ -0,0 +1,47 @@ +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional + from pip._internal.models.format_control import FormatControl + + +class SelectionPreferences(object): + + """ + Encapsulates the candidate selection preferences for downloading + and installing files. + """ + + # Don't include an allow_yanked default value to make sure each call + # site considers whether yanked releases are allowed. This also causes + # that decision to be made explicit in the calling code, which helps + # people when reading the code. + def __init__( + self, + allow_yanked, # type: bool + allow_all_prereleases=False, # type: bool + format_control=None, # type: Optional[FormatControl] + prefer_binary=False, # type: bool + ignore_requires_python=None, # type: Optional[bool] + ): + # type: (...) -> None + """Create a SelectionPreferences object. + + :param allow_yanked: Whether files marked as yanked (in the sense + of PEP 592) are permitted to be candidates for install. + :param format_control: A FormatControl object or None. Used to control + the selection of source packages / binary packages when consulting + the index and links. + :param prefer_binary: Whether to prefer an old, but valid, binary + dist over a new source dist. + :param ignore_requires_python: Whether to ignore incompatible + "Requires-Python" values in links. Defaults to False. + """ + if ignore_requires_python is None: + ignore_requires_python = False + + self.allow_yanked = allow_yanked + self.allow_all_prereleases = allow_all_prereleases + self.format_control = format_control + self.prefer_binary = prefer_binary + self.ignore_requires_python = ignore_requires_python diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/target_python.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/target_python.py new file mode 100644 index 0000000..a23b79c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/models/target_python.py @@ -0,0 +1,106 @@ +import sys + +from pip._internal.pep425tags import get_supported, version_info_to_nodot +from pip._internal.utils.misc import normalize_version_info +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List, Optional, Tuple + from pip._internal.pep425tags import Pep425Tag + + +class TargetPython(object): + + """ + Encapsulates the properties of a Python interpreter one is targeting + for a package install, download, etc. + """ + + def __init__( + self, + platform=None, # type: Optional[str] + py_version_info=None, # type: Optional[Tuple[int, ...]] + abi=None, # type: Optional[str] + implementation=None, # type: Optional[str] + ): + # type: (...) -> None + """ + :param platform: A string or None. If None, searches for packages + that are supported by the current system. Otherwise, will find + packages that can be built on the platform passed in. These + packages will only be downloaded for distribution: they will + not be built locally. + :param py_version_info: An optional tuple of ints representing the + Python version information to use (e.g. `sys.version_info[:3]`). + This can have length 1, 2, or 3 when provided. + :param abi: A string or None. This is passed to pep425tags.py's + get_supported() function as is. + :param implementation: A string or None. This is passed to + pep425tags.py's get_supported() function as is. + """ + # Store the given py_version_info for when we call get_supported(). + self._given_py_version_info = py_version_info + + if py_version_info is None: + py_version_info = sys.version_info[:3] + else: + py_version_info = normalize_version_info(py_version_info) + + py_version = '.'.join(map(str, py_version_info[:2])) + + self.abi = abi + self.implementation = implementation + self.platform = platform + self.py_version = py_version + self.py_version_info = py_version_info + + # This is used to cache the return value of get_tags(). + self._valid_tags = None # type: Optional[List[Pep425Tag]] + + def format_given(self): + # type: () -> str + """ + Format the given, non-None attributes for display. + """ + display_version = None + if self._given_py_version_info is not None: + display_version = '.'.join( + str(part) for part in self._given_py_version_info + ) + + key_values = [ + ('platform', self.platform), + ('version_info', display_version), + ('abi', self.abi), + ('implementation', self.implementation), + ] + return ' '.join( + '{}={!r}'.format(key, value) for key, value in key_values + if value is not None + ) + + def get_tags(self): + # type: () -> List[Pep425Tag] + """ + Return the supported PEP 425 tags to check wheel candidates against. + + The tags are returned in order of preference (most preferred first). + """ + if self._valid_tags is None: + # Pass versions=None if no py_version_info was given since + # versions=None uses special default logic. + py_version_info = self._given_py_version_info + if py_version_info is None: + versions = None + else: + versions = [version_info_to_nodot(py_version_info)] + + tags = get_supported( + versions=versions, + platform=self.platform, + abi=self.abi, + impl=self.implementation, + ) + self._valid_tags = tags + + return self._valid_tags diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..40971bec64a28a8b697bbde0874aeb53cf1f7934 GIT binary patch literal 209 zcmWIL<>g`kf^QoZCW7e4AOaaM0yz#qT+9L_QW%06G#UL?G8BP?5yY=D{eq&*vc!^9 z{j$U&{j~g?l+>bPeai~{^mxm%qTH%HqqHo8jEst^s`wmBv!sk710YDx(+|-v$Sly! z%quQQ%*oL;Ffc2tEHf+x34(EaW?o5ZQC?z>ettn}QDRAEeqOPDJWw>VBtBlRpz;=n SO>TZlX-=vg$UUEdm;nH_YdL8E literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/check.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/check.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f71926d2554f1effe8a2fc5c37dd2c08bbf99012 GIT binary patch literal 3715 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8b78d00e43ebd1b223041a75628db0d6ba7d086b GIT binary patch literal 5796 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 Tuple[PackageSet, bool] + """Converts a list of distributions into a PackageSet. + """ + # Default to using all packages installed on the system + if kwargs == {}: + kwargs = {"local_only": False, "skip": ()} + + package_set = {} + problems = False + for dist in get_installed_distributions(**kwargs): + name = canonicalize_name(dist.project_name) + try: + package_set[name] = PackageDetails(dist.version, dist.requires()) + except RequirementParseError as e: + # Don't crash on broken metadata + logging.warning("Error parsing requirements for %s: %s", name, e) + problems = True + return package_set, problems + + +def check_package_set(package_set, should_ignore=None): + # type: (PackageSet, Optional[Callable[[str], bool]]) -> CheckResult + """Check if a package set is consistent + + If should_ignore is passed, it should be a callable that takes a + package name and returns a boolean. + """ + if should_ignore is None: + def should_ignore(name): + return False + + missing = dict() + conflicting = dict() + + for package_name in package_set: + # Info about dependencies of package_name + missing_deps = set() # type: Set[Missing] + conflicting_deps = set() # type: Set[Conflicting] + + if should_ignore(package_name): + continue + + for req in package_set[package_name].requires: + name = canonicalize_name(req.project_name) # type: str + + # Check if it's missing + if name not in package_set: + missed = True + if req.marker is not None: + missed = req.marker.evaluate() + if missed: + missing_deps.add((name, req)) + continue + + # Check if there's a conflict + version = package_set[name].version # type: str + if not req.specifier.contains(version, prereleases=True): + conflicting_deps.add((name, version, req)) + + if missing_deps: + missing[package_name] = sorted(missing_deps, key=str) + if conflicting_deps: + conflicting[package_name] = sorted(conflicting_deps, key=str) + + return missing, conflicting + + +def check_install_conflicts(to_install): + # type: (List[InstallRequirement]) -> Tuple[PackageSet, CheckResult] + """For checking if the dependency graph would be consistent after \ + installing given requirements + """ + # Start from the current state + package_set, _ = create_package_set_from_installed() + # Install packages + would_be_installed = _simulate_installation_of(to_install, package_set) + + # Only warn about directly-dependent packages; create a whitelist of them + whitelist = _create_whitelist(would_be_installed, package_set) + + return ( + package_set, + check_package_set( + package_set, should_ignore=lambda name: name not in whitelist + ) + ) + + +def _simulate_installation_of(to_install, package_set): + # type: (List[InstallRequirement], PackageSet) -> Set[str] + """Computes the version of packages after installing to_install. + """ + + # Keep track of packages that were installed + installed = set() + + # Modify it as installing requirement_set would (assuming no errors) + for inst_req in to_install: + abstract_dist = make_distribution_for_install_requirement(inst_req) + dist = abstract_dist.get_pkg_resources_distribution() + + name = canonicalize_name(dist.key) + package_set[name] = PackageDetails(dist.version, dist.requires()) + + installed.add(name) + + return installed + + +def _create_whitelist(would_be_installed, package_set): + # type: (Set[str], PackageSet) -> Set[str] + packages_affected = set(would_be_installed) + + for package_name in package_set: + if package_name in packages_affected: + continue + + for req in package_set[package_name].requires: + if canonicalize_name(req.name) in packages_affected: + packages_affected.add(package_name) + break + + return packages_affected diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/freeze.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/freeze.py new file mode 100644 index 0000000..6f5a3dd --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/freeze.py @@ -0,0 +1,253 @@ +from __future__ import absolute_import + +import collections +import logging +import os +import re + +from pip._vendor import six +from pip._vendor.packaging.utils import canonicalize_name +from pip._vendor.pkg_resources import RequirementParseError + +from pip._internal.exceptions import BadCommand, InstallationError +from pip._internal.req.constructors import ( + install_req_from_editable, install_req_from_line, +) +from pip._internal.req.req_file import COMMENT_RE +from pip._internal.utils.misc import ( + dist_is_editable, get_installed_distributions, +) +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import ( + Iterator, Optional, List, Container, Set, Dict, Tuple, Iterable, Union + ) + from pip._internal.cache import WheelCache + from pip._vendor.pkg_resources import ( + Distribution, Requirement + ) + + RequirementInfo = Tuple[Optional[Union[str, Requirement]], bool, List[str]] + + +logger = logging.getLogger(__name__) + + +def freeze( + requirement=None, # type: Optional[List[str]] + find_links=None, # type: Optional[List[str]] + local_only=None, # type: Optional[bool] + user_only=None, # type: Optional[bool] + paths=None, # type: Optional[List[str]] + skip_regex=None, # type: Optional[str] + isolated=False, # type: bool + wheel_cache=None, # type: Optional[WheelCache] + exclude_editable=False, # type: bool + skip=() # type: Container[str] +): + # type: (...) -> Iterator[str] + find_links = find_links or [] + skip_match = None + + if skip_regex: + skip_match = re.compile(skip_regex).search + + for link in find_links: + yield '-f %s' % link + installations = {} # type: Dict[str, FrozenRequirement] + for dist in get_installed_distributions(local_only=local_only, + skip=(), + user_only=user_only, + paths=paths): + try: + req = FrozenRequirement.from_dist(dist) + except RequirementParseError as exc: + # We include dist rather than dist.project_name because the + # dist string includes more information, like the version and + # location. We also include the exception message to aid + # troubleshooting. + logger.warning( + 'Could not generate requirement for distribution %r: %s', + dist, exc + ) + continue + if exclude_editable and req.editable: + continue + installations[req.name] = req + + if requirement: + # the options that don't get turned into an InstallRequirement + # should only be emitted once, even if the same option is in multiple + # requirements files, so we need to keep track of what has been emitted + # so that we don't emit it again if it's seen again + emitted_options = set() # type: Set[str] + # keep track of which files a requirement is in so that we can + # give an accurate warning if a requirement appears multiple times. + req_files = collections.defaultdict(list) # type: Dict[str, List[str]] + for req_file_path in requirement: + with open(req_file_path) as req_file: + for line in req_file: + if (not line.strip() or + line.strip().startswith('#') or + (skip_match and skip_match(line)) or + line.startswith(( + '-r', '--requirement', + '-Z', '--always-unzip', + '-f', '--find-links', + '-i', '--index-url', + '--pre', + '--trusted-host', + '--process-dependency-links', + '--extra-index-url'))): + line = line.rstrip() + if line not in emitted_options: + emitted_options.add(line) + yield line + continue + + if line.startswith('-e') or line.startswith('--editable'): + if line.startswith('-e'): + line = line[2:].strip() + else: + line = line[len('--editable'):].strip().lstrip('=') + line_req = install_req_from_editable( + line, + isolated=isolated, + wheel_cache=wheel_cache, + ) + else: + line_req = install_req_from_line( + COMMENT_RE.sub('', line).strip(), + isolated=isolated, + wheel_cache=wheel_cache, + ) + + if not line_req.name: + logger.info( + "Skipping line in requirement file [%s] because " + "it's not clear what it would install: %s", + req_file_path, line.strip(), + ) + logger.info( + " (add #egg=PackageName to the URL to avoid" + " this warning)" + ) + elif line_req.name not in installations: + # either it's not installed, or it is installed + # but has been processed already + if not req_files[line_req.name]: + logger.warning( + "Requirement file [%s] contains %s, but " + "package %r is not installed", + req_file_path, + COMMENT_RE.sub('', line).strip(), line_req.name + ) + else: + req_files[line_req.name].append(req_file_path) + else: + yield str(installations[line_req.name]).rstrip() + del installations[line_req.name] + req_files[line_req.name].append(req_file_path) + + # Warn about requirements that were included multiple times (in a + # single requirements file or in different requirements files). + for name, files in six.iteritems(req_files): + if len(files) > 1: + logger.warning("Requirement %s included multiple times [%s]", + name, ', '.join(sorted(set(files)))) + + yield( + '## The following requirements were added by ' + 'pip freeze:' + ) + for installation in sorted( + installations.values(), key=lambda x: x.name.lower()): + if canonicalize_name(installation.name) not in skip: + yield str(installation).rstrip() + + +def get_requirement_info(dist): + # type: (Distribution) -> RequirementInfo + """ + Compute and return values (req, editable, comments) for use in + FrozenRequirement.from_dist(). + """ + if not dist_is_editable(dist): + return (None, False, []) + + location = os.path.normcase(os.path.abspath(dist.location)) + + from pip._internal.vcs import vcs, RemoteNotFoundError + vcs_backend = vcs.get_backend_for_dir(location) + + if vcs_backend is None: + req = dist.as_requirement() + logger.debug( + 'No VCS found for editable requirement "%s" in: %r', req, + location, + ) + comments = [ + '# Editable install with no version control ({})'.format(req) + ] + return (location, True, comments) + + try: + req = vcs_backend.get_src_requirement(location, dist.project_name) + except RemoteNotFoundError: + req = dist.as_requirement() + comments = [ + '# Editable {} install with no remote ({})'.format( + type(vcs_backend).__name__, req, + ) + ] + return (location, True, comments) + + except BadCommand: + logger.warning( + 'cannot determine version of editable source in %s ' + '(%s command not found in path)', + location, + vcs_backend.name, + ) + return (None, True, []) + + except InstallationError as exc: + logger.warning( + "Error when trying to get requirement for VCS system %s, " + "falling back to uneditable format", exc + ) + else: + if req is not None: + return (req, True, []) + + logger.warning( + 'Could not determine repository location of %s', location + ) + comments = ['## !! Could not determine repository location'] + + return (None, False, comments) + + +class FrozenRequirement(object): + def __init__(self, name, req, editable, comments=()): + # type: (str, Union[str, Requirement], bool, Iterable[str]) -> None + self.name = name + self.req = req + self.editable = editable + self.comments = comments + + @classmethod + def from_dist(cls, dist): + # type: (Distribution) -> FrozenRequirement + req, editable, comments = get_requirement_info(dist) + if req is None: + req = dist.as_requirement() + + return cls(dist.project_name, req, editable, comments=comments) + + def __str__(self): + req = self.req + if self.editable: + req = '-e %s' % req + return '\n'.join(list(self.comments) + [str(req)]) + '\n' diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/prepare.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/prepare.py new file mode 100644 index 0000000..6cf5f0e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/operations/prepare.py @@ -0,0 +1,287 @@ +"""Prepares a distribution for installation +""" + +import logging +import os + +from pip._vendor import requests + +from pip._internal.distributions import ( + make_distribution_for_install_requirement, +) +from pip._internal.distributions.installed import InstalledDistribution +from pip._internal.download import ( + is_dir_url, is_file_url, is_vcs_url, unpack_url, url_to_path, +) +from pip._internal.exceptions import ( + DirectoryUrlHashUnsupported, HashUnpinned, InstallationError, + PreviousBuildDirError, VcsHashUnsupported, +) +from pip._internal.utils.compat import expanduser +from pip._internal.utils.hashes import MissingHashes +from pip._internal.utils.logging import indent_log +from pip._internal.utils.misc import display_path, normalize_path +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional + + from pip._internal.distributions import AbstractDistribution + from pip._internal.download import PipSession + from pip._internal.index import PackageFinder + from pip._internal.req.req_install import InstallRequirement + from pip._internal.req.req_tracker import RequirementTracker + +logger = logging.getLogger(__name__) + + +class RequirementPreparer(object): + """Prepares a Requirement + """ + + def __init__( + self, + build_dir, # type: str + download_dir, # type: Optional[str] + src_dir, # type: str + wheel_download_dir, # type: Optional[str] + progress_bar, # type: str + build_isolation, # type: bool + req_tracker # type: RequirementTracker + ): + # type: (...) -> None + super(RequirementPreparer, self).__init__() + + self.src_dir = src_dir + self.build_dir = build_dir + self.req_tracker = req_tracker + + # Where still packed archives should be written to. If None, they are + # not saved, and are deleted immediately after unpacking. + self.download_dir = download_dir + + # Where still-packed .whl files should be written to. If None, they are + # written to the download_dir parameter. Separate to download_dir to + # permit only keeping wheel archives for pip wheel. + if wheel_download_dir: + wheel_download_dir = normalize_path(wheel_download_dir) + self.wheel_download_dir = wheel_download_dir + + # NOTE + # download_dir and wheel_download_dir overlap semantically and may + # be combined if we're willing to have non-wheel archives present in + # the wheelhouse output by 'pip wheel'. + + self.progress_bar = progress_bar + + # Is build isolation allowed? + self.build_isolation = build_isolation + + @property + def _download_should_save(self): + # type: () -> bool + # TODO: Modify to reduce indentation needed + if self.download_dir: + self.download_dir = expanduser(self.download_dir) + if os.path.exists(self.download_dir): + return True + else: + logger.critical('Could not find download directory') + raise InstallationError( + "Could not find or access download directory '%s'" + % display_path(self.download_dir)) + return False + + def prepare_linked_requirement( + self, + req, # type: InstallRequirement + session, # type: PipSession + finder, # type: PackageFinder + upgrade_allowed, # type: bool + require_hashes # type: bool + ): + # type: (...) -> AbstractDistribution + """Prepare a requirement that would be obtained from req.link + """ + # TODO: Breakup into smaller functions + if req.link and req.link.scheme == 'file': + path = url_to_path(req.link.url) + logger.info('Processing %s', display_path(path)) + else: + logger.info('Collecting %s', req) + + with indent_log(): + # @@ if filesystem packages are not marked + # editable in a req, a non deterministic error + # occurs when the script attempts to unpack the + # build directory + req.ensure_has_source_dir(self.build_dir) + # If a checkout exists, it's unwise to keep going. version + # inconsistencies are logged later, but do not fail the + # installation. + # FIXME: this won't upgrade when there's an existing + # package unpacked in `req.source_dir` + # package unpacked in `req.source_dir` + if os.path.exists(os.path.join(req.source_dir, 'setup.py')): + raise PreviousBuildDirError( + "pip can't proceed with requirements '%s' due to a" + " pre-existing build directory (%s). This is " + "likely due to a previous installation that failed" + ". pip is being responsible and not assuming it " + "can delete this. Please delete it and try again." + % (req, req.source_dir) + ) + req.populate_link(finder, upgrade_allowed, require_hashes) + + # We can't hit this spot and have populate_link return None. + # req.satisfied_by is None here (because we're + # guarded) and upgrade has no impact except when satisfied_by + # is not None. + # Then inside find_requirement existing_applicable -> False + # If no new versions are found, DistributionNotFound is raised, + # otherwise a result is guaranteed. + assert req.link + link = req.link + + # Now that we have the real link, we can tell what kind of + # requirements we have and raise some more informative errors + # than otherwise. (For example, we can raise VcsHashUnsupported + # for a VCS URL rather than HashMissing.) + if require_hashes: + # We could check these first 2 conditions inside + # unpack_url and save repetition of conditions, but then + # we would report less-useful error messages for + # unhashable requirements, complaining that there's no + # hash provided. + if is_vcs_url(link): + raise VcsHashUnsupported() + elif is_file_url(link) and is_dir_url(link): + raise DirectoryUrlHashUnsupported() + if not req.original_link and not req.is_pinned: + # Unpinned packages are asking for trouble when a new + # version is uploaded. This isn't a security check, but + # it saves users a surprising hash mismatch in the + # future. + # + # file:/// URLs aren't pinnable, so don't complain + # about them not being pinned. + raise HashUnpinned() + + hashes = req.hashes(trust_internet=not require_hashes) + if require_hashes and not hashes: + # Known-good hashes are missing for this requirement, so + # shim it with a facade object that will provoke hash + # computation and then raise a HashMissing exception + # showing the user what the hash should be. + hashes = MissingHashes() + + try: + download_dir = self.download_dir + # We always delete unpacked sdists after pip ran. + autodelete_unpacked = True + if req.link.is_wheel and self.wheel_download_dir: + # when doing 'pip wheel` we download wheels to a + # dedicated dir. + download_dir = self.wheel_download_dir + if req.link.is_wheel: + if download_dir: + # When downloading, we only unpack wheels to get + # metadata. + autodelete_unpacked = True + else: + # When installing a wheel, we use the unpacked + # wheel. + autodelete_unpacked = False + unpack_url( + req.link, req.source_dir, + download_dir, autodelete_unpacked, + session=session, hashes=hashes, + progress_bar=self.progress_bar + ) + except requests.HTTPError as exc: + logger.critical( + 'Could not install requirement %s because of error %s', + req, + exc, + ) + raise InstallationError( + 'Could not install requirement %s because of HTTP ' + 'error %s for URL %s' % + (req, exc, req.link) + ) + abstract_dist = make_distribution_for_install_requirement(req) + with self.req_tracker.track(req): + abstract_dist.prepare_distribution_metadata( + finder, self.build_isolation, + ) + if self._download_should_save: + # Make a .zip of the source_dir we already created. + if not req.link.is_artifact: + req.archive(self.download_dir) + return abstract_dist + + def prepare_editable_requirement( + self, + req, # type: InstallRequirement + require_hashes, # type: bool + use_user_site, # type: bool + finder # type: PackageFinder + ): + # type: (...) -> AbstractDistribution + """Prepare an editable requirement + """ + assert req.editable, "cannot prepare a non-editable req as editable" + + logger.info('Obtaining %s', req) + + with indent_log(): + if require_hashes: + raise InstallationError( + 'The editable requirement %s cannot be installed when ' + 'requiring hashes, because there is no single file to ' + 'hash.' % req + ) + req.ensure_has_source_dir(self.src_dir) + req.update_editable(not self._download_should_save) + + abstract_dist = make_distribution_for_install_requirement(req) + with self.req_tracker.track(req): + abstract_dist.prepare_distribution_metadata( + finder, self.build_isolation, + ) + + if self._download_should_save: + req.archive(self.download_dir) + req.check_if_exists(use_user_site) + + return abstract_dist + + def prepare_installed_requirement( + self, + req, # type: InstallRequirement + require_hashes, # type: bool + skip_reason # type: str + ): + # type: (...) -> AbstractDistribution + """Prepare an already-installed requirement + """ + assert req.satisfied_by, "req should have been satisfied but isn't" + assert skip_reason is not None, ( + "did not get skip reason skipped but req.satisfied_by " + "is set to %r" % (req.satisfied_by,) + ) + logger.info( + 'Requirement %s: %s (%s)', + skip_reason, req, req.satisfied_by.version + ) + with indent_log(): + if require_hashes: + logger.debug( + 'Since it is already installed, we are trusting this ' + 'package without checking its hash. To ensure a ' + 'completely repeatable environment, install into an ' + 'empty virtualenv.' + ) + abstract_dist = InstalledDistribution(req) + + return abstract_dist diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/pep425tags.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/pep425tags.py new file mode 100644 index 0000000..c6e58bf --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/pep425tags.py @@ -0,0 +1,384 @@ +"""Generate and work with PEP 425 Compatibility Tags.""" +from __future__ import absolute_import + +import distutils.util +import logging +import platform +import re +import sys +import sysconfig +import warnings +from collections import OrderedDict + +import pip._internal.utils.glibc +from pip._internal.utils.compat import get_extension_suffixes +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import ( + Tuple, Callable, List, Optional, Union, Dict + ) + + Pep425Tag = Tuple[str, str, str] + +logger = logging.getLogger(__name__) + +_osx_arch_pat = re.compile(r'(.+)_(\d+)_(\d+)_(.+)') + + +def get_config_var(var): + # type: (str) -> Optional[str] + try: + return sysconfig.get_config_var(var) + except IOError as e: # Issue #1074 + warnings.warn("{}".format(e), RuntimeWarning) + return None + + +def get_abbr_impl(): + # type: () -> str + """Return abbreviated implementation name.""" + if hasattr(sys, 'pypy_version_info'): + pyimpl = 'pp' + elif sys.platform.startswith('java'): + pyimpl = 'jy' + elif sys.platform == 'cli': + pyimpl = 'ip' + else: + pyimpl = 'cp' + return pyimpl + + +def version_info_to_nodot(version_info): + # type: (Tuple[int, ...]) -> str + # Only use up to the first two numbers. + return ''.join(map(str, version_info[:2])) + + +def get_impl_ver(): + # type: () -> str + """Return implementation version.""" + impl_ver = get_config_var("py_version_nodot") + if not impl_ver or get_abbr_impl() == 'pp': + impl_ver = ''.join(map(str, get_impl_version_info())) + return impl_ver + + +def get_impl_version_info(): + # type: () -> Tuple[int, ...] + """Return sys.version_info-like tuple for use in decrementing the minor + version.""" + if get_abbr_impl() == 'pp': + # as per https://github.com/pypa/pip/issues/2882 + # attrs exist only on pypy + return (sys.version_info[0], + sys.pypy_version_info.major, # type: ignore + sys.pypy_version_info.minor) # type: ignore + else: + return sys.version_info[0], sys.version_info[1] + + +def get_impl_tag(): + # type: () -> str + """ + Returns the Tag for this specific implementation. + """ + return "{}{}".format(get_abbr_impl(), get_impl_ver()) + + +def get_flag(var, fallback, expected=True, warn=True): + # type: (str, Callable[..., bool], Union[bool, int], bool) -> bool + """Use a fallback method for determining SOABI flags if the needed config + var is unset or unavailable.""" + val = get_config_var(var) + if val is None: + if warn: + logger.debug("Config variable '%s' is unset, Python ABI tag may " + "be incorrect", var) + return fallback() + return val == expected + + +def get_abi_tag(): + # type: () -> Optional[str] + """Return the ABI tag based on SOABI (if available) or emulate SOABI + (CPython 2, PyPy).""" + soabi = get_config_var('SOABI') + impl = get_abbr_impl() + if not soabi and impl in {'cp', 'pp'} and hasattr(sys, 'maxunicode'): + d = '' + m = '' + u = '' + is_cpython = (impl == 'cp') + if get_flag( + 'Py_DEBUG', lambda: hasattr(sys, 'gettotalrefcount'), + warn=is_cpython): + d = 'd' + if sys.version_info < (3, 8) and get_flag( + 'WITH_PYMALLOC', lambda: is_cpython, warn=is_cpython): + m = 'm' + if sys.version_info < (3, 3) and get_flag( + 'Py_UNICODE_SIZE', lambda: sys.maxunicode == 0x10ffff, + expected=4, warn=is_cpython): + u = 'u' + abi = '%s%s%s%s%s' % (impl, get_impl_ver(), d, m, u) + elif soabi and soabi.startswith('cpython-'): + abi = 'cp' + soabi.split('-')[1] + elif soabi: + abi = soabi.replace('.', '_').replace('-', '_') + else: + abi = None + return abi + + +def _is_running_32bit(): + # type: () -> bool + return sys.maxsize == 2147483647 + + +def get_platform(): + # type: () -> str + """Return our platform name 'win32', 'linux_x86_64'""" + if sys.platform == 'darwin': + # distutils.util.get_platform() returns the release based on the value + # of MACOSX_DEPLOYMENT_TARGET on which Python was built, which may + # be significantly older than the user's current machine. + release, _, machine = platform.mac_ver() + split_ver = release.split('.') + + if machine == "x86_64" and _is_running_32bit(): + machine = "i386" + elif machine == "ppc64" and _is_running_32bit(): + machine = "ppc" + + return 'macosx_{}_{}_{}'.format(split_ver[0], split_ver[1], machine) + + # XXX remove distutils dependency + result = distutils.util.get_platform().replace('.', '_').replace('-', '_') + if result == "linux_x86_64" and _is_running_32bit(): + # 32 bit Python program (running on a 64 bit Linux): pip should only + # install and run 32 bit compiled extensions in that case. + result = "linux_i686" + + return result + + +def is_manylinux1_compatible(): + # type: () -> bool + # Only Linux, and only x86-64 / i686 + if get_platform() not in {"linux_x86_64", "linux_i686"}: + return False + + # Check for presence of _manylinux module + try: + import _manylinux + return bool(_manylinux.manylinux1_compatible) + except (ImportError, AttributeError): + # Fall through to heuristic check below + pass + + # Check glibc version. CentOS 5 uses glibc 2.5. + return pip._internal.utils.glibc.have_compatible_glibc(2, 5) + + +def is_manylinux2010_compatible(): + # type: () -> bool + # Only Linux, and only x86-64 / i686 + if get_platform() not in {"linux_x86_64", "linux_i686"}: + return False + + # Check for presence of _manylinux module + try: + import _manylinux + return bool(_manylinux.manylinux2010_compatible) + except (ImportError, AttributeError): + # Fall through to heuristic check below + pass + + # Check glibc version. CentOS 6 uses glibc 2.12. + return pip._internal.utils.glibc.have_compatible_glibc(2, 12) + + +def get_darwin_arches(major, minor, machine): + # type: (int, int, str) -> List[str] + """Return a list of supported arches (including group arches) for + the given major, minor and machine architecture of an macOS machine. + """ + arches = [] + + def _supports_arch(major, minor, arch): + # type: (int, int, str) -> bool + # Looking at the application support for macOS versions in the chart + # provided by https://en.wikipedia.org/wiki/OS_X#Versions it appears + # our timeline looks roughly like: + # + # 10.0 - Introduces ppc support. + # 10.4 - Introduces ppc64, i386, and x86_64 support, however the ppc64 + # and x86_64 support is CLI only, and cannot be used for GUI + # applications. + # 10.5 - Extends ppc64 and x86_64 support to cover GUI applications. + # 10.6 - Drops support for ppc64 + # 10.7 - Drops support for ppc + # + # Given that we do not know if we're installing a CLI or a GUI + # application, we must be conservative and assume it might be a GUI + # application and behave as if ppc64 and x86_64 support did not occur + # until 10.5. + # + # Note: The above information is taken from the "Application support" + # column in the chart not the "Processor support" since I believe + # that we care about what instruction sets an application can use + # not which processors the OS supports. + if arch == 'ppc': + return (major, minor) <= (10, 5) + if arch == 'ppc64': + return (major, minor) == (10, 5) + if arch == 'i386': + return (major, minor) >= (10, 4) + if arch == 'x86_64': + return (major, minor) >= (10, 5) + if arch in groups: + for garch in groups[arch]: + if _supports_arch(major, minor, garch): + return True + return False + + groups = OrderedDict([ + ("fat", ("i386", "ppc")), + ("intel", ("x86_64", "i386")), + ("fat64", ("x86_64", "ppc64")), + ("fat32", ("x86_64", "i386", "ppc")), + ]) # type: Dict[str, Tuple[str, ...]] + + if _supports_arch(major, minor, machine): + arches.append(machine) + + for garch in groups: + if machine in groups[garch] and _supports_arch(major, minor, garch): + arches.append(garch) + + arches.append('universal') + + return arches + + +def get_all_minor_versions_as_strings(version_info): + # type: (Tuple[int, ...]) -> List[str] + versions = [] + major = version_info[:-1] + # Support all previous minor Python versions. + for minor in range(version_info[-1], -1, -1): + versions.append(''.join(map(str, major + (minor,)))) + return versions + + +def get_supported( + versions=None, # type: Optional[List[str]] + noarch=False, # type: bool + platform=None, # type: Optional[str] + impl=None, # type: Optional[str] + abi=None # type: Optional[str] +): + # type: (...) -> List[Pep425Tag] + """Return a list of supported tags for each version specified in + `versions`. + + :param versions: a list of string versions, of the form ["33", "32"], + or None. The first version will be assumed to support our ABI. + :param platform: specify the exact platform you want valid + tags for, or None. If None, use the local system platform. + :param impl: specify the exact implementation you want valid + tags for, or None. If None, use the local interpreter impl. + :param abi: specify the exact abi you want valid + tags for, or None. If None, use the local interpreter abi. + """ + supported = [] + + # Versions must be given with respect to the preference + if versions is None: + version_info = get_impl_version_info() + versions = get_all_minor_versions_as_strings(version_info) + + impl = impl or get_abbr_impl() + + abis = [] # type: List[str] + + abi = abi or get_abi_tag() + if abi: + abis[0:0] = [abi] + + abi3s = set() + for suffix in get_extension_suffixes(): + if suffix.startswith('.abi'): + abi3s.add(suffix.split('.', 2)[1]) + + abis.extend(sorted(list(abi3s))) + + abis.append('none') + + if not noarch: + arch = platform or get_platform() + arch_prefix, arch_sep, arch_suffix = arch.partition('_') + if arch.startswith('macosx'): + # support macosx-10.6-intel on macosx-10.9-x86_64 + match = _osx_arch_pat.match(arch) + if match: + name, major, minor, actual_arch = match.groups() + tpl = '{}_{}_%i_%s'.format(name, major) + arches = [] + for m in reversed(range(int(minor) + 1)): + for a in get_darwin_arches(int(major), m, actual_arch): + arches.append(tpl % (m, a)) + else: + # arch pattern didn't match (?!) + arches = [arch] + elif arch_prefix == 'manylinux2010': + # manylinux1 wheels run on most manylinux2010 systems with the + # exception of wheels depending on ncurses. PEP 571 states + # manylinux1 wheels should be considered manylinux2010 wheels: + # https://www.python.org/dev/peps/pep-0571/#backwards-compatibility-with-manylinux1-wheels + arches = [arch, 'manylinux1' + arch_sep + arch_suffix] + elif platform is None: + arches = [] + if is_manylinux2010_compatible(): + arches.append('manylinux2010' + arch_sep + arch_suffix) + if is_manylinux1_compatible(): + arches.append('manylinux1' + arch_sep + arch_suffix) + arches.append(arch) + else: + arches = [arch] + + # Current version, current API (built specifically for our Python): + for abi in abis: + for arch in arches: + supported.append(('%s%s' % (impl, versions[0]), abi, arch)) + + # abi3 modules compatible with older version of Python + for version in versions[1:]: + # abi3 was introduced in Python 3.2 + if version in {'31', '30'}: + break + for abi in abi3s: # empty set if not Python 3 + for arch in arches: + supported.append(("%s%s" % (impl, version), abi, arch)) + + # Has binaries, does not use the Python API: + for arch in arches: + supported.append(('py%s' % (versions[0][0]), 'none', arch)) + + # No abi / arch, but requires our implementation: + supported.append(('%s%s' % (impl, versions[0]), 'none', 'any')) + # Tagged specifically as being cross-version compatible + # (with just the major version specified) + supported.append(('%s%s' % (impl, versions[0][0]), 'none', 'any')) + + # No abi / arch, generic Python + for i, version in enumerate(versions): + supported.append(('py%s' % (version,), 'none', 'any')) + if i == 0: + supported.append(('py%s' % (version[0]), 'none', 'any')) + + return supported + + +implementation_tag = get_impl_tag() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/pyproject.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/pyproject.py new file mode 100644 index 0000000..43efbed --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/pyproject.py @@ -0,0 +1,171 @@ +from __future__ import absolute_import + +import io +import os +import sys + +from pip._vendor import pytoml, six + +from pip._internal.exceptions import InstallationError +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Any, Tuple, Optional, List + + +def _is_list_of_str(obj): + # type: (Any) -> bool + return ( + isinstance(obj, list) and + all(isinstance(item, six.string_types) for item in obj) + ) + + +def make_pyproject_path(setup_py_dir): + # type: (str) -> str + path = os.path.join(setup_py_dir, 'pyproject.toml') + + # Python2 __file__ should not be unicode + if six.PY2 and isinstance(path, six.text_type): + path = path.encode(sys.getfilesystemencoding()) + + return path + + +def load_pyproject_toml( + use_pep517, # type: Optional[bool] + pyproject_toml, # type: str + setup_py, # type: str + req_name # type: str +): + # type: (...) -> Optional[Tuple[List[str], str, List[str]]] + """Load the pyproject.toml file. + + Parameters: + use_pep517 - Has the user requested PEP 517 processing? None + means the user hasn't explicitly specified. + pyproject_toml - Location of the project's pyproject.toml file + setup_py - Location of the project's setup.py file + req_name - The name of the requirement we're processing (for + error reporting) + + Returns: + None if we should use the legacy code path, otherwise a tuple + ( + requirements from pyproject.toml, + name of PEP 517 backend, + requirements we should check are installed after setting + up the build environment + ) + """ + has_pyproject = os.path.isfile(pyproject_toml) + has_setup = os.path.isfile(setup_py) + + if has_pyproject: + with io.open(pyproject_toml, encoding="utf-8") as f: + pp_toml = pytoml.load(f) + build_system = pp_toml.get("build-system") + else: + build_system = None + + # The following cases must use PEP 517 + # We check for use_pep517 being non-None and falsey because that means + # the user explicitly requested --no-use-pep517. The value 0 as + # opposed to False can occur when the value is provided via an + # environment variable or config file option (due to the quirk of + # strtobool() returning an integer in pip's configuration code). + if has_pyproject and not has_setup: + if use_pep517 is not None and not use_pep517: + raise InstallationError( + "Disabling PEP 517 processing is invalid: " + "project does not have a setup.py" + ) + use_pep517 = True + elif build_system and "build-backend" in build_system: + if use_pep517 is not None and not use_pep517: + raise InstallationError( + "Disabling PEP 517 processing is invalid: " + "project specifies a build backend of {} " + "in pyproject.toml".format( + build_system["build-backend"] + ) + ) + use_pep517 = True + + # If we haven't worked out whether to use PEP 517 yet, + # and the user hasn't explicitly stated a preference, + # we do so if the project has a pyproject.toml file. + elif use_pep517 is None: + use_pep517 = has_pyproject + + # At this point, we know whether we're going to use PEP 517. + assert use_pep517 is not None + + # If we're using the legacy code path, there is nothing further + # for us to do here. + if not use_pep517: + return None + + if build_system is None: + # Either the user has a pyproject.toml with no build-system + # section, or the user has no pyproject.toml, but has opted in + # explicitly via --use-pep517. + # In the absence of any explicit backend specification, we + # assume the setuptools backend that most closely emulates the + # traditional direct setup.py execution, and require wheel and + # a version of setuptools that supports that backend. + + build_system = { + "requires": ["setuptools>=40.8.0", "wheel"], + "build-backend": "setuptools.build_meta:__legacy__", + } + + # If we're using PEP 517, we have build system information (either + # from pyproject.toml, or defaulted by the code above). + # Note that at this point, we do not know if the user has actually + # specified a backend, though. + assert build_system is not None + + # Ensure that the build-system section in pyproject.toml conforms + # to PEP 518. + error_template = ( + "{package} has a pyproject.toml file that does not comply " + "with PEP 518: {reason}" + ) + + # Specifying the build-system table but not the requires key is invalid + if "requires" not in build_system: + raise InstallationError( + error_template.format(package=req_name, reason=( + "it has a 'build-system' table but not " + "'build-system.requires' which is mandatory in the table" + )) + ) + + # Error out if requires is not a list of strings + requires = build_system["requires"] + if not _is_list_of_str(requires): + raise InstallationError(error_template.format( + package=req_name, + reason="'build-system.requires' is not a list of strings.", + )) + + backend = build_system.get("build-backend") + check = [] # type: List[str] + if backend is None: + # If the user didn't specify a backend, we assume they want to use + # the setuptools backend. But we can't be sure they have included + # a version of setuptools which supplies the backend, or wheel + # (which is needed by the backend) in their requirements. So we + # make a note to check that those requirements are present once + # we have set up the environment. + # This is quite a lot of work to check for a very specific case. But + # the problem is, that case is potentially quite common - projects that + # adopted PEP 518 early for the ability to specify requirements to + # execute setup.py, but never considered needing to mention the build + # tools themselves. The original PEP 518 code had a similar check (but + # implemented in a different way). + backend = "setuptools.build_meta:__legacy__" + check = ["setuptools>=40.8.0", "wheel"] + + return (requires, backend, check) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__init__.py new file mode 100644 index 0000000..c39f63f --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__init__.py @@ -0,0 +1,78 @@ +from __future__ import absolute_import + +import logging + +from .req_install import InstallRequirement +from .req_set import RequirementSet +from .req_file import parse_requirements +from pip._internal.utils.logging import indent_log +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Any, List, Sequence + +__all__ = [ + "RequirementSet", "InstallRequirement", + "parse_requirements", "install_given_reqs", +] + +logger = logging.getLogger(__name__) + + +def install_given_reqs( + to_install, # type: List[InstallRequirement] + install_options, # type: List[str] + global_options=(), # type: Sequence[str] + *args, # type: Any + **kwargs # type: Any +): + # type: (...) -> List[InstallRequirement] + """ + Install everything in the given list. + + (to be called after having downloaded and unpacked the packages) + """ + + if to_install: + logger.info( + 'Installing collected packages: %s', + ', '.join([req.name for req in to_install]), + ) + + with indent_log(): + for requirement in to_install: + if requirement.conflicts_with: + logger.info( + 'Found existing installation: %s', + requirement.conflicts_with, + ) + with indent_log(): + uninstalled_pathset = requirement.uninstall( + auto_confirm=True + ) + try: + requirement.install( + install_options, + global_options, + *args, + **kwargs + ) + except Exception: + should_rollback = ( + requirement.conflicts_with and + not requirement.install_succeeded + ) + # if install did not succeed, rollback previous uninstall + if should_rollback: + uninstalled_pathset.rollback() + raise + else: + should_commit = ( + requirement.conflicts_with and + requirement.install_succeeded + ) + if should_commit: + uninstalled_pathset.commit() + requirement.remove_temporary_source() + + return to_install diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ea7a0f5e6328225aea01473361e0f4c8a6fee731 GIT binary patch literal 1749 zcmZuyPj4GV6rY)0uh$#fN!(CSIj|h~W2v%`)7ORL#;sj2~JEEGn zfm_;EMJ@3HujE~^kko@ZM!YTu;HM@UNi%3Bi@{>D6fA*_#}-(fHTrh2%*kT^ih^14OstX%w^{k9cZM$$vzV1xxb*xT6J_pTW$32Qop@SLhfs z%*b(x@KexzfS%wJd_pi%))Vy2&$!e*K0c~UDm%8^E_amtnN169DmxYCuw7Y>zlNMXMCq!HRCU*rKVf8k#&h-^P`8ebs*|exVd5Ou zPGIE=w1v_ukERyC8jB-$;>zD(-81Wx%JG8v?p-}Ub%G#o?zr%L7_;Q~e8lCU8pLVe zk5gX_xL*S03qZBwm8Ng1%-`mI1i9qQ4||GBe-Mt$7MAU&A`6+(r_3+XVHoX#VEh<1 z?DM=`IvKw@JJD>5GH?|sFq|8`>%W$d$yGlx#WNoS7?Y_@n0X6GA25IH9pMSyLEn-+ zdlSh9sG&gYG)#D#Xwq5L79_dUm*lUkJCyM#RJ=P1Ww)0J#%11JJLvZ5+DInj^zGix z>R@m%9#gS)eS08RVf54P{q8UxUYnKAwbj+@qr=f#g;AE1#wh@ihN26{bt#CkqO>zS z)ZV%QFUpePjWrWhSW(D?QL)?#N}WB_b_1DN@y@hcx@1)#|fKr>BD*+`*^v(x}} zA1+)E3zg9*OM9_Q+I8(fqx8AdcAWMyZSQ1pDywj?ZWG3G@SaSoZ)u7q@LLpHSomr7!#UxaqfMw}{cT0WGAG|vhd@pesn5Y^o6 z;@nqO`p$K;FS6}W(79}fvY%^bcfb5DTzCTXrL!Z-{Eq)nUq%&{n6BwaNcxJda(0j?nR zV!@{`)yq&>owKUy6e<>ZXXa~~$}9h8p$>;|m~_q2&P*^*nl%3`(mZUsN-6X%rMlMV z>dv%ITuM#LK+r43&OmhmKGRhthT2_EGFAwF!!%~@1E~|2)bZ>`Y`kI-L@-PM)^pJF Fe*uS5?_2-? literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/constructors.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/constructors.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..a890cf0fd60f8d12fcf8241a8c76c43121b63098 GIT binary patch literal 8021 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_file.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_file.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..bffb869c70bdab442e5d1d15c1af110d3a440166 GIT binary patch literal 9426 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 Cg>X** literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_install.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_install.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..aa90725e67c44daed581d74d515546f31656d125 GIT binary patch literal 25779 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_tracker.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_tracker.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ac31cd1b5c335e931ae6bbb211aee160ba431861 GIT binary patch literal 3274 zcmZ`+%W@mX744ok9(;(TWQme&CKV+?RY=OJL{)NJDXA#NW?6w`nvSJOQd1zhNe(!e z0ec1%i2}0_wM@#t04$YNz96f7MQ^>z4`h)=l5=}V@nL#UefxF0`##RS-S~Q9qRR07 z`|sn{qdH^XQRn>Upz|0d{~L&4f+wuYL(ZvfC01ye+74|~JE3E0H*`(yg&t}<@w-77 zm^DsP=~lxkXR@mPf;l&-b?af>%z4Q~cQTypPK8t5>2SJxExcyN{bZ&)8_t?`kj!*0jCpwTGbSpc`j&~Rymf4c^TPUyHEREYysW|XRBJQOl71nhxZBHA(Ztxq zhV1s9#!9w}OdVoi=6A1Nyoy#nUtRekTK~G)Tx))2*i@@6H(Tx9jl-U7I67D>q-tS} z4xaalI7?fJw!e~vb_@gdSxfVxl_cwOuaE7!GA*!=^DItx+a%BV&qn7lO1=&vS;z&0 zHMy|fGFa0V4r)iZ!b9x}Uj(SVQq#~EHBm=D5EEh&bwyS?H8CZo-?C#K*2OhgU`EfJ z6JrCa>`K+aPiT-L~+{L&%^2Ura zYIS@Eb!5|8!9Qh1FscaRvBwr?>71Zh*Nl3nqebprbHrAi4 ze6hOz+d)mqy~U!GxnXHf$V3)WJG*fz1|O{`*(#)10Mn_N^Mw=cg?nnSur3$-d7N(l z5J#h~tt{8RO!s4zrP|(x6WvHiA zwVh*O5W&wXmiasQI+w}TJErbpm;b2co{IM&>hgX|EpKIskSbq(bg;Y~J=#~@LHb~; zbAM;&U@(Z1M-Ml5)O~#0>GH;MFYYbIC6*TN-+#D&xc_mV22F|L6gUL9~lZ56G)CAk3QNRZeA&Pg@>ZgWKz8mODYl(&@VIL4;spAVOFf!e#Gx)99ye zW1wu2y6Qs^SdOeARTTXM-P{6U*5J;S2c9stY2(w6+O)`=h>V02M~uKmU{MPgKt%cN zM7Gj?ui>aW7}0?|Xh#Kt6fQ+;A93lKq0P(U!94PS%=2@sE2Z;)z#JuC+h_o0`Uo2& zpb?JrE7*t+dB+;rV>ad^XUvYQ!tHn?A6O5D))={{6uP4QomRe+#GBg7cUlh~{8G>L zRT909i=C`rL|dx0P5AqIBItgMMY*xGHOB`ZUgZ#iamjo^Yac7g6GrQQq5+LbPiTJ3kB}!u7BuBY z&fph?J#>!wxAR9Xat0q-LwDqk*_L$!dFc)RhW(0t$=2CR_6|KM;>Q` zKMuW)U-+G1*H+>U&VU6gyMC^U>Kjh`3hUVVcKXQ0p0%Mp#vOFFAMuXrLu4+_iiy#r zu+93Zv0ZWrobhMxC40qE>!pEG!)Xrg-pd!_e4&*f!o}gjrlgdy*^iUrlZAV^=C22L zo(O?N1HK|NGvZvHX-um{SOZC*P->Z4PS%sDu06}L-F|OXDclqe?XCT_=VjNGN~M|h zR-4aPn;UALR!u(1bE)V)IpKM&VkA4eC4{0VRyT;;9k#su-t>v~q+nQ4gp`i2^{yHA+FE9t$hQ1&bN~y;%UyS-_6acph`w zKe3heS11Qc(FoKn9B*u6R8n)){V|bC=s9nY$25P*AhhNM%KK}h4v+vK+@t!xgZV2= zbCQWKK!Z{y*{4l=(XBu^yo7{czc&vDN}B|Uv#f3zj2aCZmVtTcxr;Jt*W7h~pq)Js zW|MS-n^#C?7@Lg=x)Re?S4NSpMo~8t{e;@}DBA0{l5$3Ugss$%i2RfYMe~_F#+bU= z&Tz3E6qLdzPuks9+QM@{Jth7#NzX7wdGk7oF==206M+*{0ymfq{GjG=Me~i@B-mEJ z=qm`O$a?B?A{15XXCT_AX9u!V3Hm#D2`s&T1uXT8ILVhzA1vhqX8uZ+!yfHHmjLXD z>oQjq!P-NcCdib#EJRp&QR>Q>eMKOd|o AMF0Q* literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_uninstall.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_uninstall.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ae76af6620774c016a2b358808236fde6b3f7f82 GIT binary patch literal 17401 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

ch{gIE7QI$u`a z-JSiV@y<#!G(75|NMH3$WJT#4wdN*p1VykSYsk_^&Q`6t4#?XD)bOMIUSoOL2bEA!TaBg% z#N-807Am(Y=q;M!ZLqlnDh5#|xk*W;CZx<##QuSMY{L$^4hW!)%&egE^qn*oIc=pa z*Kwf;tUIo4S!t+;Ip7sMSxj>&BKcWMaidRg1Pwc?iA%VGpCQqVu8%LXkkRc_}DD^mxmB1}Lp>_N`_5aniK_f@GvELi!ensUD~B z4|un=+5qB?bw-DRyW50LfYPALMx*F!H1x5;;kdd9l1fxGTOBBSsu|C3`Tz+4^MdZt z0ij-fy|$uJ6wy|@1JvbtP))?}R5D?wd#(u$(i{PJj*VGy<>G2BKvSn5IjyUT@Td=(W~UPlEM&*k{;BVYLcV;p1GH78C6F<<11hCa{tCNbKv? zSc)ZD5x~*t&pJCH^c+BEA6_xb40Aw6HOD4ha%NzG9~f&m*l&xX`diSXc51@=#2e zmm36SumiV?Lpw4Cl&$gvzY>{{XD@Mf1tbmdYt>j`idiP8#ENp&0K10HG5A)i^n?X4 zo8Yu*F7I6&H`yrvhK-Uz4JU2)ik~sja#Fm`fh2z-%D|>N2kzZR<6o5BJQP6Q}tbfoH_*X(IeteJO^G7}r>u*8%3K6Utp;q{1X?F}9mHGp z7nzK9GWRb83}KJnf^M>kdlzkvAcD)QNl=xE{%6z^t}rqdHVn23Hq8uFb?@wFF6KR& znOIm_t;2==2_6#3NWYof3)u7^(*`i`JQE&ot8cH{YPmPdW$e>4=DccbybA`H0|TVM z0553<(90dS0?psIbSoPtM=b+4q`7awCh(>2WXMW=ctY6nMLin$KKd3kH_(Lo{eFsd z*RmMF?@KGWzO!ZmGe9Tv4s7J~zB6JY?$+2a6Jv^X9q?0)!_iO(47{k2FcQ`d^ ziUdyAHx;_oMn`&#Z=6*)!y*@M?kexp`|Rp3GZD=+QcwGYk4OW}LjMhAf`^b8Y5J)g z%2_ZGe5*u(c3$ptki!N1>z)3&Y&B|if}i|@fb3il8gxI+oyiCY$Ug;>n&T~1bLk2S0=YJniU_--epJy)C>;9 zyWYP}-ppG$t6e;&vewep;x^jIiQ=%e z64Ab|-uX+NR*NJcp@!lNCrBE;Q7=iSkb|ULP+lxKBF8`w2trsQbvW?an_ZztGW|b~ zfoLw=!+>c(19UgfsZ-7v_ADlxHhU*NYs$L9#GGk{PT`U{{}bGB&X_OE(GU()53KX+ z*1McBo%_uB9w-5E)%zuw2#yDrDIEGX*hcFdGSf?8YRA>g)Si>~Sw1N*%)ui>7MtSf z30Vxntq8%EhhY0H6T;3kddJc3G|U)?C6r_z5MI20)%b$pr3TI~JFgk9quy({!00nv z4=)8)&Ga6BrR{Z~!0uWAD51N^k5hp9dimpnFX}ufrc*(#$fI4{^yaSmuqf)RbqWW4 z$=fS6teiNf;F-Z`sL!&~&)%&2avXXAk2q{re-o4}?UQwkGB^o_FKPuxJ^;~CnvcGU zQl7uGxiZ=ns)sr}0OIMd`T!5=026Kn^&az5@X>da`gPowQd(sFIcEMElanlA`8W6O z4_9@XP0qAPJ~@t3h7Dgj36E=e;J+=C`Zpelz4nyqWVE+aVQ zEa6;AZ}7KKVDIqq^;)}{wEcMwQLvHSd+0Nnc&x%=DIWoZ5kFU}KyH9*-X;WcHOg13 zJl&0RGS#ZrsaLD&yBxwu?))`AlAh}CAcOT0DEXPLlwt{Wnvc&rItQ6qa7?d8RxT`Kuj&*?ec_5;%e~{ z`Edp}bW#vf$G?_HNGK+}11^<31iU2tkJaI0Zs7*a4Ky6v&Ablf@B=z_-d;WjN>VY5!xxq zj8Ecz&y2zG!!Dj3?ww5U*xeHzmYY~Tf(gP@Sv_vg5j@aRUY>0npFwWRJ%TgfPJ%9! zCuj#aoi1=aA&JG}fa}RvbKyKfj%l>>c*-SDQfG=eo_PepQR|kv9p=?-)Xj#|w0T&E zt>H-irxY&gB9hX~n3Q~$Zy#i`p9yh)l=g4J{14PWnT8%J+&yq-snA~|AE0ZA9Gie~~!1!cDP%st9rDpizO;{5Zd$n8WtB{tFg zy=KnhS0<)UT9fE9{RCSCM?)N%c$_F4kkso8-O^7U0(j&ub=csE7s@%{H{yWwE#ti| zAgLL=B%DS(@!Kft4xBKHUpN{NDwG4VNbx8aIOXUd4WlRDPYb9ufhkhBM_U_Bl%Ltz zC%7&@$n-Ni1;KPblpfQ%N1}~y7*~zgWPHFD-?}PcF|qp)2Fms8^a+$jnqI#S;|BX5 zJ~?+9(gzxCZ-6#|mX|Y8JpXqbO;k164RJJ6pcT;31T&Yfm{sZL zmLmY|S`&5qn|w!BRjWuCd_eIIW1o96%8!#MVn0hAs017iAZ|{ydE9lB60H#BMu%g9 zfppU&)h(LgBQ)J4D?f}IBgNPu%S?ajIF3CFpI9Eu4J%E|25xT{|5oqtT}-Y=Iw3$) zXl`hcweg@2cVTy#!SMtPL6q79r(Iy|48ajt+u~s^B4yxj*OnGRZhV(QDgD+|*HH$s zF}fb}5yg=4+*_8HU8i-H>pgclc71D)xEL09`L)Gkjg@J2LkWTzXVW2jPE3qqi+lHF zT)|}|n2<}!%pjn?ghy}^@0}z@#{e-c*>y8KtUw77S{o0K?IP6GA}ggvyhZ*QF$fOj z?N+d&8Sq~E&V}Db9Q{8S$t4FMjAk~B>L>16vU_mm$VHqq)|-A+&H?oLUg$llAL;Mc zuZm|{jg?h|4Z)iQ`wZN^t=;*h3%yf!7lunZfYU>QKmchPH&N`stMq*!hD6sU?_TKb zdr5DW;+gG*cIm4{#!qZVW?TIM$Wls+i&hhZkqjch^_HSUPE3HGFza72`8Jb2lRfPJ zFYxYrq}U}LpF@1Z{p?Iys#g|>#ge-#hlQt&tU-r9jT3r~m% zO9VXLrNQmPcPtxwqy#R+!WddnzukCBB6^+PV^ z5Mqj_IQB$*^{UoYbgy<4Bai3}r4qOR2VHCriZ>1(yJiO@Rb=kOc?-vcrROfT(c9=^ zFH14w_c$4Hfnnc6TE@->$!8h-k^LxCC|rVnimE*?c{>Na?5;U_;;HKU zX7FR2xgOGW2~>6tdpRj}0{8R0-#H>&{_wz+evV3dj5Yf1E(GQPv5{y2Z3CqIkM{f0 z#uVDH)PI$GoSvfBXQVyczhktW72_R4B3fx5!gGh7P($}50{QttZrG36&jGrR^`iUp z_Qi41(z{ofc-pU@-ZwXv-Z$Hi_cIv5ABD%g*&P6RQty`e9gM0yk0%q9IUwUb8Ph@l zz4U({^8x(l;M1PcBa#%GJ$7>%F6cY3b!;e|qP^U1R5=U8t_X%t$TuXW0L`^}ZGS zt?-n0M4si{vV90#^&Ny-VNJkoP;}&uWAUi*#v2>6%z`5>fCnG;5IHDs$b;mBV;H%u zuHpXl*!>yaV;(OI_Jt+R31yCkj|>WkhJSQWV9&bGexbjQ9D*^NMHxWU$sF%^yh`>) zdc_#*N8ji8eFQxJv;Enfvhdyf;6Q)>&O&$|V>{s8e@lXv-?ssWS-L2t=lXN^Ed9W+ z^sn{z3*`?AT@G?gXybSLHqgk)#ol9!<1$v`(ISquPX#yvi1ni1zR^&fHk}E0KOx#E zEhrrXc2G{rsdApN0SX{PpC^yWqI-oYZKK-1rf8yNn>H-V`LuWLF6}0ta1d3F@WAlA z88L&Q*K90BIk*5rec!wIb7ltJ(g+FX<8uqRdD|X>PKs!R;DmLvv-K#H$YeczyFZH1PIHU;a$|DMm~T`Tzzy> zzd4ss?`;EiCaCxWIhEf-MVz|jhFt_Ylh`@RUF6w1q18RUUSRp14DuWOok~B$J(6mX{D_|@QkvIrr6UV`T z1-hA99j7{oB?2n&5Y7ST3lE(nQbgn8C7;TUCKQ%SXXro)_}#^_lF(U(eyFg4;K3mx zDDzW|l@;}mIO>953%0S6GNLlf-kw!nP+Q1SSD62mXR*-q;)1)2;*aJWVHDOGt((jv zIU~_vqj*L(NvT&Nn+2ON_f|Vw6UH8W%Lo{`#K4*t17ZQXB35@h5OZNAa(UuO zb64$SF@$Z<(pB8A(G*NS(wHnH=m@dl_>zep?=k1iKW5PknyH1Min25oc|52TEe!Ee zM0rHa4CBwEJiAPy(Ggb6AajXH*CCZMmd%178|!DAE=_B&}t&WVofeIr?NfUqwiY*o9xqS@g# z85NotGMX%lh@5C7QmXhEE)qV*5(!7L>Yg{?Y=!gcBl2R@r{ z)#$q+_3xPB2qXM^-kPyA`6E2&Nb2lR`2KTBls`lU4<$4rCMtG*=A>Pm;kkEmwmh5G zCr-*0mo7YTcN}ZZnsMfM$MZfS={tFZ+s)i@>=}8J$45drEB|TE(b#&%JcN9-Y&)MI z{KaJ{hRIlHYu1`W8wCXK<;@eo;g*@dgZHqI3X)%tF<6H4sgs^ZJ}oClK1w)_9QJ<* zHJQSVVD*lEwoC-BzH$Zb%-( z1YpY5j;H=N^G0@t+)-+)zmEj5BHHAWa|#zH6>}~k zW=3Zf2m?0|1!Q{;e&aB7L;=AUf#lQ_zZw&Y9bpVhuQjz zfK1#3P8MhudHO4t#B}>TRvD30sL8dtgvkUHmj)Ia-XpLY6*()5XIsiXy_ zhwt}%hCc8>(^o%ZHWwqAF^QrKe_`NKH8sNJh+Gj~>x*r7%TzDm=oep!dTGR{TI!c! z3ufRQ&j5wGo=Y1ph~Fh|;7Udr@uX*gSf3m?y@zBZS$&+0cvQr<^x<+&T9D)D+c=J% z!g2IRCXSU&9yH&^LGx{R=Q-*eMqMDDf@4|m_-Mq!u2YL+zE{Xk1bL2e>#5*EWT~YI zY9(7F0HMS`1H?8nFg@4}>*?`GeX+EsbBnT4Sh{bZLgY}L?OnT9kW=N_k=Y!$3dZ5@ zXx;RF8iT*dH#a?NIv1I_pW<_|JH6CqxP0zQy;<=n5YKZ)+k!u=ttG@p{suZx)ST-7 zF!^I7jK$WPHc+4NrNn$w$3rEy>m6u(VZx92CihJShl>J^a$5?K5S&wxxVQdz{l*nJQ26kr;Op`gh$#x{&xNRLUmq1P($bxB~t zSvao3fgC*-EEB42rl**x0 zA__?Dz3fE4RfmKXzm=7vwly4xKm7sjq0bP3iJxf^1K6YQMAeCw`-uIC3vDEEM@o$P z9xSW=;&k-u~Z~F8K^kJo;hwgcZ`nR zt7se;qEAuw3`aNCY5;9bv6Va%L7oEHiNNJ}SY!EFJ{~|49luvc^aC>FQ35I@e)8U9 z54XG6;);H{C>=i>X4CUbjxagOFN_UoM?@26xKo((uF(w`IOXObE@gGl89R(MW@MLHB s&&oq{7XaMy=2^f(0>-mA`^nkvA$J Tuple[str, Optional[str]] + m = re.match(r'^(.+)(\[[^\]]+\])$', path) + extras = None + if m: + path_no_extras = m.group(1) + extras = m.group(2) + else: + path_no_extras = path + + return path_no_extras, extras + + +def parse_editable(editable_req): + # type: (str) -> Tuple[Optional[str], str, Optional[Set[str]]] + """Parses an editable requirement into: + - a requirement name + - an URL + - extras + - editable options + Accepted requirements: + svn+http://blahblah@rev#egg=Foobar[baz]&subdirectory=version_subdir + .[some_extra] + """ + + url = editable_req + + # If a file path is specified with extras, strip off the extras. + url_no_extras, extras = _strip_extras(url) + + if os.path.isdir(url_no_extras): + if not os.path.exists(os.path.join(url_no_extras, 'setup.py')): + msg = ( + 'File "setup.py" not found. Directory cannot be installed ' + 'in editable mode: {}'.format(os.path.abspath(url_no_extras)) + ) + pyproject_path = make_pyproject_path(url_no_extras) + if os.path.isfile(pyproject_path): + msg += ( + '\n(A "pyproject.toml" file was found, but editable ' + 'mode currently requires a setup.py based build.)' + ) + raise InstallationError(msg) + + # Treating it as code that has already been checked out + url_no_extras = path_to_url(url_no_extras) + + if url_no_extras.lower().startswith('file:'): + package_name = Link(url_no_extras).egg_fragment + if extras: + return ( + package_name, + url_no_extras, + Requirement("placeholder" + extras.lower()).extras, + ) + else: + return package_name, url_no_extras, None + + for version_control in vcs: + if url.lower().startswith('%s:' % version_control): + url = '%s+%s' % (version_control, url) + break + + if '+' not in url: + raise InstallationError( + '{} is not a valid editable requirement. ' + 'It should either be a path to a local project or a VCS URL ' + '(beginning with svn+, git+, hg+, or bzr+).'.format(editable_req) + ) + + vc_type = url.split('+', 1)[0].lower() + + if not vcs.get_backend(vc_type): + error_message = 'For --editable=%s only ' % editable_req + \ + ', '.join([backend.name + '+URL' for backend in vcs.backends]) + \ + ' is currently supported' + raise InstallationError(error_message) + + package_name = Link(url).egg_fragment + if not package_name: + raise InstallationError( + "Could not detect requirement name for '%s', please specify one " + "with #egg=your_package_name" % editable_req + ) + return package_name, url, None + + +def deduce_helpful_msg(req): + # type: (str) -> str + """Returns helpful msg in case requirements file does not exist, + or cannot be parsed. + + :params req: Requirements file path + """ + msg = "" + if os.path.exists(req): + msg = " It does exist." + # Try to parse and check if it is a requirements file. + try: + with open(req, 'r') as fp: + # parse first line only + next(parse_requirements(fp.read())) + msg += " The argument you provided " + \ + "(%s) appears to be a" % (req) + \ + " requirements file. If that is the" + \ + " case, use the '-r' flag to install" + \ + " the packages specified within it." + except RequirementParseError: + logger.debug("Cannot parse '%s' as requirements \ + file" % (req), exc_info=True) + else: + msg += " File '%s' does not exist." % (req) + return msg + + +# ---- The actual constructors follow ---- + + +def install_req_from_editable( + editable_req, # type: str + comes_from=None, # type: Optional[str] + use_pep517=None, # type: Optional[bool] + isolated=False, # type: bool + options=None, # type: Optional[Dict[str, Any]] + wheel_cache=None, # type: Optional[WheelCache] + constraint=False # type: bool +): + # type: (...) -> InstallRequirement + name, url, extras_override = parse_editable(editable_req) + if url.startswith('file:'): + source_dir = url_to_path(url) + else: + source_dir = None + + if name is not None: + try: + req = Requirement(name) + except InvalidRequirement: + raise InstallationError("Invalid requirement: '%s'" % name) + else: + req = None + return InstallRequirement( + req, comes_from, source_dir=source_dir, + editable=True, + link=Link(url), + constraint=constraint, + use_pep517=use_pep517, + isolated=isolated, + options=options if options else {}, + wheel_cache=wheel_cache, + extras=extras_override or (), + ) + + +def install_req_from_line( + name, # type: str + comes_from=None, # type: Optional[Union[str, InstallRequirement]] + use_pep517=None, # type: Optional[bool] + isolated=False, # type: bool + options=None, # type: Optional[Dict[str, Any]] + wheel_cache=None, # type: Optional[WheelCache] + constraint=False, # type: bool + line_source=None, # type: Optional[str] +): + # type: (...) -> InstallRequirement + """Creates an InstallRequirement from a name, which might be a + requirement, directory containing 'setup.py', filename, or URL. + + :param line_source: An optional string describing where the line is from, + for logging purposes in case of an error. + """ + if is_url(name): + marker_sep = '; ' + else: + marker_sep = ';' + if marker_sep in name: + name, markers_as_string = name.split(marker_sep, 1) + markers_as_string = markers_as_string.strip() + if not markers_as_string: + markers = None + else: + markers = Marker(markers_as_string) + else: + markers = None + name = name.strip() + req_as_string = None + path = os.path.normpath(os.path.abspath(name)) + link = None + extras_as_string = None + + if is_url(name): + link = Link(name) + else: + p, extras_as_string = _strip_extras(path) + looks_like_dir = os.path.isdir(p) and ( + os.path.sep in name or + (os.path.altsep is not None and os.path.altsep in name) or + name.startswith('.') + ) + if looks_like_dir: + if not is_installable_dir(p): + raise InstallationError( + "Directory %r is not installable. Neither 'setup.py' " + "nor 'pyproject.toml' found." % name + ) + link = Link(path_to_url(p)) + elif is_archive_file(p): + if not os.path.isfile(p): + logger.warning( + 'Requirement %r looks like a filename, but the ' + 'file does not exist', + name + ) + link = Link(path_to_url(p)) + + # it's a local file, dir, or url + if link: + # Handle relative file URLs + if link.scheme == 'file' and re.search(r'\.\./', link.url): + link = Link( + path_to_url(os.path.normpath(os.path.abspath(link.path)))) + # wheel file + if link.is_wheel: + wheel = Wheel(link.filename) # can raise InvalidWheelFilename + req_as_string = "%s==%s" % (wheel.name, wheel.version) + else: + # set the req to the egg fragment. when it's not there, this + # will become an 'unnamed' requirement + req_as_string = link.egg_fragment + + # a requirement specifier + else: + req_as_string = name + + if extras_as_string: + extras = Requirement("placeholder" + extras_as_string.lower()).extras + else: + extras = () + if req_as_string is not None: + try: + req = Requirement(req_as_string) + except InvalidRequirement: + if os.path.sep in req_as_string: + add_msg = "It looks like a path." + add_msg += deduce_helpful_msg(req_as_string) + elif ('=' in req_as_string and + not any(op in req_as_string for op in operators)): + add_msg = "= is not a valid operator. Did you mean == ?" + else: + add_msg = '' + if line_source is None: + source = '' + else: + source = ' (from {})'.format(line_source) + msg = ( + 'Invalid requirement: {!r}{}'.format(req_as_string, source) + ) + if add_msg: + msg += '\nHint: {}'.format(add_msg) + raise InstallationError(msg) + else: + req = None + + return InstallRequirement( + req, comes_from, link=link, markers=markers, + use_pep517=use_pep517, isolated=isolated, + options=options if options else {}, + wheel_cache=wheel_cache, + constraint=constraint, + extras=extras, + ) + + +def install_req_from_req_string( + req_string, # type: str + comes_from=None, # type: Optional[InstallRequirement] + isolated=False, # type: bool + wheel_cache=None, # type: Optional[WheelCache] + use_pep517=None # type: Optional[bool] +): + # type: (...) -> InstallRequirement + try: + req = Requirement(req_string) + except InvalidRequirement: + raise InstallationError("Invalid requirement: '%s'" % req_string) + + domains_not_allowed = [ + PyPI.file_storage_domain, + TestPyPI.file_storage_domain, + ] + if (req.url and comes_from and comes_from.link and + comes_from.link.netloc in domains_not_allowed): + # Explicitly disallow pypi packages that depend on external urls + raise InstallationError( + "Packages installed from PyPI cannot depend on packages " + "which are not also hosted on PyPI.\n" + "%s depends on %s " % (comes_from.name, req) + ) + + return InstallRequirement( + req, comes_from, isolated=isolated, wheel_cache=wheel_cache, + use_pep517=use_pep517 + ) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_file.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_file.py new file mode 100644 index 0000000..5a9920f --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_file.py @@ -0,0 +1,399 @@ +""" +Requirements file parsing +""" + +from __future__ import absolute_import + +import optparse +import os +import re +import shlex +import sys + +from pip._vendor.six.moves import filterfalse +from pip._vendor.six.moves.urllib import parse as urllib_parse + +from pip._internal.cli import cmdoptions +from pip._internal.download import get_file_content +from pip._internal.exceptions import RequirementsFileParseError +from pip._internal.models.search_scope import SearchScope +from pip._internal.req.constructors import ( + install_req_from_editable, install_req_from_line, +) +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import ( + Any, Callable, Iterator, List, NoReturn, Optional, Text, Tuple, + ) + from pip._internal.req import InstallRequirement + from pip._internal.cache import WheelCache + from pip._internal.index import PackageFinder + from pip._internal.download import PipSession + + ReqFileLines = Iterator[Tuple[int, Text]] + +__all__ = ['parse_requirements'] + +SCHEME_RE = re.compile(r'^(http|https|file):', re.I) +COMMENT_RE = re.compile(r'(^|\s+)#.*$') + +# Matches environment variable-style values in '${MY_VARIABLE_1}' with the +# variable name consisting of only uppercase letters, digits or the '_' +# (underscore). This follows the POSIX standard defined in IEEE Std 1003.1, +# 2013 Edition. +ENV_VAR_RE = re.compile(r'(?P\$\{(?P[A-Z0-9_]+)\})') + +SUPPORTED_OPTIONS = [ + cmdoptions.constraints, + cmdoptions.editable, + cmdoptions.requirements, + cmdoptions.no_index, + cmdoptions.index_url, + cmdoptions.find_links, + cmdoptions.extra_index_url, + cmdoptions.always_unzip, + cmdoptions.no_binary, + cmdoptions.only_binary, + cmdoptions.pre, + cmdoptions.trusted_host, + cmdoptions.require_hashes, +] # type: List[Callable[..., optparse.Option]] + +# options to be passed to requirements +SUPPORTED_OPTIONS_REQ = [ + cmdoptions.install_options, + cmdoptions.global_options, + cmdoptions.hash, +] # type: List[Callable[..., optparse.Option]] + +# the 'dest' string values +SUPPORTED_OPTIONS_REQ_DEST = [str(o().dest) for o in SUPPORTED_OPTIONS_REQ] + + +def parse_requirements( + filename, # type: str + finder=None, # type: Optional[PackageFinder] + comes_from=None, # type: Optional[str] + options=None, # type: Optional[optparse.Values] + session=None, # type: Optional[PipSession] + constraint=False, # type: bool + wheel_cache=None, # type: Optional[WheelCache] + use_pep517=None # type: Optional[bool] +): + # type: (...) -> Iterator[InstallRequirement] + """Parse a requirements file and yield InstallRequirement instances. + + :param filename: Path or url of requirements file. + :param finder: Instance of pip.index.PackageFinder. + :param comes_from: Origin description of requirements. + :param options: cli options. + :param session: Instance of pip.download.PipSession. + :param constraint: If true, parsing a constraint file rather than + requirements file. + :param wheel_cache: Instance of pip.wheel.WheelCache + :param use_pep517: Value of the --use-pep517 option. + """ + if session is None: + raise TypeError( + "parse_requirements() missing 1 required keyword argument: " + "'session'" + ) + + _, content = get_file_content( + filename, comes_from=comes_from, session=session + ) + + lines_enum = preprocess(content, options) + + for line_number, line in lines_enum: + req_iter = process_line(line, filename, line_number, finder, + comes_from, options, session, wheel_cache, + use_pep517=use_pep517, constraint=constraint) + for req in req_iter: + yield req + + +def preprocess(content, options): + # type: (Text, Optional[optparse.Values]) -> ReqFileLines + """Split, filter, and join lines, and return a line iterator + + :param content: the content of the requirements file + :param options: cli options + """ + lines_enum = enumerate(content.splitlines(), start=1) # type: ReqFileLines + lines_enum = join_lines(lines_enum) + lines_enum = ignore_comments(lines_enum) + lines_enum = skip_regex(lines_enum, options) + lines_enum = expand_env_variables(lines_enum) + return lines_enum + + +def process_line( + line, # type: Text + filename, # type: str + line_number, # type: int + finder=None, # type: Optional[PackageFinder] + comes_from=None, # type: Optional[str] + options=None, # type: Optional[optparse.Values] + session=None, # type: Optional[PipSession] + wheel_cache=None, # type: Optional[WheelCache] + use_pep517=None, # type: Optional[bool] + constraint=False, # type: bool +): + # type: (...) -> Iterator[InstallRequirement] + """Process a single requirements line; This can result in creating/yielding + requirements, or updating the finder. + + For lines that contain requirements, the only options that have an effect + are from SUPPORTED_OPTIONS_REQ, and they are scoped to the + requirement. Other options from SUPPORTED_OPTIONS may be present, but are + ignored. + + For lines that do not contain requirements, the only options that have an + effect are from SUPPORTED_OPTIONS. Options from SUPPORTED_OPTIONS_REQ may + be present, but are ignored. These lines may contain multiple options + (although our docs imply only one is supported), and all our parsed and + affect the finder. + + :param constraint: If True, parsing a constraints file. + :param options: OptionParser options that we may update + """ + parser = build_parser(line) + defaults = parser.get_default_values() + defaults.index_url = None + if finder: + defaults.format_control = finder.format_control + args_str, options_str = break_args_options(line) + # Prior to 2.7.3, shlex cannot deal with unicode entries + if sys.version_info < (2, 7, 3): + # https://github.com/python/mypy/issues/1174 + options_str = options_str.encode('utf8') # type: ignore + # https://github.com/python/mypy/issues/1174 + opts, _ = parser.parse_args( + shlex.split(options_str), defaults) # type: ignore + + # preserve for the nested code path + line_comes_from = '%s %s (line %s)' % ( + '-c' if constraint else '-r', filename, line_number, + ) + + # yield a line requirement + if args_str: + isolated = options.isolated_mode if options else False + if options: + cmdoptions.check_install_build_global(options, opts) + # get the options that apply to requirements + req_options = {} + for dest in SUPPORTED_OPTIONS_REQ_DEST: + if dest in opts.__dict__ and opts.__dict__[dest]: + req_options[dest] = opts.__dict__[dest] + line_source = 'line {} of {}'.format(line_number, filename) + yield install_req_from_line( + args_str, + comes_from=line_comes_from, + use_pep517=use_pep517, + isolated=isolated, + options=req_options, + wheel_cache=wheel_cache, + constraint=constraint, + line_source=line_source, + ) + + # yield an editable requirement + elif opts.editables: + isolated = options.isolated_mode if options else False + yield install_req_from_editable( + opts.editables[0], comes_from=line_comes_from, + use_pep517=use_pep517, + constraint=constraint, isolated=isolated, wheel_cache=wheel_cache + ) + + # parse a nested requirements file + elif opts.requirements or opts.constraints: + if opts.requirements: + req_path = opts.requirements[0] + nested_constraint = False + else: + req_path = opts.constraints[0] + nested_constraint = True + # original file is over http + if SCHEME_RE.search(filename): + # do a url join so relative paths work + req_path = urllib_parse.urljoin(filename, req_path) + # original file and nested file are paths + elif not SCHEME_RE.search(req_path): + # do a join so relative paths work + req_path = os.path.join(os.path.dirname(filename), req_path) + # TODO: Why not use `comes_from='-r {} (line {})'` here as well? + parsed_reqs = parse_requirements( + req_path, finder, comes_from, options, session, + constraint=nested_constraint, wheel_cache=wheel_cache + ) + for req in parsed_reqs: + yield req + + # percolate hash-checking option upward + elif opts.require_hashes: + options.require_hashes = opts.require_hashes + + # set finder options + elif finder: + find_links = finder.find_links + index_urls = finder.index_urls + if opts.index_url: + index_urls = [opts.index_url] + if opts.no_index is True: + index_urls = [] + if opts.extra_index_urls: + index_urls.extend(opts.extra_index_urls) + if opts.find_links: + # FIXME: it would be nice to keep track of the source + # of the find_links: support a find-links local path + # relative to a requirements file. + value = opts.find_links[0] + req_dir = os.path.dirname(os.path.abspath(filename)) + relative_to_reqs_file = os.path.join(req_dir, value) + if os.path.exists(relative_to_reqs_file): + value = relative_to_reqs_file + find_links.append(value) + + search_scope = SearchScope( + find_links=find_links, + index_urls=index_urls, + ) + finder.search_scope = search_scope + + if opts.pre: + finder.set_allow_all_prereleases() + for host in opts.trusted_hosts or []: + source = 'line {} of {}'.format(line_number, filename) + finder.add_trusted_host(host, source=source) + + +def break_args_options(line): + # type: (Text) -> Tuple[str, Text] + """Break up the line into an args and options string. We only want to shlex + (and then optparse) the options, not the args. args can contain markers + which are corrupted by shlex. + """ + tokens = line.split(' ') + args = [] + options = tokens[:] + for token in tokens: + if token.startswith('-') or token.startswith('--'): + break + else: + args.append(token) + options.pop(0) + return ' '.join(args), ' '.join(options) # type: ignore + + +def build_parser(line): + # type: (Text) -> optparse.OptionParser + """ + Return a parser for parsing requirement lines + """ + parser = optparse.OptionParser(add_help_option=False) + + option_factories = SUPPORTED_OPTIONS + SUPPORTED_OPTIONS_REQ + for option_factory in option_factories: + option = option_factory() + parser.add_option(option) + + # By default optparse sys.exits on parsing errors. We want to wrap + # that in our own exception. + def parser_exit(self, msg): + # type: (Any, str) -> NoReturn + # add offending line + msg = 'Invalid requirement: %s\n%s' % (line, msg) + raise RequirementsFileParseError(msg) + # NOTE: mypy disallows assigning to a method + # https://github.com/python/mypy/issues/2427 + parser.exit = parser_exit # type: ignore + + return parser + + +def join_lines(lines_enum): + # type: (ReqFileLines) -> ReqFileLines + """Joins a line ending in '\' with the previous line (except when following + comments). The joined line takes on the index of the first line. + """ + primary_line_number = None + new_line = [] # type: List[Text] + for line_number, line in lines_enum: + if not line.endswith('\\') or COMMENT_RE.match(line): + if COMMENT_RE.match(line): + # this ensures comments are always matched later + line = ' ' + line + if new_line: + new_line.append(line) + yield primary_line_number, ''.join(new_line) + new_line = [] + else: + yield line_number, line + else: + if not new_line: + primary_line_number = line_number + new_line.append(line.strip('\\')) + + # last line contains \ + if new_line: + yield primary_line_number, ''.join(new_line) + + # TODO: handle space after '\'. + + +def ignore_comments(lines_enum): + # type: (ReqFileLines) -> ReqFileLines + """ + Strips comments and filter empty lines. + """ + for line_number, line in lines_enum: + line = COMMENT_RE.sub('', line) + line = line.strip() + if line: + yield line_number, line + + +def skip_regex(lines_enum, options): + # type: (ReqFileLines, Optional[optparse.Values]) -> ReqFileLines + """ + Skip lines that match '--skip-requirements-regex' pattern + + Note: the regex pattern is only built once + """ + skip_regex = options.skip_requirements_regex if options else None + if skip_regex: + pattern = re.compile(skip_regex) + lines_enum = filterfalse(lambda e: pattern.search(e[1]), lines_enum) + return lines_enum + + +def expand_env_variables(lines_enum): + # type: (ReqFileLines) -> ReqFileLines + """Replace all environment variables that can be retrieved via `os.getenv`. + + The only allowed format for environment variables defined in the + requirement file is `${MY_VARIABLE_1}` to ensure two things: + + 1. Strings that contain a `$` aren't accidentally (partially) expanded. + 2. Ensure consistency across platforms for requirement files. + + These points are the result of a discussion on the `github pull + request #3514 `_. + + Valid characters in variable names follow the `POSIX standard + `_ and are limited + to uppercase letter, digits and the `_` (underscore). + """ + for line_number, line in lines_enum: + for env_var, var_name in ENV_VAR_RE.findall(line): + value = os.getenv(var_name) + if not value: + continue + + line = line.replace(env_var, value) + + yield line_number, line diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_install.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_install.py new file mode 100644 index 0000000..f5c9350 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_install.py @@ -0,0 +1,1035 @@ +from __future__ import absolute_import + +import logging +import os +import shutil +import sys +import sysconfig +import zipfile +from distutils.util import change_root + +from pip._vendor import pkg_resources, six +from pip._vendor.packaging.requirements import Requirement +from pip._vendor.packaging.utils import canonicalize_name +from pip._vendor.packaging.version import Version +from pip._vendor.packaging.version import parse as parse_version +from pip._vendor.pep517.wrappers import Pep517HookCaller + +from pip._internal import wheel +from pip._internal.build_env import NoOpBuildEnvironment +from pip._internal.exceptions import InstallationError +from pip._internal.models.link import Link +from pip._internal.pyproject import load_pyproject_toml, make_pyproject_path +from pip._internal.req.req_uninstall import UninstallPathSet +from pip._internal.utils.compat import native_str +from pip._internal.utils.hashes import Hashes +from pip._internal.utils.logging import indent_log +from pip._internal.utils.marker_files import PIP_DELETE_MARKER_FILENAME +from pip._internal.utils.misc import ( + _make_build_dir, ask_path_exists, backup_dir, call_subprocess, + display_path, dist_in_site_packages, dist_in_usersite, ensure_dir, + get_installed_version, redact_password_from_url, rmtree, +) +from pip._internal.utils.packaging import get_metadata +from pip._internal.utils.setuptools_build import make_setuptools_shim_args +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.ui import open_spinner +from pip._internal.utils.virtualenv import running_under_virtualenv +from pip._internal.vcs import vcs + +if MYPY_CHECK_RUNNING: + from typing import ( + Any, Dict, Iterable, List, Mapping, Optional, Sequence, Union, + ) + from pip._internal.build_env import BuildEnvironment + from pip._internal.cache import WheelCache + from pip._internal.index import PackageFinder + from pip._vendor.pkg_resources import Distribution + from pip._vendor.packaging.specifiers import SpecifierSet + from pip._vendor.packaging.markers import Marker + + +logger = logging.getLogger(__name__) + + +class InstallRequirement(object): + """ + Represents something that may be installed later on, may have information + about where to fetch the relevant requirement and also contains logic for + installing the said requirement. + """ + + def __init__( + self, + req, # type: Optional[Requirement] + comes_from, # type: Optional[Union[str, InstallRequirement]] + source_dir=None, # type: Optional[str] + editable=False, # type: bool + link=None, # type: Optional[Link] + update=True, # type: bool + markers=None, # type: Optional[Marker] + use_pep517=None, # type: Optional[bool] + isolated=False, # type: bool + options=None, # type: Optional[Dict[str, Any]] + wheel_cache=None, # type: Optional[WheelCache] + constraint=False, # type: bool + extras=() # type: Iterable[str] + ): + # type: (...) -> None + assert req is None or isinstance(req, Requirement), req + self.req = req + self.comes_from = comes_from + self.constraint = constraint + if source_dir is None: + self.source_dir = None # type: Optional[str] + else: + self.source_dir = os.path.normpath(os.path.abspath(source_dir)) + self.editable = editable + + self._wheel_cache = wheel_cache + if link is None and req and req.url: + # PEP 508 URL requirement + link = Link(req.url) + self.link = self.original_link = link + + if extras: + self.extras = extras + elif req: + self.extras = { + pkg_resources.safe_extra(extra) for extra in req.extras + } + else: + self.extras = set() + if markers is None and req: + markers = req.marker + self.markers = markers + + self._egg_info_path = None # type: Optional[str] + # This holds the pkg_resources.Distribution object if this requirement + # is already available: + self.satisfied_by = None + # This hold the pkg_resources.Distribution object if this requirement + # conflicts with another installed distribution: + self.conflicts_with = None + # Temporary build location + self._temp_build_dir = TempDirectory(kind="req-build") + # Used to store the global directory where the _temp_build_dir should + # have been created. Cf _correct_build_location method. + self._ideal_build_dir = None # type: Optional[str] + # True if the editable should be updated: + self.update = update + # Set to True after successful installation + self.install_succeeded = None # type: Optional[bool] + # UninstallPathSet of uninstalled distribution (for possible rollback) + self.uninstalled_pathset = None + self.options = options if options else {} + # Set to True after successful preparation of this requirement + self.prepared = False + self.is_direct = False + + self.isolated = isolated + self.build_env = NoOpBuildEnvironment() # type: BuildEnvironment + + # For PEP 517, the directory where we request the project metadata + # gets stored. We need this to pass to build_wheel, so the backend + # can ensure that the wheel matches the metadata (see the PEP for + # details). + self.metadata_directory = None # type: Optional[str] + + # The static build requirements (from pyproject.toml) + self.pyproject_requires = None # type: Optional[List[str]] + + # Build requirements that we will check are available + self.requirements_to_check = [] # type: List[str] + + # The PEP 517 backend we should use to build the project + self.pep517_backend = None # type: Optional[Pep517HookCaller] + + # Are we using PEP 517 for this requirement? + # After pyproject.toml has been loaded, the only valid values are True + # and False. Before loading, None is valid (meaning "use the default"). + # Setting an explicit value before loading pyproject.toml is supported, + # but after loading this flag should be treated as read only. + self.use_pep517 = use_pep517 + + def __str__(self): + # type: () -> str + if self.req: + s = str(self.req) + if self.link: + s += ' from %s' % redact_password_from_url(self.link.url) + elif self.link: + s = redact_password_from_url(self.link.url) + else: + s = '' + if self.satisfied_by is not None: + s += ' in %s' % display_path(self.satisfied_by.location) + if self.comes_from: + if isinstance(self.comes_from, six.string_types): + comes_from = self.comes_from # type: Optional[str] + else: + comes_from = self.comes_from.from_path() + if comes_from: + s += ' (from %s)' % comes_from + return s + + def __repr__(self): + # type: () -> str + return '<%s object: %s editable=%r>' % ( + self.__class__.__name__, str(self), self.editable) + + def format_debug(self): + # type: () -> str + """An un-tested helper for getting state, for debugging. + """ + attributes = vars(self) + names = sorted(attributes) + + state = ( + "{}={!r}".format(attr, attributes[attr]) for attr in sorted(names) + ) + return '<{name} object: {{{state}}}>'.format( + name=self.__class__.__name__, + state=", ".join(state), + ) + + def populate_link(self, finder, upgrade, require_hashes): + # type: (PackageFinder, bool, bool) -> None + """Ensure that if a link can be found for this, that it is found. + + Note that self.link may still be None - if Upgrade is False and the + requirement is already installed. + + If require_hashes is True, don't use the wheel cache, because cached + wheels, always built locally, have different hashes than the files + downloaded from the index server and thus throw false hash mismatches. + Furthermore, cached wheels at present have undeterministic contents due + to file modification times. + """ + if self.link is None: + self.link = finder.find_requirement(self, upgrade) + if self._wheel_cache is not None and not require_hashes: + old_link = self.link + self.link = self._wheel_cache.get(self.link, self.name) + if old_link != self.link: + logger.debug('Using cached wheel link: %s', self.link) + + # Things that are valid for all kinds of requirements? + @property + def name(self): + # type: () -> Optional[str] + if self.req is None: + return None + return native_str(pkg_resources.safe_name(self.req.name)) + + @property + def specifier(self): + # type: () -> SpecifierSet + return self.req.specifier + + @property + def is_pinned(self): + # type: () -> bool + """Return whether I am pinned to an exact version. + + For example, some-package==1.2 is pinned; some-package>1.2 is not. + """ + specifiers = self.specifier + return (len(specifiers) == 1 and + next(iter(specifiers)).operator in {'==', '==='}) + + @property + def installed_version(self): + # type: () -> Optional[str] + return get_installed_version(self.name) + + def match_markers(self, extras_requested=None): + # type: (Optional[Iterable[str]]) -> bool + if not extras_requested: + # Provide an extra to safely evaluate the markers + # without matching any extra + extras_requested = ('',) + if self.markers is not None: + return any( + self.markers.evaluate({'extra': extra}) + for extra in extras_requested) + else: + return True + + @property + def has_hash_options(self): + # type: () -> bool + """Return whether any known-good hashes are specified as options. + + These activate --require-hashes mode; hashes specified as part of a + URL do not. + + """ + return bool(self.options.get('hashes', {})) + + def hashes(self, trust_internet=True): + # type: (bool) -> Hashes + """Return a hash-comparer that considers my option- and URL-based + hashes to be known-good. + + Hashes in URLs--ones embedded in the requirements file, not ones + downloaded from an index server--are almost peers with ones from + flags. They satisfy --require-hashes (whether it was implicitly or + explicitly activated) but do not activate it. md5 and sha224 are not + allowed in flags, which should nudge people toward good algos. We + always OR all hashes together, even ones from URLs. + + :param trust_internet: Whether to trust URL-based (#md5=...) hashes + downloaded from the internet, as by populate_link() + + """ + good_hashes = self.options.get('hashes', {}).copy() + link = self.link if trust_internet else self.original_link + if link and link.hash: + good_hashes.setdefault(link.hash_name, []).append(link.hash) + return Hashes(good_hashes) + + def from_path(self): + # type: () -> Optional[str] + """Format a nice indicator to show where this "comes from" + """ + if self.req is None: + return None + s = str(self.req) + if self.comes_from: + if isinstance(self.comes_from, six.string_types): + comes_from = self.comes_from + else: + comes_from = self.comes_from.from_path() + if comes_from: + s += '->' + comes_from + return s + + def build_location(self, build_dir): + # type: (str) -> str + assert build_dir is not None + if self._temp_build_dir.path is not None: + return self._temp_build_dir.path + if self.req is None: + # for requirement via a path to a directory: the name of the + # package is not available yet so we create a temp directory + # Once run_egg_info will have run, we'll be able + # to fix it via _correct_build_location + # Some systems have /tmp as a symlink which confuses custom + # builds (such as numpy). Thus, we ensure that the real path + # is returned. + self._temp_build_dir.create() + self._ideal_build_dir = build_dir + + return self._temp_build_dir.path + if self.editable: + name = self.name.lower() + else: + name = self.name + # FIXME: Is there a better place to create the build_dir? (hg and bzr + # need this) + if not os.path.exists(build_dir): + logger.debug('Creating directory %s', build_dir) + _make_build_dir(build_dir) + return os.path.join(build_dir, name) + + def _correct_build_location(self): + # type: () -> None + """Move self._temp_build_dir to self._ideal_build_dir/self.req.name + + For some requirements (e.g. a path to a directory), the name of the + package is not available until we run egg_info, so the build_location + will return a temporary directory and store the _ideal_build_dir. + + This is only called by self.run_egg_info to fix the temporary build + directory. + """ + if self.source_dir is not None: + return + assert self.req is not None + assert self._temp_build_dir.path + assert (self._ideal_build_dir is not None and + self._ideal_build_dir.path) # type: ignore + old_location = self._temp_build_dir.path + self._temp_build_dir.path = None + + new_location = self.build_location(self._ideal_build_dir) + if os.path.exists(new_location): + raise InstallationError( + 'A package already exists in %s; please remove it to continue' + % display_path(new_location)) + logger.debug( + 'Moving package %s from %s to new location %s', + self, display_path(old_location), display_path(new_location), + ) + shutil.move(old_location, new_location) + self._temp_build_dir.path = new_location + self._ideal_build_dir = None + self.source_dir = os.path.normpath(os.path.abspath(new_location)) + self._egg_info_path = None + + # Correct the metadata directory, if it exists + if self.metadata_directory: + old_meta = self.metadata_directory + rel = os.path.relpath(old_meta, start=old_location) + new_meta = os.path.join(new_location, rel) + new_meta = os.path.normpath(os.path.abspath(new_meta)) + self.metadata_directory = new_meta + + def remove_temporary_source(self): + # type: () -> None + """Remove the source files from this requirement, if they are marked + for deletion""" + if self.source_dir and os.path.exists( + os.path.join(self.source_dir, PIP_DELETE_MARKER_FILENAME)): + logger.debug('Removing source in %s', self.source_dir) + rmtree(self.source_dir) + self.source_dir = None + self._temp_build_dir.cleanup() + self.build_env.cleanup() + + def check_if_exists(self, use_user_site): + # type: (bool) -> bool + """Find an installed distribution that satisfies or conflicts + with this requirement, and set self.satisfied_by or + self.conflicts_with appropriately. + """ + if self.req is None: + return False + try: + # get_distribution() will resolve the entire list of requirements + # anyway, and we've already determined that we need the requirement + # in question, so strip the marker so that we don't try to + # evaluate it. + no_marker = Requirement(str(self.req)) + no_marker.marker = None + self.satisfied_by = pkg_resources.get_distribution(str(no_marker)) + if self.editable and self.satisfied_by: + self.conflicts_with = self.satisfied_by + # when installing editables, nothing pre-existing should ever + # satisfy + self.satisfied_by = None + return True + except pkg_resources.DistributionNotFound: + return False + except pkg_resources.VersionConflict: + existing_dist = pkg_resources.get_distribution( + self.req.name + ) + if use_user_site: + if dist_in_usersite(existing_dist): + self.conflicts_with = existing_dist + elif (running_under_virtualenv() and + dist_in_site_packages(existing_dist)): + raise InstallationError( + "Will not install to the user site because it will " + "lack sys.path precedence to %s in %s" % + (existing_dist.project_name, existing_dist.location) + ) + else: + self.conflicts_with = existing_dist + return True + + # Things valid for wheels + @property + def is_wheel(self): + # type: () -> bool + if not self.link: + return False + return self.link.is_wheel + + def move_wheel_files( + self, + wheeldir, # type: str + root=None, # type: Optional[str] + home=None, # type: Optional[str] + prefix=None, # type: Optional[str] + warn_script_location=True, # type: bool + use_user_site=False, # type: bool + pycompile=True # type: bool + ): + # type: (...) -> None + wheel.move_wheel_files( + self.name, self.req, wheeldir, + user=use_user_site, + home=home, + root=root, + prefix=prefix, + pycompile=pycompile, + isolated=self.isolated, + warn_script_location=warn_script_location, + ) + + # Things valid for sdists + @property + def setup_py_dir(self): + # type: () -> str + return os.path.join( + self.source_dir, + self.link and self.link.subdirectory_fragment or '') + + @property + def setup_py_path(self): + # type: () -> str + assert self.source_dir, "No source dir for %s" % self + + setup_py = os.path.join(self.setup_py_dir, 'setup.py') + + # Python2 __file__ should not be unicode + if six.PY2 and isinstance(setup_py, six.text_type): + setup_py = setup_py.encode(sys.getfilesystemencoding()) + + return setup_py + + @property + def pyproject_toml_path(self): + # type: () -> str + assert self.source_dir, "No source dir for %s" % self + + return make_pyproject_path(self.setup_py_dir) + + def load_pyproject_toml(self): + # type: () -> None + """Load the pyproject.toml file. + + After calling this routine, all of the attributes related to PEP 517 + processing for this requirement have been set. In particular, the + use_pep517 attribute can be used to determine whether we should + follow the PEP 517 or legacy (setup.py) code path. + """ + pyproject_toml_data = load_pyproject_toml( + self.use_pep517, + self.pyproject_toml_path, + self.setup_py_path, + str(self) + ) + + self.use_pep517 = (pyproject_toml_data is not None) + + if not self.use_pep517: + return + + requires, backend, check = pyproject_toml_data + self.requirements_to_check = check + self.pyproject_requires = requires + self.pep517_backend = Pep517HookCaller(self.setup_py_dir, backend) + + # Use a custom function to call subprocesses + self.spin_message = "" + + def runner( + cmd, # type: List[str] + cwd=None, # type: Optional[str] + extra_environ=None # type: Optional[Mapping[str, Any]] + ): + # type: (...) -> None + with open_spinner(self.spin_message) as spinner: + call_subprocess( + cmd, + cwd=cwd, + extra_environ=extra_environ, + spinner=spinner + ) + self.spin_message = "" + + self.pep517_backend._subprocess_runner = runner + + def prepare_metadata(self): + # type: () -> None + """Ensure that project metadata is available. + + Under PEP 517, call the backend hook to prepare the metadata. + Under legacy processing, call setup.py egg-info. + """ + assert self.source_dir + + with indent_log(): + if self.use_pep517: + self.prepare_pep517_metadata() + else: + self.run_egg_info() + + if not self.req: + if isinstance(parse_version(self.metadata["Version"]), Version): + op = "==" + else: + op = "===" + self.req = Requirement( + "".join([ + self.metadata["Name"], + op, + self.metadata["Version"], + ]) + ) + self._correct_build_location() + else: + metadata_name = canonicalize_name(self.metadata["Name"]) + if canonicalize_name(self.req.name) != metadata_name: + logger.warning( + 'Generating metadata for package %s ' + 'produced metadata for project name %s. Fix your ' + '#egg=%s fragments.', + self.name, metadata_name, self.name + ) + self.req = Requirement(metadata_name) + + def prepare_pep517_metadata(self): + # type: () -> None + assert self.pep517_backend is not None + + metadata_dir = os.path.join( + self.setup_py_dir, + 'pip-wheel-metadata' + ) + ensure_dir(metadata_dir) + + with self.build_env: + # Note that Pep517HookCaller implements a fallback for + # prepare_metadata_for_build_wheel, so we don't have to + # consider the possibility that this hook doesn't exist. + backend = self.pep517_backend + self.spin_message = "Preparing wheel metadata" + distinfo_dir = backend.prepare_metadata_for_build_wheel( + metadata_dir + ) + + self.metadata_directory = os.path.join(metadata_dir, distinfo_dir) + + def run_egg_info(self): + # type: () -> None + if self.name: + logger.debug( + 'Running setup.py (path:%s) egg_info for package %s', + self.setup_py_path, self.name, + ) + else: + logger.debug( + 'Running setup.py (path:%s) egg_info for package from %s', + self.setup_py_path, self.link, + ) + base_cmd = make_setuptools_shim_args(self.setup_py_path) + if self.isolated: + base_cmd += ["--no-user-cfg"] + egg_info_cmd = base_cmd + ['egg_info'] + # We can't put the .egg-info files at the root, because then the + # source code will be mistaken for an installed egg, causing + # problems + if self.editable: + egg_base_option = [] # type: List[str] + else: + egg_info_dir = os.path.join(self.setup_py_dir, 'pip-egg-info') + ensure_dir(egg_info_dir) + egg_base_option = ['--egg-base', 'pip-egg-info'] + with self.build_env: + call_subprocess( + egg_info_cmd + egg_base_option, + cwd=self.setup_py_dir, + command_desc='python setup.py egg_info') + + @property + def egg_info_path(self): + # type: () -> str + if self._egg_info_path is None: + if self.editable: + base = self.source_dir + else: + base = os.path.join(self.setup_py_dir, 'pip-egg-info') + filenames = os.listdir(base) + if self.editable: + filenames = [] + for root, dirs, files in os.walk(base): + for dir in vcs.dirnames: + if dir in dirs: + dirs.remove(dir) + # Iterate over a copy of ``dirs``, since mutating + # a list while iterating over it can cause trouble. + # (See https://github.com/pypa/pip/pull/462.) + for dir in list(dirs): + # Don't search in anything that looks like a virtualenv + # environment + if ( + os.path.lexists( + os.path.join(root, dir, 'bin', 'python') + ) or + os.path.exists( + os.path.join( + root, dir, 'Scripts', 'Python.exe' + ) + )): + dirs.remove(dir) + # Also don't search through tests + elif dir == 'test' or dir == 'tests': + dirs.remove(dir) + filenames.extend([os.path.join(root, dir) + for dir in dirs]) + filenames = [f for f in filenames if f.endswith('.egg-info')] + + if not filenames: + raise InstallationError( + "Files/directories not found in %s" % base + ) + # if we have more than one match, we pick the toplevel one. This + # can easily be the case if there is a dist folder which contains + # an extracted tarball for testing purposes. + if len(filenames) > 1: + filenames.sort( + key=lambda x: x.count(os.path.sep) + + (os.path.altsep and x.count(os.path.altsep) or 0) + ) + self._egg_info_path = os.path.join(base, filenames[0]) + return self._egg_info_path + + @property + def metadata(self): + # type: () -> Any + if not hasattr(self, '_metadata'): + self._metadata = get_metadata(self.get_dist()) + + return self._metadata + + def get_dist(self): + # type: () -> Distribution + """Return a pkg_resources.Distribution for this requirement""" + if self.metadata_directory: + dist_dir = self.metadata_directory + dist_cls = pkg_resources.DistInfoDistribution + else: + dist_dir = self.egg_info_path.rstrip(os.path.sep) + # https://github.com/python/mypy/issues/1174 + dist_cls = pkg_resources.Distribution # type: ignore + + # dist_dir_name can be of the form ".dist-info" or + # e.g. ".egg-info". + base_dir, dist_dir_name = os.path.split(dist_dir) + dist_name = os.path.splitext(dist_dir_name)[0] + metadata = pkg_resources.PathMetadata(base_dir, dist_dir) + + return dist_cls( + base_dir, + project_name=dist_name, + metadata=metadata, + ) + + def assert_source_matches_version(self): + # type: () -> None + assert self.source_dir + version = self.metadata['version'] + if self.req.specifier and version not in self.req.specifier: + logger.warning( + 'Requested %s, but installing version %s', + self, + version, + ) + else: + logger.debug( + 'Source in %s has version %s, which satisfies requirement %s', + display_path(self.source_dir), + version, + self, + ) + + # For both source distributions and editables + def ensure_has_source_dir(self, parent_dir): + # type: (str) -> str + """Ensure that a source_dir is set. + + This will create a temporary build dir if the name of the requirement + isn't known yet. + + :param parent_dir: The ideal pip parent_dir for the source_dir. + Generally src_dir for editables and build_dir for sdists. + :return: self.source_dir + """ + if self.source_dir is None: + self.source_dir = self.build_location(parent_dir) + return self.source_dir + + # For editable installations + def install_editable( + self, + install_options, # type: List[str] + global_options=(), # type: Sequence[str] + prefix=None # type: Optional[str] + ): + # type: (...) -> None + logger.info('Running setup.py develop for %s', self.name) + + if self.isolated: + global_options = list(global_options) + ["--no-user-cfg"] + + if prefix: + prefix_param = ['--prefix={}'.format(prefix)] + install_options = list(install_options) + prefix_param + + with indent_log(): + # FIXME: should we do --install-headers here too? + with self.build_env: + call_subprocess( + make_setuptools_shim_args(self.setup_py_path) + + list(global_options) + + ['develop', '--no-deps'] + + list(install_options), + + cwd=self.setup_py_dir, + ) + + self.install_succeeded = True + + def update_editable(self, obtain=True): + # type: (bool) -> None + if not self.link: + logger.debug( + "Cannot update repository at %s; repository location is " + "unknown", + self.source_dir, + ) + return + assert self.editable + assert self.source_dir + if self.link.scheme == 'file': + # Static paths don't get updated + return + assert '+' in self.link.url, "bad url: %r" % self.link.url + if not self.update: + return + vc_type, url = self.link.url.split('+', 1) + vcs_backend = vcs.get_backend(vc_type) + if vcs_backend: + url = self.link.url + if obtain: + vcs_backend.obtain(self.source_dir, url=url) + else: + vcs_backend.export(self.source_dir, url=url) + else: + assert 0, ( + 'Unexpected version control type (in %s): %s' + % (self.link, vc_type)) + + # Top-level Actions + def uninstall(self, auto_confirm=False, verbose=False, + use_user_site=False): + # type: (bool, bool, bool) -> Optional[UninstallPathSet] + """ + Uninstall the distribution currently satisfying this requirement. + + Prompts before removing or modifying files unless + ``auto_confirm`` is True. + + Refuses to delete or modify files outside of ``sys.prefix`` - + thus uninstallation within a virtual environment can only + modify that virtual environment, even if the virtualenv is + linked to global site-packages. + + """ + if not self.check_if_exists(use_user_site): + logger.warning("Skipping %s as it is not installed.", self.name) + return None + dist = self.satisfied_by or self.conflicts_with + + uninstalled_pathset = UninstallPathSet.from_dist(dist) + uninstalled_pathset.remove(auto_confirm, verbose) + return uninstalled_pathset + + def _clean_zip_name(self, name, prefix): # only used by archive. + # type: (str, str) -> str + assert name.startswith(prefix + os.path.sep), ( + "name %r doesn't start with prefix %r" % (name, prefix) + ) + name = name[len(prefix) + 1:] + name = name.replace(os.path.sep, '/') + return name + + def _get_archive_name(self, path, parentdir, rootdir): + # type: (str, str, str) -> str + path = os.path.join(parentdir, path) + name = self._clean_zip_name(path, rootdir) + return self.name + '/' + name + + # TODO: Investigate if this should be kept in InstallRequirement + # Seems to be used only when VCS + downloads + def archive(self, build_dir): + # type: (str) -> None + assert self.source_dir + create_archive = True + archive_name = '%s-%s.zip' % (self.name, self.metadata["version"]) + archive_path = os.path.join(build_dir, archive_name) + if os.path.exists(archive_path): + response = ask_path_exists( + 'The file %s exists. (i)gnore, (w)ipe, (b)ackup, (a)bort ' % + display_path(archive_path), ('i', 'w', 'b', 'a')) + if response == 'i': + create_archive = False + elif response == 'w': + logger.warning('Deleting %s', display_path(archive_path)) + os.remove(archive_path) + elif response == 'b': + dest_file = backup_dir(archive_path) + logger.warning( + 'Backing up %s to %s', + display_path(archive_path), + display_path(dest_file), + ) + shutil.move(archive_path, dest_file) + elif response == 'a': + sys.exit(-1) + if create_archive: + zip = zipfile.ZipFile( + archive_path, 'w', zipfile.ZIP_DEFLATED, + allowZip64=True + ) + dir = os.path.normcase(os.path.abspath(self.setup_py_dir)) + for dirpath, dirnames, filenames in os.walk(dir): + if 'pip-egg-info' in dirnames: + dirnames.remove('pip-egg-info') + for dirname in dirnames: + dir_arcname = self._get_archive_name(dirname, + parentdir=dirpath, + rootdir=dir) + zipdir = zipfile.ZipInfo(dir_arcname + '/') + zipdir.external_attr = 0x1ED << 16 # 0o755 + zip.writestr(zipdir, '') + for filename in filenames: + if filename == PIP_DELETE_MARKER_FILENAME: + continue + file_arcname = self._get_archive_name(filename, + parentdir=dirpath, + rootdir=dir) + filename = os.path.join(dirpath, filename) + zip.write(filename, file_arcname) + zip.close() + logger.info('Saved %s', display_path(archive_path)) + + def install( + self, + install_options, # type: List[str] + global_options=None, # type: Optional[Sequence[str]] + root=None, # type: Optional[str] + home=None, # type: Optional[str] + prefix=None, # type: Optional[str] + warn_script_location=True, # type: bool + use_user_site=False, # type: bool + pycompile=True # type: bool + ): + # type: (...) -> None + global_options = global_options if global_options is not None else [] + if self.editable: + self.install_editable( + install_options, global_options, prefix=prefix, + ) + return + if self.is_wheel: + version = wheel.wheel_version(self.source_dir) + wheel.check_compatibility(version, self.name) + + self.move_wheel_files( + self.source_dir, root=root, prefix=prefix, home=home, + warn_script_location=warn_script_location, + use_user_site=use_user_site, pycompile=pycompile, + ) + self.install_succeeded = True + return + + # Extend the list of global and install options passed on to + # the setup.py call with the ones from the requirements file. + # Options specified in requirements file override those + # specified on the command line, since the last option given + # to setup.py is the one that is used. + global_options = list(global_options) + \ + self.options.get('global_options', []) + install_options = list(install_options) + \ + self.options.get('install_options', []) + + if self.isolated: + # https://github.com/python/mypy/issues/1174 + global_options = global_options + ["--no-user-cfg"] # type: ignore + + with TempDirectory(kind="record") as temp_dir: + record_filename = os.path.join(temp_dir.path, 'install-record.txt') + install_args = self.get_install_args( + global_options, record_filename, root, prefix, pycompile, + ) + msg = 'Running setup.py install for %s' % (self.name,) + with open_spinner(msg) as spinner: + with indent_log(): + with self.build_env: + call_subprocess( + install_args + install_options, + cwd=self.setup_py_dir, + spinner=spinner, + ) + + if not os.path.exists(record_filename): + logger.debug('Record file %s not found', record_filename) + return + self.install_succeeded = True + + def prepend_root(path): + # type: (str) -> str + if root is None or not os.path.isabs(path): + return path + else: + return change_root(root, path) + + with open(record_filename) as f: + for line in f: + directory = os.path.dirname(line) + if directory.endswith('.egg-info'): + egg_info_dir = prepend_root(directory) + break + else: + logger.warning( + 'Could not find .egg-info directory in install record' + ' for %s', + self, + ) + # FIXME: put the record somewhere + # FIXME: should this be an error? + return + new_lines = [] + with open(record_filename) as f: + for line in f: + filename = line.strip() + if os.path.isdir(filename): + filename += os.path.sep + new_lines.append( + os.path.relpath(prepend_root(filename), egg_info_dir) + ) + new_lines.sort() + ensure_dir(egg_info_dir) + inst_files_path = os.path.join(egg_info_dir, 'installed-files.txt') + with open(inst_files_path, 'w') as f: + f.write('\n'.join(new_lines) + '\n') + + def get_install_args( + self, + global_options, # type: Sequence[str] + record_filename, # type: str + root, # type: Optional[str] + prefix, # type: Optional[str] + pycompile # type: bool + ): + # type: (...) -> List[str] + install_args = make_setuptools_shim_args(self.setup_py_path, + unbuffered_output=True) + install_args += list(global_options) + \ + ['install', '--record', record_filename] + install_args += ['--single-version-externally-managed'] + + if root is not None: + install_args += ['--root', root] + if prefix is not None: + install_args += ['--prefix', prefix] + + if pycompile: + install_args += ["--compile"] + else: + install_args += ["--no-compile"] + + if running_under_virtualenv(): + py_ver_str = 'python' + sysconfig.get_python_version() + install_args += ['--install-headers', + os.path.join(sys.prefix, 'include', 'site', + py_ver_str, self.name)] + + return install_args diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_set.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_set.py new file mode 100644 index 0000000..d1966a4 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_set.py @@ -0,0 +1,193 @@ +from __future__ import absolute_import + +import logging +from collections import OrderedDict + +from pip._internal.exceptions import InstallationError +from pip._internal.utils.logging import indent_log +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.wheel import Wheel + +if MYPY_CHECK_RUNNING: + from typing import Dict, Iterable, List, Optional, Tuple + from pip._internal.req.req_install import InstallRequirement + + +logger = logging.getLogger(__name__) + + +class RequirementSet(object): + + def __init__(self, require_hashes=False, check_supported_wheels=True): + # type: (bool, bool) -> None + """Create a RequirementSet. + """ + + self.requirements = OrderedDict() # type: Dict[str, InstallRequirement] # noqa: E501 + self.require_hashes = require_hashes + self.check_supported_wheels = check_supported_wheels + + # Mapping of alias: real_name + self.requirement_aliases = {} # type: Dict[str, str] + self.unnamed_requirements = [] # type: List[InstallRequirement] + self.successfully_downloaded = [] # type: List[InstallRequirement] + self.reqs_to_cleanup = [] # type: List[InstallRequirement] + + def __str__(self): + # type: () -> str + reqs = [req for req in self.requirements.values() + if not req.comes_from] + reqs.sort(key=lambda req: req.name.lower()) + return ' '.join([str(req.req) for req in reqs]) + + def __repr__(self): + # type: () -> str + reqs = [req for req in self.requirements.values()] + reqs.sort(key=lambda req: req.name.lower()) + reqs_str = ', '.join([str(req.req) for req in reqs]) + return ('<%s object; %d requirement(s): %s>' + % (self.__class__.__name__, len(reqs), reqs_str)) + + def add_requirement( + self, + install_req, # type: InstallRequirement + parent_req_name=None, # type: Optional[str] + extras_requested=None # type: Optional[Iterable[str]] + ): + # type: (...) -> Tuple[List[InstallRequirement], Optional[InstallRequirement]] # noqa: E501 + """Add install_req as a requirement to install. + + :param parent_req_name: The name of the requirement that needed this + added. The name is used because when multiple unnamed requirements + resolve to the same name, we could otherwise end up with dependency + links that point outside the Requirements set. parent_req must + already be added. Note that None implies that this is a user + supplied requirement, vs an inferred one. + :param extras_requested: an iterable of extras used to evaluate the + environment markers. + :return: Additional requirements to scan. That is either [] if + the requirement is not applicable, or [install_req] if the + requirement is applicable and has just been added. + """ + name = install_req.name + + # If the markers do not match, ignore this requirement. + if not install_req.match_markers(extras_requested): + logger.info( + "Ignoring %s: markers '%s' don't match your environment", + name, install_req.markers, + ) + return [], None + + # If the wheel is not supported, raise an error. + # Should check this after filtering out based on environment markers to + # allow specifying different wheels based on the environment/OS, in a + # single requirements file. + if install_req.link and install_req.link.is_wheel: + wheel = Wheel(install_req.link.filename) + if self.check_supported_wheels and not wheel.supported(): + raise InstallationError( + "%s is not a supported wheel on this platform." % + wheel.filename + ) + + # This next bit is really a sanity check. + assert install_req.is_direct == (parent_req_name is None), ( + "a direct req shouldn't have a parent and also, " + "a non direct req should have a parent" + ) + + # Unnamed requirements are scanned again and the requirement won't be + # added as a dependency until after scanning. + if not name: + # url or path requirement w/o an egg fragment + self.unnamed_requirements.append(install_req) + return [install_req], None + + try: + existing_req = self.get_requirement(name) + except KeyError: + existing_req = None + + has_conflicting_requirement = ( + parent_req_name is None and + existing_req and + not existing_req.constraint and + existing_req.extras == install_req.extras and + existing_req.req.specifier != install_req.req.specifier + ) + if has_conflicting_requirement: + raise InstallationError( + "Double requirement given: %s (already in %s, name=%r)" + % (install_req, existing_req, name) + ) + + # When no existing requirement exists, add the requirement as a + # dependency and it will be scanned again after. + if not existing_req: + self.requirements[name] = install_req + # FIXME: what about other normalizations? E.g., _ vs. -? + if name.lower() != name: + self.requirement_aliases[name.lower()] = name + # We'd want to rescan this requirements later + return [install_req], install_req + + # Assume there's no need to scan, and that we've already + # encountered this for scanning. + if install_req.constraint or not existing_req.constraint: + return [], existing_req + + does_not_satisfy_constraint = ( + install_req.link and + not ( + existing_req.link and + install_req.link.path == existing_req.link.path + ) + ) + if does_not_satisfy_constraint: + self.reqs_to_cleanup.append(install_req) + raise InstallationError( + "Could not satisfy constraints for '%s': " + "installation from path or url cannot be " + "constrained to a version" % name, + ) + # If we're now installing a constraint, mark the existing + # object for real installation. + existing_req.constraint = False + existing_req.extras = tuple(sorted( + set(existing_req.extras) | set(install_req.extras) + )) + logger.debug( + "Setting %s extras to: %s", + existing_req, existing_req.extras, + ) + # Return the existing requirement for addition to the parent and + # scanning again. + return [existing_req], existing_req + + def has_requirement(self, project_name): + # type: (str) -> bool + name = project_name.lower() + if (name in self.requirements and + not self.requirements[name].constraint or + name in self.requirement_aliases and + not self.requirements[self.requirement_aliases[name]].constraint): + return True + return False + + def get_requirement(self, project_name): + # type: (str) -> InstallRequirement + for name in project_name, project_name.lower(): + if name in self.requirements: + return self.requirements[name] + if name in self.requirement_aliases: + return self.requirements[self.requirement_aliases[name]] + raise KeyError("No project with the name %r" % project_name) + + def cleanup_files(self): + # type: () -> None + """Clean up files, remove builds.""" + logger.debug('Cleaning up...') + with indent_log(): + for req in self.reqs_to_cleanup: + req.remove_temporary_source() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_tracker.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_tracker.py new file mode 100644 index 0000000..e36a3f6 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_tracker.py @@ -0,0 +1,96 @@ +from __future__ import absolute_import + +import contextlib +import errno +import hashlib +import logging +import os + +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from types import TracebackType + from typing import Iterator, Optional, Set, Type + from pip._internal.req.req_install import InstallRequirement + from pip._internal.models.link import Link + +logger = logging.getLogger(__name__) + + +class RequirementTracker(object): + + def __init__(self): + # type: () -> None + self._root = os.environ.get('PIP_REQ_TRACKER') + if self._root is None: + self._temp_dir = TempDirectory(delete=False, kind='req-tracker') + self._temp_dir.create() + self._root = os.environ['PIP_REQ_TRACKER'] = self._temp_dir.path + logger.debug('Created requirements tracker %r', self._root) + else: + self._temp_dir = None + logger.debug('Re-using requirements tracker %r', self._root) + self._entries = set() # type: Set[InstallRequirement] + + def __enter__(self): + # type: () -> RequirementTracker + return self + + def __exit__( + self, + exc_type, # type: Optional[Type[BaseException]] + exc_val, # type: Optional[BaseException] + exc_tb # type: Optional[TracebackType] + ): + # type: (...) -> None + self.cleanup() + + def _entry_path(self, link): + # type: (Link) -> str + hashed = hashlib.sha224(link.url_without_fragment.encode()).hexdigest() + return os.path.join(self._root, hashed) + + def add(self, req): + # type: (InstallRequirement) -> None + link = req.link + info = str(req) + entry_path = self._entry_path(link) + try: + with open(entry_path) as fp: + # Error, these's already a build in progress. + raise LookupError('%s is already being built: %s' + % (link, fp.read())) + except IOError as e: + if e.errno != errno.ENOENT: + raise + assert req not in self._entries + with open(entry_path, 'w') as fp: + fp.write(info) + self._entries.add(req) + logger.debug('Added %s to build tracker %r', req, self._root) + + def remove(self, req): + # type: (InstallRequirement) -> None + link = req.link + self._entries.remove(req) + os.unlink(self._entry_path(link)) + logger.debug('Removed %s from build tracker %r', req, self._root) + + def cleanup(self): + # type: () -> None + for req in set(self._entries): + self.remove(req) + remove = self._temp_dir is not None + if remove: + self._temp_dir.cleanup() + logger.debug('%s build tracker %r', + 'Removed' if remove else 'Cleaned', + self._root) + + @contextlib.contextmanager + def track(self, req): + # type: (InstallRequirement) -> Iterator[None] + self.add(req) + yield + self.remove(req) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_uninstall.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_uninstall.py new file mode 100644 index 0000000..733301c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/req/req_uninstall.py @@ -0,0 +1,633 @@ +from __future__ import absolute_import + +import csv +import functools +import logging +import os +import sys +import sysconfig + +from pip._vendor import pkg_resources + +from pip._internal.exceptions import UninstallationError +from pip._internal.locations import bin_py, bin_user +from pip._internal.utils.compat import WINDOWS, cache_from_source, uses_pycache +from pip._internal.utils.logging import indent_log +from pip._internal.utils.misc import ( + FakeFile, ask, dist_in_usersite, dist_is_local, egg_link_path, is_local, + normalize_path, renames, rmtree, +) +from pip._internal.utils.temp_dir import AdjacentTempDirectory, TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import ( + Any, Callable, Dict, Iterable, Iterator, List, Optional, Set, Tuple, + ) + from pip._vendor.pkg_resources import Distribution + +logger = logging.getLogger(__name__) + + +def _script_names(dist, script_name, is_gui): + # type: (Distribution, str, bool) -> List[str] + """Create the fully qualified name of the files created by + {console,gui}_scripts for the given ``dist``. + Returns the list of file names + """ + if dist_in_usersite(dist): + bin_dir = bin_user + else: + bin_dir = bin_py + exe_name = os.path.join(bin_dir, script_name) + paths_to_remove = [exe_name] + if WINDOWS: + paths_to_remove.append(exe_name + '.exe') + paths_to_remove.append(exe_name + '.exe.manifest') + if is_gui: + paths_to_remove.append(exe_name + '-script.pyw') + else: + paths_to_remove.append(exe_name + '-script.py') + return paths_to_remove + + +def _unique(fn): + # type: (Callable) -> Callable[..., Iterator[Any]] + @functools.wraps(fn) + def unique(*args, **kw): + # type: (Any, Any) -> Iterator[Any] + seen = set() # type: Set[Any] + for item in fn(*args, **kw): + if item not in seen: + seen.add(item) + yield item + return unique + + +@_unique +def uninstallation_paths(dist): + # type: (Distribution) -> Iterator[str] + """ + Yield all the uninstallation paths for dist based on RECORD-without-.py[co] + + Yield paths to all the files in RECORD. For each .py file in RECORD, add + the .pyc and .pyo in the same directory. + + UninstallPathSet.add() takes care of the __pycache__ .py[co]. + """ + r = csv.reader(FakeFile(dist.get_metadata_lines('RECORD'))) + for row in r: + path = os.path.join(dist.location, row[0]) + yield path + if path.endswith('.py'): + dn, fn = os.path.split(path) + base = fn[:-3] + path = os.path.join(dn, base + '.pyc') + yield path + path = os.path.join(dn, base + '.pyo') + yield path + + +def compact(paths): + # type: (Iterable[str]) -> Set[str] + """Compact a path set to contain the minimal number of paths + necessary to contain all paths in the set. If /a/path/ and + /a/path/to/a/file.txt are both in the set, leave only the + shorter path.""" + + sep = os.path.sep + short_paths = set() # type: Set[str] + for path in sorted(paths, key=len): + should_skip = any( + path.startswith(shortpath.rstrip("*")) and + path[len(shortpath.rstrip("*").rstrip(sep))] == sep + for shortpath in short_paths + ) + if not should_skip: + short_paths.add(path) + return short_paths + + +def compress_for_rename(paths): + # type: (Iterable[str]) -> Set[str] + """Returns a set containing the paths that need to be renamed. + + This set may include directories when the original sequence of paths + included every file on disk. + """ + case_map = dict((os.path.normcase(p), p) for p in paths) + remaining = set(case_map) + unchecked = sorted(set(os.path.split(p)[0] + for p in case_map.values()), key=len) + wildcards = set() # type: Set[str] + + def norm_join(*a): + # type: (str) -> str + return os.path.normcase(os.path.join(*a)) + + for root in unchecked: + if any(os.path.normcase(root).startswith(w) + for w in wildcards): + # This directory has already been handled. + continue + + all_files = set() # type: Set[str] + all_subdirs = set() # type: Set[str] + for dirname, subdirs, files in os.walk(root): + all_subdirs.update(norm_join(root, dirname, d) + for d in subdirs) + all_files.update(norm_join(root, dirname, f) + for f in files) + # If all the files we found are in our remaining set of files to + # remove, then remove them from the latter set and add a wildcard + # for the directory. + if not (all_files - remaining): + remaining.difference_update(all_files) + wildcards.add(root + os.sep) + + return set(map(case_map.__getitem__, remaining)) | wildcards + + +def compress_for_output_listing(paths): + # type: (Iterable[str]) -> Tuple[Set[str], Set[str]] + """Returns a tuple of 2 sets of which paths to display to user + + The first set contains paths that would be deleted. Files of a package + are not added and the top-level directory of the package has a '*' added + at the end - to signify that all it's contents are removed. + + The second set contains files that would have been skipped in the above + folders. + """ + + will_remove = set(paths) + will_skip = set() + + # Determine folders and files + folders = set() + files = set() + for path in will_remove: + if path.endswith(".pyc"): + continue + if path.endswith("__init__.py") or ".dist-info" in path: + folders.add(os.path.dirname(path)) + files.add(path) + + # probably this one https://github.com/python/mypy/issues/390 + _normcased_files = set(map(os.path.normcase, files)) # type: ignore + + folders = compact(folders) + + # This walks the tree using os.walk to not miss extra folders + # that might get added. + for folder in folders: + for dirpath, _, dirfiles in os.walk(folder): + for fname in dirfiles: + if fname.endswith(".pyc"): + continue + + file_ = os.path.join(dirpath, fname) + if (os.path.isfile(file_) and + os.path.normcase(file_) not in _normcased_files): + # We are skipping this file. Add it to the set. + will_skip.add(file_) + + will_remove = files | { + os.path.join(folder, "*") for folder in folders + } + + return will_remove, will_skip + + +class StashedUninstallPathSet(object): + """A set of file rename operations to stash files while + tentatively uninstalling them.""" + def __init__(self): + # type: () -> None + # Mapping from source file root to [Adjacent]TempDirectory + # for files under that directory. + self._save_dirs = {} # type: Dict[str, TempDirectory] + # (old path, new path) tuples for each move that may need + # to be undone. + self._moves = [] # type: List[Tuple[str, str]] + + def _get_directory_stash(self, path): + # type: (str) -> str + """Stashes a directory. + + Directories are stashed adjacent to their original location if + possible, or else moved/copied into the user's temp dir.""" + + try: + save_dir = AdjacentTempDirectory(path) # type: TempDirectory + save_dir.create() + except OSError: + save_dir = TempDirectory(kind="uninstall") + save_dir.create() + self._save_dirs[os.path.normcase(path)] = save_dir + + return save_dir.path + + def _get_file_stash(self, path): + # type: (str) -> str + """Stashes a file. + + If no root has been provided, one will be created for the directory + in the user's temp directory.""" + path = os.path.normcase(path) + head, old_head = os.path.dirname(path), None + save_dir = None + + while head != old_head: + try: + save_dir = self._save_dirs[head] + break + except KeyError: + pass + head, old_head = os.path.dirname(head), head + else: + # Did not find any suitable root + head = os.path.dirname(path) + save_dir = TempDirectory(kind='uninstall') + save_dir.create() + self._save_dirs[head] = save_dir + + relpath = os.path.relpath(path, head) + if relpath and relpath != os.path.curdir: + return os.path.join(save_dir.path, relpath) + return save_dir.path + + def stash(self, path): + # type: (str) -> str + """Stashes the directory or file and returns its new location. + """ + if os.path.isdir(path): + new_path = self._get_directory_stash(path) + else: + new_path = self._get_file_stash(path) + + self._moves.append((path, new_path)) + if os.path.isdir(path) and os.path.isdir(new_path): + # If we're moving a directory, we need to + # remove the destination first or else it will be + # moved to inside the existing directory. + # We just created new_path ourselves, so it will + # be removable. + os.rmdir(new_path) + renames(path, new_path) + return new_path + + def commit(self): + # type: () -> None + """Commits the uninstall by removing stashed files.""" + for _, save_dir in self._save_dirs.items(): + save_dir.cleanup() + self._moves = [] + self._save_dirs = {} + + def rollback(self): + # type: () -> None + """Undoes the uninstall by moving stashed files back.""" + for p in self._moves: + logging.info("Moving to %s\n from %s", *p) + + for new_path, path in self._moves: + try: + logger.debug('Replacing %s from %s', new_path, path) + if os.path.isfile(new_path): + os.unlink(new_path) + elif os.path.isdir(new_path): + rmtree(new_path) + renames(path, new_path) + except OSError as ex: + logger.error("Failed to restore %s", new_path) + logger.debug("Exception: %s", ex) + + self.commit() + + @property + def can_rollback(self): + # type: () -> bool + return bool(self._moves) + + +class UninstallPathSet(object): + """A set of file paths to be removed in the uninstallation of a + requirement.""" + def __init__(self, dist): + # type: (Distribution) -> None + self.paths = set() # type: Set[str] + self._refuse = set() # type: Set[str] + self.pth = {} # type: Dict[str, UninstallPthEntries] + self.dist = dist + self._moved_paths = StashedUninstallPathSet() + + def _permitted(self, path): + # type: (str) -> bool + """ + Return True if the given path is one we are permitted to + remove/modify, False otherwise. + + """ + return is_local(path) + + def add(self, path): + # type: (str) -> None + head, tail = os.path.split(path) + + # we normalize the head to resolve parent directory symlinks, but not + # the tail, since we only want to uninstall symlinks, not their targets + path = os.path.join(normalize_path(head), os.path.normcase(tail)) + + if not os.path.exists(path): + return + if self._permitted(path): + self.paths.add(path) + else: + self._refuse.add(path) + + # __pycache__ files can show up after 'installed-files.txt' is created, + # due to imports + if os.path.splitext(path)[1] == '.py' and uses_pycache: + self.add(cache_from_source(path)) + + def add_pth(self, pth_file, entry): + # type: (str, str) -> None + pth_file = normalize_path(pth_file) + if self._permitted(pth_file): + if pth_file not in self.pth: + self.pth[pth_file] = UninstallPthEntries(pth_file) + self.pth[pth_file].add(entry) + else: + self._refuse.add(pth_file) + + def remove(self, auto_confirm=False, verbose=False): + # type: (bool, bool) -> None + """Remove paths in ``self.paths`` with confirmation (unless + ``auto_confirm`` is True).""" + + if not self.paths: + logger.info( + "Can't uninstall '%s'. No files were found to uninstall.", + self.dist.project_name, + ) + return + + dist_name_version = ( + self.dist.project_name + "-" + self.dist.version + ) + logger.info('Uninstalling %s:', dist_name_version) + + with indent_log(): + if auto_confirm or self._allowed_to_proceed(verbose): + moved = self._moved_paths + + for_rename = compress_for_rename(self.paths) + + for path in sorted(compact(for_rename)): + moved.stash(path) + logger.debug('Removing file or directory %s', path) + + for pth in self.pth.values(): + pth.remove() + + logger.info('Successfully uninstalled %s', dist_name_version) + + def _allowed_to_proceed(self, verbose): + # type: (bool) -> bool + """Display which files would be deleted and prompt for confirmation + """ + + def _display(msg, paths): + # type: (str, Iterable[str]) -> None + if not paths: + return + + logger.info(msg) + with indent_log(): + for path in sorted(compact(paths)): + logger.info(path) + + if not verbose: + will_remove, will_skip = compress_for_output_listing(self.paths) + else: + # In verbose mode, display all the files that are going to be + # deleted. + will_remove = set(self.paths) + will_skip = set() + + _display('Would remove:', will_remove) + _display('Would not remove (might be manually added):', will_skip) + _display('Would not remove (outside of prefix):', self._refuse) + if verbose: + _display('Will actually move:', compress_for_rename(self.paths)) + + return ask('Proceed (y/n)? ', ('y', 'n')) == 'y' + + def rollback(self): + # type: () -> None + """Rollback the changes previously made by remove().""" + if not self._moved_paths.can_rollback: + logger.error( + "Can't roll back %s; was not uninstalled", + self.dist.project_name, + ) + return + logger.info('Rolling back uninstall of %s', self.dist.project_name) + self._moved_paths.rollback() + for pth in self.pth.values(): + pth.rollback() + + def commit(self): + # type: () -> None + """Remove temporary save dir: rollback will no longer be possible.""" + self._moved_paths.commit() + + @classmethod + def from_dist(cls, dist): + # type: (Distribution) -> UninstallPathSet + dist_path = normalize_path(dist.location) + if not dist_is_local(dist): + logger.info( + "Not uninstalling %s at %s, outside environment %s", + dist.key, + dist_path, + sys.prefix, + ) + return cls(dist) + + if dist_path in {p for p in {sysconfig.get_path("stdlib"), + sysconfig.get_path("platstdlib")} + if p}: + logger.info( + "Not uninstalling %s at %s, as it is in the standard library.", + dist.key, + dist_path, + ) + return cls(dist) + + paths_to_remove = cls(dist) + develop_egg_link = egg_link_path(dist) + develop_egg_link_egg_info = '{}.egg-info'.format( + pkg_resources.to_filename(dist.project_name)) + egg_info_exists = dist.egg_info and os.path.exists(dist.egg_info) + # Special case for distutils installed package + distutils_egg_info = getattr(dist._provider, 'path', None) + + # Uninstall cases order do matter as in the case of 2 installs of the + # same package, pip needs to uninstall the currently detected version + if (egg_info_exists and dist.egg_info.endswith('.egg-info') and + not dist.egg_info.endswith(develop_egg_link_egg_info)): + # if dist.egg_info.endswith(develop_egg_link_egg_info), we + # are in fact in the develop_egg_link case + paths_to_remove.add(dist.egg_info) + if dist.has_metadata('installed-files.txt'): + for installed_file in dist.get_metadata( + 'installed-files.txt').splitlines(): + path = os.path.normpath( + os.path.join(dist.egg_info, installed_file) + ) + paths_to_remove.add(path) + # FIXME: need a test for this elif block + # occurs with --single-version-externally-managed/--record outside + # of pip + elif dist.has_metadata('top_level.txt'): + if dist.has_metadata('namespace_packages.txt'): + namespaces = dist.get_metadata('namespace_packages.txt') + else: + namespaces = [] + for top_level_pkg in [ + p for p + in dist.get_metadata('top_level.txt').splitlines() + if p and p not in namespaces]: + path = os.path.join(dist.location, top_level_pkg) + paths_to_remove.add(path) + paths_to_remove.add(path + '.py') + paths_to_remove.add(path + '.pyc') + paths_to_remove.add(path + '.pyo') + + elif distutils_egg_info: + raise UninstallationError( + "Cannot uninstall {!r}. It is a distutils installed project " + "and thus we cannot accurately determine which files belong " + "to it which would lead to only a partial uninstall.".format( + dist.project_name, + ) + ) + + elif dist.location.endswith('.egg'): + # package installed by easy_install + # We cannot match on dist.egg_name because it can slightly vary + # i.e. setuptools-0.6c11-py2.6.egg vs setuptools-0.6rc11-py2.6.egg + paths_to_remove.add(dist.location) + easy_install_egg = os.path.split(dist.location)[1] + easy_install_pth = os.path.join(os.path.dirname(dist.location), + 'easy-install.pth') + paths_to_remove.add_pth(easy_install_pth, './' + easy_install_egg) + + elif egg_info_exists and dist.egg_info.endswith('.dist-info'): + for path in uninstallation_paths(dist): + paths_to_remove.add(path) + + elif develop_egg_link: + # develop egg + with open(develop_egg_link, 'r') as fh: + link_pointer = os.path.normcase(fh.readline().strip()) + assert (link_pointer == dist.location), ( + 'Egg-link %s does not match installed location of %s ' + '(at %s)' % (link_pointer, dist.project_name, dist.location) + ) + paths_to_remove.add(develop_egg_link) + easy_install_pth = os.path.join(os.path.dirname(develop_egg_link), + 'easy-install.pth') + paths_to_remove.add_pth(easy_install_pth, dist.location) + + else: + logger.debug( + 'Not sure how to uninstall: %s - Check: %s', + dist, dist.location, + ) + + # find distutils scripts= scripts + if dist.has_metadata('scripts') and dist.metadata_isdir('scripts'): + for script in dist.metadata_listdir('scripts'): + if dist_in_usersite(dist): + bin_dir = bin_user + else: + bin_dir = bin_py + paths_to_remove.add(os.path.join(bin_dir, script)) + if WINDOWS: + paths_to_remove.add(os.path.join(bin_dir, script) + '.bat') + + # find console_scripts + _scripts_to_remove = [] + console_scripts = dist.get_entry_map(group='console_scripts') + for name in console_scripts.keys(): + _scripts_to_remove.extend(_script_names(dist, name, False)) + # find gui_scripts + gui_scripts = dist.get_entry_map(group='gui_scripts') + for name in gui_scripts.keys(): + _scripts_to_remove.extend(_script_names(dist, name, True)) + + for s in _scripts_to_remove: + paths_to_remove.add(s) + + return paths_to_remove + + +class UninstallPthEntries(object): + def __init__(self, pth_file): + # type: (str) -> None + if not os.path.isfile(pth_file): + raise UninstallationError( + "Cannot remove entries from nonexistent file %s" % pth_file + ) + self.file = pth_file + self.entries = set() # type: Set[str] + self._saved_lines = None # type: Optional[List[bytes]] + + def add(self, entry): + # type: (str) -> None + entry = os.path.normcase(entry) + # On Windows, os.path.normcase converts the entry to use + # backslashes. This is correct for entries that describe absolute + # paths outside of site-packages, but all the others use forward + # slashes. + if WINDOWS and not os.path.splitdrive(entry)[0]: + entry = entry.replace('\\', '/') + self.entries.add(entry) + + def remove(self): + # type: () -> None + logger.debug('Removing pth entries from %s:', self.file) + with open(self.file, 'rb') as fh: + # windows uses '\r\n' with py3k, but uses '\n' with py2.x + lines = fh.readlines() + self._saved_lines = lines + if any(b'\r\n' in line for line in lines): + endline = '\r\n' + else: + endline = '\n' + # handle missing trailing newline + if lines and not lines[-1].endswith(endline.encode("utf-8")): + lines[-1] = lines[-1] + endline.encode("utf-8") + for entry in self.entries: + try: + logger.debug('Removing entry: %s', entry) + lines.remove((entry + endline).encode("utf-8")) + except ValueError: + pass + with open(self.file, 'wb') as fh: + fh.writelines(lines) + + def rollback(self): + # type: () -> bool + if self._saved_lines is None: + logger.error( + 'Cannot roll back changes to %s, none were made', self.file + ) + return False + logger.debug('Rolling %s back to previous state', self.file) + with open(self.file, 'wb') as fh: + fh.writelines(self._saved_lines) + return True diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..fcaffdde923f12819e0587eccc17cde7b0d2e436 GIT binary patch literal 204 zcmWIL<>g`kf^QoZCW7e4AOaaM0yz#qT+9L_QW%06G#UL?G8BP?5yY=T{eq&*vc!^9 z{j$U&{j~g?l+>bPeai~{^mxm%qTH%HqqHo8jEst^s`wmBv!sk710YDx(+|-v$Sly! z%quQQ%*oL;Ffc2tEHf+x34(EaW?o5ZQC?z>erZW&PO*MGP$07;K3=b&@)n0pZhlH> NPO2TqDW8Fu0RV=AH&Flp literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/appdirs.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/appdirs.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..197dbbc88c457e53a14b1e78a99f50baad16f62c GIT binary patch literal 8083 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..cb89b4c8f3c817df7e2caff56f90b2e7240935f9 GIT binary patch literal 6979 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ebae4a9c4d2a0da558d9dc6feb86cddb05922616 GIT binary patch literal 2875 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4e6e95868dca807a2951162d3a258792df974567 GIT binary patch literal 675 zcmYjOy^hmB5Z+xov59;kLWlzK0Jyj~P@EJAAtVG1(p{0DgA`cCyNR9nkJ*h$BB$XH z&ykdLJkJ(1RJ;HM6|=q*y0PYecD|YM+mn+XLHhIK82z*e`DL8j#L#(xEFYubgwu@7 zt~G5n%UEvBEK0b=?XP5Jb2=e@=Qmc9bDwH&AyimJDhbyqkEsdY5TX$m`6aUahC&fV zIlW@C&)Ebq_Ou}lU0Lu&(Iq=r4LMRM6g}8SL|ZZVu=7->Ay;(IE=lpgCaSyY!ITp7 zy(iqBkawhErgnn84^D$}=^oMhbg#A9;g0Fb5NnSy^TO|(YX^rGIPVn9z_0zDc9KX& zN`Ypj)VA42JDJ#|Qb{n2fVq=)E+(%4O3>XXj)la^%kbijc6bU!lndX2t|@aX5OrFv zC0aL^`A(pZslPI)Agv=Mf;xg=US?c?491&a5squfcg55Ba+D;S-7d_=XCD(7AuWnv z8dPa@nif(;S#~-aoz>g=$=U>44%0#joFNO=D$QgtPctF6Qi*(6ZS^2dM7+BGOXcT6 zfPw#x?WK7|41{SI_cX{VIK_9_n%a`+!^*uo9tGRI_l dqxMz1>n(BDv~Zv0C0}Raxw*MChcZZ>^$%~bs%-!O literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e9752f880b74226d077a0af0f4c8df92f31f7396 GIT binary patch literal 2306 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/marker_files.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/marker_files.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c22bc1c44412b3660a052916a5ba862c5ed00d4b GIT binary patch literal 815 zcmY*W!EVz)5Z$$%HnC{w1qmUL_DBwiLnSIzLO=utRWzj}MMb$-u6I*!yRog^b=pMf z3GVztd*sHIU)d`set-ifW}N_Gq?uiN-oBZ6^L}H)M_@m{-oyh3q3`x%)!-j`4zBJ) zpon6DhL}1-hq^_IzINtFyEo1i*4`Xb{L%Tmb>+;R>zZD>!5AH*$LJmEqYsEW zpqM**<`b}E$(K@Cc^37_IF{#3E_KX6vue734OK4Lv#fyEeXxxWEzU+$&= literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/misc.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/misc.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..01b66a55309c1f41797150b750387e57ecd62dce GIT binary patch literal 29900 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 HRBQeMUEHLl literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/outdated.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/outdated.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..eb107e55ae3986f585b62fe254db7c3ba82243df GIT binary patch literal 4260 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 Dgtk9o literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d2c2b6f119bf01b034aafa3bdd2d8489cd3ec1a9 GIT binary patch literal 4924 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 K#zRaGzxfX;^}}@l literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/ui.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/ui.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..43d06af6814d45a42625973a880c6864a604764c GIT binary patch literal 11859 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4e7ffc90a842c9b06f7a90918fce7a29a5d09aa5 GIT binary patch literal 927 zcmZuv!EO^V5M6sWyJ<=bLZw3D;u9!{WCMpvtq>rPdZPy#F1f6n+DV*lyer$gO+$Ms zA3~1Y_#R(5@dF$ZqqgYynlzW~Dm zhVo#5{D}wHpWz^6n1x@1LBt}~fV08SY0!>;K}B$K=ImW*fb#)VKL=w1gBZHOYM0?t zc%Nbu0s=b4H{p4xo;sXG@V&<3V~c=%;-*rP^i{=)7?BJ9OmU(rDTN#pA+=zfP*MwJ zDw=ayzaYmn*PIk)!qtV)yxa2MvD=E%JS!C+iFw~{52@z2-f=s!$%JZZjIyD=)HYtF z*<{R(L%#>A3FCY7N2jF{H8nh~sY*vh&bZR);XEB@hqan5Ai!47p7*13V zWGvHuT8gp*BO99MonG&tzN}wX4)mG{X}FR!Pb(vGoo=qwEidik+bd_4gm&2`7`xqi zQsWkm&>oJka_&DwI9k_4ya&ewQ}hjc8=7d^SfVAmUZL?7(7wdi$Rsy`I`TQqD~PKj zPfoZd=}T*f ccN+Nr$9HMIhH str + r""" + Return full path to the user-specific cache dir for this application. + + "appname" is the name of application. + + Typical user cache directories are: + macOS: ~/Library/Caches/ + Unix: ~/.cache/ (XDG default) + Windows: C:\Users\\AppData\Local\\Cache + + On Windows the only suggestion in the MSDN docs is that local settings go + in the `CSIDL_LOCAL_APPDATA` directory. This is identical to the + non-roaming app data dir (the default returned by `user_data_dir`). Apps + typically put cache data somewhere *under* the given dir here. Some + examples: + ...\Mozilla\Firefox\Profiles\\Cache + ...\Acme\SuperApp\Cache\1.0 + + OPINION: This function appends "Cache" to the `CSIDL_LOCAL_APPDATA` value. + """ + if WINDOWS: + # Get the base path + path = os.path.normpath(_get_win_folder("CSIDL_LOCAL_APPDATA")) + + # When using Python 2, return paths as bytes on Windows like we do on + # other operating systems. See helper function docs for more details. + if PY2 and isinstance(path, text_type): + path = _win_path_to_bytes(path) + + # Add our app name and Cache directory to it + path = os.path.join(path, appname, "Cache") + elif sys.platform == "darwin": + # Get the base path + path = expanduser("~/Library/Caches") + + # Add our app name to it + path = os.path.join(path, appname) + else: + # Get the base path + path = os.getenv("XDG_CACHE_HOME", expanduser("~/.cache")) + + # Add our app name to it + path = os.path.join(path, appname) + + return path + + +def user_data_dir(appname, roaming=False): + # type: (str, bool) -> str + r""" + Return full path to the user-specific data dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "roaming" (boolean, default False) can be set True to use the Windows + roaming appdata directory. That means that for users on a Windows + network setup for roaming profiles, this user data will be + sync'd on login. See + + for a discussion of issues. + + Typical user data directories are: + macOS: ~/Library/Application Support/ + if it exists, else ~/.config/ + Unix: ~/.local/share/ # or in + $XDG_DATA_HOME, if defined + Win XP (not roaming): C:\Documents and Settings\\ ... + ...Application Data\ + Win XP (roaming): C:\Documents and Settings\\Local ... + ...Settings\Application Data\ + Win 7 (not roaming): C:\\Users\\AppData\Local\ + Win 7 (roaming): C:\\Users\\AppData\Roaming\ + + For Unix, we follow the XDG spec and support $XDG_DATA_HOME. + That means, by default "~/.local/share/". + """ + if WINDOWS: + const = roaming and "CSIDL_APPDATA" or "CSIDL_LOCAL_APPDATA" + path = os.path.join(os.path.normpath(_get_win_folder(const)), appname) + elif sys.platform == "darwin": + path = os.path.join( + expanduser('~/Library/Application Support/'), + appname, + ) if os.path.isdir(os.path.join( + expanduser('~/Library/Application Support/'), + appname, + ) + ) else os.path.join( + expanduser('~/.config/'), + appname, + ) + else: + path = os.path.join( + os.getenv('XDG_DATA_HOME', expanduser("~/.local/share")), + appname, + ) + + return path + + +def user_config_dir(appname, roaming=True): + # type: (str, bool) -> str + """Return full path to the user-specific config dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "roaming" (boolean, default True) can be set False to not use the + Windows roaming appdata directory. That means that for users on a + Windows network setup for roaming profiles, this user data will be + sync'd on login. See + + for a discussion of issues. + + Typical user data directories are: + macOS: same as user_data_dir + Unix: ~/.config/ + Win *: same as user_data_dir + + For Unix, we follow the XDG spec and support $XDG_CONFIG_HOME. + That means, by default "~/.config/". + """ + if WINDOWS: + path = user_data_dir(appname, roaming=roaming) + elif sys.platform == "darwin": + path = user_data_dir(appname) + else: + path = os.getenv('XDG_CONFIG_HOME', expanduser("~/.config")) + path = os.path.join(path, appname) + + return path + + +# for the discussion regarding site_config_dirs locations +# see +def site_config_dirs(appname): + # type: (str) -> List[str] + r"""Return a list of potential user-shared config dirs for this application. + + "appname" is the name of application. + + Typical user config directories are: + macOS: /Library/Application Support// + Unix: /etc or $XDG_CONFIG_DIRS[i]// for each value in + $XDG_CONFIG_DIRS + Win XP: C:\Documents and Settings\All Users\Application ... + ...Data\\ + Vista: (Fail! "C:\ProgramData" is a hidden *system* directory + on Vista.) + Win 7: Hidden, but writeable on Win 7: + C:\ProgramData\\ + """ + if WINDOWS: + path = os.path.normpath(_get_win_folder("CSIDL_COMMON_APPDATA")) + pathlist = [os.path.join(path, appname)] + elif sys.platform == 'darwin': + pathlist = [os.path.join('/Library/Application Support', appname)] + else: + # try looking in $XDG_CONFIG_DIRS + xdg_config_dirs = os.getenv('XDG_CONFIG_DIRS', '/etc/xdg') + if xdg_config_dirs: + pathlist = [ + os.path.join(expanduser(x), appname) + for x in xdg_config_dirs.split(os.pathsep) + ] + else: + pathlist = [] + + # always look in /etc directly as well + pathlist.append('/etc') + + return pathlist + + +# -- Windows support functions -- + +def _get_win_folder_from_registry(csidl_name): + # type: (str) -> str + """ + This is a fallback technique at best. I'm not sure if using the + registry for this guarantees us the correct answer for all CSIDL_* + names. + """ + import _winreg + + shell_folder_name = { + "CSIDL_APPDATA": "AppData", + "CSIDL_COMMON_APPDATA": "Common AppData", + "CSIDL_LOCAL_APPDATA": "Local AppData", + }[csidl_name] + + key = _winreg.OpenKey( + _winreg.HKEY_CURRENT_USER, + r"Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders" + ) + directory, _type = _winreg.QueryValueEx(key, shell_folder_name) + return directory + + +def _get_win_folder_with_ctypes(csidl_name): + # type: (str) -> str + csidl_const = { + "CSIDL_APPDATA": 26, + "CSIDL_COMMON_APPDATA": 35, + "CSIDL_LOCAL_APPDATA": 28, + }[csidl_name] + + buf = ctypes.create_unicode_buffer(1024) + ctypes.windll.shell32.SHGetFolderPathW(None, csidl_const, None, 0, buf) + + # Downgrade to short path name if have highbit chars. See + # . + has_high_char = False + for c in buf: + if ord(c) > 255: + has_high_char = True + break + if has_high_char: + buf2 = ctypes.create_unicode_buffer(1024) + if ctypes.windll.kernel32.GetShortPathNameW(buf.value, buf2, 1024): + buf = buf2 + + return buf.value + + +if WINDOWS: + try: + import ctypes + _get_win_folder = _get_win_folder_with_ctypes + except ImportError: + _get_win_folder = _get_win_folder_from_registry + + +def _win_path_to_bytes(path): + """Encode Windows paths to bytes. Only used on Python 2. + + Motivation is to be consistent with other operating systems where paths + are also returned as bytes. This avoids problems mixing bytes and Unicode + elsewhere in the codebase. For more details and discussion see + . + + If encoding using ASCII and MBCS fails, return the original Unicode path. + """ + for encoding in ('ASCII', 'MBCS'): + try: + return path.encode(encoding) + except (UnicodeEncodeError, LookupError): + pass + return path diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/compat.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/compat.py new file mode 100644 index 0000000..ec3995c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/compat.py @@ -0,0 +1,293 @@ +"""Stuff that differs in different Python versions and platform +distributions.""" +from __future__ import absolute_import, division + +import codecs +import locale +import logging +import os +import shutil +import sys + +from pip._vendor.six import text_type +from pip._vendor.urllib3.util import IS_PYOPENSSL + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional, Text, Tuple, Union + +try: + import _ssl # noqa +except ImportError: + ssl = None +else: + # This additional assignment was needed to prevent a mypy error. + ssl = _ssl + +try: + import ipaddress +except ImportError: + try: + from pip._vendor import ipaddress # type: ignore + except ImportError: + import ipaddr as ipaddress # type: ignore + ipaddress.ip_address = ipaddress.IPAddress # type: ignore + ipaddress.ip_network = ipaddress.IPNetwork # type: ignore + + +__all__ = [ + "ipaddress", "uses_pycache", "console_to_str", "native_str", + "get_path_uid", "stdlib_pkgs", "WINDOWS", "samefile", "get_terminal_size", + "get_extension_suffixes", +] + + +logger = logging.getLogger(__name__) + +HAS_TLS = (ssl is not None) or IS_PYOPENSSL + +if sys.version_info >= (3, 4): + uses_pycache = True + from importlib.util import cache_from_source +else: + import imp + + try: + cache_from_source = imp.cache_from_source # type: ignore + except AttributeError: + # does not use __pycache__ + cache_from_source = None + + uses_pycache = cache_from_source is not None + + +if sys.version_info >= (3, 5): + backslashreplace_decode = "backslashreplace" +else: + # In version 3.4 and older, backslashreplace exists + # but does not support use for decoding. + # We implement our own replace handler for this + # situation, so that we can consistently use + # backslash replacement for all versions. + def backslashreplace_decode_fn(err): + raw_bytes = (err.object[i] for i in range(err.start, err.end)) + if sys.version_info[0] == 2: + # Python 2 gave us characters - convert to numeric bytes + raw_bytes = (ord(b) for b in raw_bytes) + return u"".join(u"\\x%x" % c for c in raw_bytes), err.end + codecs.register_error( + "backslashreplace_decode", + backslashreplace_decode_fn, + ) + backslashreplace_decode = "backslashreplace_decode" + + +def str_to_display(data, desc=None): + # type: (Union[bytes, Text], Optional[str]) -> Text + """ + For display or logging purposes, convert a bytes object (or text) to + text (e.g. unicode in Python 2) safe for output. + + :param desc: An optional phrase describing the input data, for use in + the log message if a warning is logged. Defaults to "Bytes object". + + This function should never error out and so can take a best effort + approach. It is okay to be lossy if needed since the return value is + just for display. + + We assume the data is in the locale preferred encoding. If it won't + decode properly, we warn the user but decode as best we can. + + We also ensure that the output can be safely written to standard output + without encoding errors. + """ + if isinstance(data, text_type): + return data + + # Otherwise, data is a bytes object (str in Python 2). + # First, get the encoding we assume. This is the preferred + # encoding for the locale, unless that is not found, or + # it is ASCII, in which case assume UTF-8 + encoding = locale.getpreferredencoding() + if (not encoding) or codecs.lookup(encoding).name == "ascii": + encoding = "utf-8" + + # Now try to decode the data - if we fail, warn the user and + # decode with replacement. + try: + decoded_data = data.decode(encoding) + except UnicodeDecodeError: + if desc is None: + desc = 'Bytes object' + msg_format = '{} does not appear to be encoded as %s'.format(desc) + logger.warning(msg_format, encoding) + decoded_data = data.decode(encoding, errors=backslashreplace_decode) + + # Make sure we can print the output, by encoding it to the output + # encoding with replacement of unencodable characters, and then + # decoding again. + # We use stderr's encoding because it's less likely to be + # redirected and if we don't find an encoding we skip this + # step (on the assumption that output is wrapped by something + # that won't fail). + # The double getattr is to deal with the possibility that we're + # being called in a situation where sys.__stderr__ doesn't exist, + # or doesn't have an encoding attribute. Neither of these cases + # should occur in normal pip use, but there's no harm in checking + # in case people use pip in (unsupported) unusual situations. + output_encoding = getattr(getattr(sys, "__stderr__", None), + "encoding", None) + + if output_encoding: + output_encoded = decoded_data.encode( + output_encoding, + errors="backslashreplace" + ) + decoded_data = output_encoded.decode(output_encoding) + + return decoded_data + + +def console_to_str(data): + # type: (bytes) -> Text + """Return a string, safe for output, of subprocess output. + """ + return str_to_display(data, desc='Subprocess output') + + +if sys.version_info >= (3,): + def native_str(s, replace=False): + # type: (str, bool) -> str + if isinstance(s, bytes): + return s.decode('utf-8', 'replace' if replace else 'strict') + return s + +else: + def native_str(s, replace=False): + # type: (str, bool) -> str + # Replace is ignored -- unicode to UTF-8 can't fail + if isinstance(s, text_type): + return s.encode('utf-8') + return s + + +def get_path_uid(path): + # type: (str) -> int + """ + Return path's uid. + + Does not follow symlinks: + https://github.com/pypa/pip/pull/935#discussion_r5307003 + + Placed this function in compat due to differences on AIX and + Jython, that should eventually go away. + + :raises OSError: When path is a symlink or can't be read. + """ + if hasattr(os, 'O_NOFOLLOW'): + fd = os.open(path, os.O_RDONLY | os.O_NOFOLLOW) + file_uid = os.fstat(fd).st_uid + os.close(fd) + else: # AIX and Jython + # WARNING: time of check vulnerability, but best we can do w/o NOFOLLOW + if not os.path.islink(path): + # older versions of Jython don't have `os.fstat` + file_uid = os.stat(path).st_uid + else: + # raise OSError for parity with os.O_NOFOLLOW above + raise OSError( + "%s is a symlink; Will not return uid for symlinks" % path + ) + return file_uid + + +if sys.version_info >= (3, 4): + from importlib.machinery import EXTENSION_SUFFIXES + + def get_extension_suffixes(): + return EXTENSION_SUFFIXES +else: + from imp import get_suffixes + + def get_extension_suffixes(): + return [suffix[0] for suffix in get_suffixes()] + + +def expanduser(path): + # type: (str) -> str + """ + Expand ~ and ~user constructions. + + Includes a workaround for https://bugs.python.org/issue14768 + """ + expanded = os.path.expanduser(path) + if path.startswith('~/') and expanded.startswith('//'): + expanded = expanded[1:] + return expanded + + +# packages in the stdlib that may have installation metadata, but should not be +# considered 'installed'. this theoretically could be determined based on +# dist.location (py27:`sysconfig.get_paths()['stdlib']`, +# py26:sysconfig.get_config_vars('LIBDEST')), but fear platform variation may +# make this ineffective, so hard-coding +stdlib_pkgs = {"python", "wsgiref", "argparse"} + + +# windows detection, covers cpython and ironpython +WINDOWS = (sys.platform.startswith("win") or + (sys.platform == 'cli' and os.name == 'nt')) + + +def samefile(file1, file2): + # type: (str, str) -> bool + """Provide an alternative for os.path.samefile on Windows/Python2""" + if hasattr(os.path, 'samefile'): + return os.path.samefile(file1, file2) + else: + path1 = os.path.normcase(os.path.abspath(file1)) + path2 = os.path.normcase(os.path.abspath(file2)) + return path1 == path2 + + +if hasattr(shutil, 'get_terminal_size'): + def get_terminal_size(): + # type: () -> Tuple[int, int] + """ + Returns a tuple (x, y) representing the width(x) and the height(y) + in characters of the terminal window. + """ + return tuple(shutil.get_terminal_size()) # type: ignore +else: + def get_terminal_size(): + # type: () -> Tuple[int, int] + """ + Returns a tuple (x, y) representing the width(x) and the height(y) + in characters of the terminal window. + """ + def ioctl_GWINSZ(fd): + try: + import fcntl + import termios + import struct + cr = struct.unpack_from( + 'hh', + fcntl.ioctl(fd, termios.TIOCGWINSZ, '12345678') + ) + except Exception: + return None + if cr == (0, 0): + return None + return cr + cr = ioctl_GWINSZ(0) or ioctl_GWINSZ(1) or ioctl_GWINSZ(2) + if not cr: + try: + fd = os.open(os.ctermid(), os.O_RDONLY) + cr = ioctl_GWINSZ(fd) + os.close(fd) + except Exception: + pass + if not cr: + cr = (os.environ.get('LINES', 25), os.environ.get('COLUMNS', 80)) + return int(cr[1]), int(cr[0]) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/deprecation.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/deprecation.py new file mode 100644 index 0000000..b9359bd --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/deprecation.py @@ -0,0 +1,100 @@ +""" +A module that implements tooling to enable easy warnings about deprecations. +""" +from __future__ import absolute_import + +import logging +import warnings + +from pip._vendor.packaging.version import parse + +from pip import __version__ as current_version +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Any, Optional + + +DEPRECATION_MSG_PREFIX = "DEPRECATION: " + + +class PipDeprecationWarning(Warning): + pass + + +_original_showwarning = None # type: Any + + +# Warnings <-> Logging Integration +def _showwarning(message, category, filename, lineno, file=None, line=None): + if file is not None: + if _original_showwarning is not None: + _original_showwarning( + message, category, filename, lineno, file, line, + ) + elif issubclass(category, PipDeprecationWarning): + # We use a specially named logger which will handle all of the + # deprecation messages for pip. + logger = logging.getLogger("pip._internal.deprecations") + logger.warning(message) + else: + _original_showwarning( + message, category, filename, lineno, file, line, + ) + + +def install_warning_logger(): + # type: () -> None + # Enable our Deprecation Warnings + warnings.simplefilter("default", PipDeprecationWarning, append=True) + + global _original_showwarning + + if _original_showwarning is None: + _original_showwarning = warnings.showwarning + warnings.showwarning = _showwarning + + +def deprecated(reason, replacement, gone_in, issue=None): + # type: (str, Optional[str], Optional[str], Optional[int]) -> None + """Helper to deprecate existing functionality. + + reason: + Textual reason shown to the user about why this functionality has + been deprecated. + replacement: + Textual suggestion shown to the user about what alternative + functionality they can use. + gone_in: + The version of pip does this functionality should get removed in. + Raises errors if pip's current version is greater than or equal to + this. + issue: + Issue number on the tracker that would serve as a useful place for + users to find related discussion and provide feedback. + + Always pass replacement, gone_in and issue as keyword arguments for clarity + at the call site. + """ + + # Construct a nice message. + # This is eagerly formatted as we want it to get logged as if someone + # typed this entire message out. + sentences = [ + (reason, DEPRECATION_MSG_PREFIX + "{}"), + (gone_in, "pip {} will remove support for this functionality."), + (replacement, "A possible replacement is {}."), + (issue, ( + "You can find discussion regarding this at " + "https://github.com/pypa/pip/issues/{}." + )), + ] + message = " ".join( + template.format(val) for val, template in sentences if val is not None + ) + + # Raise as an error if it has to be removed. + if gone_in is not None and parse(current_version) >= parse(gone_in): + raise PipDeprecationWarning(message) + + warnings.warn(message, category=PipDeprecationWarning, stacklevel=2) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/encoding.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/encoding.py new file mode 100644 index 0000000..30139f2 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/encoding.py @@ -0,0 +1,39 @@ +import codecs +import locale +import re +import sys + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List, Tuple, Text + +BOMS = [ + (codecs.BOM_UTF8, 'utf-8'), + (codecs.BOM_UTF16, 'utf-16'), + (codecs.BOM_UTF16_BE, 'utf-16-be'), + (codecs.BOM_UTF16_LE, 'utf-16-le'), + (codecs.BOM_UTF32, 'utf-32'), + (codecs.BOM_UTF32_BE, 'utf-32-be'), + (codecs.BOM_UTF32_LE, 'utf-32-le'), +] # type: List[Tuple[bytes, Text]] + +ENCODING_RE = re.compile(br'coding[:=]\s*([-\w.]+)') + + +def auto_decode(data): + # type: (bytes) -> Text + """Check a bytes string for a BOM to correctly detect the encoding + + Fallback to locale.getpreferredencoding(False) like open() on Python3""" + for bom, encoding in BOMS: + if data.startswith(bom): + return data[len(bom):].decode(encoding) + # Lets check the first two lines as in PEP263 + for line in data.split(b'\n')[:2]: + if line[0:1] == b'#' and ENCODING_RE.search(line): + encoding = ENCODING_RE.search(line).groups()[0].decode('ascii') + return data.decode(encoding) + return data.decode( + locale.getpreferredencoding(False) or sys.getdefaultencoding(), + ) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/filesystem.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/filesystem.py new file mode 100644 index 0000000..1e6b033 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/filesystem.py @@ -0,0 +1,30 @@ +import os +import os.path + +from pip._internal.utils.compat import get_path_uid + + +def check_path_owner(path): + # type: (str) -> bool + # If we don't have a way to check the effective uid of this process, then + # we'll just assume that we own the directory. + if not hasattr(os, "geteuid"): + return True + + previous = None + while path != previous: + if os.path.lexists(path): + # Check if path is writable by current user. + if os.geteuid() == 0: + # Special handling for root user in order to handle properly + # cases where users use sudo without -H flag. + try: + path_uid = get_path_uid(path) + except OSError: + return False + return path_uid == 0 + else: + return os.access(path, os.W_OK) + else: + previous, path = path, os.path.dirname(path) + return False # assume we don't own the path diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/glibc.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/glibc.py new file mode 100644 index 0000000..aa77d9b --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/glibc.py @@ -0,0 +1,120 @@ +from __future__ import absolute_import + +import os +import re +import warnings + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional, Tuple + + +def glibc_version_string(): + # type: () -> Optional[str] + "Returns glibc version string, or None if not using glibc." + return glibc_version_string_confstr() or glibc_version_string_ctypes() + + +def glibc_version_string_confstr(): + # type: () -> Optional[str] + "Primary implementation of glibc_version_string using os.confstr." + # os.confstr is quite a bit faster than ctypes.DLL. It's also less likely + # to be broken or missing. This strategy is used in the standard library + # platform module: + # https://github.com/python/cpython/blob/fcf1d003bf4f0100c9d0921ff3d70e1127ca1b71/Lib/platform.py#L175-L183 + try: + # os.confstr("CS_GNU_LIBC_VERSION") returns a string like "glibc 2.17": + _, version = os.confstr("CS_GNU_LIBC_VERSION").split() + except (AttributeError, OSError, ValueError): + # os.confstr() or CS_GNU_LIBC_VERSION not available (or a bad value)... + return None + return version + + +def glibc_version_string_ctypes(): + # type: () -> Optional[str] + "Fallback implementation of glibc_version_string using ctypes." + + try: + import ctypes + except ImportError: + return None + + # ctypes.CDLL(None) internally calls dlopen(NULL), and as the dlopen + # manpage says, "If filename is NULL, then the returned handle is for the + # main program". This way we can let the linker do the work to figure out + # which libc our process is actually using. + process_namespace = ctypes.CDLL(None) + try: + gnu_get_libc_version = process_namespace.gnu_get_libc_version + except AttributeError: + # Symbol doesn't exist -> therefore, we are not linked to + # glibc. + return None + + # Call gnu_get_libc_version, which returns a string like "2.5" + gnu_get_libc_version.restype = ctypes.c_char_p + version_str = gnu_get_libc_version() + # py2 / py3 compatibility: + if not isinstance(version_str, str): + version_str = version_str.decode("ascii") + + return version_str + + +# Separated out from have_compatible_glibc for easier unit testing +def check_glibc_version(version_str, required_major, minimum_minor): + # type: (str, int, int) -> bool + # Parse string and check against requested version. + # + # We use a regexp instead of str.split because we want to discard any + # random junk that might come after the minor version -- this might happen + # in patched/forked versions of glibc (e.g. Linaro's version of glibc + # uses version strings like "2.20-2014.11"). See gh-3588. + m = re.match(r"(?P[0-9]+)\.(?P[0-9]+)", version_str) + if not m: + warnings.warn("Expected glibc version with 2 components major.minor," + " got: %s" % version_str, RuntimeWarning) + return False + return (int(m.group("major")) == required_major and + int(m.group("minor")) >= minimum_minor) + + +def have_compatible_glibc(required_major, minimum_minor): + # type: (int, int) -> bool + version_str = glibc_version_string() + if version_str is None: + return False + return check_glibc_version(version_str, required_major, minimum_minor) + + +# platform.libc_ver regularly returns completely nonsensical glibc +# versions. E.g. on my computer, platform says: +# +# ~$ python2.7 -c 'import platform; print(platform.libc_ver())' +# ('glibc', '2.7') +# ~$ python3.5 -c 'import platform; print(platform.libc_ver())' +# ('glibc', '2.9') +# +# But the truth is: +# +# ~$ ldd --version +# ldd (Debian GLIBC 2.22-11) 2.22 +# +# This is unfortunate, because it means that the linehaul data on libc +# versions that was generated by pip 8.1.2 and earlier is useless and +# misleading. Solution: instead of using platform, use our code that actually +# works. +def libc_ver(): + # type: () -> Tuple[str, str] + """Try to determine the glibc version + + Returns a tuple of strings (lib, version) which default to empty strings + in case the lookup fails. + """ + glibc_version = glibc_version_string() + if glibc_version is None: + return ("", "") + else: + return ("glibc", glibc_version) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/hashes.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/hashes.py new file mode 100644 index 0000000..e8aabe1 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/hashes.py @@ -0,0 +1,128 @@ +from __future__ import absolute_import + +import hashlib + +from pip._vendor.six import iteritems, iterkeys, itervalues + +from pip._internal.exceptions import ( + HashMismatch, HashMissing, InstallationError, +) +from pip._internal.utils.misc import read_chunks +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import ( + Dict, List, BinaryIO, NoReturn, Iterator + ) + from pip._vendor.six import PY3 + if PY3: + from hashlib import _Hash + else: + from hashlib import _hash as _Hash + + +# The recommended hash algo of the moment. Change this whenever the state of +# the art changes; it won't hurt backward compatibility. +FAVORITE_HASH = 'sha256' + + +# Names of hashlib algorithms allowed by the --hash option and ``pip hash`` +# Currently, those are the ones at least as collision-resistant as sha256. +STRONG_HASHES = ['sha256', 'sha384', 'sha512'] + + +class Hashes(object): + """A wrapper that builds multiple hashes at once and checks them against + known-good values + + """ + def __init__(self, hashes=None): + # type: (Dict[str, List[str]]) -> None + """ + :param hashes: A dict of algorithm names pointing to lists of allowed + hex digests + """ + self._allowed = {} if hashes is None else hashes + + @property + def digest_count(self): + # type: () -> int + return sum(len(digests) for digests in self._allowed.values()) + + def is_hash_allowed( + self, + hash_name, # type: str + hex_digest, # type: str + ): + """Return whether the given hex digest is allowed.""" + return hex_digest in self._allowed.get(hash_name, []) + + def check_against_chunks(self, chunks): + # type: (Iterator[bytes]) -> None + """Check good hashes against ones built from iterable of chunks of + data. + + Raise HashMismatch if none match. + + """ + gots = {} + for hash_name in iterkeys(self._allowed): + try: + gots[hash_name] = hashlib.new(hash_name) + except (ValueError, TypeError): + raise InstallationError('Unknown hash name: %s' % hash_name) + + for chunk in chunks: + for hash in itervalues(gots): + hash.update(chunk) + + for hash_name, got in iteritems(gots): + if got.hexdigest() in self._allowed[hash_name]: + return + self._raise(gots) + + def _raise(self, gots): + # type: (Dict[str, _Hash]) -> NoReturn + raise HashMismatch(self._allowed, gots) + + def check_against_file(self, file): + # type: (BinaryIO) -> None + """Check good hashes against a file-like object + + Raise HashMismatch if none match. + + """ + return self.check_against_chunks(read_chunks(file)) + + def check_against_path(self, path): + # type: (str) -> None + with open(path, 'rb') as file: + return self.check_against_file(file) + + def __nonzero__(self): + # type: () -> bool + """Return whether I know any known-good hashes.""" + return bool(self._allowed) + + def __bool__(self): + # type: () -> bool + return self.__nonzero__() + + +class MissingHashes(Hashes): + """A workalike for Hashes used when we're missing a hash for a requirement + + It computes the actual hash of the requirement and raises a HashMissing + exception showing it to the user. + + """ + def __init__(self): + # type: () -> None + """Don't offer the ``hashes`` kwarg.""" + # Pass our favorite hash in to generate a "gotten hash". With the + # empty list, it will never match, so an error will always raise. + super(MissingHashes, self).__init__(hashes={FAVORITE_HASH: []}) + + def _raise(self, gots): + # type: (Dict[str, _Hash]) -> NoReturn + raise HashMissing(gots[FAVORITE_HASH].hexdigest()) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/logging.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/logging.py new file mode 100644 index 0000000..3fbec71 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/logging.py @@ -0,0 +1,394 @@ +from __future__ import absolute_import + +import contextlib +import errno +import logging +import logging.handlers +import os +import sys +from logging import Filter + +from pip._vendor.six import PY2 + +from pip._internal.utils.compat import WINDOWS +from pip._internal.utils.deprecation import DEPRECATION_MSG_PREFIX +from pip._internal.utils.misc import ensure_dir, subprocess_logger + +try: + import threading +except ImportError: + import dummy_threading as threading # type: ignore + + +try: + # Use "import as" and set colorama in the else clause to avoid mypy + # errors and get the following correct revealed type for colorama: + # `Union[_importlib_modulespec.ModuleType, None]` + # Otherwise, we get an error like the following in the except block: + # > Incompatible types in assignment (expression has type "None", + # variable has type Module) + # TODO: eliminate the need to use "import as" once mypy addresses some + # of its issues with conditional imports. Here is an umbrella issue: + # https://github.com/python/mypy/issues/1297 + from pip._vendor import colorama as _colorama +# Lots of different errors can come from this, including SystemError and +# ImportError. +except Exception: + colorama = None +else: + # Import Fore explicitly rather than accessing below as colorama.Fore + # to avoid the following error running mypy: + # > Module has no attribute "Fore" + # TODO: eliminate the need to import Fore once mypy addresses some of its + # issues with conditional imports. This particular case could be an + # instance of the following issue (but also see the umbrella issue above): + # https://github.com/python/mypy/issues/3500 + from pip._vendor.colorama import Fore + + colorama = _colorama + + +_log_state = threading.local() +_log_state.indentation = 0 + + +class BrokenStdoutLoggingError(Exception): + """ + Raised if BrokenPipeError occurs for the stdout stream while logging. + """ + pass + + +# BrokenPipeError does not exist in Python 2 and, in addition, manifests +# differently in Windows and non-Windows. +if WINDOWS: + # In Windows, a broken pipe can show up as EINVAL rather than EPIPE: + # https://bugs.python.org/issue19612 + # https://bugs.python.org/issue30418 + if PY2: + def _is_broken_pipe_error(exc_class, exc): + """See the docstring for non-Windows Python 3 below.""" + return (exc_class is IOError and + exc.errno in (errno.EINVAL, errno.EPIPE)) + else: + # In Windows, a broken pipe IOError became OSError in Python 3. + def _is_broken_pipe_error(exc_class, exc): + """See the docstring for non-Windows Python 3 below.""" + return ((exc_class is BrokenPipeError) or # noqa: F821 + (exc_class is OSError and + exc.errno in (errno.EINVAL, errno.EPIPE))) +elif PY2: + def _is_broken_pipe_error(exc_class, exc): + """See the docstring for non-Windows Python 3 below.""" + return (exc_class is IOError and exc.errno == errno.EPIPE) +else: + # Then we are in the non-Windows Python 3 case. + def _is_broken_pipe_error(exc_class, exc): + """ + Return whether an exception is a broken pipe error. + + Args: + exc_class: an exception class. + exc: an exception instance. + """ + return (exc_class is BrokenPipeError) # noqa: F821 + + +@contextlib.contextmanager +def indent_log(num=2): + """ + A context manager which will cause the log output to be indented for any + log messages emitted inside it. + """ + _log_state.indentation += num + try: + yield + finally: + _log_state.indentation -= num + + +def get_indentation(): + return getattr(_log_state, 'indentation', 0) + + +class IndentingFormatter(logging.Formatter): + + def __init__(self, *args, **kwargs): + """ + A logging.Formatter that obeys the indent_log() context manager. + + :param add_timestamp: A bool indicating output lines should be prefixed + with their record's timestamp. + """ + self.add_timestamp = kwargs.pop("add_timestamp", False) + super(IndentingFormatter, self).__init__(*args, **kwargs) + + def get_message_start(self, formatted, levelno): + """ + Return the start of the formatted log message (not counting the + prefix to add to each line). + """ + if levelno < logging.WARNING: + return '' + if formatted.startswith(DEPRECATION_MSG_PREFIX): + # Then the message already has a prefix. We don't want it to + # look like "WARNING: DEPRECATION: ...." + return '' + if levelno < logging.ERROR: + return 'WARNING: ' + + return 'ERROR: ' + + def format(self, record): + """ + Calls the standard formatter, but will indent all of the log message + lines by our current indentation level. + """ + formatted = super(IndentingFormatter, self).format(record) + message_start = self.get_message_start(formatted, record.levelno) + formatted = message_start + formatted + + prefix = '' + if self.add_timestamp: + # TODO: Use Formatter.default_time_format after dropping PY2. + t = self.formatTime(record, "%Y-%m-%dT%H:%M:%S") + prefix = '%s,%03d ' % (t, record.msecs) + prefix += " " * get_indentation() + formatted = "".join([ + prefix + line + for line in formatted.splitlines(True) + ]) + return formatted + + +def _color_wrap(*colors): + def wrapped(inp): + return "".join(list(colors) + [inp, colorama.Style.RESET_ALL]) + return wrapped + + +class ColorizedStreamHandler(logging.StreamHandler): + + # Don't build up a list of colors if we don't have colorama + if colorama: + COLORS = [ + # This needs to be in order from highest logging level to lowest. + (logging.ERROR, _color_wrap(Fore.RED)), + (logging.WARNING, _color_wrap(Fore.YELLOW)), + ] + else: + COLORS = [] + + def __init__(self, stream=None, no_color=None): + logging.StreamHandler.__init__(self, stream) + self._no_color = no_color + + if WINDOWS and colorama: + self.stream = colorama.AnsiToWin32(self.stream) + + def _using_stdout(self): + """ + Return whether the handler is using sys.stdout. + """ + if WINDOWS and colorama: + # Then self.stream is an AnsiToWin32 object. + return self.stream.wrapped is sys.stdout + + return self.stream is sys.stdout + + def should_color(self): + # Don't colorize things if we do not have colorama or if told not to + if not colorama or self._no_color: + return False + + real_stream = ( + self.stream if not isinstance(self.stream, colorama.AnsiToWin32) + else self.stream.wrapped + ) + + # If the stream is a tty we should color it + if hasattr(real_stream, "isatty") and real_stream.isatty(): + return True + + # If we have an ANSI term we should color it + if os.environ.get("TERM") == "ANSI": + return True + + # If anything else we should not color it + return False + + def format(self, record): + msg = logging.StreamHandler.format(self, record) + + if self.should_color(): + for level, color in self.COLORS: + if record.levelno >= level: + msg = color(msg) + break + + return msg + + # The logging module says handleError() can be customized. + def handleError(self, record): + exc_class, exc = sys.exc_info()[:2] + # If a broken pipe occurred while calling write() or flush() on the + # stdout stream in logging's Handler.emit(), then raise our special + # exception so we can handle it in main() instead of logging the + # broken pipe error and continuing. + if (exc_class and self._using_stdout() and + _is_broken_pipe_error(exc_class, exc)): + raise BrokenStdoutLoggingError() + + return super(ColorizedStreamHandler, self).handleError(record) + + +class BetterRotatingFileHandler(logging.handlers.RotatingFileHandler): + + def _open(self): + ensure_dir(os.path.dirname(self.baseFilename)) + return logging.handlers.RotatingFileHandler._open(self) + + +class MaxLevelFilter(Filter): + + def __init__(self, level): + self.level = level + + def filter(self, record): + return record.levelno < self.level + + +class ExcludeLoggerFilter(Filter): + + """ + A logging Filter that excludes records from a logger (or its children). + """ + + def filter(self, record): + # The base Filter class allows only records from a logger (or its + # children). + return not super(ExcludeLoggerFilter, self).filter(record) + + +def setup_logging(verbosity, no_color, user_log_file): + """Configures and sets up all of the logging + + Returns the requested logging level, as its integer value. + """ + + # Determine the level to be logging at. + if verbosity >= 1: + level = "DEBUG" + elif verbosity == -1: + level = "WARNING" + elif verbosity == -2: + level = "ERROR" + elif verbosity <= -3: + level = "CRITICAL" + else: + level = "INFO" + + level_number = getattr(logging, level) + + # The "root" logger should match the "console" level *unless* we also need + # to log to a user log file. + include_user_log = user_log_file is not None + if include_user_log: + additional_log_file = user_log_file + root_level = "DEBUG" + else: + additional_log_file = "/dev/null" + root_level = level + + # Disable any logging besides WARNING unless we have DEBUG level logging + # enabled for vendored libraries. + vendored_log_level = "WARNING" if level in ["INFO", "ERROR"] else "DEBUG" + + # Shorthands for clarity + log_streams = { + "stdout": "ext://sys.stdout", + "stderr": "ext://sys.stderr", + } + handler_classes = { + "stream": "pip._internal.utils.logging.ColorizedStreamHandler", + "file": "pip._internal.utils.logging.BetterRotatingFileHandler", + } + handlers = ["console", "console_errors", "console_subprocess"] + ( + ["user_log"] if include_user_log else [] + ) + + logging.config.dictConfig({ + "version": 1, + "disable_existing_loggers": False, + "filters": { + "exclude_warnings": { + "()": "pip._internal.utils.logging.MaxLevelFilter", + "level": logging.WARNING, + }, + "restrict_to_subprocess": { + "()": "logging.Filter", + "name": subprocess_logger.name, + }, + "exclude_subprocess": { + "()": "pip._internal.utils.logging.ExcludeLoggerFilter", + "name": subprocess_logger.name, + }, + }, + "formatters": { + "indent": { + "()": IndentingFormatter, + "format": "%(message)s", + }, + "indent_with_timestamp": { + "()": IndentingFormatter, + "format": "%(message)s", + "add_timestamp": True, + }, + }, + "handlers": { + "console": { + "level": level, + "class": handler_classes["stream"], + "no_color": no_color, + "stream": log_streams["stdout"], + "filters": ["exclude_subprocess", "exclude_warnings"], + "formatter": "indent", + }, + "console_errors": { + "level": "WARNING", + "class": handler_classes["stream"], + "no_color": no_color, + "stream": log_streams["stderr"], + "filters": ["exclude_subprocess"], + "formatter": "indent", + }, + # A handler responsible for logging to the console messages + # from the "subprocessor" logger. + "console_subprocess": { + "level": level, + "class": handler_classes["stream"], + "no_color": no_color, + "stream": log_streams["stderr"], + "filters": ["restrict_to_subprocess"], + "formatter": "indent", + }, + "user_log": { + "level": "DEBUG", + "class": handler_classes["file"], + "filename": additional_log_file, + "delay": True, + "formatter": "indent_with_timestamp", + }, + }, + "root": { + "level": root_level, + "handlers": handlers, + }, + "loggers": { + "pip._vendor": { + "level": vendored_log_level + } + }, + }) + + return level_number diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/marker_files.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/marker_files.py new file mode 100644 index 0000000..cb0c8eb --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/marker_files.py @@ -0,0 +1,20 @@ +import os.path + +DELETE_MARKER_MESSAGE = '''\ +This file is placed here by pip to indicate the source was put +here by pip. + +Once this package is successfully installed this source code will be +deleted (unless you remove this file). +''' +PIP_DELETE_MARKER_FILENAME = 'pip-delete-this-directory.txt' + + +def write_delete_marker_file(directory): + # type: (str) -> None + """ + Write the pip delete marker file into this directory. + """ + filepath = os.path.join(directory, PIP_DELETE_MARKER_FILENAME) + with open(filepath, 'w') as marker_fp: + marker_fp.write(DELETE_MARKER_MESSAGE) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/misc.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/misc.py new file mode 100644 index 0000000..61f74dc --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/misc.py @@ -0,0 +1,1201 @@ +from __future__ import absolute_import + +import contextlib +import errno +import getpass +import io +# we have a submodule named 'logging' which would shadow this if we used the +# regular name: +import logging as std_logging +import os +import posixpath +import re +import shutil +import stat +import subprocess +import sys +import tarfile +import zipfile +from collections import deque + +from pip._vendor import pkg_resources +# NOTE: retrying is not annotated in typeshed as on 2017-07-17, which is +# why we ignore the type on this import. +from pip._vendor.retrying import retry # type: ignore +from pip._vendor.six import PY2, text_type +from pip._vendor.six.moves import input, shlex_quote +from pip._vendor.six.moves.urllib import parse as urllib_parse +from pip._vendor.six.moves.urllib import request as urllib_request +from pip._vendor.six.moves.urllib.parse import unquote as urllib_unquote + +from pip import __version__ +from pip._internal.exceptions import CommandError, InstallationError +from pip._internal.locations import site_packages, user_site +from pip._internal.utils.compat import ( + WINDOWS, console_to_str, expanduser, stdlib_pkgs, str_to_display, +) +from pip._internal.utils.marker_files import write_delete_marker_file +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.virtualenv import ( + running_under_virtualenv, virtualenv_no_global, +) + +if PY2: + from io import BytesIO as StringIO +else: + from io import StringIO + +if MYPY_CHECK_RUNNING: + from typing import ( + Any, AnyStr, Container, Iterable, List, Mapping, Match, Optional, Text, + Tuple, Union, cast, + ) + from pip._vendor.pkg_resources import Distribution + from pip._internal.models.link import Link + from pip._internal.utils.ui import SpinnerInterface + + VersionInfo = Tuple[int, int, int] +else: + # typing's cast() is needed at runtime, but we don't want to import typing. + # Thus, we use a dummy no-op version, which we tell mypy to ignore. + def cast(type_, value): # type: ignore + return value + + +__all__ = ['rmtree', 'display_path', 'backup_dir', + 'ask', 'splitext', + 'format_size', 'is_installable_dir', + 'is_svn_page', 'file_contents', + 'split_leading_dir', 'has_leading_dir', + 'normalize_path', + 'renames', 'get_prog', + 'unzip_file', 'untar_file', 'unpack_file', 'call_subprocess', + 'captured_stdout', 'ensure_dir', + 'ARCHIVE_EXTENSIONS', 'SUPPORTED_EXTENSIONS', 'WHEEL_EXTENSION', + 'get_installed_version', 'remove_auth_from_url'] + + +logger = std_logging.getLogger(__name__) +subprocess_logger = std_logging.getLogger('pip.subprocessor') + +LOG_DIVIDER = '----------------------------------------' + +WHEEL_EXTENSION = '.whl' +BZ2_EXTENSIONS = ('.tar.bz2', '.tbz') +XZ_EXTENSIONS = ('.tar.xz', '.txz', '.tlz', '.tar.lz', '.tar.lzma') +ZIP_EXTENSIONS = ('.zip', WHEEL_EXTENSION) +TAR_EXTENSIONS = ('.tar.gz', '.tgz', '.tar') +ARCHIVE_EXTENSIONS = ( + ZIP_EXTENSIONS + BZ2_EXTENSIONS + TAR_EXTENSIONS + XZ_EXTENSIONS) +SUPPORTED_EXTENSIONS = ZIP_EXTENSIONS + TAR_EXTENSIONS + +try: + import bz2 # noqa + SUPPORTED_EXTENSIONS += BZ2_EXTENSIONS +except ImportError: + logger.debug('bz2 module is not available') + +try: + # Only for Python 3.3+ + import lzma # noqa + SUPPORTED_EXTENSIONS += XZ_EXTENSIONS +except ImportError: + logger.debug('lzma module is not available') + + +def get_pip_version(): + # type: () -> str + pip_pkg_dir = os.path.join(os.path.dirname(__file__), "..", "..") + pip_pkg_dir = os.path.abspath(pip_pkg_dir) + + return ( + 'pip {} from {} (python {})'.format( + __version__, pip_pkg_dir, sys.version[:3], + ) + ) + + +def normalize_version_info(py_version_info): + # type: (Tuple[int, ...]) -> Tuple[int, int, int] + """ + Convert a tuple of ints representing a Python version to one of length + three. + + :param py_version_info: a tuple of ints representing a Python version, + or None to specify no version. The tuple can have any length. + + :return: a tuple of length three if `py_version_info` is non-None. + Otherwise, return `py_version_info` unchanged (i.e. None). + """ + if len(py_version_info) < 3: + py_version_info += (3 - len(py_version_info)) * (0,) + elif len(py_version_info) > 3: + py_version_info = py_version_info[:3] + + return cast('VersionInfo', py_version_info) + + +def ensure_dir(path): + # type: (AnyStr) -> None + """os.path.makedirs without EEXIST.""" + try: + os.makedirs(path) + except OSError as e: + if e.errno != errno.EEXIST: + raise + + +def get_prog(): + # type: () -> str + try: + prog = os.path.basename(sys.argv[0]) + if prog in ('__main__.py', '-c'): + return "%s -m pip" % sys.executable + else: + return prog + except (AttributeError, TypeError, IndexError): + pass + return 'pip' + + +# Retry every half second for up to 3 seconds +@retry(stop_max_delay=3000, wait_fixed=500) +def rmtree(dir, ignore_errors=False): + # type: (str, bool) -> None + shutil.rmtree(dir, ignore_errors=ignore_errors, + onerror=rmtree_errorhandler) + + +def rmtree_errorhandler(func, path, exc_info): + """On Windows, the files in .svn are read-only, so when rmtree() tries to + remove them, an exception is thrown. We catch that here, remove the + read-only attribute, and hopefully continue without problems.""" + # if file type currently read only + if os.stat(path).st_mode & stat.S_IREAD: + # convert to read/write + os.chmod(path, stat.S_IWRITE) + # use the original function to repeat the operation + func(path) + return + else: + raise + + +def path_to_display(path): + # type: (Optional[Union[str, Text]]) -> Optional[Text] + """ + Convert a bytes (or text) path to text (unicode in Python 2) for display + and logging purposes. + + This function should never error out. Also, this function is mainly needed + for Python 2 since in Python 3 str paths are already text. + """ + if path is None: + return None + if isinstance(path, text_type): + return path + # Otherwise, path is a bytes object (str in Python 2). + try: + display_path = path.decode(sys.getfilesystemencoding(), 'strict') + except UnicodeDecodeError: + # Include the full bytes to make troubleshooting easier, even though + # it may not be very human readable. + if PY2: + # Convert the bytes to a readable str representation using + # repr(), and then convert the str to unicode. + # Also, we add the prefix "b" to the repr() return value both + # to make the Python 2 output look like the Python 3 output, and + # to signal to the user that this is a bytes representation. + display_path = str_to_display('b{!r}'.format(path)) + else: + # Silence the "F821 undefined name 'ascii'" flake8 error since + # in Python 3 ascii() is a built-in. + display_path = ascii(path) # noqa: F821 + + return display_path + + +def display_path(path): + # type: (Union[str, Text]) -> str + """Gives the display value for a given path, making it relative to cwd + if possible.""" + path = os.path.normcase(os.path.abspath(path)) + if sys.version_info[0] == 2: + path = path.decode(sys.getfilesystemencoding(), 'replace') + path = path.encode(sys.getdefaultencoding(), 'replace') + if path.startswith(os.getcwd() + os.path.sep): + path = '.' + path[len(os.getcwd()):] + return path + + +def backup_dir(dir, ext='.bak'): + # type: (str, str) -> str + """Figure out the name of a directory to back up the given dir to + (adding .bak, .bak2, etc)""" + n = 1 + extension = ext + while os.path.exists(dir + extension): + n += 1 + extension = ext + str(n) + return dir + extension + + +def ask_path_exists(message, options): + # type: (str, Iterable[str]) -> str + for action in os.environ.get('PIP_EXISTS_ACTION', '').split(): + if action in options: + return action + return ask(message, options) + + +def _check_no_input(message): + # type: (str) -> None + """Raise an error if no input is allowed.""" + if os.environ.get('PIP_NO_INPUT'): + raise Exception( + 'No input was expected ($PIP_NO_INPUT set); question: %s' % + message + ) + + +def ask(message, options): + # type: (str, Iterable[str]) -> str + """Ask the message interactively, with the given possible responses""" + while 1: + _check_no_input(message) + response = input(message) + response = response.strip().lower() + if response not in options: + print( + 'Your response (%r) was not one of the expected responses: ' + '%s' % (response, ', '.join(options)) + ) + else: + return response + + +def ask_input(message): + # type: (str) -> str + """Ask for input interactively.""" + _check_no_input(message) + return input(message) + + +def ask_password(message): + # type: (str) -> str + """Ask for a password interactively.""" + _check_no_input(message) + return getpass.getpass(message) + + +def format_size(bytes): + # type: (float) -> str + if bytes > 1000 * 1000: + return '%.1fMB' % (bytes / 1000.0 / 1000) + elif bytes > 10 * 1000: + return '%ikB' % (bytes / 1000) + elif bytes > 1000: + return '%.1fkB' % (bytes / 1000.0) + else: + return '%ibytes' % bytes + + +def is_installable_dir(path): + # type: (str) -> bool + """Is path is a directory containing setup.py or pyproject.toml? + """ + if not os.path.isdir(path): + return False + setup_py = os.path.join(path, 'setup.py') + if os.path.isfile(setup_py): + return True + pyproject_toml = os.path.join(path, 'pyproject.toml') + if os.path.isfile(pyproject_toml): + return True + return False + + +def is_svn_page(html): + # type: (Union[str, Text]) -> Optional[Match[Union[str, Text]]] + """ + Returns true if the page appears to be the index page of an svn repository + """ + return (re.search(r'[^<]*Revision \d+:', html) and + re.search(r'Powered by (?:<a[^>]*?>)?Subversion', html, re.I)) + + +def file_contents(filename): + # type: (str) -> Text + with open(filename, 'rb') as fp: + return fp.read().decode('utf-8') + + +def read_chunks(file, size=io.DEFAULT_BUFFER_SIZE): + """Yield pieces of data from a file-like object until EOF.""" + while True: + chunk = file.read(size) + if not chunk: + break + yield chunk + + +def split_leading_dir(path): + # type: (Union[str, Text]) -> List[Union[str, Text]] + path = path.lstrip('/').lstrip('\\') + if '/' in path and (('\\' in path and path.find('/') < path.find('\\')) or + '\\' not in path): + return path.split('/', 1) + elif '\\' in path: + return path.split('\\', 1) + else: + return [path, ''] + + +def has_leading_dir(paths): + # type: (Iterable[Union[str, Text]]) -> bool + """Returns true if all the paths have the same leading path name + (i.e., everything is in one subdirectory in an archive)""" + common_prefix = None + for path in paths: + prefix, rest = split_leading_dir(path) + if not prefix: + return False + elif common_prefix is None: + common_prefix = prefix + elif prefix != common_prefix: + return False + return True + + +def normalize_path(path, resolve_symlinks=True): + # type: (str, bool) -> str + """ + Convert a path to its canonical, case-normalized, absolute version. + + """ + path = expanduser(path) + if resolve_symlinks: + path = os.path.realpath(path) + else: + path = os.path.abspath(path) + return os.path.normcase(path) + + +def splitext(path): + # type: (str) -> Tuple[str, str] + """Like os.path.splitext, but take off .tar too""" + base, ext = posixpath.splitext(path) + if base.lower().endswith('.tar'): + ext = base[-4:] + ext + base = base[:-4] + return base, ext + + +def renames(old, new): + # type: (str, str) -> None + """Like os.renames(), but handles renaming across devices.""" + # Implementation borrowed from os.renames(). + head, tail = os.path.split(new) + if head and tail and not os.path.exists(head): + os.makedirs(head) + + shutil.move(old, new) + + head, tail = os.path.split(old) + if head and tail: + try: + os.removedirs(head) + except OSError: + pass + + +def is_local(path): + # type: (str) -> bool + """ + Return True if path is within sys.prefix, if we're running in a virtualenv. + + If we're not in a virtualenv, all paths are considered "local." + + """ + if not running_under_virtualenv(): + return True + return normalize_path(path).startswith(normalize_path(sys.prefix)) + + +def dist_is_local(dist): + # type: (Distribution) -> bool + """ + Return True if given Distribution object is installed locally + (i.e. within current virtualenv). + + Always True if we're not in a virtualenv. + + """ + return is_local(dist_location(dist)) + + +def dist_in_usersite(dist): + # type: (Distribution) -> bool + """ + Return True if given Distribution is installed in user site. + """ + norm_path = normalize_path(dist_location(dist)) + return norm_path.startswith(normalize_path(user_site)) + + +def dist_in_site_packages(dist): + # type: (Distribution) -> bool + """ + Return True if given Distribution is installed in + sysconfig.get_python_lib(). + """ + return normalize_path( + dist_location(dist) + ).startswith(normalize_path(site_packages)) + + +def dist_is_editable(dist): + # type: (Distribution) -> bool + """ + Return True if given Distribution is an editable install. + """ + for path_item in sys.path: + egg_link = os.path.join(path_item, dist.project_name + '.egg-link') + if os.path.isfile(egg_link): + return True + return False + + +def get_installed_distributions( + local_only=True, # type: bool + skip=stdlib_pkgs, # type: Container[str] + include_editables=True, # type: bool + editables_only=False, # type: bool + user_only=False, # type: bool + paths=None # type: Optional[List[str]] +): + # type: (...) -> List[Distribution] + """ + Return a list of installed Distribution objects. + + If ``local_only`` is True (default), only return installations + local to the current virtualenv, if in a virtualenv. + + ``skip`` argument is an iterable of lower-case project names to + ignore; defaults to stdlib_pkgs + + If ``include_editables`` is False, don't report editables. + + If ``editables_only`` is True , only report editables. + + If ``user_only`` is True , only report installations in the user + site directory. + + If ``paths`` is set, only report the distributions present at the + specified list of locations. + """ + if paths: + working_set = pkg_resources.WorkingSet(paths) + else: + working_set = pkg_resources.working_set + + if local_only: + local_test = dist_is_local + else: + def local_test(d): + return True + + if include_editables: + def editable_test(d): + return True + else: + def editable_test(d): + return not dist_is_editable(d) + + if editables_only: + def editables_only_test(d): + return dist_is_editable(d) + else: + def editables_only_test(d): + return True + + if user_only: + user_test = dist_in_usersite + else: + def user_test(d): + return True + + # because of pkg_resources vendoring, mypy cannot find stub in typeshed + return [d for d in working_set # type: ignore + if local_test(d) and + d.key not in skip and + editable_test(d) and + editables_only_test(d) and + user_test(d) + ] + + +def egg_link_path(dist): + # type: (Distribution) -> Optional[str] + """ + Return the path for the .egg-link file if it exists, otherwise, None. + + There's 3 scenarios: + 1) not in a virtualenv + try to find in site.USER_SITE, then site_packages + 2) in a no-global virtualenv + try to find in site_packages + 3) in a yes-global virtualenv + try to find in site_packages, then site.USER_SITE + (don't look in global location) + + For #1 and #3, there could be odd cases, where there's an egg-link in 2 + locations. + + This method will just return the first one found. + """ + sites = [] + if running_under_virtualenv(): + if virtualenv_no_global(): + sites.append(site_packages) + else: + sites.append(site_packages) + if user_site: + sites.append(user_site) + else: + if user_site: + sites.append(user_site) + sites.append(site_packages) + + for site in sites: + egglink = os.path.join(site, dist.project_name) + '.egg-link' + if os.path.isfile(egglink): + return egglink + return None + + +def dist_location(dist): + # type: (Distribution) -> str + """ + Get the site-packages location of this distribution. Generally + this is dist.location, except in the case of develop-installed + packages, where dist.location is the source code location, and we + want to know where the egg-link file is. + + """ + egg_link = egg_link_path(dist) + if egg_link: + return egg_link + return dist.location + + +def current_umask(): + """Get the current umask which involves having to set it temporarily.""" + mask = os.umask(0) + os.umask(mask) + return mask + + +def unzip_file(filename, location, flatten=True): + # type: (str, str, bool) -> None + """ + Unzip the file (with path `filename`) to the destination `location`. All + files are written based on system defaults and umask (i.e. permissions are + not preserved), except that regular file members with any execute + permissions (user, group, or world) have "chmod +x" applied after being + written. Note that for windows, any execute changes using os.chmod are + no-ops per the python docs. + """ + ensure_dir(location) + zipfp = open(filename, 'rb') + try: + zip = zipfile.ZipFile(zipfp, allowZip64=True) + leading = has_leading_dir(zip.namelist()) and flatten + for info in zip.infolist(): + name = info.filename + fn = name + if leading: + fn = split_leading_dir(name)[1] + fn = os.path.join(location, fn) + dir = os.path.dirname(fn) + if fn.endswith('/') or fn.endswith('\\'): + # A directory + ensure_dir(fn) + else: + ensure_dir(dir) + # Don't use read() to avoid allocating an arbitrarily large + # chunk of memory for the file's content + fp = zip.open(name) + try: + with open(fn, 'wb') as destfp: + shutil.copyfileobj(fp, destfp) + finally: + fp.close() + mode = info.external_attr >> 16 + # if mode and regular file and any execute permissions for + # user/group/world? + if mode and stat.S_ISREG(mode) and mode & 0o111: + # make dest file have execute for user/group/world + # (chmod +x) no-op on windows per python docs + os.chmod(fn, (0o777 - current_umask() | 0o111)) + finally: + zipfp.close() + + +def untar_file(filename, location): + # type: (str, str) -> None + """ + Untar the file (with path `filename`) to the destination `location`. + All files are written based on system defaults and umask (i.e. permissions + are not preserved), except that regular file members with any execute + permissions (user, group, or world) have "chmod +x" applied after being + written. Note that for windows, any execute changes using os.chmod are + no-ops per the python docs. + """ + ensure_dir(location) + if filename.lower().endswith('.gz') or filename.lower().endswith('.tgz'): + mode = 'r:gz' + elif filename.lower().endswith(BZ2_EXTENSIONS): + mode = 'r:bz2' + elif filename.lower().endswith(XZ_EXTENSIONS): + mode = 'r:xz' + elif filename.lower().endswith('.tar'): + mode = 'r' + else: + logger.warning( + 'Cannot determine compression type for file %s', filename, + ) + mode = 'r:*' + tar = tarfile.open(filename, mode) + try: + leading = has_leading_dir([ + member.name for member in tar.getmembers() + ]) + for member in tar.getmembers(): + fn = member.name + if leading: + # https://github.com/python/mypy/issues/1174 + fn = split_leading_dir(fn)[1] # type: ignore + path = os.path.join(location, fn) + if member.isdir(): + ensure_dir(path) + elif member.issym(): + try: + # https://github.com/python/typeshed/issues/2673 + tar._extract_member(member, path) # type: ignore + except Exception as exc: + # Some corrupt tar files seem to produce this + # (specifically bad symlinks) + logger.warning( + 'In the tar file %s the member %s is invalid: %s', + filename, member.name, exc, + ) + continue + else: + try: + fp = tar.extractfile(member) + except (KeyError, AttributeError) as exc: + # Some corrupt tar files seem to produce this + # (specifically bad symlinks) + logger.warning( + 'In the tar file %s the member %s is invalid: %s', + filename, member.name, exc, + ) + continue + ensure_dir(os.path.dirname(path)) + with open(path, 'wb') as destfp: + shutil.copyfileobj(fp, destfp) + fp.close() + # Update the timestamp (useful for cython compiled files) + # https://github.com/python/typeshed/issues/2673 + tar.utime(member, path) # type: ignore + # member have any execute permissions for user/group/world? + if member.mode & 0o111: + # make dest file have execute for user/group/world + # no-op on windows per python docs + os.chmod(path, (0o777 - current_umask() | 0o111)) + finally: + tar.close() + + +def unpack_file( + filename, # type: str + location, # type: str + content_type, # type: Optional[str] + link # type: Optional[Link] +): + # type: (...) -> None + filename = os.path.realpath(filename) + if (content_type == 'application/zip' or + filename.lower().endswith(ZIP_EXTENSIONS) or + zipfile.is_zipfile(filename)): + unzip_file( + filename, + location, + flatten=not filename.endswith('.whl') + ) + elif (content_type == 'application/x-gzip' or + tarfile.is_tarfile(filename) or + filename.lower().endswith( + TAR_EXTENSIONS + BZ2_EXTENSIONS + XZ_EXTENSIONS)): + untar_file(filename, location) + elif (content_type and content_type.startswith('text/html') and + is_svn_page(file_contents(filename))): + # We don't really care about this + from pip._internal.vcs.subversion import Subversion + url = 'svn+' + link.url + Subversion().unpack(location, url=url) + else: + # FIXME: handle? + # FIXME: magic signatures? + logger.critical( + 'Cannot unpack file %s (downloaded from %s, content-type: %s); ' + 'cannot detect archive format', + filename, location, content_type, + ) + raise InstallationError( + 'Cannot determine archive format of %s' % location + ) + + +def format_command_args(args): + # type: (List[str]) -> str + """ + Format command arguments for display. + """ + return ' '.join(shlex_quote(arg) for arg in args) + + +def make_subprocess_output_error( + cmd_args, # type: List[str] + cwd, # type: Optional[str] + lines, # type: List[Text] + exit_status, # type: int +): + # type: (...) -> Text + """ + Create and return the error message to use to log a subprocess error + with command output. + + :param lines: A list of lines, each ending with a newline. + """ + command = format_command_args(cmd_args) + # Convert `command` and `cwd` to text (unicode in Python 2) so we can use + # them as arguments in the unicode format string below. This avoids + # "UnicodeDecodeError: 'ascii' codec can't decode byte ..." in Python 2 + # if either contains a non-ascii character. + command_display = str_to_display(command, desc='command bytes') + cwd_display = path_to_display(cwd) + + # We know the joined output value ends in a newline. + output = ''.join(lines) + msg = ( + # Use a unicode string to avoid "UnicodeEncodeError: 'ascii' + # codec can't encode character ..." in Python 2 when a format + # argument (e.g. `output`) has a non-ascii character. + u'Command errored out with exit status {exit_status}:\n' + ' command: {command_display}\n' + ' cwd: {cwd_display}\n' + 'Complete output ({line_count} lines):\n{output}{divider}' + ).format( + exit_status=exit_status, + command_display=command_display, + cwd_display=cwd_display, + line_count=len(lines), + output=output, + divider=LOG_DIVIDER, + ) + return msg + + +def call_subprocess( + cmd, # type: List[str] + show_stdout=False, # type: bool + cwd=None, # type: Optional[str] + on_returncode='raise', # type: str + extra_ok_returncodes=None, # type: Optional[Iterable[int]] + command_desc=None, # type: Optional[str] + extra_environ=None, # type: Optional[Mapping[str, Any]] + unset_environ=None, # type: Optional[Iterable[str]] + spinner=None # type: Optional[SpinnerInterface] +): + # type: (...) -> Text + """ + Args: + show_stdout: if true, use INFO to log the subprocess's stderr and + stdout streams. Otherwise, use DEBUG. Defaults to False. + extra_ok_returncodes: an iterable of integer return codes that are + acceptable, in addition to 0. Defaults to None, which means []. + unset_environ: an iterable of environment variable names to unset + prior to calling subprocess.Popen(). + """ + if extra_ok_returncodes is None: + extra_ok_returncodes = [] + if unset_environ is None: + unset_environ = [] + # Most places in pip use show_stdout=False. What this means is-- + # + # - We connect the child's output (combined stderr and stdout) to a + # single pipe, which we read. + # - We log this output to stderr at DEBUG level as it is received. + # - If DEBUG logging isn't enabled (e.g. if --verbose logging wasn't + # requested), then we show a spinner so the user can still see the + # subprocess is in progress. + # - If the subprocess exits with an error, we log the output to stderr + # at ERROR level if it hasn't already been displayed to the console + # (e.g. if --verbose logging wasn't enabled). This way we don't log + # the output to the console twice. + # + # If show_stdout=True, then the above is still done, but with DEBUG + # replaced by INFO. + if show_stdout: + # Then log the subprocess output at INFO level. + log_subprocess = subprocess_logger.info + used_level = std_logging.INFO + else: + # Then log the subprocess output using DEBUG. This also ensures + # it will be logged to the log file (aka user_log), if enabled. + log_subprocess = subprocess_logger.debug + used_level = std_logging.DEBUG + + # Whether the subprocess will be visible in the console. + showing_subprocess = subprocess_logger.getEffectiveLevel() <= used_level + + # Only use the spinner if we're not showing the subprocess output + # and we have a spinner. + use_spinner = not showing_subprocess and spinner is not None + + if command_desc is None: + command_desc = format_command_args(cmd) + + log_subprocess("Running command %s", command_desc) + env = os.environ.copy() + if extra_environ: + env.update(extra_environ) + for name in unset_environ: + env.pop(name, None) + try: + proc = subprocess.Popen( + cmd, stderr=subprocess.STDOUT, stdin=subprocess.PIPE, + stdout=subprocess.PIPE, cwd=cwd, env=env, + ) + proc.stdin.close() + except Exception as exc: + subprocess_logger.critical( + "Error %s while executing command %s", exc, command_desc, + ) + raise + all_output = [] + while True: + # The "line" value is a unicode string in Python 2. + line = console_to_str(proc.stdout.readline()) + if not line: + break + line = line.rstrip() + all_output.append(line + '\n') + + # Show the line immediately. + log_subprocess(line) + # Update the spinner. + if use_spinner: + spinner.spin() + try: + proc.wait() + finally: + if proc.stdout: + proc.stdout.close() + proc_had_error = ( + proc.returncode and proc.returncode not in extra_ok_returncodes + ) + if use_spinner: + if proc_had_error: + spinner.finish("error") + else: + spinner.finish("done") + if proc_had_error: + if on_returncode == 'raise': + if not showing_subprocess: + # Then the subprocess streams haven't been logged to the + # console yet. + msg = make_subprocess_output_error( + cmd_args=cmd, + cwd=cwd, + lines=all_output, + exit_status=proc.returncode, + ) + subprocess_logger.error(msg) + exc_msg = ( + 'Command errored out with exit status {}: {} ' + 'Check the logs for full command output.' + ).format(proc.returncode, command_desc) + raise InstallationError(exc_msg) + elif on_returncode == 'warn': + subprocess_logger.warning( + 'Command "%s" had error code %s in %s', + command_desc, proc.returncode, cwd, + ) + elif on_returncode == 'ignore': + pass + else: + raise ValueError('Invalid value: on_returncode=%s' % + repr(on_returncode)) + return ''.join(all_output) + + +def _make_build_dir(build_dir): + os.makedirs(build_dir) + write_delete_marker_file(build_dir) + + +class FakeFile(object): + """Wrap a list of lines in an object with readline() to make + ConfigParser happy.""" + def __init__(self, lines): + self._gen = (l for l in lines) + + def readline(self): + try: + try: + return next(self._gen) + except NameError: + return self._gen.next() + except StopIteration: + return '' + + def __iter__(self): + return self._gen + + +class StreamWrapper(StringIO): + + @classmethod + def from_stream(cls, orig_stream): + cls.orig_stream = orig_stream + return cls() + + # compileall.compile_dir() needs stdout.encoding to print to stdout + @property + def encoding(self): + return self.orig_stream.encoding + + +@contextlib.contextmanager +def captured_output(stream_name): + """Return a context manager used by captured_stdout/stdin/stderr + that temporarily replaces the sys stream *stream_name* with a StringIO. + + Taken from Lib/support/__init__.py in the CPython repo. + """ + orig_stdout = getattr(sys, stream_name) + setattr(sys, stream_name, StreamWrapper.from_stream(orig_stdout)) + try: + yield getattr(sys, stream_name) + finally: + setattr(sys, stream_name, orig_stdout) + + +def captured_stdout(): + """Capture the output of sys.stdout: + + with captured_stdout() as stdout: + print('hello') + self.assertEqual(stdout.getvalue(), 'hello\n') + + Taken from Lib/support/__init__.py in the CPython repo. + """ + return captured_output('stdout') + + +def captured_stderr(): + """ + See captured_stdout(). + """ + return captured_output('stderr') + + +class cached_property(object): + """A property that is only computed once per instance and then replaces + itself with an ordinary attribute. Deleting the attribute resets the + property. + + Source: https://github.com/bottlepy/bottle/blob/0.11.5/bottle.py#L175 + """ + + def __init__(self, func): + self.__doc__ = getattr(func, '__doc__') + self.func = func + + def __get__(self, obj, cls): + if obj is None: + # We're being accessed from the class itself, not from an object + return self + value = obj.__dict__[self.func.__name__] = self.func(obj) + return value + + +def get_installed_version(dist_name, working_set=None): + """Get the installed version of dist_name avoiding pkg_resources cache""" + # Create a requirement that we'll look for inside of setuptools. + req = pkg_resources.Requirement.parse(dist_name) + + if working_set is None: + # We want to avoid having this cached, so we need to construct a new + # working set each time. + working_set = pkg_resources.WorkingSet() + + # Get the installed distribution from our working set + dist = working_set.find(req) + + # Check to see if we got an installed distribution or not, if we did + # we want to return it's version. + return dist.version if dist else None + + +def consume(iterator): + """Consume an iterable at C speed.""" + deque(iterator, maxlen=0) + + +# Simulates an enum +def enum(*sequential, **named): + enums = dict(zip(sequential, range(len(sequential))), **named) + reverse = {value: key for key, value in enums.items()} + enums['reverse_mapping'] = reverse + return type('Enum', (), enums) + + +def path_to_url(path): + # type: (Union[str, Text]) -> str + """ + Convert a path to a file: URL. The path will be made absolute and have + quoted path parts. + """ + path = os.path.normpath(os.path.abspath(path)) + url = urllib_parse.urljoin('file:', urllib_request.pathname2url(path)) + return url + + +def split_auth_from_netloc(netloc): + """ + Parse out and remove the auth information from a netloc. + + Returns: (netloc, (username, password)). + """ + if '@' not in netloc: + return netloc, (None, None) + + # Split from the right because that's how urllib.parse.urlsplit() + # behaves if more than one @ is present (which can be checked using + # the password attribute of urlsplit()'s return value). + auth, netloc = netloc.rsplit('@', 1) + if ':' in auth: + # Split from the left because that's how urllib.parse.urlsplit() + # behaves if more than one : is present (which again can be checked + # using the password attribute of the return value) + user_pass = auth.split(':', 1) + else: + user_pass = auth, None + + user_pass = tuple( + None if x is None else urllib_unquote(x) for x in user_pass + ) + + return netloc, user_pass + + +def redact_netloc(netloc): + # type: (str) -> str + """ + Replace the password in a netloc with "****", if it exists. + + For example, "user:pass@example.com" returns "user:****@example.com". + """ + netloc, (user, password) = split_auth_from_netloc(netloc) + if user is None: + return netloc + password = '' if password is None else ':****' + return '{user}{password}@{netloc}'.format(user=urllib_parse.quote(user), + password=password, + netloc=netloc) + + +def _transform_url(url, transform_netloc): + """Transform and replace netloc in a url. + + transform_netloc is a function taking the netloc and returning a + tuple. The first element of this tuple is the new netloc. The + entire tuple is returned. + + Returns a tuple containing the transformed url as item 0 and the + original tuple returned by transform_netloc as item 1. + """ + purl = urllib_parse.urlsplit(url) + netloc_tuple = transform_netloc(purl.netloc) + # stripped url + url_pieces = ( + purl.scheme, netloc_tuple[0], purl.path, purl.query, purl.fragment + ) + surl = urllib_parse.urlunsplit(url_pieces) + return surl, netloc_tuple + + +def _get_netloc(netloc): + return split_auth_from_netloc(netloc) + + +def _redact_netloc(netloc): + return (redact_netloc(netloc),) + + +def split_auth_netloc_from_url(url): + # type: (str) -> Tuple[str, str, Tuple[str, str]] + """ + Parse a url into separate netloc, auth, and url with no auth. + + Returns: (url_without_auth, netloc, (username, password)) + """ + url_without_auth, (netloc, auth) = _transform_url(url, _get_netloc) + return url_without_auth, netloc, auth + + +def remove_auth_from_url(url): + # type: (str) -> str + """Return a copy of url with 'username:password@' removed.""" + # username/pass params are passed to subversion through flags + # and are not recognized in the url. + return _transform_url(url, _get_netloc)[0] + + +def redact_password_from_url(url): + # type: (str) -> str + """Replace the password in a given url with ****.""" + return _transform_url(url, _redact_netloc)[0] + + +def protect_pip_from_modification_on_windows(modifying_pip): + """Protection of pip.exe from modification on Windows + + On Windows, any operation modifying pip should be run as: + python -m pip ... + """ + pip_names = [ + "pip.exe", + "pip{}.exe".format(sys.version_info[0]), + "pip{}.{}.exe".format(*sys.version_info[:2]) + ] + + # See https://github.com/pypa/pip/issues/1299 for more discussion + should_show_use_python_msg = ( + modifying_pip and + WINDOWS and + os.path.basename(sys.argv[0]) in pip_names + ) + + if should_show_use_python_msg: + new_command = [ + sys.executable, "-m", "pip" + ] + sys.argv[1:] + raise CommandError( + 'To modify pip, please run the following command:\n{}' + .format(" ".join(new_command)) + ) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/models.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/models.py new file mode 100644 index 0000000..fccaf5d --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/models.py @@ -0,0 +1,40 @@ +"""Utilities for defining models +""" + +import operator + + +class KeyBasedCompareMixin(object): + """Provides comparison capabilities that is based on a key + """ + + def __init__(self, key, defining_class): + self._compare_key = key + self._defining_class = defining_class + + def __hash__(self): + return hash(self._compare_key) + + def __lt__(self, other): + return self._compare(other, operator.__lt__) + + def __le__(self, other): + return self._compare(other, operator.__le__) + + def __gt__(self, other): + return self._compare(other, operator.__gt__) + + def __ge__(self, other): + return self._compare(other, operator.__ge__) + + def __eq__(self, other): + return self._compare(other, operator.__eq__) + + def __ne__(self, other): + return self._compare(other, operator.__ne__) + + def _compare(self, other, method): + if not isinstance(other, self._defining_class): + return NotImplemented + + return method(self._compare_key, other._compare_key) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/outdated.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/outdated.py new file mode 100644 index 0000000..2b10aef --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/outdated.py @@ -0,0 +1,178 @@ +from __future__ import absolute_import + +import datetime +import json +import logging +import os.path +import sys + +from pip._vendor import lockfile, pkg_resources +from pip._vendor.packaging import version as packaging_version + +from pip._internal.cli.cmdoptions import make_search_scope +from pip._internal.index import PackageFinder +from pip._internal.models.selection_prefs import SelectionPreferences +from pip._internal.utils.compat import WINDOWS +from pip._internal.utils.filesystem import check_path_owner +from pip._internal.utils.misc import ensure_dir, get_installed_version +from pip._internal.utils.packaging import get_installer +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + import optparse + from typing import Any, Dict + from pip._internal.download import PipSession + + +SELFCHECK_DATE_FMT = "%Y-%m-%dT%H:%M:%SZ" + + +logger = logging.getLogger(__name__) + + +class SelfCheckState(object): + def __init__(self, cache_dir): + # type: (str) -> None + self.state = {} # type: Dict[str, Any] + self.statefile_path = None + + # Try to load the existing state + if cache_dir: + self.statefile_path = os.path.join(cache_dir, "selfcheck.json") + try: + with open(self.statefile_path) as statefile: + self.state = json.load(statefile)[sys.prefix] + except (IOError, ValueError, KeyError): + # Explicitly suppressing exceptions, since we don't want to + # error out if the cache file is invalid. + pass + + def save(self, pypi_version, current_time): + # type: (str, datetime.datetime) -> None + # If we do not have a path to cache in, don't bother saving. + if not self.statefile_path: + return + + # Check to make sure that we own the directory + if not check_path_owner(os.path.dirname(self.statefile_path)): + return + + # Now that we've ensured the directory is owned by this user, we'll go + # ahead and make sure that all our directories are created. + ensure_dir(os.path.dirname(self.statefile_path)) + + # Attempt to write out our version check file + with lockfile.LockFile(self.statefile_path): + if os.path.exists(self.statefile_path): + with open(self.statefile_path) as statefile: + state = json.load(statefile) + else: + state = {} + + state[sys.prefix] = { + "last_check": current_time.strftime(SELFCHECK_DATE_FMT), + "pypi_version": pypi_version, + } + + with open(self.statefile_path, "w") as statefile: + json.dump(state, statefile, sort_keys=True, + separators=(",", ":")) + + +def was_installed_by_pip(pkg): + # type: (str) -> bool + """Checks whether pkg was installed by pip + + This is used not to display the upgrade message when pip is in fact + installed by system package manager, such as dnf on Fedora. + """ + try: + dist = pkg_resources.get_distribution(pkg) + return "pip" == get_installer(dist) + except pkg_resources.DistributionNotFound: + return False + + +def pip_version_check(session, options): + # type: (PipSession, optparse.Values) -> None + """Check for an update for pip. + + Limit the frequency of checks to once per week. State is stored either in + the active virtualenv or in the user's USER_CACHE_DIR keyed off the prefix + of the pip script path. + """ + installed_version = get_installed_version("pip") + if not installed_version: + return + + pip_version = packaging_version.parse(installed_version) + pypi_version = None + + try: + state = SelfCheckState(cache_dir=options.cache_dir) + + current_time = datetime.datetime.utcnow() + # Determine if we need to refresh the state + if "last_check" in state.state and "pypi_version" in state.state: + last_check = datetime.datetime.strptime( + state.state["last_check"], + SELFCHECK_DATE_FMT + ) + if (current_time - last_check).total_seconds() < 7 * 24 * 60 * 60: + pypi_version = state.state["pypi_version"] + + # Refresh the version if we need to or just see if we need to warn + if pypi_version is None: + # Lets use PackageFinder to see what the latest pip version is + search_scope = make_search_scope(options, suppress_no_index=True) + + # Pass allow_yanked=False so we don't suggest upgrading to a + # yanked version. + selection_prefs = SelectionPreferences( + allow_yanked=False, + allow_all_prereleases=False, # Explicitly set to False + ) + + finder = PackageFinder.create( + search_scope=search_scope, + selection_prefs=selection_prefs, + trusted_hosts=options.trusted_hosts, + session=session, + ) + candidate = finder.find_candidates("pip").get_best() + if candidate is None: + return + pypi_version = str(candidate.version) + + # save that we've performed a check + state.save(pypi_version, current_time) + + remote_version = packaging_version.parse(pypi_version) + + local_version_is_older = ( + pip_version < remote_version and + pip_version.base_version != remote_version.base_version and + was_installed_by_pip('pip') + ) + + # Determine if our pypi_version is older + if not local_version_is_older: + return + + # Advise "python -m pip" on Windows to avoid issues + # with overwriting pip.exe. + if WINDOWS: + pip_cmd = "python -m pip" + else: + pip_cmd = "pip" + logger.warning( + "You are using pip version %s, however version %s is " + "available.\nYou should consider upgrading via the " + "'%s install --upgrade pip' command.", + pip_version, pypi_version, pip_cmd + ) + except Exception: + logger.debug( + "There was an error checking the latest version of pip", + exc_info=True, + ) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/packaging.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/packaging.py new file mode 100644 index 0000000..68aa86e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/packaging.py @@ -0,0 +1,94 @@ +from __future__ import absolute_import + +import logging +from email.parser import FeedParser + +from pip._vendor import pkg_resources +from pip._vendor.packaging import specifiers, version + +from pip._internal.exceptions import NoneMetadataError +from pip._internal.utils.misc import display_path +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional, Tuple + from email.message import Message + from pip._vendor.pkg_resources import Distribution + + +logger = logging.getLogger(__name__) + + +def check_requires_python(requires_python, version_info): + # type: (Optional[str], Tuple[int, ...]) -> bool + """ + Check if the given Python version matches a "Requires-Python" specifier. + + :param version_info: A 3-tuple of ints representing a Python + major-minor-micro version to check (e.g. `sys.version_info[:3]`). + + :return: `True` if the given Python version satisfies the requirement. + Otherwise, return `False`. + + :raises InvalidSpecifier: If `requires_python` has an invalid format. + """ + if requires_python is None: + # The package provides no information + return True + requires_python_specifier = specifiers.SpecifierSet(requires_python) + + python_version = version.parse('.'.join(map(str, version_info))) + return python_version in requires_python_specifier + + +def get_metadata(dist): + # type: (Distribution) -> Message + """ + :raises NoneMetadataError: if the distribution reports `has_metadata()` + True but `get_metadata()` returns None. + """ + metadata_name = 'METADATA' + if (isinstance(dist, pkg_resources.DistInfoDistribution) and + dist.has_metadata(metadata_name)): + metadata = dist.get_metadata(metadata_name) + elif dist.has_metadata('PKG-INFO'): + metadata_name = 'PKG-INFO' + metadata = dist.get_metadata(metadata_name) + else: + logger.warning("No metadata found in %s", display_path(dist.location)) + metadata = '' + + if metadata is None: + raise NoneMetadataError(dist, metadata_name) + + feed_parser = FeedParser() + # The following line errors out if with a "NoneType" TypeError if + # passed metadata=None. + feed_parser.feed(metadata) + return feed_parser.close() + + +def get_requires_python(dist): + # type: (pkg_resources.Distribution) -> Optional[str] + """ + Return the "Requires-Python" metadata for a distribution, or None + if not present. + """ + pkg_info_dict = get_metadata(dist) + requires_python = pkg_info_dict.get('Requires-Python') + + if requires_python is not None: + # Convert to a str to satisfy the type checker, since requires_python + # can be a Header object. + requires_python = str(requires_python) + + return requires_python + + +def get_installer(dist): + # type: (Distribution) -> str + if dist.has_metadata('INSTALLER'): + for line in dist.get_metadata_lines('INSTALLER'): + if line.strip(): + return line.strip() + return '' diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/setuptools_build.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/setuptools_build.py new file mode 100644 index 0000000..5895607 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/setuptools_build.py @@ -0,0 +1,36 @@ +import sys + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List + +# Shim to wrap setup.py invocation with setuptools +# +# We set sys.argv[0] to the path to the underlying setup.py file so +# setuptools / distutils don't take the path to the setup.py to be "-c" when +# invoking via the shim. This avoids e.g. the following manifest_maker +# warning: "warning: manifest_maker: standard file '-c' not found". +_SETUPTOOLS_SHIM = ( + "import sys, setuptools, tokenize; sys.argv[0] = {0!r}; __file__={0!r};" + "f=getattr(tokenize, 'open', open)(__file__);" + "code=f.read().replace('\\r\\n', '\\n');" + "f.close();" + "exec(compile(code, __file__, 'exec'))" +) + + +def make_setuptools_shim_args(setup_py_path, unbuffered_output=False): + # type: (str, bool) -> List[str] + """ + Get setuptools command arguments with shim wrapped setup file invocation. + + :param setup_py_path: The path to setup.py to be wrapped. + :param unbuffered_output: If True, adds the unbuffered switch to the + argument list. + """ + args = [sys.executable] + if unbuffered_output: + args.append('-u') + args.extend(['-c', _SETUPTOOLS_SHIM.format(setup_py_path)]) + return args diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/temp_dir.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/temp_dir.py new file mode 100644 index 0000000..2c81ad5 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/temp_dir.py @@ -0,0 +1,155 @@ +from __future__ import absolute_import + +import errno +import itertools +import logging +import os.path +import tempfile + +from pip._internal.utils.misc import rmtree + +logger = logging.getLogger(__name__) + + +class TempDirectory(object): + """Helper class that owns and cleans up a temporary directory. + + This class can be used as a context manager or as an OO representation of a + temporary directory. + + Attributes: + path + Location to the created temporary directory or None + delete + Whether the directory should be deleted when exiting + (when used as a contextmanager) + + Methods: + create() + Creates a temporary directory and stores its path in the path + attribute. + cleanup() + Deletes the temporary directory and sets path attribute to None + + When used as a context manager, a temporary directory is created on + entering the context and, if the delete attribute is True, on exiting the + context the created directory is deleted. + """ + + def __init__(self, path=None, delete=None, kind="temp"): + super(TempDirectory, self).__init__() + + if path is None and delete is None: + # If we were not given an explicit directory, and we were not given + # an explicit delete option, then we'll default to deleting. + delete = True + + self.path = path + self.delete = delete + self.kind = kind + + def __repr__(self): + return "<{} {!r}>".format(self.__class__.__name__, self.path) + + def __enter__(self): + self.create() + return self + + def __exit__(self, exc, value, tb): + if self.delete: + self.cleanup() + + def create(self): + """Create a temporary directory and store its path in self.path + """ + if self.path is not None: + logger.debug( + "Skipped creation of temporary directory: {}".format(self.path) + ) + return + # We realpath here because some systems have their default tmpdir + # symlinked to another directory. This tends to confuse build + # scripts, so we canonicalize the path by traversing potential + # symlinks here. + self.path = os.path.realpath( + tempfile.mkdtemp(prefix="pip-{}-".format(self.kind)) + ) + logger.debug("Created temporary directory: {}".format(self.path)) + + def cleanup(self): + """Remove the temporary directory created and reset state + """ + if self.path is not None and os.path.exists(self.path): + rmtree(self.path) + self.path = None + + +class AdjacentTempDirectory(TempDirectory): + """Helper class that creates a temporary directory adjacent to a real one. + + Attributes: + original + The original directory to create a temp directory for. + path + After calling create() or entering, contains the full + path to the temporary directory. + delete + Whether the directory should be deleted when exiting + (when used as a contextmanager) + + """ + # The characters that may be used to name the temp directory + # We always prepend a ~ and then rotate through these until + # a usable name is found. + # pkg_resources raises a different error for .dist-info folder + # with leading '-' and invalid metadata + LEADING_CHARS = "-~.=%0123456789" + + def __init__(self, original, delete=None): + super(AdjacentTempDirectory, self).__init__(delete=delete) + self.original = original.rstrip('/\\') + + @classmethod + def _generate_names(cls, name): + """Generates a series of temporary names. + + The algorithm replaces the leading characters in the name + with ones that are valid filesystem characters, but are not + valid package names (for both Python and pip definitions of + package). + """ + for i in range(1, len(name)): + for candidate in itertools.combinations_with_replacement( + cls.LEADING_CHARS, i - 1): + new_name = '~' + ''.join(candidate) + name[i:] + if new_name != name: + yield new_name + + # If we make it this far, we will have to make a longer name + for i in range(len(cls.LEADING_CHARS)): + for candidate in itertools.combinations_with_replacement( + cls.LEADING_CHARS, i): + new_name = '~' + ''.join(candidate) + name + if new_name != name: + yield new_name + + def create(self): + root, name = os.path.split(self.original) + for candidate in self._generate_names(name): + path = os.path.join(root, candidate) + try: + os.mkdir(path) + except OSError as ex: + # Continue if the name exists already + if ex.errno != errno.EEXIST: + raise + else: + self.path = os.path.realpath(path) + break + + if not self.path: + # Final fallback on the default behavior. + self.path = os.path.realpath( + tempfile.mkdtemp(prefix="pip-{}-".format(self.kind)) + ) + logger.debug("Created temporary directory: {}".format(self.path)) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/typing.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/typing.py new file mode 100644 index 0000000..10170ce --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/typing.py @@ -0,0 +1,29 @@ +"""For neatly implementing static typing in pip. + +`mypy` - the static type analysis tool we use - uses the `typing` module, which +provides core functionality fundamental to mypy's functioning. + +Generally, `typing` would be imported at runtime and used in that fashion - +it acts as a no-op at runtime and does not have any run-time overhead by +design. + +As it turns out, `typing` is not vendorable - it uses separate sources for +Python 2/Python 3. Thus, this codebase can not expect it to be present. +To work around this, mypy allows the typing import to be behind a False-y +optional to prevent it from running at runtime and type-comments can be used +to remove the need for the types to be accessible directly during runtime. + +This module provides the False-y guard in a nicely named fashion so that a +curious maintainer can reach here to read this. + +In pip, all static-typing related imports should be guarded as follows: + + from pip._internal.utils.typing import MYPY_CHECK_RUNNING + + if MYPY_CHECK_RUNNING: + from typing import ... + +Ref: https://github.com/python/mypy/issues/3216 +""" + +MYPY_CHECK_RUNNING = False diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/ui.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/ui.py new file mode 100644 index 0000000..46390f4 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/ui.py @@ -0,0 +1,424 @@ +from __future__ import absolute_import, division + +import contextlib +import itertools +import logging +import sys +import time +from signal import SIGINT, default_int_handler, signal + +from pip._vendor import six +from pip._vendor.progress import HIDE_CURSOR, SHOW_CURSOR +from pip._vendor.progress.bar import Bar, FillingCirclesBar, IncrementalBar +from pip._vendor.progress.spinner import Spinner + +from pip._internal.utils.compat import WINDOWS +from pip._internal.utils.logging import get_indentation +from pip._internal.utils.misc import format_size +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Any, Iterator, IO + +try: + from pip._vendor import colorama +# Lots of different errors can come from this, including SystemError and +# ImportError. +except Exception: + colorama = None + +logger = logging.getLogger(__name__) + + +def _select_progress_class(preferred, fallback): + encoding = getattr(preferred.file, "encoding", None) + + # If we don't know what encoding this file is in, then we'll just assume + # that it doesn't support unicode and use the ASCII bar. + if not encoding: + return fallback + + # Collect all of the possible characters we want to use with the preferred + # bar. + characters = [ + getattr(preferred, "empty_fill", six.text_type()), + getattr(preferred, "fill", six.text_type()), + ] + characters += list(getattr(preferred, "phases", [])) + + # Try to decode the characters we're using for the bar using the encoding + # of the given file, if this works then we'll assume that we can use the + # fancier bar and if not we'll fall back to the plaintext bar. + try: + six.text_type().join(characters).encode(encoding) + except UnicodeEncodeError: + return fallback + else: + return preferred + + +_BaseBar = _select_progress_class(IncrementalBar, Bar) # type: Any + + +class InterruptibleMixin(object): + """ + Helper to ensure that self.finish() gets called on keyboard interrupt. + + This allows downloads to be interrupted without leaving temporary state + (like hidden cursors) behind. + + This class is similar to the progress library's existing SigIntMixin + helper, but as of version 1.2, that helper has the following problems: + + 1. It calls sys.exit(). + 2. It discards the existing SIGINT handler completely. + 3. It leaves its own handler in place even after an uninterrupted finish, + which will have unexpected delayed effects if the user triggers an + unrelated keyboard interrupt some time after a progress-displaying + download has already completed, for example. + """ + + def __init__(self, *args, **kwargs): + """ + Save the original SIGINT handler for later. + """ + super(InterruptibleMixin, self).__init__(*args, **kwargs) + + self.original_handler = signal(SIGINT, self.handle_sigint) + + # If signal() returns None, the previous handler was not installed from + # Python, and we cannot restore it. This probably should not happen, + # but if it does, we must restore something sensible instead, at least. + # The least bad option should be Python's default SIGINT handler, which + # just raises KeyboardInterrupt. + if self.original_handler is None: + self.original_handler = default_int_handler + + def finish(self): + """ + Restore the original SIGINT handler after finishing. + + This should happen regardless of whether the progress display finishes + normally, or gets interrupted. + """ + super(InterruptibleMixin, self).finish() + signal(SIGINT, self.original_handler) + + def handle_sigint(self, signum, frame): + """ + Call self.finish() before delegating to the original SIGINT handler. + + This handler should only be in place while the progress display is + active. + """ + self.finish() + self.original_handler(signum, frame) + + +class SilentBar(Bar): + + def update(self): + pass + + +class BlueEmojiBar(IncrementalBar): + + suffix = "%(percent)d%%" + bar_prefix = " " + bar_suffix = " " + phases = (u"\U0001F539", u"\U0001F537", u"\U0001F535") # type: Any + + +class DownloadProgressMixin(object): + + def __init__(self, *args, **kwargs): + super(DownloadProgressMixin, self).__init__(*args, **kwargs) + self.message = (" " * (get_indentation() + 2)) + self.message + + @property + def downloaded(self): + return format_size(self.index) + + @property + def download_speed(self): + # Avoid zero division errors... + if self.avg == 0.0: + return "..." + return format_size(1 / self.avg) + "/s" + + @property + def pretty_eta(self): + if self.eta: + return "eta %s" % self.eta_td + return "" + + def iter(self, it, n=1): + for x in it: + yield x + self.next(n) + self.finish() + + +class WindowsMixin(object): + + def __init__(self, *args, **kwargs): + # The Windows terminal does not support the hide/show cursor ANSI codes + # even with colorama. So we'll ensure that hide_cursor is False on + # Windows. + # This call needs to go before the super() call, so that hide_cursor + # is set in time. The base progress bar class writes the "hide cursor" + # code to the terminal in its init, so if we don't set this soon + # enough, we get a "hide" with no corresponding "show"... + if WINDOWS and self.hide_cursor: + self.hide_cursor = False + + super(WindowsMixin, self).__init__(*args, **kwargs) + + # Check if we are running on Windows and we have the colorama module, + # if we do then wrap our file with it. + if WINDOWS and colorama: + self.file = colorama.AnsiToWin32(self.file) + # The progress code expects to be able to call self.file.isatty() + # but the colorama.AnsiToWin32() object doesn't have that, so we'll + # add it. + self.file.isatty = lambda: self.file.wrapped.isatty() + # The progress code expects to be able to call self.file.flush() + # but the colorama.AnsiToWin32() object doesn't have that, so we'll + # add it. + self.file.flush = lambda: self.file.wrapped.flush() + + +class BaseDownloadProgressBar(WindowsMixin, InterruptibleMixin, + DownloadProgressMixin): + + file = sys.stdout + message = "%(percent)d%%" + suffix = "%(downloaded)s %(download_speed)s %(pretty_eta)s" + +# NOTE: The "type: ignore" comments on the following classes are there to +# work around https://github.com/python/typing/issues/241 + + +class DefaultDownloadProgressBar(BaseDownloadProgressBar, + _BaseBar): + pass + + +class DownloadSilentBar(BaseDownloadProgressBar, SilentBar): # type: ignore + pass + + +class DownloadBar(BaseDownloadProgressBar, # type: ignore + Bar): + pass + + +class DownloadFillingCirclesBar(BaseDownloadProgressBar, # type: ignore + FillingCirclesBar): + pass + + +class DownloadBlueEmojiProgressBar(BaseDownloadProgressBar, # type: ignore + BlueEmojiBar): + pass + + +class DownloadProgressSpinner(WindowsMixin, InterruptibleMixin, + DownloadProgressMixin, Spinner): + + file = sys.stdout + suffix = "%(downloaded)s %(download_speed)s" + + def next_phase(self): + if not hasattr(self, "_phaser"): + self._phaser = itertools.cycle(self.phases) + return next(self._phaser) + + def update(self): + message = self.message % self + phase = self.next_phase() + suffix = self.suffix % self + line = ''.join([ + message, + " " if message else "", + phase, + " " if suffix else "", + suffix, + ]) + + self.writeln(line) + + +BAR_TYPES = { + "off": (DownloadSilentBar, DownloadSilentBar), + "on": (DefaultDownloadProgressBar, DownloadProgressSpinner), + "ascii": (DownloadBar, DownloadProgressSpinner), + "pretty": (DownloadFillingCirclesBar, DownloadProgressSpinner), + "emoji": (DownloadBlueEmojiProgressBar, DownloadProgressSpinner) +} + + +def DownloadProgressProvider(progress_bar, max=None): + if max is None or max == 0: + return BAR_TYPES[progress_bar][1]().iter + else: + return BAR_TYPES[progress_bar][0](max=max).iter + + +################################################################ +# Generic "something is happening" spinners +# +# We don't even try using progress.spinner.Spinner here because it's actually +# simpler to reimplement from scratch than to coerce their code into doing +# what we need. +################################################################ + +@contextlib.contextmanager +def hidden_cursor(file): + # type: (IO) -> Iterator[None] + # The Windows terminal does not support the hide/show cursor ANSI codes, + # even via colorama. So don't even try. + if WINDOWS: + yield + # We don't want to clutter the output with control characters if we're + # writing to a file, or if the user is running with --quiet. + # See https://github.com/pypa/pip/issues/3418 + elif not file.isatty() or logger.getEffectiveLevel() > logging.INFO: + yield + else: + file.write(HIDE_CURSOR) + try: + yield + finally: + file.write(SHOW_CURSOR) + + +class RateLimiter(object): + def __init__(self, min_update_interval_seconds): + # type: (float) -> None + self._min_update_interval_seconds = min_update_interval_seconds + self._last_update = 0 # type: float + + def ready(self): + # type: () -> bool + now = time.time() + delta = now - self._last_update + return delta >= self._min_update_interval_seconds + + def reset(self): + # type: () -> None + self._last_update = time.time() + + +class SpinnerInterface(object): + def spin(self): + # type: () -> None + raise NotImplementedError() + + def finish(self, final_status): + # type: (str) -> None + raise NotImplementedError() + + +class InteractiveSpinner(SpinnerInterface): + def __init__(self, message, file=None, spin_chars="-\\|/", + # Empirically, 8 updates/second looks nice + min_update_interval_seconds=0.125): + self._message = message + if file is None: + file = sys.stdout + self._file = file + self._rate_limiter = RateLimiter(min_update_interval_seconds) + self._finished = False + + self._spin_cycle = itertools.cycle(spin_chars) + + self._file.write(" " * get_indentation() + self._message + " ... ") + self._width = 0 + + def _write(self, status): + assert not self._finished + # Erase what we wrote before by backspacing to the beginning, writing + # spaces to overwrite the old text, and then backspacing again + backup = "\b" * self._width + self._file.write(backup + " " * self._width + backup) + # Now we have a blank slate to add our status + self._file.write(status) + self._width = len(status) + self._file.flush() + self._rate_limiter.reset() + + def spin(self): + # type: () -> None + if self._finished: + return + if not self._rate_limiter.ready(): + return + self._write(next(self._spin_cycle)) + + def finish(self, final_status): + # type: (str) -> None + if self._finished: + return + self._write(final_status) + self._file.write("\n") + self._file.flush() + self._finished = True + + +# Used for dumb terminals, non-interactive installs (no tty), etc. +# We still print updates occasionally (once every 60 seconds by default) to +# act as a keep-alive for systems like Travis-CI that take lack-of-output as +# an indication that a task has frozen. +class NonInteractiveSpinner(SpinnerInterface): + def __init__(self, message, min_update_interval_seconds=60): + # type: (str, float) -> None + self._message = message + self._finished = False + self._rate_limiter = RateLimiter(min_update_interval_seconds) + self._update("started") + + def _update(self, status): + assert not self._finished + self._rate_limiter.reset() + logger.info("%s: %s", self._message, status) + + def spin(self): + # type: () -> None + if self._finished: + return + if not self._rate_limiter.ready(): + return + self._update("still running...") + + def finish(self, final_status): + # type: (str) -> None + if self._finished: + return + self._update("finished with status '%s'" % (final_status,)) + self._finished = True + + +@contextlib.contextmanager +def open_spinner(message): + # type: (str) -> Iterator[SpinnerInterface] + # Interactive spinner goes directly to sys.stdout rather than being routed + # through the logging system, but it acts like it has level INFO, + # i.e. it's only displayed if we're at level INFO or better. + # Non-interactive spinner goes through the logging system, so it is always + # in sync with logging configuration. + if sys.stdout.isatty() and logger.getEffectiveLevel() <= logging.INFO: + spinner = InteractiveSpinner(message) # type: SpinnerInterface + else: + spinner = NonInteractiveSpinner(message) + try: + with hidden_cursor(sys.stdout): + yield spinner + except KeyboardInterrupt: + spinner.finish("canceled") + raise + except Exception: + spinner.finish("error") + raise + else: + spinner.finish("done") diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/virtualenv.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/virtualenv.py new file mode 100644 index 0000000..380db1c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/utils/virtualenv.py @@ -0,0 +1,34 @@ +import os.path +import site +import sys + + +def running_under_virtualenv(): + # type: () -> bool + """ + Return True if we're running inside a virtualenv, False otherwise. + + """ + if hasattr(sys, 'real_prefix'): + # pypa/virtualenv case + return True + elif sys.prefix != getattr(sys, "base_prefix", sys.prefix): + # PEP 405 venv + return True + + return False + + +def virtualenv_no_global(): + # type: () -> bool + """ + Return True if in a venv and no system site packages. + """ + # this mirrors the logic in virtualenv.py for locating the + # no-global-site-packages.txt file + site_mod_dir = os.path.dirname(os.path.abspath(site.__file__)) + no_global_file = os.path.join(site_mod_dir, 'no-global-site-packages.txt') + if running_under_virtualenv() and os.path.isfile(no_global_file): + return True + else: + return False diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__init__.py new file mode 100644 index 0000000..cb573ab --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__init__.py @@ -0,0 +1,12 @@ +# Expose a limited set of classes and functions so callers outside of +# the vcs package don't need to import deeper than `pip._internal.vcs`. +# (The test directory and imports protected by MYPY_CHECK_RUNNING may +# still need to import from a vcs sub-package.) +from pip._internal.vcs.versioncontrol import ( # noqa: F401 + RemoteNotFoundError, make_vcs_requirement_url, vcs, +) +# Import all vcs modules to register each VCS in the VcsSupport object. +import pip._internal.vcs.bazaar +import pip._internal.vcs.git +import pip._internal.vcs.mercurial +import pip._internal.vcs.subversion # noqa: F401 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..82339f038d0b212d5ac63225abb0714cbdcc0816 GIT binary patch literal 480 zcmZWkJx{|x49!Oi0n`bQD#5_op}D|-sDuy;j2(b3Sx(pH+8*3Ta4u1sf5XVe@41zU zKfu6*Q&k8lw)~#_o-EswUT@#S`2Kiflfd&no92I@=G|fyR|uJx`O;H<>Z>3PRG5Z- zqXn{)b~n7U<=rhu$ibsG2)}R|$sIm$Wh@^Xdv8je-2oVIeZ^ilt!4!U{#pv)ifc<t zkS;`VJlJz*xyWNGwB?|gj8Tm%4uvp!X0!z(p}7;n2093?-yWE<nlW%8I_|h_FNAd` zZCP=cl^~dOr){$+r`t2$JveBVH}GRf4x(a~lZpYE8=2v)WV9j+I;ud``eOc^ESIag zrgC&ST|$Df(Bz5WilNYjWl|24<g!{<=Vc>q>hFJo{}YO>u$0F6+C|sOWToUcU0h#8 K2uGdBZ}Jz;l#{&x literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1bce19f94fcf294ab76ce3a8a532e99f8b34ef4a GIT binary patch literal 3456 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 F{699cPagmP literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/git.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/git.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7552ea42d592fdfa5b0d4efeeaf97cf8159cea3f GIT binary patch literal 9012 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 YE3%v?+iX~>r91eujrm_Fzff-d4=qj%T>t<8 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..eaaa0214d36f5636a0e6b79e2b9162299d786a1a GIT binary patch literal 3743 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..090ac9b66954a87ee2946d1c17f63264a36c85f3 GIT binary patch literal 8396 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..fe91f27e969a73ce21305d1f0d22e39d63a36f7f GIT binary patch literal 17126 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 Je(w3A{XYPVONsyh literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/bazaar.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/bazaar.py new file mode 100644 index 0000000..4f1e114 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/bazaar.py @@ -0,0 +1,101 @@ +from __future__ import absolute_import + +import logging +import os + +from pip._vendor.six.moves.urllib import parse as urllib_parse + +from pip._internal.utils.misc import display_path, path_to_url, rmtree +from pip._internal.vcs.versioncontrol import VersionControl, vcs + +logger = logging.getLogger(__name__) + + +class Bazaar(VersionControl): + name = 'bzr' + dirname = '.bzr' + repo_name = 'branch' + schemes = ( + 'bzr', 'bzr+http', 'bzr+https', 'bzr+ssh', 'bzr+sftp', 'bzr+ftp', + 'bzr+lp', + ) + + def __init__(self, *args, **kwargs): + super(Bazaar, self).__init__(*args, **kwargs) + # This is only needed for python <2.7.5 + # Register lp but do not expose as a scheme to support bzr+lp. + if getattr(urllib_parse, 'uses_fragment', None): + urllib_parse.uses_fragment.extend(['lp']) + + @staticmethod + def get_base_rev_args(rev): + return ['-r', rev] + + def export(self, location, url): + """ + Export the Bazaar repository at the url to the destination location + """ + # Remove the location to make sure Bazaar can export it correctly + if os.path.exists(location): + rmtree(location) + + url, rev_options = self.get_url_rev_options(url) + self.run_command( + ['export', location, url] + rev_options.to_args(), + show_stdout=False, + ) + + def fetch_new(self, dest, url, rev_options): + rev_display = rev_options.to_display() + logger.info( + 'Checking out %s%s to %s', + url, + rev_display, + display_path(dest), + ) + cmd_args = ['branch', '-q'] + rev_options.to_args() + [url, dest] + self.run_command(cmd_args) + + def switch(self, dest, url, rev_options): + self.run_command(['switch', url], cwd=dest) + + def update(self, dest, url, rev_options): + cmd_args = ['pull', '-q'] + rev_options.to_args() + self.run_command(cmd_args, cwd=dest) + + @classmethod + def get_url_rev_and_auth(cls, url): + # hotfix the URL scheme after removing bzr+ from bzr+ssh:// readd it + url, rev, user_pass = super(Bazaar, cls).get_url_rev_and_auth(url) + if url.startswith('ssh://'): + url = 'bzr+' + url + return url, rev, user_pass + + @classmethod + def get_remote_url(cls, location): + urls = cls.run_command(['info'], show_stdout=False, cwd=location) + for line in urls.splitlines(): + line = line.strip() + for x in ('checkout of branch: ', + 'parent branch: '): + if line.startswith(x): + repo = line.split(x)[1] + if cls._is_local_repository(repo): + return path_to_url(repo) + return repo + return None + + @classmethod + def get_revision(cls, location): + revision = cls.run_command( + ['revno'], show_stdout=False, cwd=location, + ) + return revision.splitlines()[-1] + + @classmethod + def is_commit_id_equal(cls, dest, name): + """Always assume the versions don't match""" + return False + + +vcs.register(Bazaar) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/git.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/git.py new file mode 100644 index 0000000..3445c1b --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/git.py @@ -0,0 +1,358 @@ +from __future__ import absolute_import + +import logging +import os.path +import re + +from pip._vendor.packaging.version import parse as parse_version +from pip._vendor.six.moves.urllib import parse as urllib_parse +from pip._vendor.six.moves.urllib import request as urllib_request + +from pip._internal.exceptions import BadCommand +from pip._internal.utils.compat import samefile +from pip._internal.utils.misc import display_path, redact_password_from_url +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.vcs.versioncontrol import ( + RemoteNotFoundError, VersionControl, vcs, +) + +urlsplit = urllib_parse.urlsplit +urlunsplit = urllib_parse.urlunsplit + + +logger = logging.getLogger(__name__) + + +HASH_REGEX = re.compile('^[a-fA-F0-9]{40}$') + + +def looks_like_hash(sha): + return bool(HASH_REGEX.match(sha)) + + +class Git(VersionControl): + name = 'git' + dirname = '.git' + repo_name = 'clone' + schemes = ( + 'git', 'git+http', 'git+https', 'git+ssh', 'git+git', 'git+file', + ) + # Prevent the user's environment variables from interfering with pip: + # https://github.com/pypa/pip/issues/1130 + unset_environ = ('GIT_DIR', 'GIT_WORK_TREE') + default_arg_rev = 'HEAD' + + @staticmethod + def get_base_rev_args(rev): + return [rev] + + def get_git_version(self): + VERSION_PFX = 'git version ' + version = self.run_command(['version'], show_stdout=False) + if version.startswith(VERSION_PFX): + version = version[len(VERSION_PFX):].split()[0] + else: + version = '' + # get first 3 positions of the git version because + # on windows it is x.y.z.windows.t, and this parses as + # LegacyVersion which always smaller than a Version. + version = '.'.join(version.split('.')[:3]) + return parse_version(version) + + @classmethod + def get_current_branch(cls, location): + """ + Return the current branch, or None if HEAD isn't at a branch + (e.g. detached HEAD). + """ + # git-symbolic-ref exits with empty stdout if "HEAD" is a detached + # HEAD rather than a symbolic ref. In addition, the -q causes the + # command to exit with status code 1 instead of 128 in this case + # and to suppress the message to stderr. + args = ['symbolic-ref', '-q', 'HEAD'] + output = cls.run_command( + args, extra_ok_returncodes=(1, ), show_stdout=False, cwd=location, + ) + ref = output.strip() + + if ref.startswith('refs/heads/'): + return ref[len('refs/heads/'):] + + return None + + def export(self, location, url): + """Export the Git repository at the url to the destination location""" + if not location.endswith('/'): + location = location + '/' + + with TempDirectory(kind="export") as temp_dir: + self.unpack(temp_dir.path, url=url) + self.run_command( + ['checkout-index', '-a', '-f', '--prefix', location], + show_stdout=False, cwd=temp_dir.path + ) + + @classmethod + def get_revision_sha(cls, dest, rev): + """ + Return (sha_or_none, is_branch), where sha_or_none is a commit hash + if the revision names a remote branch or tag, otherwise None. + + Args: + dest: the repository directory. + rev: the revision name. + """ + # Pass rev to pre-filter the list. + output = cls.run_command(['show-ref', rev], cwd=dest, + show_stdout=False, on_returncode='ignore') + refs = {} + for line in output.strip().splitlines(): + try: + sha, ref = line.split() + except ValueError: + # Include the offending line to simplify troubleshooting if + # this error ever occurs. + raise ValueError('unexpected show-ref line: {!r}'.format(line)) + + refs[ref] = sha + + branch_ref = 'refs/remotes/origin/{}'.format(rev) + tag_ref = 'refs/tags/{}'.format(rev) + + sha = refs.get(branch_ref) + if sha is not None: + return (sha, True) + + sha = refs.get(tag_ref) + + return (sha, False) + + @classmethod + def resolve_revision(cls, dest, url, rev_options): + """ + Resolve a revision to a new RevOptions object with the SHA1 of the + branch, tag, or ref if found. + + Args: + rev_options: a RevOptions object. + """ + rev = rev_options.arg_rev + sha, is_branch = cls.get_revision_sha(dest, rev) + + if sha is not None: + rev_options = rev_options.make_new(sha) + rev_options.branch_name = rev if is_branch else None + + return rev_options + + # Do not show a warning for the common case of something that has + # the form of a Git commit hash. + if not looks_like_hash(rev): + logger.warning( + "Did not find branch or tag '%s', assuming revision or ref.", + rev, + ) + + if not rev.startswith('refs/'): + return rev_options + + # If it looks like a ref, we have to fetch it explicitly. + cls.run_command( + ['fetch', '-q', url] + rev_options.to_args(), + cwd=dest, + ) + # Change the revision to the SHA of the ref we fetched + sha = cls.get_revision(dest, rev='FETCH_HEAD') + rev_options = rev_options.make_new(sha) + + return rev_options + + @classmethod + def is_commit_id_equal(cls, dest, name): + """ + Return whether the current commit hash equals the given name. + + Args: + dest: the repository directory. + name: a string name. + """ + if not name: + # Then avoid an unnecessary subprocess call. + return False + + return cls.get_revision(dest) == name + + def fetch_new(self, dest, url, rev_options): + rev_display = rev_options.to_display() + logger.info( + 'Cloning %s%s to %s', redact_password_from_url(url), + rev_display, display_path(dest), + ) + self.run_command(['clone', '-q', url, dest]) + + if rev_options.rev: + # Then a specific revision was requested. + rev_options = self.resolve_revision(dest, url, rev_options) + branch_name = getattr(rev_options, 'branch_name', None) + if branch_name is None: + # Only do a checkout if the current commit id doesn't match + # the requested revision. + if not self.is_commit_id_equal(dest, rev_options.rev): + cmd_args = ['checkout', '-q'] + rev_options.to_args() + self.run_command(cmd_args, cwd=dest) + elif self.get_current_branch(dest) != branch_name: + # Then a specific branch was requested, and that branch + # is not yet checked out. + track_branch = 'origin/{}'.format(branch_name) + cmd_args = [ + 'checkout', '-b', branch_name, '--track', track_branch, + ] + self.run_command(cmd_args, cwd=dest) + + #: repo may contain submodules + self.update_submodules(dest) + + def switch(self, dest, url, rev_options): + self.run_command(['config', 'remote.origin.url', url], cwd=dest) + cmd_args = ['checkout', '-q'] + rev_options.to_args() + self.run_command(cmd_args, cwd=dest) + + self.update_submodules(dest) + + def update(self, dest, url, rev_options): + # First fetch changes from the default remote + if self.get_git_version() >= parse_version('1.9.0'): + # fetch tags in addition to everything else + self.run_command(['fetch', '-q', '--tags'], cwd=dest) + else: + self.run_command(['fetch', '-q'], cwd=dest) + # Then reset to wanted revision (maybe even origin/master) + rev_options = self.resolve_revision(dest, url, rev_options) + cmd_args = ['reset', '--hard', '-q'] + rev_options.to_args() + self.run_command(cmd_args, cwd=dest) + #: update submodules + self.update_submodules(dest) + + @classmethod + def get_remote_url(cls, location): + """ + Return URL of the first remote encountered. + + Raises RemoteNotFoundError if the repository does not have a remote + url configured. + """ + # We need to pass 1 for extra_ok_returncodes since the command + # exits with return code 1 if there are no matching lines. + stdout = cls.run_command( + ['config', '--get-regexp', r'remote\..*\.url'], + extra_ok_returncodes=(1, ), show_stdout=False, cwd=location, + ) + remotes = stdout.splitlines() + try: + found_remote = remotes[0] + except IndexError: + raise RemoteNotFoundError + + for remote in remotes: + if remote.startswith('remote.origin.url '): + found_remote = remote + break + url = found_remote.split(' ')[1] + return url.strip() + + @classmethod + def get_revision(cls, location, rev=None): + if rev is None: + rev = 'HEAD' + current_rev = cls.run_command( + ['rev-parse', rev], show_stdout=False, cwd=location, + ) + return current_rev.strip() + + @classmethod + def get_subdirectory(cls, location): + # find the repo root + git_dir = cls.run_command(['rev-parse', '--git-dir'], + show_stdout=False, cwd=location).strip() + if not os.path.isabs(git_dir): + git_dir = os.path.join(location, git_dir) + root_dir = os.path.join(git_dir, '..') + # find setup.py + orig_location = location + while not os.path.exists(os.path.join(location, 'setup.py')): + last_location = location + location = os.path.dirname(location) + if location == last_location: + # We've traversed up to the root of the filesystem without + # finding setup.py + logger.warning( + "Could not find setup.py for directory %s (tried all " + "parent directories)", + orig_location, + ) + return None + # relative path of setup.py to repo root + if samefile(root_dir, location): + return None + return os.path.relpath(location, root_dir) + + @classmethod + def get_url_rev_and_auth(cls, url): + """ + Prefixes stub URLs like 'user@hostname:user/repo.git' with 'ssh://'. + That's required because although they use SSH they sometimes don't + work with a ssh:// scheme (e.g. GitHub). But we need a scheme for + parsing. Hence we remove it again afterwards and return it as a stub. + """ + # Works around an apparent Git bug + # (see https://article.gmane.org/gmane.comp.version-control.git/146500) + scheme, netloc, path, query, fragment = urlsplit(url) + if scheme.endswith('file'): + initial_slashes = path[:-len(path.lstrip('/'))] + newpath = ( + initial_slashes + + urllib_request.url2pathname(path) + .replace('\\', '/').lstrip('/') + ) + url = urlunsplit((scheme, netloc, newpath, query, fragment)) + after_plus = scheme.find('+') + 1 + url = scheme[:after_plus] + urlunsplit( + (scheme[after_plus:], netloc, newpath, query, fragment), + ) + + if '://' not in url: + assert 'file:' not in url + url = url.replace('git+', 'git+ssh://') + url, rev, user_pass = super(Git, cls).get_url_rev_and_auth(url) + url = url.replace('ssh://', '') + else: + url, rev, user_pass = super(Git, cls).get_url_rev_and_auth(url) + + return url, rev, user_pass + + @classmethod + def update_submodules(cls, location): + if not os.path.exists(os.path.join(location, '.gitmodules')): + return + cls.run_command( + ['submodule', 'update', '--init', '--recursive', '-q'], + cwd=location, + ) + + @classmethod + def controls_location(cls, location): + if super(Git, cls).controls_location(location): + return True + try: + r = cls.run_command(['rev-parse'], + cwd=location, + show_stdout=False, + on_returncode='ignore') + return not r + except BadCommand: + logger.debug("could not determine if %s is under git control " + "because git is not available", location) + return False + + +vcs.register(Git) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/mercurial.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/mercurial.py new file mode 100644 index 0000000..db42783 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/mercurial.py @@ -0,0 +1,103 @@ +from __future__ import absolute_import + +import logging +import os + +from pip._vendor.six.moves import configparser + +from pip._internal.utils.misc import display_path, path_to_url +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.vcs.versioncontrol import VersionControl, vcs + +logger = logging.getLogger(__name__) + + +class Mercurial(VersionControl): + name = 'hg' + dirname = '.hg' + repo_name = 'clone' + schemes = ('hg', 'hg+http', 'hg+https', 'hg+ssh', 'hg+static-http') + + @staticmethod + def get_base_rev_args(rev): + return [rev] + + def export(self, location, url): + """Export the Hg repository at the url to the destination location""" + with TempDirectory(kind="export") as temp_dir: + self.unpack(temp_dir.path, url=url) + + self.run_command( + ['archive', location], show_stdout=False, cwd=temp_dir.path + ) + + def fetch_new(self, dest, url, rev_options): + rev_display = rev_options.to_display() + logger.info( + 'Cloning hg %s%s to %s', + url, + rev_display, + display_path(dest), + ) + self.run_command(['clone', '--noupdate', '-q', url, dest]) + cmd_args = ['update', '-q'] + rev_options.to_args() + self.run_command(cmd_args, cwd=dest) + + def switch(self, dest, url, rev_options): + repo_config = os.path.join(dest, self.dirname, 'hgrc') + config = configparser.RawConfigParser() + try: + config.read(repo_config) + config.set('paths', 'default', url) + with open(repo_config, 'w') as config_file: + config.write(config_file) + except (OSError, configparser.NoSectionError) as exc: + logger.warning( + 'Could not switch Mercurial repository to %s: %s', url, exc, + ) + else: + cmd_args = ['update', '-q'] + rev_options.to_args() + self.run_command(cmd_args, cwd=dest) + + def update(self, dest, url, rev_options): + self.run_command(['pull', '-q'], cwd=dest) + cmd_args = ['update', '-q'] + rev_options.to_args() + self.run_command(cmd_args, cwd=dest) + + @classmethod + def get_remote_url(cls, location): + url = cls.run_command( + ['showconfig', 'paths.default'], + show_stdout=False, cwd=location).strip() + if cls._is_local_repository(url): + url = path_to_url(url) + return url.strip() + + @classmethod + def get_revision(cls, location): + """ + Return the repository-local changeset revision number, as an integer. + """ + current_revision = cls.run_command( + ['parents', '--template={rev}'], + show_stdout=False, cwd=location).strip() + return current_revision + + @classmethod + def get_requirement_revision(cls, location): + """ + Return the changeset identification hash, as a 40-character + hexadecimal string + """ + current_rev_hash = cls.run_command( + ['parents', '--template={node}'], + show_stdout=False, cwd=location).strip() + return current_rev_hash + + @classmethod + def is_commit_id_equal(cls, dest, name): + """Always assume the versions don't match""" + return False + + +vcs.register(Mercurial) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/subversion.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/subversion.py new file mode 100644 index 0000000..6bb4c8c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/subversion.py @@ -0,0 +1,314 @@ +from __future__ import absolute_import + +import logging +import os +import re +import sys + +from pip._internal.utils.logging import indent_log +from pip._internal.utils.misc import ( + display_path, rmtree, split_auth_from_netloc, +) +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.vcs.versioncontrol import VersionControl, vcs + +_svn_xml_url_re = re.compile('url="([^"]+)"') +_svn_rev_re = re.compile(r'committed-rev="(\d+)"') +_svn_info_xml_rev_re = re.compile(r'\s*revision="(\d+)"') +_svn_info_xml_url_re = re.compile(r'<url>(.*)</url>') + + +if MYPY_CHECK_RUNNING: + from typing import List, Optional, Tuple + from pip._internal.vcs.versioncontrol import RevOptions + +logger = logging.getLogger(__name__) + + +class Subversion(VersionControl): + name = 'svn' + dirname = '.svn' + repo_name = 'checkout' + schemes = ('svn', 'svn+ssh', 'svn+http', 'svn+https', 'svn+svn') + + @classmethod + def should_add_vcs_url_prefix(cls, remote_url): + return True + + @staticmethod + def get_base_rev_args(rev): + return ['-r', rev] + + @classmethod + def get_revision(cls, location): + """ + Return the maximum revision for all files under a given location + """ + # Note: taken from setuptools.command.egg_info + revision = 0 + + for base, dirs, files in os.walk(location): + if cls.dirname not in dirs: + dirs[:] = [] + continue # no sense walking uncontrolled subdirs + dirs.remove(cls.dirname) + entries_fn = os.path.join(base, cls.dirname, 'entries') + if not os.path.exists(entries_fn): + # FIXME: should we warn? + continue + + dirurl, localrev = cls._get_svn_url_rev(base) + + if base == location: + base = dirurl + '/' # save the root url + elif not dirurl or not dirurl.startswith(base): + dirs[:] = [] + continue # not part of the same svn tree, skip it + revision = max(revision, localrev) + return revision + + @classmethod + def get_netloc_and_auth(cls, netloc, scheme): + """ + This override allows the auth information to be passed to svn via the + --username and --password options instead of via the URL. + """ + if scheme == 'ssh': + # The --username and --password options can't be used for + # svn+ssh URLs, so keep the auth information in the URL. + return super(Subversion, cls).get_netloc_and_auth(netloc, scheme) + + return split_auth_from_netloc(netloc) + + @classmethod + def get_url_rev_and_auth(cls, url): + # hotfix the URL scheme after removing svn+ from svn+ssh:// readd it + url, rev, user_pass = super(Subversion, cls).get_url_rev_and_auth(url) + if url.startswith('ssh://'): + url = 'svn+' + url + return url, rev, user_pass + + @staticmethod + def make_rev_args(username, password): + extra_args = [] + if username: + extra_args += ['--username', username] + if password: + extra_args += ['--password', password] + + return extra_args + + @classmethod + def get_remote_url(cls, location): + # In cases where the source is in a subdirectory, not alongside + # setup.py we have to look up in the location until we find a real + # setup.py + orig_location = location + while not os.path.exists(os.path.join(location, 'setup.py')): + last_location = location + location = os.path.dirname(location) + if location == last_location: + # We've traversed up to the root of the filesystem without + # finding setup.py + logger.warning( + "Could not find setup.py for directory %s (tried all " + "parent directories)", + orig_location, + ) + return None + + return cls._get_svn_url_rev(location)[0] + + @classmethod + def _get_svn_url_rev(cls, location): + from pip._internal.exceptions import InstallationError + + entries_path = os.path.join(location, cls.dirname, 'entries') + if os.path.exists(entries_path): + with open(entries_path) as f: + data = f.read() + else: # subversion >= 1.7 does not have the 'entries' file + data = '' + + if (data.startswith('8') or + data.startswith('9') or + data.startswith('10')): + data = list(map(str.splitlines, data.split('\n\x0c\n'))) + del data[0][0] # get rid of the '8' + url = data[0][3] + revs = [int(d[9]) for d in data if len(d) > 9 and d[9]] + [0] + elif data.startswith('<?xml'): + match = _svn_xml_url_re.search(data) + if not match: + raise ValueError('Badly formatted data: %r' % data) + url = match.group(1) # get repository URL + revs = [int(m.group(1)) for m in _svn_rev_re.finditer(data)] + [0] + else: + try: + # subversion >= 1.7 + # Note that using get_remote_call_options is not necessary here + # because `svn info` is being run against a local directory. + # We don't need to worry about making sure interactive mode + # is being used to prompt for passwords, because passwords + # are only potentially needed for remote server requests. + xml = cls.run_command( + ['info', '--xml', location], + show_stdout=False, + ) + url = _svn_info_xml_url_re.search(xml).group(1) + revs = [ + int(m.group(1)) for m in _svn_info_xml_rev_re.finditer(xml) + ] + except InstallationError: + url, revs = None, [] + + if revs: + rev = max(revs) + else: + rev = 0 + + return url, rev + + @classmethod + def is_commit_id_equal(cls, dest, name): + """Always assume the versions don't match""" + return False + + def __init__(self, use_interactive=None): + # type: (bool) -> None + if use_interactive is None: + use_interactive = sys.stdin.isatty() + self.use_interactive = use_interactive + + # This member is used to cache the fetched version of the current + # ``svn`` client. + # Special value definitions: + # None: Not evaluated yet. + # Empty tuple: Could not parse version. + self._vcs_version = None # type: Optional[Tuple[int, ...]] + + super(Subversion, self).__init__() + + def call_vcs_version(self): + # type: () -> Tuple[int, ...] + """Query the version of the currently installed Subversion client. + + :return: A tuple containing the parts of the version information or + ``()`` if the version returned from ``svn`` could not be parsed. + :raises: BadCommand: If ``svn`` is not installed. + """ + # Example versions: + # svn, version 1.10.3 (r1842928) + # compiled Feb 25 2019, 14:20:39 on x86_64-apple-darwin17.0.0 + # svn, version 1.7.14 (r1542130) + # compiled Mar 28 2018, 08:49:13 on x86_64-pc-linux-gnu + version_prefix = 'svn, version ' + version = self.run_command(['--version'], show_stdout=False) + if not version.startswith(version_prefix): + return () + + version = version[len(version_prefix):].split()[0] + version_list = version.split('.') + try: + parsed_version = tuple(map(int, version_list)) + except ValueError: + return () + + return parsed_version + + def get_vcs_version(self): + # type: () -> Tuple[int, ...] + """Return the version of the currently installed Subversion client. + + If the version of the Subversion client has already been queried, + a cached value will be used. + + :return: A tuple containing the parts of the version information or + ``()`` if the version returned from ``svn`` could not be parsed. + :raises: BadCommand: If ``svn`` is not installed. + """ + if self._vcs_version is not None: + # Use cached version, if available. + # If parsing the version failed previously (empty tuple), + # do not attempt to parse it again. + return self._vcs_version + + vcs_version = self.call_vcs_version() + self._vcs_version = vcs_version + return vcs_version + + def get_remote_call_options(self): + # type: () -> List[str] + """Return options to be used on calls to Subversion that contact the server. + + These options are applicable for the following ``svn`` subcommands used + in this class. + + - checkout + - export + - switch + - update + + :return: A list of command line arguments to pass to ``svn``. + """ + if not self.use_interactive: + # --non-interactive switch is available since Subversion 0.14.4. + # Subversion < 1.8 runs in interactive mode by default. + return ['--non-interactive'] + + svn_version = self.get_vcs_version() + # By default, Subversion >= 1.8 runs in non-interactive mode if + # stdin is not a TTY. Since that is how pip invokes SVN, in + # call_subprocess(), pip must pass --force-interactive to ensure + # the user can be prompted for a password, if required. + # SVN added the --force-interactive option in SVN 1.8. Since + # e.g. RHEL/CentOS 7, which is supported until 2024, ships with + # SVN 1.7, pip should continue to support SVN 1.7. Therefore, pip + # can't safely add the option if the SVN version is < 1.8 (or unknown). + if svn_version >= (1, 8): + return ['--force-interactive'] + + return [] + + def export(self, location, url): + """Export the svn repository at the url to the destination location""" + url, rev_options = self.get_url_rev_options(url) + + logger.info('Exporting svn repository %s to %s', url, location) + with indent_log(): + if os.path.exists(location): + # Subversion doesn't like to check out over an existing + # directory --force fixes this, but was only added in svn 1.5 + rmtree(location) + cmd_args = (['export'] + self.get_remote_call_options() + + rev_options.to_args() + [url, location]) + self.run_command(cmd_args, show_stdout=False) + + def fetch_new(self, dest, url, rev_options): + # type: (str, str, RevOptions) -> None + rev_display = rev_options.to_display() + logger.info( + 'Checking out %s%s to %s', + url, + rev_display, + display_path(dest), + ) + cmd_args = (['checkout', '-q'] + + self.get_remote_call_options() + + rev_options.to_args() + [url, dest]) + self.run_command(cmd_args) + + def switch(self, dest, url, rev_options): + # type: (str, str, RevOptions) -> None + cmd_args = (['switch'] + self.get_remote_call_options() + + rev_options.to_args() + [url, dest]) + self.run_command(cmd_args) + + def update(self, dest, url, rev_options): + # type: (str, str, RevOptions) -> None + cmd_args = (['update'] + self.get_remote_call_options() + + rev_options.to_args() + [dest]) + self.run_command(cmd_args) + + +vcs.register(Subversion) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/versioncontrol.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/versioncontrol.py new file mode 100644 index 0000000..2d05fc1 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/vcs/versioncontrol.py @@ -0,0 +1,600 @@ +"""Handles all VCS (version control) support""" +from __future__ import absolute_import + +import errno +import logging +import os +import shutil +import sys + +from pip._vendor import pkg_resources +from pip._vendor.six.moves.urllib import parse as urllib_parse + +from pip._internal.exceptions import BadCommand +from pip._internal.utils.misc import ( + ask_path_exists, backup_dir, call_subprocess, display_path, rmtree, +) +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import ( + Any, Dict, Iterable, List, Mapping, Optional, Text, Tuple, Type + ) + from pip._internal.utils.ui import SpinnerInterface + + AuthInfo = Tuple[Optional[str], Optional[str]] + +__all__ = ['vcs'] + + +logger = logging.getLogger(__name__) + + +def make_vcs_requirement_url(repo_url, rev, project_name, subdir=None): + """ + Return the URL for a VCS requirement. + + Args: + repo_url: the remote VCS url, with any needed VCS prefix (e.g. "git+"). + project_name: the (unescaped) project name. + """ + egg_project_name = pkg_resources.to_filename(project_name) + req = '{}@{}#egg={}'.format(repo_url, rev, egg_project_name) + if subdir: + req += '&subdirectory={}'.format(subdir) + + return req + + +class RemoteNotFoundError(Exception): + pass + + +class RevOptions(object): + + """ + Encapsulates a VCS-specific revision to install, along with any VCS + install options. + + Instances of this class should be treated as if immutable. + """ + + def __init__( + self, + vc_class, # type: Type[VersionControl] + rev=None, # type: Optional[str] + extra_args=None, # type: Optional[List[str]] + ): + # type: (...) -> None + """ + Args: + vc_class: a VersionControl subclass. + rev: the name of the revision to install. + extra_args: a list of extra options. + """ + if extra_args is None: + extra_args = [] + + self.extra_args = extra_args + self.rev = rev + self.vc_class = vc_class + + def __repr__(self): + return '<RevOptions {}: rev={!r}>'.format(self.vc_class.name, self.rev) + + @property + def arg_rev(self): + # type: () -> Optional[str] + if self.rev is None: + return self.vc_class.default_arg_rev + + return self.rev + + def to_args(self): + # type: () -> List[str] + """ + Return the VCS-specific command arguments. + """ + args = [] # type: List[str] + rev = self.arg_rev + if rev is not None: + args += self.vc_class.get_base_rev_args(rev) + args += self.extra_args + + return args + + def to_display(self): + # type: () -> str + if not self.rev: + return '' + + return ' (to revision {})'.format(self.rev) + + def make_new(self, rev): + # type: (str) -> RevOptions + """ + Make a copy of the current instance, but with a new rev. + + Args: + rev: the name of the revision for the new object. + """ + return self.vc_class.make_rev_options(rev, extra_args=self.extra_args) + + +class VcsSupport(object): + _registry = {} # type: Dict[str, VersionControl] + schemes = ['ssh', 'git', 'hg', 'bzr', 'sftp', 'svn'] + + def __init__(self): + # type: () -> None + # Register more schemes with urlparse for various version control + # systems + urllib_parse.uses_netloc.extend(self.schemes) + # Python >= 2.7.4, 3.3 doesn't have uses_fragment + if getattr(urllib_parse, 'uses_fragment', None): + urllib_parse.uses_fragment.extend(self.schemes) + super(VcsSupport, self).__init__() + + def __iter__(self): + return self._registry.__iter__() + + @property + def backends(self): + # type: () -> List[VersionControl] + return list(self._registry.values()) + + @property + def dirnames(self): + # type: () -> List[str] + return [backend.dirname for backend in self.backends] + + @property + def all_schemes(self): + # type: () -> List[str] + schemes = [] # type: List[str] + for backend in self.backends: + schemes.extend(backend.schemes) + return schemes + + def register(self, cls): + # type: (Type[VersionControl]) -> None + if not hasattr(cls, 'name'): + logger.warning('Cannot register VCS %s', cls.__name__) + return + if cls.name not in self._registry: + self._registry[cls.name] = cls() + logger.debug('Registered VCS backend: %s', cls.name) + + def unregister(self, name): + # type: (str) -> None + if name in self._registry: + del self._registry[name] + + def get_backend_for_dir(self, location): + # type: (str) -> Optional[VersionControl] + """ + Return a VersionControl object if a repository of that type is found + at the given directory. + """ + for vcs_backend in self._registry.values(): + if vcs_backend.controls_location(location): + logger.debug('Determine that %s uses VCS: %s', + location, vcs_backend.name) + return vcs_backend + return None + + def get_backend(self, name): + # type: (str) -> Optional[VersionControl] + """ + Return a VersionControl object or None. + """ + name = name.lower() + return self._registry.get(name) + + +vcs = VcsSupport() + + +class VersionControl(object): + name = '' + dirname = '' + repo_name = '' + # List of supported schemes for this Version Control + schemes = () # type: Tuple[str, ...] + # Iterable of environment variable names to pass to call_subprocess(). + unset_environ = () # type: Tuple[str, ...] + default_arg_rev = None # type: Optional[str] + + @classmethod + def should_add_vcs_url_prefix(cls, remote_url): + """ + Return whether the vcs prefix (e.g. "git+") should be added to a + repository's remote url when used in a requirement. + """ + return not remote_url.lower().startswith('{}:'.format(cls.name)) + + @classmethod + def get_subdirectory(cls, repo_dir): + """ + Return the path to setup.py, relative to the repo root. + """ + return None + + @classmethod + def get_requirement_revision(cls, repo_dir): + """ + Return the revision string that should be used in a requirement. + """ + return cls.get_revision(repo_dir) + + @classmethod + def get_src_requirement(cls, repo_dir, project_name): + """ + Return the requirement string to use to redownload the files + currently at the given repository directory. + + Args: + project_name: the (unescaped) project name. + + The return value has a form similar to the following: + + {repository_url}@{revision}#egg={project_name} + """ + repo_url = cls.get_remote_url(repo_dir) + if repo_url is None: + return None + + if cls.should_add_vcs_url_prefix(repo_url): + repo_url = '{}+{}'.format(cls.name, repo_url) + + revision = cls.get_requirement_revision(repo_dir) + subdir = cls.get_subdirectory(repo_dir) + req = make_vcs_requirement_url(repo_url, revision, project_name, + subdir=subdir) + + return req + + @staticmethod + def get_base_rev_args(rev): + """ + Return the base revision arguments for a vcs command. + + Args: + rev: the name of a revision to install. Cannot be None. + """ + raise NotImplementedError + + @classmethod + def make_rev_options(cls, rev=None, extra_args=None): + # type: (Optional[str], Optional[List[str]]) -> RevOptions + """ + Return a RevOptions object. + + Args: + rev: the name of a revision to install. + extra_args: a list of extra options. + """ + return RevOptions(cls, rev, extra_args=extra_args) + + @classmethod + def _is_local_repository(cls, repo): + # type: (str) -> bool + """ + posix absolute paths start with os.path.sep, + win32 ones start with drive (like c:\\folder) + """ + drive, tail = os.path.splitdrive(repo) + return repo.startswith(os.path.sep) or bool(drive) + + def export(self, location, url): + """ + Export the repository at the url to the destination location + i.e. only download the files, without vcs informations + + :param url: the repository URL starting with a vcs prefix. + """ + raise NotImplementedError + + @classmethod + def get_netloc_and_auth(cls, netloc, scheme): + """ + Parse the repository URL's netloc, and return the new netloc to use + along with auth information. + + Args: + netloc: the original repository URL netloc. + scheme: the repository URL's scheme without the vcs prefix. + + This is mainly for the Subversion class to override, so that auth + information can be provided via the --username and --password options + instead of through the URL. For other subclasses like Git without + such an option, auth information must stay in the URL. + + Returns: (netloc, (username, password)). + """ + return netloc, (None, None) + + @classmethod + def get_url_rev_and_auth(cls, url): + # type: (str) -> Tuple[str, Optional[str], AuthInfo] + """ + Parse the repository URL to use, and return the URL, revision, + and auth info to use. + + Returns: (url, rev, (username, password)). + """ + scheme, netloc, path, query, frag = urllib_parse.urlsplit(url) + if '+' not in scheme: + raise ValueError( + "Sorry, {!r} is a malformed VCS url. " + "The format is <vcs>+<protocol>://<url>, " + "e.g. svn+http://myrepo/svn/MyApp#egg=MyApp".format(url) + ) + # Remove the vcs prefix. + scheme = scheme.split('+', 1)[1] + netloc, user_pass = cls.get_netloc_and_auth(netloc, scheme) + rev = None + if '@' in path: + path, rev = path.rsplit('@', 1) + url = urllib_parse.urlunsplit((scheme, netloc, path, query, '')) + return url, rev, user_pass + + @staticmethod + def make_rev_args(username, password): + """ + Return the RevOptions "extra arguments" to use in obtain(). + """ + return [] + + def get_url_rev_options(self, url): + # type: (str) -> Tuple[str, RevOptions] + """ + Return the URL and RevOptions object to use in obtain() and in + some cases export(), as a tuple (url, rev_options). + """ + url, rev, user_pass = self.get_url_rev_and_auth(url) + username, password = user_pass + extra_args = self.make_rev_args(username, password) + rev_options = self.make_rev_options(rev, extra_args=extra_args) + + return url, rev_options + + @staticmethod + def normalize_url(url): + # type: (str) -> str + """ + Normalize a URL for comparison by unquoting it and removing any + trailing slash. + """ + return urllib_parse.unquote(url).rstrip('/') + + @classmethod + def compare_urls(cls, url1, url2): + # type: (str, str) -> bool + """ + Compare two repo URLs for identity, ignoring incidental differences. + """ + return (cls.normalize_url(url1) == cls.normalize_url(url2)) + + def fetch_new(self, dest, url, rev_options): + """ + Fetch a revision from a repository, in the case that this is the + first fetch from the repository. + + Args: + dest: the directory to fetch the repository to. + rev_options: a RevOptions object. + """ + raise NotImplementedError + + def switch(self, dest, url, rev_options): + """ + Switch the repo at ``dest`` to point to ``URL``. + + Args: + rev_options: a RevOptions object. + """ + raise NotImplementedError + + def update(self, dest, url, rev_options): + """ + Update an already-existing repo to the given ``rev_options``. + + Args: + rev_options: a RevOptions object. + """ + raise NotImplementedError + + @classmethod + def is_commit_id_equal(cls, dest, name): + """ + Return whether the id of the current commit equals the given name. + + Args: + dest: the repository directory. + name: a string name. + """ + raise NotImplementedError + + def obtain(self, dest, url): + # type: (str, str) -> None + """ + Install or update in editable mode the package represented by this + VersionControl object. + + :param dest: the repository directory in which to install or update. + :param url: the repository URL starting with a vcs prefix. + """ + url, rev_options = self.get_url_rev_options(url) + + if not os.path.exists(dest): + self.fetch_new(dest, url, rev_options) + return + + rev_display = rev_options.to_display() + if self.is_repository_directory(dest): + existing_url = self.get_remote_url(dest) + if self.compare_urls(existing_url, url): + logger.debug( + '%s in %s exists, and has correct URL (%s)', + self.repo_name.title(), + display_path(dest), + url, + ) + if not self.is_commit_id_equal(dest, rev_options.rev): + logger.info( + 'Updating %s %s%s', + display_path(dest), + self.repo_name, + rev_display, + ) + self.update(dest, url, rev_options) + else: + logger.info('Skipping because already up-to-date.') + return + + logger.warning( + '%s %s in %s exists with URL %s', + self.name, + self.repo_name, + display_path(dest), + existing_url, + ) + prompt = ('(s)witch, (i)gnore, (w)ipe, (b)ackup ', + ('s', 'i', 'w', 'b')) + else: + logger.warning( + 'Directory %s already exists, and is not a %s %s.', + dest, + self.name, + self.repo_name, + ) + # https://github.com/python/mypy/issues/1174 + prompt = ('(i)gnore, (w)ipe, (b)ackup ', # type: ignore + ('i', 'w', 'b')) + + logger.warning( + 'The plan is to install the %s repository %s', + self.name, + url, + ) + response = ask_path_exists('What to do? %s' % prompt[0], prompt[1]) + + if response == 'a': + sys.exit(-1) + + if response == 'w': + logger.warning('Deleting %s', display_path(dest)) + rmtree(dest) + self.fetch_new(dest, url, rev_options) + return + + if response == 'b': + dest_dir = backup_dir(dest) + logger.warning( + 'Backing up %s to %s', display_path(dest), dest_dir, + ) + shutil.move(dest, dest_dir) + self.fetch_new(dest, url, rev_options) + return + + # Do nothing if the response is "i". + if response == 's': + logger.info( + 'Switching %s %s to %s%s', + self.repo_name, + display_path(dest), + url, + rev_display, + ) + self.switch(dest, url, rev_options) + + def unpack(self, location, url): + # type: (str, str) -> None + """ + Clean up current location and download the url repository + (and vcs infos) into location + + :param url: the repository URL starting with a vcs prefix. + """ + if os.path.exists(location): + rmtree(location) + self.obtain(location, url=url) + + @classmethod + def get_remote_url(cls, location): + """ + Return the url used at location + + Raises RemoteNotFoundError if the repository does not have a remote + url configured. + """ + raise NotImplementedError + + @classmethod + def get_revision(cls, location): + """ + Return the current commit id of the files at the given location. + """ + raise NotImplementedError + + @classmethod + def run_command( + cls, + cmd, # type: List[str] + show_stdout=True, # type: bool + cwd=None, # type: Optional[str] + on_returncode='raise', # type: str + extra_ok_returncodes=None, # type: Optional[Iterable[int]] + command_desc=None, # type: Optional[str] + extra_environ=None, # type: Optional[Mapping[str, Any]] + spinner=None # type: Optional[SpinnerInterface] + ): + # type: (...) -> Text + """ + Run a VCS subcommand + This is simply a wrapper around call_subprocess that adds the VCS + command name, and checks that the VCS is available + """ + cmd = [cls.name] + cmd + try: + return call_subprocess(cmd, show_stdout, cwd, + on_returncode=on_returncode, + extra_ok_returncodes=extra_ok_returncodes, + command_desc=command_desc, + extra_environ=extra_environ, + unset_environ=cls.unset_environ, + spinner=spinner) + except OSError as e: + # errno.ENOENT = no such file or directory + # In other words, the VCS executable isn't available + if e.errno == errno.ENOENT: + raise BadCommand( + 'Cannot find command %r - do you have ' + '%r installed and in your ' + 'PATH?' % (cls.name, cls.name)) + else: + raise # re-raise exception if a different error occurred + + @classmethod + def is_repository_directory(cls, path): + # type: (str) -> bool + """ + Return whether a directory path is a repository directory. + """ + logger.debug('Checking in %s for %s (%s)...', + path, cls.dirname, cls.name) + return os.path.exists(os.path.join(path, cls.dirname)) + + @classmethod + def controls_location(cls, location): + # type: (str) -> bool + """ + Check if a location is controlled by the vcs. + It is meant to be overridden to implement smarter detection + mechanisms for specific vcs. + + This can do more than is_repository_directory() alone. For example, + the Git override checks that Git is actually available. + """ + return cls.is_repository_directory(location) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/wheel.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/wheel.py new file mode 100644 index 0000000..6f034cd --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_internal/wheel.py @@ -0,0 +1,1125 @@ +""" +Support for installing and building the "wheel" binary package format. +""" +from __future__ import absolute_import + +import collections +import compileall +import csv +import hashlib +import logging +import os.path +import re +import shutil +import stat +import sys +import warnings +from base64 import urlsafe_b64encode +from email.parser import Parser + +from pip._vendor import pkg_resources +from pip._vendor.distlib.scripts import ScriptMaker +from pip._vendor.packaging.utils import canonicalize_name +from pip._vendor.six import StringIO + +from pip._internal import pep425tags +from pip._internal.download import unpack_url +from pip._internal.exceptions import ( + InstallationError, InvalidWheelFilename, UnsupportedWheel, +) +from pip._internal.locations import distutils_scheme +from pip._internal.models.link import Link +from pip._internal.utils.logging import indent_log +from pip._internal.utils.marker_files import PIP_DELETE_MARKER_FILENAME +from pip._internal.utils.misc import ( + LOG_DIVIDER, call_subprocess, captured_stdout, ensure_dir, + format_command_args, path_to_url, read_chunks, +) +from pip._internal.utils.setuptools_build import make_setuptools_shim_args +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.ui import open_spinner + +if MYPY_CHECK_RUNNING: + from typing import ( + Dict, List, Optional, Sequence, Mapping, Tuple, IO, Text, Any, Iterable + ) + from pip._vendor.packaging.requirements import Requirement + from pip._internal.req.req_install import InstallRequirement + from pip._internal.download import PipSession + from pip._internal.index import FormatControl, PackageFinder + from pip._internal.operations.prepare import ( + RequirementPreparer + ) + from pip._internal.cache import WheelCache + from pip._internal.pep425tags import Pep425Tag + + InstalledCSVRow = Tuple[str, ...] + + +VERSION_COMPATIBLE = (1, 0) + + +logger = logging.getLogger(__name__) + + +def normpath(src, p): + return os.path.relpath(src, p).replace(os.path.sep, '/') + + +def hash_file(path, blocksize=1 << 20): + # type: (str, int) -> Tuple[Any, int] + """Return (hash, length) for path using hashlib.sha256()""" + h = hashlib.sha256() + length = 0 + with open(path, 'rb') as f: + for block in read_chunks(f, size=blocksize): + length += len(block) + h.update(block) + return (h, length) # type: ignore + + +def rehash(path, blocksize=1 << 20): + # type: (str, int) -> Tuple[str, str] + """Return (encoded_digest, length) for path using hashlib.sha256()""" + h, length = hash_file(path, blocksize) + digest = 'sha256=' + urlsafe_b64encode( + h.digest() + ).decode('latin1').rstrip('=') + # unicode/str python2 issues + return (digest, str(length)) # type: ignore + + +def open_for_csv(name, mode): + # type: (str, Text) -> IO + if sys.version_info[0] < 3: + nl = {} # type: Dict[str, Any] + bin = 'b' + else: + nl = {'newline': ''} # type: Dict[str, Any] + bin = '' + return open(name, mode + bin, **nl) + + +def replace_python_tag(wheelname, new_tag): + # type: (str, str) -> str + """Replace the Python tag in a wheel file name with a new value. + """ + parts = wheelname.split('-') + parts[-3] = new_tag + return '-'.join(parts) + + +def fix_script(path): + # type: (str) -> Optional[bool] + """Replace #!python with #!/path/to/python + Return True if file was changed.""" + # XXX RECORD hashes will need to be updated + if os.path.isfile(path): + with open(path, 'rb') as script: + firstline = script.readline() + if not firstline.startswith(b'#!python'): + return False + exename = sys.executable.encode(sys.getfilesystemencoding()) + firstline = b'#!' + exename + os.linesep.encode("ascii") + rest = script.read() + with open(path, 'wb') as script: + script.write(firstline) + script.write(rest) + return True + return None + + +dist_info_re = re.compile(r"""^(?P<namever>(?P<name>.+?)(-(?P<ver>.+?))?) + \.dist-info$""", re.VERBOSE) + + +def root_is_purelib(name, wheeldir): + # type: (str, str) -> bool + """ + Return True if the extracted wheel in wheeldir should go into purelib. + """ + name_folded = name.replace("-", "_") + for item in os.listdir(wheeldir): + match = dist_info_re.match(item) + if match and match.group('name') == name_folded: + with open(os.path.join(wheeldir, item, 'WHEEL')) as wheel: + for line in wheel: + line = line.lower().rstrip() + if line == "root-is-purelib: true": + return True + return False + + +def get_entrypoints(filename): + # type: (str) -> Tuple[Dict[str, str], Dict[str, str]] + if not os.path.exists(filename): + return {}, {} + + # This is done because you can pass a string to entry_points wrappers which + # means that they may or may not be valid INI files. The attempt here is to + # strip leading and trailing whitespace in order to make them valid INI + # files. + with open(filename) as fp: + data = StringIO() + for line in fp: + data.write(line.strip()) + data.write("\n") + data.seek(0) + + # get the entry points and then the script names + entry_points = pkg_resources.EntryPoint.parse_map(data) + console = entry_points.get('console_scripts', {}) + gui = entry_points.get('gui_scripts', {}) + + def _split_ep(s): + """get the string representation of EntryPoint, remove space and split + on '='""" + return str(s).replace(" ", "").split("=") + + # convert the EntryPoint objects into strings with module:function + console = dict(_split_ep(v) for v in console.values()) + gui = dict(_split_ep(v) for v in gui.values()) + return console, gui + + +def message_about_scripts_not_on_PATH(scripts): + # type: (Sequence[str]) -> Optional[str] + """Determine if any scripts are not on PATH and format a warning. + + Returns a warning message if one or more scripts are not on PATH, + otherwise None. + """ + if not scripts: + return None + + # Group scripts by the path they were installed in + grouped_by_dir = collections.defaultdict(set) # type: Dict[str, set] + for destfile in scripts: + parent_dir = os.path.dirname(destfile) + script_name = os.path.basename(destfile) + grouped_by_dir[parent_dir].add(script_name) + + # We don't want to warn for directories that are on PATH. + not_warn_dirs = [ + os.path.normcase(i).rstrip(os.sep) for i in + os.environ.get("PATH", "").split(os.pathsep) + ] + # If an executable sits with sys.executable, we don't warn for it. + # This covers the case of venv invocations without activating the venv. + not_warn_dirs.append(os.path.normcase(os.path.dirname(sys.executable))) + warn_for = { + parent_dir: scripts for parent_dir, scripts in grouped_by_dir.items() + if os.path.normcase(parent_dir) not in not_warn_dirs + } + if not warn_for: + return None + + # Format a message + msg_lines = [] + for parent_dir, scripts in warn_for.items(): + sorted_scripts = sorted(scripts) # type: List[str] + if len(sorted_scripts) == 1: + start_text = "script {} is".format(sorted_scripts[0]) + else: + start_text = "scripts {} are".format( + ", ".join(sorted_scripts[:-1]) + " and " + sorted_scripts[-1] + ) + + msg_lines.append( + "The {} installed in '{}' which is not on PATH." + .format(start_text, parent_dir) + ) + + last_line_fmt = ( + "Consider adding {} to PATH or, if you prefer " + "to suppress this warning, use --no-warn-script-location." + ) + if len(msg_lines) == 1: + msg_lines.append(last_line_fmt.format("this directory")) + else: + msg_lines.append(last_line_fmt.format("these directories")) + + # Returns the formatted multiline message + return "\n".join(msg_lines) + + +def sorted_outrows(outrows): + # type: (Iterable[InstalledCSVRow]) -> List[InstalledCSVRow] + """ + Return the given rows of a RECORD file in sorted order. + + Each row is a 3-tuple (path, hash, size) and corresponds to a record of + a RECORD file (see PEP 376 and PEP 427 for details). For the rows + passed to this function, the size can be an integer as an int or string, + or the empty string. + """ + # Normally, there should only be one row per path, in which case the + # second and third elements don't come into play when sorting. + # However, in cases in the wild where a path might happen to occur twice, + # we don't want the sort operation to trigger an error (but still want + # determinism). Since the third element can be an int or string, we + # coerce each element to a string to avoid a TypeError in this case. + # For additional background, see-- + # https://github.com/pypa/pip/issues/5868 + return sorted(outrows, key=lambda row: tuple(str(x) for x in row)) + + +def get_csv_rows_for_installed( + old_csv_rows, # type: Iterable[List[str]] + installed, # type: Dict[str, str] + changed, # type: set + generated, # type: List[str] + lib_dir, # type: str +): + # type: (...) -> List[InstalledCSVRow] + """ + :param installed: A map from archive RECORD path to installation RECORD + path. + """ + installed_rows = [] # type: List[InstalledCSVRow] + for row in old_csv_rows: + if len(row) > 3: + logger.warning( + 'RECORD line has more than three elements: {}'.format(row) + ) + # Make a copy because we are mutating the row. + row = list(row) + old_path = row[0] + new_path = installed.pop(old_path, old_path) + row[0] = new_path + if new_path in changed: + digest, length = rehash(new_path) + row[1] = digest + row[2] = length + installed_rows.append(tuple(row)) + for f in generated: + digest, length = rehash(f) + installed_rows.append((normpath(f, lib_dir), digest, str(length))) + for f in installed: + installed_rows.append((installed[f], '', '')) + return installed_rows + + +def move_wheel_files( + name, # type: str + req, # type: Requirement + wheeldir, # type: str + user=False, # type: bool + home=None, # type: Optional[str] + root=None, # type: Optional[str] + pycompile=True, # type: bool + scheme=None, # type: Optional[Mapping[str, str]] + isolated=False, # type: bool + prefix=None, # type: Optional[str] + warn_script_location=True # type: bool +): + # type: (...) -> None + """Install a wheel""" + # TODO: Investigate and break this up. + # TODO: Look into moving this into a dedicated class for representing an + # installation. + + if not scheme: + scheme = distutils_scheme( + name, user=user, home=home, root=root, isolated=isolated, + prefix=prefix, + ) + + if root_is_purelib(name, wheeldir): + lib_dir = scheme['purelib'] + else: + lib_dir = scheme['platlib'] + + info_dir = [] # type: List[str] + data_dirs = [] + source = wheeldir.rstrip(os.path.sep) + os.path.sep + + # Record details of the files moved + # installed = files copied from the wheel to the destination + # changed = files changed while installing (scripts #! line typically) + # generated = files newly generated during the install (script wrappers) + installed = {} # type: Dict[str, str] + changed = set() + generated = [] # type: List[str] + + # Compile all of the pyc files that we're going to be installing + if pycompile: + with captured_stdout() as stdout: + with warnings.catch_warnings(): + warnings.filterwarnings('ignore') + compileall.compile_dir(source, force=True, quiet=True) + logger.debug(stdout.getvalue()) + + def record_installed(srcfile, destfile, modified=False): + """Map archive RECORD paths to installation RECORD paths.""" + oldpath = normpath(srcfile, wheeldir) + newpath = normpath(destfile, lib_dir) + installed[oldpath] = newpath + if modified: + changed.add(destfile) + + def clobber(source, dest, is_base, fixer=None, filter=None): + ensure_dir(dest) # common for the 'include' path + + for dir, subdirs, files in os.walk(source): + basedir = dir[len(source):].lstrip(os.path.sep) + destdir = os.path.join(dest, basedir) + if is_base and basedir.split(os.path.sep, 1)[0].endswith('.data'): + continue + for s in subdirs: + destsubdir = os.path.join(dest, basedir, s) + if is_base and basedir == '' and destsubdir.endswith('.data'): + data_dirs.append(s) + continue + elif (is_base and + s.endswith('.dist-info') and + canonicalize_name(s).startswith( + canonicalize_name(req.name))): + assert not info_dir, ('Multiple .dist-info directories: ' + + destsubdir + ', ' + + ', '.join(info_dir)) + info_dir.append(destsubdir) + for f in files: + # Skip unwanted files + if filter and filter(f): + continue + srcfile = os.path.join(dir, f) + destfile = os.path.join(dest, basedir, f) + # directory creation is lazy and after the file filtering above + # to ensure we don't install empty dirs; empty dirs can't be + # uninstalled. + ensure_dir(destdir) + + # copyfile (called below) truncates the destination if it + # exists and then writes the new contents. This is fine in most + # cases, but can cause a segfault if pip has loaded a shared + # object (e.g. from pyopenssl through its vendored urllib3) + # Since the shared object is mmap'd an attempt to call a + # symbol in it will then cause a segfault. Unlinking the file + # allows writing of new contents while allowing the process to + # continue to use the old copy. + if os.path.exists(destfile): + os.unlink(destfile) + + # We use copyfile (not move, copy, or copy2) to be extra sure + # that we are not moving directories over (copyfile fails for + # directories) as well as to ensure that we are not copying + # over any metadata because we want more control over what + # metadata we actually copy over. + shutil.copyfile(srcfile, destfile) + + # Copy over the metadata for the file, currently this only + # includes the atime and mtime. + st = os.stat(srcfile) + if hasattr(os, "utime"): + os.utime(destfile, (st.st_atime, st.st_mtime)) + + # If our file is executable, then make our destination file + # executable. + if os.access(srcfile, os.X_OK): + st = os.stat(srcfile) + permissions = ( + st.st_mode | stat.S_IXUSR | stat.S_IXGRP | stat.S_IXOTH + ) + os.chmod(destfile, permissions) + + changed = False + if fixer: + changed = fixer(destfile) + record_installed(srcfile, destfile, changed) + + clobber(source, lib_dir, True) + + assert info_dir, "%s .dist-info directory not found" % req + + # Get the defined entry points + ep_file = os.path.join(info_dir[0], 'entry_points.txt') + console, gui = get_entrypoints(ep_file) + + def is_entrypoint_wrapper(name): + # EP, EP.exe and EP-script.py are scripts generated for + # entry point EP by setuptools + if name.lower().endswith('.exe'): + matchname = name[:-4] + elif name.lower().endswith('-script.py'): + matchname = name[:-10] + elif name.lower().endswith(".pya"): + matchname = name[:-4] + else: + matchname = name + # Ignore setuptools-generated scripts + return (matchname in console or matchname in gui) + + for datadir in data_dirs: + fixer = None + filter = None + for subdir in os.listdir(os.path.join(wheeldir, datadir)): + fixer = None + if subdir == 'scripts': + fixer = fix_script + filter = is_entrypoint_wrapper + source = os.path.join(wheeldir, datadir, subdir) + dest = scheme[subdir] + clobber(source, dest, False, fixer=fixer, filter=filter) + + maker = ScriptMaker(None, scheme['scripts']) + + # Ensure old scripts are overwritten. + # See https://github.com/pypa/pip/issues/1800 + maker.clobber = True + + # Ensure we don't generate any variants for scripts because this is almost + # never what somebody wants. + # See https://bitbucket.org/pypa/distlib/issue/35/ + maker.variants = {''} + + # This is required because otherwise distlib creates scripts that are not + # executable. + # See https://bitbucket.org/pypa/distlib/issue/32/ + maker.set_mode = True + + # Simplify the script and fix the fact that the default script swallows + # every single stack trace. + # See https://bitbucket.org/pypa/distlib/issue/34/ + # See https://bitbucket.org/pypa/distlib/issue/33/ + def _get_script_text(entry): + if entry.suffix is None: + raise InstallationError( + "Invalid script entry point: %s for req: %s - A callable " + "suffix is required. Cf https://packaging.python.org/en/" + "latest/distributing.html#console-scripts for more " + "information." % (entry, req) + ) + return maker.script_template % { + "module": entry.prefix, + "import_name": entry.suffix.split(".")[0], + "func": entry.suffix, + } + # ignore type, because mypy disallows assigning to a method, + # see https://github.com/python/mypy/issues/2427 + maker._get_script_text = _get_script_text # type: ignore + maker.script_template = r"""# -*- coding: utf-8 -*- +import re +import sys + +from %(module)s import %(import_name)s + +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0]) + sys.exit(%(func)s()) +""" + + # Special case pip and setuptools to generate versioned wrappers + # + # The issue is that some projects (specifically, pip and setuptools) use + # code in setup.py to create "versioned" entry points - pip2.7 on Python + # 2.7, pip3.3 on Python 3.3, etc. But these entry points are baked into + # the wheel metadata at build time, and so if the wheel is installed with + # a *different* version of Python the entry points will be wrong. The + # correct fix for this is to enhance the metadata to be able to describe + # such versioned entry points, but that won't happen till Metadata 2.0 is + # available. + # In the meantime, projects using versioned entry points will either have + # incorrect versioned entry points, or they will not be able to distribute + # "universal" wheels (i.e., they will need a wheel per Python version). + # + # Because setuptools and pip are bundled with _ensurepip and virtualenv, + # we need to use universal wheels. So, as a stopgap until Metadata 2.0, we + # override the versioned entry points in the wheel and generate the + # correct ones. This code is purely a short-term measure until Metadata 2.0 + # is available. + # + # To add the level of hack in this section of code, in order to support + # ensurepip this code will look for an ``ENSUREPIP_OPTIONS`` environment + # variable which will control which version scripts get installed. + # + # ENSUREPIP_OPTIONS=altinstall + # - Only pipX.Y and easy_install-X.Y will be generated and installed + # ENSUREPIP_OPTIONS=install + # - pipX.Y, pipX, easy_install-X.Y will be generated and installed. Note + # that this option is technically if ENSUREPIP_OPTIONS is set and is + # not altinstall + # DEFAULT + # - The default behavior is to install pip, pipX, pipX.Y, easy_install + # and easy_install-X.Y. + pip_script = console.pop('pip', None) + if pip_script: + if "ENSUREPIP_OPTIONS" not in os.environ: + spec = 'pip = ' + pip_script + generated.extend(maker.make(spec)) + + if os.environ.get("ENSUREPIP_OPTIONS", "") != "altinstall": + spec = 'pip%s = %s' % (sys.version[:1], pip_script) + generated.extend(maker.make(spec)) + + spec = 'pip%s = %s' % (sys.version[:3], pip_script) + generated.extend(maker.make(spec)) + # Delete any other versioned pip entry points + pip_ep = [k for k in console if re.match(r'pip(\d(\.\d)?)?$', k)] + for k in pip_ep: + del console[k] + easy_install_script = console.pop('easy_install', None) + if easy_install_script: + if "ENSUREPIP_OPTIONS" not in os.environ: + spec = 'easy_install = ' + easy_install_script + generated.extend(maker.make(spec)) + + spec = 'easy_install-%s = %s' % (sys.version[:3], easy_install_script) + generated.extend(maker.make(spec)) + # Delete any other versioned easy_install entry points + easy_install_ep = [ + k for k in console if re.match(r'easy_install(-\d\.\d)?$', k) + ] + for k in easy_install_ep: + del console[k] + + # Generate the console and GUI entry points specified in the wheel + if len(console) > 0: + generated_console_scripts = maker.make_multiple( + ['%s = %s' % kv for kv in console.items()] + ) + generated.extend(generated_console_scripts) + + if warn_script_location: + msg = message_about_scripts_not_on_PATH(generated_console_scripts) + if msg is not None: + logger.warning(msg) + + if len(gui) > 0: + generated.extend( + maker.make_multiple( + ['%s = %s' % kv for kv in gui.items()], + {'gui': True} + ) + ) + + # Record pip as the installer + installer = os.path.join(info_dir[0], 'INSTALLER') + temp_installer = os.path.join(info_dir[0], 'INSTALLER.pip') + with open(temp_installer, 'wb') as installer_file: + installer_file.write(b'pip\n') + shutil.move(temp_installer, installer) + generated.append(installer) + + # Record details of all files installed + record = os.path.join(info_dir[0], 'RECORD') + temp_record = os.path.join(info_dir[0], 'RECORD.pip') + with open_for_csv(record, 'r') as record_in: + with open_for_csv(temp_record, 'w+') as record_out: + reader = csv.reader(record_in) + outrows = get_csv_rows_for_installed( + reader, installed=installed, changed=changed, + generated=generated, lib_dir=lib_dir, + ) + writer = csv.writer(record_out) + # Sort to simplify testing. + for row in sorted_outrows(outrows): + writer.writerow(row) + shutil.move(temp_record, record) + + +def wheel_version(source_dir): + # type: (Optional[str]) -> Optional[Tuple[int, ...]] + """ + Return the Wheel-Version of an extracted wheel, if possible. + + Otherwise, return None if we couldn't parse / extract it. + """ + try: + dist = [d for d in pkg_resources.find_on_path(None, source_dir)][0] + + wheel_data = dist.get_metadata('WHEEL') + wheel_data = Parser().parsestr(wheel_data) + + version = wheel_data['Wheel-Version'].strip() + version = tuple(map(int, version.split('.'))) + return version + except Exception: + return None + + +def check_compatibility(version, name): + # type: (Optional[Tuple[int, ...]], str) -> None + """ + Raises errors or warns if called with an incompatible Wheel-Version. + + Pip should refuse to install a Wheel-Version that's a major series + ahead of what it's compatible with (e.g 2.0 > 1.1); and warn when + installing a version only minor version ahead (e.g 1.2 > 1.1). + + version: a 2-tuple representing a Wheel-Version (Major, Minor) + name: name of wheel or package to raise exception about + + :raises UnsupportedWheel: when an incompatible Wheel-Version is given + """ + if not version: + raise UnsupportedWheel( + "%s is in an unsupported or invalid wheel" % name + ) + if version[0] > VERSION_COMPATIBLE[0]: + raise UnsupportedWheel( + "%s's Wheel-Version (%s) is not compatible with this version " + "of pip" % (name, '.'.join(map(str, version))) + ) + elif version > VERSION_COMPATIBLE: + logger.warning( + 'Installing from a newer Wheel-Version (%s)', + '.'.join(map(str, version)), + ) + + +def format_tag(file_tag): + # type: (Tuple[str, ...]) -> str + """ + Format three tags in the form "<python_tag>-<abi_tag>-<platform_tag>". + + :param file_tag: A 3-tuple of tags (python_tag, abi_tag, platform_tag). + """ + return '-'.join(file_tag) + + +class Wheel(object): + """A wheel file""" + + # TODO: Maybe move the class into the models sub-package + # TODO: Maybe move the install code into this class + + wheel_file_re = re.compile( + r"""^(?P<namever>(?P<name>.+?)-(?P<ver>.*?)) + ((-(?P<build>\d[^-]*?))?-(?P<pyver>.+?)-(?P<abi>.+?)-(?P<plat>.+?) + \.whl|\.dist-info)$""", + re.VERBOSE + ) + + def __init__(self, filename): + # type: (str) -> None + """ + :raises InvalidWheelFilename: when the filename is invalid for a wheel + """ + wheel_info = self.wheel_file_re.match(filename) + if not wheel_info: + raise InvalidWheelFilename( + "%s is not a valid wheel filename." % filename + ) + self.filename = filename + self.name = wheel_info.group('name').replace('_', '-') + # we'll assume "_" means "-" due to wheel naming scheme + # (https://github.com/pypa/pip/issues/1150) + self.version = wheel_info.group('ver').replace('_', '-') + self.build_tag = wheel_info.group('build') + self.pyversions = wheel_info.group('pyver').split('.') + self.abis = wheel_info.group('abi').split('.') + self.plats = wheel_info.group('plat').split('.') + + # All the tag combinations from this file + self.file_tags = { + (x, y, z) for x in self.pyversions + for y in self.abis for z in self.plats + } + + def get_formatted_file_tags(self): + # type: () -> List[str] + """ + Return the wheel's tags as a sorted list of strings. + """ + return sorted(format_tag(tag) for tag in self.file_tags) + + def support_index_min(self, tags=None): + # type: (Optional[List[Pep425Tag]]) -> Optional[int] + """ + Return the lowest index that one of the wheel's file_tag combinations + achieves in the supported_tags list e.g. if there are 8 supported tags, + and one of the file tags is first in the list, then return 0. Returns + None is the wheel is not supported. + """ + if tags is None: # for mock + tags = pep425tags.get_supported() + indexes = [tags.index(c) for c in self.file_tags if c in tags] + return min(indexes) if indexes else None + + def supported(self, tags=None): + # type: (Optional[List[Pep425Tag]]) -> bool + """Is this wheel supported on this system?""" + if tags is None: # for mock + tags = pep425tags.get_supported() + return bool(set(tags).intersection(self.file_tags)) + + +def _contains_egg_info( + s, _egg_info_re=re.compile(r'([a-z0-9_.]+)-([a-z0-9_.!+-]+)', re.I)): + """Determine whether the string looks like an egg_info. + + :param s: The string to parse. E.g. foo-2.1 + """ + return bool(_egg_info_re.search(s)) + + +def should_use_ephemeral_cache( + req, # type: InstallRequirement + format_control, # type: FormatControl + autobuilding, # type: bool + cache_available # type: bool +): + # type: (...) -> Optional[bool] + """ + Return whether to build an InstallRequirement object using the + ephemeral cache. + + :param cache_available: whether a cache directory is available for the + autobuilding=True case. + + :return: True or False to build the requirement with ephem_cache=True + or False, respectively; or None not to build the requirement. + """ + if req.constraint: + return None + if req.is_wheel: + if not autobuilding: + logger.info( + 'Skipping %s, due to already being wheel.', req.name, + ) + return None + if not autobuilding: + return False + + if req.editable or not req.source_dir: + return None + + if "binary" not in format_control.get_allowed_formats( + canonicalize_name(req.name)): + logger.info( + "Skipping bdist_wheel for %s, due to binaries " + "being disabled for it.", req.name, + ) + return None + + if req.link and not req.link.is_artifact: + # VCS checkout. Build wheel just for this run. + return True + + link = req.link + base, ext = link.splitext() + if cache_available and _contains_egg_info(base): + return False + + # Otherwise, build the wheel just for this run using the ephemeral + # cache since we are either in the case of e.g. a local directory, or + # no cache directory is available to use. + return True + + +def format_command_result( + command_args, # type: List[str] + command_output, # type: str +): + # type: (...) -> str + """ + Format command information for logging. + """ + command_desc = format_command_args(command_args) + text = 'Command arguments: {}\n'.format(command_desc) + + if not command_output: + text += 'Command output: None' + elif logger.getEffectiveLevel() > logging.DEBUG: + text += 'Command output: [use --verbose to show]' + else: + if not command_output.endswith('\n'): + command_output += '\n' + text += 'Command output:\n{}{}'.format(command_output, LOG_DIVIDER) + + return text + + +def get_legacy_build_wheel_path( + names, # type: List[str] + temp_dir, # type: str + req, # type: InstallRequirement + command_args, # type: List[str] + command_output, # type: str +): + # type: (...) -> Optional[str] + """ + Return the path to the wheel in the temporary build directory. + """ + # Sort for determinism. + names = sorted(names) + if not names: + msg = ( + 'Legacy build of wheel for {!r} created no files.\n' + ).format(req.name) + msg += format_command_result(command_args, command_output) + logger.warning(msg) + return None + + if len(names) > 1: + msg = ( + 'Legacy build of wheel for {!r} created more than one file.\n' + 'Filenames (choosing first): {}\n' + ).format(req.name, names) + msg += format_command_result(command_args, command_output) + logger.warning(msg) + + return os.path.join(temp_dir, names[0]) + + +class WheelBuilder(object): + """Build wheels from a RequirementSet.""" + + def __init__( + self, + finder, # type: PackageFinder + preparer, # type: RequirementPreparer + wheel_cache, # type: WheelCache + build_options=None, # type: Optional[List[str]] + global_options=None, # type: Optional[List[str]] + no_clean=False # type: bool + ): + # type: (...) -> None + self.finder = finder + self.preparer = preparer + self.wheel_cache = wheel_cache + + self._wheel_dir = preparer.wheel_download_dir + + self.build_options = build_options or [] + self.global_options = global_options or [] + self.no_clean = no_clean + + def _build_one(self, req, output_dir, python_tag=None): + """Build one wheel. + + :return: The filename of the built wheel, or None if the build failed. + """ + # Install build deps into temporary directory (PEP 518) + with req.build_env: + return self._build_one_inside_env(req, output_dir, + python_tag=python_tag) + + def _build_one_inside_env(self, req, output_dir, python_tag=None): + with TempDirectory(kind="wheel") as temp_dir: + if req.use_pep517: + builder = self._build_one_pep517 + else: + builder = self._build_one_legacy + wheel_path = builder(req, temp_dir.path, python_tag=python_tag) + if wheel_path is not None: + wheel_name = os.path.basename(wheel_path) + dest_path = os.path.join(output_dir, wheel_name) + try: + wheel_hash, length = hash_file(wheel_path) + shutil.move(wheel_path, dest_path) + logger.info('Created wheel for %s: ' + 'filename=%s size=%d sha256=%s', + req.name, wheel_name, length, + wheel_hash.hexdigest()) + logger.info('Stored in directory: %s', output_dir) + return dest_path + except Exception: + pass + # Ignore return, we can't do anything else useful. + self._clean_one(req) + return None + + def _base_setup_args(self, req): + # NOTE: Eventually, we'd want to also -S to the flags here, when we're + # isolating. Currently, it breaks Python in virtualenvs, because it + # relies on site.py to find parts of the standard library outside the + # virtualenv. + base_cmd = make_setuptools_shim_args(req.setup_py_path, + unbuffered_output=True) + return base_cmd + list(self.global_options) + + def _build_one_pep517(self, req, tempd, python_tag=None): + """Build one InstallRequirement using the PEP 517 build process. + + Returns path to wheel if successfully built. Otherwise, returns None. + """ + assert req.metadata_directory is not None + if self.build_options: + # PEP 517 does not support --build-options + logger.error('Cannot build wheel for %s using PEP 517 when ' + '--build-options is present' % (req.name,)) + return None + try: + req.spin_message = 'Building wheel for %s (PEP 517)' % (req.name,) + logger.debug('Destination directory: %s', tempd) + wheel_name = req.pep517_backend.build_wheel( + tempd, + metadata_directory=req.metadata_directory + ) + if python_tag: + # General PEP 517 backends don't necessarily support + # a "--python-tag" option, so we rename the wheel + # file directly. + new_name = replace_python_tag(wheel_name, python_tag) + os.rename( + os.path.join(tempd, wheel_name), + os.path.join(tempd, new_name) + ) + # Reassign to simplify the return at the end of function + wheel_name = new_name + except Exception: + logger.error('Failed building wheel for %s', req.name) + return None + return os.path.join(tempd, wheel_name) + + def _build_one_legacy(self, req, tempd, python_tag=None): + """Build one InstallRequirement using the "legacy" build process. + + Returns path to wheel if successfully built. Otherwise, returns None. + """ + base_args = self._base_setup_args(req) + + spin_message = 'Building wheel for %s (setup.py)' % (req.name,) + with open_spinner(spin_message) as spinner: + logger.debug('Destination directory: %s', tempd) + wheel_args = base_args + ['bdist_wheel', '-d', tempd] \ + + self.build_options + + if python_tag is not None: + wheel_args += ["--python-tag", python_tag] + + try: + output = call_subprocess(wheel_args, cwd=req.setup_py_dir, + spinner=spinner) + except Exception: + spinner.finish("error") + logger.error('Failed building wheel for %s', req.name) + return None + names = os.listdir(tempd) + wheel_path = get_legacy_build_wheel_path( + names=names, + temp_dir=tempd, + req=req, + command_args=wheel_args, + command_output=output, + ) + return wheel_path + + def _clean_one(self, req): + base_args = self._base_setup_args(req) + + logger.info('Running setup.py clean for %s', req.name) + clean_args = base_args + ['clean', '--all'] + try: + call_subprocess(clean_args, cwd=req.source_dir) + return True + except Exception: + logger.error('Failed cleaning build dir for %s', req.name) + return False + + def build( + self, + requirements, # type: Iterable[InstallRequirement] + session, # type: PipSession + autobuilding=False # type: bool + ): + # type: (...) -> List[InstallRequirement] + """Build wheels. + + :param unpack: If True, replace the sdist we built from with the + newly built wheel, in preparation for installation. + :return: True if all the wheels built correctly. + """ + buildset = [] + format_control = self.finder.format_control + # Whether a cache directory is available for autobuilding=True. + cache_available = bool(self._wheel_dir or self.wheel_cache.cache_dir) + + for req in requirements: + ephem_cache = should_use_ephemeral_cache( + req, format_control=format_control, autobuilding=autobuilding, + cache_available=cache_available, + ) + if ephem_cache is None: + continue + + buildset.append((req, ephem_cache)) + + if not buildset: + return [] + + # Is any wheel build not using the ephemeral cache? + if any(not ephem_cache for _, ephem_cache in buildset): + have_directory_for_build = self._wheel_dir or ( + autobuilding and self.wheel_cache.cache_dir + ) + assert have_directory_for_build + + # TODO by @pradyunsg + # Should break up this method into 2 separate methods. + + # Build the wheels. + logger.info( + 'Building wheels for collected packages: %s', + ', '.join([req.name for (req, _) in buildset]), + ) + _cache = self.wheel_cache # shorter name + with indent_log(): + build_success, build_failure = [], [] + for req, ephem in buildset: + python_tag = None + if autobuilding: + python_tag = pep425tags.implementation_tag + if ephem: + output_dir = _cache.get_ephem_path_for_link(req.link) + else: + output_dir = _cache.get_path_for_link(req.link) + try: + ensure_dir(output_dir) + except OSError as e: + logger.warning("Building wheel for %s failed: %s", + req.name, e) + build_failure.append(req) + continue + else: + output_dir = self._wheel_dir + wheel_file = self._build_one( + req, output_dir, + python_tag=python_tag, + ) + if wheel_file: + build_success.append(req) + if autobuilding: + # XXX: This is mildly duplicative with prepare_files, + # but not close enough to pull out to a single common + # method. + # The code below assumes temporary source dirs - + # prevent it doing bad things. + if req.source_dir and not os.path.exists(os.path.join( + req.source_dir, PIP_DELETE_MARKER_FILENAME)): + raise AssertionError( + "bad source dir - missing marker") + # Delete the source we built the wheel from + req.remove_temporary_source() + # set the build directory again - name is known from + # the work prepare_files did. + req.source_dir = req.build_location( + self.preparer.build_dir + ) + # Update the link for this. + req.link = Link(path_to_url(wheel_file)) + assert req.link.is_wheel + # extract the wheel into the dir + unpack_url( + req.link, req.source_dir, None, False, + session=session, + ) + else: + build_failure.append(req) + + # notify success/failure + if build_success: + logger.info( + 'Successfully built %s', + ' '.join([req.name for req in build_success]), + ) + if build_failure: + logger.info( + 'Failed to build %s', + ' '.join([req.name for req in build_failure]), + ) + # Return a list of requirements that failed to build + return build_failure diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__init__.py new file mode 100644 index 0000000..c1d9508 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__init__.py @@ -0,0 +1,109 @@ +""" +pip._vendor is for vendoring dependencies of pip to prevent needing pip to +depend on something external. + +Files inside of pip._vendor should be considered immutable and should only be +updated to versions from upstream. +""" +from __future__ import absolute_import + +import glob +import os.path +import sys + +# Downstream redistributors which have debundled our dependencies should also +# patch this value to be true. This will trigger the additional patching +# to cause things like "six" to be available as pip. +DEBUNDLED = False + +# By default, look in this directory for a bunch of .whl files which we will +# add to the beginning of sys.path before attempting to import anything. This +# is done to support downstream re-distributors like Debian and Fedora who +# wish to create their own Wheels for our dependencies to aid in debundling. +WHEEL_DIR = os.path.abspath(os.path.dirname(__file__)) + + +# Define a small helper function to alias our vendored modules to the real ones +# if the vendored ones do not exist. This idea of this was taken from +# https://github.com/kennethreitz/requests/pull/2567. +def vendored(modulename): + vendored_name = "{0}.{1}".format(__name__, modulename) + + try: + __import__(modulename, globals(), locals(), level=0) + except ImportError: + # We can just silently allow import failures to pass here. If we + # got to this point it means that ``import pip._vendor.whatever`` + # failed and so did ``import whatever``. Since we're importing this + # upfront in an attempt to alias imports, not erroring here will + # just mean we get a regular import error whenever pip *actually* + # tries to import one of these modules to use it, which actually + # gives us a better error message than we would have otherwise + # gotten. + pass + else: + sys.modules[vendored_name] = sys.modules[modulename] + base, head = vendored_name.rsplit(".", 1) + setattr(sys.modules[base], head, sys.modules[modulename]) + + +# If we're operating in a debundled setup, then we want to go ahead and trigger +# the aliasing of our vendored libraries as well as looking for wheels to add +# to our sys.path. This will cause all of this code to be a no-op typically +# however downstream redistributors can enable it in a consistent way across +# all platforms. +if DEBUNDLED: + # Actually look inside of WHEEL_DIR to find .whl files and add them to the + # front of our sys.path. + sys.path[:] = glob.glob(os.path.join(WHEEL_DIR, "*.whl")) + sys.path + + # Actually alias all of our vendored dependencies. + vendored("cachecontrol") + vendored("colorama") + vendored("distlib") + vendored("distro") + vendored("html5lib") + vendored("lockfile") + vendored("six") + vendored("six.moves") + vendored("six.moves.urllib") + vendored("six.moves.urllib.parse") + vendored("packaging") + vendored("packaging.version") + vendored("packaging.specifiers") + vendored("pep517") + vendored("pkg_resources") + vendored("progress") + vendored("pytoml") + vendored("retrying") + vendored("requests") + vendored("requests.exceptions") + vendored("requests.packages") + vendored("requests.packages.urllib3") + vendored("requests.packages.urllib3._collections") + vendored("requests.packages.urllib3.connection") + vendored("requests.packages.urllib3.connectionpool") + vendored("requests.packages.urllib3.contrib") + vendored("requests.packages.urllib3.contrib.ntlmpool") + vendored("requests.packages.urllib3.contrib.pyopenssl") + vendored("requests.packages.urllib3.exceptions") + vendored("requests.packages.urllib3.fields") + vendored("requests.packages.urllib3.filepost") + vendored("requests.packages.urllib3.packages") + vendored("requests.packages.urllib3.packages.ordered_dict") + vendored("requests.packages.urllib3.packages.six") + vendored("requests.packages.urllib3.packages.ssl_match_hostname") + vendored("requests.packages.urllib3.packages.ssl_match_hostname." + "_implementation") + vendored("requests.packages.urllib3.poolmanager") + vendored("requests.packages.urllib3.request") + vendored("requests.packages.urllib3.response") + vendored("requests.packages.urllib3.util") + vendored("requests.packages.urllib3.util.connection") + vendored("requests.packages.urllib3.util.request") + vendored("requests.packages.urllib3.util.response") + vendored("requests.packages.urllib3.util.retry") + vendored("requests.packages.urllib3.util.ssl_") + vendored("requests.packages.urllib3.util.timeout") + vendored("requests.packages.urllib3.util.url") + vendored("urllib3") diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..220773146a6b520344aa7db40b56effa3995b7bb GIT binary patch literal 2875 zcmbuA&2QT_6u|XmS$6FvZPSl*Yo~rU?J6hj(vP7ShAk;ppy**+(ajhj$Rcekp+t?O zy;x07*^UGDC&b6y_V*CG?bPcIJ?ykcnel=Zaf(fX_@f@5p2+te`Cc@ebpx(9zm22d zq+$G_UJhO^ynG4|e`6X3GTH_*kwwhZYFno2+r)0$C7pJqq}z6p)2`ymhPPKM+d4ir zHpgbWfhx%T(P%eu^%s-<iS0eR96yd5s5-XBCU!TxvxaJsjqIPS#|Ca9Z`U*xYnpY< zW10=krsi?YIn8;^6PhPAPiZb_p4L30c~<kB=A!0#&G$6l*Sw&4QS$>$U-OdYWz8#^ zS2eF`Ue~;#c~f&q^Oojq%?~y2Xa<@s&1KCM&AXcSG(XZ@)x59yKoQwr8A}g~-|Kmj z2jLKBh%!Ineitx#OR}Dia1J9lixbR!+Vw%%7u3%g1|8vN7$c=N5!WZ$KFxeiQ!M&w z2yY3@vWNur`jdo!l_cW{!rIvM&%93u1o<88$Fx*n82L$>4n));*pD*gYZaQ25$M$i zIf?`*!E}b0@dQ5eyNss(Am@VNC=KebRlYBoaxUs{N(KUlNt#n8o<E5p=cktgJrADG z;o(DQkhy0FbK4kOJ7#fCSlfoMcMaj}8puNS&yH!lG_nQ95S7h3duST!{?^Do{>BjQ zMs?d*oX~u1Y@2%?a!_S#eP``hJGQ8m8rGt*ZSU*u+7Jx`qTxO-s;`!Jf>$d$OwA8w zULoLUBF*4+DX2>q;*&-~dSRGFDGozf5A~{`U+odvi3pc2p|Rqzr{#jz8KX?ve8gon zrDy<gkS^mnNrbF&EFvM;k|XPrF=bdbCrN-&`5)<YB95ig#}WF~U<)w2zmitYk|D&P zHH=uRO9_H7v>t7>df}rXON;DocVoHV-ztibJi6cMvt_t?S?lW-q{|&h0}&B&XL<Sl za5P*QC}H{NTx`LzvP6VokdLIdKbZ?EMDx%XX2Y_~bLR1yYt5VUCOZSNqH-(vp-*HZ zj^aLsL=ub=>BW>#7NwD_qJ#^Qbfl{~j7qOBQnIQf9yn~X3keEdO16p`G(k#-m>2WY zZZKd3bc-|pmIQgkz&o`(iZ`PkWPNdB+6{Da77PD~c#h+wn}EBdo8x?S<$-MGo4t@> zP6sT8;CMNsJ$O|LBSBMG1;c`kz_#jrKfqk@;?#aGz*{lSh1vtfiK%e%Ls-J%TOz%b zd&Tubhk_9NMsPf_di8KU@N+g%D{j7vR!%7?F3r>w4BUL{NR=QH1o9iq-9B13A5l2V zI48x7wH)xHf4E5q9YMUfJWGS%oN_TsXBwW?;db_Q0?J@_!Dd8BEM^65`hm*g)psxq z4hi8viThz6=Bu`TvHqVv3)C@0a0+!HQaMvxn_&iGmPT3B!)#V2XalpH2zw-ltjER0 z!~ZrA2`QFlj|T^`c*dSkrh@%x-8jPJbZ#>eP8)=+U0gZBoQl+}(3hq}l43fTnRlfg z9A&aPInVAb&B<yQA{tMsNp~Oy3@Qt=;7FB@Dk-u`IUI7LFD=ShL&<Av>z}=NzV>W= zO*-XB6^iVngAyqCP(q+asS_2f)?R+GzWyv+d-`R0PD^KlCRtfU4m78gS?}?r27RLH h9cR!u)rRGna9136!S&9&_Eo!lSF-<iPwc*B<8NSmiDv)+ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/appdirs.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/appdirs.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..fc79cb028571f0e259c803def5dd5ba375fef652 GIT binary patch literal 20486 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 Yb3=$^q&HbSk8g6xq;LACZ))NH04rNQw*UYD literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/distro.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/distro.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3ab1921bed46c41dddfc9bd8a6d11bc620bb64f9 GIT binary patch literal 36590 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 abD(graG<bneDC<rrqsWUe5UYt(fGf8JkgQ> literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/ipaddress.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/ipaddress.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..cc8897f54b7e512b20ad69bd09b9fed56fd7f1cd GIT binary patch literal 64831 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/pyparsing.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/pyparsing.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2d4900242a7262389838c2f154a14c2f591ca9c5 GIT binary patch literal 220254 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%0AA@(IeR4I@Y6=&> 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%0Aios$;H#J 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 b4o*zpKzSSS1&p*r!9Q42S6zqk*%1Cev1H@p literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/retrying.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/retrying.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..96bebdcb8ec8262f423ca37b0193c1efb29b12eb GIT binary patch literal 8055 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 R$8DO1{mk4KwHM}o_tzS=oZ|oh literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/six.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/__pycache__/six.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ad86c11258c2e91108d95daef79bdef2d581c455 GIT binary patch literal 26445 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/appdirs.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/appdirs.py new file mode 100644 index 0000000..2bd3911 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/appdirs.py @@ -0,0 +1,604 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- +# Copyright (c) 2005-2010 ActiveState Software Inc. +# Copyright (c) 2013 Eddy Petrișor + +"""Utilities for determining application-specific dirs. + +See <http://github.com/ActiveState/appdirs> for details and usage. +""" +# Dev Notes: +# - MSDN on where to store app data files: +# http://support.microsoft.com/default.aspx?scid=kb;en-us;310294#XSLTH3194121123120121120120 +# - Mac OS X: http://developer.apple.com/documentation/MacOSX/Conceptual/BPFileSystem/index.html +# - XDG spec for Un*x: http://standards.freedesktop.org/basedir-spec/basedir-spec-latest.html + +__version_info__ = (1, 4, 3) +__version__ = '.'.join(map(str, __version_info__)) + + +import sys +import os + +PY3 = sys.version_info[0] == 3 + +if PY3: + unicode = str + +if sys.platform.startswith('java'): + import platform + os_name = platform.java_ver()[3][0] + if os_name.startswith('Windows'): # "Windows XP", "Windows 7", etc. + system = 'win32' + elif os_name.startswith('Mac'): # "Mac OS X", etc. + system = 'darwin' + else: # "Linux", "SunOS", "FreeBSD", etc. + # Setting this to "linux2" is not ideal, but only Windows or Mac + # are actually checked for and the rest of the module expects + # *sys.platform* style strings. + system = 'linux2' +else: + system = sys.platform + + + +def user_data_dir(appname=None, appauthor=None, version=None, roaming=False): + r"""Return full path to the user-specific data dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "appauthor" (only used on Windows) is the name of the + appauthor or distributing body for this application. Typically + it is the owning company name. This falls back to appname. You may + pass False to disable it. + "version" is an optional version path element to append to the + path. You might want to use this if you want multiple versions + of your app to be able to run independently. If used, this + would typically be "<major>.<minor>". + Only applied when appname is present. + "roaming" (boolean, default False) can be set True to use the Windows + roaming appdata directory. That means that for users on a Windows + network setup for roaming profiles, this user data will be + sync'd on login. See + <http://technet.microsoft.com/en-us/library/cc766489(WS.10).aspx> + for a discussion of issues. + + Typical user data directories are: + Mac OS X: ~/Library/Application Support/<AppName> + Unix: ~/.local/share/<AppName> # or in $XDG_DATA_HOME, if defined + Win XP (not roaming): C:\Documents and Settings\<username>\Application Data\<AppAuthor>\<AppName> + Win XP (roaming): C:\Documents and Settings\<username>\Local Settings\Application Data\<AppAuthor>\<AppName> + Win 7 (not roaming): C:\Users\<username>\AppData\Local\<AppAuthor>\<AppName> + Win 7 (roaming): C:\Users\<username>\AppData\Roaming\<AppAuthor>\<AppName> + + For Unix, we follow the XDG spec and support $XDG_DATA_HOME. + That means, by default "~/.local/share/<AppName>". + """ + if system == "win32": + if appauthor is None: + appauthor = appname + const = roaming and "CSIDL_APPDATA" or "CSIDL_LOCAL_APPDATA" + path = os.path.normpath(_get_win_folder(const)) + if appname: + if appauthor is not False: + path = os.path.join(path, appauthor, appname) + else: + path = os.path.join(path, appname) + elif system == 'darwin': + path = os.path.expanduser('~/Library/Application Support/') + if appname: + path = os.path.join(path, appname) + else: + path = os.getenv('XDG_DATA_HOME', os.path.expanduser("~/.local/share")) + if appname: + path = os.path.join(path, appname) + if appname and version: + path = os.path.join(path, version) + return path + + +def site_data_dir(appname=None, appauthor=None, version=None, multipath=False): + r"""Return full path to the user-shared data dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "appauthor" (only used on Windows) is the name of the + appauthor or distributing body for this application. Typically + it is the owning company name. This falls back to appname. You may + pass False to disable it. + "version" is an optional version path element to append to the + path. You might want to use this if you want multiple versions + of your app to be able to run independently. If used, this + would typically be "<major>.<minor>". + Only applied when appname is present. + "multipath" is an optional parameter only applicable to *nix + which indicates that the entire list of data dirs should be + returned. By default, the first item from XDG_DATA_DIRS is + returned, or '/usr/local/share/<AppName>', + if XDG_DATA_DIRS is not set + + Typical site data directories are: + Mac OS X: /Library/Application Support/<AppName> + Unix: /usr/local/share/<AppName> or /usr/share/<AppName> + Win XP: C:\Documents and Settings\All Users\Application Data\<AppAuthor>\<AppName> + Vista: (Fail! "C:\ProgramData" is a hidden *system* directory on Vista.) + Win 7: C:\ProgramData\<AppAuthor>\<AppName> # Hidden, but writeable on Win 7. + + For Unix, this is using the $XDG_DATA_DIRS[0] default. + + WARNING: Do not use this on Windows. See the Vista-Fail note above for why. + """ + if system == "win32": + if appauthor is None: + appauthor = appname + path = os.path.normpath(_get_win_folder("CSIDL_COMMON_APPDATA")) + if appname: + if appauthor is not False: + path = os.path.join(path, appauthor, appname) + else: + path = os.path.join(path, appname) + elif system == 'darwin': + path = os.path.expanduser('/Library/Application Support') + if appname: + path = os.path.join(path, appname) + else: + # XDG default for $XDG_DATA_DIRS + # only first, if multipath is False + path = os.getenv('XDG_DATA_DIRS', + os.pathsep.join(['/usr/local/share', '/usr/share'])) + pathlist = [os.path.expanduser(x.rstrip(os.sep)) for x in path.split(os.pathsep)] + if appname: + if version: + appname = os.path.join(appname, version) + pathlist = [os.sep.join([x, appname]) for x in pathlist] + + if multipath: + path = os.pathsep.join(pathlist) + else: + path = pathlist[0] + return path + + if appname and version: + path = os.path.join(path, version) + return path + + +def user_config_dir(appname=None, appauthor=None, version=None, roaming=False): + r"""Return full path to the user-specific config dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "appauthor" (only used on Windows) is the name of the + appauthor or distributing body for this application. Typically + it is the owning company name. This falls back to appname. You may + pass False to disable it. + "version" is an optional version path element to append to the + path. You might want to use this if you want multiple versions + of your app to be able to run independently. If used, this + would typically be "<major>.<minor>". + Only applied when appname is present. + "roaming" (boolean, default False) can be set True to use the Windows + roaming appdata directory. That means that for users on a Windows + network setup for roaming profiles, this user data will be + sync'd on login. See + <http://technet.microsoft.com/en-us/library/cc766489(WS.10).aspx> + for a discussion of issues. + + Typical user config directories are: + Mac OS X: same as user_data_dir + Unix: ~/.config/<AppName> # or in $XDG_CONFIG_HOME, if defined + Win *: same as user_data_dir + + For Unix, we follow the XDG spec and support $XDG_CONFIG_HOME. + That means, by default "~/.config/<AppName>". + """ + if system in ["win32", "darwin"]: + path = user_data_dir(appname, appauthor, None, roaming) + else: + path = os.getenv('XDG_CONFIG_HOME', os.path.expanduser("~/.config")) + if appname: + path = os.path.join(path, appname) + if appname and version: + path = os.path.join(path, version) + return path + + +def site_config_dir(appname=None, appauthor=None, version=None, multipath=False): + r"""Return full path to the user-shared data dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "appauthor" (only used on Windows) is the name of the + appauthor or distributing body for this application. Typically + it is the owning company name. This falls back to appname. You may + pass False to disable it. + "version" is an optional version path element to append to the + path. You might want to use this if you want multiple versions + of your app to be able to run independently. If used, this + would typically be "<major>.<minor>". + Only applied when appname is present. + "multipath" is an optional parameter only applicable to *nix + which indicates that the entire list of config dirs should be + returned. By default, the first item from XDG_CONFIG_DIRS is + returned, or '/etc/xdg/<AppName>', if XDG_CONFIG_DIRS is not set + + Typical site config directories are: + Mac OS X: same as site_data_dir + Unix: /etc/xdg/<AppName> or $XDG_CONFIG_DIRS[i]/<AppName> for each value in + $XDG_CONFIG_DIRS + Win *: same as site_data_dir + Vista: (Fail! "C:\ProgramData" is a hidden *system* directory on Vista.) + + For Unix, this is using the $XDG_CONFIG_DIRS[0] default, if multipath=False + + WARNING: Do not use this on Windows. See the Vista-Fail note above for why. + """ + if system in ["win32", "darwin"]: + path = site_data_dir(appname, appauthor) + if appname and version: + path = os.path.join(path, version) + else: + # XDG default for $XDG_CONFIG_DIRS + # only first, if multipath is False + path = os.getenv('XDG_CONFIG_DIRS', '/etc/xdg') + pathlist = [os.path.expanduser(x.rstrip(os.sep)) for x in path.split(os.pathsep)] + if appname: + if version: + appname = os.path.join(appname, version) + pathlist = [os.sep.join([x, appname]) for x in pathlist] + + if multipath: + path = os.pathsep.join(pathlist) + else: + path = pathlist[0] + return path + + +def user_cache_dir(appname=None, appauthor=None, version=None, opinion=True): + r"""Return full path to the user-specific cache dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "appauthor" (only used on Windows) is the name of the + appauthor or distributing body for this application. Typically + it is the owning company name. This falls back to appname. You may + pass False to disable it. + "version" is an optional version path element to append to the + path. You might want to use this if you want multiple versions + of your app to be able to run independently. If used, this + would typically be "<major>.<minor>". + Only applied when appname is present. + "opinion" (boolean) can be False to disable the appending of + "Cache" to the base app data dir for Windows. See + discussion below. + + Typical user cache directories are: + Mac OS X: ~/Library/Caches/<AppName> + Unix: ~/.cache/<AppName> (XDG default) + Win XP: C:\Documents and Settings\<username>\Local Settings\Application Data\<AppAuthor>\<AppName>\Cache + Vista: C:\Users\<username>\AppData\Local\<AppAuthor>\<AppName>\Cache + + On Windows the only suggestion in the MSDN docs is that local settings go in + the `CSIDL_LOCAL_APPDATA` directory. This is identical to the non-roaming + app data dir (the default returned by `user_data_dir` above). Apps typically + put cache data somewhere *under* the given dir here. Some examples: + ...\Mozilla\Firefox\Profiles\<ProfileName>\Cache + ...\Acme\SuperApp\Cache\1.0 + OPINION: This function appends "Cache" to the `CSIDL_LOCAL_APPDATA` value. + This can be disabled with the `opinion=False` option. + """ + if system == "win32": + if appauthor is None: + appauthor = appname + path = os.path.normpath(_get_win_folder("CSIDL_LOCAL_APPDATA")) + if appname: + if appauthor is not False: + path = os.path.join(path, appauthor, appname) + else: + path = os.path.join(path, appname) + if opinion: + path = os.path.join(path, "Cache") + elif system == 'darwin': + path = os.path.expanduser('~/Library/Caches') + if appname: + path = os.path.join(path, appname) + else: + path = os.getenv('XDG_CACHE_HOME', os.path.expanduser('~/.cache')) + if appname: + path = os.path.join(path, appname) + if appname and version: + path = os.path.join(path, version) + return path + + +def user_state_dir(appname=None, appauthor=None, version=None, roaming=False): + r"""Return full path to the user-specific state dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "appauthor" (only used on Windows) is the name of the + appauthor or distributing body for this application. Typically + it is the owning company name. This falls back to appname. You may + pass False to disable it. + "version" is an optional version path element to append to the + path. You might want to use this if you want multiple versions + of your app to be able to run independently. If used, this + would typically be "<major>.<minor>". + Only applied when appname is present. + "roaming" (boolean, default False) can be set True to use the Windows + roaming appdata directory. That means that for users on a Windows + network setup for roaming profiles, this user data will be + sync'd on login. See + <http://technet.microsoft.com/en-us/library/cc766489(WS.10).aspx> + for a discussion of issues. + + Typical user state directories are: + Mac OS X: same as user_data_dir + Unix: ~/.local/state/<AppName> # or in $XDG_STATE_HOME, if defined + Win *: same as user_data_dir + + For Unix, we follow this Debian proposal <https://wiki.debian.org/XDGBaseDirectorySpecification#state> + to extend the XDG spec and support $XDG_STATE_HOME. + + That means, by default "~/.local/state/<AppName>". + """ + if system in ["win32", "darwin"]: + path = user_data_dir(appname, appauthor, None, roaming) + else: + path = os.getenv('XDG_STATE_HOME', os.path.expanduser("~/.local/state")) + if appname: + path = os.path.join(path, appname) + if appname and version: + path = os.path.join(path, version) + return path + + +def user_log_dir(appname=None, appauthor=None, version=None, opinion=True): + r"""Return full path to the user-specific log dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "appauthor" (only used on Windows) is the name of the + appauthor or distributing body for this application. Typically + it is the owning company name. This falls back to appname. You may + pass False to disable it. + "version" is an optional version path element to append to the + path. You might want to use this if you want multiple versions + of your app to be able to run independently. If used, this + would typically be "<major>.<minor>". + Only applied when appname is present. + "opinion" (boolean) can be False to disable the appending of + "Logs" to the base app data dir for Windows, and "log" to the + base cache dir for Unix. See discussion below. + + Typical user log directories are: + Mac OS X: ~/Library/Logs/<AppName> + Unix: ~/.cache/<AppName>/log # or under $XDG_CACHE_HOME if defined + Win XP: C:\Documents and Settings\<username>\Local Settings\Application Data\<AppAuthor>\<AppName>\Logs + Vista: C:\Users\<username>\AppData\Local\<AppAuthor>\<AppName>\Logs + + On Windows the only suggestion in the MSDN docs is that local settings + go in the `CSIDL_LOCAL_APPDATA` directory. (Note: I'm interested in + examples of what some windows apps use for a logs dir.) + + OPINION: This function appends "Logs" to the `CSIDL_LOCAL_APPDATA` + value for Windows and appends "log" to the user cache dir for Unix. + This can be disabled with the `opinion=False` option. + """ + if system == "darwin": + path = os.path.join( + os.path.expanduser('~/Library/Logs'), + appname) + elif system == "win32": + path = user_data_dir(appname, appauthor, version) + version = False + if opinion: + path = os.path.join(path, "Logs") + else: + path = user_cache_dir(appname, appauthor, version) + version = False + if opinion: + path = os.path.join(path, "log") + if appname and version: + path = os.path.join(path, version) + return path + + +class AppDirs(object): + """Convenience wrapper for getting application dirs.""" + def __init__(self, appname=None, appauthor=None, version=None, + roaming=False, multipath=False): + self.appname = appname + self.appauthor = appauthor + self.version = version + self.roaming = roaming + self.multipath = multipath + + @property + def user_data_dir(self): + return user_data_dir(self.appname, self.appauthor, + version=self.version, roaming=self.roaming) + + @property + def site_data_dir(self): + return site_data_dir(self.appname, self.appauthor, + version=self.version, multipath=self.multipath) + + @property + def user_config_dir(self): + return user_config_dir(self.appname, self.appauthor, + version=self.version, roaming=self.roaming) + + @property + def site_config_dir(self): + return site_config_dir(self.appname, self.appauthor, + version=self.version, multipath=self.multipath) + + @property + def user_cache_dir(self): + return user_cache_dir(self.appname, self.appauthor, + version=self.version) + + @property + def user_state_dir(self): + return user_state_dir(self.appname, self.appauthor, + version=self.version) + + @property + def user_log_dir(self): + return user_log_dir(self.appname, self.appauthor, + version=self.version) + + +#---- internal support stuff + +def _get_win_folder_from_registry(csidl_name): + """This is a fallback technique at best. I'm not sure if using the + registry for this guarantees us the correct answer for all CSIDL_* + names. + """ + if PY3: + import winreg as _winreg + else: + import _winreg + + shell_folder_name = { + "CSIDL_APPDATA": "AppData", + "CSIDL_COMMON_APPDATA": "Common AppData", + "CSIDL_LOCAL_APPDATA": "Local AppData", + }[csidl_name] + + key = _winreg.OpenKey( + _winreg.HKEY_CURRENT_USER, + r"Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders" + ) + dir, type = _winreg.QueryValueEx(key, shell_folder_name) + return dir + + +def _get_win_folder_with_pywin32(csidl_name): + from win32com.shell import shellcon, shell + dir = shell.SHGetFolderPath(0, getattr(shellcon, csidl_name), 0, 0) + # Try to make this a unicode path because SHGetFolderPath does + # not return unicode strings when there is unicode data in the + # path. + try: + dir = unicode(dir) + + # Downgrade to short path name if have highbit chars. See + # <http://bugs.activestate.com/show_bug.cgi?id=85099>. + has_high_char = False + for c in dir: + if ord(c) > 255: + has_high_char = True + break + if has_high_char: + try: + import win32api + dir = win32api.GetShortPathName(dir) + except ImportError: + pass + except UnicodeError: + pass + return dir + + +def _get_win_folder_with_ctypes(csidl_name): + import ctypes + + csidl_const = { + "CSIDL_APPDATA": 26, + "CSIDL_COMMON_APPDATA": 35, + "CSIDL_LOCAL_APPDATA": 28, + }[csidl_name] + + buf = ctypes.create_unicode_buffer(1024) + ctypes.windll.shell32.SHGetFolderPathW(None, csidl_const, None, 0, buf) + + # Downgrade to short path name if have highbit chars. See + # <http://bugs.activestate.com/show_bug.cgi?id=85099>. + has_high_char = False + for c in buf: + if ord(c) > 255: + has_high_char = True + break + if has_high_char: + buf2 = ctypes.create_unicode_buffer(1024) + if ctypes.windll.kernel32.GetShortPathNameW(buf.value, buf2, 1024): + buf = buf2 + + return buf.value + +def _get_win_folder_with_jna(csidl_name): + import array + from com.sun import jna + from com.sun.jna.platform import win32 + + buf_size = win32.WinDef.MAX_PATH * 2 + buf = array.zeros('c', buf_size) + shell = win32.Shell32.INSTANCE + shell.SHGetFolderPath(None, getattr(win32.ShlObj, csidl_name), None, win32.ShlObj.SHGFP_TYPE_CURRENT, buf) + dir = jna.Native.toString(buf.tostring()).rstrip("\0") + + # Downgrade to short path name if have highbit chars. See + # <http://bugs.activestate.com/show_bug.cgi?id=85099>. + has_high_char = False + for c in dir: + if ord(c) > 255: + has_high_char = True + break + if has_high_char: + buf = array.zeros('c', buf_size) + kernel = win32.Kernel32.INSTANCE + if kernel.GetShortPathName(dir, buf, buf_size): + dir = jna.Native.toString(buf.tostring()).rstrip("\0") + + return dir + +if system == "win32": + try: + from ctypes import windll + _get_win_folder = _get_win_folder_with_ctypes + except ImportError: + try: + import com.sun.jna + _get_win_folder = _get_win_folder_with_jna + except ImportError: + _get_win_folder = _get_win_folder_from_registry + + +#---- self test code + +if __name__ == "__main__": + appname = "MyApp" + appauthor = "MyCompany" + + props = ("user_data_dir", + "user_config_dir", + "user_cache_dir", + "user_state_dir", + "user_log_dir", + "site_data_dir", + "site_config_dir") + + print("-- app dirs %s --" % __version__) + + print("-- app dirs (with optional 'version')") + dirs = AppDirs(appname, appauthor, version="1.0") + for prop in props: + print("%s: %s" % (prop, getattr(dirs, prop))) + + print("\n-- app dirs (without optional 'version')") + dirs = AppDirs(appname, appauthor) + for prop in props: + print("%s: %s" % (prop, getattr(dirs, prop))) + + print("\n-- app dirs (without optional 'appauthor')") + dirs = AppDirs(appname) + for prop in props: + print("%s: %s" % (prop, getattr(dirs, prop))) + + print("\n-- app dirs (with disabled 'appauthor')") + dirs = AppDirs(appname, appauthor=False) + for prop in props: + print("%s: %s" % (prop, getattr(dirs, prop))) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__init__.py new file mode 100644 index 0000000..8fdee66 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__init__.py @@ -0,0 +1,11 @@ +"""CacheControl import Interface. + +Make it easy to import from cachecontrol without long namespaces. +""" +__author__ = "Eric Larson" +__email__ = "eric@ionrock.org" +__version__ = "0.12.5" + +from .wrapper import CacheControl +from .adapter import CacheControlAdapter +from .controller import CacheController diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4cb751d37259910f64e203249576e75b9a515d82 GIT binary patch literal 562 zcmYjNy>8nu5T<O|vK0p{kQd<UA(9fHK@Ai|f}lfzwoBVZ3&DuA#fE=4(Mqhh>DVpL zqqS3CphKsg+!W9ecl^Es@A%z)Jv~hc+V7|DJc|hVIgqhUkX)lTuQ3Qx5)qY=n3NMS zEvF(DGaZ{*Ig1G5xt^P(OpZ9w3$rYjh!>y9dfDCG@~W1%&IWLrD&rjl`rZZ!TVBa5 zO+WH`NmZbdHwPNr|0i2;hE_vu^<4X)Lhbf}YG-%Uaw8j$9hxldPTqm4=m!psv)xOH z<XSlkuDZ`0?7Df8U0i0be&Lv89rdfRBIIXdej~U?ZJ2&BPHPFD)@h$GCS1i>pEAbx zC<hQP8Iy)9jqrrARzicHBS{{BdoKZoRrU%0*BPb*OP`0rz7S*L2Z0q{$MC1kJ*buk znYSGBt<wT~=9|ZS$2KjP&R%Z66?OgCbxd!r?rJE|b~gW#d*#oSZ35T&yeO{PLwm6w rl1E2rRyfGVOU)TmRt3f~f9Mx)j1zk;-wumv20d{cM|dWyXchehNv*3b literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9716bfbbab1818b8381d33d0dd2c06f706053652 GIT binary patch literal 1589 zcmZ`(OOM+&5GJXoW!bw;gCZ@8)O{S{Lspv}0&GwONjF7v2#lh;d(lNuOvaY0S18)q zHJsDtn*U%QbL;QnwWt1p9(rkKC~dn55DKI|4j-EN<{O<21_6Qg*YCS@&mrUwoLp}f zOddgR&SBt$)11WkW;rcb%qU_jw+cJ94YqTqaAVhCC-(|J_6>IPUJ=9rV2}H6NZjW= z9>6=~eICMl!1wup58u#uDE9c?Z%isNyd<!no{;e;f5O+vWK6X$#ml8=R0H_a<8(R~ z$5p9hl|SZbt%L+~?@2aQW(g*4Ud?94JbWx?%R-dumsB=FPVvU8Mgd@?$IzQ^U{GXB z6<b(4N{M1ydq-ZQ&DjvNZ~{Kj$=H=Z8PR?t)HAUXx%TjDSvk|rlb?P(`&kc8loV<4 zG%a~9qz+QfI}EOQ^Va;1$N^mQw~T6;tx_eTRVt$wRnCQMqNDR@mK?2Qu`a)Vu{fO1 z&)4fDKf3>XE)Sv2%IGwzv-)mUHY&~YyN8GOR~M^$OEj9EtVGEx8BLL_X-ig=ObdQc zU+4k2zO0kZ?GVFvVIVZ5K9zfb-s6dZ0oM&r4*@8m=q2O`Q~;WIYXeJcYXMtyL$@}! zfG^O9!FGqq!r9Qo-C$mw$?4eAedAgpR61*P0J+K1JX-@_y}4M*tWnu??ah^{A4JjG zN6-KodlFM7Z5+@s?VX6G$*NL2MYSxI4!UTO`u+AB|69gPdugi~Z8vbxB%vLKcw2ua zRDug|;|(x0pTR&Vqc&mq{Nq|a&=fKt>T_6mk0=xrI%bIa5`ZF?AfXLeP#}wO>n+kk zwrqz|vM1VF%6xt6bS_3`zdjqOYNX`F2=p;BeuG-<xyb9WC6Rs|f{>E5)3Xk0R5Z@9 zDqJ&@ABN*&IJo6DT+k)ir9&#eg83Bvy=utnf4-l>r1c#WZPLmh3Mh=%OxakV8@h0| z?uIQq=zg1Su=LQfqw=W=IK70TDSbc;ktrW*vi6QqlKkuSU{a|zP(FHaXWTbF8B(<c zZp$yg2_r^{Incv4mr^u!RW?F<-9JHFGJVyp^5n|sKvk6rWM*UZ@)q7;<Jk`xvWqk; zzk}sw9|l5Q>RO@YS~sjA4Vb)x2mK_$T}guFzb}2X^`X)Zx+*h5j7Qfj2gcb>cL$x~ zjB?}KAKhlo7-h%betc6~%b@P=Hw5vuxkrt(e4#K~Hm}?-(?TT4wb=3BBaPzyABu`E bbMX+>VC3$zkb%TO<e}xee(1ZwO`rY?kui`a literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c0a050d50595067927c6d7957d4494ff40f3b7cc GIT binary patch literal 3088 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/cache.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/cache.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..02f6c24fd87eb8cb1fe885bcb0d3c4dafedb62ad GIT binary patch literal 1795 zcma)7&2G~`5Z<*N$8noBv`~Zu$Ok}*M3aD^QYC~61))kP0$K#h#d5uy#I0kSwG%Z_ zPPF&FLVL`O=kb*jFTjBlGwbGuHb~uSr?WfLoo{BosXrHsCV}<)$GP)RCFCa_W|szs zE!goh5R5bkqfGH>M`<XOydz9y+6iGASC7?(2Im~p;jD8F&N-IfC1qo<Z|=3Z<vK3N zaQ}e2iS_Ekj@1l><#i&TcX*I^K`Zl!D;9b)-gLTtVtKLUSV>!Ohnca{<dzq#cX%fh zeT#W+;)Q`D`W5pRpd)3PYVSk$(8a^-QsA%!JAMp;lLm!E6inoVG}J7GhL%A`(9D2) zofQDQnHF9<G2ce)E<Q6}s8iV6uwyJ?LXOFIczBnLXnjP})q0rhjI-nHtq`FYDXA87 zznQ9sygwoW|L#v*jfB^85?<{&qS_37#zkD+JgT<r&7SBCf~U=cTDyHT7});i#(rDW zV6}qkUN!QfbuWk$$M@H3wT)iC_oR!La@#!~uuxQG+1)TmMCfOSO4Lu)7EdsGEOVlR z;v~xoSX>oM<AwTvG8M=UkpnSOg@JkjM4Ib4ewWMaGO>WSYRr=&D04!B<+{b4h7@@W zh)K)@(HZx7!b>x8O4HObql?*$7wVJjFdgh*76hLz(=4w`VREh?#(WhV#@Q@Sqexr5 zoKFqg4xA3R?bNjGPRP1G>WjAht?T%iMJ&P_Vi^Tu7B^5#gGmjmC$I}x;TVOX7%KkA zTNf_=S?Ib2JFbA3u-#+|Q%@-H9heUM)|k%n@H@v0R*-zB!1sl;@CL?8^1XhgCrFlU ze0dE75`IW*I;7E(hng}eU0D_Anrc2wW2!MHamtD;WLoe7FR^iSXVR4XfNDvbeFr08 zD+o2{U}b`*GIqFv3!NpdB~XUsfSds;M$VOsRzmRGV9AO-hc?o14?M=*EKY;Y8wX^$ zjQ8jw-su{}xb#dJ(xKwfb4tk<@|=7mpUBrKrJycYISD4!yAc$I3!I5dwUC6c;C@<$ z8AS7@Wr7I*!(jzZ?*bx<m=1Mue~j%qxYQ_&=FOHQ=mP|$gTUUHbWoZWDjTjc1?Gzt za1b~i;wB30=w+tQBl#`x!$w_@+|+>Nn!ww7Sx@t}%|aI@sE~aR;FFQjOwT?lavG%f YOgSeLlo~Ix5qyc`E_2YdMYXj27gP{fy8r+H literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..78a01f4e64b43bd710d25cbfe6b36dea523ec97c GIT binary patch literal 769 zcmZ`#KabNe6u0x|n(L*dV!Gi5CZr-=5<ohs5<<6}1k33JMSzzmm$+@NPHb!^YV#TR z5{ztYY<!SRNJvP00R|>snox2`IP$aK`~AuDdo>yj5v-q|K181lguXRNe>sqx!&cuR zRFecHn4t_4jL~b9-?I=k)<YR!)O<VCY|*zUH{PJig_^-EVgvi6W0O7GU^cNkX5($L zgKR(sx4hr)*(P&Zw5PDxVKyYgTZ%7xg~g6qv{N|LB_rtM7&;k4-(OoMy+cMVBQaj0 zsr>`qil(?86q4QWG{1zq`)oeHdO?-oxuQ*;s&FB~m~lmu>7;gn%hGF4L{d=+qeS)5 z^GtB5FQnwMb^zaD^&q}V<29r8f!LkI6RGgRlI97Qo}}*zs<Z;5cpWXN@>=7^fV4lC zCYY0xzUW^HdC*7yZ&~P+Nvp9t?hF3dH82bzPh+0Y`cTu24)s>R^)kw6`z}*y`4P!6 znC!wY?F*Tfk*0nbNq@mvLZ$L&8-E$jN|{ypqs2|IT5YN-WV5sDl?-4lbARqb3#VzW zbi~+c5S*3U@?p^wce|U9A4l<u#yr=OGe72;h_olRweuw7Nx|q-42`J!5DYxQV|>>% PunXtd?sDUA-GTaVQ9#lr literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/controller.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/controller.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0802478932001c16a5a4570646d74a5d42aca531 GIT binary patch literal 7709 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 KBJdifTlqirx*Dzk literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..379424f8cb8a0f01875d55698de294e3101b4864 GIT binary patch literal 2188 zcmZ`)&2Aev5GJ`RX}z{pr@u~GB&<&nkXUXG0Su&t;~;5!aSu+BRu_U=Qr6n5U6ou( zmY|;O2eFR6^?CMM^pF?mp{LGpC0lhB3LJ7d<na53Gozn3H$wvL?>}bpuQfvc#E<3X z!^Z)1%RwljXhM3lMJf57D5ktiqCCwmyq2f@W74R+hh3yWi`wBh*Y?MsBK%%%9()`? zw}&7!X;DR5Oi?)RthIdQtI8#5Ra8~gV63V@t-)ARAE|Y<aY<W&+EjH|SyLh0xK(`e zN+wBLMrUv0M87k#-`7SCDIp<;cH9FkAC=2onrx6NE_tWVv-YWuaz5(DQJ0Tm*p+L| z^-!B}-i^}}ZnRW9PV<aQXR1BubhLTGC0H1Bb;|Ru%y|cH<+0^al35M=!6Mqy=Q<kX z8m@}w@L)af!Wr$1MOm8bG`BqKly*w%yP?y*1Pe0HP22_>7GP`MH`#d%7XTcv!GVT0 z$ry1u1SOmK@wZ(ENLtGW7S8u{udR(O5lF7GK^s6j6E@1g_+ud&JORFFuWxiGKIayA zTZbmia=cbXQLF$n@ELR4l`0#7FK%(}mc;Od7Y*kO`YY&m8$?bn$dm{=r6Adqf%FtP zCfD?+;Tzmq+!rezR0!}-vAtT==@$=IYZkt5c!h6u(kU414Hm1{#H_=O|BRb`6Axvs zn?q@uoh$*@+UEXw^F-_qO>dGu>zwX&yXTXMNcNw%yJipCN!ond?8p75aca>ePxtno z568oA2Ds?D80u7IrWwhotMR=}mNfCP=Fzy@9~XfTaT@1BY@vs$AP5a;l}^4|;e_4A z<_I0NXy{|?&c~m^WJ<0ePiORZmQ(OBy<m_h?8u<?1}nCNIMMk{bO}+^=HCs^1hA*@ zQ`yr7szK===OnX%n)RErLVN}b7Rv)!3+d$1YP@sHLPU^|Hx1`_lY{&NOeXayIVGo1 z49<dg5Dq@c*;#0ID8b*aBxS#lN$B=?OZvlQy`qlh8;B!h>hKr!my0ZVZA@m0YMG|j z)G;lYVGNY?>fm52I(<>@`Wh7WV-SQgT4!}yWsHV6`jeg2e3y^^k1{&TQRXl~GUju9 zE11zMHX}2rstU6M<S{Y08(yRagQ<Wh0&wO~CIfBomG5G&mY|=3Y92>bx>cJzSc%i| zJNj@KJpn5S@Cp(Y0}1Br%9}ET2$205F^^%a%;0sV5MCwNs&jndW8o|zS4Jkzb+NNL zJC~hhzJM#Q=K<)+US9Z0=JF0pgEiz^r0D*&=mz`(8nDUsDw>Gn!yFI5%zrpiMbDVw zQ>Ius9;5y)?-$Fw8{W}-%tec0Gi=N~5DF_hTHN@-+y}LJfC6cnFHyL#yNNyX2-aRh zw{;K%cx`z;o3nekirwuU4Je)=mJ-Zc$mdXqUZw^K&NqbkZ6K4mrY3~SA|cEs++psa zxJ8A&bugBo-QvR%gCXhg1=L>;D#1o@FIW!)gF2|+1&gz?hF8nKBd1tptq5L}2*1Np J;Jmlt{R?Pc8q@#) literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7e1c456143235174ac690712a61c14c6e4cae1b5 GIT binary patch literal 4747 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 Nd~f0Hh4TyN{|%WMQu6=+ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/serialize.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/serialize.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3c9c3422bb4bb61b99aaf02c0fc9aaad84b5d942 GIT binary patch literal 4260 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2d87dd6317c1c1804ead461edafd8bbc4299dc95 GIT binary patch literal 678 zcmYjPy^ho{5Vn)e&;G#z9S?w%;_yOo(w-1HSn6$9nr$Lq?Aru6iDi4kU6iekmS=z~ z>3ANuRJ;H}S251sNjuhj`o=Svd^5?X>2!p^{{Fh9-#vtWyWrR&2+qOv3jl@~7O2D< zj2-ucSNa<tc*Fu0e#M&s^FN{_{)3@7!S>mbW;tKhl~J{L$EY-1!S(P%k(oZVT4yno zKG+b5i<jW~JwS(LY|stb<1UmlgZE(<cDVC8zZ-Nx7cu-T+{YdI;W4j^Z#|59?muu4 zGgu{o9cNBR$_?FWJJMVgR1_^&c9`>>DzqswJIf9_1y^Y%sMhvL{}jCtJT1A&Yo^;M zH%6Wj(#DQxV2Q7MP^w^g$OdJ-t4uPq1I?j9&^J&6mk%6-4%|xZlpfY`c$IQf+vxu8 zCsL0fzS|M0iiR3a8mh=;Ef`mtEUw5lT{Nm}tJjyG=XrkBwy9X0UgT;HwynsT$U>eJ zl{Qp}lllC#xo%!TvqJWsHoRiBBE7i#p~)9TrR3_Rytb3&(N}Y_^>Y9;9^n{!$LB7L zCwSti8Dx`awO%<(0yTxW--jAI*00Ca^iv(dW4N>No3ds*!QZ-nMn46Bo&mx~=ih(u C*{OX1 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/_cmd.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/_cmd.py new file mode 100644 index 0000000..f1e0ad9 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/_cmd.py @@ -0,0 +1,57 @@ +import logging + +from pip._vendor import requests + +from pip._vendor.cachecontrol.adapter import CacheControlAdapter +from pip._vendor.cachecontrol.cache import DictCache +from pip._vendor.cachecontrol.controller import logger + +from argparse import ArgumentParser + + +def setup_logging(): + logger.setLevel(logging.DEBUG) + handler = logging.StreamHandler() + logger.addHandler(handler) + + +def get_session(): + adapter = CacheControlAdapter( + DictCache(), cache_etags=True, serializer=None, heuristic=None + ) + sess = requests.Session() + sess.mount("http://", adapter) + sess.mount("https://", adapter) + + sess.cache_controller = adapter.controller + return sess + + +def get_args(): + parser = ArgumentParser() + parser.add_argument("url", help="The URL to try and cache") + return parser.parse_args() + + +def main(args=None): + args = get_args() + sess = get_session() + + # Make a request to get a response + resp = sess.get(args.url) + + # Turn on logging + setup_logging() + + # try setting the cache + sess.cache_controller.cache_response(resp.request, resp.raw) + + # Now try to get it + if sess.cache_controller.cached_request(resp.request): + print("Cached!") + else: + print("Not cached :(") + + +if __name__ == "__main__": + main() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/adapter.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/adapter.py new file mode 100644 index 0000000..780eb28 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/adapter.py @@ -0,0 +1,133 @@ +import types +import functools +import zlib + +from pip._vendor.requests.adapters import HTTPAdapter + +from .controller import CacheController +from .cache import DictCache +from .filewrapper import CallbackFileWrapper + + +class CacheControlAdapter(HTTPAdapter): + invalidating_methods = {"PUT", "DELETE"} + + def __init__( + self, + cache=None, + cache_etags=True, + controller_class=None, + serializer=None, + heuristic=None, + cacheable_methods=None, + *args, + **kw + ): + super(CacheControlAdapter, self).__init__(*args, **kw) + self.cache = cache or DictCache() + self.heuristic = heuristic + self.cacheable_methods = cacheable_methods or ("GET",) + + controller_factory = controller_class or CacheController + self.controller = controller_factory( + self.cache, cache_etags=cache_etags, serializer=serializer + ) + + def send(self, request, cacheable_methods=None, **kw): + """ + Send a request. Use the request information to see if it + exists in the cache and cache the response if we need to and can. + """ + cacheable = cacheable_methods or self.cacheable_methods + if request.method in cacheable: + try: + cached_response = self.controller.cached_request(request) + except zlib.error: + cached_response = None + if cached_response: + return self.build_response(request, cached_response, from_cache=True) + + # check for etags and add headers if appropriate + request.headers.update(self.controller.conditional_headers(request)) + + resp = super(CacheControlAdapter, self).send(request, **kw) + + return resp + + def build_response( + self, request, response, from_cache=False, cacheable_methods=None + ): + """ + Build a response by making a request or using the cache. + + This will end up calling send and returning a potentially + cached response + """ + cacheable = cacheable_methods or self.cacheable_methods + if not from_cache and request.method in cacheable: + # Check for any heuristics that might update headers + # before trying to cache. + if self.heuristic: + response = self.heuristic.apply(response) + + # apply any expiration heuristics + if response.status == 304: + # We must have sent an ETag request. This could mean + # that we've been expired already or that we simply + # have an etag. In either case, we want to try and + # update the cache if that is the case. + cached_response = self.controller.update_cached_response( + request, response + ) + + if cached_response is not response: + from_cache = True + + # We are done with the server response, read a + # possible response body (compliant servers will + # not return one, but we cannot be 100% sure) and + # release the connection back to the pool. + response.read(decode_content=False) + response.release_conn() + + response = cached_response + + # We always cache the 301 responses + elif response.status == 301: + self.controller.cache_response(request, response) + else: + # Wrap the response file with a wrapper that will cache the + # response when the stream has been consumed. + response._fp = CallbackFileWrapper( + response._fp, + functools.partial( + self.controller.cache_response, request, response + ), + ) + if response.chunked: + super_update_chunk_length = response._update_chunk_length + + def _update_chunk_length(self): + super_update_chunk_length() + if self.chunk_left == 0: + self._fp._close() + + response._update_chunk_length = types.MethodType( + _update_chunk_length, response + ) + + resp = super(CacheControlAdapter, self).build_response(request, response) + + # See if we should invalidate the cache. + if request.method in self.invalidating_methods and resp.ok: + cache_url = self.controller.cache_url(request.url) + self.cache.delete(cache_url) + + # Give the request a from_cache attr to let people use it + resp.from_cache = from_cache + + return resp + + def close(self): + self.cache.close() + super(CacheControlAdapter, self).close() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/cache.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/cache.py new file mode 100644 index 0000000..94e0773 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/cache.py @@ -0,0 +1,39 @@ +""" +The cache object API for implementing caches. The default is a thread +safe in-memory dictionary. +""" +from threading import Lock + + +class BaseCache(object): + + def get(self, key): + raise NotImplementedError() + + def set(self, key, value): + raise NotImplementedError() + + def delete(self, key): + raise NotImplementedError() + + def close(self): + pass + + +class DictCache(BaseCache): + + def __init__(self, init_dict=None): + self.lock = Lock() + self.data = init_dict or {} + + def get(self, key): + return self.data.get(key, None) + + def set(self, key, value): + with self.lock: + self.data.update({key: value}) + + def delete(self, key): + with self.lock: + if key in self.data: + self.data.pop(key) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/__init__.py new file mode 100644 index 0000000..0e1658f --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/__init__.py @@ -0,0 +1,2 @@ +from .file_cache import FileCache # noqa +from .redis_cache import RedisCache # noqa diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..749b2b16b79d2a1fcda7fdcb0d7d128008300ac2 GIT binary patch literal 306 zcmYjMJ5Izf5VeyPg23K@3#3>aC{~Ju5E2q41;1h&%f!yc$g!hw*4mB4VJPW1Pg*K2 zKtaVgQ1GPry!S?<nTPp2BZ#l}SMiATBa;6}kX&N;V@#4rYDi00l*T?WNt>=x?9)4v z&ps)R<a9i^)<#{4s!>R?TP3xh*iAkgvl=~KMHAxc@erc_r=+O75!k~rrSBKkfexZq zEC^t=Gg5(P<(92^8K52PS^Zoz&2|{LDVI+T6o|ED_pH<1LR;SpV-`iR47+f;iQ*JI nC@USX>5j_T9-R3lo^h_N?m0i{cH{ne>*U6$i};z3_a4z7IBrzv literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..140a13ed5ae2c254384734424202bc51786bc96a GIT binary patch literal 3304 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4b74f697deb075ee785854ae1389d1d64398cd35 GIT binary patch literal 1578 zcmZ`(!H(ND5G6%P);jiPg9Jf(Nm!s40gbiIA;<zjQX~c1TztqTKw+Q|6p>yll_iIy zoLxf!3S>WIecW5WN7tVE13mQA8Op*ci<AJxA%~-x_hyD~$KxS^@z0;z<X1+>U%2TH z7dAh_)KB0eh@d%H(ix>FJGrxTW{#Cv&X(@XrQ~NKT;ZJ);Ys&1n|Z=NCgI?3uqGjG z0+FpVot1@^6C+KwlpycDNVI&Jqzjqi&HjL>+6bP3AjymhGIInK&N-Pe!GsH|EB1vi z2Imy~1!50Qd@&R^U>%5&7{eL}58}Al3|~u;>DH6ebAvL@moPO_Qq!8mfby7J(kVpf zre#rtPUC8s&(#2KToSbh%fEj_E0wJQOSDc@G%s@@m5z>1qm%e(t(KeO(fs}4VsX0J z#QD+VcMEk0<D`h*M5}D|Fe|i4^8Df9;p6q$`iBY+?Tpv55T%Mz%Su@oRp#wRM+!m2 zRx??hH9;I_MP}j{<Ixrt-Q2!HI_dQ3b;wArg**bGChy4wt?8B?6XnA}=vbf)JCWwn zQ2`t^?00!)akn3&N}(~%&h>uJHJDCQtfFq9j6b(-pMp>`eW!C>J6ouy;=7s|=Ynm? zJ@ScJom*4m)$GFGlFt-wF|4{S%)u^9Esa7%jbE9xC_gqHoXFFLWrb<RrUas6Eg_LY zhpvUA_VK#6PV!1N19`g2l+@SZ-Gn<hH4;FmOAnk8-Sk0%oByZw0E{|(TiZEZ+&g-G zA#;dRjp5>T-*@2*XGiU=9<{AmN<rNX%r6pb$>kulj<@6|^4q~DC~3&BgBhme!%#q; zLud2q7n!f5;`37RG?$6WiW3ec$<0D?$hPKL!4obLle~j2o$$9>@{gHW4Eb)PNoAm? zznzAx&4i0)3giA7sK&Eyz5%timBIGu=AZ}6s=vU67;#!$XtRs`xwYbzmYQRO$`k|P ztFp`i#rM1@c_F3XrUYmu#EqD)E>5PF?~t~|fbDZt))*$3Jb=TNedk(`pbX({*u(xS zlBJB}W*EoIQdBw0qd5LhC3&k+H}K!sBnnHZ<>nqrNJB5{HU`^O9w_jg(P$Mo0Snl0 z0AF9BW*YkFZC;s5fj5Pjx5YoZ4=>1M_j*jy-s{nB6w+sZ@inha@U#W+4C&U`s3WNM G5&I9lURpK) literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py new file mode 100644 index 0000000..1ba0080 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py @@ -0,0 +1,146 @@ +import hashlib +import os +from textwrap import dedent + +from ..cache import BaseCache +from ..controller import CacheController + +try: + FileNotFoundError +except NameError: + # py2.X + FileNotFoundError = (IOError, OSError) + + +def _secure_open_write(filename, fmode): + # We only want to write to this file, so open it in write only mode + flags = os.O_WRONLY + + # os.O_CREAT | os.O_EXCL will fail if the file already exists, so we only + # will open *new* files. + # We specify this because we want to ensure that the mode we pass is the + # mode of the file. + flags |= os.O_CREAT | os.O_EXCL + + # Do not follow symlinks to prevent someone from making a symlink that + # we follow and insecurely open a cache file. + if hasattr(os, "O_NOFOLLOW"): + flags |= os.O_NOFOLLOW + + # On Windows we'll mark this file as binary + if hasattr(os, "O_BINARY"): + flags |= os.O_BINARY + + # Before we open our file, we want to delete any existing file that is + # there + try: + os.remove(filename) + except (IOError, OSError): + # The file must not exist already, so we can just skip ahead to opening + pass + + # Open our file, the use of os.O_CREAT | os.O_EXCL will ensure that if a + # race condition happens between the os.remove and this line, that an + # error will be raised. Because we utilize a lockfile this should only + # happen if someone is attempting to attack us. + fd = os.open(filename, flags, fmode) + try: + return os.fdopen(fd, "wb") + + except: + # An error occurred wrapping our FD in a file object + os.close(fd) + raise + + +class FileCache(BaseCache): + + def __init__( + self, + directory, + forever=False, + filemode=0o0600, + dirmode=0o0700, + use_dir_lock=None, + lock_class=None, + ): + + if use_dir_lock is not None and lock_class is not None: + raise ValueError("Cannot use use_dir_lock and lock_class together") + + try: + from pip._vendor.lockfile import LockFile + from pip._vendor.lockfile.mkdirlockfile import MkdirLockFile + except ImportError: + notice = dedent( + """ + NOTE: In order to use the FileCache you must have + lockfile installed. You can install it via pip: + pip install lockfile + """ + ) + raise ImportError(notice) + + else: + if use_dir_lock: + lock_class = MkdirLockFile + + elif lock_class is None: + lock_class = LockFile + + self.directory = directory + self.forever = forever + self.filemode = filemode + self.dirmode = dirmode + self.lock_class = lock_class + + @staticmethod + def encode(x): + return hashlib.sha224(x.encode()).hexdigest() + + def _fn(self, name): + # NOTE: This method should not change as some may depend on it. + # See: https://github.com/ionrock/cachecontrol/issues/63 + hashed = self.encode(name) + parts = list(hashed[:5]) + [hashed] + return os.path.join(self.directory, *parts) + + def get(self, key): + name = self._fn(key) + try: + with open(name, "rb") as fh: + return fh.read() + + except FileNotFoundError: + return None + + def set(self, key, value): + name = self._fn(key) + + # Make sure the directory exists + try: + os.makedirs(os.path.dirname(name), self.dirmode) + except (IOError, OSError): + pass + + with self.lock_class(name) as lock: + # Write our actual file + with _secure_open_write(lock.path, self.filemode) as fh: + fh.write(value) + + def delete(self, key): + name = self._fn(key) + if not self.forever: + try: + os.remove(name) + except FileNotFoundError: + pass + + +def url_to_file_path(url, filecache): + """Return the file cache path based on the URL. + + This does not ensure the file exists! + """ + key = CacheController.cache_url(url) + return filecache._fn(key) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py new file mode 100644 index 0000000..ed705ce --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py @@ -0,0 +1,33 @@ +from __future__ import division + +from datetime import datetime +from pip._vendor.cachecontrol.cache import BaseCache + + +class RedisCache(BaseCache): + + def __init__(self, conn): + self.conn = conn + + def get(self, key): + return self.conn.get(key) + + def set(self, key, value, expires=None): + if not expires: + self.conn.set(key, value) + else: + expires = expires - datetime.utcnow() + self.conn.setex(key, int(expires.total_seconds()), value) + + def delete(self, key): + self.conn.delete(key) + + def clear(self): + """Helper for clearing all the keys in a database. Use with + caution!""" + for key in self.conn.keys(): + self.conn.delete(key) + + def close(self): + """Redis uses connection pooling, no need to close the connection.""" + pass diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/compat.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/compat.py new file mode 100644 index 0000000..33b5aed --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/compat.py @@ -0,0 +1,29 @@ +try: + from urllib.parse import urljoin +except ImportError: + from urlparse import urljoin + + +try: + import cPickle as pickle +except ImportError: + import pickle + + +# Handle the case where the requests module has been patched to not have +# urllib3 bundled as part of its source. +try: + from pip._vendor.requests.packages.urllib3.response import HTTPResponse +except ImportError: + from pip._vendor.urllib3.response import HTTPResponse + +try: + from pip._vendor.requests.packages.urllib3.util import is_fp_closed +except ImportError: + from pip._vendor.urllib3.util import is_fp_closed + +# Replicate some six behaviour +try: + text_type = unicode +except NameError: + text_type = str diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/controller.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/controller.py new file mode 100644 index 0000000..1b2b943 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/controller.py @@ -0,0 +1,367 @@ +""" +The httplib2 algorithms ported for use with requests. +""" +import logging +import re +import calendar +import time +from email.utils import parsedate_tz + +from pip._vendor.requests.structures import CaseInsensitiveDict + +from .cache import DictCache +from .serialize import Serializer + + +logger = logging.getLogger(__name__) + +URI = re.compile(r"^(([^:/?#]+):)?(//([^/?#]*))?([^?#]*)(\?([^#]*))?(#(.*))?") + + +def parse_uri(uri): + """Parses a URI using the regex given in Appendix B of RFC 3986. + + (scheme, authority, path, query, fragment) = parse_uri(uri) + """ + groups = URI.match(uri).groups() + return (groups[1], groups[3], groups[4], groups[6], groups[8]) + + +class CacheController(object): + """An interface to see if request should cached or not. + """ + + def __init__( + self, cache=None, cache_etags=True, serializer=None, status_codes=None + ): + self.cache = cache or DictCache() + self.cache_etags = cache_etags + self.serializer = serializer or Serializer() + self.cacheable_status_codes = status_codes or (200, 203, 300, 301) + + @classmethod + def _urlnorm(cls, uri): + """Normalize the URL to create a safe key for the cache""" + (scheme, authority, path, query, fragment) = parse_uri(uri) + if not scheme or not authority: + raise Exception("Only absolute URIs are allowed. uri = %s" % uri) + + scheme = scheme.lower() + authority = authority.lower() + + if not path: + path = "/" + + # Could do syntax based normalization of the URI before + # computing the digest. See Section 6.2.2 of Std 66. + request_uri = query and "?".join([path, query]) or path + defrag_uri = scheme + "://" + authority + request_uri + + return defrag_uri + + @classmethod + def cache_url(cls, uri): + return cls._urlnorm(uri) + + def parse_cache_control(self, headers): + known_directives = { + # https://tools.ietf.org/html/rfc7234#section-5.2 + "max-age": (int, True), + "max-stale": (int, False), + "min-fresh": (int, True), + "no-cache": (None, False), + "no-store": (None, False), + "no-transform": (None, False), + "only-if-cached": (None, False), + "must-revalidate": (None, False), + "public": (None, False), + "private": (None, False), + "proxy-revalidate": (None, False), + "s-maxage": (int, True), + } + + cc_headers = headers.get("cache-control", headers.get("Cache-Control", "")) + + retval = {} + + for cc_directive in cc_headers.split(","): + if not cc_directive.strip(): + continue + + parts = cc_directive.split("=", 1) + directive = parts[0].strip() + + try: + typ, required = known_directives[directive] + except KeyError: + logger.debug("Ignoring unknown cache-control directive: %s", directive) + continue + + if not typ or not required: + retval[directive] = None + if typ: + try: + retval[directive] = typ(parts[1].strip()) + except IndexError: + if required: + logger.debug( + "Missing value for cache-control " "directive: %s", + directive, + ) + except ValueError: + logger.debug( + "Invalid value for cache-control directive " "%s, must be %s", + directive, + typ.__name__, + ) + + return retval + + def cached_request(self, request): + """ + Return a cached response if it exists in the cache, otherwise + return False. + """ + cache_url = self.cache_url(request.url) + logger.debug('Looking up "%s" in the cache', cache_url) + cc = self.parse_cache_control(request.headers) + + # Bail out if the request insists on fresh data + if "no-cache" in cc: + logger.debug('Request header has "no-cache", cache bypassed') + return False + + if "max-age" in cc and cc["max-age"] == 0: + logger.debug('Request header has "max_age" as 0, cache bypassed') + return False + + # Request allows serving from the cache, let's see if we find something + cache_data = self.cache.get(cache_url) + if cache_data is None: + logger.debug("No cache entry available") + return False + + # Check whether it can be deserialized + resp = self.serializer.loads(request, cache_data) + if not resp: + logger.warning("Cache entry deserialization failed, entry ignored") + return False + + # If we have a cached 301, return it immediately. We don't + # need to test our response for other headers b/c it is + # intrinsically "cacheable" as it is Permanent. + # See: + # https://tools.ietf.org/html/rfc7231#section-6.4.2 + # + # Client can try to refresh the value by repeating the request + # with cache busting headers as usual (ie no-cache). + if resp.status == 301: + msg = ( + 'Returning cached "301 Moved Permanently" response ' + "(ignoring date and etag information)" + ) + logger.debug(msg) + return resp + + headers = CaseInsensitiveDict(resp.headers) + if not headers or "date" not in headers: + if "etag" not in headers: + # Without date or etag, the cached response can never be used + # and should be deleted. + logger.debug("Purging cached response: no date or etag") + self.cache.delete(cache_url) + logger.debug("Ignoring cached response: no date") + return False + + now = time.time() + date = calendar.timegm(parsedate_tz(headers["date"])) + current_age = max(0, now - date) + logger.debug("Current age based on date: %i", current_age) + + # TODO: There is an assumption that the result will be a + # urllib3 response object. This may not be best since we + # could probably avoid instantiating or constructing the + # response until we know we need it. + resp_cc = self.parse_cache_control(headers) + + # determine freshness + freshness_lifetime = 0 + + # Check the max-age pragma in the cache control header + if "max-age" in resp_cc: + freshness_lifetime = resp_cc["max-age"] + logger.debug("Freshness lifetime from max-age: %i", freshness_lifetime) + + # If there isn't a max-age, check for an expires header + elif "expires" in headers: + expires = parsedate_tz(headers["expires"]) + if expires is not None: + expire_time = calendar.timegm(expires) - date + freshness_lifetime = max(0, expire_time) + logger.debug("Freshness lifetime from expires: %i", freshness_lifetime) + + # Determine if we are setting freshness limit in the + # request. Note, this overrides what was in the response. + if "max-age" in cc: + freshness_lifetime = cc["max-age"] + logger.debug( + "Freshness lifetime from request max-age: %i", freshness_lifetime + ) + + if "min-fresh" in cc: + min_fresh = cc["min-fresh"] + # adjust our current age by our min fresh + current_age += min_fresh + logger.debug("Adjusted current age from min-fresh: %i", current_age) + + # Return entry if it is fresh enough + if freshness_lifetime > current_age: + logger.debug('The response is "fresh", returning cached response') + logger.debug("%i > %i", freshness_lifetime, current_age) + return resp + + # we're not fresh. If we don't have an Etag, clear it out + if "etag" not in headers: + logger.debug('The cached response is "stale" with no etag, purging') + self.cache.delete(cache_url) + + # return the original handler + return False + + def conditional_headers(self, request): + cache_url = self.cache_url(request.url) + resp = self.serializer.loads(request, self.cache.get(cache_url)) + new_headers = {} + + if resp: + headers = CaseInsensitiveDict(resp.headers) + + if "etag" in headers: + new_headers["If-None-Match"] = headers["ETag"] + + if "last-modified" in headers: + new_headers["If-Modified-Since"] = headers["Last-Modified"] + + return new_headers + + def cache_response(self, request, response, body=None, status_codes=None): + """ + Algorithm for caching requests. + + This assumes a requests Response object. + """ + # From httplib2: Don't cache 206's since we aren't going to + # handle byte range requests + cacheable_status_codes = status_codes or self.cacheable_status_codes + if response.status not in cacheable_status_codes: + logger.debug( + "Status code %s not in %s", response.status, cacheable_status_codes + ) + return + + response_headers = CaseInsensitiveDict(response.headers) + + # If we've been given a body, our response has a Content-Length, that + # Content-Length is valid then we can check to see if the body we've + # been given matches the expected size, and if it doesn't we'll just + # skip trying to cache it. + if ( + body is not None + and "content-length" in response_headers + and response_headers["content-length"].isdigit() + and int(response_headers["content-length"]) != len(body) + ): + return + + cc_req = self.parse_cache_control(request.headers) + cc = self.parse_cache_control(response_headers) + + cache_url = self.cache_url(request.url) + logger.debug('Updating cache with response from "%s"', cache_url) + + # Delete it from the cache if we happen to have it stored there + no_store = False + if "no-store" in cc: + no_store = True + logger.debug('Response header has "no-store"') + if "no-store" in cc_req: + no_store = True + logger.debug('Request header has "no-store"') + if no_store and self.cache.get(cache_url): + logger.debug('Purging existing cache entry to honor "no-store"') + self.cache.delete(cache_url) + if no_store: + return + + # If we've been given an etag, then keep the response + if self.cache_etags and "etag" in response_headers: + logger.debug("Caching due to etag") + self.cache.set( + cache_url, self.serializer.dumps(request, response, body=body) + ) + + # Add to the cache any 301s. We do this before looking that + # the Date headers. + elif response.status == 301: + logger.debug("Caching permanant redirect") + self.cache.set(cache_url, self.serializer.dumps(request, response)) + + # Add to the cache if the response headers demand it. If there + # is no date header then we can't do anything about expiring + # the cache. + elif "date" in response_headers: + # cache when there is a max-age > 0 + if "max-age" in cc and cc["max-age"] > 0: + logger.debug("Caching b/c date exists and max-age > 0") + self.cache.set( + cache_url, self.serializer.dumps(request, response, body=body) + ) + + # If the request can expire, it means we should cache it + # in the meantime. + elif "expires" in response_headers: + if response_headers["expires"]: + logger.debug("Caching b/c of expires header") + self.cache.set( + cache_url, self.serializer.dumps(request, response, body=body) + ) + + def update_cached_response(self, request, response): + """On a 304 we will get a new set of headers that we want to + update our cached value with, assuming we have one. + + This should only ever be called when we've sent an ETag and + gotten a 304 as the response. + """ + cache_url = self.cache_url(request.url) + + cached_response = self.serializer.loads(request, self.cache.get(cache_url)) + + if not cached_response: + # we didn't have a cached response + return response + + # Lets update our headers with the headers from the new request: + # http://tools.ietf.org/html/draft-ietf-httpbis-p4-conditional-26#section-4.1 + # + # The server isn't supposed to send headers that would make + # the cached body invalid. But... just in case, we'll be sure + # to strip out ones we know that might be problmatic due to + # typical assumptions. + excluded_headers = ["content-length"] + + cached_response.headers.update( + dict( + (k, v) + for k, v in response.headers.items() + if k.lower() not in excluded_headers + ) + ) + + # we want a 200 b/c we have content via the cache + cached_response.status = 200 + + # update our cache + self.cache.set(cache_url, self.serializer.dumps(request, cached_response)) + + return cached_response diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/filewrapper.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/filewrapper.py new file mode 100644 index 0000000..30ed4c5 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/filewrapper.py @@ -0,0 +1,80 @@ +from io import BytesIO + + +class CallbackFileWrapper(object): + """ + Small wrapper around a fp object which will tee everything read into a + buffer, and when that file is closed it will execute a callback with the + contents of that buffer. + + All attributes are proxied to the underlying file object. + + This class uses members with a double underscore (__) leading prefix so as + not to accidentally shadow an attribute. + """ + + def __init__(self, fp, callback): + self.__buf = BytesIO() + self.__fp = fp + self.__callback = callback + + def __getattr__(self, name): + # The vaguaries of garbage collection means that self.__fp is + # not always set. By using __getattribute__ and the private + # name[0] allows looking up the attribute value and raising an + # AttributeError when it doesn't exist. This stop thigns from + # infinitely recursing calls to getattr in the case where + # self.__fp hasn't been set. + # + # [0] https://docs.python.org/2/reference/expressions.html#atom-identifiers + fp = self.__getattribute__("_CallbackFileWrapper__fp") + return getattr(fp, name) + + def __is_fp_closed(self): + try: + return self.__fp.fp is None + + except AttributeError: + pass + + try: + return self.__fp.closed + + except AttributeError: + pass + + # We just don't cache it then. + # TODO: Add some logging here... + return False + + def _close(self): + if self.__callback: + self.__callback(self.__buf.getvalue()) + + # We assign this to None here, because otherwise we can get into + # really tricky problems where the CPython interpreter dead locks + # because the callback is holding a reference to something which + # has a __del__ method. Setting this to None breaks the cycle + # and allows the garbage collector to do it's thing normally. + self.__callback = None + + def read(self, amt=None): + data = self.__fp.read(amt) + self.__buf.write(data) + if self.__is_fp_closed(): + self._close() + + return data + + def _safe_read(self, amt): + data = self.__fp._safe_read(amt) + if amt == 2 and data == b"\r\n": + # urllib executes this read to toss the CRLF at the end + # of the chunk. + return data + + self.__buf.write(data) + if self.__is_fp_closed(): + self._close() + + return data diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/heuristics.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/heuristics.py new file mode 100644 index 0000000..6c0e979 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/heuristics.py @@ -0,0 +1,135 @@ +import calendar +import time + +from email.utils import formatdate, parsedate, parsedate_tz + +from datetime import datetime, timedelta + +TIME_FMT = "%a, %d %b %Y %H:%M:%S GMT" + + +def expire_after(delta, date=None): + date = date or datetime.utcnow() + return date + delta + + +def datetime_to_header(dt): + return formatdate(calendar.timegm(dt.timetuple())) + + +class BaseHeuristic(object): + + def warning(self, response): + """ + Return a valid 1xx warning header value describing the cache + adjustments. + + The response is provided too allow warnings like 113 + http://tools.ietf.org/html/rfc7234#section-5.5.4 where we need + to explicitly say response is over 24 hours old. + """ + return '110 - "Response is Stale"' + + def update_headers(self, response): + """Update the response headers with any new headers. + + NOTE: This SHOULD always include some Warning header to + signify that the response was cached by the client, not + by way of the provided headers. + """ + return {} + + def apply(self, response): + updated_headers = self.update_headers(response) + + if updated_headers: + response.headers.update(updated_headers) + warning_header_value = self.warning(response) + if warning_header_value is not None: + response.headers.update({"Warning": warning_header_value}) + + return response + + +class OneDayCache(BaseHeuristic): + """ + Cache the response by providing an expires 1 day in the + future. + """ + + def update_headers(self, response): + headers = {} + + if "expires" not in response.headers: + date = parsedate(response.headers["date"]) + expires = expire_after(timedelta(days=1), date=datetime(*date[:6])) + headers["expires"] = datetime_to_header(expires) + headers["cache-control"] = "public" + return headers + + +class ExpiresAfter(BaseHeuristic): + """ + Cache **all** requests for a defined time period. + """ + + def __init__(self, **kw): + self.delta = timedelta(**kw) + + def update_headers(self, response): + expires = expire_after(self.delta) + return {"expires": datetime_to_header(expires), "cache-control": "public"} + + def warning(self, response): + tmpl = "110 - Automatically cached for %s. Response might be stale" + return tmpl % self.delta + + +class LastModified(BaseHeuristic): + """ + If there is no Expires header already, fall back on Last-Modified + using the heuristic from + http://tools.ietf.org/html/rfc7234#section-4.2.2 + to calculate a reasonable value. + + Firefox also does something like this per + https://developer.mozilla.org/en-US/docs/Web/HTTP/Caching_FAQ + http://lxr.mozilla.org/mozilla-release/source/netwerk/protocol/http/nsHttpResponseHead.cpp#397 + Unlike mozilla we limit this to 24-hr. + """ + cacheable_by_default_statuses = { + 200, 203, 204, 206, 300, 301, 404, 405, 410, 414, 501 + } + + def update_headers(self, resp): + headers = resp.headers + + if "expires" in headers: + return {} + + if "cache-control" in headers and headers["cache-control"] != "public": + return {} + + if resp.status not in self.cacheable_by_default_statuses: + return {} + + if "date" not in headers or "last-modified" not in headers: + return {} + + date = calendar.timegm(parsedate_tz(headers["date"])) + last_modified = parsedate(headers["last-modified"]) + if date is None or last_modified is None: + return {} + + now = time.time() + current_age = max(0, now - date) + delta = date - calendar.timegm(last_modified) + freshness_lifetime = max(0, min(delta / 10, 24 * 3600)) + if freshness_lifetime <= current_age: + return {} + + expires = date + freshness_lifetime + return {"expires": time.strftime(TIME_FMT, time.gmtime(expires))} + + def warning(self, resp): + return None diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/serialize.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/serialize.py new file mode 100644 index 0000000..ec43ff2 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/serialize.py @@ -0,0 +1,186 @@ +import base64 +import io +import json +import zlib + +from pip._vendor import msgpack +from pip._vendor.requests.structures import CaseInsensitiveDict + +from .compat import HTTPResponse, pickle, text_type + + +def _b64_decode_bytes(b): + return base64.b64decode(b.encode("ascii")) + + +def _b64_decode_str(s): + return _b64_decode_bytes(s).decode("utf8") + + +class Serializer(object): + + def dumps(self, request, response, body=None): + response_headers = CaseInsensitiveDict(response.headers) + + if body is None: + body = response.read(decode_content=False) + + # NOTE: 99% sure this is dead code. I'm only leaving it + # here b/c I don't have a test yet to prove + # it. Basically, before using + # `cachecontrol.filewrapper.CallbackFileWrapper`, + # this made an effort to reset the file handle. The + # `CallbackFileWrapper` short circuits this code by + # setting the body as the content is consumed, the + # result being a `body` argument is *always* passed + # into cache_response, and in turn, + # `Serializer.dump`. + response._fp = io.BytesIO(body) + + # NOTE: This is all a bit weird, but it's really important that on + # Python 2.x these objects are unicode and not str, even when + # they contain only ascii. The problem here is that msgpack + # understands the difference between unicode and bytes and we + # have it set to differentiate between them, however Python 2 + # doesn't know the difference. Forcing these to unicode will be + # enough to have msgpack know the difference. + data = { + u"response": { + u"body": body, + u"headers": dict( + (text_type(k), text_type(v)) for k, v in response.headers.items() + ), + u"status": response.status, + u"version": response.version, + u"reason": text_type(response.reason), + u"strict": response.strict, + u"decode_content": response.decode_content, + } + } + + # Construct our vary headers + data[u"vary"] = {} + if u"vary" in response_headers: + varied_headers = response_headers[u"vary"].split(",") + for header in varied_headers: + header = text_type(header).strip() + header_value = request.headers.get(header, None) + if header_value is not None: + header_value = text_type(header_value) + data[u"vary"][header] = header_value + + return b",".join([b"cc=4", msgpack.dumps(data, use_bin_type=True)]) + + def loads(self, request, data): + # Short circuit if we've been given an empty set of data + if not data: + return + + # Determine what version of the serializer the data was serialized + # with + try: + ver, data = data.split(b",", 1) + except ValueError: + ver = b"cc=0" + + # Make sure that our "ver" is actually a version and isn't a false + # positive from a , being in the data stream. + if ver[:3] != b"cc=": + data = ver + data + ver = b"cc=0" + + # Get the version number out of the cc=N + ver = ver.split(b"=", 1)[-1].decode("ascii") + + # Dispatch to the actual load method for the given version + try: + return getattr(self, "_loads_v{}".format(ver))(request, data) + + except AttributeError: + # This is a version we don't have a loads function for, so we'll + # just treat it as a miss and return None + return + + def prepare_response(self, request, cached): + """Verify our vary headers match and construct a real urllib3 + HTTPResponse object. + """ + # Special case the '*' Vary value as it means we cannot actually + # determine if the cached response is suitable for this request. + if "*" in cached.get("vary", {}): + return + + # Ensure that the Vary headers for the cached response match our + # request + for header, value in cached.get("vary", {}).items(): + if request.headers.get(header, None) != value: + return + + body_raw = cached["response"].pop("body") + + headers = CaseInsensitiveDict(data=cached["response"]["headers"]) + if headers.get("transfer-encoding", "") == "chunked": + headers.pop("transfer-encoding") + + cached["response"]["headers"] = headers + + try: + body = io.BytesIO(body_raw) + except TypeError: + # This can happen if cachecontrol serialized to v1 format (pickle) + # using Python 2. A Python 2 str(byte string) will be unpickled as + # a Python 3 str (unicode string), which will cause the above to + # fail with: + # + # TypeError: 'str' does not support the buffer interface + body = io.BytesIO(body_raw.encode("utf8")) + + return HTTPResponse(body=body, preload_content=False, **cached["response"]) + + def _loads_v0(self, request, data): + # The original legacy cache data. This doesn't contain enough + # information to construct everything we need, so we'll treat this as + # a miss. + return + + def _loads_v1(self, request, data): + try: + cached = pickle.loads(data) + except ValueError: + return + + return self.prepare_response(request, cached) + + def _loads_v2(self, request, data): + try: + cached = json.loads(zlib.decompress(data).decode("utf8")) + except (ValueError, zlib.error): + return + + # We need to decode the items that we've base64 encoded + cached["response"]["body"] = _b64_decode_bytes(cached["response"]["body"]) + cached["response"]["headers"] = dict( + (_b64_decode_str(k), _b64_decode_str(v)) + for k, v in cached["response"]["headers"].items() + ) + cached["response"]["reason"] = _b64_decode_str(cached["response"]["reason"]) + cached["vary"] = dict( + (_b64_decode_str(k), _b64_decode_str(v) if v is not None else v) + for k, v in cached["vary"].items() + ) + + return self.prepare_response(request, cached) + + def _loads_v3(self, request, data): + # Due to Python 2 encoding issues, it's impossible to know for sure + # exactly how to load v3 entries, thus we'll treat these as a miss so + # that they get rewritten out as v4 entries. + return + + def _loads_v4(self, request, data): + try: + cached = msgpack.loads(data, encoding="utf-8") + except ValueError: + return + + return self.prepare_response(request, cached) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/wrapper.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/wrapper.py new file mode 100644 index 0000000..265bfc8 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/cachecontrol/wrapper.py @@ -0,0 +1,29 @@ +from .adapter import CacheControlAdapter +from .cache import DictCache + + +def CacheControl( + sess, + cache=None, + cache_etags=True, + serializer=None, + heuristic=None, + controller_class=None, + adapter_class=None, + cacheable_methods=None, +): + + cache = cache or DictCache() + adapter_class = adapter_class or CacheControlAdapter + adapter = adapter_class( + cache, + cache_etags=cache_etags, + serializer=serializer, + heuristic=heuristic, + controller_class=controller_class, + cacheable_methods=cacheable_methods, + ) + sess.mount("http://", adapter) + sess.mount("https://", adapter) + + return sess diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__init__.py new file mode 100644 index 0000000..8ccb14e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__init__.py @@ -0,0 +1,3 @@ +from .core import where + +__version__ = "2019.06.16" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__main__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__main__.py new file mode 100644 index 0000000..ae2aff5 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__main__.py @@ -0,0 +1,2 @@ +from pip._vendor.certifi import where +print(where()) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5fc0765842a4b6012925fa70f819e4f02a33a2d4 GIT binary patch literal 269 zcmYjLu};G<5Vg}*LZ#jKi42XMs)`f|A-;eGSh}1-?KDP?6E3M~^EZrad{0&;et?0g z=T1E7z0-Sly1VD)a?S|9UmwMW>US{z5s|qkb~hx7DQ;QKx12K-Z6h^#WbyQeQ!D1< z?7h;chxuBjc_OnU%^u>(INdd<F{~M{0ldb}G!EdC;f%72{Jn`5jW2pFe1W2DtfDcI zAH^PWkM-cz<*Tf!<1m2DvzH1bVeiC~Xid8^uImeHS5jvF<kLe4FQjWuH7Ir(ds7+# ZV4UdzlJ+!S-PVmdSbZ0s@4|bF=nT<DNPPeR literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__pycache__/__main__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__pycache__/__main__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2fe5bb54789670247e6a42645e985122646aee29 GIT binary patch literal 272 zcmWIL<>g`kf^QoZCYl22#~=<eU;=U+fVfx+NTe{NFy=7iGDa~nGNdx4GBz_b16e6d z!3>(rFM;w5nvAzt%QI4oQvEcUZwVJ<7U;#7rRJsN7wILZ7L{bCWfp<VyTw{il$lqu zlA(wd$O99<3iW|vWr-!J`elhl`f2$&DXB%p`j!>?>G76jMY&aZMrm0F85tE-Rq;8N zW=R=E20)OWryrsZv_&^Fuec;JCr8)7z^tsY%&-(B2*yzB^`X}5$H(U;X6D7m>lIYq W;;_lhPbtkwwPOUjq8Q{b9!3ClxJr%y literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8c4a486a5afe6b3956857d0794be64ede7bd153c GIT binary patch literal 485 zcmYjOyH3L}6t$g{mZ;qkQ`QWv14E@s2qCd|p<TLIA$A&9NgO$DXd__aL+HrH_jqOE z2N;;J(*ixxIlkAHj_+eW7<j<o>wOn#bAH(57|0|yhSix73KoDuiZZx>)S>PRSRjh- zK+tLCUd*K82_KbP@A(g&H%oct=Yp;?=1Zp5vZ#EOGM^Wfin1(HToisL;(Z_zKaQ-^ zsAT!b`!t_|X>9cu&;+jGtzmU;M1d82MatR1r+w@`nj&|$EHrJrf4iWgk*Ks=Mk>`^ z%4HGdO!o*$c*Y3P?n>|?fEp%mK=zFDcaBTR>qs$NM-nF@qfAzKvcXF-sb$_2m&qzj z(@oQmY%;!2WoWQ0@C=u{93DCxhT*v0))#Ag*^<<(phDuq#BeMmGh@@8hm=Xyw~g5j p0qi4bw-Y$JO9&M)A=2)ny=*Hyl2h}bdsq8OUpppiP27{7^8+|yf++w1 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/cacert.pem b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/cacert.pem new file mode 100644 index 0000000..9ca290f --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/cacert.pem @@ -0,0 +1,4618 @@ + +# Issuer: CN=GlobalSign Root CA O=GlobalSign nv-sa OU=Root CA +# Subject: CN=GlobalSign Root CA O=GlobalSign nv-sa OU=Root CA +# Label: "GlobalSign Root CA" +# Serial: 4835703278459707669005204 +# MD5 Fingerprint: 3e:45:52:15:09:51:92:e1:b7:5d:37:9f:b1:87:29:8a +# SHA1 Fingerprint: b1:bc:96:8b:d4:f4:9d:62:2a:a8:9a:81:f2:15:01:52:a4:1d:82:9c +# SHA256 Fingerprint: eb:d4:10:40:e4:bb:3e:c7:42:c9:e3:81:d3:1e:f2:a4:1a:48:b6:68:5c:96:e7:ce:f3:c1:df:6c:d4:33:1c:99 +-----BEGIN CERTIFICATE----- +MIIDdTCCAl2gAwIBAgILBAAAAAABFUtaw5QwDQYJKoZIhvcNAQEFBQAwVzELMAkG +A1UEBhMCQkUxGTAXBgNVBAoTEEdsb2JhbFNpZ24gbnYtc2ExEDAOBgNVBAsTB1Jv +b3QgQ0ExGzAZBgNVBAMTEkdsb2JhbFNpZ24gUm9vdCBDQTAeFw05ODA5MDExMjAw +MDBaFw0yODAxMjgxMjAwMDBaMFcxCzAJBgNVBAYTAkJFMRkwFwYDVQQKExBHbG9i +YWxTaWduIG52LXNhMRAwDgYDVQQLEwdSb290IENBMRswGQYDVQQDExJHbG9iYWxT +aWduIFJvb3QgQ0EwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDaDuaZ +jc6j40+Kfvvxi4Mla+pIH/EqsLmVEQS98GPR4mdmzxzdzxtIK+6NiY6arymAZavp +xy0Sy6scTHAHoT0KMM0VjU/43dSMUBUc71DuxC73/OlS8pF94G3VNTCOXkNz8kHp +1Wrjsok6Vjk4bwY8iGlbKk3Fp1S4bInMm/k8yuX9ifUSPJJ4ltbcdG6TRGHRjcdG +snUOhugZitVtbNV4FpWi6cgKOOvyJBNPc1STE4U6G7weNLWLBYy5d4ux2x8gkasJ +U26Qzns3dLlwR5EiUWMWea6xrkEmCMgZK9FGqkjWZCrXgzT/LCrBbBlDSgeF59N8 +9iFo7+ryUp9/k5DPAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8E +BTADAQH/MB0GA1UdDgQWBBRge2YaRQ2XyolQL30EzTSo//z9SzANBgkqhkiG9w0B +AQUFAAOCAQEA1nPnfE920I2/7LqivjTFKDK1fPxsnCwrvQmeU79rXqoRSLblCKOz +yj1hTdNGCbM+w6DjY1Ub8rrvrTnhQ7k4o+YviiY776BQVvnGCv04zcQLcFGUl5gE +38NflNUVyRRBnMRddWQVDf9VMOyGj/8N7yy5Y0b2qvzfvGn9LhJIZJrglfCm7ymP +AbEVtQwdpf5pLGkkeB6zpxxxYu7KyJesF12KwvhHhm4qxFYxldBniYUr+WymXUad +DKqC5JlR3XC321Y9YeRq4VzW9v493kHMB65jUr9TU/Qr6cf9tveCX4XSQRjbgbME +HMUfpIBvFSDJ3gyICh3WZlXi/EjJKSZp4A== +-----END CERTIFICATE----- + +# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R2 +# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R2 +# Label: "GlobalSign Root CA - R2" +# Serial: 4835703278459682885658125 +# MD5 Fingerprint: 94:14:77:7e:3e:5e:fd:8f:30:bd:41:b0:cf:e7:d0:30 +# SHA1 Fingerprint: 75:e0:ab:b6:13:85:12:27:1c:04:f8:5f:dd:de:38:e4:b7:24:2e:fe +# SHA256 Fingerprint: ca:42:dd:41:74:5f:d0:b8:1e:b9:02:36:2c:f9:d8:bf:71:9d:a1:bd:1b:1e:fc:94:6f:5b:4c:99:f4:2c:1b:9e +-----BEGIN CERTIFICATE----- +MIIDujCCAqKgAwIBAgILBAAAAAABD4Ym5g0wDQYJKoZIhvcNAQEFBQAwTDEgMB4G +A1UECxMXR2xvYmFsU2lnbiBSb290IENBIC0gUjIxEzARBgNVBAoTCkdsb2JhbFNp +Z24xEzARBgNVBAMTCkdsb2JhbFNpZ24wHhcNMDYxMjE1MDgwMDAwWhcNMjExMjE1 +MDgwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxTaWduIFJvb3QgQ0EgLSBSMjETMBEG +A1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2lnbjCCASIwDQYJKoZI +hvcNAQEBBQADggEPADCCAQoCggEBAKbPJA6+Lm8omUVCxKs+IVSbC9N/hHD6ErPL +v4dfxn+G07IwXNb9rfF73OX4YJYJkhD10FPe+3t+c4isUoh7SqbKSaZeqKeMWhG8 +eoLrvozps6yWJQeXSpkqBy+0Hne/ig+1AnwblrjFuTosvNYSuetZfeLQBoZfXklq +tTleiDTsvHgMCJiEbKjNS7SgfQx5TfC4LcshytVsW33hoCmEofnTlEnLJGKRILzd +C9XZzPnqJworc5HGnRusyMvo4KD0L5CLTfuwNhv2GXqF4G3yYROIXJ/gkwpRl4pa +zq+r1feqCapgvdzZX99yqWATXgAByUr6P6TqBwMhAo6CygPCm48CAwEAAaOBnDCB +mTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUm+IH +V2ccHsBqBt5ZtJot39wZhi4wNgYDVR0fBC8wLTAroCmgJ4YlaHR0cDovL2NybC5n +bG9iYWxzaWduLm5ldC9yb290LXIyLmNybDAfBgNVHSMEGDAWgBSb4gdXZxwewGoG +3lm0mi3f3BmGLjANBgkqhkiG9w0BAQUFAAOCAQEAmYFThxxol4aR7OBKuEQLq4Gs +J0/WwbgcQ3izDJr86iw8bmEbTUsp9Z8FHSbBuOmDAGJFtqkIk7mpM0sYmsL4h4hO +291xNBrBVNpGP+DTKqttVCL1OmLNIG+6KYnX3ZHu01yiPqFbQfXf5WRDLenVOavS +ot+3i9DAgBkcRcAtjOj4LaR0VknFBbVPFd5uRHg5h6h+u/N5GJG79G+dwfCMNYxd +AfvDbbnvRG15RjF+Cv6pgsH/76tuIMRQyV+dTZsXjAzlAcmgQWpzU/qlULRuJQ/7 +TBj0/VLZjmmx6BEP3ojY+x1J96relc8geMJgEtslQIxq/H5COEBkEveegeGTLg== +-----END CERTIFICATE----- + +# Issuer: CN=VeriSign Class 3 Public Primary Certification Authority - G3 O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 1999 VeriSign, Inc. - For authorized use only +# Subject: CN=VeriSign Class 3 Public Primary Certification Authority - G3 O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 1999 VeriSign, Inc. - For authorized use only +# Label: "Verisign Class 3 Public Primary Certification Authority - G3" +# Serial: 206684696279472310254277870180966723415 +# MD5 Fingerprint: cd:68:b6:a7:c7:c4:ce:75:e0:1d:4f:57:44:61:92:09 +# SHA1 Fingerprint: 13:2d:0d:45:53:4b:69:97:cd:b2:d5:c3:39:e2:55:76:60:9b:5c:c6 +# SHA256 Fingerprint: eb:04:cf:5e:b1:f3:9a:fa:76:2f:2b:b1:20:f2:96:cb:a5:20:c1:b9:7d:b1:58:95:65:b8:1c:b9:a1:7b:72:44 +-----BEGIN CERTIFICATE----- +MIIEGjCCAwICEQCbfgZJoz5iudXukEhxKe9XMA0GCSqGSIb3DQEBBQUAMIHKMQsw +CQYDVQQGEwJVUzEXMBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZl +cmlTaWduIFRydXN0IE5ldHdvcmsxOjA4BgNVBAsTMShjKSAxOTk5IFZlcmlTaWdu +LCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxRTBDBgNVBAMTPFZlcmlT +aWduIENsYXNzIDMgUHVibGljIFByaW1hcnkgQ2VydGlmaWNhdGlvbiBBdXRob3Jp +dHkgLSBHMzAeFw05OTEwMDEwMDAwMDBaFw0zNjA3MTYyMzU5NTlaMIHKMQswCQYD +VQQGEwJVUzEXMBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZlcmlT +aWduIFRydXN0IE5ldHdvcmsxOjA4BgNVBAsTMShjKSAxOTk5IFZlcmlTaWduLCBJ +bmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxRTBDBgNVBAMTPFZlcmlTaWdu +IENsYXNzIDMgUHVibGljIFByaW1hcnkgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkg +LSBHMzCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMu6nFL8eB8aHm8b +N3O9+MlrlBIwT/A2R/XQkQr1F8ilYcEWQE37imGQ5XYgwREGfassbqb1EUGO+i2t +KmFZpGcmTNDovFJbcCAEWNF6yaRpvIMXZK0Fi7zQWM6NjPXr8EJJC52XJ2cybuGu +kxUccLwgTS8Y3pKI6GyFVxEa6X7jJhFUokWWVYPKMIno3Nij7SqAP395ZVc+FSBm +CC+Vk7+qRy+oRpfwEuL+wgorUeZ25rdGt+INpsyow0xZVYnm6FNcHOqd8GIWC6fJ +Xwzw3sJ2zq/3avL6QaaiMxTJ5Xpj055iN9WFZZ4O5lMkdBteHRJTW8cs54NJOxWu +imi5V5cCAwEAATANBgkqhkiG9w0BAQUFAAOCAQEAERSWwauSCPc/L8my/uRan2Te +2yFPhpk0djZX3dAVL8WtfxUfN2JzPtTnX84XA9s1+ivbrmAJXx5fj267Cz3qWhMe +DGBvtcC1IyIuBwvLqXTLR7sdwdela8wv0kL9Sd2nic9TutoAWii/gt/4uhMdUIaC +/Y4wjylGsB49Ndo4YhYYSq3mtlFs3q9i6wHQHiT+eo8SGhJouPtmmRQURVyu565p +F4ErWjfJXir0xuKhXFSbplQAz/DxwceYMBo7Nhbbo27q/a2ywtrvAkcTisDxszGt +TxzhT5yvDwyd93gN2PQ1VoDat20Xj50egWTh/sVFuq1ruQp6Tk9LhO5L8X3dEQ== +-----END CERTIFICATE----- + +# Issuer: CN=Entrust.net Certification Authority (2048) O=Entrust.net OU=www.entrust.net/CPS_2048 incorp. by ref. (limits liab.)/(c) 1999 Entrust.net Limited +# Subject: CN=Entrust.net Certification Authority (2048) O=Entrust.net OU=www.entrust.net/CPS_2048 incorp. by ref. (limits liab.)/(c) 1999 Entrust.net Limited +# Label: "Entrust.net Premium 2048 Secure Server CA" +# Serial: 946069240 +# MD5 Fingerprint: ee:29:31:bc:32:7e:9a:e6:e8:b5:f7:51:b4:34:71:90 +# SHA1 Fingerprint: 50:30:06:09:1d:97:d4:f5:ae:39:f7:cb:e7:92:7d:7d:65:2d:34:31 +# SHA256 Fingerprint: 6d:c4:71:72:e0:1c:bc:b0:bf:62:58:0d:89:5f:e2:b8:ac:9a:d4:f8:73:80:1e:0c:10:b9:c8:37:d2:1e:b1:77 +-----BEGIN CERTIFICATE----- +MIIEKjCCAxKgAwIBAgIEOGPe+DANBgkqhkiG9w0BAQUFADCBtDEUMBIGA1UEChML +RW50cnVzdC5uZXQxQDA+BgNVBAsUN3d3dy5lbnRydXN0Lm5ldC9DUFNfMjA0OCBp +bmNvcnAuIGJ5IHJlZi4gKGxpbWl0cyBsaWFiLikxJTAjBgNVBAsTHChjKSAxOTk5 +IEVudHJ1c3QubmV0IExpbWl0ZWQxMzAxBgNVBAMTKkVudHJ1c3QubmV0IENlcnRp +ZmljYXRpb24gQXV0aG9yaXR5ICgyMDQ4KTAeFw05OTEyMjQxNzUwNTFaFw0yOTA3 +MjQxNDE1MTJaMIG0MRQwEgYDVQQKEwtFbnRydXN0Lm5ldDFAMD4GA1UECxQ3d3d3 +LmVudHJ1c3QubmV0L0NQU18yMDQ4IGluY29ycC4gYnkgcmVmLiAobGltaXRzIGxp +YWIuKTElMCMGA1UECxMcKGMpIDE5OTkgRW50cnVzdC5uZXQgTGltaXRlZDEzMDEG +A1UEAxMqRW50cnVzdC5uZXQgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgKDIwNDgp +MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEArU1LqRKGsuqjIAcVFmQq +K0vRvwtKTY7tgHalZ7d4QMBzQshowNtTK91euHaYNZOLGp18EzoOH1u3Hs/lJBQe +sYGpjX24zGtLA/ECDNyrpUAkAH90lKGdCCmziAv1h3edVc3kw37XamSrhRSGlVuX +MlBvPci6Zgzj/L24ScF2iUkZ/cCovYmjZy/Gn7xxGWC4LeksyZB2ZnuU4q941mVT +XTzWnLLPKQP5L6RQstRIzgUyVYr9smRMDuSYB3Xbf9+5CFVghTAp+XtIpGmG4zU/ +HoZdenoVve8AjhUiVBcAkCaTvA5JaJG/+EfTnZVCwQ5N328mz8MYIWJmQ3DW1cAH +4QIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNV +HQ4EFgQUVeSB0RGAvtiJuQijMfmhJAkWuXAwDQYJKoZIhvcNAQEFBQADggEBADub +j1abMOdTmXx6eadNl9cZlZD7Bh/KM3xGY4+WZiT6QBshJ8rmcnPyT/4xmf3IDExo +U8aAghOY+rat2l098c5u9hURlIIM7j+VrxGrD9cv3h8Dj1csHsm7mhpElesYT6Yf +zX1XEC+bBAlahLVu2B064dae0Wx5XnkcFMXj0EyTO2U87d89vqbllRrDtRnDvV5b +u/8j72gZyxKTJ1wDLW8w0B62GqzeWvfRqqgnpv55gcR5mTNXuhKwqeBCbJPKVt7+ +bYQLCIt+jerXmCHG8+c8eS9enNFMFY3h7CI3zJpDC5fcgJCNs2ebb0gIFVbPv/Er +fF6adulZkMV8gzURZVE= +-----END CERTIFICATE----- + +# Issuer: CN=Baltimore CyberTrust Root O=Baltimore OU=CyberTrust +# Subject: CN=Baltimore CyberTrust Root O=Baltimore OU=CyberTrust +# Label: "Baltimore CyberTrust Root" +# Serial: 33554617 +# MD5 Fingerprint: ac:b6:94:a5:9c:17:e0:d7:91:52:9b:b1:97:06:a6:e4 +# SHA1 Fingerprint: d4:de:20:d0:5e:66:fc:53:fe:1a:50:88:2c:78:db:28:52:ca:e4:74 +# SHA256 Fingerprint: 16:af:57:a9:f6:76:b0:ab:12:60:95:aa:5e:ba:de:f2:2a:b3:11:19:d6:44:ac:95:cd:4b:93:db:f3:f2:6a:eb +-----BEGIN CERTIFICATE----- +MIIDdzCCAl+gAwIBAgIEAgAAuTANBgkqhkiG9w0BAQUFADBaMQswCQYDVQQGEwJJ +RTESMBAGA1UEChMJQmFsdGltb3JlMRMwEQYDVQQLEwpDeWJlclRydXN0MSIwIAYD +VQQDExlCYWx0aW1vcmUgQ3liZXJUcnVzdCBSb290MB4XDTAwMDUxMjE4NDYwMFoX +DTI1MDUxMjIzNTkwMFowWjELMAkGA1UEBhMCSUUxEjAQBgNVBAoTCUJhbHRpbW9y +ZTETMBEGA1UECxMKQ3liZXJUcnVzdDEiMCAGA1UEAxMZQmFsdGltb3JlIEN5YmVy +VHJ1c3QgUm9vdDCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKMEuyKr +mD1X6CZymrV51Cni4eiVgLGw41uOKymaZN+hXe2wCQVt2yguzmKiYv60iNoS6zjr +IZ3AQSsBUnuId9Mcj8e6uYi1agnnc+gRQKfRzMpijS3ljwumUNKoUMMo6vWrJYeK +mpYcqWe4PwzV9/lSEy/CG9VwcPCPwBLKBsua4dnKM3p31vjsufFoREJIE9LAwqSu +XmD+tqYF/LTdB1kC1FkYmGP1pWPgkAx9XbIGevOF6uvUA65ehD5f/xXtabz5OTZy +dc93Uk3zyZAsuT3lySNTPx8kmCFcB5kpvcY67Oduhjprl3RjM71oGDHweI12v/ye +jl0qhqdNkNwnGjkCAwEAAaNFMEMwHQYDVR0OBBYEFOWdWTCCR1jMrPoIVDaGezq1 +BE3wMBIGA1UdEwEB/wQIMAYBAf8CAQMwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3 +DQEBBQUAA4IBAQCFDF2O5G9RaEIFoN27TyclhAO992T9Ldcw46QQF+vaKSm2eT92 +9hkTI7gQCvlYpNRhcL0EYWoSihfVCr3FvDB81ukMJY2GQE/szKN+OMY3EU/t3Wgx +jkzSswF07r51XgdIGn9w/xZchMB5hbgF/X++ZRGjD8ACtPhSNzkE1akxehi/oCr0 +Epn3o0WC4zxe9Z2etciefC7IpJ5OCBRLbf1wbWsaY71k5h+3zvDyny67G7fyUIhz +ksLi4xaNmjICq44Y3ekQEe5+NauQrz4wlHrQMz2nZQ/1/I6eYs9HRCwBXbsdtTLS +R9I4LtD+gdwyah617jzV/OeBHRnDJELqYzmp +-----END CERTIFICATE----- + +# Issuer: CN=AddTrust External CA Root O=AddTrust AB OU=AddTrust External TTP Network +# Subject: CN=AddTrust External CA Root O=AddTrust AB OU=AddTrust External TTP Network +# Label: "AddTrust External Root" +# Serial: 1 +# MD5 Fingerprint: 1d:35:54:04:85:78:b0:3f:42:42:4d:bf:20:73:0a:3f +# SHA1 Fingerprint: 02:fa:f3:e2:91:43:54:68:60:78:57:69:4d:f5:e4:5b:68:85:18:68 +# SHA256 Fingerprint: 68:7f:a4:51:38:22:78:ff:f0:c8:b1:1f:8d:43:d5:76:67:1c:6e:b2:bc:ea:b4:13:fb:83:d9:65:d0:6d:2f:f2 +-----BEGIN CERTIFICATE----- +MIIENjCCAx6gAwIBAgIBATANBgkqhkiG9w0BAQUFADBvMQswCQYDVQQGEwJTRTEU +MBIGA1UEChMLQWRkVHJ1c3QgQUIxJjAkBgNVBAsTHUFkZFRydXN0IEV4dGVybmFs +IFRUUCBOZXR3b3JrMSIwIAYDVQQDExlBZGRUcnVzdCBFeHRlcm5hbCBDQSBSb290 +MB4XDTAwMDUzMDEwNDgzOFoXDTIwMDUzMDEwNDgzOFowbzELMAkGA1UEBhMCU0Ux +FDASBgNVBAoTC0FkZFRydXN0IEFCMSYwJAYDVQQLEx1BZGRUcnVzdCBFeHRlcm5h +bCBUVFAgTmV0d29yazEiMCAGA1UEAxMZQWRkVHJ1c3QgRXh0ZXJuYWwgQ0EgUm9v +dDCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALf3GjPm8gAELTngTlvt +H7xsD821+iO2zt6bETOXpClMfZOfvUq8k+0DGuOPz+VtUFrWlymUWoCwSXrbLpX9 +uMq/NzgtHj6RQa1wVsfwTz/oMp50ysiQVOnGXw94nZpAPA6sYapeFI+eh6FqUNzX +mk6vBbOmcZSccbNQYArHE504B4YCqOmoaSYYkKtMsE8jqzpPhNjfzp/haW+710LX +a0Tkx63ubUFfclpxCDezeWWkWaCUN/cALw3CknLa0Dhy2xSoRcRdKn23tNbE7qzN +E0S3ySvdQwAl+mG5aWpYIxG3pzOPVnVZ9c0p10a3CitlttNCbxWyuHv77+ldU9U0 +WicCAwEAAaOB3DCB2TAdBgNVHQ4EFgQUrb2YejS0Jvf6xCZU7wO94CTLVBowCwYD +VR0PBAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wgZkGA1UdIwSBkTCBjoAUrb2YejS0 +Jvf6xCZU7wO94CTLVBqhc6RxMG8xCzAJBgNVBAYTAlNFMRQwEgYDVQQKEwtBZGRU +cnVzdCBBQjEmMCQGA1UECxMdQWRkVHJ1c3QgRXh0ZXJuYWwgVFRQIE5ldHdvcmsx +IjAgBgNVBAMTGUFkZFRydXN0IEV4dGVybmFsIENBIFJvb3SCAQEwDQYJKoZIhvcN +AQEFBQADggEBALCb4IUlwtYj4g+WBpKdQZic2YR5gdkeWxQHIzZlj7DYd7usQWxH +YINRsPkyPef89iYTx4AWpb9a/IfPeHmJIZriTAcKhjW88t5RxNKWt9x+Tu5w/Rw5 +6wwCURQtjr0W4MHfRnXnJK3s9EK0hZNwEGe6nQY1ShjTK3rMUUKhemPR5ruhxSvC +Nr4TDea9Y355e6cJDUCrat2PisP29owaQgVR1EX1n6diIWgVIEM8med8vSTYqZEX +c4g/VhsxOBi0cQ+azcgOno4uG+GMmIPLHzHxREzGBHNJdmAPx/i9F4BrLunMTA5a +mnkPIAou1Z5jJh5VkpTYghdae9C8x49OhgQ= +-----END CERTIFICATE----- + +# Issuer: CN=Entrust Root Certification Authority O=Entrust, Inc. OU=www.entrust.net/CPS is incorporated by reference/(c) 2006 Entrust, Inc. +# Subject: CN=Entrust Root Certification Authority O=Entrust, Inc. OU=www.entrust.net/CPS is incorporated by reference/(c) 2006 Entrust, Inc. +# Label: "Entrust Root Certification Authority" +# Serial: 1164660820 +# MD5 Fingerprint: d6:a5:c3:ed:5d:dd:3e:00:c1:3d:87:92:1f:1d:3f:e4 +# SHA1 Fingerprint: b3:1e:b1:b7:40:e3:6c:84:02:da:dc:37:d4:4d:f5:d4:67:49:52:f9 +# SHA256 Fingerprint: 73:c1:76:43:4f:1b:c6:d5:ad:f4:5b:0e:76:e7:27:28:7c:8d:e5:76:16:c1:e6:e6:14:1a:2b:2c:bc:7d:8e:4c +-----BEGIN CERTIFICATE----- +MIIEkTCCA3mgAwIBAgIERWtQVDANBgkqhkiG9w0BAQUFADCBsDELMAkGA1UEBhMC +VVMxFjAUBgNVBAoTDUVudHJ1c3QsIEluYy4xOTA3BgNVBAsTMHd3dy5lbnRydXN0 +Lm5ldC9DUFMgaXMgaW5jb3Jwb3JhdGVkIGJ5IHJlZmVyZW5jZTEfMB0GA1UECxMW +KGMpIDIwMDYgRW50cnVzdCwgSW5jLjEtMCsGA1UEAxMkRW50cnVzdCBSb290IENl +cnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTA2MTEyNzIwMjM0MloXDTI2MTEyNzIw +NTM0MlowgbAxCzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1FbnRydXN0LCBJbmMuMTkw +NwYDVQQLEzB3d3cuZW50cnVzdC5uZXQvQ1BTIGlzIGluY29ycG9yYXRlZCBieSBy +ZWZlcmVuY2UxHzAdBgNVBAsTFihjKSAyMDA2IEVudHJ1c3QsIEluYy4xLTArBgNV +BAMTJEVudHJ1c3QgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTCCASIwDQYJ +KoZIhvcNAQEBBQADggEPADCCAQoCggEBALaVtkNC+sZtKm9I35RMOVcF7sN5EUFo +Nu3s/poBj6E4KPz3EEZmLk0eGrEaTsbRwJWIsMn/MYszA9u3g3s+IIRe7bJWKKf4 +4LlAcTfFy0cOlypowCKVYhXbR9n10Cv/gkvJrT7eTNuQgFA/CYqEAOwwCj0Yzfv9 +KlmaI5UXLEWeH25DeW0MXJj+SKfFI0dcXv1u5x609mhF0YaDW6KKjbHjKYD+JXGI +rb68j6xSlkuqUY3kEzEZ6E5Nn9uss2rVvDlUccp6en+Q3X0dgNmBu1kmwhH+5pPi +94DkZfs0Nw4pgHBNrziGLp5/V6+eF67rHMsoIV+2HNjnogQi+dPa2MsCAwEAAaOB +sDCBrTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zArBgNVHRAEJDAi +gA8yMDA2MTEyNzIwMjM0MlqBDzIwMjYxMTI3MjA1MzQyWjAfBgNVHSMEGDAWgBRo +kORnpKZTgMeGZqTx90tD+4S9bTAdBgNVHQ4EFgQUaJDkZ6SmU4DHhmak8fdLQ/uE +vW0wHQYJKoZIhvZ9B0EABBAwDhsIVjcuMTo0LjADAgSQMA0GCSqGSIb3DQEBBQUA +A4IBAQCT1DCw1wMgKtD5Y+iRDAUgqV8ZyntyTtSx29CW+1RaGSwMCPeyvIWonX9t +O1KzKtvn1ISMY/YPyyYBkVBs9F8U4pN0wBOeMDpQ47RgxRzwIkSNcUesyBrJ6Zua +AGAT/3B+XxFNSRuzFVJ7yVTav52Vr2ua2J7p8eRDjeIRRDq/r72DQnNSi6q7pynP +9WQcCk3RvKqsnyrQ/39/2n3qse0wJcGE2jTSW3iDVuycNsMm4hH2Z0kdkquM++v/ +eu6FSqdQgPCnXEqULl8FmTxSQeDNtGPPAUO6nIPcj2A781q0tHuu2guQOHXvgR1m +0vdXcDazv/wor3ElhVsT/h5/WrQ8 +-----END CERTIFICATE----- + +# Issuer: CN=GeoTrust Global CA O=GeoTrust Inc. +# Subject: CN=GeoTrust Global CA O=GeoTrust Inc. +# Label: "GeoTrust Global CA" +# Serial: 144470 +# MD5 Fingerprint: f7:75:ab:29:fb:51:4e:b7:77:5e:ff:05:3c:99:8e:f5 +# SHA1 Fingerprint: de:28:f4:a4:ff:e5:b9:2f:a3:c5:03:d1:a3:49:a7:f9:96:2a:82:12 +# SHA256 Fingerprint: ff:85:6a:2d:25:1d:cd:88:d3:66:56:f4:50:12:67:98:cf:ab:aa:de:40:79:9c:72:2d:e4:d2:b5:db:36:a7:3a +-----BEGIN CERTIFICATE----- +MIIDVDCCAjygAwIBAgIDAjRWMA0GCSqGSIb3DQEBBQUAMEIxCzAJBgNVBAYTAlVT +MRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMRswGQYDVQQDExJHZW9UcnVzdCBHbG9i +YWwgQ0EwHhcNMDIwNTIxMDQwMDAwWhcNMjIwNTIxMDQwMDAwWjBCMQswCQYDVQQG +EwJVUzEWMBQGA1UEChMNR2VvVHJ1c3QgSW5jLjEbMBkGA1UEAxMSR2VvVHJ1c3Qg +R2xvYmFsIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA2swYYzD9 +9BcjGlZ+W988bDjkcbd4kdS8odhM+KhDtgPpTSEHCIjaWC9mOSm9BXiLnTjoBbdq +fnGk5sRgprDvgOSJKA+eJdbtg/OtppHHmMlCGDUUna2YRpIuT8rxh0PBFpVXLVDv +iS2Aelet8u5fa9IAjbkU+BQVNdnARqN7csiRv8lVK83Qlz6cJmTM386DGXHKTubU +1XupGc1V3sjs0l44U+VcT4wt/lAjNvxm5suOpDkZALeVAjmRCw7+OC7RHQWa9k0+ +bw8HHa8sHo9gOeL6NlMTOdReJivbPagUvTLrGAMoUgRx5aszPeE4uwc2hGKceeoW +MPRfwCvocWvk+QIDAQABo1MwUTAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBTA +ephojYn7qwVkDBF9qn1luMrMTjAfBgNVHSMEGDAWgBTAephojYn7qwVkDBF9qn1l +uMrMTjANBgkqhkiG9w0BAQUFAAOCAQEANeMpauUvXVSOKVCUn5kaFOSPeCpilKIn +Z57QzxpeR+nBsqTP3UEaBU6bS+5Kb1VSsyShNwrrZHYqLizz/Tt1kL/6cdjHPTfS +tQWVYrmm3ok9Nns4d0iXrKYgjy6myQzCsplFAMfOEVEiIuCl6rYVSAlk6l5PdPcF +PseKUgzbFbS9bZvlxrFUaKnjaZC2mqUPuLk/IH2uSrW4nOQdtqvmlKXBx4Ot2/Un +hw4EbNX/3aBd7YdStysVAq45pmp06drE57xNNB6pXE0zX5IJL4hmXXeXxx12E6nV +5fEWCRE11azbJHFwLJhWC9kXtNHjUStedejV0NxPNO3CBWaAocvmMw== +-----END CERTIFICATE----- + +# Issuer: CN=GeoTrust Universal CA O=GeoTrust Inc. +# Subject: CN=GeoTrust Universal CA O=GeoTrust Inc. +# Label: "GeoTrust Universal CA" +# Serial: 1 +# MD5 Fingerprint: 92:65:58:8b:a2:1a:31:72:73:68:5c:b4:a5:7a:07:48 +# SHA1 Fingerprint: e6:21:f3:35:43:79:05:9a:4b:68:30:9d:8a:2f:74:22:15:87:ec:79 +# SHA256 Fingerprint: a0:45:9b:9f:63:b2:25:59:f5:fa:5d:4c:6d:b3:f9:f7:2f:f1:93:42:03:35:78:f0:73:bf:1d:1b:46:cb:b9:12 +-----BEGIN CERTIFICATE----- +MIIFaDCCA1CgAwIBAgIBATANBgkqhkiG9w0BAQUFADBFMQswCQYDVQQGEwJVUzEW +MBQGA1UEChMNR2VvVHJ1c3QgSW5jLjEeMBwGA1UEAxMVR2VvVHJ1c3QgVW5pdmVy +c2FsIENBMB4XDTA0MDMwNDA1MDAwMFoXDTI5MDMwNDA1MDAwMFowRTELMAkGA1UE +BhMCVVMxFjAUBgNVBAoTDUdlb1RydXN0IEluYy4xHjAcBgNVBAMTFUdlb1RydXN0 +IFVuaXZlcnNhbCBDQTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAKYV +VaCjxuAfjJ0hUNfBvitbtaSeodlyWL0AG0y/YckUHUWCq8YdgNY96xCcOq9tJPi8 +cQGeBvV8Xx7BDlXKg5pZMK4ZyzBIle0iN430SppyZj6tlcDgFgDgEB8rMQ7XlFTT +QjOgNB0eRXbdT8oYN+yFFXoZCPzVx5zw8qkuEKmS5j1YPakWaDwvdSEYfyh3peFh +F7em6fgemdtzbvQKoiFs7tqqhZJmr/Z6a4LauiIINQ/PQvE1+mrufislzDoR5G2v +c7J2Ha3QsnhnGqQ5HFELZ1aD/ThdDc7d8Lsrlh/eezJS/R27tQahsiFepdaVaH/w +mZ7cRQg+59IJDTWU3YBOU5fXtQlEIGQWFwMCTFMNaN7VqnJNk22CDtucvc+081xd +VHppCZbW2xHBjXWotM85yM48vCR85mLK4b19p71XZQvk/iXttmkQ3CgaRr0BHdCX +teGYO8A3ZNY9lO4L4fUorgtWv3GLIylBjobFS1J72HGrH4oVpjuDWtdYAVHGTEHZ +f9hBZ3KiKN9gg6meyHv8U3NyWfWTehd2Ds735VzZC1U0oqpbtWpU5xPKV+yXbfRe +Bi9Fi1jUIxaS5BZuKGNZMN9QAZxjiRqf2xeUgnA3wySemkfWWspOqGmJch+RbNt+ +nhutxx9z3SxPGWX9f5NAEC7S8O08ni4oPmkmM8V7AgMBAAGjYzBhMA8GA1UdEwEB +/wQFMAMBAf8wHQYDVR0OBBYEFNq7LqqwDLiIJlF0XG0D08DYj3rWMB8GA1UdIwQY +MBaAFNq7LqqwDLiIJlF0XG0D08DYj3rWMA4GA1UdDwEB/wQEAwIBhjANBgkqhkiG +9w0BAQUFAAOCAgEAMXjmx7XfuJRAyXHEqDXsRh3ChfMoWIawC/yOsjmPRFWrZIRc +aanQmjg8+uUfNeVE44B5lGiku8SfPeE0zTBGi1QrlaXv9z+ZhP015s8xxtxqv6fX +IwjhmF7DWgh2qaavdy+3YL1ERmrvl/9zlcGO6JP7/TG37FcREUWbMPEaiDnBTzyn +ANXH/KttgCJwpQzgXQQpAvvLoJHRfNbDflDVnVi+QTjruXU8FdmbyUqDWcDaU/0z +uzYYm4UPFd3uLax2k7nZAY1IEKj79TiG8dsKxr2EoyNB3tZ3b4XUhRxQ4K5RirqN +Pnbiucon8l+f725ZDQbYKxek0nxru18UGkiPGkzns0ccjkxFKyDuSN/n3QmOGKja +QI2SJhFTYXNd673nxE0pN2HrrDktZy4W1vUAg4WhzH92xH3kt0tm7wNFYGm2DFKW +koRepqO1pD4r2czYG0eq8kTaT/kD6PAUyz/zg97QwVTjt+gKN02LIFkDMBmhLMi9 +ER/frslKxfMnZmaGrGiR/9nmUxwPi1xpZQomyB40w11Re9epnAahNt3ViZS82eQt +DF4JbAiXfKM9fJP/P6EUp8+1Xevb2xzEdt+Iub1FBZUbrvxGakyvSOPOrg/Sfuvm +bJxPgWp6ZKy7PtXny3YuxadIwVyQD8vIP/rmMuGNG2+k5o7Y+SlIis5z/iw= +-----END CERTIFICATE----- + +# Issuer: CN=GeoTrust Universal CA 2 O=GeoTrust Inc. +# Subject: CN=GeoTrust Universal CA 2 O=GeoTrust Inc. +# Label: "GeoTrust Universal CA 2" +# Serial: 1 +# MD5 Fingerprint: 34:fc:b8:d0:36:db:9e:14:b3:c2:f2:db:8f:e4:94:c7 +# SHA1 Fingerprint: 37:9a:19:7b:41:85:45:35:0c:a6:03:69:f3:3c:2e:af:47:4f:20:79 +# SHA256 Fingerprint: a0:23:4f:3b:c8:52:7c:a5:62:8e:ec:81:ad:5d:69:89:5d:a5:68:0d:c9:1d:1c:b8:47:7f:33:f8:78:b9:5b:0b +-----BEGIN CERTIFICATE----- +MIIFbDCCA1SgAwIBAgIBATANBgkqhkiG9w0BAQUFADBHMQswCQYDVQQGEwJVUzEW +MBQGA1UEChMNR2VvVHJ1c3QgSW5jLjEgMB4GA1UEAxMXR2VvVHJ1c3QgVW5pdmVy +c2FsIENBIDIwHhcNMDQwMzA0MDUwMDAwWhcNMjkwMzA0MDUwMDAwWjBHMQswCQYD +VQQGEwJVUzEWMBQGA1UEChMNR2VvVHJ1c3QgSW5jLjEgMB4GA1UEAxMXR2VvVHJ1 +c3QgVW5pdmVyc2FsIENBIDIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoIC +AQCzVFLByT7y2dyxUxpZKeexw0Uo5dfR7cXFS6GqdHtXr0om/Nj1XqduGdt0DE81 +WzILAePb63p3NeqqWuDW6KFXlPCQo3RWlEQwAx5cTiuFJnSCegx2oG9NzkEtoBUG +FF+3Qs17j1hhNNwqCPkuwwGmIkQcTAeC5lvO0Ep8BNMZcyfwqph/Lq9O64ceJHdq +XbboW0W63MOhBW9Wjo8QJqVJwy7XQYci4E+GymC16qFjwAGXEHm9ADwSbSsVsaxL +se4YuU6W3Nx2/zu+z18DwPw76L5GG//aQMJS9/7jOvdqdzXQ2o3rXhhqMcceujwb +KNZrVMaqW9eiLBsZzKIC9ptZvTdrhrVtgrrY6slWvKk2WP0+GfPtDCapkzj4T8Fd +IgbQl+rhrcZV4IErKIM6+vR7IVEAvlI4zs1meaj0gVbi0IMJR1FbUGrP20gaXT73 +y/Zl92zxlfgCOzJWgjl6W70viRu/obTo/3+NjN8D8WBOWBFM66M/ECuDmgFz2ZRt +hAAnZqzwcEAJQpKtT5MNYQlRJNiS1QuUYbKHsu3/mjX/hVTK7URDrBs8FmtISgoc +QIgfksILAAX/8sgCSqSqqcyZlpwvWOB94b67B9xfBHJcMTTD7F8t4D1kkCLm0ey4 +Lt1ZrtmhN79UNdxzMk+MBB4zsslG8dhcyFVQyWi9qLo2CQIDAQABo2MwYTAPBgNV +HRMBAf8EBTADAQH/MB0GA1UdDgQWBBR281Xh+qQ2+/CfXGJx7Tz0RzgQKzAfBgNV +HSMEGDAWgBR281Xh+qQ2+/CfXGJx7Tz0RzgQKzAOBgNVHQ8BAf8EBAMCAYYwDQYJ +KoZIhvcNAQEFBQADggIBAGbBxiPz2eAubl/oz66wsCVNK/g7WJtAJDday6sWSf+z +dXkzoS9tcBc0kf5nfo/sm+VegqlVHy/c1FEHEv6sFj4sNcZj/NwQ6w2jqtB8zNHQ +L1EuxBRa3ugZ4T7GzKQp5y6EqgYweHZUcyiYWTjgAA1i00J9IZ+uPTqM1fp3DRgr +Fg5fNuH8KrUwJM/gYwx7WBr+mbpCErGR9Hxo4sjoryzqyX6uuyo9DRXcNJW2GHSo +ag/HtPQTxORb7QrSpJdMKu0vbBKJPfEncKpqA1Ihn0CoZ1Dy81of398j9tx4TuaY +T1U6U+Pv8vSfx3zYWK8pIpe44L2RLrB27FcRz+8pRPPphXpgY+RdM4kX2TGq2tbz +GDVyz4crL2MjhF2EjD9XoIj8mZEoJmmZ1I+XRL6O1UixpCgp8RW04eWe3fiPpm8m +1wk8OhwRDqZsN/etRIcsKMfYdIKz0G9KV7s1KSegi+ghp4dkNl3M2Basx7InQJJV +OCiNUW7dFGdTbHFcJoRNdVq2fmBWqU2t+5sel/MN2dKXVHfaPRK34B7vCAas+YWH +6aLcr34YEoP9VhdBLtUpgn2Z9DH2canPLAEnpQW5qrJITirvn5NSUZU8UnOOVkwX +QMAJKOSLakhT2+zNVVXxxvjpoixMptEmX36vWkzaH6byHCx+rgIW0lbQL1dTR+iS +-----END CERTIFICATE----- + +# Issuer: CN=AAA Certificate Services O=Comodo CA Limited +# Subject: CN=AAA Certificate Services O=Comodo CA Limited +# Label: "Comodo AAA Services root" +# Serial: 1 +# MD5 Fingerprint: 49:79:04:b0:eb:87:19:ac:47:b0:bc:11:51:9b:74:d0 +# SHA1 Fingerprint: d1:eb:23:a4:6d:17:d6:8f:d9:25:64:c2:f1:f1:60:17:64:d8:e3:49 +# SHA256 Fingerprint: d7:a7:a0:fb:5d:7e:27:31:d7:71:e9:48:4e:bc:de:f7:1d:5f:0c:3e:0a:29:48:78:2b:c8:3e:e0:ea:69:9e:f4 +-----BEGIN CERTIFICATE----- +MIIEMjCCAxqgAwIBAgIBATANBgkqhkiG9w0BAQUFADB7MQswCQYDVQQGEwJHQjEb +MBkGA1UECAwSR3JlYXRlciBNYW5jaGVzdGVyMRAwDgYDVQQHDAdTYWxmb3JkMRow +GAYDVQQKDBFDb21vZG8gQ0EgTGltaXRlZDEhMB8GA1UEAwwYQUFBIENlcnRpZmlj +YXRlIFNlcnZpY2VzMB4XDTA0MDEwMTAwMDAwMFoXDTI4MTIzMTIzNTk1OVowezEL +MAkGA1UEBhMCR0IxGzAZBgNVBAgMEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UE +BwwHU2FsZm9yZDEaMBgGA1UECgwRQ29tb2RvIENBIExpbWl0ZWQxITAfBgNVBAMM +GEFBQSBDZXJ0aWZpY2F0ZSBTZXJ2aWNlczCCASIwDQYJKoZIhvcNAQEBBQADggEP +ADCCAQoCggEBAL5AnfRu4ep2hxxNRUSOvkbIgwadwSr+GB+O5AL686tdUIoWMQua +BtDFcCLNSS1UY8y2bmhGC1Pqy0wkwLxyTurxFa70VJoSCsN6sjNg4tqJVfMiWPPe +3M/vg4aijJRPn2jymJBGhCfHdr/jzDUsi14HZGWCwEiwqJH5YZ92IFCokcdmtet4 +YgNW8IoaE+oxox6gmf049vYnMlhvB/VruPsUK6+3qszWY19zjNoFmag4qMsXeDZR +rOme9Hg6jc8P2ULimAyrL58OAd7vn5lJ8S3frHRNG5i1R8XlKdH5kBjHYpy+g8cm +ez6KJcfA3Z3mNWgQIJ2P2N7Sw4ScDV7oL8kCAwEAAaOBwDCBvTAdBgNVHQ4EFgQU +oBEKIz6W8Qfs4q8p74Klf9AwpLQwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQF +MAMBAf8wewYDVR0fBHQwcjA4oDagNIYyaHR0cDovL2NybC5jb21vZG9jYS5jb20v +QUFBQ2VydGlmaWNhdGVTZXJ2aWNlcy5jcmwwNqA0oDKGMGh0dHA6Ly9jcmwuY29t +b2RvLm5ldC9BQUFDZXJ0aWZpY2F0ZVNlcnZpY2VzLmNybDANBgkqhkiG9w0BAQUF +AAOCAQEACFb8AvCb6P+k+tZ7xkSAzk/ExfYAWMymtrwUSWgEdujm7l3sAg9g1o1Q +GE8mTgHj5rCl7r+8dFRBv/38ErjHT1r0iWAFf2C3BUrz9vHCv8S5dIa2LX1rzNLz +Rt0vxuBqw8M0Ayx9lt1awg6nCpnBBYurDC/zXDrPbDdVCYfeU0BsWO/8tqtlbgT2 +G9w84FoVxp7Z8VlIMCFlA2zs6SFz7JsDoeA3raAVGI/6ugLOpyypEBMs1OUIJqsi +l2D4kF501KKaU73yqWjgom7C12yxow+ev+to51byrvLjKzg6CYG1a4XXvi3tPxq3 +smPi9WIsgtRqAEFQ8TmDn5XpNpaYbg== +-----END CERTIFICATE----- + +# Issuer: CN=QuoVadis Root Certification Authority O=QuoVadis Limited OU=Root Certification Authority +# Subject: CN=QuoVadis Root Certification Authority O=QuoVadis Limited OU=Root Certification Authority +# Label: "QuoVadis Root CA" +# Serial: 985026699 +# MD5 Fingerprint: 27:de:36:fe:72:b7:00:03:00:9d:f4:f0:1e:6c:04:24 +# SHA1 Fingerprint: de:3f:40:bd:50:93:d3:9b:6c:60:f6:da:bc:07:62:01:00:89:76:c9 +# SHA256 Fingerprint: a4:5e:de:3b:bb:f0:9c:8a:e1:5c:72:ef:c0:72:68:d6:93:a2:1c:99:6f:d5:1e:67:ca:07:94:60:fd:6d:88:73 +-----BEGIN CERTIFICATE----- +MIIF0DCCBLigAwIBAgIEOrZQizANBgkqhkiG9w0BAQUFADB/MQswCQYDVQQGEwJC +TTEZMBcGA1UEChMQUXVvVmFkaXMgTGltaXRlZDElMCMGA1UECxMcUm9vdCBDZXJ0 +aWZpY2F0aW9uIEF1dGhvcml0eTEuMCwGA1UEAxMlUXVvVmFkaXMgUm9vdCBDZXJ0 +aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wMTAzMTkxODMzMzNaFw0yMTAzMTcxODMz +MzNaMH8xCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMSUw +IwYDVQQLExxSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MS4wLAYDVQQDEyVR +dW9WYWRpcyBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIIBIjANBgkqhkiG +9w0BAQEFAAOCAQ8AMIIBCgKCAQEAv2G1lVO6V/z68mcLOhrfEYBklbTRvM16z/Yp +li4kVEAkOPcahdxYTMukJ0KX0J+DisPkBgNbAKVRHnAEdOLB1Dqr1607BxgFjv2D +rOpm2RgbaIr1VxqYuvXtdj182d6UajtLF8HVj71lODqV0D1VNk7feVcxKh7YWWVJ +WCCYfqtffp/p1k3sg3Spx2zY7ilKhSoGFPlU5tPaZQeLYzcS19Dsw3sgQUSj7cug +F+FxZc4dZjH3dgEZyH0DWLaVSR2mEiboxgx24ONmy+pdpibu5cxfvWenAScOospU +xbF6lR1xHkopigPcakXBpBlebzbNw6Kwt/5cOOJSvPhEQ+aQuwIDAQABo4ICUjCC +Ak4wPQYIKwYBBQUHAQEEMTAvMC0GCCsGAQUFBzABhiFodHRwczovL29jc3AucXVv +dmFkaXNvZmZzaG9yZS5jb20wDwYDVR0TAQH/BAUwAwEB/zCCARoGA1UdIASCAREw +ggENMIIBCQYJKwYBBAG+WAABMIH7MIHUBggrBgEFBQcCAjCBxxqBxFJlbGlhbmNl +IG9uIHRoZSBRdW9WYWRpcyBSb290IENlcnRpZmljYXRlIGJ5IGFueSBwYXJ0eSBh +c3N1bWVzIGFjY2VwdGFuY2Ugb2YgdGhlIHRoZW4gYXBwbGljYWJsZSBzdGFuZGFy +ZCB0ZXJtcyBhbmQgY29uZGl0aW9ucyBvZiB1c2UsIGNlcnRpZmljYXRpb24gcHJh +Y3RpY2VzLCBhbmQgdGhlIFF1b1ZhZGlzIENlcnRpZmljYXRlIFBvbGljeS4wIgYI +KwYBBQUHAgEWFmh0dHA6Ly93d3cucXVvdmFkaXMuYm0wHQYDVR0OBBYEFItLbe3T +KbkGGew5Oanwl4Rqy+/fMIGuBgNVHSMEgaYwgaOAFItLbe3TKbkGGew5Oanwl4Rq +y+/foYGEpIGBMH8xCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBMaW1p +dGVkMSUwIwYDVQQLExxSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MS4wLAYD +VQQDEyVRdW9WYWRpcyBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5ggQ6tlCL +MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQUFAAOCAQEAitQUtf70mpKnGdSk +fnIYj9lofFIk3WdvOXrEql494liwTXCYhGHoG+NpGA7O+0dQoE7/8CQfvbLO9Sf8 +7C9TqnN7Az10buYWnuulLsS/VidQK2K6vkscPFVcQR0kvoIgR13VRH56FmjffU1R +cHhXHTMe/QKZnAzNCgVPx7uOpHX6Sm2xgI4JVrmcGmD+XcHXetwReNDWXcG31a0y +mQM6isxUJTkxgXsTIlG6Rmyhu576BGxJJnSP0nPrzDCi5upZIof4l/UO/erMkqQW +xFIY6iHOsfHmhIHluqmGKPJDWl0Snawe2ajlCmqnf6CHKc/yiU3U7MXi5nrQNiOK +SnQ2+Q== +-----END CERTIFICATE----- + +# Issuer: CN=QuoVadis Root CA 2 O=QuoVadis Limited +# Subject: CN=QuoVadis Root CA 2 O=QuoVadis Limited +# Label: "QuoVadis Root CA 2" +# Serial: 1289 +# MD5 Fingerprint: 5e:39:7b:dd:f8:ba:ec:82:e9:ac:62:ba:0c:54:00:2b +# SHA1 Fingerprint: ca:3a:fb:cf:12:40:36:4b:44:b2:16:20:88:80:48:39:19:93:7c:f7 +# SHA256 Fingerprint: 85:a0:dd:7d:d7:20:ad:b7:ff:05:f8:3d:54:2b:20:9d:c7:ff:45:28:f7:d6:77:b1:83:89:fe:a5:e5:c4:9e:86 +-----BEGIN CERTIFICATE----- +MIIFtzCCA5+gAwIBAgICBQkwDQYJKoZIhvcNAQEFBQAwRTELMAkGA1UEBhMCQk0x +GTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMTElF1b1ZhZGlzIFJv +b3QgQ0EgMjAeFw0wNjExMjQxODI3MDBaFw0zMTExMjQxODIzMzNaMEUxCzAJBgNV +BAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMRswGQYDVQQDExJRdW9W +YWRpcyBSb290IENBIDIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCa +GMpLlA0ALa8DKYrwD4HIrkwZhR0In6spRIXzL4GtMh6QRr+jhiYaHv5+HBg6XJxg +Fyo6dIMzMH1hVBHL7avg5tKifvVrbxi3Cgst/ek+7wrGsxDp3MJGF/hd/aTa/55J +WpzmM+Yklvc/ulsrHHo1wtZn/qtmUIttKGAr79dgw8eTvI02kfN/+NsRE8Scd3bB +rrcCaoF6qUWD4gXmuVbBlDePSHFjIuwXZQeVikvfj8ZaCuWw419eaxGrDPmF60Tp ++ARz8un+XJiM9XOva7R+zdRcAitMOeGylZUtQofX1bOQQ7dsE/He3fbE+Ik/0XX1 +ksOR1YqI0JDs3G3eicJlcZaLDQP9nL9bFqyS2+r+eXyt66/3FsvbzSUr5R/7mp/i +Ucw6UwxI5g69ybR2BlLmEROFcmMDBOAENisgGQLodKcftslWZvB1JdxnwQ5hYIiz +PtGo/KPaHbDRsSNU30R2be1B2MGyIrZTHN81Hdyhdyox5C315eXbyOD/5YDXC2Og +/zOhD7osFRXql7PSorW+8oyWHhqPHWykYTe5hnMz15eWniN9gqRMgeKh0bpnX5UH +oycR7hYQe7xFSkyyBNKr79X9DFHOUGoIMfmR2gyPZFwDwzqLID9ujWc9Otb+fVuI +yV77zGHcizN300QyNQliBJIWENieJ0f7OyHj+OsdWwIDAQABo4GwMIGtMA8GA1Ud +EwEB/wQFMAMBAf8wCwYDVR0PBAQDAgEGMB0GA1UdDgQWBBQahGK8SEwzJQTU7tD2 +A8QZRtGUazBuBgNVHSMEZzBlgBQahGK8SEwzJQTU7tD2A8QZRtGUa6FJpEcwRTEL +MAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMT +ElF1b1ZhZGlzIFJvb3QgQ0EgMoICBQkwDQYJKoZIhvcNAQEFBQADggIBAD4KFk2f +BluornFdLwUvZ+YTRYPENvbzwCYMDbVHZF34tHLJRqUDGCdViXh9duqWNIAXINzn +g/iN/Ae42l9NLmeyhP3ZRPx3UIHmfLTJDQtyU/h2BwdBR5YM++CCJpNVjP4iH2Bl +fF/nJrP3MpCYUNQ3cVX2kiF495V5+vgtJodmVjB3pjd4M1IQWK4/YY7yarHvGH5K +WWPKjaJW1acvvFYfzznB4vsKqBUsfU16Y8Zsl0Q80m/DShcK+JDSV6IZUaUtl0Ha +B0+pUNqQjZRG4T7wlP0QADj1O+hA4bRuVhogzG9Yje0uRY/W6ZM/57Es3zrWIozc +hLsib9D45MY56QSIPMO661V6bYCZJPVsAfv4l7CUW+v90m/xd2gNNWQjrLhVoQPR +TUIZ3Ph1WVaj+ahJefivDrkRoHy3au000LYmYjgahwz46P0u05B/B5EqHdZ+XIWD +mbA4CD/pXvk1B+TJYm5Xf6dQlfe6yJvmjqIBxdZmv3lh8zwc4bmCXF2gw+nYSL0Z +ohEUGW6yhhtoPkg3Goi3XZZenMfvJ2II4pEZXNLxId26F0KCl3GBUzGpn/Z9Yr9y +4aOTHcyKJloJONDO1w2AFrR4pTqHTI2KpdVGl/IsELm8VCLAAVBpQ570su9t+Oza +8eOx79+Rj1QqCyXBJhnEUhAFZdWCEOrCMc0u +-----END CERTIFICATE----- + +# Issuer: CN=QuoVadis Root CA 3 O=QuoVadis Limited +# Subject: CN=QuoVadis Root CA 3 O=QuoVadis Limited +# Label: "QuoVadis Root CA 3" +# Serial: 1478 +# MD5 Fingerprint: 31:85:3c:62:94:97:63:b9:aa:fd:89:4e:af:6f:e0:cf +# SHA1 Fingerprint: 1f:49:14:f7:d8:74:95:1d:dd:ae:02:c0:be:fd:3a:2d:82:75:51:85 +# SHA256 Fingerprint: 18:f1:fc:7f:20:5d:f8:ad:dd:eb:7f:e0:07:dd:57:e3:af:37:5a:9c:4d:8d:73:54:6b:f4:f1:fe:d1:e1:8d:35 +-----BEGIN CERTIFICATE----- +MIIGnTCCBIWgAwIBAgICBcYwDQYJKoZIhvcNAQEFBQAwRTELMAkGA1UEBhMCQk0x +GTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMTElF1b1ZhZGlzIFJv +b3QgQ0EgMzAeFw0wNjExMjQxOTExMjNaFw0zMTExMjQxOTA2NDRaMEUxCzAJBgNV +BAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMRswGQYDVQQDExJRdW9W +YWRpcyBSb290IENBIDMwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDM +V0IWVJzmmNPTTe7+7cefQzlKZbPoFog02w1ZkXTPkrgEQK0CSzGrvI2RaNggDhoB +4hp7Thdd4oq3P5kazethq8Jlph+3t723j/z9cI8LoGe+AaJZz3HmDyl2/7FWeUUr +H556VOijKTVopAFPD6QuN+8bv+OPEKhyq1hX51SGyMnzW9os2l2ObjyjPtr7guXd +8lyyBTNvijbO0BNO/79KDDRMpsMhvVAEVeuxu537RR5kFd5VAYwCdrXLoT9Cabwv +vWhDFlaJKjdhkf2mrk7AyxRllDdLkgbvBNDInIjbC3uBr7E9KsRlOni27tyAsdLT +mZw67mtaa7ONt9XOnMK+pUsvFrGeaDsGb659n/je7Mwpp5ijJUMv7/FfJuGITfhe +btfZFG4ZM2mnO4SJk8RTVROhUXhA+LjJou57ulJCg54U7QVSWllWp5f8nT8KKdjc +T5EOE7zelaTfi5m+rJsziO+1ga8bxiJTyPbH7pcUsMV8eFLI8M5ud2CEpukqdiDt +WAEXMJPpGovgc2PZapKUSU60rUqFxKMiMPwJ7Wgic6aIDFUhWMXhOp8q3crhkODZ +c6tsgLjoC2SToJyMGf+z0gzskSaHirOi4XCPLArlzW1oUevaPwV/izLmE1xr/l9A +4iLItLRkT9a6fUg+qGkM17uGcclzuD87nSVL2v9A6wIDAQABo4IBlTCCAZEwDwYD +VR0TAQH/BAUwAwEB/zCB4QYDVR0gBIHZMIHWMIHTBgkrBgEEAb5YAAMwgcUwgZMG +CCsGAQUFBwICMIGGGoGDQW55IHVzZSBvZiB0aGlzIENlcnRpZmljYXRlIGNvbnN0 +aXR1dGVzIGFjY2VwdGFuY2Ugb2YgdGhlIFF1b1ZhZGlzIFJvb3QgQ0EgMyBDZXJ0 +aWZpY2F0ZSBQb2xpY3kgLyBDZXJ0aWZpY2F0aW9uIFByYWN0aWNlIFN0YXRlbWVu +dC4wLQYIKwYBBQUHAgEWIWh0dHA6Ly93d3cucXVvdmFkaXNnbG9iYWwuY29tL2Nw +czALBgNVHQ8EBAMCAQYwHQYDVR0OBBYEFPLAE+CCQz777i9nMpY1XNu4ywLQMG4G +A1UdIwRnMGWAFPLAE+CCQz777i9nMpY1XNu4ywLQoUmkRzBFMQswCQYDVQQGEwJC +TTEZMBcGA1UEChMQUXVvVmFkaXMgTGltaXRlZDEbMBkGA1UEAxMSUXVvVmFkaXMg +Um9vdCBDQSAzggIFxjANBgkqhkiG9w0BAQUFAAOCAgEAT62gLEz6wPJv92ZVqyM0 +7ucp2sNbtrCD2dDQ4iH782CnO11gUyeim/YIIirnv6By5ZwkajGxkHon24QRiSem +d1o417+shvzuXYO8BsbRd2sPbSQvS3pspweWyuOEn62Iix2rFo1bZhfZFvSLgNLd ++LJ2w/w4E6oM3kJpK27zPOuAJ9v1pkQNn1pVWQvVDVJIxa6f8i+AxeoyUDUSly7B +4f/xI4hROJ/yZlZ25w9Rl6VSDE1JUZU2Pb+iSwwQHYaZTKrzchGT5Or2m9qoXadN +t54CrnMAyNojA+j56hl0YgCUyyIgvpSnWbWCar6ZeXqp8kokUvd0/bpO5qgdAm6x +DYBEwa7TIzdfu4V8K5Iu6H6li92Z4b8nby1dqnuH/grdS/yO9SbkbnBCbjPsMZ57 +k8HkyWkaPcBrTiJt7qtYTcbQQcEr6k8Sh17rRdhs9ZgC06DYVYoGmRmioHfRMJ6s +zHXug/WwYjnPbFfiTNKRCw51KBuav/0aQ/HKd/s7j2G4aSgWQgRecCocIdiP4b0j +Wy10QJLZYxkNc91pvGJHvOB0K7Lrfb5BG7XARsWhIstfTsEokt4YutUqKLsRixeT +mJlglFwjz1onl14LBQaTNx47aTbrqZ5hHY8y2o4M1nQ+ewkk2gF3R8Q7zTSMmfXK +4SVhM7JZG+Ju1zdXtg2pEto= +-----END CERTIFICATE----- + +# Issuer: O=SECOM Trust.net OU=Security Communication RootCA1 +# Subject: O=SECOM Trust.net OU=Security Communication RootCA1 +# Label: "Security Communication Root CA" +# Serial: 0 +# MD5 Fingerprint: f1:bc:63:6a:54:e0:b5:27:f5:cd:e7:1a:e3:4d:6e:4a +# SHA1 Fingerprint: 36:b1:2b:49:f9:81:9e:d7:4c:9e:bc:38:0f:c6:56:8f:5d:ac:b2:f7 +# SHA256 Fingerprint: e7:5e:72:ed:9f:56:0e:ec:6e:b4:80:00:73:a4:3f:c3:ad:19:19:5a:39:22:82:01:78:95:97:4a:99:02:6b:6c +-----BEGIN CERTIFICATE----- +MIIDWjCCAkKgAwIBAgIBADANBgkqhkiG9w0BAQUFADBQMQswCQYDVQQGEwJKUDEY +MBYGA1UEChMPU0VDT00gVHJ1c3QubmV0MScwJQYDVQQLEx5TZWN1cml0eSBDb21t +dW5pY2F0aW9uIFJvb3RDQTEwHhcNMDMwOTMwMDQyMDQ5WhcNMjMwOTMwMDQyMDQ5 +WjBQMQswCQYDVQQGEwJKUDEYMBYGA1UEChMPU0VDT00gVHJ1c3QubmV0MScwJQYD +VQQLEx5TZWN1cml0eSBDb21tdW5pY2F0aW9uIFJvb3RDQTEwggEiMA0GCSqGSIb3 +DQEBAQUAA4IBDwAwggEKAoIBAQCzs/5/022x7xZ8V6UMbXaKL0u/ZPtM7orw8yl8 +9f/uKuDp6bpbZCKamm8sOiZpUQWZJtzVHGpxxpp9Hp3dfGzGjGdnSj74cbAZJ6kJ +DKaVv0uMDPpVmDvY6CKhS3E4eayXkmmziX7qIWgGmBSWh9JhNrxtJ1aeV+7AwFb9 +Ms+k2Y7CI9eNqPPYJayX5HA49LY6tJ07lyZDo6G8SVlyTCMwhwFY9k6+HGhWZq/N +QV3Is00qVUarH9oe4kA92819uZKAnDfdDJZkndwi92SL32HeFZRSFaB9UslLqCHJ +xrHty8OVYNEP8Ktw+N/LTX7s1vqr2b1/VPKl6Xn62dZ2JChzAgMBAAGjPzA9MB0G +A1UdDgQWBBSgc0mZaNyFW2XjmygvV5+9M7wHSDALBgNVHQ8EBAMCAQYwDwYDVR0T +AQH/BAUwAwEB/zANBgkqhkiG9w0BAQUFAAOCAQEAaECpqLvkT115swW1F7NgE+vG +kl3g0dNq/vu+m22/xwVtWSDEHPC32oRYAmP6SBbvT6UL90qY8j+eG61Ha2POCEfr +Uj94nK9NrvjVT8+amCoQQTlSxN3Zmw7vkwGusi7KaEIkQmywszo+zenaSMQVy+n5 +Bw+SUEmK3TGXX8npN6o7WWWXlDLJs58+OmJYxUmtYg5xpTKqL8aJdkNAExNnPaJU +JRDL8Try2frbSVa7pv6nQTXD4IhhyYjH3zYQIphZ6rBK+1YWc26sTfcioU+tHXot +RSflMMFe8toTyyVCUZVHA4xsIcx0Qu1T/zOLjw9XARYvz6buyXAiFL39vmwLAw== +-----END CERTIFICATE----- + +# Issuer: CN=Sonera Class2 CA O=Sonera +# Subject: CN=Sonera Class2 CA O=Sonera +# Label: "Sonera Class 2 Root CA" +# Serial: 29 +# MD5 Fingerprint: a3:ec:75:0f:2e:88:df:fa:48:01:4e:0b:5c:48:6f:fb +# SHA1 Fingerprint: 37:f7:6d:e6:07:7c:90:c5:b1:3e:93:1a:b7:41:10:b4:f2:e4:9a:27 +# SHA256 Fingerprint: 79:08:b4:03:14:c1:38:10:0b:51:8d:07:35:80:7f:fb:fc:f8:51:8a:00:95:33:71:05:ba:38:6b:15:3d:d9:27 +-----BEGIN CERTIFICATE----- +MIIDIDCCAgigAwIBAgIBHTANBgkqhkiG9w0BAQUFADA5MQswCQYDVQQGEwJGSTEP +MA0GA1UEChMGU29uZXJhMRkwFwYDVQQDExBTb25lcmEgQ2xhc3MyIENBMB4XDTAx +MDQwNjA3Mjk0MFoXDTIxMDQwNjA3Mjk0MFowOTELMAkGA1UEBhMCRkkxDzANBgNV +BAoTBlNvbmVyYTEZMBcGA1UEAxMQU29uZXJhIENsYXNzMiBDQTCCASIwDQYJKoZI +hvcNAQEBBQADggEPADCCAQoCggEBAJAXSjWdyvANlsdE+hY3/Ei9vX+ALTU74W+o +Z6m/AxxNjG8yR9VBaKQTBME1DJqEQ/xcHf+Js+gXGM2RX/uJ4+q/Tl18GybTdXnt +5oTjV+WtKcT0OijnpXuENmmz/V52vaMtmdOQTiMofRhj8VQ7Jp12W5dCsv+u8E7s +3TmVToMGf+dJQMjFAbJUWmYdPfz56TwKnoG4cPABi+QjVHzIrviQHgCWctRUz2Ej +vOr7nQKV0ba5cTppCD8PtOFCx4j1P5iop7oc4HFx71hXgVB6XGt0Rg6DA5jDjqhu +8nYybieDwnPz3BjotJPqdURrBGAgcVeHnfO+oJAjPYok4doh28MCAwEAAaMzMDEw +DwYDVR0TAQH/BAUwAwEB/zARBgNVHQ4ECgQISqCqWITTXjwwCwYDVR0PBAQDAgEG +MA0GCSqGSIb3DQEBBQUAA4IBAQBazof5FnIVV0sd2ZvnoiYw7JNn39Yt0jSv9zil +zqsWuasvfDXLrNAPtEwr/IDva4yRXzZ299uzGxnq9LIR/WFxRL8oszodv7ND6J+/ +3DEIcbCdjdY0RzKQxmUk96BKfARzjzlvF4xytb1LyHr4e4PDKE6cCepnP7JnBBvD +FNr450kkkdAdavphOe9r5yF1BgfYErQhIHBCcYHaPJo2vqZbDWpsmh+Re/n570K6 +Tk6ezAyNlNzZRZxe7EJQY670XcSxEtzKO6gunRRaBXW37Ndj4ro1tgQIkejanZz2 +ZrUYrAqmVCY0M9IbwdR/GjqOC6oybtv8TyWf2TLHllpwrN9M +-----END CERTIFICATE----- + +# Issuer: CN=XRamp Global Certification Authority O=XRamp Security Services Inc OU=www.xrampsecurity.com +# Subject: CN=XRamp Global Certification Authority O=XRamp Security Services Inc OU=www.xrampsecurity.com +# Label: "XRamp Global CA Root" +# Serial: 107108908803651509692980124233745014957 +# MD5 Fingerprint: a1:0b:44:b3:ca:10:d8:00:6e:9d:0f:d8:0f:92:0a:d1 +# SHA1 Fingerprint: b8:01:86:d1:eb:9c:86:a5:41:04:cf:30:54:f3:4c:52:b7:e5:58:c6 +# SHA256 Fingerprint: ce:cd:dc:90:50:99:d8:da:df:c5:b1:d2:09:b7:37:cb:e2:c1:8c:fb:2c:10:c0:ff:0b:cf:0d:32:86:fc:1a:a2 +-----BEGIN CERTIFICATE----- +MIIEMDCCAxigAwIBAgIQUJRs7Bjq1ZxN1ZfvdY+grTANBgkqhkiG9w0BAQUFADCB +gjELMAkGA1UEBhMCVVMxHjAcBgNVBAsTFXd3dy54cmFtcHNlY3VyaXR5LmNvbTEk +MCIGA1UEChMbWFJhbXAgU2VjdXJpdHkgU2VydmljZXMgSW5jMS0wKwYDVQQDEyRY +UmFtcCBHbG9iYWwgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDQxMTAxMTcx +NDA0WhcNMzUwMTAxMDUzNzE5WjCBgjELMAkGA1UEBhMCVVMxHjAcBgNVBAsTFXd3 +dy54cmFtcHNlY3VyaXR5LmNvbTEkMCIGA1UEChMbWFJhbXAgU2VjdXJpdHkgU2Vy +dmljZXMgSW5jMS0wKwYDVQQDEyRYUmFtcCBHbG9iYWwgQ2VydGlmaWNhdGlvbiBB +dXRob3JpdHkwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCYJB69FbS6 +38eMpSe2OAtp87ZOqCwuIR1cRN8hXX4jdP5efrRKt6atH67gBhbim1vZZ3RrXYCP +KZ2GG9mcDZhtdhAoWORlsH9KmHmf4MMxfoArtYzAQDsRhtDLooY2YKTVMIJt2W7Q +DxIEM5dfT2Fa8OT5kavnHTu86M/0ay00fOJIYRyO82FEzG+gSqmUsE3a56k0enI4 +qEHMPJQRfevIpoy3hsvKMzvZPTeL+3o+hiznc9cKV6xkmxnr9A8ECIqsAxcZZPRa +JSKNNCyy9mgdEm3Tih4U2sSPpuIjhdV6Db1q4Ons7Be7QhtnqiXtRYMh/MHJfNVi +PvryxS3T/dRlAgMBAAGjgZ8wgZwwEwYJKwYBBAGCNxQCBAYeBABDAEEwCwYDVR0P +BAQDAgGGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFMZPoj0GY4QJnM5i5ASs +jVy16bYbMDYGA1UdHwQvMC0wK6ApoCeGJWh0dHA6Ly9jcmwueHJhbXBzZWN1cml0 +eS5jb20vWEdDQS5jcmwwEAYJKwYBBAGCNxUBBAMCAQEwDQYJKoZIhvcNAQEFBQAD +ggEBAJEVOQMBG2f7Shz5CmBbodpNl2L5JFMn14JkTpAuw0kbK5rc/Kh4ZzXxHfAR +vbdI4xD2Dd8/0sm2qlWkSLoC295ZLhVbO50WfUfXN+pfTXYSNrsf16GBBEYgoyxt +qZ4Bfj8pzgCT3/3JknOJiWSe5yvkHJEs0rnOfc5vMZnT5r7SHpDwCRR5XCOrTdLa +IR9NmXmd4c8nnxCbHIgNsIpkQTG4DmyQJKSbXHGPurt+HBvbaoAPIbzp26a3QPSy +i6mx5O+aGtA9aZnuqCij4Tyz8LIRnM98QObd50N9otg6tamN8jSZxNQQ4Qb9CYQQ +O+7ETPTsJ3xCwnR8gooJybQDJbw= +-----END CERTIFICATE----- + +# Issuer: O=The Go Daddy Group, Inc. OU=Go Daddy Class 2 Certification Authority +# Subject: O=The Go Daddy Group, Inc. OU=Go Daddy Class 2 Certification Authority +# Label: "Go Daddy Class 2 CA" +# Serial: 0 +# MD5 Fingerprint: 91:de:06:25:ab:da:fd:32:17:0c:bb:25:17:2a:84:67 +# SHA1 Fingerprint: 27:96:ba:e6:3f:18:01:e2:77:26:1b:a0:d7:77:70:02:8f:20:ee:e4 +# SHA256 Fingerprint: c3:84:6b:f2:4b:9e:93:ca:64:27:4c:0e:c6:7c:1e:cc:5e:02:4f:fc:ac:d2:d7:40:19:35:0e:81:fe:54:6a:e4 +-----BEGIN CERTIFICATE----- +MIIEADCCAuigAwIBAgIBADANBgkqhkiG9w0BAQUFADBjMQswCQYDVQQGEwJVUzEh +MB8GA1UEChMYVGhlIEdvIERhZGR5IEdyb3VwLCBJbmMuMTEwLwYDVQQLEyhHbyBE +YWRkeSBDbGFzcyAyIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTA0MDYyOTE3 +MDYyMFoXDTM0MDYyOTE3MDYyMFowYzELMAkGA1UEBhMCVVMxITAfBgNVBAoTGFRo +ZSBHbyBEYWRkeSBHcm91cCwgSW5jLjExMC8GA1UECxMoR28gRGFkZHkgQ2xhc3Mg +MiBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTCCASAwDQYJKoZIhvcNAQEBBQADggEN +ADCCAQgCggEBAN6d1+pXGEmhW+vXX0iG6r7d/+TvZxz0ZWizV3GgXne77ZtJ6XCA +PVYYYwhv2vLM0D9/AlQiVBDYsoHUwHU9S3/Hd8M+eKsaA7Ugay9qK7HFiH7Eux6w +wdhFJ2+qN1j3hybX2C32qRe3H3I2TqYXP2WYktsqbl2i/ojgC95/5Y0V4evLOtXi +EqITLdiOr18SPaAIBQi2XKVlOARFmR6jYGB0xUGlcmIbYsUfb18aQr4CUWWoriMY +avx4A6lNf4DD+qta/KFApMoZFv6yyO9ecw3ud72a9nmYvLEHZ6IVDd2gWMZEewo+ +YihfukEHU1jPEX44dMX4/7VpkI+EdOqXG68CAQOjgcAwgb0wHQYDVR0OBBYEFNLE +sNKR1EwRcbNhyz2h/t2oatTjMIGNBgNVHSMEgYUwgYKAFNLEsNKR1EwRcbNhyz2h +/t2oatTjoWekZTBjMQswCQYDVQQGEwJVUzEhMB8GA1UEChMYVGhlIEdvIERhZGR5 +IEdyb3VwLCBJbmMuMTEwLwYDVQQLEyhHbyBEYWRkeSBDbGFzcyAyIENlcnRpZmlj +YXRpb24gQXV0aG9yaXR5ggEAMAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEFBQAD +ggEBADJL87LKPpH8EsahB4yOd6AzBhRckB4Y9wimPQoZ+YeAEW5p5JYXMP80kWNy +OO7MHAGjHZQopDH2esRU1/blMVgDoszOYtuURXO1v0XJJLXVggKtI3lpjbi2Tc7P +TMozI+gciKqdi0FuFskg5YmezTvacPd+mSYgFFQlq25zheabIZ0KbIIOqPjCDPoQ +HmyW74cNxA9hi63ugyuV+I6ShHI56yDqg+2DzZduCLzrTia2cyvk0/ZM/iZx4mER +dEr/VxqHD3VILs9RaRegAhJhldXRQLIQTO7ErBBDpqWeCtWVYpoNz4iCxTIM5Cuf +ReYNnyicsbkqWletNw+vHX/bvZ8= +-----END CERTIFICATE----- + +# Issuer: O=Starfield Technologies, Inc. OU=Starfield Class 2 Certification Authority +# Subject: O=Starfield Technologies, Inc. OU=Starfield Class 2 Certification Authority +# Label: "Starfield Class 2 CA" +# Serial: 0 +# MD5 Fingerprint: 32:4a:4b:bb:c8:63:69:9b:be:74:9a:c6:dd:1d:46:24 +# SHA1 Fingerprint: ad:7e:1c:28:b0:64:ef:8f:60:03:40:20:14:c3:d0:e3:37:0e:b5:8a +# SHA256 Fingerprint: 14:65:fa:20:53:97:b8:76:fa:a6:f0:a9:95:8e:55:90:e4:0f:cc:7f:aa:4f:b7:c2:c8:67:75:21:fb:5f:b6:58 +-----BEGIN CERTIFICATE----- +MIIEDzCCAvegAwIBAgIBADANBgkqhkiG9w0BAQUFADBoMQswCQYDVQQGEwJVUzEl +MCMGA1UEChMcU3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjEyMDAGA1UECxMp +U3RhcmZpZWxkIENsYXNzIDIgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDQw +NjI5MTczOTE2WhcNMzQwNjI5MTczOTE2WjBoMQswCQYDVQQGEwJVUzElMCMGA1UE +ChMcU3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjEyMDAGA1UECxMpU3RhcmZp +ZWxkIENsYXNzIDIgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwggEgMA0GCSqGSIb3 +DQEBAQUAA4IBDQAwggEIAoIBAQC3Msj+6XGmBIWtDBFk385N78gDGIc/oav7PKaf +8MOh2tTYbitTkPskpD6E8J7oX+zlJ0T1KKY/e97gKvDIr1MvnsoFAZMej2YcOadN ++lq2cwQlZut3f+dZxkqZJRRU6ybH838Z1TBwj6+wRir/resp7defqgSHo9T5iaU0 +X9tDkYI22WY8sbi5gv2cOj4QyDvvBmVmepsZGD3/cVE8MC5fvj13c7JdBmzDI1aa +K4UmkhynArPkPw2vCHmCuDY96pzTNbO8acr1zJ3o/WSNF4Azbl5KXZnJHoe0nRrA +1W4TNSNe35tfPe/W93bC6j67eA0cQmdrBNj41tpvi/JEoAGrAgEDo4HFMIHCMB0G +A1UdDgQWBBS/X7fRzt0fhvRbVazc1xDCDqmI5zCBkgYDVR0jBIGKMIGHgBS/X7fR +zt0fhvRbVazc1xDCDqmI56FspGowaDELMAkGA1UEBhMCVVMxJTAjBgNVBAoTHFN0 +YXJmaWVsZCBUZWNobm9sb2dpZXMsIEluYy4xMjAwBgNVBAsTKVN0YXJmaWVsZCBD +bGFzcyAyIENlcnRpZmljYXRpb24gQXV0aG9yaXR5ggEAMAwGA1UdEwQFMAMBAf8w +DQYJKoZIhvcNAQEFBQADggEBAAWdP4id0ckaVaGsafPzWdqbAYcaT1epoXkJKtv3 +L7IezMdeatiDh6GX70k1PncGQVhiv45YuApnP+yz3SFmH8lU+nLMPUxA2IGvd56D +eruix/U0F47ZEUD0/CwqTRV/p2JdLiXTAAsgGh1o+Re49L2L7ShZ3U0WixeDyLJl +xy16paq8U4Zt3VekyvggQQto8PT7dL5WXXp59fkdheMtlb71cZBDzI0fmgAKhynp +VSJYACPq4xJDKVtHCN2MQWplBqjlIapBtJUhlbl90TSrE9atvNziPTnNvT51cKEY +WQPJIrSPnNVeKtelttQKbfi3QBFGmh95DmK/D5fs4C8fF5Q= +-----END CERTIFICATE----- + +# Issuer: O=Government Root Certification Authority +# Subject: O=Government Root Certification Authority +# Label: "Taiwan GRCA" +# Serial: 42023070807708724159991140556527066870 +# MD5 Fingerprint: 37:85:44:53:32:45:1f:20:f0:f3:95:e1:25:c4:43:4e +# SHA1 Fingerprint: f4:8b:11:bf:de:ab:be:94:54:20:71:e6:41:de:6b:be:88:2b:40:b9 +# SHA256 Fingerprint: 76:00:29:5e:ef:e8:5b:9e:1f:d6:24:db:76:06:2a:aa:ae:59:81:8a:54:d2:77:4c:d4:c0:b2:c0:11:31:e1:b3 +-----BEGIN CERTIFICATE----- +MIIFcjCCA1qgAwIBAgIQH51ZWtcvwgZEpYAIaeNe9jANBgkqhkiG9w0BAQUFADA/ +MQswCQYDVQQGEwJUVzEwMC4GA1UECgwnR292ZXJubWVudCBSb290IENlcnRpZmlj +YXRpb24gQXV0aG9yaXR5MB4XDTAyMTIwNTEzMjMzM1oXDTMyMTIwNTEzMjMzM1ow +PzELMAkGA1UEBhMCVFcxMDAuBgNVBAoMJ0dvdmVybm1lbnQgUm9vdCBDZXJ0aWZp +Y2F0aW9uIEF1dGhvcml0eTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIB +AJoluOzMonWoe/fOW1mKydGGEghU7Jzy50b2iPN86aXfTEc2pBsBHH8eV4qNw8XR +IePaJD9IK/ufLqGU5ywck9G/GwGHU5nOp/UKIXZ3/6m3xnOUT0b3EEk3+qhZSV1q +gQdW8or5BtD3cCJNtLdBuTK4sfCxw5w/cP1T3YGq2GN49thTbqGsaoQkclSGxtKy +yhwOeYHWtXBiCAEuTk8O1RGvqa/lmr/czIdtJuTJV6L7lvnM4T9TjGxMfptTCAts +F/tnyMKtsc2AtJfcdgEWFelq16TheEfOhtX7MfP6Mb40qij7cEwdScevLJ1tZqa2 +jWR+tSBqnTuBto9AAGdLiYa4zGX+FVPpBMHWXx1E1wovJ5pGfaENda1UhhXcSTvx +ls4Pm6Dso3pdvtUqdULle96ltqqvKKyskKw4t9VoNSZ63Pc78/1Fm9G7Q3hub/FC +VGqY8A2tl+lSXunVanLeavcbYBT0peS2cWeqH+riTcFCQP5nRhc4L0c/cZyu5SHK +YS1tB6iEfC3uUSXxY5Ce/eFXiGvviiNtsea9P63RPZYLhY3Naye7twWb7LuRqQoH +EgKXTiCQ8P8NHuJBO9NAOueNXdpm5AKwB1KYXA6OM5zCppX7VRluTI6uSw+9wThN +Xo+EHWbNxWCWtFJaBYmOlXqYwZE8lSOyDvR5tMl8wUohAgMBAAGjajBoMB0GA1Ud +DgQWBBTMzO/MKWCkO7GStjz6MmKPrCUVOzAMBgNVHRMEBTADAQH/MDkGBGcqBwAE +MTAvMC0CAQAwCQYFKw4DAhoFADAHBgVnKgMAAAQUA5vwIhP/lSg209yewDL7MTqK +UWUwDQYJKoZIhvcNAQEFBQADggIBAECASvomyc5eMN1PhnR2WPWus4MzeKR6dBcZ +TulStbngCnRiqmjKeKBMmo4sIy7VahIkv9Ro04rQ2JyftB8M3jh+Vzj8jeJPXgyf +qzvS/3WXy6TjZwj/5cAWtUgBfen5Cv8b5Wppv3ghqMKnI6mGq3ZW6A4M9hPdKmaK +ZEk9GhiHkASfQlK3T8v+R0F2Ne//AHY2RTKbxkaFXeIksB7jSJaYV0eUVXoPQbFE +JPPB/hprv4j9wabak2BegUqZIJxIZhm1AHlUD7gsL0u8qV1bYH+Mh6XgUmMqvtg7 +hUAV/h62ZT/FS9p+tXo1KaMuephgIqP0fSdOLeq0dDzpD6QzDxARvBMB1uUO07+1 +EqLhRSPAzAhuYbeJq4PjJB7mXQfnHyA+z2fI56wwbSdLaG5LKlwCCDTb+HbkZ6Mm +nD+iMsJKxYEYMRBWqoTvLQr/uB930r+lWKBi5NdLkXWNiYCYfm3LU05er/ayl4WX +udpVBrkk7tfGOB5jGxI7leFYrPLfhNVfmS8NVVvmONsuP3LpSIXLuykTjx44Vbnz +ssQwmSNOXfJIoRIM3BKQCZBUkQM8R+XVyWXgt0t97EfTsws+rZ7QdAAO671RrcDe +LMDDav7v3Aun+kbfYNucpllQdSNpc5Oy+fwC00fmcc4QAu4njIT/rEUNE1yDMuAl +pYYsfPQS +-----END CERTIFICATE----- + +# Issuer: CN=DigiCert Assured ID Root CA O=DigiCert Inc OU=www.digicert.com +# Subject: CN=DigiCert Assured ID Root CA O=DigiCert Inc OU=www.digicert.com +# Label: "DigiCert Assured ID Root CA" +# Serial: 17154717934120587862167794914071425081 +# MD5 Fingerprint: 87:ce:0b:7b:2a:0e:49:00:e1:58:71:9b:37:a8:93:72 +# SHA1 Fingerprint: 05:63:b8:63:0d:62:d7:5a:bb:c8:ab:1e:4b:df:b5:a8:99:b2:4d:43 +# SHA256 Fingerprint: 3e:90:99:b5:01:5e:8f:48:6c:00:bc:ea:9d:11:1e:e7:21:fa:ba:35:5a:89:bc:f1:df:69:56:1e:3d:c6:32:5c +-----BEGIN CERTIFICATE----- +MIIDtzCCAp+gAwIBAgIQDOfg5RfYRv6P5WD8G/AwOTANBgkqhkiG9w0BAQUFADBl +MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 +d3cuZGlnaWNlcnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJv +b3QgQ0EwHhcNMDYxMTEwMDAwMDAwWhcNMzExMTEwMDAwMDAwWjBlMQswCQYDVQQG +EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNl +cnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgQ0EwggEi +MA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCtDhXO5EOAXLGH87dg+XESpa7c +JpSIqvTO9SA5KFhgDPiA2qkVlTJhPLWxKISKityfCgyDF3qPkKyK53lTXDGEKvYP +mDI2dsze3Tyoou9q+yHyUmHfnyDXH+Kx2f4YZNISW1/5WBg1vEfNoTb5a3/UsDg+ +wRvDjDPZ2C8Y/igPs6eD1sNuRMBhNZYW/lmci3Zt1/GiSw0r/wty2p5g0I6QNcZ4 +VYcgoc/lbQrISXwxmDNsIumH0DJaoroTghHtORedmTpyoeb6pNnVFzF1roV9Iq4/ +AUaG9ih5yLHa5FcXxH4cDrC0kqZWs72yl+2qp/C3xag/lRbQ/6GW6whfGHdPAgMB +AAGjYzBhMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQW +BBRF66Kv9JLLgjEtUYunpyGd823IDzAfBgNVHSMEGDAWgBRF66Kv9JLLgjEtUYun +pyGd823IDzANBgkqhkiG9w0BAQUFAAOCAQEAog683+Lt8ONyc3pklL/3cmbYMuRC +dWKuh+vy1dneVrOfzM4UKLkNl2BcEkxY5NM9g0lFWJc1aRqoR+pWxnmrEthngYTf +fwk8lOa4JiwgvT2zKIn3X/8i4peEH+ll74fg38FnSbNd67IJKusm7Xi+fT8r87cm +NW1fiQG2SVufAQWbqz0lwcy2f8Lxb4bG+mRo64EtlOtCt/qMHt1i8b5QZ7dsvfPx +H2sMNgcWfzd8qVttevESRmCD1ycEvkvOl77DZypoEd+A5wwzZr8TDRRu838fYxAe ++o0bJW1sj6W3YQGx0qMmoRBxna3iw/nDmVG3KwcIzi7mULKn+gpFL6Lw8g== +-----END CERTIFICATE----- + +# Issuer: CN=DigiCert Global Root CA O=DigiCert Inc OU=www.digicert.com +# Subject: CN=DigiCert Global Root CA O=DigiCert Inc OU=www.digicert.com +# Label: "DigiCert Global Root CA" +# Serial: 10944719598952040374951832963794454346 +# MD5 Fingerprint: 79:e4:a9:84:0d:7d:3a:96:d7:c0:4f:e2:43:4c:89:2e +# SHA1 Fingerprint: a8:98:5d:3a:65:e5:e5:c4:b2:d7:d6:6d:40:c6:dd:2f:b1:9c:54:36 +# SHA256 Fingerprint: 43:48:a0:e9:44:4c:78:cb:26:5e:05:8d:5e:89:44:b4:d8:4f:96:62:bd:26:db:25:7f:89:34:a4:43:c7:01:61 +-----BEGIN CERTIFICATE----- +MIIDrzCCApegAwIBAgIQCDvgVpBCRrGhdWrJWZHHSjANBgkqhkiG9w0BAQUFADBh +MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 +d3cuZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBD +QTAeFw0wNjExMTAwMDAwMDBaFw0zMTExMTAwMDAwMDBaMGExCzAJBgNVBAYTAlVT +MRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5j +b20xIDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IENBMIIBIjANBgkqhkiG +9w0BAQEFAAOCAQ8AMIIBCgKCAQEA4jvhEXLeqKTTo1eqUKKPC3eQyaKl7hLOllsB +CSDMAZOnTjC3U/dDxGkAV53ijSLdhwZAAIEJzs4bg7/fzTtxRuLWZscFs3YnFo97 +nh6Vfe63SKMI2tavegw5BmV/Sl0fvBf4q77uKNd0f3p4mVmFaG5cIzJLv07A6Fpt +43C/dxC//AH2hdmoRBBYMql1GNXRor5H4idq9Joz+EkIYIvUX7Q6hL+hqkpMfT7P +T19sdl6gSzeRntwi5m3OFBqOasv+zbMUZBfHWymeMr/y7vrTC0LUq7dBMtoM1O/4 +gdW7jVg/tRvoSSiicNoxBN33shbyTApOB6jtSj1etX+jkMOvJwIDAQABo2MwYTAO +BgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUA95QNVbR +TLtm8KPiGxvDl7I90VUwHwYDVR0jBBgwFoAUA95QNVbRTLtm8KPiGxvDl7I90VUw +DQYJKoZIhvcNAQEFBQADggEBAMucN6pIExIK+t1EnE9SsPTfrgT1eXkIoyQY/Esr +hMAtudXH/vTBH1jLuG2cenTnmCmrEbXjcKChzUyImZOMkXDiqw8cvpOp/2PV5Adg +06O/nVsJ8dWO41P0jmP6P6fbtGbfYmbW0W5BjfIttep3Sp+dWOIrWcBAI+0tKIJF +PnlUkiaY4IBIqDfv8NZ5YBberOgOzW6sRBc4L0na4UU+Krk2U886UAb3LujEV0ls +YSEY1QSteDwsOoBrp+uvFRTp2InBuThs4pFsiv9kuXclVzDAGySj4dzp30d8tbQk +CAUw7C29C79Fv1C5qfPrmAESrciIxpg0X40KPMbp1ZWVbd4= +-----END CERTIFICATE----- + +# Issuer: CN=DigiCert High Assurance EV Root CA O=DigiCert Inc OU=www.digicert.com +# Subject: CN=DigiCert High Assurance EV Root CA O=DigiCert Inc OU=www.digicert.com +# Label: "DigiCert High Assurance EV Root CA" +# Serial: 3553400076410547919724730734378100087 +# MD5 Fingerprint: d4:74:de:57:5c:39:b2:d3:9c:85:83:c5:c0:65:49:8a +# SHA1 Fingerprint: 5f:b7:ee:06:33:e2:59:db:ad:0c:4c:9a:e6:d3:8f:1a:61:c7:dc:25 +# SHA256 Fingerprint: 74:31:e5:f4:c3:c1:ce:46:90:77:4f:0b:61:e0:54:40:88:3b:a9:a0:1e:d0:0b:a6:ab:d7:80:6e:d3:b1:18:cf +-----BEGIN CERTIFICATE----- +MIIDxTCCAq2gAwIBAgIQAqxcJmoLQJuPC3nyrkYldzANBgkqhkiG9w0BAQUFADBs +MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 +d3cuZGlnaWNlcnQuY29tMSswKQYDVQQDEyJEaWdpQ2VydCBIaWdoIEFzc3VyYW5j +ZSBFViBSb290IENBMB4XDTA2MTExMDAwMDAwMFoXDTMxMTExMDAwMDAwMFowbDEL +MAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IEluYzEZMBcGA1UECxMQd3d3 +LmRpZ2ljZXJ0LmNvbTErMCkGA1UEAxMiRGlnaUNlcnQgSGlnaCBBc3N1cmFuY2Ug +RVYgUm9vdCBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMbM5XPm ++9S75S0tMqbf5YE/yc0lSbZxKsPVlDRnogocsF9ppkCxxLeyj9CYpKlBWTrT3JTW +PNt0OKRKzE0lgvdKpVMSOO7zSW1xkX5jtqumX8OkhPhPYlG++MXs2ziS4wblCJEM +xChBVfvLWokVfnHoNb9Ncgk9vjo4UFt3MRuNs8ckRZqnrG0AFFoEt7oT61EKmEFB +Ik5lYYeBQVCmeVyJ3hlKV9Uu5l0cUyx+mM0aBhakaHPQNAQTXKFx01p8VdteZOE3 +hzBWBOURtCmAEvF5OYiiAhF8J2a3iLd48soKqDirCmTCv2ZdlYTBoSUeh10aUAsg +EsxBu24LUTi4S8sCAwEAAaNjMGEwDgYDVR0PAQH/BAQDAgGGMA8GA1UdEwEB/wQF +MAMBAf8wHQYDVR0OBBYEFLE+w2kD+L9HAdSYJhoIAu9jZCvDMB8GA1UdIwQYMBaA +FLE+w2kD+L9HAdSYJhoIAu9jZCvDMA0GCSqGSIb3DQEBBQUAA4IBAQAcGgaX3Nec +nzyIZgYIVyHbIUf4KmeqvxgydkAQV8GK83rZEWWONfqe/EW1ntlMMUu4kehDLI6z +eM7b41N5cdblIZQB2lWHmiRk9opmzN6cN82oNLFpmyPInngiK3BD41VHMWEZ71jF +hS9OMPagMRYjyOfiZRYzy78aG6A9+MpeizGLYAiJLQwGXFK3xPkKmNEVX58Svnw2 +Yzi9RKR/5CYrCsSXaQ3pjOLAEFe4yHYSkVXySGnYvCoCWw9E1CAx2/S6cCZdkGCe +vEsXCS+0yx5DaMkHJ8HSXPfqIbloEpw8nL+e/IBcm2PN7EeqJSdnoDfzAIJ9VNep ++OkuE6N36B9K +-----END CERTIFICATE----- + +# Issuer: CN=Class 2 Primary CA O=Certplus +# Subject: CN=Class 2 Primary CA O=Certplus +# Label: "Certplus Class 2 Primary CA" +# Serial: 177770208045934040241468760488327595043 +# MD5 Fingerprint: 88:2c:8c:52:b8:a2:3c:f3:f7:bb:03:ea:ae:ac:42:0b +# SHA1 Fingerprint: 74:20:74:41:72:9c:dd:92:ec:79:31:d8:23:10:8d:c2:81:92:e2:bb +# SHA256 Fingerprint: 0f:99:3c:8a:ef:97:ba:af:56:87:14:0e:d5:9a:d1:82:1b:b4:af:ac:f0:aa:9a:58:b5:d5:7a:33:8a:3a:fb:cb +-----BEGIN CERTIFICATE----- +MIIDkjCCAnqgAwIBAgIRAIW9S/PY2uNp9pTXX8OlRCMwDQYJKoZIhvcNAQEFBQAw +PTELMAkGA1UEBhMCRlIxETAPBgNVBAoTCENlcnRwbHVzMRswGQYDVQQDExJDbGFz +cyAyIFByaW1hcnkgQ0EwHhcNOTkwNzA3MTcwNTAwWhcNMTkwNzA2MjM1OTU5WjA9 +MQswCQYDVQQGEwJGUjERMA8GA1UEChMIQ2VydHBsdXMxGzAZBgNVBAMTEkNsYXNz +IDIgUHJpbWFyeSBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANxQ +ltAS+DXSCHh6tlJw/W/uz7kRy1134ezpfgSN1sxvc0NXYKwzCkTsA18cgCSR5aiR +VhKC9+Ar9NuuYS6JEI1rbLqzAr3VNsVINyPi8Fo3UjMXEuLRYE2+L0ER4/YXJQyL +kcAbmXuZVg2v7tK8R1fjeUl7NIknJITesezpWE7+Tt9avkGtrAjFGA7v0lPubNCd +EgETjdyAYveVqUSISnFOYFWe2yMZeVYHDD9jC1yw4r5+FfyUM1hBOHTE4Y+L3yas +H7WLO7dDWWuwJKZtkIvEcupdM5i3y95ee++U8Rs+yskhwcWYAqqi9lt3m/V+llU0 +HGdpwPFC40es/CgcZlUCAwEAAaOBjDCBiTAPBgNVHRMECDAGAQH/AgEKMAsGA1Ud +DwQEAwIBBjAdBgNVHQ4EFgQU43Mt38sOKAze3bOkynm4jrvoMIkwEQYJYIZIAYb4 +QgEBBAQDAgEGMDcGA1UdHwQwMC4wLKAqoCiGJmh0dHA6Ly93d3cuY2VydHBsdXMu +Y29tL0NSTC9jbGFzczIuY3JsMA0GCSqGSIb3DQEBBQUAA4IBAQCnVM+IRBnL39R/ +AN9WM2K191EBkOvDP9GIROkkXe/nFL0gt5o8AP5tn9uQ3Nf0YtaLcF3n5QRIqWh8 +yfFC82x/xXp8HVGIutIKPidd3i1RTtMTZGnkLuPT55sJmabglZvOGtd/vjzOUrMR +FcEPF80Du5wlFbqidon8BvEY0JNLDnyCt6X09l/+7UCmnYR0ObncHoUW2ikbhiMA +ybuJfm6AiB4vFLQDJKgybwOaRywwvlbGp0ICcBvqQNi6BQNwB6SW//1IMwrh3KWB +kJtN3X3n57LNXMhqlfil9o3EXXgIvnsG1knPGTZQIy4I5p4FTUcY1Rbpsda2ENW7 +l7+ijrRU +-----END CERTIFICATE----- + +# Issuer: CN=DST Root CA X3 O=Digital Signature Trust Co. +# Subject: CN=DST Root CA X3 O=Digital Signature Trust Co. +# Label: "DST Root CA X3" +# Serial: 91299735575339953335919266965803778155 +# MD5 Fingerprint: 41:03:52:dc:0f:f7:50:1b:16:f0:02:8e:ba:6f:45:c5 +# SHA1 Fingerprint: da:c9:02:4f:54:d8:f6:df:94:93:5f:b1:73:26:38:ca:6a:d7:7c:13 +# SHA256 Fingerprint: 06:87:26:03:31:a7:24:03:d9:09:f1:05:e6:9b:cf:0d:32:e1:bd:24:93:ff:c6:d9:20:6d:11:bc:d6:77:07:39 +-----BEGIN CERTIFICATE----- +MIIDSjCCAjKgAwIBAgIQRK+wgNajJ7qJMDmGLvhAazANBgkqhkiG9w0BAQUFADA/ +MSQwIgYDVQQKExtEaWdpdGFsIFNpZ25hdHVyZSBUcnVzdCBDby4xFzAVBgNVBAMT +DkRTVCBSb290IENBIFgzMB4XDTAwMDkzMDIxMTIxOVoXDTIxMDkzMDE0MDExNVow +PzEkMCIGA1UEChMbRGlnaXRhbCBTaWduYXR1cmUgVHJ1c3QgQ28uMRcwFQYDVQQD +Ew5EU1QgUm9vdCBDQSBYMzCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEB +AN+v6ZdQCINXtMxiZfaQguzH0yxrMMpb7NnDfcdAwRgUi+DoM3ZJKuM/IUmTrE4O +rz5Iy2Xu/NMhD2XSKtkyj4zl93ewEnu1lcCJo6m67XMuegwGMoOifooUMM0RoOEq +OLl5CjH9UL2AZd+3UWODyOKIYepLYYHsUmu5ouJLGiifSKOeDNoJjj4XLh7dIN9b +xiqKqy69cK3FCxolkHRyxXtqqzTWMIn/5WgTe1QLyNau7Fqckh49ZLOMxt+/yUFw +7BZy1SbsOFU5Q9D8/RhcQPGX69Wam40dutolucbY38EVAjqr2m7xPi71XAicPNaD +aeQQmxkqtilX4+U9m5/wAl0CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNV +HQ8BAf8EBAMCAQYwHQYDVR0OBBYEFMSnsaR7LHH62+FLkHX/xBVghYkQMA0GCSqG +SIb3DQEBBQUAA4IBAQCjGiybFwBcqR7uKGY3Or+Dxz9LwwmglSBd49lZRNI+DT69 +ikugdB/OEIKcdBodfpga3csTS7MgROSR6cz8faXbauX+5v3gTt23ADq1cEmv8uXr +AvHRAosZy5Q6XkjEGB5YGV8eAlrwDPGxrancWYaLbumR9YbK+rlmM6pZW87ipxZz +R8srzJmwN0jP41ZL9c8PDHIyh8bwRLtTcm1D9SZImlJnt1ir/md2cXjbDaJWFBM5 +JDGFoqgCWjBH4d1QB7wCCZAA62RjYJsWvIjJEubSfZGL+T0yjWW06XyxV3bqxbYo +Ob8VZRzI9neWagqNdwvYkQsEjgfbKbYK7p2CNTUQ +-----END CERTIFICATE----- + +# Issuer: CN=SwissSign Gold CA - G2 O=SwissSign AG +# Subject: CN=SwissSign Gold CA - G2 O=SwissSign AG +# Label: "SwissSign Gold CA - G2" +# Serial: 13492815561806991280 +# MD5 Fingerprint: 24:77:d9:a8:91:d1:3b:fa:88:2d:c2:ff:f8:cd:33:93 +# SHA1 Fingerprint: d8:c5:38:8a:b7:30:1b:1b:6e:d4:7a:e6:45:25:3a:6f:9f:1a:27:61 +# SHA256 Fingerprint: 62:dd:0b:e9:b9:f5:0a:16:3e:a0:f8:e7:5c:05:3b:1e:ca:57:ea:55:c8:68:8f:64:7c:68:81:f2:c8:35:7b:95 +-----BEGIN CERTIFICATE----- +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 +-----END CERTIFICATE----- + +# Issuer: CN=SwissSign Silver CA - G2 O=SwissSign AG +# Subject: CN=SwissSign Silver CA - G2 O=SwissSign AG +# Label: "SwissSign Silver CA - G2" +# Serial: 5700383053117599563 +# MD5 Fingerprint: e0:06:a1:c9:7d:cf:c9:fc:0d:c0:56:75:96:d8:62:13 +# SHA1 Fingerprint: 9b:aa:e5:9f:56:ee:21:cb:43:5a:be:25:93:df:a7:f0:40:d1:1d:cb +# SHA256 Fingerprint: be:6c:4d:a2:bb:b9:ba:59:b6:f3:93:97:68:37:42:46:c3:c0:05:99:3f:a9:8f:02:0d:1d:ed:be:d4:8a:81:d5 +-----BEGIN CERTIFICATE----- +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 +-----END CERTIFICATE----- + +# Issuer: CN=GeoTrust Primary Certification Authority O=GeoTrust Inc. +# Subject: CN=GeoTrust Primary Certification Authority O=GeoTrust Inc. +# Label: "GeoTrust Primary Certification Authority" +# Serial: 32798226551256963324313806436981982369 +# MD5 Fingerprint: 02:26:c3:01:5e:08:30:37:43:a9:d0:7d:cf:37:e6:bf +# SHA1 Fingerprint: 32:3c:11:8e:1b:f7:b8:b6:52:54:e2:e2:10:0d:d6:02:90:37:f0:96 +# SHA256 Fingerprint: 37:d5:10:06:c5:12:ea:ab:62:64:21:f1:ec:8c:92:01:3f:c5:f8:2a:e9:8e:e5:33:eb:46:19:b8:de:b4:d0:6c +-----BEGIN CERTIFICATE----- +MIIDfDCCAmSgAwIBAgIQGKy1av1pthU6Y2yv2vrEoTANBgkqhkiG9w0BAQUFADBY +MQswCQYDVQQGEwJVUzEWMBQGA1UEChMNR2VvVHJ1c3QgSW5jLjExMC8GA1UEAxMo +R2VvVHJ1c3QgUHJpbWFyeSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wNjEx +MjcwMDAwMDBaFw0zNjA3MTYyMzU5NTlaMFgxCzAJBgNVBAYTAlVTMRYwFAYDVQQK +Ew1HZW9UcnVzdCBJbmMuMTEwLwYDVQQDEyhHZW9UcnVzdCBQcmltYXJ5IENlcnRp +ZmljYXRpb24gQXV0aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKC +AQEAvrgVe//UfH1nrYNke8hCUy3f9oQIIGHWAVlqnEQRr+92/ZV+zmEwu3qDXwK9 +AWbK7hWNb6EwnL2hhZ6UOvNWiAAxz9juapYC2e0DjPt1befquFUWBRaa9OBesYjA +ZIVcFU2Ix7e64HXprQU9nceJSOC7KMgD4TCTZF5SwFlwIjVXiIrxlQqD17wxcwE0 +7e9GceBrAqg1cmuXm2bgyxx5X9gaBGgeRwLmnWDiNpcB3841kt++Z8dtd1k7j53W +kBWUvEI0EME5+bEnPn7WinXFsq+W06Lem+SYvn3h6YGttm/81w7a4DSwDRp35+MI +mO9Y+pyEtzavwt+s0vQQBnBxNQIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4G +A1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQULNVQQZcVi/CPNmFbSvtr2ZnJM5IwDQYJ +KoZIhvcNAQEFBQADggEBAFpwfyzdtzRP9YZRqSa+S7iq8XEN3GHHoOo0Hnp3DwQ1 +6CePbJC/kRYkRj5KTs4rFtULUh38H2eiAkUxT87z+gOneZ1TatnaYzr4gNfTmeGl +4b7UVXGYNTq+k+qurUKykG/g/CFNNWMziUnWm07Kx+dOCQD32sfvmWKZd7aVIl6K +oKv0uHiYyjgZmclynnjNS6yvGaBzEi38wkG6gZHaFloxt/m0cYASSJlyc1pZU8Fj +UjPtp8nSOQJw+uCxQmYpqptR7TBUIhRf2asdweSU8Pj1K/fqynhG1riR/aYNKxoU +AT6A8EKglQdebc3MS6RFjasS6LPeWuWgfOgPIh1a6Vk= +-----END CERTIFICATE----- + +# Issuer: CN=thawte Primary Root CA O=thawte, Inc. OU=Certification Services Division/(c) 2006 thawte, Inc. - For authorized use only +# Subject: CN=thawte Primary Root CA O=thawte, Inc. OU=Certification Services Division/(c) 2006 thawte, Inc. - For authorized use only +# Label: "thawte Primary Root CA" +# Serial: 69529181992039203566298953787712940909 +# MD5 Fingerprint: 8c:ca:dc:0b:22:ce:f5:be:72:ac:41:1a:11:a8:d8:12 +# SHA1 Fingerprint: 91:c6:d6:ee:3e:8a:c8:63:84:e5:48:c2:99:29:5c:75:6c:81:7b:81 +# SHA256 Fingerprint: 8d:72:2f:81:a9:c1:13:c0:79:1d:f1:36:a2:96:6d:b2:6c:95:0a:97:1d:b4:6b:41:99:f4:ea:54:b7:8b:fb:9f +-----BEGIN CERTIFICATE----- +MIIEIDCCAwigAwIBAgIQNE7VVyDV7exJ9C/ON9srbTANBgkqhkiG9w0BAQUFADCB +qTELMAkGA1UEBhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5jLjEoMCYGA1UECxMf +Q2VydGlmaWNhdGlvbiBTZXJ2aWNlcyBEaXZpc2lvbjE4MDYGA1UECxMvKGMpIDIw +MDYgdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxHzAdBgNV +BAMTFnRoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EwHhcNMDYxMTE3MDAwMDAwWhcNMzYw +NzE2MjM1OTU5WjCBqTELMAkGA1UEBhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5j +LjEoMCYGA1UECxMfQ2VydGlmaWNhdGlvbiBTZXJ2aWNlcyBEaXZpc2lvbjE4MDYG +A1UECxMvKGMpIDIwMDYgdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNl +IG9ubHkxHzAdBgNVBAMTFnRoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EwggEiMA0GCSqG +SIb3DQEBAQUAA4IBDwAwggEKAoIBAQCsoPD7gFnUnMekz52hWXMJEEUMDSxuaPFs +W0hoSVk3/AszGcJ3f8wQLZU0HObrTQmnHNK4yZc2AreJ1CRfBsDMRJSUjQJib+ta +3RGNKJpchJAQeg29dGYvajig4tVUROsdB58Hum/u6f1OCyn1PoSgAfGcq/gcfomk +6KHYcWUNo1F77rzSImANuVud37r8UVsLr5iy6S7pBOhih94ryNdOwUxkHt3Ph1i6 +Sk/KaAcdHJ1KxtUvkcx8cXIcxcBn6zL9yZJclNqFwJu/U30rCfSMnZEfl2pSy94J +NqR32HuHUETVPm4pafs5SSYeCaWAe0At6+gnhcn+Yf1+5nyXHdWdAgMBAAGjQjBA +MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBR7W0XP +r87Lev0xkhpqtvNG61dIUDANBgkqhkiG9w0BAQUFAAOCAQEAeRHAS7ORtvzw6WfU +DW5FvlXok9LOAz/t2iWwHVfLHjp2oEzsUHboZHIMpKnxuIvW1oeEuzLlQRHAd9mz +YJ3rG9XRbkREqaYB7FViHXe4XI5ISXycO1cRrK1zN44veFyQaEfZYGDm/Ac9IiAX +xPcW6cTYcvnIc3zfFi8VqT79aie2oetaupgf1eNNZAqdE8hhuvU5HIe6uL17In/2 +/qxAeeWsEG89jxt5dovEN7MhGITlNgDrYyCZuen+MwS7QcjBAvlEYyCegc5C09Y/ +LHbTY5xZ3Y+m4Q6gLkH3LpVHz7z9M/P2C2F+fpErgUfCJzDupxBdN49cOSvkBPB7 +jVaMaA== +-----END CERTIFICATE----- + +# Issuer: CN=VeriSign Class 3 Public Primary Certification Authority - G5 O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 2006 VeriSign, Inc. - For authorized use only +# Subject: CN=VeriSign Class 3 Public Primary Certification Authority - G5 O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 2006 VeriSign, Inc. - For authorized use only +# Label: "VeriSign Class 3 Public Primary Certification Authority - G5" +# Serial: 33037644167568058970164719475676101450 +# MD5 Fingerprint: cb:17:e4:31:67:3e:e2:09:fe:45:57:93:f3:0a:fa:1c +# SHA1 Fingerprint: 4e:b6:d5:78:49:9b:1c:cf:5f:58:1e:ad:56:be:3d:9b:67:44:a5:e5 +# SHA256 Fingerprint: 9a:cf:ab:7e:43:c8:d8:80:d0:6b:26:2a:94:de:ee:e4:b4:65:99:89:c3:d0:ca:f1:9b:af:64:05:e4:1a:b7:df +-----BEGIN CERTIFICATE----- +MIIE0zCCA7ugAwIBAgIQGNrRniZ96LtKIVjNzGs7SjANBgkqhkiG9w0BAQUFADCB +yjELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQL +ExZWZXJpU2lnbiBUcnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNiBWZXJp +U2lnbiwgSW5jLiAtIEZvciBhdXRob3JpemVkIHVzZSBvbmx5MUUwQwYDVQQDEzxW +ZXJpU2lnbiBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5IENlcnRpZmljYXRpb24gQXV0 +aG9yaXR5IC0gRzUwHhcNMDYxMTA4MDAwMDAwWhcNMzYwNzE2MjM1OTU5WjCByjEL +MAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZW +ZXJpU2lnbiBUcnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNiBWZXJpU2ln +biwgSW5jLiAtIEZvciBhdXRob3JpemVkIHVzZSBvbmx5MUUwQwYDVQQDEzxWZXJp +U2lnbiBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5IENlcnRpZmljYXRpb24gQXV0aG9y +aXR5IC0gRzUwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCvJAgIKXo1 +nmAMqudLO07cfLw8RRy7K+D+KQL5VwijZIUVJ/XxrcgxiV0i6CqqpkKzj/i5Vbex +t0uz/o9+B1fs70PbZmIVYc9gDaTY3vjgw2IIPVQT60nKWVSFJuUrjxuf6/WhkcIz +SdhDY2pSS9KP6HBRTdGJaXvHcPaz3BJ023tdS1bTlr8Vd6Gw9KIl8q8ckmcY5fQG +BO+QueQA5N06tRn/Arr0PO7gi+s3i+z016zy9vA9r911kTMZHRxAy3QkGSGT2RT+ +rCpSx4/VBEnkjWNHiDxpg8v+R70rfk/Fla4OndTRQ8Bnc+MUCH7lP59zuDMKz10/ +NIeWiu5T6CUVAgMBAAGjgbIwga8wDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8E +BAMCAQYwbQYIKwYBBQUHAQwEYTBfoV2gWzBZMFcwVRYJaW1hZ2UvZ2lmMCEwHzAH +BgUrDgMCGgQUj+XTGoasjY5rw8+AatRIGCx7GS4wJRYjaHR0cDovL2xvZ28udmVy +aXNpZ24uY29tL3ZzbG9nby5naWYwHQYDVR0OBBYEFH/TZafC3ey78DAJ80M5+gKv +MzEzMA0GCSqGSIb3DQEBBQUAA4IBAQCTJEowX2LP2BqYLz3q3JktvXf2pXkiOOzE +p6B4Eq1iDkVwZMXnl2YtmAl+X6/WzChl8gGqCBpH3vn5fJJaCGkgDdk+bW48DW7Y +5gaRQBi5+MHt39tBquCWIMnNZBU4gcmU7qKEKQsTb47bDN0lAtukixlE0kF6BWlK +WE9gyn6CagsCqiUXObXbf+eEZSqVir2G3l6BFoMtEMze/aiCKm0oHw0LxOXnGiYZ +4fQRbxC1lfznQgUy286dUV4otp6F01vvpX1FQHKOtw5rDgb7MzVIcbidJ4vEZV8N +hnacRHr2lVz2XTIIM6RUthg/aFzyQkqFOFSDX9HoLPKsEdao7WNq +-----END CERTIFICATE----- + +# Issuer: CN=SecureTrust CA O=SecureTrust Corporation +# Subject: CN=SecureTrust CA O=SecureTrust Corporation +# Label: "SecureTrust CA" +# Serial: 17199774589125277788362757014266862032 +# MD5 Fingerprint: dc:32:c3:a7:6d:25:57:c7:68:09:9d:ea:2d:a9:a2:d1 +# SHA1 Fingerprint: 87:82:c6:c3:04:35:3b:cf:d2:96:92:d2:59:3e:7d:44:d9:34:ff:11 +# SHA256 Fingerprint: f1:c1:b5:0a:e5:a2:0d:d8:03:0e:c9:f6:bc:24:82:3d:d3:67:b5:25:57:59:b4:e7:1b:61:fc:e9:f7:37:5d:73 +-----BEGIN CERTIFICATE----- +MIIDuDCCAqCgAwIBAgIQDPCOXAgWpa1Cf/DrJxhZ0DANBgkqhkiG9w0BAQUFADBI +MQswCQYDVQQGEwJVUzEgMB4GA1UEChMXU2VjdXJlVHJ1c3QgQ29ycG9yYXRpb24x +FzAVBgNVBAMTDlNlY3VyZVRydXN0IENBMB4XDTA2MTEwNzE5MzExOFoXDTI5MTIz +MTE5NDA1NVowSDELMAkGA1UEBhMCVVMxIDAeBgNVBAoTF1NlY3VyZVRydXN0IENv +cnBvcmF0aW9uMRcwFQYDVQQDEw5TZWN1cmVUcnVzdCBDQTCCASIwDQYJKoZIhvcN +AQEBBQADggEPADCCAQoCggEBAKukgeWVzfX2FI7CT8rU4niVWJxB4Q2ZQCQXOZEz +Zum+4YOvYlyJ0fwkW2Gz4BERQRwdbvC4u/jep4G6pkjGnx29vo6pQT64lO0pGtSO +0gMdA+9tDWccV9cGrcrI9f4Or2YlSASWC12juhbDCE/RRvgUXPLIXgGZbf2IzIao +wW8xQmxSPmjL8xk037uHGFaAJsTQ3MBv396gwpEWoGQRS0S8Hvbn+mPeZqx2pHGj +7DaUaHp3pLHnDi+BeuK1cobvomuL8A/b01k/unK8RCSc43Oz969XL0Imnal0ugBS +8kvNU3xHCzaFDmapCJcWNFfBZveA4+1wVMeT4C4oFVmHursCAwEAAaOBnTCBmjAT +BgkrBgEEAYI3FAIEBh4EAEMAQTALBgNVHQ8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB +/zAdBgNVHQ4EFgQUQjK2FvoE/f5dS3rD/fdMQB1aQ68wNAYDVR0fBC0wKzApoCeg +JYYjaHR0cDovL2NybC5zZWN1cmV0cnVzdC5jb20vU1RDQS5jcmwwEAYJKwYBBAGC +NxUBBAMCAQAwDQYJKoZIhvcNAQEFBQADggEBADDtT0rhWDpSclu1pqNlGKa7UTt3 +6Z3q059c4EVlew3KW+JwULKUBRSuSceNQQcSc5R+DCMh/bwQf2AQWnL1mA6s7Ll/ +3XpvXdMc9P+IBWlCqQVxyLesJugutIxq/3HcuLHfmbx8IVQr5Fiiu1cprp6poxkm +D5kuCLDv/WnPmRoJjeOnnyvJNjR7JLN4TJUXpAYmHrZkUjZfYGfZnMUFdAvnZyPS +CPyI6a6Lf+Ew9Dd+/cYy2i2eRDAwbO4H3tI0/NL/QPZL9GZGBlSm8jIKYyYwa5vR +3ItHuuG51WLQoqD0ZwV4KWMabwTW+MZMo5qxN7SN5ShLHZ4swrhovO0C7jE= +-----END CERTIFICATE----- + +# Issuer: CN=Secure Global CA O=SecureTrust Corporation +# Subject: CN=Secure Global CA O=SecureTrust Corporation +# Label: "Secure Global CA" +# Serial: 9751836167731051554232119481456978597 +# MD5 Fingerprint: cf:f4:27:0d:d4:ed:dc:65:16:49:6d:3d:da:bf:6e:de +# SHA1 Fingerprint: 3a:44:73:5a:e5:81:90:1f:24:86:61:46:1e:3b:9c:c4:5f:f5:3a:1b +# SHA256 Fingerprint: 42:00:f5:04:3a:c8:59:0e:bb:52:7d:20:9e:d1:50:30:29:fb:cb:d4:1c:a1:b5:06:ec:27:f1:5a:de:7d:ac:69 +-----BEGIN CERTIFICATE----- +MIIDvDCCAqSgAwIBAgIQB1YipOjUiolN9BPI8PjqpTANBgkqhkiG9w0BAQUFADBK +MQswCQYDVQQGEwJVUzEgMB4GA1UEChMXU2VjdXJlVHJ1c3QgQ29ycG9yYXRpb24x +GTAXBgNVBAMTEFNlY3VyZSBHbG9iYWwgQ0EwHhcNMDYxMTA3MTk0MjI4WhcNMjkx +MjMxMTk1MjA2WjBKMQswCQYDVQQGEwJVUzEgMB4GA1UEChMXU2VjdXJlVHJ1c3Qg +Q29ycG9yYXRpb24xGTAXBgNVBAMTEFNlY3VyZSBHbG9iYWwgQ0EwggEiMA0GCSqG +SIb3DQEBAQUAA4IBDwAwggEKAoIBAQCvNS7YrGxVaQZx5RNoJLNP2MwhR/jxYDiJ +iQPpvepeRlMJ3Fz1Wuj3RSoC6zFh1ykzTM7HfAo3fg+6MpjhHZevj8fcyTiW89sa +/FHtaMbQbqR8JNGuQsiWUGMu4P51/pinX0kuleM5M2SOHqRfkNJnPLLZ/kG5VacJ +jnIFHovdRIWCQtBJwB1g8NEXLJXr9qXBkqPFwqcIYA1gBBCWeZ4WNOaptvolRTnI +HmX5k/Wq8VLcmZg9pYYaDDUz+kulBAYVHDGA76oYa8J719rO+TMg1fW9ajMtgQT7 +sFzUnKPiXB3jqUJ1XnvUd+85VLrJChgbEplJL4hL/VBi0XPnj3pDAgMBAAGjgZ0w +gZowEwYJKwYBBAGCNxQCBAYeBABDAEEwCwYDVR0PBAQDAgGGMA8GA1UdEwEB/wQF +MAMBAf8wHQYDVR0OBBYEFK9EBMJBfkiD2045AuzshHrmzsmkMDQGA1UdHwQtMCsw +KaAnoCWGI2h0dHA6Ly9jcmwuc2VjdXJldHJ1c3QuY29tL1NHQ0EuY3JsMBAGCSsG +AQQBgjcVAQQDAgEAMA0GCSqGSIb3DQEBBQUAA4IBAQBjGghAfaReUw132HquHw0L +URYD7xh8yOOvaliTFGCRsoTciE6+OYo68+aCiV0BN7OrJKQVDpI1WkpEXk5X+nXO +H0jOZvQ8QCaSmGwb7iRGDBezUqXbpZGRzzfTb+cnCDpOGR86p1hcF895P4vkp9Mm +I50mD1hp/Ed+stCNi5O/KU9DaXR2Z0vPB4zmAve14bRDtUstFJ/53CYNv6ZHdAbY +iNE6KTCEztI5gGIbqMdXSbxqVVFnFUq+NQfk1XWYN3kwFNspnWzFacxHVaIw98xc +f8LDmBxrThaA63p4ZUWiABqvDA1VZDRIuJK58bRQKfJPIx/abKwfROHdI3hRW8cW +-----END CERTIFICATE----- + +# Issuer: CN=COMODO Certification Authority O=COMODO CA Limited +# Subject: CN=COMODO Certification Authority O=COMODO CA Limited +# Label: "COMODO Certification Authority" +# Serial: 104350513648249232941998508985834464573 +# MD5 Fingerprint: 5c:48:dc:f7:42:72:ec:56:94:6d:1c:cc:71:35:80:75 +# SHA1 Fingerprint: 66:31:bf:9e:f7:4f:9e:b6:c9:d5:a6:0c:ba:6a:be:d1:f7:bd:ef:7b +# SHA256 Fingerprint: 0c:2c:d6:3d:f7:80:6f:a3:99:ed:e8:09:11:6b:57:5b:f8:79:89:f0:65:18:f9:80:8c:86:05:03:17:8b:af:66 +-----BEGIN CERTIFICATE----- +MIIEHTCCAwWgAwIBAgIQToEtioJl4AsC7j41AkblPTANBgkqhkiG9w0BAQUFADCB +gTELMAkGA1UEBhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4G +A1UEBxMHU2FsZm9yZDEaMBgGA1UEChMRQ09NT0RPIENBIExpbWl0ZWQxJzAlBgNV +BAMTHkNPTU9ETyBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wNjEyMDEwMDAw +MDBaFw0yOTEyMzEyMzU5NTlaMIGBMQswCQYDVQQGEwJHQjEbMBkGA1UECBMSR3Jl +YXRlciBNYW5jaGVzdGVyMRAwDgYDVQQHEwdTYWxmb3JkMRowGAYDVQQKExFDT01P +RE8gQ0EgTGltaXRlZDEnMCUGA1UEAxMeQ09NT0RPIENlcnRpZmljYXRpb24gQXV0 +aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA0ECLi3LjkRv3 +UcEbVASY06m/weaKXTuH+7uIzg3jLz8GlvCiKVCZrts7oVewdFFxze1CkU1B/qnI +2GqGd0S7WWaXUF601CxwRM/aN5VCaTwwxHGzUvAhTaHYujl8HJ6jJJ3ygxaYqhZ8 +Q5sVW7euNJH+1GImGEaaP+vB+fGQV+useg2L23IwambV4EajcNxo2f8ESIl33rXp ++2dtQem8Ob0y2WIC8bGoPW43nOIv4tOiJovGuFVDiOEjPqXSJDlqR6sA1KGzqSX+ +DT+nHbrTUcELpNqsOO9VUCQFZUaTNE8tja3G1CEZ0o7KBWFxB3NH5YoZEr0ETc5O +nKVIrLsm9wIDAQABo4GOMIGLMB0GA1UdDgQWBBQLWOWLxkwVN6RAqTCpIb5HNlpW +/zAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zBJBgNVHR8EQjBAMD6g +PKA6hjhodHRwOi8vY3JsLmNvbW9kb2NhLmNvbS9DT01PRE9DZXJ0aWZpY2F0aW9u +QXV0aG9yaXR5LmNybDANBgkqhkiG9w0BAQUFAAOCAQEAPpiem/Yb6dc5t3iuHXIY +SdOH5EOC6z/JqvWote9VfCFSZfnVDeFs9D6Mk3ORLgLETgdxb8CPOGEIqB6BCsAv +IC9Bi5HcSEW88cbeunZrM8gALTFGTO3nnc+IlP8zwFboJIYmuNg4ON8qa90SzMc/ +RxdMosIGlgnW2/4/PEZB31jiVg88O8EckzXZOFKs7sjsLjBOlDW0JB9LeGna8gI4 +zJVSk/BwJVmcIGfE7vmLV2H0knZ9P4SNVbfo5azV8fUZVqZa+5Acr5Pr5RzUZ5dd +BA6+C4OmF4O5MBKgxTMVBbkN+8cFduPYSo38NBejxiEovjBFMR7HeL5YYTisO+IB +ZQ== +-----END CERTIFICATE----- + +# Issuer: CN=Network Solutions Certificate Authority O=Network Solutions L.L.C. +# Subject: CN=Network Solutions Certificate Authority O=Network Solutions L.L.C. +# Label: "Network Solutions Certificate Authority" +# Serial: 116697915152937497490437556386812487904 +# MD5 Fingerprint: d3:f3:a6:16:c0:fa:6b:1d:59:b1:2d:96:4d:0e:11:2e +# SHA1 Fingerprint: 74:f8:a3:c3:ef:e7:b3:90:06:4b:83:90:3c:21:64:60:20:e5:df:ce +# SHA256 Fingerprint: 15:f0:ba:00:a3:ac:7a:f3:ac:88:4c:07:2b:10:11:a0:77:bd:77:c0:97:f4:01:64:b2:f8:59:8a:bd:83:86:0c +-----BEGIN CERTIFICATE----- +MIID5jCCAs6gAwIBAgIQV8szb8JcFuZHFhfjkDFo4DANBgkqhkiG9w0BAQUFADBi +MQswCQYDVQQGEwJVUzEhMB8GA1UEChMYTmV0d29yayBTb2x1dGlvbnMgTC5MLkMu +MTAwLgYDVQQDEydOZXR3b3JrIFNvbHV0aW9ucyBDZXJ0aWZpY2F0ZSBBdXRob3Jp +dHkwHhcNMDYxMjAxMDAwMDAwWhcNMjkxMjMxMjM1OTU5WjBiMQswCQYDVQQGEwJV +UzEhMB8GA1UEChMYTmV0d29yayBTb2x1dGlvbnMgTC5MLkMuMTAwLgYDVQQDEydO +ZXR3b3JrIFNvbHV0aW9ucyBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwggEiMA0GCSqG +SIb3DQEBAQUAA4IBDwAwggEKAoIBAQDkvH6SMG3G2I4rC7xGzuAnlt7e+foS0zwz +c7MEL7xxjOWftiJgPl9dzgn/ggwbmlFQGiaJ3dVhXRncEg8tCqJDXRfQNJIg6nPP +OCwGJgl6cvf6UDL4wpPTaaIjzkGxzOTVHzbRijr4jGPiFFlp7Q3Tf2vouAPlT2rl +mGNpSAW+Lv8ztumXWWn4Zxmuk2GWRBXTcrA/vGp97Eh/jcOrqnErU2lBUzS1sLnF +BgrEsEX1QV1uiUV7PTsmjHTC5dLRfbIR1PtYMiKagMnc/Qzpf14Dl847ABSHJ3A4 +qY5usyd2mFHgBeMhqxrVhSI8KbWaFsWAqPS7azCPL0YCorEMIuDTAgMBAAGjgZcw +gZQwHQYDVR0OBBYEFCEwyfsA106Y2oeqKtCnLrFAMadMMA4GA1UdDwEB/wQEAwIB +BjAPBgNVHRMBAf8EBTADAQH/MFIGA1UdHwRLMEkwR6BFoEOGQWh0dHA6Ly9jcmwu +bmV0c29sc3NsLmNvbS9OZXR3b3JrU29sdXRpb25zQ2VydGlmaWNhdGVBdXRob3Jp +dHkuY3JsMA0GCSqGSIb3DQEBBQUAA4IBAQC7rkvnt1frf6ott3NHhWrB5KUd5Oc8 +6fRZZXe1eltajSU24HqXLjjAV2CDmAaDn7l2em5Q4LqILPxFzBiwmZVRDuwduIj/ +h1AcgsLj4DKAv6ALR8jDMe+ZZzKATxcheQxpXN5eNK4CtSbqUN9/GGUsyfJj4akH +/nxxH2szJGoeBfcFaMBqEssuXmHLrijTfsK0ZpEmXzwuJF/LWA/rKOyvEZbz3Htv +wKeI8lN3s2Berq4o2jUsbzRF0ybh3uxbTydrFny9RAQYgrOJeRcQcT16ohZO9QHN +pGxlaKFJdlxDydi8NmdspZS11My5vWo1ViHe2MPr+8ukYEywVaCge1ey +-----END CERTIFICATE----- + +# Issuer: CN=COMODO ECC Certification Authority O=COMODO CA Limited +# Subject: CN=COMODO ECC Certification Authority O=COMODO CA Limited +# Label: "COMODO ECC Certification Authority" +# Serial: 41578283867086692638256921589707938090 +# MD5 Fingerprint: 7c:62:ff:74:9d:31:53:5e:68:4a:d5:78:aa:1e:bf:23 +# SHA1 Fingerprint: 9f:74:4e:9f:2b:4d:ba:ec:0f:31:2c:50:b6:56:3b:8e:2d:93:c3:11 +# SHA256 Fingerprint: 17:93:92:7a:06:14:54:97:89:ad:ce:2f:8f:34:f7:f0:b6:6d:0f:3a:e3:a3:b8:4d:21:ec:15:db:ba:4f:ad:c7 +-----BEGIN CERTIFICATE----- +MIICiTCCAg+gAwIBAgIQH0evqmIAcFBUTAGem2OZKjAKBggqhkjOPQQDAzCBhTEL +MAkGA1UEBhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UE +BxMHU2FsZm9yZDEaMBgGA1UEChMRQ09NT0RPIENBIExpbWl0ZWQxKzApBgNVBAMT +IkNPTU9ETyBFQ0MgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDgwMzA2MDAw +MDAwWhcNMzgwMTE4MjM1OTU5WjCBhTELMAkGA1UEBhMCR0IxGzAZBgNVBAgTEkdy +ZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UEChMRQ09N +T0RPIENBIExpbWl0ZWQxKzApBgNVBAMTIkNPTU9ETyBFQ0MgQ2VydGlmaWNhdGlv +biBBdXRob3JpdHkwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQDR3svdcmCFYX7deSR +FtSrYpn1PlILBs5BAH+X4QokPB0BBO490o0JlwzgdeT6+3eKKvUDYEs2ixYjFq0J +cfRK9ChQtP6IHG4/bC8vCVlbpVsLM5niwz2J+Wos77LTBumjQjBAMB0GA1UdDgQW +BBR1cacZSBm8nZ3qQUfflMRId5nTeTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/ +BAUwAwEB/zAKBggqhkjOPQQDAwNoADBlAjEA7wNbeqy3eApyt4jf/7VGFAkK+qDm +fQjGGoe9GKhzvSbKYAydzpmfz1wPMOG+FDHqAjAU9JM8SaczepBGR7NjfRObTrdv +GDeAU/7dIOA1mjbRxwG55tzd8/8dLDoWV9mSOdY= +-----END CERTIFICATE----- + +# Issuer: CN=OISTE WISeKey Global Root GA CA O=WISeKey OU=Copyright (c) 2005/OISTE Foundation Endorsed +# Subject: CN=OISTE WISeKey Global Root GA CA O=WISeKey OU=Copyright (c) 2005/OISTE Foundation Endorsed +# Label: "OISTE WISeKey Global Root GA CA" +# Serial: 86718877871133159090080555911823548314 +# MD5 Fingerprint: bc:6c:51:33:a7:e9:d3:66:63:54:15:72:1b:21:92:93 +# SHA1 Fingerprint: 59:22:a1:e1:5a:ea:16:35:21:f8:98:39:6a:46:46:b0:44:1b:0f:a9 +# SHA256 Fingerprint: 41:c9:23:86:6a:b4:ca:d6:b7:ad:57:80:81:58:2e:02:07:97:a6:cb:df:4f:ff:78:ce:83:96:b3:89:37:d7:f5 +-----BEGIN CERTIFICATE----- +MIID8TCCAtmgAwIBAgIQQT1yx/RrH4FDffHSKFTfmjANBgkqhkiG9w0BAQUFADCB +ijELMAkGA1UEBhMCQ0gxEDAOBgNVBAoTB1dJU2VLZXkxGzAZBgNVBAsTEkNvcHly +aWdodCAoYykgMjAwNTEiMCAGA1UECxMZT0lTVEUgRm91bmRhdGlvbiBFbmRvcnNl +ZDEoMCYGA1UEAxMfT0lTVEUgV0lTZUtleSBHbG9iYWwgUm9vdCBHQSBDQTAeFw0w +NTEyMTExNjAzNDRaFw0zNzEyMTExNjA5NTFaMIGKMQswCQYDVQQGEwJDSDEQMA4G +A1UEChMHV0lTZUtleTEbMBkGA1UECxMSQ29weXJpZ2h0IChjKSAyMDA1MSIwIAYD +VQQLExlPSVNURSBGb3VuZGF0aW9uIEVuZG9yc2VkMSgwJgYDVQQDEx9PSVNURSBX +SVNlS2V5IEdsb2JhbCBSb290IEdBIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A +MIIBCgKCAQEAy0+zAJs9Nt350UlqaxBJH+zYK7LG+DKBKUOVTJoZIyEVRd7jyBxR +VVuuk+g3/ytr6dTqvirdqFEr12bDYVxgAsj1znJ7O7jyTmUIms2kahnBAbtzptf2 +w93NvKSLtZlhuAGio9RN1AU9ka34tAhxZK9w8RxrfvbDd50kc3vkDIzh2TbhmYsF +mQvtRTEJysIA2/dyoJaqlYfQjse2YXMNdmaM3Bu0Y6Kff5MTMPGhJ9vZ/yxViJGg +4E8HsChWjBgbl0SOid3gF27nKu+POQoxhILYQBRJLnpB5Kf+42TMwVlxSywhp1t9 +4B3RLoGbw9ho972WG6xwsRYUC9tguSYBBQIDAQABo1EwTzALBgNVHQ8EBAMCAYYw +DwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUswN+rja8sHnR3JQmthG+IbJphpQw +EAYJKwYBBAGCNxUBBAMCAQAwDQYJKoZIhvcNAQEFBQADggEBAEuh/wuHbrP5wUOx +SPMowB0uyQlB+pQAHKSkq0lPjz0e701vvbyk9vImMMkQyh2I+3QZH4VFvbBsUfk2 +ftv1TDI6QU9bR8/oCy22xBmddMVHxjtqD6wU2zz0c5ypBd8A3HR4+vg1YFkCExh8 +vPtNsCBtQ7tgMHpnM1zFmdH4LTlSc/uMqpclXHLZCB6rTjzjgTGfA6b7wP4piFXa +hNVQA7bihKOmNqoROgHhGEvWRGizPflTdISzRpFGlgC3gCy24eMQ4tui5yiPAZZi +Fj4A4xylNoEYokxSdsARo27mHbrjWr42U8U+dY+GaSlYU7Wcu2+fXMUY7N0v4ZjJ +/L7fCg0= +-----END CERTIFICATE----- + +# Issuer: CN=Certigna O=Dhimyotis +# Subject: CN=Certigna O=Dhimyotis +# Label: "Certigna" +# Serial: 18364802974209362175 +# MD5 Fingerprint: ab:57:a6:5b:7d:42:82:19:b5:d8:58:26:28:5e:fd:ff +# SHA1 Fingerprint: b1:2e:13:63:45:86:a4:6f:1a:b2:60:68:37:58:2d:c4:ac:fd:94:97 +# SHA256 Fingerprint: e3:b6:a2:db:2e:d7:ce:48:84:2f:7a:c5:32:41:c7:b7:1d:54:14:4b:fb:40:c1:1f:3f:1d:0b:42:f5:ee:a1:2d +-----BEGIN CERTIFICATE----- +MIIDqDCCApCgAwIBAgIJAP7c4wEPyUj/MA0GCSqGSIb3DQEBBQUAMDQxCzAJBgNV +BAYTAkZSMRIwEAYDVQQKDAlEaGlteW90aXMxETAPBgNVBAMMCENlcnRpZ25hMB4X +DTA3MDYyOTE1MTMwNVoXDTI3MDYyOTE1MTMwNVowNDELMAkGA1UEBhMCRlIxEjAQ +BgNVBAoMCURoaW15b3RpczERMA8GA1UEAwwIQ2VydGlnbmEwggEiMA0GCSqGSIb3 +DQEBAQUAA4IBDwAwggEKAoIBAQDIaPHJ1tazNHUmgh7stL7qXOEm7RFHYeGifBZ4 +QCHkYJ5ayGPhxLGWkv8YbWkj4Sti993iNi+RB7lIzw7sebYs5zRLcAglozyHGxny +gQcPOJAZ0xH+hrTy0V4eHpbNgGzOOzGTtvKg0KmVEn2lmsxryIRWijOp5yIVUxbw +zBfsV1/pogqYCd7jX5xv3EjjhQsVWqa6n6xI4wmy9/Qy3l40vhx4XUJbzg4ij02Q +130yGLMLLGq/jj8UEYkgDncUtT2UCIf3JR7VsmAA7G8qKCVuKj4YYxclPz5EIBb2 +JsglrgVKtOdjLPOMFlN+XPsRGgjBRmKfIrjxwo1p3Po6WAbfAgMBAAGjgbwwgbkw +DwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUGu3+QTmQtCRZvgHyUtVF9lo53BEw +ZAYDVR0jBF0wW4AUGu3+QTmQtCRZvgHyUtVF9lo53BGhOKQ2MDQxCzAJBgNVBAYT +AkZSMRIwEAYDVQQKDAlEaGlteW90aXMxETAPBgNVBAMMCENlcnRpZ25hggkA/tzj +AQ/JSP8wDgYDVR0PAQH/BAQDAgEGMBEGCWCGSAGG+EIBAQQEAwIABzANBgkqhkiG +9w0BAQUFAAOCAQEAhQMeknH2Qq/ho2Ge6/PAD/Kl1NqV5ta+aDY9fm4fTIrv0Q8h +bV6lUmPOEvjvKtpv6zf+EwLHyzs+ImvaYS5/1HI93TDhHkxAGYwP15zRgzB7mFnc +fca5DClMoTOi62c6ZYTTluLtdkVwj7Ur3vkj1kluPBS1xp81HlDQwY9qcEQCYsuu +HWhBp6pX6FOqB9IG9tUUBguRA3UsbHK1YZWaDYu5Def131TN3ubY1gkIl2PlwS6w +t0QmwCbAr1UwnjvVNioZBPRcHv/PLLf/0P2HQBHVESO7SMAhqaQoLf0V+LBOK/Qw +WyH8EZE0vkHve52Xdf+XlcCWWC/qu0bXu+TZLg== +-----END CERTIFICATE----- + +# Issuer: CN=Deutsche Telekom Root CA 2 O=Deutsche Telekom AG OU=T-TeleSec Trust Center +# Subject: CN=Deutsche Telekom Root CA 2 O=Deutsche Telekom AG OU=T-TeleSec Trust Center +# Label: "Deutsche Telekom Root CA 2" +# Serial: 38 +# MD5 Fingerprint: 74:01:4a:91:b1:08:c4:58:ce:47:cd:f0:dd:11:53:08 +# SHA1 Fingerprint: 85:a4:08:c0:9c:19:3e:5d:51:58:7d:cd:d6:13:30:fd:8c:de:37:bf +# SHA256 Fingerprint: b6:19:1a:50:d0:c3:97:7f:7d:a9:9b:cd:aa:c8:6a:22:7d:ae:b9:67:9e:c7:0b:a3:b0:c9:d9:22:71:c1:70:d3 +-----BEGIN CERTIFICATE----- +MIIDnzCCAoegAwIBAgIBJjANBgkqhkiG9w0BAQUFADBxMQswCQYDVQQGEwJERTEc +MBoGA1UEChMTRGV1dHNjaGUgVGVsZWtvbSBBRzEfMB0GA1UECxMWVC1UZWxlU2Vj +IFRydXN0IENlbnRlcjEjMCEGA1UEAxMaRGV1dHNjaGUgVGVsZWtvbSBSb290IENB +IDIwHhcNOTkwNzA5MTIxMTAwWhcNMTkwNzA5MjM1OTAwWjBxMQswCQYDVQQGEwJE +RTEcMBoGA1UEChMTRGV1dHNjaGUgVGVsZWtvbSBBRzEfMB0GA1UECxMWVC1UZWxl +U2VjIFRydXN0IENlbnRlcjEjMCEGA1UEAxMaRGV1dHNjaGUgVGVsZWtvbSBSb290 +IENBIDIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCrC6M14IspFLEU +ha88EOQ5bzVdSq7d6mGNlUn0b2SjGmBmpKlAIoTZ1KXleJMOaAGtuU1cOs7TuKhC +QN/Po7qCWWqSG6wcmtoIKyUn+WkjR/Hg6yx6m/UTAtB+NHzCnjwAWav12gz1Mjwr +rFDa1sPeg5TKqAyZMg4ISFZbavva4VhYAUlfckE8FQYBjl2tqriTtM2e66foai1S +NNs671x1Udrb8zH57nGYMsRUFUQM+ZtV7a3fGAigo4aKSe5TBY8ZTNXeWHmb0moc +QqvF1afPaA+W5OFhmHZhyJF81j4A4pFQh+GdCuatl9Idxjp9y7zaAzTVjlsB9WoH +txa2bkp/AgMBAAGjQjBAMB0GA1UdDgQWBBQxw3kbuvVT1xfgiXotF2wKsyudMzAP +BgNVHRMECDAGAQH/AgEFMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQUFAAOC +AQEAlGRZrTlk5ynrE/5aw4sTV8gEJPB0d8Bg42f76Ymmg7+Wgnxu1MM9756Abrsp +tJh6sTtU6zkXR34ajgv8HzFZMQSyzhfzLMdiNlXiItiJVbSYSKpk+tYcNthEeFpa +IzpXl/V6ME+un2pMSyuOoAPjPuCp1NJ70rOo4nI8rZ7/gFnkm0W09juwzTkZmDLl +6iFhkOQxIY40sfcvNUqFENrnijchvllj4PKFiDFT1FQUhXB59C4Gdyd1Lx+4ivn+ +xbrYNuSD7Odlt79jWvNGr4GUN9RBjNYj1h7P9WgbRGOiWrqnNVmh5XAFmw4jV5mU +Cm26OWMohpLzGITY+9HPBVZkVw== +-----END CERTIFICATE----- + +# Issuer: CN=Cybertrust Global Root O=Cybertrust, Inc +# Subject: CN=Cybertrust Global Root O=Cybertrust, Inc +# Label: "Cybertrust Global Root" +# Serial: 4835703278459682877484360 +# MD5 Fingerprint: 72:e4:4a:87:e3:69:40:80:77:ea:bc:e3:f4:ff:f0:e1 +# SHA1 Fingerprint: 5f:43:e5:b1:bf:f8:78:8c:ac:1c:c7:ca:4a:9a:c6:22:2b:cc:34:c6 +# SHA256 Fingerprint: 96:0a:df:00:63:e9:63:56:75:0c:29:65:dd:0a:08:67:da:0b:9c:bd:6e:77:71:4a:ea:fb:23:49:ab:39:3d:a3 +-----BEGIN CERTIFICATE----- +MIIDoTCCAomgAwIBAgILBAAAAAABD4WqLUgwDQYJKoZIhvcNAQEFBQAwOzEYMBYG +A1UEChMPQ3liZXJ0cnVzdCwgSW5jMR8wHQYDVQQDExZDeWJlcnRydXN0IEdsb2Jh +bCBSb290MB4XDTA2MTIxNTA4MDAwMFoXDTIxMTIxNTA4MDAwMFowOzEYMBYGA1UE +ChMPQ3liZXJ0cnVzdCwgSW5jMR8wHQYDVQQDExZDeWJlcnRydXN0IEdsb2JhbCBS +b290MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA+Mi8vRRQZhP/8NN5 +7CPytxrHjoXxEnOmGaoQ25yiZXRadz5RfVb23CO21O1fWLE3TdVJDm71aofW0ozS +J8bi/zafmGWgE07GKmSb1ZASzxQG9Dvj1Ci+6A74q05IlG2OlTEQXO2iLb3VOm2y +HLtgwEZLAfVJrn5GitB0jaEMAs7u/OePuGtm839EAL9mJRQr3RAwHQeWP032a7iP +t3sMpTjr3kfb1V05/Iin89cqdPHoWqI7n1C6poxFNcJQZZXcY4Lv3b93TZxiyWNz +FtApD0mpSPCzqrdsxacwOUBdrsTiXSZT8M4cIwhhqJQZugRiQOwfOHB3EgZxpzAY +XSUnpQIDAQABo4GlMIGiMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/ +MB0GA1UdDgQWBBS2CHsNesysIEyGVjJez6tuhS1wVzA/BgNVHR8EODA2MDSgMqAw +hi5odHRwOi8vd3d3Mi5wdWJsaWMtdHJ1c3QuY29tL2NybC9jdC9jdHJvb3QuY3Js +MB8GA1UdIwQYMBaAFLYIew16zKwgTIZWMl7Pq26FLXBXMA0GCSqGSIb3DQEBBQUA +A4IBAQBW7wojoFROlZfJ+InaRcHUowAl9B8Tq7ejhVhpwjCt2BWKLePJzYFa+HMj +Wqd8BfP9IjsO0QbE2zZMcwSO5bAi5MXzLqXZI+O4Tkogp24CJJ8iYGd7ix1yCcUx +XOl5n4BHPa2hCwcUPUf/A2kaDAtE52Mlp3+yybh2hO0j9n0Hq0V+09+zv+mKts2o +omcrUtW3ZfA5TGOgkXmTUg9U3YO7n9GPp1Nzw8v/MOx8BLjYRB+TX3EJIrduPuoc +A06dGiBh+4E37F78CkWr1+cXVdCg6mCbpvbjjFspwgZgFJ0tl0ypkxWdYcQBX0jW +WL1WMRJOEcgh4LMRkWXbtKaIOM5V +-----END CERTIFICATE----- + +# Issuer: O=Chunghwa Telecom Co., Ltd. OU=ePKI Root Certification Authority +# Subject: O=Chunghwa Telecom Co., Ltd. OU=ePKI Root Certification Authority +# Label: "ePKI Root Certification Authority" +# Serial: 28956088682735189655030529057352760477 +# MD5 Fingerprint: 1b:2e:00:ca:26:06:90:3d:ad:fe:6f:15:68:d3:6b:b3 +# SHA1 Fingerprint: 67:65:0d:f1:7e:8e:7e:5b:82:40:a4:f4:56:4b:cf:e2:3d:69:c6:f0 +# SHA256 Fingerprint: c0:a6:f4:dc:63:a2:4b:fd:cf:54:ef:2a:6a:08:2a:0a:72:de:35:80:3e:2f:f5:ff:52:7a:e5:d8:72:06:df:d5 +-----BEGIN CERTIFICATE----- +MIIFsDCCA5igAwIBAgIQFci9ZUdcr7iXAF7kBtK8nTANBgkqhkiG9w0BAQUFADBe +MQswCQYDVQQGEwJUVzEjMCEGA1UECgwaQ2h1bmdod2EgVGVsZWNvbSBDby4sIEx0 +ZC4xKjAoBgNVBAsMIWVQS0kgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAe +Fw0wNDEyMjAwMjMxMjdaFw0zNDEyMjAwMjMxMjdaMF4xCzAJBgNVBAYTAlRXMSMw +IQYDVQQKDBpDaHVuZ2h3YSBUZWxlY29tIENvLiwgTHRkLjEqMCgGA1UECwwhZVBL +SSBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIICIjANBgkqhkiG9w0BAQEF +AAOCAg8AMIICCgKCAgEA4SUP7o3biDN1Z82tH306Tm2d0y8U82N0ywEhajfqhFAH +SyZbCUNsIZ5qyNUD9WBpj8zwIuQf5/dqIjG3LBXy4P4AakP/h2XGtRrBp0xtInAh +ijHyl3SJCRImHJ7K2RKilTza6We/CKBk49ZCt0Xvl/T29de1ShUCWH2YWEtgvM3X +DZoTM1PRYfl61dd4s5oz9wCGzh1NlDivqOx4UXCKXBCDUSH3ET00hl7lSM2XgYI1 +TBnsZfZrxQWh7kcT1rMhJ5QQCtkkO7q+RBNGMD+XPNjX12ruOzjjK9SXDrkb5wdJ +fzcq+Xd4z1TtW0ado4AOkUPB1ltfFLqfpo0kR0BZv3I4sjZsN/+Z0V0OWQqraffA +sgRFelQArr5T9rXn4fg8ozHSqf4hUmTFpmfwdQcGlBSBVcYn5AGPF8Fqcde+S/uU +WH1+ETOxQvdibBjWzwloPn9s9h6PYq2lY9sJpx8iQkEeb5mKPtf5P0B6ebClAZLS +nT0IFaUQAS2zMnaolQ2zepr7BxB4EW/hj8e6DyUadCrlHJhBmd8hh+iVBmoKs2pH +dmX2Os+PYhcZewoozRrSgx4hxyy/vv9haLdnG7t4TY3OZ+XkwY63I2binZB1NJip +NiuKmpS5nezMirH4JYlcWrYvjB9teSSnUmjDhDXiZo1jDiVN1Rmy5nk3pyKdVDEC +AwEAAaNqMGgwHQYDVR0OBBYEFB4M97Zn8uGSJglFwFU5Lnc/QkqiMAwGA1UdEwQF +MAMBAf8wOQYEZyoHAAQxMC8wLQIBADAJBgUrDgMCGgUAMAcGBWcqAwAABBRFsMLH +ClZ87lt4DJX5GFPBphzYEDANBgkqhkiG9w0BAQUFAAOCAgEACbODU1kBPpVJufGB +uvl2ICO1J2B01GqZNF5sAFPZn/KmsSQHRGoqxqWOeBLoR9lYGxMqXnmbnwoqZ6Yl +PwZpVnPDimZI+ymBV3QGypzqKOg4ZyYr8dW1P2WT+DZdjo2NQCCHGervJ8A9tDkP +JXtoUHRVnAxZfVo9QZQlUgjgRywVMRnVvwdVxrsStZf0X4OFunHB2WyBEXYKCrC/ +gpf36j36+uwtqSiUO1bd0lEursC9CBWMd1I0ltabrNMdjmEPNXubrjlpC2JgQCA2 +j6/7Nu4tCEoduL+bXPjqpRugc6bY+G7gMwRfaKonh+3ZwZCc7b3jajWvY9+rGNm6 +5ulK6lCKD2GTHuItGeIwlDWSXQ62B68ZgI9HkFFLLk3dheLSClIKF5r8GrBQAuUB +o2M3IUxExJtRmREOc5wGj1QupyheRDmHVi03vYVElOEMSyycw5KFNGHLD7ibSkNS +/jQ6fbjpKdx2qcgw+BRxgMYeNkh0IkFch4LoGHGLQYlE535YW6i4jRPpp2zDR+2z +Gp1iro2C6pSe3VkQw63d4k3jMdXH7OjysP6SHhYKGvzZ8/gntsm+HbRsZJB/9OTE +W9c3rkIO3aQab3yIVMUWbuF6aC74Or8NpDyJO3inTmODBCEIZ43ygknQW/2xzQ+D +hNQ+IIX3Sj0rnP0qCglN6oH4EZw= +-----END CERTIFICATE----- + +# Issuer: O=certSIGN OU=certSIGN ROOT CA +# Subject: O=certSIGN OU=certSIGN ROOT CA +# Label: "certSIGN ROOT CA" +# Serial: 35210227249154 +# MD5 Fingerprint: 18:98:c0:d6:e9:3a:fc:f9:b0:f5:0c:f7:4b:01:44:17 +# SHA1 Fingerprint: fa:b7:ee:36:97:26:62:fb:2d:b0:2a:f6:bf:03:fd:e8:7c:4b:2f:9b +# SHA256 Fingerprint: ea:a9:62:c4:fa:4a:6b:af:eb:e4:15:19:6d:35:1c:cd:88:8d:4f:53:f3:fa:8a:e6:d7:c4:66:a9:4e:60:42:bb +-----BEGIN CERTIFICATE----- +MIIDODCCAiCgAwIBAgIGIAYFFnACMA0GCSqGSIb3DQEBBQUAMDsxCzAJBgNVBAYT +AlJPMREwDwYDVQQKEwhjZXJ0U0lHTjEZMBcGA1UECxMQY2VydFNJR04gUk9PVCBD +QTAeFw0wNjA3MDQxNzIwMDRaFw0zMTA3MDQxNzIwMDRaMDsxCzAJBgNVBAYTAlJP +MREwDwYDVQQKEwhjZXJ0U0lHTjEZMBcGA1UECxMQY2VydFNJR04gUk9PVCBDQTCC +ASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALczuX7IJUqOtdu0KBuqV5Do +0SLTZLrTk+jUrIZhQGpgV2hUhE28alQCBf/fm5oqrl0Hj0rDKH/v+yv6efHHrfAQ +UySQi2bJqIirr1qjAOm+ukbuW3N7LBeCgV5iLKECZbO9xSsAfsT8AzNXDe3i+s5d +RdY4zTW2ssHQnIFKquSyAVwdj1+ZxLGt24gh65AIgoDzMKND5pCCrlUoSe1b16kQ +OA7+j0xbm0bqQfWwCHTD0IgztnzXdN/chNFDDnU5oSVAKOp4yw4sLjmdjItuFhwv +JoIQ4uNllAoEwF73XVv4EOLQunpL+943AAAaWyjj0pxzPjKHmKHJUS/X3qwzs08C +AwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAcYwHQYDVR0O +BBYEFOCMm9slSbPxfIbWskKHC9BroNnkMA0GCSqGSIb3DQEBBQUAA4IBAQA+0hyJ +LjX8+HXd5n9liPRyTMks1zJO890ZeUe9jjtbkw9QSSQTaxQGcu8J06Gh40CEyecY +MnQ8SG4Pn0vU9x7Tk4ZkVJdjclDVVc/6IJMCopvDI5NOFlV2oHB5bc0hH88vLbwZ +44gx+FkagQnIl6Z0x2DEW8xXjrJ1/RsCCdtZb3KTafcxQdaIOL+Hsr0Wefmq5L6I +Jd1hJyMctTEHBDa0GpC9oHRxUIltvBTjD4au8as+x6AJzKNI0eDbZOeStc+vckNw +i/nDhDwTqn6Sm1dTk/pwwpEOMfmbZ13pljheX7NzTogVZ96edhBiIL5VaZVDADlN +9u6wWk5JRFRYX0KD +-----END CERTIFICATE----- + +# Issuer: CN=GeoTrust Primary Certification Authority - G3 O=GeoTrust Inc. OU=(c) 2008 GeoTrust Inc. - For authorized use only +# Subject: CN=GeoTrust Primary Certification Authority - G3 O=GeoTrust Inc. OU=(c) 2008 GeoTrust Inc. - For authorized use only +# Label: "GeoTrust Primary Certification Authority - G3" +# Serial: 28809105769928564313984085209975885599 +# MD5 Fingerprint: b5:e8:34:36:c9:10:44:58:48:70:6d:2e:83:d4:b8:05 +# SHA1 Fingerprint: 03:9e:ed:b8:0b:e7:a0:3c:69:53:89:3b:20:d2:d9:32:3a:4c:2a:fd +# SHA256 Fingerprint: b4:78:b8:12:25:0d:f8:78:63:5c:2a:a7:ec:7d:15:5e:aa:62:5e:e8:29:16:e2:cd:29:43:61:88:6c:d1:fb:d4 +-----BEGIN CERTIFICATE----- +MIID/jCCAuagAwIBAgIQFaxulBmyeUtB9iepwxgPHzANBgkqhkiG9w0BAQsFADCB +mDELMAkGA1UEBhMCVVMxFjAUBgNVBAoTDUdlb1RydXN0IEluYy4xOTA3BgNVBAsT +MChjKSAyMDA4IEdlb1RydXN0IEluYy4gLSBGb3IgYXV0aG9yaXplZCB1c2Ugb25s +eTE2MDQGA1UEAxMtR2VvVHJ1c3QgUHJpbWFyeSBDZXJ0aWZpY2F0aW9uIEF1dGhv +cml0eSAtIEczMB4XDTA4MDQwMjAwMDAwMFoXDTM3MTIwMTIzNTk1OVowgZgxCzAJ +BgNVBAYTAlVTMRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMTkwNwYDVQQLEzAoYykg +MjAwOCBHZW9UcnVzdCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxNjA0 +BgNVBAMTLUdlb1RydXN0IFByaW1hcnkgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkg +LSBHMzCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANziXmJYHTNXOTIz ++uvLh4yn1ErdBojqZI4xmKU4kB6Yzy5jK/BGvESyiaHAKAxJcCGVn2TAppMSAmUm +hsalifD614SgcK9PGpc/BkTVyetyEH3kMSj7HGHmKAdEc5IiaacDiGydY8hS2pgn +5whMcD60yRLBxWeDXTPzAxHsatBT4tG6NmCUgLthY2xbF37fQJQeqw3CIShwiP/W +JmxsYAQlTlV+fe+/lEjetx3dcI0FX4ilm/LC7urRQEFtYjgdVgbFA0dRIBn8exAL +DmKudlW/X3e+PkkBUz2YJQN2JFodtNuJ6nnltrM7P7pMKEF/BqxqjsHQ9gUdfeZC +huOl1UcCAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYw +HQYDVR0OBBYEFMR5yo6hTgMdHNxr2zFblD4/MH8tMA0GCSqGSIb3DQEBCwUAA4IB +AQAtxRPPVoB7eni9n64smefv2t+UXglpp+duaIy9cr5HqQ6XErhK8WTTOd8lNNTB +zU6B8A8ExCSzNJbGpqow32hhc9f5joWJ7w5elShKKiePEI4ufIbEAp7aDHdlDkQN +kv39sxY2+hENHYwOB4lqKVb3cvTdFZx3NWZXqxNT2I7BQMXXExZacse3aQHEerGD +AWh9jUGhlBjBJVz88P6DAod8DQ3PLghcSkANPuyBYeYk28rgDi0Hsj5W3I31QYUH +SJsMC8tJP33st/3LjWeJGqvtux6jAAgIFyqCXDFdRootD4abdNlF+9RAsXqqaC2G +spki4cErx5z481+oghLrGREt +-----END CERTIFICATE----- + +# Issuer: CN=thawte Primary Root CA - G2 O=thawte, Inc. OU=(c) 2007 thawte, Inc. - For authorized use only +# Subject: CN=thawte Primary Root CA - G2 O=thawte, Inc. OU=(c) 2007 thawte, Inc. - For authorized use only +# Label: "thawte Primary Root CA - G2" +# Serial: 71758320672825410020661621085256472406 +# MD5 Fingerprint: 74:9d:ea:60:24:c4:fd:22:53:3e:cc:3a:72:d9:29:4f +# SHA1 Fingerprint: aa:db:bc:22:23:8f:c4:01:a1:27:bb:38:dd:f4:1d:db:08:9e:f0:12 +# SHA256 Fingerprint: a4:31:0d:50:af:18:a6:44:71:90:37:2a:86:af:af:8b:95:1f:fb:43:1d:83:7f:1e:56:88:b4:59:71:ed:15:57 +-----BEGIN CERTIFICATE----- +MIICiDCCAg2gAwIBAgIQNfwmXNmET8k9Jj1Xm67XVjAKBggqhkjOPQQDAzCBhDEL +MAkGA1UEBhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5jLjE4MDYGA1UECxMvKGMp +IDIwMDcgdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxJDAi +BgNVBAMTG3RoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EgLSBHMjAeFw0wNzExMDUwMDAw +MDBaFw0zODAxMTgyMzU5NTlaMIGEMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMdGhh +d3RlLCBJbmMuMTgwNgYDVQQLEy8oYykgMjAwNyB0aGF3dGUsIEluYy4gLSBGb3Ig +YXV0aG9yaXplZCB1c2Ugb25seTEkMCIGA1UEAxMbdGhhd3RlIFByaW1hcnkgUm9v +dCBDQSAtIEcyMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAEotWcgnuVnfFSeIf+iha/ +BebfowJPDQfGAFG6DAJSLSKkQjnE/o/qycG+1E3/n3qe4rF8mq2nhglzh9HnmuN6 +papu+7qzcMBniKI11KOasf2twu8x+qi58/sIxpHR+ymVo0IwQDAPBgNVHRMBAf8E +BTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUmtgAMADna3+FGO6Lts6K +DPgR4bswCgYIKoZIzj0EAwMDaQAwZgIxAN344FdHW6fmCsO99YCKlzUNG4k8VIZ3 +KMqh9HneteY4sPBlcIx/AlTCv//YoT7ZzwIxAMSNlPzcU9LcnXgWHxUzI1NS41ox +XZ3Krr0TKUQNJ1uo52icEvdYPy5yAlejj6EULg== +-----END CERTIFICATE----- + +# Issuer: CN=thawte Primary Root CA - G3 O=thawte, Inc. OU=Certification Services Division/(c) 2008 thawte, Inc. - For authorized use only +# Subject: CN=thawte Primary Root CA - G3 O=thawte, Inc. OU=Certification Services Division/(c) 2008 thawte, Inc. - For authorized use only +# Label: "thawte Primary Root CA - G3" +# Serial: 127614157056681299805556476275995414779 +# MD5 Fingerprint: fb:1b:5d:43:8a:94:cd:44:c6:76:f2:43:4b:47:e7:31 +# SHA1 Fingerprint: f1:8b:53:8d:1b:e9:03:b6:a6:f0:56:43:5b:17:15:89:ca:f3:6b:f2 +# SHA256 Fingerprint: 4b:03:f4:58:07:ad:70:f2:1b:fc:2c:ae:71:c9:fd:e4:60:4c:06:4c:f5:ff:b6:86:ba:e5:db:aa:d7:fd:d3:4c +-----BEGIN CERTIFICATE----- +MIIEKjCCAxKgAwIBAgIQYAGXt0an6rS0mtZLL/eQ+zANBgkqhkiG9w0BAQsFADCB +rjELMAkGA1UEBhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5jLjEoMCYGA1UECxMf +Q2VydGlmaWNhdGlvbiBTZXJ2aWNlcyBEaXZpc2lvbjE4MDYGA1UECxMvKGMpIDIw +MDggdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxJDAiBgNV +BAMTG3RoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EgLSBHMzAeFw0wODA0MDIwMDAwMDBa +Fw0zNzEyMDEyMzU5NTlaMIGuMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMdGhhd3Rl +LCBJbmMuMSgwJgYDVQQLEx9DZXJ0aWZpY2F0aW9uIFNlcnZpY2VzIERpdmlzaW9u +MTgwNgYDVQQLEy8oYykgMjAwOCB0aGF3dGUsIEluYy4gLSBGb3IgYXV0aG9yaXpl +ZCB1c2Ugb25seTEkMCIGA1UEAxMbdGhhd3RlIFByaW1hcnkgUm9vdCBDQSAtIEcz +MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAsr8nLPvb2FvdeHsbnndm +gcs+vHyu86YnmjSjaDFxODNi5PNxZnmxqWWjpYvVj2AtP0LMqmsywCPLLEHd5N/8 +YZzic7IilRFDGF/Eth9XbAoFWCLINkw6fKXRz4aviKdEAhN0cXMKQlkC+BsUa0Lf +b1+6a4KinVvnSr0eAXLbS3ToO39/fR8EtCab4LRarEc9VbjXsCZSKAExQGbY2SS9 +9irY7CFJXJv2eul/VTV+lmuNk5Mny5K76qxAwJ/C+IDPXfRa3M50hqY+bAtTyr2S +zhkGcuYMXDhpxwTWvGzOW/b3aJzcJRVIiKHpqfiYnODz1TEoYRFsZ5aNOZnLwkUk +OQIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNV +HQ4EFgQUrWyqlGCc7eT/+j4KdCtjA/e2Wb8wDQYJKoZIhvcNAQELBQADggEBABpA +2JVlrAmSicY59BDlqQ5mU1143vokkbvnRFHfxhY0Cu9qRFHqKweKA3rD6z8KLFIW +oCtDuSWQP3CpMyVtRRooOyfPqsMpQhvfO0zAMzRbQYi/aytlryjvsvXDqmbOe1bu +t8jLZ8HJnBoYuMTDSQPxYA5QzUbF83d597YV4Djbxy8ooAw/dyZ02SUS2jHaGh7c +KUGRIjxpp7sC8rZcJwOJ9Abqm+RyguOhCcHpABnTPtRwa7pxpqpYrvS76Wy274fM +m7v/OeZWYdMKp8RcTGB7BXcmer/YB1IsYvdwY9k5vG8cwnncdimvzsUsZAReiDZu +MdRAGmI0Nj81Aa6sY6A= +-----END CERTIFICATE----- + +# Issuer: CN=GeoTrust Primary Certification Authority - G2 O=GeoTrust Inc. OU=(c) 2007 GeoTrust Inc. - For authorized use only +# Subject: CN=GeoTrust Primary Certification Authority - G2 O=GeoTrust Inc. OU=(c) 2007 GeoTrust Inc. - For authorized use only +# Label: "GeoTrust Primary Certification Authority - G2" +# Serial: 80682863203381065782177908751794619243 +# MD5 Fingerprint: 01:5e:d8:6b:bd:6f:3d:8e:a1:31:f8:12:e0:98:73:6a +# SHA1 Fingerprint: 8d:17:84:d5:37:f3:03:7d:ec:70:fe:57:8b:51:9a:99:e6:10:d7:b0 +# SHA256 Fingerprint: 5e:db:7a:c4:3b:82:a0:6a:87:61:e8:d7:be:49:79:eb:f2:61:1f:7d:d7:9b:f9:1c:1c:6b:56:6a:21:9e:d7:66 +-----BEGIN CERTIFICATE----- +MIICrjCCAjWgAwIBAgIQPLL0SAoA4v7rJDteYD7DazAKBggqhkjOPQQDAzCBmDEL +MAkGA1UEBhMCVVMxFjAUBgNVBAoTDUdlb1RydXN0IEluYy4xOTA3BgNVBAsTMChj +KSAyMDA3IEdlb1RydXN0IEluYy4gLSBGb3IgYXV0aG9yaXplZCB1c2Ugb25seTE2 +MDQGA1UEAxMtR2VvVHJ1c3QgUHJpbWFyeSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0 +eSAtIEcyMB4XDTA3MTEwNTAwMDAwMFoXDTM4MDExODIzNTk1OVowgZgxCzAJBgNV +BAYTAlVTMRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMTkwNwYDVQQLEzAoYykgMjAw +NyBHZW9UcnVzdCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxNjA0BgNV +BAMTLUdlb1RydXN0IFByaW1hcnkgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgLSBH +MjB2MBAGByqGSM49AgEGBSuBBAAiA2IABBWx6P0DFUPlrOuHNxFi79KDNlJ9RVcL +So17VDs6bl8VAsBQps8lL33KSLjHUGMcKiEIfJo22Av+0SbFWDEwKCXzXV2juLal +tJLtbCyf691DiaI8S0iRHVDsJt/WYC69IaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAO +BgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFBVfNVdRVfslsq0DafwBo/q+EVXVMAoG +CCqGSM49BAMDA2cAMGQCMGSWWaboCd6LuvpaiIjwH5HTRqjySkwCY/tsXzjbLkGT +qQ7mndwxHLKgpxgceeHHNgIwOlavmnRs9vuD4DPTCF+hnMJbn0bWtsuRBmOiBucz +rD6ogRLQy7rQkgu2npaqBA+K +-----END CERTIFICATE----- + +# Issuer: CN=VeriSign Universal Root Certification Authority O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 2008 VeriSign, Inc. - For authorized use only +# Subject: CN=VeriSign Universal Root Certification Authority O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 2008 VeriSign, Inc. - For authorized use only +# Label: "VeriSign Universal Root Certification Authority" +# Serial: 85209574734084581917763752644031726877 +# MD5 Fingerprint: 8e:ad:b5:01:aa:4d:81:e4:8c:1d:d1:e1:14:00:95:19 +# SHA1 Fingerprint: 36:79:ca:35:66:87:72:30:4d:30:a5:fb:87:3b:0f:a7:7b:b7:0d:54 +# SHA256 Fingerprint: 23:99:56:11:27:a5:71:25:de:8c:ef:ea:61:0d:df:2f:a0:78:b5:c8:06:7f:4e:82:82:90:bf:b8:60:e8:4b:3c +-----BEGIN CERTIFICATE----- +MIIEuTCCA6GgAwIBAgIQQBrEZCGzEyEDDrvkEhrFHTANBgkqhkiG9w0BAQsFADCB +vTELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQL +ExZWZXJpU2lnbiBUcnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwOCBWZXJp +U2lnbiwgSW5jLiAtIEZvciBhdXRob3JpemVkIHVzZSBvbmx5MTgwNgYDVQQDEy9W +ZXJpU2lnbiBVbml2ZXJzYWwgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAe +Fw0wODA0MDIwMDAwMDBaFw0zNzEyMDEyMzU5NTlaMIG9MQswCQYDVQQGEwJVUzEX +MBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZlcmlTaWduIFRydXN0 +IE5ldHdvcmsxOjA4BgNVBAsTMShjKSAyMDA4IFZlcmlTaWduLCBJbmMuIC0gRm9y +IGF1dGhvcml6ZWQgdXNlIG9ubHkxODA2BgNVBAMTL1ZlcmlTaWduIFVuaXZlcnNh +bCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEF +AAOCAQ8AMIIBCgKCAQEAx2E3XrEBNNti1xWb/1hajCMj1mCOkdeQmIN65lgZOIzF +9uVkhbSicfvtvbnazU0AtMgtc6XHaXGVHzk8skQHnOgO+k1KxCHfKWGPMiJhgsWH +H26MfF8WIFFE0XBPV+rjHOPMee5Y2A7Cs0WTwCznmhcrewA3ekEzeOEz4vMQGn+H +LL729fdC4uW/h2KJXwBL38Xd5HVEMkE6HnFuacsLdUYI0crSK5XQz/u5QGtkjFdN +/BMReYTtXlT2NJ8IAfMQJQYXStrxHXpma5hgZqTZ79IugvHw7wnqRMkVauIDbjPT +rJ9VAMf2CGqUuV/c4DPxhGD5WycRtPwW8rtWaoAljQIDAQABo4GyMIGvMA8GA1Ud +EwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMG0GCCsGAQUFBwEMBGEwX6FdoFsw +WTBXMFUWCWltYWdlL2dpZjAhMB8wBwYFKw4DAhoEFI/l0xqGrI2Oa8PPgGrUSBgs +exkuMCUWI2h0dHA6Ly9sb2dvLnZlcmlzaWduLmNvbS92c2xvZ28uZ2lmMB0GA1Ud +DgQWBBS2d/ppSEefUxLVwuoHMnYH0ZcHGTANBgkqhkiG9w0BAQsFAAOCAQEASvj4 +sAPmLGd75JR3Y8xuTPl9Dg3cyLk1uXBPY/ok+myDjEedO2Pzmvl2MpWRsXe8rJq+ +seQxIcaBlVZaDrHC1LGmWazxY8u4TB1ZkErvkBYoH1quEPuBUDgMbMzxPcP1Y+Oz +4yHJJDnp/RVmRvQbEdBNc6N9Rvk97ahfYtTxP/jgdFcrGJ2BtMQo2pSXpXDrrB2+ +BxHw1dvd5Yzw1TKwg+ZX4o+/vqGqvz0dtdQ46tewXDpPaj+PwGZsY6rp2aQW9IHR +lRQOfc2VNNnSj3BzgXucfr2YYdhFh5iQxeuGMMY1v/D/w1WIg0vvBZIGcfK4mJO3 +7M2CYfE45k+XmCpajQ== +-----END CERTIFICATE----- + +# Issuer: CN=VeriSign Class 3 Public Primary Certification Authority - G4 O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 2007 VeriSign, Inc. - For authorized use only +# Subject: CN=VeriSign Class 3 Public Primary Certification Authority - G4 O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 2007 VeriSign, Inc. - For authorized use only +# Label: "VeriSign Class 3 Public Primary Certification Authority - G4" +# Serial: 63143484348153506665311985501458640051 +# MD5 Fingerprint: 3a:52:e1:e7:fd:6f:3a:e3:6f:f3:6f:99:1b:f9:22:41 +# SHA1 Fingerprint: 22:d5:d8:df:8f:02:31:d1:8d:f7:9d:b7:cf:8a:2d:64:c9:3f:6c:3a +# SHA256 Fingerprint: 69:dd:d7:ea:90:bb:57:c9:3e:13:5d:c8:5e:a6:fc:d5:48:0b:60:32:39:bd:c4:54:fc:75:8b:2a:26:cf:7f:79 +-----BEGIN CERTIFICATE----- +MIIDhDCCAwqgAwIBAgIQL4D+I4wOIg9IZxIokYesszAKBggqhkjOPQQDAzCByjEL +MAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZW +ZXJpU2lnbiBUcnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNyBWZXJpU2ln +biwgSW5jLiAtIEZvciBhdXRob3JpemVkIHVzZSBvbmx5MUUwQwYDVQQDEzxWZXJp +U2lnbiBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5IENlcnRpZmljYXRpb24gQXV0aG9y +aXR5IC0gRzQwHhcNMDcxMTA1MDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCByjELMAkG +A1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJp +U2lnbiBUcnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNyBWZXJpU2lnbiwg +SW5jLiAtIEZvciBhdXRob3JpemVkIHVzZSBvbmx5MUUwQwYDVQQDEzxWZXJpU2ln +biBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5IENlcnRpZmljYXRpb24gQXV0aG9yaXR5 +IC0gRzQwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAASnVnp8Utpkmw4tXNherJI9/gHm +GUo9FANL+mAnINmDiWn6VMaaGF5VKmTeBvaNSjutEDxlPZCIBIngMGGzrl0Bp3ve +fLK+ymVhAIau2o970ImtTR1ZmkGxvEeA3J5iw/mjgbIwga8wDwYDVR0TAQH/BAUw +AwEB/zAOBgNVHQ8BAf8EBAMCAQYwbQYIKwYBBQUHAQwEYTBfoV2gWzBZMFcwVRYJ +aW1hZ2UvZ2lmMCEwHzAHBgUrDgMCGgQUj+XTGoasjY5rw8+AatRIGCx7GS4wJRYj +aHR0cDovL2xvZ28udmVyaXNpZ24uY29tL3ZzbG9nby5naWYwHQYDVR0OBBYEFLMW +kf3upm7ktS5Jj4d4gYDs5bG1MAoGCCqGSM49BAMDA2gAMGUCMGYhDBgmYFo4e1ZC +4Kf8NoRRkSAsdk1DPcQdhCPQrNZ8NQbOzWm9kA3bbEhCHQ6qQgIxAJw9SDkjOVga +FRJZap7v1VmyHVIsmXHNxynfGyphe3HR3vPA5Q06Sqotp9iGKt0uEA== +-----END CERTIFICATE----- + +# Issuer: CN=NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny O=NetLock Kft. OU=Tan\xfas\xedtv\xe1nykiad\xf3k (Certification Services) +# Subject: CN=NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny O=NetLock Kft. OU=Tan\xfas\xedtv\xe1nykiad\xf3k (Certification Services) +# Label: "NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny" +# Serial: 80544274841616 +# MD5 Fingerprint: c5:a1:b7:ff:73:dd:d6:d7:34:32:18:df:fc:3c:ad:88 +# SHA1 Fingerprint: 06:08:3f:59:3f:15:a1:04:a0:69:a4:6b:a9:03:d0:06:b7:97:09:91 +# SHA256 Fingerprint: 6c:61:da:c3:a2:de:f0:31:50:6b:e0:36:d2:a6:fe:40:19:94:fb:d1:3d:f9:c8:d4:66:59:92:74:c4:46:ec:98 +-----BEGIN CERTIFICATE----- +MIIEFTCCAv2gAwIBAgIGSUEs5AAQMA0GCSqGSIb3DQEBCwUAMIGnMQswCQYDVQQG +EwJIVTERMA8GA1UEBwwIQnVkYXBlc3QxFTATBgNVBAoMDE5ldExvY2sgS2Z0LjE3 +MDUGA1UECwwuVGFuw7pzw610dsOhbnlraWFkw7NrIChDZXJ0aWZpY2F0aW9uIFNl +cnZpY2VzKTE1MDMGA1UEAwwsTmV0TG9jayBBcmFueSAoQ2xhc3MgR29sZCkgRsWR +dGFuw7pzw610dsOhbnkwHhcNMDgxMjExMTUwODIxWhcNMjgxMjA2MTUwODIxWjCB +pzELMAkGA1UEBhMCSFUxETAPBgNVBAcMCEJ1ZGFwZXN0MRUwEwYDVQQKDAxOZXRM +b2NrIEtmdC4xNzA1BgNVBAsMLlRhbsO6c8OtdHbDoW55a2lhZMOzayAoQ2VydGlm +aWNhdGlvbiBTZXJ2aWNlcykxNTAzBgNVBAMMLE5ldExvY2sgQXJhbnkgKENsYXNz +IEdvbGQpIEbFkXRhbsO6c8OtdHbDoW55MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A +MIIBCgKCAQEAxCRec75LbRTDofTjl5Bu0jBFHjzuZ9lk4BqKf8owyoPjIMHj9DrT +lF8afFttvzBPhCf2nx9JvMaZCpDyD/V/Q4Q3Y1GLeqVw/HpYzY6b7cNGbIRwXdrz +AZAj/E4wqX7hJ2Pn7WQ8oLjJM2P+FpD/sLj916jAwJRDC7bVWaaeVtAkH3B5r9s5 +VA1lddkVQZQBr17s9o3x/61k/iCa11zr/qYfCGSji3ZVrR47KGAuhyXoqq8fxmRG +ILdwfzzeSNuWU7c5d+Qa4scWhHaXWy+7GRWF+GmF9ZmnqfI0p6m2pgP8b4Y9VHx2 +BJtr+UBdADTHLpl1neWIA6pN+APSQnbAGwIDAKiLo0UwQzASBgNVHRMBAf8ECDAG +AQH/AgEEMA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUzPpnk/C2uNClwB7zU/2M +U9+D15YwDQYJKoZIhvcNAQELBQADggEBAKt/7hwWqZw8UQCgwBEIBaeZ5m8BiFRh +bvG5GK1Krf6BQCOUL/t1fC8oS2IkgYIL9WHxHG64YTjrgfpioTtaYtOUZcTh5m2C ++C8lcLIhJsFyUR+MLMOEkMNaj7rP9KdlpeuY0fsFskZ1FSNqb4VjMIDw1Z4fKRzC +bLBQWV2QWzuoDTDPv31/zvGdg73JRm4gpvlhUbohL3u+pRVjodSVh/GeufOJ8z2F +uLjbvrW5KfnaNwUASZQDhETnv0Mxz3WLJdH0pmT1kvarBes96aULNmLazAZfNou2 +XjG4Kvte9nHfRCaexOYNkbQudZWAUWpLMKawYqGT8ZvYzsRjdT9ZR7E= +-----END CERTIFICATE----- + +# Issuer: CN=Staat der Nederlanden Root CA - G2 O=Staat der Nederlanden +# Subject: CN=Staat der Nederlanden Root CA - G2 O=Staat der Nederlanden +# Label: "Staat der Nederlanden Root CA - G2" +# Serial: 10000012 +# MD5 Fingerprint: 7c:a5:0f:f8:5b:9a:7d:6d:30:ae:54:5a:e3:42:a2:8a +# SHA1 Fingerprint: 59:af:82:79:91:86:c7:b4:75:07:cb:cf:03:57:46:eb:04:dd:b7:16 +# SHA256 Fingerprint: 66:8c:83:94:7d:a6:3b:72:4b:ec:e1:74:3c:31:a0:e6:ae:d0:db:8e:c5:b3:1b:e3:77:bb:78:4f:91:b6:71:6f +-----BEGIN CERTIFICATE----- +MIIFyjCCA7KgAwIBAgIEAJiWjDANBgkqhkiG9w0BAQsFADBaMQswCQYDVQQGEwJO +TDEeMBwGA1UECgwVU3RhYXQgZGVyIE5lZGVybGFuZGVuMSswKQYDVQQDDCJTdGFh +dCBkZXIgTmVkZXJsYW5kZW4gUm9vdCBDQSAtIEcyMB4XDTA4MDMyNjExMTgxN1oX +DTIwMDMyNTExMDMxMFowWjELMAkGA1UEBhMCTkwxHjAcBgNVBAoMFVN0YWF0IGRl +ciBOZWRlcmxhbmRlbjErMCkGA1UEAwwiU3RhYXQgZGVyIE5lZGVybGFuZGVuIFJv +b3QgQ0EgLSBHMjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMVZ5291 +qj5LnLW4rJ4L5PnZyqtdj7U5EILXr1HgO+EASGrP2uEGQxGZqhQlEq0i6ABtQ8Sp +uOUfiUtnvWFI7/3S4GCI5bkYYCjDdyutsDeqN95kWSpGV+RLufg3fNU254DBtvPU +Z5uW6M7XxgpT0GtJlvOjCwV3SPcl5XCsMBQgJeN/dVrlSPhOewMHBPqCYYdu8DvE +pMfQ9XQ+pV0aCPKbJdL2rAQmPlU6Yiile7Iwr/g3wtG61jj99O9JMDeZJiFIhQGp +5Rbn3JBV3w/oOM2ZNyFPXfUib2rFEhZgF1XyZWampzCROME4HYYEhLoaJXhena/M +UGDWE4dS7WMfbWV9whUYdMrhfmQpjHLYFhN9C0lK8SgbIHRrxT3dsKpICT0ugpTN +GmXZK4iambwYfp/ufWZ8Pr2UuIHOzZgweMFvZ9C+X+Bo7d7iscksWXiSqt8rYGPy +5V6548r6f1CGPqI0GAwJaCgRHOThuVw+R7oyPxjMW4T182t0xHJ04eOLoEq9jWYv +6q012iDTiIJh8BIitrzQ1aTsr1SIJSQ8p22xcik/Plemf1WvbibG/ufMQFxRRIEK +eN5KzlW/HdXZt1bv8Hb/C3m1r737qWmRRpdogBQ2HbN/uymYNqUg+oJgYjOk7Na6 +B6duxc8UpufWkjTYgfX8HV2qXB72o007uPc5AgMBAAGjgZcwgZQwDwYDVR0TAQH/ +BAUwAwEB/zBSBgNVHSAESzBJMEcGBFUdIAAwPzA9BggrBgEFBQcCARYxaHR0cDov +L3d3dy5wa2lvdmVyaGVpZC5ubC9wb2xpY2llcy9yb290LXBvbGljeS1HMjAOBgNV +HQ8BAf8EBAMCAQYwHQYDVR0OBBYEFJFoMocVHYnitfGsNig0jQt8YojrMA0GCSqG +SIb3DQEBCwUAA4ICAQCoQUpnKpKBglBu4dfYszk78wIVCVBR7y29JHuIhjv5tLyS +CZa59sCrI2AGeYwRTlHSeYAz+51IvuxBQ4EffkdAHOV6CMqqi3WtFMTC6GY8ggen +5ieCWxjmD27ZUD6KQhgpxrRW/FYQoAUXvQwjf/ST7ZwaUb7dRUG/kSS0H4zpX897 +IZmflZ85OkYcbPnNe5yQzSipx6lVu6xiNGI1E0sUOlWDuYaNkqbG9AclVMwWVxJK +gnjIFNkXgiYtXSAfea7+1HAWFpWD2DU5/1JddRwWxRNVz0fMdWVSSt7wsKfkCpYL ++63C4iWEst3kvX5ZbJvw8NjnyvLplzh+ib7M+zkXYT9y2zqR2GUBGR2tUKRXCnxL +vJxxcypFURmFzI79R6d0lR2o0a9OF7FpJsKqeFdbxU2n5Z4FF5TKsl+gSRiNNOkm +bEgeqmiSBeGCc1qb3AdbCG19ndeNIdn8FCCqwkXfP+cAslHkwvgFuXkajDTznlvk +N1trSt8sV4pAWja63XVECDdCcAz+3F4hoKOKwJCcaNpQ5kUQR3i2TtJlycM33+FC +Y7BXN0Ute4qcvwXqZVUz9zkQxSgqIXobisQk+T8VyJoVIPVVYpbtbZNQvOSqeK3Z +ywplh6ZmwcSBo3c6WB4L7oOLnR7SUqTMHW+wmG2UMbX4cQrcufx9MmDm66+KAQ== +-----END CERTIFICATE----- + +# Issuer: CN=Hongkong Post Root CA 1 O=Hongkong Post +# Subject: CN=Hongkong Post Root CA 1 O=Hongkong Post +# Label: "Hongkong Post Root CA 1" +# Serial: 1000 +# MD5 Fingerprint: a8:0d:6f:39:78:b9:43:6d:77:42:6d:98:5a:cc:23:ca +# SHA1 Fingerprint: d6:da:a8:20:8d:09:d2:15:4d:24:b5:2f:cb:34:6e:b2:58:b2:8a:58 +# SHA256 Fingerprint: f9:e6:7d:33:6c:51:00:2a:c0:54:c6:32:02:2d:66:dd:a2:e7:e3:ff:f1:0a:d0:61:ed:31:d8:bb:b4:10:cf:b2 +-----BEGIN CERTIFICATE----- +MIIDMDCCAhigAwIBAgICA+gwDQYJKoZIhvcNAQEFBQAwRzELMAkGA1UEBhMCSEsx +FjAUBgNVBAoTDUhvbmdrb25nIFBvc3QxIDAeBgNVBAMTF0hvbmdrb25nIFBvc3Qg +Um9vdCBDQSAxMB4XDTAzMDUxNTA1MTMxNFoXDTIzMDUxNTA0NTIyOVowRzELMAkG +A1UEBhMCSEsxFjAUBgNVBAoTDUhvbmdrb25nIFBvc3QxIDAeBgNVBAMTF0hvbmdr +b25nIFBvc3QgUm9vdCBDQSAxMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKC +AQEArP84tulmAknjorThkPlAj3n54r15/gK97iSSHSL22oVyaf7XPwnU3ZG1ApzQ +jVrhVcNQhrkpJsLj2aDxaQMoIIBFIi1WpztUlVYiWR8o3x8gPW2iNr4joLFutbEn +PzlTCeqrauh0ssJlXI6/fMN4hM2eFvz1Lk8gKgifd/PFHsSaUmYeSF7jEAaPIpjh +ZY4bXSNmO7ilMlHIhqqhqZ5/dpTCpmy3QfDVyAY45tQM4vM7TG1QjMSDJ8EThFk9 +nnV0ttgCXjqQesBCNnLsak3c78QA3xMYV18meMjWCnl3v/evt3a5pQuEF10Q6m/h +q5URX208o1xNg1vysxmKgIsLhwIDAQABoyYwJDASBgNVHRMBAf8ECDAGAQH/AgED +MA4GA1UdDwEB/wQEAwIBxjANBgkqhkiG9w0BAQUFAAOCAQEADkbVPK7ih9legYsC +mEEIjEy82tvuJxuC52pF7BaLT4Wg87JwvVqWuspube5Gi27nKi6Wsxkz67SfqLI3 +7piol7Yutmcn1KZJ/RyTZXaeQi/cImyaT/JaFTmxcdcrUehtHJjA2Sr0oYJ71clB +oiMBdDhViw+5LmeiIAQ32pwL0xch4I+XeTRvhEgCIDMb5jREn5Fw9IBehEPCKdJs +EhTkYY2sEJCehFC78JZvRZ+K88psT/oROhUVRsPNH4NbLUES7VBnQRM9IauUiqpO +fMGx+6fWtScvl6tu4B3i0RwsH0Ti/L6RoZz71ilTc4afU9hDDl3WY4JxHYB0yvbi +AmvZWg== +-----END CERTIFICATE----- + +# Issuer: CN=SecureSign RootCA11 O=Japan Certification Services, Inc. +# Subject: CN=SecureSign RootCA11 O=Japan Certification Services, Inc. +# Label: "SecureSign RootCA11" +# Serial: 1 +# MD5 Fingerprint: b7:52:74:e2:92:b4:80:93:f2:75:e4:cc:d7:f2:ea:26 +# SHA1 Fingerprint: 3b:c4:9f:48:f8:f3:73:a0:9c:1e:bd:f8:5b:b1:c3:65:c7:d8:11:b3 +# SHA256 Fingerprint: bf:0f:ee:fb:9e:3a:58:1a:d5:f9:e9:db:75:89:98:57:43:d2:61:08:5c:4d:31:4f:6f:5d:72:59:aa:42:16:12 +-----BEGIN CERTIFICATE----- +MIIDbTCCAlWgAwIBAgIBATANBgkqhkiG9w0BAQUFADBYMQswCQYDVQQGEwJKUDEr +MCkGA1UEChMiSmFwYW4gQ2VydGlmaWNhdGlvbiBTZXJ2aWNlcywgSW5jLjEcMBoG +A1UEAxMTU2VjdXJlU2lnbiBSb290Q0ExMTAeFw0wOTA0MDgwNDU2NDdaFw0yOTA0 +MDgwNDU2NDdaMFgxCzAJBgNVBAYTAkpQMSswKQYDVQQKEyJKYXBhbiBDZXJ0aWZp +Y2F0aW9uIFNlcnZpY2VzLCBJbmMuMRwwGgYDVQQDExNTZWN1cmVTaWduIFJvb3RD +QTExMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA/XeqpRyQBTvLTJsz +i1oURaTnkBbR31fSIRCkF/3frNYfp+TbfPfs37gD2pRY/V1yfIw/XwFndBWW4wI8 +h9uuywGOwvNmxoVF9ALGOrVisq/6nL+k5tSAMJjzDbaTj6nU2DbysPyKyiyhFTOV +MdrAG/LuYpmGYz+/3ZMqg6h2uRMft85OQoWPIucuGvKVCbIFtUROd6EgvanyTgp9 +UK31BQ1FT0Zx/Sg+U/sE2C3XZR1KG/rPO7AxmjVuyIsG0wCR8pQIZUyxNAYAeoni +8McDWc/V1uinMrPmmECGxc0nEovMe863ETxiYAcjPitAbpSACW22s293bzUIUPsC +h8U+iQIDAQABo0IwQDAdBgNVHQ4EFgQUW/hNT7KlhtQ60vFjmqC+CfZXt94wDgYD +VR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEB +AKChOBZmLqdWHyGcBvod7bkixTgm2E5P7KN/ed5GIaGHd48HCJqypMWvDzKYC3xm +KbabfSVSSUOrTC4rbnpwrxYO4wJs+0LmGJ1F2FXI6Dvd5+H0LgscNFxsWEr7jIhQ +X5Ucv+2rIrVls4W6ng+4reV6G4pQOh29Dbx7VFALuUKvVaAYga1lme++5Jy/xIWr +QbJUb9wlze144o4MjQlJ3WN7WmmWAiGovVJZ6X01y8hSyn+B/tlr0/cR7SXf+Of5 +pPpyl4RTDaXQMhhRdlkUbA/r7F+AjHVDg8OFmP9Mni0N5HeDk061lgeLKBObjBmN +QSdJQO7e5iNEOdyhIta6A/I= +-----END CERTIFICATE----- + +# Issuer: CN=Microsec e-Szigno Root CA 2009 O=Microsec Ltd. +# Subject: CN=Microsec e-Szigno Root CA 2009 O=Microsec Ltd. +# Label: "Microsec e-Szigno Root CA 2009" +# Serial: 14014712776195784473 +# MD5 Fingerprint: f8:49:f4:03:bc:44:2d:83:be:48:69:7d:29:64:fc:b1 +# SHA1 Fingerprint: 89:df:74:fe:5c:f4:0f:4a:80:f9:e3:37:7d:54:da:91:e1:01:31:8e +# SHA256 Fingerprint: 3c:5f:81:fe:a5:fa:b8:2c:64:bf:a2:ea:ec:af:cd:e8:e0:77:fc:86:20:a7:ca:e5:37:16:3d:f3:6e:db:f3:78 +-----BEGIN CERTIFICATE----- +MIIECjCCAvKgAwIBAgIJAMJ+QwRORz8ZMA0GCSqGSIb3DQEBCwUAMIGCMQswCQYD +VQQGEwJIVTERMA8GA1UEBwwIQnVkYXBlc3QxFjAUBgNVBAoMDU1pY3Jvc2VjIEx0 +ZC4xJzAlBgNVBAMMHk1pY3Jvc2VjIGUtU3ppZ25vIFJvb3QgQ0EgMjAwOTEfMB0G +CSqGSIb3DQEJARYQaW5mb0BlLXN6aWduby5odTAeFw0wOTA2MTYxMTMwMThaFw0y +OTEyMzAxMTMwMThaMIGCMQswCQYDVQQGEwJIVTERMA8GA1UEBwwIQnVkYXBlc3Qx +FjAUBgNVBAoMDU1pY3Jvc2VjIEx0ZC4xJzAlBgNVBAMMHk1pY3Jvc2VjIGUtU3pp +Z25vIFJvb3QgQ0EgMjAwOTEfMB0GCSqGSIb3DQEJARYQaW5mb0BlLXN6aWduby5o +dTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOn4j/NjrdqG2KfgQvvP +kd6mJviZpWNwrZuuyjNAfW2WbqEORO7hE52UQlKavXWFdCyoDh2Tthi3jCyoz/tc +cbna7P7ofo/kLx2yqHWH2Leh5TvPmUpG0IMZfcChEhyVbUr02MelTTMuhTlAdX4U +fIASmFDHQWe4oIBhVKZsTh/gnQ4H6cm6M+f+wFUoLAKApxn1ntxVUwOXewdI/5n7 +N4okxFnMUBBjjqqpGrCEGob5X7uxUG6k0QrM1XF+H6cbfPVTbiJfyyvm1HxdrtbC +xkzlBQHZ7Vf8wSN5/PrIJIOV87VqUQHQd9bpEqH5GoP7ghu5sJf0dgYzQ0mg/wu1 ++rUCAwEAAaOBgDB+MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0G +A1UdDgQWBBTLD8bfQkPMPcu1SCOhGnqmKrs0aDAfBgNVHSMEGDAWgBTLD8bfQkPM +Pcu1SCOhGnqmKrs0aDAbBgNVHREEFDASgRBpbmZvQGUtc3ppZ25vLmh1MA0GCSqG +SIb3DQEBCwUAA4IBAQDJ0Q5eLtXMs3w+y/w9/w0olZMEyL/azXm4Q5DwpL7v8u8h +mLzU1F0G9u5C7DBsoKqpyvGvivo/C3NqPuouQH4frlRheesuCDfXI/OMn74dseGk +ddug4lQUsbocKaQY9hK6ohQU4zE1yED/t+AFdlfBHFny+L/k7SViXITwfn4fs775 +tyERzAMBVnCnEJIeGzSBHq2cGsMEPO0CYdYeBvNfOofyK/FFh+U9rNHHV4S9a67c +2Pm2G2JwCz02yULyMtd6YebS2z3PyKnJm9zbWETXbzivf3jTo60adbocwTZ8jx5t +HMN1Rq41Bab2XD0h7lbwyYIiLXpUq3DDfSJlgnCW +-----END CERTIFICATE----- + +# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R3 +# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R3 +# Label: "GlobalSign Root CA - R3" +# Serial: 4835703278459759426209954 +# MD5 Fingerprint: c5:df:b8:49:ca:05:13:55:ee:2d:ba:1a:c3:3e:b0:28 +# SHA1 Fingerprint: d6:9b:56:11:48:f0:1c:77:c5:45:78:c1:09:26:df:5b:85:69:76:ad +# SHA256 Fingerprint: cb:b5:22:d7:b7:f1:27:ad:6a:01:13:86:5b:df:1c:d4:10:2e:7d:07:59:af:63:5a:7c:f4:72:0d:c9:63:c5:3b +-----BEGIN CERTIFICATE----- +MIIDXzCCAkegAwIBAgILBAAAAAABIVhTCKIwDQYJKoZIhvcNAQELBQAwTDEgMB4G +A1UECxMXR2xvYmFsU2lnbiBSb290IENBIC0gUjMxEzARBgNVBAoTCkdsb2JhbFNp +Z24xEzARBgNVBAMTCkdsb2JhbFNpZ24wHhcNMDkwMzE4MTAwMDAwWhcNMjkwMzE4 +MTAwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxTaWduIFJvb3QgQ0EgLSBSMzETMBEG +A1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2lnbjCCASIwDQYJKoZI +hvcNAQEBBQADggEPADCCAQoCggEBAMwldpB5BngiFvXAg7aEyiie/QV2EcWtiHL8 +RgJDx7KKnQRfJMsuS+FggkbhUqsMgUdwbN1k0ev1LKMPgj0MK66X17YUhhB5uzsT +gHeMCOFJ0mpiLx9e+pZo34knlTifBtc+ycsmWQ1z3rDI6SYOgxXG71uL0gRgykmm +KPZpO/bLyCiR5Z2KYVc3rHQU3HTgOu5yLy6c+9C7v/U9AOEGM+iCK65TpjoWc4zd +QQ4gOsC0p6Hpsk+QLjJg6VfLuQSSaGjlOCZgdbKfd/+RFO+uIEn8rUAVSNECMWEZ +XriX7613t2Saer9fwRPvm2L7DWzgVGkWqQPabumDk3F2xmmFghcCAwEAAaNCMEAw +DgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFI/wS3+o +LkUkrk1Q+mOai97i3Ru8MA0GCSqGSIb3DQEBCwUAA4IBAQBLQNvAUKr+yAzv95ZU +RUm7lgAJQayzE4aGKAczymvmdLm6AC2upArT9fHxD4q/c2dKg8dEe3jgr25sbwMp +jjM5RcOO5LlXbKr8EpbsU8Yt5CRsuZRj+9xTaGdWPoO4zzUhw8lo/s7awlOqzJCK +6fBdRoyV3XpYKBovHd7NADdBj+1EbddTKJd+82cEHhXXipa0095MJ6RMG3NzdvQX +mcIfeg7jLQitChws/zyrVQ4PkX4268NXSb7hLi18YIvDQVETI53O9zJrlAGomecs +Mx86OyXShkDOOyyGeMlhLxS67ttVb9+E7gUJTb0o2HLO02JQZR7rkpeDMdmztcpH +WD9f +-----END CERTIFICATE----- + +# Issuer: CN=Autoridad de Certificacion Firmaprofesional CIF A62634068 +# Subject: CN=Autoridad de Certificacion Firmaprofesional CIF A62634068 +# Label: "Autoridad de Certificacion Firmaprofesional CIF A62634068" +# Serial: 6047274297262753887 +# MD5 Fingerprint: 73:3a:74:7a:ec:bb:a3:96:a6:c2:e4:e2:c8:9b:c0:c3 +# SHA1 Fingerprint: ae:c5:fb:3f:c8:e1:bf:c4:e5:4f:03:07:5a:9a:e8:00:b7:f7:b6:fa +# SHA256 Fingerprint: 04:04:80:28:bf:1f:28:64:d4:8f:9a:d4:d8:32:94:36:6a:82:88:56:55:3f:3b:14:30:3f:90:14:7f:5d:40:ef +-----BEGIN CERTIFICATE----- +MIIGFDCCA/ygAwIBAgIIU+w77vuySF8wDQYJKoZIhvcNAQEFBQAwUTELMAkGA1UE +BhMCRVMxQjBABgNVBAMMOUF1dG9yaWRhZCBkZSBDZXJ0aWZpY2FjaW9uIEZpcm1h +cHJvZmVzaW9uYWwgQ0lGIEE2MjYzNDA2ODAeFw0wOTA1MjAwODM4MTVaFw0zMDEy +MzEwODM4MTVaMFExCzAJBgNVBAYTAkVTMUIwQAYDVQQDDDlBdXRvcmlkYWQgZGUg +Q2VydGlmaWNhY2lvbiBGaXJtYXByb2Zlc2lvbmFsIENJRiBBNjI2MzQwNjgwggIi +MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDKlmuO6vj78aI14H9M2uDDUtd9 +thDIAl6zQyrET2qyyhxdKJp4ERppWVevtSBC5IsP5t9bpgOSL/UR5GLXMnE42QQM +cas9UX4PB99jBVzpv5RvwSmCwLTaUbDBPLutN0pcyvFLNg4kq7/DhHf9qFD0sefG +L9ItWY16Ck6WaVICqjaY7Pz6FIMMNx/Jkjd/14Et5cS54D40/mf0PmbR0/RAz15i +NA9wBj4gGFrO93IbJWyTdBSTo3OxDqqHECNZXyAFGUftaI6SEspd/NYrspI8IM/h +X68gvqB2f3bl7BqGYTM+53u0P6APjqK5am+5hyZvQWyIplD9amML9ZMWGxmPsu2b +m8mQ9QEM3xk9Dz44I8kvjwzRAv4bVdZO0I08r0+k8/6vKtMFnXkIoctXMbScyJCy +Z/QYFpM6/EfY0XiWMR+6KwxfXZmtY4laJCB22N/9q06mIqqdXuYnin1oKaPnirja +EbsXLZmdEyRG98Xi2J+Of8ePdG1asuhy9azuJBCtLxTa/y2aRnFHvkLfuwHb9H/T +KI8xWVvTyQKmtFLKbpf7Q8UIJm+K9Lv9nyiqDdVF8xM6HdjAeI9BZzwelGSuewvF +6NkBiDkal4ZkQdU7hwxu+g/GvUgUvzlN1J5Bto+WHWOWk9mVBngxaJ43BjuAiUVh +OSPHG0SjFeUc+JIwuwIDAQABo4HvMIHsMBIGA1UdEwEB/wQIMAYBAf8CAQEwDgYD +VR0PAQH/BAQDAgEGMB0GA1UdDgQWBBRlzeurNR4APn7VdMActHNHDhpkLzCBpgYD +VR0gBIGeMIGbMIGYBgRVHSAAMIGPMC8GCCsGAQUFBwIBFiNodHRwOi8vd3d3LmZp +cm1hcHJvZmVzaW9uYWwuY29tL2NwczBcBggrBgEFBQcCAjBQHk4AUABhAHMAZQBv +ACAAZABlACAAbABhACAAQgBvAG4AYQBuAG8AdgBhACAANAA3ACAAQgBhAHIAYwBl +AGwAbwBuAGEAIAAwADgAMAAxADcwDQYJKoZIhvcNAQEFBQADggIBABd9oPm03cXF +661LJLWhAqvdpYhKsg9VSytXjDvlMd3+xDLx51tkljYyGOylMnfX40S2wBEqgLk9 +am58m9Ot/MPWo+ZkKXzR4Tgegiv/J2Wv+xYVxC5xhOW1//qkR71kMrv2JYSiJ0L1 +ILDCExARzRAVukKQKtJE4ZYm6zFIEv0q2skGz3QeqUvVhyj5eTSSPi5E6PaPT481 +PyWzOdxjKpBrIF/EUhJOlywqrJ2X3kjyo2bbwtKDlaZmp54lD+kLM5FlClrD2VQS +3a/DTg4fJl4N3LON7NWBcN7STyQF82xO9UxJZo3R/9ILJUFI/lGExkKvgATP0H5k +SeTy36LssUzAKh3ntLFlosS88Zj0qnAHY7S42jtM+kAiMFsRpvAFDsYCA0irhpuF +3dvd6qJ2gHN99ZwExEWN57kci57q13XRcrHedUTnQn3iV2t93Jm8PYMo6oCTjcVM +ZcFwgbg4/EMxsvYDNEeyrPsiBsse3RdHHF9mudMaotoRsaS8I8nkvof/uZS2+F0g +StRf571oe2XyFR7SOqkt6dhrJKyXWERHrVkY8SFlcN7ONGCoQPHzPKTDKCOM/icz +Q0CgFzzr6juwcqajuUpLXhZI9LK8yIySxZ2frHI2vDSANGupi5LAuBft7HZT9SQB +jLMi6Et8Vcad+qMUu2WFbm5PEn4KPJ2V +-----END CERTIFICATE----- + +# Issuer: CN=Izenpe.com O=IZENPE S.A. +# Subject: CN=Izenpe.com O=IZENPE S.A. +# Label: "Izenpe.com" +# Serial: 917563065490389241595536686991402621 +# MD5 Fingerprint: a6:b0:cd:85:80:da:5c:50:34:a3:39:90:2f:55:67:73 +# SHA1 Fingerprint: 2f:78:3d:25:52:18:a7:4a:65:39:71:b5:2c:a2:9c:45:15:6f:e9:19 +# SHA256 Fingerprint: 25:30:cc:8e:98:32:15:02:ba:d9:6f:9b:1f:ba:1b:09:9e:2d:29:9e:0f:45:48:bb:91:4f:36:3b:c0:d4:53:1f +-----BEGIN CERTIFICATE----- +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 +-----END CERTIFICATE----- + +# Issuer: CN=Chambers of Commerce Root - 2008 O=AC Camerfirma S.A. +# Subject: CN=Chambers of Commerce Root - 2008 O=AC Camerfirma S.A. +# Label: "Chambers of Commerce Root - 2008" +# Serial: 11806822484801597146 +# MD5 Fingerprint: 5e:80:9e:84:5a:0e:65:0b:17:02:f3:55:18:2a:3e:d7 +# SHA1 Fingerprint: 78:6a:74:ac:76:ab:14:7f:9c:6a:30:50:ba:9e:a8:7e:fe:9a:ce:3c +# SHA256 Fingerprint: 06:3e:4a:fa:c4:91:df:d3:32:f3:08:9b:85:42:e9:46:17:d8:93:d7:fe:94:4e:10:a7:93:7e:e2:9d:96:93:c0 +-----BEGIN CERTIFICATE----- +MIIHTzCCBTegAwIBAgIJAKPaQn6ksa7aMA0GCSqGSIb3DQEBBQUAMIGuMQswCQYD +VQQGEwJFVTFDMEEGA1UEBxM6TWFkcmlkIChzZWUgY3VycmVudCBhZGRyZXNzIGF0 +IHd3dy5jYW1lcmZpcm1hLmNvbS9hZGRyZXNzKTESMBAGA1UEBRMJQTgyNzQzMjg3 +MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMuQS4xKTAnBgNVBAMTIENoYW1iZXJz +IG9mIENvbW1lcmNlIFJvb3QgLSAyMDA4MB4XDTA4MDgwMTEyMjk1MFoXDTM4MDcz +MTEyMjk1MFowga4xCzAJBgNVBAYTAkVVMUMwQQYDVQQHEzpNYWRyaWQgKHNlZSBj +dXJyZW50IGFkZHJlc3MgYXQgd3d3LmNhbWVyZmlybWEuY29tL2FkZHJlc3MpMRIw +EAYDVQQFEwlBODI3NDMyODcxGzAZBgNVBAoTEkFDIENhbWVyZmlybWEgUy5BLjEp +MCcGA1UEAxMgQ2hhbWJlcnMgb2YgQ29tbWVyY2UgUm9vdCAtIDIwMDgwggIiMA0G +CSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCvAMtwNyuAWko6bHiUfaN/Gh/2NdW9 +28sNRHI+JrKQUrpjOyhYb6WzbZSm891kDFX29ufyIiKAXuFixrYp4YFs8r/lfTJq +VKAyGVn+H4vXPWCGhSRv4xGzdz4gljUha7MI2XAuZPeEklPWDrCQiorjh40G072Q +DuKZoRuGDtqaCrsLYVAGUvGef3bsyw/QHg3PmTA9HMRFEFis1tPo1+XqxQEHd9ZR +5gN/ikilTWh1uem8nk4ZcfUyS5xtYBkL+8ydddy/Js2Pk3g5eXNeJQ7KXOt3EgfL +ZEFHcpOrUMPrCXZkNNI5t3YRCQ12RcSprj1qr7V9ZS+UWBDsXHyvfuK2GNnQm05a +Sd+pZgvMPMZ4fKecHePOjlO+Bd5gD2vlGts/4+EhySnB8esHnFIbAURRPHsl18Tl +UlRdJQfKFiC4reRB7noI/plvg6aRArBsNlVq5331lubKgdaX8ZSD6e2wsWsSaR6s ++12pxZjptFtYer49okQ6Y1nUCyXeG0+95QGezdIp1Z8XGQpvvwyQ0wlf2eOKNcx5 +Wk0ZN5K3xMGtr/R5JJqyAQuxr1yW84Ay+1w9mPGgP0revq+ULtlVmhduYJ1jbLhj +ya6BXBg14JC7vjxPNyK5fuvPnnchpj04gftI2jE9K+OJ9dC1vX7gUMQSibMjmhAx +hduub+84Mxh2EQIDAQABo4IBbDCCAWgwEgYDVR0TAQH/BAgwBgEB/wIBDDAdBgNV +HQ4EFgQU+SSsD7K1+HnA+mCIG8TZTQKeFxkwgeMGA1UdIwSB2zCB2IAU+SSsD7K1 ++HnA+mCIG8TZTQKeFxmhgbSkgbEwga4xCzAJBgNVBAYTAkVVMUMwQQYDVQQHEzpN +YWRyaWQgKHNlZSBjdXJyZW50IGFkZHJlc3MgYXQgd3d3LmNhbWVyZmlybWEuY29t +L2FkZHJlc3MpMRIwEAYDVQQFEwlBODI3NDMyODcxGzAZBgNVBAoTEkFDIENhbWVy +ZmlybWEgUy5BLjEpMCcGA1UEAxMgQ2hhbWJlcnMgb2YgQ29tbWVyY2UgUm9vdCAt +IDIwMDiCCQCj2kJ+pLGu2jAOBgNVHQ8BAf8EBAMCAQYwPQYDVR0gBDYwNDAyBgRV +HSAAMCowKAYIKwYBBQUHAgEWHGh0dHA6Ly9wb2xpY3kuY2FtZXJmaXJtYS5jb20w +DQYJKoZIhvcNAQEFBQADggIBAJASryI1wqM58C7e6bXpeHxIvj99RZJe6dqxGfwW +PJ+0W2aeaufDuV2I6A+tzyMP3iU6XsxPpcG1Lawk0lgH3qLPaYRgM+gQDROpI9CF +5Y57pp49chNyM/WqfcZjHwj0/gF/JM8rLFQJ3uIrbZLGOU8W6jx+ekbURWpGqOt1 +glanq6B8aBMz9p0w8G8nOSQjKpD9kCk18pPfNKXG9/jvjA9iSnyu0/VU+I22mlaH +FoI6M6taIgj3grrqLuBHmrS1RaMFO9ncLkVAO+rcf+g769HsJtg1pDDFOqxXnrN2 +pSB7+R5KBWIBpih1YJeSDW4+TTdDDZIVnBgizVGZoCkaPF+KMjNbMMeJL0eYD6MD +xvbxrN8y8NmBGuScvfaAFPDRLLmF9dijscilIeUcE5fuDr3fKanvNFNb0+RqE4QG +tjICxFKuItLcsiFCGtpA8CnJ7AoMXOLQusxI0zcKzBIKinmwPQN/aUv0NCB9szTq +jktk9T79syNnFQ0EuPAtwQlRPLJsFfClI9eDdOTlLsn+mCdCxqvGnrDQWzilm1De +fhiYtUU79nm06PcaewaD+9CL2rvHvRirCG88gGtAPxkZumWK5r7VXNM21+9AUiRg +OGcEMeyP84LG3rlV8zsxkVrctQgVrXYlCg17LofiDKYGvCYQbTed7N14jHyAxfDZ +d0jQ +-----END CERTIFICATE----- + +# Issuer: CN=Global Chambersign Root - 2008 O=AC Camerfirma S.A. +# Subject: CN=Global Chambersign Root - 2008 O=AC Camerfirma S.A. +# Label: "Global Chambersign Root - 2008" +# Serial: 14541511773111788494 +# MD5 Fingerprint: 9e:80:ff:78:01:0c:2e:c1:36:bd:fe:96:90:6e:08:f3 +# SHA1 Fingerprint: 4a:bd:ee:ec:95:0d:35:9c:89:ae:c7:52:a1:2c:5b:29:f6:d6:aa:0c +# SHA256 Fingerprint: 13:63:35:43:93:34:a7:69:80:16:a0:d3:24:de:72:28:4e:07:9d:7b:52:20:bb:8f:bd:74:78:16:ee:be:ba:ca +-----BEGIN CERTIFICATE----- +MIIHSTCCBTGgAwIBAgIJAMnN0+nVfSPOMA0GCSqGSIb3DQEBBQUAMIGsMQswCQYD +VQQGEwJFVTFDMEEGA1UEBxM6TWFkcmlkIChzZWUgY3VycmVudCBhZGRyZXNzIGF0 +IHd3dy5jYW1lcmZpcm1hLmNvbS9hZGRyZXNzKTESMBAGA1UEBRMJQTgyNzQzMjg3 +MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMuQS4xJzAlBgNVBAMTHkdsb2JhbCBD +aGFtYmVyc2lnbiBSb290IC0gMjAwODAeFw0wODA4MDExMjMxNDBaFw0zODA3MzEx +MjMxNDBaMIGsMQswCQYDVQQGEwJFVTFDMEEGA1UEBxM6TWFkcmlkIChzZWUgY3Vy +cmVudCBhZGRyZXNzIGF0IHd3dy5jYW1lcmZpcm1hLmNvbS9hZGRyZXNzKTESMBAG +A1UEBRMJQTgyNzQzMjg3MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMuQS4xJzAl +BgNVBAMTHkdsb2JhbCBDaGFtYmVyc2lnbiBSb290IC0gMjAwODCCAiIwDQYJKoZI +hvcNAQEBBQADggIPADCCAgoCggIBAMDfVtPkOpt2RbQT2//BthmLN0EYlVJH6xed +KYiONWwGMi5HYvNJBL99RDaxccy9Wglz1dmFRP+RVyXfXjaOcNFccUMd2drvXNL7 +G706tcuto8xEpw2uIRU/uXpbknXYpBI4iRmKt4DS4jJvVpyR1ogQC7N0ZJJ0YPP2 +zxhPYLIj0Mc7zmFLmY/CDNBAspjcDahOo7kKrmCgrUVSY7pmvWjg+b4aqIG7HkF4 +ddPB/gBVsIdU6CeQNR1MM62X/JcumIS/LMmjv9GYERTtY/jKmIhYF5ntRQOXfjyG +HoiMvvKRhI9lNNgATH23MRdaKXoKGCQwoze1eqkBfSbW+Q6OWfH9GzO1KTsXO0G2 +Id3UwD2ln58fQ1DJu7xsepeY7s2MH/ucUa6LcL0nn3HAa6x9kGbo1106DbDVwo3V +yJ2dwW3Q0L9R5OP4wzg2rtandeavhENdk5IMagfeOx2YItaswTXbo6Al/3K1dh3e +beksZixShNBFks4c5eUzHdwHU1SjqoI7mjcv3N2gZOnm3b2u/GSFHTynyQbehP9r +6GsaPMWis0L7iwk+XwhSx2LE1AVxv8Rk5Pihg+g+EpuoHtQ2TS9x9o0o9oOpE9Jh +wZG7SMA0j0GMS0zbaRL/UJScIINZc+18ofLx/d33SdNDWKBWY8o9PeU1VlnpDsog +zCtLkykPAgMBAAGjggFqMIIBZjASBgNVHRMBAf8ECDAGAQH/AgEMMB0GA1UdDgQW +BBS5CcqcHtvTbDprru1U8VuTBjUuXjCB4QYDVR0jBIHZMIHWgBS5CcqcHtvTbDpr +ru1U8VuTBjUuXqGBsqSBrzCBrDELMAkGA1UEBhMCRVUxQzBBBgNVBAcTOk1hZHJp +ZCAoc2VlIGN1cnJlbnQgYWRkcmVzcyBhdCB3d3cuY2FtZXJmaXJtYS5jb20vYWRk +cmVzcykxEjAQBgNVBAUTCUE4Mjc0MzI4NzEbMBkGA1UEChMSQUMgQ2FtZXJmaXJt +YSBTLkEuMScwJQYDVQQDEx5HbG9iYWwgQ2hhbWJlcnNpZ24gUm9vdCAtIDIwMDiC +CQDJzdPp1X0jzjAOBgNVHQ8BAf8EBAMCAQYwPQYDVR0gBDYwNDAyBgRVHSAAMCow +KAYIKwYBBQUHAgEWHGh0dHA6Ly9wb2xpY3kuY2FtZXJmaXJtYS5jb20wDQYJKoZI +hvcNAQEFBQADggIBAICIf3DekijZBZRG/5BXqfEv3xoNa/p8DhxJJHkn2EaqbylZ +UohwEurdPfWbU1Rv4WCiqAm57OtZfMY18dwY6fFn5a+6ReAJ3spED8IXDneRRXoz +X1+WLGiLwUePmJs9wOzL9dWCkoQ10b42OFZyMVtHLaoXpGNR6woBrX/sdZ7LoR/x +fxKxueRkf2fWIyr0uDldmOghp+G9PUIadJpwr2hsUF1Jz//7Dl3mLEfXgTpZALVz +a2Mg9jFFCDkO9HB+QHBaP9BrQql0PSgvAm11cpUJjUhjxsYjV5KTXjXBjfkK9yyd +Yhz2rXzdpjEetrHHfoUm+qRqtdpjMNHvkzeyZi99Bffnt0uYlDXA2TopwZ2yUDMd +SqlapskD7+3056huirRXhOukP9DuqqqHW2Pok+JrqNS4cnhrG+055F3Lm6qH1U9O +AP7Zap88MQ8oAgF9mOinsKJknnn4SPIVqczmyETrP3iZ8ntxPjzxmKfFGBI/5rso +M0LpRQp8bfKGeS/Fghl9CYl8slR2iK7ewfPM4W7bMdaTrpmg7yVqc5iJWzouE4ge +v8CSlDQb4ye3ix5vQv/n6TebUB0tovkC7stYWDpxvGjjqsGvHCgfotwjZT+B6q6Z +09gwzxMNTxXJhLynSC34MCN32EZLeW32jO06f2ARePTpm67VVMB0gNELQp/B +-----END CERTIFICATE----- + +# Issuer: CN=Go Daddy Root Certificate Authority - G2 O=GoDaddy.com, Inc. +# Subject: CN=Go Daddy Root Certificate Authority - G2 O=GoDaddy.com, Inc. +# Label: "Go Daddy Root Certificate Authority - G2" +# Serial: 0 +# MD5 Fingerprint: 80:3a:bc:22:c1:e6:fb:8d:9b:3b:27:4a:32:1b:9a:01 +# SHA1 Fingerprint: 47:be:ab:c9:22:ea:e8:0e:78:78:34:62:a7:9f:45:c2:54:fd:e6:8b +# SHA256 Fingerprint: 45:14:0b:32:47:eb:9c:c8:c5:b4:f0:d7:b5:30:91:f7:32:92:08:9e:6e:5a:63:e2:74:9d:d3:ac:a9:19:8e:da +-----BEGIN CERTIFICATE----- +MIIDxTCCAq2gAwIBAgIBADANBgkqhkiG9w0BAQsFADCBgzELMAkGA1UEBhMCVVMx +EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxGjAYBgNVBAoT +EUdvRGFkZHkuY29tLCBJbmMuMTEwLwYDVQQDEyhHbyBEYWRkeSBSb290IENlcnRp +ZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5MDkwMTAwMDAwMFoXDTM3MTIzMTIz +NTk1OVowgYMxCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6b25hMRMwEQYDVQQH +EwpTY290dHNkYWxlMRowGAYDVQQKExFHb0RhZGR5LmNvbSwgSW5jLjExMC8GA1UE +AxMoR28gRGFkZHkgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIw +DQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAL9xYgjx+lk09xvJGKP3gElY6SKD +E6bFIEMBO4Tx5oVJnyfq9oQbTqC023CYxzIBsQU+B07u9PpPL1kwIuerGVZr4oAH +/PMWdYA5UXvl+TW2dE6pjYIT5LY/qQOD+qK+ihVqf94Lw7YZFAXK6sOoBJQ7Rnwy +DfMAZiLIjWltNowRGLfTshxgtDj6AozO091GB94KPutdfMh8+7ArU6SSYmlRJQVh +GkSBjCypQ5Yj36w6gZoOKcUcqeldHraenjAKOc7xiID7S13MMuyFYkMlNAJWJwGR +tDtwKj9useiciAF9n9T521NtYJ2/LOdYq7hfRvzOxBsDPAnrSTFcaUaz4EcCAwEA +AaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYE +FDqahQcQZyi27/a9BUFuIMGU2g/eMA0GCSqGSIb3DQEBCwUAA4IBAQCZ21151fmX +WWcDYfF+OwYxdS2hII5PZYe096acvNjpL9DbWu7PdIxztDhC2gV7+AJ1uP2lsdeu +9tfeE8tTEH6KRtGX+rcuKxGrkLAngPnon1rpN5+r5N9ss4UXnT3ZJE95kTXWXwTr +gIOrmgIttRD02JDHBHNA7XIloKmf7J6raBKZV8aPEjoJpL1E/QYVN8Gb5DKj7Tjo +2GTzLH4U/ALqn83/B2gX2yKQOC16jdFU8WnjXzPKej17CuPKf1855eJ1usV2GDPO +LPAvTK33sefOT6jEm0pUBsV/fdUID+Ic/n4XuKxe9tQWskMJDE32p2u0mYRlynqI +4uJEvlz36hz1 +-----END CERTIFICATE----- + +# Issuer: CN=Starfield Root Certificate Authority - G2 O=Starfield Technologies, Inc. +# Subject: CN=Starfield Root Certificate Authority - G2 O=Starfield Technologies, Inc. +# Label: "Starfield Root Certificate Authority - G2" +# Serial: 0 +# MD5 Fingerprint: d6:39:81:c6:52:7e:96:69:fc:fc:ca:66:ed:05:f2:96 +# SHA1 Fingerprint: b5:1c:06:7c:ee:2b:0c:3d:f8:55:ab:2d:92:f4:fe:39:d4:e7:0f:0e +# SHA256 Fingerprint: 2c:e1:cb:0b:f9:d2:f9:e1:02:99:3f:be:21:51:52:c3:b2:dd:0c:ab:de:1c:68:e5:31:9b:83:91:54:db:b7:f5 +-----BEGIN CERTIFICATE----- +MIID3TCCAsWgAwIBAgIBADANBgkqhkiG9w0BAQsFADCBjzELMAkGA1UEBhMCVVMx +EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoT +HFN0YXJmaWVsZCBUZWNobm9sb2dpZXMsIEluYy4xMjAwBgNVBAMTKVN0YXJmaWVs +ZCBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5MDkwMTAwMDAw +MFoXDTM3MTIzMTIzNTk1OVowgY8xCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6 +b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxTdGFyZmllbGQgVGVj +aG5vbG9naWVzLCBJbmMuMTIwMAYDVQQDEylTdGFyZmllbGQgUm9vdCBDZXJ0aWZp +Y2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC +ggEBAL3twQP89o/8ArFvW59I2Z154qK3A2FWGMNHttfKPTUuiUP3oWmb3ooa/RMg +nLRJdzIpVv257IzdIvpy3Cdhl+72WoTsbhm5iSzchFvVdPtrX8WJpRBSiUZV9Lh1 +HOZ/5FSuS/hVclcCGfgXcVnrHigHdMWdSL5stPSksPNkN3mSwOxGXn/hbVNMYq/N +Hwtjuzqd+/x5AJhhdM8mgkBj87JyahkNmcrUDnXMN/uLicFZ8WJ/X7NfZTD4p7dN +dloedl40wOiWVpmKs/B/pM293DIxfJHP4F8R+GuqSVzRmZTRouNjWwl2tVZi4Ut0 +HZbUJtQIBFnQmA4O5t78w+wfkPECAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAO +BgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFHwMMh+n2TB/xH1oo2Kooc6rB1snMA0G +CSqGSIb3DQEBCwUAA4IBAQARWfolTwNvlJk7mh+ChTnUdgWUXuEok21iXQnCoKjU +sHU48TRqneSfioYmUeYs0cYtbpUgSpIB7LiKZ3sx4mcujJUDJi5DnUox9g61DLu3 +4jd/IroAow57UvtruzvE03lRTs2Q9GcHGcg8RnoNAX3FWOdt5oUwF5okxBDgBPfg +8n/Uqgr/Qh037ZTlZFkSIHc40zI+OIF1lnP6aI+xy84fxez6nH7PfrHxBy22/L/K +pL/QlwVKvOoYKAKQvVR4CSFx09F9HdkWsKlhPdAKACL8x3vLCWRFCztAgfd9fDL1 +mMpYjn0q7pBZc2T5NnReJaH1ZgUufzkVqSr7UIuOhWn0 +-----END CERTIFICATE----- + +# Issuer: CN=Starfield Services Root Certificate Authority - G2 O=Starfield Technologies, Inc. +# Subject: CN=Starfield Services Root Certificate Authority - G2 O=Starfield Technologies, Inc. +# Label: "Starfield Services Root Certificate Authority - G2" +# Serial: 0 +# MD5 Fingerprint: 17:35:74:af:7b:61:1c:eb:f4:f9:3c:e2:ee:40:f9:a2 +# SHA1 Fingerprint: 92:5a:8f:8d:2c:6d:04:e0:66:5f:59:6a:ff:22:d8:63:e8:25:6f:3f +# SHA256 Fingerprint: 56:8d:69:05:a2:c8:87:08:a4:b3:02:51:90:ed:cf:ed:b1:97:4a:60:6a:13:c6:e5:29:0f:cb:2a:e6:3e:da:b5 +-----BEGIN CERTIFICATE----- +MIID7zCCAtegAwIBAgIBADANBgkqhkiG9w0BAQsFADCBmDELMAkGA1UEBhMCVVMx +EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoT +HFN0YXJmaWVsZCBUZWNobm9sb2dpZXMsIEluYy4xOzA5BgNVBAMTMlN0YXJmaWVs +ZCBTZXJ2aWNlcyBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5 +MDkwMTAwMDAwMFoXDTM3MTIzMTIzNTk1OVowgZgxCzAJBgNVBAYTAlVTMRAwDgYD +VQQIEwdBcml6b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxTdGFy +ZmllbGQgVGVjaG5vbG9naWVzLCBJbmMuMTswOQYDVQQDEzJTdGFyZmllbGQgU2Vy +dmljZXMgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZI +hvcNAQEBBQADggEPADCCAQoCggEBANUMOsQq+U7i9b4Zl1+OiFOxHz/Lz58gE20p +OsgPfTz3a3Y4Y9k2YKibXlwAgLIvWX/2h/klQ4bnaRtSmpDhcePYLQ1Ob/bISdm2 +8xpWriu2dBTrz/sm4xq6HZYuajtYlIlHVv8loJNwU4PahHQUw2eeBGg6345AWh1K +Ts9DkTvnVtYAcMtS7nt9rjrnvDH5RfbCYM8TWQIrgMw0R9+53pBlbQLPLJGmpufe +hRhJfGZOozptqbXuNC66DQO4M99H67FrjSXZm86B0UVGMpZwh94CDklDhbZsc7tk +6mFBrMnUVN+HL8cisibMn1lUaJ/8viovxFUcdUBgF4UCVTmLfwUCAwEAAaNCMEAw +DwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFJxfAN+q +AdcwKziIorhtSpzyEZGDMA0GCSqGSIb3DQEBCwUAA4IBAQBLNqaEd2ndOxmfZyMI +bw5hyf2E3F/YNoHN2BtBLZ9g3ccaaNnRbobhiCPPE95Dz+I0swSdHynVv/heyNXB +ve6SbzJ08pGCL72CQnqtKrcgfU28elUSwhXqvfdqlS5sdJ/PHLTyxQGjhdByPq1z +qwubdQxtRbeOlKyWN7Wg0I8VRw7j6IPdj/3vQQF3zCepYoUz8jcI73HPdwbeyBkd +iEDPfUYd/x7H4c7/I9vG+o1VTqkC50cRRj70/b17KSa7qWFiNyi2LSr2EIZkyXCn +0q23KXB56jzaYyWf/Wi3MOxw+3WKt21gZ7IeyLnp2KhvAotnDU0mV3HaIPzBSlCN +sSi6 +-----END CERTIFICATE----- + +# Issuer: CN=AffirmTrust Commercial O=AffirmTrust +# Subject: CN=AffirmTrust Commercial O=AffirmTrust +# Label: "AffirmTrust Commercial" +# Serial: 8608355977964138876 +# MD5 Fingerprint: 82:92:ba:5b:ef:cd:8a:6f:a6:3d:55:f9:84:f6:d6:b7 +# SHA1 Fingerprint: f9:b5:b6:32:45:5f:9c:be:ec:57:5f:80:dc:e9:6e:2c:c7:b2:78:b7 +# SHA256 Fingerprint: 03:76:ab:1d:54:c5:f9:80:3c:e4:b2:e2:01:a0:ee:7e:ef:7b:57:b6:36:e8:a9:3c:9b:8d:48:60:c9:6f:5f:a7 +-----BEGIN CERTIFICATE----- +MIIDTDCCAjSgAwIBAgIId3cGJyapsXwwDQYJKoZIhvcNAQELBQAwRDELMAkGA1UE +BhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVz +dCBDb21tZXJjaWFsMB4XDTEwMDEyOTE0MDYwNloXDTMwMTIzMTE0MDYwNlowRDEL +MAkGA1UEBhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZp +cm1UcnVzdCBDb21tZXJjaWFsMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKC +AQEA9htPZwcroRX1BiLLHwGy43NFBkRJLLtJJRTWzsO3qyxPxkEylFf6EqdbDuKP +Hx6GGaeqtS25Xw2Kwq+FNXkyLbscYjfysVtKPcrNcV/pQr6U6Mje+SJIZMblq8Yr +ba0F8PrVC8+a5fBQpIs7R6UjW3p6+DM/uO+Zl+MgwdYoic+U+7lF7eNAFxHUdPAL +MeIrJmqbTFeurCA+ukV6BfO9m2kVrn1OIGPENXY6BwLJN/3HR+7o8XYdcxXyl6S1 +yHp52UKqK39c/s4mT6NmgTWvRLpUHhwwMmWd5jyTXlBOeuM61G7MGvv50jeuJCqr +VwMiKA1JdX+3KNp1v47j3A55MQIDAQABo0IwQDAdBgNVHQ4EFgQUnZPGU4teyq8/ +nx4P5ZmVvCT2lI8wDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwDQYJ +KoZIhvcNAQELBQADggEBAFis9AQOzcAN/wr91LoWXym9e2iZWEnStB03TX8nfUYG +XUPGhi4+c7ImfU+TqbbEKpqrIZcUsd6M06uJFdhrJNTxFq7YpFzUf1GO7RgBsZNj +vbz4YYCanrHOQnDiqX0GJX0nof5v7LMeJNrjS1UaADs1tDvZ110w/YETifLCBivt +Z8SOyUOyXGsViQK8YvxO8rUzqrJv0wqiUOP2O+guRMLbZjipM1ZI8W0bM40NjD9g +N53Tym1+NH4Nn3J2ixufcv1SNUFFApYvHLKac0khsUlHRUe072o0EclNmsxZt9YC +nlpOZbWUrhvfKbAW8b8Angc6F2S1BLUjIZkKlTuXfO8= +-----END CERTIFICATE----- + +# Issuer: CN=AffirmTrust Networking O=AffirmTrust +# Subject: CN=AffirmTrust Networking O=AffirmTrust +# Label: "AffirmTrust Networking" +# Serial: 8957382827206547757 +# MD5 Fingerprint: 42:65:ca:be:01:9a:9a:4c:a9:8c:41:49:cd:c0:d5:7f +# SHA1 Fingerprint: 29:36:21:02:8b:20:ed:02:f5:66:c5:32:d1:d6:ed:90:9f:45:00:2f +# SHA256 Fingerprint: 0a:81:ec:5a:92:97:77:f1:45:90:4a:f3:8d:5d:50:9f:66:b5:e2:c5:8f:cd:b5:31:05:8b:0e:17:f3:f0:b4:1b +-----BEGIN CERTIFICATE----- +MIIDTDCCAjSgAwIBAgIIfE8EORzUmS0wDQYJKoZIhvcNAQEFBQAwRDELMAkGA1UE +BhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVz +dCBOZXR3b3JraW5nMB4XDTEwMDEyOTE0MDgyNFoXDTMwMTIzMTE0MDgyNFowRDEL +MAkGA1UEBhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZp +cm1UcnVzdCBOZXR3b3JraW5nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKC +AQEAtITMMxcua5Rsa2FSoOujz3mUTOWUgJnLVWREZY9nZOIG41w3SfYvm4SEHi3y +YJ0wTsyEheIszx6e/jarM3c1RNg1lho9Nuh6DtjVR6FqaYvZ/Ls6rnla1fTWcbua +kCNrmreIdIcMHl+5ni36q1Mr3Lt2PpNMCAiMHqIjHNRqrSK6mQEubWXLviRmVSRL +QESxG9fhwoXA3hA/Pe24/PHxI1Pcv2WXb9n5QHGNfb2V1M6+oF4nI979ptAmDgAp +6zxG8D1gvz9Q0twmQVGeFDdCBKNwV6gbh+0t+nvujArjqWaJGctB+d1ENmHP4ndG +yH329JKBNv3bNPFyfvMMFr20FQIDAQABo0IwQDAdBgNVHQ4EFgQUBx/S55zawm6i +QLSwelAQUHTEyL0wDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwDQYJ +KoZIhvcNAQEFBQADggEBAIlXshZ6qML91tmbmzTCnLQyFE2npN/svqe++EPbkTfO +tDIuUFUaNU52Q3Eg75N3ThVwLofDwR1t3Mu1J9QsVtFSUzpE0nPIxBsFZVpikpzu +QY0x2+c06lkh1QF612S4ZDnNye2v7UsDSKegmQGA3GWjNq5lWUhPgkvIZfFXHeVZ +Lgo/bNjR9eUJtGxUAArgFU2HdW23WJZa3W3SAKD0m0i+wzekujbgfIeFlxoVot4u +olu9rxj5kFDNcFn4J2dHy8egBzp90SxdbBk6ZrV9/ZFvgrG+CJPbFEfxojfHRZ48 +x3evZKiT3/Zpg4Jg8klCNO1aAFSFHBY2kgxc+qatv9s= +-----END CERTIFICATE----- + +# Issuer: CN=AffirmTrust Premium O=AffirmTrust +# Subject: CN=AffirmTrust Premium O=AffirmTrust +# Label: "AffirmTrust Premium" +# Serial: 7893706540734352110 +# MD5 Fingerprint: c4:5d:0e:48:b6:ac:28:30:4e:0a:bc:f9:38:16:87:57 +# SHA1 Fingerprint: d8:a6:33:2c:e0:03:6f:b1:85:f6:63:4f:7d:6a:06:65:26:32:28:27 +# SHA256 Fingerprint: 70:a7:3f:7f:37:6b:60:07:42:48:90:45:34:b1:14:82:d5:bf:0e:69:8e:cc:49:8d:f5:25:77:eb:f2:e9:3b:9a +-----BEGIN CERTIFICATE----- +MIIFRjCCAy6gAwIBAgIIbYwURrGmCu4wDQYJKoZIhvcNAQEMBQAwQTELMAkGA1UE +BhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MRwwGgYDVQQDDBNBZmZpcm1UcnVz +dCBQcmVtaXVtMB4XDTEwMDEyOTE0MTAzNloXDTQwMTIzMTE0MTAzNlowQTELMAkG +A1UEBhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MRwwGgYDVQQDDBNBZmZpcm1U +cnVzdCBQcmVtaXVtMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAxBLf +qV/+Qd3d9Z+K4/as4Tx4mrzY8H96oDMq3I0gW64tb+eT2TZwamjPjlGjhVtnBKAQ +JG9dKILBl1fYSCkTtuG+kU3fhQxTGJoeJKJPj/CihQvL9Cl/0qRY7iZNyaqoe5rZ ++jjeRFcV5fiMyNlI4g0WJx0eyIOFJbe6qlVBzAMiSy2RjYvmia9mx+n/K+k8rNrS +s8PhaJyJ+HoAVt70VZVs+7pk3WKL3wt3MutizCaam7uqYoNMtAZ6MMgpv+0GTZe5 +HMQxK9VfvFMSF5yZVylmd2EhMQcuJUmdGPLu8ytxjLW6OQdJd/zvLpKQBY0tL3d7 +70O/Nbua2Plzpyzy0FfuKE4mX4+QaAkvuPjcBukumj5Rp9EixAqnOEhss/n/fauG +V+O61oV4d7pD6kh/9ti+I20ev9E2bFhc8e6kGVQa9QPSdubhjL08s9NIS+LI+H+S +qHZGnEJlPqQewQcDWkYtuJfzt9WyVSHvutxMAJf7FJUnM7/oQ0dG0giZFmA7mn7S +5u046uwBHjxIVkkJx0w3AJ6IDsBz4W9m6XJHMD4Q5QsDyZpCAGzFlH5hxIrff4Ia +C1nEWTJ3s7xgaVY5/bQGeyzWZDbZvUjthB9+pSKPKrhC9IK31FOQeE4tGv2Bb0TX +OwF0lkLgAOIua+rF7nKsu7/+6qqo+Nz2snmKtmcCAwEAAaNCMEAwHQYDVR0OBBYE +FJ3AZ6YMItkm9UWrpmVSESfYRaxjMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/ +BAQDAgEGMA0GCSqGSIb3DQEBDAUAA4ICAQCzV00QYk465KzquByvMiPIs0laUZx2 +KI15qldGF9X1Uva3ROgIRL8YhNILgM3FEv0AVQVhh0HctSSePMTYyPtwni94loMg +Nt58D2kTiKV1NpgIpsbfrM7jWNa3Pt668+s0QNiigfV4Py/VpfzZotReBA4Xrf5B +8OWycvpEgjNC6C1Y91aMYj+6QrCcDFx+LmUmXFNPALJ4fqENmS2NuB2OosSw/WDQ +MKSOyARiqcTtNd56l+0OOF6SL5Nwpamcb6d9Ex1+xghIsV5n61EIJenmJWtSKZGc +0jlzCFfemQa0W50QBuHCAKi4HEoCChTQwUHK+4w1IX2COPKpVJEZNZOUbWo6xbLQ +u4mGk+ibyQ86p3q4ofB4Rvr8Ny/lioTz3/4E2aFooC8k4gmVBtWVyuEklut89pMF +u+1z6S3RdTnX5yTb2E5fQ4+e0BQ5v1VwSJlXMbSc7kqYA5YwH2AG7hsj/oFgIxpH +YoWlzBk0gG+zrBrjn/B7SK3VAdlntqlyk+otZrWyuOQ9PLLvTIzq6we/qzWaVYa8 +GKa1qF60g2xraUDTn9zxw2lrueFtCfTxqlB2Cnp9ehehVZZCmTEJ3WARjQUwfuaO +RtGdFNrHF+QFlozEJLUbzxQHskD4o55BhrwE0GuWyCqANP2/7waj3VjFhT0+j/6e +KeC2uAloGRwYQw== +-----END CERTIFICATE----- + +# Issuer: CN=AffirmTrust Premium ECC O=AffirmTrust +# Subject: CN=AffirmTrust Premium ECC O=AffirmTrust +# Label: "AffirmTrust Premium ECC" +# Serial: 8401224907861490260 +# MD5 Fingerprint: 64:b0:09:55:cf:b1:d5:99:e2:be:13:ab:a6:5d:ea:4d +# SHA1 Fingerprint: b8:23:6b:00:2f:1d:16:86:53:01:55:6c:11:a4:37:ca:eb:ff:c3:bb +# SHA256 Fingerprint: bd:71:fd:f6:da:97:e4:cf:62:d1:64:7a:dd:25:81:b0:7d:79:ad:f8:39:7e:b4:ec:ba:9c:5e:84:88:82:14:23 +-----BEGIN CERTIFICATE----- +MIIB/jCCAYWgAwIBAgIIdJclisc/elQwCgYIKoZIzj0EAwMwRTELMAkGA1UEBhMC +VVMxFDASBgNVBAoMC0FmZmlybVRydXN0MSAwHgYDVQQDDBdBZmZpcm1UcnVzdCBQ +cmVtaXVtIEVDQzAeFw0xMDAxMjkxNDIwMjRaFw00MDEyMzExNDIwMjRaMEUxCzAJ +BgNVBAYTAlVTMRQwEgYDVQQKDAtBZmZpcm1UcnVzdDEgMB4GA1UEAwwXQWZmaXJt +VHJ1c3QgUHJlbWl1bSBFQ0MwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQNMF4bFZ0D +0KF5Nbc6PJJ6yhUczWLznCZcBz3lVPqj1swS6vQUX+iOGasvLkjmrBhDeKzQN8O9 +ss0s5kfiGuZjuD0uL3jET9v0D6RoTFVya5UdThhClXjMNzyR4ptlKymjQjBAMB0G +A1UdDgQWBBSaryl6wBE1NSZRMADDav5A1a7WPDAPBgNVHRMBAf8EBTADAQH/MA4G +A1UdDwEB/wQEAwIBBjAKBggqhkjOPQQDAwNnADBkAjAXCfOHiFBar8jAQr9HX/Vs +aobgxCd05DhT1wV/GzTjxi+zygk8N53X57hG8f2h4nECMEJZh0PUUd+60wkyWs6I +flc9nF9Ca/UHLbXwgpP5WW+uZPpY5Yse42O+tYHNbwKMeQ== +-----END CERTIFICATE----- + +# Issuer: CN=Certum Trusted Network CA O=Unizeto Technologies S.A. OU=Certum Certification Authority +# Subject: CN=Certum Trusted Network CA O=Unizeto Technologies S.A. OU=Certum Certification Authority +# Label: "Certum Trusted Network CA" +# Serial: 279744 +# MD5 Fingerprint: d5:e9:81:40:c5:18:69:fc:46:2c:89:75:62:0f:aa:78 +# SHA1 Fingerprint: 07:e0:32:e0:20:b7:2c:3f:19:2f:06:28:a2:59:3a:19:a7:0f:06:9e +# SHA256 Fingerprint: 5c:58:46:8d:55:f5:8e:49:7e:74:39:82:d2:b5:00:10:b6:d1:65:37:4a:cf:83:a7:d4:a3:2d:b7:68:c4:40:8e +-----BEGIN CERTIFICATE----- +MIIDuzCCAqOgAwIBAgIDBETAMA0GCSqGSIb3DQEBBQUAMH4xCzAJBgNVBAYTAlBM +MSIwIAYDVQQKExlVbml6ZXRvIFRlY2hub2xvZ2llcyBTLkEuMScwJQYDVQQLEx5D +ZXJ0dW0gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkxIjAgBgNVBAMTGUNlcnR1bSBU +cnVzdGVkIE5ldHdvcmsgQ0EwHhcNMDgxMDIyMTIwNzM3WhcNMjkxMjMxMTIwNzM3 +WjB+MQswCQYDVQQGEwJQTDEiMCAGA1UEChMZVW5pemV0byBUZWNobm9sb2dpZXMg +Uy5BLjEnMCUGA1UECxMeQ2VydHVtIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MSIw +IAYDVQQDExlDZXJ0dW0gVHJ1c3RlZCBOZXR3b3JrIENBMIIBIjANBgkqhkiG9w0B +AQEFAAOCAQ8AMIIBCgKCAQEA4/t9o3K6wvDJFIf1awFO4W5AB7ptJ11/91sts1rH +UV+rpDKmYYe2bg+G0jACl/jXaVehGDldamR5xgFZrDwxSjh80gTSSyjoIF87B6LM +TXPb865Px1bVWqeWifrzq2jUI4ZZJ88JJ7ysbnKDHDBy3+Ci6dLhdHUZvSqeexVU +BBvXQzmtVSjF4hq79MDkrjhJM8x2hZ85RdKknvISjFH4fOQtf/WsX+sWn7Et0brM +kUJ3TCXJkDhv2/DM+44el1k+1WBO5gUo7Ul5E0u6SNsv+XLTOcr+H9g0cvW0QM8x +AcPs3hEtF10fuFDRXhmnad4HMyjKUJX5p1TLVIZQRan5SQIDAQABo0IwQDAPBgNV +HRMBAf8EBTADAQH/MB0GA1UdDgQWBBQIds3LB/8k9sXN7buQvOKEN0Z19zAOBgNV +HQ8BAf8EBAMCAQYwDQYJKoZIhvcNAQEFBQADggEBAKaorSLOAT2mo/9i0Eidi15y +sHhE49wcrwn9I0j6vSrEuVUEtRCjjSfeC4Jj0O7eDDd5QVsisrCaQVymcODU0HfL +I9MA4GxWL+FpDQ3Zqr8hgVDZBqWo/5U30Kr+4rP1mS1FhIrlQgnXdAIv94nYmem8 +J9RHjboNRhx3zxSkHLmkMcScKHQDNP8zGSal6Q10tz6XxnboJ5ajZt3hrvJBW8qY +VoNzcOSGGtIxQbovvi0TWnZvTuhOgQ4/WwMioBK+ZlgRSssDxLQqKi2WF+A5VLxI +03YnnZotBqbJ7DnSq9ufmgsnAjUpsUCV5/nonFWIGUbWtzT1fs45mtk48VH3Tyw= +-----END CERTIFICATE----- + +# Issuer: CN=TWCA Root Certification Authority O=TAIWAN-CA OU=Root CA +# Subject: CN=TWCA Root Certification Authority O=TAIWAN-CA OU=Root CA +# Label: "TWCA Root Certification Authority" +# Serial: 1 +# MD5 Fingerprint: aa:08:8f:f6:f9:7b:b7:f2:b1:a7:1e:9b:ea:ea:bd:79 +# SHA1 Fingerprint: cf:9e:87:6d:d3:eb:fc:42:26:97:a3:b5:a3:7a:a0:76:a9:06:23:48 +# SHA256 Fingerprint: bf:d8:8f:e1:10:1c:41:ae:3e:80:1b:f8:be:56:35:0e:e9:ba:d1:a6:b9:bd:51:5e:dc:5c:6d:5b:87:11:ac:44 +-----BEGIN CERTIFICATE----- +MIIDezCCAmOgAwIBAgIBATANBgkqhkiG9w0BAQUFADBfMQswCQYDVQQGEwJUVzES +MBAGA1UECgwJVEFJV0FOLUNBMRAwDgYDVQQLDAdSb290IENBMSowKAYDVQQDDCFU +V0NBIFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDgwODI4MDcyNDMz +WhcNMzAxMjMxMTU1OTU5WjBfMQswCQYDVQQGEwJUVzESMBAGA1UECgwJVEFJV0FO +LUNBMRAwDgYDVQQLDAdSb290IENBMSowKAYDVQQDDCFUV0NBIFJvb3QgQ2VydGlm +aWNhdGlvbiBBdXRob3JpdHkwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB +AQCwfnK4pAOU5qfeCTiRShFAh6d8WWQUe7UREN3+v9XAu1bihSX0NXIP+FPQQeFE +AcK0HMMxQhZHhTMidrIKbw/lJVBPhYa+v5guEGcevhEFhgWQxFnQfHgQsIBct+HH +K3XLfJ+utdGdIzdjp9xCoi2SBBtQwXu4PhvJVgSLL1KbralW6cH/ralYhzC2gfeX +RfwZVzsrb+RH9JlF/h3x+JejiB03HFyP4HYlmlD4oFT/RJB2I9IyxsOrBr/8+7/z +rX2SYgJbKdM1o5OaQ2RgXbL6Mv87BK9NQGr5x+PvI/1ry+UPizgN7gr8/g+YnzAx +3WxSZfmLgb4i4RxYA7qRG4kHAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNV +HRMBAf8EBTADAQH/MB0GA1UdDgQWBBRqOFsmjd6LWvJPelSDGRjjCDWmujANBgkq +hkiG9w0BAQUFAAOCAQEAPNV3PdrfibqHDAhUaiBQkr6wQT25JmSDCi/oQMCXKCeC +MErJk/9q56YAf4lCmtYR5VPOL8zy2gXE/uJQxDqGfczafhAJO5I1KlOy/usrBdls +XebQ79NqZp4VKIV66IIArB6nCWlWQtNoURi+VJq/REG6Sb4gumlc7rh3zc5sH62D +lhh9DrUUOYTxKOkto557HnpyWoOzeW/vtPzQCqVYT0bf+215WfKEIlKuD8z7fDvn +aspHYcN6+NOSBB+4IIThNlQWx0DeO4pz3N/GCUzf7Nr/1FNCocnyYh0igzyXxfkZ +YiesZSLX0zzG5Y6yU8xJzrww/nsOM5D77dIUkR8Hrw== +-----END CERTIFICATE----- + +# Issuer: O=SECOM Trust Systems CO.,LTD. OU=Security Communication RootCA2 +# Subject: O=SECOM Trust Systems CO.,LTD. OU=Security Communication RootCA2 +# Label: "Security Communication RootCA2" +# Serial: 0 +# MD5 Fingerprint: 6c:39:7d:a4:0e:55:59:b2:3f:d6:41:b1:12:50:de:43 +# SHA1 Fingerprint: 5f:3b:8c:f2:f8:10:b3:7d:78:b4:ce:ec:19:19:c3:73:34:b9:c7:74 +# SHA256 Fingerprint: 51:3b:2c:ec:b8:10:d4:cd:e5:dd:85:39:1a:df:c6:c2:dd:60:d8:7b:b7:36:d2:b5:21:48:4a:a4:7a:0e:be:f6 +-----BEGIN CERTIFICATE----- +MIIDdzCCAl+gAwIBAgIBADANBgkqhkiG9w0BAQsFADBdMQswCQYDVQQGEwJKUDEl +MCMGA1UEChMcU0VDT00gVHJ1c3QgU3lzdGVtcyBDTy4sTFRELjEnMCUGA1UECxMe +U2VjdXJpdHkgQ29tbXVuaWNhdGlvbiBSb290Q0EyMB4XDTA5MDUyOTA1MDAzOVoX +DTI5MDUyOTA1MDAzOVowXTELMAkGA1UEBhMCSlAxJTAjBgNVBAoTHFNFQ09NIFRy +dXN0IFN5c3RlbXMgQ08uLExURC4xJzAlBgNVBAsTHlNlY3VyaXR5IENvbW11bmlj +YXRpb24gUm9vdENBMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANAV +OVKxUrO6xVmCxF1SrjpDZYBLx/KWvNs2l9amZIyoXvDjChz335c9S672XewhtUGr +zbl+dp+++T42NKA7wfYxEUV0kz1XgMX5iZnK5atq1LXaQZAQwdbWQonCv/Q4EpVM +VAX3NuRFg3sUZdbcDE3R3n4MqzvEFb46VqZab3ZpUql6ucjrappdUtAtCms1FgkQ +hNBqyjoGADdH5H5XTz+L62e4iKrFvlNVspHEfbmwhRkGeC7bYRr6hfVKkaHnFtWO +ojnflLhwHyg/i/xAXmODPIMqGplrz95Zajv8bxbXH/1KEOtOghY6rCcMU/Gt1SSw +awNQwS08Ft1ENCcadfsCAwEAAaNCMEAwHQYDVR0OBBYEFAqFqXdlBZh8QIH4D5cs +OPEK7DzPMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MA0GCSqGSIb3 +DQEBCwUAA4IBAQBMOqNErLlFsceTfsgLCkLfZOoc7llsCLqJX2rKSpWeeo8HxdpF +coJxDjrSzG+ntKEju/Ykn8sX/oymzsLS28yN/HH8AynBbF0zX2S2ZTuJbxh2ePXc +okgfGT+Ok+vx+hfuzU7jBBJV1uXk3fs+BXziHV7Gp7yXT2g69ekuCkO2r1dcYmh8 +t/2jioSgrGK+KwmHNPBqAbubKVY8/gA3zyNs8U6qtnRGEmyR7jTV7JqR50S+kDFy +1UkC9gLl9B/rfNmWVan/7Ir5mUf/NVoCqgTLiluHcSmRvaS0eg29mvVXIwAHIRc/ +SjnRBUkLp7Y3gaVdjKozXoEofKd9J+sAro03 +-----END CERTIFICATE----- + +# Issuer: CN=Hellenic Academic and Research Institutions RootCA 2011 O=Hellenic Academic and Research Institutions Cert. Authority +# Subject: CN=Hellenic Academic and Research Institutions RootCA 2011 O=Hellenic Academic and Research Institutions Cert. Authority +# Label: "Hellenic Academic and Research Institutions RootCA 2011" +# Serial: 0 +# MD5 Fingerprint: 73:9f:4c:4b:73:5b:79:e9:fa:ba:1c:ef:6e:cb:d5:c9 +# SHA1 Fingerprint: fe:45:65:9b:79:03:5b:98:a1:61:b5:51:2e:ac:da:58:09:48:22:4d +# SHA256 Fingerprint: bc:10:4f:15:a4:8b:e7:09:dc:a5:42:a7:e1:d4:b9:df:6f:05:45:27:e8:02:ea:a9:2d:59:54:44:25:8a:fe:71 +-----BEGIN CERTIFICATE----- +MIIEMTCCAxmgAwIBAgIBADANBgkqhkiG9w0BAQUFADCBlTELMAkGA1UEBhMCR1Ix +RDBCBgNVBAoTO0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1 +dGlvbnMgQ2VydC4gQXV0aG9yaXR5MUAwPgYDVQQDEzdIZWxsZW5pYyBBY2FkZW1p +YyBhbmQgUmVzZWFyY2ggSW5zdGl0dXRpb25zIFJvb3RDQSAyMDExMB4XDTExMTIw +NjEzNDk1MloXDTMxMTIwMTEzNDk1MlowgZUxCzAJBgNVBAYTAkdSMUQwQgYDVQQK +EztIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0dXRpb25zIENl +cnQuIEF1dGhvcml0eTFAMD4GA1UEAxM3SGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJl +c2VhcmNoIEluc3RpdHV0aW9ucyBSb290Q0EgMjAxMTCCASIwDQYJKoZIhvcNAQEB +BQADggEPADCCAQoCggEBAKlTAOMupvaO+mDYLZU++CwqVE7NuYRhlFhPjz2L5EPz +dYmNUeTDN9KKiE15HrcS3UN4SoqS5tdI1Q+kOilENbgH9mgdVc04UfCMJDGFr4PJ +fel3r+0ae50X+bOdOFAPplp5kYCvN66m0zH7tSYJnTxa71HFK9+WXesyHgLacEns +bgzImjeN9/E2YEsmLIKe0HjzDQ9jpFEw4fkrJxIH2Oq9GGKYsFk3fb7u8yBRQlqD +75O6aRXxYp2fmTmCobd0LovUxQt7L/DICto9eQqakxylKHJzkUOap9FNhYS5qXSP +FEDH3N6sQWRstBmbAmNtJGSPRLIl6s5ddAxjMlyNh+UCAwEAAaOBiTCBhjAPBgNV +HRMBAf8EBTADAQH/MAsGA1UdDwQEAwIBBjAdBgNVHQ4EFgQUppFC/RNhSiOeCKQp +5dgTBCPuQSUwRwYDVR0eBEAwPqA8MAWCAy5ncjAFggMuZXUwBoIELmVkdTAGggQu +b3JnMAWBAy5ncjAFgQMuZXUwBoEELmVkdTAGgQQub3JnMA0GCSqGSIb3DQEBBQUA +A4IBAQAf73lB4XtuP7KMhjdCSk4cNx6NZrokgclPEg8hwAOXhiVtXdMiKahsog2p +6z0GW5k6x8zDmjR/qw7IThzh+uTczQ2+vyT+bOdrwg3IBp5OjWEopmr95fZi6hg8 +TqBTnbI6nOulnJEWtk2C4AwFSKls9cz4y51JtPACpf1wA+2KIaWuE4ZJwzNzvoc7 +dIsXRSZMFpGD/md9zU1jZ/rzAxKWeAaNsWftjj++n08C9bMJL/NMh98qy5V8Acys +Nnq/onN694/BtZqhFLKPM58N7yLcZnuEvUUXBj08yrl3NI/K6s8/MT7jiOOASSXI +l7WdmplNsDz4SgCbZN2fOUvRJ9e4 +-----END CERTIFICATE----- + +# Issuer: CN=Actalis Authentication Root CA O=Actalis S.p.A./03358520967 +# Subject: CN=Actalis Authentication Root CA O=Actalis S.p.A./03358520967 +# Label: "Actalis Authentication Root CA" +# Serial: 6271844772424770508 +# MD5 Fingerprint: 69:c1:0d:4f:07:a3:1b:c3:fe:56:3d:04:bc:11:f6:a6 +# SHA1 Fingerprint: f3:73:b3:87:06:5a:28:84:8a:f2:f3:4a:ce:19:2b:dd:c7:8e:9c:ac +# SHA256 Fingerprint: 55:92:60:84:ec:96:3a:64:b9:6e:2a:be:01:ce:0b:a8:6a:64:fb:fe:bc:c7:aa:b5:af:c1:55:b3:7f:d7:60:66 +-----BEGIN CERTIFICATE----- +MIIFuzCCA6OgAwIBAgIIVwoRl0LE48wwDQYJKoZIhvcNAQELBQAwazELMAkGA1UE +BhMCSVQxDjAMBgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlzIFMucC5BLi8w +MzM1ODUyMDk2NzEnMCUGA1UEAwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290 +IENBMB4XDTExMDkyMjExMjIwMloXDTMwMDkyMjExMjIwMlowazELMAkGA1UEBhMC +SVQxDjAMBgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlzIFMucC5BLi8wMzM1 +ODUyMDk2NzEnMCUGA1UEAwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290IENB +MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAp8bEpSmkLO/lGMWwUKNv +UTufClrJwkg4CsIcoBh/kbWHuUA/3R1oHwiD1S0eiKD4j1aPbZkCkpAW1V8IbInX +4ay8IMKx4INRimlNAJZaby/ARH6jDuSRzVju3PvHHkVH3Se5CAGfpiEd9UEtL0z9 +KK3giq0itFZljoZUj5NDKd45RnijMCO6zfB9E1fAXdKDa0hMxKufgFpbOr3JpyI/ +gCczWw63igxdBzcIy2zSekciRDXFzMwujt0q7bd9Zg1fYVEiVRvjRuPjPdA1Yprb +rxTIW6HMiRvhMCb8oJsfgadHHwTrozmSBp+Z07/T6k9QnBn+locePGX2oxgkg4YQ +51Q+qDp2JE+BIcXjDwL4k5RHILv+1A7TaLndxHqEguNTVHnd25zS8gebLra8Pu2F +be8lEfKXGkJh90qX6IuxEAf6ZYGyojnP9zz/GPvG8VqLWeICrHuS0E4UT1lF9gxe +KF+w6D9Fz8+vm2/7hNN3WpVvrJSEnu68wEqPSpP4RCHiMUVhUE4Q2OM1fEwZtN4F +v6MGn8i1zeQf1xcGDXqVdFUNaBr8EBtiZJ1t4JWgw5QHVw0U5r0F+7if5t+L4sbn +fpb2U8WANFAoWPASUHEXMLrmeGO89LKtmyuy/uE5jF66CyCU3nuDuP/jVo23Eek7 +jPKxwV2dpAtMK9myGPW1n0sCAwEAAaNjMGEwHQYDVR0OBBYEFFLYiDrIn3hm7Ynz +ezhwlMkCAjbQMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUUtiIOsifeGbt +ifN7OHCUyQICNtAwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEBCwUAA4ICAQAL +e3KHwGCmSUyIWOYdiPcUZEim2FgKDk8TNd81HdTtBjHIgT5q1d07GjLukD0R0i70 +jsNjLiNmsGe+b7bAEzlgqqI0JZN1Ut6nna0Oh4lScWoWPBkdg/iaKWW+9D+a2fDz +WochcYBNy+A4mz+7+uAwTc+G02UQGRjRlwKxK3JCaKygvU5a2hi/a5iB0P2avl4V +SM0RFbnAKVy06Ij3Pjaut2L9HmLecHgQHEhb2rykOLpn7VU+Xlff1ANATIGk0k9j +pwlCCRT8AKnCgHNPLsBA2RF7SOp6AsDT6ygBJlh0wcBzIm2Tlf05fbsq4/aC4yyX +X04fkZT6/iyj2HYauE2yOE+b+h1IYHkm4vP9qdCa6HCPSXrW5b0KDtst842/6+Ok +fcvHlXHo2qN8xcL4dJIEG4aspCJTQLas/kx2z/uUMsA1n3Y/buWQbqCmJqK4LL7R +K4X9p2jIugErsWx0Hbhzlefut8cl8ABMALJ+tguLHPPAUJ4lueAI3jZm/zel0btU +ZCzJJ7VLkn5l/9Mt4blOvH+kQSGQQXemOR/qnuOf0GZvBeyqdn6/axag67XH/JJU +LysRJyU3eExRarDzzFhdFPFqSBX/wge2sY0PjlxQRrM9vwGYT7JZVEc+NHt4bVaT +LnPqZih4zR0Uv6CPLy64Lo7yFIrM6bV8+2ydDKXhlg== +-----END CERTIFICATE----- + +# Issuer: O=Trustis Limited OU=Trustis FPS Root CA +# Subject: O=Trustis Limited OU=Trustis FPS Root CA +# Label: "Trustis FPS Root CA" +# Serial: 36053640375399034304724988975563710553 +# MD5 Fingerprint: 30:c9:e7:1e:6b:e6:14:eb:65:b2:16:69:20:31:67:4d +# SHA1 Fingerprint: 3b:c0:38:0b:33:c3:f6:a6:0c:86:15:22:93:d9:df:f5:4b:81:c0:04 +# SHA256 Fingerprint: c1:b4:82:99:ab:a5:20:8f:e9:63:0a:ce:55:ca:68:a0:3e:da:5a:51:9c:88:02:a0:d3:a6:73:be:8f:8e:55:7d +-----BEGIN CERTIFICATE----- +MIIDZzCCAk+gAwIBAgIQGx+ttiD5JNM2a/fH8YygWTANBgkqhkiG9w0BAQUFADBF +MQswCQYDVQQGEwJHQjEYMBYGA1UEChMPVHJ1c3RpcyBMaW1pdGVkMRwwGgYDVQQL +ExNUcnVzdGlzIEZQUyBSb290IENBMB4XDTAzMTIyMzEyMTQwNloXDTI0MDEyMTEx +MzY1NFowRTELMAkGA1UEBhMCR0IxGDAWBgNVBAoTD1RydXN0aXMgTGltaXRlZDEc +MBoGA1UECxMTVHJ1c3RpcyBGUFMgUm9vdCBDQTCCASIwDQYJKoZIhvcNAQEBBQAD +ggEPADCCAQoCggEBAMVQe547NdDfxIzNjpvto8A2mfRC6qc+gIMPpqdZh8mQRUN+ +AOqGeSoDvT03mYlmt+WKVoaTnGhLaASMk5MCPjDSNzoiYYkchU59j9WvezX2fihH +iTHcDnlkH5nSW7r+f2C/revnPDgpai/lkQtV/+xvWNUtyd5MZnGPDNcE2gfmHhjj +vSkCqPoc4Vu5g6hBSLwacY3nYuUtsuvffM/bq1rKMfFMIvMFE/eC+XN5DL7XSxzA +0RU8k0Fk0ea+IxciAIleH2ulrG6nS4zto3Lmr2NNL4XSFDWaLk6M6jKYKIahkQlB +OrTh4/L68MkKokHdqeMDx4gVOxzUGpTXn2RZEm0CAwEAAaNTMFEwDwYDVR0TAQH/ +BAUwAwEB/zAfBgNVHSMEGDAWgBS6+nEleYtXQSUhhgtx67JkDoshZzAdBgNVHQ4E +FgQUuvpxJXmLV0ElIYYLceuyZA6LIWcwDQYJKoZIhvcNAQEFBQADggEBAH5Y//01 +GX2cGE+esCu8jowU/yyg2kdbw++BLa8F6nRIW/M+TgfHbcWzk88iNVy2P3UnXwmW +zaD+vkAMXBJV+JOCyinpXj9WV4s4NvdFGkwozZ5BuO1WTISkQMi4sKUraXAEasP4 +1BIy+Q7DsdwyhEQsb8tGD+pmQQ9P8Vilpg0ND2HepZ5dfWWhPBfnqFVO76DH7cZE +f1T1o+CP8HxVIo8ptoGj4W1OLBuAZ+ytIJ8MYmHVl/9D7S3B2l0pKoU/rGXuhg8F +jZBf3+6f9L/uHfuY5H+QK4R4EA5sSVPvFVtlRkpdr7r7OnIdzfYliB6XzCGcKQEN +ZetX2fNXlrtIzYE= +-----END CERTIFICATE----- + +# Issuer: CN=Buypass Class 2 Root CA O=Buypass AS-983163327 +# Subject: CN=Buypass Class 2 Root CA O=Buypass AS-983163327 +# Label: "Buypass Class 2 Root CA" +# Serial: 2 +# MD5 Fingerprint: 46:a7:d2:fe:45:fb:64:5a:a8:59:90:9b:78:44:9b:29 +# SHA1 Fingerprint: 49:0a:75:74:de:87:0a:47:fe:58:ee:f6:c7:6b:eb:c6:0b:12:40:99 +# SHA256 Fingerprint: 9a:11:40:25:19:7c:5b:b9:5d:94:e6:3d:55:cd:43:79:08:47:b6:46:b2:3c:df:11:ad:a4:a0:0e:ff:15:fb:48 +-----BEGIN CERTIFICATE----- +MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEd +MBsGA1UECgwUQnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3Mg +Q2xhc3MgMiBSb290IENBMB4XDTEwMTAyNjA4MzgwM1oXDTQwMTAyNjA4MzgwM1ow +TjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1eXBhc3MgQVMtOTgzMTYzMzI3MSAw +HgYDVQQDDBdCdXlwYXNzIENsYXNzIDIgUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEB +BQADggIPADCCAgoCggIBANfHXvfBB9R3+0Mh9PT1aeTuMgHbo4Yf5FkNuud1g1Lr +6hxhFUi7HQfKjK6w3Jad6sNgkoaCKHOcVgb/S2TwDCo3SbXlzwx87vFKu3MwZfPV +L4O2fuPn9Z6rYPnT8Z2SdIrkHJasW4DptfQxh6NR/Md+oW+OU3fUl8FVM5I+GC91 +1K2GScuVr1QGbNgGE41b/+EmGVnAJLqBcXmQRFBoJJRfuLMR8SlBYaNByyM21cHx +MlAQTn/0hpPshNOOvEu/XAFOBz3cFIqUCqTqc/sLUegTBxj6DvEr0VQVfTzh97QZ +QmdiXnfgolXsttlpF9U6r0TtSsWe5HonfOV116rLJeffawrbD02TTqigzXsu8lkB +arcNuAeBfos4GzjmCleZPe4h6KP1DBbdi+w0jpwqHAAVF41og9JwnxgIzRFo1clr +Us3ERo/ctfPYV3Me6ZQ5BL/T3jjetFPsaRyifsSP5BtwrfKi+fv3FmRmaZ9JUaLi +FRhnBkp/1Wy1TbMz4GHrXb7pmA8y1x1LPC5aAVKRCfLf6o3YBkBjqhHk/sM3nhRS +P/TizPJhk9H9Z2vXUq6/aKtAQ6BXNVN48FP4YUIHZMbXb5tMOA1jrGKvNouicwoN +9SG9dKpN6nIDSdvHXx1iY8f93ZHsM+71bbRuMGjeyNYmsHVee7QHIJihdjK4TWxP +AgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFMmAd+BikoL1Rpzz +uvdMw964o605MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAU18h +9bqwOlI5LJKwbADJ784g7wbylp7ppHR/ehb8t/W2+xUbP6umwHJdELFx7rxP462s +A20ucS6vxOOto70MEae0/0qyexAQH6dXQbLArvQsWdZHEIjzIVEpMMpghq9Gqx3t +OluwlN5E40EIosHsHdb9T7bWR9AUC8rmyrV7d35BH16Dx7aMOZawP5aBQW9gkOLo ++fsicdl9sz1Gv7SEr5AcD48Saq/v7h56rgJKihcrdv6sVIkkLE8/trKnToyokZf7 +KcZ7XC25y2a2t6hbElGFtQl+Ynhw/qlqYLYdDnkM/crqJIByw5c/8nerQyIKx+u2 +DISCLIBrQYoIwOula9+ZEsuK1V6ADJHgJgg2SMX6OBE1/yWDLfJ6v9r9jv6ly0Us +H8SIU653DtmadsWOLB2jutXsMq7Aqqz30XpN69QH4kj3Io6wpJ9qzo6ysmD0oyLQ +I+uUWnpp3Q+/QFesa1lQ2aOZ4W7+jQF5JyMV3pKdewlNWudLSDBaGOYKbeaP4NK7 +5t98biGCwWg5TbSYWGZizEqQXsP6JwSxeRV0mcy+rSDeJmAc61ZRpqPq5KM/p/9h +3PFaTWwyI0PurKju7koSCTxdccK+efrCh2gdC/1cacwG0Jp9VJkqyTkaGa9LKkPz +Y11aWOIv4x3kqdbQCtCev9eBCfHJxyYNrJgWVqA= +-----END CERTIFICATE----- + +# Issuer: CN=Buypass Class 3 Root CA O=Buypass AS-983163327 +# Subject: CN=Buypass Class 3 Root CA O=Buypass AS-983163327 +# Label: "Buypass Class 3 Root CA" +# Serial: 2 +# MD5 Fingerprint: 3d:3b:18:9e:2c:64:5a:e8:d5:88:ce:0e:f9:37:c2:ec +# SHA1 Fingerprint: da:fa:f7:fa:66:84:ec:06:8f:14:50:bd:c7:c2:81:a5:bc:a9:64:57 +# SHA256 Fingerprint: ed:f7:eb:bc:a2:7a:2a:38:4d:38:7b:7d:40:10:c6:66:e2:ed:b4:84:3e:4c:29:b4:ae:1d:5b:93:32:e6:b2:4d +-----BEGIN CERTIFICATE----- +MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEd +MBsGA1UECgwUQnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3Mg +Q2xhc3MgMyBSb290IENBMB4XDTEwMTAyNjA4Mjg1OFoXDTQwMTAyNjA4Mjg1OFow +TjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1eXBhc3MgQVMtOTgzMTYzMzI3MSAw +HgYDVQQDDBdCdXlwYXNzIENsYXNzIDMgUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEB +BQADggIPADCCAgoCggIBAKXaCpUWUOOV8l6ddjEGMnqb8RB2uACatVI2zSRHsJ8Y +ZLya9vrVediQYkwiL944PdbgqOkcLNt4EemOaFEVcsfzM4fkoF0LXOBXByow9c3E +N3coTRiR5r/VUv1xLXA+58bEiuPwKAv0dpihi4dVsjoT/Lc+JzeOIuOoTyrvYLs9 +tznDDgFHmV0ST9tD+leh7fmdvhFHJlsTmKtdFoqwNxxXnUX/iJY2v7vKB3tvh2PX +0DJq1l1sDPGzbjniazEuOQAnFN44wOwZZoYS6J1yFhNkUsepNxz9gjDthBgd9K5c +/3ATAOux9TN6S9ZV+AWNS2mw9bMoNlwUxFFzTWsL8TQH2xc519woe2v1n/MuwU8X +KhDzzMro6/1rqy6any2CbgTUUgGTLT2G/H783+9CHaZr77kgxve9oKeV/afmiSTY +zIw0bOIjL9kSGiG5VZFvC5F5GQytQIgLcOJ60g7YaEi7ghM5EFjp2CoHxhLbWNvS +O1UQRwUVZ2J+GGOmRj8JDlQyXr8NYnon74Do29lLBlo3WiXQCBJ31G8JUJc9yB3D +34xFMFbG02SrZvPAXpacw8Tvw3xrizp5f7NJzz3iiZ+gMEuFuZyUJHmPfWupRWgP +K9Dx2hzLabjKSWJtyNBjYt1gD1iqj6G8BaVmos8bdrKEZLFMOVLAMLrwjEsCsLa3 +AgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFEe4zf/lb+74suwv +Tg75JbCOPGvDMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAACAj +QTUEkMJAYmDv4jVM1z+s4jSQuKFvdvoWFqRINyzpkMLyPPgKn9iB5btb2iUspKdV +cSQy9sgL8rxq+JOssgfCX5/bzMiKqr5qb+FJEMwx14C7u8jYog5kV+qi9cKpMRXS +IGrs/CIBKM+GuIAeqcwRpTzyFrNHnfzSgCHEy9BHcEGhyoMZCCxt8l13nIoUE9Q2 +HJLw5QY33KbmkJs4j1xrG0aGQ0JfPgEHU1RdZX33inOhmlRaHylDFCfChQ+1iHsa +O5S3HWCntZznKWlXWpuTekMwGwPXYshApqr8ZORK15FTAaggiG6cX0S5y2CBNOxv +033aSF/rtJC8LakcC6wc1aJoIIAE1vyxjy+7SjENSoYc6+I2KSb12tjE8nVhz36u +dmNKekBlk4f4HoCMhuWG1o8O/FMsYOgWYRqiPkN7zTlgVGr18okmAWiDSKIz6MkE +kbIRNBE+6tBDGR8Dk5AM/1E9V/RBbuHLoL7ryWPNbczk+DaqaJ3tvV2XcEQNtg41 +3OEMXbugUZTLfhbrES+jkkXITHHZvMmZUldGL1DPvTVp9D0VzgalLA8+9oG6lLvD +u79leNKGef9JOxqDDPDeeOzI8k1MGt6CKfjBWtrt7uYnXuhF0J0cUahoq0Tj0Itq +4/g7u9xN12TyUb7mqqta6THuBrxzvxNiCp/HuZc= +-----END CERTIFICATE----- + +# Issuer: CN=T-TeleSec GlobalRoot Class 3 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center +# Subject: CN=T-TeleSec GlobalRoot Class 3 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center +# Label: "T-TeleSec GlobalRoot Class 3" +# Serial: 1 +# MD5 Fingerprint: ca:fb:40:a8:4e:39:92:8a:1d:fe:8e:2f:c4:27:ea:ef +# SHA1 Fingerprint: 55:a6:72:3e:cb:f2:ec:cd:c3:23:74:70:19:9d:2a:be:11:e3:81:d1 +# SHA256 Fingerprint: fd:73:da:d3:1c:64:4f:f1:b4:3b:ef:0c:cd:da:96:71:0b:9c:d9:87:5e:ca:7e:31:70:7a:f3:e9:6d:52:2b:bd +-----BEGIN CERTIFICATE----- +MIIDwzCCAqugAwIBAgIBATANBgkqhkiG9w0BAQsFADCBgjELMAkGA1UEBhMCREUx +KzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAd +BgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNl +YyBHbG9iYWxSb290IENsYXNzIDMwHhcNMDgxMDAxMTAyOTU2WhcNMzMxMDAxMjM1 +OTU5WjCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnBy +aXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50 +ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDMwggEiMA0G +CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC9dZPwYiJvJK7genasfb3ZJNW4t/zN +8ELg63iIVl6bmlQdTQyK9tPPcPRStdiTBONGhnFBSivwKixVA9ZIw+A5OO3yXDw/ +RLyTPWGrTs0NvvAgJ1gORH8EGoel15YUNpDQSXuhdfsaa3Ox+M6pCSzyU9XDFES4 +hqX2iys52qMzVNn6chr3IhUciJFrf2blw2qAsCTz34ZFiP0Zf3WHHx+xGwpzJFu5 +ZeAsVMhg02YXP+HMVDNzkQI6pn97djmiH5a2OK61yJN0HZ65tOVgnS9W0eDrXltM +EnAMbEQgqxHY9Bn20pxSN+f6tsIxO0rUFJmtxxr1XV/6B7h8DR/Wgx6zAgMBAAGj +QjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBS1 +A/d2O2GCahKqGFPrAyGUv/7OyjANBgkqhkiG9w0BAQsFAAOCAQEAVj3vlNW92nOy +WL6ukK2YJ5f+AbGwUgC4TeQbIXQbfsDuXmkqJa9c1h3a0nnJ85cp4IaH3gRZD/FZ +1GSFS5mvJQQeyUapl96Cshtwn5z2r3Ex3XsFpSzTucpH9sry9uetuUg/vBa3wW30 +6gmv7PO15wWeph6KU1HWk4HMdJP2udqmJQV0eVp+QD6CSyYRMG7hP0HHRwA11fXT +91Q+gT3aSWqas+8QPebrb9HIIkfLzM8BMZLZGOMivgkeGj5asuRrDFR6fUNOuIml +e9eiPZaGzPImNC1qkp2aGtAw4l1OBLBfiyB+d8E9lYLRRpo7PHi4b6HQDWSieB4p +TpPDpFQUWw== +-----END CERTIFICATE----- + +# Issuer: CN=EE Certification Centre Root CA O=AS Sertifitseerimiskeskus +# Subject: CN=EE Certification Centre Root CA O=AS Sertifitseerimiskeskus +# Label: "EE Certification Centre Root CA" +# Serial: 112324828676200291871926431888494945866 +# MD5 Fingerprint: 43:5e:88:d4:7d:1a:4a:7e:fd:84:2e:52:eb:01:d4:6f +# SHA1 Fingerprint: c9:a8:b9:e7:55:80:5e:58:e3:53:77:a7:25:eb:af:c3:7b:27:cc:d7 +# SHA256 Fingerprint: 3e:84:ba:43:42:90:85:16:e7:75:73:c0:99:2f:09:79:ca:08:4e:46:85:68:1f:f1:95:cc:ba:8a:22:9b:8a:76 +-----BEGIN CERTIFICATE----- +MIIEAzCCAuugAwIBAgIQVID5oHPtPwBMyonY43HmSjANBgkqhkiG9w0BAQUFADB1 +MQswCQYDVQQGEwJFRTEiMCAGA1UECgwZQVMgU2VydGlmaXRzZWVyaW1pc2tlc2t1 +czEoMCYGA1UEAwwfRUUgQ2VydGlmaWNhdGlvbiBDZW50cmUgUm9vdCBDQTEYMBYG +CSqGSIb3DQEJARYJcGtpQHNrLmVlMCIYDzIwMTAxMDMwMTAxMDMwWhgPMjAzMDEy +MTcyMzU5NTlaMHUxCzAJBgNVBAYTAkVFMSIwIAYDVQQKDBlBUyBTZXJ0aWZpdHNl +ZXJpbWlza2Vza3VzMSgwJgYDVQQDDB9FRSBDZXJ0aWZpY2F0aW9uIENlbnRyZSBS +b290IENBMRgwFgYJKoZIhvcNAQkBFglwa2lAc2suZWUwggEiMA0GCSqGSIb3DQEB +AQUAA4IBDwAwggEKAoIBAQDIIMDs4MVLqwd4lfNE7vsLDP90jmG7sWLqI9iroWUy +euuOF0+W2Ap7kaJjbMeMTC55v6kF/GlclY1i+blw7cNRfdCT5mzrMEvhvH2/UpvO +bntl8jixwKIy72KyaOBhU8E2lf/slLo2rpwcpzIP5Xy0xm90/XsY6KxX7QYgSzIw +WFv9zajmofxwvI6Sc9uXp3whrj3B9UiHbCe9nyV0gVWw93X2PaRka9ZP585ArQ/d +MtO8ihJTmMmJ+xAdTX7Nfh9WDSFwhfYggx/2uh8Ej+p3iDXE/+pOoYtNP2MbRMNE +1CV2yreN1x5KZmTNXMWcg+HCCIia7E6j8T4cLNlsHaFLAgMBAAGjgYowgYcwDwYD +VR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFBLyWj7qVhy/ +zQas8fElyalL1BSZMEUGA1UdJQQ+MDwGCCsGAQUFBwMCBggrBgEFBQcDAQYIKwYB +BQUHAwMGCCsGAQUFBwMEBggrBgEFBQcDCAYIKwYBBQUHAwkwDQYJKoZIhvcNAQEF +BQADggEBAHv25MANqhlHt01Xo/6tu7Fq1Q+e2+RjxY6hUFaTlrg4wCQiZrxTFGGV +v9DHKpY5P30osxBAIWrEr7BSdxjhlthWXePdNl4dp1BUoMUq5KqMlIpPnTX/dqQG +E5Gion0ARD9V04I8GtVbvFZMIi5GQ4okQC3zErg7cBqklrkar4dBGmoYDQZPxz5u +uSlNDUmJEYcyW+ZLBMjkXOZ0c5RdFpgTlf7727FE5TpwrDdr5rMzcijJs1eg9gIW +iAYLtqZLICjU3j2LrTcFU3T+bsy8QxdxXvnFzBqpYe73dgzzcvRyrc9yAjYHR8/v +GVCJYMzpJJUPwssd8m92kMfMdcGWxZ0= +-----END CERTIFICATE----- + +# Issuer: CN=D-TRUST Root Class 3 CA 2 2009 O=D-Trust GmbH +# Subject: CN=D-TRUST Root Class 3 CA 2 2009 O=D-Trust GmbH +# Label: "D-TRUST Root Class 3 CA 2 2009" +# Serial: 623603 +# MD5 Fingerprint: cd:e0:25:69:8d:47:ac:9c:89:35:90:f7:fd:51:3d:2f +# SHA1 Fingerprint: 58:e8:ab:b0:36:15:33:fb:80:f7:9b:1b:6d:29:d3:ff:8d:5f:00:f0 +# SHA256 Fingerprint: 49:e7:a4:42:ac:f0:ea:62:87:05:00:54:b5:25:64:b6:50:e4:f4:9e:42:e3:48:d6:aa:38:e0:39:e9:57:b1:c1 +-----BEGIN CERTIFICATE----- +MIIEMzCCAxugAwIBAgIDCYPzMA0GCSqGSIb3DQEBCwUAME0xCzAJBgNVBAYTAkRF +MRUwEwYDVQQKDAxELVRydXN0IEdtYkgxJzAlBgNVBAMMHkQtVFJVU1QgUm9vdCBD +bGFzcyAzIENBIDIgMjAwOTAeFw0wOTExMDUwODM1NThaFw0yOTExMDUwODM1NTha +ME0xCzAJBgNVBAYTAkRFMRUwEwYDVQQKDAxELVRydXN0IEdtYkgxJzAlBgNVBAMM +HkQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgMjAwOTCCASIwDQYJKoZIhvcNAQEB +BQADggEPADCCAQoCggEBANOySs96R+91myP6Oi/WUEWJNTrGa9v+2wBoqOADER03 +UAifTUpolDWzU9GUY6cgVq/eUXjsKj3zSEhQPgrfRlWLJ23DEE0NkVJD2IfgXU42 +tSHKXzlABF9bfsyjxiupQB7ZNoTWSPOSHjRGICTBpFGOShrvUD9pXRl/RcPHAY9R +ySPocq60vFYJfxLLHLGvKZAKyVXMD9O0Gu1HNVpK7ZxzBCHQqr0ME7UAyiZsxGsM +lFqVlNpQmvH/pStmMaTJOKDfHR+4CS7zp+hnUquVH+BGPtikw8paxTGA6Eian5Rp +/hnd2HN8gcqW3o7tszIFZYQ05ub9VxC1X3a/L7AQDcUCAwEAAaOCARowggEWMA8G +A1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFP3aFMSfMN4hvR5COfyrYyNJ4PGEMA4G +A1UdDwEB/wQEAwIBBjCB0wYDVR0fBIHLMIHIMIGAoH6gfIZ6bGRhcDovL2RpcmVj +dG9yeS5kLXRydXN0Lm5ldC9DTj1ELVRSVVNUJTIwUm9vdCUyMENsYXNzJTIwMyUy +MENBJTIwMiUyMDIwMDksTz1ELVRydXN0JTIwR21iSCxDPURFP2NlcnRpZmljYXRl +cmV2b2NhdGlvbmxpc3QwQ6BBoD+GPWh0dHA6Ly93d3cuZC10cnVzdC5uZXQvY3Js +L2QtdHJ1c3Rfcm9vdF9jbGFzc18zX2NhXzJfMjAwOS5jcmwwDQYJKoZIhvcNAQEL +BQADggEBAH+X2zDI36ScfSF6gHDOFBJpiBSVYEQBrLLpME+bUMJm2H6NMLVwMeni +acfzcNsgFYbQDfC+rAF1hM5+n02/t2A7nPPKHeJeaNijnZflQGDSNiH+0LS4F9p0 +o3/U37CYAqxva2ssJSRyoWXuJVrl5jLn8t+rSfrzkGkj2wTZ51xY/GXUl77M/C4K +zCUqNQT4YJEVdT1B/yMfGchs64JTBKbkTCJNjYy6zltz7GRUUG3RnFX7acM2w4y8 +PIWmawomDeCTmGCufsYkl4phX5GOZpIJhzbNi5stPvZR1FDUWSi9g/LMKHtThm3Y +Johw1+qRzT65ysCQblrGXnRl11z+o+I= +-----END CERTIFICATE----- + +# Issuer: CN=D-TRUST Root Class 3 CA 2 EV 2009 O=D-Trust GmbH +# Subject: CN=D-TRUST Root Class 3 CA 2 EV 2009 O=D-Trust GmbH +# Label: "D-TRUST Root Class 3 CA 2 EV 2009" +# Serial: 623604 +# MD5 Fingerprint: aa:c6:43:2c:5e:2d:cd:c4:34:c0:50:4f:11:02:4f:b6 +# SHA1 Fingerprint: 96:c9:1b:0b:95:b4:10:98:42:fa:d0:d8:22:79:fe:60:fa:b9:16:83 +# SHA256 Fingerprint: ee:c5:49:6b:98:8c:e9:86:25:b9:34:09:2e:ec:29:08:be:d0:b0:f3:16:c2:d4:73:0c:84:ea:f1:f3:d3:48:81 +-----BEGIN CERTIFICATE----- +MIIEQzCCAyugAwIBAgIDCYP0MA0GCSqGSIb3DQEBCwUAMFAxCzAJBgNVBAYTAkRF +MRUwEwYDVQQKDAxELVRydXN0IEdtYkgxKjAoBgNVBAMMIUQtVFJVU1QgUm9vdCBD +bGFzcyAzIENBIDIgRVYgMjAwOTAeFw0wOTExMDUwODUwNDZaFw0yOTExMDUwODUw +NDZaMFAxCzAJBgNVBAYTAkRFMRUwEwYDVQQKDAxELVRydXN0IEdtYkgxKjAoBgNV +BAMMIUQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgRVYgMjAwOTCCASIwDQYJKoZI +hvcNAQEBBQADggEPADCCAQoCggEBAJnxhDRwui+3MKCOvXwEz75ivJn9gpfSegpn +ljgJ9hBOlSJzmY3aFS3nBfwZcyK3jpgAvDw9rKFs+9Z5JUut8Mxk2og+KbgPCdM0 +3TP1YtHhzRnp7hhPTFiu4h7WDFsVWtg6uMQYZB7jM7K1iXdODL/ZlGsTl28So/6Z +qQTMFexgaDbtCHu39b+T7WYxg4zGcTSHThfqr4uRjRxWQa4iN1438h3Z0S0NL2lR +p75mpoo6Kr3HGrHhFPC+Oh25z1uxav60sUYgovseO3Dvk5h9jHOW8sXvhXCtKSb8 +HgQ+HKDYD8tSg2J87otTlZCpV6LqYQXY+U3EJ/pure3511H3a6UCAwEAAaOCASQw +ggEgMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFNOUikxiEyoZLsyvcop9Ntea +HNxnMA4GA1UdDwEB/wQEAwIBBjCB3QYDVR0fBIHVMIHSMIGHoIGEoIGBhn9sZGFw +Oi8vZGlyZWN0b3J5LmQtdHJ1c3QubmV0L0NOPUQtVFJVU1QlMjBSb290JTIwQ2xh +c3MlMjAzJTIwQ0ElMjAyJTIwRVYlMjAyMDA5LE89RC1UcnVzdCUyMEdtYkgsQz1E +RT9jZXJ0aWZpY2F0ZXJldm9jYXRpb25saXN0MEagRKBChkBodHRwOi8vd3d3LmQt +dHJ1c3QubmV0L2NybC9kLXRydXN0X3Jvb3RfY2xhc3NfM19jYV8yX2V2XzIwMDku +Y3JsMA0GCSqGSIb3DQEBCwUAA4IBAQA07XtaPKSUiO8aEXUHL7P+PPoeUSbrh/Yp +3uDx1MYkCenBz1UbtDDZzhr+BlGmFaQt77JLvyAoJUnRpjZ3NOhk31KxEcdzes05 +nsKtjHEh8lprr988TlWvsoRlFIm5d8sqMb7Po23Pb0iUMkZv53GMoKaEGTcH8gNF +CSuGdXzfX2lXANtu2KZyIktQ1HWYVt+3GP9DQ1CuekR78HlR10M9p9OB0/DJT7na +xpeG0ILD5EJt/rDiZE4OJudANCa1CInXCGNjOCd1HjPqbqjdn5lPdE2BiYBL3ZqX +KVwvvoFBuYz/6n1gBp7N1z3TLqMVvKjmJuVvw9y4AyHqnxbxLFS1 +-----END CERTIFICATE----- + +# Issuer: CN=CA Disig Root R2 O=Disig a.s. +# Subject: CN=CA Disig Root R2 O=Disig a.s. +# Label: "CA Disig Root R2" +# Serial: 10572350602393338211 +# MD5 Fingerprint: 26:01:fb:d8:27:a7:17:9a:45:54:38:1a:43:01:3b:03 +# SHA1 Fingerprint: b5:61:eb:ea:a4:de:e4:25:4b:69:1a:98:a5:57:47:c2:34:c7:d9:71 +# SHA256 Fingerprint: e2:3d:4a:03:6d:7b:70:e9:f5:95:b1:42:20:79:d2:b9:1e:df:bb:1f:b6:51:a0:63:3e:aa:8a:9d:c5:f8:07:03 +-----BEGIN CERTIFICATE----- +MIIFaTCCA1GgAwIBAgIJAJK4iNuwisFjMA0GCSqGSIb3DQEBCwUAMFIxCzAJBgNV +BAYTAlNLMRMwEQYDVQQHEwpCcmF0aXNsYXZhMRMwEQYDVQQKEwpEaXNpZyBhLnMu +MRkwFwYDVQQDExBDQSBEaXNpZyBSb290IFIyMB4XDTEyMDcxOTA5MTUzMFoXDTQy +MDcxOTA5MTUzMFowUjELMAkGA1UEBhMCU0sxEzARBgNVBAcTCkJyYXRpc2xhdmEx +EzARBgNVBAoTCkRpc2lnIGEucy4xGTAXBgNVBAMTEENBIERpc2lnIFJvb3QgUjIw +ggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCio8QACdaFXS1tFPbCw3Oe +NcJxVX6B+6tGUODBfEl45qt5WDza/3wcn9iXAng+a0EE6UG9vgMsRfYvZNSrXaNH +PWSb6WiaxswbP7q+sos0Ai6YVRn8jG+qX9pMzk0DIaPY0jSTVpbLTAwAFjxfGs3I +x2ymrdMxp7zo5eFm1tL7A7RBZckQrg4FY8aAamkw/dLukO8NJ9+flXP04SXabBbe +QTg06ov80egEFGEtQX6sx3dOy1FU+16SGBsEWmjGycT6txOgmLcRK7fWV8x8nhfR +yyX+hk4kLlYMeE2eARKmK6cBZW58Yh2EhN/qwGu1pSqVg8NTEQxzHQuyRpDRQjrO +QG6Vrf/GlK1ul4SOfW+eioANSW1z4nuSHsPzwfPrLgVv2RvPN3YEyLRa5Beny912 +H9AZdugsBbPWnDTYltxhh5EF5EQIM8HauQhl1K6yNg3ruji6DOWbnuuNZt2Zz9aJ +QfYEkoopKW1rOhzndX0CcQ7zwOe9yxndnWCywmZgtrEE7snmhrmaZkCo5xHtgUUD +i/ZnWejBBhG93c+AAk9lQHhcR1DIm+YfgXvkRKhbhZri3lrVx/k6RGZL5DJUfORs +nLMOPReisjQS1n6yqEm70XooQL6iFh/f5DcfEXP7kAplQ6INfPgGAVUzfbANuPT1 +rqVCV3w2EYx7XsQDnYx5nQIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1Ud +DwEB/wQEAwIBBjAdBgNVHQ4EFgQUtZn4r7CU9eMg1gqtzk5WpC5uQu0wDQYJKoZI +hvcNAQELBQADggIBACYGXnDnZTPIgm7ZnBc6G3pmsgH2eDtpXi/q/075KMOYKmFM +tCQSin1tERT3nLXK5ryeJ45MGcipvXrA1zYObYVybqjGom32+nNjf7xueQgcnYqf +GopTpti72TVVsRHFqQOzVju5hJMiXn7B9hJSi+osZ7z+Nkz1uM/Rs0mSO9MpDpkb +lvdhuDvEK7Z4bLQjb/D907JedR+Zlais9trhxTF7+9FGs9K8Z7RiVLoJ92Owk6Ka ++elSLotgEqv89WBW7xBci8QaQtyDW2QOy7W81k/BfDxujRNt+3vrMNDcTa/F1bal +TFtxyegxvug4BkihGuLq0t4SOVga/4AOgnXmt8kHbA7v/zjxmHHEt38OFdAlab0i +nSvtBfZGR6ztwPDUO+Ls7pZbkBNOHlY667DvlruWIxG68kOGdGSVyCh13x01utI3 +gzhTODY7z2zp+WsO0PsE6E9312UBeIYMej4hYvF/Y3EMyZ9E26gnonW+boE+18Dr +G5gPcFw0sorMwIUY6256s/daoQe/qUKS82Ail+QUoQebTnbAjn39pCXHR+3/H3Os +zMOl6W8KjptlwlCFtaOgUxLMVYdh84GuEEZhvUQhuMI9dM9+JDX6HAcOmz0iyu8x +L4ysEr3vQCj8KWefshNPZiTEUxnpHikV7+ZtsH8tZ/3zbBt1RqPlShfppNcL +-----END CERTIFICATE----- + +# Issuer: CN=ACCVRAIZ1 O=ACCV OU=PKIACCV +# Subject: CN=ACCVRAIZ1 O=ACCV OU=PKIACCV +# Label: "ACCVRAIZ1" +# Serial: 6828503384748696800 +# MD5 Fingerprint: d0:a0:5a:ee:05:b6:09:94:21:a1:7d:f1:b2:29:82:02 +# SHA1 Fingerprint: 93:05:7a:88:15:c6:4f:ce:88:2f:fa:91:16:52:28:78:bc:53:64:17 +# SHA256 Fingerprint: 9a:6e:c0:12:e1:a7:da:9d:be:34:19:4d:47:8a:d7:c0:db:18:22:fb:07:1d:f1:29:81:49:6e:d1:04:38:41:13 +-----BEGIN CERTIFICATE----- +MIIH0zCCBbugAwIBAgIIXsO3pkN/pOAwDQYJKoZIhvcNAQEFBQAwQjESMBAGA1UE +AwwJQUNDVlJBSVoxMRAwDgYDVQQLDAdQS0lBQ0NWMQ0wCwYDVQQKDARBQ0NWMQsw +CQYDVQQGEwJFUzAeFw0xMTA1MDUwOTM3MzdaFw0zMDEyMzEwOTM3MzdaMEIxEjAQ +BgNVBAMMCUFDQ1ZSQUlaMTEQMA4GA1UECwwHUEtJQUNDVjENMAsGA1UECgwEQUND +VjELMAkGA1UEBhMCRVMwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCb +qau/YUqXry+XZpp0X9DZlv3P4uRm7x8fRzPCRKPfmt4ftVTdFXxpNRFvu8gMjmoY +HtiP2Ra8EEg2XPBjs5BaXCQ316PWywlxufEBcoSwfdtNgM3802/J+Nq2DoLSRYWo +G2ioPej0RGy9ocLLA76MPhMAhN9KSMDjIgro6TenGEyxCQ0jVn8ETdkXhBilyNpA +lHPrzg5XPAOBOp0KoVdDaaxXbXmQeOW1tDvYvEyNKKGno6e6Ak4l0Squ7a4DIrhr +IA8wKFSVf+DuzgpmndFALW4ir50awQUZ0m/A8p/4e7MCQvtQqR0tkw8jq8bBD5L/ +0KIV9VMJcRz/RROE5iZe+OCIHAr8Fraocwa48GOEAqDGWuzndN9wrqODJerWx5eH +k6fGioozl2A3ED6XPm4pFdahD9GILBKfb6qkxkLrQaLjlUPTAYVtjrs78yM2x/47 +4KElB0iryYl0/wiPgL/AlmXz7uxLaL2diMMxs0Dx6M/2OLuc5NF/1OVYm3z61PMO +m3WR5LpSLhl+0fXNWhn8ugb2+1KoS5kE3fj5tItQo05iifCHJPqDQsGH+tUtKSpa +cXpkatcnYGMN285J9Y0fkIkyF/hzQ7jSWpOGYdbhdQrqeWZ2iE9x6wQl1gpaepPl +uUsXQA+xtrn13k/c4LOsOxFwYIRKQ26ZIMApcQrAZQIDAQABo4ICyzCCAscwfQYI +KwYBBQUHAQEEcTBvMEwGCCsGAQUFBzAChkBodHRwOi8vd3d3LmFjY3YuZXMvZmls +ZWFkbWluL0FyY2hpdm9zL2NlcnRpZmljYWRvcy9yYWl6YWNjdjEuY3J0MB8GCCsG +AQUFBzABhhNodHRwOi8vb2NzcC5hY2N2LmVzMB0GA1UdDgQWBBTSh7Tj3zcnk1X2 +VuqB5TbMjB4/vTAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFNKHtOPfNyeT +VfZW6oHlNsyMHj+9MIIBcwYDVR0gBIIBajCCAWYwggFiBgRVHSAAMIIBWDCCASIG +CCsGAQUFBwICMIIBFB6CARAAQQB1AHQAbwByAGkAZABhAGQAIABkAGUAIABDAGUA +cgB0AGkAZgBpAGMAYQBjAGkA8wBuACAAUgBhAO0AegAgAGQAZQAgAGwAYQAgAEEA +QwBDAFYAIAAoAEEAZwBlAG4AYwBpAGEAIABkAGUAIABUAGUAYwBuAG8AbABvAGcA +7QBhACAAeQAgAEMAZQByAHQAaQBmAGkAYwBhAGMAaQDzAG4AIABFAGwAZQBjAHQA +cgDzAG4AaQBjAGEALAAgAEMASQBGACAAUQA0ADYAMAAxADEANQA2AEUAKQAuACAA +QwBQAFMAIABlAG4AIABoAHQAdABwADoALwAvAHcAdwB3AC4AYQBjAGMAdgAuAGUA +czAwBggrBgEFBQcCARYkaHR0cDovL3d3dy5hY2N2LmVzL2xlZ2lzbGFjaW9uX2Mu +aHRtMFUGA1UdHwROMEwwSqBIoEaGRGh0dHA6Ly93d3cuYWNjdi5lcy9maWxlYWRt +aW4vQXJjaGl2b3MvY2VydGlmaWNhZG9zL3JhaXphY2N2MV9kZXIuY3JsMA4GA1Ud +DwEB/wQEAwIBBjAXBgNVHREEEDAOgQxhY2N2QGFjY3YuZXMwDQYJKoZIhvcNAQEF +BQADggIBAJcxAp/n/UNnSEQU5CmH7UwoZtCPNdpNYbdKl02125DgBS4OxnnQ8pdp +D70ER9m+27Up2pvZrqmZ1dM8MJP1jaGo/AaNRPTKFpV8M9xii6g3+CfYCS0b78gU +JyCpZET/LtZ1qmxNYEAZSUNUY9rizLpm5U9EelvZaoErQNV/+QEnWCzI7UiRfD+m +AM/EKXMRNt6GGT6d7hmKG9Ww7Y49nCrADdg9ZuM8Db3VlFzi4qc1GwQA9j9ajepD +vV+JHanBsMyZ4k0ACtrJJ1vnE5Bc5PUzolVt3OAJTS+xJlsndQAJxGJ3KQhfnlms +tn6tn1QwIgPBHnFk/vk4CpYY3QIUrCPLBhwepH2NDd4nQeit2hW3sCPdK6jT2iWH +7ehVRE2I9DZ+hJp4rPcOVkkO1jMl1oRQQmwgEh0q1b688nCBpHBgvgW1m54ERL5h +I6zppSSMEYCUWqKiuUnSwdzRp+0xESyeGabu4VXhwOrPDYTkF7eifKXeVSUG7szA +h1xA2syVP1XgNce4hL60Xc16gwFy7ofmXx2utYXGJt/mwZrpHgJHnyqobalbz+xF +d3+YJ5oyXSrjhO7FmGYvliAd3djDJ9ew+f7Zfc3Qn48LFFhRny+Lwzgt3uiP1o2H +pPVWQxaZLPSkVrQ0uGE3ycJYgBugl6H8WY3pEfbRD0tVNEYqi4Y7 +-----END CERTIFICATE----- + +# Issuer: CN=TWCA Global Root CA O=TAIWAN-CA OU=Root CA +# Subject: CN=TWCA Global Root CA O=TAIWAN-CA OU=Root CA +# Label: "TWCA Global Root CA" +# Serial: 3262 +# MD5 Fingerprint: f9:03:7e:cf:e6:9e:3c:73:7a:2a:90:07:69:ff:2b:96 +# SHA1 Fingerprint: 9c:bb:48:53:f6:a4:f6:d3:52:a4:e8:32:52:55:60:13:f5:ad:af:65 +# SHA256 Fingerprint: 59:76:90:07:f7:68:5d:0f:cd:50:87:2f:9f:95:d5:75:5a:5b:2b:45:7d:81:f3:69:2b:61:0a:98:67:2f:0e:1b +-----BEGIN CERTIFICATE----- +MIIFQTCCAymgAwIBAgICDL4wDQYJKoZIhvcNAQELBQAwUTELMAkGA1UEBhMCVFcx +EjAQBgNVBAoTCVRBSVdBTi1DQTEQMA4GA1UECxMHUm9vdCBDQTEcMBoGA1UEAxMT +VFdDQSBHbG9iYWwgUm9vdCBDQTAeFw0xMjA2MjcwNjI4MzNaFw0zMDEyMzExNTU5 +NTlaMFExCzAJBgNVBAYTAlRXMRIwEAYDVQQKEwlUQUlXQU4tQ0ExEDAOBgNVBAsT +B1Jvb3QgQ0ExHDAaBgNVBAMTE1RXQ0EgR2xvYmFsIFJvb3QgQ0EwggIiMA0GCSqG +SIb3DQEBAQUAA4ICDwAwggIKAoICAQCwBdvI64zEbooh745NnHEKH1Jw7W2CnJfF +10xORUnLQEK1EjRsGcJ0pDFfhQKX7EMzClPSnIyOt7h52yvVavKOZsTuKwEHktSz +0ALfUPZVr2YOy+BHYC8rMjk1Ujoog/h7FsYYuGLWRyWRzvAZEk2tY/XTP3VfKfCh +MBwqoJimFb3u/Rk28OKRQ4/6ytYQJ0lM793B8YVwm8rqqFpD/G2Gb3PpN0Wp8DbH +zIh1HrtsBv+baz4X7GGqcXzGHaL3SekVtTzWoWH1EfcFbx39Eb7QMAfCKbAJTibc +46KokWofwpFFiFzlmLhxpRUZyXx1EcxwdE8tmx2RRP1WKKD+u4ZqyPpcC1jcxkt2 +yKsi2XMPpfRaAok/T54igu6idFMqPVMnaR1sjjIsZAAmY2E2TqNGtz99sy2sbZCi +laLOz9qC5wc0GZbpuCGqKX6mOL6OKUohZnkfs8O1CWfe1tQHRvMq2uYiN2DLgbYP +oA/pyJV/v1WRBXrPPRXAb94JlAGD1zQbzECl8LibZ9WYkTunhHiVJqRaCPgrdLQA +BDzfuBSO6N+pjWxnkjMdwLfS7JLIvgm/LCkFbwJrnu+8vyq8W8BQj0FwcYeyTbcE +qYSjMq+u7msXi7Kx/mzhkIyIqJdIzshNy/MGz19qCkKxHh53L46g5pIOBvwFItIm +4TFRfTLcDwIDAQABoyMwITAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB +/zANBgkqhkiG9w0BAQsFAAOCAgEAXzSBdu+WHdXltdkCY4QWwa6gcFGn90xHNcgL +1yg9iXHZqjNB6hQbbCEAwGxCGX6faVsgQt+i0trEfJdLjbDorMjupWkEmQqSpqsn +LhpNgb+E1HAerUf+/UqdM+DyucRFCCEK2mlpc3INvjT+lIutwx4116KD7+U4x6WF +H6vPNOw/KP4M8VeGTslV9xzU2KV9Bnpv1d8Q34FOIWWxtuEXeZVFBs5fzNxGiWNo +RI2T9GRwoD2dKAXDOXC4Ynsg/eTb6QihuJ49CcdP+yz4k3ZB3lLg4VfSnQO8d57+ +nile98FRYB/e2guyLXW3Q0iT5/Z5xoRdgFlglPx4mI88k1HtQJAH32RjJMtOcQWh +15QaiDLxInQirqWm2BJpTGCjAu4r7NRjkgtevi92a6O2JryPA9gK8kxkRr05YuWW +6zRjESjMlfGt7+/cgFhI6Uu46mWs6fyAtbXIRfmswZ/ZuepiiI7E8UuDEq3mi4TW +nsLrgxifarsbJGAzcMzs9zLzXNl5fe+epP7JI8Mk7hWSsT2RTyaGvWZzJBPqpK5j +wa19hAM8EHiGG3njxPPyBJUgriOCxLM6AGK/5jYk4Ve6xx6QddVfP5VhK8E7zeWz +aGHQRiapIVJpLesux+t3zqY6tQMzT3bR51xUAV3LePTJDL/PEo4XLSNolOer/qmy +KwbQBM0= +-----END CERTIFICATE----- + +# Issuer: CN=TeliaSonera Root CA v1 O=TeliaSonera +# Subject: CN=TeliaSonera Root CA v1 O=TeliaSonera +# Label: "TeliaSonera Root CA v1" +# Serial: 199041966741090107964904287217786801558 +# MD5 Fingerprint: 37:41:49:1b:18:56:9a:26:f5:ad:c2:66:fb:40:a5:4c +# SHA1 Fingerprint: 43:13:bb:96:f1:d5:86:9b:c1:4e:6a:92:f6:cf:f6:34:69:87:82:37 +# SHA256 Fingerprint: dd:69:36:fe:21:f8:f0:77:c1:23:a1:a5:21:c1:22:24:f7:22:55:b7:3e:03:a7:26:06:93:e8:a2:4b:0f:a3:89 +-----BEGIN CERTIFICATE----- +MIIFODCCAyCgAwIBAgIRAJW+FqD3LkbxezmCcvqLzZYwDQYJKoZIhvcNAQEFBQAw +NzEUMBIGA1UECgwLVGVsaWFTb25lcmExHzAdBgNVBAMMFlRlbGlhU29uZXJhIFJv +b3QgQ0EgdjEwHhcNMDcxMDE4MTIwMDUwWhcNMzIxMDE4MTIwMDUwWjA3MRQwEgYD +VQQKDAtUZWxpYVNvbmVyYTEfMB0GA1UEAwwWVGVsaWFTb25lcmEgUm9vdCBDQSB2 +MTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMK+6yfwIaPzaSZVfp3F +VRaRXP3vIb9TgHot0pGMYzHw7CTww6XScnwQbfQ3t+XmfHnqjLWCi65ItqwA3GV1 +7CpNX8GH9SBlK4GoRz6JI5UwFpB/6FcHSOcZrr9FZ7E3GwYq/t75rH2D+1665I+X +Z75Ljo1kB1c4VWk0Nj0TSO9P4tNmHqTPGrdeNjPUtAa9GAH9d4RQAEX1jF3oI7x+ +/jXh7VB7qTCNGdMJjmhnXb88lxhTuylixcpecsHHltTbLaC0H2kD7OriUPEMPPCs +81Mt8Bz17Ww5OXOAFshSsCPN4D7c3TxHoLs1iuKYaIu+5b9y7tL6pe0S7fyYGKkm +dtwoSxAgHNN/Fnct7W+A90m7UwW7XWjH1Mh1Fj+JWov3F0fUTPHSiXk+TT2YqGHe +Oh7S+F4D4MHJHIzTjU3TlTazN19jY5szFPAtJmtTfImMMsJu7D0hADnJoWjiUIMu +sDor8zagrC/kb2HCUQk5PotTubtn2txTuXZZNp1D5SDgPTJghSJRt8czu90VL6R4 +pgd7gUY2BIbdeTXHlSw7sKMXNeVzH7RcWe/a6hBle3rQf5+ztCo3O3CLm1u5K7fs +slESl1MpWtTwEhDcTwK7EpIvYtQ/aUN8Ddb8WHUBiJ1YFkveupD/RwGJBmr2X7KQ +arMCpgKIv7NHfirZ1fpoeDVNAgMBAAGjPzA9MA8GA1UdEwEB/wQFMAMBAf8wCwYD +VR0PBAQDAgEGMB0GA1UdDgQWBBTwj1k4ALP1j5qWDNXr+nuqF+gTEjANBgkqhkiG +9w0BAQUFAAOCAgEAvuRcYk4k9AwI//DTDGjkk0kiP0Qnb7tt3oNmzqjMDfz1mgbl +dxSR651Be5kqhOX//CHBXfDkH1e3damhXwIm/9fH907eT/j3HEbAek9ALCI18Bmx +0GtnLLCo4MBANzX2hFxc469CeP6nyQ1Q6g2EdvZR74NTxnr/DlZJLo961gzmJ1Tj +TQpgcmLNkQfWpb/ImWvtxBnmq0wROMVvMeJuScg/doAmAyYp4Db29iBT4xdwNBed +Y2gea+zDTYa4EzAvXUYNR0PVG6pZDrlcjQZIrXSHX8f8MVRBE+LHIQ6e4B4N4cB7 +Q4WQxYpYxmUKeFfyxiMPAdkgS94P+5KFdSpcc41teyWRyu5FrgZLAMzTsVlQ2jqI +OylDRl6XK1TOU2+NSueW+r9xDkKLfP0ooNBIytrEgUy7onOTJsjrDNYmiLbAJM+7 +vVvrdX3pCI6GMyx5dwlppYn8s3CQh3aP0yK7Qs69cwsgJirQmz1wHiRszYd2qReW +t88NkvuOGKmYSdGe/mBEciG5Ge3C9THxOUiIkCR1VBatzvT4aRRkOfujuLpwQMcn +HL/EVlP6Y2XQ8xwOFvVrhlhNGNTkDY6lnVuR3HYkUD/GKvvZt5y11ubQ2egZixVx +SK236thZiNSQvxaz2emsWWFUyBy6ysHK4bkgTI86k4mloMy/0/Z1pHWWbVY= +-----END CERTIFICATE----- + +# Issuer: CN=E-Tugra Certification Authority O=E-Tu\u011fra EBG Bili\u015fim Teknolojileri ve Hizmetleri A.\u015e. OU=E-Tugra Sertifikasyon Merkezi +# Subject: CN=E-Tugra Certification Authority O=E-Tu\u011fra EBG Bili\u015fim Teknolojileri ve Hizmetleri A.\u015e. OU=E-Tugra Sertifikasyon Merkezi +# Label: "E-Tugra Certification Authority" +# Serial: 7667447206703254355 +# MD5 Fingerprint: b8:a1:03:63:b0:bd:21:71:70:8a:6f:13:3a:bb:79:49 +# SHA1 Fingerprint: 51:c6:e7:08:49:06:6e:f3:92:d4:5c:a0:0d:6d:a3:62:8f:c3:52:39 +# SHA256 Fingerprint: b0:bf:d5:2b:b0:d7:d9:bd:92:bf:5d:4d:c1:3d:a2:55:c0:2c:54:2f:37:83:65:ea:89:39:11:f5:5e:55:f2:3c +-----BEGIN CERTIFICATE----- +MIIGSzCCBDOgAwIBAgIIamg+nFGby1MwDQYJKoZIhvcNAQELBQAwgbIxCzAJBgNV +BAYTAlRSMQ8wDQYDVQQHDAZBbmthcmExQDA+BgNVBAoMN0UtVHXEn3JhIEVCRyBC +aWxpxZ9pbSBUZWtub2xvamlsZXJpIHZlIEhpem1ldGxlcmkgQS7Fni4xJjAkBgNV +BAsMHUUtVHVncmEgU2VydGlmaWthc3lvbiBNZXJrZXppMSgwJgYDVQQDDB9FLVR1 +Z3JhIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTEzMDMwNTEyMDk0OFoXDTIz +MDMwMzEyMDk0OFowgbIxCzAJBgNVBAYTAlRSMQ8wDQYDVQQHDAZBbmthcmExQDA+ +BgNVBAoMN0UtVHXEn3JhIEVCRyBCaWxpxZ9pbSBUZWtub2xvamlsZXJpIHZlIEhp +em1ldGxlcmkgQS7Fni4xJjAkBgNVBAsMHUUtVHVncmEgU2VydGlmaWthc3lvbiBN +ZXJrZXppMSgwJgYDVQQDDB9FLVR1Z3JhIENlcnRpZmljYXRpb24gQXV0aG9yaXR5 +MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA4vU/kwVRHoViVF56C/UY +B4Oufq9899SKa6VjQzm5S/fDxmSJPZQuVIBSOTkHS0vdhQd2h8y/L5VMzH2nPbxH +D5hw+IyFHnSOkm0bQNGZDbt1bsipa5rAhDGvykPL6ys06I+XawGb1Q5KCKpbknSF +Q9OArqGIW66z6l7LFpp3RMih9lRozt6Plyu6W0ACDGQXwLWTzeHxE2bODHnv0ZEo +q1+gElIwcxmOj+GMB6LDu0rw6h8VqO4lzKRG+Bsi77MOQ7osJLjFLFzUHPhdZL3D +k14opz8n8Y4e0ypQBaNV2cvnOVPAmJ6MVGKLJrD3fY185MaeZkJVgkfnsliNZvcH +fC425lAcP9tDJMW/hkd5s3kc91r0E+xs+D/iWR+V7kI+ua2oMoVJl0b+SzGPWsut +dEcf6ZG33ygEIqDUD13ieU/qbIWGvaimzuT6w+Gzrt48Ue7LE3wBf4QOXVGUnhMM +ti6lTPk5cDZvlsouDERVxcr6XQKj39ZkjFqzAQqptQpHF//vkUAqjqFGOjGY5RH8 +zLtJVor8udBhmm9lbObDyz51Sf6Pp+KJxWfXnUYTTjF2OySznhFlhqt/7x3U+Lzn +rFpct1pHXFXOVbQicVtbC/DP3KBhZOqp12gKY6fgDT+gr9Oq0n7vUaDmUStVkhUX +U8u3Zg5mTPj5dUyQ5xJwx0UCAwEAAaNjMGEwHQYDVR0OBBYEFC7j27JJ0JxUeVz6 +Jyr+zE7S6E5UMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAULuPbsknQnFR5 +XPonKv7MTtLoTlQwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEBCwUAA4ICAQAF +Nzr0TbdF4kV1JI+2d1LoHNgQk2Xz8lkGpD4eKexd0dCrfOAKkEh47U6YA5n+KGCR +HTAduGN8qOY1tfrTYXbm1gdLymmasoR6d5NFFxWfJNCYExL/u6Au/U5Mh/jOXKqY +GwXgAEZKgoClM4so3O0409/lPun++1ndYYRP0lSWE2ETPo+Aab6TR7U1Q9Jauz1c +77NCR807VRMGsAnb/WP2OogKmW9+4c4bU2pEZiNRCHu8W1Ki/QY3OEBhj0qWuJA3 ++GbHeJAAFS6LrVE1Uweoa2iu+U48BybNCAVwzDk/dr2l02cmAYamU9JgO3xDf1WK +vJUawSg5TB9D0pH0clmKuVb8P7Sd2nCcdlqMQ1DujjByTd//SffGqWfZbawCEeI6 +FiWnWAjLb1NBnEg4R2gz0dfHj9R0IdTDBZB6/86WiLEVKV0jq9BgoRJP3vQXzTLl +yb/IQ639Lo7xr+L0mPoSHyDYwKcMhcWQ9DstliaxLL5Mq+ux0orJ23gTDx4JnW2P +AJ8C2sH6H3p6CcRK5ogql5+Ji/03X186zjhZhkuvcQu02PJwT58yE+Owp1fl2tpD +y4Q08ijE6m30Ku/Ba3ba+367hTzSU8JNvnHhRdH9I2cNE3X7z2VnIp2usAnRCf8d +NL/+I5c30jn6PQ0GC7TbO6Orb1wdtn7os4I07QZcJA== +-----END CERTIFICATE----- + +# Issuer: CN=T-TeleSec GlobalRoot Class 2 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center +# Subject: CN=T-TeleSec GlobalRoot Class 2 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center +# Label: "T-TeleSec GlobalRoot Class 2" +# Serial: 1 +# MD5 Fingerprint: 2b:9b:9e:e4:7b:6c:1f:00:72:1a:cc:c1:77:79:df:6a +# SHA1 Fingerprint: 59:0d:2d:7d:88:4f:40:2e:61:7e:a5:62:32:17:65:cf:17:d8:94:e9 +# SHA256 Fingerprint: 91:e2:f5:78:8d:58:10:eb:a7:ba:58:73:7d:e1:54:8a:8e:ca:cd:01:45:98:bc:0b:14:3e:04:1b:17:05:25:52 +-----BEGIN CERTIFICATE----- +MIIDwzCCAqugAwIBAgIBATANBgkqhkiG9w0BAQsFADCBgjELMAkGA1UEBhMCREUx +KzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAd +BgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNl +YyBHbG9iYWxSb290IENsYXNzIDIwHhcNMDgxMDAxMTA0MDE0WhcNMzMxMDAxMjM1 +OTU5WjCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnBy +aXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50 +ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDIwggEiMA0G +CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCqX9obX+hzkeXaXPSi5kfl82hVYAUd +AqSzm1nzHoqvNK38DcLZSBnuaY/JIPwhqgcZ7bBcrGXHX+0CfHt8LRvWurmAwhiC +FoT6ZrAIxlQjgeTNuUk/9k9uN0goOA/FvudocP05l03Sx5iRUKrERLMjfTlH6VJi +1hKTXrcxlkIF+3anHqP1wvzpesVsqXFP6st4vGCvx9702cu+fjOlbpSD8DT6Iavq +jnKgP6TeMFvvhk1qlVtDRKgQFRzlAVfFmPHmBiiRqiDFt1MmUUOyCxGVWOHAD3bZ +wI18gfNycJ5v/hqO2V81xrJvNHy+SE/iWjnX2J14np+GPgNeGYtEotXHAgMBAAGj +QjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBS/ +WSA2AHmgoCJrjNXyYdK4LMuCSjANBgkqhkiG9w0BAQsFAAOCAQEAMQOiYQsfdOhy +NsZt+U2e+iKo4YFWz827n+qrkRk4r6p8FU3ztqONpfSO9kSpp+ghla0+AGIWiPAC +uvxhI+YzmzB6azZie60EI4RYZeLbK4rnJVM3YlNfvNoBYimipidx5joifsFvHZVw +IEoHNN/q/xWA5brXethbdXwFeilHfkCoMRN3zUA7tFFHei4R40cR3p1m0IvVVGb6 +g1XqfMIpiRvpb7PO4gWEyS8+eIVibslfwXhjdFjASBgMmTnrpMwatXlajRWc2BQN +9noHV8cigwUtPJslJj0Ys6lDfMjIq2SPDqO/nBudMNva0Bkuqjzx+zOAduTNrRlP +BSeOE6Fuwg== +-----END CERTIFICATE----- + +# Issuer: CN=Atos TrustedRoot 2011 O=Atos +# Subject: CN=Atos TrustedRoot 2011 O=Atos +# Label: "Atos TrustedRoot 2011" +# Serial: 6643877497813316402 +# MD5 Fingerprint: ae:b9:c4:32:4b:ac:7f:5d:66:cc:77:94:bb:2a:77:56 +# SHA1 Fingerprint: 2b:b1:f5:3e:55:0c:1d:c5:f1:d4:e6:b7:6a:46:4b:55:06:02:ac:21 +# SHA256 Fingerprint: f3:56:be:a2:44:b7:a9:1e:b3:5d:53:ca:9a:d7:86:4a:ce:01:8e:2d:35:d5:f8:f9:6d:df:68:a6:f4:1a:a4:74 +-----BEGIN CERTIFICATE----- +MIIDdzCCAl+gAwIBAgIIXDPLYixfszIwDQYJKoZIhvcNAQELBQAwPDEeMBwGA1UE +AwwVQXRvcyBUcnVzdGVkUm9vdCAyMDExMQ0wCwYDVQQKDARBdG9zMQswCQYDVQQG +EwJERTAeFw0xMTA3MDcxNDU4MzBaFw0zMDEyMzEyMzU5NTlaMDwxHjAcBgNVBAMM +FUF0b3MgVHJ1c3RlZFJvb3QgMjAxMTENMAsGA1UECgwEQXRvczELMAkGA1UEBhMC +REUwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCVhTuXbyo7LjvPpvMp +Nb7PGKw+qtn4TaA+Gke5vJrf8v7MPkfoepbCJI419KkM/IL9bcFyYie96mvr54rM +VD6QUM+A1JX76LWC1BTFtqlVJVfbsVD2sGBkWXppzwO3bw2+yj5vdHLqqjAqc2K+ +SZFhyBH+DgMq92og3AIVDV4VavzjgsG1xZ1kCWyjWZgHJ8cblithdHFsQ/H3NYkQ +4J7sVaE3IqKHBAUsR320HLliKWYoyrfhk/WklAOZuXCFteZI6o1Q/NnezG8HDt0L +cp2AMBYHlT8oDv3FdU9T1nSatCQujgKRz3bFmx5VdJx4IbHwLfELn8LVlhgf8FQi +eowHAgMBAAGjfTB7MB0GA1UdDgQWBBSnpQaxLKYJYO7Rl+lwrrw7GWzbITAPBgNV +HRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFKelBrEspglg7tGX6XCuvDsZbNshMBgG +A1UdIAQRMA8wDQYLKwYBBAGwLQMEAQEwDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3 +DQEBCwUAA4IBAQAmdzTblEiGKkGdLD4GkGDEjKwLVLgfuXvTBznk+j57sj1O7Z8j +vZfza1zv7v1Apt+hk6EKhqzvINB5Ab149xnYJDE0BAGmuhWawyfc2E8PzBhj/5kP +DpFrdRbhIfzYJsdHt6bPWHJxfrrhTZVHO8mvbaG0weyJ9rQPOLXiZNwlz6bb65pc +maHFCN795trV1lpFDMS3wrUU77QR/w4VtfX128a961qn8FYiqTxlVMYVqL2Gns2D +lmh6cYGJ4Qvh6hEbaAjMaZ7snkGeRDImeuKHCnE96+RapNLbxc3G3mB/ufNPRJLv +KrcYPqcZ2Qt9sTdBQrC6YB3y/gkRsPCHe6ed +-----END CERTIFICATE----- + +# Issuer: CN=QuoVadis Root CA 1 G3 O=QuoVadis Limited +# Subject: CN=QuoVadis Root CA 1 G3 O=QuoVadis Limited +# Label: "QuoVadis Root CA 1 G3" +# Serial: 687049649626669250736271037606554624078720034195 +# MD5 Fingerprint: a4:bc:5b:3f:fe:37:9a:fa:64:f0:e2:fa:05:3d:0b:ab +# SHA1 Fingerprint: 1b:8e:ea:57:96:29:1a:c9:39:ea:b8:0a:81:1a:73:73:c0:93:79:67 +# SHA256 Fingerprint: 8a:86:6f:d1:b2:76:b5:7e:57:8e:92:1c:65:82:8a:2b:ed:58:e9:f2:f2:88:05:41:34:b7:f1:f4:bf:c9:cc:74 +-----BEGIN CERTIFICATE----- +MIIFYDCCA0igAwIBAgIUeFhfLq0sGUvjNwc1NBMotZbUZZMwDQYJKoZIhvcNAQEL +BQAwSDELMAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxHjAc +BgNVBAMTFVF1b1ZhZGlzIFJvb3QgQ0EgMSBHMzAeFw0xMjAxMTIxNzI3NDRaFw00 +MjAxMTIxNzI3NDRaMEgxCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBM +aW1pdGVkMR4wHAYDVQQDExVRdW9WYWRpcyBSb290IENBIDEgRzMwggIiMA0GCSqG +SIb3DQEBAQUAA4ICDwAwggIKAoICAQCgvlAQjunybEC0BJyFuTHK3C3kEakEPBtV +wedYMB0ktMPvhd6MLOHBPd+C5k+tR4ds7FtJwUrVu4/sh6x/gpqG7D0DmVIB0jWe +rNrwU8lmPNSsAgHaJNM7qAJGr6Qc4/hzWHa39g6QDbXwz8z6+cZM5cOGMAqNF341 +68Xfuw6cwI2H44g4hWf6Pser4BOcBRiYz5P1sZK0/CPTz9XEJ0ngnjybCKOLXSoh +4Pw5qlPafX7PGglTvF0FBM+hSo+LdoINofjSxxR3W5A2B4GbPgb6Ul5jxaYA/qXp +UhtStZI5cgMJYr2wYBZupt0lwgNm3fME0UDiTouG9G/lg6AnhF4EwfWQvTA9xO+o +abw4m6SkltFi2mnAAZauy8RRNOoMqv8hjlmPSlzkYZqn0ukqeI1RPToV7qJZjqlc +3sX5kCLliEVx3ZGZbHqfPT2YfF72vhZooF6uCyP8Wg+qInYtyaEQHeTTRCOQiJ/G +KubX9ZqzWB4vMIkIG1SitZgj7Ah3HJVdYdHLiZxfokqRmu8hqkkWCKi9YSgxyXSt +hfbZxbGL0eUQMk1fiyA6PEkfM4VZDdvLCXVDaXP7a3F98N/ETH3Goy7IlXnLc6KO +Tk0k+17kBL5yG6YnLUlamXrXXAkgt3+UuU/xDRxeiEIbEbfnkduebPRq34wGmAOt +zCjvpUfzUwIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIB +BjAdBgNVHQ4EFgQUo5fW816iEOGrRZ88F2Q87gFwnMwwDQYJKoZIhvcNAQELBQAD +ggIBABj6W3X8PnrHX3fHyt/PX8MSxEBd1DKquGrX1RUVRpgjpeaQWxiZTOOtQqOC +MTaIzen7xASWSIsBx40Bz1szBpZGZnQdT+3Btrm0DWHMY37XLneMlhwqI2hrhVd2 +cDMT/uFPpiN3GPoajOi9ZcnPP/TJF9zrx7zABC4tRi9pZsMbj/7sPtPKlL92CiUN +qXsCHKnQO18LwIE6PWThv6ctTr1NxNgpxiIY0MWscgKCP6o6ojoilzHdCGPDdRS5 +YCgtW2jgFqlmgiNR9etT2DGbe+m3nUvriBbP+V04ikkwj+3x6xn0dxoxGE1nVGwv +b2X52z3sIexe9PSLymBlVNFxZPT5pqOBMzYzcfCkeF9OrYMh3jRJjehZrJ3ydlo2 +8hP0r+AJx2EqbPfgna67hkooby7utHnNkDPDs3b69fBsnQGQ+p6Q9pxyz0fawx/k +NSBT8lTR32GDpgLiJTjehTItXnOQUl1CxM49S+H5GYQd1aJQzEH7QRTDvdbJWqNj +ZgKAvQU6O0ec7AAmTPWIUb+oI38YB7AL7YsmoWTTYUrrXJ/es69nA7Mf3W1daWhp +q1467HxpvMc7hU6eFbm0FU/DlXpY18ls6Wy58yljXrQs8C097Vpl4KlbQMJImYFt +nh8GKjwStIsPm6Ik8KaN1nrgS7ZklmOVhMJKzRwuJIczYOXD +-----END CERTIFICATE----- + +# Issuer: CN=QuoVadis Root CA 2 G3 O=QuoVadis Limited +# Subject: CN=QuoVadis Root CA 2 G3 O=QuoVadis Limited +# Label: "QuoVadis Root CA 2 G3" +# Serial: 390156079458959257446133169266079962026824725800 +# MD5 Fingerprint: af:0c:86:6e:bf:40:2d:7f:0b:3e:12:50:ba:12:3d:06 +# SHA1 Fingerprint: 09:3c:61:f3:8b:8b:dc:7d:55:df:75:38:02:05:00:e1:25:f5:c8:36 +# SHA256 Fingerprint: 8f:e4:fb:0a:f9:3a:4d:0d:67:db:0b:eb:b2:3e:37:c7:1b:f3:25:dc:bc:dd:24:0e:a0:4d:af:58:b4:7e:18:40 +-----BEGIN CERTIFICATE----- +MIIFYDCCA0igAwIBAgIURFc0JFuBiZs18s64KztbpybwdSgwDQYJKoZIhvcNAQEL +BQAwSDELMAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxHjAc +BgNVBAMTFVF1b1ZhZGlzIFJvb3QgQ0EgMiBHMzAeFw0xMjAxMTIxODU5MzJaFw00 +MjAxMTIxODU5MzJaMEgxCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBM +aW1pdGVkMR4wHAYDVQQDExVRdW9WYWRpcyBSb290IENBIDIgRzMwggIiMA0GCSqG +SIb3DQEBAQUAA4ICDwAwggIKAoICAQChriWyARjcV4g/Ruv5r+LrI3HimtFhZiFf +qq8nUeVuGxbULX1QsFN3vXg6YOJkApt8hpvWGo6t/x8Vf9WVHhLL5hSEBMHfNrMW +n4rjyduYNM7YMxcoRvynyfDStNVNCXJJ+fKH46nafaF9a7I6JaltUkSs+L5u+9ym +c5GQYaYDFCDy54ejiK2toIz/pgslUiXnFgHVy7g1gQyjO/Dh4fxaXc6AcW34Sas+ +O7q414AB+6XrW7PFXmAqMaCvN+ggOp+oMiwMzAkd056OXbxMmO7FGmh77FOm6RQ1 +o9/NgJ8MSPsc9PG/Srj61YxxSscfrf5BmrODXfKEVu+lV0POKa2Mq1W/xPtbAd0j +IaFYAI7D0GoT7RPjEiuA3GfmlbLNHiJuKvhB1PLKFAeNilUSxmn1uIZoL1NesNKq +IcGY5jDjZ1XHm26sGahVpkUG0CM62+tlXSoREfA7T8pt9DTEceT/AFr2XK4jYIVz +8eQQsSWu1ZK7E8EM4DnatDlXtas1qnIhO4M15zHfeiFuuDIIfR0ykRVKYnLP43eh +vNURG3YBZwjgQQvD6xVu+KQZ2aKrr+InUlYrAoosFCT5v0ICvybIxo/gbjh9Uy3l +7ZizlWNof/k19N+IxWA1ksB8aRxhlRbQ694Lrz4EEEVlWFA4r0jyWbYW8jwNkALG +cC4BrTwV1wIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIB +BjAdBgNVHQ4EFgQU7edvdlq/YOxJW8ald7tyFnGbxD0wDQYJKoZIhvcNAQELBQAD +ggIBAJHfgD9DCX5xwvfrs4iP4VGyvD11+ShdyLyZm3tdquXK4Qr36LLTn91nMX66 +AarHakE7kNQIXLJgapDwyM4DYvmL7ftuKtwGTTwpD4kWilhMSA/ohGHqPHKmd+RC +roijQ1h5fq7KpVMNqT1wvSAZYaRsOPxDMuHBR//47PERIjKWnML2W2mWeyAMQ0Ga +W/ZZGYjeVYg3UQt4XAoeo0L9x52ID8DyeAIkVJOviYeIyUqAHerQbj5hLja7NQ4n +lv1mNDthcnPxFlxHBlRJAHpYErAK74X9sbgzdWqTHBLmYF5vHX/JHyPLhGGfHoJE ++V+tYlUkmlKY7VHnoX6XOuYvHxHaU4AshZ6rNRDbIl9qxV6XU/IyAgkwo1jwDQHV +csaxfGl7w/U2Rcxhbl5MlMVerugOXou/983g7aEOGzPuVBj+D77vfoRrQ+NwmNtd +dbINWQeFFSM51vHfqSYP1kjHs6Yi9TM3WpVHn3u6GBVv/9YUZINJ0gpnIdsPNWNg +KCLjsZWDzYWm3S8P52dSbrsvhXz1SnPnxT7AvSESBT/8twNJAlvIJebiVDj1eYeM +HVOyToV7BjjHLPj4sHKNJeV3UvQDHEimUF+IIDBu8oJDqz2XhOdT+yHBTw8imoa4 +WSr2Rz0ZiC3oheGe7IUIarFsNMkd7EgrO3jtZsSOeWmD3n+M +-----END CERTIFICATE----- + +# Issuer: CN=QuoVadis Root CA 3 G3 O=QuoVadis Limited +# Subject: CN=QuoVadis Root CA 3 G3 O=QuoVadis Limited +# Label: "QuoVadis Root CA 3 G3" +# Serial: 268090761170461462463995952157327242137089239581 +# MD5 Fingerprint: df:7d:b9:ad:54:6f:68:a1:df:89:57:03:97:43:b0:d7 +# SHA1 Fingerprint: 48:12:bd:92:3c:a8:c4:39:06:e7:30:6d:27:96:e6:a4:cf:22:2e:7d +# SHA256 Fingerprint: 88:ef:81:de:20:2e:b0:18:45:2e:43:f8:64:72:5c:ea:5f:bd:1f:c2:d9:d2:05:73:07:09:c5:d8:b8:69:0f:46 +-----BEGIN CERTIFICATE----- +MIIFYDCCA0igAwIBAgIULvWbAiin23r/1aOp7r0DoM8Sah0wDQYJKoZIhvcNAQEL +BQAwSDELMAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxHjAc +BgNVBAMTFVF1b1ZhZGlzIFJvb3QgQ0EgMyBHMzAeFw0xMjAxMTIyMDI2MzJaFw00 +MjAxMTIyMDI2MzJaMEgxCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBM +aW1pdGVkMR4wHAYDVQQDExVRdW9WYWRpcyBSb290IENBIDMgRzMwggIiMA0GCSqG +SIb3DQEBAQUAA4ICDwAwggIKAoICAQCzyw4QZ47qFJenMioKVjZ/aEzHs286IxSR +/xl/pcqs7rN2nXrpixurazHb+gtTTK/FpRp5PIpM/6zfJd5O2YIyC0TeytuMrKNu +FoM7pmRLMon7FhY4futD4tN0SsJiCnMK3UmzV9KwCoWdcTzeo8vAMvMBOSBDGzXR +U7Ox7sWTaYI+FrUoRqHe6okJ7UO4BUaKhvVZR74bbwEhELn9qdIoyhA5CcoTNs+c +ra1AdHkrAj80//ogaX3T7mH1urPnMNA3I4ZyYUUpSFlob3emLoG+B01vr87ERROR +FHAGjx+f+IdpsQ7vw4kZ6+ocYfx6bIrc1gMLnia6Et3UVDmrJqMz6nWB2i3ND0/k +A9HvFZcba5DFApCTZgIhsUfei5pKgLlVj7WiL8DWM2fafsSntARE60f75li59wzw +eyuxwHApw0BiLTtIadwjPEjrewl5qW3aqDCYz4ByA4imW0aucnl8CAMhZa634Ryl +sSqiMd5mBPfAdOhx3v89WcyWJhKLhZVXGqtrdQtEPREoPHtht+KPZ0/l7DxMYIBp +VzgeAVuNVejH38DMdyM0SXV89pgR6y3e7UEuFAUCf+D+IOs15xGsIs5XPd7JMG0Q +A4XN8f+MFrXBsj6IbGB/kE+V9/YtrQE5BwT6dYB9v0lQ7e/JxHwc64B+27bQ3RP+ +ydOc17KXqQIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIB +BjAdBgNVHQ4EFgQUxhfQvKjqAkPyGwaZXSuQILnXnOQwDQYJKoZIhvcNAQELBQAD +ggIBADRh2Va1EodVTd2jNTFGu6QHcrxfYWLopfsLN7E8trP6KZ1/AvWkyaiTt3px +KGmPc+FSkNrVvjrlt3ZqVoAh313m6Tqe5T72omnHKgqwGEfcIHB9UqM+WXzBusnI +FUBhynLWcKzSt/Ac5IYp8M7vaGPQtSCKFWGafoaYtMnCdvvMujAWzKNhxnQT5Wvv +oxXqA/4Ti2Tk08HS6IT7SdEQTXlm66r99I0xHnAUrdzeZxNMgRVhvLfZkXdxGYFg +u/BYpbWcC/ePIlUnwEsBbTuZDdQdm2NnL9DuDcpmvJRPpq3t/O5jrFc/ZSXPsoaP +0Aj/uHYUbt7lJ+yreLVTubY/6CD50qi+YUbKh4yE8/nxoGibIh6BJpsQBJFxwAYf +3KDTuVan45gtf4Od34wrnDKOMpTwATwiKp9Dwi7DmDkHOHv8XgBCH/MyJnmDhPbl +8MFREsALHgQjDFSlTC9JxUrRtm5gDWv8a4uFJGS3iQ6rJUdbPM9+Sb3H6QrG2vd+ +DhcI00iX0HGS8A85PjRqHH3Y8iKuu2n0M7SmSFXRDw4m6Oy2Cy2nhTXN/VnIn9HN +PlopNLk9hM6xZdRZkZFWdSHBd575euFgndOtBBj0fOtek49TSiIp+EgrPk2GrFt/ +ywaZWWDYWGWVjUTR939+J399roD1B0y2PpxxVJkES/1Y+Zj0 +-----END CERTIFICATE----- + +# Issuer: CN=DigiCert Assured ID Root G2 O=DigiCert Inc OU=www.digicert.com +# Subject: CN=DigiCert Assured ID Root G2 O=DigiCert Inc OU=www.digicert.com +# Label: "DigiCert Assured ID Root G2" +# Serial: 15385348160840213938643033620894905419 +# MD5 Fingerprint: 92:38:b9:f8:63:24:82:65:2c:57:33:e6:fe:81:8f:9d +# SHA1 Fingerprint: a1:4b:48:d9:43:ee:0a:0e:40:90:4f:3c:e0:a4:c0:91:93:51:5d:3f +# SHA256 Fingerprint: 7d:05:eb:b6:82:33:9f:8c:94:51:ee:09:4e:eb:fe:fa:79:53:a1:14:ed:b2:f4:49:49:45:2f:ab:7d:2f:c1:85 +-----BEGIN CERTIFICATE----- +MIIDljCCAn6gAwIBAgIQC5McOtY5Z+pnI7/Dr5r0SzANBgkqhkiG9w0BAQsFADBl +MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 +d3cuZGlnaWNlcnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJv +b3QgRzIwHhcNMTMwODAxMTIwMDAwWhcNMzgwMTE1MTIwMDAwWjBlMQswCQYDVQQG +EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNl +cnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgRzIwggEi +MA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDZ5ygvUj82ckmIkzTz+GoeMVSA +n61UQbVH35ao1K+ALbkKz3X9iaV9JPrjIgwrvJUXCzO/GU1BBpAAvQxNEP4Htecc +biJVMWWXvdMX0h5i89vqbFCMP4QMls+3ywPgym2hFEwbid3tALBSfK+RbLE4E9Hp +EgjAALAcKxHad3A2m67OeYfcgnDmCXRwVWmvo2ifv922ebPynXApVfSr/5Vh88lA +bx3RvpO704gqu52/clpWcTs/1PPRCv4o76Pu2ZmvA9OPYLfykqGxvYmJHzDNw6Yu +YjOuFgJ3RFrngQo8p0Quebg/BLxcoIfhG69Rjs3sLPr4/m3wOnyqi+RnlTGNAgMB +AAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQW +BBTOw0q5mVXyuNtgv6l+vVa1lzan1jANBgkqhkiG9w0BAQsFAAOCAQEAyqVVjOPI +QW5pJ6d1Ee88hjZv0p3GeDgdaZaikmkuOGybfQTUiaWxMTeKySHMq2zNixya1r9I +0jJmwYrA8y8678Dj1JGG0VDjA9tzd29KOVPt3ibHtX2vK0LRdWLjSisCx1BL4Gni +lmwORGYQRI+tBev4eaymG+g3NJ1TyWGqolKvSnAWhsI6yLETcDbYz+70CjTVW0z9 +B5yiutkBclzzTcHdDrEcDcRjvq30FPuJ7KJBDkzMyFdA0G4Dqs0MjomZmWzwPDCv +ON9vvKO+KSAnq3T/EyJ43pdSVR6DtVQgA+6uwE9W3jfMw3+qBCe703e4YtsXfJwo +IhNzbM8m9Yop5w== +-----END CERTIFICATE----- + +# Issuer: CN=DigiCert Assured ID Root G3 O=DigiCert Inc OU=www.digicert.com +# Subject: CN=DigiCert Assured ID Root G3 O=DigiCert Inc OU=www.digicert.com +# Label: "DigiCert Assured ID Root G3" +# Serial: 15459312981008553731928384953135426796 +# MD5 Fingerprint: 7c:7f:65:31:0c:81:df:8d:ba:3e:99:e2:5c:ad:6e:fb +# SHA1 Fingerprint: f5:17:a2:4f:9a:48:c6:c9:f8:a2:00:26:9f:dc:0f:48:2c:ab:30:89 +# SHA256 Fingerprint: 7e:37:cb:8b:4c:47:09:0c:ab:36:55:1b:a6:f4:5d:b8:40:68:0f:ba:16:6a:95:2d:b1:00:71:7f:43:05:3f:c2 +-----BEGIN CERTIFICATE----- +MIICRjCCAc2gAwIBAgIQC6Fa+h3foLVJRK/NJKBs7DAKBggqhkjOPQQDAzBlMQsw +CQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cu +ZGlnaWNlcnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3Qg +RzMwHhcNMTMwODAxMTIwMDAwWhcNMzgwMTE1MTIwMDAwWjBlMQswCQYDVQQGEwJV +UzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQu +Y29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgRzMwdjAQBgcq +hkjOPQIBBgUrgQQAIgNiAAQZ57ysRGXtzbg/WPuNsVepRC0FFfLvC/8QdJ+1YlJf +Zn4f5dwbRXkLzMZTCp2NXQLZqVneAlr2lSoOjThKiknGvMYDOAdfVdp+CW7if17Q +RSAPWXYQ1qAk8C3eNvJsKTmjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/ +BAQDAgGGMB0GA1UdDgQWBBTL0L2p4ZgFUaFNN6KDec6NHSrkhDAKBggqhkjOPQQD +AwNnADBkAjAlpIFFAmsSS3V0T8gj43DydXLefInwz5FyYZ5eEJJZVrmDxxDnOOlY +JjZ91eQ0hjkCMHw2U/Aw5WJjOpnitqM7mzT6HtoQknFekROn3aRukswy1vUhZscv +6pZjamVFkpUBtA== +-----END CERTIFICATE----- + +# Issuer: CN=DigiCert Global Root G2 O=DigiCert Inc OU=www.digicert.com +# Subject: CN=DigiCert Global Root G2 O=DigiCert Inc OU=www.digicert.com +# Label: "DigiCert Global Root G2" +# Serial: 4293743540046975378534879503202253541 +# MD5 Fingerprint: e4:a6:8a:c8:54:ac:52:42:46:0a:fd:72:48:1b:2a:44 +# SHA1 Fingerprint: df:3c:24:f9:bf:d6:66:76:1b:26:80:73:fe:06:d1:cc:8d:4f:82:a4 +# SHA256 Fingerprint: cb:3c:cb:b7:60:31:e5:e0:13:8f:8d:d3:9a:23:f9:de:47:ff:c3:5e:43:c1:14:4c:ea:27:d4:6a:5a:b1:cb:5f +-----BEGIN CERTIFICATE----- +MIIDjjCCAnagAwIBAgIQAzrx5qcRqaC7KGSxHQn65TANBgkqhkiG9w0BAQsFADBh +MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 +d3cuZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBH +MjAeFw0xMzA4MDExMjAwMDBaFw0zODAxMTUxMjAwMDBaMGExCzAJBgNVBAYTAlVT +MRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5j +b20xIDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IEcyMIIBIjANBgkqhkiG +9w0BAQEFAAOCAQ8AMIIBCgKCAQEAuzfNNNx7a8myaJCtSnX/RrohCgiN9RlUyfuI +2/Ou8jqJkTx65qsGGmvPrC3oXgkkRLpimn7Wo6h+4FR1IAWsULecYxpsMNzaHxmx +1x7e/dfgy5SDN67sH0NO3Xss0r0upS/kqbitOtSZpLYl6ZtrAGCSYP9PIUkY92eQ +q2EGnI/yuum06ZIya7XzV+hdG82MHauVBJVJ8zUtluNJbd134/tJS7SsVQepj5Wz +tCO7TG1F8PapspUwtP1MVYwnSlcUfIKdzXOS0xZKBgyMUNGPHgm+F6HmIcr9g+UQ +vIOlCsRnKPZzFBQ9RnbDhxSJITRNrw9FDKZJobq7nMWxM4MphQIDAQABo0IwQDAP +BgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBhjAdBgNVHQ4EFgQUTiJUIBiV +5uNu5g/6+rkS7QYXjzkwDQYJKoZIhvcNAQELBQADggEBAGBnKJRvDkhj6zHd6mcY +1Yl9PMWLSn/pvtsrF9+wX3N3KjITOYFnQoQj8kVnNeyIv/iPsGEMNKSuIEyExtv4 +NeF22d+mQrvHRAiGfzZ0JFrabA0UWTW98kndth/Jsw1HKj2ZL7tcu7XUIOGZX1NG +Fdtom/DzMNU+MeKNhJ7jitralj41E6Vf8PlwUHBHQRFXGU7Aj64GxJUTFy8bJZ91 +8rGOmaFvE7FBcf6IKshPECBV1/MUReXgRPTqh5Uykw7+U0b6LJ3/iyK5S9kJRaTe +pLiaWN0bfVKfjllDiIGknibVb63dDcY3fe0Dkhvld1927jyNxF1WW6LZZm6zNTfl +MrY= +-----END CERTIFICATE----- + +# Issuer: CN=DigiCert Global Root G3 O=DigiCert Inc OU=www.digicert.com +# Subject: CN=DigiCert Global Root G3 O=DigiCert Inc OU=www.digicert.com +# Label: "DigiCert Global Root G3" +# Serial: 7089244469030293291760083333884364146 +# MD5 Fingerprint: f5:5d:a4:50:a5:fb:28:7e:1e:0f:0d:cc:96:57:56:ca +# SHA1 Fingerprint: 7e:04:de:89:6a:3e:66:6d:00:e6:87:d3:3f:fa:d9:3b:e8:3d:34:9e +# SHA256 Fingerprint: 31:ad:66:48:f8:10:41:38:c7:38:f3:9e:a4:32:01:33:39:3e:3a:18:cc:02:29:6e:f9:7c:2a:c9:ef:67:31:d0 +-----BEGIN CERTIFICATE----- +MIICPzCCAcWgAwIBAgIQBVVWvPJepDU1w6QP1atFcjAKBggqhkjOPQQDAzBhMQsw +CQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cu +ZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBHMzAe +Fw0xMzA4MDExMjAwMDBaFw0zODAxMTUxMjAwMDBaMGExCzAJBgNVBAYTAlVTMRUw +EwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20x +IDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IEczMHYwEAYHKoZIzj0CAQYF +K4EEACIDYgAE3afZu4q4C/sLfyHS8L6+c/MzXRq8NOrexpu80JX28MzQC7phW1FG +fp4tn+6OYwwX7Adw9c+ELkCDnOg/QW07rdOkFFk2eJ0DQ+4QE2xy3q6Ip6FrtUPO +Z9wj/wMco+I+o0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBhjAd +BgNVHQ4EFgQUs9tIpPmhxdiuNkHMEWNpYim8S8YwCgYIKoZIzj0EAwMDaAAwZQIx +AK288mw/EkrRLTnDCgmXc/SINoyIJ7vmiI1Qhadj+Z4y3maTD/HMsQmP3Wyr+mt/ +oAIwOWZbwmSNuJ5Q3KjVSaLtx9zRSX8XAbjIho9OjIgrqJqpisXRAL34VOKa5Vt8 +sycX +-----END CERTIFICATE----- + +# Issuer: CN=DigiCert Trusted Root G4 O=DigiCert Inc OU=www.digicert.com +# Subject: CN=DigiCert Trusted Root G4 O=DigiCert Inc OU=www.digicert.com +# Label: "DigiCert Trusted Root G4" +# Serial: 7451500558977370777930084869016614236 +# MD5 Fingerprint: 78:f2:fc:aa:60:1f:2f:b4:eb:c9:37:ba:53:2e:75:49 +# SHA1 Fingerprint: dd:fb:16:cd:49:31:c9:73:a2:03:7d:3f:c8:3a:4d:7d:77:5d:05:e4 +# SHA256 Fingerprint: 55:2f:7b:dc:f1:a7:af:9e:6c:e6:72:01:7f:4f:12:ab:f7:72:40:c7:8e:76:1a:c2:03:d1:d9:d2:0a:c8:99:88 +-----BEGIN CERTIFICATE----- +MIIFkDCCA3igAwIBAgIQBZsbV56OITLiOQe9p3d1XDANBgkqhkiG9w0BAQwFADBi +MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 +d3cuZGlnaWNlcnQuY29tMSEwHwYDVQQDExhEaWdpQ2VydCBUcnVzdGVkIFJvb3Qg +RzQwHhcNMTMwODAxMTIwMDAwWhcNMzgwMTE1MTIwMDAwWjBiMQswCQYDVQQGEwJV +UzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQu +Y29tMSEwHwYDVQQDExhEaWdpQ2VydCBUcnVzdGVkIFJvb3QgRzQwggIiMA0GCSqG +SIb3DQEBAQUAA4ICDwAwggIKAoICAQC/5pBzaN675F1KPDAiMGkz7MKnJS7JIT3y +ithZwuEppz1Yq3aaza57G4QNxDAf8xukOBbrVsaXbR2rsnnyyhHS5F/WBTxSD1If +xp4VpX6+n6lXFllVcq9ok3DCsrp1mWpzMpTREEQQLt+C8weE5nQ7bXHiLQwb7iDV +ySAdYyktzuxeTsiT+CFhmzTrBcZe7FsavOvJz82sNEBfsXpm7nfISKhmV1efVFiO +DCu3T6cw2Vbuyntd463JT17lNecxy9qTXtyOj4DatpGYQJB5w3jHtrHEtWoYOAMQ +jdjUN6QuBX2I9YI+EJFwq1WCQTLX2wRzKm6RAXwhTNS8rhsDdV14Ztk6MUSaM0C/ +CNdaSaTC5qmgZ92kJ7yhTzm1EVgX9yRcRo9k98FpiHaYdj1ZXUJ2h4mXaXpI8OCi +EhtmmnTK3kse5w5jrubU75KSOp493ADkRSWJtppEGSt+wJS00mFt6zPZxd9LBADM +fRyVw4/3IbKyEbe7f/LVjHAsQWCqsWMYRJUadmJ+9oCw++hkpjPRiQfhvbfmQ6QY +uKZ3AeEPlAwhHbJUKSWJbOUOUlFHdL4mrLZBdd56rF+NP8m800ERElvlEFDrMcXK +chYiCd98THU/Y+whX8QgUWtvsauGi0/C1kVfnSD8oR7FwI+isX4KJpn15GkvmB0t +9dmpsh3lGwIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIB +hjAdBgNVHQ4EFgQU7NfjgtJxXWRM3y5nP+e6mK4cD08wDQYJKoZIhvcNAQEMBQAD +ggIBALth2X2pbL4XxJEbw6GiAI3jZGgPVs93rnD5/ZpKmbnJeFwMDF/k5hQpVgs2 +SV1EY+CtnJYYZhsjDT156W1r1lT40jzBQ0CuHVD1UvyQO7uYmWlrx8GnqGikJ9yd ++SeuMIW59mdNOj6PWTkiU0TryF0Dyu1Qen1iIQqAyHNm0aAFYF/opbSnr6j3bTWc +fFqK1qI4mfN4i/RN0iAL3gTujJtHgXINwBQy7zBZLq7gcfJW5GqXb5JQbZaNaHqa +sjYUegbyJLkJEVDXCLG4iXqEI2FCKeWjzaIgQdfRnGTZ6iahixTXTBmyUEFxPT9N +cCOGDErcgdLMMpSEDQgJlxxPwO5rIHQw0uA5NBCFIRUBCOhVMt5xSdkoF1BN5r5N +0XWs0Mr7QbhDparTwwVETyw2m+L64kW4I1NsBm9nVX9GtUw/bihaeSbSpKhil9Ie +4u1Ki7wb/UdKDd9nZn6yW0HQO+T0O/QEY+nvwlQAUaCKKsnOeMzV6ocEGLPOr0mI +r/OSmbaz5mEP0oUA51Aa5BuVnRmhuZyxm7EAHu/QD09CbMkKvO5D+jpxpchNJqU1 +/YldvIViHTLSoCtU7ZpXwdv6EM8Zt4tKG48BtieVU+i2iW1bvGjUI+iLUaJW+fCm +gKDWHrO8Dw9TdSmq6hN35N6MgSGtBxBHEa2HPQfRdbzP82Z+ +-----END CERTIFICATE----- + +# Issuer: CN=COMODO RSA Certification Authority O=COMODO CA Limited +# Subject: CN=COMODO RSA Certification Authority O=COMODO CA Limited +# Label: "COMODO RSA Certification Authority" +# Serial: 101909084537582093308941363524873193117 +# MD5 Fingerprint: 1b:31:b0:71:40:36:cc:14:36:91:ad:c4:3e:fd:ec:18 +# SHA1 Fingerprint: af:e5:d2:44:a8:d1:19:42:30:ff:47:9f:e2:f8:97:bb:cd:7a:8c:b4 +# SHA256 Fingerprint: 52:f0:e1:c4:e5:8e:c6:29:29:1b:60:31:7f:07:46:71:b8:5d:7e:a8:0d:5b:07:27:34:63:53:4b:32:b4:02:34 +-----BEGIN CERTIFICATE----- +MIIF2DCCA8CgAwIBAgIQTKr5yttjb+Af907YWwOGnTANBgkqhkiG9w0BAQwFADCB +hTELMAkGA1UEBhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4G +A1UEBxMHU2FsZm9yZDEaMBgGA1UEChMRQ09NT0RPIENBIExpbWl0ZWQxKzApBgNV +BAMTIkNPTU9ETyBSU0EgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMTAwMTE5 +MDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBhTELMAkGA1UEBhMCR0IxGzAZBgNVBAgT +EkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UEChMR +Q09NT0RPIENBIExpbWl0ZWQxKzApBgNVBAMTIkNPTU9ETyBSU0EgQ2VydGlmaWNh +dGlvbiBBdXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCR +6FSS0gpWsawNJN3Fz0RndJkrN6N9I3AAcbxT38T6KhKPS38QVr2fcHK3YX/JSw8X +pz3jsARh7v8Rl8f0hj4K+j5c+ZPmNHrZFGvnnLOFoIJ6dq9xkNfs/Q36nGz637CC +9BR++b7Epi9Pf5l/tfxnQ3K9DADWietrLNPtj5gcFKt+5eNu/Nio5JIk2kNrYrhV +/erBvGy2i/MOjZrkm2xpmfh4SDBF1a3hDTxFYPwyllEnvGfDyi62a+pGx8cgoLEf +Zd5ICLqkTqnyg0Y3hOvozIFIQ2dOciqbXL1MGyiKXCJ7tKuY2e7gUYPDCUZObT6Z ++pUX2nwzV0E8jVHtC7ZcryxjGt9XyD+86V3Em69FmeKjWiS0uqlWPc9vqv9JWL7w +qP/0uK3pN/u6uPQLOvnoQ0IeidiEyxPx2bvhiWC4jChWrBQdnArncevPDt09qZah +SL0896+1DSJMwBGB7FY79tOi4lu3sgQiUpWAk2nojkxl8ZEDLXB0AuqLZxUpaVIC +u9ffUGpVRr+goyhhf3DQw6KqLCGqR84onAZFdr+CGCe01a60y1Dma/RMhnEw6abf +Fobg2P9A3fvQQoh/ozM6LlweQRGBY84YcWsr7KaKtzFcOmpH4MN5WdYgGq/yapiq +crxXStJLnbsQ/LBMQeXtHT1eKJ2czL+zUdqnR+WEUwIDAQABo0IwQDAdBgNVHQ4E +FgQUu69+Aj36pvE8hI6t7jiY7NkyMtQwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB +/wQFMAMBAf8wDQYJKoZIhvcNAQEMBQADggIBAArx1UaEt65Ru2yyTUEUAJNMnMvl +wFTPoCWOAvn9sKIN9SCYPBMtrFaisNZ+EZLpLrqeLppysb0ZRGxhNaKatBYSaVqM +4dc+pBroLwP0rmEdEBsqpIt6xf4FpuHA1sj+nq6PK7o9mfjYcwlYRm6mnPTXJ9OV +2jeDchzTc+CiR5kDOF3VSXkAKRzH7JsgHAckaVd4sjn8OoSgtZx8jb8uk2Intzna +FxiuvTwJaP+EmzzV1gsD41eeFPfR60/IvYcjt7ZJQ3mFXLrrkguhxuhoqEwWsRqZ +CuhTLJK7oQkYdQxlqHvLI7cawiiFwxv/0Cti76R7CZGYZ4wUAc1oBmpjIXUDgIiK +boHGhfKppC3n9KUkEEeDys30jXlYsQab5xoq2Z0B15R97QNKyvDb6KkBPvVWmcke +jkk9u+UJueBPSZI9FoJAzMxZxuY67RIuaTxslbH9qh17f4a+Hg4yRvv7E491f0yL +S0Zj/gA0QHDBw7mh3aZw4gSzQbzpgJHqZJx64SIDqZxubw5lT2yHh17zbqD5daWb +QOhTsiedSrnAdyGN/4fy3ryM7xfft0kL0fJuMAsaDk527RH89elWsn2/x20Kk4yl +0MC2Hb46TpSi125sC8KKfPog88Tk5c0NqMuRkrF8hey1FGlmDoLnzc7ILaZRfyHB +NVOFBkpdn627G190 +-----END CERTIFICATE----- + +# Issuer: CN=USERTrust RSA Certification Authority O=The USERTRUST Network +# Subject: CN=USERTrust RSA Certification Authority O=The USERTRUST Network +# Label: "USERTrust RSA Certification Authority" +# Serial: 2645093764781058787591871645665788717 +# MD5 Fingerprint: 1b:fe:69:d1:91:b7:19:33:a3:72:a8:0f:e1:55:e5:b5 +# SHA1 Fingerprint: 2b:8f:1b:57:33:0d:bb:a2:d0:7a:6c:51:f7:0e:e9:0d:da:b9:ad:8e +# SHA256 Fingerprint: e7:93:c9:b0:2f:d8:aa:13:e2:1c:31:22:8a:cc:b0:81:19:64:3b:74:9c:89:89:64:b1:74:6d:46:c3:d4:cb:d2 +-----BEGIN CERTIFICATE----- +MIIF3jCCA8agAwIBAgIQAf1tMPyjylGoG7xkDjUDLTANBgkqhkiG9w0BAQwFADCB +iDELMAkGA1UEBhMCVVMxEzARBgNVBAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0pl +cnNleSBDaXR5MR4wHAYDVQQKExVUaGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNV +BAMTJVVTRVJUcnVzdCBSU0EgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMTAw +MjAxMDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBiDELMAkGA1UEBhMCVVMxEzARBgNV +BAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNleSBDaXR5MR4wHAYDVQQKExVU +aGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMTJVVTRVJUcnVzdCBSU0EgQ2Vy +dGlmaWNhdGlvbiBBdXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIK +AoICAQCAEmUXNg7D2wiz0KxXDXbtzSfTTK1Qg2HiqiBNCS1kCdzOiZ/MPans9s/B +3PHTsdZ7NygRK0faOca8Ohm0X6a9fZ2jY0K2dvKpOyuR+OJv0OwWIJAJPuLodMkY +tJHUYmTbf6MG8YgYapAiPLz+E/CHFHv25B+O1ORRxhFnRghRy4YUVD+8M/5+bJz/ +Fp0YvVGONaanZshyZ9shZrHUm3gDwFA66Mzw3LyeTP6vBZY1H1dat//O+T23LLb2 +VN3I5xI6Ta5MirdcmrS3ID3KfyI0rn47aGYBROcBTkZTmzNg95S+UzeQc0PzMsNT +79uq/nROacdrjGCT3sTHDN/hMq7MkztReJVni+49Vv4M0GkPGw/zJSZrM233bkf6 +c0Plfg6lZrEpfDKEY1WJxA3Bk1QwGROs0303p+tdOmw1XNtB1xLaqUkL39iAigmT +Yo61Zs8liM2EuLE/pDkP2QKe6xJMlXzzawWpXhaDzLhn4ugTncxbgtNMs+1b/97l +c6wjOy0AvzVVdAlJ2ElYGn+SNuZRkg7zJn0cTRe8yexDJtC/QV9AqURE9JnnV4ee +UB9XVKg+/XRjL7FQZQnmWEIuQxpMtPAlR1n6BB6T1CZGSlCBst6+eLf8ZxXhyVeE +Hg9j1uliutZfVS7qXMYoCAQlObgOK6nyTJccBz8NUvXt7y+CDwIDAQABo0IwQDAd +BgNVHQ4EFgQUU3m/WqorSs9UgOHYm8Cd8rIDZsswDgYDVR0PAQH/BAQDAgEGMA8G +A1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEMBQADggIBAFzUfA3P9wF9QZllDHPF +Up/L+M+ZBn8b2kMVn54CVVeWFPFSPCeHlCjtHzoBN6J2/FNQwISbxmtOuowhT6KO +VWKR82kV2LyI48SqC/3vqOlLVSoGIG1VeCkZ7l8wXEskEVX/JJpuXior7gtNn3/3 +ATiUFJVDBwn7YKnuHKsSjKCaXqeYalltiz8I+8jRRa8YFWSQEg9zKC7F4iRO/Fjs +8PRF/iKz6y+O0tlFYQXBl2+odnKPi4w2r78NBc5xjeambx9spnFixdjQg3IM8WcR +iQycE0xyNN+81XHfqnHd4blsjDwSXWXavVcStkNr/+XeTWYRUc+ZruwXtuhxkYze +Sf7dNXGiFSeUHM9h4ya7b6NnJSFd5t0dCy5oGzuCr+yDZ4XUmFF0sbmZgIn/f3gZ +XHlKYC6SQK5MNyosycdiyA5d9zZbyuAlJQG03RoHnHcAP9Dc1ew91Pq7P8yF1m9/ +qS3fuQL39ZeatTXaw2ewh0qpKJ4jjv9cJ2vhsE/zB+4ALtRZh8tSQZXq9EfX7mRB +VXyNWQKV3WKdwrnuWih0hKWbt5DHDAff9Yk2dDLWKMGwsAvgnEzDHNb842m1R0aB +L6KCq9NjRHDEjf8tM7qtj3u1cIiuPhnPQCjY/MiQu12ZIvVS5ljFH4gxQ+6IHdfG +jjxDah2nGN59PRbxYvnKkKj9 +-----END CERTIFICATE----- + +# Issuer: CN=USERTrust ECC Certification Authority O=The USERTRUST Network +# Subject: CN=USERTrust ECC Certification Authority O=The USERTRUST Network +# Label: "USERTrust ECC Certification Authority" +# Serial: 123013823720199481456569720443997572134 +# MD5 Fingerprint: fa:68:bc:d9:b5:7f:ad:fd:c9:1d:06:83:28:cc:24:c1 +# SHA1 Fingerprint: d1:cb:ca:5d:b2:d5:2a:7f:69:3b:67:4d:e5:f0:5a:1d:0c:95:7d:f0 +# SHA256 Fingerprint: 4f:f4:60:d5:4b:9c:86:da:bf:bc:fc:57:12:e0:40:0d:2b:ed:3f:bc:4d:4f:bd:aa:86:e0:6a:dc:d2:a9:ad:7a +-----BEGIN CERTIFICATE----- +MIICjzCCAhWgAwIBAgIQXIuZxVqUxdJxVt7NiYDMJjAKBggqhkjOPQQDAzCBiDEL +MAkGA1UEBhMCVVMxEzARBgNVBAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNl +eSBDaXR5MR4wHAYDVQQKExVUaGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMT +JVVTRVJUcnVzdCBFQ0MgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMTAwMjAx +MDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBiDELMAkGA1UEBhMCVVMxEzARBgNVBAgT +Ck5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNleSBDaXR5MR4wHAYDVQQKExVUaGUg +VVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMTJVVTRVJUcnVzdCBFQ0MgQ2VydGlm +aWNhdGlvbiBBdXRob3JpdHkwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQarFRaqflo +I+d61SRvU8Za2EurxtW20eZzca7dnNYMYf3boIkDuAUU7FfO7l0/4iGzzvfUinng +o4N+LZfQYcTxmdwlkWOrfzCjtHDix6EznPO/LlxTsV+zfTJ/ijTjeXmjQjBAMB0G +A1UdDgQWBBQ64QmG1M8ZwpZ2dEl23OA1xmNjmjAOBgNVHQ8BAf8EBAMCAQYwDwYD +VR0TAQH/BAUwAwEB/zAKBggqhkjOPQQDAwNoADBlAjA2Z6EWCNzklwBBHU6+4WMB +zzuqQhFkoJ2UOQIReVx7Hfpkue4WQrO/isIJxOzksU0CMQDpKmFHjFJKS04YcPbW +RNZu9YO6bVi9JNlWSOrvxKJGgYhqOkbRqZtNyWHa0V1Xahg= +-----END CERTIFICATE----- + +# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R4 +# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R4 +# Label: "GlobalSign ECC Root CA - R4" +# Serial: 14367148294922964480859022125800977897474 +# MD5 Fingerprint: 20:f0:27:68:d1:7e:a0:9d:0e:e6:2a:ca:df:5c:89:8e +# SHA1 Fingerprint: 69:69:56:2e:40:80:f4:24:a1:e7:19:9f:14:ba:f3:ee:58:ab:6a:bb +# SHA256 Fingerprint: be:c9:49:11:c2:95:56:76:db:6c:0a:55:09:86:d7:6e:3b:a0:05:66:7c:44:2c:97:62:b4:fb:b7:73:de:22:8c +-----BEGIN CERTIFICATE----- +MIIB4TCCAYegAwIBAgIRKjikHJYKBN5CsiilC+g0mAIwCgYIKoZIzj0EAwIwUDEk +MCIGA1UECxMbR2xvYmFsU2lnbiBFQ0MgUm9vdCBDQSAtIFI0MRMwEQYDVQQKEwpH +bG9iYWxTaWduMRMwEQYDVQQDEwpHbG9iYWxTaWduMB4XDTEyMTExMzAwMDAwMFoX +DTM4MDExOTAzMTQwN1owUDEkMCIGA1UECxMbR2xvYmFsU2lnbiBFQ0MgUm9vdCBD +QSAtIFI0MRMwEQYDVQQKEwpHbG9iYWxTaWduMRMwEQYDVQQDEwpHbG9iYWxTaWdu +MFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEuMZ5049sJQ6fLjkZHAOkrprlOQcJ +FspjsbmG+IpXwVfOQvpzofdlQv8ewQCybnMO/8ch5RikqtlxP6jUuc6MHaNCMEAw +DgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFFSwe61F +uOJAf/sKbvu+M8k8o4TVMAoGCCqGSM49BAMCA0gAMEUCIQDckqGgE6bPA7DmxCGX +kPoUVy0D7O48027KqGx2vKLeuwIgJ6iFJzWbVsaj8kfSt24bAgAXqmemFZHe+pTs +ewv4n4Q= +-----END CERTIFICATE----- + +# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R5 +# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R5 +# Label: "GlobalSign ECC Root CA - R5" +# Serial: 32785792099990507226680698011560947931244 +# MD5 Fingerprint: 9f:ad:3b:1c:02:1e:8a:ba:17:74:38:81:0c:a2:bc:08 +# SHA1 Fingerprint: 1f:24:c6:30:cd:a4:18:ef:20:69:ff:ad:4f:dd:5f:46:3a:1b:69:aa +# SHA256 Fingerprint: 17:9f:bc:14:8a:3d:d0:0f:d2:4e:a1:34:58:cc:43:bf:a7:f5:9c:81:82:d7:83:a5:13:f6:eb:ec:10:0c:89:24 +-----BEGIN CERTIFICATE----- +MIICHjCCAaSgAwIBAgIRYFlJ4CYuu1X5CneKcflK2GwwCgYIKoZIzj0EAwMwUDEk +MCIGA1UECxMbR2xvYmFsU2lnbiBFQ0MgUm9vdCBDQSAtIFI1MRMwEQYDVQQKEwpH +bG9iYWxTaWduMRMwEQYDVQQDEwpHbG9iYWxTaWduMB4XDTEyMTExMzAwMDAwMFoX +DTM4MDExOTAzMTQwN1owUDEkMCIGA1UECxMbR2xvYmFsU2lnbiBFQ0MgUm9vdCBD +QSAtIFI1MRMwEQYDVQQKEwpHbG9iYWxTaWduMRMwEQYDVQQDEwpHbG9iYWxTaWdu +MHYwEAYHKoZIzj0CAQYFK4EEACIDYgAER0UOlvt9Xb/pOdEh+J8LttV7HpI6SFkc +8GIxLcB6KP4ap1yztsyX50XUWPrRd21DosCHZTQKH3rd6zwzocWdTaRvQZU4f8ke +hOvRnkmSh5SHDDqFSmafnVmTTZdhBoZKo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYD +VR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUPeYpSJvqB8ohREom3m7e0oPQn1kwCgYI +KoZIzj0EAwMDaAAwZQIxAOVpEslu28YxuglB4Zf4+/2a4n0Sye18ZNPLBSWLVtmg +515dTguDnFt2KaAJJiFqYgIwcdK1j1zqO+F4CYWodZI7yFz9SO8NdCKoCOJuxUnO +xwy8p2Fp8fc74SrL+SvzZpA3 +-----END CERTIFICATE----- + +# Issuer: CN=Staat der Nederlanden Root CA - G3 O=Staat der Nederlanden +# Subject: CN=Staat der Nederlanden Root CA - G3 O=Staat der Nederlanden +# Label: "Staat der Nederlanden Root CA - G3" +# Serial: 10003001 +# MD5 Fingerprint: 0b:46:67:07:db:10:2f:19:8c:35:50:60:d1:0b:f4:37 +# SHA1 Fingerprint: d8:eb:6b:41:51:92:59:e0:f3:e7:85:00:c0:3d:b6:88:97:c9:ee:fc +# SHA256 Fingerprint: 3c:4f:b0:b9:5a:b8:b3:00:32:f4:32:b8:6f:53:5f:e1:72:c1:85:d0:fd:39:86:58:37:cf:36:18:7f:a6:f4:28 +-----BEGIN CERTIFICATE----- +MIIFdDCCA1ygAwIBAgIEAJiiOTANBgkqhkiG9w0BAQsFADBaMQswCQYDVQQGEwJO +TDEeMBwGA1UECgwVU3RhYXQgZGVyIE5lZGVybGFuZGVuMSswKQYDVQQDDCJTdGFh +dCBkZXIgTmVkZXJsYW5kZW4gUm9vdCBDQSAtIEczMB4XDTEzMTExNDExMjg0MloX +DTI4MTExMzIzMDAwMFowWjELMAkGA1UEBhMCTkwxHjAcBgNVBAoMFVN0YWF0IGRl +ciBOZWRlcmxhbmRlbjErMCkGA1UEAwwiU3RhYXQgZGVyIE5lZGVybGFuZGVuIFJv +b3QgQ0EgLSBHMzCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL4yolQP +cPssXFnrbMSkUeiFKrPMSjTysF/zDsccPVMeiAho2G89rcKezIJnByeHaHE6n3WW +IkYFsO2tx1ueKt6c/DrGlaf1F2cY5y9JCAxcz+bMNO14+1Cx3Gsy8KL+tjzk7FqX +xz8ecAgwoNzFs21v0IJyEavSgWhZghe3eJJg+szeP4TrjTgzkApyI/o1zCZxMdFy +KJLZWyNtZrVtB0LrpjPOktvA9mxjeM3KTj215VKb8b475lRgsGYeCasH/lSJEULR +9yS6YHgamPfJEf0WwTUaVHXvQ9Plrk7O53vDxk5hUUurmkVLoR9BvUhTFXFkC4az +5S6+zqQbwSmEorXLCCN2QyIkHxcE1G6cxvx/K2Ya7Irl1s9N9WMJtxU51nus6+N8 +6U78dULI7ViVDAZCopz35HCz33JvWjdAidiFpNfxC95DGdRKWCyMijmev4SH8RY7 +Ngzp07TKbBlBUgmhHbBqv4LvcFEhMtwFdozL92TkA1CvjJFnq8Xy7ljY3r735zHP +bMk7ccHViLVlvMDoFxcHErVc0qsgk7TmgoNwNsXNo42ti+yjwUOH5kPiNL6VizXt +BznaqB16nzaeErAMZRKQFWDZJkBE41ZgpRDUajz9QdwOWke275dhdU/Z/seyHdTt +XUmzqWrLZoQT1Vyg3N9udwbRcXXIV2+vD3dbAgMBAAGjQjBAMA8GA1UdEwEB/wQF +MAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBRUrfrHkleuyjWcLhL75Lpd +INyUVzANBgkqhkiG9w0BAQsFAAOCAgEAMJmdBTLIXg47mAE6iqTnB/d6+Oea31BD +U5cqPco8R5gu4RV78ZLzYdqQJRZlwJ9UXQ4DO1t3ApyEtg2YXzTdO2PCwyiBwpwp +LiniyMMB8jPqKqrMCQj3ZWfGzd/TtiunvczRDnBfuCPRy5FOCvTIeuXZYzbB1N/8 +Ipf3YF3qKS9Ysr1YvY2WTxB1v0h7PVGHoTx0IsL8B3+A3MSs/mrBcDCw6Y5p4ixp +gZQJut3+TcCDjJRYwEYgr5wfAvg1VUkvRtTA8KCWAg8zxXHzniN9lLf9OtMJgwYh +/WA9rjLA0u6NpvDntIJ8CsxwyXmA+P5M9zWEGYox+wrZ13+b8KKaa8MFSu1BYBQw +0aoRQm7TIwIEC8Zl3d1Sd9qBa7Ko+gE4uZbqKmxnl4mUnrzhVNXkanjvSr0rmj1A +fsbAddJu+2gw7OyLnflJNZoaLNmzlTnVHpL3prllL+U9bTpITAjc5CgSKL59NVzq +4BZ+Extq1z7XnvwtdbLBFNUjA9tbbws+eC8N3jONFrdI54OagQ97wUNNVQQXOEpR +1VmiiXTTn74eS9fGbbeIJG9gkaSChVtWQbzQRKtqE77RLFi3EjNYsjdj3BP1lB0/ +QFH1T/U67cjF68IeHRaVesd+QnGTbksVtzDfqu1XhUisHWrdOWnk4Xl4vs4Fv6EM +94B7IWcnMFk= +-----END CERTIFICATE----- + +# Issuer: CN=Staat der Nederlanden EV Root CA O=Staat der Nederlanden +# Subject: CN=Staat der Nederlanden EV Root CA O=Staat der Nederlanden +# Label: "Staat der Nederlanden EV Root CA" +# Serial: 10000013 +# MD5 Fingerprint: fc:06:af:7b:e8:1a:f1:9a:b4:e8:d2:70:1f:c0:f5:ba +# SHA1 Fingerprint: 76:e2:7e:c1:4f:db:82:c1:c0:a6:75:b5:05:be:3d:29:b4:ed:db:bb +# SHA256 Fingerprint: 4d:24:91:41:4c:fe:95:67:46:ec:4c:ef:a6:cf:6f:72:e2:8a:13:29:43:2f:9d:8a:90:7a:c4:cb:5d:ad:c1:5a +-----BEGIN CERTIFICATE----- +MIIFcDCCA1igAwIBAgIEAJiWjTANBgkqhkiG9w0BAQsFADBYMQswCQYDVQQGEwJO +TDEeMBwGA1UECgwVU3RhYXQgZGVyIE5lZGVybGFuZGVuMSkwJwYDVQQDDCBTdGFh +dCBkZXIgTmVkZXJsYW5kZW4gRVYgUm9vdCBDQTAeFw0xMDEyMDgxMTE5MjlaFw0y +MjEyMDgxMTEwMjhaMFgxCzAJBgNVBAYTAk5MMR4wHAYDVQQKDBVTdGFhdCBkZXIg +TmVkZXJsYW5kZW4xKTAnBgNVBAMMIFN0YWF0IGRlciBOZWRlcmxhbmRlbiBFViBS +b290IENBMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA48d+ifkkSzrS +M4M1LGns3Amk41GoJSt5uAg94JG6hIXGhaTK5skuU6TJJB79VWZxXSzFYGgEt9nC +UiY4iKTWO0Cmws0/zZiTs1QUWJZV1VD+hq2kY39ch/aO5ieSZxeSAgMs3NZmdO3d +Z//BYY1jTw+bbRcwJu+r0h8QoPnFfxZpgQNH7R5ojXKhTbImxrpsX23Wr9GxE46p +rfNeaXUmGD5BKyF/7otdBwadQ8QpCiv8Kj6GyzyDOvnJDdrFmeK8eEEzduG/L13l +pJhQDBXd4Pqcfzho0LKmeqfRMb1+ilgnQ7O6M5HTp5gVXJrm0w912fxBmJc+qiXb +j5IusHsMX/FjqTf5m3VpTCgmJdrV8hJwRVXj33NeN/UhbJCONVrJ0yPr08C+eKxC +KFhmpUZtcALXEPlLVPxdhkqHz3/KRawRWrUgUY0viEeXOcDPusBCAUCZSCELa6fS +/ZbV0b5GnUngC6agIk440ME8MLxwjyx1zNDFjFE7PZQIZCZhfbnDZY8UnCHQqv0X +cgOPvZuM5l5Tnrmd74K74bzickFbIZTTRTeU0d8JOV3nI6qaHcptqAqGhYqCvkIH +1vI4gnPah1vlPNOePqc7nvQDs/nxfRN0Av+7oeX6AHkcpmZBiFxgV6YuCcS6/ZrP +px9Aw7vMWgpVSzs4dlG4Y4uElBbmVvMCAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB +/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFP6rAJCYniT8qcwaivsnuL8wbqg7 +MA0GCSqGSIb3DQEBCwUAA4ICAQDPdyxuVr5Os7aEAJSrR8kN0nbHhp8dB9O2tLsI +eK9p0gtJ3jPFrK3CiAJ9Brc1AsFgyb/E6JTe1NOpEyVa/m6irn0F3H3zbPB+po3u +2dfOWBfoqSmuc0iH55vKbimhZF8ZE/euBhD/UcabTVUlT5OZEAFTdfETzsemQUHS +v4ilf0X8rLiltTMMgsT7B/Zq5SWEXwbKwYY5EdtYzXc7LMJMD16a4/CrPmEbUCTC +wPTxGfARKbalGAKb12NMcIxHowNDXLldRqANb/9Zjr7dn3LDWyvfjFvO5QxGbJKy +CqNMVEIYFRIYvdr8unRu/8G2oGTYqV9Vrp9canaW2HNnh/tNf1zuacpzEPuKqf2e +vTY4SUmH9A4U8OmHuD+nT3pajnnUk+S7aFKErGzp85hwVXIy+TSrK0m1zSBi5Dp6 +Z2Orltxtrpfs/J92VoguZs9btsmksNcFuuEnL5O7Jiqik7Ab846+HUCjuTaPPoIa +Gl6I6lD4WeKDRikL40Rc4ZW2aZCaFG+XroHPaO+Zmr615+F/+PoTRxZMzG0IQOeL +eG9QgkRQP2YGiqtDhFZKDyAthg710tvSeopLzaXoTvFeJiUBWSOgftL2fiFX1ye8 +FVdMpEbB4IMeDExNH08GGeL5qPQ6gqGyeUN51q1veieQA6TqJIc/2b3Z6fJfUEkc +7uzXLg== +-----END CERTIFICATE----- + +# Issuer: CN=IdenTrust Commercial Root CA 1 O=IdenTrust +# Subject: CN=IdenTrust Commercial Root CA 1 O=IdenTrust +# Label: "IdenTrust Commercial Root CA 1" +# Serial: 13298821034946342390520003877796839426 +# MD5 Fingerprint: b3:3e:77:73:75:ee:a0:d3:e3:7e:49:63:49:59:bb:c7 +# SHA1 Fingerprint: df:71:7e:aa:4a:d9:4e:c9:55:84:99:60:2d:48:de:5f:bc:f0:3a:25 +# SHA256 Fingerprint: 5d:56:49:9b:e4:d2:e0:8b:cf:ca:d0:8a:3e:38:72:3d:50:50:3b:de:70:69:48:e4:2f:55:60:30:19:e5:28:ae +-----BEGIN CERTIFICATE----- +MIIFYDCCA0igAwIBAgIQCgFCgAAAAUUjyES1AAAAAjANBgkqhkiG9w0BAQsFADBK +MQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0MScwJQYDVQQDEx5JZGVu +VHJ1c3QgQ29tbWVyY2lhbCBSb290IENBIDEwHhcNMTQwMTE2MTgxMjIzWhcNMzQw +MTE2MTgxMjIzWjBKMQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0MScw +JQYDVQQDEx5JZGVuVHJ1c3QgQ29tbWVyY2lhbCBSb290IENBIDEwggIiMA0GCSqG +SIb3DQEBAQUAA4ICDwAwggIKAoICAQCnUBneP5k91DNG8W9RYYKyqU+PZ4ldhNlT +3Qwo2dfw/66VQ3KZ+bVdfIrBQuExUHTRgQ18zZshq0PirK1ehm7zCYofWjK9ouuU ++ehcCuz/mNKvcbO0U59Oh++SvL3sTzIwiEsXXlfEU8L2ApeN2WIrvyQfYo3fw7gp +S0l4PJNgiCL8mdo2yMKi1CxUAGc1bnO/AljwpN3lsKImesrgNqUZFvX9t++uP0D1 +bVoE/c40yiTcdCMbXTMTEl3EASX2MN0CXZ/g1Ue9tOsbobtJSdifWwLziuQkkORi +T0/Br4sOdBeo0XKIanoBScy0RnnGF7HamB4HWfp1IYVl3ZBWzvurpWCdxJ35UrCL +vYf5jysjCiN2O/cz4ckA82n5S6LgTrx+kzmEB/dEcH7+B1rlsazRGMzyNeVJSQjK +Vsk9+w8YfYs7wRPCTY/JTw436R+hDmrfYi7LNQZReSzIJTj0+kuniVyc0uMNOYZK +dHzVWYfCP04MXFL0PfdSgvHqo6z9STQaKPNBiDoT7uje/5kdX7rL6B7yuVBgwDHT +c+XvvqDtMwt0viAgxGds8AgDelWAf0ZOlqf0Hj7h9tgJ4TNkK2PXMl6f+cB7D3hv +l7yTmvmcEpB4eoCHFddydJxVdHixuuFucAS6T6C6aMN7/zHwcz09lCqxC0EOoP5N +iGVreTO01wIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB +/zAdBgNVHQ4EFgQU7UQZwNPwBovupHu+QucmVMiONnYwDQYJKoZIhvcNAQELBQAD +ggIBAA2ukDL2pkt8RHYZYR4nKM1eVO8lvOMIkPkp165oCOGUAFjvLi5+U1KMtlwH +6oi6mYtQlNeCgN9hCQCTrQ0U5s7B8jeUeLBfnLOic7iPBZM4zY0+sLj7wM+x8uwt +LRvM7Kqas6pgghstO8OEPVeKlh6cdbjTMM1gCIOQ045U8U1mwF10A0Cj7oV+wh93 +nAbowacYXVKV7cndJZ5t+qntozo00Fl72u1Q8zW/7esUTTHHYPTa8Yec4kjixsU3 ++wYQ+nVZZjFHKdp2mhzpgq7vmrlR94gjmmmVYjzlVYA211QC//G5Xc7UI2/YRYRK +W2XviQzdFKcgyxilJbQN+QHwotL0AMh0jqEqSI5l2xPE4iUXfeu+h1sXIFRRk0pT +AwvsXcoz7WL9RccvW9xYoIA55vrX/hMUpu09lEpCdNTDd1lzzY9GvlU47/rokTLq +l1gEIt44w8y8bckzOmoKaT+gyOpyj4xjhiO9bTyWnpXgSUyqorkqG5w2gXjtw+hG +4iZZRHUe2XWJUc0QhJ1hYMtd+ZciTY6Y5uN/9lu7rs3KSoFrXgvzUeF0K+l+J6fZ +mUlO+KWA2yUPHGNiiskzZ2s8EIPGrd6ozRaOjfAHN3Gf8qv8QfXBi+wAN10J5U6A +7/qxXDgGpRtK4dw4LTzcqx+QGtVKnO7RcGzM7vRX+Bi6hG6H +-----END CERTIFICATE----- + +# Issuer: CN=IdenTrust Public Sector Root CA 1 O=IdenTrust +# Subject: CN=IdenTrust Public Sector Root CA 1 O=IdenTrust +# Label: "IdenTrust Public Sector Root CA 1" +# Serial: 13298821034946342390521976156843933698 +# MD5 Fingerprint: 37:06:a5:b0:fc:89:9d:ba:f4:6b:8c:1a:64:cd:d5:ba +# SHA1 Fingerprint: ba:29:41:60:77:98:3f:f4:f3:ef:f2:31:05:3b:2e:ea:6d:4d:45:fd +# SHA256 Fingerprint: 30:d0:89:5a:9a:44:8a:26:20:91:63:55:22:d1:f5:20:10:b5:86:7a:ca:e1:2c:78:ef:95:8f:d4:f4:38:9f:2f +-----BEGIN CERTIFICATE----- +MIIFZjCCA06gAwIBAgIQCgFCgAAAAUUjz0Z8AAAAAjANBgkqhkiG9w0BAQsFADBN +MQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0MSowKAYDVQQDEyFJZGVu +VHJ1c3QgUHVibGljIFNlY3RvciBSb290IENBIDEwHhcNMTQwMTE2MTc1MzMyWhcN +MzQwMTE2MTc1MzMyWjBNMQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0 +MSowKAYDVQQDEyFJZGVuVHJ1c3QgUHVibGljIFNlY3RvciBSb290IENBIDEwggIi +MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC2IpT8pEiv6EdrCvsnduTyP4o7 +ekosMSqMjbCpwzFrqHd2hCa2rIFCDQjrVVi7evi8ZX3yoG2LqEfpYnYeEe4IFNGy +RBb06tD6Hi9e28tzQa68ALBKK0CyrOE7S8ItneShm+waOh7wCLPQ5CQ1B5+ctMlS +bdsHyo+1W/CD80/HLaXIrcuVIKQxKFdYWuSNG5qrng0M8gozOSI5Cpcu81N3uURF +/YTLNiCBWS2ab21ISGHKTN9T0a9SvESfqy9rg3LvdYDaBjMbXcjaY8ZNzaxmMc3R +3j6HEDbhuaR672BQssvKplbgN6+rNBM5Jeg5ZuSYeqoSmJxZZoY+rfGwyj4GD3vw +EUs3oERte8uojHH01bWRNszwFcYr3lEXsZdMUD2xlVl8BX0tIdUAvwFnol57plzy +9yLxkA2T26pEUWbMfXYD62qoKjgZl3YNa4ph+bz27nb9cCvdKTz4Ch5bQhyLVi9V +GxyhLrXHFub4qjySjmm2AcG1hp2JDws4lFTo6tyePSW8Uybt1as5qsVATFSrsrTZ +2fjXctscvG29ZV/viDUqZi/u9rNl8DONfJhBaUYPQxxp+pu10GFqzcpL2UyQRqsV +WaFHVCkugyhfHMKiq3IXAAaOReyL4jM9f9oZRORicsPfIsbyVtTdX5Vy7W1f90gD +W/3FKqD2cyOEEBsB5wIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/ +BAUwAwEB/zAdBgNVHQ4EFgQU43HgntinQtnbcZFrlJPrw6PRFKMwDQYJKoZIhvcN +AQELBQADggIBAEf63QqwEZE4rU1d9+UOl1QZgkiHVIyqZJnYWv6IAcVYpZmxI1Qj +t2odIFflAWJBF9MJ23XLblSQdf4an4EKwt3X9wnQW3IV5B4Jaj0z8yGa5hV+rVHV +DRDtfULAj+7AmgjVQdZcDiFpboBhDhXAuM/FSRJSzL46zNQuOAXeNf0fb7iAaJg9 +TaDKQGXSc3z1i9kKlT/YPyNtGtEqJBnZhbMX73huqVjRI9PHE+1yJX9dsXNw0H8G +lwmEKYBhHfpe/3OsoOOJuBxxFcbeMX8S3OFtm6/n6J91eEyrRjuazr8FGF1NFTwW +mhlQBJqymm9li1JfPFgEKCXAZmExfrngdbkaqIHWchezxQMxNRF4eKLg6TCMf4Df +WN88uieW4oA0beOY02QnrEh+KHdcxiVhJfiFDGX6xDIvpZgF5PgLZxYWxoK4Mhn5 ++bl53B/N66+rDt0b20XkeucC4pVd/GnwU2lhlXV5C15V5jgclKlZM57IcXR5f1GJ +tshquDDIajjDbp7hNxbqBWJMWxJH7ae0s1hWx0nzfxJoCTFx8G34Tkf71oXuxVhA +GaQdp/lLQzfcaFpPz+vCZHTetBXZ9FRUGi8c15dxVJCO2SCdUyt/q4/i6jC8UDfv +8Ue1fXwsBOxonbRJRBD0ckscZOf85muQ3Wl9af0AVqW3rLatt8o+Ae+c +-----END CERTIFICATE----- + +# Issuer: CN=Entrust Root Certification Authority - G2 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2009 Entrust, Inc. - for authorized use only +# Subject: CN=Entrust Root Certification Authority - G2 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2009 Entrust, Inc. - for authorized use only +# Label: "Entrust Root Certification Authority - G2" +# Serial: 1246989352 +# MD5 Fingerprint: 4b:e2:c9:91:96:65:0c:f4:0e:5a:93:92:a0:0a:fe:b2 +# SHA1 Fingerprint: 8c:f4:27:fd:79:0c:3a:d1:66:06:8d:e8:1e:57:ef:bb:93:22:72:d4 +# SHA256 Fingerprint: 43:df:57:74:b0:3e:7f:ef:5f:e4:0d:93:1a:7b:ed:f1:bb:2e:6b:42:73:8c:4e:6d:38:41:10:3d:3a:a7:f3:39 +-----BEGIN CERTIFICATE----- +MIIEPjCCAyagAwIBAgIESlOMKDANBgkqhkiG9w0BAQsFADCBvjELMAkGA1UEBhMC +VVMxFjAUBgNVBAoTDUVudHJ1c3QsIEluYy4xKDAmBgNVBAsTH1NlZSB3d3cuZW50 +cnVzdC5uZXQvbGVnYWwtdGVybXMxOTA3BgNVBAsTMChjKSAyMDA5IEVudHJ1c3Qs +IEluYy4gLSBmb3IgYXV0aG9yaXplZCB1c2Ugb25seTEyMDAGA1UEAxMpRW50cnVz +dCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IC0gRzIwHhcNMDkwNzA3MTcy +NTU0WhcNMzAxMjA3MTc1NTU0WjCBvjELMAkGA1UEBhMCVVMxFjAUBgNVBAoTDUVu +dHJ1c3QsIEluYy4xKDAmBgNVBAsTH1NlZSB3d3cuZW50cnVzdC5uZXQvbGVnYWwt +dGVybXMxOTA3BgNVBAsTMChjKSAyMDA5IEVudHJ1c3QsIEluYy4gLSBmb3IgYXV0 +aG9yaXplZCB1c2Ugb25seTEyMDAGA1UEAxMpRW50cnVzdCBSb290IENlcnRpZmlj +YXRpb24gQXV0aG9yaXR5IC0gRzIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEK +AoIBAQC6hLZy254Ma+KZ6TABp3bqMriVQRrJ2mFOWHLP/vaCeb9zYQYKpSfYs1/T +RU4cctZOMvJyig/3gxnQaoCAAEUesMfnmr8SVycco2gvCoe9amsOXmXzHHfV1IWN +cCG0szLni6LVhjkCsbjSR87kyUnEO6fe+1R9V77w6G7CebI6C1XiUJgWMhNcL3hW +wcKUs/Ja5CeanyTXxuzQmyWC48zCxEXFjJd6BmsqEZ+pCm5IO2/b1BEZQvePB7/1 +U1+cPvQXLOZprE4yTGJ36rfo5bs0vBmLrpxR57d+tVOxMyLlbc9wPBr64ptntoP0 +jaWvYkxN4FisZDQSA/i2jZRjJKRxAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAP +BgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBRqciZ60B7vfec7aVHUbI2fkBJmqzAN +BgkqhkiG9w0BAQsFAAOCAQEAeZ8dlsa2eT8ijYfThwMEYGprmi5ZiXMRrEPR9RP/ +jTkrwPK9T3CMqS/qF8QLVJ7UG5aYMzyorWKiAHarWWluBh1+xLlEjZivEtRh2woZ +Rkfz6/djwUAFQKXSt/S1mja/qYh2iARVBCuch38aNzx+LaUa2NSJXsq9rD1s2G2v +1fN2D807iDginWyTmsQ9v4IbZT+mD12q/OWyFcq1rca8PdCE6OoGcrBNOTJ4vz4R +nAuknZoh8/CbCzB428Hch0P+vGOaysXCHMnHjf87ElgI5rY97HosTvuDls4MPGmH +VHOkc8KT/1EQrBVUAdj8BbGJoX90g5pJ19xOe4pIb4tF9g== +-----END CERTIFICATE----- + +# Issuer: CN=Entrust Root Certification Authority - EC1 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2012 Entrust, Inc. - for authorized use only +# Subject: CN=Entrust Root Certification Authority - EC1 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2012 Entrust, Inc. - for authorized use only +# Label: "Entrust Root Certification Authority - EC1" +# Serial: 51543124481930649114116133369 +# MD5 Fingerprint: b6:7e:1d:f0:58:c5:49:6c:24:3b:3d:ed:98:18:ed:bc +# SHA1 Fingerprint: 20:d8:06:40:df:9b:25:f5:12:25:3a:11:ea:f7:59:8a:eb:14:b5:47 +# SHA256 Fingerprint: 02:ed:0e:b2:8c:14:da:45:16:5c:56:67:91:70:0d:64:51:d7:fb:56:f0:b2:ab:1d:3b:8e:b0:70:e5:6e:df:f5 +-----BEGIN CERTIFICATE----- +MIIC+TCCAoCgAwIBAgINAKaLeSkAAAAAUNCR+TAKBggqhkjOPQQDAzCBvzELMAkG +A1UEBhMCVVMxFjAUBgNVBAoTDUVudHJ1c3QsIEluYy4xKDAmBgNVBAsTH1NlZSB3 +d3cuZW50cnVzdC5uZXQvbGVnYWwtdGVybXMxOTA3BgNVBAsTMChjKSAyMDEyIEVu +dHJ1c3QsIEluYy4gLSBmb3IgYXV0aG9yaXplZCB1c2Ugb25seTEzMDEGA1UEAxMq +RW50cnVzdCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IC0gRUMxMB4XDTEy +MTIxODE1MjUzNloXDTM3MTIxODE1NTUzNlowgb8xCzAJBgNVBAYTAlVTMRYwFAYD +VQQKEw1FbnRydXN0LCBJbmMuMSgwJgYDVQQLEx9TZWUgd3d3LmVudHJ1c3QubmV0 +L2xlZ2FsLXRlcm1zMTkwNwYDVQQLEzAoYykgMjAxMiBFbnRydXN0LCBJbmMuIC0g +Zm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxMzAxBgNVBAMTKkVudHJ1c3QgUm9vdCBD +ZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIEVDMTB2MBAGByqGSM49AgEGBSuBBAAi +A2IABIQTydC6bUF74mzQ61VfZgIaJPRbiWlH47jCffHyAsWfoPZb1YsGGYZPUxBt +ByQnoaD41UcZYUx9ypMn6nQM72+WCf5j7HBdNq1nd67JnXxVRDqiY1Ef9eNi1KlH +Bz7MIKNCMEAwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0O +BBYEFLdj5xrdjekIplWDpOBqUEFlEUJJMAoGCCqGSM49BAMDA2cAMGQCMGF52OVC +R98crlOZF7ZvHH3hvxGU0QOIdeSNiaSKd0bebWHvAvX7td/M/k7//qnmpwIwW5nX +hTcGtXsI/esni0qU+eH6p44mCOh8kmhtc9hvJqwhAriZtyZBWyVgrtBIGu4G +-----END CERTIFICATE----- + +# Issuer: CN=CFCA EV ROOT O=China Financial Certification Authority +# Subject: CN=CFCA EV ROOT O=China Financial Certification Authority +# Label: "CFCA EV ROOT" +# Serial: 407555286 +# MD5 Fingerprint: 74:e1:b6:ed:26:7a:7a:44:30:33:94:ab:7b:27:81:30 +# SHA1 Fingerprint: e2:b8:29:4b:55:84:ab:6b:58:c2:90:46:6c:ac:3f:b8:39:8f:84:83 +# SHA256 Fingerprint: 5c:c3:d7:8e:4e:1d:5e:45:54:7a:04:e6:87:3e:64:f9:0c:f9:53:6d:1c:cc:2e:f8:00:f3:55:c4:c5:fd:70:fd +-----BEGIN CERTIFICATE----- +MIIFjTCCA3WgAwIBAgIEGErM1jANBgkqhkiG9w0BAQsFADBWMQswCQYDVQQGEwJD +TjEwMC4GA1UECgwnQ2hpbmEgRmluYW5jaWFsIENlcnRpZmljYXRpb24gQXV0aG9y +aXR5MRUwEwYDVQQDDAxDRkNBIEVWIFJPT1QwHhcNMTIwODA4MDMwNzAxWhcNMjkx +MjMxMDMwNzAxWjBWMQswCQYDVQQGEwJDTjEwMC4GA1UECgwnQ2hpbmEgRmluYW5j +aWFsIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MRUwEwYDVQQDDAxDRkNBIEVWIFJP +T1QwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDXXWvNED8fBVnVBU03 +sQ7smCuOFR36k0sXgiFxEFLXUWRwFsJVaU2OFW2fvwwbwuCjZ9YMrM8irq93VCpL +TIpTUnrD7i7es3ElweldPe6hL6P3KjzJIx1qqx2hp/Hz7KDVRM8Vz3IvHWOX6Jn5 +/ZOkVIBMUtRSqy5J35DNuF++P96hyk0g1CXohClTt7GIH//62pCfCqktQT+x8Rgp +7hZZLDRJGqgG16iI0gNyejLi6mhNbiyWZXvKWfry4t3uMCz7zEasxGPrb382KzRz +EpR/38wmnvFyXVBlWY9ps4deMm/DGIq1lY+wejfeWkU7xzbh72fROdOXW3NiGUgt +hxwG+3SYIElz8AXSG7Ggo7cbcNOIabla1jj0Ytwli3i/+Oh+uFzJlU9fpy25IGvP +a931DfSCt/SyZi4QKPaXWnuWFo8BGS1sbn85WAZkgwGDg8NNkt0yxoekN+kWzqot +aK8KgWU6cMGbrU1tVMoqLUuFG7OA5nBFDWteNfB/O7ic5ARwiRIlk9oKmSJgamNg +TnYGmE69g60dWIolhdLHZR4tjsbftsbhf4oEIRUpdPA+nJCdDC7xij5aqgwJHsfV +PKPtl8MeNPo4+QgO48BdK4PRVmrJtqhUUy54Mmc9gn900PvhtgVguXDbjgv5E1hv +cWAQUhC5wUEJ73IfZzF4/5YFjQIDAQABo2MwYTAfBgNVHSMEGDAWgBTj/i39KNAL +tbq2osS/BqoFjJP7LzAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAd +BgNVHQ4EFgQU4/4t/SjQC7W6tqLEvwaqBYyT+y8wDQYJKoZIhvcNAQELBQADggIB +ACXGumvrh8vegjmWPfBEp2uEcwPenStPuiB/vHiyz5ewG5zz13ku9Ui20vsXiObT +ej/tUxPQ4i9qecsAIyjmHjdXNYmEwnZPNDatZ8POQQaIxffu2Bq41gt/UP+TqhdL +jOztUmCypAbqTuv0axn96/Ua4CUqmtzHQTb3yHQFhDmVOdYLO6Qn+gjYXB74BGBS +ESgoA//vU2YApUo0FmZ8/Qmkrp5nGm9BC2sGE5uPhnEFtC+NiWYzKXZUmhH4J/qy +P5Hgzg0b8zAarb8iXRvTvyUFTeGSGn+ZnzxEk8rUQElsgIfXBDrDMlI1Dlb4pd19 +xIsNER9Tyx6yF7Zod1rg1MvIB671Oi6ON7fQAUtDKXeMOZePglr4UeWJoBjnaH9d +Ci77o0cOPaYjesYBx4/IXr9tgFa+iiS6M+qf4TIRnvHST4D2G0CvOJ4RUHlzEhLN +5mydLIhyPDCBBpEi6lmt2hkuIsKNuYyH4Ga8cyNfIWRjgEj1oDwYPZTISEEdQLpe +/v5WOaHIz16eGWRGENoXkbcFgKyLmZJ956LYBws2J+dIeWCKw9cTXPhyQN9Ky8+Z +AAoACxGV2lZFA4gKn2fQ1XmxqI1AbQ3CekD6819kR5LLU7m7Wc5P/dAVUwHY3+vZ +5nbv0CO7O6l5s9UCKc2Jo5YPSjXnTkLAdc0Hz+Ys63su +-----END CERTIFICATE----- + +# Issuer: CN=OISTE WISeKey Global Root GB CA O=WISeKey OU=OISTE Foundation Endorsed +# Subject: CN=OISTE WISeKey Global Root GB CA O=WISeKey OU=OISTE Foundation Endorsed +# Label: "OISTE WISeKey Global Root GB CA" +# Serial: 157768595616588414422159278966750757568 +# MD5 Fingerprint: a4:eb:b9:61:28:2e:b7:2f:98:b0:35:26:90:99:51:1d +# SHA1 Fingerprint: 0f:f9:40:76:18:d3:d7:6a:4b:98:f0:a8:35:9e:0c:fd:27:ac:cc:ed +# SHA256 Fingerprint: 6b:9c:08:e8:6e:b0:f7:67:cf:ad:65:cd:98:b6:21:49:e5:49:4a:67:f5:84:5e:7b:d1:ed:01:9f:27:b8:6b:d6 +-----BEGIN CERTIFICATE----- +MIIDtTCCAp2gAwIBAgIQdrEgUnTwhYdGs/gjGvbCwDANBgkqhkiG9w0BAQsFADBt +MQswCQYDVQQGEwJDSDEQMA4GA1UEChMHV0lTZUtleTEiMCAGA1UECxMZT0lTVEUg +Rm91bmRhdGlvbiBFbmRvcnNlZDEoMCYGA1UEAxMfT0lTVEUgV0lTZUtleSBHbG9i +YWwgUm9vdCBHQiBDQTAeFw0xNDEyMDExNTAwMzJaFw0zOTEyMDExNTEwMzFaMG0x +CzAJBgNVBAYTAkNIMRAwDgYDVQQKEwdXSVNlS2V5MSIwIAYDVQQLExlPSVNURSBG +b3VuZGF0aW9uIEVuZG9yc2VkMSgwJgYDVQQDEx9PSVNURSBXSVNlS2V5IEdsb2Jh +bCBSb290IEdCIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA2Be3 +HEokKtaXscriHvt9OO+Y9bI5mE4nuBFde9IllIiCFSZqGzG7qFshISvYD06fWvGx +WuR51jIjK+FTzJlFXHtPrby/h0oLS5daqPZI7H17Dc0hBt+eFf1Biki3IPShehtX +1F1Q/7pn2COZH8g/497/b1t3sWtuuMlk9+HKQUYOKXHQuSP8yYFfTvdv37+ErXNk +u7dCjmn21HYdfp2nuFeKUWdy19SouJVUQHMD9ur06/4oQnc/nSMbsrY9gBQHTC5P +99UKFg29ZkM3fiNDecNAhvVMKdqOmq0NpQSHiB6F4+lT1ZvIiwNjeOvgGUpuuy9r +M2RYk61pv48b74JIxwIDAQABo1EwTzALBgNVHQ8EBAMCAYYwDwYDVR0TAQH/BAUw +AwEB/zAdBgNVHQ4EFgQUNQ/INmNe4qPs+TtmFc5RUuORmj0wEAYJKwYBBAGCNxUB +BAMCAQAwDQYJKoZIhvcNAQELBQADggEBAEBM+4eymYGQfp3FsLAmzYh7KzKNbrgh +cViXfa43FK8+5/ea4n32cZiZBKpDdHij40lhPnOMTZTg+XHEthYOU3gf1qKHLwI5 +gSk8rxWYITD+KJAAjNHhy/peyP34EEY7onhCkRd0VQreUGdNZtGn//3ZwLWoo4rO +ZvUPQ82nK1d7Y0Zqqi5S2PTt4W2tKZB4SLrhI6qjiey1q5bAtEuiHZeeevJuQHHf +aPFlTc58Bd9TZaml8LGXBHAVRgOY1NK/VLSgWH1Sb9pWJmLU2NuJMW8c8CLC02Ic +Nc1MaRVUGpCY3useX8p3x8uOPUNpnJpY0CQ73xtAln41rYHHTnG6iBM= +-----END CERTIFICATE----- + +# Issuer: CN=SZAFIR ROOT CA2 O=Krajowa Izba Rozliczeniowa S.A. +# Subject: CN=SZAFIR ROOT CA2 O=Krajowa Izba Rozliczeniowa S.A. +# Label: "SZAFIR ROOT CA2" +# Serial: 357043034767186914217277344587386743377558296292 +# MD5 Fingerprint: 11:64:c1:89:b0:24:b1:8c:b1:07:7e:89:9e:51:9e:99 +# SHA1 Fingerprint: e2:52:fa:95:3f:ed:db:24:60:bd:6e:28:f3:9c:cc:cf:5e:b3:3f:de +# SHA256 Fingerprint: a1:33:9d:33:28:1a:0b:56:e5:57:d3:d3:2b:1c:e7:f9:36:7e:b0:94:bd:5f:a7:2a:7e:50:04:c8:de:d7:ca:fe +-----BEGIN CERTIFICATE----- +MIIDcjCCAlqgAwIBAgIUPopdB+xV0jLVt+O2XwHrLdzk1uQwDQYJKoZIhvcNAQEL +BQAwUTELMAkGA1UEBhMCUEwxKDAmBgNVBAoMH0tyYWpvd2EgSXpiYSBSb3psaWN6 +ZW5pb3dhIFMuQS4xGDAWBgNVBAMMD1NaQUZJUiBST09UIENBMjAeFw0xNTEwMTkw +NzQzMzBaFw0zNTEwMTkwNzQzMzBaMFExCzAJBgNVBAYTAlBMMSgwJgYDVQQKDB9L +cmFqb3dhIEl6YmEgUm96bGljemVuaW93YSBTLkEuMRgwFgYDVQQDDA9TWkFGSVIg +Uk9PVCBDQTIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC3vD5QqEvN +QLXOYeeWyrSh2gwisPq1e3YAd4wLz32ohswmUeQgPYUM1ljj5/QqGJ3a0a4m7utT +3PSQ1hNKDJA8w/Ta0o4NkjrcsbH/ON7Dui1fgLkCvUqdGw+0w8LBZwPd3BucPbOw +3gAeqDRHu5rr/gsUvTaE2g0gv/pby6kWIK05YO4vdbbnl5z5Pv1+TW9NL++IDWr6 +3fE9biCloBK0TXC5ztdyO4mTp4CEHCdJckm1/zuVnsHMyAHs6A6KCpbns6aH5db5 +BSsNl0BwPLqsdVqc1U2dAgrSS5tmS0YHF2Wtn2yIANwiieDhZNRnvDF5YTy7ykHN +XGoAyDw4jlivAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQD +AgEGMB0GA1UdDgQWBBQuFqlKGLXLzPVvUPMjX/hd56zwyDANBgkqhkiG9w0BAQsF +AAOCAQEAtXP4A9xZWx126aMqe5Aosk3AM0+qmrHUuOQn/6mWmc5G4G18TKI4pAZw +8PRBEew/R40/cof5O/2kbytTAOD/OblqBw7rHRz2onKQy4I9EYKL0rufKq8h5mOG +nXkZ7/e7DDWQw4rtTw/1zBLZpD67oPwglV9PJi8RI4NOdQcPv5vRtB3pEAT+ymCP +oky4rc/hkA/NrgrHXXu3UNLUYfrVFdvXn4dRVOul4+vJhaAlIDf7js4MNIThPIGy +d05DpYhfhmehPea0XGG2Ptv+tyjFogeutcrKjSoS75ftwjCkySp6+/NNIxuZMzSg +LvWpCz/UXeHPhJ/iGcJfitYgHuNztw== +-----END CERTIFICATE----- + +# Issuer: CN=Certum Trusted Network CA 2 O=Unizeto Technologies S.A. OU=Certum Certification Authority +# Subject: CN=Certum Trusted Network CA 2 O=Unizeto Technologies S.A. OU=Certum Certification Authority +# Label: "Certum Trusted Network CA 2" +# Serial: 44979900017204383099463764357512596969 +# MD5 Fingerprint: 6d:46:9e:d9:25:6d:08:23:5b:5e:74:7d:1e:27:db:f2 +# SHA1 Fingerprint: d3:dd:48:3e:2b:bf:4c:05:e8:af:10:f5:fa:76:26:cf:d3:dc:30:92 +# SHA256 Fingerprint: b6:76:f2:ed:da:e8:77:5c:d3:6c:b0:f6:3c:d1:d4:60:39:61:f4:9e:62:65:ba:01:3a:2f:03:07:b6:d0:b8:04 +-----BEGIN CERTIFICATE----- +MIIF0jCCA7qgAwIBAgIQIdbQSk8lD8kyN/yqXhKN6TANBgkqhkiG9w0BAQ0FADCB +gDELMAkGA1UEBhMCUEwxIjAgBgNVBAoTGVVuaXpldG8gVGVjaG5vbG9naWVzIFMu +QS4xJzAlBgNVBAsTHkNlcnR1bSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTEkMCIG +A1UEAxMbQ2VydHVtIFRydXN0ZWQgTmV0d29yayBDQSAyMCIYDzIwMTExMDA2MDgz +OTU2WhgPMjA0NjEwMDYwODM5NTZaMIGAMQswCQYDVQQGEwJQTDEiMCAGA1UEChMZ +VW5pemV0byBUZWNobm9sb2dpZXMgUy5BLjEnMCUGA1UECxMeQ2VydHVtIENlcnRp +ZmljYXRpb24gQXV0aG9yaXR5MSQwIgYDVQQDExtDZXJ0dW0gVHJ1c3RlZCBOZXR3 +b3JrIENBIDIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC9+Xj45tWA +DGSdhhuWZGc/IjoedQF97/tcZ4zJzFxrqZHmuULlIEub2pt7uZld2ZuAS9eEQCsn +0+i6MLs+CRqnSZXvK0AkwpfHp+6bJe+oCgCXhVqqndwpyeI1B+twTUrWwbNWuKFB +OJvR+zF/j+Bf4bE/D44WSWDXBo0Y+aomEKsq09DRZ40bRr5HMNUuctHFY9rnY3lE +fktjJImGLjQ/KUxSiyqnwOKRKIm5wFv5HdnnJ63/mgKXwcZQkpsCLL2puTRZCr+E +Sv/f/rOf69me4Jgj7KZrdxYq28ytOxykh9xGc14ZYmhFV+SQgkK7QtbwYeDBoz1m +o130GO6IyY0XRSmZMnUCMe4pJshrAua1YkV/NxVaI2iJ1D7eTiew8EAMvE0Xy02i +sx7QBlrd9pPPV3WZ9fqGGmd4s7+W/jTcvedSVuWz5XV710GRBdxdaeOVDUO5/IOW +OZV7bIBaTxNyxtd9KXpEulKkKtVBRgkg/iKgtlswjbyJDNXXcPiHUv3a76xRLgez +Tv7QCdpw75j6VuZt27VXS9zlLCUVyJ4ueE742pyehizKV/Ma5ciSixqClnrDvFAS +adgOWkaLOusm+iPJtrCBvkIApPjW/jAux9JG9uWOdf3yzLnQh1vMBhBgu4M1t15n +3kfsmUjxpKEV/q2MYo45VU85FrmxY53/twIDAQABo0IwQDAPBgNVHRMBAf8EBTAD +AQH/MB0GA1UdDgQWBBS2oVQ5AsOgP46KvPrU+Bym0ToO/TAOBgNVHQ8BAf8EBAMC +AQYwDQYJKoZIhvcNAQENBQADggIBAHGlDs7k6b8/ONWJWsQCYftMxRQXLYtPU2sQ +F/xlhMcQSZDe28cmk4gmb3DWAl45oPePq5a1pRNcgRRtDoGCERuKTsZPpd1iHkTf +CVn0W3cLN+mLIMb4Ck4uWBzrM9DPhmDJ2vuAL55MYIR4PSFk1vtBHxgP58l1cb29 +XN40hz5BsA72udY/CROWFC/emh1auVbONTqwX3BNXuMp8SMoclm2q8KMZiYcdywm +djWLKKdpoPk79SPdhRB0yZADVpHnr7pH1BKXESLjokmUbOe3lEu6LaTaM4tMpkT/ +WjzGHWTYtTHkpjx6qFcL2+1hGsvxznN3Y6SHb0xRONbkX8eftoEq5IVIeVheO/jb +AoJnwTnbw3RLPTYe+SmTiGhbqEQZIfCn6IENLOiTNrQ3ssqwGyZ6miUfmpqAnksq +P/ujmv5zMnHCnsZy4YpoJ/HkD7TETKVhk/iXEAcqMCWpuchxuO9ozC1+9eB+D4Ko +b7a6bINDd82Kkhehnlt4Fj1F4jNy3eFmypnTycUm/Q1oBEauttmbjL4ZvrHG8hnj +XALKLNhvSgfZyTXaQHXyxKcZb55CEJh15pWLYLztxRLXis7VmFxWlgPF7ncGNf/P +5O4/E2Hu29othfDNrp2yGAlFw5Khchf8R7agCyzxxN5DaAhqXzvwdmP7zAYspsbi +DrW5viSP +-----END CERTIFICATE----- + +# Issuer: CN=Hellenic Academic and Research Institutions RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority +# Subject: CN=Hellenic Academic and Research Institutions RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority +# Label: "Hellenic Academic and Research Institutions RootCA 2015" +# Serial: 0 +# MD5 Fingerprint: ca:ff:e2:db:03:d9:cb:4b:e9:0f:ad:84:fd:7b:18:ce +# SHA1 Fingerprint: 01:0c:06:95:a6:98:19:14:ff:bf:5f:c6:b0:b6:95:ea:29:e9:12:a6 +# SHA256 Fingerprint: a0:40:92:9a:02:ce:53:b4:ac:f4:f2:ff:c6:98:1c:e4:49:6f:75:5e:6d:45:fe:0b:2a:69:2b:cd:52:52:3f:36 +-----BEGIN CERTIFICATE----- +MIIGCzCCA/OgAwIBAgIBADANBgkqhkiG9w0BAQsFADCBpjELMAkGA1UEBhMCR1Ix +DzANBgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNhZGVtaWMgYW5k +IFJlc2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkxQDA+BgNVBAMT +N0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgUm9v +dENBIDIwMTUwHhcNMTUwNzA3MTAxMTIxWhcNNDAwNjMwMTAxMTIxWjCBpjELMAkG +A1UEBhMCR1IxDzANBgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNh +ZGVtaWMgYW5kIFJlc2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkx +QDA+BgNVBAMTN0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1 +dGlvbnMgUm9vdENBIDIwMTUwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoIC +AQDC+Kk/G4n8PDwEXT2QNrCROnk8ZlrvbTkBSRq0t89/TSNTt5AA4xMqKKYx8ZEA +4yjsriFBzh/a/X0SWwGDD7mwX5nh8hKDgE0GPt+sr+ehiGsxr/CL0BgzuNtFajT0 +AoAkKAoCFZVedioNmToUW/bLy1O8E00BiDeUJRtCvCLYjqOWXjrZMts+6PAQZe10 +4S+nfK8nNLspfZu2zwnI5dMK/IhlZXQK3HMcXM1AsRzUtoSMTFDPaI6oWa7CJ06C +ojXdFPQf/7J31Ycvqm59JCfnxssm5uX+Zwdj2EUN3TpZZTlYepKZcj2chF6IIbjV +9Cz82XBST3i4vTwri5WY9bPRaM8gFH5MXF/ni+X1NYEZN9cRCLdmvtNKzoNXADrD +gfgXy5I2XdGj2HUb4Ysn6npIQf1FGQatJ5lOwXBH3bWfgVMS5bGMSF0xQxfjjMZ6 +Y5ZLKTBOhE5iGV48zpeQpX8B653g+IuJ3SWYPZK2fu/Z8VFRfS0myGlZYeCsargq +NhEEelC9MoS+L9xy1dcdFkfkR2YgP/SWxa+OAXqlD3pk9Q0Yh9muiNX6hME6wGko +LfINaFGq46V3xqSQDqE3izEjR8EJCOtu93ib14L8hCCZSRm2Ekax+0VVFqmjZayc +Bw/qa9wfLgZy7IaIEuQt218FL+TwA9MmM+eAws1CoRc0CwIDAQABo0IwQDAPBgNV +HRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUcRVnyMjJvXVd +ctA4GGqd83EkVAswDQYJKoZIhvcNAQELBQADggIBAHW7bVRLqhBYRjTyYtcWNl0I +XtVsyIe9tC5G8jH4fOpCtZMWVdyhDBKg2mF+D1hYc2Ryx+hFjtyp8iY/xnmMsVMI +M4GwVhO+5lFc2JsKT0ucVlMC6U/2DWDqTUJV6HwbISHTGzrMd/K4kPFox/la/vot +9L/J9UUbzjgQKjeKeaO04wlshYaT/4mWJ3iBj2fjRnRUjtkNaeJK9E10A/+yd+2V +Z5fkscWrv2oj6NSU4kQoYsRL4vDY4ilrGnB+JGGTe08DMiUNRSQrlrRGar9KC/ea +j8GsGsVn82800vpzY4zvFrCopEYq+OsS7HK07/grfoxSwIuEVPkvPuNVqNxmsdnh +X9izjFk0WaSrT2y7HxjbdavYy5LNlDhhDgcGH0tGEPEVvo2FXDtKK4F5D7Rpn0lQ +l033DlZdwJVqwjbDG2jJ9SrcR5q+ss7FJej6A7na+RZukYT1HCjI/CbM1xyQVqdf +bzoEvM14iQuODy+jqk+iGxI9FghAD/FGTNeqewjBCvVtJ94Cj8rDtSvK6evIIVM4 +pcw72Hc3MKJP2W/R8kCtQXoXxdZKNYm3QdV8hn9VTYNKpXMgwDqvkPGaJI7ZjnHK +e7iG2rKPmT4dEw0SEe7Uq/DpFXYC5ODfqiAeW2GFZECpkJcNrVPSWh2HagCXZWK0 +vm9qp/UsQu0yrbYhnr68 +-----END CERTIFICATE----- + +# Issuer: CN=Hellenic Academic and Research Institutions ECC RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority +# Subject: CN=Hellenic Academic and Research Institutions ECC RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority +# Label: "Hellenic Academic and Research Institutions ECC RootCA 2015" +# Serial: 0 +# MD5 Fingerprint: 81:e5:b4:17:eb:c2:f5:e1:4b:0d:41:7b:49:92:fe:ef +# SHA1 Fingerprint: 9f:f1:71:8d:92:d5:9a:f3:7d:74:97:b4:bc:6f:84:68:0b:ba:b6:66 +# SHA256 Fingerprint: 44:b5:45:aa:8a:25:e6:5a:73:ca:15:dc:27:fc:36:d2:4c:1c:b9:95:3a:06:65:39:b1:15:82:dc:48:7b:48:33 +-----BEGIN CERTIFICATE----- +MIICwzCCAkqgAwIBAgIBADAKBggqhkjOPQQDAjCBqjELMAkGA1UEBhMCR1IxDzAN +BgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJl +c2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkxRDBCBgNVBAMTO0hl +bGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgRUNDIFJv +b3RDQSAyMDE1MB4XDTE1MDcwNzEwMzcxMloXDTQwMDYzMDEwMzcxMlowgaoxCzAJ +BgNVBAYTAkdSMQ8wDQYDVQQHEwZBdGhlbnMxRDBCBgNVBAoTO0hlbGxlbmljIEFj +YWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgQ2VydC4gQXV0aG9yaXR5 +MUQwQgYDVQQDEztIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0 +dXRpb25zIEVDQyBSb290Q0EgMjAxNTB2MBAGByqGSM49AgEGBSuBBAAiA2IABJKg +QehLgoRc4vgxEZmGZE4JJS+dQS8KrjVPdJWyUWRrjWvmP3CV8AVER6ZyOFB2lQJa +jq4onvktTpnvLEhvTCUp6NFxW98dwXU3tNf6e3pCnGoKVlp8aQuqgAkkbH7BRqNC +MEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFLQi +C4KZJAEOnLvkDv2/+5cgk5kqMAoGCCqGSM49BAMCA2cAMGQCMGfOFmI4oqxiRaep +lSTAGiecMjvAwNW6qef4BENThe5SId6d9SWDPp5YSy/XZxMOIQIwBeF1Ad5o7Sof +TUwJCA3sS61kFyjndc5FZXIhF8siQQ6ME5g4mlRtm8rifOoCWCKR +-----END CERTIFICATE----- + +# Issuer: CN=ISRG Root X1 O=Internet Security Research Group +# Subject: CN=ISRG Root X1 O=Internet Security Research Group +# Label: "ISRG Root X1" +# Serial: 172886928669790476064670243504169061120 +# MD5 Fingerprint: 0c:d2:f9:e0:da:17:73:e9:ed:86:4d:a5:e3:70:e7:4e +# SHA1 Fingerprint: ca:bd:2a:79:a1:07:6a:31:f2:1d:25:36:35:cb:03:9d:43:29:a5:e8 +# SHA256 Fingerprint: 96:bc:ec:06:26:49:76:f3:74:60:77:9a:cf:28:c5:a7:cf:e8:a3:c0:aa:e1:1a:8f:fc:ee:05:c0:bd:df:08:c6 +-----BEGIN CERTIFICATE----- +MIIFazCCA1OgAwIBAgIRAIIQz7DSQONZRGPgu2OCiwAwDQYJKoZIhvcNAQELBQAw +TzELMAkGA1UEBhMCVVMxKTAnBgNVBAoTIEludGVybmV0IFNlY3VyaXR5IFJlc2Vh +cmNoIEdyb3VwMRUwEwYDVQQDEwxJU1JHIFJvb3QgWDEwHhcNMTUwNjA0MTEwNDM4 +WhcNMzUwNjA0MTEwNDM4WjBPMQswCQYDVQQGEwJVUzEpMCcGA1UEChMgSW50ZXJu +ZXQgU2VjdXJpdHkgUmVzZWFyY2ggR3JvdXAxFTATBgNVBAMTDElTUkcgUm9vdCBY +MTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAK3oJHP0FDfzm54rVygc +h77ct984kIxuPOZXoHj3dcKi/vVqbvYATyjb3miGbESTtrFj/RQSa78f0uoxmyF+ +0TM8ukj13Xnfs7j/EvEhmkvBioZxaUpmZmyPfjxwv60pIgbz5MDmgK7iS4+3mX6U +A5/TR5d8mUgjU+g4rk8Kb4Mu0UlXjIB0ttov0DiNewNwIRt18jA8+o+u3dpjq+sW +T8KOEUt+zwvo/7V3LvSye0rgTBIlDHCNAymg4VMk7BPZ7hm/ELNKjD+Jo2FR3qyH +B5T0Y3HsLuJvW5iB4YlcNHlsdu87kGJ55tukmi8mxdAQ4Q7e2RCOFvu396j3x+UC +B5iPNgiV5+I3lg02dZ77DnKxHZu8A/lJBdiB3QW0KtZB6awBdpUKD9jf1b0SHzUv +KBds0pjBqAlkd25HN7rOrFleaJ1/ctaJxQZBKT5ZPt0m9STJEadao0xAH0ahmbWn +OlFuhjuefXKnEgV4We0+UXgVCwOPjdAvBbI+e0ocS3MFEvzG6uBQE3xDk3SzynTn +jh8BCNAw1FtxNrQHusEwMFxIt4I7mKZ9YIqioymCzLq9gwQbooMDQaHWBfEbwrbw +qHyGO0aoSCqI3Haadr8faqU9GY/rOPNk3sgrDQoo//fb4hVC1CLQJ13hef4Y53CI +rU7m2Ys6xt0nUW7/vGT1M0NPAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNV +HRMBAf8EBTADAQH/MB0GA1UdDgQWBBR5tFnme7bl5AFzgAiIyBpY9umbbjANBgkq +hkiG9w0BAQsFAAOCAgEAVR9YqbyyqFDQDLHYGmkgJykIrGF1XIpu+ILlaS/V9lZL +ubhzEFnTIZd+50xx+7LSYK05qAvqFyFWhfFQDlnrzuBZ6brJFe+GnY+EgPbk6ZGQ +3BebYhtF8GaV0nxvwuo77x/Py9auJ/GpsMiu/X1+mvoiBOv/2X/qkSsisRcOj/KK +NFtY2PwByVS5uCbMiogziUwthDyC3+6WVwW6LLv3xLfHTjuCvjHIInNzktHCgKQ5 +ORAzI4JMPJ+GslWYHb4phowim57iaztXOoJwTdwJx4nLCgdNbOhdjsnvzqvHu7Ur +TkXWStAmzOVyyghqpZXjFaH3pO3JLF+l+/+sKAIuvtd7u+Nxe5AW0wdeRlN8NwdC +jNPElpzVmbUq4JUagEiuTDkHzsxHpFKVK7q4+63SM1N95R1NbdWhscdCb+ZAJzVc +oyi3B43njTOQ5yOf+1CceWxG1bQVs5ZufpsMljq4Ui0/1lvh+wjChP4kqKOJ2qxq +4RgqsahDYVvTH9w7jXbyLeiNdd8XM2w9U/t7y0Ff/9yi0GE44Za4rF2LN9d11TPA +mRGunUHBcnWEvgJBQl9nJEiU0Zsnvgc/ubhPgXRR4Xq37Z0j4r7g1SgEEzwxA57d +emyPxgcYxn/eR44/KJ4EBs+lVDR3veyJm+kXQ99b21/+jh5Xos1AnX5iItreGCc= +-----END CERTIFICATE----- + +# Issuer: O=FNMT-RCM OU=AC RAIZ FNMT-RCM +# Subject: O=FNMT-RCM OU=AC RAIZ FNMT-RCM +# Label: "AC RAIZ FNMT-RCM" +# Serial: 485876308206448804701554682760554759 +# MD5 Fingerprint: e2:09:04:b4:d3:bd:d1:a0:14:fd:1a:d2:47:c4:57:1d +# SHA1 Fingerprint: ec:50:35:07:b2:15:c4:95:62:19:e2:a8:9a:5b:42:99:2c:4c:2c:20 +# SHA256 Fingerprint: eb:c5:57:0c:29:01:8c:4d:67:b1:aa:12:7b:af:12:f7:03:b4:61:1e:bc:17:b7:da:b5:57:38:94:17:9b:93:fa +-----BEGIN CERTIFICATE----- +MIIFgzCCA2ugAwIBAgIPXZONMGc2yAYdGsdUhGkHMA0GCSqGSIb3DQEBCwUAMDsx +CzAJBgNVBAYTAkVTMREwDwYDVQQKDAhGTk1ULVJDTTEZMBcGA1UECwwQQUMgUkFJ +WiBGTk1ULVJDTTAeFw0wODEwMjkxNTU5NTZaFw0zMDAxMDEwMDAwMDBaMDsxCzAJ +BgNVBAYTAkVTMREwDwYDVQQKDAhGTk1ULVJDTTEZMBcGA1UECwwQQUMgUkFJWiBG +Tk1ULVJDTTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBALpxgHpMhm5/ +yBNtwMZ9HACXjywMI7sQmkCpGreHiPibVmr75nuOi5KOpyVdWRHbNi63URcfqQgf +BBckWKo3Shjf5TnUV/3XwSyRAZHiItQDwFj8d0fsjz50Q7qsNI1NOHZnjrDIbzAz +WHFctPVrbtQBULgTfmxKo0nRIBnuvMApGGWn3v7v3QqQIecaZ5JCEJhfTzC8PhxF +tBDXaEAUwED653cXeuYLj2VbPNmaUtu1vZ5Gzz3rkQUCwJaydkxNEJY7kvqcfw+Z +374jNUUeAlz+taibmSXaXvMiwzn15Cou08YfxGyqxRxqAQVKL9LFwag0Jl1mpdIC +IfkYtwb1TplvqKtMUejPUBjFd8g5CSxJkjKZqLsXF3mwWsXmo8RZZUc1g16p6DUL +mbvkzSDGm0oGObVo/CK67lWMK07q87Hj/LaZmtVC+nFNCM+HHmpxffnTtOmlcYF7 +wk5HlqX2doWjKI/pgG6BU6VtX7hI+cL5NqYuSf+4lsKMB7ObiFj86xsc3i1w4peS +MKGJ47xVqCfWS+2QrYv6YyVZLag13cqXM7zlzced0ezvXg5KkAYmY6252TUtB7p2 +ZSysV4999AeU14ECll2jB0nVetBX+RvnU0Z1qrB5QstocQjpYL05ac70r8NWQMet +UqIJ5G+GR4of6ygnXYMgrwTJbFaai0b1AgMBAAGjgYMwgYAwDwYDVR0TAQH/BAUw +AwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFPd9xf3E6Jobd2Sn9R2gzL+H +YJptMD4GA1UdIAQ3MDUwMwYEVR0gADArMCkGCCsGAQUFBwIBFh1odHRwOi8vd3d3 +LmNlcnQuZm5tdC5lcy9kcGNzLzANBgkqhkiG9w0BAQsFAAOCAgEAB5BK3/MjTvDD +nFFlm5wioooMhfNzKWtN/gHiqQxjAb8EZ6WdmF/9ARP67Jpi6Yb+tmLSbkyU+8B1 +RXxlDPiyN8+sD8+Nb/kZ94/sHvJwnvDKuO+3/3Y3dlv2bojzr2IyIpMNOmqOFGYM +LVN0V2Ue1bLdI4E7pWYjJ2cJj+F3qkPNZVEI7VFY/uY5+ctHhKQV8Xa7pO6kO8Rf +77IzlhEYt8llvhjho6Tc+hj507wTmzl6NLrTQfv6MooqtyuGC2mDOL7Nii4LcK2N +JpLuHvUBKwrZ1pebbuCoGRw6IYsMHkCtA+fdZn71uSANA+iW+YJF1DngoABd15jm +fZ5nc8OaKveri6E6FO80vFIOiZiaBECEHX5FaZNXzuvO+FB8TxxuBEOb+dY7Ixjp +6o7RTUaN8Tvkasq6+yO3m/qZASlaWFot4/nUbQ4mrcFuNLwy+AwF+mWj2zs3gyLp +1txyM/1d8iC9djwj2ij3+RvrWWTV3F9yfiD8zYm1kGdNYno/Tq0dwzn+evQoFt9B +9kiABdcPUXmsEKvU7ANm5mqwujGSQkBqvjrTcuFqN1W8rB2Vt2lh8kORdOag0wok +RqEIr9baRRmW1FMdW4R58MD3R++Lj8UGrp1MYp3/RgT408m2ECVAdf4WqslKYIYv +uu8wd+RU4riEmViAqhOLUTpPSPaLtrM= +-----END CERTIFICATE----- + +# Issuer: CN=Amazon Root CA 1 O=Amazon +# Subject: CN=Amazon Root CA 1 O=Amazon +# Label: "Amazon Root CA 1" +# Serial: 143266978916655856878034712317230054538369994 +# MD5 Fingerprint: 43:c6:bf:ae:ec:fe:ad:2f:18:c6:88:68:30:fc:c8:e6 +# SHA1 Fingerprint: 8d:a7:f9:65:ec:5e:fc:37:91:0f:1c:6e:59:fd:c1:cc:6a:6e:de:16 +# SHA256 Fingerprint: 8e:cd:e6:88:4f:3d:87:b1:12:5b:a3:1a:c3:fc:b1:3d:70:16:de:7f:57:cc:90:4f:e1:cb:97:c6:ae:98:19:6e +-----BEGIN CERTIFICATE----- +MIIDQTCCAimgAwIBAgITBmyfz5m/jAo54vB4ikPmljZbyjANBgkqhkiG9w0BAQsF +ADA5MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6 +b24gUm9vdCBDQSAxMB4XDTE1MDUyNjAwMDAwMFoXDTM4MDExNzAwMDAwMFowOTEL +MAkGA1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJv +b3QgQ0EgMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALJ4gHHKeNXj +ca9HgFB0fW7Y14h29Jlo91ghYPl0hAEvrAIthtOgQ3pOsqTQNroBvo3bSMgHFzZM +9O6II8c+6zf1tRn4SWiw3te5djgdYZ6k/oI2peVKVuRF4fn9tBb6dNqcmzU5L/qw +IFAGbHrQgLKm+a/sRxmPUDgH3KKHOVj4utWp+UhnMJbulHheb4mjUcAwhmahRWa6 +VOujw5H5SNz/0egwLX0tdHA114gk957EWW67c4cX8jJGKLhD+rcdqsq08p8kDi1L +93FcXmn/6pUCyziKrlA4b9v7LWIbxcceVOF34GfID5yHI9Y/QCB/IIDEgEw+OyQm +jgSubJrIqg0CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC +AYYwHQYDVR0OBBYEFIQYzIU07LwMlJQuCFmcx7IQTgoIMA0GCSqGSIb3DQEBCwUA +A4IBAQCY8jdaQZChGsV2USggNiMOruYou6r4lK5IpDB/G/wkjUu0yKGX9rbxenDI +U5PMCCjjmCXPI6T53iHTfIUJrU6adTrCC2qJeHZERxhlbI1Bjjt/msv0tadQ1wUs +N+gDS63pYaACbvXy8MWy7Vu33PqUXHeeE6V/Uq2V8viTO96LXFvKWlJbYK8U90vv +o/ufQJVtMVT8QtPHRh8jrdkPSHCa2XV4cdFyQzR1bldZwgJcJmApzyMZFo6IQ6XU +5MsI+yMRQ+hDKXJioaldXgjUkK642M4UwtBV8ob2xJNDd2ZhwLnoQdeXeGADbkpy +rqXRfboQnoZsG4q5WTP468SQvvG5 +-----END CERTIFICATE----- + +# Issuer: CN=Amazon Root CA 2 O=Amazon +# Subject: CN=Amazon Root CA 2 O=Amazon +# Label: "Amazon Root CA 2" +# Serial: 143266982885963551818349160658925006970653239 +# MD5 Fingerprint: c8:e5:8d:ce:a8:42:e2:7a:c0:2a:5c:7c:9e:26:bf:66 +# SHA1 Fingerprint: 5a:8c:ef:45:d7:a6:98:59:76:7a:8c:8b:44:96:b5:78:cf:47:4b:1a +# SHA256 Fingerprint: 1b:a5:b2:aa:8c:65:40:1a:82:96:01:18:f8:0b:ec:4f:62:30:4d:83:ce:c4:71:3a:19:c3:9c:01:1e:a4:6d:b4 +-----BEGIN CERTIFICATE----- +MIIFQTCCAymgAwIBAgITBmyf0pY1hp8KD+WGePhbJruKNzANBgkqhkiG9w0BAQwF +ADA5MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6 +b24gUm9vdCBDQSAyMB4XDTE1MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTEL +MAkGA1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJv +b3QgQ0EgMjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAK2Wny2cSkxK +gXlRmeyKy2tgURO8TW0G/LAIjd0ZEGrHJgw12MBvIITplLGbhQPDW9tK6Mj4kHbZ +W0/jTOgGNk3Mmqw9DJArktQGGWCsN0R5hYGCrVo34A3MnaZMUnbqQ523BNFQ9lXg +1dKmSYXpN+nKfq5clU1Imj+uIFptiJXZNLhSGkOQsL9sBbm2eLfq0OQ6PBJTYv9K +8nu+NQWpEjTj82R0Yiw9AElaKP4yRLuH3WUnAnE72kr3H9rN9yFVkE8P7K6C4Z9r +2UXTu/Bfh+08LDmG2j/e7HJV63mjrdvdfLC6HM783k81ds8P+HgfajZRRidhW+me +z/CiVX18JYpvL7TFz4QuK/0NURBs+18bvBt+xa47mAExkv8LV/SasrlX6avvDXbR +8O70zoan4G7ptGmh32n2M8ZpLpcTnqWHsFcQgTfJU7O7f/aS0ZzQGPSSbtqDT6Zj +mUyl+17vIWR6IF9sZIUVyzfpYgwLKhbcAS4y2j5L9Z469hdAlO+ekQiG+r5jqFoz +7Mt0Q5X5bGlSNscpb/xVA1wf+5+9R+vnSUeVC06JIglJ4PVhHvG/LopyboBZ/1c6 ++XUyo05f7O0oYtlNc/LMgRdg7c3r3NunysV+Ar3yVAhU/bQtCSwXVEqY0VThUWcI +0u1ufm8/0i2BWSlmy5A5lREedCf+3euvAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMB +Af8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBSwDPBMMPQFWAJI/TPlUq9LhONm +UjANBgkqhkiG9w0BAQwFAAOCAgEAqqiAjw54o+Ci1M3m9Zh6O+oAA7CXDpO8Wqj2 +LIxyh6mx/H9z/WNxeKWHWc8w4Q0QshNabYL1auaAn6AFC2jkR2vHat+2/XcycuUY ++gn0oJMsXdKMdYV2ZZAMA3m3MSNjrXiDCYZohMr/+c8mmpJ5581LxedhpxfL86kS +k5Nrp+gvU5LEYFiwzAJRGFuFjWJZY7attN6a+yb3ACfAXVU3dJnJUH/jWS5E4ywl +7uxMMne0nxrpS10gxdr9HIcWxkPo1LsmmkVwXqkLN1PiRnsn/eBG8om3zEK2yygm +btmlyTrIQRNg91CMFa6ybRoVGld45pIq2WWQgj9sAq+uEjonljYE1x2igGOpm/Hl +urR8FLBOybEfdF849lHqm/osohHUqS0nGkWxr7JOcQ3AWEbWaQbLU8uz/mtBzUF+ +fUwPfHJ5elnNXkoOrJupmHN5fLT0zLm4BwyydFy4x2+IoZCn9Kr5v2c69BoVYh63 +n749sSmvZ6ES8lgQGVMDMBu4Gon2nL2XA46jCfMdiyHxtN/kHNGfZQIG6lzWE7OE +76KlXIx3KadowGuuQNKotOrN8I1LOJwZmhsoVLiJkO/KdYE+HvJkJMcYr07/R54H +9jVlpNMKVv/1F2Rs76giJUmTtt8AF9pYfl3uxRuw0dFfIRDH+fO6AgonB8Xx1sfT +4PsJYGw= +-----END CERTIFICATE----- + +# Issuer: CN=Amazon Root CA 3 O=Amazon +# Subject: CN=Amazon Root CA 3 O=Amazon +# Label: "Amazon Root CA 3" +# Serial: 143266986699090766294700635381230934788665930 +# MD5 Fingerprint: a0:d4:ef:0b:f7:b5:d8:49:95:2a:ec:f5:c4:fc:81:87 +# SHA1 Fingerprint: 0d:44:dd:8c:3c:8c:1a:1a:58:75:64:81:e9:0f:2e:2a:ff:b3:d2:6e +# SHA256 Fingerprint: 18:ce:6c:fe:7b:f1:4e:60:b2:e3:47:b8:df:e8:68:cb:31:d0:2e:bb:3a:da:27:15:69:f5:03:43:b4:6d:b3:a4 +-----BEGIN CERTIFICATE----- +MIIBtjCCAVugAwIBAgITBmyf1XSXNmY/Owua2eiedgPySjAKBggqhkjOPQQDAjA5 +MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6b24g +Um9vdCBDQSAzMB4XDTE1MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTELMAkG +A1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJvb3Qg +Q0EgMzBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABCmXp8ZBf8ANm+gBG1bG8lKl +ui2yEujSLtf6ycXYqm0fc4E7O5hrOXwzpcVOho6AF2hiRVd9RFgdszflZwjrZt6j +QjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBSr +ttvXBp43rDCGB5Fwx5zEGbF4wDAKBggqhkjOPQQDAgNJADBGAiEA4IWSoxe3jfkr +BqWTrBqYaGFy+uGh0PsceGCmQ5nFuMQCIQCcAu/xlJyzlvnrxir4tiz+OpAUFteM +YyRIHN8wfdVoOw== +-----END CERTIFICATE----- + +# Issuer: CN=Amazon Root CA 4 O=Amazon +# Subject: CN=Amazon Root CA 4 O=Amazon +# Label: "Amazon Root CA 4" +# Serial: 143266989758080763974105200630763877849284878 +# MD5 Fingerprint: 89:bc:27:d5:eb:17:8d:06:6a:69:d5:fd:89:47:b4:cd +# SHA1 Fingerprint: f6:10:84:07:d6:f8:bb:67:98:0c:c2:e2:44:c2:eb:ae:1c:ef:63:be +# SHA256 Fingerprint: e3:5d:28:41:9e:d0:20:25:cf:a6:90:38:cd:62:39:62:45:8d:a5:c6:95:fb:de:a3:c2:2b:0b:fb:25:89:70:92 +-----BEGIN CERTIFICATE----- +MIIB8jCCAXigAwIBAgITBmyf18G7EEwpQ+Vxe3ssyBrBDjAKBggqhkjOPQQDAzA5 +MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6b24g +Um9vdCBDQSA0MB4XDTE1MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTELMAkG +A1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJvb3Qg +Q0EgNDB2MBAGByqGSM49AgEGBSuBBAAiA2IABNKrijdPo1MN/sGKe0uoe0ZLY7Bi +9i0b2whxIdIA6GO9mif78DluXeo9pcmBqqNbIJhFXRbb/egQbeOc4OO9X4Ri83Bk +M6DLJC9wuoihKqB1+IGuYgbEgds5bimwHvouXKNCMEAwDwYDVR0TAQH/BAUwAwEB +/zAOBgNVHQ8BAf8EBAMCAYYwHQYDVR0OBBYEFNPsxzplbszh2naaVvuc84ZtV+WB +MAoGCCqGSM49BAMDA2gAMGUCMDqLIfG9fhGt0O9Yli/W651+kI0rz2ZVwyzjKKlw +CkcO8DdZEv8tmZQoTipPNU0zWgIxAOp1AE47xDqUEpHJWEadIRNyp4iciuRMStuW +1KyLa2tJElMzrdfkviT8tQp21KW8EA== +-----END CERTIFICATE----- + +# Issuer: CN=LuxTrust Global Root 2 O=LuxTrust S.A. +# Subject: CN=LuxTrust Global Root 2 O=LuxTrust S.A. +# Label: "LuxTrust Global Root 2" +# Serial: 59914338225734147123941058376788110305822489521 +# MD5 Fingerprint: b2:e1:09:00:61:af:f7:f1:91:6f:c4:ad:8d:5e:3b:7c +# SHA1 Fingerprint: 1e:0e:56:19:0a:d1:8b:25:98:b2:04:44:ff:66:8a:04:17:99:5f:3f +# SHA256 Fingerprint: 54:45:5f:71:29:c2:0b:14:47:c4:18:f9:97:16:8f:24:c5:8f:c5:02:3b:f5:da:5b:e2:eb:6e:1d:d8:90:2e:d5 +-----BEGIN CERTIFICATE----- +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 +-----END CERTIFICATE----- + +# Issuer: CN=TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1 O=Turkiye Bilimsel ve Teknolojik Arastirma Kurumu - TUBITAK OU=Kamu Sertifikasyon Merkezi - Kamu SM +# Subject: CN=TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1 O=Turkiye Bilimsel ve Teknolojik Arastirma Kurumu - TUBITAK OU=Kamu Sertifikasyon Merkezi - Kamu SM +# Label: "TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1" +# Serial: 1 +# MD5 Fingerprint: dc:00:81:dc:69:2f:3e:2f:b0:3b:f6:3d:5a:91:8e:49 +# SHA1 Fingerprint: 31:43:64:9b:ec:ce:27:ec:ed:3a:3f:0b:8f:0d:e4:e8:91:dd:ee:ca +# SHA256 Fingerprint: 46:ed:c3:68:90:46:d5:3a:45:3f:b3:10:4a:b8:0d:ca:ec:65:8b:26:60:ea:16:29:dd:7e:86:79:90:64:87:16 +-----BEGIN CERTIFICATE----- +MIIEYzCCA0ugAwIBAgIBATANBgkqhkiG9w0BAQsFADCB0jELMAkGA1UEBhMCVFIx +GDAWBgNVBAcTD0dlYnplIC0gS29jYWVsaTFCMEAGA1UEChM5VHVya2l5ZSBCaWxp +bXNlbCB2ZSBUZWtub2xvamlrIEFyYXN0aXJtYSBLdXJ1bXUgLSBUVUJJVEFLMS0w +KwYDVQQLEyRLYW11IFNlcnRpZmlrYXN5b24gTWVya2V6aSAtIEthbXUgU00xNjA0 +BgNVBAMTLVRVQklUQUsgS2FtdSBTTSBTU0wgS29rIFNlcnRpZmlrYXNpIC0gU3Vy +dW0gMTAeFw0xMzExMjUwODI1NTVaFw00MzEwMjUwODI1NTVaMIHSMQswCQYDVQQG +EwJUUjEYMBYGA1UEBxMPR2ViemUgLSBLb2NhZWxpMUIwQAYDVQQKEzlUdXJraXll +IEJpbGltc2VsIHZlIFRla25vbG9qaWsgQXJhc3Rpcm1hIEt1cnVtdSAtIFRVQklU +QUsxLTArBgNVBAsTJEthbXUgU2VydGlmaWthc3lvbiBNZXJrZXppIC0gS2FtdSBT +TTE2MDQGA1UEAxMtVFVCSVRBSyBLYW11IFNNIFNTTCBLb2sgU2VydGlmaWthc2kg +LSBTdXJ1bSAxMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAr3UwM6q7 +a9OZLBI3hNmNe5eA027n/5tQlT6QlVZC1xl8JoSNkvoBHToP4mQ4t4y86Ij5iySr +LqP1N+RAjhgleYN1Hzv/bKjFxlb4tO2KRKOrbEz8HdDc72i9z+SqzvBV96I01INr +N3wcwv61A+xXzry0tcXtAA9TNypN9E8Mg/uGz8v+jE69h/mniyFXnHrfA2eJLJ2X +YacQuFWQfw4tJzh03+f92k4S400VIgLI4OD8D62K18lUUMw7D8oWgITQUVbDjlZ/ +iSIzL+aFCr2lqBs23tPcLG07xxO9WSMs5uWk99gL7eqQQESolbuT1dCANLZGeA4f +AJNG4e7p+exPFwIDAQABo0IwQDAdBgNVHQ4EFgQUZT/HiobGPN08VFw1+DrtUgxH +V8gwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEL +BQADggEBACo/4fEyjq7hmFxLXs9rHmoJ0iKpEsdeV31zVmSAhHqT5Am5EM2fKifh +AHe+SMg1qIGf5LgsyX8OsNJLN13qudULXjS99HMpw+0mFZx+CFOKWI3QSyjfwbPf +IPP54+M638yclNhOT8NrF7f3cuitZjO1JVOr4PhMqZ398g26rrnZqsZr+ZO7rqu4 +lzwDGrpDxpa5RXI4s6ehlj2Re37AIVNMh+3yC1SVUZPVIqUNivGTDj5UDrDYyU7c +8jEyVupk+eq1nRZmQnLzf9OxMUP8pI4X8W0jq5Rm+K37DwhuJi1/FwcJsoz7UMCf +lo3Ptv0AnVoUmr8CRPXBwp8iXqIPoeM= +-----END CERTIFICATE----- + +# Issuer: CN=GDCA TrustAUTH R5 ROOT O=GUANG DONG CERTIFICATE AUTHORITY CO.,LTD. +# Subject: CN=GDCA TrustAUTH R5 ROOT O=GUANG DONG CERTIFICATE AUTHORITY CO.,LTD. +# Label: "GDCA TrustAUTH R5 ROOT" +# Serial: 9009899650740120186 +# MD5 Fingerprint: 63:cc:d9:3d:34:35:5c:6f:53:a3:e2:08:70:48:1f:b4 +# SHA1 Fingerprint: 0f:36:38:5b:81:1a:25:c3:9b:31:4e:83:ca:e9:34:66:70:cc:74:b4 +# SHA256 Fingerprint: bf:ff:8f:d0:44:33:48:7d:6a:8a:a6:0c:1a:29:76:7a:9f:c2:bb:b0:5e:42:0f:71:3a:13:b9:92:89:1d:38:93 +-----BEGIN CERTIFICATE----- +MIIFiDCCA3CgAwIBAgIIfQmX/vBH6nowDQYJKoZIhvcNAQELBQAwYjELMAkGA1UE +BhMCQ04xMjAwBgNVBAoMKUdVQU5HIERPTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZ +IENPLixMVEQuMR8wHQYDVQQDDBZHRENBIFRydXN0QVVUSCBSNSBST09UMB4XDTE0 +MTEyNjA1MTMxNVoXDTQwMTIzMTE1NTk1OVowYjELMAkGA1UEBhMCQ04xMjAwBgNV +BAoMKUdVQU5HIERPTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZIENPLixMVEQuMR8w +HQYDVQQDDBZHRENBIFRydXN0QVVUSCBSNSBST09UMIICIjANBgkqhkiG9w0BAQEF +AAOCAg8AMIICCgKCAgEA2aMW8Mh0dHeb7zMNOwZ+Vfy1YI92hhJCfVZmPoiC7XJj +Dp6L3TQsAlFRwxn9WVSEyfFrs0yw6ehGXTjGoqcuEVe6ghWinI9tsJlKCvLriXBj +TnnEt1u9ol2x8kECK62pOqPseQrsXzrj/e+APK00mxqriCZ7VqKChh/rNYmDf1+u +KU49tm7srsHwJ5uu4/Ts765/94Y9cnrrpftZTqfrlYwiOXnhLQiPzLyRuEH3FMEj +qcOtmkVEs7LXLM3GKeJQEK5cy4KOFxg2fZfmiJqwTTQJ9Cy5WmYqsBebnh52nUpm +MUHfP/vFBu8btn4aRjb3ZGM74zkYI+dndRTVdVeSN72+ahsmUPI2JgaQxXABZG12 +ZuGR224HwGGALrIuL4xwp9E7PLOR5G62xDtw8mySlwnNR30YwPO7ng/Wi64HtloP +zgsMR6flPri9fcebNaBhlzpBdRfMK5Z3KpIhHtmVdiBnaM8Nvd/WHwlqmuLMc3Gk +L30SgLdTMEZeS1SZD2fJpcjyIMGC7J0R38IC+xo70e0gmu9lZJIQDSri3nDxGGeC +jGHeuLzRL5z7D9Ar7Rt2ueQ5Vfj4oR24qoAATILnsn8JuLwwoC8N9VKejveSswoA +HQBUlwbgsQfZxw9cZX08bVlX5O2ljelAU58VS6Bx9hoh49pwBiFYFIeFd3mqgnkC +AwEAAaNCMEAwHQYDVR0OBBYEFOLJQJ9NzuiaoXzPDj9lxSmIahlRMA8GA1UdEwEB +/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEBCwUAA4ICAQDRSVfg +p8xoWLoBDysZzY2wYUWsEe1jUGn4H3++Fo/9nesLqjJHdtJnJO29fDMylyrHBYZm +DRd9FBUb1Ov9H5r2XpdptxolpAqzkT9fNqyL7FeoPueBihhXOYV0GkLH6VsTX4/5 +COmSdI31R9KrO9b7eGZONn356ZLpBN79SWP8bfsUcZNnL0dKt7n/HipzcEYwv1ry +L3ml4Y0M2fmyYzeMN2WFcGpcWwlyua1jPLHd+PwyvzeG5LuOmCd+uh8W4XAR8gPf +JWIyJyYYMoSf/wA6E7qaTfRPuBRwIrHKK5DOKcFw9C+df/KQHtZa37dG/OaG+svg +IHZ6uqbL9XzeYqWxi+7egmaKTjowHz+Ay60nugxe19CxVsp3cbK1daFQqUBDF8Io +2c9Si1vIY9RCPqAzekYu9wogRlR+ak8x8YF+QnQ4ZXMn7sZ8uI7XpTrXmKGcjBBV +09tL7ECQ8s1uV9JiDnxXk7Gnbc2dg7sq5+W2O3FYrf3RRbxake5TFW/TRQl1brqQ +XR4EzzffHqhmsYzmIGrv/EhOdJhCrylvLmrH+33RZjEizIYAfmaDDEL0vTSSwxrq +T8p+ck0LcIymSLumoRT2+1hEmRSuqguTaaApJUqlyyvdimYHFngVV3Eb7PVHhPOe +MTd61X8kreS8/f3MboPoDKi3QWwH3b08hpcv0g== +-----END CERTIFICATE----- + +# Issuer: CN=TrustCor RootCert CA-1 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority +# Subject: CN=TrustCor RootCert CA-1 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority +# Label: "TrustCor RootCert CA-1" +# Serial: 15752444095811006489 +# MD5 Fingerprint: 6e:85:f1:dc:1a:00:d3:22:d5:b2:b2:ac:6b:37:05:45 +# SHA1 Fingerprint: ff:bd:cd:e7:82:c8:43:5e:3c:6f:26:86:5c:ca:a8:3a:45:5b:c3:0a +# SHA256 Fingerprint: d4:0e:9c:86:cd:8f:e4:68:c1:77:69:59:f4:9e:a7:74:fa:54:86:84:b6:c4:06:f3:90:92:61:f4:dc:e2:57:5c +-----BEGIN CERTIFICATE----- +MIIEMDCCAxigAwIBAgIJANqb7HHzA7AZMA0GCSqGSIb3DQEBCwUAMIGkMQswCQYD +VQQGEwJQQTEPMA0GA1UECAwGUGFuYW1hMRQwEgYDVQQHDAtQYW5hbWEgQ2l0eTEk +MCIGA1UECgwbVHJ1c3RDb3IgU3lzdGVtcyBTLiBkZSBSLkwuMScwJQYDVQQLDB5U +cnVzdENvciBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkxHzAdBgNVBAMMFlRydXN0Q29y +IFJvb3RDZXJ0IENBLTEwHhcNMTYwMjA0MTIzMjE2WhcNMjkxMjMxMTcyMzE2WjCB +pDELMAkGA1UEBhMCUEExDzANBgNVBAgMBlBhbmFtYTEUMBIGA1UEBwwLUGFuYW1h +IENpdHkxJDAiBgNVBAoMG1RydXN0Q29yIFN5c3RlbXMgUy4gZGUgUi5MLjEnMCUG +A1UECwweVHJ1c3RDb3IgQ2VydGlmaWNhdGUgQXV0aG9yaXR5MR8wHQYDVQQDDBZU +cnVzdENvciBSb290Q2VydCBDQS0xMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIB +CgKCAQEAv463leLCJhJrMxnHQFgKq1mqjQCj/IDHUHuO1CAmujIS2CNUSSUQIpid +RtLByZ5OGy4sDjjzGiVoHKZaBeYei0i/mJZ0PmnK6bV4pQa81QBeCQryJ3pS/C3V +seq0iWEk8xoT26nPUu0MJLq5nux+AHT6k61sKZKuUbS701e/s/OojZz0JEsq1pme +9J7+wH5COucLlVPat2gOkEz7cD+PSiyU8ybdY2mplNgQTsVHCJCZGxdNuWxu72CV +EY4hgLW9oHPY0LJ3xEXqWib7ZnZ2+AYfYW0PVcWDtxBWcgYHpfOxGgMFZA6dWorW +hnAbJN7+KIor0Gqw/Hqi3LJ5DotlDwIDAQABo2MwYTAdBgNVHQ4EFgQU7mtJPHo/ +DeOxCbeKyKsZn3MzUOcwHwYDVR0jBBgwFoAU7mtJPHo/DeOxCbeKyKsZn3MzUOcw +DwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAYYwDQYJKoZIhvcNAQELBQAD +ggEBACUY1JGPE+6PHh0RU9otRCkZoB5rMZ5NDp6tPVxBb5UrJKF5mDo4Nvu7Zp5I +/5CQ7z3UuJu0h3U/IJvOcs+hVcFNZKIZBqEHMwwLKeXx6quj7LUKdJDHfXLy11yf +ke+Ri7fc7Waiz45mO7yfOgLgJ90WmMCV1Aqk5IGadZQ1nJBfiDcGrVmVCrDRZ9MZ +yonnMlo2HD6CqFqTvsbQZJG2z9m2GM/bftJlo6bEjhcxwft+dtvTheNYsnd6djts +L1Ac59v2Z3kf9YKVmgenFK+P3CghZwnS1k1aHBkcjndcw5QkPTJrS37UeJSDvjdN +zl/HHk484IkzlQsPpTLWPFp5LBk= +-----END CERTIFICATE----- + +# Issuer: CN=TrustCor RootCert CA-2 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority +# Subject: CN=TrustCor RootCert CA-2 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority +# Label: "TrustCor RootCert CA-2" +# Serial: 2711694510199101698 +# MD5 Fingerprint: a2:e1:f8:18:0b:ba:45:d5:c7:41:2a:bb:37:52:45:64 +# SHA1 Fingerprint: b8:be:6d:cb:56:f1:55:b9:63:d4:12:ca:4e:06:34:c7:94:b2:1c:c0 +# SHA256 Fingerprint: 07:53:e9:40:37:8c:1b:d5:e3:83:6e:39:5d:ae:a5:cb:83:9e:50:46:f1:bd:0e:ae:19:51:cf:10:fe:c7:c9:65 +-----BEGIN CERTIFICATE----- +MIIGLzCCBBegAwIBAgIIJaHfyjPLWQIwDQYJKoZIhvcNAQELBQAwgaQxCzAJBgNV +BAYTAlBBMQ8wDQYDVQQIDAZQYW5hbWExFDASBgNVBAcMC1BhbmFtYSBDaXR5MSQw +IgYDVQQKDBtUcnVzdENvciBTeXN0ZW1zIFMuIGRlIFIuTC4xJzAlBgNVBAsMHlRy +dXN0Q29yIENlcnRpZmljYXRlIEF1dGhvcml0eTEfMB0GA1UEAwwWVHJ1c3RDb3Ig +Um9vdENlcnQgQ0EtMjAeFw0xNjAyMDQxMjMyMjNaFw0zNDEyMzExNzI2MzlaMIGk +MQswCQYDVQQGEwJQQTEPMA0GA1UECAwGUGFuYW1hMRQwEgYDVQQHDAtQYW5hbWEg +Q2l0eTEkMCIGA1UECgwbVHJ1c3RDb3IgU3lzdGVtcyBTLiBkZSBSLkwuMScwJQYD +VQQLDB5UcnVzdENvciBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkxHzAdBgNVBAMMFlRy +dXN0Q29yIFJvb3RDZXJ0IENBLTIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIK +AoICAQCnIG7CKqJiJJWQdsg4foDSq8GbZQWU9MEKENUCrO2fk8eHyLAnK0IMPQo+ +QVqedd2NyuCb7GgypGmSaIwLgQ5WoD4a3SwlFIIvl9NkRvRUqdw6VC0xK5mC8tkq +1+9xALgxpL56JAfDQiDyitSSBBtlVkxs1Pu2YVpHI7TYabS3OtB0PAx1oYxOdqHp +2yqlO/rOsP9+aij9JxzIsekp8VduZLTQwRVtDr4uDkbIXvRR/u8OYzo7cbrPb1nK +DOObXUm4TOJXsZiKQlecdu/vvdFoqNL0Cbt3Nb4lggjEFixEIFapRBF37120Hape +az6LMvYHL1cEksr1/p3C6eizjkxLAjHZ5DxIgif3GIJ2SDpxsROhOdUuxTTCHWKF +3wP+TfSvPd9cW436cOGlfifHhi5qjxLGhF5DUVCcGZt45vz27Ud+ez1m7xMTiF88 +oWP7+ayHNZ/zgp6kPwqcMWmLmaSISo5uZk3vFsQPeSghYA2FFn3XVDjxklb9tTNM +g9zXEJ9L/cb4Qr26fHMC4P99zVvh1Kxhe1fVSntb1IVYJ12/+CtgrKAmrhQhJ8Z3 +mjOAPF5GP/fDsaOGM8boXg25NSyqRsGFAnWAoOsk+xWq5Gd/bnc/9ASKL3x74xdh +8N0JqSDIvgmk0H5Ew7IwSjiqqewYmgeCK9u4nBit2uBGF6zPXQIDAQABo2MwYTAd +BgNVHQ4EFgQU2f4hQG6UnrybPZx9mCAZ5YwwYrIwHwYDVR0jBBgwFoAU2f4hQG6U +nrybPZx9mCAZ5YwwYrIwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAYYw +DQYJKoZIhvcNAQELBQADggIBAJ5Fngw7tu/hOsh80QA9z+LqBrWyOrsGS2h60COX +dKcs8AjYeVrXWoSK2BKaG9l9XE1wxaX5q+WjiYndAfrs3fnpkpfbsEZC89NiqpX+ +MWcUaViQCqoL7jcjx1BRtPV+nuN79+TMQjItSQzL/0kMmx40/W5ulop5A7Zv2wnL +/V9lFDfhOPXzYRZY5LVtDQsEGz9QLX+zx3oaFoBg+Iof6Rsqxvm6ARppv9JYx1RX +CI/hOWB3S6xZhBqI8d3LT3jX5+EzLfzuQfogsL7L9ziUwOHQhQ+77Sxzq+3+knYa +ZH9bDTMJBzN7Bj8RpFxwPIXAz+OQqIN3+tvmxYxoZxBnpVIt8MSZj3+/0WvitUfW +2dCFmU2Umw9Lje4AWkcdEQOsQRivh7dvDDqPys/cA8GiCcjl/YBeyGBCARsaU1q7 +N6a3vLqE6R5sGtRk2tRD/pOLS/IseRYQ1JMLiI+h2IYURpFHmygk71dSTlxCnKr3 +Sewn6EAes6aJInKc9Q0ztFijMDvd1GpUk74aTfOTlPf8hAs/hCBcNANExdqtvArB +As8e5ZTZ845b2EzwnexhF7sUMlQMAimTHpKG9n/v55IFDlndmQguLvqcAFLTxWYp +5KeXRKQOKIETNcX2b2TmQcTVL8w0RSXPQQCWPUouwpaYT05KnJe32x+SMsj/D1Fu +1uwJ +-----END CERTIFICATE----- + +# Issuer: CN=TrustCor ECA-1 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority +# Subject: CN=TrustCor ECA-1 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority +# Label: "TrustCor ECA-1" +# Serial: 9548242946988625984 +# MD5 Fingerprint: 27:92:23:1d:0a:f5:40:7c:e9:e6:6b:9d:d8:f5:e7:6c +# SHA1 Fingerprint: 58:d1:df:95:95:67:6b:63:c0:f0:5b:1c:17:4d:8b:84:0b:c8:78:bd +# SHA256 Fingerprint: 5a:88:5d:b1:9c:01:d9:12:c5:75:93:88:93:8c:af:bb:df:03:1a:b2:d4:8e:91:ee:15:58:9b:42:97:1d:03:9c +-----BEGIN CERTIFICATE----- +MIIEIDCCAwigAwIBAgIJAISCLF8cYtBAMA0GCSqGSIb3DQEBCwUAMIGcMQswCQYD +VQQGEwJQQTEPMA0GA1UECAwGUGFuYW1hMRQwEgYDVQQHDAtQYW5hbWEgQ2l0eTEk +MCIGA1UECgwbVHJ1c3RDb3IgU3lzdGVtcyBTLiBkZSBSLkwuMScwJQYDVQQLDB5U +cnVzdENvciBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkxFzAVBgNVBAMMDlRydXN0Q29y +IEVDQS0xMB4XDTE2MDIwNDEyMzIzM1oXDTI5MTIzMTE3MjgwN1owgZwxCzAJBgNV +BAYTAlBBMQ8wDQYDVQQIDAZQYW5hbWExFDASBgNVBAcMC1BhbmFtYSBDaXR5MSQw +IgYDVQQKDBtUcnVzdENvciBTeXN0ZW1zIFMuIGRlIFIuTC4xJzAlBgNVBAsMHlRy +dXN0Q29yIENlcnRpZmljYXRlIEF1dGhvcml0eTEXMBUGA1UEAwwOVHJ1c3RDb3Ig +RUNBLTEwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDPj+ARtZ+odnbb +3w9U73NjKYKtR8aja+3+XzP4Q1HpGjORMRegdMTUpwHmspI+ap3tDvl0mEDTPwOA +BoJA6LHip1GnHYMma6ve+heRK9jGrB6xnhkB1Zem6g23xFUfJ3zSCNV2HykVh0A5 +3ThFEXXQmqc04L/NyFIduUd+Dbi7xgz2c1cWWn5DkR9VOsZtRASqnKmcp0yJF4Ou +owReUoCLHhIlERnXDH19MURB6tuvsBzvgdAsxZohmz3tQjtQJvLsznFhBmIhVE5/ +wZ0+fyCMgMsq2JdiyIMzkX2woloPV+g7zPIlstR8L+xNxqE6FXrntl019fZISjZF +ZtS6mFjBAgMBAAGjYzBhMB0GA1UdDgQWBBREnkj1zG1I1KBLf/5ZJC+Dl5mahjAf +BgNVHSMEGDAWgBREnkj1zG1I1KBLf/5ZJC+Dl5mahjAPBgNVHRMBAf8EBTADAQH/ +MA4GA1UdDwEB/wQEAwIBhjANBgkqhkiG9w0BAQsFAAOCAQEABT41XBVwm8nHc2Fv +civUwo/yQ10CzsSUuZQRg2dd4mdsdXa/uwyqNsatR5Nj3B5+1t4u/ukZMjgDfxT2 +AHMsWbEhBuH7rBiVDKP/mZb3Kyeb1STMHd3BOuCYRLDE5D53sXOpZCz2HAF8P11F +hcCF5yWPldwX8zyfGm6wyuMdKulMY/okYWLW2n62HGz1Ah3UKt1VkOsqEUc8Ll50 +soIipX1TH0XsJ5F95yIW6MBoNtjG8U+ARDL54dHRHareqKucBK+tIA5kmE2la8BI +WJZpTdwHjFGTot+fDz2LYLSCjaoITmJF4PkL0uDgPFveXHEnJcLmA4GLEFPjx1Wi +tJ/X5g== +-----END CERTIFICATE----- + +# Issuer: CN=SSL.com Root Certification Authority RSA O=SSL Corporation +# Subject: CN=SSL.com Root Certification Authority RSA O=SSL Corporation +# Label: "SSL.com Root Certification Authority RSA" +# Serial: 8875640296558310041 +# MD5 Fingerprint: 86:69:12:c0:70:f1:ec:ac:ac:c2:d5:bc:a5:5b:a1:29 +# SHA1 Fingerprint: b7:ab:33:08:d1:ea:44:77:ba:14:80:12:5a:6f:bd:a9:36:49:0c:bb +# SHA256 Fingerprint: 85:66:6a:56:2e:e0:be:5c:e9:25:c1:d8:89:0a:6f:76:a8:7e:c1:6d:4d:7d:5f:29:ea:74:19:cf:20:12:3b:69 +-----BEGIN CERTIFICATE----- +MIIF3TCCA8WgAwIBAgIIeyyb0xaAMpkwDQYJKoZIhvcNAQELBQAwfDELMAkGA1UE +BhMCVVMxDjAMBgNVBAgMBVRleGFzMRAwDgYDVQQHDAdIb3VzdG9uMRgwFgYDVQQK +DA9TU0wgQ29ycG9yYXRpb24xMTAvBgNVBAMMKFNTTC5jb20gUm9vdCBDZXJ0aWZp +Y2F0aW9uIEF1dGhvcml0eSBSU0EwHhcNMTYwMjEyMTczOTM5WhcNNDEwMjEyMTcz +OTM5WjB8MQswCQYDVQQGEwJVUzEOMAwGA1UECAwFVGV4YXMxEDAOBgNVBAcMB0hv +dXN0b24xGDAWBgNVBAoMD1NTTCBDb3Jwb3JhdGlvbjExMC8GA1UEAwwoU1NMLmNv +bSBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IFJTQTCCAiIwDQYJKoZIhvcN +AQEBBQADggIPADCCAgoCggIBAPkP3aMrfcvQKv7sZ4Wm5y4bunfh4/WvpOz6Sl2R +xFdHaxh3a3by/ZPkPQ/CFp4LZsNWlJ4Xg4XOVu/yFv0AYvUiCVToZRdOQbngT0aX +qhvIuG5iXmmxX9sqAn78bMrzQdjt0Oj8P2FI7bADFB0QDksZ4LtO7IZl/zbzXmcC +C52GVWH9ejjt/uIZALdvoVBidXQ8oPrIJZK0bnoix/geoeOy3ZExqysdBP+lSgQ3 +6YWkMyv94tZVNHwZpEpox7Ko07fKoZOI68GXvIz5HdkihCR0xwQ9aqkpk8zruFvh +/l8lqjRYyMEjVJ0bmBHDOJx+PYZspQ9AhnwC9FwCTyjLrnGfDzrIM/4RJTXq/LrF +YD3ZfBjVsqnTdXgDciLKOsMf7yzlLqn6niy2UUb9rwPW6mBo6oUWNmuF6R7As93E +JNyAKoFBbZQ+yODJgUEAnl6/f8UImKIYLEJAs/lvOCdLToD0PYFH4Ih86hzOtXVc +US4cK38acijnALXRdMbX5J+tB5O2UzU1/Dfkw/ZdFr4hc96SCvigY2q8lpJqPvi8 +ZVWb3vUNiSYE/CUapiVpy8JtynziWV+XrOvvLsi81xtZPCvM8hnIk2snYxnP/Okm ++Mpxm3+T/jRnhE6Z6/yzeAkzcLpmpnbtG3PrGqUNxCITIJRWCk4sbE6x/c+cCbqi +M+2HAgMBAAGjYzBhMB0GA1UdDgQWBBTdBAkHovV6fVJTEpKV7jiAJQ2mWTAPBgNV +HRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFN0ECQei9Xp9UlMSkpXuOIAlDaZZMA4G +A1UdDwEB/wQEAwIBhjANBgkqhkiG9w0BAQsFAAOCAgEAIBgRlCn7Jp0cHh5wYfGV +cpNxJK1ok1iOMq8bs3AD/CUrdIWQPXhq9LmLpZc7tRiRux6n+UBbkflVma8eEdBc +Hadm47GUBwwyOabqG7B52B2ccETjit3E+ZUfijhDPwGFpUenPUayvOUiaPd7nNgs +PgohyC0zrL/FgZkxdMF1ccW+sfAjRfSda/wZY52jvATGGAslu1OJD7OAUN5F7kR/ +q5R4ZJjT9ijdh9hwZXT7DrkT66cPYakylszeu+1jTBi7qUD3oFRuIIhxdRjqerQ0 +cuAjJ3dctpDqhiVAq+8zD8ufgr6iIPv2tS0a5sKFsXQP+8hlAqRSAUfdSSLBv9jr +a6x+3uxjMxW3IwiPxg+NQVrdjsW5j+VFP3jbutIbQLH+cU0/4IGiul607BXgk90I +H37hVZkLId6Tngr75qNJvTYw/ud3sqB1l7UtgYgXZSD32pAAn8lSzDLKNXz1PQ/Y +K9f1JmzJBjSWFupwWRoyeXkLtoh/D1JIPb9s2KJELtFOt3JY04kTlf5Eq/jXixtu +nLwsoFvVagCvXzfh1foQC5ichucmj87w7G6KVwuA406ywKBjYZC6VWg3dGq2ktuf +oYYitmUnDuy2n0Jg5GfCtdpBC8TTi2EbvPofkSvXRAdeuims2cXp71NIWuuA8ShY +Ic2wBlX7Jz9TkHCpBB5XJ7k= +-----END CERTIFICATE----- + +# Issuer: CN=SSL.com Root Certification Authority ECC O=SSL Corporation +# Subject: CN=SSL.com Root Certification Authority ECC O=SSL Corporation +# Label: "SSL.com Root Certification Authority ECC" +# Serial: 8495723813297216424 +# MD5 Fingerprint: 2e:da:e4:39:7f:9c:8f:37:d1:70:9f:26:17:51:3a:8e +# SHA1 Fingerprint: c3:19:7c:39:24:e6:54:af:1b:c4:ab:20:95:7a:e2:c3:0e:13:02:6a +# SHA256 Fingerprint: 34:17:bb:06:cc:60:07:da:1b:96:1c:92:0b:8a:b4:ce:3f:ad:82:0e:4a:a3:0b:9a:cb:c4:a7:4e:bd:ce:bc:65 +-----BEGIN CERTIFICATE----- +MIICjTCCAhSgAwIBAgIIdebfy8FoW6gwCgYIKoZIzj0EAwIwfDELMAkGA1UEBhMC +VVMxDjAMBgNVBAgMBVRleGFzMRAwDgYDVQQHDAdIb3VzdG9uMRgwFgYDVQQKDA9T +U0wgQ29ycG9yYXRpb24xMTAvBgNVBAMMKFNTTC5jb20gUm9vdCBDZXJ0aWZpY2F0 +aW9uIEF1dGhvcml0eSBFQ0MwHhcNMTYwMjEyMTgxNDAzWhcNNDEwMjEyMTgxNDAz +WjB8MQswCQYDVQQGEwJVUzEOMAwGA1UECAwFVGV4YXMxEDAOBgNVBAcMB0hvdXN0 +b24xGDAWBgNVBAoMD1NTTCBDb3Jwb3JhdGlvbjExMC8GA1UEAwwoU1NMLmNvbSBS +b290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IEVDQzB2MBAGByqGSM49AgEGBSuB +BAAiA2IABEVuqVDEpiM2nl8ojRfLliJkP9x6jh3MCLOicSS6jkm5BBtHllirLZXI +7Z4INcgn64mMU1jrYor+8FsPazFSY0E7ic3s7LaNGdM0B9y7xgZ/wkWV7Mt/qCPg +CemB+vNH06NjMGEwHQYDVR0OBBYEFILRhXMw5zUE044CkvvlpNHEIejNMA8GA1Ud +EwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUgtGFczDnNQTTjgKS++Wk0cQh6M0wDgYD +VR0PAQH/BAQDAgGGMAoGCCqGSM49BAMCA2cAMGQCMG/n61kRpGDPYbCWe+0F+S8T +kdzt5fxQaxFGRrMcIQBiu77D5+jNB5n5DQtdcj7EqgIwH7y6C+IwJPt8bYBVCpk+ +gA0z5Wajs6O7pdWLjwkspl1+4vAHCGht0nxpbl/f5Wpl +-----END CERTIFICATE----- + +# Issuer: CN=SSL.com EV Root Certification Authority RSA R2 O=SSL Corporation +# Subject: CN=SSL.com EV Root Certification Authority RSA R2 O=SSL Corporation +# Label: "SSL.com EV Root Certification Authority RSA R2" +# Serial: 6248227494352943350 +# MD5 Fingerprint: e1:1e:31:58:1a:ae:54:53:02:f6:17:6a:11:7b:4d:95 +# SHA1 Fingerprint: 74:3a:f0:52:9b:d0:32:a0:f4:4a:83:cd:d4:ba:a9:7b:7c:2e:c4:9a +# SHA256 Fingerprint: 2e:7b:f1:6c:c2:24:85:a7:bb:e2:aa:86:96:75:07:61:b0:ae:39:be:3b:2f:e9:d0:cc:6d:4e:f7:34:91:42:5c +-----BEGIN CERTIFICATE----- +MIIF6zCCA9OgAwIBAgIIVrYpzTS8ePYwDQYJKoZIhvcNAQELBQAwgYIxCzAJBgNV +BAYTAlVTMQ4wDAYDVQQIDAVUZXhhczEQMA4GA1UEBwwHSG91c3RvbjEYMBYGA1UE +CgwPU1NMIENvcnBvcmF0aW9uMTcwNQYDVQQDDC5TU0wuY29tIEVWIFJvb3QgQ2Vy +dGlmaWNhdGlvbiBBdXRob3JpdHkgUlNBIFIyMB4XDTE3MDUzMTE4MTQzN1oXDTQy +MDUzMDE4MTQzN1owgYIxCzAJBgNVBAYTAlVTMQ4wDAYDVQQIDAVUZXhhczEQMA4G +A1UEBwwHSG91c3RvbjEYMBYGA1UECgwPU1NMIENvcnBvcmF0aW9uMTcwNQYDVQQD +DC5TU0wuY29tIEVWIFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgUlNBIFIy +MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAjzZlQOHWTcDXtOlG2mvq +M0fNTPl9fb69LT3w23jhhqXZuglXaO1XPqDQCEGD5yhBJB/jchXQARr7XnAjssuf +OePPxU7Gkm0mxnu7s9onnQqG6YE3Bf7wcXHswxzpY6IXFJ3vG2fThVUCAtZJycxa +4bH3bzKfydQ7iEGonL3Lq9ttewkfokxykNorCPzPPFTOZw+oz12WGQvE43LrrdF9 +HSfvkusQv1vrO6/PgN3B0pYEW3p+pKk8OHakYo6gOV7qd89dAFmPZiw+B6KjBSYR +aZfqhbcPlgtLyEDhULouisv3D5oi53+aNxPN8k0TayHRwMwi8qFG9kRpnMphNQcA +b9ZhCBHqurj26bNg5U257J8UZslXWNvNh2n4ioYSA0e/ZhN2rHd9NCSFg83XqpyQ +Gp8hLH94t2S42Oim9HizVcuE0jLEeK6jj2HdzghTreyI/BXkmg3mnxp3zkyPuBQV +PWKchjgGAGYS5Fl2WlPAApiiECtoRHuOec4zSnaqW4EWG7WK2NAAe15itAnWhmMO +pgWVSbooi4iTsjQc2KRVbrcc0N6ZVTsj9CLg+SlmJuwgUHfbSguPvuUCYHBBXtSu +UDkiFCbLsjtzdFVHB3mBOagwE0TlBIqulhMlQg+5U8Sb/M3kHN48+qvWBkofZ6aY +MBzdLNvcGJVXZsb/XItW9XcCAwEAAaNjMGEwDwYDVR0TAQH/BAUwAwEB/zAfBgNV +HSMEGDAWgBT5YLvU49U09rj1BoAlp3PbRmmonjAdBgNVHQ4EFgQU+WC71OPVNPa4 +9QaAJadz20ZpqJ4wDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEBCwUAA4ICAQBW +s47LCp1Jjr+kxJG7ZhcFUZh1++VQLHqe8RT6q9OKPv+RKY9ji9i0qVQBDb6Thi/5 +Sm3HXvVX+cpVHBK+Rw82xd9qt9t1wkclf7nxY/hoLVUE0fKNsKTPvDxeH3jnpaAg +cLAExbf3cqfeIg29MyVGjGSSJuM+LmOW2puMPfgYCdcDzH2GguDKBAdRUNf/ktUM +79qGn5nX67evaOI5JpS6aLe/g9Pqemc9YmeuJeVy6OLk7K4S9ksrPJ/psEDzOFSz +/bdoyNrGj1E8svuR3Bznm53htw1yj+KkxKl4+esUrMZDBcJlOSgYAsOCsp0FvmXt +ll9ldDz7CTUue5wT/RsPXcdtgTpWD8w74a8CLyKsRspGPKAcTNZEtF4uXBVmCeEm +Kf7GUmG6sXP/wwyc5WxqlD8UykAWlYTzWamsX0xhk23RO8yilQwipmdnRC652dKK +QbNmC1r7fSOl8hqw/96bg5Qu0T/fkreRrwU7ZcegbLHNYhLDkBvjJc40vG93drEQ +w/cFGsDWr3RiSBd3kmmQYRzelYB0VI8YHMPzA9C/pEN1hlMYegouCRw2n5H9gooi +S9EOUCXdywMMF8mDAAhONU2Ki+3wApRmLER/y5UnlhetCTCstnEXbosX9hwJ1C07 +mKVx01QT2WDz9UtmT/rx7iASjbSsV7FFY6GsdqnC+w== +-----END CERTIFICATE----- + +# Issuer: CN=SSL.com EV Root Certification Authority ECC O=SSL Corporation +# Subject: CN=SSL.com EV Root Certification Authority ECC O=SSL Corporation +# Label: "SSL.com EV Root Certification Authority ECC" +# Serial: 3182246526754555285 +# MD5 Fingerprint: 59:53:22:65:83:42:01:54:c0:ce:42:b9:5a:7c:f2:90 +# SHA1 Fingerprint: 4c:dd:51:a3:d1:f5:20:32:14:b0:c6:c5:32:23:03:91:c7:46:42:6d +# SHA256 Fingerprint: 22:a2:c1:f7:bd:ed:70:4c:c1:e7:01:b5:f4:08:c3:10:88:0f:e9:56:b5:de:2a:4a:44:f9:9c:87:3a:25:a7:c8 +-----BEGIN CERTIFICATE----- +MIIClDCCAhqgAwIBAgIILCmcWxbtBZUwCgYIKoZIzj0EAwIwfzELMAkGA1UEBhMC +VVMxDjAMBgNVBAgMBVRleGFzMRAwDgYDVQQHDAdIb3VzdG9uMRgwFgYDVQQKDA9T +U0wgQ29ycG9yYXRpb24xNDAyBgNVBAMMK1NTTC5jb20gRVYgUm9vdCBDZXJ0aWZp +Y2F0aW9uIEF1dGhvcml0eSBFQ0MwHhcNMTYwMjEyMTgxNTIzWhcNNDEwMjEyMTgx +NTIzWjB/MQswCQYDVQQGEwJVUzEOMAwGA1UECAwFVGV4YXMxEDAOBgNVBAcMB0hv +dXN0b24xGDAWBgNVBAoMD1NTTCBDb3Jwb3JhdGlvbjE0MDIGA1UEAwwrU1NMLmNv +bSBFViBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IEVDQzB2MBAGByqGSM49 +AgEGBSuBBAAiA2IABKoSR5CYG/vvw0AHgyBO8TCCogbR8pKGYfL2IWjKAMTH6kMA +VIbc/R/fALhBYlzccBYy3h+Z1MzFB8gIH2EWB1E9fVwHU+M1OIzfzZ/ZLg1Kthku +WnBaBu2+8KGwytAJKaNjMGEwHQYDVR0OBBYEFFvKXuXe0oGqzagtZFG22XKbl+ZP +MA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUW8pe5d7SgarNqC1kUbbZcpuX +5k8wDgYDVR0PAQH/BAQDAgGGMAoGCCqGSM49BAMCA2gAMGUCMQCK5kCJN+vp1RPZ +ytRrJPOwPYdGWBrssd9v+1a6cGvHOMzosYxPD/fxZ3YOg9AeUY8CMD32IygmTMZg +h5Mmm7I1HrrW9zzRHM76JTymGoEVW/MSD2zuZYrJh6j5B+BimoxcSg== +-----END CERTIFICATE----- + +# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R6 +# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R6 +# Label: "GlobalSign Root CA - R6" +# Serial: 1417766617973444989252670301619537 +# MD5 Fingerprint: 4f:dd:07:e4:d4:22:64:39:1e:0c:37:42:ea:d1:c6:ae +# SHA1 Fingerprint: 80:94:64:0e:b5:a7:a1:ca:11:9c:1f:dd:d5:9f:81:02:63:a7:fb:d1 +# SHA256 Fingerprint: 2c:ab:ea:fe:37:d0:6c:a2:2a:ba:73:91:c0:03:3d:25:98:29:52:c4:53:64:73:49:76:3a:3a:b5:ad:6c:cf:69 +-----BEGIN CERTIFICATE----- +MIIFgzCCA2ugAwIBAgIORea7A4Mzw4VlSOb/RVEwDQYJKoZIhvcNAQEMBQAwTDEg +MB4GA1UECxMXR2xvYmFsU2lnbiBSb290IENBIC0gUjYxEzARBgNVBAoTCkdsb2Jh +bFNpZ24xEzARBgNVBAMTCkdsb2JhbFNpZ24wHhcNMTQxMjEwMDAwMDAwWhcNMzQx +MjEwMDAwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxTaWduIFJvb3QgQ0EgLSBSNjET +MBEGA1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2lnbjCCAiIwDQYJ +KoZIhvcNAQEBBQADggIPADCCAgoCggIBAJUH6HPKZvnsFMp7PPcNCPG0RQssgrRI +xutbPK6DuEGSMxSkb3/pKszGsIhrxbaJ0cay/xTOURQh7ErdG1rG1ofuTToVBu1k +ZguSgMpE3nOUTvOniX9PeGMIyBJQbUJmL025eShNUhqKGoC3GYEOfsSKvGRMIRxD +aNc9PIrFsmbVkJq3MQbFvuJtMgamHvm566qjuL++gmNQ0PAYid/kD3n16qIfKtJw +LnvnvJO7bVPiSHyMEAc4/2ayd2F+4OqMPKq0pPbzlUoSB239jLKJz9CgYXfIWHSw +1CM69106yqLbnQneXUQtkPGBzVeS+n68UARjNN9rkxi+azayOeSsJDa38O+2HBNX +k7besvjihbdzorg1qkXy4J02oW9UivFyVm4uiMVRQkQVlO6jxTiWm05OWgtH8wY2 +SXcwvHE35absIQh1/OZhFj931dmRl4QKbNQCTXTAFO39OfuD8l4UoQSwC+n+7o/h +bguyCLNhZglqsQY6ZZZZwPA1/cnaKI0aEYdwgQqomnUdnjqGBQCe24DWJfncBZ4n +WUx2OVvq+aWh2IMP0f/fMBH5hc8zSPXKbWQULHpYT9NLCEnFlWQaYw55PfWzjMpY +rZxCRXluDocZXFSxZba/jJvcE+kNb7gu3GduyYsRtYQUigAZcIN5kZeR1Bonvzce +MgfYFGM8KEyvAgMBAAGjYzBhMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTAD +AQH/MB0GA1UdDgQWBBSubAWjkxPioufi1xzWx/B/yGdToDAfBgNVHSMEGDAWgBSu +bAWjkxPioufi1xzWx/B/yGdToDANBgkqhkiG9w0BAQwFAAOCAgEAgyXt6NH9lVLN +nsAEoJFp5lzQhN7craJP6Ed41mWYqVuoPId8AorRbrcWc+ZfwFSY1XS+wc3iEZGt +Ixg93eFyRJa0lV7Ae46ZeBZDE1ZXs6KzO7V33EByrKPrmzU+sQghoefEQzd5Mr61 +55wsTLxDKZmOMNOsIeDjHfrYBzN2VAAiKrlNIC5waNrlU/yDXNOd8v9EDERm8tLj +vUYAGm0CuiVdjaExUd1URhxN25mW7xocBFymFe944Hn+Xds+qkxV/ZoVqW/hpvvf +cDDpw+5CRu3CkwWJ+n1jez/QcYF8AOiYrg54NMMl+68KnyBr3TsTjxKM4kEaSHpz +oHdpx7Zcf4LIHv5YGygrqGytXm3ABdJ7t+uA/iU3/gKbaKxCXcPu9czc8FB10jZp +nOZ7BN9uBmm23goJSFmH63sUYHpkqmlD75HHTOwY3WzvUy2MmeFe8nI+z1TIvWfs +pA9MRf/TuTAjB0yPEL+GltmZWrSZVxykzLsViVO6LAUP5MSeGbEYNNVMnbrt9x+v +JJUEeKgDu+6B5dpffItKoZB0JaezPkvILFa9x8jvOOJckvB595yEunQtYQEgfn7R +8k8HWV+LLUNS60YMlOH1Zkd5d9VUWx+tJDfLRVpOoERIyNiwmcUVhAn21klJwGW4 +5hpxbqCo8YLoRT5s1gLXCmeDBVrJpBA= +-----END CERTIFICATE----- + +# Issuer: CN=OISTE WISeKey Global Root GC CA O=WISeKey OU=OISTE Foundation Endorsed +# Subject: CN=OISTE WISeKey Global Root GC CA O=WISeKey OU=OISTE Foundation Endorsed +# Label: "OISTE WISeKey Global Root GC CA" +# Serial: 44084345621038548146064804565436152554 +# MD5 Fingerprint: a9:d6:b9:2d:2f:93:64:f8:a5:69:ca:91:e9:68:07:23 +# SHA1 Fingerprint: e0:11:84:5e:34:de:be:88:81:b9:9c:f6:16:26:d1:96:1f:c3:b9:31 +# SHA256 Fingerprint: 85:60:f9:1c:36:24:da:ba:95:70:b5:fe:a0:db:e3:6f:f1:1a:83:23:be:94:86:85:4f:b3:f3:4a:55:71:19:8d +-----BEGIN CERTIFICATE----- +MIICaTCCAe+gAwIBAgIQISpWDK7aDKtARb8roi066jAKBggqhkjOPQQDAzBtMQsw +CQYDVQQGEwJDSDEQMA4GA1UEChMHV0lTZUtleTEiMCAGA1UECxMZT0lTVEUgRm91 +bmRhdGlvbiBFbmRvcnNlZDEoMCYGA1UEAxMfT0lTVEUgV0lTZUtleSBHbG9iYWwg +Um9vdCBHQyBDQTAeFw0xNzA1MDkwOTQ4MzRaFw00MjA1MDkwOTU4MzNaMG0xCzAJ +BgNVBAYTAkNIMRAwDgYDVQQKEwdXSVNlS2V5MSIwIAYDVQQLExlPSVNURSBGb3Vu +ZGF0aW9uIEVuZG9yc2VkMSgwJgYDVQQDEx9PSVNURSBXSVNlS2V5IEdsb2JhbCBS +b290IEdDIENBMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAETOlQwMYPchi82PG6s4ni +eUqjFqdrVCTbUf/q9Akkwwsin8tqJ4KBDdLArzHkdIJuyiXZjHWd8dvQmqJLIX4W +p2OQ0jnUsYd4XxiWD1AbNTcPasbc2RNNpI6QN+a9WzGRo1QwUjAOBgNVHQ8BAf8E +BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUSIcUrOPDnpBgOtfKie7T +rYy0UGYwEAYJKwYBBAGCNxUBBAMCAQAwCgYIKoZIzj0EAwMDaAAwZQIwJsdpW9zV +57LnyAyMjMPdeYwbY9XJUpROTYJKcx6ygISpJcBMWm1JKWB4E+J+SOtkAjEA2zQg +Mgj/mkkCtojeFK9dbJlxjRo/i9fgojaGHAeCOnZT/cKi7e97sIBPWA9LUzm9 +-----END CERTIFICATE----- + +# Issuer: CN=GTS Root R1 O=Google Trust Services LLC +# Subject: CN=GTS Root R1 O=Google Trust Services LLC +# Label: "GTS Root R1" +# Serial: 146587175971765017618439757810265552097 +# MD5 Fingerprint: 82:1a:ef:d4:d2:4a:f2:9f:e2:3d:97:06:14:70:72:85 +# SHA1 Fingerprint: e1:c9:50:e6:ef:22:f8:4c:56:45:72:8b:92:20:60:d7:d5:a7:a3:e8 +# SHA256 Fingerprint: 2a:57:54:71:e3:13:40:bc:21:58:1c:bd:2c:f1:3e:15:84:63:20:3e:ce:94:bc:f9:d3:cc:19:6b:f0:9a:54:72 +-----BEGIN CERTIFICATE----- +MIIFWjCCA0KgAwIBAgIQbkepxUtHDA3sM9CJuRz04TANBgkqhkiG9w0BAQwFADBH +MQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExM +QzEUMBIGA1UEAxMLR1RTIFJvb3QgUjEwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIy +MDAwMDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNl +cnZpY2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjEwggIiMA0GCSqGSIb3DQEB +AQUAA4ICDwAwggIKAoICAQC2EQKLHuOhd5s73L+UPreVp0A8of2C+X0yBoJx9vaM +f/vo27xqLpeXo4xL+Sv2sfnOhB2x+cWX3u+58qPpvBKJXqeqUqv4IyfLpLGcY9vX +mX7wCl7raKb0xlpHDU0QM+NOsROjyBhsS+z8CZDfnWQpJSMHobTSPS5g4M/SCYe7 +zUjwTcLCeoiKu7rPWRnWr4+wB7CeMfGCwcDfLqZtbBkOtdh+JhpFAz2weaSUKK0P +fyblqAj+lug8aJRT7oM6iCsVlgmy4HqMLnXWnOunVmSPlk9orj2XwoSPwLxAwAtc +vfaHszVsrBhQf4TgTM2S0yDpM7xSma8ytSmzJSq0SPly4cpk9+aCEI3oncKKiPo4 +Zor8Y/kB+Xj9e1x3+naH+uzfsQ55lVe0vSbv1gHR6xYKu44LtcXFilWr06zqkUsp +zBmkMiVOKvFlRNACzqrOSbTqn3yDsEB750Orp2yjj32JgfpMpf/VjsPOS+C12LOO +Rc92wO1AK/1TD7Cn1TsNsYqiA94xrcx36m97PtbfkSIS5r762DL8EGMUUXLeXdYW +k70paDPvOmbsB4om3xPXV2V4J95eSRQAogB/mqghtqmxlbCluQ0WEdrHbEg8QOB+ +DVrNVjzRlwW5y0vtOUucxD/SVRNuJLDWcfr0wbrM7Rv1/oFB2ACYPTrIrnqYNxgF +lQIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNV +HQ4EFgQU5K8rJnEaK0gnhS9SZizv8IkTcT4wDQYJKoZIhvcNAQEMBQADggIBADiW +Cu49tJYeX++dnAsznyvgyv3SjgofQXSlfKqE1OXyHuY3UjKcC9FhHb8owbZEKTV1 +d5iyfNm9dKyKaOOpMQkpAWBz40d8U6iQSifvS9efk+eCNs6aaAyC58/UEBZvXw6Z +XPYfcX3v73svfuo21pdwCxXu11xWajOl40k4DLh9+42FpLFZXvRq4d2h9mREruZR +gyFmxhE+885H7pwoHyXa/6xmld01D1zvICxi/ZG6qcz8WpyTgYMpl0p8WnK0OdC3 +d8t5/Wk6kjftbjhlRn7pYL15iJdfOBL07q9bgsiG1eGZbYwE8na6SfZu6W0eX6Dv +J4J2QPim01hcDyxC2kLGe4g0x8HYRZvBPsVhHdljUEn2NIVq4BjFbkerQUIpm/Zg +DdIx02OYI5NaAIFItO/Nis3Jz5nu2Z6qNuFoS3FJFDYoOj0dzpqPJeaAcWErtXvM ++SUWgeExX6GjfhaknBZqlxi9dnKlC54dNuYvoS++cJEPqOba+MSSQGwlfnuzCdyy +F62ARPBopY+Udf90WuioAnwMCeKpSwughQtiue+hMZL77/ZRBIls6Kl0obsXs7X9 +SQ98POyDGCBDTtWTurQ0sR8WNh8M5mQ5Fkzc4P4dyKliPUDqysU0ArSuiYgzNdws +E3PYJ/HQcu51OyLemGhmW/HGY0dVHLqlCFF1pkgl +-----END CERTIFICATE----- + +# Issuer: CN=GTS Root R2 O=Google Trust Services LLC +# Subject: CN=GTS Root R2 O=Google Trust Services LLC +# Label: "GTS Root R2" +# Serial: 146587176055767053814479386953112547951 +# MD5 Fingerprint: 44:ed:9a:0e:a4:09:3b:00:f2:ae:4c:a3:c6:61:b0:8b +# SHA1 Fingerprint: d2:73:96:2a:2a:5e:39:9f:73:3f:e1:c7:1e:64:3f:03:38:34:fc:4d +# SHA256 Fingerprint: c4:5d:7b:b0:8e:6d:67:e6:2e:42:35:11:0b:56:4e:5f:78:fd:92:ef:05:8c:84:0a:ea:4e:64:55:d7:58:5c:60 +-----BEGIN CERTIFICATE----- +MIIFWjCCA0KgAwIBAgIQbkepxlqz5yDFMJo/aFLybzANBgkqhkiG9w0BAQwFADBH +MQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExM +QzEUMBIGA1UEAxMLR1RTIFJvb3QgUjIwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIy +MDAwMDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNl +cnZpY2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjIwggIiMA0GCSqGSIb3DQEB +AQUAA4ICDwAwggIKAoICAQDO3v2m++zsFDQ8BwZabFn3GTXd98GdVarTzTukk3Lv +CvptnfbwhYBboUhSnznFt+4orO/LdmgUud+tAWyZH8QiHZ/+cnfgLFuv5AS/T3Kg +GjSY6Dlo7JUle3ah5mm5hRm9iYz+re026nO8/4Piy33B0s5Ks40FnotJk9/BW9Bu +XvAuMC6C/Pq8tBcKSOWIm8Wba96wyrQD8Nr0kLhlZPdcTK3ofmZemde4wj7I0BOd +re7kRXuJVfeKH2JShBKzwkCX44ofR5GmdFrS+LFjKBC4swm4VndAoiaYecb+3yXu +PuWgf9RhD1FLPD+M2uFwdNjCaKH5wQzpoeJ/u1U8dgbuak7MkogwTZq9TwtImoS1 +mKPV+3PBV2HdKFZ1E66HjucMUQkQdYhMvI35ezzUIkgfKtzra7tEscszcTJGr61K +8YzodDqs5xoic4DSMPclQsciOzsSrZYuxsN2B6ogtzVJV+mSSeh2FnIxZyuWfoqj +x5RWIr9qS34BIbIjMt/kmkRtWVtd9QCgHJvGeJeNkP+byKq0rxFROV7Z+2et1VsR +nTKaG73VululycslaVNVJ1zgyjbLiGH7HrfQy+4W+9OmTN6SpdTi3/UGVN4unUu0 +kzCqgc7dGtxRcw1PcOnlthYhGXmy5okLdWTK1au8CcEYof/UVKGFPP0UJAOyh9Ok +twIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNV +HQ4EFgQUu//KjiOfT5nK2+JopqUVJxce2Q4wDQYJKoZIhvcNAQEMBQADggIBALZp +8KZ3/p7uC4Gt4cCpx/k1HUCCq+YEtN/L9x0Pg/B+E02NjO7jMyLDOfxA325BS0JT +vhaI8dI4XsRomRyYUpOM52jtG2pzegVATX9lO9ZY8c6DR2Dj/5epnGB3GFW1fgiT +z9D2PGcDFWEJ+YF59exTpJ/JjwGLc8R3dtyDovUMSRqodt6Sm2T4syzFJ9MHwAiA +pJiS4wGWAqoC7o87xdFtCjMwc3i5T1QWvwsHoaRc5svJXISPD+AVdyx+Jn7axEvb +pxZ3B7DNdehyQtaVhJ2Gg/LkkM0JR9SLA3DaWsYDQvTtN6LwG1BUSw7YhN4ZKJmB +R64JGz9I0cNv4rBgF/XuIwKl2gBbbZCr7qLpGzvpx0QnRY5rn/WkhLx3+WuXrD5R +RaIRpsyF7gpo8j5QOHokYh4XIDdtak23CZvJ/KRY9bb7nE4Yu5UC56GtmwfuNmsk +0jmGwZODUNKBRqhfYlcsu2xkiAhu7xNUX90txGdj08+JN7+dIPT7eoOboB6BAFDC +5AwiWVIQ7UNWhwD4FFKnHYuTjKJNRn8nxnGbJN7k2oaLDX5rIMHAnuFl2GqjpuiF +izoHCBy69Y9Vmhh1fuXsgWbRIXOhNUQLgD1bnF5vKheW0YMjiGZt5obicDIvUiLn +yOd/xCxgXS/Dr55FBcOEArf9LAhST4Ldo/DUhgkC +-----END CERTIFICATE----- + +# Issuer: CN=GTS Root R3 O=Google Trust Services LLC +# Subject: CN=GTS Root R3 O=Google Trust Services LLC +# Label: "GTS Root R3" +# Serial: 146587176140553309517047991083707763997 +# MD5 Fingerprint: 1a:79:5b:6b:04:52:9c:5d:c7:74:33:1b:25:9a:f9:25 +# SHA1 Fingerprint: 30:d4:24:6f:07:ff:db:91:89:8a:0b:e9:49:66:11:eb:8c:5e:46:e5 +# SHA256 Fingerprint: 15:d5:b8:77:46:19:ea:7d:54:ce:1c:a6:d0:b0:c4:03:e0:37:a9:17:f1:31:e8:a0:4e:1e:6b:7a:71:ba:bc:e5 +-----BEGIN CERTIFICATE----- +MIICDDCCAZGgAwIBAgIQbkepx2ypcyRAiQ8DVd2NHTAKBggqhkjOPQQDAzBHMQsw +CQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEU +MBIGA1UEAxMLR1RTIFJvb3QgUjMwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAw +MDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZp +Y2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjMwdjAQBgcqhkjOPQIBBgUrgQQA +IgNiAAQfTzOHMymKoYTey8chWEGJ6ladK0uFxh1MJ7x/JlFyb+Kf1qPKzEUURout +736GjOyxfi//qXGdGIRFBEFVbivqJn+7kAHjSxm65FSWRQmx1WyRRK2EE46ajA2A +DDL24CejQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1Ud +DgQWBBTB8Sa6oC2uhYHP0/EqEr24Cmf9vDAKBggqhkjOPQQDAwNpADBmAjEAgFuk +fCPAlaUs3L6JbyO5o91lAFJekazInXJ0glMLfalAvWhgxeG4VDvBNhcl2MG9AjEA +njWSdIUlUfUk7GRSJFClH9voy8l27OyCbvWFGFPouOOaKaqW04MjyaR7YbPMAuhd +-----END CERTIFICATE----- + +# Issuer: CN=GTS Root R4 O=Google Trust Services LLC +# Subject: CN=GTS Root R4 O=Google Trust Services LLC +# Label: "GTS Root R4" +# Serial: 146587176229350439916519468929765261721 +# MD5 Fingerprint: 5d:b6:6a:c4:60:17:24:6a:1a:99:a8:4b:ee:5e:b4:26 +# SHA1 Fingerprint: 2a:1d:60:27:d9:4a:b1:0a:1c:4d:91:5c:cd:33:a0:cb:3e:2d:54:cb +# SHA256 Fingerprint: 71:cc:a5:39:1f:9e:79:4b:04:80:25:30:b3:63:e1:21:da:8a:30:43:bb:26:66:2f:ea:4d:ca:7f:c9:51:a4:bd +-----BEGIN CERTIFICATE----- +MIICCjCCAZGgAwIBAgIQbkepyIuUtui7OyrYorLBmTAKBggqhkjOPQQDAzBHMQsw +CQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEU +MBIGA1UEAxMLR1RTIFJvb3QgUjQwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAw +MDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZp +Y2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjQwdjAQBgcqhkjOPQIBBgUrgQQA +IgNiAATzdHOnaItgrkO4NcWBMHtLSZ37wWHO5t5GvWvVYRg1rkDdc/eJkTBa6zzu +hXyiQHY7qca4R9gq55KRanPpsXI5nymfopjTX15YhmUPoYRlBtHci8nHc8iMai/l +xKvRHYqjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1Ud +DgQWBBSATNbrdP9JNqPV2Py1PsVq8JQdjDAKBggqhkjOPQQDAwNnADBkAjBqUFJ0 +CMRw3J5QdCHojXohw0+WbhXRIjVhLfoIN+4Zba3bssx9BzT1YBkstTTZbyACMANx +sbqjYAuG7ZoIapVon+Kz4ZNkfF6Tpt95LY2F45TPI11xzPKwTdb+mciUqXWi4w== +-----END CERTIFICATE----- + +# Issuer: CN=UCA Global G2 Root O=UniTrust +# Subject: CN=UCA Global G2 Root O=UniTrust +# Label: "UCA Global G2 Root" +# Serial: 124779693093741543919145257850076631279 +# MD5 Fingerprint: 80:fe:f0:c4:4a:f0:5c:62:32:9f:1c:ba:78:a9:50:f8 +# SHA1 Fingerprint: 28:f9:78:16:19:7a:ff:18:25:18:aa:44:fe:c1:a0:ce:5c:b6:4c:8a +# SHA256 Fingerprint: 9b:ea:11:c9:76:fe:01:47:64:c1:be:56:a6:f9:14:b5:a5:60:31:7a:bd:99:88:39:33:82:e5:16:1a:a0:49:3c +-----BEGIN CERTIFICATE----- +MIIFRjCCAy6gAwIBAgIQXd+x2lqj7V2+WmUgZQOQ7zANBgkqhkiG9w0BAQsFADA9 +MQswCQYDVQQGEwJDTjERMA8GA1UECgwIVW5pVHJ1c3QxGzAZBgNVBAMMElVDQSBH +bG9iYWwgRzIgUm9vdDAeFw0xNjAzMTEwMDAwMDBaFw00MDEyMzEwMDAwMDBaMD0x +CzAJBgNVBAYTAkNOMREwDwYDVQQKDAhVbmlUcnVzdDEbMBkGA1UEAwwSVUNBIEds +b2JhbCBHMiBSb290MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAxeYr +b3zvJgUno4Ek2m/LAfmZmqkywiKHYUGRO8vDaBsGxUypK8FnFyIdK+35KYmToni9 +kmugow2ifsqTs6bRjDXVdfkX9s9FxeV67HeToI8jrg4aA3++1NDtLnurRiNb/yzm +VHqUwCoV8MmNsHo7JOHXaOIxPAYzRrZUEaalLyJUKlgNAQLx+hVRZ2zA+te2G3/R +VogvGjqNO7uCEeBHANBSh6v7hn4PJGtAnTRnvI3HLYZveT6OqTwXS3+wmeOwcWDc +C/Vkw85DvG1xudLeJ1uK6NjGruFZfc8oLTW4lVYa8bJYS7cSN8h8s+1LgOGN+jIj +tm+3SJUIsUROhYw6AlQgL9+/V087OpAh18EmNVQg7Mc/R+zvWr9LesGtOxdQXGLY +D0tK3Cv6brxzks3sx1DoQZbXqX5t2Okdj4q1uViSukqSKwxW/YDrCPBeKW4bHAyv +j5OJrdu9o54hyokZ7N+1wxrrFv54NkzWbtA+FxyQF2smuvt6L78RHBgOLXMDj6Dl +NaBa4kx1HXHhOThTeEDMg5PXCp6dW4+K5OXgSORIskfNTip1KnvyIvbJvgmRlld6 +iIis7nCs+dwp4wwcOxJORNanTrAmyPPZGpeRaOrvjUYG0lZFWJo8DA+DuAUlwznP +O6Q0ibd5Ei9Hxeepl2n8pndntd978XplFeRhVmUCAwEAAaNCMEAwDgYDVR0PAQH/ +BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFIHEjMz15DD/pQwIX4wV +ZyF0Ad/fMA0GCSqGSIb3DQEBCwUAA4ICAQATZSL1jiutROTL/7lo5sOASD0Ee/oj +L3rtNtqyzm325p7lX1iPyzcyochltq44PTUbPrw7tgTQvPlJ9Zv3hcU2tsu8+Mg5 +1eRfB70VVJd0ysrtT7q6ZHafgbiERUlMjW+i67HM0cOU2kTC5uLqGOiiHycFutfl +1qnN3e92mI0ADs0b+gO3joBYDic/UvuUospeZcnWhNq5NXHzJsBPd+aBJ9J3O5oU +b3n09tDh05S60FdRvScFDcH9yBIw7m+NESsIndTUv4BFFJqIRNow6rSn4+7vW4LV +PtateJLbXDzz2K36uGt/xDYotgIVilQsnLAXc47QN6MUPJiVAAwpBVueSUmxX8fj +y88nZY41F7dXyDDZQVu5FLbowg+UMaeUmMxq67XhJ/UQqAHojhJi6IjMtX9Gl8Cb +EGY4GjZGXyJoPd/JxhMnq1MGrKI8hgZlb7F+sSlEmqO6SWkoaY/X5V+tBIZkbxqg +DMUIYs6Ao9Dz7GjevjPHF1t/gMRMTLGmhIrDO7gJzRSBuhjjVFc2/tsvfEehOjPI ++Vg7RE+xygKJBJYoaMVLuCaJu9YzL1DV/pqJuhgyklTGW+Cd+V7lDSKb9triyCGy +YiGqhkCyLmTTX8jjfhFnRR8F/uOi77Oos/N9j/gMHyIfLXC0uAE0djAA5SN4p1bX +UB+K+wb1whnw0A== +-----END CERTIFICATE----- + +# Issuer: CN=UCA Extended Validation Root O=UniTrust +# Subject: CN=UCA Extended Validation Root O=UniTrust +# Label: "UCA Extended Validation Root" +# Serial: 106100277556486529736699587978573607008 +# MD5 Fingerprint: a1:f3:5f:43:c6:34:9b:da:bf:8c:7e:05:53:ad:96:e2 +# SHA1 Fingerprint: a3:a1:b0:6f:24:61:23:4a:e3:36:a5:c2:37:fc:a6:ff:dd:f0:d7:3a +# SHA256 Fingerprint: d4:3a:f9:b3:54:73:75:5c:96:84:fc:06:d7:d8:cb:70:ee:5c:28:e7:73:fb:29:4e:b4:1e:e7:17:22:92:4d:24 +-----BEGIN CERTIFICATE----- +MIIFWjCCA0KgAwIBAgIQT9Irj/VkyDOeTzRYZiNwYDANBgkqhkiG9w0BAQsFADBH +MQswCQYDVQQGEwJDTjERMA8GA1UECgwIVW5pVHJ1c3QxJTAjBgNVBAMMHFVDQSBF +eHRlbmRlZCBWYWxpZGF0aW9uIFJvb3QwHhcNMTUwMzEzMDAwMDAwWhcNMzgxMjMx +MDAwMDAwWjBHMQswCQYDVQQGEwJDTjERMA8GA1UECgwIVW5pVHJ1c3QxJTAjBgNV +BAMMHFVDQSBFeHRlbmRlZCBWYWxpZGF0aW9uIFJvb3QwggIiMA0GCSqGSIb3DQEB +AQUAA4ICDwAwggIKAoICAQCpCQcoEwKwmeBkqh5DFnpzsZGgdT6o+uM4AHrsiWog +D4vFsJszA1qGxliG1cGFu0/GnEBNyr7uaZa4rYEwmnySBesFK5pI0Lh2PpbIILvS +sPGP2KxFRv+qZ2C0d35qHzwaUnoEPQc8hQ2E0B92CvdqFN9y4zR8V05WAT558aop +O2z6+I9tTcg1367r3CTueUWnhbYFiN6IXSV8l2RnCdm/WhUFhvMJHuxYMjMR83dk +sHYf5BA1FxvyDrFspCqjc/wJHx4yGVMR59mzLC52LqGj3n5qiAno8geK+LLNEOfi +c0CTuwjRP+H8C5SzJe98ptfRr5//lpr1kXuYC3fUfugH0mK1lTnj8/FtDw5lhIpj +VMWAtuCeS31HJqcBCF3RiJ7XwzJE+oJKCmhUfzhTA8ykADNkUVkLo4KRel7sFsLz +KuZi2irbWWIQJUoqgQtHB0MGcIfS+pMRKXpITeuUx3BNr2fVUbGAIAEBtHoIppB/ +TuDvB0GHr2qlXov7z1CymlSvw4m6WC31MJixNnI5fkkE/SmnTHnkBVfblLkWU41G +sx2VYVdWf6/wFlthWG82UBEL2KwrlRYaDh8IzTY0ZRBiZtWAXxQgXy0MoHgKaNYs +1+lvK9JKBZP8nm9rZ/+I8U6laUpSNwXqxhaN0sSZ0YIrO7o1dfdRUVjzyAfd5LQD +fwIDAQABo0IwQDAdBgNVHQ4EFgQU2XQ65DA9DfcS3H5aBZ8eNJr34RQwDwYDVR0T +AQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAYYwDQYJKoZIhvcNAQELBQADggIBADaN +l8xCFWQpN5smLNb7rhVpLGsaGvdftvkHTFnq88nIua7Mui563MD1sC3AO6+fcAUR +ap8lTwEpcOPlDOHqWnzcSbvBHiqB9RZLcpHIojG5qtr8nR/zXUACE/xOHAbKsxSQ +VBcZEhrxH9cMaVr2cXj0lH2RC47skFSOvG+hTKv8dGT9cZr4QQehzZHkPJrgmzI5 +c6sq1WnIeJEmMX3ixzDx/BR4dxIOE/TdFpS/S2d7cFOFyrC78zhNLJA5wA3CXWvp +4uXViI3WLL+rG761KIcSF3Ru/H38j9CHJrAb+7lsq+KePRXBOy5nAliRn+/4Qh8s +t2j1da3Ptfb/EX3C8CSlrdP6oDyp+l3cpaDvRKS+1ujl5BOWF3sGPjLtx7dCvHaj +2GU4Kzg1USEODm8uNBNA4StnDG1KQTAYI1oyVZnJF+A83vbsea0rWBmirSwiGpWO +vpaQXUJXxPkUAzUrHC1RVwinOt4/5Mi0A3PCwSaAuwtCH60NryZy2sy+s6ODWA2C +xR9GUeOcGMyNm43sSet1UNWMKFnKdDTajAshqx7qG+XH/RU+wBeq+yNuJkbL+vmx +cmtpzyKEC2IPrNkZAJSidjzULZrtBJ4tBmIQN1IchXIbJ+XMxjHsN+xjWZsLHXbM +fjKaiJUINlK73nZfdklJrX+9ZSCyycErdhh2n1ax +-----END CERTIFICATE----- + +# Issuer: CN=Certigna Root CA O=Dhimyotis OU=0002 48146308100036 +# Subject: CN=Certigna Root CA O=Dhimyotis OU=0002 48146308100036 +# Label: "Certigna Root CA" +# Serial: 269714418870597844693661054334862075617 +# MD5 Fingerprint: 0e:5c:30:62:27:eb:5b:bc:d7:ae:62:ba:e9:d5:df:77 +# SHA1 Fingerprint: 2d:0d:52:14:ff:9e:ad:99:24:01:74:20:47:6e:6c:85:27:27:f5:43 +# SHA256 Fingerprint: d4:8d:3d:23:ee:db:50:a4:59:e5:51:97:60:1c:27:77:4b:9d:7b:18:c9:4d:5a:05:95:11:a1:02:50:b9:31:68 +-----BEGIN CERTIFICATE----- +MIIGWzCCBEOgAwIBAgIRAMrpG4nxVQMNo+ZBbcTjpuEwDQYJKoZIhvcNAQELBQAw +WjELMAkGA1UEBhMCRlIxEjAQBgNVBAoMCURoaW15b3RpczEcMBoGA1UECwwTMDAw +MiA0ODE0NjMwODEwMDAzNjEZMBcGA1UEAwwQQ2VydGlnbmEgUm9vdCBDQTAeFw0x +MzEwMDEwODMyMjdaFw0zMzEwMDEwODMyMjdaMFoxCzAJBgNVBAYTAkZSMRIwEAYD +VQQKDAlEaGlteW90aXMxHDAaBgNVBAsMEzAwMDIgNDgxNDYzMDgxMDAwMzYxGTAX +BgNVBAMMEENlcnRpZ25hIFJvb3QgQ0EwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAw +ggIKAoICAQDNGDllGlmx6mQWDoyUJJV8g9PFOSbcDO8WV43X2KyjQn+Cyu3NW9sO +ty3tRQgXstmzy9YXUnIo245Onoq2C/mehJpNdt4iKVzSs9IGPjA5qXSjklYcoW9M +CiBtnyN6tMbaLOQdLNyzKNAT8kxOAkmhVECe5uUFoC2EyP+YbNDrihqECB63aCPu +I9Vwzm1RaRDuoXrC0SIxwoKF0vJVdlB8JXrJhFwLrN1CTivngqIkicuQstDuI7pm +TLtipPlTWmR7fJj6o0ieD5Wupxj0auwuA0Wv8HT4Ks16XdG+RCYyKfHx9WzMfgIh +C59vpD++nVPiz32pLHxYGpfhPTc3GGYo0kDFUYqMwy3OU4gkWGQwFsWq4NYKpkDf +ePb1BHxpE4S80dGnBs8B92jAqFe7OmGtBIyT46388NtEbVncSVmurJqZNjBBe3Yz +IoejwpKGbvlw7q6Hh5UbxHq9MfPU0uWZ/75I7HX1eBYdpnDBfzwboZL7z8g81sWT +Co/1VTp2lc5ZmIoJlXcymoO6LAQ6l73UL77XbJuiyn1tJslV1c/DeVIICZkHJC1k +JWumIWmbat10TWuXekG9qxf5kBdIjzb5LdXF2+6qhUVB+s06RbFo5jZMm5BX7CO5 +hwjCxAnxl4YqKE3idMDaxIzb3+KhF1nOJFl0Mdp//TBt2dzhauH8XwIDAQABo4IB +GjCCARYwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYE +FBiHVuBud+4kNTxOc5of1uHieX4rMB8GA1UdIwQYMBaAFBiHVuBud+4kNTxOc5of +1uHieX4rMEQGA1UdIAQ9MDswOQYEVR0gADAxMC8GCCsGAQUFBwIBFiNodHRwczov +L3d3d3cuY2VydGlnbmEuZnIvYXV0b3JpdGVzLzBtBgNVHR8EZjBkMC+gLaArhilo +dHRwOi8vY3JsLmNlcnRpZ25hLmZyL2NlcnRpZ25hcm9vdGNhLmNybDAxoC+gLYYr +aHR0cDovL2NybC5kaGlteW90aXMuY29tL2NlcnRpZ25hcm9vdGNhLmNybDANBgkq +hkiG9w0BAQsFAAOCAgEAlLieT/DjlQgi581oQfccVdV8AOItOoldaDgvUSILSo3L +6btdPrtcPbEo/uRTVRPPoZAbAh1fZkYJMyjhDSSXcNMQH+pkV5a7XdrnxIxPTGRG +HVyH41neQtGbqH6mid2PHMkwgu07nM3A6RngatgCdTer9zQoKJHyBApPNeNgJgH6 +0BGM+RFq7q89w1DTj18zeTyGqHNFkIwgtnJzFyO+B2XleJINugHA64wcZr+shncB +lA2c5uk5jR+mUYyZDDl34bSb+hxnV29qao6pK0xXeXpXIs/NX2NGjVxZOob4Mkdi +o2cNGJHc+6Zr9UhhcyNZjgKnvETq9Emd8VRY+WCv2hikLyhF3HqgiIZd8zvn/yk1 +gPxkQ5Tm4xxvvq0OKmOZK8l+hfZx6AYDlf7ej0gcWtSS6Cvu5zHbugRqh5jnxV/v +faci9wHYTfmJ0A6aBVmknpjZbyvKcL5kwlWj9Omvw5Ip3IgWJJk8jSaYtlu3zM63 +Nwf9JtmYhST/WSMDmu2dnajkXjjO11INb9I/bbEFa0nOipFGc/T2L/Coc3cOZayh +jWZSaX5LaAzHHjcng6WMxwLkFM1JAbBzs/3GkDpv0mztO+7skb6iQ12LAEpmJURw +3kAP+HwV96LOPNdeE4yBFxgX0b3xdxA61GU5wSesVywlVP+i2k+KYTlerj1KjL0= +-----END CERTIFICATE----- + +# Issuer: CN=emSign Root CA - G1 O=eMudhra Technologies Limited OU=emSign PKI +# Subject: CN=emSign Root CA - G1 O=eMudhra Technologies Limited OU=emSign PKI +# Label: "emSign Root CA - G1" +# Serial: 235931866688319308814040 +# MD5 Fingerprint: 9c:42:84:57:dd:cb:0b:a7:2e:95:ad:b6:f3:da:bc:ac +# SHA1 Fingerprint: 8a:c7:ad:8f:73:ac:4e:c1:b5:75:4d:a5:40:f4:fc:cf:7c:b5:8e:8c +# SHA256 Fingerprint: 40:f6:af:03:46:a9:9a:a1:cd:1d:55:5a:4e:9c:ce:62:c7:f9:63:46:03:ee:40:66:15:83:3d:c8:c8:d0:03:67 +-----BEGIN CERTIFICATE----- +MIIDlDCCAnygAwIBAgIKMfXkYgxsWO3W2DANBgkqhkiG9w0BAQsFADBnMQswCQYD +VQQGEwJJTjETMBEGA1UECxMKZW1TaWduIFBLSTElMCMGA1UEChMcZU11ZGhyYSBU +ZWNobm9sb2dpZXMgTGltaXRlZDEcMBoGA1UEAxMTZW1TaWduIFJvb3QgQ0EgLSBH +MTAeFw0xODAyMTgxODMwMDBaFw00MzAyMTgxODMwMDBaMGcxCzAJBgNVBAYTAklO +MRMwEQYDVQQLEwplbVNpZ24gUEtJMSUwIwYDVQQKExxlTXVkaHJhIFRlY2hub2xv +Z2llcyBMaW1pdGVkMRwwGgYDVQQDExNlbVNpZ24gUm9vdCBDQSAtIEcxMIIBIjAN +BgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAk0u76WaK7p1b1TST0Bsew+eeuGQz +f2N4aLTNLnF115sgxk0pvLZoYIr3IZpWNVrzdr3YzZr/k1ZLpVkGoZM0Kd0WNHVO +8oG0x5ZOrRkVUkr+PHB1cM2vK6sVmjM8qrOLqs1D/fXqcP/tzxE7lM5OMhbTI0Aq +d7OvPAEsbO2ZLIvZTmmYsvePQbAyeGHWDV/D+qJAkh1cF+ZwPjXnorfCYuKrpDhM +tTk1b+oDafo6VGiFbdbyL0NVHpENDtjVaqSW0RM8LHhQ6DqS0hdW5TUaQBw+jSzt +Od9C4INBdN+jzcKGYEho42kLVACL5HZpIQ15TjQIXhTCzLG3rdd8cIrHhQIDAQAB +o0IwQDAdBgNVHQ4EFgQU++8Nhp6w492pufEhF38+/PB3KxowDgYDVR0PAQH/BAQD +AgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQELBQADggEBAFn/8oz1h31x +PaOfG1vR2vjTnGs2vZupYeveFix0PZ7mddrXuqe8QhfnPZHr5X3dPpzxz5KsbEjM +wiI/aTvFthUvozXGaCocV685743QNcMYDHsAVhzNixl03r4PEuDQqqE/AjSxcM6d +GNYIAwlG7mDgfrbESQRRfXBgvKqy/3lyeqYdPV8q+Mri/Tm3R7nrft8EI6/6nAYH +6ftjk4BAtcZsCjEozgyfz7MjNYBBjWzEN3uBL4ChQEKF6dk4jeihU80Bv2noWgby +RQuQ+q7hv53yrlc8pa6yVvSLZUDp/TGBLPQ5Cdjua6e0ph0VpZj3AYHYhX3zUVxx +iN66zB+Afko= +-----END CERTIFICATE----- + +# Issuer: CN=emSign ECC Root CA - G3 O=eMudhra Technologies Limited OU=emSign PKI +# Subject: CN=emSign ECC Root CA - G3 O=eMudhra Technologies Limited OU=emSign PKI +# Label: "emSign ECC Root CA - G3" +# Serial: 287880440101571086945156 +# MD5 Fingerprint: ce:0b:72:d1:9f:88:8e:d0:50:03:e8:e3:b8:8b:67:40 +# SHA1 Fingerprint: 30:43:fa:4f:f2:57:dc:a0:c3:80:ee:2e:58:ea:78:b2:3f:e6:bb:c1 +# SHA256 Fingerprint: 86:a1:ec:ba:08:9c:4a:8d:3b:be:27:34:c6:12:ba:34:1d:81:3e:04:3c:f9:e8:a8:62:cd:5c:57:a3:6b:be:6b +-----BEGIN CERTIFICATE----- +MIICTjCCAdOgAwIBAgIKPPYHqWhwDtqLhDAKBggqhkjOPQQDAzBrMQswCQYDVQQG +EwJJTjETMBEGA1UECxMKZW1TaWduIFBLSTElMCMGA1UEChMcZU11ZGhyYSBUZWNo +bm9sb2dpZXMgTGltaXRlZDEgMB4GA1UEAxMXZW1TaWduIEVDQyBSb290IENBIC0g +RzMwHhcNMTgwMjE4MTgzMDAwWhcNNDMwMjE4MTgzMDAwWjBrMQswCQYDVQQGEwJJ +TjETMBEGA1UECxMKZW1TaWduIFBLSTElMCMGA1UEChMcZU11ZGhyYSBUZWNobm9s +b2dpZXMgTGltaXRlZDEgMB4GA1UEAxMXZW1TaWduIEVDQyBSb290IENBIC0gRzMw +djAQBgcqhkjOPQIBBgUrgQQAIgNiAAQjpQy4LRL1KPOxst3iAhKAnjlfSU2fySU0 +WXTsuwYc58Byr+iuL+FBVIcUqEqy6HyC5ltqtdyzdc6LBtCGI79G1Y4PPwT01xyS +fvalY8L1X44uT6EYGQIrMgqCZH0Wk9GjQjBAMB0GA1UdDgQWBBR8XQKEE9TMipuB +zhccLikenEhjQjAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAKBggq +hkjOPQQDAwNpADBmAjEAvvNhzwIQHWSVB7gYboiFBS+DCBeQyh+KTOgNG3qxrdWB +CUfvO6wIBHxcmbHtRwfSAjEAnbpV/KlK6O3t5nYBQnvI+GDZjVGLVTv7jHvrZQnD ++JbNR6iC8hZVdyR+EhCVBCyj +-----END CERTIFICATE----- + +# Issuer: CN=emSign Root CA - C1 O=eMudhra Inc OU=emSign PKI +# Subject: CN=emSign Root CA - C1 O=eMudhra Inc OU=emSign PKI +# Label: "emSign Root CA - C1" +# Serial: 825510296613316004955058 +# MD5 Fingerprint: d8:e3:5d:01:21:fa:78:5a:b0:df:ba:d2:ee:2a:5f:68 +# SHA1 Fingerprint: e7:2e:f1:df:fc:b2:09:28:cf:5d:d4:d5:67:37:b1:51:cb:86:4f:01 +# SHA256 Fingerprint: 12:56:09:aa:30:1d:a0:a2:49:b9:7a:82:39:cb:6a:34:21:6f:44:dc:ac:9f:39:54:b1:42:92:f2:e8:c8:60:8f +-----BEGIN CERTIFICATE----- +MIIDczCCAlugAwIBAgILAK7PALrEzzL4Q7IwDQYJKoZIhvcNAQELBQAwVjELMAkG +A1UEBhMCVVMxEzARBgNVBAsTCmVtU2lnbiBQS0kxFDASBgNVBAoTC2VNdWRocmEg +SW5jMRwwGgYDVQQDExNlbVNpZ24gUm9vdCBDQSAtIEMxMB4XDTE4MDIxODE4MzAw +MFoXDTQzMDIxODE4MzAwMFowVjELMAkGA1UEBhMCVVMxEzARBgNVBAsTCmVtU2ln +biBQS0kxFDASBgNVBAoTC2VNdWRocmEgSW5jMRwwGgYDVQQDExNlbVNpZ24gUm9v +dCBDQSAtIEMxMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAz+upufGZ +BczYKCFK83M0UYRWEPWgTywS4/oTmifQz/l5GnRfHXk5/Fv4cI7gklL35CX5VIPZ +HdPIWoU/Xse2B+4+wM6ar6xWQio5JXDWv7V7Nq2s9nPczdcdioOl+yuQFTdrHCZH +3DspVpNqs8FqOp099cGXOFgFixwR4+S0uF2FHYP+eF8LRWgYSKVGczQ7/g/IdrvH +GPMF0Ybzhe3nudkyrVWIzqa2kbBPrH4VI5b2P/AgNBbeCsbEBEV5f6f9vtKppa+c +xSMq9zwhbL2vj07FOrLzNBL834AaSaTUqZX3noleoomslMuoaJuvimUnzYnu3Yy1 +aylwQ6BpC+S5DwIDAQABo0IwQDAdBgNVHQ4EFgQU/qHgcB4qAzlSWkK+XJGFehiq +TbUwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEL +BQADggEBAMJKVvoVIXsoounlHfv4LcQ5lkFMOycsxGwYFYDGrK9HWS8mC+M2sO87 +/kOXSTKZEhVb3xEp/6tT+LvBeA+snFOvV71ojD1pM/CjoCNjO2RnIkSt1XHLVip4 +kqNPEjE2NuLe/gDEo2APJ62gsIq1NnpSob0n9CAnYuhNlCQT5AoE6TyrLshDCUrG +YQTlSTR+08TI9Q/Aqum6VF7zYytPT1DU/rl7mYw9wC68AivTxEDkigcxHpvOJpkT ++xHqmiIMERnHXhuBUDDIlhJu58tBf5E7oke3VIAb3ADMmpDqw8NQBmIMMMAVSKeo +WXzhriKi4gp6D/piq1JM4fHfyr6DDUI= +-----END CERTIFICATE----- + +# Issuer: CN=emSign ECC Root CA - C3 O=eMudhra Inc OU=emSign PKI +# Subject: CN=emSign ECC Root CA - C3 O=eMudhra Inc OU=emSign PKI +# Label: "emSign ECC Root CA - C3" +# Serial: 582948710642506000014504 +# MD5 Fingerprint: 3e:53:b3:a3:81:ee:d7:10:f8:d3:b0:1d:17:92:f5:d5 +# SHA1 Fingerprint: b6:af:43:c2:9b:81:53:7d:f6:ef:6b:c3:1f:1f:60:15:0c:ee:48:66 +# SHA256 Fingerprint: bc:4d:80:9b:15:18:9d:78:db:3e:1d:8c:f4:f9:72:6a:79:5d:a1:64:3c:a5:f1:35:8e:1d:db:0e:dc:0d:7e:b3 +-----BEGIN CERTIFICATE----- +MIICKzCCAbGgAwIBAgIKe3G2gla4EnycqDAKBggqhkjOPQQDAzBaMQswCQYDVQQG +EwJVUzETMBEGA1UECxMKZW1TaWduIFBLSTEUMBIGA1UEChMLZU11ZGhyYSBJbmMx +IDAeBgNVBAMTF2VtU2lnbiBFQ0MgUm9vdCBDQSAtIEMzMB4XDTE4MDIxODE4MzAw +MFoXDTQzMDIxODE4MzAwMFowWjELMAkGA1UEBhMCVVMxEzARBgNVBAsTCmVtU2ln +biBQS0kxFDASBgNVBAoTC2VNdWRocmEgSW5jMSAwHgYDVQQDExdlbVNpZ24gRUND +IFJvb3QgQ0EgLSBDMzB2MBAGByqGSM49AgEGBSuBBAAiA2IABP2lYa57JhAd6bci +MK4G9IGzsUJxlTm801Ljr6/58pc1kjZGDoeVjbk5Wum739D+yAdBPLtVb4Ojavti +sIGJAnB9SMVK4+kiVCJNk7tCDK93nCOmfddhEc5lx/h//vXyqaNCMEAwHQYDVR0O +BBYEFPtaSNCAIEDyqOkAB2kZd6fmw/TPMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMB +Af8EBTADAQH/MAoGCCqGSM49BAMDA2gAMGUCMQC02C8Cif22TGK6Q04ThHK1rt0c +3ta13FaPWEBaLd4gTCKDypOofu4SQMfWh0/434UCMBwUZOR8loMRnLDRWmFLpg9J +0wD8ofzkpf9/rdcw0Md3f76BB1UwUCAU9Vc4CqgxUQ== +-----END CERTIFICATE----- + +# Issuer: CN=Hongkong Post Root CA 3 O=Hongkong Post +# Subject: CN=Hongkong Post Root CA 3 O=Hongkong Post +# Label: "Hongkong Post Root CA 3" +# Serial: 46170865288971385588281144162979347873371282084 +# MD5 Fingerprint: 11:fc:9f:bd:73:30:02:8a:fd:3f:f3:58:b9:cb:20:f0 +# SHA1 Fingerprint: 58:a2:d0:ec:20:52:81:5b:c1:f3:f8:64:02:24:4e:c2:8e:02:4b:02 +# SHA256 Fingerprint: 5a:2f:c0:3f:0c:83:b0:90:bb:fa:40:60:4b:09:88:44:6c:76:36:18:3d:f9:84:6e:17:10:1a:44:7f:b8:ef:d6 +-----BEGIN CERTIFICATE----- +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 +mpv0 +-----END CERTIFICATE----- diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/core.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/core.py new file mode 100644 index 0000000..7271acf --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/certifi/core.py @@ -0,0 +1,15 @@ +# -*- coding: utf-8 -*- + +""" +certifi.py +~~~~~~~~~~ + +This module returns the installation location of cacert.pem. +""" +import os + + +def where(): + f = os.path.dirname(__file__) + + return os.path.join(f, 'cacert.pem') diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__init__.py new file mode 100644 index 0000000..0f9f820 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__init__.py @@ -0,0 +1,39 @@ +######################## BEGIN LICENSE BLOCK ######################## +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + + +from .compat import PY2, PY3 +from .universaldetector import UniversalDetector +from .version import __version__, VERSION + + +def detect(byte_str): + """ + Detect the encoding of the given byte string. + + :param byte_str: The byte sequence to examine. + :type byte_str: ``bytes`` or ``bytearray`` + """ + if not isinstance(byte_str, bytearray): + if not isinstance(byte_str, bytes): + raise TypeError('Expected object of type bytes or bytearray, got: ' + '{0}'.format(type(byte_str))) + else: + byte_str = bytearray(byte_str) + detector = UniversalDetector() + detector.feed(byte_str) + return detector.close() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..12fdbd5e0a32c15e9cdfa8f7cb6b6b75250055e7 GIT binary patch literal 862 zcmYjQ!H&}~5VeyuNdqfw;Q&V;sl+yAK`UAzgann~vLLpLL@%kgaoentIP17oTiOfd zL$>0?jqmZ56F<O#3yj?scBGli*z;zd?aBGUL4ZJhec#Y~E<!(aa8oP@UVxTQ!Ne%W zDavpUXI9U`I<`_fb9#>P?X;4)JvZ}u9>h*u`GR_W?4F^z_Y(uWZYlfS$75|C*RiUd z=gE|blBTbiWCO_sB;1N3y_WDiij?=E^ZxA3+tYzY??p4JfW8DRUxSfoi6mZIWz%>T zcn_o<<7-D&mS~MPc#S{f+?QBKD<s`DTHz(W_LgXaF#^xuAYf@Nz6JzjONYoYBP<{A zILSwZ4^2D*#yPo|OGZj5V51QjNV}kdW@aOTjkYdBx=>)7%C06*i4n;Oo6#)ESz`;6 z^J1IxA4U3o4J!M6!o@D2LeP1?Z!n7|omm0b#bUxQF2OO}_H{}P(s%=TNJd<?$*1P3 zUR6O-CV43-5K+~CDXL<+scIKWbcEnSxkD~8DwU(z2?wrNIYY)`RT-qbWbjJ9#%RjQ zk9TkP4T&0L{=NzekxZ#%;gpJS$kP~}Gi=SmQPi4>Y>^)iFPr1>Y_W*a*2%?KG(kpr z*bR%MI5Gs&^r+c9na-z=CVJ5*Ohq1Z5e~*wK+7<Sl01=7)F|f4-Ez3E2jUJG<OMju zE_VO;wh!L`i@UIT3U}ZRcves;^biRfjH*rcQ@B6L_Qc+9427OG0lx+^Ma&^@7~N0# U&oUlQQubW8DRu54zKsv<zt}GFS^xk5 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6ab45e14d81d81256c3c9f3e024bd70d92c7f39e GIT binary patch literal 27191 zcmYk^b+nLm_BC+2Q@XpmyBp~c!9bdebP3qfph$OjcT0DRl!7rT`G9oy@A=&KpVzhK z%!z&W+2?$pd!4~q(>!6qcu~T?o~)hMCgq?gQ7#Mq|G%P!LFMpYeUgNxeUw&F+DB~_ zwSBZ!(b`9E8YNGRPGL6u>qey@N{T2^ax;OJh`6ys^KZ;Bd@G#7I~00BT&4*VOJQuX z&|4=wCTx=^G&f>|CT9FF*In*fm<zJ-jwMhC`Ga~o^2=3?6MDo&d>3{^j1I$ysR$-S z3(erfVKuGl=LtjeQMhcxYSkfOAtI$*m#{fvdPo|vL~lV}1HBQvmEj&in2!>iV9KJJ zoisG#Lg5kLt5%X5FPy+sh$IM?3*Oc77c&RsQ-gYi`$rrJuMsg3_%a2_!nK0GL1I~< zt$m|w^E44dDc$XU8HAUu(8CHvfhW3iM2HT)Q#~G1MYK~bO~xcM=8zl1ZZE@J@Ct6Z z1t*8qV2to{dwdak!71V3kU7Z8yF%X(`YH=Q)HVg_L3?a7e7oKms)vO`LB3^bhBt_q z3j76@#)j91n@rj?!y5_vhv482Zz%Ow9Va%(ig2xn>X!M~(vOhNRjn!aCDOe}Yv^6! z8Vylx5Ei!Yud0274@oOdY56b=ips6D<uG1OgX)9)WyT}kS0R0{QT4KFEe|?Vm<Hqn z)7J8)Td)$jX-JC?+{W-|s_!~eUe&o?p%d>=m<w8=nrW@F+NOlyAmoe^F$%%E7JLqu zTy7+9GcP&PjSf4*+&_e$An5Aj%EbGg8Rp5-=txLG=8!MwCH#?subA1c@j&itms}2) z6yFK2@H@y7RPDmgF=A#oE$A15gYYLj{HcY@OKDP&SN6?_;3}$Fz+b_2qiP@Uk&rK# zEZ0FeFT6%jOZc%>AG>(>5FCt?OHO@rUNtkW(NfKfzktUZxl-;|R5685;WCFN=%THM zLLrc-s<Yjy5rR@gexPtYTr2n!_!`ZXEIkKqAuZn;)Pta=Ah~s{kxN0^9=V?3jNl{Q zTx}&O=%P2aZ=*84baF|}{U7fg?-q+G?Q2RG_6GS76w~nm^`nJrY5q{hd>_pw!;jc# znBQg#K|Zoa6*IPwaaQh6EJea;!G7Uzzc*@|cHM$EnD*Xs1eTj1`OH|QttgQrb!_9! zqae`H5J5fDW>SzrwWC~-P*rdR%QwOWl%Az@4l~b5V)2UUC=)`0yCFE}sw2PNBfPk7 z8U^$Jco~7`>s`QnBOGqa4ulW#<I)(oKH)iaoD8eM`>1{*<B10tWsf<b7o1awXWG=z z3nmHAQS~WYPhaOkUt)dLpHvr``&W39ActIdhwyJ0F0@EtH0H&;C7}s&ss7<Oi>&`4 z+z4_rg~EeU2qrRh;TD5rq5d)j`<ytY6~1+xiy#fCdZ|zqOC#0RmhR<COpR(K+)Xbt z#0|bD=$7z5W{G7ogM5P}4ndiDb&R~ulqUDM!_LB-1k2~47lgyYSJ06P)dX#?N!t+? zf^Mo05iGTSNAI!8#osUku<RxGZv;!Nx(x0%s^z@Yyn9GH>HQ%T9vna#Pg`sRE8tc# z^Mt9r;B$~I;oKl6Z<T5;9jke1;l{YZj7Yi8UNFQ3>w!->;yYGd16<$cYeO%%5J^S& zGD@?DEI~H8{hp_~Ejtrg1>{B87JRRIT%os*W*xruOmlN<kʬDW)G$zAswOE(ra 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 Bu}%O0 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5d36de5775b3f8975bd943ef9fa00ed33cb0ef7c GIT binary patch literal 1146 zcma)5&ubGw6rR~%*@mRnmZ}F&dJ5QX6k8~WXj3VIsY3L!mtm8cBrCI<I5P=N=q-W% z8||?-|DFX;p8N+qc=EkTOIJj2!n}O*X7~O0-nXCX^(uk&^Xp~uEg<AO9?Hvu!z<YO z2n;8jN|Mo-QpApQGB<WDcBPm3v2U>_gRBx)C^;tF=fRTjK+uI7hrH4ujqnGBPz_q# zYfq#}4`)WShKcG3^FfWeLcz^uYsAxh&@qV-?W8wMa{=B5hv{JNDAh)#-HAy@`RhE9 zGo5O<s~^5S-ea9MYrj8w^R5R8{#fqyNk0c5NK842opaKsoN{Lw#;)+V%e^I8(AWoT zs|FmL6OY7Lb)~3c`c;WN?BHf0#`w7P6EKDtdPWw`g>y+LF|P3zaAv*<76kq)XXGNp z8%`iDJ!z~JzMhPQQouhcLdMcOHH;|?sC@LT^(-GuXA0+0Z1WNeEI}IPLKVIeT9_+Z zcv{Fl{I4<AlZn=hU6Efp8mn{)j7HN$Mg5WFLh0z>G#apjsmkX0v;ODiaCkbOGkLJz z9jYd*K^}dK#_4z`&9zCS+-WxVr?ctP2|Dd&Q<3wLih3|ZE=<$~md19FyW^P(q1?x? zH3CA{X_ba_zI99G?oGRYaf-aQ@KtP?Q{c)uDLi~rZGcDB&{$;6T{spstO7V-d6J0+ zc(enCIP?3ZjOAzkFKeZR64c_~i9?y>gGn+FJEf%MHgE15Ax;>}W2~q$mW}vCBCav^ zWs=C%jpeNffk)7VnW-&^s<y!t_3M%Lgp{C>+y2+_5hTIN=n(*oUv@}qfkUgVL#-dx zb|>pzQ?QzoLXL{fmBwJoMr5mR&ML6ju#+tbZl%EhqG%8#3e<)!)p9$K@WraZmk+TZ K6hV#JpZgnwmllu! literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..570f2953a9db161b0af92c567809e83bf0652510 GIT binary patch literal 6232 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..62297cb9c1a5d339ffa4dc7dc78f4058f074917a GIT binary patch literal 2263 zcmbtVPj4GV6rY*><F#X_A*5|+kw{SyHKKLeLm^V3KnoQ}xTr}lme9!Yj5l^SwllM~ z8h3MQq@IvC@BxxzFBRW|Z?HGSsV8n6IPrV44oOOGjQ!reH#0l){`}tC$F*98Vf^*$ zVf(jv#{MAX<nW<<0kR*1DW-VBwt0(ll0_o6y_Uz>1ExIX?=$6V@446VRj|(L;cJdp z>O8OhV1}E$LA;)}Qw_a#Z>w$AbxPCPbg=2vpc`q}M_`(@xMD4#=3lTbS3-IF<(B7U z+_E3Fd>yDzmG;?l-U=Z{s_f*Fs;Ier){0bB)$lC8U_NVAVAr{Pab~~+GaQc!E1DhQ zE-e_z-i+)u2q{Z>#-5A5$hhJ^k^3TJ(u*0muZRbV;c%}B2j`OZAeP-;l4|psPOOJ{ zV8<hE3^|uaQuYSDRLXo#wmWHWqUB(`otH)~AU0o=o7$!_9&2l5F<BS6Z*|f&0S<V{ z^Rkqkq>W|ylKuUxF*3agg4>w1O`|(Zls2}p_OubpwTaoD4sLb(t6N)7r&F1%-QL_X zs~GX1vC$ayM%Q}-o3@kW`s(WK$?oLlm?j;`i5{q-X>^b-rBnB`I*lo6g;h63yC#A` zS3s5o#us^r-}Lf-Lww`N>ki@KXi%srC=_n{9oSK*55yrum=SjAWvuVtXFp!u;~6)X zGCo^FGGvh9^}eUPPnf{Yol7nmp-YC}G$BshFb;?%Q-V@tATS!9m@-We{`0WNgPDU; z7pCgw3MWmCcAX=(K<q8B4?&hR#^>Q~h5J0hbAeBn&v4vbcFJoqh&;asvMXTlklE#o z9dPox(8vdp`eGd^Z`M6$T|OV{RCb1gZcph!N9R?_54@3s_O^b>o$ZCW$2MQU6*uWF zSL`Bm*7|(<-Wk@OJnsJ)ZI*E5%xrTWavo7-jN7p`7ooms<uc~hKyO-k7MP9>I#ss> zBqA5qeFzjj0B5o%GGP~X!c6qJU8d&&z;np=yv(!LpnIv;_n!#!RYr9UQ1wHBL?8jQ zQo>3IC<+NU0&bBKpAy_6?2DB5gqx6d;mz{#n>ZDxpeOjvZyW+080!@WII{@ra=)v! zG6aM?`sU%|=6(6?Mv>$IHJR!>Y(CtO-+%3ZnupR&*8KvW(dKTdF=fo#IKW&c<}!Yq z_IEJ%CCFX{V-BVQFcmYY;-E`>9y1ZI^6AAh06|8c0s{3QswEfZUm(CyMzxvpzCfs! z6i47l^Ps)2fM4b930Iju_6A7FBNzHRJGU~gAKDGfmJTB2Ln|K&&S?Iia>({*Kdl6` z0-DSGLmw3)GXDuPw=y58MSqY!-awbIKPwM+<HmZ}j9)$YeY*7O&%5!nB@*}V#xT~6 zY3&2MG8m>SMcq%&L&g8NtX4jQUauBmr3{%%#NH)FP2xlr!(<o((RrZs<~TM~YYy#( z@LUgyf~551W!Kl~5|^{wcj6mKqe6KMvLAslmm=RK%%91W!UZHT;uk<g=RqxBIU{wa zTSXmBWRAW*)G6@wsYtm!RO5u?s+2q9c2cakrtTVD9-#^1!<Ft9evwOtU{%y}ZT1=J z=p>Qy1pHjjbnTMraRubsWyI&hY6bW!5k*U`8#n7g9%y_4ZBYufSqGZ6U-~k*eJ76p U7vgzzr*PqO%8aGUs=Vs`1D7J}IRF3v literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c2181d8e33128ddd8a092884e15d132a338e25f4 GIT binary patch literal 3495 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2b2d1164e1def62d4f58afe9d0b258cf38997556 GIT binary patch literal 2922 zcmb7G%W@k<6z!SO%d#v&9z{|Rs$oGzMIsrfN-8M|5|Y4%7|J#*w3%v8x1=$n8Kt|W z*v45U-@rOqX2<u;mQ{X$1sgcGM`KyGpo&&?Yx;HW>2vSxnV&W`nhfR7-(QPbo3THr zbGlT}xsPgYppi^^3F|ZI%OLT_e&6@lcT84f^(B*46}$-g73uA;PVFsLv#qxt+K!jE zo``4^r)tLvt0I~@T>^COqnbx(6zhAE^?m8}12XfH0n!=hS7lAs(XYvdT*H4|Hsw10 z8){9q<i<<(!s|C>8|L51FFwp<oDQAAxpDCu&eG&454a&Bd|a^NHsdp;<G~>peD4qw zMm?RXG*Wz!X^c&TwsAB~gytA^z+L`rrX839NU_U~6qgDIwAiIpq~e(}H+gLNvp7lk zKq<-XNZ9%6j4N1$&B$V*!&;^#W+G0+UZQUDELFuW>=xX{W7XxmFt@xR8i{nM3@n;c zaC^eQaF)_ApJ+9Uv#FWy6e&@fV}oeP+M#R31?m?IEI_BQziibVi56x9Ok1Uuu_UR$ z(y7gEm6F_RI-s512iv;^#66rL2BvWw3RG;wgC@=F2nQ$q6EzgcvS%C=`SPUPh`SI) z@R>+r$>Al%CmHy3oD(69hR{m$kuZEuDaavJYU4qyWVc}U<Z(%B&MTF1gg7C3(4BNz zKKTLxc9#O@EIkK+bDD{YU@{_o2#;tPWhq85E0u|dDV*iP&bda|^H5NjR;L-yfT3|r zV`7BKNpSLKqZmOM!2?m2S^=k75}GKUg)2jyJdPzUQb8_J0+HdI7>~zF#*{BG6jQ9i zwdNTNgXUQ{I#lWKxvY=3w}03!l`R~8O4$F>6h2B8zCUY<FQ=)Kc#)oq)2uqmd8`yM zcIIq_XbZ?kWo|o>)IpR?5oDz7dAM>HALwjMUN8t24GYLaHw4EaW74kM8u_^S%0kZp z>O)ksiRRclW+84~w4Q5y$?zQ5%B!lay{7T{F?-c`%{<)Dxc>Yt?JnN6ycUj;2ua=! zqp8**1waTdmVFApFi~l~Ud+4j&g)4w9OClK*M`b|k7uRxMi{1Itimv_(JV%)$a7^o zeqJ#u8RWhhzhU|U=>GL<Z=&NF0;V?;x;MxYoZR&89`uIc-I*RArJoP>H%Fs`qoXjn zdwXxBH&KRZZ?`vzC%57hERy8b=H~6$;q0?14Z0f6R4OywBhm=5UU3mS%JYl7J2@nx zaT?n&yhHM}&@ity|FyiM_s_o<y5)|DL@NtDlP8=P2*$E~QX1Otus7aTC(z`iyz1^V z-N5r3PvZ?*h~Sja?^1UI&DW^LIoUh9x`Kk!aw!Vvy?YV`BXo}0K4Rb+qTw2Q?xW{f ze?R!e*P9Z(u;S(e%=@S;tkMcMR=LJ5WAr`tJaGLg=4l<G>6lg6enr;q;HVCP-re=B zd_78pF`=cGj|-)|U4}|An74`*1Kg>Z&exq6=IiO0otm!V&&lF+(wC`Qqoz*t6(?2h zMS0T&rGv|xE=nC(At1$*Q!#I*>cEC>>KhCi!ec?(Yr(e{{I=)+UGXn?ZSUy%3V9cM z&-s}A?0ihzNS__1FX6G{IimUsp3ic*guHMGgBM6h!XSly#JbYMpRAy;V#_%$C-Fv~ zWX@Ocwae$cLfMA^bE>Z5bk!Mf-zJ4h;XEmJP7(X`--xZ)_kY+m5`1_}1+E1SYpXQV zA7kR@6Dt17L@ZIZI_r8JYx8DE_t!L`d#4qKPp2Z8-$L~;lvxyp`XU*m6w}wK`H-5A z(BzGY&L&FRLudMw3r}K7Q;yMELqiR(a;4E|1dTRo;CpViQ`Kt(R#oYAY>JGpWqbSh X#&h$lVDrY81?jIoAZ#+y@LRz@2oDiC literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f54503ff827ed995720df4a63442980d02e364ba GIT binary patch literal 367 zcmYj~u};G<5QZHmY0|1)5aJo=P#lU>sS-j=j0lM`kR@{KOOuk?k?mSd--eNm=kdza z7hqt*E(`zZzSI3D{r55&4Up6K=R4&QLSKIQFYK0k*UEz-7BnbFfHnccZ%AIUFvl#) zLx><Qao&SCPx!fWu)BniLUeMYJYm5z8plVMf*!~C7`iC~hsDFVZ$s57J2W6wEqGD$ zQrPh6b?R~Bj#}De$Lp0~VACa4P<X4aVXq6_wP53Ar$K!nIrOm}KZ3NfHdF&KRFYCO z%%zk0o~(<xk=p~GmYb}q_J>2!%xB9=W=?BP7No7)NzIj}O*6@|nd!{+&YPz$3~(kS oSyfar&}1dHE!9_TXVcrQV7mtHF5G){=8%SiAaa!kJ^VL+0h~c&&j0`b literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..40ff3d2e82103daa63cf7abc34b8890c87a4f65d GIT binary patch literal 1153 zcma)5OK%e~5VrS`Y)e{7p$H^SaEhSafT~K75U;f2P*N%am%Uh<wUaFJZi4MZP1IW| z^>4Jt-uOLx<-{N0z=;{BRkuP&cxCT5<HwA@`TS*NWtl+x_5D14T_xlP8s+AJ@dmoy zg@F@JCCO++DPl)DnH#wlyVA@2$hX*&m8=?7DS1!0&nqW{SA;)zqkvaCq#pdFa8#WZ z5BI*b_CM{W+NiWUHt8^bo5ymhQw@{rtszhIe#gW{wBuxu<^sI;+hb|ccT*!;gIINh zIaI^0P%yLFI&5w?S*Oj~A9wdYBoN|8b1yBu4M32HauPYGq(?dB&Pfot!s9OYPRN`_ zK46<S;L0iSNQ8M;i(59vB4mP>xN3+o0CxQh215)zCUfV^IVY4D*LZWVnQtm{0{`kU zISX)x6F8V2)Rzihk4HkO3T!R{#?m}Bj43=&`RH3pEFVl~%0YXBmw00_5;qg7@RiWQ zT+qVPLiXUl#8@I@tr@!@zfCw&=>!-JC$S29L&=5GVe=^Lv*tu)v;0NxYhy4tn$4JO z?sNyL0j-~hpTki)+Dvn8VktKpjh)GK@_dX=+u20qe5k?%YQlvHlM$3+WGk~ZnyLWu zeF9x0Aas>3y8)fuE0MW%b>Y8QMP^&L7j?)fu;m;SzTK+Uz@=(9SY(GgU=}q@1ZZG+ zoQbF4(MTC_W)I3S%ZvUmZe@R{M4bOSa3JHnKaTq%ECs!B(W?dZ0IQ7oF;*-ymJRt> zBCav^Z5+$RjHRv!fJ)GYnX0>RtlEH~Sh*}~BBTVJTobU0OOORCrN;m?KJb9n0tbk9 zsP&`b)@->-Dq09@eIYa`wGr9k;aM3Lx3lggWsA}(EJ;xTuLe<~NbS+3T&^n;yj)!H O)gw#@bx@=BbN>L<G!@nW literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5d1613e22b1a7077a0212ec0f9a65f81e81d672f GIT binary patch literal 2660 zcmbtWOK;mo5GM5?DaOvjJ+?p>=mQndNNx@R;s%BFpdH3CWr%c9>q61owZw!Xl_jaf z0(wgRNRPes*x$lyPx=Er^gXkZVkdHp1YKc9oZaE>>^#2V@#dy3!T9}`pS&LxN%{?i z%cBIsE>JQ8My0;AFHxBmUP-jT<d?;M0pubrfm{-D5#%yeKvslY0$HUR$eNJLAXlgk zvMyu=<QsGY<P9OKbkmlqH)mXLgdvH~NIGJ~h_Z14PhLtq&PbLp3KEaA;V8~hq2iA` zPFYGOp8wPvvYM{%cv(7%`3`A&5ov~ABvi;()Qf7TD{*%?_JXkH$K$H*!wugUGDy2X z$tS>=)R*D@1uFN8w9qfnV!upFeTA06UM1JfXp*IN>ZNRE>jZ`~3KGJ=a>Ch!vxG${ z-hmMsoSiWaB1up^As)%1V9I#ng#_-v{50mo2dhsR38I?VZ4M?#bF^q)0A^LyTyx#X z8#C9<b=MuoGz;;0!*!o!UbtLQU6;l_svI5n47XvoOf#<-c5C(c$lQPAHcuSmXNhmX z#)AD3)h9fdf^qe!$LnWtNWr@LgBSIo`(Vn)v*_O0lkL&y#cbw=5AL6i_%@7TRCnr= zU~)Hz;9_BTcYFK(^nChFhLeKaDT`>#>&sx((K|_Pa?bHy8c>2vlS{>tT$07?T2S!z zyQumQ*t>($SE<t1sM@cv5-T^QzRq-}G$p3O^9`y&&?@=Oju#CxNSD1JOc|d&dEdZ6 z`iS?)nRqcF&zT6AH<^UzB#ntDb{Y(hSAlIW<2o2D;>n9(KF8{s3x*e;-$wQ+Fsr)3 z%ka;kBqgpQLxp^+^~kgg+i-33@Tg<%nMOPRXf@~b8g0`tyH=x<YmXa84b;q)gKp1g zSh;F-Ew}afATKsLom^eMlow&@BJhi+O+4==uscA>7BC1&2}82_X|h;f3(kjB%*GLq zPlIT<sG0rub^Ys_nZWC8txh=R$AxpDPOfxhrENGy%Q3C}T-)m&TW!~La>eR8?xAs| zJ3fYO3DBDvinIUE35T9P3L>^}g7v{p5Z)l;#U^iK#(VmrY&(sflb4NNuiMKN)3M*> z1We89niFt#%?X&^yQum#u<Oc{X;h)=E9s@&uPn=Q%Vy6q7Wu3bJY``pieoza;d<AE zuQjn}cmxr~^P#2*fL9nlhddM53qU*#;w&L?1U&*_`Yk8T(QqI0cs1}DsRfi^tx_4l zqcGdq;VjK~l<WZ1GXhYC=?JG^vc(4o9mYHWkPjkZ0771k--2yKnpNez=!eOrl*8i7 zw}vcrLDRk1;9EQ%lUpjzzF2oqZT$_as$ZG=nq}-a9P@i4*N&}@d0=!-a%K6i9d&KM z5Lmn6hhCD58T3%fzl38i*(e%?K#9*_;T}+eaIpezK#4*@=D6kqy)n>}yFkh3z^==S z1$=|2wfs(N70uSdpXak*uTO`I7JK19@*1?ESF$jH%-~{|!N7*}2wC$yWq4A;QiLYP z2Ll2<{UVnzh-nO;7MM4U=sbnW9g>hG;@c!5t*+(tx*Y<2-;bjtfTjr_DjsO0kcrDa z{x95n{tvRhk^P12PheKHa%HqC08Yjppnf~oJMiZ=0nQI{#XdP~b~|~wZSDhfsmrsk z3=)=L11Q0`L6DRcjB{MEs@kHtDDmkN`1TNOSHL?*c;i^!B9=n?ssnQE;o|e-JB+S4 NrKH}j+`a__{6AMhgtPzv literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/escprober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/escprober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1fd7c02adf65856f4d4566da52f413b77ef3634a GIT binary patch literal 2645 zcma)7OK%)S5bmCtot=H!S)AY?5{3YWMI`I^5D|nRk-biw#B0mzAT$zc#?!s8%*?KP zW=*_WpKK`?xFb%s#Ko70AHXk}8{))?8wXBQ_3Zi)gG7(Ix~97NQB_}6KQEQ?1lnJ} z9J}ERA;06#`DVb+1L)D$Kse#lCjoURMPBo@KzDS->%I|WoJ?RkW{`EVN@n<0kaKcD z-pL0Arw|mKA|;Oq&v5gQa8u9&-6`>GlT@ugC~RM)NolF$%BF}nWPe*o5LA}>yc@Qg zu^Wpu*XwjcQPq?3GdFAx-L_ci`mvBn5%s5PNpYg67FCU;@YrF^HMX|CTz{5SR-5aK z3yX_Ojmxqp8<%BIH&10A-0?y~=U|Jz0wRb*IdL>j9i7j-A}z{wZXD(uL-A;|<z$4( zv)no)2h_;|pW}JOTfD%Fhs4S85--D;e?<)96u>pJ$!tCHF1Tg%Yu<*o)#*m|g$a8Y ziO6>CTV9_FJMuar5Vvf1Fpzz4o!#n7n~PX@F}TVWA!q>;eWG^zt|O$_-m`@pb^SeC z3a{S|yCZko7q*BzcOYz79(B5{*p9@`5SHUvQh=)872NKJcHCE6b-4)RZfnnuJ0gPB z(}V7)*@mYnr=<jWbfXSEIsy`tn2yPT*3-t6(;on7Z89cIACsODXL{xXBA0>JkFv29 z=MLyGXq^7%PybQ30J`6v&J{1rm0)gsI#*8TIG!}4=&Yhw6s?TO(Obs^F%1FH8UV|J z4*+B>g}&-sl8J@`A!PyXpID4_!*0x2l1m-TqCgg5Mxvbn=*O##db7@&t7{w2R##T* z%ZUjg5+Rr91erx*p{n)d;l@MMl{x%1pRRA#A2uW=Y%=3Q6n6#e&Ak3FjFT%Y4XxnJ zgB*%PoK((4cwNkw#AFesQj(Dnnz*VZMkM@}y59*+a*TPt8%2zrkiTVZAiKMuT-$YJ zt=0FrkWuaa%UYY=-<82ATx|6gI-QrJ5%cfg+wRB(Xzj4JRU32%x4R)6<omZ57Vhot z?cN=tP<6HoruJnGZwXhf0k{C4knMK{d$J6+eGEN%7YLyhYSJQ|g%2rqbMlR@znK+x zrhfOZmP{Ms3*D;l^#qtHzK%4EC?a5)d^5jK$27XRGsj_M#+atFJ9BXcH4Xrg%v4y& zDr!xTuvN{;5^Sm>FXxeiA_}2Oqm$^q2<04#uOhhyq^im5$fKTo2ML-gZy>=9K7$@r zfDl@yd1_D%EY5@NCLLY7WV4Fm1%uIe>`Txi69^apusxxT6RK_jgSvn^_VnzeI6(~y z-9XfFu}V{IbmP*Y=QaP&+0usXs#KXTZvmg0e0H`qh3D$Ib1w&Ys`cMzqTkS7ndh_# z4-|AvS-sJI{ph#R-0MHTY=ees@_iWo^)}_Uh#{%M7S=IOtbv|#B!LhZ+UUJY{<x@r zp}b{aF?JP=pMe=ufZLDz8r~AP@AvhwF3V%Rhwy{(NE>U%bl(^ovEDOYXtD#4)ENNK zAiWINJ|!Aq2+9oCUr_l|Z1%DMP75SC4FZq7Nnj^jpNI8j&?qPk{it}11+E0Am0_HD zbIp!{67ZMNSdoaKKcK@4lw$QJ@JT)tFXOa?NCa1ssc&wsZ>AVWLld*HzQxw+@@+Mn z78`SQs|m8iT3LVISZ1qR$$aWFe1Fp2Sdc#MX`*}xi_>h$D6l5h_FfFdE|v-P(iAIB ziz}A1Hvwg|gy2osBtp0mYC#6&A(N1rDz7Z4C3z*cXhj=cy%bd3p-LOoA{KPa2`K1! z#)3W{`p6d<+Znq4WG2fP?|Y1?0;cjfv7oBKqY&@O56~KA(nrYM1(K8|mDUr!56jMy zQI!N$4e&L=rK%cO)G*7l#RAx%W4BCIa~johQkvvrT16$MZBm)M?dY7TXLX#&h;SH0 u>M4>KuSpa|<iRU-`t+y=M?ExYWjnjxxupF(^~Dz`itxcILY11M^Tt0vL3c|4 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c249e7ced488f0e739d331a3e40abf239e41bc43 GIT binary patch literal 7486 zcmeHLOK;mo5GHAgddsh*&7sF0q5>)v6$oG;2;w+G6+Z(>z3@UX+Lh&iq6AVF68)B5 zddw|9r{J|G{(-beE}dDDD~hIVFcmDom55#LJa=X|`-$Lh<#IuQ-{((%7?r9Z{DnmH z*8<`N4Cl`cK_CJVO<^c%q9_nalc@M^1BOg+jt&{Q2_pl%q!H>eAB0f^^<<*3IYTl5 z*O$ozE+(1Js2`1iulsdPAz3X;CGe)uEXk2PDg3TzIa1W}XvN}3PuwQ9X1f6Irh8Ie zaUQq#qmOxH8Ao}LHOoKByJmgG_7=U3{tK-@N?MWTNtqUCkyL`Jl*p!52J73ag4N;~ z-Lj5X;yRl9^Phj{HL+fPcZ8XTckUsy4esHNQTc5)s2l3A-srcq3fa;&X_;)(3f&|- zWS8~Q7I~m;gLZP&qI*WyVNCHm*GbMBGg_=qkYi|v{uX+<|5)3BGq6jyp`&)_E_q14 zV{tzq-*<%SBTs}gUKQQaiP0NeShO=SCiJlYTpJ}G48aBjSlxtStTuv`rhnfz_vG;T zdKp-GQb@A?TTj73To>Z53*oVo$GVd>rUH#wRc=P2S)rxXetlVM{PLvXW)Bch9a>e~ zV$U=jN1qsPP3o3>qHpvjBik)Hh`52M(i<4IZc;0tWy=^+H)k5w`K56l;4%hsa~O9b zT@Eg1SDp;VpF64AJ%Dr8f9pxG*ELv04XXK62i401!pw@VJ7={<z0s&0oceFK%R$k3 z3w-0jPJ^Oe5?ChjzA=_mW;qVr96-G}FXn0smGNIR)uX%D%Ja@yuT}vg|8w-N7Sf+C z55E{jp!D#Kn>#ed2EODj6I5g1k)BKgs`j-2%5g1yrIuu|M$D9d7;7k9Ln*#xtf&tn z*m%@-m7|eO4ePY}(9KZma_HFjZOc_!ntpKHaWkFne!J^tn(g)(D8KG@^pmEW0coe} zZlh9bzpWoPPxbEp%j2e7M9GPMa`viu?3Uqu7GGx%PMNRLoCM=Xb1LRzXD+$o>hR5i zD<C7TP`DUQ=nD1XQ604xTmczzg~DW4s28~UDA+&YgT(2JrH<{3DSRbSr-rTeM<$`R zqwc*|&-J~jJ)BvM{=52M@P0Pa&Aq2@2X-BP=a$-4#~0(;g#}+&OtV(6Kb?M<KDk6D z8~T)5WMr%O&4tj3N}ZlF{CWJr%{?2A$fZf2{{Xu?TkzCMlKi7A$btkTxJ174ISVxC ziKy!j3GV^T)|`&`_#)?JNfP<>RmtL>=z(7gdjR)F8u#RuL5%+HoO?yiCBFVYa&fsa m`7wt%v3n3h$h#VIET(wOf6Jx+5@R$5UhViEU*+859{&P*MV5L1 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c52123fc295f681ef75423d87b6f452317f938b5 GIT binary patch literal 2463 zcma)8%}*Og6rY*>U~LxTkdQ!BRa9yYmP$;kDr%&tN(wX|3I<_wsHJMUc*gcRyK855 zjlgnFQ03Y`0UvtEt?HjM$M%$4Pd)UKzBh}5NfoJU=FNNa_1^sEeQ>a_P$cmE{o5q? zwM59DD9nB~2oIs9KLHU$(1^seNn_Sz6lE4!vE8%{Z$(b*HeJKp(Om2`J;OUuAucwH zhIga+*l+rjJSJjJcxOa-(mu7C3!+dbmEv0pYAQ_od#ZmJCY^c~WK#P(L8}`k(nuAm zZ|)4EEd1^ylbhW@)n$gOrGlBI&Aym!yVwMytJ?>g&-S*$G*jW>Fbn(1qa=t<(lCX| z8)kB|pJehln;9>eabDlyJG)!k&s$*FmCw46(mh}#X;ML&>@{gqK?OVWnwH@$VFPbV zM>xVgBd4_K0&i{({G2F=;u&drVqW;r7hV&aG>d@5f}S_}^P9C0mg$E)D#w<74J0EO z9g|ab&L)JC%*yOjkhzn&rv&=B%rkvqOwNnALXbLnLu-|J?WDtjRH^`nXpi$S2{X=> z1ETV9tk5!W@-$X1%FAK~LmnWABiKKObLCbJ;rn6jD4ELa4b^rkqc-#f&RbECrkuYa z|76vH3XkA<t4D#Vw)>HgDy`l>u6FqSBNdO5uiCwhZufXJ;?ezkhh4P+Uni+Hs)KN_ z9wuoPMA7=j#=WDHqc4XzXc|9~iRi0p3p_)}tSX1C-e6$-<L=-@`C#fDXsK~~TB1ej z!Ecm%L5}v_DH0!t{S!FiD(qv@v+@T(coiOBvDG|u23}Q0ZV|~fB-fEFBe{tLXTN}! zV!RPBYjkbq`R^Ja|6>h0!sc|7px`yEHgaL#`m??KY@^C(d9O<Qhzz_7Pl8x(;C2Rt zu+hq_#@R*xOR@Hz1%n`g7yr0wFA9>*Fz871+Ns(r$WIrvj7?}4eCUtpV&<;*;MN9t zdJ4ZS^5Y+`7+}xNtuY<5RWhNktTBW@&w0UA4QAZ)IRW9&^Pm;RYy!C|EB59gFdz%P z{OhG}RxiNnHjI}(7+-{O-<)5bkXQDY2?is-k0HiaA-H<ig!KUXrSt13jqM5KMc{7C z%Ag}(0Tv2tg&@5}e#R4K*MDRdc2i+rXk$j(GFW=^1^b1n4Ri9X3Ca2Ml?iHJePN?K zy$_5mgLgQ!(PwwkHTcWpVXYfxYY@JDwH9P+hmcNT?kys&(6!#agRgQM!WdpnYAce7 zT7Yp~OdwNoh`&rKOhVe(-rwKd*KXABbfnUbkcY#Lx`hX=BEiShZf&>0ceb^g@6_(o zMjd7E``v@u7Ju5%PQCGHzoD;pz&Tq(rDOs<I4daDMGlE07flptyDg<qP_jV1F+~@) zwj0}<ji<H8da={bxJ>%PPM3=y3v|hx*-zS`kV#AGrTUZI{l?}&gEyY+Z-elBtKz67 zJk3KOz(%EM2*GlZ08Jh8&>D_7T#YGJfsNllOCJIuw9LvTuh@{y**lwg)HO0v%r_-k zrb}#v;v7=fDzOsvsgG;fs5~2pc+D#Th=^k|(eNoS@Vexjf_I{qGsCgWM8he&%tR*j zti$pgGb;{`D^`AExTGn59QwBQFLJz*KD;O%@B_3I%K<Uh8Qq>W_bSd%VxX*GqTw8# zkjH&7jF9&^e>n`Ie8wbYlLEB|o(UBxJDKqw1XrPAy>L-KS~7~DPF+5N$)+ZeVk!F^ zT8bIfqyC(4Gg`E;d7qg~T&t9{Ba>mA8o$gvcriY_$ar~ZD9popDSv(AUUB{}h$)Ux z>#(}a)WW<xy1hXw$&T}S=)#dH6izIpc?r0*_c9xM4{}Vt#fp+*bt<DH<Ui|Q;?q@Y literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e609d2ebff181f69a17a68e1caead7d9e321921f GIT binary patch literal 12075 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/euckrprober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/euckrprober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7740c52e687ad35b348c71fcaa54dcb95d73020b GIT binary patch literal 1154 zcma)5&u`N(6t?rLS?R`@1_Fr_oGMXL5SlazA)uQ$j1IK2OD<L#yKTTpitSWuv|A_b z-`I}3@yBq=l@tE}2TnY@o0bV7;m9wapPl!fzxU;Eb+w6L{Q7ntefJRhp%?Yxz~VJb zxdVnGiaAPgh_S{Nw^BQ_4Ys+Hx}j^Z!@aZ-HZXdJs7t*QL_LNVcIeZ_0JZ&}7(%si zb+2D=mAsuR)|*6Pz|=>P51D|Sjb2WZY&=krV*MzdBpCzmgWbd4-oZ{Hl}Lt#O7iSY z7V)`EBy6skO)}_{{)e62_c5fnG3?8gd;x%=5K|Odr)Y#Jrq+oc+RULgbxzO%hb~}K zH(>7+IVjY1H>z7E$Fj;;U*c+LtP|)dpMX(F;bXM0&a88Uk+PMufHiTIw?Oc29HTQ| z?@$DR@qT-ya%C}PLO=^p<r9)*i6TVkfWp<jmDo^1WGZw^s=Ktt1Bo;dB@>k^m}Ke# zSB_+S1n(6>Vjf9J$OZbXf~iPmKx#0HL@>%ZWkLqqN5PnE&qP{g&qtrTlgUw86284P zoQN)raTa_ErpdIEWKu<(ce>rJ*?jh_&`vYSjAb+zK@4rAOa-inzlf=6=F{n1_)za- zm{J3T*Kia2xZJFf`Sj|-f3d2W?dfmzr6~rsto_o1Pdj@DVjX;<rHw(x+<|4)(v<)Y zB#Tnk29LDBAgjDzPg+0pUx_PkFBdGz{+-z8Q8q53G3(Tl-ni-2fwr&Ptm`ABY7&y> zwBQ=I2>Dt>e7R$|t9;-R#G&S51Hy_;FxBd1Ut`8O2<4i9HGM?0V6^lIfYg7uk6WIF zo3@3GUrX+GI=rM{*(;$*sy3EFgH|h+F8@6v!)o2Mx2C$K5Iu+@L6usiCUmWq>yG#@ Rmlu5XP#2_y(8A`i{{U$77*hZM literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ea199ef8f512d9fea70b62f0e7093e63132ba520 GIT binary patch literal 27195 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 ZSD#LUdUh_CH$2jS@FR^DD`u=1{{!A|*2Vw; literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..089b5770aa87e83b3082c1e4fd6f58a8716019cd GIT binary patch literal 1154 zcma)5O>Yx15ViL!+mM!06$BC&I1!0<145N5Aq1oq7gCUts?uI8XYC}5yqjQq(<bUI zmHIc@V{iNyZhPg#AK<`=vD2uj5E5Q__Id1`8NYdZxVl<JFn)czq~8OCewfAb@L=&4 zrrHC;5W@mxIL6puM>v@qyB52`%lz24*b_lki7Oa=K+I>s8Das)GdB)drH$(0PYj{z zxO~tmgiha2G;a>5Y;*lt4!c~!&PH>{(!Af+RPz>125HX0`)L2L**V%vm6mC@(CILL zms2rOse;WlyGhzD()zTw|1p6Sw}yMYQm+7T6k~>B=N$Dg!^}AgW0!l(W!@Q@;n)Xk z>joU0BM-%<?n-&b=9pKRm`f~%!6t#3>NyyVG(JT$=fb%}7-?5~GguQ}2Qvik$|<@C z%??8l7$4MEN?#QtE+w=8l_4Q%o@zp*2`GKzTS+V>L}k*nq`c3Tcp%geG3B!KC0ATu z;nGuF^x(ZhNFu0Ggj}KDIvUAz45UV5Dx=;|FfLWJdlL1@?pS8i{AKS;V=y?GPKnsv z=?-KAMn8`_(I_2lrMc2nh^<CrXFM6dD2&riGUhoO$|!+0GOi<DB>H${o4Gxj$Pns% z3R4+?@EWe-5KlLk$lP9B_%BusvrY4@xirJTmUA!-;M1+nkz5C#tQljGHTPgy)=VY9 z1IcN|pMgg?V30F?xSVwP(0?T^gAPrPY5woTp`dxcpnYycut<9Ari%mh(6rgqM@U&E zBpb3q7+fRdYeB_)$8uMOz$J)7Pvi!Km78G7)$6_{TnG@#4FPNBh+)BM=?MU3{_qgj z0tZ)J2V1|9+}*5uO~JfZ(vVbc%!LN6);yd4dsc?!x^3^0>gGZWAc_K28kO46OSRl| TBz!%;;G4&$AR~ktwvY1%be0&w literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/gb2312freq.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/gb2312freq.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..35b3e7982857f0dd97fbb42771b138fe0fa2dce0 GIT binary patch literal 19119 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 T*||c2a0~v+r#K1XC5ZPw8j6U& literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..a5f88fb7436da10a7458447cac993155a5db28f8 GIT binary patch literal 1162 zcma)5O>Yx15ViL!+bI2@s7N3#a3T`zrUg~1gb*}Ey^w+wxa`H+#7?r6cN1(UYNFm! zsehwA_QvnoD<}Q{2Tsg*8#NU|!Yj`{kG(VFH*deLu2u<*U*E5jA|T`kE|!M}i+3>f z5g1N5l_aAvrHCErWNz$Q>`E{5W8Y#=23aMpP;yMT&w~rX13~9*9P&z=)We??Le**U zs5O=*J)9cR93-kO%x5+12n9Qv%^^?oe%mBQw36;1%>{U$93Sqz+TA-!wNYtjY|>%= zK2PLSry6$G%U#xPvDT-f4<Eab<lb;^SNb&oL1M~D>|Bx_<&--YVeATzyWG1Va~k`A zZRLQ2OX86jE3Xu_GD%rz7w@qch%p0B{Su5JhMtqTbLCtUN{nl~Ijos)f;oYA<(yoF zxWfrVrYH54!q?-GPzt(0ijc81PYq)V11cYVD_zS9)0x7q6kB|W36>xgGocD!2`$VG zEj%q`58f+`b!DP8V>jgYI2x&R0=!0(L`A)!<U;A_;4JF1gNe#!`Cjj|F&Lc9W=tOJ zcLu5fqn}4#qER~9PIGM%DYqMq{mFE)3&GNnoopg<K2%W`I?08J`W<Z5$ToCmG*uxK z{2Zo6K<FB+(vZ%!mg(GCT=_3vk=rJIjMwHA_;OB)p!`;CfKS!XSY*uuSQa&`1(;xY zl8G1K(GD2m%pTv%x_s*YGFO@?NG<-II+RJ?A18f*LRh4|f7!)}dWgNo5*aJ1jAcVU zmWXSNeH$mT+_C%>A@B(bF;n#r;;Jn$#p-QyyFyA(%N+-6cm#>Cf_er(<DVYVTHw&C z>rm@Q-K}SxTN28CDdefxEY$}6HX<wkL94}L!}fSddZiizh@wH7C{-JJsg}E@gm20V OzI}=Xp%`k^KF%Ma>la7> literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/hebrewprober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/hebrewprober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ce3a5c32ba549f628bebd838d835803cd39d6a19 GIT binary patch literal 3035 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7a60459ade33d5cebb7f73bea30f82445fad6555 GIT binary patch literal 22147 zcmYk^b+}d47RKR2cXxMpcZZ@#BO%?J?v@ToyG0sAv1qU;1q`~oVbR@j*L(iDJdeLS z<{V>u<C}A>y}jo=+}k`!l7vy=p9eq9@Az|<sHk%m|NkdOxTqffGbnk8E>W$cy2NN5 zqf5-zF}uWS8dV^6_i#7-6Tf;Sd5Wm0{1D_1Hv)Y@Tv!92!Kx6Ed|@WiFn)+EqPO8x z;t;#T36W=sLc9o7B5m!hNfKf$WQ`Z%Oz1W8Qg&JF5G$zcOcf$3Whnn0`Bel?h1nq7 ziV9ZR+ohystPpR9jv_bo?zYz}W>_*-Np~~W!Pn;YGHp><99*VyUP;n8AyPtSo-@H? zbx$A<(Y)ps*HHorLlM0{D_#M~)un**45fnAJYTZ6#~oC5tQevF$Vcq<hdu1>g?+Fe z4!}X^o;1WEQA}-zMJ<wrXbDFwPdio*2h7RFbu<2Om>Hs@N>aPs1iYk^Xe05D;fpON z$`&K=rM)xs_OiPVVwt;@a`EU(bePX|^kD5d(f#U<8FU;@z)3g-r{N5og>!HoF2F^& z1eYOzD{vLA!F9L+H{llChC6T<?!kR{01x32#9-~Q=m|W9XYd?ez)Ofq9U=zAgjf(8 z;y_%82k{{RB!one7?MCzNCwFv1*C*jkQ&lJT1W@!Ap>NDOpqC}Kvu{G*&((^kwcUd zazSp$19>4I<c9)K5DGzIC;~;H7!-#RP!dW(X($6_p&V@Vmb@8$q9Q$^bo86;J;)+4 z32OSJWD<Sl9V)M_0#t-bP#LN~RTxTOxsJV}kDw`)r_eR}lOpP-WRBNtj=5bDgeau= z2yC?1QOPhR`$V7G+az0$zzrB9aSVR*?#A?5RAZw$)PR~$3u;3Qb+ObH@qtK8B?ea! z@BIOZ^*#_|owtsTcIt}4Stuou0V3+^Dk&z>%HA4w&soOtR4>}=N%^d~aqYdL<5j2! zufc%OL6FfGPl-@82p>nN7k(84VKV%33k8B=qS&Fopkx>Y;dg3O5U!$vToQ@HPjZmS z@-7sFFCjgA0a;)jgm)Mfyal0fRL};>gow<fl0%e36h4!vAP-cx*V~tG8q0i^HI#%` z9~FehjS9kpM+K!JJV8_tKCGx<H%y1{pQs?b>!_e|h)7aWvn)TgED|~jR*O=FqLFgp ztp!bGC)wK)4hhDHUYD&BN(bTHL<MzV9#n#~FbB$oh?MiHlxMP!y}XbPGC=q^qI@ew z1r0+)UJoxis3IC;Mi+*{XA%`;wO8LWdIK6jLudqzp$RmFX3!ko3=y;<P!(Q-oTU1P zmm2i9oB><yC1dhq%Vw7CUCu<&b5T)=mhic~@9fnV^>h(kMKK9fP|^sp+v{y_gy_8c zTP8~6Vrz#{a24LSw>ErmK><+@C*NmTSGF2tgF>>gWaC12dY$d1;bpUun$Xr>1Fnu( zZiMpC6Do#?lnFZ`>8T`#av_2!_&`Y$C8aH2vFrll;9!WzyQcLO#Zl5jG}wbGtE3d< zh89pOMC66TtQS=bpLb+<xQv_+-@+iXy@FwH<jwGTL=uIMI?}>(YYDBOHM|9Fpe?k6 z_Rs<1`8anJb%M^&1-e2v=ng#~0zIJ@^oBmr7y3be7ytud5DbP5;YTVmL^KqJ!EhJ> zBViPbhQ|(bGdyJ^K7R+pFNsL+@Pi(CTlS?p7$Zt*Z>%VRy1BlzelcjAy*SzqK|<Nn ziVs`Hh4D(_iQ+>t*$MV0!X%gsQ(!8*1JhtS%z&9N3ueQ+@E*JmAHaw35qu1vz^CvT zd=6j0m+%$Lfv;gM%!B!`02aa`SPV;GDSQLV;9K|(mc#e(1N;a-!OyS)R>CS+4QpU6 ztb_Hi0e*pB;Wzjl{(z0J2{ywP*b0BbU$70f!w&cx{(*ntKiCPoU^nc6y|54V!vQ!5 zhu|<AfunE?j>8E!38&yRoPo1&4$i{`xCocvG6Zl1uEI6A4maQ?+=AP12kyc>xDOBD zAv}V|@C2U1Gk6X!;3Y(b|3ZqyfS3>qVnZD06@F1fCiu=d=L?`}^cR5W0wng?pXa?# zBI@boKj!OUv9E_ue1uwu|DuV!1#O@$#HF0bry`yxu_(SM0VIshMkgQ%B!y&<98y3^ zNCl}O4Wxy1kRCEXM#u!2Aq!-MY>*vtKu*X7xgihag?x}73P3?91cjjp6oq0?97;e* zC<UdV43vd(P#!8kMW_Uop$b%mYET_&KuxFxwV@8wg;(HJs0XjX>rfxwfCkVI8bM=d z0!^VAG>12#1+;`#&>G%?HqaK@L3`)`9ibC+hAz+*x<Pm70TJj4y`VSrfxgfW`ojPi z2!miS41u9A42Hu97zv|bG`tOCU@VM-@h|}<!X%gsQ(!8*1JhtS%z&9N3ueQ+@E*Jm zAHaw35qu1vz^CvTd=6j0m+%$Lfv;gM%!B!`02aa`SPV;GDSQLV;9K|(mc#e(1N;a- z!OyS)R>CS+4QpU6tb_Hi0e*pB;Wzjl{(z0J2{ywP*b0BbU$70f!w&cx{(*ntKiCPo zU^nc6y|54V!vQ!5hu|<AfunE?j>8E!38&yRoPo1&4$i{`xCocvG6Zl1uEI6A4maQ? z+=AP12kyc>xDOBDAv}V|@C2U1Gk6X!;3Y(b|D`$-17bofhz)TdF2sZQkN^@wB1jBL zASon+<d6bVLMliNX&^16gY=LAGD0TE3|Sy6WP|LG19Czx$PIZQFXV&#Pyh--At($* zpePiB;!pxgLMbQ>WuPpSgYr-TDnccw3{{{iRD<eJ18PDos10?XF1!M-LOpm5UWfYd z1~h<%&<Gks6KD#}pgFt=EubZ|g4XaBw1KwJ4%$Np=m?#lGjxHj&<(mn4~Rfd=mou@ z5A=n8&>sfCKo|srVF(O`VK5v<z(^Pcqv35B17l$vjE4y@5hlT8m;zJb9he5wVFt{E zSuh*kh4<in_y9hHkKkkY1U`k&;B)u_zJ#w}4tx!BVIItf1+Wkn!D3hfOW_+>2H(PW zupGXJAK*v$34VqZuo70mYFGnnVI8c84e$&63ctbc@CR&!O|TiZz*hJZ{(^0=9d^Lq z@DKb8|G`e!1-oGn?1g=>9}d7lI0T2`2polDa2!s+NjL?k;S8LGb8sFmz(u$Ommz>F za22k>b+`dH;TGJ6J8&27!F_lD58)9!h9~e8p22f?0WTpc{Ea~*2E>F|5F6q^T!;tp zAps<WM35MgKvGBs$sq-#gjA3k(m+~B2k9XLWQ0tR8L~iD$OhRV2jqlYkQ?$qUdRXe zp#T(wLQoirKv5_L#i0b0gi=r%%0O8t2j!sxRD?=U8LB{4s0P)c2GoRFP#fw%U3djv zg?jKBybkr@4QK!jp%FBOCeRd`L34N$T0l!^1+C#NXajAb9khoI&=ER8XXpZ5p&N9E z9uR?^&<lD)ALtAHpg#<NfiMUL!w?t>!(cd!fRQi?M#I}M2FAiT7!MO*B20qGFa@T< zJ1`BV!wi@SvtTy73-7`E@Bw@XAHm1)3498l!RPP=d<kE{9QYdM!aSG{3t%BEg2k`| zmclo%48Dc$U^#pbKfsUh6Z{M-U?r@A)vyNE!a7(F8{ilC6@G)?;Sbmdn_x3+fvxZ- z`~}-!JM4hJ;UD-H{)3&c3wFaE*bDn$KOBIAa0m{=5jYCR;5eLslW+=7!x=aW&-~1p z*e`IB_^I+j_`9^oKEI|q;s@CUqNEa^NtE>S>N#!aVU&_)(Zzlz)6q}3KSDb{v|dnh z#_wrH`*C=_pL(l^V(RE4(Tm>K(LW-~K4BvPsW(j<Au-p_$<qu<LwSH@CMvfeD*VM@ z<addm!bC9BPtnuJuhX$rNsjP0kde<toAmCrOr-5DtP5uZi?r2}XlQOJi3~dab2%4D zJ%c$)22xoev69`sI<^{FNJ(7L4tp~R{J~m((Ey1HPFX433u+j7(egQ|Gn8wIirbqm z>g$Gnbwi&LxTK^R<yz2BHi?lhWfQuqT&!i_ew>mqM#dC1(tFYKc%tK^l1$v+lRcy@ zp6IY>E~(t2k)orX$9_>>9ovb1%HIvkOGKl1KBjJ?y~j$nC~5CKND~eZestdEoE|ag zH^&-e#u0djp#x^rQ}V5n83b;MGSi!B`LT0cHnJ3f<3=X)cIH;sLT?FP%Ft`X%T@AI z38d6}i^^G7_oL$5mMzU)M_{47U-b4S9~iWW%BuvP5O{}PJkcb*`?aMJtx}i7a*}7> z!rozeV?_OpOdjpj-q-e0Sf&tFCtu&(OWYqd<1>i|p4Puahlpb6O~meNqI&9Dz*Qyd zbhKyf3gh!6DpP((@hypzMz-a&HoeW-j%yolFEjLD<D!lUmfu)@9DRRbU2rmdj6pZg zvIv3SLIiJH4mRx*ZJR}DB(_UzB`}LX;Sj-TdokTmCy6DnnN&+QJ|vKitGc38?2dBY z4ql{dil2}wBwLEV0WS8Ljy|#vptOf~)_H${r?6V_R|eG-^){^~r@t$XqL+uO@03iI z%_CdV^B6+l6PRyr3#`}in&K2N8U|8c%S&}g45uIsS20NaX?arJALf2V<ruyChR0Qx z&fZv2T+v+kO<N}=uPIJsT4#xmNgZ@USHou>JaW5F?QPQ$&pAr#Xks~?XdiQ%NnCc5 z+wCPLu*Lzed2_DAG0Sn#mB0;qsXdQsij%-yHYS?3h?g|7MMN2NERiS(b<{0z{N18L zysRg1T9jAu&#;@J-xw;UZnNIKqM{OmEZ-u3o2x>WX^q_IUebxa5Y^PtS+qR*l#0*T zo2g?h`HZF&;2^ozr?A8!%OMi!NhKAfm8d`^FTD&BX$kC<m_&Io3{`xNR4Xcnp_KE! z(3{Y=)H!uuLq;mKML#<Juc9A_er(wVmXd$pp+}R-@6aPG<J0?Blufh{Dmz<wdpp^P zSSFK5syC70UAQmf!PhkCUFfSLvFuHcHj5cI?fnO%;TpXh5_^aiAX=ShUs8Q6V>;yu zb;TL)=wrG=$1}&;8YY5~-pPF7GT0*e&hS5Vv@qkA;cw|3YQ_$GTO5C-k`w$*kw_rX z&)ir>9+&;pjD)fo2+X6L&rw%cCW4&sRLOWz1uDt;n`K5~9osBlbC}=gy{n{$=(fac zy<LfB2@}BsM`&a3WN0mzW*McUKWo*sWue>{Dj0dn5jKQU!41U;M8AlhDVeNyn8QT$ z)`4|gy(X$BdtLUL=qrhbT<y}EmgjDwP4*VLm(N*?#qMRx5)wx|vIB}^OB}Sf$TA=0 zfnM7rOs;14yyXSh=tPs*n5Cn$;U{zqQ1^+s!zFf$V)2(yqNM1A#9}jIigxH-ptqpq zBptttI(c8}n(<igP<6Mx5nV)^IQU%R4CJuaMB65(++*2T?`$KZlzd>X5!_S~lY<lv z^SP3gq7Ou;oi{&2$JH%^_AV@w4`&C_dsN<+=;qcw)K-?EokVL`CZ%#hNk<(=MR&L# zqNEw8$=rQO%Nw$*?Pby%8`efgdfQ3VaxaHO7meJ+!COi$+1qURP*EO7eI|Q`gA3&Q zlFy;IuIzGktu5OTJ*zIJXuq~DI+DXFdl%iyaJRA2-cluP!C$k8)T9#So;!P5TiCcF z@uQMY2{bZ%0A!+)NXM%jw6dJS&`!(zj&;`!Z4&L$(Vf8CI$k$pp^kqPXC`0TpnI|{ z6i>Fd$li5PE$B|F2$e4UU37$AI#SRp9WC!Ee5iN;_hT#zS*|ke9z(xs>%nPtd(&X7 zy6WcEu&hn0BITw0&C=1;$V(hta)|>ZhAFuuyF~A2+Aho9H|VI6xvX`O-6PxD^0}y> zk#Ep@%ibMW#?>HbEjw9ugUH{Vj8rx4JyQ8ZMI7s@8@jA6nFk-oa=VfO&XHE#RW=?l zbWg`%@^vN3xuMO`dkp2Ww^Q~r(<a;73+W_U5gjkF(6XClFU6gVEMfVPL0gH=)>f8s zKgFGu#MV0iZm{-Hb}oVK;IGU?hKN?V&WdoB=sjp4yO~sTr~)^s45fERaqqA<XyDuS zrs02+f3B`A(HZJ0S>6@x=X5jCzsS#m-m>*&GgE$B+dOp#Bw{GpN4aL04W=4Y-ccJ% zY?a8RxPxUg_|tMVso}h&rZ<q(E_<0}W83>6+7N-$a7*@t6P1F#kl9z&E>T9sx71~^ z_qk|P^ikncbE{Ln=Eg6YmQKlDgDQk}gKtCQ!8_dlEL%oh4;Rrz)Y{n&$iAl|0;#;u zKb!jnsb9#awl@fhC>iJ?t{a|8HY?@*mT!4?|6#4TWd=y@J^h{Dd38mJHkC-`<V`Fa zGIWnrCUxVeT(hhM^DIkCjL`9=;z}-Ol|duzJrebY)e?)HExQ@lMc-4Y$a8*sqaEQZ zD&H8Mlk%UUz3TQ^F0-7bZV7>gj6d{=>PmjTLEnc_@YK~Mu~&<Y!EUGk<+1k4hHb&? zN~X}epshUl2lN`L%j&82kbOk{hH3sDT_iCto1v8A+>Bq5I8LCT-YVf<(20CkZE0lx zbjs3(e@pbLy}wv1>M-T#jVIN{oxWh`vAJm_dQx6WDvRPL5>xCwR=3{Xx$s#AzZzML ztBhe=u)^{Pfp7FyG52rTcG`CHQig;1MjlhQ$g+)+ld`dNJT>jQy$VL=GOdt~pB#0N zV-?o>EtHduqwbluRtDXs@~yoqI^IyS(@_gqMxe2}iEeEH&t=*8SI0S`S48U|y}A*w z%!x8^HAqP=*-_g5VyHRy-TZ5!vgo*uAB`MpdCGFJwgUF9a*$Q@xkOT;KfoQv`-m!& zPvPT|&1<pPpo@zCh3*DDci!n?BIxZ1+sS8FTw8G`haTdYZ!zs#?rZC<De*a1<1Dvv z|CWyLl%$d<ujDLz$xBtP5;OF@j<gcLcpfW^JkR6>NN%q!Tr;;esq0}BoZ)XjfwB(W z8tz#xF}Do89g630dJQVu>jT@PA2-pZikD~`!caSVYwSI@_b1Wra94I_xEItjccvq( zj=nX~O{ZL}t_}AUMM)&y2$#WN9czi6k*&kQS7A2j7bb#xvZo|oxcdVJ)nU8|`J;*x z$u1yTN7U0{Zn%T)dRr)YC_6>R>w4FjR*Qr8byRVfed^j;=2n-(Q+;l4hT^Q|?$NuR zwGNbDS3FcAKB?Gd6c<Ipz2N(>Bxna`6)$%OrRW``l9PN&Pw-2{mz3;gBWYL?bhPZ{ z94U2F@;ru#rkb$<zBBhCf%n;c>2jv%7{OJ1QY&~lr}&hSjU-}gTVnZ*V+~WcFf0ki z8+nP|VAF1~yFxag64&yw><!aiv)7TKtd>tjZHZpC{7c&bb7zJ#f{!T2QL@TjI(7A- z2bFB#?><LPh_*Vy5Dt2BI$K>biCiwMmLnXrTtqLqBXs2cKQnTKd%+;lXo;Vcq!6{D z@~+`=$p1oM38@#*!w0*eY#Ae0I>LQN7%7U#{;aL3>>Z-@;Q$nkE*9k_mENEPdMoQF zCwohF5cwKDJ>OW)ka$Dg4oCgTauA#`qac;S1oGHhA=>5~^QiRFcEyF|CDkoFOmM-W z8*<Q--JIHfqmo~75zz$ETLfN+_UOIssXo(IgtaQ_ezJVqv~iYeLaE>l@=Yb?64)zo zR7X}S-?+|H3`M06u|VRg<uTDz?$bhgXNxQPfyx*&{@~>`Dua3M#r;rUWL-@gp)PHR z;2H<hlvH+McNp&m_tm`-8VY(T`CB#y8{cx(PxfFqH`pb6!QL=7hN|mr+BGxUO1$e> z>2(wp{mJP`iE9qCPNJCJZj2A$B{%oo*?1s&B`gVk4+jO$P3x;<jgG1gSXNyXbC+0t zZ@E<40a)m+8kl>V{BV0;>FuhxpuN;=^w5?;-7Ut?tIO@9@q@b4Mt&sGPe~{43oA+M zPRE<^LR~C}8LV!b>@W7lnsHo7O!s%)@!uryf{h!N5pA(#*Xw;^d6mF0$4X~LdgyQX zt3*$Pdcm7+<2%bp^b^$9S~SbZ@?jJVR5DEO1a)~s`QRUWcb)eS9mNbf%ggtMZ&G*N zl~grtE>vZsPW1hex*?m_psw(jj$!IjD!E}f(E-cQJ7M{^=xaxfrLK*(m0?NnjF-<j zXlgIQRUEF~3+sY!WcNyx4EKUfmNz*_Nj?o5h3MteanOuB9@z|00K*w?sAN5rbR0B> z`LYM1_e9A=FGc$)w`c8D({@?@P9Qb>>M?eAqRc!W7L71tqUAf3i@V9ZY!q@EDRfMe z&A|9tPJeL9-iq@Pm}^Ep9V0C#v5`e@0waHBtv!_sRQ|M#r{f-#`|!fD8XGr>-s9k8 zC=e`kgptt+chyIBG=YSaV|(FJ8Ppw$livsjm1I|PpK?KlX0i6bw1oCLs2e5`U*bc{ zB<AJ{_kz9Vc2-wF_KfI?s0jxr!@~qSmE5)0ENlzji@t2jfslpXo8-TAVRv9b^hKDF zO7v2c6#h^*P{|z2KTTU{PzSd*-12w$S~k7JBgHGt=q6fYWDKHxWvf6zdo^U^N!)Qm z`NL-v+~IV1C>1;rHC4PatP4h2HnW_ntpZnZ%>CK&4Js2D8W_$E4l9mjMkR@ikl!*H zlX-N!Z~2x)M{S)Tjz_k^UTw;sz;eiDuZZDoIDP1Bu|2_f9@!_n^pmYazK`$c0$#XF z5;@c@mxxQgvq2jr3X>{9KAuEd%kQ|K!2Kltsv1-;EDnCMx0KW=b<HH=Ydc5zmiO-= zFMlX`*WL&ph>Xz7a-?XutpB}Kqyd2h1h(3n;!57(DvEp=*+=wFv71xLAx>Y_TN%1Y zJk}A<$-mbzN1_LTyD;4m5}MIp$vDL;lvGq)pI!;ezYJe0`;QM(a(353Rc(J7K0s7W zM{CPB6xSpF8ym@~)D*pLZtdvjt1cHLk<CD$l|<DL!DH8Xjg7RfE}Ll`$WK->neu0r zUnt3BIakR^bHAV$Tip^RPb?o>W>>O6@hyqYidRB%DwCAF6demog5w-C(>p_PM~Ep~ zQpX5V#bp1I$f>t^c!c0+*cRN@+sWQHIv#sa8y&S6`~at2#1>MCJb;XjKguf*Uo?Zs zo?%<?g4D$D>VgfTGI|SocLVZ25jbJSa#2UoaJ_%=_dTpPC==znmRH!l4Zo@@$J!%p zx83sw#nni?2oVf3a))JR0x3mzIXDD`*ck5)%2W9}dM@`3Si2?qShUUD!io=T>+9n; zQ(F>q<Li9_{Uiq2YcE?(+XW+k;p$_1lNe9z!tU9ds^m~~vEjwZpOKgi_w|mTS4z}P z_D6%N==g%QiQ0NoiKXtowsfMQ5^c53lTDy4hU|9PTW({d#5SjVpm+rNo|Lmv9ujTW zD}RMbfB09TXBY)@U2H~s2?#_SYb53P+75~aN~BgYP1|YmH${h)d?3nbFScb}(R_yT z!ER1R`K<O;my(U)<_<A8w`p<ItrM*`?G4ewP%3z+<g8^chmNA$-;>$SP&>*4ER%Q& z9jJ_U8^3cpPIj!`go;OV@UFcbmZ{j-Ap4%Zgyg@`_5+o367NgAVwqa;BiSPS-SKv| zc9;?_yA|9vw}_6I&{grBXfLkhEyinwD#1%9`d!C-=t}t~!;41CdoeQ_{tynC7K`3I z0-unY#{FC<C(%h;ZvqKIz2Ix|_Y~h{auk7kqN0>z>zHihcE=iN#yZizE@vLmc{-|z z?sA{h#a1AnRARcse{7_HkKk<=u`v2XvK{GtVEMqbOyOS8n5z#gyC|+C`=;Wf928@% zov1czhn=XJBlI!%Kh}0a1-<o*oT2x)j+0zvwoK=gN3{KIIf{+99U;4pr;yBH#%cQ? ztP7@al~>0hBgZH{udSt$m(gt;ylwa{ILLSfi7A|3)>hHp0@iYBYr{}_Ud~WXDA7JV zd9cs4@|G<KjG@<#KptqMco2b~jU1-r3wysCl-jbq`+Fu^pUP=S?nFhM_p;?2*iHGK z!=#XH5cUS!4Bsc)h~34|6h1WL4EZZi5t=wcK8fO<Oef1M^nT%Vm1*}a|D*S%x~mc+ zMJbJZ$Z1?{8C*mR$4Vvfx@cR7;4g+wJKF+!0||Tq1E^%Ncagu-I{HQ*nrJ*Dmob@< z@(*ULR5uUCE50vrA^I`Wt4`{Yj_zS^5DDi7^9}!1acTI*$ckpf)i%ZQQ;C71W#)cO zs<Gv5dZ`^IjzlGieB_@KsA_puT_;j~U<+%*3_oS=1O6VuAX2AvjCGyg8(G8NILpDJ z3TC7+?U9a5kk;};iGD`5GwmINrn`-jy!<HY3}-E~g${yahOf|(2nPDvoTX&EX)o;M zpprFuxI_la5?+B(teuJea7s*!ehT5-;6tKoI2c4P9c!zU+_(3MlmDUZZ^gqE#|X2* zP*F!J{mp&sSm!OrdUv;&R^PoeB=vxy^pu-hE}~adl+3aAlPaLMs4JPExQ;`Qx6J7X znaPjfB?FbX5>L&Tpzc2^OQ__x9LGT%?*C9SfWJCMmbI7FL-_|vx|bp5mZiK=$y3Ya zmVYTOYHzJ`M2yVJ^I@WIioRAC)5t-J|0Oz`zyh9MQSyr3o;n7*-P!h9Kt|`7K=eJu zKWOU!4;_CZOeH@=+gUa;=~!*X9V15>*_d)FdXGpol&EFoN{4>p*2cSyvy@+xeXK5C z^kE=3m3{EY$RnhRN&G`Ovyts(vyl3WKo)yFl{As~Nk=(Rd^1*QE5>AeHcGkT+R^8* zSJqKmsw*w=*vO0a60@6?@>7GdNmMm$oZ{4w4T@9gU|I(bvRU3H|4iEv9nH<%!BuuD z3zZC%NI_tgK?N)iX)D9VRm)e|_{Uy$9bbvEks3p4ptk2`%#?j0x~XlZx~~}eC^Qs& z<t5B)udTM7N`9mq57uyyRqs{Tlo+aeJim!{M3<27NN=aTp`QLjdb8m(hKf<i;cR8O zzhZd+mMSS{Z<w}CUYZ0Pl#=Z%TV8g!Y&QNDD|ujAO>>VcImE^rZue#AG<esE>RN83 z(p_;j4{8yAli0|wW4>$>*Hlq)RQP`t5;@QAs|JnN_MaKu!jZutqVJfNlfWK#Fvjw^ zj@_bjtj*Ffg54PO(%4%9chqHPBL_6#WiOS|&RavYOVq{it|5XT92wj<cO<>B1g7(R z&b0GH|Fw5Z+ZuYso#VQamyVTE^eaqO_qDq8<gddhqK93?E+tdxE#m%(19mebzdPuy z__F0I@U0n>!;;`n*4oL|<i3v?b*YS|9LKcg<WG|SLT^cE!s&5)r*-5~a)ZhQDqkwO zWUp>05S%b0X?U2RxoEw_26)P332mE=>};=>k<08gV6v&`yD$nShrPi~0(Ts6n`1pP zD7UtTiofI~EvZ)g&ERj7x_2z2SUaiX6?@6tZhDDl(1K_J0<}cd%w4S{ekdP&V(u7v z=k&fOYEG)Ij%_@DV{fh~rk5s=Jw;`Xl8J`bf?qlPRNX%ku@raZAcpJ_hna82w@Ol2 z7IUJ;^xEqf%3mec*1%e5M4&)8EjY*ND|-7F{;_HAQ<-J&6;g#s)w4G;^c=L;G0_$8 z5XIL~!3VZ4fvK?8$Qq(2va>B)!euJCD8C5>EGsjVNAVQT_iZoICd<W4zUm0W^p>&w z$Wi-?in_m8RJQW>oxMKxG7|mKau=0Jt|=Gg9(qSZCwOM>9S5ACxVpCdqIUE~n!80d zr9=(5%SLvh=_GRcOeg2QyXD8x^0NCy+u?(-Etu_^wy;)Kb~&_!2})j?R#>#h@N1R{ z+*%sZ1#P)G&1G6WZM|fFQk>0~^wj8cKt)d>0jJX}8|zKaT0e*BA$rrG+@vPEm)q`d zu)6o?tr9IH(8^H@YujxvmAypvrctS__YeNI^D@RG+h=bItT*E~ZFvmZpe_~p?4o61 zB3SE6rZbsH@n*-`uQ$6Bl{2lF;)J1m@Pp!gp_kyI=o2IB(0fzeU4stjtph_OrbAxC z|EB!VjHC{;&ePgM;5zw!veT$M=cTp1ckM-VtQAdn-qbph+WUaY*N(81mmKUKb%}kc zl!qG(<um-lP%rpR-Fu{x!8QW1eTYwJ`;_v>_Fmz6hG|VKODeu&FO#_yiH?WDVOwyW zXlf;`J(S+0W;jBAb6Z+AqFhb1fj|l;pJcC}Q_fVJUbNJV2b8xOK2b*t=O`$O6FLoU znO4cmRi4x=y?G5UVA>*fFX&BZub;NR>BV)*A9Z|h(5s^MqR(W%)mB`zMcZ)acq}ST zYL4Pc?0%>&rbj!K@=JDG@;6^`wy-4lm%lxvN=Up2{ROS<7343Ey&dZQus1e*S%cA{ zE)pGx#x?B=%1xoC<=YZ%*p25L$0Q!XD_kvQGA#$6S#}GfU;xoPE~h3h6RDJNto~Fc zI7d$JOLEKUh98C52F;{5+HwQY+lu4CUh;R%?JX)9>IFX=^e*Lt?j<h0sisvY)x+@5 zM3qQA3A4d+9r2wb4V8CwB(Pj##;=O=GM-UloR9P6=sRHOeJXh@XEFJ+lChA|D^<<3 zMe3GQK1Q#jXas*L)U6Zkp>ki{Q`xojst_nabh@_6-msT!j3S!LU5yQ+;BW5FG5H~Z zo%Cv0ehG;!XKNcwbe_AK1D{79Ridgv37z+KhDzyJZRAImRl>Q!6*FR3wxM#7t4olN zKn;mP-lp!(@i!Zt$iL3PeAA9<dkL2mCvk+WiW4f?4W-RpC0kJ9J<5Hkd=DF`ELPHw zd;|WXJc{Ca^DB-pbl)<!%PDO}c5S1GCUU?<vJ1#JCi)Ml_w_cH2rPer)k+FGQ3t&- zqQAm*{AzA8%DZ^!X=DKc+3o!&TSQyga2f1zYm>Fr^(L02T!5j}qFD9{>Rs;vv<mkc z6o_>+>udFzwr|#|QN3C<>bI|5uW7R;^=dY6R<B`$_DyPp|8X>FbiPK-`gPhjt=GEF z(X`gJUairjeY1w`>o%#=xP8MWwd*ul7Bw(V=q4IZ`WNdzFfz2`;I74nb{tr&Tfg32 zx(*yvtiteO-P>0fI<U{kz9qZ$EZ(EX@R1|i_pVU3Q;&hg!#~~o7Hd|lf24nrNZ&z& zJNE8fq<HbNLq`lPF~nx{KkbKh?c1f_z+#<ybR5{F>)>KNBZImP>^h)m{}D&ySMJlV V%aGn(s}>IL!0*$dV#kUd^M77L-Vgu) literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/jpcntx.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/jpcntx.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..fbbb8cde7eea925b0957b405e74b3891c68754da GIT binary patch literal 37620 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 nNp_&0clnRyQ3^`@?p1B)#Q7O%so#iM`anc%?J? zG`;nEcP9Tybu`WRlo^ZZlcSej58Vr$^jbJJ{ke4C^62YHJ)fjIzn{FFKh5T!v-!_t z_&nJ8IEOz>W-@p7jc0!ODLxx^{vl`oErarNnx4+Q>631HdEcJ%Nu3<NaA|bs7n;$@ zj5snLrZ-5%J=yh~a3%7y^Y`g{oS(B+en2|?_LJ%7$@GTrbr;jS{$zWxbK~*SX*C~D z=~L?$Q~PKsn{Q;3uiB)4b+nZ(>-GnuZ{=K`m9FdbVy+K2HtNgC6MHH{(3J1?U#IVJ zem48<#a^d<xXX=SPl>y}^1JN0^gYfms`^3YA#J5!Xw&;RJuwfx@YdN^--u6R?ySG= zx?F#pvhi}Iqwc1waylJ#eaW7v=F(9=%~8)+^S8R24<yu~bRnLv`YGyF3+dV<rgUu< z@-GMJ+AQ3;Hir``|FTeDoA=YjYLC8KxHgM-uFcWi*X9qC!ktgD`LATAHzt2lPybDy z{FLl`KbwEgIj%~3^lRCFHk-nW{GU?(t_yH7eXRG>?_|3!z?Vw9_+)bfmeYq_xB@d@ z%V*NKf6OEE8T8wu94{};jUG)uC-YlxUmmV+^Io35<#KtK>gM%6=|4OD2>H&J5`s^~ M-ftW~d;IbL0fdb$9RL6T literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..271c7e873700976cf954a259ac2a004870468157 GIT binary patch literal 23644 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 Nn>&Ap-8XC7e*qh_!$bf8 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langcyrillicmodel.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langcyrillicmodel.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9b68950092b4137a7a3397604e8e26811d4b7386 GIT binary patch literal 29108 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e81336b1dc80d101d4ac4568ab8fc315144590c1 GIT binary patch literal 23602 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 I$2MH}4`1*jhX4Qo literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9fda9ae311beb8837235cd8f721026030bbe6933 GIT binary patch literal 22229 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 BoMiw2 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f75abcd4f9d8c9746c036daa7e9a3b88535ac197 GIT binary patch literal 23633 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 V?wLD#*5?0hnzvwcJZtu*e*<^1H6Z{1 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..a76d10426362cbd957d7f2032fccb71a8836421e GIT binary patch literal 22208 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 XV&vk5L)duf#`m>0tzY-w|4#iI)FRJP literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8d80bbb5805cd603e445fd1ef0146d452fb9ebcf GIT binary patch literal 22231 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/latin1prober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/latin1prober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c177307ca80da3e46d1dd7b202b988d3da03afbf GIT binary patch literal 3415 zcmeHJ&2Jk;6rY*>@Ora$(-7K*7AQi3S|W9VpfplNQ@J02@=<WgVHKFVp0VSwUOThv z&=}`JBJ~J=LUZf|@i*{i><PpH<qv>EFYw-MQhP&)+7l9DM*IBcy*D#&e(xi>S17my z#vecK)t*ig@+&SfgAy_ig6K;|h#-Onq)mNFk!JyG8@>U&;hVzrEkS%+Sbk2}z5}wn z$oZ~t{4tUDJ>mKVY5(gpCtrMydhN&;pQHONK)}nO;KIt4mi|zCbfUEfdJim)>Rxo6 zm&578dBau8Wo7n=9yP8U8<`$>G`dDUE3-%RsPVq14dNHYn1AXH5uPaQ5>b$J$MDBR zu}Vs(_959wi6({0T1{1Dd{=cINCg59xmMV$#<f`Pn_#sMAK8bTB>M&u3yF;+hr|I= znpY@&Zh{-t$wZ%bvWeCnXNPZ7nhX#4M>~8;YOJ~A?1rZdxuM<gqT#(m*~xa#&Z~nL znSoH_h!%iI;!~)2_J}m7pn~l>z99@@?h@aWmav4qOLnMl1D_L)=5r!1T+lmWOnC5{ ze?&~;yAb<A;w{wTRydo+ypFye4&?D>{Gzvj#3ZHzvcn#;J%XKRK)9i)IUtX%R0e0# zrIMXkQLihN@?cxyaNY`AG3UuR4{A}&>yT%>4s4VZctgnzUhnk6SgOQQGLrEVnwXIc z8t|LvsUhc2$kSfAt6H0oi{;IlDmOZTkSZ$AJuEl*+@@;x!*?6&Giz%P`+XkFU3svk zW?(eK@=Cee>Q1-9D6R#;^vuka&8^K@IIPvxAK#Rr=%_NfC1hL<G$LJH1(&;9stAv$ zAqbe>gchj{v;XoaaF-9Ccr1by+<Xy8jF>^xnlxsU8o$_lYz@es?(BdaThes{02<3H zAE{HYC-H87cI#7Kxv|2R?k%cu5GgD`bsEV8k~7c9*+WGWm<W@YfUh3yPh`B+DF4k> z47hd`D_v0SPT&2wx;%aL>icukv*|s@+?aR>9R!YtwYCgkcZ41i)}P8;J8Jb@w<ia0 zJMK;=sD;g5ttq=B_ho}}Xi?YRphqyU2=UV|y$=i|FB#B1x=jc4Ci&u%Z3b!1rpUGt zvjJH*ViQ7ToFyPJ2d1E3F*P4s>o$ZkN6Cf{HqOAbKrh$_P%YQM8cSoN2%0>gXrw{a zjiux!=Nqj6a-DzOir2Udn?WmD<AIDp79|I9;uQdNrBl&0GM<8{7mFPsgETMlm4zGC zs!j?l(ZpU_Ug3+k5}QMw!(o^yP>0BuEcFtuoCjO61hq<NJ#jG{2W4nt6&}f>#B4|@ zV%Qg*145`v9hfd<f7%Q=lTJ{F^-pJFjC(S%Mc?q#c&`Ejs6ZoGXMp24W?2kqt(!X< ze?XV0OM-2)@B&JOF@^T<Zw{bqO_FmEsq<u;4VYkHc^55#w<om>u+A+tznT2u&M*Dl z>sSJMq<>v7yAMR~%{N!S`|0;ftG`_bWZndYLJ!p&KoTSBwKaAnBL&ThJJ2@(u1?r! z2^rSqQJ{)VNd2MuTR7$bGLM=JVYAs8fXxKhOv9o5^BKspyGvu(FtL!JVY-~RJE9jL z?{U7-s|Be>HznNy5(hdJ^xAk!y@HRpfaDUAcYr{HO+#FlLBRQl=kRYQQMzAXlfDmM zgc;*d&vq<ET?0R-s9X3_>2y*!sNS?M>K2q(GVHaZ6uc?eoEZ0R-d30`iE*P^K~e=$ z`5ehIE|IG)tBYWwUPJOa67*oiHQmq9wZyrWKL5j4VHI6~I`*i?OlCszWv0PMX41@x Qu>aTpZG3*V-!=<>0ghZ-Gynhq literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..82e72471bb65ff1bffb74726c8b648e8808659d0 GIT binary patch literal 2278 zcma)7UvC>l5Z~SVle2Sn)1-e=0mXm{GNN@rq9Rg3KoZ(Wt%G8Rhm+9i;$7S4p6}ef zbCg)_3km8I-y!C$Z#?h`_!#@jQ@;QYs8X0&Cn2GU#GZFNvwvo0XXiJ&RVoz;w7-6v zgj*#-{zTzyvqAV8dbR{a5J6+orvatNvzYa*!0Ow9P02$dEMXrIVN1Gi1&(kUr0Tw+ zu&qjUX{8&ghRnZL>9$l=rhVk1q|?a5Tx$PG*y=`!G*Sz;oNMR<w(JKWk_1$cfC(B{ z;>rusrp9g|unq4B_rMDr>53WQ9guw*%m7~yMZ<eyR`>@bD2S3M!+-Gwu}Lrsp3dnT zPlj<GeY=;-bH0u$#R{~GC(Ts7#f*DXg1mLyvrmA@NlwRPpY_<73i^u)-I#Do5TLeT zf^`^hjv(NMRfk~B#$nRo?I_NrdWBl6u6DBFKq}>cq&?1~B+5D0*F}`&D%u|AQJU~D z3FEzyRJzbg1;mzTeO=^nnB}|$;fJW(nT*@Y1tl-3E^yw0$&B-t<nP_uKt(%n7qy*G z)!Jz+q{?c`yR{Bq-ckKg@>#pL)a~w$Mm%1=zui?!&^k%2SsO%yyHS$mVI1FGTDrfp zxAW-`2TkWYG7+h&p?x9qT7Mh4Oy&cV2=@kissP@61U>VB5IRp?_(tzu9PoQ5M{i+b zoiyZ6WBveylb9c}384_@o~3RhJ(X>B4`h2P3%Hjvcfjgu26R+ig&s{q?kEXPt63aC zz$hQcOR4}eM3s@uA-RfV9>`tj8LlC;496*&K6?9-LmB07oCr^~f_l)6ocsi7-vFC+ zxVnXUny>c<vFytvmtsw+RH+46Hg)6F7wsR1n<rskevZmauCmbwm$-6v{r~ewT|>Lq zkzC|~hsit)J97Dq^~-MeWbHXbVb0@)m{>4~in(3758o>J@%QI|o*p~2#&pbXkqLcn zjji17IZv6Y!;E`4BLIIr4|-wDCQz#KVs91@=Tq|Rk7vGFU4qqZ7%%^4{0fZwM*rM| zJh#VyRv7sekPNn9{Hm}X;Q##L0!m|h0uF-C=?HivtVM$KCixk6oXk^UAMa;o|243E z9W=i-J8w(~a)&o3sC)6LtzMt_2J$ti6Ha~f-kq!hzbTL^-6*d>eMnU$%q!ba#9+>( zvBETZbp)+?OFIfKLuxCQiOFSMOyq9P0lZLZu*_;_ZF6&DQ@e56=|ClMgxnr>)J>RD zi%1Y=+O2Oi`I9y6PIqc|z1cw7`)*^azRK5|+G#Yu*=*{Cj)dAXR0`76)F3pBurMIf zc3VmTrOmtnh1Ip@+Ddc1{!m}(q&b&KI_z}02=h>vjh-}VM?xkosplJyHa43pTTR}4 zw7CYt<JGETz^FYuJou$FjUfGx3!$;#VRCbH!2skGCF(=)=u7C?7eEM|gRe+EYQy8e zj%?-`^iC;`m+3rPr0mGG%FKtA{t;sy8@+W2r0|e$KnY=J5*n)sTq-%F6M(k?Q<Y6? z%*QZw5vCMQ1kk5orlUKTSUw-MDy>(2d_1rgz~fQmyq}6;jJ(hJvtbw?&&+Tx(iZ2Y zHk*2;J;*b7fbzXFxqx9azUb2NQ__-g4BP$<uPKeDDk6&CN1w4gLTv4_>wAnAE$rSq urp(sip(~wxAQZ+)J2DyeGn0EJOU>dlR!(nHdk>~Z`sy~C!i@Imob?a4XDO5b literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..74d19323452799bed5ed0999c1d4334b998b9088 GIT binary patch literal 1143 zcmZ8gOK;Oa5Z?7858I(MJj986kXok&szyQxH9$oXQAJuI`Lc3i=fye+yH04M9FS6} zC;kIH_Qvm7apS}vK!_7Fn~<j6)i;`NcCDS6Z+u)RI0V-3?-${ZEFnLUtS$@43xNCr zCL$5#B%uMN=o{Qf%)r#X$*sf=Z0%b-lVpRe_HCX^@<Cqv8SW%*;A%h1y`&Hnw4dX* zlC@w>`+0slSr67J*(Z?`xo0GDV>&Z~V&v6Hsql+J8YQZV)lMktak?)Cqv4?#G-3f! z=lJOL?iH&ays0ml`|7xQaJZ!2{@(WEt?ebp<G1gxX!Wr2q_U*WUbp>p$?)#chdFIR zKGzmD43~TeCME%mNMJ<PIcd?zh|IHmV4f3;1QwKItF?D~)%r>iwWguJo*VRY023fz zf=NkAr(|aIj46%iSCAn!XC$=%HXsAY0&;*nz?qSDZc3OtCEvUYf(?dOjT*Gd<zc_g zT3wz(=L*V}qhTzB3vZ|#W8Ho?WlZ3^0t*s0nhY8k5+X1ukw=5mqq0M-fK;}KWt^4_ zWyzSgga?P0ROK0K@=!{~F3H~$e<-@+Fpd3jDE!udN3oE8<-~8Z%2*_m{&uTZ?sQHj z6UHk$jgBb8YWMvkf7l&vbo(+5Io~LkcgCmVtq}$_*f{P-1K~GeE}}T~lSWgvaX99w zZ4OVxEy(5(K;8#KXwk6fwf!gKOdj0OWAlG6O0))YL2LS95;LY8#*#ra;^=#feHw*) zexjdIg+<BDm~&|4U3hSAis;=#gS{>Rq*j?~UMt;EMJxfjxRSlVE6N$At=)M!S{dcY zURN#xsFHHyQM0$GSWBk7b_2(JaR~*~mp+O`1l3e-a|pw}h@iB}X~4WM0w}ZoDE+*M dpyoQ=mAZ6=SeME@n>Xe;{s0o|_2`Xl{sZx#9-aUI literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/mbcssm.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/mbcssm.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..21a1eb49b840bab8b06f339862b5d7523c67982f GIT binary patch literal 16766 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0b0585ace9a96b9f52ed181b04e775fecec9a8ed GIT binary patch literal 3031 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 W@KriA!R_pze|VdAr3ocI@BSYcDB!99 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4109c83c46af15b990e9aae01b447470b45f183d GIT binary patch literal 1641 zcmaJ>O>g5w7@n~m=gUr<H0>4yqSpv^lXjJ`l@LO$L|MVEkP?J67t67yj(5jS7(3av z%AT^){s|7P#AR>%p1E@3#)$(Ln0F>E%_1?;JbAzDc|RV{53XB7a{c-1O(0x^egozH zvZV5r-1*NEA{1eUQcN%g*<eO$5>v@0v(geNr8cqCGAXAOQc0_%n$}27`7KsY9pa=e zag|<TjkHOcsYg7e+pLwgNn6Qfwv%>9N68hoo9>Z4C0E&lbf4^FbcUi@RDXk_I>l>~ zd=NP!)OCNyGQ}<y?bB(%N3=NOv&H;-KATW3tq(>?7BhNsS<sDt<FZBP$0R#E8XTTp z@`SM@d^U?H6SZ$=$rG;So$rDo$p+g2-m@Uww$z_a(kH{Aenu&Sfl|7L@YE|lKjW0X z)B!Dh?Bjn;GOVLdI$5wd;7O3_(A`aj+h$o+bNqBPJnE09L81?m<?GnNH*~`3t6Qt1 z)w_1I^*Q4Of0^V{6&1?%Z7p-7<sV6bB7!4CjJN0<M>sOxREYT&S%_G&_oir$PEJSn zIv&C>ZWoY9k_*8L^Is$ssK6_<Hm;2ugi&D@)*4GJDYO-q6;>2h71k8i6*>xCg$;$x zHIAJX^1Y(9Mz7&*?Fg?VJzg71Hk53x@b%8hSeZ8lMl1BfyY8$o=&^YtNxeeXyO2?Y zps43xkGp%KlrQF#^R`S|RD3_llEU{nl)|AdUIMTI$^aFBDgb;~ybj<1Km&LKpd~?+ z=Zcv*_rTNyQ!A&1p91;(jZ@h4qM%tMN}Nh(*AiAv*|~71YPg#)vCC$05(doQHg}du zzIfmI4vVVqhb+i*-+zbxy6DY$vJ48^TL!#$K4TH(dGGk57yHLco?c}~=P&xx>BZHR z&yI(aDeub_XT5Q6p3EO6SzZK;J?!^~%gg2A0*q?=OPThJ_d@wCMzrYVlQ56rgVdEh znqTsctobv!^PvQU8-|Vl^D9ZqA9mZu7B-Oaw<Ti$9bA+Dwt2Px9_=384yap#VP!!| zeP7gkXzPN3?D+mqvMJi5auDvOA0cH-j`kCojfRgwIsky_e=2uwNT^_?Kkt4h+EAaI z%)Qb$govgrSi5w=iZG(Zf-DX<*NmF<|8qz*;DH$K3>|&PDbWVc<o24--aDQN7rceM z6|@6rCz@c>4AE9aI!9YJSppe_rykZfgN_8os+#XLN44ny;wxXsDB0aFp<g+)%E1mk MFg@(aNvWUt4<)F%l>h($ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/sjisprober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/sjisprober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ba7128858fcfa6583f77f51b0c943e1a5214aecd GIT binary patch literal 2499 zcmZ`5%WfMtkmNqJl2@{0*RP@|T%b7!Z6dcQf(8hRrnZ|nh~>ai4i!+aYmt^$*<C5z zm0=6Y$u4ruCs@ba`UO4oGkEREKhQ%i=?qt@<p$x3<d8#h-ZOe$E|&<jfBqN;e^v<j z8yB<9hQ*K2)8AkaM9_%Dv_&bxEMl?MvJ7lRcI>nq1KW`s7g_}aJCPR`TSWuAQ7N8l z&BcDpr{ob41>s!~;YoUKwaTK{Al1?p1u|8tSM~-`7XEaW$*to+HDvZo^$w*1%;Hv0 zgh{871)1Cn+Q(rcVRx<ZWVf*$rkM&42U*xl9wtF_mWC<dmJqkqOEP(y&1{!(n>Y6O z-v0K^(<;+G(wIK2{mJ8oP#d_q(X7cTeFlIeEh<Qhy(ULgP{A&|mStc|*Z|wo5sq*# z$T@Af02{FZE{LKiU67V1=7bM(@innYs|0E&>k=}T%iKnlOdG;T8+-a43>nGjh@7)a zHYSv0R%V~Wnmd_$PGBx%o|%gya#_L?f;7lmTCdJ&Cmr;qQbl+~dz^<!m~pP~Vddgp zv27I1(^#Ps=w&gZULK%+hj8CP+(J87?|<9cQ8Ja;TdM6;Mn^CgId4ZnnsWY@yi03+ z6`p_vYbSxK9rYq1Ra(1$TI=xpCn_E$-yU^0kB?7>Lmu6~cX+Hep>>j4v(^v$cfusi zf+)JPxq0v8?BtsPZko<dWFmU1)&`#uGOMNCFzp-1x!XTeK5%*)dTKnLR%nTO@C}WB z<hs5))x*b?{u#V*Q|TkpwQ}{NauvQ_wbdL<M!9MMp?Mr`;jo0mG7c*^AogqMDJq!& zSHp#C+ut=>{D2wsf-St`!2sk*mre;YLrMFn0x$qif>`Es4asY|t8jG_-(WBhHe8*d zI(zx!#F1eEgsZHsy(d9GNWkQ|WJb`N1hp3hNoNprB)aXC>a6ak__pB)xq^o7Re)~9 zt%Kl3_w*dTZSw28R}92wm)3}m*g6^0SJntZpzFL~>KS0%%YuM#=z7qLBQ~}nL`vN` z2n@(TZ|F<!rEkuc;d~b`l@BoUfbk8Dg)w<$kC<Sv^VbN%d>vJPOIQzZUc6i~D|=+G zL6H59SbNMU;y%f7`5GwZr-5T(t-`4_0+5qKAKWvi%n3MqjfGdJa3>rv!@)A}zw&~; zq3W@rusQ|_5x!g-BNyv0Y+O&Jgq>xuU7<ew;&!?LzdTSjj>BvN!n&t6f^6du5-{Md z&=Ly0?h0*lg-PP-J+$hl5a?i5sjWyRsto(Olt7;45TTh==%3ozIXKuq&~DW0bfnUb zkcWegLjP0iIG}m8Ti<W;y&di5H?_OlY~b4adH;ERo9{NY(`Y_CXzHa7cy)WAluTd- zF9*W9#38lh%iRC%BPoS~f(GObE4sM7)7;r=?$#ga`A#q6GU*LE$6N$ipeyFhUUC!) znY5)|Y&_mSXl^}k^5)}%9aucwt~zQFU-M8Uz@ySMgeaS&NEB9k$PGt5-1L0)6<qut zdiod!LKon})MG=sXYXx>NhnW6B{Ns(3dQ|Jwg$6nU;|kdR-r!i@eUi#&jc(=dm~WM zLfB2%d=3DZn_N<GVGIXmAeNc1IcL+{Vdq(@2FG*NS#fY$wQ|8hR#QPa%tzXv6a%yR zzr6UsFVIu0BLrkB(c$_Gw>Py7r3lIo<|)p>kUZ{*L4>f+`O85N<rtH_O|sM;cq&w` z>}<w|P{j)A>hh${v}F`QJ-arA$-5@yV#)gwdWyN%qkh4+87*1Zy)R78u2(C1K0ch} z!8|e)y1rh_O>TTD&i{Uxnh7Nki_T1m%&Vr`?YEQcG%u4bJefj0HTBhz$skUR_nSD$ ci^Vm+210(d_aN8F4_JFrEMwpVlW)QL7aa{*N&o-= literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/universaldetector.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/universaldetector.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2631d1289273ac4e0e00ee26c73b05816f2925a5 GIT binary patch literal 5843 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/utf8prober.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/utf8prober.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..26fb4b6bd8856f1c797aea0fddf5103b601b6737 GIT binary patch literal 2004 zcma)7%}ygn5bmBokIfhetnwp8Ic%hj94(lQlnqEx$i{d93G9_UTt<po#@#kHGh@>; zMqrr}NPF8;9srJeS>;Lc0DVf76Q|^qLr$sc0oLp$Qd;VARZn+U)z?*@_lm^=f$`VR zSFK+_`yGwxVS({I%w!7$C!B^Pq5-9-8=(=Iff-qWrEN2`BPVdQZiTtX4O~h#3Aed( zLAWF6xf$enu1QMnHHGU+R23@+E!h<53pv;qvScU^wO-t9rma*cZ@1Mx=*2=?uzjI2 z;I|)dKH(*M{_|DV+-1A<jp|MtZoW6n8!Pca5hS3T1O}&p`I2-fH@JD>2A0+>Zi8+M zhdVrXLC$HA1Ks6$t-HLyXD$e&;PE2-7G4sI1T&D%tSVp#SrXmM-LLCy%<*=hj)CAz zz66nylupRGacNu;N>Vem&cS9jCm@{(xy<1@CvZKjm0V>fqoI&82S=65STF9Sj7b|z z>EK$vt)XE_q>3yaMJ(E9Z2&h>wiJm-UsGizBJ99#p0Re=N)pCilfRSlQ1*@i?DBC- zmOF!x3z?MHPRd=jb}XZD{8gvFa&T}m9<y-m>HdLSfzgf2etFm%F7@IhZH3{|%F5H@ z)8i*2T-1{ti<l2&8AISAEsxU9>QF!O^6*sVA>v0c6Bh)bv$Q}RI$nGW;__{V{|(|p zIC&q$3F(^|oE)LFG<Zhs8hw;(iM}*`(nAgFUe2H>qL@SR0g43_xaBd-1i{TB9M4b1 zr!jpmIDF*_p2D`_6yDCLjcv$%X*IiByV73nTq#dKlSo<Iio_E<ZGa%g_@gO*(|i7x zTXmDozj<`SR@@!6y5j38Z`0`CesAkYFd7(`6HcArPoPZb2KljbW&rNwl1_{(dS*_{ z)aaXshJ2h_eH%-elB4j*((5@`-+*=Zo%KAdTl$v56~K0Aqh*o)3^%?Z24ORBp7cF9 zS%jUhpgCr*piTO7hn9SGdmruqz|Gn<1}!zg%<ETHg;<=V3@SAh5;IVCwb7_IBsQaR zYIUFOR+W=&P|mjBMB9B{->Yq~ZC}|<|5?LVi(Po5_DD(*!!OizC}Lee(3_gA@*7pZ zTJg7Qn`&0?9mJg;7javth2~bh;aB#2=5IBsVC-y^EIEt*-Tl*4fN!a28*1UEi*>B; z6pGamg0I1u<TDV2y3~WlaiMi?<t&{yJZLA^7|%@=51zYMG>8x;ub*-m6i&~eW%|JB zheSS_pswvjvPRA*Hz)LCV4?|Bv~DV^)_t@2+xWqoKi03YL2fwj&-Id#AyTZ@s;sj0 ztifJ1>Oa7$PSqL3Vee36t#H=>@*&)?12fToMbv_H<}rm&rc$_%XURhj#C~B+6&Q;K zd=#SYF?KX+h1nNbf=e~m=yp~v5D;)^dMY2_hYwMFfdT^n*34M3Ey56(^)2?A88j&% z`F;*FLCd9<;W?gd(1MB6UDV`KD-~4nrdu<@lZdvm1(0&0OD?Oyh3u(y=|tJzoThW- jMEmU|i8QTeeDyY#JJ6K-ZI<+RpJG7BZ62WJQP27ZoaMyI literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/version.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/__pycache__/version.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1d7e8afbdb11e94821d1d065aa391dcb0e115978 GIT binary patch literal 451 zcmYjOJx{|h6inKbqM)wKZ=^%x@S#er5ULOiEJdP)p-be}PGWHE$aX@TUqeSWB>qiS z{s9966K*LIC%v=Ie$u;lzVCE=$Kva4jX&-Au@V2#v|?mSA6g>L%pvZ~rS40EG}i8{ zNtzR<>s9amG-VnxNeWJZE}1qOq~I$s5;V(l&f*m)Y80a-6A74<LP?coQh+G3IaMHI zSfp4HYW!Hq44#=unE*{qkq7w-upqE~*mZ#}<~d$G;e_hI_lLMJsZ>L_!U8Ti7TY#B zB3K0TKRHS=%y_VnS=X;xr$HE;)ow8EdUZRBh+ITbeGo-EV^*}Zb#ChR!}Z<d=63w* zs689QmcDb8D^_AdQHd3bB`0<tG+3e}8k8!l#7X=Zrs=Y(B0lKPQx#ey0!>lQ@*We~ rV9tAC*e_S*ak07FmYpt$RA{#)+L^Hl)cfbZ0bjVA5AiH{ZO{Dy!pM&9 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/big5freq.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/big5freq.py new file mode 100644 index 0000000..38f3251 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/big5freq.py @@ -0,0 +1,386 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Communicator client code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +# Big5 frequency table +# by Taiwan's Mandarin Promotion Council +# <http://www.edu.tw:81/mandr/> +# +# 128 --> 0.42261 +# 256 --> 0.57851 +# 512 --> 0.74851 +# 1024 --> 0.89384 +# 2048 --> 0.97583 +# +# Ideal Distribution Ratio = 0.74851/(1-0.74851) =2.98 +# Random Distribution Ration = 512/(5401-512)=0.105 +# +# Typical Distribution Ratio about 25% of Ideal one, still much higher than RDR + +BIG5_TYPICAL_DISTRIBUTION_RATIO = 0.75 + +#Char to FreqOrder table +BIG5_TABLE_SIZE = 5376 + +BIG5_CHAR_TO_FREQ_ORDER = ( + 1,1801,1506, 255,1431, 198, 9, 82, 6,5008, 177, 202,3681,1256,2821, 110, # 16 +3814, 33,3274, 261, 76, 44,2114, 16,2946,2187,1176, 659,3971, 26,3451,2653, # 32 +1198,3972,3350,4202, 410,2215, 302, 590, 361,1964, 8, 204, 58,4510,5009,1932, # 48 + 63,5010,5011, 317,1614, 75, 222, 159,4203,2417,1480,5012,3555,3091, 224,2822, # 64 +3682, 3, 10,3973,1471, 29,2787,1135,2866,1940, 873, 130,3275,1123, 312,5013, # 80 +4511,2052, 507, 252, 682,5014, 142,1915, 124, 206,2947, 34,3556,3204, 64, 604, # 96 +5015,2501,1977,1978, 155,1991, 645, 641,1606,5016,3452, 337, 72, 406,5017, 80, # 112 + 630, 238,3205,1509, 263, 939,1092,2654, 756,1440,1094,3453, 449, 69,2987, 591, # 128 + 179,2096, 471, 115,2035,1844, 60, 50,2988, 134, 806,1869, 734,2036,3454, 180, # 144 + 995,1607, 156, 537,2907, 688,5018, 319,1305, 779,2145, 514,2379, 298,4512, 359, # 160 +2502, 90,2716,1338, 663, 11, 906,1099,2553, 20,2441, 182, 532,1716,5019, 732, # 176 +1376,4204,1311,1420,3206, 25,2317,1056, 113, 399, 382,1950, 242,3455,2474, 529, # 192 +3276, 475,1447,3683,5020, 117, 21, 656, 810,1297,2300,2334,3557,5021, 126,4205, # 208 + 706, 456, 150, 613,4513, 71,1118,2037,4206, 145,3092, 85, 835, 486,2115,1246, # 224 +1426, 428, 727,1285,1015, 800, 106, 623, 303,1281,5022,2128,2359, 347,3815, 221, # 240 +3558,3135,5023,1956,1153,4207, 83, 296,1199,3093, 192, 624, 93,5024, 822,1898, # 256 +2823,3136, 795,2065, 991,1554,1542,1592, 27, 43,2867, 859, 139,1456, 860,4514, # 272 + 437, 712,3974, 164,2397,3137, 695, 211,3037,2097, 195,3975,1608,3559,3560,3684, # 288 +3976, 234, 811,2989,2098,3977,2233,1441,3561,1615,2380, 668,2077,1638, 305, 228, # 304 +1664,4515, 467, 415,5025, 262,2099,1593, 239, 108, 300, 200,1033, 512,1247,2078, # 320 +5026,5027,2176,3207,3685,2682, 593, 845,1062,3277, 88,1723,2038,3978,1951, 212, # 336 + 266, 152, 149, 468,1899,4208,4516, 77, 187,5028,3038, 37, 5,2990,5029,3979, # 352 +5030,5031, 39,2524,4517,2908,3208,2079, 55, 148, 74,4518, 545, 483,1474,1029, # 368 +1665, 217,1870,1531,3138,1104,2655,4209, 24, 172,3562, 900,3980,3563,3564,4519, # 384 + 32,1408,2824,1312, 329, 487,2360,2251,2717, 784,2683, 4,3039,3351,1427,1789, # 400 + 188, 109, 499,5032,3686,1717,1790, 888,1217,3040,4520,5033,3565,5034,3352,1520, # 416 +3687,3981, 196,1034, 775,5035,5036, 929,1816, 249, 439, 38,5037,1063,5038, 794, # 432 +3982,1435,2301, 46, 178,3278,2066,5039,2381,5040, 214,1709,4521, 804, 35, 707, # 448 + 324,3688,1601,2554, 140, 459,4210,5041,5042,1365, 839, 272, 978,2262,2580,3456, # 464 +2129,1363,3689,1423, 697, 100,3094, 48, 70,1231, 495,3139,2196,5043,1294,5044, # 480 +2080, 462, 586,1042,3279, 853, 256, 988, 185,2382,3457,1698, 434,1084,5045,3458, # 496 + 314,2625,2788,4522,2335,2336, 569,2285, 637,1817,2525, 757,1162,1879,1616,3459, # 512 + 287,1577,2116, 768,4523,1671,2868,3566,2526,1321,3816, 909,2418,5046,4211, 933, # 528 +3817,4212,2053,2361,1222,4524, 765,2419,1322, 786,4525,5047,1920,1462,1677,2909, # 544 +1699,5048,4526,1424,2442,3140,3690,2600,3353,1775,1941,3460,3983,4213, 309,1369, # 560 +1130,2825, 364,2234,1653,1299,3984,3567,3985,3986,2656, 525,1085,3041, 902,2001, # 576 +1475, 964,4527, 421,1845,1415,1057,2286, 940,1364,3141, 376,4528,4529,1381, 7, # 592 +2527, 983,2383, 336,1710,2684,1846, 321,3461, 559,1131,3042,2752,1809,1132,1313, # 608 + 265,1481,1858,5049, 352,1203,2826,3280, 167,1089, 420,2827, 776, 792,1724,3568, # 624 +4214,2443,3281,5050,4215,5051, 446, 229, 333,2753, 901,3818,1200,1557,4530,2657, # 640 +1921, 395,2754,2685,3819,4216,1836, 125, 916,3209,2626,4531,5052,5053,3820,5054, # 656 +5055,5056,4532,3142,3691,1133,2555,1757,3462,1510,2318,1409,3569,5057,2146, 438, # 672 +2601,2910,2384,3354,1068, 958,3043, 461, 311,2869,2686,4217,1916,3210,4218,1979, # 688 + 383, 750,2755,2627,4219, 274, 539, 385,1278,1442,5058,1154,1965, 384, 561, 210, # 704 + 98,1295,2556,3570,5059,1711,2420,1482,3463,3987,2911,1257, 129,5060,3821, 642, # 720 + 523,2789,2790,2658,5061, 141,2235,1333, 68, 176, 441, 876, 907,4220, 603,2602, # 736 + 710, 171,3464, 404, 549, 18,3143,2398,1410,3692,1666,5062,3571,4533,2912,4534, # 752 +5063,2991, 368,5064, 146, 366, 99, 871,3693,1543, 748, 807,1586,1185, 22,2263, # 768 + 379,3822,3211,5065,3212, 505,1942,2628,1992,1382,2319,5066, 380,2362, 218, 702, # 784 +1818,1248,3465,3044,3572,3355,3282,5067,2992,3694, 930,3283,3823,5068, 59,5069, # 800 + 585, 601,4221, 497,3466,1112,1314,4535,1802,5070,1223,1472,2177,5071, 749,1837, # 816 + 690,1900,3824,1773,3988,1476, 429,1043,1791,2236,2117, 917,4222, 447,1086,1629, # 832 +5072, 556,5073,5074,2021,1654, 844,1090, 105, 550, 966,1758,2828,1008,1783, 686, # 848 +1095,5075,2287, 793,1602,5076,3573,2603,4536,4223,2948,2302,4537,3825, 980,2503, # 864 + 544, 353, 527,4538, 908,2687,2913,5077, 381,2629,1943,1348,5078,1341,1252, 560, # 880 +3095,5079,3467,2870,5080,2054, 973, 886,2081, 143,4539,5081,5082, 157,3989, 496, # 896 +4224, 57, 840, 540,2039,4540,4541,3468,2118,1445, 970,2264,1748,1966,2082,4225, # 912 +3144,1234,1776,3284,2829,3695, 773,1206,2130,1066,2040,1326,3990,1738,1725,4226, # 928 + 279,3145, 51,1544,2604, 423,1578,2131,2067, 173,4542,1880,5083,5084,1583, 264, # 944 + 610,3696,4543,2444, 280, 154,5085,5086,5087,1739, 338,1282,3096, 693,2871,1411, # 960 +1074,3826,2445,5088,4544,5089,5090,1240, 952,2399,5091,2914,1538,2688, 685,1483, # 976 +4227,2475,1436, 953,4228,2055,4545, 671,2400, 79,4229,2446,3285, 608, 567,2689, # 992 +3469,4230,4231,1691, 393,1261,1792,2401,5092,4546,5093,5094,5095,5096,1383,1672, # 1008 +3827,3213,1464, 522,1119, 661,1150, 216, 675,4547,3991,1432,3574, 609,4548,2690, # 1024 +2402,5097,5098,5099,4232,3045, 0,5100,2476, 315, 231,2447, 301,3356,4549,2385, # 1040 +5101, 233,4233,3697,1819,4550,4551,5102, 96,1777,1315,2083,5103, 257,5104,1810, # 1056 +3698,2718,1139,1820,4234,2022,1124,2164,2791,1778,2659,5105,3097, 363,1655,3214, # 1072 +5106,2993,5107,5108,5109,3992,1567,3993, 718, 103,3215, 849,1443, 341,3357,2949, # 1088 +1484,5110,1712, 127, 67, 339,4235,2403, 679,1412, 821,5111,5112, 834, 738, 351, # 1104 +2994,2147, 846, 235,1497,1881, 418,1993,3828,2719, 186,1100,2148,2756,3575,1545, # 1120 +1355,2950,2872,1377, 583,3994,4236,2581,2995,5113,1298,3699,1078,2557,3700,2363, # 1136 + 78,3829,3830, 267,1289,2100,2002,1594,4237, 348, 369,1274,2197,2178,1838,4552, # 1152 +1821,2830,3701,2757,2288,2003,4553,2951,2758, 144,3358, 882,4554,3995,2759,3470, # 1168 +4555,2915,5114,4238,1726, 320,5115,3996,3046, 788,2996,5116,2831,1774,1327,2873, # 1184 +3997,2832,5117,1306,4556,2004,1700,3831,3576,2364,2660, 787,2023, 506, 824,3702, # 1200 + 534, 323,4557,1044,3359,2024,1901, 946,3471,5118,1779,1500,1678,5119,1882,4558, # 1216 + 165, 243,4559,3703,2528, 123, 683,4239, 764,4560, 36,3998,1793, 589,2916, 816, # 1232 + 626,1667,3047,2237,1639,1555,1622,3832,3999,5120,4000,2874,1370,1228,1933, 891, # 1248 +2084,2917, 304,4240,5121, 292,2997,2720,3577, 691,2101,4241,1115,4561, 118, 662, # 1264 +5122, 611,1156, 854,2386,1316,2875, 2, 386, 515,2918,5123,5124,3286, 868,2238, # 1280 +1486, 855,2661, 785,2216,3048,5125,1040,3216,3578,5126,3146, 448,5127,1525,5128, # 1296 +2165,4562,5129,3833,5130,4242,2833,3579,3147, 503, 818,4001,3148,1568, 814, 676, # 1312 +1444, 306,1749,5131,3834,1416,1030, 197,1428, 805,2834,1501,4563,5132,5133,5134, # 1328 +1994,5135,4564,5136,5137,2198, 13,2792,3704,2998,3149,1229,1917,5138,3835,2132, # 1344 +5139,4243,4565,2404,3580,5140,2217,1511,1727,1120,5141,5142, 646,3836,2448, 307, # 1360 +5143,5144,1595,3217,5145,5146,5147,3705,1113,1356,4002,1465,2529,2530,5148, 519, # 1376 +5149, 128,2133, 92,2289,1980,5150,4003,1512, 342,3150,2199,5151,2793,2218,1981, # 1392 +3360,4244, 290,1656,1317, 789, 827,2365,5152,3837,4566, 562, 581,4004,5153, 401, # 1408 +4567,2252, 94,4568,5154,1399,2794,5155,1463,2025,4569,3218,1944,5156, 828,1105, # 1424 +4245,1262,1394,5157,4246, 605,4570,5158,1784,2876,5159,2835, 819,2102, 578,2200, # 1440 +2952,5160,1502, 436,3287,4247,3288,2836,4005,2919,3472,3473,5161,2721,2320,5162, # 1456 +5163,2337,2068, 23,4571, 193, 826,3838,2103, 699,1630,4248,3098, 390,1794,1064, # 1472 +3581,5164,1579,3099,3100,1400,5165,4249,1839,1640,2877,5166,4572,4573, 137,4250, # 1488 + 598,3101,1967, 780, 104, 974,2953,5167, 278, 899, 253, 402, 572, 504, 493,1339, # 1504 +5168,4006,1275,4574,2582,2558,5169,3706,3049,3102,2253, 565,1334,2722, 863, 41, # 1520 +5170,5171,4575,5172,1657,2338, 19, 463,2760,4251, 606,5173,2999,3289,1087,2085, # 1536 +1323,2662,3000,5174,1631,1623,1750,4252,2691,5175,2878, 791,2723,2663,2339, 232, # 1552 +2421,5176,3001,1498,5177,2664,2630, 755,1366,3707,3290,3151,2026,1609, 119,1918, # 1568 +3474, 862,1026,4253,5178,4007,3839,4576,4008,4577,2265,1952,2477,5179,1125, 817, # 1584 +4254,4255,4009,1513,1766,2041,1487,4256,3050,3291,2837,3840,3152,5180,5181,1507, # 1600 +5182,2692, 733, 40,1632,1106,2879, 345,4257, 841,2531, 230,4578,3002,1847,3292, # 1616 +3475,5183,1263, 986,3476,5184, 735, 879, 254,1137, 857, 622,1300,1180,1388,1562, # 1632 +4010,4011,2954, 967,2761,2665,1349, 592,2134,1692,3361,3003,1995,4258,1679,4012, # 1648 +1902,2188,5185, 739,3708,2724,1296,1290,5186,4259,2201,2202,1922,1563,2605,2559, # 1664 +1871,2762,3004,5187, 435,5188, 343,1108, 596, 17,1751,4579,2239,3477,3709,5189, # 1680 +4580, 294,3582,2955,1693, 477, 979, 281,2042,3583, 643,2043,3710,2631,2795,2266, # 1696 +1031,2340,2135,2303,3584,4581, 367,1249,2560,5190,3585,5191,4582,1283,3362,2005, # 1712 + 240,1762,3363,4583,4584, 836,1069,3153, 474,5192,2149,2532, 268,3586,5193,3219, # 1728 +1521,1284,5194,1658,1546,4260,5195,3587,3588,5196,4261,3364,2693,1685,4262, 961, # 1744 +1673,2632, 190,2006,2203,3841,4585,4586,5197, 570,2504,3711,1490,5198,4587,2633, # 1760 +3293,1957,4588, 584,1514, 396,1045,1945,5199,4589,1968,2449,5200,5201,4590,4013, # 1776 + 619,5202,3154,3294, 215,2007,2796,2561,3220,4591,3221,4592, 763,4263,3842,4593, # 1792 +5203,5204,1958,1767,2956,3365,3712,1174, 452,1477,4594,3366,3155,5205,2838,1253, # 1808 +2387,2189,1091,2290,4264, 492,5206, 638,1169,1825,2136,1752,4014, 648, 926,1021, # 1824 +1324,4595, 520,4596, 997, 847,1007, 892,4597,3843,2267,1872,3713,2405,1785,4598, # 1840 +1953,2957,3103,3222,1728,4265,2044,3714,4599,2008,1701,3156,1551, 30,2268,4266, # 1856 +5207,2027,4600,3589,5208, 501,5209,4267, 594,3478,2166,1822,3590,3479,3591,3223, # 1872 + 829,2839,4268,5210,1680,3157,1225,4269,5211,3295,4601,4270,3158,2341,5212,4602, # 1888 +4271,5213,4015,4016,5214,1848,2388,2606,3367,5215,4603, 374,4017, 652,4272,4273, # 1904 + 375,1140, 798,5216,5217,5218,2366,4604,2269, 546,1659, 138,3051,2450,4605,5219, # 1920 +2254, 612,1849, 910, 796,3844,1740,1371, 825,3845,3846,5220,2920,2562,5221, 692, # 1936 + 444,3052,2634, 801,4606,4274,5222,1491, 244,1053,3053,4275,4276, 340,5223,4018, # 1952 +1041,3005, 293,1168, 87,1357,5224,1539, 959,5225,2240, 721, 694,4277,3847, 219, # 1968 +1478, 644,1417,3368,2666,1413,1401,1335,1389,4019,5226,5227,3006,2367,3159,1826, # 1984 + 730,1515, 184,2840, 66,4607,5228,1660,2958, 246,3369, 378,1457, 226,3480, 975, # 2000 +4020,2959,1264,3592, 674, 696,5229, 163,5230,1141,2422,2167, 713,3593,3370,4608, # 2016 +4021,5231,5232,1186, 15,5233,1079,1070,5234,1522,3224,3594, 276,1050,2725, 758, # 2032 +1126, 653,2960,3296,5235,2342, 889,3595,4022,3104,3007, 903,1250,4609,4023,3481, # 2048 +3596,1342,1681,1718, 766,3297, 286, 89,2961,3715,5236,1713,5237,2607,3371,3008, # 2064 +5238,2962,2219,3225,2880,5239,4610,2505,2533, 181, 387,1075,4024, 731,2190,3372, # 2080 +5240,3298, 310, 313,3482,2304, 770,4278, 54,3054, 189,4611,3105,3848,4025,5241, # 2096 +1230,1617,1850, 355,3597,4279,4612,3373, 111,4280,3716,1350,3160,3483,3055,4281, # 2112 +2150,3299,3598,5242,2797,4026,4027,3009, 722,2009,5243,1071, 247,1207,2343,2478, # 2128 +1378,4613,2010, 864,1437,1214,4614, 373,3849,1142,2220, 667,4615, 442,2763,2563, # 2144 +3850,4028,1969,4282,3300,1840, 837, 170,1107, 934,1336,1883,5244,5245,2119,4283, # 2160 +2841, 743,1569,5246,4616,4284, 582,2389,1418,3484,5247,1803,5248, 357,1395,1729, # 2176 +3717,3301,2423,1564,2241,5249,3106,3851,1633,4617,1114,2086,4285,1532,5250, 482, # 2192 +2451,4618,5251,5252,1492, 833,1466,5253,2726,3599,1641,2842,5254,1526,1272,3718, # 2208 +4286,1686,1795, 416,2564,1903,1954,1804,5255,3852,2798,3853,1159,2321,5256,2881, # 2224 +4619,1610,1584,3056,2424,2764, 443,3302,1163,3161,5257,5258,4029,5259,4287,2506, # 2240 +3057,4620,4030,3162,2104,1647,3600,2011,1873,4288,5260,4289, 431,3485,5261, 250, # 2256 + 97, 81,4290,5262,1648,1851,1558, 160, 848,5263, 866, 740,1694,5264,2204,2843, # 2272 +3226,4291,4621,3719,1687, 950,2479, 426, 469,3227,3720,3721,4031,5265,5266,1188, # 2288 + 424,1996, 861,3601,4292,3854,2205,2694, 168,1235,3602,4293,5267,2087,1674,4622, # 2304 +3374,3303, 220,2565,1009,5268,3855, 670,3010, 332,1208, 717,5269,5270,3603,2452, # 2320 +4032,3375,5271, 513,5272,1209,2882,3376,3163,4623,1080,5273,5274,5275,5276,2534, # 2336 +3722,3604, 815,1587,4033,4034,5277,3605,3486,3856,1254,4624,1328,3058,1390,4035, # 2352 +1741,4036,3857,4037,5278, 236,3858,2453,3304,5279,5280,3723,3859,1273,3860,4625, # 2368 +5281, 308,5282,4626, 245,4627,1852,2480,1307,2583, 430, 715,2137,2454,5283, 270, # 2384 + 199,2883,4038,5284,3606,2727,1753, 761,1754, 725,1661,1841,4628,3487,3724,5285, # 2400 +5286, 587, 14,3305, 227,2608, 326, 480,2270, 943,2765,3607, 291, 650,1884,5287, # 2416 +1702,1226, 102,1547, 62,3488, 904,4629,3489,1164,4294,5288,5289,1224,1548,2766, # 2432 + 391, 498,1493,5290,1386,1419,5291,2056,1177,4630, 813, 880,1081,2368, 566,1145, # 2448 +4631,2291,1001,1035,2566,2609,2242, 394,1286,5292,5293,2069,5294, 86,1494,1730, # 2464 +4039, 491,1588, 745, 897,2963, 843,3377,4040,2767,2884,3306,1768, 998,2221,2070, # 2480 + 397,1827,1195,1970,3725,3011,3378, 284,5295,3861,2507,2138,2120,1904,5296,4041, # 2496 +2151,4042,4295,1036,3490,1905, 114,2567,4296, 209,1527,5297,5298,2964,2844,2635, # 2512 +2390,2728,3164, 812,2568,5299,3307,5300,1559, 737,1885,3726,1210, 885, 28,2695, # 2528 +3608,3862,5301,4297,1004,1780,4632,5302, 346,1982,2222,2696,4633,3863,1742, 797, # 2544 +1642,4043,1934,1072,1384,2152, 896,4044,3308,3727,3228,2885,3609,5303,2569,1959, # 2560 +4634,2455,1786,5304,5305,5306,4045,4298,1005,1308,3728,4299,2729,4635,4636,1528, # 2576 +2610, 161,1178,4300,1983, 987,4637,1101,4301, 631,4046,1157,3229,2425,1343,1241, # 2592 +1016,2243,2570, 372, 877,2344,2508,1160, 555,1935, 911,4047,5307, 466,1170, 169, # 2608 +1051,2921,2697,3729,2481,3012,1182,2012,2571,1251,2636,5308, 992,2345,3491,1540, # 2624 +2730,1201,2071,2406,1997,2482,5309,4638, 528,1923,2191,1503,1874,1570,2369,3379, # 2640 +3309,5310, 557,1073,5311,1828,3492,2088,2271,3165,3059,3107, 767,3108,2799,4639, # 2656 +1006,4302,4640,2346,1267,2179,3730,3230, 778,4048,3231,2731,1597,2667,5312,4641, # 2672 +5313,3493,5314,5315,5316,3310,2698,1433,3311, 131, 95,1504,4049, 723,4303,3166, # 2688 +1842,3610,2768,2192,4050,2028,2105,3731,5317,3013,4051,1218,5318,3380,3232,4052, # 2704 +4304,2584, 248,1634,3864, 912,5319,2845,3732,3060,3865, 654, 53,5320,3014,5321, # 2720 +1688,4642, 777,3494,1032,4053,1425,5322, 191, 820,2121,2846, 971,4643, 931,3233, # 2736 + 135, 664, 783,3866,1998, 772,2922,1936,4054,3867,4644,2923,3234, 282,2732, 640, # 2752 +1372,3495,1127, 922, 325,3381,5323,5324, 711,2045,5325,5326,4055,2223,2800,1937, # 2768 +4056,3382,2224,2255,3868,2305,5327,4645,3869,1258,3312,4057,3235,2139,2965,4058, # 2784 +4059,5328,2225, 258,3236,4646, 101,1227,5329,3313,1755,5330,1391,3314,5331,2924, # 2800 +2057, 893,5332,5333,5334,1402,4305,2347,5335,5336,3237,3611,5337,5338, 878,1325, # 2816 +1781,2801,4647, 259,1385,2585, 744,1183,2272,4648,5339,4060,2509,5340, 684,1024, # 2832 +4306,5341, 472,3612,3496,1165,3315,4061,4062, 322,2153, 881, 455,1695,1152,1340, # 2848 + 660, 554,2154,4649,1058,4650,4307, 830,1065,3383,4063,4651,1924,5342,1703,1919, # 2864 +5343, 932,2273, 122,5344,4652, 947, 677,5345,3870,2637, 297,1906,1925,2274,4653, # 2880 +2322,3316,5346,5347,4308,5348,4309, 84,4310, 112, 989,5349, 547,1059,4064, 701, # 2896 +3613,1019,5350,4311,5351,3497, 942, 639, 457,2306,2456, 993,2966, 407, 851, 494, # 2912 +4654,3384, 927,5352,1237,5353,2426,3385, 573,4312, 680, 921,2925,1279,1875, 285, # 2928 + 790,1448,1984, 719,2168,5354,5355,4655,4065,4066,1649,5356,1541, 563,5357,1077, # 2944 +5358,3386,3061,3498, 511,3015,4067,4068,3733,4069,1268,2572,3387,3238,4656,4657, # 2960 +5359, 535,1048,1276,1189,2926,2029,3167,1438,1373,2847,2967,1134,2013,5360,4313, # 2976 +1238,2586,3109,1259,5361, 700,5362,2968,3168,3734,4314,5363,4315,1146,1876,1907, # 2992 +4658,2611,4070, 781,2427, 132,1589, 203, 147, 273,2802,2407, 898,1787,2155,4071, # 3008 +4072,5364,3871,2803,5365,5366,4659,4660,5367,3239,5368,1635,3872, 965,5369,1805, # 3024 +2699,1516,3614,1121,1082,1329,3317,4073,1449,3873, 65,1128,2848,2927,2769,1590, # 3040 +3874,5370,5371, 12,2668, 45, 976,2587,3169,4661, 517,2535,1013,1037,3240,5372, # 3056 +3875,2849,5373,3876,5374,3499,5375,2612, 614,1999,2323,3877,3110,2733,2638,5376, # 3072 +2588,4316, 599,1269,5377,1811,3735,5378,2700,3111, 759,1060, 489,1806,3388,3318, # 3088 +1358,5379,5380,2391,1387,1215,2639,2256, 490,5381,5382,4317,1759,2392,2348,5383, # 3104 +4662,3878,1908,4074,2640,1807,3241,4663,3500,3319,2770,2349, 874,5384,5385,3501, # 3120 +3736,1859, 91,2928,3737,3062,3879,4664,5386,3170,4075,2669,5387,3502,1202,1403, # 3136 +3880,2969,2536,1517,2510,4665,3503,2511,5388,4666,5389,2701,1886,1495,1731,4076, # 3152 +2370,4667,5390,2030,5391,5392,4077,2702,1216, 237,2589,4318,2324,4078,3881,4668, # 3168 +4669,2703,3615,3504, 445,4670,5393,5394,5395,5396,2771, 61,4079,3738,1823,4080, # 3184 +5397, 687,2046, 935, 925, 405,2670, 703,1096,1860,2734,4671,4081,1877,1367,2704, # 3200 +3389, 918,2106,1782,2483, 334,3320,1611,1093,4672, 564,3171,3505,3739,3390, 945, # 3216 +2641,2058,4673,5398,1926, 872,4319,5399,3506,2705,3112, 349,4320,3740,4082,4674, # 3232 +3882,4321,3741,2156,4083,4675,4676,4322,4677,2408,2047, 782,4084, 400, 251,4323, # 3248 +1624,5400,5401, 277,3742, 299,1265, 476,1191,3883,2122,4324,4325,1109, 205,5402, # 3264 +2590,1000,2157,3616,1861,5403,5404,5405,4678,5406,4679,2573, 107,2484,2158,4085, # 3280 +3507,3172,5407,1533, 541,1301, 158, 753,4326,2886,3617,5408,1696, 370,1088,4327, # 3296 +4680,3618, 579, 327, 440, 162,2244, 269,1938,1374,3508, 968,3063, 56,1396,3113, # 3312 +2107,3321,3391,5409,1927,2159,4681,3016,5410,3619,5411,5412,3743,4682,2485,5413, # 3328 +2804,5414,1650,4683,5415,2613,5416,5417,4086,2671,3392,1149,3393,4087,3884,4088, # 3344 +5418,1076, 49,5419, 951,3242,3322,3323, 450,2850, 920,5420,1812,2805,2371,4328, # 3360 +1909,1138,2372,3885,3509,5421,3243,4684,1910,1147,1518,2428,4685,3886,5422,4686, # 3376 +2393,2614, 260,1796,3244,5423,5424,3887,3324, 708,5425,3620,1704,5426,3621,1351, # 3392 +1618,3394,3017,1887, 944,4329,3395,4330,3064,3396,4331,5427,3744, 422, 413,1714, # 3408 +3325, 500,2059,2350,4332,2486,5428,1344,1911, 954,5429,1668,5430,5431,4089,2409, # 3424 +4333,3622,3888,4334,5432,2307,1318,2512,3114, 133,3115,2887,4687, 629, 31,2851, # 3440 +2706,3889,4688, 850, 949,4689,4090,2970,1732,2089,4335,1496,1853,5433,4091, 620, # 3456 +3245, 981,1242,3745,3397,1619,3746,1643,3326,2140,2457,1971,1719,3510,2169,5434, # 3472 +3246,5435,5436,3398,1829,5437,1277,4690,1565,2048,5438,1636,3623,3116,5439, 869, # 3488 +2852, 655,3890,3891,3117,4092,3018,3892,1310,3624,4691,5440,5441,5442,1733, 558, # 3504 +4692,3747, 335,1549,3065,1756,4336,3748,1946,3511,1830,1291,1192, 470,2735,2108, # 3520 +2806, 913,1054,4093,5443,1027,5444,3066,4094,4693, 982,2672,3399,3173,3512,3247, # 3536 +3248,1947,2807,5445, 571,4694,5446,1831,5447,3625,2591,1523,2429,5448,2090, 984, # 3552 +4695,3749,1960,5449,3750, 852, 923,2808,3513,3751, 969,1519, 999,2049,2325,1705, # 3568 +5450,3118, 615,1662, 151, 597,4095,2410,2326,1049, 275,4696,3752,4337, 568,3753, # 3584 +3626,2487,4338,3754,5451,2430,2275, 409,3249,5452,1566,2888,3514,1002, 769,2853, # 3600 + 194,2091,3174,3755,2226,3327,4339, 628,1505,5453,5454,1763,2180,3019,4096, 521, # 3616 +1161,2592,1788,2206,2411,4697,4097,1625,4340,4341, 412, 42,3119, 464,5455,2642, # 3632 +4698,3400,1760,1571,2889,3515,2537,1219,2207,3893,2643,2141,2373,4699,4700,3328, # 3648 +1651,3401,3627,5456,5457,3628,2488,3516,5458,3756,5459,5460,2276,2092, 460,5461, # 3664 +4701,5462,3020, 962, 588,3629, 289,3250,2644,1116, 52,5463,3067,1797,5464,5465, # 3680 +5466,1467,5467,1598,1143,3757,4342,1985,1734,1067,4702,1280,3402, 465,4703,1572, # 3696 + 510,5468,1928,2245,1813,1644,3630,5469,4704,3758,5470,5471,2673,1573,1534,5472, # 3712 +5473, 536,1808,1761,3517,3894,3175,2645,5474,5475,5476,4705,3518,2929,1912,2809, # 3728 +5477,3329,1122, 377,3251,5478, 360,5479,5480,4343,1529, 551,5481,2060,3759,1769, # 3744 +2431,5482,2930,4344,3330,3120,2327,2109,2031,4706,1404, 136,1468,1479, 672,1171, # 3760 +3252,2308, 271,3176,5483,2772,5484,2050, 678,2736, 865,1948,4707,5485,2014,4098, # 3776 +2971,5486,2737,2227,1397,3068,3760,4708,4709,1735,2931,3403,3631,5487,3895, 509, # 3792 +2854,2458,2890,3896,5488,5489,3177,3178,4710,4345,2538,4711,2309,1166,1010, 552, # 3808 + 681,1888,5490,5491,2972,2973,4099,1287,1596,1862,3179, 358, 453, 736, 175, 478, # 3824 +1117, 905,1167,1097,5492,1854,1530,5493,1706,5494,2181,3519,2292,3761,3520,3632, # 3840 +4346,2093,4347,5495,3404,1193,2489,4348,1458,2193,2208,1863,1889,1421,3331,2932, # 3856 +3069,2182,3521, 595,2123,5496,4100,5497,5498,4349,1707,2646, 223,3762,1359, 751, # 3872 +3121, 183,3522,5499,2810,3021, 419,2374, 633, 704,3897,2394, 241,5500,5501,5502, # 3888 + 838,3022,3763,2277,2773,2459,3898,1939,2051,4101,1309,3122,2246,1181,5503,1136, # 3904 +2209,3899,2375,1446,4350,2310,4712,5504,5505,4351,1055,2615, 484,3764,5506,4102, # 3920 + 625,4352,2278,3405,1499,4353,4103,5507,4104,4354,3253,2279,2280,3523,5508,5509, # 3936 +2774, 808,2616,3765,3406,4105,4355,3123,2539, 526,3407,3900,4356, 955,5510,1620, # 3952 +4357,2647,2432,5511,1429,3766,1669,1832, 994, 928,5512,3633,1260,5513,5514,5515, # 3968 +1949,2293, 741,2933,1626,4358,2738,2460, 867,1184, 362,3408,1392,5516,5517,4106, # 3984 +4359,1770,1736,3254,2934,4713,4714,1929,2707,1459,1158,5518,3070,3409,2891,1292, # 4000 +1930,2513,2855,3767,1986,1187,2072,2015,2617,4360,5519,2574,2514,2170,3768,2490, # 4016 +3332,5520,3769,4715,5521,5522, 666,1003,3023,1022,3634,4361,5523,4716,1814,2257, # 4032 + 574,3901,1603, 295,1535, 705,3902,4362, 283, 858, 417,5524,5525,3255,4717,4718, # 4048 +3071,1220,1890,1046,2281,2461,4107,1393,1599, 689,2575, 388,4363,5526,2491, 802, # 4064 +5527,2811,3903,2061,1405,2258,5528,4719,3904,2110,1052,1345,3256,1585,5529, 809, # 4080 +5530,5531,5532, 575,2739,3524, 956,1552,1469,1144,2328,5533,2329,1560,2462,3635, # 4096 +3257,4108, 616,2210,4364,3180,2183,2294,5534,1833,5535,3525,4720,5536,1319,3770, # 4112 +3771,1211,3636,1023,3258,1293,2812,5537,5538,5539,3905, 607,2311,3906, 762,2892, # 4128 +1439,4365,1360,4721,1485,3072,5540,4722,1038,4366,1450,2062,2648,4367,1379,4723, # 4144 +2593,5541,5542,4368,1352,1414,2330,2935,1172,5543,5544,3907,3908,4724,1798,1451, # 4160 +5545,5546,5547,5548,2936,4109,4110,2492,2351, 411,4111,4112,3637,3333,3124,4725, # 4176 +1561,2674,1452,4113,1375,5549,5550, 47,2974, 316,5551,1406,1591,2937,3181,5552, # 4192 +1025,2142,3125,3182, 354,2740, 884,2228,4369,2412, 508,3772, 726,3638, 996,2433, # 4208 +3639, 729,5553, 392,2194,1453,4114,4726,3773,5554,5555,2463,3640,2618,1675,2813, # 4224 + 919,2352,2975,2353,1270,4727,4115, 73,5556,5557, 647,5558,3259,2856,2259,1550, # 4240 +1346,3024,5559,1332, 883,3526,5560,5561,5562,5563,3334,2775,5564,1212, 831,1347, # 4256 +4370,4728,2331,3909,1864,3073, 720,3910,4729,4730,3911,5565,4371,5566,5567,4731, # 4272 +5568,5569,1799,4732,3774,2619,4733,3641,1645,2376,4734,5570,2938, 669,2211,2675, # 4288 +2434,5571,2893,5572,5573,1028,3260,5574,4372,2413,5575,2260,1353,5576,5577,4735, # 4304 +3183, 518,5578,4116,5579,4373,1961,5580,2143,4374,5581,5582,3025,2354,2355,3912, # 4320 + 516,1834,1454,4117,2708,4375,4736,2229,2620,1972,1129,3642,5583,2776,5584,2976, # 4336 +1422, 577,1470,3026,1524,3410,5585,5586, 432,4376,3074,3527,5587,2594,1455,2515, # 4352 +2230,1973,1175,5588,1020,2741,4118,3528,4737,5589,2742,5590,1743,1361,3075,3529, # 4368 +2649,4119,4377,4738,2295, 895, 924,4378,2171, 331,2247,3076, 166,1627,3077,1098, # 4384 +5591,1232,2894,2231,3411,4739, 657, 403,1196,2377, 542,3775,3412,1600,4379,3530, # 4400 +5592,4740,2777,3261, 576, 530,1362,4741,4742,2540,2676,3776,4120,5593, 842,3913, # 4416 +5594,2814,2032,1014,4121, 213,2709,3413, 665, 621,4380,5595,3777,2939,2435,5596, # 4432 +2436,3335,3643,3414,4743,4381,2541,4382,4744,3644,1682,4383,3531,1380,5597, 724, # 4448 +2282, 600,1670,5598,1337,1233,4745,3126,2248,5599,1621,4746,5600, 651,4384,5601, # 4464 +1612,4385,2621,5602,2857,5603,2743,2312,3078,5604, 716,2464,3079, 174,1255,2710, # 4480 +4122,3645, 548,1320,1398, 728,4123,1574,5605,1891,1197,3080,4124,5606,3081,3082, # 4496 +3778,3646,3779, 747,5607, 635,4386,4747,5608,5609,5610,4387,5611,5612,4748,5613, # 4512 +3415,4749,2437, 451,5614,3780,2542,2073,4388,2744,4389,4125,5615,1764,4750,5616, # 4528 +4390, 350,4751,2283,2395,2493,5617,4391,4126,2249,1434,4127, 488,4752, 458,4392, # 4544 +4128,3781, 771,1330,2396,3914,2576,3184,2160,2414,1553,2677,3185,4393,5618,2494, # 4560 +2895,2622,1720,2711,4394,3416,4753,5619,2543,4395,5620,3262,4396,2778,5621,2016, # 4576 +2745,5622,1155,1017,3782,3915,5623,3336,2313, 201,1865,4397,1430,5624,4129,5625, # 4592 +5626,5627,5628,5629,4398,1604,5630, 414,1866, 371,2595,4754,4755,3532,2017,3127, # 4608 +4756,1708, 960,4399, 887, 389,2172,1536,1663,1721,5631,2232,4130,2356,2940,1580, # 4624 +5632,5633,1744,4757,2544,4758,4759,5634,4760,5635,2074,5636,4761,3647,3417,2896, # 4640 +4400,5637,4401,2650,3418,2815, 673,2712,2465, 709,3533,4131,3648,4402,5638,1148, # 4656 + 502, 634,5639,5640,1204,4762,3649,1575,4763,2623,3783,5641,3784,3128, 948,3263, # 4672 + 121,1745,3916,1110,5642,4403,3083,2516,3027,4132,3785,1151,1771,3917,1488,4133, # 4688 +1987,5643,2438,3534,5644,5645,2094,5646,4404,3918,1213,1407,2816, 531,2746,2545, # 4704 +3264,1011,1537,4764,2779,4405,3129,1061,5647,3786,3787,1867,2897,5648,2018, 120, # 4720 +4406,4407,2063,3650,3265,2314,3919,2678,3419,1955,4765,4134,5649,3535,1047,2713, # 4736 +1266,5650,1368,4766,2858, 649,3420,3920,2546,2747,1102,2859,2679,5651,5652,2000, # 4752 +5653,1111,3651,2977,5654,2495,3921,3652,2817,1855,3421,3788,5655,5656,3422,2415, # 4768 +2898,3337,3266,3653,5657,2577,5658,3654,2818,4135,1460, 856,5659,3655,5660,2899, # 4784 +2978,5661,2900,3922,5662,4408, 632,2517, 875,3923,1697,3924,2296,5663,5664,4767, # 4800 +3028,1239, 580,4768,4409,5665, 914, 936,2075,1190,4136,1039,2124,5666,5667,5668, # 4816 +5669,3423,1473,5670,1354,4410,3925,4769,2173,3084,4137, 915,3338,4411,4412,3339, # 4832 +1605,1835,5671,2748, 398,3656,4413,3926,4138, 328,1913,2860,4139,3927,1331,4414, # 4848 +3029, 937,4415,5672,3657,4140,4141,3424,2161,4770,3425, 524, 742, 538,3085,1012, # 4864 +5673,5674,3928,2466,5675, 658,1103, 225,3929,5676,5677,4771,5678,4772,5679,3267, # 4880 +1243,5680,4142, 963,2250,4773,5681,2714,3658,3186,5682,5683,2596,2332,5684,4774, # 4896 +5685,5686,5687,3536, 957,3426,2547,2033,1931,2941,2467, 870,2019,3659,1746,2780, # 4912 +2781,2439,2468,5688,3930,5689,3789,3130,3790,3537,3427,3791,5690,1179,3086,5691, # 4928 +3187,2378,4416,3792,2548,3188,3131,2749,4143,5692,3428,1556,2549,2297, 977,2901, # 4944 +2034,4144,1205,3429,5693,1765,3430,3189,2125,1271, 714,1689,4775,3538,5694,2333, # 4960 +3931, 533,4417,3660,2184, 617,5695,2469,3340,3539,2315,5696,5697,3190,5698,5699, # 4976 +3932,1988, 618, 427,2651,3540,3431,5700,5701,1244,1690,5702,2819,4418,4776,5703, # 4992 +3541,4777,5704,2284,1576, 473,3661,4419,3432, 972,5705,3662,5706,3087,5707,5708, # 5008 +4778,4779,5709,3793,4145,4146,5710, 153,4780, 356,5711,1892,2902,4420,2144, 408, # 5024 + 803,2357,5712,3933,5713,4421,1646,2578,2518,4781,4782,3934,5714,3935,4422,5715, # 5040 +2416,3433, 752,5716,5717,1962,3341,2979,5718, 746,3030,2470,4783,4423,3794, 698, # 5056 +4784,1893,4424,3663,2550,4785,3664,3936,5719,3191,3434,5720,1824,1302,4147,2715, # 5072 +3937,1974,4425,5721,4426,3192, 823,1303,1288,1236,2861,3542,4148,3435, 774,3938, # 5088 +5722,1581,4786,1304,2862,3939,4787,5723,2440,2162,1083,3268,4427,4149,4428, 344, # 5104 +1173, 288,2316, 454,1683,5724,5725,1461,4788,4150,2597,5726,5727,4789, 985, 894, # 5120 +5728,3436,3193,5729,1914,2942,3795,1989,5730,2111,1975,5731,4151,5732,2579,1194, # 5136 + 425,5733,4790,3194,1245,3796,4429,5734,5735,2863,5736, 636,4791,1856,3940, 760, # 5152 +1800,5737,4430,2212,1508,4792,4152,1894,1684,2298,5738,5739,4793,4431,4432,2213, # 5168 + 479,5740,5741, 832,5742,4153,2496,5743,2980,2497,3797, 990,3132, 627,1815,2652, # 5184 +4433,1582,4434,2126,2112,3543,4794,5744, 799,4435,3195,5745,4795,2113,1737,3031, # 5200 +1018, 543, 754,4436,3342,1676,4796,4797,4154,4798,1489,5746,3544,5747,2624,2903, # 5216 +4155,5748,5749,2981,5750,5751,5752,5753,3196,4799,4800,2185,1722,5754,3269,3270, # 5232 +1843,3665,1715, 481, 365,1976,1857,5755,5756,1963,2498,4801,5757,2127,3666,3271, # 5248 + 433,1895,2064,2076,5758, 602,2750,5759,5760,5761,5762,5763,3032,1628,3437,5764, # 5264 +3197,4802,4156,2904,4803,2519,5765,2551,2782,5766,5767,5768,3343,4804,2905,5769, # 5280 +4805,5770,2864,4806,4807,1221,2982,4157,2520,5771,5772,5773,1868,1990,5774,5775, # 5296 +5776,1896,5777,5778,4808,1897,4158, 318,5779,2095,4159,4437,5780,5781, 485,5782, # 5312 + 938,3941, 553,2680, 116,5783,3942,3667,5784,3545,2681,2783,3438,3344,2820,5785, # 5328 +3668,2943,4160,1747,2944,2983,5786,5787, 207,5788,4809,5789,4810,2521,5790,3033, # 5344 + 890,3669,3943,5791,1878,3798,3439,5792,2186,2358,3440,1652,5793,5794,5795, 941, # 5360 +2299, 208,3546,4161,2020, 330,4438,3944,2906,2499,3799,4439,4811,5796,5797,5798, # 5376 +) + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/big5prober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/big5prober.py new file mode 100644 index 0000000..98f9970 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/big5prober.py @@ -0,0 +1,47 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Communicator client code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .mbcharsetprober import MultiByteCharSetProber +from .codingstatemachine import CodingStateMachine +from .chardistribution import Big5DistributionAnalysis +from .mbcssm import BIG5_SM_MODEL + + +class Big5Prober(MultiByteCharSetProber): + def __init__(self): + super(Big5Prober, self).__init__() + self.coding_sm = CodingStateMachine(BIG5_SM_MODEL) + self.distribution_analyzer = Big5DistributionAnalysis() + self.reset() + + @property + def charset_name(self): + return "Big5" + + @property + def language(self): + return "Chinese" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/chardistribution.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/chardistribution.py new file mode 100644 index 0000000..c0395f4 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/chardistribution.py @@ -0,0 +1,233 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Communicator client code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .euctwfreq import (EUCTW_CHAR_TO_FREQ_ORDER, EUCTW_TABLE_SIZE, + EUCTW_TYPICAL_DISTRIBUTION_RATIO) +from .euckrfreq import (EUCKR_CHAR_TO_FREQ_ORDER, EUCKR_TABLE_SIZE, + EUCKR_TYPICAL_DISTRIBUTION_RATIO) +from .gb2312freq import (GB2312_CHAR_TO_FREQ_ORDER, GB2312_TABLE_SIZE, + GB2312_TYPICAL_DISTRIBUTION_RATIO) +from .big5freq import (BIG5_CHAR_TO_FREQ_ORDER, BIG5_TABLE_SIZE, + BIG5_TYPICAL_DISTRIBUTION_RATIO) +from .jisfreq import (JIS_CHAR_TO_FREQ_ORDER, JIS_TABLE_SIZE, + JIS_TYPICAL_DISTRIBUTION_RATIO) + + +class CharDistributionAnalysis(object): + ENOUGH_DATA_THRESHOLD = 1024 + SURE_YES = 0.99 + SURE_NO = 0.01 + MINIMUM_DATA_THRESHOLD = 3 + + def __init__(self): + # Mapping table to get frequency order from char order (get from + # GetOrder()) + self._char_to_freq_order = None + self._table_size = None # Size of above table + # This is a constant value which varies from language to language, + # used in calculating confidence. See + # http://www.mozilla.org/projects/intl/UniversalCharsetDetection.html + # for further detail. + self.typical_distribution_ratio = None + self._done = None + self._total_chars = None + self._freq_chars = None + self.reset() + + def reset(self): + """reset analyser, clear any state""" + # If this flag is set to True, detection is done and conclusion has + # been made + self._done = False + self._total_chars = 0 # Total characters encountered + # The number of characters whose frequency order is less than 512 + self._freq_chars = 0 + + def feed(self, char, char_len): + """feed a character with known length""" + if char_len == 2: + # we only care about 2-bytes character in our distribution analysis + order = self.get_order(char) + else: + order = -1 + if order >= 0: + self._total_chars += 1 + # order is valid + if order < self._table_size: + if 512 > self._char_to_freq_order[order]: + self._freq_chars += 1 + + def get_confidence(self): + """return confidence based on existing data""" + # if we didn't receive any character in our consideration range, + # return negative answer + if self._total_chars <= 0 or self._freq_chars <= self.MINIMUM_DATA_THRESHOLD: + return self.SURE_NO + + if self._total_chars != self._freq_chars: + r = (self._freq_chars / ((self._total_chars - self._freq_chars) + * self.typical_distribution_ratio)) + if r < self.SURE_YES: + return r + + # normalize confidence (we don't want to be 100% sure) + return self.SURE_YES + + def got_enough_data(self): + # It is not necessary to receive all data to draw conclusion. + # For charset detection, certain amount of data is enough + return self._total_chars > self.ENOUGH_DATA_THRESHOLD + + def get_order(self, byte_str): + # We do not handle characters based on the original encoding string, + # but convert this encoding string to a number, here called order. + # This allows multiple encodings of a language to share one frequency + # table. + return -1 + + +class EUCTWDistributionAnalysis(CharDistributionAnalysis): + def __init__(self): + super(EUCTWDistributionAnalysis, self).__init__() + self._char_to_freq_order = EUCTW_CHAR_TO_FREQ_ORDER + self._table_size = EUCTW_TABLE_SIZE + self.typical_distribution_ratio = EUCTW_TYPICAL_DISTRIBUTION_RATIO + + def get_order(self, byte_str): + # for euc-TW encoding, we are interested + # first byte range: 0xc4 -- 0xfe + # second byte range: 0xa1 -- 0xfe + # no validation needed here. State machine has done that + first_char = byte_str[0] + if first_char >= 0xC4: + return 94 * (first_char - 0xC4) + byte_str[1] - 0xA1 + else: + return -1 + + +class EUCKRDistributionAnalysis(CharDistributionAnalysis): + def __init__(self): + super(EUCKRDistributionAnalysis, self).__init__() + self._char_to_freq_order = EUCKR_CHAR_TO_FREQ_ORDER + self._table_size = EUCKR_TABLE_SIZE + self.typical_distribution_ratio = EUCKR_TYPICAL_DISTRIBUTION_RATIO + + def get_order(self, byte_str): + # for euc-KR encoding, we are interested + # first byte range: 0xb0 -- 0xfe + # second byte range: 0xa1 -- 0xfe + # no validation needed here. State machine has done that + first_char = byte_str[0] + if first_char >= 0xB0: + return 94 * (first_char - 0xB0) + byte_str[1] - 0xA1 + else: + return -1 + + +class GB2312DistributionAnalysis(CharDistributionAnalysis): + def __init__(self): + super(GB2312DistributionAnalysis, self).__init__() + self._char_to_freq_order = GB2312_CHAR_TO_FREQ_ORDER + self._table_size = GB2312_TABLE_SIZE + self.typical_distribution_ratio = GB2312_TYPICAL_DISTRIBUTION_RATIO + + def get_order(self, byte_str): + # for GB2312 encoding, we are interested + # first byte range: 0xb0 -- 0xfe + # second byte range: 0xa1 -- 0xfe + # no validation needed here. State machine has done that + first_char, second_char = byte_str[0], byte_str[1] + if (first_char >= 0xB0) and (second_char >= 0xA1): + return 94 * (first_char - 0xB0) + second_char - 0xA1 + else: + return -1 + + +class Big5DistributionAnalysis(CharDistributionAnalysis): + def __init__(self): + super(Big5DistributionAnalysis, self).__init__() + self._char_to_freq_order = BIG5_CHAR_TO_FREQ_ORDER + self._table_size = BIG5_TABLE_SIZE + self.typical_distribution_ratio = BIG5_TYPICAL_DISTRIBUTION_RATIO + + def get_order(self, byte_str): + # for big5 encoding, we are interested + # first byte range: 0xa4 -- 0xfe + # second byte range: 0x40 -- 0x7e , 0xa1 -- 0xfe + # no validation needed here. State machine has done that + first_char, second_char = byte_str[0], byte_str[1] + if first_char >= 0xA4: + if second_char >= 0xA1: + return 157 * (first_char - 0xA4) + second_char - 0xA1 + 63 + else: + return 157 * (first_char - 0xA4) + second_char - 0x40 + else: + return -1 + + +class SJISDistributionAnalysis(CharDistributionAnalysis): + def __init__(self): + super(SJISDistributionAnalysis, self).__init__() + self._char_to_freq_order = JIS_CHAR_TO_FREQ_ORDER + self._table_size = JIS_TABLE_SIZE + self.typical_distribution_ratio = JIS_TYPICAL_DISTRIBUTION_RATIO + + def get_order(self, byte_str): + # for sjis encoding, we are interested + # first byte range: 0x81 -- 0x9f , 0xe0 -- 0xfe + # second byte range: 0x40 -- 0x7e, 0x81 -- oxfe + # no validation needed here. State machine has done that + first_char, second_char = byte_str[0], byte_str[1] + if (first_char >= 0x81) and (first_char <= 0x9F): + order = 188 * (first_char - 0x81) + elif (first_char >= 0xE0) and (first_char <= 0xEF): + order = 188 * (first_char - 0xE0 + 31) + else: + return -1 + order = order + second_char - 0x40 + if second_char > 0x7F: + order = -1 + return order + + +class EUCJPDistributionAnalysis(CharDistributionAnalysis): + def __init__(self): + super(EUCJPDistributionAnalysis, self).__init__() + self._char_to_freq_order = JIS_CHAR_TO_FREQ_ORDER + self._table_size = JIS_TABLE_SIZE + self.typical_distribution_ratio = JIS_TYPICAL_DISTRIBUTION_RATIO + + def get_order(self, byte_str): + # for euc-JP encoding, we are interested + # first byte range: 0xa0 -- 0xfe + # second byte range: 0xa1 -- 0xfe + # no validation needed here. State machine has done that + char = byte_str[0] + if char >= 0xA0: + return 94 * (char - 0xA1) + byte_str[1] - 0xa1 + else: + return -1 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/charsetgroupprober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/charsetgroupprober.py new file mode 100644 index 0000000..8b3738e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/charsetgroupprober.py @@ -0,0 +1,106 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Communicator client code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .enums import ProbingState +from .charsetprober import CharSetProber + + +class CharSetGroupProber(CharSetProber): + def __init__(self, lang_filter=None): + super(CharSetGroupProber, self).__init__(lang_filter=lang_filter) + self._active_num = 0 + self.probers = [] + self._best_guess_prober = None + + def reset(self): + super(CharSetGroupProber, self).reset() + self._active_num = 0 + for prober in self.probers: + if prober: + prober.reset() + prober.active = True + self._active_num += 1 + self._best_guess_prober = None + + @property + def charset_name(self): + if not self._best_guess_prober: + self.get_confidence() + if not self._best_guess_prober: + return None + return self._best_guess_prober.charset_name + + @property + def language(self): + if not self._best_guess_prober: + self.get_confidence() + if not self._best_guess_prober: + return None + return self._best_guess_prober.language + + def feed(self, byte_str): + for prober in self.probers: + if not prober: + continue + if not prober.active: + continue + state = prober.feed(byte_str) + if not state: + continue + if state == ProbingState.FOUND_IT: + self._best_guess_prober = prober + return self.state + elif state == ProbingState.NOT_ME: + prober.active = False + self._active_num -= 1 + if self._active_num <= 0: + self._state = ProbingState.NOT_ME + return self.state + return self.state + + def get_confidence(self): + state = self.state + if state == ProbingState.FOUND_IT: + return 0.99 + elif state == ProbingState.NOT_ME: + return 0.01 + best_conf = 0.0 + self._best_guess_prober = None + for prober in self.probers: + if not prober: + continue + if not prober.active: + self.logger.debug('%s not active', prober.charset_name) + continue + conf = prober.get_confidence() + self.logger.debug('%s %s confidence = %s', prober.charset_name, prober.language, conf) + if best_conf < conf: + best_conf = conf + self._best_guess_prober = prober + if not self._best_guess_prober: + return 0.0 + return best_conf diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/charsetprober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/charsetprober.py new file mode 100644 index 0000000..eac4e59 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/charsetprober.py @@ -0,0 +1,145 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Universal charset detector code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 2001 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# Shy Shalom - original C code +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +import logging +import re + +from .enums import ProbingState + + +class CharSetProber(object): + + SHORTCUT_THRESHOLD = 0.95 + + def __init__(self, lang_filter=None): + self._state = None + self.lang_filter = lang_filter + self.logger = logging.getLogger(__name__) + + def reset(self): + self._state = ProbingState.DETECTING + + @property + def charset_name(self): + return None + + def feed(self, buf): + pass + + @property + def state(self): + return self._state + + def get_confidence(self): + return 0.0 + + @staticmethod + def filter_high_byte_only(buf): + buf = re.sub(b'([\x00-\x7F])+', b' ', buf) + return buf + + @staticmethod + def filter_international_words(buf): + """ + We define three types of bytes: + alphabet: english alphabets [a-zA-Z] + international: international characters [\x80-\xFF] + marker: everything else [^a-zA-Z\x80-\xFF] + + The input buffer can be thought to contain a series of words delimited + by markers. This function works to filter all words that contain at + least one international character. All contiguous sequences of markers + are replaced by a single space ascii character. + + This filter applies to all scripts which do not use English characters. + """ + filtered = bytearray() + + # This regex expression filters out only words that have at-least one + # international character. The word may include one marker character at + # the end. + words = re.findall(b'[a-zA-Z]*[\x80-\xFF]+[a-zA-Z]*[^a-zA-Z\x80-\xFF]?', + buf) + + for word in words: + filtered.extend(word[:-1]) + + # If the last character in the word is a marker, replace it with a + # space as markers shouldn't affect our analysis (they are used + # similarly across all languages and may thus have similar + # frequencies). + last_char = word[-1:] + if not last_char.isalpha() and last_char < b'\x80': + last_char = b' ' + filtered.extend(last_char) + + return filtered + + @staticmethod + def filter_with_english_letters(buf): + """ + Returns a copy of ``buf`` that retains only the sequences of English + alphabet and high byte characters that are not between <> characters. + Also retains English alphabet and high byte characters immediately + before occurrences of >. + + This filter can be applied to all scripts which contain both English + characters and extended ASCII characters, but is currently only used by + ``Latin1Prober``. + """ + filtered = bytearray() + in_tag = False + prev = 0 + + for curr in range(len(buf)): + # Slice here to get bytes instead of an int with Python 3 + buf_char = buf[curr:curr + 1] + # Check if we're coming out of or entering an HTML tag + if buf_char == b'>': + in_tag = False + elif buf_char == b'<': + in_tag = True + + # If current character is not extended-ASCII and not alphabetic... + if buf_char < b'\x80' and not buf_char.isalpha(): + # ...and we're not in a tag + if curr > prev and not in_tag: + # Keep everything after last non-extended-ASCII, + # non-alphabetic character + filtered.extend(buf[prev:curr]) + # Output a space to delimit stretch we kept + filtered.extend(b' ') + prev = curr + 1 + + # If we're not in a tag... + if not in_tag: + # Keep everything after last non-extended-ASCII, non-alphabetic + # character + filtered.extend(buf[prev:]) + + return filtered diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cli/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cli/__init__.py new file mode 100644 index 0000000..8b13789 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cli/__init__.py @@ -0,0 +1 @@ + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..47d8e5425c8f8df6ee4f5904696b199af1a68eb7 GIT binary patch literal 208 zcmWIL<>g`kf^QoZCNcu)#~=<e00}w(aWM;!NMQ(O&}8&m$xs9mMi9SB^$UtJ%Mwdc z^~(~A^waWlQc{bG^(`y()8j46igK&+jMB0UGBPTvs^W7j&5|;T41gd#Pd`MzAhSR> zGq1QLF(*gYz`(4mvdj=@SY`nj$Cst%rQ{dsCubxUrKFbVC+B49$H!;pWtPOp>lIYq U;;_lhPbtkwwF5clGY~TX0BR68m;e9( literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1cd4fefe5f3cd4aa7c07587d14f6ebbdf41b0f9d GIT binary patch literal 2709 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 TJr4o!>Y&lOAAJzrtGWLJu8SqX literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cli/chardetect.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cli/chardetect.py new file mode 100644 index 0000000..c61136b --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cli/chardetect.py @@ -0,0 +1,85 @@ +#!/usr/bin/env python +""" +Script which takes one or more file paths and reports on their detected +encodings + +Example:: + + % chardetect somefile someotherfile + somefile: windows-1252 with confidence 0.5 + someotherfile: ascii with confidence 1.0 + +If no paths are provided, it takes its input from stdin. + +""" + +from __future__ import absolute_import, print_function, unicode_literals + +import argparse +import sys + +from pip._vendor.chardet import __version__ +from pip._vendor.chardet.compat import PY2 +from pip._vendor.chardet.universaldetector import UniversalDetector + + +def description_of(lines, name='stdin'): + """ + Return a string describing the probable encoding of a file or + list of strings. + + :param lines: The lines to get the encoding of. + :type lines: Iterable of bytes + :param name: Name of file or collection of lines + :type name: str + """ + u = UniversalDetector() + for line in lines: + line = bytearray(line) + u.feed(line) + # shortcut out of the loop to save reading further - particularly useful if we read a BOM. + if u.done: + break + u.close() + result = u.result + if PY2: + name = name.decode(sys.getfilesystemencoding(), 'ignore') + if result['encoding']: + return '{0}: {1} with confidence {2}'.format(name, result['encoding'], + result['confidence']) + else: + return '{0}: no result'.format(name) + + +def main(argv=None): + """ + Handles command line arguments and gets things started. + + :param argv: List of arguments, as if specified on the command-line. + If None, ``sys.argv[1:]`` is used instead. + :type argv: list of str + """ + # Get command line arguments + parser = argparse.ArgumentParser( + description="Takes one or more file paths and reports their detected \ + encodings") + parser.add_argument('input', + help='File whose encoding we would like to determine. \ + (default: stdin)', + type=argparse.FileType('rb'), nargs='*', + default=[sys.stdin if PY2 else sys.stdin.buffer]) + parser.add_argument('--version', action='version', + version='%(prog)s {0}'.format(__version__)) + args = parser.parse_args(argv) + + for f in args.input: + if f.isatty(): + print("You are running chardetect interactively. Press " + + "CTRL-D twice at the start of a blank line to signal the " + + "end of your input. If you want help, run chardetect " + + "--help\n", file=sys.stderr) + print(description_of(f, f.name)) + + +if __name__ == '__main__': + main() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/codingstatemachine.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/codingstatemachine.py new file mode 100644 index 0000000..68fba44 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/codingstatemachine.py @@ -0,0 +1,88 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is mozilla.org code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +import logging + +from .enums import MachineState + + +class CodingStateMachine(object): + """ + A state machine to verify a byte sequence for a particular encoding. For + each byte the detector receives, it will feed that byte to every active + state machine available, one byte at a time. The state machine changes its + state based on its previous state and the byte it receives. There are 3 + states in a state machine that are of interest to an auto-detector: + + START state: This is the state to start with, or a legal byte sequence + (i.e. a valid code point) for character has been identified. + + ME state: This indicates that the state machine identified a byte sequence + that is specific to the charset it is designed for and that + there is no other possible encoding which can contain this byte + sequence. This will to lead to an immediate positive answer for + the detector. + + ERROR state: This indicates the state machine identified an illegal byte + sequence for that encoding. This will lead to an immediate + negative answer for this encoding. Detector will exclude this + encoding from consideration from here on. + """ + def __init__(self, sm): + self._model = sm + self._curr_byte_pos = 0 + self._curr_char_len = 0 + self._curr_state = None + self.logger = logging.getLogger(__name__) + self.reset() + + def reset(self): + self._curr_state = MachineState.START + + def next_state(self, c): + # for each byte we get its class + # if it is first byte, we also get byte length + byte_class = self._model['class_table'][c] + if self._curr_state == MachineState.START: + self._curr_byte_pos = 0 + self._curr_char_len = self._model['char_len_table'][byte_class] + # from byte's class and state_table, we get its next state + curr_state = (self._curr_state * self._model['class_factor'] + + byte_class) + self._curr_state = self._model['state_table'][curr_state] + self._curr_byte_pos += 1 + return self._curr_state + + def get_current_charlen(self): + return self._curr_char_len + + def get_coding_state_machine(self): + return self._model['name'] + + @property + def language(self): + return self._model['language'] diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/compat.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/compat.py new file mode 100644 index 0000000..ddd7468 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/compat.py @@ -0,0 +1,34 @@ +######################## BEGIN LICENSE BLOCK ######################## +# Contributor(s): +# Dan Blanchard +# Ian Cordasco +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +import sys + + +if sys.version_info < (3, 0): + PY2 = True + PY3 = False + base_str = (str, unicode) + text_type = unicode +else: + PY2 = False + PY3 = True + base_str = (bytes, str) + text_type = str diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cp949prober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cp949prober.py new file mode 100644 index 0000000..efd793a --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/cp949prober.py @@ -0,0 +1,49 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is mozilla.org code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .chardistribution import EUCKRDistributionAnalysis +from .codingstatemachine import CodingStateMachine +from .mbcharsetprober import MultiByteCharSetProber +from .mbcssm import CP949_SM_MODEL + + +class CP949Prober(MultiByteCharSetProber): + def __init__(self): + super(CP949Prober, self).__init__() + self.coding_sm = CodingStateMachine(CP949_SM_MODEL) + # NOTE: CP949 is a superset of EUC-KR, so the distribution should be + # not different. + self.distribution_analyzer = EUCKRDistributionAnalysis() + self.reset() + + @property + def charset_name(self): + return "CP949" + + @property + def language(self): + return "Korean" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/enums.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/enums.py new file mode 100644 index 0000000..0451207 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/enums.py @@ -0,0 +1,76 @@ +""" +All of the Enums that are used throughout the chardet package. + +:author: Dan Blanchard (dan.blanchard@gmail.com) +""" + + +class InputState(object): + """ + This enum represents the different states a universal detector can be in. + """ + PURE_ASCII = 0 + ESC_ASCII = 1 + HIGH_BYTE = 2 + + +class LanguageFilter(object): + """ + This enum represents the different language filters we can apply to a + ``UniversalDetector``. + """ + CHINESE_SIMPLIFIED = 0x01 + CHINESE_TRADITIONAL = 0x02 + JAPANESE = 0x04 + KOREAN = 0x08 + NON_CJK = 0x10 + ALL = 0x1F + CHINESE = CHINESE_SIMPLIFIED | CHINESE_TRADITIONAL + CJK = CHINESE | JAPANESE | KOREAN + + +class ProbingState(object): + """ + This enum represents the different states a prober can be in. + """ + DETECTING = 0 + FOUND_IT = 1 + NOT_ME = 2 + + +class MachineState(object): + """ + This enum represents the different states a state machine can be in. + """ + START = 0 + ERROR = 1 + ITS_ME = 2 + + +class SequenceLikelihood(object): + """ + This enum represents the likelihood of a character following the previous one. + """ + NEGATIVE = 0 + UNLIKELY = 1 + LIKELY = 2 + POSITIVE = 3 + + @classmethod + def get_num_categories(cls): + """:returns: The number of likelihood categories in the enum.""" + return 4 + + +class CharacterCategory(object): + """ + This enum represents the different categories language models for + ``SingleByteCharsetProber`` put characters into. + + Anything less than CONTROL is considered a letter. + """ + UNDEFINED = 255 + LINE_BREAK = 254 + SYMBOL = 253 + DIGIT = 252 + CONTROL = 251 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/escprober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/escprober.py new file mode 100644 index 0000000..c70493f --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/escprober.py @@ -0,0 +1,101 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is mozilla.org code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .charsetprober import CharSetProber +from .codingstatemachine import CodingStateMachine +from .enums import LanguageFilter, ProbingState, MachineState +from .escsm import (HZ_SM_MODEL, ISO2022CN_SM_MODEL, ISO2022JP_SM_MODEL, + ISO2022KR_SM_MODEL) + + +class EscCharSetProber(CharSetProber): + """ + This CharSetProber uses a "code scheme" approach for detecting encodings, + whereby easily recognizable escape or shift sequences are relied on to + identify these encodings. + """ + + def __init__(self, lang_filter=None): + super(EscCharSetProber, self).__init__(lang_filter=lang_filter) + self.coding_sm = [] + if self.lang_filter & LanguageFilter.CHINESE_SIMPLIFIED: + self.coding_sm.append(CodingStateMachine(HZ_SM_MODEL)) + self.coding_sm.append(CodingStateMachine(ISO2022CN_SM_MODEL)) + if self.lang_filter & LanguageFilter.JAPANESE: + self.coding_sm.append(CodingStateMachine(ISO2022JP_SM_MODEL)) + if self.lang_filter & LanguageFilter.KOREAN: + self.coding_sm.append(CodingStateMachine(ISO2022KR_SM_MODEL)) + self.active_sm_count = None + self._detected_charset = None + self._detected_language = None + self._state = None + self.reset() + + def reset(self): + super(EscCharSetProber, self).reset() + for coding_sm in self.coding_sm: + if not coding_sm: + continue + coding_sm.active = True + coding_sm.reset() + self.active_sm_count = len(self.coding_sm) + self._detected_charset = None + self._detected_language = None + + @property + def charset_name(self): + return self._detected_charset + + @property + def language(self): + return self._detected_language + + def get_confidence(self): + if self._detected_charset: + return 0.99 + else: + return 0.00 + + def feed(self, byte_str): + for c in byte_str: + for coding_sm in self.coding_sm: + if not coding_sm or not coding_sm.active: + continue + coding_state = coding_sm.next_state(c) + if coding_state == MachineState.ERROR: + coding_sm.active = False + self.active_sm_count -= 1 + if self.active_sm_count <= 0: + self._state = ProbingState.NOT_ME + return self.state + elif coding_state == MachineState.ITS_ME: + self._state = ProbingState.FOUND_IT + self._detected_charset = coding_sm.get_coding_state_machine() + self._detected_language = coding_sm.language + return self.state + + return self.state diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/escsm.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/escsm.py new file mode 100644 index 0000000..0069523 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/escsm.py @@ -0,0 +1,246 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is mozilla.org code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .enums import MachineState + +HZ_CLS = ( +1,0,0,0,0,0,0,0, # 00 - 07 +0,0,0,0,0,0,0,0, # 08 - 0f +0,0,0,0,0,0,0,0, # 10 - 17 +0,0,0,1,0,0,0,0, # 18 - 1f +0,0,0,0,0,0,0,0, # 20 - 27 +0,0,0,0,0,0,0,0, # 28 - 2f +0,0,0,0,0,0,0,0, # 30 - 37 +0,0,0,0,0,0,0,0, # 38 - 3f +0,0,0,0,0,0,0,0, # 40 - 47 +0,0,0,0,0,0,0,0, # 48 - 4f +0,0,0,0,0,0,0,0, # 50 - 57 +0,0,0,0,0,0,0,0, # 58 - 5f +0,0,0,0,0,0,0,0, # 60 - 67 +0,0,0,0,0,0,0,0, # 68 - 6f +0,0,0,0,0,0,0,0, # 70 - 77 +0,0,0,4,0,5,2,0, # 78 - 7f +1,1,1,1,1,1,1,1, # 80 - 87 +1,1,1,1,1,1,1,1, # 88 - 8f +1,1,1,1,1,1,1,1, # 90 - 97 +1,1,1,1,1,1,1,1, # 98 - 9f +1,1,1,1,1,1,1,1, # a0 - a7 +1,1,1,1,1,1,1,1, # a8 - af +1,1,1,1,1,1,1,1, # b0 - b7 +1,1,1,1,1,1,1,1, # b8 - bf +1,1,1,1,1,1,1,1, # c0 - c7 +1,1,1,1,1,1,1,1, # c8 - cf +1,1,1,1,1,1,1,1, # d0 - d7 +1,1,1,1,1,1,1,1, # d8 - df +1,1,1,1,1,1,1,1, # e0 - e7 +1,1,1,1,1,1,1,1, # e8 - ef +1,1,1,1,1,1,1,1, # f0 - f7 +1,1,1,1,1,1,1,1, # f8 - ff +) + +HZ_ST = ( +MachineState.START,MachineState.ERROR, 3,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,# 00-07 +MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 08-0f +MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START, 4,MachineState.ERROR,# 10-17 + 5,MachineState.ERROR, 6,MachineState.ERROR, 5, 5, 4,MachineState.ERROR,# 18-1f + 4,MachineState.ERROR, 4, 4, 4,MachineState.ERROR, 4,MachineState.ERROR,# 20-27 + 4,MachineState.ITS_ME,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 28-2f +) + +HZ_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0) + +HZ_SM_MODEL = {'class_table': HZ_CLS, + 'class_factor': 6, + 'state_table': HZ_ST, + 'char_len_table': HZ_CHAR_LEN_TABLE, + 'name': "HZ-GB-2312", + 'language': 'Chinese'} + +ISO2022CN_CLS = ( +2,0,0,0,0,0,0,0, # 00 - 07 +0,0,0,0,0,0,0,0, # 08 - 0f +0,0,0,0,0,0,0,0, # 10 - 17 +0,0,0,1,0,0,0,0, # 18 - 1f +0,0,0,0,0,0,0,0, # 20 - 27 +0,3,0,0,0,0,0,0, # 28 - 2f +0,0,0,0,0,0,0,0, # 30 - 37 +0,0,0,0,0,0,0,0, # 38 - 3f +0,0,0,4,0,0,0,0, # 40 - 47 +0,0,0,0,0,0,0,0, # 48 - 4f +0,0,0,0,0,0,0,0, # 50 - 57 +0,0,0,0,0,0,0,0, # 58 - 5f +0,0,0,0,0,0,0,0, # 60 - 67 +0,0,0,0,0,0,0,0, # 68 - 6f +0,0,0,0,0,0,0,0, # 70 - 77 +0,0,0,0,0,0,0,0, # 78 - 7f +2,2,2,2,2,2,2,2, # 80 - 87 +2,2,2,2,2,2,2,2, # 88 - 8f +2,2,2,2,2,2,2,2, # 90 - 97 +2,2,2,2,2,2,2,2, # 98 - 9f +2,2,2,2,2,2,2,2, # a0 - a7 +2,2,2,2,2,2,2,2, # a8 - af +2,2,2,2,2,2,2,2, # b0 - b7 +2,2,2,2,2,2,2,2, # b8 - bf +2,2,2,2,2,2,2,2, # c0 - c7 +2,2,2,2,2,2,2,2, # c8 - cf +2,2,2,2,2,2,2,2, # d0 - d7 +2,2,2,2,2,2,2,2, # d8 - df +2,2,2,2,2,2,2,2, # e0 - e7 +2,2,2,2,2,2,2,2, # e8 - ef +2,2,2,2,2,2,2,2, # f0 - f7 +2,2,2,2,2,2,2,2, # f8 - ff +) + +ISO2022CN_ST = ( +MachineState.START, 3,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 00-07 +MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 08-0f +MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 10-17 +MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 4,MachineState.ERROR,# 18-1f +MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 20-27 + 5, 6,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 28-2f +MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 30-37 +MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.START,# 38-3f +) + +ISO2022CN_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0, 0, 0, 0) + +ISO2022CN_SM_MODEL = {'class_table': ISO2022CN_CLS, + 'class_factor': 9, + 'state_table': ISO2022CN_ST, + 'char_len_table': ISO2022CN_CHAR_LEN_TABLE, + 'name': "ISO-2022-CN", + 'language': 'Chinese'} + +ISO2022JP_CLS = ( +2,0,0,0,0,0,0,0, # 00 - 07 +0,0,0,0,0,0,2,2, # 08 - 0f +0,0,0,0,0,0,0,0, # 10 - 17 +0,0,0,1,0,0,0,0, # 18 - 1f +0,0,0,0,7,0,0,0, # 20 - 27 +3,0,0,0,0,0,0,0, # 28 - 2f +0,0,0,0,0,0,0,0, # 30 - 37 +0,0,0,0,0,0,0,0, # 38 - 3f +6,0,4,0,8,0,0,0, # 40 - 47 +0,9,5,0,0,0,0,0, # 48 - 4f +0,0,0,0,0,0,0,0, # 50 - 57 +0,0,0,0,0,0,0,0, # 58 - 5f +0,0,0,0,0,0,0,0, # 60 - 67 +0,0,0,0,0,0,0,0, # 68 - 6f +0,0,0,0,0,0,0,0, # 70 - 77 +0,0,0,0,0,0,0,0, # 78 - 7f +2,2,2,2,2,2,2,2, # 80 - 87 +2,2,2,2,2,2,2,2, # 88 - 8f +2,2,2,2,2,2,2,2, # 90 - 97 +2,2,2,2,2,2,2,2, # 98 - 9f +2,2,2,2,2,2,2,2, # a0 - a7 +2,2,2,2,2,2,2,2, # a8 - af +2,2,2,2,2,2,2,2, # b0 - b7 +2,2,2,2,2,2,2,2, # b8 - bf +2,2,2,2,2,2,2,2, # c0 - c7 +2,2,2,2,2,2,2,2, # c8 - cf +2,2,2,2,2,2,2,2, # d0 - d7 +2,2,2,2,2,2,2,2, # d8 - df +2,2,2,2,2,2,2,2, # e0 - e7 +2,2,2,2,2,2,2,2, # e8 - ef +2,2,2,2,2,2,2,2, # f0 - f7 +2,2,2,2,2,2,2,2, # f8 - ff +) + +ISO2022JP_ST = ( +MachineState.START, 3,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 00-07 +MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 08-0f +MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 10-17 +MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,# 18-1f +MachineState.ERROR, 5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 4,MachineState.ERROR,MachineState.ERROR,# 20-27 +MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 6,MachineState.ITS_ME,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,# 28-2f +MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,# 30-37 +MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 38-3f +MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.START,MachineState.START,# 40-47 +) + +ISO2022JP_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0, 0, 0, 0, 0) + +ISO2022JP_SM_MODEL = {'class_table': ISO2022JP_CLS, + 'class_factor': 10, + 'state_table': ISO2022JP_ST, + 'char_len_table': ISO2022JP_CHAR_LEN_TABLE, + 'name': "ISO-2022-JP", + 'language': 'Japanese'} + +ISO2022KR_CLS = ( +2,0,0,0,0,0,0,0, # 00 - 07 +0,0,0,0,0,0,0,0, # 08 - 0f +0,0,0,0,0,0,0,0, # 10 - 17 +0,0,0,1,0,0,0,0, # 18 - 1f +0,0,0,0,3,0,0,0, # 20 - 27 +0,4,0,0,0,0,0,0, # 28 - 2f +0,0,0,0,0,0,0,0, # 30 - 37 +0,0,0,0,0,0,0,0, # 38 - 3f +0,0,0,5,0,0,0,0, # 40 - 47 +0,0,0,0,0,0,0,0, # 48 - 4f +0,0,0,0,0,0,0,0, # 50 - 57 +0,0,0,0,0,0,0,0, # 58 - 5f +0,0,0,0,0,0,0,0, # 60 - 67 +0,0,0,0,0,0,0,0, # 68 - 6f +0,0,0,0,0,0,0,0, # 70 - 77 +0,0,0,0,0,0,0,0, # 78 - 7f +2,2,2,2,2,2,2,2, # 80 - 87 +2,2,2,2,2,2,2,2, # 88 - 8f +2,2,2,2,2,2,2,2, # 90 - 97 +2,2,2,2,2,2,2,2, # 98 - 9f +2,2,2,2,2,2,2,2, # a0 - a7 +2,2,2,2,2,2,2,2, # a8 - af +2,2,2,2,2,2,2,2, # b0 - b7 +2,2,2,2,2,2,2,2, # b8 - bf +2,2,2,2,2,2,2,2, # c0 - c7 +2,2,2,2,2,2,2,2, # c8 - cf +2,2,2,2,2,2,2,2, # d0 - d7 +2,2,2,2,2,2,2,2, # d8 - df +2,2,2,2,2,2,2,2, # e0 - e7 +2,2,2,2,2,2,2,2, # e8 - ef +2,2,2,2,2,2,2,2, # f0 - f7 +2,2,2,2,2,2,2,2, # f8 - ff +) + +ISO2022KR_ST = ( +MachineState.START, 3,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,# 00-07 +MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 08-0f +MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 4,MachineState.ERROR,MachineState.ERROR,# 10-17 +MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 18-1f +MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 20-27 +) + +ISO2022KR_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0) + +ISO2022KR_SM_MODEL = {'class_table': ISO2022KR_CLS, + 'class_factor': 6, + 'state_table': ISO2022KR_ST, + 'char_len_table': ISO2022KR_CHAR_LEN_TABLE, + 'name': "ISO-2022-KR", + 'language': 'Korean'} + + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/eucjpprober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/eucjpprober.py new file mode 100644 index 0000000..20ce8f7 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/eucjpprober.py @@ -0,0 +1,92 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is mozilla.org code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .enums import ProbingState, MachineState +from .mbcharsetprober import MultiByteCharSetProber +from .codingstatemachine import CodingStateMachine +from .chardistribution import EUCJPDistributionAnalysis +from .jpcntx import EUCJPContextAnalysis +from .mbcssm import EUCJP_SM_MODEL + + +class EUCJPProber(MultiByteCharSetProber): + def __init__(self): + super(EUCJPProber, self).__init__() + self.coding_sm = CodingStateMachine(EUCJP_SM_MODEL) + self.distribution_analyzer = EUCJPDistributionAnalysis() + self.context_analyzer = EUCJPContextAnalysis() + self.reset() + + def reset(self): + super(EUCJPProber, self).reset() + self.context_analyzer.reset() + + @property + def charset_name(self): + return "EUC-JP" + + @property + def language(self): + return "Japanese" + + def feed(self, byte_str): + for i in range(len(byte_str)): + # PY3K: byte_str is a byte array, so byte_str[i] is an int, not a byte + coding_state = self.coding_sm.next_state(byte_str[i]) + if coding_state == MachineState.ERROR: + self.logger.debug('%s %s prober hit error at byte %s', + self.charset_name, self.language, i) + self._state = ProbingState.NOT_ME + break + elif coding_state == MachineState.ITS_ME: + self._state = ProbingState.FOUND_IT + break + elif coding_state == MachineState.START: + char_len = self.coding_sm.get_current_charlen() + if i == 0: + self._last_char[1] = byte_str[0] + self.context_analyzer.feed(self._last_char, char_len) + self.distribution_analyzer.feed(self._last_char, char_len) + else: + self.context_analyzer.feed(byte_str[i - 1:i + 1], + char_len) + self.distribution_analyzer.feed(byte_str[i - 1:i + 1], + char_len) + + self._last_char[0] = byte_str[-1] + + if self.state == ProbingState.DETECTING: + if (self.context_analyzer.got_enough_data() and + (self.get_confidence() > self.SHORTCUT_THRESHOLD)): + self._state = ProbingState.FOUND_IT + + return self.state + + def get_confidence(self): + context_conf = self.context_analyzer.get_confidence() + distrib_conf = self.distribution_analyzer.get_confidence() + return max(context_conf, distrib_conf) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euckrfreq.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euckrfreq.py new file mode 100644 index 0000000..b68078c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euckrfreq.py @@ -0,0 +1,195 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Communicator client code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +# Sampling from about 20M text materials include literature and computer technology + +# 128 --> 0.79 +# 256 --> 0.92 +# 512 --> 0.986 +# 1024 --> 0.99944 +# 2048 --> 0.99999 +# +# Idea Distribution Ratio = 0.98653 / (1-0.98653) = 73.24 +# Random Distribution Ration = 512 / (2350-512) = 0.279. +# +# Typical Distribution Ratio + +EUCKR_TYPICAL_DISTRIBUTION_RATIO = 6.0 + +EUCKR_TABLE_SIZE = 2352 + +# Char to FreqOrder table , +EUCKR_CHAR_TO_FREQ_ORDER = ( + 13, 130, 120,1396, 481,1719,1720, 328, 609, 212,1721, 707, 400, 299,1722, 87, +1397,1723, 104, 536,1117,1203,1724,1267, 685,1268, 508,1725,1726,1727,1728,1398, +1399,1729,1730,1731, 141, 621, 326,1057, 368,1732, 267, 488, 20,1733,1269,1734, + 945,1400,1735, 47, 904,1270,1736,1737, 773, 248,1738, 409, 313, 786, 429,1739, + 116, 987, 813,1401, 683, 75,1204, 145,1740,1741,1742,1743, 16, 847, 667, 622, + 708,1744,1745,1746, 966, 787, 304, 129,1747, 60, 820, 123, 676,1748,1749,1750, +1751, 617,1752, 626,1753,1754,1755,1756, 653,1757,1758,1759,1760,1761,1762, 856, + 344,1763,1764,1765,1766, 89, 401, 418, 806, 905, 848,1767,1768,1769, 946,1205, + 709,1770,1118,1771, 241,1772,1773,1774,1271,1775, 569,1776, 999,1777,1778,1779, +1780, 337, 751,1058, 28, 628, 254,1781, 177, 906, 270, 349, 891,1079,1782, 19, +1783, 379,1784, 315,1785, 629, 754,1402, 559,1786, 636, 203,1206,1787, 710, 567, +1788, 935, 814,1789,1790,1207, 766, 528,1791,1792,1208,1793,1794,1795,1796,1797, +1403,1798,1799, 533,1059,1404,1405,1156,1406, 936, 884,1080,1800, 351,1801,1802, +1803,1804,1805, 801,1806,1807,1808,1119,1809,1157, 714, 474,1407,1810, 298, 899, + 885,1811,1120, 802,1158,1812, 892,1813,1814,1408, 659,1815,1816,1121,1817,1818, +1819,1820,1821,1822, 319,1823, 594, 545,1824, 815, 937,1209,1825,1826, 573,1409, +1022,1827,1210,1828,1829,1830,1831,1832,1833, 556, 722, 807,1122,1060,1834, 697, +1835, 900, 557, 715,1836,1410, 540,1411, 752,1159, 294, 597,1211, 976, 803, 770, +1412,1837,1838, 39, 794,1413, 358,1839, 371, 925,1840, 453, 661, 788, 531, 723, + 544,1023,1081, 869, 91,1841, 392, 430, 790, 602,1414, 677,1082, 457,1415,1416, +1842,1843, 475, 327,1024,1417, 795, 121,1844, 733, 403,1418,1845,1846,1847, 300, + 119, 711,1212, 627,1848,1272, 207,1849,1850, 796,1213, 382,1851, 519,1852,1083, + 893,1853,1854,1855, 367, 809, 487, 671,1856, 663,1857,1858, 956, 471, 306, 857, +1859,1860,1160,1084,1861,1862,1863,1864,1865,1061,1866,1867,1868,1869,1870,1871, + 282, 96, 574,1872, 502,1085,1873,1214,1874, 907,1875,1876, 827, 977,1419,1420, +1421, 268,1877,1422,1878,1879,1880, 308,1881, 2, 537,1882,1883,1215,1884,1885, + 127, 791,1886,1273,1423,1887, 34, 336, 404, 643,1888, 571, 654, 894, 840,1889, + 0, 886,1274, 122, 575, 260, 908, 938,1890,1275, 410, 316,1891,1892, 100,1893, +1894,1123, 48,1161,1124,1025,1895, 633, 901,1276,1896,1897, 115, 816,1898, 317, +1899, 694,1900, 909, 734,1424, 572, 866,1425, 691, 85, 524,1010, 543, 394, 841, +1901,1902,1903,1026,1904,1905,1906,1907,1908,1909, 30, 451, 651, 988, 310,1910, +1911,1426, 810,1216, 93,1912,1913,1277,1217,1914, 858, 759, 45, 58, 181, 610, + 269,1915,1916, 131,1062, 551, 443,1000, 821,1427, 957, 895,1086,1917,1918, 375, +1919, 359,1920, 687,1921, 822,1922, 293,1923,1924, 40, 662, 118, 692, 29, 939, + 887, 640, 482, 174,1925, 69,1162, 728,1428, 910,1926,1278,1218,1279, 386, 870, + 217, 854,1163, 823,1927,1928,1929,1930, 834,1931, 78,1932, 859,1933,1063,1934, +1935,1936,1937, 438,1164, 208, 595,1938,1939,1940,1941,1219,1125,1942, 280, 888, +1429,1430,1220,1431,1943,1944,1945,1946,1947,1280, 150, 510,1432,1948,1949,1950, +1951,1952,1953,1954,1011,1087,1955,1433,1043,1956, 881,1957, 614, 958,1064,1065, +1221,1958, 638,1001, 860, 967, 896,1434, 989, 492, 553,1281,1165,1959,1282,1002, +1283,1222,1960,1961,1962,1963, 36, 383, 228, 753, 247, 454,1964, 876, 678,1965, +1966,1284, 126, 464, 490, 835, 136, 672, 529, 940,1088,1435, 473,1967,1968, 467, + 50, 390, 227, 587, 279, 378, 598, 792, 968, 240, 151, 160, 849, 882,1126,1285, + 639,1044, 133, 140, 288, 360, 811, 563,1027, 561, 142, 523,1969,1970,1971, 7, + 103, 296, 439, 407, 506, 634, 990,1972,1973,1974,1975, 645,1976,1977,1978,1979, +1980,1981, 236,1982,1436,1983,1984,1089, 192, 828, 618, 518,1166, 333,1127,1985, + 818,1223,1986,1987,1988,1989,1990,1991,1992,1993, 342,1128,1286, 746, 842,1994, +1995, 560, 223,1287, 98, 8, 189, 650, 978,1288,1996,1437,1997, 17, 345, 250, + 423, 277, 234, 512, 226, 97, 289, 42, 167,1998, 201,1999,2000, 843, 836, 824, + 532, 338, 783,1090, 182, 576, 436,1438,1439, 527, 500,2001, 947, 889,2002,2003, +2004,2005, 262, 600, 314, 447,2006, 547,2007, 693, 738,1129,2008, 71,1440, 745, + 619, 688,2009, 829,2010,2011, 147,2012, 33, 948,2013,2014, 74, 224,2015, 61, + 191, 918, 399, 637,2016,1028,1130, 257, 902,2017,2018,2019,2020,2021,2022,2023, +2024,2025,2026, 837,2027,2028,2029,2030, 179, 874, 591, 52, 724, 246,2031,2032, +2033,2034,1167, 969,2035,1289, 630, 605, 911,1091,1168,2036,2037,2038,1441, 912, +2039, 623,2040,2041, 253,1169,1290,2042,1442, 146, 620, 611, 577, 433,2043,1224, + 719,1170, 959, 440, 437, 534, 84, 388, 480,1131, 159, 220, 198, 679,2044,1012, + 819,1066,1443, 113,1225, 194, 318,1003,1029,2045,2046,2047,2048,1067,2049,2050, +2051,2052,2053, 59, 913, 112,2054, 632,2055, 455, 144, 739,1291,2056, 273, 681, + 499,2057, 448,2058,2059, 760,2060,2061, 970, 384, 169, 245,1132,2062,2063, 414, +1444,2064,2065, 41, 235,2066, 157, 252, 877, 568, 919, 789, 580,2067, 725,2068, +2069,1292,2070,2071,1445,2072,1446,2073,2074, 55, 588, 66,1447, 271,1092,2075, +1226,2076, 960,1013, 372,2077,2078,2079,2080,2081,1293,2082,2083,2084,2085, 850, +2086,2087,2088,2089,2090, 186,2091,1068, 180,2092,2093,2094, 109,1227, 522, 606, +2095, 867,1448,1093, 991,1171, 926, 353,1133,2096, 581,2097,2098,2099,1294,1449, +1450,2100, 596,1172,1014,1228,2101,1451,1295,1173,1229,2102,2103,1296,1134,1452, + 949,1135,2104,2105,1094,1453,1454,1455,2106,1095,2107,2108,2109,2110,2111,2112, +2113,2114,2115,2116,2117, 804,2118,2119,1230,1231, 805,1456, 405,1136,2120,2121, +2122,2123,2124, 720, 701,1297, 992,1457, 927,1004,2125,2126,2127,2128,2129,2130, + 22, 417,2131, 303,2132, 385,2133, 971, 520, 513,2134,1174, 73,1096, 231, 274, + 962,1458, 673,2135,1459,2136, 152,1137,2137,2138,2139,2140,1005,1138,1460,1139, +2141,2142,2143,2144, 11, 374, 844,2145, 154,1232, 46,1461,2146, 838, 830, 721, +1233, 106,2147, 90, 428, 462, 578, 566,1175, 352,2148,2149, 538,1234, 124,1298, +2150,1462, 761, 565,2151, 686,2152, 649,2153, 72, 173,2154, 460, 415,2155,1463, +2156,1235, 305,2157,2158,2159,2160,2161,2162, 579,2163,2164,2165,2166,2167, 747, +2168,2169,2170,2171,1464, 669,2172,2173,2174,2175,2176,1465,2177, 23, 530, 285, +2178, 335, 729,2179, 397,2180,2181,2182,1030,2183,2184, 698,2185,2186, 325,2187, +2188, 369,2189, 799,1097,1015, 348,2190,1069, 680,2191, 851,1466,2192,2193, 10, +2194, 613, 424,2195, 979, 108, 449, 589, 27, 172, 81,1031, 80, 774, 281, 350, +1032, 525, 301, 582,1176,2196, 674,1045,2197,2198,1467, 730, 762,2199,2200,2201, +2202,1468,2203, 993,2204,2205, 266,1070, 963,1140,2206,2207,2208, 664,1098, 972, +2209,2210,2211,1177,1469,1470, 871,2212,2213,2214,2215,2216,1471,2217,2218,2219, +2220,2221,2222,2223,2224,2225,2226,2227,1472,1236,2228,2229,2230,2231,2232,2233, +2234,2235,1299,2236,2237, 200,2238, 477, 373,2239,2240, 731, 825, 777,2241,2242, +2243, 521, 486, 548,2244,2245,2246,1473,1300, 53, 549, 137, 875, 76, 158,2247, +1301,1474, 469, 396,1016, 278, 712,2248, 321, 442, 503, 767, 744, 941,1237,1178, +1475,2249, 82, 178,1141,1179, 973,2250,1302,2251, 297,2252,2253, 570,2254,2255, +2256, 18, 450, 206,2257, 290, 292,1142,2258, 511, 162, 99, 346, 164, 735,2259, +1476,1477, 4, 554, 343, 798,1099,2260,1100,2261, 43, 171,1303, 139, 215,2262, +2263, 717, 775,2264,1033, 322, 216,2265, 831,2266, 149,2267,1304,2268,2269, 702, +1238, 135, 845, 347, 309,2270, 484,2271, 878, 655, 238,1006,1478,2272, 67,2273, + 295,2274,2275, 461,2276, 478, 942, 412,2277,1034,2278,2279,2280, 265,2281, 541, +2282,2283,2284,2285,2286, 70, 852,1071,2287,2288,2289,2290, 21, 56, 509, 117, + 432,2291,2292, 331, 980, 552,1101, 148, 284, 105, 393,1180,1239, 755,2293, 187, +2294,1046,1479,2295, 340,2296, 63,1047, 230,2297,2298,1305, 763,1306, 101, 800, + 808, 494,2299,2300,2301, 903,2302, 37,1072, 14, 5,2303, 79, 675,2304, 312, +2305,2306,2307,2308,2309,1480, 6,1307,2310,2311,2312, 1, 470, 35, 24, 229, +2313, 695, 210, 86, 778, 15, 784, 592, 779, 32, 77, 855, 964,2314, 259,2315, + 501, 380,2316,2317, 83, 981, 153, 689,1308,1481,1482,1483,2318,2319, 716,1484, +2320,2321,2322,2323,2324,2325,1485,2326,2327, 128, 57, 68, 261,1048, 211, 170, +1240, 31,2328, 51, 435, 742,2329,2330,2331, 635,2332, 264, 456,2333,2334,2335, + 425,2336,1486, 143, 507, 263, 943,2337, 363, 920,1487, 256,1488,1102, 243, 601, +1489,2338,2339,2340,2341,2342,2343,2344, 861,2345,2346,2347,2348,2349,2350, 395, +2351,1490,1491, 62, 535, 166, 225,2352,2353, 668, 419,1241, 138, 604, 928,2354, +1181,2355,1492,1493,2356,2357,2358,1143,2359, 696,2360, 387, 307,1309, 682, 476, +2361,2362, 332, 12, 222, 156,2363, 232,2364, 641, 276, 656, 517,1494,1495,1035, + 416, 736,1496,2365,1017, 586,2366,2367,2368,1497,2369, 242,2370,2371,2372,1498, +2373, 965, 713,2374,2375,2376,2377, 740, 982,1499, 944,1500,1007,2378,2379,1310, +1501,2380,2381,2382, 785, 329,2383,2384,1502,2385,2386,2387, 932,2388,1503,2389, +2390,2391,2392,1242,2393,2394,2395,2396,2397, 994, 950,2398,2399,2400,2401,1504, +1311,2402,2403,2404,2405,1049, 749,2406,2407, 853, 718,1144,1312,2408,1182,1505, +2409,2410, 255, 516, 479, 564, 550, 214,1506,1507,1313, 413, 239, 444, 339,1145, +1036,1508,1509,1314,1037,1510,1315,2411,1511,2412,2413,2414, 176, 703, 497, 624, + 593, 921, 302,2415, 341, 165,1103,1512,2416,1513,2417,2418,2419, 376,2420, 700, +2421,2422,2423, 258, 768,1316,2424,1183,2425, 995, 608,2426,2427,2428,2429, 221, +2430,2431,2432,2433,2434,2435,2436,2437, 195, 323, 726, 188, 897, 983,1317, 377, + 644,1050, 879,2438, 452,2439,2440,2441,2442,2443,2444, 914,2445,2446,2447,2448, + 915, 489,2449,1514,1184,2450,2451, 515, 64, 427, 495,2452, 583,2453, 483, 485, +1038, 562, 213,1515, 748, 666,2454,2455,2456,2457, 334,2458, 780, 996,1008, 705, +1243,2459,2460,2461,2462,2463, 114,2464, 493,1146, 366, 163,1516, 961,1104,2465, + 291,2466,1318,1105,2467,1517, 365,2468, 355, 951,1244,2469,1319,2470, 631,2471, +2472, 218,1320, 364, 320, 756,1518,1519,1321,1520,1322,2473,2474,2475,2476, 997, +2477,2478,2479,2480, 665,1185,2481, 916,1521,2482,2483,2484, 584, 684,2485,2486, + 797,2487,1051,1186,2488,2489,2490,1522,2491,2492, 370,2493,1039,1187, 65,2494, + 434, 205, 463,1188,2495, 125, 812, 391, 402, 826, 699, 286, 398, 155, 781, 771, + 585,2496, 590, 505,1073,2497, 599, 244, 219, 917,1018, 952, 646,1523,2498,1323, +2499,2500, 49, 984, 354, 741,2501, 625,2502,1324,2503,1019, 190, 357, 757, 491, + 95, 782, 868,2504,2505,2506,2507,2508,2509, 134,1524,1074, 422,1525, 898,2510, + 161,2511,2512,2513,2514, 769,2515,1526,2516,2517, 411,1325,2518, 472,1527,2519, +2520,2521,2522,2523,2524, 985,2525,2526,2527,2528,2529,2530, 764,2531,1245,2532, +2533, 25, 204, 311,2534, 496,2535,1052,2536,2537,2538,2539,2540,2541,2542, 199, + 704, 504, 468, 758, 657,1528, 196, 44, 839,1246, 272, 750,2543, 765, 862,2544, +2545,1326,2546, 132, 615, 933,2547, 732,2548,2549,2550,1189,1529,2551, 283,1247, +1053, 607, 929,2552,2553,2554, 930, 183, 872, 616,1040,1147,2555,1148,1020, 441, + 249,1075,2556,2557,2558, 466, 743,2559,2560,2561, 92, 514, 426, 420, 526,2562, +2563,2564,2565,2566,2567,2568, 185,2569,2570,2571,2572, 776,1530, 658,2573, 362, +2574, 361, 922,1076, 793,2575,2576,2577,2578,2579,2580,1531, 251,2581,2582,2583, +2584,1532, 54, 612, 237,1327,2585,2586, 275, 408, 647, 111,2587,1533,1106, 465, + 3, 458, 9, 38,2588, 107, 110, 890, 209, 26, 737, 498,2589,1534,2590, 431, + 202, 88,1535, 356, 287,1107, 660,1149,2591, 381,1536, 986,1150, 445,1248,1151, + 974,2592,2593, 846,2594, 446, 953, 184,1249,1250, 727,2595, 923, 193, 883,2596, +2597,2598, 102, 324, 539, 817,2599, 421,1041,2600, 832,2601, 94, 175, 197, 406, +2602, 459,2603,2604,2605,2606,2607, 330, 555,2608,2609,2610, 706,1108, 389,2611, +2612,2613,2614, 233,2615, 833, 558, 931, 954,1251,2616,2617,1537, 546,2618,2619, +1009,2620,2621,2622,1538, 690,1328,2623, 955,2624,1539,2625,2626, 772,2627,2628, +2629,2630,2631, 924, 648, 863, 603,2632,2633, 934,1540, 864, 865,2634, 642,1042, + 670,1190,2635,2636,2637,2638, 168,2639, 652, 873, 542,1054,1541,2640,2641,2642, # 512, 256 +) + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euckrprober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euckrprober.py new file mode 100644 index 0000000..345a060 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euckrprober.py @@ -0,0 +1,47 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is mozilla.org code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .mbcharsetprober import MultiByteCharSetProber +from .codingstatemachine import CodingStateMachine +from .chardistribution import EUCKRDistributionAnalysis +from .mbcssm import EUCKR_SM_MODEL + + +class EUCKRProber(MultiByteCharSetProber): + def __init__(self): + super(EUCKRProber, self).__init__() + self.coding_sm = CodingStateMachine(EUCKR_SM_MODEL) + self.distribution_analyzer = EUCKRDistributionAnalysis() + self.reset() + + @property + def charset_name(self): + return "EUC-KR" + + @property + def language(self): + return "Korean" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euctwfreq.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euctwfreq.py new file mode 100644 index 0000000..ed7a995 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euctwfreq.py @@ -0,0 +1,387 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Communicator client code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +# EUCTW frequency table +# Converted from big5 work +# by Taiwan's Mandarin Promotion Council +# <http:#www.edu.tw:81/mandr/> + +# 128 --> 0.42261 +# 256 --> 0.57851 +# 512 --> 0.74851 +# 1024 --> 0.89384 +# 2048 --> 0.97583 +# +# Idea Distribution Ratio = 0.74851/(1-0.74851) =2.98 +# Random Distribution Ration = 512/(5401-512)=0.105 +# +# Typical Distribution Ratio about 25% of Ideal one, still much higher than RDR + +EUCTW_TYPICAL_DISTRIBUTION_RATIO = 0.75 + +# Char to FreqOrder table , +EUCTW_TABLE_SIZE = 5376 + +EUCTW_CHAR_TO_FREQ_ORDER = ( + 1,1800,1506, 255,1431, 198, 9, 82, 6,7310, 177, 202,3615,1256,2808, 110, # 2742 +3735, 33,3241, 261, 76, 44,2113, 16,2931,2184,1176, 659,3868, 26,3404,2643, # 2758 +1198,3869,3313,4060, 410,2211, 302, 590, 361,1963, 8, 204, 58,4296,7311,1931, # 2774 + 63,7312,7313, 317,1614, 75, 222, 159,4061,2412,1480,7314,3500,3068, 224,2809, # 2790 +3616, 3, 10,3870,1471, 29,2774,1135,2852,1939, 873, 130,3242,1123, 312,7315, # 2806 +4297,2051, 507, 252, 682,7316, 142,1914, 124, 206,2932, 34,3501,3173, 64, 604, # 2822 +7317,2494,1976,1977, 155,1990, 645, 641,1606,7318,3405, 337, 72, 406,7319, 80, # 2838 + 630, 238,3174,1509, 263, 939,1092,2644, 756,1440,1094,3406, 449, 69,2969, 591, # 2854 + 179,2095, 471, 115,2034,1843, 60, 50,2970, 134, 806,1868, 734,2035,3407, 180, # 2870 + 995,1607, 156, 537,2893, 688,7320, 319,1305, 779,2144, 514,2374, 298,4298, 359, # 2886 +2495, 90,2707,1338, 663, 11, 906,1099,2545, 20,2436, 182, 532,1716,7321, 732, # 2902 +1376,4062,1311,1420,3175, 25,2312,1056, 113, 399, 382,1949, 242,3408,2467, 529, # 2918 +3243, 475,1447,3617,7322, 117, 21, 656, 810,1297,2295,2329,3502,7323, 126,4063, # 2934 + 706, 456, 150, 613,4299, 71,1118,2036,4064, 145,3069, 85, 835, 486,2114,1246, # 2950 +1426, 428, 727,1285,1015, 800, 106, 623, 303,1281,7324,2127,2354, 347,3736, 221, # 2966 +3503,3110,7325,1955,1153,4065, 83, 296,1199,3070, 192, 624, 93,7326, 822,1897, # 2982 +2810,3111, 795,2064, 991,1554,1542,1592, 27, 43,2853, 859, 139,1456, 860,4300, # 2998 + 437, 712,3871, 164,2392,3112, 695, 211,3017,2096, 195,3872,1608,3504,3505,3618, # 3014 +3873, 234, 811,2971,2097,3874,2229,1441,3506,1615,2375, 668,2076,1638, 305, 228, # 3030 +1664,4301, 467, 415,7327, 262,2098,1593, 239, 108, 300, 200,1033, 512,1247,2077, # 3046 +7328,7329,2173,3176,3619,2673, 593, 845,1062,3244, 88,1723,2037,3875,1950, 212, # 3062 + 266, 152, 149, 468,1898,4066,4302, 77, 187,7330,3018, 37, 5,2972,7331,3876, # 3078 +7332,7333, 39,2517,4303,2894,3177,2078, 55, 148, 74,4304, 545, 483,1474,1029, # 3094 +1665, 217,1869,1531,3113,1104,2645,4067, 24, 172,3507, 900,3877,3508,3509,4305, # 3110 + 32,1408,2811,1312, 329, 487,2355,2247,2708, 784,2674, 4,3019,3314,1427,1788, # 3126 + 188, 109, 499,7334,3620,1717,1789, 888,1217,3020,4306,7335,3510,7336,3315,1520, # 3142 +3621,3878, 196,1034, 775,7337,7338, 929,1815, 249, 439, 38,7339,1063,7340, 794, # 3158 +3879,1435,2296, 46, 178,3245,2065,7341,2376,7342, 214,1709,4307, 804, 35, 707, # 3174 + 324,3622,1601,2546, 140, 459,4068,7343,7344,1365, 839, 272, 978,2257,2572,3409, # 3190 +2128,1363,3623,1423, 697, 100,3071, 48, 70,1231, 495,3114,2193,7345,1294,7346, # 3206 +2079, 462, 586,1042,3246, 853, 256, 988, 185,2377,3410,1698, 434,1084,7347,3411, # 3222 + 314,2615,2775,4308,2330,2331, 569,2280, 637,1816,2518, 757,1162,1878,1616,3412, # 3238 + 287,1577,2115, 768,4309,1671,2854,3511,2519,1321,3737, 909,2413,7348,4069, 933, # 3254 +3738,7349,2052,2356,1222,4310, 765,2414,1322, 786,4311,7350,1919,1462,1677,2895, # 3270 +1699,7351,4312,1424,2437,3115,3624,2590,3316,1774,1940,3413,3880,4070, 309,1369, # 3286 +1130,2812, 364,2230,1653,1299,3881,3512,3882,3883,2646, 525,1085,3021, 902,2000, # 3302 +1475, 964,4313, 421,1844,1415,1057,2281, 940,1364,3116, 376,4314,4315,1381, 7, # 3318 +2520, 983,2378, 336,1710,2675,1845, 321,3414, 559,1131,3022,2742,1808,1132,1313, # 3334 + 265,1481,1857,7352, 352,1203,2813,3247, 167,1089, 420,2814, 776, 792,1724,3513, # 3350 +4071,2438,3248,7353,4072,7354, 446, 229, 333,2743, 901,3739,1200,1557,4316,2647, # 3366 +1920, 395,2744,2676,3740,4073,1835, 125, 916,3178,2616,4317,7355,7356,3741,7357, # 3382 +7358,7359,4318,3117,3625,1133,2547,1757,3415,1510,2313,1409,3514,7360,2145, 438, # 3398 +2591,2896,2379,3317,1068, 958,3023, 461, 311,2855,2677,4074,1915,3179,4075,1978, # 3414 + 383, 750,2745,2617,4076, 274, 539, 385,1278,1442,7361,1154,1964, 384, 561, 210, # 3430 + 98,1295,2548,3515,7362,1711,2415,1482,3416,3884,2897,1257, 129,7363,3742, 642, # 3446 + 523,2776,2777,2648,7364, 141,2231,1333, 68, 176, 441, 876, 907,4077, 603,2592, # 3462 + 710, 171,3417, 404, 549, 18,3118,2393,1410,3626,1666,7365,3516,4319,2898,4320, # 3478 +7366,2973, 368,7367, 146, 366, 99, 871,3627,1543, 748, 807,1586,1185, 22,2258, # 3494 + 379,3743,3180,7368,3181, 505,1941,2618,1991,1382,2314,7369, 380,2357, 218, 702, # 3510 +1817,1248,3418,3024,3517,3318,3249,7370,2974,3628, 930,3250,3744,7371, 59,7372, # 3526 + 585, 601,4078, 497,3419,1112,1314,4321,1801,7373,1223,1472,2174,7374, 749,1836, # 3542 + 690,1899,3745,1772,3885,1476, 429,1043,1790,2232,2116, 917,4079, 447,1086,1629, # 3558 +7375, 556,7376,7377,2020,1654, 844,1090, 105, 550, 966,1758,2815,1008,1782, 686, # 3574 +1095,7378,2282, 793,1602,7379,3518,2593,4322,4080,2933,2297,4323,3746, 980,2496, # 3590 + 544, 353, 527,4324, 908,2678,2899,7380, 381,2619,1942,1348,7381,1341,1252, 560, # 3606 +3072,7382,3420,2856,7383,2053, 973, 886,2080, 143,4325,7384,7385, 157,3886, 496, # 3622 +4081, 57, 840, 540,2038,4326,4327,3421,2117,1445, 970,2259,1748,1965,2081,4082, # 3638 +3119,1234,1775,3251,2816,3629, 773,1206,2129,1066,2039,1326,3887,1738,1725,4083, # 3654 + 279,3120, 51,1544,2594, 423,1578,2130,2066, 173,4328,1879,7386,7387,1583, 264, # 3670 + 610,3630,4329,2439, 280, 154,7388,7389,7390,1739, 338,1282,3073, 693,2857,1411, # 3686 +1074,3747,2440,7391,4330,7392,7393,1240, 952,2394,7394,2900,1538,2679, 685,1483, # 3702 +4084,2468,1436, 953,4085,2054,4331, 671,2395, 79,4086,2441,3252, 608, 567,2680, # 3718 +3422,4087,4088,1691, 393,1261,1791,2396,7395,4332,7396,7397,7398,7399,1383,1672, # 3734 +3748,3182,1464, 522,1119, 661,1150, 216, 675,4333,3888,1432,3519, 609,4334,2681, # 3750 +2397,7400,7401,7402,4089,3025, 0,7403,2469, 315, 231,2442, 301,3319,4335,2380, # 3766 +7404, 233,4090,3631,1818,4336,4337,7405, 96,1776,1315,2082,7406, 257,7407,1809, # 3782 +3632,2709,1139,1819,4091,2021,1124,2163,2778,1777,2649,7408,3074, 363,1655,3183, # 3798 +7409,2975,7410,7411,7412,3889,1567,3890, 718, 103,3184, 849,1443, 341,3320,2934, # 3814 +1484,7413,1712, 127, 67, 339,4092,2398, 679,1412, 821,7414,7415, 834, 738, 351, # 3830 +2976,2146, 846, 235,1497,1880, 418,1992,3749,2710, 186,1100,2147,2746,3520,1545, # 3846 +1355,2935,2858,1377, 583,3891,4093,2573,2977,7416,1298,3633,1078,2549,3634,2358, # 3862 + 78,3750,3751, 267,1289,2099,2001,1594,4094, 348, 369,1274,2194,2175,1837,4338, # 3878 +1820,2817,3635,2747,2283,2002,4339,2936,2748, 144,3321, 882,4340,3892,2749,3423, # 3894 +4341,2901,7417,4095,1726, 320,7418,3893,3026, 788,2978,7419,2818,1773,1327,2859, # 3910 +3894,2819,7420,1306,4342,2003,1700,3752,3521,2359,2650, 787,2022, 506, 824,3636, # 3926 + 534, 323,4343,1044,3322,2023,1900, 946,3424,7421,1778,1500,1678,7422,1881,4344, # 3942 + 165, 243,4345,3637,2521, 123, 683,4096, 764,4346, 36,3895,1792, 589,2902, 816, # 3958 + 626,1667,3027,2233,1639,1555,1622,3753,3896,7423,3897,2860,1370,1228,1932, 891, # 3974 +2083,2903, 304,4097,7424, 292,2979,2711,3522, 691,2100,4098,1115,4347, 118, 662, # 3990 +7425, 611,1156, 854,2381,1316,2861, 2, 386, 515,2904,7426,7427,3253, 868,2234, # 4006 +1486, 855,2651, 785,2212,3028,7428,1040,3185,3523,7429,3121, 448,7430,1525,7431, # 4022 +2164,4348,7432,3754,7433,4099,2820,3524,3122, 503, 818,3898,3123,1568, 814, 676, # 4038 +1444, 306,1749,7434,3755,1416,1030, 197,1428, 805,2821,1501,4349,7435,7436,7437, # 4054 +1993,7438,4350,7439,7440,2195, 13,2779,3638,2980,3124,1229,1916,7441,3756,2131, # 4070 +7442,4100,4351,2399,3525,7443,2213,1511,1727,1120,7444,7445, 646,3757,2443, 307, # 4086 +7446,7447,1595,3186,7448,7449,7450,3639,1113,1356,3899,1465,2522,2523,7451, 519, # 4102 +7452, 128,2132, 92,2284,1979,7453,3900,1512, 342,3125,2196,7454,2780,2214,1980, # 4118 +3323,7455, 290,1656,1317, 789, 827,2360,7456,3758,4352, 562, 581,3901,7457, 401, # 4134 +4353,2248, 94,4354,1399,2781,7458,1463,2024,4355,3187,1943,7459, 828,1105,4101, # 4150 +1262,1394,7460,4102, 605,4356,7461,1783,2862,7462,2822, 819,2101, 578,2197,2937, # 4166 +7463,1502, 436,3254,4103,3255,2823,3902,2905,3425,3426,7464,2712,2315,7465,7466, # 4182 +2332,2067, 23,4357, 193, 826,3759,2102, 699,1630,4104,3075, 390,1793,1064,3526, # 4198 +7467,1579,3076,3077,1400,7468,4105,1838,1640,2863,7469,4358,4359, 137,4106, 598, # 4214 +3078,1966, 780, 104, 974,2938,7470, 278, 899, 253, 402, 572, 504, 493,1339,7471, # 4230 +3903,1275,4360,2574,2550,7472,3640,3029,3079,2249, 565,1334,2713, 863, 41,7473, # 4246 +7474,4361,7475,1657,2333, 19, 463,2750,4107, 606,7476,2981,3256,1087,2084,1323, # 4262 +2652,2982,7477,1631,1623,1750,4108,2682,7478,2864, 791,2714,2653,2334, 232,2416, # 4278 +7479,2983,1498,7480,2654,2620, 755,1366,3641,3257,3126,2025,1609, 119,1917,3427, # 4294 + 862,1026,4109,7481,3904,3760,4362,3905,4363,2260,1951,2470,7482,1125, 817,4110, # 4310 +4111,3906,1513,1766,2040,1487,4112,3030,3258,2824,3761,3127,7483,7484,1507,7485, # 4326 +2683, 733, 40,1632,1106,2865, 345,4113, 841,2524, 230,4364,2984,1846,3259,3428, # 4342 +7486,1263, 986,3429,7487, 735, 879, 254,1137, 857, 622,1300,1180,1388,1562,3907, # 4358 +3908,2939, 967,2751,2655,1349, 592,2133,1692,3324,2985,1994,4114,1679,3909,1901, # 4374 +2185,7488, 739,3642,2715,1296,1290,7489,4115,2198,2199,1921,1563,2595,2551,1870, # 4390 +2752,2986,7490, 435,7491, 343,1108, 596, 17,1751,4365,2235,3430,3643,7492,4366, # 4406 + 294,3527,2940,1693, 477, 979, 281,2041,3528, 643,2042,3644,2621,2782,2261,1031, # 4422 +2335,2134,2298,3529,4367, 367,1249,2552,7493,3530,7494,4368,1283,3325,2004, 240, # 4438 +1762,3326,4369,4370, 836,1069,3128, 474,7495,2148,2525, 268,3531,7496,3188,1521, # 4454 +1284,7497,1658,1546,4116,7498,3532,3533,7499,4117,3327,2684,1685,4118, 961,1673, # 4470 +2622, 190,2005,2200,3762,4371,4372,7500, 570,2497,3645,1490,7501,4373,2623,3260, # 4486 +1956,4374, 584,1514, 396,1045,1944,7502,4375,1967,2444,7503,7504,4376,3910, 619, # 4502 +7505,3129,3261, 215,2006,2783,2553,3189,4377,3190,4378, 763,4119,3763,4379,7506, # 4518 +7507,1957,1767,2941,3328,3646,1174, 452,1477,4380,3329,3130,7508,2825,1253,2382, # 4534 +2186,1091,2285,4120, 492,7509, 638,1169,1824,2135,1752,3911, 648, 926,1021,1324, # 4550 +4381, 520,4382, 997, 847,1007, 892,4383,3764,2262,1871,3647,7510,2400,1784,4384, # 4566 +1952,2942,3080,3191,1728,4121,2043,3648,4385,2007,1701,3131,1551, 30,2263,4122, # 4582 +7511,2026,4386,3534,7512, 501,7513,4123, 594,3431,2165,1821,3535,3432,3536,3192, # 4598 + 829,2826,4124,7514,1680,3132,1225,4125,7515,3262,4387,4126,3133,2336,7516,4388, # 4614 +4127,7517,3912,3913,7518,1847,2383,2596,3330,7519,4389, 374,3914, 652,4128,4129, # 4630 + 375,1140, 798,7520,7521,7522,2361,4390,2264, 546,1659, 138,3031,2445,4391,7523, # 4646 +2250, 612,1848, 910, 796,3765,1740,1371, 825,3766,3767,7524,2906,2554,7525, 692, # 4662 + 444,3032,2624, 801,4392,4130,7526,1491, 244,1053,3033,4131,4132, 340,7527,3915, # 4678 +1041,2987, 293,1168, 87,1357,7528,1539, 959,7529,2236, 721, 694,4133,3768, 219, # 4694 +1478, 644,1417,3331,2656,1413,1401,1335,1389,3916,7530,7531,2988,2362,3134,1825, # 4710 + 730,1515, 184,2827, 66,4393,7532,1660,2943, 246,3332, 378,1457, 226,3433, 975, # 4726 +3917,2944,1264,3537, 674, 696,7533, 163,7534,1141,2417,2166, 713,3538,3333,4394, # 4742 +3918,7535,7536,1186, 15,7537,1079,1070,7538,1522,3193,3539, 276,1050,2716, 758, # 4758 +1126, 653,2945,3263,7539,2337, 889,3540,3919,3081,2989, 903,1250,4395,3920,3434, # 4774 +3541,1342,1681,1718, 766,3264, 286, 89,2946,3649,7540,1713,7541,2597,3334,2990, # 4790 +7542,2947,2215,3194,2866,7543,4396,2498,2526, 181, 387,1075,3921, 731,2187,3335, # 4806 +7544,3265, 310, 313,3435,2299, 770,4134, 54,3034, 189,4397,3082,3769,3922,7545, # 4822 +1230,1617,1849, 355,3542,4135,4398,3336, 111,4136,3650,1350,3135,3436,3035,4137, # 4838 +2149,3266,3543,7546,2784,3923,3924,2991, 722,2008,7547,1071, 247,1207,2338,2471, # 4854 +1378,4399,2009, 864,1437,1214,4400, 373,3770,1142,2216, 667,4401, 442,2753,2555, # 4870 +3771,3925,1968,4138,3267,1839, 837, 170,1107, 934,1336,1882,7548,7549,2118,4139, # 4886 +2828, 743,1569,7550,4402,4140, 582,2384,1418,3437,7551,1802,7552, 357,1395,1729, # 4902 +3651,3268,2418,1564,2237,7553,3083,3772,1633,4403,1114,2085,4141,1532,7554, 482, # 4918 +2446,4404,7555,7556,1492, 833,1466,7557,2717,3544,1641,2829,7558,1526,1272,3652, # 4934 +4142,1686,1794, 416,2556,1902,1953,1803,7559,3773,2785,3774,1159,2316,7560,2867, # 4950 +4405,1610,1584,3036,2419,2754, 443,3269,1163,3136,7561,7562,3926,7563,4143,2499, # 4966 +3037,4406,3927,3137,2103,1647,3545,2010,1872,4144,7564,4145, 431,3438,7565, 250, # 4982 + 97, 81,4146,7566,1648,1850,1558, 160, 848,7567, 866, 740,1694,7568,2201,2830, # 4998 +3195,4147,4407,3653,1687, 950,2472, 426, 469,3196,3654,3655,3928,7569,7570,1188, # 5014 + 424,1995, 861,3546,4148,3775,2202,2685, 168,1235,3547,4149,7571,2086,1674,4408, # 5030 +3337,3270, 220,2557,1009,7572,3776, 670,2992, 332,1208, 717,7573,7574,3548,2447, # 5046 +3929,3338,7575, 513,7576,1209,2868,3339,3138,4409,1080,7577,7578,7579,7580,2527, # 5062 +3656,3549, 815,1587,3930,3931,7581,3550,3439,3777,1254,4410,1328,3038,1390,3932, # 5078 +1741,3933,3778,3934,7582, 236,3779,2448,3271,7583,7584,3657,3780,1273,3781,4411, # 5094 +7585, 308,7586,4412, 245,4413,1851,2473,1307,2575, 430, 715,2136,2449,7587, 270, # 5110 + 199,2869,3935,7588,3551,2718,1753, 761,1754, 725,1661,1840,4414,3440,3658,7589, # 5126 +7590, 587, 14,3272, 227,2598, 326, 480,2265, 943,2755,3552, 291, 650,1883,7591, # 5142 +1702,1226, 102,1547, 62,3441, 904,4415,3442,1164,4150,7592,7593,1224,1548,2756, # 5158 + 391, 498,1493,7594,1386,1419,7595,2055,1177,4416, 813, 880,1081,2363, 566,1145, # 5174 +4417,2286,1001,1035,2558,2599,2238, 394,1286,7596,7597,2068,7598, 86,1494,1730, # 5190 +3936, 491,1588, 745, 897,2948, 843,3340,3937,2757,2870,3273,1768, 998,2217,2069, # 5206 + 397,1826,1195,1969,3659,2993,3341, 284,7599,3782,2500,2137,2119,1903,7600,3938, # 5222 +2150,3939,4151,1036,3443,1904, 114,2559,4152, 209,1527,7601,7602,2949,2831,2625, # 5238 +2385,2719,3139, 812,2560,7603,3274,7604,1559, 737,1884,3660,1210, 885, 28,2686, # 5254 +3553,3783,7605,4153,1004,1779,4418,7606, 346,1981,2218,2687,4419,3784,1742, 797, # 5270 +1642,3940,1933,1072,1384,2151, 896,3941,3275,3661,3197,2871,3554,7607,2561,1958, # 5286 +4420,2450,1785,7608,7609,7610,3942,4154,1005,1308,3662,4155,2720,4421,4422,1528, # 5302 +2600, 161,1178,4156,1982, 987,4423,1101,4157, 631,3943,1157,3198,2420,1343,1241, # 5318 +1016,2239,2562, 372, 877,2339,2501,1160, 555,1934, 911,3944,7611, 466,1170, 169, # 5334 +1051,2907,2688,3663,2474,2994,1182,2011,2563,1251,2626,7612, 992,2340,3444,1540, # 5350 +2721,1201,2070,2401,1996,2475,7613,4424, 528,1922,2188,1503,1873,1570,2364,3342, # 5366 +3276,7614, 557,1073,7615,1827,3445,2087,2266,3140,3039,3084, 767,3085,2786,4425, # 5382 +1006,4158,4426,2341,1267,2176,3664,3199, 778,3945,3200,2722,1597,2657,7616,4427, # 5398 +7617,3446,7618,7619,7620,3277,2689,1433,3278, 131, 95,1504,3946, 723,4159,3141, # 5414 +1841,3555,2758,2189,3947,2027,2104,3665,7621,2995,3948,1218,7622,3343,3201,3949, # 5430 +4160,2576, 248,1634,3785, 912,7623,2832,3666,3040,3786, 654, 53,7624,2996,7625, # 5446 +1688,4428, 777,3447,1032,3950,1425,7626, 191, 820,2120,2833, 971,4429, 931,3202, # 5462 + 135, 664, 783,3787,1997, 772,2908,1935,3951,3788,4430,2909,3203, 282,2723, 640, # 5478 +1372,3448,1127, 922, 325,3344,7627,7628, 711,2044,7629,7630,3952,2219,2787,1936, # 5494 +3953,3345,2220,2251,3789,2300,7631,4431,3790,1258,3279,3954,3204,2138,2950,3955, # 5510 +3956,7632,2221, 258,3205,4432, 101,1227,7633,3280,1755,7634,1391,3281,7635,2910, # 5526 +2056, 893,7636,7637,7638,1402,4161,2342,7639,7640,3206,3556,7641,7642, 878,1325, # 5542 +1780,2788,4433, 259,1385,2577, 744,1183,2267,4434,7643,3957,2502,7644, 684,1024, # 5558 +4162,7645, 472,3557,3449,1165,3282,3958,3959, 322,2152, 881, 455,1695,1152,1340, # 5574 + 660, 554,2153,4435,1058,4436,4163, 830,1065,3346,3960,4437,1923,7646,1703,1918, # 5590 +7647, 932,2268, 122,7648,4438, 947, 677,7649,3791,2627, 297,1905,1924,2269,4439, # 5606 +2317,3283,7650,7651,4164,7652,4165, 84,4166, 112, 989,7653, 547,1059,3961, 701, # 5622 +3558,1019,7654,4167,7655,3450, 942, 639, 457,2301,2451, 993,2951, 407, 851, 494, # 5638 +4440,3347, 927,7656,1237,7657,2421,3348, 573,4168, 680, 921,2911,1279,1874, 285, # 5654 + 790,1448,1983, 719,2167,7658,7659,4441,3962,3963,1649,7660,1541, 563,7661,1077, # 5670 +7662,3349,3041,3451, 511,2997,3964,3965,3667,3966,1268,2564,3350,3207,4442,4443, # 5686 +7663, 535,1048,1276,1189,2912,2028,3142,1438,1373,2834,2952,1134,2012,7664,4169, # 5702 +1238,2578,3086,1259,7665, 700,7666,2953,3143,3668,4170,7667,4171,1146,1875,1906, # 5718 +4444,2601,3967, 781,2422, 132,1589, 203, 147, 273,2789,2402, 898,1786,2154,3968, # 5734 +3969,7668,3792,2790,7669,7670,4445,4446,7671,3208,7672,1635,3793, 965,7673,1804, # 5750 +2690,1516,3559,1121,1082,1329,3284,3970,1449,3794, 65,1128,2835,2913,2759,1590, # 5766 +3795,7674,7675, 12,2658, 45, 976,2579,3144,4447, 517,2528,1013,1037,3209,7676, # 5782 +3796,2836,7677,3797,7678,3452,7679,2602, 614,1998,2318,3798,3087,2724,2628,7680, # 5798 +2580,4172, 599,1269,7681,1810,3669,7682,2691,3088, 759,1060, 489,1805,3351,3285, # 5814 +1358,7683,7684,2386,1387,1215,2629,2252, 490,7685,7686,4173,1759,2387,2343,7687, # 5830 +4448,3799,1907,3971,2630,1806,3210,4449,3453,3286,2760,2344, 874,7688,7689,3454, # 5846 +3670,1858, 91,2914,3671,3042,3800,4450,7690,3145,3972,2659,7691,3455,1202,1403, # 5862 +3801,2954,2529,1517,2503,4451,3456,2504,7692,4452,7693,2692,1885,1495,1731,3973, # 5878 +2365,4453,7694,2029,7695,7696,3974,2693,1216, 237,2581,4174,2319,3975,3802,4454, # 5894 +4455,2694,3560,3457, 445,4456,7697,7698,7699,7700,2761, 61,3976,3672,1822,3977, # 5910 +7701, 687,2045, 935, 925, 405,2660, 703,1096,1859,2725,4457,3978,1876,1367,2695, # 5926 +3352, 918,2105,1781,2476, 334,3287,1611,1093,4458, 564,3146,3458,3673,3353, 945, # 5942 +2631,2057,4459,7702,1925, 872,4175,7703,3459,2696,3089, 349,4176,3674,3979,4460, # 5958 +3803,4177,3675,2155,3980,4461,4462,4178,4463,2403,2046, 782,3981, 400, 251,4179, # 5974 +1624,7704,7705, 277,3676, 299,1265, 476,1191,3804,2121,4180,4181,1109, 205,7706, # 5990 +2582,1000,2156,3561,1860,7707,7708,7709,4464,7710,4465,2565, 107,2477,2157,3982, # 6006 +3460,3147,7711,1533, 541,1301, 158, 753,4182,2872,3562,7712,1696, 370,1088,4183, # 6022 +4466,3563, 579, 327, 440, 162,2240, 269,1937,1374,3461, 968,3043, 56,1396,3090, # 6038 +2106,3288,3354,7713,1926,2158,4467,2998,7714,3564,7715,7716,3677,4468,2478,7717, # 6054 +2791,7718,1650,4469,7719,2603,7720,7721,3983,2661,3355,1149,3356,3984,3805,3985, # 6070 +7722,1076, 49,7723, 951,3211,3289,3290, 450,2837, 920,7724,1811,2792,2366,4184, # 6086 +1908,1138,2367,3806,3462,7725,3212,4470,1909,1147,1518,2423,4471,3807,7726,4472, # 6102 +2388,2604, 260,1795,3213,7727,7728,3808,3291, 708,7729,3565,1704,7730,3566,1351, # 6118 +1618,3357,2999,1886, 944,4185,3358,4186,3044,3359,4187,7731,3678, 422, 413,1714, # 6134 +3292, 500,2058,2345,4188,2479,7732,1344,1910, 954,7733,1668,7734,7735,3986,2404, # 6150 +4189,3567,3809,4190,7736,2302,1318,2505,3091, 133,3092,2873,4473, 629, 31,2838, # 6166 +2697,3810,4474, 850, 949,4475,3987,2955,1732,2088,4191,1496,1852,7737,3988, 620, # 6182 +3214, 981,1242,3679,3360,1619,3680,1643,3293,2139,2452,1970,1719,3463,2168,7738, # 6198 +3215,7739,7740,3361,1828,7741,1277,4476,1565,2047,7742,1636,3568,3093,7743, 869, # 6214 +2839, 655,3811,3812,3094,3989,3000,3813,1310,3569,4477,7744,7745,7746,1733, 558, # 6230 +4478,3681, 335,1549,3045,1756,4192,3682,1945,3464,1829,1291,1192, 470,2726,2107, # 6246 +2793, 913,1054,3990,7747,1027,7748,3046,3991,4479, 982,2662,3362,3148,3465,3216, # 6262 +3217,1946,2794,7749, 571,4480,7750,1830,7751,3570,2583,1523,2424,7752,2089, 984, # 6278 +4481,3683,1959,7753,3684, 852, 923,2795,3466,3685, 969,1519, 999,2048,2320,1705, # 6294 +7754,3095, 615,1662, 151, 597,3992,2405,2321,1049, 275,4482,3686,4193, 568,3687, # 6310 +3571,2480,4194,3688,7755,2425,2270, 409,3218,7756,1566,2874,3467,1002, 769,2840, # 6326 + 194,2090,3149,3689,2222,3294,4195, 628,1505,7757,7758,1763,2177,3001,3993, 521, # 6342 +1161,2584,1787,2203,2406,4483,3994,1625,4196,4197, 412, 42,3096, 464,7759,2632, # 6358 +4484,3363,1760,1571,2875,3468,2530,1219,2204,3814,2633,2140,2368,4485,4486,3295, # 6374 +1651,3364,3572,7760,7761,3573,2481,3469,7762,3690,7763,7764,2271,2091, 460,7765, # 6390 +4487,7766,3002, 962, 588,3574, 289,3219,2634,1116, 52,7767,3047,1796,7768,7769, # 6406 +7770,1467,7771,1598,1143,3691,4198,1984,1734,1067,4488,1280,3365, 465,4489,1572, # 6422 + 510,7772,1927,2241,1812,1644,3575,7773,4490,3692,7774,7775,2663,1573,1534,7776, # 6438 +7777,4199, 536,1807,1761,3470,3815,3150,2635,7778,7779,7780,4491,3471,2915,1911, # 6454 +2796,7781,3296,1122, 377,3220,7782, 360,7783,7784,4200,1529, 551,7785,2059,3693, # 6470 +1769,2426,7786,2916,4201,3297,3097,2322,2108,2030,4492,1404, 136,1468,1479, 672, # 6486 +1171,3221,2303, 271,3151,7787,2762,7788,2049, 678,2727, 865,1947,4493,7789,2013, # 6502 +3995,2956,7790,2728,2223,1397,3048,3694,4494,4495,1735,2917,3366,3576,7791,3816, # 6518 + 509,2841,2453,2876,3817,7792,7793,3152,3153,4496,4202,2531,4497,2304,1166,1010, # 6534 + 552, 681,1887,7794,7795,2957,2958,3996,1287,1596,1861,3154, 358, 453, 736, 175, # 6550 + 478,1117, 905,1167,1097,7796,1853,1530,7797,1706,7798,2178,3472,2287,3695,3473, # 6566 +3577,4203,2092,4204,7799,3367,1193,2482,4205,1458,2190,2205,1862,1888,1421,3298, # 6582 +2918,3049,2179,3474, 595,2122,7800,3997,7801,7802,4206,1707,2636, 223,3696,1359, # 6598 + 751,3098, 183,3475,7803,2797,3003, 419,2369, 633, 704,3818,2389, 241,7804,7805, # 6614 +7806, 838,3004,3697,2272,2763,2454,3819,1938,2050,3998,1309,3099,2242,1181,7807, # 6630 +1136,2206,3820,2370,1446,4207,2305,4498,7808,7809,4208,1055,2605, 484,3698,7810, # 6646 +3999, 625,4209,2273,3368,1499,4210,4000,7811,4001,4211,3222,2274,2275,3476,7812, # 6662 +7813,2764, 808,2606,3699,3369,4002,4212,3100,2532, 526,3370,3821,4213, 955,7814, # 6678 +1620,4214,2637,2427,7815,1429,3700,1669,1831, 994, 928,7816,3578,1260,7817,7818, # 6694 +7819,1948,2288, 741,2919,1626,4215,2729,2455, 867,1184, 362,3371,1392,7820,7821, # 6710 +4003,4216,1770,1736,3223,2920,4499,4500,1928,2698,1459,1158,7822,3050,3372,2877, # 6726 +1292,1929,2506,2842,3701,1985,1187,2071,2014,2607,4217,7823,2566,2507,2169,3702, # 6742 +2483,3299,7824,3703,4501,7825,7826, 666,1003,3005,1022,3579,4218,7827,4502,1813, # 6758 +2253, 574,3822,1603, 295,1535, 705,3823,4219, 283, 858, 417,7828,7829,3224,4503, # 6774 +4504,3051,1220,1889,1046,2276,2456,4004,1393,1599, 689,2567, 388,4220,7830,2484, # 6790 + 802,7831,2798,3824,2060,1405,2254,7832,4505,3825,2109,1052,1345,3225,1585,7833, # 6806 + 809,7834,7835,7836, 575,2730,3477, 956,1552,1469,1144,2323,7837,2324,1560,2457, # 6822 +3580,3226,4005, 616,2207,3155,2180,2289,7838,1832,7839,3478,4506,7840,1319,3704, # 6838 +3705,1211,3581,1023,3227,1293,2799,7841,7842,7843,3826, 607,2306,3827, 762,2878, # 6854 +1439,4221,1360,7844,1485,3052,7845,4507,1038,4222,1450,2061,2638,4223,1379,4508, # 6870 +2585,7846,7847,4224,1352,1414,2325,2921,1172,7848,7849,3828,3829,7850,1797,1451, # 6886 +7851,7852,7853,7854,2922,4006,4007,2485,2346, 411,4008,4009,3582,3300,3101,4509, # 6902 +1561,2664,1452,4010,1375,7855,7856, 47,2959, 316,7857,1406,1591,2923,3156,7858, # 6918 +1025,2141,3102,3157, 354,2731, 884,2224,4225,2407, 508,3706, 726,3583, 996,2428, # 6934 +3584, 729,7859, 392,2191,1453,4011,4510,3707,7860,7861,2458,3585,2608,1675,2800, # 6950 + 919,2347,2960,2348,1270,4511,4012, 73,7862,7863, 647,7864,3228,2843,2255,1550, # 6966 +1346,3006,7865,1332, 883,3479,7866,7867,7868,7869,3301,2765,7870,1212, 831,1347, # 6982 +4226,4512,2326,3830,1863,3053, 720,3831,4513,4514,3832,7871,4227,7872,7873,4515, # 6998 +7874,7875,1798,4516,3708,2609,4517,3586,1645,2371,7876,7877,2924, 669,2208,2665, # 7014 +2429,7878,2879,7879,7880,1028,3229,7881,4228,2408,7882,2256,1353,7883,7884,4518, # 7030 +3158, 518,7885,4013,7886,4229,1960,7887,2142,4230,7888,7889,3007,2349,2350,3833, # 7046 + 516,1833,1454,4014,2699,4231,4519,2225,2610,1971,1129,3587,7890,2766,7891,2961, # 7062 +1422, 577,1470,3008,1524,3373,7892,7893, 432,4232,3054,3480,7894,2586,1455,2508, # 7078 +2226,1972,1175,7895,1020,2732,4015,3481,4520,7896,2733,7897,1743,1361,3055,3482, # 7094 +2639,4016,4233,4521,2290, 895, 924,4234,2170, 331,2243,3056, 166,1627,3057,1098, # 7110 +7898,1232,2880,2227,3374,4522, 657, 403,1196,2372, 542,3709,3375,1600,4235,3483, # 7126 +7899,4523,2767,3230, 576, 530,1362,7900,4524,2533,2666,3710,4017,7901, 842,3834, # 7142 +7902,2801,2031,1014,4018, 213,2700,3376, 665, 621,4236,7903,3711,2925,2430,7904, # 7158 +2431,3302,3588,3377,7905,4237,2534,4238,4525,3589,1682,4239,3484,1380,7906, 724, # 7174 +2277, 600,1670,7907,1337,1233,4526,3103,2244,7908,1621,4527,7909, 651,4240,7910, # 7190 +1612,4241,2611,7911,2844,7912,2734,2307,3058,7913, 716,2459,3059, 174,1255,2701, # 7206 +4019,3590, 548,1320,1398, 728,4020,1574,7914,1890,1197,3060,4021,7915,3061,3062, # 7222 +3712,3591,3713, 747,7916, 635,4242,4528,7917,7918,7919,4243,7920,7921,4529,7922, # 7238 +3378,4530,2432, 451,7923,3714,2535,2072,4244,2735,4245,4022,7924,1764,4531,7925, # 7254 +4246, 350,7926,2278,2390,2486,7927,4247,4023,2245,1434,4024, 488,4532, 458,4248, # 7270 +4025,3715, 771,1330,2391,3835,2568,3159,2159,2409,1553,2667,3160,4249,7928,2487, # 7286 +2881,2612,1720,2702,4250,3379,4533,7929,2536,4251,7930,3231,4252,2768,7931,2015, # 7302 +2736,7932,1155,1017,3716,3836,7933,3303,2308, 201,1864,4253,1430,7934,4026,7935, # 7318 +7936,7937,7938,7939,4254,1604,7940, 414,1865, 371,2587,4534,4535,3485,2016,3104, # 7334 +4536,1708, 960,4255, 887, 389,2171,1536,1663,1721,7941,2228,4027,2351,2926,1580, # 7350 +7942,7943,7944,1744,7945,2537,4537,4538,7946,4539,7947,2073,7948,7949,3592,3380, # 7366 +2882,4256,7950,4257,2640,3381,2802, 673,2703,2460, 709,3486,4028,3593,4258,7951, # 7382 +1148, 502, 634,7952,7953,1204,4540,3594,1575,4541,2613,3717,7954,3718,3105, 948, # 7398 +3232, 121,1745,3837,1110,7955,4259,3063,2509,3009,4029,3719,1151,1771,3838,1488, # 7414 +4030,1986,7956,2433,3487,7957,7958,2093,7959,4260,3839,1213,1407,2803, 531,2737, # 7430 +2538,3233,1011,1537,7960,2769,4261,3106,1061,7961,3720,3721,1866,2883,7962,2017, # 7446 + 120,4262,4263,2062,3595,3234,2309,3840,2668,3382,1954,4542,7963,7964,3488,1047, # 7462 +2704,1266,7965,1368,4543,2845, 649,3383,3841,2539,2738,1102,2846,2669,7966,7967, # 7478 +1999,7968,1111,3596,2962,7969,2488,3842,3597,2804,1854,3384,3722,7970,7971,3385, # 7494 +2410,2884,3304,3235,3598,7972,2569,7973,3599,2805,4031,1460, 856,7974,3600,7975, # 7510 +2885,2963,7976,2886,3843,7977,4264, 632,2510, 875,3844,1697,3845,2291,7978,7979, # 7526 +4544,3010,1239, 580,4545,4265,7980, 914, 936,2074,1190,4032,1039,2123,7981,7982, # 7542 +7983,3386,1473,7984,1354,4266,3846,7985,2172,3064,4033, 915,3305,4267,4268,3306, # 7558 +1605,1834,7986,2739, 398,3601,4269,3847,4034, 328,1912,2847,4035,3848,1331,4270, # 7574 +3011, 937,4271,7987,3602,4036,4037,3387,2160,4546,3388, 524, 742, 538,3065,1012, # 7590 +7988,7989,3849,2461,7990, 658,1103, 225,3850,7991,7992,4547,7993,4548,7994,3236, # 7606 +1243,7995,4038, 963,2246,4549,7996,2705,3603,3161,7997,7998,2588,2327,7999,4550, # 7622 +8000,8001,8002,3489,3307, 957,3389,2540,2032,1930,2927,2462, 870,2018,3604,1746, # 7638 +2770,2771,2434,2463,8003,3851,8004,3723,3107,3724,3490,3390,3725,8005,1179,3066, # 7654 +8006,3162,2373,4272,3726,2541,3163,3108,2740,4039,8007,3391,1556,2542,2292, 977, # 7670 +2887,2033,4040,1205,3392,8008,1765,3393,3164,2124,1271,1689, 714,4551,3491,8009, # 7686 +2328,3852, 533,4273,3605,2181, 617,8010,2464,3308,3492,2310,8011,8012,3165,8013, # 7702 +8014,3853,1987, 618, 427,2641,3493,3394,8015,8016,1244,1690,8017,2806,4274,4552, # 7718 +8018,3494,8019,8020,2279,1576, 473,3606,4275,3395, 972,8021,3607,8022,3067,8023, # 7734 +8024,4553,4554,8025,3727,4041,4042,8026, 153,4555, 356,8027,1891,2888,4276,2143, # 7750 + 408, 803,2352,8028,3854,8029,4277,1646,2570,2511,4556,4557,3855,8030,3856,4278, # 7766 +8031,2411,3396, 752,8032,8033,1961,2964,8034, 746,3012,2465,8035,4279,3728, 698, # 7782 +4558,1892,4280,3608,2543,4559,3609,3857,8036,3166,3397,8037,1823,1302,4043,2706, # 7798 +3858,1973,4281,8038,4282,3167, 823,1303,1288,1236,2848,3495,4044,3398, 774,3859, # 7814 +8039,1581,4560,1304,2849,3860,4561,8040,2435,2161,1083,3237,4283,4045,4284, 344, # 7830 +1173, 288,2311, 454,1683,8041,8042,1461,4562,4046,2589,8043,8044,4563, 985, 894, # 7846 +8045,3399,3168,8046,1913,2928,3729,1988,8047,2110,1974,8048,4047,8049,2571,1194, # 7862 + 425,8050,4564,3169,1245,3730,4285,8051,8052,2850,8053, 636,4565,1855,3861, 760, # 7878 +1799,8054,4286,2209,1508,4566,4048,1893,1684,2293,8055,8056,8057,4287,4288,2210, # 7894 + 479,8058,8059, 832,8060,4049,2489,8061,2965,2490,3731, 990,3109, 627,1814,2642, # 7910 +4289,1582,4290,2125,2111,3496,4567,8062, 799,4291,3170,8063,4568,2112,1737,3013, # 7926 +1018, 543, 754,4292,3309,1676,4569,4570,4050,8064,1489,8065,3497,8066,2614,2889, # 7942 +4051,8067,8068,2966,8069,8070,8071,8072,3171,4571,4572,2182,1722,8073,3238,3239, # 7958 +1842,3610,1715, 481, 365,1975,1856,8074,8075,1962,2491,4573,8076,2126,3611,3240, # 7974 + 433,1894,2063,2075,8077, 602,2741,8078,8079,8080,8081,8082,3014,1628,3400,8083, # 7990 +3172,4574,4052,2890,4575,2512,8084,2544,2772,8085,8086,8087,3310,4576,2891,8088, # 8006 +4577,8089,2851,4578,4579,1221,2967,4053,2513,8090,8091,8092,1867,1989,8093,8094, # 8022 +8095,1895,8096,8097,4580,1896,4054, 318,8098,2094,4055,4293,8099,8100, 485,8101, # 8038 + 938,3862, 553,2670, 116,8102,3863,3612,8103,3498,2671,2773,3401,3311,2807,8104, # 8054 +3613,2929,4056,1747,2930,2968,8105,8106, 207,8107,8108,2672,4581,2514,8109,3015, # 8070 + 890,3614,3864,8110,1877,3732,3402,8111,2183,2353,3403,1652,8112,8113,8114, 941, # 8086 +2294, 208,3499,4057,2019, 330,4294,3865,2892,2492,3733,4295,8115,8116,8117,8118, # 8102 +) + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euctwprober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euctwprober.py new file mode 100644 index 0000000..35669cc --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/euctwprober.py @@ -0,0 +1,46 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is mozilla.org code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .mbcharsetprober import MultiByteCharSetProber +from .codingstatemachine import CodingStateMachine +from .chardistribution import EUCTWDistributionAnalysis +from .mbcssm import EUCTW_SM_MODEL + +class EUCTWProber(MultiByteCharSetProber): + def __init__(self): + super(EUCTWProber, self).__init__() + self.coding_sm = CodingStateMachine(EUCTW_SM_MODEL) + self.distribution_analyzer = EUCTWDistributionAnalysis() + self.reset() + + @property + def charset_name(self): + return "EUC-TW" + + @property + def language(self): + return "Taiwan" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/gb2312freq.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/gb2312freq.py new file mode 100644 index 0000000..697837b --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/gb2312freq.py @@ -0,0 +1,283 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Communicator client code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +# GB2312 most frequently used character table +# +# Char to FreqOrder table , from hz6763 + +# 512 --> 0.79 -- 0.79 +# 1024 --> 0.92 -- 0.13 +# 2048 --> 0.98 -- 0.06 +# 6768 --> 1.00 -- 0.02 +# +# Ideal Distribution Ratio = 0.79135/(1-0.79135) = 3.79 +# Random Distribution Ration = 512 / (3755 - 512) = 0.157 +# +# Typical Distribution Ratio about 25% of Ideal one, still much higher that RDR + +GB2312_TYPICAL_DISTRIBUTION_RATIO = 0.9 + +GB2312_TABLE_SIZE = 3760 + +GB2312_CHAR_TO_FREQ_ORDER = ( +1671, 749,1443,2364,3924,3807,2330,3921,1704,3463,2691,1511,1515, 572,3191,2205, +2361, 224,2558, 479,1711, 963,3162, 440,4060,1905,2966,2947,3580,2647,3961,3842, +2204, 869,4207, 970,2678,5626,2944,2956,1479,4048, 514,3595, 588,1346,2820,3409, + 249,4088,1746,1873,2047,1774, 581,1813, 358,1174,3590,1014,1561,4844,2245, 670, +1636,3112, 889,1286, 953, 556,2327,3060,1290,3141, 613, 185,3477,1367, 850,3820, +1715,2428,2642,2303,2732,3041,2562,2648,3566,3946,1349, 388,3098,2091,1360,3585, + 152,1687,1539, 738,1559, 59,1232,2925,2267,1388,1249,1741,1679,2960, 151,1566, +1125,1352,4271, 924,4296, 385,3166,4459, 310,1245,2850, 70,3285,2729,3534,3575, +2398,3298,3466,1960,2265, 217,3647, 864,1909,2084,4401,2773,1010,3269,5152, 853, +3051,3121,1244,4251,1895, 364,1499,1540,2313,1180,3655,2268, 562, 715,2417,3061, + 544, 336,3768,2380,1752,4075, 950, 280,2425,4382, 183,2759,3272, 333,4297,2155, +1688,2356,1444,1039,4540, 736,1177,3349,2443,2368,2144,2225, 565, 196,1482,3406, + 927,1335,4147, 692, 878,1311,1653,3911,3622,1378,4200,1840,2969,3149,2126,1816, +2534,1546,2393,2760, 737,2494, 13, 447, 245,2747, 38,2765,2129,2589,1079, 606, + 360, 471,3755,2890, 404, 848, 699,1785,1236, 370,2221,1023,3746,2074,2026,2023, +2388,1581,2119, 812,1141,3091,2536,1519, 804,2053, 406,1596,1090, 784, 548,4414, +1806,2264,2936,1100, 343,4114,5096, 622,3358, 743,3668,1510,1626,5020,3567,2513, +3195,4115,5627,2489,2991, 24,2065,2697,1087,2719, 48,1634, 315, 68, 985,2052, + 198,2239,1347,1107,1439, 597,2366,2172, 871,3307, 919,2487,2790,1867, 236,2570, +1413,3794, 906,3365,3381,1701,1982,1818,1524,2924,1205, 616,2586,2072,2004, 575, + 253,3099, 32,1365,1182, 197,1714,2454,1201, 554,3388,3224,2748, 756,2587, 250, +2567,1507,1517,3529,1922,2761,2337,3416,1961,1677,2452,2238,3153, 615, 911,1506, +1474,2495,1265,1906,2749,3756,3280,2161, 898,2714,1759,3450,2243,2444, 563, 26, +3286,2266,3769,3344,2707,3677, 611,1402, 531,1028,2871,4548,1375, 261,2948, 835, +1190,4134, 353, 840,2684,1900,3082,1435,2109,1207,1674, 329,1872,2781,4055,2686, +2104, 608,3318,2423,2957,2768,1108,3739,3512,3271,3985,2203,1771,3520,1418,2054, +1681,1153, 225,1627,2929, 162,2050,2511,3687,1954, 124,1859,2431,1684,3032,2894, + 585,4805,3969,2869,2704,2088,2032,2095,3656,2635,4362,2209, 256, 518,2042,2105, +3777,3657, 643,2298,1148,1779, 190, 989,3544, 414, 11,2135,2063,2979,1471, 403, +3678, 126, 770,1563, 671,2499,3216,2877, 600,1179, 307,2805,4937,1268,1297,2694, + 252,4032,1448,1494,1331,1394, 127,2256, 222,1647,1035,1481,3056,1915,1048, 873, +3651, 210, 33,1608,2516, 200,1520, 415, 102, 0,3389,1287, 817, 91,3299,2940, + 836,1814, 549,2197,1396,1669,2987,3582,2297,2848,4528,1070, 687, 20,1819, 121, +1552,1364,1461,1968,2617,3540,2824,2083, 177, 948,4938,2291, 110,4549,2066, 648, +3359,1755,2110,2114,4642,4845,1693,3937,3308,1257,1869,2123, 208,1804,3159,2992, +2531,2549,3361,2418,1350,2347,2800,2568,1291,2036,2680, 72, 842,1990, 212,1233, +1154,1586, 75,2027,3410,4900,1823,1337,2710,2676, 728,2810,1522,3026,4995, 157, + 755,1050,4022, 710, 785,1936,2194,2085,1406,2777,2400, 150,1250,4049,1206, 807, +1910, 534, 529,3309,1721,1660, 274, 39,2827, 661,2670,1578, 925,3248,3815,1094, +4278,4901,4252, 41,1150,3747,2572,2227,4501,3658,4902,3813,3357,3617,2884,2258, + 887, 538,4187,3199,1294,2439,3042,2329,2343,2497,1255, 107, 543,1527, 521,3478, +3568, 194,5062, 15, 961,3870,1241,1192,2664, 66,5215,3260,2111,1295,1127,2152, +3805,4135, 901,1164,1976, 398,1278, 530,1460, 748, 904,1054,1966,1426, 53,2909, + 509, 523,2279,1534, 536,1019, 239,1685, 460,2353, 673,1065,2401,3600,4298,2272, +1272,2363, 284,1753,3679,4064,1695, 81, 815,2677,2757,2731,1386, 859, 500,4221, +2190,2566, 757,1006,2519,2068,1166,1455, 337,2654,3203,1863,1682,1914,3025,1252, +1409,1366, 847, 714,2834,2038,3209, 964,2970,1901, 885,2553,1078,1756,3049, 301, +1572,3326, 688,2130,1996,2429,1805,1648,2930,3421,2750,3652,3088, 262,1158,1254, + 389,1641,1812, 526,1719, 923,2073,1073,1902, 468, 489,4625,1140, 857,2375,3070, +3319,2863, 380, 116,1328,2693,1161,2244, 273,1212,1884,2769,3011,1775,1142, 461, +3066,1200,2147,2212, 790, 702,2695,4222,1601,1058, 434,2338,5153,3640, 67,2360, +4099,2502, 618,3472,1329, 416,1132, 830,2782,1807,2653,3211,3510,1662, 192,2124, + 296,3979,1739,1611,3684, 23, 118, 324, 446,1239,1225, 293,2520,3814,3795,2535, +3116, 17,1074, 467,2692,2201, 387,2922, 45,1326,3055,1645,3659,2817, 958, 243, +1903,2320,1339,2825,1784,3289, 356, 576, 865,2315,2381,3377,3916,1088,3122,1713, +1655, 935, 628,4689,1034,1327, 441, 800, 720, 894,1979,2183,1528,5289,2702,1071, +4046,3572,2399,1571,3281, 79, 761,1103, 327, 134, 758,1899,1371,1615, 879, 442, + 215,2605,2579, 173,2048,2485,1057,2975,3317,1097,2253,3801,4263,1403,1650,2946, + 814,4968,3487,1548,2644,1567,1285, 2, 295,2636, 97, 946,3576, 832, 141,4257, +3273, 760,3821,3521,3156,2607, 949,1024,1733,1516,1803,1920,2125,2283,2665,3180, +1501,2064,3560,2171,1592, 803,3518,1416, 732,3897,4258,1363,1362,2458, 119,1427, + 602,1525,2608,1605,1639,3175, 694,3064, 10, 465, 76,2000,4846,4208, 444,3781, +1619,3353,2206,1273,3796, 740,2483, 320,1723,2377,3660,2619,1359,1137,1762,1724, +2345,2842,1850,1862, 912, 821,1866, 612,2625,1735,2573,3369,1093, 844, 89, 937, + 930,1424,3564,2413,2972,1004,3046,3019,2011, 711,3171,1452,4178, 428, 801,1943, + 432, 445,2811, 206,4136,1472, 730, 349, 73, 397,2802,2547, 998,1637,1167, 789, + 396,3217, 154,1218, 716,1120,1780,2819,4826,1931,3334,3762,2139,1215,2627, 552, +3664,3628,3232,1405,2383,3111,1356,2652,3577,3320,3101,1703, 640,1045,1370,1246, +4996, 371,1575,2436,1621,2210, 984,4033,1734,2638, 16,4529, 663,2755,3255,1451, +3917,2257,1253,1955,2234,1263,2951, 214,1229, 617, 485, 359,1831,1969, 473,2310, + 750,2058, 165, 80,2864,2419, 361,4344,2416,2479,1134, 796,3726,1266,2943, 860, +2715, 938, 390,2734,1313,1384, 248, 202, 877,1064,2854, 522,3907, 279,1602, 297, +2357, 395,3740, 137,2075, 944,4089,2584,1267,3802, 62,1533,2285, 178, 176, 780, +2440, 201,3707, 590, 478,1560,4354,2117,1075, 30, 74,4643,4004,1635,1441,2745, + 776,2596, 238,1077,1692,1912,2844, 605, 499,1742,3947, 241,3053, 980,1749, 936, +2640,4511,2582, 515,1543,2162,5322,2892,2993, 890,2148,1924, 665,1827,3581,1032, + 968,3163, 339,1044,1896, 270, 583,1791,1720,4367,1194,3488,3669, 43,2523,1657, + 163,2167, 290,1209,1622,3378, 550, 634,2508,2510, 695,2634,2384,2512,1476,1414, + 220,1469,2341,2138,2852,3183,2900,4939,2865,3502,1211,3680, 854,3227,1299,2976, +3172, 186,2998,1459, 443,1067,3251,1495, 321,1932,3054, 909, 753,1410,1828, 436, +2441,1119,1587,3164,2186,1258, 227, 231,1425,1890,3200,3942, 247, 959, 725,5254, +2741, 577,2158,2079, 929, 120, 174, 838,2813, 591,1115, 417,2024, 40,3240,1536, +1037, 291,4151,2354, 632,1298,2406,2500,3535,1825,1846,3451, 205,1171, 345,4238, + 18,1163, 811, 685,2208,1217, 425,1312,1508,1175,4308,2552,1033, 587,1381,3059, +2984,3482, 340,1316,4023,3972, 792,3176, 519, 777,4690, 918, 933,4130,2981,3741, + 90,3360,2911,2200,5184,4550, 609,3079,2030, 272,3379,2736, 363,3881,1130,1447, + 286, 779, 357,1169,3350,3137,1630,1220,2687,2391, 747,1277,3688,2618,2682,2601, +1156,3196,5290,4034,3102,1689,3596,3128, 874, 219,2783, 798, 508,1843,2461, 269, +1658,1776,1392,1913,2983,3287,2866,2159,2372, 829,4076, 46,4253,2873,1889,1894, + 915,1834,1631,2181,2318, 298, 664,2818,3555,2735, 954,3228,3117, 527,3511,2173, + 681,2712,3033,2247,2346,3467,1652, 155,2164,3382, 113,1994, 450, 899, 494, 994, +1237,2958,1875,2336,1926,3727, 545,1577,1550, 633,3473, 204,1305,3072,2410,1956, +2471, 707,2134, 841,2195,2196,2663,3843,1026,4940, 990,3252,4997, 368,1092, 437, +3212,3258,1933,1829, 675,2977,2893, 412, 943,3723,4644,3294,3283,2230,2373,5154, +2389,2241,2661,2323,1404,2524, 593, 787, 677,3008,1275,2059, 438,2709,2609,2240, +2269,2246,1446, 36,1568,1373,3892,1574,2301,1456,3962, 693,2276,5216,2035,1143, +2720,1919,1797,1811,2763,4137,2597,1830,1699,1488,1198,2090, 424,1694, 312,3634, +3390,4179,3335,2252,1214, 561,1059,3243,2295,2561, 975,5155,2321,2751,3772, 472, +1537,3282,3398,1047,2077,2348,2878,1323,3340,3076, 690,2906, 51, 369, 170,3541, +1060,2187,2688,3670,2541,1083,1683, 928,3918, 459, 109,4427, 599,3744,4286, 143, +2101,2730,2490, 82,1588,3036,2121, 281,1860, 477,4035,1238,2812,3020,2716,3312, +1530,2188,2055,1317, 843, 636,1808,1173,3495, 649, 181,1002, 147,3641,1159,2414, +3750,2289,2795, 813,3123,2610,1136,4368, 5,3391,4541,2174, 420, 429,1728, 754, +1228,2115,2219, 347,2223,2733, 735,1518,3003,2355,3134,1764,3948,3329,1888,2424, +1001,1234,1972,3321,3363,1672,1021,1450,1584, 226, 765, 655,2526,3404,3244,2302, +3665, 731, 594,2184, 319,1576, 621, 658,2656,4299,2099,3864,1279,2071,2598,2739, + 795,3086,3699,3908,1707,2352,2402,1382,3136,2475,1465,4847,3496,3865,1085,3004, +2591,1084, 213,2287,1963,3565,2250, 822, 793,4574,3187,1772,1789,3050, 595,1484, +1959,2770,1080,2650, 456, 422,2996, 940,3322,4328,4345,3092,2742, 965,2784, 739, +4124, 952,1358,2498,2949,2565, 332,2698,2378, 660,2260,2473,4194,3856,2919, 535, +1260,2651,1208,1428,1300,1949,1303,2942, 433,2455,2450,1251,1946, 614,1269, 641, +1306,1810,2737,3078,2912, 564,2365,1419,1415,1497,4460,2367,2185,1379,3005,1307, +3218,2175,1897,3063, 682,1157,4040,4005,1712,1160,1941,1399, 394, 402,2952,1573, +1151,2986,2404, 862, 299,2033,1489,3006, 346, 171,2886,3401,1726,2932, 168,2533, + 47,2507,1030,3735,1145,3370,1395,1318,1579,3609,4560,2857,4116,1457,2529,1965, + 504,1036,2690,2988,2405, 745,5871, 849,2397,2056,3081, 863,2359,3857,2096, 99, +1397,1769,2300,4428,1643,3455,1978,1757,3718,1440, 35,4879,3742,1296,4228,2280, + 160,5063,1599,2013, 166, 520,3479,1646,3345,3012, 490,1937,1545,1264,2182,2505, +1096,1188,1369,1436,2421,1667,2792,2460,1270,2122, 727,3167,2143, 806,1706,1012, +1800,3037, 960,2218,1882, 805, 139,2456,1139,1521, 851,1052,3093,3089, 342,2039, + 744,5097,1468,1502,1585,2087, 223, 939, 326,2140,2577, 892,2481,1623,4077, 982, +3708, 135,2131, 87,2503,3114,2326,1106, 876,1616, 547,2997,2831,2093,3441,4530, +4314, 9,3256,4229,4148, 659,1462,1986,1710,2046,2913,2231,4090,4880,5255,3392, +3274,1368,3689,4645,1477, 705,3384,3635,1068,1529,2941,1458,3782,1509, 100,1656, +2548, 718,2339, 408,1590,2780,3548,1838,4117,3719,1345,3530, 717,3442,2778,3220, +2898,1892,4590,3614,3371,2043,1998,1224,3483, 891, 635, 584,2559,3355, 733,1766, +1729,1172,3789,1891,2307, 781,2982,2271,1957,1580,5773,2633,2005,4195,3097,1535, +3213,1189,1934,5693,3262, 586,3118,1324,1598, 517,1564,2217,1868,1893,4445,3728, +2703,3139,1526,1787,1992,3882,2875,1549,1199,1056,2224,1904,2711,5098,4287, 338, +1993,3129,3489,2689,1809,2815,1997, 957,1855,3898,2550,3275,3057,1105,1319, 627, +1505,1911,1883,3526, 698,3629,3456,1833,1431, 746, 77,1261,2017,2296,1977,1885, + 125,1334,1600, 525,1798,1109,2222,1470,1945, 559,2236,1186,3443,2476,1929,1411, +2411,3135,1777,3372,2621,1841,1613,3229, 668,1430,1839,2643,2916, 195,1989,2671, +2358,1387, 629,3205,2293,5256,4439, 123,1310, 888,1879,4300,3021,3605,1003,1162, +3192,2910,2010, 140,2395,2859, 55,1082,2012,2901, 662, 419,2081,1438, 680,2774, +4654,3912,1620,1731,1625,5035,4065,2328, 512,1344, 802,5443,2163,2311,2537, 524, +3399, 98,1155,2103,1918,2606,3925,2816,1393,2465,1504,3773,2177,3963,1478,4346, + 180,1113,4655,3461,2028,1698, 833,2696,1235,1322,1594,4408,3623,3013,3225,2040, +3022, 541,2881, 607,3632,2029,1665,1219, 639,1385,1686,1099,2803,3231,1938,3188, +2858, 427, 676,2772,1168,2025, 454,3253,2486,3556, 230,1950, 580, 791,1991,1280, +1086,1974,2034, 630, 257,3338,2788,4903,1017, 86,4790, 966,2789,1995,1696,1131, + 259,3095,4188,1308, 179,1463,5257, 289,4107,1248, 42,3413,1725,2288, 896,1947, + 774,4474,4254, 604,3430,4264, 392,2514,2588, 452, 237,1408,3018, 988,4531,1970, +3034,3310, 540,2370,1562,1288,2990, 502,4765,1147, 4,1853,2708, 207, 294,2814, +4078,2902,2509, 684, 34,3105,3532,2551, 644, 709,2801,2344, 573,1727,3573,3557, +2021,1081,3100,4315,2100,3681, 199,2263,1837,2385, 146,3484,1195,2776,3949, 997, +1939,3973,1008,1091,1202,1962,1847,1149,4209,5444,1076, 493, 117,5400,2521, 972, +1490,2934,1796,4542,2374,1512,2933,2657, 413,2888,1135,2762,2314,2156,1355,2369, + 766,2007,2527,2170,3124,2491,2593,2632,4757,2437, 234,3125,3591,1898,1750,1376, +1942,3468,3138, 570,2127,2145,3276,4131, 962, 132,1445,4196, 19, 941,3624,3480, +3366,1973,1374,4461,3431,2629, 283,2415,2275, 808,2887,3620,2112,2563,1353,3610, + 955,1089,3103,1053, 96, 88,4097, 823,3808,1583, 399, 292,4091,3313, 421,1128, + 642,4006, 903,2539,1877,2082, 596, 29,4066,1790, 722,2157, 130, 995,1569, 769, +1485, 464, 513,2213, 288,1923,1101,2453,4316, 133, 486,2445, 50, 625, 487,2207, + 57, 423, 481,2962, 159,3729,1558, 491, 303, 482, 501, 240,2837, 112,3648,2392, +1783, 362, 8,3433,3422, 610,2793,3277,1390,1284,1654, 21,3823, 734, 367, 623, + 193, 287, 374,1009,1483, 816, 476, 313,2255,2340,1262,2150,2899,1146,2581, 782, +2116,1659,2018,1880, 255,3586,3314,1110,2867,2137,2564, 986,2767,5185,2006, 650, + 158, 926, 762, 881,3157,2717,2362,3587, 306,3690,3245,1542,3077,2427,1691,2478, +2118,2985,3490,2438, 539,2305, 983, 129,1754, 355,4201,2386, 827,2923, 104,1773, +2838,2771, 411,2905,3919, 376, 767, 122,1114, 828,2422,1817,3506, 266,3460,1007, +1609,4998, 945,2612,4429,2274, 726,1247,1964,2914,2199,2070,4002,4108, 657,3323, +1422, 579, 455,2764,4737,1222,2895,1670, 824,1223,1487,2525, 558, 861,3080, 598, +2659,2515,1967, 752,2583,2376,2214,4180, 977, 704,2464,4999,2622,4109,1210,2961, + 819,1541, 142,2284, 44, 418, 457,1126,3730,4347,4626,1644,1876,3671,1864, 302, +1063,5694, 624, 723,1984,3745,1314,1676,2488,1610,1449,3558,3569,2166,2098, 409, +1011,2325,3704,2306, 818,1732,1383,1824,1844,3757, 999,2705,3497,1216,1423,2683, +2426,2954,2501,2726,2229,1475,2554,5064,1971,1794,1666,2014,1343, 783, 724, 191, +2434,1354,2220,5065,1763,2752,2472,4152, 131, 175,2885,3434, 92,1466,4920,2616, +3871,3872,3866, 128,1551,1632, 669,1854,3682,4691,4125,1230, 188,2973,3290,1302, +1213, 560,3266, 917, 763,3909,3249,1760, 868,1958, 764,1782,2097, 145,2277,3774, +4462, 64,1491,3062, 971,2132,3606,2442, 221,1226,1617, 218, 323,1185,3207,3147, + 571, 619,1473,1005,1744,2281, 449,1887,2396,3685, 275, 375,3816,1743,3844,3731, + 845,1983,2350,4210,1377, 773, 967,3499,3052,3743,2725,4007,1697,1022,3943,1464, +3264,2855,2722,1952,1029,2839,2467, 84,4383,2215, 820,1391,2015,2448,3672, 377, +1948,2168, 797,2545,3536,2578,2645, 94,2874,1678, 405,1259,3071, 771, 546,1315, + 470,1243,3083, 895,2468, 981, 969,2037, 846,4181, 653,1276,2928, 14,2594, 557, +3007,2474, 156, 902,1338,1740,2574, 537,2518, 973,2282,2216,2433,1928, 138,2903, +1293,2631,1612, 646,3457, 839,2935, 111, 496,2191,2847, 589,3186, 149,3994,2060, +4031,2641,4067,3145,1870, 37,3597,2136,1025,2051,3009,3383,3549,1121,1016,3261, +1301, 251,2446,2599,2153, 872,3246, 637, 334,3705, 831, 884, 921,3065,3140,4092, +2198,1944, 246,2964, 108,2045,1152,1921,2308,1031, 203,3173,4170,1907,3890, 810, +1401,2003,1690, 506, 647,1242,2828,1761,1649,3208,2249,1589,3709,2931,5156,1708, + 498, 666,2613, 834,3817,1231, 184,2851,1124, 883,3197,2261,3710,1765,1553,2658, +1178,2639,2351, 93,1193, 942,2538,2141,4402, 235,1821, 870,1591,2192,1709,1871, +3341,1618,4126,2595,2334, 603, 651, 69, 701, 268,2662,3411,2555,1380,1606, 503, + 448, 254,2371,2646, 574,1187,2309,1770, 322,2235,1292,1801, 305, 566,1133, 229, +2067,2057, 706, 167, 483,2002,2672,3295,1820,3561,3067, 316, 378,2746,3452,1112, + 136,1981, 507,1651,2917,1117, 285,4591, 182,2580,3522,1304, 335,3303,1835,2504, +1795,1792,2248, 674,1018,2106,2449,1857,2292,2845, 976,3047,1781,2600,2727,1389, +1281, 52,3152, 153, 265,3950, 672,3485,3951,4463, 430,1183, 365, 278,2169, 27, +1407,1336,2304, 209,1340,1730,2202,1852,2403,2883, 979,1737,1062, 631,2829,2542, +3876,2592, 825,2086,2226,3048,3625, 352,1417,3724, 542, 991, 431,1351,3938,1861, +2294, 826,1361,2927,3142,3503,1738, 463,2462,2723, 582,1916,1595,2808, 400,3845, +3891,2868,3621,2254, 58,2492,1123, 910,2160,2614,1372,1603,1196,1072,3385,1700, +3267,1980, 696, 480,2430, 920, 799,1570,2920,1951,2041,4047,2540,1321,4223,2469, +3562,2228,1271,2602, 401,2833,3351,2575,5157, 907,2312,1256, 410, 263,3507,1582, + 996, 678,1849,2316,1480, 908,3545,2237, 703,2322, 667,1826,2849,1531,2604,2999, +2407,3146,2151,2630,1786,3711, 469,3542, 497,3899,2409, 858, 837,4446,3393,1274, + 786, 620,1845,2001,3311, 484, 308,3367,1204,1815,3691,2332,1532,2557,1842,2020, +2724,1927,2333,4440, 567, 22,1673,2728,4475,1987,1858,1144,1597, 101,1832,3601, + 12, 974,3783,4391, 951,1412, 1,3720, 453,4608,4041, 528,1041,1027,3230,2628, +1129, 875,1051,3291,1203,2262,1069,2860,2799,2149,2615,3278, 144,1758,3040, 31, + 475,1680, 366,2685,3184, 311,1642,4008,2466,5036,1593,1493,2809, 216,1420,1668, + 233, 304,2128,3284, 232,1429,1768,1040,2008,3407,2740,2967,2543, 242,2133, 778, +1565,2022,2620, 505,2189,2756,1098,2273, 372,1614, 708, 553,2846,2094,2278, 169, +3626,2835,4161, 228,2674,3165, 809,1454,1309, 466,1705,1095, 900,3423, 880,2667, +3751,5258,2317,3109,2571,4317,2766,1503,1342, 866,4447,1118, 63,2076, 314,1881, +1348,1061, 172, 978,3515,1747, 532, 511,3970, 6, 601, 905,2699,3300,1751, 276, +1467,3725,2668, 65,4239,2544,2779,2556,1604, 578,2451,1802, 992,2331,2624,1320, +3446, 713,1513,1013, 103,2786,2447,1661, 886,1702, 916, 654,3574,2031,1556, 751, +2178,2821,2179,1498,1538,2176, 271, 914,2251,2080,1325, 638,1953,2937,3877,2432, +2754, 95,3265,1716, 260,1227,4083, 775, 106,1357,3254, 426,1607, 555,2480, 772, +1985, 244,2546, 474, 495,1046,2611,1851,2061, 71,2089,1675,2590, 742,3758,2843, +3222,1433, 267,2180,2576,2826,2233,2092,3913,2435, 956,1745,3075, 856,2113,1116, + 451, 3,1988,2896,1398, 993,2463,1878,2049,1341,2718,2721,2870,2108, 712,2904, +4363,2753,2324, 277,2872,2349,2649, 384, 987, 435, 691,3000, 922, 164,3939, 652, +1500,1184,4153,2482,3373,2165,4848,2335,3775,3508,3154,2806,2830,1554,2102,1664, +2530,1434,2408, 893,1547,2623,3447,2832,2242,2532,3169,2856,3223,2078, 49,3770, +3469, 462, 318, 656,2259,3250,3069, 679,1629,2758, 344,1138,1104,3120,1836,1283, +3115,2154,1437,4448, 934, 759,1999, 794,2862,1038, 533,2560,1722,2342, 855,2626, +1197,1663,4476,3127, 85,4240,2528, 25,1111,1181,3673, 407,3470,4561,2679,2713, + 768,1925,2841,3986,1544,1165, 932, 373,1240,2146,1930,2673, 721,4766, 354,4333, + 391,2963, 187, 61,3364,1442,1102, 330,1940,1767, 341,3809,4118, 393,2496,2062, +2211, 105, 331, 300, 439, 913,1332, 626, 379,3304,1557, 328, 689,3952, 309,1555, + 931, 317,2517,3027, 325, 569, 686,2107,3084, 60,1042,1333,2794, 264,3177,4014, +1628, 258,3712, 7,4464,1176,1043,1778, 683, 114,1975, 78,1492, 383,1886, 510, + 386, 645,5291,2891,2069,3305,4138,3867,2939,2603,2493,1935,1066,1848,3588,1015, +1282,1289,4609, 697,1453,3044,2666,3611,1856,2412, 54, 719,1330, 568,3778,2459, +1748, 788, 492, 551,1191,1000, 488,3394,3763, 282,1799, 348,2016,1523,3155,2390, +1049, 382,2019,1788,1170, 729,2968,3523, 897,3926,2785,2938,3292, 350,2319,3238, +1718,1717,2655,3453,3143,4465, 161,2889,2980,2009,1421, 56,1908,1640,2387,2232, +1917,1874,2477,4921, 148, 83,3438, 592,4245,2882,1822,1055, 741, 115,1496,1624, + 381,1638,4592,1020, 516,3214, 458, 947,4575,1432, 211,1514,2926,1865,2142, 189, + 852,1221,1400,1486, 882,2299,4036, 351, 28,1122, 700,6479,6480,6481,6482,6483, #last 512 +) + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/gb2312prober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/gb2312prober.py new file mode 100644 index 0000000..8446d2d --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/gb2312prober.py @@ -0,0 +1,46 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is mozilla.org code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .mbcharsetprober import MultiByteCharSetProber +from .codingstatemachine import CodingStateMachine +from .chardistribution import GB2312DistributionAnalysis +from .mbcssm import GB2312_SM_MODEL + +class GB2312Prober(MultiByteCharSetProber): + def __init__(self): + super(GB2312Prober, self).__init__() + self.coding_sm = CodingStateMachine(GB2312_SM_MODEL) + self.distribution_analyzer = GB2312DistributionAnalysis() + self.reset() + + @property + def charset_name(self): + return "GB2312" + + @property + def language(self): + return "Chinese" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/hebrewprober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/hebrewprober.py new file mode 100644 index 0000000..b0e1bf4 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/hebrewprober.py @@ -0,0 +1,292 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Universal charset detector code. +# +# The Initial Developer of the Original Code is +# Shy Shalom +# Portions created by the Initial Developer are Copyright (C) 2005 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .charsetprober import CharSetProber +from .enums import ProbingState + +# This prober doesn't actually recognize a language or a charset. +# It is a helper prober for the use of the Hebrew model probers + +### General ideas of the Hebrew charset recognition ### +# +# Four main charsets exist in Hebrew: +# "ISO-8859-8" - Visual Hebrew +# "windows-1255" - Logical Hebrew +# "ISO-8859-8-I" - Logical Hebrew +# "x-mac-hebrew" - ?? Logical Hebrew ?? +# +# Both "ISO" charsets use a completely identical set of code points, whereas +# "windows-1255" and "x-mac-hebrew" are two different proper supersets of +# these code points. windows-1255 defines additional characters in the range +# 0x80-0x9F as some misc punctuation marks as well as some Hebrew-specific +# diacritics and additional 'Yiddish' ligature letters in the range 0xc0-0xd6. +# x-mac-hebrew defines similar additional code points but with a different +# mapping. +# +# As far as an average Hebrew text with no diacritics is concerned, all four +# charsets are identical with respect to code points. Meaning that for the +# main Hebrew alphabet, all four map the same values to all 27 Hebrew letters +# (including final letters). +# +# The dominant difference between these charsets is their directionality. +# "Visual" directionality means that the text is ordered as if the renderer is +# not aware of a BIDI rendering algorithm. The renderer sees the text and +# draws it from left to right. The text itself when ordered naturally is read +# backwards. A buffer of Visual Hebrew generally looks like so: +# "[last word of first line spelled backwards] [whole line ordered backwards +# and spelled backwards] [first word of first line spelled backwards] +# [end of line] [last word of second line] ... etc' " +# adding punctuation marks, numbers and English text to visual text is +# naturally also "visual" and from left to right. +# +# "Logical" directionality means the text is ordered "naturally" according to +# the order it is read. It is the responsibility of the renderer to display +# the text from right to left. A BIDI algorithm is used to place general +# punctuation marks, numbers and English text in the text. +# +# Texts in x-mac-hebrew are almost impossible to find on the Internet. From +# what little evidence I could find, it seems that its general directionality +# is Logical. +# +# To sum up all of the above, the Hebrew probing mechanism knows about two +# charsets: +# Visual Hebrew - "ISO-8859-8" - backwards text - Words and sentences are +# backwards while line order is natural. For charset recognition purposes +# the line order is unimportant (In fact, for this implementation, even +# word order is unimportant). +# Logical Hebrew - "windows-1255" - normal, naturally ordered text. +# +# "ISO-8859-8-I" is a subset of windows-1255 and doesn't need to be +# specifically identified. +# "x-mac-hebrew" is also identified as windows-1255. A text in x-mac-hebrew +# that contain special punctuation marks or diacritics is displayed with +# some unconverted characters showing as question marks. This problem might +# be corrected using another model prober for x-mac-hebrew. Due to the fact +# that x-mac-hebrew texts are so rare, writing another model prober isn't +# worth the effort and performance hit. +# +#### The Prober #### +# +# The prober is divided between two SBCharSetProbers and a HebrewProber, +# all of which are managed, created, fed data, inquired and deleted by the +# SBCSGroupProber. The two SBCharSetProbers identify that the text is in +# fact some kind of Hebrew, Logical or Visual. The final decision about which +# one is it is made by the HebrewProber by combining final-letter scores +# with the scores of the two SBCharSetProbers to produce a final answer. +# +# The SBCSGroupProber is responsible for stripping the original text of HTML +# tags, English characters, numbers, low-ASCII punctuation characters, spaces +# and new lines. It reduces any sequence of such characters to a single space. +# The buffer fed to each prober in the SBCS group prober is pure text in +# high-ASCII. +# The two SBCharSetProbers (model probers) share the same language model: +# Win1255Model. +# The first SBCharSetProber uses the model normally as any other +# SBCharSetProber does, to recognize windows-1255, upon which this model was +# built. The second SBCharSetProber is told to make the pair-of-letter +# lookup in the language model backwards. This in practice exactly simulates +# a visual Hebrew model using the windows-1255 logical Hebrew model. +# +# The HebrewProber is not using any language model. All it does is look for +# final-letter evidence suggesting the text is either logical Hebrew or visual +# Hebrew. Disjointed from the model probers, the results of the HebrewProber +# alone are meaningless. HebrewProber always returns 0.00 as confidence +# since it never identifies a charset by itself. Instead, the pointer to the +# HebrewProber is passed to the model probers as a helper "Name Prober". +# When the Group prober receives a positive identification from any prober, +# it asks for the name of the charset identified. If the prober queried is a +# Hebrew model prober, the model prober forwards the call to the +# HebrewProber to make the final decision. In the HebrewProber, the +# decision is made according to the final-letters scores maintained and Both +# model probers scores. The answer is returned in the form of the name of the +# charset identified, either "windows-1255" or "ISO-8859-8". + +class HebrewProber(CharSetProber): + # windows-1255 / ISO-8859-8 code points of interest + FINAL_KAF = 0xea + NORMAL_KAF = 0xeb + FINAL_MEM = 0xed + NORMAL_MEM = 0xee + FINAL_NUN = 0xef + NORMAL_NUN = 0xf0 + FINAL_PE = 0xf3 + NORMAL_PE = 0xf4 + FINAL_TSADI = 0xf5 + NORMAL_TSADI = 0xf6 + + # Minimum Visual vs Logical final letter score difference. + # If the difference is below this, don't rely solely on the final letter score + # distance. + MIN_FINAL_CHAR_DISTANCE = 5 + + # Minimum Visual vs Logical model score difference. + # If the difference is below this, don't rely at all on the model score + # distance. + MIN_MODEL_DISTANCE = 0.01 + + VISUAL_HEBREW_NAME = "ISO-8859-8" + LOGICAL_HEBREW_NAME = "windows-1255" + + def __init__(self): + super(HebrewProber, self).__init__() + self._final_char_logical_score = None + self._final_char_visual_score = None + self._prev = None + self._before_prev = None + self._logical_prober = None + self._visual_prober = None + self.reset() + + def reset(self): + self._final_char_logical_score = 0 + self._final_char_visual_score = 0 + # The two last characters seen in the previous buffer, + # mPrev and mBeforePrev are initialized to space in order to simulate + # a word delimiter at the beginning of the data + self._prev = ' ' + self._before_prev = ' ' + # These probers are owned by the group prober. + + def set_model_probers(self, logicalProber, visualProber): + self._logical_prober = logicalProber + self._visual_prober = visualProber + + def is_final(self, c): + return c in [self.FINAL_KAF, self.FINAL_MEM, self.FINAL_NUN, + self.FINAL_PE, self.FINAL_TSADI] + + def is_non_final(self, c): + # The normal Tsadi is not a good Non-Final letter due to words like + # 'lechotet' (to chat) containing an apostrophe after the tsadi. This + # apostrophe is converted to a space in FilterWithoutEnglishLetters + # causing the Non-Final tsadi to appear at an end of a word even + # though this is not the case in the original text. + # The letters Pe and Kaf rarely display a related behavior of not being + # a good Non-Final letter. Words like 'Pop', 'Winamp' and 'Mubarak' + # for example legally end with a Non-Final Pe or Kaf. However, the + # benefit of these letters as Non-Final letters outweighs the damage + # since these words are quite rare. + return c in [self.NORMAL_KAF, self.NORMAL_MEM, + self.NORMAL_NUN, self.NORMAL_PE] + + def feed(self, byte_str): + # Final letter analysis for logical-visual decision. + # Look for evidence that the received buffer is either logical Hebrew + # or visual Hebrew. + # The following cases are checked: + # 1) A word longer than 1 letter, ending with a final letter. This is + # an indication that the text is laid out "naturally" since the + # final letter really appears at the end. +1 for logical score. + # 2) A word longer than 1 letter, ending with a Non-Final letter. In + # normal Hebrew, words ending with Kaf, Mem, Nun, Pe or Tsadi, + # should not end with the Non-Final form of that letter. Exceptions + # to this rule are mentioned above in isNonFinal(). This is an + # indication that the text is laid out backwards. +1 for visual + # score + # 3) A word longer than 1 letter, starting with a final letter. Final + # letters should not appear at the beginning of a word. This is an + # indication that the text is laid out backwards. +1 for visual + # score. + # + # The visual score and logical score are accumulated throughout the + # text and are finally checked against each other in GetCharSetName(). + # No checking for final letters in the middle of words is done since + # that case is not an indication for either Logical or Visual text. + # + # We automatically filter out all 7-bit characters (replace them with + # spaces) so the word boundary detection works properly. [MAP] + + if self.state == ProbingState.NOT_ME: + # Both model probers say it's not them. No reason to continue. + return ProbingState.NOT_ME + + byte_str = self.filter_high_byte_only(byte_str) + + for cur in byte_str: + if cur == ' ': + # We stand on a space - a word just ended + if self._before_prev != ' ': + # next-to-last char was not a space so self._prev is not a + # 1 letter word + if self.is_final(self._prev): + # case (1) [-2:not space][-1:final letter][cur:space] + self._final_char_logical_score += 1 + elif self.is_non_final(self._prev): + # case (2) [-2:not space][-1:Non-Final letter][ + # cur:space] + self._final_char_visual_score += 1 + else: + # Not standing on a space + if ((self._before_prev == ' ') and + (self.is_final(self._prev)) and (cur != ' ')): + # case (3) [-2:space][-1:final letter][cur:not space] + self._final_char_visual_score += 1 + self._before_prev = self._prev + self._prev = cur + + # Forever detecting, till the end or until both model probers return + # ProbingState.NOT_ME (handled above) + return ProbingState.DETECTING + + @property + def charset_name(self): + # Make the decision: is it Logical or Visual? + # If the final letter score distance is dominant enough, rely on it. + finalsub = self._final_char_logical_score - self._final_char_visual_score + if finalsub >= self.MIN_FINAL_CHAR_DISTANCE: + return self.LOGICAL_HEBREW_NAME + if finalsub <= -self.MIN_FINAL_CHAR_DISTANCE: + return self.VISUAL_HEBREW_NAME + + # It's not dominant enough, try to rely on the model scores instead. + modelsub = (self._logical_prober.get_confidence() + - self._visual_prober.get_confidence()) + if modelsub > self.MIN_MODEL_DISTANCE: + return self.LOGICAL_HEBREW_NAME + if modelsub < -self.MIN_MODEL_DISTANCE: + return self.VISUAL_HEBREW_NAME + + # Still no good, back to final letter distance, maybe it'll save the + # day. + if finalsub < 0.0: + return self.VISUAL_HEBREW_NAME + + # (finalsub > 0 - Logical) or (don't know what to do) default to + # Logical. + return self.LOGICAL_HEBREW_NAME + + @property + def language(self): + return 'Hebrew' + + @property + def state(self): + # Remain active as long as any of the model probers are active. + if (self._logical_prober.state == ProbingState.NOT_ME) and \ + (self._visual_prober.state == ProbingState.NOT_ME): + return ProbingState.NOT_ME + return ProbingState.DETECTING diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/jisfreq.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/jisfreq.py new file mode 100644 index 0000000..83fc082 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/jisfreq.py @@ -0,0 +1,325 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Communicator client code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +# Sampling from about 20M text materials include literature and computer technology +# +# Japanese frequency table, applied to both S-JIS and EUC-JP +# They are sorted in order. + +# 128 --> 0.77094 +# 256 --> 0.85710 +# 512 --> 0.92635 +# 1024 --> 0.97130 +# 2048 --> 0.99431 +# +# Ideal Distribution Ratio = 0.92635 / (1-0.92635) = 12.58 +# Random Distribution Ration = 512 / (2965+62+83+86-512) = 0.191 +# +# Typical Distribution Ratio, 25% of IDR + +JIS_TYPICAL_DISTRIBUTION_RATIO = 3.0 + +# Char to FreqOrder table , +JIS_TABLE_SIZE = 4368 + +JIS_CHAR_TO_FREQ_ORDER = ( + 40, 1, 6, 182, 152, 180, 295,2127, 285, 381,3295,4304,3068,4606,3165,3510, # 16 +3511,1822,2785,4607,1193,2226,5070,4608, 171,2996,1247, 18, 179,5071, 856,1661, # 32 +1262,5072, 619, 127,3431,3512,3230,1899,1700, 232, 228,1294,1298, 284, 283,2041, # 48 +2042,1061,1062, 48, 49, 44, 45, 433, 434,1040,1041, 996, 787,2997,1255,4305, # 64 +2108,4609,1684,1648,5073,5074,5075,5076,5077,5078,3687,5079,4610,5080,3927,3928, # 80 +5081,3296,3432, 290,2285,1471,2187,5082,2580,2825,1303,2140,1739,1445,2691,3375, # 96 +1691,3297,4306,4307,4611, 452,3376,1182,2713,3688,3069,4308,5083,5084,5085,5086, # 112 +5087,5088,5089,5090,5091,5092,5093,5094,5095,5096,5097,5098,5099,5100,5101,5102, # 128 +5103,5104,5105,5106,5107,5108,5109,5110,5111,5112,4097,5113,5114,5115,5116,5117, # 144 +5118,5119,5120,5121,5122,5123,5124,5125,5126,5127,5128,5129,5130,5131,5132,5133, # 160 +5134,5135,5136,5137,5138,5139,5140,5141,5142,5143,5144,5145,5146,5147,5148,5149, # 176 +5150,5151,5152,4612,5153,5154,5155,5156,5157,5158,5159,5160,5161,5162,5163,5164, # 192 +5165,5166,5167,5168,5169,5170,5171,5172,5173,5174,5175,1472, 598, 618, 820,1205, # 208 +1309,1412,1858,1307,1692,5176,5177,5178,5179,5180,5181,5182,1142,1452,1234,1172, # 224 +1875,2043,2149,1793,1382,2973, 925,2404,1067,1241, 960,1377,2935,1491, 919,1217, # 240 +1865,2030,1406,1499,2749,4098,5183,5184,5185,5186,5187,5188,2561,4099,3117,1804, # 256 +2049,3689,4309,3513,1663,5189,3166,3118,3298,1587,1561,3433,5190,3119,1625,2998, # 272 +3299,4613,1766,3690,2786,4614,5191,5192,5193,5194,2161, 26,3377, 2,3929, 20, # 288 +3691, 47,4100, 50, 17, 16, 35, 268, 27, 243, 42, 155, 24, 154, 29, 184, # 304 + 4, 91, 14, 92, 53, 396, 33, 289, 9, 37, 64, 620, 21, 39, 321, 5, # 320 + 12, 11, 52, 13, 3, 208, 138, 0, 7, 60, 526, 141, 151,1069, 181, 275, # 336 +1591, 83, 132,1475, 126, 331, 829, 15, 69, 160, 59, 22, 157, 55,1079, 312, # 352 + 109, 38, 23, 25, 10, 19, 79,5195, 61, 382,1124, 8, 30,5196,5197,5198, # 368 +5199,5200,5201,5202,5203,5204,5205,5206, 89, 62, 74, 34,2416, 112, 139, 196, # 384 + 271, 149, 84, 607, 131, 765, 46, 88, 153, 683, 76, 874, 101, 258, 57, 80, # 400 + 32, 364, 121,1508, 169,1547, 68, 235, 145,2999, 41, 360,3027, 70, 63, 31, # 416 + 43, 259, 262,1383, 99, 533, 194, 66, 93, 846, 217, 192, 56, 106, 58, 565, # 432 + 280, 272, 311, 256, 146, 82, 308, 71, 100, 128, 214, 655, 110, 261, 104,1140, # 448 + 54, 51, 36, 87, 67,3070, 185,2618,2936,2020, 28,1066,2390,2059,5207,5208, # 464 +5209,5210,5211,5212,5213,5214,5215,5216,4615,5217,5218,5219,5220,5221,5222,5223, # 480 +5224,5225,5226,5227,5228,5229,5230,5231,5232,5233,5234,5235,5236,3514,5237,5238, # 496 +5239,5240,5241,5242,5243,5244,2297,2031,4616,4310,3692,5245,3071,5246,3598,5247, # 512 +4617,3231,3515,5248,4101,4311,4618,3808,4312,4102,5249,4103,4104,3599,5250,5251, # 528 +5252,5253,5254,5255,5256,5257,5258,5259,5260,5261,5262,5263,5264,5265,5266,5267, # 544 +5268,5269,5270,5271,5272,5273,5274,5275,5276,5277,5278,5279,5280,5281,5282,5283, # 560 +5284,5285,5286,5287,5288,5289,5290,5291,5292,5293,5294,5295,5296,5297,5298,5299, # 576 +5300,5301,5302,5303,5304,5305,5306,5307,5308,5309,5310,5311,5312,5313,5314,5315, # 592 +5316,5317,5318,5319,5320,5321,5322,5323,5324,5325,5326,5327,5328,5329,5330,5331, # 608 +5332,5333,5334,5335,5336,5337,5338,5339,5340,5341,5342,5343,5344,5345,5346,5347, # 624 +5348,5349,5350,5351,5352,5353,5354,5355,5356,5357,5358,5359,5360,5361,5362,5363, # 640 +5364,5365,5366,5367,5368,5369,5370,5371,5372,5373,5374,5375,5376,5377,5378,5379, # 656 +5380,5381, 363, 642,2787,2878,2788,2789,2316,3232,2317,3434,2011, 165,1942,3930, # 672 +3931,3932,3933,5382,4619,5383,4620,5384,5385,5386,5387,5388,5389,5390,5391,5392, # 688 +5393,5394,5395,5396,5397,5398,5399,5400,5401,5402,5403,5404,5405,5406,5407,5408, # 704 +5409,5410,5411,5412,5413,5414,5415,5416,5417,5418,5419,5420,5421,5422,5423,5424, # 720 +5425,5426,5427,5428,5429,5430,5431,5432,5433,5434,5435,5436,5437,5438,5439,5440, # 736 +5441,5442,5443,5444,5445,5446,5447,5448,5449,5450,5451,5452,5453,5454,5455,5456, # 752 +5457,5458,5459,5460,5461,5462,5463,5464,5465,5466,5467,5468,5469,5470,5471,5472, # 768 +5473,5474,5475,5476,5477,5478,5479,5480,5481,5482,5483,5484,5485,5486,5487,5488, # 784 +5489,5490,5491,5492,5493,5494,5495,5496,5497,5498,5499,5500,5501,5502,5503,5504, # 800 +5505,5506,5507,5508,5509,5510,5511,5512,5513,5514,5515,5516,5517,5518,5519,5520, # 816 +5521,5522,5523,5524,5525,5526,5527,5528,5529,5530,5531,5532,5533,5534,5535,5536, # 832 +5537,5538,5539,5540,5541,5542,5543,5544,5545,5546,5547,5548,5549,5550,5551,5552, # 848 +5553,5554,5555,5556,5557,5558,5559,5560,5561,5562,5563,5564,5565,5566,5567,5568, # 864 +5569,5570,5571,5572,5573,5574,5575,5576,5577,5578,5579,5580,5581,5582,5583,5584, # 880 +5585,5586,5587,5588,5589,5590,5591,5592,5593,5594,5595,5596,5597,5598,5599,5600, # 896 +5601,5602,5603,5604,5605,5606,5607,5608,5609,5610,5611,5612,5613,5614,5615,5616, # 912 +5617,5618,5619,5620,5621,5622,5623,5624,5625,5626,5627,5628,5629,5630,5631,5632, # 928 +5633,5634,5635,5636,5637,5638,5639,5640,5641,5642,5643,5644,5645,5646,5647,5648, # 944 +5649,5650,5651,5652,5653,5654,5655,5656,5657,5658,5659,5660,5661,5662,5663,5664, # 960 +5665,5666,5667,5668,5669,5670,5671,5672,5673,5674,5675,5676,5677,5678,5679,5680, # 976 +5681,5682,5683,5684,5685,5686,5687,5688,5689,5690,5691,5692,5693,5694,5695,5696, # 992 +5697,5698,5699,5700,5701,5702,5703,5704,5705,5706,5707,5708,5709,5710,5711,5712, # 1008 +5713,5714,5715,5716,5717,5718,5719,5720,5721,5722,5723,5724,5725,5726,5727,5728, # 1024 +5729,5730,5731,5732,5733,5734,5735,5736,5737,5738,5739,5740,5741,5742,5743,5744, # 1040 +5745,5746,5747,5748,5749,5750,5751,5752,5753,5754,5755,5756,5757,5758,5759,5760, # 1056 +5761,5762,5763,5764,5765,5766,5767,5768,5769,5770,5771,5772,5773,5774,5775,5776, # 1072 +5777,5778,5779,5780,5781,5782,5783,5784,5785,5786,5787,5788,5789,5790,5791,5792, # 1088 +5793,5794,5795,5796,5797,5798,5799,5800,5801,5802,5803,5804,5805,5806,5807,5808, # 1104 +5809,5810,5811,5812,5813,5814,5815,5816,5817,5818,5819,5820,5821,5822,5823,5824, # 1120 +5825,5826,5827,5828,5829,5830,5831,5832,5833,5834,5835,5836,5837,5838,5839,5840, # 1136 +5841,5842,5843,5844,5845,5846,5847,5848,5849,5850,5851,5852,5853,5854,5855,5856, # 1152 +5857,5858,5859,5860,5861,5862,5863,5864,5865,5866,5867,5868,5869,5870,5871,5872, # 1168 +5873,5874,5875,5876,5877,5878,5879,5880,5881,5882,5883,5884,5885,5886,5887,5888, # 1184 +5889,5890,5891,5892,5893,5894,5895,5896,5897,5898,5899,5900,5901,5902,5903,5904, # 1200 +5905,5906,5907,5908,5909,5910,5911,5912,5913,5914,5915,5916,5917,5918,5919,5920, # 1216 +5921,5922,5923,5924,5925,5926,5927,5928,5929,5930,5931,5932,5933,5934,5935,5936, # 1232 +5937,5938,5939,5940,5941,5942,5943,5944,5945,5946,5947,5948,5949,5950,5951,5952, # 1248 +5953,5954,5955,5956,5957,5958,5959,5960,5961,5962,5963,5964,5965,5966,5967,5968, # 1264 +5969,5970,5971,5972,5973,5974,5975,5976,5977,5978,5979,5980,5981,5982,5983,5984, # 1280 +5985,5986,5987,5988,5989,5990,5991,5992,5993,5994,5995,5996,5997,5998,5999,6000, # 1296 +6001,6002,6003,6004,6005,6006,6007,6008,6009,6010,6011,6012,6013,6014,6015,6016, # 1312 +6017,6018,6019,6020,6021,6022,6023,6024,6025,6026,6027,6028,6029,6030,6031,6032, # 1328 +6033,6034,6035,6036,6037,6038,6039,6040,6041,6042,6043,6044,6045,6046,6047,6048, # 1344 +6049,6050,6051,6052,6053,6054,6055,6056,6057,6058,6059,6060,6061,6062,6063,6064, # 1360 +6065,6066,6067,6068,6069,6070,6071,6072,6073,6074,6075,6076,6077,6078,6079,6080, # 1376 +6081,6082,6083,6084,6085,6086,6087,6088,6089,6090,6091,6092,6093,6094,6095,6096, # 1392 +6097,6098,6099,6100,6101,6102,6103,6104,6105,6106,6107,6108,6109,6110,6111,6112, # 1408 +6113,6114,2044,2060,4621, 997,1235, 473,1186,4622, 920,3378,6115,6116, 379,1108, # 1424 +4313,2657,2735,3934,6117,3809, 636,3233, 573,1026,3693,3435,2974,3300,2298,4105, # 1440 + 854,2937,2463, 393,2581,2417, 539, 752,1280,2750,2480, 140,1161, 440, 708,1569, # 1456 + 665,2497,1746,1291,1523,3000, 164,1603, 847,1331, 537,1997, 486, 508,1693,2418, # 1472 +1970,2227, 878,1220, 299,1030, 969, 652,2751, 624,1137,3301,2619, 65,3302,2045, # 1488 +1761,1859,3120,1930,3694,3516, 663,1767, 852, 835,3695, 269, 767,2826,2339,1305, # 1504 + 896,1150, 770,1616,6118, 506,1502,2075,1012,2519, 775,2520,2975,2340,2938,4314, # 1520 +3028,2086,1224,1943,2286,6119,3072,4315,2240,1273,1987,3935,1557, 175, 597, 985, # 1536 +3517,2419,2521,1416,3029, 585, 938,1931,1007,1052,1932,1685,6120,3379,4316,4623, # 1552 + 804, 599,3121,1333,2128,2539,1159,1554,2032,3810, 687,2033,2904, 952, 675,1467, # 1568 +3436,6121,2241,1096,1786,2440,1543,1924, 980,1813,2228, 781,2692,1879, 728,1918, # 1584 +3696,4624, 548,1950,4625,1809,1088,1356,3303,2522,1944, 502, 972, 373, 513,2827, # 1600 + 586,2377,2391,1003,1976,1631,6122,2464,1084, 648,1776,4626,2141, 324, 962,2012, # 1616 +2177,2076,1384, 742,2178,1448,1173,1810, 222, 102, 301, 445, 125,2420, 662,2498, # 1632 + 277, 200,1476,1165,1068, 224,2562,1378,1446, 450,1880, 659, 791, 582,4627,2939, # 1648 +3936,1516,1274, 555,2099,3697,1020,1389,1526,3380,1762,1723,1787,2229, 412,2114, # 1664 +1900,2392,3518, 512,2597, 427,1925,2341,3122,1653,1686,2465,2499, 697, 330, 273, # 1680 + 380,2162, 951, 832, 780, 991,1301,3073, 965,2270,3519, 668,2523,2636,1286, 535, # 1696 +1407, 518, 671, 957,2658,2378, 267, 611,2197,3030,6123, 248,2299, 967,1799,2356, # 1712 + 850,1418,3437,1876,1256,1480,2828,1718,6124,6125,1755,1664,2405,6126,4628,2879, # 1728 +2829, 499,2179, 676,4629, 557,2329,2214,2090, 325,3234, 464, 811,3001, 992,2342, # 1744 +2481,1232,1469, 303,2242, 466,1070,2163, 603,1777,2091,4630,2752,4631,2714, 322, # 1760 +2659,1964,1768, 481,2188,1463,2330,2857,3600,2092,3031,2421,4632,2318,2070,1849, # 1776 +2598,4633,1302,2254,1668,1701,2422,3811,2905,3032,3123,2046,4106,1763,1694,4634, # 1792 +1604, 943,1724,1454, 917, 868,2215,1169,2940, 552,1145,1800,1228,1823,1955, 316, # 1808 +1080,2510, 361,1807,2830,4107,2660,3381,1346,1423,1134,4108,6127, 541,1263,1229, # 1824 +1148,2540, 545, 465,1833,2880,3438,1901,3074,2482, 816,3937, 713,1788,2500, 122, # 1840 +1575, 195,1451,2501,1111,6128, 859, 374,1225,2243,2483,4317, 390,1033,3439,3075, # 1856 +2524,1687, 266, 793,1440,2599, 946, 779, 802, 507, 897,1081, 528,2189,1292, 711, # 1872 +1866,1725,1167,1640, 753, 398,2661,1053, 246, 348,4318, 137,1024,3440,1600,2077, # 1888 +2129, 825,4319, 698, 238, 521, 187,2300,1157,2423,1641,1605,1464,1610,1097,2541, # 1904 +1260,1436, 759,2255,1814,2150, 705,3235, 409,2563,3304, 561,3033,2005,2564, 726, # 1920 +1956,2343,3698,4109, 949,3812,3813,3520,1669, 653,1379,2525, 881,2198, 632,2256, # 1936 +1027, 778,1074, 733,1957, 514,1481,2466, 554,2180, 702,3938,1606,1017,1398,6129, # 1952 +1380,3521, 921, 993,1313, 594, 449,1489,1617,1166, 768,1426,1360, 495,1794,3601, # 1968 +1177,3602,1170,4320,2344, 476, 425,3167,4635,3168,1424, 401,2662,1171,3382,1998, # 1984 +1089,4110, 477,3169, 474,6130,1909, 596,2831,1842, 494, 693,1051,1028,1207,3076, # 2000 + 606,2115, 727,2790,1473,1115, 743,3522, 630, 805,1532,4321,2021, 366,1057, 838, # 2016 + 684,1114,2142,4322,2050,1492,1892,1808,2271,3814,2424,1971,1447,1373,3305,1090, # 2032 +1536,3939,3523,3306,1455,2199, 336, 369,2331,1035, 584,2393, 902, 718,2600,6131, # 2048 +2753, 463,2151,1149,1611,2467, 715,1308,3124,1268, 343,1413,3236,1517,1347,2663, # 2064 +2093,3940,2022,1131,1553,2100,2941,1427,3441,2942,1323,2484,6132,1980, 872,2368, # 2080 +2441,2943, 320,2369,2116,1082, 679,1933,3941,2791,3815, 625,1143,2023, 422,2200, # 2096 +3816,6133, 730,1695, 356,2257,1626,2301,2858,2637,1627,1778, 937, 883,2906,2693, # 2112 +3002,1769,1086, 400,1063,1325,3307,2792,4111,3077, 456,2345,1046, 747,6134,1524, # 2128 + 884,1094,3383,1474,2164,1059, 974,1688,2181,2258,1047, 345,1665,1187, 358, 875, # 2144 +3170, 305, 660,3524,2190,1334,1135,3171,1540,1649,2542,1527, 927, 968,2793, 885, # 2160 +1972,1850, 482, 500,2638,1218,1109,1085,2543,1654,2034, 876, 78,2287,1482,1277, # 2176 + 861,1675,1083,1779, 724,2754, 454, 397,1132,1612,2332, 893, 672,1237, 257,2259, # 2192 +2370, 135,3384, 337,2244, 547, 352, 340, 709,2485,1400, 788,1138,2511, 540, 772, # 2208 +1682,2260,2272,2544,2013,1843,1902,4636,1999,1562,2288,4637,2201,1403,1533, 407, # 2224 + 576,3308,1254,2071, 978,3385, 170, 136,1201,3125,2664,3172,2394, 213, 912, 873, # 2240 +3603,1713,2202, 699,3604,3699, 813,3442, 493, 531,1054, 468,2907,1483, 304, 281, # 2256 +4112,1726,1252,2094, 339,2319,2130,2639, 756,1563,2944, 748, 571,2976,1588,2425, # 2272 +2715,1851,1460,2426,1528,1392,1973,3237, 288,3309, 685,3386, 296, 892,2716,2216, # 2288 +1570,2245, 722,1747,2217, 905,3238,1103,6135,1893,1441,1965, 251,1805,2371,3700, # 2304 +2601,1919,1078, 75,2182,1509,1592,1270,2640,4638,2152,6136,3310,3817, 524, 706, # 2320 +1075, 292,3818,1756,2602, 317, 98,3173,3605,3525,1844,2218,3819,2502, 814, 567, # 2336 + 385,2908,1534,6137, 534,1642,3239, 797,6138,1670,1529, 953,4323, 188,1071, 538, # 2352 + 178, 729,3240,2109,1226,1374,2000,2357,2977, 731,2468,1116,2014,2051,6139,1261, # 2368 +1593, 803,2859,2736,3443, 556, 682, 823,1541,6140,1369,2289,1706,2794, 845, 462, # 2384 +2603,2665,1361, 387, 162,2358,1740, 739,1770,1720,1304,1401,3241,1049, 627,1571, # 2400 +2427,3526,1877,3942,1852,1500, 431,1910,1503, 677, 297,2795, 286,1433,1038,1198, # 2416 +2290,1133,1596,4113,4639,2469,1510,1484,3943,6141,2442, 108, 712,4640,2372, 866, # 2432 +3701,2755,3242,1348, 834,1945,1408,3527,2395,3243,1811, 824, 994,1179,2110,1548, # 2448 +1453, 790,3003, 690,4324,4325,2832,2909,3820,1860,3821, 225,1748, 310, 346,1780, # 2464 +2470, 821,1993,2717,2796, 828, 877,3528,2860,2471,1702,2165,2910,2486,1789, 453, # 2480 + 359,2291,1676, 73,1164,1461,1127,3311, 421, 604, 314,1037, 589, 116,2487, 737, # 2496 + 837,1180, 111, 244, 735,6142,2261,1861,1362, 986, 523, 418, 581,2666,3822, 103, # 2512 + 855, 503,1414,1867,2488,1091, 657,1597, 979, 605,1316,4641,1021,2443,2078,2001, # 2528 +1209, 96, 587,2166,1032, 260,1072,2153, 173, 94, 226,3244, 819,2006,4642,4114, # 2544 +2203, 231,1744, 782, 97,2667, 786,3387, 887, 391, 442,2219,4326,1425,6143,2694, # 2560 + 633,1544,1202, 483,2015, 592,2052,1958,2472,1655, 419, 129,4327,3444,3312,1714, # 2576 +1257,3078,4328,1518,1098, 865,1310,1019,1885,1512,1734, 469,2444, 148, 773, 436, # 2592 +1815,1868,1128,1055,4329,1245,2756,3445,2154,1934,1039,4643, 579,1238, 932,2320, # 2608 + 353, 205, 801, 115,2428, 944,2321,1881, 399,2565,1211, 678, 766,3944, 335,2101, # 2624 +1459,1781,1402,3945,2737,2131,1010, 844, 981,1326,1013, 550,1816,1545,2620,1335, # 2640 +1008, 371,2881, 936,1419,1613,3529,1456,1395,2273,1834,2604,1317,2738,2503, 416, # 2656 +1643,4330, 806,1126, 229, 591,3946,1314,1981,1576,1837,1666, 347,1790, 977,3313, # 2672 + 764,2861,1853, 688,2429,1920,1462, 77, 595, 415,2002,3034, 798,1192,4115,6144, # 2688 +2978,4331,3035,2695,2582,2072,2566, 430,2430,1727, 842,1396,3947,3702, 613, 377, # 2704 + 278, 236,1417,3388,3314,3174, 757,1869, 107,3530,6145,1194, 623,2262, 207,1253, # 2720 +2167,3446,3948, 492,1117,1935, 536,1838,2757,1246,4332, 696,2095,2406,1393,1572, # 2736 +3175,1782, 583, 190, 253,1390,2230, 830,3126,3389, 934,3245,1703,1749,2979,1870, # 2752 +2545,1656,2204, 869,2346,4116,3176,1817, 496,1764,4644, 942,1504, 404,1903,1122, # 2768 +1580,3606,2945,1022, 515, 372,1735, 955,2431,3036,6146,2797,1110,2302,2798, 617, # 2784 +6147, 441, 762,1771,3447,3607,3608,1904, 840,3037, 86, 939,1385, 572,1370,2445, # 2800 +1336, 114,3703, 898, 294, 203,3315, 703,1583,2274, 429, 961,4333,1854,1951,3390, # 2816 +2373,3704,4334,1318,1381, 966,1911,2322,1006,1155, 309, 989, 458,2718,1795,1372, # 2832 +1203, 252,1689,1363,3177, 517,1936, 168,1490, 562, 193,3823,1042,4117,1835, 551, # 2848 + 470,4645, 395, 489,3448,1871,1465,2583,2641, 417,1493, 279,1295, 511,1236,1119, # 2864 + 72,1231,1982,1812,3004, 871,1564, 984,3449,1667,2696,2096,4646,2347,2833,1673, # 2880 +3609, 695,3246,2668, 807,1183,4647, 890, 388,2333,1801,1457,2911,1765,1477,1031, # 2896 +3316,3317,1278,3391,2799,2292,2526, 163,3450,4335,2669,1404,1802,6148,2323,2407, # 2912 +1584,1728,1494,1824,1269, 298, 909,3318,1034,1632, 375, 776,1683,2061, 291, 210, # 2928 +1123, 809,1249,1002,2642,3038, 206,1011,2132, 144, 975, 882,1565, 342, 667, 754, # 2944 +1442,2143,1299,2303,2062, 447, 626,2205,1221,2739,2912,1144,1214,2206,2584, 760, # 2960 +1715, 614, 950,1281,2670,2621, 810, 577,1287,2546,4648, 242,2168, 250,2643, 691, # 2976 + 123,2644, 647, 313,1029, 689,1357,2946,1650, 216, 771,1339,1306, 808,2063, 549, # 2992 + 913,1371,2913,2914,6149,1466,1092,1174,1196,1311,2605,2396,1783,1796,3079, 406, # 3008 +2671,2117,3949,4649, 487,1825,2220,6150,2915, 448,2348,1073,6151,2397,1707, 130, # 3024 + 900,1598, 329, 176,1959,2527,1620,6152,2275,4336,3319,1983,2191,3705,3610,2155, # 3040 +3706,1912,1513,1614,6153,1988, 646, 392,2304,1589,3320,3039,1826,1239,1352,1340, # 3056 +2916, 505,2567,1709,1437,2408,2547, 906,6154,2672, 384,1458,1594,1100,1329, 710, # 3072 + 423,3531,2064,2231,2622,1989,2673,1087,1882, 333, 841,3005,1296,2882,2379, 580, # 3088 +1937,1827,1293,2585, 601, 574, 249,1772,4118,2079,1120, 645, 901,1176,1690, 795, # 3104 +2207, 478,1434, 516,1190,1530, 761,2080, 930,1264, 355, 435,1552, 644,1791, 987, # 3120 + 220,1364,1163,1121,1538, 306,2169,1327,1222, 546,2645, 218, 241, 610,1704,3321, # 3136 +1984,1839,1966,2528, 451,6155,2586,3707,2568, 907,3178, 254,2947, 186,1845,4650, # 3152 + 745, 432,1757, 428,1633, 888,2246,2221,2489,3611,2118,1258,1265, 956,3127,1784, # 3168 +4337,2490, 319, 510, 119, 457,3612, 274,2035,2007,4651,1409,3128, 970,2758, 590, # 3184 +2800, 661,2247,4652,2008,3950,1420,1549,3080,3322,3951,1651,1375,2111, 485,2491, # 3200 +1429,1156,6156,2548,2183,1495, 831,1840,2529,2446, 501,1657, 307,1894,3247,1341, # 3216 + 666, 899,2156,1539,2549,1559, 886, 349,2208,3081,2305,1736,3824,2170,2759,1014, # 3232 +1913,1386, 542,1397,2948, 490, 368, 716, 362, 159, 282,2569,1129,1658,1288,1750, # 3248 +2674, 276, 649,2016, 751,1496, 658,1818,1284,1862,2209,2087,2512,3451, 622,2834, # 3264 + 376, 117,1060,2053,1208,1721,1101,1443, 247,1250,3179,1792,3952,2760,2398,3953, # 3280 +6157,2144,3708, 446,2432,1151,2570,3452,2447,2761,2835,1210,2448,3082, 424,2222, # 3296 +1251,2449,2119,2836, 504,1581,4338, 602, 817, 857,3825,2349,2306, 357,3826,1470, # 3312 +1883,2883, 255, 958, 929,2917,3248, 302,4653,1050,1271,1751,2307,1952,1430,2697, # 3328 +2719,2359, 354,3180, 777, 158,2036,4339,1659,4340,4654,2308,2949,2248,1146,2232, # 3344 +3532,2720,1696,2623,3827,6158,3129,1550,2698,1485,1297,1428, 637, 931,2721,2145, # 3360 + 914,2550,2587, 81,2450, 612, 827,2646,1242,4655,1118,2884, 472,1855,3181,3533, # 3376 +3534, 569,1353,2699,1244,1758,2588,4119,2009,2762,2171,3709,1312,1531,6159,1152, # 3392 +1938, 134,1830, 471,3710,2276,1112,1535,3323,3453,3535, 982,1337,2950, 488, 826, # 3408 + 674,1058,1628,4120,2017, 522,2399, 211, 568,1367,3454, 350, 293,1872,1139,3249, # 3424 +1399,1946,3006,1300,2360,3324, 588, 736,6160,2606, 744, 669,3536,3828,6161,1358, # 3440 + 199, 723, 848, 933, 851,1939,1505,1514,1338,1618,1831,4656,1634,3613, 443,2740, # 3456 +3829, 717,1947, 491,1914,6162,2551,1542,4121,1025,6163,1099,1223, 198,3040,2722, # 3472 + 370, 410,1905,2589, 998,1248,3182,2380, 519,1449,4122,1710, 947, 928,1153,4341, # 3488 +2277, 344,2624,1511, 615, 105, 161,1212,1076,1960,3130,2054,1926,1175,1906,2473, # 3504 + 414,1873,2801,6164,2309, 315,1319,3325, 318,2018,2146,2157, 963, 631, 223,4342, # 3520 +4343,2675, 479,3711,1197,2625,3712,2676,2361,6165,4344,4123,6166,2451,3183,1886, # 3536 +2184,1674,1330,1711,1635,1506, 799, 219,3250,3083,3954,1677,3713,3326,2081,3614, # 3552 +1652,2073,4657,1147,3041,1752, 643,1961, 147,1974,3955,6167,1716,2037, 918,3007, # 3568 +1994, 120,1537, 118, 609,3184,4345, 740,3455,1219, 332,1615,3830,6168,1621,2980, # 3584 +1582, 783, 212, 553,2350,3714,1349,2433,2082,4124, 889,6169,2310,1275,1410, 973, # 3600 + 166,1320,3456,1797,1215,3185,2885,1846,2590,2763,4658, 629, 822,3008, 763, 940, # 3616 +1990,2862, 439,2409,1566,1240,1622, 926,1282,1907,2764, 654,2210,1607, 327,1130, # 3632 +3956,1678,1623,6170,2434,2192, 686, 608,3831,3715, 903,3957,3042,6171,2741,1522, # 3648 +1915,1105,1555,2552,1359, 323,3251,4346,3457, 738,1354,2553,2311,2334,1828,2003, # 3664 +3832,1753,2351,1227,6172,1887,4125,1478,6173,2410,1874,1712,1847, 520,1204,2607, # 3680 + 264,4659, 836,2677,2102, 600,4660,3833,2278,3084,6174,4347,3615,1342, 640, 532, # 3696 + 543,2608,1888,2400,2591,1009,4348,1497, 341,1737,3616,2723,1394, 529,3252,1321, # 3712 + 983,4661,1515,2120, 971,2592, 924, 287,1662,3186,4349,2700,4350,1519, 908,1948, # 3728 +2452, 156, 796,1629,1486,2223,2055, 694,4126,1259,1036,3392,1213,2249,2742,1889, # 3744 +1230,3958,1015, 910, 408, 559,3617,4662, 746, 725, 935,4663,3959,3009,1289, 563, # 3760 + 867,4664,3960,1567,2981,2038,2626, 988,2263,2381,4351, 143,2374, 704,1895,6175, # 3776 +1188,3716,2088, 673,3085,2362,4352, 484,1608,1921,2765,2918, 215, 904,3618,3537, # 3792 + 894, 509, 976,3043,2701,3961,4353,2837,2982, 498,6176,6177,1102,3538,1332,3393, # 3808 +1487,1636,1637, 233, 245,3962, 383, 650, 995,3044, 460,1520,1206,2352, 749,3327, # 3824 + 530, 700, 389,1438,1560,1773,3963,2264, 719,2951,2724,3834, 870,1832,1644,1000, # 3840 + 839,2474,3717, 197,1630,3394, 365,2886,3964,1285,2133, 734, 922, 818,1106, 732, # 3856 + 480,2083,1774,3458, 923,2279,1350, 221,3086, 85,2233,2234,3835,1585,3010,2147, # 3872 +1387,1705,2382,1619,2475, 133, 239,2802,1991,1016,2084,2383, 411,2838,1113, 651, # 3888 +1985,1160,3328, 990,1863,3087,1048,1276,2647, 265,2627,1599,3253,2056, 150, 638, # 3904 +2019, 656, 853, 326,1479, 680,1439,4354,1001,1759, 413,3459,3395,2492,1431, 459, # 3920 +4355,1125,3329,2265,1953,1450,2065,2863, 849, 351,2678,3131,3254,3255,1104,1577, # 3936 + 227,1351,1645,2453,2193,1421,2887, 812,2121, 634, 95,2435, 201,2312,4665,1646, # 3952 +1671,2743,1601,2554,2702,2648,2280,1315,1366,2089,3132,1573,3718,3965,1729,1189, # 3968 + 328,2679,1077,1940,1136, 558,1283, 964,1195, 621,2074,1199,1743,3460,3619,1896, # 3984 +1916,1890,3836,2952,1154,2112,1064, 862, 378,3011,2066,2113,2803,1568,2839,6178, # 4000 +3088,2919,1941,1660,2004,1992,2194, 142, 707,1590,1708,1624,1922,1023,1836,1233, # 4016 +1004,2313, 789, 741,3620,6179,1609,2411,1200,4127,3719,3720,4666,2057,3721, 593, # 4032 +2840, 367,2920,1878,6180,3461,1521, 628,1168, 692,2211,2649, 300, 720,2067,2571, # 4048 +2953,3396, 959,2504,3966,3539,3462,1977, 701,6181, 954,1043, 800, 681, 183,3722, # 4064 +1803,1730,3540,4128,2103, 815,2314, 174, 467, 230,2454,1093,2134, 755,3541,3397, # 4080 +1141,1162,6182,1738,2039, 270,3256,2513,1005,1647,2185,3837, 858,1679,1897,1719, # 4096 +2954,2324,1806, 402, 670, 167,4129,1498,2158,2104, 750,6183, 915, 189,1680,1551, # 4112 + 455,4356,1501,2455, 405,1095,2955, 338,1586,1266,1819, 570, 641,1324, 237,1556, # 4128 +2650,1388,3723,6184,1368,2384,1343,1978,3089,2436, 879,3724, 792,1191, 758,3012, # 4144 +1411,2135,1322,4357, 240,4667,1848,3725,1574,6185, 420,3045,1546,1391, 714,4358, # 4160 +1967, 941,1864, 863, 664, 426, 560,1731,2680,1785,2864,1949,2363, 403,3330,1415, # 4176 +1279,2136,1697,2335, 204, 721,2097,3838, 90,6186,2085,2505, 191,3967, 124,2148, # 4192 +1376,1798,1178,1107,1898,1405, 860,4359,1243,1272,2375,2983,1558,2456,1638, 113, # 4208 +3621, 578,1923,2609, 880, 386,4130, 784,2186,2266,1422,2956,2172,1722, 497, 263, # 4224 +2514,1267,2412,2610, 177,2703,3542, 774,1927,1344, 616,1432,1595,1018, 172,4360, # 4240 +2325, 911,4361, 438,1468,3622, 794,3968,2024,2173,1681,1829,2957, 945, 895,3090, # 4256 + 575,2212,2476, 475,2401,2681, 785,2744,1745,2293,2555,1975,3133,2865, 394,4668, # 4272 +3839, 635,4131, 639, 202,1507,2195,2766,1345,1435,2572,3726,1908,1184,1181,2457, # 4288 +3727,3134,4362, 843,2611, 437, 916,4669, 234, 769,1884,3046,3047,3623, 833,6187, # 4304 +1639,2250,2402,1355,1185,2010,2047, 999, 525,1732,1290,1488,2612, 948,1578,3728, # 4320 +2413,2477,1216,2725,2159, 334,3840,1328,3624,2921,1525,4132, 564,1056, 891,4363, # 4336 +1444,1698,2385,2251,3729,1365,2281,2235,1717,6188, 864,3841,2515, 444, 527,2767, # 4352 +2922,3625, 544, 461,6189, 566, 209,2437,3398,2098,1065,2068,3331,3626,3257,2137, # 4368 #last 512 +) + + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/jpcntx.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/jpcntx.py new file mode 100644 index 0000000..20044e4 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/jpcntx.py @@ -0,0 +1,233 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Communicator client code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + + +# This is hiragana 2-char sequence table, the number in each cell represents its frequency category +jp2CharContext = ( +(0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1), +(2,4,0,4,0,3,0,4,0,3,4,4,4,2,4,3,3,4,3,2,3,3,4,2,3,3,3,2,4,1,4,3,3,1,5,4,3,4,3,4,3,5,3,0,3,5,4,2,0,3,1,0,3,3,0,3,3,0,1,1,0,4,3,0,3,3,0,4,0,2,0,3,5,5,5,5,4,0,4,1,0,3,4), +(0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2), +(0,4,0,5,0,5,0,4,0,4,5,4,4,3,5,3,5,1,5,3,4,3,4,4,3,4,3,3,4,3,5,4,4,3,5,5,3,5,5,5,3,5,5,3,4,5,5,3,1,3,2,0,3,4,0,4,2,0,4,2,1,5,3,2,3,5,0,4,0,2,0,5,4,4,5,4,5,0,4,0,0,4,4), +(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0), +(0,3,0,4,0,3,0,3,0,4,5,4,3,3,3,3,4,3,5,4,4,3,5,4,4,3,4,3,4,4,4,4,5,3,4,4,3,4,5,5,4,5,5,1,4,5,4,3,0,3,3,1,3,3,0,4,4,0,3,3,1,5,3,3,3,5,0,4,0,3,0,4,4,3,4,3,3,0,4,1,1,3,4), +(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0), +(0,4,0,3,0,3,0,4,0,3,4,4,3,2,2,1,2,1,3,1,3,3,3,3,3,4,3,1,3,3,5,3,3,0,4,3,0,5,4,3,3,5,4,4,3,4,4,5,0,1,2,0,1,2,0,2,2,0,1,0,0,5,2,2,1,4,0,3,0,1,0,4,4,3,5,4,3,0,2,1,0,4,3), +(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0), +(0,3,0,5,0,4,0,2,1,4,4,2,4,1,4,2,4,2,4,3,3,3,4,3,3,3,3,1,4,2,3,3,3,1,4,4,1,1,1,4,3,3,2,0,2,4,3,2,0,3,3,0,3,1,1,0,0,0,3,3,0,4,2,2,3,4,0,4,0,3,0,4,4,5,3,4,4,0,3,0,0,1,4), +(1,4,0,4,0,4,0,4,0,3,5,4,4,3,4,3,5,4,3,3,4,3,5,4,4,4,4,3,4,2,4,3,3,1,5,4,3,2,4,5,4,5,5,4,4,5,4,4,0,3,2,2,3,3,0,4,3,1,3,2,1,4,3,3,4,5,0,3,0,2,0,4,5,5,4,5,4,0,4,0,0,5,4), +(0,5,0,5,0,4,0,3,0,4,4,3,4,3,3,3,4,0,4,4,4,3,4,3,4,3,3,1,4,2,4,3,4,0,5,4,1,4,5,4,4,5,3,2,4,3,4,3,2,4,1,3,3,3,2,3,2,0,4,3,3,4,3,3,3,4,0,4,0,3,0,4,5,4,4,4,3,0,4,1,0,1,3), +(0,3,1,4,0,3,0,2,0,3,4,4,3,1,4,2,3,3,4,3,4,3,4,3,4,4,3,2,3,1,5,4,4,1,4,4,3,5,4,4,3,5,5,4,3,4,4,3,1,2,3,1,2,2,0,3,2,0,3,1,0,5,3,3,3,4,3,3,3,3,4,4,4,4,5,4,2,0,3,3,2,4,3), +(0,2,0,3,0,1,0,1,0,0,3,2,0,0,2,0,1,0,2,1,3,3,3,1,2,3,1,0,1,0,4,2,1,1,3,3,0,4,3,3,1,4,3,3,0,3,3,2,0,0,0,0,1,0,0,2,0,0,0,0,0,4,1,0,2,3,2,2,2,1,3,3,3,4,4,3,2,0,3,1,0,3,3), +(0,4,0,4,0,3,0,3,0,4,4,4,3,3,3,3,3,3,4,3,4,2,4,3,4,3,3,2,4,3,4,5,4,1,4,5,3,5,4,5,3,5,4,0,3,5,5,3,1,3,3,2,2,3,0,3,4,1,3,3,2,4,3,3,3,4,0,4,0,3,0,4,5,4,4,5,3,0,4,1,0,3,4), +(0,2,0,3,0,3,0,0,0,2,2,2,1,0,1,0,0,0,3,0,3,0,3,0,1,3,1,0,3,1,3,3,3,1,3,3,3,0,1,3,1,3,4,0,0,3,1,1,0,3,2,0,0,0,0,1,3,0,1,0,0,3,3,2,0,3,0,0,0,0,0,3,4,3,4,3,3,0,3,0,0,2,3), +(2,3,0,3,0,2,0,1,0,3,3,4,3,1,3,1,1,1,3,1,4,3,4,3,3,3,0,0,3,1,5,4,3,1,4,3,2,5,5,4,4,4,4,3,3,4,4,4,0,2,1,1,3,2,0,1,2,0,0,1,0,4,1,3,3,3,0,3,0,1,0,4,4,4,5,5,3,0,2,0,0,4,4), +(0,2,0,1,0,3,1,3,0,2,3,3,3,0,3,1,0,0,3,0,3,2,3,1,3,2,1,1,0,0,4,2,1,0,2,3,1,4,3,2,0,4,4,3,1,3,1,3,0,1,0,0,1,0,0,0,1,0,0,0,0,4,1,1,1,2,0,3,0,0,0,3,4,2,4,3,2,0,1,0,0,3,3), +(0,1,0,4,0,5,0,4,0,2,4,4,2,3,3,2,3,3,5,3,3,3,4,3,4,2,3,0,4,3,3,3,4,1,4,3,2,1,5,5,3,4,5,1,3,5,4,2,0,3,3,0,1,3,0,4,2,0,1,3,1,4,3,3,3,3,0,3,0,1,0,3,4,4,4,5,5,0,3,0,1,4,5), +(0,2,0,3,0,3,0,0,0,2,3,1,3,0,4,0,1,1,3,0,3,4,3,2,3,1,0,3,3,2,3,1,3,0,2,3,0,2,1,4,1,2,2,0,0,3,3,0,0,2,0,0,0,1,0,0,0,0,2,2,0,3,2,1,3,3,0,2,0,2,0,0,3,3,1,2,4,0,3,0,2,2,3), +(2,4,0,5,0,4,0,4,0,2,4,4,4,3,4,3,3,3,1,2,4,3,4,3,4,4,5,0,3,3,3,3,2,0,4,3,1,4,3,4,1,4,4,3,3,4,4,3,1,2,3,0,4,2,0,4,1,0,3,3,0,4,3,3,3,4,0,4,0,2,0,3,5,3,4,5,2,0,3,0,0,4,5), +(0,3,0,4,0,1,0,1,0,1,3,2,2,1,3,0,3,0,2,0,2,0,3,0,2,0,0,0,1,0,1,1,0,0,3,1,0,0,0,4,0,3,1,0,2,1,3,0,0,0,0,0,0,3,0,0,0,0,0,0,0,4,2,2,3,1,0,3,0,0,0,1,4,4,4,3,0,0,4,0,0,1,4), +(1,4,1,5,0,3,0,3,0,4,5,4,4,3,5,3,3,4,4,3,4,1,3,3,3,3,2,1,4,1,5,4,3,1,4,4,3,5,4,4,3,5,4,3,3,4,4,4,0,3,3,1,2,3,0,3,1,0,3,3,0,5,4,4,4,4,4,4,3,3,5,4,4,3,3,5,4,0,3,2,0,4,4), +(0,2,0,3,0,1,0,0,0,1,3,3,3,2,4,1,3,0,3,1,3,0,2,2,1,1,0,0,2,0,4,3,1,0,4,3,0,4,4,4,1,4,3,1,1,3,3,1,0,2,0,0,1,3,0,0,0,0,2,0,0,4,3,2,4,3,5,4,3,3,3,4,3,3,4,3,3,0,2,1,0,3,3), +(0,2,0,4,0,3,0,2,0,2,5,5,3,4,4,4,4,1,4,3,3,0,4,3,4,3,1,3,3,2,4,3,0,3,4,3,0,3,4,4,2,4,4,0,4,5,3,3,2,2,1,1,1,2,0,1,5,0,3,3,2,4,3,3,3,4,0,3,0,2,0,4,4,3,5,5,0,0,3,0,2,3,3), +(0,3,0,4,0,3,0,1,0,3,4,3,3,1,3,3,3,0,3,1,3,0,4,3,3,1,1,0,3,0,3,3,0,0,4,4,0,1,5,4,3,3,5,0,3,3,4,3,0,2,0,1,1,1,0,1,3,0,1,2,1,3,3,2,3,3,0,3,0,1,0,1,3,3,4,4,1,0,1,2,2,1,3), +(0,1,0,4,0,4,0,3,0,1,3,3,3,2,3,1,1,0,3,0,3,3,4,3,2,4,2,0,1,0,4,3,2,0,4,3,0,5,3,3,2,4,4,4,3,3,3,4,0,1,3,0,0,1,0,0,1,0,0,0,0,4,2,3,3,3,0,3,0,0,0,4,4,4,5,3,2,0,3,3,0,3,5), +(0,2,0,3,0,0,0,3,0,1,3,0,2,0,0,0,1,0,3,1,1,3,3,0,0,3,0,0,3,0,2,3,1,0,3,1,0,3,3,2,0,4,2,2,0,2,0,0,0,4,0,0,0,0,0,0,0,0,0,0,0,2,1,2,0,1,0,1,0,0,0,1,3,1,2,0,0,0,1,0,0,1,4), +(0,3,0,3,0,5,0,1,0,2,4,3,1,3,3,2,1,1,5,2,1,0,5,1,2,0,0,0,3,3,2,2,3,2,4,3,0,0,3,3,1,3,3,0,2,5,3,4,0,3,3,0,1,2,0,2,2,0,3,2,0,2,2,3,3,3,0,2,0,1,0,3,4,4,2,5,4,0,3,0,0,3,5), +(0,3,0,3,0,3,0,1,0,3,3,3,3,0,3,0,2,0,2,1,1,0,2,0,1,0,0,0,2,1,0,0,1,0,3,2,0,0,3,3,1,2,3,1,0,3,3,0,0,1,0,0,0,0,0,2,0,0,0,0,0,2,3,1,2,3,0,3,0,1,0,3,2,1,0,4,3,0,1,1,0,3,3), +(0,4,0,5,0,3,0,3,0,4,5,5,4,3,5,3,4,3,5,3,3,2,5,3,4,4,4,3,4,3,4,5,5,3,4,4,3,4,4,5,4,4,4,3,4,5,5,4,2,3,4,2,3,4,0,3,3,1,4,3,2,4,3,3,5,5,0,3,0,3,0,5,5,5,5,4,4,0,4,0,1,4,4), +(0,4,0,4,0,3,0,3,0,3,5,4,4,2,3,2,5,1,3,2,5,1,4,2,3,2,3,3,4,3,3,3,3,2,5,4,1,3,3,5,3,4,4,0,4,4,3,1,1,3,1,0,2,3,0,2,3,0,3,0,0,4,3,1,3,4,0,3,0,2,0,4,4,4,3,4,5,0,4,0,0,3,4), +(0,3,0,3,0,3,1,2,0,3,4,4,3,3,3,0,2,2,4,3,3,1,3,3,3,1,1,0,3,1,4,3,2,3,4,4,2,4,4,4,3,4,4,3,2,4,4,3,1,3,3,1,3,3,0,4,1,0,2,2,1,4,3,2,3,3,5,4,3,3,5,4,4,3,3,0,4,0,3,2,2,4,4), +(0,2,0,1,0,0,0,0,0,1,2,1,3,0,0,0,0,0,2,0,1,2,1,0,0,1,0,0,0,0,3,0,0,1,0,1,1,3,1,0,0,0,1,1,0,1,1,0,0,0,0,0,2,0,0,0,0,0,0,0,0,1,1,2,2,0,3,4,0,0,0,1,1,0,0,1,0,0,0,0,0,1,1), +(0,1,0,0,0,1,0,0,0,0,4,0,4,1,4,0,3,0,4,0,3,0,4,0,3,0,3,0,4,1,5,1,4,0,0,3,0,5,0,5,2,0,1,0,0,0,2,1,4,0,1,3,0,0,3,0,0,3,1,1,4,1,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0), +(1,4,0,5,0,3,0,2,0,3,5,4,4,3,4,3,5,3,4,3,3,0,4,3,3,3,3,3,3,2,4,4,3,1,3,4,4,5,4,4,3,4,4,1,3,5,4,3,3,3,1,2,2,3,3,1,3,1,3,3,3,5,3,3,4,5,0,3,0,3,0,3,4,3,4,4,3,0,3,0,2,4,3), +(0,1,0,4,0,0,0,0,0,1,4,0,4,1,4,2,4,0,3,0,1,0,1,0,0,0,0,0,2,0,3,1,1,1,0,3,0,0,0,1,2,1,0,0,1,1,1,1,0,1,0,0,0,1,0,0,3,0,0,0,0,3,2,0,2,2,0,1,0,0,0,2,3,2,3,3,0,0,0,0,2,1,0), +(0,5,1,5,0,3,0,3,0,5,4,4,5,1,5,3,3,0,4,3,4,3,5,3,4,3,3,2,4,3,4,3,3,0,3,3,1,4,4,3,4,4,4,3,4,5,5,3,2,3,1,1,3,3,1,3,1,1,3,3,2,4,5,3,3,5,0,4,0,3,0,4,4,3,5,3,3,0,3,4,0,4,3), +(0,5,0,5,0,3,0,2,0,4,4,3,5,2,4,3,3,3,4,4,4,3,5,3,5,3,3,1,4,0,4,3,3,0,3,3,0,4,4,4,4,5,4,3,3,5,5,3,2,3,1,2,3,2,0,1,0,0,3,2,2,4,4,3,1,5,0,4,0,3,0,4,3,1,3,2,1,0,3,3,0,3,3), +(0,4,0,5,0,5,0,4,0,4,5,5,5,3,4,3,3,2,5,4,4,3,5,3,5,3,4,0,4,3,4,4,3,2,4,4,3,4,5,4,4,5,5,0,3,5,5,4,1,3,3,2,3,3,1,3,1,0,4,3,1,4,4,3,4,5,0,4,0,2,0,4,3,4,4,3,3,0,4,0,0,5,5), +(0,4,0,4,0,5,0,1,1,3,3,4,4,3,4,1,3,0,5,1,3,0,3,1,3,1,1,0,3,0,3,3,4,0,4,3,0,4,4,4,3,4,4,0,3,5,4,1,0,3,0,0,2,3,0,3,1,0,3,1,0,3,2,1,3,5,0,3,0,1,0,3,2,3,3,4,4,0,2,2,0,4,4), +(2,4,0,5,0,4,0,3,0,4,5,5,4,3,5,3,5,3,5,3,5,2,5,3,4,3,3,4,3,4,5,3,2,1,5,4,3,2,3,4,5,3,4,1,2,5,4,3,0,3,3,0,3,2,0,2,3,0,4,1,0,3,4,3,3,5,0,3,0,1,0,4,5,5,5,4,3,0,4,2,0,3,5), +(0,5,0,4,0,4,0,2,0,5,4,3,4,3,4,3,3,3,4,3,4,2,5,3,5,3,4,1,4,3,4,4,4,0,3,5,0,4,4,4,4,5,3,1,3,4,5,3,3,3,3,3,3,3,0,2,2,0,3,3,2,4,3,3,3,5,3,4,1,3,3,5,3,2,0,0,0,0,4,3,1,3,3), +(0,1,0,3,0,3,0,1,0,1,3,3,3,2,3,3,3,0,3,0,0,0,3,1,3,0,0,0,2,2,2,3,0,0,3,2,0,1,2,4,1,3,3,0,0,3,3,3,0,1,0,0,2,1,0,0,3,0,3,1,0,3,0,0,1,3,0,2,0,1,0,3,3,1,3,3,0,0,1,1,0,3,3), +(0,2,0,3,0,2,1,4,0,2,2,3,1,1,3,1,1,0,2,0,3,1,2,3,1,3,0,0,1,0,4,3,2,3,3,3,1,4,2,3,3,3,3,1,0,3,1,4,0,1,1,0,1,2,0,1,1,0,1,1,0,3,1,3,2,2,0,1,0,0,0,2,3,3,3,1,0,0,0,0,0,2,3), +(0,5,0,4,0,5,0,2,0,4,5,5,3,3,4,3,3,1,5,4,4,2,4,4,4,3,4,2,4,3,5,5,4,3,3,4,3,3,5,5,4,5,5,1,3,4,5,3,1,4,3,1,3,3,0,3,3,1,4,3,1,4,5,3,3,5,0,4,0,3,0,5,3,3,1,4,3,0,4,0,1,5,3), +(0,5,0,5,0,4,0,2,0,4,4,3,4,3,3,3,3,3,5,4,4,4,4,4,4,5,3,3,5,2,4,4,4,3,4,4,3,3,4,4,5,5,3,3,4,3,4,3,3,4,3,3,3,3,1,2,2,1,4,3,3,5,4,4,3,4,0,4,0,3,0,4,4,4,4,4,1,0,4,2,0,2,4), +(0,4,0,4,0,3,0,1,0,3,5,2,3,0,3,0,2,1,4,2,3,3,4,1,4,3,3,2,4,1,3,3,3,0,3,3,0,0,3,3,3,5,3,3,3,3,3,2,0,2,0,0,2,0,0,2,0,0,1,0,0,3,1,2,2,3,0,3,0,2,0,4,4,3,3,4,1,0,3,0,0,2,4), +(0,0,0,4,0,0,0,0,0,0,1,0,1,0,2,0,0,0,0,0,1,0,2,0,1,0,0,0,0,0,3,1,3,0,3,2,0,0,0,1,0,3,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,4,0,2,0,0,0,0,0,0,2), +(0,2,1,3,0,2,0,2,0,3,3,3,3,1,3,1,3,3,3,3,3,3,4,2,2,1,2,1,4,0,4,3,1,3,3,3,2,4,3,5,4,3,3,3,3,3,3,3,0,1,3,0,2,0,0,1,0,0,1,0,0,4,2,0,2,3,0,3,3,0,3,3,4,2,3,1,4,0,1,2,0,2,3), +(0,3,0,3,0,1,0,3,0,2,3,3,3,0,3,1,2,0,3,3,2,3,3,2,3,2,3,1,3,0,4,3,2,0,3,3,1,4,3,3,2,3,4,3,1,3,3,1,1,0,1,1,0,1,0,1,0,1,0,0,0,4,1,1,0,3,0,3,1,0,2,3,3,3,3,3,1,0,0,2,0,3,3), +(0,0,0,0,0,0,0,0,0,0,3,0,2,0,3,0,0,0,0,0,0,0,3,0,0,0,0,0,0,0,3,0,3,0,3,1,0,1,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,0,2,0,2,3,0,0,0,0,0,0,0,0,3), +(0,2,0,3,1,3,0,3,0,2,3,3,3,1,3,1,3,1,3,1,3,3,3,1,3,0,2,3,1,1,4,3,3,2,3,3,1,2,2,4,1,3,3,0,1,4,2,3,0,1,3,0,3,0,0,1,3,0,2,0,0,3,3,2,1,3,0,3,0,2,0,3,4,4,4,3,1,0,3,0,0,3,3), +(0,2,0,1,0,2,0,0,0,1,3,2,2,1,3,0,1,1,3,0,3,2,3,1,2,0,2,0,1,1,3,3,3,0,3,3,1,1,2,3,2,3,3,1,2,3,2,0,0,1,0,0,0,0,0,0,3,0,1,0,0,2,1,2,1,3,0,3,0,0,0,3,4,4,4,3,2,0,2,0,0,2,4), +(0,0,0,1,0,1,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,1,1,1,0,0,0,0,0,0,0,0,0,2,2,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,1,3,1,0,0,0,0,0,0,0,3), +(0,3,0,3,0,2,0,3,0,3,3,3,2,3,2,2,2,0,3,1,3,3,3,2,3,3,0,0,3,0,3,2,2,0,2,3,1,4,3,4,3,3,2,3,1,5,4,4,0,3,1,2,1,3,0,3,1,1,2,0,2,3,1,3,1,3,0,3,0,1,0,3,3,4,4,2,1,0,2,1,0,2,4), +(0,1,0,3,0,1,0,2,0,1,4,2,5,1,4,0,2,0,2,1,3,1,4,0,2,1,0,0,2,1,4,1,1,0,3,3,0,5,1,3,2,3,3,1,0,3,2,3,0,1,0,0,0,0,0,0,1,0,0,0,0,4,0,1,0,3,0,2,0,1,0,3,3,3,4,3,3,0,0,0,0,2,3), +(0,0,0,1,0,0,0,0,0,0,2,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,1,0,0,1,0,0,0,0,0,3), +(0,1,0,3,0,4,0,3,0,2,4,3,1,0,3,2,2,1,3,1,2,2,3,1,1,1,2,1,3,0,1,2,0,1,3,2,1,3,0,5,5,1,0,0,1,3,2,1,0,3,0,0,1,0,0,0,0,0,3,4,0,1,1,1,3,2,0,2,0,1,0,2,3,3,1,2,3,0,1,0,1,0,4), +(0,0,0,1,0,3,0,3,0,2,2,1,0,0,4,0,3,0,3,1,3,0,3,0,3,0,1,0,3,0,3,1,3,0,3,3,0,0,1,2,1,1,1,0,1,2,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,2,2,1,2,0,0,2,0,0,0,0,2,3,3,3,3,0,0,0,0,1,4), +(0,0,0,3,0,3,0,0,0,0,3,1,1,0,3,0,1,0,2,0,1,0,0,0,0,0,0,0,1,0,3,0,2,0,2,3,0,0,2,2,3,1,2,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,0,0,2,0,0,0,0,2,3), +(2,4,0,5,0,5,0,4,0,3,4,3,3,3,4,3,3,3,4,3,4,4,5,4,5,5,5,2,3,0,5,5,4,1,5,4,3,1,5,4,3,4,4,3,3,4,3,3,0,3,2,0,2,3,0,3,0,0,3,3,0,5,3,2,3,3,0,3,0,3,0,3,4,5,4,5,3,0,4,3,0,3,4), +(0,3,0,3,0,3,0,3,0,3,3,4,3,2,3,2,3,0,4,3,3,3,3,3,3,3,3,0,3,2,4,3,3,1,3,4,3,4,4,4,3,4,4,3,2,4,4,1,0,2,0,0,1,1,0,2,0,0,3,1,0,5,3,2,1,3,0,3,0,1,2,4,3,2,4,3,3,0,3,2,0,4,4), +(0,3,0,3,0,1,0,0,0,1,4,3,3,2,3,1,3,1,4,2,3,2,4,2,3,4,3,0,2,2,3,3,3,0,3,3,3,0,3,4,1,3,3,0,3,4,3,3,0,1,1,0,1,0,0,0,4,0,3,0,0,3,1,2,1,3,0,4,0,1,0,4,3,3,4,3,3,0,2,0,0,3,3), +(0,3,0,4,0,1,0,3,0,3,4,3,3,0,3,3,3,1,3,1,3,3,4,3,3,3,0,0,3,1,5,3,3,1,3,3,2,5,4,3,3,4,5,3,2,5,3,4,0,1,0,0,0,0,0,2,0,0,1,1,0,4,2,2,1,3,0,3,0,2,0,4,4,3,5,3,2,0,1,1,0,3,4), +(0,5,0,4,0,5,0,2,0,4,4,3,3,2,3,3,3,1,4,3,4,1,5,3,4,3,4,0,4,2,4,3,4,1,5,4,0,4,4,4,4,5,4,1,3,5,4,2,1,4,1,1,3,2,0,3,1,0,3,2,1,4,3,3,3,4,0,4,0,3,0,4,4,4,3,3,3,0,4,2,0,3,4), +(1,4,0,4,0,3,0,1,0,3,3,3,1,1,3,3,2,2,3,3,1,0,3,2,2,1,2,0,3,1,2,1,2,0,3,2,0,2,2,3,3,4,3,0,3,3,1,2,0,1,1,3,1,2,0,0,3,0,1,1,0,3,2,2,3,3,0,3,0,0,0,2,3,3,4,3,3,0,1,0,0,1,4), +(0,4,0,4,0,4,0,0,0,3,4,4,3,1,4,2,3,2,3,3,3,1,4,3,4,0,3,0,4,2,3,3,2,2,5,4,2,1,3,4,3,4,3,1,3,3,4,2,0,2,1,0,3,3,0,0,2,0,3,1,0,4,4,3,4,3,0,4,0,1,0,2,4,4,4,4,4,0,3,2,0,3,3), +(0,0,0,1,0,4,0,0,0,0,0,0,1,1,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,3,2,0,0,1,0,0,0,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,2), +(0,2,0,3,0,4,0,4,0,1,3,3,3,0,4,0,2,1,2,1,1,1,2,0,3,1,1,0,1,0,3,1,0,0,3,3,2,0,1,1,0,0,0,0,0,1,0,2,0,2,2,0,3,1,0,0,1,0,1,1,0,1,2,0,3,0,0,0,0,1,0,0,3,3,4,3,1,0,1,0,3,0,2), +(0,0,0,3,0,5,0,0,0,0,1,0,2,0,3,1,0,1,3,0,0,0,2,0,0,0,1,0,0,0,1,1,0,0,4,0,0,0,2,3,0,1,4,1,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,1,0,0,0,0,0,0,0,2,0,0,3,0,0,0,0,0,3), +(0,2,0,5,0,5,0,1,0,2,4,3,3,2,5,1,3,2,3,3,3,0,4,1,2,0,3,0,4,0,2,2,1,1,5,3,0,0,1,4,2,3,2,0,3,3,3,2,0,2,4,1,1,2,0,1,1,0,3,1,0,1,3,1,2,3,0,2,0,0,0,1,3,5,4,4,4,0,3,0,0,1,3), +(0,4,0,5,0,4,0,4,0,4,5,4,3,3,4,3,3,3,4,3,4,4,5,3,4,5,4,2,4,2,3,4,3,1,4,4,1,3,5,4,4,5,5,4,4,5,5,5,2,3,3,1,4,3,1,3,3,0,3,3,1,4,3,4,4,4,0,3,0,4,0,3,3,4,4,5,0,0,4,3,0,4,5), +(0,4,0,4,0,3,0,3,0,3,4,4,4,3,3,2,4,3,4,3,4,3,5,3,4,3,2,1,4,2,4,4,3,1,3,4,2,4,5,5,3,4,5,4,1,5,4,3,0,3,2,2,3,2,1,3,1,0,3,3,3,5,3,3,3,5,4,4,2,3,3,4,3,3,3,2,1,0,3,2,1,4,3), +(0,4,0,5,0,4,0,3,0,3,5,5,3,2,4,3,4,0,5,4,4,1,4,4,4,3,3,3,4,3,5,5,2,3,3,4,1,2,5,5,3,5,5,2,3,5,5,4,0,3,2,0,3,3,1,1,5,1,4,1,0,4,3,2,3,5,0,4,0,3,0,5,4,3,4,3,0,0,4,1,0,4,4), +(1,3,0,4,0,2,0,2,0,2,5,5,3,3,3,3,3,0,4,2,3,4,4,4,3,4,0,0,3,4,5,4,3,3,3,3,2,5,5,4,5,5,5,4,3,5,5,5,1,3,1,0,1,0,0,3,2,0,4,2,0,5,2,3,2,4,1,3,0,3,0,4,5,4,5,4,3,0,4,2,0,5,4), +(0,3,0,4,0,5,0,3,0,3,4,4,3,2,3,2,3,3,3,3,3,2,4,3,3,2,2,0,3,3,3,3,3,1,3,3,3,0,4,4,3,4,4,1,1,4,4,2,0,3,1,0,1,1,0,4,1,0,2,3,1,3,3,1,3,4,0,3,0,1,0,3,1,3,0,0,1,0,2,0,0,4,4), +(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0), +(0,3,0,3,0,2,0,3,0,1,5,4,3,3,3,1,4,2,1,2,3,4,4,2,4,4,5,0,3,1,4,3,4,0,4,3,3,3,2,3,2,5,3,4,3,2,2,3,0,0,3,0,2,1,0,1,2,0,0,0,0,2,1,1,3,1,0,2,0,4,0,3,4,4,4,5,2,0,2,0,0,1,3), +(0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,1,1,1,0,0,1,1,0,0,0,4,2,1,1,0,1,0,3,2,0,0,3,1,1,1,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,0,1,0,0,0,2,0,0,0,1,4,0,4,2,1,0,0,0,0,0,1), +(0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,0,1,0,1,0,0,0,0,3,1,0,0,0,2,0,2,1,0,0,1,2,1,0,1,1,0,0,3,0,0,0,0,0,0,0,0,0,0,0,1,3,1,0,0,0,0,0,1,0,0,2,1,0,0,0,0,0,0,0,0,2), +(0,4,0,4,0,4,0,3,0,4,4,3,4,2,4,3,2,0,4,4,4,3,5,3,5,3,3,2,4,2,4,3,4,3,1,4,0,2,3,4,4,4,3,3,3,4,4,4,3,4,1,3,4,3,2,1,2,1,3,3,3,4,4,3,3,5,0,4,0,3,0,4,3,3,3,2,1,0,3,0,0,3,3), +(0,4,0,3,0,3,0,3,0,3,5,5,3,3,3,3,4,3,4,3,3,3,4,4,4,3,3,3,3,4,3,5,3,3,1,3,2,4,5,5,5,5,4,3,4,5,5,3,2,2,3,3,3,3,2,3,3,1,2,3,2,4,3,3,3,4,0,4,0,2,0,4,3,2,2,1,2,0,3,0,0,4,1), +) + +class JapaneseContextAnalysis(object): + NUM_OF_CATEGORY = 6 + DONT_KNOW = -1 + ENOUGH_REL_THRESHOLD = 100 + MAX_REL_THRESHOLD = 1000 + MINIMUM_DATA_THRESHOLD = 4 + + def __init__(self): + self._total_rel = None + self._rel_sample = None + self._need_to_skip_char_num = None + self._last_char_order = None + self._done = None + self.reset() + + def reset(self): + self._total_rel = 0 # total sequence received + # category counters, each integer counts sequence in its category + self._rel_sample = [0] * self.NUM_OF_CATEGORY + # if last byte in current buffer is not the last byte of a character, + # we need to know how many bytes to skip in next buffer + self._need_to_skip_char_num = 0 + self._last_char_order = -1 # The order of previous char + # If this flag is set to True, detection is done and conclusion has + # been made + self._done = False + + def feed(self, byte_str, num_bytes): + if self._done: + return + + # The buffer we got is byte oriented, and a character may span in more than one + # buffers. In case the last one or two byte in last buffer is not + # complete, we record how many byte needed to complete that character + # and skip these bytes here. We can choose to record those bytes as + # well and analyse the character once it is complete, but since a + # character will not make much difference, by simply skipping + # this character will simply our logic and improve performance. + i = self._need_to_skip_char_num + while i < num_bytes: + order, char_len = self.get_order(byte_str[i:i + 2]) + i += char_len + if i > num_bytes: + self._need_to_skip_char_num = i - num_bytes + self._last_char_order = -1 + else: + if (order != -1) and (self._last_char_order != -1): + self._total_rel += 1 + if self._total_rel > self.MAX_REL_THRESHOLD: + self._done = True + break + self._rel_sample[jp2CharContext[self._last_char_order][order]] += 1 + self._last_char_order = order + + def got_enough_data(self): + return self._total_rel > self.ENOUGH_REL_THRESHOLD + + def get_confidence(self): + # This is just one way to calculate confidence. It works well for me. + if self._total_rel > self.MINIMUM_DATA_THRESHOLD: + return (self._total_rel - self._rel_sample[0]) / self._total_rel + else: + return self.DONT_KNOW + + def get_order(self, byte_str): + return -1, 1 + +class SJISContextAnalysis(JapaneseContextAnalysis): + def __init__(self): + super(SJISContextAnalysis, self).__init__() + self._charset_name = "SHIFT_JIS" + + @property + def charset_name(self): + return self._charset_name + + def get_order(self, byte_str): + if not byte_str: + return -1, 1 + # find out current char's byte length + first_char = byte_str[0] + if (0x81 <= first_char <= 0x9F) or (0xE0 <= first_char <= 0xFC): + char_len = 2 + if (first_char == 0x87) or (0xFA <= first_char <= 0xFC): + self._charset_name = "CP932" + else: + char_len = 1 + + # return its order if it is hiragana + if len(byte_str) > 1: + second_char = byte_str[1] + if (first_char == 202) and (0x9F <= second_char <= 0xF1): + return second_char - 0x9F, char_len + + return -1, char_len + +class EUCJPContextAnalysis(JapaneseContextAnalysis): + def get_order(self, byte_str): + if not byte_str: + return -1, 1 + # find out current char's byte length + first_char = byte_str[0] + if (first_char == 0x8E) or (0xA1 <= first_char <= 0xFE): + char_len = 2 + elif first_char == 0x8F: + char_len = 3 + else: + char_len = 1 + + # return its order if it is hiragana + if len(byte_str) > 1: + second_char = byte_str[1] + if (first_char == 0xA4) and (0xA1 <= second_char <= 0xF3): + return second_char - 0xA1, char_len + + return -1, char_len + + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langbulgarianmodel.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langbulgarianmodel.py new file mode 100644 index 0000000..2aa4fb2 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langbulgarianmodel.py @@ -0,0 +1,228 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Communicator client code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +# 255: Control characters that usually does not exist in any text +# 254: Carriage/Return +# 253: symbol (punctuation) that does not belong to word +# 252: 0 - 9 + +# Character Mapping Table: +# this table is modified base on win1251BulgarianCharToOrderMap, so +# only number <64 is sure valid + +Latin5_BulgarianCharToOrderMap = ( +255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255, # 00 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 10 +253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253, # 20 +252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253, # 30 +253, 77, 90, 99,100, 72,109,107,101, 79,185, 81,102, 76, 94, 82, # 40 +110,186,108, 91, 74,119, 84, 96,111,187,115,253,253,253,253,253, # 50 +253, 65, 69, 70, 66, 63, 68,112,103, 92,194,104, 95, 86, 87, 71, # 60 +116,195, 85, 93, 97,113,196,197,198,199,200,253,253,253,253,253, # 70 +194,195,196,197,198,199,200,201,202,203,204,205,206,207,208,209, # 80 +210,211,212,213,214,215,216,217,218,219,220,221,222,223,224,225, # 90 + 81,226,227,228,229,230,105,231,232,233,234,235,236, 45,237,238, # a0 + 31, 32, 35, 43, 37, 44, 55, 47, 40, 59, 33, 46, 38, 36, 41, 30, # b0 + 39, 28, 34, 51, 48, 49, 53, 50, 54, 57, 61,239, 67,240, 60, 56, # c0 + 1, 18, 9, 20, 11, 3, 23, 15, 2, 26, 12, 10, 14, 6, 4, 13, # d0 + 7, 8, 5, 19, 29, 25, 22, 21, 27, 24, 17, 75, 52,241, 42, 16, # e0 + 62,242,243,244, 58,245, 98,246,247,248,249,250,251, 91,252,253, # f0 +) + +win1251BulgarianCharToOrderMap = ( +255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255, # 00 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 10 +253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253, # 20 +252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253, # 30 +253, 77, 90, 99,100, 72,109,107,101, 79,185, 81,102, 76, 94, 82, # 40 +110,186,108, 91, 74,119, 84, 96,111,187,115,253,253,253,253,253, # 50 +253, 65, 69, 70, 66, 63, 68,112,103, 92,194,104, 95, 86, 87, 71, # 60 +116,195, 85, 93, 97,113,196,197,198,199,200,253,253,253,253,253, # 70 +206,207,208,209,210,211,212,213,120,214,215,216,217,218,219,220, # 80 +221, 78, 64, 83,121, 98,117,105,222,223,224,225,226,227,228,229, # 90 + 88,230,231,232,233,122, 89,106,234,235,236,237,238, 45,239,240, # a0 + 73, 80,118,114,241,242,243,244,245, 62, 58,246,247,248,249,250, # b0 + 31, 32, 35, 43, 37, 44, 55, 47, 40, 59, 33, 46, 38, 36, 41, 30, # c0 + 39, 28, 34, 51, 48, 49, 53, 50, 54, 57, 61,251, 67,252, 60, 56, # d0 + 1, 18, 9, 20, 11, 3, 23, 15, 2, 26, 12, 10, 14, 6, 4, 13, # e0 + 7, 8, 5, 19, 29, 25, 22, 21, 27, 24, 17, 75, 52,253, 42, 16, # f0 +) + +# Model Table: +# total sequences: 100% +# first 512 sequences: 96.9392% +# first 1024 sequences:3.0618% +# rest sequences: 0.2992% +# negative sequences: 0.0020% +BulgarianLangModel = ( +0,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,3,3,2,3,3,3,3,3, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,0,3,3,3,2,2,3,2,2,1,2,2, +3,1,3,3,2,3,3,3,3,3,3,3,3,3,3,3,3,0,3,3,3,3,3,3,3,3,3,3,0,3,0,1, +0,0,0,0,0,0,0,0,0,0,1,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,2,3,3,3,3,3,3,3,3,0,3,1,0, +0,1,0,0,0,0,0,0,0,0,1,1,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1, +3,2,2,2,3,3,3,3,3,3,3,3,3,3,3,3,3,1,3,2,3,3,3,3,3,3,3,3,0,3,0,0, +0,0,0,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,2,3,3,2,3,3,3,3,3,3,3,3,3,3,3,3,1,3,2,3,3,3,3,3,3,3,3,0,3,0,0, +0,0,0,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,3,3,3,3,2,3,2,2,1,3,3,3,3,2,2,2,1,1,2,0,1,0,1,0,0, +0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,1, +3,3,3,3,3,3,3,2,3,2,2,3,3,1,1,2,3,3,2,3,3,3,3,2,1,2,0,2,0,3,0,0, +0,0,0,0,0,0,0,1,0,0,2,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,1, +3,3,3,3,3,3,3,1,3,3,3,3,3,2,3,2,3,3,3,3,3,2,3,3,1,3,0,3,0,2,0,0, +0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1, +3,3,3,3,3,3,3,3,1,3,3,2,3,3,3,1,3,3,2,3,2,2,2,0,0,2,0,2,0,2,0,0, +0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,1, +3,3,3,3,3,3,3,3,3,0,3,3,3,2,2,3,3,3,1,2,2,3,2,1,1,2,0,2,0,0,0,0, +1,0,0,0,0,0,0,0,0,0,2,0,0,1,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1, +3,3,3,3,3,3,3,2,3,3,1,2,3,2,2,2,3,3,3,3,3,2,2,3,1,2,0,2,1,2,0,0, +0,0,0,0,0,0,0,0,0,0,3,0,0,1,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,1, +3,3,3,3,3,1,3,3,3,3,3,2,3,3,3,2,3,3,2,3,2,2,2,3,1,2,0,1,0,1,0,0, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1, +3,3,3,3,3,3,3,3,3,3,3,1,1,1,2,2,1,3,1,3,2,2,3,0,0,1,0,1,0,1,0,0, +0,0,0,1,0,0,0,0,1,0,2,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1, +3,3,3,3,3,2,2,3,2,2,3,1,2,1,1,1,2,3,1,3,1,2,2,0,1,1,1,1,0,1,0,0, +0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1, +3,3,3,3,3,1,3,2,2,3,3,1,2,3,1,1,3,3,3,3,1,2,2,1,1,1,0,2,0,2,0,1, +0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,1,2,2,3,3,3,2,2,1,1,2,0,2,0,1,0,0, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1, +3,0,1,2,1,3,3,2,3,3,3,3,3,2,3,2,1,0,3,1,2,1,2,1,2,3,2,1,0,1,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,1,1,2,3,3,3,3,3,3,3,3,3,3,3,3,0,0,3,1,3,3,2,3,3,2,2,2,0,1,0,0, +0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,3,3,3,3,0,3,3,3,3,3,2,1,1,2,1,3,3,0,3,1,1,1,1,3,2,0,1,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1, +3,3,2,2,2,3,3,3,3,3,3,3,3,3,3,3,1,1,3,1,3,3,2,3,2,2,2,3,0,2,0,0, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,2,3,3,2,2,3,2,1,1,1,1,1,3,1,3,1,1,0,0,0,1,0,0,0,1,0,0, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,2,3,2,0,3,2,0,3,0,2,0,0,2,1,3,1,0,0,1,0,0,0,1,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1, +3,3,3,3,2,1,1,1,1,2,1,1,2,1,1,1,2,2,1,2,1,1,1,0,1,1,0,1,0,1,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1, +3,3,3,3,2,1,3,1,1,2,1,3,2,1,1,0,1,2,3,2,1,1,1,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,3,3,3,3,2,2,1,0,1,0,0,1,0,0,0,2,1,0,3,0,0,1,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1, +3,3,3,2,3,2,3,3,1,3,2,1,1,1,2,1,1,2,1,3,0,1,0,0,0,1,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,1,1,2,2,3,3,2,3,2,2,2,3,1,2,2,1,1,2,1,1,2,2,0,1,1,0,1,0,2,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,2,1,3,1,0,2,2,1,3,2,1,0,0,2,0,2,0,1,0,0,0,0,0,0,0,1,0,0, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1, +3,3,3,3,3,3,1,2,0,2,3,1,2,3,2,0,1,3,1,2,1,1,1,0,0,1,0,0,2,2,2,3, +2,2,2,2,1,2,1,1,2,2,1,1,2,0,1,1,1,0,0,1,1,0,0,1,1,0,0,0,1,1,0,1, +3,3,3,3,3,2,1,2,2,1,2,0,2,0,1,0,1,2,1,2,1,1,0,0,0,1,0,1,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,1, +3,3,2,3,3,1,1,3,1,0,3,2,1,0,0,0,1,2,0,2,0,1,0,0,0,1,0,1,2,1,2,2, +1,1,1,1,1,1,1,2,2,2,1,1,1,1,1,1,1,0,1,2,1,1,1,0,0,0,0,0,1,1,0,0, +3,1,0,1,0,2,3,2,2,2,3,2,2,2,2,2,1,0,2,1,2,1,1,1,0,1,2,1,2,2,2,1, +1,1,2,2,2,2,1,2,1,1,0,1,2,1,2,2,2,1,1,1,0,1,1,1,1,2,0,1,0,0,0,0, +2,3,2,3,3,0,0,2,1,0,2,1,0,0,0,0,2,3,0,2,0,0,0,0,0,1,0,0,2,0,1,2, +2,1,2,1,2,2,1,1,1,2,1,1,1,0,1,2,2,1,1,1,1,1,0,1,1,1,0,0,1,2,0,0, +3,3,2,2,3,0,2,3,1,1,2,0,0,0,1,0,0,2,0,2,0,0,0,1,0,1,0,1,2,0,2,2, +1,1,1,1,2,1,0,1,2,2,2,1,1,1,1,1,1,1,0,1,1,1,0,0,0,0,0,0,1,1,0,0, +2,3,2,3,3,0,0,3,0,1,1,0,1,0,0,0,2,2,1,2,0,0,0,0,0,0,0,0,2,0,1,2, +2,2,1,1,1,1,1,2,2,2,1,0,2,0,1,0,1,0,0,1,0,1,0,0,1,0,0,0,0,1,0,0, +3,3,3,3,2,2,2,2,2,0,2,1,1,1,1,2,1,2,1,1,0,2,0,1,0,1,0,0,2,0,1,2, +1,1,1,1,1,1,1,2,2,1,1,0,2,0,1,0,2,0,0,1,1,1,0,0,2,0,0,0,1,1,0,0, +2,3,3,3,3,1,0,0,0,0,0,0,0,0,0,0,2,0,0,1,1,0,0,0,0,0,0,1,2,0,1,2, +2,2,2,1,1,2,1,1,2,2,2,1,2,0,1,1,1,1,1,1,0,1,1,1,1,0,0,1,1,1,0,0, +2,3,3,3,3,0,2,2,0,2,1,0,0,0,1,1,1,2,0,2,0,0,0,3,0,0,0,0,2,0,2,2, +1,1,1,2,1,2,1,1,2,2,2,1,2,0,1,1,1,0,1,1,1,1,0,2,1,0,0,0,1,1,0,0, +2,3,3,3,3,0,2,1,0,0,2,0,0,0,0,0,1,2,0,2,0,0,0,0,0,0,0,0,2,0,1,2, +1,1,1,2,1,1,1,1,2,2,2,0,1,0,1,1,1,0,0,1,1,1,0,0,1,0,0,0,0,1,0,0, +3,3,2,2,3,0,1,0,1,0,0,0,0,0,0,0,1,1,0,3,0,0,0,0,0,0,0,0,1,0,2,2, +1,1,1,1,1,2,1,1,2,2,1,2,2,1,0,1,1,1,1,1,0,1,0,0,1,0,0,0,1,1,0,0, +3,1,0,1,0,2,2,2,2,3,2,1,1,1,2,3,0,0,1,0,2,1,1,0,1,1,1,1,2,1,1,1, +1,2,2,1,2,1,2,2,1,1,0,1,2,1,2,2,1,1,1,0,0,1,1,1,2,1,0,1,0,0,0,0, +2,1,0,1,0,3,1,2,2,2,2,1,2,2,1,1,1,0,2,1,2,2,1,1,2,1,1,0,2,1,1,1, +1,2,2,2,2,2,2,2,1,2,0,1,1,0,2,1,1,1,1,1,0,0,1,1,1,1,0,1,0,0,0,0, +2,1,1,1,1,2,2,2,2,1,2,2,2,1,2,2,1,1,2,1,2,3,2,2,1,1,1,1,0,1,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,2,2,3,2,0,1,2,0,1,2,1,1,0,1,0,1,2,1,2,0,0,0,1,1,0,0,0,1,0,0,2, +1,1,0,0,1,1,0,1,1,1,1,0,2,0,1,1,1,0,0,1,1,0,0,0,0,1,0,0,0,1,0,0, +2,0,0,0,0,1,2,2,2,2,2,2,2,1,2,1,1,1,1,1,1,1,0,1,1,1,1,1,2,1,1,1, +1,2,2,2,2,1,1,2,1,2,1,1,1,0,2,1,2,1,1,1,0,2,1,1,1,1,0,1,0,0,0,0, +3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0, +1,1,0,1,0,1,1,1,1,1,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,2,2,3,2,0,0,0,0,1,0,0,0,0,0,0,1,1,0,2,0,0,0,0,0,0,0,0,1,0,1,2, +1,1,1,1,1,1,0,0,2,2,2,2,2,0,1,1,0,1,1,1,1,1,0,0,1,0,0,0,1,1,0,1, +2,3,1,2,1,0,1,1,0,2,2,2,0,0,1,0,0,1,1,1,1,0,0,0,0,0,0,0,1,0,1,2, +1,1,1,1,2,1,1,1,1,1,1,1,1,0,1,1,0,1,0,1,0,1,0,0,1,0,0,0,0,1,0,0, +2,2,2,2,2,0,0,2,0,0,2,0,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0,0,2,0,2,2, +1,1,1,1,1,0,0,1,2,1,1,0,1,0,1,0,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0, +1,2,2,2,2,0,0,2,0,1,1,0,0,0,1,0,0,2,0,2,0,0,0,0,0,0,0,0,0,0,1,1, +0,0,0,1,1,1,1,1,1,1,1,1,1,0,1,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0, +1,2,2,3,2,0,0,1,0,0,1,0,0,0,0,0,0,1,0,2,0,0,0,1,0,0,0,0,0,0,0,2, +1,1,0,0,1,0,0,0,1,1,0,0,1,0,1,1,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0, +2,1,2,2,2,1,2,1,2,2,1,1,2,1,1,1,0,1,1,1,1,2,0,1,0,1,1,1,1,0,1,1, +1,1,2,1,1,1,1,1,1,0,0,1,2,1,1,1,1,1,1,0,0,1,1,1,0,0,0,0,0,0,0,0, +1,0,0,1,3,1,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,2,2,2,1,0,0,1,0,2,0,0,0,0,0,1,1,1,0,1,0,0,0,0,0,0,0,0,2,0,0,1, +0,2,0,1,0,0,1,1,2,0,1,0,1,0,1,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0, +1,2,2,2,2,0,1,1,0,2,1,0,1,1,1,0,0,1,0,2,0,1,0,0,0,0,0,0,0,0,0,1, +0,1,0,0,1,0,0,0,1,1,0,0,1,0,0,1,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0, +2,2,2,2,2,0,0,1,0,0,0,1,0,1,0,0,0,1,0,1,0,0,0,0,0,0,0,0,0,0,0,1, +0,1,0,1,1,1,0,0,1,1,1,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0, +2,0,1,0,0,1,2,1,1,1,1,1,1,2,2,1,0,0,1,0,1,0,0,0,0,1,1,1,1,0,0,0, +1,1,2,1,1,1,1,0,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,2,1,2,1,0,0,1,0,0,0,0,0,0,0,0,1,1,0,1,0,0,0,0,0,0,0,0,0,0,0,1, +0,0,0,0,0,0,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,0,0,1,2,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1,0,0,0, +0,1,1,0,1,1,1,0,0,1,0,0,1,0,1,0,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0, +1,0,1,0,0,1,1,1,1,1,1,1,1,1,1,1,0,0,1,0,2,0,0,2,0,1,0,0,1,0,0,1, +1,1,0,0,1,1,0,1,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0, +1,1,1,1,1,1,1,2,0,0,0,0,0,0,2,1,0,1,1,0,0,1,1,1,0,1,0,0,0,0,0,0, +2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,0,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,0,1,1,0,1,1,1,1,1,0,1,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1, +) + +Latin5BulgarianModel = { + 'char_to_order_map': Latin5_BulgarianCharToOrderMap, + 'precedence_matrix': BulgarianLangModel, + 'typical_positive_ratio': 0.969392, + 'keep_english_letter': False, + 'charset_name': "ISO-8859-5", + 'language': 'Bulgairan', +} + +Win1251BulgarianModel = { + 'char_to_order_map': win1251BulgarianCharToOrderMap, + 'precedence_matrix': BulgarianLangModel, + 'typical_positive_ratio': 0.969392, + 'keep_english_letter': False, + 'charset_name': "windows-1251", + 'language': 'Bulgarian', +} diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langcyrillicmodel.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langcyrillicmodel.py new file mode 100644 index 0000000..e5f9a1f --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langcyrillicmodel.py @@ -0,0 +1,333 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Communicator client code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +# KOI8-R language model +# Character Mapping Table: +KOI8R_char_to_order_map = ( +255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255, # 00 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 10 +253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253, # 20 +252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253, # 30 +253,142,143,144,145,146,147,148,149,150,151,152, 74,153, 75,154, # 40 +155,156,157,158,159,160,161,162,163,164,165,253,253,253,253,253, # 50 +253, 71,172, 66,173, 65,174, 76,175, 64,176,177, 77, 72,178, 69, # 60 + 67,179, 78, 73,180,181, 79,182,183,184,185,253,253,253,253,253, # 70 +191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206, # 80 +207,208,209,210,211,212,213,214,215,216,217,218,219,220,221,222, # 90 +223,224,225, 68,226,227,228,229,230,231,232,233,234,235,236,237, # a0 +238,239,240,241,242,243,244,245,246,247,248,249,250,251,252,253, # b0 + 27, 3, 21, 28, 13, 2, 39, 19, 26, 4, 23, 11, 8, 12, 5, 1, # c0 + 15, 16, 9, 7, 6, 14, 24, 10, 17, 18, 20, 25, 30, 29, 22, 54, # d0 + 59, 37, 44, 58, 41, 48, 53, 46, 55, 42, 60, 36, 49, 38, 31, 34, # e0 + 35, 43, 45, 32, 40, 52, 56, 33, 61, 62, 51, 57, 47, 63, 50, 70, # f0 +) + +win1251_char_to_order_map = ( +255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255, # 00 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 10 +253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253, # 20 +252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253, # 30 +253,142,143,144,145,146,147,148,149,150,151,152, 74,153, 75,154, # 40 +155,156,157,158,159,160,161,162,163,164,165,253,253,253,253,253, # 50 +253, 71,172, 66,173, 65,174, 76,175, 64,176,177, 77, 72,178, 69, # 60 + 67,179, 78, 73,180,181, 79,182,183,184,185,253,253,253,253,253, # 70 +191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206, +207,208,209,210,211,212,213,214,215,216,217,218,219,220,221,222, +223,224,225,226,227,228,229,230,231,232,233,234,235,236,237,238, +239,240,241,242,243,244,245,246, 68,247,248,249,250,251,252,253, + 37, 44, 33, 46, 41, 48, 56, 51, 42, 60, 36, 49, 38, 31, 34, 35, + 45, 32, 40, 52, 53, 55, 58, 50, 57, 63, 70, 62, 61, 47, 59, 43, + 3, 21, 10, 19, 13, 2, 24, 20, 4, 23, 11, 8, 12, 5, 1, 15, + 9, 7, 6, 14, 39, 26, 28, 22, 25, 29, 54, 18, 17, 30, 27, 16, +) + +latin5_char_to_order_map = ( +255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255, # 00 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 10 +253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253, # 20 +252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253, # 30 +253,142,143,144,145,146,147,148,149,150,151,152, 74,153, 75,154, # 40 +155,156,157,158,159,160,161,162,163,164,165,253,253,253,253,253, # 50 +253, 71,172, 66,173, 65,174, 76,175, 64,176,177, 77, 72,178, 69, # 60 + 67,179, 78, 73,180,181, 79,182,183,184,185,253,253,253,253,253, # 70 +191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206, +207,208,209,210,211,212,213,214,215,216,217,218,219,220,221,222, +223,224,225,226,227,228,229,230,231,232,233,234,235,236,237,238, + 37, 44, 33, 46, 41, 48, 56, 51, 42, 60, 36, 49, 38, 31, 34, 35, + 45, 32, 40, 52, 53, 55, 58, 50, 57, 63, 70, 62, 61, 47, 59, 43, + 3, 21, 10, 19, 13, 2, 24, 20, 4, 23, 11, 8, 12, 5, 1, 15, + 9, 7, 6, 14, 39, 26, 28, 22, 25, 29, 54, 18, 17, 30, 27, 16, +239, 68,240,241,242,243,244,245,246,247,248,249,250,251,252,255, +) + +macCyrillic_char_to_order_map = ( +255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255, # 00 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 10 +253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253, # 20 +252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253, # 30 +253,142,143,144,145,146,147,148,149,150,151,152, 74,153, 75,154, # 40 +155,156,157,158,159,160,161,162,163,164,165,253,253,253,253,253, # 50 +253, 71,172, 66,173, 65,174, 76,175, 64,176,177, 77, 72,178, 69, # 60 + 67,179, 78, 73,180,181, 79,182,183,184,185,253,253,253,253,253, # 70 + 37, 44, 33, 46, 41, 48, 56, 51, 42, 60, 36, 49, 38, 31, 34, 35, + 45, 32, 40, 52, 53, 55, 58, 50, 57, 63, 70, 62, 61, 47, 59, 43, +191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206, +207,208,209,210,211,212,213,214,215,216,217,218,219,220,221,222, +223,224,225,226,227,228,229,230,231,232,233,234,235,236,237,238, +239,240,241,242,243,244,245,246,247,248,249,250,251,252, 68, 16, + 3, 21, 10, 19, 13, 2, 24, 20, 4, 23, 11, 8, 12, 5, 1, 15, + 9, 7, 6, 14, 39, 26, 28, 22, 25, 29, 54, 18, 17, 30, 27,255, +) + +IBM855_char_to_order_map = ( +255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255, # 00 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 10 +253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253, # 20 +252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253, # 30 +253,142,143,144,145,146,147,148,149,150,151,152, 74,153, 75,154, # 40 +155,156,157,158,159,160,161,162,163,164,165,253,253,253,253,253, # 50 +253, 71,172, 66,173, 65,174, 76,175, 64,176,177, 77, 72,178, 69, # 60 + 67,179, 78, 73,180,181, 79,182,183,184,185,253,253,253,253,253, # 70 +191,192,193,194, 68,195,196,197,198,199,200,201,202,203,204,205, +206,207,208,209,210,211,212,213,214,215,216,217, 27, 59, 54, 70, + 3, 37, 21, 44, 28, 58, 13, 41, 2, 48, 39, 53, 19, 46,218,219, +220,221,222,223,224, 26, 55, 4, 42,225,226,227,228, 23, 60,229, +230,231,232,233,234,235, 11, 36,236,237,238,239,240,241,242,243, + 8, 49, 12, 38, 5, 31, 1, 34, 15,244,245,246,247, 35, 16,248, + 43, 9, 45, 7, 32, 6, 40, 14, 52, 24, 56, 10, 33, 17, 61,249, +250, 18, 62, 20, 51, 25, 57, 30, 47, 29, 63, 22, 50,251,252,255, +) + +IBM866_char_to_order_map = ( +255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255, # 00 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 10 +253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253, # 20 +252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253, # 30 +253,142,143,144,145,146,147,148,149,150,151,152, 74,153, 75,154, # 40 +155,156,157,158,159,160,161,162,163,164,165,253,253,253,253,253, # 50 +253, 71,172, 66,173, 65,174, 76,175, 64,176,177, 77, 72,178, 69, # 60 + 67,179, 78, 73,180,181, 79,182,183,184,185,253,253,253,253,253, # 70 + 37, 44, 33, 46, 41, 48, 56, 51, 42, 60, 36, 49, 38, 31, 34, 35, + 45, 32, 40, 52, 53, 55, 58, 50, 57, 63, 70, 62, 61, 47, 59, 43, + 3, 21, 10, 19, 13, 2, 24, 20, 4, 23, 11, 8, 12, 5, 1, 15, +191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206, +207,208,209,210,211,212,213,214,215,216,217,218,219,220,221,222, +223,224,225,226,227,228,229,230,231,232,233,234,235,236,237,238, + 9, 7, 6, 14, 39, 26, 28, 22, 25, 29, 54, 18, 17, 30, 27, 16, +239, 68,240,241,242,243,244,245,246,247,248,249,250,251,252,255, +) + +# Model Table: +# total sequences: 100% +# first 512 sequences: 97.6601% +# first 1024 sequences: 2.3389% +# rest sequences: 0.1237% +# negative sequences: 0.0009% +RussianLangModel = ( +0,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,1,1,3,3,3,3,1,3,3,3,2,3,2,3,3, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,0,3,2,2,2,2,2,0,0,2, +3,3,3,2,3,3,3,3,3,3,3,3,3,3,2,3,3,0,0,3,3,3,3,3,3,3,3,3,2,3,2,0, +0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,2,2,3,3,3,3,3,3,3,3,3,2,3,3,0,0,3,3,3,3,3,3,3,3,2,3,3,1,0, +0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,2,3,2,3,3,3,3,3,3,3,3,3,3,3,3,3,0,0,3,3,3,3,3,3,3,3,3,3,3,2,1, +0,0,0,0,0,0,0,2,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,3,0,0,3,3,3,3,3,3,3,3,3,3,3,2,1, +0,0,0,0,0,1,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,3,2,2,2,3,1,3,3,1,3,3,3,3,2,2,3,0,2,2,2,3,3,2,1,0, +0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,2,3,3,3,3,3,2,2,3,2,3,3,3,2,1,2,2,0,1,2,2,2,2,2,2,0, +0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,2,2,3,0,2,2,3,3,2,1,2,0, +0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,1,0,0,2,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,2,3,3,1,2,3,2,2,3,2,3,3,3,3,2,2,3,0,3,2,2,3,1,1,1,0, +0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,3,2,2,3,3,3,3,3,2,3,3,3,3,2,2,2,0,3,3,3,2,2,2,2,0, +0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,3,3,3,2,3,2,3,3,3,3,3,3,2,3,2,2,0,1,3,2,1,2,2,1,0, +0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,3,3,3,3,2,1,1,3,0,1,1,1,1,2,1,1,0,2,2,2,1,2,0,1,0, +0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,2,3,3,2,2,2,2,1,3,2,3,2,3,2,1,2,2,0,1,1,2,1,2,1,2,0, +0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,3,3,3,3,3,2,2,3,2,3,3,3,2,2,2,2,0,2,2,2,2,3,1,1,0, +0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0, +3,2,3,2,2,3,3,3,3,3,3,3,3,3,1,3,2,0,0,3,3,3,3,2,3,3,3,3,2,3,2,0, +0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,3,3,3,3,3,2,2,3,3,0,2,1,0,3,2,3,2,3,0,0,1,2,0,0,1,0,1,2,1,1,0, +0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,0,3,0,2,3,3,3,3,2,3,3,3,3,1,2,2,0,0,2,3,2,2,2,3,2,3,2,2,3,0,0, +0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,2,3,0,2,3,2,3,0,1,2,3,3,2,0,2,3,0,0,2,3,2,2,0,1,3,1,3,2,2,1,0, +0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,1,3,0,2,3,3,3,3,3,3,3,3,2,1,3,2,0,0,2,2,3,3,3,2,3,3,0,2,2,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,2,2,3,3,2,2,2,3,3,0,0,1,1,1,1,1,2,0,0,1,1,1,1,0,1,0, +0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,2,2,3,3,3,3,3,3,3,0,3,2,3,3,2,3,2,0,2,1,0,1,1,0,1,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,2,3,3,3,2,2,2,2,3,1,3,2,3,1,1,2,1,0,2,2,2,2,1,3,1,0, +0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0, +2,2,3,3,3,3,3,1,2,2,1,3,1,0,3,0,0,3,0,0,0,1,1,0,1,2,1,0,0,0,0,0, +0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,2,2,1,1,3,3,3,2,2,1,2,2,3,1,1,2,0,0,2,2,1,3,0,0,2,1,1,2,1,1,0, +0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,2,3,3,3,3,1,2,2,2,1,2,1,3,3,1,1,2,1,2,1,2,2,0,2,0,0,1,1,0,1,0, +0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,3,3,3,3,3,2,1,3,2,2,3,2,0,3,2,0,3,0,1,0,1,1,0,0,1,1,1,1,0,1,0, +0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,2,3,3,3,2,2,2,3,3,1,2,1,2,1,0,1,0,1,1,0,1,0,0,2,1,1,1,0,1,0, +0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0, +3,1,1,2,1,2,3,3,2,2,1,2,2,3,0,2,1,0,0,2,2,3,2,1,2,2,2,2,2,3,1,0, +0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,1,1,0,1,1,2,2,1,1,3,0,0,1,3,1,1,1,0,0,0,1,0,1,1,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,1,3,3,3,2,0,0,0,2,1,0,1,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,0,1,0,0,2,3,2,2,2,1,2,2,2,1,2,1,0,0,1,1,1,0,2,0,1,1,1,0,0,1,1, +1,0,0,0,0,0,1,2,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0, +2,3,3,3,3,0,0,0,0,1,0,0,0,0,3,0,1,2,1,0,0,0,0,0,0,0,1,1,0,0,1,1, +1,0,1,0,1,2,0,0,1,1,2,1,0,1,1,1,1,0,1,1,1,1,0,1,0,0,1,0,0,1,1,0, +2,2,3,2,2,2,3,1,2,2,2,2,2,2,2,2,1,1,1,1,1,1,1,0,1,0,1,1,1,0,2,1, +1,1,1,1,1,1,1,1,2,1,1,1,1,1,1,1,1,1,1,0,1,0,1,1,0,1,1,1,0,1,1,0, +3,3,3,2,2,2,2,3,2,2,1,1,2,2,2,2,1,1,3,1,2,1,2,0,0,1,1,0,1,0,2,1, +1,1,1,1,1,2,1,0,1,1,1,1,0,1,0,0,1,1,0,0,1,0,1,0,0,1,0,0,0,1,1,0, +2,0,0,1,0,3,2,2,2,2,1,2,1,2,1,2,0,0,0,2,1,2,2,1,1,2,2,0,1,1,0,2, +1,1,1,1,1,0,1,1,1,2,1,1,1,2,1,0,1,2,1,1,1,1,0,1,1,1,0,0,1,0,0,1, +1,3,2,2,2,1,1,1,2,3,0,0,0,0,2,0,2,2,1,0,0,0,0,0,0,1,0,0,0,0,1,1, +1,0,1,1,0,1,0,1,1,0,1,1,0,2,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,1,1,0, +2,3,2,3,2,1,2,2,2,2,1,0,0,0,2,0,0,1,1,0,0,0,0,0,0,0,1,1,0,0,2,1, +1,1,2,1,0,2,0,0,1,0,1,0,0,1,0,0,1,1,0,1,1,0,0,0,0,0,1,0,0,0,0,0, +3,0,0,1,0,2,2,2,3,2,2,2,2,2,2,2,0,0,0,2,1,2,1,1,1,2,2,0,0,0,1,2, +1,1,1,1,1,0,1,2,1,1,1,1,1,1,1,0,1,1,1,1,1,1,0,1,1,1,1,1,1,0,0,1, +2,3,2,3,3,2,0,1,1,1,0,0,1,0,2,0,1,1,3,1,0,0,0,0,0,0,0,1,0,0,2,1, +1,1,1,1,1,1,1,0,1,0,1,1,1,1,0,1,1,1,0,0,1,1,0,1,0,0,0,0,0,0,1,0, +2,3,3,3,3,1,2,2,2,2,0,1,1,0,2,1,1,1,2,1,0,1,1,0,0,1,0,1,0,0,2,0, +0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,3,3,3,2,0,0,1,1,2,2,1,0,0,2,0,1,1,3,0,0,1,0,0,0,0,0,1,0,1,2,1, +1,1,2,0,1,1,1,0,1,0,1,1,0,1,0,1,1,1,1,0,1,0,0,0,0,0,0,1,0,1,1,0, +1,3,2,3,2,1,0,0,2,2,2,0,1,0,2,0,1,1,1,0,1,0,0,0,3,0,1,1,0,0,2,1, +1,1,1,0,1,1,0,0,0,0,1,1,0,1,0,0,2,1,1,0,1,0,0,0,1,0,1,0,0,1,1,0, +3,1,2,1,1,2,2,2,2,2,2,1,2,2,1,1,0,0,0,2,2,2,0,0,0,1,2,1,0,1,0,1, +2,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,2,1,1,1,0,1,0,1,1,0,1,1,1,0,0,1, +3,0,0,0,0,2,0,1,1,1,1,1,1,1,0,1,0,0,0,1,1,1,0,1,0,1,1,0,0,1,0,1, +1,1,0,0,1,0,0,0,1,0,1,1,0,0,1,0,1,0,1,0,0,0,0,1,0,0,0,1,0,0,0,1, +1,3,3,2,2,0,0,0,2,2,0,0,0,1,2,0,1,1,2,0,0,0,0,0,0,0,0,1,0,0,2,1, +0,1,1,0,0,1,1,0,0,0,1,1,0,1,1,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,1,0, +2,3,2,3,2,0,0,0,0,1,1,0,0,0,2,0,2,0,2,0,0,0,0,0,1,0,0,1,0,0,1,1, +1,1,2,0,1,2,1,0,1,1,2,1,1,1,1,1,2,1,1,0,1,0,0,1,1,1,1,1,0,1,1,0, +1,3,2,2,2,1,0,0,2,2,1,0,1,2,2,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,1,1, +0,0,1,1,0,1,1,0,0,1,1,0,1,1,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0, +1,0,0,1,0,2,3,1,2,2,2,2,2,2,1,1,0,0,0,1,0,1,0,2,1,1,1,0,0,0,0,1, +1,1,0,1,1,0,1,1,1,1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1,0,0,0, +2,0,2,0,0,1,0,3,2,1,2,1,2,2,0,1,0,0,0,2,1,0,0,2,1,1,1,1,0,2,0,2, +2,1,1,1,1,1,1,1,1,1,1,1,1,2,1,0,1,1,1,1,0,0,0,1,1,1,1,0,1,0,0,1, +1,2,2,2,2,1,0,0,1,0,0,0,0,0,2,0,1,1,1,1,0,0,0,0,1,0,1,2,0,0,2,0, +1,0,1,1,1,2,1,0,1,0,1,1,0,0,1,0,1,1,1,0,1,0,0,0,1,0,0,1,0,1,1,0, +2,1,2,2,2,0,3,0,1,1,0,0,0,0,2,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1, +0,0,0,1,1,1,0,0,1,0,1,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,1,0,0, +1,2,2,3,2,2,0,0,1,1,2,0,1,2,1,0,1,0,1,0,0,1,0,0,0,0,0,0,0,0,0,1, +0,1,1,0,0,1,1,0,0,1,1,0,0,1,1,0,1,1,0,0,1,0,0,0,0,0,0,0,0,1,1,0, +2,2,1,1,2,1,2,2,2,2,2,1,2,2,0,1,0,0,0,1,2,2,2,1,2,1,1,1,1,1,2,1, +1,1,1,1,1,1,1,1,1,1,0,0,1,1,1,0,1,1,1,0,0,0,0,1,1,1,0,1,1,0,0,1, +1,2,2,2,2,0,1,0,2,2,0,0,0,0,2,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,2,0, +0,0,1,0,0,1,0,0,0,0,1,0,1,1,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0, +0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,2,2,2,2,0,0,0,2,2,2,0,1,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,1,1, +0,1,1,0,0,1,1,0,0,0,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,2,2,2,2,0,0,0,0,1,0,0,1,1,2,0,0,0,0,1,0,1,0,0,1,0,0,2,0,0,0,1, +0,0,1,0,0,1,0,0,0,1,1,0,0,0,0,0,1,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0, +1,2,2,2,1,1,2,0,2,1,1,1,1,0,2,2,0,0,0,0,0,0,0,0,0,1,1,0,0,0,1,1, +0,0,1,0,1,1,0,0,0,0,1,0,0,0,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0, +1,0,2,1,2,0,0,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,1,0,0,0,0, +0,0,1,0,1,1,0,0,0,0,1,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0, +1,0,0,0,0,2,0,1,2,1,0,1,1,1,0,1,0,0,0,1,0,1,0,0,1,0,1,0,0,0,0,1, +0,0,0,0,0,1,0,0,1,1,0,0,1,1,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,1, +2,2,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1, +1,0,0,0,1,0,0,0,1,1,0,0,0,0,0,0,0,1,0,0,0,0,0,1,0,0,1,0,0,0,0,0, +2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1, +1,1,1,0,1,0,1,0,0,1,1,1,1,0,0,0,1,0,0,0,0,1,0,0,0,1,0,1,0,0,0,0, +1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1, +1,1,0,1,1,0,1,0,1,0,0,0,0,1,1,0,1,1,0,0,0,0,0,1,0,1,1,0,1,0,0,0, +0,1,1,1,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,1,0,0,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0, +) + +Koi8rModel = { + 'char_to_order_map': KOI8R_char_to_order_map, + 'precedence_matrix': RussianLangModel, + 'typical_positive_ratio': 0.976601, + 'keep_english_letter': False, + 'charset_name': "KOI8-R", + 'language': 'Russian', +} + +Win1251CyrillicModel = { + 'char_to_order_map': win1251_char_to_order_map, + 'precedence_matrix': RussianLangModel, + 'typical_positive_ratio': 0.976601, + 'keep_english_letter': False, + 'charset_name': "windows-1251", + 'language': 'Russian', +} + +Latin5CyrillicModel = { + 'char_to_order_map': latin5_char_to_order_map, + 'precedence_matrix': RussianLangModel, + 'typical_positive_ratio': 0.976601, + 'keep_english_letter': False, + 'charset_name': "ISO-8859-5", + 'language': 'Russian', +} + +MacCyrillicModel = { + 'char_to_order_map': macCyrillic_char_to_order_map, + 'precedence_matrix': RussianLangModel, + 'typical_positive_ratio': 0.976601, + 'keep_english_letter': False, + 'charset_name': "MacCyrillic", + 'language': 'Russian', +} + +Ibm866Model = { + 'char_to_order_map': IBM866_char_to_order_map, + 'precedence_matrix': RussianLangModel, + 'typical_positive_ratio': 0.976601, + 'keep_english_letter': False, + 'charset_name': "IBM866", + 'language': 'Russian', +} + +Ibm855Model = { + 'char_to_order_map': IBM855_char_to_order_map, + 'precedence_matrix': RussianLangModel, + 'typical_positive_ratio': 0.976601, + 'keep_english_letter': False, + 'charset_name': "IBM855", + 'language': 'Russian', +} diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langgreekmodel.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langgreekmodel.py new file mode 100644 index 0000000..5332221 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langgreekmodel.py @@ -0,0 +1,225 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Communicator client code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +# 255: Control characters that usually does not exist in any text +# 254: Carriage/Return +# 253: symbol (punctuation) that does not belong to word +# 252: 0 - 9 + +# Character Mapping Table: +Latin7_char_to_order_map = ( +255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255, # 00 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 10 +253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253, # 20 +252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253, # 30 +253, 82,100,104, 94, 98,101,116,102,111,187,117, 92, 88,113, 85, # 40 + 79,118,105, 83, 67,114,119, 95, 99,109,188,253,253,253,253,253, # 50 +253, 72, 70, 80, 81, 60, 96, 93, 89, 68,120, 97, 77, 86, 69, 55, # 60 + 78,115, 65, 66, 58, 76,106,103, 87,107,112,253,253,253,253,253, # 70 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 80 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 90 +253,233, 90,253,253,253,253,253,253,253,253,253,253, 74,253,253, # a0 +253,253,253,253,247,248, 61, 36, 46, 71, 73,253, 54,253,108,123, # b0 +110, 31, 51, 43, 41, 34, 91, 40, 52, 47, 44, 53, 38, 49, 59, 39, # c0 + 35, 48,250, 37, 33, 45, 56, 50, 84, 57,120,121, 17, 18, 22, 15, # d0 +124, 1, 29, 20, 21, 3, 32, 13, 25, 5, 11, 16, 10, 6, 30, 4, # e0 + 9, 8, 14, 7, 2, 12, 28, 23, 42, 24, 64, 75, 19, 26, 27,253, # f0 +) + +win1253_char_to_order_map = ( +255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255, # 00 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 10 +253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253, # 20 +252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253, # 30 +253, 82,100,104, 94, 98,101,116,102,111,187,117, 92, 88,113, 85, # 40 + 79,118,105, 83, 67,114,119, 95, 99,109,188,253,253,253,253,253, # 50 +253, 72, 70, 80, 81, 60, 96, 93, 89, 68,120, 97, 77, 86, 69, 55, # 60 + 78,115, 65, 66, 58, 76,106,103, 87,107,112,253,253,253,253,253, # 70 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 80 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 90 +253,233, 61,253,253,253,253,253,253,253,253,253,253, 74,253,253, # a0 +253,253,253,253,247,253,253, 36, 46, 71, 73,253, 54,253,108,123, # b0 +110, 31, 51, 43, 41, 34, 91, 40, 52, 47, 44, 53, 38, 49, 59, 39, # c0 + 35, 48,250, 37, 33, 45, 56, 50, 84, 57,120,121, 17, 18, 22, 15, # d0 +124, 1, 29, 20, 21, 3, 32, 13, 25, 5, 11, 16, 10, 6, 30, 4, # e0 + 9, 8, 14, 7, 2, 12, 28, 23, 42, 24, 64, 75, 19, 26, 27,253, # f0 +) + +# Model Table: +# total sequences: 100% +# first 512 sequences: 98.2851% +# first 1024 sequences:1.7001% +# rest sequences: 0.0359% +# negative sequences: 0.0148% +GreekLangModel = ( +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,3,2,2,3,3,3,3,3,3,3,3,1,3,3,3,0,2,2,3,3,0,3,0,3,2,0,3,3,3,0, +3,0,0,0,2,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,3,3,3,3,0,3,3,0,3,2,3,3,0,3,2,3,3,3,0,0,3,0,3,0,3,3,2,0,0,0, +2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0, +0,2,3,2,2,3,3,3,3,3,3,3,3,0,3,3,3,3,0,2,3,3,0,3,3,3,3,2,3,3,3,0, +2,0,0,0,2,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,2,3,3,2,3,3,3,3,3,3,3,3,3,3,3,3,0,2,1,3,3,3,3,2,3,3,2,3,3,2,0, +0,0,0,0,2,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,3,3,3,0,3,3,3,3,3,3,0,3,3,0,3,3,3,3,3,3,3,3,3,3,0,3,2,3,3,0, +2,0,1,0,2,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0, +0,3,3,3,3,3,2,3,0,0,0,0,3,3,0,3,1,3,3,3,0,3,3,0,3,3,3,3,0,0,0,0, +2,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,3,3,3,3,0,3,0,3,3,3,3,3,0,3,2,2,2,3,0,2,3,3,3,3,3,2,3,3,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,3,3,3,3,3,2,2,2,3,3,3,3,0,3,1,3,3,3,3,2,3,3,3,3,3,3,3,2,2,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,3,3,3,3,2,0,3,0,0,0,3,3,2,3,3,3,3,3,0,0,3,2,3,0,2,3,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,0,3,3,3,3,0,0,3,3,0,2,3,0,3,0,3,3,3,0,0,3,0,3,0,2,2,3,3,0,0, +0,0,1,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,3,3,3,3,2,0,3,2,3,3,3,3,0,3,3,3,3,3,0,3,3,2,3,2,3,3,2,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,3,2,3,2,3,3,3,3,3,3,0,2,3,2,3,2,2,2,3,2,3,3,2,3,0,2,2,2,3,0, +2,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,3,0,0,0,3,3,3,2,3,3,0,0,3,0,3,0,0,0,3,2,0,3,0,3,0,0,2,0,2,0, +0,0,0,0,2,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,3,3,3,0,3,3,3,3,3,3,0,3,3,0,3,0,0,0,3,3,0,3,3,3,0,0,1,2,3,0, +3,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,3,3,3,3,2,0,0,3,2,2,3,3,0,3,3,3,3,3,2,1,3,0,3,2,3,3,2,1,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,3,3,0,2,3,3,3,3,3,3,0,0,3,0,3,0,0,0,3,3,0,3,2,3,0,0,3,3,3,0, +3,0,0,0,2,0,0,0,0,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,3,3,3,0,3,3,3,3,3,3,0,0,3,0,3,0,0,0,3,2,0,3,2,3,0,0,3,2,3,0, +2,0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,3,1,2,2,3,3,3,3,3,3,0,2,3,0,3,0,0,0,3,3,0,3,0,2,0,0,2,3,1,0, +2,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,0,3,3,3,3,0,3,0,3,3,2,3,0,3,3,3,3,3,3,0,3,3,3,0,2,3,0,0,3,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,0,3,3,3,0,0,3,0,0,0,3,3,0,3,0,2,3,3,0,0,3,0,3,0,3,3,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,3,0,0,0,3,3,3,3,3,3,0,0,3,0,2,0,0,0,3,3,0,3,0,3,0,0,2,0,2,0, +0,0,0,0,1,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,3,3,3,3,3,0,3,0,2,0,3,2,0,3,2,3,2,3,0,0,3,2,3,2,3,3,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,3,0,0,2,3,3,3,3,3,0,0,0,3,0,2,1,0,0,3,2,2,2,0,3,0,0,2,2,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,0,3,3,3,2,0,3,0,3,0,3,3,0,2,1,2,3,3,0,0,3,0,3,0,3,3,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,2,3,3,3,0,3,3,3,3,3,3,0,2,3,0,3,0,0,0,2,1,0,2,2,3,0,0,2,2,2,0, +0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,3,0,0,2,3,3,3,2,3,0,0,1,3,0,2,0,0,0,0,3,0,1,0,2,0,0,1,1,1,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,3,3,3,3,1,0,3,0,0,0,3,2,0,3,2,3,3,3,0,0,3,0,3,2,2,2,1,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,0,3,3,3,0,0,3,0,0,0,0,2,0,2,3,3,2,2,2,2,3,0,2,0,2,2,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,3,3,3,2,0,0,0,0,0,0,2,3,0,2,0,2,3,2,0,0,3,0,3,0,3,1,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,3,2,3,3,2,2,3,0,2,0,3,0,0,0,2,0,0,0,0,1,2,0,2,0,2,0, +0,2,0,2,0,2,2,0,0,1,0,2,2,2,0,2,2,2,0,2,2,2,0,0,2,0,0,1,0,0,0,0, +0,2,0,3,3,2,0,0,0,0,0,0,1,3,0,2,0,2,2,2,0,0,2,0,3,0,0,2,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,0,2,3,2,0,2,2,0,2,0,2,2,0,2,0,2,2,2,0,0,0,0,0,0,2,3,0,0,0,2, +0,1,2,0,0,0,0,2,2,0,0,0,2,1,0,2,2,0,0,0,0,0,0,1,0,2,0,0,0,0,0,0, +0,0,2,1,0,2,3,2,2,3,2,3,2,0,0,3,3,3,0,0,3,2,0,0,0,1,1,0,2,0,2,2, +0,2,0,2,0,2,2,0,0,2,0,2,2,2,0,2,2,2,2,0,0,2,0,0,0,2,0,1,0,0,0,0, +0,3,0,3,3,2,2,0,3,0,0,0,2,2,0,2,2,2,1,2,0,0,1,2,2,0,0,3,0,0,0,2, +0,1,2,0,0,0,1,2,0,0,0,0,0,0,0,2,2,0,1,0,0,2,0,0,0,2,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,2,3,3,2,2,0,0,0,2,0,2,3,3,0,2,0,0,0,0,0,0,2,2,2,0,2,2,0,2,0,2, +0,2,2,0,0,2,2,2,2,1,0,0,2,2,0,2,0,0,2,0,0,0,0,0,0,2,0,0,0,0,0,0, +0,2,0,3,2,3,0,0,0,3,0,0,2,2,0,2,0,2,2,2,0,0,2,0,0,0,0,0,0,0,0,2, +0,0,2,2,0,0,2,2,2,0,0,0,0,0,0,2,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,2,0,0,3,2,0,2,2,2,2,2,0,0,0,2,0,0,0,0,2,0,1,0,0,2,0,1,0,0,0, +0,2,2,2,0,2,2,0,1,2,0,2,2,2,0,2,2,2,2,1,2,2,0,0,2,0,0,0,0,0,0,0, +0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0, +0,2,0,2,0,2,2,0,0,0,0,1,2,1,0,0,2,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,3,2,3,0,0,2,0,0,0,2,2,0,2,0,0,0,1,0,0,2,0,2,0,2,2,0,0,0,0, +0,0,2,0,0,0,0,2,2,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0, +0,2,2,3,2,2,0,0,0,0,0,0,1,3,0,2,0,2,2,0,0,0,1,0,2,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,2,0,2,0,3,2,0,2,0,0,0,0,0,0,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1, +0,0,2,0,0,0,0,1,1,0,0,2,1,2,0,2,2,0,1,0,0,1,0,0,0,2,0,0,0,0,0,0, +0,3,0,2,2,2,0,0,2,0,0,0,2,0,0,0,2,3,0,2,0,0,0,0,0,0,2,2,0,0,0,2, +0,1,2,0,0,0,1,2,2,1,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,2,1,2,0,2,2,0,2,0,0,2,0,0,0,0,1,2,1,0,2,1,0,0,0,0,0,0,0,0,0,0, +0,0,2,0,0,0,3,1,2,2,0,2,0,0,0,0,2,0,0,0,2,0,0,3,0,0,0,0,2,2,2,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,2,1,0,2,0,1,2,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,1,0,0,0,0,0,0,2, +0,2,2,0,0,2,2,2,2,2,0,1,2,0,0,0,2,2,0,1,0,2,0,0,2,2,0,0,0,0,0,0, +0,0,0,0,1,0,0,0,0,0,0,0,3,0,0,2,0,0,0,0,0,0,0,0,2,0,2,0,0,0,0,2, +0,1,2,0,0,0,0,2,2,1,0,1,0,1,0,2,2,2,1,0,0,0,0,0,0,1,0,0,0,0,0,0, +0,2,0,1,2,0,0,0,0,0,0,0,0,0,0,2,0,0,2,2,0,0,0,0,1,0,0,0,0,0,0,2, +0,2,2,0,0,0,0,2,2,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,2,0,0,2,0,0,0, +0,2,2,2,2,0,0,0,3,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,2,0,0,0,0,0,0,1, +0,0,2,0,0,0,0,1,2,0,0,0,0,0,0,2,2,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0, +0,2,0,2,2,2,0,0,2,0,0,0,0,0,0,0,2,2,2,0,0,0,2,0,0,0,0,0,0,0,0,2, +0,0,1,0,0,0,0,2,1,0,0,0,0,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0, +0,3,0,2,0,0,0,0,0,0,0,0,2,0,0,0,0,0,2,0,0,0,0,0,0,0,2,0,0,0,0,2, +0,0,2,0,0,0,0,2,2,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,2,0,2,2,1,0,0,0,0,0,0,2,0,0,2,0,2,2,2,0,0,0,0,0,0,2,0,0,0,0,2, +0,0,2,0,0,2,0,2,2,0,0,0,0,2,0,2,0,0,0,0,0,2,0,0,0,2,0,0,0,0,0,0, +0,0,3,0,0,0,2,2,0,2,2,0,0,0,0,0,2,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0, +0,2,2,2,2,2,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,0,0,0,1, +0,0,0,0,0,0,0,2,1,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,2,2,0,0,0,0,0,2,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0, +0,2,0,0,0,2,0,0,0,0,0,1,0,0,0,0,2,2,0,0,0,1,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,1,0,2,0,0,0, +0,2,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,1,0,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,1,0,0,2,0,2,0,0,0, +0,0,0,0,0,0,0,0,2,1,0,0,0,0,0,0,2,0,0,0,1,2,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +) + +Latin7GreekModel = { + 'char_to_order_map': Latin7_char_to_order_map, + 'precedence_matrix': GreekLangModel, + 'typical_positive_ratio': 0.982851, + 'keep_english_letter': False, + 'charset_name': "ISO-8859-7", + 'language': 'Greek', +} + +Win1253GreekModel = { + 'char_to_order_map': win1253_char_to_order_map, + 'precedence_matrix': GreekLangModel, + 'typical_positive_ratio': 0.982851, + 'keep_english_letter': False, + 'charset_name': "windows-1253", + 'language': 'Greek', +} diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langhebrewmodel.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langhebrewmodel.py new file mode 100644 index 0000000..58f4c87 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langhebrewmodel.py @@ -0,0 +1,200 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Universal charset detector code. +# +# The Initial Developer of the Original Code is +# Simon Montagu +# Portions created by the Initial Developer are Copyright (C) 2005 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# Shy Shalom - original C code +# Shoshannah Forbes - original C code (?) +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +# 255: Control characters that usually does not exist in any text +# 254: Carriage/Return +# 253: symbol (punctuation) that does not belong to word +# 252: 0 - 9 + +# Windows-1255 language model +# Character Mapping Table: +WIN1255_CHAR_TO_ORDER_MAP = ( +255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255, # 00 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 10 +253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253, # 20 +252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253, # 30 +253, 69, 91, 79, 80, 92, 89, 97, 90, 68,111,112, 82, 73, 95, 85, # 40 + 78,121, 86, 71, 67,102,107, 84,114,103,115,253,253,253,253,253, # 50 +253, 50, 74, 60, 61, 42, 76, 70, 64, 53,105, 93, 56, 65, 54, 49, # 60 + 66,110, 51, 43, 44, 63, 81, 77, 98, 75,108,253,253,253,253,253, # 70 +124,202,203,204,205, 40, 58,206,207,208,209,210,211,212,213,214, +215, 83, 52, 47, 46, 72, 32, 94,216,113,217,109,218,219,220,221, + 34,116,222,118,100,223,224,117,119,104,125,225,226, 87, 99,227, +106,122,123,228, 55,229,230,101,231,232,120,233, 48, 39, 57,234, + 30, 59, 41, 88, 33, 37, 36, 31, 29, 35,235, 62, 28,236,126,237, +238, 38, 45,239,240,241,242,243,127,244,245,246,247,248,249,250, + 9, 8, 20, 16, 3, 2, 24, 14, 22, 1, 25, 15, 4, 11, 6, 23, + 12, 19, 13, 26, 18, 27, 21, 17, 7, 10, 5,251,252,128, 96,253, +) + +# Model Table: +# total sequences: 100% +# first 512 sequences: 98.4004% +# first 1024 sequences: 1.5981% +# rest sequences: 0.087% +# negative sequences: 0.0015% +HEBREW_LANG_MODEL = ( +0,3,3,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,3,3,3,3,3,2,3,2,1,2,0,1,0,0, +3,0,3,1,0,0,1,3,2,0,1,1,2,0,2,2,2,1,1,1,1,2,1,1,1,2,0,0,2,2,0,1, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,2,2,2, +1,2,1,2,1,2,0,0,2,0,0,0,0,0,1,0,1,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,2,2, +1,2,1,3,1,1,0,0,2,0,0,0,1,0,1,0,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,1,0,1,2,2,1,3, +1,2,1,1,2,2,0,0,2,2,0,0,0,0,1,0,1,0,0,0,1,0,0,0,0,0,0,1,0,1,1,0, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,3,2,2,2,2,3,2, +1,2,1,2,2,2,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,3,2,3,2,2,3,2,2,2,1,2,2,2,2, +1,2,1,1,2,2,0,1,2,0,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,0,2,2,2,2,2, +0,2,0,2,2,2,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,0,2,2,2, +0,2,1,2,2,2,0,0,2,1,0,0,0,0,1,0,1,0,0,0,0,0,0,2,0,0,0,0,0,0,1,0, +3,3,3,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,3,3,3,3,3,3,3,2,1,2,3,2,2,2, +1,2,1,2,2,2,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,1,0,0,0,0,0,1,1,0, +3,3,3,3,3,3,3,3,3,2,3,3,3,2,3,3,3,3,3,3,3,3,3,3,3,3,3,1,0,2,0,2, +0,2,1,2,2,2,0,0,1,2,0,0,0,0,1,0,1,0,0,0,0,0,0,1,0,0,0,2,0,0,1,0, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,2,3,2,2,3,2,1,2,1,1,1, +0,1,1,1,1,1,3,0,1,0,0,0,0,2,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0, +3,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,1,0,1,1,0,0,1,0,0,1,0,0,0,0, +0,0,1,0,0,0,0,0,2,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,2,2,2,2,2,2, +0,2,0,1,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0, +3,3,3,3,3,3,3,3,3,2,3,3,3,2,1,2,3,3,2,3,3,3,3,2,3,2,1,2,0,2,1,2, +0,2,0,2,2,2,0,0,1,2,0,0,0,0,1,0,1,0,0,0,0,0,0,0,0,0,0,1,0,0,1,0, +3,3,3,3,3,3,3,3,3,2,3,3,3,1,2,2,3,3,2,3,2,3,2,2,3,1,2,2,0,2,2,2, +0,2,1,2,2,2,0,0,1,2,0,0,0,0,1,0,0,0,0,0,1,0,0,1,0,0,0,1,0,0,1,0, +3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,3,3,2,3,3,2,2,2,3,3,3,3,1,3,2,2,2, +0,2,0,1,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,2,3,3,3,2,3,2,2,2,1,2,2,0,2,2,2,2, +0,2,0,2,2,2,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0, +3,3,3,3,3,3,3,3,3,3,3,2,3,3,3,1,3,2,3,3,2,3,3,2,2,1,2,2,2,2,2,2, +0,2,1,2,1,2,0,0,1,0,0,0,0,0,1,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,1,0, +3,3,3,3,3,3,2,3,2,3,3,2,3,3,3,3,2,3,2,3,3,3,3,3,2,2,2,2,2,2,2,1, +0,2,0,1,2,1,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0, +3,3,3,3,3,3,3,3,3,2,1,2,3,3,3,3,3,3,3,2,3,2,3,2,1,2,3,0,2,1,2,2, +0,2,1,1,2,1,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,2,0, +3,3,3,3,3,3,3,3,3,2,3,3,3,3,2,1,3,1,2,2,2,1,2,3,3,1,2,1,2,2,2,2, +0,1,1,1,1,1,0,0,0,0,0,0,0,0,1,0,0,0,0,0,1,0,0,2,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,3,3,3,0,2,3,3,3,1,3,3,3,1,2,2,2,2,1,1,2,2,2,2,2,2, +0,2,0,1,1,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0, +3,3,3,3,3,3,2,3,3,3,2,2,3,3,3,2,1,2,3,2,3,2,2,2,2,1,2,1,1,1,2,2, +0,2,1,1,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0, +3,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,0,0,0,1,0,0,0,0,0, +1,0,1,0,0,0,0,0,2,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,2,3,3,2,3,1,2,2,2,2,3,2,3,1,1,2,2,1,2,2,1,1,0,2,2,2,2, +0,1,0,1,2,2,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0, +3,0,0,1,1,0,1,0,0,1,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,2,2,0, +0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,0,1,0,1,0,1,1,0,1,1,0,0,0,1,1,0,1,1,1,0,0,0,0,0,0,1,0,0,0,0,0, +0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,0,0,0,1,1,0,1,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0, +3,2,2,1,2,2,2,2,2,2,2,1,2,2,1,2,2,1,1,1,1,1,1,1,1,2,1,1,0,3,3,3, +0,3,0,2,2,2,2,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0, +2,2,2,3,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,1,2,2,1,2,2,2,1,1,1,2,0,1, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,2,2,2,2,2,2,2,2,2,2,1,2,2,2,2,2,2,2,2,2,2,2,0,2,2,0,0,0,0,0,0, +0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,3,1,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,1,2,1,0,2,1,0, +0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,1,1,1,1,1,1,1,1,1,1,0,0,1,1,1,1,0,1,1,1,1,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0, +0,3,1,1,2,2,2,2,2,1,2,2,2,1,1,2,2,2,2,2,2,2,1,2,2,1,0,1,1,1,1,0, +0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,2,1,1,1,1,2,1,1,2,1,0,1,1,1,1,1,1,1,1,1,1,1,0,1,0,0,0,0,0,0,0, +0,0,2,0,0,0,0,0,0,0,0,1,1,0,0,0,0,1,1,0,0,1,1,0,0,0,0,0,0,1,0,0, +2,1,1,2,2,2,2,2,2,2,2,2,2,2,1,2,2,2,2,2,1,2,1,2,1,1,1,1,0,0,0,0, +0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,2,1,2,2,2,2,2,2,2,2,2,2,1,2,1,2,1,1,2,1,1,1,2,1,2,1,2,0,1,0,1, +0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,3,1,2,2,2,1,2,2,2,2,2,2,2,2,1,2,1,1,1,1,1,1,2,1,2,1,1,0,1,0,1, +0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,1,2,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2, +0,2,0,1,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0, +3,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,1,1,1,1,1,1,1,0,1,1,0,1,0,0,1,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,2,0,1,1,1,0,1,0,0,0,1,1,0,1,1,0,0,0,0,0,1,1,0,0, +0,1,1,1,2,1,2,2,2,0,2,0,2,0,1,1,2,1,1,1,1,2,1,0,1,1,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,0,1,0,0,0,0,0,1,0,1,2,2,0,1,0,0,1,1,2,2,1,2,0,2,0,0,0,1,2,0,1, +2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,2,0,2,1,2,0,2,0,0,1,1,1,1,1,1,0,1,0,0,0,1,0,0,1, +2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,1,0,0,0,0,0,1,0,2,1,1,0,1,0,0,1,1,1,2,2,0,0,1,0,0,0,1,0,0,1, +1,1,2,1,0,1,1,1,0,1,0,1,1,1,1,0,0,0,1,0,1,0,0,0,0,0,0,0,0,2,2,1, +0,2,0,1,2,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,1,0,0,1,0,1,1,1,1,0,0,0,0,0,1,0,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,1,1,1,1,1,1,1,1,2,1,0,1,1,1,1,1,1,1,1,1,1,1,0,1,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,1,1,1,0,0,0,0,1,1,1,0,1,1,0,1,0,0,0,1,1,0,1, +2,0,1,0,1,0,1,0,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,1,0,1,1,1,0,1,0,0,1,1,2,1,1,2,0,1,0,0,0,1,1,0,1, +1,0,0,1,0,0,1,0,0,0,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,1,0,1,1,2,0,1,0,0,0,0,2,1,1,2,0,2,0,0,0,1,1,0,1, +1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,1,0,2,1,1,0,1,0,0,2,2,1,2,1,1,0,1,0,0,0,1,1,0,1, +2,0,1,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,1,2,2,0,0,0,0,0,1,1,0,1,0,0,1,0,0,0,0,1,0,1, +1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,1,2,2,0,0,0,0,2,1,1,1,0,2,1,1,0,0,0,2,1,0,1, +1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,1,0,1,1,2,0,1,0,0,1,1,0,2,1,1,0,1,0,0,0,1,1,0,1, +2,2,1,1,1,0,1,1,0,1,1,0,1,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,1,0,2,1,1,0,1,0,0,1,1,0,1,2,1,0,2,0,0,0,1,1,0,1, +2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0, +0,1,0,0,2,0,2,1,1,0,1,0,1,0,0,1,0,0,0,0,1,0,0,0,1,0,0,0,0,0,1,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,0,0,1,0,0,1,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,1,0,1,1,2,0,1,0,0,1,1,1,0,1,0,0,1,0,0,0,1,0,0,1, +1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,0,0,0,0,0,0,0,1,0,1,1,0,0,1,0,0,2,1,1,1,1,1,0,1,0,0,0,0,1,0,1, +0,1,1,1,2,1,1,1,1,0,1,1,1,1,1,1,1,1,1,1,1,1,0,1,1,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,1,2,1,0,0,0,0,0,1,1,1,1,1,0,1,0,0,0,1,1,0,0, +) + +Win1255HebrewModel = { + 'char_to_order_map': WIN1255_CHAR_TO_ORDER_MAP, + 'precedence_matrix': HEBREW_LANG_MODEL, + 'typical_positive_ratio': 0.984004, + 'keep_english_letter': False, + 'charset_name': "windows-1255", + 'language': 'Hebrew', +} diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langhungarianmodel.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langhungarianmodel.py new file mode 100644 index 0000000..bb7c095 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langhungarianmodel.py @@ -0,0 +1,225 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Communicator client code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +# 255: Control characters that usually does not exist in any text +# 254: Carriage/Return +# 253: symbol (punctuation) that does not belong to word +# 252: 0 - 9 + +# Character Mapping Table: +Latin2_HungarianCharToOrderMap = ( +255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255, # 00 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 10 +253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253, # 20 +252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253, # 30 +253, 28, 40, 54, 45, 32, 50, 49, 38, 39, 53, 36, 41, 34, 35, 47, + 46, 71, 43, 33, 37, 57, 48, 64, 68, 55, 52,253,253,253,253,253, +253, 2, 18, 26, 17, 1, 27, 12, 20, 9, 22, 7, 6, 13, 4, 8, + 23, 67, 10, 5, 3, 21, 19, 65, 62, 16, 11,253,253,253,253,253, +159,160,161,162,163,164,165,166,167,168,169,170,171,172,173,174, +175,176,177,178,179,180,181,182,183,184,185,186,187,188,189,190, +191,192,193,194,195,196,197, 75,198,199,200,201,202,203,204,205, + 79,206,207,208,209,210,211,212,213,214,215,216,217,218,219,220, +221, 51, 81,222, 78,223,224,225,226, 44,227,228,229, 61,230,231, +232,233,234, 58,235, 66, 59,236,237,238, 60, 69, 63,239,240,241, + 82, 14, 74,242, 70, 80,243, 72,244, 15, 83, 77, 84, 30, 76, 85, +245,246,247, 25, 73, 42, 24,248,249,250, 31, 56, 29,251,252,253, +) + +win1250HungarianCharToOrderMap = ( +255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255, # 00 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 10 +253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253, # 20 +252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253, # 30 +253, 28, 40, 54, 45, 32, 50, 49, 38, 39, 53, 36, 41, 34, 35, 47, + 46, 72, 43, 33, 37, 57, 48, 64, 68, 55, 52,253,253,253,253,253, +253, 2, 18, 26, 17, 1, 27, 12, 20, 9, 22, 7, 6, 13, 4, 8, + 23, 67, 10, 5, 3, 21, 19, 65, 62, 16, 11,253,253,253,253,253, +161,162,163,164,165,166,167,168,169,170,171,172,173,174,175,176, +177,178,179,180, 78,181, 69,182,183,184,185,186,187,188,189,190, +191,192,193,194,195,196,197, 76,198,199,200,201,202,203,204,205, + 81,206,207,208,209,210,211,212,213,214,215,216,217,218,219,220, +221, 51, 83,222, 80,223,224,225,226, 44,227,228,229, 61,230,231, +232,233,234, 58,235, 66, 59,236,237,238, 60, 70, 63,239,240,241, + 84, 14, 75,242, 71, 82,243, 73,244, 15, 85, 79, 86, 30, 77, 87, +245,246,247, 25, 74, 42, 24,248,249,250, 31, 56, 29,251,252,253, +) + +# Model Table: +# total sequences: 100% +# first 512 sequences: 94.7368% +# first 1024 sequences:5.2623% +# rest sequences: 0.8894% +# negative sequences: 0.0009% +HungarianLangModel = ( +0,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,1,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3, +3,3,3,3,3,3,3,3,3,3,2,3,3,3,3,3,3,3,3,2,2,3,3,1,1,2,2,2,2,2,1,2, +3,2,2,3,3,3,3,3,2,3,3,3,3,3,3,1,2,3,3,3,3,2,3,3,1,1,3,3,0,1,1,1, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0, +3,2,1,3,3,3,3,3,2,3,3,3,3,3,1,1,2,3,3,3,3,3,3,3,1,1,3,2,0,1,1,1, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0, +3,3,3,3,3,3,3,3,3,3,3,1,1,2,3,3,3,1,3,3,3,3,3,1,3,3,2,2,0,3,2,3, +0,0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0, +3,3,3,3,3,3,2,3,3,3,2,3,3,2,3,3,3,3,3,2,3,3,2,2,3,2,3,2,0,3,2,2, +0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,1,0, +3,3,3,3,3,3,2,3,3,3,3,3,2,3,3,3,1,2,3,2,2,3,1,2,3,3,2,2,0,3,3,3, +0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,3,3,3,2,2,3,3,3,3,3,3,2,3,3,3,3,2,3,3,3,3,0,2,3,2, +0,0,0,1,1,0,0,0,0,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,3,3,3,3,1,1,1,3,3,2,1,3,2,2,3,2,1,3,2,2,1,0,3,3,1, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0, +3,2,2,3,3,3,3,3,1,2,3,3,3,3,1,2,1,3,3,3,3,2,2,3,1,1,3,2,0,1,1,1, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0, +3,3,3,3,3,3,3,3,2,2,3,3,3,3,3,2,1,3,3,3,3,3,2,2,1,3,3,3,0,1,1,2, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,1,0, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,2,3,3,3,2,3,3,2,3,3,3,2,0,3,2,3, +0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,1,0, +3,3,3,3,3,3,2,3,3,3,2,3,2,3,3,3,1,3,2,2,2,3,1,1,3,3,1,1,0,3,3,2, +0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,2,3,3,3,2,3,2,3,3,3,2,3,3,3,3,3,1,2,3,2,2,0,2,2,2, +0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0, +3,3,3,2,2,2,3,1,3,3,2,2,1,3,3,3,1,1,3,1,2,3,2,3,2,2,2,1,0,2,2,2, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0, +3,1,1,3,3,3,3,3,1,2,3,3,3,3,1,2,1,3,3,3,2,2,3,2,1,0,3,2,0,1,1,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,1,1,3,3,3,3,3,1,2,3,3,3,3,1,1,0,3,3,3,3,0,2,3,0,0,2,1,0,1,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,2,2,3,3,2,2,2,2,3,3,0,1,2,3,2,3,2,2,3,2,1,2,0,2,2,2, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0, +3,3,3,3,3,3,1,2,3,3,3,2,1,2,3,3,2,2,2,3,2,3,3,1,3,3,1,1,0,2,3,2, +0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0, +3,3,3,1,2,2,2,2,3,3,3,1,1,1,3,3,1,1,3,1,1,3,2,1,2,3,1,1,0,2,2,2, +0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0, +3,3,3,2,1,2,1,1,3,3,1,1,1,1,3,3,1,1,2,2,1,2,1,1,2,2,1,1,0,2,2,1, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0, +3,3,3,1,1,2,1,1,3,3,1,0,1,1,3,3,2,0,1,1,2,3,1,0,2,2,1,0,0,1,3,2, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0, +3,2,1,3,3,3,3,3,1,2,3,2,3,3,2,1,1,3,2,3,2,1,2,2,0,1,2,1,0,0,1,1, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0, +3,3,3,3,2,2,2,2,3,1,2,2,1,1,3,3,0,3,2,1,2,3,2,1,3,3,1,1,0,2,1,3, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0, +3,3,3,2,2,2,3,2,3,3,3,2,1,1,3,3,1,1,1,2,2,3,2,3,2,2,2,1,0,2,2,1, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0, +1,0,0,3,3,3,3,3,0,0,3,3,2,3,0,0,0,2,3,3,1,0,1,2,0,0,1,1,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,1,2,3,3,3,3,3,1,2,3,3,2,2,1,1,0,3,3,2,2,1,2,2,1,0,2,2,0,1,1,1, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,2,2,1,3,1,2,3,3,2,2,1,1,2,2,1,1,1,1,3,2,1,1,1,1,2,1,0,1,2,1, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,1,0,0,0,0,0,0,0,0,0, +2,3,3,1,1,1,1,1,3,3,3,0,1,1,3,3,1,1,1,1,1,2,2,0,3,1,1,2,0,2,1,1, +0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0, +3,1,0,1,2,1,2,2,0,1,2,3,1,2,0,0,0,2,1,1,1,1,1,2,0,0,1,1,0,0,0,0, +1,2,1,2,2,2,1,2,1,2,0,2,0,2,2,1,1,2,1,1,2,1,1,1,0,1,0,0,0,1,1,0, +1,1,1,2,3,2,3,3,0,1,2,2,3,1,0,1,0,2,1,2,2,0,1,1,0,0,1,1,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,0,0,3,3,2,2,1,0,0,3,2,3,2,0,0,0,1,1,3,0,0,1,1,0,0,2,1,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,1,1,2,2,3,3,1,0,1,3,2,3,1,1,1,0,1,1,1,1,1,3,1,0,0,2,2,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,1,1,1,2,2,2,1,0,1,2,3,3,2,0,0,0,2,1,1,1,2,1,1,1,0,1,1,1,0,0,0, +1,2,2,2,2,2,1,1,1,2,0,2,1,1,1,1,1,2,1,1,1,1,1,1,0,1,1,1,0,0,1,1, +3,2,2,1,0,0,1,1,2,2,0,3,0,1,2,1,1,0,0,1,1,1,0,1,1,1,1,0,2,1,1,1, +2,2,1,1,1,2,1,2,1,1,1,1,1,1,1,2,1,1,1,2,3,1,1,1,1,1,1,1,1,1,0,1, +2,3,3,0,1,0,0,0,3,3,1,0,0,1,2,2,1,0,0,0,0,2,0,0,1,1,1,0,2,1,1,1, +2,1,1,1,1,1,1,2,1,1,0,1,1,0,1,1,1,0,1,2,1,1,0,1,1,1,1,1,1,1,0,1, +2,3,3,0,1,0,0,0,2,2,0,0,0,0,1,2,2,0,0,0,0,1,0,0,1,1,0,0,2,0,1,0, +2,1,1,1,1,2,1,1,1,1,1,1,1,2,1,1,1,1,1,1,1,1,1,2,0,1,1,1,1,1,0,1, +3,2,2,0,1,0,1,0,2,3,2,0,0,1,2,2,1,0,0,1,1,1,0,0,2,1,0,1,2,2,1,1, +2,1,1,1,1,1,1,2,1,1,1,1,1,1,0,2,1,0,1,1,0,1,1,1,0,1,1,2,1,1,0,1, +2,2,2,0,0,1,0,0,2,2,1,1,0,0,2,1,1,0,0,0,1,2,0,0,2,1,0,0,2,1,1,1, +2,1,1,1,1,2,1,2,1,1,1,2,2,1,1,2,1,1,1,2,1,1,1,1,1,1,1,1,1,1,0,1, +1,2,3,0,0,0,1,0,3,2,1,0,0,1,2,1,1,0,0,0,0,2,1,0,1,1,0,0,2,1,2,1, +1,1,0,0,0,1,0,1,1,1,1,1,2,0,0,1,0,0,0,2,0,0,1,1,1,1,1,1,1,1,0,1, +3,0,0,2,1,2,2,1,0,0,2,1,2,2,0,0,0,2,1,1,1,0,1,1,0,0,1,1,2,0,0,0, +1,2,1,2,2,1,1,2,1,2,0,1,1,1,1,1,1,1,1,1,2,1,1,0,0,1,1,1,1,0,0,1, +1,3,2,0,0,0,1,0,2,2,2,0,0,0,2,2,1,0,0,0,0,3,1,1,1,1,0,0,2,1,1,1, +2,1,0,1,1,1,0,1,1,1,1,1,1,1,0,2,1,0,0,1,0,1,1,0,1,1,1,1,1,1,0,1, +2,3,2,0,0,0,1,0,2,2,0,0,0,0,2,1,1,0,0,0,0,2,1,0,1,1,0,0,2,1,1,0, +2,1,1,1,1,2,1,2,1,2,0,1,1,1,0,2,1,1,1,2,1,1,1,1,0,1,1,1,1,1,0,1, +3,1,1,2,2,2,3,2,1,1,2,2,1,1,0,1,0,2,2,1,1,1,1,1,0,0,1,1,0,1,1,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,2,2,0,0,0,0,0,2,2,0,0,0,0,2,2,1,0,0,0,1,1,0,0,1,2,0,0,2,1,1,1, +2,2,1,1,1,2,1,2,1,1,0,1,1,1,1,2,1,1,1,2,1,1,1,1,0,1,2,1,1,1,0,1, +1,0,0,1,2,3,2,1,0,0,2,0,1,1,0,0,0,1,1,1,1,0,1,1,0,0,1,0,0,0,0,0, +1,2,1,2,1,2,1,1,1,2,0,2,1,1,1,0,1,2,0,0,1,1,1,0,0,0,0,0,0,0,0,0, +2,3,2,0,0,0,0,0,1,1,2,1,0,0,1,1,1,0,0,0,0,2,0,0,1,1,0,0,2,1,1,1, +2,1,1,1,1,1,1,2,1,0,1,1,1,1,0,2,1,1,1,1,1,1,0,1,0,1,1,1,1,1,0,1, +1,2,2,0,1,1,1,0,2,2,2,0,0,0,3,2,1,0,0,0,1,1,0,0,1,1,0,1,1,1,0,0, +1,1,0,1,1,1,1,1,1,1,1,2,1,1,1,1,1,1,1,2,1,1,1,0,0,1,1,1,0,1,0,1, +2,1,0,2,1,1,2,2,1,1,2,1,1,1,0,0,0,1,1,0,1,1,1,1,0,0,1,1,1,0,0,0, +1,2,2,2,2,2,1,1,1,2,0,2,1,1,1,1,1,1,1,1,1,1,1,1,0,1,1,0,0,0,1,0, +1,2,3,0,0,0,1,0,2,2,0,0,0,0,2,2,0,0,0,0,0,1,0,0,1,0,0,0,2,0,1,0, +2,1,1,1,1,1,0,2,0,0,0,1,2,1,1,1,1,0,1,2,0,1,0,1,0,1,1,1,0,1,0,1, +2,2,2,0,0,0,1,0,2,1,2,0,0,0,1,1,2,0,0,0,0,1,0,0,1,1,0,0,2,1,0,1, +2,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,2,0,1,1,1,1,1,0,1, +1,2,2,0,0,0,1,0,2,2,2,0,0,0,1,1,0,0,0,0,0,1,1,0,2,0,0,1,1,1,0,1, +1,0,1,1,1,1,1,1,0,1,1,1,1,0,0,1,0,0,1,1,0,1,0,1,1,1,1,1,0,0,0,1, +1,0,0,1,0,1,2,1,0,0,1,1,1,2,0,0,0,1,1,0,1,0,1,1,0,0,1,0,0,0,0,0, +0,2,1,2,1,1,1,1,1,2,0,2,0,1,1,0,1,2,1,0,1,1,1,0,0,0,0,0,0,1,0,0, +2,1,1,0,1,2,0,0,1,1,1,0,0,0,1,1,0,0,0,0,0,1,0,0,1,0,0,0,2,1,0,1, +2,2,1,1,1,1,1,2,1,1,0,1,1,1,1,2,1,1,1,2,1,1,0,1,0,1,1,1,1,1,0,1, +1,2,2,0,0,0,0,0,1,1,0,0,0,0,2,1,0,0,0,0,0,2,0,0,2,2,0,0,2,0,0,1, +2,1,1,1,1,1,1,1,0,1,1,0,1,1,0,1,0,0,0,1,1,1,1,0,0,1,1,1,1,0,0,1, +1,1,2,0,0,3,1,0,2,1,1,1,0,0,1,1,1,0,0,0,1,1,0,0,0,1,0,0,1,0,1,0, +1,2,1,0,1,1,1,2,1,1,0,1,1,1,1,1,0,0,0,1,1,1,1,1,0,1,0,0,0,1,0,0, +2,1,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,1,0,1,0,0,0,1,0,0,0,0,2,0,0,0, +2,1,1,1,1,1,1,1,1,1,0,1,1,1,1,1,1,1,1,1,2,1,1,0,0,1,1,1,1,1,0,1, +2,1,1,1,2,1,1,1,0,1,1,2,1,0,0,0,0,1,1,1,1,0,1,0,0,0,0,1,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,1,0,1,1,1,1,1,0,0,1,1,2,1,0,0,0,1,1,0,0,0,1,1,0,0,1,0,1,0,0,0, +1,2,1,1,1,1,1,1,1,1,0,1,0,1,1,1,1,1,1,0,1,1,1,0,0,0,0,0,0,1,0,0, +2,0,0,0,1,1,1,1,0,0,1,1,0,0,0,0,0,1,1,1,2,0,0,1,0,0,1,0,1,0,0,0, +0,1,1,1,1,1,1,1,1,2,0,1,1,1,1,0,1,1,1,0,1,1,1,0,0,0,0,0,0,0,0,0, +1,0,0,1,1,1,1,1,0,0,2,1,0,1,0,0,0,1,0,1,0,0,0,0,0,0,1,0,0,0,0,0, +0,1,1,1,1,1,1,0,1,1,0,1,0,1,1,0,1,1,0,0,1,1,1,0,0,0,0,0,0,0,0,0, +1,0,0,1,1,1,0,0,0,0,1,0,2,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0, +0,1,1,1,1,1,0,0,1,1,0,1,0,1,0,0,1,1,1,0,1,1,1,0,0,0,0,0,0,0,0,0, +0,0,0,1,0,0,0,0,0,0,1,1,2,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,1,1,1,0,1,0,0,1,1,0,1,0,1,1,0,1,1,1,0,1,1,1,0,0,0,0,0,0,0,0,0, +2,1,1,1,1,1,1,1,1,1,1,0,0,1,1,1,0,0,1,0,0,1,0,1,0,1,1,1,0,0,1,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,0,0,1,1,1,1,0,0,0,1,1,1,0,0,0,0,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0, +0,1,1,1,1,1,1,0,1,1,0,1,0,1,0,0,1,1,0,0,1,1,0,0,0,0,0,0,0,0,0,0, +) + +Latin2HungarianModel = { + 'char_to_order_map': Latin2_HungarianCharToOrderMap, + 'precedence_matrix': HungarianLangModel, + 'typical_positive_ratio': 0.947368, + 'keep_english_letter': True, + 'charset_name': "ISO-8859-2", + 'language': 'Hungarian', +} + +Win1250HungarianModel = { + 'char_to_order_map': win1250HungarianCharToOrderMap, + 'precedence_matrix': HungarianLangModel, + 'typical_positive_ratio': 0.947368, + 'keep_english_letter': True, + 'charset_name': "windows-1250", + 'language': 'Hungarian', +} diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langthaimodel.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langthaimodel.py new file mode 100644 index 0000000..15f94c2 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langthaimodel.py @@ -0,0 +1,199 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Communicator client code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +# 255: Control characters that usually does not exist in any text +# 254: Carriage/Return +# 253: symbol (punctuation) that does not belong to word +# 252: 0 - 9 + +# The following result for thai was collected from a limited sample (1M). + +# Character Mapping Table: +TIS620CharToOrderMap = ( +255,255,255,255,255,255,255,255,255,255,254,255,255,254,255,255, # 00 +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, # 10 +253,253,253,253,253,253,253,253,253,253,253,253,253,253,253,253, # 20 +252,252,252,252,252,252,252,252,252,252,253,253,253,253,253,253, # 30 +253,182,106,107,100,183,184,185,101, 94,186,187,108,109,110,111, # 40 +188,189,190, 89, 95,112,113,191,192,193,194,253,253,253,253,253, # 50 +253, 64, 72, 73,114, 74,115,116,102, 81,201,117, 90,103, 78, 82, # 60 + 96,202, 91, 79, 84,104,105, 97, 98, 92,203,253,253,253,253,253, # 70 +209,210,211,212,213, 88,214,215,216,217,218,219,220,118,221,222, +223,224, 99, 85, 83,225,226,227,228,229,230,231,232,233,234,235, +236, 5, 30,237, 24,238, 75, 8, 26, 52, 34, 51,119, 47, 58, 57, + 49, 53, 55, 43, 20, 19, 44, 14, 48, 3, 17, 25, 39, 62, 31, 54, + 45, 9, 16, 2, 61, 15,239, 12, 42, 46, 18, 21, 76, 4, 66, 63, + 22, 10, 1, 36, 23, 13, 40, 27, 32, 35, 86,240,241,242,243,244, + 11, 28, 41, 29, 33,245, 50, 37, 6, 7, 67, 77, 38, 93,246,247, + 68, 56, 59, 65, 69, 60, 70, 80, 71, 87,248,249,250,251,252,253, +) + +# Model Table: +# total sequences: 100% +# first 512 sequences: 92.6386% +# first 1024 sequences:7.3177% +# rest sequences: 1.0230% +# negative sequences: 0.0436% +ThaiLangModel = ( +0,1,3,3,3,3,0,0,3,3,0,3,3,0,3,3,3,3,3,3,3,3,0,0,3,3,3,0,3,3,3,3, +0,3,3,0,0,0,1,3,0,3,3,2,3,3,0,1,2,3,3,3,3,0,2,0,2,0,0,3,2,1,2,2, +3,0,3,3,2,3,0,0,3,3,0,3,3,0,3,3,3,3,3,3,3,3,3,0,3,2,3,0,2,2,2,3, +0,2,3,0,0,0,0,1,0,1,2,3,1,1,3,2,2,0,1,1,0,0,1,0,0,0,0,0,0,0,1,1, +3,3,3,2,3,3,3,3,3,3,3,3,3,3,3,2,2,2,2,2,2,2,3,3,2,3,2,3,3,2,2,2, +3,1,2,3,0,3,3,2,2,1,2,3,3,1,2,0,1,3,0,1,0,0,1,0,0,0,0,0,0,0,1,1, +3,3,2,2,3,3,3,3,1,2,3,3,3,3,3,2,2,2,2,3,3,2,2,3,3,2,2,3,2,3,2,2, +3,3,1,2,3,1,2,2,3,3,1,0,2,1,0,0,3,1,2,1,0,0,1,0,0,0,0,0,0,1,0,1, +3,3,3,3,3,3,2,2,3,3,3,3,2,3,2,2,3,3,2,2,3,2,2,2,2,1,1,3,1,2,1,1, +3,2,1,0,2,1,0,1,0,1,1,0,1,1,0,0,1,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0, +3,3,3,2,3,2,3,3,2,2,3,2,3,3,2,3,1,1,2,3,2,2,2,3,2,2,2,2,2,1,2,1, +2,2,1,1,3,3,2,1,0,1,2,2,0,1,3,0,0,0,1,1,0,0,0,0,0,2,3,0,0,2,1,1, +3,3,2,3,3,2,0,0,3,3,0,3,3,0,2,2,3,1,2,2,1,1,1,0,2,2,2,0,2,2,1,1, +0,2,1,0,2,0,0,2,0,1,0,0,1,0,0,0,1,1,1,1,0,0,0,0,0,0,0,0,0,0,1,0, +3,3,2,3,3,2,0,0,3,3,0,2,3,0,2,1,2,2,2,2,1,2,0,0,2,2,2,0,2,2,1,1, +0,2,1,0,2,0,0,2,0,1,1,0,1,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0, +3,3,2,3,2,3,2,0,2,2,1,3,2,1,3,2,1,2,3,2,2,3,0,2,3,2,2,1,2,2,2,2, +1,2,2,0,0,0,0,2,0,1,2,0,1,1,1,0,1,0,3,1,1,0,0,0,0,0,0,0,0,0,1,0, +3,3,2,3,3,2,3,2,2,2,3,2,2,3,2,2,1,2,3,2,2,3,1,3,2,2,2,3,2,2,2,3, +3,2,1,3,0,1,1,1,0,2,1,1,1,1,1,0,1,0,1,1,0,0,0,0,0,0,0,0,0,2,0,0, +1,0,0,3,0,3,3,3,3,3,0,0,3,0,2,2,3,3,3,3,3,0,0,0,1,1,3,0,0,0,0,2, +0,0,1,0,0,0,0,0,0,0,2,3,0,0,0,3,0,2,0,0,0,0,0,3,0,0,0,0,0,0,0,0, +2,0,3,3,3,3,0,0,2,3,0,0,3,0,3,3,2,3,3,3,3,3,0,0,3,3,3,0,0,0,3,3, +0,0,3,0,0,0,0,2,0,0,2,1,1,3,0,0,1,0,0,2,3,0,1,0,0,0,0,0,0,0,1,0, +3,3,3,3,2,3,3,3,3,3,3,3,1,2,1,3,3,2,2,1,2,2,2,3,1,1,2,0,2,1,2,1, +2,2,1,0,0,0,1,1,0,1,0,1,1,0,0,0,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0, +3,0,2,1,2,3,3,3,0,2,0,2,2,0,2,1,3,2,2,1,2,1,0,0,2,2,1,0,2,1,2,2, +0,1,1,0,0,0,0,1,0,1,1,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,2,1,3,3,1,1,3,0,2,3,1,1,3,2,1,1,2,0,2,2,3,2,1,1,1,1,1,2, +3,0,0,1,3,1,2,1,2,0,3,0,0,0,1,0,3,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0, +3,3,1,1,3,2,3,3,3,1,3,2,1,3,2,1,3,2,2,2,2,1,3,3,1,2,1,3,1,2,3,0, +2,1,1,3,2,2,2,1,2,1,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2, +3,3,2,3,2,3,3,2,3,2,3,2,3,3,2,1,0,3,2,2,2,1,2,2,2,1,2,2,1,2,1,1, +2,2,2,3,0,1,3,1,1,1,1,0,1,1,0,2,1,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,2,3,2,2,1,1,3,2,3,2,3,2,0,3,2,2,1,2,0,2,2,2,1,2,2,2,2,1, +3,2,1,2,2,1,0,2,0,1,0,0,1,1,0,0,0,0,0,1,1,0,1,0,0,0,0,0,0,0,0,1, +3,3,3,3,3,2,3,1,2,3,3,2,2,3,0,1,1,2,0,3,3,2,2,3,0,1,1,3,0,0,0,0, +3,1,0,3,3,0,2,0,2,1,0,0,3,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,2,3,2,3,3,0,1,3,1,1,2,1,2,1,1,3,1,1,0,2,3,1,1,1,1,1,1,1,1, +3,1,1,2,2,2,2,1,1,1,0,0,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1, +3,2,2,1,1,2,1,3,3,2,3,2,2,3,2,2,3,1,2,2,1,2,0,3,2,1,2,2,2,2,2,1, +3,2,1,2,2,2,1,1,1,1,0,0,1,1,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,3,1,3,3,0,2,1,0,3,2,0,0,3,1,0,1,1,0,1,0,0,0,0,0,1, +1,0,0,1,0,3,2,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,0,2,2,2,3,0,0,1,3,0,3,2,0,3,2,2,3,3,3,3,3,1,0,2,2,2,0,2,2,1,2, +0,2,3,0,0,0,0,1,0,1,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1, +3,0,2,3,1,3,3,2,3,3,0,3,3,0,3,2,2,3,2,3,3,3,0,0,2,2,3,0,1,1,1,3, +0,0,3,0,0,0,2,2,0,1,3,0,1,2,2,2,3,0,0,0,0,0,1,0,0,0,0,0,0,0,0,1, +3,2,3,3,2,0,3,3,2,2,3,1,3,2,1,3,2,0,1,2,2,0,2,3,2,1,0,3,0,0,0,0, +3,0,0,2,3,1,3,0,0,3,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,1,3,2,2,2,1,2,0,1,3,1,1,3,1,3,0,0,2,1,1,1,1,2,1,1,1,0,2,1,0,1, +1,2,0,0,0,3,1,1,0,0,0,0,1,0,1,0,0,1,0,1,0,0,0,0,0,3,1,0,0,0,1,0, +3,3,3,3,2,2,2,2,2,1,3,1,1,1,2,0,1,1,2,1,2,1,3,2,0,0,3,1,1,1,1,1, +3,1,0,2,3,0,0,0,3,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,2,3,0,3,3,0,2,0,0,0,0,0,0,0,3,0,0,1,0,0,0,0,0,0,0,0,0,0,0, +0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,2,3,1,3,0,0,1,2,0,0,2,0,3,3,2,3,3,3,2,3,0,0,2,2,2,0,0,0,2,2, +0,0,1,0,0,0,0,3,0,0,0,0,2,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0, +0,0,0,3,0,2,0,0,0,0,0,0,0,0,0,0,1,2,3,1,3,3,0,0,1,0,3,0,0,0,0,0, +0,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,1,2,3,1,2,3,1,0,3,0,2,2,1,0,2,1,1,2,0,1,0,0,1,1,1,1,0,1,0,0, +1,0,0,0,0,1,1,0,3,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,2,1,0,1,1,1,3,1,2,2,2,2,2,2,1,1,1,1,0,3,1,0,1,3,1,1,1,1, +1,1,0,2,0,1,3,1,1,0,0,1,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,2,0,1, +3,0,2,2,1,3,3,2,3,3,0,1,1,0,2,2,1,2,1,3,3,1,0,0,3,2,0,0,0,0,2,1, +0,1,0,0,0,0,1,2,0,1,1,3,1,1,2,2,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0, +0,0,3,0,0,1,0,0,0,3,0,0,3,0,3,1,0,1,1,1,3,2,0,0,0,3,0,0,0,0,2,0, +0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,2,0,0,0,0,0,0,0,0,0, +3,3,1,3,2,1,3,3,1,2,2,0,1,2,1,0,1,2,0,0,0,0,0,3,0,0,0,3,0,0,0,0, +3,0,0,1,1,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,0,1,2,0,3,3,3,2,2,0,1,1,0,1,3,0,0,0,2,2,0,0,0,0,3,1,0,1,0,0,0, +0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,0,2,3,1,2,0,0,2,1,0,3,1,0,1,2,0,1,1,1,1,3,0,0,3,1,1,0,2,2,1,1, +0,2,0,0,0,0,0,1,0,1,0,0,1,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,0,0,3,1,2,0,0,2,2,0,1,2,0,1,0,1,3,1,2,1,0,0,0,2,0,3,0,0,0,1,0, +0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,0,1,1,2,2,0,0,0,2,0,2,1,0,1,1,0,1,1,1,2,1,0,0,1,1,1,0,2,1,1,1, +0,1,1,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,1, +0,0,0,2,0,1,3,1,1,1,1,0,0,0,0,3,2,0,1,0,0,0,1,2,0,0,0,1,0,0,0,0, +0,0,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,3,3,3,3,1,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,0,2,3,2,2,0,0,0,1,0,0,0,0,2,3,2,1,2,2,3,0,0,0,2,3,1,0,0,0,1,1, +0,0,1,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,1,1,0,1,0,0,0,0,0,0,0,0,0, +3,3,2,2,0,1,0,0,0,0,2,0,2,0,1,0,0,0,1,1,0,0,0,2,1,0,1,0,1,1,0,0, +0,1,0,2,0,0,1,0,3,0,1,0,0,0,2,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,1,0,0,1,0,0,0,0,0,1,1,2,0,0,0,0,1,0,0,1,3,1,0,0,0,0,1,1,0,0, +0,1,0,0,0,0,3,0,0,0,0,0,0,3,0,0,0,0,0,0,0,3,0,0,0,0,0,0,0,0,0,0, +3,3,1,1,1,1,2,3,0,0,2,1,1,1,1,1,0,2,1,1,0,0,0,2,1,0,1,2,1,1,0,1, +2,1,0,3,0,0,0,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,3,1,0,0,0,0,0,0,0,3,0,0,0,3,0,0,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1, +0,0,0,2,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,2,0,0,0,0,0,0,1,2,1,0,1,1,0,2,0,0,1,0,0,2,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,2,0,0,0,1,3,0,1,0,0,0,2,0,0,0,0,0,0,0,1,2,0,0,0,0,0, +3,3,0,0,1,1,2,0,0,1,2,1,0,1,1,1,0,1,1,0,0,2,1,1,0,1,0,0,1,1,1,0, +0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,3,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,2,2,1,0,0,0,0,1,0,0,0,0,3,0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,0,0,0, +2,0,0,0,0,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,3,0,0,1,1,0,0,0,2,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +1,1,0,1,2,0,1,2,0,0,1,1,0,2,0,1,0,0,1,0,0,0,0,1,0,0,0,2,0,0,0,0, +1,0,0,1,0,1,1,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,1,0,0,0,0,0,0,0,1,1,0,1,1,0,2,1,3,0,0,0,0,1,1,0,0,0,0,0,0,0,3, +1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,0,1,0,1,0,0,2,0,0,2,0,0,1,1,2,0,0,1,1,0,0,0,1,0,0,0,1,1,0,0,0, +1,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0, +1,0,0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,1, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,1,1,0,0,0, +2,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,0,0,0,0,2,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,1,3,0,0,0, +2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,1,0,0,0,0, +1,0,0,0,0,0,0,0,0,1,0,0,0,0,2,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,1,1,0,0,2,1,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +) + +TIS620ThaiModel = { + 'char_to_order_map': TIS620CharToOrderMap, + 'precedence_matrix': ThaiLangModel, + 'typical_positive_ratio': 0.926386, + 'keep_english_letter': False, + 'charset_name': "TIS-620", + 'language': 'Thai', +} diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langturkishmodel.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langturkishmodel.py new file mode 100644 index 0000000..a427a45 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/langturkishmodel.py @@ -0,0 +1,193 @@ +# -*- coding: utf-8 -*- +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Communicator client code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# Özgür Baskın - Turkish Language Model +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +# 255: Control characters that usually does not exist in any text +# 254: Carriage/Return +# 253: symbol (punctuation) that does not belong to word +# 252: 0 - 9 + +# Character Mapping Table: +Latin5_TurkishCharToOrderMap = ( +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, +255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, +255, 23, 37, 47, 39, 29, 52, 36, 45, 53, 60, 16, 49, 20, 46, 42, + 48, 69, 44, 35, 31, 51, 38, 62, 65, 43, 56,255,255,255,255,255, +255, 1, 21, 28, 12, 2, 18, 27, 25, 3, 24, 10, 5, 13, 4, 15, + 26, 64, 7, 8, 9, 14, 32, 57, 58, 11, 22,255,255,255,255,255, +180,179,178,177,176,175,174,173,172,171,170,169,168,167,166,165, +164,163,162,161,160,159,101,158,157,156,155,154,153,152,151,106, +150,149,148,147,146,145,144,100,143,142,141,140,139,138,137,136, + 94, 80, 93,135,105,134,133, 63,132,131,130,129,128,127,126,125, +124,104, 73, 99, 79, 85,123, 54,122, 98, 92,121,120, 91,103,119, + 68,118,117, 97,116,115, 50, 90,114,113,112,111, 55, 41, 40, 86, + 89, 70, 59, 78, 71, 82, 88, 33, 77, 66, 84, 83,110, 75, 61, 96, + 30, 67,109, 74, 87,102, 34, 95, 81,108, 76, 72, 17, 6, 19,107, +) + +TurkishLangModel = ( +3,2,3,3,3,1,3,3,3,3,3,3,3,3,2,1,1,3,3,1,3,3,0,3,3,3,3,3,0,3,1,3, +3,2,1,0,0,1,1,0,0,0,1,0,0,1,1,1,1,0,0,0,0,0,0,0,2,2,0,0,1,0,0,1, +3,2,2,3,3,0,3,3,3,3,3,3,3,2,3,1,0,3,3,1,3,3,0,3,3,3,3,3,0,3,0,3, +3,1,1,0,1,0,1,0,0,0,0,0,0,1,1,1,1,0,0,0,0,0,0,0,2,2,0,0,0,1,0,1, +3,3,2,3,3,0,3,3,3,3,3,3,3,2,3,1,1,3,3,0,3,3,1,2,3,3,3,3,0,3,0,3, +3,1,1,0,0,0,1,0,0,0,0,1,1,0,1,2,1,0,0,0,1,0,0,0,0,2,0,0,0,0,0,1, +3,3,3,3,3,3,2,3,3,3,3,3,3,3,3,1,3,3,2,0,3,2,1,2,2,1,3,3,0,0,0,2, +2,2,0,1,0,0,1,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,1,0,1,0,0,1, +3,3,3,2,3,3,1,2,3,3,3,3,3,3,3,1,3,2,1,0,3,2,0,1,2,3,3,2,1,0,0,2, +2,1,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,2,0,2,0,0,0, +1,0,1,3,3,1,3,3,3,3,3,3,3,1,2,0,0,2,3,0,2,3,0,0,2,2,2,3,0,3,0,1, +2,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,0,3,3,3,0,3,2,0,2,3,2,3,3,1,0,0,2, +3,2,0,0,1,0,0,0,0,0,0,2,0,0,1,0,0,0,0,0,0,0,0,0,1,1,1,0,2,0,0,1, +3,3,3,2,3,3,2,3,3,3,3,2,3,3,3,0,3,3,0,0,2,1,0,0,2,3,2,2,0,0,0,2, +2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,0,0,0,1,0,1,0,2,0,0,1, +3,3,3,2,3,3,3,3,3,3,3,2,3,3,3,0,3,2,0,1,3,2,1,1,3,2,3,2,1,0,0,2, +2,2,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0, +3,3,3,2,3,3,3,3,3,3,3,2,3,3,3,0,3,2,2,0,2,3,0,0,2,2,2,2,0,0,0,2, +3,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,2,0,1,0,0,0, +3,3,3,3,3,3,3,2,2,2,2,3,2,3,3,0,3,3,1,1,2,2,0,0,2,2,3,2,0,0,1,3, +0,3,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,0,1, +3,3,3,2,3,3,3,2,1,2,2,3,2,3,3,0,3,2,0,0,1,1,0,1,1,2,1,2,0,0,0,1, +0,3,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0,1,0,0,0, +3,3,3,2,3,3,2,3,2,2,2,3,3,3,3,1,3,1,1,0,3,2,1,1,3,3,2,3,1,0,0,1, +1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,2,0,0,1, +3,2,2,3,3,0,3,3,3,3,3,3,3,2,2,1,0,3,3,1,3,3,0,1,3,3,2,3,0,3,0,3, +2,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0, +2,2,2,3,3,0,3,3,3,3,3,3,3,3,3,0,0,3,2,0,3,3,0,3,2,3,3,3,0,3,1,3, +2,0,0,0,0,0,0,0,0,0,0,1,0,1,2,0,1,0,0,0,0,0,0,0,2,2,0,0,1,0,0,1, +3,3,3,1,2,3,3,1,0,0,1,0,0,3,3,2,3,0,0,2,0,0,2,0,2,0,0,0,2,0,2,0, +0,3,1,0,1,0,0,0,2,2,1,0,1,1,2,1,2,2,2,0,2,1,1,0,0,0,2,0,0,0,0,0, +1,2,1,3,3,0,3,3,3,3,3,2,3,0,0,0,0,2,3,0,2,3,1,0,2,3,1,3,0,3,0,2, +3,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,1,3,3,2,2,3,2,2,0,1,2,3,0,1,2,1,0,1,0,0,0,1,0,2,2,0,0,0,1, +1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,1,1,0,0,1,0,0,0, +3,3,3,1,3,3,1,1,3,3,1,1,3,3,1,0,2,1,2,0,2,1,0,0,1,1,2,1,0,0,0,2, +2,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,1,0,2,1,3,0,0,2,0,0,3,3,0,3,0,0,1,0,1,2,0,0,1,1,2,2,0,1,0, +0,1,2,1,1,0,1,0,1,1,1,1,1,0,1,1,1,2,2,1,2,0,1,0,0,0,0,0,0,1,0,0, +3,3,3,2,3,2,3,3,0,2,2,2,3,3,3,0,3,0,0,0,2,2,0,1,2,1,1,1,0,0,0,1, +0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0, +3,3,3,3,3,3,2,1,2,2,3,3,3,3,2,0,2,0,0,0,2,2,0,0,2,1,3,3,0,0,1,1, +1,1,0,0,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0,0,0, +1,1,2,3,3,0,3,3,3,3,3,3,2,2,0,2,0,2,3,2,3,2,2,2,2,2,2,2,1,3,2,3, +2,0,2,1,2,2,2,2,1,1,2,2,1,2,2,1,2,0,0,2,1,1,0,2,1,0,0,1,0,0,0,1, +2,3,3,1,1,1,0,1,1,1,2,3,2,1,1,0,0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,0, +0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,2,2,2,3,2,3,2,2,1,3,3,3,0,2,1,2,0,2,1,0,0,1,1,1,1,1,0,0,1, +2,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,2,0,1,0,0,0, +3,3,3,2,3,3,3,3,3,2,3,1,2,3,3,1,2,0,0,0,0,0,0,0,3,2,1,1,0,0,0,0, +2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0, +3,3,3,2,2,3,3,2,1,1,1,1,1,3,3,0,3,1,0,0,1,1,0,0,3,1,2,1,0,0,0,0, +0,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0, +3,3,3,2,2,3,2,2,2,3,2,1,1,3,3,0,3,0,0,0,0,1,0,0,3,1,1,2,0,0,0,1, +1,0,0,1,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1, +1,1,1,3,3,0,3,3,3,3,3,2,2,2,1,2,0,2,1,2,2,1,1,0,1,2,2,2,2,2,2,2, +0,0,2,1,2,1,2,1,0,1,1,3,1,2,1,1,2,0,0,2,0,1,0,1,0,1,0,0,0,1,0,1, +3,3,3,1,3,3,3,0,1,1,0,2,2,3,1,0,3,0,0,0,1,0,0,0,1,0,0,1,0,1,0,0, +1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,2,0,0,2,2,1,0,0,1,0,0,3,3,1,3,0,0,1,1,0,2,0,3,0,0,0,2,0,1,1, +0,1,2,0,1,2,2,0,2,2,2,2,1,0,2,1,1,0,2,0,2,1,2,0,0,0,0,0,0,0,0,0, +3,3,3,1,3,2,3,2,0,2,2,2,1,3,2,0,2,1,2,0,1,2,0,0,1,0,2,2,0,0,0,2, +1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,0,1,0,0,0, +3,3,3,0,3,3,1,1,2,3,1,0,3,2,3,0,3,0,0,0,1,0,0,0,1,0,1,0,0,0,0,0, +1,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,3,3,0,3,3,2,3,3,2,2,0,0,0,0,1,2,0,1,3,0,0,0,3,1,1,0,3,0,2, +2,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,1,2,2,1,0,3,1,1,1,1,3,3,2,3,0,0,1,0,1,2,0,2,2,0,2,2,0,2,1, +0,2,2,1,1,1,1,0,2,1,1,0,1,1,1,1,2,1,2,1,2,0,1,0,1,0,0,0,0,0,0,0, +3,3,3,0,1,1,3,0,0,1,1,0,0,2,2,0,3,0,0,1,1,0,1,0,0,0,0,0,2,0,0,0, +0,3,1,0,1,0,1,0,2,0,0,1,0,1,0,1,1,1,2,1,1,0,2,0,0,0,0,0,0,0,0,0, +3,3,3,0,2,0,2,0,1,1,1,0,0,3,3,0,2,0,0,1,0,0,2,1,1,0,1,0,1,0,1,0, +0,2,0,1,2,0,2,0,2,1,1,0,1,0,2,1,1,0,2,1,1,0,1,0,0,0,1,1,0,0,0,0, +3,2,3,0,1,0,0,0,0,0,0,0,0,1,2,0,1,0,0,1,0,0,1,0,0,0,0,0,2,0,0,0, +0,0,1,1,0,0,1,0,1,0,0,1,0,0,0,2,1,0,1,0,2,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,0,0,2,3,0,0,1,0,1,0,2,3,2,3,0,0,1,3,0,2,1,0,0,0,0,2,0,1,0, +0,2,1,0,0,1,1,0,2,1,0,0,1,0,0,1,1,0,1,1,2,0,1,0,0,0,0,1,0,0,0,0, +3,2,2,0,0,1,1,0,0,0,0,0,0,3,1,1,1,0,0,0,0,0,1,0,0,0,0,0,2,0,1,0, +0,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,0,0,1,0,1,0,0,0,0,0,0,0,0,0, +0,0,0,3,3,0,2,3,2,2,1,2,2,1,1,2,0,1,3,2,2,2,0,0,2,2,0,0,0,1,2,1, +3,0,2,1,1,0,1,1,1,0,1,2,2,2,1,1,2,0,0,0,0,1,0,1,1,0,0,0,0,0,0,0, +0,1,1,2,3,0,3,3,3,2,2,2,2,1,0,1,0,1,0,1,2,2,0,0,2,2,1,3,1,1,2,1, +0,0,1,1,2,0,1,1,0,0,1,2,0,2,1,1,2,0,0,1,0,0,0,1,0,1,0,1,0,0,0,0, +3,3,2,0,0,3,1,0,0,0,0,0,0,3,2,1,2,0,0,1,0,0,2,0,0,0,0,0,2,0,1,0, +0,2,1,1,0,0,1,0,1,2,0,0,1,1,0,0,2,1,1,1,1,0,2,0,0,0,0,0,0,0,0,0, +3,3,2,0,0,1,0,0,0,0,1,0,0,3,3,2,2,0,0,1,0,0,2,0,1,0,0,0,2,0,1,0, +0,0,1,1,0,0,2,0,2,1,0,0,1,1,2,1,2,0,2,1,2,1,1,1,0,0,1,1,0,0,0,0, +3,3,2,0,0,2,2,0,0,0,1,1,0,2,2,1,3,1,0,1,0,1,2,0,0,0,0,0,1,0,1,0, +0,1,1,0,0,0,0,0,1,0,0,1,0,0,0,1,1,0,1,0,1,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,2,0,0,0,1,0,0,1,0,0,2,3,1,2,0,0,1,0,0,2,0,0,0,1,0,2,0,2,0, +0,1,1,2,2,1,2,0,2,1,1,0,0,1,1,0,1,1,1,1,2,1,1,0,0,0,0,0,0,0,0,0, +3,3,3,0,2,1,2,1,0,0,1,1,0,3,3,1,2,0,0,1,0,0,2,0,2,0,1,1,2,0,0,0, +0,0,1,1,1,1,2,0,1,1,0,1,1,1,1,0,0,0,1,1,1,0,1,0,0,0,1,0,0,0,0,0, +3,3,3,0,2,2,3,2,0,0,1,0,0,2,3,1,0,0,0,0,0,0,2,0,2,0,0,0,2,0,0,0, +0,1,1,0,0,0,1,0,0,1,0,1,1,0,1,0,1,1,1,0,1,0,0,0,0,0,0,0,0,0,0,0, +3,2,3,0,0,0,0,0,0,0,1,0,0,2,2,2,2,0,0,1,0,0,2,0,0,0,0,0,2,0,1,0, +0,0,2,1,1,0,1,0,2,1,1,0,0,1,1,2,1,0,2,0,2,0,1,0,0,0,2,0,0,0,0,0, +0,0,0,2,2,0,2,1,1,1,1,2,2,0,0,1,0,1,0,0,1,3,0,0,0,0,1,0,0,2,1,0, +0,0,1,0,1,0,0,0,0,0,2,1,0,1,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0, +2,0,0,2,3,0,2,3,1,2,2,0,2,0,0,2,0,2,1,1,1,2,1,0,0,1,2,1,1,2,1,0, +1,0,2,0,1,0,1,1,0,0,2,2,1,2,1,1,2,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0, +3,3,3,0,2,1,2,0,0,0,1,0,0,3,2,0,1,0,0,1,0,0,2,0,0,0,1,2,1,0,1,0, +0,0,0,0,1,0,1,0,0,1,0,0,0,0,1,0,1,0,1,1,1,0,1,0,0,0,0,0,0,0,0,0, +0,0,0,2,2,0,2,2,1,1,0,1,1,1,1,1,0,0,1,2,1,1,1,0,1,0,0,0,1,1,1,1, +0,0,2,1,0,1,1,1,0,1,1,2,1,2,1,1,2,0,1,1,2,1,0,2,0,0,0,0,0,0,0,0, +3,2,2,0,0,2,0,0,0,0,0,0,0,2,2,0,2,0,0,1,0,0,2,0,0,0,0,0,2,0,0,0, +0,2,1,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,0,0,1,0,1,0,0,0,0,0,0,0,0,0, +0,0,0,3,2,0,2,2,0,1,1,0,1,0,0,1,0,0,0,1,0,1,0,0,0,0,0,1,0,0,0,0, +2,0,1,0,1,0,1,1,0,0,1,2,0,1,0,1,1,0,0,1,0,1,0,2,0,0,0,0,0,0,0,0, +2,2,2,0,1,1,0,0,0,1,0,0,0,1,2,0,1,0,0,1,0,0,1,0,0,0,0,1,2,0,1,0, +0,0,1,0,0,0,1,0,0,1,0,0,0,0,0,0,1,0,1,0,2,0,0,0,0,0,0,0,0,0,0,0, +2,2,2,2,1,0,1,1,1,0,0,0,0,1,2,0,0,1,0,0,0,1,0,0,1,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0, +1,1,2,0,1,0,0,0,1,0,1,0,0,0,1,0,0,1,0,0,0,0,0,0,0,1,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,2,0,0,0,0,0,1, +0,0,1,2,2,0,2,1,2,1,1,2,2,0,0,0,0,1,0,0,1,1,0,0,2,0,0,0,0,1,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0, +2,2,2,0,0,0,1,0,0,0,0,0,0,2,2,1,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0, +0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,1,1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +2,2,2,0,1,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,1,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,1,0,0,0,0,0,0,0,0,0,0,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, +) + +Latin5TurkishModel = { + 'char_to_order_map': Latin5_TurkishCharToOrderMap, + 'precedence_matrix': TurkishLangModel, + 'typical_positive_ratio': 0.970290, + 'keep_english_letter': True, + 'charset_name': "ISO-8859-9", + 'language': 'Turkish', +} diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/latin1prober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/latin1prober.py new file mode 100644 index 0000000..7d1e8c2 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/latin1prober.py @@ -0,0 +1,145 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Universal charset detector code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 2001 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# Shy Shalom - original C code +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .charsetprober import CharSetProber +from .enums import ProbingState + +FREQ_CAT_NUM = 4 + +UDF = 0 # undefined +OTH = 1 # other +ASC = 2 # ascii capital letter +ASS = 3 # ascii small letter +ACV = 4 # accent capital vowel +ACO = 5 # accent capital other +ASV = 6 # accent small vowel +ASO = 7 # accent small other +CLASS_NUM = 8 # total classes + +Latin1_CharToClass = ( + OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 00 - 07 + OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 08 - 0F + OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 10 - 17 + OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 18 - 1F + OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 20 - 27 + OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 28 - 2F + OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 30 - 37 + OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 38 - 3F + OTH, ASC, ASC, ASC, ASC, ASC, ASC, ASC, # 40 - 47 + ASC, ASC, ASC, ASC, ASC, ASC, ASC, ASC, # 48 - 4F + ASC, ASC, ASC, ASC, ASC, ASC, ASC, ASC, # 50 - 57 + ASC, ASC, ASC, OTH, OTH, OTH, OTH, OTH, # 58 - 5F + OTH, ASS, ASS, ASS, ASS, ASS, ASS, ASS, # 60 - 67 + ASS, ASS, ASS, ASS, ASS, ASS, ASS, ASS, # 68 - 6F + ASS, ASS, ASS, ASS, ASS, ASS, ASS, ASS, # 70 - 77 + ASS, ASS, ASS, OTH, OTH, OTH, OTH, OTH, # 78 - 7F + OTH, UDF, OTH, ASO, OTH, OTH, OTH, OTH, # 80 - 87 + OTH, OTH, ACO, OTH, ACO, UDF, ACO, UDF, # 88 - 8F + UDF, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 90 - 97 + OTH, OTH, ASO, OTH, ASO, UDF, ASO, ACO, # 98 - 9F + OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # A0 - A7 + OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # A8 - AF + OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # B0 - B7 + OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # B8 - BF + ACV, ACV, ACV, ACV, ACV, ACV, ACO, ACO, # C0 - C7 + ACV, ACV, ACV, ACV, ACV, ACV, ACV, ACV, # C8 - CF + ACO, ACO, ACV, ACV, ACV, ACV, ACV, OTH, # D0 - D7 + ACV, ACV, ACV, ACV, ACV, ACO, ACO, ACO, # D8 - DF + ASV, ASV, ASV, ASV, ASV, ASV, ASO, ASO, # E0 - E7 + ASV, ASV, ASV, ASV, ASV, ASV, ASV, ASV, # E8 - EF + ASO, ASO, ASV, ASV, ASV, ASV, ASV, OTH, # F0 - F7 + ASV, ASV, ASV, ASV, ASV, ASO, ASO, ASO, # F8 - FF +) + +# 0 : illegal +# 1 : very unlikely +# 2 : normal +# 3 : very likely +Latin1ClassModel = ( +# UDF OTH ASC ASS ACV ACO ASV ASO + 0, 0, 0, 0, 0, 0, 0, 0, # UDF + 0, 3, 3, 3, 3, 3, 3, 3, # OTH + 0, 3, 3, 3, 3, 3, 3, 3, # ASC + 0, 3, 3, 3, 1, 1, 3, 3, # ASS + 0, 3, 3, 3, 1, 2, 1, 2, # ACV + 0, 3, 3, 3, 3, 3, 3, 3, # ACO + 0, 3, 1, 3, 1, 1, 1, 3, # ASV + 0, 3, 1, 3, 1, 1, 3, 3, # ASO +) + + +class Latin1Prober(CharSetProber): + def __init__(self): + super(Latin1Prober, self).__init__() + self._last_char_class = None + self._freq_counter = None + self.reset() + + def reset(self): + self._last_char_class = OTH + self._freq_counter = [0] * FREQ_CAT_NUM + CharSetProber.reset(self) + + @property + def charset_name(self): + return "ISO-8859-1" + + @property + def language(self): + return "" + + def feed(self, byte_str): + byte_str = self.filter_with_english_letters(byte_str) + for c in byte_str: + char_class = Latin1_CharToClass[c] + freq = Latin1ClassModel[(self._last_char_class * CLASS_NUM) + + char_class] + if freq == 0: + self._state = ProbingState.NOT_ME + break + self._freq_counter[freq] += 1 + self._last_char_class = char_class + + return self.state + + def get_confidence(self): + if self.state == ProbingState.NOT_ME: + return 0.01 + + total = sum(self._freq_counter) + if total < 0.01: + confidence = 0.0 + else: + confidence = ((self._freq_counter[3] - self._freq_counter[1] * 20.0) + / total) + if confidence < 0.0: + confidence = 0.0 + # lower the confidence of latin1 so that other more accurate + # detector can take priority. + confidence = confidence * 0.73 + return confidence diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/mbcharsetprober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/mbcharsetprober.py new file mode 100644 index 0000000..6256ecf --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/mbcharsetprober.py @@ -0,0 +1,91 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Universal charset detector code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 2001 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# Shy Shalom - original C code +# Proofpoint, Inc. +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .charsetprober import CharSetProber +from .enums import ProbingState, MachineState + + +class MultiByteCharSetProber(CharSetProber): + """ + MultiByteCharSetProber + """ + + def __init__(self, lang_filter=None): + super(MultiByteCharSetProber, self).__init__(lang_filter=lang_filter) + self.distribution_analyzer = None + self.coding_sm = None + self._last_char = [0, 0] + + def reset(self): + super(MultiByteCharSetProber, self).reset() + if self.coding_sm: + self.coding_sm.reset() + if self.distribution_analyzer: + self.distribution_analyzer.reset() + self._last_char = [0, 0] + + @property + def charset_name(self): + raise NotImplementedError + + @property + def language(self): + raise NotImplementedError + + def feed(self, byte_str): + for i in range(len(byte_str)): + coding_state = self.coding_sm.next_state(byte_str[i]) + if coding_state == MachineState.ERROR: + self.logger.debug('%s %s prober hit error at byte %s', + self.charset_name, self.language, i) + self._state = ProbingState.NOT_ME + break + elif coding_state == MachineState.ITS_ME: + self._state = ProbingState.FOUND_IT + break + elif coding_state == MachineState.START: + char_len = self.coding_sm.get_current_charlen() + if i == 0: + self._last_char[1] = byte_str[0] + self.distribution_analyzer.feed(self._last_char, char_len) + else: + self.distribution_analyzer.feed(byte_str[i - 1:i + 1], + char_len) + + self._last_char[0] = byte_str[-1] + + if self.state == ProbingState.DETECTING: + if (self.distribution_analyzer.got_enough_data() and + (self.get_confidence() > self.SHORTCUT_THRESHOLD)): + self._state = ProbingState.FOUND_IT + + return self.state + + def get_confidence(self): + return self.distribution_analyzer.get_confidence() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/mbcsgroupprober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/mbcsgroupprober.py new file mode 100644 index 0000000..530abe7 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/mbcsgroupprober.py @@ -0,0 +1,54 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Universal charset detector code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 2001 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# Shy Shalom - original C code +# Proofpoint, Inc. +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .charsetgroupprober import CharSetGroupProber +from .utf8prober import UTF8Prober +from .sjisprober import SJISProber +from .eucjpprober import EUCJPProber +from .gb2312prober import GB2312Prober +from .euckrprober import EUCKRProber +from .cp949prober import CP949Prober +from .big5prober import Big5Prober +from .euctwprober import EUCTWProber + + +class MBCSGroupProber(CharSetGroupProber): + def __init__(self, lang_filter=None): + super(MBCSGroupProber, self).__init__(lang_filter=lang_filter) + self.probers = [ + UTF8Prober(), + SJISProber(), + EUCJPProber(), + GB2312Prober(), + EUCKRProber(), + CP949Prober(), + Big5Prober(), + EUCTWProber() + ] + self.reset() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/mbcssm.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/mbcssm.py new file mode 100644 index 0000000..8360d0f --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/mbcssm.py @@ -0,0 +1,572 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is mozilla.org code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .enums import MachineState + +# BIG5 + +BIG5_CLS = ( + 1,1,1,1,1,1,1,1, # 00 - 07 #allow 0x00 as legal value + 1,1,1,1,1,1,0,0, # 08 - 0f + 1,1,1,1,1,1,1,1, # 10 - 17 + 1,1,1,0,1,1,1,1, # 18 - 1f + 1,1,1,1,1,1,1,1, # 20 - 27 + 1,1,1,1,1,1,1,1, # 28 - 2f + 1,1,1,1,1,1,1,1, # 30 - 37 + 1,1,1,1,1,1,1,1, # 38 - 3f + 2,2,2,2,2,2,2,2, # 40 - 47 + 2,2,2,2,2,2,2,2, # 48 - 4f + 2,2,2,2,2,2,2,2, # 50 - 57 + 2,2,2,2,2,2,2,2, # 58 - 5f + 2,2,2,2,2,2,2,2, # 60 - 67 + 2,2,2,2,2,2,2,2, # 68 - 6f + 2,2,2,2,2,2,2,2, # 70 - 77 + 2,2,2,2,2,2,2,1, # 78 - 7f + 4,4,4,4,4,4,4,4, # 80 - 87 + 4,4,4,4,4,4,4,4, # 88 - 8f + 4,4,4,4,4,4,4,4, # 90 - 97 + 4,4,4,4,4,4,4,4, # 98 - 9f + 4,3,3,3,3,3,3,3, # a0 - a7 + 3,3,3,3,3,3,3,3, # a8 - af + 3,3,3,3,3,3,3,3, # b0 - b7 + 3,3,3,3,3,3,3,3, # b8 - bf + 3,3,3,3,3,3,3,3, # c0 - c7 + 3,3,3,3,3,3,3,3, # c8 - cf + 3,3,3,3,3,3,3,3, # d0 - d7 + 3,3,3,3,3,3,3,3, # d8 - df + 3,3,3,3,3,3,3,3, # e0 - e7 + 3,3,3,3,3,3,3,3, # e8 - ef + 3,3,3,3,3,3,3,3, # f0 - f7 + 3,3,3,3,3,3,3,0 # f8 - ff +) + +BIG5_ST = ( + MachineState.ERROR,MachineState.START,MachineState.START, 3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07 + MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,#08-0f + MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START#10-17 +) + +BIG5_CHAR_LEN_TABLE = (0, 1, 1, 2, 0) + +BIG5_SM_MODEL = {'class_table': BIG5_CLS, + 'class_factor': 5, + 'state_table': BIG5_ST, + 'char_len_table': BIG5_CHAR_LEN_TABLE, + 'name': 'Big5'} + +# CP949 + +CP949_CLS = ( + 1,1,1,1,1,1,1,1, 1,1,1,1,1,1,0,0, # 00 - 0f + 1,1,1,1,1,1,1,1, 1,1,1,0,1,1,1,1, # 10 - 1f + 1,1,1,1,1,1,1,1, 1,1,1,1,1,1,1,1, # 20 - 2f + 1,1,1,1,1,1,1,1, 1,1,1,1,1,1,1,1, # 30 - 3f + 1,4,4,4,4,4,4,4, 4,4,4,4,4,4,4,4, # 40 - 4f + 4,4,5,5,5,5,5,5, 5,5,5,1,1,1,1,1, # 50 - 5f + 1,5,5,5,5,5,5,5, 5,5,5,5,5,5,5,5, # 60 - 6f + 5,5,5,5,5,5,5,5, 5,5,5,1,1,1,1,1, # 70 - 7f + 0,6,6,6,6,6,6,6, 6,6,6,6,6,6,6,6, # 80 - 8f + 6,6,6,6,6,6,6,6, 6,6,6,6,6,6,6,6, # 90 - 9f + 6,7,7,7,7,7,7,7, 7,7,7,7,7,8,8,8, # a0 - af + 7,7,7,7,7,7,7,7, 7,7,7,7,7,7,7,7, # b0 - bf + 7,7,7,7,7,7,9,2, 2,3,2,2,2,2,2,2, # c0 - cf + 2,2,2,2,2,2,2,2, 2,2,2,2,2,2,2,2, # d0 - df + 2,2,2,2,2,2,2,2, 2,2,2,2,2,2,2,2, # e0 - ef + 2,2,2,2,2,2,2,2, 2,2,2,2,2,2,2,0, # f0 - ff +) + +CP949_ST = ( +#cls= 0 1 2 3 4 5 6 7 8 9 # previous state = + MachineState.ERROR,MachineState.START, 3,MachineState.ERROR,MachineState.START,MachineState.START, 4, 5,MachineState.ERROR, 6, # MachineState.START + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, # MachineState.ERROR + MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME, # MachineState.ITS_ME + MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START, # 3 + MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START, # 4 + MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START, # 5 + MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START, # 6 +) + +CP949_CHAR_LEN_TABLE = (0, 1, 2, 0, 1, 1, 2, 2, 0, 2) + +CP949_SM_MODEL = {'class_table': CP949_CLS, + 'class_factor': 10, + 'state_table': CP949_ST, + 'char_len_table': CP949_CHAR_LEN_TABLE, + 'name': 'CP949'} + +# EUC-JP + +EUCJP_CLS = ( + 4,4,4,4,4,4,4,4, # 00 - 07 + 4,4,4,4,4,4,5,5, # 08 - 0f + 4,4,4,4,4,4,4,4, # 10 - 17 + 4,4,4,5,4,4,4,4, # 18 - 1f + 4,4,4,4,4,4,4,4, # 20 - 27 + 4,4,4,4,4,4,4,4, # 28 - 2f + 4,4,4,4,4,4,4,4, # 30 - 37 + 4,4,4,4,4,4,4,4, # 38 - 3f + 4,4,4,4,4,4,4,4, # 40 - 47 + 4,4,4,4,4,4,4,4, # 48 - 4f + 4,4,4,4,4,4,4,4, # 50 - 57 + 4,4,4,4,4,4,4,4, # 58 - 5f + 4,4,4,4,4,4,4,4, # 60 - 67 + 4,4,4,4,4,4,4,4, # 68 - 6f + 4,4,4,4,4,4,4,4, # 70 - 77 + 4,4,4,4,4,4,4,4, # 78 - 7f + 5,5,5,5,5,5,5,5, # 80 - 87 + 5,5,5,5,5,5,1,3, # 88 - 8f + 5,5,5,5,5,5,5,5, # 90 - 97 + 5,5,5,5,5,5,5,5, # 98 - 9f + 5,2,2,2,2,2,2,2, # a0 - a7 + 2,2,2,2,2,2,2,2, # a8 - af + 2,2,2,2,2,2,2,2, # b0 - b7 + 2,2,2,2,2,2,2,2, # b8 - bf + 2,2,2,2,2,2,2,2, # c0 - c7 + 2,2,2,2,2,2,2,2, # c8 - cf + 2,2,2,2,2,2,2,2, # d0 - d7 + 2,2,2,2,2,2,2,2, # d8 - df + 0,0,0,0,0,0,0,0, # e0 - e7 + 0,0,0,0,0,0,0,0, # e8 - ef + 0,0,0,0,0,0,0,0, # f0 - f7 + 0,0,0,0,0,0,0,5 # f8 - ff +) + +EUCJP_ST = ( + 3, 4, 3, 5,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f + MachineState.ITS_ME,MachineState.ITS_ME,MachineState.START,MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#10-17 + MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 3,MachineState.ERROR,#18-1f + 3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START#20-27 +) + +EUCJP_CHAR_LEN_TABLE = (2, 2, 2, 3, 1, 0) + +EUCJP_SM_MODEL = {'class_table': EUCJP_CLS, + 'class_factor': 6, + 'state_table': EUCJP_ST, + 'char_len_table': EUCJP_CHAR_LEN_TABLE, + 'name': 'EUC-JP'} + +# EUC-KR + +EUCKR_CLS = ( + 1,1,1,1,1,1,1,1, # 00 - 07 + 1,1,1,1,1,1,0,0, # 08 - 0f + 1,1,1,1,1,1,1,1, # 10 - 17 + 1,1,1,0,1,1,1,1, # 18 - 1f + 1,1,1,1,1,1,1,1, # 20 - 27 + 1,1,1,1,1,1,1,1, # 28 - 2f + 1,1,1,1,1,1,1,1, # 30 - 37 + 1,1,1,1,1,1,1,1, # 38 - 3f + 1,1,1,1,1,1,1,1, # 40 - 47 + 1,1,1,1,1,1,1,1, # 48 - 4f + 1,1,1,1,1,1,1,1, # 50 - 57 + 1,1,1,1,1,1,1,1, # 58 - 5f + 1,1,1,1,1,1,1,1, # 60 - 67 + 1,1,1,1,1,1,1,1, # 68 - 6f + 1,1,1,1,1,1,1,1, # 70 - 77 + 1,1,1,1,1,1,1,1, # 78 - 7f + 0,0,0,0,0,0,0,0, # 80 - 87 + 0,0,0,0,0,0,0,0, # 88 - 8f + 0,0,0,0,0,0,0,0, # 90 - 97 + 0,0,0,0,0,0,0,0, # 98 - 9f + 0,2,2,2,2,2,2,2, # a0 - a7 + 2,2,2,2,2,3,3,3, # a8 - af + 2,2,2,2,2,2,2,2, # b0 - b7 + 2,2,2,2,2,2,2,2, # b8 - bf + 2,2,2,2,2,2,2,2, # c0 - c7 + 2,3,2,2,2,2,2,2, # c8 - cf + 2,2,2,2,2,2,2,2, # d0 - d7 + 2,2,2,2,2,2,2,2, # d8 - df + 2,2,2,2,2,2,2,2, # e0 - e7 + 2,2,2,2,2,2,2,2, # e8 - ef + 2,2,2,2,2,2,2,2, # f0 - f7 + 2,2,2,2,2,2,2,0 # f8 - ff +) + +EUCKR_ST = ( + MachineState.ERROR,MachineState.START, 3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07 + MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START #08-0f +) + +EUCKR_CHAR_LEN_TABLE = (0, 1, 2, 0) + +EUCKR_SM_MODEL = {'class_table': EUCKR_CLS, + 'class_factor': 4, + 'state_table': EUCKR_ST, + 'char_len_table': EUCKR_CHAR_LEN_TABLE, + 'name': 'EUC-KR'} + +# EUC-TW + +EUCTW_CLS = ( + 2,2,2,2,2,2,2,2, # 00 - 07 + 2,2,2,2,2,2,0,0, # 08 - 0f + 2,2,2,2,2,2,2,2, # 10 - 17 + 2,2,2,0,2,2,2,2, # 18 - 1f + 2,2,2,2,2,2,2,2, # 20 - 27 + 2,2,2,2,2,2,2,2, # 28 - 2f + 2,2,2,2,2,2,2,2, # 30 - 37 + 2,2,2,2,2,2,2,2, # 38 - 3f + 2,2,2,2,2,2,2,2, # 40 - 47 + 2,2,2,2,2,2,2,2, # 48 - 4f + 2,2,2,2,2,2,2,2, # 50 - 57 + 2,2,2,2,2,2,2,2, # 58 - 5f + 2,2,2,2,2,2,2,2, # 60 - 67 + 2,2,2,2,2,2,2,2, # 68 - 6f + 2,2,2,2,2,2,2,2, # 70 - 77 + 2,2,2,2,2,2,2,2, # 78 - 7f + 0,0,0,0,0,0,0,0, # 80 - 87 + 0,0,0,0,0,0,6,0, # 88 - 8f + 0,0,0,0,0,0,0,0, # 90 - 97 + 0,0,0,0,0,0,0,0, # 98 - 9f + 0,3,4,4,4,4,4,4, # a0 - a7 + 5,5,1,1,1,1,1,1, # a8 - af + 1,1,1,1,1,1,1,1, # b0 - b7 + 1,1,1,1,1,1,1,1, # b8 - bf + 1,1,3,1,3,3,3,3, # c0 - c7 + 3,3,3,3,3,3,3,3, # c8 - cf + 3,3,3,3,3,3,3,3, # d0 - d7 + 3,3,3,3,3,3,3,3, # d8 - df + 3,3,3,3,3,3,3,3, # e0 - e7 + 3,3,3,3,3,3,3,3, # e8 - ef + 3,3,3,3,3,3,3,3, # f0 - f7 + 3,3,3,3,3,3,3,0 # f8 - ff +) + +EUCTW_ST = ( + MachineState.ERROR,MachineState.ERROR,MachineState.START, 3, 3, 3, 4,MachineState.ERROR,#00-07 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f + MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.START,MachineState.ERROR,#10-17 + MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#18-1f + 5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.START,MachineState.START,#20-27 + MachineState.START,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START #28-2f +) + +EUCTW_CHAR_LEN_TABLE = (0, 0, 1, 2, 2, 2, 3) + +EUCTW_SM_MODEL = {'class_table': EUCTW_CLS, + 'class_factor': 7, + 'state_table': EUCTW_ST, + 'char_len_table': EUCTW_CHAR_LEN_TABLE, + 'name': 'x-euc-tw'} + +# GB2312 + +GB2312_CLS = ( + 1,1,1,1,1,1,1,1, # 00 - 07 + 1,1,1,1,1,1,0,0, # 08 - 0f + 1,1,1,1,1,1,1,1, # 10 - 17 + 1,1,1,0,1,1,1,1, # 18 - 1f + 1,1,1,1,1,1,1,1, # 20 - 27 + 1,1,1,1,1,1,1,1, # 28 - 2f + 3,3,3,3,3,3,3,3, # 30 - 37 + 3,3,1,1,1,1,1,1, # 38 - 3f + 2,2,2,2,2,2,2,2, # 40 - 47 + 2,2,2,2,2,2,2,2, # 48 - 4f + 2,2,2,2,2,2,2,2, # 50 - 57 + 2,2,2,2,2,2,2,2, # 58 - 5f + 2,2,2,2,2,2,2,2, # 60 - 67 + 2,2,2,2,2,2,2,2, # 68 - 6f + 2,2,2,2,2,2,2,2, # 70 - 77 + 2,2,2,2,2,2,2,4, # 78 - 7f + 5,6,6,6,6,6,6,6, # 80 - 87 + 6,6,6,6,6,6,6,6, # 88 - 8f + 6,6,6,6,6,6,6,6, # 90 - 97 + 6,6,6,6,6,6,6,6, # 98 - 9f + 6,6,6,6,6,6,6,6, # a0 - a7 + 6,6,6,6,6,6,6,6, # a8 - af + 6,6,6,6,6,6,6,6, # b0 - b7 + 6,6,6,6,6,6,6,6, # b8 - bf + 6,6,6,6,6,6,6,6, # c0 - c7 + 6,6,6,6,6,6,6,6, # c8 - cf + 6,6,6,6,6,6,6,6, # d0 - d7 + 6,6,6,6,6,6,6,6, # d8 - df + 6,6,6,6,6,6,6,6, # e0 - e7 + 6,6,6,6,6,6,6,6, # e8 - ef + 6,6,6,6,6,6,6,6, # f0 - f7 + 6,6,6,6,6,6,6,0 # f8 - ff +) + +GB2312_ST = ( + MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START, 3,MachineState.ERROR,#00-07 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f + MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,#10-17 + 4,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#18-1f + MachineState.ERROR,MachineState.ERROR, 5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,#20-27 + MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START #28-2f +) + +# To be accurate, the length of class 6 can be either 2 or 4. +# But it is not necessary to discriminate between the two since +# it is used for frequency analysis only, and we are validating +# each code range there as well. So it is safe to set it to be +# 2 here. +GB2312_CHAR_LEN_TABLE = (0, 1, 1, 1, 1, 1, 2) + +GB2312_SM_MODEL = {'class_table': GB2312_CLS, + 'class_factor': 7, + 'state_table': GB2312_ST, + 'char_len_table': GB2312_CHAR_LEN_TABLE, + 'name': 'GB2312'} + +# Shift_JIS + +SJIS_CLS = ( + 1,1,1,1,1,1,1,1, # 00 - 07 + 1,1,1,1,1,1,0,0, # 08 - 0f + 1,1,1,1,1,1,1,1, # 10 - 17 + 1,1,1,0,1,1,1,1, # 18 - 1f + 1,1,1,1,1,1,1,1, # 20 - 27 + 1,1,1,1,1,1,1,1, # 28 - 2f + 1,1,1,1,1,1,1,1, # 30 - 37 + 1,1,1,1,1,1,1,1, # 38 - 3f + 2,2,2,2,2,2,2,2, # 40 - 47 + 2,2,2,2,2,2,2,2, # 48 - 4f + 2,2,2,2,2,2,2,2, # 50 - 57 + 2,2,2,2,2,2,2,2, # 58 - 5f + 2,2,2,2,2,2,2,2, # 60 - 67 + 2,2,2,2,2,2,2,2, # 68 - 6f + 2,2,2,2,2,2,2,2, # 70 - 77 + 2,2,2,2,2,2,2,1, # 78 - 7f + 3,3,3,3,3,2,2,3, # 80 - 87 + 3,3,3,3,3,3,3,3, # 88 - 8f + 3,3,3,3,3,3,3,3, # 90 - 97 + 3,3,3,3,3,3,3,3, # 98 - 9f + #0xa0 is illegal in sjis encoding, but some pages does + #contain such byte. We need to be more error forgiven. + 2,2,2,2,2,2,2,2, # a0 - a7 + 2,2,2,2,2,2,2,2, # a8 - af + 2,2,2,2,2,2,2,2, # b0 - b7 + 2,2,2,2,2,2,2,2, # b8 - bf + 2,2,2,2,2,2,2,2, # c0 - c7 + 2,2,2,2,2,2,2,2, # c8 - cf + 2,2,2,2,2,2,2,2, # d0 - d7 + 2,2,2,2,2,2,2,2, # d8 - df + 3,3,3,3,3,3,3,3, # e0 - e7 + 3,3,3,3,3,4,4,4, # e8 - ef + 3,3,3,3,3,3,3,3, # f0 - f7 + 3,3,3,3,3,0,0,0) # f8 - ff + + +SJIS_ST = ( + MachineState.ERROR,MachineState.START,MachineState.START, 3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f + MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START #10-17 +) + +SJIS_CHAR_LEN_TABLE = (0, 1, 1, 2, 0, 0) + +SJIS_SM_MODEL = {'class_table': SJIS_CLS, + 'class_factor': 6, + 'state_table': SJIS_ST, + 'char_len_table': SJIS_CHAR_LEN_TABLE, + 'name': 'Shift_JIS'} + +# UCS2-BE + +UCS2BE_CLS = ( + 0,0,0,0,0,0,0,0, # 00 - 07 + 0,0,1,0,0,2,0,0, # 08 - 0f + 0,0,0,0,0,0,0,0, # 10 - 17 + 0,0,0,3,0,0,0,0, # 18 - 1f + 0,0,0,0,0,0,0,0, # 20 - 27 + 0,3,3,3,3,3,0,0, # 28 - 2f + 0,0,0,0,0,0,0,0, # 30 - 37 + 0,0,0,0,0,0,0,0, # 38 - 3f + 0,0,0,0,0,0,0,0, # 40 - 47 + 0,0,0,0,0,0,0,0, # 48 - 4f + 0,0,0,0,0,0,0,0, # 50 - 57 + 0,0,0,0,0,0,0,0, # 58 - 5f + 0,0,0,0,0,0,0,0, # 60 - 67 + 0,0,0,0,0,0,0,0, # 68 - 6f + 0,0,0,0,0,0,0,0, # 70 - 77 + 0,0,0,0,0,0,0,0, # 78 - 7f + 0,0,0,0,0,0,0,0, # 80 - 87 + 0,0,0,0,0,0,0,0, # 88 - 8f + 0,0,0,0,0,0,0,0, # 90 - 97 + 0,0,0,0,0,0,0,0, # 98 - 9f + 0,0,0,0,0,0,0,0, # a0 - a7 + 0,0,0,0,0,0,0,0, # a8 - af + 0,0,0,0,0,0,0,0, # b0 - b7 + 0,0,0,0,0,0,0,0, # b8 - bf + 0,0,0,0,0,0,0,0, # c0 - c7 + 0,0,0,0,0,0,0,0, # c8 - cf + 0,0,0,0,0,0,0,0, # d0 - d7 + 0,0,0,0,0,0,0,0, # d8 - df + 0,0,0,0,0,0,0,0, # e0 - e7 + 0,0,0,0,0,0,0,0, # e8 - ef + 0,0,0,0,0,0,0,0, # f0 - f7 + 0,0,0,0,0,0,4,5 # f8 - ff +) + +UCS2BE_ST = ( + 5, 7, 7,MachineState.ERROR, 4, 3,MachineState.ERROR,MachineState.ERROR,#00-07 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f + MachineState.ITS_ME,MachineState.ITS_ME, 6, 6, 6, 6,MachineState.ERROR,MachineState.ERROR,#10-17 + 6, 6, 6, 6, 6,MachineState.ITS_ME, 6, 6,#18-1f + 6, 6, 6, 6, 5, 7, 7,MachineState.ERROR,#20-27 + 5, 8, 6, 6,MachineState.ERROR, 6, 6, 6,#28-2f + 6, 6, 6, 6,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START #30-37 +) + +UCS2BE_CHAR_LEN_TABLE = (2, 2, 2, 0, 2, 2) + +UCS2BE_SM_MODEL = {'class_table': UCS2BE_CLS, + 'class_factor': 6, + 'state_table': UCS2BE_ST, + 'char_len_table': UCS2BE_CHAR_LEN_TABLE, + 'name': 'UTF-16BE'} + +# UCS2-LE + +UCS2LE_CLS = ( + 0,0,0,0,0,0,0,0, # 00 - 07 + 0,0,1,0,0,2,0,0, # 08 - 0f + 0,0,0,0,0,0,0,0, # 10 - 17 + 0,0,0,3,0,0,0,0, # 18 - 1f + 0,0,0,0,0,0,0,0, # 20 - 27 + 0,3,3,3,3,3,0,0, # 28 - 2f + 0,0,0,0,0,0,0,0, # 30 - 37 + 0,0,0,0,0,0,0,0, # 38 - 3f + 0,0,0,0,0,0,0,0, # 40 - 47 + 0,0,0,0,0,0,0,0, # 48 - 4f + 0,0,0,0,0,0,0,0, # 50 - 57 + 0,0,0,0,0,0,0,0, # 58 - 5f + 0,0,0,0,0,0,0,0, # 60 - 67 + 0,0,0,0,0,0,0,0, # 68 - 6f + 0,0,0,0,0,0,0,0, # 70 - 77 + 0,0,0,0,0,0,0,0, # 78 - 7f + 0,0,0,0,0,0,0,0, # 80 - 87 + 0,0,0,0,0,0,0,0, # 88 - 8f + 0,0,0,0,0,0,0,0, # 90 - 97 + 0,0,0,0,0,0,0,0, # 98 - 9f + 0,0,0,0,0,0,0,0, # a0 - a7 + 0,0,0,0,0,0,0,0, # a8 - af + 0,0,0,0,0,0,0,0, # b0 - b7 + 0,0,0,0,0,0,0,0, # b8 - bf + 0,0,0,0,0,0,0,0, # c0 - c7 + 0,0,0,0,0,0,0,0, # c8 - cf + 0,0,0,0,0,0,0,0, # d0 - d7 + 0,0,0,0,0,0,0,0, # d8 - df + 0,0,0,0,0,0,0,0, # e0 - e7 + 0,0,0,0,0,0,0,0, # e8 - ef + 0,0,0,0,0,0,0,0, # f0 - f7 + 0,0,0,0,0,0,4,5 # f8 - ff +) + +UCS2LE_ST = ( + 6, 6, 7, 6, 4, 3,MachineState.ERROR,MachineState.ERROR,#00-07 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f + MachineState.ITS_ME,MachineState.ITS_ME, 5, 5, 5,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,#10-17 + 5, 5, 5,MachineState.ERROR, 5,MachineState.ERROR, 6, 6,#18-1f + 7, 6, 8, 8, 5, 5, 5,MachineState.ERROR,#20-27 + 5, 5, 5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 5, 5,#28-2f + 5, 5, 5,MachineState.ERROR, 5,MachineState.ERROR,MachineState.START,MachineState.START #30-37 +) + +UCS2LE_CHAR_LEN_TABLE = (2, 2, 2, 2, 2, 2) + +UCS2LE_SM_MODEL = {'class_table': UCS2LE_CLS, + 'class_factor': 6, + 'state_table': UCS2LE_ST, + 'char_len_table': UCS2LE_CHAR_LEN_TABLE, + 'name': 'UTF-16LE'} + +# UTF-8 + +UTF8_CLS = ( + 1,1,1,1,1,1,1,1, # 00 - 07 #allow 0x00 as a legal value + 1,1,1,1,1,1,0,0, # 08 - 0f + 1,1,1,1,1,1,1,1, # 10 - 17 + 1,1,1,0,1,1,1,1, # 18 - 1f + 1,1,1,1,1,1,1,1, # 20 - 27 + 1,1,1,1,1,1,1,1, # 28 - 2f + 1,1,1,1,1,1,1,1, # 30 - 37 + 1,1,1,1,1,1,1,1, # 38 - 3f + 1,1,1,1,1,1,1,1, # 40 - 47 + 1,1,1,1,1,1,1,1, # 48 - 4f + 1,1,1,1,1,1,1,1, # 50 - 57 + 1,1,1,1,1,1,1,1, # 58 - 5f + 1,1,1,1,1,1,1,1, # 60 - 67 + 1,1,1,1,1,1,1,1, # 68 - 6f + 1,1,1,1,1,1,1,1, # 70 - 77 + 1,1,1,1,1,1,1,1, # 78 - 7f + 2,2,2,2,3,3,3,3, # 80 - 87 + 4,4,4,4,4,4,4,4, # 88 - 8f + 4,4,4,4,4,4,4,4, # 90 - 97 + 4,4,4,4,4,4,4,4, # 98 - 9f + 5,5,5,5,5,5,5,5, # a0 - a7 + 5,5,5,5,5,5,5,5, # a8 - af + 5,5,5,5,5,5,5,5, # b0 - b7 + 5,5,5,5,5,5,5,5, # b8 - bf + 0,0,6,6,6,6,6,6, # c0 - c7 + 6,6,6,6,6,6,6,6, # c8 - cf + 6,6,6,6,6,6,6,6, # d0 - d7 + 6,6,6,6,6,6,6,6, # d8 - df + 7,8,8,8,8,8,8,8, # e0 - e7 + 8,8,8,8,8,9,8,8, # e8 - ef + 10,11,11,11,11,11,11,11, # f0 - f7 + 12,13,13,13,14,15,0,0 # f8 - ff +) + +UTF8_ST = ( + MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 12, 10,#00-07 + 9, 11, 8, 7, 6, 5, 4, 3,#08-0f + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#10-17 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#18-1f + MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#20-27 + MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#28-2f + MachineState.ERROR,MachineState.ERROR, 5, 5, 5, 5,MachineState.ERROR,MachineState.ERROR,#30-37 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#38-3f + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 5, 5, 5,MachineState.ERROR,MachineState.ERROR,#40-47 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#48-4f + MachineState.ERROR,MachineState.ERROR, 7, 7, 7, 7,MachineState.ERROR,MachineState.ERROR,#50-57 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#58-5f + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 7, 7,MachineState.ERROR,MachineState.ERROR,#60-67 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#68-6f + MachineState.ERROR,MachineState.ERROR, 9, 9, 9, 9,MachineState.ERROR,MachineState.ERROR,#70-77 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#78-7f + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 9,MachineState.ERROR,MachineState.ERROR,#80-87 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#88-8f + MachineState.ERROR,MachineState.ERROR, 12, 12, 12, 12,MachineState.ERROR,MachineState.ERROR,#90-97 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#98-9f + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 12,MachineState.ERROR,MachineState.ERROR,#a0-a7 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#a8-af + MachineState.ERROR,MachineState.ERROR, 12, 12, 12,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#b0-b7 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#b8-bf + MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,#c0-c7 + MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR #c8-cf +) + +UTF8_CHAR_LEN_TABLE = (0, 1, 0, 0, 0, 0, 2, 3, 3, 3, 4, 4, 5, 5, 6, 6) + +UTF8_SM_MODEL = {'class_table': UTF8_CLS, + 'class_factor': 16, + 'state_table': UTF8_ST, + 'char_len_table': UTF8_CHAR_LEN_TABLE, + 'name': 'UTF-8'} diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/sbcharsetprober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/sbcharsetprober.py new file mode 100644 index 0000000..0adb51d --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/sbcharsetprober.py @@ -0,0 +1,132 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Universal charset detector code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 2001 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# Shy Shalom - original C code +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .charsetprober import CharSetProber +from .enums import CharacterCategory, ProbingState, SequenceLikelihood + + +class SingleByteCharSetProber(CharSetProber): + SAMPLE_SIZE = 64 + SB_ENOUGH_REL_THRESHOLD = 1024 # 0.25 * SAMPLE_SIZE^2 + POSITIVE_SHORTCUT_THRESHOLD = 0.95 + NEGATIVE_SHORTCUT_THRESHOLD = 0.05 + + def __init__(self, model, reversed=False, name_prober=None): + super(SingleByteCharSetProber, self).__init__() + self._model = model + # TRUE if we need to reverse every pair in the model lookup + self._reversed = reversed + # Optional auxiliary prober for name decision + self._name_prober = name_prober + self._last_order = None + self._seq_counters = None + self._total_seqs = None + self._total_char = None + self._freq_char = None + self.reset() + + def reset(self): + super(SingleByteCharSetProber, self).reset() + # char order of last character + self._last_order = 255 + self._seq_counters = [0] * SequenceLikelihood.get_num_categories() + self._total_seqs = 0 + self._total_char = 0 + # characters that fall in our sampling range + self._freq_char = 0 + + @property + def charset_name(self): + if self._name_prober: + return self._name_prober.charset_name + else: + return self._model['charset_name'] + + @property + def language(self): + if self._name_prober: + return self._name_prober.language + else: + return self._model.get('language') + + def feed(self, byte_str): + if not self._model['keep_english_letter']: + byte_str = self.filter_international_words(byte_str) + if not byte_str: + return self.state + char_to_order_map = self._model['char_to_order_map'] + for i, c in enumerate(byte_str): + # XXX: Order is in range 1-64, so one would think we want 0-63 here, + # but that leads to 27 more test failures than before. + order = char_to_order_map[c] + # XXX: This was SYMBOL_CAT_ORDER before, with a value of 250, but + # CharacterCategory.SYMBOL is actually 253, so we use CONTROL + # to make it closer to the original intent. The only difference + # is whether or not we count digits and control characters for + # _total_char purposes. + if order < CharacterCategory.CONTROL: + self._total_char += 1 + if order < self.SAMPLE_SIZE: + self._freq_char += 1 + if self._last_order < self.SAMPLE_SIZE: + self._total_seqs += 1 + if not self._reversed: + i = (self._last_order * self.SAMPLE_SIZE) + order + model = self._model['precedence_matrix'][i] + else: # reverse the order of the letters in the lookup + i = (order * self.SAMPLE_SIZE) + self._last_order + model = self._model['precedence_matrix'][i] + self._seq_counters[model] += 1 + self._last_order = order + + charset_name = self._model['charset_name'] + if self.state == ProbingState.DETECTING: + if self._total_seqs > self.SB_ENOUGH_REL_THRESHOLD: + confidence = self.get_confidence() + if confidence > self.POSITIVE_SHORTCUT_THRESHOLD: + self.logger.debug('%s confidence = %s, we have a winner', + charset_name, confidence) + self._state = ProbingState.FOUND_IT + elif confidence < self.NEGATIVE_SHORTCUT_THRESHOLD: + self.logger.debug('%s confidence = %s, below negative ' + 'shortcut threshhold %s', charset_name, + confidence, + self.NEGATIVE_SHORTCUT_THRESHOLD) + self._state = ProbingState.NOT_ME + + return self.state + + def get_confidence(self): + r = 0.01 + if self._total_seqs > 0: + r = ((1.0 * self._seq_counters[SequenceLikelihood.POSITIVE]) / + self._total_seqs / self._model['typical_positive_ratio']) + r = r * self._freq_char / self._total_char + if r >= 1.0: + r = 0.99 + return r diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/sbcsgroupprober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/sbcsgroupprober.py new file mode 100644 index 0000000..98e95dc --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/sbcsgroupprober.py @@ -0,0 +1,73 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Universal charset detector code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 2001 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# Shy Shalom - original C code +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .charsetgroupprober import CharSetGroupProber +from .sbcharsetprober import SingleByteCharSetProber +from .langcyrillicmodel import (Win1251CyrillicModel, Koi8rModel, + Latin5CyrillicModel, MacCyrillicModel, + Ibm866Model, Ibm855Model) +from .langgreekmodel import Latin7GreekModel, Win1253GreekModel +from .langbulgarianmodel import Latin5BulgarianModel, Win1251BulgarianModel +# from .langhungarianmodel import Latin2HungarianModel, Win1250HungarianModel +from .langthaimodel import TIS620ThaiModel +from .langhebrewmodel import Win1255HebrewModel +from .hebrewprober import HebrewProber +from .langturkishmodel import Latin5TurkishModel + + +class SBCSGroupProber(CharSetGroupProber): + def __init__(self): + super(SBCSGroupProber, self).__init__() + self.probers = [ + SingleByteCharSetProber(Win1251CyrillicModel), + SingleByteCharSetProber(Koi8rModel), + SingleByteCharSetProber(Latin5CyrillicModel), + SingleByteCharSetProber(MacCyrillicModel), + SingleByteCharSetProber(Ibm866Model), + SingleByteCharSetProber(Ibm855Model), + SingleByteCharSetProber(Latin7GreekModel), + SingleByteCharSetProber(Win1253GreekModel), + SingleByteCharSetProber(Latin5BulgarianModel), + SingleByteCharSetProber(Win1251BulgarianModel), + # TODO: Restore Hungarian encodings (iso-8859-2 and windows-1250) + # after we retrain model. + # SingleByteCharSetProber(Latin2HungarianModel), + # SingleByteCharSetProber(Win1250HungarianModel), + SingleByteCharSetProber(TIS620ThaiModel), + SingleByteCharSetProber(Latin5TurkishModel), + ] + hebrew_prober = HebrewProber() + logical_hebrew_prober = SingleByteCharSetProber(Win1255HebrewModel, + False, hebrew_prober) + visual_hebrew_prober = SingleByteCharSetProber(Win1255HebrewModel, True, + hebrew_prober) + hebrew_prober.set_model_probers(logical_hebrew_prober, visual_hebrew_prober) + self.probers.extend([hebrew_prober, logical_hebrew_prober, + visual_hebrew_prober]) + + self.reset() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/sjisprober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/sjisprober.py new file mode 100644 index 0000000..9e29623 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/sjisprober.py @@ -0,0 +1,92 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is mozilla.org code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .mbcharsetprober import MultiByteCharSetProber +from .codingstatemachine import CodingStateMachine +from .chardistribution import SJISDistributionAnalysis +from .jpcntx import SJISContextAnalysis +from .mbcssm import SJIS_SM_MODEL +from .enums import ProbingState, MachineState + + +class SJISProber(MultiByteCharSetProber): + def __init__(self): + super(SJISProber, self).__init__() + self.coding_sm = CodingStateMachine(SJIS_SM_MODEL) + self.distribution_analyzer = SJISDistributionAnalysis() + self.context_analyzer = SJISContextAnalysis() + self.reset() + + def reset(self): + super(SJISProber, self).reset() + self.context_analyzer.reset() + + @property + def charset_name(self): + return self.context_analyzer.charset_name + + @property + def language(self): + return "Japanese" + + def feed(self, byte_str): + for i in range(len(byte_str)): + coding_state = self.coding_sm.next_state(byte_str[i]) + if coding_state == MachineState.ERROR: + self.logger.debug('%s %s prober hit error at byte %s', + self.charset_name, self.language, i) + self._state = ProbingState.NOT_ME + break + elif coding_state == MachineState.ITS_ME: + self._state = ProbingState.FOUND_IT + break + elif coding_state == MachineState.START: + char_len = self.coding_sm.get_current_charlen() + if i == 0: + self._last_char[1] = byte_str[0] + self.context_analyzer.feed(self._last_char[2 - char_len:], + char_len) + self.distribution_analyzer.feed(self._last_char, char_len) + else: + self.context_analyzer.feed(byte_str[i + 1 - char_len:i + 3 + - char_len], char_len) + self.distribution_analyzer.feed(byte_str[i - 1:i + 1], + char_len) + + self._last_char[0] = byte_str[-1] + + if self.state == ProbingState.DETECTING: + if (self.context_analyzer.got_enough_data() and + (self.get_confidence() > self.SHORTCUT_THRESHOLD)): + self._state = ProbingState.FOUND_IT + + return self.state + + def get_confidence(self): + context_conf = self.context_analyzer.get_confidence() + distrib_conf = self.distribution_analyzer.get_confidence() + return max(context_conf, distrib_conf) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/universaldetector.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/universaldetector.py new file mode 100644 index 0000000..7b4e92d --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/universaldetector.py @@ -0,0 +1,286 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is Mozilla Universal charset detector code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 2001 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# Shy Shalom - original C code +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### +""" +Module containing the UniversalDetector detector class, which is the primary +class a user of ``chardet`` should use. + +:author: Mark Pilgrim (initial port to Python) +:author: Shy Shalom (original C code) +:author: Dan Blanchard (major refactoring for 3.0) +:author: Ian Cordasco +""" + + +import codecs +import logging +import re + +from .charsetgroupprober import CharSetGroupProber +from .enums import InputState, LanguageFilter, ProbingState +from .escprober import EscCharSetProber +from .latin1prober import Latin1Prober +from .mbcsgroupprober import MBCSGroupProber +from .sbcsgroupprober import SBCSGroupProber + + +class UniversalDetector(object): + """ + The ``UniversalDetector`` class underlies the ``chardet.detect`` function + and coordinates all of the different charset probers. + + To get a ``dict`` containing an encoding and its confidence, you can simply + run: + + .. code:: + + u = UniversalDetector() + u.feed(some_bytes) + u.close() + detected = u.result + + """ + + MINIMUM_THRESHOLD = 0.20 + HIGH_BYTE_DETECTOR = re.compile(b'[\x80-\xFF]') + ESC_DETECTOR = re.compile(b'(\033|~{)') + WIN_BYTE_DETECTOR = re.compile(b'[\x80-\x9F]') + ISO_WIN_MAP = {'iso-8859-1': 'Windows-1252', + 'iso-8859-2': 'Windows-1250', + 'iso-8859-5': 'Windows-1251', + 'iso-8859-6': 'Windows-1256', + 'iso-8859-7': 'Windows-1253', + 'iso-8859-8': 'Windows-1255', + 'iso-8859-9': 'Windows-1254', + 'iso-8859-13': 'Windows-1257'} + + def __init__(self, lang_filter=LanguageFilter.ALL): + self._esc_charset_prober = None + self._charset_probers = [] + self.result = None + self.done = None + self._got_data = None + self._input_state = None + self._last_char = None + self.lang_filter = lang_filter + self.logger = logging.getLogger(__name__) + self._has_win_bytes = None + self.reset() + + def reset(self): + """ + Reset the UniversalDetector and all of its probers back to their + initial states. This is called by ``__init__``, so you only need to + call this directly in between analyses of different documents. + """ + self.result = {'encoding': None, 'confidence': 0.0, 'language': None} + self.done = False + self._got_data = False + self._has_win_bytes = False + self._input_state = InputState.PURE_ASCII + self._last_char = b'' + if self._esc_charset_prober: + self._esc_charset_prober.reset() + for prober in self._charset_probers: + prober.reset() + + def feed(self, byte_str): + """ + Takes a chunk of a document and feeds it through all of the relevant + charset probers. + + After calling ``feed``, you can check the value of the ``done`` + attribute to see if you need to continue feeding the + ``UniversalDetector`` more data, or if it has made a prediction + (in the ``result`` attribute). + + .. note:: + You should always call ``close`` when you're done feeding in your + document if ``done`` is not already ``True``. + """ + if self.done: + return + + if not len(byte_str): + return + + if not isinstance(byte_str, bytearray): + byte_str = bytearray(byte_str) + + # First check for known BOMs, since these are guaranteed to be correct + if not self._got_data: + # If the data starts with BOM, we know it is UTF + if byte_str.startswith(codecs.BOM_UTF8): + # EF BB BF UTF-8 with BOM + self.result = {'encoding': "UTF-8-SIG", + 'confidence': 1.0, + 'language': ''} + elif byte_str.startswith((codecs.BOM_UTF32_LE, + codecs.BOM_UTF32_BE)): + # FF FE 00 00 UTF-32, little-endian BOM + # 00 00 FE FF UTF-32, big-endian BOM + self.result = {'encoding': "UTF-32", + 'confidence': 1.0, + 'language': ''} + elif byte_str.startswith(b'\xFE\xFF\x00\x00'): + # FE FF 00 00 UCS-4, unusual octet order BOM (3412) + self.result = {'encoding': "X-ISO-10646-UCS-4-3412", + 'confidence': 1.0, + 'language': ''} + elif byte_str.startswith(b'\x00\x00\xFF\xFE'): + # 00 00 FF FE UCS-4, unusual octet order BOM (2143) + self.result = {'encoding': "X-ISO-10646-UCS-4-2143", + 'confidence': 1.0, + 'language': ''} + elif byte_str.startswith((codecs.BOM_LE, codecs.BOM_BE)): + # FF FE UTF-16, little endian BOM + # FE FF UTF-16, big endian BOM + self.result = {'encoding': "UTF-16", + 'confidence': 1.0, + 'language': ''} + + self._got_data = True + if self.result['encoding'] is not None: + self.done = True + return + + # If none of those matched and we've only see ASCII so far, check + # for high bytes and escape sequences + if self._input_state == InputState.PURE_ASCII: + if self.HIGH_BYTE_DETECTOR.search(byte_str): + self._input_state = InputState.HIGH_BYTE + elif self._input_state == InputState.PURE_ASCII and \ + self.ESC_DETECTOR.search(self._last_char + byte_str): + self._input_state = InputState.ESC_ASCII + + self._last_char = byte_str[-1:] + + # If we've seen escape sequences, use the EscCharSetProber, which + # uses a simple state machine to check for known escape sequences in + # HZ and ISO-2022 encodings, since those are the only encodings that + # use such sequences. + if self._input_state == InputState.ESC_ASCII: + if not self._esc_charset_prober: + self._esc_charset_prober = EscCharSetProber(self.lang_filter) + if self._esc_charset_prober.feed(byte_str) == ProbingState.FOUND_IT: + self.result = {'encoding': + self._esc_charset_prober.charset_name, + 'confidence': + self._esc_charset_prober.get_confidence(), + 'language': + self._esc_charset_prober.language} + self.done = True + # If we've seen high bytes (i.e., those with values greater than 127), + # we need to do more complicated checks using all our multi-byte and + # single-byte probers that are left. The single-byte probers + # use character bigram distributions to determine the encoding, whereas + # the multi-byte probers use a combination of character unigram and + # bigram distributions. + elif self._input_state == InputState.HIGH_BYTE: + if not self._charset_probers: + self._charset_probers = [MBCSGroupProber(self.lang_filter)] + # If we're checking non-CJK encodings, use single-byte prober + if self.lang_filter & LanguageFilter.NON_CJK: + self._charset_probers.append(SBCSGroupProber()) + self._charset_probers.append(Latin1Prober()) + for prober in self._charset_probers: + if prober.feed(byte_str) == ProbingState.FOUND_IT: + self.result = {'encoding': prober.charset_name, + 'confidence': prober.get_confidence(), + 'language': prober.language} + self.done = True + break + if self.WIN_BYTE_DETECTOR.search(byte_str): + self._has_win_bytes = True + + def close(self): + """ + Stop analyzing the current document and come up with a final + prediction. + + :returns: The ``result`` attribute, a ``dict`` with the keys + `encoding`, `confidence`, and `language`. + """ + # Don't bother with checks if we're already done + if self.done: + return self.result + self.done = True + + if not self._got_data: + self.logger.debug('no data received!') + + # Default to ASCII if it is all we've seen so far + elif self._input_state == InputState.PURE_ASCII: + self.result = {'encoding': 'ascii', + 'confidence': 1.0, + 'language': ''} + + # If we have seen non-ASCII, return the best that met MINIMUM_THRESHOLD + elif self._input_state == InputState.HIGH_BYTE: + prober_confidence = None + max_prober_confidence = 0.0 + max_prober = None + for prober in self._charset_probers: + if not prober: + continue + prober_confidence = prober.get_confidence() + if prober_confidence > max_prober_confidence: + max_prober_confidence = prober_confidence + max_prober = prober + if max_prober and (max_prober_confidence > self.MINIMUM_THRESHOLD): + charset_name = max_prober.charset_name + lower_charset_name = max_prober.charset_name.lower() + confidence = max_prober.get_confidence() + # Use Windows encoding name instead of ISO-8859 if we saw any + # extra Windows-specific bytes + if lower_charset_name.startswith('iso-8859'): + if self._has_win_bytes: + charset_name = self.ISO_WIN_MAP.get(lower_charset_name, + charset_name) + self.result = {'encoding': charset_name, + 'confidence': confidence, + 'language': max_prober.language} + + # Log all prober confidences if none met MINIMUM_THRESHOLD + if self.logger.getEffectiveLevel() == logging.DEBUG: + if self.result['encoding'] is None: + self.logger.debug('no probers hit minimum threshold') + for group_prober in self._charset_probers: + if not group_prober: + continue + if isinstance(group_prober, CharSetGroupProber): + for prober in group_prober.probers: + self.logger.debug('%s %s confidence = %s', + prober.charset_name, + prober.language, + prober.get_confidence()) + else: + self.logger.debug('%s %s confidence = %s', + prober.charset_name, + prober.language, + prober.get_confidence()) + return self.result diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/utf8prober.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/utf8prober.py new file mode 100644 index 0000000..6c3196c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/utf8prober.py @@ -0,0 +1,82 @@ +######################## BEGIN LICENSE BLOCK ######################## +# The Original Code is mozilla.org code. +# +# The Initial Developer of the Original Code is +# Netscape Communications Corporation. +# Portions created by the Initial Developer are Copyright (C) 1998 +# the Initial Developer. All Rights Reserved. +# +# Contributor(s): +# Mark Pilgrim - port to Python +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# 02110-1301 USA +######################### END LICENSE BLOCK ######################### + +from .charsetprober import CharSetProber +from .enums import ProbingState, MachineState +from .codingstatemachine import CodingStateMachine +from .mbcssm import UTF8_SM_MODEL + + + +class UTF8Prober(CharSetProber): + ONE_CHAR_PROB = 0.5 + + def __init__(self): + super(UTF8Prober, self).__init__() + self.coding_sm = CodingStateMachine(UTF8_SM_MODEL) + self._num_mb_chars = None + self.reset() + + def reset(self): + super(UTF8Prober, self).reset() + self.coding_sm.reset() + self._num_mb_chars = 0 + + @property + def charset_name(self): + return "utf-8" + + @property + def language(self): + return "" + + def feed(self, byte_str): + for c in byte_str: + coding_state = self.coding_sm.next_state(c) + if coding_state == MachineState.ERROR: + self._state = ProbingState.NOT_ME + break + elif coding_state == MachineState.ITS_ME: + self._state = ProbingState.FOUND_IT + break + elif coding_state == MachineState.START: + if self.coding_sm.get_current_charlen() >= 2: + self._num_mb_chars += 1 + + if self.state == ProbingState.DETECTING: + if self.get_confidence() > self.SHORTCUT_THRESHOLD: + self._state = ProbingState.FOUND_IT + + return self.state + + def get_confidence(self): + unlike = 0.99 + if self._num_mb_chars < 6: + unlike *= self.ONE_CHAR_PROB ** self._num_mb_chars + return 1.0 - unlike + else: + return unlike diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/version.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/version.py new file mode 100644 index 0000000..bb2a34a --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/chardet/version.py @@ -0,0 +1,9 @@ +""" +This module exists only to simplify retrieving the version number of chardet +from within setup.py and from chardet subpackages. + +:author: Dan Blanchard (dan.blanchard@gmail.com) +""" + +__version__ = "3.0.4" +VERSION = __version__.split('.') diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__init__.py new file mode 100644 index 0000000..2a3bf47 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__init__.py @@ -0,0 +1,6 @@ +# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file. +from .initialise import init, deinit, reinit, colorama_text +from .ansi import Fore, Back, Style, Cursor +from .ansitowin32 import AnsiToWin32 + +__version__ = '0.4.1' diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0c5119bc8ca90cb5ae3b8318d5fab22c71b67b66 GIT binary patch literal 456 zcmYk2J5R$f5XbZGBdu8b6*{y|3#wEJAzor+X%Uha%QR_gu;b{GhPK~^k&Vyem5GUs zfe9ZK5+~j7d=H=X_g%N!cC3B9z3@*P-!b`bo=wiJm)91lle*GTE_IbhJ>^qh1vGH6 z?#WO^G*S)PP)*uYE!z66`?9TK8ryR~J83v``q77LSM>uEh+I@AO0z?RL+mcJ)W8*I zRkp2g>_$Uof=j-5GU2S+$;?Do8z?pOT@zpArI_n`kspuuVKO`!j&A#1)5ev8OHpQk z3cyDMh|t0W++KqS^9G`cXkjPDPNko5A>h}Tn6Wy8Qs|tqR|k%86!8tD08#TQBQ*!I z)H1bWWV$6QHmyPJ^YQXAS+BSIJ(JVP!x|E6tDMY9A&P;>%Zf`mNRmmtt4A9w{<?iF iPc@Lge;|yZ8pejj&NNSzPB$_;LscaT=(#<&<NW}ZihUvg literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/ansi.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/ansi.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e6ff1ee1e15f2e8d636b68cdb2c9d8357c3747ff GIT binary patch literal 3241 zcmc&$TXWM!6xK?zEz8%KkQC^&?rn<OVh1|I4A5cXI3}bRCle==B1%=^-NXV%HY+6% zPnhY9`62L_xBi};zV%6epbtE8&MFShZQ998SF@k?=&a7!bCuRI8B>Ar&!6v{zmkgb zHxlDR2Vxec{}zBMmO_a|sA{QHvoxyH*c-*tX`CkD9;2VoBsJd<D^4%b6ive_v7pcl z&Aw4+mKj6MN&=mud7$%>Hi4d?1)vKo3H%h$7w9C=lafvYeUVN9JtgT3OAQq(%hG^3 zmI2H&6L5k~x0KT5!5`*o$MuU_J-Xdx#ZBfh?gY#)R-3KGV!PvTryVd}Z1*TU40^>r zcfG*%HsMLP$K@m7Z@He+^~+|9vD?K?5cF?XD$Fatbf3F@MqQ`e<C_(vDk#@xe%t9Y z8-<z!^~z(IPu`P6n}E+o1J@eN8caVA5GVoJQ-)+3Tsp15;nk)fTl=ceYOO_~`2jBx zp`*-wg(u*J_g)1~y94G_b{t;W=yfUMe&yDy%BFp5hi?tM8ynANI-OU8f!)1z^J$0A zz}WOEtChanzvg;=;B>p!W@c{g?CxCO#)op+JItd!UXdPfww#LN`EI$tD>A6u4th5F z%}?XORRD!>$Q0#-b;ujD4z1c#roqYs>jvtLJ0&o0sZ|r&T)hG2#R50zGHG1|2FMUe zp9Qw$<bWLM%)mNC9VZn3yIX(exMv^y35jt+U%K684!8X_XUr>%sl@d;v^|j8I0pH+ zX=bFV>w4_sn4(Ek1oOy1TW4YV$YlzYodRVC#RsLPQ4KOi7s)Ebss=XsN6v}X#$nd* z^_u_zgknhMl_ytUlRfg5Q1XuWMxgE~dt|7-Rs#)Jfxf2>$xtK83xkeQ(k{h>MqMsU z$R8f~FWsOc5}Pb=f`E$z#0nQOB}$smeb(I&y60>$5!-RP+b6tj*tYArfo)&L!(qS` zJxxrw28Baw%A-w9FcRKCdA2P~+m0$5)@j>*vF&st4*v|qj5!<Yg`;eaZoULlrjbD; zeZtk~uUXu57vRv<846tvdYDGDveOahbUE4U2=ux<HE2@yx(RC16!torhM*LLDb3jC zevgM(_HB&hXy6*v$<Q430dlMlRHKAd`4!kIh&N`MED?2W`5WLI)W#t5QDb>+`5gM@ zqLf9M$5rX`OY6;V$CTy9lp*gN>S|}JOWa#pS+B0lm&P<kc_AHIK470i>HOJB^|@;8 z!S`bt$8AJj8$&i4xIPTwr$ES74wVzNa%k&OI91vBwB~zqN09qcdr3Qp=qo{Xk9%5M zUTR$faigea#~cl;W{L2xfPMN+mAq(!!9Rz6yom4x0)~&HM>!hFQ3=0+AnW8K$cp(A z7+=Hm@z1~@rW#!wpSNKi8JOR*F#TnK!^**$QK4Eis1qIj24YYfam%0yD@hH@q)979 zO)E`PR)(gnEX`OsnziyY2jB6$RiG2r1zLbwx*!bn!Mz@5Ay#;Zc7;U*v@66Th3JzI z4;*6phG=VOAv{L-72yfOZwNNR?+6Y+bAR%ft3+(B0r3{vN_}3$7FO!@rieePHyTUp zLZ54_)kWfAb)nu|tqQ&NsM-{<_4|vfbrD;sx9Y1R(^y=%zbZx8^<P9vk{}9+h$lrN znU%aqG}7sVSJ&!D<s@~W>LVLfA{EJ!s)0N;j6Z^X*J1kTB!lS3FYV|Pj{E<g@Xk5y z=iyaQA7YAz-yvY0hCd)+vW8`Z3IduGQUr#ufv}0tL2wbCAv_0Y@;czD-dP960?hyF z9o&Dmcd!YZo&1o<@#st43U=Xl2NRZO0m3N+m`byhIG%{{xfRSMq0KKo6!GTL%EM|y zBxRb})kfn~tI&MRb@^Ex#hl|)Y#yj`bSsF2ZPQ-cwmJUdbF6iqLP#Ru&lbnuAC5mC zBHnxYjI{&#@sxc)W(!BBNa;ey5`_YRNQ#)WQp9VrVV`zRVf++*#_y^i!7l>nF`15< U0hg(ndOnrU<fq_@#|d5^0H;TI{Qv*} literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/ansitowin32.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/ansitowin32.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2a943507e3f8178f2910fccdcf2cc74e83540b15 GIT binary patch literal 7750 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..041f6256a67fe4bbd0c47360db6ba9a882e53ab9 GIT binary patch literal 1717 zcma)6OK%%D5GJ_~tyT{|(xk1C7J?527HBFrK@B))iWWtE=s}mLNg)(iFydNTXSFK~ zDcM$)OYK80>2I))x%Kz#wWs`n9(qY<sK}NA1Sl7r<&d-F?Du`cUmA^&Vf*K=EBSkc zvA@Y#Z7w?BW7h_aVv1+1w|Mg&x4!5JC6tpnBe&;rjF297AA1FRpj=s1p7JkPFI3wq zP}K|GtEo`caHgK{<A$oM#sxd)y{2la4V>Ljn`#T+n~FbX(XBUlGV8qIXd_<Me#mv& zEuN<NgZqblT3T%aogcC5PtX`l^m!FNGR*LEekraPrpF$$*Sr%s;9x{qD<B=j+Nfe; z$|@u}F|o|D*9;Jhh56UC$B<5?N!n8h?V}=73F!90X?qYKOkp(3?;joS4Tq<*S)3j0 zKO4dxwn5(Rw#VuCUYcuzJKo#d+n=6Izn;*f?eR3pRRQgOkrg0EvYqCsNoAJm<g4)+ z_;~&{c1;X09&kI;?OT_ou+f;}>>t0x!Q9b1hRxZW&&9ww=dfeA!hipR8*%JN7p*6K z8Y40R>?<ZK`5hA&m%hO7oO91*M#PS+P^^vm4Wp_y%6~7)lT{Py3sbwSo5mGKbcGBF z;mGOCzB~aresm}^owWKzew3wsqgyAb8Mb78)+)>}ftG~9qb^L6ZqzItoG!yBGMgkn z0TfU=`b?Mpf*kPh_pFlu+|Wi&lMWguYDr^_d~_g@qqRl*CGvQhnphQiQu+(03?Lb# z+Tc2&8M$RuPE29dP*yPaX#%G7aL069y0rU^Iv}9DT;lFy9O=)|FtN=8&*#1fx$iXJ z2FthW@{q%)81Z4@ws7^GaGNCDSQsL!3U`fzo=flo5g&OL6R6=B>SUT^8f31;yBOIV zeU(s_4{%-61Zm1AUG3m_Egvc(+M&R%chM{)^(PWMLwcWJ89im+P*LINS6fnxjD-C+ zyI~|s7s*Bbo}bWrB_*3pV=4O>`7jUZB%2gMC3q;{Gn`pV3Vn86-7R$fFGw30y8_Y{ zxgQ1zEJ(JX)<7a&`=r5TBc)u|-WTZ1UD#dL-rQ0AmHWb*dzbu*!S38U7B8?au`&eR zJ$Eo3NH1_3&GluZhs7jQF)56sP6Cd6Xi?ny7eLorSy>1l-oq9)aq(yDn(hzAU3>&$ zC*JykD7Wj8d)Vo8qb<0FA!UdnCmyo&nT4vXNxWrEaYDDOy(t%3vkJ3-S{P}6TQWDi zm(6!ujbttdSW!eI5PJ65l~k=ptrmiBM}?YX$#=xBt)KvP8Hl=rsSDekzzgpN6|A2i GsQd?1qh>n* literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..58db4c990d7ce78698186294bf61648207717224 GIT binary patch literal 3993 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..70c85e8d27957331ddb38b8fe65bf15c739bc592 GIT binary patch literal 4677 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 U=gB`LUr-p-*}PyD$BNef0C!QkTL1t6 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/ansi.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/ansi.py new file mode 100644 index 0000000..7877658 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/ansi.py @@ -0,0 +1,102 @@ +# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file. +''' +This module generates ANSI character codes to printing colors to terminals. +See: http://en.wikipedia.org/wiki/ANSI_escape_code +''' + +CSI = '\033[' +OSC = '\033]' +BEL = '\007' + + +def code_to_chars(code): + return CSI + str(code) + 'm' + +def set_title(title): + return OSC + '2;' + title + BEL + +def clear_screen(mode=2): + return CSI + str(mode) + 'J' + +def clear_line(mode=2): + return CSI + str(mode) + 'K' + + +class AnsiCodes(object): + def __init__(self): + # the subclasses declare class attributes which are numbers. + # Upon instantiation we define instance attributes, which are the same + # as the class attributes but wrapped with the ANSI escape sequence + for name in dir(self): + if not name.startswith('_'): + value = getattr(self, name) + setattr(self, name, code_to_chars(value)) + + +class AnsiCursor(object): + def UP(self, n=1): + return CSI + str(n) + 'A' + def DOWN(self, n=1): + return CSI + str(n) + 'B' + def FORWARD(self, n=1): + return CSI + str(n) + 'C' + def BACK(self, n=1): + return CSI + str(n) + 'D' + def POS(self, x=1, y=1): + return CSI + str(y) + ';' + str(x) + 'H' + + +class AnsiFore(AnsiCodes): + BLACK = 30 + RED = 31 + GREEN = 32 + YELLOW = 33 + BLUE = 34 + MAGENTA = 35 + CYAN = 36 + WHITE = 37 + RESET = 39 + + # These are fairly well supported, but not part of the standard. + LIGHTBLACK_EX = 90 + LIGHTRED_EX = 91 + LIGHTGREEN_EX = 92 + LIGHTYELLOW_EX = 93 + LIGHTBLUE_EX = 94 + LIGHTMAGENTA_EX = 95 + LIGHTCYAN_EX = 96 + LIGHTWHITE_EX = 97 + + +class AnsiBack(AnsiCodes): + BLACK = 40 + RED = 41 + GREEN = 42 + YELLOW = 43 + BLUE = 44 + MAGENTA = 45 + CYAN = 46 + WHITE = 47 + RESET = 49 + + # These are fairly well supported, but not part of the standard. + LIGHTBLACK_EX = 100 + LIGHTRED_EX = 101 + LIGHTGREEN_EX = 102 + LIGHTYELLOW_EX = 103 + LIGHTBLUE_EX = 104 + LIGHTMAGENTA_EX = 105 + LIGHTCYAN_EX = 106 + LIGHTWHITE_EX = 107 + + +class AnsiStyle(AnsiCodes): + BRIGHT = 1 + DIM = 2 + NORMAL = 22 + RESET_ALL = 0 + +Fore = AnsiFore() +Back = AnsiBack() +Style = AnsiStyle() +Cursor = AnsiCursor() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/ansitowin32.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/ansitowin32.py new file mode 100644 index 0000000..359c92b --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/ansitowin32.py @@ -0,0 +1,257 @@ +# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file. +import re +import sys +import os + +from .ansi import AnsiFore, AnsiBack, AnsiStyle, Style +from .winterm import WinTerm, WinColor, WinStyle +from .win32 import windll, winapi_test + + +winterm = None +if windll is not None: + winterm = WinTerm() + + +class StreamWrapper(object): + ''' + Wraps a stream (such as stdout), acting as a transparent proxy for all + attribute access apart from method 'write()', which is delegated to our + Converter instance. + ''' + def __init__(self, wrapped, converter): + # double-underscore everything to prevent clashes with names of + # attributes on the wrapped stream object. + self.__wrapped = wrapped + self.__convertor = converter + + def __getattr__(self, name): + return getattr(self.__wrapped, name) + + def __enter__(self, *args, **kwargs): + # special method lookup bypasses __getattr__/__getattribute__, see + # https://stackoverflow.com/questions/12632894/why-doesnt-getattr-work-with-exit + # thus, contextlib magic methods are not proxied via __getattr__ + return self.__wrapped.__enter__(*args, **kwargs) + + def __exit__(self, *args, **kwargs): + return self.__wrapped.__exit__(*args, **kwargs) + + def write(self, text): + self.__convertor.write(text) + + def isatty(self): + stream = self.__wrapped + if 'PYCHARM_HOSTED' in os.environ: + if stream is not None and (stream is sys.__stdout__ or stream is sys.__stderr__): + return True + try: + stream_isatty = stream.isatty + except AttributeError: + return False + else: + return stream_isatty() + + @property + def closed(self): + stream = self.__wrapped + try: + return stream.closed + except AttributeError: + return True + + +class AnsiToWin32(object): + ''' + Implements a 'write()' method which, on Windows, will strip ANSI character + sequences from the text, and if outputting to a tty, will convert them into + win32 function calls. + ''' + ANSI_CSI_RE = re.compile('\001?\033\\[((?:\\d|;)*)([a-zA-Z])\002?') # Control Sequence Introducer + ANSI_OSC_RE = re.compile('\001?\033\\]((?:.|;)*?)(\x07)\002?') # Operating System Command + + def __init__(self, wrapped, convert=None, strip=None, autoreset=False): + # The wrapped stream (normally sys.stdout or sys.stderr) + self.wrapped = wrapped + + # should we reset colors to defaults after every .write() + self.autoreset = autoreset + + # create the proxy wrapping our output stream + self.stream = StreamWrapper(wrapped, self) + + on_windows = os.name == 'nt' + # We test if the WinAPI works, because even if we are on Windows + # we may be using a terminal that doesn't support the WinAPI + # (e.g. Cygwin Terminal). In this case it's up to the terminal + # to support the ANSI codes. + conversion_supported = on_windows and winapi_test() + + # should we strip ANSI sequences from our output? + if strip is None: + strip = conversion_supported or (not self.stream.closed and not self.stream.isatty()) + self.strip = strip + + # should we should convert ANSI sequences into win32 calls? + if convert is None: + convert = conversion_supported and not self.stream.closed and self.stream.isatty() + self.convert = convert + + # dict of ansi codes to win32 functions and parameters + self.win32_calls = self.get_win32_calls() + + # are we wrapping stderr? + self.on_stderr = self.wrapped is sys.stderr + + def should_wrap(self): + ''' + True if this class is actually needed. If false, then the output + stream will not be affected, nor will win32 calls be issued, so + wrapping stdout is not actually required. This will generally be + False on non-Windows platforms, unless optional functionality like + autoreset has been requested using kwargs to init() + ''' + return self.convert or self.strip or self.autoreset + + def get_win32_calls(self): + if self.convert and winterm: + return { + AnsiStyle.RESET_ALL: (winterm.reset_all, ), + AnsiStyle.BRIGHT: (winterm.style, WinStyle.BRIGHT), + AnsiStyle.DIM: (winterm.style, WinStyle.NORMAL), + AnsiStyle.NORMAL: (winterm.style, WinStyle.NORMAL), + AnsiFore.BLACK: (winterm.fore, WinColor.BLACK), + AnsiFore.RED: (winterm.fore, WinColor.RED), + AnsiFore.GREEN: (winterm.fore, WinColor.GREEN), + AnsiFore.YELLOW: (winterm.fore, WinColor.YELLOW), + AnsiFore.BLUE: (winterm.fore, WinColor.BLUE), + AnsiFore.MAGENTA: (winterm.fore, WinColor.MAGENTA), + AnsiFore.CYAN: (winterm.fore, WinColor.CYAN), + AnsiFore.WHITE: (winterm.fore, WinColor.GREY), + AnsiFore.RESET: (winterm.fore, ), + AnsiFore.LIGHTBLACK_EX: (winterm.fore, WinColor.BLACK, True), + AnsiFore.LIGHTRED_EX: (winterm.fore, WinColor.RED, True), + AnsiFore.LIGHTGREEN_EX: (winterm.fore, WinColor.GREEN, True), + AnsiFore.LIGHTYELLOW_EX: (winterm.fore, WinColor.YELLOW, True), + AnsiFore.LIGHTBLUE_EX: (winterm.fore, WinColor.BLUE, True), + AnsiFore.LIGHTMAGENTA_EX: (winterm.fore, WinColor.MAGENTA, True), + AnsiFore.LIGHTCYAN_EX: (winterm.fore, WinColor.CYAN, True), + AnsiFore.LIGHTWHITE_EX: (winterm.fore, WinColor.GREY, True), + AnsiBack.BLACK: (winterm.back, WinColor.BLACK), + AnsiBack.RED: (winterm.back, WinColor.RED), + AnsiBack.GREEN: (winterm.back, WinColor.GREEN), + AnsiBack.YELLOW: (winterm.back, WinColor.YELLOW), + AnsiBack.BLUE: (winterm.back, WinColor.BLUE), + AnsiBack.MAGENTA: (winterm.back, WinColor.MAGENTA), + AnsiBack.CYAN: (winterm.back, WinColor.CYAN), + AnsiBack.WHITE: (winterm.back, WinColor.GREY), + AnsiBack.RESET: (winterm.back, ), + AnsiBack.LIGHTBLACK_EX: (winterm.back, WinColor.BLACK, True), + AnsiBack.LIGHTRED_EX: (winterm.back, WinColor.RED, True), + AnsiBack.LIGHTGREEN_EX: (winterm.back, WinColor.GREEN, True), + AnsiBack.LIGHTYELLOW_EX: (winterm.back, WinColor.YELLOW, True), + AnsiBack.LIGHTBLUE_EX: (winterm.back, WinColor.BLUE, True), + AnsiBack.LIGHTMAGENTA_EX: (winterm.back, WinColor.MAGENTA, True), + AnsiBack.LIGHTCYAN_EX: (winterm.back, WinColor.CYAN, True), + AnsiBack.LIGHTWHITE_EX: (winterm.back, WinColor.GREY, True), + } + return dict() + + def write(self, text): + if self.strip or self.convert: + self.write_and_convert(text) + else: + self.wrapped.write(text) + self.wrapped.flush() + if self.autoreset: + self.reset_all() + + + def reset_all(self): + if self.convert: + self.call_win32('m', (0,)) + elif not self.strip and not self.stream.closed: + self.wrapped.write(Style.RESET_ALL) + + + def write_and_convert(self, text): + ''' + Write the given text to our wrapped stream, stripping any ANSI + sequences from the text, and optionally converting them into win32 + calls. + ''' + cursor = 0 + text = self.convert_osc(text) + for match in self.ANSI_CSI_RE.finditer(text): + start, end = match.span() + self.write_plain_text(text, cursor, start) + self.convert_ansi(*match.groups()) + cursor = end + self.write_plain_text(text, cursor, len(text)) + + + def write_plain_text(self, text, start, end): + if start < end: + self.wrapped.write(text[start:end]) + self.wrapped.flush() + + + def convert_ansi(self, paramstring, command): + if self.convert: + params = self.extract_params(command, paramstring) + self.call_win32(command, params) + + + def extract_params(self, command, paramstring): + if command in 'Hf': + params = tuple(int(p) if len(p) != 0 else 1 for p in paramstring.split(';')) + while len(params) < 2: + # defaults: + params = params + (1,) + else: + params = tuple(int(p) for p in paramstring.split(';') if len(p) != 0) + if len(params) == 0: + # defaults: + if command in 'JKm': + params = (0,) + elif command in 'ABCD': + params = (1,) + + return params + + + def call_win32(self, command, params): + if command == 'm': + for param in params: + if param in self.win32_calls: + func_args = self.win32_calls[param] + func = func_args[0] + args = func_args[1:] + kwargs = dict(on_stderr=self.on_stderr) + func(*args, **kwargs) + elif command in 'J': + winterm.erase_screen(params[0], on_stderr=self.on_stderr) + elif command in 'K': + winterm.erase_line(params[0], on_stderr=self.on_stderr) + elif command in 'Hf': # cursor position - absolute + winterm.set_cursor_position(params, on_stderr=self.on_stderr) + elif command in 'ABCD': # cursor position - relative + n = params[0] + # A - up, B - down, C - forward, D - back + x, y = {'A': (0, -n), 'B': (0, n), 'C': (n, 0), 'D': (-n, 0)}[command] + winterm.cursor_adjust(x, y, on_stderr=self.on_stderr) + + + def convert_osc(self, text): + for match in self.ANSI_OSC_RE.finditer(text): + start, end = match.span() + text = text[:start] + text[end:] + paramstring, command = match.groups() + if command in '\x07': # \x07 = BEL + params = paramstring.split(";") + # 0 - change title and icon (we will only change title) + # 1 - change icon (we don't support this) + # 2 - change title + if params[0] in '02': + winterm.set_title(params[1]) + return text diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/initialise.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/initialise.py new file mode 100644 index 0000000..430d066 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/initialise.py @@ -0,0 +1,80 @@ +# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file. +import atexit +import contextlib +import sys + +from .ansitowin32 import AnsiToWin32 + + +orig_stdout = None +orig_stderr = None + +wrapped_stdout = None +wrapped_stderr = None + +atexit_done = False + + +def reset_all(): + if AnsiToWin32 is not None: # Issue #74: objects might become None at exit + AnsiToWin32(orig_stdout).reset_all() + + +def init(autoreset=False, convert=None, strip=None, wrap=True): + + if not wrap and any([autoreset, convert, strip]): + raise ValueError('wrap=False conflicts with any other arg=True') + + global wrapped_stdout, wrapped_stderr + global orig_stdout, orig_stderr + + orig_stdout = sys.stdout + orig_stderr = sys.stderr + + if sys.stdout is None: + wrapped_stdout = None + else: + sys.stdout = wrapped_stdout = \ + wrap_stream(orig_stdout, convert, strip, autoreset, wrap) + if sys.stderr is None: + wrapped_stderr = None + else: + sys.stderr = wrapped_stderr = \ + wrap_stream(orig_stderr, convert, strip, autoreset, wrap) + + global atexit_done + if not atexit_done: + atexit.register(reset_all) + atexit_done = True + + +def deinit(): + if orig_stdout is not None: + sys.stdout = orig_stdout + if orig_stderr is not None: + sys.stderr = orig_stderr + + +@contextlib.contextmanager +def colorama_text(*args, **kwargs): + init(*args, **kwargs) + try: + yield + finally: + deinit() + + +def reinit(): + if wrapped_stdout is not None: + sys.stdout = wrapped_stdout + if wrapped_stderr is not None: + sys.stderr = wrapped_stderr + + +def wrap_stream(stream, convert, strip, autoreset, wrap): + if wrap: + wrapper = AnsiToWin32(stream, + convert=convert, strip=strip, autoreset=autoreset) + if wrapper.should_wrap(): + stream = wrapper.stream + return stream diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/win32.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/win32.py new file mode 100644 index 0000000..c2d8360 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/win32.py @@ -0,0 +1,152 @@ +# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file. + +# from winbase.h +STDOUT = -11 +STDERR = -12 + +try: + import ctypes + from ctypes import LibraryLoader + windll = LibraryLoader(ctypes.WinDLL) + from ctypes import wintypes +except (AttributeError, ImportError): + windll = None + SetConsoleTextAttribute = lambda *_: None + winapi_test = lambda *_: None +else: + from ctypes import byref, Structure, c_char, POINTER + + COORD = wintypes._COORD + + class CONSOLE_SCREEN_BUFFER_INFO(Structure): + """struct in wincon.h.""" + _fields_ = [ + ("dwSize", COORD), + ("dwCursorPosition", COORD), + ("wAttributes", wintypes.WORD), + ("srWindow", wintypes.SMALL_RECT), + ("dwMaximumWindowSize", COORD), + ] + def __str__(self): + return '(%d,%d,%d,%d,%d,%d,%d,%d,%d,%d,%d)' % ( + self.dwSize.Y, self.dwSize.X + , self.dwCursorPosition.Y, self.dwCursorPosition.X + , self.wAttributes + , self.srWindow.Top, self.srWindow.Left, self.srWindow.Bottom, self.srWindow.Right + , self.dwMaximumWindowSize.Y, self.dwMaximumWindowSize.X + ) + + _GetStdHandle = windll.kernel32.GetStdHandle + _GetStdHandle.argtypes = [ + wintypes.DWORD, + ] + _GetStdHandle.restype = wintypes.HANDLE + + _GetConsoleScreenBufferInfo = windll.kernel32.GetConsoleScreenBufferInfo + _GetConsoleScreenBufferInfo.argtypes = [ + wintypes.HANDLE, + POINTER(CONSOLE_SCREEN_BUFFER_INFO), + ] + _GetConsoleScreenBufferInfo.restype = wintypes.BOOL + + _SetConsoleTextAttribute = windll.kernel32.SetConsoleTextAttribute + _SetConsoleTextAttribute.argtypes = [ + wintypes.HANDLE, + wintypes.WORD, + ] + _SetConsoleTextAttribute.restype = wintypes.BOOL + + _SetConsoleCursorPosition = windll.kernel32.SetConsoleCursorPosition + _SetConsoleCursorPosition.argtypes = [ + wintypes.HANDLE, + COORD, + ] + _SetConsoleCursorPosition.restype = wintypes.BOOL + + _FillConsoleOutputCharacterA = windll.kernel32.FillConsoleOutputCharacterA + _FillConsoleOutputCharacterA.argtypes = [ + wintypes.HANDLE, + c_char, + wintypes.DWORD, + COORD, + POINTER(wintypes.DWORD), + ] + _FillConsoleOutputCharacterA.restype = wintypes.BOOL + + _FillConsoleOutputAttribute = windll.kernel32.FillConsoleOutputAttribute + _FillConsoleOutputAttribute.argtypes = [ + wintypes.HANDLE, + wintypes.WORD, + wintypes.DWORD, + COORD, + POINTER(wintypes.DWORD), + ] + _FillConsoleOutputAttribute.restype = wintypes.BOOL + + _SetConsoleTitleW = windll.kernel32.SetConsoleTitleW + _SetConsoleTitleW.argtypes = [ + wintypes.LPCWSTR + ] + _SetConsoleTitleW.restype = wintypes.BOOL + + def _winapi_test(handle): + csbi = CONSOLE_SCREEN_BUFFER_INFO() + success = _GetConsoleScreenBufferInfo( + handle, byref(csbi)) + return bool(success) + + def winapi_test(): + return any(_winapi_test(h) for h in + (_GetStdHandle(STDOUT), _GetStdHandle(STDERR))) + + def GetConsoleScreenBufferInfo(stream_id=STDOUT): + handle = _GetStdHandle(stream_id) + csbi = CONSOLE_SCREEN_BUFFER_INFO() + success = _GetConsoleScreenBufferInfo( + handle, byref(csbi)) + return csbi + + def SetConsoleTextAttribute(stream_id, attrs): + handle = _GetStdHandle(stream_id) + return _SetConsoleTextAttribute(handle, attrs) + + def SetConsoleCursorPosition(stream_id, position, adjust=True): + position = COORD(*position) + # If the position is out of range, do nothing. + if position.Y <= 0 or position.X <= 0: + return + # Adjust for Windows' SetConsoleCursorPosition: + # 1. being 0-based, while ANSI is 1-based. + # 2. expecting (x,y), while ANSI uses (y,x). + adjusted_position = COORD(position.Y - 1, position.X - 1) + if adjust: + # Adjust for viewport's scroll position + sr = GetConsoleScreenBufferInfo(STDOUT).srWindow + adjusted_position.Y += sr.Top + adjusted_position.X += sr.Left + # Resume normal processing + handle = _GetStdHandle(stream_id) + return _SetConsoleCursorPosition(handle, adjusted_position) + + def FillConsoleOutputCharacter(stream_id, char, length, start): + handle = _GetStdHandle(stream_id) + char = c_char(char.encode()) + length = wintypes.DWORD(length) + num_written = wintypes.DWORD(0) + # Note that this is hard-coded for ANSI (vs wide) bytes. + success = _FillConsoleOutputCharacterA( + handle, char, length, start, byref(num_written)) + return num_written.value + + def FillConsoleOutputAttribute(stream_id, attr, length, start): + ''' FillConsoleOutputAttribute( hConsole, csbi.wAttributes, dwConSize, coordScreen, &cCharsWritten )''' + handle = _GetStdHandle(stream_id) + attribute = wintypes.WORD(attr) + length = wintypes.DWORD(length) + num_written = wintypes.DWORD(0) + # Note that this is hard-coded for ANSI (vs wide) bytes. + return _FillConsoleOutputAttribute( + handle, attribute, length, start, byref(num_written)) + + def SetConsoleTitle(title): + return _SetConsoleTitleW(title) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/winterm.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/winterm.py new file mode 100644 index 0000000..0fdb4ec --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/colorama/winterm.py @@ -0,0 +1,169 @@ +# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file. +from . import win32 + + +# from wincon.h +class WinColor(object): + BLACK = 0 + BLUE = 1 + GREEN = 2 + CYAN = 3 + RED = 4 + MAGENTA = 5 + YELLOW = 6 + GREY = 7 + +# from wincon.h +class WinStyle(object): + NORMAL = 0x00 # dim text, dim background + BRIGHT = 0x08 # bright text, dim background + BRIGHT_BACKGROUND = 0x80 # dim text, bright background + +class WinTerm(object): + + def __init__(self): + self._default = win32.GetConsoleScreenBufferInfo(win32.STDOUT).wAttributes + self.set_attrs(self._default) + self._default_fore = self._fore + self._default_back = self._back + self._default_style = self._style + # In order to emulate LIGHT_EX in windows, we borrow the BRIGHT style. + # So that LIGHT_EX colors and BRIGHT style do not clobber each other, + # we track them separately, since LIGHT_EX is overwritten by Fore/Back + # and BRIGHT is overwritten by Style codes. + self._light = 0 + + def get_attrs(self): + return self._fore + self._back * 16 + (self._style | self._light) + + def set_attrs(self, value): + self._fore = value & 7 + self._back = (value >> 4) & 7 + self._style = value & (WinStyle.BRIGHT | WinStyle.BRIGHT_BACKGROUND) + + def reset_all(self, on_stderr=None): + self.set_attrs(self._default) + self.set_console(attrs=self._default) + self._light = 0 + + def fore(self, fore=None, light=False, on_stderr=False): + if fore is None: + fore = self._default_fore + self._fore = fore + # Emulate LIGHT_EX with BRIGHT Style + if light: + self._light |= WinStyle.BRIGHT + else: + self._light &= ~WinStyle.BRIGHT + self.set_console(on_stderr=on_stderr) + + def back(self, back=None, light=False, on_stderr=False): + if back is None: + back = self._default_back + self._back = back + # Emulate LIGHT_EX with BRIGHT_BACKGROUND Style + if light: + self._light |= WinStyle.BRIGHT_BACKGROUND + else: + self._light &= ~WinStyle.BRIGHT_BACKGROUND + self.set_console(on_stderr=on_stderr) + + def style(self, style=None, on_stderr=False): + if style is None: + style = self._default_style + self._style = style + self.set_console(on_stderr=on_stderr) + + def set_console(self, attrs=None, on_stderr=False): + if attrs is None: + attrs = self.get_attrs() + handle = win32.STDOUT + if on_stderr: + handle = win32.STDERR + win32.SetConsoleTextAttribute(handle, attrs) + + def get_position(self, handle): + position = win32.GetConsoleScreenBufferInfo(handle).dwCursorPosition + # Because Windows coordinates are 0-based, + # and win32.SetConsoleCursorPosition expects 1-based. + position.X += 1 + position.Y += 1 + return position + + def set_cursor_position(self, position=None, on_stderr=False): + if position is None: + # I'm not currently tracking the position, so there is no default. + # position = self.get_position() + return + handle = win32.STDOUT + if on_stderr: + handle = win32.STDERR + win32.SetConsoleCursorPosition(handle, position) + + def cursor_adjust(self, x, y, on_stderr=False): + handle = win32.STDOUT + if on_stderr: + handle = win32.STDERR + position = self.get_position(handle) + adjusted_position = (position.Y + y, position.X + x) + win32.SetConsoleCursorPosition(handle, adjusted_position, adjust=False) + + def erase_screen(self, mode=0, on_stderr=False): + # 0 should clear from the cursor to the end of the screen. + # 1 should clear from the cursor to the beginning of the screen. + # 2 should clear the entire screen, and move cursor to (1,1) + handle = win32.STDOUT + if on_stderr: + handle = win32.STDERR + csbi = win32.GetConsoleScreenBufferInfo(handle) + # get the number of character cells in the current buffer + cells_in_screen = csbi.dwSize.X * csbi.dwSize.Y + # get number of character cells before current cursor position + cells_before_cursor = csbi.dwSize.X * csbi.dwCursorPosition.Y + csbi.dwCursorPosition.X + if mode == 0: + from_coord = csbi.dwCursorPosition + cells_to_erase = cells_in_screen - cells_before_cursor + elif mode == 1: + from_coord = win32.COORD(0, 0) + cells_to_erase = cells_before_cursor + elif mode == 2: + from_coord = win32.COORD(0, 0) + cells_to_erase = cells_in_screen + else: + # invalid mode + return + # fill the entire screen with blanks + win32.FillConsoleOutputCharacter(handle, ' ', cells_to_erase, from_coord) + # now set the buffer's attributes accordingly + win32.FillConsoleOutputAttribute(handle, self.get_attrs(), cells_to_erase, from_coord) + if mode == 2: + # put the cursor where needed + win32.SetConsoleCursorPosition(handle, (1, 1)) + + def erase_line(self, mode=0, on_stderr=False): + # 0 should clear from the cursor to the end of the line. + # 1 should clear from the cursor to the beginning of the line. + # 2 should clear the entire line. + handle = win32.STDOUT + if on_stderr: + handle = win32.STDERR + csbi = win32.GetConsoleScreenBufferInfo(handle) + if mode == 0: + from_coord = csbi.dwCursorPosition + cells_to_erase = csbi.dwSize.X - csbi.dwCursorPosition.X + elif mode == 1: + from_coord = win32.COORD(0, csbi.dwCursorPosition.Y) + cells_to_erase = csbi.dwCursorPosition.X + elif mode == 2: + from_coord = win32.COORD(0, csbi.dwCursorPosition.Y) + cells_to_erase = csbi.dwSize.X + else: + # invalid mode + return + # fill the entire screen with blanks + win32.FillConsoleOutputCharacter(handle, ' ', cells_to_erase, from_coord) + # now set the buffer's attributes accordingly + win32.FillConsoleOutputAttribute(handle, self.get_attrs(), cells_to_erase, from_coord) + + def set_title(self, title): + win32.SetConsoleTitle(title) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__init__.py new file mode 100644 index 0000000..a2d70d4 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__init__.py @@ -0,0 +1,23 @@ +# -*- coding: utf-8 -*- +# +# Copyright (C) 2012-2019 Vinay Sajip. +# Licensed to the Python Software Foundation under a contributor agreement. +# See LICENSE.txt and CONTRIBUTORS.txt. +# +import logging + +__version__ = '0.2.9.post0' + +class DistlibException(Exception): + pass + +try: + from logging import NullHandler +except ImportError: # pragma: no cover + class NullHandler(logging.Handler): + def handle(self, record): pass + def emit(self, record): pass + def createLock(self): self.lock = None + +logger = logging.getLogger(__name__) +logger.addHandler(NullHandler()) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..24a8a6effb5e763cefa6baaa29f66f82bd6c727b GIT binary patch literal 1077 zcmah|&2G~`5T3Oi$8p*c3PL;pLdv0W=%G?1gd#x&h$;sP0(@Dy-fiM`W2b8;Y9ns# zgS5xqc%Hp-;*7+B6EmCsL<Nblb~Ll|yWfmIuC9iF^y}M2^3DPHPRcR`sPyraIWhr) zDTqNhF?$Wd72X*LPdcY=?9N+gttl9LvB%&O<WD`2wZl-qXFwnN`=XBibqNPPMtEN! zcRquJ^STT!Slp0}^H6%HaKRYX*@brS18c%y-t2ZZJH5`ND64KtSIfju>EkI^kV%M{ zfY`C&j%mHh%1UK>+sCP#R9TS^+O7#W&y%s_+=QHu3o%tBuW)`eP1M423EIbOmi<18 zCOVrXm5gSIj`j;Bq%Nc0aWv$;nI6yc&HaP!XmmWEbJg408|g06FpoY&lWek)<z<y9 zwbAWv%}!>|rgUi!pUGSlIueT(BhIrtt2pmWPBabzn)D_T0%r9#GtI$NsW(Y3l+=IW zK(2j?d4lW~2jQGS>@G$Xd!i<M)N7(n@M;=vN`cozG6DJ$Pw62OunU)LV3D|Vj8{sv zZ+tD&LW^6BbRAudKeDZ@qx=&O%-5It?JSJ{ucjLqx=2l%dAEos$657&3~N-PwOoQs zDYbu1B-4}Zb10jDufXl2Y#GGVQ$>2%W}4u>TPsYp#JTUF$3rsPijS5n-Z~80zIMrp zP}4PHtHkaRyHD(9qZSfDW(PpVl8gbP&)&70rml+NFw2Lg$#GS5iQ9{7+PGO|yA;;h zG~bRVg|4=>F0`p%Er@9hWwnDjq_&M2pAt%K!bFHGpMUjag6E5$;steBwx}`3b6T#$ LT5OFyu7&ImTJhyq literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c09074129e12b36f1ec5a3c7356dfa0ef1e6ffc5 GIT binary patch literal 32220 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 a>uhS>w-`5dZ--L(;o-*$h2izX#s3X~ko9x` literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/database.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/database.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f50f86ed23b8031e56e333eb6fb3b73a4ea494dc GIT binary patch literal 42117 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/index.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/index.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0b8a5e54e0569b70ac752d5aa139571efa523731 GIT binary patch literal 17424 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 WBI?wF=duFvr)+xGl10JEw*Ch=B%+D{ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/locators.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/locators.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..09c864211703fc2fee2b2dde7e4cb98113083ecb GIT binary patch literal 38322 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/manifest.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/manifest.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..53af53fe8dff53d54710c15a7c03662a89c8ff2e GIT binary patch literal 10246 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 X;mJ@+e^N36|FS9>a#=i~m8Jg$I*xi{ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/markers.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/markers.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..87a60615db357861f1c9af7c1fcee8d3a3b2d847 GIT binary patch literal 4510 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/metadata.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/metadata.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..55212d23c676b62592d1a88946c51e4657d28ee7 GIT binary patch literal 26657 zcmcJ23v^t^dEVZ;@5KTH!52tT)RN+BNdP1vO4fs-36Y>ki(JtJL`kd1Vu`r`7g+3q zb1x`yv#?!Lc4WJDWT$RZAEf~u#|_g{*Uf3u)>YlaP2<EpCry)_ob={(($|U4Nl(+f z+MrF;@B8Q8eE^V--JXKlxifR;&i(Jq|Nry9X7pTdZzh7jKmYpO@{u2nME)ZSoqrFY za0Wkjj~$7qNHL-;Wml~QyJ%a?N2}3d6xUcawh%AIgStd9A@`ESq+C<Ql!~iFHNB82 zW)^yiJ!ltK$!d0?x7fSTSL|EZRNN$WscQei=Hh0_r>g@CTZ&s2widTaIaA%Xu)Vl_ zVMlR?6>*X)gU-&oR&m$U5!IuzZ$wnq$=rz+??bs)^`YD+<=rT6QvE3ROZk43H>&}Z z2c*15ZBbj*w%KU$0kyrDQ#*=#oz%)cHHf|+lpNo(U+pR$Q1=xNs@=sy>i*(kwWpX@ z4-}86T=A%LMD5)XDGsT9#bIaUPNaCuIks}#IdInkoXj0;<qo%UM_Rcd$?=^J;!P*i zes$oDNO4phREKbVNF7#rbwnLiLuy!!sAKB5I-y3@L+Ye@SUsXXpdM9^smIk5>Xdp? zomL-IXVjQ_N}W~b)VMnT_MYNN^>p!Jb)oo(x>)>x`cUyv^-S?Gb*cEcx?Ft1IR$v1 zl<zFy?WffX>WcdC8&>gy7^kah0^>A+Hqqi4HCY@}&lR6i*NSIx?|HQa_qNErb1FI! z$-mh6=*5M_s<YtKys}rR*K+lloOi>?U3R>(DtqPJOkL-$-1ctZ)?#^jzC7!=xhvyW z+>uOXVrg-)u01zbu2ypk9S<y&QF-{p$nl}viIEdbMu&3cn#zri9M3tgFFLv+FRbQA zGT$ZY<}JT}saBb;E2mVgc#bYt-2y5%FF3A?SC(dUeW5f{sXE`a*xdH}&sAKnTDd;{ z`n0o1!2O<5>6W8iWJ{%d)K5)#x>B3H_^h9GC0FupFFLND_MF!}$)o>trG}R+YR5yD zeYl~^(_ZQN?b5t++t188UP<a)+?A3$eFH<~Z^i(eJbAoyZT#xQ#b*nptK-xBiq1cR zc?LhXABhtwS|CJQSs*+c!yfgwh68-L;<|uyT<f}S>>0~x=jKvHJE}dP6*sqF8Wrxv z{8Xt_D=#>ulAkG+7V2uL%6zs|y17)Y26vLBlB!RaO7|jq8(uHT>dj+|x^k=RImd35 z^|6_HRbjM_J@)#s+0tXT^g^RHIx~0t#*Nn-jZ*coN3P${$MH8?J2rW2v9dT^skt7e zdHDG8M{eD|bz+H?^24ClR9zoaW<HLEcrdbfTW`Y4cXJTHh$1OV%HQ`$Z3{>0Y`r#9 ztxS7ns7{Z0p0lv%<-9t^tgLdt)7La`r#)~p6{o6PpmW*Fm9>+b4m!X<jTAH|rae3+ zx1Du6kmT?Sp=SB}hPp*S&(*XuU7xL08jiYV@Y8%i?z!50t^QiA4R3(Hx!Tggbw|G+ zh=TxWe+P&xf8QXsQ1D{yR=HYH2CVzWIshtHmz*5%uVPxf&!FuD1cy5yV%blHQwNH9 z=IPSK!ue-Q<At-&p1W9h+TYcxx^i{={P@+Y<L5$xT8%GxGsBOrM!`KAnM}_7z1&<) zhxuH-XSF}<eK;6bKUM%`_{p%Cx>7BB;9m=Va$;#=p{#HFJ?9*ET2~CmNIm1+eyy&R zyPCdGUvP#O!D;-&*b<nXUd@{8u(MFERQ=?o%Cu8+o&08<!<Xs3O!hH(5XtI5zzQ8T z9KKU?e)It*2bmmV!V%JWCP$F?nX}b0s2_NW_niYSRO@9m{M^+`e)`$#ZoTSwU|6Xu zx_+yon7e9tgPV`*5q5Hn$#Et_Ooox<w{HZXKFa&=3z46>Tn0D955V-d^JV}9-u7Eo z`&#e~lM%1>0LVFK+9U9*y&=TrUT+AtDQ;>N&9bt(xm7X#I=FGIT+OHS!vy#dCLdt( z5R*rloM1A_<Rp^(egBuA+tClFqWx*+RqT5$41E3SrYnYthB&vH4M#!^KXrR`%Y@@C zEe^N7h=b#&`CT=xOsjpZp+TK4V<I2po1SFyIFl!soI;Y1t`2q}>oB+<I`M`lv5J{F z=j`V#eHxd>K3S(;c8@&yB$C7X4!`v3zE_Us_cae8cL=#d`Drdm;UDv4%4hL&FCl3{ zGMu+{){9IqZzDhGS(1+;zu&{Mh5FchLZ9?(FS^6Di{suIFE$bJ;?2k%>*HAFu)HM- zB;DhB4?1RUG;j0r&}wva<OGxB`2^PM(UT`i=P!<5IyZsBLnlsl6iz<eE<F6mBkjV; z(XgP&^st5}1Gd@0%gM(5flwS6m35$snOH=<%bO7^WyLyvDaq>(;ZD~uQP57{C&Tm< z1`MLH{YGTjnvE>m&B#jRZsc6#m3=SU%hBanGd3GhQ5BnsVvvSzZf)8tRx?UL@#a>F z(kiJ^Dy=fJiRF0H#&dtZ9BoEDdp@aesdzJvr*1XlD^V5aGhS>Zu6po1gm$z_pw-(d zA+6q)R*6=tY^zlgt-hs_(&}5%D%on)+iI0Ut3OaFY4r!vD%EP$*V*bVOYc@0wqvdt zRh#Cck|UIv)-(OBXVU2Tl1fX@m!#)(tJP-H>gFX6J>Id@z`TvVip{v%vJ*%X)NYa5 zrhNU@W`tkw^{8!vTJrU8S@q8~t)}f|@7T*2Qv+T7%Tm{ix?~7({b!`E4|N##pxt+* zZWHR#UVk%j$3mLCW9^9GnhLIIUIAYW@U7zQ+xhlp;w{_FHItI2Buz8*HcQX8Mh+x` zR{DraAcvOvq)H-(*7~%{Ohi-~#Id9C@HsH{X-F=Rv#&d@mkSqu<t##&f;5<ew9UJL z1heEiYGj)98vaF*;co&zcQ=xz1%w&^QUWc3NHJ(%px&D?BW@NZ&kK1#@QgvUb^Rn( z!+A&}e!^td5>HR*M%gWydmrOFQb<TO{MXo5BG@5)jhw31ry;PP9_e_<Pd-<8rts|Z zg@XPdo)lJ~&oDQ}gaoCZLekiF)mf<Dg1ifcky8*iAkQ6eJF8D@Ts^vR^+WAyS$*3* zf%mlUbyj!0SH}n#xnm>$?2<=qs4l{Sn;Xt8trgf@$9tT>Ze1tJ;Z9@d#rjf?QwQ;B zy1uXo{pxzvp+<BJEb$n)Abux;InEFGaR{#qn33`#u|S^#5Pm|-==h0heRkH-eq1@% zmuB@ip*+vzX(kugG+K3PBD+EvATzx@cJ&$PCoF-Rwo7EE?GpKESc+o(*F>g##!nd3 z(*^ebjPy^PC=N++$tiALtV3?W*MvCW784b>bfR=3xQ@zoG$@ajj;}?q-YyjS2wvb$ zA&J<jM9k{9`YhYZ+WpZK@);|;LAn+7;hnx{AJDQ7?NZULmic$kN+k#F4A^|4{j>F} zc*p-Ak)bWI$QmwUi%2XYpoyp^LYs&dvg*r%e~JKc{m<|5`$Od^99BO@jZR<0Z9lab zNVCNO*C^hODus1^(hVhCNQ!L<7jq^OuAjaE3Abb<+_Ffxe%4$|M#9ZN&JDyrz|qPF zcau=ODF6DI>6XaqXH_7wmX>tY@2iI*Yl*s`-@6#dtwB)-!mBB60fj6rmbxo9wTg>k zaqu^{Dj?s8Xy~WHDhx;{7^hpW_IprCL6jgBHw7ARIGn|7*ib>q_tWfD<g#L4*q2fG z^HC#virC4Cg`C9+#bqBaeIoW7p;0EaJ;$v_Ob>zqGUXzI3u=h8$9YG0BE(vvBIIL6 zKM)DGC9603UV3$GxL6);93Osc<dvi6r^)xjKjxG8k)OH*qDfgTvSKNVi|2AA$XhG6 zvK530)WP!C#CkDfZ>OvlZ``<wsnBM@;mqmE^(8R{5%+ShRlFPF0tK57Rk4dRv<iti zMw&oD^z@Q51U+0jg3$<;8r~WPE|wR;0jY(JtXjjXR?fFZ8u0_}@BtUAQ5urnrSXZe z^W%QhUApckwF8u%b}#``_!`0dVz%>bYZ=M563sMxSqT=VaHju);~{HSEEdaxC1|pk zY5cnW$nDSI=Vrk2yR0-HR52BYNi9aX4JN%fWj9<CDx-REO{%Qw#Wkh+)Fxchs$Xr! zHKPV-WGnX2K#6NsZC5*R?Nx(nC$4=k_1&j-qvuWPezgZR{ptag!*#RTtM=hKpdM8F zaoqxw-~n|IEw{onct{;aZW~O5Ff1asoyJA9+Tje&STr)CZYRu#Ff}5#3uZ(Z9Fe<^ zMn|;UO~WIu_tW@@>mC{)aeaVBNL+I?MB=(v1cvi|-z8_ZJbgP<vCCx)&?F?1s#Ld4 z1Xv);nD?qvcAWq{T4upOtZ})tizQHOfLQx-hrxR4!%D;;N99LyTq>u_H9;>iHPyTd zOjRNT3CA&bSg$#Ofzowg(wSYN84;#N*nVobmw#M37|tERVteDrkUY*Tg^F?;XrgD> zlKJ}exg)vR$}RLMs5@M(%;QDZ$w<tLL&lsdyEG$F6AL?7z<Ldl?Fj88<(z_ns`K%% zm9ZQKjY4_PROX1h(yrhql`~Ubs(RD$4m@Q(ir-mcY6A&n*k*J#x&rh5U6A^GMDO;X znNUuxKus&zvrMCkDfAMg@g`KW`Lw<OttHX4D3#Ynnzq!vjJjmgmbzV#^4abd>Qa!{ z(GI!v-3SCqvWsZpyOcv$4{=zBWVA3&GO@uxh^ftaeY(2jVniWI#HZ^^HE6-qT*b!Z zC&4>tnk)8&%v_j>TkI_v5!k6sS77i+1oqY#4Sar@sWkKxON%g0JN{OzBBgL{LfX&A z{g~@iXZ#pp^pn91Q|6VK(x1c!tYsrGt5#|iuT&ZUqPx4$B4TfaP>~4!r6^p;FJm=! zbQ8x&_-vQ%NFlN{Yg<w9Fp_iD9WdrO%-Ja!&wF-3q>+3enS286?pgXXxU7Lte;RfB z2pq>hVl^II1H?u{F--;+{xMHf5;UR~+_Zo|f=XNqIMp)6cA=3x;8L*7K)sHOQ59>G z!1P%>W;pXJ%(bk`T2$_ANgA8kJ<tK`eQRLtY}cjN@Y`C0M(rEO2RQFSm$_%rBM=3* zzh@g@rZxZpUI4V9BwZ>U?toy|S_s<B)-9+UC>f+|3jk0D3?TY%pn^bPtg%ALh)khM zZ!{Qy1kDU2N8cBcR<o|5;4p9n6G$jVghR1xH?qW`ru}5(`ABVdECL%sMvq#cQE1C{ z6FBy9>%~aTenBSGKppjaOW<5!J!ZAkL^Yo#P@&1r&+#)tp0cQ}onm~Ia_FML_>S<a zI7tym;*i%Nfj8EVbE|pR*L6)a$qhU$G6&UlaS-2Wamr0O9Ccd&)?Y$X{WqDc!##c; z?U!z;^e`c#;f9d)z1vuae;sYtfz_J+!+5@FdDN$~P1?dN%2f)euwvhZ5y*?K!~nKM z)Bt1DucN(hmB4>`N@JHU1x72q%<6cx{u=Z*+?braIx1E#{YBi^=v(9?ALA#81OvW9 zm8h|MEedx|=en=p01N62B4fV7?Z?%^*KC~yE2n)R5BBpc?!&*;Q@V6<Vlptt^_9ji zjb9!wOima`HyZFhAcCw_CD92#*dFqJz}vWgEwo*&*MZv_^n(N!n1EF+p|^V?xSAox za6^bS`Cu&qCumt0d@BPkRl?)`R(wlgyhOjk#TR&iW;&{yyw%@z3)LYr*@%R<KtG{z z0zSzalqc=XR9-*V{!XZ$c4Ob#?_B@Lx{qzm4VCQx!}=+ciy;gcCFU;7ks)1Mf0>~7 z!Q&;exmiUw!W_&Z`C1tbOQjFBAr-65deUq)J--gb)_jC3mjZA!3?sGf&~+UB{uPHD z{-``a<Z{b1;#vBh6o<CE1sW3tc`TP?zQt77)jDo~Pb<wVRmCIv90!799*M2v1fA{H z4FXxP(9i%fE%uA~Ar)Z=tj5tm<(Y*3ldH^#C}#vgajCUMPAK94TDaE=I@@saQZS(i z=Y5F)a|R+XV62li!dBlexFIqL5I_E2K=h&e1xTP31Iknj6mZgYMBUxC3m}eNYx$y% z>~YBw{;8s$jbah&!-z(W*!g_qVQ8-8s#XMx7W@g&OOITIyeA@jDB<OV)3`ZC1LTaT zj-UkZ#)xleeLvoD&+=1{9qY8A7V<Ga!H9xs*N@d<QiC8`t-FqX6Agpq&KCp{G0~n` zT!TdV2hmXR`-KhL{aEAr?8cTg1W&27>&v<BwB)R}P=MeEil%MW5D~;b`xF*xSZo*R z0%+0&aQG%fZ;!5n8H_}XqBmR$QIBqc7n(5@g;4&2D5a5R>>PY8xJyw!+Kk<WksMD$ zCD<8(YauRecj20tkLq1PtGH<;Q6I_1(DyX9MgtmYwCqyDf#xDIYoSZrC4KSBC-4*b znJNe@(pW!b-GqF3$NIc|6LWjdTD69-<iueCsycq$U4%e!&-QJ&j5cD!nNxJ$(1d#W zc8HD%xUU*R8%%{L2yK&e`%$ydB{dP#$Pz2ekr4bO*#N>DWO<mFoP6%eB`h8EOz9uN z{d~f(8yH2YEc(#}ch-*!srm_nlN$jpm{ujk6mVeLwEAGsOaYBjplcdAS;opf_+H=9 zC7O~Uv?z+Uo;4H|ZD0)nMUkd}5kgZ~GP`K%;PVn9LEl1)sEjT~6`7wG(9>%|Px`0v z8W58HN4V;L%;aZ~_?b}7uR5V-@K0Eub>}OKrNB<E|0&ydi)s1`sJqimQ~h>h>zV<O z?z=vosMY%TpGN_o3hx`_UC4<ft2-9R>8C(Wkrfbv5Ra`N1>ry!#?KP3+@tWy86vxe zb`;*CD!LK}30Zfe^wR~Nwzp6pgKP8CkVKM-B>0hLY$Zio5DaLsS~e)9Sc2crkZKz3 zzDf_@8*LH=se%aL95rui#^pUf1&?44m|V7Tygea^hZtsvgc!>ZvLfMEVz}VE1m=hl zAw9um{SA)q0VZE%@^_gq_^;6llW49ZQ8FeWQ7UXgqJ1z3Vk{|f8}iiu47b2ZV{`RN zP5%oN)=uKTMBR^dQR47M6ZoE_SjcBYofU_x5re<N*ZeS(Ut&V46j@HBXZ>?121H2Z zL@YM2&FF8l*}q~!l-Q64e*rf>Ls<7C0~!Py&%hoC8Vu4DRRlY0B}kw6HFmz|w`|Df zd(f?W3&{^gW@LGLBLyt9+=1E|vOX2PW9!Gs0>xK6K&B3hjMa<*XUVwt*9MLA4qoIK zFok#Ha_2ORx!Np?#G-ZgUo{J5`4jlO3CC+wbmuZjQm1LFmV?r!%k)4^)lsRZ#Aq}B z8q8=6=A&%Jzo(oV<y#dP)L_mMGuRYOS|i5bGW9s+xA1wm2y^A!)D&bJcWR2Szfo61 zt)B3b+hPo=*0KB|Knsh9ymM-b=9!o9*eiI9W-~aGW@~6NWx5V-jkLNNuevZV2X}*K zIz9+S$f>Er=x@kK2zfRMzP9t*o&lf`C`eoN+93>B*_*zBPv~Zaj3kpr7zkJdYdMCQ z-8Mb*ds<K_U5BeqwZZJd4=#wLwk^bueMp*M*x(R*nwH-4CUji<;H-t73kA}cUII;B z#C=(KL|}y6_%a?h*!_9tgr|~#{TOWwUkgbw0v&vvUC7K_dqw0E;?XO>{+`4fQd^J; zeFa^HWEK}B@e>9?^uOWTta;zMW!^4u5Cr`xBwrx}EJZTeSj@ITQdw&NM3uEgb=|gx zqzp{cQ9cp;k-@h-88^@$89bTNav*QJyC^+^DHmYkKm>{xo3ZcMt|@_F^aXl2z<TYK zgaShs8OgrcV5mlI2r_#TgWu?S)|B|{ttOTTv_lBTvhAf-(q3k+=dOhSfKymr;*hJN z9*r)&B6nF{ANukk&m|z0;R^CR4APCQY-+~wb_89h)J{yT`!)2{kKlu769(A3F_8P$ zYS#hFW(ldtnjY{LE+_+(h2OH=Q}RrP>$rKQb{tP^kta^Io;Zak5Mr|N6KKCp+7~fq zJwc#FWMw<sn;3z)9Zi}bsl{X)`_960qU%)(+qE3<V;xP5h{J0d)6)7Qe#h{W)r4B2 ztR`7b7gy$BEg`DHViu=cX%U$GO_cSoFj*rQa83Dkh{z({9bAJnfUAwg9dey4gM0CK zVbyxV`0n=~I^Z69Jjay$rB+9b1w$Njheg<t8~Mh_`c~zjU1*{2Y%fb~e$Xg!U%~tQ zOa-C4h>NXFJARBZs{ZHvGRi6X9VS1{gahPfEADuW+*h5iYd=YMK6Dg6`TW?`0-_;x zFI#?+EjQC(aqi;TvB~i;?5Q7mmcWmQ3~(&ik&<BBHFnS+#!OCxjR#weVIKlWbmhW; z0gvpaux;41-EZ){eqZUi!bJpVhSKlfBUqn660n7~?bpwSo>saqj7@!`d8PdPvz*s! z$UvXP`kQ^%hWxwTPSBz*`IH^A;ldZGI0d_V4C}KE3E%#!RBS6)Ny3!gP2gU;6pJzh zAY(TM)?>;#-a`Iz7C-kpNIH27sM>=5bp$-co=@q6xQFH2&<SmR9%J6luodky)Yqhz zLgAM>Yr&gR`c+!iz(cUegC~rDCs-1?Mez}#O0==xoH2PZr9fBP8JQ8+3+tul6ng&I zcF!KThnE45`q^f5rH7mitpaF7Pu}+QMg&_BN-*&(q>y~pATB2pLFAV&PD~K*egZ}P zdrSmZe~!5iGa-WOUt`ij=Pn%h7;jNq^P?KBnkevdElGb7cmI%6PxYUsj0`565gF~2 zrcIWC2+=_+2JuU#)LJ*CP|&(oS4v%6E~5Ckt4KJd)CXqq&ju4;#ugV$!FI~$2#HE+ zFhAIpF?^VU?O21afaOP^AYb9Kft47OupR2N2UacSH%jj9rzbm}o-|8>sMjB(+C2jU zu!pzI;mJ=KIS{dakOLE5qM4Ynz2uvbxfHHxTr)HF43Xmu<hkT>s+mN7bU6+9dzxvL zhDMQTW>gvr%R9|fGjqps-@(LNh-ynW@vL#w+<fQe*TXmGdm8g+Z#dKQG(b_@Yl$;p zebkz(m2%A+q2xv`43{SA#b71u9t;A`)XGdttf|#=1&}nwplc>zU8J}mLPCLwli5lj zMC1NoXTthz3-lkY+Cw=sKg8yTndF$9L9%WoA$e}W&t<zNqbm0-Q$hj((&&x_6_!UV zs8~X2!a!h~7>Nq{SJ7Tj{rn_e_3v3C>qTBn31mrdsFAaFh)vrd#swU;%_Q9iv81(3 z?sWb&9$Ld#z<a0X+l$bKy%ZXQ&+9s3_(Teq{WE5rLBK=Ss69epqUUTPTrJ+Of0M=E zV)ENeeuv5LG9fADd&CL>uc*u-{F!D~h@T1;1K7Dlmirc;_%BReLV}PTv$|IuZFD6W z7+HS*GaHE@8JAB>a|9kmWh9!4W<ZUgOGt5K&4xzd1O*GvCcu!b7+ANYf0>QbHQEoB zzD|>uZo4R#?1XZIFymiFCZt>i(WF8KOL1ynpzT;-%+Q{}qT#lHi5#LB1f$p~>gr;R zhOx`mUr@1SP#T_ls`cFU)^nF&1&D*vU+;SUl8NjvbrcqZelOJ?4SG(Y=kKWWa#Cot z4beNTp1<1F<5#&f<TH(L1OYXHVMVkgQKH&f)_MBB#aiqlzyRB)uFLimEW;kuASnHa z8x&ezs&SjnbX_~c;z625oCV1Eb`Zcojg2A*Ev3+cZromk1UI};c^$n-)5Db!XC&7O z{_1Sp+Vg;2SnP*?`CbrC36mnEiu@Gwq<7>QhGycQY<->i{ifbwo<xo|Gt85Qk)LHg zZ}M}@A2Io9<`0;>V*a4XmzjT1@_tV{&dilKEA&_8eQt7S^O1ZC^>tP~BG2iY%uA>i zbZ6#?&1h3&{$Z0}VE!SKzs3AXlfS|I36rldKgxtH*0HNNDktz0rRROjDEb%C2(PEu z>sw1}S4axI*GY3E2oZYoYdDSvTQ=11R)}qf+`ETeN71>5jO+zL-evwc@7Q{Yd9J<4 zf13GEFrPBEOk=7GSV*xah>d`w?6@DJ<;m!rZ{vy1o1>kD6Kg)lPZ($)<`;2JBMAt0 z{W0(cm^#5nVj1Bj$nRn)Zt5FrwL{ZO7t`P}-(nh^QjjR5G1;fEUvW8Y$3D}O2G{sa zTvaR{p~LC}kP}XcGdv$R0T&XG3@-qOr@fuR#O#qZh7N*k5TPQ0MuvR~=afV^XMb6# zFpg1LE%Ng-=mYAwuuUu^53HHiwa;`R7(}M_$M&P(byzv?K>X8hp%Rn&>$n&j+UJ?; z2251?A0RCFF<@k^<AP?JuJ^JXf22=$5Q*W;7~BlCx@(ZGZl>sY6*~o1)o0KKV0;D_ zgD%|=aIYfGFs0H*2nOd*EEF4r&q%8-U^obzb^e6P+U7Ni1vI8{DBySRdW`V%MO*k- zr&jtV&|qh$Rw~1FFVIL|MswXBL{6+Gao!05-;g+Eg?Be3&OhnyP`Z|0e;zkJ&Rz*A zW@Rn%n?Ad~>HlFU$fsl|IGw_$`Z<+mFlOuyCEZ}ppP|`C<M7F@aX7pNn;8!BeGbDF zyyz1h!?4x^AYHB-g%%6oP%^}Ij*3uZ4tBJ;=uA`sS`ogKId#B=_=*2c!wHx!m1Hp~ zmGowQ-V_sA%i0s(CTHL*Vo-szZxXr$+7f4D@2+#hhVAmP0ya5(4DIsP`S3r4DoK8y zdF24^YR-cuO6nhCA{_aLnfqHz{x*{zW%75Je2K|VFcB5}?=$x`CjWrR*O~kvlQ)@s zfypm0`4p2MVe<P-zR2VcnfwuxKW0Lr)ql!_s3<l+{Xdv%6K`uY^ha?c0sM2%AOmHs z2Rz{2On(aEq5MmxVyQ$bj$coP*H|i*+L1|Rc4l^`hO+l(hB8m2deAb)*3w&}XYn?p zj7R3&dacnL>MByihSBlKv2$aSV`M>He|;#O!O#5ypy`a%b+}Iox?3?Jxu_GHgO8?| za?-_&)Ij4yG;SP`xCy6sJ0ozDW+&F$QN-Y85P#cK-0Z+;H)A^~1uf0VNZP|xW#5h= zBDWXOxaTCo7ty%RHZ^dE5x9NMjv2c+i0e*VcVS~a%4#c9XOREYwpM<ZvrBE4`#Ts3 z{C02gzLy4H+NE}>`w(@z8}Yik)%}RqMNF`I05yA@2UJe&eFIFcm_r^14M={kvv+PE zjvEL{>U<C*{2<yeMwspQBhM&d<_|ar(Eeyx;(-L{{U8q|!1WLhCcyPD4=2Di-*G^} zcJ<iX2^^MyV+wHRsCt?Q6#&8^9#(*wVMHaL#dSpWfel~KyD&SA?}#Kh*{OtfMF{66 zZ$SC1bRRhYS=W`L0S<p?;#v5HD2Rr5k$Vm1E+-f6HxVtC=De_C2!?*_`z|li717O> zq@U0}hkh!s_1{2@ID$_^w8r{3Y;?5N%NV9!_KY~(=zaBNb@cGdBS`Z{_BZyv`Vu1W z5sLrH;UH5Q8GhwRSegIe{ziJ_2Tlx)9zXekW!d1=$P&?UNI~u}bU&dlm_id(38997 zF@+H`jOaSY?j{XsVW>TPFS6kx7wqfEb!_X%nT;F4#q7|?;cH~4M=snF(joMB$kOn9 zm~F<~AklbDwvD<uy;KWD7>o_~c7=htx$8@nYD>Ox0miNNy>Qcn%vQU)bCU(&H-|)& zoZ77l^kNZ_f<Ub`BS3#d$&8L4FNqNPNeql(u3Zt)NmQrtJBy!t92^1uwD*jNmMCaj zQu@{y5gnBn=SE{YBpmU$(E|hh4>8k-s62v*$^;@RZ&~1W@GvK-86s!}t4s;Ml@#qv zCcd)v(~2P%mi{u#bl6yN$Nr%{YN9I{1PI3Ig8y*jDneS|F}C&BU_+96gl0rwEc`{R zT0Qt>Rs3!C9jz&^w;A`aW6}NXW_)Fn!XD4%cw>*(zk*$cjEF4JzfFA@5D{iTdmPXX z%xB<4I1<9^ZJ`YdFef*HSz_l>1^w4Bc>3c=Ai{l)c@DM@)eb@tRX{&I>tHi@*{hr2 z8Z`TC*et(Q-(mg@CN#h4{}tYX0UK0R!Sp#WSDT1yN*}`g{Zx3*L=$ig^ZP@tAKIt= z^wZ;o@vCE#&t5eqNY1sNKqwEwdEl4E%E5rjvU2^*HEu|g5LQjB$R~|B`q%kJ0k`#O z`oFOkYo=qN6N!wg@jG1X&mhwg^$ppbL9Or(<6l1<SyW_bn}#VQiqc<Y;xtyW&4AUP zMC*4`c4PD9;2@M%R5&(yPoZN&>2u5}CZu_zZ#===lT3z?V3>z-Dd3uuYp<W}q))%E zn<TLftAi$sy<Oz%%L3aXO+R4>9=0PnIRxWJrsLvd7uax<IGTm$x%eqq4Hv*EUHxAH zK{4ajm-Mtljv<KArI}IDX^CYofE2moh}szpnRbxpt|Qpgn}}`#nj+4LqIh7af$*kZ z1*(!Dt^|Z}K}BkGf=8AUARM%SMIOsIO5X@t%(Yr1L3UA?ci%+27%lfrhG-;eZ+Q_s zpK8JgYwpl;4l`>S5M=NScdmb<nO=!vQ?+^G3Tl(6{avZWmT0!tzs*vs*CDxwP0hUL z{?DN2pe#Liv~DJvsreLYC!0w?gdhM$dZ9dO#syvmLb{J%h+1sTkT0e0!F;!T4@*t@ z=`saaMKCcq;D)N3FFHH+0J3l|uKO|e8YeQrp2(z+38&A`w6?jq(r9&)*<Cl%HOs4g zK`nOW;KU2JRSu8>QOyYx4+fu87-Y(wVmN-rZ~zfD$p#SJ(NYN+f=7_K(U{J1->%O4 z@r5!rA9Hi7i%3J`MM$~WQ-d(us&A>a6uJ}NLPgL$hbzT#QYHOBh~cpN>;V`h`=be= zPu6iWDBTQwa5<1>6Vg5*l*||pILUW*P$^ssG@AzBGEHO-|Hx5V$bA6?Orb=n>vOzz zpmB6DhZ+le!IQWbGyViloO{lLCjzUJY`6;pdl7hT+>a9efKUc=z)FYBn1+1uUt*EP zi4WdwXfm58UMx(Gy->O~cIhId<Y%u=7@m#sgj-PW1b`v`6NOd`y~5R#2<w85T_ZBc z&K$S~eQROOK*K{AvS((NoTD6csw@&mkAdZYigWH=``yN1dl0)H>vF!O@HEv>S*x)` ziB*B5!1asq-2t<R26-|IiI0KB_nVBA5mpfwGLGtN0R#Au7sH->Jd2euekxL%3E04# z)L}(N-BsMBJ3dz7R!A}m68)#qBB>I%KN=AHPd1Zil?qznt~|X}YSU|KZvb+#o8JJm zNf?^=9Z~G1BJ;?Iqdn!N;7Uy2AxR@AD?YqSD8*3ffm{%T84z~V?hd|!5NF!Z%PQSd z&^T8uq6e64VS;1TB8JqrF-HQ|+nK}pYGz@9li?uqgG@*{LY@AWLfvZ}_2rnueq_=1 zGjOa2!TF3IM~UPBs{S>0&gs+tj>$Vn0_$N%K*}z@;XWq2nfw@A=9p`%ld{U@QTH&> z=@eQR8a6wsNU@~Sl%17r+;kFxzCoqT^@E1l4%CYknC^&1>)ax&uq|NU+f>kx*C7xq zFcc^WUdOhpNeJK{A+S?S-qRe=&-Jl$XX(rQ21pB#6gs%b+E!iQ;E6UDIgbK>!JIOs z5p&t9AryK}b~?-wQ?a0-%pXEr;FARQH0h##3cfI$96}E!x1+%DV2-Hq&?UEQiJAc? zZCf7W4ycX~{4g2@hE2T(w|vW8J5B6sil0b@I|3Jd7LNIT3_PO0+oDY<_;*PH929=) zS^V4_5`G{)Q&=W9yaBzLm+0qU14sJ<Anvr`{wX}Y5oGg(EP<N_vMydtL4?REulJFW z*JI-j;x)fRmpmdx?ZrVF!R8P+gi)n`SS`oFoyoONV{eJMMzQ=p8q{7=EcHPe2N#C~ zZqFyk)q|5-Fc<U=>09vrLQ6oeytg0xpJCXD@Z((F+^^zz(|Mdi0)YVY3DJT5=+A*4 zB${$U3Sdg&4N2ZNI3Rt%YfKIUeI@l-bCS&G7$lHSmp_B)69t#b@>6sQL5W599eqbw z(4eRB5DBx7awrG@EK6t)^l>8uwjReL2m-6PGYHqiA$^E=GiP3utGN!P&Fp)9J<yK% z+Q%2my1YQwuZQh|V^CRfmI=Cdanyi^6aL)c*Wh@DC#nmW)@#{C`wwf}4QlaWTl9p; zJ06k*%^py7K+<+s1rV5KoglP60Mf@Ib_R2o@O1|PGvcU*g4-Fk7xq%Sg)ZLX<6#*< zxFF9=$vIpa<*>vyAbwn6@OwJIoD^pal-jrm?0yt-x*wx>-iSSp4VI0b18z$)2l{78 zkx_JzPa9Im0*R&8*zt(qBEa)>kgL2$VaxBwbcfv-<=Ti}eq1KTbTCRrK#~{U>?d&| zNp%UH#mnr5vVw0pYYFZoo0H&1aX*sAPFQeYvVwjav9kE}Az*_70e`ILzf5!h{MvpO zQ8{fHYb}Ib+!1dPuY=GnWeuTQZVo}jtc1ECx+08>B#Xd_CUP94u@o4^^Yf@*1HYf4 z=M0B#;oP^kJNX9OF<V-aOS{cFpzw@gCUmqJX5wLEWvve}gaLcL1JGIy5$Jis!47fU zdI*rr&!%(ZSH=tHaPHlUrDw)poaivGx9qIc;o9{2<xXf5cB6Fy;z(z!_vXF3yWtHr zD6p^2Fw<BEv;@@HjyK}GPvC>@b;Hyp;ZZv$Q$CBIOL3DCfWj@o?BRFc?%8)DALp4_ zvaYSfBoaFGr$fR6_uUUJNA9~Hu`UviPrliV>g$TpIoReR(K!j&VsK^?BtI+YWqS}s z!`<rOo<<tG3H8vdkF;Ync3n1s5^bZRco!I<qW=>bfZjxR!SFzALWSRVd8{A;b}(i1 zR+zA;Ut(?(6AD>)QZ${mjo}Y?iv*?jv$t<C_ivf}3X?T5(YvVoItP|7jev%z!$6zC zKe!x3kHPMcT`gp7OXq=Mr3+`#QCrY{3I)O05vC@D21CW@Ps`l{W7KI6S~a&*1_CVi zjz|a-+9xQQ2P^bs<H7L#kB8@wa^!|`VblprP&)+o#n&)_cWbV|njdHglxPu(9x_JX z<*ha20kc}<n;Z|yY!QqGxr)U8y_<-3h##T0(e?RV;>Te;FP|?`mic_dXmt=S-CzOn zQYi_E_m2oxn|L!9LAfso-GW2QTniUn12~`hHUXyqLcl3CH8zC<HxhWX@t)Qnxp_;q z`~?&QT-n&I`#l>d9`G1ty^VR}UE}Cj20=iaIKoIo5hF$*9&oeD1r>*=1LG#tCx{I6 zdrP1Uj(LE3lMu0jVo7qAQPdvD5hbWCDR{=y6kOP=kQ0R&3Mg-&pX5$h`4D_2xr#N5 zVUu3p07O)&dQL?Uv;*Y{Vhx4TY(f7ezGf0~=oGFUR<G+UPBWQrC8EC^M9~kF7aPM| z=j{|H#ny|=r;#_24HQqIg9xq(ckLT<v89h}-q-+zhJn3-$4ls19tvy{oV{YSx}bzA zeY-aA+w-r9Q_Q#P^Co`f24A{niXX*;zsxBf!A;OA?SX%lz}Ye;G>U5@51`^&2z>_H zOFwLdMqTb;;9V=%UcP1@lOs&_GdY0d{f3SM)`j-OxE3D0jY4=tq2LpOq~<J~<OqE7 zqOgaN01O+3h$?J&H)fpMPJlO<ao`d+rjQvU#A*a{4Q_y6atEAAz!8>H_@$)`1$Zu_ zKjzVhjX*`jrbn@_v4<=gc?4-8kHhtlM{iB6l{gu49q{}BatxOyTQS<<B|ya{^&UgH zj0r=I(l$_=A+tnXw7CY5V($576hB%L<V?hyBZvlrG_J4VR7LoNk&o#`Na<C`-#~5A zsgfWRwxZSr$s49R)ZdjQ^5)1*C@KIJHu7O&63;m>=yw{qMz4r^xhJ2@?K|M^YxK~$ zBO)r6lV8O*z_}qFSmK@^MWlypY09TyUqzHX&Nb0Io<M(qiS$q5tQgl4K>iQ$kdex| z@z2LuR&^L@UHDO?lRqOa5_!mOOxUcEz_{f?aF8nq@`F}msKtm%UOn)zw4)Z*bZjiq zj}VS0kieWE(t(g1H~AYoe&40>r^g`CTpqh}g>l4J*q$`2dzc8tW|$MHHsQjqjDvnm z?2#Vl4MT}FP~sUDpF&c!^$Gk&*U%nLx^98}r~GURI5>=O8yC!kESS_$St1F-M9`M+ z+E1RJ>~bLy?I^gM#n1f~65zHyYeR5>(uP=W?3@jc)WOOqyC{KDQ^547KFM@BUIQgi z3=szqY}a$(rp8eO;pLksCqPHyID&!bRe5p|PbBd~qDHEsZQ9mvdFi<f5D*lDV?uG@ z)Mw*7oX6`~f$~aM_1)+X?OIL-t&*Ls+72dJt<wdG_ip6JU&lG-)!R^^<h&&A=@bkN zw$90(2***F5li;aO^P!Js!A5;p)Dacw(L$<Dt@9u6%t4HaQei~tp7DeO16gPdyNN( z(E*wZw_(Z`nEL`7aZS_Yng)LmxQp#dYH4Ayy_qz`2U5Oq*8Bx?-$qhQ8}Ysb{K&DB zB$IBMkoW8a^K;2RBZ1_^1OLdAp_ACqRA4tUmSK2jqS$)?-K5diq6f3l)aK*CUjo+_ zKm9Zcm?xOsn3`irFgG|#f|hy(krw6}xE9Hvz>an=W4mcH1~K*sOgM4{lZgTwF5EmK zPREp<!Rc#O#S)f=`G#PN)e48NAxDD&4kQH@-LakmRv~ztZamaug{DB8C>RnGh9s=R z1%MhOL%Xj~=pVB}2$r@V&LEdZ!;qdvO&G)f-`S4zit{F`ua)6Wh?BA0F2*!$YHJ6Y zy*|W&-h~VqP9K#&upJ)tLH0wl`qoaf`uhgBfri_XD(8-)yO>hk>xK1daX@iYsVvyW z3`W|ViAi`*tk6gwMu<8sZuv$AxnS=~V^b^YM+{-7yZml{j<=Xt9I6DNBs#^~i%iyF z76W3=@q@(-hIO2_$QblgU{Bi&wowQW{B{NGm@X6$kA7^U=pT4kaYi}q64=LD99--B z1V^1bdtv;lZ(S^A3uBkZ!wOAMikrg!=RnY`xM||K%Q(Q3oLHXIA^{PLwTMBdFvt2y zCXX}O%PB`hlv}NPI4H-2BFS<khUQ=AJJLK$&1@NpQ9lkUm^GGYu_}v^nO0pnh*4Y= z`Y2yPaSK7}4jm3!j0lghnp&h$2!vaRpe^j-Ja4r5hG6h}1|$&yzW{o5sd8aT5*avv zV1~di6~(3@%l^wmA{L9qgM+*NcOn_H@xpgA!y>4`O~lxB{tK@`?oSf^=;LT6lRAX` zi|8wpfoUU=If7gqzXVIEzEnDuOzkl}NV=Lxrw(Lxr8YC<Yg_`n_`hbDS;AR}^o^0Z z2+IS7;attCIe>udQ2z#RU15%bg{GH8bLPZp2Bs|@ZDWDwQl&33$*@5TCp1=#o|0vy z;BYT<#1eY$y-RXptieFh$V6-1!8TMk#ao1U3m$s_DDPtx*H!&tf^v_!pJZ~5$vBg1 zOwKcTp2-C!FEV+W$qP&bkye=d6p~_U{DsM@WBA`=m>|_xdE?7Wev`>>G5H-PKhEUm zn0$rF?=cbg#qTrs15CtJ|54<Mn_Cpaqa#Tn#U0OI7$3h>T7P3Olv0AQGHiS^k4Usq z2hj`pZ%6lj>XdPfpXNlkUq^xiB(a>(34woDLbwGD(uSRh_9M8N|1wcvoa}Fk#bb$B zG?qd+6H6dWfD2Ig4^IGpE_C2dfQjF8&3{PjrErIT@fa{3y`#@eZ~sRl{0Dr+zv%w~ D95Atr literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/resources.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/resources.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9f9cdd5997f80c603ccb5d36623afec3dea70605 GIT binary patch literal 11021 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 J_RlWZ{|{{wl>h($ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/scripts.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/scripts.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e9f951958921f751f14b57b6f4877cc78ba898d4 GIT binary patch literal 10803 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/util.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/util.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..22edac92a8ce7dda0ec4812755954d5e44a70158 GIT binary patch literal 48154 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 ak^IOo=^Z0?6#9pUhVL3)H~gOAvHu5wJ#$n5 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/version.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/version.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d1562c0dbda037139966841f159e456f484b7f52 GIT binary patch literal 20380 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 ZvuC7l#2PsY!3%9bEy(x(wlf3f{{`sM{TcuO literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/wheel.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/__pycache__/wheel.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7c456f9efd597b57f7026fef699752bf8ec87a95 GIT binary patch literal 25567 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 XWhcVfCt~63r$W7dn-ZsEwjKUIJJ$6) literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__init__.py new file mode 100644 index 0000000..f7dbf4c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__init__.py @@ -0,0 +1,6 @@ +"""Modules copied from Python 3 standard libraries, for internal use only. + +Individual classes and functions are found in d2._backport.misc. Intended +usage is to always import things missing from 3.1 from that module: the +built-in/stdlib objects will be used if found. +""" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..32c1293e801003dd99df9d222bf3d286543c41e1 GIT binary patch literal 496 zcmYjOu};J=49&5CidgspuSn1wAR!$>h?N0^1S~93+N4)QnpAOG=<zj-Y<$nHd;$^! z6Yiaau;j>ov7Psv`<<Okuzi2L>D`GCpJVdh7!w!lw8e)J55i1t#omVA=8LOfI%f&W z(4sX^#n8abkm}&!7$|9PbTr_wh&rOBeW*eN^vOoA9du+NcsJx(cIgfFXgWqqr-^tb zH$&C=GGXwXMa#_{W9Y#g<*Lx-QyXH+8>BJ^xa6tcSd(?6=N6D41<>wU4+PkZm5^%m za{_K44%Tds^TTzJYMr22={e;}n-v|pbbww`GOPeX@o39L@QltuVMq2%rdqSgv+KRd za#JZ2N~PXK+~8%cj-OZAM(lO6ve!{o!5JG#&R*nP&HC6Z{89Bdt?QS?Lb=&VQO7CU z+{-)JV$1LI8l5|sPEY!wKkP<u<*H}7AxeXkn4bJwh*SzaCZ+OrSZ<xIC7qAI_{A=M E0k&qJasU7T literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__pycache__/misc.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__pycache__/misc.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d9a93fc4361a9851fc13120fffc09adcef2ec5a6 GIT binary patch literal 1107 zcmZV+O=}ZDbl&W4ve~4e1wRfISp>y^?M4rULJ_ri5F{5X>Ry)3&LrJ-znGcCBt#Fk zKcu|~f(QSH|6s13`~x1m=$mbdqHlR`-{-u~muqVtLHP0IJpO7C^34c;gNwo=MEMyB zBOzhHXa*tFe;QI|F`GGKE3_8tsB2_)?t~7ISERUU6W%!X#B(6#V;$x)>l8xg4Jqhr zvT%7bY@**?^mEbg{mKtmD{JLm=wXb<>{AjpR}mhEqjuQFm>U?=!I+P$m^O3JuYKXi z=nK+YTLe$y<hUw@lK!X^ep;|}nzBip`AHT_$)z6`%pXmPM5SdRx4&bHWS}>aI636e zNR)Xb%ZW(1c9S^E;$eo|Nb({n8SjCh=zfqGdI>l|V&r{9c?HQ5gv+4v7=1^VWJ#|R ztjro{NHmn6kPVyFJQ}6=vcvdrGS(KKDbd8xn*4klR3e?miU-qJ1fw!zT*zQ|7L23a zsmK?_gV9m{@Nl+RMA`1n@KE#-#zk-tRB5%97E)p5TmAmdbUwX5G0GaFDKA(l0+vdZ zrNbZ^u0|E)sZ6%3dEMNGX~RZBpaVV7?*3{F2^i%H3~w5*n>N>^$dV{HF-w3!k7_TK zbs<H<MH}t-l2s0m{&Xo!lrV2>BFcKA@Lvv7NS$L3nadoayTp;!5<Q{f&XSy2%06?> z$vL3D!9X>a<OGh~Ye+u;GYg=D#U`IsJW>8|uJ8`<I;0Z!{GwF;ZP{yy4yMpfZPXT; zbmL;{D9ok4I_Apk40*-#+L9Jy-8z_8{HYM7(6&NWyHQlcIgcVUI}>1}f7>=~-9nUI zBm_LL5xdj|_g4=NdTY8FMXXGsNYhdZvl64hMWDt?^QzvIZa>S-rPtZ(N$S=BlU-EP zPRcC9Zq1d~8xSU`?mkvZq{E52aQmyU`u@yPw7Zv=Y?ASZ4V0vh#HKE|)Uzn8Ll@Q^ O3NHRTv};pSIQ#|{5euCF literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__pycache__/shutil.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__pycache__/shutil.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..da511eb8986adf2ff58488be7554f21995384f49 GIT binary patch literal 21500 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 O{jVH=5|AqE<o`F;sUCy? literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__pycache__/sysconfig.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__pycache__/sysconfig.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7fd6b8ab82f31be2d092741512c5f7c18daa201e GIT binary patch literal 15899 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 G&i?_aoV8~F literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__pycache__/tarfile.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/__pycache__/tarfile.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..bd53d1ca799857930ffb1a39dd3a7084cb3b6835 GIT binary patch literal 62756 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 KZV6Tt^Zy6%X^Zgy literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/misc.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/misc.py new file mode 100644 index 0000000..cfb318d --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/misc.py @@ -0,0 +1,41 @@ +# -*- coding: utf-8 -*- +# +# Copyright (C) 2012 The Python Software Foundation. +# See LICENSE.txt and CONTRIBUTORS.txt. +# +"""Backports for individual classes and functions.""" + +import os +import sys + +__all__ = ['cache_from_source', 'callable', 'fsencode'] + + +try: + from imp import cache_from_source +except ImportError: + def cache_from_source(py_file, debug=__debug__): + ext = debug and 'c' or 'o' + return py_file + ext + + +try: + callable = callable +except NameError: + from collections import Callable + + def callable(obj): + return isinstance(obj, Callable) + + +try: + fsencode = os.fsencode +except AttributeError: + def fsencode(filename): + if isinstance(filename, bytes): + return filename + elif isinstance(filename, str): + return filename.encode(sys.getfilesystemencoding()) + else: + raise TypeError("expect bytes or str, not %s" % + type(filename).__name__) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/shutil.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/shutil.py new file mode 100644 index 0000000..159e49e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/shutil.py @@ -0,0 +1,761 @@ +# -*- coding: utf-8 -*- +# +# Copyright (C) 2012 The Python Software Foundation. +# See LICENSE.txt and CONTRIBUTORS.txt. +# +"""Utility functions for copying and archiving files and directory trees. + +XXX The functions here don't copy the resource fork or other metadata on Mac. + +""" + +import os +import sys +import stat +from os.path import abspath +import fnmatch +import collections +import errno +from . import tarfile + +try: + import bz2 + _BZ2_SUPPORTED = True +except ImportError: + _BZ2_SUPPORTED = False + +try: + from pwd import getpwnam +except ImportError: + getpwnam = None + +try: + from grp import getgrnam +except ImportError: + getgrnam = None + +__all__ = ["copyfileobj", "copyfile", "copymode", "copystat", "copy", "copy2", + "copytree", "move", "rmtree", "Error", "SpecialFileError", + "ExecError", "make_archive", "get_archive_formats", + "register_archive_format", "unregister_archive_format", + "get_unpack_formats", "register_unpack_format", + "unregister_unpack_format", "unpack_archive", "ignore_patterns"] + +class Error(EnvironmentError): + pass + +class SpecialFileError(EnvironmentError): + """Raised when trying to do a kind of operation (e.g. copying) which is + not supported on a special file (e.g. a named pipe)""" + +class ExecError(EnvironmentError): + """Raised when a command could not be executed""" + +class ReadError(EnvironmentError): + """Raised when an archive cannot be read""" + +class RegistryError(Exception): + """Raised when a registry operation with the archiving + and unpacking registries fails""" + + +try: + WindowsError +except NameError: + WindowsError = None + +def copyfileobj(fsrc, fdst, length=16*1024): + """copy data from file-like object fsrc to file-like object fdst""" + while 1: + buf = fsrc.read(length) + if not buf: + break + fdst.write(buf) + +def _samefile(src, dst): + # Macintosh, Unix. + if hasattr(os.path, 'samefile'): + try: + return os.path.samefile(src, dst) + except OSError: + return False + + # All other platforms: check for same pathname. + return (os.path.normcase(os.path.abspath(src)) == + os.path.normcase(os.path.abspath(dst))) + +def copyfile(src, dst): + """Copy data from src to dst""" + if _samefile(src, dst): + raise Error("`%s` and `%s` are the same file" % (src, dst)) + + for fn in [src, dst]: + try: + st = os.stat(fn) + except OSError: + # File most likely does not exist + pass + else: + # XXX What about other special files? (sockets, devices...) + if stat.S_ISFIFO(st.st_mode): + raise SpecialFileError("`%s` is a named pipe" % fn) + + with open(src, 'rb') as fsrc: + with open(dst, 'wb') as fdst: + copyfileobj(fsrc, fdst) + +def copymode(src, dst): + """Copy mode bits from src to dst""" + if hasattr(os, 'chmod'): + st = os.stat(src) + mode = stat.S_IMODE(st.st_mode) + os.chmod(dst, mode) + +def copystat(src, dst): + """Copy all stat info (mode bits, atime, mtime, flags) from src to dst""" + st = os.stat(src) + mode = stat.S_IMODE(st.st_mode) + if hasattr(os, 'utime'): + os.utime(dst, (st.st_atime, st.st_mtime)) + if hasattr(os, 'chmod'): + os.chmod(dst, mode) + if hasattr(os, 'chflags') and hasattr(st, 'st_flags'): + try: + os.chflags(dst, st.st_flags) + except OSError as why: + if (not hasattr(errno, 'EOPNOTSUPP') or + why.errno != errno.EOPNOTSUPP): + raise + +def copy(src, dst): + """Copy data and mode bits ("cp src dst"). + + The destination may be a directory. + + """ + if os.path.isdir(dst): + dst = os.path.join(dst, os.path.basename(src)) + copyfile(src, dst) + copymode(src, dst) + +def copy2(src, dst): + """Copy data and all stat info ("cp -p src dst"). + + The destination may be a directory. + + """ + if os.path.isdir(dst): + dst = os.path.join(dst, os.path.basename(src)) + copyfile(src, dst) + copystat(src, dst) + +def ignore_patterns(*patterns): + """Function that can be used as copytree() ignore parameter. + + Patterns is a sequence of glob-style patterns + that are used to exclude files""" + def _ignore_patterns(path, names): + ignored_names = [] + for pattern in patterns: + ignored_names.extend(fnmatch.filter(names, pattern)) + return set(ignored_names) + return _ignore_patterns + +def copytree(src, dst, symlinks=False, ignore=None, copy_function=copy2, + ignore_dangling_symlinks=False): + """Recursively copy a directory tree. + + The destination directory must not already exist. + If exception(s) occur, an Error is raised with a list of reasons. + + If the optional symlinks flag is true, symbolic links in the + source tree result in symbolic links in the destination tree; if + it is false, the contents of the files pointed to by symbolic + links are copied. If the file pointed by the symlink doesn't + exist, an exception will be added in the list of errors raised in + an Error exception at the end of the copy process. + + You can set the optional ignore_dangling_symlinks flag to true if you + want to silence this exception. Notice that this has no effect on + platforms that don't support os.symlink. + + The optional ignore argument is a callable. If given, it + is called with the `src` parameter, which is the directory + being visited by copytree(), and `names` which is the list of + `src` contents, as returned by os.listdir(): + + callable(src, names) -> ignored_names + + Since copytree() is called recursively, the callable will be + called once for each directory that is copied. It returns a + list of names relative to the `src` directory that should + not be copied. + + The optional copy_function argument is a callable that will be used + to copy each file. It will be called with the source path and the + destination path as arguments. By default, copy2() is used, but any + function that supports the same signature (like copy()) can be used. + + """ + names = os.listdir(src) + if ignore is not None: + ignored_names = ignore(src, names) + else: + ignored_names = set() + + os.makedirs(dst) + errors = [] + for name in names: + if name in ignored_names: + continue + srcname = os.path.join(src, name) + dstname = os.path.join(dst, name) + try: + if os.path.islink(srcname): + linkto = os.readlink(srcname) + if symlinks: + os.symlink(linkto, dstname) + else: + # ignore dangling symlink if the flag is on + if not os.path.exists(linkto) and ignore_dangling_symlinks: + continue + # otherwise let the copy occurs. copy2 will raise an error + copy_function(srcname, dstname) + elif os.path.isdir(srcname): + copytree(srcname, dstname, symlinks, ignore, copy_function) + else: + # Will raise a SpecialFileError for unsupported file types + copy_function(srcname, dstname) + # catch the Error from the recursive copytree so that we can + # continue with other files + except Error as err: + errors.extend(err.args[0]) + except EnvironmentError as why: + errors.append((srcname, dstname, str(why))) + try: + copystat(src, dst) + except OSError as why: + if WindowsError is not None and isinstance(why, WindowsError): + # Copying file access times may fail on Windows + pass + else: + errors.extend((src, dst, str(why))) + if errors: + raise Error(errors) + +def rmtree(path, ignore_errors=False, onerror=None): + """Recursively delete a directory tree. + + If ignore_errors is set, errors are ignored; otherwise, if onerror + is set, it is called to handle the error with arguments (func, + path, exc_info) where func is os.listdir, os.remove, or os.rmdir; + path is the argument to that function that caused it to fail; and + exc_info is a tuple returned by sys.exc_info(). If ignore_errors + is false and onerror is None, an exception is raised. + + """ + if ignore_errors: + def onerror(*args): + pass + elif onerror is None: + def onerror(*args): + raise + try: + if os.path.islink(path): + # symlinks to directories are forbidden, see bug #1669 + raise OSError("Cannot call rmtree on a symbolic link") + except OSError: + onerror(os.path.islink, path, sys.exc_info()) + # can't continue even if onerror hook returns + return + names = [] + try: + names = os.listdir(path) + except os.error: + onerror(os.listdir, path, sys.exc_info()) + for name in names: + fullname = os.path.join(path, name) + try: + mode = os.lstat(fullname).st_mode + except os.error: + mode = 0 + if stat.S_ISDIR(mode): + rmtree(fullname, ignore_errors, onerror) + else: + try: + os.remove(fullname) + except os.error: + onerror(os.remove, fullname, sys.exc_info()) + try: + os.rmdir(path) + except os.error: + onerror(os.rmdir, path, sys.exc_info()) + + +def _basename(path): + # A basename() variant which first strips the trailing slash, if present. + # Thus we always get the last component of the path, even for directories. + return os.path.basename(path.rstrip(os.path.sep)) + +def move(src, dst): + """Recursively move a file or directory to another location. This is + similar to the Unix "mv" command. + + If the destination is a directory or a symlink to a directory, the source + is moved inside the directory. The destination path must not already + exist. + + If the destination already exists but is not a directory, it may be + overwritten depending on os.rename() semantics. + + If the destination is on our current filesystem, then rename() is used. + Otherwise, src is copied to the destination and then removed. + A lot more could be done here... A look at a mv.c shows a lot of + the issues this implementation glosses over. + + """ + real_dst = dst + if os.path.isdir(dst): + if _samefile(src, dst): + # We might be on a case insensitive filesystem, + # perform the rename anyway. + os.rename(src, dst) + return + + real_dst = os.path.join(dst, _basename(src)) + if os.path.exists(real_dst): + raise Error("Destination path '%s' already exists" % real_dst) + try: + os.rename(src, real_dst) + except OSError: + if os.path.isdir(src): + if _destinsrc(src, dst): + raise Error("Cannot move a directory '%s' into itself '%s'." % (src, dst)) + copytree(src, real_dst, symlinks=True) + rmtree(src) + else: + copy2(src, real_dst) + os.unlink(src) + +def _destinsrc(src, dst): + src = abspath(src) + dst = abspath(dst) + if not src.endswith(os.path.sep): + src += os.path.sep + if not dst.endswith(os.path.sep): + dst += os.path.sep + return dst.startswith(src) + +def _get_gid(name): + """Returns a gid, given a group name.""" + if getgrnam is None or name is None: + return None + try: + result = getgrnam(name) + except KeyError: + result = None + if result is not None: + return result[2] + return None + +def _get_uid(name): + """Returns an uid, given a user name.""" + if getpwnam is None or name is None: + return None + try: + result = getpwnam(name) + except KeyError: + result = None + if result is not None: + return result[2] + return None + +def _make_tarball(base_name, base_dir, compress="gzip", verbose=0, dry_run=0, + owner=None, group=None, logger=None): + """Create a (possibly compressed) tar file from all the files under + 'base_dir'. + + 'compress' must be "gzip" (the default), "bzip2", or None. + + 'owner' and 'group' can be used to define an owner and a group for the + archive that is being built. If not provided, the current owner and group + will be used. + + The output tar file will be named 'base_name' + ".tar", possibly plus + the appropriate compression extension (".gz", or ".bz2"). + + Returns the output filename. + """ + tar_compression = {'gzip': 'gz', None: ''} + compress_ext = {'gzip': '.gz'} + + if _BZ2_SUPPORTED: + tar_compression['bzip2'] = 'bz2' + compress_ext['bzip2'] = '.bz2' + + # flags for compression program, each element of list will be an argument + if compress is not None and compress not in compress_ext: + raise ValueError("bad value for 'compress', or compression format not " + "supported : {0}".format(compress)) + + archive_name = base_name + '.tar' + compress_ext.get(compress, '') + archive_dir = os.path.dirname(archive_name) + + if not os.path.exists(archive_dir): + if logger is not None: + logger.info("creating %s", archive_dir) + if not dry_run: + os.makedirs(archive_dir) + + # creating the tarball + if logger is not None: + logger.info('Creating tar archive') + + uid = _get_uid(owner) + gid = _get_gid(group) + + def _set_uid_gid(tarinfo): + if gid is not None: + tarinfo.gid = gid + tarinfo.gname = group + if uid is not None: + tarinfo.uid = uid + tarinfo.uname = owner + return tarinfo + + if not dry_run: + tar = tarfile.open(archive_name, 'w|%s' % tar_compression[compress]) + try: + tar.add(base_dir, filter=_set_uid_gid) + finally: + tar.close() + + return archive_name + +def _call_external_zip(base_dir, zip_filename, verbose=False, dry_run=False): + # XXX see if we want to keep an external call here + if verbose: + zipoptions = "-r" + else: + zipoptions = "-rq" + from distutils.errors import DistutilsExecError + from distutils.spawn import spawn + try: + spawn(["zip", zipoptions, zip_filename, base_dir], dry_run=dry_run) + except DistutilsExecError: + # XXX really should distinguish between "couldn't find + # external 'zip' command" and "zip failed". + raise ExecError("unable to create zip file '%s': " + "could neither import the 'zipfile' module nor " + "find a standalone zip utility") % zip_filename + +def _make_zipfile(base_name, base_dir, verbose=0, dry_run=0, logger=None): + """Create a zip file from all the files under 'base_dir'. + + The output zip file will be named 'base_name' + ".zip". Uses either the + "zipfile" Python module (if available) or the InfoZIP "zip" utility + (if installed and found on the default search path). If neither tool is + available, raises ExecError. Returns the name of the output zip + file. + """ + zip_filename = base_name + ".zip" + archive_dir = os.path.dirname(base_name) + + if not os.path.exists(archive_dir): + if logger is not None: + logger.info("creating %s", archive_dir) + if not dry_run: + os.makedirs(archive_dir) + + # If zipfile module is not available, try spawning an external 'zip' + # command. + try: + import zipfile + except ImportError: + zipfile = None + + if zipfile is None: + _call_external_zip(base_dir, zip_filename, verbose, dry_run) + else: + if logger is not None: + logger.info("creating '%s' and adding '%s' to it", + zip_filename, base_dir) + + if not dry_run: + zip = zipfile.ZipFile(zip_filename, "w", + compression=zipfile.ZIP_DEFLATED) + + for dirpath, dirnames, filenames in os.walk(base_dir): + for name in filenames: + path = os.path.normpath(os.path.join(dirpath, name)) + if os.path.isfile(path): + zip.write(path, path) + if logger is not None: + logger.info("adding '%s'", path) + zip.close() + + return zip_filename + +_ARCHIVE_FORMATS = { + 'gztar': (_make_tarball, [('compress', 'gzip')], "gzip'ed tar-file"), + 'bztar': (_make_tarball, [('compress', 'bzip2')], "bzip2'ed tar-file"), + 'tar': (_make_tarball, [('compress', None)], "uncompressed tar file"), + 'zip': (_make_zipfile, [], "ZIP file"), + } + +if _BZ2_SUPPORTED: + _ARCHIVE_FORMATS['bztar'] = (_make_tarball, [('compress', 'bzip2')], + "bzip2'ed tar-file") + +def get_archive_formats(): + """Returns a list of supported formats for archiving and unarchiving. + + Each element of the returned sequence is a tuple (name, description) + """ + formats = [(name, registry[2]) for name, registry in + _ARCHIVE_FORMATS.items()] + formats.sort() + return formats + +def register_archive_format(name, function, extra_args=None, description=''): + """Registers an archive format. + + name is the name of the format. function is the callable that will be + used to create archives. If provided, extra_args is a sequence of + (name, value) tuples that will be passed as arguments to the callable. + description can be provided to describe the format, and will be returned + by the get_archive_formats() function. + """ + if extra_args is None: + extra_args = [] + if not isinstance(function, collections.Callable): + raise TypeError('The %s object is not callable' % function) + if not isinstance(extra_args, (tuple, list)): + raise TypeError('extra_args needs to be a sequence') + for element in extra_args: + if not isinstance(element, (tuple, list)) or len(element) !=2: + raise TypeError('extra_args elements are : (arg_name, value)') + + _ARCHIVE_FORMATS[name] = (function, extra_args, description) + +def unregister_archive_format(name): + del _ARCHIVE_FORMATS[name] + +def make_archive(base_name, format, root_dir=None, base_dir=None, verbose=0, + dry_run=0, owner=None, group=None, logger=None): + """Create an archive file (eg. zip or tar). + + 'base_name' is the name of the file to create, minus any format-specific + extension; 'format' is the archive format: one of "zip", "tar", "bztar" + or "gztar". + + 'root_dir' is a directory that will be the root directory of the + archive; ie. we typically chdir into 'root_dir' before creating the + archive. 'base_dir' is the directory where we start archiving from; + ie. 'base_dir' will be the common prefix of all files and + directories in the archive. 'root_dir' and 'base_dir' both default + to the current directory. Returns the name of the archive file. + + 'owner' and 'group' are used when creating a tar archive. By default, + uses the current owner and group. + """ + save_cwd = os.getcwd() + if root_dir is not None: + if logger is not None: + logger.debug("changing into '%s'", root_dir) + base_name = os.path.abspath(base_name) + if not dry_run: + os.chdir(root_dir) + + if base_dir is None: + base_dir = os.curdir + + kwargs = {'dry_run': dry_run, 'logger': logger} + + try: + format_info = _ARCHIVE_FORMATS[format] + except KeyError: + raise ValueError("unknown archive format '%s'" % format) + + func = format_info[0] + for arg, val in format_info[1]: + kwargs[arg] = val + + if format != 'zip': + kwargs['owner'] = owner + kwargs['group'] = group + + try: + filename = func(base_name, base_dir, **kwargs) + finally: + if root_dir is not None: + if logger is not None: + logger.debug("changing back to '%s'", save_cwd) + os.chdir(save_cwd) + + return filename + + +def get_unpack_formats(): + """Returns a list of supported formats for unpacking. + + Each element of the returned sequence is a tuple + (name, extensions, description) + """ + formats = [(name, info[0], info[3]) for name, info in + _UNPACK_FORMATS.items()] + formats.sort() + return formats + +def _check_unpack_options(extensions, function, extra_args): + """Checks what gets registered as an unpacker.""" + # first make sure no other unpacker is registered for this extension + existing_extensions = {} + for name, info in _UNPACK_FORMATS.items(): + for ext in info[0]: + existing_extensions[ext] = name + + for extension in extensions: + if extension in existing_extensions: + msg = '%s is already registered for "%s"' + raise RegistryError(msg % (extension, + existing_extensions[extension])) + + if not isinstance(function, collections.Callable): + raise TypeError('The registered function must be a callable') + + +def register_unpack_format(name, extensions, function, extra_args=None, + description=''): + """Registers an unpack format. + + `name` is the name of the format. `extensions` is a list of extensions + corresponding to the format. + + `function` is the callable that will be + used to unpack archives. The callable will receive archives to unpack. + If it's unable to handle an archive, it needs to raise a ReadError + exception. + + If provided, `extra_args` is a sequence of + (name, value) tuples that will be passed as arguments to the callable. + description can be provided to describe the format, and will be returned + by the get_unpack_formats() function. + """ + if extra_args is None: + extra_args = [] + _check_unpack_options(extensions, function, extra_args) + _UNPACK_FORMATS[name] = extensions, function, extra_args, description + +def unregister_unpack_format(name): + """Removes the pack format from the registry.""" + del _UNPACK_FORMATS[name] + +def _ensure_directory(path): + """Ensure that the parent directory of `path` exists""" + dirname = os.path.dirname(path) + if not os.path.isdir(dirname): + os.makedirs(dirname) + +def _unpack_zipfile(filename, extract_dir): + """Unpack zip `filename` to `extract_dir` + """ + try: + import zipfile + except ImportError: + raise ReadError('zlib not supported, cannot unpack this archive.') + + if not zipfile.is_zipfile(filename): + raise ReadError("%s is not a zip file" % filename) + + zip = zipfile.ZipFile(filename) + try: + for info in zip.infolist(): + name = info.filename + + # don't extract absolute paths or ones with .. in them + if name.startswith('/') or '..' in name: + continue + + target = os.path.join(extract_dir, *name.split('/')) + if not target: + continue + + _ensure_directory(target) + if not name.endswith('/'): + # file + data = zip.read(info.filename) + f = open(target, 'wb') + try: + f.write(data) + finally: + f.close() + del data + finally: + zip.close() + +def _unpack_tarfile(filename, extract_dir): + """Unpack tar/tar.gz/tar.bz2 `filename` to `extract_dir` + """ + try: + tarobj = tarfile.open(filename) + except tarfile.TarError: + raise ReadError( + "%s is not a compressed or uncompressed tar file" % filename) + try: + tarobj.extractall(extract_dir) + finally: + tarobj.close() + +_UNPACK_FORMATS = { + 'gztar': (['.tar.gz', '.tgz'], _unpack_tarfile, [], "gzip'ed tar-file"), + 'tar': (['.tar'], _unpack_tarfile, [], "uncompressed tar file"), + 'zip': (['.zip'], _unpack_zipfile, [], "ZIP file") + } + +if _BZ2_SUPPORTED: + _UNPACK_FORMATS['bztar'] = (['.bz2'], _unpack_tarfile, [], + "bzip2'ed tar-file") + +def _find_unpack_format(filename): + for name, info in _UNPACK_FORMATS.items(): + for extension in info[0]: + if filename.endswith(extension): + return name + return None + +def unpack_archive(filename, extract_dir=None, format=None): + """Unpack an archive. + + `filename` is the name of the archive. + + `extract_dir` is the name of the target directory, where the archive + is unpacked. If not provided, the current working directory is used. + + `format` is the archive format: one of "zip", "tar", or "gztar". Or any + other registered format. If not provided, unpack_archive will use the + filename extension and see if an unpacker was registered for that + extension. + + In case none is found, a ValueError is raised. + """ + if extract_dir is None: + extract_dir = os.getcwd() + + if format is not None: + try: + format_info = _UNPACK_FORMATS[format] + except KeyError: + raise ValueError("Unknown unpack format '{0}'".format(format)) + + func = format_info[1] + func(filename, extract_dir, **dict(format_info[2])) + else: + # we need to look at the registered unpackers supported extensions + format = _find_unpack_format(filename) + if format is None: + raise ReadError("Unknown archive format '{0}'".format(filename)) + + func = _UNPACK_FORMATS[format][1] + kwargs = dict(_UNPACK_FORMATS[format][2]) + func(filename, extract_dir, **kwargs) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg new file mode 100644 index 0000000..1746bd0 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg @@ -0,0 +1,84 @@ +[posix_prefix] +# Configuration directories. Some of these come straight out of the +# configure script. They are for implementing the other variables, not to +# be used directly in [resource_locations]. +confdir = /etc +datadir = /usr/share +libdir = /usr/lib +statedir = /var +# User resource directory +local = ~/.local/{distribution.name} + +stdlib = {base}/lib/python{py_version_short} +platstdlib = {platbase}/lib/python{py_version_short} +purelib = {base}/lib/python{py_version_short}/site-packages +platlib = {platbase}/lib/python{py_version_short}/site-packages +include = {base}/include/python{py_version_short}{abiflags} +platinclude = {platbase}/include/python{py_version_short}{abiflags} +data = {base} + +[posix_home] +stdlib = {base}/lib/python +platstdlib = {base}/lib/python +purelib = {base}/lib/python +platlib = {base}/lib/python +include = {base}/include/python +platinclude = {base}/include/python +scripts = {base}/bin +data = {base} + +[nt] +stdlib = {base}/Lib +platstdlib = {base}/Lib +purelib = {base}/Lib/site-packages +platlib = {base}/Lib/site-packages +include = {base}/Include +platinclude = {base}/Include +scripts = {base}/Scripts +data = {base} + +[os2] +stdlib = {base}/Lib +platstdlib = {base}/Lib +purelib = {base}/Lib/site-packages +platlib = {base}/Lib/site-packages +include = {base}/Include +platinclude = {base}/Include +scripts = {base}/Scripts +data = {base} + +[os2_home] +stdlib = {userbase}/lib/python{py_version_short} +platstdlib = {userbase}/lib/python{py_version_short} +purelib = {userbase}/lib/python{py_version_short}/site-packages +platlib = {userbase}/lib/python{py_version_short}/site-packages +include = {userbase}/include/python{py_version_short} +scripts = {userbase}/bin +data = {userbase} + +[nt_user] +stdlib = {userbase}/Python{py_version_nodot} +platstdlib = {userbase}/Python{py_version_nodot} +purelib = {userbase}/Python{py_version_nodot}/site-packages +platlib = {userbase}/Python{py_version_nodot}/site-packages +include = {userbase}/Python{py_version_nodot}/Include +scripts = {userbase}/Scripts +data = {userbase} + +[posix_user] +stdlib = {userbase}/lib/python{py_version_short} +platstdlib = {userbase}/lib/python{py_version_short} +purelib = {userbase}/lib/python{py_version_short}/site-packages +platlib = {userbase}/lib/python{py_version_short}/site-packages +include = {userbase}/include/python{py_version_short} +scripts = {userbase}/bin +data = {userbase} + +[osx_framework_user] +stdlib = {userbase}/lib/python +platstdlib = {userbase}/lib/python +purelib = {userbase}/lib/python/site-packages +platlib = {userbase}/lib/python/site-packages +include = {userbase}/include +scripts = {userbase}/bin +data = {userbase} diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/sysconfig.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/sysconfig.py new file mode 100644 index 0000000..1df3aba --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/sysconfig.py @@ -0,0 +1,788 @@ +# -*- coding: utf-8 -*- +# +# Copyright (C) 2012 The Python Software Foundation. +# See LICENSE.txt and CONTRIBUTORS.txt. +# +"""Access to Python's configuration information.""" + +import codecs +import os +import re +import sys +from os.path import pardir, realpath +try: + import configparser +except ImportError: + import ConfigParser as configparser + + +__all__ = [ + 'get_config_h_filename', + 'get_config_var', + 'get_config_vars', + 'get_makefile_filename', + 'get_path', + 'get_path_names', + 'get_paths', + 'get_platform', + 'get_python_version', + 'get_scheme_names', + 'parse_config_h', +] + + +def _safe_realpath(path): + try: + return realpath(path) + except OSError: + return path + + +if sys.executable: + _PROJECT_BASE = os.path.dirname(_safe_realpath(sys.executable)) +else: + # sys.executable can be empty if argv[0] has been changed and Python is + # unable to retrieve the real program name + _PROJECT_BASE = _safe_realpath(os.getcwd()) + +if os.name == "nt" and "pcbuild" in _PROJECT_BASE[-8:].lower(): + _PROJECT_BASE = _safe_realpath(os.path.join(_PROJECT_BASE, pardir)) +# PC/VS7.1 +if os.name == "nt" and "\\pc\\v" in _PROJECT_BASE[-10:].lower(): + _PROJECT_BASE = _safe_realpath(os.path.join(_PROJECT_BASE, pardir, pardir)) +# PC/AMD64 +if os.name == "nt" and "\\pcbuild\\amd64" in _PROJECT_BASE[-14:].lower(): + _PROJECT_BASE = _safe_realpath(os.path.join(_PROJECT_BASE, pardir, pardir)) + + +def is_python_build(): + for fn in ("Setup.dist", "Setup.local"): + if os.path.isfile(os.path.join(_PROJECT_BASE, "Modules", fn)): + return True + return False + +_PYTHON_BUILD = is_python_build() + +_cfg_read = False + +def _ensure_cfg_read(): + global _cfg_read + if not _cfg_read: + from ..resources import finder + backport_package = __name__.rsplit('.', 1)[0] + _finder = finder(backport_package) + _cfgfile = _finder.find('sysconfig.cfg') + assert _cfgfile, 'sysconfig.cfg exists' + with _cfgfile.as_stream() as s: + _SCHEMES.readfp(s) + if _PYTHON_BUILD: + for scheme in ('posix_prefix', 'posix_home'): + _SCHEMES.set(scheme, 'include', '{srcdir}/Include') + _SCHEMES.set(scheme, 'platinclude', '{projectbase}/.') + + _cfg_read = True + + +_SCHEMES = configparser.RawConfigParser() +_VAR_REPL = re.compile(r'\{([^{]*?)\}') + +def _expand_globals(config): + _ensure_cfg_read() + if config.has_section('globals'): + globals = config.items('globals') + else: + globals = tuple() + + sections = config.sections() + for section in sections: + if section == 'globals': + continue + for option, value in globals: + if config.has_option(section, option): + continue + config.set(section, option, value) + config.remove_section('globals') + + # now expanding local variables defined in the cfg file + # + for section in config.sections(): + variables = dict(config.items(section)) + + def _replacer(matchobj): + name = matchobj.group(1) + if name in variables: + return variables[name] + return matchobj.group(0) + + for option, value in config.items(section): + config.set(section, option, _VAR_REPL.sub(_replacer, value)) + +#_expand_globals(_SCHEMES) + + # FIXME don't rely on sys.version here, its format is an implementation detail + # of CPython, use sys.version_info or sys.hexversion +_PY_VERSION = sys.version.split()[0] +_PY_VERSION_SHORT = sys.version[:3] +_PY_VERSION_SHORT_NO_DOT = _PY_VERSION[0] + _PY_VERSION[2] +_PREFIX = os.path.normpath(sys.prefix) +_EXEC_PREFIX = os.path.normpath(sys.exec_prefix) +_CONFIG_VARS = None +_USER_BASE = None + + +def _subst_vars(path, local_vars): + """In the string `path`, replace tokens like {some.thing} with the + corresponding value from the map `local_vars`. + + If there is no corresponding value, leave the token unchanged. + """ + def _replacer(matchobj): + name = matchobj.group(1) + if name in local_vars: + return local_vars[name] + elif name in os.environ: + return os.environ[name] + return matchobj.group(0) + return _VAR_REPL.sub(_replacer, path) + + +def _extend_dict(target_dict, other_dict): + target_keys = target_dict.keys() + for key, value in other_dict.items(): + if key in target_keys: + continue + target_dict[key] = value + + +def _expand_vars(scheme, vars): + res = {} + if vars is None: + vars = {} + _extend_dict(vars, get_config_vars()) + + for key, value in _SCHEMES.items(scheme): + if os.name in ('posix', 'nt'): + value = os.path.expanduser(value) + res[key] = os.path.normpath(_subst_vars(value, vars)) + return res + + +def format_value(value, vars): + def _replacer(matchobj): + name = matchobj.group(1) + if name in vars: + return vars[name] + return matchobj.group(0) + return _VAR_REPL.sub(_replacer, value) + + +def _get_default_scheme(): + if os.name == 'posix': + # the default scheme for posix is posix_prefix + return 'posix_prefix' + return os.name + + +def _getuserbase(): + env_base = os.environ.get("PYTHONUSERBASE", None) + + def joinuser(*args): + return os.path.expanduser(os.path.join(*args)) + + # what about 'os2emx', 'riscos' ? + if os.name == "nt": + base = os.environ.get("APPDATA") or "~" + if env_base: + return env_base + else: + return joinuser(base, "Python") + + if sys.platform == "darwin": + framework = get_config_var("PYTHONFRAMEWORK") + if framework: + if env_base: + return env_base + else: + return joinuser("~", "Library", framework, "%d.%d" % + sys.version_info[:2]) + + if env_base: + return env_base + else: + return joinuser("~", ".local") + + +def _parse_makefile(filename, vars=None): + """Parse a Makefile-style file. + + A dictionary containing name/value pairs is returned. If an + optional dictionary is passed in as the second argument, it is + used instead of a new dictionary. + """ + # Regexes needed for parsing Makefile (and similar syntaxes, + # like old-style Setup files). + _variable_rx = re.compile(r"([a-zA-Z][a-zA-Z0-9_]+)\s*=\s*(.*)") + _findvar1_rx = re.compile(r"\$\(([A-Za-z][A-Za-z0-9_]*)\)") + _findvar2_rx = re.compile(r"\${([A-Za-z][A-Za-z0-9_]*)}") + + if vars is None: + vars = {} + done = {} + notdone = {} + + with codecs.open(filename, encoding='utf-8', errors="surrogateescape") as f: + lines = f.readlines() + + for line in lines: + if line.startswith('#') or line.strip() == '': + continue + m = _variable_rx.match(line) + if m: + n, v = m.group(1, 2) + v = v.strip() + # `$$' is a literal `$' in make + tmpv = v.replace('$$', '') + + if "$" in tmpv: + notdone[n] = v + else: + try: + v = int(v) + except ValueError: + # insert literal `$' + done[n] = v.replace('$$', '$') + else: + done[n] = v + + # do variable interpolation here + variables = list(notdone.keys()) + + # Variables with a 'PY_' prefix in the makefile. These need to + # be made available without that prefix through sysconfig. + # Special care is needed to ensure that variable expansion works, even + # if the expansion uses the name without a prefix. + renamed_variables = ('CFLAGS', 'LDFLAGS', 'CPPFLAGS') + + while len(variables) > 0: + for name in tuple(variables): + value = notdone[name] + m = _findvar1_rx.search(value) or _findvar2_rx.search(value) + if m is not None: + n = m.group(1) + found = True + if n in done: + item = str(done[n]) + elif n in notdone: + # get it on a subsequent round + found = False + elif n in os.environ: + # do it like make: fall back to environment + item = os.environ[n] + + elif n in renamed_variables: + if (name.startswith('PY_') and + name[3:] in renamed_variables): + item = "" + + elif 'PY_' + n in notdone: + found = False + + else: + item = str(done['PY_' + n]) + + else: + done[n] = item = "" + + if found: + after = value[m.end():] + value = value[:m.start()] + item + after + if "$" in after: + notdone[name] = value + else: + try: + value = int(value) + except ValueError: + done[name] = value.strip() + else: + done[name] = value + variables.remove(name) + + if (name.startswith('PY_') and + name[3:] in renamed_variables): + + name = name[3:] + if name not in done: + done[name] = value + + else: + # bogus variable reference (e.g. "prefix=$/opt/python"); + # just drop it since we can't deal + done[name] = value + variables.remove(name) + + # strip spurious spaces + for k, v in done.items(): + if isinstance(v, str): + done[k] = v.strip() + + # save the results in the global dictionary + vars.update(done) + return vars + + +def get_makefile_filename(): + """Return the path of the Makefile.""" + if _PYTHON_BUILD: + return os.path.join(_PROJECT_BASE, "Makefile") + if hasattr(sys, 'abiflags'): + config_dir_name = 'config-%s%s' % (_PY_VERSION_SHORT, sys.abiflags) + else: + config_dir_name = 'config' + return os.path.join(get_path('stdlib'), config_dir_name, 'Makefile') + + +def _init_posix(vars): + """Initialize the module as appropriate for POSIX systems.""" + # load the installed Makefile: + makefile = get_makefile_filename() + try: + _parse_makefile(makefile, vars) + except IOError as e: + msg = "invalid Python installation: unable to open %s" % makefile + if hasattr(e, "strerror"): + msg = msg + " (%s)" % e.strerror + raise IOError(msg) + # load the installed pyconfig.h: + config_h = get_config_h_filename() + try: + with open(config_h) as f: + parse_config_h(f, vars) + except IOError as e: + msg = "invalid Python installation: unable to open %s" % config_h + if hasattr(e, "strerror"): + msg = msg + " (%s)" % e.strerror + raise IOError(msg) + # On AIX, there are wrong paths to the linker scripts in the Makefile + # -- these paths are relative to the Python source, but when installed + # the scripts are in another directory. + if _PYTHON_BUILD: + vars['LDSHARED'] = vars['BLDSHARED'] + + +def _init_non_posix(vars): + """Initialize the module as appropriate for NT""" + # set basic install directories + vars['LIBDEST'] = get_path('stdlib') + vars['BINLIBDEST'] = get_path('platstdlib') + vars['INCLUDEPY'] = get_path('include') + vars['SO'] = '.pyd' + vars['EXE'] = '.exe' + vars['VERSION'] = _PY_VERSION_SHORT_NO_DOT + vars['BINDIR'] = os.path.dirname(_safe_realpath(sys.executable)) + +# +# public APIs +# + + +def parse_config_h(fp, vars=None): + """Parse a config.h-style file. + + A dictionary containing name/value pairs is returned. If an + optional dictionary is passed in as the second argument, it is + used instead of a new dictionary. + """ + if vars is None: + vars = {} + define_rx = re.compile("#define ([A-Z][A-Za-z0-9_]+) (.*)\n") + undef_rx = re.compile("/[*] #undef ([A-Z][A-Za-z0-9_]+) [*]/\n") + + while True: + line = fp.readline() + if not line: + break + m = define_rx.match(line) + if m: + n, v = m.group(1, 2) + try: + v = int(v) + except ValueError: + pass + vars[n] = v + else: + m = undef_rx.match(line) + if m: + vars[m.group(1)] = 0 + return vars + + +def get_config_h_filename(): + """Return the path of pyconfig.h.""" + if _PYTHON_BUILD: + if os.name == "nt": + inc_dir = os.path.join(_PROJECT_BASE, "PC") + else: + inc_dir = _PROJECT_BASE + else: + inc_dir = get_path('platinclude') + return os.path.join(inc_dir, 'pyconfig.h') + + +def get_scheme_names(): + """Return a tuple containing the schemes names.""" + return tuple(sorted(_SCHEMES.sections())) + + +def get_path_names(): + """Return a tuple containing the paths names.""" + # xxx see if we want a static list + return _SCHEMES.options('posix_prefix') + + +def get_paths(scheme=_get_default_scheme(), vars=None, expand=True): + """Return a mapping containing an install scheme. + + ``scheme`` is the install scheme name. If not provided, it will + return the default scheme for the current platform. + """ + _ensure_cfg_read() + if expand: + return _expand_vars(scheme, vars) + else: + return dict(_SCHEMES.items(scheme)) + + +def get_path(name, scheme=_get_default_scheme(), vars=None, expand=True): + """Return a path corresponding to the scheme. + + ``scheme`` is the install scheme name. + """ + return get_paths(scheme, vars, expand)[name] + + +def get_config_vars(*args): + """With no arguments, return a dictionary of all configuration + variables relevant for the current platform. + + On Unix, this means every variable defined in Python's installed Makefile; + On Windows and Mac OS it's a much smaller set. + + With arguments, return a list of values that result from looking up + each argument in the configuration variable dictionary. + """ + global _CONFIG_VARS + if _CONFIG_VARS is None: + _CONFIG_VARS = {} + # Normalized versions of prefix and exec_prefix are handy to have; + # in fact, these are the standard versions used most places in the + # distutils2 module. + _CONFIG_VARS['prefix'] = _PREFIX + _CONFIG_VARS['exec_prefix'] = _EXEC_PREFIX + _CONFIG_VARS['py_version'] = _PY_VERSION + _CONFIG_VARS['py_version_short'] = _PY_VERSION_SHORT + _CONFIG_VARS['py_version_nodot'] = _PY_VERSION[0] + _PY_VERSION[2] + _CONFIG_VARS['base'] = _PREFIX + _CONFIG_VARS['platbase'] = _EXEC_PREFIX + _CONFIG_VARS['projectbase'] = _PROJECT_BASE + try: + _CONFIG_VARS['abiflags'] = sys.abiflags + except AttributeError: + # sys.abiflags may not be defined on all platforms. + _CONFIG_VARS['abiflags'] = '' + + if os.name in ('nt', 'os2'): + _init_non_posix(_CONFIG_VARS) + if os.name == 'posix': + _init_posix(_CONFIG_VARS) + # Setting 'userbase' is done below the call to the + # init function to enable using 'get_config_var' in + # the init-function. + if sys.version >= '2.6': + _CONFIG_VARS['userbase'] = _getuserbase() + + if 'srcdir' not in _CONFIG_VARS: + _CONFIG_VARS['srcdir'] = _PROJECT_BASE + else: + _CONFIG_VARS['srcdir'] = _safe_realpath(_CONFIG_VARS['srcdir']) + + # Convert srcdir into an absolute path if it appears necessary. + # Normally it is relative to the build directory. However, during + # testing, for example, we might be running a non-installed python + # from a different directory. + if _PYTHON_BUILD and os.name == "posix": + base = _PROJECT_BASE + try: + cwd = os.getcwd() + except OSError: + cwd = None + if (not os.path.isabs(_CONFIG_VARS['srcdir']) and + base != cwd): + # srcdir is relative and we are not in the same directory + # as the executable. Assume executable is in the build + # directory and make srcdir absolute. + srcdir = os.path.join(base, _CONFIG_VARS['srcdir']) + _CONFIG_VARS['srcdir'] = os.path.normpath(srcdir) + + if sys.platform == 'darwin': + kernel_version = os.uname()[2] # Kernel version (8.4.3) + major_version = int(kernel_version.split('.')[0]) + + if major_version < 8: + # On Mac OS X before 10.4, check if -arch and -isysroot + # are in CFLAGS or LDFLAGS and remove them if they are. + # This is needed when building extensions on a 10.3 system + # using a universal build of python. + for key in ('LDFLAGS', 'BASECFLAGS', + # a number of derived variables. These need to be + # patched up as well. + 'CFLAGS', 'PY_CFLAGS', 'BLDSHARED'): + flags = _CONFIG_VARS[key] + flags = re.sub(r'-arch\s+\w+\s', ' ', flags) + flags = re.sub('-isysroot [^ \t]*', ' ', flags) + _CONFIG_VARS[key] = flags + else: + # Allow the user to override the architecture flags using + # an environment variable. + # NOTE: This name was introduced by Apple in OSX 10.5 and + # is used by several scripting languages distributed with + # that OS release. + if 'ARCHFLAGS' in os.environ: + arch = os.environ['ARCHFLAGS'] + for key in ('LDFLAGS', 'BASECFLAGS', + # a number of derived variables. These need to be + # patched up as well. + 'CFLAGS', 'PY_CFLAGS', 'BLDSHARED'): + + flags = _CONFIG_VARS[key] + flags = re.sub(r'-arch\s+\w+\s', ' ', flags) + flags = flags + ' ' + arch + _CONFIG_VARS[key] = flags + + # If we're on OSX 10.5 or later and the user tries to + # compiles an extension using an SDK that is not present + # on the current machine it is better to not use an SDK + # than to fail. + # + # The major usecase for this is users using a Python.org + # binary installer on OSX 10.6: that installer uses + # the 10.4u SDK, but that SDK is not installed by default + # when you install Xcode. + # + CFLAGS = _CONFIG_VARS.get('CFLAGS', '') + m = re.search(r'-isysroot\s+(\S+)', CFLAGS) + if m is not None: + sdk = m.group(1) + if not os.path.exists(sdk): + for key in ('LDFLAGS', 'BASECFLAGS', + # a number of derived variables. These need to be + # patched up as well. + 'CFLAGS', 'PY_CFLAGS', 'BLDSHARED'): + + flags = _CONFIG_VARS[key] + flags = re.sub(r'-isysroot\s+\S+(\s|$)', ' ', flags) + _CONFIG_VARS[key] = flags + + if args: + vals = [] + for name in args: + vals.append(_CONFIG_VARS.get(name)) + return vals + else: + return _CONFIG_VARS + + +def get_config_var(name): + """Return the value of a single variable using the dictionary returned by + 'get_config_vars()'. + + Equivalent to get_config_vars().get(name) + """ + return get_config_vars().get(name) + + +def get_platform(): + """Return a string that identifies the current platform. + + This is used mainly to distinguish platform-specific build directories and + platform-specific built distributions. Typically includes the OS name + and version and the architecture (as supplied by 'os.uname()'), + although the exact information included depends on the OS; eg. for IRIX + the architecture isn't particularly important (IRIX only runs on SGI + hardware), but for Linux the kernel version isn't particularly + important. + + Examples of returned values: + linux-i586 + linux-alpha (?) + solaris-2.6-sun4u + irix-5.3 + irix64-6.2 + + Windows will return one of: + win-amd64 (64bit Windows on AMD64 (aka x86_64, Intel64, EM64T, etc) + win-ia64 (64bit Windows on Itanium) + win32 (all others - specifically, sys.platform is returned) + + For other non-POSIX platforms, currently just returns 'sys.platform'. + """ + if os.name == 'nt': + # sniff sys.version for architecture. + prefix = " bit (" + i = sys.version.find(prefix) + if i == -1: + return sys.platform + j = sys.version.find(")", i) + look = sys.version[i+len(prefix):j].lower() + if look == 'amd64': + return 'win-amd64' + if look == 'itanium': + return 'win-ia64' + return sys.platform + + if os.name != "posix" or not hasattr(os, 'uname'): + # XXX what about the architecture? NT is Intel or Alpha, + # Mac OS is M68k or PPC, etc. + return sys.platform + + # Try to distinguish various flavours of Unix + osname, host, release, version, machine = os.uname() + + # Convert the OS name to lowercase, remove '/' characters + # (to accommodate BSD/OS), and translate spaces (for "Power Macintosh") + osname = osname.lower().replace('/', '') + machine = machine.replace(' ', '_') + machine = machine.replace('/', '-') + + if osname[:5] == "linux": + # At least on Linux/Intel, 'machine' is the processor -- + # i386, etc. + # XXX what about Alpha, SPARC, etc? + return "%s-%s" % (osname, machine) + elif osname[:5] == "sunos": + if release[0] >= "5": # SunOS 5 == Solaris 2 + osname = "solaris" + release = "%d.%s" % (int(release[0]) - 3, release[2:]) + # fall through to standard osname-release-machine representation + elif osname[:4] == "irix": # could be "irix64"! + return "%s-%s" % (osname, release) + elif osname[:3] == "aix": + return "%s-%s.%s" % (osname, version, release) + elif osname[:6] == "cygwin": + osname = "cygwin" + rel_re = re.compile(r'[\d.]+') + m = rel_re.match(release) + if m: + release = m.group() + elif osname[:6] == "darwin": + # + # For our purposes, we'll assume that the system version from + # distutils' perspective is what MACOSX_DEPLOYMENT_TARGET is set + # to. This makes the compatibility story a bit more sane because the + # machine is going to compile and link as if it were + # MACOSX_DEPLOYMENT_TARGET. + cfgvars = get_config_vars() + macver = cfgvars.get('MACOSX_DEPLOYMENT_TARGET') + + if True: + # Always calculate the release of the running machine, + # needed to determine if we can build fat binaries or not. + + macrelease = macver + # Get the system version. Reading this plist is a documented + # way to get the system version (see the documentation for + # the Gestalt Manager) + try: + f = open('/System/Library/CoreServices/SystemVersion.plist') + except IOError: + # We're on a plain darwin box, fall back to the default + # behaviour. + pass + else: + try: + m = re.search(r'<key>ProductUserVisibleVersion</key>\s*' + r'<string>(.*?)</string>', f.read()) + finally: + f.close() + if m is not None: + macrelease = '.'.join(m.group(1).split('.')[:2]) + # else: fall back to the default behaviour + + if not macver: + macver = macrelease + + if macver: + release = macver + osname = "macosx" + + if ((macrelease + '.') >= '10.4.' and + '-arch' in get_config_vars().get('CFLAGS', '').strip()): + # The universal build will build fat binaries, but not on + # systems before 10.4 + # + # Try to detect 4-way universal builds, those have machine-type + # 'universal' instead of 'fat'. + + machine = 'fat' + cflags = get_config_vars().get('CFLAGS') + + archs = re.findall(r'-arch\s+(\S+)', cflags) + archs = tuple(sorted(set(archs))) + + if len(archs) == 1: + machine = archs[0] + elif archs == ('i386', 'ppc'): + machine = 'fat' + elif archs == ('i386', 'x86_64'): + machine = 'intel' + elif archs == ('i386', 'ppc', 'x86_64'): + machine = 'fat3' + elif archs == ('ppc64', 'x86_64'): + machine = 'fat64' + elif archs == ('i386', 'ppc', 'ppc64', 'x86_64'): + machine = 'universal' + else: + raise ValueError( + "Don't know machine value for archs=%r" % (archs,)) + + elif machine == 'i386': + # On OSX the machine type returned by uname is always the + # 32-bit variant, even if the executable architecture is + # the 64-bit variant + if sys.maxsize >= 2**32: + machine = 'x86_64' + + elif machine in ('PowerPC', 'Power_Macintosh'): + # Pick a sane name for the PPC architecture. + # See 'i386' case + if sys.maxsize >= 2**32: + machine = 'ppc64' + else: + machine = 'ppc' + + return "%s-%s-%s" % (osname, release, machine) + + +def get_python_version(): + return _PY_VERSION_SHORT + + +def _print_dict(title, data): + for index, (key, value) in enumerate(sorted(data.items())): + if index == 0: + print('%s: ' % (title)) + print('\t%s = "%s"' % (key, value)) + + +def _main(): + """Display all information sysconfig detains.""" + print('Platform: "%s"' % get_platform()) + print('Python version: "%s"' % get_python_version()) + print('Current installation scheme: "%s"' % _get_default_scheme()) + print() + _print_dict('Paths', get_paths()) + print() + _print_dict('Variables', get_config_vars()) + + +if __name__ == '__main__': + _main() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/tarfile.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/tarfile.py new file mode 100644 index 0000000..d66d856 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/_backport/tarfile.py @@ -0,0 +1,2607 @@ +#------------------------------------------------------------------- +# tarfile.py +#------------------------------------------------------------------- +# Copyright (C) 2002 Lars Gustaebel <lars@gustaebel.de> +# All rights reserved. +# +# Permission is hereby granted, free of charge, to any person +# obtaining a copy of this software and associated documentation +# files (the "Software"), to deal in the Software without +# restriction, including without limitation the rights to use, +# copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the +# Software is furnished to do so, subject to the following +# conditions: +# +# The above copyright notice and this permission notice shall be +# included in all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES +# OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT +# HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, +# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR +# OTHER DEALINGS IN THE SOFTWARE. +# +from __future__ import print_function + +"""Read from and write to tar format archives. +""" + +__version__ = "$Revision$" + +version = "0.9.0" +__author__ = "Lars Gust\u00e4bel (lars@gustaebel.de)" +__date__ = "$Date: 2011-02-25 17:42:01 +0200 (Fri, 25 Feb 2011) $" +__cvsid__ = "$Id: tarfile.py 88586 2011-02-25 15:42:01Z marc-andre.lemburg $" +__credits__ = "Gustavo Niemeyer, Niels Gust\u00e4bel, Richard Townsend." + +#--------- +# Imports +#--------- +import sys +import os +import stat +import errno +import time +import struct +import copy +import re + +try: + import grp, pwd +except ImportError: + grp = pwd = None + +# os.symlink on Windows prior to 6.0 raises NotImplementedError +symlink_exception = (AttributeError, NotImplementedError) +try: + # WindowsError (1314) will be raised if the caller does not hold the + # SeCreateSymbolicLinkPrivilege privilege + symlink_exception += (WindowsError,) +except NameError: + pass + +# from tarfile import * +__all__ = ["TarFile", "TarInfo", "is_tarfile", "TarError"] + +if sys.version_info[0] < 3: + import __builtin__ as builtins +else: + import builtins + +_open = builtins.open # Since 'open' is TarFile.open + +#--------------------------------------------------------- +# tar constants +#--------------------------------------------------------- +NUL = b"\0" # the null character +BLOCKSIZE = 512 # length of processing blocks +RECORDSIZE = BLOCKSIZE * 20 # length of records +GNU_MAGIC = b"ustar \0" # magic gnu tar string +POSIX_MAGIC = b"ustar\x0000" # magic posix tar string + +LENGTH_NAME = 100 # maximum length of a filename +LENGTH_LINK = 100 # maximum length of a linkname +LENGTH_PREFIX = 155 # maximum length of the prefix field + +REGTYPE = b"0" # regular file +AREGTYPE = b"\0" # regular file +LNKTYPE = b"1" # link (inside tarfile) +SYMTYPE = b"2" # symbolic link +CHRTYPE = b"3" # character special device +BLKTYPE = b"4" # block special device +DIRTYPE = b"5" # directory +FIFOTYPE = b"6" # fifo special device +CONTTYPE = b"7" # contiguous file + +GNUTYPE_LONGNAME = b"L" # GNU tar longname +GNUTYPE_LONGLINK = b"K" # GNU tar longlink +GNUTYPE_SPARSE = b"S" # GNU tar sparse file + +XHDTYPE = b"x" # POSIX.1-2001 extended header +XGLTYPE = b"g" # POSIX.1-2001 global header +SOLARIS_XHDTYPE = b"X" # Solaris extended header + +USTAR_FORMAT = 0 # POSIX.1-1988 (ustar) format +GNU_FORMAT = 1 # GNU tar format +PAX_FORMAT = 2 # POSIX.1-2001 (pax) format +DEFAULT_FORMAT = GNU_FORMAT + +#--------------------------------------------------------- +# tarfile constants +#--------------------------------------------------------- +# File types that tarfile supports: +SUPPORTED_TYPES = (REGTYPE, AREGTYPE, LNKTYPE, + SYMTYPE, DIRTYPE, FIFOTYPE, + CONTTYPE, CHRTYPE, BLKTYPE, + GNUTYPE_LONGNAME, GNUTYPE_LONGLINK, + GNUTYPE_SPARSE) + +# File types that will be treated as a regular file. +REGULAR_TYPES = (REGTYPE, AREGTYPE, + CONTTYPE, GNUTYPE_SPARSE) + +# File types that are part of the GNU tar format. +GNU_TYPES = (GNUTYPE_LONGNAME, GNUTYPE_LONGLINK, + GNUTYPE_SPARSE) + +# Fields from a pax header that override a TarInfo attribute. +PAX_FIELDS = ("path", "linkpath", "size", "mtime", + "uid", "gid", "uname", "gname") + +# Fields from a pax header that are affected by hdrcharset. +PAX_NAME_FIELDS = set(("path", "linkpath", "uname", "gname")) + +# Fields in a pax header that are numbers, all other fields +# are treated as strings. +PAX_NUMBER_FIELDS = { + "atime": float, + "ctime": float, + "mtime": float, + "uid": int, + "gid": int, + "size": int +} + +#--------------------------------------------------------- +# Bits used in the mode field, values in octal. +#--------------------------------------------------------- +S_IFLNK = 0o120000 # symbolic link +S_IFREG = 0o100000 # regular file +S_IFBLK = 0o060000 # block device +S_IFDIR = 0o040000 # directory +S_IFCHR = 0o020000 # character device +S_IFIFO = 0o010000 # fifo + +TSUID = 0o4000 # set UID on execution +TSGID = 0o2000 # set GID on execution +TSVTX = 0o1000 # reserved + +TUREAD = 0o400 # read by owner +TUWRITE = 0o200 # write by owner +TUEXEC = 0o100 # execute/search by owner +TGREAD = 0o040 # read by group +TGWRITE = 0o020 # write by group +TGEXEC = 0o010 # execute/search by group +TOREAD = 0o004 # read by other +TOWRITE = 0o002 # write by other +TOEXEC = 0o001 # execute/search by other + +#--------------------------------------------------------- +# initialization +#--------------------------------------------------------- +if os.name in ("nt", "ce"): + ENCODING = "utf-8" +else: + ENCODING = sys.getfilesystemencoding() + +#--------------------------------------------------------- +# Some useful functions +#--------------------------------------------------------- + +def stn(s, length, encoding, errors): + """Convert a string to a null-terminated bytes object. + """ + s = s.encode(encoding, errors) + return s[:length] + (length - len(s)) * NUL + +def nts(s, encoding, errors): + """Convert a null-terminated bytes object to a string. + """ + p = s.find(b"\0") + if p != -1: + s = s[:p] + return s.decode(encoding, errors) + +def nti(s): + """Convert a number field to a python number. + """ + # There are two possible encodings for a number field, see + # itn() below. + if s[0] != chr(0o200): + try: + n = int(nts(s, "ascii", "strict") or "0", 8) + except ValueError: + raise InvalidHeaderError("invalid header") + else: + n = 0 + for i in range(len(s) - 1): + n <<= 8 + n += ord(s[i + 1]) + return n + +def itn(n, digits=8, format=DEFAULT_FORMAT): + """Convert a python number to a number field. + """ + # POSIX 1003.1-1988 requires numbers to be encoded as a string of + # octal digits followed by a null-byte, this allows values up to + # (8**(digits-1))-1. GNU tar allows storing numbers greater than + # that if necessary. A leading 0o200 byte indicates this particular + # encoding, the following digits-1 bytes are a big-endian + # representation. This allows values up to (256**(digits-1))-1. + if 0 <= n < 8 ** (digits - 1): + s = ("%0*o" % (digits - 1, n)).encode("ascii") + NUL + else: + if format != GNU_FORMAT or n >= 256 ** (digits - 1): + raise ValueError("overflow in number field") + + if n < 0: + # XXX We mimic GNU tar's behaviour with negative numbers, + # this could raise OverflowError. + n = struct.unpack("L", struct.pack("l", n))[0] + + s = bytearray() + for i in range(digits - 1): + s.insert(0, n & 0o377) + n >>= 8 + s.insert(0, 0o200) + return s + +def calc_chksums(buf): + """Calculate the checksum for a member's header by summing up all + characters except for the chksum field which is treated as if + it was filled with spaces. According to the GNU tar sources, + some tars (Sun and NeXT) calculate chksum with signed char, + which will be different if there are chars in the buffer with + the high bit set. So we calculate two checksums, unsigned and + signed. + """ + unsigned_chksum = 256 + sum(struct.unpack("148B", buf[:148]) + struct.unpack("356B", buf[156:512])) + signed_chksum = 256 + sum(struct.unpack("148b", buf[:148]) + struct.unpack("356b", buf[156:512])) + return unsigned_chksum, signed_chksum + +def copyfileobj(src, dst, length=None): + """Copy length bytes from fileobj src to fileobj dst. + If length is None, copy the entire content. + """ + if length == 0: + return + if length is None: + while True: + buf = src.read(16*1024) + if not buf: + break + dst.write(buf) + return + + BUFSIZE = 16 * 1024 + blocks, remainder = divmod(length, BUFSIZE) + for b in range(blocks): + buf = src.read(BUFSIZE) + if len(buf) < BUFSIZE: + raise IOError("end of file reached") + dst.write(buf) + + if remainder != 0: + buf = src.read(remainder) + if len(buf) < remainder: + raise IOError("end of file reached") + dst.write(buf) + return + +filemode_table = ( + ((S_IFLNK, "l"), + (S_IFREG, "-"), + (S_IFBLK, "b"), + (S_IFDIR, "d"), + (S_IFCHR, "c"), + (S_IFIFO, "p")), + + ((TUREAD, "r"),), + ((TUWRITE, "w"),), + ((TUEXEC|TSUID, "s"), + (TSUID, "S"), + (TUEXEC, "x")), + + ((TGREAD, "r"),), + ((TGWRITE, "w"),), + ((TGEXEC|TSGID, "s"), + (TSGID, "S"), + (TGEXEC, "x")), + + ((TOREAD, "r"),), + ((TOWRITE, "w"),), + ((TOEXEC|TSVTX, "t"), + (TSVTX, "T"), + (TOEXEC, "x")) +) + +def filemode(mode): + """Convert a file's mode to a string of the form + -rwxrwxrwx. + Used by TarFile.list() + """ + perm = [] + for table in filemode_table: + for bit, char in table: + if mode & bit == bit: + perm.append(char) + break + else: + perm.append("-") + return "".join(perm) + +class TarError(Exception): + """Base exception.""" + pass +class ExtractError(TarError): + """General exception for extract errors.""" + pass +class ReadError(TarError): + """Exception for unreadable tar archives.""" + pass +class CompressionError(TarError): + """Exception for unavailable compression methods.""" + pass +class StreamError(TarError): + """Exception for unsupported operations on stream-like TarFiles.""" + pass +class HeaderError(TarError): + """Base exception for header errors.""" + pass +class EmptyHeaderError(HeaderError): + """Exception for empty headers.""" + pass +class TruncatedHeaderError(HeaderError): + """Exception for truncated headers.""" + pass +class EOFHeaderError(HeaderError): + """Exception for end of file headers.""" + pass +class InvalidHeaderError(HeaderError): + """Exception for invalid headers.""" + pass +class SubsequentHeaderError(HeaderError): + """Exception for missing and invalid extended headers.""" + pass + +#--------------------------- +# internal stream interface +#--------------------------- +class _LowLevelFile(object): + """Low-level file object. Supports reading and writing. + It is used instead of a regular file object for streaming + access. + """ + + def __init__(self, name, mode): + mode = { + "r": os.O_RDONLY, + "w": os.O_WRONLY | os.O_CREAT | os.O_TRUNC, + }[mode] + if hasattr(os, "O_BINARY"): + mode |= os.O_BINARY + self.fd = os.open(name, mode, 0o666) + + def close(self): + os.close(self.fd) + + def read(self, size): + return os.read(self.fd, size) + + def write(self, s): + os.write(self.fd, s) + +class _Stream(object): + """Class that serves as an adapter between TarFile and + a stream-like object. The stream-like object only + needs to have a read() or write() method and is accessed + blockwise. Use of gzip or bzip2 compression is possible. + A stream-like object could be for example: sys.stdin, + sys.stdout, a socket, a tape device etc. + + _Stream is intended to be used only internally. + """ + + def __init__(self, name, mode, comptype, fileobj, bufsize): + """Construct a _Stream object. + """ + self._extfileobj = True + if fileobj is None: + fileobj = _LowLevelFile(name, mode) + self._extfileobj = False + + if comptype == '*': + # Enable transparent compression detection for the + # stream interface + fileobj = _StreamProxy(fileobj) + comptype = fileobj.getcomptype() + + self.name = name or "" + self.mode = mode + self.comptype = comptype + self.fileobj = fileobj + self.bufsize = bufsize + self.buf = b"" + self.pos = 0 + self.closed = False + + try: + if comptype == "gz": + try: + import zlib + except ImportError: + raise CompressionError("zlib module is not available") + self.zlib = zlib + self.crc = zlib.crc32(b"") + if mode == "r": + self._init_read_gz() + else: + self._init_write_gz() + + if comptype == "bz2": + try: + import bz2 + except ImportError: + raise CompressionError("bz2 module is not available") + if mode == "r": + self.dbuf = b"" + self.cmp = bz2.BZ2Decompressor() + else: + self.cmp = bz2.BZ2Compressor() + except: + if not self._extfileobj: + self.fileobj.close() + self.closed = True + raise + + def __del__(self): + if hasattr(self, "closed") and not self.closed: + self.close() + + def _init_write_gz(self): + """Initialize for writing with gzip compression. + """ + self.cmp = self.zlib.compressobj(9, self.zlib.DEFLATED, + -self.zlib.MAX_WBITS, + self.zlib.DEF_MEM_LEVEL, + 0) + timestamp = struct.pack("<L", int(time.time())) + self.__write(b"\037\213\010\010" + timestamp + b"\002\377") + if self.name.endswith(".gz"): + self.name = self.name[:-3] + # RFC1952 says we must use ISO-8859-1 for the FNAME field. + self.__write(self.name.encode("iso-8859-1", "replace") + NUL) + + def write(self, s): + """Write string s to the stream. + """ + if self.comptype == "gz": + self.crc = self.zlib.crc32(s, self.crc) + self.pos += len(s) + if self.comptype != "tar": + s = self.cmp.compress(s) + self.__write(s) + + def __write(self, s): + """Write string s to the stream if a whole new block + is ready to be written. + """ + self.buf += s + while len(self.buf) > self.bufsize: + self.fileobj.write(self.buf[:self.bufsize]) + self.buf = self.buf[self.bufsize:] + + def close(self): + """Close the _Stream object. No operation should be + done on it afterwards. + """ + if self.closed: + return + + if self.mode == "w" and self.comptype != "tar": + self.buf += self.cmp.flush() + + if self.mode == "w" and self.buf: + self.fileobj.write(self.buf) + self.buf = b"" + if self.comptype == "gz": + # The native zlib crc is an unsigned 32-bit integer, but + # the Python wrapper implicitly casts that to a signed C + # long. So, on a 32-bit box self.crc may "look negative", + # while the same crc on a 64-bit box may "look positive". + # To avoid irksome warnings from the `struct` module, force + # it to look positive on all boxes. + self.fileobj.write(struct.pack("<L", self.crc & 0xffffffff)) + self.fileobj.write(struct.pack("<L", self.pos & 0xffffFFFF)) + + if not self._extfileobj: + self.fileobj.close() + + self.closed = True + + def _init_read_gz(self): + """Initialize for reading a gzip compressed fileobj. + """ + self.cmp = self.zlib.decompressobj(-self.zlib.MAX_WBITS) + self.dbuf = b"" + + # taken from gzip.GzipFile with some alterations + if self.__read(2) != b"\037\213": + raise ReadError("not a gzip file") + if self.__read(1) != b"\010": + raise CompressionError("unsupported compression method") + + flag = ord(self.__read(1)) + self.__read(6) + + if flag & 4: + xlen = ord(self.__read(1)) + 256 * ord(self.__read(1)) + self.read(xlen) + if flag & 8: + while True: + s = self.__read(1) + if not s or s == NUL: + break + if flag & 16: + while True: + s = self.__read(1) + if not s or s == NUL: + break + if flag & 2: + self.__read(2) + + def tell(self): + """Return the stream's file pointer position. + """ + return self.pos + + def seek(self, pos=0): + """Set the stream's file pointer to pos. Negative seeking + is forbidden. + """ + if pos - self.pos >= 0: + blocks, remainder = divmod(pos - self.pos, self.bufsize) + for i in range(blocks): + self.read(self.bufsize) + self.read(remainder) + else: + raise StreamError("seeking backwards is not allowed") + return self.pos + + def read(self, size=None): + """Return the next size number of bytes from the stream. + If size is not defined, return all bytes of the stream + up to EOF. + """ + if size is None: + t = [] + while True: + buf = self._read(self.bufsize) + if not buf: + break + t.append(buf) + buf = "".join(t) + else: + buf = self._read(size) + self.pos += len(buf) + return buf + + def _read(self, size): + """Return size bytes from the stream. + """ + if self.comptype == "tar": + return self.__read(size) + + c = len(self.dbuf) + while c < size: + buf = self.__read(self.bufsize) + if not buf: + break + try: + buf = self.cmp.decompress(buf) + except IOError: + raise ReadError("invalid compressed data") + self.dbuf += buf + c += len(buf) + buf = self.dbuf[:size] + self.dbuf = self.dbuf[size:] + return buf + + def __read(self, size): + """Return size bytes from stream. If internal buffer is empty, + read another block from the stream. + """ + c = len(self.buf) + while c < size: + buf = self.fileobj.read(self.bufsize) + if not buf: + break + self.buf += buf + c += len(buf) + buf = self.buf[:size] + self.buf = self.buf[size:] + return buf +# class _Stream + +class _StreamProxy(object): + """Small proxy class that enables transparent compression + detection for the Stream interface (mode 'r|*'). + """ + + def __init__(self, fileobj): + self.fileobj = fileobj + self.buf = self.fileobj.read(BLOCKSIZE) + + def read(self, size): + self.read = self.fileobj.read + return self.buf + + def getcomptype(self): + if self.buf.startswith(b"\037\213\010"): + return "gz" + if self.buf.startswith(b"BZh91"): + return "bz2" + return "tar" + + def close(self): + self.fileobj.close() +# class StreamProxy + +class _BZ2Proxy(object): + """Small proxy class that enables external file object + support for "r:bz2" and "w:bz2" modes. This is actually + a workaround for a limitation in bz2 module's BZ2File + class which (unlike gzip.GzipFile) has no support for + a file object argument. + """ + + blocksize = 16 * 1024 + + def __init__(self, fileobj, mode): + self.fileobj = fileobj + self.mode = mode + self.name = getattr(self.fileobj, "name", None) + self.init() + + def init(self): + import bz2 + self.pos = 0 + if self.mode == "r": + self.bz2obj = bz2.BZ2Decompressor() + self.fileobj.seek(0) + self.buf = b"" + else: + self.bz2obj = bz2.BZ2Compressor() + + def read(self, size): + x = len(self.buf) + while x < size: + raw = self.fileobj.read(self.blocksize) + if not raw: + break + data = self.bz2obj.decompress(raw) + self.buf += data + x += len(data) + + buf = self.buf[:size] + self.buf = self.buf[size:] + self.pos += len(buf) + return buf + + def seek(self, pos): + if pos < self.pos: + self.init() + self.read(pos - self.pos) + + def tell(self): + return self.pos + + def write(self, data): + self.pos += len(data) + raw = self.bz2obj.compress(data) + self.fileobj.write(raw) + + def close(self): + if self.mode == "w": + raw = self.bz2obj.flush() + self.fileobj.write(raw) +# class _BZ2Proxy + +#------------------------ +# Extraction file object +#------------------------ +class _FileInFile(object): + """A thin wrapper around an existing file object that + provides a part of its data as an individual file + object. + """ + + def __init__(self, fileobj, offset, size, blockinfo=None): + self.fileobj = fileobj + self.offset = offset + self.size = size + self.position = 0 + + if blockinfo is None: + blockinfo = [(0, size)] + + # Construct a map with data and zero blocks. + self.map_index = 0 + self.map = [] + lastpos = 0 + realpos = self.offset + for offset, size in blockinfo: + if offset > lastpos: + self.map.append((False, lastpos, offset, None)) + self.map.append((True, offset, offset + size, realpos)) + realpos += size + lastpos = offset + size + if lastpos < self.size: + self.map.append((False, lastpos, self.size, None)) + + def seekable(self): + if not hasattr(self.fileobj, "seekable"): + # XXX gzip.GzipFile and bz2.BZ2File + return True + return self.fileobj.seekable() + + def tell(self): + """Return the current file position. + """ + return self.position + + def seek(self, position): + """Seek to a position in the file. + """ + self.position = position + + def read(self, size=None): + """Read data from the file. + """ + if size is None: + size = self.size - self.position + else: + size = min(size, self.size - self.position) + + buf = b"" + while size > 0: + while True: + data, start, stop, offset = self.map[self.map_index] + if start <= self.position < stop: + break + else: + self.map_index += 1 + if self.map_index == len(self.map): + self.map_index = 0 + length = min(size, stop - self.position) + if data: + self.fileobj.seek(offset + (self.position - start)) + buf += self.fileobj.read(length) + else: + buf += NUL * length + size -= length + self.position += length + return buf +#class _FileInFile + + +class ExFileObject(object): + """File-like object for reading an archive member. + Is returned by TarFile.extractfile(). + """ + blocksize = 1024 + + def __init__(self, tarfile, tarinfo): + self.fileobj = _FileInFile(tarfile.fileobj, + tarinfo.offset_data, + tarinfo.size, + tarinfo.sparse) + self.name = tarinfo.name + self.mode = "r" + self.closed = False + self.size = tarinfo.size + + self.position = 0 + self.buffer = b"" + + def readable(self): + return True + + def writable(self): + return False + + def seekable(self): + return self.fileobj.seekable() + + def read(self, size=None): + """Read at most size bytes from the file. If size is not + present or None, read all data until EOF is reached. + """ + if self.closed: + raise ValueError("I/O operation on closed file") + + buf = b"" + if self.buffer: + if size is None: + buf = self.buffer + self.buffer = b"" + else: + buf = self.buffer[:size] + self.buffer = self.buffer[size:] + + if size is None: + buf += self.fileobj.read() + else: + buf += self.fileobj.read(size - len(buf)) + + self.position += len(buf) + return buf + + # XXX TextIOWrapper uses the read1() method. + read1 = read + + def readline(self, size=-1): + """Read one entire line from the file. If size is present + and non-negative, return a string with at most that + size, which may be an incomplete line. + """ + if self.closed: + raise ValueError("I/O operation on closed file") + + pos = self.buffer.find(b"\n") + 1 + if pos == 0: + # no newline found. + while True: + buf = self.fileobj.read(self.blocksize) + self.buffer += buf + if not buf or b"\n" in buf: + pos = self.buffer.find(b"\n") + 1 + if pos == 0: + # no newline found. + pos = len(self.buffer) + break + + if size != -1: + pos = min(size, pos) + + buf = self.buffer[:pos] + self.buffer = self.buffer[pos:] + self.position += len(buf) + return buf + + def readlines(self): + """Return a list with all remaining lines. + """ + result = [] + while True: + line = self.readline() + if not line: break + result.append(line) + return result + + def tell(self): + """Return the current file position. + """ + if self.closed: + raise ValueError("I/O operation on closed file") + + return self.position + + def seek(self, pos, whence=os.SEEK_SET): + """Seek to a position in the file. + """ + if self.closed: + raise ValueError("I/O operation on closed file") + + if whence == os.SEEK_SET: + self.position = min(max(pos, 0), self.size) + elif whence == os.SEEK_CUR: + if pos < 0: + self.position = max(self.position + pos, 0) + else: + self.position = min(self.position + pos, self.size) + elif whence == os.SEEK_END: + self.position = max(min(self.size + pos, self.size), 0) + else: + raise ValueError("Invalid argument") + + self.buffer = b"" + self.fileobj.seek(self.position) + + def close(self): + """Close the file object. + """ + self.closed = True + + def __iter__(self): + """Get an iterator over the file's lines. + """ + while True: + line = self.readline() + if not line: + break + yield line +#class ExFileObject + +#------------------ +# Exported Classes +#------------------ +class TarInfo(object): + """Informational class which holds the details about an + archive member given by a tar header block. + TarInfo objects are returned by TarFile.getmember(), + TarFile.getmembers() and TarFile.gettarinfo() and are + usually created internally. + """ + + __slots__ = ("name", "mode", "uid", "gid", "size", "mtime", + "chksum", "type", "linkname", "uname", "gname", + "devmajor", "devminor", + "offset", "offset_data", "pax_headers", "sparse", + "tarfile", "_sparse_structs", "_link_target") + + def __init__(self, name=""): + """Construct a TarInfo object. name is the optional name + of the member. + """ + self.name = name # member name + self.mode = 0o644 # file permissions + self.uid = 0 # user id + self.gid = 0 # group id + self.size = 0 # file size + self.mtime = 0 # modification time + self.chksum = 0 # header checksum + self.type = REGTYPE # member type + self.linkname = "" # link name + self.uname = "" # user name + self.gname = "" # group name + self.devmajor = 0 # device major number + self.devminor = 0 # device minor number + + self.offset = 0 # the tar header starts here + self.offset_data = 0 # the file's data starts here + + self.sparse = None # sparse member information + self.pax_headers = {} # pax header information + + # In pax headers the "name" and "linkname" field are called + # "path" and "linkpath". + def _getpath(self): + return self.name + def _setpath(self, name): + self.name = name + path = property(_getpath, _setpath) + + def _getlinkpath(self): + return self.linkname + def _setlinkpath(self, linkname): + self.linkname = linkname + linkpath = property(_getlinkpath, _setlinkpath) + + def __repr__(self): + return "<%s %r at %#x>" % (self.__class__.__name__,self.name,id(self)) + + def get_info(self): + """Return the TarInfo's attributes as a dictionary. + """ + info = { + "name": self.name, + "mode": self.mode & 0o7777, + "uid": self.uid, + "gid": self.gid, + "size": self.size, + "mtime": self.mtime, + "chksum": self.chksum, + "type": self.type, + "linkname": self.linkname, + "uname": self.uname, + "gname": self.gname, + "devmajor": self.devmajor, + "devminor": self.devminor + } + + if info["type"] == DIRTYPE and not info["name"].endswith("/"): + info["name"] += "/" + + return info + + def tobuf(self, format=DEFAULT_FORMAT, encoding=ENCODING, errors="surrogateescape"): + """Return a tar header as a string of 512 byte blocks. + """ + info = self.get_info() + + if format == USTAR_FORMAT: + return self.create_ustar_header(info, encoding, errors) + elif format == GNU_FORMAT: + return self.create_gnu_header(info, encoding, errors) + elif format == PAX_FORMAT: + return self.create_pax_header(info, encoding) + else: + raise ValueError("invalid format") + + def create_ustar_header(self, info, encoding, errors): + """Return the object as a ustar header block. + """ + info["magic"] = POSIX_MAGIC + + if len(info["linkname"]) > LENGTH_LINK: + raise ValueError("linkname is too long") + + if len(info["name"]) > LENGTH_NAME: + info["prefix"], info["name"] = self._posix_split_name(info["name"]) + + return self._create_header(info, USTAR_FORMAT, encoding, errors) + + def create_gnu_header(self, info, encoding, errors): + """Return the object as a GNU header block sequence. + """ + info["magic"] = GNU_MAGIC + + buf = b"" + if len(info["linkname"]) > LENGTH_LINK: + buf += self._create_gnu_long_header(info["linkname"], GNUTYPE_LONGLINK, encoding, errors) + + if len(info["name"]) > LENGTH_NAME: + buf += self._create_gnu_long_header(info["name"], GNUTYPE_LONGNAME, encoding, errors) + + return buf + self._create_header(info, GNU_FORMAT, encoding, errors) + + def create_pax_header(self, info, encoding): + """Return the object as a ustar header block. If it cannot be + represented this way, prepend a pax extended header sequence + with supplement information. + """ + info["magic"] = POSIX_MAGIC + pax_headers = self.pax_headers.copy() + + # Test string fields for values that exceed the field length or cannot + # be represented in ASCII encoding. + for name, hname, length in ( + ("name", "path", LENGTH_NAME), ("linkname", "linkpath", LENGTH_LINK), + ("uname", "uname", 32), ("gname", "gname", 32)): + + if hname in pax_headers: + # The pax header has priority. + continue + + # Try to encode the string as ASCII. + try: + info[name].encode("ascii", "strict") + except UnicodeEncodeError: + pax_headers[hname] = info[name] + continue + + if len(info[name]) > length: + pax_headers[hname] = info[name] + + # Test number fields for values that exceed the field limit or values + # that like to be stored as float. + for name, digits in (("uid", 8), ("gid", 8), ("size", 12), ("mtime", 12)): + if name in pax_headers: + # The pax header has priority. Avoid overflow. + info[name] = 0 + continue + + val = info[name] + if not 0 <= val < 8 ** (digits - 1) or isinstance(val, float): + pax_headers[name] = str(val) + info[name] = 0 + + # Create a pax extended header if necessary. + if pax_headers: + buf = self._create_pax_generic_header(pax_headers, XHDTYPE, encoding) + else: + buf = b"" + + return buf + self._create_header(info, USTAR_FORMAT, "ascii", "replace") + + @classmethod + def create_pax_global_header(cls, pax_headers): + """Return the object as a pax global header block sequence. + """ + return cls._create_pax_generic_header(pax_headers, XGLTYPE, "utf8") + + def _posix_split_name(self, name): + """Split a name longer than 100 chars into a prefix + and a name part. + """ + prefix = name[:LENGTH_PREFIX + 1] + while prefix and prefix[-1] != "/": + prefix = prefix[:-1] + + name = name[len(prefix):] + prefix = prefix[:-1] + + if not prefix or len(name) > LENGTH_NAME: + raise ValueError("name is too long") + return prefix, name + + @staticmethod + def _create_header(info, format, encoding, errors): + """Return a header block. info is a dictionary with file + information, format must be one of the *_FORMAT constants. + """ + parts = [ + stn(info.get("name", ""), 100, encoding, errors), + itn(info.get("mode", 0) & 0o7777, 8, format), + itn(info.get("uid", 0), 8, format), + itn(info.get("gid", 0), 8, format), + itn(info.get("size", 0), 12, format), + itn(info.get("mtime", 0), 12, format), + b" ", # checksum field + info.get("type", REGTYPE), + stn(info.get("linkname", ""), 100, encoding, errors), + info.get("magic", POSIX_MAGIC), + stn(info.get("uname", ""), 32, encoding, errors), + stn(info.get("gname", ""), 32, encoding, errors), + itn(info.get("devmajor", 0), 8, format), + itn(info.get("devminor", 0), 8, format), + stn(info.get("prefix", ""), 155, encoding, errors) + ] + + buf = struct.pack("%ds" % BLOCKSIZE, b"".join(parts)) + chksum = calc_chksums(buf[-BLOCKSIZE:])[0] + buf = buf[:-364] + ("%06o\0" % chksum).encode("ascii") + buf[-357:] + return buf + + @staticmethod + def _create_payload(payload): + """Return the string payload filled with zero bytes + up to the next 512 byte border. + """ + blocks, remainder = divmod(len(payload), BLOCKSIZE) + if remainder > 0: + payload += (BLOCKSIZE - remainder) * NUL + return payload + + @classmethod + def _create_gnu_long_header(cls, name, type, encoding, errors): + """Return a GNUTYPE_LONGNAME or GNUTYPE_LONGLINK sequence + for name. + """ + name = name.encode(encoding, errors) + NUL + + info = {} + info["name"] = "././@LongLink" + info["type"] = type + info["size"] = len(name) + info["magic"] = GNU_MAGIC + + # create extended header + name blocks. + return cls._create_header(info, USTAR_FORMAT, encoding, errors) + \ + cls._create_payload(name) + + @classmethod + def _create_pax_generic_header(cls, pax_headers, type, encoding): + """Return a POSIX.1-2008 extended or global header sequence + that contains a list of keyword, value pairs. The values + must be strings. + """ + # Check if one of the fields contains surrogate characters and thereby + # forces hdrcharset=BINARY, see _proc_pax() for more information. + binary = False + for keyword, value in pax_headers.items(): + try: + value.encode("utf8", "strict") + except UnicodeEncodeError: + binary = True + break + + records = b"" + if binary: + # Put the hdrcharset field at the beginning of the header. + records += b"21 hdrcharset=BINARY\n" + + for keyword, value in pax_headers.items(): + keyword = keyword.encode("utf8") + if binary: + # Try to restore the original byte representation of `value'. + # Needless to say, that the encoding must match the string. + value = value.encode(encoding, "surrogateescape") + else: + value = value.encode("utf8") + + l = len(keyword) + len(value) + 3 # ' ' + '=' + '\n' + n = p = 0 + while True: + n = l + len(str(p)) + if n == p: + break + p = n + records += bytes(str(p), "ascii") + b" " + keyword + b"=" + value + b"\n" + + # We use a hardcoded "././@PaxHeader" name like star does + # instead of the one that POSIX recommends. + info = {} + info["name"] = "././@PaxHeader" + info["type"] = type + info["size"] = len(records) + info["magic"] = POSIX_MAGIC + + # Create pax header + record blocks. + return cls._create_header(info, USTAR_FORMAT, "ascii", "replace") + \ + cls._create_payload(records) + + @classmethod + def frombuf(cls, buf, encoding, errors): + """Construct a TarInfo object from a 512 byte bytes object. + """ + if len(buf) == 0: + raise EmptyHeaderError("empty header") + if len(buf) != BLOCKSIZE: + raise TruncatedHeaderError("truncated header") + if buf.count(NUL) == BLOCKSIZE: + raise EOFHeaderError("end of file header") + + chksum = nti(buf[148:156]) + if chksum not in calc_chksums(buf): + raise InvalidHeaderError("bad checksum") + + obj = cls() + obj.name = nts(buf[0:100], encoding, errors) + obj.mode = nti(buf[100:108]) + obj.uid = nti(buf[108:116]) + obj.gid = nti(buf[116:124]) + obj.size = nti(buf[124:136]) + obj.mtime = nti(buf[136:148]) + obj.chksum = chksum + obj.type = buf[156:157] + obj.linkname = nts(buf[157:257], encoding, errors) + obj.uname = nts(buf[265:297], encoding, errors) + obj.gname = nts(buf[297:329], encoding, errors) + obj.devmajor = nti(buf[329:337]) + obj.devminor = nti(buf[337:345]) + prefix = nts(buf[345:500], encoding, errors) + + # Old V7 tar format represents a directory as a regular + # file with a trailing slash. + if obj.type == AREGTYPE and obj.name.endswith("/"): + obj.type = DIRTYPE + + # The old GNU sparse format occupies some of the unused + # space in the buffer for up to 4 sparse structures. + # Save the them for later processing in _proc_sparse(). + if obj.type == GNUTYPE_SPARSE: + pos = 386 + structs = [] + for i in range(4): + try: + offset = nti(buf[pos:pos + 12]) + numbytes = nti(buf[pos + 12:pos + 24]) + except ValueError: + break + structs.append((offset, numbytes)) + pos += 24 + isextended = bool(buf[482]) + origsize = nti(buf[483:495]) + obj._sparse_structs = (structs, isextended, origsize) + + # Remove redundant slashes from directories. + if obj.isdir(): + obj.name = obj.name.rstrip("/") + + # Reconstruct a ustar longname. + if prefix and obj.type not in GNU_TYPES: + obj.name = prefix + "/" + obj.name + return obj + + @classmethod + def fromtarfile(cls, tarfile): + """Return the next TarInfo object from TarFile object + tarfile. + """ + buf = tarfile.fileobj.read(BLOCKSIZE) + obj = cls.frombuf(buf, tarfile.encoding, tarfile.errors) + obj.offset = tarfile.fileobj.tell() - BLOCKSIZE + return obj._proc_member(tarfile) + + #-------------------------------------------------------------------------- + # The following are methods that are called depending on the type of a + # member. The entry point is _proc_member() which can be overridden in a + # subclass to add custom _proc_*() methods. A _proc_*() method MUST + # implement the following + # operations: + # 1. Set self.offset_data to the position where the data blocks begin, + # if there is data that follows. + # 2. Set tarfile.offset to the position where the next member's header will + # begin. + # 3. Return self or another valid TarInfo object. + def _proc_member(self, tarfile): + """Choose the right processing method depending on + the type and call it. + """ + if self.type in (GNUTYPE_LONGNAME, GNUTYPE_LONGLINK): + return self._proc_gnulong(tarfile) + elif self.type == GNUTYPE_SPARSE: + return self._proc_sparse(tarfile) + elif self.type in (XHDTYPE, XGLTYPE, SOLARIS_XHDTYPE): + return self._proc_pax(tarfile) + else: + return self._proc_builtin(tarfile) + + def _proc_builtin(self, tarfile): + """Process a builtin type or an unknown type which + will be treated as a regular file. + """ + self.offset_data = tarfile.fileobj.tell() + offset = self.offset_data + if self.isreg() or self.type not in SUPPORTED_TYPES: + # Skip the following data blocks. + offset += self._block(self.size) + tarfile.offset = offset + + # Patch the TarInfo object with saved global + # header information. + self._apply_pax_info(tarfile.pax_headers, tarfile.encoding, tarfile.errors) + + return self + + def _proc_gnulong(self, tarfile): + """Process the blocks that hold a GNU longname + or longlink member. + """ + buf = tarfile.fileobj.read(self._block(self.size)) + + # Fetch the next header and process it. + try: + next = self.fromtarfile(tarfile) + except HeaderError: + raise SubsequentHeaderError("missing or bad subsequent header") + + # Patch the TarInfo object from the next header with + # the longname information. + next.offset = self.offset + if self.type == GNUTYPE_LONGNAME: + next.name = nts(buf, tarfile.encoding, tarfile.errors) + elif self.type == GNUTYPE_LONGLINK: + next.linkname = nts(buf, tarfile.encoding, tarfile.errors) + + return next + + def _proc_sparse(self, tarfile): + """Process a GNU sparse header plus extra headers. + """ + # We already collected some sparse structures in frombuf(). + structs, isextended, origsize = self._sparse_structs + del self._sparse_structs + + # Collect sparse structures from extended header blocks. + while isextended: + buf = tarfile.fileobj.read(BLOCKSIZE) + pos = 0 + for i in range(21): + try: + offset = nti(buf[pos:pos + 12]) + numbytes = nti(buf[pos + 12:pos + 24]) + except ValueError: + break + if offset and numbytes: + structs.append((offset, numbytes)) + pos += 24 + isextended = bool(buf[504]) + self.sparse = structs + + self.offset_data = tarfile.fileobj.tell() + tarfile.offset = self.offset_data + self._block(self.size) + self.size = origsize + return self + + def _proc_pax(self, tarfile): + """Process an extended or global header as described in + POSIX.1-2008. + """ + # Read the header information. + buf = tarfile.fileobj.read(self._block(self.size)) + + # A pax header stores supplemental information for either + # the following file (extended) or all following files + # (global). + if self.type == XGLTYPE: + pax_headers = tarfile.pax_headers + else: + pax_headers = tarfile.pax_headers.copy() + + # Check if the pax header contains a hdrcharset field. This tells us + # the encoding of the path, linkpath, uname and gname fields. Normally, + # these fields are UTF-8 encoded but since POSIX.1-2008 tar + # implementations are allowed to store them as raw binary strings if + # the translation to UTF-8 fails. + match = re.search(br"\d+ hdrcharset=([^\n]+)\n", buf) + if match is not None: + pax_headers["hdrcharset"] = match.group(1).decode("utf8") + + # For the time being, we don't care about anything other than "BINARY". + # The only other value that is currently allowed by the standard is + # "ISO-IR 10646 2000 UTF-8" in other words UTF-8. + hdrcharset = pax_headers.get("hdrcharset") + if hdrcharset == "BINARY": + encoding = tarfile.encoding + else: + encoding = "utf8" + + # Parse pax header information. A record looks like that: + # "%d %s=%s\n" % (length, keyword, value). length is the size + # of the complete record including the length field itself and + # the newline. keyword and value are both UTF-8 encoded strings. + regex = re.compile(br"(\d+) ([^=]+)=") + pos = 0 + while True: + match = regex.match(buf, pos) + if not match: + break + + length, keyword = match.groups() + length = int(length) + value = buf[match.end(2) + 1:match.start(1) + length - 1] + + # Normally, we could just use "utf8" as the encoding and "strict" + # as the error handler, but we better not take the risk. For + # example, GNU tar <= 1.23 is known to store filenames it cannot + # translate to UTF-8 as raw strings (unfortunately without a + # hdrcharset=BINARY header). + # We first try the strict standard encoding, and if that fails we + # fall back on the user's encoding and error handler. + keyword = self._decode_pax_field(keyword, "utf8", "utf8", + tarfile.errors) + if keyword in PAX_NAME_FIELDS: + value = self._decode_pax_field(value, encoding, tarfile.encoding, + tarfile.errors) + else: + value = self._decode_pax_field(value, "utf8", "utf8", + tarfile.errors) + + pax_headers[keyword] = value + pos += length + + # Fetch the next header. + try: + next = self.fromtarfile(tarfile) + except HeaderError: + raise SubsequentHeaderError("missing or bad subsequent header") + + # Process GNU sparse information. + if "GNU.sparse.map" in pax_headers: + # GNU extended sparse format version 0.1. + self._proc_gnusparse_01(next, pax_headers) + + elif "GNU.sparse.size" in pax_headers: + # GNU extended sparse format version 0.0. + self._proc_gnusparse_00(next, pax_headers, buf) + + elif pax_headers.get("GNU.sparse.major") == "1" and pax_headers.get("GNU.sparse.minor") == "0": + # GNU extended sparse format version 1.0. + self._proc_gnusparse_10(next, pax_headers, tarfile) + + if self.type in (XHDTYPE, SOLARIS_XHDTYPE): + # Patch the TarInfo object with the extended header info. + next._apply_pax_info(pax_headers, tarfile.encoding, tarfile.errors) + next.offset = self.offset + + if "size" in pax_headers: + # If the extended header replaces the size field, + # we need to recalculate the offset where the next + # header starts. + offset = next.offset_data + if next.isreg() or next.type not in SUPPORTED_TYPES: + offset += next._block(next.size) + tarfile.offset = offset + + return next + + def _proc_gnusparse_00(self, next, pax_headers, buf): + """Process a GNU tar extended sparse header, version 0.0. + """ + offsets = [] + for match in re.finditer(br"\d+ GNU.sparse.offset=(\d+)\n", buf): + offsets.append(int(match.group(1))) + numbytes = [] + for match in re.finditer(br"\d+ GNU.sparse.numbytes=(\d+)\n", buf): + numbytes.append(int(match.group(1))) + next.sparse = list(zip(offsets, numbytes)) + + def _proc_gnusparse_01(self, next, pax_headers): + """Process a GNU tar extended sparse header, version 0.1. + """ + sparse = [int(x) for x in pax_headers["GNU.sparse.map"].split(",")] + next.sparse = list(zip(sparse[::2], sparse[1::2])) + + def _proc_gnusparse_10(self, next, pax_headers, tarfile): + """Process a GNU tar extended sparse header, version 1.0. + """ + fields = None + sparse = [] + buf = tarfile.fileobj.read(BLOCKSIZE) + fields, buf = buf.split(b"\n", 1) + fields = int(fields) + while len(sparse) < fields * 2: + if b"\n" not in buf: + buf += tarfile.fileobj.read(BLOCKSIZE) + number, buf = buf.split(b"\n", 1) + sparse.append(int(number)) + next.offset_data = tarfile.fileobj.tell() + next.sparse = list(zip(sparse[::2], sparse[1::2])) + + def _apply_pax_info(self, pax_headers, encoding, errors): + """Replace fields with supplemental information from a previous + pax extended or global header. + """ + for keyword, value in pax_headers.items(): + if keyword == "GNU.sparse.name": + setattr(self, "path", value) + elif keyword == "GNU.sparse.size": + setattr(self, "size", int(value)) + elif keyword == "GNU.sparse.realsize": + setattr(self, "size", int(value)) + elif keyword in PAX_FIELDS: + if keyword in PAX_NUMBER_FIELDS: + try: + value = PAX_NUMBER_FIELDS[keyword](value) + except ValueError: + value = 0 + if keyword == "path": + value = value.rstrip("/") + setattr(self, keyword, value) + + self.pax_headers = pax_headers.copy() + + def _decode_pax_field(self, value, encoding, fallback_encoding, fallback_errors): + """Decode a single field from a pax record. + """ + try: + return value.decode(encoding, "strict") + except UnicodeDecodeError: + return value.decode(fallback_encoding, fallback_errors) + + def _block(self, count): + """Round up a byte count by BLOCKSIZE and return it, + e.g. _block(834) => 1024. + """ + blocks, remainder = divmod(count, BLOCKSIZE) + if remainder: + blocks += 1 + return blocks * BLOCKSIZE + + def isreg(self): + return self.type in REGULAR_TYPES + def isfile(self): + return self.isreg() + def isdir(self): + return self.type == DIRTYPE + def issym(self): + return self.type == SYMTYPE + def islnk(self): + return self.type == LNKTYPE + def ischr(self): + return self.type == CHRTYPE + def isblk(self): + return self.type == BLKTYPE + def isfifo(self): + return self.type == FIFOTYPE + def issparse(self): + return self.sparse is not None + def isdev(self): + return self.type in (CHRTYPE, BLKTYPE, FIFOTYPE) +# class TarInfo + +class TarFile(object): + """The TarFile Class provides an interface to tar archives. + """ + + debug = 0 # May be set from 0 (no msgs) to 3 (all msgs) + + dereference = False # If true, add content of linked file to the + # tar file, else the link. + + ignore_zeros = False # If true, skips empty or invalid blocks and + # continues processing. + + errorlevel = 1 # If 0, fatal errors only appear in debug + # messages (if debug >= 0). If > 0, errors + # are passed to the caller as exceptions. + + format = DEFAULT_FORMAT # The format to use when creating an archive. + + encoding = ENCODING # Encoding for 8-bit character strings. + + errors = None # Error handler for unicode conversion. + + tarinfo = TarInfo # The default TarInfo class to use. + + fileobject = ExFileObject # The default ExFileObject class to use. + + def __init__(self, name=None, mode="r", fileobj=None, format=None, + tarinfo=None, dereference=None, ignore_zeros=None, encoding=None, + errors="surrogateescape", pax_headers=None, debug=None, errorlevel=None): + """Open an (uncompressed) tar archive `name'. `mode' is either 'r' to + read from an existing archive, 'a' to append data to an existing + file or 'w' to create a new file overwriting an existing one. `mode' + defaults to 'r'. + If `fileobj' is given, it is used for reading or writing data. If it + can be determined, `mode' is overridden by `fileobj's mode. + `fileobj' is not closed, when TarFile is closed. + """ + if len(mode) > 1 or mode not in "raw": + raise ValueError("mode must be 'r', 'a' or 'w'") + self.mode = mode + self._mode = {"r": "rb", "a": "r+b", "w": "wb"}[mode] + + if not fileobj: + if self.mode == "a" and not os.path.exists(name): + # Create nonexistent files in append mode. + self.mode = "w" + self._mode = "wb" + fileobj = bltn_open(name, self._mode) + self._extfileobj = False + else: + if name is None and hasattr(fileobj, "name"): + name = fileobj.name + if hasattr(fileobj, "mode"): + self._mode = fileobj.mode + self._extfileobj = True + self.name = os.path.abspath(name) if name else None + self.fileobj = fileobj + + # Init attributes. + if format is not None: + self.format = format + if tarinfo is not None: + self.tarinfo = tarinfo + if dereference is not None: + self.dereference = dereference + if ignore_zeros is not None: + self.ignore_zeros = ignore_zeros + if encoding is not None: + self.encoding = encoding + self.errors = errors + + if pax_headers is not None and self.format == PAX_FORMAT: + self.pax_headers = pax_headers + else: + self.pax_headers = {} + + if debug is not None: + self.debug = debug + if errorlevel is not None: + self.errorlevel = errorlevel + + # Init datastructures. + self.closed = False + self.members = [] # list of members as TarInfo objects + self._loaded = False # flag if all members have been read + self.offset = self.fileobj.tell() + # current position in the archive file + self.inodes = {} # dictionary caching the inodes of + # archive members already added + + try: + if self.mode == "r": + self.firstmember = None + self.firstmember = self.next() + + if self.mode == "a": + # Move to the end of the archive, + # before the first empty block. + while True: + self.fileobj.seek(self.offset) + try: + tarinfo = self.tarinfo.fromtarfile(self) + self.members.append(tarinfo) + except EOFHeaderError: + self.fileobj.seek(self.offset) + break + except HeaderError as e: + raise ReadError(str(e)) + + if self.mode in "aw": + self._loaded = True + + if self.pax_headers: + buf = self.tarinfo.create_pax_global_header(self.pax_headers.copy()) + self.fileobj.write(buf) + self.offset += len(buf) + except: + if not self._extfileobj: + self.fileobj.close() + self.closed = True + raise + + #-------------------------------------------------------------------------- + # Below are the classmethods which act as alternate constructors to the + # TarFile class. The open() method is the only one that is needed for + # public use; it is the "super"-constructor and is able to select an + # adequate "sub"-constructor for a particular compression using the mapping + # from OPEN_METH. + # + # This concept allows one to subclass TarFile without losing the comfort of + # the super-constructor. A sub-constructor is registered and made available + # by adding it to the mapping in OPEN_METH. + + @classmethod + def open(cls, name=None, mode="r", fileobj=None, bufsize=RECORDSIZE, **kwargs): + """Open a tar archive for reading, writing or appending. Return + an appropriate TarFile class. + + mode: + 'r' or 'r:*' open for reading with transparent compression + 'r:' open for reading exclusively uncompressed + 'r:gz' open for reading with gzip compression + 'r:bz2' open for reading with bzip2 compression + 'a' or 'a:' open for appending, creating the file if necessary + 'w' or 'w:' open for writing without compression + 'w:gz' open for writing with gzip compression + 'w:bz2' open for writing with bzip2 compression + + 'r|*' open a stream of tar blocks with transparent compression + 'r|' open an uncompressed stream of tar blocks for reading + 'r|gz' open a gzip compressed stream of tar blocks + 'r|bz2' open a bzip2 compressed stream of tar blocks + 'w|' open an uncompressed stream for writing + 'w|gz' open a gzip compressed stream for writing + 'w|bz2' open a bzip2 compressed stream for writing + """ + + if not name and not fileobj: + raise ValueError("nothing to open") + + if mode in ("r", "r:*"): + # Find out which *open() is appropriate for opening the file. + for comptype in cls.OPEN_METH: + func = getattr(cls, cls.OPEN_METH[comptype]) + if fileobj is not None: + saved_pos = fileobj.tell() + try: + return func(name, "r", fileobj, **kwargs) + except (ReadError, CompressionError) as e: + if fileobj is not None: + fileobj.seek(saved_pos) + continue + raise ReadError("file could not be opened successfully") + + elif ":" in mode: + filemode, comptype = mode.split(":", 1) + filemode = filemode or "r" + comptype = comptype or "tar" + + # Select the *open() function according to + # given compression. + if comptype in cls.OPEN_METH: + func = getattr(cls, cls.OPEN_METH[comptype]) + else: + raise CompressionError("unknown compression type %r" % comptype) + return func(name, filemode, fileobj, **kwargs) + + elif "|" in mode: + filemode, comptype = mode.split("|", 1) + filemode = filemode or "r" + comptype = comptype or "tar" + + if filemode not in "rw": + raise ValueError("mode must be 'r' or 'w'") + + stream = _Stream(name, filemode, comptype, fileobj, bufsize) + try: + t = cls(name, filemode, stream, **kwargs) + except: + stream.close() + raise + t._extfileobj = False + return t + + elif mode in "aw": + return cls.taropen(name, mode, fileobj, **kwargs) + + raise ValueError("undiscernible mode") + + @classmethod + def taropen(cls, name, mode="r", fileobj=None, **kwargs): + """Open uncompressed tar archive name for reading or writing. + """ + if len(mode) > 1 or mode not in "raw": + raise ValueError("mode must be 'r', 'a' or 'w'") + return cls(name, mode, fileobj, **kwargs) + + @classmethod + def gzopen(cls, name, mode="r", fileobj=None, compresslevel=9, **kwargs): + """Open gzip compressed tar archive name for reading or writing. + Appending is not allowed. + """ + if len(mode) > 1 or mode not in "rw": + raise ValueError("mode must be 'r' or 'w'") + + try: + import gzip + gzip.GzipFile + except (ImportError, AttributeError): + raise CompressionError("gzip module is not available") + + extfileobj = fileobj is not None + try: + fileobj = gzip.GzipFile(name, mode + "b", compresslevel, fileobj) + t = cls.taropen(name, mode, fileobj, **kwargs) + except IOError: + if not extfileobj and fileobj is not None: + fileobj.close() + if fileobj is None: + raise + raise ReadError("not a gzip file") + except: + if not extfileobj and fileobj is not None: + fileobj.close() + raise + t._extfileobj = extfileobj + return t + + @classmethod + def bz2open(cls, name, mode="r", fileobj=None, compresslevel=9, **kwargs): + """Open bzip2 compressed tar archive name for reading or writing. + Appending is not allowed. + """ + if len(mode) > 1 or mode not in "rw": + raise ValueError("mode must be 'r' or 'w'.") + + try: + import bz2 + except ImportError: + raise CompressionError("bz2 module is not available") + + if fileobj is not None: + fileobj = _BZ2Proxy(fileobj, mode) + else: + fileobj = bz2.BZ2File(name, mode, compresslevel=compresslevel) + + try: + t = cls.taropen(name, mode, fileobj, **kwargs) + except (IOError, EOFError): + fileobj.close() + raise ReadError("not a bzip2 file") + t._extfileobj = False + return t + + # All *open() methods are registered here. + OPEN_METH = { + "tar": "taropen", # uncompressed tar + "gz": "gzopen", # gzip compressed tar + "bz2": "bz2open" # bzip2 compressed tar + } + + #-------------------------------------------------------------------------- + # The public methods which TarFile provides: + + def close(self): + """Close the TarFile. In write-mode, two finishing zero blocks are + appended to the archive. + """ + if self.closed: + return + + if self.mode in "aw": + self.fileobj.write(NUL * (BLOCKSIZE * 2)) + self.offset += (BLOCKSIZE * 2) + # fill up the end with zero-blocks + # (like option -b20 for tar does) + blocks, remainder = divmod(self.offset, RECORDSIZE) + if remainder > 0: + self.fileobj.write(NUL * (RECORDSIZE - remainder)) + + if not self._extfileobj: + self.fileobj.close() + self.closed = True + + def getmember(self, name): + """Return a TarInfo object for member `name'. If `name' can not be + found in the archive, KeyError is raised. If a member occurs more + than once in the archive, its last occurrence is assumed to be the + most up-to-date version. + """ + tarinfo = self._getmember(name) + if tarinfo is None: + raise KeyError("filename %r not found" % name) + return tarinfo + + def getmembers(self): + """Return the members of the archive as a list of TarInfo objects. The + list has the same order as the members in the archive. + """ + self._check() + if not self._loaded: # if we want to obtain a list of + self._load() # all members, we first have to + # scan the whole archive. + return self.members + + def getnames(self): + """Return the members of the archive as a list of their names. It has + the same order as the list returned by getmembers(). + """ + return [tarinfo.name for tarinfo in self.getmembers()] + + def gettarinfo(self, name=None, arcname=None, fileobj=None): + """Create a TarInfo object for either the file `name' or the file + object `fileobj' (using os.fstat on its file descriptor). You can + modify some of the TarInfo's attributes before you add it using + addfile(). If given, `arcname' specifies an alternative name for the + file in the archive. + """ + self._check("aw") + + # When fileobj is given, replace name by + # fileobj's real name. + if fileobj is not None: + name = fileobj.name + + # Building the name of the member in the archive. + # Backward slashes are converted to forward slashes, + # Absolute paths are turned to relative paths. + if arcname is None: + arcname = name + drv, arcname = os.path.splitdrive(arcname) + arcname = arcname.replace(os.sep, "/") + arcname = arcname.lstrip("/") + + # Now, fill the TarInfo object with + # information specific for the file. + tarinfo = self.tarinfo() + tarinfo.tarfile = self + + # Use os.stat or os.lstat, depending on platform + # and if symlinks shall be resolved. + if fileobj is None: + if hasattr(os, "lstat") and not self.dereference: + statres = os.lstat(name) + else: + statres = os.stat(name) + else: + statres = os.fstat(fileobj.fileno()) + linkname = "" + + stmd = statres.st_mode + if stat.S_ISREG(stmd): + inode = (statres.st_ino, statres.st_dev) + if not self.dereference and statres.st_nlink > 1 and \ + inode in self.inodes and arcname != self.inodes[inode]: + # Is it a hardlink to an already + # archived file? + type = LNKTYPE + linkname = self.inodes[inode] + else: + # The inode is added only if its valid. + # For win32 it is always 0. + type = REGTYPE + if inode[0]: + self.inodes[inode] = arcname + elif stat.S_ISDIR(stmd): + type = DIRTYPE + elif stat.S_ISFIFO(stmd): + type = FIFOTYPE + elif stat.S_ISLNK(stmd): + type = SYMTYPE + linkname = os.readlink(name) + elif stat.S_ISCHR(stmd): + type = CHRTYPE + elif stat.S_ISBLK(stmd): + type = BLKTYPE + else: + return None + + # Fill the TarInfo object with all + # information we can get. + tarinfo.name = arcname + tarinfo.mode = stmd + tarinfo.uid = statres.st_uid + tarinfo.gid = statres.st_gid + if type == REGTYPE: + tarinfo.size = statres.st_size + else: + tarinfo.size = 0 + tarinfo.mtime = statres.st_mtime + tarinfo.type = type + tarinfo.linkname = linkname + if pwd: + try: + tarinfo.uname = pwd.getpwuid(tarinfo.uid)[0] + except KeyError: + pass + if grp: + try: + tarinfo.gname = grp.getgrgid(tarinfo.gid)[0] + except KeyError: + pass + + if type in (CHRTYPE, BLKTYPE): + if hasattr(os, "major") and hasattr(os, "minor"): + tarinfo.devmajor = os.major(statres.st_rdev) + tarinfo.devminor = os.minor(statres.st_rdev) + return tarinfo + + def list(self, verbose=True): + """Print a table of contents to sys.stdout. If `verbose' is False, only + the names of the members are printed. If it is True, an `ls -l'-like + output is produced. + """ + self._check() + + for tarinfo in self: + if verbose: + print(filemode(tarinfo.mode), end=' ') + print("%s/%s" % (tarinfo.uname or tarinfo.uid, + tarinfo.gname or tarinfo.gid), end=' ') + if tarinfo.ischr() or tarinfo.isblk(): + print("%10s" % ("%d,%d" \ + % (tarinfo.devmajor, tarinfo.devminor)), end=' ') + else: + print("%10d" % tarinfo.size, end=' ') + print("%d-%02d-%02d %02d:%02d:%02d" \ + % time.localtime(tarinfo.mtime)[:6], end=' ') + + print(tarinfo.name + ("/" if tarinfo.isdir() else ""), end=' ') + + if verbose: + if tarinfo.issym(): + print("->", tarinfo.linkname, end=' ') + if tarinfo.islnk(): + print("link to", tarinfo.linkname, end=' ') + print() + + def add(self, name, arcname=None, recursive=True, exclude=None, filter=None): + """Add the file `name' to the archive. `name' may be any type of file + (directory, fifo, symbolic link, etc.). If given, `arcname' + specifies an alternative name for the file in the archive. + Directories are added recursively by default. This can be avoided by + setting `recursive' to False. `exclude' is a function that should + return True for each filename to be excluded. `filter' is a function + that expects a TarInfo object argument and returns the changed + TarInfo object, if it returns None the TarInfo object will be + excluded from the archive. + """ + self._check("aw") + + if arcname is None: + arcname = name + + # Exclude pathnames. + if exclude is not None: + import warnings + warnings.warn("use the filter argument instead", + DeprecationWarning, 2) + if exclude(name): + self._dbg(2, "tarfile: Excluded %r" % name) + return + + # Skip if somebody tries to archive the archive... + if self.name is not None and os.path.abspath(name) == self.name: + self._dbg(2, "tarfile: Skipped %r" % name) + return + + self._dbg(1, name) + + # Create a TarInfo object from the file. + tarinfo = self.gettarinfo(name, arcname) + + if tarinfo is None: + self._dbg(1, "tarfile: Unsupported type %r" % name) + return + + # Change or exclude the TarInfo object. + if filter is not None: + tarinfo = filter(tarinfo) + if tarinfo is None: + self._dbg(2, "tarfile: Excluded %r" % name) + return + + # Append the tar header and data to the archive. + if tarinfo.isreg(): + f = bltn_open(name, "rb") + self.addfile(tarinfo, f) + f.close() + + elif tarinfo.isdir(): + self.addfile(tarinfo) + if recursive: + for f in os.listdir(name): + self.add(os.path.join(name, f), os.path.join(arcname, f), + recursive, exclude, filter=filter) + + else: + self.addfile(tarinfo) + + def addfile(self, tarinfo, fileobj=None): + """Add the TarInfo object `tarinfo' to the archive. If `fileobj' is + given, tarinfo.size bytes are read from it and added to the archive. + You can create TarInfo objects using gettarinfo(). + On Windows platforms, `fileobj' should always be opened with mode + 'rb' to avoid irritation about the file size. + """ + self._check("aw") + + tarinfo = copy.copy(tarinfo) + + buf = tarinfo.tobuf(self.format, self.encoding, self.errors) + self.fileobj.write(buf) + self.offset += len(buf) + + # If there's data to follow, append it. + if fileobj is not None: + copyfileobj(fileobj, self.fileobj, tarinfo.size) + blocks, remainder = divmod(tarinfo.size, BLOCKSIZE) + if remainder > 0: + self.fileobj.write(NUL * (BLOCKSIZE - remainder)) + blocks += 1 + self.offset += blocks * BLOCKSIZE + + self.members.append(tarinfo) + + def extractall(self, path=".", members=None): + """Extract all members from the archive to the current working + directory and set owner, modification time and permissions on + directories afterwards. `path' specifies a different directory + to extract to. `members' is optional and must be a subset of the + list returned by getmembers(). + """ + directories = [] + + if members is None: + members = self + + for tarinfo in members: + if tarinfo.isdir(): + # Extract directories with a safe mode. + directories.append(tarinfo) + tarinfo = copy.copy(tarinfo) + tarinfo.mode = 0o700 + # Do not set_attrs directories, as we will do that further down + self.extract(tarinfo, path, set_attrs=not tarinfo.isdir()) + + # Reverse sort directories. + directories.sort(key=lambda a: a.name) + directories.reverse() + + # Set correct owner, mtime and filemode on directories. + for tarinfo in directories: + dirpath = os.path.join(path, tarinfo.name) + try: + self.chown(tarinfo, dirpath) + self.utime(tarinfo, dirpath) + self.chmod(tarinfo, dirpath) + except ExtractError as e: + if self.errorlevel > 1: + raise + else: + self._dbg(1, "tarfile: %s" % e) + + def extract(self, member, path="", set_attrs=True): + """Extract a member from the archive to the current working directory, + using its full name. Its file information is extracted as accurately + as possible. `member' may be a filename or a TarInfo object. You can + specify a different directory using `path'. File attributes (owner, + mtime, mode) are set unless `set_attrs' is False. + """ + self._check("r") + + if isinstance(member, str): + tarinfo = self.getmember(member) + else: + tarinfo = member + + # Prepare the link target for makelink(). + if tarinfo.islnk(): + tarinfo._link_target = os.path.join(path, tarinfo.linkname) + + try: + self._extract_member(tarinfo, os.path.join(path, tarinfo.name), + set_attrs=set_attrs) + except EnvironmentError as e: + if self.errorlevel > 0: + raise + else: + if e.filename is None: + self._dbg(1, "tarfile: %s" % e.strerror) + else: + self._dbg(1, "tarfile: %s %r" % (e.strerror, e.filename)) + except ExtractError as e: + if self.errorlevel > 1: + raise + else: + self._dbg(1, "tarfile: %s" % e) + + def extractfile(self, member): + """Extract a member from the archive as a file object. `member' may be + a filename or a TarInfo object. If `member' is a regular file, a + file-like object is returned. If `member' is a link, a file-like + object is constructed from the link's target. If `member' is none of + the above, None is returned. + The file-like object is read-only and provides the following + methods: read(), readline(), readlines(), seek() and tell() + """ + self._check("r") + + if isinstance(member, str): + tarinfo = self.getmember(member) + else: + tarinfo = member + + if tarinfo.isreg(): + return self.fileobject(self, tarinfo) + + elif tarinfo.type not in SUPPORTED_TYPES: + # If a member's type is unknown, it is treated as a + # regular file. + return self.fileobject(self, tarinfo) + + elif tarinfo.islnk() or tarinfo.issym(): + if isinstance(self.fileobj, _Stream): + # A small but ugly workaround for the case that someone tries + # to extract a (sym)link as a file-object from a non-seekable + # stream of tar blocks. + raise StreamError("cannot extract (sym)link as file object") + else: + # A (sym)link's file object is its target's file object. + return self.extractfile(self._find_link_target(tarinfo)) + else: + # If there's no data associated with the member (directory, chrdev, + # blkdev, etc.), return None instead of a file object. + return None + + def _extract_member(self, tarinfo, targetpath, set_attrs=True): + """Extract the TarInfo object tarinfo to a physical + file called targetpath. + """ + # Fetch the TarInfo object for the given name + # and build the destination pathname, replacing + # forward slashes to platform specific separators. + targetpath = targetpath.rstrip("/") + targetpath = targetpath.replace("/", os.sep) + + # Create all upper directories. + upperdirs = os.path.dirname(targetpath) + if upperdirs and not os.path.exists(upperdirs): + # Create directories that are not part of the archive with + # default permissions. + os.makedirs(upperdirs) + + if tarinfo.islnk() or tarinfo.issym(): + self._dbg(1, "%s -> %s" % (tarinfo.name, tarinfo.linkname)) + else: + self._dbg(1, tarinfo.name) + + if tarinfo.isreg(): + self.makefile(tarinfo, targetpath) + elif tarinfo.isdir(): + self.makedir(tarinfo, targetpath) + elif tarinfo.isfifo(): + self.makefifo(tarinfo, targetpath) + elif tarinfo.ischr() or tarinfo.isblk(): + self.makedev(tarinfo, targetpath) + elif tarinfo.islnk() or tarinfo.issym(): + self.makelink(tarinfo, targetpath) + elif tarinfo.type not in SUPPORTED_TYPES: + self.makeunknown(tarinfo, targetpath) + else: + self.makefile(tarinfo, targetpath) + + if set_attrs: + self.chown(tarinfo, targetpath) + if not tarinfo.issym(): + self.chmod(tarinfo, targetpath) + self.utime(tarinfo, targetpath) + + #-------------------------------------------------------------------------- + # Below are the different file methods. They are called via + # _extract_member() when extract() is called. They can be replaced in a + # subclass to implement other functionality. + + def makedir(self, tarinfo, targetpath): + """Make a directory called targetpath. + """ + try: + # Use a safe mode for the directory, the real mode is set + # later in _extract_member(). + os.mkdir(targetpath, 0o700) + except EnvironmentError as e: + if e.errno != errno.EEXIST: + raise + + def makefile(self, tarinfo, targetpath): + """Make a file called targetpath. + """ + source = self.fileobj + source.seek(tarinfo.offset_data) + target = bltn_open(targetpath, "wb") + if tarinfo.sparse is not None: + for offset, size in tarinfo.sparse: + target.seek(offset) + copyfileobj(source, target, size) + else: + copyfileobj(source, target, tarinfo.size) + target.seek(tarinfo.size) + target.truncate() + target.close() + + def makeunknown(self, tarinfo, targetpath): + """Make a file from a TarInfo object with an unknown type + at targetpath. + """ + self.makefile(tarinfo, targetpath) + self._dbg(1, "tarfile: Unknown file type %r, " \ + "extracted as regular file." % tarinfo.type) + + def makefifo(self, tarinfo, targetpath): + """Make a fifo called targetpath. + """ + if hasattr(os, "mkfifo"): + os.mkfifo(targetpath) + else: + raise ExtractError("fifo not supported by system") + + def makedev(self, tarinfo, targetpath): + """Make a character or block device called targetpath. + """ + if not hasattr(os, "mknod") or not hasattr(os, "makedev"): + raise ExtractError("special devices not supported by system") + + mode = tarinfo.mode + if tarinfo.isblk(): + mode |= stat.S_IFBLK + else: + mode |= stat.S_IFCHR + + os.mknod(targetpath, mode, + os.makedev(tarinfo.devmajor, tarinfo.devminor)) + + def makelink(self, tarinfo, targetpath): + """Make a (symbolic) link called targetpath. If it cannot be created + (platform limitation), we try to make a copy of the referenced file + instead of a link. + """ + try: + # For systems that support symbolic and hard links. + if tarinfo.issym(): + os.symlink(tarinfo.linkname, targetpath) + else: + # See extract(). + if os.path.exists(tarinfo._link_target): + os.link(tarinfo._link_target, targetpath) + else: + self._extract_member(self._find_link_target(tarinfo), + targetpath) + except symlink_exception: + if tarinfo.issym(): + linkpath = os.path.join(os.path.dirname(tarinfo.name), + tarinfo.linkname) + else: + linkpath = tarinfo.linkname + else: + try: + self._extract_member(self._find_link_target(tarinfo), + targetpath) + except KeyError: + raise ExtractError("unable to resolve link inside archive") + + def chown(self, tarinfo, targetpath): + """Set owner of targetpath according to tarinfo. + """ + if pwd and hasattr(os, "geteuid") and os.geteuid() == 0: + # We have to be root to do so. + try: + g = grp.getgrnam(tarinfo.gname)[2] + except KeyError: + g = tarinfo.gid + try: + u = pwd.getpwnam(tarinfo.uname)[2] + except KeyError: + u = tarinfo.uid + try: + if tarinfo.issym() and hasattr(os, "lchown"): + os.lchown(targetpath, u, g) + else: + if sys.platform != "os2emx": + os.chown(targetpath, u, g) + except EnvironmentError as e: + raise ExtractError("could not change owner") + + def chmod(self, tarinfo, targetpath): + """Set file permissions of targetpath according to tarinfo. + """ + if hasattr(os, 'chmod'): + try: + os.chmod(targetpath, tarinfo.mode) + except EnvironmentError as e: + raise ExtractError("could not change mode") + + def utime(self, tarinfo, targetpath): + """Set modification time of targetpath according to tarinfo. + """ + if not hasattr(os, 'utime'): + return + try: + os.utime(targetpath, (tarinfo.mtime, tarinfo.mtime)) + except EnvironmentError as e: + raise ExtractError("could not change modification time") + + #-------------------------------------------------------------------------- + def next(self): + """Return the next member of the archive as a TarInfo object, when + TarFile is opened for reading. Return None if there is no more + available. + """ + self._check("ra") + if self.firstmember is not None: + m = self.firstmember + self.firstmember = None + return m + + # Read the next block. + self.fileobj.seek(self.offset) + tarinfo = None + while True: + try: + tarinfo = self.tarinfo.fromtarfile(self) + except EOFHeaderError as e: + if self.ignore_zeros: + self._dbg(2, "0x%X: %s" % (self.offset, e)) + self.offset += BLOCKSIZE + continue + except InvalidHeaderError as e: + if self.ignore_zeros: + self._dbg(2, "0x%X: %s" % (self.offset, e)) + self.offset += BLOCKSIZE + continue + elif self.offset == 0: + raise ReadError(str(e)) + except EmptyHeaderError: + if self.offset == 0: + raise ReadError("empty file") + except TruncatedHeaderError as e: + if self.offset == 0: + raise ReadError(str(e)) + except SubsequentHeaderError as e: + raise ReadError(str(e)) + break + + if tarinfo is not None: + self.members.append(tarinfo) + else: + self._loaded = True + + return tarinfo + + #-------------------------------------------------------------------------- + # Little helper methods: + + def _getmember(self, name, tarinfo=None, normalize=False): + """Find an archive member by name from bottom to top. + If tarinfo is given, it is used as the starting point. + """ + # Ensure that all members have been loaded. + members = self.getmembers() + + # Limit the member search list up to tarinfo. + if tarinfo is not None: + members = members[:members.index(tarinfo)] + + if normalize: + name = os.path.normpath(name) + + for member in reversed(members): + if normalize: + member_name = os.path.normpath(member.name) + else: + member_name = member.name + + if name == member_name: + return member + + def _load(self): + """Read through the entire archive file and look for readable + members. + """ + while True: + tarinfo = self.next() + if tarinfo is None: + break + self._loaded = True + + def _check(self, mode=None): + """Check if TarFile is still open, and if the operation's mode + corresponds to TarFile's mode. + """ + if self.closed: + raise IOError("%s is closed" % self.__class__.__name__) + if mode is not None and self.mode not in mode: + raise IOError("bad operation for mode %r" % self.mode) + + def _find_link_target(self, tarinfo): + """Find the target member of a symlink or hardlink member in the + archive. + """ + if tarinfo.issym(): + # Always search the entire archive. + linkname = os.path.dirname(tarinfo.name) + "/" + tarinfo.linkname + limit = None + else: + # Search the archive before the link, because a hard link is + # just a reference to an already archived file. + linkname = tarinfo.linkname + limit = tarinfo + + member = self._getmember(linkname, tarinfo=limit, normalize=True) + if member is None: + raise KeyError("linkname %r not found" % linkname) + return member + + def __iter__(self): + """Provide an iterator object. + """ + if self._loaded: + return iter(self.members) + else: + return TarIter(self) + + def _dbg(self, level, msg): + """Write debugging output to sys.stderr. + """ + if level <= self.debug: + print(msg, file=sys.stderr) + + def __enter__(self): + self._check() + return self + + def __exit__(self, type, value, traceback): + if type is None: + self.close() + else: + # An exception occurred. We must not call close() because + # it would try to write end-of-archive blocks and padding. + if not self._extfileobj: + self.fileobj.close() + self.closed = True +# class TarFile + +class TarIter(object): + """Iterator Class. + + for tarinfo in TarFile(...): + suite... + """ + + def __init__(self, tarfile): + """Construct a TarIter object. + """ + self.tarfile = tarfile + self.index = 0 + def __iter__(self): + """Return iterator object. + """ + return self + + def __next__(self): + """Return the next item using TarFile's next() method. + When all members have been read, set TarFile as _loaded. + """ + # Fix for SF #1100429: Under rare circumstances it can + # happen that getmembers() is called during iteration, + # which will cause TarIter to stop prematurely. + if not self.tarfile._loaded: + tarinfo = self.tarfile.next() + if not tarinfo: + self.tarfile._loaded = True + raise StopIteration + else: + try: + tarinfo = self.tarfile.members[self.index] + except IndexError: + raise StopIteration + self.index += 1 + return tarinfo + + next = __next__ # for Python 2.x + +#-------------------- +# exported functions +#-------------------- +def is_tarfile(name): + """Return True if name points to a tar archive that we + are able to handle, else return False. + """ + try: + t = open(name) + t.close() + return True + except TarError: + return False + +bltn_open = open +open = TarFile.open diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/compat.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/compat.py new file mode 100644 index 0000000..ff328c8 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/compat.py @@ -0,0 +1,1120 @@ +# -*- coding: utf-8 -*- +# +# Copyright (C) 2013-2017 Vinay Sajip. +# Licensed to the Python Software Foundation under a contributor agreement. +# See LICENSE.txt and CONTRIBUTORS.txt. +# +from __future__ import absolute_import + +import os +import re +import sys + +try: + import ssl +except ImportError: # pragma: no cover + ssl = None + +if sys.version_info[0] < 3: # pragma: no cover + from StringIO import StringIO + string_types = basestring, + text_type = unicode + from types import FileType as file_type + import __builtin__ as builtins + import ConfigParser as configparser + from ._backport import shutil + from urlparse import urlparse, urlunparse, urljoin, urlsplit, urlunsplit + from urllib import (urlretrieve, quote as _quote, unquote, url2pathname, + pathname2url, ContentTooShortError, splittype) + + def quote(s): + if isinstance(s, unicode): + s = s.encode('utf-8') + return _quote(s) + + import urllib2 + from urllib2 import (Request, urlopen, URLError, HTTPError, + HTTPBasicAuthHandler, HTTPPasswordMgr, + HTTPHandler, HTTPRedirectHandler, + build_opener) + if ssl: + from urllib2 import HTTPSHandler + import httplib + import xmlrpclib + import Queue as queue + from HTMLParser import HTMLParser + import htmlentitydefs + raw_input = raw_input + from itertools import ifilter as filter + from itertools import ifilterfalse as filterfalse + + _userprog = None + def splituser(host): + """splituser('user[:passwd]@host[:port]') --> 'user[:passwd]', 'host[:port]'.""" + global _userprog + if _userprog is None: + import re + _userprog = re.compile('^(.*)@(.*)$') + + match = _userprog.match(host) + if match: return match.group(1, 2) + return None, host + +else: # pragma: no cover + from io import StringIO + string_types = str, + text_type = str + from io import TextIOWrapper as file_type + import builtins + import configparser + import shutil + from urllib.parse import (urlparse, urlunparse, urljoin, splituser, quote, + unquote, urlsplit, urlunsplit, splittype) + from urllib.request import (urlopen, urlretrieve, Request, url2pathname, + pathname2url, + HTTPBasicAuthHandler, HTTPPasswordMgr, + HTTPHandler, HTTPRedirectHandler, + build_opener) + if ssl: + from urllib.request import HTTPSHandler + from urllib.error import HTTPError, URLError, ContentTooShortError + import http.client as httplib + import urllib.request as urllib2 + import xmlrpc.client as xmlrpclib + import queue + from html.parser import HTMLParser + import html.entities as htmlentitydefs + raw_input = input + from itertools import filterfalse + filter = filter + +try: + from ssl import match_hostname, CertificateError +except ImportError: # pragma: no cover + class CertificateError(ValueError): + pass + + + def _dnsname_match(dn, hostname, max_wildcards=1): + """Matching according to RFC 6125, section 6.4.3 + + http://tools.ietf.org/html/rfc6125#section-6.4.3 + """ + pats = [] + if not dn: + return False + + parts = dn.split('.') + leftmost, remainder = parts[0], parts[1:] + + wildcards = leftmost.count('*') + if wildcards > max_wildcards: + # Issue #17980: avoid denials of service by refusing more + # than one wildcard per fragment. A survey of established + # policy among SSL implementations showed it to be a + # reasonable choice. + raise CertificateError( + "too many wildcards in certificate DNS name: " + repr(dn)) + + # speed up common case w/o wildcards + if not wildcards: + return dn.lower() == hostname.lower() + + # RFC 6125, section 6.4.3, subitem 1. + # The client SHOULD NOT attempt to match a presented identifier in which + # the wildcard character comprises a label other than the left-most label. + if leftmost == '*': + # When '*' is a fragment by itself, it matches a non-empty dotless + # fragment. + pats.append('[^.]+') + elif leftmost.startswith('xn--') or hostname.startswith('xn--'): + # RFC 6125, section 6.4.3, subitem 3. + # The client SHOULD NOT attempt to match a presented identifier + # where the wildcard character is embedded within an A-label or + # U-label of an internationalized domain name. + pats.append(re.escape(leftmost)) + else: + # Otherwise, '*' matches any dotless string, e.g. www* + pats.append(re.escape(leftmost).replace(r'\*', '[^.]*')) + + # add the remaining fragments, ignore any wildcards + for frag in remainder: + pats.append(re.escape(frag)) + + pat = re.compile(r'\A' + r'\.'.join(pats) + r'\Z', re.IGNORECASE) + return pat.match(hostname) + + + def match_hostname(cert, hostname): + """Verify that *cert* (in decoded format as returned by + SSLSocket.getpeercert()) matches the *hostname*. RFC 2818 and RFC 6125 + rules are followed, but IP addresses are not accepted for *hostname*. + + CertificateError is raised on failure. On success, the function + returns nothing. + """ + if not cert: + raise ValueError("empty or no certificate, match_hostname needs a " + "SSL socket or SSL context with either " + "CERT_OPTIONAL or CERT_REQUIRED") + dnsnames = [] + san = cert.get('subjectAltName', ()) + for key, value in san: + if key == 'DNS': + if _dnsname_match(value, hostname): + return + dnsnames.append(value) + if not dnsnames: + # The subject is only checked when there is no dNSName entry + # in subjectAltName + for sub in cert.get('subject', ()): + for key, value in sub: + # XXX according to RFC 2818, the most specific Common Name + # must be used. + if key == 'commonName': + if _dnsname_match(value, hostname): + return + dnsnames.append(value) + if len(dnsnames) > 1: + raise CertificateError("hostname %r " + "doesn't match either of %s" + % (hostname, ', '.join(map(repr, dnsnames)))) + elif len(dnsnames) == 1: + raise CertificateError("hostname %r " + "doesn't match %r" + % (hostname, dnsnames[0])) + else: + raise CertificateError("no appropriate commonName or " + "subjectAltName fields were found") + + +try: + from types import SimpleNamespace as Container +except ImportError: # pragma: no cover + class Container(object): + """ + A generic container for when multiple values need to be returned + """ + def __init__(self, **kwargs): + self.__dict__.update(kwargs) + + +try: + from shutil import which +except ImportError: # pragma: no cover + # Implementation from Python 3.3 + def which(cmd, mode=os.F_OK | os.X_OK, path=None): + """Given a command, mode, and a PATH string, return the path which + conforms to the given mode on the PATH, or None if there is no such + file. + + `mode` defaults to os.F_OK | os.X_OK. `path` defaults to the result + of os.environ.get("PATH"), or can be overridden with a custom search + path. + + """ + # Check that a given file can be accessed with the correct mode. + # Additionally check that `file` is not a directory, as on Windows + # directories pass the os.access check. + def _access_check(fn, mode): + return (os.path.exists(fn) and os.access(fn, mode) + and not os.path.isdir(fn)) + + # If we're given a path with a directory part, look it up directly rather + # than referring to PATH directories. This includes checking relative to the + # current directory, e.g. ./script + if os.path.dirname(cmd): + if _access_check(cmd, mode): + return cmd + return None + + if path is None: + path = os.environ.get("PATH", os.defpath) + if not path: + return None + path = path.split(os.pathsep) + + if sys.platform == "win32": + # The current directory takes precedence on Windows. + if not os.curdir in path: + path.insert(0, os.curdir) + + # PATHEXT is necessary to check on Windows. + pathext = os.environ.get("PATHEXT", "").split(os.pathsep) + # See if the given file matches any of the expected path extensions. + # This will allow us to short circuit when given "python.exe". + # If it does match, only test that one, otherwise we have to try + # others. + if any(cmd.lower().endswith(ext.lower()) for ext in pathext): + files = [cmd] + else: + files = [cmd + ext for ext in pathext] + else: + # On other platforms you don't have things like PATHEXT to tell you + # what file suffixes are executable, so just pass on cmd as-is. + files = [cmd] + + seen = set() + for dir in path: + normdir = os.path.normcase(dir) + if not normdir in seen: + seen.add(normdir) + for thefile in files: + name = os.path.join(dir, thefile) + if _access_check(name, mode): + return name + return None + + +# ZipFile is a context manager in 2.7, but not in 2.6 + +from zipfile import ZipFile as BaseZipFile + +if hasattr(BaseZipFile, '__enter__'): # pragma: no cover + ZipFile = BaseZipFile +else: # pragma: no cover + from zipfile import ZipExtFile as BaseZipExtFile + + class ZipExtFile(BaseZipExtFile): + def __init__(self, base): + self.__dict__.update(base.__dict__) + + def __enter__(self): + return self + + def __exit__(self, *exc_info): + self.close() + # return None, so if an exception occurred, it will propagate + + class ZipFile(BaseZipFile): + def __enter__(self): + return self + + def __exit__(self, *exc_info): + self.close() + # return None, so if an exception occurred, it will propagate + + def open(self, *args, **kwargs): + base = BaseZipFile.open(self, *args, **kwargs) + return ZipExtFile(base) + +try: + from platform import python_implementation +except ImportError: # pragma: no cover + def python_implementation(): + """Return a string identifying the Python implementation.""" + if 'PyPy' in sys.version: + return 'PyPy' + if os.name == 'java': + return 'Jython' + if sys.version.startswith('IronPython'): + return 'IronPython' + return 'CPython' + +try: + import sysconfig +except ImportError: # pragma: no cover + from ._backport import sysconfig + +try: + callable = callable +except NameError: # pragma: no cover + from collections import Callable + + def callable(obj): + return isinstance(obj, Callable) + + +try: + fsencode = os.fsencode + fsdecode = os.fsdecode +except AttributeError: # pragma: no cover + # Issue #99: on some systems (e.g. containerised), + # sys.getfilesystemencoding() returns None, and we need a real value, + # so fall back to utf-8. From the CPython 2.7 docs relating to Unix and + # sys.getfilesystemencoding(): the return value is "the user’s preference + # according to the result of nl_langinfo(CODESET), or None if the + # nl_langinfo(CODESET) failed." + _fsencoding = sys.getfilesystemencoding() or 'utf-8' + if _fsencoding == 'mbcs': + _fserrors = 'strict' + else: + _fserrors = 'surrogateescape' + + def fsencode(filename): + if isinstance(filename, bytes): + return filename + elif isinstance(filename, text_type): + return filename.encode(_fsencoding, _fserrors) + else: + raise TypeError("expect bytes or str, not %s" % + type(filename).__name__) + + def fsdecode(filename): + if isinstance(filename, text_type): + return filename + elif isinstance(filename, bytes): + return filename.decode(_fsencoding, _fserrors) + else: + raise TypeError("expect bytes or str, not %s" % + type(filename).__name__) + +try: + from tokenize import detect_encoding +except ImportError: # pragma: no cover + from codecs import BOM_UTF8, lookup + import re + + cookie_re = re.compile(r"coding[:=]\s*([-\w.]+)") + + def _get_normal_name(orig_enc): + """Imitates get_normal_name in tokenizer.c.""" + # Only care about the first 12 characters. + enc = orig_enc[:12].lower().replace("_", "-") + if enc == "utf-8" or enc.startswith("utf-8-"): + return "utf-8" + if enc in ("latin-1", "iso-8859-1", "iso-latin-1") or \ + enc.startswith(("latin-1-", "iso-8859-1-", "iso-latin-1-")): + return "iso-8859-1" + return orig_enc + + def detect_encoding(readline): + """ + The detect_encoding() function is used to detect the encoding that should + be used to decode a Python source file. It requires one argument, readline, + in the same way as the tokenize() generator. + + It will call readline a maximum of twice, and return the encoding used + (as a string) and a list of any lines (left as bytes) it has read in. + + It detects the encoding from the presence of a utf-8 bom or an encoding + cookie as specified in pep-0263. If both a bom and a cookie are present, + but disagree, a SyntaxError will be raised. If the encoding cookie is an + invalid charset, raise a SyntaxError. Note that if a utf-8 bom is found, + 'utf-8-sig' is returned. + + If no encoding is specified, then the default of 'utf-8' will be returned. + """ + try: + filename = readline.__self__.name + except AttributeError: + filename = None + bom_found = False + encoding = None + default = 'utf-8' + def read_or_stop(): + try: + return readline() + except StopIteration: + return b'' + + def find_cookie(line): + try: + # Decode as UTF-8. Either the line is an encoding declaration, + # in which case it should be pure ASCII, or it must be UTF-8 + # per default encoding. + line_string = line.decode('utf-8') + except UnicodeDecodeError: + msg = "invalid or missing encoding declaration" + if filename is not None: + msg = '{} for {!r}'.format(msg, filename) + raise SyntaxError(msg) + + matches = cookie_re.findall(line_string) + if not matches: + return None + encoding = _get_normal_name(matches[0]) + try: + codec = lookup(encoding) + except LookupError: + # This behaviour mimics the Python interpreter + if filename is None: + msg = "unknown encoding: " + encoding + else: + msg = "unknown encoding for {!r}: {}".format(filename, + encoding) + raise SyntaxError(msg) + + if bom_found: + if codec.name != 'utf-8': + # This behaviour mimics the Python interpreter + if filename is None: + msg = 'encoding problem: utf-8' + else: + msg = 'encoding problem for {!r}: utf-8'.format(filename) + raise SyntaxError(msg) + encoding += '-sig' + return encoding + + first = read_or_stop() + if first.startswith(BOM_UTF8): + bom_found = True + first = first[3:] + default = 'utf-8-sig' + if not first: + return default, [] + + encoding = find_cookie(first) + if encoding: + return encoding, [first] + + second = read_or_stop() + if not second: + return default, [first] + + encoding = find_cookie(second) + if encoding: + return encoding, [first, second] + + return default, [first, second] + +# For converting & <-> & etc. +try: + from html import escape +except ImportError: + from cgi import escape +if sys.version_info[:2] < (3, 4): + unescape = HTMLParser().unescape +else: + from html import unescape + +try: + from collections import ChainMap +except ImportError: # pragma: no cover + from collections import MutableMapping + + try: + from reprlib import recursive_repr as _recursive_repr + except ImportError: + def _recursive_repr(fillvalue='...'): + ''' + Decorator to make a repr function return fillvalue for a recursive + call + ''' + + def decorating_function(user_function): + repr_running = set() + + def wrapper(self): + key = id(self), get_ident() + if key in repr_running: + return fillvalue + repr_running.add(key) + try: + result = user_function(self) + finally: + repr_running.discard(key) + return result + + # Can't use functools.wraps() here because of bootstrap issues + wrapper.__module__ = getattr(user_function, '__module__') + wrapper.__doc__ = getattr(user_function, '__doc__') + wrapper.__name__ = getattr(user_function, '__name__') + wrapper.__annotations__ = getattr(user_function, '__annotations__', {}) + return wrapper + + return decorating_function + + class ChainMap(MutableMapping): + ''' A ChainMap groups multiple dicts (or other mappings) together + to create a single, updateable view. + + The underlying mappings are stored in a list. That list is public and can + accessed or updated using the *maps* attribute. There is no other state. + + Lookups search the underlying mappings successively until a key is found. + In contrast, writes, updates, and deletions only operate on the first + mapping. + + ''' + + def __init__(self, *maps): + '''Initialize a ChainMap by setting *maps* to the given mappings. + If no mappings are provided, a single empty dictionary is used. + + ''' + self.maps = list(maps) or [{}] # always at least one map + + def __missing__(self, key): + raise KeyError(key) + + def __getitem__(self, key): + for mapping in self.maps: + try: + return mapping[key] # can't use 'key in mapping' with defaultdict + except KeyError: + pass + return self.__missing__(key) # support subclasses that define __missing__ + + def get(self, key, default=None): + return self[key] if key in self else default + + def __len__(self): + return len(set().union(*self.maps)) # reuses stored hash values if possible + + def __iter__(self): + return iter(set().union(*self.maps)) + + def __contains__(self, key): + return any(key in m for m in self.maps) + + def __bool__(self): + return any(self.maps) + + @_recursive_repr() + def __repr__(self): + return '{0.__class__.__name__}({1})'.format( + self, ', '.join(map(repr, self.maps))) + + @classmethod + def fromkeys(cls, iterable, *args): + 'Create a ChainMap with a single dict created from the iterable.' + return cls(dict.fromkeys(iterable, *args)) + + def copy(self): + 'New ChainMap or subclass with a new copy of maps[0] and refs to maps[1:]' + return self.__class__(self.maps[0].copy(), *self.maps[1:]) + + __copy__ = copy + + def new_child(self): # like Django's Context.push() + 'New ChainMap with a new dict followed by all previous maps.' + return self.__class__({}, *self.maps) + + @property + def parents(self): # like Django's Context.pop() + 'New ChainMap from maps[1:].' + return self.__class__(*self.maps[1:]) + + def __setitem__(self, key, value): + self.maps[0][key] = value + + def __delitem__(self, key): + try: + del self.maps[0][key] + except KeyError: + raise KeyError('Key not found in the first mapping: {!r}'.format(key)) + + def popitem(self): + 'Remove and return an item pair from maps[0]. Raise KeyError is maps[0] is empty.' + try: + return self.maps[0].popitem() + except KeyError: + raise KeyError('No keys found in the first mapping.') + + def pop(self, key, *args): + 'Remove *key* from maps[0] and return its value. Raise KeyError if *key* not in maps[0].' + try: + return self.maps[0].pop(key, *args) + except KeyError: + raise KeyError('Key not found in the first mapping: {!r}'.format(key)) + + def clear(self): + 'Clear maps[0], leaving maps[1:] intact.' + self.maps[0].clear() + +try: + from importlib.util import cache_from_source # Python >= 3.4 +except ImportError: # pragma: no cover + try: + from imp import cache_from_source + except ImportError: # pragma: no cover + def cache_from_source(path, debug_override=None): + assert path.endswith('.py') + if debug_override is None: + debug_override = __debug__ + if debug_override: + suffix = 'c' + else: + suffix = 'o' + return path + suffix + +try: + from collections import OrderedDict +except ImportError: # pragma: no cover +## {{{ http://code.activestate.com/recipes/576693/ (r9) +# Backport of OrderedDict() class that runs on Python 2.4, 2.5, 2.6, 2.7 and pypy. +# Passes Python2.7's test suite and incorporates all the latest updates. + try: + from thread import get_ident as _get_ident + except ImportError: + from dummy_thread import get_ident as _get_ident + + try: + from _abcoll import KeysView, ValuesView, ItemsView + except ImportError: + pass + + + class OrderedDict(dict): + 'Dictionary that remembers insertion order' + # An inherited dict maps keys to values. + # The inherited dict provides __getitem__, __len__, __contains__, and get. + # The remaining methods are order-aware. + # Big-O running times for all methods are the same as for regular dictionaries. + + # The internal self.__map dictionary maps keys to links in a doubly linked list. + # The circular doubly linked list starts and ends with a sentinel element. + # The sentinel element never gets deleted (this simplifies the algorithm). + # Each link is stored as a list of length three: [PREV, NEXT, KEY]. + + def __init__(self, *args, **kwds): + '''Initialize an ordered dictionary. Signature is the same as for + regular dictionaries, but keyword arguments are not recommended + because their insertion order is arbitrary. + + ''' + if len(args) > 1: + raise TypeError('expected at most 1 arguments, got %d' % len(args)) + try: + self.__root + except AttributeError: + self.__root = root = [] # sentinel node + root[:] = [root, root, None] + self.__map = {} + self.__update(*args, **kwds) + + def __setitem__(self, key, value, dict_setitem=dict.__setitem__): + 'od.__setitem__(i, y) <==> od[i]=y' + # Setting a new item creates a new link which goes at the end of the linked + # list, and the inherited dictionary is updated with the new key/value pair. + if key not in self: + root = self.__root + last = root[0] + last[1] = root[0] = self.__map[key] = [last, root, key] + dict_setitem(self, key, value) + + def __delitem__(self, key, dict_delitem=dict.__delitem__): + 'od.__delitem__(y) <==> del od[y]' + # Deleting an existing item uses self.__map to find the link which is + # then removed by updating the links in the predecessor and successor nodes. + dict_delitem(self, key) + link_prev, link_next, key = self.__map.pop(key) + link_prev[1] = link_next + link_next[0] = link_prev + + def __iter__(self): + 'od.__iter__() <==> iter(od)' + root = self.__root + curr = root[1] + while curr is not root: + yield curr[2] + curr = curr[1] + + def __reversed__(self): + 'od.__reversed__() <==> reversed(od)' + root = self.__root + curr = root[0] + while curr is not root: + yield curr[2] + curr = curr[0] + + def clear(self): + 'od.clear() -> None. Remove all items from od.' + try: + for node in self.__map.itervalues(): + del node[:] + root = self.__root + root[:] = [root, root, None] + self.__map.clear() + except AttributeError: + pass + dict.clear(self) + + def popitem(self, last=True): + '''od.popitem() -> (k, v), return and remove a (key, value) pair. + Pairs are returned in LIFO order if last is true or FIFO order if false. + + ''' + if not self: + raise KeyError('dictionary is empty') + root = self.__root + if last: + link = root[0] + link_prev = link[0] + link_prev[1] = root + root[0] = link_prev + else: + link = root[1] + link_next = link[1] + root[1] = link_next + link_next[0] = root + key = link[2] + del self.__map[key] + value = dict.pop(self, key) + return key, value + + # -- the following methods do not depend on the internal structure -- + + def keys(self): + 'od.keys() -> list of keys in od' + return list(self) + + def values(self): + 'od.values() -> list of values in od' + return [self[key] for key in self] + + def items(self): + 'od.items() -> list of (key, value) pairs in od' + return [(key, self[key]) for key in self] + + def iterkeys(self): + 'od.iterkeys() -> an iterator over the keys in od' + return iter(self) + + def itervalues(self): + 'od.itervalues -> an iterator over the values in od' + for k in self: + yield self[k] + + def iteritems(self): + 'od.iteritems -> an iterator over the (key, value) items in od' + for k in self: + yield (k, self[k]) + + def update(*args, **kwds): + '''od.update(E, **F) -> None. Update od from dict/iterable E and F. + + If E is a dict instance, does: for k in E: od[k] = E[k] + If E has a .keys() method, does: for k in E.keys(): od[k] = E[k] + Or if E is an iterable of items, does: for k, v in E: od[k] = v + In either case, this is followed by: for k, v in F.items(): od[k] = v + + ''' + if len(args) > 2: + raise TypeError('update() takes at most 2 positional ' + 'arguments (%d given)' % (len(args),)) + elif not args: + raise TypeError('update() takes at least 1 argument (0 given)') + self = args[0] + # Make progressively weaker assumptions about "other" + other = () + if len(args) == 2: + other = args[1] + if isinstance(other, dict): + for key in other: + self[key] = other[key] + elif hasattr(other, 'keys'): + for key in other.keys(): + self[key] = other[key] + else: + for key, value in other: + self[key] = value + for key, value in kwds.items(): + self[key] = value + + __update = update # let subclasses override update without breaking __init__ + + __marker = object() + + def pop(self, key, default=__marker): + '''od.pop(k[,d]) -> v, remove specified key and return the corresponding value. + If key is not found, d is returned if given, otherwise KeyError is raised. + + ''' + if key in self: + result = self[key] + del self[key] + return result + if default is self.__marker: + raise KeyError(key) + return default + + def setdefault(self, key, default=None): + 'od.setdefault(k[,d]) -> od.get(k,d), also set od[k]=d if k not in od' + if key in self: + return self[key] + self[key] = default + return default + + def __repr__(self, _repr_running=None): + 'od.__repr__() <==> repr(od)' + if not _repr_running: _repr_running = {} + call_key = id(self), _get_ident() + if call_key in _repr_running: + return '...' + _repr_running[call_key] = 1 + try: + if not self: + return '%s()' % (self.__class__.__name__,) + return '%s(%r)' % (self.__class__.__name__, self.items()) + finally: + del _repr_running[call_key] + + def __reduce__(self): + 'Return state information for pickling' + items = [[k, self[k]] for k in self] + inst_dict = vars(self).copy() + for k in vars(OrderedDict()): + inst_dict.pop(k, None) + if inst_dict: + return (self.__class__, (items,), inst_dict) + return self.__class__, (items,) + + def copy(self): + 'od.copy() -> a shallow copy of od' + return self.__class__(self) + + @classmethod + def fromkeys(cls, iterable, value=None): + '''OD.fromkeys(S[, v]) -> New ordered dictionary with keys from S + and values equal to v (which defaults to None). + + ''' + d = cls() + for key in iterable: + d[key] = value + return d + + def __eq__(self, other): + '''od.__eq__(y) <==> od==y. Comparison to another OD is order-sensitive + while comparison to a regular mapping is order-insensitive. + + ''' + if isinstance(other, OrderedDict): + return len(self)==len(other) and self.items() == other.items() + return dict.__eq__(self, other) + + def __ne__(self, other): + return not self == other + + # -- the following methods are only used in Python 2.7 -- + + def viewkeys(self): + "od.viewkeys() -> a set-like object providing a view on od's keys" + return KeysView(self) + + def viewvalues(self): + "od.viewvalues() -> an object providing a view on od's values" + return ValuesView(self) + + def viewitems(self): + "od.viewitems() -> a set-like object providing a view on od's items" + return ItemsView(self) + +try: + from logging.config import BaseConfigurator, valid_ident +except ImportError: # pragma: no cover + IDENTIFIER = re.compile('^[a-z_][a-z0-9_]*$', re.I) + + + def valid_ident(s): + m = IDENTIFIER.match(s) + if not m: + raise ValueError('Not a valid Python identifier: %r' % s) + return True + + + # The ConvertingXXX classes are wrappers around standard Python containers, + # and they serve to convert any suitable values in the container. The + # conversion converts base dicts, lists and tuples to their wrapped + # equivalents, whereas strings which match a conversion format are converted + # appropriately. + # + # Each wrapper should have a configurator attribute holding the actual + # configurator to use for conversion. + + class ConvertingDict(dict): + """A converting dictionary wrapper.""" + + def __getitem__(self, key): + value = dict.__getitem__(self, key) + result = self.configurator.convert(value) + #If the converted value is different, save for next time + if value is not result: + self[key] = result + if type(result) in (ConvertingDict, ConvertingList, + ConvertingTuple): + result.parent = self + result.key = key + return result + + def get(self, key, default=None): + value = dict.get(self, key, default) + result = self.configurator.convert(value) + #If the converted value is different, save for next time + if value is not result: + self[key] = result + if type(result) in (ConvertingDict, ConvertingList, + ConvertingTuple): + result.parent = self + result.key = key + return result + + def pop(self, key, default=None): + value = dict.pop(self, key, default) + result = self.configurator.convert(value) + if value is not result: + if type(result) in (ConvertingDict, ConvertingList, + ConvertingTuple): + result.parent = self + result.key = key + return result + + class ConvertingList(list): + """A converting list wrapper.""" + def __getitem__(self, key): + value = list.__getitem__(self, key) + result = self.configurator.convert(value) + #If the converted value is different, save for next time + if value is not result: + self[key] = result + if type(result) in (ConvertingDict, ConvertingList, + ConvertingTuple): + result.parent = self + result.key = key + return result + + def pop(self, idx=-1): + value = list.pop(self, idx) + result = self.configurator.convert(value) + if value is not result: + if type(result) in (ConvertingDict, ConvertingList, + ConvertingTuple): + result.parent = self + return result + + class ConvertingTuple(tuple): + """A converting tuple wrapper.""" + def __getitem__(self, key): + value = tuple.__getitem__(self, key) + result = self.configurator.convert(value) + if value is not result: + if type(result) in (ConvertingDict, ConvertingList, + ConvertingTuple): + result.parent = self + result.key = key + return result + + class BaseConfigurator(object): + """ + The configurator base class which defines some useful defaults. + """ + + CONVERT_PATTERN = re.compile(r'^(?P<prefix>[a-z]+)://(?P<suffix>.*)$') + + WORD_PATTERN = re.compile(r'^\s*(\w+)\s*') + DOT_PATTERN = re.compile(r'^\.\s*(\w+)\s*') + INDEX_PATTERN = re.compile(r'^\[\s*(\w+)\s*\]\s*') + DIGIT_PATTERN = re.compile(r'^\d+$') + + value_converters = { + 'ext' : 'ext_convert', + 'cfg' : 'cfg_convert', + } + + # We might want to use a different one, e.g. importlib + importer = staticmethod(__import__) + + def __init__(self, config): + self.config = ConvertingDict(config) + self.config.configurator = self + + def resolve(self, s): + """ + Resolve strings to objects using standard import and attribute + syntax. + """ + name = s.split('.') + used = name.pop(0) + try: + found = self.importer(used) + for frag in name: + used += '.' + frag + try: + found = getattr(found, frag) + except AttributeError: + self.importer(used) + found = getattr(found, frag) + return found + except ImportError: + e, tb = sys.exc_info()[1:] + v = ValueError('Cannot resolve %r: %s' % (s, e)) + v.__cause__, v.__traceback__ = e, tb + raise v + + def ext_convert(self, value): + """Default converter for the ext:// protocol.""" + return self.resolve(value) + + def cfg_convert(self, value): + """Default converter for the cfg:// protocol.""" + rest = value + m = self.WORD_PATTERN.match(rest) + if m is None: + raise ValueError("Unable to convert %r" % value) + else: + rest = rest[m.end():] + d = self.config[m.groups()[0]] + #print d, rest + while rest: + m = self.DOT_PATTERN.match(rest) + if m: + d = d[m.groups()[0]] + else: + m = self.INDEX_PATTERN.match(rest) + if m: + idx = m.groups()[0] + if not self.DIGIT_PATTERN.match(idx): + d = d[idx] + else: + try: + n = int(idx) # try as number first (most likely) + d = d[n] + except TypeError: + d = d[idx] + if m: + rest = rest[m.end():] + else: + raise ValueError('Unable to convert ' + '%r at %r' % (value, rest)) + #rest should be empty + return d + + def convert(self, value): + """ + Convert values to an appropriate type. dicts, lists and tuples are + replaced by their converting alternatives. Strings are checked to + see if they have a conversion format and are converted if they do. + """ + if not isinstance(value, ConvertingDict) and isinstance(value, dict): + value = ConvertingDict(value) + value.configurator = self + elif not isinstance(value, ConvertingList) and isinstance(value, list): + value = ConvertingList(value) + value.configurator = self + elif not isinstance(value, ConvertingTuple) and\ + isinstance(value, tuple): + value = ConvertingTuple(value) + value.configurator = self + elif isinstance(value, string_types): + m = self.CONVERT_PATTERN.match(value) + if m: + d = m.groupdict() + prefix = d['prefix'] + converter = self.value_converters.get(prefix, None) + if converter: + suffix = d['suffix'] + converter = getattr(self, converter) + value = converter(suffix) + return value + + def configure_custom(self, config): + """Configure an object with a user-supplied factory.""" + c = config.pop('()') + if not callable(c): + c = self.resolve(c) + props = config.pop('.', None) + # Check for valid identifiers + kwargs = dict([(k, config[k]) for k in config if valid_ident(k)]) + result = c(**kwargs) + if props: + for name, value in props.items(): + setattr(result, name, value) + return result + + def as_tuple(self, value): + """Utility function which converts lists to tuples.""" + if isinstance(value, list): + value = tuple(value) + return value diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/database.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/database.py new file mode 100644 index 0000000..b13cdac --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/database.py @@ -0,0 +1,1339 @@ +# -*- coding: utf-8 -*- +# +# Copyright (C) 2012-2017 The Python Software Foundation. +# See LICENSE.txt and CONTRIBUTORS.txt. +# +"""PEP 376 implementation.""" + +from __future__ import unicode_literals + +import base64 +import codecs +import contextlib +import hashlib +import logging +import os +import posixpath +import sys +import zipimport + +from . import DistlibException, resources +from .compat import StringIO +from .version import get_scheme, UnsupportedVersionError +from .metadata import (Metadata, METADATA_FILENAME, WHEEL_METADATA_FILENAME, + LEGACY_METADATA_FILENAME) +from .util import (parse_requirement, cached_property, parse_name_and_version, + read_exports, write_exports, CSVReader, CSVWriter) + + +__all__ = ['Distribution', 'BaseInstalledDistribution', + 'InstalledDistribution', 'EggInfoDistribution', + 'DistributionPath'] + + +logger = logging.getLogger(__name__) + +EXPORTS_FILENAME = 'pydist-exports.json' +COMMANDS_FILENAME = 'pydist-commands.json' + +DIST_FILES = ('INSTALLER', METADATA_FILENAME, 'RECORD', 'REQUESTED', + 'RESOURCES', EXPORTS_FILENAME, 'SHARED') + +DISTINFO_EXT = '.dist-info' + + +class _Cache(object): + """ + A simple cache mapping names and .dist-info paths to distributions + """ + def __init__(self): + """ + Initialise an instance. There is normally one for each DistributionPath. + """ + self.name = {} + self.path = {} + self.generated = False + + def clear(self): + """ + Clear the cache, setting it to its initial state. + """ + self.name.clear() + self.path.clear() + self.generated = False + + def add(self, dist): + """ + Add a distribution to the cache. + :param dist: The distribution to add. + """ + if dist.path not in self.path: + self.path[dist.path] = dist + self.name.setdefault(dist.key, []).append(dist) + + +class DistributionPath(object): + """ + Represents a set of distributions installed on a path (typically sys.path). + """ + def __init__(self, path=None, include_egg=False): + """ + Create an instance from a path, optionally including legacy (distutils/ + setuptools/distribute) distributions. + :param path: The path to use, as a list of directories. If not specified, + sys.path is used. + :param include_egg: If True, this instance will look for and return legacy + distributions as well as those based on PEP 376. + """ + if path is None: + path = sys.path + self.path = path + self._include_dist = True + self._include_egg = include_egg + + self._cache = _Cache() + self._cache_egg = _Cache() + self._cache_enabled = True + self._scheme = get_scheme('default') + + def _get_cache_enabled(self): + return self._cache_enabled + + def _set_cache_enabled(self, value): + self._cache_enabled = value + + cache_enabled = property(_get_cache_enabled, _set_cache_enabled) + + def clear_cache(self): + """ + Clears the internal cache. + """ + self._cache.clear() + self._cache_egg.clear() + + + def _yield_distributions(self): + """ + Yield .dist-info and/or .egg(-info) distributions. + """ + # We need to check if we've seen some resources already, because on + # some Linux systems (e.g. some Debian/Ubuntu variants) there are + # symlinks which alias other files in the environment. + seen = set() + for path in self.path: + finder = resources.finder_for_path(path) + if finder is None: + continue + r = finder.find('') + if not r or not r.is_container: + continue + rset = sorted(r.resources) + for entry in rset: + r = finder.find(entry) + if not r or r.path in seen: + continue + if self._include_dist and entry.endswith(DISTINFO_EXT): + possible_filenames = [METADATA_FILENAME, + WHEEL_METADATA_FILENAME, + LEGACY_METADATA_FILENAME] + for metadata_filename in possible_filenames: + metadata_path = posixpath.join(entry, metadata_filename) + pydist = finder.find(metadata_path) + if pydist: + break + else: + continue + + with contextlib.closing(pydist.as_stream()) as stream: + metadata = Metadata(fileobj=stream, scheme='legacy') + logger.debug('Found %s', r.path) + seen.add(r.path) + yield new_dist_class(r.path, metadata=metadata, + env=self) + elif self._include_egg and entry.endswith(('.egg-info', + '.egg')): + logger.debug('Found %s', r.path) + seen.add(r.path) + yield old_dist_class(r.path, self) + + def _generate_cache(self): + """ + Scan the path for distributions and populate the cache with + those that are found. + """ + gen_dist = not self._cache.generated + gen_egg = self._include_egg and not self._cache_egg.generated + if gen_dist or gen_egg: + for dist in self._yield_distributions(): + if isinstance(dist, InstalledDistribution): + self._cache.add(dist) + else: + self._cache_egg.add(dist) + + if gen_dist: + self._cache.generated = True + if gen_egg: + self._cache_egg.generated = True + + @classmethod + def distinfo_dirname(cls, name, version): + """ + The *name* and *version* parameters are converted into their + filename-escaped form, i.e. any ``'-'`` characters are replaced + with ``'_'`` other than the one in ``'dist-info'`` and the one + separating the name from the version number. + + :parameter name: is converted to a standard distribution name by replacing + any runs of non- alphanumeric characters with a single + ``'-'``. + :type name: string + :parameter version: is converted to a standard version string. Spaces + become dots, and all other non-alphanumeric characters + (except dots) become dashes, with runs of multiple + dashes condensed to a single dash. + :type version: string + :returns: directory name + :rtype: string""" + name = name.replace('-', '_') + return '-'.join([name, version]) + DISTINFO_EXT + + def get_distributions(self): + """ + Provides an iterator that looks for distributions and returns + :class:`InstalledDistribution` or + :class:`EggInfoDistribution` instances for each one of them. + + :rtype: iterator of :class:`InstalledDistribution` and + :class:`EggInfoDistribution` instances + """ + if not self._cache_enabled: + for dist in self._yield_distributions(): + yield dist + else: + self._generate_cache() + + for dist in self._cache.path.values(): + yield dist + + if self._include_egg: + for dist in self._cache_egg.path.values(): + yield dist + + def get_distribution(self, name): + """ + Looks for a named distribution on the path. + + This function only returns the first result found, as no more than one + value is expected. If nothing is found, ``None`` is returned. + + :rtype: :class:`InstalledDistribution`, :class:`EggInfoDistribution` + or ``None`` + """ + result = None + name = name.lower() + if not self._cache_enabled: + for dist in self._yield_distributions(): + if dist.key == name: + result = dist + break + else: + self._generate_cache() + + if name in self._cache.name: + result = self._cache.name[name][0] + elif self._include_egg and name in self._cache_egg.name: + result = self._cache_egg.name[name][0] + return result + + def provides_distribution(self, name, version=None): + """ + Iterates over all distributions to find which distributions provide *name*. + If a *version* is provided, it will be used to filter the results. + + This function only returns the first result found, since no more than + one values are expected. If the directory is not found, returns ``None``. + + :parameter version: a version specifier that indicates the version + required, conforming to the format in ``PEP-345`` + + :type name: string + :type version: string + """ + matcher = None + if version is not None: + try: + matcher = self._scheme.matcher('%s (%s)' % (name, version)) + except ValueError: + raise DistlibException('invalid name or version: %r, %r' % + (name, version)) + + for dist in self.get_distributions(): + # We hit a problem on Travis where enum34 was installed and doesn't + # have a provides attribute ... + if not hasattr(dist, 'provides'): + logger.debug('No "provides": %s', dist) + else: + provided = dist.provides + + for p in provided: + p_name, p_ver = parse_name_and_version(p) + if matcher is None: + if p_name == name: + yield dist + break + else: + if p_name == name and matcher.match(p_ver): + yield dist + break + + def get_file_path(self, name, relative_path): + """ + Return the path to a resource file. + """ + dist = self.get_distribution(name) + if dist is None: + raise LookupError('no distribution named %r found' % name) + return dist.get_resource_path(relative_path) + + def get_exported_entries(self, category, name=None): + """ + Return all of the exported entries in a particular category. + + :param category: The category to search for entries. + :param name: If specified, only entries with that name are returned. + """ + for dist in self.get_distributions(): + r = dist.exports + if category in r: + d = r[category] + if name is not None: + if name in d: + yield d[name] + else: + for v in d.values(): + yield v + + +class Distribution(object): + """ + A base class for distributions, whether installed or from indexes. + Either way, it must have some metadata, so that's all that's needed + for construction. + """ + + build_time_dependency = False + """ + Set to True if it's known to be only a build-time dependency (i.e. + not needed after installation). + """ + + requested = False + """A boolean that indicates whether the ``REQUESTED`` metadata file is + present (in other words, whether the package was installed by user + request or it was installed as a dependency).""" + + def __init__(self, metadata): + """ + Initialise an instance. + :param metadata: The instance of :class:`Metadata` describing this + distribution. + """ + self.metadata = metadata + self.name = metadata.name + self.key = self.name.lower() # for case-insensitive comparisons + self.version = metadata.version + self.locator = None + self.digest = None + self.extras = None # additional features requested + self.context = None # environment marker overrides + self.download_urls = set() + self.digests = {} + + @property + def source_url(self): + """ + The source archive download URL for this distribution. + """ + return self.metadata.source_url + + download_url = source_url # Backward compatibility + + @property + def name_and_version(self): + """ + A utility property which displays the name and version in parentheses. + """ + return '%s (%s)' % (self.name, self.version) + + @property + def provides(self): + """ + A set of distribution names and versions provided by this distribution. + :return: A set of "name (version)" strings. + """ + plist = self.metadata.provides + s = '%s (%s)' % (self.name, self.version) + if s not in plist: + plist.append(s) + return plist + + def _get_requirements(self, req_attr): + md = self.metadata + logger.debug('Getting requirements from metadata %r', md.todict()) + reqts = getattr(md, req_attr) + return set(md.get_requirements(reqts, extras=self.extras, + env=self.context)) + + @property + def run_requires(self): + return self._get_requirements('run_requires') + + @property + def meta_requires(self): + return self._get_requirements('meta_requires') + + @property + def build_requires(self): + return self._get_requirements('build_requires') + + @property + def test_requires(self): + return self._get_requirements('test_requires') + + @property + def dev_requires(self): + return self._get_requirements('dev_requires') + + def matches_requirement(self, req): + """ + Say if this instance matches (fulfills) a requirement. + :param req: The requirement to match. + :rtype req: str + :return: True if it matches, else False. + """ + # Requirement may contain extras - parse to lose those + # from what's passed to the matcher + r = parse_requirement(req) + scheme = get_scheme(self.metadata.scheme) + try: + matcher = scheme.matcher(r.requirement) + except UnsupportedVersionError: + # XXX compat-mode if cannot read the version + logger.warning('could not read version %r - using name only', + req) + name = req.split()[0] + matcher = scheme.matcher(name) + + name = matcher.key # case-insensitive + + result = False + for p in self.provides: + p_name, p_ver = parse_name_and_version(p) + if p_name != name: + continue + try: + result = matcher.match(p_ver) + break + except UnsupportedVersionError: + pass + return result + + def __repr__(self): + """ + Return a textual representation of this instance, + """ + if self.source_url: + suffix = ' [%s]' % self.source_url + else: + suffix = '' + return '<Distribution %s (%s)%s>' % (self.name, self.version, suffix) + + def __eq__(self, other): + """ + See if this distribution is the same as another. + :param other: The distribution to compare with. To be equal to one + another. distributions must have the same type, name, + version and source_url. + :return: True if it is the same, else False. + """ + if type(other) is not type(self): + result = False + else: + result = (self.name == other.name and + self.version == other.version and + self.source_url == other.source_url) + return result + + def __hash__(self): + """ + Compute hash in a way which matches the equality test. + """ + return hash(self.name) + hash(self.version) + hash(self.source_url) + + +class BaseInstalledDistribution(Distribution): + """ + This is the base class for installed distributions (whether PEP 376 or + legacy). + """ + + hasher = None + + def __init__(self, metadata, path, env=None): + """ + Initialise an instance. + :param metadata: An instance of :class:`Metadata` which describes the + distribution. This will normally have been initialised + from a metadata file in the ``path``. + :param path: The path of the ``.dist-info`` or ``.egg-info`` + directory for the distribution. + :param env: This is normally the :class:`DistributionPath` + instance where this distribution was found. + """ + super(BaseInstalledDistribution, self).__init__(metadata) + self.path = path + self.dist_path = env + + def get_hash(self, data, hasher=None): + """ + Get the hash of some data, using a particular hash algorithm, if + specified. + + :param data: The data to be hashed. + :type data: bytes + :param hasher: The name of a hash implementation, supported by hashlib, + or ``None``. Examples of valid values are ``'sha1'``, + ``'sha224'``, ``'sha384'``, '``sha256'``, ``'md5'`` and + ``'sha512'``. If no hasher is specified, the ``hasher`` + attribute of the :class:`InstalledDistribution` instance + is used. If the hasher is determined to be ``None``, MD5 + is used as the hashing algorithm. + :returns: The hash of the data. If a hasher was explicitly specified, + the returned hash will be prefixed with the specified hasher + followed by '='. + :rtype: str + """ + if hasher is None: + hasher = self.hasher + if hasher is None: + hasher = hashlib.md5 + prefix = '' + else: + hasher = getattr(hashlib, hasher) + prefix = '%s=' % self.hasher + digest = hasher(data).digest() + digest = base64.urlsafe_b64encode(digest).rstrip(b'=').decode('ascii') + return '%s%s' % (prefix, digest) + + +class InstalledDistribution(BaseInstalledDistribution): + """ + Created with the *path* of the ``.dist-info`` directory provided to the + constructor. It reads the metadata contained in ``pydist.json`` when it is + instantiated., or uses a passed in Metadata instance (useful for when + dry-run mode is being used). + """ + + hasher = 'sha256' + + def __init__(self, path, metadata=None, env=None): + self.modules = [] + self.finder = finder = resources.finder_for_path(path) + if finder is None: + raise ValueError('finder unavailable for %s' % path) + if env and env._cache_enabled and path in env._cache.path: + metadata = env._cache.path[path].metadata + elif metadata is None: + r = finder.find(METADATA_FILENAME) + # Temporary - for Wheel 0.23 support + if r is None: + r = finder.find(WHEEL_METADATA_FILENAME) + # Temporary - for legacy support + if r is None: + r = finder.find('METADATA') + if r is None: + raise ValueError('no %s found in %s' % (METADATA_FILENAME, + path)) + with contextlib.closing(r.as_stream()) as stream: + metadata = Metadata(fileobj=stream, scheme='legacy') + + super(InstalledDistribution, self).__init__(metadata, path, env) + + if env and env._cache_enabled: + env._cache.add(self) + + r = finder.find('REQUESTED') + self.requested = r is not None + p = os.path.join(path, 'top_level.txt') + if os.path.exists(p): + with open(p, 'rb') as f: + data = f.read() + self.modules = data.splitlines() + + def __repr__(self): + return '<InstalledDistribution %r %s at %r>' % ( + self.name, self.version, self.path) + + def __str__(self): + return "%s %s" % (self.name, self.version) + + def _get_records(self): + """ + Get the list of installed files for the distribution + :return: A list of tuples of path, hash and size. Note that hash and + size might be ``None`` for some entries. The path is exactly + as stored in the file (which is as in PEP 376). + """ + results = [] + r = self.get_distinfo_resource('RECORD') + with contextlib.closing(r.as_stream()) as stream: + with CSVReader(stream=stream) as record_reader: + # Base location is parent dir of .dist-info dir + #base_location = os.path.dirname(self.path) + #base_location = os.path.abspath(base_location) + for row in record_reader: + missing = [None for i in range(len(row), 3)] + path, checksum, size = row + missing + #if not os.path.isabs(path): + # path = path.replace('/', os.sep) + # path = os.path.join(base_location, path) + results.append((path, checksum, size)) + return results + + @cached_property + def exports(self): + """ + Return the information exported by this distribution. + :return: A dictionary of exports, mapping an export category to a dict + of :class:`ExportEntry` instances describing the individual + export entries, and keyed by name. + """ + result = {} + r = self.get_distinfo_resource(EXPORTS_FILENAME) + if r: + result = self.read_exports() + return result + + def read_exports(self): + """ + Read exports data from a file in .ini format. + + :return: A dictionary of exports, mapping an export category to a list + of :class:`ExportEntry` instances describing the individual + export entries. + """ + result = {} + r = self.get_distinfo_resource(EXPORTS_FILENAME) + if r: + with contextlib.closing(r.as_stream()) as stream: + result = read_exports(stream) + return result + + def write_exports(self, exports): + """ + Write a dictionary of exports to a file in .ini format. + :param exports: A dictionary of exports, mapping an export category to + a list of :class:`ExportEntry` instances describing the + individual export entries. + """ + rf = self.get_distinfo_file(EXPORTS_FILENAME) + with open(rf, 'w') as f: + write_exports(exports, f) + + def get_resource_path(self, relative_path): + """ + NOTE: This API may change in the future. + + Return the absolute path to a resource file with the given relative + path. + + :param relative_path: The path, relative to .dist-info, of the resource + of interest. + :return: The absolute path where the resource is to be found. + """ + r = self.get_distinfo_resource('RESOURCES') + with contextlib.closing(r.as_stream()) as stream: + with CSVReader(stream=stream) as resources_reader: + for relative, destination in resources_reader: + if relative == relative_path: + return destination + raise KeyError('no resource file with relative path %r ' + 'is installed' % relative_path) + + def list_installed_files(self): + """ + Iterates over the ``RECORD`` entries and returns a tuple + ``(path, hash, size)`` for each line. + + :returns: iterator of (path, hash, size) + """ + for result in self._get_records(): + yield result + + def write_installed_files(self, paths, prefix, dry_run=False): + """ + Writes the ``RECORD`` file, using the ``paths`` iterable passed in. Any + existing ``RECORD`` file is silently overwritten. + + prefix is used to determine when to write absolute paths. + """ + prefix = os.path.join(prefix, '') + base = os.path.dirname(self.path) + base_under_prefix = base.startswith(prefix) + base = os.path.join(base, '') + record_path = self.get_distinfo_file('RECORD') + logger.info('creating %s', record_path) + if dry_run: + return None + with CSVWriter(record_path) as writer: + for path in paths: + if os.path.isdir(path) or path.endswith(('.pyc', '.pyo')): + # do not put size and hash, as in PEP-376 + hash_value = size = '' + else: + size = '%d' % os.path.getsize(path) + with open(path, 'rb') as fp: + hash_value = self.get_hash(fp.read()) + if path.startswith(base) or (base_under_prefix and + path.startswith(prefix)): + path = os.path.relpath(path, base) + writer.writerow((path, hash_value, size)) + + # add the RECORD file itself + if record_path.startswith(base): + record_path = os.path.relpath(record_path, base) + writer.writerow((record_path, '', '')) + return record_path + + def check_installed_files(self): + """ + Checks that the hashes and sizes of the files in ``RECORD`` are + matched by the files themselves. Returns a (possibly empty) list of + mismatches. Each entry in the mismatch list will be a tuple consisting + of the path, 'exists', 'size' or 'hash' according to what didn't match + (existence is checked first, then size, then hash), the expected + value and the actual value. + """ + mismatches = [] + base = os.path.dirname(self.path) + record_path = self.get_distinfo_file('RECORD') + for path, hash_value, size in self.list_installed_files(): + if not os.path.isabs(path): + path = os.path.join(base, path) + if path == record_path: + continue + if not os.path.exists(path): + mismatches.append((path, 'exists', True, False)) + elif os.path.isfile(path): + actual_size = str(os.path.getsize(path)) + if size and actual_size != size: + mismatches.append((path, 'size', size, actual_size)) + elif hash_value: + if '=' in hash_value: + hasher = hash_value.split('=', 1)[0] + else: + hasher = None + + with open(path, 'rb') as f: + actual_hash = self.get_hash(f.read(), hasher) + if actual_hash != hash_value: + mismatches.append((path, 'hash', hash_value, actual_hash)) + return mismatches + + @cached_property + def shared_locations(self): + """ + A dictionary of shared locations whose keys are in the set 'prefix', + 'purelib', 'platlib', 'scripts', 'headers', 'data' and 'namespace'. + The corresponding value is the absolute path of that category for + this distribution, and takes into account any paths selected by the + user at installation time (e.g. via command-line arguments). In the + case of the 'namespace' key, this would be a list of absolute paths + for the roots of namespace packages in this distribution. + + The first time this property is accessed, the relevant information is + read from the SHARED file in the .dist-info directory. + """ + result = {} + shared_path = os.path.join(self.path, 'SHARED') + if os.path.isfile(shared_path): + with codecs.open(shared_path, 'r', encoding='utf-8') as f: + lines = f.read().splitlines() + for line in lines: + key, value = line.split('=', 1) + if key == 'namespace': + result.setdefault(key, []).append(value) + else: + result[key] = value + return result + + def write_shared_locations(self, paths, dry_run=False): + """ + Write shared location information to the SHARED file in .dist-info. + :param paths: A dictionary as described in the documentation for + :meth:`shared_locations`. + :param dry_run: If True, the action is logged but no file is actually + written. + :return: The path of the file written to. + """ + shared_path = os.path.join(self.path, 'SHARED') + logger.info('creating %s', shared_path) + if dry_run: + return None + lines = [] + for key in ('prefix', 'lib', 'headers', 'scripts', 'data'): + path = paths[key] + if os.path.isdir(paths[key]): + lines.append('%s=%s' % (key, path)) + for ns in paths.get('namespace', ()): + lines.append('namespace=%s' % ns) + + with codecs.open(shared_path, 'w', encoding='utf-8') as f: + f.write('\n'.join(lines)) + return shared_path + + def get_distinfo_resource(self, path): + if path not in DIST_FILES: + raise DistlibException('invalid path for a dist-info file: ' + '%r at %r' % (path, self.path)) + finder = resources.finder_for_path(self.path) + if finder is None: + raise DistlibException('Unable to get a finder for %s' % self.path) + return finder.find(path) + + def get_distinfo_file(self, path): + """ + Returns a path located under the ``.dist-info`` directory. Returns a + string representing the path. + + :parameter path: a ``'/'``-separated path relative to the + ``.dist-info`` directory or an absolute path; + If *path* is an absolute path and doesn't start + with the ``.dist-info`` directory path, + a :class:`DistlibException` is raised + :type path: str + :rtype: str + """ + # Check if it is an absolute path # XXX use relpath, add tests + if path.find(os.sep) >= 0: + # it's an absolute path? + distinfo_dirname, path = path.split(os.sep)[-2:] + if distinfo_dirname != self.path.split(os.sep)[-1]: + raise DistlibException( + 'dist-info file %r does not belong to the %r %s ' + 'distribution' % (path, self.name, self.version)) + + # The file must be relative + if path not in DIST_FILES: + raise DistlibException('invalid path for a dist-info file: ' + '%r at %r' % (path, self.path)) + + return os.path.join(self.path, path) + + def list_distinfo_files(self): + """ + Iterates over the ``RECORD`` entries and returns paths for each line if + the path is pointing to a file located in the ``.dist-info`` directory + or one of its subdirectories. + + :returns: iterator of paths + """ + base = os.path.dirname(self.path) + for path, checksum, size in self._get_records(): + # XXX add separator or use real relpath algo + if not os.path.isabs(path): + path = os.path.join(base, path) + if path.startswith(self.path): + yield path + + def __eq__(self, other): + return (isinstance(other, InstalledDistribution) and + self.path == other.path) + + # See http://docs.python.org/reference/datamodel#object.__hash__ + __hash__ = object.__hash__ + + +class EggInfoDistribution(BaseInstalledDistribution): + """Created with the *path* of the ``.egg-info`` directory or file provided + to the constructor. It reads the metadata contained in the file itself, or + if the given path happens to be a directory, the metadata is read from the + file ``PKG-INFO`` under that directory.""" + + requested = True # as we have no way of knowing, assume it was + shared_locations = {} + + def __init__(self, path, env=None): + def set_name_and_version(s, n, v): + s.name = n + s.key = n.lower() # for case-insensitive comparisons + s.version = v + + self.path = path + self.dist_path = env + if env and env._cache_enabled and path in env._cache_egg.path: + metadata = env._cache_egg.path[path].metadata + set_name_and_version(self, metadata.name, metadata.version) + else: + metadata = self._get_metadata(path) + + # Need to be set before caching + set_name_and_version(self, metadata.name, metadata.version) + + if env and env._cache_enabled: + env._cache_egg.add(self) + super(EggInfoDistribution, self).__init__(metadata, path, env) + + def _get_metadata(self, path): + requires = None + + def parse_requires_data(data): + """Create a list of dependencies from a requires.txt file. + + *data*: the contents of a setuptools-produced requires.txt file. + """ + reqs = [] + lines = data.splitlines() + for line in lines: + line = line.strip() + if line.startswith('['): + logger.warning('Unexpected line: quitting requirement scan: %r', + line) + break + r = parse_requirement(line) + if not r: + logger.warning('Not recognised as a requirement: %r', line) + continue + if r.extras: + logger.warning('extra requirements in requires.txt are ' + 'not supported') + if not r.constraints: + reqs.append(r.name) + else: + cons = ', '.join('%s%s' % c for c in r.constraints) + reqs.append('%s (%s)' % (r.name, cons)) + return reqs + + def parse_requires_path(req_path): + """Create a list of dependencies from a requires.txt file. + + *req_path*: the path to a setuptools-produced requires.txt file. + """ + + reqs = [] + try: + with codecs.open(req_path, 'r', 'utf-8') as fp: + reqs = parse_requires_data(fp.read()) + except IOError: + pass + return reqs + + tl_path = tl_data = None + if path.endswith('.egg'): + if os.path.isdir(path): + p = os.path.join(path, 'EGG-INFO') + meta_path = os.path.join(p, 'PKG-INFO') + metadata = Metadata(path=meta_path, scheme='legacy') + req_path = os.path.join(p, 'requires.txt') + tl_path = os.path.join(p, 'top_level.txt') + requires = parse_requires_path(req_path) + else: + # FIXME handle the case where zipfile is not available + zipf = zipimport.zipimporter(path) + fileobj = StringIO( + zipf.get_data('EGG-INFO/PKG-INFO').decode('utf8')) + metadata = Metadata(fileobj=fileobj, scheme='legacy') + try: + data = zipf.get_data('EGG-INFO/requires.txt') + tl_data = zipf.get_data('EGG-INFO/top_level.txt').decode('utf-8') + requires = parse_requires_data(data.decode('utf-8')) + except IOError: + requires = None + elif path.endswith('.egg-info'): + if os.path.isdir(path): + req_path = os.path.join(path, 'requires.txt') + requires = parse_requires_path(req_path) + path = os.path.join(path, 'PKG-INFO') + tl_path = os.path.join(path, 'top_level.txt') + metadata = Metadata(path=path, scheme='legacy') + else: + raise DistlibException('path must end with .egg-info or .egg, ' + 'got %r' % path) + + if requires: + metadata.add_requirements(requires) + # look for top-level modules in top_level.txt, if present + if tl_data is None: + if tl_path is not None and os.path.exists(tl_path): + with open(tl_path, 'rb') as f: + tl_data = f.read().decode('utf-8') + if not tl_data: + tl_data = [] + else: + tl_data = tl_data.splitlines() + self.modules = tl_data + return metadata + + def __repr__(self): + return '<EggInfoDistribution %r %s at %r>' % ( + self.name, self.version, self.path) + + def __str__(self): + return "%s %s" % (self.name, self.version) + + def check_installed_files(self): + """ + Checks that the hashes and sizes of the files in ``RECORD`` are + matched by the files themselves. Returns a (possibly empty) list of + mismatches. Each entry in the mismatch list will be a tuple consisting + of the path, 'exists', 'size' or 'hash' according to what didn't match + (existence is checked first, then size, then hash), the expected + value and the actual value. + """ + mismatches = [] + record_path = os.path.join(self.path, 'installed-files.txt') + if os.path.exists(record_path): + for path, _, _ in self.list_installed_files(): + if path == record_path: + continue + if not os.path.exists(path): + mismatches.append((path, 'exists', True, False)) + return mismatches + + def list_installed_files(self): + """ + Iterates over the ``installed-files.txt`` entries and returns a tuple + ``(path, hash, size)`` for each line. + + :returns: a list of (path, hash, size) + """ + + def _md5(path): + f = open(path, 'rb') + try: + content = f.read() + finally: + f.close() + return hashlib.md5(content).hexdigest() + + def _size(path): + return os.stat(path).st_size + + record_path = os.path.join(self.path, 'installed-files.txt') + result = [] + if os.path.exists(record_path): + with codecs.open(record_path, 'r', encoding='utf-8') as f: + for line in f: + line = line.strip() + p = os.path.normpath(os.path.join(self.path, line)) + # "./" is present as a marker between installed files + # and installation metadata files + if not os.path.exists(p): + logger.warning('Non-existent file: %s', p) + if p.endswith(('.pyc', '.pyo')): + continue + #otherwise fall through and fail + if not os.path.isdir(p): + result.append((p, _md5(p), _size(p))) + result.append((record_path, None, None)) + return result + + def list_distinfo_files(self, absolute=False): + """ + Iterates over the ``installed-files.txt`` entries and returns paths for + each line if the path is pointing to a file located in the + ``.egg-info`` directory or one of its subdirectories. + + :parameter absolute: If *absolute* is ``True``, each returned path is + transformed into a local absolute path. Otherwise the + raw value from ``installed-files.txt`` is returned. + :type absolute: boolean + :returns: iterator of paths + """ + record_path = os.path.join(self.path, 'installed-files.txt') + if os.path.exists(record_path): + skip = True + with codecs.open(record_path, 'r', encoding='utf-8') as f: + for line in f: + line = line.strip() + if line == './': + skip = False + continue + if not skip: + p = os.path.normpath(os.path.join(self.path, line)) + if p.startswith(self.path): + if absolute: + yield p + else: + yield line + + def __eq__(self, other): + return (isinstance(other, EggInfoDistribution) and + self.path == other.path) + + # See http://docs.python.org/reference/datamodel#object.__hash__ + __hash__ = object.__hash__ + +new_dist_class = InstalledDistribution +old_dist_class = EggInfoDistribution + + +class DependencyGraph(object): + """ + Represents a dependency graph between distributions. + + The dependency relationships are stored in an ``adjacency_list`` that maps + distributions to a list of ``(other, label)`` tuples where ``other`` + is a distribution and the edge is labeled with ``label`` (i.e. the version + specifier, if such was provided). Also, for more efficient traversal, for + every distribution ``x``, a list of predecessors is kept in + ``reverse_list[x]``. An edge from distribution ``a`` to + distribution ``b`` means that ``a`` depends on ``b``. If any missing + dependencies are found, they are stored in ``missing``, which is a + dictionary that maps distributions to a list of requirements that were not + provided by any other distributions. + """ + + def __init__(self): + self.adjacency_list = {} + self.reverse_list = {} + self.missing = {} + + def add_distribution(self, distribution): + """Add the *distribution* to the graph. + + :type distribution: :class:`distutils2.database.InstalledDistribution` + or :class:`distutils2.database.EggInfoDistribution` + """ + self.adjacency_list[distribution] = [] + self.reverse_list[distribution] = [] + #self.missing[distribution] = [] + + def add_edge(self, x, y, label=None): + """Add an edge from distribution *x* to distribution *y* with the given + *label*. + + :type x: :class:`distutils2.database.InstalledDistribution` or + :class:`distutils2.database.EggInfoDistribution` + :type y: :class:`distutils2.database.InstalledDistribution` or + :class:`distutils2.database.EggInfoDistribution` + :type label: ``str`` or ``None`` + """ + self.adjacency_list[x].append((y, label)) + # multiple edges are allowed, so be careful + if x not in self.reverse_list[y]: + self.reverse_list[y].append(x) + + def add_missing(self, distribution, requirement): + """ + Add a missing *requirement* for the given *distribution*. + + :type distribution: :class:`distutils2.database.InstalledDistribution` + or :class:`distutils2.database.EggInfoDistribution` + :type requirement: ``str`` + """ + logger.debug('%s missing %r', distribution, requirement) + self.missing.setdefault(distribution, []).append(requirement) + + def _repr_dist(self, dist): + return '%s %s' % (dist.name, dist.version) + + def repr_node(self, dist, level=1): + """Prints only a subgraph""" + output = [self._repr_dist(dist)] + for other, label in self.adjacency_list[dist]: + dist = self._repr_dist(other) + if label is not None: + dist = '%s [%s]' % (dist, label) + output.append(' ' * level + str(dist)) + suboutput = self.repr_node(other, level + 1) + subs = suboutput.split('\n') + output.extend(subs[1:]) + return '\n'.join(output) + + def to_dot(self, f, skip_disconnected=True): + """Writes a DOT output for the graph to the provided file *f*. + + If *skip_disconnected* is set to ``True``, then all distributions + that are not dependent on any other distribution are skipped. + + :type f: has to support ``file``-like operations + :type skip_disconnected: ``bool`` + """ + disconnected = [] + + f.write("digraph dependencies {\n") + for dist, adjs in self.adjacency_list.items(): + if len(adjs) == 0 and not skip_disconnected: + disconnected.append(dist) + for other, label in adjs: + if not label is None: + f.write('"%s" -> "%s" [label="%s"]\n' % + (dist.name, other.name, label)) + else: + f.write('"%s" -> "%s"\n' % (dist.name, other.name)) + if not skip_disconnected and len(disconnected) > 0: + f.write('subgraph disconnected {\n') + f.write('label = "Disconnected"\n') + f.write('bgcolor = red\n') + + for dist in disconnected: + f.write('"%s"' % dist.name) + f.write('\n') + f.write('}\n') + f.write('}\n') + + def topological_sort(self): + """ + Perform a topological sort of the graph. + :return: A tuple, the first element of which is a topologically sorted + list of distributions, and the second element of which is a + list of distributions that cannot be sorted because they have + circular dependencies and so form a cycle. + """ + result = [] + # Make a shallow copy of the adjacency list + alist = {} + for k, v in self.adjacency_list.items(): + alist[k] = v[:] + while True: + # See what we can remove in this run + to_remove = [] + for k, v in list(alist.items())[:]: + if not v: + to_remove.append(k) + del alist[k] + if not to_remove: + # What's left in alist (if anything) is a cycle. + break + # Remove from the adjacency list of others + for k, v in alist.items(): + alist[k] = [(d, r) for d, r in v if d not in to_remove] + logger.debug('Moving to result: %s', + ['%s (%s)' % (d.name, d.version) for d in to_remove]) + result.extend(to_remove) + return result, list(alist.keys()) + + def __repr__(self): + """Representation of the graph""" + output = [] + for dist, adjs in self.adjacency_list.items(): + output.append(self.repr_node(dist)) + return '\n'.join(output) + + +def make_graph(dists, scheme='default'): + """Makes a dependency graph from the given distributions. + + :parameter dists: a list of distributions + :type dists: list of :class:`distutils2.database.InstalledDistribution` and + :class:`distutils2.database.EggInfoDistribution` instances + :rtype: a :class:`DependencyGraph` instance + """ + scheme = get_scheme(scheme) + graph = DependencyGraph() + provided = {} # maps names to lists of (version, dist) tuples + + # first, build the graph and find out what's provided + for dist in dists: + graph.add_distribution(dist) + + for p in dist.provides: + name, version = parse_name_and_version(p) + logger.debug('Add to provided: %s, %s, %s', name, version, dist) + provided.setdefault(name, []).append((version, dist)) + + # now make the edges + for dist in dists: + requires = (dist.run_requires | dist.meta_requires | + dist.build_requires | dist.dev_requires) + for req in requires: + try: + matcher = scheme.matcher(req) + except UnsupportedVersionError: + # XXX compat-mode if cannot read the version + logger.warning('could not read version %r - using name only', + req) + name = req.split()[0] + matcher = scheme.matcher(name) + + name = matcher.key # case-insensitive + + matched = False + if name in provided: + for version, provider in provided[name]: + try: + match = matcher.match(version) + except UnsupportedVersionError: + match = False + + if match: + graph.add_edge(dist, provider, req) + matched = True + break + if not matched: + graph.add_missing(dist, req) + return graph + + +def get_dependent_dists(dists, dist): + """Recursively generate a list of distributions from *dists* that are + dependent on *dist*. + + :param dists: a list of distributions + :param dist: a distribution, member of *dists* for which we are interested + """ + if dist not in dists: + raise DistlibException('given distribution %r is not a member ' + 'of the list' % dist.name) + graph = make_graph(dists) + + dep = [dist] # dependent distributions + todo = graph.reverse_list[dist] # list of nodes we should inspect + + while todo: + d = todo.pop() + dep.append(d) + for succ in graph.reverse_list[d]: + if succ not in dep: + todo.append(succ) + + dep.pop(0) # remove dist from dep, was there to prevent infinite loops + return dep + + +def get_required_dists(dists, dist): + """Recursively generate a list of distributions from *dists* that are + required by *dist*. + + :param dists: a list of distributions + :param dist: a distribution, member of *dists* for which we are interested + """ + if dist not in dists: + raise DistlibException('given distribution %r is not a member ' + 'of the list' % dist.name) + graph = make_graph(dists) + + req = [] # required distributions + todo = graph.adjacency_list[dist] # list of nodes we should inspect + + while todo: + d = todo.pop()[0] + req.append(d) + for pred in graph.adjacency_list[d]: + if pred not in req: + todo.append(pred) + + return req + + +def make_dist(name, version, **kwargs): + """ + A convenience method for making a dist given just a name and version. + """ + summary = kwargs.pop('summary', 'Placeholder for summary') + md = Metadata(**kwargs) + md.name = name + md.version = version + md.summary = summary or 'Placeholder for summary' + return Distribution(md) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/index.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/index.py new file mode 100644 index 0000000..7a87cdc --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/index.py @@ -0,0 +1,516 @@ +# -*- coding: utf-8 -*- +# +# Copyright (C) 2013 Vinay Sajip. +# Licensed to the Python Software Foundation under a contributor agreement. +# See LICENSE.txt and CONTRIBUTORS.txt. +# +import hashlib +import logging +import os +import shutil +import subprocess +import tempfile +try: + from threading import Thread +except ImportError: + from dummy_threading import Thread + +from . import DistlibException +from .compat import (HTTPBasicAuthHandler, Request, HTTPPasswordMgr, + urlparse, build_opener, string_types) +from .util import cached_property, zip_dir, ServerProxy + +logger = logging.getLogger(__name__) + +DEFAULT_INDEX = 'https://pypi.org/pypi' +DEFAULT_REALM = 'pypi' + +class PackageIndex(object): + """ + This class represents a package index compatible with PyPI, the Python + Package Index. + """ + + boundary = b'----------ThIs_Is_tHe_distlib_index_bouNdaRY_$' + + def __init__(self, url=None): + """ + Initialise an instance. + + :param url: The URL of the index. If not specified, the URL for PyPI is + used. + """ + self.url = url or DEFAULT_INDEX + self.read_configuration() + scheme, netloc, path, params, query, frag = urlparse(self.url) + if params or query or frag or scheme not in ('http', 'https'): + raise DistlibException('invalid repository: %s' % self.url) + self.password_handler = None + self.ssl_verifier = None + self.gpg = None + self.gpg_home = None + with open(os.devnull, 'w') as sink: + # Use gpg by default rather than gpg2, as gpg2 insists on + # prompting for passwords + for s in ('gpg', 'gpg2'): + try: + rc = subprocess.check_call([s, '--version'], stdout=sink, + stderr=sink) + if rc == 0: + self.gpg = s + break + except OSError: + pass + + def _get_pypirc_command(self): + """ + Get the distutils command for interacting with PyPI configurations. + :return: the command. + """ + from distutils.core import Distribution + from distutils.config import PyPIRCCommand + d = Distribution() + return PyPIRCCommand(d) + + def read_configuration(self): + """ + Read the PyPI access configuration as supported by distutils, getting + PyPI to do the actual work. This populates ``username``, ``password``, + ``realm`` and ``url`` attributes from the configuration. + """ + # get distutils to do the work + c = self._get_pypirc_command() + c.repository = self.url + cfg = c._read_pypirc() + self.username = cfg.get('username') + self.password = cfg.get('password') + self.realm = cfg.get('realm', 'pypi') + self.url = cfg.get('repository', self.url) + + def save_configuration(self): + """ + Save the PyPI access configuration. You must have set ``username`` and + ``password`` attributes before calling this method. + + Again, distutils is used to do the actual work. + """ + self.check_credentials() + # get distutils to do the work + c = self._get_pypirc_command() + c._store_pypirc(self.username, self.password) + + def check_credentials(self): + """ + Check that ``username`` and ``password`` have been set, and raise an + exception if not. + """ + if self.username is None or self.password is None: + raise DistlibException('username and password must be set') + pm = HTTPPasswordMgr() + _, netloc, _, _, _, _ = urlparse(self.url) + pm.add_password(self.realm, netloc, self.username, self.password) + self.password_handler = HTTPBasicAuthHandler(pm) + + def register(self, metadata): + """ + Register a distribution on PyPI, using the provided metadata. + + :param metadata: A :class:`Metadata` instance defining at least a name + and version number for the distribution to be + registered. + :return: The HTTP response received from PyPI upon submission of the + request. + """ + self.check_credentials() + metadata.validate() + d = metadata.todict() + d[':action'] = 'verify' + request = self.encode_request(d.items(), []) + response = self.send_request(request) + d[':action'] = 'submit' + request = self.encode_request(d.items(), []) + return self.send_request(request) + + def _reader(self, name, stream, outbuf): + """ + Thread runner for reading lines of from a subprocess into a buffer. + + :param name: The logical name of the stream (used for logging only). + :param stream: The stream to read from. This will typically a pipe + connected to the output stream of a subprocess. + :param outbuf: The list to append the read lines to. + """ + while True: + s = stream.readline() + if not s: + break + s = s.decode('utf-8').rstrip() + outbuf.append(s) + logger.debug('%s: %s' % (name, s)) + stream.close() + + def get_sign_command(self, filename, signer, sign_password, + keystore=None): + """ + Return a suitable command for signing a file. + + :param filename: The pathname to the file to be signed. + :param signer: The identifier of the signer of the file. + :param sign_password: The passphrase for the signer's + private key used for signing. + :param keystore: The path to a directory which contains the keys + used in verification. If not specified, the + instance's ``gpg_home`` attribute is used instead. + :return: The signing command as a list suitable to be + passed to :class:`subprocess.Popen`. + """ + cmd = [self.gpg, '--status-fd', '2', '--no-tty'] + if keystore is None: + keystore = self.gpg_home + if keystore: + cmd.extend(['--homedir', keystore]) + if sign_password is not None: + cmd.extend(['--batch', '--passphrase-fd', '0']) + td = tempfile.mkdtemp() + sf = os.path.join(td, os.path.basename(filename) + '.asc') + cmd.extend(['--detach-sign', '--armor', '--local-user', + signer, '--output', sf, filename]) + logger.debug('invoking: %s', ' '.join(cmd)) + return cmd, sf + + def run_command(self, cmd, input_data=None): + """ + Run a command in a child process , passing it any input data specified. + + :param cmd: The command to run. + :param input_data: If specified, this must be a byte string containing + data to be sent to the child process. + :return: A tuple consisting of the subprocess' exit code, a list of + lines read from the subprocess' ``stdout``, and a list of + lines read from the subprocess' ``stderr``. + """ + kwargs = { + 'stdout': subprocess.PIPE, + 'stderr': subprocess.PIPE, + } + if input_data is not None: + kwargs['stdin'] = subprocess.PIPE + stdout = [] + stderr = [] + p = subprocess.Popen(cmd, **kwargs) + # We don't use communicate() here because we may need to + # get clever with interacting with the command + t1 = Thread(target=self._reader, args=('stdout', p.stdout, stdout)) + t1.start() + t2 = Thread(target=self._reader, args=('stderr', p.stderr, stderr)) + t2.start() + if input_data is not None: + p.stdin.write(input_data) + p.stdin.close() + + p.wait() + t1.join() + t2.join() + return p.returncode, stdout, stderr + + def sign_file(self, filename, signer, sign_password, keystore=None): + """ + Sign a file. + + :param filename: The pathname to the file to be signed. + :param signer: The identifier of the signer of the file. + :param sign_password: The passphrase for the signer's + private key used for signing. + :param keystore: The path to a directory which contains the keys + used in signing. If not specified, the instance's + ``gpg_home`` attribute is used instead. + :return: The absolute pathname of the file where the signature is + stored. + """ + cmd, sig_file = self.get_sign_command(filename, signer, sign_password, + keystore) + rc, stdout, stderr = self.run_command(cmd, + sign_password.encode('utf-8')) + if rc != 0: + raise DistlibException('sign command failed with error ' + 'code %s' % rc) + return sig_file + + def upload_file(self, metadata, filename, signer=None, sign_password=None, + filetype='sdist', pyversion='source', keystore=None): + """ + Upload a release file to the index. + + :param metadata: A :class:`Metadata` instance defining at least a name + and version number for the file to be uploaded. + :param filename: The pathname of the file to be uploaded. + :param signer: The identifier of the signer of the file. + :param sign_password: The passphrase for the signer's + private key used for signing. + :param filetype: The type of the file being uploaded. This is the + distutils command which produced that file, e.g. + ``sdist`` or ``bdist_wheel``. + :param pyversion: The version of Python which the release relates + to. For code compatible with any Python, this would + be ``source``, otherwise it would be e.g. ``3.2``. + :param keystore: The path to a directory which contains the keys + used in signing. If not specified, the instance's + ``gpg_home`` attribute is used instead. + :return: The HTTP response received from PyPI upon submission of the + request. + """ + self.check_credentials() + if not os.path.exists(filename): + raise DistlibException('not found: %s' % filename) + metadata.validate() + d = metadata.todict() + sig_file = None + if signer: + if not self.gpg: + logger.warning('no signing program available - not signed') + else: + sig_file = self.sign_file(filename, signer, sign_password, + keystore) + with open(filename, 'rb') as f: + file_data = f.read() + md5_digest = hashlib.md5(file_data).hexdigest() + sha256_digest = hashlib.sha256(file_data).hexdigest() + d.update({ + ':action': 'file_upload', + 'protocol_version': '1', + 'filetype': filetype, + 'pyversion': pyversion, + 'md5_digest': md5_digest, + 'sha256_digest': sha256_digest, + }) + files = [('content', os.path.basename(filename), file_data)] + if sig_file: + with open(sig_file, 'rb') as f: + sig_data = f.read() + files.append(('gpg_signature', os.path.basename(sig_file), + sig_data)) + shutil.rmtree(os.path.dirname(sig_file)) + request = self.encode_request(d.items(), files) + return self.send_request(request) + + def upload_documentation(self, metadata, doc_dir): + """ + Upload documentation to the index. + + :param metadata: A :class:`Metadata` instance defining at least a name + and version number for the documentation to be + uploaded. + :param doc_dir: The pathname of the directory which contains the + documentation. This should be the directory that + contains the ``index.html`` for the documentation. + :return: The HTTP response received from PyPI upon submission of the + request. + """ + self.check_credentials() + if not os.path.isdir(doc_dir): + raise DistlibException('not a directory: %r' % doc_dir) + fn = os.path.join(doc_dir, 'index.html') + if not os.path.exists(fn): + raise DistlibException('not found: %r' % fn) + metadata.validate() + name, version = metadata.name, metadata.version + zip_data = zip_dir(doc_dir).getvalue() + fields = [(':action', 'doc_upload'), + ('name', name), ('version', version)] + files = [('content', name, zip_data)] + request = self.encode_request(fields, files) + return self.send_request(request) + + def get_verify_command(self, signature_filename, data_filename, + keystore=None): + """ + Return a suitable command for verifying a file. + + :param signature_filename: The pathname to the file containing the + signature. + :param data_filename: The pathname to the file containing the + signed data. + :param keystore: The path to a directory which contains the keys + used in verification. If not specified, the + instance's ``gpg_home`` attribute is used instead. + :return: The verifying command as a list suitable to be + passed to :class:`subprocess.Popen`. + """ + cmd = [self.gpg, '--status-fd', '2', '--no-tty'] + if keystore is None: + keystore = self.gpg_home + if keystore: + cmd.extend(['--homedir', keystore]) + cmd.extend(['--verify', signature_filename, data_filename]) + logger.debug('invoking: %s', ' '.join(cmd)) + return cmd + + def verify_signature(self, signature_filename, data_filename, + keystore=None): + """ + Verify a signature for a file. + + :param signature_filename: The pathname to the file containing the + signature. + :param data_filename: The pathname to the file containing the + signed data. + :param keystore: The path to a directory which contains the keys + used in verification. If not specified, the + instance's ``gpg_home`` attribute is used instead. + :return: True if the signature was verified, else False. + """ + if not self.gpg: + raise DistlibException('verification unavailable because gpg ' + 'unavailable') + cmd = self.get_verify_command(signature_filename, data_filename, + keystore) + rc, stdout, stderr = self.run_command(cmd) + if rc not in (0, 1): + raise DistlibException('verify command failed with error ' + 'code %s' % rc) + return rc == 0 + + def download_file(self, url, destfile, digest=None, reporthook=None): + """ + This is a convenience method for downloading a file from an URL. + Normally, this will be a file from the index, though currently + no check is made for this (i.e. a file can be downloaded from + anywhere). + + The method is just like the :func:`urlretrieve` function in the + standard library, except that it allows digest computation to be + done during download and checking that the downloaded data + matched any expected value. + + :param url: The URL of the file to be downloaded (assumed to be + available via an HTTP GET request). + :param destfile: The pathname where the downloaded file is to be + saved. + :param digest: If specified, this must be a (hasher, value) + tuple, where hasher is the algorithm used (e.g. + ``'md5'``) and ``value`` is the expected value. + :param reporthook: The same as for :func:`urlretrieve` in the + standard library. + """ + if digest is None: + digester = None + logger.debug('No digest specified') + else: + if isinstance(digest, (list, tuple)): + hasher, digest = digest + else: + hasher = 'md5' + digester = getattr(hashlib, hasher)() + logger.debug('Digest specified: %s' % digest) + # The following code is equivalent to urlretrieve. + # We need to do it this way so that we can compute the + # digest of the file as we go. + with open(destfile, 'wb') as dfp: + # addinfourl is not a context manager on 2.x + # so we have to use try/finally + sfp = self.send_request(Request(url)) + try: + headers = sfp.info() + blocksize = 8192 + size = -1 + read = 0 + blocknum = 0 + if "content-length" in headers: + size = int(headers["Content-Length"]) + if reporthook: + reporthook(blocknum, blocksize, size) + while True: + block = sfp.read(blocksize) + if not block: + break + read += len(block) + dfp.write(block) + if digester: + digester.update(block) + blocknum += 1 + if reporthook: + reporthook(blocknum, blocksize, size) + finally: + sfp.close() + + # check that we got the whole file, if we can + if size >= 0 and read < size: + raise DistlibException( + 'retrieval incomplete: got only %d out of %d bytes' + % (read, size)) + # if we have a digest, it must match. + if digester: + actual = digester.hexdigest() + if digest != actual: + raise DistlibException('%s digest mismatch for %s: expected ' + '%s, got %s' % (hasher, destfile, + digest, actual)) + logger.debug('Digest verified: %s', digest) + + def send_request(self, req): + """ + Send a standard library :class:`Request` to PyPI and return its + response. + + :param req: The request to send. + :return: The HTTP response from PyPI (a standard library HTTPResponse). + """ + handlers = [] + if self.password_handler: + handlers.append(self.password_handler) + if self.ssl_verifier: + handlers.append(self.ssl_verifier) + opener = build_opener(*handlers) + return opener.open(req) + + def encode_request(self, fields, files): + """ + Encode fields and files for posting to an HTTP server. + + :param fields: The fields to send as a list of (fieldname, value) + tuples. + :param files: The files to send as a list of (fieldname, filename, + file_bytes) tuple. + """ + # Adapted from packaging, which in turn was adapted from + # http://code.activestate.com/recipes/146306 + + parts = [] + boundary = self.boundary + for k, values in fields: + if not isinstance(values, (list, tuple)): + values = [values] + + for v in values: + parts.extend(( + b'--' + boundary, + ('Content-Disposition: form-data; name="%s"' % + k).encode('utf-8'), + b'', + v.encode('utf-8'))) + for key, filename, value in files: + parts.extend(( + b'--' + boundary, + ('Content-Disposition: form-data; name="%s"; filename="%s"' % + (key, filename)).encode('utf-8'), + b'', + value)) + + parts.extend((b'--' + boundary + b'--', b'')) + + body = b'\r\n'.join(parts) + ct = b'multipart/form-data; boundary=' + boundary + headers = { + 'Content-type': ct, + 'Content-length': str(len(body)) + } + return Request(self.url, body, headers) + + def search(self, terms, operator=None): + if isinstance(terms, string_types): + terms = {'name': terms} + rpc_proxy = ServerProxy(self.url, timeout=3.0) + try: + return rpc_proxy.search(terms, operator or 'and') + finally: + rpc_proxy('close')() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/locators.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/locators.py new file mode 100644 index 0000000..a7ed946 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/locators.py @@ -0,0 +1,1295 @@ +# -*- coding: utf-8 -*- +# +# Copyright (C) 2012-2015 Vinay Sajip. +# Licensed to the Python Software Foundation under a contributor agreement. +# See LICENSE.txt and CONTRIBUTORS.txt. +# + +import gzip +from io import BytesIO +import json +import logging +import os +import posixpath +import re +try: + import threading +except ImportError: # pragma: no cover + import dummy_threading as threading +import zlib + +from . import DistlibException +from .compat import (urljoin, urlparse, urlunparse, url2pathname, pathname2url, + queue, quote, unescape, string_types, build_opener, + HTTPRedirectHandler as BaseRedirectHandler, text_type, + Request, HTTPError, URLError) +from .database import Distribution, DistributionPath, make_dist +from .metadata import Metadata, MetadataInvalidError +from .util import (cached_property, parse_credentials, ensure_slash, + split_filename, get_project_data, parse_requirement, + parse_name_and_version, ServerProxy, normalize_name) +from .version import get_scheme, UnsupportedVersionError +from .wheel import Wheel, is_compatible + +logger = logging.getLogger(__name__) + +HASHER_HASH = re.compile(r'^(\w+)=([a-f0-9]+)') +CHARSET = re.compile(r';\s*charset\s*=\s*(.*)\s*$', re.I) +HTML_CONTENT_TYPE = re.compile('text/html|application/x(ht)?ml') +DEFAULT_INDEX = 'https://pypi.org/pypi' + +def get_all_distribution_names(url=None): + """ + Return all distribution names known by an index. + :param url: The URL of the index. + :return: A list of all known distribution names. + """ + if url is None: + url = DEFAULT_INDEX + client = ServerProxy(url, timeout=3.0) + try: + return client.list_packages() + finally: + client('close')() + +class RedirectHandler(BaseRedirectHandler): + """ + A class to work around a bug in some Python 3.2.x releases. + """ + # There's a bug in the base version for some 3.2.x + # (e.g. 3.2.2 on Ubuntu Oneiric). If a Location header + # returns e.g. /abc, it bails because it says the scheme '' + # is bogus, when actually it should use the request's + # URL for the scheme. See Python issue #13696. + def http_error_302(self, req, fp, code, msg, headers): + # Some servers (incorrectly) return multiple Location headers + # (so probably same goes for URI). Use first header. + newurl = None + for key in ('location', 'uri'): + if key in headers: + newurl = headers[key] + break + if newurl is None: # pragma: no cover + return + urlparts = urlparse(newurl) + if urlparts.scheme == '': + newurl = urljoin(req.get_full_url(), newurl) + if hasattr(headers, 'replace_header'): + headers.replace_header(key, newurl) + else: + headers[key] = newurl + return BaseRedirectHandler.http_error_302(self, req, fp, code, msg, + headers) + + http_error_301 = http_error_303 = http_error_307 = http_error_302 + +class Locator(object): + """ + A base class for locators - things that locate distributions. + """ + source_extensions = ('.tar.gz', '.tar.bz2', '.tar', '.zip', '.tgz', '.tbz') + binary_extensions = ('.egg', '.exe', '.whl') + excluded_extensions = ('.pdf',) + + # A list of tags indicating which wheels you want to match. The default + # value of None matches against the tags compatible with the running + # Python. If you want to match other values, set wheel_tags on a locator + # instance to a list of tuples (pyver, abi, arch) which you want to match. + wheel_tags = None + + downloadable_extensions = source_extensions + ('.whl',) + + def __init__(self, scheme='default'): + """ + Initialise an instance. + :param scheme: Because locators look for most recent versions, they + need to know the version scheme to use. This specifies + the current PEP-recommended scheme - use ``'legacy'`` + if you need to support existing distributions on PyPI. + """ + self._cache = {} + self.scheme = scheme + # Because of bugs in some of the handlers on some of the platforms, + # we use our own opener rather than just using urlopen. + self.opener = build_opener(RedirectHandler()) + # If get_project() is called from locate(), the matcher instance + # is set from the requirement passed to locate(). See issue #18 for + # why this can be useful to know. + self.matcher = None + self.errors = queue.Queue() + + def get_errors(self): + """ + Return any errors which have occurred. + """ + result = [] + while not self.errors.empty(): # pragma: no cover + try: + e = self.errors.get(False) + result.append(e) + except self.errors.Empty: + continue + self.errors.task_done() + return result + + def clear_errors(self): + """ + Clear any errors which may have been logged. + """ + # Just get the errors and throw them away + self.get_errors() + + def clear_cache(self): + self._cache.clear() + + def _get_scheme(self): + return self._scheme + + def _set_scheme(self, value): + self._scheme = value + + scheme = property(_get_scheme, _set_scheme) + + def _get_project(self, name): + """ + For a given project, get a dictionary mapping available versions to Distribution + instances. + + This should be implemented in subclasses. + + If called from a locate() request, self.matcher will be set to a + matcher for the requirement to satisfy, otherwise it will be None. + """ + raise NotImplementedError('Please implement in the subclass') + + def get_distribution_names(self): + """ + Return all the distribution names known to this locator. + """ + raise NotImplementedError('Please implement in the subclass') + + def get_project(self, name): + """ + For a given project, get a dictionary mapping available versions to Distribution + instances. + + This calls _get_project to do all the work, and just implements a caching layer on top. + """ + if self._cache is None: # pragma: no cover + result = self._get_project(name) + elif name in self._cache: + result = self._cache[name] + else: + self.clear_errors() + result = self._get_project(name) + self._cache[name] = result + return result + + def score_url(self, url): + """ + Give an url a score which can be used to choose preferred URLs + for a given project release. + """ + t = urlparse(url) + basename = posixpath.basename(t.path) + compatible = True + is_wheel = basename.endswith('.whl') + is_downloadable = basename.endswith(self.downloadable_extensions) + if is_wheel: + compatible = is_compatible(Wheel(basename), self.wheel_tags) + return (t.scheme == 'https', 'pypi.org' in t.netloc, + is_downloadable, is_wheel, compatible, basename) + + def prefer_url(self, url1, url2): + """ + Choose one of two URLs where both are candidates for distribution + archives for the same version of a distribution (for example, + .tar.gz vs. zip). + + The current implementation favours https:// URLs over http://, archives + from PyPI over those from other locations, wheel compatibility (if a + wheel) and then the archive name. + """ + result = url2 + if url1: + s1 = self.score_url(url1) + s2 = self.score_url(url2) + if s1 > s2: + result = url1 + if result != url2: + logger.debug('Not replacing %r with %r', url1, url2) + else: + logger.debug('Replacing %r with %r', url1, url2) + return result + + def split_filename(self, filename, project_name): + """ + Attempt to split a filename in project name, version and Python version. + """ + return split_filename(filename, project_name) + + def convert_url_to_download_info(self, url, project_name): + """ + See if a URL is a candidate for a download URL for a project (the URL + has typically been scraped from an HTML page). + + If it is, a dictionary is returned with keys "name", "version", + "filename" and "url"; otherwise, None is returned. + """ + def same_project(name1, name2): + return normalize_name(name1) == normalize_name(name2) + + result = None + scheme, netloc, path, params, query, frag = urlparse(url) + if frag.lower().startswith('egg='): # pragma: no cover + logger.debug('%s: version hint in fragment: %r', + project_name, frag) + m = HASHER_HASH.match(frag) + if m: + algo, digest = m.groups() + else: + algo, digest = None, None + origpath = path + if path and path[-1] == '/': # pragma: no cover + path = path[:-1] + if path.endswith('.whl'): + try: + wheel = Wheel(path) + if not is_compatible(wheel, self.wheel_tags): + logger.debug('Wheel not compatible: %s', path) + else: + if project_name is None: + include = True + else: + include = same_project(wheel.name, project_name) + if include: + result = { + 'name': wheel.name, + 'version': wheel.version, + 'filename': wheel.filename, + 'url': urlunparse((scheme, netloc, origpath, + params, query, '')), + 'python-version': ', '.join( + ['.'.join(list(v[2:])) for v in wheel.pyver]), + } + except Exception as e: # pragma: no cover + logger.warning('invalid path for wheel: %s', path) + elif not path.endswith(self.downloadable_extensions): # pragma: no cover + logger.debug('Not downloadable: %s', path) + else: # downloadable extension + path = filename = posixpath.basename(path) + for ext in self.downloadable_extensions: + if path.endswith(ext): + path = path[:-len(ext)] + t = self.split_filename(path, project_name) + if not t: # pragma: no cover + logger.debug('No match for project/version: %s', path) + else: + name, version, pyver = t + if not project_name or same_project(project_name, name): + result = { + 'name': name, + 'version': version, + 'filename': filename, + 'url': urlunparse((scheme, netloc, origpath, + params, query, '')), + #'packagetype': 'sdist', + } + if pyver: # pragma: no cover + result['python-version'] = pyver + break + if result and algo: + result['%s_digest' % algo] = digest + return result + + def _get_digest(self, info): + """ + Get a digest from a dictionary by looking at keys of the form + 'algo_digest'. + + Returns a 2-tuple (algo, digest) if found, else None. Currently + looks only for SHA256, then MD5. + """ + result = None + for algo in ('sha256', 'md5'): + key = '%s_digest' % algo + if key in info: + result = (algo, info[key]) + break + return result + + def _update_version_data(self, result, info): + """ + Update a result dictionary (the final result from _get_project) with a + dictionary for a specific version, which typically holds information + gleaned from a filename or URL for an archive for the distribution. + """ + name = info.pop('name') + version = info.pop('version') + if version in result: + dist = result[version] + md = dist.metadata + else: + dist = make_dist(name, version, scheme=self.scheme) + md = dist.metadata + dist.digest = digest = self._get_digest(info) + url = info['url'] + result['digests'][url] = digest + if md.source_url != info['url']: + md.source_url = self.prefer_url(md.source_url, url) + result['urls'].setdefault(version, set()).add(url) + dist.locator = self + result[version] = dist + + def locate(self, requirement, prereleases=False): + """ + Find the most recent distribution which matches the given + requirement. + + :param requirement: A requirement of the form 'foo (1.0)' or perhaps + 'foo (>= 1.0, < 2.0, != 1.3)' + :param prereleases: If ``True``, allow pre-release versions + to be located. Otherwise, pre-release versions + are not returned. + :return: A :class:`Distribution` instance, or ``None`` if no such + distribution could be located. + """ + result = None + r = parse_requirement(requirement) + if r is None: # pragma: no cover + raise DistlibException('Not a valid requirement: %r' % requirement) + scheme = get_scheme(self.scheme) + self.matcher = matcher = scheme.matcher(r.requirement) + logger.debug('matcher: %s (%s)', matcher, type(matcher).__name__) + versions = self.get_project(r.name) + if len(versions) > 2: # urls and digests keys are present + # sometimes, versions are invalid + slist = [] + vcls = matcher.version_class + for k in versions: + if k in ('urls', 'digests'): + continue + try: + if not matcher.match(k): + logger.debug('%s did not match %r', matcher, k) + else: + if prereleases or not vcls(k).is_prerelease: + slist.append(k) + else: + logger.debug('skipping pre-release ' + 'version %s of %s', k, matcher.name) + except Exception: # pragma: no cover + logger.warning('error matching %s with %r', matcher, k) + pass # slist.append(k) + if len(slist) > 1: + slist = sorted(slist, key=scheme.key) + if slist: + logger.debug('sorted list: %s', slist) + version = slist[-1] + result = versions[version] + if result: + if r.extras: + result.extras = r.extras + result.download_urls = versions.get('urls', {}).get(version, set()) + d = {} + sd = versions.get('digests', {}) + for url in result.download_urls: + if url in sd: # pragma: no cover + d[url] = sd[url] + result.digests = d + self.matcher = None + return result + + +class PyPIRPCLocator(Locator): + """ + This locator uses XML-RPC to locate distributions. It therefore + cannot be used with simple mirrors (that only mirror file content). + """ + def __init__(self, url, **kwargs): + """ + Initialise an instance. + + :param url: The URL to use for XML-RPC. + :param kwargs: Passed to the superclass constructor. + """ + super(PyPIRPCLocator, self).__init__(**kwargs) + self.base_url = url + self.client = ServerProxy(url, timeout=3.0) + + def get_distribution_names(self): + """ + Return all the distribution names known to this locator. + """ + return set(self.client.list_packages()) + + def _get_project(self, name): + result = {'urls': {}, 'digests': {}} + versions = self.client.package_releases(name, True) + for v in versions: + urls = self.client.release_urls(name, v) + data = self.client.release_data(name, v) + metadata = Metadata(scheme=self.scheme) + metadata.name = data['name'] + metadata.version = data['version'] + metadata.license = data.get('license') + metadata.keywords = data.get('keywords', []) + metadata.summary = data.get('summary') + dist = Distribution(metadata) + if urls: + info = urls[0] + metadata.source_url = info['url'] + dist.digest = self._get_digest(info) + dist.locator = self + result[v] = dist + for info in urls: + url = info['url'] + digest = self._get_digest(info) + result['urls'].setdefault(v, set()).add(url) + result['digests'][url] = digest + return result + +class PyPIJSONLocator(Locator): + """ + This locator uses PyPI's JSON interface. It's very limited in functionality + and probably not worth using. + """ + def __init__(self, url, **kwargs): + super(PyPIJSONLocator, self).__init__(**kwargs) + self.base_url = ensure_slash(url) + + def get_distribution_names(self): + """ + Return all the distribution names known to this locator. + """ + raise NotImplementedError('Not available from this locator') + + def _get_project(self, name): + result = {'urls': {}, 'digests': {}} + url = urljoin(self.base_url, '%s/json' % quote(name)) + try: + resp = self.opener.open(url) + data = resp.read().decode() # for now + d = json.loads(data) + md = Metadata(scheme=self.scheme) + data = d['info'] + md.name = data['name'] + md.version = data['version'] + md.license = data.get('license') + md.keywords = data.get('keywords', []) + md.summary = data.get('summary') + dist = Distribution(md) + dist.locator = self + urls = d['urls'] + result[md.version] = dist + for info in d['urls']: + url = info['url'] + dist.download_urls.add(url) + dist.digests[url] = self._get_digest(info) + result['urls'].setdefault(md.version, set()).add(url) + result['digests'][url] = self._get_digest(info) + # Now get other releases + for version, infos in d['releases'].items(): + if version == md.version: + continue # already done + omd = Metadata(scheme=self.scheme) + omd.name = md.name + omd.version = version + odist = Distribution(omd) + odist.locator = self + result[version] = odist + for info in infos: + url = info['url'] + odist.download_urls.add(url) + odist.digests[url] = self._get_digest(info) + result['urls'].setdefault(version, set()).add(url) + result['digests'][url] = self._get_digest(info) +# for info in urls: +# md.source_url = info['url'] +# dist.digest = self._get_digest(info) +# dist.locator = self +# for info in urls: +# url = info['url'] +# result['urls'].setdefault(md.version, set()).add(url) +# result['digests'][url] = self._get_digest(info) + except Exception as e: + self.errors.put(text_type(e)) + logger.exception('JSON fetch failed: %s', e) + return result + + +class Page(object): + """ + This class represents a scraped HTML page. + """ + # The following slightly hairy-looking regex just looks for the contents of + # an anchor link, which has an attribute "href" either immediately preceded + # or immediately followed by a "rel" attribute. The attribute values can be + # declared with double quotes, single quotes or no quotes - which leads to + # the length of the expression. + _href = re.compile(""" +(rel\\s*=\\s*(?:"(?P<rel1>[^"]*)"|'(?P<rel2>[^']*)'|(?P<rel3>[^>\\s\n]*))\\s+)? +href\\s*=\\s*(?:"(?P<url1>[^"]*)"|'(?P<url2>[^']*)'|(?P<url3>[^>\\s\n]*)) +(\\s+rel\\s*=\\s*(?:"(?P<rel4>[^"]*)"|'(?P<rel5>[^']*)'|(?P<rel6>[^>\\s\n]*)))? +""", re.I | re.S | re.X) + _base = re.compile(r"""<base\s+href\s*=\s*['"]?([^'">]+)""", re.I | re.S) + + def __init__(self, data, url): + """ + Initialise an instance with the Unicode page contents and the URL they + came from. + """ + self.data = data + self.base_url = self.url = url + m = self._base.search(self.data) + if m: + self.base_url = m.group(1) + + _clean_re = re.compile(r'[^a-z0-9$&+,/:;=?@.#%_\\|-]', re.I) + + @cached_property + def links(self): + """ + Return the URLs of all the links on a page together with information + about their "rel" attribute, for determining which ones to treat as + downloads and which ones to queue for further scraping. + """ + def clean(url): + "Tidy up an URL." + scheme, netloc, path, params, query, frag = urlparse(url) + return urlunparse((scheme, netloc, quote(path), + params, query, frag)) + + result = set() + for match in self._href.finditer(self.data): + d = match.groupdict('') + rel = (d['rel1'] or d['rel2'] or d['rel3'] or + d['rel4'] or d['rel5'] or d['rel6']) + url = d['url1'] or d['url2'] or d['url3'] + url = urljoin(self.base_url, url) + url = unescape(url) + url = self._clean_re.sub(lambda m: '%%%2x' % ord(m.group(0)), url) + result.add((url, rel)) + # We sort the result, hoping to bring the most recent versions + # to the front + result = sorted(result, key=lambda t: t[0], reverse=True) + return result + + +class SimpleScrapingLocator(Locator): + """ + A locator which scrapes HTML pages to locate downloads for a distribution. + This runs multiple threads to do the I/O; performance is at least as good + as pip's PackageFinder, which works in an analogous fashion. + """ + + # These are used to deal with various Content-Encoding schemes. + decoders = { + 'deflate': zlib.decompress, + 'gzip': lambda b: gzip.GzipFile(fileobj=BytesIO(d)).read(), + 'none': lambda b: b, + } + + def __init__(self, url, timeout=None, num_workers=10, **kwargs): + """ + Initialise an instance. + :param url: The root URL to use for scraping. + :param timeout: The timeout, in seconds, to be applied to requests. + This defaults to ``None`` (no timeout specified). + :param num_workers: The number of worker threads you want to do I/O, + This defaults to 10. + :param kwargs: Passed to the superclass. + """ + super(SimpleScrapingLocator, self).__init__(**kwargs) + self.base_url = ensure_slash(url) + self.timeout = timeout + self._page_cache = {} + self._seen = set() + self._to_fetch = queue.Queue() + self._bad_hosts = set() + self.skip_externals = False + self.num_workers = num_workers + self._lock = threading.RLock() + # See issue #45: we need to be resilient when the locator is used + # in a thread, e.g. with concurrent.futures. We can't use self._lock + # as it is for coordinating our internal threads - the ones created + # in _prepare_threads. + self._gplock = threading.RLock() + self.platform_check = False # See issue #112 + + def _prepare_threads(self): + """ + Threads are created only when get_project is called, and terminate + before it returns. They are there primarily to parallelise I/O (i.e. + fetching web pages). + """ + self._threads = [] + for i in range(self.num_workers): + t = threading.Thread(target=self._fetch) + t.setDaemon(True) + t.start() + self._threads.append(t) + + def _wait_threads(self): + """ + Tell all the threads to terminate (by sending a sentinel value) and + wait for them to do so. + """ + # Note that you need two loops, since you can't say which + # thread will get each sentinel + for t in self._threads: + self._to_fetch.put(None) # sentinel + for t in self._threads: + t.join() + self._threads = [] + + def _get_project(self, name): + result = {'urls': {}, 'digests': {}} + with self._gplock: + self.result = result + self.project_name = name + url = urljoin(self.base_url, '%s/' % quote(name)) + self._seen.clear() + self._page_cache.clear() + self._prepare_threads() + try: + logger.debug('Queueing %s', url) + self._to_fetch.put(url) + self._to_fetch.join() + finally: + self._wait_threads() + del self.result + return result + + platform_dependent = re.compile(r'\b(linux_(i\d86|x86_64|arm\w+)|' + r'win(32|_amd64)|macosx_?\d+)\b', re.I) + + def _is_platform_dependent(self, url): + """ + Does an URL refer to a platform-specific download? + """ + return self.platform_dependent.search(url) + + def _process_download(self, url): + """ + See if an URL is a suitable download for a project. + + If it is, register information in the result dictionary (for + _get_project) about the specific version it's for. + + Note that the return value isn't actually used other than as a boolean + value. + """ + if self.platform_check and self._is_platform_dependent(url): + info = None + else: + info = self.convert_url_to_download_info(url, self.project_name) + logger.debug('process_download: %s -> %s', url, info) + if info: + with self._lock: # needed because self.result is shared + self._update_version_data(self.result, info) + return info + + def _should_queue(self, link, referrer, rel): + """ + Determine whether a link URL from a referring page and with a + particular "rel" attribute should be queued for scraping. + """ + scheme, netloc, path, _, _, _ = urlparse(link) + if path.endswith(self.source_extensions + self.binary_extensions + + self.excluded_extensions): + result = False + elif self.skip_externals and not link.startswith(self.base_url): + result = False + elif not referrer.startswith(self.base_url): + result = False + elif rel not in ('homepage', 'download'): + result = False + elif scheme not in ('http', 'https', 'ftp'): + result = False + elif self._is_platform_dependent(link): + result = False + else: + host = netloc.split(':', 1)[0] + if host.lower() == 'localhost': + result = False + else: + result = True + logger.debug('should_queue: %s (%s) from %s -> %s', link, rel, + referrer, result) + return result + + def _fetch(self): + """ + Get a URL to fetch from the work queue, get the HTML page, examine its + links for download candidates and candidates for further scraping. + + This is a handy method to run in a thread. + """ + while True: + url = self._to_fetch.get() + try: + if url: + page = self.get_page(url) + if page is None: # e.g. after an error + continue + for link, rel in page.links: + if link not in self._seen: + try: + self._seen.add(link) + if (not self._process_download(link) and + self._should_queue(link, url, rel)): + logger.debug('Queueing %s from %s', link, url) + self._to_fetch.put(link) + except MetadataInvalidError: # e.g. invalid versions + pass + except Exception as e: # pragma: no cover + self.errors.put(text_type(e)) + finally: + # always do this, to avoid hangs :-) + self._to_fetch.task_done() + if not url: + #logger.debug('Sentinel seen, quitting.') + break + + def get_page(self, url): + """ + Get the HTML for an URL, possibly from an in-memory cache. + + XXX TODO Note: this cache is never actually cleared. It's assumed that + the data won't get stale over the lifetime of a locator instance (not + necessarily true for the default_locator). + """ + # http://peak.telecommunity.com/DevCenter/EasyInstall#package-index-api + scheme, netloc, path, _, _, _ = urlparse(url) + if scheme == 'file' and os.path.isdir(url2pathname(path)): + url = urljoin(ensure_slash(url), 'index.html') + + if url in self._page_cache: + result = self._page_cache[url] + logger.debug('Returning %s from cache: %s', url, result) + else: + host = netloc.split(':', 1)[0] + result = None + if host in self._bad_hosts: + logger.debug('Skipping %s due to bad host %s', url, host) + else: + req = Request(url, headers={'Accept-encoding': 'identity'}) + try: + logger.debug('Fetching %s', url) + resp = self.opener.open(req, timeout=self.timeout) + logger.debug('Fetched %s', url) + headers = resp.info() + content_type = headers.get('Content-Type', '') + if HTML_CONTENT_TYPE.match(content_type): + final_url = resp.geturl() + data = resp.read() + encoding = headers.get('Content-Encoding') + if encoding: + decoder = self.decoders[encoding] # fail if not found + data = decoder(data) + encoding = 'utf-8' + m = CHARSET.search(content_type) + if m: + encoding = m.group(1) + try: + data = data.decode(encoding) + except UnicodeError: # pragma: no cover + data = data.decode('latin-1') # fallback + result = Page(data, final_url) + self._page_cache[final_url] = result + except HTTPError as e: + if e.code != 404: + logger.exception('Fetch failed: %s: %s', url, e) + except URLError as e: # pragma: no cover + logger.exception('Fetch failed: %s: %s', url, e) + with self._lock: + self._bad_hosts.add(host) + except Exception as e: # pragma: no cover + logger.exception('Fetch failed: %s: %s', url, e) + finally: + self._page_cache[url] = result # even if None (failure) + return result + + _distname_re = re.compile('<a href=[^>]*>([^<]+)<') + + def get_distribution_names(self): + """ + Return all the distribution names known to this locator. + """ + result = set() + page = self.get_page(self.base_url) + if not page: + raise DistlibException('Unable to get %s' % self.base_url) + for match in self._distname_re.finditer(page.data): + result.add(match.group(1)) + return result + +class DirectoryLocator(Locator): + """ + This class locates distributions in a directory tree. + """ + + def __init__(self, path, **kwargs): + """ + Initialise an instance. + :param path: The root of the directory tree to search. + :param kwargs: Passed to the superclass constructor, + except for: + * recursive - if True (the default), subdirectories are + recursed into. If False, only the top-level directory + is searched, + """ + self.recursive = kwargs.pop('recursive', True) + super(DirectoryLocator, self).__init__(**kwargs) + path = os.path.abspath(path) + if not os.path.isdir(path): # pragma: no cover + raise DistlibException('Not a directory: %r' % path) + self.base_dir = path + + def should_include(self, filename, parent): + """ + Should a filename be considered as a candidate for a distribution + archive? As well as the filename, the directory which contains it + is provided, though not used by the current implementation. + """ + return filename.endswith(self.downloadable_extensions) + + def _get_project(self, name): + result = {'urls': {}, 'digests': {}} + for root, dirs, files in os.walk(self.base_dir): + for fn in files: + if self.should_include(fn, root): + fn = os.path.join(root, fn) + url = urlunparse(('file', '', + pathname2url(os.path.abspath(fn)), + '', '', '')) + info = self.convert_url_to_download_info(url, name) + if info: + self._update_version_data(result, info) + if not self.recursive: + break + return result + + def get_distribution_names(self): + """ + Return all the distribution names known to this locator. + """ + result = set() + for root, dirs, files in os.walk(self.base_dir): + for fn in files: + if self.should_include(fn, root): + fn = os.path.join(root, fn) + url = urlunparse(('file', '', + pathname2url(os.path.abspath(fn)), + '', '', '')) + info = self.convert_url_to_download_info(url, None) + if info: + result.add(info['name']) + if not self.recursive: + break + return result + +class JSONLocator(Locator): + """ + This locator uses special extended metadata (not available on PyPI) and is + the basis of performant dependency resolution in distlib. Other locators + require archive downloads before dependencies can be determined! As you + might imagine, that can be slow. + """ + def get_distribution_names(self): + """ + Return all the distribution names known to this locator. + """ + raise NotImplementedError('Not available from this locator') + + def _get_project(self, name): + result = {'urls': {}, 'digests': {}} + data = get_project_data(name) + if data: + for info in data.get('files', []): + if info['ptype'] != 'sdist' or info['pyversion'] != 'source': + continue + # We don't store summary in project metadata as it makes + # the data bigger for no benefit during dependency + # resolution + dist = make_dist(data['name'], info['version'], + summary=data.get('summary', + 'Placeholder for summary'), + scheme=self.scheme) + md = dist.metadata + md.source_url = info['url'] + # TODO SHA256 digest + if 'digest' in info and info['digest']: + dist.digest = ('md5', info['digest']) + md.dependencies = info.get('requirements', {}) + dist.exports = info.get('exports', {}) + result[dist.version] = dist + result['urls'].setdefault(dist.version, set()).add(info['url']) + return result + +class DistPathLocator(Locator): + """ + This locator finds installed distributions in a path. It can be useful for + adding to an :class:`AggregatingLocator`. + """ + def __init__(self, distpath, **kwargs): + """ + Initialise an instance. + + :param distpath: A :class:`DistributionPath` instance to search. + """ + super(DistPathLocator, self).__init__(**kwargs) + assert isinstance(distpath, DistributionPath) + self.distpath = distpath + + def _get_project(self, name): + dist = self.distpath.get_distribution(name) + if dist is None: + result = {'urls': {}, 'digests': {}} + else: + result = { + dist.version: dist, + 'urls': {dist.version: set([dist.source_url])}, + 'digests': {dist.version: set([None])} + } + return result + + +class AggregatingLocator(Locator): + """ + This class allows you to chain and/or merge a list of locators. + """ + def __init__(self, *locators, **kwargs): + """ + Initialise an instance. + + :param locators: The list of locators to search. + :param kwargs: Passed to the superclass constructor, + except for: + * merge - if False (the default), the first successful + search from any of the locators is returned. If True, + the results from all locators are merged (this can be + slow). + """ + self.merge = kwargs.pop('merge', False) + self.locators = locators + super(AggregatingLocator, self).__init__(**kwargs) + + def clear_cache(self): + super(AggregatingLocator, self).clear_cache() + for locator in self.locators: + locator.clear_cache() + + def _set_scheme(self, value): + self._scheme = value + for locator in self.locators: + locator.scheme = value + + scheme = property(Locator.scheme.fget, _set_scheme) + + def _get_project(self, name): + result = {} + for locator in self.locators: + d = locator.get_project(name) + if d: + if self.merge: + files = result.get('urls', {}) + digests = result.get('digests', {}) + # next line could overwrite result['urls'], result['digests'] + result.update(d) + df = result.get('urls') + if files and df: + for k, v in files.items(): + if k in df: + df[k] |= v + else: + df[k] = v + dd = result.get('digests') + if digests and dd: + dd.update(digests) + else: + # See issue #18. If any dists are found and we're looking + # for specific constraints, we only return something if + # a match is found. For example, if a DirectoryLocator + # returns just foo (1.0) while we're looking for + # foo (>= 2.0), we'll pretend there was nothing there so + # that subsequent locators can be queried. Otherwise we + # would just return foo (1.0) which would then lead to a + # failure to find foo (>= 2.0), because other locators + # weren't searched. Note that this only matters when + # merge=False. + if self.matcher is None: + found = True + else: + found = False + for k in d: + if self.matcher.match(k): + found = True + break + if found: + result = d + break + return result + + def get_distribution_names(self): + """ + Return all the distribution names known to this locator. + """ + result = set() + for locator in self.locators: + try: + result |= locator.get_distribution_names() + except NotImplementedError: + pass + return result + + +# We use a legacy scheme simply because most of the dists on PyPI use legacy +# versions which don't conform to PEP 426 / PEP 440. +default_locator = AggregatingLocator( + JSONLocator(), + SimpleScrapingLocator('https://pypi.org/simple/', + timeout=3.0), + scheme='legacy') + +locate = default_locator.locate + +NAME_VERSION_RE = re.compile(r'(?P<name>[\w-]+)\s*' + r'\(\s*(==\s*)?(?P<ver>[^)]+)\)$') + +class DependencyFinder(object): + """ + Locate dependencies for distributions. + """ + + def __init__(self, locator=None): + """ + Initialise an instance, using the specified locator + to locate distributions. + """ + self.locator = locator or default_locator + self.scheme = get_scheme(self.locator.scheme) + + def add_distribution(self, dist): + """ + Add a distribution to the finder. This will update internal information + about who provides what. + :param dist: The distribution to add. + """ + logger.debug('adding distribution %s', dist) + name = dist.key + self.dists_by_name[name] = dist + self.dists[(name, dist.version)] = dist + for p in dist.provides: + name, version = parse_name_and_version(p) + logger.debug('Add to provided: %s, %s, %s', name, version, dist) + self.provided.setdefault(name, set()).add((version, dist)) + + def remove_distribution(self, dist): + """ + Remove a distribution from the finder. This will update internal + information about who provides what. + :param dist: The distribution to remove. + """ + logger.debug('removing distribution %s', dist) + name = dist.key + del self.dists_by_name[name] + del self.dists[(name, dist.version)] + for p in dist.provides: + name, version = parse_name_and_version(p) + logger.debug('Remove from provided: %s, %s, %s', name, version, dist) + s = self.provided[name] + s.remove((version, dist)) + if not s: + del self.provided[name] + + def get_matcher(self, reqt): + """ + Get a version matcher for a requirement. + :param reqt: The requirement + :type reqt: str + :return: A version matcher (an instance of + :class:`distlib.version.Matcher`). + """ + try: + matcher = self.scheme.matcher(reqt) + except UnsupportedVersionError: # pragma: no cover + # XXX compat-mode if cannot read the version + name = reqt.split()[0] + matcher = self.scheme.matcher(name) + return matcher + + def find_providers(self, reqt): + """ + Find the distributions which can fulfill a requirement. + + :param reqt: The requirement. + :type reqt: str + :return: A set of distribution which can fulfill the requirement. + """ + matcher = self.get_matcher(reqt) + name = matcher.key # case-insensitive + result = set() + provided = self.provided + if name in provided: + for version, provider in provided[name]: + try: + match = matcher.match(version) + except UnsupportedVersionError: + match = False + + if match: + result.add(provider) + break + return result + + def try_to_replace(self, provider, other, problems): + """ + Attempt to replace one provider with another. This is typically used + when resolving dependencies from multiple sources, e.g. A requires + (B >= 1.0) while C requires (B >= 1.1). + + For successful replacement, ``provider`` must meet all the requirements + which ``other`` fulfills. + + :param provider: The provider we are trying to replace with. + :param other: The provider we're trying to replace. + :param problems: If False is returned, this will contain what + problems prevented replacement. This is currently + a tuple of the literal string 'cantreplace', + ``provider``, ``other`` and the set of requirements + that ``provider`` couldn't fulfill. + :return: True if we can replace ``other`` with ``provider``, else + False. + """ + rlist = self.reqts[other] + unmatched = set() + for s in rlist: + matcher = self.get_matcher(s) + if not matcher.match(provider.version): + unmatched.add(s) + if unmatched: + # can't replace other with provider + problems.add(('cantreplace', provider, other, + frozenset(unmatched))) + result = False + else: + # can replace other with provider + self.remove_distribution(other) + del self.reqts[other] + for s in rlist: + self.reqts.setdefault(provider, set()).add(s) + self.add_distribution(provider) + result = True + return result + + def find(self, requirement, meta_extras=None, prereleases=False): + """ + Find a distribution and all distributions it depends on. + + :param requirement: The requirement specifying the distribution to + find, or a Distribution instance. + :param meta_extras: A list of meta extras such as :test:, :build: and + so on. + :param prereleases: If ``True``, allow pre-release versions to be + returned - otherwise, don't return prereleases + unless they're all that's available. + + Return a set of :class:`Distribution` instances and a set of + problems. + + The distributions returned should be such that they have the + :attr:`required` attribute set to ``True`` if they were + from the ``requirement`` passed to ``find()``, and they have the + :attr:`build_time_dependency` attribute set to ``True`` unless they + are post-installation dependencies of the ``requirement``. + + The problems should be a tuple consisting of the string + ``'unsatisfied'`` and the requirement which couldn't be satisfied + by any distribution known to the locator. + """ + + self.provided = {} + self.dists = {} + self.dists_by_name = {} + self.reqts = {} + + meta_extras = set(meta_extras or []) + if ':*:' in meta_extras: + meta_extras.remove(':*:') + # :meta: and :run: are implicitly included + meta_extras |= set([':test:', ':build:', ':dev:']) + + if isinstance(requirement, Distribution): + dist = odist = requirement + logger.debug('passed %s as requirement', odist) + else: + dist = odist = self.locator.locate(requirement, + prereleases=prereleases) + if dist is None: + raise DistlibException('Unable to locate %r' % requirement) + logger.debug('located %s', odist) + dist.requested = True + problems = set() + todo = set([dist]) + install_dists = set([odist]) + while todo: + dist = todo.pop() + name = dist.key # case-insensitive + if name not in self.dists_by_name: + self.add_distribution(dist) + else: + #import pdb; pdb.set_trace() + other = self.dists_by_name[name] + if other != dist: + self.try_to_replace(dist, other, problems) + + ireqts = dist.run_requires | dist.meta_requires + sreqts = dist.build_requires + ereqts = set() + if meta_extras and dist in install_dists: + for key in ('test', 'build', 'dev'): + e = ':%s:' % key + if e in meta_extras: + ereqts |= getattr(dist, '%s_requires' % key) + all_reqts = ireqts | sreqts | ereqts + for r in all_reqts: + providers = self.find_providers(r) + if not providers: + logger.debug('No providers found for %r', r) + provider = self.locator.locate(r, prereleases=prereleases) + # If no provider is found and we didn't consider + # prereleases, consider them now. + if provider is None and not prereleases: + provider = self.locator.locate(r, prereleases=True) + if provider is None: + logger.debug('Cannot satisfy %r', r) + problems.add(('unsatisfied', r)) + else: + n, v = provider.key, provider.version + if (n, v) not in self.dists: + todo.add(provider) + providers.add(provider) + if r in ireqts and dist in install_dists: + install_dists.add(provider) + logger.debug('Adding %s to install_dists', + provider.name_and_version) + for p in providers: + name = p.key + if name not in self.dists_by_name: + self.reqts.setdefault(p, set()).add(r) + else: + other = self.dists_by_name[name] + if other != p: + # see if other can be replaced by p + self.try_to_replace(p, other, problems) + + dists = set(self.dists.values()) + for dist in dists: + dist.build_time_dependency = dist not in install_dists + if dist.build_time_dependency: + logger.debug('%s is a build-time dependency only.', + dist.name_and_version) + logger.debug('find done for %s', odist) + return dists, problems diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/manifest.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/manifest.py new file mode 100644 index 0000000..ca0fe44 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/manifest.py @@ -0,0 +1,393 @@ +# -*- coding: utf-8 -*- +# +# Copyright (C) 2012-2013 Python Software Foundation. +# See LICENSE.txt and CONTRIBUTORS.txt. +# +""" +Class representing the list of files in a distribution. + +Equivalent to distutils.filelist, but fixes some problems. +""" +import fnmatch +import logging +import os +import re +import sys + +from . import DistlibException +from .compat import fsdecode +from .util import convert_path + + +__all__ = ['Manifest'] + +logger = logging.getLogger(__name__) + +# a \ followed by some spaces + EOL +_COLLAPSE_PATTERN = re.compile('\\\\w*\n', re.M) +_COMMENTED_LINE = re.compile('#.*?(?=\n)|\n(?=$)', re.M | re.S) + +# +# Due to the different results returned by fnmatch.translate, we need +# to do slightly different processing for Python 2.7 and 3.2 ... this needed +# to be brought in for Python 3.6 onwards. +# +_PYTHON_VERSION = sys.version_info[:2] + +class Manifest(object): + """A list of files built by on exploring the filesystem and filtered by + applying various patterns to what we find there. + """ + + def __init__(self, base=None): + """ + Initialise an instance. + + :param base: The base directory to explore under. + """ + self.base = os.path.abspath(os.path.normpath(base or os.getcwd())) + self.prefix = self.base + os.sep + self.allfiles = None + self.files = set() + + # + # Public API + # + + def findall(self): + """Find all files under the base and set ``allfiles`` to the absolute + pathnames of files found. + """ + from stat import S_ISREG, S_ISDIR, S_ISLNK + + self.allfiles = allfiles = [] + root = self.base + stack = [root] + pop = stack.pop + push = stack.append + + while stack: + root = pop() + names = os.listdir(root) + + for name in names: + fullname = os.path.join(root, name) + + # Avoid excess stat calls -- just one will do, thank you! + stat = os.stat(fullname) + mode = stat.st_mode + if S_ISREG(mode): + allfiles.append(fsdecode(fullname)) + elif S_ISDIR(mode) and not S_ISLNK(mode): + push(fullname) + + def add(self, item): + """ + Add a file to the manifest. + + :param item: The pathname to add. This can be relative to the base. + """ + if not item.startswith(self.prefix): + item = os.path.join(self.base, item) + self.files.add(os.path.normpath(item)) + + def add_many(self, items): + """ + Add a list of files to the manifest. + + :param items: The pathnames to add. These can be relative to the base. + """ + for item in items: + self.add(item) + + def sorted(self, wantdirs=False): + """ + Return sorted files in directory order + """ + + def add_dir(dirs, d): + dirs.add(d) + logger.debug('add_dir added %s', d) + if d != self.base: + parent, _ = os.path.split(d) + assert parent not in ('', '/') + add_dir(dirs, parent) + + result = set(self.files) # make a copy! + if wantdirs: + dirs = set() + for f in result: + add_dir(dirs, os.path.dirname(f)) + result |= dirs + return [os.path.join(*path_tuple) for path_tuple in + sorted(os.path.split(path) for path in result)] + + def clear(self): + """Clear all collected files.""" + self.files = set() + self.allfiles = [] + + def process_directive(self, directive): + """ + Process a directive which either adds some files from ``allfiles`` to + ``files``, or removes some files from ``files``. + + :param directive: The directive to process. This should be in a format + compatible with distutils ``MANIFEST.in`` files: + + http://docs.python.org/distutils/sourcedist.html#commands + """ + # Parse the line: split it up, make sure the right number of words + # is there, and return the relevant words. 'action' is always + # defined: it's the first word of the line. Which of the other + # three are defined depends on the action; it'll be either + # patterns, (dir and patterns), or (dirpattern). + action, patterns, thedir, dirpattern = self._parse_directive(directive) + + # OK, now we know that the action is valid and we have the + # right number of words on the line for that action -- so we + # can proceed with minimal error-checking. + if action == 'include': + for pattern in patterns: + if not self._include_pattern(pattern, anchor=True): + logger.warning('no files found matching %r', pattern) + + elif action == 'exclude': + for pattern in patterns: + found = self._exclude_pattern(pattern, anchor=True) + #if not found: + # logger.warning('no previously-included files ' + # 'found matching %r', pattern) + + elif action == 'global-include': + for pattern in patterns: + if not self._include_pattern(pattern, anchor=False): + logger.warning('no files found matching %r ' + 'anywhere in distribution', pattern) + + elif action == 'global-exclude': + for pattern in patterns: + found = self._exclude_pattern(pattern, anchor=False) + #if not found: + # logger.warning('no previously-included files ' + # 'matching %r found anywhere in ' + # 'distribution', pattern) + + elif action == 'recursive-include': + for pattern in patterns: + if not self._include_pattern(pattern, prefix=thedir): + logger.warning('no files found matching %r ' + 'under directory %r', pattern, thedir) + + elif action == 'recursive-exclude': + for pattern in patterns: + found = self._exclude_pattern(pattern, prefix=thedir) + #if not found: + # logger.warning('no previously-included files ' + # 'matching %r found under directory %r', + # pattern, thedir) + + elif action == 'graft': + if not self._include_pattern(None, prefix=dirpattern): + logger.warning('no directories found matching %r', + dirpattern) + + elif action == 'prune': + if not self._exclude_pattern(None, prefix=dirpattern): + logger.warning('no previously-included directories found ' + 'matching %r', dirpattern) + else: # pragma: no cover + # This should never happen, as it should be caught in + # _parse_template_line + raise DistlibException( + 'invalid action %r' % action) + + # + # Private API + # + + def _parse_directive(self, directive): + """ + Validate a directive. + :param directive: The directive to validate. + :return: A tuple of action, patterns, thedir, dir_patterns + """ + words = directive.split() + if len(words) == 1 and words[0] not in ('include', 'exclude', + 'global-include', + 'global-exclude', + 'recursive-include', + 'recursive-exclude', + 'graft', 'prune'): + # no action given, let's use the default 'include' + words.insert(0, 'include') + + action = words[0] + patterns = thedir = dir_pattern = None + + if action in ('include', 'exclude', + 'global-include', 'global-exclude'): + if len(words) < 2: + raise DistlibException( + '%r expects <pattern1> <pattern2> ...' % action) + + patterns = [convert_path(word) for word in words[1:]] + + elif action in ('recursive-include', 'recursive-exclude'): + if len(words) < 3: + raise DistlibException( + '%r expects <dir> <pattern1> <pattern2> ...' % action) + + thedir = convert_path(words[1]) + patterns = [convert_path(word) for word in words[2:]] + + elif action in ('graft', 'prune'): + if len(words) != 2: + raise DistlibException( + '%r expects a single <dir_pattern>' % action) + + dir_pattern = convert_path(words[1]) + + else: + raise DistlibException('unknown action %r' % action) + + return action, patterns, thedir, dir_pattern + + def _include_pattern(self, pattern, anchor=True, prefix=None, + is_regex=False): + """Select strings (presumably filenames) from 'self.files' that + match 'pattern', a Unix-style wildcard (glob) pattern. + + Patterns are not quite the same as implemented by the 'fnmatch' + module: '*' and '?' match non-special characters, where "special" + is platform-dependent: slash on Unix; colon, slash, and backslash on + DOS/Windows; and colon on Mac OS. + + If 'anchor' is true (the default), then the pattern match is more + stringent: "*.py" will match "foo.py" but not "foo/bar.py". If + 'anchor' is false, both of these will match. + + If 'prefix' is supplied, then only filenames starting with 'prefix' + (itself a pattern) and ending with 'pattern', with anything in between + them, will match. 'anchor' is ignored in this case. + + If 'is_regex' is true, 'anchor' and 'prefix' are ignored, and + 'pattern' is assumed to be either a string containing a regex or a + regex object -- no translation is done, the regex is just compiled + and used as-is. + + Selected strings will be added to self.files. + + Return True if files are found. + """ + # XXX docstring lying about what the special chars are? + found = False + pattern_re = self._translate_pattern(pattern, anchor, prefix, is_regex) + + # delayed loading of allfiles list + if self.allfiles is None: + self.findall() + + for name in self.allfiles: + if pattern_re.search(name): + self.files.add(name) + found = True + return found + + def _exclude_pattern(self, pattern, anchor=True, prefix=None, + is_regex=False): + """Remove strings (presumably filenames) from 'files' that match + 'pattern'. + + Other parameters are the same as for 'include_pattern()', above. + The list 'self.files' is modified in place. Return True if files are + found. + + This API is public to allow e.g. exclusion of SCM subdirs, e.g. when + packaging source distributions + """ + found = False + pattern_re = self._translate_pattern(pattern, anchor, prefix, is_regex) + for f in list(self.files): + if pattern_re.search(f): + self.files.remove(f) + found = True + return found + + def _translate_pattern(self, pattern, anchor=True, prefix=None, + is_regex=False): + """Translate a shell-like wildcard pattern to a compiled regular + expression. + + Return the compiled regex. If 'is_regex' true, + then 'pattern' is directly compiled to a regex (if it's a string) + or just returned as-is (assumes it's a regex object). + """ + if is_regex: + if isinstance(pattern, str): + return re.compile(pattern) + else: + return pattern + + if _PYTHON_VERSION > (3, 2): + # ditch start and end characters + start, _, end = self._glob_to_re('_').partition('_') + + if pattern: + pattern_re = self._glob_to_re(pattern) + if _PYTHON_VERSION > (3, 2): + assert pattern_re.startswith(start) and pattern_re.endswith(end) + else: + pattern_re = '' + + base = re.escape(os.path.join(self.base, '')) + if prefix is not None: + # ditch end of pattern character + if _PYTHON_VERSION <= (3, 2): + empty_pattern = self._glob_to_re('') + prefix_re = self._glob_to_re(prefix)[:-len(empty_pattern)] + else: + prefix_re = self._glob_to_re(prefix) + assert prefix_re.startswith(start) and prefix_re.endswith(end) + prefix_re = prefix_re[len(start): len(prefix_re) - len(end)] + sep = os.sep + if os.sep == '\\': + sep = r'\\' + if _PYTHON_VERSION <= (3, 2): + pattern_re = '^' + base + sep.join((prefix_re, + '.*' + pattern_re)) + else: + pattern_re = pattern_re[len(start): len(pattern_re) - len(end)] + pattern_re = r'%s%s%s%s.*%s%s' % (start, base, prefix_re, sep, + pattern_re, end) + else: # no prefix -- respect anchor flag + if anchor: + if _PYTHON_VERSION <= (3, 2): + pattern_re = '^' + base + pattern_re + else: + pattern_re = r'%s%s%s' % (start, base, pattern_re[len(start):]) + + return re.compile(pattern_re) + + def _glob_to_re(self, pattern): + """Translate a shell-like glob pattern to a regular expression. + + Return a string containing the regex. Differs from + 'fnmatch.translate()' in that '*' does not match "special characters" + (which are platform-specific). + """ + pattern_re = fnmatch.translate(pattern) + + # '?' and '*' in the glob pattern become '.' and '.*' in the RE, which + # IMHO is wrong -- '?' and '*' aren't supposed to match slash in Unix, + # and by extension they shouldn't match such "special characters" under + # any OS. So change all non-escaped dots in the RE to match any + # character except the special characters (currently: just os.sep). + sep = os.sep + if os.sep == '\\': + # we're using a regex to manipulate a regex, so we need + # to escape the backslash twice + sep = r'\\\\' + escaped = r'\1[^%s]' % sep + pattern_re = re.sub(r'((?<!\\)(\\\\)*)\.', escaped, pattern_re) + return pattern_re diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/markers.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/markers.py new file mode 100644 index 0000000..ee1f3e2 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/markers.py @@ -0,0 +1,131 @@ +# -*- coding: utf-8 -*- +# +# Copyright (C) 2012-2017 Vinay Sajip. +# Licensed to the Python Software Foundation under a contributor agreement. +# See LICENSE.txt and CONTRIBUTORS.txt. +# +""" +Parser for the environment markers micro-language defined in PEP 508. +""" + +# Note: In PEP 345, the micro-language was Python compatible, so the ast +# module could be used to parse it. However, PEP 508 introduced operators such +# as ~= and === which aren't in Python, necessitating a different approach. + +import os +import sys +import platform +import re + +from .compat import python_implementation, urlparse, string_types +from .util import in_venv, parse_marker + +__all__ = ['interpret'] + +def _is_literal(o): + if not isinstance(o, string_types) or not o: + return False + return o[0] in '\'"' + +class Evaluator(object): + """ + This class is used to evaluate marker expessions. + """ + + operations = { + '==': lambda x, y: x == y, + '===': lambda x, y: x == y, + '~=': lambda x, y: x == y or x > y, + '!=': lambda x, y: x != y, + '<': lambda x, y: x < y, + '<=': lambda x, y: x == y or x < y, + '>': lambda x, y: x > y, + '>=': lambda x, y: x == y or x > y, + 'and': lambda x, y: x and y, + 'or': lambda x, y: x or y, + 'in': lambda x, y: x in y, + 'not in': lambda x, y: x not in y, + } + + def evaluate(self, expr, context): + """ + Evaluate a marker expression returned by the :func:`parse_requirement` + function in the specified context. + """ + if isinstance(expr, string_types): + if expr[0] in '\'"': + result = expr[1:-1] + else: + if expr not in context: + raise SyntaxError('unknown variable: %s' % expr) + result = context[expr] + else: + assert isinstance(expr, dict) + op = expr['op'] + if op not in self.operations: + raise NotImplementedError('op not implemented: %s' % op) + elhs = expr['lhs'] + erhs = expr['rhs'] + if _is_literal(expr['lhs']) and _is_literal(expr['rhs']): + raise SyntaxError('invalid comparison: %s %s %s' % (elhs, op, erhs)) + + lhs = self.evaluate(elhs, context) + rhs = self.evaluate(erhs, context) + result = self.operations[op](lhs, rhs) + return result + +def default_context(): + def format_full_version(info): + version = '%s.%s.%s' % (info.major, info.minor, info.micro) + kind = info.releaselevel + if kind != 'final': + version += kind[0] + str(info.serial) + return version + + if hasattr(sys, 'implementation'): + implementation_version = format_full_version(sys.implementation.version) + implementation_name = sys.implementation.name + else: + implementation_version = '0' + implementation_name = '' + + result = { + 'implementation_name': implementation_name, + 'implementation_version': implementation_version, + 'os_name': os.name, + 'platform_machine': platform.machine(), + 'platform_python_implementation': platform.python_implementation(), + 'platform_release': platform.release(), + 'platform_system': platform.system(), + 'platform_version': platform.version(), + 'platform_in_venv': str(in_venv()), + 'python_full_version': platform.python_version(), + 'python_version': platform.python_version()[:3], + 'sys_platform': sys.platform, + } + return result + +DEFAULT_CONTEXT = default_context() +del default_context + +evaluator = Evaluator() + +def interpret(marker, execution_context=None): + """ + Interpret a marker and return a result depending on environment. + + :param marker: The marker to interpret. + :type marker: str + :param execution_context: The context used for name lookup. + :type execution_context: mapping + """ + try: + expr, rest = parse_marker(marker) + except Exception as e: + raise SyntaxError('Unable to interpret marker syntax: %s: %s' % (marker, e)) + if rest and rest[0] != '#': + raise SyntaxError('unexpected trailing data in marker: %s: %s' % (marker, rest)) + context = dict(DEFAULT_CONTEXT) + if execution_context: + context.update(execution_context) + return evaluator.evaluate(expr, context) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/metadata.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/metadata.py new file mode 100644 index 0000000..2d61378 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/metadata.py @@ -0,0 +1,1096 @@ +# -*- coding: utf-8 -*- +# +# Copyright (C) 2012 The Python Software Foundation. +# See LICENSE.txt and CONTRIBUTORS.txt. +# +"""Implementation of the Metadata for Python packages PEPs. + +Supports all metadata formats (1.0, 1.1, 1.2, and 2.0 experimental). +""" +from __future__ import unicode_literals + +import codecs +from email import message_from_file +import json +import logging +import re + + +from . import DistlibException, __version__ +from .compat import StringIO, string_types, text_type +from .markers import interpret +from .util import extract_by_key, get_extras +from .version import get_scheme, PEP440_VERSION_RE + +logger = logging.getLogger(__name__) + + +class MetadataMissingError(DistlibException): + """A required metadata is missing""" + + +class MetadataConflictError(DistlibException): + """Attempt to read or write metadata fields that are conflictual.""" + + +class MetadataUnrecognizedVersionError(DistlibException): + """Unknown metadata version number.""" + + +class MetadataInvalidError(DistlibException): + """A metadata value is invalid""" + +# public API of this module +__all__ = ['Metadata', 'PKG_INFO_ENCODING', 'PKG_INFO_PREFERRED_VERSION'] + +# Encoding used for the PKG-INFO files +PKG_INFO_ENCODING = 'utf-8' + +# preferred version. Hopefully will be changed +# to 1.2 once PEP 345 is supported everywhere +PKG_INFO_PREFERRED_VERSION = '1.1' + +_LINE_PREFIX_1_2 = re.compile('\n \\|') +_LINE_PREFIX_PRE_1_2 = re.compile('\n ') +_241_FIELDS = ('Metadata-Version', 'Name', 'Version', 'Platform', + 'Summary', 'Description', + 'Keywords', 'Home-page', 'Author', 'Author-email', + 'License') + +_314_FIELDS = ('Metadata-Version', 'Name', 'Version', 'Platform', + 'Supported-Platform', 'Summary', 'Description', + 'Keywords', 'Home-page', 'Author', 'Author-email', + 'License', 'Classifier', 'Download-URL', 'Obsoletes', + 'Provides', 'Requires') + +_314_MARKERS = ('Obsoletes', 'Provides', 'Requires', 'Classifier', + 'Download-URL') + +_345_FIELDS = ('Metadata-Version', 'Name', 'Version', 'Platform', + 'Supported-Platform', 'Summary', 'Description', + 'Keywords', 'Home-page', 'Author', 'Author-email', + 'Maintainer', 'Maintainer-email', 'License', + 'Classifier', 'Download-URL', 'Obsoletes-Dist', + 'Project-URL', 'Provides-Dist', 'Requires-Dist', + 'Requires-Python', 'Requires-External') + +_345_MARKERS = ('Provides-Dist', 'Requires-Dist', 'Requires-Python', + 'Obsoletes-Dist', 'Requires-External', 'Maintainer', + 'Maintainer-email', 'Project-URL') + +_426_FIELDS = ('Metadata-Version', 'Name', 'Version', 'Platform', + 'Supported-Platform', 'Summary', 'Description', + 'Keywords', 'Home-page', 'Author', 'Author-email', + 'Maintainer', 'Maintainer-email', 'License', + 'Classifier', 'Download-URL', 'Obsoletes-Dist', + 'Project-URL', 'Provides-Dist', 'Requires-Dist', + 'Requires-Python', 'Requires-External', 'Private-Version', + 'Obsoleted-By', 'Setup-Requires-Dist', 'Extension', + 'Provides-Extra') + +_426_MARKERS = ('Private-Version', 'Provides-Extra', 'Obsoleted-By', + 'Setup-Requires-Dist', 'Extension') + +# See issue #106: Sometimes 'Requires' and 'Provides' occur wrongly in +# the metadata. Include them in the tuple literal below to allow them +# (for now). +_566_FIELDS = _426_FIELDS + ('Description-Content-Type', + 'Requires', 'Provides') + +_566_MARKERS = ('Description-Content-Type',) + +_ALL_FIELDS = set() +_ALL_FIELDS.update(_241_FIELDS) +_ALL_FIELDS.update(_314_FIELDS) +_ALL_FIELDS.update(_345_FIELDS) +_ALL_FIELDS.update(_426_FIELDS) +_ALL_FIELDS.update(_566_FIELDS) + +EXTRA_RE = re.compile(r'''extra\s*==\s*("([^"]+)"|'([^']+)')''') + + +def _version2fieldlist(version): + if version == '1.0': + return _241_FIELDS + elif version == '1.1': + return _314_FIELDS + elif version == '1.2': + return _345_FIELDS + elif version in ('1.3', '2.1'): + return _345_FIELDS + _566_FIELDS + elif version == '2.0': + return _426_FIELDS + raise MetadataUnrecognizedVersionError(version) + + +def _best_version(fields): + """Detect the best version depending on the fields used.""" + def _has_marker(keys, markers): + for marker in markers: + if marker in keys: + return True + return False + + keys = [] + for key, value in fields.items(): + if value in ([], 'UNKNOWN', None): + continue + keys.append(key) + + possible_versions = ['1.0', '1.1', '1.2', '1.3', '2.0', '2.1'] + + # first let's try to see if a field is not part of one of the version + for key in keys: + if key not in _241_FIELDS and '1.0' in possible_versions: + possible_versions.remove('1.0') + logger.debug('Removed 1.0 due to %s', key) + if key not in _314_FIELDS and '1.1' in possible_versions: + possible_versions.remove('1.1') + logger.debug('Removed 1.1 due to %s', key) + if key not in _345_FIELDS and '1.2' in possible_versions: + possible_versions.remove('1.2') + logger.debug('Removed 1.2 due to %s', key) + if key not in _566_FIELDS and '1.3' in possible_versions: + possible_versions.remove('1.3') + logger.debug('Removed 1.3 due to %s', key) + if key not in _566_FIELDS and '2.1' in possible_versions: + if key != 'Description': # In 2.1, description allowed after headers + possible_versions.remove('2.1') + logger.debug('Removed 2.1 due to %s', key) + if key not in _426_FIELDS and '2.0' in possible_versions: + possible_versions.remove('2.0') + logger.debug('Removed 2.0 due to %s', key) + + # possible_version contains qualified versions + if len(possible_versions) == 1: + return possible_versions[0] # found ! + elif len(possible_versions) == 0: + logger.debug('Out of options - unknown metadata set: %s', fields) + raise MetadataConflictError('Unknown metadata set') + + # let's see if one unique marker is found + is_1_1 = '1.1' in possible_versions and _has_marker(keys, _314_MARKERS) + is_1_2 = '1.2' in possible_versions and _has_marker(keys, _345_MARKERS) + is_2_1 = '2.1' in possible_versions and _has_marker(keys, _566_MARKERS) + is_2_0 = '2.0' in possible_versions and _has_marker(keys, _426_MARKERS) + if int(is_1_1) + int(is_1_2) + int(is_2_1) + int(is_2_0) > 1: + raise MetadataConflictError('You used incompatible 1.1/1.2/2.0/2.1 fields') + + # we have the choice, 1.0, or 1.2, or 2.0 + # - 1.0 has a broken Summary field but works with all tools + # - 1.1 is to avoid + # - 1.2 fixes Summary but has little adoption + # - 2.0 adds more features and is very new + if not is_1_1 and not is_1_2 and not is_2_1 and not is_2_0: + # we couldn't find any specific marker + if PKG_INFO_PREFERRED_VERSION in possible_versions: + return PKG_INFO_PREFERRED_VERSION + if is_1_1: + return '1.1' + if is_1_2: + return '1.2' + if is_2_1: + return '2.1' + + return '2.0' + +_ATTR2FIELD = { + 'metadata_version': 'Metadata-Version', + 'name': 'Name', + 'version': 'Version', + 'platform': 'Platform', + 'supported_platform': 'Supported-Platform', + 'summary': 'Summary', + 'description': 'Description', + 'keywords': 'Keywords', + 'home_page': 'Home-page', + 'author': 'Author', + 'author_email': 'Author-email', + 'maintainer': 'Maintainer', + 'maintainer_email': 'Maintainer-email', + 'license': 'License', + 'classifier': 'Classifier', + 'download_url': 'Download-URL', + 'obsoletes_dist': 'Obsoletes-Dist', + 'provides_dist': 'Provides-Dist', + 'requires_dist': 'Requires-Dist', + 'setup_requires_dist': 'Setup-Requires-Dist', + 'requires_python': 'Requires-Python', + 'requires_external': 'Requires-External', + 'requires': 'Requires', + 'provides': 'Provides', + 'obsoletes': 'Obsoletes', + 'project_url': 'Project-URL', + 'private_version': 'Private-Version', + 'obsoleted_by': 'Obsoleted-By', + 'extension': 'Extension', + 'provides_extra': 'Provides-Extra', +} + +_PREDICATE_FIELDS = ('Requires-Dist', 'Obsoletes-Dist', 'Provides-Dist') +_VERSIONS_FIELDS = ('Requires-Python',) +_VERSION_FIELDS = ('Version',) +_LISTFIELDS = ('Platform', 'Classifier', 'Obsoletes', + 'Requires', 'Provides', 'Obsoletes-Dist', + 'Provides-Dist', 'Requires-Dist', 'Requires-External', + 'Project-URL', 'Supported-Platform', 'Setup-Requires-Dist', + 'Provides-Extra', 'Extension') +_LISTTUPLEFIELDS = ('Project-URL',) + +_ELEMENTSFIELD = ('Keywords',) + +_UNICODEFIELDS = ('Author', 'Maintainer', 'Summary', 'Description') + +_MISSING = object() + +_FILESAFE = re.compile('[^A-Za-z0-9.]+') + + +def _get_name_and_version(name, version, for_filename=False): + """Return the distribution name with version. + + If for_filename is true, return a filename-escaped form.""" + if for_filename: + # For both name and version any runs of non-alphanumeric or '.' + # characters are replaced with a single '-'. Additionally any + # spaces in the version string become '.' + name = _FILESAFE.sub('-', name) + version = _FILESAFE.sub('-', version.replace(' ', '.')) + return '%s-%s' % (name, version) + + +class LegacyMetadata(object): + """The legacy metadata of a release. + + Supports versions 1.0, 1.1 and 1.2 (auto-detected). You can + instantiate the class with one of these arguments (or none): + - *path*, the path to a metadata file + - *fileobj* give a file-like object with metadata as content + - *mapping* is a dict-like object + - *scheme* is a version scheme name + """ + # TODO document the mapping API and UNKNOWN default key + + def __init__(self, path=None, fileobj=None, mapping=None, + scheme='default'): + if [path, fileobj, mapping].count(None) < 2: + raise TypeError('path, fileobj and mapping are exclusive') + self._fields = {} + self.requires_files = [] + self._dependencies = None + self.scheme = scheme + if path is not None: + self.read(path) + elif fileobj is not None: + self.read_file(fileobj) + elif mapping is not None: + self.update(mapping) + self.set_metadata_version() + + def set_metadata_version(self): + self._fields['Metadata-Version'] = _best_version(self._fields) + + def _write_field(self, fileobj, name, value): + fileobj.write('%s: %s\n' % (name, value)) + + def __getitem__(self, name): + return self.get(name) + + def __setitem__(self, name, value): + return self.set(name, value) + + def __delitem__(self, name): + field_name = self._convert_name(name) + try: + del self._fields[field_name] + except KeyError: + raise KeyError(name) + + def __contains__(self, name): + return (name in self._fields or + self._convert_name(name) in self._fields) + + def _convert_name(self, name): + if name in _ALL_FIELDS: + return name + name = name.replace('-', '_').lower() + return _ATTR2FIELD.get(name, name) + + def _default_value(self, name): + if name in _LISTFIELDS or name in _ELEMENTSFIELD: + return [] + return 'UNKNOWN' + + def _remove_line_prefix(self, value): + if self.metadata_version in ('1.0', '1.1'): + return _LINE_PREFIX_PRE_1_2.sub('\n', value) + else: + return _LINE_PREFIX_1_2.sub('\n', value) + + def __getattr__(self, name): + if name in _ATTR2FIELD: + return self[name] + raise AttributeError(name) + + # + # Public API + # + +# dependencies = property(_get_dependencies, _set_dependencies) + + def get_fullname(self, filesafe=False): + """Return the distribution name with version. + + If filesafe is true, return a filename-escaped form.""" + return _get_name_and_version(self['Name'], self['Version'], filesafe) + + def is_field(self, name): + """return True if name is a valid metadata key""" + name = self._convert_name(name) + return name in _ALL_FIELDS + + def is_multi_field(self, name): + name = self._convert_name(name) + return name in _LISTFIELDS + + def read(self, filepath): + """Read the metadata values from a file path.""" + fp = codecs.open(filepath, 'r', encoding='utf-8') + try: + self.read_file(fp) + finally: + fp.close() + + def read_file(self, fileob): + """Read the metadata values from a file object.""" + msg = message_from_file(fileob) + self._fields['Metadata-Version'] = msg['metadata-version'] + + # When reading, get all the fields we can + for field in _ALL_FIELDS: + if field not in msg: + continue + if field in _LISTFIELDS: + # we can have multiple lines + values = msg.get_all(field) + if field in _LISTTUPLEFIELDS and values is not None: + values = [tuple(value.split(',')) for value in values] + self.set(field, values) + else: + # single line + value = msg[field] + if value is not None and value != 'UNKNOWN': + self.set(field, value) + # logger.debug('Attempting to set metadata for %s', self) + # self.set_metadata_version() + + def write(self, filepath, skip_unknown=False): + """Write the metadata fields to filepath.""" + fp = codecs.open(filepath, 'w', encoding='utf-8') + try: + self.write_file(fp, skip_unknown) + finally: + fp.close() + + def write_file(self, fileobject, skip_unknown=False): + """Write the PKG-INFO format data to a file object.""" + self.set_metadata_version() + + for field in _version2fieldlist(self['Metadata-Version']): + values = self.get(field) + if skip_unknown and values in ('UNKNOWN', [], ['UNKNOWN']): + continue + if field in _ELEMENTSFIELD: + self._write_field(fileobject, field, ','.join(values)) + continue + if field not in _LISTFIELDS: + if field == 'Description': + if self.metadata_version in ('1.0', '1.1'): + values = values.replace('\n', '\n ') + else: + values = values.replace('\n', '\n |') + values = [values] + + if field in _LISTTUPLEFIELDS: + values = [','.join(value) for value in values] + + for value in values: + self._write_field(fileobject, field, value) + + def update(self, other=None, **kwargs): + """Set metadata values from the given iterable `other` and kwargs. + + Behavior is like `dict.update`: If `other` has a ``keys`` method, + they are looped over and ``self[key]`` is assigned ``other[key]``. + Else, ``other`` is an iterable of ``(key, value)`` iterables. + + Keys that don't match a metadata field or that have an empty value are + dropped. + """ + def _set(key, value): + if key in _ATTR2FIELD and value: + self.set(self._convert_name(key), value) + + if not other: + # other is None or empty container + pass + elif hasattr(other, 'keys'): + for k in other.keys(): + _set(k, other[k]) + else: + for k, v in other: + _set(k, v) + + if kwargs: + for k, v in kwargs.items(): + _set(k, v) + + def set(self, name, value): + """Control then set a metadata field.""" + name = self._convert_name(name) + + if ((name in _ELEMENTSFIELD or name == 'Platform') and + not isinstance(value, (list, tuple))): + if isinstance(value, string_types): + value = [v.strip() for v in value.split(',')] + else: + value = [] + elif (name in _LISTFIELDS and + not isinstance(value, (list, tuple))): + if isinstance(value, string_types): + value = [value] + else: + value = [] + + if logger.isEnabledFor(logging.WARNING): + project_name = self['Name'] + + scheme = get_scheme(self.scheme) + if name in _PREDICATE_FIELDS and value is not None: + for v in value: + # check that the values are valid + if not scheme.is_valid_matcher(v.split(';')[0]): + logger.warning( + "'%s': '%s' is not valid (field '%s')", + project_name, v, name) + # FIXME this rejects UNKNOWN, is that right? + elif name in _VERSIONS_FIELDS and value is not None: + if not scheme.is_valid_constraint_list(value): + logger.warning("'%s': '%s' is not a valid version (field '%s')", + project_name, value, name) + elif name in _VERSION_FIELDS and value is not None: + if not scheme.is_valid_version(value): + logger.warning("'%s': '%s' is not a valid version (field '%s')", + project_name, value, name) + + if name in _UNICODEFIELDS: + if name == 'Description': + value = self._remove_line_prefix(value) + + self._fields[name] = value + + def get(self, name, default=_MISSING): + """Get a metadata field.""" + name = self._convert_name(name) + if name not in self._fields: + if default is _MISSING: + default = self._default_value(name) + return default + if name in _UNICODEFIELDS: + value = self._fields[name] + return value + elif name in _LISTFIELDS: + value = self._fields[name] + if value is None: + return [] + res = [] + for val in value: + if name not in _LISTTUPLEFIELDS: + res.append(val) + else: + # That's for Project-URL + res.append((val[0], val[1])) + return res + + elif name in _ELEMENTSFIELD: + value = self._fields[name] + if isinstance(value, string_types): + return value.split(',') + return self._fields[name] + + def check(self, strict=False): + """Check if the metadata is compliant. If strict is True then raise if + no Name or Version are provided""" + self.set_metadata_version() + + # XXX should check the versions (if the file was loaded) + missing, warnings = [], [] + + for attr in ('Name', 'Version'): # required by PEP 345 + if attr not in self: + missing.append(attr) + + if strict and missing != []: + msg = 'missing required metadata: %s' % ', '.join(missing) + raise MetadataMissingError(msg) + + for attr in ('Home-page', 'Author'): + if attr not in self: + missing.append(attr) + + # checking metadata 1.2 (XXX needs to check 1.1, 1.0) + if self['Metadata-Version'] != '1.2': + return missing, warnings + + scheme = get_scheme(self.scheme) + + def are_valid_constraints(value): + for v in value: + if not scheme.is_valid_matcher(v.split(';')[0]): + return False + return True + + for fields, controller in ((_PREDICATE_FIELDS, are_valid_constraints), + (_VERSIONS_FIELDS, + scheme.is_valid_constraint_list), + (_VERSION_FIELDS, + scheme.is_valid_version)): + for field in fields: + value = self.get(field, None) + if value is not None and not controller(value): + warnings.append("Wrong value for '%s': %s" % (field, value)) + + return missing, warnings + + def todict(self, skip_missing=False): + """Return fields as a dict. + + Field names will be converted to use the underscore-lowercase style + instead of hyphen-mixed case (i.e. home_page instead of Home-page). + """ + self.set_metadata_version() + + mapping_1_0 = ( + ('metadata_version', 'Metadata-Version'), + ('name', 'Name'), + ('version', 'Version'), + ('summary', 'Summary'), + ('home_page', 'Home-page'), + ('author', 'Author'), + ('author_email', 'Author-email'), + ('license', 'License'), + ('description', 'Description'), + ('keywords', 'Keywords'), + ('platform', 'Platform'), + ('classifiers', 'Classifier'), + ('download_url', 'Download-URL'), + ) + + data = {} + for key, field_name in mapping_1_0: + if not skip_missing or field_name in self._fields: + data[key] = self[field_name] + + if self['Metadata-Version'] == '1.2': + mapping_1_2 = ( + ('requires_dist', 'Requires-Dist'), + ('requires_python', 'Requires-Python'), + ('requires_external', 'Requires-External'), + ('provides_dist', 'Provides-Dist'), + ('obsoletes_dist', 'Obsoletes-Dist'), + ('project_url', 'Project-URL'), + ('maintainer', 'Maintainer'), + ('maintainer_email', 'Maintainer-email'), + ) + for key, field_name in mapping_1_2: + if not skip_missing or field_name in self._fields: + if key != 'project_url': + data[key] = self[field_name] + else: + data[key] = [','.join(u) for u in self[field_name]] + + elif self['Metadata-Version'] == '1.1': + mapping_1_1 = ( + ('provides', 'Provides'), + ('requires', 'Requires'), + ('obsoletes', 'Obsoletes'), + ) + for key, field_name in mapping_1_1: + if not skip_missing or field_name in self._fields: + data[key] = self[field_name] + + return data + + def add_requirements(self, requirements): + if self['Metadata-Version'] == '1.1': + # we can't have 1.1 metadata *and* Setuptools requires + for field in ('Obsoletes', 'Requires', 'Provides'): + if field in self: + del self[field] + self['Requires-Dist'] += requirements + + # Mapping API + # TODO could add iter* variants + + def keys(self): + return list(_version2fieldlist(self['Metadata-Version'])) + + def __iter__(self): + for key in self.keys(): + yield key + + def values(self): + return [self[key] for key in self.keys()] + + def items(self): + return [(key, self[key]) for key in self.keys()] + + def __repr__(self): + return '<%s %s %s>' % (self.__class__.__name__, self.name, + self.version) + + +METADATA_FILENAME = 'pydist.json' +WHEEL_METADATA_FILENAME = 'metadata.json' +LEGACY_METADATA_FILENAME = 'METADATA' + + +class Metadata(object): + """ + The metadata of a release. This implementation uses 2.0 (JSON) + metadata where possible. If not possible, it wraps a LegacyMetadata + instance which handles the key-value metadata format. + """ + + METADATA_VERSION_MATCHER = re.compile(r'^\d+(\.\d+)*$') + + NAME_MATCHER = re.compile('^[0-9A-Z]([0-9A-Z_.-]*[0-9A-Z])?$', re.I) + + VERSION_MATCHER = PEP440_VERSION_RE + + SUMMARY_MATCHER = re.compile('.{1,2047}') + + METADATA_VERSION = '2.0' + + GENERATOR = 'distlib (%s)' % __version__ + + MANDATORY_KEYS = { + 'name': (), + 'version': (), + 'summary': ('legacy',), + } + + INDEX_KEYS = ('name version license summary description author ' + 'author_email keywords platform home_page classifiers ' + 'download_url') + + DEPENDENCY_KEYS = ('extras run_requires test_requires build_requires ' + 'dev_requires provides meta_requires obsoleted_by ' + 'supports_environments') + + SYNTAX_VALIDATORS = { + 'metadata_version': (METADATA_VERSION_MATCHER, ()), + 'name': (NAME_MATCHER, ('legacy',)), + 'version': (VERSION_MATCHER, ('legacy',)), + 'summary': (SUMMARY_MATCHER, ('legacy',)), + } + + __slots__ = ('_legacy', '_data', 'scheme') + + def __init__(self, path=None, fileobj=None, mapping=None, + scheme='default'): + if [path, fileobj, mapping].count(None) < 2: + raise TypeError('path, fileobj and mapping are exclusive') + self._legacy = None + self._data = None + self.scheme = scheme + #import pdb; pdb.set_trace() + if mapping is not None: + try: + self._validate_mapping(mapping, scheme) + self._data = mapping + except MetadataUnrecognizedVersionError: + self._legacy = LegacyMetadata(mapping=mapping, scheme=scheme) + self.validate() + else: + data = None + if path: + with open(path, 'rb') as f: + data = f.read() + elif fileobj: + data = fileobj.read() + if data is None: + # Initialised with no args - to be added + self._data = { + 'metadata_version': self.METADATA_VERSION, + 'generator': self.GENERATOR, + } + else: + if not isinstance(data, text_type): + data = data.decode('utf-8') + try: + self._data = json.loads(data) + self._validate_mapping(self._data, scheme) + except ValueError: + # Note: MetadataUnrecognizedVersionError does not + # inherit from ValueError (it's a DistlibException, + # which should not inherit from ValueError). + # The ValueError comes from the json.load - if that + # succeeds and we get a validation error, we want + # that to propagate + self._legacy = LegacyMetadata(fileobj=StringIO(data), + scheme=scheme) + self.validate() + + common_keys = set(('name', 'version', 'license', 'keywords', 'summary')) + + none_list = (None, list) + none_dict = (None, dict) + + mapped_keys = { + 'run_requires': ('Requires-Dist', list), + 'build_requires': ('Setup-Requires-Dist', list), + 'dev_requires': none_list, + 'test_requires': none_list, + 'meta_requires': none_list, + 'extras': ('Provides-Extra', list), + 'modules': none_list, + 'namespaces': none_list, + 'exports': none_dict, + 'commands': none_dict, + 'classifiers': ('Classifier', list), + 'source_url': ('Download-URL', None), + 'metadata_version': ('Metadata-Version', None), + } + + del none_list, none_dict + + def __getattribute__(self, key): + common = object.__getattribute__(self, 'common_keys') + mapped = object.__getattribute__(self, 'mapped_keys') + if key in mapped: + lk, maker = mapped[key] + if self._legacy: + if lk is None: + result = None if maker is None else maker() + else: + result = self._legacy.get(lk) + else: + value = None if maker is None else maker() + if key not in ('commands', 'exports', 'modules', 'namespaces', + 'classifiers'): + result = self._data.get(key, value) + else: + # special cases for PEP 459 + sentinel = object() + result = sentinel + d = self._data.get('extensions') + if d: + if key == 'commands': + result = d.get('python.commands', value) + elif key == 'classifiers': + d = d.get('python.details') + if d: + result = d.get(key, value) + else: + d = d.get('python.exports') + if not d: + d = self._data.get('python.exports') + if d: + result = d.get(key, value) + if result is sentinel: + result = value + elif key not in common: + result = object.__getattribute__(self, key) + elif self._legacy: + result = self._legacy.get(key) + else: + result = self._data.get(key) + return result + + def _validate_value(self, key, value, scheme=None): + if key in self.SYNTAX_VALIDATORS: + pattern, exclusions = self.SYNTAX_VALIDATORS[key] + if (scheme or self.scheme) not in exclusions: + m = pattern.match(value) + if not m: + raise MetadataInvalidError("'%s' is an invalid value for " + "the '%s' property" % (value, + key)) + + def __setattr__(self, key, value): + self._validate_value(key, value) + common = object.__getattribute__(self, 'common_keys') + mapped = object.__getattribute__(self, 'mapped_keys') + if key in mapped: + lk, _ = mapped[key] + if self._legacy: + if lk is None: + raise NotImplementedError + self._legacy[lk] = value + elif key not in ('commands', 'exports', 'modules', 'namespaces', + 'classifiers'): + self._data[key] = value + else: + # special cases for PEP 459 + d = self._data.setdefault('extensions', {}) + if key == 'commands': + d['python.commands'] = value + elif key == 'classifiers': + d = d.setdefault('python.details', {}) + d[key] = value + else: + d = d.setdefault('python.exports', {}) + d[key] = value + elif key not in common: + object.__setattr__(self, key, value) + else: + if key == 'keywords': + if isinstance(value, string_types): + value = value.strip() + if value: + value = value.split() + else: + value = [] + if self._legacy: + self._legacy[key] = value + else: + self._data[key] = value + + @property + def name_and_version(self): + return _get_name_and_version(self.name, self.version, True) + + @property + def provides(self): + if self._legacy: + result = self._legacy['Provides-Dist'] + else: + result = self._data.setdefault('provides', []) + s = '%s (%s)' % (self.name, self.version) + if s not in result: + result.append(s) + return result + + @provides.setter + def provides(self, value): + if self._legacy: + self._legacy['Provides-Dist'] = value + else: + self._data['provides'] = value + + def get_requirements(self, reqts, extras=None, env=None): + """ + Base method to get dependencies, given a set of extras + to satisfy and an optional environment context. + :param reqts: A list of sometimes-wanted dependencies, + perhaps dependent on extras and environment. + :param extras: A list of optional components being requested. + :param env: An optional environment for marker evaluation. + """ + if self._legacy: + result = reqts + else: + result = [] + extras = get_extras(extras or [], self.extras) + for d in reqts: + if 'extra' not in d and 'environment' not in d: + # unconditional + include = True + else: + if 'extra' not in d: + # Not extra-dependent - only environment-dependent + include = True + else: + include = d.get('extra') in extras + if include: + # Not excluded because of extras, check environment + marker = d.get('environment') + if marker: + include = interpret(marker, env) + if include: + result.extend(d['requires']) + for key in ('build', 'dev', 'test'): + e = ':%s:' % key + if e in extras: + extras.remove(e) + # A recursive call, but it should terminate since 'test' + # has been removed from the extras + reqts = self._data.get('%s_requires' % key, []) + result.extend(self.get_requirements(reqts, extras=extras, + env=env)) + return result + + @property + def dictionary(self): + if self._legacy: + return self._from_legacy() + return self._data + + @property + def dependencies(self): + if self._legacy: + raise NotImplementedError + else: + return extract_by_key(self._data, self.DEPENDENCY_KEYS) + + @dependencies.setter + def dependencies(self, value): + if self._legacy: + raise NotImplementedError + else: + self._data.update(value) + + def _validate_mapping(self, mapping, scheme): + if mapping.get('metadata_version') != self.METADATA_VERSION: + raise MetadataUnrecognizedVersionError() + missing = [] + for key, exclusions in self.MANDATORY_KEYS.items(): + if key not in mapping: + if scheme not in exclusions: + missing.append(key) + if missing: + msg = 'Missing metadata items: %s' % ', '.join(missing) + raise MetadataMissingError(msg) + for k, v in mapping.items(): + self._validate_value(k, v, scheme) + + def validate(self): + if self._legacy: + missing, warnings = self._legacy.check(True) + if missing or warnings: + logger.warning('Metadata: missing: %s, warnings: %s', + missing, warnings) + else: + self._validate_mapping(self._data, self.scheme) + + def todict(self): + if self._legacy: + return self._legacy.todict(True) + else: + result = extract_by_key(self._data, self.INDEX_KEYS) + return result + + def _from_legacy(self): + assert self._legacy and not self._data + result = { + 'metadata_version': self.METADATA_VERSION, + 'generator': self.GENERATOR, + } + lmd = self._legacy.todict(True) # skip missing ones + for k in ('name', 'version', 'license', 'summary', 'description', + 'classifier'): + if k in lmd: + if k == 'classifier': + nk = 'classifiers' + else: + nk = k + result[nk] = lmd[k] + kw = lmd.get('Keywords', []) + if kw == ['']: + kw = [] + result['keywords'] = kw + keys = (('requires_dist', 'run_requires'), + ('setup_requires_dist', 'build_requires')) + for ok, nk in keys: + if ok in lmd and lmd[ok]: + result[nk] = [{'requires': lmd[ok]}] + result['provides'] = self.provides + author = {} + maintainer = {} + return result + + LEGACY_MAPPING = { + 'name': 'Name', + 'version': 'Version', + 'license': 'License', + 'summary': 'Summary', + 'description': 'Description', + 'classifiers': 'Classifier', + } + + def _to_legacy(self): + def process_entries(entries): + reqts = set() + for e in entries: + extra = e.get('extra') + env = e.get('environment') + rlist = e['requires'] + for r in rlist: + if not env and not extra: + reqts.add(r) + else: + marker = '' + if extra: + marker = 'extra == "%s"' % extra + if env: + if marker: + marker = '(%s) and %s' % (env, marker) + else: + marker = env + reqts.add(';'.join((r, marker))) + return reqts + + assert self._data and not self._legacy + result = LegacyMetadata() + nmd = self._data + for nk, ok in self.LEGACY_MAPPING.items(): + if nk in nmd: + result[ok] = nmd[nk] + r1 = process_entries(self.run_requires + self.meta_requires) + r2 = process_entries(self.build_requires + self.dev_requires) + if self.extras: + result['Provides-Extra'] = sorted(self.extras) + result['Requires-Dist'] = sorted(r1) + result['Setup-Requires-Dist'] = sorted(r2) + # TODO: other fields such as contacts + return result + + def write(self, path=None, fileobj=None, legacy=False, skip_unknown=True): + if [path, fileobj].count(None) != 1: + raise ValueError('Exactly one of path and fileobj is needed') + self.validate() + if legacy: + if self._legacy: + legacy_md = self._legacy + else: + legacy_md = self._to_legacy() + if path: + legacy_md.write(path, skip_unknown=skip_unknown) + else: + legacy_md.write_file(fileobj, skip_unknown=skip_unknown) + else: + if self._legacy: + d = self._from_legacy() + else: + d = self._data + if fileobj: + json.dump(d, fileobj, ensure_ascii=True, indent=2, + sort_keys=True) + else: + with codecs.open(path, 'w', 'utf-8') as f: + json.dump(d, f, ensure_ascii=True, indent=2, + sort_keys=True) + + def add_requirements(self, requirements): + if self._legacy: + self._legacy.add_requirements(requirements) + else: + run_requires = self._data.setdefault('run_requires', []) + always = None + for entry in run_requires: + if 'environment' not in entry and 'extra' not in entry: + always = entry + break + if always is None: + always = { 'requires': requirements } + run_requires.insert(0, always) + else: + rset = set(always['requires']) | set(requirements) + always['requires'] = sorted(rset) + + def __repr__(self): + name = self.name or '(no name)' + version = self.version or 'no version' + return '<%s %s %s (%s)>' % (self.__class__.__name__, + self.metadata_version, name, version) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/resources.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/resources.py new file mode 100644 index 0000000..1884016 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/resources.py @@ -0,0 +1,355 @@ +# -*- coding: utf-8 -*- +# +# Copyright (C) 2013-2017 Vinay Sajip. +# Licensed to the Python Software Foundation under a contributor agreement. +# See LICENSE.txt and CONTRIBUTORS.txt. +# +from __future__ import unicode_literals + +import bisect +import io +import logging +import os +import pkgutil +import shutil +import sys +import types +import zipimport + +from . import DistlibException +from .util import cached_property, get_cache_base, path_to_cache_dir, Cache + +logger = logging.getLogger(__name__) + + +cache = None # created when needed + + +class ResourceCache(Cache): + def __init__(self, base=None): + if base is None: + # Use native string to avoid issues on 2.x: see Python #20140. + base = os.path.join(get_cache_base(), str('resource-cache')) + super(ResourceCache, self).__init__(base) + + def is_stale(self, resource, path): + """ + Is the cache stale for the given resource? + + :param resource: The :class:`Resource` being cached. + :param path: The path of the resource in the cache. + :return: True if the cache is stale. + """ + # Cache invalidation is a hard problem :-) + return True + + def get(self, resource): + """ + Get a resource into the cache, + + :param resource: A :class:`Resource` instance. + :return: The pathname of the resource in the cache. + """ + prefix, path = resource.finder.get_cache_info(resource) + if prefix is None: + result = path + else: + result = os.path.join(self.base, self.prefix_to_dir(prefix), path) + dirname = os.path.dirname(result) + if not os.path.isdir(dirname): + os.makedirs(dirname) + if not os.path.exists(result): + stale = True + else: + stale = self.is_stale(resource, path) + if stale: + # write the bytes of the resource to the cache location + with open(result, 'wb') as f: + f.write(resource.bytes) + return result + + +class ResourceBase(object): + def __init__(self, finder, name): + self.finder = finder + self.name = name + + +class Resource(ResourceBase): + """ + A class representing an in-package resource, such as a data file. This is + not normally instantiated by user code, but rather by a + :class:`ResourceFinder` which manages the resource. + """ + is_container = False # Backwards compatibility + + def as_stream(self): + """ + Get the resource as a stream. + + This is not a property to make it obvious that it returns a new stream + each time. + """ + return self.finder.get_stream(self) + + @cached_property + def file_path(self): + global cache + if cache is None: + cache = ResourceCache() + return cache.get(self) + + @cached_property + def bytes(self): + return self.finder.get_bytes(self) + + @cached_property + def size(self): + return self.finder.get_size(self) + + +class ResourceContainer(ResourceBase): + is_container = True # Backwards compatibility + + @cached_property + def resources(self): + return self.finder.get_resources(self) + + +class ResourceFinder(object): + """ + Resource finder for file system resources. + """ + + if sys.platform.startswith('java'): + skipped_extensions = ('.pyc', '.pyo', '.class') + else: + skipped_extensions = ('.pyc', '.pyo') + + def __init__(self, module): + self.module = module + self.loader = getattr(module, '__loader__', None) + self.base = os.path.dirname(getattr(module, '__file__', '')) + + def _adjust_path(self, path): + return os.path.realpath(path) + + def _make_path(self, resource_name): + # Issue #50: need to preserve type of path on Python 2.x + # like os.path._get_sep + if isinstance(resource_name, bytes): # should only happen on 2.x + sep = b'/' + else: + sep = '/' + parts = resource_name.split(sep) + parts.insert(0, self.base) + result = os.path.join(*parts) + return self._adjust_path(result) + + def _find(self, path): + return os.path.exists(path) + + def get_cache_info(self, resource): + return None, resource.path + + def find(self, resource_name): + path = self._make_path(resource_name) + if not self._find(path): + result = None + else: + if self._is_directory(path): + result = ResourceContainer(self, resource_name) + else: + result = Resource(self, resource_name) + result.path = path + return result + + def get_stream(self, resource): + return open(resource.path, 'rb') + + def get_bytes(self, resource): + with open(resource.path, 'rb') as f: + return f.read() + + def get_size(self, resource): + return os.path.getsize(resource.path) + + def get_resources(self, resource): + def allowed(f): + return (f != '__pycache__' and not + f.endswith(self.skipped_extensions)) + return set([f for f in os.listdir(resource.path) if allowed(f)]) + + def is_container(self, resource): + return self._is_directory(resource.path) + + _is_directory = staticmethod(os.path.isdir) + + def iterator(self, resource_name): + resource = self.find(resource_name) + if resource is not None: + todo = [resource] + while todo: + resource = todo.pop(0) + yield resource + if resource.is_container: + rname = resource.name + for name in resource.resources: + if not rname: + new_name = name + else: + new_name = '/'.join([rname, name]) + child = self.find(new_name) + if child.is_container: + todo.append(child) + else: + yield child + + +class ZipResourceFinder(ResourceFinder): + """ + Resource finder for resources in .zip files. + """ + def __init__(self, module): + super(ZipResourceFinder, self).__init__(module) + archive = self.loader.archive + self.prefix_len = 1 + len(archive) + # PyPy doesn't have a _files attr on zipimporter, and you can't set one + if hasattr(self.loader, '_files'): + self._files = self.loader._files + else: + self._files = zipimport._zip_directory_cache[archive] + self.index = sorted(self._files) + + def _adjust_path(self, path): + return path + + def _find(self, path): + path = path[self.prefix_len:] + if path in self._files: + result = True + else: + if path and path[-1] != os.sep: + path = path + os.sep + i = bisect.bisect(self.index, path) + try: + result = self.index[i].startswith(path) + except IndexError: + result = False + if not result: + logger.debug('_find failed: %r %r', path, self.loader.prefix) + else: + logger.debug('_find worked: %r %r', path, self.loader.prefix) + return result + + def get_cache_info(self, resource): + prefix = self.loader.archive + path = resource.path[1 + len(prefix):] + return prefix, path + + def get_bytes(self, resource): + return self.loader.get_data(resource.path) + + def get_stream(self, resource): + return io.BytesIO(self.get_bytes(resource)) + + def get_size(self, resource): + path = resource.path[self.prefix_len:] + return self._files[path][3] + + def get_resources(self, resource): + path = resource.path[self.prefix_len:] + if path and path[-1] != os.sep: + path += os.sep + plen = len(path) + result = set() + i = bisect.bisect(self.index, path) + while i < len(self.index): + if not self.index[i].startswith(path): + break + s = self.index[i][plen:] + result.add(s.split(os.sep, 1)[0]) # only immediate children + i += 1 + return result + + def _is_directory(self, path): + path = path[self.prefix_len:] + if path and path[-1] != os.sep: + path += os.sep + i = bisect.bisect(self.index, path) + try: + result = self.index[i].startswith(path) + except IndexError: + result = False + return result + +_finder_registry = { + type(None): ResourceFinder, + zipimport.zipimporter: ZipResourceFinder +} + +try: + # In Python 3.6, _frozen_importlib -> _frozen_importlib_external + try: + import _frozen_importlib_external as _fi + except ImportError: + import _frozen_importlib as _fi + _finder_registry[_fi.SourceFileLoader] = ResourceFinder + _finder_registry[_fi.FileFinder] = ResourceFinder + del _fi +except (ImportError, AttributeError): + pass + + +def register_finder(loader, finder_maker): + _finder_registry[type(loader)] = finder_maker + +_finder_cache = {} + + +def finder(package): + """ + Return a resource finder for a package. + :param package: The name of the package. + :return: A :class:`ResourceFinder` instance for the package. + """ + if package in _finder_cache: + result = _finder_cache[package] + else: + if package not in sys.modules: + __import__(package) + module = sys.modules[package] + path = getattr(module, '__path__', None) + if path is None: + raise DistlibException('You cannot get a finder for a module, ' + 'only for a package') + loader = getattr(module, '__loader__', None) + finder_maker = _finder_registry.get(type(loader)) + if finder_maker is None: + raise DistlibException('Unable to locate finder for %r' % package) + result = finder_maker(module) + _finder_cache[package] = result + return result + + +_dummy_module = types.ModuleType(str('__dummy__')) + + +def finder_for_path(path): + """ + Return a resource finder for a path, which should represent a container. + + :param path: The path. + :return: A :class:`ResourceFinder` instance for the path. + """ + result = None + # calls any path hooks, gets importer into cache + pkgutil.get_importer(path) + loader = sys.path_importer_cache.get(path) + finder = _finder_registry.get(type(loader)) + if finder: + module = _dummy_module + module.__file__ = os.path.join(path, '') + module.__loader__ = loader + result = finder(module) + return result diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/scripts.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/scripts.py new file mode 100644 index 0000000..5965e24 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/scripts.py @@ -0,0 +1,403 @@ +# -*- coding: utf-8 -*- +# +# Copyright (C) 2013-2015 Vinay Sajip. +# Licensed to the Python Software Foundation under a contributor agreement. +# See LICENSE.txt and CONTRIBUTORS.txt. +# +from io import BytesIO +import logging +import os +import re +import struct +import sys + +from .compat import sysconfig, detect_encoding, ZipFile +from .resources import finder +from .util import (FileOperator, get_export_entry, convert_path, + get_executable, in_venv) + +logger = logging.getLogger(__name__) + +_DEFAULT_MANIFEST = ''' +<?xml version="1.0" encoding="UTF-8" standalone="yes"?> +<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0"> + <assemblyIdentity version="1.0.0.0" + processorArchitecture="X86" + name="%s" + type="win32"/> + + <!-- Identify the application security requirements. --> + <trustInfo xmlns="urn:schemas-microsoft-com:asm.v3"> + <security> + <requestedPrivileges> + <requestedExecutionLevel level="asInvoker" uiAccess="false"/> + </requestedPrivileges> + </security> + </trustInfo> +</assembly>'''.strip() + +# check if Python is called on the first line with this expression +FIRST_LINE_RE = re.compile(b'^#!.*pythonw?[0-9.]*([ \t].*)?$') +SCRIPT_TEMPLATE = r'''# -*- coding: utf-8 -*- +import re +import sys +from %(module)s import %(import_name)s +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(%(func)s()) +''' + + +def _enquote_executable(executable): + if ' ' in executable: + # make sure we quote only the executable in case of env + # for example /usr/bin/env "/dir with spaces/bin/jython" + # instead of "/usr/bin/env /dir with spaces/bin/jython" + # otherwise whole + if executable.startswith('/usr/bin/env '): + env, _executable = executable.split(' ', 1) + if ' ' in _executable and not _executable.startswith('"'): + executable = '%s "%s"' % (env, _executable) + else: + if not executable.startswith('"'): + executable = '"%s"' % executable + return executable + + +class ScriptMaker(object): + """ + A class to copy or create scripts from source scripts or callable + specifications. + """ + script_template = SCRIPT_TEMPLATE + + executable = None # for shebangs + + def __init__(self, source_dir, target_dir, add_launchers=True, + dry_run=False, fileop=None): + self.source_dir = source_dir + self.target_dir = target_dir + self.add_launchers = add_launchers + self.force = False + self.clobber = False + # It only makes sense to set mode bits on POSIX. + self.set_mode = (os.name == 'posix') or (os.name == 'java' and + os._name == 'posix') + self.variants = set(('', 'X.Y')) + self._fileop = fileop or FileOperator(dry_run) + + self._is_nt = os.name == 'nt' or ( + os.name == 'java' and os._name == 'nt') + + def _get_alternate_executable(self, executable, options): + if options.get('gui', False) and self._is_nt: # pragma: no cover + dn, fn = os.path.split(executable) + fn = fn.replace('python', 'pythonw') + executable = os.path.join(dn, fn) + return executable + + if sys.platform.startswith('java'): # pragma: no cover + def _is_shell(self, executable): + """ + Determine if the specified executable is a script + (contains a #! line) + """ + try: + with open(executable) as fp: + return fp.read(2) == '#!' + except (OSError, IOError): + logger.warning('Failed to open %s', executable) + return False + + def _fix_jython_executable(self, executable): + if self._is_shell(executable): + # Workaround for Jython is not needed on Linux systems. + import java + + if java.lang.System.getProperty('os.name') == 'Linux': + return executable + elif executable.lower().endswith('jython.exe'): + # Use wrapper exe for Jython on Windows + return executable + return '/usr/bin/env %s' % executable + + def _build_shebang(self, executable, post_interp): + """ + Build a shebang line. In the simple case (on Windows, or a shebang line + which is not too long or contains spaces) use a simple formulation for + the shebang. Otherwise, use /bin/sh as the executable, with a contrived + shebang which allows the script to run either under Python or sh, using + suitable quoting. Thanks to Harald Nordgren for his input. + + See also: http://www.in-ulm.de/~mascheck/various/shebang/#length + https://hg.mozilla.org/mozilla-central/file/tip/mach + """ + if os.name != 'posix': + simple_shebang = True + else: + # Add 3 for '#!' prefix and newline suffix. + shebang_length = len(executable) + len(post_interp) + 3 + if sys.platform == 'darwin': + max_shebang_length = 512 + else: + max_shebang_length = 127 + simple_shebang = ((b' ' not in executable) and + (shebang_length <= max_shebang_length)) + + if simple_shebang: + result = b'#!' + executable + post_interp + b'\n' + else: + result = b'#!/bin/sh\n' + result += b"'''exec' " + executable + post_interp + b' "$0" "$@"\n' + result += b"' '''" + return result + + def _get_shebang(self, encoding, post_interp=b'', options=None): + enquote = True + if self.executable: + executable = self.executable + enquote = False # assume this will be taken care of + elif not sysconfig.is_python_build(): + executable = get_executable() + elif in_venv(): # pragma: no cover + executable = os.path.join(sysconfig.get_path('scripts'), + 'python%s' % sysconfig.get_config_var('EXE')) + else: # pragma: no cover + executable = os.path.join( + sysconfig.get_config_var('BINDIR'), + 'python%s%s' % (sysconfig.get_config_var('VERSION'), + sysconfig.get_config_var('EXE'))) + if options: + executable = self._get_alternate_executable(executable, options) + + if sys.platform.startswith('java'): # pragma: no cover + executable = self._fix_jython_executable(executable) + # Normalise case for Windows + executable = os.path.normcase(executable) + # If the user didn't specify an executable, it may be necessary to + # cater for executable paths with spaces (not uncommon on Windows) + if enquote: + executable = _enquote_executable(executable) + # Issue #51: don't use fsencode, since we later try to + # check that the shebang is decodable using utf-8. + executable = executable.encode('utf-8') + # in case of IronPython, play safe and enable frames support + if (sys.platform == 'cli' and '-X:Frames' not in post_interp + and '-X:FullFrames' not in post_interp): # pragma: no cover + post_interp += b' -X:Frames' + shebang = self._build_shebang(executable, post_interp) + # Python parser starts to read a script using UTF-8 until + # it gets a #coding:xxx cookie. The shebang has to be the + # first line of a file, the #coding:xxx cookie cannot be + # written before. So the shebang has to be decodable from + # UTF-8. + try: + shebang.decode('utf-8') + except UnicodeDecodeError: # pragma: no cover + raise ValueError( + 'The shebang (%r) is not decodable from utf-8' % shebang) + # If the script is encoded to a custom encoding (use a + # #coding:xxx cookie), the shebang has to be decodable from + # the script encoding too. + if encoding != 'utf-8': + try: + shebang.decode(encoding) + except UnicodeDecodeError: # pragma: no cover + raise ValueError( + 'The shebang (%r) is not decodable ' + 'from the script encoding (%r)' % (shebang, encoding)) + return shebang + + def _get_script_text(self, entry): + return self.script_template % dict(module=entry.prefix, + import_name=entry.suffix.split('.')[0], + func=entry.suffix) + + manifest = _DEFAULT_MANIFEST + + def get_manifest(self, exename): + base = os.path.basename(exename) + return self.manifest % base + + def _write_script(self, names, shebang, script_bytes, filenames, ext): + use_launcher = self.add_launchers and self._is_nt + linesep = os.linesep.encode('utf-8') + if not shebang.endswith(linesep): + shebang += linesep + if not use_launcher: + script_bytes = shebang + script_bytes + else: # pragma: no cover + if ext == 'py': + launcher = self._get_launcher('t') + else: + launcher = self._get_launcher('w') + stream = BytesIO() + with ZipFile(stream, 'w') as zf: + zf.writestr('__main__.py', script_bytes) + zip_data = stream.getvalue() + script_bytes = launcher + shebang + zip_data + for name in names: + outname = os.path.join(self.target_dir, name) + if use_launcher: # pragma: no cover + n, e = os.path.splitext(outname) + if e.startswith('.py'): + outname = n + outname = '%s.exe' % outname + try: + self._fileop.write_binary_file(outname, script_bytes) + except Exception: + # Failed writing an executable - it might be in use. + logger.warning('Failed to write executable - trying to ' + 'use .deleteme logic') + dfname = '%s.deleteme' % outname + if os.path.exists(dfname): + os.remove(dfname) # Not allowed to fail here + os.rename(outname, dfname) # nor here + self._fileop.write_binary_file(outname, script_bytes) + logger.debug('Able to replace executable using ' + '.deleteme logic') + try: + os.remove(dfname) + except Exception: + pass # still in use - ignore error + else: + if self._is_nt and not outname.endswith('.' + ext): # pragma: no cover + outname = '%s.%s' % (outname, ext) + if os.path.exists(outname) and not self.clobber: + logger.warning('Skipping existing file %s', outname) + continue + self._fileop.write_binary_file(outname, script_bytes) + if self.set_mode: + self._fileop.set_executable_mode([outname]) + filenames.append(outname) + + def _make_script(self, entry, filenames, options=None): + post_interp = b'' + if options: + args = options.get('interpreter_args', []) + if args: + args = ' %s' % ' '.join(args) + post_interp = args.encode('utf-8') + shebang = self._get_shebang('utf-8', post_interp, options=options) + script = self._get_script_text(entry).encode('utf-8') + name = entry.name + scriptnames = set() + if '' in self.variants: + scriptnames.add(name) + if 'X' in self.variants: + scriptnames.add('%s%s' % (name, sys.version[0])) + if 'X.Y' in self.variants: + scriptnames.add('%s-%s' % (name, sys.version[:3])) + if options and options.get('gui', False): + ext = 'pyw' + else: + ext = 'py' + self._write_script(scriptnames, shebang, script, filenames, ext) + + def _copy_script(self, script, filenames): + adjust = False + script = os.path.join(self.source_dir, convert_path(script)) + outname = os.path.join(self.target_dir, os.path.basename(script)) + if not self.force and not self._fileop.newer(script, outname): + logger.debug('not copying %s (up-to-date)', script) + return + + # Always open the file, but ignore failures in dry-run mode -- + # that way, we'll get accurate feedback if we can read the + # script. + try: + f = open(script, 'rb') + except IOError: # pragma: no cover + if not self.dry_run: + raise + f = None + else: + first_line = f.readline() + if not first_line: # pragma: no cover + logger.warning('%s: %s is an empty file (skipping)', + self.get_command_name(), script) + return + + match = FIRST_LINE_RE.match(first_line.replace(b'\r\n', b'\n')) + if match: + adjust = True + post_interp = match.group(1) or b'' + + if not adjust: + if f: + f.close() + self._fileop.copy_file(script, outname) + if self.set_mode: + self._fileop.set_executable_mode([outname]) + filenames.append(outname) + else: + logger.info('copying and adjusting %s -> %s', script, + self.target_dir) + if not self._fileop.dry_run: + encoding, lines = detect_encoding(f.readline) + f.seek(0) + shebang = self._get_shebang(encoding, post_interp) + if b'pythonw' in first_line: # pragma: no cover + ext = 'pyw' + else: + ext = 'py' + n = os.path.basename(outname) + self._write_script([n], shebang, f.read(), filenames, ext) + if f: + f.close() + + @property + def dry_run(self): + return self._fileop.dry_run + + @dry_run.setter + def dry_run(self, value): + self._fileop.dry_run = value + + if os.name == 'nt' or (os.name == 'java' and os._name == 'nt'): # pragma: no cover + # Executable launcher support. + # Launchers are from https://bitbucket.org/vinay.sajip/simple_launcher/ + + def _get_launcher(self, kind): + if struct.calcsize('P') == 8: # 64-bit + bits = '64' + else: + bits = '32' + name = '%s%s.exe' % (kind, bits) + # Issue 31: don't hardcode an absolute package name, but + # determine it relative to the current package + distlib_package = __name__.rsplit('.', 1)[0] + result = finder(distlib_package).find(name).bytes + return result + + # Public API follows + + def make(self, specification, options=None): + """ + Make a script. + + :param specification: The specification, which is either a valid export + entry specification (to make a script from a + callable) or a filename (to make a script by + copying from a source location). + :param options: A dictionary of options controlling script generation. + :return: A list of all absolute pathnames written to. + """ + filenames = [] + entry = get_export_entry(specification) + if entry is None: + self._copy_script(specification, filenames) + else: + self._make_script(entry, filenames, options=options) + return filenames + + def make_multiple(self, specifications, options=None): + """ + Take a list of specifications and make scripts from them, + :param specifications: A list of specifications. + :return: A list of all absolute pathnames written to, + """ + filenames = [] + for specification in specifications: + filenames.extend(self.make(specification, options)) + return filenames diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/t32.exe b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/t32.exe new file mode 100644 index 0000000000000000000000000000000000000000..5d5bce1f4a65f0bea9636a5a825646c520903df4 GIT binary patch literal 92672 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 bEwa>S$L3eF2AVa{tbt|?G;84hUIYIIEj{&8 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/t64.exe b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/t64.exe new file mode 100644 index 0000000000000000000000000000000000000000..039ce441b721ee180d373e5590289a6aa9249a51 GIT binary patch literal 102912 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 FzX4cTQwjh8 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/util.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/util.py new file mode 100644 index 0000000..e851146 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/util.py @@ -0,0 +1,1760 @@ +# +# Copyright (C) 2012-2017 The Python Software Foundation. +# See LICENSE.txt and CONTRIBUTORS.txt. +# +import codecs +from collections import deque +import contextlib +import csv +from glob import iglob as std_iglob +import io +import json +import logging +import os +import py_compile +import re +import socket +try: + import ssl +except ImportError: # pragma: no cover + ssl = None +import subprocess +import sys +import tarfile +import tempfile +import textwrap + +try: + import threading +except ImportError: # pragma: no cover + import dummy_threading as threading +import time + +from . import DistlibException +from .compat import (string_types, text_type, shutil, raw_input, StringIO, + cache_from_source, urlopen, urljoin, httplib, xmlrpclib, + splittype, HTTPHandler, BaseConfigurator, valid_ident, + Container, configparser, URLError, ZipFile, fsdecode, + unquote, urlparse) + +logger = logging.getLogger(__name__) + +# +# Requirement parsing code as per PEP 508 +# + +IDENTIFIER = re.compile(r'^([\w\.-]+)\s*') +VERSION_IDENTIFIER = re.compile(r'^([\w\.*+-]+)\s*') +COMPARE_OP = re.compile(r'^(<=?|>=?|={2,3}|[~!]=)\s*') +MARKER_OP = re.compile(r'^((<=?)|(>=?)|={2,3}|[~!]=|in|not\s+in)\s*') +OR = re.compile(r'^or\b\s*') +AND = re.compile(r'^and\b\s*') +NON_SPACE = re.compile(r'(\S+)\s*') +STRING_CHUNK = re.compile(r'([\s\w\.{}()*+#:;,/?!~`@$%^&=|<>\[\]-]+)') + + +def parse_marker(marker_string): + """ + Parse a marker string and return a dictionary containing a marker expression. + + The dictionary will contain keys "op", "lhs" and "rhs" for non-terminals in + the expression grammar, or strings. A string contained in quotes is to be + interpreted as a literal string, and a string not contained in quotes is a + variable (such as os_name). + """ + def marker_var(remaining): + # either identifier, or literal string + m = IDENTIFIER.match(remaining) + if m: + result = m.groups()[0] + remaining = remaining[m.end():] + elif not remaining: + raise SyntaxError('unexpected end of input') + else: + q = remaining[0] + if q not in '\'"': + raise SyntaxError('invalid expression: %s' % remaining) + oq = '\'"'.replace(q, '') + remaining = remaining[1:] + parts = [q] + while remaining: + # either a string chunk, or oq, or q to terminate + if remaining[0] == q: + break + elif remaining[0] == oq: + parts.append(oq) + remaining = remaining[1:] + else: + m = STRING_CHUNK.match(remaining) + if not m: + raise SyntaxError('error in string literal: %s' % remaining) + parts.append(m.groups()[0]) + remaining = remaining[m.end():] + else: + s = ''.join(parts) + raise SyntaxError('unterminated string: %s' % s) + parts.append(q) + result = ''.join(parts) + remaining = remaining[1:].lstrip() # skip past closing quote + return result, remaining + + def marker_expr(remaining): + if remaining and remaining[0] == '(': + result, remaining = marker(remaining[1:].lstrip()) + if remaining[0] != ')': + raise SyntaxError('unterminated parenthesis: %s' % remaining) + remaining = remaining[1:].lstrip() + else: + lhs, remaining = marker_var(remaining) + while remaining: + m = MARKER_OP.match(remaining) + if not m: + break + op = m.groups()[0] + remaining = remaining[m.end():] + rhs, remaining = marker_var(remaining) + lhs = {'op': op, 'lhs': lhs, 'rhs': rhs} + result = lhs + return result, remaining + + def marker_and(remaining): + lhs, remaining = marker_expr(remaining) + while remaining: + m = AND.match(remaining) + if not m: + break + remaining = remaining[m.end():] + rhs, remaining = marker_expr(remaining) + lhs = {'op': 'and', 'lhs': lhs, 'rhs': rhs} + return lhs, remaining + + def marker(remaining): + lhs, remaining = marker_and(remaining) + while remaining: + m = OR.match(remaining) + if not m: + break + remaining = remaining[m.end():] + rhs, remaining = marker_and(remaining) + lhs = {'op': 'or', 'lhs': lhs, 'rhs': rhs} + return lhs, remaining + + return marker(marker_string) + + +def parse_requirement(req): + """ + Parse a requirement passed in as a string. Return a Container + whose attributes contain the various parts of the requirement. + """ + remaining = req.strip() + if not remaining or remaining.startswith('#'): + return None + m = IDENTIFIER.match(remaining) + if not m: + raise SyntaxError('name expected: %s' % remaining) + distname = m.groups()[0] + remaining = remaining[m.end():] + extras = mark_expr = versions = uri = None + if remaining and remaining[0] == '[': + i = remaining.find(']', 1) + if i < 0: + raise SyntaxError('unterminated extra: %s' % remaining) + s = remaining[1:i] + remaining = remaining[i + 1:].lstrip() + extras = [] + while s: + m = IDENTIFIER.match(s) + if not m: + raise SyntaxError('malformed extra: %s' % s) + extras.append(m.groups()[0]) + s = s[m.end():] + if not s: + break + if s[0] != ',': + raise SyntaxError('comma expected in extras: %s' % s) + s = s[1:].lstrip() + if not extras: + extras = None + if remaining: + if remaining[0] == '@': + # it's a URI + remaining = remaining[1:].lstrip() + m = NON_SPACE.match(remaining) + if not m: + raise SyntaxError('invalid URI: %s' % remaining) + uri = m.groups()[0] + t = urlparse(uri) + # there are issues with Python and URL parsing, so this test + # is a bit crude. See bpo-20271, bpo-23505. Python doesn't + # always parse invalid URLs correctly - it should raise + # exceptions for malformed URLs + if not (t.scheme and t.netloc): + raise SyntaxError('Invalid URL: %s' % uri) + remaining = remaining[m.end():].lstrip() + else: + + def get_versions(ver_remaining): + """ + Return a list of operator, version tuples if any are + specified, else None. + """ + m = COMPARE_OP.match(ver_remaining) + versions = None + if m: + versions = [] + while True: + op = m.groups()[0] + ver_remaining = ver_remaining[m.end():] + m = VERSION_IDENTIFIER.match(ver_remaining) + if not m: + raise SyntaxError('invalid version: %s' % ver_remaining) + v = m.groups()[0] + versions.append((op, v)) + ver_remaining = ver_remaining[m.end():] + if not ver_remaining or ver_remaining[0] != ',': + break + ver_remaining = ver_remaining[1:].lstrip() + m = COMPARE_OP.match(ver_remaining) + if not m: + raise SyntaxError('invalid constraint: %s' % ver_remaining) + if not versions: + versions = None + return versions, ver_remaining + + if remaining[0] != '(': + versions, remaining = get_versions(remaining) + else: + i = remaining.find(')', 1) + if i < 0: + raise SyntaxError('unterminated parenthesis: %s' % remaining) + s = remaining[1:i] + remaining = remaining[i + 1:].lstrip() + # As a special diversion from PEP 508, allow a version number + # a.b.c in parentheses as a synonym for ~= a.b.c (because this + # is allowed in earlier PEPs) + if COMPARE_OP.match(s): + versions, _ = get_versions(s) + else: + m = VERSION_IDENTIFIER.match(s) + if not m: + raise SyntaxError('invalid constraint: %s' % s) + v = m.groups()[0] + s = s[m.end():].lstrip() + if s: + raise SyntaxError('invalid constraint: %s' % s) + versions = [('~=', v)] + + if remaining: + if remaining[0] != ';': + raise SyntaxError('invalid requirement: %s' % remaining) + remaining = remaining[1:].lstrip() + + mark_expr, remaining = parse_marker(remaining) + + if remaining and remaining[0] != '#': + raise SyntaxError('unexpected trailing data: %s' % remaining) + + if not versions: + rs = distname + else: + rs = '%s %s' % (distname, ', '.join(['%s %s' % con for con in versions])) + return Container(name=distname, extras=extras, constraints=versions, + marker=mark_expr, url=uri, requirement=rs) + + +def get_resources_dests(resources_root, rules): + """Find destinations for resources files""" + + def get_rel_path(root, path): + # normalizes and returns a lstripped-/-separated path + root = root.replace(os.path.sep, '/') + path = path.replace(os.path.sep, '/') + assert path.startswith(root) + return path[len(root):].lstrip('/') + + destinations = {} + for base, suffix, dest in rules: + prefix = os.path.join(resources_root, base) + for abs_base in iglob(prefix): + abs_glob = os.path.join(abs_base, suffix) + for abs_path in iglob(abs_glob): + resource_file = get_rel_path(resources_root, abs_path) + if dest is None: # remove the entry if it was here + destinations.pop(resource_file, None) + else: + rel_path = get_rel_path(abs_base, abs_path) + rel_dest = dest.replace(os.path.sep, '/').rstrip('/') + destinations[resource_file] = rel_dest + '/' + rel_path + return destinations + + +def in_venv(): + if hasattr(sys, 'real_prefix'): + # virtualenv venvs + result = True + else: + # PEP 405 venvs + result = sys.prefix != getattr(sys, 'base_prefix', sys.prefix) + return result + + +def get_executable(): +# The __PYVENV_LAUNCHER__ dance is apparently no longer needed, as +# changes to the stub launcher mean that sys.executable always points +# to the stub on OS X +# if sys.platform == 'darwin' and ('__PYVENV_LAUNCHER__' +# in os.environ): +# result = os.environ['__PYVENV_LAUNCHER__'] +# else: +# result = sys.executable +# return result + result = os.path.normcase(sys.executable) + if not isinstance(result, text_type): + result = fsdecode(result) + return result + + +def proceed(prompt, allowed_chars, error_prompt=None, default=None): + p = prompt + while True: + s = raw_input(p) + p = prompt + if not s and default: + s = default + if s: + c = s[0].lower() + if c in allowed_chars: + break + if error_prompt: + p = '%c: %s\n%s' % (c, error_prompt, prompt) + return c + + +def extract_by_key(d, keys): + if isinstance(keys, string_types): + keys = keys.split() + result = {} + for key in keys: + if key in d: + result[key] = d[key] + return result + +def read_exports(stream): + if sys.version_info[0] >= 3: + # needs to be a text stream + stream = codecs.getreader('utf-8')(stream) + # Try to load as JSON, falling back on legacy format + data = stream.read() + stream = StringIO(data) + try: + jdata = json.load(stream) + result = jdata['extensions']['python.exports']['exports'] + for group, entries in result.items(): + for k, v in entries.items(): + s = '%s = %s' % (k, v) + entry = get_export_entry(s) + assert entry is not None + entries[k] = entry + return result + except Exception: + stream.seek(0, 0) + + def read_stream(cp, stream): + if hasattr(cp, 'read_file'): + cp.read_file(stream) + else: + cp.readfp(stream) + + cp = configparser.ConfigParser() + try: + read_stream(cp, stream) + except configparser.MissingSectionHeaderError: + stream.close() + data = textwrap.dedent(data) + stream = StringIO(data) + read_stream(cp, stream) + + result = {} + for key in cp.sections(): + result[key] = entries = {} + for name, value in cp.items(key): + s = '%s = %s' % (name, value) + entry = get_export_entry(s) + assert entry is not None + #entry.dist = self + entries[name] = entry + return result + + +def write_exports(exports, stream): + if sys.version_info[0] >= 3: + # needs to be a text stream + stream = codecs.getwriter('utf-8')(stream) + cp = configparser.ConfigParser() + for k, v in exports.items(): + # TODO check k, v for valid values + cp.add_section(k) + for entry in v.values(): + if entry.suffix is None: + s = entry.prefix + else: + s = '%s:%s' % (entry.prefix, entry.suffix) + if entry.flags: + s = '%s [%s]' % (s, ', '.join(entry.flags)) + cp.set(k, entry.name, s) + cp.write(stream) + + +@contextlib.contextmanager +def tempdir(): + td = tempfile.mkdtemp() + try: + yield td + finally: + shutil.rmtree(td) + +@contextlib.contextmanager +def chdir(d): + cwd = os.getcwd() + try: + os.chdir(d) + yield + finally: + os.chdir(cwd) + + +@contextlib.contextmanager +def socket_timeout(seconds=15): + cto = socket.getdefaulttimeout() + try: + socket.setdefaulttimeout(seconds) + yield + finally: + socket.setdefaulttimeout(cto) + + +class cached_property(object): + def __init__(self, func): + self.func = func + #for attr in ('__name__', '__module__', '__doc__'): + # setattr(self, attr, getattr(func, attr, None)) + + def __get__(self, obj, cls=None): + if obj is None: + return self + value = self.func(obj) + object.__setattr__(obj, self.func.__name__, value) + #obj.__dict__[self.func.__name__] = value = self.func(obj) + return value + +def convert_path(pathname): + """Return 'pathname' as a name that will work on the native filesystem. + + The path is split on '/' and put back together again using the current + directory separator. Needed because filenames in the setup script are + always supplied in Unix style, and have to be converted to the local + convention before we can actually use them in the filesystem. Raises + ValueError on non-Unix-ish systems if 'pathname' either starts or + ends with a slash. + """ + if os.sep == '/': + return pathname + if not pathname: + return pathname + if pathname[0] == '/': + raise ValueError("path '%s' cannot be absolute" % pathname) + if pathname[-1] == '/': + raise ValueError("path '%s' cannot end with '/'" % pathname) + + paths = pathname.split('/') + while os.curdir in paths: + paths.remove(os.curdir) + if not paths: + return os.curdir + return os.path.join(*paths) + + +class FileOperator(object): + def __init__(self, dry_run=False): + self.dry_run = dry_run + self.ensured = set() + self._init_record() + + def _init_record(self): + self.record = False + self.files_written = set() + self.dirs_created = set() + + def record_as_written(self, path): + if self.record: + self.files_written.add(path) + + def newer(self, source, target): + """Tell if the target is newer than the source. + + Returns true if 'source' exists and is more recently modified than + 'target', or if 'source' exists and 'target' doesn't. + + Returns false if both exist and 'target' is the same age or younger + than 'source'. Raise PackagingFileError if 'source' does not exist. + + Note that this test is not very accurate: files created in the same + second will have the same "age". + """ + if not os.path.exists(source): + raise DistlibException("file '%r' does not exist" % + os.path.abspath(source)) + if not os.path.exists(target): + return True + + return os.stat(source).st_mtime > os.stat(target).st_mtime + + def copy_file(self, infile, outfile, check=True): + """Copy a file respecting dry-run and force flags. + """ + self.ensure_dir(os.path.dirname(outfile)) + logger.info('Copying %s to %s', infile, outfile) + if not self.dry_run: + msg = None + if check: + if os.path.islink(outfile): + msg = '%s is a symlink' % outfile + elif os.path.exists(outfile) and not os.path.isfile(outfile): + msg = '%s is a non-regular file' % outfile + if msg: + raise ValueError(msg + ' which would be overwritten') + shutil.copyfile(infile, outfile) + self.record_as_written(outfile) + + def copy_stream(self, instream, outfile, encoding=None): + assert not os.path.isdir(outfile) + self.ensure_dir(os.path.dirname(outfile)) + logger.info('Copying stream %s to %s', instream, outfile) + if not self.dry_run: + if encoding is None: + outstream = open(outfile, 'wb') + else: + outstream = codecs.open(outfile, 'w', encoding=encoding) + try: + shutil.copyfileobj(instream, outstream) + finally: + outstream.close() + self.record_as_written(outfile) + + def write_binary_file(self, path, data): + self.ensure_dir(os.path.dirname(path)) + if not self.dry_run: + if os.path.exists(path): + os.remove(path) + with open(path, 'wb') as f: + f.write(data) + self.record_as_written(path) + + def write_text_file(self, path, data, encoding): + self.write_binary_file(path, data.encode(encoding)) + + def set_mode(self, bits, mask, files): + if os.name == 'posix' or (os.name == 'java' and os._name == 'posix'): + # Set the executable bits (owner, group, and world) on + # all the files specified. + for f in files: + if self.dry_run: + logger.info("changing mode of %s", f) + else: + mode = (os.stat(f).st_mode | bits) & mask + logger.info("changing mode of %s to %o", f, mode) + os.chmod(f, mode) + + set_executable_mode = lambda s, f: s.set_mode(0o555, 0o7777, f) + + def ensure_dir(self, path): + path = os.path.abspath(path) + if path not in self.ensured and not os.path.exists(path): + self.ensured.add(path) + d, f = os.path.split(path) + self.ensure_dir(d) + logger.info('Creating %s' % path) + if not self.dry_run: + os.mkdir(path) + if self.record: + self.dirs_created.add(path) + + def byte_compile(self, path, optimize=False, force=False, prefix=None, hashed_invalidation=False): + dpath = cache_from_source(path, not optimize) + logger.info('Byte-compiling %s to %s', path, dpath) + if not self.dry_run: + if force or self.newer(path, dpath): + if not prefix: + diagpath = None + else: + assert path.startswith(prefix) + diagpath = path[len(prefix):] + compile_kwargs = {} + if hashed_invalidation and hasattr(py_compile, 'PycInvalidationMode'): + compile_kwargs['invalidation_mode'] = py_compile.PycInvalidationMode.CHECKED_HASH + py_compile.compile(path, dpath, diagpath, True, **compile_kwargs) # raise error + self.record_as_written(dpath) + return dpath + + def ensure_removed(self, path): + if os.path.exists(path): + if os.path.isdir(path) and not os.path.islink(path): + logger.debug('Removing directory tree at %s', path) + if not self.dry_run: + shutil.rmtree(path) + if self.record: + if path in self.dirs_created: + self.dirs_created.remove(path) + else: + if os.path.islink(path): + s = 'link' + else: + s = 'file' + logger.debug('Removing %s %s', s, path) + if not self.dry_run: + os.remove(path) + if self.record: + if path in self.files_written: + self.files_written.remove(path) + + def is_writable(self, path): + result = False + while not result: + if os.path.exists(path): + result = os.access(path, os.W_OK) + break + parent = os.path.dirname(path) + if parent == path: + break + path = parent + return result + + def commit(self): + """ + Commit recorded changes, turn off recording, return + changes. + """ + assert self.record + result = self.files_written, self.dirs_created + self._init_record() + return result + + def rollback(self): + if not self.dry_run: + for f in list(self.files_written): + if os.path.exists(f): + os.remove(f) + # dirs should all be empty now, except perhaps for + # __pycache__ subdirs + # reverse so that subdirs appear before their parents + dirs = sorted(self.dirs_created, reverse=True) + for d in dirs: + flist = os.listdir(d) + if flist: + assert flist == ['__pycache__'] + sd = os.path.join(d, flist[0]) + os.rmdir(sd) + os.rmdir(d) # should fail if non-empty + self._init_record() + +def resolve(module_name, dotted_path): + if module_name in sys.modules: + mod = sys.modules[module_name] + else: + mod = __import__(module_name) + if dotted_path is None: + result = mod + else: + parts = dotted_path.split('.') + result = getattr(mod, parts.pop(0)) + for p in parts: + result = getattr(result, p) + return result + + +class ExportEntry(object): + def __init__(self, name, prefix, suffix, flags): + self.name = name + self.prefix = prefix + self.suffix = suffix + self.flags = flags + + @cached_property + def value(self): + return resolve(self.prefix, self.suffix) + + def __repr__(self): # pragma: no cover + return '<ExportEntry %s = %s:%s %s>' % (self.name, self.prefix, + self.suffix, self.flags) + + def __eq__(self, other): + if not isinstance(other, ExportEntry): + result = False + else: + result = (self.name == other.name and + self.prefix == other.prefix and + self.suffix == other.suffix and + self.flags == other.flags) + return result + + __hash__ = object.__hash__ + + +ENTRY_RE = re.compile(r'''(?P<name>(\w|[-.+])+) + \s*=\s*(?P<callable>(\w+)([:\.]\w+)*) + \s*(\[\s*(?P<flags>\w+(=\w+)?(,\s*\w+(=\w+)?)*)\s*\])? + ''', re.VERBOSE) + +def get_export_entry(specification): + m = ENTRY_RE.search(specification) + if not m: + result = None + if '[' in specification or ']' in specification: + raise DistlibException("Invalid specification " + "'%s'" % specification) + else: + d = m.groupdict() + name = d['name'] + path = d['callable'] + colons = path.count(':') + if colons == 0: + prefix, suffix = path, None + else: + if colons != 1: + raise DistlibException("Invalid specification " + "'%s'" % specification) + prefix, suffix = path.split(':') + flags = d['flags'] + if flags is None: + if '[' in specification or ']' in specification: + raise DistlibException("Invalid specification " + "'%s'" % specification) + flags = [] + else: + flags = [f.strip() for f in flags.split(',')] + result = ExportEntry(name, prefix, suffix, flags) + return result + + +def get_cache_base(suffix=None): + """ + Return the default base location for distlib caches. If the directory does + not exist, it is created. Use the suffix provided for the base directory, + and default to '.distlib' if it isn't provided. + + On Windows, if LOCALAPPDATA is defined in the environment, then it is + assumed to be a directory, and will be the parent directory of the result. + On POSIX, and on Windows if LOCALAPPDATA is not defined, the user's home + directory - using os.expanduser('~') - will be the parent directory of + the result. + + The result is just the directory '.distlib' in the parent directory as + determined above, or with the name specified with ``suffix``. + """ + if suffix is None: + suffix = '.distlib' + if os.name == 'nt' and 'LOCALAPPDATA' in os.environ: + result = os.path.expandvars('$localappdata') + else: + # Assume posix, or old Windows + result = os.path.expanduser('~') + # we use 'isdir' instead of 'exists', because we want to + # fail if there's a file with that name + if os.path.isdir(result): + usable = os.access(result, os.W_OK) + if not usable: + logger.warning('Directory exists but is not writable: %s', result) + else: + try: + os.makedirs(result) + usable = True + except OSError: + logger.warning('Unable to create %s', result, exc_info=True) + usable = False + if not usable: + result = tempfile.mkdtemp() + logger.warning('Default location unusable, using %s', result) + return os.path.join(result, suffix) + + +def path_to_cache_dir(path): + """ + Convert an absolute path to a directory name for use in a cache. + + The algorithm used is: + + #. On Windows, any ``':'`` in the drive is replaced with ``'---'``. + #. Any occurrence of ``os.sep`` is replaced with ``'--'``. + #. ``'.cache'`` is appended. + """ + d, p = os.path.splitdrive(os.path.abspath(path)) + if d: + d = d.replace(':', '---') + p = p.replace(os.sep, '--') + return d + p + '.cache' + + +def ensure_slash(s): + if not s.endswith('/'): + return s + '/' + return s + + +def parse_credentials(netloc): + username = password = None + if '@' in netloc: + prefix, netloc = netloc.rsplit('@', 1) + if ':' not in prefix: + username = prefix + else: + username, password = prefix.split(':', 1) + if username: + username = unquote(username) + if password: + password = unquote(password) + return username, password, netloc + + +def get_process_umask(): + result = os.umask(0o22) + os.umask(result) + return result + +def is_string_sequence(seq): + result = True + i = None + for i, s in enumerate(seq): + if not isinstance(s, string_types): + result = False + break + assert i is not None + return result + +PROJECT_NAME_AND_VERSION = re.compile('([a-z0-9_]+([.-][a-z_][a-z0-9_]*)*)-' + '([a-z0-9_.+-]+)', re.I) +PYTHON_VERSION = re.compile(r'-py(\d\.?\d?)') + + +def split_filename(filename, project_name=None): + """ + Extract name, version, python version from a filename (no extension) + + Return name, version, pyver or None + """ + result = None + pyver = None + filename = unquote(filename).replace(' ', '-') + m = PYTHON_VERSION.search(filename) + if m: + pyver = m.group(1) + filename = filename[:m.start()] + if project_name and len(filename) > len(project_name) + 1: + m = re.match(re.escape(project_name) + r'\b', filename) + if m: + n = m.end() + result = filename[:n], filename[n + 1:], pyver + if result is None: + m = PROJECT_NAME_AND_VERSION.match(filename) + if m: + result = m.group(1), m.group(3), pyver + return result + +# Allow spaces in name because of legacy dists like "Twisted Core" +NAME_VERSION_RE = re.compile(r'(?P<name>[\w .-]+)\s*' + r'\(\s*(?P<ver>[^\s)]+)\)$') + +def parse_name_and_version(p): + """ + A utility method used to get name and version from a string. + + From e.g. a Provides-Dist value. + + :param p: A value in a form 'foo (1.0)' + :return: The name and version as a tuple. + """ + m = NAME_VERSION_RE.match(p) + if not m: + raise DistlibException('Ill-formed name/version string: \'%s\'' % p) + d = m.groupdict() + return d['name'].strip().lower(), d['ver'] + +def get_extras(requested, available): + result = set() + requested = set(requested or []) + available = set(available or []) + if '*' in requested: + requested.remove('*') + result |= available + for r in requested: + if r == '-': + result.add(r) + elif r.startswith('-'): + unwanted = r[1:] + if unwanted not in available: + logger.warning('undeclared extra: %s' % unwanted) + if unwanted in result: + result.remove(unwanted) + else: + if r not in available: + logger.warning('undeclared extra: %s' % r) + result.add(r) + return result +# +# Extended metadata functionality +# + +def _get_external_data(url): + result = {} + try: + # urlopen might fail if it runs into redirections, + # because of Python issue #13696. Fixed in locators + # using a custom redirect handler. + resp = urlopen(url) + headers = resp.info() + ct = headers.get('Content-Type') + if not ct.startswith('application/json'): + logger.debug('Unexpected response for JSON request: %s', ct) + else: + reader = codecs.getreader('utf-8')(resp) + #data = reader.read().decode('utf-8') + #result = json.loads(data) + result = json.load(reader) + except Exception as e: + logger.exception('Failed to get external data for %s: %s', url, e) + return result + +_external_data_base_url = 'https://www.red-dove.com/pypi/projects/' + +def get_project_data(name): + url = '%s/%s/project.json' % (name[0].upper(), name) + url = urljoin(_external_data_base_url, url) + result = _get_external_data(url) + return result + +def get_package_data(name, version): + url = '%s/%s/package-%s.json' % (name[0].upper(), name, version) + url = urljoin(_external_data_base_url, url) + return _get_external_data(url) + + +class Cache(object): + """ + A class implementing a cache for resources that need to live in the file system + e.g. shared libraries. This class was moved from resources to here because it + could be used by other modules, e.g. the wheel module. + """ + + def __init__(self, base): + """ + Initialise an instance. + + :param base: The base directory where the cache should be located. + """ + # we use 'isdir' instead of 'exists', because we want to + # fail if there's a file with that name + if not os.path.isdir(base): # pragma: no cover + os.makedirs(base) + if (os.stat(base).st_mode & 0o77) != 0: + logger.warning('Directory \'%s\' is not private', base) + self.base = os.path.abspath(os.path.normpath(base)) + + def prefix_to_dir(self, prefix): + """ + Converts a resource prefix to a directory name in the cache. + """ + return path_to_cache_dir(prefix) + + def clear(self): + """ + Clear the cache. + """ + not_removed = [] + for fn in os.listdir(self.base): + fn = os.path.join(self.base, fn) + try: + if os.path.islink(fn) or os.path.isfile(fn): + os.remove(fn) + elif os.path.isdir(fn): + shutil.rmtree(fn) + except Exception: + not_removed.append(fn) + return not_removed + + +class EventMixin(object): + """ + A very simple publish/subscribe system. + """ + def __init__(self): + self._subscribers = {} + + def add(self, event, subscriber, append=True): + """ + Add a subscriber for an event. + + :param event: The name of an event. + :param subscriber: The subscriber to be added (and called when the + event is published). + :param append: Whether to append or prepend the subscriber to an + existing subscriber list for the event. + """ + subs = self._subscribers + if event not in subs: + subs[event] = deque([subscriber]) + else: + sq = subs[event] + if append: + sq.append(subscriber) + else: + sq.appendleft(subscriber) + + def remove(self, event, subscriber): + """ + Remove a subscriber for an event. + + :param event: The name of an event. + :param subscriber: The subscriber to be removed. + """ + subs = self._subscribers + if event not in subs: + raise ValueError('No subscribers: %r' % event) + subs[event].remove(subscriber) + + def get_subscribers(self, event): + """ + Return an iterator for the subscribers for an event. + :param event: The event to return subscribers for. + """ + return iter(self._subscribers.get(event, ())) + + def publish(self, event, *args, **kwargs): + """ + Publish a event and return a list of values returned by its + subscribers. + + :param event: The event to publish. + :param args: The positional arguments to pass to the event's + subscribers. + :param kwargs: The keyword arguments to pass to the event's + subscribers. + """ + result = [] + for subscriber in self.get_subscribers(event): + try: + value = subscriber(event, *args, **kwargs) + except Exception: + logger.exception('Exception during event publication') + value = None + result.append(value) + logger.debug('publish %s: args = %s, kwargs = %s, result = %s', + event, args, kwargs, result) + return result + +# +# Simple sequencing +# +class Sequencer(object): + def __init__(self): + self._preds = {} + self._succs = {} + self._nodes = set() # nodes with no preds/succs + + def add_node(self, node): + self._nodes.add(node) + + def remove_node(self, node, edges=False): + if node in self._nodes: + self._nodes.remove(node) + if edges: + for p in set(self._preds.get(node, ())): + self.remove(p, node) + for s in set(self._succs.get(node, ())): + self.remove(node, s) + # Remove empties + for k, v in list(self._preds.items()): + if not v: + del self._preds[k] + for k, v in list(self._succs.items()): + if not v: + del self._succs[k] + + def add(self, pred, succ): + assert pred != succ + self._preds.setdefault(succ, set()).add(pred) + self._succs.setdefault(pred, set()).add(succ) + + def remove(self, pred, succ): + assert pred != succ + try: + preds = self._preds[succ] + succs = self._succs[pred] + except KeyError: # pragma: no cover + raise ValueError('%r not a successor of anything' % succ) + try: + preds.remove(pred) + succs.remove(succ) + except KeyError: # pragma: no cover + raise ValueError('%r not a successor of %r' % (succ, pred)) + + def is_step(self, step): + return (step in self._preds or step in self._succs or + step in self._nodes) + + def get_steps(self, final): + if not self.is_step(final): + raise ValueError('Unknown: %r' % final) + result = [] + todo = [] + seen = set() + todo.append(final) + while todo: + step = todo.pop(0) + if step in seen: + # if a step was already seen, + # move it to the end (so it will appear earlier + # when reversed on return) ... but not for the + # final step, as that would be confusing for + # users + if step != final: + result.remove(step) + result.append(step) + else: + seen.add(step) + result.append(step) + preds = self._preds.get(step, ()) + todo.extend(preds) + return reversed(result) + + @property + def strong_connections(self): + #http://en.wikipedia.org/wiki/Tarjan%27s_strongly_connected_components_algorithm + index_counter = [0] + stack = [] + lowlinks = {} + index = {} + result = [] + + graph = self._succs + + def strongconnect(node): + # set the depth index for this node to the smallest unused index + index[node] = index_counter[0] + lowlinks[node] = index_counter[0] + index_counter[0] += 1 + stack.append(node) + + # Consider successors + try: + successors = graph[node] + except Exception: + successors = [] + for successor in successors: + if successor not in lowlinks: + # Successor has not yet been visited + strongconnect(successor) + lowlinks[node] = min(lowlinks[node],lowlinks[successor]) + elif successor in stack: + # the successor is in the stack and hence in the current + # strongly connected component (SCC) + lowlinks[node] = min(lowlinks[node],index[successor]) + + # If `node` is a root node, pop the stack and generate an SCC + if lowlinks[node] == index[node]: + connected_component = [] + + while True: + successor = stack.pop() + connected_component.append(successor) + if successor == node: break + component = tuple(connected_component) + # storing the result + result.append(component) + + for node in graph: + if node not in lowlinks: + strongconnect(node) + + return result + + @property + def dot(self): + result = ['digraph G {'] + for succ in self._preds: + preds = self._preds[succ] + for pred in preds: + result.append(' %s -> %s;' % (pred, succ)) + for node in self._nodes: + result.append(' %s;' % node) + result.append('}') + return '\n'.join(result) + +# +# Unarchiving functionality for zip, tar, tgz, tbz, whl +# + +ARCHIVE_EXTENSIONS = ('.tar.gz', '.tar.bz2', '.tar', '.zip', + '.tgz', '.tbz', '.whl') + +def unarchive(archive_filename, dest_dir, format=None, check=True): + + def check_path(path): + if not isinstance(path, text_type): + path = path.decode('utf-8') + p = os.path.abspath(os.path.join(dest_dir, path)) + if not p.startswith(dest_dir) or p[plen] != os.sep: + raise ValueError('path outside destination: %r' % p) + + dest_dir = os.path.abspath(dest_dir) + plen = len(dest_dir) + archive = None + if format is None: + if archive_filename.endswith(('.zip', '.whl')): + format = 'zip' + elif archive_filename.endswith(('.tar.gz', '.tgz')): + format = 'tgz' + mode = 'r:gz' + elif archive_filename.endswith(('.tar.bz2', '.tbz')): + format = 'tbz' + mode = 'r:bz2' + elif archive_filename.endswith('.tar'): + format = 'tar' + mode = 'r' + else: # pragma: no cover + raise ValueError('Unknown format for %r' % archive_filename) + try: + if format == 'zip': + archive = ZipFile(archive_filename, 'r') + if check: + names = archive.namelist() + for name in names: + check_path(name) + else: + archive = tarfile.open(archive_filename, mode) + if check: + names = archive.getnames() + for name in names: + check_path(name) + if format != 'zip' and sys.version_info[0] < 3: + # See Python issue 17153. If the dest path contains Unicode, + # tarfile extraction fails on Python 2.x if a member path name + # contains non-ASCII characters - it leads to an implicit + # bytes -> unicode conversion using ASCII to decode. + for tarinfo in archive.getmembers(): + if not isinstance(tarinfo.name, text_type): + tarinfo.name = tarinfo.name.decode('utf-8') + archive.extractall(dest_dir) + + finally: + if archive: + archive.close() + + +def zip_dir(directory): + """zip a directory tree into a BytesIO object""" + result = io.BytesIO() + dlen = len(directory) + with ZipFile(result, "w") as zf: + for root, dirs, files in os.walk(directory): + for name in files: + full = os.path.join(root, name) + rel = root[dlen:] + dest = os.path.join(rel, name) + zf.write(full, dest) + return result + +# +# Simple progress bar +# + +UNITS = ('', 'K', 'M', 'G','T','P') + + +class Progress(object): + unknown = 'UNKNOWN' + + def __init__(self, minval=0, maxval=100): + assert maxval is None or maxval >= minval + self.min = self.cur = minval + self.max = maxval + self.started = None + self.elapsed = 0 + self.done = False + + def update(self, curval): + assert self.min <= curval + assert self.max is None or curval <= self.max + self.cur = curval + now = time.time() + if self.started is None: + self.started = now + else: + self.elapsed = now - self.started + + def increment(self, incr): + assert incr >= 0 + self.update(self.cur + incr) + + def start(self): + self.update(self.min) + return self + + def stop(self): + if self.max is not None: + self.update(self.max) + self.done = True + + @property + def maximum(self): + return self.unknown if self.max is None else self.max + + @property + def percentage(self): + if self.done: + result = '100 %' + elif self.max is None: + result = ' ?? %' + else: + v = 100.0 * (self.cur - self.min) / (self.max - self.min) + result = '%3d %%' % v + return result + + def format_duration(self, duration): + if (duration <= 0) and self.max is None or self.cur == self.min: + result = '??:??:??' + #elif duration < 1: + # result = '--:--:--' + else: + result = time.strftime('%H:%M:%S', time.gmtime(duration)) + return result + + @property + def ETA(self): + if self.done: + prefix = 'Done' + t = self.elapsed + #import pdb; pdb.set_trace() + else: + prefix = 'ETA ' + if self.max is None: + t = -1 + elif self.elapsed == 0 or (self.cur == self.min): + t = 0 + else: + #import pdb; pdb.set_trace() + t = float(self.max - self.min) + t /= self.cur - self.min + t = (t - 1) * self.elapsed + return '%s: %s' % (prefix, self.format_duration(t)) + + @property + def speed(self): + if self.elapsed == 0: + result = 0.0 + else: + result = (self.cur - self.min) / self.elapsed + for unit in UNITS: + if result < 1000: + break + result /= 1000.0 + return '%d %sB/s' % (result, unit) + +# +# Glob functionality +# + +RICH_GLOB = re.compile(r'\{([^}]*)\}') +_CHECK_RECURSIVE_GLOB = re.compile(r'[^/\\,{]\*\*|\*\*[^/\\,}]') +_CHECK_MISMATCH_SET = re.compile(r'^[^{]*\}|\{[^}]*$') + + +def iglob(path_glob): + """Extended globbing function that supports ** and {opt1,opt2,opt3}.""" + if _CHECK_RECURSIVE_GLOB.search(path_glob): + msg = """invalid glob %r: recursive glob "**" must be used alone""" + raise ValueError(msg % path_glob) + if _CHECK_MISMATCH_SET.search(path_glob): + msg = """invalid glob %r: mismatching set marker '{' or '}'""" + raise ValueError(msg % path_glob) + return _iglob(path_glob) + + +def _iglob(path_glob): + rich_path_glob = RICH_GLOB.split(path_glob, 1) + if len(rich_path_glob) > 1: + assert len(rich_path_glob) == 3, rich_path_glob + prefix, set, suffix = rich_path_glob + for item in set.split(','): + for path in _iglob(''.join((prefix, item, suffix))): + yield path + else: + if '**' not in path_glob: + for item in std_iglob(path_glob): + yield item + else: + prefix, radical = path_glob.split('**', 1) + if prefix == '': + prefix = '.' + if radical == '': + radical = '*' + else: + # we support both + radical = radical.lstrip('/') + radical = radical.lstrip('\\') + for path, dir, files in os.walk(prefix): + path = os.path.normpath(path) + for fn in _iglob(os.path.join(path, radical)): + yield fn + +if ssl: + from .compat import (HTTPSHandler as BaseHTTPSHandler, match_hostname, + CertificateError) + + +# +# HTTPSConnection which verifies certificates/matches domains +# + + class HTTPSConnection(httplib.HTTPSConnection): + ca_certs = None # set this to the path to the certs file (.pem) + check_domain = True # only used if ca_certs is not None + + # noinspection PyPropertyAccess + def connect(self): + sock = socket.create_connection((self.host, self.port), self.timeout) + if getattr(self, '_tunnel_host', False): + self.sock = sock + self._tunnel() + + if not hasattr(ssl, 'SSLContext'): + # For 2.x + if self.ca_certs: + cert_reqs = ssl.CERT_REQUIRED + else: + cert_reqs = ssl.CERT_NONE + self.sock = ssl.wrap_socket(sock, self.key_file, self.cert_file, + cert_reqs=cert_reqs, + ssl_version=ssl.PROTOCOL_SSLv23, + ca_certs=self.ca_certs) + else: # pragma: no cover + context = ssl.SSLContext(ssl.PROTOCOL_SSLv23) + context.options |= ssl.OP_NO_SSLv2 + if self.cert_file: + context.load_cert_chain(self.cert_file, self.key_file) + kwargs = {} + if self.ca_certs: + context.verify_mode = ssl.CERT_REQUIRED + context.load_verify_locations(cafile=self.ca_certs) + if getattr(ssl, 'HAS_SNI', False): + kwargs['server_hostname'] = self.host + self.sock = context.wrap_socket(sock, **kwargs) + if self.ca_certs and self.check_domain: + try: + match_hostname(self.sock.getpeercert(), self.host) + logger.debug('Host verified: %s', self.host) + except CertificateError: # pragma: no cover + self.sock.shutdown(socket.SHUT_RDWR) + self.sock.close() + raise + + class HTTPSHandler(BaseHTTPSHandler): + def __init__(self, ca_certs, check_domain=True): + BaseHTTPSHandler.__init__(self) + self.ca_certs = ca_certs + self.check_domain = check_domain + + def _conn_maker(self, *args, **kwargs): + """ + This is called to create a connection instance. Normally you'd + pass a connection class to do_open, but it doesn't actually check for + a class, and just expects a callable. As long as we behave just as a + constructor would have, we should be OK. If it ever changes so that + we *must* pass a class, we'll create an UnsafeHTTPSConnection class + which just sets check_domain to False in the class definition, and + choose which one to pass to do_open. + """ + result = HTTPSConnection(*args, **kwargs) + if self.ca_certs: + result.ca_certs = self.ca_certs + result.check_domain = self.check_domain + return result + + def https_open(self, req): + try: + return self.do_open(self._conn_maker, req) + except URLError as e: + if 'certificate verify failed' in str(e.reason): + raise CertificateError('Unable to verify server certificate ' + 'for %s' % req.host) + else: + raise + + # + # To prevent against mixing HTTP traffic with HTTPS (examples: A Man-In-The- + # Middle proxy using HTTP listens on port 443, or an index mistakenly serves + # HTML containing a http://xyz link when it should be https://xyz), + # you can use the following handler class, which does not allow HTTP traffic. + # + # It works by inheriting from HTTPHandler - so build_opener won't add a + # handler for HTTP itself. + # + class HTTPSOnlyHandler(HTTPSHandler, HTTPHandler): + def http_open(self, req): + raise URLError('Unexpected HTTP request on what should be a secure ' + 'connection: %s' % req) + +# +# XML-RPC with timeouts +# + +_ver_info = sys.version_info[:2] + +if _ver_info == (2, 6): + class HTTP(httplib.HTTP): + def __init__(self, host='', port=None, **kwargs): + if port == 0: # 0 means use port 0, not the default port + port = None + self._setup(self._connection_class(host, port, **kwargs)) + + + if ssl: + class HTTPS(httplib.HTTPS): + def __init__(self, host='', port=None, **kwargs): + if port == 0: # 0 means use port 0, not the default port + port = None + self._setup(self._connection_class(host, port, **kwargs)) + + +class Transport(xmlrpclib.Transport): + def __init__(self, timeout, use_datetime=0): + self.timeout = timeout + xmlrpclib.Transport.__init__(self, use_datetime) + + def make_connection(self, host): + h, eh, x509 = self.get_host_info(host) + if _ver_info == (2, 6): + result = HTTP(h, timeout=self.timeout) + else: + if not self._connection or host != self._connection[0]: + self._extra_headers = eh + self._connection = host, httplib.HTTPConnection(h) + result = self._connection[1] + return result + +if ssl: + class SafeTransport(xmlrpclib.SafeTransport): + def __init__(self, timeout, use_datetime=0): + self.timeout = timeout + xmlrpclib.SafeTransport.__init__(self, use_datetime) + + def make_connection(self, host): + h, eh, kwargs = self.get_host_info(host) + if not kwargs: + kwargs = {} + kwargs['timeout'] = self.timeout + if _ver_info == (2, 6): + result = HTTPS(host, None, **kwargs) + else: + if not self._connection or host != self._connection[0]: + self._extra_headers = eh + self._connection = host, httplib.HTTPSConnection(h, None, + **kwargs) + result = self._connection[1] + return result + + +class ServerProxy(xmlrpclib.ServerProxy): + def __init__(self, uri, **kwargs): + self.timeout = timeout = kwargs.pop('timeout', None) + # The above classes only come into play if a timeout + # is specified + if timeout is not None: + scheme, _ = splittype(uri) + use_datetime = kwargs.get('use_datetime', 0) + if scheme == 'https': + tcls = SafeTransport + else: + tcls = Transport + kwargs['transport'] = t = tcls(timeout, use_datetime=use_datetime) + self.transport = t + xmlrpclib.ServerProxy.__init__(self, uri, **kwargs) + +# +# CSV functionality. This is provided because on 2.x, the csv module can't +# handle Unicode. However, we need to deal with Unicode in e.g. RECORD files. +# + +def _csv_open(fn, mode, **kwargs): + if sys.version_info[0] < 3: + mode += 'b' + else: + kwargs['newline'] = '' + # Python 3 determines encoding from locale. Force 'utf-8' + # file encoding to match other forced utf-8 encoding + kwargs['encoding'] = 'utf-8' + return open(fn, mode, **kwargs) + + +class CSVBase(object): + defaults = { + 'delimiter': str(','), # The strs are used because we need native + 'quotechar': str('"'), # str in the csv API (2.x won't take + 'lineterminator': str('\n') # Unicode) + } + + def __enter__(self): + return self + + def __exit__(self, *exc_info): + self.stream.close() + + +class CSVReader(CSVBase): + def __init__(self, **kwargs): + if 'stream' in kwargs: + stream = kwargs['stream'] + if sys.version_info[0] >= 3: + # needs to be a text stream + stream = codecs.getreader('utf-8')(stream) + self.stream = stream + else: + self.stream = _csv_open(kwargs['path'], 'r') + self.reader = csv.reader(self.stream, **self.defaults) + + def __iter__(self): + return self + + def next(self): + result = next(self.reader) + if sys.version_info[0] < 3: + for i, item in enumerate(result): + if not isinstance(item, text_type): + result[i] = item.decode('utf-8') + return result + + __next__ = next + +class CSVWriter(CSVBase): + def __init__(self, fn, **kwargs): + self.stream = _csv_open(fn, 'w') + self.writer = csv.writer(self.stream, **self.defaults) + + def writerow(self, row): + if sys.version_info[0] < 3: + r = [] + for item in row: + if isinstance(item, text_type): + item = item.encode('utf-8') + r.append(item) + row = r + self.writer.writerow(row) + +# +# Configurator functionality +# + +class Configurator(BaseConfigurator): + + value_converters = dict(BaseConfigurator.value_converters) + value_converters['inc'] = 'inc_convert' + + def __init__(self, config, base=None): + super(Configurator, self).__init__(config) + self.base = base or os.getcwd() + + def configure_custom(self, config): + def convert(o): + if isinstance(o, (list, tuple)): + result = type(o)([convert(i) for i in o]) + elif isinstance(o, dict): + if '()' in o: + result = self.configure_custom(o) + else: + result = {} + for k in o: + result[k] = convert(o[k]) + else: + result = self.convert(o) + return result + + c = config.pop('()') + if not callable(c): + c = self.resolve(c) + props = config.pop('.', None) + # Check for valid identifiers + args = config.pop('[]', ()) + if args: + args = tuple([convert(o) for o in args]) + items = [(k, convert(config[k])) for k in config if valid_ident(k)] + kwargs = dict(items) + result = c(*args, **kwargs) + if props: + for n, v in props.items(): + setattr(result, n, convert(v)) + return result + + def __getitem__(self, key): + result = self.config[key] + if isinstance(result, dict) and '()' in result: + self.config[key] = result = self.configure_custom(result) + return result + + def inc_convert(self, value): + """Default converter for the inc:// protocol.""" + if not os.path.isabs(value): + value = os.path.join(self.base, value) + with codecs.open(value, 'r', encoding='utf-8') as f: + result = json.load(f) + return result + + +class SubprocessMixin(object): + """ + Mixin for running subprocesses and capturing their output + """ + def __init__(self, verbose=False, progress=None): + self.verbose = verbose + self.progress = progress + + def reader(self, stream, context): + """ + Read lines from a subprocess' output stream and either pass to a progress + callable (if specified) or write progress information to sys.stderr. + """ + progress = self.progress + verbose = self.verbose + while True: + s = stream.readline() + if not s: + break + if progress is not None: + progress(s, context) + else: + if not verbose: + sys.stderr.write('.') + else: + sys.stderr.write(s.decode('utf-8')) + sys.stderr.flush() + stream.close() + + def run_command(self, cmd, **kwargs): + p = subprocess.Popen(cmd, stdout=subprocess.PIPE, + stderr=subprocess.PIPE, **kwargs) + t1 = threading.Thread(target=self.reader, args=(p.stdout, 'stdout')) + t1.start() + t2 = threading.Thread(target=self.reader, args=(p.stderr, 'stderr')) + t2.start() + p.wait() + t1.join() + t2.join() + if self.progress is not None: + self.progress('done.', 'main') + elif self.verbose: + sys.stderr.write('done.\n') + return p + + +def normalize_name(name): + """Normalize a python package name a la PEP 503""" + # https://www.python.org/dev/peps/pep-0503/#normalized-names + return re.sub('[-_.]+', '-', name).lower() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/version.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/version.py new file mode 100644 index 0000000..3eebe18 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/version.py @@ -0,0 +1,736 @@ +# -*- coding: utf-8 -*- +# +# Copyright (C) 2012-2017 The Python Software Foundation. +# See LICENSE.txt and CONTRIBUTORS.txt. +# +""" +Implementation of a flexible versioning scheme providing support for PEP-440, +setuptools-compatible and semantic versioning. +""" + +import logging +import re + +from .compat import string_types +from .util import parse_requirement + +__all__ = ['NormalizedVersion', 'NormalizedMatcher', + 'LegacyVersion', 'LegacyMatcher', + 'SemanticVersion', 'SemanticMatcher', + 'UnsupportedVersionError', 'get_scheme'] + +logger = logging.getLogger(__name__) + + +class UnsupportedVersionError(ValueError): + """This is an unsupported version.""" + pass + + +class Version(object): + def __init__(self, s): + self._string = s = s.strip() + self._parts = parts = self.parse(s) + assert isinstance(parts, tuple) + assert len(parts) > 0 + + def parse(self, s): + raise NotImplementedError('please implement in a subclass') + + def _check_compatible(self, other): + if type(self) != type(other): + raise TypeError('cannot compare %r and %r' % (self, other)) + + def __eq__(self, other): + self._check_compatible(other) + return self._parts == other._parts + + def __ne__(self, other): + return not self.__eq__(other) + + def __lt__(self, other): + self._check_compatible(other) + return self._parts < other._parts + + def __gt__(self, other): + return not (self.__lt__(other) or self.__eq__(other)) + + def __le__(self, other): + return self.__lt__(other) or self.__eq__(other) + + def __ge__(self, other): + return self.__gt__(other) or self.__eq__(other) + + # See http://docs.python.org/reference/datamodel#object.__hash__ + def __hash__(self): + return hash(self._parts) + + def __repr__(self): + return "%s('%s')" % (self.__class__.__name__, self._string) + + def __str__(self): + return self._string + + @property + def is_prerelease(self): + raise NotImplementedError('Please implement in subclasses.') + + +class Matcher(object): + version_class = None + + # value is either a callable or the name of a method + _operators = { + '<': lambda v, c, p: v < c, + '>': lambda v, c, p: v > c, + '<=': lambda v, c, p: v == c or v < c, + '>=': lambda v, c, p: v == c or v > c, + '==': lambda v, c, p: v == c, + '===': lambda v, c, p: v == c, + # by default, compatible => >=. + '~=': lambda v, c, p: v == c or v > c, + '!=': lambda v, c, p: v != c, + } + + # this is a method only to support alternative implementations + # via overriding + def parse_requirement(self, s): + return parse_requirement(s) + + def __init__(self, s): + if self.version_class is None: + raise ValueError('Please specify a version class') + self._string = s = s.strip() + r = self.parse_requirement(s) + if not r: + raise ValueError('Not valid: %r' % s) + self.name = r.name + self.key = self.name.lower() # for case-insensitive comparisons + clist = [] + if r.constraints: + # import pdb; pdb.set_trace() + for op, s in r.constraints: + if s.endswith('.*'): + if op not in ('==', '!='): + raise ValueError('\'.*\' not allowed for ' + '%r constraints' % op) + # Could be a partial version (e.g. for '2.*') which + # won't parse as a version, so keep it as a string + vn, prefix = s[:-2], True + # Just to check that vn is a valid version + self.version_class(vn) + else: + # Should parse as a version, so we can create an + # instance for the comparison + vn, prefix = self.version_class(s), False + clist.append((op, vn, prefix)) + self._parts = tuple(clist) + + def match(self, version): + """ + Check if the provided version matches the constraints. + + :param version: The version to match against this instance. + :type version: String or :class:`Version` instance. + """ + if isinstance(version, string_types): + version = self.version_class(version) + for operator, constraint, prefix in self._parts: + f = self._operators.get(operator) + if isinstance(f, string_types): + f = getattr(self, f) + if not f: + msg = ('%r not implemented ' + 'for %s' % (operator, self.__class__.__name__)) + raise NotImplementedError(msg) + if not f(version, constraint, prefix): + return False + return True + + @property + def exact_version(self): + result = None + if len(self._parts) == 1 and self._parts[0][0] in ('==', '==='): + result = self._parts[0][1] + return result + + def _check_compatible(self, other): + if type(self) != type(other) or self.name != other.name: + raise TypeError('cannot compare %s and %s' % (self, other)) + + def __eq__(self, other): + self._check_compatible(other) + return self.key == other.key and self._parts == other._parts + + def __ne__(self, other): + return not self.__eq__(other) + + # See http://docs.python.org/reference/datamodel#object.__hash__ + def __hash__(self): + return hash(self.key) + hash(self._parts) + + def __repr__(self): + return "%s(%r)" % (self.__class__.__name__, self._string) + + def __str__(self): + return self._string + + +PEP440_VERSION_RE = re.compile(r'^v?(\d+!)?(\d+(\.\d+)*)((a|b|c|rc)(\d+))?' + r'(\.(post)(\d+))?(\.(dev)(\d+))?' + r'(\+([a-zA-Z\d]+(\.[a-zA-Z\d]+)?))?$') + + +def _pep_440_key(s): + s = s.strip() + m = PEP440_VERSION_RE.match(s) + if not m: + raise UnsupportedVersionError('Not a valid version: %s' % s) + groups = m.groups() + nums = tuple(int(v) for v in groups[1].split('.')) + while len(nums) > 1 and nums[-1] == 0: + nums = nums[:-1] + + if not groups[0]: + epoch = 0 + else: + epoch = int(groups[0]) + pre = groups[4:6] + post = groups[7:9] + dev = groups[10:12] + local = groups[13] + if pre == (None, None): + pre = () + else: + pre = pre[0], int(pre[1]) + if post == (None, None): + post = () + else: + post = post[0], int(post[1]) + if dev == (None, None): + dev = () + else: + dev = dev[0], int(dev[1]) + if local is None: + local = () + else: + parts = [] + for part in local.split('.'): + # to ensure that numeric compares as > lexicographic, avoid + # comparing them directly, but encode a tuple which ensures + # correct sorting + if part.isdigit(): + part = (1, int(part)) + else: + part = (0, part) + parts.append(part) + local = tuple(parts) + if not pre: + # either before pre-release, or final release and after + if not post and dev: + # before pre-release + pre = ('a', -1) # to sort before a0 + else: + pre = ('z',) # to sort after all pre-releases + # now look at the state of post and dev. + if not post: + post = ('_',) # sort before 'a' + if not dev: + dev = ('final',) + + #print('%s -> %s' % (s, m.groups())) + return epoch, nums, pre, post, dev, local + + +_normalized_key = _pep_440_key + + +class NormalizedVersion(Version): + """A rational version. + + Good: + 1.2 # equivalent to "1.2.0" + 1.2.0 + 1.2a1 + 1.2.3a2 + 1.2.3b1 + 1.2.3c1 + 1.2.3.4 + TODO: fill this out + + Bad: + 1 # minimum two numbers + 1.2a # release level must have a release serial + 1.2.3b + """ + def parse(self, s): + result = _normalized_key(s) + # _normalized_key loses trailing zeroes in the release + # clause, since that's needed to ensure that X.Y == X.Y.0 == X.Y.0.0 + # However, PEP 440 prefix matching needs it: for example, + # (~= 1.4.5.0) matches differently to (~= 1.4.5.0.0). + m = PEP440_VERSION_RE.match(s) # must succeed + groups = m.groups() + self._release_clause = tuple(int(v) for v in groups[1].split('.')) + return result + + PREREL_TAGS = set(['a', 'b', 'c', 'rc', 'dev']) + + @property + def is_prerelease(self): + return any(t[0] in self.PREREL_TAGS for t in self._parts if t) + + +def _match_prefix(x, y): + x = str(x) + y = str(y) + if x == y: + return True + if not x.startswith(y): + return False + n = len(y) + return x[n] == '.' + + +class NormalizedMatcher(Matcher): + version_class = NormalizedVersion + + # value is either a callable or the name of a method + _operators = { + '~=': '_match_compatible', + '<': '_match_lt', + '>': '_match_gt', + '<=': '_match_le', + '>=': '_match_ge', + '==': '_match_eq', + '===': '_match_arbitrary', + '!=': '_match_ne', + } + + def _adjust_local(self, version, constraint, prefix): + if prefix: + strip_local = '+' not in constraint and version._parts[-1] + else: + # both constraint and version are + # NormalizedVersion instances. + # If constraint does not have a local component, + # ensure the version doesn't, either. + strip_local = not constraint._parts[-1] and version._parts[-1] + if strip_local: + s = version._string.split('+', 1)[0] + version = self.version_class(s) + return version, constraint + + def _match_lt(self, version, constraint, prefix): + version, constraint = self._adjust_local(version, constraint, prefix) + if version >= constraint: + return False + release_clause = constraint._release_clause + pfx = '.'.join([str(i) for i in release_clause]) + return not _match_prefix(version, pfx) + + def _match_gt(self, version, constraint, prefix): + version, constraint = self._adjust_local(version, constraint, prefix) + if version <= constraint: + return False + release_clause = constraint._release_clause + pfx = '.'.join([str(i) for i in release_clause]) + return not _match_prefix(version, pfx) + + def _match_le(self, version, constraint, prefix): + version, constraint = self._adjust_local(version, constraint, prefix) + return version <= constraint + + def _match_ge(self, version, constraint, prefix): + version, constraint = self._adjust_local(version, constraint, prefix) + return version >= constraint + + def _match_eq(self, version, constraint, prefix): + version, constraint = self._adjust_local(version, constraint, prefix) + if not prefix: + result = (version == constraint) + else: + result = _match_prefix(version, constraint) + return result + + def _match_arbitrary(self, version, constraint, prefix): + return str(version) == str(constraint) + + def _match_ne(self, version, constraint, prefix): + version, constraint = self._adjust_local(version, constraint, prefix) + if not prefix: + result = (version != constraint) + else: + result = not _match_prefix(version, constraint) + return result + + def _match_compatible(self, version, constraint, prefix): + version, constraint = self._adjust_local(version, constraint, prefix) + if version == constraint: + return True + if version < constraint: + return False +# if not prefix: +# return True + release_clause = constraint._release_clause + if len(release_clause) > 1: + release_clause = release_clause[:-1] + pfx = '.'.join([str(i) for i in release_clause]) + return _match_prefix(version, pfx) + +_REPLACEMENTS = ( + (re.compile('[.+-]$'), ''), # remove trailing puncts + (re.compile(r'^[.](\d)'), r'0.\1'), # .N -> 0.N at start + (re.compile('^[.-]'), ''), # remove leading puncts + (re.compile(r'^\((.*)\)$'), r'\1'), # remove parentheses + (re.compile(r'^v(ersion)?\s*(\d+)'), r'\2'), # remove leading v(ersion) + (re.compile(r'^r(ev)?\s*(\d+)'), r'\2'), # remove leading v(ersion) + (re.compile('[.]{2,}'), '.'), # multiple runs of '.' + (re.compile(r'\b(alfa|apha)\b'), 'alpha'), # misspelt alpha + (re.compile(r'\b(pre-alpha|prealpha)\b'), + 'pre.alpha'), # standardise + (re.compile(r'\(beta\)$'), 'beta'), # remove parentheses +) + +_SUFFIX_REPLACEMENTS = ( + (re.compile('^[:~._+-]+'), ''), # remove leading puncts + (re.compile('[,*")([\\]]'), ''), # remove unwanted chars + (re.compile('[~:+_ -]'), '.'), # replace illegal chars + (re.compile('[.]{2,}'), '.'), # multiple runs of '.' + (re.compile(r'\.$'), ''), # trailing '.' +) + +_NUMERIC_PREFIX = re.compile(r'(\d+(\.\d+)*)') + + +def _suggest_semantic_version(s): + """ + Try to suggest a semantic form for a version for which + _suggest_normalized_version couldn't come up with anything. + """ + result = s.strip().lower() + for pat, repl in _REPLACEMENTS: + result = pat.sub(repl, result) + if not result: + result = '0.0.0' + + # Now look for numeric prefix, and separate it out from + # the rest. + #import pdb; pdb.set_trace() + m = _NUMERIC_PREFIX.match(result) + if not m: + prefix = '0.0.0' + suffix = result + else: + prefix = m.groups()[0].split('.') + prefix = [int(i) for i in prefix] + while len(prefix) < 3: + prefix.append(0) + if len(prefix) == 3: + suffix = result[m.end():] + else: + suffix = '.'.join([str(i) for i in prefix[3:]]) + result[m.end():] + prefix = prefix[:3] + prefix = '.'.join([str(i) for i in prefix]) + suffix = suffix.strip() + if suffix: + #import pdb; pdb.set_trace() + # massage the suffix. + for pat, repl in _SUFFIX_REPLACEMENTS: + suffix = pat.sub(repl, suffix) + + if not suffix: + result = prefix + else: + sep = '-' if 'dev' in suffix else '+' + result = prefix + sep + suffix + if not is_semver(result): + result = None + return result + + +def _suggest_normalized_version(s): + """Suggest a normalized version close to the given version string. + + If you have a version string that isn't rational (i.e. NormalizedVersion + doesn't like it) then you might be able to get an equivalent (or close) + rational version from this function. + + This does a number of simple normalizations to the given string, based + on observation of versions currently in use on PyPI. Given a dump of + those version during PyCon 2009, 4287 of them: + - 2312 (53.93%) match NormalizedVersion without change + with the automatic suggestion + - 3474 (81.04%) match when using this suggestion method + + @param s {str} An irrational version string. + @returns A rational version string, or None, if couldn't determine one. + """ + try: + _normalized_key(s) + return s # already rational + except UnsupportedVersionError: + pass + + rs = s.lower() + + # part of this could use maketrans + for orig, repl in (('-alpha', 'a'), ('-beta', 'b'), ('alpha', 'a'), + ('beta', 'b'), ('rc', 'c'), ('-final', ''), + ('-pre', 'c'), + ('-release', ''), ('.release', ''), ('-stable', ''), + ('+', '.'), ('_', '.'), (' ', ''), ('.final', ''), + ('final', '')): + rs = rs.replace(orig, repl) + + # if something ends with dev or pre, we add a 0 + rs = re.sub(r"pre$", r"pre0", rs) + rs = re.sub(r"dev$", r"dev0", rs) + + # if we have something like "b-2" or "a.2" at the end of the + # version, that is probably beta, alpha, etc + # let's remove the dash or dot + rs = re.sub(r"([abc]|rc)[\-\.](\d+)$", r"\1\2", rs) + + # 1.0-dev-r371 -> 1.0.dev371 + # 0.1-dev-r79 -> 0.1.dev79 + rs = re.sub(r"[\-\.](dev)[\-\.]?r?(\d+)$", r".\1\2", rs) + + # Clean: 2.0.a.3, 2.0.b1, 0.9.0~c1 + rs = re.sub(r"[.~]?([abc])\.?", r"\1", rs) + + # Clean: v0.3, v1.0 + if rs.startswith('v'): + rs = rs[1:] + + # Clean leading '0's on numbers. + #TODO: unintended side-effect on, e.g., "2003.05.09" + # PyPI stats: 77 (~2%) better + rs = re.sub(r"\b0+(\d+)(?!\d)", r"\1", rs) + + # Clean a/b/c with no version. E.g. "1.0a" -> "1.0a0". Setuptools infers + # zero. + # PyPI stats: 245 (7.56%) better + rs = re.sub(r"(\d+[abc])$", r"\g<1>0", rs) + + # the 'dev-rNNN' tag is a dev tag + rs = re.sub(r"\.?(dev-r|dev\.r)\.?(\d+)$", r".dev\2", rs) + + # clean the - when used as a pre delimiter + rs = re.sub(r"-(a|b|c)(\d+)$", r"\1\2", rs) + + # a terminal "dev" or "devel" can be changed into ".dev0" + rs = re.sub(r"[\.\-](dev|devel)$", r".dev0", rs) + + # a terminal "dev" can be changed into ".dev0" + rs = re.sub(r"(?![\.\-])dev$", r".dev0", rs) + + # a terminal "final" or "stable" can be removed + rs = re.sub(r"(final|stable)$", "", rs) + + # The 'r' and the '-' tags are post release tags + # 0.4a1.r10 -> 0.4a1.post10 + # 0.9.33-17222 -> 0.9.33.post17222 + # 0.9.33-r17222 -> 0.9.33.post17222 + rs = re.sub(r"\.?(r|-|-r)\.?(\d+)$", r".post\2", rs) + + # Clean 'r' instead of 'dev' usage: + # 0.9.33+r17222 -> 0.9.33.dev17222 + # 1.0dev123 -> 1.0.dev123 + # 1.0.git123 -> 1.0.dev123 + # 1.0.bzr123 -> 1.0.dev123 + # 0.1a0dev.123 -> 0.1a0.dev123 + # PyPI stats: ~150 (~4%) better + rs = re.sub(r"\.?(dev|git|bzr)\.?(\d+)$", r".dev\2", rs) + + # Clean '.pre' (normalized from '-pre' above) instead of 'c' usage: + # 0.2.pre1 -> 0.2c1 + # 0.2-c1 -> 0.2c1 + # 1.0preview123 -> 1.0c123 + # PyPI stats: ~21 (0.62%) better + rs = re.sub(r"\.?(pre|preview|-c)(\d+)$", r"c\g<2>", rs) + + # Tcl/Tk uses "px" for their post release markers + rs = re.sub(r"p(\d+)$", r".post\1", rs) + + try: + _normalized_key(rs) + except UnsupportedVersionError: + rs = None + return rs + +# +# Legacy version processing (distribute-compatible) +# + +_VERSION_PART = re.compile(r'([a-z]+|\d+|[\.-])', re.I) +_VERSION_REPLACE = { + 'pre': 'c', + 'preview': 'c', + '-': 'final-', + 'rc': 'c', + 'dev': '@', + '': None, + '.': None, +} + + +def _legacy_key(s): + def get_parts(s): + result = [] + for p in _VERSION_PART.split(s.lower()): + p = _VERSION_REPLACE.get(p, p) + if p: + if '0' <= p[:1] <= '9': + p = p.zfill(8) + else: + p = '*' + p + result.append(p) + result.append('*final') + return result + + result = [] + for p in get_parts(s): + if p.startswith('*'): + if p < '*final': + while result and result[-1] == '*final-': + result.pop() + while result and result[-1] == '00000000': + result.pop() + result.append(p) + return tuple(result) + + +class LegacyVersion(Version): + def parse(self, s): + return _legacy_key(s) + + @property + def is_prerelease(self): + result = False + for x in self._parts: + if (isinstance(x, string_types) and x.startswith('*') and + x < '*final'): + result = True + break + return result + + +class LegacyMatcher(Matcher): + version_class = LegacyVersion + + _operators = dict(Matcher._operators) + _operators['~='] = '_match_compatible' + + numeric_re = re.compile(r'^(\d+(\.\d+)*)') + + def _match_compatible(self, version, constraint, prefix): + if version < constraint: + return False + m = self.numeric_re.match(str(constraint)) + if not m: + logger.warning('Cannot compute compatible match for version %s ' + ' and constraint %s', version, constraint) + return True + s = m.groups()[0] + if '.' in s: + s = s.rsplit('.', 1)[0] + return _match_prefix(version, s) + +# +# Semantic versioning +# + +_SEMVER_RE = re.compile(r'^(\d+)\.(\d+)\.(\d+)' + r'(-[a-z0-9]+(\.[a-z0-9-]+)*)?' + r'(\+[a-z0-9]+(\.[a-z0-9-]+)*)?$', re.I) + + +def is_semver(s): + return _SEMVER_RE.match(s) + + +def _semantic_key(s): + def make_tuple(s, absent): + if s is None: + result = (absent,) + else: + parts = s[1:].split('.') + # We can't compare ints and strings on Python 3, so fudge it + # by zero-filling numeric values so simulate a numeric comparison + result = tuple([p.zfill(8) if p.isdigit() else p for p in parts]) + return result + + m = is_semver(s) + if not m: + raise UnsupportedVersionError(s) + groups = m.groups() + major, minor, patch = [int(i) for i in groups[:3]] + # choose the '|' and '*' so that versions sort correctly + pre, build = make_tuple(groups[3], '|'), make_tuple(groups[5], '*') + return (major, minor, patch), pre, build + + +class SemanticVersion(Version): + def parse(self, s): + return _semantic_key(s) + + @property + def is_prerelease(self): + return self._parts[1][0] != '|' + + +class SemanticMatcher(Matcher): + version_class = SemanticVersion + + +class VersionScheme(object): + def __init__(self, key, matcher, suggester=None): + self.key = key + self.matcher = matcher + self.suggester = suggester + + def is_valid_version(self, s): + try: + self.matcher.version_class(s) + result = True + except UnsupportedVersionError: + result = False + return result + + def is_valid_matcher(self, s): + try: + self.matcher(s) + result = True + except UnsupportedVersionError: + result = False + return result + + def is_valid_constraint_list(self, s): + """ + Used for processing some metadata fields + """ + return self.is_valid_matcher('dummy_name (%s)' % s) + + def suggest(self, s): + if self.suggester is None: + result = None + else: + result = self.suggester(s) + return result + +_SCHEMES = { + 'normalized': VersionScheme(_normalized_key, NormalizedMatcher, + _suggest_normalized_version), + 'legacy': VersionScheme(_legacy_key, LegacyMatcher, lambda self, s: s), + 'semantic': VersionScheme(_semantic_key, SemanticMatcher, + _suggest_semantic_version), +} + +_SCHEMES['default'] = _SCHEMES['normalized'] + + +def get_scheme(name): + if name not in _SCHEMES: + raise ValueError('unknown scheme name: %r' % name) + return _SCHEMES[name] diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/w32.exe b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/w32.exe new file mode 100644 index 0000000000000000000000000000000000000000..4df77001a222c84ff3fef542618b3f45f4c1eb9e GIT binary patch literal 89088 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 fiS%H2)uMec59 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/w64.exe b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/w64.exe new file mode 100644 index 0000000000000000000000000000000000000000..63ce483d1e462373fe16015c70ec52bbbd816c11 GIT binary patch literal 99840 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 DO6W+w literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/wheel.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/wheel.py new file mode 100644 index 0000000..0c8efad --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distlib/wheel.py @@ -0,0 +1,1004 @@ +# -*- coding: utf-8 -*- +# +# Copyright (C) 2013-2017 Vinay Sajip. +# Licensed to the Python Software Foundation under a contributor agreement. +# See LICENSE.txt and CONTRIBUTORS.txt. +# +from __future__ import unicode_literals + +import base64 +import codecs +import datetime +import distutils.util +from email import message_from_file +import hashlib +import imp +import json +import logging +import os +import posixpath +import re +import shutil +import sys +import tempfile +import zipfile + +from . import __version__, DistlibException +from .compat import sysconfig, ZipFile, fsdecode, text_type, filter +from .database import InstalledDistribution +from .metadata import Metadata, METADATA_FILENAME, WHEEL_METADATA_FILENAME +from .util import (FileOperator, convert_path, CSVReader, CSVWriter, Cache, + cached_property, get_cache_base, read_exports, tempdir) +from .version import NormalizedVersion, UnsupportedVersionError + +logger = logging.getLogger(__name__) + +cache = None # created when needed + +if hasattr(sys, 'pypy_version_info'): # pragma: no cover + IMP_PREFIX = 'pp' +elif sys.platform.startswith('java'): # pragma: no cover + IMP_PREFIX = 'jy' +elif sys.platform == 'cli': # pragma: no cover + IMP_PREFIX = 'ip' +else: + IMP_PREFIX = 'cp' + +VER_SUFFIX = sysconfig.get_config_var('py_version_nodot') +if not VER_SUFFIX: # pragma: no cover + VER_SUFFIX = '%s%s' % sys.version_info[:2] +PYVER = 'py' + VER_SUFFIX +IMPVER = IMP_PREFIX + VER_SUFFIX + +ARCH = distutils.util.get_platform().replace('-', '_').replace('.', '_') + +ABI = sysconfig.get_config_var('SOABI') +if ABI and ABI.startswith('cpython-'): + ABI = ABI.replace('cpython-', 'cp') +else: + def _derive_abi(): + parts = ['cp', VER_SUFFIX] + if sysconfig.get_config_var('Py_DEBUG'): + parts.append('d') + if sysconfig.get_config_var('WITH_PYMALLOC'): + parts.append('m') + if sysconfig.get_config_var('Py_UNICODE_SIZE') == 4: + parts.append('u') + return ''.join(parts) + ABI = _derive_abi() + del _derive_abi + +FILENAME_RE = re.compile(r''' +(?P<nm>[^-]+) +-(?P<vn>\d+[^-]*) +(-(?P<bn>\d+[^-]*))? +-(?P<py>\w+\d+(\.\w+\d+)*) +-(?P<bi>\w+) +-(?P<ar>\w+(\.\w+)*) +\.whl$ +''', re.IGNORECASE | re.VERBOSE) + +NAME_VERSION_RE = re.compile(r''' +(?P<nm>[^-]+) +-(?P<vn>\d+[^-]*) +(-(?P<bn>\d+[^-]*))?$ +''', re.IGNORECASE | re.VERBOSE) + +SHEBANG_RE = re.compile(br'\s*#![^\r\n]*') +SHEBANG_DETAIL_RE = re.compile(br'^(\s*#!("[^"]+"|\S+))\s+(.*)$') +SHEBANG_PYTHON = b'#!python' +SHEBANG_PYTHONW = b'#!pythonw' + +if os.sep == '/': + to_posix = lambda o: o +else: + to_posix = lambda o: o.replace(os.sep, '/') + + +class Mounter(object): + def __init__(self): + self.impure_wheels = {} + self.libs = {} + + def add(self, pathname, extensions): + self.impure_wheels[pathname] = extensions + self.libs.update(extensions) + + def remove(self, pathname): + extensions = self.impure_wheels.pop(pathname) + for k, v in extensions: + if k in self.libs: + del self.libs[k] + + def find_module(self, fullname, path=None): + if fullname in self.libs: + result = self + else: + result = None + return result + + def load_module(self, fullname): + if fullname in sys.modules: + result = sys.modules[fullname] + else: + if fullname not in self.libs: + raise ImportError('unable to find extension for %s' % fullname) + result = imp.load_dynamic(fullname, self.libs[fullname]) + result.__loader__ = self + parts = fullname.rsplit('.', 1) + if len(parts) > 1: + result.__package__ = parts[0] + return result + +_hook = Mounter() + + +class Wheel(object): + """ + Class to build and install from Wheel files (PEP 427). + """ + + wheel_version = (1, 1) + hash_kind = 'sha256' + + def __init__(self, filename=None, sign=False, verify=False): + """ + Initialise an instance using a (valid) filename. + """ + self.sign = sign + self.should_verify = verify + self.buildver = '' + self.pyver = [PYVER] + self.abi = ['none'] + self.arch = ['any'] + self.dirname = os.getcwd() + if filename is None: + self.name = 'dummy' + self.version = '0.1' + self._filename = self.filename + else: + m = NAME_VERSION_RE.match(filename) + if m: + info = m.groupdict('') + self.name = info['nm'] + # Reinstate the local version separator + self.version = info['vn'].replace('_', '-') + self.buildver = info['bn'] + self._filename = self.filename + else: + dirname, filename = os.path.split(filename) + m = FILENAME_RE.match(filename) + if not m: + raise DistlibException('Invalid name or ' + 'filename: %r' % filename) + if dirname: + self.dirname = os.path.abspath(dirname) + self._filename = filename + info = m.groupdict('') + self.name = info['nm'] + self.version = info['vn'] + self.buildver = info['bn'] + self.pyver = info['py'].split('.') + self.abi = info['bi'].split('.') + self.arch = info['ar'].split('.') + + @property + def filename(self): + """ + Build and return a filename from the various components. + """ + if self.buildver: + buildver = '-' + self.buildver + else: + buildver = '' + pyver = '.'.join(self.pyver) + abi = '.'.join(self.abi) + arch = '.'.join(self.arch) + # replace - with _ as a local version separator + version = self.version.replace('-', '_') + return '%s-%s%s-%s-%s-%s.whl' % (self.name, version, buildver, + pyver, abi, arch) + + @property + def exists(self): + path = os.path.join(self.dirname, self.filename) + return os.path.isfile(path) + + @property + def tags(self): + for pyver in self.pyver: + for abi in self.abi: + for arch in self.arch: + yield pyver, abi, arch + + @cached_property + def metadata(self): + pathname = os.path.join(self.dirname, self.filename) + name_ver = '%s-%s' % (self.name, self.version) + info_dir = '%s.dist-info' % name_ver + wrapper = codecs.getreader('utf-8') + with ZipFile(pathname, 'r') as zf: + wheel_metadata = self.get_wheel_metadata(zf) + wv = wheel_metadata['Wheel-Version'].split('.', 1) + file_version = tuple([int(i) for i in wv]) + if file_version < (1, 1): + fns = [WHEEL_METADATA_FILENAME, METADATA_FILENAME, 'METADATA'] + else: + fns = [WHEEL_METADATA_FILENAME, METADATA_FILENAME] + result = None + for fn in fns: + try: + metadata_filename = posixpath.join(info_dir, fn) + with zf.open(metadata_filename) as bf: + wf = wrapper(bf) + result = Metadata(fileobj=wf) + if result: + break + except KeyError: + pass + if not result: + raise ValueError('Invalid wheel, because metadata is ' + 'missing: looked in %s' % ', '.join(fns)) + return result + + def get_wheel_metadata(self, zf): + name_ver = '%s-%s' % (self.name, self.version) + info_dir = '%s.dist-info' % name_ver + metadata_filename = posixpath.join(info_dir, 'WHEEL') + with zf.open(metadata_filename) as bf: + wf = codecs.getreader('utf-8')(bf) + message = message_from_file(wf) + return dict(message) + + @cached_property + def info(self): + pathname = os.path.join(self.dirname, self.filename) + with ZipFile(pathname, 'r') as zf: + result = self.get_wheel_metadata(zf) + return result + + def process_shebang(self, data): + m = SHEBANG_RE.match(data) + if m: + end = m.end() + shebang, data_after_shebang = data[:end], data[end:] + # Preserve any arguments after the interpreter + if b'pythonw' in shebang.lower(): + shebang_python = SHEBANG_PYTHONW + else: + shebang_python = SHEBANG_PYTHON + m = SHEBANG_DETAIL_RE.match(shebang) + if m: + args = b' ' + m.groups()[-1] + else: + args = b'' + shebang = shebang_python + args + data = shebang + data_after_shebang + else: + cr = data.find(b'\r') + lf = data.find(b'\n') + if cr < 0 or cr > lf: + term = b'\n' + else: + if data[cr:cr + 2] == b'\r\n': + term = b'\r\n' + else: + term = b'\r' + data = SHEBANG_PYTHON + term + data + return data + + def get_hash(self, data, hash_kind=None): + if hash_kind is None: + hash_kind = self.hash_kind + try: + hasher = getattr(hashlib, hash_kind) + except AttributeError: + raise DistlibException('Unsupported hash algorithm: %r' % hash_kind) + result = hasher(data).digest() + result = base64.urlsafe_b64encode(result).rstrip(b'=').decode('ascii') + return hash_kind, result + + def write_record(self, records, record_path, base): + records = list(records) # make a copy for sorting + p = to_posix(os.path.relpath(record_path, base)) + records.append((p, '', '')) + records.sort() + with CSVWriter(record_path) as writer: + for row in records: + writer.writerow(row) + + def write_records(self, info, libdir, archive_paths): + records = [] + distinfo, info_dir = info + hasher = getattr(hashlib, self.hash_kind) + for ap, p in archive_paths: + with open(p, 'rb') as f: + data = f.read() + digest = '%s=%s' % self.get_hash(data) + size = os.path.getsize(p) + records.append((ap, digest, size)) + + p = os.path.join(distinfo, 'RECORD') + self.write_record(records, p, libdir) + ap = to_posix(os.path.join(info_dir, 'RECORD')) + archive_paths.append((ap, p)) + + def build_zip(self, pathname, archive_paths): + with ZipFile(pathname, 'w', zipfile.ZIP_DEFLATED) as zf: + for ap, p in archive_paths: + logger.debug('Wrote %s to %s in wheel', p, ap) + zf.write(p, ap) + + def build(self, paths, tags=None, wheel_version=None): + """ + Build a wheel from files in specified paths, and use any specified tags + when determining the name of the wheel. + """ + if tags is None: + tags = {} + + libkey = list(filter(lambda o: o in paths, ('purelib', 'platlib')))[0] + if libkey == 'platlib': + is_pure = 'false' + default_pyver = [IMPVER] + default_abi = [ABI] + default_arch = [ARCH] + else: + is_pure = 'true' + default_pyver = [PYVER] + default_abi = ['none'] + default_arch = ['any'] + + self.pyver = tags.get('pyver', default_pyver) + self.abi = tags.get('abi', default_abi) + self.arch = tags.get('arch', default_arch) + + libdir = paths[libkey] + + name_ver = '%s-%s' % (self.name, self.version) + data_dir = '%s.data' % name_ver + info_dir = '%s.dist-info' % name_ver + + archive_paths = [] + + # First, stuff which is not in site-packages + for key in ('data', 'headers', 'scripts'): + if key not in paths: + continue + path = paths[key] + if os.path.isdir(path): + for root, dirs, files in os.walk(path): + for fn in files: + p = fsdecode(os.path.join(root, fn)) + rp = os.path.relpath(p, path) + ap = to_posix(os.path.join(data_dir, key, rp)) + archive_paths.append((ap, p)) + if key == 'scripts' and not p.endswith('.exe'): + with open(p, 'rb') as f: + data = f.read() + data = self.process_shebang(data) + with open(p, 'wb') as f: + f.write(data) + + # Now, stuff which is in site-packages, other than the + # distinfo stuff. + path = libdir + distinfo = None + for root, dirs, files in os.walk(path): + if root == path: + # At the top level only, save distinfo for later + # and skip it for now + for i, dn in enumerate(dirs): + dn = fsdecode(dn) + if dn.endswith('.dist-info'): + distinfo = os.path.join(root, dn) + del dirs[i] + break + assert distinfo, '.dist-info directory expected, not found' + + for fn in files: + # comment out next suite to leave .pyc files in + if fsdecode(fn).endswith(('.pyc', '.pyo')): + continue + p = os.path.join(root, fn) + rp = to_posix(os.path.relpath(p, path)) + archive_paths.append((rp, p)) + + # Now distinfo. Assumed to be flat, i.e. os.listdir is enough. + files = os.listdir(distinfo) + for fn in files: + if fn not in ('RECORD', 'INSTALLER', 'SHARED', 'WHEEL'): + p = fsdecode(os.path.join(distinfo, fn)) + ap = to_posix(os.path.join(info_dir, fn)) + archive_paths.append((ap, p)) + + wheel_metadata = [ + 'Wheel-Version: %d.%d' % (wheel_version or self.wheel_version), + 'Generator: distlib %s' % __version__, + 'Root-Is-Purelib: %s' % is_pure, + ] + for pyver, abi, arch in self.tags: + wheel_metadata.append('Tag: %s-%s-%s' % (pyver, abi, arch)) + p = os.path.join(distinfo, 'WHEEL') + with open(p, 'w') as f: + f.write('\n'.join(wheel_metadata)) + ap = to_posix(os.path.join(info_dir, 'WHEEL')) + archive_paths.append((ap, p)) + + # Now, at last, RECORD. + # Paths in here are archive paths - nothing else makes sense. + self.write_records((distinfo, info_dir), libdir, archive_paths) + # Now, ready to build the zip file + pathname = os.path.join(self.dirname, self.filename) + self.build_zip(pathname, archive_paths) + return pathname + + def skip_entry(self, arcname): + """ + Determine whether an archive entry should be skipped when verifying + or installing. + """ + # The signature file won't be in RECORD, + # and we don't currently don't do anything with it + # We also skip directories, as they won't be in RECORD + # either. See: + # + # https://github.com/pypa/wheel/issues/294 + # https://github.com/pypa/wheel/issues/287 + # https://github.com/pypa/wheel/pull/289 + # + return arcname.endswith(('/', '/RECORD.jws')) + + def install(self, paths, maker, **kwargs): + """ + Install a wheel to the specified paths. If kwarg ``warner`` is + specified, it should be a callable, which will be called with two + tuples indicating the wheel version of this software and the wheel + version in the file, if there is a discrepancy in the versions. + This can be used to issue any warnings to raise any exceptions. + If kwarg ``lib_only`` is True, only the purelib/platlib files are + installed, and the headers, scripts, data and dist-info metadata are + not written. If kwarg ``bytecode_hashed_invalidation`` is True, written + bytecode will try to use file-hash based invalidation (PEP-552) on + supported interpreter versions (CPython 2.7+). + + The return value is a :class:`InstalledDistribution` instance unless + ``options.lib_only`` is True, in which case the return value is ``None``. + """ + + dry_run = maker.dry_run + warner = kwargs.get('warner') + lib_only = kwargs.get('lib_only', False) + bc_hashed_invalidation = kwargs.get('bytecode_hashed_invalidation', False) + + pathname = os.path.join(self.dirname, self.filename) + name_ver = '%s-%s' % (self.name, self.version) + data_dir = '%s.data' % name_ver + info_dir = '%s.dist-info' % name_ver + + metadata_name = posixpath.join(info_dir, METADATA_FILENAME) + wheel_metadata_name = posixpath.join(info_dir, 'WHEEL') + record_name = posixpath.join(info_dir, 'RECORD') + + wrapper = codecs.getreader('utf-8') + + with ZipFile(pathname, 'r') as zf: + with zf.open(wheel_metadata_name) as bwf: + wf = wrapper(bwf) + message = message_from_file(wf) + wv = message['Wheel-Version'].split('.', 1) + file_version = tuple([int(i) for i in wv]) + if (file_version != self.wheel_version) and warner: + warner(self.wheel_version, file_version) + + if message['Root-Is-Purelib'] == 'true': + libdir = paths['purelib'] + else: + libdir = paths['platlib'] + + records = {} + with zf.open(record_name) as bf: + with CSVReader(stream=bf) as reader: + for row in reader: + p = row[0] + records[p] = row + + data_pfx = posixpath.join(data_dir, '') + info_pfx = posixpath.join(info_dir, '') + script_pfx = posixpath.join(data_dir, 'scripts', '') + + # make a new instance rather than a copy of maker's, + # as we mutate it + fileop = FileOperator(dry_run=dry_run) + fileop.record = True # so we can rollback if needed + + bc = not sys.dont_write_bytecode # Double negatives. Lovely! + + outfiles = [] # for RECORD writing + + # for script copying/shebang processing + workdir = tempfile.mkdtemp() + # set target dir later + # we default add_launchers to False, as the + # Python Launcher should be used instead + maker.source_dir = workdir + maker.target_dir = None + try: + for zinfo in zf.infolist(): + arcname = zinfo.filename + if isinstance(arcname, text_type): + u_arcname = arcname + else: + u_arcname = arcname.decode('utf-8') + if self.skip_entry(u_arcname): + continue + row = records[u_arcname] + if row[2] and str(zinfo.file_size) != row[2]: + raise DistlibException('size mismatch for ' + '%s' % u_arcname) + if row[1]: + kind, value = row[1].split('=', 1) + with zf.open(arcname) as bf: + data = bf.read() + _, digest = self.get_hash(data, kind) + if digest != value: + raise DistlibException('digest mismatch for ' + '%s' % arcname) + + if lib_only and u_arcname.startswith((info_pfx, data_pfx)): + logger.debug('lib_only: skipping %s', u_arcname) + continue + is_script = (u_arcname.startswith(script_pfx) + and not u_arcname.endswith('.exe')) + + if u_arcname.startswith(data_pfx): + _, where, rp = u_arcname.split('/', 2) + outfile = os.path.join(paths[where], convert_path(rp)) + else: + # meant for site-packages. + if u_arcname in (wheel_metadata_name, record_name): + continue + outfile = os.path.join(libdir, convert_path(u_arcname)) + if not is_script: + with zf.open(arcname) as bf: + fileop.copy_stream(bf, outfile) + outfiles.append(outfile) + # Double check the digest of the written file + if not dry_run and row[1]: + with open(outfile, 'rb') as bf: + data = bf.read() + _, newdigest = self.get_hash(data, kind) + if newdigest != digest: + raise DistlibException('digest mismatch ' + 'on write for ' + '%s' % outfile) + if bc and outfile.endswith('.py'): + try: + pyc = fileop.byte_compile(outfile, + hashed_invalidation=bc_hashed_invalidation) + outfiles.append(pyc) + except Exception: + # Don't give up if byte-compilation fails, + # but log it and perhaps warn the user + logger.warning('Byte-compilation failed', + exc_info=True) + else: + fn = os.path.basename(convert_path(arcname)) + workname = os.path.join(workdir, fn) + with zf.open(arcname) as bf: + fileop.copy_stream(bf, workname) + + dn, fn = os.path.split(outfile) + maker.target_dir = dn + filenames = maker.make(fn) + fileop.set_executable_mode(filenames) + outfiles.extend(filenames) + + if lib_only: + logger.debug('lib_only: returning None') + dist = None + else: + # Generate scripts + + # Try to get pydist.json so we can see if there are + # any commands to generate. If this fails (e.g. because + # of a legacy wheel), log a warning but don't give up. + commands = None + file_version = self.info['Wheel-Version'] + if file_version == '1.0': + # Use legacy info + ep = posixpath.join(info_dir, 'entry_points.txt') + try: + with zf.open(ep) as bwf: + epdata = read_exports(bwf) + commands = {} + for key in ('console', 'gui'): + k = '%s_scripts' % key + if k in epdata: + commands['wrap_%s' % key] = d = {} + for v in epdata[k].values(): + s = '%s:%s' % (v.prefix, v.suffix) + if v.flags: + s += ' %s' % v.flags + d[v.name] = s + except Exception: + logger.warning('Unable to read legacy script ' + 'metadata, so cannot generate ' + 'scripts') + else: + try: + with zf.open(metadata_name) as bwf: + wf = wrapper(bwf) + commands = json.load(wf).get('extensions') + if commands: + commands = commands.get('python.commands') + except Exception: + logger.warning('Unable to read JSON metadata, so ' + 'cannot generate scripts') + if commands: + console_scripts = commands.get('wrap_console', {}) + gui_scripts = commands.get('wrap_gui', {}) + if console_scripts or gui_scripts: + script_dir = paths.get('scripts', '') + if not os.path.isdir(script_dir): + raise ValueError('Valid script path not ' + 'specified') + maker.target_dir = script_dir + for k, v in console_scripts.items(): + script = '%s = %s' % (k, v) + filenames = maker.make(script) + fileop.set_executable_mode(filenames) + + if gui_scripts: + options = {'gui': True } + for k, v in gui_scripts.items(): + script = '%s = %s' % (k, v) + filenames = maker.make(script, options) + fileop.set_executable_mode(filenames) + + p = os.path.join(libdir, info_dir) + dist = InstalledDistribution(p) + + # Write SHARED + paths = dict(paths) # don't change passed in dict + del paths['purelib'] + del paths['platlib'] + paths['lib'] = libdir + p = dist.write_shared_locations(paths, dry_run) + if p: + outfiles.append(p) + + # Write RECORD + dist.write_installed_files(outfiles, paths['prefix'], + dry_run) + return dist + except Exception: # pragma: no cover + logger.exception('installation failed.') + fileop.rollback() + raise + finally: + shutil.rmtree(workdir) + + def _get_dylib_cache(self): + global cache + if cache is None: + # Use native string to avoid issues on 2.x: see Python #20140. + base = os.path.join(get_cache_base(), str('dylib-cache'), + sys.version[:3]) + cache = Cache(base) + return cache + + def _get_extensions(self): + pathname = os.path.join(self.dirname, self.filename) + name_ver = '%s-%s' % (self.name, self.version) + info_dir = '%s.dist-info' % name_ver + arcname = posixpath.join(info_dir, 'EXTENSIONS') + wrapper = codecs.getreader('utf-8') + result = [] + with ZipFile(pathname, 'r') as zf: + try: + with zf.open(arcname) as bf: + wf = wrapper(bf) + extensions = json.load(wf) + cache = self._get_dylib_cache() + prefix = cache.prefix_to_dir(pathname) + cache_base = os.path.join(cache.base, prefix) + if not os.path.isdir(cache_base): + os.makedirs(cache_base) + for name, relpath in extensions.items(): + dest = os.path.join(cache_base, convert_path(relpath)) + if not os.path.exists(dest): + extract = True + else: + file_time = os.stat(dest).st_mtime + file_time = datetime.datetime.fromtimestamp(file_time) + info = zf.getinfo(relpath) + wheel_time = datetime.datetime(*info.date_time) + extract = wheel_time > file_time + if extract: + zf.extract(relpath, cache_base) + result.append((name, dest)) + except KeyError: + pass + return result + + def is_compatible(self): + """ + Determine if a wheel is compatible with the running system. + """ + return is_compatible(self) + + def is_mountable(self): + """ + Determine if a wheel is asserted as mountable by its metadata. + """ + return True # for now - metadata details TBD + + def mount(self, append=False): + pathname = os.path.abspath(os.path.join(self.dirname, self.filename)) + if not self.is_compatible(): + msg = 'Wheel %s not compatible with this Python.' % pathname + raise DistlibException(msg) + if not self.is_mountable(): + msg = 'Wheel %s is marked as not mountable.' % pathname + raise DistlibException(msg) + if pathname in sys.path: + logger.debug('%s already in path', pathname) + else: + if append: + sys.path.append(pathname) + else: + sys.path.insert(0, pathname) + extensions = self._get_extensions() + if extensions: + if _hook not in sys.meta_path: + sys.meta_path.append(_hook) + _hook.add(pathname, extensions) + + def unmount(self): + pathname = os.path.abspath(os.path.join(self.dirname, self.filename)) + if pathname not in sys.path: + logger.debug('%s not in path', pathname) + else: + sys.path.remove(pathname) + if pathname in _hook.impure_wheels: + _hook.remove(pathname) + if not _hook.impure_wheels: + if _hook in sys.meta_path: + sys.meta_path.remove(_hook) + + def verify(self): + pathname = os.path.join(self.dirname, self.filename) + name_ver = '%s-%s' % (self.name, self.version) + data_dir = '%s.data' % name_ver + info_dir = '%s.dist-info' % name_ver + + metadata_name = posixpath.join(info_dir, METADATA_FILENAME) + wheel_metadata_name = posixpath.join(info_dir, 'WHEEL') + record_name = posixpath.join(info_dir, 'RECORD') + + wrapper = codecs.getreader('utf-8') + + with ZipFile(pathname, 'r') as zf: + with zf.open(wheel_metadata_name) as bwf: + wf = wrapper(bwf) + message = message_from_file(wf) + wv = message['Wheel-Version'].split('.', 1) + file_version = tuple([int(i) for i in wv]) + # TODO version verification + + records = {} + with zf.open(record_name) as bf: + with CSVReader(stream=bf) as reader: + for row in reader: + p = row[0] + records[p] = row + + for zinfo in zf.infolist(): + arcname = zinfo.filename + if isinstance(arcname, text_type): + u_arcname = arcname + else: + u_arcname = arcname.decode('utf-8') + # See issue #115: some wheels have .. in their entries, but + # in the filename ... e.g. __main__..py ! So the check is + # updated to look for .. in the directory portions + p = u_arcname.split('/') + if '..' in p: + raise DistlibException('invalid entry in ' + 'wheel: %r' % u_arcname) + + if self.skip_entry(u_arcname): + continue + row = records[u_arcname] + if row[2] and str(zinfo.file_size) != row[2]: + raise DistlibException('size mismatch for ' + '%s' % u_arcname) + if row[1]: + kind, value = row[1].split('=', 1) + with zf.open(arcname) as bf: + data = bf.read() + _, digest = self.get_hash(data, kind) + if digest != value: + raise DistlibException('digest mismatch for ' + '%s' % arcname) + + def update(self, modifier, dest_dir=None, **kwargs): + """ + Update the contents of a wheel in a generic way. The modifier should + be a callable which expects a dictionary argument: its keys are + archive-entry paths, and its values are absolute filesystem paths + where the contents the corresponding archive entries can be found. The + modifier is free to change the contents of the files pointed to, add + new entries and remove entries, before returning. This method will + extract the entire contents of the wheel to a temporary location, call + the modifier, and then use the passed (and possibly updated) + dictionary to write a new wheel. If ``dest_dir`` is specified, the new + wheel is written there -- otherwise, the original wheel is overwritten. + + The modifier should return True if it updated the wheel, else False. + This method returns the same value the modifier returns. + """ + + def get_version(path_map, info_dir): + version = path = None + key = '%s/%s' % (info_dir, METADATA_FILENAME) + if key not in path_map: + key = '%s/PKG-INFO' % info_dir + if key in path_map: + path = path_map[key] + version = Metadata(path=path).version + return version, path + + def update_version(version, path): + updated = None + try: + v = NormalizedVersion(version) + i = version.find('-') + if i < 0: + updated = '%s+1' % version + else: + parts = [int(s) for s in version[i + 1:].split('.')] + parts[-1] += 1 + updated = '%s+%s' % (version[:i], + '.'.join(str(i) for i in parts)) + except UnsupportedVersionError: + logger.debug('Cannot update non-compliant (PEP-440) ' + 'version %r', version) + if updated: + md = Metadata(path=path) + md.version = updated + legacy = not path.endswith(METADATA_FILENAME) + md.write(path=path, legacy=legacy) + logger.debug('Version updated from %r to %r', version, + updated) + + pathname = os.path.join(self.dirname, self.filename) + name_ver = '%s-%s' % (self.name, self.version) + info_dir = '%s.dist-info' % name_ver + record_name = posixpath.join(info_dir, 'RECORD') + with tempdir() as workdir: + with ZipFile(pathname, 'r') as zf: + path_map = {} + for zinfo in zf.infolist(): + arcname = zinfo.filename + if isinstance(arcname, text_type): + u_arcname = arcname + else: + u_arcname = arcname.decode('utf-8') + if u_arcname == record_name: + continue + if '..' in u_arcname: + raise DistlibException('invalid entry in ' + 'wheel: %r' % u_arcname) + zf.extract(zinfo, workdir) + path = os.path.join(workdir, convert_path(u_arcname)) + path_map[u_arcname] = path + + # Remember the version. + original_version, _ = get_version(path_map, info_dir) + # Files extracted. Call the modifier. + modified = modifier(path_map, **kwargs) + if modified: + # Something changed - need to build a new wheel. + current_version, path = get_version(path_map, info_dir) + if current_version and (current_version == original_version): + # Add or update local version to signify changes. + update_version(current_version, path) + # Decide where the new wheel goes. + if dest_dir is None: + fd, newpath = tempfile.mkstemp(suffix='.whl', + prefix='wheel-update-', + dir=workdir) + os.close(fd) + else: + if not os.path.isdir(dest_dir): + raise DistlibException('Not a directory: %r' % dest_dir) + newpath = os.path.join(dest_dir, self.filename) + archive_paths = list(path_map.items()) + distinfo = os.path.join(workdir, info_dir) + info = distinfo, info_dir + self.write_records(info, workdir, archive_paths) + self.build_zip(newpath, archive_paths) + if dest_dir is None: + shutil.copyfile(newpath, pathname) + return modified + +def compatible_tags(): + """ + Return (pyver, abi, arch) tuples compatible with this Python. + """ + versions = [VER_SUFFIX] + major = VER_SUFFIX[0] + for minor in range(sys.version_info[1] - 1, - 1, -1): + versions.append(''.join([major, str(minor)])) + + abis = [] + for suffix, _, _ in imp.get_suffixes(): + if suffix.startswith('.abi'): + abis.append(suffix.split('.', 2)[1]) + abis.sort() + if ABI != 'none': + abis.insert(0, ABI) + abis.append('none') + result = [] + + arches = [ARCH] + if sys.platform == 'darwin': + m = re.match(r'(\w+)_(\d+)_(\d+)_(\w+)$', ARCH) + if m: + name, major, minor, arch = m.groups() + minor = int(minor) + matches = [arch] + if arch in ('i386', 'ppc'): + matches.append('fat') + if arch in ('i386', 'ppc', 'x86_64'): + matches.append('fat3') + if arch in ('ppc64', 'x86_64'): + matches.append('fat64') + if arch in ('i386', 'x86_64'): + matches.append('intel') + if arch in ('i386', 'x86_64', 'intel', 'ppc', 'ppc64'): + matches.append('universal') + while minor >= 0: + for match in matches: + s = '%s_%s_%s_%s' % (name, major, minor, match) + if s != ARCH: # already there + arches.append(s) + minor -= 1 + + # Most specific - our Python version, ABI and arch + for abi in abis: + for arch in arches: + result.append((''.join((IMP_PREFIX, versions[0])), abi, arch)) + + # where no ABI / arch dependency, but IMP_PREFIX dependency + for i, version in enumerate(versions): + result.append((''.join((IMP_PREFIX, version)), 'none', 'any')) + if i == 0: + result.append((''.join((IMP_PREFIX, version[0])), 'none', 'any')) + + # no IMP_PREFIX, ABI or arch dependency + for i, version in enumerate(versions): + result.append((''.join(('py', version)), 'none', 'any')) + if i == 0: + result.append((''.join(('py', version[0])), 'none', 'any')) + return set(result) + + +COMPATIBLE_TAGS = compatible_tags() + +del compatible_tags + + +def is_compatible(wheel, tags=None): + if not isinstance(wheel, Wheel): + wheel = Wheel(wheel) # assume it's a filename + result = False + if tags is None: + tags = COMPATIBLE_TAGS + for ver, abi, arch in tags: + if ver in wheel.pyver and abi in wheel.abi and arch in wheel.arch: + result = True + break + return result diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distro.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distro.py new file mode 100644 index 0000000..3306163 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/distro.py @@ -0,0 +1,1216 @@ +# Copyright 2015,2016,2017 Nir Cohen +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +""" +The ``distro`` package (``distro`` stands for Linux Distribution) provides +information about the Linux distribution it runs on, such as a reliable +machine-readable distro ID, or version information. + +It is the recommended replacement for Python's original +:py:func:`platform.linux_distribution` function, but it provides much more +functionality. An alternative implementation became necessary because Python +3.5 deprecated this function, and Python 3.8 will remove it altogether. +Its predecessor function :py:func:`platform.dist` was already +deprecated since Python 2.6 and will also be removed in Python 3.8. +Still, there are many cases in which access to OS distribution information +is needed. See `Python issue 1322 <https://bugs.python.org/issue1322>`_ for +more information. +""" + +import os +import re +import sys +import json +import shlex +import logging +import argparse +import subprocess + + +_UNIXCONFDIR = os.environ.get('UNIXCONFDIR', '/etc') +_OS_RELEASE_BASENAME = 'os-release' + +#: Translation table for normalizing the "ID" attribute defined in os-release +#: files, for use by the :func:`distro.id` method. +#: +#: * Key: Value as defined in the os-release file, translated to lower case, +#: with blanks translated to underscores. +#: +#: * Value: Normalized value. +NORMALIZED_OS_ID = { + 'ol': 'oracle', # Oracle Enterprise Linux +} + +#: Translation table for normalizing the "Distributor ID" attribute returned by +#: the lsb_release command, for use by the :func:`distro.id` method. +#: +#: * Key: Value as returned by the lsb_release command, translated to lower +#: case, with blanks translated to underscores. +#: +#: * Value: Normalized value. +NORMALIZED_LSB_ID = { + 'enterpriseenterprise': 'oracle', # Oracle Enterprise Linux + 'redhatenterpriseworkstation': 'rhel', # RHEL 6, 7 Workstation + 'redhatenterpriseserver': 'rhel', # RHEL 6, 7 Server +} + +#: Translation table for normalizing the distro ID derived from the file name +#: of distro release files, for use by the :func:`distro.id` method. +#: +#: * Key: Value as derived from the file name of a distro release file, +#: translated to lower case, with blanks translated to underscores. +#: +#: * Value: Normalized value. +NORMALIZED_DISTRO_ID = { + 'redhat': 'rhel', # RHEL 6.x, 7.x +} + +# Pattern for content of distro release file (reversed) +_DISTRO_RELEASE_CONTENT_REVERSED_PATTERN = re.compile( + r'(?:[^)]*\)(.*)\()? *(?:STL )?([\d.+\-a-z]*\d) *(?:esaeler *)?(.+)') + +# Pattern for base file name of distro release file +_DISTRO_RELEASE_BASENAME_PATTERN = re.compile( + r'(\w+)[-_](release|version)$') + +# Base file names to be ignored when searching for distro release file +_DISTRO_RELEASE_IGNORE_BASENAMES = ( + 'debian_version', + 'lsb-release', + 'oem-release', + _OS_RELEASE_BASENAME, + 'system-release' +) + + +def linux_distribution(full_distribution_name=True): + """ + Return information about the current OS distribution as a tuple + ``(id_name, version, codename)`` with items as follows: + + * ``id_name``: If *full_distribution_name* is false, the result of + :func:`distro.id`. Otherwise, the result of :func:`distro.name`. + + * ``version``: The result of :func:`distro.version`. + + * ``codename``: The result of :func:`distro.codename`. + + The interface of this function is compatible with the original + :py:func:`platform.linux_distribution` function, supporting a subset of + its parameters. + + The data it returns may not exactly be the same, because it uses more data + sources than the original function, and that may lead to different data if + the OS distribution is not consistent across multiple data sources it + provides (there are indeed such distributions ...). + + Another reason for differences is the fact that the :func:`distro.id` + method normalizes the distro ID string to a reliable machine-readable value + for a number of popular OS distributions. + """ + return _distro.linux_distribution(full_distribution_name) + + +def id(): + """ + Return the distro ID of the current distribution, as a + machine-readable string. + + For a number of OS distributions, the returned distro ID value is + *reliable*, in the sense that it is documented and that it does not change + across releases of the distribution. + + This package maintains the following reliable distro ID values: + + ============== ========================================= + Distro ID Distribution + ============== ========================================= + "ubuntu" Ubuntu + "debian" Debian + "rhel" RedHat Enterprise Linux + "centos" CentOS + "fedora" Fedora + "sles" SUSE Linux Enterprise Server + "opensuse" openSUSE + "amazon" Amazon Linux + "arch" Arch Linux + "cloudlinux" CloudLinux OS + "exherbo" Exherbo Linux + "gentoo" GenToo Linux + "ibm_powerkvm" IBM PowerKVM + "kvmibm" KVM for IBM z Systems + "linuxmint" Linux Mint + "mageia" Mageia + "mandriva" Mandriva Linux + "parallels" Parallels + "pidora" Pidora + "raspbian" Raspbian + "oracle" Oracle Linux (and Oracle Enterprise Linux) + "scientific" Scientific Linux + "slackware" Slackware + "xenserver" XenServer + "openbsd" OpenBSD + "netbsd" NetBSD + "freebsd" FreeBSD + ============== ========================================= + + If you have a need to get distros for reliable IDs added into this set, + or if you find that the :func:`distro.id` function returns a different + distro ID for one of the listed distros, please create an issue in the + `distro issue tracker`_. + + **Lookup hierarchy and transformations:** + + First, the ID is obtained from the following sources, in the specified + order. The first available and non-empty value is used: + + * the value of the "ID" attribute of the os-release file, + + * the value of the "Distributor ID" attribute returned by the lsb_release + command, + + * the first part of the file name of the distro release file, + + The so determined ID value then passes the following transformations, + before it is returned by this method: + + * it is translated to lower case, + + * blanks (which should not be there anyway) are translated to underscores, + + * a normalization of the ID is performed, based upon + `normalization tables`_. The purpose of this normalization is to ensure + that the ID is as reliable as possible, even across incompatible changes + in the OS distributions. A common reason for an incompatible change is + the addition of an os-release file, or the addition of the lsb_release + command, with ID values that differ from what was previously determined + from the distro release file name. + """ + return _distro.id() + + +def name(pretty=False): + """ + Return the name of the current OS distribution, as a human-readable + string. + + If *pretty* is false, the name is returned without version or codename. + (e.g. "CentOS Linux") + + If *pretty* is true, the version and codename are appended. + (e.g. "CentOS Linux 7.1.1503 (Core)") + + **Lookup hierarchy:** + + The name is obtained from the following sources, in the specified order. + The first available and non-empty value is used: + + * If *pretty* is false: + + - the value of the "NAME" attribute of the os-release file, + + - the value of the "Distributor ID" attribute returned by the lsb_release + command, + + - the value of the "<name>" field of the distro release file. + + * If *pretty* is true: + + - the value of the "PRETTY_NAME" attribute of the os-release file, + + - the value of the "Description" attribute returned by the lsb_release + command, + + - the value of the "<name>" field of the distro release file, appended + with the value of the pretty version ("<version_id>" and "<codename>" + fields) of the distro release file, if available. + """ + return _distro.name(pretty) + + +def version(pretty=False, best=False): + """ + Return the version of the current OS distribution, as a human-readable + string. + + If *pretty* is false, the version is returned without codename (e.g. + "7.0"). + + If *pretty* is true, the codename in parenthesis is appended, if the + codename is non-empty (e.g. "7.0 (Maipo)"). + + Some distributions provide version numbers with different precisions in + the different sources of distribution information. Examining the different + sources in a fixed priority order does not always yield the most precise + version (e.g. for Debian 8.2, or CentOS 7.1). + + The *best* parameter can be used to control the approach for the returned + version: + + If *best* is false, the first non-empty version number in priority order of + the examined sources is returned. + + If *best* is true, the most precise version number out of all examined + sources is returned. + + **Lookup hierarchy:** + + In all cases, the version number is obtained from the following sources. + If *best* is false, this order represents the priority order: + + * the value of the "VERSION_ID" attribute of the os-release file, + * the value of the "Release" attribute returned by the lsb_release + command, + * the version number parsed from the "<version_id>" field of the first line + of the distro release file, + * the version number parsed from the "PRETTY_NAME" attribute of the + os-release file, if it follows the format of the distro release files. + * the version number parsed from the "Description" attribute returned by + the lsb_release command, if it follows the format of the distro release + files. + """ + return _distro.version(pretty, best) + + +def version_parts(best=False): + """ + Return the version of the current OS distribution as a tuple + ``(major, minor, build_number)`` with items as follows: + + * ``major``: The result of :func:`distro.major_version`. + + * ``minor``: The result of :func:`distro.minor_version`. + + * ``build_number``: The result of :func:`distro.build_number`. + + For a description of the *best* parameter, see the :func:`distro.version` + method. + """ + return _distro.version_parts(best) + + +def major_version(best=False): + """ + Return the major version of the current OS distribution, as a string, + if provided. + Otherwise, the empty string is returned. The major version is the first + part of the dot-separated version string. + + For a description of the *best* parameter, see the :func:`distro.version` + method. + """ + return _distro.major_version(best) + + +def minor_version(best=False): + """ + Return the minor version of the current OS distribution, as a string, + if provided. + Otherwise, the empty string is returned. The minor version is the second + part of the dot-separated version string. + + For a description of the *best* parameter, see the :func:`distro.version` + method. + """ + return _distro.minor_version(best) + + +def build_number(best=False): + """ + Return the build number of the current OS distribution, as a string, + if provided. + Otherwise, the empty string is returned. The build number is the third part + of the dot-separated version string. + + For a description of the *best* parameter, see the :func:`distro.version` + method. + """ + return _distro.build_number(best) + + +def like(): + """ + Return a space-separated list of distro IDs of distributions that are + closely related to the current OS distribution in regards to packaging + and programming interfaces, for example distributions the current + distribution is a derivative from. + + **Lookup hierarchy:** + + This information item is only provided by the os-release file. + For details, see the description of the "ID_LIKE" attribute in the + `os-release man page + <http://www.freedesktop.org/software/systemd/man/os-release.html>`_. + """ + return _distro.like() + + +def codename(): + """ + Return the codename for the release of the current OS distribution, + as a string. + + If the distribution does not have a codename, an empty string is returned. + + Note that the returned codename is not always really a codename. For + example, openSUSE returns "x86_64". This function does not handle such + cases in any special way and just returns the string it finds, if any. + + **Lookup hierarchy:** + + * the codename within the "VERSION" attribute of the os-release file, if + provided, + + * the value of the "Codename" attribute returned by the lsb_release + command, + + * the value of the "<codename>" field of the distro release file. + """ + return _distro.codename() + + +def info(pretty=False, best=False): + """ + Return certain machine-readable information items about the current OS + distribution in a dictionary, as shown in the following example: + + .. sourcecode:: python + + { + 'id': 'rhel', + 'version': '7.0', + 'version_parts': { + 'major': '7', + 'minor': '0', + 'build_number': '' + }, + 'like': 'fedora', + 'codename': 'Maipo' + } + + The dictionary structure and keys are always the same, regardless of which + information items are available in the underlying data sources. The values + for the various keys are as follows: + + * ``id``: The result of :func:`distro.id`. + + * ``version``: The result of :func:`distro.version`. + + * ``version_parts -> major``: The result of :func:`distro.major_version`. + + * ``version_parts -> minor``: The result of :func:`distro.minor_version`. + + * ``version_parts -> build_number``: The result of + :func:`distro.build_number`. + + * ``like``: The result of :func:`distro.like`. + + * ``codename``: The result of :func:`distro.codename`. + + For a description of the *pretty* and *best* parameters, see the + :func:`distro.version` method. + """ + return _distro.info(pretty, best) + + +def os_release_info(): + """ + Return a dictionary containing key-value pairs for the information items + from the os-release file data source of the current OS distribution. + + See `os-release file`_ for details about these information items. + """ + return _distro.os_release_info() + + +def lsb_release_info(): + """ + Return a dictionary containing key-value pairs for the information items + from the lsb_release command data source of the current OS distribution. + + See `lsb_release command output`_ for details about these information + items. + """ + return _distro.lsb_release_info() + + +def distro_release_info(): + """ + Return a dictionary containing key-value pairs for the information items + from the distro release file data source of the current OS distribution. + + See `distro release file`_ for details about these information items. + """ + return _distro.distro_release_info() + + +def uname_info(): + """ + Return a dictionary containing key-value pairs for the information items + from the distro release file data source of the current OS distribution. + """ + return _distro.uname_info() + + +def os_release_attr(attribute): + """ + Return a single named information item from the os-release file data source + of the current OS distribution. + + Parameters: + + * ``attribute`` (string): Key of the information item. + + Returns: + + * (string): Value of the information item, if the item exists. + The empty string, if the item does not exist. + + See `os-release file`_ for details about these information items. + """ + return _distro.os_release_attr(attribute) + + +def lsb_release_attr(attribute): + """ + Return a single named information item from the lsb_release command output + data source of the current OS distribution. + + Parameters: + + * ``attribute`` (string): Key of the information item. + + Returns: + + * (string): Value of the information item, if the item exists. + The empty string, if the item does not exist. + + See `lsb_release command output`_ for details about these information + items. + """ + return _distro.lsb_release_attr(attribute) + + +def distro_release_attr(attribute): + """ + Return a single named information item from the distro release file + data source of the current OS distribution. + + Parameters: + + * ``attribute`` (string): Key of the information item. + + Returns: + + * (string): Value of the information item, if the item exists. + The empty string, if the item does not exist. + + See `distro release file`_ for details about these information items. + """ + return _distro.distro_release_attr(attribute) + + +def uname_attr(attribute): + """ + Return a single named information item from the distro release file + data source of the current OS distribution. + + Parameters: + + * ``attribute`` (string): Key of the information item. + + Returns: + + * (string): Value of the information item, if the item exists. + The empty string, if the item does not exist. + """ + return _distro.uname_attr(attribute) + + +class cached_property(object): + """A version of @property which caches the value. On access, it calls the + underlying function and sets the value in `__dict__` so future accesses + will not re-call the property. + """ + def __init__(self, f): + self._fname = f.__name__ + self._f = f + + def __get__(self, obj, owner): + assert obj is not None, 'call {} on an instance'.format(self._fname) + ret = obj.__dict__[self._fname] = self._f(obj) + return ret + + +class LinuxDistribution(object): + """ + Provides information about a OS distribution. + + This package creates a private module-global instance of this class with + default initialization arguments, that is used by the + `consolidated accessor functions`_ and `single source accessor functions`_. + By using default initialization arguments, that module-global instance + returns data about the current OS distribution (i.e. the distro this + package runs on). + + Normally, it is not necessary to create additional instances of this class. + However, in situations where control is needed over the exact data sources + that are used, instances of this class can be created with a specific + distro release file, or a specific os-release file, or without invoking the + lsb_release command. + """ + + def __init__(self, + include_lsb=True, + os_release_file='', + distro_release_file='', + include_uname=True): + """ + The initialization method of this class gathers information from the + available data sources, and stores that in private instance attributes. + Subsequent access to the information items uses these private instance + attributes, so that the data sources are read only once. + + Parameters: + + * ``include_lsb`` (bool): Controls whether the + `lsb_release command output`_ is included as a data source. + + If the lsb_release command is not available in the program execution + path, the data source for the lsb_release command will be empty. + + * ``os_release_file`` (string): The path name of the + `os-release file`_ that is to be used as a data source. + + An empty string (the default) will cause the default path name to + be used (see `os-release file`_ for details). + + If the specified or defaulted os-release file does not exist, the + data source for the os-release file will be empty. + + * ``distro_release_file`` (string): The path name of the + `distro release file`_ that is to be used as a data source. + + An empty string (the default) will cause a default search algorithm + to be used (see `distro release file`_ for details). + + If the specified distro release file does not exist, or if no default + distro release file can be found, the data source for the distro + release file will be empty. + + * ``include_name`` (bool): Controls whether uname command output is + included as a data source. If the uname command is not available in + the program execution path the data source for the uname command will + be empty. + + Public instance attributes: + + * ``os_release_file`` (string): The path name of the + `os-release file`_ that is actually used as a data source. The + empty string if no distro release file is used as a data source. + + * ``distro_release_file`` (string): The path name of the + `distro release file`_ that is actually used as a data source. The + empty string if no distro release file is used as a data source. + + * ``include_lsb`` (bool): The result of the ``include_lsb`` parameter. + This controls whether the lsb information will be loaded. + + * ``include_uname`` (bool): The result of the ``include_uname`` + parameter. This controls whether the uname information will + be loaded. + + Raises: + + * :py:exc:`IOError`: Some I/O issue with an os-release file or distro + release file. + + * :py:exc:`subprocess.CalledProcessError`: The lsb_release command had + some issue (other than not being available in the program execution + path). + + * :py:exc:`UnicodeError`: A data source has unexpected characters or + uses an unexpected encoding. + """ + self.os_release_file = os_release_file or \ + os.path.join(_UNIXCONFDIR, _OS_RELEASE_BASENAME) + self.distro_release_file = distro_release_file or '' # updated later + self.include_lsb = include_lsb + self.include_uname = include_uname + + def __repr__(self): + """Return repr of all info + """ + return \ + "LinuxDistribution(" \ + "os_release_file={self.os_release_file!r}, " \ + "distro_release_file={self.distro_release_file!r}, " \ + "include_lsb={self.include_lsb!r}, " \ + "include_uname={self.include_uname!r}, " \ + "_os_release_info={self._os_release_info!r}, " \ + "_lsb_release_info={self._lsb_release_info!r}, " \ + "_distro_release_info={self._distro_release_info!r}, " \ + "_uname_info={self._uname_info!r})".format( + self=self) + + def linux_distribution(self, full_distribution_name=True): + """ + Return information about the OS distribution that is compatible + with Python's :func:`platform.linux_distribution`, supporting a subset + of its parameters. + + For details, see :func:`distro.linux_distribution`. + """ + return ( + self.name() if full_distribution_name else self.id(), + self.version(), + self.codename() + ) + + def id(self): + """Return the distro ID of the OS distribution, as a string. + + For details, see :func:`distro.id`. + """ + def normalize(distro_id, table): + distro_id = distro_id.lower().replace(' ', '_') + return table.get(distro_id, distro_id) + + distro_id = self.os_release_attr('id') + if distro_id: + return normalize(distro_id, NORMALIZED_OS_ID) + + distro_id = self.lsb_release_attr('distributor_id') + if distro_id: + return normalize(distro_id, NORMALIZED_LSB_ID) + + distro_id = self.distro_release_attr('id') + if distro_id: + return normalize(distro_id, NORMALIZED_DISTRO_ID) + + distro_id = self.uname_attr('id') + if distro_id: + return normalize(distro_id, NORMALIZED_DISTRO_ID) + + return '' + + def name(self, pretty=False): + """ + Return the name of the OS distribution, as a string. + + For details, see :func:`distro.name`. + """ + name = self.os_release_attr('name') \ + or self.lsb_release_attr('distributor_id') \ + or self.distro_release_attr('name') \ + or self.uname_attr('name') + if pretty: + name = self.os_release_attr('pretty_name') \ + or self.lsb_release_attr('description') + if not name: + name = self.distro_release_attr('name') \ + or self.uname_attr('name') + version = self.version(pretty=True) + if version: + name = name + ' ' + version + return name or '' + + def version(self, pretty=False, best=False): + """ + Return the version of the OS distribution, as a string. + + For details, see :func:`distro.version`. + """ + versions = [ + self.os_release_attr('version_id'), + self.lsb_release_attr('release'), + self.distro_release_attr('version_id'), + self._parse_distro_release_content( + self.os_release_attr('pretty_name')).get('version_id', ''), + self._parse_distro_release_content( + self.lsb_release_attr('description')).get('version_id', ''), + self.uname_attr('release') + ] + version = '' + if best: + # This algorithm uses the last version in priority order that has + # the best precision. If the versions are not in conflict, that + # does not matter; otherwise, using the last one instead of the + # first one might be considered a surprise. + for v in versions: + if v.count(".") > version.count(".") or version == '': + version = v + else: + for v in versions: + if v != '': + version = v + break + if pretty and version and self.codename(): + version = u'{0} ({1})'.format(version, self.codename()) + return version + + def version_parts(self, best=False): + """ + Return the version of the OS distribution, as a tuple of version + numbers. + + For details, see :func:`distro.version_parts`. + """ + version_str = self.version(best=best) + if version_str: + version_regex = re.compile(r'(\d+)\.?(\d+)?\.?(\d+)?') + matches = version_regex.match(version_str) + if matches: + major, minor, build_number = matches.groups() + return major, minor or '', build_number or '' + return '', '', '' + + def major_version(self, best=False): + """ + Return the major version number of the current distribution. + + For details, see :func:`distro.major_version`. + """ + return self.version_parts(best)[0] + + def minor_version(self, best=False): + """ + Return the minor version number of the current distribution. + + For details, see :func:`distro.minor_version`. + """ + return self.version_parts(best)[1] + + def build_number(self, best=False): + """ + Return the build number of the current distribution. + + For details, see :func:`distro.build_number`. + """ + return self.version_parts(best)[2] + + def like(self): + """ + Return the IDs of distributions that are like the OS distribution. + + For details, see :func:`distro.like`. + """ + return self.os_release_attr('id_like') or '' + + def codename(self): + """ + Return the codename of the OS distribution. + + For details, see :func:`distro.codename`. + """ + try: + # Handle os_release specially since distros might purposefully set + # this to empty string to have no codename + return self._os_release_info['codename'] + except KeyError: + return self.lsb_release_attr('codename') \ + or self.distro_release_attr('codename') \ + or '' + + def info(self, pretty=False, best=False): + """ + Return certain machine-readable information about the OS + distribution. + + For details, see :func:`distro.info`. + """ + return dict( + id=self.id(), + version=self.version(pretty, best), + version_parts=dict( + major=self.major_version(best), + minor=self.minor_version(best), + build_number=self.build_number(best) + ), + like=self.like(), + codename=self.codename(), + ) + + def os_release_info(self): + """ + Return a dictionary containing key-value pairs for the information + items from the os-release file data source of the OS distribution. + + For details, see :func:`distro.os_release_info`. + """ + return self._os_release_info + + def lsb_release_info(self): + """ + Return a dictionary containing key-value pairs for the information + items from the lsb_release command data source of the OS + distribution. + + For details, see :func:`distro.lsb_release_info`. + """ + return self._lsb_release_info + + def distro_release_info(self): + """ + Return a dictionary containing key-value pairs for the information + items from the distro release file data source of the OS + distribution. + + For details, see :func:`distro.distro_release_info`. + """ + return self._distro_release_info + + def uname_info(self): + """ + Return a dictionary containing key-value pairs for the information + items from the uname command data source of the OS distribution. + + For details, see :func:`distro.uname_info`. + """ + return self._uname_info + + def os_release_attr(self, attribute): + """ + Return a single named information item from the os-release file data + source of the OS distribution. + + For details, see :func:`distro.os_release_attr`. + """ + return self._os_release_info.get(attribute, '') + + def lsb_release_attr(self, attribute): + """ + Return a single named information item from the lsb_release command + output data source of the OS distribution. + + For details, see :func:`distro.lsb_release_attr`. + """ + return self._lsb_release_info.get(attribute, '') + + def distro_release_attr(self, attribute): + """ + Return a single named information item from the distro release file + data source of the OS distribution. + + For details, see :func:`distro.distro_release_attr`. + """ + return self._distro_release_info.get(attribute, '') + + def uname_attr(self, attribute): + """ + Return a single named information item from the uname command + output data source of the OS distribution. + + For details, see :func:`distro.uname_release_attr`. + """ + return self._uname_info.get(attribute, '') + + @cached_property + def _os_release_info(self): + """ + Get the information items from the specified os-release file. + + Returns: + A dictionary containing all information items. + """ + if os.path.isfile(self.os_release_file): + with open(self.os_release_file) as release_file: + return self._parse_os_release_content(release_file) + return {} + + @staticmethod + def _parse_os_release_content(lines): + """ + Parse the lines of an os-release file. + + Parameters: + + * lines: Iterable through the lines in the os-release file. + Each line must be a unicode string or a UTF-8 encoded byte + string. + + Returns: + A dictionary containing all information items. + """ + props = {} + lexer = shlex.shlex(lines, posix=True) + lexer.whitespace_split = True + + # The shlex module defines its `wordchars` variable using literals, + # making it dependent on the encoding of the Python source file. + # In Python 2.6 and 2.7, the shlex source file is encoded in + # 'iso-8859-1', and the `wordchars` variable is defined as a byte + # string. This causes a UnicodeDecodeError to be raised when the + # parsed content is a unicode object. The following fix resolves that + # (... but it should be fixed in shlex...): + if sys.version_info[0] == 2 and isinstance(lexer.wordchars, bytes): + lexer.wordchars = lexer.wordchars.decode('iso-8859-1') + + tokens = list(lexer) + for token in tokens: + # At this point, all shell-like parsing has been done (i.e. + # comments processed, quotes and backslash escape sequences + # processed, multi-line values assembled, trailing newlines + # stripped, etc.), so the tokens are now either: + # * variable assignments: var=value + # * commands or their arguments (not allowed in os-release) + if '=' in token: + k, v = token.split('=', 1) + if isinstance(v, bytes): + v = v.decode('utf-8') + props[k.lower()] = v + else: + # Ignore any tokens that are not variable assignments + pass + + if 'version_codename' in props: + # os-release added a version_codename field. Use that in + # preference to anything else Note that some distros purposefully + # do not have code names. They should be setting + # version_codename="" + props['codename'] = props['version_codename'] + elif 'ubuntu_codename' in props: + # Same as above but a non-standard field name used on older Ubuntus + props['codename'] = props['ubuntu_codename'] + elif 'version' in props: + # If there is no version_codename, parse it from the version + codename = re.search(r'(\(\D+\))|,(\s+)?\D+', props['version']) + if codename: + codename = codename.group() + codename = codename.strip('()') + codename = codename.strip(',') + codename = codename.strip() + # codename appears within paranthese. + props['codename'] = codename + + return props + + @cached_property + def _lsb_release_info(self): + """ + Get the information items from the lsb_release command output. + + Returns: + A dictionary containing all information items. + """ + if not self.include_lsb: + return {} + with open(os.devnull, 'w') as devnull: + try: + cmd = ('lsb_release', '-a') + stdout = subprocess.check_output(cmd, stderr=devnull) + except OSError: # Command not found + return {} + content = stdout.decode(sys.getfilesystemencoding()).splitlines() + return self._parse_lsb_release_content(content) + + @staticmethod + def _parse_lsb_release_content(lines): + """ + Parse the output of the lsb_release command. + + Parameters: + + * lines: Iterable through the lines of the lsb_release output. + Each line must be a unicode string or a UTF-8 encoded byte + string. + + Returns: + A dictionary containing all information items. + """ + props = {} + for line in lines: + kv = line.strip('\n').split(':', 1) + if len(kv) != 2: + # Ignore lines without colon. + continue + k, v = kv + props.update({k.replace(' ', '_').lower(): v.strip()}) + return props + + @cached_property + def _uname_info(self): + with open(os.devnull, 'w') as devnull: + try: + cmd = ('uname', '-rs') + stdout = subprocess.check_output(cmd, stderr=devnull) + except OSError: + return {} + content = stdout.decode(sys.getfilesystemencoding()).splitlines() + return self._parse_uname_content(content) + + @staticmethod + def _parse_uname_content(lines): + props = {} + match = re.search(r'^([^\s]+)\s+([\d\.]+)', lines[0].strip()) + if match: + name, version = match.groups() + + # This is to prevent the Linux kernel version from + # appearing as the 'best' version on otherwise + # identifiable distributions. + if name == 'Linux': + return {} + props['id'] = name.lower() + props['name'] = name + props['release'] = version + return props + + @cached_property + def _distro_release_info(self): + """ + Get the information items from the specified distro release file. + + Returns: + A dictionary containing all information items. + """ + if self.distro_release_file: + # If it was specified, we use it and parse what we can, even if + # its file name or content does not match the expected pattern. + distro_info = self._parse_distro_release_file( + self.distro_release_file) + basename = os.path.basename(self.distro_release_file) + # The file name pattern for user-specified distro release files + # is somewhat more tolerant (compared to when searching for the + # file), because we want to use what was specified as best as + # possible. + match = _DISTRO_RELEASE_BASENAME_PATTERN.match(basename) + if 'name' in distro_info \ + and 'cloudlinux' in distro_info['name'].lower(): + distro_info['id'] = 'cloudlinux' + elif match: + distro_info['id'] = match.group(1) + return distro_info + else: + try: + basenames = os.listdir(_UNIXCONFDIR) + # We sort for repeatability in cases where there are multiple + # distro specific files; e.g. CentOS, Oracle, Enterprise all + # containing `redhat-release` on top of their own. + basenames.sort() + except OSError: + # This may occur when /etc is not readable but we can't be + # sure about the *-release files. Check common entries of + # /etc for information. If they turn out to not be there the + # error is handled in `_parse_distro_release_file()`. + basenames = ['SuSE-release', + 'arch-release', + 'base-release', + 'centos-release', + 'fedora-release', + 'gentoo-release', + 'mageia-release', + 'mandrake-release', + 'mandriva-release', + 'mandrivalinux-release', + 'manjaro-release', + 'oracle-release', + 'redhat-release', + 'sl-release', + 'slackware-version'] + for basename in basenames: + if basename in _DISTRO_RELEASE_IGNORE_BASENAMES: + continue + match = _DISTRO_RELEASE_BASENAME_PATTERN.match(basename) + if match: + filepath = os.path.join(_UNIXCONFDIR, basename) + distro_info = self._parse_distro_release_file(filepath) + if 'name' in distro_info: + # The name is always present if the pattern matches + self.distro_release_file = filepath + distro_info['id'] = match.group(1) + if 'cloudlinux' in distro_info['name'].lower(): + distro_info['id'] = 'cloudlinux' + return distro_info + return {} + + def _parse_distro_release_file(self, filepath): + """ + Parse a distro release file. + + Parameters: + + * filepath: Path name of the distro release file. + + Returns: + A dictionary containing all information items. + """ + try: + with open(filepath) as fp: + # Only parse the first line. For instance, on SLES there + # are multiple lines. We don't want them... + return self._parse_distro_release_content(fp.readline()) + except (OSError, IOError): + # Ignore not being able to read a specific, seemingly version + # related file. + # See https://github.com/nir0s/distro/issues/162 + return {} + + @staticmethod + def _parse_distro_release_content(line): + """ + Parse a line from a distro release file. + + Parameters: + * line: Line from the distro release file. Must be a unicode string + or a UTF-8 encoded byte string. + + Returns: + A dictionary containing all information items. + """ + if isinstance(line, bytes): + line = line.decode('utf-8') + matches = _DISTRO_RELEASE_CONTENT_REVERSED_PATTERN.match( + line.strip()[::-1]) + distro_info = {} + if matches: + # regexp ensures non-None + distro_info['name'] = matches.group(3)[::-1] + if matches.group(2): + distro_info['version_id'] = matches.group(2)[::-1] + if matches.group(1): + distro_info['codename'] = matches.group(1)[::-1] + elif line: + distro_info['name'] = line.strip() + return distro_info + + +_distro = LinuxDistribution() + + +def main(): + logger = logging.getLogger(__name__) + logger.setLevel(logging.DEBUG) + logger.addHandler(logging.StreamHandler(sys.stdout)) + + parser = argparse.ArgumentParser(description="OS distro info tool") + parser.add_argument( + '--json', + '-j', + help="Output in machine readable format", + action="store_true") + args = parser.parse_args() + + if args.json: + logger.info(json.dumps(info(), indent=4, sort_keys=True)) + else: + logger.info('Name: %s', name(pretty=True)) + distribution_version = version(pretty=True) + logger.info('Version: %s', distribution_version) + distribution_codename = codename() + logger.info('Codename: %s', distribution_codename) + + +if __name__ == '__main__': + main() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__init__.py new file mode 100644 index 0000000..0491234 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__init__.py @@ -0,0 +1,35 @@ +""" +HTML parsing library based on the `WHATWG HTML specification +<https://whatwg.org/html>`_. The parser is designed to be compatible with +existing HTML found in the wild and implements well-defined error recovery that +is largely compatible with modern desktop web browsers. + +Example usage:: + + from pip._vendor import html5lib + with open("my_document.html", "rb") as f: + tree = html5lib.parse(f) + +For convenience, this module re-exports the following names: + +* :func:`~.html5parser.parse` +* :func:`~.html5parser.parseFragment` +* :class:`~.html5parser.HTMLParser` +* :func:`~.treebuilders.getTreeBuilder` +* :func:`~.treewalkers.getTreeWalker` +* :func:`~.serializer.serialize` +""" + +from __future__ import absolute_import, division, unicode_literals + +from .html5parser import HTMLParser, parse, parseFragment +from .treebuilders import getTreeBuilder +from .treewalkers import getTreeWalker +from .serializer import serialize + +__all__ = ["HTMLParser", "parse", "parseFragment", "getTreeBuilder", + "getTreeWalker", "serialize"] + +# this has to be at the top level, see how setup.py parses this +#: Distribution version number. +__version__ = "1.0.1" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ac0e16fe52565bc4c27fcd5bb3d934baef89da9c GIT binary patch literal 1329 zcmaJ>&5k2A5bpeEI?2o+jW}C#+Mu284AQPN(Xs+0mOTJMB50((IPSK)+pODe+3x%u zcmUplBN7Lmr>~s$1vqelvNH@bgM_10T$SqjzWVF$XR|PX^T%&Llb`xQ@ViqUo*^io z!q=1_XpjW7L%X6=b(3z@OL|p5>30I!qkS=`hRLuRC8KJbjJ<6jPO2~o{e37V)ijy< z`$){H)8rKHV|qeEI-yfKD~8D#Jx$K(*>}PGoc!7ig7EF?>#tBvwBfQqf~T73JxYmT z6e)>p$<X@t?PsgoFOl~&HOqL;Gh(@t;j7Zx+AQOETN1l1BBhJCw3T?h#t~Y<vo0{x zh#N$i;e~{#R-u%kOjR|+NCiV%Zp)DExUr6cN6A$qDdI=`Ef*9Kr&qOL6_eJWEfeC3 zvYfk!Olzf)W|`VBAa8+72#A8{f{Fc8C{!uRv~+~tSye-*6s1~ifv1VW@QWRBFsL!4 zV9R9~A~?BL6{>k1;SG}%z<`R<7P(wsK+(LD%LA#J$!C|<9#fSyj%(z6E}x@IonFon zF(_YpZx_~T#?UACQ6gWhXZbt~-vCCYB%pC7Gxi*kf{cK91JpFTVmpU#e1CE!gxb2= zNm4Nbls`htyph>*{i8>JaqPk|{Q7_YeWOX?SbMKb5M!POasBz$clA*umrB||r(6{a zW>=tpe$@Ztw<Y4;1GihRKJtQIa3c7D>FEBt4&TFi1oK{dMpC0hV;MfSp&e7c;RXh> zJ#Qq>pubpf%QO+@edqX$pYtQ{cHryL&iv0m8P7ZI>0{ntncZ2A6v1$EPe;40)gvdy zPMkR5_FPXu90u3XBD(%&{y{s!ZWb_ZLyYsrHkx6qVe<mra{^unK|Aq-<oW0)f!pcB z(t4P7;!Jl{^q6h<FE5YpP>B$LI>9iru-!^x{7axO9HtY0>bTZ?LoACoM8_~hu66Ov zE-vuRMpp;<asI=iEO&<k7B?@`QZL{XGG4{72v=Mh3jkM(#mmipbKN+j|K4qge+{_R oh%x4pTa2T6-;Q4$NBFhtig7ghA6|4XI#c)Qjyv6;`&WPPH_8m6ZU6uP literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/_ihatexml.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/_ihatexml.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7808728bd70c7d499b778506df4d185e0756b172 GIT binary patch literal 13801 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/_inputstream.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/_inputstream.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..efc876e2f27f7ac9d17171c5902140be247ba59c GIT binary patch literal 21953 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/_tokenizer.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/_tokenizer.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..09a39ec8cc2e12f60f57b971749171f899567898 GIT binary patch literal 39671 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/_utils.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/_utils.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5b70fc38577f0ee5f9372b017a097215b28f20af GIT binary patch literal 3359 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 O_PyD+gK97ly!Agc3Nrox literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/constants.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/constants.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4669996ac91e501df18cf6669c79d8cce8779dc0 GIT binary patch literal 66366 zcmb@P2Y6h?)%PuFi{x%h4<Vx324vF%7)XpQ7jVN3a0;w+SJK+6U9r1z*+61rSynN| zxX}!TV96@9&`Br>*rdQ~?DT9p>6J86oaD{-J2PkQUb!TBpXc-A|DKt-Q_q}p=FHry zdlwEHHh2*K{`|y4u`8#R4Em8og8!Z`A2jHLBxL_lHE57G$SX+>YAjh?(pb8<w6Sb) zS&5{TCPRxuUg_enSLTJhuov;7Ub$D{4fck3L%m_%aBqY+(i`O+<&E}^_Kxw6^^Wt7 z_fGIm^xos0<h|EB*?XT?>7C-8>Ye7D?w#SC>5cKmdgHvaytBP?yee<JHvxK%cdmDy zcfNOlccFKYcd_?=?-K7)?=o+qce!_kccu3M?}OeX?<#MyH^r;=rh3!7>D~<QYVR6v zrZ>x*?alG#de?gMy!qY&Z=tuyyUx4byTM!ReaQQ;_Yv=--i_W(Ud*fUYCX@3dv#vD z*We|*CEijm={0&OFYPsXH+vZ`>*c&=Z<)8;Tj8zr^4`b1TfAGnk9(i+R(Y$v+q^Z~ zZ(AJkTD-MhtGCW;^V+?R?UBXNczHbPb)GQDTVGeIq1*jXryttjhwku08~xCoerS^k zZKl30erT&7+UAGu@<Vs~p?gf|UdrC*hqn8n`|C>UN3AJYT;ccl0dr0IzQYea=!YKi zL!b0R5Bs5=eyGb2b^D=ReyGO}_4=VcKh#g3hSR6PexDxkuNC?EsGs(jA9~ymJ>iEw z<%gd1Lr?jkr~S|~e&|_0RGhQt{Iuu&&<lR((|+hPe&|I%^pYQX*$=(qhd%3vKIeyC z^+T`uq1}FHj~{y74}IPbeZdcX(GPve553`s-t<HN<A?V8p|||dK0j2H+x>ppm;KOJ z{LokZ(AWIX*Zt5p{LnZ3P*D%Q<);<=(6{~2cl^+I{m}RPP*I1z@2CC15B<;&z3qp7 z<cEIjhkoLRe(HyQ=7);f`Ex(5sHea1(|+lPtnP|F{mM^6>(naz+7JE45B=5;y<<YE zyY;iti6KTO#1i~xy$+FosGtA;U^(i;lpN;$&ilRh2k(#GpS*XyKYM@i{_6eBJK+7@ z`-k^W?|;32Z7lHyff7&(%0LK&K?FoWIj8`G!4NPM3<JZ#2rv?i0!M+-;An6RI2IfS zjt3`z6Ty4HN#MQUWbi&v2~Gj0g44k1;0$mk7z4(Fao{X)HaG`Vf$`g~Tr7Q<0M1R6 zESA2U2hNX6ug^PSP@RlMQZ6_o<-$W!E;=OT;(;mN{R89F`~Cqbmv~Q@_$Au%CFHpD zkd(`cDTd<{O?;x3nJ7ITkaGF<p^Hbxg}+yTD_aJ|M?QGeLxZLaT2sROj*iRhd;ok9 zOafPd$!6}4j+c8Iy`Ou(^nT_2+N2zV9EFw~OS$7r=y*aWn9zxY-eW>15jx3)-b?6Y z)AAJRl$JwFj@Nc&-l`W@(!vworwLE>zTp+Tecm(PSG>=8KlC2;p7*{=`ZO@Tegrk0 zLf-qmU(}ZpK9%s#ydQh-c>BHYc;EHDS05$yG&7bNl(<@Qnb<Y;jM9W=`k`6mnC<5n z7@Nbjx&F0l{W9}NpYNwHkQi797S*F+riJVL+}Had$#sKY&csMrTwkVT4!!=NLvnwZ z5+4H6+RXY$u%up@=l5Y?eIJp2kmsY@M=utwxN-3rrl&U%j)59b3p_KsqAzhp9aK=S zXn-aZOQ1_ZQqc%afi!3WH-ikwDss?fuuQQWDp&zlf;{*bxCPt_J`O$sR)N(((ryE5 zK#O86v=yuaZJ-@=C_16*!R=rJxC2O@jo?nO32X*iz*evg+y(9i_kerBePBDdA3Okd zfCs@t;FI8CAZ_miU7#E60zIG?^nrfx2zV4c1|A1bfKP!Z!BgOA@C<ksJO`c!F96XA z>4U^S16~9#0jc+8@Cx`W_#Ai@yaslIJ>YfldGH1BMerr?26z+v57-Od0{g&z@MR!v zd<A?Jd<}eE@eQcpo8ViD0`%M9JK(#D??Jy0egJ+5-UdGcKL$SmKLtMnKL@`6zXZQh z{2KZj@LTW>_#OB?_yhPO_><yY=${pTf&LZz4IBV}2mb*71pf>EwXu|Ssg!l86f0TE zx>U-#RLZ(k%DPm_x>U-#RLZ(k%DPm_x>U-#RLZ(k%DPm_x>U-#RLZ(!!$(o)ZG=aI zqroxYSa6);c&Ok6a3XjQI7uPl_kxqD<8#pWfl6=+I2D`*P6uazGr<@z7K{UDDb9wT z1FFDyFaewk&I9Lz3&4foB5*NyKez;33N8Z^6_-P=09S$!fDeL6;3_Z~OaawkDwqbQ zgBjpza1EFVW`WsY4wwtB1@pjsumCIsi@<f@dT;|+3_is8tsIwnA13}0@KJChxCz8S z4X6bkh=V#%4;m<2l>1U_QK`2CECn)-BxnRFkOocQW{?3{kOR#cUj|(cR)Cct4?YHN zIS3*fDcTht-3mSqJ^@yN)j;H74QK&tK`U4X+CV$#0G(hxxE*W&cYuxHPOu4V23x>Z zunpV=?gsaOd%=BRJGdV_0Cs=}!9(Da;9;;6bb)TL3-o|q&<Fa#Bj8c+7<e2!0X_wu z1W$pd!871l#dFZ-!3&B{Lj|7!FM^lA%ZgW^p9P--uY%XWZm<Wu4nD8=0#xut@Fm3? z&^N*VfW6=?un+79Uj|<RUj@U#*TC1oH^4W+w?F}W8;Bheo_!a54}2f|K=DK9+u%pw z$KWT5pF)2Iehz*CehGdBehq#Dehc0Kzti~dp??5>1b+hWf<J@5fWLyjfdk<0;2+?h z;D5otHkM(B%CJLa*r77)5a%Tz3?d*(-#-T}2Nhs27y^cZVPH5I0Y-vR;3zN}91V^E z$AaUiLwH>c{z&|IZ~{0Hya${F-V06!?*o<K6mTjy4V(_n0B0)3K*xe{;4E-9_5K!m z4yXd-!2}JT3l*FP&IcFJmk&TM1Q&se!TZ4_;8JiIm<TQhSAZ*l<o_U;1g-*;!4y!f zm<pW+rh^&aYQ;6snP3)}t(XIy3$6w8z<jU(ECh?dbwK!YJ-7iZ1|I?+1|OmCb{#Fl zE|p=I%CJji*rhV;QW<us47*f@U9zZy)`JF+087A9kW@56Qy>kRz|9~7vLFYV!7{KM ztN<%P9()Yk0&WE#2cH0|z-n-tVhywftOc!L9cTmXpaXP*^+4>7)U^TJ0XBj=!6wCK z=oYXQYy)>0SU=?n!gqsv48*4^!zPtslPtDF1^0sofcQvt24&c&GHg^CHmVF8Rfdf! z!$y^1qb%J8?E$@@5A=gaz@y+X@Hmk6KLwry;wuT?o(9i=XMxDfbKrUK0{Are43Kn* zzo>W#`ZD++bx2=cQG6CEKGY8A=fJDrHLx4(0k4D4gD-$DD&|4I1SH=ZKzyoO49c)$ zQda!cGVECy_N)whR%YzkDbOzik;SiouY#|EuY+%ZZ-Q@u0uUJznfNvk+xC0tcft3- z_rVXq55e2uN8rccC*Y^xXW-}H7vRH+UqXKcehq#Dehc0KzXMYDAHW~MpTN7|&)_fM zui$Us0Qfuj2lyxWU+}MuA?#WRyT&OnC_~OhK|>%6A|MLNK?N8LhJc}97#I#lfRRAT z9R)^%qroxMFMjN5!pAC(gC0-1os$suErfjwVc$a7H-Y$PA>(I_rY}<0$>4pU5}X1~ z1*d`2!5QF8@=2e@fU#hl;w<Rd;2cmzy&DWd*u4;TPau1W5Oyzw-3wv&EG~dv2rdE_ zgZG0=z@@bF6X<1NBDfq}0p$9X-~-@;V3Oi0>Tfm(VGBdp!jQ3rGTv&^?}rakW-8(B z&}q;IK#M^LI~l@GhOm<%e6|oaGK7r`VIxEMY$5Dp2>TeqK8CQ5A!IUyeGFkAL)ga< zwlRcl3}G8X*v1fY6v8%!u!$jTVzJCkgkzvaA$3R|n=X5+5H>S}&6NE`2)h}=K7`Dk z@^xqfe38B+xc($`30O*4_Ch^`lb{i#6lrJ^xEW+9dkql(U-nPWkd`%&JyQt#8iI!* z>}wIr2@6($l^_p321I{lPxfiTw}Ov@Pk>dV<$?4y>9;3-M99dd$lDsw0@i|7unveF z{vPGT-}xQ!cF+Mjfs9AmSg*Jpx&eqhZB*O|-2^sM$8Vrpfben~xJz+2^d4|8xDSXN z+z%cAJHUehJVf}D;9;;6bb)TL3kaWkK_BQ>JOY*e+)4XCg-Tme_oLu3(xlDD!4u$9 zK;};Dv+P+V|I<L`L-4HPIjHPqWv?fDKsT-zNEg0~e7p!=0xyGCz-Phdz^mXjup5Y7 z_#^an@OkhB@I}R!pl>MNg#HiM3*G|zz<$M-p<e-C1z!VS2j2kS1m6PUSC&D)4ZZ`u z3q+p22fhz}0DcI>uPgzjO2r073_{rDkdYJ7d*R8?z|VpBniY)UUxa@N#ODk{e+`5u zzXk6AksHD96_WM`@JGr%1r;AO3Vj#2J@KCj{{{RN{0$rce+Sa<e*p1OOQGU3hqe4a ziOZh(C1mzy!s4HgfQs)r8~U$}VeEXEafT_&-9AMK8U_&%1?8Xu3<g8MP%sP(2P1%# z9|=ZLX9M&o1KIzEvDFqwLyrN+8c3hQ__kr}zCiZRVeEbwyC25xhq3u#?0uMYyWbvT zXc(Ix#^#63neg|Z(#C1vbnrg%$h9*V??ywztOH@zfG}%7m^C1b&l|@6+q83_0$B&7 zuJK?3I2W8}(q#W0W(^4A`-ZXq78gM;2JZ)#fJ?z;U?R92Tmh~G9{?W&lfYGAGMECY z!BqMxw(~{8)4+7%AA!yQSA%Q7Owy!|Sx_lATj?Caa}C^nK8(!|WAp9&%!e)j3&A3A z9k?Fc02YG}fe!;|@1x*Ga1)4u8c<6+)1h+R199Tw6TL~e4%7pg=LG38mPL$1_IgtH z5~%cZ8hD5JAh49Mv?uvL0&X%0V|T;Y%rI*}7(Y6U{SPCjVb-y*Sp%fZ4Dx;yNZ+#1 zS<swG3!8P+wY!Y;<zNNZq`oD{;!3C>4?YHNQQQjsxZ)E~fuyYhtHEv5A??-y8S5IT zj92*D0@i|7unx2V@ylgCIt;|G3$q@C&Dp>-`mvhw!i(F%25<-12;`hV)*cz#Ca@XE zSa(CW06909Xb@(72(vy2Uxc4w>~@$nB8<Hbvqpr?Il@Bv@qNPgg9pG4#e>j?6rY4X zY+(1XVjpBbel2BXzITEy&<(_o-v#Xfy`ayaj5!mZJ8aHC@1VSlN7j{cAbfokJO)D4 zn}a?M<Xl3+;`7Vco&--Ro`%X9#d_$o;5qO-c!4w-=cmDEz>Bmcb-x5&=9-j$1$-9B z8HL1OHL&M6pCC=J5!^}oYe0Crhq$!=I`};J0{9|nGN)ex;``rd5H@ms8)<Tmu@1Bu zgw2^oC*cl-gf}SU9H`yEj^!=N%h|_oq5FaGTf$!fGTyI(uK_s&k$IM|oR>&g&PeW2 zh&<d2gl+;`fbi}c;F|_=RuyKQ3!8OL!runpA)lNpi5z?ve2;L8LD<O44@i@<l>5OB z@PLLzhJ^QTgCBt(o3K5fdYC+Y;1SSI`cI%w1F2W$TF#&ZF0G5O$kI=NoXzxt9z$(h z>XLeX4t_!SaqyU-HZHpJO9Ok3=EnaJc|@Ln1%3^F1BAElfZu`NgFk>jf<J+G!Jolj zz+b`Nzya`g@DK1$AbX&X8idVSe%Zzdc1+-W{0M8Fg{-+(5H15D<nvBw7(_r6l!FQ| zSTO`Tls?PeRQ$S2hz|q9NqYl20*nNsz)@f{`8Gk12FHM7iEoA;N7+lE$Ac3TCqf19 zQJe&QFE|;z4@kaB#VOEJ4dh-)gmo^$8ftL{ZR{a@rhyHQAv~5oz6Biz&H`tHbKuj5 zp;cf!m;lZtUj}*}IG=vL4!r=r3ePT7dJ*A^xhA}MKlBq&;f3s{MCQLrSokjXPr{c2 z;q#RSa#k2&ZH%zK+VjG1LM5#jkFf4WSa&0=yK<fwVGWhDMw=$rB>g+kYA_YZnkDCq z0?9ue%m7z|YrstUE<BtCW`jB8lewA;u4N1&uRk!5vpzZdi<o^_0y-Zo0AizMUKWw> z576tt^%}l`@C}6j2we>Q6ZAts_$#(~C}<)4QE(%;3B*7Rs3pIg8GM_t2jZX()Pn{f zeOLlyE&el9t|vhwkaO^D1`%_<F6RhC$R||fw~4Um_fH7l4E;MaLw-2}i4e|$9BAg6 z^!+CPnw+J|y`czuHQU$a&=v4XY=gVDlC-?yW6)c`tz7>L^y5HeV-;8pZUbw8@ImTa z3tH*NP^g?w-DMEL7l>f5BWAx=!u1~zZU-Hp6UbV#h4it6ZwDK|9mLN9;|OmAqRXOt zo52>am1`pN+rV9nLHcwzkaajpe}%V8iQlWZ54xTHtT2dRUn6D@_buoS@E~}IIvcsZ zhwvvA4?}kv$T@1noUL6+K9T)yunY8nUeE{nf!JX=KUhKdQ6T4RGPjR|C%~t`li(@v zG<XI)3!Ved8%Q7I964gn*Tf#kncMq7Wq`_A*QvnK_Y!_D?aDp9-_r+~f4Sc%{dk;f zXF%nw?i=vy5yI!ftB0U3ftSH6TpI)ZED(Kp6}$#^1L2A6UF5ptm2|oOI`}-0vpbo; z4Ny04GFLKZGPh@ga|nMCd`a;JRPd&OoOef9+as*!5hKrHzxILs;LG4E;HyCF#@B(I z=Zy!FPs&M}T>B=Fc@?`MYi>Eb5MNkyPHfC~72kt?pL8iJGWkOwdV3Z0M?lW|E;Wc4 zefueCa`q?Zo>zd&{cyzSmE3og`TV(ooW(_0KO<(XJdu9<57%WZzXHDozX87m+ku=D zo(Gk^sQ9sRFKQw2-vc@4D1rV#<1(**0`G!91JTXDg1><SK+X`w#}WH0X8<x+{{a6q zkaPJ6>uQAcG|D<^A$oZO;Zo>_pk*Kg!Ul4GQSPTiu`yBf%c2}w0mQz_nZxshhk&8v zl`}-Ko3@<X7l@ksEH@b%WsQxpzFLfgjsi!4(coxs4E>XH)9(_NyvHi!9?WjS$Ac3H zzY0Ck$g}M8<UB^?TGlvOJERX{3q^;cti@66eH0yu8r}LSdFBJ*!~3AZqvHryf>VI# zR>~mCnr!ompY#~lPKV0cBxTP4Qm@p1GLZVu1Y^Kh%0CDl2hIX#gL6#S-m7RLTtz*i z!|vSro1~3rY_E`BPgu@D#mBBgF4hn~m%Lwro(Hw(+wzQp?2Dr2-jJMi%lWpPbK5iS zDEzRv5PA`~7`$I`3G`BM8JGwz2UjSrgnj^g5KN-JJD^vA$zTeo22;T_FdfVQS8pue z{@h|2{WbJ_GPCj=VOg=|giTKU-y|F&EUSc^j9m=p#d{e|`bI_~k~E8WCv-ND)qOX4 z<*u#VIod{<lgRr;u#5Q9<Q46?1IQ{QQaTrWfb=%#wcAf!Jl4qiJYw^~0w6NE2wVrQ z2RCdlUp$T{s${MfpD@VK4=Mfd34`QWqQz&$MN;JsmON(_4Lso`GyBo_+1}dA2TdD9 z_(pJ3i-c~9pR=ZHag|Ap5w9_+HSzJJPVh?S4;ot=9W>|{@@V+Dvcia1O*Wlu&c$y` zG&ZF(xk9;@SeD2p(y7A8=2W6K?Zt0QCUWsiESa61zi4)IGFe&M5X;1BNvlkx_}|o= ztIXyy@mS+Im6>=`GFBV+Dwij64V4Seo;r2vl=1nKW~7$Ik_oR;s%uIoQaLGU%Z$&T zIX}&{=4|EI3FAnwO=mLk+FWvFrB+4OT&#Y4e*6q~t#b0b%2a%LGLec`##6aOZsox( z&zw3we`&S3RN0(${YfN~@%mV@GS%EzL+{5fPw+7K@@&<4=U;R_U9XF0;;GvBxbgY9 zvzr^^nMAGDPQROzUTRFPvL;SAwJe^=QD-h4V8z(t*cP6B##rIer0k4TZrr(-tf0oL z4yqAGW#U;npRJ6+MD3Vg$7S&Dpi0K)Pdlg%9%`39#Z$`eF%!p(&!2Ztrud2`xEc4x zS58aYyy?2ix<oP#tFyUy%p0E{bA%$5HOy=(4U_BA%_%aTGCS7DxGl>o58Hg@fGh(W zm#S#3n*K7O!pK~VPE<ChT)xU!E|*ErY&^?+|GSLYc(SglHkr;QQuUQ}Ns*7!s&%NQ z_7q*UV;*zmnBrLHA1TuZikT|MPG2x<W~G;oXNAAn<|fgM%BD=ZHl8&N3hOe>wK>!z zJAPcg>Iju)(~a?5gY+<-%=!$^U+iah0}%N(^AqfA<&64NIwPgWTt4ASrncD3fN~3q z>=RMY=^dZH{P4{LvKJM3%o$_7SS~g$JI2lRm_WWjwW7GWhIo<1`AZI;aeSrUyg#Xx zGAYHm7<c%R(!{_b%&l)hg0^R1uKa0JGU=u!1k`J8N+xP!xp<(Sv|5q#4&P{?yH`}E zGe)W4q%l1Ixk#}i*tuqe{H((a-d;Lnn)9aydUS;hzBzSsb6O0HUv2)ZK%U~P{a^CN z>cn9CHJYgypFjJs^&Xs82Q@yB`5=)f)@$-sjy)Bd_kYPhhWx=n{`>mJ=l_lD7-jPL ze`S6`pxZ^>*)dKq@+{gHC~&499#d5{Mx<fPlsS_Z+%UI#%=pULSWz{Hm4S*+sk9YV zRY{Gt>BdH^Wd8I(j%*VP<6(0hRb1G#;P?STaS$*3JZA)IKYX6bu~p*+%<&k;V>@bw zW(E@IFxL6Msk4g7Ix~>5$kpQ59h1h+PFDtpuFiz4{>HTVoE;!8R~A>+z|?47mE9wV z*Aesoo1qP?IH-^Z@l`X9&!6GTh#i~=2{zhlw{J}ICkD8rRryr}#b*Eq{T!pNzy5k= zCl$|_1*v+@)ci?-3SB<CP_V@3&uGXs;@-sLURJylycMz4b%{(?T(lUAm@#NU<*5!V z8AT;<Rp*bY&SY4&)3|4T+WCP#u%=g84){aJ9y$Z#^T9HHPb$ZrF;<p@aoKT)D|2q3 z9bq1Q{|_ZT@NY|~<O@s2;_W6Aac^8@CM|AJGA{Z$K7Zjs6}ZK;$eF`*WI(Cn;2LnQ zM7QEA64{){x+IJ*PS(Nlc<}Jd@-MSGG0>@E^+nz>$+28zEq){uPJ_0cS?Og`I4EU@ zD?C2`o>>X&)f{eUCmnPVFTFTt`N>D>nQ2K}L8i9S@;YnQR2?Ku>DBT14<4x!oS*tc zDwcFPD;KcIFzaHrl1{{z+Y96K=Nz^M*U#~lQ_|wcu@9(B<W3o2;))z8=Jxqs9jG?I zoBDLl@6kcr5$43z3w3$&msKAkyOr5^9DgL8u8hYr$&~@&Pa~by`!Je1^*?vPH$;Ih z9@2-i|BF8O<G%JVnU^KfNqC>djKrHN&pW5Gi9KL_Cf3wYd7ikOqEs<2-6Sq?Wvo7) zs$E$bOV%@mxrWB^`Tt{;=l}n&@`C>_RbChz_=W#Pl~*2q0{?5#9<!h!f#z8I6wtlO zhFF%pnbRqDyMcz(xVekLVweY+s$8sw9bglc;H(Dw_}><-NqcP2ZTTsIrVqCsh)uE$ z%9by_LTr`UlrKxCJ#?UvQ-SgM3j(#+Lj`k&kXzXluWU&0m)vsJFt8qWq=7<p=}hBc zvIKiqRQIA4JEX{Adv{f!p@5>LoQXTAXNRpLXf2f=agI}t*eQRWg3O*O+xS4~!*phO zgKY0J@td0y8M9qCOD6{nnRsQRwe{ok|6!>dASZ$Li_6y)0gn8)Qj<w9cR~{sy2FfN zK>NjF#pbULG|yoGXB+`WYH3Y3Vp=IDRJwR*x;8t0zz)HkXQ{Jfq=ShFR>f&fuyN;C zVb7N$q`qVwwrFtx!Bzdp3>eUEvG6s44p?DuCgR^olUC-dk?QY^BUbhw`*m<t!NY(f zngUrW%x*LwR|AYtaSR8sRL%$OQgcZ8%L9XO-Tv=O2YryDBkNkL%b@1jI7dLn;8jj` zhY;Dygq+ccpA~c#{&W8iuF+q654Yg!FkBg*2`<5Q3!m2Q6xf~xZOwmT$H0059%^t* z|9Lk5t7?j@@%6+Xj}?j|R&%%^{huotdl)e(3Zt@+P1Lyj#etlM8+^cN69&7T!hmvz z8|{(G9lZ58csnq_&+}Ug9&QA?QQWWuR$kfR9K5M=H5Ch}l`w0yln8F!4&Q`7Wqz6e zqLtcAq6tqxJc9qOU##zO)Xf#ipSvIvOK=aMzLGl_<_1EFr7@OFrkAto;f6Ys=v@2! z`PJ%2xfDF8VhK!3Opd#&%qCi0l|v4t22Kk*F6maK6p=d)|FQl=N_J;esdP3l{uR0Z z;uQ6;B{^dXny$mhX+YeLR0EUc#p}44!qGmveQu0!XpN`eT)R~6PI#5s2D$$syUV)7 z3O3E-Zp#l(aVMzCH<kHO344pD%D;t?KQVAGr^?>TsnVIszsJ8;Rhy~OdpTA1#sU}Z z?U1VA{Tcrv``jF@n42(FDSMyBT|C{D^m|do^c<W^?*GW$9W6yOIR==k%ElYH;gw9M z@~62C)Imk7xHVD5{;w*YuFD^HgiQI9#VhoVT>CM_f`N?rWBfzZY*ivfajyzt%b$ck z`nNi&<W@%&GU~35@#`XQl{D=4k==7cuBwJxbxY&9{J+U~b90;n3My@kWtQeg9a3Zd zEI&zaJV?im&<@8P_J)(YJ2N1!@a>d;n?pn@KZ1P112?9?g!oJvI9RFp7%eq0Oa3%p zG~Kc-RUedTw13Z_cqM<j-&0{XU2^^L$1cqla~10}r{Du}jrZ$1Qm%pXbt>*V_gtl` z?tVbAXH};D{JG8kt)HSQ{@W5~9?A=|`UR>M8Oon^*qRT{YI||oA#As!_tMR5GONtJ z3?|Ud=)r@R+i8BL$|Gb-rEM+Q{Aq!HaU5D@d!$xHB_=;Ekjb}DhtGPVKPz4=+YrxI zVJ*CLt!z5;=LD*$iKXhb1|62<mj>NYKeOc5We!CDeRk}n-stvg7_OstH6AxGZd6`c z9ndk;4a<cibnL`~stIJvpM20Y5p&ylJeOQN|K7t~H>|LiPYjG%7#-xt@p1~SmAU>| zzMk##NjW`GlLx9n(O4WdGyTht)=ma9<Q+5JWEM@B9Ut>NpdsnH%X>m#SgQE$(&0wz zu8q`w7&lxTg8Wf|id?Q?&cmpZljr<NhcF|!#EfW8Els7D7rS=y5wi>bv-wkxc-^?7 zV!-l63$1-B+9_RfPSn*!MOb(Dw!>%oE!b7=a4Uk$$|<?!=_>JcvQ?Zr;P9{%#dF+) ztm3pf#S#`Dz#eUJfP(v7u9DRm`_Z`4)R;dyz*j$0euSQF_-o_HgA%g&(+^j$%8oDV zmwVq~bLsg(RV<qy&QmNrqaw!%hNCAPwt#L81M35Wc8&NvkHHy^d|7ra^Q$-&t}>^> zI2Z>f8BOu>CmedgH8$EE!dBTs*sAl!pO-&O;`xV5yx`Ep3&&rWe{W!Te#`bWMYu5- z^Q_4Orq79uD}siZy-0p+puQtzs*<yT0rO=IjJa)-wG~y_^TT}L0g@_vQiwM5RFdel zZSnX(i*ig@yb@e1d{Ocx!jyK+j0sfYkLhsz3G%C!6F$E+JE-FV^_a_!dBJh`4d@VT z(O?&j$T?2S@<9<kq$<hqo<Jw;hEIBFL;0YU^Es*4P7W57qc72bK-r)!1X|Y87X?aN z=ISP`D!_c#51()O3yxUqkS2<Sf}=3PW0xT#SV8_2TMlFh&Y^1~a5>06xAM7N@Bn!% zRt|gp96_mbiPG^vn47+44GHqwbtI58AG{tIrK@RxMix6`hvH{CCBR?T$U#|xqBk&$ zFqF=_4xivJ5V9V+)l9mEyW#c*!ApLx0*hhry0(@dDv1o;s`N08sbIMsgFhtaJ=uM> zl(V7y(OOWC6RMKzaI^U{Wm#U9POxpWdw8=etjg&TgTHYNI>s_Tes-A?dq5$ZQ#sQZ zFg1>4_PoFxF$}nV(B52>%J1ob6NCIQPTmG4kLFncd{EuUSDB4`{-lOnuIaJ~6P7Pu zK7RQH<I|b?3FlpU>7^4^7|}ZQuvagcFe{d8Fh8?q=1)8{&-v$`d+vnnGIpkiUbD4x zD6=$w`k_~^pEXn3zhr{A4#p45zxU8wrv4R;$y9d2xJV%+T`fc!=@Yb!b_?MZ(m<h% zJcK1<Cd|{Ug-EQaDH+cdqO~z|AF>c-L(AqiUWlY?mT-rl5H_+?D9w4GArp~OrHu)Y z1}Ts&gd61+RepFZ#mXEr`(oP2@XYL>!Z4lUIkq}pevqxD(nKy9FO<XzB{hYznnZme zB*zbh(s*MbREI1SN)m-oDqWK)lu&)Pkt3=?M4o?HO3$F_R6X4xTXP{A^E{pl%@#s9 zO);XGT%wlB!?A3FDnm8guq%|yuc<g%Q=d&U>4m{H$#m^fv(+LK3Rx(nxd_^q<4N8~ zE#er@6v{Z=D3tS4pGh}2!6zP5Li!8*L2@DL#d#VtnJw_v8*=g#Fv&>(*Wx@b>lMoD z67i(RF?b<Tm#A;f(D^!CSn6eznZ`oc=pNbhw7gK-a2_}xTmUWv7lDhJQryBqM1Cn; z+CWDWwrn`jh}%*qOEfaeX5}eFc^Da~UQsAb!bLOj(WHH#q7Z6~r<&zA7b}#dV#^BA zR9gF*O51J}%H2_0p_IXwG!?>f=en^_!HE<PA~V&6GMqUk!W_sIqFDq*9)FHl%ff`^ zR>}<I3|q^kgqfRgPDW3<8BJ-9ku)Qq%i%kc*;E+jZ*^xQ?Sbe5HkXBAGKW*;9-Z7O zFAS0B+)P>?%w>jR$=X>WLc?m4iKe-T{=!rumo1D^%QD||)zmZ6B}peu$_Ot}SI6zu z$vm5y<E*Su9{1|wraDYB)5Q}N^Wun2hNoHQ=}p2y1ub)p3xy#zXqzmrPp)igm=~`r zjN)#;mq3s>c1>l?j1O~3Ht*1-R31-aJ~D|Fg^@NUmuALO^|^*Z#nSl7x$^XPwlJ9B ze4fBb(Ox;>1qlp7VQA81oa8NO&gKfEl8MHIJUGKh;*;c<pfFTUsCXKRbKr(tVTg^{ z#x-(X!lR{;jj`-fiisJvmn$U21_yKeH>WliTSkk6n_#YXZ!}?H&wz3xHL*D8p_-!g zn#b9*lXBN1QD$tDayJx%iwncdbKaR{@kvSU9u-FW(X1Sk%@YGt7~YgILtPfPm4<j0 z{rZCZ-cT6Alj7XCoQ#_13Kcdor8!eL%H7|sW=>P`z<#zc(xpwM1PV%uw9=f6WqfJy zQ>s@q!B;9Bnx#)MZx)X#r@g`uvmDQ<s}n^Zn$3Ar;>!}o49cZMuC`$TGRj<Kn=^Gh z(KsJrjTeSzSMp#;<4lf8nni<$7(=^A9)`^pq9{y#91dyVhQeUcB4vAYSt7pts`QG& zU<oWRSqmdqOlFseFwJK<uFa)0g^?={P8pm}ryD1wyt%Q|xGMwtC5uZSDrY%X-RcIa z8_#nW)lHs3u<9lf(L6xitYt9uICV2N!K65Ks~w<jraE8Um<g+HZhoA)$rP!&*(R;J zG4Vxp!v#55-E3Y}H&(`gy2&N0MMmAMNE&s^2GlJVRJYhc>c&Xo%wtjA8V0DFZCurD zc~RXcChBG{8+EfmQ8!N1it47_bLuvroKv^rpq;vDy>>vc+zO{-vE0gHFke)+*g$oQ z8FkAXq;9rSQM46C-7v&f!}x=bqPlrObrTbMu)5V9qHex4`09r1J3!s!F9UpaOBdD6 zJ6PRv1Jo@WR5x7Lpt_l3S6|&$ICWcT)lJ!M)UC#;o7GIz4X0An&8~Sy-40GM>V~(_ z6iXF`88;K-oK7`olELW0c{4M7XkrkqOKq;16B6-ZYBOo1Dbyfx9kO9=DJ?IAM1wLF zl0772VXc*iq%-m%i*ZBq!;GJInO5XSZFTv<_Nr9s!cw&hO9S~KHji=8+y!YfUye(6 znXI`sB#q}QB(2y13X5xbnW>_-gf6*%;%o{ggY2pN)DOC4&__=EaOtfjA1=GK^wzRl zL$`!(DXS~JrKGO(&eEGh^9S_~%KU+h<HCi~@#hx8Hyaxj!R~THtq{g{i{WbF$4Vyi zb09l`MPV5XoUkmGnNXKb;wxn*T)JXH{f(C{%QWUw=hrPcx1nK0K7V8K(u->vGI-_Z z)~6;cn9!7HV!MMG=j7qsb1z=Da@l#!l4x+_GIk>A%mneOFG?nACOApWj&DLxE*IAd zx3KBT!KDl?M0X;Ch7QX7jlhADibBcY10_QblvExl88(0=WG17sq>_MP$?><A<Obcs z%c|w~!IFmtt??OR*-=_3OJ_V`!18!zTxsTylq{6g7TJ*bD=DV+)BOIFl>Td6Br`=W zRLjp)`I#m^)8%IdKkOA5CwKIW*~OK!G>loPU0N8N;4jRQ@nzy1Rq(fMjoI2XYXlx3 zgx(}@(VGh8vF2PFCvl~C%qhHdd}H2-!yk!>H@-4eTL_UoRVZ(4PUaG9JmgR3vhrM= z__pSOH9YKwICtNScU>1FpLnR*2K?T_V5vUaT!V{KD3|p&ol4S_RX|Eq$o0B(Z8Hv% zzie<h*2wCc9XGl#C{ruLox=|uYWDCW!pqnsq%${3`X!QHE`QWhpGkO`izRKQ{4A88 zE9Gj$KCW3PhngKh=6ty}SAJ@2hUOgSXqj0=cuM1uO8#!}pZ^*(C~+d8#3pniak7NY zl%GoZIYoY6XQ~qCO6VrZa;b#o5z16b^i~(L(c|Un3G#E2{Jd9wPL-e0@^iHOd`Id# z^%Q<$Qo&`CHs95f__(C4;O9VDGB@!+Sv^0YSYy+~1L0UxIt!6)(ZqMDWYBA^2TIPg zq1DZju=_R}yUoP*ZEO~a|K0stT5R$vlf3s%Lw2ufF5~Lky_;>c#btiprmud;7Fw(6 zo3`8Z_ANGjjU_EMwQZZF{ktq(-)d^zcc)%{#?qEYO!D4Mt}$2pmKV&0H}1Ci+BewZ zyWW*yz1nMHyIbwW&P|rCU8|KoYA>%hnO|FHV{P_g+Y>h0VJ^P<yd}?>#J$?tj(cq0 z4jn|tR*m1Kbv$Y5s{55{{<i0Ay!UBK+aI#D?Qx}#S=w@&#y2W`%F>?49d94737wlQ zZNJ^pop!4B>3ps=z20|+y|_wSYgO96(_G%ItlMI9wOMxT-QqaD&T`;sllhH%EV=(c z$xSw-v)rlky0+Do`;0BuW2;@`q(O(YPJ6!2#kKhzDor~+ZOiR=!P0d)haFnqIu(?4 z%KEl0o3B;t-RbIo#&q*d&EBQWbtwZ|U$VuzbSArYXmhJIU1zjor&hnq&A<**@9vF; z?6K1F+D0?x*V^s1du^=4#P+GsZFBr-vsaziwb?Q{%)35g+uPP}lkaw=UNrH&I_h3k zlXexDb?a@hmM1LjeadFP>s_P%oi?>?jiqbtRPWpADsQ*xcfDxowmx@3xzwg6pygAh z+I?#dlw4^Wur}eX?IyPS0ZTq<iA~(6X5&FuXNPU1^B$M*vQ22$ne4nz<EnIhpVYWh zBA5RutzeVOV0pH$&ouwWx&tL2wH?tpY;jCdcC@JSY_aBUcel24hbgsht1bMbjjevy zaPoFbRCVsQS(NE5ciM~VZEBybZmpZ>M{K;U-_lN<y44Tc_-f_aV>+s>YJ}B<v{-@L z-D4`>*J_)xUEOVUbf3@B+g%;29gDhbF)M8QT5L=cZGZRPYZ7-qYp>m_CAVyFb=~Ib z>b5!B50qSPi&&GqSLbbq4!lK0x>cp(C7by(wzSKvYTfG0fzH)BHR0=(dpmS;y3~fP zQ&H|x_N-T_YE^U6wZU?=L%G|k^>*E>>1wHWsg3MV%iQJc#e+6q>noOa>3Y+uD$=Ec z>(u(%o$x$s^Y>{#dsTzlpLG1x20OLFb;@>aXNM~G4i)wt&pP(&fLnFIt*%3M+1jIa zt6iDDQ<ng>zN^)|wK$#GqWo^#?CQ5Nu~(JW+O9oo%w+Ac_F|9L=@z$6HzeiR>IdI7 zi?Fh;MQv5T3Vyp&(?>0f+LUE&YJJ)tY?j@{+wHf#scS)7i_O`t%VhhfG{-J-*u4EN zZ~F^2rT1k&<r&Sh!Owk%yVlufuk9+PxL)c~+^$O9?po?|we-H^YH5Gk*3$P$cdhRs zcdcWUUVGf7bShuk)C_g@YacfHIUcns9mQUKQd5d~9&VNm$J-sZy}d?dutRmEW3@K< zgkRx9Hl_U)Qf#p`#bS={PIMf%*D2TadYfA&HuakMea-qBd+)chvB@TGwq%P*+-FsO zkMCD%rcJhp8XW7a?cL!dP*r}F%IqqY@LuPUZ0fUZ+--@9SI=`cstfrlT^;Vwg?@u7 z_8nSlo4QD@)h%{;+G~y4UKQa_Sr)XYvi0ez+^)_^pA$&62JPDDs;5-6Rmt1#*RgG~ zOVi$-10|<Atx-$W;w<eZmB5|WnRxXv%Ph^dLzj(Km7<;7>}9(I?Xj_aPW9Yib){RU zwCizGXs;Tl9lf@@ttv?CbOm0glCWMSV27^6U8?!(bm{8SDOj)7cc_N9I%BOyzC+ov zON~y48o4fIQ<rwPRoU33V_vt)_ODBQx)yD}OLcRd*59JERi|y2u7_5@_UV%Oh-H`> z?7kOm^g&BhVAc9P<mO0)s#Qf^7n3&Um2K5kr%fx}ri|^-4tMAPJJdpUI0iV)^+j8) zPN(WXr^~4Eb``)r9eKN3R&?2D(*`<SL%LdYSSS89RfZPpW9;iRgWjhyztgfniDvnv zV}UxtZI-8d@3wYi^^Uh!>EKs6JK>Z;+iurgS9_aQwN=Gr&3&4%$%^Bi?stuErA%zq zwW`Z{)BCKiwdWC==|0=_hi#vqaJ^KUV0S5d`U)jCTG6>fE8CzVcZZ5lr(=-T?w04R zYMggEmC!-7s;GDAM0KdDv^we}<u22)x2&bxYdx$z&Zpa?i*=73i;8_mzwK+k`matn zR6F}sn>y7_uhOR49zIZVi!FJ-n#y)n7^X%y^v)&R>RiH2sv{lNOWvdAv2&Fx;mpxi z=lE@MyxC%TzxM&ny7dkXY<kL0ik;4Vy1RJH4pNtiXKj{#*UWZTiCZH!SpnPgyv?ZQ z&AOI*tnawbGIx)4A@?dDTGWMX@z<$mY|9Usns)0<x4mrF!nT*+bXNKmn@=VF2^;Hn zJ$%5%ok_L($-Q<5v|Hz*$LXJ1$X*qbUY*)rw}z=~w`pzN>W;Rl!RXd8bnBdVs~gv? zqS38uL$~@)-71FNx)8Ogn0KfJ?N%{wQ;U4NwRXGRDauxrv0k+&y;@JZ>U4YOfs!$H z{9SI6pDmP}Ws@GZM90vhHm6_v)^3;gx1P1Kxk@#!O-)v(?z%cOzFswKgGz|X=PET> z-BxAxK51)f(OTOdanqzDze`8ZqbktjW=Pkn9<`)*YjfMQ`E4o;J-X)Y)b8z4&Tmr% z*`}PmOY7UFKI+DYZO67LN4F_Aw&@bE&04=J-d@vXEob{f5;P}j>z(Xx)y$ph$!%4m zyHyv$tt#p+-&S27wyJ5^s$#QMr(~;&<5m@ettx(7RV=rvU$a#^yH&+&s}5$Xis@Em z!d4Zdt;+0OYVx<LxI1xjyNWGpMYrlex2kw=(RQ{dQ#+j4>STAgc6CADs_L`FQRT-L zorJBbCR<gFwrV|FUbGC}qWsvh-AL@KPPaGd?rQZN2TDF{v+h#4*r8LfN{8HM-LT#2 z6t^j-dsSR|l@q<4wwhke*SpHjc3bZ|&#OePR*CGry;+vK-FlR;%f?(i%DG<M?rXK( zPuc<atFm=l_G@d~trPo}M(@&6yX^Mu4d+CtRJDHE_O(@=ip@IY4&{1>N=t`IPmfAl zzpB_S<^DY^K$jgTIp;vh2W^FIZiJ6I<F517;#yW)u>CG)R8))l@31xWJ6qzKRITdN zrgv)oomx?+PI#vZQmdMWovPh!Dj>Z n1ZuiCi|)%M=CI$eGKbhWCC>{MCm++e%d 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 D70Cr) literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/html5parser.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/html5parser.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d2af9dcd74163490c681375db77c190bcc98626f GIT binary patch literal 95188 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/serializer.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/__pycache__/serializer.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4d6969ac2236a27b846b5c41178a5ffff766acb8 GIT binary patch literal 10837 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 WRmZrIG830lX6j=0``Y)lr~e1FUiuCI literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_ihatexml.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_ihatexml.py new file mode 100644 index 0000000..4c77717 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_ihatexml.py @@ -0,0 +1,288 @@ +from __future__ import absolute_import, division, unicode_literals + +import re +import warnings + +from .constants import DataLossWarning + +baseChar = """ +[#x0041-#x005A] | [#x0061-#x007A] | [#x00C0-#x00D6] | [#x00D8-#x00F6] | +[#x00F8-#x00FF] | [#x0100-#x0131] | [#x0134-#x013E] | [#x0141-#x0148] | +[#x014A-#x017E] | [#x0180-#x01C3] | [#x01CD-#x01F0] | [#x01F4-#x01F5] | +[#x01FA-#x0217] | [#x0250-#x02A8] | [#x02BB-#x02C1] | #x0386 | +[#x0388-#x038A] | #x038C | [#x038E-#x03A1] | [#x03A3-#x03CE] | +[#x03D0-#x03D6] | #x03DA | #x03DC | #x03DE | #x03E0 | [#x03E2-#x03F3] | +[#x0401-#x040C] | [#x040E-#x044F] | [#x0451-#x045C] | [#x045E-#x0481] | +[#x0490-#x04C4] | [#x04C7-#x04C8] | [#x04CB-#x04CC] | [#x04D0-#x04EB] | +[#x04EE-#x04F5] | [#x04F8-#x04F9] | [#x0531-#x0556] | #x0559 | +[#x0561-#x0586] | [#x05D0-#x05EA] | [#x05F0-#x05F2] | [#x0621-#x063A] | +[#x0641-#x064A] | [#x0671-#x06B7] | [#x06BA-#x06BE] | [#x06C0-#x06CE] | +[#x06D0-#x06D3] | #x06D5 | [#x06E5-#x06E6] | [#x0905-#x0939] | #x093D | +[#x0958-#x0961] | [#x0985-#x098C] | [#x098F-#x0990] | [#x0993-#x09A8] | +[#x09AA-#x09B0] | #x09B2 | [#x09B6-#x09B9] | [#x09DC-#x09DD] | +[#x09DF-#x09E1] | [#x09F0-#x09F1] | [#x0A05-#x0A0A] | [#x0A0F-#x0A10] | +[#x0A13-#x0A28] | [#x0A2A-#x0A30] | [#x0A32-#x0A33] | [#x0A35-#x0A36] | +[#x0A38-#x0A39] | [#x0A59-#x0A5C] | #x0A5E | [#x0A72-#x0A74] | +[#x0A85-#x0A8B] | #x0A8D | [#x0A8F-#x0A91] | [#x0A93-#x0AA8] | +[#x0AAA-#x0AB0] | [#x0AB2-#x0AB3] | [#x0AB5-#x0AB9] | #x0ABD | #x0AE0 | +[#x0B05-#x0B0C] | [#x0B0F-#x0B10] | [#x0B13-#x0B28] | [#x0B2A-#x0B30] | +[#x0B32-#x0B33] | [#x0B36-#x0B39] | #x0B3D | [#x0B5C-#x0B5D] | +[#x0B5F-#x0B61] | [#x0B85-#x0B8A] | [#x0B8E-#x0B90] | [#x0B92-#x0B95] | +[#x0B99-#x0B9A] | #x0B9C | [#x0B9E-#x0B9F] | [#x0BA3-#x0BA4] | +[#x0BA8-#x0BAA] | [#x0BAE-#x0BB5] | [#x0BB7-#x0BB9] | [#x0C05-#x0C0C] | +[#x0C0E-#x0C10] | [#x0C12-#x0C28] | [#x0C2A-#x0C33] | [#x0C35-#x0C39] | +[#x0C60-#x0C61] | [#x0C85-#x0C8C] | [#x0C8E-#x0C90] | [#x0C92-#x0CA8] | +[#x0CAA-#x0CB3] | [#x0CB5-#x0CB9] | #x0CDE | [#x0CE0-#x0CE1] | +[#x0D05-#x0D0C] | [#x0D0E-#x0D10] | [#x0D12-#x0D28] | [#x0D2A-#x0D39] | +[#x0D60-#x0D61] | [#x0E01-#x0E2E] | #x0E30 | [#x0E32-#x0E33] | +[#x0E40-#x0E45] | [#x0E81-#x0E82] | #x0E84 | [#x0E87-#x0E88] | #x0E8A | +#x0E8D | [#x0E94-#x0E97] | [#x0E99-#x0E9F] | [#x0EA1-#x0EA3] | #x0EA5 | +#x0EA7 | [#x0EAA-#x0EAB] | [#x0EAD-#x0EAE] | #x0EB0 | [#x0EB2-#x0EB3] | +#x0EBD | [#x0EC0-#x0EC4] | [#x0F40-#x0F47] | [#x0F49-#x0F69] | +[#x10A0-#x10C5] | [#x10D0-#x10F6] | #x1100 | [#x1102-#x1103] | +[#x1105-#x1107] | #x1109 | [#x110B-#x110C] | [#x110E-#x1112] | #x113C | +#x113E | #x1140 | #x114C | #x114E | #x1150 | [#x1154-#x1155] | #x1159 | +[#x115F-#x1161] | #x1163 | #x1165 | #x1167 | #x1169 | [#x116D-#x116E] | +[#x1172-#x1173] | #x1175 | #x119E | #x11A8 | #x11AB | [#x11AE-#x11AF] | +[#x11B7-#x11B8] | #x11BA | [#x11BC-#x11C2] | #x11EB | #x11F0 | #x11F9 | +[#x1E00-#x1E9B] | [#x1EA0-#x1EF9] | [#x1F00-#x1F15] | [#x1F18-#x1F1D] | +[#x1F20-#x1F45] | [#x1F48-#x1F4D] | [#x1F50-#x1F57] | #x1F59 | #x1F5B | +#x1F5D | [#x1F5F-#x1F7D] | [#x1F80-#x1FB4] | [#x1FB6-#x1FBC] | #x1FBE | +[#x1FC2-#x1FC4] | [#x1FC6-#x1FCC] | [#x1FD0-#x1FD3] | [#x1FD6-#x1FDB] | +[#x1FE0-#x1FEC] | [#x1FF2-#x1FF4] | [#x1FF6-#x1FFC] | #x2126 | +[#x212A-#x212B] | #x212E | [#x2180-#x2182] | [#x3041-#x3094] | +[#x30A1-#x30FA] | [#x3105-#x312C] | [#xAC00-#xD7A3]""" + +ideographic = """[#x4E00-#x9FA5] | #x3007 | [#x3021-#x3029]""" + +combiningCharacter = """ +[#x0300-#x0345] | [#x0360-#x0361] | [#x0483-#x0486] | [#x0591-#x05A1] | +[#x05A3-#x05B9] | [#x05BB-#x05BD] | #x05BF | [#x05C1-#x05C2] | #x05C4 | +[#x064B-#x0652] | #x0670 | [#x06D6-#x06DC] | [#x06DD-#x06DF] | +[#x06E0-#x06E4] | [#x06E7-#x06E8] | [#x06EA-#x06ED] | [#x0901-#x0903] | +#x093C | [#x093E-#x094C] | #x094D | [#x0951-#x0954] | [#x0962-#x0963] | +[#x0981-#x0983] | #x09BC | #x09BE | #x09BF | [#x09C0-#x09C4] | +[#x09C7-#x09C8] | [#x09CB-#x09CD] | #x09D7 | [#x09E2-#x09E3] | #x0A02 | +#x0A3C | #x0A3E | #x0A3F | [#x0A40-#x0A42] | [#x0A47-#x0A48] | +[#x0A4B-#x0A4D] | [#x0A70-#x0A71] | [#x0A81-#x0A83] | #x0ABC | +[#x0ABE-#x0AC5] | [#x0AC7-#x0AC9] | [#x0ACB-#x0ACD] | [#x0B01-#x0B03] | +#x0B3C | [#x0B3E-#x0B43] | [#x0B47-#x0B48] | [#x0B4B-#x0B4D] | +[#x0B56-#x0B57] | [#x0B82-#x0B83] | [#x0BBE-#x0BC2] | [#x0BC6-#x0BC8] | +[#x0BCA-#x0BCD] | #x0BD7 | [#x0C01-#x0C03] | [#x0C3E-#x0C44] | +[#x0C46-#x0C48] | [#x0C4A-#x0C4D] | [#x0C55-#x0C56] | [#x0C82-#x0C83] | +[#x0CBE-#x0CC4] | [#x0CC6-#x0CC8] | [#x0CCA-#x0CCD] | [#x0CD5-#x0CD6] | +[#x0D02-#x0D03] | [#x0D3E-#x0D43] | [#x0D46-#x0D48] | [#x0D4A-#x0D4D] | +#x0D57 | #x0E31 | [#x0E34-#x0E3A] | [#x0E47-#x0E4E] | #x0EB1 | +[#x0EB4-#x0EB9] | [#x0EBB-#x0EBC] | [#x0EC8-#x0ECD] | [#x0F18-#x0F19] | +#x0F35 | #x0F37 | #x0F39 | #x0F3E | #x0F3F | [#x0F71-#x0F84] | +[#x0F86-#x0F8B] | [#x0F90-#x0F95] | #x0F97 | [#x0F99-#x0FAD] | +[#x0FB1-#x0FB7] | #x0FB9 | [#x20D0-#x20DC] | #x20E1 | [#x302A-#x302F] | +#x3099 | #x309A""" + +digit = """ +[#x0030-#x0039] | [#x0660-#x0669] | [#x06F0-#x06F9] | [#x0966-#x096F] | +[#x09E6-#x09EF] | [#x0A66-#x0A6F] | [#x0AE6-#x0AEF] | [#x0B66-#x0B6F] | +[#x0BE7-#x0BEF] | [#x0C66-#x0C6F] | [#x0CE6-#x0CEF] | [#x0D66-#x0D6F] | +[#x0E50-#x0E59] | [#x0ED0-#x0ED9] | [#x0F20-#x0F29]""" + +extender = """ +#x00B7 | #x02D0 | #x02D1 | #x0387 | #x0640 | #x0E46 | #x0EC6 | #x3005 | +#[#x3031-#x3035] | [#x309D-#x309E] | [#x30FC-#x30FE]""" + +letter = " | ".join([baseChar, ideographic]) + +# Without the +name = " | ".join([letter, digit, ".", "-", "_", combiningCharacter, + extender]) +nameFirst = " | ".join([letter, "_"]) + +reChar = re.compile(r"#x([\d|A-F]{4,4})") +reCharRange = re.compile(r"\[#x([\d|A-F]{4,4})-#x([\d|A-F]{4,4})\]") + + +def charStringToList(chars): + charRanges = [item.strip() for item in chars.split(" | ")] + rv = [] + for item in charRanges: + foundMatch = False + for regexp in (reChar, reCharRange): + match = regexp.match(item) + if match is not None: + rv.append([hexToInt(item) for item in match.groups()]) + if len(rv[-1]) == 1: + rv[-1] = rv[-1] * 2 + foundMatch = True + break + if not foundMatch: + assert len(item) == 1 + + rv.append([ord(item)] * 2) + rv = normaliseCharList(rv) + return rv + + +def normaliseCharList(charList): + charList = sorted(charList) + for item in charList: + assert item[1] >= item[0] + rv = [] + i = 0 + while i < len(charList): + j = 1 + rv.append(charList[i]) + while i + j < len(charList) and charList[i + j][0] <= rv[-1][1] + 1: + rv[-1][1] = charList[i + j][1] + j += 1 + i += j + return rv + +# We don't really support characters above the BMP :( +max_unicode = int("FFFF", 16) + + +def missingRanges(charList): + rv = [] + if charList[0] != 0: + rv.append([0, charList[0][0] - 1]) + for i, item in enumerate(charList[:-1]): + rv.append([item[1] + 1, charList[i + 1][0] - 1]) + if charList[-1][1] != max_unicode: + rv.append([charList[-1][1] + 1, max_unicode]) + return rv + + +def listToRegexpStr(charList): + rv = [] + for item in charList: + if item[0] == item[1]: + rv.append(escapeRegexp(chr(item[0]))) + else: + rv.append(escapeRegexp(chr(item[0])) + "-" + + escapeRegexp(chr(item[1]))) + return "[%s]" % "".join(rv) + + +def hexToInt(hex_str): + return int(hex_str, 16) + + +def escapeRegexp(string): + specialCharacters = (".", "^", "$", "*", "+", "?", "{", "}", + "[", "]", "|", "(", ")", "-") + for char in specialCharacters: + string = string.replace(char, "\\" + char) + + return string + +# output from the above +nonXmlNameBMPRegexp = re.compile('[\x00-,/:-@\\[-\\^`\\{-\xb6\xb8-\xbf\xd7\xf7\u0132-\u0133\u013f-\u0140\u0149\u017f\u01c4-\u01cc\u01f1-\u01f3\u01f6-\u01f9\u0218-\u024f\u02a9-\u02ba\u02c2-\u02cf\u02d2-\u02ff\u0346-\u035f\u0362-\u0385\u038b\u038d\u03a2\u03cf\u03d7-\u03d9\u03db\u03dd\u03df\u03e1\u03f4-\u0400\u040d\u0450\u045d\u0482\u0487-\u048f\u04c5-\u04c6\u04c9-\u04ca\u04cd-\u04cf\u04ec-\u04ed\u04f6-\u04f7\u04fa-\u0530\u0557-\u0558\u055a-\u0560\u0587-\u0590\u05a2\u05ba\u05be\u05c0\u05c3\u05c5-\u05cf\u05eb-\u05ef\u05f3-\u0620\u063b-\u063f\u0653-\u065f\u066a-\u066f\u06b8-\u06b9\u06bf\u06cf\u06d4\u06e9\u06ee-\u06ef\u06fa-\u0900\u0904\u093a-\u093b\u094e-\u0950\u0955-\u0957\u0964-\u0965\u0970-\u0980\u0984\u098d-\u098e\u0991-\u0992\u09a9\u09b1\u09b3-\u09b5\u09ba-\u09bb\u09bd\u09c5-\u09c6\u09c9-\u09ca\u09ce-\u09d6\u09d8-\u09db\u09de\u09e4-\u09e5\u09f2-\u0a01\u0a03-\u0a04\u0a0b-\u0a0e\u0a11-\u0a12\u0a29\u0a31\u0a34\u0a37\u0a3a-\u0a3b\u0a3d\u0a43-\u0a46\u0a49-\u0a4a\u0a4e-\u0a58\u0a5d\u0a5f-\u0a65\u0a75-\u0a80\u0a84\u0a8c\u0a8e\u0a92\u0aa9\u0ab1\u0ab4\u0aba-\u0abb\u0ac6\u0aca\u0ace-\u0adf\u0ae1-\u0ae5\u0af0-\u0b00\u0b04\u0b0d-\u0b0e\u0b11-\u0b12\u0b29\u0b31\u0b34-\u0b35\u0b3a-\u0b3b\u0b44-\u0b46\u0b49-\u0b4a\u0b4e-\u0b55\u0b58-\u0b5b\u0b5e\u0b62-\u0b65\u0b70-\u0b81\u0b84\u0b8b-\u0b8d\u0b91\u0b96-\u0b98\u0b9b\u0b9d\u0ba0-\u0ba2\u0ba5-\u0ba7\u0bab-\u0bad\u0bb6\u0bba-\u0bbd\u0bc3-\u0bc5\u0bc9\u0bce-\u0bd6\u0bd8-\u0be6\u0bf0-\u0c00\u0c04\u0c0d\u0c11\u0c29\u0c34\u0c3a-\u0c3d\u0c45\u0c49\u0c4e-\u0c54\u0c57-\u0c5f\u0c62-\u0c65\u0c70-\u0c81\u0c84\u0c8d\u0c91\u0ca9\u0cb4\u0cba-\u0cbd\u0cc5\u0cc9\u0cce-\u0cd4\u0cd7-\u0cdd\u0cdf\u0ce2-\u0ce5\u0cf0-\u0d01\u0d04\u0d0d\u0d11\u0d29\u0d3a-\u0d3d\u0d44-\u0d45\u0d49\u0d4e-\u0d56\u0d58-\u0d5f\u0d62-\u0d65\u0d70-\u0e00\u0e2f\u0e3b-\u0e3f\u0e4f\u0e5a-\u0e80\u0e83\u0e85-\u0e86\u0e89\u0e8b-\u0e8c\u0e8e-\u0e93\u0e98\u0ea0\u0ea4\u0ea6\u0ea8-\u0ea9\u0eac\u0eaf\u0eba\u0ebe-\u0ebf\u0ec5\u0ec7\u0ece-\u0ecf\u0eda-\u0f17\u0f1a-\u0f1f\u0f2a-\u0f34\u0f36\u0f38\u0f3a-\u0f3d\u0f48\u0f6a-\u0f70\u0f85\u0f8c-\u0f8f\u0f96\u0f98\u0fae-\u0fb0\u0fb8\u0fba-\u109f\u10c6-\u10cf\u10f7-\u10ff\u1101\u1104\u1108\u110a\u110d\u1113-\u113b\u113d\u113f\u1141-\u114b\u114d\u114f\u1151-\u1153\u1156-\u1158\u115a-\u115e\u1162\u1164\u1166\u1168\u116a-\u116c\u116f-\u1171\u1174\u1176-\u119d\u119f-\u11a7\u11a9-\u11aa\u11ac-\u11ad\u11b0-\u11b6\u11b9\u11bb\u11c3-\u11ea\u11ec-\u11ef\u11f1-\u11f8\u11fa-\u1dff\u1e9c-\u1e9f\u1efa-\u1eff\u1f16-\u1f17\u1f1e-\u1f1f\u1f46-\u1f47\u1f4e-\u1f4f\u1f58\u1f5a\u1f5c\u1f5e\u1f7e-\u1f7f\u1fb5\u1fbd\u1fbf-\u1fc1\u1fc5\u1fcd-\u1fcf\u1fd4-\u1fd5\u1fdc-\u1fdf\u1fed-\u1ff1\u1ff5\u1ffd-\u20cf\u20dd-\u20e0\u20e2-\u2125\u2127-\u2129\u212c-\u212d\u212f-\u217f\u2183-\u3004\u3006\u3008-\u3020\u3030\u3036-\u3040\u3095-\u3098\u309b-\u309c\u309f-\u30a0\u30fb\u30ff-\u3104\u312d-\u4dff\u9fa6-\uabff\ud7a4-\uffff]') # noqa + +nonXmlNameFirstBMPRegexp = re.compile('[\x00-@\\[-\\^`\\{-\xbf\xd7\xf7\u0132-\u0133\u013f-\u0140\u0149\u017f\u01c4-\u01cc\u01f1-\u01f3\u01f6-\u01f9\u0218-\u024f\u02a9-\u02ba\u02c2-\u0385\u0387\u038b\u038d\u03a2\u03cf\u03d7-\u03d9\u03db\u03dd\u03df\u03e1\u03f4-\u0400\u040d\u0450\u045d\u0482-\u048f\u04c5-\u04c6\u04c9-\u04ca\u04cd-\u04cf\u04ec-\u04ed\u04f6-\u04f7\u04fa-\u0530\u0557-\u0558\u055a-\u0560\u0587-\u05cf\u05eb-\u05ef\u05f3-\u0620\u063b-\u0640\u064b-\u0670\u06b8-\u06b9\u06bf\u06cf\u06d4\u06d6-\u06e4\u06e7-\u0904\u093a-\u093c\u093e-\u0957\u0962-\u0984\u098d-\u098e\u0991-\u0992\u09a9\u09b1\u09b3-\u09b5\u09ba-\u09db\u09de\u09e2-\u09ef\u09f2-\u0a04\u0a0b-\u0a0e\u0a11-\u0a12\u0a29\u0a31\u0a34\u0a37\u0a3a-\u0a58\u0a5d\u0a5f-\u0a71\u0a75-\u0a84\u0a8c\u0a8e\u0a92\u0aa9\u0ab1\u0ab4\u0aba-\u0abc\u0abe-\u0adf\u0ae1-\u0b04\u0b0d-\u0b0e\u0b11-\u0b12\u0b29\u0b31\u0b34-\u0b35\u0b3a-\u0b3c\u0b3e-\u0b5b\u0b5e\u0b62-\u0b84\u0b8b-\u0b8d\u0b91\u0b96-\u0b98\u0b9b\u0b9d\u0ba0-\u0ba2\u0ba5-\u0ba7\u0bab-\u0bad\u0bb6\u0bba-\u0c04\u0c0d\u0c11\u0c29\u0c34\u0c3a-\u0c5f\u0c62-\u0c84\u0c8d\u0c91\u0ca9\u0cb4\u0cba-\u0cdd\u0cdf\u0ce2-\u0d04\u0d0d\u0d11\u0d29\u0d3a-\u0d5f\u0d62-\u0e00\u0e2f\u0e31\u0e34-\u0e3f\u0e46-\u0e80\u0e83\u0e85-\u0e86\u0e89\u0e8b-\u0e8c\u0e8e-\u0e93\u0e98\u0ea0\u0ea4\u0ea6\u0ea8-\u0ea9\u0eac\u0eaf\u0eb1\u0eb4-\u0ebc\u0ebe-\u0ebf\u0ec5-\u0f3f\u0f48\u0f6a-\u109f\u10c6-\u10cf\u10f7-\u10ff\u1101\u1104\u1108\u110a\u110d\u1113-\u113b\u113d\u113f\u1141-\u114b\u114d\u114f\u1151-\u1153\u1156-\u1158\u115a-\u115e\u1162\u1164\u1166\u1168\u116a-\u116c\u116f-\u1171\u1174\u1176-\u119d\u119f-\u11a7\u11a9-\u11aa\u11ac-\u11ad\u11b0-\u11b6\u11b9\u11bb\u11c3-\u11ea\u11ec-\u11ef\u11f1-\u11f8\u11fa-\u1dff\u1e9c-\u1e9f\u1efa-\u1eff\u1f16-\u1f17\u1f1e-\u1f1f\u1f46-\u1f47\u1f4e-\u1f4f\u1f58\u1f5a\u1f5c\u1f5e\u1f7e-\u1f7f\u1fb5\u1fbd\u1fbf-\u1fc1\u1fc5\u1fcd-\u1fcf\u1fd4-\u1fd5\u1fdc-\u1fdf\u1fed-\u1ff1\u1ff5\u1ffd-\u2125\u2127-\u2129\u212c-\u212d\u212f-\u217f\u2183-\u3006\u3008-\u3020\u302a-\u3040\u3095-\u30a0\u30fb-\u3104\u312d-\u4dff\u9fa6-\uabff\ud7a4-\uffff]') # noqa + +# Simpler things +nonPubidCharRegexp = re.compile("[^\x20\x0D\x0Aa-zA-Z0-9\\-'()+,./:=?;!*#@$_%]") + + +class InfosetFilter(object): + replacementRegexp = re.compile(r"U[\dA-F]{5,5}") + + def __init__(self, + dropXmlnsLocalName=False, + dropXmlnsAttrNs=False, + preventDoubleDashComments=False, + preventDashAtCommentEnd=False, + replaceFormFeedCharacters=True, + preventSingleQuotePubid=False): + + self.dropXmlnsLocalName = dropXmlnsLocalName + self.dropXmlnsAttrNs = dropXmlnsAttrNs + + self.preventDoubleDashComments = preventDoubleDashComments + self.preventDashAtCommentEnd = preventDashAtCommentEnd + + self.replaceFormFeedCharacters = replaceFormFeedCharacters + + self.preventSingleQuotePubid = preventSingleQuotePubid + + self.replaceCache = {} + + def coerceAttribute(self, name, namespace=None): + if self.dropXmlnsLocalName and name.startswith("xmlns:"): + warnings.warn("Attributes cannot begin with xmlns", DataLossWarning) + return None + elif (self.dropXmlnsAttrNs and + namespace == "http://www.w3.org/2000/xmlns/"): + warnings.warn("Attributes cannot be in the xml namespace", DataLossWarning) + return None + else: + return self.toXmlName(name) + + def coerceElement(self, name): + return self.toXmlName(name) + + def coerceComment(self, data): + if self.preventDoubleDashComments: + while "--" in data: + warnings.warn("Comments cannot contain adjacent dashes", DataLossWarning) + data = data.replace("--", "- -") + if data.endswith("-"): + warnings.warn("Comments cannot end in a dash", DataLossWarning) + data += " " + return data + + def coerceCharacters(self, data): + if self.replaceFormFeedCharacters: + for _ in range(data.count("\x0C")): + warnings.warn("Text cannot contain U+000C", DataLossWarning) + data = data.replace("\x0C", " ") + # Other non-xml characters + return data + + def coercePubid(self, data): + dataOutput = data + for char in nonPubidCharRegexp.findall(data): + warnings.warn("Coercing non-XML pubid", DataLossWarning) + replacement = self.getReplacementCharacter(char) + dataOutput = dataOutput.replace(char, replacement) + if self.preventSingleQuotePubid and dataOutput.find("'") >= 0: + warnings.warn("Pubid cannot contain single quote", DataLossWarning) + dataOutput = dataOutput.replace("'", self.getReplacementCharacter("'")) + return dataOutput + + def toXmlName(self, name): + nameFirst = name[0] + nameRest = name[1:] + m = nonXmlNameFirstBMPRegexp.match(nameFirst) + if m: + warnings.warn("Coercing non-XML name", DataLossWarning) + nameFirstOutput = self.getReplacementCharacter(nameFirst) + else: + nameFirstOutput = nameFirst + + nameRestOutput = nameRest + replaceChars = set(nonXmlNameBMPRegexp.findall(nameRest)) + for char in replaceChars: + warnings.warn("Coercing non-XML name", DataLossWarning) + replacement = self.getReplacementCharacter(char) + nameRestOutput = nameRestOutput.replace(char, replacement) + return nameFirstOutput + nameRestOutput + + def getReplacementCharacter(self, char): + if char in self.replaceCache: + replacement = self.replaceCache[char] + else: + replacement = self.escapeChar(char) + return replacement + + def fromXmlName(self, name): + for item in set(self.replacementRegexp.findall(name)): + name = name.replace(item, self.unescapeChar(item)) + return name + + def escapeChar(self, char): + replacement = "U%05X" % ord(char) + self.replaceCache[char] = replacement + return replacement + + def unescapeChar(self, charcode): + return chr(int(charcode[1:], 16)) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_inputstream.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_inputstream.py new file mode 100644 index 0000000..a65e55f --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_inputstream.py @@ -0,0 +1,923 @@ +from __future__ import absolute_import, division, unicode_literals + +from pip._vendor.six import text_type, binary_type +from pip._vendor.six.moves import http_client, urllib + +import codecs +import re + +from pip._vendor import webencodings + +from .constants import EOF, spaceCharacters, asciiLetters, asciiUppercase +from .constants import _ReparseException +from . import _utils + +from io import StringIO + +try: + from io import BytesIO +except ImportError: + BytesIO = StringIO + +# Non-unicode versions of constants for use in the pre-parser +spaceCharactersBytes = frozenset([item.encode("ascii") for item in spaceCharacters]) +asciiLettersBytes = frozenset([item.encode("ascii") for item in asciiLetters]) +asciiUppercaseBytes = frozenset([item.encode("ascii") for item in asciiUppercase]) +spacesAngleBrackets = spaceCharactersBytes | frozenset([b">", b"<"]) + + +invalid_unicode_no_surrogate = "[\u0001-\u0008\u000B\u000E-\u001F\u007F-\u009F\uFDD0-\uFDEF\uFFFE\uFFFF\U0001FFFE\U0001FFFF\U0002FFFE\U0002FFFF\U0003FFFE\U0003FFFF\U0004FFFE\U0004FFFF\U0005FFFE\U0005FFFF\U0006FFFE\U0006FFFF\U0007FFFE\U0007FFFF\U0008FFFE\U0008FFFF\U0009FFFE\U0009FFFF\U000AFFFE\U000AFFFF\U000BFFFE\U000BFFFF\U000CFFFE\U000CFFFF\U000DFFFE\U000DFFFF\U000EFFFE\U000EFFFF\U000FFFFE\U000FFFFF\U0010FFFE\U0010FFFF]" # noqa + +if _utils.supports_lone_surrogates: + # Use one extra step of indirection and create surrogates with + # eval. Not using this indirection would introduce an illegal + # unicode literal on platforms not supporting such lone + # surrogates. + assert invalid_unicode_no_surrogate[-1] == "]" and invalid_unicode_no_surrogate.count("]") == 1 + invalid_unicode_re = re.compile(invalid_unicode_no_surrogate[:-1] + + eval('"\\uD800-\\uDFFF"') + # pylint:disable=eval-used + "]") +else: + invalid_unicode_re = re.compile(invalid_unicode_no_surrogate) + +non_bmp_invalid_codepoints = set([0x1FFFE, 0x1FFFF, 0x2FFFE, 0x2FFFF, 0x3FFFE, + 0x3FFFF, 0x4FFFE, 0x4FFFF, 0x5FFFE, 0x5FFFF, + 0x6FFFE, 0x6FFFF, 0x7FFFE, 0x7FFFF, 0x8FFFE, + 0x8FFFF, 0x9FFFE, 0x9FFFF, 0xAFFFE, 0xAFFFF, + 0xBFFFE, 0xBFFFF, 0xCFFFE, 0xCFFFF, 0xDFFFE, + 0xDFFFF, 0xEFFFE, 0xEFFFF, 0xFFFFE, 0xFFFFF, + 0x10FFFE, 0x10FFFF]) + +ascii_punctuation_re = re.compile("[\u0009-\u000D\u0020-\u002F\u003A-\u0040\u005C\u005B-\u0060\u007B-\u007E]") + +# Cache for charsUntil() +charsUntilRegEx = {} + + +class BufferedStream(object): + """Buffering for streams that do not have buffering of their own + + The buffer is implemented as a list of chunks on the assumption that + joining many strings will be slow since it is O(n**2) + """ + + def __init__(self, stream): + self.stream = stream + self.buffer = [] + self.position = [-1, 0] # chunk number, offset + + def tell(self): + pos = 0 + for chunk in self.buffer[:self.position[0]]: + pos += len(chunk) + pos += self.position[1] + return pos + + def seek(self, pos): + assert pos <= self._bufferedBytes() + offset = pos + i = 0 + while len(self.buffer[i]) < offset: + offset -= len(self.buffer[i]) + i += 1 + self.position = [i, offset] + + def read(self, bytes): + if not self.buffer: + return self._readStream(bytes) + elif (self.position[0] == len(self.buffer) and + self.position[1] == len(self.buffer[-1])): + return self._readStream(bytes) + else: + return self._readFromBuffer(bytes) + + def _bufferedBytes(self): + return sum([len(item) for item in self.buffer]) + + def _readStream(self, bytes): + data = self.stream.read(bytes) + self.buffer.append(data) + self.position[0] += 1 + self.position[1] = len(data) + return data + + def _readFromBuffer(self, bytes): + remainingBytes = bytes + rv = [] + bufferIndex = self.position[0] + bufferOffset = self.position[1] + while bufferIndex < len(self.buffer) and remainingBytes != 0: + assert remainingBytes > 0 + bufferedData = self.buffer[bufferIndex] + + if remainingBytes <= len(bufferedData) - bufferOffset: + bytesToRead = remainingBytes + self.position = [bufferIndex, bufferOffset + bytesToRead] + else: + bytesToRead = len(bufferedData) - bufferOffset + self.position = [bufferIndex, len(bufferedData)] + bufferIndex += 1 + rv.append(bufferedData[bufferOffset:bufferOffset + bytesToRead]) + remainingBytes -= bytesToRead + + bufferOffset = 0 + + if remainingBytes: + rv.append(self._readStream(remainingBytes)) + + return b"".join(rv) + + +def HTMLInputStream(source, **kwargs): + # Work around Python bug #20007: read(0) closes the connection. + # http://bugs.python.org/issue20007 + if (isinstance(source, http_client.HTTPResponse) or + # Also check for addinfourl wrapping HTTPResponse + (isinstance(source, urllib.response.addbase) and + isinstance(source.fp, http_client.HTTPResponse))): + isUnicode = False + elif hasattr(source, "read"): + isUnicode = isinstance(source.read(0), text_type) + else: + isUnicode = isinstance(source, text_type) + + if isUnicode: + encodings = [x for x in kwargs if x.endswith("_encoding")] + if encodings: + raise TypeError("Cannot set an encoding with a unicode input, set %r" % encodings) + + return HTMLUnicodeInputStream(source, **kwargs) + else: + return HTMLBinaryInputStream(source, **kwargs) + + +class HTMLUnicodeInputStream(object): + """Provides a unicode stream of characters to the HTMLTokenizer. + + This class takes care of character encoding and removing or replacing + incorrect byte-sequences and also provides column and line tracking. + + """ + + _defaultChunkSize = 10240 + + def __init__(self, source): + """Initialises the HTMLInputStream. + + HTMLInputStream(source, [encoding]) -> Normalized stream from source + for use by html5lib. + + source can be either a file-object, local filename or a string. + + The optional encoding parameter must be a string that indicates + the encoding. If specified, that encoding will be used, + regardless of any BOM or later declaration (such as in a meta + element) + + """ + + if not _utils.supports_lone_surrogates: + # Such platforms will have already checked for such + # surrogate errors, so no need to do this checking. + self.reportCharacterErrors = None + elif len("\U0010FFFF") == 1: + self.reportCharacterErrors = self.characterErrorsUCS4 + else: + self.reportCharacterErrors = self.characterErrorsUCS2 + + # List of where new lines occur + self.newLines = [0] + + self.charEncoding = (lookupEncoding("utf-8"), "certain") + self.dataStream = self.openStream(source) + + self.reset() + + def reset(self): + self.chunk = "" + self.chunkSize = 0 + self.chunkOffset = 0 + self.errors = [] + + # number of (complete) lines in previous chunks + self.prevNumLines = 0 + # number of columns in the last line of the previous chunk + self.prevNumCols = 0 + + # Deal with CR LF and surrogates split over chunk boundaries + self._bufferedCharacter = None + + def openStream(self, source): + """Produces a file object from source. + + source can be either a file object, local filename or a string. + + """ + # Already a file object + if hasattr(source, 'read'): + stream = source + else: + stream = StringIO(source) + + return stream + + def _position(self, offset): + chunk = self.chunk + nLines = chunk.count('\n', 0, offset) + positionLine = self.prevNumLines + nLines + lastLinePos = chunk.rfind('\n', 0, offset) + if lastLinePos == -1: + positionColumn = self.prevNumCols + offset + else: + positionColumn = offset - (lastLinePos + 1) + return (positionLine, positionColumn) + + def position(self): + """Returns (line, col) of the current position in the stream.""" + line, col = self._position(self.chunkOffset) + return (line + 1, col) + + def char(self): + """ Read one character from the stream or queue if available. Return + EOF when EOF is reached. + """ + # Read a new chunk from the input stream if necessary + if self.chunkOffset >= self.chunkSize: + if not self.readChunk(): + return EOF + + chunkOffset = self.chunkOffset + char = self.chunk[chunkOffset] + self.chunkOffset = chunkOffset + 1 + + return char + + def readChunk(self, chunkSize=None): + if chunkSize is None: + chunkSize = self._defaultChunkSize + + self.prevNumLines, self.prevNumCols = self._position(self.chunkSize) + + self.chunk = "" + self.chunkSize = 0 + self.chunkOffset = 0 + + data = self.dataStream.read(chunkSize) + + # Deal with CR LF and surrogates broken across chunks + if self._bufferedCharacter: + data = self._bufferedCharacter + data + self._bufferedCharacter = None + elif not data: + # We have no more data, bye-bye stream + return False + + if len(data) > 1: + lastv = ord(data[-1]) + if lastv == 0x0D or 0xD800 <= lastv <= 0xDBFF: + self._bufferedCharacter = data[-1] + data = data[:-1] + + if self.reportCharacterErrors: + self.reportCharacterErrors(data) + + # Replace invalid characters + data = data.replace("\r\n", "\n") + data = data.replace("\r", "\n") + + self.chunk = data + self.chunkSize = len(data) + + return True + + def characterErrorsUCS4(self, data): + for _ in range(len(invalid_unicode_re.findall(data))): + self.errors.append("invalid-codepoint") + + def characterErrorsUCS2(self, data): + # Someone picked the wrong compile option + # You lose + skip = False + for match in invalid_unicode_re.finditer(data): + if skip: + continue + codepoint = ord(match.group()) + pos = match.start() + # Pretty sure there should be endianness issues here + if _utils.isSurrogatePair(data[pos:pos + 2]): + # We have a surrogate pair! + char_val = _utils.surrogatePairToCodepoint(data[pos:pos + 2]) + if char_val in non_bmp_invalid_codepoints: + self.errors.append("invalid-codepoint") + skip = True + elif (codepoint >= 0xD800 and codepoint <= 0xDFFF and + pos == len(data) - 1): + self.errors.append("invalid-codepoint") + else: + skip = False + self.errors.append("invalid-codepoint") + + def charsUntil(self, characters, opposite=False): + """ Returns a string of characters from the stream up to but not + including any character in 'characters' or EOF. 'characters' must be + a container that supports the 'in' method and iteration over its + characters. + """ + + # Use a cache of regexps to find the required characters + try: + chars = charsUntilRegEx[(characters, opposite)] + except KeyError: + if __debug__: + for c in characters: + assert(ord(c) < 128) + regex = "".join(["\\x%02x" % ord(c) for c in characters]) + if not opposite: + regex = "^%s" % regex + chars = charsUntilRegEx[(characters, opposite)] = re.compile("[%s]+" % regex) + + rv = [] + + while True: + # Find the longest matching prefix + m = chars.match(self.chunk, self.chunkOffset) + if m is None: + # If nothing matched, and it wasn't because we ran out of chunk, + # then stop + if self.chunkOffset != self.chunkSize: + break + else: + end = m.end() + # If not the whole chunk matched, return everything + # up to the part that didn't match + if end != self.chunkSize: + rv.append(self.chunk[self.chunkOffset:end]) + self.chunkOffset = end + break + # If the whole remainder of the chunk matched, + # use it all and read the next chunk + rv.append(self.chunk[self.chunkOffset:]) + if not self.readChunk(): + # Reached EOF + break + + r = "".join(rv) + return r + + def unget(self, char): + # Only one character is allowed to be ungotten at once - it must + # be consumed again before any further call to unget + if char is not None: + if self.chunkOffset == 0: + # unget is called quite rarely, so it's a good idea to do + # more work here if it saves a bit of work in the frequently + # called char and charsUntil. + # So, just prepend the ungotten character onto the current + # chunk: + self.chunk = char + self.chunk + self.chunkSize += 1 + else: + self.chunkOffset -= 1 + assert self.chunk[self.chunkOffset] == char + + +class HTMLBinaryInputStream(HTMLUnicodeInputStream): + """Provides a unicode stream of characters to the HTMLTokenizer. + + This class takes care of character encoding and removing or replacing + incorrect byte-sequences and also provides column and line tracking. + + """ + + def __init__(self, source, override_encoding=None, transport_encoding=None, + same_origin_parent_encoding=None, likely_encoding=None, + default_encoding="windows-1252", useChardet=True): + """Initialises the HTMLInputStream. + + HTMLInputStream(source, [encoding]) -> Normalized stream from source + for use by html5lib. + + source can be either a file-object, local filename or a string. + + The optional encoding parameter must be a string that indicates + the encoding. If specified, that encoding will be used, + regardless of any BOM or later declaration (such as in a meta + element) + + """ + # Raw Stream - for unicode objects this will encode to utf-8 and set + # self.charEncoding as appropriate + self.rawStream = self.openStream(source) + + HTMLUnicodeInputStream.__init__(self, self.rawStream) + + # Encoding Information + # Number of bytes to use when looking for a meta element with + # encoding information + self.numBytesMeta = 1024 + # Number of bytes to use when using detecting encoding using chardet + self.numBytesChardet = 100 + # Things from args + self.override_encoding = override_encoding + self.transport_encoding = transport_encoding + self.same_origin_parent_encoding = same_origin_parent_encoding + self.likely_encoding = likely_encoding + self.default_encoding = default_encoding + + # Determine encoding + self.charEncoding = self.determineEncoding(useChardet) + assert self.charEncoding[0] is not None + + # Call superclass + self.reset() + + def reset(self): + self.dataStream = self.charEncoding[0].codec_info.streamreader(self.rawStream, 'replace') + HTMLUnicodeInputStream.reset(self) + + def openStream(self, source): + """Produces a file object from source. + + source can be either a file object, local filename or a string. + + """ + # Already a file object + if hasattr(source, 'read'): + stream = source + else: + stream = BytesIO(source) + + try: + stream.seek(stream.tell()) + except: # pylint:disable=bare-except + stream = BufferedStream(stream) + + return stream + + def determineEncoding(self, chardet=True): + # BOMs take precedence over everything + # This will also read past the BOM if present + charEncoding = self.detectBOM(), "certain" + if charEncoding[0] is not None: + return charEncoding + + # If we've been overriden, we've been overriden + charEncoding = lookupEncoding(self.override_encoding), "certain" + if charEncoding[0] is not None: + return charEncoding + + # Now check the transport layer + charEncoding = lookupEncoding(self.transport_encoding), "certain" + if charEncoding[0] is not None: + return charEncoding + + # Look for meta elements with encoding information + charEncoding = self.detectEncodingMeta(), "tentative" + if charEncoding[0] is not None: + return charEncoding + + # Parent document encoding + charEncoding = lookupEncoding(self.same_origin_parent_encoding), "tentative" + if charEncoding[0] is not None and not charEncoding[0].name.startswith("utf-16"): + return charEncoding + + # "likely" encoding + charEncoding = lookupEncoding(self.likely_encoding), "tentative" + if charEncoding[0] is not None: + return charEncoding + + # Guess with chardet, if available + if chardet: + try: + from pip._vendor.chardet.universaldetector import UniversalDetector + except ImportError: + pass + else: + buffers = [] + detector = UniversalDetector() + while not detector.done: + buffer = self.rawStream.read(self.numBytesChardet) + assert isinstance(buffer, bytes) + if not buffer: + break + buffers.append(buffer) + detector.feed(buffer) + detector.close() + encoding = lookupEncoding(detector.result['encoding']) + self.rawStream.seek(0) + if encoding is not None: + return encoding, "tentative" + + # Try the default encoding + charEncoding = lookupEncoding(self.default_encoding), "tentative" + if charEncoding[0] is not None: + return charEncoding + + # Fallback to html5lib's default if even that hasn't worked + return lookupEncoding("windows-1252"), "tentative" + + def changeEncoding(self, newEncoding): + assert self.charEncoding[1] != "certain" + newEncoding = lookupEncoding(newEncoding) + if newEncoding is None: + return + if newEncoding.name in ("utf-16be", "utf-16le"): + newEncoding = lookupEncoding("utf-8") + assert newEncoding is not None + elif newEncoding == self.charEncoding[0]: + self.charEncoding = (self.charEncoding[0], "certain") + else: + self.rawStream.seek(0) + self.charEncoding = (newEncoding, "certain") + self.reset() + raise _ReparseException("Encoding changed from %s to %s" % (self.charEncoding[0], newEncoding)) + + def detectBOM(self): + """Attempts to detect at BOM at the start of the stream. If + an encoding can be determined from the BOM return the name of the + encoding otherwise return None""" + bomDict = { + codecs.BOM_UTF8: 'utf-8', + codecs.BOM_UTF16_LE: 'utf-16le', codecs.BOM_UTF16_BE: 'utf-16be', + codecs.BOM_UTF32_LE: 'utf-32le', codecs.BOM_UTF32_BE: 'utf-32be' + } + + # Go to beginning of file and read in 4 bytes + string = self.rawStream.read(4) + assert isinstance(string, bytes) + + # Try detecting the BOM using bytes from the string + encoding = bomDict.get(string[:3]) # UTF-8 + seek = 3 + if not encoding: + # Need to detect UTF-32 before UTF-16 + encoding = bomDict.get(string) # UTF-32 + seek = 4 + if not encoding: + encoding = bomDict.get(string[:2]) # UTF-16 + seek = 2 + + # Set the read position past the BOM if one was found, otherwise + # set it to the start of the stream + if encoding: + self.rawStream.seek(seek) + return lookupEncoding(encoding) + else: + self.rawStream.seek(0) + return None + + def detectEncodingMeta(self): + """Report the encoding declared by the meta element + """ + buffer = self.rawStream.read(self.numBytesMeta) + assert isinstance(buffer, bytes) + parser = EncodingParser(buffer) + self.rawStream.seek(0) + encoding = parser.getEncoding() + + if encoding is not None and encoding.name in ("utf-16be", "utf-16le"): + encoding = lookupEncoding("utf-8") + + return encoding + + +class EncodingBytes(bytes): + """String-like object with an associated position and various extra methods + If the position is ever greater than the string length then an exception is + raised""" + def __new__(self, value): + assert isinstance(value, bytes) + return bytes.__new__(self, value.lower()) + + def __init__(self, value): + # pylint:disable=unused-argument + self._position = -1 + + def __iter__(self): + return self + + def __next__(self): + p = self._position = self._position + 1 + if p >= len(self): + raise StopIteration + elif p < 0: + raise TypeError + return self[p:p + 1] + + def next(self): + # Py2 compat + return self.__next__() + + def previous(self): + p = self._position + if p >= len(self): + raise StopIteration + elif p < 0: + raise TypeError + self._position = p = p - 1 + return self[p:p + 1] + + def setPosition(self, position): + if self._position >= len(self): + raise StopIteration + self._position = position + + def getPosition(self): + if self._position >= len(self): + raise StopIteration + if self._position >= 0: + return self._position + else: + return None + + position = property(getPosition, setPosition) + + def getCurrentByte(self): + return self[self.position:self.position + 1] + + currentByte = property(getCurrentByte) + + def skip(self, chars=spaceCharactersBytes): + """Skip past a list of characters""" + p = self.position # use property for the error-checking + while p < len(self): + c = self[p:p + 1] + if c not in chars: + self._position = p + return c + p += 1 + self._position = p + return None + + def skipUntil(self, chars): + p = self.position + while p < len(self): + c = self[p:p + 1] + if c in chars: + self._position = p + return c + p += 1 + self._position = p + return None + + def matchBytes(self, bytes): + """Look for a sequence of bytes at the start of a string. If the bytes + are found return True and advance the position to the byte after the + match. Otherwise return False and leave the position alone""" + p = self.position + data = self[p:p + len(bytes)] + rv = data.startswith(bytes) + if rv: + self.position += len(bytes) + return rv + + def jumpTo(self, bytes): + """Look for the next sequence of bytes matching a given sequence. If + a match is found advance the position to the last byte of the match""" + newPosition = self[self.position:].find(bytes) + if newPosition > -1: + # XXX: This is ugly, but I can't see a nicer way to fix this. + if self._position == -1: + self._position = 0 + self._position += (newPosition + len(bytes) - 1) + return True + else: + raise StopIteration + + +class EncodingParser(object): + """Mini parser for detecting character encoding from meta elements""" + + def __init__(self, data): + """string - the data to work on for encoding detection""" + self.data = EncodingBytes(data) + self.encoding = None + + def getEncoding(self): + methodDispatch = ( + (b"<!--", self.handleComment), + (b"<meta", self.handleMeta), + (b"</", self.handlePossibleEndTag), + (b"<!", self.handleOther), + (b"<?", self.handleOther), + (b"<", self.handlePossibleStartTag)) + for _ in self.data: + keepParsing = True + for key, method in methodDispatch: + if self.data.matchBytes(key): + try: + keepParsing = method() + break + except StopIteration: + keepParsing = False + break + if not keepParsing: + break + + return self.encoding + + def handleComment(self): + """Skip over comments""" + return self.data.jumpTo(b"-->") + + def handleMeta(self): + if self.data.currentByte not in spaceCharactersBytes: + # if we have <meta not followed by a space so just keep going + return True + # We have a valid meta element we want to search for attributes + hasPragma = False + pendingEncoding = None + while True: + # Try to find the next attribute after the current position + attr = self.getAttribute() + if attr is None: + return True + else: + if attr[0] == b"http-equiv": + hasPragma = attr[1] == b"content-type" + if hasPragma and pendingEncoding is not None: + self.encoding = pendingEncoding + return False + elif attr[0] == b"charset": + tentativeEncoding = attr[1] + codec = lookupEncoding(tentativeEncoding) + if codec is not None: + self.encoding = codec + return False + elif attr[0] == b"content": + contentParser = ContentAttrParser(EncodingBytes(attr[1])) + tentativeEncoding = contentParser.parse() + if tentativeEncoding is not None: + codec = lookupEncoding(tentativeEncoding) + if codec is not None: + if hasPragma: + self.encoding = codec + return False + else: + pendingEncoding = codec + + def handlePossibleStartTag(self): + return self.handlePossibleTag(False) + + def handlePossibleEndTag(self): + next(self.data) + return self.handlePossibleTag(True) + + def handlePossibleTag(self, endTag): + data = self.data + if data.currentByte not in asciiLettersBytes: + # If the next byte is not an ascii letter either ignore this + # fragment (possible start tag case) or treat it according to + # handleOther + if endTag: + data.previous() + self.handleOther() + return True + + c = data.skipUntil(spacesAngleBrackets) + if c == b"<": + # return to the first step in the overall "two step" algorithm + # reprocessing the < byte + data.previous() + else: + # Read all attributes + attr = self.getAttribute() + while attr is not None: + attr = self.getAttribute() + return True + + def handleOther(self): + return self.data.jumpTo(b">") + + def getAttribute(self): + """Return a name,value pair for the next attribute in the stream, + if one is found, or None""" + data = self.data + # Step 1 (skip chars) + c = data.skip(spaceCharactersBytes | frozenset([b"/"])) + assert c is None or len(c) == 1 + # Step 2 + if c in (b">", None): + return None + # Step 3 + attrName = [] + attrValue = [] + # Step 4 attribute name + while True: + if c == b"=" and attrName: + break + elif c in spaceCharactersBytes: + # Step 6! + c = data.skip() + break + elif c in (b"/", b">"): + return b"".join(attrName), b"" + elif c in asciiUppercaseBytes: + attrName.append(c.lower()) + elif c is None: + return None + else: + attrName.append(c) + # Step 5 + c = next(data) + # Step 7 + if c != b"=": + data.previous() + return b"".join(attrName), b"" + # Step 8 + next(data) + # Step 9 + c = data.skip() + # Step 10 + if c in (b"'", b'"'): + # 10.1 + quoteChar = c + while True: + # 10.2 + c = next(data) + # 10.3 + if c == quoteChar: + next(data) + return b"".join(attrName), b"".join(attrValue) + # 10.4 + elif c in asciiUppercaseBytes: + attrValue.append(c.lower()) + # 10.5 + else: + attrValue.append(c) + elif c == b">": + return b"".join(attrName), b"" + elif c in asciiUppercaseBytes: + attrValue.append(c.lower()) + elif c is None: + return None + else: + attrValue.append(c) + # Step 11 + while True: + c = next(data) + if c in spacesAngleBrackets: + return b"".join(attrName), b"".join(attrValue) + elif c in asciiUppercaseBytes: + attrValue.append(c.lower()) + elif c is None: + return None + else: + attrValue.append(c) + + +class ContentAttrParser(object): + def __init__(self, data): + assert isinstance(data, bytes) + self.data = data + + def parse(self): + try: + # Check if the attr name is charset + # otherwise return + self.data.jumpTo(b"charset") + self.data.position += 1 + self.data.skip() + if not self.data.currentByte == b"=": + # If there is no = sign keep looking for attrs + return None + self.data.position += 1 + self.data.skip() + # Look for an encoding between matching quote marks + if self.data.currentByte in (b'"', b"'"): + quoteMark = self.data.currentByte + self.data.position += 1 + oldPosition = self.data.position + if self.data.jumpTo(quoteMark): + return self.data[oldPosition:self.data.position] + else: + return None + else: + # Unquoted value + oldPosition = self.data.position + try: + self.data.skipUntil(spaceCharactersBytes) + return self.data[oldPosition:self.data.position] + except StopIteration: + # Return the whole remaining value + return self.data[oldPosition:] + except StopIteration: + return None + + +def lookupEncoding(encoding): + """Return the python codec name corresponding to an encoding or None if the + string doesn't correspond to a valid encoding.""" + if isinstance(encoding, binary_type): + try: + encoding = encoding.decode("ascii") + except UnicodeDecodeError: + return None + + if encoding is not None: + try: + return webencodings.lookup(encoding) + except AttributeError: + return None + else: + return None diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_tokenizer.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_tokenizer.py new file mode 100644 index 0000000..178f6e7 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_tokenizer.py @@ -0,0 +1,1721 @@ +from __future__ import absolute_import, division, unicode_literals + +from pip._vendor.six import unichr as chr + +from collections import deque + +from .constants import spaceCharacters +from .constants import entities +from .constants import asciiLetters, asciiUpper2Lower +from .constants import digits, hexDigits, EOF +from .constants import tokenTypes, tagTokenTypes +from .constants import replacementCharacters + +from ._inputstream import HTMLInputStream + +from ._trie import Trie + +entitiesTrie = Trie(entities) + + +class HTMLTokenizer(object): + """ This class takes care of tokenizing HTML. + + * self.currentToken + Holds the token that is currently being processed. + + * self.state + Holds a reference to the method to be invoked... XXX + + * self.stream + Points to HTMLInputStream object. + """ + + def __init__(self, stream, parser=None, **kwargs): + + self.stream = HTMLInputStream(stream, **kwargs) + self.parser = parser + + # Setup the initial tokenizer state + self.escapeFlag = False + self.lastFourChars = [] + self.state = self.dataState + self.escape = False + + # The current token being created + self.currentToken = None + super(HTMLTokenizer, self).__init__() + + def __iter__(self): + """ This is where the magic happens. + + We do our usually processing through the states and when we have a token + to return we yield the token which pauses processing until the next token + is requested. + """ + self.tokenQueue = deque([]) + # Start processing. When EOF is reached self.state will return False + # instead of True and the loop will terminate. + while self.state(): + while self.stream.errors: + yield {"type": tokenTypes["ParseError"], "data": self.stream.errors.pop(0)} + while self.tokenQueue: + yield self.tokenQueue.popleft() + + def consumeNumberEntity(self, isHex): + """This function returns either U+FFFD or the character based on the + decimal or hexadecimal representation. It also discards ";" if present. + If not present self.tokenQueue.append({"type": tokenTypes["ParseError"]}) is invoked. + """ + + allowed = digits + radix = 10 + if isHex: + allowed = hexDigits + radix = 16 + + charStack = [] + + # Consume all the characters that are in range while making sure we + # don't hit an EOF. + c = self.stream.char() + while c in allowed and c is not EOF: + charStack.append(c) + c = self.stream.char() + + # Convert the set of characters consumed to an int. + charAsInt = int("".join(charStack), radix) + + # Certain characters get replaced with others + if charAsInt in replacementCharacters: + char = replacementCharacters[charAsInt] + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "illegal-codepoint-for-numeric-entity", + "datavars": {"charAsInt": charAsInt}}) + elif ((0xD800 <= charAsInt <= 0xDFFF) or + (charAsInt > 0x10FFFF)): + char = "\uFFFD" + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "illegal-codepoint-for-numeric-entity", + "datavars": {"charAsInt": charAsInt}}) + else: + # Should speed up this check somehow (e.g. move the set to a constant) + if ((0x0001 <= charAsInt <= 0x0008) or + (0x000E <= charAsInt <= 0x001F) or + (0x007F <= charAsInt <= 0x009F) or + (0xFDD0 <= charAsInt <= 0xFDEF) or + charAsInt in frozenset([0x000B, 0xFFFE, 0xFFFF, 0x1FFFE, + 0x1FFFF, 0x2FFFE, 0x2FFFF, 0x3FFFE, + 0x3FFFF, 0x4FFFE, 0x4FFFF, 0x5FFFE, + 0x5FFFF, 0x6FFFE, 0x6FFFF, 0x7FFFE, + 0x7FFFF, 0x8FFFE, 0x8FFFF, 0x9FFFE, + 0x9FFFF, 0xAFFFE, 0xAFFFF, 0xBFFFE, + 0xBFFFF, 0xCFFFE, 0xCFFFF, 0xDFFFE, + 0xDFFFF, 0xEFFFE, 0xEFFFF, 0xFFFFE, + 0xFFFFF, 0x10FFFE, 0x10FFFF])): + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": + "illegal-codepoint-for-numeric-entity", + "datavars": {"charAsInt": charAsInt}}) + try: + # Try/except needed as UCS-2 Python builds' unichar only works + # within the BMP. + char = chr(charAsInt) + except ValueError: + v = charAsInt - 0x10000 + char = chr(0xD800 | (v >> 10)) + chr(0xDC00 | (v & 0x3FF)) + + # Discard the ; if present. Otherwise, put it back on the queue and + # invoke parseError on parser. + if c != ";": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "numeric-entity-without-semicolon"}) + self.stream.unget(c) + + return char + + def consumeEntity(self, allowedChar=None, fromAttribute=False): + # Initialise to the default output for when no entity is matched + output = "&" + + charStack = [self.stream.char()] + if (charStack[0] in spaceCharacters or charStack[0] in (EOF, "<", "&") or + (allowedChar is not None and allowedChar == charStack[0])): + self.stream.unget(charStack[0]) + + elif charStack[0] == "#": + # Read the next character to see if it's hex or decimal + hex = False + charStack.append(self.stream.char()) + if charStack[-1] in ("x", "X"): + hex = True + charStack.append(self.stream.char()) + + # charStack[-1] should be the first digit + if (hex and charStack[-1] in hexDigits) \ + or (not hex and charStack[-1] in digits): + # At least one digit found, so consume the whole number + self.stream.unget(charStack[-1]) + output = self.consumeNumberEntity(hex) + else: + # No digits found + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "expected-numeric-entity"}) + self.stream.unget(charStack.pop()) + output = "&" + "".join(charStack) + + else: + # At this point in the process might have named entity. Entities + # are stored in the global variable "entities". + # + # Consume characters and compare to these to a substring of the + # entity names in the list until the substring no longer matches. + while (charStack[-1] is not EOF): + if not entitiesTrie.has_keys_with_prefix("".join(charStack)): + break + charStack.append(self.stream.char()) + + # At this point we have a string that starts with some characters + # that may match an entity + # Try to find the longest entity the string will match to take care + # of ¬i for instance. + try: + entityName = entitiesTrie.longest_prefix("".join(charStack[:-1])) + entityLength = len(entityName) + except KeyError: + entityName = None + + if entityName is not None: + if entityName[-1] != ";": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "named-entity-without-semicolon"}) + if (entityName[-1] != ";" and fromAttribute and + (charStack[entityLength] in asciiLetters or + charStack[entityLength] in digits or + charStack[entityLength] == "=")): + self.stream.unget(charStack.pop()) + output = "&" + "".join(charStack) + else: + output = entities[entityName] + self.stream.unget(charStack.pop()) + output += "".join(charStack[entityLength:]) + else: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-named-entity"}) + self.stream.unget(charStack.pop()) + output = "&" + "".join(charStack) + + if fromAttribute: + self.currentToken["data"][-1][1] += output + else: + if output in spaceCharacters: + tokenType = "SpaceCharacters" + else: + tokenType = "Characters" + self.tokenQueue.append({"type": tokenTypes[tokenType], "data": output}) + + def processEntityInAttribute(self, allowedChar): + """This method replaces the need for "entityInAttributeValueState". + """ + self.consumeEntity(allowedChar=allowedChar, fromAttribute=True) + + def emitCurrentToken(self): + """This method is a generic handler for emitting the tags. It also sets + the state to "data" because that's what's needed after a token has been + emitted. + """ + token = self.currentToken + # Add token to the queue to be yielded + if (token["type"] in tagTokenTypes): + token["name"] = token["name"].translate(asciiUpper2Lower) + if token["type"] == tokenTypes["EndTag"]: + if token["data"]: + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "attributes-in-end-tag"}) + if token["selfClosing"]: + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "self-closing-flag-on-end-tag"}) + self.tokenQueue.append(token) + self.state = self.dataState + + # Below are the various tokenizer states worked out. + def dataState(self): + data = self.stream.char() + if data == "&": + self.state = self.entityDataState + elif data == "<": + self.state = self.tagOpenState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": "\u0000"}) + elif data is EOF: + # Tokenization ends. + return False + elif data in spaceCharacters: + # Directly after emitting a token you switch back to the "data + # state". At that point spaceCharacters are important so they are + # emitted separately. + self.tokenQueue.append({"type": tokenTypes["SpaceCharacters"], "data": + data + self.stream.charsUntil(spaceCharacters, True)}) + # No need to update lastFourChars here, since the first space will + # have already been appended to lastFourChars and will have broken + # any <!-- or --> sequences + else: + chars = self.stream.charsUntil(("&", "<", "\u0000")) + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": + data + chars}) + return True + + def entityDataState(self): + self.consumeEntity() + self.state = self.dataState + return True + + def rcdataState(self): + data = self.stream.char() + if data == "&": + self.state = self.characterReferenceInRcdata + elif data == "<": + self.state = self.rcdataLessThanSignState + elif data == EOF: + # Tokenization ends. + return False + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": "\uFFFD"}) + elif data in spaceCharacters: + # Directly after emitting a token you switch back to the "data + # state". At that point spaceCharacters are important so they are + # emitted separately. + self.tokenQueue.append({"type": tokenTypes["SpaceCharacters"], "data": + data + self.stream.charsUntil(spaceCharacters, True)}) + # No need to update lastFourChars here, since the first space will + # have already been appended to lastFourChars and will have broken + # any <!-- or --> sequences + else: + chars = self.stream.charsUntil(("&", "<", "\u0000")) + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": + data + chars}) + return True + + def characterReferenceInRcdata(self): + self.consumeEntity() + self.state = self.rcdataState + return True + + def rawtextState(self): + data = self.stream.char() + if data == "<": + self.state = self.rawtextLessThanSignState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": "\uFFFD"}) + elif data == EOF: + # Tokenization ends. + return False + else: + chars = self.stream.charsUntil(("<", "\u0000")) + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": + data + chars}) + return True + + def scriptDataState(self): + data = self.stream.char() + if data == "<": + self.state = self.scriptDataLessThanSignState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": "\uFFFD"}) + elif data == EOF: + # Tokenization ends. + return False + else: + chars = self.stream.charsUntil(("<", "\u0000")) + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": + data + chars}) + return True + + def plaintextState(self): + data = self.stream.char() + if data == EOF: + # Tokenization ends. + return False + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": "\uFFFD"}) + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": + data + self.stream.charsUntil("\u0000")}) + return True + + def tagOpenState(self): + data = self.stream.char() + if data == "!": + self.state = self.markupDeclarationOpenState + elif data == "/": + self.state = self.closeTagOpenState + elif data in asciiLetters: + self.currentToken = {"type": tokenTypes["StartTag"], + "name": data, "data": [], + "selfClosing": False, + "selfClosingAcknowledged": False} + self.state = self.tagNameState + elif data == ">": + # XXX In theory it could be something besides a tag name. But + # do we really care? + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-tag-name-but-got-right-bracket"}) + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<>"}) + self.state = self.dataState + elif data == "?": + # XXX In theory it could be something besides a tag name. But + # do we really care? + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-tag-name-but-got-question-mark"}) + self.stream.unget(data) + self.state = self.bogusCommentState + else: + # XXX + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-tag-name"}) + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) + self.stream.unget(data) + self.state = self.dataState + return True + + def closeTagOpenState(self): + data = self.stream.char() + if data in asciiLetters: + self.currentToken = {"type": tokenTypes["EndTag"], "name": data, + "data": [], "selfClosing": False} + self.state = self.tagNameState + elif data == ">": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-closing-tag-but-got-right-bracket"}) + self.state = self.dataState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-closing-tag-but-got-eof"}) + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "</"}) + self.state = self.dataState + else: + # XXX data can be _'_... + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-closing-tag-but-got-char", + "datavars": {"data": data}}) + self.stream.unget(data) + self.state = self.bogusCommentState + return True + + def tagNameState(self): + data = self.stream.char() + if data in spaceCharacters: + self.state = self.beforeAttributeNameState + elif data == ">": + self.emitCurrentToken() + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-tag-name"}) + self.state = self.dataState + elif data == "/": + self.state = self.selfClosingStartTagState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["name"] += "\uFFFD" + else: + self.currentToken["name"] += data + # (Don't use charsUntil here, because tag names are + # very short and it's faster to not do anything fancy) + return True + + def rcdataLessThanSignState(self): + data = self.stream.char() + if data == "/": + self.temporaryBuffer = "" + self.state = self.rcdataEndTagOpenState + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) + self.stream.unget(data) + self.state = self.rcdataState + return True + + def rcdataEndTagOpenState(self): + data = self.stream.char() + if data in asciiLetters: + self.temporaryBuffer += data + self.state = self.rcdataEndTagNameState + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "</"}) + self.stream.unget(data) + self.state = self.rcdataState + return True + + def rcdataEndTagNameState(self): + appropriate = self.currentToken and self.currentToken["name"].lower() == self.temporaryBuffer.lower() + data = self.stream.char() + if data in spaceCharacters and appropriate: + self.currentToken = {"type": tokenTypes["EndTag"], + "name": self.temporaryBuffer, + "data": [], "selfClosing": False} + self.state = self.beforeAttributeNameState + elif data == "/" and appropriate: + self.currentToken = {"type": tokenTypes["EndTag"], + "name": self.temporaryBuffer, + "data": [], "selfClosing": False} + self.state = self.selfClosingStartTagState + elif data == ">" and appropriate: + self.currentToken = {"type": tokenTypes["EndTag"], + "name": self.temporaryBuffer, + "data": [], "selfClosing": False} + self.emitCurrentToken() + self.state = self.dataState + elif data in asciiLetters: + self.temporaryBuffer += data + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": "</" + self.temporaryBuffer}) + self.stream.unget(data) + self.state = self.rcdataState + return True + + def rawtextLessThanSignState(self): + data = self.stream.char() + if data == "/": + self.temporaryBuffer = "" + self.state = self.rawtextEndTagOpenState + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) + self.stream.unget(data) + self.state = self.rawtextState + return True + + def rawtextEndTagOpenState(self): + data = self.stream.char() + if data in asciiLetters: + self.temporaryBuffer += data + self.state = self.rawtextEndTagNameState + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "</"}) + self.stream.unget(data) + self.state = self.rawtextState + return True + + def rawtextEndTagNameState(self): + appropriate = self.currentToken and self.currentToken["name"].lower() == self.temporaryBuffer.lower() + data = self.stream.char() + if data in spaceCharacters and appropriate: + self.currentToken = {"type": tokenTypes["EndTag"], + "name": self.temporaryBuffer, + "data": [], "selfClosing": False} + self.state = self.beforeAttributeNameState + elif data == "/" and appropriate: + self.currentToken = {"type": tokenTypes["EndTag"], + "name": self.temporaryBuffer, + "data": [], "selfClosing": False} + self.state = self.selfClosingStartTagState + elif data == ">" and appropriate: + self.currentToken = {"type": tokenTypes["EndTag"], + "name": self.temporaryBuffer, + "data": [], "selfClosing": False} + self.emitCurrentToken() + self.state = self.dataState + elif data in asciiLetters: + self.temporaryBuffer += data + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": "</" + self.temporaryBuffer}) + self.stream.unget(data) + self.state = self.rawtextState + return True + + def scriptDataLessThanSignState(self): + data = self.stream.char() + if data == "/": + self.temporaryBuffer = "" + self.state = self.scriptDataEndTagOpenState + elif data == "!": + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<!"}) + self.state = self.scriptDataEscapeStartState + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) + self.stream.unget(data) + self.state = self.scriptDataState + return True + + def scriptDataEndTagOpenState(self): + data = self.stream.char() + if data in asciiLetters: + self.temporaryBuffer += data + self.state = self.scriptDataEndTagNameState + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "</"}) + self.stream.unget(data) + self.state = self.scriptDataState + return True + + def scriptDataEndTagNameState(self): + appropriate = self.currentToken and self.currentToken["name"].lower() == self.temporaryBuffer.lower() + data = self.stream.char() + if data in spaceCharacters and appropriate: + self.currentToken = {"type": tokenTypes["EndTag"], + "name": self.temporaryBuffer, + "data": [], "selfClosing": False} + self.state = self.beforeAttributeNameState + elif data == "/" and appropriate: + self.currentToken = {"type": tokenTypes["EndTag"], + "name": self.temporaryBuffer, + "data": [], "selfClosing": False} + self.state = self.selfClosingStartTagState + elif data == ">" and appropriate: + self.currentToken = {"type": tokenTypes["EndTag"], + "name": self.temporaryBuffer, + "data": [], "selfClosing": False} + self.emitCurrentToken() + self.state = self.dataState + elif data in asciiLetters: + self.temporaryBuffer += data + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": "</" + self.temporaryBuffer}) + self.stream.unget(data) + self.state = self.scriptDataState + return True + + def scriptDataEscapeStartState(self): + data = self.stream.char() + if data == "-": + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) + self.state = self.scriptDataEscapeStartDashState + else: + self.stream.unget(data) + self.state = self.scriptDataState + return True + + def scriptDataEscapeStartDashState(self): + data = self.stream.char() + if data == "-": + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) + self.state = self.scriptDataEscapedDashDashState + else: + self.stream.unget(data) + self.state = self.scriptDataState + return True + + def scriptDataEscapedState(self): + data = self.stream.char() + if data == "-": + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) + self.state = self.scriptDataEscapedDashState + elif data == "<": + self.state = self.scriptDataEscapedLessThanSignState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": "\uFFFD"}) + elif data == EOF: + self.state = self.dataState + else: + chars = self.stream.charsUntil(("<", "-", "\u0000")) + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": + data + chars}) + return True + + def scriptDataEscapedDashState(self): + data = self.stream.char() + if data == "-": + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) + self.state = self.scriptDataEscapedDashDashState + elif data == "<": + self.state = self.scriptDataEscapedLessThanSignState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": "\uFFFD"}) + self.state = self.scriptDataEscapedState + elif data == EOF: + self.state = self.dataState + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) + self.state = self.scriptDataEscapedState + return True + + def scriptDataEscapedDashDashState(self): + data = self.stream.char() + if data == "-": + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) + elif data == "<": + self.state = self.scriptDataEscapedLessThanSignState + elif data == ">": + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": ">"}) + self.state = self.scriptDataState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": "\uFFFD"}) + self.state = self.scriptDataEscapedState + elif data == EOF: + self.state = self.dataState + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) + self.state = self.scriptDataEscapedState + return True + + def scriptDataEscapedLessThanSignState(self): + data = self.stream.char() + if data == "/": + self.temporaryBuffer = "" + self.state = self.scriptDataEscapedEndTagOpenState + elif data in asciiLetters: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<" + data}) + self.temporaryBuffer = data + self.state = self.scriptDataDoubleEscapeStartState + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) + self.stream.unget(data) + self.state = self.scriptDataEscapedState + return True + + def scriptDataEscapedEndTagOpenState(self): + data = self.stream.char() + if data in asciiLetters: + self.temporaryBuffer = data + self.state = self.scriptDataEscapedEndTagNameState + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "</"}) + self.stream.unget(data) + self.state = self.scriptDataEscapedState + return True + + def scriptDataEscapedEndTagNameState(self): + appropriate = self.currentToken and self.currentToken["name"].lower() == self.temporaryBuffer.lower() + data = self.stream.char() + if data in spaceCharacters and appropriate: + self.currentToken = {"type": tokenTypes["EndTag"], + "name": self.temporaryBuffer, + "data": [], "selfClosing": False} + self.state = self.beforeAttributeNameState + elif data == "/" and appropriate: + self.currentToken = {"type": tokenTypes["EndTag"], + "name": self.temporaryBuffer, + "data": [], "selfClosing": False} + self.state = self.selfClosingStartTagState + elif data == ">" and appropriate: + self.currentToken = {"type": tokenTypes["EndTag"], + "name": self.temporaryBuffer, + "data": [], "selfClosing": False} + self.emitCurrentToken() + self.state = self.dataState + elif data in asciiLetters: + self.temporaryBuffer += data + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": "</" + self.temporaryBuffer}) + self.stream.unget(data) + self.state = self.scriptDataEscapedState + return True + + def scriptDataDoubleEscapeStartState(self): + data = self.stream.char() + if data in (spaceCharacters | frozenset(("/", ">"))): + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) + if self.temporaryBuffer.lower() == "script": + self.state = self.scriptDataDoubleEscapedState + else: + self.state = self.scriptDataEscapedState + elif data in asciiLetters: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) + self.temporaryBuffer += data + else: + self.stream.unget(data) + self.state = self.scriptDataEscapedState + return True + + def scriptDataDoubleEscapedState(self): + data = self.stream.char() + if data == "-": + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) + self.state = self.scriptDataDoubleEscapedDashState + elif data == "<": + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) + self.state = self.scriptDataDoubleEscapedLessThanSignState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": "\uFFFD"}) + elif data == EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-script-in-script"}) + self.state = self.dataState + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) + return True + + def scriptDataDoubleEscapedDashState(self): + data = self.stream.char() + if data == "-": + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) + self.state = self.scriptDataDoubleEscapedDashDashState + elif data == "<": + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) + self.state = self.scriptDataDoubleEscapedLessThanSignState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": "\uFFFD"}) + self.state = self.scriptDataDoubleEscapedState + elif data == EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-script-in-script"}) + self.state = self.dataState + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) + self.state = self.scriptDataDoubleEscapedState + return True + + def scriptDataDoubleEscapedDashDashState(self): + data = self.stream.char() + if data == "-": + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) + elif data == "<": + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) + self.state = self.scriptDataDoubleEscapedLessThanSignState + elif data == ">": + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": ">"}) + self.state = self.scriptDataState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": "\uFFFD"}) + self.state = self.scriptDataDoubleEscapedState + elif data == EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-script-in-script"}) + self.state = self.dataState + else: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) + self.state = self.scriptDataDoubleEscapedState + return True + + def scriptDataDoubleEscapedLessThanSignState(self): + data = self.stream.char() + if data == "/": + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "/"}) + self.temporaryBuffer = "" + self.state = self.scriptDataDoubleEscapeEndState + else: + self.stream.unget(data) + self.state = self.scriptDataDoubleEscapedState + return True + + def scriptDataDoubleEscapeEndState(self): + data = self.stream.char() + if data in (spaceCharacters | frozenset(("/", ">"))): + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) + if self.temporaryBuffer.lower() == "script": + self.state = self.scriptDataEscapedState + else: + self.state = self.scriptDataDoubleEscapedState + elif data in asciiLetters: + self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) + self.temporaryBuffer += data + else: + self.stream.unget(data) + self.state = self.scriptDataDoubleEscapedState + return True + + def beforeAttributeNameState(self): + data = self.stream.char() + if data in spaceCharacters: + self.stream.charsUntil(spaceCharacters, True) + elif data in asciiLetters: + self.currentToken["data"].append([data, ""]) + self.state = self.attributeNameState + elif data == ">": + self.emitCurrentToken() + elif data == "/": + self.state = self.selfClosingStartTagState + elif data in ("'", '"', "=", "<"): + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "invalid-character-in-attribute-name"}) + self.currentToken["data"].append([data, ""]) + self.state = self.attributeNameState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["data"].append(["\uFFFD", ""]) + self.state = self.attributeNameState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-attribute-name-but-got-eof"}) + self.state = self.dataState + else: + self.currentToken["data"].append([data, ""]) + self.state = self.attributeNameState + return True + + def attributeNameState(self): + data = self.stream.char() + leavingThisState = True + emitToken = False + if data == "=": + self.state = self.beforeAttributeValueState + elif data in asciiLetters: + self.currentToken["data"][-1][0] += data +\ + self.stream.charsUntil(asciiLetters, True) + leavingThisState = False + elif data == ">": + # XXX If we emit here the attributes are converted to a dict + # without being checked and when the code below runs we error + # because data is a dict not a list + emitToken = True + elif data in spaceCharacters: + self.state = self.afterAttributeNameState + elif data == "/": + self.state = self.selfClosingStartTagState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["data"][-1][0] += "\uFFFD" + leavingThisState = False + elif data in ("'", '"', "<"): + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": + "invalid-character-in-attribute-name"}) + self.currentToken["data"][-1][0] += data + leavingThisState = False + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "eof-in-attribute-name"}) + self.state = self.dataState + else: + self.currentToken["data"][-1][0] += data + leavingThisState = False + + if leavingThisState: + # Attributes are not dropped at this stage. That happens when the + # start tag token is emitted so values can still be safely appended + # to attributes, but we do want to report the parse error in time. + self.currentToken["data"][-1][0] = ( + self.currentToken["data"][-1][0].translate(asciiUpper2Lower)) + for name, _ in self.currentToken["data"][:-1]: + if self.currentToken["data"][-1][0] == name: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "duplicate-attribute"}) + break + # XXX Fix for above XXX + if emitToken: + self.emitCurrentToken() + return True + + def afterAttributeNameState(self): + data = self.stream.char() + if data in spaceCharacters: + self.stream.charsUntil(spaceCharacters, True) + elif data == "=": + self.state = self.beforeAttributeValueState + elif data == ">": + self.emitCurrentToken() + elif data in asciiLetters: + self.currentToken["data"].append([data, ""]) + self.state = self.attributeNameState + elif data == "/": + self.state = self.selfClosingStartTagState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["data"].append(["\uFFFD", ""]) + self.state = self.attributeNameState + elif data in ("'", '"', "<"): + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "invalid-character-after-attribute-name"}) + self.currentToken["data"].append([data, ""]) + self.state = self.attributeNameState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-end-of-tag-but-got-eof"}) + self.state = self.dataState + else: + self.currentToken["data"].append([data, ""]) + self.state = self.attributeNameState + return True + + def beforeAttributeValueState(self): + data = self.stream.char() + if data in spaceCharacters: + self.stream.charsUntil(spaceCharacters, True) + elif data == "\"": + self.state = self.attributeValueDoubleQuotedState + elif data == "&": + self.state = self.attributeValueUnQuotedState + self.stream.unget(data) + elif data == "'": + self.state = self.attributeValueSingleQuotedState + elif data == ">": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-attribute-value-but-got-right-bracket"}) + self.emitCurrentToken() + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["data"][-1][1] += "\uFFFD" + self.state = self.attributeValueUnQuotedState + elif data in ("=", "<", "`"): + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "equals-in-unquoted-attribute-value"}) + self.currentToken["data"][-1][1] += data + self.state = self.attributeValueUnQuotedState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-attribute-value-but-got-eof"}) + self.state = self.dataState + else: + self.currentToken["data"][-1][1] += data + self.state = self.attributeValueUnQuotedState + return True + + def attributeValueDoubleQuotedState(self): + data = self.stream.char() + if data == "\"": + self.state = self.afterAttributeValueState + elif data == "&": + self.processEntityInAttribute('"') + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["data"][-1][1] += "\uFFFD" + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-attribute-value-double-quote"}) + self.state = self.dataState + else: + self.currentToken["data"][-1][1] += data +\ + self.stream.charsUntil(("\"", "&", "\u0000")) + return True + + def attributeValueSingleQuotedState(self): + data = self.stream.char() + if data == "'": + self.state = self.afterAttributeValueState + elif data == "&": + self.processEntityInAttribute("'") + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["data"][-1][1] += "\uFFFD" + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-attribute-value-single-quote"}) + self.state = self.dataState + else: + self.currentToken["data"][-1][1] += data +\ + self.stream.charsUntil(("'", "&", "\u0000")) + return True + + def attributeValueUnQuotedState(self): + data = self.stream.char() + if data in spaceCharacters: + self.state = self.beforeAttributeNameState + elif data == "&": + self.processEntityInAttribute(">") + elif data == ">": + self.emitCurrentToken() + elif data in ('"', "'", "=", "<", "`"): + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-character-in-unquoted-attribute-value"}) + self.currentToken["data"][-1][1] += data + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["data"][-1][1] += "\uFFFD" + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-attribute-value-no-quotes"}) + self.state = self.dataState + else: + self.currentToken["data"][-1][1] += data + self.stream.charsUntil( + frozenset(("&", ">", '"', "'", "=", "<", "`", "\u0000")) | spaceCharacters) + return True + + def afterAttributeValueState(self): + data = self.stream.char() + if data in spaceCharacters: + self.state = self.beforeAttributeNameState + elif data == ">": + self.emitCurrentToken() + elif data == "/": + self.state = self.selfClosingStartTagState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-EOF-after-attribute-value"}) + self.stream.unget(data) + self.state = self.dataState + else: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-character-after-attribute-value"}) + self.stream.unget(data) + self.state = self.beforeAttributeNameState + return True + + def selfClosingStartTagState(self): + data = self.stream.char() + if data == ">": + self.currentToken["selfClosing"] = True + self.emitCurrentToken() + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": + "unexpected-EOF-after-solidus-in-tag"}) + self.stream.unget(data) + self.state = self.dataState + else: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-character-after-solidus-in-tag"}) + self.stream.unget(data) + self.state = self.beforeAttributeNameState + return True + + def bogusCommentState(self): + # Make a new comment token and give it as value all the characters + # until the first > or EOF (charsUntil checks for EOF automatically) + # and emit it. + data = self.stream.charsUntil(">") + data = data.replace("\u0000", "\uFFFD") + self.tokenQueue.append( + {"type": tokenTypes["Comment"], "data": data}) + + # Eat the character directly after the bogus comment which is either a + # ">" or an EOF. + self.stream.char() + self.state = self.dataState + return True + + def markupDeclarationOpenState(self): + charStack = [self.stream.char()] + if charStack[-1] == "-": + charStack.append(self.stream.char()) + if charStack[-1] == "-": + self.currentToken = {"type": tokenTypes["Comment"], "data": ""} + self.state = self.commentStartState + return True + elif charStack[-1] in ('d', 'D'): + matched = True + for expected in (('o', 'O'), ('c', 'C'), ('t', 'T'), + ('y', 'Y'), ('p', 'P'), ('e', 'E')): + charStack.append(self.stream.char()) + if charStack[-1] not in expected: + matched = False + break + if matched: + self.currentToken = {"type": tokenTypes["Doctype"], + "name": "", + "publicId": None, "systemId": None, + "correct": True} + self.state = self.doctypeState + return True + elif (charStack[-1] == "[" and + self.parser is not None and + self.parser.tree.openElements and + self.parser.tree.openElements[-1].namespace != self.parser.tree.defaultNamespace): + matched = True + for expected in ["C", "D", "A", "T", "A", "["]: + charStack.append(self.stream.char()) + if charStack[-1] != expected: + matched = False + break + if matched: + self.state = self.cdataSectionState + return True + + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-dashes-or-doctype"}) + + while charStack: + self.stream.unget(charStack.pop()) + self.state = self.bogusCommentState + return True + + def commentStartState(self): + data = self.stream.char() + if data == "-": + self.state = self.commentStartDashState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["data"] += "\uFFFD" + elif data == ">": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "incorrect-comment"}) + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-comment"}) + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.currentToken["data"] += data + self.state = self.commentState + return True + + def commentStartDashState(self): + data = self.stream.char() + if data == "-": + self.state = self.commentEndState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["data"] += "-\uFFFD" + elif data == ">": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "incorrect-comment"}) + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-comment"}) + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.currentToken["data"] += "-" + data + self.state = self.commentState + return True + + def commentState(self): + data = self.stream.char() + if data == "-": + self.state = self.commentEndDashState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["data"] += "\uFFFD" + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "eof-in-comment"}) + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.currentToken["data"] += data + \ + self.stream.charsUntil(("-", "\u0000")) + return True + + def commentEndDashState(self): + data = self.stream.char() + if data == "-": + self.state = self.commentEndState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["data"] += "-\uFFFD" + self.state = self.commentState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-comment-end-dash"}) + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.currentToken["data"] += "-" + data + self.state = self.commentState + return True + + def commentEndState(self): + data = self.stream.char() + if data == ">": + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["data"] += "--\uFFFD" + self.state = self.commentState + elif data == "!": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-bang-after-double-dash-in-comment"}) + self.state = self.commentEndBangState + elif data == "-": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-dash-after-double-dash-in-comment"}) + self.currentToken["data"] += data + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-comment-double-dash"}) + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + # XXX + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-char-in-comment"}) + self.currentToken["data"] += "--" + data + self.state = self.commentState + return True + + def commentEndBangState(self): + data = self.stream.char() + if data == ">": + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data == "-": + self.currentToken["data"] += "--!" + self.state = self.commentEndDashState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["data"] += "--!\uFFFD" + self.state = self.commentState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-comment-end-bang-state"}) + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.currentToken["data"] += "--!" + data + self.state = self.commentState + return True + + def doctypeState(self): + data = self.stream.char() + if data in spaceCharacters: + self.state = self.beforeDoctypeNameState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-doctype-name-but-got-eof"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "need-space-after-doctype"}) + self.stream.unget(data) + self.state = self.beforeDoctypeNameState + return True + + def beforeDoctypeNameState(self): + data = self.stream.char() + if data in spaceCharacters: + pass + elif data == ">": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-doctype-name-but-got-right-bracket"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["name"] = "\uFFFD" + self.state = self.doctypeNameState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-doctype-name-but-got-eof"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.currentToken["name"] = data + self.state = self.doctypeNameState + return True + + def doctypeNameState(self): + data = self.stream.char() + if data in spaceCharacters: + self.currentToken["name"] = self.currentToken["name"].translate(asciiUpper2Lower) + self.state = self.afterDoctypeNameState + elif data == ">": + self.currentToken["name"] = self.currentToken["name"].translate(asciiUpper2Lower) + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["name"] += "\uFFFD" + self.state = self.doctypeNameState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-doctype-name"}) + self.currentToken["correct"] = False + self.currentToken["name"] = self.currentToken["name"].translate(asciiUpper2Lower) + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.currentToken["name"] += data + return True + + def afterDoctypeNameState(self): + data = self.stream.char() + if data in spaceCharacters: + pass + elif data == ">": + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data is EOF: + self.currentToken["correct"] = False + self.stream.unget(data) + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-doctype"}) + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + if data in ("p", "P"): + matched = True + for expected in (("u", "U"), ("b", "B"), ("l", "L"), + ("i", "I"), ("c", "C")): + data = self.stream.char() + if data not in expected: + matched = False + break + if matched: + self.state = self.afterDoctypePublicKeywordState + return True + elif data in ("s", "S"): + matched = True + for expected in (("y", "Y"), ("s", "S"), ("t", "T"), + ("e", "E"), ("m", "M")): + data = self.stream.char() + if data not in expected: + matched = False + break + if matched: + self.state = self.afterDoctypeSystemKeywordState + return True + + # All the characters read before the current 'data' will be + # [a-zA-Z], so they're garbage in the bogus doctype and can be + # discarded; only the latest character might be '>' or EOF + # and needs to be ungetted + self.stream.unget(data) + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "expected-space-or-right-bracket-in-doctype", "datavars": + {"data": data}}) + self.currentToken["correct"] = False + self.state = self.bogusDoctypeState + + return True + + def afterDoctypePublicKeywordState(self): + data = self.stream.char() + if data in spaceCharacters: + self.state = self.beforeDoctypePublicIdentifierState + elif data in ("'", '"'): + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-char-in-doctype"}) + self.stream.unget(data) + self.state = self.beforeDoctypePublicIdentifierState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.stream.unget(data) + self.state = self.beforeDoctypePublicIdentifierState + return True + + def beforeDoctypePublicIdentifierState(self): + data = self.stream.char() + if data in spaceCharacters: + pass + elif data == "\"": + self.currentToken["publicId"] = "" + self.state = self.doctypePublicIdentifierDoubleQuotedState + elif data == "'": + self.currentToken["publicId"] = "" + self.state = self.doctypePublicIdentifierSingleQuotedState + elif data == ">": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-end-of-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-char-in-doctype"}) + self.currentToken["correct"] = False + self.state = self.bogusDoctypeState + return True + + def doctypePublicIdentifierDoubleQuotedState(self): + data = self.stream.char() + if data == "\"": + self.state = self.afterDoctypePublicIdentifierState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["publicId"] += "\uFFFD" + elif data == ">": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-end-of-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.currentToken["publicId"] += data + return True + + def doctypePublicIdentifierSingleQuotedState(self): + data = self.stream.char() + if data == "'": + self.state = self.afterDoctypePublicIdentifierState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["publicId"] += "\uFFFD" + elif data == ">": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-end-of-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.currentToken["publicId"] += data + return True + + def afterDoctypePublicIdentifierState(self): + data = self.stream.char() + if data in spaceCharacters: + self.state = self.betweenDoctypePublicAndSystemIdentifiersState + elif data == ">": + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data == '"': + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-char-in-doctype"}) + self.currentToken["systemId"] = "" + self.state = self.doctypeSystemIdentifierDoubleQuotedState + elif data == "'": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-char-in-doctype"}) + self.currentToken["systemId"] = "" + self.state = self.doctypeSystemIdentifierSingleQuotedState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-char-in-doctype"}) + self.currentToken["correct"] = False + self.state = self.bogusDoctypeState + return True + + def betweenDoctypePublicAndSystemIdentifiersState(self): + data = self.stream.char() + if data in spaceCharacters: + pass + elif data == ">": + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data == '"': + self.currentToken["systemId"] = "" + self.state = self.doctypeSystemIdentifierDoubleQuotedState + elif data == "'": + self.currentToken["systemId"] = "" + self.state = self.doctypeSystemIdentifierSingleQuotedState + elif data == EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-char-in-doctype"}) + self.currentToken["correct"] = False + self.state = self.bogusDoctypeState + return True + + def afterDoctypeSystemKeywordState(self): + data = self.stream.char() + if data in spaceCharacters: + self.state = self.beforeDoctypeSystemIdentifierState + elif data in ("'", '"'): + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-char-in-doctype"}) + self.stream.unget(data) + self.state = self.beforeDoctypeSystemIdentifierState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.stream.unget(data) + self.state = self.beforeDoctypeSystemIdentifierState + return True + + def beforeDoctypeSystemIdentifierState(self): + data = self.stream.char() + if data in spaceCharacters: + pass + elif data == "\"": + self.currentToken["systemId"] = "" + self.state = self.doctypeSystemIdentifierDoubleQuotedState + elif data == "'": + self.currentToken["systemId"] = "" + self.state = self.doctypeSystemIdentifierSingleQuotedState + elif data == ">": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-char-in-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-char-in-doctype"}) + self.currentToken["correct"] = False + self.state = self.bogusDoctypeState + return True + + def doctypeSystemIdentifierDoubleQuotedState(self): + data = self.stream.char() + if data == "\"": + self.state = self.afterDoctypeSystemIdentifierState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["systemId"] += "\uFFFD" + elif data == ">": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-end-of-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.currentToken["systemId"] += data + return True + + def doctypeSystemIdentifierSingleQuotedState(self): + data = self.stream.char() + if data == "'": + self.state = self.afterDoctypeSystemIdentifierState + elif data == "\u0000": + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + self.currentToken["systemId"] += "\uFFFD" + elif data == ">": + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-end-of-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.currentToken["systemId"] += data + return True + + def afterDoctypeSystemIdentifierState(self): + data = self.stream.char() + if data in spaceCharacters: + pass + elif data == ">": + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data is EOF: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "eof-in-doctype"}) + self.currentToken["correct"] = False + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": + "unexpected-char-in-doctype"}) + self.state = self.bogusDoctypeState + return True + + def bogusDoctypeState(self): + data = self.stream.char() + if data == ">": + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + elif data is EOF: + # XXX EMIT + self.stream.unget(data) + self.tokenQueue.append(self.currentToken) + self.state = self.dataState + else: + pass + return True + + def cdataSectionState(self): + data = [] + while True: + data.append(self.stream.charsUntil("]")) + data.append(self.stream.charsUntil(">")) + char = self.stream.char() + if char == EOF: + break + else: + assert char == ">" + if data[-1][-2:] == "]]": + data[-1] = data[-1][:-2] + break + else: + data.append(char) + + data = "".join(data) # pylint:disable=redefined-variable-type + # Deal with null here rather than in the parser + nullCount = data.count("\u0000") + if nullCount > 0: + for _ in range(nullCount): + self.tokenQueue.append({"type": tokenTypes["ParseError"], + "data": "invalid-codepoint"}) + data = data.replace("\u0000", "\uFFFD") + if data: + self.tokenQueue.append({"type": tokenTypes["Characters"], + "data": data}) + self.state = self.dataState + return True diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__init__.py new file mode 100644 index 0000000..a5ba4bf --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__init__.py @@ -0,0 +1,14 @@ +from __future__ import absolute_import, division, unicode_literals + +from .py import Trie as PyTrie + +Trie = PyTrie + +# pylint:disable=wrong-import-position +try: + from .datrie import Trie as DATrie +except ImportError: + pass +else: + Trie = DATrie +# pylint:enable=wrong-import-position diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..766667c00d461dbab400490aec4530ce76a2027f GIT binary patch literal 438 zcmYjMJx{|h5Is9-2!)mo`~k)e;DSV@N(g}j5-bQo5s<}7u}ck(6J4CB?Z07U<M(7` z>K|ZW!tTU7-8;W`{y0B$I&E<H`T9ur2*9@&{}DTJ=CZtVBtQ@i8A(V+6Pg7{KtNCt z=rC&~5dj$`tz~cRY&a(-@Car%1iAU%#w!9op20*<AmgMZ!h7hqR_<Qt2hC18DRW&} z$yHY5Xq#B5T9qm{O|LTQB^Q!wWhJJ%T)9c1PnvLyO5XI_O`G#+Wh<1NBXvCtJcW)L zS}ZW~i|BUYw<nQE?Ydr^d);hZuiv{w%<&U&%b)c0J7)!|I<=D3DY9v<g~XDL=IoV^ zYRs1AX!<so&F0G`*Q4QNh69IJ!^W&o#lAA7O|{-142JchKCHaCPF_nRa%3}`>0_-X njQepI=gKI{`9ZO0;*%^Fm6oUepJmt4F5RYKKuM2uNksnuee-p+ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__pycache__/_base.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__pycache__/_base.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7e5fe64491518663a52bbf0b52ed9b5be4bba638 GIT binary patch literal 1617 zcmZ`(&2J+$6o2+il1cipRa+K{ma5`_$YGO!#7ad~1)_iuqL(cKMp{{uvC|CoeAJ$V zHkw{&(e9bQpgr!5zh|zT_78vqC*E_qtCU?lvd16Ke!t)QJ^TBWl@4I}`;VLGFAv~P z8Z4Fo2cKcJAvO{u(~z=|r99-R7kUh4YdFibpEkk<gC8K<@j*3DI_7`@eQvciU;PO( z{v&)1(v$ubNMAKBy)clC$IxxQ!1JN&)%T*I&Gn>IB1wzflyxAJX=0N+tJfx366aD0 zos`N%+ICsp`YtMpBs-32`(p8L2li9!C<vK^kV_VNa_K3In1j#`ec6!BD+n91B?J67 zWm|Ue-+Br@gaHCuuKgpEsM&j;4{d3pxZD{=R_(+(vUX>bo1GF@?P1IpoMRy2Wwiqw zlu)t?F8MXTfeZc&gK`p>?b56GC3_4G50m^VsQ3ZUOxHV%*}{QzcmwMOR{JhCW2oTC z`UR`lH9UhGX8el%&QJZv@EkBI9a~1Gw7(?fxXWwa8`SLVIjft6QKRI{wD5#~CjG)B z)2LMaX=M7NTuWtafA_3^EOw_Ron;@7ejbd+XS12myN`xrGr)43^^f{RQansDbfNXb z!Qj#KeEJa{mK3gvsmf$-`r|UypXg-R7Zjkrps4kV^SZrfRT<}LvG2$<5lRy{bYS*? z;@mq?=eD<}^BDEr@4Yha`gOxj3S|uKsC_c4Jv<6i#<xn3%refKHEfV*TL>qR5N3&{ zS6;4>k)@mlzRCj@@LBtn*ViPZ6#9ZTypK%<*Kh*|@MQCXSNs|yk5LaWzfrE!KyoMA z(N|sWFc|XD^~^f{9J1Ohmjh7i@8<H!nPB1kDQSLZEUnL}jDtV0mD9K<)-{y*d+ zJf*^%J87Eb3L%yV6myVWGRfY?Ohh6dA`!e56<>ni_!bgG+wH{}j@K8-ZI@_w$$mv! zB*_n7P-bG-8z#z*Rqbh&)xo#w{7YkUbB8la{>yk(=eWm~w_G0(SJDJnz<hq6t+P!& z+i-mETE51V?w1qiK6XeP5`?6wkkJ;5NDy||Wrlp*LDkX=*I+@7jk_KNJ~HVCxY@d= z1f`h0^9Eqfj6AjLK!_|#l@N7Dh%}cIP5osdPA8GRU1<p+^BD7zGSv`v2heO|uU@%L z+gNFhCUi~b4PBLa5>xiKv08ezDQ2tfpcQo7tso5Oc{C{}20a^kH4Mec5QF+&oNKM( y5}#7ri-xhG7o}eM#yzu6yn1QD#2vYS!J%<!8|=-=?NcH+Ae)@CHMYvuy?+5(GjrDf literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__pycache__/datrie.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__pycache__/datrie.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2ae06d48ed05f2b5182631f117c61ad7ba7a6b38 GIT binary patch literal 2050 zcmbVNOK%%D5GMDfl`PAO?G$#OZkwV}i&$=f1~3p5ag(AbQ0P#*JqRs`wMa?p>_a9g z)fU#5*uSDD`{-ML53fDt5A@JeXDG>$9isuv1&6aU-1+83?k|gr6$0a*zb>LbJwpD* zm-zuQ@)V}}2?!^gCM2b8nmTPKb=xjQnUi>_-wrJACZ#lNhroLvFN3^7$q$74JUAmf z5S3H6?eo$uX@sx9B5Am0DcV<gGSq^_=^&TdgghR_D$X-gA7*hU=Yl1%7BWgygBov7 z#sb!|7Dt-t<AHcZ!B7XS%?}q|p2AeW0uiK5IcYnba_5Y+UG8!ZR&U}Ldc;F`4|thZ zU@h@gUge8tv>oyqUjj*)*ZDnID}0%+z`DQ}Acp(W2jd+F$ZQ0_pzs+?bpS+@Q*z=I z^qgLh=j8V<PF(F2u69oy^+0=^p3;}Ja6wZ$@e1eMFT4v%$>GDpnhv;gUMidm*i#S| zf{n7ZvHY8J;-2`0Uyy^aaG#LFpE&_{+}3z)CrLJ5h-0;p4wc^67aK~;IO{1x8WrOz zp^b-XQ-KU;N=I2oNc7p1_aK$uOPNdKMx2}A`3`2<cn5i$8K3b;N5+Rbq^c1ZPl=>! zyos>WkEAj#*fk#V#vet=P+StZ2A2OFH3u>tMOrjRk!*JJgbS&f+eghF+aAeuoPFIr z*y{I>#$%RjKi==lEf~G5xz`-TgGbiOBzd&8^>}nV`f7+mJK0ENJeSSBPLpqvc)!UY zQqcsLVA&iTn~<?Mi#21|;%XTPp#iPZ3Ju|@Idxj6<3$W|bGGwZDY2|LZ7I=40cAKK zFM?fiNn4jx)<JgZNVF{PBf)SdWF0tDWvr8DI)V@wdj}-Sb_yNen}WX9cCd$M1Nm#f zngB3#!7h>Sfv({gHxbzcpHA>^K$jSU9gLwLGt}x7)hgZqM9`~9v1wnziJ1XXv(n1- zkLe&0smQe8wo&8;d~-8s%sL!a#@?TUzRI%Iyd}$!<AScwuqE1&AKZepz*tXc>`2Bw znggp(<GfO~-T=hQ!3J9e28()53wrT7zc#fJYd)>72?kPh<D(nV+AW{VVV5m7p0K-N zn$>=!7=F+Gh;^S$Q9lESo6w(w4CS-(u3PBaKEI<YwIt7aLh1i=;vqPIbLPZ~b>jMm zcZ6TLZUwt4mA56L0r+3e`LK425BBQ@Z8fTREo4zD7&8^d(wq+y<l(Fy4x?nEk?(>z z`5}^zk$j5e0TOHpiJ6xewM6K-y4XXAN6!8i%D~ub2d<lH=uV!BU9G;=SU?xLLp_w> zg2W>)u`?z9b>U}ZZ!)`8)<9yG;Og6)UVEDgn$cd|KHHC!Fr}UEo?+m(xnsg7lR&@4 PQ?5cFt4@_xovQmE*fhOT literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__pycache__/py.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/__pycache__/py.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9a28323efefc2df97d204447124979351076c498 GIT binary patch literal 2274 zcmb7F&5s*36t_JenPjuOX{okd1SKF43aH6~#G*=7)lw)Ds`k=_Lj<yBV`nqFGn3SI zLN=OQNdFGhJ@$t9bA0906E_Z=c+Zn;H%ldiNAqkyKfh=H-iN>6+^i93fBkkI{}~eU z2Tm?GA0`jr*H3^5B4|o7+NBxmvdrsx6nQN5v!ENev6qHfrCWiqFM>46s@)nT-x3ju z%5x$rvbONLRS`WUt?Db#NLrrVj*s*(9UIA$Y&2BHMk1LcIvM7+G0v0TP)MF8Myfc~ zEo!SqP7OC_BMFm@qeRP|;i>GKR}}S8>mRB__E7od=E39v{Q5BvNxD>!E)!I+=cMZi zPx#Qokwpl7ASxn)J``0^gT5jfqAoU{({3cT#5QoMVgs&lO+}!r$AGLFjuEp*@ayk@ z7{CmT6!Zl>Cts5VT~K}7FySreFSMWq;hyo!)dkK1;R6jtU@8U3_8H6~LBL#i(8DXP z+RBs$hQ0-)AU`$c)PN~N7wiW@$uou<U($mXvo(M;*Cx(;QUxFlEY{w$bo!F0O_=|! zIwO@#Vk0|~SatftR7j;ecc-0Wes`j>S^jzdWN$E-&SpHlyMHuLd(e*a&S7VijP5wy zX?kaGZ+~(&`D~0#_w$L&#ZYwyCQH9alcNqd;GfRutUWrj)qBS>m(!8Dzk#<v<b1-& ztcgBsbDrdh;k<n>9rnQc_uCiZvs(|-w0SDebTb=k(>#(*4SMrqZHaP$P_<s1rq)Lp zTRnt$`9`UsvH=&diEXGM)TDrEDZqPiZy-U3^-`JJdO05rliX;4%GWaOTOYSNv`VrC z=e5!5n3zer4usGh8nKXW(U8tI*RJxfU_mdsV8PuO4kzR^d`eUmrZ1_wfgMwCLuWlW z=~d%(&U?e$!~j3%Z-JC{(MV_4mS$hCt_2T5v}PK@hMYjWElszW!jLNMQ)mCG=?aIm z%Q@e<WVODu>K6W|LF;3ZJB#Xlw2e`D1!oZ8eD{*U3v}Jef1nH47IYUf!lA3)Mg6xg zj5u@7qZ^zbO9Q9LIDhAovBvUt7mEjL1}h+nndRL1I}8daGN+N=fu5c+=-~jmX`GW0 zX~=rW?i25vswdF<Ke9QSdnQ0R2nAMn3*RSme;(wG6?ef(4x~7lhlOuKlwN>-WeNx! zw>Q`&pqYZ+UyJZXWyL$EloWwrUy^z7%#^jK@Qc9J7$0}HyaUyMlPkPSD^loN>uG6h z4N8YH`sc(9)J>E?FDQ62hzk@*HX&M-GEl>jlKo_ASvs_Akl4WOwKP%JQGVU8j`tq$ zHM#;*r^f2EMt4}lrI61Wv;n*j{#n&|05f(Cc|`pJc>$AEBB?D=;*6Lxz+)eJZ;3P1 z*^^*}^W4wtP=_67!RG!F*}x%tD40VwD11N`s`fc(1*{Gq!<8{b)yGJ#;DX>ea9Tl` zKrLi^g5*;qcaW@uVQ&m#?J5#Sq<IPCJ_u@rjsPycL+3iHvn?3Ub{!&b+SP)xU&HE@ z$C>2Z);Q0GVw~a_%Eq&CoR%vJV_Y?ne1PObBp)Gh?rP)c^)cND)5JY~Sf(`2A{tdA zul#B^-P%EG1C92_W~{)d!g{0d9adQ9?KZp+?d9vx*2&bpN;WKCbQf7roR4BHoibZ_ d_|+r4>zj^ZqkHAm?qglk_$uF^b%3bu{R5tm?2!Nf literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/_base.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/_base.py new file mode 100644 index 0000000..6b71975 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/_base.py @@ -0,0 +1,40 @@ +from __future__ import absolute_import, division, unicode_literals + +try: + from collections.abc import Mapping +except ImportError: # Python 2.7 + from collections import Mapping + + +class Trie(Mapping): + """Abstract base class for tries""" + + def keys(self, prefix=None): + # pylint:disable=arguments-differ + keys = super(Trie, self).keys() + + if prefix is None: + return set(keys) + + return {x for x in keys if x.startswith(prefix)} + + def has_keys_with_prefix(self, prefix): + for key in self.keys(): + if key.startswith(prefix): + return True + + return False + + def longest_prefix(self, prefix): + if prefix in self: + return prefix + + for i in range(1, len(prefix) + 1): + if prefix[:-i] in self: + return prefix[:-i] + + raise KeyError(prefix) + + def longest_prefix_item(self, prefix): + lprefix = self.longest_prefix(prefix) + return (lprefix, self[lprefix]) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/datrie.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/datrie.py new file mode 100644 index 0000000..e2e5f86 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/datrie.py @@ -0,0 +1,44 @@ +from __future__ import absolute_import, division, unicode_literals + +from datrie import Trie as DATrie +from pip._vendor.six import text_type + +from ._base import Trie as ABCTrie + + +class Trie(ABCTrie): + def __init__(self, data): + chars = set() + for key in data.keys(): + if not isinstance(key, text_type): + raise TypeError("All keys must be strings") + for char in key: + chars.add(char) + + self._data = DATrie("".join(chars)) + for key, value in data.items(): + self._data[key] = value + + def __contains__(self, key): + return key in self._data + + def __len__(self): + return len(self._data) + + def __iter__(self): + raise NotImplementedError() + + def __getitem__(self, key): + return self._data[key] + + def keys(self, prefix=None): + return self._data.keys(prefix) + + def has_keys_with_prefix(self, prefix): + return self._data.has_keys_with_prefix(prefix) + + def longest_prefix(self, prefix): + return self._data.longest_prefix(prefix) + + def longest_prefix_item(self, prefix): + return self._data.longest_prefix_item(prefix) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/py.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/py.py new file mode 100644 index 0000000..c178b21 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_trie/py.py @@ -0,0 +1,67 @@ +from __future__ import absolute_import, division, unicode_literals +from pip._vendor.six import text_type + +from bisect import bisect_left + +from ._base import Trie as ABCTrie + + +class Trie(ABCTrie): + def __init__(self, data): + if not all(isinstance(x, text_type) for x in data.keys()): + raise TypeError("All keys must be strings") + + self._data = data + self._keys = sorted(data.keys()) + self._cachestr = "" + self._cachepoints = (0, len(data)) + + def __contains__(self, key): + return key in self._data + + def __len__(self): + return len(self._data) + + def __iter__(self): + return iter(self._data) + + def __getitem__(self, key): + return self._data[key] + + def keys(self, prefix=None): + if prefix is None or prefix == "" or not self._keys: + return set(self._keys) + + if prefix.startswith(self._cachestr): + lo, hi = self._cachepoints + start = i = bisect_left(self._keys, prefix, lo, hi) + else: + start = i = bisect_left(self._keys, prefix) + + keys = set() + if start == len(self._keys): + return keys + + while self._keys[i].startswith(prefix): + keys.add(self._keys[i]) + i += 1 + + self._cachestr = prefix + self._cachepoints = (start, i) + + return keys + + def has_keys_with_prefix(self, prefix): + if prefix in self._data: + return True + + if prefix.startswith(self._cachestr): + lo, hi = self._cachepoints + i = bisect_left(self._keys, prefix, lo, hi) + else: + i = bisect_left(self._keys, prefix) + + if i == len(self._keys): + return False + + return self._keys[i].startswith(prefix) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_utils.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_utils.py new file mode 100644 index 0000000..0703afb --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/_utils.py @@ -0,0 +1,124 @@ +from __future__ import absolute_import, division, unicode_literals + +from types import ModuleType + +from pip._vendor.six import text_type + +try: + import xml.etree.cElementTree as default_etree +except ImportError: + import xml.etree.ElementTree as default_etree + + +__all__ = ["default_etree", "MethodDispatcher", "isSurrogatePair", + "surrogatePairToCodepoint", "moduleFactoryFactory", + "supports_lone_surrogates"] + + +# Platforms not supporting lone surrogates (\uD800-\uDFFF) should be +# caught by the below test. In general this would be any platform +# using UTF-16 as its encoding of unicode strings, such as +# Jython. This is because UTF-16 itself is based on the use of such +# surrogates, and there is no mechanism to further escape such +# escapes. +try: + _x = eval('"\\uD800"') # pylint:disable=eval-used + if not isinstance(_x, text_type): + # We need this with u"" because of http://bugs.jython.org/issue2039 + _x = eval('u"\\uD800"') # pylint:disable=eval-used + assert isinstance(_x, text_type) +except: # pylint:disable=bare-except + supports_lone_surrogates = False +else: + supports_lone_surrogates = True + + +class MethodDispatcher(dict): + """Dict with 2 special properties: + + On initiation, keys that are lists, sets or tuples are converted to + multiple keys so accessing any one of the items in the original + list-like object returns the matching value + + md = MethodDispatcher({("foo", "bar"):"baz"}) + md["foo"] == "baz" + + A default value which can be set through the default attribute. + """ + + def __init__(self, items=()): + # Using _dictEntries instead of directly assigning to self is about + # twice as fast. Please do careful performance testing before changing + # anything here. + _dictEntries = [] + for name, value in items: + if isinstance(name, (list, tuple, frozenset, set)): + for item in name: + _dictEntries.append((item, value)) + else: + _dictEntries.append((name, value)) + dict.__init__(self, _dictEntries) + assert len(self) == len(_dictEntries) + self.default = None + + def __getitem__(self, key): + return dict.get(self, key, self.default) + + +# Some utility functions to deal with weirdness around UCS2 vs UCS4 +# python builds + +def isSurrogatePair(data): + return (len(data) == 2 and + ord(data[0]) >= 0xD800 and ord(data[0]) <= 0xDBFF and + ord(data[1]) >= 0xDC00 and ord(data[1]) <= 0xDFFF) + + +def surrogatePairToCodepoint(data): + char_val = (0x10000 + (ord(data[0]) - 0xD800) * 0x400 + + (ord(data[1]) - 0xDC00)) + return char_val + +# Module Factory Factory (no, this isn't Java, I know) +# Here to stop this being duplicated all over the place. + + +def moduleFactoryFactory(factory): + moduleCache = {} + + def moduleFactory(baseModule, *args, **kwargs): + if isinstance(ModuleType.__name__, type("")): + name = "_%s_factory" % baseModule.__name__ + else: + name = b"_%s_factory" % baseModule.__name__ + + kwargs_tuple = tuple(kwargs.items()) + + try: + return moduleCache[name][args][kwargs_tuple] + except KeyError: + mod = ModuleType(name) + objs = factory(baseModule, *args, **kwargs) + mod.__dict__.update(objs) + if "name" not in moduleCache: + moduleCache[name] = {} + if "args" not in moduleCache[name]: + moduleCache[name][args] = {} + if "kwargs" not in moduleCache[name][args]: + moduleCache[name][args][kwargs_tuple] = {} + moduleCache[name][args][kwargs_tuple] = mod + return mod + + return moduleFactory + + +def memoize(func): + cache = {} + + def wrapped(*args, **kwargs): + key = (tuple(args), tuple(kwargs.items())) + if key not in cache: + cache[key] = func(*args, **kwargs) + return cache[key] + + return wrapped diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/constants.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/constants.py new file mode 100644 index 0000000..1ff8041 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/constants.py @@ -0,0 +1,2947 @@ +from __future__ import absolute_import, division, unicode_literals + +import string + +EOF = None + +E = { + "null-character": + "Null character in input stream, replaced with U+FFFD.", + "invalid-codepoint": + "Invalid codepoint in stream.", + "incorrectly-placed-solidus": + "Solidus (/) incorrectly placed in tag.", + "incorrect-cr-newline-entity": + "Incorrect CR newline entity, replaced with LF.", + "illegal-windows-1252-entity": + "Entity used with illegal number (windows-1252 reference).", + "cant-convert-numeric-entity": + "Numeric entity couldn't be converted to character " + "(codepoint U+%(charAsInt)08x).", + "illegal-codepoint-for-numeric-entity": + "Numeric entity represents an illegal codepoint: " + "U+%(charAsInt)08x.", + "numeric-entity-without-semicolon": + "Numeric entity didn't end with ';'.", + "expected-numeric-entity-but-got-eof": + "Numeric entity expected. Got end of file instead.", + "expected-numeric-entity": + "Numeric entity expected but none found.", + "named-entity-without-semicolon": + "Named entity didn't end with ';'.", + "expected-named-entity": + "Named entity expected. Got none.", + "attributes-in-end-tag": + "End tag contains unexpected attributes.", + 'self-closing-flag-on-end-tag': + "End tag contains unexpected self-closing flag.", + "expected-tag-name-but-got-right-bracket": + "Expected tag name. Got '>' instead.", + "expected-tag-name-but-got-question-mark": + "Expected tag name. Got '?' instead. (HTML doesn't " + "support processing instructions.)", + "expected-tag-name": + "Expected tag name. Got something else instead", + "expected-closing-tag-but-got-right-bracket": + "Expected closing tag. Got '>' instead. Ignoring '</>'.", + "expected-closing-tag-but-got-eof": + "Expected closing tag. Unexpected end of file.", + "expected-closing-tag-but-got-char": + "Expected closing tag. Unexpected character '%(data)s' found.", + "eof-in-tag-name": + "Unexpected end of file in the tag name.", + "expected-attribute-name-but-got-eof": + "Unexpected end of file. Expected attribute name instead.", + "eof-in-attribute-name": + "Unexpected end of file in attribute name.", + "invalid-character-in-attribute-name": + "Invalid character in attribute name", + "duplicate-attribute": + "Dropped duplicate attribute on tag.", + "expected-end-of-tag-name-but-got-eof": + "Unexpected end of file. Expected = or end of tag.", + "expected-attribute-value-but-got-eof": + "Unexpected end of file. Expected attribute value.", + "expected-attribute-value-but-got-right-bracket": + "Expected attribute value. Got '>' instead.", + 'equals-in-unquoted-attribute-value': + "Unexpected = in unquoted attribute", + 'unexpected-character-in-unquoted-attribute-value': + "Unexpected character in unquoted attribute", + "invalid-character-after-attribute-name": + "Unexpected character after attribute name.", + "unexpected-character-after-attribute-value": + "Unexpected character after attribute value.", + "eof-in-attribute-value-double-quote": + "Unexpected end of file in attribute value (\").", + "eof-in-attribute-value-single-quote": + "Unexpected end of file in attribute value (').", + "eof-in-attribute-value-no-quotes": + "Unexpected end of file in attribute value.", + "unexpected-EOF-after-solidus-in-tag": + "Unexpected end of file in tag. Expected >", + "unexpected-character-after-solidus-in-tag": + "Unexpected character after / in tag. Expected >", + "expected-dashes-or-doctype": + "Expected '--' or 'DOCTYPE'. Not found.", + "unexpected-bang-after-double-dash-in-comment": + "Unexpected ! after -- in comment", + "unexpected-space-after-double-dash-in-comment": + "Unexpected space after -- in comment", + "incorrect-comment": + "Incorrect comment.", + "eof-in-comment": + "Unexpected end of file in comment.", + "eof-in-comment-end-dash": + "Unexpected end of file in comment (-)", + "unexpected-dash-after-double-dash-in-comment": + "Unexpected '-' after '--' found in comment.", + "eof-in-comment-double-dash": + "Unexpected end of file in comment (--).", + "eof-in-comment-end-space-state": + "Unexpected end of file in comment.", + "eof-in-comment-end-bang-state": + "Unexpected end of file in comment.", + "unexpected-char-in-comment": + "Unexpected character in comment found.", + "need-space-after-doctype": + "No space after literal string 'DOCTYPE'.", + "expected-doctype-name-but-got-right-bracket": + "Unexpected > character. Expected DOCTYPE name.", + "expected-doctype-name-but-got-eof": + "Unexpected end of file. Expected DOCTYPE name.", + "eof-in-doctype-name": + "Unexpected end of file in DOCTYPE name.", + "eof-in-doctype": + "Unexpected end of file in DOCTYPE.", + "expected-space-or-right-bracket-in-doctype": + "Expected space or '>'. Got '%(data)s'", + "unexpected-end-of-doctype": + "Unexpected end of DOCTYPE.", + "unexpected-char-in-doctype": + "Unexpected character in DOCTYPE.", + "eof-in-innerhtml": + "XXX innerHTML EOF", + "unexpected-doctype": + "Unexpected DOCTYPE. Ignored.", + "non-html-root": + "html needs to be the first start tag.", + "expected-doctype-but-got-eof": + "Unexpected End of file. Expected DOCTYPE.", + "unknown-doctype": + "Erroneous DOCTYPE.", + "expected-doctype-but-got-chars": + "Unexpected non-space characters. Expected DOCTYPE.", + "expected-doctype-but-got-start-tag": + "Unexpected start tag (%(name)s). Expected DOCTYPE.", + "expected-doctype-but-got-end-tag": + "Unexpected end tag (%(name)s). Expected DOCTYPE.", + "end-tag-after-implied-root": + "Unexpected end tag (%(name)s) after the (implied) root element.", + "expected-named-closing-tag-but-got-eof": + "Unexpected end of file. Expected end tag (%(name)s).", + "two-heads-are-not-better-than-one": + "Unexpected start tag head in existing head. Ignored.", + "unexpected-end-tag": + "Unexpected end tag (%(name)s). Ignored.", + "unexpected-start-tag-out-of-my-head": + "Unexpected start tag (%(name)s) that can be in head. Moved.", + "unexpected-start-tag": + "Unexpected start tag (%(name)s).", + "missing-end-tag": + "Missing end tag (%(name)s).", + "missing-end-tags": + "Missing end tags (%(name)s).", + "unexpected-start-tag-implies-end-tag": + "Unexpected start tag (%(startName)s) " + "implies end tag (%(endName)s).", + "unexpected-start-tag-treated-as": + "Unexpected start tag (%(originalName)s). Treated as %(newName)s.", + "deprecated-tag": + "Unexpected start tag %(name)s. Don't use it!", + "unexpected-start-tag-ignored": + "Unexpected start tag %(name)s. Ignored.", + "expected-one-end-tag-but-got-another": + "Unexpected end tag (%(gotName)s). " + "Missing end tag (%(expectedName)s).", + "end-tag-too-early": + "End tag (%(name)s) seen too early. Expected other end tag.", + "end-tag-too-early-named": + "Unexpected end tag (%(gotName)s). Expected end tag (%(expectedName)s).", + "end-tag-too-early-ignored": + "End tag (%(name)s) seen too early. Ignored.", + "adoption-agency-1.1": + "End tag (%(name)s) violates step 1, " + "paragraph 1 of the adoption agency algorithm.", + "adoption-agency-1.2": + "End tag (%(name)s) violates step 1, " + "paragraph 2 of the adoption agency algorithm.", + "adoption-agency-1.3": + "End tag (%(name)s) violates step 1, " + "paragraph 3 of the adoption agency algorithm.", + "adoption-agency-4.4": + "End tag (%(name)s) violates step 4, " + "paragraph 4 of the adoption agency algorithm.", + "unexpected-end-tag-treated-as": + "Unexpected end tag (%(originalName)s). Treated as %(newName)s.", + "no-end-tag": + "This element (%(name)s) has no end tag.", + "unexpected-implied-end-tag-in-table": + "Unexpected implied end tag (%(name)s) in the table phase.", + "unexpected-implied-end-tag-in-table-body": + "Unexpected implied end tag (%(name)s) in the table body phase.", + "unexpected-char-implies-table-voodoo": + "Unexpected non-space characters in " + "table context caused voodoo mode.", + "unexpected-hidden-input-in-table": + "Unexpected input with type hidden in table context.", + "unexpected-form-in-table": + "Unexpected form in table context.", + "unexpected-start-tag-implies-table-voodoo": + "Unexpected start tag (%(name)s) in " + "table context caused voodoo mode.", + "unexpected-end-tag-implies-table-voodoo": + "Unexpected end tag (%(name)s) in " + "table context caused voodoo mode.", + "unexpected-cell-in-table-body": + "Unexpected table cell start tag (%(name)s) " + "in the table body phase.", + "unexpected-cell-end-tag": + "Got table cell end tag (%(name)s) " + "while required end tags are missing.", + "unexpected-end-tag-in-table-body": + "Unexpected end tag (%(name)s) in the table body phase. Ignored.", + "unexpected-implied-end-tag-in-table-row": + "Unexpected implied end tag (%(name)s) in the table row phase.", + "unexpected-end-tag-in-table-row": + "Unexpected end tag (%(name)s) in the table row phase. Ignored.", + "unexpected-select-in-select": + "Unexpected select start tag in the select phase " + "treated as select end tag.", + "unexpected-input-in-select": + "Unexpected input start tag in the select phase.", + "unexpected-start-tag-in-select": + "Unexpected start tag token (%(name)s in the select phase. " + "Ignored.", + "unexpected-end-tag-in-select": + "Unexpected end tag (%(name)s) in the select phase. Ignored.", + "unexpected-table-element-start-tag-in-select-in-table": + "Unexpected table element start tag (%(name)s) in the select in table phase.", + "unexpected-table-element-end-tag-in-select-in-table": + "Unexpected table element end tag (%(name)s) in the select in table phase.", + "unexpected-char-after-body": + "Unexpected non-space characters in the after body phase.", + "unexpected-start-tag-after-body": + "Unexpected start tag token (%(name)s)" + " in the after body phase.", + "unexpected-end-tag-after-body": + "Unexpected end tag token (%(name)s)" + " in the after body phase.", + "unexpected-char-in-frameset": + "Unexpected characters in the frameset phase. Characters ignored.", + "unexpected-start-tag-in-frameset": + "Unexpected start tag token (%(name)s)" + " in the frameset phase. Ignored.", + "unexpected-frameset-in-frameset-innerhtml": + "Unexpected end tag token (frameset) " + "in the frameset phase (innerHTML).", + "unexpected-end-tag-in-frameset": + "Unexpected end tag token (%(name)s)" + " in the frameset phase. Ignored.", + "unexpected-char-after-frameset": + "Unexpected non-space characters in the " + "after frameset phase. Ignored.", + "unexpected-start-tag-after-frameset": + "Unexpected start tag (%(name)s)" + " in the after frameset phase. Ignored.", + "unexpected-end-tag-after-frameset": + "Unexpected end tag (%(name)s)" + " in the after frameset phase. Ignored.", + "unexpected-end-tag-after-body-innerhtml": + "Unexpected end tag after body(innerHtml)", + "expected-eof-but-got-char": + "Unexpected non-space characters. Expected end of file.", + "expected-eof-but-got-start-tag": + "Unexpected start tag (%(name)s)" + ". Expected end of file.", + "expected-eof-but-got-end-tag": + "Unexpected end tag (%(name)s)" + ". Expected end of file.", + "eof-in-table": + "Unexpected end of file. Expected table content.", + "eof-in-select": + "Unexpected end of file. Expected select content.", + "eof-in-frameset": + "Unexpected end of file. Expected frameset content.", + "eof-in-script-in-script": + "Unexpected end of file. Expected script content.", + "eof-in-foreign-lands": + "Unexpected end of file. Expected foreign content", + "non-void-element-with-trailing-solidus": + "Trailing solidus not allowed on element %(name)s", + "unexpected-html-element-in-foreign-content": + "Element %(name)s not allowed in a non-html context", + "unexpected-end-tag-before-html": + "Unexpected end tag (%(name)s) before html.", + "unexpected-inhead-noscript-tag": + "Element %(name)s not allowed in a inhead-noscript context", + "eof-in-head-noscript": + "Unexpected end of file. Expected inhead-noscript content", + "char-in-head-noscript": + "Unexpected non-space character. Expected inhead-noscript content", + "XXX-undefined-error": + "Undefined error (this sucks and should be fixed)", +} + +namespaces = { + "html": "http://www.w3.org/1999/xhtml", + "mathml": "http://www.w3.org/1998/Math/MathML", + "svg": "http://www.w3.org/2000/svg", + "xlink": "http://www.w3.org/1999/xlink", + "xml": "http://www.w3.org/XML/1998/namespace", + "xmlns": "http://www.w3.org/2000/xmlns/" +} + +scopingElements = frozenset([ + (namespaces["html"], "applet"), + (namespaces["html"], "caption"), + (namespaces["html"], "html"), + (namespaces["html"], "marquee"), + (namespaces["html"], "object"), + (namespaces["html"], "table"), + (namespaces["html"], "td"), + (namespaces["html"], "th"), + (namespaces["mathml"], "mi"), + (namespaces["mathml"], "mo"), + (namespaces["mathml"], "mn"), + (namespaces["mathml"], "ms"), + (namespaces["mathml"], "mtext"), + (namespaces["mathml"], "annotation-xml"), + (namespaces["svg"], "foreignObject"), + (namespaces["svg"], "desc"), + (namespaces["svg"], "title"), +]) + +formattingElements = frozenset([ + (namespaces["html"], "a"), + (namespaces["html"], "b"), + (namespaces["html"], "big"), + (namespaces["html"], "code"), + (namespaces["html"], "em"), + (namespaces["html"], "font"), + (namespaces["html"], "i"), + (namespaces["html"], "nobr"), + (namespaces["html"], "s"), + (namespaces["html"], "small"), + (namespaces["html"], "strike"), + (namespaces["html"], "strong"), + (namespaces["html"], "tt"), + (namespaces["html"], "u") +]) + +specialElements = frozenset([ + (namespaces["html"], "address"), + (namespaces["html"], "applet"), + (namespaces["html"], "area"), + (namespaces["html"], "article"), + (namespaces["html"], "aside"), + (namespaces["html"], "base"), + (namespaces["html"], "basefont"), + (namespaces["html"], "bgsound"), + (namespaces["html"], "blockquote"), + (namespaces["html"], "body"), + (namespaces["html"], "br"), + (namespaces["html"], "button"), + (namespaces["html"], "caption"), + (namespaces["html"], "center"), + (namespaces["html"], "col"), + (namespaces["html"], "colgroup"), + (namespaces["html"], "command"), + (namespaces["html"], "dd"), + (namespaces["html"], "details"), + (namespaces["html"], "dir"), + (namespaces["html"], "div"), + (namespaces["html"], "dl"), + (namespaces["html"], "dt"), + (namespaces["html"], "embed"), + (namespaces["html"], "fieldset"), + (namespaces["html"], "figure"), + (namespaces["html"], "footer"), + (namespaces["html"], "form"), + (namespaces["html"], "frame"), + (namespaces["html"], "frameset"), + (namespaces["html"], "h1"), + (namespaces["html"], "h2"), + (namespaces["html"], "h3"), + (namespaces["html"], "h4"), + (namespaces["html"], "h5"), + (namespaces["html"], "h6"), + (namespaces["html"], "head"), + (namespaces["html"], "header"), + (namespaces["html"], "hr"), + (namespaces["html"], "html"), + (namespaces["html"], "iframe"), + # Note that image is commented out in the spec as "this isn't an + # element that can end up on the stack, so it doesn't matter," + (namespaces["html"], "image"), + (namespaces["html"], "img"), + (namespaces["html"], "input"), + (namespaces["html"], "isindex"), + (namespaces["html"], "li"), + (namespaces["html"], "link"), + (namespaces["html"], "listing"), + (namespaces["html"], "marquee"), + (namespaces["html"], "menu"), + (namespaces["html"], "meta"), + (namespaces["html"], "nav"), + (namespaces["html"], "noembed"), + (namespaces["html"], "noframes"), + (namespaces["html"], "noscript"), + (namespaces["html"], "object"), + (namespaces["html"], "ol"), + (namespaces["html"], "p"), + (namespaces["html"], "param"), + (namespaces["html"], "plaintext"), + (namespaces["html"], "pre"), + (namespaces["html"], "script"), + (namespaces["html"], "section"), + (namespaces["html"], "select"), + (namespaces["html"], "style"), + (namespaces["html"], "table"), + (namespaces["html"], "tbody"), + (namespaces["html"], "td"), + (namespaces["html"], "textarea"), + (namespaces["html"], "tfoot"), + (namespaces["html"], "th"), + (namespaces["html"], "thead"), + (namespaces["html"], "title"), + (namespaces["html"], "tr"), + (namespaces["html"], "ul"), + (namespaces["html"], "wbr"), + (namespaces["html"], "xmp"), + (namespaces["svg"], "foreignObject") +]) + +htmlIntegrationPointElements = frozenset([ + (namespaces["mathml"], "annotation-xml"), + (namespaces["svg"], "foreignObject"), + (namespaces["svg"], "desc"), + (namespaces["svg"], "title") +]) + +mathmlTextIntegrationPointElements = frozenset([ + (namespaces["mathml"], "mi"), + (namespaces["mathml"], "mo"), + (namespaces["mathml"], "mn"), + (namespaces["mathml"], "ms"), + (namespaces["mathml"], "mtext") +]) + +adjustSVGAttributes = { + "attributename": "attributeName", + "attributetype": "attributeType", + "basefrequency": "baseFrequency", + "baseprofile": "baseProfile", + "calcmode": "calcMode", + "clippathunits": "clipPathUnits", + "contentscripttype": "contentScriptType", + "contentstyletype": "contentStyleType", + "diffuseconstant": "diffuseConstant", + "edgemode": "edgeMode", + "externalresourcesrequired": "externalResourcesRequired", + "filterres": "filterRes", + "filterunits": "filterUnits", + "glyphref": "glyphRef", + "gradienttransform": "gradientTransform", + "gradientunits": "gradientUnits", + "kernelmatrix": "kernelMatrix", + "kernelunitlength": "kernelUnitLength", + "keypoints": "keyPoints", + "keysplines": "keySplines", + "keytimes": "keyTimes", + "lengthadjust": "lengthAdjust", + "limitingconeangle": "limitingConeAngle", + "markerheight": "markerHeight", + "markerunits": "markerUnits", + "markerwidth": "markerWidth", + "maskcontentunits": "maskContentUnits", + "maskunits": "maskUnits", + "numoctaves": "numOctaves", + "pathlength": "pathLength", + "patterncontentunits": "patternContentUnits", + "patterntransform": "patternTransform", + "patternunits": "patternUnits", + "pointsatx": "pointsAtX", + "pointsaty": "pointsAtY", + "pointsatz": "pointsAtZ", + "preservealpha": "preserveAlpha", + "preserveaspectratio": "preserveAspectRatio", + "primitiveunits": "primitiveUnits", + "refx": "refX", + "refy": "refY", + "repeatcount": "repeatCount", + "repeatdur": "repeatDur", + "requiredextensions": "requiredExtensions", + "requiredfeatures": "requiredFeatures", + "specularconstant": "specularConstant", + "specularexponent": "specularExponent", + "spreadmethod": "spreadMethod", + "startoffset": "startOffset", + "stddeviation": "stdDeviation", + "stitchtiles": "stitchTiles", + "surfacescale": "surfaceScale", + "systemlanguage": "systemLanguage", + "tablevalues": "tableValues", + "targetx": "targetX", + "targety": "targetY", + "textlength": "textLength", + "viewbox": "viewBox", + "viewtarget": "viewTarget", + "xchannelselector": "xChannelSelector", + "ychannelselector": "yChannelSelector", + "zoomandpan": "zoomAndPan" +} + +adjustMathMLAttributes = {"definitionurl": "definitionURL"} + +adjustForeignAttributes = { + "xlink:actuate": ("xlink", "actuate", namespaces["xlink"]), + "xlink:arcrole": ("xlink", "arcrole", namespaces["xlink"]), + "xlink:href": ("xlink", "href", namespaces["xlink"]), + "xlink:role": ("xlink", "role", namespaces["xlink"]), + "xlink:show": ("xlink", "show", namespaces["xlink"]), + "xlink:title": ("xlink", "title", namespaces["xlink"]), + "xlink:type": ("xlink", "type", namespaces["xlink"]), + "xml:base": ("xml", "base", namespaces["xml"]), + "xml:lang": ("xml", "lang", namespaces["xml"]), + "xml:space": ("xml", "space", namespaces["xml"]), + "xmlns": (None, "xmlns", namespaces["xmlns"]), + "xmlns:xlink": ("xmlns", "xlink", namespaces["xmlns"]) +} + +unadjustForeignAttributes = dict([((ns, local), qname) for qname, (prefix, local, ns) in + adjustForeignAttributes.items()]) + +spaceCharacters = frozenset([ + "\t", + "\n", + "\u000C", + " ", + "\r" +]) + +tableInsertModeElements = frozenset([ + "table", + "tbody", + "tfoot", + "thead", + "tr" +]) + +asciiLowercase = frozenset(string.ascii_lowercase) +asciiUppercase = frozenset(string.ascii_uppercase) +asciiLetters = frozenset(string.ascii_letters) +digits = frozenset(string.digits) +hexDigits = frozenset(string.hexdigits) + +asciiUpper2Lower = dict([(ord(c), ord(c.lower())) + for c in string.ascii_uppercase]) + +# Heading elements need to be ordered +headingElements = ( + "h1", + "h2", + "h3", + "h4", + "h5", + "h6" +) + +voidElements = frozenset([ + "base", + "command", + "event-source", + "link", + "meta", + "hr", + "br", + "img", + "embed", + "param", + "area", + "col", + "input", + "source", + "track" +]) + +cdataElements = frozenset(['title', 'textarea']) + +rcdataElements = frozenset([ + 'style', + 'script', + 'xmp', + 'iframe', + 'noembed', + 'noframes', + 'noscript' +]) + +booleanAttributes = { + "": frozenset(["irrelevant", "itemscope"]), + "style": frozenset(["scoped"]), + "img": frozenset(["ismap"]), + "audio": frozenset(["autoplay", "controls"]), + "video": frozenset(["autoplay", "controls"]), + "script": frozenset(["defer", "async"]), + "details": frozenset(["open"]), + "datagrid": frozenset(["multiple", "disabled"]), + "command": frozenset(["hidden", "disabled", "checked", "default"]), + "hr": frozenset(["noshade"]), + "menu": frozenset(["autosubmit"]), + "fieldset": frozenset(["disabled", "readonly"]), + "option": frozenset(["disabled", "readonly", "selected"]), + "optgroup": frozenset(["disabled", "readonly"]), + "button": frozenset(["disabled", "autofocus"]), + "input": frozenset(["disabled", "readonly", "required", "autofocus", "checked", "ismap"]), + "select": frozenset(["disabled", "readonly", "autofocus", "multiple"]), + "output": frozenset(["disabled", "readonly"]), + "iframe": frozenset(["seamless"]), +} + +# entitiesWindows1252 has to be _ordered_ and needs to have an index. It +# therefore can't be a frozenset. +entitiesWindows1252 = ( + 8364, # 0x80 0x20AC EURO SIGN + 65533, # 0x81 UNDEFINED + 8218, # 0x82 0x201A SINGLE LOW-9 QUOTATION MARK + 402, # 0x83 0x0192 LATIN SMALL LETTER F WITH HOOK + 8222, # 0x84 0x201E DOUBLE LOW-9 QUOTATION MARK + 8230, # 0x85 0x2026 HORIZONTAL ELLIPSIS + 8224, # 0x86 0x2020 DAGGER + 8225, # 0x87 0x2021 DOUBLE DAGGER + 710, # 0x88 0x02C6 MODIFIER LETTER CIRCUMFLEX ACCENT + 8240, # 0x89 0x2030 PER MILLE SIGN + 352, # 0x8A 0x0160 LATIN CAPITAL LETTER S WITH CARON + 8249, # 0x8B 0x2039 SINGLE LEFT-POINTING ANGLE QUOTATION MARK + 338, # 0x8C 0x0152 LATIN CAPITAL LIGATURE OE + 65533, # 0x8D UNDEFINED + 381, # 0x8E 0x017D LATIN CAPITAL LETTER Z WITH CARON + 65533, # 0x8F UNDEFINED + 65533, # 0x90 UNDEFINED + 8216, # 0x91 0x2018 LEFT SINGLE QUOTATION MARK + 8217, # 0x92 0x2019 RIGHT SINGLE QUOTATION MARK + 8220, # 0x93 0x201C LEFT DOUBLE QUOTATION MARK + 8221, # 0x94 0x201D RIGHT DOUBLE QUOTATION MARK + 8226, # 0x95 0x2022 BULLET + 8211, # 0x96 0x2013 EN DASH + 8212, # 0x97 0x2014 EM DASH + 732, # 0x98 0x02DC SMALL TILDE + 8482, # 0x99 0x2122 TRADE MARK SIGN + 353, # 0x9A 0x0161 LATIN SMALL LETTER S WITH CARON + 8250, # 0x9B 0x203A SINGLE RIGHT-POINTING ANGLE QUOTATION MARK + 339, # 0x9C 0x0153 LATIN SMALL LIGATURE OE + 65533, # 0x9D UNDEFINED + 382, # 0x9E 0x017E LATIN SMALL LETTER Z WITH CARON + 376 # 0x9F 0x0178 LATIN CAPITAL LETTER Y WITH DIAERESIS +) + +xmlEntities = frozenset(['lt;', 'gt;', 'amp;', 'apos;', 'quot;']) + +entities = { + "AElig": "\xc6", + "AElig;": "\xc6", + "AMP": "&", + "AMP;": "&", + "Aacute": "\xc1", + "Aacute;": "\xc1", + "Abreve;": "\u0102", + "Acirc": "\xc2", + "Acirc;": "\xc2", + "Acy;": "\u0410", + "Afr;": "\U0001d504", + "Agrave": "\xc0", + "Agrave;": "\xc0", + "Alpha;": "\u0391", + "Amacr;": "\u0100", + "And;": "\u2a53", + "Aogon;": "\u0104", + "Aopf;": "\U0001d538", + "ApplyFunction;": "\u2061", + "Aring": "\xc5", + "Aring;": "\xc5", + "Ascr;": "\U0001d49c", + "Assign;": "\u2254", + "Atilde": "\xc3", + "Atilde;": "\xc3", + "Auml": "\xc4", + "Auml;": "\xc4", + "Backslash;": "\u2216", + "Barv;": "\u2ae7", + "Barwed;": "\u2306", + "Bcy;": "\u0411", + "Because;": "\u2235", + "Bernoullis;": "\u212c", + "Beta;": "\u0392", + "Bfr;": "\U0001d505", + "Bopf;": "\U0001d539", + "Breve;": "\u02d8", + "Bscr;": "\u212c", + "Bumpeq;": "\u224e", + "CHcy;": "\u0427", + "COPY": "\xa9", + "COPY;": "\xa9", + "Cacute;": "\u0106", + "Cap;": "\u22d2", + "CapitalDifferentialD;": "\u2145", + "Cayleys;": "\u212d", + "Ccaron;": "\u010c", + "Ccedil": "\xc7", + "Ccedil;": "\xc7", + "Ccirc;": "\u0108", + "Cconint;": "\u2230", + "Cdot;": "\u010a", + "Cedilla;": "\xb8", + "CenterDot;": "\xb7", + "Cfr;": "\u212d", + "Chi;": "\u03a7", + "CircleDot;": "\u2299", + "CircleMinus;": "\u2296", + "CirclePlus;": "\u2295", + "CircleTimes;": "\u2297", + "ClockwiseContourIntegral;": "\u2232", + "CloseCurlyDoubleQuote;": "\u201d", + "CloseCurlyQuote;": "\u2019", + "Colon;": "\u2237", + "Colone;": "\u2a74", + "Congruent;": "\u2261", + "Conint;": "\u222f", + "ContourIntegral;": "\u222e", + "Copf;": "\u2102", + "Coproduct;": "\u2210", + "CounterClockwiseContourIntegral;": "\u2233", + "Cross;": "\u2a2f", + "Cscr;": "\U0001d49e", + "Cup;": "\u22d3", + "CupCap;": "\u224d", + "DD;": "\u2145", + "DDotrahd;": "\u2911", + "DJcy;": "\u0402", + "DScy;": "\u0405", + "DZcy;": "\u040f", + "Dagger;": "\u2021", + "Darr;": "\u21a1", + "Dashv;": "\u2ae4", + "Dcaron;": "\u010e", + "Dcy;": "\u0414", + "Del;": "\u2207", + "Delta;": "\u0394", + "Dfr;": "\U0001d507", + "DiacriticalAcute;": "\xb4", + "DiacriticalDot;": "\u02d9", + "DiacriticalDoubleAcute;": "\u02dd", + "DiacriticalGrave;": "`", + "DiacriticalTilde;": "\u02dc", + "Diamond;": "\u22c4", + "DifferentialD;": "\u2146", + "Dopf;": "\U0001d53b", + "Dot;": "\xa8", + "DotDot;": "\u20dc", + "DotEqual;": "\u2250", + "DoubleContourIntegral;": "\u222f", + "DoubleDot;": "\xa8", + "DoubleDownArrow;": "\u21d3", + "DoubleLeftArrow;": "\u21d0", + "DoubleLeftRightArrow;": "\u21d4", + "DoubleLeftTee;": "\u2ae4", + "DoubleLongLeftArrow;": "\u27f8", + "DoubleLongLeftRightArrow;": "\u27fa", + "DoubleLongRightArrow;": "\u27f9", + "DoubleRightArrow;": "\u21d2", + "DoubleRightTee;": "\u22a8", + "DoubleUpArrow;": "\u21d1", + "DoubleUpDownArrow;": "\u21d5", + "DoubleVerticalBar;": "\u2225", + "DownArrow;": "\u2193", + "DownArrowBar;": "\u2913", + "DownArrowUpArrow;": "\u21f5", + "DownBreve;": "\u0311", + "DownLeftRightVector;": "\u2950", + "DownLeftTeeVector;": "\u295e", + "DownLeftVector;": "\u21bd", + "DownLeftVectorBar;": "\u2956", + "DownRightTeeVector;": "\u295f", + "DownRightVector;": "\u21c1", + "DownRightVectorBar;": "\u2957", + "DownTee;": "\u22a4", + "DownTeeArrow;": "\u21a7", + "Downarrow;": "\u21d3", + "Dscr;": "\U0001d49f", + "Dstrok;": "\u0110", + "ENG;": "\u014a", + "ETH": "\xd0", + "ETH;": "\xd0", + "Eacute": "\xc9", + "Eacute;": "\xc9", + "Ecaron;": "\u011a", + "Ecirc": "\xca", + "Ecirc;": "\xca", + "Ecy;": "\u042d", + "Edot;": "\u0116", + "Efr;": "\U0001d508", + "Egrave": "\xc8", + "Egrave;": "\xc8", + "Element;": "\u2208", + "Emacr;": "\u0112", + "EmptySmallSquare;": "\u25fb", + "EmptyVerySmallSquare;": "\u25ab", + "Eogon;": "\u0118", + "Eopf;": "\U0001d53c", + "Epsilon;": "\u0395", + "Equal;": "\u2a75", + "EqualTilde;": "\u2242", + "Equilibrium;": "\u21cc", + "Escr;": "\u2130", + "Esim;": "\u2a73", + "Eta;": "\u0397", + "Euml": "\xcb", + "Euml;": "\xcb", + "Exists;": "\u2203", + "ExponentialE;": "\u2147", + "Fcy;": "\u0424", + "Ffr;": "\U0001d509", + "FilledSmallSquare;": "\u25fc", + "FilledVerySmallSquare;": "\u25aa", + "Fopf;": "\U0001d53d", + "ForAll;": "\u2200", + "Fouriertrf;": "\u2131", + "Fscr;": "\u2131", + "GJcy;": "\u0403", + "GT": ">", + "GT;": ">", + "Gamma;": "\u0393", + "Gammad;": "\u03dc", + "Gbreve;": "\u011e", + "Gcedil;": "\u0122", + "Gcirc;": "\u011c", + "Gcy;": "\u0413", + "Gdot;": "\u0120", + "Gfr;": "\U0001d50a", + "Gg;": "\u22d9", + "Gopf;": "\U0001d53e", + "GreaterEqual;": "\u2265", + "GreaterEqualLess;": "\u22db", + "GreaterFullEqual;": "\u2267", + "GreaterGreater;": "\u2aa2", + "GreaterLess;": "\u2277", + "GreaterSlantEqual;": "\u2a7e", + "GreaterTilde;": "\u2273", + "Gscr;": "\U0001d4a2", + "Gt;": "\u226b", + "HARDcy;": "\u042a", + "Hacek;": "\u02c7", + "Hat;": "^", + "Hcirc;": "\u0124", + "Hfr;": "\u210c", + "HilbertSpace;": "\u210b", + "Hopf;": "\u210d", + "HorizontalLine;": "\u2500", + "Hscr;": "\u210b", + "Hstrok;": "\u0126", + "HumpDownHump;": "\u224e", + "HumpEqual;": "\u224f", + "IEcy;": "\u0415", + "IJlig;": "\u0132", + "IOcy;": "\u0401", + "Iacute": "\xcd", + "Iacute;": "\xcd", + "Icirc": "\xce", + "Icirc;": "\xce", + "Icy;": "\u0418", + "Idot;": "\u0130", + "Ifr;": "\u2111", + "Igrave": "\xcc", + "Igrave;": "\xcc", + "Im;": "\u2111", + "Imacr;": "\u012a", + "ImaginaryI;": "\u2148", + "Implies;": "\u21d2", + "Int;": "\u222c", + "Integral;": "\u222b", + "Intersection;": "\u22c2", + "InvisibleComma;": "\u2063", + "InvisibleTimes;": "\u2062", + "Iogon;": "\u012e", + "Iopf;": "\U0001d540", + "Iota;": "\u0399", + "Iscr;": "\u2110", + "Itilde;": "\u0128", + "Iukcy;": "\u0406", + "Iuml": "\xcf", + "Iuml;": "\xcf", + "Jcirc;": "\u0134", + "Jcy;": "\u0419", + "Jfr;": "\U0001d50d", + "Jopf;": "\U0001d541", + "Jscr;": "\U0001d4a5", + "Jsercy;": "\u0408", + "Jukcy;": "\u0404", + "KHcy;": "\u0425", + "KJcy;": "\u040c", + "Kappa;": "\u039a", + "Kcedil;": "\u0136", + "Kcy;": "\u041a", + "Kfr;": "\U0001d50e", + "Kopf;": "\U0001d542", + "Kscr;": "\U0001d4a6", + "LJcy;": "\u0409", + "LT": "<", + "LT;": "<", + "Lacute;": "\u0139", + "Lambda;": "\u039b", + "Lang;": "\u27ea", + "Laplacetrf;": "\u2112", + "Larr;": "\u219e", + "Lcaron;": "\u013d", + "Lcedil;": "\u013b", + "Lcy;": "\u041b", + "LeftAngleBracket;": "\u27e8", + "LeftArrow;": "\u2190", + "LeftArrowBar;": "\u21e4", + "LeftArrowRightArrow;": "\u21c6", + "LeftCeiling;": "\u2308", + "LeftDoubleBracket;": "\u27e6", + "LeftDownTeeVector;": "\u2961", + "LeftDownVector;": "\u21c3", + "LeftDownVectorBar;": "\u2959", + "LeftFloor;": "\u230a", + "LeftRightArrow;": "\u2194", + "LeftRightVector;": "\u294e", + "LeftTee;": "\u22a3", + "LeftTeeArrow;": "\u21a4", + "LeftTeeVector;": "\u295a", + "LeftTriangle;": "\u22b2", + "LeftTriangleBar;": "\u29cf", + "LeftTriangleEqual;": "\u22b4", + "LeftUpDownVector;": "\u2951", + "LeftUpTeeVector;": "\u2960", + "LeftUpVector;": "\u21bf", + "LeftUpVectorBar;": "\u2958", + "LeftVector;": "\u21bc", + "LeftVectorBar;": "\u2952", + "Leftarrow;": "\u21d0", + "Leftrightarrow;": "\u21d4", + "LessEqualGreater;": "\u22da", + "LessFullEqual;": "\u2266", + "LessGreater;": "\u2276", + "LessLess;": "\u2aa1", + "LessSlantEqual;": "\u2a7d", + "LessTilde;": "\u2272", + "Lfr;": "\U0001d50f", + "Ll;": "\u22d8", + "Lleftarrow;": "\u21da", + "Lmidot;": "\u013f", + "LongLeftArrow;": "\u27f5", + "LongLeftRightArrow;": "\u27f7", + "LongRightArrow;": "\u27f6", + "Longleftarrow;": "\u27f8", + "Longleftrightarrow;": "\u27fa", + "Longrightarrow;": "\u27f9", + "Lopf;": "\U0001d543", + "LowerLeftArrow;": "\u2199", + "LowerRightArrow;": "\u2198", + "Lscr;": "\u2112", + "Lsh;": "\u21b0", + "Lstrok;": "\u0141", + "Lt;": "\u226a", + "Map;": "\u2905", + "Mcy;": "\u041c", + "MediumSpace;": "\u205f", + "Mellintrf;": "\u2133", + "Mfr;": "\U0001d510", + "MinusPlus;": "\u2213", + "Mopf;": "\U0001d544", + "Mscr;": "\u2133", + "Mu;": "\u039c", + "NJcy;": "\u040a", + "Nacute;": "\u0143", + "Ncaron;": "\u0147", + "Ncedil;": "\u0145", + "Ncy;": "\u041d", + "NegativeMediumSpace;": "\u200b", + "NegativeThickSpace;": "\u200b", + "NegativeThinSpace;": "\u200b", + "NegativeVeryThinSpace;": "\u200b", + "NestedGreaterGreater;": "\u226b", + "NestedLessLess;": "\u226a", + "NewLine;": "\n", + "Nfr;": "\U0001d511", + "NoBreak;": "\u2060", + "NonBreakingSpace;": "\xa0", + "Nopf;": "\u2115", + "Not;": "\u2aec", + "NotCongruent;": "\u2262", + "NotCupCap;": "\u226d", + "NotDoubleVerticalBar;": "\u2226", + "NotElement;": "\u2209", + "NotEqual;": "\u2260", + "NotEqualTilde;": "\u2242\u0338", + "NotExists;": "\u2204", + "NotGreater;": "\u226f", + "NotGreaterEqual;": "\u2271", + "NotGreaterFullEqual;": "\u2267\u0338", + "NotGreaterGreater;": "\u226b\u0338", + "NotGreaterLess;": "\u2279", + "NotGreaterSlantEqual;": "\u2a7e\u0338", + "NotGreaterTilde;": "\u2275", + "NotHumpDownHump;": "\u224e\u0338", + "NotHumpEqual;": "\u224f\u0338", + "NotLeftTriangle;": "\u22ea", + "NotLeftTriangleBar;": "\u29cf\u0338", + "NotLeftTriangleEqual;": "\u22ec", + "NotLess;": "\u226e", + "NotLessEqual;": "\u2270", + "NotLessGreater;": "\u2278", + "NotLessLess;": "\u226a\u0338", + "NotLessSlantEqual;": "\u2a7d\u0338", + "NotLessTilde;": "\u2274", + "NotNestedGreaterGreater;": "\u2aa2\u0338", + "NotNestedLessLess;": "\u2aa1\u0338", + "NotPrecedes;": "\u2280", + "NotPrecedesEqual;": "\u2aaf\u0338", + "NotPrecedesSlantEqual;": "\u22e0", + "NotReverseElement;": "\u220c", + "NotRightTriangle;": "\u22eb", + "NotRightTriangleBar;": "\u29d0\u0338", + "NotRightTriangleEqual;": "\u22ed", + "NotSquareSubset;": "\u228f\u0338", + "NotSquareSubsetEqual;": "\u22e2", + "NotSquareSuperset;": "\u2290\u0338", + "NotSquareSupersetEqual;": "\u22e3", + "NotSubset;": "\u2282\u20d2", + "NotSubsetEqual;": "\u2288", + "NotSucceeds;": "\u2281", + "NotSucceedsEqual;": "\u2ab0\u0338", + "NotSucceedsSlantEqual;": "\u22e1", + "NotSucceedsTilde;": "\u227f\u0338", + "NotSuperset;": "\u2283\u20d2", + "NotSupersetEqual;": "\u2289", + "NotTilde;": "\u2241", + "NotTildeEqual;": "\u2244", + "NotTildeFullEqual;": "\u2247", + "NotTildeTilde;": "\u2249", + "NotVerticalBar;": "\u2224", + "Nscr;": "\U0001d4a9", + "Ntilde": "\xd1", + "Ntilde;": "\xd1", + "Nu;": "\u039d", + "OElig;": "\u0152", + "Oacute": "\xd3", + "Oacute;": "\xd3", + "Ocirc": "\xd4", + "Ocirc;": "\xd4", + "Ocy;": "\u041e", + "Odblac;": "\u0150", + "Ofr;": "\U0001d512", + "Ograve": "\xd2", + "Ograve;": "\xd2", + "Omacr;": "\u014c", + "Omega;": "\u03a9", + "Omicron;": "\u039f", + "Oopf;": "\U0001d546", + "OpenCurlyDoubleQuote;": "\u201c", + "OpenCurlyQuote;": "\u2018", + "Or;": "\u2a54", + "Oscr;": "\U0001d4aa", + "Oslash": "\xd8", + "Oslash;": "\xd8", + "Otilde": "\xd5", + "Otilde;": "\xd5", + "Otimes;": "\u2a37", + "Ouml": "\xd6", + "Ouml;": "\xd6", + "OverBar;": "\u203e", + "OverBrace;": "\u23de", + "OverBracket;": "\u23b4", + "OverParenthesis;": "\u23dc", + "PartialD;": "\u2202", + "Pcy;": "\u041f", + "Pfr;": "\U0001d513", + "Phi;": "\u03a6", + "Pi;": "\u03a0", + "PlusMinus;": "\xb1", + "Poincareplane;": "\u210c", + "Popf;": "\u2119", + "Pr;": "\u2abb", + "Precedes;": "\u227a", + "PrecedesEqual;": "\u2aaf", + "PrecedesSlantEqual;": "\u227c", + "PrecedesTilde;": "\u227e", + "Prime;": "\u2033", + "Product;": "\u220f", + "Proportion;": "\u2237", + "Proportional;": "\u221d", + "Pscr;": "\U0001d4ab", + "Psi;": "\u03a8", + "QUOT": "\"", + "QUOT;": "\"", + "Qfr;": "\U0001d514", + "Qopf;": "\u211a", + "Qscr;": "\U0001d4ac", + "RBarr;": "\u2910", + "REG": "\xae", + "REG;": "\xae", + "Racute;": "\u0154", + "Rang;": "\u27eb", + "Rarr;": "\u21a0", + "Rarrtl;": "\u2916", + "Rcaron;": "\u0158", + "Rcedil;": "\u0156", + "Rcy;": "\u0420", + "Re;": "\u211c", + "ReverseElement;": "\u220b", + "ReverseEquilibrium;": "\u21cb", + "ReverseUpEquilibrium;": "\u296f", + "Rfr;": "\u211c", + "Rho;": "\u03a1", + "RightAngleBracket;": "\u27e9", + "RightArrow;": "\u2192", + "RightArrowBar;": "\u21e5", + "RightArrowLeftArrow;": "\u21c4", + "RightCeiling;": "\u2309", + "RightDoubleBracket;": "\u27e7", + "RightDownTeeVector;": "\u295d", + "RightDownVector;": "\u21c2", + "RightDownVectorBar;": "\u2955", + "RightFloor;": "\u230b", + "RightTee;": "\u22a2", + "RightTeeArrow;": "\u21a6", + "RightTeeVector;": "\u295b", + "RightTriangle;": "\u22b3", + "RightTriangleBar;": "\u29d0", + "RightTriangleEqual;": "\u22b5", + "RightUpDownVector;": "\u294f", + "RightUpTeeVector;": "\u295c", + "RightUpVector;": "\u21be", + "RightUpVectorBar;": "\u2954", + "RightVector;": "\u21c0", + "RightVectorBar;": "\u2953", + "Rightarrow;": "\u21d2", + "Ropf;": "\u211d", + "RoundImplies;": "\u2970", + "Rrightarrow;": "\u21db", + "Rscr;": "\u211b", + "Rsh;": "\u21b1", + "RuleDelayed;": "\u29f4", + "SHCHcy;": "\u0429", + "SHcy;": "\u0428", + "SOFTcy;": "\u042c", + "Sacute;": "\u015a", + "Sc;": "\u2abc", + "Scaron;": "\u0160", + "Scedil;": "\u015e", + "Scirc;": "\u015c", + "Scy;": "\u0421", + "Sfr;": "\U0001d516", + "ShortDownArrow;": "\u2193", + "ShortLeftArrow;": "\u2190", + "ShortRightArrow;": "\u2192", + "ShortUpArrow;": "\u2191", + "Sigma;": "\u03a3", + "SmallCircle;": "\u2218", + "Sopf;": "\U0001d54a", + "Sqrt;": "\u221a", + "Square;": "\u25a1", + "SquareIntersection;": "\u2293", + "SquareSubset;": "\u228f", + "SquareSubsetEqual;": "\u2291", + "SquareSuperset;": "\u2290", + "SquareSupersetEqual;": "\u2292", + "SquareUnion;": "\u2294", + "Sscr;": "\U0001d4ae", + "Star;": "\u22c6", + "Sub;": "\u22d0", + "Subset;": "\u22d0", + "SubsetEqual;": "\u2286", + "Succeeds;": "\u227b", + "SucceedsEqual;": "\u2ab0", + "SucceedsSlantEqual;": "\u227d", + "SucceedsTilde;": "\u227f", + "SuchThat;": "\u220b", + "Sum;": "\u2211", + "Sup;": "\u22d1", + "Superset;": "\u2283", + "SupersetEqual;": "\u2287", + "Supset;": "\u22d1", + "THORN": "\xde", + "THORN;": "\xde", + "TRADE;": "\u2122", + "TSHcy;": "\u040b", + "TScy;": "\u0426", + "Tab;": "\t", + "Tau;": "\u03a4", + "Tcaron;": "\u0164", + "Tcedil;": "\u0162", + "Tcy;": "\u0422", + "Tfr;": "\U0001d517", + "Therefore;": "\u2234", + "Theta;": "\u0398", + "ThickSpace;": "\u205f\u200a", + "ThinSpace;": "\u2009", + "Tilde;": "\u223c", + "TildeEqual;": "\u2243", + "TildeFullEqual;": "\u2245", + "TildeTilde;": "\u2248", + "Topf;": "\U0001d54b", + "TripleDot;": "\u20db", + "Tscr;": "\U0001d4af", + "Tstrok;": "\u0166", + "Uacute": "\xda", + "Uacute;": "\xda", + "Uarr;": "\u219f", + "Uarrocir;": "\u2949", + "Ubrcy;": "\u040e", + "Ubreve;": "\u016c", + "Ucirc": "\xdb", + "Ucirc;": "\xdb", + "Ucy;": "\u0423", + "Udblac;": "\u0170", + "Ufr;": "\U0001d518", + "Ugrave": "\xd9", + "Ugrave;": "\xd9", + "Umacr;": "\u016a", + "UnderBar;": "_", + "UnderBrace;": "\u23df", + "UnderBracket;": "\u23b5", + "UnderParenthesis;": "\u23dd", + "Union;": "\u22c3", + "UnionPlus;": "\u228e", + "Uogon;": "\u0172", + "Uopf;": "\U0001d54c", + "UpArrow;": "\u2191", + "UpArrowBar;": "\u2912", + "UpArrowDownArrow;": "\u21c5", + "UpDownArrow;": "\u2195", + "UpEquilibrium;": "\u296e", + "UpTee;": "\u22a5", + "UpTeeArrow;": "\u21a5", + "Uparrow;": "\u21d1", + "Updownarrow;": "\u21d5", + "UpperLeftArrow;": "\u2196", + "UpperRightArrow;": "\u2197", + "Upsi;": "\u03d2", + "Upsilon;": "\u03a5", + "Uring;": "\u016e", + "Uscr;": "\U0001d4b0", + "Utilde;": "\u0168", + "Uuml": "\xdc", + "Uuml;": "\xdc", + "VDash;": "\u22ab", + "Vbar;": "\u2aeb", + "Vcy;": "\u0412", + "Vdash;": "\u22a9", + "Vdashl;": "\u2ae6", + "Vee;": "\u22c1", + "Verbar;": "\u2016", + "Vert;": "\u2016", + "VerticalBar;": "\u2223", + "VerticalLine;": "|", + "VerticalSeparator;": "\u2758", + "VerticalTilde;": "\u2240", + "VeryThinSpace;": "\u200a", + "Vfr;": "\U0001d519", + "Vopf;": "\U0001d54d", + "Vscr;": "\U0001d4b1", + "Vvdash;": "\u22aa", + "Wcirc;": "\u0174", + "Wedge;": "\u22c0", + "Wfr;": "\U0001d51a", + "Wopf;": "\U0001d54e", + "Wscr;": "\U0001d4b2", + "Xfr;": "\U0001d51b", + "Xi;": "\u039e", + "Xopf;": "\U0001d54f", + "Xscr;": "\U0001d4b3", + "YAcy;": "\u042f", + "YIcy;": "\u0407", + "YUcy;": "\u042e", + "Yacute": "\xdd", + "Yacute;": "\xdd", + "Ycirc;": "\u0176", + "Ycy;": "\u042b", + "Yfr;": "\U0001d51c", + "Yopf;": "\U0001d550", + "Yscr;": "\U0001d4b4", + "Yuml;": "\u0178", + "ZHcy;": "\u0416", + "Zacute;": "\u0179", + "Zcaron;": "\u017d", + "Zcy;": "\u0417", + "Zdot;": "\u017b", + "ZeroWidthSpace;": "\u200b", + "Zeta;": "\u0396", + "Zfr;": "\u2128", + "Zopf;": "\u2124", + "Zscr;": "\U0001d4b5", + "aacute": "\xe1", + "aacute;": "\xe1", + "abreve;": "\u0103", + "ac;": "\u223e", + "acE;": "\u223e\u0333", + "acd;": "\u223f", + "acirc": "\xe2", + "acirc;": "\xe2", + "acute": "\xb4", + "acute;": "\xb4", + "acy;": "\u0430", + "aelig": "\xe6", + "aelig;": "\xe6", + "af;": "\u2061", + "afr;": "\U0001d51e", + "agrave": "\xe0", + "agrave;": "\xe0", + "alefsym;": "\u2135", + "aleph;": "\u2135", + "alpha;": "\u03b1", + "amacr;": "\u0101", + "amalg;": "\u2a3f", + "amp": "&", + "amp;": "&", + "and;": "\u2227", + "andand;": "\u2a55", + "andd;": "\u2a5c", + "andslope;": "\u2a58", + "andv;": "\u2a5a", + "ang;": "\u2220", + "ange;": "\u29a4", + "angle;": "\u2220", + "angmsd;": "\u2221", + "angmsdaa;": "\u29a8", + "angmsdab;": "\u29a9", + "angmsdac;": "\u29aa", + "angmsdad;": "\u29ab", + "angmsdae;": "\u29ac", + "angmsdaf;": "\u29ad", + "angmsdag;": "\u29ae", + "angmsdah;": "\u29af", + "angrt;": "\u221f", + "angrtvb;": "\u22be", + "angrtvbd;": "\u299d", + "angsph;": "\u2222", + "angst;": "\xc5", + "angzarr;": "\u237c", + "aogon;": "\u0105", + "aopf;": "\U0001d552", + "ap;": "\u2248", + "apE;": "\u2a70", + "apacir;": "\u2a6f", + "ape;": "\u224a", + "apid;": "\u224b", + "apos;": "'", + "approx;": "\u2248", + "approxeq;": "\u224a", + "aring": "\xe5", + "aring;": "\xe5", + "ascr;": "\U0001d4b6", + "ast;": "*", + "asymp;": "\u2248", + "asympeq;": "\u224d", + "atilde": "\xe3", + "atilde;": "\xe3", + "auml": "\xe4", + "auml;": "\xe4", + "awconint;": "\u2233", + "awint;": "\u2a11", + "bNot;": "\u2aed", + "backcong;": "\u224c", + "backepsilon;": "\u03f6", + "backprime;": "\u2035", + "backsim;": "\u223d", + "backsimeq;": "\u22cd", + "barvee;": "\u22bd", + "barwed;": "\u2305", + "barwedge;": "\u2305", + "bbrk;": "\u23b5", + "bbrktbrk;": "\u23b6", + "bcong;": "\u224c", + "bcy;": "\u0431", + "bdquo;": "\u201e", + "becaus;": "\u2235", + "because;": "\u2235", + "bemptyv;": "\u29b0", + "bepsi;": "\u03f6", + "bernou;": "\u212c", + "beta;": "\u03b2", + "beth;": "\u2136", + "between;": "\u226c", + "bfr;": "\U0001d51f", + "bigcap;": "\u22c2", + "bigcirc;": "\u25ef", + "bigcup;": "\u22c3", + "bigodot;": "\u2a00", + "bigoplus;": "\u2a01", + "bigotimes;": "\u2a02", + "bigsqcup;": "\u2a06", + "bigstar;": "\u2605", + "bigtriangledown;": "\u25bd", + "bigtriangleup;": "\u25b3", + "biguplus;": "\u2a04", + "bigvee;": "\u22c1", + "bigwedge;": "\u22c0", + "bkarow;": "\u290d", + "blacklozenge;": "\u29eb", + "blacksquare;": "\u25aa", + "blacktriangle;": "\u25b4", + "blacktriangledown;": "\u25be", + "blacktriangleleft;": "\u25c2", + "blacktriangleright;": "\u25b8", + "blank;": "\u2423", + "blk12;": "\u2592", + "blk14;": "\u2591", + "blk34;": "\u2593", + "block;": "\u2588", + "bne;": "=\u20e5", + "bnequiv;": "\u2261\u20e5", + "bnot;": "\u2310", + "bopf;": "\U0001d553", + "bot;": "\u22a5", + "bottom;": "\u22a5", + "bowtie;": "\u22c8", + "boxDL;": "\u2557", + "boxDR;": "\u2554", + "boxDl;": "\u2556", + "boxDr;": "\u2553", + "boxH;": "\u2550", + "boxHD;": "\u2566", + "boxHU;": "\u2569", + "boxHd;": "\u2564", + "boxHu;": "\u2567", + "boxUL;": "\u255d", + "boxUR;": "\u255a", + "boxUl;": "\u255c", + "boxUr;": "\u2559", + "boxV;": "\u2551", + "boxVH;": "\u256c", + "boxVL;": "\u2563", + "boxVR;": "\u2560", + "boxVh;": "\u256b", + "boxVl;": "\u2562", + "boxVr;": "\u255f", + "boxbox;": "\u29c9", + "boxdL;": "\u2555", + "boxdR;": "\u2552", + "boxdl;": "\u2510", + "boxdr;": "\u250c", + "boxh;": "\u2500", + "boxhD;": "\u2565", + "boxhU;": "\u2568", + "boxhd;": "\u252c", + "boxhu;": "\u2534", + "boxminus;": "\u229f", + "boxplus;": "\u229e", + "boxtimes;": "\u22a0", + "boxuL;": "\u255b", + "boxuR;": "\u2558", + "boxul;": "\u2518", + "boxur;": "\u2514", + "boxv;": "\u2502", + "boxvH;": "\u256a", + "boxvL;": "\u2561", + "boxvR;": "\u255e", + "boxvh;": "\u253c", + "boxvl;": "\u2524", + "boxvr;": "\u251c", + "bprime;": "\u2035", + "breve;": "\u02d8", + "brvbar": "\xa6", + "brvbar;": "\xa6", + "bscr;": "\U0001d4b7", + "bsemi;": "\u204f", + "bsim;": "\u223d", + "bsime;": "\u22cd", + "bsol;": "\\", + "bsolb;": "\u29c5", + "bsolhsub;": "\u27c8", + "bull;": "\u2022", + "bullet;": "\u2022", + "bump;": "\u224e", + "bumpE;": "\u2aae", + "bumpe;": "\u224f", + "bumpeq;": "\u224f", + "cacute;": "\u0107", + "cap;": "\u2229", + "capand;": "\u2a44", + "capbrcup;": "\u2a49", + "capcap;": "\u2a4b", + "capcup;": "\u2a47", + "capdot;": "\u2a40", + "caps;": "\u2229\ufe00", + "caret;": "\u2041", + "caron;": "\u02c7", + "ccaps;": "\u2a4d", + "ccaron;": "\u010d", + "ccedil": "\xe7", + "ccedil;": "\xe7", + "ccirc;": "\u0109", + "ccups;": "\u2a4c", + "ccupssm;": "\u2a50", + "cdot;": "\u010b", + "cedil": "\xb8", + "cedil;": "\xb8", + "cemptyv;": "\u29b2", + "cent": "\xa2", + "cent;": "\xa2", + "centerdot;": "\xb7", + "cfr;": "\U0001d520", + "chcy;": "\u0447", + "check;": "\u2713", + "checkmark;": "\u2713", + "chi;": "\u03c7", + "cir;": "\u25cb", + "cirE;": "\u29c3", + "circ;": "\u02c6", + "circeq;": "\u2257", + "circlearrowleft;": "\u21ba", + "circlearrowright;": "\u21bb", + "circledR;": "\xae", + "circledS;": "\u24c8", + "circledast;": "\u229b", + "circledcirc;": "\u229a", + "circleddash;": "\u229d", + "cire;": "\u2257", + "cirfnint;": "\u2a10", + "cirmid;": "\u2aef", + "cirscir;": "\u29c2", + "clubs;": "\u2663", + "clubsuit;": "\u2663", + "colon;": ":", + "colone;": "\u2254", + "coloneq;": "\u2254", + "comma;": ",", + "commat;": "@", + "comp;": "\u2201", + "compfn;": "\u2218", + "complement;": "\u2201", + "complexes;": "\u2102", + "cong;": "\u2245", + "congdot;": "\u2a6d", + "conint;": "\u222e", + "copf;": "\U0001d554", + "coprod;": "\u2210", + "copy": "\xa9", + "copy;": "\xa9", + "copysr;": "\u2117", + "crarr;": "\u21b5", + "cross;": "\u2717", + "cscr;": "\U0001d4b8", + "csub;": "\u2acf", + "csube;": "\u2ad1", + "csup;": "\u2ad0", + "csupe;": "\u2ad2", + "ctdot;": "\u22ef", + "cudarrl;": "\u2938", + "cudarrr;": "\u2935", + "cuepr;": "\u22de", + "cuesc;": "\u22df", + "cularr;": "\u21b6", + "cularrp;": "\u293d", + "cup;": "\u222a", + "cupbrcap;": "\u2a48", + "cupcap;": "\u2a46", + "cupcup;": "\u2a4a", + "cupdot;": "\u228d", + "cupor;": "\u2a45", + "cups;": "\u222a\ufe00", + "curarr;": "\u21b7", + "curarrm;": "\u293c", + "curlyeqprec;": "\u22de", + "curlyeqsucc;": "\u22df", + "curlyvee;": "\u22ce", + "curlywedge;": "\u22cf", + "curren": "\xa4", + "curren;": "\xa4", + "curvearrowleft;": "\u21b6", + "curvearrowright;": "\u21b7", + "cuvee;": "\u22ce", + "cuwed;": "\u22cf", + "cwconint;": "\u2232", + "cwint;": "\u2231", + "cylcty;": "\u232d", + "dArr;": "\u21d3", + "dHar;": "\u2965", + "dagger;": "\u2020", + "daleth;": "\u2138", + "darr;": "\u2193", + "dash;": "\u2010", + "dashv;": "\u22a3", + "dbkarow;": "\u290f", + "dblac;": "\u02dd", + "dcaron;": "\u010f", + "dcy;": "\u0434", + "dd;": "\u2146", + "ddagger;": "\u2021", + "ddarr;": "\u21ca", + "ddotseq;": "\u2a77", + "deg": "\xb0", + "deg;": "\xb0", + "delta;": "\u03b4", + "demptyv;": "\u29b1", + "dfisht;": "\u297f", + "dfr;": "\U0001d521", + "dharl;": "\u21c3", + "dharr;": "\u21c2", + "diam;": "\u22c4", + "diamond;": "\u22c4", + "diamondsuit;": "\u2666", + "diams;": "\u2666", + "die;": "\xa8", + "digamma;": "\u03dd", + "disin;": "\u22f2", + "div;": "\xf7", + "divide": "\xf7", + "divide;": "\xf7", + "divideontimes;": "\u22c7", + "divonx;": "\u22c7", + "djcy;": "\u0452", + "dlcorn;": "\u231e", + "dlcrop;": "\u230d", + "dollar;": "$", + "dopf;": "\U0001d555", + "dot;": "\u02d9", + "doteq;": "\u2250", + "doteqdot;": "\u2251", + "dotminus;": "\u2238", + "dotplus;": "\u2214", + "dotsquare;": "\u22a1", + "doublebarwedge;": "\u2306", + "downarrow;": "\u2193", + "downdownarrows;": "\u21ca", + "downharpoonleft;": "\u21c3", + "downharpoonright;": "\u21c2", + "drbkarow;": "\u2910", + "drcorn;": "\u231f", + "drcrop;": "\u230c", + "dscr;": "\U0001d4b9", + "dscy;": "\u0455", + "dsol;": "\u29f6", + "dstrok;": "\u0111", + "dtdot;": "\u22f1", + "dtri;": "\u25bf", + "dtrif;": "\u25be", + "duarr;": "\u21f5", + "duhar;": "\u296f", + "dwangle;": "\u29a6", + "dzcy;": "\u045f", + "dzigrarr;": "\u27ff", + "eDDot;": "\u2a77", + "eDot;": "\u2251", + "eacute": "\xe9", + "eacute;": "\xe9", + "easter;": "\u2a6e", + "ecaron;": "\u011b", + "ecir;": "\u2256", + "ecirc": "\xea", + "ecirc;": "\xea", + "ecolon;": "\u2255", + "ecy;": "\u044d", + "edot;": "\u0117", + "ee;": "\u2147", + "efDot;": "\u2252", + "efr;": "\U0001d522", + "eg;": "\u2a9a", + "egrave": "\xe8", + "egrave;": "\xe8", + "egs;": "\u2a96", + "egsdot;": "\u2a98", + "el;": "\u2a99", + "elinters;": "\u23e7", + "ell;": "\u2113", + "els;": "\u2a95", + "elsdot;": "\u2a97", + "emacr;": "\u0113", + "empty;": "\u2205", + "emptyset;": "\u2205", + "emptyv;": "\u2205", + "emsp13;": "\u2004", + "emsp14;": "\u2005", + "emsp;": "\u2003", + "eng;": "\u014b", + "ensp;": "\u2002", + "eogon;": "\u0119", + "eopf;": "\U0001d556", + "epar;": "\u22d5", + "eparsl;": "\u29e3", + "eplus;": "\u2a71", + "epsi;": "\u03b5", + "epsilon;": "\u03b5", + "epsiv;": "\u03f5", + "eqcirc;": "\u2256", + "eqcolon;": "\u2255", + "eqsim;": "\u2242", + "eqslantgtr;": "\u2a96", + "eqslantless;": "\u2a95", + "equals;": "=", + "equest;": "\u225f", + "equiv;": "\u2261", + "equivDD;": "\u2a78", + "eqvparsl;": "\u29e5", + "erDot;": "\u2253", + "erarr;": "\u2971", + "escr;": "\u212f", + "esdot;": "\u2250", + "esim;": "\u2242", + "eta;": "\u03b7", + "eth": "\xf0", + "eth;": "\xf0", + "euml": "\xeb", + "euml;": "\xeb", + "euro;": "\u20ac", + "excl;": "!", + "exist;": "\u2203", + "expectation;": "\u2130", + "exponentiale;": "\u2147", + "fallingdotseq;": "\u2252", + "fcy;": "\u0444", + "female;": "\u2640", + "ffilig;": "\ufb03", + "fflig;": "\ufb00", + "ffllig;": "\ufb04", + "ffr;": "\U0001d523", + "filig;": "\ufb01", + "fjlig;": "fj", + "flat;": "\u266d", + "fllig;": "\ufb02", + "fltns;": "\u25b1", + "fnof;": "\u0192", + "fopf;": "\U0001d557", + "forall;": "\u2200", + "fork;": "\u22d4", + "forkv;": "\u2ad9", + "fpartint;": "\u2a0d", + "frac12": "\xbd", + "frac12;": "\xbd", + "frac13;": "\u2153", + "frac14": "\xbc", + "frac14;": "\xbc", + "frac15;": "\u2155", + "frac16;": "\u2159", + "frac18;": "\u215b", + "frac23;": "\u2154", + "frac25;": "\u2156", + "frac34": "\xbe", + "frac34;": "\xbe", + "frac35;": "\u2157", + "frac38;": "\u215c", + "frac45;": "\u2158", + "frac56;": "\u215a", + "frac58;": "\u215d", + "frac78;": "\u215e", + "frasl;": "\u2044", + "frown;": "\u2322", + "fscr;": "\U0001d4bb", + "gE;": "\u2267", + "gEl;": "\u2a8c", + "gacute;": "\u01f5", + "gamma;": "\u03b3", + "gammad;": "\u03dd", + "gap;": "\u2a86", + "gbreve;": "\u011f", + "gcirc;": "\u011d", + "gcy;": "\u0433", + "gdot;": "\u0121", + "ge;": "\u2265", + "gel;": "\u22db", + "geq;": "\u2265", + "geqq;": "\u2267", + "geqslant;": "\u2a7e", + "ges;": "\u2a7e", + "gescc;": "\u2aa9", + "gesdot;": "\u2a80", + "gesdoto;": "\u2a82", + "gesdotol;": "\u2a84", + "gesl;": "\u22db\ufe00", + "gesles;": "\u2a94", + "gfr;": "\U0001d524", + "gg;": "\u226b", + "ggg;": "\u22d9", + "gimel;": "\u2137", + "gjcy;": "\u0453", + "gl;": "\u2277", + "glE;": "\u2a92", + "gla;": "\u2aa5", + "glj;": "\u2aa4", + "gnE;": "\u2269", + "gnap;": "\u2a8a", + "gnapprox;": "\u2a8a", + "gne;": "\u2a88", + "gneq;": "\u2a88", + "gneqq;": "\u2269", + "gnsim;": "\u22e7", + "gopf;": "\U0001d558", + "grave;": "`", + "gscr;": "\u210a", + "gsim;": "\u2273", + "gsime;": "\u2a8e", + "gsiml;": "\u2a90", + "gt": ">", + "gt;": ">", + "gtcc;": "\u2aa7", + "gtcir;": "\u2a7a", + "gtdot;": "\u22d7", + "gtlPar;": "\u2995", + "gtquest;": "\u2a7c", + "gtrapprox;": "\u2a86", + "gtrarr;": "\u2978", + "gtrdot;": "\u22d7", + "gtreqless;": "\u22db", + "gtreqqless;": "\u2a8c", + "gtrless;": "\u2277", + "gtrsim;": "\u2273", + "gvertneqq;": "\u2269\ufe00", + "gvnE;": "\u2269\ufe00", + "hArr;": "\u21d4", + "hairsp;": "\u200a", + "half;": "\xbd", + "hamilt;": "\u210b", + "hardcy;": "\u044a", + "harr;": "\u2194", + "harrcir;": "\u2948", + "harrw;": "\u21ad", + "hbar;": "\u210f", + "hcirc;": "\u0125", + "hearts;": "\u2665", + "heartsuit;": "\u2665", + "hellip;": "\u2026", + "hercon;": "\u22b9", + "hfr;": "\U0001d525", + "hksearow;": "\u2925", + "hkswarow;": "\u2926", + "hoarr;": "\u21ff", + "homtht;": "\u223b", + "hookleftarrow;": "\u21a9", + "hookrightarrow;": "\u21aa", + "hopf;": "\U0001d559", + "horbar;": "\u2015", + "hscr;": "\U0001d4bd", + "hslash;": "\u210f", + "hstrok;": "\u0127", + "hybull;": "\u2043", + "hyphen;": "\u2010", + "iacute": "\xed", + "iacute;": "\xed", + "ic;": "\u2063", + "icirc": "\xee", + "icirc;": "\xee", + "icy;": "\u0438", + "iecy;": "\u0435", + "iexcl": "\xa1", + "iexcl;": "\xa1", + "iff;": "\u21d4", + "ifr;": "\U0001d526", + "igrave": "\xec", + "igrave;": "\xec", + "ii;": "\u2148", + "iiiint;": "\u2a0c", + "iiint;": "\u222d", + "iinfin;": "\u29dc", + "iiota;": "\u2129", + "ijlig;": "\u0133", + "imacr;": "\u012b", + "image;": "\u2111", + "imagline;": "\u2110", + "imagpart;": "\u2111", + "imath;": "\u0131", + "imof;": "\u22b7", + "imped;": "\u01b5", + "in;": "\u2208", + "incare;": "\u2105", + "infin;": "\u221e", + "infintie;": "\u29dd", + "inodot;": "\u0131", + "int;": "\u222b", + "intcal;": "\u22ba", + "integers;": "\u2124", + "intercal;": "\u22ba", + "intlarhk;": "\u2a17", + "intprod;": "\u2a3c", + "iocy;": "\u0451", + "iogon;": "\u012f", + "iopf;": "\U0001d55a", + "iota;": "\u03b9", + "iprod;": "\u2a3c", + "iquest": "\xbf", + "iquest;": "\xbf", + "iscr;": "\U0001d4be", + "isin;": "\u2208", + "isinE;": "\u22f9", + "isindot;": "\u22f5", + "isins;": "\u22f4", + "isinsv;": "\u22f3", + "isinv;": "\u2208", + "it;": "\u2062", + "itilde;": "\u0129", + "iukcy;": "\u0456", + "iuml": "\xef", + "iuml;": "\xef", + "jcirc;": "\u0135", + "jcy;": "\u0439", + "jfr;": "\U0001d527", + "jmath;": "\u0237", + "jopf;": "\U0001d55b", + "jscr;": "\U0001d4bf", + "jsercy;": "\u0458", + "jukcy;": "\u0454", + "kappa;": "\u03ba", + "kappav;": "\u03f0", + "kcedil;": "\u0137", + "kcy;": "\u043a", + "kfr;": "\U0001d528", + "kgreen;": "\u0138", + "khcy;": "\u0445", + "kjcy;": "\u045c", + "kopf;": "\U0001d55c", + "kscr;": "\U0001d4c0", + "lAarr;": "\u21da", + "lArr;": "\u21d0", + "lAtail;": "\u291b", + "lBarr;": "\u290e", + "lE;": "\u2266", + "lEg;": "\u2a8b", + "lHar;": "\u2962", + "lacute;": "\u013a", + "laemptyv;": "\u29b4", + "lagran;": "\u2112", + "lambda;": "\u03bb", + "lang;": "\u27e8", + "langd;": "\u2991", + "langle;": "\u27e8", + "lap;": "\u2a85", + "laquo": "\xab", + "laquo;": "\xab", + "larr;": "\u2190", + "larrb;": "\u21e4", + "larrbfs;": "\u291f", + "larrfs;": "\u291d", + "larrhk;": "\u21a9", + "larrlp;": "\u21ab", + "larrpl;": "\u2939", + "larrsim;": "\u2973", + "larrtl;": "\u21a2", + "lat;": "\u2aab", + "latail;": "\u2919", + "late;": "\u2aad", + "lates;": "\u2aad\ufe00", + "lbarr;": "\u290c", + "lbbrk;": "\u2772", + "lbrace;": "{", + "lbrack;": "[", + "lbrke;": "\u298b", + "lbrksld;": "\u298f", + "lbrkslu;": "\u298d", + "lcaron;": "\u013e", + "lcedil;": "\u013c", + "lceil;": "\u2308", + "lcub;": "{", + "lcy;": "\u043b", + "ldca;": "\u2936", + "ldquo;": "\u201c", + "ldquor;": "\u201e", + "ldrdhar;": "\u2967", + "ldrushar;": "\u294b", + "ldsh;": "\u21b2", + "le;": "\u2264", + "leftarrow;": "\u2190", + "leftarrowtail;": "\u21a2", + "leftharpoondown;": "\u21bd", + "leftharpoonup;": "\u21bc", + "leftleftarrows;": "\u21c7", + "leftrightarrow;": "\u2194", + "leftrightarrows;": "\u21c6", + "leftrightharpoons;": "\u21cb", + "leftrightsquigarrow;": "\u21ad", + "leftthreetimes;": "\u22cb", + "leg;": "\u22da", + "leq;": "\u2264", + "leqq;": "\u2266", + "leqslant;": "\u2a7d", + "les;": "\u2a7d", + "lescc;": "\u2aa8", + "lesdot;": "\u2a7f", + "lesdoto;": "\u2a81", + "lesdotor;": "\u2a83", + "lesg;": "\u22da\ufe00", + "lesges;": "\u2a93", + "lessapprox;": "\u2a85", + "lessdot;": "\u22d6", + "lesseqgtr;": "\u22da", + "lesseqqgtr;": "\u2a8b", + "lessgtr;": "\u2276", + "lesssim;": "\u2272", + "lfisht;": "\u297c", + "lfloor;": "\u230a", + "lfr;": "\U0001d529", + "lg;": "\u2276", + "lgE;": "\u2a91", + "lhard;": "\u21bd", + "lharu;": "\u21bc", + "lharul;": "\u296a", + "lhblk;": "\u2584", + "ljcy;": "\u0459", + "ll;": "\u226a", + "llarr;": "\u21c7", + "llcorner;": "\u231e", + "llhard;": "\u296b", + "lltri;": "\u25fa", + "lmidot;": "\u0140", + "lmoust;": "\u23b0", + "lmoustache;": "\u23b0", + "lnE;": "\u2268", + "lnap;": "\u2a89", + "lnapprox;": "\u2a89", + "lne;": "\u2a87", + "lneq;": "\u2a87", + "lneqq;": "\u2268", + "lnsim;": "\u22e6", + "loang;": "\u27ec", + "loarr;": "\u21fd", + "lobrk;": "\u27e6", + "longleftarrow;": "\u27f5", + "longleftrightarrow;": "\u27f7", + "longmapsto;": "\u27fc", + "longrightarrow;": "\u27f6", + "looparrowleft;": "\u21ab", + "looparrowright;": "\u21ac", + "lopar;": "\u2985", + "lopf;": "\U0001d55d", + "loplus;": "\u2a2d", + "lotimes;": "\u2a34", + "lowast;": "\u2217", + "lowbar;": "_", + "loz;": "\u25ca", + "lozenge;": "\u25ca", + "lozf;": "\u29eb", + "lpar;": "(", + "lparlt;": "\u2993", + "lrarr;": "\u21c6", + "lrcorner;": "\u231f", + "lrhar;": "\u21cb", + "lrhard;": "\u296d", + "lrm;": "\u200e", + "lrtri;": "\u22bf", + "lsaquo;": "\u2039", + "lscr;": "\U0001d4c1", + "lsh;": "\u21b0", + "lsim;": "\u2272", + "lsime;": "\u2a8d", + "lsimg;": "\u2a8f", + "lsqb;": "[", + "lsquo;": "\u2018", + "lsquor;": "\u201a", + "lstrok;": "\u0142", + "lt": "<", + "lt;": "<", + "ltcc;": "\u2aa6", + "ltcir;": "\u2a79", + "ltdot;": "\u22d6", + "lthree;": "\u22cb", + "ltimes;": "\u22c9", + "ltlarr;": "\u2976", + "ltquest;": "\u2a7b", + "ltrPar;": "\u2996", + "ltri;": "\u25c3", + "ltrie;": "\u22b4", + "ltrif;": "\u25c2", + "lurdshar;": "\u294a", + "luruhar;": "\u2966", + "lvertneqq;": "\u2268\ufe00", + "lvnE;": "\u2268\ufe00", + "mDDot;": "\u223a", + "macr": "\xaf", + "macr;": "\xaf", + "male;": "\u2642", + "malt;": "\u2720", + "maltese;": "\u2720", + "map;": "\u21a6", + "mapsto;": "\u21a6", + "mapstodown;": "\u21a7", + "mapstoleft;": "\u21a4", + "mapstoup;": "\u21a5", + "marker;": "\u25ae", + "mcomma;": "\u2a29", + "mcy;": "\u043c", + "mdash;": "\u2014", + "measuredangle;": "\u2221", + "mfr;": "\U0001d52a", + "mho;": "\u2127", + "micro": "\xb5", + "micro;": "\xb5", + "mid;": "\u2223", + "midast;": "*", + "midcir;": "\u2af0", + "middot": "\xb7", + "middot;": "\xb7", + "minus;": "\u2212", + "minusb;": "\u229f", + "minusd;": "\u2238", + "minusdu;": "\u2a2a", + "mlcp;": "\u2adb", + "mldr;": "\u2026", + "mnplus;": "\u2213", + "models;": "\u22a7", + "mopf;": "\U0001d55e", + "mp;": "\u2213", + "mscr;": "\U0001d4c2", + "mstpos;": "\u223e", + "mu;": "\u03bc", + "multimap;": "\u22b8", + "mumap;": "\u22b8", + "nGg;": "\u22d9\u0338", + "nGt;": "\u226b\u20d2", + "nGtv;": "\u226b\u0338", + "nLeftarrow;": "\u21cd", + "nLeftrightarrow;": "\u21ce", + "nLl;": "\u22d8\u0338", + "nLt;": "\u226a\u20d2", + "nLtv;": "\u226a\u0338", + "nRightarrow;": "\u21cf", + "nVDash;": "\u22af", + "nVdash;": "\u22ae", + "nabla;": "\u2207", + "nacute;": "\u0144", + "nang;": "\u2220\u20d2", + "nap;": "\u2249", + "napE;": "\u2a70\u0338", + "napid;": "\u224b\u0338", + "napos;": "\u0149", + "napprox;": "\u2249", + "natur;": "\u266e", + "natural;": "\u266e", + "naturals;": "\u2115", + "nbsp": "\xa0", + "nbsp;": "\xa0", + "nbump;": "\u224e\u0338", + "nbumpe;": "\u224f\u0338", + "ncap;": "\u2a43", + "ncaron;": "\u0148", + "ncedil;": "\u0146", + "ncong;": "\u2247", + "ncongdot;": "\u2a6d\u0338", + "ncup;": "\u2a42", + "ncy;": "\u043d", + "ndash;": "\u2013", + "ne;": "\u2260", + "neArr;": "\u21d7", + "nearhk;": "\u2924", + "nearr;": "\u2197", + "nearrow;": "\u2197", + "nedot;": "\u2250\u0338", + "nequiv;": "\u2262", + "nesear;": "\u2928", + "nesim;": "\u2242\u0338", + "nexist;": "\u2204", + "nexists;": "\u2204", + "nfr;": "\U0001d52b", + "ngE;": "\u2267\u0338", + "nge;": "\u2271", + "ngeq;": "\u2271", + "ngeqq;": "\u2267\u0338", + "ngeqslant;": "\u2a7e\u0338", + "nges;": "\u2a7e\u0338", + "ngsim;": "\u2275", + "ngt;": "\u226f", + "ngtr;": "\u226f", + "nhArr;": "\u21ce", + "nharr;": "\u21ae", + "nhpar;": "\u2af2", + "ni;": "\u220b", + "nis;": "\u22fc", + "nisd;": "\u22fa", + "niv;": "\u220b", + "njcy;": "\u045a", + "nlArr;": "\u21cd", + "nlE;": "\u2266\u0338", + "nlarr;": "\u219a", + "nldr;": "\u2025", + "nle;": "\u2270", + "nleftarrow;": "\u219a", + "nleftrightarrow;": "\u21ae", + "nleq;": "\u2270", + "nleqq;": "\u2266\u0338", + "nleqslant;": "\u2a7d\u0338", + "nles;": "\u2a7d\u0338", + "nless;": "\u226e", + "nlsim;": "\u2274", + "nlt;": "\u226e", + "nltri;": "\u22ea", + "nltrie;": "\u22ec", + "nmid;": "\u2224", + "nopf;": "\U0001d55f", + "not": "\xac", + "not;": "\xac", + "notin;": "\u2209", + "notinE;": "\u22f9\u0338", + "notindot;": "\u22f5\u0338", + "notinva;": "\u2209", + "notinvb;": "\u22f7", + "notinvc;": "\u22f6", + "notni;": "\u220c", + "notniva;": "\u220c", + "notnivb;": "\u22fe", + "notnivc;": "\u22fd", + "npar;": "\u2226", + "nparallel;": "\u2226", + "nparsl;": "\u2afd\u20e5", + "npart;": "\u2202\u0338", + "npolint;": "\u2a14", + "npr;": "\u2280", + "nprcue;": "\u22e0", + "npre;": "\u2aaf\u0338", + "nprec;": "\u2280", + "npreceq;": "\u2aaf\u0338", + "nrArr;": "\u21cf", + "nrarr;": "\u219b", + "nrarrc;": "\u2933\u0338", + "nrarrw;": "\u219d\u0338", + "nrightarrow;": "\u219b", + "nrtri;": "\u22eb", + "nrtrie;": "\u22ed", + "nsc;": "\u2281", + "nsccue;": "\u22e1", + "nsce;": "\u2ab0\u0338", + "nscr;": "\U0001d4c3", + "nshortmid;": "\u2224", + "nshortparallel;": "\u2226", + "nsim;": "\u2241", + "nsime;": "\u2244", + "nsimeq;": "\u2244", + "nsmid;": "\u2224", + "nspar;": "\u2226", + "nsqsube;": "\u22e2", + "nsqsupe;": "\u22e3", + "nsub;": "\u2284", + "nsubE;": "\u2ac5\u0338", + "nsube;": "\u2288", + "nsubset;": "\u2282\u20d2", + "nsubseteq;": "\u2288", + "nsubseteqq;": "\u2ac5\u0338", + "nsucc;": "\u2281", + "nsucceq;": "\u2ab0\u0338", + "nsup;": "\u2285", + "nsupE;": "\u2ac6\u0338", + "nsupe;": "\u2289", + "nsupset;": "\u2283\u20d2", + "nsupseteq;": "\u2289", + "nsupseteqq;": "\u2ac6\u0338", + "ntgl;": "\u2279", + "ntilde": "\xf1", + "ntilde;": "\xf1", + "ntlg;": "\u2278", + "ntriangleleft;": "\u22ea", + "ntrianglelefteq;": "\u22ec", + "ntriangleright;": "\u22eb", + "ntrianglerighteq;": "\u22ed", + "nu;": "\u03bd", + "num;": "#", + "numero;": "\u2116", + "numsp;": "\u2007", + "nvDash;": "\u22ad", + "nvHarr;": "\u2904", + "nvap;": "\u224d\u20d2", + "nvdash;": "\u22ac", + "nvge;": "\u2265\u20d2", + "nvgt;": ">\u20d2", + "nvinfin;": "\u29de", + "nvlArr;": "\u2902", + "nvle;": "\u2264\u20d2", + "nvlt;": "<\u20d2", + "nvltrie;": "\u22b4\u20d2", + "nvrArr;": "\u2903", + "nvrtrie;": "\u22b5\u20d2", + "nvsim;": "\u223c\u20d2", + "nwArr;": "\u21d6", + "nwarhk;": "\u2923", + "nwarr;": "\u2196", + "nwarrow;": "\u2196", + "nwnear;": "\u2927", + "oS;": "\u24c8", + "oacute": "\xf3", + "oacute;": "\xf3", + "oast;": "\u229b", + "ocir;": "\u229a", + "ocirc": "\xf4", + "ocirc;": "\xf4", + "ocy;": "\u043e", + "odash;": "\u229d", + "odblac;": "\u0151", + "odiv;": "\u2a38", + "odot;": "\u2299", + "odsold;": "\u29bc", + "oelig;": "\u0153", + "ofcir;": "\u29bf", + "ofr;": "\U0001d52c", + "ogon;": "\u02db", + "ograve": "\xf2", + "ograve;": "\xf2", + "ogt;": "\u29c1", + "ohbar;": "\u29b5", + "ohm;": "\u03a9", + "oint;": "\u222e", + "olarr;": "\u21ba", + "olcir;": "\u29be", + "olcross;": "\u29bb", + "oline;": "\u203e", + "olt;": "\u29c0", + "omacr;": "\u014d", + "omega;": "\u03c9", + "omicron;": "\u03bf", + "omid;": "\u29b6", + "ominus;": "\u2296", + "oopf;": "\U0001d560", + "opar;": "\u29b7", + "operp;": "\u29b9", + "oplus;": "\u2295", + "or;": "\u2228", + "orarr;": "\u21bb", + "ord;": "\u2a5d", + "order;": "\u2134", + "orderof;": "\u2134", + "ordf": "\xaa", + "ordf;": "\xaa", + "ordm": "\xba", + "ordm;": "\xba", + "origof;": "\u22b6", + "oror;": "\u2a56", + "orslope;": "\u2a57", + "orv;": "\u2a5b", + "oscr;": "\u2134", + "oslash": "\xf8", + "oslash;": "\xf8", + "osol;": "\u2298", + "otilde": "\xf5", + "otilde;": "\xf5", + "otimes;": "\u2297", + "otimesas;": "\u2a36", + "ouml": "\xf6", + "ouml;": "\xf6", + "ovbar;": "\u233d", + "par;": "\u2225", + "para": "\xb6", + "para;": "\xb6", + "parallel;": "\u2225", + "parsim;": "\u2af3", + "parsl;": "\u2afd", + "part;": "\u2202", + "pcy;": "\u043f", + "percnt;": "%", + "period;": ".", + "permil;": "\u2030", + "perp;": "\u22a5", + "pertenk;": "\u2031", + "pfr;": "\U0001d52d", + "phi;": "\u03c6", + "phiv;": "\u03d5", + "phmmat;": "\u2133", + "phone;": "\u260e", + "pi;": "\u03c0", + "pitchfork;": "\u22d4", + "piv;": "\u03d6", + "planck;": "\u210f", + "planckh;": "\u210e", + "plankv;": "\u210f", + "plus;": "+", + "plusacir;": "\u2a23", + "plusb;": "\u229e", + "pluscir;": "\u2a22", + "plusdo;": "\u2214", + "plusdu;": "\u2a25", + "pluse;": "\u2a72", + "plusmn": "\xb1", + "plusmn;": "\xb1", + "plussim;": "\u2a26", + "plustwo;": "\u2a27", + "pm;": "\xb1", + "pointint;": "\u2a15", + "popf;": "\U0001d561", + "pound": "\xa3", + "pound;": "\xa3", + "pr;": "\u227a", + "prE;": "\u2ab3", + "prap;": "\u2ab7", + "prcue;": "\u227c", + "pre;": "\u2aaf", + "prec;": "\u227a", + "precapprox;": "\u2ab7", + "preccurlyeq;": "\u227c", + "preceq;": "\u2aaf", + "precnapprox;": "\u2ab9", + "precneqq;": "\u2ab5", + "precnsim;": "\u22e8", + "precsim;": "\u227e", + "prime;": "\u2032", + "primes;": "\u2119", + "prnE;": "\u2ab5", + "prnap;": "\u2ab9", + "prnsim;": "\u22e8", + "prod;": "\u220f", + "profalar;": "\u232e", + "profline;": "\u2312", + "profsurf;": "\u2313", + "prop;": "\u221d", + "propto;": "\u221d", + "prsim;": "\u227e", + "prurel;": "\u22b0", + "pscr;": "\U0001d4c5", + "psi;": "\u03c8", + "puncsp;": "\u2008", + "qfr;": "\U0001d52e", + "qint;": "\u2a0c", + "qopf;": "\U0001d562", + "qprime;": "\u2057", + "qscr;": "\U0001d4c6", + "quaternions;": "\u210d", + "quatint;": "\u2a16", + "quest;": "?", + "questeq;": "\u225f", + "quot": "\"", + "quot;": "\"", + "rAarr;": "\u21db", + "rArr;": "\u21d2", + "rAtail;": "\u291c", + "rBarr;": "\u290f", + "rHar;": "\u2964", + "race;": "\u223d\u0331", + "racute;": "\u0155", + "radic;": "\u221a", + "raemptyv;": "\u29b3", + "rang;": "\u27e9", + "rangd;": "\u2992", + "range;": "\u29a5", + "rangle;": "\u27e9", + "raquo": "\xbb", + "raquo;": "\xbb", + "rarr;": "\u2192", + "rarrap;": "\u2975", + "rarrb;": "\u21e5", + "rarrbfs;": "\u2920", + "rarrc;": "\u2933", + "rarrfs;": "\u291e", + "rarrhk;": "\u21aa", + "rarrlp;": "\u21ac", + "rarrpl;": "\u2945", + "rarrsim;": "\u2974", + "rarrtl;": "\u21a3", + "rarrw;": "\u219d", + "ratail;": "\u291a", + "ratio;": "\u2236", + "rationals;": "\u211a", + "rbarr;": "\u290d", + "rbbrk;": "\u2773", + "rbrace;": "}", + "rbrack;": "]", + "rbrke;": "\u298c", + "rbrksld;": "\u298e", + "rbrkslu;": "\u2990", + "rcaron;": "\u0159", + "rcedil;": "\u0157", + "rceil;": "\u2309", + "rcub;": "}", + "rcy;": "\u0440", + "rdca;": "\u2937", + "rdldhar;": "\u2969", + "rdquo;": "\u201d", + "rdquor;": "\u201d", + "rdsh;": "\u21b3", + "real;": "\u211c", + "realine;": "\u211b", + "realpart;": "\u211c", + "reals;": "\u211d", + "rect;": "\u25ad", + "reg": "\xae", + "reg;": "\xae", + "rfisht;": "\u297d", + "rfloor;": "\u230b", + "rfr;": "\U0001d52f", + "rhard;": "\u21c1", + "rharu;": "\u21c0", + "rharul;": "\u296c", + "rho;": "\u03c1", + "rhov;": "\u03f1", + "rightarrow;": "\u2192", + "rightarrowtail;": "\u21a3", + "rightharpoondown;": "\u21c1", + "rightharpoonup;": "\u21c0", + "rightleftarrows;": "\u21c4", + "rightleftharpoons;": "\u21cc", + "rightrightarrows;": "\u21c9", + "rightsquigarrow;": "\u219d", + "rightthreetimes;": "\u22cc", + "ring;": "\u02da", + "risingdotseq;": "\u2253", + "rlarr;": "\u21c4", + "rlhar;": "\u21cc", + "rlm;": "\u200f", + "rmoust;": "\u23b1", + "rmoustache;": "\u23b1", + "rnmid;": "\u2aee", + "roang;": "\u27ed", + "roarr;": "\u21fe", + "robrk;": "\u27e7", + "ropar;": "\u2986", + "ropf;": "\U0001d563", + "roplus;": "\u2a2e", + "rotimes;": "\u2a35", + "rpar;": ")", + "rpargt;": "\u2994", + "rppolint;": "\u2a12", + "rrarr;": "\u21c9", + "rsaquo;": "\u203a", + "rscr;": "\U0001d4c7", + "rsh;": "\u21b1", + "rsqb;": "]", + "rsquo;": "\u2019", + "rsquor;": "\u2019", + "rthree;": "\u22cc", + "rtimes;": "\u22ca", + "rtri;": "\u25b9", + "rtrie;": "\u22b5", + "rtrif;": "\u25b8", + "rtriltri;": "\u29ce", + "ruluhar;": "\u2968", + "rx;": "\u211e", + "sacute;": "\u015b", + "sbquo;": "\u201a", + "sc;": "\u227b", + "scE;": "\u2ab4", + "scap;": "\u2ab8", + "scaron;": "\u0161", + "sccue;": "\u227d", + "sce;": "\u2ab0", + "scedil;": "\u015f", + "scirc;": "\u015d", + "scnE;": "\u2ab6", + "scnap;": "\u2aba", + "scnsim;": "\u22e9", + "scpolint;": "\u2a13", + "scsim;": "\u227f", + "scy;": "\u0441", + "sdot;": "\u22c5", + "sdotb;": "\u22a1", + "sdote;": "\u2a66", + "seArr;": "\u21d8", + "searhk;": "\u2925", + "searr;": "\u2198", + "searrow;": "\u2198", + "sect": "\xa7", + "sect;": "\xa7", + "semi;": ";", + "seswar;": "\u2929", + "setminus;": "\u2216", + "setmn;": "\u2216", + "sext;": "\u2736", + "sfr;": "\U0001d530", + "sfrown;": "\u2322", + "sharp;": "\u266f", + "shchcy;": "\u0449", + "shcy;": "\u0448", + "shortmid;": "\u2223", + "shortparallel;": "\u2225", + "shy": "\xad", + "shy;": "\xad", + "sigma;": "\u03c3", + "sigmaf;": "\u03c2", + "sigmav;": "\u03c2", + "sim;": "\u223c", + "simdot;": "\u2a6a", + "sime;": "\u2243", + "simeq;": "\u2243", + "simg;": "\u2a9e", + "simgE;": "\u2aa0", + "siml;": "\u2a9d", + "simlE;": "\u2a9f", + "simne;": "\u2246", + "simplus;": "\u2a24", + "simrarr;": "\u2972", + "slarr;": "\u2190", + "smallsetminus;": "\u2216", + "smashp;": "\u2a33", + "smeparsl;": "\u29e4", + "smid;": "\u2223", + "smile;": "\u2323", + "smt;": "\u2aaa", + "smte;": "\u2aac", + "smtes;": "\u2aac\ufe00", + "softcy;": "\u044c", + "sol;": "/", + "solb;": "\u29c4", + "solbar;": "\u233f", + "sopf;": "\U0001d564", + "spades;": "\u2660", + "spadesuit;": "\u2660", + "spar;": "\u2225", + "sqcap;": "\u2293", + "sqcaps;": "\u2293\ufe00", + "sqcup;": "\u2294", + "sqcups;": "\u2294\ufe00", + "sqsub;": "\u228f", + "sqsube;": "\u2291", + "sqsubset;": "\u228f", + "sqsubseteq;": "\u2291", + "sqsup;": "\u2290", + "sqsupe;": "\u2292", + "sqsupset;": "\u2290", + "sqsupseteq;": "\u2292", + "squ;": "\u25a1", + "square;": "\u25a1", + "squarf;": "\u25aa", + "squf;": "\u25aa", + "srarr;": "\u2192", + "sscr;": "\U0001d4c8", + "ssetmn;": "\u2216", + "ssmile;": "\u2323", + "sstarf;": "\u22c6", + "star;": "\u2606", + "starf;": "\u2605", + "straightepsilon;": "\u03f5", + "straightphi;": "\u03d5", + "strns;": "\xaf", + "sub;": "\u2282", + "subE;": "\u2ac5", + "subdot;": "\u2abd", + "sube;": "\u2286", + "subedot;": "\u2ac3", + "submult;": "\u2ac1", + "subnE;": "\u2acb", + "subne;": "\u228a", + "subplus;": "\u2abf", + "subrarr;": "\u2979", + "subset;": "\u2282", + "subseteq;": "\u2286", + "subseteqq;": "\u2ac5", + "subsetneq;": "\u228a", + "subsetneqq;": "\u2acb", + "subsim;": "\u2ac7", + "subsub;": "\u2ad5", + "subsup;": "\u2ad3", + "succ;": "\u227b", + "succapprox;": "\u2ab8", + "succcurlyeq;": "\u227d", + "succeq;": "\u2ab0", + "succnapprox;": "\u2aba", + "succneqq;": "\u2ab6", + "succnsim;": "\u22e9", + "succsim;": "\u227f", + "sum;": "\u2211", + "sung;": "\u266a", + "sup1": "\xb9", + "sup1;": "\xb9", + "sup2": "\xb2", + "sup2;": "\xb2", + "sup3": "\xb3", + "sup3;": "\xb3", + "sup;": "\u2283", + "supE;": "\u2ac6", + "supdot;": "\u2abe", + "supdsub;": "\u2ad8", + "supe;": "\u2287", + "supedot;": "\u2ac4", + "suphsol;": "\u27c9", + "suphsub;": "\u2ad7", + "suplarr;": "\u297b", + "supmult;": "\u2ac2", + "supnE;": "\u2acc", + "supne;": "\u228b", + "supplus;": "\u2ac0", + "supset;": "\u2283", + "supseteq;": "\u2287", + "supseteqq;": "\u2ac6", + "supsetneq;": "\u228b", + "supsetneqq;": "\u2acc", + "supsim;": "\u2ac8", + "supsub;": "\u2ad4", + "supsup;": "\u2ad6", + "swArr;": "\u21d9", + "swarhk;": "\u2926", + "swarr;": "\u2199", + "swarrow;": "\u2199", + "swnwar;": "\u292a", + "szlig": "\xdf", + "szlig;": "\xdf", + "target;": "\u2316", + "tau;": "\u03c4", + "tbrk;": "\u23b4", + "tcaron;": "\u0165", + "tcedil;": "\u0163", + "tcy;": "\u0442", + "tdot;": "\u20db", + "telrec;": "\u2315", + "tfr;": "\U0001d531", + "there4;": "\u2234", + "therefore;": "\u2234", + "theta;": "\u03b8", + "thetasym;": "\u03d1", + "thetav;": "\u03d1", + "thickapprox;": "\u2248", + "thicksim;": "\u223c", + "thinsp;": "\u2009", + "thkap;": "\u2248", + "thksim;": "\u223c", + "thorn": "\xfe", + "thorn;": "\xfe", + "tilde;": "\u02dc", + "times": "\xd7", + "times;": "\xd7", + "timesb;": "\u22a0", + "timesbar;": "\u2a31", + "timesd;": "\u2a30", + "tint;": "\u222d", + "toea;": "\u2928", + "top;": "\u22a4", + "topbot;": "\u2336", + "topcir;": "\u2af1", + "topf;": "\U0001d565", + "topfork;": "\u2ada", + "tosa;": "\u2929", + "tprime;": "\u2034", + "trade;": "\u2122", + "triangle;": "\u25b5", + "triangledown;": "\u25bf", + "triangleleft;": "\u25c3", + "trianglelefteq;": "\u22b4", + "triangleq;": "\u225c", + "triangleright;": "\u25b9", + "trianglerighteq;": "\u22b5", + "tridot;": "\u25ec", + "trie;": "\u225c", + "triminus;": "\u2a3a", + "triplus;": "\u2a39", + "trisb;": "\u29cd", + "tritime;": "\u2a3b", + "trpezium;": "\u23e2", + "tscr;": "\U0001d4c9", + "tscy;": "\u0446", + "tshcy;": "\u045b", + "tstrok;": "\u0167", + "twixt;": "\u226c", + "twoheadleftarrow;": "\u219e", + "twoheadrightarrow;": "\u21a0", + "uArr;": "\u21d1", + "uHar;": "\u2963", + "uacute": "\xfa", + "uacute;": "\xfa", + "uarr;": "\u2191", + "ubrcy;": "\u045e", + "ubreve;": "\u016d", + "ucirc": "\xfb", + "ucirc;": "\xfb", + "ucy;": "\u0443", + "udarr;": "\u21c5", + "udblac;": "\u0171", + "udhar;": "\u296e", + "ufisht;": "\u297e", + "ufr;": "\U0001d532", + "ugrave": "\xf9", + "ugrave;": "\xf9", + "uharl;": "\u21bf", + "uharr;": "\u21be", + "uhblk;": "\u2580", + "ulcorn;": "\u231c", + "ulcorner;": "\u231c", + "ulcrop;": "\u230f", + "ultri;": "\u25f8", + "umacr;": "\u016b", + "uml": "\xa8", + "uml;": "\xa8", + "uogon;": "\u0173", + "uopf;": "\U0001d566", + "uparrow;": "\u2191", + "updownarrow;": "\u2195", + "upharpoonleft;": "\u21bf", + "upharpoonright;": "\u21be", + "uplus;": "\u228e", + "upsi;": "\u03c5", + "upsih;": "\u03d2", + "upsilon;": "\u03c5", + "upuparrows;": "\u21c8", + "urcorn;": "\u231d", + "urcorner;": "\u231d", + "urcrop;": "\u230e", + "uring;": "\u016f", + "urtri;": "\u25f9", + "uscr;": "\U0001d4ca", + "utdot;": "\u22f0", + "utilde;": "\u0169", + "utri;": "\u25b5", + "utrif;": "\u25b4", + "uuarr;": "\u21c8", + "uuml": "\xfc", + "uuml;": "\xfc", + "uwangle;": "\u29a7", + "vArr;": "\u21d5", + "vBar;": "\u2ae8", + "vBarv;": "\u2ae9", + "vDash;": "\u22a8", + "vangrt;": "\u299c", + "varepsilon;": "\u03f5", + "varkappa;": "\u03f0", + "varnothing;": "\u2205", + "varphi;": "\u03d5", + "varpi;": "\u03d6", + "varpropto;": "\u221d", + "varr;": "\u2195", + "varrho;": "\u03f1", + "varsigma;": "\u03c2", + "varsubsetneq;": "\u228a\ufe00", + "varsubsetneqq;": "\u2acb\ufe00", + "varsupsetneq;": "\u228b\ufe00", + "varsupsetneqq;": "\u2acc\ufe00", + "vartheta;": "\u03d1", + "vartriangleleft;": "\u22b2", + "vartriangleright;": "\u22b3", + "vcy;": "\u0432", + "vdash;": "\u22a2", + "vee;": "\u2228", + "veebar;": "\u22bb", + "veeeq;": "\u225a", + "vellip;": "\u22ee", + "verbar;": "|", + "vert;": "|", + "vfr;": "\U0001d533", + "vltri;": "\u22b2", + "vnsub;": "\u2282\u20d2", + "vnsup;": "\u2283\u20d2", + "vopf;": "\U0001d567", + "vprop;": "\u221d", + "vrtri;": "\u22b3", + "vscr;": "\U0001d4cb", + "vsubnE;": "\u2acb\ufe00", + "vsubne;": "\u228a\ufe00", + "vsupnE;": "\u2acc\ufe00", + "vsupne;": "\u228b\ufe00", + "vzigzag;": "\u299a", + "wcirc;": "\u0175", + "wedbar;": "\u2a5f", + "wedge;": "\u2227", + "wedgeq;": "\u2259", + "weierp;": "\u2118", + "wfr;": "\U0001d534", + "wopf;": "\U0001d568", + "wp;": "\u2118", + "wr;": "\u2240", + "wreath;": "\u2240", + "wscr;": "\U0001d4cc", + "xcap;": "\u22c2", + "xcirc;": "\u25ef", + "xcup;": "\u22c3", + "xdtri;": "\u25bd", + "xfr;": "\U0001d535", + "xhArr;": "\u27fa", + "xharr;": "\u27f7", + "xi;": "\u03be", + "xlArr;": "\u27f8", + "xlarr;": "\u27f5", + "xmap;": "\u27fc", + "xnis;": "\u22fb", + "xodot;": "\u2a00", + "xopf;": "\U0001d569", + "xoplus;": "\u2a01", + "xotime;": "\u2a02", + "xrArr;": "\u27f9", + "xrarr;": "\u27f6", + "xscr;": "\U0001d4cd", + "xsqcup;": "\u2a06", + "xuplus;": "\u2a04", + "xutri;": "\u25b3", + "xvee;": "\u22c1", + "xwedge;": "\u22c0", + "yacute": "\xfd", + "yacute;": "\xfd", + "yacy;": "\u044f", + "ycirc;": "\u0177", + "ycy;": "\u044b", + "yen": "\xa5", + "yen;": "\xa5", + "yfr;": "\U0001d536", + "yicy;": "\u0457", + "yopf;": "\U0001d56a", + "yscr;": "\U0001d4ce", + "yucy;": "\u044e", + "yuml": "\xff", + "yuml;": "\xff", + "zacute;": "\u017a", + "zcaron;": "\u017e", + "zcy;": "\u0437", + "zdot;": "\u017c", + "zeetrf;": "\u2128", + "zeta;": "\u03b6", + "zfr;": "\U0001d537", + "zhcy;": "\u0436", + "zigrarr;": "\u21dd", + "zopf;": "\U0001d56b", + "zscr;": "\U0001d4cf", + "zwj;": "\u200d", + "zwnj;": "\u200c", +} + +replacementCharacters = { + 0x0: "\uFFFD", + 0x0d: "\u000D", + 0x80: "\u20AC", + 0x81: "\u0081", + 0x82: "\u201A", + 0x83: "\u0192", + 0x84: "\u201E", + 0x85: "\u2026", + 0x86: "\u2020", + 0x87: "\u2021", + 0x88: "\u02C6", + 0x89: "\u2030", + 0x8A: "\u0160", + 0x8B: "\u2039", + 0x8C: "\u0152", + 0x8D: "\u008D", + 0x8E: "\u017D", + 0x8F: "\u008F", + 0x90: "\u0090", + 0x91: "\u2018", + 0x92: "\u2019", + 0x93: "\u201C", + 0x94: "\u201D", + 0x95: "\u2022", + 0x96: "\u2013", + 0x97: "\u2014", + 0x98: "\u02DC", + 0x99: "\u2122", + 0x9A: "\u0161", + 0x9B: "\u203A", + 0x9C: "\u0153", + 0x9D: "\u009D", + 0x9E: "\u017E", + 0x9F: "\u0178", +} + +tokenTypes = { + "Doctype": 0, + "Characters": 1, + "SpaceCharacters": 2, + "StartTag": 3, + "EndTag": 4, + "EmptyTag": 5, + "Comment": 6, + "ParseError": 7 +} + +tagTokenTypes = frozenset([tokenTypes["StartTag"], tokenTypes["EndTag"], + tokenTypes["EmptyTag"]]) + + +prefixes = dict([(v, k) for k, v in namespaces.items()]) +prefixes["http://www.w3.org/1998/Math/MathML"] = "math" + + +class DataLossWarning(UserWarning): + """Raised when the current tree is unable to represent the input data""" + pass + + +class _ReparseException(Exception): + pass diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5110adac059a1f16b1e51e0680e58e2fb50e3c5d GIT binary patch literal 213 zcmWIL<>g`kf^QoZCW7e4AOaaM0yz#qT+9L_QW%06G#UL?G8BP?5yY=5{eq&*vc!^9 z{j$U&{j~g?l+>bPeai~{^mxm%qTH%HqqHo8jEst^s`wmBv!sk710YDx(+|-v$Sly! z%quQQ%*oL;Ffc2tEHf+x34(EaS!!NNevy7gNp6m5PG*vRT4qiO$mIC=%)HE!_;|g7 V%3B;Zx%nxjIjMFaH+=?T1^}GxI->vp literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/alphabeticalattributes.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/alphabeticalattributes.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..08a601d01050890f3ecb5e540a1d5ce65a3c12cf GIT binary patch literal 1335 zcmZux&2Jnv6u0MNcXqRBBR(W5ahL;AwGz#wNJNShp;i=-dI*RXkVZw0ckJ1n#Pbo` zJMFGEr}n^wGuP(GjlaiNPW=av-~#VC2@Mj~yk|duy!Z3(J<oUB+hYRlkKZo%FCihn zqj9rEU_1aZk3k6{s3JAZX&vN29p)h=A`qd9>Nt;KOhlvx^)Mg8I2MCfBu~B~VknYV zL?kjk8NCeikr+K8)A1YdN2Z~>&1a@nODkDbcdfQA5mjHAs%_lPvZ;zzNTw<)HCN^h z#WU1JGj1gGTVHD-wG@x4!WOu8-Ea)IA)kYo4?%4J`5iCaEfHK<;T=*2fF)Z0`K`1| z-J~48uG4L&D{f_aDpzUQYCmnQu4Vw!PZ$7NHS_T}h4%1z$)pS3%ao@LuchgDAyd2H zHZ8#IOs2B33#rrN<D<5b$Hyr;P7Szi=DX<+())s~ci})=cU<FXkmoHNF8I=TdvzD) zMOBt?@5ZKf)k*VlYTER<gkw!Fwe^nvjbdAbFYC^(u7agyrH$Ra1h0`QM|2F`ubx{D z*U=*|z545?49Mt#jjZQ7D_aGOo9y64HfIODuGh^c<;mV+@nXGZ>R^Ai(0kD4P4+bF zs_tIZ7|WHqx3{<7uloB-ob<wa*@#wW3tOvCRW-}XN<orM##OiAGij@WD}>@nH@n@+ zjTqVtl9B*A6M!O#o`5cJc(dW!0}%58C`ocENFE59hghvpm63=b@39+v>7%YcdUzdm zElv71tWUO7vIefre<}?5Lc!4H87NCm=xeB~3;Kxs`1qV|sIR!-bfCYn;Y)HJ*a+sJ z=3d7a#12ICa{xPco(1ROd9;Z(!6rN;XZz5@u0yh+-xEsCCW0W+BNt(+r-4hJSg!3; zK6l9%m{c4^f?E#nAp~xwLp=aEdK;8W7{jN-m>!}zz`B*f#V}bLPaTjD8L3Ja+xAp8 zF2>6n7hwszxaVpq-xh=3LeKAldLP8R1B%ccI-vuQ;O|?(m?m_6`;ye%>)1yS1Aw4M z#@v{(x)n=>;|XJDORla~hKz}}0IV3`Mo?diJ~G}37Y+WE5*kr|%cJQSy_QRO!r)b7 x@^y#`w`nXEPl?+qTBT%R;oo9BA)W#6<Nw0B<nR*dXZS`8`gt#y1d}k?`Ug=sT;~7) literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/base.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/base.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ecb65e15706af22174a720969bee280099ca1541 GIT binary patch literal 883 zcmZuvJ#X7E5G6%fR+AVBiq4%nR6`=SKm!B_iU0-LEsNVl3n7cNO@oqLk`fZboAXCH zX6x_K+Npn_L#N(RiR*qGaL123-MjawPovQR0sHawOa7b^@(mCB7Q*2Q+`fb$h@hI3 zG^1sZ1trTEB_D_g1iK@G$#BcEfe0rg8GMIolCbVLpW0eCPI6VQYU8?Cs8(53SKUcd zsiGE=YvrWLwJq?QeGA}l1#VwJkR+pmWPzX}xFZ=8OoXt8Vjv<|2Vw}gaTmQ;8rl{3 z?W5ry{T;YPx*NJ79N0|AJ-tq77umWog-n7jv{KK^5Nhs;c>>GNHeDIj=1!(<Zqiw; zg)}z3xJl>yqBZ5ZdOcf?7mJ(qn(K@6>B5Y`=2iMJU8&Wns;tYkJ{^zG+uQb4gO}cU zD=Sf(bm2<<MyqK$^K;vDnp=6cy6s}lRizx~1Dx8^q3h$G-PvQVfG67-?*E|a$c8NG zmQIL?Acyo&YELhrCWbrDu@5MWM}-p3G5H@<pZiB#2E|_7BiQt)8@dgC;|}N2<<31o z2Ohc$tGtwd4{*r&LoMfrdow)UG2f-HlL+U<E}VA<oR_s|H13Z$|J>xd&lqfDMi@>o z;H&Nhq-{`R{L?M!6w{c+%-<mdG@doCG0@ncyaw4CtnQ+Ex|D_UrF$(sLNDiKKhs-$ J8!zWG_6s)y#3KLz literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/inject_meta_charset.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/inject_meta_charset.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..50d34d33624ad301e31128df2987337b316fac96 GIT binary patch literal 1889 zcmZt{O>Y}TbY}L`uG54zDXEaEy>Rd$bwHw0OIuY++ERoJQVT+>mdVC5wl~=?&x}oC ztq+KDMN!W^#5a&Q^u$l#2XNdgr~ZKoae+6pPHU=;HE-X{`<VCbuUA%@2-d3?^XP|j z2>qoG%gctt9oX_30EQS&P>MsGl8~fUXko+%vl2UXLI<P!h}q0}ikQQl1NTQObea1Q zwY`@hi`rJT8tuzG87ofXw8(|3d=^h)8RuEGHqPQ+&NxkC#YL3Jmsrc-%HEG8?`Z|g zi@@OyY#9LHD8vkfgyGQA<~&8AT^kZQwE>lTFHS)3^wxvyfcKOP_V#Y3Ttz`|7zxSM zt-IZwFLxhw@890r3sf`+;!NeikVh=Y`vJ>)<CJHrXTfV{OXE5^JFw*@0EG_lDJfBj z=LDk?FlsRj{*$TN5j;{{22oHO(rgBcbt4jkK;~o7<2M2|<O@7d`615&sX#D&i<@T< zsW=<d{AVYS2*8s!yxq1fT(C=c04kr-IExjfm47Ay8L=f#`juP1FB-u3D-tdE{PR<% z5b*?z?o1-l>E{XKLUyhnbq4hMM5NQ~<Nm?+aCkJG(&YNJ{h`=~HOM-TIz?P;#hFx5 zl5A~nUz;3HJ{s#wv+0CqEEk=jN|R5Lc)!y(iIJVyB!=pw&_z<N7RSN|TlAJX)W|=N zr>k`Yub%nS(}i-jbTMn6d$8r7Kw)@>OLPFGd+5)|0L?6g56G!iqB-70C-}*4GrP1I zxr}B`=`ib%h%ex5Uq+|)910oEpD}laPjJS7?j4d7EIwc2@PXrR)|k0)*90kNj&{+L zZy%G#WaiEMS)=se?S}YyG#O1w-)KDtGQVr9YMIh2{XV&gSZfA_GkT@@*b4AW%7)=T zuW_KdKyk$@wpz;_YJ5%WxwO#4R%<QUS4$Rx4`B0)5}<s+EaueG?7ipKHwYToV?Mi} zwZ!=K-9_fG_2<OU!K%@ftPkE_Txj}Ve2i|ZhNmvum}4zvUVHW~-KFOJrL^Agp5W0l z?K`^!xx&mfulxZVUTM!UMC3|oYn`Jj3_&}+-wpjjaH_krvej|HEB~R2gnASWDm#l( zUfG%!dT~}W`FGPo9UHQ)uX~lvA{ABMqRt*on?t3FEj}8@lWD7$X9}8qOKWbEF0j=X z(+$Osl&RcLU(byXW!n<xq1wcn2I~MoMr^>ha_?pg9&M8)23@RSqsXN)rnP<3bZ_-3 zOe*M8C&|C(qH<s$rn0h%yr|r$D4>7ZO`!|Da-hi+51XcG`uR9xm8a=28!E>P5c6{Q z!7!3kyGV_Tbm0&+v1{mv$s+1;<3i<3qGZg?5U9ZlJSFsiy9ir;2LNFkH?d7FU>|;K z*e6ZAMr^zZCmXl$1%NJI$1Yg|+$EbpbN}@L`T$!%wLxMNFc)xr=Yp2{wndgZ+(e?= zcJ=tuc0yR1l%_cwCmL^2IvPjGg5psMlbTX9G>pYdUg)7Fj4OH^>KP$5&<6YG%!ur^ qJ*~VyR%56xD)fJh&{JOM*;Ao6NqU#s%D-8gbz7&{jH`9hvi<|)Amcdz literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/lint.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/lint.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..cd1604a4727aeedfa88ca20f9c6a36c01b5494dd GIT binary patch literal 2647 zcmZuz&5smC6tC)!nV#?EYhe*dhiG67>>!B*&=?IL24lFe5YvJ5_IB0m^iF>aRW-xz zWcDINJnlu~aW^q0Bpy5(Plmt2Q^y0*6ITx&JQ&}ro>>N^lB#~MUe$ZQ_c8V6PNPvJ zF#h^+FL=L6$REhe4-1%&V9FjWj4&FLgnBeFJR>nZlj5EcTZ!%2K%2~pOG())18uWX z>?9Shl2pB_=F7m>yc*EXZk^Zms8{=hunMa_CalWK8;wV%*I>2Vq+Ndj)=1mTTfv&l z;-TVxlngSVa)(8uNJd$jFAUQt%oz9MNO2LwvQ6`f;+x7>TLb=rq5_&*Yk}l13}lSF zng$7%gCOKGuaB~bU5|OfQ-xPsdjD!K5J3p~WKKfFFh4LBIOIF9aN<!$JcCisWaTHM zOVRts70*J?9}~}hLM-Byz#Ato-H2jPI$r-Q0&A}7aaU!1p1M*A9wcrz6D}7b6S7)$ zVchJxk#f6H%A^~lTT|It*gPG_t_UK@Vc%U{{a8va6olhC-d<f@F7B^{rbb#UNYAD` z4vZp-PRJu;*O<^fO3B2S5Z`1Juo~m9uL2~+!LVDPE>t3{D}h*dWi}KczoMNe=vRFC z&uPIQ3?sq)Bv4^5O4ofAtjjCz!ybnq2p9ZLGX)CV=|OjP(8Yr<mECGvxh;nSh*ASQ z$Q|F0(n$G!e&n?#pmr?D<8EFmFp34Z^%N?^_ro}l()XW|zek;ch(_RSXB3D|H;Wl0 zzH@oAv+iFWiDaB!=x&_v^)|<2KfZi%ttZaISWi1Eok27>7o}1KaeVIl`HQ2i(Yr(3 z)YBjFlx3pRQ%U?@9IbV_I{UH{L-v;kTcQP64#JeWqMQXfZWW<ko_Q5w`OZcK2peVy zQ(l8iu9I!5$OeV{kv)2i?3nk@ZW|M*#U-+BPE2O>OFLBDfE^QdEcjaRwI>!MeMjC> z=EPFgBLgV=3kth--;^HGAhETirzN(QsHwzYr6r<DaPQ0Fp7;jzlv#O+^bPR?+;sXS z_?pb=8}cVSlh%Q&%(#LUzfQ<T1y;ISomdmQYZNtz+IMSv<QloZde69LY+Kv*cB#O; zLuF}(TGRWufjd0Kr;!8ymPV(s19xF6Eor}=BlqC>4o&|AG}XSbV+f4gYvKfV$8$Ev zTC0u~NWPkCo!R_WOJ_E}FU~>^etsDt;C?G&gcPfRmVcDZ>Z~!bBf3Z)QHa+mjLnWI zE<tqadt|#jDHkyUq^7)tdI9@Iz~0o@&j5Ca+qMHp9rSSS)B>DpK_wVs^M9ud`KiX} zV1{=L`MKsywt#lPy0hC*%{>azeU0fapznaT`ul!G*;r9<|GQb`Xd1I)u!Bp`9kle> zob;KtWUxb1DS9=nx*7KLE?7FOkr*J;)jRK-_Wy{MpVD%y%Q@fEMToAB7F%R=V$PyF zG42vd9xN~dFWu2wxrLnq`hs&?1wyR^>$!718K^C!D*L@6w~!Qd`1R!$3sjI>_{$bc zupy4&Zs~f;;LeTl@?B^uE-$(YJZadnICBH(7AK0A@{0TR8F<~=GB@Fqm#=0Cb|Gv~ zbN#1v8ynTj4RH!hm9J$XqRySca4n9)n=E(amQ*|e3UH`MZF#NRTtq<}jk(Z$VSM6F z+E25G>GY*W1sVjpFWW6qMpyRVRp?aku2!MV;tQ9CT;S`IH(zZw5Q`{O0v{)V{~`1X zo0o#Y0A9b`hNhf=gM(}U@3s=rK-Az+yCM$2$7^J8%AW>G=C<yJ;wY-Y1|{BrCAUXG zJmh#CvLjC5{*nD<5vkL#ya`jrun=m|gVdo_m=0Z}b=rh^kRGE=1L-DE$6;N7dDtjU z&G?fb)3@|~A;oi5x~O-K)05N%3b{pd(U^a*b-3DerCr9Zgtdav^Zg`a!x-th?>`s@ z@l;aweU^p3ue*TuAa6{YQpn>N1TURD1YQa4DJBOiP?lhEsAV^6I$^ikO|;b=sv&e) zU*JC-fz4iEZ^>KGla{CbXjw*^I+MDTb<XojnCToVIhROGRBml#QL0VM;nBztPwsqB Uxc4D8Dv8Jr8+8ct0?exUFC93(>i_@% literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/optionaltags.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/optionaltags.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5e0fdb7e49dbe696d1cc660eed640951251694e8 GIT binary patch literal 2776 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/sanitizer.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/sanitizer.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3986eda6381ee0ea65d665e341a71e6cfdba744c GIT binary patch literal 16318 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/whitespace.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/__pycache__/whitespace.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..a329e4dfec81646e5e0191f7d979b8652b8a45c9 GIT binary patch literal 1381 zcmZ8h&2Aev5GJ`l+La|sDBPq5Qb331Ak>N60(I*mC=$48ZiZ2%L9s=!SS=}QW$sT% zO0@;~<e=v~Ko8Ebw?081gx8+@0zKrC&aC3v4Hq-J{APyp%l)a{ZW37k{P`yN%O&J* z+}vJ(k;g!~0LBTYlH@d^Ig42CL=HuaNjGx2!(Hj+e&hq@abGs_APVv@3Sr;4Y>My= zjY8pGZty^acL?lSPYDls^A+Ju;m_I^PSoZby!DDio1BeEzkLNhN#C)ZWUNa$HzLmR zs#L}XJX>TsD+}A57g<_z5zEX7l}LSfMbU^_cbsT(#c;#yrb>BYlA#p2D2%opT_veF zm?kPo!A@JU^nSUoUwodT%iHU}0_*@PNJKe_7^jgVT+X<2%!DWW3woDa(5S&(?m_qg z_aXd-^?%4DoW6W=P)eCpTIk-dQ;4&6-V>*(s7x;_dX*A8JtIy{qC~ROOA6l8smeeo zt^;;J#|GCrDdu>+FhV2@UH=Y@({pObj9#)8l=*w|;<t0QVw`Q0b7$pn=Y*-pE2{SZ zbGONg%$yS+5$=6W&S`N3IzH$;Ur{9PeS_$?U|~Sg0Eq$1V4EnzL;QL~ihCe^4bmn^ zUmJHVzo2XBiajTkyzFuURoOUH7`%1OSp^x5AZPO|Iks+*<U)BU@`nXSs5APYNiO#A zE$!LnP3QWa^1(=Lpk)xpI0kWSKdx(hq=Xh~A#VDfzVAd_%XQzit`>4)1E_DUYCTh) zh(c|`d4CXf4_<FqgGyzK#E8KnQG-b-IgHF;|8#I1?=MuoEWVt~cBj+R<uaE0d*i9v zg>_sEo(-z3dXN>`BvL-u-Q8Q9Exwo|SW~<Z1uxZLYI6CN%*KOBJuZ51Gb9hIGj#_- z=mO~;FhX70r2#zb9iy#xj5S${HrZDF?y_ZPJ#!DQD{<Hlu`F0!C`&Vr^ODacez)TI z<vfw^C5<@dWeRXOQRPw;S{UofOdAz|S9KQ|Mp9Sg7W))2EPe|}V=Dp(af{X1|K=3i zj&pi|il}YKCFK-m6fZkFR9k?-U2Tnyo*WEE@sGo&!=J6A=VQFhIQk#D{R9l|<7s%y z301i7cQDDx+{_gusZgREWa!#5B^3Vf>Y1@&T4HbDhp<jEL=|^dW`%8}WnN`csLxOv k^Q%w46#-6$!t8DEXkF9qFhh-lv&91FN*DUF>3p>PFH{_1D*ylh literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py new file mode 100644 index 0000000..5ba926e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py @@ -0,0 +1,29 @@ +from __future__ import absolute_import, division, unicode_literals + +from . import base + +from collections import OrderedDict + + +def _attr_key(attr): + """Return an appropriate key for an attribute for sorting + + Attributes have a namespace that can be either ``None`` or a string. We + can't compare the two because they're different types, so we convert + ``None`` to an empty string first. + + """ + return (attr[0][0] or ''), attr[0][1] + + +class Filter(base.Filter): + """Alphabetizes attributes for elements""" + def __iter__(self): + for token in base.Filter.__iter__(self): + if token["type"] in ("StartTag", "EmptyTag"): + attrs = OrderedDict() + for name, value in sorted(token["data"].items(), + key=_attr_key): + attrs[name] = value + token["data"] = attrs + yield token diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/base.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/base.py new file mode 100644 index 0000000..c7dbaed --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/base.py @@ -0,0 +1,12 @@ +from __future__ import absolute_import, division, unicode_literals + + +class Filter(object): + def __init__(self, source): + self.source = source + + def __iter__(self): + return iter(self.source) + + def __getattr__(self, name): + return getattr(self.source, name) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py new file mode 100644 index 0000000..aefb5c8 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py @@ -0,0 +1,73 @@ +from __future__ import absolute_import, division, unicode_literals + +from . import base + + +class Filter(base.Filter): + """Injects ``<meta charset=ENCODING>`` tag into head of document""" + def __init__(self, source, encoding): + """Creates a Filter + + :arg source: the source token stream + + :arg encoding: the encoding to set + + """ + base.Filter.__init__(self, source) + self.encoding = encoding + + def __iter__(self): + state = "pre_head" + meta_found = (self.encoding is None) + pending = [] + + for token in base.Filter.__iter__(self): + type = token["type"] + if type == "StartTag": + if token["name"].lower() == "head": + state = "in_head" + + elif type == "EmptyTag": + if token["name"].lower() == "meta": + # replace charset with actual encoding + has_http_equiv_content_type = False + for (namespace, name), value in token["data"].items(): + if namespace is not None: + continue + elif name.lower() == 'charset': + token["data"][(namespace, name)] = self.encoding + meta_found = True + break + elif name == 'http-equiv' and value.lower() == 'content-type': + has_http_equiv_content_type = True + else: + if has_http_equiv_content_type and (None, "content") in token["data"]: + token["data"][(None, "content")] = 'text/html; charset=%s' % self.encoding + meta_found = True + + elif token["name"].lower() == "head" and not meta_found: + # insert meta into empty head + yield {"type": "StartTag", "name": "head", + "data": token["data"]} + yield {"type": "EmptyTag", "name": "meta", + "data": {(None, "charset"): self.encoding}} + yield {"type": "EndTag", "name": "head"} + meta_found = True + continue + + elif type == "EndTag": + if token["name"].lower() == "head" and pending: + # insert meta into head (if necessary) and flush pending queue + yield pending.pop(0) + if not meta_found: + yield {"type": "EmptyTag", "name": "meta", + "data": {(None, "charset"): self.encoding}} + while pending: + yield pending.pop(0) + meta_found = True + state = "post_head" + + if state == "in_head": + pending.append(token) + else: + yield token diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/lint.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/lint.py new file mode 100644 index 0000000..fcc07ee --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/lint.py @@ -0,0 +1,93 @@ +from __future__ import absolute_import, division, unicode_literals + +from pip._vendor.six import text_type + +from . import base +from ..constants import namespaces, voidElements + +from ..constants import spaceCharacters +spaceCharacters = "".join(spaceCharacters) + + +class Filter(base.Filter): + """Lints the token stream for errors + + If it finds any errors, it'll raise an ``AssertionError``. + + """ + def __init__(self, source, require_matching_tags=True): + """Creates a Filter + + :arg source: the source token stream + + :arg require_matching_tags: whether or not to require matching tags + + """ + super(Filter, self).__init__(source) + self.require_matching_tags = require_matching_tags + + def __iter__(self): + open_elements = [] + for token in base.Filter.__iter__(self): + type = token["type"] + if type in ("StartTag", "EmptyTag"): + namespace = token["namespace"] + name = token["name"] + assert namespace is None or isinstance(namespace, text_type) + assert namespace != "" + assert isinstance(name, text_type) + assert name != "" + assert isinstance(token["data"], dict) + if (not namespace or namespace == namespaces["html"]) and name in voidElements: + assert type == "EmptyTag" + else: + assert type == "StartTag" + if type == "StartTag" and self.require_matching_tags: + open_elements.append((namespace, name)) + for (namespace, name), value in token["data"].items(): + assert namespace is None or isinstance(namespace, text_type) + assert namespace != "" + assert isinstance(name, text_type) + assert name != "" + assert isinstance(value, text_type) + + elif type == "EndTag": + namespace = token["namespace"] + name = token["name"] + assert namespace is None or isinstance(namespace, text_type) + assert namespace != "" + assert isinstance(name, text_type) + assert name != "" + if (not namespace or namespace == namespaces["html"]) and name in voidElements: + assert False, "Void element reported as EndTag token: %(tag)s" % {"tag": name} + elif self.require_matching_tags: + start = open_elements.pop() + assert start == (namespace, name) + + elif type == "Comment": + data = token["data"] + assert isinstance(data, text_type) + + elif type in ("Characters", "SpaceCharacters"): + data = token["data"] + assert isinstance(data, text_type) + assert data != "" + if type == "SpaceCharacters": + assert data.strip(spaceCharacters) == "" + + elif type == "Doctype": + name = token["name"] + assert name is None or isinstance(name, text_type) + assert token["publicId"] is None or isinstance(name, text_type) + assert token["systemId"] is None or isinstance(name, text_type) + + elif type == "Entity": + assert isinstance(token["name"], text_type) + + elif type == "SerializerError": + assert isinstance(token["data"], text_type) + + else: + assert False, "Unknown token type: %(type)s" % {"type": type} + + yield token diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/optionaltags.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/optionaltags.py new file mode 100644 index 0000000..4a86501 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/optionaltags.py @@ -0,0 +1,207 @@ +from __future__ import absolute_import, division, unicode_literals + +from . import base + + +class Filter(base.Filter): + """Removes optional tags from the token stream""" + def slider(self): + previous1 = previous2 = None + for token in self.source: + if previous1 is not None: + yield previous2, previous1, token + previous2 = previous1 + previous1 = token + if previous1 is not None: + yield previous2, previous1, None + + def __iter__(self): + for previous, token, next in self.slider(): + type = token["type"] + if type == "StartTag": + if (token["data"] or + not self.is_optional_start(token["name"], previous, next)): + yield token + elif type == "EndTag": + if not self.is_optional_end(token["name"], next): + yield token + else: + yield token + + def is_optional_start(self, tagname, previous, next): + type = next and next["type"] or None + if tagname in 'html': + # An html element's start tag may be omitted if the first thing + # inside the html element is not a space character or a comment. + return type not in ("Comment", "SpaceCharacters") + elif tagname == 'head': + # A head element's start tag may be omitted if the first thing + # inside the head element is an element. + # XXX: we also omit the start tag if the head element is empty + if type in ("StartTag", "EmptyTag"): + return True + elif type == "EndTag": + return next["name"] == "head" + elif tagname == 'body': + # A body element's start tag may be omitted if the first thing + # inside the body element is not a space character or a comment, + # except if the first thing inside the body element is a script + # or style element and the node immediately preceding the body + # element is a head element whose end tag has been omitted. + if type in ("Comment", "SpaceCharacters"): + return False + elif type == "StartTag": + # XXX: we do not look at the preceding event, so we never omit + # the body element's start tag if it's followed by a script or + # a style element. + return next["name"] not in ('script', 'style') + else: + return True + elif tagname == 'colgroup': + # A colgroup element's start tag may be omitted if the first thing + # inside the colgroup element is a col element, and if the element + # is not immediately preceded by another colgroup element whose + # end tag has been omitted. + if type in ("StartTag", "EmptyTag"): + # XXX: we do not look at the preceding event, so instead we never + # omit the colgroup element's end tag when it is immediately + # followed by another colgroup element. See is_optional_end. + return next["name"] == "col" + else: + return False + elif tagname == 'tbody': + # A tbody element's start tag may be omitted if the first thing + # inside the tbody element is a tr element, and if the element is + # not immediately preceded by a tbody, thead, or tfoot element + # whose end tag has been omitted. + if type == "StartTag": + # omit the thead and tfoot elements' end tag when they are + # immediately followed by a tbody element. See is_optional_end. + if previous and previous['type'] == 'EndTag' and \ + previous['name'] in ('tbody', 'thead', 'tfoot'): + return False + return next["name"] == 'tr' + else: + return False + return False + + def is_optional_end(self, tagname, next): + type = next and next["type"] or None + if tagname in ('html', 'head', 'body'): + # An html element's end tag may be omitted if the html element + # is not immediately followed by a space character or a comment. + return type not in ("Comment", "SpaceCharacters") + elif tagname in ('li', 'optgroup', 'tr'): + # A li element's end tag may be omitted if the li element is + # immediately followed by another li element or if there is + # no more content in the parent element. + # An optgroup element's end tag may be omitted if the optgroup + # element is immediately followed by another optgroup element, + # or if there is no more content in the parent element. + # A tr element's end tag may be omitted if the tr element is + # immediately followed by another tr element, or if there is + # no more content in the parent element. + if type == "StartTag": + return next["name"] == tagname + else: + return type == "EndTag" or type is None + elif tagname in ('dt', 'dd'): + # A dt element's end tag may be omitted if the dt element is + # immediately followed by another dt element or a dd element. + # A dd element's end tag may be omitted if the dd element is + # immediately followed by another dd element or a dt element, + # or if there is no more content in the parent element. + if type == "StartTag": + return next["name"] in ('dt', 'dd') + elif tagname == 'dd': + return type == "EndTag" or type is None + else: + return False + elif tagname == 'p': + # A p element's end tag may be omitted if the p element is + # immediately followed by an address, article, aside, + # blockquote, datagrid, dialog, dir, div, dl, fieldset, + # footer, form, h1, h2, h3, h4, h5, h6, header, hr, menu, + # nav, ol, p, pre, section, table, or ul, element, or if + # there is no more content in the parent element. + if type in ("StartTag", "EmptyTag"): + return next["name"] in ('address', 'article', 'aside', + 'blockquote', 'datagrid', 'dialog', + 'dir', 'div', 'dl', 'fieldset', 'footer', + 'form', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', + 'header', 'hr', 'menu', 'nav', 'ol', + 'p', 'pre', 'section', 'table', 'ul') + else: + return type == "EndTag" or type is None + elif tagname == 'option': + # An option element's end tag may be omitted if the option + # element is immediately followed by another option element, + # or if it is immediately followed by an <code>optgroup</code> + # element, or if there is no more content in the parent + # element. + if type == "StartTag": + return next["name"] in ('option', 'optgroup') + else: + return type == "EndTag" or type is None + elif tagname in ('rt', 'rp'): + # An rt element's end tag may be omitted if the rt element is + # immediately followed by an rt or rp element, or if there is + # no more content in the parent element. + # An rp element's end tag may be omitted if the rp element is + # immediately followed by an rt or rp element, or if there is + # no more content in the parent element. + if type == "StartTag": + return next["name"] in ('rt', 'rp') + else: + return type == "EndTag" or type is None + elif tagname == 'colgroup': + # A colgroup element's end tag may be omitted if the colgroup + # element is not immediately followed by a space character or + # a comment. + if type in ("Comment", "SpaceCharacters"): + return False + elif type == "StartTag": + # XXX: we also look for an immediately following colgroup + # element. See is_optional_start. + return next["name"] != 'colgroup' + else: + return True + elif tagname in ('thead', 'tbody'): + # A thead element's end tag may be omitted if the thead element + # is immediately followed by a tbody or tfoot element. + # A tbody element's end tag may be omitted if the tbody element + # is immediately followed by a tbody or tfoot element, or if + # there is no more content in the parent element. + # A tfoot element's end tag may be omitted if the tfoot element + # is immediately followed by a tbody element, or if there is no + # more content in the parent element. + # XXX: we never omit the end tag when the following element is + # a tbody. See is_optional_start. + if type == "StartTag": + return next["name"] in ['tbody', 'tfoot'] + elif tagname == 'tbody': + return type == "EndTag" or type is None + else: + return False + elif tagname == 'tfoot': + # A tfoot element's end tag may be omitted if the tfoot element + # is immediately followed by a tbody element, or if there is no + # more content in the parent element. + # XXX: we never omit the end tag when the following element is + # a tbody. See is_optional_start. + if type == "StartTag": + return next["name"] == 'tbody' + else: + return type == "EndTag" or type is None + elif tagname in ('td', 'th'): + # A td element's end tag may be omitted if the td element is + # immediately followed by a td or th element, or if there is + # no more content in the parent element. + # A th element's end tag may be omitted if the th element is + # immediately followed by a td or th element, or if there is + # no more content in the parent element. + if type == "StartTag": + return next["name"] in ('td', 'th') + else: + return type == "EndTag" or type is None + return False diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/sanitizer.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/sanitizer.py new file mode 100644 index 0000000..af8e77b --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/sanitizer.py @@ -0,0 +1,896 @@ +from __future__ import absolute_import, division, unicode_literals + +import re +from xml.sax.saxutils import escape, unescape + +from pip._vendor.six.moves import urllib_parse as urlparse + +from . import base +from ..constants import namespaces, prefixes + +__all__ = ["Filter"] + + +allowed_elements = frozenset(( + (namespaces['html'], 'a'), + (namespaces['html'], 'abbr'), + (namespaces['html'], 'acronym'), + (namespaces['html'], 'address'), + (namespaces['html'], 'area'), + (namespaces['html'], 'article'), + (namespaces['html'], 'aside'), + (namespaces['html'], 'audio'), + (namespaces['html'], 'b'), + (namespaces['html'], 'big'), + (namespaces['html'], 'blockquote'), + (namespaces['html'], 'br'), + (namespaces['html'], 'button'), + (namespaces['html'], 'canvas'), + (namespaces['html'], 'caption'), + (namespaces['html'], 'center'), + (namespaces['html'], 'cite'), + (namespaces['html'], 'code'), + (namespaces['html'], 'col'), + (namespaces['html'], 'colgroup'), + (namespaces['html'], 'command'), + (namespaces['html'], 'datagrid'), + (namespaces['html'], 'datalist'), + (namespaces['html'], 'dd'), + (namespaces['html'], 'del'), + (namespaces['html'], 'details'), + (namespaces['html'], 'dfn'), + (namespaces['html'], 'dialog'), + (namespaces['html'], 'dir'), + (namespaces['html'], 'div'), + (namespaces['html'], 'dl'), + (namespaces['html'], 'dt'), + (namespaces['html'], 'em'), + (namespaces['html'], 'event-source'), + (namespaces['html'], 'fieldset'), + (namespaces['html'], 'figcaption'), + (namespaces['html'], 'figure'), + (namespaces['html'], 'footer'), + (namespaces['html'], 'font'), + (namespaces['html'], 'form'), + (namespaces['html'], 'header'), + (namespaces['html'], 'h1'), + (namespaces['html'], 'h2'), + (namespaces['html'], 'h3'), + (namespaces['html'], 'h4'), + (namespaces['html'], 'h5'), + (namespaces['html'], 'h6'), + (namespaces['html'], 'hr'), + (namespaces['html'], 'i'), + (namespaces['html'], 'img'), + (namespaces['html'], 'input'), + (namespaces['html'], 'ins'), + (namespaces['html'], 'keygen'), + (namespaces['html'], 'kbd'), + (namespaces['html'], 'label'), + (namespaces['html'], 'legend'), + (namespaces['html'], 'li'), + (namespaces['html'], 'm'), + (namespaces['html'], 'map'), + (namespaces['html'], 'menu'), + (namespaces['html'], 'meter'), + (namespaces['html'], 'multicol'), + (namespaces['html'], 'nav'), + (namespaces['html'], 'nextid'), + (namespaces['html'], 'ol'), + (namespaces['html'], 'output'), + (namespaces['html'], 'optgroup'), + (namespaces['html'], 'option'), + (namespaces['html'], 'p'), + (namespaces['html'], 'pre'), + (namespaces['html'], 'progress'), + (namespaces['html'], 'q'), + (namespaces['html'], 's'), + (namespaces['html'], 'samp'), + (namespaces['html'], 'section'), + (namespaces['html'], 'select'), + (namespaces['html'], 'small'), + (namespaces['html'], 'sound'), + (namespaces['html'], 'source'), + (namespaces['html'], 'spacer'), + (namespaces['html'], 'span'), + (namespaces['html'], 'strike'), + (namespaces['html'], 'strong'), + (namespaces['html'], 'sub'), + (namespaces['html'], 'sup'), + (namespaces['html'], 'table'), + (namespaces['html'], 'tbody'), + (namespaces['html'], 'td'), + (namespaces['html'], 'textarea'), + (namespaces['html'], 'time'), + (namespaces['html'], 'tfoot'), + (namespaces['html'], 'th'), + (namespaces['html'], 'thead'), + (namespaces['html'], 'tr'), + (namespaces['html'], 'tt'), + (namespaces['html'], 'u'), + (namespaces['html'], 'ul'), + (namespaces['html'], 'var'), + (namespaces['html'], 'video'), + (namespaces['mathml'], 'maction'), + (namespaces['mathml'], 'math'), + (namespaces['mathml'], 'merror'), + (namespaces['mathml'], 'mfrac'), + (namespaces['mathml'], 'mi'), + (namespaces['mathml'], 'mmultiscripts'), + (namespaces['mathml'], 'mn'), + (namespaces['mathml'], 'mo'), + (namespaces['mathml'], 'mover'), + (namespaces['mathml'], 'mpadded'), + (namespaces['mathml'], 'mphantom'), + (namespaces['mathml'], 'mprescripts'), + (namespaces['mathml'], 'mroot'), + (namespaces['mathml'], 'mrow'), + (namespaces['mathml'], 'mspace'), + (namespaces['mathml'], 'msqrt'), + (namespaces['mathml'], 'mstyle'), + (namespaces['mathml'], 'msub'), + (namespaces['mathml'], 'msubsup'), + (namespaces['mathml'], 'msup'), + (namespaces['mathml'], 'mtable'), + (namespaces['mathml'], 'mtd'), + (namespaces['mathml'], 'mtext'), + (namespaces['mathml'], 'mtr'), + (namespaces['mathml'], 'munder'), + (namespaces['mathml'], 'munderover'), + (namespaces['mathml'], 'none'), + (namespaces['svg'], 'a'), + (namespaces['svg'], 'animate'), + (namespaces['svg'], 'animateColor'), + (namespaces['svg'], 'animateMotion'), + (namespaces['svg'], 'animateTransform'), + (namespaces['svg'], 'clipPath'), + (namespaces['svg'], 'circle'), + (namespaces['svg'], 'defs'), + (namespaces['svg'], 'desc'), + (namespaces['svg'], 'ellipse'), + (namespaces['svg'], 'font-face'), + (namespaces['svg'], 'font-face-name'), + (namespaces['svg'], 'font-face-src'), + (namespaces['svg'], 'g'), + (namespaces['svg'], 'glyph'), + (namespaces['svg'], 'hkern'), + (namespaces['svg'], 'linearGradient'), + (namespaces['svg'], 'line'), + (namespaces['svg'], 'marker'), + (namespaces['svg'], 'metadata'), + (namespaces['svg'], 'missing-glyph'), + (namespaces['svg'], 'mpath'), + (namespaces['svg'], 'path'), + (namespaces['svg'], 'polygon'), + (namespaces['svg'], 'polyline'), + (namespaces['svg'], 'radialGradient'), + (namespaces['svg'], 'rect'), + (namespaces['svg'], 'set'), + (namespaces['svg'], 'stop'), + (namespaces['svg'], 'svg'), + (namespaces['svg'], 'switch'), + (namespaces['svg'], 'text'), + (namespaces['svg'], 'title'), + (namespaces['svg'], 'tspan'), + (namespaces['svg'], 'use'), +)) + +allowed_attributes = frozenset(( + # HTML attributes + (None, 'abbr'), + (None, 'accept'), + (None, 'accept-charset'), + (None, 'accesskey'), + (None, 'action'), + (None, 'align'), + (None, 'alt'), + (None, 'autocomplete'), + (None, 'autofocus'), + (None, 'axis'), + (None, 'background'), + (None, 'balance'), + (None, 'bgcolor'), + (None, 'bgproperties'), + (None, 'border'), + (None, 'bordercolor'), + (None, 'bordercolordark'), + (None, 'bordercolorlight'), + (None, 'bottompadding'), + (None, 'cellpadding'), + (None, 'cellspacing'), + (None, 'ch'), + (None, 'challenge'), + (None, 'char'), + (None, 'charoff'), + (None, 'choff'), + (None, 'charset'), + (None, 'checked'), + (None, 'cite'), + (None, 'class'), + (None, 'clear'), + (None, 'color'), + (None, 'cols'), + (None, 'colspan'), + (None, 'compact'), + (None, 'contenteditable'), + (None, 'controls'), + (None, 'coords'), + (None, 'data'), + (None, 'datafld'), + (None, 'datapagesize'), + (None, 'datasrc'), + (None, 'datetime'), + (None, 'default'), + (None, 'delay'), + (None, 'dir'), + (None, 'disabled'), + (None, 'draggable'), + (None, 'dynsrc'), + (None, 'enctype'), + (None, 'end'), + (None, 'face'), + (None, 'for'), + (None, 'form'), + (None, 'frame'), + (None, 'galleryimg'), + (None, 'gutter'), + (None, 'headers'), + (None, 'height'), + (None, 'hidefocus'), + (None, 'hidden'), + (None, 'high'), + (None, 'href'), + (None, 'hreflang'), + (None, 'hspace'), + (None, 'icon'), + (None, 'id'), + (None, 'inputmode'), + (None, 'ismap'), + (None, 'keytype'), + (None, 'label'), + (None, 'leftspacing'), + (None, 'lang'), + (None, 'list'), + (None, 'longdesc'), + (None, 'loop'), + (None, 'loopcount'), + (None, 'loopend'), + (None, 'loopstart'), + (None, 'low'), + (None, 'lowsrc'), + (None, 'max'), + (None, 'maxlength'), + (None, 'media'), + (None, 'method'), + (None, 'min'), + (None, 'multiple'), + (None, 'name'), + (None, 'nohref'), + (None, 'noshade'), + (None, 'nowrap'), + (None, 'open'), + (None, 'optimum'), + (None, 'pattern'), + (None, 'ping'), + (None, 'point-size'), + (None, 'poster'), + (None, 'pqg'), + (None, 'preload'), + (None, 'prompt'), + (None, 'radiogroup'), + (None, 'readonly'), + (None, 'rel'), + (None, 'repeat-max'), + (None, 'repeat-min'), + (None, 'replace'), + (None, 'required'), + (None, 'rev'), + (None, 'rightspacing'), + (None, 'rows'), + (None, 'rowspan'), + (None, 'rules'), + (None, 'scope'), + (None, 'selected'), + (None, 'shape'), + (None, 'size'), + (None, 'span'), + (None, 'src'), + (None, 'start'), + (None, 'step'), + (None, 'style'), + (None, 'summary'), + (None, 'suppress'), + (None, 'tabindex'), + (None, 'target'), + (None, 'template'), + (None, 'title'), + (None, 'toppadding'), + (None, 'type'), + (None, 'unselectable'), + (None, 'usemap'), + (None, 'urn'), + (None, 'valign'), + (None, 'value'), + (None, 'variable'), + (None, 'volume'), + (None, 'vspace'), + (None, 'vrml'), + (None, 'width'), + (None, 'wrap'), + (namespaces['xml'], 'lang'), + # MathML attributes + (None, 'actiontype'), + (None, 'align'), + (None, 'columnalign'), + (None, 'columnalign'), + (None, 'columnalign'), + (None, 'columnlines'), + (None, 'columnspacing'), + (None, 'columnspan'), + (None, 'depth'), + (None, 'display'), + (None, 'displaystyle'), + (None, 'equalcolumns'), + (None, 'equalrows'), + (None, 'fence'), + (None, 'fontstyle'), + (None, 'fontweight'), + (None, 'frame'), + (None, 'height'), + (None, 'linethickness'), + (None, 'lspace'), + (None, 'mathbackground'), + (None, 'mathcolor'), + (None, 'mathvariant'), + (None, 'mathvariant'), + (None, 'maxsize'), + (None, 'minsize'), + (None, 'other'), + (None, 'rowalign'), + (None, 'rowalign'), + (None, 'rowalign'), + (None, 'rowlines'), + (None, 'rowspacing'), + (None, 'rowspan'), + (None, 'rspace'), + (None, 'scriptlevel'), + (None, 'selection'), + (None, 'separator'), + (None, 'stretchy'), + (None, 'width'), + (None, 'width'), + (namespaces['xlink'], 'href'), + (namespaces['xlink'], 'show'), + (namespaces['xlink'], 'type'), + # SVG attributes + (None, 'accent-height'), + (None, 'accumulate'), + (None, 'additive'), + (None, 'alphabetic'), + (None, 'arabic-form'), + (None, 'ascent'), + (None, 'attributeName'), + (None, 'attributeType'), + (None, 'baseProfile'), + (None, 'bbox'), + (None, 'begin'), + (None, 'by'), + (None, 'calcMode'), + (None, 'cap-height'), + (None, 'class'), + (None, 'clip-path'), + (None, 'color'), + (None, 'color-rendering'), + (None, 'content'), + (None, 'cx'), + (None, 'cy'), + (None, 'd'), + (None, 'dx'), + (None, 'dy'), + (None, 'descent'), + (None, 'display'), + (None, 'dur'), + (None, 'end'), + (None, 'fill'), + (None, 'fill-opacity'), + (None, 'fill-rule'), + (None, 'font-family'), + (None, 'font-size'), + (None, 'font-stretch'), + (None, 'font-style'), + (None, 'font-variant'), + (None, 'font-weight'), + (None, 'from'), + (None, 'fx'), + (None, 'fy'), + (None, 'g1'), + (None, 'g2'), + (None, 'glyph-name'), + (None, 'gradientUnits'), + (None, 'hanging'), + (None, 'height'), + (None, 'horiz-adv-x'), + (None, 'horiz-origin-x'), + (None, 'id'), + (None, 'ideographic'), + (None, 'k'), + (None, 'keyPoints'), + (None, 'keySplines'), + (None, 'keyTimes'), + (None, 'lang'), + (None, 'marker-end'), + (None, 'marker-mid'), + (None, 'marker-start'), + (None, 'markerHeight'), + (None, 'markerUnits'), + (None, 'markerWidth'), + (None, 'mathematical'), + (None, 'max'), + (None, 'min'), + (None, 'name'), + (None, 'offset'), + (None, 'opacity'), + (None, 'orient'), + (None, 'origin'), + (None, 'overline-position'), + (None, 'overline-thickness'), + (None, 'panose-1'), + (None, 'path'), + (None, 'pathLength'), + (None, 'points'), + (None, 'preserveAspectRatio'), + (None, 'r'), + (None, 'refX'), + (None, 'refY'), + (None, 'repeatCount'), + (None, 'repeatDur'), + (None, 'requiredExtensions'), + (None, 'requiredFeatures'), + (None, 'restart'), + (None, 'rotate'), + (None, 'rx'), + (None, 'ry'), + (None, 'slope'), + (None, 'stemh'), + (None, 'stemv'), + (None, 'stop-color'), + (None, 'stop-opacity'), + (None, 'strikethrough-position'), + (None, 'strikethrough-thickness'), + (None, 'stroke'), + (None, 'stroke-dasharray'), + (None, 'stroke-dashoffset'), + (None, 'stroke-linecap'), + (None, 'stroke-linejoin'), + (None, 'stroke-miterlimit'), + (None, 'stroke-opacity'), + (None, 'stroke-width'), + (None, 'systemLanguage'), + (None, 'target'), + (None, 'text-anchor'), + (None, 'to'), + (None, 'transform'), + (None, 'type'), + (None, 'u1'), + (None, 'u2'), + (None, 'underline-position'), + (None, 'underline-thickness'), + (None, 'unicode'), + (None, 'unicode-range'), + (None, 'units-per-em'), + (None, 'values'), + (None, 'version'), + (None, 'viewBox'), + (None, 'visibility'), + (None, 'width'), + (None, 'widths'), + (None, 'x'), + (None, 'x-height'), + (None, 'x1'), + (None, 'x2'), + (namespaces['xlink'], 'actuate'), + (namespaces['xlink'], 'arcrole'), + (namespaces['xlink'], 'href'), + (namespaces['xlink'], 'role'), + (namespaces['xlink'], 'show'), + (namespaces['xlink'], 'title'), + (namespaces['xlink'], 'type'), + (namespaces['xml'], 'base'), + (namespaces['xml'], 'lang'), + (namespaces['xml'], 'space'), + (None, 'y'), + (None, 'y1'), + (None, 'y2'), + (None, 'zoomAndPan'), +)) + +attr_val_is_uri = frozenset(( + (None, 'href'), + (None, 'src'), + (None, 'cite'), + (None, 'action'), + (None, 'longdesc'), + (None, 'poster'), + (None, 'background'), + (None, 'datasrc'), + (None, 'dynsrc'), + (None, 'lowsrc'), + (None, 'ping'), + (namespaces['xlink'], 'href'), + (namespaces['xml'], 'base'), +)) + +svg_attr_val_allows_ref = frozenset(( + (None, 'clip-path'), + (None, 'color-profile'), + (None, 'cursor'), + (None, 'fill'), + (None, 'filter'), + (None, 'marker'), + (None, 'marker-start'), + (None, 'marker-mid'), + (None, 'marker-end'), + (None, 'mask'), + (None, 'stroke'), +)) + +svg_allow_local_href = frozenset(( + (None, 'altGlyph'), + (None, 'animate'), + (None, 'animateColor'), + (None, 'animateMotion'), + (None, 'animateTransform'), + (None, 'cursor'), + (None, 'feImage'), + (None, 'filter'), + (None, 'linearGradient'), + (None, 'pattern'), + (None, 'radialGradient'), + (None, 'textpath'), + (None, 'tref'), + (None, 'set'), + (None, 'use') +)) + +allowed_css_properties = frozenset(( + 'azimuth', + 'background-color', + 'border-bottom-color', + 'border-collapse', + 'border-color', + 'border-left-color', + 'border-right-color', + 'border-top-color', + 'clear', + 'color', + 'cursor', + 'direction', + 'display', + 'elevation', + 'float', + 'font', + 'font-family', + 'font-size', + 'font-style', + 'font-variant', + 'font-weight', + 'height', + 'letter-spacing', + 'line-height', + 'overflow', + 'pause', + 'pause-after', + 'pause-before', + 'pitch', + 'pitch-range', + 'richness', + 'speak', + 'speak-header', + 'speak-numeral', + 'speak-punctuation', + 'speech-rate', + 'stress', + 'text-align', + 'text-decoration', + 'text-indent', + 'unicode-bidi', + 'vertical-align', + 'voice-family', + 'volume', + 'white-space', + 'width', +)) + +allowed_css_keywords = frozenset(( + 'auto', + 'aqua', + 'black', + 'block', + 'blue', + 'bold', + 'both', + 'bottom', + 'brown', + 'center', + 'collapse', + 'dashed', + 'dotted', + 'fuchsia', + 'gray', + 'green', + '!important', + 'italic', + 'left', + 'lime', + 'maroon', + 'medium', + 'none', + 'navy', + 'normal', + 'nowrap', + 'olive', + 'pointer', + 'purple', + 'red', + 'right', + 'solid', + 'silver', + 'teal', + 'top', + 'transparent', + 'underline', + 'white', + 'yellow', +)) + +allowed_svg_properties = frozenset(( + 'fill', + 'fill-opacity', + 'fill-rule', + 'stroke', + 'stroke-width', + 'stroke-linecap', + 'stroke-linejoin', + 'stroke-opacity', +)) + +allowed_protocols = frozenset(( + 'ed2k', + 'ftp', + 'http', + 'https', + 'irc', + 'mailto', + 'news', + 'gopher', + 'nntp', + 'telnet', + 'webcal', + 'xmpp', + 'callto', + 'feed', + 'urn', + 'aim', + 'rsync', + 'tag', + 'ssh', + 'sftp', + 'rtsp', + 'afs', + 'data', +)) + +allowed_content_types = frozenset(( + 'image/png', + 'image/jpeg', + 'image/gif', + 'image/webp', + 'image/bmp', + 'text/plain', +)) + + +data_content_type = re.compile(r''' + ^ + # Match a content type <application>/<type> + (?P<content_type>[-a-zA-Z0-9.]+/[-a-zA-Z0-9.]+) + # Match any character set and encoding + (?:(?:;charset=(?:[-a-zA-Z0-9]+)(?:;(?:base64))?) + |(?:;(?:base64))?(?:;charset=(?:[-a-zA-Z0-9]+))?) + # Assume the rest is data + ,.* + $ + ''', + re.VERBOSE) + + +class Filter(base.Filter): + """Sanitizes token stream of XHTML+MathML+SVG and of inline style attributes""" + def __init__(self, + source, + allowed_elements=allowed_elements, + allowed_attributes=allowed_attributes, + allowed_css_properties=allowed_css_properties, + allowed_css_keywords=allowed_css_keywords, + allowed_svg_properties=allowed_svg_properties, + allowed_protocols=allowed_protocols, + allowed_content_types=allowed_content_types, + attr_val_is_uri=attr_val_is_uri, + svg_attr_val_allows_ref=svg_attr_val_allows_ref, + svg_allow_local_href=svg_allow_local_href): + """Creates a Filter + + :arg allowed_elements: set of elements to allow--everything else will + be escaped + + :arg allowed_attributes: set of attributes to allow in + elements--everything else will be stripped + + :arg allowed_css_properties: set of CSS properties to allow--everything + else will be stripped + + :arg allowed_css_keywords: set of CSS keywords to allow--everything + else will be stripped + + :arg allowed_svg_properties: set of SVG properties to allow--everything + else will be removed + + :arg allowed_protocols: set of allowed protocols for URIs + + :arg allowed_content_types: set of allowed content types for ``data`` URIs. + + :arg attr_val_is_uri: set of attributes that have URI values--values + that have a scheme not listed in ``allowed_protocols`` are removed + + :arg svg_attr_val_allows_ref: set of SVG attributes that can have + references + + :arg svg_allow_local_href: set of SVG elements that can have local + hrefs--these are removed + + """ + super(Filter, self).__init__(source) + self.allowed_elements = allowed_elements + self.allowed_attributes = allowed_attributes + self.allowed_css_properties = allowed_css_properties + self.allowed_css_keywords = allowed_css_keywords + self.allowed_svg_properties = allowed_svg_properties + self.allowed_protocols = allowed_protocols + self.allowed_content_types = allowed_content_types + self.attr_val_is_uri = attr_val_is_uri + self.svg_attr_val_allows_ref = svg_attr_val_allows_ref + self.svg_allow_local_href = svg_allow_local_href + + def __iter__(self): + for token in base.Filter.__iter__(self): + token = self.sanitize_token(token) + if token: + yield token + + # Sanitize the +html+, escaping all elements not in ALLOWED_ELEMENTS, and + # stripping out all attributes not in ALLOWED_ATTRIBUTES. Style attributes + # are parsed, and a restricted set, specified by ALLOWED_CSS_PROPERTIES and + # ALLOWED_CSS_KEYWORDS, are allowed through. attributes in ATTR_VAL_IS_URI + # are scanned, and only URI schemes specified in ALLOWED_PROTOCOLS are + # allowed. + # + # sanitize_html('<script> do_nasty_stuff() </script>') + # => <script> do_nasty_stuff() </script> + # sanitize_html('<a href="javascript: sucker();">Click here for $100</a>') + # => <a>Click here for $100</a> + def sanitize_token(self, token): + + # accommodate filters which use token_type differently + token_type = token["type"] + if token_type in ("StartTag", "EndTag", "EmptyTag"): + name = token["name"] + namespace = token["namespace"] + if ((namespace, name) in self.allowed_elements or + (namespace is None and + (namespaces["html"], name) in self.allowed_elements)): + return self.allowed_token(token) + else: + return self.disallowed_token(token) + elif token_type == "Comment": + pass + else: + return token + + def allowed_token(self, token): + if "data" in token: + attrs = token["data"] + attr_names = set(attrs.keys()) + + # Remove forbidden attributes + for to_remove in (attr_names - self.allowed_attributes): + del token["data"][to_remove] + attr_names.remove(to_remove) + + # Remove attributes with disallowed URL values + for attr in (attr_names & self.attr_val_is_uri): + assert attr in attrs + # I don't have a clue where this regexp comes from or why it matches those + # characters, nor why we call unescape. I just know it's always been here. + # Should you be worried by this comment in a sanitizer? Yes. On the other hand, all + # this will do is remove *more* than it otherwise would. + val_unescaped = re.sub("[`\x00-\x20\x7f-\xa0\\s]+", '', + unescape(attrs[attr])).lower() + # remove replacement characters from unescaped characters + val_unescaped = val_unescaped.replace("\ufffd", "") + try: + uri = urlparse.urlparse(val_unescaped) + except ValueError: + uri = None + del attrs[attr] + if uri and uri.scheme: + if uri.scheme not in self.allowed_protocols: + del attrs[attr] + if uri.scheme == 'data': + m = data_content_type.match(uri.path) + if not m: + del attrs[attr] + elif m.group('content_type') not in self.allowed_content_types: + del attrs[attr] + + for attr in self.svg_attr_val_allows_ref: + if attr in attrs: + attrs[attr] = re.sub(r'url\s*\(\s*[^#\s][^)]+?\)', + ' ', + unescape(attrs[attr])) + if (token["name"] in self.svg_allow_local_href and + (namespaces['xlink'], 'href') in attrs and re.search(r'^\s*[^#\s].*', + attrs[(namespaces['xlink'], 'href')])): + del attrs[(namespaces['xlink'], 'href')] + if (None, 'style') in attrs: + attrs[(None, 'style')] = self.sanitize_css(attrs[(None, 'style')]) + token["data"] = attrs + return token + + def disallowed_token(self, token): + token_type = token["type"] + if token_type == "EndTag": + token["data"] = "</%s>" % token["name"] + elif token["data"]: + assert token_type in ("StartTag", "EmptyTag") + attrs = [] + for (ns, name), v in token["data"].items(): + attrs.append(' %s="%s"' % (name if ns is None else "%s:%s" % (prefixes[ns], name), escape(v))) + token["data"] = "<%s%s>" % (token["name"], ''.join(attrs)) + else: + token["data"] = "<%s>" % token["name"] + if token.get("selfClosing"): + token["data"] = token["data"][:-1] + "/>" + + token["type"] = "Characters" + + del token["name"] + return token + + def sanitize_css(self, style): + # disallow urls + style = re.compile(r'url\s*\(\s*[^\s)]+?\s*\)\s*').sub(' ', style) + + # gauntlet + if not re.match(r"""^([:,;#%.\sa-zA-Z0-9!]|\w-\w|'[\s\w]+'|"[\s\w]+"|\([\d,\s]+\))*$""", style): + return '' + if not re.match(r"^\s*([-\w]+\s*:[^:;]*(;\s*|$))*$", style): + return '' + + clean = [] + for prop, value in re.findall(r"([-\w]+)\s*:\s*([^:;]*)", style): + if not value: + continue + if prop.lower() in self.allowed_css_properties: + clean.append(prop + ': ' + value + ';') + elif prop.split('-')[0].lower() in ['background', 'border', 'margin', + 'padding']: + for keyword in value.split(): + if keyword not in self.allowed_css_keywords and \ + not re.match(r"^(#[0-9a-fA-F]+|rgb\(\d+%?,\d*%?,?\d*%?\)?|\d{0,2}\.?\d{0,2}(cm|em|ex|in|mm|pc|pt|px|%|,|\))?)$", keyword): # noqa + break + else: + clean.append(prop + ': ' + value + ';') + elif prop.lower() in self.allowed_svg_properties: + clean.append(prop + ': ' + value + ';') + + return ' '.join(clean) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/whitespace.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/filters/whitespace.py new file mode 100644 index 0000000..0d12584 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/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/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/html5parser.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/html5parser.py new file mode 100644 index 0000000..ae41a13 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/html5parser.py @@ -0,0 +1,2791 @@ +from __future__ import absolute_import, division, unicode_literals +from pip._vendor.six import with_metaclass, viewkeys + +import types +from collections import OrderedDict + +from . import _inputstream +from . import _tokenizer + +from . import treebuilders +from .treebuilders.base import Marker + +from . import _utils +from .constants import ( + spaceCharacters, asciiUpper2Lower, + specialElements, headingElements, cdataElements, rcdataElements, + tokenTypes, tagTokenTypes, + namespaces, + htmlIntegrationPointElements, mathmlTextIntegrationPointElements, + adjustForeignAttributes as adjustForeignAttributesMap, + adjustMathMLAttributes, adjustSVGAttributes, + E, + _ReparseException +) + + +def parse(doc, treebuilder="etree", namespaceHTMLElements=True, **kwargs): + """Parse an HTML document as a string or file-like object into a tree + + :arg doc: the document to parse as a string or file-like object + + :arg treebuilder: the treebuilder to use when parsing + + :arg namespaceHTMLElements: whether or not to namespace HTML elements + + :returns: parsed tree + + Example: + + >>> from html5lib.html5parser import parse + >>> parse('<html><body><p>This is a doc</p></body></html>') + <Element u'{http://www.w3.org/1999/xhtml}html' at 0x7feac4909db0> + + """ + tb = treebuilders.getTreeBuilder(treebuilder) + p = HTMLParser(tb, namespaceHTMLElements=namespaceHTMLElements) + return p.parse(doc, **kwargs) + + +def parseFragment(doc, container="div", treebuilder="etree", namespaceHTMLElements=True, **kwargs): + """Parse an HTML fragment as a string or file-like object into a tree + + :arg doc: the fragment to parse as a string or file-like object + + :arg container: the container context to parse the fragment in + + :arg treebuilder: the treebuilder to use when parsing + + :arg namespaceHTMLElements: whether or not to namespace HTML elements + + :returns: parsed tree + + Example: + + >>> from html5lib.html5libparser import parseFragment + >>> parseFragment('<b>this is a fragment</b>') + <Element u'DOCUMENT_FRAGMENT' at 0x7feac484b090> + + """ + tb = treebuilders.getTreeBuilder(treebuilder) + p = HTMLParser(tb, namespaceHTMLElements=namespaceHTMLElements) + return p.parseFragment(doc, container=container, **kwargs) + + +def method_decorator_metaclass(function): + class Decorated(type): + def __new__(meta, classname, bases, classDict): + for attributeName, attribute in classDict.items(): + if isinstance(attribute, types.FunctionType): + attribute = function(attribute) + + classDict[attributeName] = attribute + return type.__new__(meta, classname, bases, classDict) + return Decorated + + +class HTMLParser(object): + """HTML parser + + Generates a tree structure from a stream of (possibly malformed) HTML. + + """ + + def __init__(self, tree=None, strict=False, namespaceHTMLElements=True, debug=False): + """ + :arg tree: a treebuilder class controlling the type of tree that will be + returned. Built in treebuilders can be accessed through + html5lib.treebuilders.getTreeBuilder(treeType) + + :arg strict: raise an exception when a parse error is encountered + + :arg namespaceHTMLElements: whether or not to namespace HTML elements + + :arg debug: whether or not to enable debug mode which logs things + + Example: + + >>> from html5lib.html5parser import HTMLParser + >>> parser = HTMLParser() # generates parser with etree builder + >>> parser = HTMLParser('lxml', strict=True) # generates parser with lxml builder which is strict + + """ + + # Raise an exception on the first error encountered + self.strict = strict + + if tree is None: + tree = treebuilders.getTreeBuilder("etree") + self.tree = tree(namespaceHTMLElements) + self.errors = [] + + self.phases = dict([(name, cls(self, self.tree)) for name, cls in + getPhases(debug).items()]) + + def _parse(self, stream, innerHTML=False, container="div", scripting=False, **kwargs): + + self.innerHTMLMode = innerHTML + self.container = container + self.scripting = scripting + self.tokenizer = _tokenizer.HTMLTokenizer(stream, parser=self, **kwargs) + self.reset() + + try: + self.mainLoop() + except _ReparseException: + self.reset() + self.mainLoop() + + def reset(self): + self.tree.reset() + self.firstStartTag = False + self.errors = [] + self.log = [] # only used with debug mode + # "quirks" / "limited quirks" / "no quirks" + self.compatMode = "no quirks" + + if self.innerHTMLMode: + self.innerHTML = self.container.lower() + + if self.innerHTML in cdataElements: + self.tokenizer.state = self.tokenizer.rcdataState + elif self.innerHTML in rcdataElements: + self.tokenizer.state = self.tokenizer.rawtextState + elif self.innerHTML == 'plaintext': + self.tokenizer.state = self.tokenizer.plaintextState + else: + # state already is data state + # self.tokenizer.state = self.tokenizer.dataState + pass + self.phase = self.phases["beforeHtml"] + self.phase.insertHtmlElement() + self.resetInsertionMode() + else: + self.innerHTML = False # pylint:disable=redefined-variable-type + self.phase = self.phases["initial"] + + self.lastPhase = None + + self.beforeRCDataPhase = None + + self.framesetOK = True + + @property + def documentEncoding(self): + """Name of the character encoding that was used to decode the input stream, or + :obj:`None` if that is not determined yet + + """ + if not hasattr(self, 'tokenizer'): + return None + return self.tokenizer.stream.charEncoding[0].name + + def isHTMLIntegrationPoint(self, element): + if (element.name == "annotation-xml" and + element.namespace == namespaces["mathml"]): + return ("encoding" in element.attributes and + element.attributes["encoding"].translate( + asciiUpper2Lower) in + ("text/html", "application/xhtml+xml")) + else: + return (element.namespace, element.name) in htmlIntegrationPointElements + + def isMathMLTextIntegrationPoint(self, element): + return (element.namespace, element.name) in mathmlTextIntegrationPointElements + + def mainLoop(self): + CharactersToken = tokenTypes["Characters"] + SpaceCharactersToken = tokenTypes["SpaceCharacters"] + StartTagToken = tokenTypes["StartTag"] + EndTagToken = tokenTypes["EndTag"] + CommentToken = tokenTypes["Comment"] + DoctypeToken = tokenTypes["Doctype"] + ParseErrorToken = tokenTypes["ParseError"] + + for token in self.normalizedTokens(): + prev_token = None + new_token = token + while new_token is not None: + prev_token = new_token + currentNode = self.tree.openElements[-1] if self.tree.openElements else None + currentNodeNamespace = currentNode.namespace if currentNode else None + currentNodeName = currentNode.name if currentNode else None + + type = new_token["type"] + + if type == ParseErrorToken: + self.parseError(new_token["data"], new_token.get("datavars", {})) + new_token = None + else: + if (len(self.tree.openElements) == 0 or + currentNodeNamespace == self.tree.defaultNamespace or + (self.isMathMLTextIntegrationPoint(currentNode) and + ((type == StartTagToken and + token["name"] not in frozenset(["mglyph", "malignmark"])) or + type in (CharactersToken, SpaceCharactersToken))) or + (currentNodeNamespace == namespaces["mathml"] and + currentNodeName == "annotation-xml" and + type == StartTagToken and + token["name"] == "svg") or + (self.isHTMLIntegrationPoint(currentNode) and + type in (StartTagToken, CharactersToken, SpaceCharactersToken))): + phase = self.phase + else: + phase = self.phases["inForeignContent"] + + if type == CharactersToken: + new_token = phase.processCharacters(new_token) + elif type == SpaceCharactersToken: + new_token = phase.processSpaceCharacters(new_token) + elif type == StartTagToken: + new_token = phase.processStartTag(new_token) + elif type == EndTagToken: + new_token = phase.processEndTag(new_token) + elif type == CommentToken: + new_token = phase.processComment(new_token) + elif type == DoctypeToken: + new_token = phase.processDoctype(new_token) + + if (type == StartTagToken and prev_token["selfClosing"] and + not prev_token["selfClosingAcknowledged"]): + self.parseError("non-void-element-with-trailing-solidus", + {"name": prev_token["name"]}) + + # When the loop finishes it's EOF + reprocess = True + phases = [] + while reprocess: + phases.append(self.phase) + reprocess = self.phase.processEOF() + if reprocess: + assert self.phase not in phases + + def normalizedTokens(self): + for token in self.tokenizer: + yield self.normalizeToken(token) + + def parse(self, stream, *args, **kwargs): + """Parse a HTML document into a well-formed tree + + :arg stream: a file-like object or string containing the HTML to be parsed + + The optional encoding parameter must be a string that indicates + the encoding. If specified, that encoding will be used, + regardless of any BOM or later declaration (such as in a meta + element). + + :arg scripting: treat noscript elements as if JavaScript was turned on + + :returns: parsed tree + + Example: + + >>> from html5lib.html5parser import HTMLParser + >>> parser = HTMLParser() + >>> parser.parse('<html><body><p>This is a doc</p></body></html>') + <Element u'{http://www.w3.org/1999/xhtml}html' at 0x7feac4909db0> + + """ + self._parse(stream, False, None, *args, **kwargs) + return self.tree.getDocument() + + def parseFragment(self, stream, *args, **kwargs): + """Parse a HTML fragment into a well-formed tree fragment + + :arg container: name of the element we're setting the innerHTML + property if set to None, default to 'div' + + :arg stream: a file-like object or string containing the HTML to be parsed + + The optional encoding parameter must be a string that indicates + the encoding. If specified, that encoding will be used, + regardless of any BOM or later declaration (such as in a meta + element) + + :arg scripting: treat noscript elements as if JavaScript was turned on + + :returns: parsed tree + + Example: + + >>> from html5lib.html5libparser import HTMLParser + >>> parser = HTMLParser() + >>> parser.parseFragment('<b>this is a fragment</b>') + <Element u'DOCUMENT_FRAGMENT' at 0x7feac484b090> + + """ + self._parse(stream, True, *args, **kwargs) + return self.tree.getFragment() + + def parseError(self, errorcode="XXX-undefined-error", datavars=None): + # XXX The idea is to make errorcode mandatory. + if datavars is None: + datavars = {} + self.errors.append((self.tokenizer.stream.position(), errorcode, datavars)) + if self.strict: + raise ParseError(E[errorcode] % datavars) + + def normalizeToken(self, token): + # HTML5 specific normalizations to the token stream + if token["type"] == tokenTypes["StartTag"]: + raw = token["data"] + token["data"] = OrderedDict(raw) + if len(raw) > len(token["data"]): + # we had some duplicated attribute, fix so first wins + token["data"].update(raw[::-1]) + + return token + + def adjustMathMLAttributes(self, token): + adjust_attributes(token, adjustMathMLAttributes) + + def adjustSVGAttributes(self, token): + adjust_attributes(token, adjustSVGAttributes) + + def adjustForeignAttributes(self, token): + adjust_attributes(token, adjustForeignAttributesMap) + + def reparseTokenNormal(self, token): + # pylint:disable=unused-argument + self.parser.phase() + + def resetInsertionMode(self): + # The name of this method is mostly historical. (It's also used in the + # specification.) + last = False + newModes = { + "select": "inSelect", + "td": "inCell", + "th": "inCell", + "tr": "inRow", + "tbody": "inTableBody", + "thead": "inTableBody", + "tfoot": "inTableBody", + "caption": "inCaption", + "colgroup": "inColumnGroup", + "table": "inTable", + "head": "inBody", + "body": "inBody", + "frameset": "inFrameset", + "html": "beforeHead" + } + for node in self.tree.openElements[::-1]: + nodeName = node.name + new_phase = None + if node == self.tree.openElements[0]: + assert self.innerHTML + last = True + nodeName = self.innerHTML + # Check for conditions that should only happen in the innerHTML + # case + if nodeName in ("select", "colgroup", "head", "html"): + assert self.innerHTML + + if not last and node.namespace != self.tree.defaultNamespace: + continue + + if nodeName in newModes: + new_phase = self.phases[newModes[nodeName]] + break + elif last: + new_phase = self.phases["inBody"] + break + + self.phase = new_phase + + def parseRCDataRawtext(self, token, contentType): + # Generic RCDATA/RAWTEXT Parsing algorithm + assert contentType in ("RAWTEXT", "RCDATA") + + self.tree.insertElement(token) + + if contentType == "RAWTEXT": + self.tokenizer.state = self.tokenizer.rawtextState + else: + self.tokenizer.state = self.tokenizer.rcdataState + + self.originalPhase = self.phase + + self.phase = self.phases["text"] + + +@_utils.memoize +def getPhases(debug): + def log(function): + """Logger that records which phase processes each token""" + type_names = dict((value, key) for key, value in + tokenTypes.items()) + + def wrapped(self, *args, **kwargs): + if function.__name__.startswith("process") and len(args) > 0: + token = args[0] + try: + info = {"type": type_names[token['type']]} + except: + raise + if token['type'] in tagTokenTypes: + info["name"] = token['name'] + + self.parser.log.append((self.parser.tokenizer.state.__name__, + self.parser.phase.__class__.__name__, + self.__class__.__name__, + function.__name__, + info)) + return function(self, *args, **kwargs) + else: + return function(self, *args, **kwargs) + return wrapped + + def getMetaclass(use_metaclass, metaclass_func): + if use_metaclass: + return method_decorator_metaclass(metaclass_func) + else: + return type + + # pylint:disable=unused-argument + class Phase(with_metaclass(getMetaclass(debug, log))): + """Base class for helper object that implements each phase of processing + """ + + def __init__(self, parser, tree): + self.parser = parser + self.tree = tree + + def processEOF(self): + raise NotImplementedError + + def processComment(self, token): + # For most phases the following is correct. Where it's not it will be + # overridden. + self.tree.insertComment(token, self.tree.openElements[-1]) + + def processDoctype(self, token): + self.parser.parseError("unexpected-doctype") + + def processCharacters(self, token): + self.tree.insertText(token["data"]) + + def processSpaceCharacters(self, token): + self.tree.insertText(token["data"]) + + def processStartTag(self, token): + return self.startTagHandler[token["name"]](token) + + def startTagHtml(self, token): + if not self.parser.firstStartTag and token["name"] == "html": + self.parser.parseError("non-html-root") + # XXX Need a check here to see if the first start tag token emitted is + # this token... If it's not, invoke self.parser.parseError(). + for attr, value in token["data"].items(): + if attr not in self.tree.openElements[0].attributes: + self.tree.openElements[0].attributes[attr] = value + self.parser.firstStartTag = False + + def processEndTag(self, token): + return self.endTagHandler[token["name"]](token) + + class InitialPhase(Phase): + def processSpaceCharacters(self, token): + pass + + def processComment(self, token): + self.tree.insertComment(token, self.tree.document) + + def processDoctype(self, token): + name = token["name"] + publicId = token["publicId"] + systemId = token["systemId"] + correct = token["correct"] + + if (name != "html" or publicId is not None or + systemId is not None and systemId != "about:legacy-compat"): + self.parser.parseError("unknown-doctype") + + if publicId is None: + publicId = "" + + self.tree.insertDoctype(token) + + if publicId != "": + publicId = publicId.translate(asciiUpper2Lower) + + if (not correct or token["name"] != "html" or + publicId.startswith( + ("+//silmaril//dtd html pro v0r11 19970101//", + "-//advasoft ltd//dtd html 3.0 aswedit + extensions//", + "-//as//dtd html 3.0 aswedit + extensions//", + "-//ietf//dtd html 2.0 level 1//", + "-//ietf//dtd html 2.0 level 2//", + "-//ietf//dtd html 2.0 strict level 1//", + "-//ietf//dtd html 2.0 strict level 2//", + "-//ietf//dtd html 2.0 strict//", + "-//ietf//dtd html 2.0//", + "-//ietf//dtd html 2.1e//", + "-//ietf//dtd html 3.0//", + "-//ietf//dtd html 3.2 final//", + "-//ietf//dtd html 3.2//", + "-//ietf//dtd html 3//", + "-//ietf//dtd html level 0//", + "-//ietf//dtd html level 1//", + "-//ietf//dtd html level 2//", + "-//ietf//dtd html level 3//", + "-//ietf//dtd html strict level 0//", + "-//ietf//dtd html strict level 1//", + "-//ietf//dtd html strict level 2//", + "-//ietf//dtd html strict level 3//", + "-//ietf//dtd html strict//", + "-//ietf//dtd html//", + "-//metrius//dtd metrius presentational//", + "-//microsoft//dtd internet explorer 2.0 html strict//", + "-//microsoft//dtd internet explorer 2.0 html//", + "-//microsoft//dtd internet explorer 2.0 tables//", + "-//microsoft//dtd internet explorer 3.0 html strict//", + "-//microsoft//dtd internet explorer 3.0 html//", + "-//microsoft//dtd internet explorer 3.0 tables//", + "-//netscape comm. corp.//dtd html//", + "-//netscape comm. corp.//dtd strict html//", + "-//o'reilly and associates//dtd html 2.0//", + "-//o'reilly and associates//dtd html extended 1.0//", + "-//o'reilly and associates//dtd html extended relaxed 1.0//", + "-//softquad software//dtd hotmetal pro 6.0::19990601::extensions to html 4.0//", + "-//softquad//dtd hotmetal pro 4.0::19971010::extensions to html 4.0//", + "-//spyglass//dtd html 2.0 extended//", + "-//sq//dtd html 2.0 hotmetal + extensions//", + "-//sun microsystems corp.//dtd hotjava html//", + "-//sun microsystems corp.//dtd hotjava strict html//", + "-//w3c//dtd html 3 1995-03-24//", + "-//w3c//dtd html 3.2 draft//", + "-//w3c//dtd html 3.2 final//", + "-//w3c//dtd html 3.2//", + "-//w3c//dtd html 3.2s draft//", + "-//w3c//dtd html 4.0 frameset//", + "-//w3c//dtd html 4.0 transitional//", + "-//w3c//dtd html experimental 19960712//", + "-//w3c//dtd html experimental 970421//", + "-//w3c//dtd w3 html//", + "-//w3o//dtd w3 html 3.0//", + "-//webtechs//dtd mozilla html 2.0//", + "-//webtechs//dtd mozilla html//")) or + publicId in ("-//w3o//dtd w3 html strict 3.0//en//", + "-/w3c/dtd html 4.0 transitional/en", + "html") or + publicId.startswith( + ("-//w3c//dtd html 4.01 frameset//", + "-//w3c//dtd html 4.01 transitional//")) and + systemId is None or + systemId and systemId.lower() == "http://www.ibm.com/data/dtd/v11/ibmxhtml1-transitional.dtd"): + self.parser.compatMode = "quirks" + elif (publicId.startswith( + ("-//w3c//dtd xhtml 1.0 frameset//", + "-//w3c//dtd xhtml 1.0 transitional//")) or + publicId.startswith( + ("-//w3c//dtd html 4.01 frameset//", + "-//w3c//dtd html 4.01 transitional//")) and + systemId is not None): + self.parser.compatMode = "limited quirks" + + self.parser.phase = self.parser.phases["beforeHtml"] + + def anythingElse(self): + self.parser.compatMode = "quirks" + self.parser.phase = self.parser.phases["beforeHtml"] + + def processCharacters(self, token): + self.parser.parseError("expected-doctype-but-got-chars") + self.anythingElse() + return token + + def processStartTag(self, token): + self.parser.parseError("expected-doctype-but-got-start-tag", + {"name": token["name"]}) + self.anythingElse() + return token + + def processEndTag(self, token): + self.parser.parseError("expected-doctype-but-got-end-tag", + {"name": token["name"]}) + self.anythingElse() + return token + + def processEOF(self): + self.parser.parseError("expected-doctype-but-got-eof") + self.anythingElse() + return True + + class BeforeHtmlPhase(Phase): + # helper methods + def insertHtmlElement(self): + self.tree.insertRoot(impliedTagToken("html", "StartTag")) + self.parser.phase = self.parser.phases["beforeHead"] + + # other + def processEOF(self): + self.insertHtmlElement() + return True + + def processComment(self, token): + self.tree.insertComment(token, self.tree.document) + + def processSpaceCharacters(self, token): + pass + + def processCharacters(self, token): + self.insertHtmlElement() + return token + + def processStartTag(self, token): + if token["name"] == "html": + self.parser.firstStartTag = True + self.insertHtmlElement() + return token + + def processEndTag(self, token): + if token["name"] not in ("head", "body", "html", "br"): + self.parser.parseError("unexpected-end-tag-before-html", + {"name": token["name"]}) + else: + self.insertHtmlElement() + return token + + class BeforeHeadPhase(Phase): + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml), + ("head", self.startTagHead) + ]) + self.startTagHandler.default = self.startTagOther + + self.endTagHandler = _utils.MethodDispatcher([ + (("head", "body", "html", "br"), self.endTagImplyHead) + ]) + self.endTagHandler.default = self.endTagOther + + def processEOF(self): + self.startTagHead(impliedTagToken("head", "StartTag")) + return True + + def processSpaceCharacters(self, token): + pass + + def processCharacters(self, token): + self.startTagHead(impliedTagToken("head", "StartTag")) + return token + + def startTagHtml(self, token): + return self.parser.phases["inBody"].processStartTag(token) + + def startTagHead(self, token): + self.tree.insertElement(token) + self.tree.headPointer = self.tree.openElements[-1] + self.parser.phase = self.parser.phases["inHead"] + + def startTagOther(self, token): + self.startTagHead(impliedTagToken("head", "StartTag")) + return token + + def endTagImplyHead(self, token): + self.startTagHead(impliedTagToken("head", "StartTag")) + return token + + def endTagOther(self, token): + self.parser.parseError("end-tag-after-implied-root", + {"name": token["name"]}) + + class InHeadPhase(Phase): + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml), + ("title", self.startTagTitle), + (("noframes", "style"), self.startTagNoFramesStyle), + ("noscript", self.startTagNoscript), + ("script", self.startTagScript), + (("base", "basefont", "bgsound", "command", "link"), + self.startTagBaseLinkCommand), + ("meta", self.startTagMeta), + ("head", self.startTagHead) + ]) + self.startTagHandler.default = self.startTagOther + + self.endTagHandler = _utils.MethodDispatcher([ + ("head", self.endTagHead), + (("br", "html", "body"), self.endTagHtmlBodyBr) + ]) + self.endTagHandler.default = self.endTagOther + + # the real thing + def processEOF(self): + self.anythingElse() + return True + + def processCharacters(self, token): + self.anythingElse() + return token + + def startTagHtml(self, token): + return self.parser.phases["inBody"].processStartTag(token) + + def startTagHead(self, token): + self.parser.parseError("two-heads-are-not-better-than-one") + + def startTagBaseLinkCommand(self, token): + self.tree.insertElement(token) + self.tree.openElements.pop() + token["selfClosingAcknowledged"] = True + + def startTagMeta(self, token): + self.tree.insertElement(token) + self.tree.openElements.pop() + token["selfClosingAcknowledged"] = True + + attributes = token["data"] + if self.parser.tokenizer.stream.charEncoding[1] == "tentative": + if "charset" in attributes: + self.parser.tokenizer.stream.changeEncoding(attributes["charset"]) + elif ("content" in attributes and + "http-equiv" in attributes and + attributes["http-equiv"].lower() == "content-type"): + # Encoding it as UTF-8 here is a hack, as really we should pass + # the abstract Unicode string, and just use the + # ContentAttrParser on that, but using UTF-8 allows all chars + # to be encoded and as a ASCII-superset works. + data = _inputstream.EncodingBytes(attributes["content"].encode("utf-8")) + parser = _inputstream.ContentAttrParser(data) + codec = parser.parse() + self.parser.tokenizer.stream.changeEncoding(codec) + + def startTagTitle(self, token): + self.parser.parseRCDataRawtext(token, "RCDATA") + + def startTagNoFramesStyle(self, token): + # Need to decide whether to implement the scripting-disabled case + self.parser.parseRCDataRawtext(token, "RAWTEXT") + + def startTagNoscript(self, token): + if self.parser.scripting: + self.parser.parseRCDataRawtext(token, "RAWTEXT") + else: + self.tree.insertElement(token) + self.parser.phase = self.parser.phases["inHeadNoscript"] + + def startTagScript(self, token): + self.tree.insertElement(token) + self.parser.tokenizer.state = self.parser.tokenizer.scriptDataState + self.parser.originalPhase = self.parser.phase + self.parser.phase = self.parser.phases["text"] + + def startTagOther(self, token): + self.anythingElse() + return token + + def endTagHead(self, token): + node = self.parser.tree.openElements.pop() + assert node.name == "head", "Expected head got %s" % node.name + self.parser.phase = self.parser.phases["afterHead"] + + def endTagHtmlBodyBr(self, token): + self.anythingElse() + return token + + def endTagOther(self, token): + self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) + + def anythingElse(self): + self.endTagHead(impliedTagToken("head")) + + class InHeadNoscriptPhase(Phase): + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml), + (("basefont", "bgsound", "link", "meta", "noframes", "style"), self.startTagBaseLinkCommand), + (("head", "noscript"), self.startTagHeadNoscript), + ]) + self.startTagHandler.default = self.startTagOther + + self.endTagHandler = _utils.MethodDispatcher([ + ("noscript", self.endTagNoscript), + ("br", self.endTagBr), + ]) + self.endTagHandler.default = self.endTagOther + + def processEOF(self): + self.parser.parseError("eof-in-head-noscript") + self.anythingElse() + return True + + def processComment(self, token): + return self.parser.phases["inHead"].processComment(token) + + def processCharacters(self, token): + self.parser.parseError("char-in-head-noscript") + self.anythingElse() + return token + + def processSpaceCharacters(self, token): + return self.parser.phases["inHead"].processSpaceCharacters(token) + + def startTagHtml(self, token): + return self.parser.phases["inBody"].processStartTag(token) + + def startTagBaseLinkCommand(self, token): + return self.parser.phases["inHead"].processStartTag(token) + + def startTagHeadNoscript(self, token): + self.parser.parseError("unexpected-start-tag", {"name": token["name"]}) + + def startTagOther(self, token): + self.parser.parseError("unexpected-inhead-noscript-tag", {"name": token["name"]}) + self.anythingElse() + return token + + def endTagNoscript(self, token): + node = self.parser.tree.openElements.pop() + assert node.name == "noscript", "Expected noscript got %s" % node.name + self.parser.phase = self.parser.phases["inHead"] + + def endTagBr(self, token): + self.parser.parseError("unexpected-inhead-noscript-tag", {"name": token["name"]}) + self.anythingElse() + return token + + def endTagOther(self, token): + self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) + + def anythingElse(self): + # Caller must raise parse error first! + self.endTagNoscript(impliedTagToken("noscript")) + + class AfterHeadPhase(Phase): + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml), + ("body", self.startTagBody), + ("frameset", self.startTagFrameset), + (("base", "basefont", "bgsound", "link", "meta", "noframes", "script", + "style", "title"), + self.startTagFromHead), + ("head", self.startTagHead) + ]) + self.startTagHandler.default = self.startTagOther + self.endTagHandler = _utils.MethodDispatcher([(("body", "html", "br"), + self.endTagHtmlBodyBr)]) + self.endTagHandler.default = self.endTagOther + + def processEOF(self): + self.anythingElse() + return True + + def processCharacters(self, token): + self.anythingElse() + return token + + def startTagHtml(self, token): + return self.parser.phases["inBody"].processStartTag(token) + + def startTagBody(self, token): + self.parser.framesetOK = False + self.tree.insertElement(token) + self.parser.phase = self.parser.phases["inBody"] + + def startTagFrameset(self, token): + self.tree.insertElement(token) + self.parser.phase = self.parser.phases["inFrameset"] + + def startTagFromHead(self, token): + self.parser.parseError("unexpected-start-tag-out-of-my-head", + {"name": token["name"]}) + self.tree.openElements.append(self.tree.headPointer) + self.parser.phases["inHead"].processStartTag(token) + for node in self.tree.openElements[::-1]: + if node.name == "head": + self.tree.openElements.remove(node) + break + + def startTagHead(self, token): + self.parser.parseError("unexpected-start-tag", {"name": token["name"]}) + + def startTagOther(self, token): + self.anythingElse() + return token + + def endTagHtmlBodyBr(self, token): + self.anythingElse() + return token + + def endTagOther(self, token): + self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) + + def anythingElse(self): + self.tree.insertElement(impliedTagToken("body", "StartTag")) + self.parser.phase = self.parser.phases["inBody"] + self.parser.framesetOK = True + + class InBodyPhase(Phase): + # http://www.whatwg.org/specs/web-apps/current-work/#parsing-main-inbody + # the really-really-really-very crazy mode + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + + # Set this to the default handler + self.processSpaceCharacters = self.processSpaceCharactersNonPre + + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml), + (("base", "basefont", "bgsound", "command", "link", "meta", + "script", "style", "title"), + self.startTagProcessInHead), + ("body", self.startTagBody), + ("frameset", self.startTagFrameset), + (("address", "article", "aside", "blockquote", "center", "details", + "dir", "div", "dl", "fieldset", "figcaption", "figure", + "footer", "header", "hgroup", "main", "menu", "nav", "ol", "p", + "section", "summary", "ul"), + self.startTagCloseP), + (headingElements, self.startTagHeading), + (("pre", "listing"), self.startTagPreListing), + ("form", self.startTagForm), + (("li", "dd", "dt"), self.startTagListItem), + ("plaintext", self.startTagPlaintext), + ("a", self.startTagA), + (("b", "big", "code", "em", "font", "i", "s", "small", "strike", + "strong", "tt", "u"), self.startTagFormatting), + ("nobr", self.startTagNobr), + ("button", self.startTagButton), + (("applet", "marquee", "object"), self.startTagAppletMarqueeObject), + ("xmp", self.startTagXmp), + ("table", self.startTagTable), + (("area", "br", "embed", "img", "keygen", "wbr"), + self.startTagVoidFormatting), + (("param", "source", "track"), self.startTagParamSource), + ("input", self.startTagInput), + ("hr", self.startTagHr), + ("image", self.startTagImage), + ("isindex", self.startTagIsIndex), + ("textarea", self.startTagTextarea), + ("iframe", self.startTagIFrame), + ("noscript", self.startTagNoscript), + (("noembed", "noframes"), self.startTagRawtext), + ("select", self.startTagSelect), + (("rp", "rt"), self.startTagRpRt), + (("option", "optgroup"), self.startTagOpt), + (("math"), self.startTagMath), + (("svg"), self.startTagSvg), + (("caption", "col", "colgroup", "frame", "head", + "tbody", "td", "tfoot", "th", "thead", + "tr"), self.startTagMisplaced) + ]) + self.startTagHandler.default = self.startTagOther + + self.endTagHandler = _utils.MethodDispatcher([ + ("body", self.endTagBody), + ("html", self.endTagHtml), + (("address", "article", "aside", "blockquote", "button", "center", + "details", "dialog", "dir", "div", "dl", "fieldset", "figcaption", "figure", + "footer", "header", "hgroup", "listing", "main", "menu", "nav", "ol", "pre", + "section", "summary", "ul"), self.endTagBlock), + ("form", self.endTagForm), + ("p", self.endTagP), + (("dd", "dt", "li"), self.endTagListItem), + (headingElements, self.endTagHeading), + (("a", "b", "big", "code", "em", "font", "i", "nobr", "s", "small", + "strike", "strong", "tt", "u"), self.endTagFormatting), + (("applet", "marquee", "object"), self.endTagAppletMarqueeObject), + ("br", self.endTagBr), + ]) + self.endTagHandler.default = self.endTagOther + + def isMatchingFormattingElement(self, node1, node2): + return (node1.name == node2.name and + node1.namespace == node2.namespace and + node1.attributes == node2.attributes) + + # helper + def addFormattingElement(self, token): + self.tree.insertElement(token) + element = self.tree.openElements[-1] + + matchingElements = [] + for node in self.tree.activeFormattingElements[::-1]: + if node is Marker: + break + elif self.isMatchingFormattingElement(node, element): + matchingElements.append(node) + + assert len(matchingElements) <= 3 + if len(matchingElements) == 3: + self.tree.activeFormattingElements.remove(matchingElements[-1]) + self.tree.activeFormattingElements.append(element) + + # the real deal + def processEOF(self): + allowed_elements = frozenset(("dd", "dt", "li", "p", "tbody", "td", + "tfoot", "th", "thead", "tr", "body", + "html")) + for node in self.tree.openElements[::-1]: + if node.name not in allowed_elements: + self.parser.parseError("expected-closing-tag-but-got-eof") + break + # Stop parsing + + def processSpaceCharactersDropNewline(self, token): + # Sometimes (start of <pre>, <listing>, and <textarea> blocks) we + # want to drop leading newlines + data = token["data"] + self.processSpaceCharacters = self.processSpaceCharactersNonPre + if (data.startswith("\n") and + self.tree.openElements[-1].name in ("pre", "listing", "textarea") and + not self.tree.openElements[-1].hasContent()): + data = data[1:] + if data: + self.tree.reconstructActiveFormattingElements() + self.tree.insertText(data) + + def processCharacters(self, token): + if token["data"] == "\u0000": + # The tokenizer should always emit null on its own + return + self.tree.reconstructActiveFormattingElements() + self.tree.insertText(token["data"]) + # This must be bad for performance + if (self.parser.framesetOK and + any([char not in spaceCharacters + for char in token["data"]])): + self.parser.framesetOK = False + + def processSpaceCharactersNonPre(self, token): + self.tree.reconstructActiveFormattingElements() + self.tree.insertText(token["data"]) + + def startTagProcessInHead(self, token): + return self.parser.phases["inHead"].processStartTag(token) + + def startTagBody(self, token): + self.parser.parseError("unexpected-start-tag", {"name": "body"}) + if (len(self.tree.openElements) == 1 or + self.tree.openElements[1].name != "body"): + assert self.parser.innerHTML + else: + self.parser.framesetOK = False + for attr, value in token["data"].items(): + if attr not in self.tree.openElements[1].attributes: + self.tree.openElements[1].attributes[attr] = value + + def startTagFrameset(self, token): + self.parser.parseError("unexpected-start-tag", {"name": "frameset"}) + if (len(self.tree.openElements) == 1 or self.tree.openElements[1].name != "body"): + assert self.parser.innerHTML + elif not self.parser.framesetOK: + pass + else: + if self.tree.openElements[1].parent: + self.tree.openElements[1].parent.removeChild(self.tree.openElements[1]) + while self.tree.openElements[-1].name != "html": + self.tree.openElements.pop() + self.tree.insertElement(token) + self.parser.phase = self.parser.phases["inFrameset"] + + def startTagCloseP(self, token): + if self.tree.elementInScope("p", variant="button"): + self.endTagP(impliedTagToken("p")) + self.tree.insertElement(token) + + def startTagPreListing(self, token): + if self.tree.elementInScope("p", variant="button"): + self.endTagP(impliedTagToken("p")) + self.tree.insertElement(token) + self.parser.framesetOK = False + self.processSpaceCharacters = self.processSpaceCharactersDropNewline + + def startTagForm(self, token): + if self.tree.formPointer: + self.parser.parseError("unexpected-start-tag", {"name": "form"}) + else: + if self.tree.elementInScope("p", variant="button"): + self.endTagP(impliedTagToken("p")) + self.tree.insertElement(token) + self.tree.formPointer = self.tree.openElements[-1] + + def startTagListItem(self, token): + self.parser.framesetOK = False + + stopNamesMap = {"li": ["li"], + "dt": ["dt", "dd"], + "dd": ["dt", "dd"]} + stopNames = stopNamesMap[token["name"]] + for node in reversed(self.tree.openElements): + if node.name in stopNames: + self.parser.phase.processEndTag( + impliedTagToken(node.name, "EndTag")) + break + if (node.nameTuple in specialElements and + node.name not in ("address", "div", "p")): + break + + if self.tree.elementInScope("p", variant="button"): + self.parser.phase.processEndTag( + impliedTagToken("p", "EndTag")) + + self.tree.insertElement(token) + + def startTagPlaintext(self, token): + if self.tree.elementInScope("p", variant="button"): + self.endTagP(impliedTagToken("p")) + self.tree.insertElement(token) + self.parser.tokenizer.state = self.parser.tokenizer.plaintextState + + def startTagHeading(self, token): + if self.tree.elementInScope("p", variant="button"): + self.endTagP(impliedTagToken("p")) + if self.tree.openElements[-1].name in headingElements: + self.parser.parseError("unexpected-start-tag", {"name": token["name"]}) + self.tree.openElements.pop() + self.tree.insertElement(token) + + def startTagA(self, token): + afeAElement = self.tree.elementInActiveFormattingElements("a") + if afeAElement: + self.parser.parseError("unexpected-start-tag-implies-end-tag", + {"startName": "a", "endName": "a"}) + self.endTagFormatting(impliedTagToken("a")) + if afeAElement in self.tree.openElements: + self.tree.openElements.remove(afeAElement) + if afeAElement in self.tree.activeFormattingElements: + self.tree.activeFormattingElements.remove(afeAElement) + self.tree.reconstructActiveFormattingElements() + self.addFormattingElement(token) + + def startTagFormatting(self, token): + self.tree.reconstructActiveFormattingElements() + self.addFormattingElement(token) + + def startTagNobr(self, token): + self.tree.reconstructActiveFormattingElements() + if self.tree.elementInScope("nobr"): + self.parser.parseError("unexpected-start-tag-implies-end-tag", + {"startName": "nobr", "endName": "nobr"}) + self.processEndTag(impliedTagToken("nobr")) + # XXX Need tests that trigger the following + self.tree.reconstructActiveFormattingElements() + self.addFormattingElement(token) + + def startTagButton(self, token): + if self.tree.elementInScope("button"): + self.parser.parseError("unexpected-start-tag-implies-end-tag", + {"startName": "button", "endName": "button"}) + self.processEndTag(impliedTagToken("button")) + return token + else: + self.tree.reconstructActiveFormattingElements() + self.tree.insertElement(token) + self.parser.framesetOK = False + + def startTagAppletMarqueeObject(self, token): + self.tree.reconstructActiveFormattingElements() + self.tree.insertElement(token) + self.tree.activeFormattingElements.append(Marker) + self.parser.framesetOK = False + + def startTagXmp(self, token): + if self.tree.elementInScope("p", variant="button"): + self.endTagP(impliedTagToken("p")) + self.tree.reconstructActiveFormattingElements() + self.parser.framesetOK = False + self.parser.parseRCDataRawtext(token, "RAWTEXT") + + def startTagTable(self, token): + if self.parser.compatMode != "quirks": + if self.tree.elementInScope("p", variant="button"): + self.processEndTag(impliedTagToken("p")) + self.tree.insertElement(token) + self.parser.framesetOK = False + self.parser.phase = self.parser.phases["inTable"] + + def startTagVoidFormatting(self, token): + self.tree.reconstructActiveFormattingElements() + self.tree.insertElement(token) + self.tree.openElements.pop() + token["selfClosingAcknowledged"] = True + self.parser.framesetOK = False + + def startTagInput(self, token): + framesetOK = self.parser.framesetOK + self.startTagVoidFormatting(token) + if ("type" in token["data"] and + token["data"]["type"].translate(asciiUpper2Lower) == "hidden"): + # input type=hidden doesn't change framesetOK + self.parser.framesetOK = framesetOK + + def startTagParamSource(self, token): + self.tree.insertElement(token) + self.tree.openElements.pop() + token["selfClosingAcknowledged"] = True + + def startTagHr(self, token): + if self.tree.elementInScope("p", variant="button"): + self.endTagP(impliedTagToken("p")) + self.tree.insertElement(token) + self.tree.openElements.pop() + token["selfClosingAcknowledged"] = True + self.parser.framesetOK = False + + def startTagImage(self, token): + # No really... + self.parser.parseError("unexpected-start-tag-treated-as", + {"originalName": "image", "newName": "img"}) + self.processStartTag(impliedTagToken("img", "StartTag", + attributes=token["data"], + selfClosing=token["selfClosing"])) + + def startTagIsIndex(self, token): + self.parser.parseError("deprecated-tag", {"name": "isindex"}) + if self.tree.formPointer: + return + form_attrs = {} + if "action" in token["data"]: + form_attrs["action"] = token["data"]["action"] + self.processStartTag(impliedTagToken("form", "StartTag", + attributes=form_attrs)) + self.processStartTag(impliedTagToken("hr", "StartTag")) + self.processStartTag(impliedTagToken("label", "StartTag")) + # XXX Localization ... + if "prompt" in token["data"]: + prompt = token["data"]["prompt"] + else: + prompt = "This is a searchable index. Enter search keywords: " + self.processCharacters( + {"type": tokenTypes["Characters"], "data": prompt}) + attributes = token["data"].copy() + if "action" in attributes: + del attributes["action"] + if "prompt" in attributes: + del attributes["prompt"] + attributes["name"] = "isindex" + self.processStartTag(impliedTagToken("input", "StartTag", + attributes=attributes, + selfClosing=token["selfClosing"])) + self.processEndTag(impliedTagToken("label")) + self.processStartTag(impliedTagToken("hr", "StartTag")) + self.processEndTag(impliedTagToken("form")) + + def startTagTextarea(self, token): + self.tree.insertElement(token) + self.parser.tokenizer.state = self.parser.tokenizer.rcdataState + self.processSpaceCharacters = self.processSpaceCharactersDropNewline + self.parser.framesetOK = False + + def startTagIFrame(self, token): + self.parser.framesetOK = False + self.startTagRawtext(token) + + def startTagNoscript(self, token): + if self.parser.scripting: + self.startTagRawtext(token) + else: + self.startTagOther(token) + + def startTagRawtext(self, token): + """iframe, noembed noframes, noscript(if scripting enabled)""" + self.parser.parseRCDataRawtext(token, "RAWTEXT") + + def startTagOpt(self, token): + if self.tree.openElements[-1].name == "option": + self.parser.phase.processEndTag(impliedTagToken("option")) + self.tree.reconstructActiveFormattingElements() + self.parser.tree.insertElement(token) + + def startTagSelect(self, token): + self.tree.reconstructActiveFormattingElements() + self.tree.insertElement(token) + self.parser.framesetOK = False + if self.parser.phase in (self.parser.phases["inTable"], + self.parser.phases["inCaption"], + self.parser.phases["inColumnGroup"], + self.parser.phases["inTableBody"], + self.parser.phases["inRow"], + self.parser.phases["inCell"]): + self.parser.phase = self.parser.phases["inSelectInTable"] + else: + self.parser.phase = self.parser.phases["inSelect"] + + def startTagRpRt(self, token): + if self.tree.elementInScope("ruby"): + self.tree.generateImpliedEndTags() + if self.tree.openElements[-1].name != "ruby": + self.parser.parseError() + self.tree.insertElement(token) + + def startTagMath(self, token): + self.tree.reconstructActiveFormattingElements() + self.parser.adjustMathMLAttributes(token) + self.parser.adjustForeignAttributes(token) + token["namespace"] = namespaces["mathml"] + self.tree.insertElement(token) + # Need to get the parse error right for the case where the token + # has a namespace not equal to the xmlns attribute + if token["selfClosing"]: + self.tree.openElements.pop() + token["selfClosingAcknowledged"] = True + + def startTagSvg(self, token): + self.tree.reconstructActiveFormattingElements() + self.parser.adjustSVGAttributes(token) + self.parser.adjustForeignAttributes(token) + token["namespace"] = namespaces["svg"] + self.tree.insertElement(token) + # Need to get the parse error right for the case where the token + # has a namespace not equal to the xmlns attribute + if token["selfClosing"]: + self.tree.openElements.pop() + token["selfClosingAcknowledged"] = True + + def startTagMisplaced(self, token): + """ Elements that should be children of other elements that have a + different insertion mode; here they are ignored + "caption", "col", "colgroup", "frame", "frameset", "head", + "option", "optgroup", "tbody", "td", "tfoot", "th", "thead", + "tr", "noscript" + """ + self.parser.parseError("unexpected-start-tag-ignored", {"name": token["name"]}) + + def startTagOther(self, token): + self.tree.reconstructActiveFormattingElements() + self.tree.insertElement(token) + + def endTagP(self, token): + if not self.tree.elementInScope("p", variant="button"): + self.startTagCloseP(impliedTagToken("p", "StartTag")) + self.parser.parseError("unexpected-end-tag", {"name": "p"}) + self.endTagP(impliedTagToken("p", "EndTag")) + else: + self.tree.generateImpliedEndTags("p") + if self.tree.openElements[-1].name != "p": + self.parser.parseError("unexpected-end-tag", {"name": "p"}) + node = self.tree.openElements.pop() + while node.name != "p": + node = self.tree.openElements.pop() + + def endTagBody(self, token): + if not self.tree.elementInScope("body"): + self.parser.parseError() + return + elif self.tree.openElements[-1].name != "body": + for node in self.tree.openElements[2:]: + if node.name not in frozenset(("dd", "dt", "li", "optgroup", + "option", "p", "rp", "rt", + "tbody", "td", "tfoot", + "th", "thead", "tr", "body", + "html")): + # Not sure this is the correct name for the parse error + self.parser.parseError( + "expected-one-end-tag-but-got-another", + {"gotName": "body", "expectedName": node.name}) + break + self.parser.phase = self.parser.phases["afterBody"] + + def endTagHtml(self, token): + # We repeat the test for the body end tag token being ignored here + if self.tree.elementInScope("body"): + self.endTagBody(impliedTagToken("body")) + return token + + def endTagBlock(self, token): + # Put us back in the right whitespace handling mode + if token["name"] == "pre": + self.processSpaceCharacters = self.processSpaceCharactersNonPre + inScope = self.tree.elementInScope(token["name"]) + if inScope: + self.tree.generateImpliedEndTags() + if self.tree.openElements[-1].name != token["name"]: + self.parser.parseError("end-tag-too-early", {"name": token["name"]}) + if inScope: + node = self.tree.openElements.pop() + while node.name != token["name"]: + node = self.tree.openElements.pop() + + def endTagForm(self, token): + node = self.tree.formPointer + self.tree.formPointer = None + if node is None or not self.tree.elementInScope(node): + self.parser.parseError("unexpected-end-tag", + {"name": "form"}) + else: + self.tree.generateImpliedEndTags() + if self.tree.openElements[-1] != node: + self.parser.parseError("end-tag-too-early-ignored", + {"name": "form"}) + self.tree.openElements.remove(node) + + def endTagListItem(self, token): + if token["name"] == "li": + variant = "list" + else: + variant = None + if not self.tree.elementInScope(token["name"], variant=variant): + self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) + else: + self.tree.generateImpliedEndTags(exclude=token["name"]) + if self.tree.openElements[-1].name != token["name"]: + self.parser.parseError( + "end-tag-too-early", + {"name": token["name"]}) + node = self.tree.openElements.pop() + while node.name != token["name"]: + node = self.tree.openElements.pop() + + def endTagHeading(self, token): + for item in headingElements: + if self.tree.elementInScope(item): + self.tree.generateImpliedEndTags() + break + if self.tree.openElements[-1].name != token["name"]: + self.parser.parseError("end-tag-too-early", {"name": token["name"]}) + + for item in headingElements: + if self.tree.elementInScope(item): + item = self.tree.openElements.pop() + while item.name not in headingElements: + item = self.tree.openElements.pop() + break + + def endTagFormatting(self, token): + """The much-feared adoption agency algorithm""" + # http://svn.whatwg.org/webapps/complete.html#adoptionAgency revision 7867 + # XXX Better parseError messages appreciated. + + # Step 1 + outerLoopCounter = 0 + + # Step 2 + while outerLoopCounter < 8: + + # Step 3 + outerLoopCounter += 1 + + # Step 4: + + # Let the formatting element be the last element in + # the list of active formatting elements that: + # - is between the end of the list and the last scope + # marker in the list, if any, or the start of the list + # otherwise, and + # - has the same tag name as the token. + formattingElement = self.tree.elementInActiveFormattingElements( + token["name"]) + if (not formattingElement or + (formattingElement in self.tree.openElements and + not self.tree.elementInScope(formattingElement.name))): + # If there is no such node, then abort these steps + # and instead act as described in the "any other + # end tag" entry below. + self.endTagOther(token) + return + + # Otherwise, if there is such a node, but that node is + # not in the stack of open elements, then this is a + # parse error; remove the element from the list, and + # abort these steps. + elif formattingElement not in self.tree.openElements: + self.parser.parseError("adoption-agency-1.2", {"name": token["name"]}) + self.tree.activeFormattingElements.remove(formattingElement) + return + + # Otherwise, if there is such a node, and that node is + # also in the stack of open elements, but the element + # is not in scope, then this is a parse error; ignore + # the token, and abort these steps. + elif not self.tree.elementInScope(formattingElement.name): + self.parser.parseError("adoption-agency-4.4", {"name": token["name"]}) + return + + # Otherwise, there is a formatting element and that + # element is in the stack and is in scope. If the + # element is not the current node, this is a parse + # error. In any case, proceed with the algorithm as + # written in the following steps. + else: + if formattingElement != self.tree.openElements[-1]: + self.parser.parseError("adoption-agency-1.3", {"name": token["name"]}) + + # Step 5: + + # Let the furthest block be the topmost node in the + # stack of open elements that is lower in the stack + # than the formatting element, and is an element in + # the special category. There might not be one. + afeIndex = self.tree.openElements.index(formattingElement) + furthestBlock = None + for element in self.tree.openElements[afeIndex:]: + if element.nameTuple in specialElements: + furthestBlock = element + break + + # Step 6: + + # If there is no furthest block, then the UA must + # first pop all the nodes from the bottom of the stack + # of open elements, from the current node up to and + # including the formatting element, then remove the + # formatting element from the list of active + # formatting elements, and finally abort these steps. + if furthestBlock is None: + element = self.tree.openElements.pop() + while element != formattingElement: + element = self.tree.openElements.pop() + self.tree.activeFormattingElements.remove(element) + return + + # Step 7 + commonAncestor = self.tree.openElements[afeIndex - 1] + + # Step 8: + # The bookmark is supposed to help us identify where to reinsert + # nodes in step 15. We have to ensure that we reinsert nodes after + # the node before the active formatting element. Note the bookmark + # can move in step 9.7 + bookmark = self.tree.activeFormattingElements.index(formattingElement) + + # Step 9 + lastNode = node = furthestBlock + innerLoopCounter = 0 + + index = self.tree.openElements.index(node) + while innerLoopCounter < 3: + innerLoopCounter += 1 + # Node is element before node in open elements + index -= 1 + node = self.tree.openElements[index] + if node not in self.tree.activeFormattingElements: + self.tree.openElements.remove(node) + continue + # Step 9.6 + if node == formattingElement: + break + # Step 9.7 + if lastNode == furthestBlock: + bookmark = self.tree.activeFormattingElements.index(node) + 1 + # Step 9.8 + clone = node.cloneNode() + # Replace node with clone + self.tree.activeFormattingElements[ + self.tree.activeFormattingElements.index(node)] = clone + self.tree.openElements[ + self.tree.openElements.index(node)] = clone + node = clone + # Step 9.9 + # Remove lastNode from its parents, if any + if lastNode.parent: + lastNode.parent.removeChild(lastNode) + node.appendChild(lastNode) + # Step 9.10 + lastNode = node + + # Step 10 + # Foster parent lastNode if commonAncestor is a + # table, tbody, tfoot, thead, or tr we need to foster + # parent the lastNode + if lastNode.parent: + lastNode.parent.removeChild(lastNode) + + if commonAncestor.name in frozenset(("table", "tbody", "tfoot", "thead", "tr")): + parent, insertBefore = self.tree.getTableMisnestedNodePosition() + parent.insertBefore(lastNode, insertBefore) + else: + commonAncestor.appendChild(lastNode) + + # Step 11 + clone = formattingElement.cloneNode() + + # Step 12 + furthestBlock.reparentChildren(clone) + + # Step 13 + furthestBlock.appendChild(clone) + + # Step 14 + self.tree.activeFormattingElements.remove(formattingElement) + self.tree.activeFormattingElements.insert(bookmark, clone) + + # Step 15 + self.tree.openElements.remove(formattingElement) + self.tree.openElements.insert( + self.tree.openElements.index(furthestBlock) + 1, clone) + + def endTagAppletMarqueeObject(self, token): + if self.tree.elementInScope(token["name"]): + self.tree.generateImpliedEndTags() + if self.tree.openElements[-1].name != token["name"]: + self.parser.parseError("end-tag-too-early", {"name": token["name"]}) + + if self.tree.elementInScope(token["name"]): + element = self.tree.openElements.pop() + while element.name != token["name"]: + element = self.tree.openElements.pop() + self.tree.clearActiveFormattingElements() + + def endTagBr(self, token): + self.parser.parseError("unexpected-end-tag-treated-as", + {"originalName": "br", "newName": "br element"}) + self.tree.reconstructActiveFormattingElements() + self.tree.insertElement(impliedTagToken("br", "StartTag")) + self.tree.openElements.pop() + + def endTagOther(self, token): + for node in self.tree.openElements[::-1]: + if node.name == token["name"]: + self.tree.generateImpliedEndTags(exclude=token["name"]) + if self.tree.openElements[-1].name != token["name"]: + self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) + while self.tree.openElements.pop() != node: + pass + break + else: + if node.nameTuple in specialElements: + self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) + break + + class TextPhase(Phase): + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + self.startTagHandler = _utils.MethodDispatcher([]) + self.startTagHandler.default = self.startTagOther + self.endTagHandler = _utils.MethodDispatcher([ + ("script", self.endTagScript)]) + self.endTagHandler.default = self.endTagOther + + def processCharacters(self, token): + self.tree.insertText(token["data"]) + + def processEOF(self): + self.parser.parseError("expected-named-closing-tag-but-got-eof", + {"name": self.tree.openElements[-1].name}) + self.tree.openElements.pop() + self.parser.phase = self.parser.originalPhase + return True + + def startTagOther(self, token): + assert False, "Tried to process start tag %s in RCDATA/RAWTEXT mode" % token['name'] + + def endTagScript(self, token): + node = self.tree.openElements.pop() + assert node.name == "script" + self.parser.phase = self.parser.originalPhase + # The rest of this method is all stuff that only happens if + # document.write works + + def endTagOther(self, token): + self.tree.openElements.pop() + self.parser.phase = self.parser.originalPhase + + class InTablePhase(Phase): + # http://www.whatwg.org/specs/web-apps/current-work/#in-table + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml), + ("caption", self.startTagCaption), + ("colgroup", self.startTagColgroup), + ("col", self.startTagCol), + (("tbody", "tfoot", "thead"), self.startTagRowGroup), + (("td", "th", "tr"), self.startTagImplyTbody), + ("table", self.startTagTable), + (("style", "script"), self.startTagStyleScript), + ("input", self.startTagInput), + ("form", self.startTagForm) + ]) + self.startTagHandler.default = self.startTagOther + + self.endTagHandler = _utils.MethodDispatcher([ + ("table", self.endTagTable), + (("body", "caption", "col", "colgroup", "html", "tbody", "td", + "tfoot", "th", "thead", "tr"), self.endTagIgnore) + ]) + self.endTagHandler.default = self.endTagOther + + # helper methods + def clearStackToTableContext(self): + # "clear the stack back to a table context" + while self.tree.openElements[-1].name not in ("table", "html"): + # self.parser.parseError("unexpected-implied-end-tag-in-table", + # {"name": self.tree.openElements[-1].name}) + self.tree.openElements.pop() + # When the current node is <html> it's an innerHTML case + + # processing methods + def processEOF(self): + if self.tree.openElements[-1].name != "html": + self.parser.parseError("eof-in-table") + else: + assert self.parser.innerHTML + # Stop parsing + + def processSpaceCharacters(self, token): + originalPhase = self.parser.phase + self.parser.phase = self.parser.phases["inTableText"] + self.parser.phase.originalPhase = originalPhase + self.parser.phase.processSpaceCharacters(token) + + def processCharacters(self, token): + originalPhase = self.parser.phase + self.parser.phase = self.parser.phases["inTableText"] + self.parser.phase.originalPhase = originalPhase + self.parser.phase.processCharacters(token) + + def insertText(self, token): + # If we get here there must be at least one non-whitespace character + # Do the table magic! + self.tree.insertFromTable = True + self.parser.phases["inBody"].processCharacters(token) + self.tree.insertFromTable = False + + def startTagCaption(self, token): + self.clearStackToTableContext() + self.tree.activeFormattingElements.append(Marker) + self.tree.insertElement(token) + self.parser.phase = self.parser.phases["inCaption"] + + def startTagColgroup(self, token): + self.clearStackToTableContext() + self.tree.insertElement(token) + self.parser.phase = self.parser.phases["inColumnGroup"] + + def startTagCol(self, token): + self.startTagColgroup(impliedTagToken("colgroup", "StartTag")) + return token + + def startTagRowGroup(self, token): + self.clearStackToTableContext() + self.tree.insertElement(token) + self.parser.phase = self.parser.phases["inTableBody"] + + def startTagImplyTbody(self, token): + self.startTagRowGroup(impliedTagToken("tbody", "StartTag")) + return token + + def startTagTable(self, token): + self.parser.parseError("unexpected-start-tag-implies-end-tag", + {"startName": "table", "endName": "table"}) + self.parser.phase.processEndTag(impliedTagToken("table")) + if not self.parser.innerHTML: + return token + + def startTagStyleScript(self, token): + return self.parser.phases["inHead"].processStartTag(token) + + def startTagInput(self, token): + if ("type" in token["data"] and + token["data"]["type"].translate(asciiUpper2Lower) == "hidden"): + self.parser.parseError("unexpected-hidden-input-in-table") + self.tree.insertElement(token) + # XXX associate with form + self.tree.openElements.pop() + else: + self.startTagOther(token) + + def startTagForm(self, token): + self.parser.parseError("unexpected-form-in-table") + if self.tree.formPointer is None: + self.tree.insertElement(token) + self.tree.formPointer = self.tree.openElements[-1] + self.tree.openElements.pop() + + def startTagOther(self, token): + self.parser.parseError("unexpected-start-tag-implies-table-voodoo", {"name": token["name"]}) + # Do the table magic! + self.tree.insertFromTable = True + self.parser.phases["inBody"].processStartTag(token) + self.tree.insertFromTable = False + + def endTagTable(self, token): + if self.tree.elementInScope("table", variant="table"): + self.tree.generateImpliedEndTags() + if self.tree.openElements[-1].name != "table": + self.parser.parseError("end-tag-too-early-named", + {"gotName": "table", + "expectedName": self.tree.openElements[-1].name}) + while self.tree.openElements[-1].name != "table": + self.tree.openElements.pop() + self.tree.openElements.pop() + self.parser.resetInsertionMode() + else: + # innerHTML case + assert self.parser.innerHTML + self.parser.parseError() + + def endTagIgnore(self, token): + self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) + + def endTagOther(self, token): + self.parser.parseError("unexpected-end-tag-implies-table-voodoo", {"name": token["name"]}) + # Do the table magic! + self.tree.insertFromTable = True + self.parser.phases["inBody"].processEndTag(token) + self.tree.insertFromTable = False + + class InTableTextPhase(Phase): + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + self.originalPhase = None + self.characterTokens = [] + + def flushCharacters(self): + data = "".join([item["data"] for item in self.characterTokens]) + if any([item not in spaceCharacters for item in data]): + token = {"type": tokenTypes["Characters"], "data": data} + self.parser.phases["inTable"].insertText(token) + elif data: + self.tree.insertText(data) + self.characterTokens = [] + + def processComment(self, token): + self.flushCharacters() + self.parser.phase = self.originalPhase + return token + + def processEOF(self): + self.flushCharacters() + self.parser.phase = self.originalPhase + return True + + def processCharacters(self, token): + if token["data"] == "\u0000": + return + self.characterTokens.append(token) + + def processSpaceCharacters(self, token): + # pretty sure we should never reach here + self.characterTokens.append(token) + # assert False + + def processStartTag(self, token): + self.flushCharacters() + self.parser.phase = self.originalPhase + return token + + def processEndTag(self, token): + self.flushCharacters() + self.parser.phase = self.originalPhase + return token + + class InCaptionPhase(Phase): + # http://www.whatwg.org/specs/web-apps/current-work/#in-caption + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml), + (("caption", "col", "colgroup", "tbody", "td", "tfoot", "th", + "thead", "tr"), self.startTagTableElement) + ]) + self.startTagHandler.default = self.startTagOther + + self.endTagHandler = _utils.MethodDispatcher([ + ("caption", self.endTagCaption), + ("table", self.endTagTable), + (("body", "col", "colgroup", "html", "tbody", "td", "tfoot", "th", + "thead", "tr"), self.endTagIgnore) + ]) + self.endTagHandler.default = self.endTagOther + + def ignoreEndTagCaption(self): + return not self.tree.elementInScope("caption", variant="table") + + def processEOF(self): + self.parser.phases["inBody"].processEOF() + + def processCharacters(self, token): + return self.parser.phases["inBody"].processCharacters(token) + + def startTagTableElement(self, token): + self.parser.parseError() + # XXX Have to duplicate logic here to find out if the tag is ignored + ignoreEndTag = self.ignoreEndTagCaption() + self.parser.phase.processEndTag(impliedTagToken("caption")) + if not ignoreEndTag: + return token + + def startTagOther(self, token): + return self.parser.phases["inBody"].processStartTag(token) + + def endTagCaption(self, token): + if not self.ignoreEndTagCaption(): + # AT this code is quite similar to endTagTable in "InTable" + self.tree.generateImpliedEndTags() + if self.tree.openElements[-1].name != "caption": + self.parser.parseError("expected-one-end-tag-but-got-another", + {"gotName": "caption", + "expectedName": self.tree.openElements[-1].name}) + while self.tree.openElements[-1].name != "caption": + self.tree.openElements.pop() + self.tree.openElements.pop() + self.tree.clearActiveFormattingElements() + self.parser.phase = self.parser.phases["inTable"] + else: + # innerHTML case + assert self.parser.innerHTML + self.parser.parseError() + + def endTagTable(self, token): + self.parser.parseError() + ignoreEndTag = self.ignoreEndTagCaption() + self.parser.phase.processEndTag(impliedTagToken("caption")) + if not ignoreEndTag: + return token + + def endTagIgnore(self, token): + self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) + + def endTagOther(self, token): + return self.parser.phases["inBody"].processEndTag(token) + + class InColumnGroupPhase(Phase): + # http://www.whatwg.org/specs/web-apps/current-work/#in-column + + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml), + ("col", self.startTagCol) + ]) + self.startTagHandler.default = self.startTagOther + + self.endTagHandler = _utils.MethodDispatcher([ + ("colgroup", self.endTagColgroup), + ("col", self.endTagCol) + ]) + self.endTagHandler.default = self.endTagOther + + def ignoreEndTagColgroup(self): + return self.tree.openElements[-1].name == "html" + + def processEOF(self): + if self.tree.openElements[-1].name == "html": + assert self.parser.innerHTML + return + else: + ignoreEndTag = self.ignoreEndTagColgroup() + self.endTagColgroup(impliedTagToken("colgroup")) + if not ignoreEndTag: + return True + + def processCharacters(self, token): + ignoreEndTag = self.ignoreEndTagColgroup() + self.endTagColgroup(impliedTagToken("colgroup")) + if not ignoreEndTag: + return token + + def startTagCol(self, token): + self.tree.insertElement(token) + self.tree.openElements.pop() + token["selfClosingAcknowledged"] = True + + def startTagOther(self, token): + ignoreEndTag = self.ignoreEndTagColgroup() + self.endTagColgroup(impliedTagToken("colgroup")) + if not ignoreEndTag: + return token + + def endTagColgroup(self, token): + if self.ignoreEndTagColgroup(): + # innerHTML case + assert self.parser.innerHTML + self.parser.parseError() + else: + self.tree.openElements.pop() + self.parser.phase = self.parser.phases["inTable"] + + def endTagCol(self, token): + self.parser.parseError("no-end-tag", {"name": "col"}) + + def endTagOther(self, token): + ignoreEndTag = self.ignoreEndTagColgroup() + self.endTagColgroup(impliedTagToken("colgroup")) + if not ignoreEndTag: + return token + + class InTableBodyPhase(Phase): + # http://www.whatwg.org/specs/web-apps/current-work/#in-table0 + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml), + ("tr", self.startTagTr), + (("td", "th"), self.startTagTableCell), + (("caption", "col", "colgroup", "tbody", "tfoot", "thead"), + self.startTagTableOther) + ]) + self.startTagHandler.default = self.startTagOther + + self.endTagHandler = _utils.MethodDispatcher([ + (("tbody", "tfoot", "thead"), self.endTagTableRowGroup), + ("table", self.endTagTable), + (("body", "caption", "col", "colgroup", "html", "td", "th", + "tr"), self.endTagIgnore) + ]) + self.endTagHandler.default = self.endTagOther + + # helper methods + def clearStackToTableBodyContext(self): + while self.tree.openElements[-1].name not in ("tbody", "tfoot", + "thead", "html"): + # self.parser.parseError("unexpected-implied-end-tag-in-table", + # {"name": self.tree.openElements[-1].name}) + self.tree.openElements.pop() + if self.tree.openElements[-1].name == "html": + assert self.parser.innerHTML + + # the rest + def processEOF(self): + self.parser.phases["inTable"].processEOF() + + def processSpaceCharacters(self, token): + return self.parser.phases["inTable"].processSpaceCharacters(token) + + def processCharacters(self, token): + return self.parser.phases["inTable"].processCharacters(token) + + def startTagTr(self, token): + self.clearStackToTableBodyContext() + self.tree.insertElement(token) + self.parser.phase = self.parser.phases["inRow"] + + def startTagTableCell(self, token): + self.parser.parseError("unexpected-cell-in-table-body", + {"name": token["name"]}) + self.startTagTr(impliedTagToken("tr", "StartTag")) + return token + + def startTagTableOther(self, token): + # XXX AT Any ideas on how to share this with endTagTable? + if (self.tree.elementInScope("tbody", variant="table") or + self.tree.elementInScope("thead", variant="table") or + self.tree.elementInScope("tfoot", variant="table")): + self.clearStackToTableBodyContext() + self.endTagTableRowGroup( + impliedTagToken(self.tree.openElements[-1].name)) + return token + else: + # innerHTML case + assert self.parser.innerHTML + self.parser.parseError() + + def startTagOther(self, token): + return self.parser.phases["inTable"].processStartTag(token) + + def endTagTableRowGroup(self, token): + if self.tree.elementInScope(token["name"], variant="table"): + self.clearStackToTableBodyContext() + self.tree.openElements.pop() + self.parser.phase = self.parser.phases["inTable"] + else: + self.parser.parseError("unexpected-end-tag-in-table-body", + {"name": token["name"]}) + + def endTagTable(self, token): + if (self.tree.elementInScope("tbody", variant="table") or + self.tree.elementInScope("thead", variant="table") or + self.tree.elementInScope("tfoot", variant="table")): + self.clearStackToTableBodyContext() + self.endTagTableRowGroup( + impliedTagToken(self.tree.openElements[-1].name)) + return token + else: + # innerHTML case + assert self.parser.innerHTML + self.parser.parseError() + + def endTagIgnore(self, token): + self.parser.parseError("unexpected-end-tag-in-table-body", + {"name": token["name"]}) + + def endTagOther(self, token): + return self.parser.phases["inTable"].processEndTag(token) + + class InRowPhase(Phase): + # http://www.whatwg.org/specs/web-apps/current-work/#in-row + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml), + (("td", "th"), self.startTagTableCell), + (("caption", "col", "colgroup", "tbody", "tfoot", "thead", + "tr"), self.startTagTableOther) + ]) + self.startTagHandler.default = self.startTagOther + + self.endTagHandler = _utils.MethodDispatcher([ + ("tr", self.endTagTr), + ("table", self.endTagTable), + (("tbody", "tfoot", "thead"), self.endTagTableRowGroup), + (("body", "caption", "col", "colgroup", "html", "td", "th"), + self.endTagIgnore) + ]) + self.endTagHandler.default = self.endTagOther + + # helper methods (XXX unify this with other table helper methods) + def clearStackToTableRowContext(self): + while self.tree.openElements[-1].name not in ("tr", "html"): + self.parser.parseError("unexpected-implied-end-tag-in-table-row", + {"name": self.tree.openElements[-1].name}) + self.tree.openElements.pop() + + def ignoreEndTagTr(self): + return not self.tree.elementInScope("tr", variant="table") + + # the rest + def processEOF(self): + self.parser.phases["inTable"].processEOF() + + def processSpaceCharacters(self, token): + return self.parser.phases["inTable"].processSpaceCharacters(token) + + def processCharacters(self, token): + return self.parser.phases["inTable"].processCharacters(token) + + def startTagTableCell(self, token): + self.clearStackToTableRowContext() + self.tree.insertElement(token) + self.parser.phase = self.parser.phases["inCell"] + self.tree.activeFormattingElements.append(Marker) + + def startTagTableOther(self, token): + ignoreEndTag = self.ignoreEndTagTr() + self.endTagTr(impliedTagToken("tr")) + # XXX how are we sure it's always ignored in the innerHTML case? + if not ignoreEndTag: + return token + + def startTagOther(self, token): + return self.parser.phases["inTable"].processStartTag(token) + + def endTagTr(self, token): + if not self.ignoreEndTagTr(): + self.clearStackToTableRowContext() + self.tree.openElements.pop() + self.parser.phase = self.parser.phases["inTableBody"] + else: + # innerHTML case + assert self.parser.innerHTML + self.parser.parseError() + + def endTagTable(self, token): + ignoreEndTag = self.ignoreEndTagTr() + self.endTagTr(impliedTagToken("tr")) + # Reprocess the current tag if the tr end tag was not ignored + # XXX how are we sure it's always ignored in the innerHTML case? + if not ignoreEndTag: + return token + + def endTagTableRowGroup(self, token): + if self.tree.elementInScope(token["name"], variant="table"): + self.endTagTr(impliedTagToken("tr")) + return token + else: + self.parser.parseError() + + def endTagIgnore(self, token): + self.parser.parseError("unexpected-end-tag-in-table-row", + {"name": token["name"]}) + + def endTagOther(self, token): + return self.parser.phases["inTable"].processEndTag(token) + + class InCellPhase(Phase): + # http://www.whatwg.org/specs/web-apps/current-work/#in-cell + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml), + (("caption", "col", "colgroup", "tbody", "td", "tfoot", "th", + "thead", "tr"), self.startTagTableOther) + ]) + self.startTagHandler.default = self.startTagOther + + self.endTagHandler = _utils.MethodDispatcher([ + (("td", "th"), self.endTagTableCell), + (("body", "caption", "col", "colgroup", "html"), self.endTagIgnore), + (("table", "tbody", "tfoot", "thead", "tr"), self.endTagImply) + ]) + self.endTagHandler.default = self.endTagOther + + # helper + def closeCell(self): + if self.tree.elementInScope("td", variant="table"): + self.endTagTableCell(impliedTagToken("td")) + elif self.tree.elementInScope("th", variant="table"): + self.endTagTableCell(impliedTagToken("th")) + + # the rest + def processEOF(self): + self.parser.phases["inBody"].processEOF() + + def processCharacters(self, token): + return self.parser.phases["inBody"].processCharacters(token) + + def startTagTableOther(self, token): + if (self.tree.elementInScope("td", variant="table") or + self.tree.elementInScope("th", variant="table")): + self.closeCell() + return token + else: + # innerHTML case + assert self.parser.innerHTML + self.parser.parseError() + + def startTagOther(self, token): + return self.parser.phases["inBody"].processStartTag(token) + + def endTagTableCell(self, token): + if self.tree.elementInScope(token["name"], variant="table"): + self.tree.generateImpliedEndTags(token["name"]) + if self.tree.openElements[-1].name != token["name"]: + self.parser.parseError("unexpected-cell-end-tag", + {"name": token["name"]}) + while True: + node = self.tree.openElements.pop() + if node.name == token["name"]: + break + else: + self.tree.openElements.pop() + self.tree.clearActiveFormattingElements() + self.parser.phase = self.parser.phases["inRow"] + else: + self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) + + def endTagIgnore(self, token): + self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) + + def endTagImply(self, token): + if self.tree.elementInScope(token["name"], variant="table"): + self.closeCell() + return token + else: + # sometimes innerHTML case + self.parser.parseError() + + def endTagOther(self, token): + return self.parser.phases["inBody"].processEndTag(token) + + class InSelectPhase(Phase): + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml), + ("option", self.startTagOption), + ("optgroup", self.startTagOptgroup), + ("select", self.startTagSelect), + (("input", "keygen", "textarea"), self.startTagInput), + ("script", self.startTagScript) + ]) + self.startTagHandler.default = self.startTagOther + + self.endTagHandler = _utils.MethodDispatcher([ + ("option", self.endTagOption), + ("optgroup", self.endTagOptgroup), + ("select", self.endTagSelect) + ]) + self.endTagHandler.default = self.endTagOther + + # http://www.whatwg.org/specs/web-apps/current-work/#in-select + def processEOF(self): + if self.tree.openElements[-1].name != "html": + self.parser.parseError("eof-in-select") + else: + assert self.parser.innerHTML + + def processCharacters(self, token): + if token["data"] == "\u0000": + return + self.tree.insertText(token["data"]) + + def startTagOption(self, token): + # We need to imply </option> if <option> is the current node. + if self.tree.openElements[-1].name == "option": + self.tree.openElements.pop() + self.tree.insertElement(token) + + def startTagOptgroup(self, token): + if self.tree.openElements[-1].name == "option": + self.tree.openElements.pop() + if self.tree.openElements[-1].name == "optgroup": + self.tree.openElements.pop() + self.tree.insertElement(token) + + def startTagSelect(self, token): + self.parser.parseError("unexpected-select-in-select") + self.endTagSelect(impliedTagToken("select")) + + def startTagInput(self, token): + self.parser.parseError("unexpected-input-in-select") + if self.tree.elementInScope("select", variant="select"): + self.endTagSelect(impliedTagToken("select")) + return token + else: + assert self.parser.innerHTML + + def startTagScript(self, token): + return self.parser.phases["inHead"].processStartTag(token) + + def startTagOther(self, token): + self.parser.parseError("unexpected-start-tag-in-select", + {"name": token["name"]}) + + def endTagOption(self, token): + if self.tree.openElements[-1].name == "option": + self.tree.openElements.pop() + else: + self.parser.parseError("unexpected-end-tag-in-select", + {"name": "option"}) + + def endTagOptgroup(self, token): + # </optgroup> implicitly closes <option> + if (self.tree.openElements[-1].name == "option" and + self.tree.openElements[-2].name == "optgroup"): + self.tree.openElements.pop() + # It also closes </optgroup> + if self.tree.openElements[-1].name == "optgroup": + self.tree.openElements.pop() + # But nothing else + else: + self.parser.parseError("unexpected-end-tag-in-select", + {"name": "optgroup"}) + + def endTagSelect(self, token): + if self.tree.elementInScope("select", variant="select"): + node = self.tree.openElements.pop() + while node.name != "select": + node = self.tree.openElements.pop() + self.parser.resetInsertionMode() + else: + # innerHTML case + assert self.parser.innerHTML + self.parser.parseError() + + def endTagOther(self, token): + self.parser.parseError("unexpected-end-tag-in-select", + {"name": token["name"]}) + + class InSelectInTablePhase(Phase): + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + + self.startTagHandler = _utils.MethodDispatcher([ + (("caption", "table", "tbody", "tfoot", "thead", "tr", "td", "th"), + self.startTagTable) + ]) + self.startTagHandler.default = self.startTagOther + + self.endTagHandler = _utils.MethodDispatcher([ + (("caption", "table", "tbody", "tfoot", "thead", "tr", "td", "th"), + self.endTagTable) + ]) + self.endTagHandler.default = self.endTagOther + + def processEOF(self): + self.parser.phases["inSelect"].processEOF() + + def processCharacters(self, token): + return self.parser.phases["inSelect"].processCharacters(token) + + def startTagTable(self, token): + self.parser.parseError("unexpected-table-element-start-tag-in-select-in-table", {"name": token["name"]}) + self.endTagOther(impliedTagToken("select")) + return token + + def startTagOther(self, token): + return self.parser.phases["inSelect"].processStartTag(token) + + def endTagTable(self, token): + self.parser.parseError("unexpected-table-element-end-tag-in-select-in-table", {"name": token["name"]}) + if self.tree.elementInScope(token["name"], variant="table"): + self.endTagOther(impliedTagToken("select")) + return token + + def endTagOther(self, token): + return self.parser.phases["inSelect"].processEndTag(token) + + class InForeignContentPhase(Phase): + breakoutElements = frozenset(["b", "big", "blockquote", "body", "br", + "center", "code", "dd", "div", "dl", "dt", + "em", "embed", "h1", "h2", "h3", + "h4", "h5", "h6", "head", "hr", "i", "img", + "li", "listing", "menu", "meta", "nobr", + "ol", "p", "pre", "ruby", "s", "small", + "span", "strong", "strike", "sub", "sup", + "table", "tt", "u", "ul", "var"]) + + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + + def adjustSVGTagNames(self, token): + replacements = {"altglyph": "altGlyph", + "altglyphdef": "altGlyphDef", + "altglyphitem": "altGlyphItem", + "animatecolor": "animateColor", + "animatemotion": "animateMotion", + "animatetransform": "animateTransform", + "clippath": "clipPath", + "feblend": "feBlend", + "fecolormatrix": "feColorMatrix", + "fecomponenttransfer": "feComponentTransfer", + "fecomposite": "feComposite", + "feconvolvematrix": "feConvolveMatrix", + "fediffuselighting": "feDiffuseLighting", + "fedisplacementmap": "feDisplacementMap", + "fedistantlight": "feDistantLight", + "feflood": "feFlood", + "fefunca": "feFuncA", + "fefuncb": "feFuncB", + "fefuncg": "feFuncG", + "fefuncr": "feFuncR", + "fegaussianblur": "feGaussianBlur", + "feimage": "feImage", + "femerge": "feMerge", + "femergenode": "feMergeNode", + "femorphology": "feMorphology", + "feoffset": "feOffset", + "fepointlight": "fePointLight", + "fespecularlighting": "feSpecularLighting", + "fespotlight": "feSpotLight", + "fetile": "feTile", + "feturbulence": "feTurbulence", + "foreignobject": "foreignObject", + "glyphref": "glyphRef", + "lineargradient": "linearGradient", + "radialgradient": "radialGradient", + "textpath": "textPath"} + + if token["name"] in replacements: + token["name"] = replacements[token["name"]] + + def processCharacters(self, token): + if token["data"] == "\u0000": + token["data"] = "\uFFFD" + elif (self.parser.framesetOK and + any(char not in spaceCharacters for char in token["data"])): + self.parser.framesetOK = False + Phase.processCharacters(self, token) + + def processStartTag(self, token): + currentNode = self.tree.openElements[-1] + if (token["name"] in self.breakoutElements or + (token["name"] == "font" and + set(token["data"].keys()) & set(["color", "face", "size"]))): + self.parser.parseError("unexpected-html-element-in-foreign-content", + {"name": token["name"]}) + while (self.tree.openElements[-1].namespace != + self.tree.defaultNamespace and + not self.parser.isHTMLIntegrationPoint(self.tree.openElements[-1]) and + not self.parser.isMathMLTextIntegrationPoint(self.tree.openElements[-1])): + self.tree.openElements.pop() + return token + + else: + if currentNode.namespace == namespaces["mathml"]: + self.parser.adjustMathMLAttributes(token) + elif currentNode.namespace == namespaces["svg"]: + self.adjustSVGTagNames(token) + self.parser.adjustSVGAttributes(token) + self.parser.adjustForeignAttributes(token) + token["namespace"] = currentNode.namespace + self.tree.insertElement(token) + if token["selfClosing"]: + self.tree.openElements.pop() + token["selfClosingAcknowledged"] = True + + def processEndTag(self, token): + nodeIndex = len(self.tree.openElements) - 1 + node = self.tree.openElements[-1] + if node.name.translate(asciiUpper2Lower) != token["name"]: + self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) + + while True: + if node.name.translate(asciiUpper2Lower) == token["name"]: + # XXX this isn't in the spec but it seems necessary + if self.parser.phase == self.parser.phases["inTableText"]: + self.parser.phase.flushCharacters() + self.parser.phase = self.parser.phase.originalPhase + while self.tree.openElements.pop() != node: + assert self.tree.openElements + new_token = None + break + nodeIndex -= 1 + + node = self.tree.openElements[nodeIndex] + if node.namespace != self.tree.defaultNamespace: + continue + else: + new_token = self.parser.phase.processEndTag(token) + break + return new_token + + class AfterBodyPhase(Phase): + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml) + ]) + self.startTagHandler.default = self.startTagOther + + self.endTagHandler = _utils.MethodDispatcher([("html", self.endTagHtml)]) + self.endTagHandler.default = self.endTagOther + + def processEOF(self): + # Stop parsing + pass + + def processComment(self, token): + # This is needed because data is to be appended to the <html> element + # here and not to whatever is currently open. + self.tree.insertComment(token, self.tree.openElements[0]) + + def processCharacters(self, token): + self.parser.parseError("unexpected-char-after-body") + self.parser.phase = self.parser.phases["inBody"] + return token + + def startTagHtml(self, token): + return self.parser.phases["inBody"].processStartTag(token) + + def startTagOther(self, token): + self.parser.parseError("unexpected-start-tag-after-body", + {"name": token["name"]}) + self.parser.phase = self.parser.phases["inBody"] + return token + + def endTagHtml(self, name): + if self.parser.innerHTML: + self.parser.parseError("unexpected-end-tag-after-body-innerhtml") + else: + self.parser.phase = self.parser.phases["afterAfterBody"] + + def endTagOther(self, token): + self.parser.parseError("unexpected-end-tag-after-body", + {"name": token["name"]}) + self.parser.phase = self.parser.phases["inBody"] + return token + + class InFramesetPhase(Phase): + # http://www.whatwg.org/specs/web-apps/current-work/#in-frameset + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml), + ("frameset", self.startTagFrameset), + ("frame", self.startTagFrame), + ("noframes", self.startTagNoframes) + ]) + self.startTagHandler.default = self.startTagOther + + self.endTagHandler = _utils.MethodDispatcher([ + ("frameset", self.endTagFrameset) + ]) + self.endTagHandler.default = self.endTagOther + + def processEOF(self): + if self.tree.openElements[-1].name != "html": + self.parser.parseError("eof-in-frameset") + else: + assert self.parser.innerHTML + + def processCharacters(self, token): + self.parser.parseError("unexpected-char-in-frameset") + + def startTagFrameset(self, token): + self.tree.insertElement(token) + + def startTagFrame(self, token): + self.tree.insertElement(token) + self.tree.openElements.pop() + + def startTagNoframes(self, token): + return self.parser.phases["inBody"].processStartTag(token) + + def startTagOther(self, token): + self.parser.parseError("unexpected-start-tag-in-frameset", + {"name": token["name"]}) + + def endTagFrameset(self, token): + if self.tree.openElements[-1].name == "html": + # innerHTML case + self.parser.parseError("unexpected-frameset-in-frameset-innerhtml") + else: + self.tree.openElements.pop() + if (not self.parser.innerHTML and + self.tree.openElements[-1].name != "frameset"): + # If we're not in innerHTML mode and the current node is not a + # "frameset" element (anymore) then switch. + self.parser.phase = self.parser.phases["afterFrameset"] + + def endTagOther(self, token): + self.parser.parseError("unexpected-end-tag-in-frameset", + {"name": token["name"]}) + + class AfterFramesetPhase(Phase): + # http://www.whatwg.org/specs/web-apps/current-work/#after3 + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml), + ("noframes", self.startTagNoframes) + ]) + self.startTagHandler.default = self.startTagOther + + self.endTagHandler = _utils.MethodDispatcher([ + ("html", self.endTagHtml) + ]) + self.endTagHandler.default = self.endTagOther + + def processEOF(self): + # Stop parsing + pass + + def processCharacters(self, token): + self.parser.parseError("unexpected-char-after-frameset") + + def startTagNoframes(self, token): + return self.parser.phases["inHead"].processStartTag(token) + + def startTagOther(self, token): + self.parser.parseError("unexpected-start-tag-after-frameset", + {"name": token["name"]}) + + def endTagHtml(self, token): + self.parser.phase = self.parser.phases["afterAfterFrameset"] + + def endTagOther(self, token): + self.parser.parseError("unexpected-end-tag-after-frameset", + {"name": token["name"]}) + + class AfterAfterBodyPhase(Phase): + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml) + ]) + self.startTagHandler.default = self.startTagOther + + def processEOF(self): + pass + + def processComment(self, token): + self.tree.insertComment(token, self.tree.document) + + def processSpaceCharacters(self, token): + return self.parser.phases["inBody"].processSpaceCharacters(token) + + def processCharacters(self, token): + self.parser.parseError("expected-eof-but-got-char") + self.parser.phase = self.parser.phases["inBody"] + return token + + def startTagHtml(self, token): + return self.parser.phases["inBody"].processStartTag(token) + + def startTagOther(self, token): + self.parser.parseError("expected-eof-but-got-start-tag", + {"name": token["name"]}) + self.parser.phase = self.parser.phases["inBody"] + return token + + def processEndTag(self, token): + self.parser.parseError("expected-eof-but-got-end-tag", + {"name": token["name"]}) + self.parser.phase = self.parser.phases["inBody"] + return token + + class AfterAfterFramesetPhase(Phase): + def __init__(self, parser, tree): + Phase.__init__(self, parser, tree) + + self.startTagHandler = _utils.MethodDispatcher([ + ("html", self.startTagHtml), + ("noframes", self.startTagNoFrames) + ]) + self.startTagHandler.default = self.startTagOther + + def processEOF(self): + pass + + def processComment(self, token): + self.tree.insertComment(token, self.tree.document) + + def processSpaceCharacters(self, token): + return self.parser.phases["inBody"].processSpaceCharacters(token) + + def processCharacters(self, token): + self.parser.parseError("expected-eof-but-got-char") + + def startTagHtml(self, token): + return self.parser.phases["inBody"].processStartTag(token) + + def startTagNoFrames(self, token): + return self.parser.phases["inHead"].processStartTag(token) + + def startTagOther(self, token): + self.parser.parseError("expected-eof-but-got-start-tag", + {"name": token["name"]}) + + def processEndTag(self, token): + self.parser.parseError("expected-eof-but-got-end-tag", + {"name": token["name"]}) + # pylint:enable=unused-argument + + return { + "initial": InitialPhase, + "beforeHtml": BeforeHtmlPhase, + "beforeHead": BeforeHeadPhase, + "inHead": InHeadPhase, + "inHeadNoscript": InHeadNoscriptPhase, + "afterHead": AfterHeadPhase, + "inBody": InBodyPhase, + "text": TextPhase, + "inTable": InTablePhase, + "inTableText": InTableTextPhase, + "inCaption": InCaptionPhase, + "inColumnGroup": InColumnGroupPhase, + "inTableBody": InTableBodyPhase, + "inRow": InRowPhase, + "inCell": InCellPhase, + "inSelect": InSelectPhase, + "inSelectInTable": InSelectInTablePhase, + "inForeignContent": InForeignContentPhase, + "afterBody": AfterBodyPhase, + "inFrameset": InFramesetPhase, + "afterFrameset": AfterFramesetPhase, + "afterAfterBody": AfterAfterBodyPhase, + "afterAfterFrameset": AfterAfterFramesetPhase, + # XXX after after frameset + } + + +def adjust_attributes(token, replacements): + needs_adjustment = viewkeys(token['data']) & viewkeys(replacements) + if needs_adjustment: + token['data'] = OrderedDict((replacements.get(k, k), v) + for k, v in token['data'].items()) + + +def impliedTagToken(name, type="EndTag", attributes=None, + selfClosing=False): + if attributes is None: + attributes = {} + return {"type": tokenTypes[type], "name": name, "data": attributes, + "selfClosing": selfClosing} + + +class ParseError(Exception): + """Error in parsed document""" + pass diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/serializer.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/serializer.py new file mode 100644 index 0000000..53f4d44 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/serializer.py @@ -0,0 +1,409 @@ +from __future__ import absolute_import, division, unicode_literals +from pip._vendor.six import text_type + +import re + +from codecs import register_error, xmlcharrefreplace_errors + +from .constants import voidElements, booleanAttributes, spaceCharacters +from .constants import rcdataElements, entities, xmlEntities +from . import treewalkers, _utils +from xml.sax.saxutils import escape + +_quoteAttributeSpecChars = "".join(spaceCharacters) + "\"'=<>`" +_quoteAttributeSpec = re.compile("[" + _quoteAttributeSpecChars + "]") +_quoteAttributeLegacy = re.compile("[" + _quoteAttributeSpecChars + + "\x00\x01\x02\x03\x04\x05\x06\x07\x08\t\n" + "\x0b\x0c\r\x0e\x0f\x10\x11\x12\x13\x14\x15" + "\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f" + "\x20\x2f\x60\xa0\u1680\u180e\u180f\u2000" + "\u2001\u2002\u2003\u2004\u2005\u2006\u2007" + "\u2008\u2009\u200a\u2028\u2029\u202f\u205f" + "\u3000]") + + +_encode_entity_map = {} +_is_ucs4 = len("\U0010FFFF") == 1 +for k, v in list(entities.items()): + # skip multi-character entities + if ((_is_ucs4 and len(v) > 1) or + (not _is_ucs4 and len(v) > 2)): + continue + if v != "&": + if len(v) == 2: + v = _utils.surrogatePairToCodepoint(v) + else: + v = ord(v) + if v not in _encode_entity_map or k.islower(): + # prefer < over < and similarly for &, >, etc. + _encode_entity_map[v] = k + + +def htmlentityreplace_errors(exc): + if isinstance(exc, (UnicodeEncodeError, UnicodeTranslateError)): + res = [] + codepoints = [] + skip = False + for i, c in enumerate(exc.object[exc.start:exc.end]): + if skip: + skip = False + continue + index = i + exc.start + if _utils.isSurrogatePair(exc.object[index:min([exc.end, index + 2])]): + codepoint = _utils.surrogatePairToCodepoint(exc.object[index:index + 2]) + skip = True + else: + codepoint = ord(c) + codepoints.append(codepoint) + for cp in codepoints: + e = _encode_entity_map.get(cp) + if e: + res.append("&") + res.append(e) + if not e.endswith(";"): + res.append(";") + else: + res.append("&#x%s;" % (hex(cp)[2:])) + return ("".join(res), exc.end) + else: + return xmlcharrefreplace_errors(exc) + + +register_error("htmlentityreplace", htmlentityreplace_errors) + + +def serialize(input, tree="etree", encoding=None, **serializer_opts): + """Serializes the input token stream using the specified treewalker + + :arg input: the token stream to serialize + + :arg tree: the treewalker to use + + :arg encoding: the encoding to use + + :arg serializer_opts: any options to pass to the + :py:class:`html5lib.serializer.HTMLSerializer` that gets created + + :returns: the tree serialized as a string + + Example: + + >>> from html5lib.html5parser import parse + >>> from html5lib.serializer import serialize + >>> token_stream = parse('<html><body><p>Hi!</p></body></html>') + >>> serialize(token_stream, omit_optional_tags=False) + '<html><head></head><body><p>Hi!</p></body></html>' + + """ + # XXX: Should we cache this? + walker = treewalkers.getTreeWalker(tree) + s = HTMLSerializer(**serializer_opts) + return s.render(walker(input), encoding) + + +class HTMLSerializer(object): + + # attribute quoting options + quote_attr_values = "legacy" # be secure by default + quote_char = '"' + use_best_quote_char = True + + # tag syntax options + omit_optional_tags = True + minimize_boolean_attributes = True + use_trailing_solidus = False + space_before_trailing_solidus = True + + # escaping options + escape_lt_in_attrs = False + escape_rcdata = False + resolve_entities = True + + # miscellaneous options + alphabetical_attributes = False + inject_meta_charset = True + strip_whitespace = False + sanitize = False + + options = ("quote_attr_values", "quote_char", "use_best_quote_char", + "omit_optional_tags", "minimize_boolean_attributes", + "use_trailing_solidus", "space_before_trailing_solidus", + "escape_lt_in_attrs", "escape_rcdata", "resolve_entities", + "alphabetical_attributes", "inject_meta_charset", + "strip_whitespace", "sanitize") + + def __init__(self, **kwargs): + """Initialize HTMLSerializer + + :arg inject_meta_charset: Whether or not to inject the meta charset. + + Defaults to ``True``. + + :arg quote_attr_values: Whether to quote attribute values that don't + require quoting per legacy browser behavior (``"legacy"``), when + required by the standard (``"spec"``), or always (``"always"``). + + Defaults to ``"legacy"``. + + :arg quote_char: Use given quote character for attribute quoting. + + Defaults to ``"`` which will use double quotes unless attribute + value contains a double quote, in which case single quotes are + used. + + :arg escape_lt_in_attrs: Whether or not to escape ``<`` in attribute + values. + + Defaults to ``False``. + + :arg escape_rcdata: Whether to escape characters that need to be + escaped within normal elements within rcdata elements such as + style. + + Defaults to ``False``. + + :arg resolve_entities: Whether to resolve named character entities that + appear in the source tree. The XML predefined entities < > + & " ' are unaffected by this setting. + + Defaults to ``True``. + + :arg strip_whitespace: Whether to remove semantically meaningless + whitespace. (This compresses all whitespace to a single space + except within ``pre``.) + + Defaults to ``False``. + + :arg minimize_boolean_attributes: Shortens boolean attributes to give + just the attribute value, for example:: + + <input disabled="disabled"> + + becomes:: + + <input disabled> + + Defaults to ``True``. + + :arg use_trailing_solidus: Includes a close-tag slash at the end of the + start tag of void elements (empty elements whose end tag is + forbidden). E.g. ``<hr/>``. + + Defaults to ``False``. + + :arg space_before_trailing_solidus: Places a space immediately before + the closing slash in a tag using a trailing solidus. E.g. + ``<hr />``. Requires ``use_trailing_solidus=True``. + + Defaults to ``True``. + + :arg sanitize: Strip all unsafe or unknown constructs from output. + See :py:class:`html5lib.filters.sanitizer.Filter`. + + Defaults to ``False``. + + :arg omit_optional_tags: Omit start/end tags that are optional. + + Defaults to ``True``. + + :arg alphabetical_attributes: Reorder attributes to be in alphabetical order. + + Defaults to ``False``. + + """ + unexpected_args = frozenset(kwargs) - frozenset(self.options) + if len(unexpected_args) > 0: + raise TypeError("__init__() got an unexpected keyword argument '%s'" % next(iter(unexpected_args))) + if 'quote_char' in kwargs: + self.use_best_quote_char = False + for attr in self.options: + setattr(self, attr, kwargs.get(attr, getattr(self, attr))) + self.errors = [] + self.strict = False + + def encode(self, string): + assert(isinstance(string, text_type)) + if self.encoding: + return string.encode(self.encoding, "htmlentityreplace") + else: + return string + + def encodeStrict(self, string): + assert(isinstance(string, text_type)) + if self.encoding: + return string.encode(self.encoding, "strict") + else: + return string + + def serialize(self, treewalker, encoding=None): + # pylint:disable=too-many-nested-blocks + self.encoding = encoding + in_cdata = False + self.errors = [] + + if encoding and self.inject_meta_charset: + from .filters.inject_meta_charset import Filter + treewalker = Filter(treewalker, encoding) + # Alphabetical attributes is here under the assumption that none of + # the later filters add or change order of attributes; it needs to be + # before the sanitizer so escaped elements come out correctly + if self.alphabetical_attributes: + from .filters.alphabeticalattributes import Filter + treewalker = Filter(treewalker) + # WhitespaceFilter should be used before OptionalTagFilter + # for maximum efficiently of this latter filter + if self.strip_whitespace: + from .filters.whitespace import Filter + treewalker = Filter(treewalker) + if self.sanitize: + from .filters.sanitizer import Filter + treewalker = Filter(treewalker) + if self.omit_optional_tags: + from .filters.optionaltags import Filter + treewalker = Filter(treewalker) + + for token in treewalker: + type = token["type"] + if type == "Doctype": + doctype = "<!DOCTYPE %s" % token["name"] + + if token["publicId"]: + doctype += ' PUBLIC "%s"' % token["publicId"] + elif token["systemId"]: + doctype += " SYSTEM" + if token["systemId"]: + if token["systemId"].find('"') >= 0: + if token["systemId"].find("'") >= 0: + self.serializeError("System identifer contains both single and double quote characters") + quote_char = "'" + else: + quote_char = '"' + doctype += " %s%s%s" % (quote_char, token["systemId"], quote_char) + + doctype += ">" + yield self.encodeStrict(doctype) + + elif type in ("Characters", "SpaceCharacters"): + if type == "SpaceCharacters" or in_cdata: + if in_cdata and token["data"].find("</") >= 0: + self.serializeError("Unexpected </ in CDATA") + yield self.encode(token["data"]) + else: + yield self.encode(escape(token["data"])) + + elif type in ("StartTag", "EmptyTag"): + name = token["name"] + yield self.encodeStrict("<%s" % name) + if name in rcdataElements and not self.escape_rcdata: + in_cdata = True + elif in_cdata: + self.serializeError("Unexpected child element of a CDATA element") + for (_, attr_name), attr_value in token["data"].items(): + # TODO: Add namespace support here + k = attr_name + v = attr_value + yield self.encodeStrict(' ') + + yield self.encodeStrict(k) + if not self.minimize_boolean_attributes or \ + (k not in booleanAttributes.get(name, tuple()) and + k not in booleanAttributes.get("", tuple())): + yield self.encodeStrict("=") + if self.quote_attr_values == "always" or len(v) == 0: + quote_attr = True + elif self.quote_attr_values == "spec": + quote_attr = _quoteAttributeSpec.search(v) is not None + elif self.quote_attr_values == "legacy": + quote_attr = _quoteAttributeLegacy.search(v) is not None + else: + raise ValueError("quote_attr_values must be one of: " + "'always', 'spec', or 'legacy'") + v = v.replace("&", "&") + if self.escape_lt_in_attrs: + v = v.replace("<", "<") + if quote_attr: + quote_char = self.quote_char + if self.use_best_quote_char: + if "'" in v and '"' not in v: + quote_char = '"' + elif '"' in v and "'" not in v: + quote_char = "'" + if quote_char == "'": + v = v.replace("'", "'") + else: + v = v.replace('"', """) + yield self.encodeStrict(quote_char) + yield self.encode(v) + yield self.encodeStrict(quote_char) + else: + yield self.encode(v) + if name in voidElements and self.use_trailing_solidus: + if self.space_before_trailing_solidus: + yield self.encodeStrict(" /") + else: + yield self.encodeStrict("/") + yield self.encode(">") + + elif type == "EndTag": + name = token["name"] + if name in rcdataElements: + in_cdata = False + elif in_cdata: + self.serializeError("Unexpected child element of a CDATA element") + yield self.encodeStrict("</%s>" % name) + + elif type == "Comment": + data = token["data"] + if data.find("--") >= 0: + self.serializeError("Comment contains --") + yield self.encodeStrict("<!--%s-->" % token["data"]) + + elif type == "Entity": + name = token["name"] + key = name + ";" + if key not in entities: + self.serializeError("Entity %s not recognized" % name) + if self.resolve_entities and key not in xmlEntities: + data = entities[key] + else: + data = "&%s;" % name + yield self.encodeStrict(data) + + else: + self.serializeError(token["data"]) + + def render(self, treewalker, encoding=None): + """Serializes the stream from the treewalker into a string + + :arg treewalker: the treewalker to serialize + + :arg encoding: the string encoding to use + + :returns: the serialized tree + + Example: + + >>> from html5lib import parse, getTreeWalker + >>> from html5lib.serializer import HTMLSerializer + >>> token_stream = parse('<html><body>Hi!</body></html>') + >>> walker = getTreeWalker('etree') + >>> serializer = HTMLSerializer(omit_optional_tags=False) + >>> serializer.render(walker(token_stream)) + '<html><head></head><body>Hi!</body></html>' + + """ + if encoding: + return b"".join(list(self.serialize(treewalker, encoding))) + else: + return "".join(list(self.serialize(treewalker))) + + def serializeError(self, data="XXX ERROR MESSAGE NEEDED"): + # XXX The idea is to make data mandatory. + self.errors.append(data) + if self.strict: + raise SerializeError + + +class SerializeError(Exception): + """Error in serialized tree""" + pass diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py new file mode 100644 index 0000000..7ef5959 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py @@ -0,0 +1,30 @@ +"""Tree adapters let you convert from one tree structure to another + +Example: + +.. code-block:: python + + from pip._vendor import html5lib + from pip._vendor.html5lib.treeadapters import genshi + + doc = '<html><body>Hi!</body></html>' + treebuilder = html5lib.getTreeBuilder('etree') + parser = html5lib.HTMLParser(tree=treebuilder) + tree = parser.parse(doc) + TreeWalker = html5lib.getTreeWalker('etree') + + genshi_tree = genshi.to_genshi(TreeWalker(tree)) + +""" +from __future__ import absolute_import, division, unicode_literals + +from . import sax + +__all__ = ["sax"] + +try: + from . import genshi # noqa +except ImportError: + pass +else: + __all__.append("genshi") diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..a6d0ce1a21bacb0798461a4571fc50c6d2a2b315 GIT binary patch literal 952 zcmZuvPjAyO6nD}t?Xo{qXdl3w+8mY?BqnX@CWJI;NH8H$G{^zVt=-0(V@Hk?wY~6F z*a>mtqj1iZ)4l))PS{EJPr{L3{QmrY&wlTH+}ZJgS$}?B<L@p2zpe6cb&c}M?EH%n z1jK+i#N|%v#%|h*TWLFPJAkxEn{T9E?3we%+=)A@p0Rnx){VOkxBz0W4d~{Tug)D{ zzt2Eye*(1g%_p5}$Dq0&K(L8_IRK0mr4SRGX{vI_sfJ5gz^N1^RT|EeOraDMY8#eo zRZMlEj4B}(QYTdT{^<gz8K+0SABF}<=>CMu>DAE@%$7Ql!uKI;h%%OisHB2O1zDO& zlOWM4f63Y8e=*^$Gql<7?zl$IsmK#nlM^|G$FM)L@h78+B+HXC_G}c@r%_a!`!<8+ znG}o@stn+ceonP5!|TQ~=u;cl4=f_XDt{b&Hh%Z^eQh1su;T}uHNxtKya9&wZ(uH1 z`^Lt1f%(;A#&!C}ai86$Zyt%(oQ)Q0iJH^kp0B=35cvL$85|I_swa4oOI~P-ntD}T z!b+AiDXLx}nC%nd%rqVI{Km`y2%M^w<Aw5?v)80h9iyHHTU7@k^9qD2AE8-chX5gE zMi{7;6>TFbP=jqK=G?d~w%U4AcluN*sVWa=nd$!zpmr_Fioai@OtBJc8kJZ@Gike% zM~91Ojt)zeuEdMk<uFMWs}<sh2a`k%&6<m79GQ9AXCl`o+x~EPP%g{og*DcDJ!p0J u?Sw_Ph_^!&A;bjJ2!+|Q>W)%L3QkXK8S<VH?WcS0w(GgB({pwm&;1AQ`XKTE literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/genshi.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/genshi.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0cd013eca6a53c22c39ce649add1d8150722b7e9 GIT binary patch literal 1558 zcmah}OK%%D5GJ_~t=4wzIH>`*2_O{6K|y1=MH|3|VKlG>G(e-Yky^Bi1_HgLq>c6! zl2UC|IypZeJ@jrLdo$4g(gUwO`PNepxwyk!`4RL`E;twtXFkphKkj!+OFn|}&)F&c z!$s&Xv$#13EWU&(zXrh&!!b&5fD;ms#0o5IY$Uc5CvXxsaErAC>q<~byueGUK{fFM zKUoMCV9#dG8x$-uw~gwRb3jCOOE1#{nZ+Z;yHS#7LTQgh<48tXs#iv76lRQf<4AEq zV_7HK`L;z9uAL`J30Zfv)9yTZ(a~13wXf|?^M{VE>^*<>tl0u(|M_0$$8VY;Hb>0| zREf+CVagY<(?>HrMf>P2e)(`lri9^jG_$4_BSTkgOz{Z<o3)NkF-GZ!Q!KtxnAs;} zicc|fde-*{mlzgvA>s_YE9*$4%qumJ)pgV(YiMSt#s;gItt{rVg*S8T6Z;f0IL60# z<|s$GQ~MZCogTTwhin#yM4YjuBC{pX|DK=o=l`5jDbX&GUVDIbYe?Q=v8YToP}zHX z%Yf~vYMCd<m35QjZK%My_5&0Q2(ABif~~^c-kJQim!)GaRE^e@;Jl_X(E2=;gQzh0 zehtPp75&=JG#+xXT~h;a1K)COB1W<ZG={5PV-M%pk($E@u0|r2+vWt|iONJR>s=m~ z0)b@dsBLwWb0CqwH=u%sKq{%1+c^#S4TH_7q8g~#I=_G+ZUa*w#%n7oREPGp*GzJC zWVC7uT$CpMo%_oJIeQ?rZA|Ym&VqOcX4^3Ca}a$rMK3@3iOlefC^W?k!5!dXRea2V zRck19!3OsN93VaND|u~0Pi<jX+!7yvJU40`3xf(Th-_?Xo5Fk0&X~p{{yP#M!Opu` zBNx$_D&81V(dcC{gL)fVhmC%BYb=sU`dRPQ=3sC*nRMf=#|Hzk38SAjI*mNaA4RED zG>#u_Zay9#jXxb3V==p9p0Z3d1}cfah@*psxi!jYZra%>FL@(B(*8~yNfl;EzIz|i zkv0eyyBCxDD(lYOcH%6AcfGrD?JMqppLUxmGaat%Wl6$Q1&=uk&FyI~A05O|_>^f+ z9!bTMr>s@?wM+9H@)A`OZNJK*RG4S39r$%5QdB@M`XxN0nZKS`08w|fTQUyF!4H*o zR5s+PSTqi6AhcsTD~pbn;-0ZquWB&JavucpZ0utXz7=faRcsTZuNBh2@W@?QUD?Pg z@$o9`-GYt~OfEc|5EqMwfYYikX}{a;jeym>+ZE;~EDVc;X<@K1?_HP)UY2AEEh{XF jGcCBTuz<XgzM+OFYVdZFjE!QxYv?2m$X&96?^*u>!x)Oz literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/sax.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/sax.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7d8196d8fbeaef9db0d7f3869cfd07985010e8ed GIT binary patch literal 1493 zcmah}OK%%D5GJ`#J*^rk3gslA?Lh_{IRzTPh7r_t9H5691(X2ABE^ChX=x+wLnK$R z1^LqSXY^nli(dL0dgzbfwY}t)Qx7>b9j^Q;(4rJ}IGp+B$q}EoT6F~L&tF#bt&h;} z_HcK(aQFf~#eguxus|t}a7rSQI+25|j0iXNA`f_nxx!C_C`iL7#3(^gjR%+Y6?%fc zyZ^$88c{Q9@dopzHM!4Qyv7^*XtvLM7W{ysHuHw4AHIP|sPC8!dZKbsY91$PkxOkt zmdq2C<eBM|Su)BQk42)nq(b$v=^SV+lM}$J<Kb6nA>I({hnSBjds!;|G?zRXXSXQR zEwlen9gnQ-^$LK2-k?MH)P0Q55?`Vf!bsywQq^|v1-T#>4#=G)Svo6%(X6wyRsVM3 zE?tJZ=)zlij7*9Aa<(<w0^XVW@<(m8ZWn3qHM#J?-iNc-ML_*7Iwk9U>93&EU=x7- zTR;W>hN_}k&mo|G{a;iK;u}DP;0rQXVaVB9*TMRa*%oW4EnQ>H*Z6xp+q$WA^QO}J zl2kVDz(>P&gSFuH+KZnLsSv&4!MEEYneyH!&os|;Z$dLBxa^%!#aS=UdRlV+ii#=7 z)?2;agSAKH_)4(X(-VFdr}JK^K$2I08?6;Um^qiam*_igu43-lY;F=*J6WTQtIrE= zf+zXNGB7ORP*bU&(Xk1S(n6nG&Sg|nQ_E<|RY6DGxR#Yo7zg7YWehN2SwEamNk=e` z%4`fR?v5Zh%+nOw@N}{HJey|uE2ux8a-b0QxZgA_W#d8~rG=SxA^B-?7N@i*l5A`| znDbPb%?kBRrTcoVk{+ZXLz_#x(jEzJT^tWhlV|MqR3F{u*FI1Rx&?owBPnxfI)MC# zSJME=bvFIL`0Fb&!BtC*zfMrLZD6meMb;{w!rxH+gyhF?dbb!9GMQ7&2XiV1r@3Iz zp26<fU>xtxWxB{dJAJt`nVc;avDkfdGLbv5#@XQ6ph$}CB!h~C*xuQBG(Vp|EUmEm z;yI+3%fUpa;&YLl4D2vbMhn~hfud&*igV-ZJO;J}d8o%gP#EG4Zj%t(pIcG#-X)vZ z$K)^92{CZ*eb8U;9l#LMCLP?w@>B58-!Sz!J}q@Ac^pgoNJz&L`%Fe3oTcJ{4Gz16 zbhxZ8$JAgrp^!`~X`hnnvgC)r8GlYi$(8I`^P0#<R2<vUvR$nLR$aV9KCxEeewwpV W@W=2JA!V`mNRxDk3yFug?)(ktg{;~D literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py new file mode 100644 index 0000000..61d5fb6 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py @@ -0,0 +1,54 @@ +from __future__ import absolute_import, division, unicode_literals + +from genshi.core import QName, Attrs +from genshi.core import START, END, TEXT, COMMENT, DOCTYPE + + +def to_genshi(walker): + """Convert a tree to a genshi tree + + :arg walker: the treewalker to use to walk the tree to convert it + + :returns: generator of genshi nodes + + """ + text = [] + for token in walker: + type = token["type"] + if type in ("Characters", "SpaceCharacters"): + text.append(token["data"]) + elif text: + yield TEXT, "".join(text), (None, -1, -1) + text = [] + + if type in ("StartTag", "EmptyTag"): + if token["namespace"]: + name = "{%s}%s" % (token["namespace"], token["name"]) + else: + name = token["name"] + attrs = Attrs([(QName("{%s}%s" % attr if attr[0] is not None else attr[1]), value) + for attr, value in token["data"].items()]) + yield (START, (QName(name), attrs), (None, -1, -1)) + if type == "EmptyTag": + type = "EndTag" + + if type == "EndTag": + if token["namespace"]: + name = "{%s}%s" % (token["namespace"], token["name"]) + else: + name = token["name"] + + yield END, QName(name), (None, -1, -1) + + elif type == "Comment": + yield COMMENT, token["data"], (None, -1, -1) + + elif type == "Doctype": + yield DOCTYPE, (token["name"], token["publicId"], + token["systemId"]), (None, -1, -1) + + else: + pass # FIXME: What to do? + + if text: + yield TEXT, "".join(text), (None, -1, -1) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/sax.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/sax.py new file mode 100644 index 0000000..f4ccea5 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treeadapters/sax.py @@ -0,0 +1,50 @@ +from __future__ import absolute_import, division, unicode_literals + +from xml.sax.xmlreader import AttributesNSImpl + +from ..constants import adjustForeignAttributes, unadjustForeignAttributes + +prefix_mapping = {} +for prefix, localName, namespace in adjustForeignAttributes.values(): + if prefix is not None: + prefix_mapping[prefix] = namespace + + +def to_sax(walker, handler): + """Call SAX-like content handler based on treewalker walker + + :arg walker: the treewalker to use to walk the tree to convert it + + :arg handler: SAX handler to use + + """ + handler.startDocument() + for prefix, namespace in prefix_mapping.items(): + handler.startPrefixMapping(prefix, namespace) + + for token in walker: + type = token["type"] + if type == "Doctype": + continue + elif type in ("StartTag", "EmptyTag"): + attrs = AttributesNSImpl(token["data"], + unadjustForeignAttributes) + handler.startElementNS((token["namespace"], token["name"]), + token["name"], + attrs) + if type == "EmptyTag": + handler.endElementNS((token["namespace"], token["name"]), + token["name"]) + elif type == "EndTag": + handler.endElementNS((token["namespace"], token["name"]), + token["name"]) + elif type in ("Characters", "SpaceCharacters"): + handler.characters(token["data"]) + elif type == "Comment": + pass + else: + assert False, "Unknown token type" + + for prefix, namespace in prefix_mapping.items(): + handler.endPrefixMapping(prefix) + handler.endDocument() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py new file mode 100644 index 0000000..d44447e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py @@ -0,0 +1,88 @@ +"""A collection of modules for building different kinds of trees from HTML +documents. + +To create a treebuilder for a new type of tree, you need to do +implement several things: + +1. A set of classes for various types of elements: Document, Doctype, Comment, + Element. These must implement the interface of ``base.treebuilders.Node`` + (although comment nodes have a different signature for their constructor, + see ``treebuilders.etree.Comment``) Textual content may also be implemented + as another node type, or not, as your tree implementation requires. + +2. A treebuilder object (called ``TreeBuilder`` by convention) that inherits + from ``treebuilders.base.TreeBuilder``. This has 4 required attributes: + + * ``documentClass`` - the class to use for the bottommost node of a document + * ``elementClass`` - the class to use for HTML Elements + * ``commentClass`` - the class to use for comments + * ``doctypeClass`` - the class to use for doctypes + + It also has one required method: + + * ``getDocument`` - Returns the root node of the complete document tree + +3. If you wish to run the unit tests, you must also create a ``testSerializer`` + method on your treebuilder which accepts a node and returns a string + containing Node and its children serialized according to the format used in + the unittests + +""" + +from __future__ import absolute_import, division, unicode_literals + +from .._utils import default_etree + +treeBuilderCache = {} + + +def getTreeBuilder(treeType, implementation=None, **kwargs): + """Get a TreeBuilder class for various types of trees with built-in support + + :arg treeType: the name of the tree type required (case-insensitive). Supported + values are: + + * "dom" - A generic builder for DOM implementations, defaulting to a + xml.dom.minidom based implementation. + * "etree" - A generic builder for tree implementations exposing an + ElementTree-like interface, defaulting to xml.etree.cElementTree if + available and xml.etree.ElementTree if not. + * "lxml" - A etree-based builder for lxml.etree, handling limitations + of lxml's implementation. + + :arg implementation: (Currently applies to the "etree" and "dom" tree + types). A module implementing the tree type e.g. xml.etree.ElementTree + or xml.etree.cElementTree. + + :arg kwargs: Any additional options to pass to the TreeBuilder when + creating it. + + Example: + + >>> from html5lib.treebuilders import getTreeBuilder + >>> builder = getTreeBuilder('etree') + + """ + + treeType = treeType.lower() + if treeType not in treeBuilderCache: + if treeType == "dom": + from . import dom + # Come up with a sane default (pref. from the stdlib) + if implementation is None: + from xml.dom import minidom + implementation = minidom + # NEVER cache here, caching is done in the dom submodule + return dom.getDomModule(implementation, **kwargs).TreeBuilder + elif treeType == "lxml": + from . import etree_lxml + treeBuilderCache[treeType] = etree_lxml.TreeBuilder + elif treeType == "etree": + from . import etree + if implementation is None: + implementation = default_etree + # NEVER cache here, caching is done in the etree submodule + return etree.getETreeModule(implementation, **kwargs).TreeBuilder + else: + raise ValueError("""Unrecognised treebuilder "%s" """ % treeType) + return treeBuilderCache.get(treeType) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7a417879ceb0ac0552298aaa8ff62ba7488cf456 GIT binary patch literal 3337 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/base.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/base.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6ec7c67ce1ed2220544235cb2e3a843442f238a5 GIT binary patch literal 11363 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 KEiW_{PX9jy?8<up literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/dom.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/dom.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..41226e4f1e01a02eafcdee8366b3ac11268708de GIT binary patch literal 9470 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7b1447ab93aaca549d4acb9aa1a0dff77bffe6b8 GIT binary patch literal 11857 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 IiFWb-0iWKAlK=n! literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree_lxml.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree_lxml.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..df33d12b467b0d1be76d2bea7120dcf2d62d247f GIT binary patch literal 11825 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/base.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/base.py new file mode 100644 index 0000000..73973db --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/base.py @@ -0,0 +1,417 @@ +from __future__ import absolute_import, division, unicode_literals +from pip._vendor.six import text_type + +from ..constants import scopingElements, tableInsertModeElements, namespaces + +# The scope markers are inserted when entering object elements, +# marquees, table cells, and table captions, and are used to prevent formatting +# from "leaking" into tables, object elements, and marquees. +Marker = None + +listElementsMap = { + None: (frozenset(scopingElements), False), + "button": (frozenset(scopingElements | set([(namespaces["html"], "button")])), False), + "list": (frozenset(scopingElements | set([(namespaces["html"], "ol"), + (namespaces["html"], "ul")])), False), + "table": (frozenset([(namespaces["html"], "html"), + (namespaces["html"], "table")]), False), + "select": (frozenset([(namespaces["html"], "optgroup"), + (namespaces["html"], "option")]), True) +} + + +class Node(object): + """Represents an item in the tree""" + def __init__(self, name): + """Creates a Node + + :arg name: The tag name associated with the node + + """ + # The tag name assocaited with the node + self.name = name + # The parent of the current node (or None for the document node) + self.parent = None + # The value of the current node (applies to text nodes and comments) + self.value = None + # A dict holding name -> value pairs for attributes of the node + self.attributes = {} + # A list of child nodes of the current node. This must include all + # elements but not necessarily other node types. + self.childNodes = [] + # A list of miscellaneous flags that can be set on the node. + self._flags = [] + + def __str__(self): + attributesStr = " ".join(["%s=\"%s\"" % (name, value) + for name, value in + self.attributes.items()]) + if attributesStr: + return "<%s %s>" % (self.name, attributesStr) + else: + return "<%s>" % (self.name) + + def __repr__(self): + return "<%s>" % (self.name) + + def appendChild(self, node): + """Insert node as a child of the current node + + :arg node: the node to insert + + """ + raise NotImplementedError + + def insertText(self, data, insertBefore=None): + """Insert data as text in the current node, positioned before the + start of node insertBefore or to the end of the node's text. + + :arg data: the data to insert + + :arg insertBefore: True if you want to insert the text before the node + and False if you want to insert it after the node + + """ + raise NotImplementedError + + def insertBefore(self, node, refNode): + """Insert node as a child of the current node, before refNode in the + list of child nodes. Raises ValueError if refNode is not a child of + the current node + + :arg node: the node to insert + + :arg refNode: the child node to insert the node before + + """ + raise NotImplementedError + + def removeChild(self, node): + """Remove node from the children of the current node + + :arg node: the child node to remove + + """ + raise NotImplementedError + + def reparentChildren(self, newParent): + """Move all the children of the current node to newParent. + This is needed so that trees that don't store text as nodes move the + text in the correct way + + :arg newParent: the node to move all this node's children to + + """ + # XXX - should this method be made more general? + for child in self.childNodes: + newParent.appendChild(child) + self.childNodes = [] + + def cloneNode(self): + """Return a shallow copy of the current node i.e. a node with the same + name and attributes but with no parent or child nodes + """ + raise NotImplementedError + + def hasContent(self): + """Return true if the node has children or text, false otherwise + """ + raise NotImplementedError + + +class ActiveFormattingElements(list): + def append(self, node): + equalCount = 0 + if node != Marker: + for element in self[::-1]: + if element == Marker: + break + if self.nodesEqual(element, node): + equalCount += 1 + if equalCount == 3: + self.remove(element) + break + list.append(self, node) + + def nodesEqual(self, node1, node2): + if not node1.nameTuple == node2.nameTuple: + return False + + if not node1.attributes == node2.attributes: + return False + + return True + + +class TreeBuilder(object): + """Base treebuilder implementation + + * documentClass - the class to use for the bottommost node of a document + * elementClass - the class to use for HTML Elements + * commentClass - the class to use for comments + * doctypeClass - the class to use for doctypes + + """ + # pylint:disable=not-callable + + # Document class + documentClass = None + + # The class to use for creating a node + elementClass = None + + # The class to use for creating comments + commentClass = None + + # The class to use for creating doctypes + doctypeClass = None + + # Fragment class + fragmentClass = None + + def __init__(self, namespaceHTMLElements): + """Create a TreeBuilder + + :arg namespaceHTMLElements: whether or not to namespace HTML elements + + """ + if namespaceHTMLElements: + self.defaultNamespace = "http://www.w3.org/1999/xhtml" + else: + self.defaultNamespace = None + self.reset() + + def reset(self): + self.openElements = [] + self.activeFormattingElements = ActiveFormattingElements() + + # XXX - rename these to headElement, formElement + self.headPointer = None + self.formPointer = None + + self.insertFromTable = False + + self.document = self.documentClass() + + def elementInScope(self, target, variant=None): + + # If we pass a node in we match that. if we pass a string + # match any node with that name + exactNode = hasattr(target, "nameTuple") + if not exactNode: + if isinstance(target, text_type): + target = (namespaces["html"], target) + assert isinstance(target, tuple) + + listElements, invert = listElementsMap[variant] + + for node in reversed(self.openElements): + if exactNode and node == target: + return True + elif not exactNode and node.nameTuple == target: + return True + elif (invert ^ (node.nameTuple in listElements)): + return False + + assert False # We should never reach this point + + def reconstructActiveFormattingElements(self): + # Within this algorithm the order of steps described in the + # specification is not quite the same as the order of steps in the + # code. It should still do the same though. + + # Step 1: stop the algorithm when there's nothing to do. + if not self.activeFormattingElements: + return + + # Step 2 and step 3: we start with the last element. So i is -1. + i = len(self.activeFormattingElements) - 1 + entry = self.activeFormattingElements[i] + if entry == Marker or entry in self.openElements: + return + + # Step 6 + while entry != Marker and entry not in self.openElements: + if i == 0: + # This will be reset to 0 below + i = -1 + break + i -= 1 + # Step 5: let entry be one earlier in the list. + entry = self.activeFormattingElements[i] + + while True: + # Step 7 + i += 1 + + # Step 8 + entry = self.activeFormattingElements[i] + clone = entry.cloneNode() # Mainly to get a new copy of the attributes + + # Step 9 + element = self.insertElement({"type": "StartTag", + "name": clone.name, + "namespace": clone.namespace, + "data": clone.attributes}) + + # Step 10 + self.activeFormattingElements[i] = element + + # Step 11 + if element == self.activeFormattingElements[-1]: + break + + def clearActiveFormattingElements(self): + entry = self.activeFormattingElements.pop() + while self.activeFormattingElements and entry != Marker: + entry = self.activeFormattingElements.pop() + + def elementInActiveFormattingElements(self, name): + """Check if an element exists between the end of the active + formatting elements and the last marker. If it does, return it, else + return false""" + + for item in self.activeFormattingElements[::-1]: + # Check for Marker first because if it's a Marker it doesn't have a + # name attribute. + if item == Marker: + break + elif item.name == name: + return item + return False + + def insertRoot(self, token): + element = self.createElement(token) + self.openElements.append(element) + self.document.appendChild(element) + + def insertDoctype(self, token): + name = token["name"] + publicId = token["publicId"] + systemId = token["systemId"] + + doctype = self.doctypeClass(name, publicId, systemId) + self.document.appendChild(doctype) + + def insertComment(self, token, parent=None): + if parent is None: + parent = self.openElements[-1] + parent.appendChild(self.commentClass(token["data"])) + + def createElement(self, token): + """Create an element but don't insert it anywhere""" + name = token["name"] + namespace = token.get("namespace", self.defaultNamespace) + element = self.elementClass(name, namespace) + element.attributes = token["data"] + return element + + def _getInsertFromTable(self): + return self._insertFromTable + + def _setInsertFromTable(self, value): + """Switch the function used to insert an element from the + normal one to the misnested table one and back again""" + self._insertFromTable = value + if value: + self.insertElement = self.insertElementTable + else: + self.insertElement = self.insertElementNormal + + insertFromTable = property(_getInsertFromTable, _setInsertFromTable) + + def insertElementNormal(self, token): + name = token["name"] + assert isinstance(name, text_type), "Element %s not unicode" % name + namespace = token.get("namespace", self.defaultNamespace) + element = self.elementClass(name, namespace) + element.attributes = token["data"] + self.openElements[-1].appendChild(element) + self.openElements.append(element) + return element + + def insertElementTable(self, token): + """Create an element and insert it into the tree""" + element = self.createElement(token) + if self.openElements[-1].name not in tableInsertModeElements: + return self.insertElementNormal(token) + else: + # We should be in the InTable mode. This means we want to do + # special magic element rearranging + parent, insertBefore = self.getTableMisnestedNodePosition() + if insertBefore is None: + parent.appendChild(element) + else: + parent.insertBefore(element, insertBefore) + self.openElements.append(element) + return element + + def insertText(self, data, parent=None): + """Insert text data.""" + if parent is None: + parent = self.openElements[-1] + + if (not self.insertFromTable or (self.insertFromTable and + self.openElements[-1].name + not in tableInsertModeElements)): + parent.insertText(data) + else: + # We should be in the InTable mode. This means we want to do + # special magic element rearranging + parent, insertBefore = self.getTableMisnestedNodePosition() + parent.insertText(data, insertBefore) + + def getTableMisnestedNodePosition(self): + """Get the foster parent element, and sibling to insert before + (or None) when inserting a misnested table node""" + # The foster parent element is the one which comes before the most + # recently opened table element + # XXX - this is really inelegant + lastTable = None + fosterParent = None + insertBefore = None + for elm in self.openElements[::-1]: + if elm.name == "table": + lastTable = elm + break + if lastTable: + # XXX - we should really check that this parent is actually a + # node here + if lastTable.parent: + fosterParent = lastTable.parent + insertBefore = lastTable + else: + fosterParent = self.openElements[ + self.openElements.index(lastTable) - 1] + else: + fosterParent = self.openElements[0] + return fosterParent, insertBefore + + def generateImpliedEndTags(self, exclude=None): + name = self.openElements[-1].name + # XXX td, th and tr are not actually needed + if (name in frozenset(("dd", "dt", "li", "option", "optgroup", "p", "rp", "rt")) and + name != exclude): + self.openElements.pop() + # XXX This is not entirely what the specification says. We should + # investigate it more closely. + self.generateImpliedEndTags(exclude) + + def getDocument(self): + """Return the final tree""" + return self.document + + def getFragment(self): + """Return the final fragment""" + # assert self.innerHTML + fragment = self.fragmentClass() + self.openElements[0].reparentChildren(fragment) + return fragment + + def testSerializer(self, node): + """Serialize the subtree of node in the format required by unit tests + + :arg node: the node from which to start serializing + + """ + raise NotImplementedError diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/dom.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/dom.py new file mode 100644 index 0000000..d8b5300 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/dom.py @@ -0,0 +1,239 @@ +from __future__ import absolute_import, division, unicode_literals + + +try: + from collections.abc import MutableMapping +except ImportError: # Python 2.7 + from collections import MutableMapping +from xml.dom import minidom, Node +import weakref + +from . import base +from .. import constants +from ..constants import namespaces +from .._utils import moduleFactoryFactory + + +def getDomBuilder(DomImplementation): + Dom = DomImplementation + + class AttrList(MutableMapping): + def __init__(self, element): + self.element = element + + def __iter__(self): + return iter(self.element.attributes.keys()) + + def __setitem__(self, name, value): + if isinstance(name, tuple): + raise NotImplementedError + else: + attr = self.element.ownerDocument.createAttribute(name) + attr.value = value + self.element.attributes[name] = attr + + def __len__(self): + return len(self.element.attributes) + + def items(self): + return list(self.element.attributes.items()) + + def values(self): + return list(self.element.attributes.values()) + + def __getitem__(self, name): + if isinstance(name, tuple): + raise NotImplementedError + else: + return self.element.attributes[name].value + + def __delitem__(self, name): + if isinstance(name, tuple): + raise NotImplementedError + else: + del self.element.attributes[name] + + class NodeBuilder(base.Node): + def __init__(self, element): + base.Node.__init__(self, element.nodeName) + self.element = element + + namespace = property(lambda self: hasattr(self.element, "namespaceURI") and + self.element.namespaceURI or None) + + def appendChild(self, node): + node.parent = self + self.element.appendChild(node.element) + + def insertText(self, data, insertBefore=None): + text = self.element.ownerDocument.createTextNode(data) + if insertBefore: + self.element.insertBefore(text, insertBefore.element) + else: + self.element.appendChild(text) + + def insertBefore(self, node, refNode): + self.element.insertBefore(node.element, refNode.element) + node.parent = self + + def removeChild(self, node): + if node.element.parentNode == self.element: + self.element.removeChild(node.element) + node.parent = None + + def reparentChildren(self, newParent): + while self.element.hasChildNodes(): + child = self.element.firstChild + self.element.removeChild(child) + newParent.element.appendChild(child) + self.childNodes = [] + + def getAttributes(self): + return AttrList(self.element) + + def setAttributes(self, attributes): + if attributes: + for name, value in list(attributes.items()): + if isinstance(name, tuple): + if name[0] is not None: + qualifiedName = (name[0] + ":" + name[1]) + else: + qualifiedName = name[1] + self.element.setAttributeNS(name[2], qualifiedName, + value) + else: + self.element.setAttribute( + name, value) + attributes = property(getAttributes, setAttributes) + + def cloneNode(self): + return NodeBuilder(self.element.cloneNode(False)) + + def hasContent(self): + return self.element.hasChildNodes() + + def getNameTuple(self): + if self.namespace is None: + return namespaces["html"], self.name + else: + return self.namespace, self.name + + nameTuple = property(getNameTuple) + + class TreeBuilder(base.TreeBuilder): # pylint:disable=unused-variable + def documentClass(self): + self.dom = Dom.getDOMImplementation().createDocument(None, None, None) + return weakref.proxy(self) + + def insertDoctype(self, token): + name = token["name"] + publicId = token["publicId"] + systemId = token["systemId"] + + domimpl = Dom.getDOMImplementation() + doctype = domimpl.createDocumentType(name, publicId, systemId) + self.document.appendChild(NodeBuilder(doctype)) + if Dom == minidom: + doctype.ownerDocument = self.dom + + def elementClass(self, name, namespace=None): + if namespace is None and self.defaultNamespace is None: + node = self.dom.createElement(name) + else: + node = self.dom.createElementNS(namespace, name) + + return NodeBuilder(node) + + def commentClass(self, data): + return NodeBuilder(self.dom.createComment(data)) + + def fragmentClass(self): + return NodeBuilder(self.dom.createDocumentFragment()) + + def appendChild(self, node): + self.dom.appendChild(node.element) + + def testSerializer(self, element): + return testSerializer(element) + + def getDocument(self): + return self.dom + + def getFragment(self): + return base.TreeBuilder.getFragment(self).element + + def insertText(self, data, parent=None): + data = data + if parent != self: + base.TreeBuilder.insertText(self, data, parent) + else: + # HACK: allow text nodes as children of the document node + if hasattr(self.dom, '_child_node_types'): + # pylint:disable=protected-access + if Node.TEXT_NODE not in self.dom._child_node_types: + self.dom._child_node_types = list(self.dom._child_node_types) + self.dom._child_node_types.append(Node.TEXT_NODE) + self.dom.appendChild(self.dom.createTextNode(data)) + + implementation = DomImplementation + name = None + + def testSerializer(element): + element.normalize() + rv = [] + + def serializeElement(element, indent=0): + if element.nodeType == Node.DOCUMENT_TYPE_NODE: + if element.name: + if element.publicId or element.systemId: + publicId = element.publicId or "" + systemId = element.systemId or "" + rv.append("""|%s<!DOCTYPE %s "%s" "%s">""" % + (' ' * indent, element.name, publicId, systemId)) + else: + rv.append("|%s<!DOCTYPE %s>" % (' ' * indent, element.name)) + else: + rv.append("|%s<!DOCTYPE >" % (' ' * indent,)) + elif element.nodeType == Node.DOCUMENT_NODE: + rv.append("#document") + elif element.nodeType == Node.DOCUMENT_FRAGMENT_NODE: + rv.append("#document-fragment") + elif element.nodeType == Node.COMMENT_NODE: + rv.append("|%s<!-- %s -->" % (' ' * indent, element.nodeValue)) + elif element.nodeType == Node.TEXT_NODE: + rv.append("|%s\"%s\"" % (' ' * indent, element.nodeValue)) + else: + if (hasattr(element, "namespaceURI") and + element.namespaceURI is not None): + name = "%s %s" % (constants.prefixes[element.namespaceURI], + element.nodeName) + else: + name = element.nodeName + rv.append("|%s<%s>" % (' ' * indent, name)) + if element.hasAttributes(): + attributes = [] + for i in range(len(element.attributes)): + attr = element.attributes.item(i) + name = attr.nodeName + value = attr.value + ns = attr.namespaceURI + if ns: + name = "%s %s" % (constants.prefixes[ns], attr.localName) + else: + name = attr.nodeName + attributes.append((name, value)) + + for name, value in sorted(attributes): + rv.append('|%s%s="%s"' % (' ' * (indent + 2), name, value)) + indent += 2 + for child in element.childNodes: + serializeElement(child, indent) + serializeElement(element, 0) + + return "\n".join(rv) + + return locals() + + +# The actual means to get a module! +getDomModule = moduleFactoryFactory(getDomBuilder) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/etree.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/etree.py new file mode 100644 index 0000000..0dedf44 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/etree.py @@ -0,0 +1,340 @@ +from __future__ import absolute_import, division, unicode_literals +# pylint:disable=protected-access + +from pip._vendor.six import text_type + +import re + +from . import base +from .. import _ihatexml +from .. import constants +from ..constants import namespaces +from .._utils import moduleFactoryFactory + +tag_regexp = re.compile("{([^}]*)}(.*)") + + +def getETreeBuilder(ElementTreeImplementation, fullTree=False): + ElementTree = ElementTreeImplementation + ElementTreeCommentType = ElementTree.Comment("asd").tag + + class Element(base.Node): + def __init__(self, name, namespace=None): + self._name = name + self._namespace = namespace + self._element = ElementTree.Element(self._getETreeTag(name, + namespace)) + if namespace is None: + self.nameTuple = namespaces["html"], self._name + else: + self.nameTuple = self._namespace, self._name + self.parent = None + self._childNodes = [] + self._flags = [] + + def _getETreeTag(self, name, namespace): + if namespace is None: + etree_tag = name + else: + etree_tag = "{%s}%s" % (namespace, name) + return etree_tag + + def _setName(self, name): + self._name = name + self._element.tag = self._getETreeTag(self._name, self._namespace) + + def _getName(self): + return self._name + + name = property(_getName, _setName) + + def _setNamespace(self, namespace): + self._namespace = namespace + self._element.tag = self._getETreeTag(self._name, self._namespace) + + def _getNamespace(self): + return self._namespace + + namespace = property(_getNamespace, _setNamespace) + + def _getAttributes(self): + return self._element.attrib + + def _setAttributes(self, attributes): + # Delete existing attributes first + # XXX - there may be a better way to do this... + for key in list(self._element.attrib.keys()): + del self._element.attrib[key] + for key, value in attributes.items(): + if isinstance(key, tuple): + name = "{%s}%s" % (key[2], key[1]) + else: + name = key + self._element.set(name, value) + + attributes = property(_getAttributes, _setAttributes) + + def _getChildNodes(self): + return self._childNodes + + def _setChildNodes(self, value): + del self._element[:] + self._childNodes = [] + for element in value: + self.insertChild(element) + + childNodes = property(_getChildNodes, _setChildNodes) + + def hasContent(self): + """Return true if the node has children or text""" + return bool(self._element.text or len(self._element)) + + def appendChild(self, node): + self._childNodes.append(node) + self._element.append(node._element) + node.parent = self + + def insertBefore(self, node, refNode): + index = list(self._element).index(refNode._element) + self._element.insert(index, node._element) + node.parent = self + + def removeChild(self, node): + self._childNodes.remove(node) + self._element.remove(node._element) + node.parent = None + + def insertText(self, data, insertBefore=None): + if not(len(self._element)): + if not self._element.text: + self._element.text = "" + self._element.text += data + elif insertBefore is None: + # Insert the text as the tail of the last child element + if not self._element[-1].tail: + self._element[-1].tail = "" + self._element[-1].tail += data + else: + # Insert the text before the specified node + children = list(self._element) + index = children.index(insertBefore._element) + if index > 0: + if not self._element[index - 1].tail: + self._element[index - 1].tail = "" + self._element[index - 1].tail += data + else: + if not self._element.text: + self._element.text = "" + self._element.text += data + + def cloneNode(self): + element = type(self)(self.name, self.namespace) + for name, value in self.attributes.items(): + element.attributes[name] = value + return element + + def reparentChildren(self, newParent): + if newParent.childNodes: + newParent.childNodes[-1]._element.tail += self._element.text + else: + if not newParent._element.text: + newParent._element.text = "" + if self._element.text is not None: + newParent._element.text += self._element.text + self._element.text = "" + base.Node.reparentChildren(self, newParent) + + class Comment(Element): + def __init__(self, data): + # Use the superclass constructor to set all properties on the + # wrapper element + self._element = ElementTree.Comment(data) + self.parent = None + self._childNodes = [] + self._flags = [] + + def _getData(self): + return self._element.text + + def _setData(self, value): + self._element.text = value + + data = property(_getData, _setData) + + class DocumentType(Element): + def __init__(self, name, publicId, systemId): + Element.__init__(self, "<!DOCTYPE>") + self._element.text = name + self.publicId = publicId + self.systemId = systemId + + def _getPublicId(self): + return self._element.get("publicId", "") + + def _setPublicId(self, value): + if value is not None: + self._element.set("publicId", value) + + publicId = property(_getPublicId, _setPublicId) + + def _getSystemId(self): + return self._element.get("systemId", "") + + def _setSystemId(self, value): + if value is not None: + self._element.set("systemId", value) + + systemId = property(_getSystemId, _setSystemId) + + class Document(Element): + def __init__(self): + Element.__init__(self, "DOCUMENT_ROOT") + + class DocumentFragment(Element): + def __init__(self): + Element.__init__(self, "DOCUMENT_FRAGMENT") + + def testSerializer(element): + rv = [] + + def serializeElement(element, indent=0): + if not(hasattr(element, "tag")): + element = element.getroot() + if element.tag == "<!DOCTYPE>": + if element.get("publicId") or element.get("systemId"): + publicId = element.get("publicId") or "" + systemId = element.get("systemId") or "" + rv.append("""<!DOCTYPE %s "%s" "%s">""" % + (element.text, publicId, systemId)) + else: + rv.append("<!DOCTYPE %s>" % (element.text,)) + elif element.tag == "DOCUMENT_ROOT": + rv.append("#document") + if element.text is not None: + rv.append("|%s\"%s\"" % (' ' * (indent + 2), element.text)) + if element.tail is not None: + raise TypeError("Document node cannot have tail") + if hasattr(element, "attrib") and len(element.attrib): + raise TypeError("Document node cannot have attributes") + elif element.tag == ElementTreeCommentType: + rv.append("|%s<!-- %s -->" % (' ' * indent, element.text)) + else: + assert isinstance(element.tag, text_type), \ + "Expected unicode, got %s, %s" % (type(element.tag), element.tag) + nsmatch = tag_regexp.match(element.tag) + + if nsmatch is None: + name = element.tag + else: + ns, name = nsmatch.groups() + prefix = constants.prefixes[ns] + name = "%s %s" % (prefix, name) + rv.append("|%s<%s>" % (' ' * indent, name)) + + if hasattr(element, "attrib"): + attributes = [] + for name, value in element.attrib.items(): + nsmatch = tag_regexp.match(name) + if nsmatch is not None: + ns, name = nsmatch.groups() + prefix = constants.prefixes[ns] + attr_string = "%s %s" % (prefix, name) + else: + attr_string = name + attributes.append((attr_string, value)) + + for name, value in sorted(attributes): + rv.append('|%s%s="%s"' % (' ' * (indent + 2), name, value)) + if element.text: + rv.append("|%s\"%s\"" % (' ' * (indent + 2), element.text)) + indent += 2 + for child in element: + serializeElement(child, indent) + if element.tail: + rv.append("|%s\"%s\"" % (' ' * (indent - 2), element.tail)) + serializeElement(element, 0) + + return "\n".join(rv) + + def tostring(element): # pylint:disable=unused-variable + """Serialize an element and its child nodes to a string""" + rv = [] + filter = _ihatexml.InfosetFilter() + + def serializeElement(element): + if isinstance(element, ElementTree.ElementTree): + element = element.getroot() + + if element.tag == "<!DOCTYPE>": + if element.get("publicId") or element.get("systemId"): + publicId = element.get("publicId") or "" + systemId = element.get("systemId") or "" + rv.append("""<!DOCTYPE %s PUBLIC "%s" "%s">""" % + (element.text, publicId, systemId)) + else: + rv.append("<!DOCTYPE %s>" % (element.text,)) + elif element.tag == "DOCUMENT_ROOT": + if element.text is not None: + rv.append(element.text) + if element.tail is not None: + raise TypeError("Document node cannot have tail") + if hasattr(element, "attrib") and len(element.attrib): + raise TypeError("Document node cannot have attributes") + + for child in element: + serializeElement(child) + + elif element.tag == ElementTreeCommentType: + rv.append("<!--%s-->" % (element.text,)) + else: + # This is assumed to be an ordinary element + if not element.attrib: + rv.append("<%s>" % (filter.fromXmlName(element.tag),)) + else: + attr = " ".join(["%s=\"%s\"" % ( + filter.fromXmlName(name), value) + for name, value in element.attrib.items()]) + rv.append("<%s %s>" % (element.tag, attr)) + if element.text: + rv.append(element.text) + + for child in element: + serializeElement(child) + + rv.append("</%s>" % (element.tag,)) + + if element.tail: + rv.append(element.tail) + + serializeElement(element) + + return "".join(rv) + + class TreeBuilder(base.TreeBuilder): # pylint:disable=unused-variable + documentClass = Document + doctypeClass = DocumentType + elementClass = Element + commentClass = Comment + fragmentClass = DocumentFragment + implementation = ElementTreeImplementation + + def testSerializer(self, element): + return testSerializer(element) + + def getDocument(self): + if fullTree: + return self.document._element + else: + if self.defaultNamespace is not None: + return self.document._element.find( + "{%s}html" % self.defaultNamespace) + else: + return self.document._element.find("html") + + def getFragment(self): + return base.TreeBuilder.getFragment(self)._element + + return locals() + + +getETreeModule = moduleFactoryFactory(getETreeBuilder) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py new file mode 100644 index 0000000..ca12a99 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py @@ -0,0 +1,366 @@ +"""Module for supporting the lxml.etree library. The idea here is to use as much +of the native library as possible, without using fragile hacks like custom element +names that break between releases. The downside of this is that we cannot represent +all possible trees; specifically the following are known to cause problems: + +Text or comments as siblings of the root element +Docypes with no name + +When any of these things occur, we emit a DataLossWarning +""" + +from __future__ import absolute_import, division, unicode_literals +# pylint:disable=protected-access + +import warnings +import re +import sys + +from . import base +from ..constants import DataLossWarning +from .. import constants +from . import etree as etree_builders +from .. import _ihatexml + +import lxml.etree as etree + + +fullTree = True +tag_regexp = re.compile("{([^}]*)}(.*)") + +comment_type = etree.Comment("asd").tag + + +class DocumentType(object): + def __init__(self, name, publicId, systemId): + self.name = name + self.publicId = publicId + self.systemId = systemId + + +class Document(object): + def __init__(self): + self._elementTree = None + self._childNodes = [] + + def appendChild(self, element): + self._elementTree.getroot().addnext(element._element) + + def _getChildNodes(self): + return self._childNodes + + childNodes = property(_getChildNodes) + + +def testSerializer(element): + rv = [] + infosetFilter = _ihatexml.InfosetFilter(preventDoubleDashComments=True) + + def serializeElement(element, indent=0): + if not hasattr(element, "tag"): + if hasattr(element, "getroot"): + # Full tree case + rv.append("#document") + if element.docinfo.internalDTD: + if not (element.docinfo.public_id or + element.docinfo.system_url): + dtd_str = "<!DOCTYPE %s>" % element.docinfo.root_name + else: + dtd_str = """<!DOCTYPE %s "%s" "%s">""" % ( + element.docinfo.root_name, + element.docinfo.public_id, + element.docinfo.system_url) + rv.append("|%s%s" % (' ' * (indent + 2), dtd_str)) + next_element = element.getroot() + while next_element.getprevious() is not None: + next_element = next_element.getprevious() + while next_element is not None: + serializeElement(next_element, indent + 2) + next_element = next_element.getnext() + elif isinstance(element, str) or isinstance(element, bytes): + # Text in a fragment + assert isinstance(element, str) or sys.version_info[0] == 2 + rv.append("|%s\"%s\"" % (' ' * indent, element)) + else: + # Fragment case + rv.append("#document-fragment") + for next_element in element: + serializeElement(next_element, indent + 2) + elif element.tag == comment_type: + rv.append("|%s<!-- %s -->" % (' ' * indent, element.text)) + if hasattr(element, "tail") and element.tail: + rv.append("|%s\"%s\"" % (' ' * indent, element.tail)) + else: + assert isinstance(element, etree._Element) + nsmatch = etree_builders.tag_regexp.match(element.tag) + if nsmatch is not None: + ns = nsmatch.group(1) + tag = nsmatch.group(2) + prefix = constants.prefixes[ns] + rv.append("|%s<%s %s>" % (' ' * indent, prefix, + infosetFilter.fromXmlName(tag))) + else: + rv.append("|%s<%s>" % (' ' * indent, + infosetFilter.fromXmlName(element.tag))) + + if hasattr(element, "attrib"): + attributes = [] + for name, value in element.attrib.items(): + nsmatch = tag_regexp.match(name) + if nsmatch is not None: + ns, name = nsmatch.groups() + name = infosetFilter.fromXmlName(name) + prefix = constants.prefixes[ns] + attr_string = "%s %s" % (prefix, name) + else: + attr_string = infosetFilter.fromXmlName(name) + attributes.append((attr_string, value)) + + for name, value in sorted(attributes): + rv.append('|%s%s="%s"' % (' ' * (indent + 2), name, value)) + + if element.text: + rv.append("|%s\"%s\"" % (' ' * (indent + 2), element.text)) + indent += 2 + for child in element: + serializeElement(child, indent) + if hasattr(element, "tail") and element.tail: + rv.append("|%s\"%s\"" % (' ' * (indent - 2), element.tail)) + serializeElement(element, 0) + + return "\n".join(rv) + + +def tostring(element): + """Serialize an element and its child nodes to a string""" + rv = [] + + def serializeElement(element): + if not hasattr(element, "tag"): + if element.docinfo.internalDTD: + if element.docinfo.doctype: + dtd_str = element.docinfo.doctype + else: + dtd_str = "<!DOCTYPE %s>" % element.docinfo.root_name + rv.append(dtd_str) + serializeElement(element.getroot()) + + elif element.tag == comment_type: + rv.append("<!--%s-->" % (element.text,)) + + else: + # This is assumed to be an ordinary element + if not element.attrib: + rv.append("<%s>" % (element.tag,)) + else: + attr = " ".join(["%s=\"%s\"" % (name, value) + for name, value in element.attrib.items()]) + rv.append("<%s %s>" % (element.tag, attr)) + if element.text: + rv.append(element.text) + + for child in element: + serializeElement(child) + + rv.append("</%s>" % (element.tag,)) + + if hasattr(element, "tail") and element.tail: + rv.append(element.tail) + + serializeElement(element) + + return "".join(rv) + + +class TreeBuilder(base.TreeBuilder): + documentClass = Document + doctypeClass = DocumentType + elementClass = None + commentClass = None + fragmentClass = Document + implementation = etree + + def __init__(self, namespaceHTMLElements, fullTree=False): + builder = etree_builders.getETreeModule(etree, fullTree=fullTree) + infosetFilter = self.infosetFilter = _ihatexml.InfosetFilter(preventDoubleDashComments=True) + self.namespaceHTMLElements = namespaceHTMLElements + + class Attributes(dict): + def __init__(self, element, value=None): + if value is None: + value = {} + self._element = element + dict.__init__(self, value) # pylint:disable=non-parent-init-called + for key, value in self.items(): + if isinstance(key, tuple): + name = "{%s}%s" % (key[2], infosetFilter.coerceAttribute(key[1])) + else: + name = infosetFilter.coerceAttribute(key) + self._element._element.attrib[name] = value + + def __setitem__(self, key, value): + dict.__setitem__(self, key, value) + if isinstance(key, tuple): + name = "{%s}%s" % (key[2], infosetFilter.coerceAttribute(key[1])) + else: + name = infosetFilter.coerceAttribute(key) + self._element._element.attrib[name] = value + + class Element(builder.Element): + def __init__(self, name, namespace): + name = infosetFilter.coerceElement(name) + builder.Element.__init__(self, name, namespace=namespace) + self._attributes = Attributes(self) + + def _setName(self, name): + self._name = infosetFilter.coerceElement(name) + self._element.tag = self._getETreeTag( + self._name, self._namespace) + + def _getName(self): + return infosetFilter.fromXmlName(self._name) + + name = property(_getName, _setName) + + def _getAttributes(self): + return self._attributes + + def _setAttributes(self, attributes): + self._attributes = Attributes(self, attributes) + + attributes = property(_getAttributes, _setAttributes) + + def insertText(self, data, insertBefore=None): + data = infosetFilter.coerceCharacters(data) + builder.Element.insertText(self, data, insertBefore) + + def appendChild(self, child): + builder.Element.appendChild(self, child) + + class Comment(builder.Comment): + def __init__(self, data): + data = infosetFilter.coerceComment(data) + builder.Comment.__init__(self, data) + + def _setData(self, data): + data = infosetFilter.coerceComment(data) + self._element.text = data + + def _getData(self): + return self._element.text + + data = property(_getData, _setData) + + self.elementClass = Element + self.commentClass = Comment + # self.fragmentClass = builder.DocumentFragment + base.TreeBuilder.__init__(self, namespaceHTMLElements) + + def reset(self): + base.TreeBuilder.reset(self) + self.insertComment = self.insertCommentInitial + self.initial_comments = [] + self.doctype = None + + def testSerializer(self, element): + return testSerializer(element) + + def getDocument(self): + if fullTree: + return self.document._elementTree + else: + return self.document._elementTree.getroot() + + def getFragment(self): + fragment = [] + element = self.openElements[0]._element + if element.text: + fragment.append(element.text) + fragment.extend(list(element)) + if element.tail: + fragment.append(element.tail) + return fragment + + def insertDoctype(self, token): + name = token["name"] + publicId = token["publicId"] + systemId = token["systemId"] + + if not name: + warnings.warn("lxml cannot represent empty doctype", DataLossWarning) + self.doctype = None + else: + coercedName = self.infosetFilter.coerceElement(name) + if coercedName != name: + warnings.warn("lxml cannot represent non-xml doctype", DataLossWarning) + + doctype = self.doctypeClass(coercedName, publicId, systemId) + self.doctype = doctype + + def insertCommentInitial(self, data, parent=None): + assert parent is None or parent is self.document + assert self.document._elementTree is None + self.initial_comments.append(data) + + def insertCommentMain(self, data, parent=None): + if (parent == self.document and + self.document._elementTree.getroot()[-1].tag == comment_type): + warnings.warn("lxml cannot represent adjacent comments beyond the root elements", DataLossWarning) + super(TreeBuilder, self).insertComment(data, parent) + + def insertRoot(self, token): + # Because of the way libxml2 works, it doesn't seem to be possible to + # alter information like the doctype after the tree has been parsed. + # Therefore we need to use the built-in parser to create our initial + # tree, after which we can add elements like normal + docStr = "" + if self.doctype: + assert self.doctype.name + docStr += "<!DOCTYPE %s" % self.doctype.name + if (self.doctype.publicId is not None or + self.doctype.systemId is not None): + docStr += (' PUBLIC "%s" ' % + (self.infosetFilter.coercePubid(self.doctype.publicId or ""))) + if self.doctype.systemId: + sysid = self.doctype.systemId + if sysid.find("'") >= 0 and sysid.find('"') >= 0: + warnings.warn("DOCTYPE system cannot contain single and double quotes", DataLossWarning) + sysid = sysid.replace("'", 'U00027') + if sysid.find("'") >= 0: + docStr += '"%s"' % sysid + else: + docStr += "'%s'" % sysid + else: + docStr += "''" + docStr += ">" + if self.doctype.name != token["name"]: + warnings.warn("lxml cannot represent doctype with a different name to the root element", DataLossWarning) + docStr += "<THIS_SHOULD_NEVER_APPEAR_PUBLICLY/>" + root = etree.fromstring(docStr) + + # Append the initial comments: + for comment_token in self.initial_comments: + comment = self.commentClass(comment_token["data"]) + root.addprevious(comment._element) + + # Create the root document and add the ElementTree to it + self.document = self.documentClass() + self.document._elementTree = root.getroottree() + + # Give the root element the right name + name = token["name"] + namespace = token.get("namespace", self.defaultNamespace) + if namespace is None: + etree_tag = name + else: + etree_tag = "{%s}%s" % (namespace, name) + root.tag = etree_tag + + # Add the root element to the internal child/open data structures + root_element = self.elementClass(name, namespace) + root_element._element = root + self.document._childNodes.append(root_element) + self.openElements.append(root_element) + + # Reset to the default insert comment function + self.insertComment = self.insertCommentMain diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py new file mode 100644 index 0000000..9bec207 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py @@ -0,0 +1,154 @@ +"""A collection of modules for iterating through different kinds of +tree, generating tokens identical to those produced by the tokenizer +module. + +To create a tree walker for a new type of tree, you need to do +implement a tree walker object (called TreeWalker by convention) that +implements a 'serialize' method taking a tree as sole argument and +returning an iterator generating tokens. +""" + +from __future__ import absolute_import, division, unicode_literals + +from .. import constants +from .._utils import default_etree + +__all__ = ["getTreeWalker", "pprint"] + +treeWalkerCache = {} + + +def getTreeWalker(treeType, implementation=None, **kwargs): + """Get a TreeWalker class for various types of tree with built-in support + + :arg str treeType: the name of the tree type required (case-insensitive). + Supported values are: + + * "dom": The xml.dom.minidom DOM implementation + * "etree": A generic walker for tree implementations exposing an + elementtree-like interface (known to work with ElementTree, + cElementTree and lxml.etree). + * "lxml": Optimized walker for lxml.etree + * "genshi": a Genshi stream + + :arg implementation: A module implementing the tree type e.g. + xml.etree.ElementTree or cElementTree (Currently applies to the "etree" + tree type only). + + :arg kwargs: keyword arguments passed to the etree walker--for other + walkers, this has no effect + + :returns: a TreeWalker class + + """ + + treeType = treeType.lower() + if treeType not in treeWalkerCache: + if treeType == "dom": + from . import dom + treeWalkerCache[treeType] = dom.TreeWalker + elif treeType == "genshi": + from . import genshi + treeWalkerCache[treeType] = genshi.TreeWalker + elif treeType == "lxml": + from . import etree_lxml + treeWalkerCache[treeType] = etree_lxml.TreeWalker + elif treeType == "etree": + from . import etree + if implementation is None: + implementation = default_etree + # XXX: NEVER cache here, caching is done in the etree submodule + return etree.getETreeModule(implementation, **kwargs).TreeWalker + return treeWalkerCache.get(treeType) + + +def concatenateCharacterTokens(tokens): + pendingCharacters = [] + for token in tokens: + type = token["type"] + if type in ("Characters", "SpaceCharacters"): + pendingCharacters.append(token["data"]) + else: + if pendingCharacters: + yield {"type": "Characters", "data": "".join(pendingCharacters)} + pendingCharacters = [] + yield token + if pendingCharacters: + yield {"type": "Characters", "data": "".join(pendingCharacters)} + + +def pprint(walker): + """Pretty printer for tree walkers + + Takes a TreeWalker instance and pretty prints the output of walking the tree. + + :arg walker: a TreeWalker instance + + """ + output = [] + indent = 0 + for token in concatenateCharacterTokens(walker): + type = token["type"] + if type in ("StartTag", "EmptyTag"): + # tag name + if token["namespace"] and token["namespace"] != constants.namespaces["html"]: + if token["namespace"] in constants.prefixes: + ns = constants.prefixes[token["namespace"]] + else: + ns = token["namespace"] + name = "%s %s" % (ns, token["name"]) + else: + name = token["name"] + output.append("%s<%s>" % (" " * indent, name)) + indent += 2 + # attributes (sorted for consistent ordering) + attrs = token["data"] + for (namespace, localname), value in sorted(attrs.items()): + if namespace: + if namespace in constants.prefixes: + ns = constants.prefixes[namespace] + else: + ns = namespace + name = "%s %s" % (ns, localname) + else: + name = localname + output.append("%s%s=\"%s\"" % (" " * indent, name, value)) + # self-closing + if type == "EmptyTag": + indent -= 2 + + elif type == "EndTag": + indent -= 2 + + elif type == "Comment": + output.append("%s<!-- %s -->" % (" " * indent, token["data"])) + + elif type == "Doctype": + if token["name"]: + if token["publicId"]: + output.append("""%s<!DOCTYPE %s "%s" "%s">""" % + (" " * indent, + token["name"], + token["publicId"], + token["systemId"] if token["systemId"] else "")) + elif token["systemId"]: + output.append("""%s<!DOCTYPE %s "" "%s">""" % + (" " * indent, + token["name"], + token["systemId"])) + else: + output.append("%s<!DOCTYPE %s>" % (" " * indent, + token["name"])) + else: + output.append("%s<!DOCTYPE >" % (" " * indent,)) + + elif type == "Characters": + output.append("%s\"%s\"" % (" " * indent, token["data"])) + + elif type == "SpaceCharacters": + assert False, "concatenateCharacterTokens should have got rid of all Space tokens" + + else: + raise ValueError("Unknown token type, %s" % type) + + return "\n".join(output) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d33e283995d9f9a0d48fdc05315fcfa20c571485 GIT binary patch literal 4018 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 a+3Vu2J`r*mFE702qF%d!>y^TdVCjFe@>Kl* literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/base.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/base.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..98869a3944692b5e8e0f478da235a9f6ed364840 GIT binary patch literal 7018 zcmdT}&2JmW72jPhm&+CPVfj-|+HB(_GFw}6gVbnL*L5mUj@yI|V%cdn38)okC9bqw z%Ck$^Vks18(jJN;$f1WGa<B@tfKSaKEdmrM&>s5-^st9s+Dk4y6h#jOn)LT(NbZud zoCL_BU1HzP%zJM>-h1=jo8iszaZADTulM%dXTG2)f2B(HDWY-(Z*&iUDNGHNrs}9o z&C!}UC#O=I7U<2qlSetn^uTBqoI=xd%x2LkqAkx1R$wM8GK-C|5*yzrI+mB;9CJ#5 z<IV)&q%#G0#F+*>>Kp?+?wnu~&Pg_T@03^ESDoTjg-x;2TM8?AGjHac)2JU|<EW2& zr%``|P2W(;M?b_Ym2xhbbl0L*(2l*D-`sBTI5C;O<41lgOs3kQUvDw57WlEp-5@Hf ziC#s+hnnQILbvHf+iu;9lG0AgXO+NfdSM(TlcII8;c~YQ-Y7Abt}otvu~J=03Mj3- z`cfs)S1R8_wemtmwl7|PQ4|bNU0ZoIDcr1nw|f1RYGSQ$&wIrUwmhDksJ6nFy?UER z{*ITncg8NA>5-qgoG5i#T=vPKas_V`0C<X{GR4uD>g1Tla&IY)&UBW?SEvAAgPkTd zyrnt?QUzK}HqIvSEwV{Ag|7vnPUAbq9%0AWaZr}n33d`K<Lnfh!FPfkg`gkhM=)e( zkLDlQt{r17_O9;*%nvv0xV7blk!9I<Rz%r$xo0!K9!GZEaAVsI0=wbvcwk*!jd!=b z)m3|)*zIWBtNZJ_qML?i6V7g}gUb`$iLU2l*L6}@|DiIyi+Cfl>8{#UYA{&LR_iP- za?g!DnrbRu*$Yi_!R44W*04YW$<@Ry`wmu@5>?4ih^VY3dgKM`{1}G0ukaK2{JS&1 z&HWvWF~8&T`Sn)7U?B6)-ksm5J-fr3o$%@P%?pjj-A<<#JbQ7i!7t$12<KPkxBcz& zei+4&$@vQxF7E8^e6>xD;;rp?A#3sZM%)a(7WixPGy$3y^}gmt-rV+XV%BPY=*P9% zBeZxS6{B-BUFcjNUsplUf2d5akeG==to#rbbVIqXR`09H(P}Hc*4&o1@39K!EnZgn zaS)0XOK=iZF+TP~t#$@AIlekNzQ7;QSPl$ge9{<GyDHP()u6Fl=f_vQ5ZhDeEVMlu zUD}m>$B!FAO&i!Op^d#7xf@=pC!x${v>|mVIS&$XFK+WNTCi_;+;;=N<B1i@G1AVG ziDCSG=$>pc(U}{&LI!0`2qnp3%u&hY#qduJ#A0@)GHMaX<$50I{zGMY>v*Fl03Z|% zri?B9u6_&p>gwF?D)-=P_f@Jh9pcKn9GV=GSf#lg@2<GL&6qAoNN3>Tq>KjD-cFN3 zIDfwGhW46=9SZk^9r}PyQvN=xCk<wV){SEhS<~jCqQ3^$9F4HpE^SY85+lqFH(G4? z0pnh{VBcwY=!M%bhp-i6rqb<zv#%&OhMSklT=VK~JCdG*_BlOq!-o@sV4_B=9k6gV zmY%5I8zM9Kz(x)eW@7d+_jUdlw3X;2%cMAvD7VqtnYo29V)sOY;Uc>~8g?3g93<tu z+*xEQ{7HZ$FJzXCWmZ3GU8dJl@&zzNB>-hoS2b1p$js@(JFrh#*NLk4P??NP?7#^W zvc@KM;XgArW#53o$N&E(HPGr|>q*Q$hSLs|n_M5!4?o*SNv%jn2rn)~Q~^>%A*BR$ z(C<G(4zW*H&w;T2P?=OB)Ir*m>cGy=31z&WQATK2LiRtQi-9;FJfXyp?d6=<Ai}n} zuyP8UXcYlvVD_UXZXo<&nYTb2QH)Y7A<d6EN3woY&<q6^GHZJ4c%!=jU3CxP<(?9& z`|2J%DpO;?HwkKQs;876X*0@RuAAc*nFep0dsh?QRuf#gK9{6ss-V`p8fOe}K&|r_ z+<Lz*k`L@-C^l8y4azLj9MX0}W@oC|+=<-PlD7>JP&(8K;r!fqHnROtcv6Z$=cGT| z7z9grYVwWE7Ej&Y>gvd#$hK(M)zx%hG|8cR$rX*gjE=m!E+qjAsaqt><;$1tb>3>) z{k&u@lb6g<USi9{JDYA1WB;KJ&e&HG!EGPuAR;`uGMRa8wxigNT7(dJQ5gG_2Z;PH z%P-R)`<t0D&c60W`2bzuNAX!nJQsU+<Fm7~<zcGV-uM(uwtax@`|Vj$!t8=Q3+y?& zJxjR(s_oekiO=qRsv+F9I*npOHmrp+MiejDU#VVy`Nij6xaL%9uRMQkrE=q?=N2nN z^L;Hlk58D!xgpM!u|12ihj~-unB6;^?UUC%7*XUNBrur?kS=Vhrna>(@Fp2MhMkT` z^I`Uzc2-R$NBH;`;RzBeU07L9j37cnvd!tFo8$s7Objks`XSi{!ZDgYV*%2>z*~=# zJoh&m@u;uTX+aFs(J26BMprHMl&Y&Gyp}rED|IF_o{Kn!{1zqe6bD2MIFJ;x)Q!0I zVyj8V($S1{M96hXl}aTQ@gW@~g&smkOGZDL;)-Nubk&942tUEBW$tfwrZY?Ip{t*m zc~GJ&(p(YjewtnC67~We1cisnEQOA3lxk(XlUV+CdoA$m*Vt%#v>U}<bGUtAag>}M zG7ygUat39Y=E)4r><^Qe{f?!ydbz@rkO*HO@C^bK?<5epLV-3o7WFeUkERM)`Sr*? zgOzM%L`Qi-?2~7ubNGWqCqfDAh=@p*8JdA;;GZAd4Mlh2#2JXvUm4v+VDDLskip2x z5z~q1m$YzkST#qYIbjd1caRxTqAE^6i03DjeR;q?{X7C%fHOrq+zMNFLL3g5ygi6I zM{ka{E!cb(z4T6Qj!DET(8U2A^?LjDV5-`XZTHY+b-AontK~^L36l(KwZy8`nl082 zs9dVmZnxc_hbh!*&}ps4$xHA@3D60Ef0@8J0&@f|68JiSO9U<x_!fawnxaI;ByMBq zHbQtFQ`HUAG;^k99XF4d6XsJW9WgD+g@zsy{uR8@GXUxR5z}zbgA|DA_~HhM8TjVu z5)WTP+#o4*gM@ur;?rO~psNR7EASbR^3wqKdnaa{<epiN*cTHUUQE|<OJ3~yLG&BY zODj=3Pd@mXY;Kt2v(APu(Y#Wridl@K&t)HhK%6{3$V}pi!zYn4d@gekl0bmC;lrDS z8^6m;;$f0VIX;(JkR)Eh^<5~m^83sr9wLd9Vd%<f4BQ4@vc%{gu#&E_sZfT^l&#`B zD*rq7HEJS5$3^Chg4|kTA~)BNo$n#j-qX9eSliP0cfgzLYHur)r-y$=tB%%9wC1UG zNqNKC%XjmHz5ROlTi^}g|J2o9*Y}LQ!k&qq4E}c4hzm@gQGolPTZqjq17GD{v1@b- zU9+q2>q9;Lie?Z_fx?m$`#CZGE%ZNzKK=$w3A4uB<^4=}37GLM4XY!sH8F&<ftwV# zDVFc`JC&vA>fn1Cd`E;-ilNSwy<)f6lh<;$xToGWr2M!6x`#?n$^bpSH!KCT{CpsX z+&gOY3n7Vupj7Tn(@OW{c?kOIs#_*7f5c2^Y~|ijF*mDg^=9>#u0@#80`8c=sqd(_ zmv0+%xmY%;bXTQ(NMJe9=>V}(J}&N3`7+u#8Hx0HbOx4waGXj70(1z>xJn8J(o0TK zNq9+0o209}N+sb<pQq9_fby8UtsBE_d*7&&0+Y^02C*{8lDr6*@}x>ZEV0syE5}+N zxCUn|OgG$!7ZJ|=4`7a72T)W4X`rQ^P<72zC+Jlzz!H)~OVvI$Q8u(`z-i4AuaTS5 z47H@`s2gY}UJLYJ1Schx8fq54y4HE@5U+%rUvcwVEt~ub=D?pL@NEJ@*g`@B;mBx| zy23QTkeh!WugFwP6~RUPs^v#1(yg~~nTklqDWY)7Upa;Aq;R(x%&}IJ=c!h#x9FN1 z|D<G8Dbj9)MBIMYYR-8750zT=`cj3HCY|X)8~wo|5o9Ayk^X9tb+Qzv)cey#Hj&9V zrQY8!vWbkv8Iym+$QEHVQ)o`~&6bbUzqPjM)ngG)MQF=tbRdkxyd*>WWwPPuae!l5 aNj;`bsG6dEtmh19y8naja#KH0zVu&6)y0<p literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/dom.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/dom.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..45288a8fb22c91746f10f5d4c5e67dd958195471 GIT binary patch literal 1747 zcmb7EPj4GV6rb5$d)KbrrX~$Z)1n@bz=*~HiHb;7)sVPV1l?4zLtzA3tv%y-o!PZJ zvo>**o*KSKa?AzsDfkd`LgLgLCk|ZTy>(+JQ7;|oy`A@G-}}v*_hz?TE)rP({C*n# znj_>d6fQ0YgvUVo8(^GpDoIQkjV)%yHnS<}Ea}8KmV>>`9hr|^=2G&M@Ep${6P_1t z&wFjN0(Tpv>b-$Dq-vWRVN3VrFcm=*5Be%K9*;(mj{1q28zxb^&qW}kRH#tuDm9J| ziZ>Mh1)&vc(Z)a*mj%LOApJQoK^WzPS)6j~m@pfm!Pl99Vma<|59B;A0H~rVHkA-B zLb)$g8{?cWJboT%14#c3?1=VAN_*D6rS7G6&jC3Hlm~J<PUGC}flr}h?dR1a@G64! zTF07NOYrw^5qV{$Ww2a7xp7Kf(@pa8*RSj&dNOxppHkS_y_@P7c;(2#J<tao>mhmh z(?rJ!d~*{G<d}y@H-T<}H$7Q6C7s+f--nRz5Aa#Mf@29#-p)||3D)HfZ4mh00WX4R zIcbnH>R0bFFM;Ye#{;3DM+mEIZg1>9tNYEM`Q!6?;BRl%m5T-!45%_r62`)KgJDZX z?JaIRJ=Up+w>T>_>pwKJUsz>hbG^A9H0m48t!;mzbI{BRnD6^g4h1XKzpH1dFpF_y zq*GH2(^N$*XdZ2xeKFQ-Zcn7^=Spl9Rzd`N5Vpnc&X&oIvS0<-Z->$c3v=JbHQCuR zRk<7Ljcz142GFduvHfh8*?lXq^7QbCh%HRTCp+s;r~b@4*Bf`&|JL7r;a45wXdydL z9EfjncnH9cpEIHsp??34YXcRH!c^2op{jNIk_)A4YX`NxU~Q!0!{p0OZ?)S!I6MsG z+JjbCt-{(%YR%dp8r+W(orY50UtN7L8jrphqB5gkBof|NwQd^AuVmD!rO@raWZkZ7 zydSR&#^yRy5YN3S(lC;`0C4oDzz8kTd8<N8R*5>aLW?v%k*P)U|2cLEEEVe6hfA{& zTDctS(nR5O;TUHVg`<Vt)*uQKRw*lXBBj&p7S1d+4@z|l8J1_lmSAVfkm1SH^J7ry zY;5V_;$;{!r}sf|EfEK4BZB5l_SEt;bp|5KpH*w-^T`DOSL-nIdLIPEL8wHM-N-uu zU;&;_T|T>z|4IR7PJY!jUJ&411c50ALEPs<iThFzyc~vdVo|s8ymye@MfMT0S^1|m zP#zeNbhe@1vS)jCruFef4T8=v9V&>g@M@He4Bu1Z9>j75+Ae!c44FI~3w}S@5$&PU c(MZhhFpKxD^u~KQ!T$)mNn<C?ThOHT|CMI7$N&HU literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..01b8a2b7d386d30fd419ceb72c56eb76ff121ac9 GIT binary patch literal 3532 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 Ds(6=$ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree_lxml.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree_lxml.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ef36fce66c2b4ba9454cbdec48420b04ca050106 GIT binary patch literal 6631 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/genshi.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/genshi.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c26c71e3a548ddfa14d7b35e630e802cf7398d78 GIT binary patch literal 1905 zcmZ`(&2Jk;6rY)0uh;9f<G4=Ri1MKx5I!^xm8evysv0F01rfJ22Fj{vwef6{jrYTu z9lK35duq>B&m2&5MB;$>1NcMciiFfV>VX6B-r9i(!K~)Z%x~Vj`R%-qFB%PpKzsA! zSx~7F@(V65HWL<iq316^aKdR!66(=}c`PwJgCfRaGpTr$a&Exf@~oulRTJB@lbTmc z9M38DOxUY?^~Ckuq~SG^rq@iCyrrb&wP3%(t#~<Udu^CkxgB3hI$kGP@m47LnD82R zo)hkb?W5IahPTS=yQJ&B22P}F=%rvU&*G^J{V17aLTZ~wvnY?URJW#SG|G7B$B_(0 z5a(U0E1wU7B<xmnWp}vwaHx&`U|TmH?R@4BHh22F4>q^@y1IRTYxwnpzBY&bN5ihA z?NZkt>}m_tajeggt?kX>rmi74pRxy^=<3$}ot^$*_?jX^s?EJ14_`A}FzwE=i1*_# z2~(MCCj~P3Bp8MH2><6|!vlAr=T||5#G{;ej8o2@6VKoVH(@k+1>VBa&QOHmS3x`u z#RzXbZ|K1abTpnn0>Mc^6*(f?<eLu)roiU7Ce{^sMHN--i~;TxhBCe+lpJ4Etf0rv zLTfnJ;^bdi_c#F#bO1kRN}!=FnT^9V@0!}o!+2lY6A{j$Y?|vzID_BTl~Un*BHji@ zzpLIvM6*DKy;&f7`&rCGk@s#r?H%~HW+FLFZ|om!93DPBJ@w;TH}?+32DF2;H|$NK z$@M7BWe~^LH#Tn0PG%oY5iGk8SMf~r4rLO56i0hK<o2X|qP%wi{0^h_$%(doAA`g9 z8~8+R5QLf3p*C$nw+tLlFa7hp>*x9-19caz38M|Yd}j$BQ1r1;7=>9>lp)EOiJz7E zm=#u0Rn`$LY>=#|MWk?472bRU_UeTz4ON%sGbSD?S2?PF#GuoCcAFfpBf^QQFIF{K z;dBix|DbGXjV&0-tE#Fg8%{EpOuki&vo#{^u~E*AHKMGsab}i2Zm34-<L}ZIoU6^x zot1u1e*(@nSbn3-lB<ba)%lG^{%d(-Rs04g9Xxr)&{ld1=jvnjl8PqmxXL`ECB6rE zqr`6j-b5TYxW$6QOL}}Qy#qQ+rOu}ipDks+Am!Qj0biC&vMn#kj$Dze`_-`pH}KR2 zTbGqFzoU#nbD&Lhx4;w-%OJW}gaw1H#n~u`G1+wO@08OHlnD%<bQB8A60w4!1H!Yz zWFk+7!GWljOVAP$mfC`-LbwI6u8y(<6Ioy#h3F5TN&$rwHh4CYCzDWMP>4DT7X=2H zz+e$eAar$_j??T(+HHz81m8l?Ou>vc$5G0)$paZ^>T5#=2VOOhQbc<>sKB3yYoP5d zkFs<Y3K??$e3y<joe8WOWrEGcJGi_80`JK0fgoj+LyW^`QWsWj)?^(Vsq=?zIIPX) zyB*qM4sBwm?qbFWe1F=E8K=t^vSXh51E{Z%Sjf`%wd4Cq#-}mPUEe>R&OPD#;$2`- zlDa??Yl0}*uEGpoEypTmQ@be;8FVkB#r>(A3a}`!ObX0JfofiTk=mn7ES!n~P<nCh z4D?Uwum5$++_ywvG0-)5UknkMmw_=45#;e-l(l_({-<{^0&^taVJ^K&-(xOo8GiwP CILtW! literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/base.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/base.py new file mode 100644 index 0000000..80c474c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/base.py @@ -0,0 +1,252 @@ +from __future__ import absolute_import, division, unicode_literals + +from xml.dom import Node +from ..constants import namespaces, voidElements, spaceCharacters + +__all__ = ["DOCUMENT", "DOCTYPE", "TEXT", "ELEMENT", "COMMENT", "ENTITY", "UNKNOWN", + "TreeWalker", "NonRecursiveTreeWalker"] + +DOCUMENT = Node.DOCUMENT_NODE +DOCTYPE = Node.DOCUMENT_TYPE_NODE +TEXT = Node.TEXT_NODE +ELEMENT = Node.ELEMENT_NODE +COMMENT = Node.COMMENT_NODE +ENTITY = Node.ENTITY_NODE +UNKNOWN = "<#UNKNOWN#>" + +spaceCharacters = "".join(spaceCharacters) + + +class TreeWalker(object): + """Walks a tree yielding tokens + + Tokens are dicts that all have a ``type`` field specifying the type of the + token. + + """ + def __init__(self, tree): + """Creates a TreeWalker + + :arg tree: the tree to walk + + """ + self.tree = tree + + def __iter__(self): + raise NotImplementedError + + def error(self, msg): + """Generates an error token with the given message + + :arg msg: the error message + + :returns: SerializeError token + + """ + return {"type": "SerializeError", "data": msg} + + def emptyTag(self, namespace, name, attrs, hasChildren=False): + """Generates an EmptyTag token + + :arg namespace: the namespace of the token--can be ``None`` + + :arg name: the name of the element + + :arg attrs: the attributes of the element as a dict + + :arg hasChildren: whether or not to yield a SerializationError because + this tag shouldn't have children + + :returns: EmptyTag token + + """ + yield {"type": "EmptyTag", "name": name, + "namespace": namespace, + "data": attrs} + if hasChildren: + yield self.error("Void element has children") + + def startTag(self, namespace, name, attrs): + """Generates a StartTag token + + :arg namespace: the namespace of the token--can be ``None`` + + :arg name: the name of the element + + :arg attrs: the attributes of the element as a dict + + :returns: StartTag token + + """ + return {"type": "StartTag", + "name": name, + "namespace": namespace, + "data": attrs} + + def endTag(self, namespace, name): + """Generates an EndTag token + + :arg namespace: the namespace of the token--can be ``None`` + + :arg name: the name of the element + + :returns: EndTag token + + """ + return {"type": "EndTag", + "name": name, + "namespace": namespace} + + def text(self, data): + """Generates SpaceCharacters and Characters tokens + + Depending on what's in the data, this generates one or more + ``SpaceCharacters`` and ``Characters`` tokens. + + For example: + + >>> from html5lib.treewalkers.base import TreeWalker + >>> # Give it an empty tree just so it instantiates + >>> walker = TreeWalker([]) + >>> list(walker.text('')) + [] + >>> list(walker.text(' ')) + [{u'data': ' ', u'type': u'SpaceCharacters'}] + >>> list(walker.text(' abc ')) # doctest: +NORMALIZE_WHITESPACE + [{u'data': ' ', u'type': u'SpaceCharacters'}, + {u'data': u'abc', u'type': u'Characters'}, + {u'data': u' ', u'type': u'SpaceCharacters'}] + + :arg data: the text data + + :returns: one or more ``SpaceCharacters`` and ``Characters`` tokens + + """ + data = data + middle = data.lstrip(spaceCharacters) + left = data[:len(data) - len(middle)] + if left: + yield {"type": "SpaceCharacters", "data": left} + data = middle + middle = data.rstrip(spaceCharacters) + right = data[len(middle):] + if middle: + yield {"type": "Characters", "data": middle} + if right: + yield {"type": "SpaceCharacters", "data": right} + + def comment(self, data): + """Generates a Comment token + + :arg data: the comment + + :returns: Comment token + + """ + return {"type": "Comment", "data": data} + + def doctype(self, name, publicId=None, systemId=None): + """Generates a Doctype token + + :arg name: + + :arg publicId: + + :arg systemId: + + :returns: the Doctype token + + """ + return {"type": "Doctype", + "name": name, + "publicId": publicId, + "systemId": systemId} + + def entity(self, name): + """Generates an Entity token + + :arg name: the entity name + + :returns: an Entity token + + """ + return {"type": "Entity", "name": name} + + def unknown(self, nodeType): + """Handles unknown node types""" + return self.error("Unknown node type: " + nodeType) + + +class NonRecursiveTreeWalker(TreeWalker): + def getNodeDetails(self, node): + raise NotImplementedError + + def getFirstChild(self, node): + raise NotImplementedError + + def getNextSibling(self, node): + raise NotImplementedError + + def getParentNode(self, node): + raise NotImplementedError + + def __iter__(self): + currentNode = self.tree + while currentNode is not None: + details = self.getNodeDetails(currentNode) + type, details = details[0], details[1:] + hasChildren = False + + if type == DOCTYPE: + yield self.doctype(*details) + + elif type == TEXT: + for token in self.text(*details): + yield token + + elif type == ELEMENT: + namespace, name, attributes, hasChildren = details + if (not namespace or namespace == namespaces["html"]) and name in voidElements: + for token in self.emptyTag(namespace, name, attributes, + hasChildren): + yield token + hasChildren = False + else: + yield self.startTag(namespace, name, attributes) + + elif type == COMMENT: + yield self.comment(details[0]) + + elif type == ENTITY: + yield self.entity(details[0]) + + elif type == DOCUMENT: + hasChildren = True + + else: + yield self.unknown(details[0]) + + if hasChildren: + firstChild = self.getFirstChild(currentNode) + else: + firstChild = None + + if firstChild is not None: + currentNode = firstChild + else: + while currentNode is not None: + details = self.getNodeDetails(currentNode) + type, details = details[0], details[1:] + if type == ELEMENT: + namespace, name, attributes, hasChildren = details + if (namespace and namespace != namespaces["html"]) or name not in voidElements: + yield self.endTag(namespace, name) + if self.tree is currentNode: + currentNode = None + break + nextSibling = self.getNextSibling(currentNode) + if nextSibling is not None: + currentNode = nextSibling + break + else: + currentNode = self.getParentNode(currentNode) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/dom.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/dom.py new file mode 100644 index 0000000..b0c89b0 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/dom.py @@ -0,0 +1,43 @@ +from __future__ import absolute_import, division, unicode_literals + +from xml.dom import Node + +from . import base + + +class TreeWalker(base.NonRecursiveTreeWalker): + def getNodeDetails(self, node): + if node.nodeType == Node.DOCUMENT_TYPE_NODE: + return base.DOCTYPE, node.name, node.publicId, node.systemId + + elif node.nodeType in (Node.TEXT_NODE, Node.CDATA_SECTION_NODE): + return base.TEXT, node.nodeValue + + elif node.nodeType == Node.ELEMENT_NODE: + attrs = {} + for attr in list(node.attributes.keys()): + attr = node.getAttributeNode(attr) + if attr.namespaceURI: + attrs[(attr.namespaceURI, attr.localName)] = attr.value + else: + attrs[(None, attr.name)] = attr.value + return (base.ELEMENT, node.namespaceURI, node.nodeName, + attrs, node.hasChildNodes()) + + elif node.nodeType == Node.COMMENT_NODE: + return base.COMMENT, node.nodeValue + + elif node.nodeType in (Node.DOCUMENT_NODE, Node.DOCUMENT_FRAGMENT_NODE): + return (base.DOCUMENT,) + + else: + return base.UNKNOWN, node.nodeType + + def getFirstChild(self, node): + return node.firstChild + + def getNextSibling(self, node): + return node.nextSibling + + def getParentNode(self, node): + return node.parentNode diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/etree.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/etree.py new file mode 100644 index 0000000..95fc0c1 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/etree.py @@ -0,0 +1,130 @@ +from __future__ import absolute_import, division, unicode_literals + +from collections import OrderedDict +import re + +from pip._vendor.six import string_types + +from . import base +from .._utils import moduleFactoryFactory + +tag_regexp = re.compile("{([^}]*)}(.*)") + + +def getETreeBuilder(ElementTreeImplementation): + ElementTree = ElementTreeImplementation + ElementTreeCommentType = ElementTree.Comment("asd").tag + + class TreeWalker(base.NonRecursiveTreeWalker): # pylint:disable=unused-variable + """Given the particular ElementTree representation, this implementation, + to avoid using recursion, returns "nodes" as tuples with the following + content: + + 1. The current element + + 2. The index of the element relative to its parent + + 3. A stack of ancestor elements + + 4. A flag "text", "tail" or None to indicate if the current node is a + text node; either the text or tail of the current element (1) + """ + def getNodeDetails(self, node): + if isinstance(node, tuple): # It might be the root Element + elt, _, _, flag = node + if flag in ("text", "tail"): + return base.TEXT, getattr(elt, flag) + else: + node = elt + + if not(hasattr(node, "tag")): + node = node.getroot() + + if node.tag in ("DOCUMENT_ROOT", "DOCUMENT_FRAGMENT"): + return (base.DOCUMENT,) + + elif node.tag == "<!DOCTYPE>": + return (base.DOCTYPE, node.text, + node.get("publicId"), node.get("systemId")) + + elif node.tag == ElementTreeCommentType: + return base.COMMENT, node.text + + else: + assert isinstance(node.tag, string_types), type(node.tag) + # This is assumed to be an ordinary element + match = tag_regexp.match(node.tag) + if match: + namespace, tag = match.groups() + else: + namespace = None + tag = node.tag + attrs = OrderedDict() + for name, value in list(node.attrib.items()): + match = tag_regexp.match(name) + if match: + attrs[(match.group(1), match.group(2))] = value + else: + attrs[(None, name)] = value + return (base.ELEMENT, namespace, tag, + attrs, len(node) or node.text) + + def getFirstChild(self, node): + if isinstance(node, tuple): + element, key, parents, flag = node + else: + element, key, parents, flag = node, None, [], None + + if flag in ("text", "tail"): + return None + else: + if element.text: + return element, key, parents, "text" + elif len(element): + parents.append(element) + return element[0], 0, parents, None + else: + return None + + def getNextSibling(self, node): + if isinstance(node, tuple): + element, key, parents, flag = node + else: + return None + + if flag == "text": + if len(element): + parents.append(element) + return element[0], 0, parents, None + else: + return None + else: + if element.tail and flag != "tail": + return element, key, parents, "tail" + elif key < len(parents[-1]) - 1: + return parents[-1][key + 1], key + 1, parents, None + else: + return None + + def getParentNode(self, node): + if isinstance(node, tuple): + element, key, parents, flag = node + else: + return None + + if flag == "text": + if not parents: + return element + else: + return element, key, parents, None + else: + parent = parents.pop() + if not parents: + return parent + else: + assert list(parents[-1]).count(parent) == 1 + return parent, list(parents[-1]).index(parent), parents, None + + return locals() + +getETreeModule = moduleFactoryFactory(getETreeBuilder) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py new file mode 100644 index 0000000..e81ddf3 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py @@ -0,0 +1,213 @@ +from __future__ import absolute_import, division, unicode_literals +from pip._vendor.six import text_type + +from lxml import etree +from ..treebuilders.etree import tag_regexp + +from . import base + +from .. import _ihatexml + + +def ensure_str(s): + if s is None: + return None + elif isinstance(s, text_type): + return s + else: + return s.decode("ascii", "strict") + + +class Root(object): + def __init__(self, et): + self.elementtree = et + self.children = [] + + try: + if et.docinfo.internalDTD: + self.children.append(Doctype(self, + ensure_str(et.docinfo.root_name), + ensure_str(et.docinfo.public_id), + ensure_str(et.docinfo.system_url))) + except AttributeError: + pass + + try: + node = et.getroot() + except AttributeError: + node = et + + while node.getprevious() is not None: + node = node.getprevious() + while node is not None: + self.children.append(node) + node = node.getnext() + + self.text = None + self.tail = None + + def __getitem__(self, key): + return self.children[key] + + def getnext(self): + return None + + def __len__(self): + return 1 + + +class Doctype(object): + def __init__(self, root_node, name, public_id, system_id): + self.root_node = root_node + self.name = name + self.public_id = public_id + self.system_id = system_id + + self.text = None + self.tail = None + + def getnext(self): + return self.root_node.children[1] + + +class FragmentRoot(Root): + def __init__(self, children): + self.children = [FragmentWrapper(self, child) for child in children] + self.text = self.tail = None + + def getnext(self): + return None + + +class FragmentWrapper(object): + def __init__(self, fragment_root, obj): + self.root_node = fragment_root + self.obj = obj + if hasattr(self.obj, 'text'): + self.text = ensure_str(self.obj.text) + else: + self.text = None + if hasattr(self.obj, 'tail'): + self.tail = ensure_str(self.obj.tail) + else: + self.tail = None + + def __getattr__(self, name): + return getattr(self.obj, name) + + def getnext(self): + siblings = self.root_node.children + idx = siblings.index(self) + if idx < len(siblings) - 1: + return siblings[idx + 1] + else: + return None + + def __getitem__(self, key): + return self.obj[key] + + def __bool__(self): + return bool(self.obj) + + def getparent(self): + return None + + def __str__(self): + return str(self.obj) + + def __unicode__(self): + return str(self.obj) + + def __len__(self): + return len(self.obj) + + +class TreeWalker(base.NonRecursiveTreeWalker): + def __init__(self, tree): + # pylint:disable=redefined-variable-type + if isinstance(tree, list): + self.fragmentChildren = set(tree) + tree = FragmentRoot(tree) + else: + self.fragmentChildren = set() + tree = Root(tree) + base.NonRecursiveTreeWalker.__init__(self, tree) + self.filter = _ihatexml.InfosetFilter() + + def getNodeDetails(self, node): + if isinstance(node, tuple): # Text node + node, key = node + assert key in ("text", "tail"), "Text nodes are text or tail, found %s" % key + return base.TEXT, ensure_str(getattr(node, key)) + + elif isinstance(node, Root): + return (base.DOCUMENT,) + + elif isinstance(node, Doctype): + return base.DOCTYPE, node.name, node.public_id, node.system_id + + elif isinstance(node, FragmentWrapper) and not hasattr(node, "tag"): + return base.TEXT, ensure_str(node.obj) + + elif node.tag == etree.Comment: + return base.COMMENT, ensure_str(node.text) + + elif node.tag == etree.Entity: + return base.ENTITY, ensure_str(node.text)[1:-1] # strip &; + + else: + # This is assumed to be an ordinary element + match = tag_regexp.match(ensure_str(node.tag)) + if match: + namespace, tag = match.groups() + else: + namespace = None + tag = ensure_str(node.tag) + attrs = {} + for name, value in list(node.attrib.items()): + name = ensure_str(name) + value = ensure_str(value) + match = tag_regexp.match(name) + if match: + attrs[(match.group(1), match.group(2))] = value + else: + attrs[(None, name)] = value + return (base.ELEMENT, namespace, self.filter.fromXmlName(tag), + attrs, len(node) > 0 or node.text) + + def getFirstChild(self, node): + assert not isinstance(node, tuple), "Text nodes have no children" + + assert len(node) or node.text, "Node has no children" + if node.text: + return (node, "text") + else: + return node[0] + + def getNextSibling(self, node): + if isinstance(node, tuple): # Text node + node, key = node + assert key in ("text", "tail"), "Text nodes are text or tail, found %s" % key + if key == "text": + # XXX: we cannot use a "bool(node) and node[0] or None" construct here + # because node[0] might evaluate to False if it has no child element + if len(node): + return node[0] + else: + return None + else: # tail + return node.getnext() + + return (node, "tail") if node.tail else node.getnext() + + def getParentNode(self, node): + if isinstance(node, tuple): # Text node + node, key = node + assert key in ("text", "tail"), "Text nodes are text or tail, found %s" % key + if key == "text": + return node + # else: fallback to "normal" processing + elif node in self.fragmentChildren: + return None + + return node.getparent() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py new file mode 100644 index 0000000..7483be2 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py @@ -0,0 +1,69 @@ +from __future__ import absolute_import, division, unicode_literals + +from genshi.core import QName +from genshi.core import START, END, XML_NAMESPACE, DOCTYPE, TEXT +from genshi.core import START_NS, END_NS, START_CDATA, END_CDATA, PI, COMMENT + +from . import base + +from ..constants import voidElements, namespaces + + +class TreeWalker(base.TreeWalker): + def __iter__(self): + # Buffer the events so we can pass in the following one + previous = None + for event in self.tree: + if previous is not None: + for token in self.tokens(previous, event): + yield token + previous = event + + # Don't forget the final event! + if previous is not None: + for token in self.tokens(previous, None): + yield token + + def tokens(self, event, next): + kind, data, _ = event + if kind == START: + tag, attribs = data + name = tag.localname + namespace = tag.namespace + converted_attribs = {} + for k, v in attribs: + if isinstance(k, QName): + converted_attribs[(k.namespace, k.localname)] = v + else: + converted_attribs[(None, k)] = v + + if namespace == namespaces["html"] and name in voidElements: + for token in self.emptyTag(namespace, name, converted_attribs, + not next or next[0] != END or + next[1] != tag): + yield token + else: + yield self.startTag(namespace, name, converted_attribs) + + elif kind == END: + name = data.localname + namespace = data.namespace + if namespace != namespaces["html"] or name not in voidElements: + yield self.endTag(namespace, name) + + elif kind == COMMENT: + yield self.comment(data) + + elif kind == TEXT: + for token in self.text(data): + yield token + + elif kind == DOCTYPE: + yield self.doctype(*data) + + elif kind in (XML_NAMESPACE, DOCTYPE, START_NS, END_NS, + START_CDATA, END_CDATA, PI): + pass + + else: + yield self.unknown(kind) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__init__.py new file mode 100644 index 0000000..847bf93 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__init__.py @@ -0,0 +1,2 @@ +from .package_data import __version__ +from .core import * diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..36c99f0607387c6dd7b980aff8cd4c55d4d4552a GIT binary patch literal 270 zcmYjLF-`+95VS85LXh-);gEt4ibxkl5ig)2G&Cy{J9j2N+uFNW$^C|sj`v(k#Rn*; zvQEWFGrO}Zjpk)Ky<&vluMfGP`JK#vWMm$R?G1@yid)w3SI*O(*=)_!=$Yl?A5QO_ z57z)uV{5zvAj@x`^3gB}a<h|_1|>U*DRCHYJnBz|7i7-z=R`mgWv4}yD7M}z$`R#3 zR8U52diSt>FY5Zx_h8HUTa5*wa$+rl2{Yr`PFg!Fig`T7`+Yi|Np+m^D2#Ga02pUF VfV*%UE|-m0d#hKed7Da2_zAqRNo)WB literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/codec.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/codec.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1bda20d9ad99a69a0c7360f02c7e978f6b6387fc GIT binary patch literal 2924 zcmb`JOOG2x5P+xW?OE?5CL|<;;N${E%6dU4VI>k4vJuL~hlGGMC>qVW+uqrX$4<?7 zNtSUG#W^9tZ}8sOTYdoi57gJ3a>@+}E>P8Duf2~D2^gzux~qG-y1Kur_MQ28Ps8W; zXS?C^vZg(!#_VHZV+~6>Lcul8Vy(k`*3o^vWB5kL^v#atTTJ6RH)7kj)!XqM;f!2v z?lQmhrN%98Kh?M`>@9C-_#SE;?xMy;%^YgVs3~y|H6Ci_QL})WIbKFhS&(jVX!?t& zo97FtTTr?s)GhHvzVuY{PjKV5Ry*;6;WBHMv_;bFav^Oligy@?8zPo=zj&8!t~Wlv z0nmjP_<`2wqwm_c%g-M_dHKsvFMr*=+a&euV_;(qOIk%CG@o(J*U=4h`ziAcj?Qum zYbLjGAth;DNBd1_rx`@etVy3w9;%yIu474;QRF&j_Y63d;VzC?uJ5uTd%|*-o+qy| zJ;!!tkZkF<wLP-|CH(5o>YXI*_j+B(1g{Emrn(s>JdTof_2Ty{gNu8*)WE@^H4|)n zNxRjBPMCpC4I>uGo*~Ut#4Ty^Fbi?pXqI$OgOg<7UcCp=c9@C!b_n%WH|7G;`s#yv zJ6PR@&Q9`CYinh5^TEze5U*a|*n|~)+DZMZdN1l-ijp)7<M`6b%H{2c+aLBxsY<Xd z65fS+#FMa2$J1QyJydHVw^9Y9?y?2lWTw7TRvWoo9O(bKk3fdTI|B<?2Ray7B(X$- z_Mi}NQjL1w!19U(7Nj+5OdZbTWl1*(lCUF!Kzc#Y>GFO|^>Ps0?}u^GqkJ!{Pi?B2 zGVG#JI>nTradpoF(loIgc<4~qu%z_mKB0{37#@ZS4^vidCQT3>k>JVPP$2?MnsxHf z0Z_;*G@oJRb!d(d%Uw1wxjC?M6TZ$d3eIThI=89Kt*cs6$&FO$uWB@cdfM8+=FY&$ z&2{bW2Lm^^M`mW_?hxl<TJFH(923M94M#YcO?s-|-{AJh$?aX1Tc>db)n^rbIkqS` zYNaALU=9}#6xA?~;>BP1NVcq^0aTK3RY<6VmrFrEiHO92ce6AAA+59*N13$4UJqdf z+9O4VG`G4@vR8r=q^Xb~CZyGhk`VKYN-wD_XAnjdh%}+JL8SdS!%&NMaB4N?5M6R1 z*yy)f0)hhc^Ehd`f<j}HNbnfO1GZGrZE8`3P=6tf1y*J|7mgnB^1-<q2>mIX8BUXU zi^O{*j$`i(cD#cnCAwS&)c()pt*fN`59IxZR$fP5jwx}d!^fF9vI+*1bI1xN$$?6i z+#Kr25*u0EQiLiZ;So~lAfYk06rs+TP^DLdKB68)sC$4=Cv#^A{TT@@jR`I76Z!+U zM&1EJOZj0!y~Bh`D@>bF1aG6)idHyFH46Cx)wvl|y(m?QHE9azjH!ilG?b1>8hGCT z!2=Y=MKXJrYE=@`6Q;y6Wv<9wpP?@O1jRmchR4c=%RJ_dNqZ%G`VscVhrG|;BtITu z?-ClES=lu2y^kH&uuRya_7V0dme*(y#ribsVJ6UJ`E~{(?0f@JCZMs0H!O~sp?<m@ zQ=@brw`smH@YMb{MsJA_Z_5VM$>ec{D7d#~3{m@tA<D<sX;2kKrfo6KGJU9R8A@W# z%<K%g<ob^edTcbLNtbHPktW?N(|bi$qG{qUG7KEh6{iETjQrr1eW$i;(n1aTf`4jk zbz7&hr0(RK3I3g+t7vLR<p-dH0@^qrr;hVp&b0*^YU4!&4?8$0rBte69@CkPKfU<< z0jsF3RixSM!i+mbK30U&{~EZ0Lh6{doo2Vwi(*kk1g%Y;{X*qc!H?!ewc29`jNv`( j39aT>cic~loBbN$sC+qxc^U6&y>hB@p;9|(oHYIhNPcWJ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..39aea1e6ec51729a941618a64371952d42343b77 GIT binary patch literal 642 zcma)4&2H2%5Vn&|Hw%;tFOch^7Ka`xRzirXaM(*OyS;E(r5U#y<k;548?`G=lo#Q+ zH=ZX~F7N^zI5CrIr3wj&k><}cw!hEgi^Ic5g5=k?ujLQ&-#K|G5hZU)+aod{KpL^U z_mX@B@fYzSf)OO-V>o~@`4OZGF`fLBv}G!L`Mlz2FC6o!=cH{)CWuesPA<ew7Sw&9 zZRJ4kWS^MwQk$K?F*W@*%46M?L94Drb>$3bY}M>WU9V;xHd}jg^)X+sZ?@Z&nVnv) zF(<jUYN>qfk89h8(wO5sKkaV2mm6Ljbk%7K4pj}dRF!Ld8D99?e!O&Ni}U$>#2^{1 zkT@axe@rl@R^|elxnM%+z~bI8>3*_w7q;dy)7#(inBsrm@r0^@W^gAzOAz$NQL#Om zzbnqNlRSTwfzxefUC1_}Hg&5rTQ=IG_L)Z)T;&X5dRDkFZ@kfswn4*tM2EC2+rI&( z``!FO_V}JsTuhUGR5{dr!tkr%VUUp{mmi$N%y3|vzHS_BjDEw@AEutlG)m(%{sT=m Bij4pO literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/core.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/core.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..754eddd9872a83cf73bdfa9b65bd678890f8e3c2 GIT binary patch literal 9058 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 $hL74a`~<CVUa-@FB?Bh%nA$6H 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 V(wt*E$J~PBIs2X6?m_p-{{tW6FeLy0 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/idnadata.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/idnadata.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..71cfb301041d137bc3af669799b861b01d707e32 GIT binary patch literal 21394 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 R)MP*J4($?ZN7~PO|0flKtcm~t literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/intranges.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/intranges.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8449cd53252b72a44e6758e63bf5f2f3ff91e58d GIT binary patch literal 1822 zcmZux%WE7r7?(6N>&@DRq-krL8Y)~UUT}8TE(Bbh2W?0p2Nx3eVj9Ndm3DXPS!pb3 z)(>XM!7cR9h>yMXpXp_;J^3H#p%?f2G=3#igEZ2o@1@`O_-TH=MPU5%=Xvs1gOI=R zaCa~`Jcns}un4kC1Qjf!yHo@s{FUr75s3!;12H3-@DIg3(Sm;@*c;NGP3}=bT0f){ zsd&P()H<#QJXKB(rLk*#oCwK_9EqzVoy$RyWhZT5wc{kqxGKi`(%@~T)sUM)*%lo7 zT3OjI9H_mctFOm-;UowfnHy=Pa*0c|LUA{ee4x#^wYq9uV%+)~mrAU+*LZ#2@aK&- z?{qrt4&ND}zseqgaTGl)r1h#+juOj{`IY)ss{FM!=`dAE<{$WM1$^Qz9ZUY>YNm&) zUwOaV?M~|gFeKZ3faGQX=41xu_b~16usBkZGdiV1GG&5J14kVz=^1=4$lLvCScZZv zkeYTt%&U@?;S#|W=}SbgMRLH*tHWiW1xTxJeq&2y8kOvQ;KDKz0mwvxBL4z8W9O6t z-!wQ}cEEE+A$DQ%1vvWp8p{6(9|tTTQWDTneTgueL=C0=w#8vwAszQTv~lkS>$nC# zM)VQxHExUk2!Kr72WWaN*Qvr2Be^_I`Yt;GE^Q@*;a1KEHBR}~6CiJ4Y~cU_=T<`; z(oV}Od+pt;RjIxfQs5J8s)pHZB3)$!-`e8eZ156wfs0Bz<aI@!N!#(-E-qnQU@#3X z?MBtG+Bhky$m382nN(FH$#YOq&Bp)|n2hVY$ZG<b2#X@FW^2(HPgSGFv1(-r+#Q+J z$%>}ce7`UTvbt9B2Ql}-?7zC3n{<*m*_|Y&JJ6Yc%Ia<&cZc!j#EehX#^9IUXmosf z8fTl2_eZ7&W2m}2-8{`7r3#?SvPZq%<H^Zny+ER$F_f&(rke_tbRi10OP&0rdU$h+ z2S$&*%h*Kh=dh4wlZNo!hi{QG`YBze4Q4)pn?ClE>w$ZmKJVvXQ$lBX3VHk;f!t%; z7aVB*fo)brKD<=`9(hu|JV1^nEMLO3UODyW4+;!J6TtL_5HK|K3|ID?46sQB+vXwA zGvvB_clj>3vP&y!J~9VU6!JETD<E-gcmehwyb!B8gy{{R!Uii_&@(n=j=qPQF4;Mo z22i8)AT--9sOxnRYWR%)%%&k!YgmGcfE-ZsvW%eGw^c}q3PtdSlvu~m6@WUaWpCsf zC<i@Yf_x%`Cq}1FUPvd+I8~771HK0#jQ98eB5$#SYOdkps!!ID#wNB`Z}&Pr!3_em z^RgXzkgLXi3QgEmv-LmD<iHt3!C+5o&r~5AF&Nvb;j=xif?V4wL{6xYbU1PqjX#F? z!EJg$pLa>Bz6KR_a<LYj3!0Eri!@|&kYbo@hNHbkH511|_v6?s!r5n>ceM5idG1)k eL@<~@RdZ{sMUly;m?#$WIGky+=4Z{I8U6>O2-z(F literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/package_data.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/package_data.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..a40d4f3012feccc08c7e31645e52554e0951afe5 GIT binary patch literal 224 zcmWIL<>g`kf^QoZCW->-#~=<eU<7g;fVh|gNTe`CF{CgCGiWkZF&pVw_-QiU;*O6m zOD!tS%+HIDU&&C!1XKkkeii8#6lInrmZa*JB^K$Y<>#aTmFZhn=%>e9mKEhz<r$@A z8DwNsR8__2Sehke6d3?PdY*oWenDn|Zf0I_Nn%cpu7QDBS!J1FDM%2EfwtwP<QM5@ orsO5+7bGTUC#I*yrzDmn>J?Pp;;_lhPbtkwwF9~OGY~TX0EW>%kpKVy literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/uts46data.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/__pycache__/uts46data.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..54325382a312d8fc8e6f6cd72065f585906dc56e GIT binary patch literal 174197 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/codec.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/codec.py new file mode 100644 index 0000000..98c65ea --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/codec.py @@ -0,0 +1,118 @@ +from .core import encode, decode, alabel, ulabel, IDNAError +import codecs +import re + +_unicode_dots_re = re.compile(u'[\u002e\u3002\uff0e\uff61]') + +class Codec(codecs.Codec): + + def encode(self, data, errors='strict'): + + if errors != 'strict': + raise IDNAError("Unsupported error handling \"{0}\"".format(errors)) + + if not data: + return "", 0 + + return encode(data), len(data) + + def decode(self, data, errors='strict'): + + if errors != 'strict': + raise IDNAError("Unsupported error handling \"{0}\"".format(errors)) + + if not data: + return u"", 0 + + return decode(data), len(data) + +class IncrementalEncoder(codecs.BufferedIncrementalEncoder): + def _buffer_encode(self, data, errors, final): + if errors != 'strict': + raise IDNAError("Unsupported error handling \"{0}\"".format(errors)) + + if not data: + return ("", 0) + + labels = _unicode_dots_re.split(data) + trailing_dot = u'' + if labels: + if not labels[-1]: + trailing_dot = '.' + del labels[-1] + elif not final: + # Keep potentially unfinished label until the next call + del labels[-1] + if labels: + trailing_dot = '.' + + result = [] + size = 0 + for label in labels: + result.append(alabel(label)) + if size: + size += 1 + size += len(label) + + # Join with U+002E + result = ".".join(result) + trailing_dot + size += len(trailing_dot) + return (result, size) + +class IncrementalDecoder(codecs.BufferedIncrementalDecoder): + def _buffer_decode(self, data, errors, final): + if errors != 'strict': + raise IDNAError("Unsupported error handling \"{0}\"".format(errors)) + + if not data: + return (u"", 0) + + # IDNA allows decoding to operate on Unicode strings, too. + if isinstance(data, unicode): + labels = _unicode_dots_re.split(data) + else: + # Must be ASCII string + data = str(data) + unicode(data, "ascii") + labels = data.split(".") + + trailing_dot = u'' + if labels: + if not labels[-1]: + trailing_dot = u'.' + del labels[-1] + elif not final: + # Keep potentially unfinished label until the next call + del labels[-1] + if labels: + trailing_dot = u'.' + + result = [] + size = 0 + for label in labels: + result.append(ulabel(label)) + if size: + size += 1 + size += len(label) + + result = u".".join(result) + trailing_dot + size += len(trailing_dot) + return (result, size) + + +class StreamWriter(Codec, codecs.StreamWriter): + pass + +class StreamReader(Codec, codecs.StreamReader): + pass + +def getregentry(): + return codecs.CodecInfo( + name='idna', + encode=Codec().encode, + decode=Codec().decode, + incrementalencoder=IncrementalEncoder, + incrementaldecoder=IncrementalDecoder, + streamwriter=StreamWriter, + streamreader=StreamReader, + ) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/compat.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/compat.py new file mode 100644 index 0000000..4d47f33 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/compat.py @@ -0,0 +1,12 @@ +from .core import * +from .codec import * + +def ToASCII(label): + return encode(label) + +def ToUnicode(label): + return decode(label) + +def nameprep(s): + raise NotImplementedError("IDNA 2008 does not utilise nameprep protocol") + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/core.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/core.py new file mode 100644 index 0000000..104624a --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/core.py @@ -0,0 +1,396 @@ +from . import idnadata +import bisect +import unicodedata +import re +import sys +from .intranges import intranges_contain + +_virama_combining_class = 9 +_alabel_prefix = b'xn--' +_unicode_dots_re = re.compile(u'[\u002e\u3002\uff0e\uff61]') + +if sys.version_info[0] == 3: + unicode = str + unichr = chr + +class IDNAError(UnicodeError): + """ Base exception for all IDNA-encoding related problems """ + pass + + +class IDNABidiError(IDNAError): + """ Exception when bidirectional requirements are not satisfied """ + pass + + +class InvalidCodepoint(IDNAError): + """ Exception when a disallowed or unallocated codepoint is used """ + pass + + +class InvalidCodepointContext(IDNAError): + """ Exception when the codepoint is not valid in the context it is used """ + pass + + +def _combining_class(cp): + v = unicodedata.combining(unichr(cp)) + if v == 0: + if not unicodedata.name(unichr(cp)): + raise ValueError("Unknown character in unicodedata") + return v + +def _is_script(cp, script): + return intranges_contain(ord(cp), idnadata.scripts[script]) + +def _punycode(s): + return s.encode('punycode') + +def _unot(s): + return 'U+{0:04X}'.format(s) + + +def valid_label_length(label): + + if len(label) > 63: + return False + return True + + +def valid_string_length(label, trailing_dot): + + if len(label) > (254 if trailing_dot else 253): + return False + return True + + +def check_bidi(label, check_ltr=False): + + # Bidi rules should only be applied if string contains RTL characters + bidi_label = False + for (idx, cp) in enumerate(label, 1): + direction = unicodedata.bidirectional(cp) + if direction == '': + # String likely comes from a newer version of Unicode + raise IDNABidiError('Unknown directionality in label {0} at position {1}'.format(repr(label), idx)) + if direction in ['R', 'AL', 'AN']: + bidi_label = True + if not bidi_label and not check_ltr: + return True + + # Bidi rule 1 + direction = unicodedata.bidirectional(label[0]) + if direction in ['R', 'AL']: + rtl = True + elif direction == 'L': + rtl = False + else: + raise IDNABidiError('First codepoint in label {0} must be directionality L, R or AL'.format(repr(label))) + + valid_ending = False + number_type = False + for (idx, cp) in enumerate(label, 1): + direction = unicodedata.bidirectional(cp) + + if rtl: + # Bidi rule 2 + if not direction in ['R', 'AL', 'AN', 'EN', 'ES', 'CS', 'ET', 'ON', 'BN', 'NSM']: + raise IDNABidiError('Invalid direction for codepoint at position {0} in a right-to-left label'.format(idx)) + # Bidi rule 3 + if direction in ['R', 'AL', 'EN', 'AN']: + valid_ending = True + elif direction != 'NSM': + valid_ending = False + # Bidi rule 4 + if direction in ['AN', 'EN']: + if not number_type: + number_type = direction + else: + if number_type != direction: + raise IDNABidiError('Can not mix numeral types in a right-to-left label') + else: + # Bidi rule 5 + if not direction in ['L', 'EN', 'ES', 'CS', 'ET', 'ON', 'BN', 'NSM']: + raise IDNABidiError('Invalid direction for codepoint at position {0} in a left-to-right label'.format(idx)) + # Bidi rule 6 + if direction in ['L', 'EN']: + valid_ending = True + elif direction != 'NSM': + valid_ending = False + + if not valid_ending: + raise IDNABidiError('Label ends with illegal codepoint directionality') + + return True + + +def check_initial_combiner(label): + + if unicodedata.category(label[0])[0] == 'M': + raise IDNAError('Label begins with an illegal combining character') + return True + + +def check_hyphen_ok(label): + + if label[2:4] == '--': + raise IDNAError('Label has disallowed hyphens in 3rd and 4th position') + if label[0] == '-' or label[-1] == '-': + raise IDNAError('Label must not start or end with a hyphen') + return True + + +def check_nfc(label): + + if unicodedata.normalize('NFC', label) != label: + raise IDNAError('Label must be in Normalization Form C') + + +def valid_contextj(label, pos): + + cp_value = ord(label[pos]) + + if cp_value == 0x200c: + + if pos > 0: + if _combining_class(ord(label[pos - 1])) == _virama_combining_class: + return True + + ok = False + for i in range(pos-1, -1, -1): + joining_type = idnadata.joining_types.get(ord(label[i])) + if joining_type == ord('T'): + continue + if joining_type in [ord('L'), ord('D')]: + ok = True + break + + if not ok: + return False + + ok = False + for i in range(pos+1, len(label)): + joining_type = idnadata.joining_types.get(ord(label[i])) + if joining_type == ord('T'): + continue + if joining_type in [ord('R'), ord('D')]: + ok = True + break + return ok + + if cp_value == 0x200d: + + if pos > 0: + if _combining_class(ord(label[pos - 1])) == _virama_combining_class: + return True + return False + + else: + + return False + + +def valid_contexto(label, pos, exception=False): + + cp_value = ord(label[pos]) + + if cp_value == 0x00b7: + if 0 < pos < len(label)-1: + if ord(label[pos - 1]) == 0x006c and ord(label[pos + 1]) == 0x006c: + return True + return False + + elif cp_value == 0x0375: + if pos < len(label)-1 and len(label) > 1: + return _is_script(label[pos + 1], 'Greek') + return False + + elif cp_value == 0x05f3 or cp_value == 0x05f4: + if pos > 0: + return _is_script(label[pos - 1], 'Hebrew') + return False + + elif cp_value == 0x30fb: + for cp in label: + if cp == u'\u30fb': + continue + if _is_script(cp, 'Hiragana') or _is_script(cp, 'Katakana') or _is_script(cp, 'Han'): + return True + return False + + elif 0x660 <= cp_value <= 0x669: + for cp in label: + if 0x6f0 <= ord(cp) <= 0x06f9: + return False + return True + + elif 0x6f0 <= cp_value <= 0x6f9: + for cp in label: + if 0x660 <= ord(cp) <= 0x0669: + return False + return True + + +def check_label(label): + + if isinstance(label, (bytes, bytearray)): + label = label.decode('utf-8') + if len(label) == 0: + raise IDNAError('Empty Label') + + check_nfc(label) + check_hyphen_ok(label) + check_initial_combiner(label) + + for (pos, cp) in enumerate(label): + cp_value = ord(cp) + if intranges_contain(cp_value, idnadata.codepoint_classes['PVALID']): + continue + elif intranges_contain(cp_value, idnadata.codepoint_classes['CONTEXTJ']): + try: + if not valid_contextj(label, pos): + raise InvalidCodepointContext('Joiner {0} not allowed at position {1} in {2}'.format( + _unot(cp_value), pos+1, repr(label))) + except ValueError: + raise IDNAError('Unknown codepoint adjacent to joiner {0} at position {1} in {2}'.format( + _unot(cp_value), pos+1, repr(label))) + elif intranges_contain(cp_value, idnadata.codepoint_classes['CONTEXTO']): + if not valid_contexto(label, pos): + raise InvalidCodepointContext('Codepoint {0} not allowed at position {1} in {2}'.format(_unot(cp_value), pos+1, repr(label))) + else: + raise InvalidCodepoint('Codepoint {0} at position {1} of {2} not allowed'.format(_unot(cp_value), pos+1, repr(label))) + + check_bidi(label) + + +def alabel(label): + + try: + label = label.encode('ascii') + ulabel(label) + if not valid_label_length(label): + raise IDNAError('Label too long') + return label + except UnicodeEncodeError: + pass + + if not label: + raise IDNAError('No Input') + + label = unicode(label) + check_label(label) + label = _punycode(label) + label = _alabel_prefix + label + + if not valid_label_length(label): + raise IDNAError('Label too long') + + return label + + +def ulabel(label): + + if not isinstance(label, (bytes, bytearray)): + try: + label = label.encode('ascii') + except UnicodeEncodeError: + check_label(label) + return label + + label = label.lower() + if label.startswith(_alabel_prefix): + label = label[len(_alabel_prefix):] + else: + check_label(label) + return label.decode('ascii') + + label = label.decode('punycode') + check_label(label) + return label + + +def uts46_remap(domain, std3_rules=True, transitional=False): + """Re-map the characters in the string according to UTS46 processing.""" + from .uts46data import uts46data + output = u"" + try: + for pos, char in enumerate(domain): + code_point = ord(char) + uts46row = uts46data[code_point if code_point < 256 else + bisect.bisect_left(uts46data, (code_point, "Z")) - 1] + status = uts46row[1] + replacement = uts46row[2] if len(uts46row) == 3 else None + if (status == "V" or + (status == "D" and not transitional) or + (status == "3" and not std3_rules and replacement is None)): + output += char + elif replacement is not None and (status == "M" or + (status == "3" and not std3_rules) or + (status == "D" and transitional)): + output += replacement + elif status != "I": + raise IndexError() + return unicodedata.normalize("NFC", output) + except IndexError: + raise InvalidCodepoint( + "Codepoint {0} not allowed at position {1} in {2}".format( + _unot(code_point), pos + 1, repr(domain))) + + +def encode(s, strict=False, uts46=False, std3_rules=False, transitional=False): + + if isinstance(s, (bytes, bytearray)): + s = s.decode("ascii") + if uts46: + s = uts46_remap(s, std3_rules, transitional) + trailing_dot = False + result = [] + if strict: + labels = s.split('.') + else: + labels = _unicode_dots_re.split(s) + if not labels or labels == ['']: + raise IDNAError('Empty domain') + if labels[-1] == '': + del labels[-1] + trailing_dot = True + for label in labels: + s = alabel(label) + if s: + result.append(s) + else: + raise IDNAError('Empty label') + if trailing_dot: + result.append(b'') + s = b'.'.join(result) + if not valid_string_length(s, trailing_dot): + raise IDNAError('Domain too long') + return s + + +def decode(s, strict=False, uts46=False, std3_rules=False): + + if isinstance(s, (bytes, bytearray)): + s = s.decode("ascii") + if uts46: + s = uts46_remap(s, std3_rules, False) + trailing_dot = False + result = [] + if not strict: + labels = _unicode_dots_re.split(s) + else: + labels = s.split(u'.') + if not labels or labels == ['']: + raise IDNAError('Empty domain') + if not labels[-1]: + del labels[-1] + trailing_dot = True + for label in labels: + s = ulabel(label) + if s: + result.append(s) + else: + raise IDNAError('Empty label') + if trailing_dot: + result.append(u'') + return u'.'.join(result) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/idnadata.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/idnadata.py new file mode 100644 index 0000000..a80c959 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/idnadata.py @@ -0,0 +1,1979 @@ +# This file is automatically generated by tools/idna-data + +__version__ = "11.0.0" +scripts = { + 'Greek': ( + 0x37000000374, + 0x37500000378, + 0x37a0000037e, + 0x37f00000380, + 0x38400000385, + 0x38600000387, + 0x3880000038b, + 0x38c0000038d, + 0x38e000003a2, + 0x3a3000003e2, + 0x3f000000400, + 0x1d2600001d2b, + 0x1d5d00001d62, + 0x1d6600001d6b, + 0x1dbf00001dc0, + 0x1f0000001f16, + 0x1f1800001f1e, + 0x1f2000001f46, + 0x1f4800001f4e, + 0x1f5000001f58, + 0x1f5900001f5a, + 0x1f5b00001f5c, + 0x1f5d00001f5e, + 0x1f5f00001f7e, + 0x1f8000001fb5, + 0x1fb600001fc5, + 0x1fc600001fd4, + 0x1fd600001fdc, + 0x1fdd00001ff0, + 0x1ff200001ff5, + 0x1ff600001fff, + 0x212600002127, + 0xab650000ab66, + 0x101400001018f, + 0x101a0000101a1, + 0x1d2000001d246, + ), + 'Han': ( + 0x2e8000002e9a, + 0x2e9b00002ef4, + 0x2f0000002fd6, + 0x300500003006, + 0x300700003008, + 0x30210000302a, + 0x30380000303c, + 0x340000004db6, + 0x4e0000009ff0, + 0xf9000000fa6e, + 0xfa700000fada, + 0x200000002a6d7, + 0x2a7000002b735, + 0x2b7400002b81e, + 0x2b8200002cea2, + 0x2ceb00002ebe1, + 0x2f8000002fa1e, + ), + 'Hebrew': ( + 0x591000005c8, + 0x5d0000005eb, + 0x5ef000005f5, + 0xfb1d0000fb37, + 0xfb380000fb3d, + 0xfb3e0000fb3f, + 0xfb400000fb42, + 0xfb430000fb45, + 0xfb460000fb50, + ), + 'Hiragana': ( + 0x304100003097, + 0x309d000030a0, + 0x1b0010001b11f, + 0x1f2000001f201, + ), + 'Katakana': ( + 0x30a1000030fb, + 0x30fd00003100, + 0x31f000003200, + 0x32d0000032ff, + 0x330000003358, + 0xff660000ff70, + 0xff710000ff9e, + 0x1b0000001b001, + ), +} +joining_types = { + 0x600: 85, + 0x601: 85, + 0x602: 85, + 0x603: 85, + 0x604: 85, + 0x605: 85, + 0x608: 85, + 0x60b: 85, + 0x620: 68, + 0x621: 85, + 0x622: 82, + 0x623: 82, + 0x624: 82, + 0x625: 82, + 0x626: 68, + 0x627: 82, + 0x628: 68, + 0x629: 82, + 0x62a: 68, + 0x62b: 68, + 0x62c: 68, + 0x62d: 68, + 0x62e: 68, + 0x62f: 82, + 0x630: 82, + 0x631: 82, + 0x632: 82, + 0x633: 68, + 0x634: 68, + 0x635: 68, + 0x636: 68, + 0x637: 68, + 0x638: 68, + 0x639: 68, + 0x63a: 68, + 0x63b: 68, + 0x63c: 68, + 0x63d: 68, + 0x63e: 68, + 0x63f: 68, + 0x640: 67, + 0x641: 68, + 0x642: 68, + 0x643: 68, + 0x644: 68, + 0x645: 68, + 0x646: 68, + 0x647: 68, + 0x648: 82, + 0x649: 68, + 0x64a: 68, + 0x66e: 68, + 0x66f: 68, + 0x671: 82, + 0x672: 82, + 0x673: 82, + 0x674: 85, + 0x675: 82, + 0x676: 82, + 0x677: 82, + 0x678: 68, + 0x679: 68, + 0x67a: 68, + 0x67b: 68, + 0x67c: 68, + 0x67d: 68, + 0x67e: 68, + 0x67f: 68, + 0x680: 68, + 0x681: 68, + 0x682: 68, + 0x683: 68, + 0x684: 68, + 0x685: 68, + 0x686: 68, + 0x687: 68, + 0x688: 82, + 0x689: 82, + 0x68a: 82, + 0x68b: 82, + 0x68c: 82, + 0x68d: 82, + 0x68e: 82, + 0x68f: 82, + 0x690: 82, + 0x691: 82, + 0x692: 82, + 0x693: 82, + 0x694: 82, + 0x695: 82, + 0x696: 82, + 0x697: 82, + 0x698: 82, + 0x699: 82, + 0x69a: 68, + 0x69b: 68, + 0x69c: 68, + 0x69d: 68, + 0x69e: 68, + 0x69f: 68, + 0x6a0: 68, + 0x6a1: 68, + 0x6a2: 68, + 0x6a3: 68, + 0x6a4: 68, + 0x6a5: 68, + 0x6a6: 68, + 0x6a7: 68, + 0x6a8: 68, + 0x6a9: 68, + 0x6aa: 68, + 0x6ab: 68, + 0x6ac: 68, + 0x6ad: 68, + 0x6ae: 68, + 0x6af: 68, + 0x6b0: 68, + 0x6b1: 68, + 0x6b2: 68, + 0x6b3: 68, + 0x6b4: 68, + 0x6b5: 68, + 0x6b6: 68, + 0x6b7: 68, + 0x6b8: 68, + 0x6b9: 68, + 0x6ba: 68, + 0x6bb: 68, + 0x6bc: 68, + 0x6bd: 68, + 0x6be: 68, + 0x6bf: 68, + 0x6c0: 82, + 0x6c1: 68, + 0x6c2: 68, + 0x6c3: 82, + 0x6c4: 82, + 0x6c5: 82, + 0x6c6: 82, + 0x6c7: 82, + 0x6c8: 82, + 0x6c9: 82, + 0x6ca: 82, + 0x6cb: 82, + 0x6cc: 68, + 0x6cd: 82, + 0x6ce: 68, + 0x6cf: 82, + 0x6d0: 68, + 0x6d1: 68, + 0x6d2: 82, + 0x6d3: 82, + 0x6d5: 82, + 0x6dd: 85, + 0x6ee: 82, + 0x6ef: 82, + 0x6fa: 68, + 0x6fb: 68, + 0x6fc: 68, + 0x6ff: 68, + 0x70f: 84, + 0x710: 82, + 0x712: 68, + 0x713: 68, + 0x714: 68, + 0x715: 82, + 0x716: 82, + 0x717: 82, + 0x718: 82, + 0x719: 82, + 0x71a: 68, + 0x71b: 68, + 0x71c: 68, + 0x71d: 68, + 0x71e: 82, + 0x71f: 68, + 0x720: 68, + 0x721: 68, + 0x722: 68, + 0x723: 68, + 0x724: 68, + 0x725: 68, + 0x726: 68, + 0x727: 68, + 0x728: 82, + 0x729: 68, + 0x72a: 82, + 0x72b: 68, + 0x72c: 82, + 0x72d: 68, + 0x72e: 68, + 0x72f: 82, + 0x74d: 82, + 0x74e: 68, + 0x74f: 68, + 0x750: 68, + 0x751: 68, + 0x752: 68, + 0x753: 68, + 0x754: 68, + 0x755: 68, + 0x756: 68, + 0x757: 68, + 0x758: 68, + 0x759: 82, + 0x75a: 82, + 0x75b: 82, + 0x75c: 68, + 0x75d: 68, + 0x75e: 68, + 0x75f: 68, + 0x760: 68, + 0x761: 68, + 0x762: 68, + 0x763: 68, + 0x764: 68, + 0x765: 68, + 0x766: 68, + 0x767: 68, + 0x768: 68, + 0x769: 68, + 0x76a: 68, + 0x76b: 82, + 0x76c: 82, + 0x76d: 68, + 0x76e: 68, + 0x76f: 68, + 0x770: 68, + 0x771: 82, + 0x772: 68, + 0x773: 82, + 0x774: 82, + 0x775: 68, + 0x776: 68, + 0x777: 68, + 0x778: 82, + 0x779: 82, + 0x77a: 68, + 0x77b: 68, + 0x77c: 68, + 0x77d: 68, + 0x77e: 68, + 0x77f: 68, + 0x7ca: 68, + 0x7cb: 68, + 0x7cc: 68, + 0x7cd: 68, + 0x7ce: 68, + 0x7cf: 68, + 0x7d0: 68, + 0x7d1: 68, + 0x7d2: 68, + 0x7d3: 68, + 0x7d4: 68, + 0x7d5: 68, + 0x7d6: 68, + 0x7d7: 68, + 0x7d8: 68, + 0x7d9: 68, + 0x7da: 68, + 0x7db: 68, + 0x7dc: 68, + 0x7dd: 68, + 0x7de: 68, + 0x7df: 68, + 0x7e0: 68, + 0x7e1: 68, + 0x7e2: 68, + 0x7e3: 68, + 0x7e4: 68, + 0x7e5: 68, + 0x7e6: 68, + 0x7e7: 68, + 0x7e8: 68, + 0x7e9: 68, + 0x7ea: 68, + 0x7fa: 67, + 0x840: 82, + 0x841: 68, + 0x842: 68, + 0x843: 68, + 0x844: 68, + 0x845: 68, + 0x846: 82, + 0x847: 82, + 0x848: 68, + 0x849: 82, + 0x84a: 68, + 0x84b: 68, + 0x84c: 68, + 0x84d: 68, + 0x84e: 68, + 0x84f: 68, + 0x850: 68, + 0x851: 68, + 0x852: 68, + 0x853: 68, + 0x854: 82, + 0x855: 68, + 0x856: 85, + 0x857: 85, + 0x858: 85, + 0x860: 68, + 0x861: 85, + 0x862: 68, + 0x863: 68, + 0x864: 68, + 0x865: 68, + 0x866: 85, + 0x867: 82, + 0x868: 68, + 0x869: 82, + 0x86a: 82, + 0x8a0: 68, + 0x8a1: 68, + 0x8a2: 68, + 0x8a3: 68, + 0x8a4: 68, + 0x8a5: 68, + 0x8a6: 68, + 0x8a7: 68, + 0x8a8: 68, + 0x8a9: 68, + 0x8aa: 82, + 0x8ab: 82, + 0x8ac: 82, + 0x8ad: 85, + 0x8ae: 82, + 0x8af: 68, + 0x8b0: 68, + 0x8b1: 82, + 0x8b2: 82, + 0x8b3: 68, + 0x8b4: 68, + 0x8b6: 68, + 0x8b7: 68, + 0x8b8: 68, + 0x8b9: 82, + 0x8ba: 68, + 0x8bb: 68, + 0x8bc: 68, + 0x8bd: 68, + 0x8e2: 85, + 0x1806: 85, + 0x1807: 68, + 0x180a: 67, + 0x180e: 85, + 0x1820: 68, + 0x1821: 68, + 0x1822: 68, + 0x1823: 68, + 0x1824: 68, + 0x1825: 68, + 0x1826: 68, + 0x1827: 68, + 0x1828: 68, + 0x1829: 68, + 0x182a: 68, + 0x182b: 68, + 0x182c: 68, + 0x182d: 68, + 0x182e: 68, + 0x182f: 68, + 0x1830: 68, + 0x1831: 68, + 0x1832: 68, + 0x1833: 68, + 0x1834: 68, + 0x1835: 68, + 0x1836: 68, + 0x1837: 68, + 0x1838: 68, + 0x1839: 68, + 0x183a: 68, + 0x183b: 68, + 0x183c: 68, + 0x183d: 68, + 0x183e: 68, + 0x183f: 68, + 0x1840: 68, + 0x1841: 68, + 0x1842: 68, + 0x1843: 68, + 0x1844: 68, + 0x1845: 68, + 0x1846: 68, + 0x1847: 68, + 0x1848: 68, + 0x1849: 68, + 0x184a: 68, + 0x184b: 68, + 0x184c: 68, + 0x184d: 68, + 0x184e: 68, + 0x184f: 68, + 0x1850: 68, + 0x1851: 68, + 0x1852: 68, + 0x1853: 68, + 0x1854: 68, + 0x1855: 68, + 0x1856: 68, + 0x1857: 68, + 0x1858: 68, + 0x1859: 68, + 0x185a: 68, + 0x185b: 68, + 0x185c: 68, + 0x185d: 68, + 0x185e: 68, + 0x185f: 68, + 0x1860: 68, + 0x1861: 68, + 0x1862: 68, + 0x1863: 68, + 0x1864: 68, + 0x1865: 68, + 0x1866: 68, + 0x1867: 68, + 0x1868: 68, + 0x1869: 68, + 0x186a: 68, + 0x186b: 68, + 0x186c: 68, + 0x186d: 68, + 0x186e: 68, + 0x186f: 68, + 0x1870: 68, + 0x1871: 68, + 0x1872: 68, + 0x1873: 68, + 0x1874: 68, + 0x1875: 68, + 0x1876: 68, + 0x1877: 68, + 0x1878: 68, + 0x1880: 85, + 0x1881: 85, + 0x1882: 85, + 0x1883: 85, + 0x1884: 85, + 0x1885: 84, + 0x1886: 84, + 0x1887: 68, + 0x1888: 68, + 0x1889: 68, + 0x188a: 68, + 0x188b: 68, + 0x188c: 68, + 0x188d: 68, + 0x188e: 68, + 0x188f: 68, + 0x1890: 68, + 0x1891: 68, + 0x1892: 68, + 0x1893: 68, + 0x1894: 68, + 0x1895: 68, + 0x1896: 68, + 0x1897: 68, + 0x1898: 68, + 0x1899: 68, + 0x189a: 68, + 0x189b: 68, + 0x189c: 68, + 0x189d: 68, + 0x189e: 68, + 0x189f: 68, + 0x18a0: 68, + 0x18a1: 68, + 0x18a2: 68, + 0x18a3: 68, + 0x18a4: 68, + 0x18a5: 68, + 0x18a6: 68, + 0x18a7: 68, + 0x18a8: 68, + 0x18aa: 68, + 0x200c: 85, + 0x200d: 67, + 0x202f: 85, + 0x2066: 85, + 0x2067: 85, + 0x2068: 85, + 0x2069: 85, + 0xa840: 68, + 0xa841: 68, + 0xa842: 68, + 0xa843: 68, + 0xa844: 68, + 0xa845: 68, + 0xa846: 68, + 0xa847: 68, + 0xa848: 68, + 0xa849: 68, + 0xa84a: 68, + 0xa84b: 68, + 0xa84c: 68, + 0xa84d: 68, + 0xa84e: 68, + 0xa84f: 68, + 0xa850: 68, + 0xa851: 68, + 0xa852: 68, + 0xa853: 68, + 0xa854: 68, + 0xa855: 68, + 0xa856: 68, + 0xa857: 68, + 0xa858: 68, + 0xa859: 68, + 0xa85a: 68, + 0xa85b: 68, + 0xa85c: 68, + 0xa85d: 68, + 0xa85e: 68, + 0xa85f: 68, + 0xa860: 68, + 0xa861: 68, + 0xa862: 68, + 0xa863: 68, + 0xa864: 68, + 0xa865: 68, + 0xa866: 68, + 0xa867: 68, + 0xa868: 68, + 0xa869: 68, + 0xa86a: 68, + 0xa86b: 68, + 0xa86c: 68, + 0xa86d: 68, + 0xa86e: 68, + 0xa86f: 68, + 0xa870: 68, + 0xa871: 68, + 0xa872: 76, + 0xa873: 85, + 0x10ac0: 68, + 0x10ac1: 68, + 0x10ac2: 68, + 0x10ac3: 68, + 0x10ac4: 68, + 0x10ac5: 82, + 0x10ac6: 85, + 0x10ac7: 82, + 0x10ac8: 85, + 0x10ac9: 82, + 0x10aca: 82, + 0x10acb: 85, + 0x10acc: 85, + 0x10acd: 76, + 0x10ace: 82, + 0x10acf: 82, + 0x10ad0: 82, + 0x10ad1: 82, + 0x10ad2: 82, + 0x10ad3: 68, + 0x10ad4: 68, + 0x10ad5: 68, + 0x10ad6: 68, + 0x10ad7: 76, + 0x10ad8: 68, + 0x10ad9: 68, + 0x10ada: 68, + 0x10adb: 68, + 0x10adc: 68, + 0x10add: 82, + 0x10ade: 68, + 0x10adf: 68, + 0x10ae0: 68, + 0x10ae1: 82, + 0x10ae2: 85, + 0x10ae3: 85, + 0x10ae4: 82, + 0x10aeb: 68, + 0x10aec: 68, + 0x10aed: 68, + 0x10aee: 68, + 0x10aef: 82, + 0x10b80: 68, + 0x10b81: 82, + 0x10b82: 68, + 0x10b83: 82, + 0x10b84: 82, + 0x10b85: 82, + 0x10b86: 68, + 0x10b87: 68, + 0x10b88: 68, + 0x10b89: 82, + 0x10b8a: 68, + 0x10b8b: 68, + 0x10b8c: 82, + 0x10b8d: 68, + 0x10b8e: 82, + 0x10b8f: 82, + 0x10b90: 68, + 0x10b91: 82, + 0x10ba9: 82, + 0x10baa: 82, + 0x10bab: 82, + 0x10bac: 82, + 0x10bad: 68, + 0x10bae: 68, + 0x10baf: 85, + 0x10d00: 76, + 0x10d01: 68, + 0x10d02: 68, + 0x10d03: 68, + 0x10d04: 68, + 0x10d05: 68, + 0x10d06: 68, + 0x10d07: 68, + 0x10d08: 68, + 0x10d09: 68, + 0x10d0a: 68, + 0x10d0b: 68, + 0x10d0c: 68, + 0x10d0d: 68, + 0x10d0e: 68, + 0x10d0f: 68, + 0x10d10: 68, + 0x10d11: 68, + 0x10d12: 68, + 0x10d13: 68, + 0x10d14: 68, + 0x10d15: 68, + 0x10d16: 68, + 0x10d17: 68, + 0x10d18: 68, + 0x10d19: 68, + 0x10d1a: 68, + 0x10d1b: 68, + 0x10d1c: 68, + 0x10d1d: 68, + 0x10d1e: 68, + 0x10d1f: 68, + 0x10d20: 68, + 0x10d21: 68, + 0x10d22: 82, + 0x10d23: 68, + 0x10f30: 68, + 0x10f31: 68, + 0x10f32: 68, + 0x10f33: 82, + 0x10f34: 68, + 0x10f35: 68, + 0x10f36: 68, + 0x10f37: 68, + 0x10f38: 68, + 0x10f39: 68, + 0x10f3a: 68, + 0x10f3b: 68, + 0x10f3c: 68, + 0x10f3d: 68, + 0x10f3e: 68, + 0x10f3f: 68, + 0x10f40: 68, + 0x10f41: 68, + 0x10f42: 68, + 0x10f43: 68, + 0x10f44: 68, + 0x10f45: 85, + 0x10f51: 68, + 0x10f52: 68, + 0x10f53: 68, + 0x10f54: 82, + 0x110bd: 85, + 0x110cd: 85, + 0x1e900: 68, + 0x1e901: 68, + 0x1e902: 68, + 0x1e903: 68, + 0x1e904: 68, + 0x1e905: 68, + 0x1e906: 68, + 0x1e907: 68, + 0x1e908: 68, + 0x1e909: 68, + 0x1e90a: 68, + 0x1e90b: 68, + 0x1e90c: 68, + 0x1e90d: 68, + 0x1e90e: 68, + 0x1e90f: 68, + 0x1e910: 68, + 0x1e911: 68, + 0x1e912: 68, + 0x1e913: 68, + 0x1e914: 68, + 0x1e915: 68, + 0x1e916: 68, + 0x1e917: 68, + 0x1e918: 68, + 0x1e919: 68, + 0x1e91a: 68, + 0x1e91b: 68, + 0x1e91c: 68, + 0x1e91d: 68, + 0x1e91e: 68, + 0x1e91f: 68, + 0x1e920: 68, + 0x1e921: 68, + 0x1e922: 68, + 0x1e923: 68, + 0x1e924: 68, + 0x1e925: 68, + 0x1e926: 68, + 0x1e927: 68, + 0x1e928: 68, + 0x1e929: 68, + 0x1e92a: 68, + 0x1e92b: 68, + 0x1e92c: 68, + 0x1e92d: 68, + 0x1e92e: 68, + 0x1e92f: 68, + 0x1e930: 68, + 0x1e931: 68, + 0x1e932: 68, + 0x1e933: 68, + 0x1e934: 68, + 0x1e935: 68, + 0x1e936: 68, + 0x1e937: 68, + 0x1e938: 68, + 0x1e939: 68, + 0x1e93a: 68, + 0x1e93b: 68, + 0x1e93c: 68, + 0x1e93d: 68, + 0x1e93e: 68, + 0x1e93f: 68, + 0x1e940: 68, + 0x1e941: 68, + 0x1e942: 68, + 0x1e943: 68, +} +codepoint_classes = { + 'PVALID': ( + 0x2d0000002e, + 0x300000003a, + 0x610000007b, + 0xdf000000f7, + 0xf800000100, + 0x10100000102, + 0x10300000104, + 0x10500000106, + 0x10700000108, + 0x1090000010a, + 0x10b0000010c, + 0x10d0000010e, + 0x10f00000110, + 0x11100000112, + 0x11300000114, + 0x11500000116, + 0x11700000118, + 0x1190000011a, + 0x11b0000011c, + 0x11d0000011e, + 0x11f00000120, + 0x12100000122, + 0x12300000124, + 0x12500000126, + 0x12700000128, + 0x1290000012a, + 0x12b0000012c, + 0x12d0000012e, + 0x12f00000130, + 0x13100000132, + 0x13500000136, + 0x13700000139, + 0x13a0000013b, + 0x13c0000013d, + 0x13e0000013f, + 0x14200000143, + 0x14400000145, + 0x14600000147, + 0x14800000149, + 0x14b0000014c, + 0x14d0000014e, + 0x14f00000150, + 0x15100000152, + 0x15300000154, + 0x15500000156, + 0x15700000158, + 0x1590000015a, + 0x15b0000015c, + 0x15d0000015e, + 0x15f00000160, + 0x16100000162, + 0x16300000164, + 0x16500000166, + 0x16700000168, + 0x1690000016a, + 0x16b0000016c, + 0x16d0000016e, + 0x16f00000170, + 0x17100000172, + 0x17300000174, + 0x17500000176, + 0x17700000178, + 0x17a0000017b, + 0x17c0000017d, + 0x17e0000017f, + 0x18000000181, + 0x18300000184, + 0x18500000186, + 0x18800000189, + 0x18c0000018e, + 0x19200000193, + 0x19500000196, + 0x1990000019c, + 0x19e0000019f, + 0x1a1000001a2, + 0x1a3000001a4, + 0x1a5000001a6, + 0x1a8000001a9, + 0x1aa000001ac, + 0x1ad000001ae, + 0x1b0000001b1, + 0x1b4000001b5, + 0x1b6000001b7, + 0x1b9000001bc, + 0x1bd000001c4, + 0x1ce000001cf, + 0x1d0000001d1, + 0x1d2000001d3, + 0x1d4000001d5, + 0x1d6000001d7, + 0x1d8000001d9, + 0x1da000001db, + 0x1dc000001de, + 0x1df000001e0, + 0x1e1000001e2, + 0x1e3000001e4, + 0x1e5000001e6, + 0x1e7000001e8, + 0x1e9000001ea, + 0x1eb000001ec, + 0x1ed000001ee, + 0x1ef000001f1, + 0x1f5000001f6, + 0x1f9000001fa, + 0x1fb000001fc, + 0x1fd000001fe, + 0x1ff00000200, + 0x20100000202, + 0x20300000204, + 0x20500000206, + 0x20700000208, + 0x2090000020a, + 0x20b0000020c, + 0x20d0000020e, + 0x20f00000210, + 0x21100000212, + 0x21300000214, + 0x21500000216, + 0x21700000218, + 0x2190000021a, + 0x21b0000021c, + 0x21d0000021e, + 0x21f00000220, + 0x22100000222, + 0x22300000224, + 0x22500000226, + 0x22700000228, + 0x2290000022a, + 0x22b0000022c, + 0x22d0000022e, + 0x22f00000230, + 0x23100000232, + 0x2330000023a, + 0x23c0000023d, + 0x23f00000241, + 0x24200000243, + 0x24700000248, + 0x2490000024a, + 0x24b0000024c, + 0x24d0000024e, + 0x24f000002b0, + 0x2b9000002c2, + 0x2c6000002d2, + 0x2ec000002ed, + 0x2ee000002ef, + 0x30000000340, + 0x34200000343, + 0x3460000034f, + 0x35000000370, + 0x37100000372, + 0x37300000374, + 0x37700000378, + 0x37b0000037e, + 0x39000000391, + 0x3ac000003cf, + 0x3d7000003d8, + 0x3d9000003da, + 0x3db000003dc, + 0x3dd000003de, + 0x3df000003e0, + 0x3e1000003e2, + 0x3e3000003e4, + 0x3e5000003e6, + 0x3e7000003e8, + 0x3e9000003ea, + 0x3eb000003ec, + 0x3ed000003ee, + 0x3ef000003f0, + 0x3f3000003f4, + 0x3f8000003f9, + 0x3fb000003fd, + 0x43000000460, + 0x46100000462, + 0x46300000464, + 0x46500000466, + 0x46700000468, + 0x4690000046a, + 0x46b0000046c, + 0x46d0000046e, + 0x46f00000470, + 0x47100000472, + 0x47300000474, + 0x47500000476, + 0x47700000478, + 0x4790000047a, + 0x47b0000047c, + 0x47d0000047e, + 0x47f00000480, + 0x48100000482, + 0x48300000488, + 0x48b0000048c, + 0x48d0000048e, + 0x48f00000490, + 0x49100000492, + 0x49300000494, + 0x49500000496, + 0x49700000498, + 0x4990000049a, + 0x49b0000049c, + 0x49d0000049e, + 0x49f000004a0, + 0x4a1000004a2, + 0x4a3000004a4, + 0x4a5000004a6, + 0x4a7000004a8, + 0x4a9000004aa, + 0x4ab000004ac, + 0x4ad000004ae, + 0x4af000004b0, + 0x4b1000004b2, + 0x4b3000004b4, + 0x4b5000004b6, + 0x4b7000004b8, + 0x4b9000004ba, + 0x4bb000004bc, + 0x4bd000004be, + 0x4bf000004c0, + 0x4c2000004c3, + 0x4c4000004c5, + 0x4c6000004c7, + 0x4c8000004c9, + 0x4ca000004cb, + 0x4cc000004cd, + 0x4ce000004d0, + 0x4d1000004d2, + 0x4d3000004d4, + 0x4d5000004d6, + 0x4d7000004d8, + 0x4d9000004da, + 0x4db000004dc, + 0x4dd000004de, + 0x4df000004e0, + 0x4e1000004e2, + 0x4e3000004e4, + 0x4e5000004e6, + 0x4e7000004e8, + 0x4e9000004ea, + 0x4eb000004ec, + 0x4ed000004ee, + 0x4ef000004f0, + 0x4f1000004f2, + 0x4f3000004f4, + 0x4f5000004f6, + 0x4f7000004f8, + 0x4f9000004fa, + 0x4fb000004fc, + 0x4fd000004fe, + 0x4ff00000500, + 0x50100000502, + 0x50300000504, + 0x50500000506, + 0x50700000508, + 0x5090000050a, + 0x50b0000050c, + 0x50d0000050e, + 0x50f00000510, + 0x51100000512, + 0x51300000514, + 0x51500000516, + 0x51700000518, + 0x5190000051a, + 0x51b0000051c, + 0x51d0000051e, + 0x51f00000520, + 0x52100000522, + 0x52300000524, + 0x52500000526, + 0x52700000528, + 0x5290000052a, + 0x52b0000052c, + 0x52d0000052e, + 0x52f00000530, + 0x5590000055a, + 0x56000000587, + 0x58800000589, + 0x591000005be, + 0x5bf000005c0, + 0x5c1000005c3, + 0x5c4000005c6, + 0x5c7000005c8, + 0x5d0000005eb, + 0x5ef000005f3, + 0x6100000061b, + 0x62000000640, + 0x64100000660, + 0x66e00000675, + 0x679000006d4, + 0x6d5000006dd, + 0x6df000006e9, + 0x6ea000006f0, + 0x6fa00000700, + 0x7100000074b, + 0x74d000007b2, + 0x7c0000007f6, + 0x7fd000007fe, + 0x8000000082e, + 0x8400000085c, + 0x8600000086b, + 0x8a0000008b5, + 0x8b6000008be, + 0x8d3000008e2, + 0x8e300000958, + 0x96000000964, + 0x96600000970, + 0x97100000984, + 0x9850000098d, + 0x98f00000991, + 0x993000009a9, + 0x9aa000009b1, + 0x9b2000009b3, + 0x9b6000009ba, + 0x9bc000009c5, + 0x9c7000009c9, + 0x9cb000009cf, + 0x9d7000009d8, + 0x9e0000009e4, + 0x9e6000009f2, + 0x9fc000009fd, + 0x9fe000009ff, + 0xa0100000a04, + 0xa0500000a0b, + 0xa0f00000a11, + 0xa1300000a29, + 0xa2a00000a31, + 0xa3200000a33, + 0xa3500000a36, + 0xa3800000a3a, + 0xa3c00000a3d, + 0xa3e00000a43, + 0xa4700000a49, + 0xa4b00000a4e, + 0xa5100000a52, + 0xa5c00000a5d, + 0xa6600000a76, + 0xa8100000a84, + 0xa8500000a8e, + 0xa8f00000a92, + 0xa9300000aa9, + 0xaaa00000ab1, + 0xab200000ab4, + 0xab500000aba, + 0xabc00000ac6, + 0xac700000aca, + 0xacb00000ace, + 0xad000000ad1, + 0xae000000ae4, + 0xae600000af0, + 0xaf900000b00, + 0xb0100000b04, + 0xb0500000b0d, + 0xb0f00000b11, + 0xb1300000b29, + 0xb2a00000b31, + 0xb3200000b34, + 0xb3500000b3a, + 0xb3c00000b45, + 0xb4700000b49, + 0xb4b00000b4e, + 0xb5600000b58, + 0xb5f00000b64, + 0xb6600000b70, + 0xb7100000b72, + 0xb8200000b84, + 0xb8500000b8b, + 0xb8e00000b91, + 0xb9200000b96, + 0xb9900000b9b, + 0xb9c00000b9d, + 0xb9e00000ba0, + 0xba300000ba5, + 0xba800000bab, + 0xbae00000bba, + 0xbbe00000bc3, + 0xbc600000bc9, + 0xbca00000bce, + 0xbd000000bd1, + 0xbd700000bd8, + 0xbe600000bf0, + 0xc0000000c0d, + 0xc0e00000c11, + 0xc1200000c29, + 0xc2a00000c3a, + 0xc3d00000c45, + 0xc4600000c49, + 0xc4a00000c4e, + 0xc5500000c57, + 0xc5800000c5b, + 0xc6000000c64, + 0xc6600000c70, + 0xc8000000c84, + 0xc8500000c8d, + 0xc8e00000c91, + 0xc9200000ca9, + 0xcaa00000cb4, + 0xcb500000cba, + 0xcbc00000cc5, + 0xcc600000cc9, + 0xcca00000cce, + 0xcd500000cd7, + 0xcde00000cdf, + 0xce000000ce4, + 0xce600000cf0, + 0xcf100000cf3, + 0xd0000000d04, + 0xd0500000d0d, + 0xd0e00000d11, + 0xd1200000d45, + 0xd4600000d49, + 0xd4a00000d4f, + 0xd5400000d58, + 0xd5f00000d64, + 0xd6600000d70, + 0xd7a00000d80, + 0xd8200000d84, + 0xd8500000d97, + 0xd9a00000db2, + 0xdb300000dbc, + 0xdbd00000dbe, + 0xdc000000dc7, + 0xdca00000dcb, + 0xdcf00000dd5, + 0xdd600000dd7, + 0xdd800000de0, + 0xde600000df0, + 0xdf200000df4, + 0xe0100000e33, + 0xe3400000e3b, + 0xe4000000e4f, + 0xe5000000e5a, + 0xe8100000e83, + 0xe8400000e85, + 0xe8700000e89, + 0xe8a00000e8b, + 0xe8d00000e8e, + 0xe9400000e98, + 0xe9900000ea0, + 0xea100000ea4, + 0xea500000ea6, + 0xea700000ea8, + 0xeaa00000eac, + 0xead00000eb3, + 0xeb400000eba, + 0xebb00000ebe, + 0xec000000ec5, + 0xec600000ec7, + 0xec800000ece, + 0xed000000eda, + 0xede00000ee0, + 0xf0000000f01, + 0xf0b00000f0c, + 0xf1800000f1a, + 0xf2000000f2a, + 0xf3500000f36, + 0xf3700000f38, + 0xf3900000f3a, + 0xf3e00000f43, + 0xf4400000f48, + 0xf4900000f4d, + 0xf4e00000f52, + 0xf5300000f57, + 0xf5800000f5c, + 0xf5d00000f69, + 0xf6a00000f6d, + 0xf7100000f73, + 0xf7400000f75, + 0xf7a00000f81, + 0xf8200000f85, + 0xf8600000f93, + 0xf9400000f98, + 0xf9900000f9d, + 0xf9e00000fa2, + 0xfa300000fa7, + 0xfa800000fac, + 0xfad00000fb9, + 0xfba00000fbd, + 0xfc600000fc7, + 0x10000000104a, + 0x10500000109e, + 0x10d0000010fb, + 0x10fd00001100, + 0x120000001249, + 0x124a0000124e, + 0x125000001257, + 0x125800001259, + 0x125a0000125e, + 0x126000001289, + 0x128a0000128e, + 0x1290000012b1, + 0x12b2000012b6, + 0x12b8000012bf, + 0x12c0000012c1, + 0x12c2000012c6, + 0x12c8000012d7, + 0x12d800001311, + 0x131200001316, + 0x13180000135b, + 0x135d00001360, + 0x138000001390, + 0x13a0000013f6, + 0x14010000166d, + 0x166f00001680, + 0x16810000169b, + 0x16a0000016eb, + 0x16f1000016f9, + 0x17000000170d, + 0x170e00001715, + 0x172000001735, + 0x174000001754, + 0x17600000176d, + 0x176e00001771, + 0x177200001774, + 0x1780000017b4, + 0x17b6000017d4, + 0x17d7000017d8, + 0x17dc000017de, + 0x17e0000017ea, + 0x18100000181a, + 0x182000001879, + 0x1880000018ab, + 0x18b0000018f6, + 0x19000000191f, + 0x19200000192c, + 0x19300000193c, + 0x19460000196e, + 0x197000001975, + 0x1980000019ac, + 0x19b0000019ca, + 0x19d0000019da, + 0x1a0000001a1c, + 0x1a2000001a5f, + 0x1a6000001a7d, + 0x1a7f00001a8a, + 0x1a9000001a9a, + 0x1aa700001aa8, + 0x1ab000001abe, + 0x1b0000001b4c, + 0x1b5000001b5a, + 0x1b6b00001b74, + 0x1b8000001bf4, + 0x1c0000001c38, + 0x1c4000001c4a, + 0x1c4d00001c7e, + 0x1cd000001cd3, + 0x1cd400001cfa, + 0x1d0000001d2c, + 0x1d2f00001d30, + 0x1d3b00001d3c, + 0x1d4e00001d4f, + 0x1d6b00001d78, + 0x1d7900001d9b, + 0x1dc000001dfa, + 0x1dfb00001e00, + 0x1e0100001e02, + 0x1e0300001e04, + 0x1e0500001e06, + 0x1e0700001e08, + 0x1e0900001e0a, + 0x1e0b00001e0c, + 0x1e0d00001e0e, + 0x1e0f00001e10, + 0x1e1100001e12, + 0x1e1300001e14, + 0x1e1500001e16, + 0x1e1700001e18, + 0x1e1900001e1a, + 0x1e1b00001e1c, + 0x1e1d00001e1e, + 0x1e1f00001e20, + 0x1e2100001e22, + 0x1e2300001e24, + 0x1e2500001e26, + 0x1e2700001e28, + 0x1e2900001e2a, + 0x1e2b00001e2c, + 0x1e2d00001e2e, + 0x1e2f00001e30, + 0x1e3100001e32, + 0x1e3300001e34, + 0x1e3500001e36, + 0x1e3700001e38, + 0x1e3900001e3a, + 0x1e3b00001e3c, + 0x1e3d00001e3e, + 0x1e3f00001e40, + 0x1e4100001e42, + 0x1e4300001e44, + 0x1e4500001e46, + 0x1e4700001e48, + 0x1e4900001e4a, + 0x1e4b00001e4c, + 0x1e4d00001e4e, + 0x1e4f00001e50, + 0x1e5100001e52, + 0x1e5300001e54, + 0x1e5500001e56, + 0x1e5700001e58, + 0x1e5900001e5a, + 0x1e5b00001e5c, + 0x1e5d00001e5e, + 0x1e5f00001e60, + 0x1e6100001e62, + 0x1e6300001e64, + 0x1e6500001e66, + 0x1e6700001e68, + 0x1e6900001e6a, + 0x1e6b00001e6c, + 0x1e6d00001e6e, + 0x1e6f00001e70, + 0x1e7100001e72, + 0x1e7300001e74, + 0x1e7500001e76, + 0x1e7700001e78, + 0x1e7900001e7a, + 0x1e7b00001e7c, + 0x1e7d00001e7e, + 0x1e7f00001e80, + 0x1e8100001e82, + 0x1e8300001e84, + 0x1e8500001e86, + 0x1e8700001e88, + 0x1e8900001e8a, + 0x1e8b00001e8c, + 0x1e8d00001e8e, + 0x1e8f00001e90, + 0x1e9100001e92, + 0x1e9300001e94, + 0x1e9500001e9a, + 0x1e9c00001e9e, + 0x1e9f00001ea0, + 0x1ea100001ea2, + 0x1ea300001ea4, + 0x1ea500001ea6, + 0x1ea700001ea8, + 0x1ea900001eaa, + 0x1eab00001eac, + 0x1ead00001eae, + 0x1eaf00001eb0, + 0x1eb100001eb2, + 0x1eb300001eb4, + 0x1eb500001eb6, + 0x1eb700001eb8, + 0x1eb900001eba, + 0x1ebb00001ebc, + 0x1ebd00001ebe, + 0x1ebf00001ec0, + 0x1ec100001ec2, + 0x1ec300001ec4, + 0x1ec500001ec6, + 0x1ec700001ec8, + 0x1ec900001eca, + 0x1ecb00001ecc, + 0x1ecd00001ece, + 0x1ecf00001ed0, + 0x1ed100001ed2, + 0x1ed300001ed4, + 0x1ed500001ed6, + 0x1ed700001ed8, + 0x1ed900001eda, + 0x1edb00001edc, + 0x1edd00001ede, + 0x1edf00001ee0, + 0x1ee100001ee2, + 0x1ee300001ee4, + 0x1ee500001ee6, + 0x1ee700001ee8, + 0x1ee900001eea, + 0x1eeb00001eec, + 0x1eed00001eee, + 0x1eef00001ef0, + 0x1ef100001ef2, + 0x1ef300001ef4, + 0x1ef500001ef6, + 0x1ef700001ef8, + 0x1ef900001efa, + 0x1efb00001efc, + 0x1efd00001efe, + 0x1eff00001f08, + 0x1f1000001f16, + 0x1f2000001f28, + 0x1f3000001f38, + 0x1f4000001f46, + 0x1f5000001f58, + 0x1f6000001f68, + 0x1f7000001f71, + 0x1f7200001f73, + 0x1f7400001f75, + 0x1f7600001f77, + 0x1f7800001f79, + 0x1f7a00001f7b, + 0x1f7c00001f7d, + 0x1fb000001fb2, + 0x1fb600001fb7, + 0x1fc600001fc7, + 0x1fd000001fd3, + 0x1fd600001fd8, + 0x1fe000001fe3, + 0x1fe400001fe8, + 0x1ff600001ff7, + 0x214e0000214f, + 0x218400002185, + 0x2c3000002c5f, + 0x2c6100002c62, + 0x2c6500002c67, + 0x2c6800002c69, + 0x2c6a00002c6b, + 0x2c6c00002c6d, + 0x2c7100002c72, + 0x2c7300002c75, + 0x2c7600002c7c, + 0x2c8100002c82, + 0x2c8300002c84, + 0x2c8500002c86, + 0x2c8700002c88, + 0x2c8900002c8a, + 0x2c8b00002c8c, + 0x2c8d00002c8e, + 0x2c8f00002c90, + 0x2c9100002c92, + 0x2c9300002c94, + 0x2c9500002c96, + 0x2c9700002c98, + 0x2c9900002c9a, + 0x2c9b00002c9c, + 0x2c9d00002c9e, + 0x2c9f00002ca0, + 0x2ca100002ca2, + 0x2ca300002ca4, + 0x2ca500002ca6, + 0x2ca700002ca8, + 0x2ca900002caa, + 0x2cab00002cac, + 0x2cad00002cae, + 0x2caf00002cb0, + 0x2cb100002cb2, + 0x2cb300002cb4, + 0x2cb500002cb6, + 0x2cb700002cb8, + 0x2cb900002cba, + 0x2cbb00002cbc, + 0x2cbd00002cbe, + 0x2cbf00002cc0, + 0x2cc100002cc2, + 0x2cc300002cc4, + 0x2cc500002cc6, + 0x2cc700002cc8, + 0x2cc900002cca, + 0x2ccb00002ccc, + 0x2ccd00002cce, + 0x2ccf00002cd0, + 0x2cd100002cd2, + 0x2cd300002cd4, + 0x2cd500002cd6, + 0x2cd700002cd8, + 0x2cd900002cda, + 0x2cdb00002cdc, + 0x2cdd00002cde, + 0x2cdf00002ce0, + 0x2ce100002ce2, + 0x2ce300002ce5, + 0x2cec00002ced, + 0x2cee00002cf2, + 0x2cf300002cf4, + 0x2d0000002d26, + 0x2d2700002d28, + 0x2d2d00002d2e, + 0x2d3000002d68, + 0x2d7f00002d97, + 0x2da000002da7, + 0x2da800002daf, + 0x2db000002db7, + 0x2db800002dbf, + 0x2dc000002dc7, + 0x2dc800002dcf, + 0x2dd000002dd7, + 0x2dd800002ddf, + 0x2de000002e00, + 0x2e2f00002e30, + 0x300500003008, + 0x302a0000302e, + 0x303c0000303d, + 0x304100003097, + 0x30990000309b, + 0x309d0000309f, + 0x30a1000030fb, + 0x30fc000030ff, + 0x310500003130, + 0x31a0000031bb, + 0x31f000003200, + 0x340000004db6, + 0x4e0000009ff0, + 0xa0000000a48d, + 0xa4d00000a4fe, + 0xa5000000a60d, + 0xa6100000a62c, + 0xa6410000a642, + 0xa6430000a644, + 0xa6450000a646, + 0xa6470000a648, + 0xa6490000a64a, + 0xa64b0000a64c, + 0xa64d0000a64e, + 0xa64f0000a650, + 0xa6510000a652, + 0xa6530000a654, + 0xa6550000a656, + 0xa6570000a658, + 0xa6590000a65a, + 0xa65b0000a65c, + 0xa65d0000a65e, + 0xa65f0000a660, + 0xa6610000a662, + 0xa6630000a664, + 0xa6650000a666, + 0xa6670000a668, + 0xa6690000a66a, + 0xa66b0000a66c, + 0xa66d0000a670, + 0xa6740000a67e, + 0xa67f0000a680, + 0xa6810000a682, + 0xa6830000a684, + 0xa6850000a686, + 0xa6870000a688, + 0xa6890000a68a, + 0xa68b0000a68c, + 0xa68d0000a68e, + 0xa68f0000a690, + 0xa6910000a692, + 0xa6930000a694, + 0xa6950000a696, + 0xa6970000a698, + 0xa6990000a69a, + 0xa69b0000a69c, + 0xa69e0000a6e6, + 0xa6f00000a6f2, + 0xa7170000a720, + 0xa7230000a724, + 0xa7250000a726, + 0xa7270000a728, + 0xa7290000a72a, + 0xa72b0000a72c, + 0xa72d0000a72e, + 0xa72f0000a732, + 0xa7330000a734, + 0xa7350000a736, + 0xa7370000a738, + 0xa7390000a73a, + 0xa73b0000a73c, + 0xa73d0000a73e, + 0xa73f0000a740, + 0xa7410000a742, + 0xa7430000a744, + 0xa7450000a746, + 0xa7470000a748, + 0xa7490000a74a, + 0xa74b0000a74c, + 0xa74d0000a74e, + 0xa74f0000a750, + 0xa7510000a752, + 0xa7530000a754, + 0xa7550000a756, + 0xa7570000a758, + 0xa7590000a75a, + 0xa75b0000a75c, + 0xa75d0000a75e, + 0xa75f0000a760, + 0xa7610000a762, + 0xa7630000a764, + 0xa7650000a766, + 0xa7670000a768, + 0xa7690000a76a, + 0xa76b0000a76c, + 0xa76d0000a76e, + 0xa76f0000a770, + 0xa7710000a779, + 0xa77a0000a77b, + 0xa77c0000a77d, + 0xa77f0000a780, + 0xa7810000a782, + 0xa7830000a784, + 0xa7850000a786, + 0xa7870000a789, + 0xa78c0000a78d, + 0xa78e0000a790, + 0xa7910000a792, + 0xa7930000a796, + 0xa7970000a798, + 0xa7990000a79a, + 0xa79b0000a79c, + 0xa79d0000a79e, + 0xa79f0000a7a0, + 0xa7a10000a7a2, + 0xa7a30000a7a4, + 0xa7a50000a7a6, + 0xa7a70000a7a8, + 0xa7a90000a7aa, + 0xa7af0000a7b0, + 0xa7b50000a7b6, + 0xa7b70000a7b8, + 0xa7b90000a7ba, + 0xa7f70000a7f8, + 0xa7fa0000a828, + 0xa8400000a874, + 0xa8800000a8c6, + 0xa8d00000a8da, + 0xa8e00000a8f8, + 0xa8fb0000a8fc, + 0xa8fd0000a92e, + 0xa9300000a954, + 0xa9800000a9c1, + 0xa9cf0000a9da, + 0xa9e00000a9ff, + 0xaa000000aa37, + 0xaa400000aa4e, + 0xaa500000aa5a, + 0xaa600000aa77, + 0xaa7a0000aac3, + 0xaadb0000aade, + 0xaae00000aaf0, + 0xaaf20000aaf7, + 0xab010000ab07, + 0xab090000ab0f, + 0xab110000ab17, + 0xab200000ab27, + 0xab280000ab2f, + 0xab300000ab5b, + 0xab600000ab66, + 0xabc00000abeb, + 0xabec0000abee, + 0xabf00000abfa, + 0xac000000d7a4, + 0xfa0e0000fa10, + 0xfa110000fa12, + 0xfa130000fa15, + 0xfa1f0000fa20, + 0xfa210000fa22, + 0xfa230000fa25, + 0xfa270000fa2a, + 0xfb1e0000fb1f, + 0xfe200000fe30, + 0xfe730000fe74, + 0x100000001000c, + 0x1000d00010027, + 0x100280001003b, + 0x1003c0001003e, + 0x1003f0001004e, + 0x100500001005e, + 0x10080000100fb, + 0x101fd000101fe, + 0x102800001029d, + 0x102a0000102d1, + 0x102e0000102e1, + 0x1030000010320, + 0x1032d00010341, + 0x103420001034a, + 0x103500001037b, + 0x103800001039e, + 0x103a0000103c4, + 0x103c8000103d0, + 0x104280001049e, + 0x104a0000104aa, + 0x104d8000104fc, + 0x1050000010528, + 0x1053000010564, + 0x1060000010737, + 0x1074000010756, + 0x1076000010768, + 0x1080000010806, + 0x1080800010809, + 0x1080a00010836, + 0x1083700010839, + 0x1083c0001083d, + 0x1083f00010856, + 0x1086000010877, + 0x108800001089f, + 0x108e0000108f3, + 0x108f4000108f6, + 0x1090000010916, + 0x109200001093a, + 0x10980000109b8, + 0x109be000109c0, + 0x10a0000010a04, + 0x10a0500010a07, + 0x10a0c00010a14, + 0x10a1500010a18, + 0x10a1900010a36, + 0x10a3800010a3b, + 0x10a3f00010a40, + 0x10a6000010a7d, + 0x10a8000010a9d, + 0x10ac000010ac8, + 0x10ac900010ae7, + 0x10b0000010b36, + 0x10b4000010b56, + 0x10b6000010b73, + 0x10b8000010b92, + 0x10c0000010c49, + 0x10cc000010cf3, + 0x10d0000010d28, + 0x10d3000010d3a, + 0x10f0000010f1d, + 0x10f2700010f28, + 0x10f3000010f51, + 0x1100000011047, + 0x1106600011070, + 0x1107f000110bb, + 0x110d0000110e9, + 0x110f0000110fa, + 0x1110000011135, + 0x1113600011140, + 0x1114400011147, + 0x1115000011174, + 0x1117600011177, + 0x11180000111c5, + 0x111c9000111cd, + 0x111d0000111db, + 0x111dc000111dd, + 0x1120000011212, + 0x1121300011238, + 0x1123e0001123f, + 0x1128000011287, + 0x1128800011289, + 0x1128a0001128e, + 0x1128f0001129e, + 0x1129f000112a9, + 0x112b0000112eb, + 0x112f0000112fa, + 0x1130000011304, + 0x113050001130d, + 0x1130f00011311, + 0x1131300011329, + 0x1132a00011331, + 0x1133200011334, + 0x113350001133a, + 0x1133b00011345, + 0x1134700011349, + 0x1134b0001134e, + 0x1135000011351, + 0x1135700011358, + 0x1135d00011364, + 0x113660001136d, + 0x1137000011375, + 0x114000001144b, + 0x114500001145a, + 0x1145e0001145f, + 0x11480000114c6, + 0x114c7000114c8, + 0x114d0000114da, + 0x11580000115b6, + 0x115b8000115c1, + 0x115d8000115de, + 0x1160000011641, + 0x1164400011645, + 0x116500001165a, + 0x11680000116b8, + 0x116c0000116ca, + 0x117000001171b, + 0x1171d0001172c, + 0x117300001173a, + 0x118000001183b, + 0x118c0000118ea, + 0x118ff00011900, + 0x11a0000011a3f, + 0x11a4700011a48, + 0x11a5000011a84, + 0x11a8600011a9a, + 0x11a9d00011a9e, + 0x11ac000011af9, + 0x11c0000011c09, + 0x11c0a00011c37, + 0x11c3800011c41, + 0x11c5000011c5a, + 0x11c7200011c90, + 0x11c9200011ca8, + 0x11ca900011cb7, + 0x11d0000011d07, + 0x11d0800011d0a, + 0x11d0b00011d37, + 0x11d3a00011d3b, + 0x11d3c00011d3e, + 0x11d3f00011d48, + 0x11d5000011d5a, + 0x11d6000011d66, + 0x11d6700011d69, + 0x11d6a00011d8f, + 0x11d9000011d92, + 0x11d9300011d99, + 0x11da000011daa, + 0x11ee000011ef7, + 0x120000001239a, + 0x1248000012544, + 0x130000001342f, + 0x1440000014647, + 0x1680000016a39, + 0x16a4000016a5f, + 0x16a6000016a6a, + 0x16ad000016aee, + 0x16af000016af5, + 0x16b0000016b37, + 0x16b4000016b44, + 0x16b5000016b5a, + 0x16b6300016b78, + 0x16b7d00016b90, + 0x16e6000016e80, + 0x16f0000016f45, + 0x16f5000016f7f, + 0x16f8f00016fa0, + 0x16fe000016fe2, + 0x17000000187f2, + 0x1880000018af3, + 0x1b0000001b11f, + 0x1b1700001b2fc, + 0x1bc000001bc6b, + 0x1bc700001bc7d, + 0x1bc800001bc89, + 0x1bc900001bc9a, + 0x1bc9d0001bc9f, + 0x1da000001da37, + 0x1da3b0001da6d, + 0x1da750001da76, + 0x1da840001da85, + 0x1da9b0001daa0, + 0x1daa10001dab0, + 0x1e0000001e007, + 0x1e0080001e019, + 0x1e01b0001e022, + 0x1e0230001e025, + 0x1e0260001e02b, + 0x1e8000001e8c5, + 0x1e8d00001e8d7, + 0x1e9220001e94b, + 0x1e9500001e95a, + 0x200000002a6d7, + 0x2a7000002b735, + 0x2b7400002b81e, + 0x2b8200002cea2, + 0x2ceb00002ebe1, + ), + 'CONTEXTJ': ( + 0x200c0000200e, + ), + 'CONTEXTO': ( + 0xb7000000b8, + 0x37500000376, + 0x5f3000005f5, + 0x6600000066a, + 0x6f0000006fa, + 0x30fb000030fc, + ), +} diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/intranges.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/intranges.py new file mode 100644 index 0000000..fa8a735 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/intranges.py @@ -0,0 +1,53 @@ +""" +Given a list of integers, made up of (hopefully) a small number of long runs +of consecutive integers, compute a representation of the form +((start1, end1), (start2, end2) ...). Then answer the question "was x present +in the original list?" in time O(log(# runs)). +""" + +import bisect + +def intranges_from_list(list_): + """Represent a list of integers as a sequence of ranges: + ((start_0, end_0), (start_1, end_1), ...), such that the original + integers are exactly those x such that start_i <= x < end_i for some i. + + Ranges are encoded as single integers (start << 32 | end), not as tuples. + """ + + sorted_list = sorted(list_) + ranges = [] + last_write = -1 + for i in range(len(sorted_list)): + if i+1 < len(sorted_list): + if sorted_list[i] == sorted_list[i+1]-1: + continue + current_range = sorted_list[last_write+1:i+1] + ranges.append(_encode_range(current_range[0], current_range[-1] + 1)) + last_write = i + + return tuple(ranges) + +def _encode_range(start, end): + return (start << 32) | end + +def _decode_range(r): + return (r >> 32), (r & ((1 << 32) - 1)) + + +def intranges_contain(int_, ranges): + """Determine if `int_` falls into one of the ranges in `ranges`.""" + tuple_ = _encode_range(int_, 0) + pos = bisect.bisect_left(ranges, tuple_) + # we could be immediately ahead of a tuple (start, end) + # with start < int_ <= end + if pos > 0: + left, right = _decode_range(ranges[pos-1]) + if left <= int_ < right: + return True + # or we could be immediately behind a tuple (int_, end) + if pos < len(ranges): + left, _ = _decode_range(ranges[pos]) + if left == int_: + return True + return False diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/package_data.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/package_data.py new file mode 100644 index 0000000..257e898 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/package_data.py @@ -0,0 +1,2 @@ +__version__ = '2.8' + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/uts46data.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/uts46data.py new file mode 100644 index 0000000..a68ed4c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/idna/uts46data.py @@ -0,0 +1,8205 @@ +# This file is automatically generated by tools/idna-data +# vim: set fileencoding=utf-8 : + +"""IDNA Mapping Table from UTS46.""" + + +__version__ = "11.0.0" +def _seg_0(): + return [ + (0x0, '3'), + (0x1, '3'), + (0x2, '3'), + (0x3, '3'), + (0x4, '3'), + (0x5, '3'), + (0x6, '3'), + (0x7, '3'), + (0x8, '3'), + (0x9, '3'), + (0xA, '3'), + (0xB, '3'), + (0xC, '3'), + (0xD, '3'), + (0xE, '3'), + (0xF, '3'), + (0x10, '3'), + (0x11, '3'), + (0x12, '3'), + (0x13, '3'), + (0x14, '3'), + (0x15, '3'), + (0x16, '3'), + (0x17, '3'), + (0x18, '3'), + (0x19, '3'), + (0x1A, '3'), + (0x1B, '3'), + (0x1C, '3'), + (0x1D, '3'), + (0x1E, '3'), + (0x1F, '3'), + (0x20, '3'), + (0x21, '3'), + (0x22, '3'), + (0x23, '3'), + (0x24, '3'), + (0x25, '3'), + (0x26, '3'), + (0x27, '3'), + (0x28, '3'), + (0x29, '3'), + (0x2A, '3'), + (0x2B, '3'), + (0x2C, '3'), + (0x2D, 'V'), + (0x2E, 'V'), + (0x2F, '3'), + (0x30, 'V'), + (0x31, 'V'), + (0x32, 'V'), + (0x33, 'V'), + (0x34, 'V'), + (0x35, 'V'), + (0x36, 'V'), + (0x37, 'V'), + (0x38, 'V'), + (0x39, 'V'), + (0x3A, '3'), + (0x3B, '3'), + (0x3C, '3'), + (0x3D, '3'), + (0x3E, '3'), + (0x3F, '3'), + (0x40, '3'), + (0x41, 'M', u'a'), + (0x42, 'M', u'b'), + (0x43, 'M', u'c'), + (0x44, 'M', u'd'), + (0x45, 'M', u'e'), + (0x46, 'M', u'f'), + (0x47, 'M', u'g'), + (0x48, 'M', u'h'), + (0x49, 'M', u'i'), + (0x4A, 'M', u'j'), + (0x4B, 'M', u'k'), + (0x4C, 'M', u'l'), + (0x4D, 'M', u'm'), + (0x4E, 'M', u'n'), + (0x4F, 'M', u'o'), + (0x50, 'M', u'p'), + (0x51, 'M', u'q'), + (0x52, 'M', u'r'), + (0x53, 'M', u's'), + (0x54, 'M', u't'), + (0x55, 'M', u'u'), + (0x56, 'M', u'v'), + (0x57, 'M', u'w'), + (0x58, 'M', u'x'), + (0x59, 'M', u'y'), + (0x5A, 'M', u'z'), + (0x5B, '3'), + (0x5C, '3'), + (0x5D, '3'), + (0x5E, '3'), + (0x5F, '3'), + (0x60, '3'), + (0x61, 'V'), + (0x62, 'V'), + (0x63, 'V'), + ] + +def _seg_1(): + return [ + (0x64, 'V'), + (0x65, 'V'), + (0x66, 'V'), + (0x67, 'V'), + (0x68, 'V'), + (0x69, 'V'), + (0x6A, 'V'), + (0x6B, 'V'), + (0x6C, 'V'), + (0x6D, 'V'), + (0x6E, 'V'), + (0x6F, 'V'), + (0x70, 'V'), + (0x71, 'V'), + (0x72, 'V'), + (0x73, 'V'), + (0x74, 'V'), + (0x75, 'V'), + (0x76, 'V'), + (0x77, 'V'), + (0x78, 'V'), + (0x79, 'V'), + (0x7A, 'V'), + (0x7B, '3'), + (0x7C, '3'), + (0x7D, '3'), + (0x7E, '3'), + (0x7F, '3'), + (0x80, 'X'), + (0x81, 'X'), + (0x82, 'X'), + (0x83, 'X'), + (0x84, 'X'), + (0x85, 'X'), + (0x86, 'X'), + (0x87, 'X'), + (0x88, 'X'), + (0x89, 'X'), + (0x8A, 'X'), + (0x8B, 'X'), + (0x8C, 'X'), + (0x8D, 'X'), + (0x8E, 'X'), + (0x8F, 'X'), + (0x90, 'X'), + (0x91, 'X'), + (0x92, 'X'), + (0x93, 'X'), + (0x94, 'X'), + (0x95, 'X'), + (0x96, 'X'), + (0x97, 'X'), + (0x98, 'X'), + (0x99, 'X'), + (0x9A, 'X'), + (0x9B, 'X'), + (0x9C, 'X'), + (0x9D, 'X'), + (0x9E, 'X'), + (0x9F, 'X'), + (0xA0, '3', u' '), + (0xA1, 'V'), + (0xA2, 'V'), + (0xA3, 'V'), + (0xA4, 'V'), + (0xA5, 'V'), + (0xA6, 'V'), + (0xA7, 'V'), + (0xA8, '3', u' ̈'), + (0xA9, 'V'), + (0xAA, 'M', u'a'), + (0xAB, 'V'), + (0xAC, 'V'), + (0xAD, 'I'), + (0xAE, 'V'), + (0xAF, '3', u' ̄'), + (0xB0, 'V'), + (0xB1, 'V'), + (0xB2, 'M', u'2'), + (0xB3, 'M', u'3'), + (0xB4, '3', u' ́'), + (0xB5, 'M', u'μ'), + (0xB6, 'V'), + (0xB7, 'V'), + (0xB8, '3', u' ̧'), + (0xB9, 'M', u'1'), + (0xBA, 'M', u'o'), + (0xBB, 'V'), + (0xBC, 'M', u'1⁄4'), + (0xBD, 'M', u'1⁄2'), + (0xBE, 'M', u'3⁄4'), + (0xBF, 'V'), + (0xC0, 'M', u'à'), + (0xC1, 'M', u'á'), + (0xC2, 'M', u'â'), + (0xC3, 'M', u'ã'), + (0xC4, 'M', u'ä'), + (0xC5, 'M', u'å'), + (0xC6, 'M', u'æ'), + (0xC7, 'M', u'ç'), + ] + +def _seg_2(): + return [ + (0xC8, 'M', u'è'), + (0xC9, 'M', u'é'), + (0xCA, 'M', u'ê'), + (0xCB, 'M', u'ë'), + (0xCC, 'M', u'ì'), + (0xCD, 'M', u'í'), + (0xCE, 'M', u'î'), + (0xCF, 'M', u'ï'), + (0xD0, 'M', u'ð'), + (0xD1, 'M', u'ñ'), + (0xD2, 'M', u'ò'), + (0xD3, 'M', u'ó'), + (0xD4, 'M', u'ô'), + (0xD5, 'M', u'õ'), + (0xD6, 'M', u'ö'), + (0xD7, 'V'), + (0xD8, 'M', u'ø'), + (0xD9, 'M', u'ù'), + (0xDA, 'M', u'ú'), + (0xDB, 'M', u'û'), + (0xDC, 'M', u'ü'), + (0xDD, 'M', u'ý'), + (0xDE, 'M', u'þ'), + (0xDF, 'D', u'ss'), + (0xE0, 'V'), + (0xE1, 'V'), + (0xE2, 'V'), + (0xE3, 'V'), + (0xE4, 'V'), + (0xE5, 'V'), + (0xE6, 'V'), + (0xE7, 'V'), + (0xE8, 'V'), + (0xE9, 'V'), + (0xEA, 'V'), + (0xEB, 'V'), + (0xEC, 'V'), + (0xED, 'V'), + (0xEE, 'V'), + (0xEF, 'V'), + (0xF0, 'V'), + (0xF1, 'V'), + (0xF2, 'V'), + (0xF3, 'V'), + (0xF4, 'V'), + (0xF5, 'V'), + (0xF6, 'V'), + (0xF7, 'V'), + (0xF8, 'V'), + (0xF9, 'V'), + (0xFA, 'V'), + (0xFB, 'V'), + (0xFC, 'V'), + (0xFD, 'V'), + (0xFE, 'V'), + (0xFF, 'V'), + (0x100, 'M', u'ā'), + (0x101, 'V'), + (0x102, 'M', u'ă'), + (0x103, 'V'), + (0x104, 'M', u'ą'), + (0x105, 'V'), + (0x106, 'M', u'ć'), + (0x107, 'V'), + (0x108, 'M', u'ĉ'), + (0x109, 'V'), + (0x10A, 'M', u'ċ'), + (0x10B, 'V'), + (0x10C, 'M', u'č'), + (0x10D, 'V'), + (0x10E, 'M', u'ď'), + (0x10F, 'V'), + (0x110, 'M', u'đ'), + (0x111, 'V'), + (0x112, 'M', u'ē'), + (0x113, 'V'), + (0x114, 'M', u'ĕ'), + (0x115, 'V'), + (0x116, 'M', u'ė'), + (0x117, 'V'), + (0x118, 'M', u'ę'), + (0x119, 'V'), + (0x11A, 'M', u'ě'), + (0x11B, 'V'), + (0x11C, 'M', u'ĝ'), + (0x11D, 'V'), + (0x11E, 'M', u'ğ'), + (0x11F, 'V'), + (0x120, 'M', u'ġ'), + (0x121, 'V'), + (0x122, 'M', u'ģ'), + (0x123, 'V'), + (0x124, 'M', u'ĥ'), + (0x125, 'V'), + (0x126, 'M', u'ħ'), + (0x127, 'V'), + (0x128, 'M', u'ĩ'), + (0x129, 'V'), + (0x12A, 'M', u'ī'), + (0x12B, 'V'), + ] + +def _seg_3(): + return [ + (0x12C, 'M', u'ĭ'), + (0x12D, 'V'), + (0x12E, 'M', u'į'), + (0x12F, 'V'), + (0x130, 'M', u'i̇'), + (0x131, 'V'), + (0x132, 'M', u'ij'), + (0x134, 'M', u'ĵ'), + (0x135, 'V'), + (0x136, 'M', u'ķ'), + (0x137, 'V'), + (0x139, 'M', u'ĺ'), + (0x13A, 'V'), + (0x13B, 'M', u'ļ'), + (0x13C, 'V'), + (0x13D, 'M', u'ľ'), + (0x13E, 'V'), + (0x13F, 'M', u'l·'), + (0x141, 'M', u'ł'), + (0x142, 'V'), + (0x143, 'M', u'ń'), + (0x144, 'V'), + (0x145, 'M', u'ņ'), + (0x146, 'V'), + (0x147, 'M', u'ň'), + (0x148, 'V'), + (0x149, 'M', u'ʼn'), + (0x14A, 'M', u'ŋ'), + (0x14B, 'V'), + (0x14C, 'M', u'ō'), + (0x14D, 'V'), + (0x14E, 'M', u'ŏ'), + (0x14F, 'V'), + (0x150, 'M', u'ő'), + (0x151, 'V'), + (0x152, 'M', u'œ'), + (0x153, 'V'), + (0x154, 'M', u'ŕ'), + (0x155, 'V'), + (0x156, 'M', u'ŗ'), + (0x157, 'V'), + (0x158, 'M', u'ř'), + (0x159, 'V'), + (0x15A, 'M', u'ś'), + (0x15B, 'V'), + (0x15C, 'M', u'ŝ'), + (0x15D, 'V'), + (0x15E, 'M', u'ş'), + (0x15F, 'V'), + (0x160, 'M', u'š'), + (0x161, 'V'), + (0x162, 'M', u'ţ'), + (0x163, 'V'), + (0x164, 'M', u'ť'), + (0x165, 'V'), + (0x166, 'M', u'ŧ'), + (0x167, 'V'), + (0x168, 'M', u'ũ'), + (0x169, 'V'), + (0x16A, 'M', u'ū'), + (0x16B, 'V'), + (0x16C, 'M', u'ŭ'), + (0x16D, 'V'), + (0x16E, 'M', u'ů'), + (0x16F, 'V'), + (0x170, 'M', u'ű'), + (0x171, 'V'), + (0x172, 'M', u'ų'), + (0x173, 'V'), + (0x174, 'M', u'ŵ'), + (0x175, 'V'), + (0x176, 'M', u'ŷ'), + (0x177, 'V'), + (0x178, 'M', u'ÿ'), + (0x179, 'M', u'ź'), + (0x17A, 'V'), + (0x17B, 'M', u'ż'), + (0x17C, 'V'), + (0x17D, 'M', u'ž'), + (0x17E, 'V'), + (0x17F, 'M', u's'), + (0x180, 'V'), + (0x181, 'M', u'ɓ'), + (0x182, 'M', u'ƃ'), + (0x183, 'V'), + (0x184, 'M', u'ƅ'), + (0x185, 'V'), + (0x186, 'M', u'ɔ'), + (0x187, 'M', u'ƈ'), + (0x188, 'V'), + (0x189, 'M', u'ɖ'), + (0x18A, 'M', u'ɗ'), + (0x18B, 'M', u'ƌ'), + (0x18C, 'V'), + (0x18E, 'M', u'ǝ'), + (0x18F, 'M', u'ə'), + (0x190, 'M', u'ɛ'), + (0x191, 'M', u'ƒ'), + (0x192, 'V'), + (0x193, 'M', u'ɠ'), + ] + +def _seg_4(): + return [ + (0x194, 'M', u'ɣ'), + (0x195, 'V'), + (0x196, 'M', u'ɩ'), + (0x197, 'M', u'ɨ'), + (0x198, 'M', u'ƙ'), + (0x199, 'V'), + (0x19C, 'M', u'ɯ'), + (0x19D, 'M', u'ɲ'), + (0x19E, 'V'), + (0x19F, 'M', u'ɵ'), + (0x1A0, 'M', u'ơ'), + (0x1A1, 'V'), + (0x1A2, 'M', u'ƣ'), + (0x1A3, 'V'), + (0x1A4, 'M', u'ƥ'), + (0x1A5, 'V'), + (0x1A6, 'M', u'ʀ'), + (0x1A7, 'M', u'ƨ'), + (0x1A8, 'V'), + (0x1A9, 'M', u'ʃ'), + (0x1AA, 'V'), + (0x1AC, 'M', u'ƭ'), + (0x1AD, 'V'), + (0x1AE, 'M', u'ʈ'), + (0x1AF, 'M', u'ư'), + (0x1B0, 'V'), + (0x1B1, 'M', u'ʊ'), + (0x1B2, 'M', u'ʋ'), + (0x1B3, 'M', u'ƴ'), + (0x1B4, 'V'), + (0x1B5, 'M', u'ƶ'), + (0x1B6, 'V'), + (0x1B7, 'M', u'ʒ'), + (0x1B8, 'M', u'ƹ'), + (0x1B9, 'V'), + (0x1BC, 'M', u'ƽ'), + (0x1BD, 'V'), + (0x1C4, 'M', u'dž'), + (0x1C7, 'M', u'lj'), + (0x1CA, 'M', u'nj'), + (0x1CD, 'M', u'ǎ'), + (0x1CE, 'V'), + (0x1CF, 'M', u'ǐ'), + (0x1D0, 'V'), + (0x1D1, 'M', u'ǒ'), + (0x1D2, 'V'), + (0x1D3, 'M', u'ǔ'), + (0x1D4, 'V'), + (0x1D5, 'M', u'ǖ'), + (0x1D6, 'V'), + (0x1D7, 'M', u'ǘ'), + (0x1D8, 'V'), + (0x1D9, 'M', u'ǚ'), + (0x1DA, 'V'), + (0x1DB, 'M', u'ǜ'), + (0x1DC, 'V'), + (0x1DE, 'M', u'ǟ'), + (0x1DF, 'V'), + (0x1E0, 'M', u'ǡ'), + (0x1E1, 'V'), + (0x1E2, 'M', u'ǣ'), + (0x1E3, 'V'), + (0x1E4, 'M', u'ǥ'), + (0x1E5, 'V'), + (0x1E6, 'M', u'ǧ'), + (0x1E7, 'V'), + (0x1E8, 'M', u'ǩ'), + (0x1E9, 'V'), + (0x1EA, 'M', u'ǫ'), + (0x1EB, 'V'), + (0x1EC, 'M', u'ǭ'), + (0x1ED, 'V'), + (0x1EE, 'M', u'ǯ'), + (0x1EF, 'V'), + (0x1F1, 'M', u'dz'), + (0x1F4, 'M', u'ǵ'), + (0x1F5, 'V'), + (0x1F6, 'M', u'ƕ'), + (0x1F7, 'M', u'ƿ'), + (0x1F8, 'M', u'ǹ'), + (0x1F9, 'V'), + (0x1FA, 'M', u'ǻ'), + (0x1FB, 'V'), + (0x1FC, 'M', u'ǽ'), + (0x1FD, 'V'), + (0x1FE, 'M', u'ǿ'), + (0x1FF, 'V'), + (0x200, 'M', u'ȁ'), + (0x201, 'V'), + (0x202, 'M', u'ȃ'), + (0x203, 'V'), + (0x204, 'M', u'ȅ'), + (0x205, 'V'), + (0x206, 'M', u'ȇ'), + (0x207, 'V'), + (0x208, 'M', u'ȉ'), + (0x209, 'V'), + (0x20A, 'M', u'ȋ'), + (0x20B, 'V'), + (0x20C, 'M', u'ȍ'), + ] + +def _seg_5(): + return [ + (0x20D, 'V'), + (0x20E, 'M', u'ȏ'), + (0x20F, 'V'), + (0x210, 'M', u'ȑ'), + (0x211, 'V'), + (0x212, 'M', u'ȓ'), + (0x213, 'V'), + (0x214, 'M', u'ȕ'), + (0x215, 'V'), + (0x216, 'M', u'ȗ'), + (0x217, 'V'), + (0x218, 'M', u'ș'), + (0x219, 'V'), + (0x21A, 'M', u'ț'), + (0x21B, 'V'), + (0x21C, 'M', u'ȝ'), + (0x21D, 'V'), + (0x21E, 'M', u'ȟ'), + (0x21F, 'V'), + (0x220, 'M', u'ƞ'), + (0x221, 'V'), + (0x222, 'M', u'ȣ'), + (0x223, 'V'), + (0x224, 'M', u'ȥ'), + (0x225, 'V'), + (0x226, 'M', u'ȧ'), + (0x227, 'V'), + (0x228, 'M', u'ȩ'), + (0x229, 'V'), + (0x22A, 'M', u'ȫ'), + (0x22B, 'V'), + (0x22C, 'M', u'ȭ'), + (0x22D, 'V'), + (0x22E, 'M', u'ȯ'), + (0x22F, 'V'), + (0x230, 'M', u'ȱ'), + (0x231, 'V'), + (0x232, 'M', u'ȳ'), + (0x233, 'V'), + (0x23A, 'M', u'ⱥ'), + (0x23B, 'M', u'ȼ'), + (0x23C, 'V'), + (0x23D, 'M', u'ƚ'), + (0x23E, 'M', u'ⱦ'), + (0x23F, 'V'), + (0x241, 'M', u'ɂ'), + (0x242, 'V'), + (0x243, 'M', u'ƀ'), + (0x244, 'M', u'ʉ'), + (0x245, 'M', u'ʌ'), + (0x246, 'M', u'ɇ'), + (0x247, 'V'), + (0x248, 'M', u'ɉ'), + (0x249, 'V'), + (0x24A, 'M', u'ɋ'), + (0x24B, 'V'), + (0x24C, 'M', u'ɍ'), + (0x24D, 'V'), + (0x24E, 'M', u'ɏ'), + (0x24F, 'V'), + (0x2B0, 'M', u'h'), + (0x2B1, 'M', u'ɦ'), + (0x2B2, 'M', u'j'), + (0x2B3, 'M', u'r'), + (0x2B4, 'M', u'ɹ'), + (0x2B5, 'M', u'ɻ'), + (0x2B6, 'M', u'ʁ'), + (0x2B7, 'M', u'w'), + (0x2B8, 'M', u'y'), + (0x2B9, 'V'), + (0x2D8, '3', u' ̆'), + (0x2D9, '3', u' ̇'), + (0x2DA, '3', u' ̊'), + (0x2DB, '3', u' ̨'), + (0x2DC, '3', u' ̃'), + (0x2DD, '3', u' ̋'), + (0x2DE, 'V'), + (0x2E0, 'M', u'ɣ'), + (0x2E1, 'M', u'l'), + (0x2E2, 'M', u's'), + (0x2E3, 'M', u'x'), + (0x2E4, 'M', u'ʕ'), + (0x2E5, 'V'), + (0x340, 'M', u'̀'), + (0x341, 'M', u'́'), + (0x342, 'V'), + (0x343, 'M', u'̓'), + (0x344, 'M', u'̈́'), + (0x345, 'M', u'ι'), + (0x346, 'V'), + (0x34F, 'I'), + (0x350, 'V'), + (0x370, 'M', u'ͱ'), + (0x371, 'V'), + (0x372, 'M', u'ͳ'), + (0x373, 'V'), + (0x374, 'M', u'ʹ'), + (0x375, 'V'), + (0x376, 'M', u'ͷ'), + (0x377, 'V'), + ] + +def _seg_6(): + return [ + (0x378, 'X'), + (0x37A, '3', u' ι'), + (0x37B, 'V'), + (0x37E, '3', u';'), + (0x37F, 'M', u'ϳ'), + (0x380, 'X'), + (0x384, '3', u' ́'), + (0x385, '3', u' ̈́'), + (0x386, 'M', u'ά'), + (0x387, 'M', u'·'), + (0x388, 'M', u'έ'), + (0x389, 'M', u'ή'), + (0x38A, 'M', u'ί'), + (0x38B, 'X'), + (0x38C, 'M', u'ό'), + (0x38D, 'X'), + (0x38E, 'M', u'ύ'), + (0x38F, 'M', u'ώ'), + (0x390, 'V'), + (0x391, 'M', u'α'), + (0x392, 'M', u'β'), + (0x393, 'M', u'γ'), + (0x394, 'M', u'δ'), + (0x395, 'M', u'ε'), + (0x396, 'M', u'ζ'), + (0x397, 'M', u'η'), + (0x398, 'M', u'θ'), + (0x399, 'M', u'ι'), + (0x39A, 'M', u'κ'), + (0x39B, 'M', u'λ'), + (0x39C, 'M', u'μ'), + (0x39D, 'M', u'ν'), + (0x39E, 'M', u'ξ'), + (0x39F, 'M', u'ο'), + (0x3A0, 'M', u'π'), + (0x3A1, 'M', u'ρ'), + (0x3A2, 'X'), + (0x3A3, 'M', u'σ'), + (0x3A4, 'M', u'τ'), + (0x3A5, 'M', u'υ'), + (0x3A6, 'M', u'φ'), + (0x3A7, 'M', u'χ'), + (0x3A8, 'M', u'ψ'), + (0x3A9, 'M', u'ω'), + (0x3AA, 'M', u'ϊ'), + (0x3AB, 'M', u'ϋ'), + (0x3AC, 'V'), + (0x3C2, 'D', u'σ'), + (0x3C3, 'V'), + (0x3CF, 'M', u'ϗ'), + (0x3D0, 'M', u'β'), + (0x3D1, 'M', u'θ'), + (0x3D2, 'M', u'υ'), + (0x3D3, 'M', u'ύ'), + (0x3D4, 'M', u'ϋ'), + (0x3D5, 'M', u'φ'), + (0x3D6, 'M', u'π'), + (0x3D7, 'V'), + (0x3D8, 'M', u'ϙ'), + (0x3D9, 'V'), + (0x3DA, 'M', u'ϛ'), + (0x3DB, 'V'), + (0x3DC, 'M', u'ϝ'), + (0x3DD, 'V'), + (0x3DE, 'M', u'ϟ'), + (0x3DF, 'V'), + (0x3E0, 'M', u'ϡ'), + (0x3E1, 'V'), + (0x3E2, 'M', u'ϣ'), + (0x3E3, 'V'), + (0x3E4, 'M', u'ϥ'), + (0x3E5, 'V'), + (0x3E6, 'M', u'ϧ'), + (0x3E7, 'V'), + (0x3E8, 'M', u'ϩ'), + (0x3E9, 'V'), + (0x3EA, 'M', u'ϫ'), + (0x3EB, 'V'), + (0x3EC, 'M', u'ϭ'), + (0x3ED, 'V'), + (0x3EE, 'M', u'ϯ'), + (0x3EF, 'V'), + (0x3F0, 'M', u'κ'), + (0x3F1, 'M', u'ρ'), + (0x3F2, 'M', u'σ'), + (0x3F3, 'V'), + (0x3F4, 'M', u'θ'), + (0x3F5, 'M', u'ε'), + (0x3F6, 'V'), + (0x3F7, 'M', u'ϸ'), + (0x3F8, 'V'), + (0x3F9, 'M', u'σ'), + (0x3FA, 'M', u'ϻ'), + (0x3FB, 'V'), + (0x3FD, 'M', u'ͻ'), + (0x3FE, 'M', u'ͼ'), + (0x3FF, 'M', u'ͽ'), + (0x400, 'M', u'ѐ'), + (0x401, 'M', u'ё'), + (0x402, 'M', u'ђ'), + ] + +def _seg_7(): + return [ + (0x403, 'M', u'ѓ'), + (0x404, 'M', u'є'), + (0x405, 'M', u'ѕ'), + (0x406, 'M', u'і'), + (0x407, 'M', u'ї'), + (0x408, 'M', u'ј'), + (0x409, 'M', u'љ'), + (0x40A, 'M', u'њ'), + (0x40B, 'M', u'ћ'), + (0x40C, 'M', u'ќ'), + (0x40D, 'M', u'ѝ'), + (0x40E, 'M', u'ў'), + (0x40F, 'M', u'џ'), + (0x410, 'M', u'а'), + (0x411, 'M', u'б'), + (0x412, 'M', u'в'), + (0x413, 'M', u'г'), + (0x414, 'M', u'д'), + (0x415, 'M', u'е'), + (0x416, 'M', u'ж'), + (0x417, 'M', u'з'), + (0x418, 'M', u'и'), + (0x419, 'M', u'й'), + (0x41A, 'M', u'к'), + (0x41B, 'M', u'л'), + (0x41C, 'M', u'м'), + (0x41D, 'M', u'н'), + (0x41E, 'M', u'о'), + (0x41F, 'M', u'п'), + (0x420, 'M', u'р'), + (0x421, 'M', u'с'), + (0x422, 'M', u'т'), + (0x423, 'M', u'у'), + (0x424, 'M', u'ф'), + (0x425, 'M', u'х'), + (0x426, 'M', u'ц'), + (0x427, 'M', u'ч'), + (0x428, 'M', u'ш'), + (0x429, 'M', u'щ'), + (0x42A, 'M', u'ъ'), + (0x42B, 'M', u'ы'), + (0x42C, 'M', u'ь'), + (0x42D, 'M', u'э'), + (0x42E, 'M', u'ю'), + (0x42F, 'M', u'я'), + (0x430, 'V'), + (0x460, 'M', u'ѡ'), + (0x461, 'V'), + (0x462, 'M', u'ѣ'), + (0x463, 'V'), + (0x464, 'M', u'ѥ'), + (0x465, 'V'), + (0x466, 'M', u'ѧ'), + (0x467, 'V'), + (0x468, 'M', u'ѩ'), + (0x469, 'V'), + (0x46A, 'M', u'ѫ'), + (0x46B, 'V'), + (0x46C, 'M', u'ѭ'), + (0x46D, 'V'), + (0x46E, 'M', u'ѯ'), + (0x46F, 'V'), + (0x470, 'M', u'ѱ'), + (0x471, 'V'), + (0x472, 'M', u'ѳ'), + (0x473, 'V'), + (0x474, 'M', u'ѵ'), + (0x475, 'V'), + (0x476, 'M', u'ѷ'), + (0x477, 'V'), + (0x478, 'M', u'ѹ'), + (0x479, 'V'), + (0x47A, 'M', u'ѻ'), + (0x47B, 'V'), + (0x47C, 'M', u'ѽ'), + (0x47D, 'V'), + (0x47E, 'M', u'ѿ'), + (0x47F, 'V'), + (0x480, 'M', u'ҁ'), + (0x481, 'V'), + (0x48A, 'M', u'ҋ'), + (0x48B, 'V'), + (0x48C, 'M', u'ҍ'), + (0x48D, 'V'), + (0x48E, 'M', u'ҏ'), + (0x48F, 'V'), + (0x490, 'M', u'ґ'), + (0x491, 'V'), + (0x492, 'M', u'ғ'), + (0x493, 'V'), + (0x494, 'M', u'ҕ'), + (0x495, 'V'), + (0x496, 'M', u'җ'), + (0x497, 'V'), + (0x498, 'M', u'ҙ'), + (0x499, 'V'), + (0x49A, 'M', u'қ'), + (0x49B, 'V'), + (0x49C, 'M', u'ҝ'), + (0x49D, 'V'), + ] + +def _seg_8(): + return [ + (0x49E, 'M', u'ҟ'), + (0x49F, 'V'), + (0x4A0, 'M', u'ҡ'), + (0x4A1, 'V'), + (0x4A2, 'M', u'ң'), + (0x4A3, 'V'), + (0x4A4, 'M', u'ҥ'), + (0x4A5, 'V'), + (0x4A6, 'M', u'ҧ'), + (0x4A7, 'V'), + (0x4A8, 'M', u'ҩ'), + (0x4A9, 'V'), + (0x4AA, 'M', u'ҫ'), + (0x4AB, 'V'), + (0x4AC, 'M', u'ҭ'), + (0x4AD, 'V'), + (0x4AE, 'M', u'ү'), + (0x4AF, 'V'), + (0x4B0, 'M', u'ұ'), + (0x4B1, 'V'), + (0x4B2, 'M', u'ҳ'), + (0x4B3, 'V'), + (0x4B4, 'M', u'ҵ'), + (0x4B5, 'V'), + (0x4B6, 'M', u'ҷ'), + (0x4B7, 'V'), + (0x4B8, 'M', u'ҹ'), + (0x4B9, 'V'), + (0x4BA, 'M', u'һ'), + (0x4BB, 'V'), + (0x4BC, 'M', u'ҽ'), + (0x4BD, 'V'), + (0x4BE, 'M', u'ҿ'), + (0x4BF, 'V'), + (0x4C0, 'X'), + (0x4C1, 'M', u'ӂ'), + (0x4C2, 'V'), + (0x4C3, 'M', u'ӄ'), + (0x4C4, 'V'), + (0x4C5, 'M', u'ӆ'), + (0x4C6, 'V'), + (0x4C7, 'M', u'ӈ'), + (0x4C8, 'V'), + (0x4C9, 'M', u'ӊ'), + (0x4CA, 'V'), + (0x4CB, 'M', u'ӌ'), + (0x4CC, 'V'), + (0x4CD, 'M', u'ӎ'), + (0x4CE, 'V'), + (0x4D0, 'M', u'ӑ'), + (0x4D1, 'V'), + (0x4D2, 'M', u'ӓ'), + (0x4D3, 'V'), + (0x4D4, 'M', u'ӕ'), + (0x4D5, 'V'), + (0x4D6, 'M', u'ӗ'), + (0x4D7, 'V'), + (0x4D8, 'M', u'ә'), + (0x4D9, 'V'), + (0x4DA, 'M', u'ӛ'), + (0x4DB, 'V'), + (0x4DC, 'M', u'ӝ'), + (0x4DD, 'V'), + (0x4DE, 'M', u'ӟ'), + (0x4DF, 'V'), + (0x4E0, 'M', u'ӡ'), + (0x4E1, 'V'), + (0x4E2, 'M', u'ӣ'), + (0x4E3, 'V'), + (0x4E4, 'M', u'ӥ'), + (0x4E5, 'V'), + (0x4E6, 'M', u'ӧ'), + (0x4E7, 'V'), + (0x4E8, 'M', u'ө'), + (0x4E9, 'V'), + (0x4EA, 'M', u'ӫ'), + (0x4EB, 'V'), + (0x4EC, 'M', u'ӭ'), + (0x4ED, 'V'), + (0x4EE, 'M', u'ӯ'), + (0x4EF, 'V'), + (0x4F0, 'M', u'ӱ'), + (0x4F1, 'V'), + (0x4F2, 'M', u'ӳ'), + (0x4F3, 'V'), + (0x4F4, 'M', u'ӵ'), + (0x4F5, 'V'), + (0x4F6, 'M', u'ӷ'), + (0x4F7, 'V'), + (0x4F8, 'M', u'ӹ'), + (0x4F9, 'V'), + (0x4FA, 'M', u'ӻ'), + (0x4FB, 'V'), + (0x4FC, 'M', u'ӽ'), + (0x4FD, 'V'), + (0x4FE, 'M', u'ӿ'), + (0x4FF, 'V'), + (0x500, 'M', u'ԁ'), + (0x501, 'V'), + (0x502, 'M', u'ԃ'), + ] + +def _seg_9(): + return [ + (0x503, 'V'), + (0x504, 'M', u'ԅ'), + (0x505, 'V'), + (0x506, 'M', u'ԇ'), + (0x507, 'V'), + (0x508, 'M', u'ԉ'), + (0x509, 'V'), + (0x50A, 'M', u'ԋ'), + (0x50B, 'V'), + (0x50C, 'M', u'ԍ'), + (0x50D, 'V'), + (0x50E, 'M', u'ԏ'), + (0x50F, 'V'), + (0x510, 'M', u'ԑ'), + (0x511, 'V'), + (0x512, 'M', u'ԓ'), + (0x513, 'V'), + (0x514, 'M', u'ԕ'), + (0x515, 'V'), + (0x516, 'M', u'ԗ'), + (0x517, 'V'), + (0x518, 'M', u'ԙ'), + (0x519, 'V'), + (0x51A, 'M', u'ԛ'), + (0x51B, 'V'), + (0x51C, 'M', u'ԝ'), + (0x51D, 'V'), + (0x51E, 'M', u'ԟ'), + (0x51F, 'V'), + (0x520, 'M', u'ԡ'), + (0x521, 'V'), + (0x522, 'M', u'ԣ'), + (0x523, 'V'), + (0x524, 'M', u'ԥ'), + (0x525, 'V'), + (0x526, 'M', u'ԧ'), + (0x527, 'V'), + (0x528, 'M', u'ԩ'), + (0x529, 'V'), + (0x52A, 'M', u'ԫ'), + (0x52B, 'V'), + (0x52C, 'M', u'ԭ'), + (0x52D, 'V'), + (0x52E, 'M', u'ԯ'), + (0x52F, 'V'), + (0x530, 'X'), + (0x531, 'M', u'ա'), + (0x532, 'M', u'բ'), + (0x533, 'M', u'գ'), + (0x534, 'M', u'դ'), + (0x535, 'M', u'ե'), + (0x536, 'M', u'զ'), + (0x537, 'M', u'է'), + (0x538, 'M', u'ը'), + (0x539, 'M', u'թ'), + (0x53A, 'M', u'ժ'), + (0x53B, 'M', u'ի'), + (0x53C, 'M', u'լ'), + (0x53D, 'M', u'խ'), + (0x53E, 'M', u'ծ'), + (0x53F, 'M', u'կ'), + (0x540, 'M', u'հ'), + (0x541, 'M', u'ձ'), + (0x542, 'M', u'ղ'), + (0x543, 'M', u'ճ'), + (0x544, 'M', u'մ'), + (0x545, 'M', u'յ'), + (0x546, 'M', u'ն'), + (0x547, 'M', u'շ'), + (0x548, 'M', u'ո'), + (0x549, 'M', u'չ'), + (0x54A, 'M', u'պ'), + (0x54B, 'M', u'ջ'), + (0x54C, 'M', u'ռ'), + (0x54D, 'M', u'ս'), + (0x54E, 'M', u'վ'), + (0x54F, 'M', u'տ'), + (0x550, 'M', u'ր'), + (0x551, 'M', u'ց'), + (0x552, 'M', u'ւ'), + (0x553, 'M', u'փ'), + (0x554, 'M', u'ք'), + (0x555, 'M', u'օ'), + (0x556, 'M', u'ֆ'), + (0x557, 'X'), + (0x559, 'V'), + (0x587, 'M', u'եւ'), + (0x588, 'V'), + (0x58B, 'X'), + (0x58D, 'V'), + (0x590, 'X'), + (0x591, 'V'), + (0x5C8, 'X'), + (0x5D0, 'V'), + (0x5EB, 'X'), + (0x5EF, 'V'), + (0x5F5, 'X'), + (0x606, 'V'), + (0x61C, 'X'), + (0x61E, 'V'), + ] + +def _seg_10(): + return [ + (0x675, 'M', u'اٴ'), + (0x676, 'M', u'وٴ'), + (0x677, 'M', u'ۇٴ'), + (0x678, 'M', u'يٴ'), + (0x679, 'V'), + (0x6DD, 'X'), + (0x6DE, 'V'), + (0x70E, 'X'), + (0x710, 'V'), + (0x74B, 'X'), + (0x74D, 'V'), + (0x7B2, 'X'), + (0x7C0, 'V'), + (0x7FB, 'X'), + (0x7FD, 'V'), + (0x82E, 'X'), + (0x830, 'V'), + (0x83F, 'X'), + (0x840, 'V'), + (0x85C, 'X'), + (0x85E, 'V'), + (0x85F, 'X'), + (0x860, 'V'), + (0x86B, 'X'), + (0x8A0, 'V'), + (0x8B5, 'X'), + (0x8B6, 'V'), + (0x8BE, 'X'), + (0x8D3, 'V'), + (0x8E2, 'X'), + (0x8E3, 'V'), + (0x958, 'M', u'क़'), + (0x959, 'M', u'ख़'), + (0x95A, 'M', u'ग़'), + (0x95B, 'M', u'ज़'), + (0x95C, 'M', u'ड़'), + (0x95D, 'M', u'ढ़'), + (0x95E, 'M', u'फ़'), + (0x95F, 'M', u'य़'), + (0x960, 'V'), + (0x984, 'X'), + (0x985, 'V'), + (0x98D, 'X'), + (0x98F, 'V'), + (0x991, 'X'), + (0x993, 'V'), + (0x9A9, 'X'), + (0x9AA, 'V'), + (0x9B1, 'X'), + (0x9B2, 'V'), + (0x9B3, 'X'), + (0x9B6, 'V'), + (0x9BA, 'X'), + (0x9BC, 'V'), + (0x9C5, 'X'), + (0x9C7, 'V'), + (0x9C9, 'X'), + (0x9CB, 'V'), + (0x9CF, 'X'), + (0x9D7, 'V'), + (0x9D8, 'X'), + (0x9DC, 'M', u'ড়'), + (0x9DD, 'M', u'ঢ়'), + (0x9DE, 'X'), + (0x9DF, 'M', u'য়'), + (0x9E0, 'V'), + (0x9E4, 'X'), + (0x9E6, 'V'), + (0x9FF, 'X'), + (0xA01, 'V'), + (0xA04, 'X'), + (0xA05, 'V'), + (0xA0B, 'X'), + (0xA0F, 'V'), + (0xA11, 'X'), + (0xA13, 'V'), + (0xA29, 'X'), + (0xA2A, 'V'), + (0xA31, 'X'), + (0xA32, 'V'), + (0xA33, 'M', u'ਲ਼'), + (0xA34, 'X'), + (0xA35, 'V'), + (0xA36, 'M', u'ਸ਼'), + (0xA37, 'X'), + (0xA38, 'V'), + (0xA3A, 'X'), + (0xA3C, 'V'), + (0xA3D, 'X'), + (0xA3E, 'V'), + (0xA43, 'X'), + (0xA47, 'V'), + (0xA49, 'X'), + (0xA4B, 'V'), + (0xA4E, 'X'), + (0xA51, 'V'), + (0xA52, 'X'), + (0xA59, 'M', u'ਖ਼'), + (0xA5A, 'M', u'ਗ਼'), + (0xA5B, 'M', u'ਜ਼'), + ] + +def _seg_11(): + return [ + (0xA5C, 'V'), + (0xA5D, 'X'), + (0xA5E, 'M', u'ਫ਼'), + (0xA5F, 'X'), + (0xA66, 'V'), + (0xA77, 'X'), + (0xA81, 'V'), + (0xA84, 'X'), + (0xA85, 'V'), + (0xA8E, 'X'), + (0xA8F, 'V'), + (0xA92, 'X'), + (0xA93, 'V'), + (0xAA9, 'X'), + (0xAAA, 'V'), + (0xAB1, 'X'), + (0xAB2, 'V'), + (0xAB4, 'X'), + (0xAB5, 'V'), + (0xABA, 'X'), + (0xABC, 'V'), + (0xAC6, 'X'), + (0xAC7, 'V'), + (0xACA, 'X'), + (0xACB, 'V'), + (0xACE, 'X'), + (0xAD0, 'V'), + (0xAD1, 'X'), + (0xAE0, 'V'), + (0xAE4, 'X'), + (0xAE6, 'V'), + (0xAF2, 'X'), + (0xAF9, 'V'), + (0xB00, 'X'), + (0xB01, 'V'), + (0xB04, 'X'), + (0xB05, 'V'), + (0xB0D, 'X'), + (0xB0F, 'V'), + (0xB11, 'X'), + (0xB13, 'V'), + (0xB29, 'X'), + (0xB2A, 'V'), + (0xB31, 'X'), + (0xB32, 'V'), + (0xB34, 'X'), + (0xB35, 'V'), + (0xB3A, 'X'), + (0xB3C, 'V'), + (0xB45, 'X'), + (0xB47, 'V'), + (0xB49, 'X'), + (0xB4B, 'V'), + (0xB4E, 'X'), + (0xB56, 'V'), + (0xB58, 'X'), + (0xB5C, 'M', u'ଡ଼'), + (0xB5D, 'M', u'ଢ଼'), + (0xB5E, 'X'), + (0xB5F, 'V'), + (0xB64, 'X'), + (0xB66, 'V'), + (0xB78, 'X'), + (0xB82, 'V'), + (0xB84, 'X'), + (0xB85, 'V'), + (0xB8B, 'X'), + (0xB8E, 'V'), + (0xB91, 'X'), + (0xB92, 'V'), + (0xB96, 'X'), + (0xB99, 'V'), + (0xB9B, 'X'), + (0xB9C, 'V'), + (0xB9D, 'X'), + (0xB9E, 'V'), + (0xBA0, 'X'), + (0xBA3, 'V'), + (0xBA5, 'X'), + (0xBA8, 'V'), + (0xBAB, 'X'), + (0xBAE, 'V'), + (0xBBA, 'X'), + (0xBBE, 'V'), + (0xBC3, 'X'), + (0xBC6, 'V'), + (0xBC9, 'X'), + (0xBCA, 'V'), + (0xBCE, 'X'), + (0xBD0, 'V'), + (0xBD1, 'X'), + (0xBD7, 'V'), + (0xBD8, 'X'), + (0xBE6, 'V'), + (0xBFB, 'X'), + (0xC00, 'V'), + (0xC0D, 'X'), + (0xC0E, 'V'), + (0xC11, 'X'), + (0xC12, 'V'), + ] + +def _seg_12(): + return [ + (0xC29, 'X'), + (0xC2A, 'V'), + (0xC3A, 'X'), + (0xC3D, 'V'), + (0xC45, 'X'), + (0xC46, 'V'), + (0xC49, 'X'), + (0xC4A, 'V'), + (0xC4E, 'X'), + (0xC55, 'V'), + (0xC57, 'X'), + (0xC58, 'V'), + (0xC5B, 'X'), + (0xC60, 'V'), + (0xC64, 'X'), + (0xC66, 'V'), + (0xC70, 'X'), + (0xC78, 'V'), + (0xC8D, 'X'), + (0xC8E, 'V'), + (0xC91, 'X'), + (0xC92, 'V'), + (0xCA9, 'X'), + (0xCAA, 'V'), + (0xCB4, 'X'), + (0xCB5, 'V'), + (0xCBA, 'X'), + (0xCBC, 'V'), + (0xCC5, 'X'), + (0xCC6, 'V'), + (0xCC9, 'X'), + (0xCCA, 'V'), + (0xCCE, 'X'), + (0xCD5, 'V'), + (0xCD7, 'X'), + (0xCDE, 'V'), + (0xCDF, 'X'), + (0xCE0, 'V'), + (0xCE4, 'X'), + (0xCE6, 'V'), + (0xCF0, 'X'), + (0xCF1, 'V'), + (0xCF3, 'X'), + (0xD00, 'V'), + (0xD04, 'X'), + (0xD05, 'V'), + (0xD0D, 'X'), + (0xD0E, 'V'), + (0xD11, 'X'), + (0xD12, 'V'), + (0xD45, 'X'), + (0xD46, 'V'), + (0xD49, 'X'), + (0xD4A, 'V'), + (0xD50, 'X'), + (0xD54, 'V'), + (0xD64, 'X'), + (0xD66, 'V'), + (0xD80, 'X'), + (0xD82, 'V'), + (0xD84, 'X'), + (0xD85, 'V'), + (0xD97, 'X'), + (0xD9A, 'V'), + (0xDB2, 'X'), + (0xDB3, 'V'), + (0xDBC, 'X'), + (0xDBD, 'V'), + (0xDBE, 'X'), + (0xDC0, 'V'), + (0xDC7, 'X'), + (0xDCA, 'V'), + (0xDCB, 'X'), + (0xDCF, 'V'), + (0xDD5, 'X'), + (0xDD6, 'V'), + (0xDD7, 'X'), + (0xDD8, 'V'), + (0xDE0, 'X'), + (0xDE6, 'V'), + (0xDF0, 'X'), + (0xDF2, 'V'), + (0xDF5, 'X'), + (0xE01, 'V'), + (0xE33, 'M', u'ํา'), + (0xE34, 'V'), + (0xE3B, 'X'), + (0xE3F, 'V'), + (0xE5C, 'X'), + (0xE81, 'V'), + (0xE83, 'X'), + (0xE84, 'V'), + (0xE85, 'X'), + (0xE87, 'V'), + (0xE89, 'X'), + (0xE8A, 'V'), + (0xE8B, 'X'), + (0xE8D, 'V'), + (0xE8E, 'X'), + (0xE94, 'V'), + ] + +def _seg_13(): + return [ + (0xE98, 'X'), + (0xE99, 'V'), + (0xEA0, 'X'), + (0xEA1, 'V'), + (0xEA4, 'X'), + (0xEA5, 'V'), + (0xEA6, 'X'), + (0xEA7, 'V'), + (0xEA8, 'X'), + (0xEAA, 'V'), + (0xEAC, 'X'), + (0xEAD, 'V'), + (0xEB3, 'M', u'ໍາ'), + (0xEB4, 'V'), + (0xEBA, 'X'), + (0xEBB, 'V'), + (0xEBE, 'X'), + (0xEC0, 'V'), + (0xEC5, 'X'), + (0xEC6, 'V'), + (0xEC7, 'X'), + (0xEC8, 'V'), + (0xECE, 'X'), + (0xED0, 'V'), + (0xEDA, 'X'), + (0xEDC, 'M', u'ຫນ'), + (0xEDD, 'M', u'ຫມ'), + (0xEDE, 'V'), + (0xEE0, 'X'), + (0xF00, 'V'), + (0xF0C, 'M', u'་'), + (0xF0D, 'V'), + (0xF43, 'M', u'གྷ'), + (0xF44, 'V'), + (0xF48, 'X'), + (0xF49, 'V'), + (0xF4D, 'M', u'ཌྷ'), + (0xF4E, 'V'), + (0xF52, 'M', u'དྷ'), + (0xF53, 'V'), + (0xF57, 'M', u'བྷ'), + (0xF58, 'V'), + (0xF5C, 'M', u'ཛྷ'), + (0xF5D, 'V'), + (0xF69, 'M', u'ཀྵ'), + (0xF6A, 'V'), + (0xF6D, 'X'), + (0xF71, 'V'), + (0xF73, 'M', u'ཱི'), + (0xF74, 'V'), + (0xF75, 'M', u'ཱུ'), + (0xF76, 'M', u'ྲྀ'), + (0xF77, 'M', u'ྲཱྀ'), + (0xF78, 'M', u'ླྀ'), + (0xF79, 'M', u'ླཱྀ'), + (0xF7A, 'V'), + (0xF81, 'M', u'ཱྀ'), + (0xF82, 'V'), + (0xF93, 'M', u'ྒྷ'), + (0xF94, 'V'), + (0xF98, 'X'), + (0xF99, 'V'), + (0xF9D, 'M', u'ྜྷ'), + (0xF9E, 'V'), + (0xFA2, 'M', u'ྡྷ'), + (0xFA3, 'V'), + (0xFA7, 'M', u'ྦྷ'), + (0xFA8, 'V'), + (0xFAC, 'M', u'ྫྷ'), + (0xFAD, 'V'), + (0xFB9, 'M', u'ྐྵ'), + (0xFBA, 'V'), + (0xFBD, 'X'), + (0xFBE, 'V'), + (0xFCD, 'X'), + (0xFCE, 'V'), + (0xFDB, 'X'), + (0x1000, 'V'), + (0x10A0, 'X'), + (0x10C7, 'M', u'ⴧ'), + (0x10C8, 'X'), + (0x10CD, 'M', u'ⴭ'), + (0x10CE, 'X'), + (0x10D0, 'V'), + (0x10FC, 'M', u'ნ'), + (0x10FD, 'V'), + (0x115F, 'X'), + (0x1161, 'V'), + (0x1249, 'X'), + (0x124A, 'V'), + (0x124E, 'X'), + (0x1250, 'V'), + (0x1257, 'X'), + (0x1258, 'V'), + (0x1259, 'X'), + (0x125A, 'V'), + (0x125E, 'X'), + (0x1260, 'V'), + (0x1289, 'X'), + (0x128A, 'V'), + ] + +def _seg_14(): + return [ + (0x128E, 'X'), + (0x1290, 'V'), + (0x12B1, 'X'), + (0x12B2, 'V'), + (0x12B6, 'X'), + (0x12B8, 'V'), + (0x12BF, 'X'), + (0x12C0, 'V'), + (0x12C1, 'X'), + (0x12C2, 'V'), + (0x12C6, 'X'), + (0x12C8, 'V'), + (0x12D7, 'X'), + (0x12D8, 'V'), + (0x1311, 'X'), + (0x1312, 'V'), + (0x1316, 'X'), + (0x1318, 'V'), + (0x135B, 'X'), + (0x135D, 'V'), + (0x137D, 'X'), + (0x1380, 'V'), + (0x139A, 'X'), + (0x13A0, 'V'), + (0x13F6, 'X'), + (0x13F8, 'M', u'Ᏸ'), + (0x13F9, 'M', u'Ᏹ'), + (0x13FA, 'M', u'Ᏺ'), + (0x13FB, 'M', u'Ᏻ'), + (0x13FC, 'M', u'Ᏼ'), + (0x13FD, 'M', u'Ᏽ'), + (0x13FE, 'X'), + (0x1400, 'V'), + (0x1680, 'X'), + (0x1681, 'V'), + (0x169D, 'X'), + (0x16A0, 'V'), + (0x16F9, 'X'), + (0x1700, 'V'), + (0x170D, 'X'), + (0x170E, 'V'), + (0x1715, 'X'), + (0x1720, 'V'), + (0x1737, 'X'), + (0x1740, 'V'), + (0x1754, 'X'), + (0x1760, 'V'), + (0x176D, 'X'), + (0x176E, 'V'), + (0x1771, 'X'), + (0x1772, 'V'), + (0x1774, 'X'), + (0x1780, 'V'), + (0x17B4, 'X'), + (0x17B6, 'V'), + (0x17DE, 'X'), + (0x17E0, 'V'), + (0x17EA, 'X'), + (0x17F0, 'V'), + (0x17FA, 'X'), + (0x1800, 'V'), + (0x1806, 'X'), + (0x1807, 'V'), + (0x180B, 'I'), + (0x180E, 'X'), + (0x1810, 'V'), + (0x181A, 'X'), + (0x1820, 'V'), + (0x1879, 'X'), + (0x1880, 'V'), + (0x18AB, 'X'), + (0x18B0, 'V'), + (0x18F6, 'X'), + (0x1900, 'V'), + (0x191F, 'X'), + (0x1920, 'V'), + (0x192C, 'X'), + (0x1930, 'V'), + (0x193C, 'X'), + (0x1940, 'V'), + (0x1941, 'X'), + (0x1944, 'V'), + (0x196E, 'X'), + (0x1970, 'V'), + (0x1975, 'X'), + (0x1980, 'V'), + (0x19AC, 'X'), + (0x19B0, 'V'), + (0x19CA, 'X'), + (0x19D0, 'V'), + (0x19DB, 'X'), + (0x19DE, 'V'), + (0x1A1C, 'X'), + (0x1A1E, 'V'), + (0x1A5F, 'X'), + (0x1A60, 'V'), + (0x1A7D, 'X'), + (0x1A7F, 'V'), + (0x1A8A, 'X'), + (0x1A90, 'V'), + ] + +def _seg_15(): + return [ + (0x1A9A, 'X'), + (0x1AA0, 'V'), + (0x1AAE, 'X'), + (0x1AB0, 'V'), + (0x1ABF, 'X'), + (0x1B00, 'V'), + (0x1B4C, 'X'), + (0x1B50, 'V'), + (0x1B7D, 'X'), + (0x1B80, 'V'), + (0x1BF4, 'X'), + (0x1BFC, 'V'), + (0x1C38, 'X'), + (0x1C3B, 'V'), + (0x1C4A, 'X'), + (0x1C4D, 'V'), + (0x1C80, 'M', u'в'), + (0x1C81, 'M', u'д'), + (0x1C82, 'M', u'о'), + (0x1C83, 'M', u'с'), + (0x1C84, 'M', u'т'), + (0x1C86, 'M', u'ъ'), + (0x1C87, 'M', u'ѣ'), + (0x1C88, 'M', u'ꙋ'), + (0x1C89, 'X'), + (0x1CC0, 'V'), + (0x1CC8, 'X'), + (0x1CD0, 'V'), + (0x1CFA, 'X'), + (0x1D00, 'V'), + (0x1D2C, 'M', u'a'), + (0x1D2D, 'M', u'æ'), + (0x1D2E, 'M', u'b'), + (0x1D2F, 'V'), + (0x1D30, 'M', u'd'), + (0x1D31, 'M', u'e'), + (0x1D32, 'M', u'ǝ'), + (0x1D33, 'M', u'g'), + (0x1D34, 'M', u'h'), + (0x1D35, 'M', u'i'), + (0x1D36, 'M', u'j'), + (0x1D37, 'M', u'k'), + (0x1D38, 'M', u'l'), + (0x1D39, 'M', u'm'), + (0x1D3A, 'M', u'n'), + (0x1D3B, 'V'), + (0x1D3C, 'M', u'o'), + (0x1D3D, 'M', u'ȣ'), + (0x1D3E, 'M', u'p'), + (0x1D3F, 'M', u'r'), + (0x1D40, 'M', u't'), + (0x1D41, 'M', u'u'), + (0x1D42, 'M', u'w'), + (0x1D43, 'M', u'a'), + (0x1D44, 'M', u'ɐ'), + (0x1D45, 'M', u'ɑ'), + (0x1D46, 'M', u'ᴂ'), + (0x1D47, 'M', u'b'), + (0x1D48, 'M', u'd'), + (0x1D49, 'M', u'e'), + (0x1D4A, 'M', u'ə'), + (0x1D4B, 'M', u'ɛ'), + (0x1D4C, 'M', u'ɜ'), + (0x1D4D, 'M', u'g'), + (0x1D4E, 'V'), + (0x1D4F, 'M', u'k'), + (0x1D50, 'M', u'm'), + (0x1D51, 'M', u'ŋ'), + (0x1D52, 'M', u'o'), + (0x1D53, 'M', u'ɔ'), + (0x1D54, 'M', u'ᴖ'), + (0x1D55, 'M', u'ᴗ'), + (0x1D56, 'M', u'p'), + (0x1D57, 'M', u't'), + (0x1D58, 'M', u'u'), + (0x1D59, 'M', u'ᴝ'), + (0x1D5A, 'M', u'ɯ'), + (0x1D5B, 'M', u'v'), + (0x1D5C, 'M', u'ᴥ'), + (0x1D5D, 'M', u'β'), + (0x1D5E, 'M', u'γ'), + (0x1D5F, 'M', u'δ'), + (0x1D60, 'M', u'φ'), + (0x1D61, 'M', u'χ'), + (0x1D62, 'M', u'i'), + (0x1D63, 'M', u'r'), + (0x1D64, 'M', u'u'), + (0x1D65, 'M', u'v'), + (0x1D66, 'M', u'β'), + (0x1D67, 'M', u'γ'), + (0x1D68, 'M', u'ρ'), + (0x1D69, 'M', u'φ'), + (0x1D6A, 'M', u'χ'), + (0x1D6B, 'V'), + (0x1D78, 'M', u'н'), + (0x1D79, 'V'), + (0x1D9B, 'M', u'ɒ'), + (0x1D9C, 'M', u'c'), + (0x1D9D, 'M', u'ɕ'), + (0x1D9E, 'M', u'ð'), + ] + +def _seg_16(): + return [ + (0x1D9F, 'M', u'ɜ'), + (0x1DA0, 'M', u'f'), + (0x1DA1, 'M', u'ɟ'), + (0x1DA2, 'M', u'ɡ'), + (0x1DA3, 'M', u'ɥ'), + (0x1DA4, 'M', u'ɨ'), + (0x1DA5, 'M', u'ɩ'), + (0x1DA6, 'M', u'ɪ'), + (0x1DA7, 'M', u'ᵻ'), + (0x1DA8, 'M', u'ʝ'), + (0x1DA9, 'M', u'ɭ'), + (0x1DAA, 'M', u'ᶅ'), + (0x1DAB, 'M', u'ʟ'), + (0x1DAC, 'M', u'ɱ'), + (0x1DAD, 'M', u'ɰ'), + (0x1DAE, 'M', u'ɲ'), + (0x1DAF, 'M', u'ɳ'), + (0x1DB0, 'M', u'ɴ'), + (0x1DB1, 'M', u'ɵ'), + (0x1DB2, 'M', u'ɸ'), + (0x1DB3, 'M', u'ʂ'), + (0x1DB4, 'M', u'ʃ'), + (0x1DB5, 'M', u'ƫ'), + (0x1DB6, 'M', u'ʉ'), + (0x1DB7, 'M', u'ʊ'), + (0x1DB8, 'M', u'ᴜ'), + (0x1DB9, 'M', u'ʋ'), + (0x1DBA, 'M', u'ʌ'), + (0x1DBB, 'M', u'z'), + (0x1DBC, 'M', u'ʐ'), + (0x1DBD, 'M', u'ʑ'), + (0x1DBE, 'M', u'ʒ'), + (0x1DBF, 'M', u'θ'), + (0x1DC0, 'V'), + (0x1DFA, 'X'), + (0x1DFB, 'V'), + (0x1E00, 'M', u'ḁ'), + (0x1E01, 'V'), + (0x1E02, 'M', u'ḃ'), + (0x1E03, 'V'), + (0x1E04, 'M', u'ḅ'), + (0x1E05, 'V'), + (0x1E06, 'M', u'ḇ'), + (0x1E07, 'V'), + (0x1E08, 'M', u'ḉ'), + (0x1E09, 'V'), + (0x1E0A, 'M', u'ḋ'), + (0x1E0B, 'V'), + (0x1E0C, 'M', u'ḍ'), + (0x1E0D, 'V'), + (0x1E0E, 'M', u'ḏ'), + (0x1E0F, 'V'), + (0x1E10, 'M', u'ḑ'), + (0x1E11, 'V'), + (0x1E12, 'M', u'ḓ'), + (0x1E13, 'V'), + (0x1E14, 'M', u'ḕ'), + (0x1E15, 'V'), + (0x1E16, 'M', u'ḗ'), + (0x1E17, 'V'), + (0x1E18, 'M', u'ḙ'), + (0x1E19, 'V'), + (0x1E1A, 'M', u'ḛ'), + (0x1E1B, 'V'), + (0x1E1C, 'M', u'ḝ'), + (0x1E1D, 'V'), + (0x1E1E, 'M', u'ḟ'), + (0x1E1F, 'V'), + (0x1E20, 'M', u'ḡ'), + (0x1E21, 'V'), + (0x1E22, 'M', u'ḣ'), + (0x1E23, 'V'), + (0x1E24, 'M', u'ḥ'), + (0x1E25, 'V'), + (0x1E26, 'M', u'ḧ'), + (0x1E27, 'V'), + (0x1E28, 'M', u'ḩ'), + (0x1E29, 'V'), + (0x1E2A, 'M', u'ḫ'), + (0x1E2B, 'V'), + (0x1E2C, 'M', u'ḭ'), + (0x1E2D, 'V'), + (0x1E2E, 'M', u'ḯ'), + (0x1E2F, 'V'), + (0x1E30, 'M', u'ḱ'), + (0x1E31, 'V'), + (0x1E32, 'M', u'ḳ'), + (0x1E33, 'V'), + (0x1E34, 'M', u'ḵ'), + (0x1E35, 'V'), + (0x1E36, 'M', u'ḷ'), + (0x1E37, 'V'), + (0x1E38, 'M', u'ḹ'), + (0x1E39, 'V'), + (0x1E3A, 'M', u'ḻ'), + (0x1E3B, 'V'), + (0x1E3C, 'M', u'ḽ'), + (0x1E3D, 'V'), + (0x1E3E, 'M', u'ḿ'), + (0x1E3F, 'V'), + ] + +def _seg_17(): + return [ + (0x1E40, 'M', u'ṁ'), + (0x1E41, 'V'), + (0x1E42, 'M', u'ṃ'), + (0x1E43, 'V'), + (0x1E44, 'M', u'ṅ'), + (0x1E45, 'V'), + (0x1E46, 'M', u'ṇ'), + (0x1E47, 'V'), + (0x1E48, 'M', u'ṉ'), + (0x1E49, 'V'), + (0x1E4A, 'M', u'ṋ'), + (0x1E4B, 'V'), + (0x1E4C, 'M', u'ṍ'), + (0x1E4D, 'V'), + (0x1E4E, 'M', u'ṏ'), + (0x1E4F, 'V'), + (0x1E50, 'M', u'ṑ'), + (0x1E51, 'V'), + (0x1E52, 'M', u'ṓ'), + (0x1E53, 'V'), + (0x1E54, 'M', u'ṕ'), + (0x1E55, 'V'), + (0x1E56, 'M', u'ṗ'), + (0x1E57, 'V'), + (0x1E58, 'M', u'ṙ'), + (0x1E59, 'V'), + (0x1E5A, 'M', u'ṛ'), + (0x1E5B, 'V'), + (0x1E5C, 'M', u'ṝ'), + (0x1E5D, 'V'), + (0x1E5E, 'M', u'ṟ'), + (0x1E5F, 'V'), + (0x1E60, 'M', u'ṡ'), + (0x1E61, 'V'), + (0x1E62, 'M', u'ṣ'), + (0x1E63, 'V'), + (0x1E64, 'M', u'ṥ'), + (0x1E65, 'V'), + (0x1E66, 'M', u'ṧ'), + (0x1E67, 'V'), + (0x1E68, 'M', u'ṩ'), + (0x1E69, 'V'), + (0x1E6A, 'M', u'ṫ'), + (0x1E6B, 'V'), + (0x1E6C, 'M', u'ṭ'), + (0x1E6D, 'V'), + (0x1E6E, 'M', u'ṯ'), + (0x1E6F, 'V'), + (0x1E70, 'M', u'ṱ'), + (0x1E71, 'V'), + (0x1E72, 'M', u'ṳ'), + (0x1E73, 'V'), + (0x1E74, 'M', u'ṵ'), + (0x1E75, 'V'), + (0x1E76, 'M', u'ṷ'), + (0x1E77, 'V'), + (0x1E78, 'M', u'ṹ'), + (0x1E79, 'V'), + (0x1E7A, 'M', u'ṻ'), + (0x1E7B, 'V'), + (0x1E7C, 'M', u'ṽ'), + (0x1E7D, 'V'), + (0x1E7E, 'M', u'ṿ'), + (0x1E7F, 'V'), + (0x1E80, 'M', u'ẁ'), + (0x1E81, 'V'), + (0x1E82, 'M', u'ẃ'), + (0x1E83, 'V'), + (0x1E84, 'M', u'ẅ'), + (0x1E85, 'V'), + (0x1E86, 'M', u'ẇ'), + (0x1E87, 'V'), + (0x1E88, 'M', u'ẉ'), + (0x1E89, 'V'), + (0x1E8A, 'M', u'ẋ'), + (0x1E8B, 'V'), + (0x1E8C, 'M', u'ẍ'), + (0x1E8D, 'V'), + (0x1E8E, 'M', u'ẏ'), + (0x1E8F, 'V'), + (0x1E90, 'M', u'ẑ'), + (0x1E91, 'V'), + (0x1E92, 'M', u'ẓ'), + (0x1E93, 'V'), + (0x1E94, 'M', u'ẕ'), + (0x1E95, 'V'), + (0x1E9A, 'M', u'aʾ'), + (0x1E9B, 'M', u'ṡ'), + (0x1E9C, 'V'), + (0x1E9E, 'M', u'ss'), + (0x1E9F, 'V'), + (0x1EA0, 'M', u'ạ'), + (0x1EA1, 'V'), + (0x1EA2, 'M', u'ả'), + (0x1EA3, 'V'), + (0x1EA4, 'M', u'ấ'), + (0x1EA5, 'V'), + (0x1EA6, 'M', u'ầ'), + (0x1EA7, 'V'), + (0x1EA8, 'M', u'ẩ'), + ] + +def _seg_18(): + return [ + (0x1EA9, 'V'), + (0x1EAA, 'M', u'ẫ'), + (0x1EAB, 'V'), + (0x1EAC, 'M', u'ậ'), + (0x1EAD, 'V'), + (0x1EAE, 'M', u'ắ'), + (0x1EAF, 'V'), + (0x1EB0, 'M', u'ằ'), + (0x1EB1, 'V'), + (0x1EB2, 'M', u'ẳ'), + (0x1EB3, 'V'), + (0x1EB4, 'M', u'ẵ'), + (0x1EB5, 'V'), + (0x1EB6, 'M', u'ặ'), + (0x1EB7, 'V'), + (0x1EB8, 'M', u'ẹ'), + (0x1EB9, 'V'), + (0x1EBA, 'M', u'ẻ'), + (0x1EBB, 'V'), + (0x1EBC, 'M', u'ẽ'), + (0x1EBD, 'V'), + (0x1EBE, 'M', u'ế'), + (0x1EBF, 'V'), + (0x1EC0, 'M', u'ề'), + (0x1EC1, 'V'), + (0x1EC2, 'M', u'ể'), + (0x1EC3, 'V'), + (0x1EC4, 'M', u'ễ'), + (0x1EC5, 'V'), + (0x1EC6, 'M', u'ệ'), + (0x1EC7, 'V'), + (0x1EC8, 'M', u'ỉ'), + (0x1EC9, 'V'), + (0x1ECA, 'M', u'ị'), + (0x1ECB, 'V'), + (0x1ECC, 'M', u'ọ'), + (0x1ECD, 'V'), + (0x1ECE, 'M', u'ỏ'), + (0x1ECF, 'V'), + (0x1ED0, 'M', u'ố'), + (0x1ED1, 'V'), + (0x1ED2, 'M', u'ồ'), + (0x1ED3, 'V'), + (0x1ED4, 'M', u'ổ'), + (0x1ED5, 'V'), + (0x1ED6, 'M', u'ỗ'), + (0x1ED7, 'V'), + (0x1ED8, 'M', u'ộ'), + (0x1ED9, 'V'), + (0x1EDA, 'M', u'ớ'), + (0x1EDB, 'V'), + (0x1EDC, 'M', u'ờ'), + (0x1EDD, 'V'), + (0x1EDE, 'M', u'ở'), + (0x1EDF, 'V'), + (0x1EE0, 'M', u'ỡ'), + (0x1EE1, 'V'), + (0x1EE2, 'M', u'ợ'), + (0x1EE3, 'V'), + (0x1EE4, 'M', u'ụ'), + (0x1EE5, 'V'), + (0x1EE6, 'M', u'ủ'), + (0x1EE7, 'V'), + (0x1EE8, 'M', u'ứ'), + (0x1EE9, 'V'), + (0x1EEA, 'M', u'ừ'), + (0x1EEB, 'V'), + (0x1EEC, 'M', u'ử'), + (0x1EED, 'V'), + (0x1EEE, 'M', u'ữ'), + (0x1EEF, 'V'), + (0x1EF0, 'M', u'ự'), + (0x1EF1, 'V'), + (0x1EF2, 'M', u'ỳ'), + (0x1EF3, 'V'), + (0x1EF4, 'M', u'ỵ'), + (0x1EF5, 'V'), + (0x1EF6, 'M', u'ỷ'), + (0x1EF7, 'V'), + (0x1EF8, 'M', u'ỹ'), + (0x1EF9, 'V'), + (0x1EFA, 'M', u'ỻ'), + (0x1EFB, 'V'), + (0x1EFC, 'M', u'ỽ'), + (0x1EFD, 'V'), + (0x1EFE, 'M', u'ỿ'), + (0x1EFF, 'V'), + (0x1F08, 'M', u'ἀ'), + (0x1F09, 'M', u'ἁ'), + (0x1F0A, 'M', u'ἂ'), + (0x1F0B, 'M', u'ἃ'), + (0x1F0C, 'M', u'ἄ'), + (0x1F0D, 'M', u'ἅ'), + (0x1F0E, 'M', u'ἆ'), + (0x1F0F, 'M', u'ἇ'), + (0x1F10, 'V'), + (0x1F16, 'X'), + (0x1F18, 'M', u'ἐ'), + (0x1F19, 'M', u'ἑ'), + (0x1F1A, 'M', u'ἒ'), + ] + +def _seg_19(): + return [ + (0x1F1B, 'M', u'ἓ'), + (0x1F1C, 'M', u'ἔ'), + (0x1F1D, 'M', u'ἕ'), + (0x1F1E, 'X'), + (0x1F20, 'V'), + (0x1F28, 'M', u'ἠ'), + (0x1F29, 'M', u'ἡ'), + (0x1F2A, 'M', u'ἢ'), + (0x1F2B, 'M', u'ἣ'), + (0x1F2C, 'M', u'ἤ'), + (0x1F2D, 'M', u'ἥ'), + (0x1F2E, 'M', u'ἦ'), + (0x1F2F, 'M', u'ἧ'), + (0x1F30, 'V'), + (0x1F38, 'M', u'ἰ'), + (0x1F39, 'M', u'ἱ'), + (0x1F3A, 'M', u'ἲ'), + (0x1F3B, 'M', u'ἳ'), + (0x1F3C, 'M', u'ἴ'), + (0x1F3D, 'M', u'ἵ'), + (0x1F3E, 'M', u'ἶ'), + (0x1F3F, 'M', u'ἷ'), + (0x1F40, 'V'), + (0x1F46, 'X'), + (0x1F48, 'M', u'ὀ'), + (0x1F49, 'M', u'ὁ'), + (0x1F4A, 'M', u'ὂ'), + (0x1F4B, 'M', u'ὃ'), + (0x1F4C, 'M', u'ὄ'), + (0x1F4D, 'M', u'ὅ'), + (0x1F4E, 'X'), + (0x1F50, 'V'), + (0x1F58, 'X'), + (0x1F59, 'M', u'ὑ'), + (0x1F5A, 'X'), + (0x1F5B, 'M', u'ὓ'), + (0x1F5C, 'X'), + (0x1F5D, 'M', u'ὕ'), + (0x1F5E, 'X'), + (0x1F5F, 'M', u'ὗ'), + (0x1F60, 'V'), + (0x1F68, 'M', u'ὠ'), + (0x1F69, 'M', u'ὡ'), + (0x1F6A, 'M', u'ὢ'), + (0x1F6B, 'M', u'ὣ'), + (0x1F6C, 'M', u'ὤ'), + (0x1F6D, 'M', u'ὥ'), + (0x1F6E, 'M', u'ὦ'), + (0x1F6F, 'M', u'ὧ'), + (0x1F70, 'V'), + (0x1F71, 'M', u'ά'), + (0x1F72, 'V'), + (0x1F73, 'M', u'έ'), + (0x1F74, 'V'), + (0x1F75, 'M', u'ή'), + (0x1F76, 'V'), + (0x1F77, 'M', u'ί'), + (0x1F78, 'V'), + (0x1F79, 'M', u'ό'), + (0x1F7A, 'V'), + (0x1F7B, 'M', u'ύ'), + (0x1F7C, 'V'), + (0x1F7D, 'M', u'ώ'), + (0x1F7E, 'X'), + (0x1F80, 'M', u'ἀι'), + (0x1F81, 'M', u'ἁι'), + (0x1F82, 'M', u'ἂι'), + (0x1F83, 'M', u'ἃι'), + (0x1F84, 'M', u'ἄι'), + (0x1F85, 'M', u'ἅι'), + (0x1F86, 'M', u'ἆι'), + (0x1F87, 'M', u'ἇι'), + (0x1F88, 'M', u'ἀι'), + (0x1F89, 'M', u'ἁι'), + (0x1F8A, 'M', u'ἂι'), + (0x1F8B, 'M', u'ἃι'), + (0x1F8C, 'M', u'ἄι'), + (0x1F8D, 'M', u'ἅι'), + (0x1F8E, 'M', u'ἆι'), + (0x1F8F, 'M', u'ἇι'), + (0x1F90, 'M', u'ἠι'), + (0x1F91, 'M', u'ἡι'), + (0x1F92, 'M', u'ἢι'), + (0x1F93, 'M', u'ἣι'), + (0x1F94, 'M', u'ἤι'), + (0x1F95, 'M', u'ἥι'), + (0x1F96, 'M', u'ἦι'), + (0x1F97, 'M', u'ἧι'), + (0x1F98, 'M', u'ἠι'), + (0x1F99, 'M', u'ἡι'), + (0x1F9A, 'M', u'ἢι'), + (0x1F9B, 'M', u'ἣι'), + (0x1F9C, 'M', u'ἤι'), + (0x1F9D, 'M', u'ἥι'), + (0x1F9E, 'M', u'ἦι'), + (0x1F9F, 'M', u'ἧι'), + (0x1FA0, 'M', u'ὠι'), + (0x1FA1, 'M', u'ὡι'), + (0x1FA2, 'M', u'ὢι'), + (0x1FA3, 'M', u'ὣι'), + ] + +def _seg_20(): + return [ + (0x1FA4, 'M', u'ὤι'), + (0x1FA5, 'M', u'ὥι'), + (0x1FA6, 'M', u'ὦι'), + (0x1FA7, 'M', u'ὧι'), + (0x1FA8, 'M', u'ὠι'), + (0x1FA9, 'M', u'ὡι'), + (0x1FAA, 'M', u'ὢι'), + (0x1FAB, 'M', u'ὣι'), + (0x1FAC, 'M', u'ὤι'), + (0x1FAD, 'M', u'ὥι'), + (0x1FAE, 'M', u'ὦι'), + (0x1FAF, 'M', u'ὧι'), + (0x1FB0, 'V'), + (0x1FB2, 'M', u'ὰι'), + (0x1FB3, 'M', u'αι'), + (0x1FB4, 'M', u'άι'), + (0x1FB5, 'X'), + (0x1FB6, 'V'), + (0x1FB7, 'M', u'ᾶι'), + (0x1FB8, 'M', u'ᾰ'), + (0x1FB9, 'M', u'ᾱ'), + (0x1FBA, 'M', u'ὰ'), + (0x1FBB, 'M', u'ά'), + (0x1FBC, 'M', u'αι'), + (0x1FBD, '3', u' ̓'), + (0x1FBE, 'M', u'ι'), + (0x1FBF, '3', u' ̓'), + (0x1FC0, '3', u' ͂'), + (0x1FC1, '3', u' ̈͂'), + (0x1FC2, 'M', u'ὴι'), + (0x1FC3, 'M', u'ηι'), + (0x1FC4, 'M', u'ήι'), + (0x1FC5, 'X'), + (0x1FC6, 'V'), + (0x1FC7, 'M', u'ῆι'), + (0x1FC8, 'M', u'ὲ'), + (0x1FC9, 'M', u'έ'), + (0x1FCA, 'M', u'ὴ'), + (0x1FCB, 'M', u'ή'), + (0x1FCC, 'M', u'ηι'), + (0x1FCD, '3', u' ̓̀'), + (0x1FCE, '3', u' ̓́'), + (0x1FCF, '3', u' ̓͂'), + (0x1FD0, 'V'), + (0x1FD3, 'M', u'ΐ'), + (0x1FD4, 'X'), + (0x1FD6, 'V'), + (0x1FD8, 'M', u'ῐ'), + (0x1FD9, 'M', u'ῑ'), + (0x1FDA, 'M', u'ὶ'), + (0x1FDB, 'M', u'ί'), + (0x1FDC, 'X'), + (0x1FDD, '3', u' ̔̀'), + (0x1FDE, '3', u' ̔́'), + (0x1FDF, '3', u' ̔͂'), + (0x1FE0, 'V'), + (0x1FE3, 'M', u'ΰ'), + (0x1FE4, 'V'), + (0x1FE8, 'M', u'ῠ'), + (0x1FE9, 'M', u'ῡ'), + (0x1FEA, 'M', u'ὺ'), + (0x1FEB, 'M', u'ύ'), + (0x1FEC, 'M', u'ῥ'), + (0x1FED, '3', u' ̈̀'), + (0x1FEE, '3', u' ̈́'), + (0x1FEF, '3', u'`'), + (0x1FF0, 'X'), + (0x1FF2, 'M', u'ὼι'), + (0x1FF3, 'M', u'ωι'), + (0x1FF4, 'M', u'ώι'), + (0x1FF5, 'X'), + (0x1FF6, 'V'), + (0x1FF7, 'M', u'ῶι'), + (0x1FF8, 'M', u'ὸ'), + (0x1FF9, 'M', u'ό'), + (0x1FFA, 'M', u'ὼ'), + (0x1FFB, 'M', u'ώ'), + (0x1FFC, 'M', u'ωι'), + (0x1FFD, '3', u' ́'), + (0x1FFE, '3', u' ̔'), + (0x1FFF, 'X'), + (0x2000, '3', u' '), + (0x200B, 'I'), + (0x200C, 'D', u''), + (0x200E, 'X'), + (0x2010, 'V'), + (0x2011, 'M', u'‐'), + (0x2012, 'V'), + (0x2017, '3', u' ̳'), + (0x2018, 'V'), + (0x2024, 'X'), + (0x2027, 'V'), + (0x2028, 'X'), + (0x202F, '3', u' '), + (0x2030, 'V'), + (0x2033, 'M', u'′′'), + (0x2034, 'M', u'′′′'), + (0x2035, 'V'), + (0x2036, 'M', u'‵‵'), + (0x2037, 'M', u'‵‵‵'), + ] + +def _seg_21(): + return [ + (0x2038, 'V'), + (0x203C, '3', u'!!'), + (0x203D, 'V'), + (0x203E, '3', u' ̅'), + (0x203F, 'V'), + (0x2047, '3', u'??'), + (0x2048, '3', u'?!'), + (0x2049, '3', u'!?'), + (0x204A, 'V'), + (0x2057, 'M', u'′′′′'), + (0x2058, 'V'), + (0x205F, '3', u' '), + (0x2060, 'I'), + (0x2061, 'X'), + (0x2064, 'I'), + (0x2065, 'X'), + (0x2070, 'M', u'0'), + (0x2071, 'M', u'i'), + (0x2072, 'X'), + (0x2074, 'M', u'4'), + (0x2075, 'M', u'5'), + (0x2076, 'M', u'6'), + (0x2077, 'M', u'7'), + (0x2078, 'M', u'8'), + (0x2079, 'M', u'9'), + (0x207A, '3', u'+'), + (0x207B, 'M', u'−'), + (0x207C, '3', u'='), + (0x207D, '3', u'('), + (0x207E, '3', u')'), + (0x207F, 'M', u'n'), + (0x2080, 'M', u'0'), + (0x2081, 'M', u'1'), + (0x2082, 'M', u'2'), + (0x2083, 'M', u'3'), + (0x2084, 'M', u'4'), + (0x2085, 'M', u'5'), + (0x2086, 'M', u'6'), + (0x2087, 'M', u'7'), + (0x2088, 'M', u'8'), + (0x2089, 'M', u'9'), + (0x208A, '3', u'+'), + (0x208B, 'M', u'−'), + (0x208C, '3', u'='), + (0x208D, '3', u'('), + (0x208E, '3', u')'), + (0x208F, 'X'), + (0x2090, 'M', u'a'), + (0x2091, 'M', u'e'), + (0x2092, 'M', u'o'), + (0x2093, 'M', u'x'), + (0x2094, 'M', u'ə'), + (0x2095, 'M', u'h'), + (0x2096, 'M', u'k'), + (0x2097, 'M', u'l'), + (0x2098, 'M', u'm'), + (0x2099, 'M', u'n'), + (0x209A, 'M', u'p'), + (0x209B, 'M', u's'), + (0x209C, 'M', u't'), + (0x209D, 'X'), + (0x20A0, 'V'), + (0x20A8, 'M', u'rs'), + (0x20A9, 'V'), + (0x20C0, 'X'), + (0x20D0, 'V'), + (0x20F1, 'X'), + (0x2100, '3', u'a/c'), + (0x2101, '3', u'a/s'), + (0x2102, 'M', u'c'), + (0x2103, 'M', u'°c'), + (0x2104, 'V'), + (0x2105, '3', u'c/o'), + (0x2106, '3', u'c/u'), + (0x2107, 'M', u'ɛ'), + (0x2108, 'V'), + (0x2109, 'M', u'°f'), + (0x210A, 'M', u'g'), + (0x210B, 'M', u'h'), + (0x210F, 'M', u'ħ'), + (0x2110, 'M', u'i'), + (0x2112, 'M', u'l'), + (0x2114, 'V'), + (0x2115, 'M', u'n'), + (0x2116, 'M', u'no'), + (0x2117, 'V'), + (0x2119, 'M', u'p'), + (0x211A, 'M', u'q'), + (0x211B, 'M', u'r'), + (0x211E, 'V'), + (0x2120, 'M', u'sm'), + (0x2121, 'M', u'tel'), + (0x2122, 'M', u'tm'), + (0x2123, 'V'), + (0x2124, 'M', u'z'), + (0x2125, 'V'), + (0x2126, 'M', u'ω'), + (0x2127, 'V'), + (0x2128, 'M', u'z'), + (0x2129, 'V'), + ] + +def _seg_22(): + return [ + (0x212A, 'M', u'k'), + (0x212B, 'M', u'å'), + (0x212C, 'M', u'b'), + (0x212D, 'M', u'c'), + (0x212E, 'V'), + (0x212F, 'M', u'e'), + (0x2131, 'M', u'f'), + (0x2132, 'X'), + (0x2133, 'M', u'm'), + (0x2134, 'M', u'o'), + (0x2135, 'M', u'א'), + (0x2136, 'M', u'ב'), + (0x2137, 'M', u'ג'), + (0x2138, 'M', u'ד'), + (0x2139, 'M', u'i'), + (0x213A, 'V'), + (0x213B, 'M', u'fax'), + (0x213C, 'M', u'π'), + (0x213D, 'M', u'γ'), + (0x213F, 'M', u'π'), + (0x2140, 'M', u'∑'), + (0x2141, 'V'), + (0x2145, 'M', u'd'), + (0x2147, 'M', u'e'), + (0x2148, 'M', u'i'), + (0x2149, 'M', u'j'), + (0x214A, 'V'), + (0x2150, 'M', u'1⁄7'), + (0x2151, 'M', u'1⁄9'), + (0x2152, 'M', u'1⁄10'), + (0x2153, 'M', u'1⁄3'), + (0x2154, 'M', u'2⁄3'), + (0x2155, 'M', u'1⁄5'), + (0x2156, 'M', u'2⁄5'), + (0x2157, 'M', u'3⁄5'), + (0x2158, 'M', u'4⁄5'), + (0x2159, 'M', u'1⁄6'), + (0x215A, 'M', u'5⁄6'), + (0x215B, 'M', u'1⁄8'), + (0x215C, 'M', u'3⁄8'), + (0x215D, 'M', u'5⁄8'), + (0x215E, 'M', u'7⁄8'), + (0x215F, 'M', u'1⁄'), + (0x2160, 'M', u'i'), + (0x2161, 'M', u'ii'), + (0x2162, 'M', u'iii'), + (0x2163, 'M', u'iv'), + (0x2164, 'M', u'v'), + (0x2165, 'M', u'vi'), + (0x2166, 'M', u'vii'), + (0x2167, 'M', u'viii'), + (0x2168, 'M', u'ix'), + (0x2169, 'M', u'x'), + (0x216A, 'M', u'xi'), + (0x216B, 'M', u'xii'), + (0x216C, 'M', u'l'), + (0x216D, 'M', u'c'), + (0x216E, 'M', u'd'), + (0x216F, 'M', u'm'), + (0x2170, 'M', u'i'), + (0x2171, 'M', u'ii'), + (0x2172, 'M', u'iii'), + (0x2173, 'M', u'iv'), + (0x2174, 'M', u'v'), + (0x2175, 'M', u'vi'), + (0x2176, 'M', u'vii'), + (0x2177, 'M', u'viii'), + (0x2178, 'M', u'ix'), + (0x2179, 'M', u'x'), + (0x217A, 'M', u'xi'), + (0x217B, 'M', u'xii'), + (0x217C, 'M', u'l'), + (0x217D, 'M', u'c'), + (0x217E, 'M', u'd'), + (0x217F, 'M', u'm'), + (0x2180, 'V'), + (0x2183, 'X'), + (0x2184, 'V'), + (0x2189, 'M', u'0⁄3'), + (0x218A, 'V'), + (0x218C, 'X'), + (0x2190, 'V'), + (0x222C, 'M', u'∫∫'), + (0x222D, 'M', u'∫∫∫'), + (0x222E, 'V'), + (0x222F, 'M', u'∮∮'), + (0x2230, 'M', u'∮∮∮'), + (0x2231, 'V'), + (0x2260, '3'), + (0x2261, 'V'), + (0x226E, '3'), + (0x2270, 'V'), + (0x2329, 'M', u'〈'), + (0x232A, 'M', u'〉'), + (0x232B, 'V'), + (0x2427, 'X'), + (0x2440, 'V'), + (0x244B, 'X'), + (0x2460, 'M', u'1'), + (0x2461, 'M', u'2'), + ] + +def _seg_23(): + return [ + (0x2462, 'M', u'3'), + (0x2463, 'M', u'4'), + (0x2464, 'M', u'5'), + (0x2465, 'M', u'6'), + (0x2466, 'M', u'7'), + (0x2467, 'M', u'8'), + (0x2468, 'M', u'9'), + (0x2469, 'M', u'10'), + (0x246A, 'M', u'11'), + (0x246B, 'M', u'12'), + (0x246C, 'M', u'13'), + (0x246D, 'M', u'14'), + (0x246E, 'M', u'15'), + (0x246F, 'M', u'16'), + (0x2470, 'M', u'17'), + (0x2471, 'M', u'18'), + (0x2472, 'M', u'19'), + (0x2473, 'M', u'20'), + (0x2474, '3', u'(1)'), + (0x2475, '3', u'(2)'), + (0x2476, '3', u'(3)'), + (0x2477, '3', u'(4)'), + (0x2478, '3', u'(5)'), + (0x2479, '3', u'(6)'), + (0x247A, '3', u'(7)'), + (0x247B, '3', u'(8)'), + (0x247C, '3', u'(9)'), + (0x247D, '3', u'(10)'), + (0x247E, '3', u'(11)'), + (0x247F, '3', u'(12)'), + (0x2480, '3', u'(13)'), + (0x2481, '3', u'(14)'), + (0x2482, '3', u'(15)'), + (0x2483, '3', u'(16)'), + (0x2484, '3', u'(17)'), + (0x2485, '3', u'(18)'), + (0x2486, '3', u'(19)'), + (0x2487, '3', u'(20)'), + (0x2488, 'X'), + (0x249C, '3', u'(a)'), + (0x249D, '3', u'(b)'), + (0x249E, '3', u'(c)'), + (0x249F, '3', u'(d)'), + (0x24A0, '3', u'(e)'), + (0x24A1, '3', u'(f)'), + (0x24A2, '3', u'(g)'), + (0x24A3, '3', u'(h)'), + (0x24A4, '3', u'(i)'), + (0x24A5, '3', u'(j)'), + (0x24A6, '3', u'(k)'), + (0x24A7, '3', u'(l)'), + (0x24A8, '3', u'(m)'), + (0x24A9, '3', u'(n)'), + (0x24AA, '3', u'(o)'), + (0x24AB, '3', u'(p)'), + (0x24AC, '3', u'(q)'), + (0x24AD, '3', u'(r)'), + (0x24AE, '3', u'(s)'), + (0x24AF, '3', u'(t)'), + (0x24B0, '3', u'(u)'), + (0x24B1, '3', u'(v)'), + (0x24B2, '3', u'(w)'), + (0x24B3, '3', u'(x)'), + (0x24B4, '3', u'(y)'), + (0x24B5, '3', u'(z)'), + (0x24B6, 'M', u'a'), + (0x24B7, 'M', u'b'), + (0x24B8, 'M', u'c'), + (0x24B9, 'M', u'd'), + (0x24BA, 'M', u'e'), + (0x24BB, 'M', u'f'), + (0x24BC, 'M', u'g'), + (0x24BD, 'M', u'h'), + (0x24BE, 'M', u'i'), + (0x24BF, 'M', u'j'), + (0x24C0, 'M', u'k'), + (0x24C1, 'M', u'l'), + (0x24C2, 'M', u'm'), + (0x24C3, 'M', u'n'), + (0x24C4, 'M', u'o'), + (0x24C5, 'M', u'p'), + (0x24C6, 'M', u'q'), + (0x24C7, 'M', u'r'), + (0x24C8, 'M', u's'), + (0x24C9, 'M', u't'), + (0x24CA, 'M', u'u'), + (0x24CB, 'M', u'v'), + (0x24CC, 'M', u'w'), + (0x24CD, 'M', u'x'), + (0x24CE, 'M', u'y'), + (0x24CF, 'M', u'z'), + (0x24D0, 'M', u'a'), + (0x24D1, 'M', u'b'), + (0x24D2, 'M', u'c'), + (0x24D3, 'M', u'd'), + (0x24D4, 'M', u'e'), + (0x24D5, 'M', u'f'), + (0x24D6, 'M', u'g'), + (0x24D7, 'M', u'h'), + (0x24D8, 'M', u'i'), + ] + +def _seg_24(): + return [ + (0x24D9, 'M', u'j'), + (0x24DA, 'M', u'k'), + (0x24DB, 'M', u'l'), + (0x24DC, 'M', u'm'), + (0x24DD, 'M', u'n'), + (0x24DE, 'M', u'o'), + (0x24DF, 'M', u'p'), + (0x24E0, 'M', u'q'), + (0x24E1, 'M', u'r'), + (0x24E2, 'M', u's'), + (0x24E3, 'M', u't'), + (0x24E4, 'M', u'u'), + (0x24E5, 'M', u'v'), + (0x24E6, 'M', u'w'), + (0x24E7, 'M', u'x'), + (0x24E8, 'M', u'y'), + (0x24E9, 'M', u'z'), + (0x24EA, 'M', u'0'), + (0x24EB, 'V'), + (0x2A0C, 'M', u'∫∫∫∫'), + (0x2A0D, 'V'), + (0x2A74, '3', u'::='), + (0x2A75, '3', u'=='), + (0x2A76, '3', u'==='), + (0x2A77, 'V'), + (0x2ADC, 'M', u'⫝̸'), + (0x2ADD, 'V'), + (0x2B74, 'X'), + (0x2B76, 'V'), + (0x2B96, 'X'), + (0x2B98, 'V'), + (0x2BC9, 'X'), + (0x2BCA, 'V'), + (0x2BFF, 'X'), + (0x2C00, 'M', u'ⰰ'), + (0x2C01, 'M', u'ⰱ'), + (0x2C02, 'M', u'ⰲ'), + (0x2C03, 'M', u'ⰳ'), + (0x2C04, 'M', u'ⰴ'), + (0x2C05, 'M', u'ⰵ'), + (0x2C06, 'M', u'ⰶ'), + (0x2C07, 'M', u'ⰷ'), + (0x2C08, 'M', u'ⰸ'), + (0x2C09, 'M', u'ⰹ'), + (0x2C0A, 'M', u'ⰺ'), + (0x2C0B, 'M', u'ⰻ'), + (0x2C0C, 'M', u'ⰼ'), + (0x2C0D, 'M', u'ⰽ'), + (0x2C0E, 'M', u'ⰾ'), + (0x2C0F, 'M', u'ⰿ'), + (0x2C10, 'M', u'ⱀ'), + (0x2C11, 'M', u'ⱁ'), + (0x2C12, 'M', u'ⱂ'), + (0x2C13, 'M', u'ⱃ'), + (0x2C14, 'M', u'ⱄ'), + (0x2C15, 'M', u'ⱅ'), + (0x2C16, 'M', u'ⱆ'), + (0x2C17, 'M', u'ⱇ'), + (0x2C18, 'M', u'ⱈ'), + (0x2C19, 'M', u'ⱉ'), + (0x2C1A, 'M', u'ⱊ'), + (0x2C1B, 'M', u'ⱋ'), + (0x2C1C, 'M', u'ⱌ'), + (0x2C1D, 'M', u'ⱍ'), + (0x2C1E, 'M', u'ⱎ'), + (0x2C1F, 'M', u'ⱏ'), + (0x2C20, 'M', u'ⱐ'), + (0x2C21, 'M', u'ⱑ'), + (0x2C22, 'M', u'ⱒ'), + (0x2C23, 'M', u'ⱓ'), + (0x2C24, 'M', u'ⱔ'), + (0x2C25, 'M', u'ⱕ'), + (0x2C26, 'M', u'ⱖ'), + (0x2C27, 'M', u'ⱗ'), + (0x2C28, 'M', u'ⱘ'), + (0x2C29, 'M', u'ⱙ'), + (0x2C2A, 'M', u'ⱚ'), + (0x2C2B, 'M', u'ⱛ'), + (0x2C2C, 'M', u'ⱜ'), + (0x2C2D, 'M', u'ⱝ'), + (0x2C2E, 'M', u'ⱞ'), + (0x2C2F, 'X'), + (0x2C30, 'V'), + (0x2C5F, 'X'), + (0x2C60, 'M', u'ⱡ'), + (0x2C61, 'V'), + (0x2C62, 'M', u'ɫ'), + (0x2C63, 'M', u'ᵽ'), + (0x2C64, 'M', u'ɽ'), + (0x2C65, 'V'), + (0x2C67, 'M', u'ⱨ'), + (0x2C68, 'V'), + (0x2C69, 'M', u'ⱪ'), + (0x2C6A, 'V'), + (0x2C6B, 'M', u'ⱬ'), + (0x2C6C, 'V'), + (0x2C6D, 'M', u'ɑ'), + (0x2C6E, 'M', u'ɱ'), + (0x2C6F, 'M', u'ɐ'), + (0x2C70, 'M', u'ɒ'), + ] + +def _seg_25(): + return [ + (0x2C71, 'V'), + (0x2C72, 'M', u'ⱳ'), + (0x2C73, 'V'), + (0x2C75, 'M', u'ⱶ'), + (0x2C76, 'V'), + (0x2C7C, 'M', u'j'), + (0x2C7D, 'M', u'v'), + (0x2C7E, 'M', u'ȿ'), + (0x2C7F, 'M', u'ɀ'), + (0x2C80, 'M', u'ⲁ'), + (0x2C81, 'V'), + (0x2C82, 'M', u'ⲃ'), + (0x2C83, 'V'), + (0x2C84, 'M', u'ⲅ'), + (0x2C85, 'V'), + (0x2C86, 'M', u'ⲇ'), + (0x2C87, 'V'), + (0x2C88, 'M', u'ⲉ'), + (0x2C89, 'V'), + (0x2C8A, 'M', u'ⲋ'), + (0x2C8B, 'V'), + (0x2C8C, 'M', u'ⲍ'), + (0x2C8D, 'V'), + (0x2C8E, 'M', u'ⲏ'), + (0x2C8F, 'V'), + (0x2C90, 'M', u'ⲑ'), + (0x2C91, 'V'), + (0x2C92, 'M', u'ⲓ'), + (0x2C93, 'V'), + (0x2C94, 'M', u'ⲕ'), + (0x2C95, 'V'), + (0x2C96, 'M', u'ⲗ'), + (0x2C97, 'V'), + (0x2C98, 'M', u'ⲙ'), + (0x2C99, 'V'), + (0x2C9A, 'M', u'ⲛ'), + (0x2C9B, 'V'), + (0x2C9C, 'M', u'ⲝ'), + (0x2C9D, 'V'), + (0x2C9E, 'M', u'ⲟ'), + (0x2C9F, 'V'), + (0x2CA0, 'M', u'ⲡ'), + (0x2CA1, 'V'), + (0x2CA2, 'M', u'ⲣ'), + (0x2CA3, 'V'), + (0x2CA4, 'M', u'ⲥ'), + (0x2CA5, 'V'), + (0x2CA6, 'M', u'ⲧ'), + (0x2CA7, 'V'), + (0x2CA8, 'M', u'ⲩ'), + (0x2CA9, 'V'), + (0x2CAA, 'M', u'ⲫ'), + (0x2CAB, 'V'), + (0x2CAC, 'M', u'ⲭ'), + (0x2CAD, 'V'), + (0x2CAE, 'M', u'ⲯ'), + (0x2CAF, 'V'), + (0x2CB0, 'M', u'ⲱ'), + (0x2CB1, 'V'), + (0x2CB2, 'M', u'ⲳ'), + (0x2CB3, 'V'), + (0x2CB4, 'M', u'ⲵ'), + (0x2CB5, 'V'), + (0x2CB6, 'M', u'ⲷ'), + (0x2CB7, 'V'), + (0x2CB8, 'M', u'ⲹ'), + (0x2CB9, 'V'), + (0x2CBA, 'M', u'ⲻ'), + (0x2CBB, 'V'), + (0x2CBC, 'M', u'ⲽ'), + (0x2CBD, 'V'), + (0x2CBE, 'M', u'ⲿ'), + (0x2CBF, 'V'), + (0x2CC0, 'M', u'ⳁ'), + (0x2CC1, 'V'), + (0x2CC2, 'M', u'ⳃ'), + (0x2CC3, 'V'), + (0x2CC4, 'M', u'ⳅ'), + (0x2CC5, 'V'), + (0x2CC6, 'M', u'ⳇ'), + (0x2CC7, 'V'), + (0x2CC8, 'M', u'ⳉ'), + (0x2CC9, 'V'), + (0x2CCA, 'M', u'ⳋ'), + (0x2CCB, 'V'), + (0x2CCC, 'M', u'ⳍ'), + (0x2CCD, 'V'), + (0x2CCE, 'M', u'ⳏ'), + (0x2CCF, 'V'), + (0x2CD0, 'M', u'ⳑ'), + (0x2CD1, 'V'), + (0x2CD2, 'M', u'ⳓ'), + (0x2CD3, 'V'), + (0x2CD4, 'M', u'ⳕ'), + (0x2CD5, 'V'), + (0x2CD6, 'M', u'ⳗ'), + (0x2CD7, 'V'), + (0x2CD8, 'M', u'ⳙ'), + (0x2CD9, 'V'), + (0x2CDA, 'M', u'ⳛ'), + ] + +def _seg_26(): + return [ + (0x2CDB, 'V'), + (0x2CDC, 'M', u'ⳝ'), + (0x2CDD, 'V'), + (0x2CDE, 'M', u'ⳟ'), + (0x2CDF, 'V'), + (0x2CE0, 'M', u'ⳡ'), + (0x2CE1, 'V'), + (0x2CE2, 'M', u'ⳣ'), + (0x2CE3, 'V'), + (0x2CEB, 'M', u'ⳬ'), + (0x2CEC, 'V'), + (0x2CED, 'M', u'ⳮ'), + (0x2CEE, 'V'), + (0x2CF2, 'M', u'ⳳ'), + (0x2CF3, 'V'), + (0x2CF4, 'X'), + (0x2CF9, 'V'), + (0x2D26, 'X'), + (0x2D27, 'V'), + (0x2D28, 'X'), + (0x2D2D, 'V'), + (0x2D2E, 'X'), + (0x2D30, 'V'), + (0x2D68, 'X'), + (0x2D6F, 'M', u'ⵡ'), + (0x2D70, 'V'), + (0x2D71, 'X'), + (0x2D7F, 'V'), + (0x2D97, 'X'), + (0x2DA0, 'V'), + (0x2DA7, 'X'), + (0x2DA8, 'V'), + (0x2DAF, 'X'), + (0x2DB0, 'V'), + (0x2DB7, 'X'), + (0x2DB8, 'V'), + (0x2DBF, 'X'), + (0x2DC0, 'V'), + (0x2DC7, 'X'), + (0x2DC8, 'V'), + (0x2DCF, 'X'), + (0x2DD0, 'V'), + (0x2DD7, 'X'), + (0x2DD8, 'V'), + (0x2DDF, 'X'), + (0x2DE0, 'V'), + (0x2E4F, 'X'), + (0x2E80, 'V'), + (0x2E9A, 'X'), + (0x2E9B, 'V'), + (0x2E9F, 'M', u'母'), + (0x2EA0, 'V'), + (0x2EF3, 'M', u'龟'), + (0x2EF4, 'X'), + (0x2F00, 'M', u'一'), + (0x2F01, 'M', u'丨'), + (0x2F02, 'M', u'丶'), + (0x2F03, 'M', u'丿'), + (0x2F04, 'M', u'乙'), + (0x2F05, 'M', u'亅'), + (0x2F06, 'M', u'二'), + (0x2F07, 'M', u'亠'), + (0x2F08, 'M', u'人'), + (0x2F09, 'M', u'儿'), + (0x2F0A, 'M', u'入'), + (0x2F0B, 'M', u'八'), + (0x2F0C, 'M', u'冂'), + (0x2F0D, 'M', u'冖'), + (0x2F0E, 'M', u'冫'), + (0x2F0F, 'M', u'几'), + (0x2F10, 'M', u'凵'), + (0x2F11, 'M', u'刀'), + (0x2F12, 'M', u'力'), + (0x2F13, 'M', u'勹'), + (0x2F14, 'M', u'匕'), + (0x2F15, 'M', u'匚'), + (0x2F16, 'M', u'匸'), + (0x2F17, 'M', u'十'), + (0x2F18, 'M', u'卜'), + (0x2F19, 'M', u'卩'), + (0x2F1A, 'M', u'厂'), + (0x2F1B, 'M', u'厶'), + (0x2F1C, 'M', u'又'), + (0x2F1D, 'M', u'口'), + (0x2F1E, 'M', u'囗'), + (0x2F1F, 'M', u'土'), + (0x2F20, 'M', u'士'), + (0x2F21, 'M', u'夂'), + (0x2F22, 'M', u'夊'), + (0x2F23, 'M', u'夕'), + (0x2F24, 'M', u'大'), + (0x2F25, 'M', u'女'), + (0x2F26, 'M', u'子'), + (0x2F27, 'M', u'宀'), + (0x2F28, 'M', u'寸'), + (0x2F29, 'M', u'小'), + (0x2F2A, 'M', u'尢'), + (0x2F2B, 'M', u'尸'), + (0x2F2C, 'M', u'屮'), + (0x2F2D, 'M', u'山'), + ] + +def _seg_27(): + return [ + (0x2F2E, 'M', u'巛'), + (0x2F2F, 'M', u'工'), + (0x2F30, 'M', u'己'), + (0x2F31, 'M', u'巾'), + (0x2F32, 'M', u'干'), + (0x2F33, 'M', u'幺'), + (0x2F34, 'M', u'广'), + (0x2F35, 'M', u'廴'), + (0x2F36, 'M', u'廾'), + (0x2F37, 'M', u'弋'), + (0x2F38, 'M', u'弓'), + (0x2F39, 'M', u'彐'), + (0x2F3A, 'M', u'彡'), + (0x2F3B, 'M', u'彳'), + (0x2F3C, 'M', u'心'), + (0x2F3D, 'M', u'戈'), + (0x2F3E, 'M', u'戶'), + (0x2F3F, 'M', u'手'), + (0x2F40, 'M', u'支'), + (0x2F41, 'M', u'攴'), + (0x2F42, 'M', u'文'), + (0x2F43, 'M', u'斗'), + (0x2F44, 'M', u'斤'), + (0x2F45, 'M', u'方'), + (0x2F46, 'M', u'无'), + (0x2F47, 'M', u'日'), + (0x2F48, 'M', u'曰'), + (0x2F49, 'M', u'月'), + (0x2F4A, 'M', u'木'), + (0x2F4B, 'M', u'欠'), + (0x2F4C, 'M', u'止'), + (0x2F4D, 'M', u'歹'), + (0x2F4E, 'M', u'殳'), + (0x2F4F, 'M', u'毋'), + (0x2F50, 'M', u'比'), + (0x2F51, 'M', u'毛'), + (0x2F52, 'M', u'氏'), + (0x2F53, 'M', u'气'), + (0x2F54, 'M', u'水'), + (0x2F55, 'M', u'火'), + (0x2F56, 'M', u'爪'), + (0x2F57, 'M', u'父'), + (0x2F58, 'M', u'爻'), + (0x2F59, 'M', u'爿'), + (0x2F5A, 'M', u'片'), + (0x2F5B, 'M', u'牙'), + (0x2F5C, 'M', u'牛'), + (0x2F5D, 'M', u'犬'), + (0x2F5E, 'M', u'玄'), + (0x2F5F, 'M', u'玉'), + (0x2F60, 'M', u'瓜'), + (0x2F61, 'M', u'瓦'), + (0x2F62, 'M', u'甘'), + (0x2F63, 'M', u'生'), + (0x2F64, 'M', u'用'), + (0x2F65, 'M', u'田'), + (0x2F66, 'M', u'疋'), + (0x2F67, 'M', u'疒'), + (0x2F68, 'M', u'癶'), + (0x2F69, 'M', u'白'), + (0x2F6A, 'M', u'皮'), + (0x2F6B, 'M', u'皿'), + (0x2F6C, 'M', u'目'), + (0x2F6D, 'M', u'矛'), + (0x2F6E, 'M', u'矢'), + (0x2F6F, 'M', u'石'), + (0x2F70, 'M', u'示'), + (0x2F71, 'M', u'禸'), + (0x2F72, 'M', u'禾'), + (0x2F73, 'M', u'穴'), + (0x2F74, 'M', u'立'), + (0x2F75, 'M', u'竹'), + (0x2F76, 'M', u'米'), + (0x2F77, 'M', u'糸'), + (0x2F78, 'M', u'缶'), + (0x2F79, 'M', u'网'), + (0x2F7A, 'M', u'羊'), + (0x2F7B, 'M', u'羽'), + (0x2F7C, 'M', u'老'), + (0x2F7D, 'M', u'而'), + (0x2F7E, 'M', u'耒'), + (0x2F7F, 'M', u'耳'), + (0x2F80, 'M', u'聿'), + (0x2F81, 'M', u'肉'), + (0x2F82, 'M', u'臣'), + (0x2F83, 'M', u'自'), + (0x2F84, 'M', u'至'), + (0x2F85, 'M', u'臼'), + (0x2F86, 'M', u'舌'), + (0x2F87, 'M', u'舛'), + (0x2F88, 'M', u'舟'), + (0x2F89, 'M', u'艮'), + (0x2F8A, 'M', u'色'), + (0x2F8B, 'M', u'艸'), + (0x2F8C, 'M', u'虍'), + (0x2F8D, 'M', u'虫'), + (0x2F8E, 'M', u'血'), + (0x2F8F, 'M', u'行'), + (0x2F90, 'M', u'衣'), + (0x2F91, 'M', u'襾'), + ] + +def _seg_28(): + return [ + (0x2F92, 'M', u'見'), + (0x2F93, 'M', u'角'), + (0x2F94, 'M', u'言'), + (0x2F95, 'M', u'谷'), + (0x2F96, 'M', u'豆'), + (0x2F97, 'M', u'豕'), + (0x2F98, 'M', u'豸'), + (0x2F99, 'M', u'貝'), + (0x2F9A, 'M', u'赤'), + (0x2F9B, 'M', u'走'), + (0x2F9C, 'M', u'足'), + (0x2F9D, 'M', u'身'), + (0x2F9E, 'M', u'車'), + (0x2F9F, 'M', u'辛'), + (0x2FA0, 'M', u'辰'), + (0x2FA1, 'M', u'辵'), + (0x2FA2, 'M', u'邑'), + (0x2FA3, 'M', u'酉'), + (0x2FA4, 'M', u'釆'), + (0x2FA5, 'M', u'里'), + (0x2FA6, 'M', u'金'), + (0x2FA7, 'M', u'長'), + (0x2FA8, 'M', u'門'), + (0x2FA9, 'M', u'阜'), + (0x2FAA, 'M', u'隶'), + (0x2FAB, 'M', u'隹'), + (0x2FAC, 'M', u'雨'), + (0x2FAD, 'M', u'靑'), + (0x2FAE, 'M', u'非'), + (0x2FAF, 'M', u'面'), + (0x2FB0, 'M', u'革'), + (0x2FB1, 'M', u'韋'), + (0x2FB2, 'M', u'韭'), + (0x2FB3, 'M', u'音'), + (0x2FB4, 'M', u'頁'), + (0x2FB5, 'M', u'風'), + (0x2FB6, 'M', u'飛'), + (0x2FB7, 'M', u'食'), + (0x2FB8, 'M', u'首'), + (0x2FB9, 'M', u'香'), + (0x2FBA, 'M', u'馬'), + (0x2FBB, 'M', u'骨'), + (0x2FBC, 'M', u'高'), + (0x2FBD, 'M', u'髟'), + (0x2FBE, 'M', u'鬥'), + (0x2FBF, 'M', u'鬯'), + (0x2FC0, 'M', u'鬲'), + (0x2FC1, 'M', u'鬼'), + (0x2FC2, 'M', u'魚'), + (0x2FC3, 'M', u'鳥'), + (0x2FC4, 'M', u'鹵'), + (0x2FC5, 'M', u'鹿'), + (0x2FC6, 'M', u'麥'), + (0x2FC7, 'M', u'麻'), + (0x2FC8, 'M', u'黃'), + (0x2FC9, 'M', u'黍'), + (0x2FCA, 'M', u'黑'), + (0x2FCB, 'M', u'黹'), + (0x2FCC, 'M', u'黽'), + (0x2FCD, 'M', u'鼎'), + (0x2FCE, 'M', u'鼓'), + (0x2FCF, 'M', u'鼠'), + (0x2FD0, 'M', u'鼻'), + (0x2FD1, 'M', u'齊'), + (0x2FD2, 'M', u'齒'), + (0x2FD3, 'M', u'龍'), + (0x2FD4, 'M', u'龜'), + (0x2FD5, 'M', u'龠'), + (0x2FD6, 'X'), + (0x3000, '3', u' '), + (0x3001, 'V'), + (0x3002, 'M', u'.'), + (0x3003, 'V'), + (0x3036, 'M', u'〒'), + (0x3037, 'V'), + (0x3038, 'M', u'十'), + (0x3039, 'M', u'卄'), + (0x303A, 'M', u'卅'), + (0x303B, 'V'), + (0x3040, 'X'), + (0x3041, 'V'), + (0x3097, 'X'), + (0x3099, 'V'), + (0x309B, '3', u' ゙'), + (0x309C, '3', u' ゚'), + (0x309D, 'V'), + (0x309F, 'M', u'より'), + (0x30A0, 'V'), + (0x30FF, 'M', u'コト'), + (0x3100, 'X'), + (0x3105, 'V'), + (0x3130, 'X'), + (0x3131, 'M', u'ᄀ'), + (0x3132, 'M', u'ᄁ'), + (0x3133, 'M', u'ᆪ'), + (0x3134, 'M', u'ᄂ'), + (0x3135, 'M', u'ᆬ'), + (0x3136, 'M', u'ᆭ'), + (0x3137, 'M', u'ᄃ'), + (0x3138, 'M', u'ᄄ'), + ] + +def _seg_29(): + return [ + (0x3139, 'M', u'ᄅ'), + (0x313A, 'M', u'ᆰ'), + (0x313B, 'M', u'ᆱ'), + (0x313C, 'M', u'ᆲ'), + (0x313D, 'M', u'ᆳ'), + (0x313E, 'M', u'ᆴ'), + (0x313F, 'M', u'ᆵ'), + (0x3140, 'M', u'ᄚ'), + (0x3141, 'M', u'ᄆ'), + (0x3142, 'M', u'ᄇ'), + (0x3143, 'M', u'ᄈ'), + (0x3144, 'M', u'ᄡ'), + (0x3145, 'M', u'ᄉ'), + (0x3146, 'M', u'ᄊ'), + (0x3147, 'M', u'ᄋ'), + (0x3148, 'M', u'ᄌ'), + (0x3149, 'M', u'ᄍ'), + (0x314A, 'M', u'ᄎ'), + (0x314B, 'M', u'ᄏ'), + (0x314C, 'M', u'ᄐ'), + (0x314D, 'M', u'ᄑ'), + (0x314E, 'M', u'ᄒ'), + (0x314F, 'M', u'ᅡ'), + (0x3150, 'M', u'ᅢ'), + (0x3151, 'M', u'ᅣ'), + (0x3152, 'M', u'ᅤ'), + (0x3153, 'M', u'ᅥ'), + (0x3154, 'M', u'ᅦ'), + (0x3155, 'M', u'ᅧ'), + (0x3156, 'M', u'ᅨ'), + (0x3157, 'M', u'ᅩ'), + (0x3158, 'M', u'ᅪ'), + (0x3159, 'M', u'ᅫ'), + (0x315A, 'M', u'ᅬ'), + (0x315B, 'M', u'ᅭ'), + (0x315C, 'M', u'ᅮ'), + (0x315D, 'M', u'ᅯ'), + (0x315E, 'M', u'ᅰ'), + (0x315F, 'M', u'ᅱ'), + (0x3160, 'M', u'ᅲ'), + (0x3161, 'M', u'ᅳ'), + (0x3162, 'M', u'ᅴ'), + (0x3163, 'M', u'ᅵ'), + (0x3164, 'X'), + (0x3165, 'M', u'ᄔ'), + (0x3166, 'M', u'ᄕ'), + (0x3167, 'M', u'ᇇ'), + (0x3168, 'M', u'ᇈ'), + (0x3169, 'M', u'ᇌ'), + (0x316A, 'M', u'ᇎ'), + (0x316B, 'M', u'ᇓ'), + (0x316C, 'M', u'ᇗ'), + (0x316D, 'M', u'ᇙ'), + (0x316E, 'M', u'ᄜ'), + (0x316F, 'M', u'ᇝ'), + (0x3170, 'M', u'ᇟ'), + (0x3171, 'M', u'ᄝ'), + (0x3172, 'M', u'ᄞ'), + (0x3173, 'M', u'ᄠ'), + (0x3174, 'M', u'ᄢ'), + (0x3175, 'M', u'ᄣ'), + (0x3176, 'M', u'ᄧ'), + (0x3177, 'M', u'ᄩ'), + (0x3178, 'M', u'ᄫ'), + (0x3179, 'M', u'ᄬ'), + (0x317A, 'M', u'ᄭ'), + (0x317B, 'M', u'ᄮ'), + (0x317C, 'M', u'ᄯ'), + (0x317D, 'M', u'ᄲ'), + (0x317E, 'M', u'ᄶ'), + (0x317F, 'M', u'ᅀ'), + (0x3180, 'M', u'ᅇ'), + (0x3181, 'M', u'ᅌ'), + (0x3182, 'M', u'ᇱ'), + (0x3183, 'M', u'ᇲ'), + (0x3184, 'M', u'ᅗ'), + (0x3185, 'M', u'ᅘ'), + (0x3186, 'M', u'ᅙ'), + (0x3187, 'M', u'ᆄ'), + (0x3188, 'M', u'ᆅ'), + (0x3189, 'M', u'ᆈ'), + (0x318A, 'M', u'ᆑ'), + (0x318B, 'M', u'ᆒ'), + (0x318C, 'M', u'ᆔ'), + (0x318D, 'M', u'ᆞ'), + (0x318E, 'M', u'ᆡ'), + (0x318F, 'X'), + (0x3190, 'V'), + (0x3192, 'M', u'一'), + (0x3193, 'M', u'二'), + (0x3194, 'M', u'三'), + (0x3195, 'M', u'四'), + (0x3196, 'M', u'上'), + (0x3197, 'M', u'中'), + (0x3198, 'M', u'下'), + (0x3199, 'M', u'甲'), + (0x319A, 'M', u'乙'), + (0x319B, 'M', u'丙'), + (0x319C, 'M', u'丁'), + (0x319D, 'M', u'天'), + ] + +def _seg_30(): + return [ + (0x319E, 'M', u'地'), + (0x319F, 'M', u'人'), + (0x31A0, 'V'), + (0x31BB, 'X'), + (0x31C0, 'V'), + (0x31E4, 'X'), + (0x31F0, 'V'), + (0x3200, '3', u'(ᄀ)'), + (0x3201, '3', u'(ᄂ)'), + (0x3202, '3', u'(ᄃ)'), + (0x3203, '3', u'(ᄅ)'), + (0x3204, '3', u'(ᄆ)'), + (0x3205, '3', u'(ᄇ)'), + (0x3206, '3', u'(ᄉ)'), + (0x3207, '3', u'(ᄋ)'), + (0x3208, '3', u'(ᄌ)'), + (0x3209, '3', u'(ᄎ)'), + (0x320A, '3', u'(ᄏ)'), + (0x320B, '3', u'(ᄐ)'), + (0x320C, '3', u'(ᄑ)'), + (0x320D, '3', u'(ᄒ)'), + (0x320E, '3', u'(가)'), + (0x320F, '3', u'(나)'), + (0x3210, '3', u'(다)'), + (0x3211, '3', u'(라)'), + (0x3212, '3', u'(마)'), + (0x3213, '3', u'(바)'), + (0x3214, '3', u'(사)'), + (0x3215, '3', u'(아)'), + (0x3216, '3', u'(자)'), + (0x3217, '3', u'(차)'), + (0x3218, '3', u'(카)'), + (0x3219, '3', u'(타)'), + (0x321A, '3', u'(파)'), + (0x321B, '3', u'(하)'), + (0x321C, '3', u'(주)'), + (0x321D, '3', u'(오전)'), + (0x321E, '3', u'(오후)'), + (0x321F, 'X'), + (0x3220, '3', u'(一)'), + (0x3221, '3', u'(二)'), + (0x3222, '3', u'(三)'), + (0x3223, '3', u'(四)'), + (0x3224, '3', u'(五)'), + (0x3225, '3', u'(六)'), + (0x3226, '3', u'(七)'), + (0x3227, '3', u'(八)'), + (0x3228, '3', u'(九)'), + (0x3229, '3', u'(十)'), + (0x322A, '3', u'(月)'), + (0x322B, '3', u'(火)'), + (0x322C, '3', u'(水)'), + (0x322D, '3', u'(木)'), + (0x322E, '3', u'(金)'), + (0x322F, '3', u'(土)'), + (0x3230, '3', u'(日)'), + (0x3231, '3', u'(株)'), + (0x3232, '3', u'(有)'), + (0x3233, '3', u'(社)'), + (0x3234, '3', u'(名)'), + (0x3235, '3', u'(特)'), + (0x3236, '3', u'(財)'), + (0x3237, '3', u'(祝)'), + (0x3238, '3', u'(労)'), + (0x3239, '3', u'(代)'), + (0x323A, '3', u'(呼)'), + (0x323B, '3', u'(学)'), + (0x323C, '3', u'(監)'), + (0x323D, '3', u'(企)'), + (0x323E, '3', u'(資)'), + (0x323F, '3', u'(協)'), + (0x3240, '3', u'(祭)'), + (0x3241, '3', u'(休)'), + (0x3242, '3', u'(自)'), + (0x3243, '3', u'(至)'), + (0x3244, 'M', u'問'), + (0x3245, 'M', u'幼'), + (0x3246, 'M', u'文'), + (0x3247, 'M', u'箏'), + (0x3248, 'V'), + (0x3250, 'M', u'pte'), + (0x3251, 'M', u'21'), + (0x3252, 'M', u'22'), + (0x3253, 'M', u'23'), + (0x3254, 'M', u'24'), + (0x3255, 'M', u'25'), + (0x3256, 'M', u'26'), + (0x3257, 'M', u'27'), + (0x3258, 'M', u'28'), + (0x3259, 'M', u'29'), + (0x325A, 'M', u'30'), + (0x325B, 'M', u'31'), + (0x325C, 'M', u'32'), + (0x325D, 'M', u'33'), + (0x325E, 'M', u'34'), + (0x325F, 'M', u'35'), + (0x3260, 'M', u'ᄀ'), + (0x3261, 'M', u'ᄂ'), + (0x3262, 'M', u'ᄃ'), + (0x3263, 'M', u'ᄅ'), + ] + +def _seg_31(): + return [ + (0x3264, 'M', u'ᄆ'), + (0x3265, 'M', u'ᄇ'), + (0x3266, 'M', u'ᄉ'), + (0x3267, 'M', u'ᄋ'), + (0x3268, 'M', u'ᄌ'), + (0x3269, 'M', u'ᄎ'), + (0x326A, 'M', u'ᄏ'), + (0x326B, 'M', u'ᄐ'), + (0x326C, 'M', u'ᄑ'), + (0x326D, 'M', u'ᄒ'), + (0x326E, 'M', u'가'), + (0x326F, 'M', u'나'), + (0x3270, 'M', u'다'), + (0x3271, 'M', u'라'), + (0x3272, 'M', u'마'), + (0x3273, 'M', u'바'), + (0x3274, 'M', u'사'), + (0x3275, 'M', u'아'), + (0x3276, 'M', u'자'), + (0x3277, 'M', u'차'), + (0x3278, 'M', u'카'), + (0x3279, 'M', u'타'), + (0x327A, 'M', u'파'), + (0x327B, 'M', u'하'), + (0x327C, 'M', u'참고'), + (0x327D, 'M', u'주의'), + (0x327E, 'M', u'우'), + (0x327F, 'V'), + (0x3280, 'M', u'一'), + (0x3281, 'M', u'二'), + (0x3282, 'M', u'三'), + (0x3283, 'M', u'四'), + (0x3284, 'M', u'五'), + (0x3285, 'M', u'六'), + (0x3286, 'M', u'七'), + (0x3287, 'M', u'八'), + (0x3288, 'M', u'九'), + (0x3289, 'M', u'十'), + (0x328A, 'M', u'月'), + (0x328B, 'M', u'火'), + (0x328C, 'M', u'水'), + (0x328D, 'M', u'木'), + (0x328E, 'M', u'金'), + (0x328F, 'M', u'土'), + (0x3290, 'M', u'日'), + (0x3291, 'M', u'株'), + (0x3292, 'M', u'有'), + (0x3293, 'M', u'社'), + (0x3294, 'M', u'名'), + (0x3295, 'M', u'特'), + (0x3296, 'M', u'財'), + (0x3297, 'M', u'祝'), + (0x3298, 'M', u'労'), + (0x3299, 'M', u'秘'), + (0x329A, 'M', u'男'), + (0x329B, 'M', u'女'), + (0x329C, 'M', u'適'), + (0x329D, 'M', u'優'), + (0x329E, 'M', u'印'), + (0x329F, 'M', u'注'), + (0x32A0, 'M', u'項'), + (0x32A1, 'M', u'休'), + (0x32A2, 'M', u'写'), + (0x32A3, 'M', u'正'), + (0x32A4, 'M', u'上'), + (0x32A5, 'M', u'中'), + (0x32A6, 'M', u'下'), + (0x32A7, 'M', u'左'), + (0x32A8, 'M', u'右'), + (0x32A9, 'M', u'医'), + (0x32AA, 'M', u'宗'), + (0x32AB, 'M', u'学'), + (0x32AC, 'M', u'監'), + (0x32AD, 'M', u'企'), + (0x32AE, 'M', u'資'), + (0x32AF, 'M', u'協'), + (0x32B0, 'M', u'夜'), + (0x32B1, 'M', u'36'), + (0x32B2, 'M', u'37'), + (0x32B3, 'M', u'38'), + (0x32B4, 'M', u'39'), + (0x32B5, 'M', u'40'), + (0x32B6, 'M', u'41'), + (0x32B7, 'M', u'42'), + (0x32B8, 'M', u'43'), + (0x32B9, 'M', u'44'), + (0x32BA, 'M', u'45'), + (0x32BB, 'M', u'46'), + (0x32BC, 'M', u'47'), + (0x32BD, 'M', u'48'), + (0x32BE, 'M', u'49'), + (0x32BF, 'M', u'50'), + (0x32C0, 'M', u'1月'), + (0x32C1, 'M', u'2月'), + (0x32C2, 'M', u'3月'), + (0x32C3, 'M', u'4月'), + (0x32C4, 'M', u'5月'), + (0x32C5, 'M', u'6月'), + (0x32C6, 'M', u'7月'), + (0x32C7, 'M', u'8月'), + ] + +def _seg_32(): + return [ + (0x32C8, 'M', u'9月'), + (0x32C9, 'M', u'10月'), + (0x32CA, 'M', u'11月'), + (0x32CB, 'M', u'12月'), + (0x32CC, 'M', u'hg'), + (0x32CD, 'M', u'erg'), + (0x32CE, 'M', u'ev'), + (0x32CF, 'M', u'ltd'), + (0x32D0, 'M', u'ア'), + (0x32D1, 'M', u'イ'), + (0x32D2, 'M', u'ウ'), + (0x32D3, 'M', u'エ'), + (0x32D4, 'M', u'オ'), + (0x32D5, 'M', u'カ'), + (0x32D6, 'M', u'キ'), + (0x32D7, 'M', u'ク'), + (0x32D8, 'M', u'ケ'), + (0x32D9, 'M', u'コ'), + (0x32DA, 'M', u'サ'), + (0x32DB, 'M', u'シ'), + (0x32DC, 'M', u'ス'), + (0x32DD, 'M', u'セ'), + (0x32DE, 'M', u'ソ'), + (0x32DF, 'M', u'タ'), + (0x32E0, 'M', u'チ'), + (0x32E1, 'M', u'ツ'), + (0x32E2, 'M', u'テ'), + (0x32E3, 'M', u'ト'), + (0x32E4, 'M', u'ナ'), + (0x32E5, 'M', u'ニ'), + (0x32E6, 'M', u'ヌ'), + (0x32E7, 'M', u'ネ'), + (0x32E8, 'M', u'ノ'), + (0x32E9, 'M', u'ハ'), + (0x32EA, 'M', u'ヒ'), + (0x32EB, 'M', u'フ'), + (0x32EC, 'M', u'ヘ'), + (0x32ED, 'M', u'ホ'), + (0x32EE, 'M', u'マ'), + (0x32EF, 'M', u'ミ'), + (0x32F0, 'M', u'ム'), + (0x32F1, 'M', u'メ'), + (0x32F2, 'M', u'モ'), + (0x32F3, 'M', u'ヤ'), + (0x32F4, 'M', u'ユ'), + (0x32F5, 'M', u'ヨ'), + (0x32F6, 'M', u'ラ'), + (0x32F7, 'M', u'リ'), + (0x32F8, 'M', u'ル'), + (0x32F9, 'M', u'レ'), + (0x32FA, 'M', u'ロ'), + (0x32FB, 'M', u'ワ'), + (0x32FC, 'M', u'ヰ'), + (0x32FD, 'M', u'ヱ'), + (0x32FE, 'M', u'ヲ'), + (0x32FF, 'X'), + (0x3300, 'M', u'アパート'), + (0x3301, 'M', u'アルファ'), + (0x3302, 'M', u'アンペア'), + (0x3303, 'M', u'アール'), + (0x3304, 'M', u'イニング'), + (0x3305, 'M', u'インチ'), + (0x3306, 'M', u'ウォン'), + (0x3307, 'M', u'エスクード'), + (0x3308, 'M', u'エーカー'), + (0x3309, 'M', u'オンス'), + (0x330A, 'M', u'オーム'), + (0x330B, 'M', u'カイリ'), + (0x330C, 'M', u'カラット'), + (0x330D, 'M', u'カロリー'), + (0x330E, 'M', u'ガロン'), + (0x330F, 'M', u'ガンマ'), + (0x3310, 'M', u'ギガ'), + (0x3311, 'M', u'ギニー'), + (0x3312, 'M', u'キュリー'), + (0x3313, 'M', u'ギルダー'), + (0x3314, 'M', u'キロ'), + (0x3315, 'M', u'キログラム'), + (0x3316, 'M', u'キロメートル'), + (0x3317, 'M', u'キロワット'), + (0x3318, 'M', u'グラム'), + (0x3319, 'M', u'グラムトン'), + (0x331A, 'M', u'クルゼイロ'), + (0x331B, 'M', u'クローネ'), + (0x331C, 'M', u'ケース'), + (0x331D, 'M', u'コルナ'), + (0x331E, 'M', u'コーポ'), + (0x331F, 'M', u'サイクル'), + (0x3320, 'M', u'サンチーム'), + (0x3321, 'M', u'シリング'), + (0x3322, 'M', u'センチ'), + (0x3323, 'M', u'セント'), + (0x3324, 'M', u'ダース'), + (0x3325, 'M', u'デシ'), + (0x3326, 'M', u'ドル'), + (0x3327, 'M', u'トン'), + (0x3328, 'M', u'ナノ'), + (0x3329, 'M', u'ノット'), + (0x332A, 'M', u'ハイツ'), + (0x332B, 'M', u'パーセント'), + ] + +def _seg_33(): + return [ + (0x332C, 'M', u'パーツ'), + (0x332D, 'M', u'バーレル'), + (0x332E, 'M', u'ピアストル'), + (0x332F, 'M', u'ピクル'), + (0x3330, 'M', u'ピコ'), + (0x3331, 'M', u'ビル'), + (0x3332, 'M', u'ファラッド'), + (0x3333, 'M', u'フィート'), + (0x3334, 'M', u'ブッシェル'), + (0x3335, 'M', u'フラン'), + (0x3336, 'M', u'ヘクタール'), + (0x3337, 'M', u'ペソ'), + (0x3338, 'M', u'ペニヒ'), + (0x3339, 'M', u'ヘルツ'), + (0x333A, 'M', u'ペンス'), + (0x333B, 'M', u'ページ'), + (0x333C, 'M', u'ベータ'), + (0x333D, 'M', u'ポイント'), + (0x333E, 'M', u'ボルト'), + (0x333F, 'M', u'ホン'), + (0x3340, 'M', u'ポンド'), + (0x3341, 'M', u'ホール'), + (0x3342, 'M', u'ホーン'), + (0x3343, 'M', u'マイクロ'), + (0x3344, 'M', u'マイル'), + (0x3345, 'M', u'マッハ'), + (0x3346, 'M', u'マルク'), + (0x3347, 'M', u'マンション'), + (0x3348, 'M', u'ミクロン'), + (0x3349, 'M', u'ミリ'), + (0x334A, 'M', u'ミリバール'), + (0x334B, 'M', u'メガ'), + (0x334C, 'M', u'メガトン'), + (0x334D, 'M', u'メートル'), + (0x334E, 'M', u'ヤード'), + (0x334F, 'M', u'ヤール'), + (0x3350, 'M', u'ユアン'), + (0x3351, 'M', u'リットル'), + (0x3352, 'M', u'リラ'), + (0x3353, 'M', u'ルピー'), + (0x3354, 'M', u'ルーブル'), + (0x3355, 'M', u'レム'), + (0x3356, 'M', u'レントゲン'), + (0x3357, 'M', u'ワット'), + (0x3358, 'M', u'0点'), + (0x3359, 'M', u'1点'), + (0x335A, 'M', u'2点'), + (0x335B, 'M', u'3点'), + (0x335C, 'M', u'4点'), + (0x335D, 'M', u'5点'), + (0x335E, 'M', u'6点'), + (0x335F, 'M', u'7点'), + (0x3360, 'M', u'8点'), + (0x3361, 'M', u'9点'), + (0x3362, 'M', u'10点'), + (0x3363, 'M', u'11点'), + (0x3364, 'M', u'12点'), + (0x3365, 'M', u'13点'), + (0x3366, 'M', u'14点'), + (0x3367, 'M', u'15点'), + (0x3368, 'M', u'16点'), + (0x3369, 'M', u'17点'), + (0x336A, 'M', u'18点'), + (0x336B, 'M', u'19点'), + (0x336C, 'M', u'20点'), + (0x336D, 'M', u'21点'), + (0x336E, 'M', u'22点'), + (0x336F, 'M', u'23点'), + (0x3370, 'M', u'24点'), + (0x3371, 'M', u'hpa'), + (0x3372, 'M', u'da'), + (0x3373, 'M', u'au'), + (0x3374, 'M', u'bar'), + (0x3375, 'M', u'ov'), + (0x3376, 'M', u'pc'), + (0x3377, 'M', u'dm'), + (0x3378, 'M', u'dm2'), + (0x3379, 'M', u'dm3'), + (0x337A, 'M', u'iu'), + (0x337B, 'M', u'平成'), + (0x337C, 'M', u'昭和'), + (0x337D, 'M', u'大正'), + (0x337E, 'M', u'明治'), + (0x337F, 'M', u'株式会社'), + (0x3380, 'M', u'pa'), + (0x3381, 'M', u'na'), + (0x3382, 'M', u'μa'), + (0x3383, 'M', u'ma'), + (0x3384, 'M', u'ka'), + (0x3385, 'M', u'kb'), + (0x3386, 'M', u'mb'), + (0x3387, 'M', u'gb'), + (0x3388, 'M', u'cal'), + (0x3389, 'M', u'kcal'), + (0x338A, 'M', u'pf'), + (0x338B, 'M', u'nf'), + (0x338C, 'M', u'μf'), + (0x338D, 'M', u'μg'), + (0x338E, 'M', u'mg'), + (0x338F, 'M', u'kg'), + ] + +def _seg_34(): + return [ + (0x3390, 'M', u'hz'), + (0x3391, 'M', u'khz'), + (0x3392, 'M', u'mhz'), + (0x3393, 'M', u'ghz'), + (0x3394, 'M', u'thz'), + (0x3395, 'M', u'μl'), + (0x3396, 'M', u'ml'), + (0x3397, 'M', u'dl'), + (0x3398, 'M', u'kl'), + (0x3399, 'M', u'fm'), + (0x339A, 'M', u'nm'), + (0x339B, 'M', u'μm'), + (0x339C, 'M', u'mm'), + (0x339D, 'M', u'cm'), + (0x339E, 'M', u'km'), + (0x339F, 'M', u'mm2'), + (0x33A0, 'M', u'cm2'), + (0x33A1, 'M', u'm2'), + (0x33A2, 'M', u'km2'), + (0x33A3, 'M', u'mm3'), + (0x33A4, 'M', u'cm3'), + (0x33A5, 'M', u'm3'), + (0x33A6, 'M', u'km3'), + (0x33A7, 'M', u'm∕s'), + (0x33A8, 'M', u'm∕s2'), + (0x33A9, 'M', u'pa'), + (0x33AA, 'M', u'kpa'), + (0x33AB, 'M', u'mpa'), + (0x33AC, 'M', u'gpa'), + (0x33AD, 'M', u'rad'), + (0x33AE, 'M', u'rad∕s'), + (0x33AF, 'M', u'rad∕s2'), + (0x33B0, 'M', u'ps'), + (0x33B1, 'M', u'ns'), + (0x33B2, 'M', u'μs'), + (0x33B3, 'M', u'ms'), + (0x33B4, 'M', u'pv'), + (0x33B5, 'M', u'nv'), + (0x33B6, 'M', u'μv'), + (0x33B7, 'M', u'mv'), + (0x33B8, 'M', u'kv'), + (0x33B9, 'M', u'mv'), + (0x33BA, 'M', u'pw'), + (0x33BB, 'M', u'nw'), + (0x33BC, 'M', u'μw'), + (0x33BD, 'M', u'mw'), + (0x33BE, 'M', u'kw'), + (0x33BF, 'M', u'mw'), + (0x33C0, 'M', u'kω'), + (0x33C1, 'M', u'mω'), + (0x33C2, 'X'), + (0x33C3, 'M', u'bq'), + (0x33C4, 'M', u'cc'), + (0x33C5, 'M', u'cd'), + (0x33C6, 'M', u'c∕kg'), + (0x33C7, 'X'), + (0x33C8, 'M', u'db'), + (0x33C9, 'M', u'gy'), + (0x33CA, 'M', u'ha'), + (0x33CB, 'M', u'hp'), + (0x33CC, 'M', u'in'), + (0x33CD, 'M', u'kk'), + (0x33CE, 'M', u'km'), + (0x33CF, 'M', u'kt'), + (0x33D0, 'M', u'lm'), + (0x33D1, 'M', u'ln'), + (0x33D2, 'M', u'log'), + (0x33D3, 'M', u'lx'), + (0x33D4, 'M', u'mb'), + (0x33D5, 'M', u'mil'), + (0x33D6, 'M', u'mol'), + (0x33D7, 'M', u'ph'), + (0x33D8, 'X'), + (0x33D9, 'M', u'ppm'), + (0x33DA, 'M', u'pr'), + (0x33DB, 'M', u'sr'), + (0x33DC, 'M', u'sv'), + (0x33DD, 'M', u'wb'), + (0x33DE, 'M', u'v∕m'), + (0x33DF, 'M', u'a∕m'), + (0x33E0, 'M', u'1日'), + (0x33E1, 'M', u'2日'), + (0x33E2, 'M', u'3日'), + (0x33E3, 'M', u'4日'), + (0x33E4, 'M', u'5日'), + (0x33E5, 'M', u'6日'), + (0x33E6, 'M', u'7日'), + (0x33E7, 'M', u'8日'), + (0x33E8, 'M', u'9日'), + (0x33E9, 'M', u'10日'), + (0x33EA, 'M', u'11日'), + (0x33EB, 'M', u'12日'), + (0x33EC, 'M', u'13日'), + (0x33ED, 'M', u'14日'), + (0x33EE, 'M', u'15日'), + (0x33EF, 'M', u'16日'), + (0x33F0, 'M', u'17日'), + (0x33F1, 'M', u'18日'), + (0x33F2, 'M', u'19日'), + (0x33F3, 'M', u'20日'), + ] + +def _seg_35(): + return [ + (0x33F4, 'M', u'21日'), + (0x33F5, 'M', u'22日'), + (0x33F6, 'M', u'23日'), + (0x33F7, 'M', u'24日'), + (0x33F8, 'M', u'25日'), + (0x33F9, 'M', u'26日'), + (0x33FA, 'M', u'27日'), + (0x33FB, 'M', u'28日'), + (0x33FC, 'M', u'29日'), + (0x33FD, 'M', u'30日'), + (0x33FE, 'M', u'31日'), + (0x33FF, 'M', u'gal'), + (0x3400, 'V'), + (0x4DB6, 'X'), + (0x4DC0, 'V'), + (0x9FF0, 'X'), + (0xA000, 'V'), + (0xA48D, 'X'), + (0xA490, 'V'), + (0xA4C7, 'X'), + (0xA4D0, 'V'), + (0xA62C, 'X'), + (0xA640, 'M', u'ꙁ'), + (0xA641, 'V'), + (0xA642, 'M', u'ꙃ'), + (0xA643, 'V'), + (0xA644, 'M', u'ꙅ'), + (0xA645, 'V'), + (0xA646, 'M', u'ꙇ'), + (0xA647, 'V'), + (0xA648, 'M', u'ꙉ'), + (0xA649, 'V'), + (0xA64A, 'M', u'ꙋ'), + (0xA64B, 'V'), + (0xA64C, 'M', u'ꙍ'), + (0xA64D, 'V'), + (0xA64E, 'M', u'ꙏ'), + (0xA64F, 'V'), + (0xA650, 'M', u'ꙑ'), + (0xA651, 'V'), + (0xA652, 'M', u'ꙓ'), + (0xA653, 'V'), + (0xA654, 'M', u'ꙕ'), + (0xA655, 'V'), + (0xA656, 'M', u'ꙗ'), + (0xA657, 'V'), + (0xA658, 'M', u'ꙙ'), + (0xA659, 'V'), + (0xA65A, 'M', u'ꙛ'), + (0xA65B, 'V'), + (0xA65C, 'M', u'ꙝ'), + (0xA65D, 'V'), + (0xA65E, 'M', u'ꙟ'), + (0xA65F, 'V'), + (0xA660, 'M', u'ꙡ'), + (0xA661, 'V'), + (0xA662, 'M', u'ꙣ'), + (0xA663, 'V'), + (0xA664, 'M', u'ꙥ'), + (0xA665, 'V'), + (0xA666, 'M', u'ꙧ'), + (0xA667, 'V'), + (0xA668, 'M', u'ꙩ'), + (0xA669, 'V'), + (0xA66A, 'M', u'ꙫ'), + (0xA66B, 'V'), + (0xA66C, 'M', u'ꙭ'), + (0xA66D, 'V'), + (0xA680, 'M', u'ꚁ'), + (0xA681, 'V'), + (0xA682, 'M', u'ꚃ'), + (0xA683, 'V'), + (0xA684, 'M', u'ꚅ'), + (0xA685, 'V'), + (0xA686, 'M', u'ꚇ'), + (0xA687, 'V'), + (0xA688, 'M', u'ꚉ'), + (0xA689, 'V'), + (0xA68A, 'M', u'ꚋ'), + (0xA68B, 'V'), + (0xA68C, 'M', u'ꚍ'), + (0xA68D, 'V'), + (0xA68E, 'M', u'ꚏ'), + (0xA68F, 'V'), + (0xA690, 'M', u'ꚑ'), + (0xA691, 'V'), + (0xA692, 'M', u'ꚓ'), + (0xA693, 'V'), + (0xA694, 'M', u'ꚕ'), + (0xA695, 'V'), + (0xA696, 'M', u'ꚗ'), + (0xA697, 'V'), + (0xA698, 'M', u'ꚙ'), + (0xA699, 'V'), + (0xA69A, 'M', u'ꚛ'), + (0xA69B, 'V'), + (0xA69C, 'M', u'ъ'), + (0xA69D, 'M', u'ь'), + (0xA69E, 'V'), + (0xA6F8, 'X'), + ] + +def _seg_36(): + return [ + (0xA700, 'V'), + (0xA722, 'M', u'ꜣ'), + (0xA723, 'V'), + (0xA724, 'M', u'ꜥ'), + (0xA725, 'V'), + (0xA726, 'M', u'ꜧ'), + (0xA727, 'V'), + (0xA728, 'M', u'ꜩ'), + (0xA729, 'V'), + (0xA72A, 'M', u'ꜫ'), + (0xA72B, 'V'), + (0xA72C, 'M', u'ꜭ'), + (0xA72D, 'V'), + (0xA72E, 'M', u'ꜯ'), + (0xA72F, 'V'), + (0xA732, 'M', u'ꜳ'), + (0xA733, 'V'), + (0xA734, 'M', u'ꜵ'), + (0xA735, 'V'), + (0xA736, 'M', u'ꜷ'), + (0xA737, 'V'), + (0xA738, 'M', u'ꜹ'), + (0xA739, 'V'), + (0xA73A, 'M', u'ꜻ'), + (0xA73B, 'V'), + (0xA73C, 'M', u'ꜽ'), + (0xA73D, 'V'), + (0xA73E, 'M', u'ꜿ'), + (0xA73F, 'V'), + (0xA740, 'M', u'ꝁ'), + (0xA741, 'V'), + (0xA742, 'M', u'ꝃ'), + (0xA743, 'V'), + (0xA744, 'M', u'ꝅ'), + (0xA745, 'V'), + (0xA746, 'M', u'ꝇ'), + (0xA747, 'V'), + (0xA748, 'M', u'ꝉ'), + (0xA749, 'V'), + (0xA74A, 'M', u'ꝋ'), + (0xA74B, 'V'), + (0xA74C, 'M', u'ꝍ'), + (0xA74D, 'V'), + (0xA74E, 'M', u'ꝏ'), + (0xA74F, 'V'), + (0xA750, 'M', u'ꝑ'), + (0xA751, 'V'), + (0xA752, 'M', u'ꝓ'), + (0xA753, 'V'), + (0xA754, 'M', u'ꝕ'), + (0xA755, 'V'), + (0xA756, 'M', u'ꝗ'), + (0xA757, 'V'), + (0xA758, 'M', u'ꝙ'), + (0xA759, 'V'), + (0xA75A, 'M', u'ꝛ'), + (0xA75B, 'V'), + (0xA75C, 'M', u'ꝝ'), + (0xA75D, 'V'), + (0xA75E, 'M', u'ꝟ'), + (0xA75F, 'V'), + (0xA760, 'M', u'ꝡ'), + (0xA761, 'V'), + (0xA762, 'M', u'ꝣ'), + (0xA763, 'V'), + (0xA764, 'M', u'ꝥ'), + (0xA765, 'V'), + (0xA766, 'M', u'ꝧ'), + (0xA767, 'V'), + (0xA768, 'M', u'ꝩ'), + (0xA769, 'V'), + (0xA76A, 'M', u'ꝫ'), + (0xA76B, 'V'), + (0xA76C, 'M', u'ꝭ'), + (0xA76D, 'V'), + (0xA76E, 'M', u'ꝯ'), + (0xA76F, 'V'), + (0xA770, 'M', u'ꝯ'), + (0xA771, 'V'), + (0xA779, 'M', u'ꝺ'), + (0xA77A, 'V'), + (0xA77B, 'M', u'ꝼ'), + (0xA77C, 'V'), + (0xA77D, 'M', u'ᵹ'), + (0xA77E, 'M', u'ꝿ'), + (0xA77F, 'V'), + (0xA780, 'M', u'ꞁ'), + (0xA781, 'V'), + (0xA782, 'M', u'ꞃ'), + (0xA783, 'V'), + (0xA784, 'M', u'ꞅ'), + (0xA785, 'V'), + (0xA786, 'M', u'ꞇ'), + (0xA787, 'V'), + (0xA78B, 'M', u'ꞌ'), + (0xA78C, 'V'), + (0xA78D, 'M', u'ɥ'), + (0xA78E, 'V'), + (0xA790, 'M', u'ꞑ'), + (0xA791, 'V'), + ] + +def _seg_37(): + return [ + (0xA792, 'M', u'ꞓ'), + (0xA793, 'V'), + (0xA796, 'M', u'ꞗ'), + (0xA797, 'V'), + (0xA798, 'M', u'ꞙ'), + (0xA799, 'V'), + (0xA79A, 'M', u'ꞛ'), + (0xA79B, 'V'), + (0xA79C, 'M', u'ꞝ'), + (0xA79D, 'V'), + (0xA79E, 'M', u'ꞟ'), + (0xA79F, 'V'), + (0xA7A0, 'M', u'ꞡ'), + (0xA7A1, 'V'), + (0xA7A2, 'M', u'ꞣ'), + (0xA7A3, 'V'), + (0xA7A4, 'M', u'ꞥ'), + (0xA7A5, 'V'), + (0xA7A6, 'M', u'ꞧ'), + (0xA7A7, 'V'), + (0xA7A8, 'M', u'ꞩ'), + (0xA7A9, 'V'), + (0xA7AA, 'M', u'ɦ'), + (0xA7AB, 'M', u'ɜ'), + (0xA7AC, 'M', u'ɡ'), + (0xA7AD, 'M', u'ɬ'), + (0xA7AE, 'M', u'ɪ'), + (0xA7AF, 'V'), + (0xA7B0, 'M', u'ʞ'), + (0xA7B1, 'M', u'ʇ'), + (0xA7B2, 'M', u'ʝ'), + (0xA7B3, 'M', u'ꭓ'), + (0xA7B4, 'M', u'ꞵ'), + (0xA7B5, 'V'), + (0xA7B6, 'M', u'ꞷ'), + (0xA7B7, 'V'), + (0xA7B8, 'X'), + (0xA7B9, 'V'), + (0xA7BA, 'X'), + (0xA7F7, 'V'), + (0xA7F8, 'M', u'ħ'), + (0xA7F9, 'M', u'œ'), + (0xA7FA, 'V'), + (0xA82C, 'X'), + (0xA830, 'V'), + (0xA83A, 'X'), + (0xA840, 'V'), + (0xA878, 'X'), + (0xA880, 'V'), + (0xA8C6, 'X'), + (0xA8CE, 'V'), + (0xA8DA, 'X'), + (0xA8E0, 'V'), + (0xA954, 'X'), + (0xA95F, 'V'), + (0xA97D, 'X'), + (0xA980, 'V'), + (0xA9CE, 'X'), + (0xA9CF, 'V'), + (0xA9DA, 'X'), + (0xA9DE, 'V'), + (0xA9FF, 'X'), + (0xAA00, 'V'), + (0xAA37, 'X'), + (0xAA40, 'V'), + (0xAA4E, 'X'), + (0xAA50, 'V'), + (0xAA5A, 'X'), + (0xAA5C, 'V'), + (0xAAC3, 'X'), + (0xAADB, 'V'), + (0xAAF7, 'X'), + (0xAB01, 'V'), + (0xAB07, 'X'), + (0xAB09, 'V'), + (0xAB0F, 'X'), + (0xAB11, 'V'), + (0xAB17, 'X'), + (0xAB20, 'V'), + (0xAB27, 'X'), + (0xAB28, 'V'), + (0xAB2F, 'X'), + (0xAB30, 'V'), + (0xAB5C, 'M', u'ꜧ'), + (0xAB5D, 'M', u'ꬷ'), + (0xAB5E, 'M', u'ɫ'), + (0xAB5F, 'M', u'ꭒ'), + (0xAB60, 'V'), + (0xAB66, 'X'), + (0xAB70, 'M', u'Ꭰ'), + (0xAB71, 'M', u'Ꭱ'), + (0xAB72, 'M', u'Ꭲ'), + (0xAB73, 'M', u'Ꭳ'), + (0xAB74, 'M', u'Ꭴ'), + (0xAB75, 'M', u'Ꭵ'), + (0xAB76, 'M', u'Ꭶ'), + (0xAB77, 'M', u'Ꭷ'), + (0xAB78, 'M', u'Ꭸ'), + (0xAB79, 'M', u'Ꭹ'), + (0xAB7A, 'M', u'Ꭺ'), + ] + +def _seg_38(): + return [ + (0xAB7B, 'M', u'Ꭻ'), + (0xAB7C, 'M', u'Ꭼ'), + (0xAB7D, 'M', u'Ꭽ'), + (0xAB7E, 'M', u'Ꭾ'), + (0xAB7F, 'M', u'Ꭿ'), + (0xAB80, 'M', u'Ꮀ'), + (0xAB81, 'M', u'Ꮁ'), + (0xAB82, 'M', u'Ꮂ'), + (0xAB83, 'M', u'Ꮃ'), + (0xAB84, 'M', u'Ꮄ'), + (0xAB85, 'M', u'Ꮅ'), + (0xAB86, 'M', u'Ꮆ'), + (0xAB87, 'M', u'Ꮇ'), + (0xAB88, 'M', u'Ꮈ'), + (0xAB89, 'M', u'Ꮉ'), + (0xAB8A, 'M', u'Ꮊ'), + (0xAB8B, 'M', u'Ꮋ'), + (0xAB8C, 'M', u'Ꮌ'), + (0xAB8D, 'M', u'Ꮍ'), + (0xAB8E, 'M', u'Ꮎ'), + (0xAB8F, 'M', u'Ꮏ'), + (0xAB90, 'M', u'Ꮐ'), + (0xAB91, 'M', u'Ꮑ'), + (0xAB92, 'M', u'Ꮒ'), + (0xAB93, 'M', u'Ꮓ'), + (0xAB94, 'M', u'Ꮔ'), + (0xAB95, 'M', u'Ꮕ'), + (0xAB96, 'M', u'Ꮖ'), + (0xAB97, 'M', u'Ꮗ'), + (0xAB98, 'M', u'Ꮘ'), + (0xAB99, 'M', u'Ꮙ'), + (0xAB9A, 'M', u'Ꮚ'), + (0xAB9B, 'M', u'Ꮛ'), + (0xAB9C, 'M', u'Ꮜ'), + (0xAB9D, 'M', u'Ꮝ'), + (0xAB9E, 'M', u'Ꮞ'), + (0xAB9F, 'M', u'Ꮟ'), + (0xABA0, 'M', u'Ꮠ'), + (0xABA1, 'M', u'Ꮡ'), + (0xABA2, 'M', u'Ꮢ'), + (0xABA3, 'M', u'Ꮣ'), + (0xABA4, 'M', u'Ꮤ'), + (0xABA5, 'M', u'Ꮥ'), + (0xABA6, 'M', u'Ꮦ'), + (0xABA7, 'M', u'Ꮧ'), + (0xABA8, 'M', u'Ꮨ'), + (0xABA9, 'M', u'Ꮩ'), + (0xABAA, 'M', u'Ꮪ'), + (0xABAB, 'M', u'Ꮫ'), + (0xABAC, 'M', u'Ꮬ'), + (0xABAD, 'M', u'Ꮭ'), + (0xABAE, 'M', u'Ꮮ'), + (0xABAF, 'M', u'Ꮯ'), + (0xABB0, 'M', u'Ꮰ'), + (0xABB1, 'M', u'Ꮱ'), + (0xABB2, 'M', u'Ꮲ'), + (0xABB3, 'M', u'Ꮳ'), + (0xABB4, 'M', u'Ꮴ'), + (0xABB5, 'M', u'Ꮵ'), + (0xABB6, 'M', u'Ꮶ'), + (0xABB7, 'M', u'Ꮷ'), + (0xABB8, 'M', u'Ꮸ'), + (0xABB9, 'M', u'Ꮹ'), + (0xABBA, 'M', u'Ꮺ'), + (0xABBB, 'M', u'Ꮻ'), + (0xABBC, 'M', u'Ꮼ'), + (0xABBD, 'M', u'Ꮽ'), + (0xABBE, 'M', u'Ꮾ'), + (0xABBF, 'M', u'Ꮿ'), + (0xABC0, 'V'), + (0xABEE, 'X'), + (0xABF0, 'V'), + (0xABFA, 'X'), + (0xAC00, 'V'), + (0xD7A4, 'X'), + (0xD7B0, 'V'), + (0xD7C7, 'X'), + (0xD7CB, 'V'), + (0xD7FC, 'X'), + (0xF900, 'M', u'豈'), + (0xF901, 'M', u'更'), + (0xF902, 'M', u'車'), + (0xF903, 'M', u'賈'), + (0xF904, 'M', u'滑'), + (0xF905, 'M', u'串'), + (0xF906, 'M', u'句'), + (0xF907, 'M', u'龜'), + (0xF909, 'M', u'契'), + (0xF90A, 'M', u'金'), + (0xF90B, 'M', u'喇'), + (0xF90C, 'M', u'奈'), + (0xF90D, 'M', u'懶'), + (0xF90E, 'M', u'癩'), + (0xF90F, 'M', u'羅'), + (0xF910, 'M', u'蘿'), + (0xF911, 'M', u'螺'), + (0xF912, 'M', u'裸'), + (0xF913, 'M', u'邏'), + (0xF914, 'M', u'樂'), + (0xF915, 'M', u'洛'), + ] + +def _seg_39(): + return [ + (0xF916, 'M', u'烙'), + (0xF917, 'M', u'珞'), + (0xF918, 'M', u'落'), + (0xF919, 'M', u'酪'), + (0xF91A, 'M', u'駱'), + (0xF91B, 'M', u'亂'), + (0xF91C, 'M', u'卵'), + (0xF91D, 'M', u'欄'), + (0xF91E, 'M', u'爛'), + (0xF91F, 'M', u'蘭'), + (0xF920, 'M', u'鸞'), + (0xF921, 'M', u'嵐'), + (0xF922, 'M', u'濫'), + (0xF923, 'M', u'藍'), + (0xF924, 'M', u'襤'), + (0xF925, 'M', u'拉'), + (0xF926, 'M', u'臘'), + (0xF927, 'M', u'蠟'), + (0xF928, 'M', u'廊'), + (0xF929, 'M', u'朗'), + (0xF92A, 'M', u'浪'), + (0xF92B, 'M', u'狼'), + (0xF92C, 'M', u'郎'), + (0xF92D, 'M', u'來'), + (0xF92E, 'M', u'冷'), + (0xF92F, 'M', u'勞'), + (0xF930, 'M', u'擄'), + (0xF931, 'M', u'櫓'), + (0xF932, 'M', u'爐'), + (0xF933, 'M', u'盧'), + (0xF934, 'M', u'老'), + (0xF935, 'M', u'蘆'), + (0xF936, 'M', u'虜'), + (0xF937, 'M', u'路'), + (0xF938, 'M', u'露'), + (0xF939, 'M', u'魯'), + (0xF93A, 'M', u'鷺'), + (0xF93B, 'M', u'碌'), + (0xF93C, 'M', u'祿'), + (0xF93D, 'M', u'綠'), + (0xF93E, 'M', u'菉'), + (0xF93F, 'M', u'錄'), + (0xF940, 'M', u'鹿'), + (0xF941, 'M', u'論'), + (0xF942, 'M', u'壟'), + (0xF943, 'M', u'弄'), + (0xF944, 'M', u'籠'), + (0xF945, 'M', u'聾'), + (0xF946, 'M', u'牢'), + (0xF947, 'M', u'磊'), + (0xF948, 'M', u'賂'), + (0xF949, 'M', u'雷'), + (0xF94A, 'M', u'壘'), + (0xF94B, 'M', u'屢'), + (0xF94C, 'M', u'樓'), + (0xF94D, 'M', u'淚'), + (0xF94E, 'M', u'漏'), + (0xF94F, 'M', u'累'), + (0xF950, 'M', u'縷'), + (0xF951, 'M', u'陋'), + (0xF952, 'M', u'勒'), + (0xF953, 'M', u'肋'), + (0xF954, 'M', u'凜'), + (0xF955, 'M', u'凌'), + (0xF956, 'M', u'稜'), + (0xF957, 'M', u'綾'), + (0xF958, 'M', u'菱'), + (0xF959, 'M', u'陵'), + (0xF95A, 'M', u'讀'), + (0xF95B, 'M', u'拏'), + (0xF95C, 'M', u'樂'), + (0xF95D, 'M', u'諾'), + (0xF95E, 'M', u'丹'), + (0xF95F, 'M', u'寧'), + (0xF960, 'M', u'怒'), + (0xF961, 'M', u'率'), + (0xF962, 'M', u'異'), + (0xF963, 'M', u'北'), + (0xF964, 'M', u'磻'), + (0xF965, 'M', u'便'), + (0xF966, 'M', u'復'), + (0xF967, 'M', u'不'), + (0xF968, 'M', u'泌'), + (0xF969, 'M', u'數'), + (0xF96A, 'M', u'索'), + (0xF96B, 'M', u'參'), + (0xF96C, 'M', u'塞'), + (0xF96D, 'M', u'省'), + (0xF96E, 'M', u'葉'), + (0xF96F, 'M', u'說'), + (0xF970, 'M', u'殺'), + (0xF971, 'M', u'辰'), + (0xF972, 'M', u'沈'), + (0xF973, 'M', u'拾'), + (0xF974, 'M', u'若'), + (0xF975, 'M', u'掠'), + (0xF976, 'M', u'略'), + (0xF977, 'M', u'亮'), + (0xF978, 'M', u'兩'), + (0xF979, 'M', u'凉'), + ] + +def _seg_40(): + return [ + (0xF97A, 'M', u'梁'), + (0xF97B, 'M', u'糧'), + (0xF97C, 'M', u'良'), + (0xF97D, 'M', u'諒'), + (0xF97E, 'M', u'量'), + (0xF97F, 'M', u'勵'), + (0xF980, 'M', u'呂'), + (0xF981, 'M', u'女'), + (0xF982, 'M', u'廬'), + (0xF983, 'M', u'旅'), + (0xF984, 'M', u'濾'), + (0xF985, 'M', u'礪'), + (0xF986, 'M', u'閭'), + (0xF987, 'M', u'驪'), + (0xF988, 'M', u'麗'), + (0xF989, 'M', u'黎'), + (0xF98A, 'M', u'力'), + (0xF98B, 'M', u'曆'), + (0xF98C, 'M', u'歷'), + (0xF98D, 'M', u'轢'), + (0xF98E, 'M', u'年'), + (0xF98F, 'M', u'憐'), + (0xF990, 'M', u'戀'), + (0xF991, 'M', u'撚'), + (0xF992, 'M', u'漣'), + (0xF993, 'M', u'煉'), + (0xF994, 'M', u'璉'), + (0xF995, 'M', u'秊'), + (0xF996, 'M', u'練'), + (0xF997, 'M', u'聯'), + (0xF998, 'M', u'輦'), + (0xF999, 'M', u'蓮'), + (0xF99A, 'M', u'連'), + (0xF99B, 'M', u'鍊'), + (0xF99C, 'M', u'列'), + (0xF99D, 'M', u'劣'), + (0xF99E, 'M', u'咽'), + (0xF99F, 'M', u'烈'), + (0xF9A0, 'M', u'裂'), + (0xF9A1, 'M', u'說'), + (0xF9A2, 'M', u'廉'), + (0xF9A3, 'M', u'念'), + (0xF9A4, 'M', u'捻'), + (0xF9A5, 'M', u'殮'), + (0xF9A6, 'M', u'簾'), + (0xF9A7, 'M', u'獵'), + (0xF9A8, 'M', u'令'), + (0xF9A9, 'M', u'囹'), + (0xF9AA, 'M', u'寧'), + (0xF9AB, 'M', u'嶺'), + (0xF9AC, 'M', u'怜'), + (0xF9AD, 'M', u'玲'), + (0xF9AE, 'M', u'瑩'), + (0xF9AF, 'M', u'羚'), + (0xF9B0, 'M', u'聆'), + (0xF9B1, 'M', u'鈴'), + (0xF9B2, 'M', u'零'), + (0xF9B3, 'M', u'靈'), + (0xF9B4, 'M', u'領'), + (0xF9B5, 'M', u'例'), + (0xF9B6, 'M', u'禮'), + (0xF9B7, 'M', u'醴'), + (0xF9B8, 'M', u'隸'), + (0xF9B9, 'M', u'惡'), + (0xF9BA, 'M', u'了'), + (0xF9BB, 'M', u'僚'), + (0xF9BC, 'M', u'寮'), + (0xF9BD, 'M', u'尿'), + (0xF9BE, 'M', u'料'), + (0xF9BF, 'M', u'樂'), + (0xF9C0, 'M', u'燎'), + (0xF9C1, 'M', u'療'), + (0xF9C2, 'M', u'蓼'), + (0xF9C3, 'M', u'遼'), + (0xF9C4, 'M', u'龍'), + (0xF9C5, 'M', u'暈'), + (0xF9C6, 'M', u'阮'), + (0xF9C7, 'M', u'劉'), + (0xF9C8, 'M', u'杻'), + (0xF9C9, 'M', u'柳'), + (0xF9CA, 'M', u'流'), + (0xF9CB, 'M', u'溜'), + (0xF9CC, 'M', u'琉'), + (0xF9CD, 'M', u'留'), + (0xF9CE, 'M', u'硫'), + (0xF9CF, 'M', u'紐'), + (0xF9D0, 'M', u'類'), + (0xF9D1, 'M', u'六'), + (0xF9D2, 'M', u'戮'), + (0xF9D3, 'M', u'陸'), + (0xF9D4, 'M', u'倫'), + (0xF9D5, 'M', u'崙'), + (0xF9D6, 'M', u'淪'), + (0xF9D7, 'M', u'輪'), + (0xF9D8, 'M', u'律'), + (0xF9D9, 'M', u'慄'), + (0xF9DA, 'M', u'栗'), + (0xF9DB, 'M', u'率'), + (0xF9DC, 'M', u'隆'), + (0xF9DD, 'M', u'利'), + ] + +def _seg_41(): + return [ + (0xF9DE, 'M', u'吏'), + (0xF9DF, 'M', u'履'), + (0xF9E0, 'M', u'易'), + (0xF9E1, 'M', u'李'), + (0xF9E2, 'M', u'梨'), + (0xF9E3, 'M', u'泥'), + (0xF9E4, 'M', u'理'), + (0xF9E5, 'M', u'痢'), + (0xF9E6, 'M', u'罹'), + (0xF9E7, 'M', u'裏'), + (0xF9E8, 'M', u'裡'), + (0xF9E9, 'M', u'里'), + (0xF9EA, 'M', u'離'), + (0xF9EB, 'M', u'匿'), + (0xF9EC, 'M', u'溺'), + (0xF9ED, 'M', u'吝'), + (0xF9EE, 'M', u'燐'), + (0xF9EF, 'M', u'璘'), + (0xF9F0, 'M', u'藺'), + (0xF9F1, 'M', u'隣'), + (0xF9F2, 'M', u'鱗'), + (0xF9F3, 'M', u'麟'), + (0xF9F4, 'M', u'林'), + (0xF9F5, 'M', u'淋'), + (0xF9F6, 'M', u'臨'), + (0xF9F7, 'M', u'立'), + (0xF9F8, 'M', u'笠'), + (0xF9F9, 'M', u'粒'), + (0xF9FA, 'M', u'狀'), + (0xF9FB, 'M', u'炙'), + (0xF9FC, 'M', u'識'), + (0xF9FD, 'M', u'什'), + (0xF9FE, 'M', u'茶'), + (0xF9FF, 'M', u'刺'), + (0xFA00, 'M', u'切'), + (0xFA01, 'M', u'度'), + (0xFA02, 'M', u'拓'), + (0xFA03, 'M', u'糖'), + (0xFA04, 'M', u'宅'), + (0xFA05, 'M', u'洞'), + (0xFA06, 'M', u'暴'), + (0xFA07, 'M', u'輻'), + (0xFA08, 'M', u'行'), + (0xFA09, 'M', u'降'), + (0xFA0A, 'M', u'見'), + (0xFA0B, 'M', u'廓'), + (0xFA0C, 'M', u'兀'), + (0xFA0D, 'M', u'嗀'), + (0xFA0E, 'V'), + (0xFA10, 'M', u'塚'), + (0xFA11, 'V'), + (0xFA12, 'M', u'晴'), + (0xFA13, 'V'), + (0xFA15, 'M', u'凞'), + (0xFA16, 'M', u'猪'), + (0xFA17, 'M', u'益'), + (0xFA18, 'M', u'礼'), + (0xFA19, 'M', u'神'), + (0xFA1A, 'M', u'祥'), + (0xFA1B, 'M', u'福'), + (0xFA1C, 'M', u'靖'), + (0xFA1D, 'M', u'精'), + (0xFA1E, 'M', u'羽'), + (0xFA1F, 'V'), + (0xFA20, 'M', u'蘒'), + (0xFA21, 'V'), + (0xFA22, 'M', u'諸'), + (0xFA23, 'V'), + (0xFA25, 'M', u'逸'), + (0xFA26, 'M', u'都'), + (0xFA27, 'V'), + (0xFA2A, 'M', u'飯'), + (0xFA2B, 'M', u'飼'), + (0xFA2C, 'M', u'館'), + (0xFA2D, 'M', u'鶴'), + (0xFA2E, 'M', u'郞'), + (0xFA2F, 'M', u'隷'), + (0xFA30, 'M', u'侮'), + (0xFA31, 'M', u'僧'), + (0xFA32, 'M', u'免'), + (0xFA33, 'M', u'勉'), + (0xFA34, 'M', u'勤'), + (0xFA35, 'M', u'卑'), + (0xFA36, 'M', u'喝'), + (0xFA37, 'M', u'嘆'), + (0xFA38, 'M', u'器'), + (0xFA39, 'M', u'塀'), + (0xFA3A, 'M', u'墨'), + (0xFA3B, 'M', u'層'), + (0xFA3C, 'M', u'屮'), + (0xFA3D, 'M', u'悔'), + (0xFA3E, 'M', u'慨'), + (0xFA3F, 'M', u'憎'), + (0xFA40, 'M', u'懲'), + (0xFA41, 'M', u'敏'), + (0xFA42, 'M', u'既'), + (0xFA43, 'M', u'暑'), + (0xFA44, 'M', u'梅'), + (0xFA45, 'M', u'海'), + (0xFA46, 'M', u'渚'), + ] + +def _seg_42(): + return [ + (0xFA47, 'M', u'漢'), + (0xFA48, 'M', u'煮'), + (0xFA49, 'M', u'爫'), + (0xFA4A, 'M', u'琢'), + (0xFA4B, 'M', u'碑'), + (0xFA4C, 'M', u'社'), + (0xFA4D, 'M', u'祉'), + (0xFA4E, 'M', u'祈'), + (0xFA4F, 'M', u'祐'), + (0xFA50, 'M', u'祖'), + (0xFA51, 'M', u'祝'), + (0xFA52, 'M', u'禍'), + (0xFA53, 'M', u'禎'), + (0xFA54, 'M', u'穀'), + (0xFA55, 'M', u'突'), + (0xFA56, 'M', u'節'), + (0xFA57, 'M', u'練'), + (0xFA58, 'M', u'縉'), + (0xFA59, 'M', u'繁'), + (0xFA5A, 'M', u'署'), + (0xFA5B, 'M', u'者'), + (0xFA5C, 'M', u'臭'), + (0xFA5D, 'M', u'艹'), + (0xFA5F, 'M', u'著'), + (0xFA60, 'M', u'褐'), + (0xFA61, 'M', u'視'), + (0xFA62, 'M', u'謁'), + (0xFA63, 'M', u'謹'), + (0xFA64, 'M', u'賓'), + (0xFA65, 'M', u'贈'), + (0xFA66, 'M', u'辶'), + (0xFA67, 'M', u'逸'), + (0xFA68, 'M', u'難'), + (0xFA69, 'M', u'響'), + (0xFA6A, 'M', u'頻'), + (0xFA6B, 'M', u'恵'), + (0xFA6C, 'M', u'𤋮'), + (0xFA6D, 'M', u'舘'), + (0xFA6E, 'X'), + (0xFA70, 'M', u'並'), + (0xFA71, 'M', u'况'), + (0xFA72, 'M', u'全'), + (0xFA73, 'M', u'侀'), + (0xFA74, 'M', u'充'), + (0xFA75, 'M', u'冀'), + (0xFA76, 'M', u'勇'), + (0xFA77, 'M', u'勺'), + (0xFA78, 'M', u'喝'), + (0xFA79, 'M', u'啕'), + (0xFA7A, 'M', u'喙'), + (0xFA7B, 'M', u'嗢'), + (0xFA7C, 'M', u'塚'), + (0xFA7D, 'M', u'墳'), + (0xFA7E, 'M', u'奄'), + (0xFA7F, 'M', u'奔'), + (0xFA80, 'M', u'婢'), + (0xFA81, 'M', u'嬨'), + (0xFA82, 'M', u'廒'), + (0xFA83, 'M', u'廙'), + (0xFA84, 'M', u'彩'), + (0xFA85, 'M', u'徭'), + (0xFA86, 'M', u'惘'), + (0xFA87, 'M', u'慎'), + (0xFA88, 'M', u'愈'), + (0xFA89, 'M', u'憎'), + (0xFA8A, 'M', u'慠'), + (0xFA8B, 'M', u'懲'), + (0xFA8C, 'M', u'戴'), + (0xFA8D, 'M', u'揄'), + (0xFA8E, 'M', u'搜'), + (0xFA8F, 'M', u'摒'), + (0xFA90, 'M', u'敖'), + (0xFA91, 'M', u'晴'), + (0xFA92, 'M', u'朗'), + (0xFA93, 'M', u'望'), + (0xFA94, 'M', u'杖'), + (0xFA95, 'M', u'歹'), + (0xFA96, 'M', u'殺'), + (0xFA97, 'M', u'流'), + (0xFA98, 'M', u'滛'), + (0xFA99, 'M', u'滋'), + (0xFA9A, 'M', u'漢'), + (0xFA9B, 'M', u'瀞'), + (0xFA9C, 'M', u'煮'), + (0xFA9D, 'M', u'瞧'), + (0xFA9E, 'M', u'爵'), + (0xFA9F, 'M', u'犯'), + (0xFAA0, 'M', u'猪'), + (0xFAA1, 'M', u'瑱'), + (0xFAA2, 'M', u'甆'), + (0xFAA3, 'M', u'画'), + (0xFAA4, 'M', u'瘝'), + (0xFAA5, 'M', u'瘟'), + (0xFAA6, 'M', u'益'), + (0xFAA7, 'M', u'盛'), + (0xFAA8, 'M', u'直'), + (0xFAA9, 'M', u'睊'), + (0xFAAA, 'M', u'着'), + (0xFAAB, 'M', u'磌'), + (0xFAAC, 'M', u'窱'), + ] + +def _seg_43(): + return [ + (0xFAAD, 'M', u'節'), + (0xFAAE, 'M', u'类'), + (0xFAAF, 'M', u'絛'), + (0xFAB0, 'M', u'練'), + (0xFAB1, 'M', u'缾'), + (0xFAB2, 'M', u'者'), + (0xFAB3, 'M', u'荒'), + (0xFAB4, 'M', u'華'), + (0xFAB5, 'M', u'蝹'), + (0xFAB6, 'M', u'襁'), + (0xFAB7, 'M', u'覆'), + (0xFAB8, 'M', u'視'), + (0xFAB9, 'M', u'調'), + (0xFABA, 'M', u'諸'), + (0xFABB, 'M', u'請'), + (0xFABC, 'M', u'謁'), + (0xFABD, 'M', u'諾'), + (0xFABE, 'M', u'諭'), + (0xFABF, 'M', u'謹'), + (0xFAC0, 'M', u'變'), + (0xFAC1, 'M', u'贈'), + (0xFAC2, 'M', u'輸'), + (0xFAC3, 'M', u'遲'), + (0xFAC4, 'M', u'醙'), + (0xFAC5, 'M', u'鉶'), + (0xFAC6, 'M', u'陼'), + (0xFAC7, 'M', u'難'), + (0xFAC8, 'M', u'靖'), + (0xFAC9, 'M', u'韛'), + (0xFACA, 'M', u'響'), + (0xFACB, 'M', u'頋'), + (0xFACC, 'M', u'頻'), + (0xFACD, 'M', u'鬒'), + (0xFACE, 'M', u'龜'), + (0xFACF, 'M', u'𢡊'), + (0xFAD0, 'M', u'𢡄'), + (0xFAD1, 'M', u'𣏕'), + (0xFAD2, 'M', u'㮝'), + (0xFAD3, 'M', u'䀘'), + (0xFAD4, 'M', u'䀹'), + (0xFAD5, 'M', u'𥉉'), + (0xFAD6, 'M', u'𥳐'), + (0xFAD7, 'M', u'𧻓'), + (0xFAD8, 'M', u'齃'), + (0xFAD9, 'M', u'龎'), + (0xFADA, 'X'), + (0xFB00, 'M', u'ff'), + (0xFB01, 'M', u'fi'), + (0xFB02, 'M', u'fl'), + (0xFB03, 'M', u'ffi'), + (0xFB04, 'M', u'ffl'), + (0xFB05, 'M', u'st'), + (0xFB07, 'X'), + (0xFB13, 'M', u'մն'), + (0xFB14, 'M', u'մե'), + (0xFB15, 'M', u'մի'), + (0xFB16, 'M', u'վն'), + (0xFB17, 'M', u'մխ'), + (0xFB18, 'X'), + (0xFB1D, 'M', u'יִ'), + (0xFB1E, 'V'), + (0xFB1F, 'M', u'ײַ'), + (0xFB20, 'M', u'ע'), + (0xFB21, 'M', u'א'), + (0xFB22, 'M', u'ד'), + (0xFB23, 'M', u'ה'), + (0xFB24, 'M', u'כ'), + (0xFB25, 'M', u'ל'), + (0xFB26, 'M', u'ם'), + (0xFB27, 'M', u'ר'), + (0xFB28, 'M', u'ת'), + (0xFB29, '3', u'+'), + (0xFB2A, 'M', u'שׁ'), + (0xFB2B, 'M', u'שׂ'), + (0xFB2C, 'M', u'שּׁ'), + (0xFB2D, 'M', u'שּׂ'), + (0xFB2E, 'M', u'אַ'), + (0xFB2F, 'M', u'אָ'), + (0xFB30, 'M', u'אּ'), + (0xFB31, 'M', u'בּ'), + (0xFB32, 'M', u'גּ'), + (0xFB33, 'M', u'דּ'), + (0xFB34, 'M', u'הּ'), + (0xFB35, 'M', u'וּ'), + (0xFB36, 'M', u'זּ'), + (0xFB37, 'X'), + (0xFB38, 'M', u'טּ'), + (0xFB39, 'M', u'יּ'), + (0xFB3A, 'M', u'ךּ'), + (0xFB3B, 'M', u'כּ'), + (0xFB3C, 'M', u'לּ'), + (0xFB3D, 'X'), + (0xFB3E, 'M', u'מּ'), + (0xFB3F, 'X'), + (0xFB40, 'M', u'נּ'), + (0xFB41, 'M', u'סּ'), + (0xFB42, 'X'), + (0xFB43, 'M', u'ףּ'), + (0xFB44, 'M', u'פּ'), + (0xFB45, 'X'), + ] + +def _seg_44(): + return [ + (0xFB46, 'M', u'צּ'), + (0xFB47, 'M', u'קּ'), + (0xFB48, 'M', u'רּ'), + (0xFB49, 'M', u'שּ'), + (0xFB4A, 'M', u'תּ'), + (0xFB4B, 'M', u'וֹ'), + (0xFB4C, 'M', u'בֿ'), + (0xFB4D, 'M', u'כֿ'), + (0xFB4E, 'M', u'פֿ'), + (0xFB4F, 'M', u'אל'), + (0xFB50, 'M', u'ٱ'), + (0xFB52, 'M', u'ٻ'), + (0xFB56, 'M', u'پ'), + (0xFB5A, 'M', u'ڀ'), + (0xFB5E, 'M', u'ٺ'), + (0xFB62, 'M', u'ٿ'), + (0xFB66, 'M', u'ٹ'), + (0xFB6A, 'M', u'ڤ'), + (0xFB6E, 'M', u'ڦ'), + (0xFB72, 'M', u'ڄ'), + (0xFB76, 'M', u'ڃ'), + (0xFB7A, 'M', u'چ'), + (0xFB7E, 'M', u'ڇ'), + (0xFB82, 'M', u'ڍ'), + (0xFB84, 'M', u'ڌ'), + (0xFB86, 'M', u'ڎ'), + (0xFB88, 'M', u'ڈ'), + (0xFB8A, 'M', u'ژ'), + (0xFB8C, 'M', u'ڑ'), + (0xFB8E, 'M', u'ک'), + (0xFB92, 'M', u'گ'), + (0xFB96, 'M', u'ڳ'), + (0xFB9A, 'M', u'ڱ'), + (0xFB9E, 'M', u'ں'), + (0xFBA0, 'M', u'ڻ'), + (0xFBA4, 'M', u'ۀ'), + (0xFBA6, 'M', u'ہ'), + (0xFBAA, 'M', u'ھ'), + (0xFBAE, 'M', u'ے'), + (0xFBB0, 'M', u'ۓ'), + (0xFBB2, 'V'), + (0xFBC2, 'X'), + (0xFBD3, 'M', u'ڭ'), + (0xFBD7, 'M', u'ۇ'), + (0xFBD9, 'M', u'ۆ'), + (0xFBDB, 'M', u'ۈ'), + (0xFBDD, 'M', u'ۇٴ'), + (0xFBDE, 'M', u'ۋ'), + (0xFBE0, 'M', u'ۅ'), + (0xFBE2, 'M', u'ۉ'), + (0xFBE4, 'M', u'ې'), + (0xFBE8, 'M', u'ى'), + (0xFBEA, 'M', u'ئا'), + (0xFBEC, 'M', u'ئە'), + (0xFBEE, 'M', u'ئو'), + (0xFBF0, 'M', u'ئۇ'), + (0xFBF2, 'M', u'ئۆ'), + (0xFBF4, 'M', u'ئۈ'), + (0xFBF6, 'M', u'ئې'), + (0xFBF9, 'M', u'ئى'), + (0xFBFC, 'M', u'ی'), + (0xFC00, 'M', u'ئج'), + (0xFC01, 'M', u'ئح'), + (0xFC02, 'M', u'ئم'), + (0xFC03, 'M', u'ئى'), + (0xFC04, 'M', u'ئي'), + (0xFC05, 'M', u'بج'), + (0xFC06, 'M', u'بح'), + (0xFC07, 'M', u'بخ'), + (0xFC08, 'M', u'بم'), + (0xFC09, 'M', u'بى'), + (0xFC0A, 'M', u'بي'), + (0xFC0B, 'M', u'تج'), + (0xFC0C, 'M', u'تح'), + (0xFC0D, 'M', u'تخ'), + (0xFC0E, 'M', u'تم'), + (0xFC0F, 'M', u'تى'), + (0xFC10, 'M', u'تي'), + (0xFC11, 'M', u'ثج'), + (0xFC12, 'M', u'ثم'), + (0xFC13, 'M', u'ثى'), + (0xFC14, 'M', u'ثي'), + (0xFC15, 'M', u'جح'), + (0xFC16, 'M', u'جم'), + (0xFC17, 'M', u'حج'), + (0xFC18, 'M', u'حم'), + (0xFC19, 'M', u'خج'), + (0xFC1A, 'M', u'خح'), + (0xFC1B, 'M', u'خم'), + (0xFC1C, 'M', u'سج'), + (0xFC1D, 'M', u'سح'), + (0xFC1E, 'M', u'سخ'), + (0xFC1F, 'M', u'سم'), + (0xFC20, 'M', u'صح'), + (0xFC21, 'M', u'صم'), + (0xFC22, 'M', u'ضج'), + (0xFC23, 'M', u'ضح'), + (0xFC24, 'M', u'ضخ'), + (0xFC25, 'M', u'ضم'), + (0xFC26, 'M', u'طح'), + ] + +def _seg_45(): + return [ + (0xFC27, 'M', u'طم'), + (0xFC28, 'M', u'ظم'), + (0xFC29, 'M', u'عج'), + (0xFC2A, 'M', u'عم'), + (0xFC2B, 'M', u'غج'), + (0xFC2C, 'M', u'غم'), + (0xFC2D, 'M', u'فج'), + (0xFC2E, 'M', u'فح'), + (0xFC2F, 'M', u'فخ'), + (0xFC30, 'M', u'فم'), + (0xFC31, 'M', u'فى'), + (0xFC32, 'M', u'في'), + (0xFC33, 'M', u'قح'), + (0xFC34, 'M', u'قم'), + (0xFC35, 'M', u'قى'), + (0xFC36, 'M', u'قي'), + (0xFC37, 'M', u'كا'), + (0xFC38, 'M', u'كج'), + (0xFC39, 'M', u'كح'), + (0xFC3A, 'M', u'كخ'), + (0xFC3B, 'M', u'كل'), + (0xFC3C, 'M', u'كم'), + (0xFC3D, 'M', u'كى'), + (0xFC3E, 'M', u'كي'), + (0xFC3F, 'M', u'لج'), + (0xFC40, 'M', u'لح'), + (0xFC41, 'M', u'لخ'), + (0xFC42, 'M', u'لم'), + (0xFC43, 'M', u'لى'), + (0xFC44, 'M', u'لي'), + (0xFC45, 'M', u'مج'), + (0xFC46, 'M', u'مح'), + (0xFC47, 'M', u'مخ'), + (0xFC48, 'M', u'مم'), + (0xFC49, 'M', u'مى'), + (0xFC4A, 'M', u'مي'), + (0xFC4B, 'M', u'نج'), + (0xFC4C, 'M', u'نح'), + (0xFC4D, 'M', u'نخ'), + (0xFC4E, 'M', u'نم'), + (0xFC4F, 'M', u'نى'), + (0xFC50, 'M', u'ني'), + (0xFC51, 'M', u'هج'), + (0xFC52, 'M', u'هم'), + (0xFC53, 'M', u'هى'), + (0xFC54, 'M', u'هي'), + (0xFC55, 'M', u'يج'), + (0xFC56, 'M', u'يح'), + (0xFC57, 'M', u'يخ'), + (0xFC58, 'M', u'يم'), + (0xFC59, 'M', u'يى'), + (0xFC5A, 'M', u'يي'), + (0xFC5B, 'M', u'ذٰ'), + (0xFC5C, 'M', u'رٰ'), + (0xFC5D, 'M', u'ىٰ'), + (0xFC5E, '3', u' ٌّ'), + (0xFC5F, '3', u' ٍّ'), + (0xFC60, '3', u' َّ'), + (0xFC61, '3', u' ُّ'), + (0xFC62, '3', u' ِّ'), + (0xFC63, '3', u' ّٰ'), + (0xFC64, 'M', u'ئر'), + (0xFC65, 'M', u'ئز'), + (0xFC66, 'M', u'ئم'), + (0xFC67, 'M', u'ئن'), + (0xFC68, 'M', u'ئى'), + (0xFC69, 'M', u'ئي'), + (0xFC6A, 'M', u'بر'), + (0xFC6B, 'M', u'بز'), + (0xFC6C, 'M', u'بم'), + (0xFC6D, 'M', u'بن'), + (0xFC6E, 'M', u'بى'), + (0xFC6F, 'M', u'بي'), + (0xFC70, 'M', u'تر'), + (0xFC71, 'M', u'تز'), + (0xFC72, 'M', u'تم'), + (0xFC73, 'M', u'تن'), + (0xFC74, 'M', u'تى'), + (0xFC75, 'M', u'تي'), + (0xFC76, 'M', u'ثر'), + (0xFC77, 'M', u'ثز'), + (0xFC78, 'M', u'ثم'), + (0xFC79, 'M', u'ثن'), + (0xFC7A, 'M', u'ثى'), + (0xFC7B, 'M', u'ثي'), + (0xFC7C, 'M', u'فى'), + (0xFC7D, 'M', u'في'), + (0xFC7E, 'M', u'قى'), + (0xFC7F, 'M', u'قي'), + (0xFC80, 'M', u'كا'), + (0xFC81, 'M', u'كل'), + (0xFC82, 'M', u'كم'), + (0xFC83, 'M', u'كى'), + (0xFC84, 'M', u'كي'), + (0xFC85, 'M', u'لم'), + (0xFC86, 'M', u'لى'), + (0xFC87, 'M', u'لي'), + (0xFC88, 'M', u'ما'), + (0xFC89, 'M', u'مم'), + (0xFC8A, 'M', u'نر'), + ] + +def _seg_46(): + return [ + (0xFC8B, 'M', u'نز'), + (0xFC8C, 'M', u'نم'), + (0xFC8D, 'M', u'نن'), + (0xFC8E, 'M', u'نى'), + (0xFC8F, 'M', u'ني'), + (0xFC90, 'M', u'ىٰ'), + (0xFC91, 'M', u'ير'), + (0xFC92, 'M', u'يز'), + (0xFC93, 'M', u'يم'), + (0xFC94, 'M', u'ين'), + (0xFC95, 'M', u'يى'), + (0xFC96, 'M', u'يي'), + (0xFC97, 'M', u'ئج'), + (0xFC98, 'M', u'ئح'), + (0xFC99, 'M', u'ئخ'), + (0xFC9A, 'M', u'ئم'), + (0xFC9B, 'M', u'ئه'), + (0xFC9C, 'M', u'بج'), + (0xFC9D, 'M', u'بح'), + (0xFC9E, 'M', u'بخ'), + (0xFC9F, 'M', u'بم'), + (0xFCA0, 'M', u'به'), + (0xFCA1, 'M', u'تج'), + (0xFCA2, 'M', u'تح'), + (0xFCA3, 'M', u'تخ'), + (0xFCA4, 'M', u'تم'), + (0xFCA5, 'M', u'ته'), + (0xFCA6, 'M', u'ثم'), + (0xFCA7, 'M', u'جح'), + (0xFCA8, 'M', u'جم'), + (0xFCA9, 'M', u'حج'), + (0xFCAA, 'M', u'حم'), + (0xFCAB, 'M', u'خج'), + (0xFCAC, 'M', u'خم'), + (0xFCAD, 'M', u'سج'), + (0xFCAE, 'M', u'سح'), + (0xFCAF, 'M', u'سخ'), + (0xFCB0, 'M', u'سم'), + (0xFCB1, 'M', u'صح'), + (0xFCB2, 'M', u'صخ'), + (0xFCB3, 'M', u'صم'), + (0xFCB4, 'M', u'ضج'), + (0xFCB5, 'M', u'ضح'), + (0xFCB6, 'M', u'ضخ'), + (0xFCB7, 'M', u'ضم'), + (0xFCB8, 'M', u'طح'), + (0xFCB9, 'M', u'ظم'), + (0xFCBA, 'M', u'عج'), + (0xFCBB, 'M', u'عم'), + (0xFCBC, 'M', u'غج'), + (0xFCBD, 'M', u'غم'), + (0xFCBE, 'M', u'فج'), + (0xFCBF, 'M', u'فح'), + (0xFCC0, 'M', u'فخ'), + (0xFCC1, 'M', u'فم'), + (0xFCC2, 'M', u'قح'), + (0xFCC3, 'M', u'قم'), + (0xFCC4, 'M', u'كج'), + (0xFCC5, 'M', u'كح'), + (0xFCC6, 'M', u'كخ'), + (0xFCC7, 'M', u'كل'), + (0xFCC8, 'M', u'كم'), + (0xFCC9, 'M', u'لج'), + (0xFCCA, 'M', u'لح'), + (0xFCCB, 'M', u'لخ'), + (0xFCCC, 'M', u'لم'), + (0xFCCD, 'M', u'له'), + (0xFCCE, 'M', u'مج'), + (0xFCCF, 'M', u'مح'), + (0xFCD0, 'M', u'مخ'), + (0xFCD1, 'M', u'مم'), + (0xFCD2, 'M', u'نج'), + (0xFCD3, 'M', u'نح'), + (0xFCD4, 'M', u'نخ'), + (0xFCD5, 'M', u'نم'), + (0xFCD6, 'M', u'نه'), + (0xFCD7, 'M', u'هج'), + (0xFCD8, 'M', u'هم'), + (0xFCD9, 'M', u'هٰ'), + (0xFCDA, 'M', u'يج'), + (0xFCDB, 'M', u'يح'), + (0xFCDC, 'M', u'يخ'), + (0xFCDD, 'M', u'يم'), + (0xFCDE, 'M', u'يه'), + (0xFCDF, 'M', u'ئم'), + (0xFCE0, 'M', u'ئه'), + (0xFCE1, 'M', u'بم'), + (0xFCE2, 'M', u'به'), + (0xFCE3, 'M', u'تم'), + (0xFCE4, 'M', u'ته'), + (0xFCE5, 'M', u'ثم'), + (0xFCE6, 'M', u'ثه'), + (0xFCE7, 'M', u'سم'), + (0xFCE8, 'M', u'سه'), + (0xFCE9, 'M', u'شم'), + (0xFCEA, 'M', u'شه'), + (0xFCEB, 'M', u'كل'), + (0xFCEC, 'M', u'كم'), + (0xFCED, 'M', u'لم'), + (0xFCEE, 'M', u'نم'), + ] + +def _seg_47(): + return [ + (0xFCEF, 'M', u'نه'), + (0xFCF0, 'M', u'يم'), + (0xFCF1, 'M', u'يه'), + (0xFCF2, 'M', u'ـَّ'), + (0xFCF3, 'M', u'ـُّ'), + (0xFCF4, 'M', u'ـِّ'), + (0xFCF5, 'M', u'طى'), + (0xFCF6, 'M', u'طي'), + (0xFCF7, 'M', u'عى'), + (0xFCF8, 'M', u'عي'), + (0xFCF9, 'M', u'غى'), + (0xFCFA, 'M', u'غي'), + (0xFCFB, 'M', u'سى'), + (0xFCFC, 'M', u'سي'), + (0xFCFD, 'M', u'شى'), + (0xFCFE, 'M', u'شي'), + (0xFCFF, 'M', u'حى'), + (0xFD00, 'M', u'حي'), + (0xFD01, 'M', u'جى'), + (0xFD02, 'M', u'جي'), + (0xFD03, 'M', u'خى'), + (0xFD04, 'M', u'خي'), + (0xFD05, 'M', u'صى'), + (0xFD06, 'M', u'صي'), + (0xFD07, 'M', u'ضى'), + (0xFD08, 'M', u'ضي'), + (0xFD09, 'M', u'شج'), + (0xFD0A, 'M', u'شح'), + (0xFD0B, 'M', u'شخ'), + (0xFD0C, 'M', u'شم'), + (0xFD0D, 'M', u'شر'), + (0xFD0E, 'M', u'سر'), + (0xFD0F, 'M', u'صر'), + (0xFD10, 'M', u'ضر'), + (0xFD11, 'M', u'طى'), + (0xFD12, 'M', u'طي'), + (0xFD13, 'M', u'عى'), + (0xFD14, 'M', u'عي'), + (0xFD15, 'M', u'غى'), + (0xFD16, 'M', u'غي'), + (0xFD17, 'M', u'سى'), + (0xFD18, 'M', u'سي'), + (0xFD19, 'M', u'شى'), + (0xFD1A, 'M', u'شي'), + (0xFD1B, 'M', u'حى'), + (0xFD1C, 'M', u'حي'), + (0xFD1D, 'M', u'جى'), + (0xFD1E, 'M', u'جي'), + (0xFD1F, 'M', u'خى'), + (0xFD20, 'M', u'خي'), + (0xFD21, 'M', u'صى'), + (0xFD22, 'M', u'صي'), + (0xFD23, 'M', u'ضى'), + (0xFD24, 'M', u'ضي'), + (0xFD25, 'M', u'شج'), + (0xFD26, 'M', u'شح'), + (0xFD27, 'M', u'شخ'), + (0xFD28, 'M', u'شم'), + (0xFD29, 'M', u'شر'), + (0xFD2A, 'M', u'سر'), + (0xFD2B, 'M', u'صر'), + (0xFD2C, 'M', u'ضر'), + (0xFD2D, 'M', u'شج'), + (0xFD2E, 'M', u'شح'), + (0xFD2F, 'M', u'شخ'), + (0xFD30, 'M', u'شم'), + (0xFD31, 'M', u'سه'), + (0xFD32, 'M', u'شه'), + (0xFD33, 'M', u'طم'), + (0xFD34, 'M', u'سج'), + (0xFD35, 'M', u'سح'), + (0xFD36, 'M', u'سخ'), + (0xFD37, 'M', u'شج'), + (0xFD38, 'M', u'شح'), + (0xFD39, 'M', u'شخ'), + (0xFD3A, 'M', u'طم'), + (0xFD3B, 'M', u'ظم'), + (0xFD3C, 'M', u'اً'), + (0xFD3E, 'V'), + (0xFD40, 'X'), + (0xFD50, 'M', u'تجم'), + (0xFD51, 'M', u'تحج'), + (0xFD53, 'M', u'تحم'), + (0xFD54, 'M', u'تخم'), + (0xFD55, 'M', u'تمج'), + (0xFD56, 'M', u'تمح'), + (0xFD57, 'M', u'تمخ'), + (0xFD58, 'M', u'جمح'), + (0xFD5A, 'M', u'حمي'), + (0xFD5B, 'M', u'حمى'), + (0xFD5C, 'M', u'سحج'), + (0xFD5D, 'M', u'سجح'), + (0xFD5E, 'M', u'سجى'), + (0xFD5F, 'M', u'سمح'), + (0xFD61, 'M', u'سمج'), + (0xFD62, 'M', u'سمم'), + (0xFD64, 'M', u'صحح'), + (0xFD66, 'M', u'صمم'), + (0xFD67, 'M', u'شحم'), + (0xFD69, 'M', u'شجي'), + ] + +def _seg_48(): + return [ + (0xFD6A, 'M', u'شمخ'), + (0xFD6C, 'M', u'شمم'), + (0xFD6E, 'M', u'ضحى'), + (0xFD6F, 'M', u'ضخم'), + (0xFD71, 'M', u'طمح'), + (0xFD73, 'M', u'طمم'), + (0xFD74, 'M', u'طمي'), + (0xFD75, 'M', u'عجم'), + (0xFD76, 'M', u'عمم'), + (0xFD78, 'M', u'عمى'), + (0xFD79, 'M', u'غمم'), + (0xFD7A, 'M', u'غمي'), + (0xFD7B, 'M', u'غمى'), + (0xFD7C, 'M', u'فخم'), + (0xFD7E, 'M', u'قمح'), + (0xFD7F, 'M', u'قمم'), + (0xFD80, 'M', u'لحم'), + (0xFD81, 'M', u'لحي'), + (0xFD82, 'M', u'لحى'), + (0xFD83, 'M', u'لجج'), + (0xFD85, 'M', u'لخم'), + (0xFD87, 'M', u'لمح'), + (0xFD89, 'M', u'محج'), + (0xFD8A, 'M', u'محم'), + (0xFD8B, 'M', u'محي'), + (0xFD8C, 'M', u'مجح'), + (0xFD8D, 'M', u'مجم'), + (0xFD8E, 'M', u'مخج'), + (0xFD8F, 'M', u'مخم'), + (0xFD90, 'X'), + (0xFD92, 'M', u'مجخ'), + (0xFD93, 'M', u'همج'), + (0xFD94, 'M', u'همم'), + (0xFD95, 'M', u'نحم'), + (0xFD96, 'M', u'نحى'), + (0xFD97, 'M', u'نجم'), + (0xFD99, 'M', u'نجى'), + (0xFD9A, 'M', u'نمي'), + (0xFD9B, 'M', u'نمى'), + (0xFD9C, 'M', u'يمم'), + (0xFD9E, 'M', u'بخي'), + (0xFD9F, 'M', u'تجي'), + (0xFDA0, 'M', u'تجى'), + (0xFDA1, 'M', u'تخي'), + (0xFDA2, 'M', u'تخى'), + (0xFDA3, 'M', u'تمي'), + (0xFDA4, 'M', u'تمى'), + (0xFDA5, 'M', u'جمي'), + (0xFDA6, 'M', u'جحى'), + (0xFDA7, 'M', u'جمى'), + (0xFDA8, 'M', u'سخى'), + (0xFDA9, 'M', u'صحي'), + (0xFDAA, 'M', u'شحي'), + (0xFDAB, 'M', u'ضحي'), + (0xFDAC, 'M', u'لجي'), + (0xFDAD, 'M', u'لمي'), + (0xFDAE, 'M', u'يحي'), + (0xFDAF, 'M', u'يجي'), + (0xFDB0, 'M', u'يمي'), + (0xFDB1, 'M', u'ممي'), + (0xFDB2, 'M', u'قمي'), + (0xFDB3, 'M', u'نحي'), + (0xFDB4, 'M', u'قمح'), + (0xFDB5, 'M', u'لحم'), + (0xFDB6, 'M', u'عمي'), + (0xFDB7, 'M', u'كمي'), + (0xFDB8, 'M', u'نجح'), + (0xFDB9, 'M', u'مخي'), + (0xFDBA, 'M', u'لجم'), + (0xFDBB, 'M', u'كمم'), + (0xFDBC, 'M', u'لجم'), + (0xFDBD, 'M', u'نجح'), + (0xFDBE, 'M', u'جحي'), + (0xFDBF, 'M', u'حجي'), + (0xFDC0, 'M', u'مجي'), + (0xFDC1, 'M', u'فمي'), + (0xFDC2, 'M', u'بحي'), + (0xFDC3, 'M', u'كمم'), + (0xFDC4, 'M', u'عجم'), + (0xFDC5, 'M', u'صمم'), + (0xFDC6, 'M', u'سخي'), + (0xFDC7, 'M', u'نجي'), + (0xFDC8, 'X'), + (0xFDF0, 'M', u'صلے'), + (0xFDF1, 'M', u'قلے'), + (0xFDF2, 'M', u'الله'), + (0xFDF3, 'M', u'اكبر'), + (0xFDF4, 'M', u'محمد'), + (0xFDF5, 'M', u'صلعم'), + (0xFDF6, 'M', u'رسول'), + (0xFDF7, 'M', u'عليه'), + (0xFDF8, 'M', u'وسلم'), + (0xFDF9, 'M', u'صلى'), + (0xFDFA, '3', u'صلى الله عليه وسلم'), + (0xFDFB, '3', u'جل جلاله'), + (0xFDFC, 'M', u'ریال'), + (0xFDFD, 'V'), + (0xFDFE, 'X'), + (0xFE00, 'I'), + (0xFE10, '3', u','), + ] + +def _seg_49(): + return [ + (0xFE11, 'M', u'、'), + (0xFE12, 'X'), + (0xFE13, '3', u':'), + (0xFE14, '3', u';'), + (0xFE15, '3', u'!'), + (0xFE16, '3', u'?'), + (0xFE17, 'M', u'〖'), + (0xFE18, 'M', u'〗'), + (0xFE19, 'X'), + (0xFE20, 'V'), + (0xFE30, 'X'), + (0xFE31, 'M', u'—'), + (0xFE32, 'M', u'–'), + (0xFE33, '3', u'_'), + (0xFE35, '3', u'('), + (0xFE36, '3', u')'), + (0xFE37, '3', u'{'), + (0xFE38, '3', u'}'), + (0xFE39, 'M', u'〔'), + (0xFE3A, 'M', u'〕'), + (0xFE3B, 'M', u'【'), + (0xFE3C, 'M', u'】'), + (0xFE3D, 'M', u'《'), + (0xFE3E, 'M', u'》'), + (0xFE3F, 'M', u'〈'), + (0xFE40, 'M', u'〉'), + (0xFE41, 'M', u'「'), + (0xFE42, 'M', u'」'), + (0xFE43, 'M', u'『'), + (0xFE44, 'M', u'』'), + (0xFE45, 'V'), + (0xFE47, '3', u'['), + (0xFE48, '3', u']'), + (0xFE49, '3', u' ̅'), + (0xFE4D, '3', u'_'), + (0xFE50, '3', u','), + (0xFE51, 'M', u'、'), + (0xFE52, 'X'), + (0xFE54, '3', u';'), + (0xFE55, '3', u':'), + (0xFE56, '3', u'?'), + (0xFE57, '3', u'!'), + (0xFE58, 'M', u'—'), + (0xFE59, '3', u'('), + (0xFE5A, '3', u')'), + (0xFE5B, '3', u'{'), + (0xFE5C, '3', u'}'), + (0xFE5D, 'M', u'〔'), + (0xFE5E, 'M', u'〕'), + (0xFE5F, '3', u'#'), + (0xFE60, '3', u'&'), + (0xFE61, '3', u'*'), + (0xFE62, '3', u'+'), + (0xFE63, 'M', u'-'), + (0xFE64, '3', u'<'), + (0xFE65, '3', u'>'), + (0xFE66, '3', u'='), + (0xFE67, 'X'), + (0xFE68, '3', u'\\'), + (0xFE69, '3', u'$'), + (0xFE6A, '3', u'%'), + (0xFE6B, '3', u'@'), + (0xFE6C, 'X'), + (0xFE70, '3', u' ً'), + (0xFE71, 'M', u'ـً'), + (0xFE72, '3', u' ٌ'), + (0xFE73, 'V'), + (0xFE74, '3', u' ٍ'), + (0xFE75, 'X'), + (0xFE76, '3', u' َ'), + (0xFE77, 'M', u'ـَ'), + (0xFE78, '3', u' ُ'), + (0xFE79, 'M', u'ـُ'), + (0xFE7A, '3', u' ِ'), + (0xFE7B, 'M', u'ـِ'), + (0xFE7C, '3', u' ّ'), + (0xFE7D, 'M', u'ـّ'), + (0xFE7E, '3', u' ْ'), + (0xFE7F, 'M', u'ـْ'), + (0xFE80, 'M', u'ء'), + (0xFE81, 'M', u'آ'), + (0xFE83, 'M', u'أ'), + (0xFE85, 'M', u'ؤ'), + (0xFE87, 'M', u'إ'), + (0xFE89, 'M', u'ئ'), + (0xFE8D, 'M', u'ا'), + (0xFE8F, 'M', u'ب'), + (0xFE93, 'M', u'ة'), + (0xFE95, 'M', u'ت'), + (0xFE99, 'M', u'ث'), + (0xFE9D, 'M', u'ج'), + (0xFEA1, 'M', u'ح'), + (0xFEA5, 'M', u'خ'), + (0xFEA9, 'M', u'د'), + (0xFEAB, 'M', u'ذ'), + (0xFEAD, 'M', u'ر'), + (0xFEAF, 'M', u'ز'), + (0xFEB1, 'M', u'س'), + (0xFEB5, 'M', u'ش'), + (0xFEB9, 'M', u'ص'), + ] + +def _seg_50(): + return [ + (0xFEBD, 'M', u'ض'), + (0xFEC1, 'M', u'ط'), + (0xFEC5, 'M', u'ظ'), + (0xFEC9, 'M', u'ع'), + (0xFECD, 'M', u'غ'), + (0xFED1, 'M', u'ف'), + (0xFED5, 'M', u'ق'), + (0xFED9, 'M', u'ك'), + (0xFEDD, 'M', u'ل'), + (0xFEE1, 'M', u'م'), + (0xFEE5, 'M', u'ن'), + (0xFEE9, 'M', u'ه'), + (0xFEED, 'M', u'و'), + (0xFEEF, 'M', u'ى'), + (0xFEF1, 'M', u'ي'), + (0xFEF5, 'M', u'لآ'), + (0xFEF7, 'M', u'لأ'), + (0xFEF9, 'M', u'لإ'), + (0xFEFB, 'M', u'لا'), + (0xFEFD, 'X'), + (0xFEFF, 'I'), + (0xFF00, 'X'), + (0xFF01, '3', u'!'), + (0xFF02, '3', u'"'), + (0xFF03, '3', u'#'), + (0xFF04, '3', u'$'), + (0xFF05, '3', u'%'), + (0xFF06, '3', u'&'), + (0xFF07, '3', u'\''), + (0xFF08, '3', u'('), + (0xFF09, '3', u')'), + (0xFF0A, '3', u'*'), + (0xFF0B, '3', u'+'), + (0xFF0C, '3', u','), + (0xFF0D, 'M', u'-'), + (0xFF0E, 'M', u'.'), + (0xFF0F, '3', u'/'), + (0xFF10, 'M', u'0'), + (0xFF11, 'M', u'1'), + (0xFF12, 'M', u'2'), + (0xFF13, 'M', u'3'), + (0xFF14, 'M', u'4'), + (0xFF15, 'M', u'5'), + (0xFF16, 'M', u'6'), + (0xFF17, 'M', u'7'), + (0xFF18, 'M', u'8'), + (0xFF19, 'M', u'9'), + (0xFF1A, '3', u':'), + (0xFF1B, '3', u';'), + (0xFF1C, '3', u'<'), + (0xFF1D, '3', u'='), + (0xFF1E, '3', u'>'), + (0xFF1F, '3', u'?'), + (0xFF20, '3', u'@'), + (0xFF21, 'M', u'a'), + (0xFF22, 'M', u'b'), + (0xFF23, 'M', u'c'), + (0xFF24, 'M', u'd'), + (0xFF25, 'M', u'e'), + (0xFF26, 'M', u'f'), + (0xFF27, 'M', u'g'), + (0xFF28, 'M', u'h'), + (0xFF29, 'M', u'i'), + (0xFF2A, 'M', u'j'), + (0xFF2B, 'M', u'k'), + (0xFF2C, 'M', u'l'), + (0xFF2D, 'M', u'm'), + (0xFF2E, 'M', u'n'), + (0xFF2F, 'M', u'o'), + (0xFF30, 'M', u'p'), + (0xFF31, 'M', u'q'), + (0xFF32, 'M', u'r'), + (0xFF33, 'M', u's'), + (0xFF34, 'M', u't'), + (0xFF35, 'M', u'u'), + (0xFF36, 'M', u'v'), + (0xFF37, 'M', u'w'), + (0xFF38, 'M', u'x'), + (0xFF39, 'M', u'y'), + (0xFF3A, 'M', u'z'), + (0xFF3B, '3', u'['), + (0xFF3C, '3', u'\\'), + (0xFF3D, '3', u']'), + (0xFF3E, '3', u'^'), + (0xFF3F, '3', u'_'), + (0xFF40, '3', u'`'), + (0xFF41, 'M', u'a'), + (0xFF42, 'M', u'b'), + (0xFF43, 'M', u'c'), + (0xFF44, 'M', u'd'), + (0xFF45, 'M', u'e'), + (0xFF46, 'M', u'f'), + (0xFF47, 'M', u'g'), + (0xFF48, 'M', u'h'), + (0xFF49, 'M', u'i'), + (0xFF4A, 'M', u'j'), + (0xFF4B, 'M', u'k'), + (0xFF4C, 'M', u'l'), + (0xFF4D, 'M', u'm'), + (0xFF4E, 'M', u'n'), + ] + +def _seg_51(): + return [ + (0xFF4F, 'M', u'o'), + (0xFF50, 'M', u'p'), + (0xFF51, 'M', u'q'), + (0xFF52, 'M', u'r'), + (0xFF53, 'M', u's'), + (0xFF54, 'M', u't'), + (0xFF55, 'M', u'u'), + (0xFF56, 'M', u'v'), + (0xFF57, 'M', u'w'), + (0xFF58, 'M', u'x'), + (0xFF59, 'M', u'y'), + (0xFF5A, 'M', u'z'), + (0xFF5B, '3', u'{'), + (0xFF5C, '3', u'|'), + (0xFF5D, '3', u'}'), + (0xFF5E, '3', u'~'), + (0xFF5F, 'M', u'⦅'), + (0xFF60, 'M', u'⦆'), + (0xFF61, 'M', u'.'), + (0xFF62, 'M', u'「'), + (0xFF63, 'M', u'」'), + (0xFF64, 'M', u'、'), + (0xFF65, 'M', u'・'), + (0xFF66, 'M', u'ヲ'), + (0xFF67, 'M', u'ァ'), + (0xFF68, 'M', u'ィ'), + (0xFF69, 'M', u'ゥ'), + (0xFF6A, 'M', u'ェ'), + (0xFF6B, 'M', u'ォ'), + (0xFF6C, 'M', u'ャ'), + (0xFF6D, 'M', u'ュ'), + (0xFF6E, 'M', u'ョ'), + (0xFF6F, 'M', u'ッ'), + (0xFF70, 'M', u'ー'), + (0xFF71, 'M', u'ア'), + (0xFF72, 'M', u'イ'), + (0xFF73, 'M', u'ウ'), + (0xFF74, 'M', u'エ'), + (0xFF75, 'M', u'オ'), + (0xFF76, 'M', u'カ'), + (0xFF77, 'M', u'キ'), + (0xFF78, 'M', u'ク'), + (0xFF79, 'M', u'ケ'), + (0xFF7A, 'M', u'コ'), + (0xFF7B, 'M', u'サ'), + (0xFF7C, 'M', u'シ'), + (0xFF7D, 'M', u'ス'), + (0xFF7E, 'M', u'セ'), + (0xFF7F, 'M', u'ソ'), + (0xFF80, 'M', u'タ'), + (0xFF81, 'M', u'チ'), + (0xFF82, 'M', u'ツ'), + (0xFF83, 'M', u'テ'), + (0xFF84, 'M', u'ト'), + (0xFF85, 'M', u'ナ'), + (0xFF86, 'M', u'ニ'), + (0xFF87, 'M', u'ヌ'), + (0xFF88, 'M', u'ネ'), + (0xFF89, 'M', u'ノ'), + (0xFF8A, 'M', u'ハ'), + (0xFF8B, 'M', u'ヒ'), + (0xFF8C, 'M', u'フ'), + (0xFF8D, 'M', u'ヘ'), + (0xFF8E, 'M', u'ホ'), + (0xFF8F, 'M', u'マ'), + (0xFF90, 'M', u'ミ'), + (0xFF91, 'M', u'ム'), + (0xFF92, 'M', u'メ'), + (0xFF93, 'M', u'モ'), + (0xFF94, 'M', u'ヤ'), + (0xFF95, 'M', u'ユ'), + (0xFF96, 'M', u'ヨ'), + (0xFF97, 'M', u'ラ'), + (0xFF98, 'M', u'リ'), + (0xFF99, 'M', u'ル'), + (0xFF9A, 'M', u'レ'), + (0xFF9B, 'M', u'ロ'), + (0xFF9C, 'M', u'ワ'), + (0xFF9D, 'M', u'ン'), + (0xFF9E, 'M', u'゙'), + (0xFF9F, 'M', u'゚'), + (0xFFA0, 'X'), + (0xFFA1, 'M', u'ᄀ'), + (0xFFA2, 'M', u'ᄁ'), + (0xFFA3, 'M', u'ᆪ'), + (0xFFA4, 'M', u'ᄂ'), + (0xFFA5, 'M', u'ᆬ'), + (0xFFA6, 'M', u'ᆭ'), + (0xFFA7, 'M', u'ᄃ'), + (0xFFA8, 'M', u'ᄄ'), + (0xFFA9, 'M', u'ᄅ'), + (0xFFAA, 'M', u'ᆰ'), + (0xFFAB, 'M', u'ᆱ'), + (0xFFAC, 'M', u'ᆲ'), + (0xFFAD, 'M', u'ᆳ'), + (0xFFAE, 'M', u'ᆴ'), + (0xFFAF, 'M', u'ᆵ'), + (0xFFB0, 'M', u'ᄚ'), + (0xFFB1, 'M', u'ᄆ'), + (0xFFB2, 'M', u'ᄇ'), + ] + +def _seg_52(): + return [ + (0xFFB3, 'M', u'ᄈ'), + (0xFFB4, 'M', u'ᄡ'), + (0xFFB5, 'M', u'ᄉ'), + (0xFFB6, 'M', u'ᄊ'), + (0xFFB7, 'M', u'ᄋ'), + (0xFFB8, 'M', u'ᄌ'), + (0xFFB9, 'M', u'ᄍ'), + (0xFFBA, 'M', u'ᄎ'), + (0xFFBB, 'M', u'ᄏ'), + (0xFFBC, 'M', u'ᄐ'), + (0xFFBD, 'M', u'ᄑ'), + (0xFFBE, 'M', u'ᄒ'), + (0xFFBF, 'X'), + (0xFFC2, 'M', u'ᅡ'), + (0xFFC3, 'M', u'ᅢ'), + (0xFFC4, 'M', u'ᅣ'), + (0xFFC5, 'M', u'ᅤ'), + (0xFFC6, 'M', u'ᅥ'), + (0xFFC7, 'M', u'ᅦ'), + (0xFFC8, 'X'), + (0xFFCA, 'M', u'ᅧ'), + (0xFFCB, 'M', u'ᅨ'), + (0xFFCC, 'M', u'ᅩ'), + (0xFFCD, 'M', u'ᅪ'), + (0xFFCE, 'M', u'ᅫ'), + (0xFFCF, 'M', u'ᅬ'), + (0xFFD0, 'X'), + (0xFFD2, 'M', u'ᅭ'), + (0xFFD3, 'M', u'ᅮ'), + (0xFFD4, 'M', u'ᅯ'), + (0xFFD5, 'M', u'ᅰ'), + (0xFFD6, 'M', u'ᅱ'), + (0xFFD7, 'M', u'ᅲ'), + (0xFFD8, 'X'), + (0xFFDA, 'M', u'ᅳ'), + (0xFFDB, 'M', u'ᅴ'), + (0xFFDC, 'M', u'ᅵ'), + (0xFFDD, 'X'), + (0xFFE0, 'M', u'¢'), + (0xFFE1, 'M', u'£'), + (0xFFE2, 'M', u'¬'), + (0xFFE3, '3', u' ̄'), + (0xFFE4, 'M', u'¦'), + (0xFFE5, 'M', u'¥'), + (0xFFE6, 'M', u'₩'), + (0xFFE7, 'X'), + (0xFFE8, 'M', u'│'), + (0xFFE9, 'M', u'←'), + (0xFFEA, 'M', u'↑'), + (0xFFEB, 'M', u'→'), + (0xFFEC, 'M', u'↓'), + (0xFFED, 'M', u'■'), + (0xFFEE, 'M', u'○'), + (0xFFEF, 'X'), + (0x10000, 'V'), + (0x1000C, 'X'), + (0x1000D, 'V'), + (0x10027, 'X'), + (0x10028, 'V'), + (0x1003B, 'X'), + (0x1003C, 'V'), + (0x1003E, 'X'), + (0x1003F, 'V'), + (0x1004E, 'X'), + (0x10050, 'V'), + (0x1005E, 'X'), + (0x10080, 'V'), + (0x100FB, 'X'), + (0x10100, 'V'), + (0x10103, 'X'), + (0x10107, 'V'), + (0x10134, 'X'), + (0x10137, 'V'), + (0x1018F, 'X'), + (0x10190, 'V'), + (0x1019C, 'X'), + (0x101A0, 'V'), + (0x101A1, 'X'), + (0x101D0, 'V'), + (0x101FE, 'X'), + (0x10280, 'V'), + (0x1029D, 'X'), + (0x102A0, 'V'), + (0x102D1, 'X'), + (0x102E0, 'V'), + (0x102FC, 'X'), + (0x10300, 'V'), + (0x10324, 'X'), + (0x1032D, 'V'), + (0x1034B, 'X'), + (0x10350, 'V'), + (0x1037B, 'X'), + (0x10380, 'V'), + (0x1039E, 'X'), + (0x1039F, 'V'), + (0x103C4, 'X'), + (0x103C8, 'V'), + (0x103D6, 'X'), + (0x10400, 'M', u'𐐨'), + (0x10401, 'M', u'𐐩'), + ] + +def _seg_53(): + return [ + (0x10402, 'M', u'𐐪'), + (0x10403, 'M', u'𐐫'), + (0x10404, 'M', u'𐐬'), + (0x10405, 'M', u'𐐭'), + (0x10406, 'M', u'𐐮'), + (0x10407, 'M', u'𐐯'), + (0x10408, 'M', u'𐐰'), + (0x10409, 'M', u'𐐱'), + (0x1040A, 'M', u'𐐲'), + (0x1040B, 'M', u'𐐳'), + (0x1040C, 'M', u'𐐴'), + (0x1040D, 'M', u'𐐵'), + (0x1040E, 'M', u'𐐶'), + (0x1040F, 'M', u'𐐷'), + (0x10410, 'M', u'𐐸'), + (0x10411, 'M', u'𐐹'), + (0x10412, 'M', u'𐐺'), + (0x10413, 'M', u'𐐻'), + (0x10414, 'M', u'𐐼'), + (0x10415, 'M', u'𐐽'), + (0x10416, 'M', u'𐐾'), + (0x10417, 'M', u'𐐿'), + (0x10418, 'M', u'𐑀'), + (0x10419, 'M', u'𐑁'), + (0x1041A, 'M', u'𐑂'), + (0x1041B, 'M', u'𐑃'), + (0x1041C, 'M', u'𐑄'), + (0x1041D, 'M', u'𐑅'), + (0x1041E, 'M', u'𐑆'), + (0x1041F, 'M', u'𐑇'), + (0x10420, 'M', u'𐑈'), + (0x10421, 'M', u'𐑉'), + (0x10422, 'M', u'𐑊'), + (0x10423, 'M', u'𐑋'), + (0x10424, 'M', u'𐑌'), + (0x10425, 'M', u'𐑍'), + (0x10426, 'M', u'𐑎'), + (0x10427, 'M', u'𐑏'), + (0x10428, 'V'), + (0x1049E, 'X'), + (0x104A0, 'V'), + (0x104AA, 'X'), + (0x104B0, 'M', u'𐓘'), + (0x104B1, 'M', u'𐓙'), + (0x104B2, 'M', u'𐓚'), + (0x104B3, 'M', u'𐓛'), + (0x104B4, 'M', u'𐓜'), + (0x104B5, 'M', u'𐓝'), + (0x104B6, 'M', u'𐓞'), + (0x104B7, 'M', u'𐓟'), + (0x104B8, 'M', u'𐓠'), + (0x104B9, 'M', u'𐓡'), + (0x104BA, 'M', u'𐓢'), + (0x104BB, 'M', u'𐓣'), + (0x104BC, 'M', u'𐓤'), + (0x104BD, 'M', u'𐓥'), + (0x104BE, 'M', u'𐓦'), + (0x104BF, 'M', u'𐓧'), + (0x104C0, 'M', u'𐓨'), + (0x104C1, 'M', u'𐓩'), + (0x104C2, 'M', u'𐓪'), + (0x104C3, 'M', u'𐓫'), + (0x104C4, 'M', u'𐓬'), + (0x104C5, 'M', u'𐓭'), + (0x104C6, 'M', u'𐓮'), + (0x104C7, 'M', u'𐓯'), + (0x104C8, 'M', u'𐓰'), + (0x104C9, 'M', u'𐓱'), + (0x104CA, 'M', u'𐓲'), + (0x104CB, 'M', u'𐓳'), + (0x104CC, 'M', u'𐓴'), + (0x104CD, 'M', u'𐓵'), + (0x104CE, 'M', u'𐓶'), + (0x104CF, 'M', u'𐓷'), + (0x104D0, 'M', u'𐓸'), + (0x104D1, 'M', u'𐓹'), + (0x104D2, 'M', u'𐓺'), + (0x104D3, 'M', u'𐓻'), + (0x104D4, 'X'), + (0x104D8, 'V'), + (0x104FC, 'X'), + (0x10500, 'V'), + (0x10528, 'X'), + (0x10530, 'V'), + (0x10564, 'X'), + (0x1056F, 'V'), + (0x10570, 'X'), + (0x10600, 'V'), + (0x10737, 'X'), + (0x10740, 'V'), + (0x10756, 'X'), + (0x10760, 'V'), + (0x10768, 'X'), + (0x10800, 'V'), + (0x10806, 'X'), + (0x10808, 'V'), + (0x10809, 'X'), + (0x1080A, 'V'), + (0x10836, 'X'), + (0x10837, 'V'), + ] + +def _seg_54(): + return [ + (0x10839, 'X'), + (0x1083C, 'V'), + (0x1083D, 'X'), + (0x1083F, 'V'), + (0x10856, 'X'), + (0x10857, 'V'), + (0x1089F, 'X'), + (0x108A7, 'V'), + (0x108B0, 'X'), + (0x108E0, 'V'), + (0x108F3, 'X'), + (0x108F4, 'V'), + (0x108F6, 'X'), + (0x108FB, 'V'), + (0x1091C, 'X'), + (0x1091F, 'V'), + (0x1093A, 'X'), + (0x1093F, 'V'), + (0x10940, 'X'), + (0x10980, 'V'), + (0x109B8, 'X'), + (0x109BC, 'V'), + (0x109D0, 'X'), + (0x109D2, 'V'), + (0x10A04, 'X'), + (0x10A05, 'V'), + (0x10A07, 'X'), + (0x10A0C, 'V'), + (0x10A14, 'X'), + (0x10A15, 'V'), + (0x10A18, 'X'), + (0x10A19, 'V'), + (0x10A36, 'X'), + (0x10A38, 'V'), + (0x10A3B, 'X'), + (0x10A3F, 'V'), + (0x10A49, 'X'), + (0x10A50, 'V'), + (0x10A59, 'X'), + (0x10A60, 'V'), + (0x10AA0, 'X'), + (0x10AC0, 'V'), + (0x10AE7, 'X'), + (0x10AEB, 'V'), + (0x10AF7, 'X'), + (0x10B00, 'V'), + (0x10B36, 'X'), + (0x10B39, 'V'), + (0x10B56, 'X'), + (0x10B58, 'V'), + (0x10B73, 'X'), + (0x10B78, 'V'), + (0x10B92, 'X'), + (0x10B99, 'V'), + (0x10B9D, 'X'), + (0x10BA9, 'V'), + (0x10BB0, 'X'), + (0x10C00, 'V'), + (0x10C49, 'X'), + (0x10C80, 'M', u'𐳀'), + (0x10C81, 'M', u'𐳁'), + (0x10C82, 'M', u'𐳂'), + (0x10C83, 'M', u'𐳃'), + (0x10C84, 'M', u'𐳄'), + (0x10C85, 'M', u'𐳅'), + (0x10C86, 'M', u'𐳆'), + (0x10C87, 'M', u'𐳇'), + (0x10C88, 'M', u'𐳈'), + (0x10C89, 'M', u'𐳉'), + (0x10C8A, 'M', u'𐳊'), + (0x10C8B, 'M', u'𐳋'), + (0x10C8C, 'M', u'𐳌'), + (0x10C8D, 'M', u'𐳍'), + (0x10C8E, 'M', u'𐳎'), + (0x10C8F, 'M', u'𐳏'), + (0x10C90, 'M', u'𐳐'), + (0x10C91, 'M', u'𐳑'), + (0x10C92, 'M', u'𐳒'), + (0x10C93, 'M', u'𐳓'), + (0x10C94, 'M', u'𐳔'), + (0x10C95, 'M', u'𐳕'), + (0x10C96, 'M', u'𐳖'), + (0x10C97, 'M', u'𐳗'), + (0x10C98, 'M', u'𐳘'), + (0x10C99, 'M', u'𐳙'), + (0x10C9A, 'M', u'𐳚'), + (0x10C9B, 'M', u'𐳛'), + (0x10C9C, 'M', u'𐳜'), + (0x10C9D, 'M', u'𐳝'), + (0x10C9E, 'M', u'𐳞'), + (0x10C9F, 'M', u'𐳟'), + (0x10CA0, 'M', u'𐳠'), + (0x10CA1, 'M', u'𐳡'), + (0x10CA2, 'M', u'𐳢'), + (0x10CA3, 'M', u'𐳣'), + (0x10CA4, 'M', u'𐳤'), + (0x10CA5, 'M', u'𐳥'), + (0x10CA6, 'M', u'𐳦'), + (0x10CA7, 'M', u'𐳧'), + (0x10CA8, 'M', u'𐳨'), + ] + +def _seg_55(): + return [ + (0x10CA9, 'M', u'𐳩'), + (0x10CAA, 'M', u'𐳪'), + (0x10CAB, 'M', u'𐳫'), + (0x10CAC, 'M', u'𐳬'), + (0x10CAD, 'M', u'𐳭'), + (0x10CAE, 'M', u'𐳮'), + (0x10CAF, 'M', u'𐳯'), + (0x10CB0, 'M', u'𐳰'), + (0x10CB1, 'M', u'𐳱'), + (0x10CB2, 'M', u'𐳲'), + (0x10CB3, 'X'), + (0x10CC0, 'V'), + (0x10CF3, 'X'), + (0x10CFA, 'V'), + (0x10D28, 'X'), + (0x10D30, 'V'), + (0x10D3A, 'X'), + (0x10E60, 'V'), + (0x10E7F, 'X'), + (0x10F00, 'V'), + (0x10F28, 'X'), + (0x10F30, 'V'), + (0x10F5A, 'X'), + (0x11000, 'V'), + (0x1104E, 'X'), + (0x11052, 'V'), + (0x11070, 'X'), + (0x1107F, 'V'), + (0x110BD, 'X'), + (0x110BE, 'V'), + (0x110C2, 'X'), + (0x110D0, 'V'), + (0x110E9, 'X'), + (0x110F0, 'V'), + (0x110FA, 'X'), + (0x11100, 'V'), + (0x11135, 'X'), + (0x11136, 'V'), + (0x11147, 'X'), + (0x11150, 'V'), + (0x11177, 'X'), + (0x11180, 'V'), + (0x111CE, 'X'), + (0x111D0, 'V'), + (0x111E0, 'X'), + (0x111E1, 'V'), + (0x111F5, 'X'), + (0x11200, 'V'), + (0x11212, 'X'), + (0x11213, 'V'), + (0x1123F, 'X'), + (0x11280, 'V'), + (0x11287, 'X'), + (0x11288, 'V'), + (0x11289, 'X'), + (0x1128A, 'V'), + (0x1128E, 'X'), + (0x1128F, 'V'), + (0x1129E, 'X'), + (0x1129F, 'V'), + (0x112AA, 'X'), + (0x112B0, 'V'), + (0x112EB, 'X'), + (0x112F0, 'V'), + (0x112FA, 'X'), + (0x11300, 'V'), + (0x11304, 'X'), + (0x11305, 'V'), + (0x1130D, 'X'), + (0x1130F, 'V'), + (0x11311, 'X'), + (0x11313, 'V'), + (0x11329, 'X'), + (0x1132A, 'V'), + (0x11331, 'X'), + (0x11332, 'V'), + (0x11334, 'X'), + (0x11335, 'V'), + (0x1133A, 'X'), + (0x1133B, 'V'), + (0x11345, 'X'), + (0x11347, 'V'), + (0x11349, 'X'), + (0x1134B, 'V'), + (0x1134E, 'X'), + (0x11350, 'V'), + (0x11351, 'X'), + (0x11357, 'V'), + (0x11358, 'X'), + (0x1135D, 'V'), + (0x11364, 'X'), + (0x11366, 'V'), + (0x1136D, 'X'), + (0x11370, 'V'), + (0x11375, 'X'), + (0x11400, 'V'), + (0x1145A, 'X'), + (0x1145B, 'V'), + (0x1145C, 'X'), + (0x1145D, 'V'), + ] + +def _seg_56(): + return [ + (0x1145F, 'X'), + (0x11480, 'V'), + (0x114C8, 'X'), + (0x114D0, 'V'), + (0x114DA, 'X'), + (0x11580, 'V'), + (0x115B6, 'X'), + (0x115B8, 'V'), + (0x115DE, 'X'), + (0x11600, 'V'), + (0x11645, 'X'), + (0x11650, 'V'), + (0x1165A, 'X'), + (0x11660, 'V'), + (0x1166D, 'X'), + (0x11680, 'V'), + (0x116B8, 'X'), + (0x116C0, 'V'), + (0x116CA, 'X'), + (0x11700, 'V'), + (0x1171B, 'X'), + (0x1171D, 'V'), + (0x1172C, 'X'), + (0x11730, 'V'), + (0x11740, 'X'), + (0x11800, 'V'), + (0x1183C, 'X'), + (0x118A0, 'M', u'𑣀'), + (0x118A1, 'M', u'𑣁'), + (0x118A2, 'M', u'𑣂'), + (0x118A3, 'M', u'𑣃'), + (0x118A4, 'M', u'𑣄'), + (0x118A5, 'M', u'𑣅'), + (0x118A6, 'M', u'𑣆'), + (0x118A7, 'M', u'𑣇'), + (0x118A8, 'M', u'𑣈'), + (0x118A9, 'M', u'𑣉'), + (0x118AA, 'M', u'𑣊'), + (0x118AB, 'M', u'𑣋'), + (0x118AC, 'M', u'𑣌'), + (0x118AD, 'M', u'𑣍'), + (0x118AE, 'M', u'𑣎'), + (0x118AF, 'M', u'𑣏'), + (0x118B0, 'M', u'𑣐'), + (0x118B1, 'M', u'𑣑'), + (0x118B2, 'M', u'𑣒'), + (0x118B3, 'M', u'𑣓'), + (0x118B4, 'M', u'𑣔'), + (0x118B5, 'M', u'𑣕'), + (0x118B6, 'M', u'𑣖'), + (0x118B7, 'M', u'𑣗'), + (0x118B8, 'M', u'𑣘'), + (0x118B9, 'M', u'𑣙'), + (0x118BA, 'M', u'𑣚'), + (0x118BB, 'M', u'𑣛'), + (0x118BC, 'M', u'𑣜'), + (0x118BD, 'M', u'𑣝'), + (0x118BE, 'M', u'𑣞'), + (0x118BF, 'M', u'𑣟'), + (0x118C0, 'V'), + (0x118F3, 'X'), + (0x118FF, 'V'), + (0x11900, 'X'), + (0x11A00, 'V'), + (0x11A48, 'X'), + (0x11A50, 'V'), + (0x11A84, 'X'), + (0x11A86, 'V'), + (0x11AA3, 'X'), + (0x11AC0, 'V'), + (0x11AF9, 'X'), + (0x11C00, 'V'), + (0x11C09, 'X'), + (0x11C0A, 'V'), + (0x11C37, 'X'), + (0x11C38, 'V'), + (0x11C46, 'X'), + (0x11C50, 'V'), + (0x11C6D, 'X'), + (0x11C70, 'V'), + (0x11C90, 'X'), + (0x11C92, 'V'), + (0x11CA8, 'X'), + (0x11CA9, 'V'), + (0x11CB7, 'X'), + (0x11D00, 'V'), + (0x11D07, 'X'), + (0x11D08, 'V'), + (0x11D0A, 'X'), + (0x11D0B, 'V'), + (0x11D37, 'X'), + (0x11D3A, 'V'), + (0x11D3B, 'X'), + (0x11D3C, 'V'), + (0x11D3E, 'X'), + (0x11D3F, 'V'), + (0x11D48, 'X'), + (0x11D50, 'V'), + (0x11D5A, 'X'), + (0x11D60, 'V'), + ] + +def _seg_57(): + return [ + (0x11D66, 'X'), + (0x11D67, 'V'), + (0x11D69, 'X'), + (0x11D6A, 'V'), + (0x11D8F, 'X'), + (0x11D90, 'V'), + (0x11D92, 'X'), + (0x11D93, 'V'), + (0x11D99, 'X'), + (0x11DA0, 'V'), + (0x11DAA, 'X'), + (0x11EE0, 'V'), + (0x11EF9, 'X'), + (0x12000, 'V'), + (0x1239A, 'X'), + (0x12400, 'V'), + (0x1246F, 'X'), + (0x12470, 'V'), + (0x12475, 'X'), + (0x12480, 'V'), + (0x12544, 'X'), + (0x13000, 'V'), + (0x1342F, 'X'), + (0x14400, 'V'), + (0x14647, 'X'), + (0x16800, 'V'), + (0x16A39, 'X'), + (0x16A40, 'V'), + (0x16A5F, 'X'), + (0x16A60, 'V'), + (0x16A6A, 'X'), + (0x16A6E, 'V'), + (0x16A70, 'X'), + (0x16AD0, 'V'), + (0x16AEE, 'X'), + (0x16AF0, 'V'), + (0x16AF6, 'X'), + (0x16B00, 'V'), + (0x16B46, 'X'), + (0x16B50, 'V'), + (0x16B5A, 'X'), + (0x16B5B, 'V'), + (0x16B62, 'X'), + (0x16B63, 'V'), + (0x16B78, 'X'), + (0x16B7D, 'V'), + (0x16B90, 'X'), + (0x16E60, 'V'), + (0x16E9B, 'X'), + (0x16F00, 'V'), + (0x16F45, 'X'), + (0x16F50, 'V'), + (0x16F7F, 'X'), + (0x16F8F, 'V'), + (0x16FA0, 'X'), + (0x16FE0, 'V'), + (0x16FE2, 'X'), + (0x17000, 'V'), + (0x187F2, 'X'), + (0x18800, 'V'), + (0x18AF3, 'X'), + (0x1B000, 'V'), + (0x1B11F, 'X'), + (0x1B170, 'V'), + (0x1B2FC, 'X'), + (0x1BC00, 'V'), + (0x1BC6B, 'X'), + (0x1BC70, 'V'), + (0x1BC7D, 'X'), + (0x1BC80, 'V'), + (0x1BC89, 'X'), + (0x1BC90, 'V'), + (0x1BC9A, 'X'), + (0x1BC9C, 'V'), + (0x1BCA0, 'I'), + (0x1BCA4, 'X'), + (0x1D000, 'V'), + (0x1D0F6, 'X'), + (0x1D100, 'V'), + (0x1D127, 'X'), + (0x1D129, 'V'), + (0x1D15E, 'M', u'𝅗𝅥'), + (0x1D15F, 'M', u'𝅘𝅥'), + (0x1D160, 'M', u'𝅘𝅥𝅮'), + (0x1D161, 'M', u'𝅘𝅥𝅯'), + (0x1D162, 'M', u'𝅘𝅥𝅰'), + (0x1D163, 'M', u'𝅘𝅥𝅱'), + (0x1D164, 'M', u'𝅘𝅥𝅲'), + (0x1D165, 'V'), + (0x1D173, 'X'), + (0x1D17B, 'V'), + (0x1D1BB, 'M', u'𝆹𝅥'), + (0x1D1BC, 'M', u'𝆺𝅥'), + (0x1D1BD, 'M', u'𝆹𝅥𝅮'), + (0x1D1BE, 'M', u'𝆺𝅥𝅮'), + (0x1D1BF, 'M', u'𝆹𝅥𝅯'), + (0x1D1C0, 'M', u'𝆺𝅥𝅯'), + (0x1D1C1, 'V'), + (0x1D1E9, 'X'), + (0x1D200, 'V'), + ] + +def _seg_58(): + return [ + (0x1D246, 'X'), + (0x1D2E0, 'V'), + (0x1D2F4, 'X'), + (0x1D300, 'V'), + (0x1D357, 'X'), + (0x1D360, 'V'), + (0x1D379, 'X'), + (0x1D400, 'M', u'a'), + (0x1D401, 'M', u'b'), + (0x1D402, 'M', u'c'), + (0x1D403, 'M', u'd'), + (0x1D404, 'M', u'e'), + (0x1D405, 'M', u'f'), + (0x1D406, 'M', u'g'), + (0x1D407, 'M', u'h'), + (0x1D408, 'M', u'i'), + (0x1D409, 'M', u'j'), + (0x1D40A, 'M', u'k'), + (0x1D40B, 'M', u'l'), + (0x1D40C, 'M', u'm'), + (0x1D40D, 'M', u'n'), + (0x1D40E, 'M', u'o'), + (0x1D40F, 'M', u'p'), + (0x1D410, 'M', u'q'), + (0x1D411, 'M', u'r'), + (0x1D412, 'M', u's'), + (0x1D413, 'M', u't'), + (0x1D414, 'M', u'u'), + (0x1D415, 'M', u'v'), + (0x1D416, 'M', u'w'), + (0x1D417, 'M', u'x'), + (0x1D418, 'M', u'y'), + (0x1D419, 'M', u'z'), + (0x1D41A, 'M', u'a'), + (0x1D41B, 'M', u'b'), + (0x1D41C, 'M', u'c'), + (0x1D41D, 'M', u'd'), + (0x1D41E, 'M', u'e'), + (0x1D41F, 'M', u'f'), + (0x1D420, 'M', u'g'), + (0x1D421, 'M', u'h'), + (0x1D422, 'M', u'i'), + (0x1D423, 'M', u'j'), + (0x1D424, 'M', u'k'), + (0x1D425, 'M', u'l'), + (0x1D426, 'M', u'm'), + (0x1D427, 'M', u'n'), + (0x1D428, 'M', u'o'), + (0x1D429, 'M', u'p'), + (0x1D42A, 'M', u'q'), + (0x1D42B, 'M', u'r'), + (0x1D42C, 'M', u's'), + (0x1D42D, 'M', u't'), + (0x1D42E, 'M', u'u'), + (0x1D42F, 'M', u'v'), + (0x1D430, 'M', u'w'), + (0x1D431, 'M', u'x'), + (0x1D432, 'M', u'y'), + (0x1D433, 'M', u'z'), + (0x1D434, 'M', u'a'), + (0x1D435, 'M', u'b'), + (0x1D436, 'M', u'c'), + (0x1D437, 'M', u'd'), + (0x1D438, 'M', u'e'), + (0x1D439, 'M', u'f'), + (0x1D43A, 'M', u'g'), + (0x1D43B, 'M', u'h'), + (0x1D43C, 'M', u'i'), + (0x1D43D, 'M', u'j'), + (0x1D43E, 'M', u'k'), + (0x1D43F, 'M', u'l'), + (0x1D440, 'M', u'm'), + (0x1D441, 'M', u'n'), + (0x1D442, 'M', u'o'), + (0x1D443, 'M', u'p'), + (0x1D444, 'M', u'q'), + (0x1D445, 'M', u'r'), + (0x1D446, 'M', u's'), + (0x1D447, 'M', u't'), + (0x1D448, 'M', u'u'), + (0x1D449, 'M', u'v'), + (0x1D44A, 'M', u'w'), + (0x1D44B, 'M', u'x'), + (0x1D44C, 'M', u'y'), + (0x1D44D, 'M', u'z'), + (0x1D44E, 'M', u'a'), + (0x1D44F, 'M', u'b'), + (0x1D450, 'M', u'c'), + (0x1D451, 'M', u'd'), + (0x1D452, 'M', u'e'), + (0x1D453, 'M', u'f'), + (0x1D454, 'M', u'g'), + (0x1D455, 'X'), + (0x1D456, 'M', u'i'), + (0x1D457, 'M', u'j'), + (0x1D458, 'M', u'k'), + (0x1D459, 'M', u'l'), + (0x1D45A, 'M', u'm'), + (0x1D45B, 'M', u'n'), + (0x1D45C, 'M', u'o'), + ] + +def _seg_59(): + return [ + (0x1D45D, 'M', u'p'), + (0x1D45E, 'M', u'q'), + (0x1D45F, 'M', u'r'), + (0x1D460, 'M', u's'), + (0x1D461, 'M', u't'), + (0x1D462, 'M', u'u'), + (0x1D463, 'M', u'v'), + (0x1D464, 'M', u'w'), + (0x1D465, 'M', u'x'), + (0x1D466, 'M', u'y'), + (0x1D467, 'M', u'z'), + (0x1D468, 'M', u'a'), + (0x1D469, 'M', u'b'), + (0x1D46A, 'M', u'c'), + (0x1D46B, 'M', u'd'), + (0x1D46C, 'M', u'e'), + (0x1D46D, 'M', u'f'), + (0x1D46E, 'M', u'g'), + (0x1D46F, 'M', u'h'), + (0x1D470, 'M', u'i'), + (0x1D471, 'M', u'j'), + (0x1D472, 'M', u'k'), + (0x1D473, 'M', u'l'), + (0x1D474, 'M', u'm'), + (0x1D475, 'M', u'n'), + (0x1D476, 'M', u'o'), + (0x1D477, 'M', u'p'), + (0x1D478, 'M', u'q'), + (0x1D479, 'M', u'r'), + (0x1D47A, 'M', u's'), + (0x1D47B, 'M', u't'), + (0x1D47C, 'M', u'u'), + (0x1D47D, 'M', u'v'), + (0x1D47E, 'M', u'w'), + (0x1D47F, 'M', u'x'), + (0x1D480, 'M', u'y'), + (0x1D481, 'M', u'z'), + (0x1D482, 'M', u'a'), + (0x1D483, 'M', u'b'), + (0x1D484, 'M', u'c'), + (0x1D485, 'M', u'd'), + (0x1D486, 'M', u'e'), + (0x1D487, 'M', u'f'), + (0x1D488, 'M', u'g'), + (0x1D489, 'M', u'h'), + (0x1D48A, 'M', u'i'), + (0x1D48B, 'M', u'j'), + (0x1D48C, 'M', u'k'), + (0x1D48D, 'M', u'l'), + (0x1D48E, 'M', u'm'), + (0x1D48F, 'M', u'n'), + (0x1D490, 'M', u'o'), + (0x1D491, 'M', u'p'), + (0x1D492, 'M', u'q'), + (0x1D493, 'M', u'r'), + (0x1D494, 'M', u's'), + (0x1D495, 'M', u't'), + (0x1D496, 'M', u'u'), + (0x1D497, 'M', u'v'), + (0x1D498, 'M', u'w'), + (0x1D499, 'M', u'x'), + (0x1D49A, 'M', u'y'), + (0x1D49B, 'M', u'z'), + (0x1D49C, 'M', u'a'), + (0x1D49D, 'X'), + (0x1D49E, 'M', u'c'), + (0x1D49F, 'M', u'd'), + (0x1D4A0, 'X'), + (0x1D4A2, 'M', u'g'), + (0x1D4A3, 'X'), + (0x1D4A5, 'M', u'j'), + (0x1D4A6, 'M', u'k'), + (0x1D4A7, 'X'), + (0x1D4A9, 'M', u'n'), + (0x1D4AA, 'M', u'o'), + (0x1D4AB, 'M', u'p'), + (0x1D4AC, 'M', u'q'), + (0x1D4AD, 'X'), + (0x1D4AE, 'M', u's'), + (0x1D4AF, 'M', u't'), + (0x1D4B0, 'M', u'u'), + (0x1D4B1, 'M', u'v'), + (0x1D4B2, 'M', u'w'), + (0x1D4B3, 'M', u'x'), + (0x1D4B4, 'M', u'y'), + (0x1D4B5, 'M', u'z'), + (0x1D4B6, 'M', u'a'), + (0x1D4B7, 'M', u'b'), + (0x1D4B8, 'M', u'c'), + (0x1D4B9, 'M', u'd'), + (0x1D4BA, 'X'), + (0x1D4BB, 'M', u'f'), + (0x1D4BC, 'X'), + (0x1D4BD, 'M', u'h'), + (0x1D4BE, 'M', u'i'), + (0x1D4BF, 'M', u'j'), + (0x1D4C0, 'M', u'k'), + (0x1D4C1, 'M', u'l'), + (0x1D4C2, 'M', u'm'), + (0x1D4C3, 'M', u'n'), + ] + +def _seg_60(): + return [ + (0x1D4C4, 'X'), + (0x1D4C5, 'M', u'p'), + (0x1D4C6, 'M', u'q'), + (0x1D4C7, 'M', u'r'), + (0x1D4C8, 'M', u's'), + (0x1D4C9, 'M', u't'), + (0x1D4CA, 'M', u'u'), + (0x1D4CB, 'M', u'v'), + (0x1D4CC, 'M', u'w'), + (0x1D4CD, 'M', u'x'), + (0x1D4CE, 'M', u'y'), + (0x1D4CF, 'M', u'z'), + (0x1D4D0, 'M', u'a'), + (0x1D4D1, 'M', u'b'), + (0x1D4D2, 'M', u'c'), + (0x1D4D3, 'M', u'd'), + (0x1D4D4, 'M', u'e'), + (0x1D4D5, 'M', u'f'), + (0x1D4D6, 'M', u'g'), + (0x1D4D7, 'M', u'h'), + (0x1D4D8, 'M', u'i'), + (0x1D4D9, 'M', u'j'), + (0x1D4DA, 'M', u'k'), + (0x1D4DB, 'M', u'l'), + (0x1D4DC, 'M', u'm'), + (0x1D4DD, 'M', u'n'), + (0x1D4DE, 'M', u'o'), + (0x1D4DF, 'M', u'p'), + (0x1D4E0, 'M', u'q'), + (0x1D4E1, 'M', u'r'), + (0x1D4E2, 'M', u's'), + (0x1D4E3, 'M', u't'), + (0x1D4E4, 'M', u'u'), + (0x1D4E5, 'M', u'v'), + (0x1D4E6, 'M', u'w'), + (0x1D4E7, 'M', u'x'), + (0x1D4E8, 'M', u'y'), + (0x1D4E9, 'M', u'z'), + (0x1D4EA, 'M', u'a'), + (0x1D4EB, 'M', u'b'), + (0x1D4EC, 'M', u'c'), + (0x1D4ED, 'M', u'd'), + (0x1D4EE, 'M', u'e'), + (0x1D4EF, 'M', u'f'), + (0x1D4F0, 'M', u'g'), + (0x1D4F1, 'M', u'h'), + (0x1D4F2, 'M', u'i'), + (0x1D4F3, 'M', u'j'), + (0x1D4F4, 'M', u'k'), + (0x1D4F5, 'M', u'l'), + (0x1D4F6, 'M', u'm'), + (0x1D4F7, 'M', u'n'), + (0x1D4F8, 'M', u'o'), + (0x1D4F9, 'M', u'p'), + (0x1D4FA, 'M', u'q'), + (0x1D4FB, 'M', u'r'), + (0x1D4FC, 'M', u's'), + (0x1D4FD, 'M', u't'), + (0x1D4FE, 'M', u'u'), + (0x1D4FF, 'M', u'v'), + (0x1D500, 'M', u'w'), + (0x1D501, 'M', u'x'), + (0x1D502, 'M', u'y'), + (0x1D503, 'M', u'z'), + (0x1D504, 'M', u'a'), + (0x1D505, 'M', u'b'), + (0x1D506, 'X'), + (0x1D507, 'M', u'd'), + (0x1D508, 'M', u'e'), + (0x1D509, 'M', u'f'), + (0x1D50A, 'M', u'g'), + (0x1D50B, 'X'), + (0x1D50D, 'M', u'j'), + (0x1D50E, 'M', u'k'), + (0x1D50F, 'M', u'l'), + (0x1D510, 'M', u'm'), + (0x1D511, 'M', u'n'), + (0x1D512, 'M', u'o'), + (0x1D513, 'M', u'p'), + (0x1D514, 'M', u'q'), + (0x1D515, 'X'), + (0x1D516, 'M', u's'), + (0x1D517, 'M', u't'), + (0x1D518, 'M', u'u'), + (0x1D519, 'M', u'v'), + (0x1D51A, 'M', u'w'), + (0x1D51B, 'M', u'x'), + (0x1D51C, 'M', u'y'), + (0x1D51D, 'X'), + (0x1D51E, 'M', u'a'), + (0x1D51F, 'M', u'b'), + (0x1D520, 'M', u'c'), + (0x1D521, 'M', u'd'), + (0x1D522, 'M', u'e'), + (0x1D523, 'M', u'f'), + (0x1D524, 'M', u'g'), + (0x1D525, 'M', u'h'), + (0x1D526, 'M', u'i'), + (0x1D527, 'M', u'j'), + (0x1D528, 'M', u'k'), + ] + +def _seg_61(): + return [ + (0x1D529, 'M', u'l'), + (0x1D52A, 'M', u'm'), + (0x1D52B, 'M', u'n'), + (0x1D52C, 'M', u'o'), + (0x1D52D, 'M', u'p'), + (0x1D52E, 'M', u'q'), + (0x1D52F, 'M', u'r'), + (0x1D530, 'M', u's'), + (0x1D531, 'M', u't'), + (0x1D532, 'M', u'u'), + (0x1D533, 'M', u'v'), + (0x1D534, 'M', u'w'), + (0x1D535, 'M', u'x'), + (0x1D536, 'M', u'y'), + (0x1D537, 'M', u'z'), + (0x1D538, 'M', u'a'), + (0x1D539, 'M', u'b'), + (0x1D53A, 'X'), + (0x1D53B, 'M', u'd'), + (0x1D53C, 'M', u'e'), + (0x1D53D, 'M', u'f'), + (0x1D53E, 'M', u'g'), + (0x1D53F, 'X'), + (0x1D540, 'M', u'i'), + (0x1D541, 'M', u'j'), + (0x1D542, 'M', u'k'), + (0x1D543, 'M', u'l'), + (0x1D544, 'M', u'm'), + (0x1D545, 'X'), + (0x1D546, 'M', u'o'), + (0x1D547, 'X'), + (0x1D54A, 'M', u's'), + (0x1D54B, 'M', u't'), + (0x1D54C, 'M', u'u'), + (0x1D54D, 'M', u'v'), + (0x1D54E, 'M', u'w'), + (0x1D54F, 'M', u'x'), + (0x1D550, 'M', u'y'), + (0x1D551, 'X'), + (0x1D552, 'M', u'a'), + (0x1D553, 'M', u'b'), + (0x1D554, 'M', u'c'), + (0x1D555, 'M', u'd'), + (0x1D556, 'M', u'e'), + (0x1D557, 'M', u'f'), + (0x1D558, 'M', u'g'), + (0x1D559, 'M', u'h'), + (0x1D55A, 'M', u'i'), + (0x1D55B, 'M', u'j'), + (0x1D55C, 'M', u'k'), + (0x1D55D, 'M', u'l'), + (0x1D55E, 'M', u'm'), + (0x1D55F, 'M', u'n'), + (0x1D560, 'M', u'o'), + (0x1D561, 'M', u'p'), + (0x1D562, 'M', u'q'), + (0x1D563, 'M', u'r'), + (0x1D564, 'M', u's'), + (0x1D565, 'M', u't'), + (0x1D566, 'M', u'u'), + (0x1D567, 'M', u'v'), + (0x1D568, 'M', u'w'), + (0x1D569, 'M', u'x'), + (0x1D56A, 'M', u'y'), + (0x1D56B, 'M', u'z'), + (0x1D56C, 'M', u'a'), + (0x1D56D, 'M', u'b'), + (0x1D56E, 'M', u'c'), + (0x1D56F, 'M', u'd'), + (0x1D570, 'M', u'e'), + (0x1D571, 'M', u'f'), + (0x1D572, 'M', u'g'), + (0x1D573, 'M', u'h'), + (0x1D574, 'M', u'i'), + (0x1D575, 'M', u'j'), + (0x1D576, 'M', u'k'), + (0x1D577, 'M', u'l'), + (0x1D578, 'M', u'm'), + (0x1D579, 'M', u'n'), + (0x1D57A, 'M', u'o'), + (0x1D57B, 'M', u'p'), + (0x1D57C, 'M', u'q'), + (0x1D57D, 'M', u'r'), + (0x1D57E, 'M', u's'), + (0x1D57F, 'M', u't'), + (0x1D580, 'M', u'u'), + (0x1D581, 'M', u'v'), + (0x1D582, 'M', u'w'), + (0x1D583, 'M', u'x'), + (0x1D584, 'M', u'y'), + (0x1D585, 'M', u'z'), + (0x1D586, 'M', u'a'), + (0x1D587, 'M', u'b'), + (0x1D588, 'M', u'c'), + (0x1D589, 'M', u'd'), + (0x1D58A, 'M', u'e'), + (0x1D58B, 'M', u'f'), + (0x1D58C, 'M', u'g'), + (0x1D58D, 'M', u'h'), + (0x1D58E, 'M', u'i'), + ] + +def _seg_62(): + return [ + (0x1D58F, 'M', u'j'), + (0x1D590, 'M', u'k'), + (0x1D591, 'M', u'l'), + (0x1D592, 'M', u'm'), + (0x1D593, 'M', u'n'), + (0x1D594, 'M', u'o'), + (0x1D595, 'M', u'p'), + (0x1D596, 'M', u'q'), + (0x1D597, 'M', u'r'), + (0x1D598, 'M', u's'), + (0x1D599, 'M', u't'), + (0x1D59A, 'M', u'u'), + (0x1D59B, 'M', u'v'), + (0x1D59C, 'M', u'w'), + (0x1D59D, 'M', u'x'), + (0x1D59E, 'M', u'y'), + (0x1D59F, 'M', u'z'), + (0x1D5A0, 'M', u'a'), + (0x1D5A1, 'M', u'b'), + (0x1D5A2, 'M', u'c'), + (0x1D5A3, 'M', u'd'), + (0x1D5A4, 'M', u'e'), + (0x1D5A5, 'M', u'f'), + (0x1D5A6, 'M', u'g'), + (0x1D5A7, 'M', u'h'), + (0x1D5A8, 'M', u'i'), + (0x1D5A9, 'M', u'j'), + (0x1D5AA, 'M', u'k'), + (0x1D5AB, 'M', u'l'), + (0x1D5AC, 'M', u'm'), + (0x1D5AD, 'M', u'n'), + (0x1D5AE, 'M', u'o'), + (0x1D5AF, 'M', u'p'), + (0x1D5B0, 'M', u'q'), + (0x1D5B1, 'M', u'r'), + (0x1D5B2, 'M', u's'), + (0x1D5B3, 'M', u't'), + (0x1D5B4, 'M', u'u'), + (0x1D5B5, 'M', u'v'), + (0x1D5B6, 'M', u'w'), + (0x1D5B7, 'M', u'x'), + (0x1D5B8, 'M', u'y'), + (0x1D5B9, 'M', u'z'), + (0x1D5BA, 'M', u'a'), + (0x1D5BB, 'M', u'b'), + (0x1D5BC, 'M', u'c'), + (0x1D5BD, 'M', u'd'), + (0x1D5BE, 'M', u'e'), + (0x1D5BF, 'M', u'f'), + (0x1D5C0, 'M', u'g'), + (0x1D5C1, 'M', u'h'), + (0x1D5C2, 'M', u'i'), + (0x1D5C3, 'M', u'j'), + (0x1D5C4, 'M', u'k'), + (0x1D5C5, 'M', u'l'), + (0x1D5C6, 'M', u'm'), + (0x1D5C7, 'M', u'n'), + (0x1D5C8, 'M', u'o'), + (0x1D5C9, 'M', u'p'), + (0x1D5CA, 'M', u'q'), + (0x1D5CB, 'M', u'r'), + (0x1D5CC, 'M', u's'), + (0x1D5CD, 'M', u't'), + (0x1D5CE, 'M', u'u'), + (0x1D5CF, 'M', u'v'), + (0x1D5D0, 'M', u'w'), + (0x1D5D1, 'M', u'x'), + (0x1D5D2, 'M', u'y'), + (0x1D5D3, 'M', u'z'), + (0x1D5D4, 'M', u'a'), + (0x1D5D5, 'M', u'b'), + (0x1D5D6, 'M', u'c'), + (0x1D5D7, 'M', u'd'), + (0x1D5D8, 'M', u'e'), + (0x1D5D9, 'M', u'f'), + (0x1D5DA, 'M', u'g'), + (0x1D5DB, 'M', u'h'), + (0x1D5DC, 'M', u'i'), + (0x1D5DD, 'M', u'j'), + (0x1D5DE, 'M', u'k'), + (0x1D5DF, 'M', u'l'), + (0x1D5E0, 'M', u'm'), + (0x1D5E1, 'M', u'n'), + (0x1D5E2, 'M', u'o'), + (0x1D5E3, 'M', u'p'), + (0x1D5E4, 'M', u'q'), + (0x1D5E5, 'M', u'r'), + (0x1D5E6, 'M', u's'), + (0x1D5E7, 'M', u't'), + (0x1D5E8, 'M', u'u'), + (0x1D5E9, 'M', u'v'), + (0x1D5EA, 'M', u'w'), + (0x1D5EB, 'M', u'x'), + (0x1D5EC, 'M', u'y'), + (0x1D5ED, 'M', u'z'), + (0x1D5EE, 'M', u'a'), + (0x1D5EF, 'M', u'b'), + (0x1D5F0, 'M', u'c'), + (0x1D5F1, 'M', u'd'), + (0x1D5F2, 'M', u'e'), + ] + +def _seg_63(): + return [ + (0x1D5F3, 'M', u'f'), + (0x1D5F4, 'M', u'g'), + (0x1D5F5, 'M', u'h'), + (0x1D5F6, 'M', u'i'), + (0x1D5F7, 'M', u'j'), + (0x1D5F8, 'M', u'k'), + (0x1D5F9, 'M', u'l'), + (0x1D5FA, 'M', u'm'), + (0x1D5FB, 'M', u'n'), + (0x1D5FC, 'M', u'o'), + (0x1D5FD, 'M', u'p'), + (0x1D5FE, 'M', u'q'), + (0x1D5FF, 'M', u'r'), + (0x1D600, 'M', u's'), + (0x1D601, 'M', u't'), + (0x1D602, 'M', u'u'), + (0x1D603, 'M', u'v'), + (0x1D604, 'M', u'w'), + (0x1D605, 'M', u'x'), + (0x1D606, 'M', u'y'), + (0x1D607, 'M', u'z'), + (0x1D608, 'M', u'a'), + (0x1D609, 'M', u'b'), + (0x1D60A, 'M', u'c'), + (0x1D60B, 'M', u'd'), + (0x1D60C, 'M', u'e'), + (0x1D60D, 'M', u'f'), + (0x1D60E, 'M', u'g'), + (0x1D60F, 'M', u'h'), + (0x1D610, 'M', u'i'), + (0x1D611, 'M', u'j'), + (0x1D612, 'M', u'k'), + (0x1D613, 'M', u'l'), + (0x1D614, 'M', u'm'), + (0x1D615, 'M', u'n'), + (0x1D616, 'M', u'o'), + (0x1D617, 'M', u'p'), + (0x1D618, 'M', u'q'), + (0x1D619, 'M', u'r'), + (0x1D61A, 'M', u's'), + (0x1D61B, 'M', u't'), + (0x1D61C, 'M', u'u'), + (0x1D61D, 'M', u'v'), + (0x1D61E, 'M', u'w'), + (0x1D61F, 'M', u'x'), + (0x1D620, 'M', u'y'), + (0x1D621, 'M', u'z'), + (0x1D622, 'M', u'a'), + (0x1D623, 'M', u'b'), + (0x1D624, 'M', u'c'), + (0x1D625, 'M', u'd'), + (0x1D626, 'M', u'e'), + (0x1D627, 'M', u'f'), + (0x1D628, 'M', u'g'), + (0x1D629, 'M', u'h'), + (0x1D62A, 'M', u'i'), + (0x1D62B, 'M', u'j'), + (0x1D62C, 'M', u'k'), + (0x1D62D, 'M', u'l'), + (0x1D62E, 'M', u'm'), + (0x1D62F, 'M', u'n'), + (0x1D630, 'M', u'o'), + (0x1D631, 'M', u'p'), + (0x1D632, 'M', u'q'), + (0x1D633, 'M', u'r'), + (0x1D634, 'M', u's'), + (0x1D635, 'M', u't'), + (0x1D636, 'M', u'u'), + (0x1D637, 'M', u'v'), + (0x1D638, 'M', u'w'), + (0x1D639, 'M', u'x'), + (0x1D63A, 'M', u'y'), + (0x1D63B, 'M', u'z'), + (0x1D63C, 'M', u'a'), + (0x1D63D, 'M', u'b'), + (0x1D63E, 'M', u'c'), + (0x1D63F, 'M', u'd'), + (0x1D640, 'M', u'e'), + (0x1D641, 'M', u'f'), + (0x1D642, 'M', u'g'), + (0x1D643, 'M', u'h'), + (0x1D644, 'M', u'i'), + (0x1D645, 'M', u'j'), + (0x1D646, 'M', u'k'), + (0x1D647, 'M', u'l'), + (0x1D648, 'M', u'm'), + (0x1D649, 'M', u'n'), + (0x1D64A, 'M', u'o'), + (0x1D64B, 'M', u'p'), + (0x1D64C, 'M', u'q'), + (0x1D64D, 'M', u'r'), + (0x1D64E, 'M', u's'), + (0x1D64F, 'M', u't'), + (0x1D650, 'M', u'u'), + (0x1D651, 'M', u'v'), + (0x1D652, 'M', u'w'), + (0x1D653, 'M', u'x'), + (0x1D654, 'M', u'y'), + (0x1D655, 'M', u'z'), + (0x1D656, 'M', u'a'), + ] + +def _seg_64(): + return [ + (0x1D657, 'M', u'b'), + (0x1D658, 'M', u'c'), + (0x1D659, 'M', u'd'), + (0x1D65A, 'M', u'e'), + (0x1D65B, 'M', u'f'), + (0x1D65C, 'M', u'g'), + (0x1D65D, 'M', u'h'), + (0x1D65E, 'M', u'i'), + (0x1D65F, 'M', u'j'), + (0x1D660, 'M', u'k'), + (0x1D661, 'M', u'l'), + (0x1D662, 'M', u'm'), + (0x1D663, 'M', u'n'), + (0x1D664, 'M', u'o'), + (0x1D665, 'M', u'p'), + (0x1D666, 'M', u'q'), + (0x1D667, 'M', u'r'), + (0x1D668, 'M', u's'), + (0x1D669, 'M', u't'), + (0x1D66A, 'M', u'u'), + (0x1D66B, 'M', u'v'), + (0x1D66C, 'M', u'w'), + (0x1D66D, 'M', u'x'), + (0x1D66E, 'M', u'y'), + (0x1D66F, 'M', u'z'), + (0x1D670, 'M', u'a'), + (0x1D671, 'M', u'b'), + (0x1D672, 'M', u'c'), + (0x1D673, 'M', u'd'), + (0x1D674, 'M', u'e'), + (0x1D675, 'M', u'f'), + (0x1D676, 'M', u'g'), + (0x1D677, 'M', u'h'), + (0x1D678, 'M', u'i'), + (0x1D679, 'M', u'j'), + (0x1D67A, 'M', u'k'), + (0x1D67B, 'M', u'l'), + (0x1D67C, 'M', u'm'), + (0x1D67D, 'M', u'n'), + (0x1D67E, 'M', u'o'), + (0x1D67F, 'M', u'p'), + (0x1D680, 'M', u'q'), + (0x1D681, 'M', u'r'), + (0x1D682, 'M', u's'), + (0x1D683, 'M', u't'), + (0x1D684, 'M', u'u'), + (0x1D685, 'M', u'v'), + (0x1D686, 'M', u'w'), + (0x1D687, 'M', u'x'), + (0x1D688, 'M', u'y'), + (0x1D689, 'M', u'z'), + (0x1D68A, 'M', u'a'), + (0x1D68B, 'M', u'b'), + (0x1D68C, 'M', u'c'), + (0x1D68D, 'M', u'd'), + (0x1D68E, 'M', u'e'), + (0x1D68F, 'M', u'f'), + (0x1D690, 'M', u'g'), + (0x1D691, 'M', u'h'), + (0x1D692, 'M', u'i'), + (0x1D693, 'M', u'j'), + (0x1D694, 'M', u'k'), + (0x1D695, 'M', u'l'), + (0x1D696, 'M', u'm'), + (0x1D697, 'M', u'n'), + (0x1D698, 'M', u'o'), + (0x1D699, 'M', u'p'), + (0x1D69A, 'M', u'q'), + (0x1D69B, 'M', u'r'), + (0x1D69C, 'M', u's'), + (0x1D69D, 'M', u't'), + (0x1D69E, 'M', u'u'), + (0x1D69F, 'M', u'v'), + (0x1D6A0, 'M', u'w'), + (0x1D6A1, 'M', u'x'), + (0x1D6A2, 'M', u'y'), + (0x1D6A3, 'M', u'z'), + (0x1D6A4, 'M', u'ı'), + (0x1D6A5, 'M', u'ȷ'), + (0x1D6A6, 'X'), + (0x1D6A8, 'M', u'α'), + (0x1D6A9, 'M', u'β'), + (0x1D6AA, 'M', u'γ'), + (0x1D6AB, 'M', u'δ'), + (0x1D6AC, 'M', u'ε'), + (0x1D6AD, 'M', u'ζ'), + (0x1D6AE, 'M', u'η'), + (0x1D6AF, 'M', u'θ'), + (0x1D6B0, 'M', u'ι'), + (0x1D6B1, 'M', u'κ'), + (0x1D6B2, 'M', u'λ'), + (0x1D6B3, 'M', u'μ'), + (0x1D6B4, 'M', u'ν'), + (0x1D6B5, 'M', u'ξ'), + (0x1D6B6, 'M', u'ο'), + (0x1D6B7, 'M', u'π'), + (0x1D6B8, 'M', u'ρ'), + (0x1D6B9, 'M', u'θ'), + (0x1D6BA, 'M', u'σ'), + (0x1D6BB, 'M', u'τ'), + ] + +def _seg_65(): + return [ + (0x1D6BC, 'M', u'υ'), + (0x1D6BD, 'M', u'φ'), + (0x1D6BE, 'M', u'χ'), + (0x1D6BF, 'M', u'ψ'), + (0x1D6C0, 'M', u'ω'), + (0x1D6C1, 'M', u'∇'), + (0x1D6C2, 'M', u'α'), + (0x1D6C3, 'M', u'β'), + (0x1D6C4, 'M', u'γ'), + (0x1D6C5, 'M', u'δ'), + (0x1D6C6, 'M', u'ε'), + (0x1D6C7, 'M', u'ζ'), + (0x1D6C8, 'M', u'η'), + (0x1D6C9, 'M', u'θ'), + (0x1D6CA, 'M', u'ι'), + (0x1D6CB, 'M', u'κ'), + (0x1D6CC, 'M', u'λ'), + (0x1D6CD, 'M', u'μ'), + (0x1D6CE, 'M', u'ν'), + (0x1D6CF, 'M', u'ξ'), + (0x1D6D0, 'M', u'ο'), + (0x1D6D1, 'M', u'π'), + (0x1D6D2, 'M', u'ρ'), + (0x1D6D3, 'M', u'σ'), + (0x1D6D5, 'M', u'τ'), + (0x1D6D6, 'M', u'υ'), + (0x1D6D7, 'M', u'φ'), + (0x1D6D8, 'M', u'χ'), + (0x1D6D9, 'M', u'ψ'), + (0x1D6DA, 'M', u'ω'), + (0x1D6DB, 'M', u'∂'), + (0x1D6DC, 'M', u'ε'), + (0x1D6DD, 'M', u'θ'), + (0x1D6DE, 'M', u'κ'), + (0x1D6DF, 'M', u'φ'), + (0x1D6E0, 'M', u'ρ'), + (0x1D6E1, 'M', u'π'), + (0x1D6E2, 'M', u'α'), + (0x1D6E3, 'M', u'β'), + (0x1D6E4, 'M', u'γ'), + (0x1D6E5, 'M', u'δ'), + (0x1D6E6, 'M', u'ε'), + (0x1D6E7, 'M', u'ζ'), + (0x1D6E8, 'M', u'η'), + (0x1D6E9, 'M', u'θ'), + (0x1D6EA, 'M', u'ι'), + (0x1D6EB, 'M', u'κ'), + (0x1D6EC, 'M', u'λ'), + (0x1D6ED, 'M', u'μ'), + (0x1D6EE, 'M', u'ν'), + (0x1D6EF, 'M', u'ξ'), + (0x1D6F0, 'M', u'ο'), + (0x1D6F1, 'M', u'π'), + (0x1D6F2, 'M', u'ρ'), + (0x1D6F3, 'M', u'θ'), + (0x1D6F4, 'M', u'σ'), + (0x1D6F5, 'M', u'τ'), + (0x1D6F6, 'M', u'υ'), + (0x1D6F7, 'M', u'φ'), + (0x1D6F8, 'M', u'χ'), + (0x1D6F9, 'M', u'ψ'), + (0x1D6FA, 'M', u'ω'), + (0x1D6FB, 'M', u'∇'), + (0x1D6FC, 'M', u'α'), + (0x1D6FD, 'M', u'β'), + (0x1D6FE, 'M', u'γ'), + (0x1D6FF, 'M', u'δ'), + (0x1D700, 'M', u'ε'), + (0x1D701, 'M', u'ζ'), + (0x1D702, 'M', u'η'), + (0x1D703, 'M', u'θ'), + (0x1D704, 'M', u'ι'), + (0x1D705, 'M', u'κ'), + (0x1D706, 'M', u'λ'), + (0x1D707, 'M', u'μ'), + (0x1D708, 'M', u'ν'), + (0x1D709, 'M', u'ξ'), + (0x1D70A, 'M', u'ο'), + (0x1D70B, 'M', u'π'), + (0x1D70C, 'M', u'ρ'), + (0x1D70D, 'M', u'σ'), + (0x1D70F, 'M', u'τ'), + (0x1D710, 'M', u'υ'), + (0x1D711, 'M', u'φ'), + (0x1D712, 'M', u'χ'), + (0x1D713, 'M', u'ψ'), + (0x1D714, 'M', u'ω'), + (0x1D715, 'M', u'∂'), + (0x1D716, 'M', u'ε'), + (0x1D717, 'M', u'θ'), + (0x1D718, 'M', u'κ'), + (0x1D719, 'M', u'φ'), + (0x1D71A, 'M', u'ρ'), + (0x1D71B, 'M', u'π'), + (0x1D71C, 'M', u'α'), + (0x1D71D, 'M', u'β'), + (0x1D71E, 'M', u'γ'), + (0x1D71F, 'M', u'δ'), + (0x1D720, 'M', u'ε'), + (0x1D721, 'M', u'ζ'), + ] + +def _seg_66(): + return [ + (0x1D722, 'M', u'η'), + (0x1D723, 'M', u'θ'), + (0x1D724, 'M', u'ι'), + (0x1D725, 'M', u'κ'), + (0x1D726, 'M', u'λ'), + (0x1D727, 'M', u'μ'), + (0x1D728, 'M', u'ν'), + (0x1D729, 'M', u'ξ'), + (0x1D72A, 'M', u'ο'), + (0x1D72B, 'M', u'π'), + (0x1D72C, 'M', u'ρ'), + (0x1D72D, 'M', u'θ'), + (0x1D72E, 'M', u'σ'), + (0x1D72F, 'M', u'τ'), + (0x1D730, 'M', u'υ'), + (0x1D731, 'M', u'φ'), + (0x1D732, 'M', u'χ'), + (0x1D733, 'M', u'ψ'), + (0x1D734, 'M', u'ω'), + (0x1D735, 'M', u'∇'), + (0x1D736, 'M', u'α'), + (0x1D737, 'M', u'β'), + (0x1D738, 'M', u'γ'), + (0x1D739, 'M', u'δ'), + (0x1D73A, 'M', u'ε'), + (0x1D73B, 'M', u'ζ'), + (0x1D73C, 'M', u'η'), + (0x1D73D, 'M', u'θ'), + (0x1D73E, 'M', u'ι'), + (0x1D73F, 'M', u'κ'), + (0x1D740, 'M', u'λ'), + (0x1D741, 'M', u'μ'), + (0x1D742, 'M', u'ν'), + (0x1D743, 'M', u'ξ'), + (0x1D744, 'M', u'ο'), + (0x1D745, 'M', u'π'), + (0x1D746, 'M', u'ρ'), + (0x1D747, 'M', u'σ'), + (0x1D749, 'M', u'τ'), + (0x1D74A, 'M', u'υ'), + (0x1D74B, 'M', u'φ'), + (0x1D74C, 'M', u'χ'), + (0x1D74D, 'M', u'ψ'), + (0x1D74E, 'M', u'ω'), + (0x1D74F, 'M', u'∂'), + (0x1D750, 'M', u'ε'), + (0x1D751, 'M', u'θ'), + (0x1D752, 'M', u'κ'), + (0x1D753, 'M', u'φ'), + (0x1D754, 'M', u'ρ'), + (0x1D755, 'M', u'π'), + (0x1D756, 'M', u'α'), + (0x1D757, 'M', u'β'), + (0x1D758, 'M', u'γ'), + (0x1D759, 'M', u'δ'), + (0x1D75A, 'M', u'ε'), + (0x1D75B, 'M', u'ζ'), + (0x1D75C, 'M', u'η'), + (0x1D75D, 'M', u'θ'), + (0x1D75E, 'M', u'ι'), + (0x1D75F, 'M', u'κ'), + (0x1D760, 'M', u'λ'), + (0x1D761, 'M', u'μ'), + (0x1D762, 'M', u'ν'), + (0x1D763, 'M', u'ξ'), + (0x1D764, 'M', u'ο'), + (0x1D765, 'M', u'π'), + (0x1D766, 'M', u'ρ'), + (0x1D767, 'M', u'θ'), + (0x1D768, 'M', u'σ'), + (0x1D769, 'M', u'τ'), + (0x1D76A, 'M', u'υ'), + (0x1D76B, 'M', u'φ'), + (0x1D76C, 'M', u'χ'), + (0x1D76D, 'M', u'ψ'), + (0x1D76E, 'M', u'ω'), + (0x1D76F, 'M', u'∇'), + (0x1D770, 'M', u'α'), + (0x1D771, 'M', u'β'), + (0x1D772, 'M', u'γ'), + (0x1D773, 'M', u'δ'), + (0x1D774, 'M', u'ε'), + (0x1D775, 'M', u'ζ'), + (0x1D776, 'M', u'η'), + (0x1D777, 'M', u'θ'), + (0x1D778, 'M', u'ι'), + (0x1D779, 'M', u'κ'), + (0x1D77A, 'M', u'λ'), + (0x1D77B, 'M', u'μ'), + (0x1D77C, 'M', u'ν'), + (0x1D77D, 'M', u'ξ'), + (0x1D77E, 'M', u'ο'), + (0x1D77F, 'M', u'π'), + (0x1D780, 'M', u'ρ'), + (0x1D781, 'M', u'σ'), + (0x1D783, 'M', u'τ'), + (0x1D784, 'M', u'υ'), + (0x1D785, 'M', u'φ'), + (0x1D786, 'M', u'χ'), + (0x1D787, 'M', u'ψ'), + ] + +def _seg_67(): + return [ + (0x1D788, 'M', u'ω'), + (0x1D789, 'M', u'∂'), + (0x1D78A, 'M', u'ε'), + (0x1D78B, 'M', u'θ'), + (0x1D78C, 'M', u'κ'), + (0x1D78D, 'M', u'φ'), + (0x1D78E, 'M', u'ρ'), + (0x1D78F, 'M', u'π'), + (0x1D790, 'M', u'α'), + (0x1D791, 'M', u'β'), + (0x1D792, 'M', u'γ'), + (0x1D793, 'M', u'δ'), + (0x1D794, 'M', u'ε'), + (0x1D795, 'M', u'ζ'), + (0x1D796, 'M', u'η'), + (0x1D797, 'M', u'θ'), + (0x1D798, 'M', u'ι'), + (0x1D799, 'M', u'κ'), + (0x1D79A, 'M', u'λ'), + (0x1D79B, 'M', u'μ'), + (0x1D79C, 'M', u'ν'), + (0x1D79D, 'M', u'ξ'), + (0x1D79E, 'M', u'ο'), + (0x1D79F, 'M', u'π'), + (0x1D7A0, 'M', u'ρ'), + (0x1D7A1, 'M', u'θ'), + (0x1D7A2, 'M', u'σ'), + (0x1D7A3, 'M', u'τ'), + (0x1D7A4, 'M', u'υ'), + (0x1D7A5, 'M', u'φ'), + (0x1D7A6, 'M', u'χ'), + (0x1D7A7, 'M', u'ψ'), + (0x1D7A8, 'M', u'ω'), + (0x1D7A9, 'M', u'∇'), + (0x1D7AA, 'M', u'α'), + (0x1D7AB, 'M', u'β'), + (0x1D7AC, 'M', u'γ'), + (0x1D7AD, 'M', u'δ'), + (0x1D7AE, 'M', u'ε'), + (0x1D7AF, 'M', u'ζ'), + (0x1D7B0, 'M', u'η'), + (0x1D7B1, 'M', u'θ'), + (0x1D7B2, 'M', u'ι'), + (0x1D7B3, 'M', u'κ'), + (0x1D7B4, 'M', u'λ'), + (0x1D7B5, 'M', u'μ'), + (0x1D7B6, 'M', u'ν'), + (0x1D7B7, 'M', u'ξ'), + (0x1D7B8, 'M', u'ο'), + (0x1D7B9, 'M', u'π'), + (0x1D7BA, 'M', u'ρ'), + (0x1D7BB, 'M', u'σ'), + (0x1D7BD, 'M', u'τ'), + (0x1D7BE, 'M', u'υ'), + (0x1D7BF, 'M', u'φ'), + (0x1D7C0, 'M', u'χ'), + (0x1D7C1, 'M', u'ψ'), + (0x1D7C2, 'M', u'ω'), + (0x1D7C3, 'M', u'∂'), + (0x1D7C4, 'M', u'ε'), + (0x1D7C5, 'M', u'θ'), + (0x1D7C6, 'M', u'κ'), + (0x1D7C7, 'M', u'φ'), + (0x1D7C8, 'M', u'ρ'), + (0x1D7C9, 'M', u'π'), + (0x1D7CA, 'M', u'ϝ'), + (0x1D7CC, 'X'), + (0x1D7CE, 'M', u'0'), + (0x1D7CF, 'M', u'1'), + (0x1D7D0, 'M', u'2'), + (0x1D7D1, 'M', u'3'), + (0x1D7D2, 'M', u'4'), + (0x1D7D3, 'M', u'5'), + (0x1D7D4, 'M', u'6'), + (0x1D7D5, 'M', u'7'), + (0x1D7D6, 'M', u'8'), + (0x1D7D7, 'M', u'9'), + (0x1D7D8, 'M', u'0'), + (0x1D7D9, 'M', u'1'), + (0x1D7DA, 'M', u'2'), + (0x1D7DB, 'M', u'3'), + (0x1D7DC, 'M', u'4'), + (0x1D7DD, 'M', u'5'), + (0x1D7DE, 'M', u'6'), + (0x1D7DF, 'M', u'7'), + (0x1D7E0, 'M', u'8'), + (0x1D7E1, 'M', u'9'), + (0x1D7E2, 'M', u'0'), + (0x1D7E3, 'M', u'1'), + (0x1D7E4, 'M', u'2'), + (0x1D7E5, 'M', u'3'), + (0x1D7E6, 'M', u'4'), + (0x1D7E7, 'M', u'5'), + (0x1D7E8, 'M', u'6'), + (0x1D7E9, 'M', u'7'), + (0x1D7EA, 'M', u'8'), + (0x1D7EB, 'M', u'9'), + (0x1D7EC, 'M', u'0'), + (0x1D7ED, 'M', u'1'), + (0x1D7EE, 'M', u'2'), + ] + +def _seg_68(): + return [ + (0x1D7EF, 'M', u'3'), + (0x1D7F0, 'M', u'4'), + (0x1D7F1, 'M', u'5'), + (0x1D7F2, 'M', u'6'), + (0x1D7F3, 'M', u'7'), + (0x1D7F4, 'M', u'8'), + (0x1D7F5, 'M', u'9'), + (0x1D7F6, 'M', u'0'), + (0x1D7F7, 'M', u'1'), + (0x1D7F8, 'M', u'2'), + (0x1D7F9, 'M', u'3'), + (0x1D7FA, 'M', u'4'), + (0x1D7FB, 'M', u'5'), + (0x1D7FC, 'M', u'6'), + (0x1D7FD, 'M', u'7'), + (0x1D7FE, 'M', u'8'), + (0x1D7FF, 'M', u'9'), + (0x1D800, 'V'), + (0x1DA8C, 'X'), + (0x1DA9B, 'V'), + (0x1DAA0, 'X'), + (0x1DAA1, 'V'), + (0x1DAB0, 'X'), + (0x1E000, 'V'), + (0x1E007, 'X'), + (0x1E008, 'V'), + (0x1E019, 'X'), + (0x1E01B, 'V'), + (0x1E022, 'X'), + (0x1E023, 'V'), + (0x1E025, 'X'), + (0x1E026, 'V'), + (0x1E02B, 'X'), + (0x1E800, 'V'), + (0x1E8C5, 'X'), + (0x1E8C7, 'V'), + (0x1E8D7, 'X'), + (0x1E900, 'M', u'𞤢'), + (0x1E901, 'M', u'𞤣'), + (0x1E902, 'M', u'𞤤'), + (0x1E903, 'M', u'𞤥'), + (0x1E904, 'M', u'𞤦'), + (0x1E905, 'M', u'𞤧'), + (0x1E906, 'M', u'𞤨'), + (0x1E907, 'M', u'𞤩'), + (0x1E908, 'M', u'𞤪'), + (0x1E909, 'M', u'𞤫'), + (0x1E90A, 'M', u'𞤬'), + (0x1E90B, 'M', u'𞤭'), + (0x1E90C, 'M', u'𞤮'), + (0x1E90D, 'M', u'𞤯'), + (0x1E90E, 'M', u'𞤰'), + (0x1E90F, 'M', u'𞤱'), + (0x1E910, 'M', u'𞤲'), + (0x1E911, 'M', u'𞤳'), + (0x1E912, 'M', u'𞤴'), + (0x1E913, 'M', u'𞤵'), + (0x1E914, 'M', u'𞤶'), + (0x1E915, 'M', u'𞤷'), + (0x1E916, 'M', u'𞤸'), + (0x1E917, 'M', u'𞤹'), + (0x1E918, 'M', u'𞤺'), + (0x1E919, 'M', u'𞤻'), + (0x1E91A, 'M', u'𞤼'), + (0x1E91B, 'M', u'𞤽'), + (0x1E91C, 'M', u'𞤾'), + (0x1E91D, 'M', u'𞤿'), + (0x1E91E, 'M', u'𞥀'), + (0x1E91F, 'M', u'𞥁'), + (0x1E920, 'M', u'𞥂'), + (0x1E921, 'M', u'𞥃'), + (0x1E922, 'V'), + (0x1E94B, 'X'), + (0x1E950, 'V'), + (0x1E95A, 'X'), + (0x1E95E, 'V'), + (0x1E960, 'X'), + (0x1EC71, 'V'), + (0x1ECB5, 'X'), + (0x1EE00, 'M', u'ا'), + (0x1EE01, 'M', u'ب'), + (0x1EE02, 'M', u'ج'), + (0x1EE03, 'M', u'د'), + (0x1EE04, 'X'), + (0x1EE05, 'M', u'و'), + (0x1EE06, 'M', u'ز'), + (0x1EE07, 'M', u'ح'), + (0x1EE08, 'M', u'ط'), + (0x1EE09, 'M', u'ي'), + (0x1EE0A, 'M', u'ك'), + (0x1EE0B, 'M', u'ل'), + (0x1EE0C, 'M', u'م'), + (0x1EE0D, 'M', u'ن'), + (0x1EE0E, 'M', u'س'), + (0x1EE0F, 'M', u'ع'), + (0x1EE10, 'M', u'ف'), + (0x1EE11, 'M', u'ص'), + (0x1EE12, 'M', u'ق'), + (0x1EE13, 'M', u'ر'), + (0x1EE14, 'M', u'ش'), + ] + +def _seg_69(): + return [ + (0x1EE15, 'M', u'ت'), + (0x1EE16, 'M', u'ث'), + (0x1EE17, 'M', u'خ'), + (0x1EE18, 'M', u'ذ'), + (0x1EE19, 'M', u'ض'), + (0x1EE1A, 'M', u'ظ'), + (0x1EE1B, 'M', u'غ'), + (0x1EE1C, 'M', u'ٮ'), + (0x1EE1D, 'M', u'ں'), + (0x1EE1E, 'M', u'ڡ'), + (0x1EE1F, 'M', u'ٯ'), + (0x1EE20, 'X'), + (0x1EE21, 'M', u'ب'), + (0x1EE22, 'M', u'ج'), + (0x1EE23, 'X'), + (0x1EE24, 'M', u'ه'), + (0x1EE25, 'X'), + (0x1EE27, 'M', u'ح'), + (0x1EE28, 'X'), + (0x1EE29, 'M', u'ي'), + (0x1EE2A, 'M', u'ك'), + (0x1EE2B, 'M', u'ل'), + (0x1EE2C, 'M', u'م'), + (0x1EE2D, 'M', u'ن'), + (0x1EE2E, 'M', u'س'), + (0x1EE2F, 'M', u'ع'), + (0x1EE30, 'M', u'ف'), + (0x1EE31, 'M', u'ص'), + (0x1EE32, 'M', u'ق'), + (0x1EE33, 'X'), + (0x1EE34, 'M', u'ش'), + (0x1EE35, 'M', u'ت'), + (0x1EE36, 'M', u'ث'), + (0x1EE37, 'M', u'خ'), + (0x1EE38, 'X'), + (0x1EE39, 'M', u'ض'), + (0x1EE3A, 'X'), + (0x1EE3B, 'M', u'غ'), + (0x1EE3C, 'X'), + (0x1EE42, 'M', u'ج'), + (0x1EE43, 'X'), + (0x1EE47, 'M', u'ح'), + (0x1EE48, 'X'), + (0x1EE49, 'M', u'ي'), + (0x1EE4A, 'X'), + (0x1EE4B, 'M', u'ل'), + (0x1EE4C, 'X'), + (0x1EE4D, 'M', u'ن'), + (0x1EE4E, 'M', u'س'), + (0x1EE4F, 'M', u'ع'), + (0x1EE50, 'X'), + (0x1EE51, 'M', u'ص'), + (0x1EE52, 'M', u'ق'), + (0x1EE53, 'X'), + (0x1EE54, 'M', u'ش'), + (0x1EE55, 'X'), + (0x1EE57, 'M', u'خ'), + (0x1EE58, 'X'), + (0x1EE59, 'M', u'ض'), + (0x1EE5A, 'X'), + (0x1EE5B, 'M', u'غ'), + (0x1EE5C, 'X'), + (0x1EE5D, 'M', u'ں'), + (0x1EE5E, 'X'), + (0x1EE5F, 'M', u'ٯ'), + (0x1EE60, 'X'), + (0x1EE61, 'M', u'ب'), + (0x1EE62, 'M', u'ج'), + (0x1EE63, 'X'), + (0x1EE64, 'M', u'ه'), + (0x1EE65, 'X'), + (0x1EE67, 'M', u'ح'), + (0x1EE68, 'M', u'ط'), + (0x1EE69, 'M', u'ي'), + (0x1EE6A, 'M', u'ك'), + (0x1EE6B, 'X'), + (0x1EE6C, 'M', u'م'), + (0x1EE6D, 'M', u'ن'), + (0x1EE6E, 'M', u'س'), + (0x1EE6F, 'M', u'ع'), + (0x1EE70, 'M', u'ف'), + (0x1EE71, 'M', u'ص'), + (0x1EE72, 'M', u'ق'), + (0x1EE73, 'X'), + (0x1EE74, 'M', u'ش'), + (0x1EE75, 'M', u'ت'), + (0x1EE76, 'M', u'ث'), + (0x1EE77, 'M', u'خ'), + (0x1EE78, 'X'), + (0x1EE79, 'M', u'ض'), + (0x1EE7A, 'M', u'ظ'), + (0x1EE7B, 'M', u'غ'), + (0x1EE7C, 'M', u'ٮ'), + (0x1EE7D, 'X'), + (0x1EE7E, 'M', u'ڡ'), + (0x1EE7F, 'X'), + (0x1EE80, 'M', u'ا'), + (0x1EE81, 'M', u'ب'), + (0x1EE82, 'M', u'ج'), + (0x1EE83, 'M', u'د'), + ] + +def _seg_70(): + return [ + (0x1EE84, 'M', u'ه'), + (0x1EE85, 'M', u'و'), + (0x1EE86, 'M', u'ز'), + (0x1EE87, 'M', u'ح'), + (0x1EE88, 'M', u'ط'), + (0x1EE89, 'M', u'ي'), + (0x1EE8A, 'X'), + (0x1EE8B, 'M', u'ل'), + (0x1EE8C, 'M', u'م'), + (0x1EE8D, 'M', u'ن'), + (0x1EE8E, 'M', u'س'), + (0x1EE8F, 'M', u'ع'), + (0x1EE90, 'M', u'ف'), + (0x1EE91, 'M', u'ص'), + (0x1EE92, 'M', u'ق'), + (0x1EE93, 'M', u'ر'), + (0x1EE94, 'M', u'ش'), + (0x1EE95, 'M', u'ت'), + (0x1EE96, 'M', u'ث'), + (0x1EE97, 'M', u'خ'), + (0x1EE98, 'M', u'ذ'), + (0x1EE99, 'M', u'ض'), + (0x1EE9A, 'M', u'ظ'), + (0x1EE9B, 'M', u'غ'), + (0x1EE9C, 'X'), + (0x1EEA1, 'M', u'ب'), + (0x1EEA2, 'M', u'ج'), + (0x1EEA3, 'M', u'د'), + (0x1EEA4, 'X'), + (0x1EEA5, 'M', u'و'), + (0x1EEA6, 'M', u'ز'), + (0x1EEA7, 'M', u'ح'), + (0x1EEA8, 'M', u'ط'), + (0x1EEA9, 'M', u'ي'), + (0x1EEAA, 'X'), + (0x1EEAB, 'M', u'ل'), + (0x1EEAC, 'M', u'م'), + (0x1EEAD, 'M', u'ن'), + (0x1EEAE, 'M', u'س'), + (0x1EEAF, 'M', u'ع'), + (0x1EEB0, 'M', u'ف'), + (0x1EEB1, 'M', u'ص'), + (0x1EEB2, 'M', u'ق'), + (0x1EEB3, 'M', u'ر'), + (0x1EEB4, 'M', u'ش'), + (0x1EEB5, 'M', u'ت'), + (0x1EEB6, 'M', u'ث'), + (0x1EEB7, 'M', u'خ'), + (0x1EEB8, 'M', u'ذ'), + (0x1EEB9, 'M', u'ض'), + (0x1EEBA, 'M', u'ظ'), + (0x1EEBB, 'M', u'غ'), + (0x1EEBC, 'X'), + (0x1EEF0, 'V'), + (0x1EEF2, 'X'), + (0x1F000, 'V'), + (0x1F02C, 'X'), + (0x1F030, 'V'), + (0x1F094, 'X'), + (0x1F0A0, 'V'), + (0x1F0AF, 'X'), + (0x1F0B1, 'V'), + (0x1F0C0, 'X'), + (0x1F0C1, 'V'), + (0x1F0D0, 'X'), + (0x1F0D1, 'V'), + (0x1F0F6, 'X'), + (0x1F101, '3', u'0,'), + (0x1F102, '3', u'1,'), + (0x1F103, '3', u'2,'), + (0x1F104, '3', u'3,'), + (0x1F105, '3', u'4,'), + (0x1F106, '3', u'5,'), + (0x1F107, '3', u'6,'), + (0x1F108, '3', u'7,'), + (0x1F109, '3', u'8,'), + (0x1F10A, '3', u'9,'), + (0x1F10B, 'V'), + (0x1F10D, 'X'), + (0x1F110, '3', u'(a)'), + (0x1F111, '3', u'(b)'), + (0x1F112, '3', u'(c)'), + (0x1F113, '3', u'(d)'), + (0x1F114, '3', u'(e)'), + (0x1F115, '3', u'(f)'), + (0x1F116, '3', u'(g)'), + (0x1F117, '3', u'(h)'), + (0x1F118, '3', u'(i)'), + (0x1F119, '3', u'(j)'), + (0x1F11A, '3', u'(k)'), + (0x1F11B, '3', u'(l)'), + (0x1F11C, '3', u'(m)'), + (0x1F11D, '3', u'(n)'), + (0x1F11E, '3', u'(o)'), + (0x1F11F, '3', u'(p)'), + (0x1F120, '3', u'(q)'), + (0x1F121, '3', u'(r)'), + (0x1F122, '3', u'(s)'), + (0x1F123, '3', u'(t)'), + (0x1F124, '3', u'(u)'), + ] + +def _seg_71(): + return [ + (0x1F125, '3', u'(v)'), + (0x1F126, '3', u'(w)'), + (0x1F127, '3', u'(x)'), + (0x1F128, '3', u'(y)'), + (0x1F129, '3', u'(z)'), + (0x1F12A, 'M', u'〔s〕'), + (0x1F12B, 'M', u'c'), + (0x1F12C, 'M', u'r'), + (0x1F12D, 'M', u'cd'), + (0x1F12E, 'M', u'wz'), + (0x1F12F, 'V'), + (0x1F130, 'M', u'a'), + (0x1F131, 'M', u'b'), + (0x1F132, 'M', u'c'), + (0x1F133, 'M', u'd'), + (0x1F134, 'M', u'e'), + (0x1F135, 'M', u'f'), + (0x1F136, 'M', u'g'), + (0x1F137, 'M', u'h'), + (0x1F138, 'M', u'i'), + (0x1F139, 'M', u'j'), + (0x1F13A, 'M', u'k'), + (0x1F13B, 'M', u'l'), + (0x1F13C, 'M', u'm'), + (0x1F13D, 'M', u'n'), + (0x1F13E, 'M', u'o'), + (0x1F13F, 'M', u'p'), + (0x1F140, 'M', u'q'), + (0x1F141, 'M', u'r'), + (0x1F142, 'M', u's'), + (0x1F143, 'M', u't'), + (0x1F144, 'M', u'u'), + (0x1F145, 'M', u'v'), + (0x1F146, 'M', u'w'), + (0x1F147, 'M', u'x'), + (0x1F148, 'M', u'y'), + (0x1F149, 'M', u'z'), + (0x1F14A, 'M', u'hv'), + (0x1F14B, 'M', u'mv'), + (0x1F14C, 'M', u'sd'), + (0x1F14D, 'M', u'ss'), + (0x1F14E, 'M', u'ppv'), + (0x1F14F, 'M', u'wc'), + (0x1F150, 'V'), + (0x1F16A, 'M', u'mc'), + (0x1F16B, 'M', u'md'), + (0x1F16C, 'X'), + (0x1F170, 'V'), + (0x1F190, 'M', u'dj'), + (0x1F191, 'V'), + (0x1F1AD, 'X'), + (0x1F1E6, 'V'), + (0x1F200, 'M', u'ほか'), + (0x1F201, 'M', u'ココ'), + (0x1F202, 'M', u'サ'), + (0x1F203, 'X'), + (0x1F210, 'M', u'手'), + (0x1F211, 'M', u'字'), + (0x1F212, 'M', u'双'), + (0x1F213, 'M', u'デ'), + (0x1F214, 'M', u'二'), + (0x1F215, 'M', u'多'), + (0x1F216, 'M', u'解'), + (0x1F217, 'M', u'天'), + (0x1F218, 'M', u'交'), + (0x1F219, 'M', u'映'), + (0x1F21A, 'M', u'無'), + (0x1F21B, 'M', u'料'), + (0x1F21C, 'M', u'前'), + (0x1F21D, 'M', u'後'), + (0x1F21E, 'M', u'再'), + (0x1F21F, 'M', u'新'), + (0x1F220, 'M', u'初'), + (0x1F221, 'M', u'終'), + (0x1F222, 'M', u'生'), + (0x1F223, 'M', u'販'), + (0x1F224, 'M', u'声'), + (0x1F225, 'M', u'吹'), + (0x1F226, 'M', u'演'), + (0x1F227, 'M', u'投'), + (0x1F228, 'M', u'捕'), + (0x1F229, 'M', u'一'), + (0x1F22A, 'M', u'三'), + (0x1F22B, 'M', u'遊'), + (0x1F22C, 'M', u'左'), + (0x1F22D, 'M', u'中'), + (0x1F22E, 'M', u'右'), + (0x1F22F, 'M', u'指'), + (0x1F230, 'M', u'走'), + (0x1F231, 'M', u'打'), + (0x1F232, 'M', u'禁'), + (0x1F233, 'M', u'空'), + (0x1F234, 'M', u'合'), + (0x1F235, 'M', u'満'), + (0x1F236, 'M', u'有'), + (0x1F237, 'M', u'月'), + (0x1F238, 'M', u'申'), + (0x1F239, 'M', u'割'), + (0x1F23A, 'M', u'営'), + (0x1F23B, 'M', u'配'), + ] + +def _seg_72(): + return [ + (0x1F23C, 'X'), + (0x1F240, 'M', u'〔本〕'), + (0x1F241, 'M', u'〔三〕'), + (0x1F242, 'M', u'〔二〕'), + (0x1F243, 'M', u'〔安〕'), + (0x1F244, 'M', u'〔点〕'), + (0x1F245, 'M', u'〔打〕'), + (0x1F246, 'M', u'〔盗〕'), + (0x1F247, 'M', u'〔勝〕'), + (0x1F248, 'M', u'〔敗〕'), + (0x1F249, 'X'), + (0x1F250, 'M', u'得'), + (0x1F251, 'M', u'可'), + (0x1F252, 'X'), + (0x1F260, 'V'), + (0x1F266, 'X'), + (0x1F300, 'V'), + (0x1F6D5, 'X'), + (0x1F6E0, 'V'), + (0x1F6ED, 'X'), + (0x1F6F0, 'V'), + (0x1F6FA, 'X'), + (0x1F700, 'V'), + (0x1F774, 'X'), + (0x1F780, 'V'), + (0x1F7D9, 'X'), + (0x1F800, 'V'), + (0x1F80C, 'X'), + (0x1F810, 'V'), + (0x1F848, 'X'), + (0x1F850, 'V'), + (0x1F85A, 'X'), + (0x1F860, 'V'), + (0x1F888, 'X'), + (0x1F890, 'V'), + (0x1F8AE, 'X'), + (0x1F900, 'V'), + (0x1F90C, 'X'), + (0x1F910, 'V'), + (0x1F93F, 'X'), + (0x1F940, 'V'), + (0x1F971, 'X'), + (0x1F973, 'V'), + (0x1F977, 'X'), + (0x1F97A, 'V'), + (0x1F97B, 'X'), + (0x1F97C, 'V'), + (0x1F9A3, 'X'), + (0x1F9B0, 'V'), + (0x1F9BA, 'X'), + (0x1F9C0, 'V'), + (0x1F9C3, 'X'), + (0x1F9D0, 'V'), + (0x1FA00, 'X'), + (0x1FA60, 'V'), + (0x1FA6E, 'X'), + (0x20000, 'V'), + (0x2A6D7, 'X'), + (0x2A700, 'V'), + (0x2B735, 'X'), + (0x2B740, 'V'), + (0x2B81E, 'X'), + (0x2B820, 'V'), + (0x2CEA2, 'X'), + (0x2CEB0, 'V'), + (0x2EBE1, 'X'), + (0x2F800, 'M', u'丽'), + (0x2F801, 'M', u'丸'), + (0x2F802, 'M', u'乁'), + (0x2F803, 'M', u'𠄢'), + (0x2F804, 'M', u'你'), + (0x2F805, 'M', u'侮'), + (0x2F806, 'M', u'侻'), + (0x2F807, 'M', u'倂'), + (0x2F808, 'M', u'偺'), + (0x2F809, 'M', u'備'), + (0x2F80A, 'M', u'僧'), + (0x2F80B, 'M', u'像'), + (0x2F80C, 'M', u'㒞'), + (0x2F80D, 'M', u'𠘺'), + (0x2F80E, 'M', u'免'), + (0x2F80F, 'M', u'兔'), + (0x2F810, 'M', u'兤'), + (0x2F811, 'M', u'具'), + (0x2F812, 'M', u'𠔜'), + (0x2F813, 'M', u'㒹'), + (0x2F814, 'M', u'內'), + (0x2F815, 'M', u'再'), + (0x2F816, 'M', u'𠕋'), + (0x2F817, 'M', u'冗'), + (0x2F818, 'M', u'冤'), + (0x2F819, 'M', u'仌'), + (0x2F81A, 'M', u'冬'), + (0x2F81B, 'M', u'况'), + (0x2F81C, 'M', u'𩇟'), + (0x2F81D, 'M', u'凵'), + (0x2F81E, 'M', u'刃'), + (0x2F81F, 'M', u'㓟'), + (0x2F820, 'M', u'刻'), + (0x2F821, 'M', u'剆'), + ] + +def _seg_73(): + return [ + (0x2F822, 'M', u'割'), + (0x2F823, 'M', u'剷'), + (0x2F824, 'M', u'㔕'), + (0x2F825, 'M', u'勇'), + (0x2F826, 'M', u'勉'), + (0x2F827, 'M', u'勤'), + (0x2F828, 'M', u'勺'), + (0x2F829, 'M', u'包'), + (0x2F82A, 'M', u'匆'), + (0x2F82B, 'M', u'北'), + (0x2F82C, 'M', u'卉'), + (0x2F82D, 'M', u'卑'), + (0x2F82E, 'M', u'博'), + (0x2F82F, 'M', u'即'), + (0x2F830, 'M', u'卽'), + (0x2F831, 'M', u'卿'), + (0x2F834, 'M', u'𠨬'), + (0x2F835, 'M', u'灰'), + (0x2F836, 'M', u'及'), + (0x2F837, 'M', u'叟'), + (0x2F838, 'M', u'𠭣'), + (0x2F839, 'M', u'叫'), + (0x2F83A, 'M', u'叱'), + (0x2F83B, 'M', u'吆'), + (0x2F83C, 'M', u'咞'), + (0x2F83D, 'M', u'吸'), + (0x2F83E, 'M', u'呈'), + (0x2F83F, 'M', u'周'), + (0x2F840, 'M', u'咢'), + (0x2F841, 'M', u'哶'), + (0x2F842, 'M', u'唐'), + (0x2F843, 'M', u'啓'), + (0x2F844, 'M', u'啣'), + (0x2F845, 'M', u'善'), + (0x2F847, 'M', u'喙'), + (0x2F848, 'M', u'喫'), + (0x2F849, 'M', u'喳'), + (0x2F84A, 'M', u'嗂'), + (0x2F84B, 'M', u'圖'), + (0x2F84C, 'M', u'嘆'), + (0x2F84D, 'M', u'圗'), + (0x2F84E, 'M', u'噑'), + (0x2F84F, 'M', u'噴'), + (0x2F850, 'M', u'切'), + (0x2F851, 'M', u'壮'), + (0x2F852, 'M', u'城'), + (0x2F853, 'M', u'埴'), + (0x2F854, 'M', u'堍'), + (0x2F855, 'M', u'型'), + (0x2F856, 'M', u'堲'), + (0x2F857, 'M', u'報'), + (0x2F858, 'M', u'墬'), + (0x2F859, 'M', u'𡓤'), + (0x2F85A, 'M', u'売'), + (0x2F85B, 'M', u'壷'), + (0x2F85C, 'M', u'夆'), + (0x2F85D, 'M', u'多'), + (0x2F85E, 'M', u'夢'), + (0x2F85F, 'M', u'奢'), + (0x2F860, 'M', u'𡚨'), + (0x2F861, 'M', u'𡛪'), + (0x2F862, 'M', u'姬'), + (0x2F863, 'M', u'娛'), + (0x2F864, 'M', u'娧'), + (0x2F865, 'M', u'姘'), + (0x2F866, 'M', u'婦'), + (0x2F867, 'M', u'㛮'), + (0x2F868, 'X'), + (0x2F869, 'M', u'嬈'), + (0x2F86A, 'M', u'嬾'), + (0x2F86C, 'M', u'𡧈'), + (0x2F86D, 'M', u'寃'), + (0x2F86E, 'M', u'寘'), + (0x2F86F, 'M', u'寧'), + (0x2F870, 'M', u'寳'), + (0x2F871, 'M', u'𡬘'), + (0x2F872, 'M', u'寿'), + (0x2F873, 'M', u'将'), + (0x2F874, 'X'), + (0x2F875, 'M', u'尢'), + (0x2F876, 'M', u'㞁'), + (0x2F877, 'M', u'屠'), + (0x2F878, 'M', u'屮'), + (0x2F879, 'M', u'峀'), + (0x2F87A, 'M', u'岍'), + (0x2F87B, 'M', u'𡷤'), + (0x2F87C, 'M', u'嵃'), + (0x2F87D, 'M', u'𡷦'), + (0x2F87E, 'M', u'嵮'), + (0x2F87F, 'M', u'嵫'), + (0x2F880, 'M', u'嵼'), + (0x2F881, 'M', u'巡'), + (0x2F882, 'M', u'巢'), + (0x2F883, 'M', u'㠯'), + (0x2F884, 'M', u'巽'), + (0x2F885, 'M', u'帨'), + (0x2F886, 'M', u'帽'), + (0x2F887, 'M', u'幩'), + (0x2F888, 'M', u'㡢'), + (0x2F889, 'M', u'𢆃'), + ] + +def _seg_74(): + return [ + (0x2F88A, 'M', u'㡼'), + (0x2F88B, 'M', u'庰'), + (0x2F88C, 'M', u'庳'), + (0x2F88D, 'M', u'庶'), + (0x2F88E, 'M', u'廊'), + (0x2F88F, 'M', u'𪎒'), + (0x2F890, 'M', u'廾'), + (0x2F891, 'M', u'𢌱'), + (0x2F893, 'M', u'舁'), + (0x2F894, 'M', u'弢'), + (0x2F896, 'M', u'㣇'), + (0x2F897, 'M', u'𣊸'), + (0x2F898, 'M', u'𦇚'), + (0x2F899, 'M', u'形'), + (0x2F89A, 'M', u'彫'), + (0x2F89B, 'M', u'㣣'), + (0x2F89C, 'M', u'徚'), + (0x2F89D, 'M', u'忍'), + (0x2F89E, 'M', u'志'), + (0x2F89F, 'M', u'忹'), + (0x2F8A0, 'M', u'悁'), + (0x2F8A1, 'M', u'㤺'), + (0x2F8A2, 'M', u'㤜'), + (0x2F8A3, 'M', u'悔'), + (0x2F8A4, 'M', u'𢛔'), + (0x2F8A5, 'M', u'惇'), + (0x2F8A6, 'M', u'慈'), + (0x2F8A7, 'M', u'慌'), + (0x2F8A8, 'M', u'慎'), + (0x2F8A9, 'M', u'慌'), + (0x2F8AA, 'M', u'慺'), + (0x2F8AB, 'M', u'憎'), + (0x2F8AC, 'M', u'憲'), + (0x2F8AD, 'M', u'憤'), + (0x2F8AE, 'M', u'憯'), + (0x2F8AF, 'M', u'懞'), + (0x2F8B0, 'M', u'懲'), + (0x2F8B1, 'M', u'懶'), + (0x2F8B2, 'M', u'成'), + (0x2F8B3, 'M', u'戛'), + (0x2F8B4, 'M', u'扝'), + (0x2F8B5, 'M', u'抱'), + (0x2F8B6, 'M', u'拔'), + (0x2F8B7, 'M', u'捐'), + (0x2F8B8, 'M', u'𢬌'), + (0x2F8B9, 'M', u'挽'), + (0x2F8BA, 'M', u'拼'), + (0x2F8BB, 'M', u'捨'), + (0x2F8BC, 'M', u'掃'), + (0x2F8BD, 'M', u'揤'), + (0x2F8BE, 'M', u'𢯱'), + (0x2F8BF, 'M', u'搢'), + (0x2F8C0, 'M', u'揅'), + (0x2F8C1, 'M', u'掩'), + (0x2F8C2, 'M', u'㨮'), + (0x2F8C3, 'M', u'摩'), + (0x2F8C4, 'M', u'摾'), + (0x2F8C5, 'M', u'撝'), + (0x2F8C6, 'M', u'摷'), + (0x2F8C7, 'M', u'㩬'), + (0x2F8C8, 'M', u'敏'), + (0x2F8C9, 'M', u'敬'), + (0x2F8CA, 'M', u'𣀊'), + (0x2F8CB, 'M', u'旣'), + (0x2F8CC, 'M', u'書'), + (0x2F8CD, 'M', u'晉'), + (0x2F8CE, 'M', u'㬙'), + (0x2F8CF, 'M', u'暑'), + (0x2F8D0, 'M', u'㬈'), + (0x2F8D1, 'M', u'㫤'), + (0x2F8D2, 'M', u'冒'), + (0x2F8D3, 'M', u'冕'), + (0x2F8D4, 'M', u'最'), + (0x2F8D5, 'M', u'暜'), + (0x2F8D6, 'M', u'肭'), + (0x2F8D7, 'M', u'䏙'), + (0x2F8D8, 'M', u'朗'), + (0x2F8D9, 'M', u'望'), + (0x2F8DA, 'M', u'朡'), + (0x2F8DB, 'M', u'杞'), + (0x2F8DC, 'M', u'杓'), + (0x2F8DD, 'M', u'𣏃'), + (0x2F8DE, 'M', u'㭉'), + (0x2F8DF, 'M', u'柺'), + (0x2F8E0, 'M', u'枅'), + (0x2F8E1, 'M', u'桒'), + (0x2F8E2, 'M', u'梅'), + (0x2F8E3, 'M', u'𣑭'), + (0x2F8E4, 'M', u'梎'), + (0x2F8E5, 'M', u'栟'), + (0x2F8E6, 'M', u'椔'), + (0x2F8E7, 'M', u'㮝'), + (0x2F8E8, 'M', u'楂'), + (0x2F8E9, 'M', u'榣'), + (0x2F8EA, 'M', u'槪'), + (0x2F8EB, 'M', u'檨'), + (0x2F8EC, 'M', u'𣚣'), + (0x2F8ED, 'M', u'櫛'), + (0x2F8EE, 'M', u'㰘'), + (0x2F8EF, 'M', u'次'), + ] + +def _seg_75(): + return [ + (0x2F8F0, 'M', u'𣢧'), + (0x2F8F1, 'M', u'歔'), + (0x2F8F2, 'M', u'㱎'), + (0x2F8F3, 'M', u'歲'), + (0x2F8F4, 'M', u'殟'), + (0x2F8F5, 'M', u'殺'), + (0x2F8F6, 'M', u'殻'), + (0x2F8F7, 'M', u'𣪍'), + (0x2F8F8, 'M', u'𡴋'), + (0x2F8F9, 'M', u'𣫺'), + (0x2F8FA, 'M', u'汎'), + (0x2F8FB, 'M', u'𣲼'), + (0x2F8FC, 'M', u'沿'), + (0x2F8FD, 'M', u'泍'), + (0x2F8FE, 'M', u'汧'), + (0x2F8FF, 'M', u'洖'), + (0x2F900, 'M', u'派'), + (0x2F901, 'M', u'海'), + (0x2F902, 'M', u'流'), + (0x2F903, 'M', u'浩'), + (0x2F904, 'M', u'浸'), + (0x2F905, 'M', u'涅'), + (0x2F906, 'M', u'𣴞'), + (0x2F907, 'M', u'洴'), + (0x2F908, 'M', u'港'), + (0x2F909, 'M', u'湮'), + (0x2F90A, 'M', u'㴳'), + (0x2F90B, 'M', u'滋'), + (0x2F90C, 'M', u'滇'), + (0x2F90D, 'M', u'𣻑'), + (0x2F90E, 'M', u'淹'), + (0x2F90F, 'M', u'潮'), + (0x2F910, 'M', u'𣽞'), + (0x2F911, 'M', u'𣾎'), + (0x2F912, 'M', u'濆'), + (0x2F913, 'M', u'瀹'), + (0x2F914, 'M', u'瀞'), + (0x2F915, 'M', u'瀛'), + (0x2F916, 'M', u'㶖'), + (0x2F917, 'M', u'灊'), + (0x2F918, 'M', u'災'), + (0x2F919, 'M', u'灷'), + (0x2F91A, 'M', u'炭'), + (0x2F91B, 'M', u'𠔥'), + (0x2F91C, 'M', u'煅'), + (0x2F91D, 'M', u'𤉣'), + (0x2F91E, 'M', u'熜'), + (0x2F91F, 'X'), + (0x2F920, 'M', u'爨'), + (0x2F921, 'M', u'爵'), + (0x2F922, 'M', u'牐'), + (0x2F923, 'M', u'𤘈'), + (0x2F924, 'M', u'犀'), + (0x2F925, 'M', u'犕'), + (0x2F926, 'M', u'𤜵'), + (0x2F927, 'M', u'𤠔'), + (0x2F928, 'M', u'獺'), + (0x2F929, 'M', u'王'), + (0x2F92A, 'M', u'㺬'), + (0x2F92B, 'M', u'玥'), + (0x2F92C, 'M', u'㺸'), + (0x2F92E, 'M', u'瑇'), + (0x2F92F, 'M', u'瑜'), + (0x2F930, 'M', u'瑱'), + (0x2F931, 'M', u'璅'), + (0x2F932, 'M', u'瓊'), + (0x2F933, 'M', u'㼛'), + (0x2F934, 'M', u'甤'), + (0x2F935, 'M', u'𤰶'), + (0x2F936, 'M', u'甾'), + (0x2F937, 'M', u'𤲒'), + (0x2F938, 'M', u'異'), + (0x2F939, 'M', u'𢆟'), + (0x2F93A, 'M', u'瘐'), + (0x2F93B, 'M', u'𤾡'), + (0x2F93C, 'M', u'𤾸'), + (0x2F93D, 'M', u'𥁄'), + (0x2F93E, 'M', u'㿼'), + (0x2F93F, 'M', u'䀈'), + (0x2F940, 'M', u'直'), + (0x2F941, 'M', u'𥃳'), + (0x2F942, 'M', u'𥃲'), + (0x2F943, 'M', u'𥄙'), + (0x2F944, 'M', u'𥄳'), + (0x2F945, 'M', u'眞'), + (0x2F946, 'M', u'真'), + (0x2F948, 'M', u'睊'), + (0x2F949, 'M', u'䀹'), + (0x2F94A, 'M', u'瞋'), + (0x2F94B, 'M', u'䁆'), + (0x2F94C, 'M', u'䂖'), + (0x2F94D, 'M', u'𥐝'), + (0x2F94E, 'M', u'硎'), + (0x2F94F, 'M', u'碌'), + (0x2F950, 'M', u'磌'), + (0x2F951, 'M', u'䃣'), + (0x2F952, 'M', u'𥘦'), + (0x2F953, 'M', u'祖'), + (0x2F954, 'M', u'𥚚'), + (0x2F955, 'M', u'𥛅'), + ] + +def _seg_76(): + return [ + (0x2F956, 'M', u'福'), + (0x2F957, 'M', u'秫'), + (0x2F958, 'M', u'䄯'), + (0x2F959, 'M', u'穀'), + (0x2F95A, 'M', u'穊'), + (0x2F95B, 'M', u'穏'), + (0x2F95C, 'M', u'𥥼'), + (0x2F95D, 'M', u'𥪧'), + (0x2F95F, 'X'), + (0x2F960, 'M', u'䈂'), + (0x2F961, 'M', u'𥮫'), + (0x2F962, 'M', u'篆'), + (0x2F963, 'M', u'築'), + (0x2F964, 'M', u'䈧'), + (0x2F965, 'M', u'𥲀'), + (0x2F966, 'M', u'糒'), + (0x2F967, 'M', u'䊠'), + (0x2F968, 'M', u'糨'), + (0x2F969, 'M', u'糣'), + (0x2F96A, 'M', u'紀'), + (0x2F96B, 'M', u'𥾆'), + (0x2F96C, 'M', u'絣'), + (0x2F96D, 'M', u'䌁'), + (0x2F96E, 'M', u'緇'), + (0x2F96F, 'M', u'縂'), + (0x2F970, 'M', u'繅'), + (0x2F971, 'M', u'䌴'), + (0x2F972, 'M', u'𦈨'), + (0x2F973, 'M', u'𦉇'), + (0x2F974, 'M', u'䍙'), + (0x2F975, 'M', u'𦋙'), + (0x2F976, 'M', u'罺'), + (0x2F977, 'M', u'𦌾'), + (0x2F978, 'M', u'羕'), + (0x2F979, 'M', u'翺'), + (0x2F97A, 'M', u'者'), + (0x2F97B, 'M', u'𦓚'), + (0x2F97C, 'M', u'𦔣'), + (0x2F97D, 'M', u'聠'), + (0x2F97E, 'M', u'𦖨'), + (0x2F97F, 'M', u'聰'), + (0x2F980, 'M', u'𣍟'), + (0x2F981, 'M', u'䏕'), + (0x2F982, 'M', u'育'), + (0x2F983, 'M', u'脃'), + (0x2F984, 'M', u'䐋'), + (0x2F985, 'M', u'脾'), + (0x2F986, 'M', u'媵'), + (0x2F987, 'M', u'𦞧'), + (0x2F988, 'M', u'𦞵'), + (0x2F989, 'M', u'𣎓'), + (0x2F98A, 'M', u'𣎜'), + (0x2F98B, 'M', u'舁'), + (0x2F98C, 'M', u'舄'), + (0x2F98D, 'M', u'辞'), + (0x2F98E, 'M', u'䑫'), + (0x2F98F, 'M', u'芑'), + (0x2F990, 'M', u'芋'), + (0x2F991, 'M', u'芝'), + (0x2F992, 'M', u'劳'), + (0x2F993, 'M', u'花'), + (0x2F994, 'M', u'芳'), + (0x2F995, 'M', u'芽'), + (0x2F996, 'M', u'苦'), + (0x2F997, 'M', u'𦬼'), + (0x2F998, 'M', u'若'), + (0x2F999, 'M', u'茝'), + (0x2F99A, 'M', u'荣'), + (0x2F99B, 'M', u'莭'), + (0x2F99C, 'M', u'茣'), + (0x2F99D, 'M', u'莽'), + (0x2F99E, 'M', u'菧'), + (0x2F99F, 'M', u'著'), + (0x2F9A0, 'M', u'荓'), + (0x2F9A1, 'M', u'菊'), + (0x2F9A2, 'M', u'菌'), + (0x2F9A3, 'M', u'菜'), + (0x2F9A4, 'M', u'𦰶'), + (0x2F9A5, 'M', u'𦵫'), + (0x2F9A6, 'M', u'𦳕'), + (0x2F9A7, 'M', u'䔫'), + (0x2F9A8, 'M', u'蓱'), + (0x2F9A9, 'M', u'蓳'), + (0x2F9AA, 'M', u'蔖'), + (0x2F9AB, 'M', u'𧏊'), + (0x2F9AC, 'M', u'蕤'), + (0x2F9AD, 'M', u'𦼬'), + (0x2F9AE, 'M', u'䕝'), + (0x2F9AF, 'M', u'䕡'), + (0x2F9B0, 'M', u'𦾱'), + (0x2F9B1, 'M', u'𧃒'), + (0x2F9B2, 'M', u'䕫'), + (0x2F9B3, 'M', u'虐'), + (0x2F9B4, 'M', u'虜'), + (0x2F9B5, 'M', u'虧'), + (0x2F9B6, 'M', u'虩'), + (0x2F9B7, 'M', u'蚩'), + (0x2F9B8, 'M', u'蚈'), + (0x2F9B9, 'M', u'蜎'), + (0x2F9BA, 'M', u'蛢'), + ] + +def _seg_77(): + return [ + (0x2F9BB, 'M', u'蝹'), + (0x2F9BC, 'M', u'蜨'), + (0x2F9BD, 'M', u'蝫'), + (0x2F9BE, 'M', u'螆'), + (0x2F9BF, 'X'), + (0x2F9C0, 'M', u'蟡'), + (0x2F9C1, 'M', u'蠁'), + (0x2F9C2, 'M', u'䗹'), + (0x2F9C3, 'M', u'衠'), + (0x2F9C4, 'M', u'衣'), + (0x2F9C5, 'M', u'𧙧'), + (0x2F9C6, 'M', u'裗'), + (0x2F9C7, 'M', u'裞'), + (0x2F9C8, 'M', u'䘵'), + (0x2F9C9, 'M', u'裺'), + (0x2F9CA, 'M', u'㒻'), + (0x2F9CB, 'M', u'𧢮'), + (0x2F9CC, 'M', u'𧥦'), + (0x2F9CD, 'M', u'䚾'), + (0x2F9CE, 'M', u'䛇'), + (0x2F9CF, 'M', u'誠'), + (0x2F9D0, 'M', u'諭'), + (0x2F9D1, 'M', u'變'), + (0x2F9D2, 'M', u'豕'), + (0x2F9D3, 'M', u'𧲨'), + (0x2F9D4, 'M', u'貫'), + (0x2F9D5, 'M', u'賁'), + (0x2F9D6, 'M', u'贛'), + (0x2F9D7, 'M', u'起'), + (0x2F9D8, 'M', u'𧼯'), + (0x2F9D9, 'M', u'𠠄'), + (0x2F9DA, 'M', u'跋'), + (0x2F9DB, 'M', u'趼'), + (0x2F9DC, 'M', u'跰'), + (0x2F9DD, 'M', u'𠣞'), + (0x2F9DE, 'M', u'軔'), + (0x2F9DF, 'M', u'輸'), + (0x2F9E0, 'M', u'𨗒'), + (0x2F9E1, 'M', u'𨗭'), + (0x2F9E2, 'M', u'邔'), + (0x2F9E3, 'M', u'郱'), + (0x2F9E4, 'M', u'鄑'), + (0x2F9E5, 'M', u'𨜮'), + (0x2F9E6, 'M', u'鄛'), + (0x2F9E7, 'M', u'鈸'), + (0x2F9E8, 'M', u'鋗'), + (0x2F9E9, 'M', u'鋘'), + (0x2F9EA, 'M', u'鉼'), + (0x2F9EB, 'M', u'鏹'), + (0x2F9EC, 'M', u'鐕'), + (0x2F9ED, 'M', u'𨯺'), + (0x2F9EE, 'M', u'開'), + (0x2F9EF, 'M', u'䦕'), + (0x2F9F0, 'M', u'閷'), + (0x2F9F1, 'M', u'𨵷'), + (0x2F9F2, 'M', u'䧦'), + (0x2F9F3, 'M', u'雃'), + (0x2F9F4, 'M', u'嶲'), + (0x2F9F5, 'M', u'霣'), + (0x2F9F6, 'M', u'𩅅'), + (0x2F9F7, 'M', u'𩈚'), + (0x2F9F8, 'M', u'䩮'), + (0x2F9F9, 'M', u'䩶'), + (0x2F9FA, 'M', u'韠'), + (0x2F9FB, 'M', u'𩐊'), + (0x2F9FC, 'M', u'䪲'), + (0x2F9FD, 'M', u'𩒖'), + (0x2F9FE, 'M', u'頋'), + (0x2FA00, 'M', u'頩'), + (0x2FA01, 'M', u'𩖶'), + (0x2FA02, 'M', u'飢'), + (0x2FA03, 'M', u'䬳'), + (0x2FA04, 'M', u'餩'), + (0x2FA05, 'M', u'馧'), + (0x2FA06, 'M', u'駂'), + (0x2FA07, 'M', u'駾'), + (0x2FA08, 'M', u'䯎'), + (0x2FA09, 'M', u'𩬰'), + (0x2FA0A, 'M', u'鬒'), + (0x2FA0B, 'M', u'鱀'), + (0x2FA0C, 'M', u'鳽'), + (0x2FA0D, 'M', u'䳎'), + (0x2FA0E, 'M', u'䳭'), + (0x2FA0F, 'M', u'鵧'), + (0x2FA10, 'M', u'𪃎'), + (0x2FA11, 'M', u'䳸'), + (0x2FA12, 'M', u'𪄅'), + (0x2FA13, 'M', u'𪈎'), + (0x2FA14, 'M', u'𪊑'), + (0x2FA15, 'M', u'麻'), + (0x2FA16, 'M', u'䵖'), + (0x2FA17, 'M', u'黹'), + (0x2FA18, 'M', u'黾'), + (0x2FA19, 'M', u'鼅'), + (0x2FA1A, 'M', u'鼏'), + (0x2FA1B, 'M', u'鼖'), + (0x2FA1C, 'M', u'鼻'), + (0x2FA1D, 'M', u'𪘀'), + (0x2FA1E, 'X'), + (0xE0100, 'I'), + ] + +def _seg_78(): + return [ + (0xE01F0, 'X'), + ] + +uts46data = tuple( + _seg_0() + + _seg_1() + + _seg_2() + + _seg_3() + + _seg_4() + + _seg_5() + + _seg_6() + + _seg_7() + + _seg_8() + + _seg_9() + + _seg_10() + + _seg_11() + + _seg_12() + + _seg_13() + + _seg_14() + + _seg_15() + + _seg_16() + + _seg_17() + + _seg_18() + + _seg_19() + + _seg_20() + + _seg_21() + + _seg_22() + + _seg_23() + + _seg_24() + + _seg_25() + + _seg_26() + + _seg_27() + + _seg_28() + + _seg_29() + + _seg_30() + + _seg_31() + + _seg_32() + + _seg_33() + + _seg_34() + + _seg_35() + + _seg_36() + + _seg_37() + + _seg_38() + + _seg_39() + + _seg_40() + + _seg_41() + + _seg_42() + + _seg_43() + + _seg_44() + + _seg_45() + + _seg_46() + + _seg_47() + + _seg_48() + + _seg_49() + + _seg_50() + + _seg_51() + + _seg_52() + + _seg_53() + + _seg_54() + + _seg_55() + + _seg_56() + + _seg_57() + + _seg_58() + + _seg_59() + + _seg_60() + + _seg_61() + + _seg_62() + + _seg_63() + + _seg_64() + + _seg_65() + + _seg_66() + + _seg_67() + + _seg_68() + + _seg_69() + + _seg_70() + + _seg_71() + + _seg_72() + + _seg_73() + + _seg_74() + + _seg_75() + + _seg_76() + + _seg_77() + + _seg_78() +) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/ipaddress.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/ipaddress.py new file mode 100644 index 0000000..f2d0766 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/ipaddress.py @@ -0,0 +1,2419 @@ +# Copyright 2007 Google Inc. +# Licensed to PSF under a Contributor Agreement. + +"""A fast, lightweight IPv4/IPv6 manipulation library in Python. + +This library is used to create/poke/manipulate IPv4 and IPv6 addresses +and networks. + +""" + +from __future__ import unicode_literals + + +import itertools +import struct + +__version__ = '1.0.22' + +# Compatibility functions +_compat_int_types = (int,) +try: + _compat_int_types = (int, long) +except NameError: + pass +try: + _compat_str = unicode +except NameError: + _compat_str = str + assert bytes != str +if b'\0'[0] == 0: # Python 3 semantics + def _compat_bytes_to_byte_vals(byt): + return byt +else: + def _compat_bytes_to_byte_vals(byt): + return [struct.unpack(b'!B', b)[0] for b in byt] +try: + _compat_int_from_byte_vals = int.from_bytes +except AttributeError: + def _compat_int_from_byte_vals(bytvals, endianess): + assert endianess == 'big' + res = 0 + for bv in bytvals: + assert isinstance(bv, _compat_int_types) + res = (res << 8) + bv + return res + + +def _compat_to_bytes(intval, length, endianess): + assert isinstance(intval, _compat_int_types) + assert endianess == 'big' + if length == 4: + if intval < 0 or intval >= 2 ** 32: + raise struct.error("integer out of range for 'I' format code") + return struct.pack(b'!I', intval) + elif length == 16: + if intval < 0 or intval >= 2 ** 128: + raise struct.error("integer out of range for 'QQ' format code") + return struct.pack(b'!QQ', intval >> 64, intval & 0xffffffffffffffff) + else: + raise NotImplementedError() + + +if hasattr(int, 'bit_length'): + # Not int.bit_length , since that won't work in 2.7 where long exists + def _compat_bit_length(i): + return i.bit_length() +else: + def _compat_bit_length(i): + for res in itertools.count(): + if i >> res == 0: + return res + + +def _compat_range(start, end, step=1): + assert step > 0 + i = start + while i < end: + yield i + i += step + + +class _TotalOrderingMixin(object): + __slots__ = () + + # Helper that derives the other comparison operations from + # __lt__ and __eq__ + # We avoid functools.total_ordering because it doesn't handle + # NotImplemented correctly yet (http://bugs.python.org/issue10042) + def __eq__(self, other): + raise NotImplementedError + + def __ne__(self, other): + equal = self.__eq__(other) + if equal is NotImplemented: + return NotImplemented + return not equal + + def __lt__(self, other): + raise NotImplementedError + + def __le__(self, other): + less = self.__lt__(other) + if less is NotImplemented or not less: + return self.__eq__(other) + return less + + def __gt__(self, other): + less = self.__lt__(other) + if less is NotImplemented: + return NotImplemented + equal = self.__eq__(other) + if equal is NotImplemented: + return NotImplemented + return not (less or equal) + + def __ge__(self, other): + less = self.__lt__(other) + if less is NotImplemented: + return NotImplemented + return not less + + +IPV4LENGTH = 32 +IPV6LENGTH = 128 + + +class AddressValueError(ValueError): + """A Value Error related to the address.""" + + +class NetmaskValueError(ValueError): + """A Value Error related to the netmask.""" + + +def ip_address(address): + """Take an IP string/int and return an object of the correct type. + + Args: + address: A string or integer, the IP address. Either IPv4 or + IPv6 addresses may be supplied; integers less than 2**32 will + be considered to be IPv4 by default. + + Returns: + An IPv4Address or IPv6Address object. + + Raises: + ValueError: if the *address* passed isn't either a v4 or a v6 + address + + """ + try: + return IPv4Address(address) + except (AddressValueError, NetmaskValueError): + pass + + try: + return IPv6Address(address) + except (AddressValueError, NetmaskValueError): + pass + + if isinstance(address, bytes): + raise AddressValueError( + '%r does not appear to be an IPv4 or IPv6 address. ' + 'Did you pass in a bytes (str in Python 2) instead of' + ' a unicode object?' % address) + + raise ValueError('%r does not appear to be an IPv4 or IPv6 address' % + address) + + +def ip_network(address, strict=True): + """Take an IP string/int and return an object of the correct type. + + Args: + address: A string or integer, the IP network. Either IPv4 or + IPv6 networks may be supplied; integers less than 2**32 will + be considered to be IPv4 by default. + + Returns: + An IPv4Network or IPv6Network object. + + Raises: + ValueError: if the string passed isn't either a v4 or a v6 + address. Or if the network has host bits set. + + """ + try: + return IPv4Network(address, strict) + except (AddressValueError, NetmaskValueError): + pass + + try: + return IPv6Network(address, strict) + except (AddressValueError, NetmaskValueError): + pass + + if isinstance(address, bytes): + raise AddressValueError( + '%r does not appear to be an IPv4 or IPv6 network. ' + 'Did you pass in a bytes (str in Python 2) instead of' + ' a unicode object?' % address) + + raise ValueError('%r does not appear to be an IPv4 or IPv6 network' % + address) + + +def ip_interface(address): + """Take an IP string/int and return an object of the correct type. + + Args: + address: A string or integer, the IP address. Either IPv4 or + IPv6 addresses may be supplied; integers less than 2**32 will + be considered to be IPv4 by default. + + Returns: + An IPv4Interface or IPv6Interface object. + + Raises: + ValueError: if the string passed isn't either a v4 or a v6 + address. + + Notes: + The IPv?Interface classes describe an Address on a particular + Network, so they're basically a combination of both the Address + and Network classes. + + """ + try: + return IPv4Interface(address) + except (AddressValueError, NetmaskValueError): + pass + + try: + return IPv6Interface(address) + except (AddressValueError, NetmaskValueError): + pass + + raise ValueError('%r does not appear to be an IPv4 or IPv6 interface' % + address) + + +def v4_int_to_packed(address): + """Represent an address as 4 packed bytes in network (big-endian) order. + + Args: + address: An integer representation of an IPv4 IP address. + + Returns: + The integer address packed as 4 bytes in network (big-endian) order. + + Raises: + ValueError: If the integer is negative or too large to be an + IPv4 IP address. + + """ + try: + return _compat_to_bytes(address, 4, 'big') + except (struct.error, OverflowError): + raise ValueError("Address negative or too large for IPv4") + + +def v6_int_to_packed(address): + """Represent an address as 16 packed bytes in network (big-endian) order. + + Args: + address: An integer representation of an IPv6 IP address. + + Returns: + The integer address packed as 16 bytes in network (big-endian) order. + + """ + try: + return _compat_to_bytes(address, 16, 'big') + except (struct.error, OverflowError): + raise ValueError("Address negative or too large for IPv6") + + +def _split_optional_netmask(address): + """Helper to split the netmask and raise AddressValueError if needed""" + addr = _compat_str(address).split('/') + if len(addr) > 2: + raise AddressValueError("Only one '/' permitted in %r" % address) + return addr + + +def _find_address_range(addresses): + """Find a sequence of sorted deduplicated IPv#Address. + + Args: + addresses: a list of IPv#Address objects. + + Yields: + A tuple containing the first and last IP addresses in the sequence. + + """ + it = iter(addresses) + first = last = next(it) + for ip in it: + if ip._ip != last._ip + 1: + yield first, last + first = ip + last = ip + yield first, last + + +def _count_righthand_zero_bits(number, bits): + """Count the number of zero bits on the right hand side. + + Args: + number: an integer. + bits: maximum number of bits to count. + + Returns: + The number of zero bits on the right hand side of the number. + + """ + if number == 0: + return bits + return min(bits, _compat_bit_length(~number & (number - 1))) + + +def summarize_address_range(first, last): + """Summarize a network range given the first and last IP addresses. + + Example: + >>> list(summarize_address_range(IPv4Address('192.0.2.0'), + ... IPv4Address('192.0.2.130'))) + ... #doctest: +NORMALIZE_WHITESPACE + [IPv4Network('192.0.2.0/25'), IPv4Network('192.0.2.128/31'), + IPv4Network('192.0.2.130/32')] + + Args: + first: the first IPv4Address or IPv6Address in the range. + last: the last IPv4Address or IPv6Address in the range. + + Returns: + An iterator of the summarized IPv(4|6) network objects. + + Raise: + TypeError: + If the first and last objects are not IP addresses. + If the first and last objects are not the same version. + ValueError: + If the last object is not greater than the first. + If the version of the first address is not 4 or 6. + + """ + if (not (isinstance(first, _BaseAddress) and + isinstance(last, _BaseAddress))): + raise TypeError('first and last must be IP addresses, not networks') + if first.version != last.version: + raise TypeError("%s and %s are not of the same version" % ( + first, last)) + if first > last: + raise ValueError('last IP address must be greater than first') + + if first.version == 4: + ip = IPv4Network + elif first.version == 6: + ip = IPv6Network + else: + raise ValueError('unknown IP version') + + ip_bits = first._max_prefixlen + first_int = first._ip + last_int = last._ip + while first_int <= last_int: + nbits = min(_count_righthand_zero_bits(first_int, ip_bits), + _compat_bit_length(last_int - first_int + 1) - 1) + net = ip((first_int, ip_bits - nbits)) + yield net + first_int += 1 << nbits + if first_int - 1 == ip._ALL_ONES: + break + + +def _collapse_addresses_internal(addresses): + """Loops through the addresses, collapsing concurrent netblocks. + + Example: + + ip1 = IPv4Network('192.0.2.0/26') + ip2 = IPv4Network('192.0.2.64/26') + ip3 = IPv4Network('192.0.2.128/26') + ip4 = IPv4Network('192.0.2.192/26') + + _collapse_addresses_internal([ip1, ip2, ip3, ip4]) -> + [IPv4Network('192.0.2.0/24')] + + This shouldn't be called directly; it is called via + collapse_addresses([]). + + Args: + addresses: A list of IPv4Network's or IPv6Network's + + Returns: + A list of IPv4Network's or IPv6Network's depending on what we were + passed. + + """ + # First merge + to_merge = list(addresses) + subnets = {} + while to_merge: + net = to_merge.pop() + supernet = net.supernet() + existing = subnets.get(supernet) + if existing is None: + subnets[supernet] = net + elif existing != net: + # Merge consecutive subnets + del subnets[supernet] + to_merge.append(supernet) + # Then iterate over resulting networks, skipping subsumed subnets + last = None + for net in sorted(subnets.values()): + if last is not None: + # Since they are sorted, + # last.network_address <= net.network_address is a given. + if last.broadcast_address >= net.broadcast_address: + continue + yield net + last = net + + +def collapse_addresses(addresses): + """Collapse a list of IP objects. + + Example: + collapse_addresses([IPv4Network('192.0.2.0/25'), + IPv4Network('192.0.2.128/25')]) -> + [IPv4Network('192.0.2.0/24')] + + Args: + addresses: An iterator of IPv4Network or IPv6Network objects. + + Returns: + An iterator of the collapsed IPv(4|6)Network objects. + + Raises: + TypeError: If passed a list of mixed version objects. + + """ + addrs = [] + ips = [] + nets = [] + + # split IP addresses and networks + for ip in addresses: + if isinstance(ip, _BaseAddress): + if ips and ips[-1]._version != ip._version: + raise TypeError("%s and %s are not of the same version" % ( + ip, ips[-1])) + ips.append(ip) + elif ip._prefixlen == ip._max_prefixlen: + if ips and ips[-1]._version != ip._version: + raise TypeError("%s and %s are not of the same version" % ( + ip, ips[-1])) + try: + ips.append(ip.ip) + except AttributeError: + ips.append(ip.network_address) + else: + if nets and nets[-1]._version != ip._version: + raise TypeError("%s and %s are not of the same version" % ( + ip, nets[-1])) + nets.append(ip) + + # sort and dedup + ips = sorted(set(ips)) + + # find consecutive address ranges in the sorted sequence and summarize them + if ips: + for first, last in _find_address_range(ips): + addrs.extend(summarize_address_range(first, last)) + + return _collapse_addresses_internal(addrs + nets) + + +def get_mixed_type_key(obj): + """Return a key suitable for sorting between networks and addresses. + + Address and Network objects are not sortable by default; they're + fundamentally different so the expression + + IPv4Address('192.0.2.0') <= IPv4Network('192.0.2.0/24') + + doesn't make any sense. There are some times however, where you may wish + to have ipaddress sort these for you anyway. If you need to do this, you + can use this function as the key= argument to sorted(). + + Args: + obj: either a Network or Address object. + Returns: + appropriate key. + + """ + if isinstance(obj, _BaseNetwork): + return obj._get_networks_key() + elif isinstance(obj, _BaseAddress): + return obj._get_address_key() + return NotImplemented + + +class _IPAddressBase(_TotalOrderingMixin): + + """The mother class.""" + + __slots__ = () + + @property + def exploded(self): + """Return the longhand version of the IP address as a string.""" + return self._explode_shorthand_ip_string() + + @property + def compressed(self): + """Return the shorthand version of the IP address as a string.""" + return _compat_str(self) + + @property + def reverse_pointer(self): + """The name of the reverse DNS pointer for the IP address, e.g.: + >>> ipaddress.ip_address("127.0.0.1").reverse_pointer + '1.0.0.127.in-addr.arpa' + >>> ipaddress.ip_address("2001:db8::1").reverse_pointer + '1.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.8.b.d.0.1.0.0.2.ip6.arpa' + + """ + return self._reverse_pointer() + + @property + def version(self): + msg = '%200s has no version specified' % (type(self),) + raise NotImplementedError(msg) + + def _check_int_address(self, address): + if address < 0: + msg = "%d (< 0) is not permitted as an IPv%d address" + raise AddressValueError(msg % (address, self._version)) + if address > self._ALL_ONES: + msg = "%d (>= 2**%d) is not permitted as an IPv%d address" + raise AddressValueError(msg % (address, self._max_prefixlen, + self._version)) + + def _check_packed_address(self, address, expected_len): + address_len = len(address) + if address_len != expected_len: + msg = ( + '%r (len %d != %d) is not permitted as an IPv%d address. ' + 'Did you pass in a bytes (str in Python 2) instead of' + ' a unicode object?') + raise AddressValueError(msg % (address, address_len, + expected_len, self._version)) + + @classmethod + def _ip_int_from_prefix(cls, prefixlen): + """Turn the prefix length into a bitwise netmask + + Args: + prefixlen: An integer, the prefix length. + + Returns: + An integer. + + """ + return cls._ALL_ONES ^ (cls._ALL_ONES >> prefixlen) + + @classmethod + def _prefix_from_ip_int(cls, ip_int): + """Return prefix length from the bitwise netmask. + + Args: + ip_int: An integer, the netmask in expanded bitwise format + + Returns: + An integer, the prefix length. + + Raises: + ValueError: If the input intermingles zeroes & ones + """ + trailing_zeroes = _count_righthand_zero_bits(ip_int, + cls._max_prefixlen) + prefixlen = cls._max_prefixlen - trailing_zeroes + leading_ones = ip_int >> trailing_zeroes + all_ones = (1 << prefixlen) - 1 + if leading_ones != all_ones: + byteslen = cls._max_prefixlen // 8 + details = _compat_to_bytes(ip_int, byteslen, 'big') + msg = 'Netmask pattern %r mixes zeroes & ones' + raise ValueError(msg % details) + return prefixlen + + @classmethod + def _report_invalid_netmask(cls, netmask_str): + msg = '%r is not a valid netmask' % netmask_str + raise NetmaskValueError(msg) + + @classmethod + def _prefix_from_prefix_string(cls, prefixlen_str): + """Return prefix length from a numeric string + + Args: + prefixlen_str: The string to be converted + + Returns: + An integer, the prefix length. + + Raises: + NetmaskValueError: If the input is not a valid netmask + """ + # int allows a leading +/- as well as surrounding whitespace, + # so we ensure that isn't the case + if not _BaseV4._DECIMAL_DIGITS.issuperset(prefixlen_str): + cls._report_invalid_netmask(prefixlen_str) + try: + prefixlen = int(prefixlen_str) + except ValueError: + cls._report_invalid_netmask(prefixlen_str) + if not (0 <= prefixlen <= cls._max_prefixlen): + cls._report_invalid_netmask(prefixlen_str) + return prefixlen + + @classmethod + def _prefix_from_ip_string(cls, ip_str): + """Turn a netmask/hostmask string into a prefix length + + Args: + ip_str: The netmask/hostmask to be converted + + Returns: + An integer, the prefix length. + + Raises: + NetmaskValueError: If the input is not a valid netmask/hostmask + """ + # Parse the netmask/hostmask like an IP address. + try: + ip_int = cls._ip_int_from_string(ip_str) + except AddressValueError: + cls._report_invalid_netmask(ip_str) + + # Try matching a netmask (this would be /1*0*/ as a bitwise regexp). + # Note that the two ambiguous cases (all-ones and all-zeroes) are + # treated as netmasks. + try: + return cls._prefix_from_ip_int(ip_int) + except ValueError: + pass + + # Invert the bits, and try matching a /0+1+/ hostmask instead. + ip_int ^= cls._ALL_ONES + try: + return cls._prefix_from_ip_int(ip_int) + except ValueError: + cls._report_invalid_netmask(ip_str) + + def __reduce__(self): + return self.__class__, (_compat_str(self),) + + +class _BaseAddress(_IPAddressBase): + + """A generic IP object. + + This IP class contains the version independent methods which are + used by single IP addresses. + """ + + __slots__ = () + + def __int__(self): + return self._ip + + def __eq__(self, other): + try: + return (self._ip == other._ip and + self._version == other._version) + except AttributeError: + return NotImplemented + + def __lt__(self, other): + if not isinstance(other, _IPAddressBase): + return NotImplemented + if not isinstance(other, _BaseAddress): + raise TypeError('%s and %s are not of the same type' % ( + self, other)) + if self._version != other._version: + raise TypeError('%s and %s are not of the same version' % ( + self, other)) + if self._ip != other._ip: + return self._ip < other._ip + return False + + # Shorthand for Integer addition and subtraction. This is not + # meant to ever support addition/subtraction of addresses. + def __add__(self, other): + if not isinstance(other, _compat_int_types): + return NotImplemented + return self.__class__(int(self) + other) + + def __sub__(self, other): + if not isinstance(other, _compat_int_types): + return NotImplemented + return self.__class__(int(self) - other) + + def __repr__(self): + return '%s(%r)' % (self.__class__.__name__, _compat_str(self)) + + def __str__(self): + return _compat_str(self._string_from_ip_int(self._ip)) + + def __hash__(self): + return hash(hex(int(self._ip))) + + def _get_address_key(self): + return (self._version, self) + + def __reduce__(self): + return self.__class__, (self._ip,) + + +class _BaseNetwork(_IPAddressBase): + + """A generic IP network object. + + This IP class contains the version independent methods which are + used by networks. + + """ + def __init__(self, address): + self._cache = {} + + def __repr__(self): + return '%s(%r)' % (self.__class__.__name__, _compat_str(self)) + + def __str__(self): + return '%s/%d' % (self.network_address, self.prefixlen) + + def hosts(self): + """Generate Iterator over usable hosts in a network. + + This is like __iter__ except it doesn't return the network + or broadcast addresses. + + """ + network = int(self.network_address) + broadcast = int(self.broadcast_address) + for x in _compat_range(network + 1, broadcast): + yield self._address_class(x) + + def __iter__(self): + network = int(self.network_address) + broadcast = int(self.broadcast_address) + for x in _compat_range(network, broadcast + 1): + yield self._address_class(x) + + def __getitem__(self, n): + network = int(self.network_address) + broadcast = int(self.broadcast_address) + if n >= 0: + if network + n > broadcast: + raise IndexError('address out of range') + return self._address_class(network + n) + else: + n += 1 + if broadcast + n < network: + raise IndexError('address out of range') + return self._address_class(broadcast + n) + + def __lt__(self, other): + if not isinstance(other, _IPAddressBase): + return NotImplemented + if not isinstance(other, _BaseNetwork): + raise TypeError('%s and %s are not of the same type' % ( + self, other)) + if self._version != other._version: + raise TypeError('%s and %s are not of the same version' % ( + self, other)) + if self.network_address != other.network_address: + return self.network_address < other.network_address + if self.netmask != other.netmask: + return self.netmask < other.netmask + return False + + def __eq__(self, other): + try: + return (self._version == other._version and + self.network_address == other.network_address and + int(self.netmask) == int(other.netmask)) + except AttributeError: + return NotImplemented + + def __hash__(self): + return hash(int(self.network_address) ^ int(self.netmask)) + + def __contains__(self, other): + # always false if one is v4 and the other is v6. + if self._version != other._version: + return False + # dealing with another network. + if isinstance(other, _BaseNetwork): + return False + # dealing with another address + else: + # address + return (int(self.network_address) <= int(other._ip) <= + int(self.broadcast_address)) + + def overlaps(self, other): + """Tell if self is partly contained in other.""" + return self.network_address in other or ( + self.broadcast_address in other or ( + other.network_address in self or ( + other.broadcast_address in self))) + + @property + def broadcast_address(self): + x = self._cache.get('broadcast_address') + if x is None: + x = self._address_class(int(self.network_address) | + int(self.hostmask)) + self._cache['broadcast_address'] = x + return x + + @property + def hostmask(self): + x = self._cache.get('hostmask') + if x is None: + x = self._address_class(int(self.netmask) ^ self._ALL_ONES) + self._cache['hostmask'] = x + return x + + @property + def with_prefixlen(self): + return '%s/%d' % (self.network_address, self._prefixlen) + + @property + def with_netmask(self): + return '%s/%s' % (self.network_address, self.netmask) + + @property + def with_hostmask(self): + return '%s/%s' % (self.network_address, self.hostmask) + + @property + def num_addresses(self): + """Number of hosts in the current subnet.""" + return int(self.broadcast_address) - int(self.network_address) + 1 + + @property + def _address_class(self): + # Returning bare address objects (rather than interfaces) allows for + # more consistent behaviour across the network address, broadcast + # address and individual host addresses. + msg = '%200s has no associated address class' % (type(self),) + raise NotImplementedError(msg) + + @property + def prefixlen(self): + return self._prefixlen + + def address_exclude(self, other): + """Remove an address from a larger block. + + For example: + + addr1 = ip_network('192.0.2.0/28') + addr2 = ip_network('192.0.2.1/32') + list(addr1.address_exclude(addr2)) = + [IPv4Network('192.0.2.0/32'), IPv4Network('192.0.2.2/31'), + IPv4Network('192.0.2.4/30'), IPv4Network('192.0.2.8/29')] + + or IPv6: + + addr1 = ip_network('2001:db8::1/32') + addr2 = ip_network('2001:db8::1/128') + list(addr1.address_exclude(addr2)) = + [ip_network('2001:db8::1/128'), + ip_network('2001:db8::2/127'), + ip_network('2001:db8::4/126'), + ip_network('2001:db8::8/125'), + ... + ip_network('2001:db8:8000::/33')] + + Args: + other: An IPv4Network or IPv6Network object of the same type. + + Returns: + An iterator of the IPv(4|6)Network objects which is self + minus other. + + Raises: + TypeError: If self and other are of differing address + versions, or if other is not a network object. + ValueError: If other is not completely contained by self. + + """ + if not self._version == other._version: + raise TypeError("%s and %s are not of the same version" % ( + self, other)) + + if not isinstance(other, _BaseNetwork): + raise TypeError("%s is not a network object" % other) + + if not other.subnet_of(self): + raise ValueError('%s not contained in %s' % (other, self)) + if other == self: + return + + # Make sure we're comparing the network of other. + other = other.__class__('%s/%s' % (other.network_address, + other.prefixlen)) + + s1, s2 = self.subnets() + while s1 != other and s2 != other: + if other.subnet_of(s1): + yield s2 + s1, s2 = s1.subnets() + elif other.subnet_of(s2): + yield s1 + s1, s2 = s2.subnets() + else: + # If we got here, there's a bug somewhere. + raise AssertionError('Error performing exclusion: ' + 's1: %s s2: %s other: %s' % + (s1, s2, other)) + if s1 == other: + yield s2 + elif s2 == other: + yield s1 + else: + # If we got here, there's a bug somewhere. + raise AssertionError('Error performing exclusion: ' + 's1: %s s2: %s other: %s' % + (s1, s2, other)) + + def compare_networks(self, other): + """Compare two IP objects. + + This is only concerned about the comparison of the integer + representation of the network addresses. This means that the + host bits aren't considered at all in this method. If you want + to compare host bits, you can easily enough do a + 'HostA._ip < HostB._ip' + + Args: + other: An IP object. + + Returns: + If the IP versions of self and other are the same, returns: + + -1 if self < other: + eg: IPv4Network('192.0.2.0/25') < IPv4Network('192.0.2.128/25') + IPv6Network('2001:db8::1000/124') < + IPv6Network('2001:db8::2000/124') + 0 if self == other + eg: IPv4Network('192.0.2.0/24') == IPv4Network('192.0.2.0/24') + IPv6Network('2001:db8::1000/124') == + IPv6Network('2001:db8::1000/124') + 1 if self > other + eg: IPv4Network('192.0.2.128/25') > IPv4Network('192.0.2.0/25') + IPv6Network('2001:db8::2000/124') > + IPv6Network('2001:db8::1000/124') + + Raises: + TypeError if the IP versions are different. + + """ + # does this need to raise a ValueError? + if self._version != other._version: + raise TypeError('%s and %s are not of the same type' % ( + self, other)) + # self._version == other._version below here: + if self.network_address < other.network_address: + return -1 + if self.network_address > other.network_address: + return 1 + # self.network_address == other.network_address below here: + if self.netmask < other.netmask: + return -1 + if self.netmask > other.netmask: + return 1 + return 0 + + def _get_networks_key(self): + """Network-only key function. + + Returns an object that identifies this address' network and + netmask. This function is a suitable "key" argument for sorted() + and list.sort(). + + """ + return (self._version, self.network_address, self.netmask) + + def subnets(self, prefixlen_diff=1, new_prefix=None): + """The subnets which join to make the current subnet. + + In the case that self contains only one IP + (self._prefixlen == 32 for IPv4 or self._prefixlen == 128 + for IPv6), yield an iterator with just ourself. + + Args: + prefixlen_diff: An integer, the amount the prefix length + should be increased by. This should not be set if + new_prefix is also set. + new_prefix: The desired new prefix length. This must be a + larger number (smaller prefix) than the existing prefix. + This should not be set if prefixlen_diff is also set. + + Returns: + An iterator of IPv(4|6) objects. + + Raises: + ValueError: The prefixlen_diff is too small or too large. + OR + prefixlen_diff and new_prefix are both set or new_prefix + is a smaller number than the current prefix (smaller + number means a larger network) + + """ + if self._prefixlen == self._max_prefixlen: + yield self + return + + if new_prefix is not None: + if new_prefix < self._prefixlen: + raise ValueError('new prefix must be longer') + if prefixlen_diff != 1: + raise ValueError('cannot set prefixlen_diff and new_prefix') + prefixlen_diff = new_prefix - self._prefixlen + + if prefixlen_diff < 0: + raise ValueError('prefix length diff must be > 0') + new_prefixlen = self._prefixlen + prefixlen_diff + + if new_prefixlen > self._max_prefixlen: + raise ValueError( + 'prefix length diff %d is invalid for netblock %s' % ( + new_prefixlen, self)) + + start = int(self.network_address) + end = int(self.broadcast_address) + 1 + step = (int(self.hostmask) + 1) >> prefixlen_diff + for new_addr in _compat_range(start, end, step): + current = self.__class__((new_addr, new_prefixlen)) + yield current + + def supernet(self, prefixlen_diff=1, new_prefix=None): + """The supernet containing the current network. + + Args: + prefixlen_diff: An integer, the amount the prefix length of + the network should be decreased by. For example, given a + /24 network and a prefixlen_diff of 3, a supernet with a + /21 netmask is returned. + + Returns: + An IPv4 network object. + + Raises: + ValueError: If self.prefixlen - prefixlen_diff < 0. I.e., you have + a negative prefix length. + OR + If prefixlen_diff and new_prefix are both set or new_prefix is a + larger number than the current prefix (larger number means a + smaller network) + + """ + if self._prefixlen == 0: + return self + + if new_prefix is not None: + if new_prefix > self._prefixlen: + raise ValueError('new prefix must be shorter') + if prefixlen_diff != 1: + raise ValueError('cannot set prefixlen_diff and new_prefix') + prefixlen_diff = self._prefixlen - new_prefix + + new_prefixlen = self.prefixlen - prefixlen_diff + if new_prefixlen < 0: + raise ValueError( + 'current prefixlen is %d, cannot have a prefixlen_diff of %d' % + (self.prefixlen, prefixlen_diff)) + return self.__class__(( + int(self.network_address) & (int(self.netmask) << prefixlen_diff), + new_prefixlen)) + + @property + def is_multicast(self): + """Test if the address is reserved for multicast use. + + Returns: + A boolean, True if the address is a multicast address. + See RFC 2373 2.7 for details. + + """ + return (self.network_address.is_multicast and + self.broadcast_address.is_multicast) + + @staticmethod + def _is_subnet_of(a, b): + try: + # Always false if one is v4 and the other is v6. + if a._version != b._version: + raise TypeError("%s and %s are not of the same version" (a, b)) + return (b.network_address <= a.network_address and + b.broadcast_address >= a.broadcast_address) + except AttributeError: + raise TypeError("Unable to test subnet containment " + "between %s and %s" % (a, b)) + + def subnet_of(self, other): + """Return True if this network is a subnet of other.""" + return self._is_subnet_of(self, other) + + def supernet_of(self, other): + """Return True if this network is a supernet of other.""" + return self._is_subnet_of(other, self) + + @property + def is_reserved(self): + """Test if the address is otherwise IETF reserved. + + Returns: + A boolean, True if the address is within one of the + reserved IPv6 Network ranges. + + """ + return (self.network_address.is_reserved and + self.broadcast_address.is_reserved) + + @property + def is_link_local(self): + """Test if the address is reserved for link-local. + + Returns: + A boolean, True if the address is reserved per RFC 4291. + + """ + return (self.network_address.is_link_local and + self.broadcast_address.is_link_local) + + @property + def is_private(self): + """Test if this address is allocated for private networks. + + Returns: + A boolean, True if the address is reserved per + iana-ipv4-special-registry or iana-ipv6-special-registry. + + """ + return (self.network_address.is_private and + self.broadcast_address.is_private) + + @property + def is_global(self): + """Test if this address is allocated for public networks. + + Returns: + A boolean, True if the address is not reserved per + iana-ipv4-special-registry or iana-ipv6-special-registry. + + """ + return not self.is_private + + @property + def is_unspecified(self): + """Test if the address is unspecified. + + Returns: + A boolean, True if this is the unspecified address as defined in + RFC 2373 2.5.2. + + """ + return (self.network_address.is_unspecified and + self.broadcast_address.is_unspecified) + + @property + def is_loopback(self): + """Test if the address is a loopback address. + + Returns: + A boolean, True if the address is a loopback address as defined in + RFC 2373 2.5.3. + + """ + return (self.network_address.is_loopback and + self.broadcast_address.is_loopback) + + +class _BaseV4(object): + + """Base IPv4 object. + + The following methods are used by IPv4 objects in both single IP + addresses and networks. + + """ + + __slots__ = () + _version = 4 + # Equivalent to 255.255.255.255 or 32 bits of 1's. + _ALL_ONES = (2 ** IPV4LENGTH) - 1 + _DECIMAL_DIGITS = frozenset('0123456789') + + # the valid octets for host and netmasks. only useful for IPv4. + _valid_mask_octets = frozenset([255, 254, 252, 248, 240, 224, 192, 128, 0]) + + _max_prefixlen = IPV4LENGTH + # There are only a handful of valid v4 netmasks, so we cache them all + # when constructed (see _make_netmask()). + _netmask_cache = {} + + def _explode_shorthand_ip_string(self): + return _compat_str(self) + + @classmethod + def _make_netmask(cls, arg): + """Make a (netmask, prefix_len) tuple from the given argument. + + Argument can be: + - an integer (the prefix length) + - a string representing the prefix length (e.g. "24") + - a string representing the prefix netmask (e.g. "255.255.255.0") + """ + if arg not in cls._netmask_cache: + if isinstance(arg, _compat_int_types): + prefixlen = arg + else: + try: + # Check for a netmask in prefix length form + prefixlen = cls._prefix_from_prefix_string(arg) + except NetmaskValueError: + # Check for a netmask or hostmask in dotted-quad form. + # This may raise NetmaskValueError. + prefixlen = cls._prefix_from_ip_string(arg) + netmask = IPv4Address(cls._ip_int_from_prefix(prefixlen)) + cls._netmask_cache[arg] = netmask, prefixlen + return cls._netmask_cache[arg] + + @classmethod + def _ip_int_from_string(cls, ip_str): + """Turn the given IP string into an integer for comparison. + + Args: + ip_str: A string, the IP ip_str. + + Returns: + The IP ip_str as an integer. + + Raises: + AddressValueError: if ip_str isn't a valid IPv4 Address. + + """ + if not ip_str: + raise AddressValueError('Address cannot be empty') + + octets = ip_str.split('.') + if len(octets) != 4: + raise AddressValueError("Expected 4 octets in %r" % ip_str) + + try: + return _compat_int_from_byte_vals( + map(cls._parse_octet, octets), 'big') + except ValueError as exc: + raise AddressValueError("%s in %r" % (exc, ip_str)) + + @classmethod + def _parse_octet(cls, octet_str): + """Convert a decimal octet into an integer. + + Args: + octet_str: A string, the number to parse. + + Returns: + The octet as an integer. + + Raises: + ValueError: if the octet isn't strictly a decimal from [0..255]. + + """ + if not octet_str: + raise ValueError("Empty octet not permitted") + # Whitelist the characters, since int() allows a lot of bizarre stuff. + if not cls._DECIMAL_DIGITS.issuperset(octet_str): + msg = "Only decimal digits permitted in %r" + raise ValueError(msg % octet_str) + # We do the length check second, since the invalid character error + # is likely to be more informative for the user + if len(octet_str) > 3: + msg = "At most 3 characters permitted in %r" + raise ValueError(msg % octet_str) + # Convert to integer (we know digits are legal) + octet_int = int(octet_str, 10) + # Any octets that look like they *might* be written in octal, + # and which don't look exactly the same in both octal and + # decimal are rejected as ambiguous + if octet_int > 7 and octet_str[0] == '0': + msg = "Ambiguous (octal/decimal) value in %r not permitted" + raise ValueError(msg % octet_str) + if octet_int > 255: + raise ValueError("Octet %d (> 255) not permitted" % octet_int) + return octet_int + + @classmethod + def _string_from_ip_int(cls, ip_int): + """Turns a 32-bit integer into dotted decimal notation. + + Args: + ip_int: An integer, the IP address. + + Returns: + The IP address as a string in dotted decimal notation. + + """ + return '.'.join(_compat_str(struct.unpack(b'!B', b)[0] + if isinstance(b, bytes) + else b) + for b in _compat_to_bytes(ip_int, 4, 'big')) + + def _is_hostmask(self, ip_str): + """Test if the IP string is a hostmask (rather than a netmask). + + Args: + ip_str: A string, the potential hostmask. + + Returns: + A boolean, True if the IP string is a hostmask. + + """ + bits = ip_str.split('.') + try: + parts = [x for x in map(int, bits) if x in self._valid_mask_octets] + except ValueError: + return False + if len(parts) != len(bits): + return False + if parts[0] < parts[-1]: + return True + return False + + def _reverse_pointer(self): + """Return the reverse DNS pointer name for the IPv4 address. + + This implements the method described in RFC1035 3.5. + + """ + reverse_octets = _compat_str(self).split('.')[::-1] + return '.'.join(reverse_octets) + '.in-addr.arpa' + + @property + def max_prefixlen(self): + return self._max_prefixlen + + @property + def version(self): + return self._version + + +class IPv4Address(_BaseV4, _BaseAddress): + + """Represent and manipulate single IPv4 Addresses.""" + + __slots__ = ('_ip', '__weakref__') + + def __init__(self, address): + + """ + Args: + address: A string or integer representing the IP + + Additionally, an integer can be passed, so + IPv4Address('192.0.2.1') == IPv4Address(3221225985). + or, more generally + IPv4Address(int(IPv4Address('192.0.2.1'))) == + IPv4Address('192.0.2.1') + + Raises: + AddressValueError: If ipaddress isn't a valid IPv4 address. + + """ + # Efficient constructor from integer. + if isinstance(address, _compat_int_types): + self._check_int_address(address) + self._ip = address + return + + # Constructing from a packed address + if isinstance(address, bytes): + self._check_packed_address(address, 4) + bvs = _compat_bytes_to_byte_vals(address) + self._ip = _compat_int_from_byte_vals(bvs, 'big') + return + + # Assume input argument to be string or any object representation + # which converts into a formatted IP string. + addr_str = _compat_str(address) + if '/' in addr_str: + raise AddressValueError("Unexpected '/' in %r" % address) + self._ip = self._ip_int_from_string(addr_str) + + @property + def packed(self): + """The binary representation of this address.""" + return v4_int_to_packed(self._ip) + + @property + def is_reserved(self): + """Test if the address is otherwise IETF reserved. + + Returns: + A boolean, True if the address is within the + reserved IPv4 Network range. + + """ + return self in self._constants._reserved_network + + @property + def is_private(self): + """Test if this address is allocated for private networks. + + Returns: + A boolean, True if the address is reserved per + iana-ipv4-special-registry. + + """ + return any(self in net for net in self._constants._private_networks) + + @property + def is_global(self): + return ( + self not in self._constants._public_network and + not self.is_private) + + @property + def is_multicast(self): + """Test if the address is reserved for multicast use. + + Returns: + A boolean, True if the address is multicast. + See RFC 3171 for details. + + """ + return self in self._constants._multicast_network + + @property + def is_unspecified(self): + """Test if the address is unspecified. + + Returns: + A boolean, True if this is the unspecified address as defined in + RFC 5735 3. + + """ + return self == self._constants._unspecified_address + + @property + def is_loopback(self): + """Test if the address is a loopback address. + + Returns: + A boolean, True if the address is a loopback per RFC 3330. + + """ + return self in self._constants._loopback_network + + @property + def is_link_local(self): + """Test if the address is reserved for link-local. + + Returns: + A boolean, True if the address is link-local per RFC 3927. + + """ + return self in self._constants._linklocal_network + + +class IPv4Interface(IPv4Address): + + def __init__(self, address): + if isinstance(address, (bytes, _compat_int_types)): + IPv4Address.__init__(self, address) + self.network = IPv4Network(self._ip) + self._prefixlen = self._max_prefixlen + return + + if isinstance(address, tuple): + IPv4Address.__init__(self, address[0]) + if len(address) > 1: + self._prefixlen = int(address[1]) + else: + self._prefixlen = self._max_prefixlen + + self.network = IPv4Network(address, strict=False) + self.netmask = self.network.netmask + self.hostmask = self.network.hostmask + return + + addr = _split_optional_netmask(address) + IPv4Address.__init__(self, addr[0]) + + self.network = IPv4Network(address, strict=False) + self._prefixlen = self.network._prefixlen + + self.netmask = self.network.netmask + self.hostmask = self.network.hostmask + + def __str__(self): + return '%s/%d' % (self._string_from_ip_int(self._ip), + self.network.prefixlen) + + def __eq__(self, other): + address_equal = IPv4Address.__eq__(self, other) + if not address_equal or address_equal is NotImplemented: + return address_equal + try: + return self.network == other.network + except AttributeError: + # An interface with an associated network is NOT the + # same as an unassociated address. That's why the hash + # takes the extra info into account. + return False + + def __lt__(self, other): + address_less = IPv4Address.__lt__(self, other) + if address_less is NotImplemented: + return NotImplemented + try: + return (self.network < other.network or + self.network == other.network and address_less) + except AttributeError: + # We *do* allow addresses and interfaces to be sorted. The + # unassociated address is considered less than all interfaces. + return False + + def __hash__(self): + return self._ip ^ self._prefixlen ^ int(self.network.network_address) + + __reduce__ = _IPAddressBase.__reduce__ + + @property + def ip(self): + return IPv4Address(self._ip) + + @property + def with_prefixlen(self): + return '%s/%s' % (self._string_from_ip_int(self._ip), + self._prefixlen) + + @property + def with_netmask(self): + return '%s/%s' % (self._string_from_ip_int(self._ip), + self.netmask) + + @property + def with_hostmask(self): + return '%s/%s' % (self._string_from_ip_int(self._ip), + self.hostmask) + + +class IPv4Network(_BaseV4, _BaseNetwork): + + """This class represents and manipulates 32-bit IPv4 network + addresses.. + + Attributes: [examples for IPv4Network('192.0.2.0/27')] + .network_address: IPv4Address('192.0.2.0') + .hostmask: IPv4Address('0.0.0.31') + .broadcast_address: IPv4Address('192.0.2.32') + .netmask: IPv4Address('255.255.255.224') + .prefixlen: 27 + + """ + # Class to use when creating address objects + _address_class = IPv4Address + + def __init__(self, address, strict=True): + + """Instantiate a new IPv4 network object. + + Args: + address: A string or integer representing the IP [& network]. + '192.0.2.0/24' + '192.0.2.0/255.255.255.0' + '192.0.0.2/0.0.0.255' + are all functionally the same in IPv4. Similarly, + '192.0.2.1' + '192.0.2.1/255.255.255.255' + '192.0.2.1/32' + are also functionally equivalent. That is to say, failing to + provide a subnetmask will create an object with a mask of /32. + + If the mask (portion after the / in the argument) is given in + dotted quad form, it is treated as a netmask if it starts with a + non-zero field (e.g. /255.0.0.0 == /8) and as a hostmask if it + starts with a zero field (e.g. 0.255.255.255 == /8), with the + single exception of an all-zero mask which is treated as a + netmask == /0. If no mask is given, a default of /32 is used. + + Additionally, an integer can be passed, so + IPv4Network('192.0.2.1') == IPv4Network(3221225985) + or, more generally + IPv4Interface(int(IPv4Interface('192.0.2.1'))) == + IPv4Interface('192.0.2.1') + + Raises: + AddressValueError: If ipaddress isn't a valid IPv4 address. + NetmaskValueError: If the netmask isn't valid for + an IPv4 address. + ValueError: If strict is True and a network address is not + supplied. + + """ + _BaseNetwork.__init__(self, address) + + # Constructing from a packed address or integer + if isinstance(address, (_compat_int_types, bytes)): + self.network_address = IPv4Address(address) + self.netmask, self._prefixlen = self._make_netmask( + self._max_prefixlen) + # fixme: address/network test here. + return + + if isinstance(address, tuple): + if len(address) > 1: + arg = address[1] + else: + # We weren't given an address[1] + arg = self._max_prefixlen + self.network_address = IPv4Address(address[0]) + self.netmask, self._prefixlen = self._make_netmask(arg) + packed = int(self.network_address) + if packed & int(self.netmask) != packed: + if strict: + raise ValueError('%s has host bits set' % self) + else: + self.network_address = IPv4Address(packed & + int(self.netmask)) + return + + # Assume input argument to be string or any object representation + # which converts into a formatted IP prefix string. + addr = _split_optional_netmask(address) + self.network_address = IPv4Address(self._ip_int_from_string(addr[0])) + + if len(addr) == 2: + arg = addr[1] + else: + arg = self._max_prefixlen + self.netmask, self._prefixlen = self._make_netmask(arg) + + if strict: + if (IPv4Address(int(self.network_address) & int(self.netmask)) != + self.network_address): + raise ValueError('%s has host bits set' % self) + self.network_address = IPv4Address(int(self.network_address) & + int(self.netmask)) + + if self._prefixlen == (self._max_prefixlen - 1): + self.hosts = self.__iter__ + + @property + def is_global(self): + """Test if this address is allocated for public networks. + + Returns: + A boolean, True if the address is not reserved per + iana-ipv4-special-registry. + + """ + return (not (self.network_address in IPv4Network('100.64.0.0/10') and + self.broadcast_address in IPv4Network('100.64.0.0/10')) and + not self.is_private) + + +class _IPv4Constants(object): + + _linklocal_network = IPv4Network('169.254.0.0/16') + + _loopback_network = IPv4Network('127.0.0.0/8') + + _multicast_network = IPv4Network('224.0.0.0/4') + + _public_network = IPv4Network('100.64.0.0/10') + + _private_networks = [ + IPv4Network('0.0.0.0/8'), + IPv4Network('10.0.0.0/8'), + IPv4Network('127.0.0.0/8'), + IPv4Network('169.254.0.0/16'), + IPv4Network('172.16.0.0/12'), + IPv4Network('192.0.0.0/29'), + IPv4Network('192.0.0.170/31'), + IPv4Network('192.0.2.0/24'), + IPv4Network('192.168.0.0/16'), + IPv4Network('198.18.0.0/15'), + IPv4Network('198.51.100.0/24'), + IPv4Network('203.0.113.0/24'), + IPv4Network('240.0.0.0/4'), + IPv4Network('255.255.255.255/32'), + ] + + _reserved_network = IPv4Network('240.0.0.0/4') + + _unspecified_address = IPv4Address('0.0.0.0') + + +IPv4Address._constants = _IPv4Constants + + +class _BaseV6(object): + + """Base IPv6 object. + + The following methods are used by IPv6 objects in both single IP + addresses and networks. + + """ + + __slots__ = () + _version = 6 + _ALL_ONES = (2 ** IPV6LENGTH) - 1 + _HEXTET_COUNT = 8 + _HEX_DIGITS = frozenset('0123456789ABCDEFabcdef') + _max_prefixlen = IPV6LENGTH + + # There are only a bunch of valid v6 netmasks, so we cache them all + # when constructed (see _make_netmask()). + _netmask_cache = {} + + @classmethod + def _make_netmask(cls, arg): + """Make a (netmask, prefix_len) tuple from the given argument. + + Argument can be: + - an integer (the prefix length) + - a string representing the prefix length (e.g. "24") + - a string representing the prefix netmask (e.g. "255.255.255.0") + """ + if arg not in cls._netmask_cache: + if isinstance(arg, _compat_int_types): + prefixlen = arg + else: + prefixlen = cls._prefix_from_prefix_string(arg) + netmask = IPv6Address(cls._ip_int_from_prefix(prefixlen)) + cls._netmask_cache[arg] = netmask, prefixlen + return cls._netmask_cache[arg] + + @classmethod + def _ip_int_from_string(cls, ip_str): + """Turn an IPv6 ip_str into an integer. + + Args: + ip_str: A string, the IPv6 ip_str. + + Returns: + An int, the IPv6 address + + Raises: + AddressValueError: if ip_str isn't a valid IPv6 Address. + + """ + if not ip_str: + raise AddressValueError('Address cannot be empty') + + parts = ip_str.split(':') + + # An IPv6 address needs at least 2 colons (3 parts). + _min_parts = 3 + if len(parts) < _min_parts: + msg = "At least %d parts expected in %r" % (_min_parts, ip_str) + raise AddressValueError(msg) + + # If the address has an IPv4-style suffix, convert it to hexadecimal. + if '.' in parts[-1]: + try: + ipv4_int = IPv4Address(parts.pop())._ip + except AddressValueError as exc: + raise AddressValueError("%s in %r" % (exc, ip_str)) + parts.append('%x' % ((ipv4_int >> 16) & 0xFFFF)) + parts.append('%x' % (ipv4_int & 0xFFFF)) + + # An IPv6 address can't have more than 8 colons (9 parts). + # The extra colon comes from using the "::" notation for a single + # leading or trailing zero part. + _max_parts = cls._HEXTET_COUNT + 1 + if len(parts) > _max_parts: + msg = "At most %d colons permitted in %r" % ( + _max_parts - 1, ip_str) + raise AddressValueError(msg) + + # Disregarding the endpoints, find '::' with nothing in between. + # This indicates that a run of zeroes has been skipped. + skip_index = None + for i in _compat_range(1, len(parts) - 1): + if not parts[i]: + if skip_index is not None: + # Can't have more than one '::' + msg = "At most one '::' permitted in %r" % ip_str + raise AddressValueError(msg) + skip_index = i + + # parts_hi is the number of parts to copy from above/before the '::' + # parts_lo is the number of parts to copy from below/after the '::' + if skip_index is not None: + # If we found a '::', then check if it also covers the endpoints. + parts_hi = skip_index + parts_lo = len(parts) - skip_index - 1 + if not parts[0]: + parts_hi -= 1 + if parts_hi: + msg = "Leading ':' only permitted as part of '::' in %r" + raise AddressValueError(msg % ip_str) # ^: requires ^:: + if not parts[-1]: + parts_lo -= 1 + if parts_lo: + msg = "Trailing ':' only permitted as part of '::' in %r" + raise AddressValueError(msg % ip_str) # :$ requires ::$ + parts_skipped = cls._HEXTET_COUNT - (parts_hi + parts_lo) + if parts_skipped < 1: + msg = "Expected at most %d other parts with '::' in %r" + raise AddressValueError(msg % (cls._HEXTET_COUNT - 1, ip_str)) + else: + # Otherwise, allocate the entire address to parts_hi. The + # endpoints could still be empty, but _parse_hextet() will check + # for that. + if len(parts) != cls._HEXTET_COUNT: + msg = "Exactly %d parts expected without '::' in %r" + raise AddressValueError(msg % (cls._HEXTET_COUNT, ip_str)) + if not parts[0]: + msg = "Leading ':' only permitted as part of '::' in %r" + raise AddressValueError(msg % ip_str) # ^: requires ^:: + if not parts[-1]: + msg = "Trailing ':' only permitted as part of '::' in %r" + raise AddressValueError(msg % ip_str) # :$ requires ::$ + parts_hi = len(parts) + parts_lo = 0 + parts_skipped = 0 + + try: + # Now, parse the hextets into a 128-bit integer. + ip_int = 0 + for i in range(parts_hi): + ip_int <<= 16 + ip_int |= cls._parse_hextet(parts[i]) + ip_int <<= 16 * parts_skipped + for i in range(-parts_lo, 0): + ip_int <<= 16 + ip_int |= cls._parse_hextet(parts[i]) + return ip_int + except ValueError as exc: + raise AddressValueError("%s in %r" % (exc, ip_str)) + + @classmethod + def _parse_hextet(cls, hextet_str): + """Convert an IPv6 hextet string into an integer. + + Args: + hextet_str: A string, the number to parse. + + Returns: + The hextet as an integer. + + Raises: + ValueError: if the input isn't strictly a hex number from + [0..FFFF]. + + """ + # Whitelist the characters, since int() allows a lot of bizarre stuff. + if not cls._HEX_DIGITS.issuperset(hextet_str): + raise ValueError("Only hex digits permitted in %r" % hextet_str) + # We do the length check second, since the invalid character error + # is likely to be more informative for the user + if len(hextet_str) > 4: + msg = "At most 4 characters permitted in %r" + raise ValueError(msg % hextet_str) + # Length check means we can skip checking the integer value + return int(hextet_str, 16) + + @classmethod + def _compress_hextets(cls, hextets): + """Compresses a list of hextets. + + Compresses a list of strings, replacing the longest continuous + sequence of "0" in the list with "" and adding empty strings at + the beginning or at the end of the string such that subsequently + calling ":".join(hextets) will produce the compressed version of + the IPv6 address. + + Args: + hextets: A list of strings, the hextets to compress. + + Returns: + A list of strings. + + """ + best_doublecolon_start = -1 + best_doublecolon_len = 0 + doublecolon_start = -1 + doublecolon_len = 0 + for index, hextet in enumerate(hextets): + if hextet == '0': + doublecolon_len += 1 + if doublecolon_start == -1: + # Start of a sequence of zeros. + doublecolon_start = index + if doublecolon_len > best_doublecolon_len: + # This is the longest sequence of zeros so far. + best_doublecolon_len = doublecolon_len + best_doublecolon_start = doublecolon_start + else: + doublecolon_len = 0 + doublecolon_start = -1 + + if best_doublecolon_len > 1: + best_doublecolon_end = (best_doublecolon_start + + best_doublecolon_len) + # For zeros at the end of the address. + if best_doublecolon_end == len(hextets): + hextets += [''] + hextets[best_doublecolon_start:best_doublecolon_end] = [''] + # For zeros at the beginning of the address. + if best_doublecolon_start == 0: + hextets = [''] + hextets + + return hextets + + @classmethod + def _string_from_ip_int(cls, ip_int=None): + """Turns a 128-bit integer into hexadecimal notation. + + Args: + ip_int: An integer, the IP address. + + Returns: + A string, the hexadecimal representation of the address. + + Raises: + ValueError: The address is bigger than 128 bits of all ones. + + """ + if ip_int is None: + ip_int = int(cls._ip) + + if ip_int > cls._ALL_ONES: + raise ValueError('IPv6 address is too large') + + hex_str = '%032x' % ip_int + hextets = ['%x' % int(hex_str[x:x + 4], 16) for x in range(0, 32, 4)] + + hextets = cls._compress_hextets(hextets) + return ':'.join(hextets) + + def _explode_shorthand_ip_string(self): + """Expand a shortened IPv6 address. + + Args: + ip_str: A string, the IPv6 address. + + Returns: + A string, the expanded IPv6 address. + + """ + if isinstance(self, IPv6Network): + ip_str = _compat_str(self.network_address) + elif isinstance(self, IPv6Interface): + ip_str = _compat_str(self.ip) + else: + ip_str = _compat_str(self) + + ip_int = self._ip_int_from_string(ip_str) + hex_str = '%032x' % ip_int + parts = [hex_str[x:x + 4] for x in range(0, 32, 4)] + if isinstance(self, (_BaseNetwork, IPv6Interface)): + return '%s/%d' % (':'.join(parts), self._prefixlen) + return ':'.join(parts) + + def _reverse_pointer(self): + """Return the reverse DNS pointer name for the IPv6 address. + + This implements the method described in RFC3596 2.5. + + """ + reverse_chars = self.exploded[::-1].replace(':', '') + return '.'.join(reverse_chars) + '.ip6.arpa' + + @property + def max_prefixlen(self): + return self._max_prefixlen + + @property + def version(self): + return self._version + + +class IPv6Address(_BaseV6, _BaseAddress): + + """Represent and manipulate single IPv6 Addresses.""" + + __slots__ = ('_ip', '__weakref__') + + def __init__(self, address): + """Instantiate a new IPv6 address object. + + Args: + address: A string or integer representing the IP + + Additionally, an integer can be passed, so + IPv6Address('2001:db8::') == + IPv6Address(42540766411282592856903984951653826560) + or, more generally + IPv6Address(int(IPv6Address('2001:db8::'))) == + IPv6Address('2001:db8::') + + Raises: + AddressValueError: If address isn't a valid IPv6 address. + + """ + # Efficient constructor from integer. + if isinstance(address, _compat_int_types): + self._check_int_address(address) + self._ip = address + return + + # Constructing from a packed address + if isinstance(address, bytes): + self._check_packed_address(address, 16) + bvs = _compat_bytes_to_byte_vals(address) + self._ip = _compat_int_from_byte_vals(bvs, 'big') + return + + # Assume input argument to be string or any object representation + # which converts into a formatted IP string. + addr_str = _compat_str(address) + if '/' in addr_str: + raise AddressValueError("Unexpected '/' in %r" % address) + self._ip = self._ip_int_from_string(addr_str) + + @property + def packed(self): + """The binary representation of this address.""" + return v6_int_to_packed(self._ip) + + @property + def is_multicast(self): + """Test if the address is reserved for multicast use. + + Returns: + A boolean, True if the address is a multicast address. + See RFC 2373 2.7 for details. + + """ + return self in self._constants._multicast_network + + @property + def is_reserved(self): + """Test if the address is otherwise IETF reserved. + + Returns: + A boolean, True if the address is within one of the + reserved IPv6 Network ranges. + + """ + return any(self in x for x in self._constants._reserved_networks) + + @property + def is_link_local(self): + """Test if the address is reserved for link-local. + + Returns: + A boolean, True if the address is reserved per RFC 4291. + + """ + return self in self._constants._linklocal_network + + @property + def is_site_local(self): + """Test if the address is reserved for site-local. + + Note that the site-local address space has been deprecated by RFC 3879. + Use is_private to test if this address is in the space of unique local + addresses as defined by RFC 4193. + + Returns: + A boolean, True if the address is reserved per RFC 3513 2.5.6. + + """ + return self in self._constants._sitelocal_network + + @property + def is_private(self): + """Test if this address is allocated for private networks. + + Returns: + A boolean, True if the address is reserved per + iana-ipv6-special-registry. + + """ + return any(self in net for net in self._constants._private_networks) + + @property + def is_global(self): + """Test if this address is allocated for public networks. + + Returns: + A boolean, true if the address is not reserved per + iana-ipv6-special-registry. + + """ + return not self.is_private + + @property + def is_unspecified(self): + """Test if the address is unspecified. + + Returns: + A boolean, True if this is the unspecified address as defined in + RFC 2373 2.5.2. + + """ + return self._ip == 0 + + @property + def is_loopback(self): + """Test if the address is a loopback address. + + Returns: + A boolean, True if the address is a loopback address as defined in + RFC 2373 2.5.3. + + """ + return self._ip == 1 + + @property + def ipv4_mapped(self): + """Return the IPv4 mapped address. + + Returns: + If the IPv6 address is a v4 mapped address, return the + IPv4 mapped address. Return None otherwise. + + """ + if (self._ip >> 32) != 0xFFFF: + return None + return IPv4Address(self._ip & 0xFFFFFFFF) + + @property + def teredo(self): + """Tuple of embedded teredo IPs. + + Returns: + Tuple of the (server, client) IPs or None if the address + doesn't appear to be a teredo address (doesn't start with + 2001::/32) + + """ + if (self._ip >> 96) != 0x20010000: + return None + return (IPv4Address((self._ip >> 64) & 0xFFFFFFFF), + IPv4Address(~self._ip & 0xFFFFFFFF)) + + @property + def sixtofour(self): + """Return the IPv4 6to4 embedded address. + + Returns: + The IPv4 6to4-embedded address if present or None if the + address doesn't appear to contain a 6to4 embedded address. + + """ + if (self._ip >> 112) != 0x2002: + return None + return IPv4Address((self._ip >> 80) & 0xFFFFFFFF) + + +class IPv6Interface(IPv6Address): + + def __init__(self, address): + if isinstance(address, (bytes, _compat_int_types)): + IPv6Address.__init__(self, address) + self.network = IPv6Network(self._ip) + self._prefixlen = self._max_prefixlen + return + if isinstance(address, tuple): + IPv6Address.__init__(self, address[0]) + if len(address) > 1: + self._prefixlen = int(address[1]) + else: + self._prefixlen = self._max_prefixlen + self.network = IPv6Network(address, strict=False) + self.netmask = self.network.netmask + self.hostmask = self.network.hostmask + return + + addr = _split_optional_netmask(address) + IPv6Address.__init__(self, addr[0]) + self.network = IPv6Network(address, strict=False) + self.netmask = self.network.netmask + self._prefixlen = self.network._prefixlen + self.hostmask = self.network.hostmask + + def __str__(self): + return '%s/%d' % (self._string_from_ip_int(self._ip), + self.network.prefixlen) + + def __eq__(self, other): + address_equal = IPv6Address.__eq__(self, other) + if not address_equal or address_equal is NotImplemented: + return address_equal + try: + return self.network == other.network + except AttributeError: + # An interface with an associated network is NOT the + # same as an unassociated address. That's why the hash + # takes the extra info into account. + return False + + def __lt__(self, other): + address_less = IPv6Address.__lt__(self, other) + if address_less is NotImplemented: + return NotImplemented + try: + return (self.network < other.network or + self.network == other.network and address_less) + except AttributeError: + # We *do* allow addresses and interfaces to be sorted. The + # unassociated address is considered less than all interfaces. + return False + + def __hash__(self): + return self._ip ^ self._prefixlen ^ int(self.network.network_address) + + __reduce__ = _IPAddressBase.__reduce__ + + @property + def ip(self): + return IPv6Address(self._ip) + + @property + def with_prefixlen(self): + return '%s/%s' % (self._string_from_ip_int(self._ip), + self._prefixlen) + + @property + def with_netmask(self): + return '%s/%s' % (self._string_from_ip_int(self._ip), + self.netmask) + + @property + def with_hostmask(self): + return '%s/%s' % (self._string_from_ip_int(self._ip), + self.hostmask) + + @property + def is_unspecified(self): + return self._ip == 0 and self.network.is_unspecified + + @property + def is_loopback(self): + return self._ip == 1 and self.network.is_loopback + + +class IPv6Network(_BaseV6, _BaseNetwork): + + """This class represents and manipulates 128-bit IPv6 networks. + + Attributes: [examples for IPv6('2001:db8::1000/124')] + .network_address: IPv6Address('2001:db8::1000') + .hostmask: IPv6Address('::f') + .broadcast_address: IPv6Address('2001:db8::100f') + .netmask: IPv6Address('ffff:ffff:ffff:ffff:ffff:ffff:ffff:fff0') + .prefixlen: 124 + + """ + + # Class to use when creating address objects + _address_class = IPv6Address + + def __init__(self, address, strict=True): + """Instantiate a new IPv6 Network object. + + Args: + address: A string or integer representing the IPv6 network or the + IP and prefix/netmask. + '2001:db8::/128' + '2001:db8:0000:0000:0000:0000:0000:0000/128' + '2001:db8::' + are all functionally the same in IPv6. That is to say, + failing to provide a subnetmask will create an object with + a mask of /128. + + Additionally, an integer can be passed, so + IPv6Network('2001:db8::') == + IPv6Network(42540766411282592856903984951653826560) + or, more generally + IPv6Network(int(IPv6Network('2001:db8::'))) == + IPv6Network('2001:db8::') + + strict: A boolean. If true, ensure that we have been passed + A true network address, eg, 2001:db8::1000/124 and not an + IP address on a network, eg, 2001:db8::1/124. + + Raises: + AddressValueError: If address isn't a valid IPv6 address. + NetmaskValueError: If the netmask isn't valid for + an IPv6 address. + ValueError: If strict was True and a network address was not + supplied. + + """ + _BaseNetwork.__init__(self, address) + + # Efficient constructor from integer or packed address + if isinstance(address, (bytes, _compat_int_types)): + self.network_address = IPv6Address(address) + self.netmask, self._prefixlen = self._make_netmask( + self._max_prefixlen) + return + + if isinstance(address, tuple): + if len(address) > 1: + arg = address[1] + else: + arg = self._max_prefixlen + self.netmask, self._prefixlen = self._make_netmask(arg) + self.network_address = IPv6Address(address[0]) + packed = int(self.network_address) + if packed & int(self.netmask) != packed: + if strict: + raise ValueError('%s has host bits set' % self) + else: + self.network_address = IPv6Address(packed & + int(self.netmask)) + return + + # Assume input argument to be string or any object representation + # which converts into a formatted IP prefix string. + addr = _split_optional_netmask(address) + + self.network_address = IPv6Address(self._ip_int_from_string(addr[0])) + + if len(addr) == 2: + arg = addr[1] + else: + arg = self._max_prefixlen + self.netmask, self._prefixlen = self._make_netmask(arg) + + if strict: + if (IPv6Address(int(self.network_address) & int(self.netmask)) != + self.network_address): + raise ValueError('%s has host bits set' % self) + self.network_address = IPv6Address(int(self.network_address) & + int(self.netmask)) + + if self._prefixlen == (self._max_prefixlen - 1): + self.hosts = self.__iter__ + + def hosts(self): + """Generate Iterator over usable hosts in a network. + + This is like __iter__ except it doesn't return the + Subnet-Router anycast address. + + """ + network = int(self.network_address) + broadcast = int(self.broadcast_address) + for x in _compat_range(network + 1, broadcast + 1): + yield self._address_class(x) + + @property + def is_site_local(self): + """Test if the address is reserved for site-local. + + Note that the site-local address space has been deprecated by RFC 3879. + Use is_private to test if this address is in the space of unique local + addresses as defined by RFC 4193. + + Returns: + A boolean, True if the address is reserved per RFC 3513 2.5.6. + + """ + return (self.network_address.is_site_local and + self.broadcast_address.is_site_local) + + +class _IPv6Constants(object): + + _linklocal_network = IPv6Network('fe80::/10') + + _multicast_network = IPv6Network('ff00::/8') + + _private_networks = [ + IPv6Network('::1/128'), + IPv6Network('::/128'), + IPv6Network('::ffff:0:0/96'), + IPv6Network('100::/64'), + IPv6Network('2001::/23'), + IPv6Network('2001:2::/48'), + IPv6Network('2001:db8::/32'), + IPv6Network('2001:10::/28'), + IPv6Network('fc00::/7'), + IPv6Network('fe80::/10'), + ] + + _reserved_networks = [ + IPv6Network('::/8'), IPv6Network('100::/8'), + IPv6Network('200::/7'), IPv6Network('400::/6'), + IPv6Network('800::/5'), IPv6Network('1000::/4'), + IPv6Network('4000::/3'), IPv6Network('6000::/3'), + IPv6Network('8000::/3'), IPv6Network('A000::/3'), + IPv6Network('C000::/3'), IPv6Network('E000::/4'), + IPv6Network('F000::/5'), IPv6Network('F800::/6'), + IPv6Network('FE00::/9'), + ] + + _sitelocal_network = IPv6Network('fec0::/10') + + +IPv6Address._constants = _IPv6Constants diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__init__.py new file mode 100644 index 0000000..a6f44a5 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__init__.py @@ -0,0 +1,347 @@ +# -*- coding: utf-8 -*- + +""" +lockfile.py - Platform-independent advisory file locks. + +Requires Python 2.5 unless you apply 2.4.diff +Locking is done on a per-thread basis instead of a per-process basis. + +Usage: + +>>> lock = LockFile('somefile') +>>> try: +... lock.acquire() +... except AlreadyLocked: +... print 'somefile', 'is locked already.' +... except LockFailed: +... print 'somefile', 'can\\'t be locked.' +... else: +... print 'got lock' +got lock +>>> print lock.is_locked() +True +>>> lock.release() + +>>> lock = LockFile('somefile') +>>> print lock.is_locked() +False +>>> with lock: +... print lock.is_locked() +True +>>> print lock.is_locked() +False + +>>> lock = LockFile('somefile') +>>> # It is okay to lock twice from the same thread... +>>> with lock: +... lock.acquire() +... +>>> # Though no counter is kept, so you can't unlock multiple times... +>>> print lock.is_locked() +False + +Exceptions: + + Error - base class for other exceptions + LockError - base class for all locking exceptions + AlreadyLocked - Another thread or process already holds the lock + LockFailed - Lock failed for some other reason + UnlockError - base class for all unlocking exceptions + AlreadyUnlocked - File was not locked. + NotMyLock - File was locked but not by the current thread/process +""" + +from __future__ import absolute_import + +import functools +import os +import socket +import threading +import warnings + +# Work with PEP8 and non-PEP8 versions of threading module. +if not hasattr(threading, "current_thread"): + threading.current_thread = threading.currentThread +if not hasattr(threading.Thread, "get_name"): + threading.Thread.get_name = threading.Thread.getName + +__all__ = ['Error', 'LockError', 'LockTimeout', 'AlreadyLocked', + 'LockFailed', 'UnlockError', 'NotLocked', 'NotMyLock', + 'LinkFileLock', 'MkdirFileLock', 'SQLiteFileLock', + 'LockBase', 'locked'] + + +class Error(Exception): + """ + Base class for other exceptions. + + >>> try: + ... raise Error + ... except Exception: + ... pass + """ + pass + + +class LockError(Error): + """ + Base class for error arising from attempts to acquire the lock. + + >>> try: + ... raise LockError + ... except Error: + ... pass + """ + pass + + +class LockTimeout(LockError): + """Raised when lock creation fails within a user-defined period of time. + + >>> try: + ... raise LockTimeout + ... except LockError: + ... pass + """ + pass + + +class AlreadyLocked(LockError): + """Some other thread/process is locking the file. + + >>> try: + ... raise AlreadyLocked + ... except LockError: + ... pass + """ + pass + + +class LockFailed(LockError): + """Lock file creation failed for some other reason. + + >>> try: + ... raise LockFailed + ... except LockError: + ... pass + """ + pass + + +class UnlockError(Error): + """ + Base class for errors arising from attempts to release the lock. + + >>> try: + ... raise UnlockError + ... except Error: + ... pass + """ + pass + + +class NotLocked(UnlockError): + """Raised when an attempt is made to unlock an unlocked file. + + >>> try: + ... raise NotLocked + ... except UnlockError: + ... pass + """ + pass + + +class NotMyLock(UnlockError): + """Raised when an attempt is made to unlock a file someone else locked. + + >>> try: + ... raise NotMyLock + ... except UnlockError: + ... pass + """ + pass + + +class _SharedBase(object): + def __init__(self, path): + self.path = path + + def acquire(self, timeout=None): + """ + Acquire the lock. + + * If timeout is omitted (or None), wait forever trying to lock the + file. + + * If timeout > 0, try to acquire the lock for that many seconds. If + the lock period expires and the file is still locked, raise + LockTimeout. + + * If timeout <= 0, raise AlreadyLocked immediately if the file is + already locked. + """ + raise NotImplemented("implement in subclass") + + def release(self): + """ + Release the lock. + + If the file is not locked, raise NotLocked. + """ + raise NotImplemented("implement in subclass") + + def __enter__(self): + """ + Context manager support. + """ + self.acquire() + return self + + def __exit__(self, *_exc): + """ + Context manager support. + """ + self.release() + + def __repr__(self): + return "<%s: %r>" % (self.__class__.__name__, self.path) + + +class LockBase(_SharedBase): + """Base class for platform-specific lock classes.""" + def __init__(self, path, threaded=True, timeout=None): + """ + >>> lock = LockBase('somefile') + >>> lock = LockBase('somefile', threaded=False) + """ + super(LockBase, self).__init__(path) + self.lock_file = os.path.abspath(path) + ".lock" + self.hostname = socket.gethostname() + self.pid = os.getpid() + if threaded: + t = threading.current_thread() + # Thread objects in Python 2.4 and earlier do not have ident + # attrs. Worm around that. + ident = getattr(t, "ident", hash(t)) + self.tname = "-%x" % (ident & 0xffffffff) + else: + self.tname = "" + dirname = os.path.dirname(self.lock_file) + + # unique name is mostly about the current process, but must + # also contain the path -- otherwise, two adjacent locked + # files conflict (one file gets locked, creating lock-file and + # unique file, the other one gets locked, creating lock-file + # and overwriting the already existing lock-file, then one + # gets unlocked, deleting both lock-file and unique file, + # finally the last lock errors out upon releasing. + self.unique_name = os.path.join(dirname, + "%s%s.%s%s" % (self.hostname, + self.tname, + self.pid, + hash(self.path))) + self.timeout = timeout + + def is_locked(self): + """ + Tell whether or not the file is locked. + """ + raise NotImplemented("implement in subclass") + + def i_am_locking(self): + """ + Return True if this object is locking the file. + """ + raise NotImplemented("implement in subclass") + + def break_lock(self): + """ + Remove a lock. Useful if a locking thread failed to unlock. + """ + raise NotImplemented("implement in subclass") + + def __repr__(self): + return "<%s: %r -- %r>" % (self.__class__.__name__, self.unique_name, + self.path) + + +def _fl_helper(cls, mod, *args, **kwds): + warnings.warn("Import from %s module instead of lockfile package" % mod, + DeprecationWarning, stacklevel=2) + # This is a bit funky, but it's only for awhile. The way the unit tests + # are constructed this function winds up as an unbound method, so it + # actually takes three args, not two. We want to toss out self. + if not isinstance(args[0], str): + # We are testing, avoid the first arg + args = args[1:] + if len(args) == 1 and not kwds: + kwds["threaded"] = True + return cls(*args, **kwds) + + +def LinkFileLock(*args, **kwds): + """Factory function provided for backwards compatibility. + + Do not use in new code. Instead, import LinkLockFile from the + lockfile.linklockfile module. + """ + from . import linklockfile + return _fl_helper(linklockfile.LinkLockFile, "lockfile.linklockfile", + *args, **kwds) + + +def MkdirFileLock(*args, **kwds): + """Factory function provided for backwards compatibility. + + Do not use in new code. Instead, import MkdirLockFile from the + lockfile.mkdirlockfile module. + """ + from . import mkdirlockfile + return _fl_helper(mkdirlockfile.MkdirLockFile, "lockfile.mkdirlockfile", + *args, **kwds) + + +def SQLiteFileLock(*args, **kwds): + """Factory function provided for backwards compatibility. + + Do not use in new code. Instead, import SQLiteLockFile from the + lockfile.mkdirlockfile module. + """ + from . import sqlitelockfile + return _fl_helper(sqlitelockfile.SQLiteLockFile, "lockfile.sqlitelockfile", + *args, **kwds) + + +def locked(path, timeout=None): + """Decorator which enables locks for decorated function. + + Arguments: + - path: path for lockfile. + - timeout (optional): Timeout for acquiring lock. + + Usage: + @locked('/var/run/myname', timeout=0) + def myname(...): + ... + """ + def decor(func): + @functools.wraps(func) + def wrapper(*args, **kwargs): + lock = FileLock(path, timeout=timeout) + lock.acquire() + try: + return func(*args, **kwargs) + finally: + lock.release() + return wrapper + return decor + + +if hasattr(os, "link"): + from . import linklockfile as _llf + LockFile = _llf.LinkLockFile +else: + from . import mkdirlockfile as _mlf + LockFile = _mlf.MkdirLockFile + +FileLock = LockFile diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0646255651ad9c1165cfcbba95b760f1f1b435d1 GIT binary patch literal 9817 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 A5&!@I literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/linklockfile.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/linklockfile.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0525f5fd78c618ead7e5f9de7124fe22b34424d7 GIT binary patch literal 2325 zcma)7&5zSY6rZsj+sS6b0ukk-ty~HVk$`Mb1)?eor7fru4V9LvU{$ibnaQpbe`IGS zfwjV=@CR_J)Jm0-BT^5&_FwU}z3i1k4?RHN8)sn`fz*-a`OWA1z4w0e{Qcr$jX?Y7 zk6HL5Xn)~gZ?j-<9lHDu1S5>bB%wZ~s2j228~SVdCNr58TS>*QB(`rSj_)L{?<Q5h zn$-LnCASExF#8E%Hm^K3{RL*Mk(RRqw~`hu4utD6i${tFQ8LVg>g-TlunYHg)*ajk zB`<2I-3+6cv!dF`6b|R=x7#=<7Es=e5}u7zvG_$Sc*yh$XI-?jx0x`w4qbi*f)k%I z0=`i2V-Y=hLVc^m>sOe=+$Y4hS(Vk`>#zk@hp($WXcYC^Q997r09yVVYF^mwaw$EP zd7;;XX>TN>bi)f(mPB1|D6%0JYTL_tUJQrNUTj^c)jVjctE*m&7hLuB-g@?o%o2_l zooW5gedj#2iT-nT^=24LUY_f84RCk2VQyXMUqY821UzplG9i7+=woAQ%m^hvko2TQ zlsTx0OBBYGD2o}m=LmUBf1>wEYTP3eh~A(ozM9a~g0;#cs_dyfBae*vN*})Fz!Lol z%v^?fu;ff#ya#%9W@t-4gQeP__LPd|+?F$4z&$hCuRk&;ke7iWe!magTidnyytFhi z;P&Tm=VG~^;yPOVTQyh(<_?s2(}r4N_Ukd6K3HM|t2NM^6XYo!)|op4j^8I+{d?Nl zRv&G)s-41ku$~|8X&PdFyAWi>z0*=4VRtaR`SP5D-h(hwn0MqscWV?0US_wK2{@5A zPfIV7URV-UFLAbm?{VYTU$Fgot#zodfGlaTFiNAX5f9QZ;YFnzXYeANZ|;08L?%Q9 zjueiXGv7j`Ffv(K$gZM_j0%uFg>z?3pC~M;LRGj@1*zU+kMvg{9SUn00(q*aR%Fci zuw}sk9{0o{oO5}~0&T<AhvYLNJXrX5+#ZT(4B=>xL(%SKG2=qEuRLsT1Xso)$<vFy z{>tX&!#oe-E0@+c#R{~Iw0*ZdjE3i<6fni{`IVJR<L&V$Bb?Md7=yt~w9yUpqK$}m z2N#Chg)<NCK>#5yf*{nOP1>MM;}CV}5_K&cFBuK$nzq@bb(pmb>xFAs)Ou+fr_8*$ z_q|=1U)aT*?l#o1YUtO3)o?<lWJcss1@8qIWy~4&zB2p9RKJ56m7gkGznA%{GN%sg ztsuMRx@MYYm)XgeN=l@en$saaQO=;hoSpO5N6N$1^=&WVt!hz?WKgaN8!(9zD4HM& zn?H=ClHvf)I4F*zI0E7s6(6APy%HaRRycyk97^qF7|1#ZqNCS<NY?2a5t?s(cZ3>n zT*2F&Vzn@5bPcR_T9(FEqC5pVG#qgnHSd)`Fydnn*Pu&Xv1oo|UxHqF{cZqf;c%Iv zY*|rAi3vcg8O6~QO9JS9o6!OOh>VUvhg*)e`zA;o!lSS*j-hx9+@c-@VWKku5B>)1 zlKQ_20j$3?jHMU(vHke>?0&ZkAHqF*V<?U*qL~Hp#6R#F5ocgatMVpbOmdm-w_&ZV zL(v*&u(uE?{s#yoIe%{-#@D-AkhyB%2D<tLK~W2WBx9qPgI*7Utx*_bU4oGl1T5<Y zfjEf>mQi3L1tvqZP<Z==&NYS#yCxkxO}n=2x~}O~1kSeVXs|a@BLOA^@<AL%p=nM8 m!q+9Rd;yy3SjTh)(>J`$XyJZd`ml-*TjGJb;ZoP|tp5NOvn$5{ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/mkdirlockfile.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/mkdirlockfile.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..23fb712a69ddc5d8141814afd6fc640acfa6861c GIT binary patch literal 2693 zcmb7F&2JM&6rb5IuN~Vl5FmUUR;Ynmg*YHeg;Y|YKvfCcN=a3)RIN6ib+Yz;I5Xpr zSmx63C-hQI_K{n!{RjFNaGF!4p1AhVLl4mRW^G6!ICNI?=FPs@o!`9odvAWIR7wQe zKfg_a#WEp(;pAYmU~(I}U?3P_G$sjc(ZpyO6z4{4woE-*ElZDf%hsdQa+t}ixRAIl zHz~G?NvTyz=2~+}xm8XotqLXI5N0#yIblxd?whSDGuBAG@EUd^bwkYu8zPGbGW4UQ zpK+;N7VShL%F^a*ic1{jKFr#^yMYK*3AG176o*U|o0-JvRDHCE6E%l&JxaoCAXVi~ z%)@|bOUT-|<H2Ua<TiA14@5{>l#!OfD4ev$EM`BaaMokYVFl1^=Ca~*0;espIT#D9 z%qlRttjgwLEHV>LbzD^*^;pC;Oh7rjfST6<)!W$f+JHtz>82NWuqbTHjPEV4H{0m` zSwp=5{cGsr1_(*UbVNpUWQ@#-MTs=J=GYpMuFc?m*MVMu?sm*mWMYhnU(^mZhoa<7 z+v@777bB2c-XVCOUJ_XnBDzcU|FihAC%4eCA-nY;h(-AR<6&V*EH8;A(X5xa4d|8Y z`%xN6-&aN^l+_R9ma@88l&T^^@^N?NZe>EIK@uuEAIyHl)Z8GAwg;h)hPtIJ5yl-} z)jyr>uL?4c^-IDR!Se6ZMxRGJfeafv0dI7&n1x(4ZtgZV{hK>H8K&1d-IcAa-Qm!W zZ{FD0;w#WL)5dzEAN8+9sgOY&Us+kXv9q^xb$~B*_jkgSWxRoq5pg5IFwbVo{XGt8 zMG%`nLF}4Yq7JpF^~QQTJax$H%QKI(4O}{H=qwkyj(ZiDKLR@Tio86cDMp(-qmqv4 zggi5*mTNH5p2e>LGw2ty_b$K9jAv$Al|W@!VV)!VFdx?Blr<Ad$&V!c#Uj$_mH6M3 z;3ErTcS4wThCH)IR<|gN-BQose@e4EH!j2el?ml9o<K2Jn<0CZ;~5!%;nft&AF|49 zSUq=&?9-nqpqOXK(CHk$r~!)s0a%VP<gJ~rd_uOHkBK~vJ27|P7@wE`D%@?miLzd7 zax4d%FMh@L`&X~AqH)ZY;l*jbdryN%r<csUpuIhS6w7Jf$+)*9h6_u=i-Z^CMM0ZF zHayYM^~8gZbbf}gR2fe<>I?id{9RedFl8peF0bI+)}iM$)C=FO-RC^x$`pG-x#4ab z$ll469de##%DI34@waR1IcJ@4Hxg3t1^AE`QQ!%bE#ffja|d-R>xZeb+i?atW%HA` zNMmq;eZIzF;Te?)|JQua#Top#Fg@})n275j2t7_+TBEMvQpc#82Iy5<re&jQICKGQ zmSMedZ6N7e$0(Z%MvV?n9;WK_pKWygtf7vjQ#18@P)1}-CPXYs;3LG(n8yA*aL33i z)r5-c(qT}YW>#RMjy`e$bQdf|)OD=Q=CGE>D$V39PUrGBm~$b!>}?FBhgK-7P#sFD z7zsbOaV($O=Q?2g6P#+VV}2=Tkj7EkQ#MZ^g>@WX(%jcrK@NJ9hj9qk&K-CyFu#fR zXH|RgsHdiDKkg~43zBr{7`*^Futr|eX5Gp$qA>@Gyy6WMhtcrM@a|jaLRSqsJbgG) z?~ea*1gGHZJXYC)q!1eukXVR>Uj-8|4)-_;NPF%BfK)m1gGBoruC#}U3`vYWD!(0` zJ%aAQ(nA38Fz>Fr2QWG4B7PSxKP-OWu6yLCvrq!b*w!nssF))<F_1LdXW>24NtYI+ zP<|ly=vnfljUf*)^jBazK96D<MBUINP!?V{N1U%p8*tzC^kI?l0+~dB2Q|7#hl_{L z`hIEMSZ~%L$R)f5@wadbmV7_S*dRu|?EBk;Af8$ZzR$9@@9V3Ce+C=y6%;xs*HHT$ z#d}(44RfE*fha@Qmk;DMEmcYvUDq{TOWW%6xNm152ORe0=yZ-L%+I61vc^3W7eFYY lFK%6t@>IgZzOPvNhaW<r+%NN!tzw1H2~&g8qaVYw{sUuGf71W} literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/pidlockfile.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/pidlockfile.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f66366422d12e50e09518dc294e5c24d5f484a65 GIT binary patch literal 4897 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/sqlitelockfile.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/sqlitelockfile.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..55442c2d857dc9a6a9685f4c1b5646210005531d GIT binary patch literal 3752 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/symlinklockfile.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/__pycache__/symlinklockfile.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..aa78d2b372febef6544a7c73346ce3160bd358e4 GIT binary patch literal 2214 zcmZ`)OLH7G5SBF0U9TSrCW#XhhDSoSig=9=fmA^-5W*!a2b+TIWoo<{+vA<bTGA}> z)aF9`1GvH=wR_Bs;zkuefZs4zPWb~II1suu<JdTkwj{M$J*`h)w|c*wooy0mfB!lS zJ_6}4T%2qsEY_jR`!I0AX-pE@qZDNpvmVp4(KEQg&Dcz=o|V`=J8^nW;`ZF6(Q8oh z72y`Q4+*zJ>#@;ma<)O*&NJ{x+O(VxwqzFPD)ggdm<iQ=MsdR`-TPU8@OdD^veC^H zE<&!wuMcoh&fvHiC1IAUa`v-WgaOw(A@8H_lg)s|I&^s#hLH3qCxD#-?gegg>yY+L zevaGR0m<SnZyb`I&6|7%W{0=<EX*#S<MS{#xB>Xjm-8D3NgSmEgmEv5!{R-ZyrAC? zrSw$h1>QEOy<A4=jwdVQ8*A;A&2ArgJ!&Z1(7%8#Z@{3)gpSFWj@j6lnv^KEXH3j7 z*|VmU(<L${zQqY(U|oS1Yuf^Sl&<ebX{3C=WSK0@VW4(POAg~ml{0x7?dPGN21(d9 zOH+pNwrJ^()GiVS)H<r-@+lGLVdtNN&QL_7K!u%AAUfMw%tIkNw;y(P{M#du6zSUb z-s<k|!=mux+qbrM#VWL&w6ob6M#Gy?Dpe52H&<70jSfa1<fzo$AB8E;L?;Hake^P? z%+Y#fcpxw-XQ4~Y6I)=#rBh_D9No3g!0xCa8!mKB<)0voA<%<{XpL!#1d>No(FvWB zN37migP9IYu?A$*4?$lnDmF2|wj!KS@*PP>CQ<gFDgK}Ye`7LnrbO@u@C-JN&UjLJ z9y9Rvr1tugaybKEjSJ*4{gI|~s>#uJy@oGlY8=18Y+fNL;}B#@9+3UD@3r^+H63cZ zEAUwq*XxA$eh4Ckd4+k_-_IivddQ%+oeA%nEEcaxFOptRy$Zb*@@L5F&M!Y>`~A~) zOPqssX=2>P42n)23o(bQ20HXHMy2!3#+O25qHINekodR(hYJVHbQ%d{9g-~$!(rPH z^QhO(T?n?X55Sz#i6ve`Tc<{i3wa#|VxOljU7)VX=pvnCF0+kA(3s5p*ELOQKDU`? z6c<k?LhYxI^c*#mF&A_m+yMb1My5nwQV?z6pVjfW0D1%TE6UVys`bj6*kI*gBsBX* zw^*nMO*2)KSzM_!$VJHC_qKB7;qKOf2XD+R8<EsJg<M#GprUCBC4B4^-*%p21rZlP z^ORP!o#sh|aR^257MMs~tSgr29DSLK+V<64U|bd1qZ7<ZV@fyR*lyd@XsUW(NAd+E z@g^euKOpf2=srO(`r*-H>2yF|-22rqJox@3jO;4ZJbZ8f2}WxG{}AFWFoM#CiCK~N zHcCiU>0-&!F!4fX!bGOmp-W_&09y;si{+P~o=E0bqrD0aPNEf;kI_~MQem~u!Yc6V zvk;ceEx5%%=g3{KscIdD_3~+$$A)dT*=<9_npo_ym_xB|`hJq}JVv?Y`}=ti*E^2y z^Q`atx}J(<1mfX<Arv|l-$m&-z*@o=DH<?fwn-!yA7RsOzT-Ns;hK7{J%i_N=PDO) uuE1QVZvQ$+CDDIKRo?4t*M$OWg#P%f6HE8w>K1qK@k+F9F_*e*+58Vby8Vg( literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/linklockfile.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/linklockfile.py new file mode 100644 index 0000000..2ca9be0 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/linklockfile.py @@ -0,0 +1,73 @@ +from __future__ import absolute_import + +import time +import os + +from . import (LockBase, LockFailed, NotLocked, NotMyLock, LockTimeout, + AlreadyLocked) + + +class LinkLockFile(LockBase): + """Lock access to a file using atomic property of link(2). + + >>> lock = LinkLockFile('somefile') + >>> lock = LinkLockFile('somefile', threaded=False) + """ + + def acquire(self, timeout=None): + try: + open(self.unique_name, "wb").close() + except IOError: + raise LockFailed("failed to create %s" % self.unique_name) + + timeout = timeout if timeout is not None else self.timeout + end_time = time.time() + if timeout is not None and timeout > 0: + end_time += timeout + + while True: + # Try and create a hard link to it. + try: + os.link(self.unique_name, self.lock_file) + except OSError: + # Link creation failed. Maybe we've double-locked? + nlinks = os.stat(self.unique_name).st_nlink + if nlinks == 2: + # The original link plus the one I created == 2. We're + # good to go. + return + else: + # Otherwise the lock creation failed. + if timeout is not None and time.time() > end_time: + os.unlink(self.unique_name) + if timeout > 0: + raise LockTimeout("Timeout waiting to acquire" + " lock for %s" % + self.path) + else: + raise AlreadyLocked("%s is already locked" % + self.path) + time.sleep(timeout is not None and timeout / 10 or 0.1) + else: + # Link creation succeeded. We're good to go. + return + + def release(self): + if not self.is_locked(): + raise NotLocked("%s is not locked" % self.path) + elif not os.path.exists(self.unique_name): + raise NotMyLock("%s is locked, but not by me" % self.path) + os.unlink(self.unique_name) + os.unlink(self.lock_file) + + def is_locked(self): + return os.path.exists(self.lock_file) + + def i_am_locking(self): + return (self.is_locked() and + os.path.exists(self.unique_name) and + os.stat(self.unique_name).st_nlink == 2) + + def break_lock(self): + if os.path.exists(self.lock_file): + os.unlink(self.lock_file) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/mkdirlockfile.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/mkdirlockfile.py new file mode 100644 index 0000000..05a8c96 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/mkdirlockfile.py @@ -0,0 +1,84 @@ +from __future__ import absolute_import, division + +import time +import os +import sys +import errno + +from . import (LockBase, LockFailed, NotLocked, NotMyLock, LockTimeout, + AlreadyLocked) + + +class MkdirLockFile(LockBase): + """Lock file by creating a directory.""" + def __init__(self, path, threaded=True, timeout=None): + """ + >>> lock = MkdirLockFile('somefile') + >>> lock = MkdirLockFile('somefile', threaded=False) + """ + LockBase.__init__(self, path, threaded, timeout) + # Lock file itself is a directory. Place the unique file name into + # it. + self.unique_name = os.path.join(self.lock_file, + "%s.%s%s" % (self.hostname, + self.tname, + self.pid)) + + def acquire(self, timeout=None): + timeout = timeout if timeout is not None else self.timeout + end_time = time.time() + if timeout is not None and timeout > 0: + end_time += timeout + + if timeout is None: + wait = 0.1 + else: + wait = max(0, timeout / 10) + + while True: + try: + os.mkdir(self.lock_file) + except OSError: + err = sys.exc_info()[1] + if err.errno == errno.EEXIST: + # Already locked. + if os.path.exists(self.unique_name): + # Already locked by me. + return + if timeout is not None and time.time() > end_time: + if timeout > 0: + raise LockTimeout("Timeout waiting to acquire" + " lock for %s" % + self.path) + else: + # Someone else has the lock. + raise AlreadyLocked("%s is already locked" % + self.path) + time.sleep(wait) + else: + # Couldn't create the lock for some other reason + raise LockFailed("failed to create %s" % self.lock_file) + else: + open(self.unique_name, "wb").close() + return + + def release(self): + if not self.is_locked(): + raise NotLocked("%s is not locked" % self.path) + elif not os.path.exists(self.unique_name): + raise NotMyLock("%s is locked, but not by me" % self.path) + os.unlink(self.unique_name) + os.rmdir(self.lock_file) + + def is_locked(self): + return os.path.exists(self.lock_file) + + def i_am_locking(self): + return (self.is_locked() and + os.path.exists(self.unique_name)) + + def break_lock(self): + if os.path.exists(self.lock_file): + for name in os.listdir(self.lock_file): + os.unlink(os.path.join(self.lock_file, name)) + os.rmdir(self.lock_file) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/pidlockfile.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/pidlockfile.py new file mode 100644 index 0000000..069e85b --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/pidlockfile.py @@ -0,0 +1,190 @@ +# -*- coding: utf-8 -*- + +# pidlockfile.py +# +# Copyright © 2008–2009 Ben Finney <ben+python@benfinney.id.au> +# +# This is free software: you may copy, modify, and/or distribute this work +# under the terms of the Python Software Foundation License, version 2 or +# later as published by the Python Software Foundation. +# No warranty expressed or implied. See the file LICENSE.PSF-2 for details. + +""" Lockfile behaviour implemented via Unix PID files. + """ + +from __future__ import absolute_import + +import errno +import os +import time + +from . import (LockBase, AlreadyLocked, LockFailed, NotLocked, NotMyLock, + LockTimeout) + + +class PIDLockFile(LockBase): + """ Lockfile implemented as a Unix PID file. + + The lock file is a normal file named by the attribute `path`. + A lock's PID file contains a single line of text, containing + the process ID (PID) of the process that acquired the lock. + + >>> lock = PIDLockFile('somefile') + >>> lock = PIDLockFile('somefile') + """ + + def __init__(self, path, threaded=False, timeout=None): + # pid lockfiles don't support threaded operation, so always force + # False as the threaded arg. + LockBase.__init__(self, path, False, timeout) + self.unique_name = self.path + + def read_pid(self): + """ Get the PID from the lock file. + """ + return read_pid_from_pidfile(self.path) + + def is_locked(self): + """ Test if the lock is currently held. + + The lock is held if the PID file for this lock exists. + + """ + return os.path.exists(self.path) + + def i_am_locking(self): + """ Test if the lock is held by the current process. + + Returns ``True`` if the current process ID matches the + number stored in the PID file. + """ + return self.is_locked() and os.getpid() == self.read_pid() + + def acquire(self, timeout=None): + """ Acquire the lock. + + Creates the PID file for this lock, or raises an error if + the lock could not be acquired. + """ + + timeout = timeout if timeout is not None else self.timeout + end_time = time.time() + if timeout is not None and timeout > 0: + end_time += timeout + + while True: + try: + write_pid_to_pidfile(self.path) + except OSError as exc: + if exc.errno == errno.EEXIST: + # The lock creation failed. Maybe sleep a bit. + if time.time() > end_time: + if timeout is not None and timeout > 0: + raise LockTimeout("Timeout waiting to acquire" + " lock for %s" % + self.path) + else: + raise AlreadyLocked("%s is already locked" % + self.path) + time.sleep(timeout is not None and timeout / 10 or 0.1) + else: + raise LockFailed("failed to create %s" % self.path) + else: + return + + def release(self): + """ Release the lock. + + Removes the PID file to release the lock, or raises an + error if the current process does not hold the lock. + + """ + if not self.is_locked(): + raise NotLocked("%s is not locked" % self.path) + if not self.i_am_locking(): + raise NotMyLock("%s is locked, but not by me" % self.path) + remove_existing_pidfile(self.path) + + def break_lock(self): + """ Break an existing lock. + + Removes the PID file if it already exists, otherwise does + nothing. + + """ + remove_existing_pidfile(self.path) + + +def read_pid_from_pidfile(pidfile_path): + """ Read the PID recorded in the named PID file. + + Read and return the numeric PID recorded as text in the named + PID file. If the PID file cannot be read, or if the content is + not a valid PID, return ``None``. + + """ + pid = None + try: + pidfile = open(pidfile_path, 'r') + except IOError: + pass + else: + # According to the FHS 2.3 section on PID files in /var/run: + # + # The file must consist of the process identifier in + # ASCII-encoded decimal, followed by a newline character. + # + # Programs that read PID files should be somewhat flexible + # in what they accept; i.e., they should ignore extra + # whitespace, leading zeroes, absence of the trailing + # newline, or additional lines in the PID file. + + line = pidfile.readline().strip() + try: + pid = int(line) + except ValueError: + pass + pidfile.close() + + return pid + + +def write_pid_to_pidfile(pidfile_path): + """ Write the PID in the named PID file. + + Get the numeric process ID (“PID”) of the current process + and write it to the named file as a line of text. + + """ + open_flags = (os.O_CREAT | os.O_EXCL | os.O_WRONLY) + open_mode = 0o644 + pidfile_fd = os.open(pidfile_path, open_flags, open_mode) + pidfile = os.fdopen(pidfile_fd, 'w') + + # According to the FHS 2.3 section on PID files in /var/run: + # + # The file must consist of the process identifier in + # ASCII-encoded decimal, followed by a newline character. For + # example, if crond was process number 25, /var/run/crond.pid + # would contain three characters: two, five, and newline. + + pid = os.getpid() + pidfile.write("%s\n" % pid) + pidfile.close() + + +def remove_existing_pidfile(pidfile_path): + """ Remove the named PID file if it exists. + + Removing a PID file that doesn't already exist puts us in the + desired state, so we ignore the condition if the file does not + exist. + + """ + try: + os.remove(pidfile_path) + except OSError as exc: + if exc.errno == errno.ENOENT: + pass + else: + raise diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/sqlitelockfile.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/sqlitelockfile.py new file mode 100644 index 0000000..f997e24 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/sqlitelockfile.py @@ -0,0 +1,156 @@ +from __future__ import absolute_import, division + +import time +import os + +try: + unicode +except NameError: + unicode = str + +from . import LockBase, NotLocked, NotMyLock, LockTimeout, AlreadyLocked + + +class SQLiteLockFile(LockBase): + "Demonstrate SQL-based locking." + + testdb = None + + def __init__(self, path, threaded=True, timeout=None): + """ + >>> lock = SQLiteLockFile('somefile') + >>> lock = SQLiteLockFile('somefile', threaded=False) + """ + LockBase.__init__(self, path, threaded, timeout) + self.lock_file = unicode(self.lock_file) + self.unique_name = unicode(self.unique_name) + + if SQLiteLockFile.testdb is None: + import tempfile + _fd, testdb = tempfile.mkstemp() + os.close(_fd) + os.unlink(testdb) + del _fd, tempfile + SQLiteLockFile.testdb = testdb + + import sqlite3 + self.connection = sqlite3.connect(SQLiteLockFile.testdb) + + c = self.connection.cursor() + try: + c.execute("create table locks" + "(" + " lock_file varchar(32)," + " unique_name varchar(32)" + ")") + except sqlite3.OperationalError: + pass + else: + self.connection.commit() + import atexit + atexit.register(os.unlink, SQLiteLockFile.testdb) + + def acquire(self, timeout=None): + timeout = timeout if timeout is not None else self.timeout + end_time = time.time() + if timeout is not None and timeout > 0: + end_time += timeout + + if timeout is None: + wait = 0.1 + elif timeout <= 0: + wait = 0 + else: + wait = timeout / 10 + + cursor = self.connection.cursor() + + while True: + if not self.is_locked(): + # Not locked. Try to lock it. + cursor.execute("insert into locks" + " (lock_file, unique_name)" + " values" + " (?, ?)", + (self.lock_file, self.unique_name)) + self.connection.commit() + + # Check to see if we are the only lock holder. + cursor.execute("select * from locks" + " where unique_name = ?", + (self.unique_name,)) + rows = cursor.fetchall() + if len(rows) > 1: + # Nope. Someone else got there. Remove our lock. + cursor.execute("delete from locks" + " where unique_name = ?", + (self.unique_name,)) + self.connection.commit() + else: + # Yup. We're done, so go home. + return + else: + # Check to see if we are the only lock holder. + cursor.execute("select * from locks" + " where unique_name = ?", + (self.unique_name,)) + rows = cursor.fetchall() + if len(rows) == 1: + # We're the locker, so go home. + return + + # Maybe we should wait a bit longer. + if timeout is not None and time.time() > end_time: + if timeout > 0: + # No more waiting. + raise LockTimeout("Timeout waiting to acquire" + " lock for %s" % + self.path) + else: + # Someone else has the lock and we are impatient.. + raise AlreadyLocked("%s is already locked" % self.path) + + # Well, okay. We'll give it a bit longer. + time.sleep(wait) + + def release(self): + if not self.is_locked(): + raise NotLocked("%s is not locked" % self.path) + if not self.i_am_locking(): + raise NotMyLock("%s is locked, but not by me (by %s)" % + (self.unique_name, self._who_is_locking())) + cursor = self.connection.cursor() + cursor.execute("delete from locks" + " where unique_name = ?", + (self.unique_name,)) + self.connection.commit() + + def _who_is_locking(self): + cursor = self.connection.cursor() + cursor.execute("select unique_name from locks" + " where lock_file = ?", + (self.lock_file,)) + return cursor.fetchone()[0] + + def is_locked(self): + cursor = self.connection.cursor() + cursor.execute("select * from locks" + " where lock_file = ?", + (self.lock_file,)) + rows = cursor.fetchall() + return not not rows + + def i_am_locking(self): + cursor = self.connection.cursor() + cursor.execute("select * from locks" + " where lock_file = ?" + " and unique_name = ?", + (self.lock_file, self.unique_name)) + return not not cursor.fetchall() + + def break_lock(self): + cursor = self.connection.cursor() + cursor.execute("delete from locks" + " where lock_file = ?", + (self.lock_file,)) + self.connection.commit() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/symlinklockfile.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/symlinklockfile.py new file mode 100644 index 0000000..23b41f5 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/lockfile/symlinklockfile.py @@ -0,0 +1,70 @@ +from __future__ import absolute_import + +import os +import time + +from . import (LockBase, NotLocked, NotMyLock, LockTimeout, + AlreadyLocked) + + +class SymlinkLockFile(LockBase): + """Lock access to a file using symlink(2).""" + + def __init__(self, path, threaded=True, timeout=None): + # super(SymlinkLockFile).__init(...) + LockBase.__init__(self, path, threaded, timeout) + # split it back! + self.unique_name = os.path.split(self.unique_name)[1] + + def acquire(self, timeout=None): + # Hopefully unnecessary for symlink. + # try: + # open(self.unique_name, "wb").close() + # except IOError: + # raise LockFailed("failed to create %s" % self.unique_name) + timeout = timeout if timeout is not None else self.timeout + end_time = time.time() + if timeout is not None and timeout > 0: + end_time += timeout + + while True: + # Try and create a symbolic link to it. + try: + os.symlink(self.unique_name, self.lock_file) + except OSError: + # Link creation failed. Maybe we've double-locked? + if self.i_am_locking(): + # Linked to out unique name. Proceed. + return + else: + # Otherwise the lock creation failed. + if timeout is not None and time.time() > end_time: + if timeout > 0: + raise LockTimeout("Timeout waiting to acquire" + " lock for %s" % + self.path) + else: + raise AlreadyLocked("%s is already locked" % + self.path) + time.sleep(timeout / 10 if timeout is not None else 0.1) + else: + # Link creation succeeded. We're good to go. + return + + def release(self): + if not self.is_locked(): + raise NotLocked("%s is not locked" % self.path) + elif not self.i_am_locking(): + raise NotMyLock("%s is locked, but not by me" % self.path) + os.unlink(self.lock_file) + + def is_locked(self): + return os.path.islink(self.lock_file) + + def i_am_locking(self): + return (os.path.islink(self.lock_file) + and os.readlink(self.lock_file) == self.unique_name) + + def break_lock(self): + if os.path.islink(self.lock_file): # exists && link + os.unlink(self.lock_file) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__init__.py new file mode 100644 index 0000000..b326507 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__init__.py @@ -0,0 +1,65 @@ +# coding: utf-8 +from pip._vendor.msgpack._version import version +from pip._vendor.msgpack.exceptions import * + +from collections import namedtuple + + +class ExtType(namedtuple('ExtType', 'code data')): + """ExtType represents ext type in msgpack.""" + def __new__(cls, code, data): + if not isinstance(code, int): + raise TypeError("code must be int") + if not isinstance(data, bytes): + raise TypeError("data must be bytes") + if not 0 <= code <= 127: + raise ValueError("code must be 0~127") + return super(ExtType, cls).__new__(cls, code, data) + + +import os +if os.environ.get('MSGPACK_PUREPYTHON'): + from pip._vendor.msgpack.fallback import Packer, unpackb, Unpacker +else: + try: + from pip._vendor.msgpack._cmsgpack import Packer, unpackb, Unpacker + except ImportError: + from pip._vendor.msgpack.fallback import Packer, unpackb, Unpacker + + +def pack(o, stream, **kwargs): + """ + Pack object `o` and write it to `stream` + + See :class:`Packer` for options. + """ + packer = Packer(**kwargs) + stream.write(packer.pack(o)) + + +def packb(o, **kwargs): + """ + Pack object `o` and return packed bytes + + See :class:`Packer` for options. + """ + return Packer(**kwargs).pack(o) + + +def unpack(stream, **kwargs): + """ + Unpack an object from `stream`. + + Raises `ExtraData` when `stream` contains extra bytes. + See :class:`Unpacker` for options. + """ + data = stream.read() + return unpackb(data, **kwargs) + + +# alias for compatibility to simplejson/marshal/pickle. +load = unpack +loads = unpackb + +dump = pack +dumps = packb diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..099cc09af15e99c8fff3ac33d1c657b6553ee797 GIT binary patch literal 2042 zcmb7EOK%%D5GHq5tMyv)E2$BrX}W!(QGrNy4rv_}MVr=0i=eI%+j;Dv)M`oDviG5o zlxz!13)BX3De@bnV{ZK={Q<o8lt0izPaSe4*Dl;cDeQ1Kq&V}<H^ZH3)kiS?{B0cl z=pyuoUYs8uEWU(K{0@R5iW8LL5M!-diM6d~JF!zIbTE2=s6$Jqh?W@4)IG6I?63qU z%847g%-t`KJnD@xZ-Q+mnMwW7PiMo~v=UY@%I*)Y8GH4j{Rzr$If%_2_<V$s{$2L( zXDG9tBI?uGQxwkA3a!GtK<DT@%!_O>Tw=4~6*eDUWeee3w7i9C3vU1us$o^`GcG!L z1}gppgr7wzqq5gcSgennANFJ+0#FzVF-4(8acI9pZA>j{pL(J55;-U=feS~K*N^1( zahDA~o+trlUCso{qzKrN3?ys@oh(SjZa0b#>haWrcBJ*vWEPJ>k!Xk|KC#4-1g|If z7Yr6l+F<z*ES9!Vdx#zQ>jCDUQRe`Q`<aE21WL^Ll5~gY#2S@{aM#cp+YqO_F<6Lm z%7U~fWYE$9$-xqhWOQa}9ZM!Sh8W)b3}Uc!;rz-^t9L%FdCKpIP9|iO#Z1|7iJH;i z*E!F*Dw!*k|2Rr|Q<La*8Rr_JDie~iLqck{vg1T3M>|lC4&pUdGlaxRBm^O^(O=IS zUEb+Ok~R7fZ?yA-0)dUSqsA^->+^Jw-D&Ty?Cl*51|(U#+uGwRFm|)XcB9+r-ZlXy z$?cVuyZz(-YEK)@NBS(IId4p;Xb{rLI+Boj_n229MBOT44g|tJ_RO~o^I(2LZGDQs zRUW8NM1&}xkTj>gMC%nop7)|;vIBr=9us2jR@Di>m?a6=u7H<9ENbnl7CKG3A%&wA z>|kRV%orwgo;Jdz@3$Uoe)aW3vbpnUee>D&w?Aw^KHW{IEXGy2m+2a7DR0LpjK>yS zH68j|?c*VQ;wA`*+E87u@C&G@5gytjYly~ptlJ+$)mVe4egH$?9^|ck7R#WSH-jjn z!6ENRC?lxvJZK8ZS(G+?b9#%h;GW^~UbBd+8MJdA<Xs6pDC*`AM9r^51gc~%QjU%r z+6m{%EpAip!C}OAg>v;46wyB!Gs)8N>(3+$xjyE473%_?4vk%Rn8CXMiouItX{>+~ z5aPj;|3t`{?C~rx-f3WJ`+oqeSq7g83iNluJAY4$i!fA4-`~0gJHk-q@()1207FAK zgQ2kx(Fl#v3rj+KxA71F87RLRC<XJt(Uh?^&(kxC>IH;HQAaQlG@-D0^bJ&2GdSF1 z+1arm&NCT7Bk3oMM+N$Vx%2c+tLzejYnF1LC@6m$0tT`Jn2H2wBL1BPw<z3I*edue zdzgO&tJ<=<0qt9#v~GR+io)7F>0BpG-Ms7wJBnFRa%wit6L{-Q{c+s|#fxO+LX}z8 z@9;cR_AZl``)Wr?(gKzWLNy+K14Q`FWnM`<2~o{{mv(b5&D&_oz%Xl2DJRJzs!CeI zLr8mRSCzCB=MrNIMboXk&x;r43k_Dh52AuSt70!#JY2!cmW8k3Iegvrd~e39IM}fq F{5O1#4Rrtj literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__pycache__/_version.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__pycache__/_version.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ac21ff2b0b767d3e0d35cbb252020e7463edad99 GIT binary patch literal 231 zcmWIL<>g`kf^QoZCW-**#~=<eU<7g;fVh|gNTe`CF{CgCGiWktGQR}!8D6r12#^{- zO~za7WvNBQnfZAu8H!keLSW)op?*P8W?5oMs(x8wk$zf!P6|+wzGa1edc0*>QEpY9 zQCgNkMn*+dReX-6SyD!k0T86;>4)eSWESXV<`tJD=H%!a7?_n+mKm0U1i?7IEHy7B mzeqo~IK3b-Ia?pd2ivVzP<e~PCO1E&G$+*#<gm{`%m4t-k3QG{ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__pycache__/exceptions.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__pycache__/exceptions.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2a04e9840c621995eabbac6dba8195d2e64e6240 GIT binary patch literal 1865 zcmb7E&2HO95GF-Rq9`koT_DF`F9jl?mfRi!xCjCxtyAP87l_jXFN-yIX|kob>Mlu3 zgm3AK^ypjPqi?`#-=T+|I<wRd?ZySNzz#V7!`b=f!)WANaQ^<|cXsMp)?di9PZyXo zxOxTT2a8+W{td3MK01L7e1|*0JHiIO1H8+-z;_Mr0N>+%;QPV_i5ql5;_(4U1{+CF zxIrJJJ|BW~DEbh`6IKBFz!$^dfFHcKCZiCt-#a#NXK?ix2-w@)3Od{l9NqzYr+)e& zTe9$%^HnI8c_Opw&o@j95~fUR5=lk0TnHkzYE2YNwBY0>PEtV%<D6vIQ{N|W<`<Xe z-)^L2!PbrS-kr!i7K-FC%ZM(nnk+Ihz7GnS67nu0Ygv#RmgOXuBxHFQ6PBh#C?(Zb zjllTs$|p&tbHVtuDd*0uJxVjS5R}$Fr3=Z66u%EB{k34}M$@O1%aGDLOZA~mhWw*v zOO=!?7qgP7StL^~l%AcgX4mwzREsM6Ci?j#j#pJh)6<t%u{wcsoy{(1%Vc?sbwH`d zCnqn<b@_FHLUU;;GA`9@p|7#=vwdr)%eBJi!mB$#JlpV(zv%%O?cWsMvs3$TiYOB5 zZIPz)J4ZQSp<rGug#)_(yXMP7*#HR6_BJK*pOtcOQRElV_bg{~g@HbqWeAEVtt`kt zp5>8Y9ln)n!SZu_{_5GgtYm4z$)=Myt)QGMY~3eoz;+$AYC!(8Yw+Lah!<0We<>x& z1WX+NpR^-L^Q@H?`TwNFqR-HX0NKAO;uJSW;5Hj0=<*)CbH5&(uX4q(>D9;GCrMiP z6dB-5D1kySO;Ug<;oz{r>SYXy-SpjaMQF<`T>}xvI+i(kkpa=U5^MosCI(#%_#32! z4wSt;_>KSb9bB__ZtYu(TDKjbuz#R_dk&-OH30;#y8?d(wvnqv8mXt?r*H&XuZW|H zSWdDer}RsVjAL!tJ-a&EHDJ0m2oXfvvjvr@2fetBSeaMPn+jfBO^6bqNJ?02rj({n zCjG=#hv4$C6j&M14oWAWGsv;*>abmh(atBmhY;*xFq}g5#r?2m^B6=TPM*WnXzST- z&vO;Z=93Y=`({&{-C)qG5KOiI6H5zW22<f=E1a`>+^p4>4kOj0AKOd6euC`YrXF3C uLPe>(G2!Y%RNoV|+Oey<_Fgsn^|jex_>bek*d4n^?orou#$(rZ?SBDDoui!q literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__pycache__/fallback.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/__pycache__/fallback.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ef6ac320233c3f8be2eb794657479c4081bf0099 GIT binary patch literal 26361 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 e@Xn zmp1qi8-NrTIU9{*O&}07Jte5&;zhjaX$8!K$t10onOR_Sxf=-D@2B*@eVXwUr?o?& z-S1-4<m!;*c^{F<A^`^_Ark9jNHlY<=pXix^w0h9K=!6}I3Al5`&J^Q*E&n=#MeNI zw?Ke99+1=41?!01DtNuD?|A5mvl>>tf>nHCe~^fg=@{r2p3($8G!REFUf>sjpW50) zE@Wa&z4B_9s%<2}vOepM`b_i6-&g~;4RPF>^|U<O#6d{#(sPfYGFZ*ayP0ku_RbiN zxNq3p0pZc#8Ph#bMJGXa#HlT$H=f2OVUK?T`Q-^fFU8wI*kvbd-VPc?PRJ}gcegV* zYp1-CUTm{P;;DWbv021Y)?zHq(;;CkA~uKE4+pWG68o!&?LzD)gV=6~^$-i2ZS~b4 zwpU``iP%2us(u*6t`jK^_djo08|Ce`>O;t}UUn=vmXW$QNS=+cJhX^os|F-xQ!_=! z2QXzvCsP)An|GQDgCq6L<nSUD$o?O%Ch@hJ;5NKmtz3Ez)UOXj`I>K{9N2g8&;#{N z^0Gs-v}oo;Ii<kyzz8pdVu-u}p&zY;z9Y~?V6UpJo>YoH$^$A*-<RoYqmOc!2nJtK z|C^Doh2gKNkA>c^sgJ{p+gV&fRUeCSS=Q53R&`m>h5d+NKtVv*V<D*(51A0d*dn)V zTzAU2rU4f7ew3q{$7cGZXanXgd20B_Q^4ilLF5>;xbD^a<6}Pr*)pf8sEJ1Y6avDt zOqEC9!m7~2%YJzD3(`2oi|p=^p2Ubc8cWB$hiJEBLOXyRb}SVq6Je^Cw6ijoC_i_M zsE?pNP3>Fsk>rX(srot{cC5lYFceM8>V3!g+-!?9_;M;HghjO0-SGi}XeF&8C;d{K zO$>m1Bq^?oZ3;-WQX2YykzU+K#OU>nR(kyo>D7CRPXxuKYP_P1QmYZ>P9%I|4Z>_} zAxw;cl4*t?iY1X~LcJeX@?g2Muu&U=Np+G+E4+r61k1tYDZRcUoN9(IcgfZY3t%T; z6fDJtiC}`oa2ulZVz-&G8{zoojBj39-p!N-zDsPlwsYRl467cl1Iq;2wR@L`h{0^w z9vjcG*#I70MM@IZReDxD8p{{W3glus=fzYkJ(?FtA3}N->F<f9;|V=IZ;+nxQg{lV zs}N^S*NFOOq=oRQm*^w&QW;X^EA%xd(pMR5PNc6PSnoNfA1#V@TcGVF=4)kH>L-jl zO=q<s(~a8xfJE*?4vG_lU__ix^0n%%!=|}OS)1Nh0EhUyJu*zReuxs3sfG~`PUKOa zA@si``oMtd)M$jM5!JD;*EFAwrA9P|En2#j7d1)vQKH-=;Xh}vNy3*AtoNM2kx_hV z!RSNCMXIby%r)uQi4uR-q@xzdG*1FwT24pmptZQO;{2VQ{3O02xRQ?gp=>-ix&K^n zQpdN4aYPdy>IJ8EE|2Z>f~qf$W8TSl5D9vS=(j}<r<9m8{giEHorV={Sp>-14Wk}A zcqAR&ih*p^pV6m`5C-Bc3r=qG_{iCiepHbJ$4N4eh~zCedA~K%(d!p%nkP~tz@m8; zunHD_O3oAiSA<6@!b1{P;DL;qz}p267b<tCA8}a1$8W`~Q50@`ojky9TR?a|aZDY` zax_Qq*!a4O=g*EjQiRPMeokCG`#8<hehD?`-MmN@><zyi2cr7CGiFdH9V2}*jB)fD zaUmNvuo=!-^`3xrM<sDcGlCPOGiM4LmRVM)AF;|iS<(7ar_UU}`1l2w&7Hh>?)>TE z<7b~ZdqK-QZ(%OkD00)Mw$RDb*-mGOj%-(iZ_BPsW&{VhHiFwrAKMxmQ%xlP0^q-m zLFIBYh#krh=N&$#@mhA19HQLLRx=%$woE(zw$RO`GdcVvGi{2c@rpZ(6pjc&_+JpN zyP}SfV<tZbJq*vu<^LSeRHhUM)lRK?NoCorc9d4Vbp8Ym28r1IeV_hZ@UFGi;)n&( zdd9cGuAt<3Y7~ZP@;@6C#Y}LtHw+F3Z~wb$0Qu!V1@Jr0&eAqO!`jD2r1k8RQR`df zn%YO;Tk*eO3<v)M#&B>-J<Mwc`bl1W_5UEj9-?y(9m<QN>sBeK&1U|Xd0wUSM|8eN z=bLoCMdx?vh=t;}>H9r8`$-wmQypPYM!_TWjnH|F&KR9%={!Y;eX&{>`<aLIi~2_a z(r~BYXxqa~q6<4xNVf@XvJQVDYbC9062A#*VtTN^^dV1Qk7!U5n=`pEFSJ0>pOs8> WwPpHXUULVuHOX|M=Q%_F9r-`+Notq? literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/_version.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/_version.py new file mode 100644 index 0000000..926c5e7 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/_version.py @@ -0,0 +1 @@ +version = (0, 6, 1) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/exceptions.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/exceptions.py new file mode 100644 index 0000000..d6d2615 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/exceptions.py @@ -0,0 +1,48 @@ +class UnpackException(Exception): + """Base class for some exceptions raised while unpacking. + + NOTE: unpack may raise exception other than subclass of + UnpackException. If you want to catch all error, catch + Exception instead. + """ + + +class BufferFull(UnpackException): + pass + + +class OutOfData(UnpackException): + pass + + +class FormatError(ValueError, UnpackException): + """Invalid msgpack format""" + + +class StackError(ValueError, UnpackException): + """Too nested""" + + +# Deprecated. Use ValueError instead +UnpackValueError = ValueError + + +class ExtraData(UnpackValueError): + """ExtraData is raised when there is trailing data. + + This exception is raised while only one-shot (not streaming) + unpack. + """ + + def __init__(self, unpacked, extra): + self.unpacked = unpacked + self.extra = extra + + def __str__(self): + return "unpack(b) received extra data." + + +# Deprecated. Use Exception instead to catch all exception during packing. +PackException = Exception +PackValueError = ValueError +PackOverflowError = OverflowError diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/fallback.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/fallback.py new file mode 100644 index 0000000..5b731dd --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/msgpack/fallback.py @@ -0,0 +1,1027 @@ +"""Fallback pure Python implementation of msgpack""" + +import sys +import struct +import warnings + + +if sys.version_info[0] == 2: + PY2 = True + int_types = (int, long) + def dict_iteritems(d): + return d.iteritems() +else: + PY2 = False + int_types = int + unicode = str + xrange = range + def dict_iteritems(d): + return d.items() + +if sys.version_info < (3, 5): + # Ugly hack... + RecursionError = RuntimeError + + def _is_recursionerror(e): + return len(e.args) == 1 and isinstance(e.args[0], str) and \ + e.args[0].startswith('maximum recursion depth exceeded') +else: + def _is_recursionerror(e): + return True + +if hasattr(sys, 'pypy_version_info'): + # cStringIO is slow on PyPy, StringIO is faster. However: PyPy's own + # StringBuilder is fastest. + from __pypy__ import newlist_hint + try: + from __pypy__.builders import BytesBuilder as StringBuilder + except ImportError: + from __pypy__.builders import StringBuilder + USING_STRINGBUILDER = True + class StringIO(object): + def __init__(self, s=b''): + if s: + self.builder = StringBuilder(len(s)) + self.builder.append(s) + else: + self.builder = StringBuilder() + def write(self, s): + if isinstance(s, memoryview): + s = s.tobytes() + elif isinstance(s, bytearray): + s = bytes(s) + self.builder.append(s) + def getvalue(self): + return self.builder.build() +else: + USING_STRINGBUILDER = False + from io import BytesIO as StringIO + newlist_hint = lambda size: [] + + +from pip._vendor.msgpack.exceptions import ( + BufferFull, + OutOfData, + ExtraData, + FormatError, + StackError, +) + +from pip._vendor.msgpack import ExtType + + +EX_SKIP = 0 +EX_CONSTRUCT = 1 +EX_READ_ARRAY_HEADER = 2 +EX_READ_MAP_HEADER = 3 + +TYPE_IMMEDIATE = 0 +TYPE_ARRAY = 1 +TYPE_MAP = 2 +TYPE_RAW = 3 +TYPE_BIN = 4 +TYPE_EXT = 5 + +DEFAULT_RECURSE_LIMIT = 511 + + +def _check_type_strict(obj, t, type=type, tuple=tuple): + if type(t) is tuple: + return type(obj) in t + else: + return type(obj) is t + + +def _get_data_from_buffer(obj): + try: + view = memoryview(obj) + except TypeError: + # try to use legacy buffer protocol if 2.7, otherwise re-raise + if PY2: + view = memoryview(buffer(obj)) + warnings.warn("using old buffer interface to unpack %s; " + "this leads to unpacking errors if slicing is used and " + "will be removed in a future version" % type(obj), + RuntimeWarning, stacklevel=3) + else: + raise + if view.itemsize != 1: + raise ValueError("cannot unpack from multi-byte object") + return view + + +def unpack(stream, **kwargs): + warnings.warn( + "Direct calling implementation's unpack() is deprecated, Use msgpack.unpack() or unpackb() instead.", + DeprecationWarning, stacklevel=2) + data = stream.read() + return unpackb(data, **kwargs) + + +def unpackb(packed, **kwargs): + """ + Unpack an object from `packed`. + + Raises ``ExtraData`` when *packed* contains extra bytes. + Raises ``ValueError`` when *packed* is incomplete. + Raises ``FormatError`` when *packed* is not valid msgpack. + Raises ``StackError`` when *packed* contains too nested. + Other exceptions can be raised during unpacking. + + See :class:`Unpacker` for options. + """ + unpacker = Unpacker(None, max_buffer_size=len(packed), **kwargs) + unpacker.feed(packed) + try: + ret = unpacker._unpack() + except OutOfData: + raise ValueError("Unpack failed: incomplete input") + except RecursionError as e: + if _is_recursionerror(e): + raise StackError + raise + if unpacker._got_extradata(): + raise ExtraData(ret, unpacker._get_extradata()) + return ret + + +if sys.version_info < (2, 7, 6): + def _unpack_from(f, b, o=0): + """Explicit typcast for legacy struct.unpack_from""" + return struct.unpack_from(f, bytes(b), o) +else: + _unpack_from = struct.unpack_from + + +class Unpacker(object): + """Streaming unpacker. + + arguments: + + :param file_like: + File-like object having `.read(n)` method. + If specified, unpacker reads serialized data from it and :meth:`feed()` is not usable. + + :param int read_size: + Used as `file_like.read(read_size)`. (default: `min(16*1024, max_buffer_size)`) + + :param bool use_list: + If true, unpack msgpack array to Python list. + Otherwise, unpack to Python tuple. (default: True) + + :param bool raw: + If true, unpack msgpack raw to Python bytes (default). + Otherwise, unpack to Python str (or unicode on Python 2) by decoding + with UTF-8 encoding (recommended). + Currently, the default is true, but it will be changed to false in + near future. So you must specify it explicitly for keeping backward + compatibility. + + *encoding* option which is deprecated overrides this option. + + :param bool strict_map_key: + If true, only str or bytes are accepted for map (dict) keys. + It's False by default for backward-compatibility. + But it will be True from msgpack 1.0. + + :param callable object_hook: + When specified, it should be callable. + Unpacker calls it with a dict argument after unpacking msgpack map. + (See also simplejson) + + :param callable object_pairs_hook: + When specified, it should be callable. + Unpacker calls it with a list of key-value pairs after unpacking msgpack map. + (See also simplejson) + + :param str encoding: + Encoding used for decoding msgpack raw. + If it is None (default), msgpack raw is deserialized to Python bytes. + + :param str unicode_errors: + (deprecated) Used for decoding msgpack raw with *encoding*. + (default: `'strict'`) + + :param int max_buffer_size: + Limits size of data waiting unpacked. 0 means system's INT_MAX (default). + Raises `BufferFull` exception when it is insufficient. + You should set this parameter when unpacking data from untrusted source. + + :param int max_str_len: + Deprecated, use *max_buffer_size* instead. + Limits max length of str. (default: max_buffer_size or 1024*1024) + + :param int max_bin_len: + Deprecated, use *max_buffer_size* instead. + Limits max length of bin. (default: max_buffer_size or 1024*1024) + + :param int max_array_len: + Limits max length of array. + (default: max_buffer_size or 128*1024) + + :param int max_map_len: + Limits max length of map. + (default: max_buffer_size//2 or 32*1024) + + :param int max_ext_len: + Deprecated, use *max_buffer_size* instead. + Limits max size of ext type. (default: max_buffer_size or 1024*1024) + + Example of streaming deserialize from file-like object:: + + unpacker = Unpacker(file_like, raw=False, max_buffer_size=10*1024*1024) + for o in unpacker: + process(o) + + Example of streaming deserialize from socket:: + + unpacker = Unpacker(raw=False, max_buffer_size=10*1024*1024) + while True: + buf = sock.recv(1024**2) + if not buf: + break + unpacker.feed(buf) + for o in unpacker: + process(o) + + Raises ``ExtraData`` when *packed* contains extra bytes. + Raises ``OutOfData`` when *packed* is incomplete. + Raises ``FormatError`` when *packed* is not valid msgpack. + Raises ``StackError`` when *packed* contains too nested. + Other exceptions can be raised during unpacking. + """ + + def __init__(self, file_like=None, read_size=0, use_list=True, raw=True, strict_map_key=False, + object_hook=None, object_pairs_hook=None, list_hook=None, + encoding=None, unicode_errors=None, max_buffer_size=0, + ext_hook=ExtType, + max_str_len=-1, + max_bin_len=-1, + max_array_len=-1, + max_map_len=-1, + max_ext_len=-1): + if encoding is not None: + warnings.warn( + "encoding is deprecated, Use raw=False instead.", + DeprecationWarning, stacklevel=2) + + if unicode_errors is None: + unicode_errors = 'strict' + + if file_like is None: + self._feeding = True + else: + if not callable(file_like.read): + raise TypeError("`file_like.read` must be callable") + self.file_like = file_like + self._feeding = False + + #: array of bytes fed. + self._buffer = bytearray() + #: Which position we currently reads + self._buff_i = 0 + + # When Unpacker is used as an iterable, between the calls to next(), + # the buffer is not "consumed" completely, for efficiency sake. + # Instead, it is done sloppily. To make sure we raise BufferFull at + # the correct moments, we have to keep track of how sloppy we were. + # Furthermore, when the buffer is incomplete (that is: in the case + # we raise an OutOfData) we need to rollback the buffer to the correct + # state, which _buf_checkpoint records. + self._buf_checkpoint = 0 + + if max_str_len == -1: + max_str_len = max_buffer_size or 1024*1024 + if max_bin_len == -1: + max_bin_len = max_buffer_size or 1024*1024 + if max_array_len == -1: + max_array_len = max_buffer_size or 128*1024 + if max_map_len == -1: + max_map_len = max_buffer_size//2 or 32*1024 + if max_ext_len == -1: + max_ext_len = max_buffer_size or 1024*1024 + + self._max_buffer_size = max_buffer_size or 2**31-1 + if read_size > self._max_buffer_size: + raise ValueError("read_size must be smaller than max_buffer_size") + self._read_size = read_size or min(self._max_buffer_size, 16*1024) + self._raw = bool(raw) + self._strict_map_key = bool(strict_map_key) + self._encoding = encoding + self._unicode_errors = unicode_errors + self._use_list = use_list + self._list_hook = list_hook + self._object_hook = object_hook + self._object_pairs_hook = object_pairs_hook + self._ext_hook = ext_hook + self._max_str_len = max_str_len + self._max_bin_len = max_bin_len + self._max_array_len = max_array_len + self._max_map_len = max_map_len + self._max_ext_len = max_ext_len + self._stream_offset = 0 + + if list_hook is not None and not callable(list_hook): + raise TypeError('`list_hook` is not callable') + if object_hook is not None and not callable(object_hook): + raise TypeError('`object_hook` is not callable') + if object_pairs_hook is not None and not callable(object_pairs_hook): + raise TypeError('`object_pairs_hook` is not callable') + if object_hook is not None and object_pairs_hook is not None: + raise TypeError("object_pairs_hook and object_hook are mutually " + "exclusive") + if not callable(ext_hook): + raise TypeError("`ext_hook` is not callable") + + def feed(self, next_bytes): + assert self._feeding + view = _get_data_from_buffer(next_bytes) + if (len(self._buffer) - self._buff_i + len(view) > self._max_buffer_size): + raise BufferFull + + # Strip buffer before checkpoint before reading file. + if self._buf_checkpoint > 0: + del self._buffer[:self._buf_checkpoint] + self._buff_i -= self._buf_checkpoint + self._buf_checkpoint = 0 + + # Use extend here: INPLACE_ADD += doesn't reliably typecast memoryview in jython + self._buffer.extend(view) + + def _consume(self): + """ Gets rid of the used parts of the buffer. """ + self._stream_offset += self._buff_i - self._buf_checkpoint + self._buf_checkpoint = self._buff_i + + def _got_extradata(self): + return self._buff_i < len(self._buffer) + + def _get_extradata(self): + return self._buffer[self._buff_i:] + + def read_bytes(self, n): + return self._read(n) + + def _read(self, n): + # (int) -> bytearray + self._reserve(n) + i = self._buff_i + self._buff_i = i+n + return self._buffer[i:i+n] + + def _reserve(self, n): + remain_bytes = len(self._buffer) - self._buff_i - n + + # Fast path: buffer has n bytes already + if remain_bytes >= 0: + return + + if self._feeding: + self._buff_i = self._buf_checkpoint + raise OutOfData + + # Strip buffer before checkpoint before reading file. + if self._buf_checkpoint > 0: + del self._buffer[:self._buf_checkpoint] + self._buff_i -= self._buf_checkpoint + self._buf_checkpoint = 0 + + # Read from file + remain_bytes = -remain_bytes + while remain_bytes > 0: + to_read_bytes = max(self._read_size, remain_bytes) + read_data = self.file_like.read(to_read_bytes) + if not read_data: + break + assert isinstance(read_data, bytes) + self._buffer += read_data + remain_bytes -= len(read_data) + + if len(self._buffer) < n + self._buff_i: + self._buff_i = 0 # rollback + raise OutOfData + + def _read_header(self, execute=EX_CONSTRUCT): + typ = TYPE_IMMEDIATE + n = 0 + obj = None + self._reserve(1) + b = self._buffer[self._buff_i] + self._buff_i += 1 + if b & 0b10000000 == 0: + obj = b + elif b & 0b11100000 == 0b11100000: + obj = -1 - (b ^ 0xff) + elif b & 0b11100000 == 0b10100000: + n = b & 0b00011111 + typ = TYPE_RAW + if n > self._max_str_len: + raise ValueError("%s exceeds max_str_len(%s)", n, self._max_str_len) + obj = self._read(n) + elif b & 0b11110000 == 0b10010000: + n = b & 0b00001111 + typ = TYPE_ARRAY + if n > self._max_array_len: + raise ValueError("%s exceeds max_array_len(%s)", n, self._max_array_len) + elif b & 0b11110000 == 0b10000000: + n = b & 0b00001111 + typ = TYPE_MAP + if n > self._max_map_len: + raise ValueError("%s exceeds max_map_len(%s)", n, self._max_map_len) + elif b == 0xc0: + obj = None + elif b == 0xc2: + obj = False + elif b == 0xc3: + obj = True + elif b == 0xc4: + typ = TYPE_BIN + self._reserve(1) + n = self._buffer[self._buff_i] + self._buff_i += 1 + if n > self._max_bin_len: + raise ValueError("%s exceeds max_bin_len(%s)" % (n, self._max_bin_len)) + obj = self._read(n) + elif b == 0xc5: + typ = TYPE_BIN + self._reserve(2) + n = _unpack_from(">H", self._buffer, self._buff_i)[0] + self._buff_i += 2 + if n > self._max_bin_len: + raise ValueError("%s exceeds max_bin_len(%s)" % (n, self._max_bin_len)) + obj = self._read(n) + elif b == 0xc6: + typ = TYPE_BIN + self._reserve(4) + n = _unpack_from(">I", self._buffer, self._buff_i)[0] + self._buff_i += 4 + if n > self._max_bin_len: + raise ValueError("%s exceeds max_bin_len(%s)" % (n, self._max_bin_len)) + obj = self._read(n) + elif b == 0xc7: # ext 8 + typ = TYPE_EXT + self._reserve(2) + L, n = _unpack_from('Bb', self._buffer, self._buff_i) + self._buff_i += 2 + if L > self._max_ext_len: + raise ValueError("%s exceeds max_ext_len(%s)" % (L, self._max_ext_len)) + obj = self._read(L) + elif b == 0xc8: # ext 16 + typ = TYPE_EXT + self._reserve(3) + L, n = _unpack_from('>Hb', self._buffer, self._buff_i) + self._buff_i += 3 + if L > self._max_ext_len: + raise ValueError("%s exceeds max_ext_len(%s)" % (L, self._max_ext_len)) + obj = self._read(L) + elif b == 0xc9: # ext 32 + typ = TYPE_EXT + self._reserve(5) + L, n = _unpack_from('>Ib', self._buffer, self._buff_i) + self._buff_i += 5 + if L > self._max_ext_len: + raise ValueError("%s exceeds max_ext_len(%s)" % (L, self._max_ext_len)) + obj = self._read(L) + elif b == 0xca: + self._reserve(4) + obj = _unpack_from(">f", self._buffer, self._buff_i)[0] + self._buff_i += 4 + elif b == 0xcb: + self._reserve(8) + obj = _unpack_from(">d", self._buffer, self._buff_i)[0] + self._buff_i += 8 + elif b == 0xcc: + self._reserve(1) + obj = self._buffer[self._buff_i] + self._buff_i += 1 + elif b == 0xcd: + self._reserve(2) + obj = _unpack_from(">H", self._buffer, self._buff_i)[0] + self._buff_i += 2 + elif b == 0xce: + self._reserve(4) + obj = _unpack_from(">I", self._buffer, self._buff_i)[0] + self._buff_i += 4 + elif b == 0xcf: + self._reserve(8) + obj = _unpack_from(">Q", self._buffer, self._buff_i)[0] + self._buff_i += 8 + elif b == 0xd0: + self._reserve(1) + obj = _unpack_from("b", self._buffer, self._buff_i)[0] + self._buff_i += 1 + elif b == 0xd1: + self._reserve(2) + obj = _unpack_from(">h", self._buffer, self._buff_i)[0] + self._buff_i += 2 + elif b == 0xd2: + self._reserve(4) + obj = _unpack_from(">i", self._buffer, self._buff_i)[0] + self._buff_i += 4 + elif b == 0xd3: + self._reserve(8) + obj = _unpack_from(">q", self._buffer, self._buff_i)[0] + self._buff_i += 8 + elif b == 0xd4: # fixext 1 + typ = TYPE_EXT + if self._max_ext_len < 1: + raise ValueError("%s exceeds max_ext_len(%s)" % (1, self._max_ext_len)) + self._reserve(2) + n, obj = _unpack_from("b1s", self._buffer, self._buff_i) + self._buff_i += 2 + elif b == 0xd5: # fixext 2 + typ = TYPE_EXT + if self._max_ext_len < 2: + raise ValueError("%s exceeds max_ext_len(%s)" % (2, self._max_ext_len)) + self._reserve(3) + n, obj = _unpack_from("b2s", self._buffer, self._buff_i) + self._buff_i += 3 + elif b == 0xd6: # fixext 4 + typ = TYPE_EXT + if self._max_ext_len < 4: + raise ValueError("%s exceeds max_ext_len(%s)" % (4, self._max_ext_len)) + self._reserve(5) + n, obj = _unpack_from("b4s", self._buffer, self._buff_i) + self._buff_i += 5 + elif b == 0xd7: # fixext 8 + typ = TYPE_EXT + if self._max_ext_len < 8: + raise ValueError("%s exceeds max_ext_len(%s)" % (8, self._max_ext_len)) + self._reserve(9) + n, obj = _unpack_from("b8s", self._buffer, self._buff_i) + self._buff_i += 9 + elif b == 0xd8: # fixext 16 + typ = TYPE_EXT + if self._max_ext_len < 16: + raise ValueError("%s exceeds max_ext_len(%s)" % (16, self._max_ext_len)) + self._reserve(17) + n, obj = _unpack_from("b16s", self._buffer, self._buff_i) + self._buff_i += 17 + elif b == 0xd9: + typ = TYPE_RAW + self._reserve(1) + n = self._buffer[self._buff_i] + self._buff_i += 1 + if n > self._max_str_len: + raise ValueError("%s exceeds max_str_len(%s)", n, self._max_str_len) + obj = self._read(n) + elif b == 0xda: + typ = TYPE_RAW + self._reserve(2) + n, = _unpack_from(">H", self._buffer, self._buff_i) + self._buff_i += 2 + if n > self._max_str_len: + raise ValueError("%s exceeds max_str_len(%s)", n, self._max_str_len) + obj = self._read(n) + elif b == 0xdb: + typ = TYPE_RAW + self._reserve(4) + n, = _unpack_from(">I", self._buffer, self._buff_i) + self._buff_i += 4 + if n > self._max_str_len: + raise ValueError("%s exceeds max_str_len(%s)", n, self._max_str_len) + obj = self._read(n) + elif b == 0xdc: + typ = TYPE_ARRAY + self._reserve(2) + n, = _unpack_from(">H", self._buffer, self._buff_i) + self._buff_i += 2 + if n > self._max_array_len: + raise ValueError("%s exceeds max_array_len(%s)", n, self._max_array_len) + elif b == 0xdd: + typ = TYPE_ARRAY + self._reserve(4) + n, = _unpack_from(">I", self._buffer, self._buff_i) + self._buff_i += 4 + if n > self._max_array_len: + raise ValueError("%s exceeds max_array_len(%s)", n, self._max_array_len) + elif b == 0xde: + self._reserve(2) + n, = _unpack_from(">H", self._buffer, self._buff_i) + self._buff_i += 2 + if n > self._max_map_len: + raise ValueError("%s exceeds max_map_len(%s)", n, self._max_map_len) + typ = TYPE_MAP + elif b == 0xdf: + self._reserve(4) + n, = _unpack_from(">I", self._buffer, self._buff_i) + self._buff_i += 4 + if n > self._max_map_len: + raise ValueError("%s exceeds max_map_len(%s)", n, self._max_map_len) + typ = TYPE_MAP + else: + raise FormatError("Unknown header: 0x%x" % b) + return typ, n, obj + + def _unpack(self, execute=EX_CONSTRUCT): + typ, n, obj = self._read_header(execute) + + if execute == EX_READ_ARRAY_HEADER: + if typ != TYPE_ARRAY: + raise ValueError("Expected array") + return n + if execute == EX_READ_MAP_HEADER: + if typ != TYPE_MAP: + raise ValueError("Expected map") + return n + # TODO should we eliminate the recursion? + if typ == TYPE_ARRAY: + if execute == EX_SKIP: + for i in xrange(n): + # TODO check whether we need to call `list_hook` + self._unpack(EX_SKIP) + return + ret = newlist_hint(n) + for i in xrange(n): + ret.append(self._unpack(EX_CONSTRUCT)) + if self._list_hook is not None: + ret = self._list_hook(ret) + # TODO is the interaction between `list_hook` and `use_list` ok? + return ret if self._use_list else tuple(ret) + if typ == TYPE_MAP: + if execute == EX_SKIP: + for i in xrange(n): + # TODO check whether we need to call hooks + self._unpack(EX_SKIP) + self._unpack(EX_SKIP) + return + if self._object_pairs_hook is not None: + ret = self._object_pairs_hook( + (self._unpack(EX_CONSTRUCT), + self._unpack(EX_CONSTRUCT)) + for _ in xrange(n)) + else: + ret = {} + for _ in xrange(n): + key = self._unpack(EX_CONSTRUCT) + if self._strict_map_key and type(key) not in (unicode, bytes): + raise ValueError("%s is not allowed for map key" % str(type(key))) + ret[key] = self._unpack(EX_CONSTRUCT) + if self._object_hook is not None: + ret = self._object_hook(ret) + return ret + if execute == EX_SKIP: + return + if typ == TYPE_RAW: + if self._encoding is not None: + obj = obj.decode(self._encoding, self._unicode_errors) + elif self._raw: + obj = bytes(obj) + else: + obj = obj.decode('utf_8') + return obj + if typ == TYPE_EXT: + return self._ext_hook(n, bytes(obj)) + if typ == TYPE_BIN: + return bytes(obj) + assert typ == TYPE_IMMEDIATE + return obj + + def __iter__(self): + return self + + def __next__(self): + try: + ret = self._unpack(EX_CONSTRUCT) + self._consume() + return ret + except OutOfData: + self._consume() + raise StopIteration + except RecursionError: + raise StackError + + next = __next__ + + def skip(self): + self._unpack(EX_SKIP) + self._consume() + + def unpack(self): + try: + ret = self._unpack(EX_CONSTRUCT) + except RecursionError: + raise StackError + self._consume() + return ret + + def read_array_header(self): + ret = self._unpack(EX_READ_ARRAY_HEADER) + self._consume() + return ret + + def read_map_header(self): + ret = self._unpack(EX_READ_MAP_HEADER) + self._consume() + return ret + + def tell(self): + return self._stream_offset + + +class Packer(object): + """ + MessagePack Packer + + usage: + + packer = Packer() + astream.write(packer.pack(a)) + astream.write(packer.pack(b)) + + Packer's constructor has some keyword arguments: + + :param callable default: + Convert user type to builtin type that Packer supports. + See also simplejson's document. + + :param bool use_single_float: + Use single precision float type for float. (default: False) + + :param bool autoreset: + Reset buffer after each pack and return its content as `bytes`. (default: True). + If set this to false, use `bytes()` to get content and `.reset()` to clear buffer. + + :param bool use_bin_type: + Use bin type introduced in msgpack spec 2.0 for bytes. + It also enables str8 type for unicode. + + :param bool strict_types: + If set to true, types will be checked to be exact. Derived classes + from serializeable types will not be serialized and will be + treated as unsupported type and forwarded to default. + Additionally tuples will not be serialized as lists. + This is useful when trying to implement accurate serialization + for python types. + + :param str encoding: + (deprecated) Convert unicode to bytes with this encoding. (default: 'utf-8') + + :param str unicode_errors: + Error handler for encoding unicode. (default: 'strict') + """ + def __init__(self, default=None, encoding=None, unicode_errors=None, + use_single_float=False, autoreset=True, use_bin_type=False, + strict_types=False): + if encoding is None: + encoding = 'utf_8' + else: + warnings.warn( + "encoding is deprecated, Use raw=False instead.", + DeprecationWarning, stacklevel=2) + + if unicode_errors is None: + unicode_errors = 'strict' + + self._strict_types = strict_types + self._use_float = use_single_float + self._autoreset = autoreset + self._use_bin_type = use_bin_type + self._encoding = encoding + self._unicode_errors = unicode_errors + self._buffer = StringIO() + if default is not None: + if not callable(default): + raise TypeError("default must be callable") + self._default = default + + def _pack(self, obj, nest_limit=DEFAULT_RECURSE_LIMIT, + check=isinstance, check_type_strict=_check_type_strict): + default_used = False + if self._strict_types: + check = check_type_strict + list_types = list + else: + list_types = (list, tuple) + while True: + if nest_limit < 0: + raise ValueError("recursion limit exceeded") + if obj is None: + return self._buffer.write(b"\xc0") + if check(obj, bool): + if obj: + return self._buffer.write(b"\xc3") + return self._buffer.write(b"\xc2") + if check(obj, int_types): + if 0 <= obj < 0x80: + return self._buffer.write(struct.pack("B", obj)) + if -0x20 <= obj < 0: + return self._buffer.write(struct.pack("b", obj)) + if 0x80 <= obj <= 0xff: + return self._buffer.write(struct.pack("BB", 0xcc, obj)) + if -0x80 <= obj < 0: + return self._buffer.write(struct.pack(">Bb", 0xd0, obj)) + if 0xff < obj <= 0xffff: + return self._buffer.write(struct.pack(">BH", 0xcd, obj)) + if -0x8000 <= obj < -0x80: + return self._buffer.write(struct.pack(">Bh", 0xd1, obj)) + if 0xffff < obj <= 0xffffffff: + return self._buffer.write(struct.pack(">BI", 0xce, obj)) + if -0x80000000 <= obj < -0x8000: + return self._buffer.write(struct.pack(">Bi", 0xd2, obj)) + if 0xffffffff < obj <= 0xffffffffffffffff: + return self._buffer.write(struct.pack(">BQ", 0xcf, obj)) + if -0x8000000000000000 <= obj < -0x80000000: + return self._buffer.write(struct.pack(">Bq", 0xd3, obj)) + if not default_used and self._default is not None: + obj = self._default(obj) + default_used = True + continue + raise OverflowError("Integer value out of range") + if check(obj, (bytes, bytearray)): + n = len(obj) + if n >= 2**32: + raise ValueError("%s is too large" % type(obj).__name__) + self._pack_bin_header(n) + return self._buffer.write(obj) + if check(obj, unicode): + if self._encoding is None: + raise TypeError( + "Can't encode unicode string: " + "no encoding is specified") + obj = obj.encode(self._encoding, self._unicode_errors) + n = len(obj) + if n >= 2**32: + raise ValueError("String is too large") + self._pack_raw_header(n) + return self._buffer.write(obj) + if check(obj, memoryview): + n = len(obj) * obj.itemsize + if n >= 2**32: + raise ValueError("Memoryview is too large") + self._pack_bin_header(n) + return self._buffer.write(obj) + if check(obj, float): + if self._use_float: + return self._buffer.write(struct.pack(">Bf", 0xca, obj)) + return self._buffer.write(struct.pack(">Bd", 0xcb, obj)) + if check(obj, ExtType): + code = obj.code + data = obj.data + assert isinstance(code, int) + assert isinstance(data, bytes) + L = len(data) + if L == 1: + self._buffer.write(b'\xd4') + elif L == 2: + self._buffer.write(b'\xd5') + elif L == 4: + self._buffer.write(b'\xd6') + elif L == 8: + self._buffer.write(b'\xd7') + elif L == 16: + self._buffer.write(b'\xd8') + elif L <= 0xff: + self._buffer.write(struct.pack(">BB", 0xc7, L)) + elif L <= 0xffff: + self._buffer.write(struct.pack(">BH", 0xc8, L)) + else: + self._buffer.write(struct.pack(">BI", 0xc9, L)) + self._buffer.write(struct.pack("b", code)) + self._buffer.write(data) + return + if check(obj, list_types): + n = len(obj) + self._pack_array_header(n) + for i in xrange(n): + self._pack(obj[i], nest_limit - 1) + return + if check(obj, dict): + return self._pack_map_pairs(len(obj), dict_iteritems(obj), + nest_limit - 1) + if not default_used and self._default is not None: + obj = self._default(obj) + default_used = 1 + continue + raise TypeError("Cannot serialize %r" % (obj, )) + + def pack(self, obj): + try: + self._pack(obj) + except: + self._buffer = StringIO() # force reset + raise + if self._autoreset: + ret = self._buffer.getvalue() + self._buffer = StringIO() + return ret + + def pack_map_pairs(self, pairs): + self._pack_map_pairs(len(pairs), pairs) + if self._autoreset: + ret = self._buffer.getvalue() + self._buffer = StringIO() + return ret + + def pack_array_header(self, n): + if n >= 2**32: + raise ValueError + self._pack_array_header(n) + if self._autoreset: + ret = self._buffer.getvalue() + self._buffer = StringIO() + return ret + + def pack_map_header(self, n): + if n >= 2**32: + raise ValueError + self._pack_map_header(n) + if self._autoreset: + ret = self._buffer.getvalue() + self._buffer = StringIO() + return ret + + def pack_ext_type(self, typecode, data): + if not isinstance(typecode, int): + raise TypeError("typecode must have int type.") + if not 0 <= typecode <= 127: + raise ValueError("typecode should be 0-127") + if not isinstance(data, bytes): + raise TypeError("data must have bytes type") + L = len(data) + if L > 0xffffffff: + raise ValueError("Too large data") + if L == 1: + self._buffer.write(b'\xd4') + elif L == 2: + self._buffer.write(b'\xd5') + elif L == 4: + self._buffer.write(b'\xd6') + elif L == 8: + self._buffer.write(b'\xd7') + elif L == 16: + self._buffer.write(b'\xd8') + elif L <= 0xff: + self._buffer.write(b'\xc7' + struct.pack('B', L)) + elif L <= 0xffff: + self._buffer.write(b'\xc8' + struct.pack('>H', L)) + else: + self._buffer.write(b'\xc9' + struct.pack('>I', L)) + self._buffer.write(struct.pack('B', typecode)) + self._buffer.write(data) + + def _pack_array_header(self, n): + if n <= 0x0f: + return self._buffer.write(struct.pack('B', 0x90 + n)) + if n <= 0xffff: + return self._buffer.write(struct.pack(">BH", 0xdc, n)) + if n <= 0xffffffff: + return self._buffer.write(struct.pack(">BI", 0xdd, n)) + raise ValueError("Array is too large") + + def _pack_map_header(self, n): + if n <= 0x0f: + return self._buffer.write(struct.pack('B', 0x80 + n)) + if n <= 0xffff: + return self._buffer.write(struct.pack(">BH", 0xde, n)) + if n <= 0xffffffff: + return self._buffer.write(struct.pack(">BI", 0xdf, n)) + raise ValueError("Dict is too large") + + def _pack_map_pairs(self, n, pairs, nest_limit=DEFAULT_RECURSE_LIMIT): + self._pack_map_header(n) + for (k, v) in pairs: + self._pack(k, nest_limit - 1) + self._pack(v, nest_limit - 1) + + def _pack_raw_header(self, n): + if n <= 0x1f: + self._buffer.write(struct.pack('B', 0xa0 + n)) + elif self._use_bin_type and n <= 0xff: + self._buffer.write(struct.pack('>BB', 0xd9, n)) + elif n <= 0xffff: + self._buffer.write(struct.pack(">BH", 0xda, n)) + elif n <= 0xffffffff: + self._buffer.write(struct.pack(">BI", 0xdb, n)) + else: + raise ValueError('Raw is too large') + + def _pack_bin_header(self, n): + if not self._use_bin_type: + return self._pack_raw_header(n) + elif n <= 0xff: + return self._buffer.write(struct.pack('>BB', 0xc4, n)) + elif n <= 0xffff: + return self._buffer.write(struct.pack(">BH", 0xc5, n)) + elif n <= 0xffffffff: + return self._buffer.write(struct.pack(">BI", 0xc6, n)) + else: + raise ValueError('Bin is too large') + + def bytes(self): + """Return internal buffer contents as bytes object""" + return self._buffer.getvalue() + + def reset(self): + """Reset internal buffer. + + This method is usaful only when autoreset=False. + """ + self._buffer = StringIO() + + def getbuffer(self): + """Return view of internal buffer.""" + if USING_STRINGBUILDER or PY2: + return memoryview(self.bytes()) + else: + return self._buffer.getbuffer() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__about__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__about__.py new file mode 100644 index 0000000..7481c9e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__about__.py @@ -0,0 +1,27 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +__all__ = [ + "__title__", + "__summary__", + "__uri__", + "__version__", + "__author__", + "__email__", + "__license__", + "__copyright__", +] + +__title__ = "packaging" +__summary__ = "Core utilities for Python packages" +__uri__ = "https://github.com/pypa/packaging" + +__version__ = "19.0" + +__author__ = "Donald Stufft and individual contributors" +__email__ = "donald@stufft.io" + +__license__ = "BSD or Apache License, Version 2.0" +__copyright__ = "Copyright 2014-2019 %s" % __author__ diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__init__.py new file mode 100644 index 0000000..a0cf67d --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__init__.py @@ -0,0 +1,26 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +from .__about__ import ( + __author__, + __copyright__, + __email__, + __license__, + __summary__, + __title__, + __uri__, + __version__, +) + +__all__ = [ + "__title__", + "__summary__", + "__uri__", + "__version__", + "__author__", + "__email__", + "__license__", + "__copyright__", +] diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9c0f737efa3a4f4c8a2cd6a45e207b80593d5016 GIT binary patch literal 746 zcmY+COK%e~5P)~{XkJYl9_rat;t+{slL%D`La5Ll5vmm6uouh8cz0cP?Uf&^X8#RG zZv38HxxgPlh!f*Ps4ydc@>t^;&x}6|hy4KM=hx5ddm{+GdE;N{qH&4K+#n!;Fb|3_ z4vR+ID4KCI44?r`Xh9o}paWg#rQNs%{kRQ-_y~^U4h-WioWwmijr%Z)2k?OR&Vu+D z9<GA%qaPSG7&mvPY;9ETET^I<mA1Psh)Nit<nE-@LRy+Qxv}2vQEG+FIi<S+rN$Kn z(_1t;lsYXArxn-!E*gDGnX{SFxW}8kU?M;G<YL36@nMFPZdAF|BF(IKE7|4~ONC79 z^DCt}aaQEQ3T{ZEG`ZPgI7tpp+|*ApYfJMYic(=Sx1MfP5tZALMfYJ^^W}6_kFS+v zIgpigNn#0;K!o&Vf@3+^C~37=JFB#*N3eIjG<(;nQ1$tn)iuHFuQ6)I$=k!@pOKG; zO34BfoL&8`f-Gk9=M%(|JT>peL*ItPS*NjFjbjdU)1!s(ePcQHM7RCXkw?eFPhR&t z{14Fsk7LA_K#%<1<F}1)Iu)}#s+f)vl>@#fTHZw|T~@lN<s!MAW!YU_(|mcc&h!i= zmC^gC6y-!nV=?z+HoK^{)!g~R{h}3@p!9tUBYfmqIULWl-0r$B3k5FcuY3XK9Pzl> R2>;VxtwAe9ZJ>IFe*hW0+|d94 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ccf644e9585d545ef2f7a2349287d7338cb759e8 GIT binary patch literal 584 zcmY+Azi!(w5XLFVw*IFmkcX&;lx~Iq28yCj(530Z<v^RV#FnH4iWFkMO~-C|9<817 z0zuHJM;j>86Ziv<xclzYeXHw&U_3wm<hL;)zeDmmGE6?>8SfE-h)59~u}H@()(J}@ zB4UxKg<i6yUa^%<S*kOZ>73=dV1+JOsVi1t-9jwIN~9taxhO>0W~>&~SF*03P?@Zg z`3>KVz4ERBsfXUWITLb{qwLLmHCSmJ9K6{(%%7srk<A4F_pa+Lz+40D`{8J1+c`{g zfJSqv@LB>Wxo^zaT$0gi&F%40<fK#KJq7SqUJ9nhhN%Fy#5p!B$W{S$z$zfD#pVGi z;>-FfcsY3IEs9xOB(X`r0uj9MUGLG>r8%^`QaJ0MC;b}|>~MwVe-ZmOR0sSSDXwAS zuAvjR^w2ATM(Or}wy>S7KAGFY_f6M5oKB#&ce~DRFj_<J=^%$2X-0>dH=E7fbeul; w@OVBjHAeK74t)QEx6-r}KpKg5-w($*`>1>2Rr4wQ%6N^qj^9;r^xyaL7w$rv$p8QV literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/_compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/_compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d8fd2fbc047ab0a33babece77f8a8730c5be207e GIT binary patch literal 1020 zcmah{J8K(35Z=d0IxDgqh)Kw!P?~@W`xFNZ24eyVq%(m$AlEGG+m&?jJ(S(m*%D4= zgZ(q&(p`SfwyFFFQl!ev$vASAftj0`z5Qmsnf<i7+9n{se_l$-3HgP=vM>l<gWAtv z6j3xIIgM$~VwUrmQ_Qg}hyxvbZ7A}XD1OM|=4})})Y2{UR)<3xuM|z)#;<Cq<{63a zDfWT%Ti1Y1`rNO{16yWOr$w4iO5=Q}(kiuSS@`b6q=gg1X^}XH_ph<BYv`CH6mQ=M zCYqovQ2PSRJ919W>5wU^*jcF91wG~8nIk{w2~%7JDY*=wg~mK;_dwnlEuHSk-hs5b zmt@k~-cjntkjb@^bz-yrGXd~Bf~8UH6EK>@RFRl17mvB(P%4-|M?~=tZ#OFwnc2O~ z+f)+NPz!@T>H|>Q0dql5=mk09rwB*)uK?5YB(pv!WUhVNjZ-U-fb~>eG2dAD0m2)c z%pViMI4fWpRnkPmGE>^vXy-T@iJi*i^I~iGbub<u&*viB**+MX0m!I`K1P#tvXK_n z$t>F#47RIT^>T{IT1BM`RRXw74&^8<Mv+L$d?MZEWae8!6#7VrXGjCLN9er&-$`uV z+}a0@A^1R02;UYWFV!?dzazxAsmvB9=04!o91Tut;jMw^S8j*<6vDcJkeYQoT5}qo zn=~^~FSx$dXFhPViLMd*+;kCc6%F25Dp8|%?-IdZY`w$Q!@xX(sNcb+hf_B-(6mAR z249T9zdW}y>pK-J0p7Mqi(%>c`!8E)UcsR=z5@mZDzGK%+x154OpU&12UokqINV*# VXb($R?0=nwyi2=5KttB#e*tS%1B?Iw literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/_structures.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/_structures.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2a9b0450cdbb340d474877c314d5ad6451447877 GIT binary patch literal 2802 zcmcImO>fgM7`Br(O}lRGJ`mp@H<-|t4WXeSK$AcqF1;`=y;xc7wi#*KIc~%%Zry>u z!Lc`fPp+K!0~|Q<zAk}oOWJ|Jm0y3nwjaMAe$uy#ixmRp+viX2$08wLa4=m8FxZ0{ zy#T=prvd5GChZzcqiZ%zN?s9eaPx$4QxryKvnYxq(k#Mkffr%6sAnx<!K}rtH)Or^ z6;2}SW>RwxqFyjig8AKkPpZV`e(XnnFHDyD(hn7D4MI=B*ux#u#el&c)My`sAWh0i z)8LdFC!}d|lNX=`d~QKo<RxxHYw<F#KwIJqyb7(&7x@yjWnSZTXe)e~uRy!NSK*dx ziTyfk`Ju0lJqjRc!9LdKP$P5>r?A>+NN^q*lQB&SkqBDSf}s}QV+V|hT_v2@l}@V{ za3LdS_r23*yRqyJ!w0Rytxo6taL9t)or8|tg3=D1eW&mDH~cVCZV+s2ZSBOz@%8{G zb!D*#c~3fh*L&x-{jlw@NXdbx22w<u{o}-DOp3l_%*Lyt#|RxRr$%k2+H=;Kuuxl9 zg^nVMejp<{0xQR~F*cGy$BjBk0gsj?Sn=CZS%x9P;tIwVV3Y+r(R%tqumlVC&pCB$ zG+ye%$A&}`l44JFgglF9F%~GsmS9DSR+};sb@Q=g9kx$SUjEh7A=EY@hF}a;nHZou zhjGS@AHa==bY#3C5*-7MtU#(`a6?ZdWjG*kqX>eMgD;L4Tg$;mT|Pc~Mv)Z1N`Brz zUV`~Nv=A)1oP&nCb7)!7+n?#sHU#Ec4g~7vLrB~{8w0L-GY<pJz-y-k`=`uMsjJp$ zQg4X1tNd7`sg;@gCB{P0X6z0el_p9(-2pF7D;wh~K9bPw!VQuNW8EGfV0tB0#*PMV zFwsclWm!Y9iUNZ#ub{Y!;yQ{OC~l$nMK_ZkX02u<e4)__2%FmG>7UknpgL9XDegi2 zkIX7DB(q)rlT?T0jnsP+yD|tz`{^FuSThP8UOgMCzo0t(MkNwpR-AQI?$3d|D9z2z zVjcU<DX7aC)?JX}W<D34U)%G5@Xcs9!$K_BpG|bRG^2C*A?#1%mSx$$Wj6hC9?gNg z7`@H@VCdKRcn;77Np9wsNi)FHc|d={bea`1lOB0yZwl&4MkY=OPTq!PnUsVt|1O@9 zLrJJ_te21#TLb(j10O`pF^Neg@$Xh*^$re&rzZEr^;tlP{ba(b&u~wKe;?M&`b`V! E4@aH!_y7O^ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/markers.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/markers.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..687911ac48abc75e80359ce8282fd9eeb1756365 GIT binary patch literal 8927 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/requirements.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/requirements.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d049e062e5bea414ac19a76aceb6221113514d4a GIT binary patch literal 4025 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 F{lETV46*<K literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5dba430b8db77577e48741432121da5136cfeaa9 GIT binary patch literal 19776 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 D+E?H! literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/utils.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/utils.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..da01223051bff9d8b10c57db7f6b5febb6be1f4d GIT binary patch literal 1477 zcmbVM&5j#I5bo|7d+b@;2}wXX<S;-WSj&zLhe#`}R!ATuIP8TGz$6;Yy4&`6=a268 ztatEU2v5Kh*vGvfo`Xl|D-u#}IdRB|s$S=3ffH@l=kBWN>iYH9-L6ky{q@@>e%2u5 z4?MiS95{Req`m~;gwvE{bVM^YVwp2?DDqh9j$H0=H*I9iQ8V*K9wowEw|HYiM{VBZ z-p^#@^A>Nz?+#~Qk-q;F?2*1>uEocyNEcc}Nmdq8n-)*1L?uOTdZkQq9ZeSbSi||~ zDa9+y^uEZeI8FFNA+4Ub-PFzR_oDFe?ilr6EZn<5p8~1t0Gg~Rrz^5yYqlZa3OjmE z_rQ~z(KybFJQ;)ST0~Mz#nL!xacmlCaVlh=8aIzKaY1Ak>^v_A;9nJMF{olWm=q}o ze+K)@!8F>hWLD=NPv*nfY+2V)x_|$8CWo-5`QX8zOv=3^S2|A9z2WeFbyj_}K&GXr z5;-sApp3^S@ifV&gN05~6_#h_jVlhKFFlNk0T3py0bU6m`B+^W`ZL(n9Zgo`2|Xv@ zko>kwG(GX<T}tq?B2Drgq~lvMCFhWyIpg%ik)N;V+Tm>NB4<N46f}XO8|x-koHy3q zWqm>3`V4G?j$^gRyv<uDZTX9};DTNo`vCOXTRpTz=Fk_Q^{dtL?K}SV9Wvjsvfr(2 z$I5nI$~so|r<HZAtaB;j@YV|afYNsBpZoyUgIS^i_*O!m1uDssG?sxbf^Fl3QKYnt zq7Q@Pg$`!13W{6=P<fq-fG3lQkRl%oWo?}%dKT!J2u|a(AVKw<r$Skl6sd?6Touzy z<T|t$B(`Af{y02;yY@bK6b}2lcMUN#{8zDX*c8%R04wsicTS;T^a*_k1^R(;D9;5w zx}eaNT3#^2!l9u{+l`li?O@smQ;~~hDG%?VEo^?5FjC*U(mjw09G>tXEui7mVfgaa z(f{#F-hgN1O@ucQa6(@BByYoU7wDBYt*|VVhNRS9$VG)4cNehVl^))00+@y<i}B1f z<FbUIFwIFJvsfD@g~Y}-?z~8H<89M!oKgzoqFv*FO`KbZ4gN8_ZM3FQ#!{<)cxP_? zS7tC4^$q}OGTNa%<}=sv=?(XNz&p5mK}@~}TK$gkBlxq@3n`*V;_yi<sKf%uI|%P0 wU|=>x<Bf}~Oj04+$infphF<f|X3-Y4b&wT&k%~jKrZD(hti`T7zSC;_4GUdt$p8QV literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/version.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/__pycache__/version.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..998ec034f4e5f6b907b252dd8d26616d4ce1c390 GIT binary patch literal 12107 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 CF<tHe literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/_compat.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/_compat.py new file mode 100644 index 0000000..25da473 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/_compat.py @@ -0,0 +1,31 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import sys + + +PY2 = sys.version_info[0] == 2 +PY3 = sys.version_info[0] == 3 + +# flake8: noqa + +if PY3: + string_types = (str,) +else: + string_types = (basestring,) + + +def with_metaclass(meta, *bases): + """ + Create a base class with a metaclass. + """ + # This requires a bit of explanation: the basic idea is to make a dummy + # metaclass for one level of class instantiation that replaces itself with + # the actual metaclass. + class metaclass(meta): + def __new__(cls, name, this_bases, d): + return meta(name, bases, d) + + return type.__new__(metaclass, "temporary_class", (), {}) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/_structures.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/_structures.py new file mode 100644 index 0000000..68dcca6 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/_structures.py @@ -0,0 +1,68 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + + +class Infinity(object): + def __repr__(self): + return "Infinity" + + def __hash__(self): + return hash(repr(self)) + + def __lt__(self, other): + return False + + def __le__(self, other): + return False + + def __eq__(self, other): + return isinstance(other, self.__class__) + + def __ne__(self, other): + return not isinstance(other, self.__class__) + + def __gt__(self, other): + return True + + def __ge__(self, other): + return True + + def __neg__(self): + return NegativeInfinity + + +Infinity = Infinity() + + +class NegativeInfinity(object): + def __repr__(self): + return "-Infinity" + + def __hash__(self): + return hash(repr(self)) + + def __lt__(self, other): + return True + + def __le__(self, other): + return True + + def __eq__(self, other): + return isinstance(other, self.__class__) + + def __ne__(self, other): + return not isinstance(other, self.__class__) + + def __gt__(self, other): + return False + + def __ge__(self, other): + return False + + def __neg__(self): + return Infinity + + +NegativeInfinity = NegativeInfinity() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/markers.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/markers.py new file mode 100644 index 0000000..5482476 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/markers.py @@ -0,0 +1,296 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import operator +import os +import platform +import sys + +from pip._vendor.pyparsing import ParseException, ParseResults, stringStart, stringEnd +from pip._vendor.pyparsing import ZeroOrMore, Group, Forward, QuotedString +from pip._vendor.pyparsing import Literal as L # noqa + +from ._compat import string_types +from .specifiers import Specifier, InvalidSpecifier + + +__all__ = [ + "InvalidMarker", + "UndefinedComparison", + "UndefinedEnvironmentName", + "Marker", + "default_environment", +] + + +class InvalidMarker(ValueError): + """ + An invalid marker was found, users should refer to PEP 508. + """ + + +class UndefinedComparison(ValueError): + """ + An invalid operation was attempted on a value that doesn't support it. + """ + + +class UndefinedEnvironmentName(ValueError): + """ + A name was attempted to be used that does not exist inside of the + environment. + """ + + +class Node(object): + def __init__(self, value): + self.value = value + + def __str__(self): + return str(self.value) + + def __repr__(self): + return "<{0}({1!r})>".format(self.__class__.__name__, str(self)) + + def serialize(self): + raise NotImplementedError + + +class Variable(Node): + def serialize(self): + return str(self) + + +class Value(Node): + def serialize(self): + return '"{0}"'.format(self) + + +class Op(Node): + def serialize(self): + return str(self) + + +VARIABLE = ( + L("implementation_version") + | L("platform_python_implementation") + | L("implementation_name") + | L("python_full_version") + | L("platform_release") + | L("platform_version") + | L("platform_machine") + | L("platform_system") + | L("python_version") + | L("sys_platform") + | L("os_name") + | L("os.name") + | L("sys.platform") # PEP-345 + | L("platform.version") # PEP-345 + | L("platform.machine") # PEP-345 + | L("platform.python_implementation") # PEP-345 + | L("python_implementation") # PEP-345 + | L("extra") # undocumented setuptools legacy +) +ALIASES = { + "os.name": "os_name", + "sys.platform": "sys_platform", + "platform.version": "platform_version", + "platform.machine": "platform_machine", + "platform.python_implementation": "platform_python_implementation", + "python_implementation": "platform_python_implementation", +} +VARIABLE.setParseAction(lambda s, l, t: Variable(ALIASES.get(t[0], t[0]))) + +VERSION_CMP = ( + L("===") | L("==") | L(">=") | L("<=") | L("!=") | L("~=") | L(">") | L("<") +) + +MARKER_OP = VERSION_CMP | L("not in") | L("in") +MARKER_OP.setParseAction(lambda s, l, t: Op(t[0])) + +MARKER_VALUE = QuotedString("'") | QuotedString('"') +MARKER_VALUE.setParseAction(lambda s, l, t: Value(t[0])) + +BOOLOP = L("and") | L("or") + +MARKER_VAR = VARIABLE | MARKER_VALUE + +MARKER_ITEM = Group(MARKER_VAR + MARKER_OP + MARKER_VAR) +MARKER_ITEM.setParseAction(lambda s, l, t: tuple(t[0])) + +LPAREN = L("(").suppress() +RPAREN = L(")").suppress() + +MARKER_EXPR = Forward() +MARKER_ATOM = MARKER_ITEM | Group(LPAREN + MARKER_EXPR + RPAREN) +MARKER_EXPR << MARKER_ATOM + ZeroOrMore(BOOLOP + MARKER_EXPR) + +MARKER = stringStart + MARKER_EXPR + stringEnd + + +def _coerce_parse_result(results): + if isinstance(results, ParseResults): + return [_coerce_parse_result(i) for i in results] + else: + return results + + +def _format_marker(marker, first=True): + assert isinstance(marker, (list, tuple, string_types)) + + # Sometimes we have a structure like [[...]] which is a single item list + # where the single item is itself it's own list. In that case we want skip + # the rest of this function so that we don't get extraneous () on the + # outside. + if ( + isinstance(marker, list) + and len(marker) == 1 + and isinstance(marker[0], (list, tuple)) + ): + return _format_marker(marker[0]) + + if isinstance(marker, list): + inner = (_format_marker(m, first=False) for m in marker) + if first: + return " ".join(inner) + else: + return "(" + " ".join(inner) + ")" + elif isinstance(marker, tuple): + return " ".join([m.serialize() for m in marker]) + else: + return marker + + +_operators = { + "in": lambda lhs, rhs: lhs in rhs, + "not in": lambda lhs, rhs: lhs not in rhs, + "<": operator.lt, + "<=": operator.le, + "==": operator.eq, + "!=": operator.ne, + ">=": operator.ge, + ">": operator.gt, +} + + +def _eval_op(lhs, op, rhs): + try: + spec = Specifier("".join([op.serialize(), rhs])) + except InvalidSpecifier: + pass + else: + return spec.contains(lhs) + + oper = _operators.get(op.serialize()) + if oper is None: + raise UndefinedComparison( + "Undefined {0!r} on {1!r} and {2!r}.".format(op, lhs, rhs) + ) + + return oper(lhs, rhs) + + +_undefined = object() + + +def _get_env(environment, name): + value = environment.get(name, _undefined) + + if value is _undefined: + raise UndefinedEnvironmentName( + "{0!r} does not exist in evaluation environment.".format(name) + ) + + return value + + +def _evaluate_markers(markers, environment): + groups = [[]] + + for marker in markers: + assert isinstance(marker, (list, tuple, string_types)) + + if isinstance(marker, list): + groups[-1].append(_evaluate_markers(marker, environment)) + elif isinstance(marker, tuple): + lhs, op, rhs = marker + + if isinstance(lhs, Variable): + lhs_value = _get_env(environment, lhs.value) + rhs_value = rhs.value + else: + lhs_value = lhs.value + rhs_value = _get_env(environment, rhs.value) + + groups[-1].append(_eval_op(lhs_value, op, rhs_value)) + else: + assert marker in ["and", "or"] + if marker == "or": + groups.append([]) + + return any(all(item) for item in groups) + + +def format_full_version(info): + version = "{0.major}.{0.minor}.{0.micro}".format(info) + kind = info.releaselevel + if kind != "final": + version += kind[0] + str(info.serial) + return version + + +def default_environment(): + if hasattr(sys, "implementation"): + iver = format_full_version(sys.implementation.version) + implementation_name = sys.implementation.name + else: + iver = "0" + implementation_name = "" + + return { + "implementation_name": implementation_name, + "implementation_version": iver, + "os_name": os.name, + "platform_machine": platform.machine(), + "platform_release": platform.release(), + "platform_system": platform.system(), + "platform_version": platform.version(), + "python_full_version": platform.python_version(), + "platform_python_implementation": platform.python_implementation(), + "python_version": platform.python_version()[:3], + "sys_platform": sys.platform, + } + + +class Marker(object): + def __init__(self, marker): + try: + self._markers = _coerce_parse_result(MARKER.parseString(marker)) + except ParseException as e: + err_str = "Invalid marker: {0!r}, parse error at {1!r}".format( + marker, marker[e.loc : e.loc + 8] + ) + raise InvalidMarker(err_str) + + def __str__(self): + return _format_marker(self._markers) + + def __repr__(self): + return "<Marker({0!r})>".format(str(self)) + + def evaluate(self, environment=None): + """Evaluate a marker. + + Return the boolean from evaluating the given marker against the + environment. environment is an optional argument to override all or + part of the determined environment. + + The environment is determined from the current Python process. + """ + current_environment = default_environment() + if environment is not None: + current_environment.update(environment) + + return _evaluate_markers(self._markers, current_environment) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/requirements.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/requirements.py new file mode 100644 index 0000000..dbc5f11 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/requirements.py @@ -0,0 +1,138 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import string +import re + +from pip._vendor.pyparsing import stringStart, stringEnd, originalTextFor, ParseException +from pip._vendor.pyparsing import ZeroOrMore, Word, Optional, Regex, Combine +from pip._vendor.pyparsing import Literal as L # noqa +from pip._vendor.six.moves.urllib import parse as urlparse + +from .markers import MARKER_EXPR, Marker +from .specifiers import LegacySpecifier, Specifier, SpecifierSet + + +class InvalidRequirement(ValueError): + """ + An invalid requirement was found, users should refer to PEP 508. + """ + + +ALPHANUM = Word(string.ascii_letters + string.digits) + +LBRACKET = L("[").suppress() +RBRACKET = L("]").suppress() +LPAREN = L("(").suppress() +RPAREN = L(")").suppress() +COMMA = L(",").suppress() +SEMICOLON = L(";").suppress() +AT = L("@").suppress() + +PUNCTUATION = Word("-_.") +IDENTIFIER_END = ALPHANUM | (ZeroOrMore(PUNCTUATION) + ALPHANUM) +IDENTIFIER = Combine(ALPHANUM + ZeroOrMore(IDENTIFIER_END)) + +NAME = IDENTIFIER("name") +EXTRA = IDENTIFIER + +URI = Regex(r"[^ ]+")("url") +URL = AT + URI + +EXTRAS_LIST = EXTRA + ZeroOrMore(COMMA + EXTRA) +EXTRAS = (LBRACKET + Optional(EXTRAS_LIST) + RBRACKET)("extras") + +VERSION_PEP440 = Regex(Specifier._regex_str, re.VERBOSE | re.IGNORECASE) +VERSION_LEGACY = Regex(LegacySpecifier._regex_str, re.VERBOSE | re.IGNORECASE) + +VERSION_ONE = VERSION_PEP440 ^ VERSION_LEGACY +VERSION_MANY = Combine( + VERSION_ONE + ZeroOrMore(COMMA + VERSION_ONE), joinString=",", adjacent=False +)("_raw_spec") +_VERSION_SPEC = Optional(((LPAREN + VERSION_MANY + RPAREN) | VERSION_MANY)) +_VERSION_SPEC.setParseAction(lambda s, l, t: t._raw_spec or "") + +VERSION_SPEC = originalTextFor(_VERSION_SPEC)("specifier") +VERSION_SPEC.setParseAction(lambda s, l, t: t[1]) + +MARKER_EXPR = originalTextFor(MARKER_EXPR())("marker") +MARKER_EXPR.setParseAction( + lambda s, l, t: Marker(s[t._original_start : t._original_end]) +) +MARKER_SEPARATOR = SEMICOLON +MARKER = MARKER_SEPARATOR + MARKER_EXPR + +VERSION_AND_MARKER = VERSION_SPEC + Optional(MARKER) +URL_AND_MARKER = URL + Optional(MARKER) + +NAMED_REQUIREMENT = NAME + Optional(EXTRAS) + (URL_AND_MARKER | VERSION_AND_MARKER) + +REQUIREMENT = stringStart + NAMED_REQUIREMENT + stringEnd +# pyparsing isn't thread safe during initialization, so we do it eagerly, see +# issue #104 +REQUIREMENT.parseString("x[]") + + +class Requirement(object): + """Parse a requirement. + + Parse a given requirement string into its parts, such as name, specifier, + URL, and extras. Raises InvalidRequirement on a badly-formed requirement + string. + """ + + # TODO: Can we test whether something is contained within a requirement? + # If so how do we do that? Do we need to test against the _name_ of + # the thing as well as the version? What about the markers? + # TODO: Can we normalize the name and extra name? + + def __init__(self, requirement_string): + try: + req = REQUIREMENT.parseString(requirement_string) + except ParseException as e: + raise InvalidRequirement( + 'Parse error at "{0!r}": {1}'.format( + requirement_string[e.loc : e.loc + 8], e.msg + ) + ) + + self.name = req.name + if req.url: + parsed_url = urlparse.urlparse(req.url) + if parsed_url.scheme == "file": + if urlparse.urlunparse(parsed_url) != req.url: + raise InvalidRequirement("Invalid URL given") + elif not (parsed_url.scheme and parsed_url.netloc) or ( + not parsed_url.scheme and not parsed_url.netloc + ): + raise InvalidRequirement("Invalid URL: {0}".format(req.url)) + self.url = req.url + else: + self.url = None + self.extras = set(req.extras.asList() if req.extras else []) + self.specifier = SpecifierSet(req.specifier) + self.marker = req.marker if req.marker else None + + def __str__(self): + parts = [self.name] + + if self.extras: + parts.append("[{0}]".format(",".join(sorted(self.extras)))) + + if self.specifier: + parts.append(str(self.specifier)) + + if self.url: + parts.append("@ {0}".format(self.url)) + if self.marker: + parts.append(" ") + + if self.marker: + parts.append("; {0}".format(self.marker)) + + return "".join(parts) + + def __repr__(self): + return "<Requirement({0!r})>".format(str(self)) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/specifiers.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/specifiers.py new file mode 100644 index 0000000..743576a --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/specifiers.py @@ -0,0 +1,749 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import abc +import functools +import itertools +import re + +from ._compat import string_types, with_metaclass +from .version import Version, LegacyVersion, parse + + +class InvalidSpecifier(ValueError): + """ + An invalid specifier was found, users should refer to PEP 440. + """ + + +class BaseSpecifier(with_metaclass(abc.ABCMeta, object)): + @abc.abstractmethod + def __str__(self): + """ + Returns the str representation of this Specifier like object. This + should be representative of the Specifier itself. + """ + + @abc.abstractmethod + def __hash__(self): + """ + Returns a hash value for this Specifier like object. + """ + + @abc.abstractmethod + def __eq__(self, other): + """ + Returns a boolean representing whether or not the two Specifier like + objects are equal. + """ + + @abc.abstractmethod + def __ne__(self, other): + """ + Returns a boolean representing whether or not the two Specifier like + objects are not equal. + """ + + @abc.abstractproperty + def prereleases(self): + """ + Returns whether or not pre-releases as a whole are allowed by this + specifier. + """ + + @prereleases.setter + def prereleases(self, value): + """ + Sets whether or not pre-releases as a whole are allowed by this + specifier. + """ + + @abc.abstractmethod + def contains(self, item, prereleases=None): + """ + Determines if the given item is contained within this specifier. + """ + + @abc.abstractmethod + def filter(self, iterable, prereleases=None): + """ + Takes an iterable of items and filters them so that only items which + are contained within this specifier are allowed in it. + """ + + +class _IndividualSpecifier(BaseSpecifier): + + _operators = {} + + def __init__(self, spec="", prereleases=None): + match = self._regex.search(spec) + if not match: + raise InvalidSpecifier("Invalid specifier: '{0}'".format(spec)) + + self._spec = (match.group("operator").strip(), match.group("version").strip()) + + # Store whether or not this Specifier should accept prereleases + self._prereleases = prereleases + + def __repr__(self): + pre = ( + ", prereleases={0!r}".format(self.prereleases) + if self._prereleases is not None + else "" + ) + + return "<{0}({1!r}{2})>".format(self.__class__.__name__, str(self), pre) + + def __str__(self): + return "{0}{1}".format(*self._spec) + + def __hash__(self): + return hash(self._spec) + + def __eq__(self, other): + if isinstance(other, string_types): + try: + other = self.__class__(other) + except InvalidSpecifier: + return NotImplemented + elif not isinstance(other, self.__class__): + return NotImplemented + + return self._spec == other._spec + + def __ne__(self, other): + if isinstance(other, string_types): + try: + other = self.__class__(other) + except InvalidSpecifier: + return NotImplemented + elif not isinstance(other, self.__class__): + return NotImplemented + + return self._spec != other._spec + + def _get_operator(self, op): + return getattr(self, "_compare_{0}".format(self._operators[op])) + + def _coerce_version(self, version): + if not isinstance(version, (LegacyVersion, Version)): + version = parse(version) + return version + + @property + def operator(self): + return self._spec[0] + + @property + def version(self): + return self._spec[1] + + @property + def prereleases(self): + return self._prereleases + + @prereleases.setter + def prereleases(self, value): + self._prereleases = value + + def __contains__(self, item): + return self.contains(item) + + def contains(self, item, prereleases=None): + # Determine if prereleases are to be allowed or not. + if prereleases is None: + prereleases = self.prereleases + + # Normalize item to a Version or LegacyVersion, this allows us to have + # a shortcut for ``"2.0" in Specifier(">=2") + item = self._coerce_version(item) + + # Determine if we should be supporting prereleases in this specifier + # or not, if we do not support prereleases than we can short circuit + # logic if this version is a prereleases. + if item.is_prerelease and not prereleases: + return False + + # Actually do the comparison to determine if this item is contained + # within this Specifier or not. + return self._get_operator(self.operator)(item, self.version) + + def filter(self, iterable, prereleases=None): + yielded = False + found_prereleases = [] + + kw = {"prereleases": prereleases if prereleases is not None else True} + + # Attempt to iterate over all the values in the iterable and if any of + # them match, yield them. + for version in iterable: + parsed_version = self._coerce_version(version) + + if self.contains(parsed_version, **kw): + # If our version is a prerelease, and we were not set to allow + # prereleases, then we'll store it for later incase nothing + # else matches this specifier. + if parsed_version.is_prerelease and not ( + prereleases or self.prereleases + ): + found_prereleases.append(version) + # Either this is not a prerelease, or we should have been + # accepting prereleases from the beginning. + else: + yielded = True + yield version + + # Now that we've iterated over everything, determine if we've yielded + # any values, and if we have not and we have any prereleases stored up + # then we will go ahead and yield the prereleases. + if not yielded and found_prereleases: + for version in found_prereleases: + yield version + + +class LegacySpecifier(_IndividualSpecifier): + + _regex_str = r""" + (?P<operator>(==|!=|<=|>=|<|>)) + \s* + (?P<version> + [^,;\s)]* # Since this is a "legacy" specifier, and the version + # string can be just about anything, we match everything + # except for whitespace, a semi-colon for marker support, + # a closing paren since versions can be enclosed in + # them, and a comma since it's a version separator. + ) + """ + + _regex = re.compile(r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE) + + _operators = { + "==": "equal", + "!=": "not_equal", + "<=": "less_than_equal", + ">=": "greater_than_equal", + "<": "less_than", + ">": "greater_than", + } + + def _coerce_version(self, version): + if not isinstance(version, LegacyVersion): + version = LegacyVersion(str(version)) + return version + + def _compare_equal(self, prospective, spec): + return prospective == self._coerce_version(spec) + + def _compare_not_equal(self, prospective, spec): + return prospective != self._coerce_version(spec) + + def _compare_less_than_equal(self, prospective, spec): + return prospective <= self._coerce_version(spec) + + def _compare_greater_than_equal(self, prospective, spec): + return prospective >= self._coerce_version(spec) + + def _compare_less_than(self, prospective, spec): + return prospective < self._coerce_version(spec) + + def _compare_greater_than(self, prospective, spec): + return prospective > self._coerce_version(spec) + + +def _require_version_compare(fn): + @functools.wraps(fn) + def wrapped(self, prospective, spec): + if not isinstance(prospective, Version): + return False + return fn(self, prospective, spec) + + return wrapped + + +class Specifier(_IndividualSpecifier): + + _regex_str = r""" + (?P<operator>(~=|==|!=|<=|>=|<|>|===)) + (?P<version> + (?: + # The identity operators allow for an escape hatch that will + # do an exact string match of the version you wish to install. + # This will not be parsed by PEP 440 and we cannot determine + # any semantic meaning from it. This operator is discouraged + # but included entirely as an escape hatch. + (?<====) # Only match for the identity operator + \s* + [^\s]* # We just match everything, except for whitespace + # since we are only testing for strict identity. + ) + | + (?: + # The (non)equality operators allow for wild card and local + # versions to be specified so we have to define these two + # operators separately to enable that. + (?<===|!=) # Only match for equals and not equals + + \s* + v? + (?:[0-9]+!)? # epoch + [0-9]+(?:\.[0-9]+)* # release + (?: # pre release + [-_\.]? + (a|b|c|rc|alpha|beta|pre|preview) + [-_\.]? + [0-9]* + )? + (?: # post release + (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) + )? + + # You cannot use a wild card and a dev or local version + # together so group them with a | and make them optional. + (?: + (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release + (?:\+[a-z0-9]+(?:[-_\.][a-z0-9]+)*)? # local + | + \.\* # Wild card syntax of .* + )? + ) + | + (?: + # The compatible operator requires at least two digits in the + # release segment. + (?<=~=) # Only match for the compatible operator + + \s* + v? + (?:[0-9]+!)? # epoch + [0-9]+(?:\.[0-9]+)+ # release (We have a + instead of a *) + (?: # pre release + [-_\.]? + (a|b|c|rc|alpha|beta|pre|preview) + [-_\.]? + [0-9]* + )? + (?: # post release + (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) + )? + (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release + ) + | + (?: + # All other operators only allow a sub set of what the + # (non)equality operators do. Specifically they do not allow + # local versions to be specified nor do they allow the prefix + # matching wild cards. + (?<!==|!=|~=) # We have special cases for these + # operators so we want to make sure they + # don't match here. + + \s* + v? + (?:[0-9]+!)? # epoch + [0-9]+(?:\.[0-9]+)* # release + (?: # pre release + [-_\.]? + (a|b|c|rc|alpha|beta|pre|preview) + [-_\.]? + [0-9]* + )? + (?: # post release + (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) + )? + (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release + ) + ) + """ + + _regex = re.compile(r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE) + + _operators = { + "~=": "compatible", + "==": "equal", + "!=": "not_equal", + "<=": "less_than_equal", + ">=": "greater_than_equal", + "<": "less_than", + ">": "greater_than", + "===": "arbitrary", + } + + @_require_version_compare + def _compare_compatible(self, prospective, spec): + # Compatible releases have an equivalent combination of >= and ==. That + # is that ~=2.2 is equivalent to >=2.2,==2.*. This allows us to + # implement this in terms of the other specifiers instead of + # implementing it ourselves. The only thing we need to do is construct + # the other specifiers. + + # We want everything but the last item in the version, but we want to + # ignore post and dev releases and we want to treat the pre-release as + # it's own separate segment. + prefix = ".".join( + list( + itertools.takewhile( + lambda x: (not x.startswith("post") and not x.startswith("dev")), + _version_split(spec), + ) + )[:-1] + ) + + # Add the prefix notation to the end of our string + prefix += ".*" + + return self._get_operator(">=")(prospective, spec) and self._get_operator("==")( + prospective, prefix + ) + + @_require_version_compare + def _compare_equal(self, prospective, spec): + # We need special logic to handle prefix matching + if spec.endswith(".*"): + # In the case of prefix matching we want to ignore local segment. + prospective = Version(prospective.public) + # Split the spec out by dots, and pretend that there is an implicit + # dot in between a release segment and a pre-release segment. + spec = _version_split(spec[:-2]) # Remove the trailing .* + + # Split the prospective version out by dots, and pretend that there + # is an implicit dot in between a release segment and a pre-release + # segment. + prospective = _version_split(str(prospective)) + + # Shorten the prospective version to be the same length as the spec + # so that we can determine if the specifier is a prefix of the + # prospective version or not. + prospective = prospective[: len(spec)] + + # Pad out our two sides with zeros so that they both equal the same + # length. + spec, prospective = _pad_version(spec, prospective) + else: + # Convert our spec string into a Version + spec = Version(spec) + + # If the specifier does not have a local segment, then we want to + # act as if the prospective version also does not have a local + # segment. + if not spec.local: + prospective = Version(prospective.public) + + return prospective == spec + + @_require_version_compare + def _compare_not_equal(self, prospective, spec): + return not self._compare_equal(prospective, spec) + + @_require_version_compare + def _compare_less_than_equal(self, prospective, spec): + return prospective <= Version(spec) + + @_require_version_compare + def _compare_greater_than_equal(self, prospective, spec): + return prospective >= Version(spec) + + @_require_version_compare + def _compare_less_than(self, prospective, spec): + # Convert our spec to a Version instance, since we'll want to work with + # it as a version. + spec = Version(spec) + + # Check to see if the prospective version is less than the spec + # version. If it's not we can short circuit and just return False now + # instead of doing extra unneeded work. + if not prospective < spec: + return False + + # This special case is here so that, unless the specifier itself + # includes is a pre-release version, that we do not accept pre-release + # versions for the version mentioned in the specifier (e.g. <3.1 should + # not match 3.1.dev0, but should match 3.0.dev0). + if not spec.is_prerelease and prospective.is_prerelease: + if Version(prospective.base_version) == Version(spec.base_version): + return False + + # If we've gotten to here, it means that prospective version is both + # less than the spec version *and* it's not a pre-release of the same + # version in the spec. + return True + + @_require_version_compare + def _compare_greater_than(self, prospective, spec): + # Convert our spec to a Version instance, since we'll want to work with + # it as a version. + spec = Version(spec) + + # Check to see if the prospective version is greater than the spec + # version. If it's not we can short circuit and just return False now + # instead of doing extra unneeded work. + if not prospective > spec: + return False + + # This special case is here so that, unless the specifier itself + # includes is a post-release version, that we do not accept + # post-release versions for the version mentioned in the specifier + # (e.g. >3.1 should not match 3.0.post0, but should match 3.2.post0). + if not spec.is_postrelease and prospective.is_postrelease: + if Version(prospective.base_version) == Version(spec.base_version): + return False + + # Ensure that we do not allow a local version of the version mentioned + # in the specifier, which is technically greater than, to match. + if prospective.local is not None: + if Version(prospective.base_version) == Version(spec.base_version): + return False + + # If we've gotten to here, it means that prospective version is both + # greater than the spec version *and* it's not a pre-release of the + # same version in the spec. + return True + + def _compare_arbitrary(self, prospective, spec): + return str(prospective).lower() == str(spec).lower() + + @property + def prereleases(self): + # If there is an explicit prereleases set for this, then we'll just + # blindly use that. + if self._prereleases is not None: + return self._prereleases + + # Look at all of our specifiers and determine if they are inclusive + # operators, and if they are if they are including an explicit + # prerelease. + operator, version = self._spec + if operator in ["==", ">=", "<=", "~=", "==="]: + # The == specifier can include a trailing .*, if it does we + # want to remove before parsing. + if operator == "==" and version.endswith(".*"): + version = version[:-2] + + # Parse the version, and if it is a pre-release than this + # specifier allows pre-releases. + if parse(version).is_prerelease: + return True + + return False + + @prereleases.setter + def prereleases(self, value): + self._prereleases = value + + +_prefix_regex = re.compile(r"^([0-9]+)((?:a|b|c|rc)[0-9]+)$") + + +def _version_split(version): + result = [] + for item in version.split("."): + match = _prefix_regex.search(item) + if match: + result.extend(match.groups()) + else: + result.append(item) + return result + + +def _pad_version(left, right): + left_split, right_split = [], [] + + # Get the release segment of our versions + left_split.append(list(itertools.takewhile(lambda x: x.isdigit(), left))) + right_split.append(list(itertools.takewhile(lambda x: x.isdigit(), right))) + + # Get the rest of our versions + left_split.append(left[len(left_split[0]) :]) + right_split.append(right[len(right_split[0]) :]) + + # Insert our padding + left_split.insert(1, ["0"] * max(0, len(right_split[0]) - len(left_split[0]))) + right_split.insert(1, ["0"] * max(0, len(left_split[0]) - len(right_split[0]))) + + return (list(itertools.chain(*left_split)), list(itertools.chain(*right_split))) + + +class SpecifierSet(BaseSpecifier): + def __init__(self, specifiers="", prereleases=None): + # Split on , to break each indidivual specifier into it's own item, and + # strip each item to remove leading/trailing whitespace. + specifiers = [s.strip() for s in specifiers.split(",") if s.strip()] + + # Parsed each individual specifier, attempting first to make it a + # Specifier and falling back to a LegacySpecifier. + parsed = set() + for specifier in specifiers: + try: + parsed.add(Specifier(specifier)) + except InvalidSpecifier: + parsed.add(LegacySpecifier(specifier)) + + # Turn our parsed specifiers into a frozen set and save them for later. + self._specs = frozenset(parsed) + + # Store our prereleases value so we can use it later to determine if + # we accept prereleases or not. + self._prereleases = prereleases + + def __repr__(self): + pre = ( + ", prereleases={0!r}".format(self.prereleases) + if self._prereleases is not None + else "" + ) + + return "<SpecifierSet({0!r}{1})>".format(str(self), pre) + + def __str__(self): + return ",".join(sorted(str(s) for s in self._specs)) + + def __hash__(self): + return hash(self._specs) + + def __and__(self, other): + if isinstance(other, string_types): + other = SpecifierSet(other) + elif not isinstance(other, SpecifierSet): + return NotImplemented + + specifier = SpecifierSet() + specifier._specs = frozenset(self._specs | other._specs) + + if self._prereleases is None and other._prereleases is not None: + specifier._prereleases = other._prereleases + elif self._prereleases is not None and other._prereleases is None: + specifier._prereleases = self._prereleases + elif self._prereleases == other._prereleases: + specifier._prereleases = self._prereleases + else: + raise ValueError( + "Cannot combine SpecifierSets with True and False prerelease " + "overrides." + ) + + return specifier + + def __eq__(self, other): + if isinstance(other, string_types): + other = SpecifierSet(other) + elif isinstance(other, _IndividualSpecifier): + other = SpecifierSet(str(other)) + elif not isinstance(other, SpecifierSet): + return NotImplemented + + return self._specs == other._specs + + def __ne__(self, other): + if isinstance(other, string_types): + other = SpecifierSet(other) + elif isinstance(other, _IndividualSpecifier): + other = SpecifierSet(str(other)) + elif not isinstance(other, SpecifierSet): + return NotImplemented + + return self._specs != other._specs + + def __len__(self): + return len(self._specs) + + def __iter__(self): + return iter(self._specs) + + @property + def prereleases(self): + # If we have been given an explicit prerelease modifier, then we'll + # pass that through here. + if self._prereleases is not None: + return self._prereleases + + # If we don't have any specifiers, and we don't have a forced value, + # then we'll just return None since we don't know if this should have + # pre-releases or not. + if not self._specs: + return None + + # Otherwise we'll see if any of the given specifiers accept + # prereleases, if any of them do we'll return True, otherwise False. + return any(s.prereleases for s in self._specs) + + @prereleases.setter + def prereleases(self, value): + self._prereleases = value + + def __contains__(self, item): + return self.contains(item) + + def contains(self, item, prereleases=None): + # Ensure that our item is a Version or LegacyVersion instance. + if not isinstance(item, (LegacyVersion, Version)): + item = parse(item) + + # Determine if we're forcing a prerelease or not, if we're not forcing + # one for this particular filter call, then we'll use whatever the + # SpecifierSet thinks for whether or not we should support prereleases. + if prereleases is None: + prereleases = self.prereleases + + # We can determine if we're going to allow pre-releases by looking to + # see if any of the underlying items supports them. If none of them do + # and this item is a pre-release then we do not allow it and we can + # short circuit that here. + # Note: This means that 1.0.dev1 would not be contained in something + # like >=1.0.devabc however it would be in >=1.0.debabc,>0.0.dev0 + if not prereleases and item.is_prerelease: + return False + + # We simply dispatch to the underlying specs here to make sure that the + # given version is contained within all of them. + # Note: This use of all() here means that an empty set of specifiers + # will always return True, this is an explicit design decision. + return all(s.contains(item, prereleases=prereleases) for s in self._specs) + + def filter(self, iterable, prereleases=None): + # Determine if we're forcing a prerelease or not, if we're not forcing + # one for this particular filter call, then we'll use whatever the + # SpecifierSet thinks for whether or not we should support prereleases. + if prereleases is None: + prereleases = self.prereleases + + # If we have any specifiers, then we want to wrap our iterable in the + # filter method for each one, this will act as a logical AND amongst + # each specifier. + if self._specs: + for spec in self._specs: + iterable = spec.filter(iterable, prereleases=bool(prereleases)) + return iterable + # If we do not have any specifiers, then we need to have a rough filter + # which will filter out any pre-releases, unless there are no final + # releases, and which will filter out LegacyVersion in general. + else: + filtered = [] + found_prereleases = [] + + for item in iterable: + # Ensure that we some kind of Version class for this item. + if not isinstance(item, (LegacyVersion, Version)): + parsed_version = parse(item) + else: + parsed_version = item + + # Filter out any item which is parsed as a LegacyVersion + if isinstance(parsed_version, LegacyVersion): + continue + + # Store any item which is a pre-release for later unless we've + # already found a final version or we are accepting prereleases + if parsed_version.is_prerelease and not prereleases: + if not filtered: + found_prereleases.append(item) + else: + filtered.append(item) + + # If we've found no items except for pre-releases, then we'll go + # ahead and use the pre-releases + if not filtered and found_prereleases and prereleases is None: + return found_prereleases + + return filtered diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/utils.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/utils.py new file mode 100644 index 0000000..8841878 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/utils.py @@ -0,0 +1,57 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import re + +from .version import InvalidVersion, Version + + +_canonicalize_regex = re.compile(r"[-_.]+") + + +def canonicalize_name(name): + # This is taken from PEP 503. + return _canonicalize_regex.sub("-", name).lower() + + +def canonicalize_version(version): + """ + This is very similar to Version.__str__, but has one subtle differences + with the way it handles the release segment. + """ + + try: + version = Version(version) + except InvalidVersion: + # Legacy versions cannot be normalized + return version + + parts = [] + + # Epoch + if version.epoch != 0: + parts.append("{0}!".format(version.epoch)) + + # Release segment + # NB: This strips trailing '.0's to normalize + parts.append(re.sub(r"(\.0)+$", "", ".".join(str(x) for x in version.release))) + + # Pre-release + if version.pre is not None: + parts.append("".join(str(x) for x in version.pre)) + + # Post-release + if version.post is not None: + parts.append(".post{0}".format(version.post)) + + # Development release + if version.dev is not None: + parts.append(".dev{0}".format(version.dev)) + + # Local version segment + if version.local is not None: + parts.append("+{0}".format(version.local)) + + return "".join(parts) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/version.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/version.py new file mode 100644 index 0000000..95157a1 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/packaging/version.py @@ -0,0 +1,420 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import collections +import itertools +import re + +from ._structures import Infinity + + +__all__ = ["parse", "Version", "LegacyVersion", "InvalidVersion", "VERSION_PATTERN"] + + +_Version = collections.namedtuple( + "_Version", ["epoch", "release", "dev", "pre", "post", "local"] +) + + +def parse(version): + """ + Parse the given version string and return either a :class:`Version` object + or a :class:`LegacyVersion` object depending on if the given version is + a valid PEP 440 version or a legacy version. + """ + try: + return Version(version) + except InvalidVersion: + return LegacyVersion(version) + + +class InvalidVersion(ValueError): + """ + An invalid version was found, users should refer to PEP 440. + """ + + +class _BaseVersion(object): + def __hash__(self): + return hash(self._key) + + def __lt__(self, other): + return self._compare(other, lambda s, o: s < o) + + def __le__(self, other): + return self._compare(other, lambda s, o: s <= o) + + def __eq__(self, other): + return self._compare(other, lambda s, o: s == o) + + def __ge__(self, other): + return self._compare(other, lambda s, o: s >= o) + + def __gt__(self, other): + return self._compare(other, lambda s, o: s > o) + + def __ne__(self, other): + return self._compare(other, lambda s, o: s != o) + + def _compare(self, other, method): + if not isinstance(other, _BaseVersion): + return NotImplemented + + return method(self._key, other._key) + + +class LegacyVersion(_BaseVersion): + def __init__(self, version): + self._version = str(version) + self._key = _legacy_cmpkey(self._version) + + def __str__(self): + return self._version + + def __repr__(self): + return "<LegacyVersion({0})>".format(repr(str(self))) + + @property + def public(self): + return self._version + + @property + def base_version(self): + return self._version + + @property + def epoch(self): + return -1 + + @property + def release(self): + return None + + @property + def pre(self): + return None + + @property + def post(self): + return None + + @property + def dev(self): + return None + + @property + def local(self): + return None + + @property + def is_prerelease(self): + return False + + @property + def is_postrelease(self): + return False + + @property + def is_devrelease(self): + return False + + +_legacy_version_component_re = re.compile(r"(\d+ | [a-z]+ | \.| -)", re.VERBOSE) + +_legacy_version_replacement_map = { + "pre": "c", + "preview": "c", + "-": "final-", + "rc": "c", + "dev": "@", +} + + +def _parse_version_parts(s): + for part in _legacy_version_component_re.split(s): + part = _legacy_version_replacement_map.get(part, part) + + if not part or part == ".": + continue + + if part[:1] in "0123456789": + # pad for numeric comparison + yield part.zfill(8) + else: + yield "*" + part + + # ensure that alpha/beta/candidate are before final + yield "*final" + + +def _legacy_cmpkey(version): + # We hardcode an epoch of -1 here. A PEP 440 version can only have a epoch + # greater than or equal to 0. This will effectively put the LegacyVersion, + # which uses the defacto standard originally implemented by setuptools, + # as before all PEP 440 versions. + epoch = -1 + + # This scheme is taken from pkg_resources.parse_version setuptools prior to + # it's adoption of the packaging library. + parts = [] + for part in _parse_version_parts(version.lower()): + if part.startswith("*"): + # remove "-" before a prerelease tag + if part < "*final": + while parts and parts[-1] == "*final-": + parts.pop() + + # remove trailing zeros from each series of numeric parts + while parts and parts[-1] == "00000000": + parts.pop() + + parts.append(part) + parts = tuple(parts) + + return epoch, parts + + +# Deliberately not anchored to the start and end of the string, to make it +# easier for 3rd party code to reuse +VERSION_PATTERN = r""" + v? + (?: + (?:(?P<epoch>[0-9]+)!)? # epoch + (?P<release>[0-9]+(?:\.[0-9]+)*) # release segment + (?P<pre> # pre-release + [-_\.]? + (?P<pre_l>(a|b|c|rc|alpha|beta|pre|preview)) + [-_\.]? + (?P<pre_n>[0-9]+)? + )? + (?P<post> # post release + (?:-(?P<post_n1>[0-9]+)) + | + (?: + [-_\.]? + (?P<post_l>post|rev|r) + [-_\.]? + (?P<post_n2>[0-9]+)? + ) + )? + (?P<dev> # dev release + [-_\.]? + (?P<dev_l>dev) + [-_\.]? + (?P<dev_n>[0-9]+)? + )? + ) + (?:\+(?P<local>[a-z0-9]+(?:[-_\.][a-z0-9]+)*))? # local version +""" + + +class Version(_BaseVersion): + + _regex = re.compile(r"^\s*" + VERSION_PATTERN + r"\s*$", re.VERBOSE | re.IGNORECASE) + + def __init__(self, version): + # Validate the version and parse it into pieces + match = self._regex.search(version) + if not match: + raise InvalidVersion("Invalid version: '{0}'".format(version)) + + # Store the parsed out pieces of the version + self._version = _Version( + epoch=int(match.group("epoch")) if match.group("epoch") else 0, + release=tuple(int(i) for i in match.group("release").split(".")), + pre=_parse_letter_version(match.group("pre_l"), match.group("pre_n")), + post=_parse_letter_version( + match.group("post_l"), match.group("post_n1") or match.group("post_n2") + ), + dev=_parse_letter_version(match.group("dev_l"), match.group("dev_n")), + local=_parse_local_version(match.group("local")), + ) + + # Generate a key which will be used for sorting + self._key = _cmpkey( + self._version.epoch, + self._version.release, + self._version.pre, + self._version.post, + self._version.dev, + self._version.local, + ) + + def __repr__(self): + return "<Version({0})>".format(repr(str(self))) + + def __str__(self): + parts = [] + + # Epoch + if self.epoch != 0: + parts.append("{0}!".format(self.epoch)) + + # Release segment + parts.append(".".join(str(x) for x in self.release)) + + # Pre-release + if self.pre is not None: + parts.append("".join(str(x) for x in self.pre)) + + # Post-release + if self.post is not None: + parts.append(".post{0}".format(self.post)) + + # Development release + if self.dev is not None: + parts.append(".dev{0}".format(self.dev)) + + # Local version segment + if self.local is not None: + parts.append("+{0}".format(self.local)) + + return "".join(parts) + + @property + def epoch(self): + return self._version.epoch + + @property + def release(self): + return self._version.release + + @property + def pre(self): + return self._version.pre + + @property + def post(self): + return self._version.post[1] if self._version.post else None + + @property + def dev(self): + return self._version.dev[1] if self._version.dev else None + + @property + def local(self): + if self._version.local: + return ".".join(str(x) for x in self._version.local) + else: + return None + + @property + def public(self): + return str(self).split("+", 1)[0] + + @property + def base_version(self): + parts = [] + + # Epoch + if self.epoch != 0: + parts.append("{0}!".format(self.epoch)) + + # Release segment + parts.append(".".join(str(x) for x in self.release)) + + return "".join(parts) + + @property + def is_prerelease(self): + return self.dev is not None or self.pre is not None + + @property + def is_postrelease(self): + return self.post is not None + + @property + def is_devrelease(self): + return self.dev is not None + + +def _parse_letter_version(letter, number): + if letter: + # We consider there to be an implicit 0 in a pre-release if there is + # not a numeral associated with it. + if number is None: + number = 0 + + # We normalize any letters to their lower case form + letter = letter.lower() + + # We consider some words to be alternate spellings of other words and + # in those cases we want to normalize the spellings to our preferred + # spelling. + if letter == "alpha": + letter = "a" + elif letter == "beta": + letter = "b" + elif letter in ["c", "pre", "preview"]: + letter = "rc" + elif letter in ["rev", "r"]: + letter = "post" + + return letter, int(number) + if not letter and number: + # We assume if we are given a number, but we are not given a letter + # then this is using the implicit post release syntax (e.g. 1.0-1) + letter = "post" + + return letter, int(number) + + +_local_version_separators = re.compile(r"[\._-]") + + +def _parse_local_version(local): + """ + Takes a string like abc.1.twelve and turns it into ("abc", 1, "twelve"). + """ + if local is not None: + return tuple( + part.lower() if not part.isdigit() else int(part) + for part in _local_version_separators.split(local) + ) + + +def _cmpkey(epoch, release, pre, post, dev, local): + # When we compare a release version, we want to compare it with all of the + # trailing zeros removed. So we'll use a reverse the list, drop all the now + # leading zeros until we come to something non zero, then take the rest + # re-reverse it back into the correct order and make it a tuple and use + # that for our sorting key. + release = tuple( + reversed(list(itertools.dropwhile(lambda x: x == 0, reversed(release)))) + ) + + # We need to "trick" the sorting algorithm to put 1.0.dev0 before 1.0a0. + # We'll do this by abusing the pre segment, but we _only_ want to do this + # if there is not a pre or a post segment. If we have one of those then + # the normal sorting rules will handle this case correctly. + if pre is None and post is None and dev is not None: + pre = -Infinity + # Versions without a pre-release (except as noted above) should sort after + # those with one. + elif pre is None: + pre = Infinity + + # Versions without a post segment should sort before those with one. + if post is None: + post = -Infinity + + # Versions without a development segment should sort after those with one. + if dev is None: + dev = Infinity + + if local is None: + # Versions without a local segment should sort before those with one. + local = -Infinity + else: + # Versions with a local segment need that segment parsed to implement + # the sorting rules in PEP440. + # - Alpha numeric segments sort before numeric segments + # - Alpha numeric segments sort lexicographically + # - Numeric segments sort numerically + # - Shorter versions sort before longer versions when the prefixes + # match exactly + local = tuple((i, "") if isinstance(i, int) else (-Infinity, i) for i in local) + + return epoch, release, pre, post, dev, local diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__init__.py new file mode 100644 index 0000000..9c1a098 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__init__.py @@ -0,0 +1,4 @@ +"""Wrappers to build Python packages using PEP 517 hooks +""" + +__version__ = '0.5.0' diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d1626d2745d6184772b4853ae29f5e4e345f70ef GIT binary patch literal 295 zcmYjMJx{|h5X}b&ROo;3+M%(F)SyTRv9O{@6d`pvxpkVDy0&E}QImhe$j0x<+W)}7 z#HABYdhhg3r+asA)9EBY{Ct1%71q;e{v$;5g!H#4B3K6^T!$ih4Q6qlzB_Jh;XJ7g z*)&oKl6Q4wG_icU=VjqZ<E1W1{+yHL;+|B-?ER#_WXUpNFSBU40uW{kFx&vNxJVie z@D;ci!_M++sdcjDbwOM1=*}pCV>CO`60+7EdVRP1U{!VOdr(=rsT@O;ny#pob}qHA uxl(h+(za_C&DcB>)3h*-+QQ;t6hLZO10=Q^t{)CYG^%(UU-uEpMf?ZIqg71+ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/_in_process.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/_in_process.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..18d4122d8a0fbb236871dca9aeddcd8414336c85 GIT binary patch literal 5553 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 UP0yO>wROlt{r$%*TXPosFCh1Wf&c&j literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/build.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/build.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..41205c8747251528dab75d9b0eb245d7432c7acc GIT binary patch literal 2809 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 D;Ah&D literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/check.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/check.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..89c174083d3fb810d5e4d93efd37be20270bb8cc GIT binary patch literal 4778 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 A1ONa4 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/colorlog.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/colorlog.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1d8c8901e49a4fd9fad161ccb9b3b8dc2a729413 GIT binary patch literal 2965 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c2760db0a72031676b085369eebda4fd77e2e976 GIT binary patch literal 1017 zcma))O>fgc5QcZxPU3{N1Ox>x$k$3uofcXesX|Cdr~)Z`v{g|qmXmc7r_QdmcAO?k zPjH1Exl(b;jo-6ZPW=NMdSb>2P*qf7q?z3r?`qzC#s`awB?9*I`<XXng#5tdvO$eJ z1CMthaMB>0au(7C%~sZ6KI<8rJ|NsU%BjcP<hhTeVe&jLz?u_fZp|yjS%tGbvQirF z?0SNSzO8(Z2cly`W)D@6;Qr;_>$)8X`(Xb?WqZ|@!hSPKy0ARTj%}=+gBDUhHz2l9 z;BPZwQv`nn9<M=2$RrcWjZenu@`;hq9-EMf(Pk6&nNo5{HpyG^j=YDbfh@DG>F^>q zNZOU{Db<!QS`yVw4Q<NE7uxK_5+Wb;qp7J4+3aaE@{+F39}PX#i8XCci7G?q3*kg6 zNWH{&QcpQ;8FF96PVLy~xV2RE$6}-1t9HA`<FOmowwhg41?vcB--&{#5{NkQ!mv`U zZl$AieSpQx-P9LcDkt)z&GjcvOZK7vS~Sunr02URuz=4;7KE0mx(#cKVm3D<hC_c2 z9#<g%rEIJjrTZr|p<mgAp3y_X=6t>ZohzJ_!VW42VQMG~_lRDbq4fBasYR^Z#DF+v z;T9e!;>a_dHz571^B!c^Pjdsl&ZhZ+oj$xgNzS+t&<Xo;%|zL-sq%1prWe^LY<xvl zh6(k}1uf9)nXSUH88guGKfG97Gu2dgu<i0cdgIgYg8%8glGg>-<+A0vGpa^BiuFPY tzfd5B8;G{d1S`CG=_MKJjIy=UmwXWVPjT|`5(JZ4)M87_GD~^O`~_am(_8=m literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/envbuild.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/envbuild.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..01cd94100285da1b3bb6f5e03d8bd119088e8425 GIT binary patch literal 4297 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/wrappers.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/__pycache__/wrappers.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f42e836d7439d9c73064471cfe91c5791fe28519 GIT binary patch literal 5557 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 bRq|MeuUy1U|8=8oESOk!ZQh!<oT+~R$_Kh@ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/_in_process.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/_in_process.py new file mode 100644 index 0000000..d6524b6 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/_in_process.py @@ -0,0 +1,207 @@ +"""This is invoked in a subprocess to call the build backend hooks. + +It expects: +- Command line args: hook_name, control_dir +- Environment variable: PEP517_BUILD_BACKEND=entry.point:spec +- control_dir/input.json: + - {"kwargs": {...}} + +Results: +- control_dir/output.json + - {"return_val": ...} +""" +from glob import glob +from importlib import import_module +import os +from os.path import join as pjoin +import re +import shutil +import sys + +# This is run as a script, not a module, so it can't do a relative import +import compat + + +class BackendUnavailable(Exception): + """Raised if we cannot import the backend""" + + +def _build_backend(): + """Find and load the build backend""" + ep = os.environ['PEP517_BUILD_BACKEND'] + mod_path, _, obj_path = ep.partition(':') + try: + obj = import_module(mod_path) + except ImportError: + raise BackendUnavailable + if obj_path: + for path_part in obj_path.split('.'): + obj = getattr(obj, path_part) + return obj + + +def get_requires_for_build_wheel(config_settings): + """Invoke the optional get_requires_for_build_wheel hook + + Returns [] if the hook is not defined. + """ + backend = _build_backend() + try: + hook = backend.get_requires_for_build_wheel + except AttributeError: + return [] + else: + return hook(config_settings) + + +def prepare_metadata_for_build_wheel(metadata_directory, config_settings): + """Invoke optional prepare_metadata_for_build_wheel + + Implements a fallback by building a wheel if the hook isn't defined. + """ + backend = _build_backend() + try: + hook = backend.prepare_metadata_for_build_wheel + except AttributeError: + return _get_wheel_metadata_from_wheel(backend, metadata_directory, + config_settings) + else: + return hook(metadata_directory, config_settings) + + +WHEEL_BUILT_MARKER = 'PEP517_ALREADY_BUILT_WHEEL' + + +def _dist_info_files(whl_zip): + """Identify the .dist-info folder inside a wheel ZipFile.""" + res = [] + for path in whl_zip.namelist(): + m = re.match(r'[^/\\]+-[^/\\]+\.dist-info/', path) + if m: + res.append(path) + if res: + return res + raise Exception("No .dist-info folder found in wheel") + + +def _get_wheel_metadata_from_wheel( + backend, metadata_directory, config_settings): + """Build a wheel and extract the metadata from it. + + Fallback for when the build backend does not + define the 'get_wheel_metadata' hook. + """ + from zipfile import ZipFile + whl_basename = backend.build_wheel(metadata_directory, config_settings) + with open(os.path.join(metadata_directory, WHEEL_BUILT_MARKER), 'wb'): + pass # Touch marker file + + whl_file = os.path.join(metadata_directory, whl_basename) + with ZipFile(whl_file) as zipf: + dist_info = _dist_info_files(zipf) + zipf.extractall(path=metadata_directory, members=dist_info) + return dist_info[0].split('/')[0] + + +def _find_already_built_wheel(metadata_directory): + """Check for a wheel already built during the get_wheel_metadata hook. + """ + if not metadata_directory: + return None + metadata_parent = os.path.dirname(metadata_directory) + if not os.path.isfile(pjoin(metadata_parent, WHEEL_BUILT_MARKER)): + return None + + whl_files = glob(os.path.join(metadata_parent, '*.whl')) + if not whl_files: + print('Found wheel built marker, but no .whl files') + return None + if len(whl_files) > 1: + print('Found multiple .whl files; unspecified behaviour. ' + 'Will call build_wheel.') + return None + + # Exactly one .whl file + return whl_files[0] + + +def build_wheel(wheel_directory, config_settings, metadata_directory=None): + """Invoke the mandatory build_wheel hook. + + If a wheel was already built in the + prepare_metadata_for_build_wheel fallback, this + will copy it rather than rebuilding the wheel. + """ + prebuilt_whl = _find_already_built_wheel(metadata_directory) + if prebuilt_whl: + shutil.copy2(prebuilt_whl, wheel_directory) + return os.path.basename(prebuilt_whl) + + return _build_backend().build_wheel(wheel_directory, config_settings, + metadata_directory) + + +def get_requires_for_build_sdist(config_settings): + """Invoke the optional get_requires_for_build_wheel hook + + Returns [] if the hook is not defined. + """ + backend = _build_backend() + try: + hook = backend.get_requires_for_build_sdist + except AttributeError: + return [] + else: + return hook(config_settings) + + +class _DummyException(Exception): + """Nothing should ever raise this exception""" + + +class GotUnsupportedOperation(Exception): + """For internal use when backend raises UnsupportedOperation""" + + +def build_sdist(sdist_directory, config_settings): + """Invoke the mandatory build_sdist hook.""" + backend = _build_backend() + try: + return backend.build_sdist(sdist_directory, config_settings) + except getattr(backend, 'UnsupportedOperation', _DummyException): + raise GotUnsupportedOperation + + +HOOK_NAMES = { + 'get_requires_for_build_wheel', + 'prepare_metadata_for_build_wheel', + 'build_wheel', + 'get_requires_for_build_sdist', + 'build_sdist', +} + + +def main(): + if len(sys.argv) < 3: + sys.exit("Needs args: hook_name, control_dir") + hook_name = sys.argv[1] + control_dir = sys.argv[2] + if hook_name not in HOOK_NAMES: + sys.exit("Unknown hook: %s" % hook_name) + hook = globals()[hook_name] + + hook_input = compat.read_json(pjoin(control_dir, 'input.json')) + + json_out = {'unsupported': False, 'return_val': None} + try: + json_out['return_val'] = hook(**hook_input['kwargs']) + except BackendUnavailable: + json_out['no_backend'] = True + except GotUnsupportedOperation: + json_out['unsupported'] = True + + compat.write_json(json_out, pjoin(control_dir, 'output.json'), indent=2) + + +if __name__ == '__main__': + main() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/build.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/build.py new file mode 100644 index 0000000..ac6c949 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/build.py @@ -0,0 +1,108 @@ +"""Build a project using PEP 517 hooks. +""" +import argparse +import logging +import os +import contextlib +from pip._vendor import pytoml +import shutil +import errno +import tempfile + +from .envbuild import BuildEnvironment +from .wrappers import Pep517HookCaller + +log = logging.getLogger(__name__) + + +@contextlib.contextmanager +def tempdir(): + td = tempfile.mkdtemp() + try: + yield td + finally: + shutil.rmtree(td) + + +def _do_build(hooks, env, dist, dest): + get_requires_name = 'get_requires_for_build_{dist}'.format(**locals()) + get_requires = getattr(hooks, get_requires_name) + reqs = get_requires({}) + log.info('Got build requires: %s', reqs) + + env.pip_install(reqs) + log.info('Installed dynamic build dependencies') + + with tempdir() as td: + log.info('Trying to build %s in %s', dist, td) + build_name = 'build_{dist}'.format(**locals()) + build = getattr(hooks, build_name) + filename = build(td, {}) + source = os.path.join(td, filename) + shutil.move(source, os.path.join(dest, os.path.basename(filename))) + + +def mkdir_p(*args, **kwargs): + """Like `mkdir`, but does not raise an exception if the + directory already exists. + """ + try: + return os.mkdir(*args, **kwargs) + except OSError as exc: + if exc.errno != errno.EEXIST: + raise + + +def build(source_dir, dist, dest=None): + pyproject = os.path.join(source_dir, 'pyproject.toml') + dest = os.path.join(source_dir, dest or 'dist') + mkdir_p(dest) + + with open(pyproject) as f: + pyproject_data = pytoml.load(f) + # Ensure the mandatory data can be loaded + buildsys = pyproject_data['build-system'] + requires = buildsys['requires'] + backend = buildsys['build-backend'] + + hooks = Pep517HookCaller(source_dir, backend) + + with BuildEnvironment() as env: + env.pip_install(requires) + _do_build(hooks, env, dist, dest) + + +parser = argparse.ArgumentParser() +parser.add_argument( + 'source_dir', + help="A directory containing pyproject.toml", +) +parser.add_argument( + '--binary', '-b', + action='store_true', + default=False, +) +parser.add_argument( + '--source', '-s', + action='store_true', + default=False, +) +parser.add_argument( + '--out-dir', '-o', + help="Destination in which to save the builds relative to source dir", +) + + +def main(args): + # determine which dists to build + dists = list(filter(None, ( + 'sdist' if args.source or not args.binary else None, + 'wheel' if args.binary or not args.source else None, + ))) + + for dist in dists: + build(args.source_dir, dist, args.out_dir) + + +if __name__ == '__main__': + main(parser.parse_args()) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/check.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/check.py new file mode 100644 index 0000000..f4cdc6b --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/check.py @@ -0,0 +1,202 @@ +"""Check a project and backend by attempting to build using PEP 517 hooks. +""" +import argparse +import logging +import os +from os.path import isfile, join as pjoin +from pip._vendor.pytoml import TomlError, load as toml_load +import shutil +from subprocess import CalledProcessError +import sys +import tarfile +from tempfile import mkdtemp +import zipfile + +from .colorlog import enable_colourful_output +from .envbuild import BuildEnvironment +from .wrappers import Pep517HookCaller + +log = logging.getLogger(__name__) + + +def check_build_sdist(hooks, build_sys_requires): + with BuildEnvironment() as env: + try: + env.pip_install(build_sys_requires) + log.info('Installed static build dependencies') + except CalledProcessError: + log.error('Failed to install static build dependencies') + return False + + try: + reqs = hooks.get_requires_for_build_sdist({}) + log.info('Got build requires: %s', reqs) + except Exception: + log.error('Failure in get_requires_for_build_sdist', exc_info=True) + return False + + try: + env.pip_install(reqs) + log.info('Installed dynamic build dependencies') + except CalledProcessError: + log.error('Failed to install dynamic build dependencies') + return False + + td = mkdtemp() + log.info('Trying to build sdist in %s', td) + try: + try: + filename = hooks.build_sdist(td, {}) + log.info('build_sdist returned %r', filename) + except Exception: + log.info('Failure in build_sdist', exc_info=True) + return False + + if not filename.endswith('.tar.gz'): + log.error( + "Filename %s doesn't have .tar.gz extension", filename) + return False + + path = pjoin(td, filename) + if isfile(path): + log.info("Output file %s exists", path) + else: + log.error("Output file %s does not exist", path) + return False + + if tarfile.is_tarfile(path): + log.info("Output file is a tar file") + else: + log.error("Output file is not a tar file") + return False + + finally: + shutil.rmtree(td) + + return True + + +def check_build_wheel(hooks, build_sys_requires): + with BuildEnvironment() as env: + try: + env.pip_install(build_sys_requires) + log.info('Installed static build dependencies') + except CalledProcessError: + log.error('Failed to install static build dependencies') + return False + + try: + reqs = hooks.get_requires_for_build_wheel({}) + log.info('Got build requires: %s', reqs) + except Exception: + log.error('Failure in get_requires_for_build_sdist', exc_info=True) + return False + + try: + env.pip_install(reqs) + log.info('Installed dynamic build dependencies') + except CalledProcessError: + log.error('Failed to install dynamic build dependencies') + return False + + td = mkdtemp() + log.info('Trying to build wheel in %s', td) + try: + try: + filename = hooks.build_wheel(td, {}) + log.info('build_wheel returned %r', filename) + except Exception: + log.info('Failure in build_wheel', exc_info=True) + return False + + if not filename.endswith('.whl'): + log.error("Filename %s doesn't have .whl extension", filename) + return False + + path = pjoin(td, filename) + if isfile(path): + log.info("Output file %s exists", path) + else: + log.error("Output file %s does not exist", path) + return False + + if zipfile.is_zipfile(path): + log.info("Output file is a zip file") + else: + log.error("Output file is not a zip file") + return False + + finally: + shutil.rmtree(td) + + return True + + +def check(source_dir): + pyproject = pjoin(source_dir, 'pyproject.toml') + if isfile(pyproject): + log.info('Found pyproject.toml') + else: + log.error('Missing pyproject.toml') + return False + + try: + with open(pyproject) as f: + pyproject_data = toml_load(f) + # Ensure the mandatory data can be loaded + buildsys = pyproject_data['build-system'] + requires = buildsys['requires'] + backend = buildsys['build-backend'] + log.info('Loaded pyproject.toml') + except (TomlError, KeyError): + log.error("Invalid pyproject.toml", exc_info=True) + return False + + hooks = Pep517HookCaller(source_dir, backend) + + sdist_ok = check_build_sdist(hooks, requires) + wheel_ok = check_build_wheel(hooks, requires) + + if not sdist_ok: + log.warning('Sdist checks failed; scroll up to see') + if not wheel_ok: + log.warning('Wheel checks failed') + + return sdist_ok + + +def main(argv=None): + ap = argparse.ArgumentParser() + ap.add_argument( + 'source_dir', + help="A directory containing pyproject.toml") + args = ap.parse_args(argv) + + enable_colourful_output() + + ok = check(args.source_dir) + + if ok: + print(ansi('Checks passed', 'green')) + else: + print(ansi('Checks failed', 'red')) + sys.exit(1) + + +ansi_codes = { + 'reset': '\x1b[0m', + 'bold': '\x1b[1m', + 'red': '\x1b[31m', + 'green': '\x1b[32m', +} + + +def ansi(s, attr): + if os.name != 'nt' and sys.stdout.isatty(): + return ansi_codes[attr] + str(s) + ansi_codes['reset'] + else: + return str(s) + + +if __name__ == '__main__': + main() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/colorlog.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/colorlog.py new file mode 100644 index 0000000..69c8a59 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/colorlog.py @@ -0,0 +1,115 @@ +"""Nicer log formatting with colours. + +Code copied from Tornado, Apache licensed. +""" +# Copyright 2012 Facebook +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may +# not use this file except in compliance with the License. You may obtain +# a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. + +import logging +import sys + +try: + import curses +except ImportError: + curses = None + + +def _stderr_supports_color(): + color = False + if curses and hasattr(sys.stderr, 'isatty') and sys.stderr.isatty(): + try: + curses.setupterm() + if curses.tigetnum("colors") > 0: + color = True + except Exception: + pass + return color + + +class LogFormatter(logging.Formatter): + """Log formatter with colour support + """ + DEFAULT_COLORS = { + logging.INFO: 2, # Green + logging.WARNING: 3, # Yellow + logging.ERROR: 1, # Red + logging.CRITICAL: 1, + } + + def __init__(self, color=True, datefmt=None): + r""" + :arg bool color: Enables color support. + :arg string fmt: Log message format. + It will be applied to the attributes dict of log records. The + text between ``%(color)s`` and ``%(end_color)s`` will be colored + depending on the level if color support is on. + :arg dict colors: color mappings from logging level to terminal color + code + :arg string datefmt: Datetime format. + Used for formatting ``(asctime)`` placeholder in ``prefix_fmt``. + .. versionchanged:: 3.2 + Added ``fmt`` and ``datefmt`` arguments. + """ + logging.Formatter.__init__(self, datefmt=datefmt) + self._colors = {} + if color and _stderr_supports_color(): + # The curses module has some str/bytes confusion in + # python3. Until version 3.2.3, most methods return + # bytes, but only accept strings. In addition, we want to + # output these strings with the logging module, which + # works with unicode strings. The explicit calls to + # unicode() below are harmless in python2 but will do the + # right conversion in python 3. + fg_color = (curses.tigetstr("setaf") or + curses.tigetstr("setf") or "") + if (3, 0) < sys.version_info < (3, 2, 3): + fg_color = str(fg_color, "ascii") + + for levelno, code in self.DEFAULT_COLORS.items(): + self._colors[levelno] = str( + curses.tparm(fg_color, code), "ascii") + self._normal = str(curses.tigetstr("sgr0"), "ascii") + + scr = curses.initscr() + self.termwidth = scr.getmaxyx()[1] + curses.endwin() + else: + self._normal = '' + # Default width is usually 80, but too wide is + # worse than too narrow + self.termwidth = 70 + + def formatMessage(self, record): + mlen = len(record.message) + right_text = '{initial}-{name}'.format(initial=record.levelname[0], + name=record.name) + if mlen + len(right_text) < self.termwidth: + space = ' ' * (self.termwidth - (mlen + len(right_text))) + else: + space = ' ' + + if record.levelno in self._colors: + start_color = self._colors[record.levelno] + end_color = self._normal + else: + start_color = end_color = '' + + return record.message + space + start_color + right_text + end_color + + +def enable_colourful_output(level=logging.INFO): + handler = logging.StreamHandler() + handler.setFormatter(LogFormatter()) + logging.root.addHandler(handler) + logging.root.setLevel(level) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/compat.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/compat.py new file mode 100644 index 0000000..01c66fc --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/compat.py @@ -0,0 +1,23 @@ +"""Handle reading and writing JSON in UTF-8, on Python 3 and 2.""" +import json +import sys + +if sys.version_info[0] >= 3: + # Python 3 + def write_json(obj, path, **kwargs): + with open(path, 'w', encoding='utf-8') as f: + json.dump(obj, f, **kwargs) + + def read_json(path): + with open(path, 'r', encoding='utf-8') as f: + return json.load(f) + +else: + # Python 2 + def write_json(obj, path, **kwargs): + with open(path, 'wb') as f: + json.dump(obj, f, encoding='utf-8', **kwargs) + + def read_json(path): + with open(path, 'rb') as f: + return json.load(f) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/envbuild.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/envbuild.py new file mode 100644 index 0000000..f7ac5f4 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/envbuild.py @@ -0,0 +1,158 @@ +"""Build wheels/sdists by installing build deps to a temporary environment. +""" + +import os +import logging +from pip._vendor import pytoml +import shutil +from subprocess import check_call +import sys +from sysconfig import get_paths +from tempfile import mkdtemp + +from .wrappers import Pep517HookCaller + +log = logging.getLogger(__name__) + + +def _load_pyproject(source_dir): + with open(os.path.join(source_dir, 'pyproject.toml')) as f: + pyproject_data = pytoml.load(f) + buildsys = pyproject_data['build-system'] + return buildsys['requires'], buildsys['build-backend'] + + +class BuildEnvironment(object): + """Context manager to install build deps in a simple temporary environment + + Based on code I wrote for pip, which is MIT licensed. + """ + # Copyright (c) 2008-2016 The pip developers (see AUTHORS.txt file) + # + # Permission is hereby granted, free of charge, to any person obtaining + # a copy of this software and associated documentation files (the + # "Software"), to deal in the Software without restriction, including + # without limitation the rights to use, copy, modify, merge, publish, + # distribute, sublicense, and/or sell copies of the Software, and to + # permit persons to whom the Software is furnished to do so, subject to + # the following conditions: + # + # The above copyright notice and this permission notice shall be + # included in all copies or substantial portions of the Software. + # + # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE + # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION + # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION + # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + path = None + + def __init__(self, cleanup=True): + self._cleanup = cleanup + + def __enter__(self): + self.path = mkdtemp(prefix='pep517-build-env-') + log.info('Temporary build environment: %s', self.path) + + self.save_path = os.environ.get('PATH', None) + self.save_pythonpath = os.environ.get('PYTHONPATH', None) + + install_scheme = 'nt' if (os.name == 'nt') else 'posix_prefix' + install_dirs = get_paths(install_scheme, vars={ + 'base': self.path, + 'platbase': self.path, + }) + + scripts = install_dirs['scripts'] + if self.save_path: + os.environ['PATH'] = scripts + os.pathsep + self.save_path + else: + os.environ['PATH'] = scripts + os.pathsep + os.defpath + + if install_dirs['purelib'] == install_dirs['platlib']: + lib_dirs = install_dirs['purelib'] + else: + lib_dirs = install_dirs['purelib'] + os.pathsep + \ + install_dirs['platlib'] + if self.save_pythonpath: + os.environ['PYTHONPATH'] = lib_dirs + os.pathsep + \ + self.save_pythonpath + else: + os.environ['PYTHONPATH'] = lib_dirs + + return self + + def pip_install(self, reqs): + """Install dependencies into this env by calling pip in a subprocess""" + if not reqs: + return + log.info('Calling pip to install %s', reqs) + check_call([ + sys.executable, '-m', 'pip', 'install', '--ignore-installed', + '--prefix', self.path] + list(reqs)) + + def __exit__(self, exc_type, exc_val, exc_tb): + needs_cleanup = ( + self._cleanup and + self.path is not None and + os.path.isdir(self.path) + ) + if needs_cleanup: + shutil.rmtree(self.path) + + if self.save_path is None: + os.environ.pop('PATH', None) + else: + os.environ['PATH'] = self.save_path + + if self.save_pythonpath is None: + os.environ.pop('PYTHONPATH', None) + else: + os.environ['PYTHONPATH'] = self.save_pythonpath + + +def build_wheel(source_dir, wheel_dir, config_settings=None): + """Build a wheel from a source directory using PEP 517 hooks. + + :param str source_dir: Source directory containing pyproject.toml + :param str wheel_dir: Target directory to create wheel in + :param dict config_settings: Options to pass to build backend + + This is a blocking function which will run pip in a subprocess to install + build requirements. + """ + if config_settings is None: + config_settings = {} + requires, backend = _load_pyproject(source_dir) + hooks = Pep517HookCaller(source_dir, backend) + + with BuildEnvironment() as env: + env.pip_install(requires) + reqs = hooks.get_requires_for_build_wheel(config_settings) + env.pip_install(reqs) + return hooks.build_wheel(wheel_dir, config_settings) + + +def build_sdist(source_dir, sdist_dir, config_settings=None): + """Build an sdist from a source directory using PEP 517 hooks. + + :param str source_dir: Source directory containing pyproject.toml + :param str sdist_dir: Target directory to place sdist in + :param dict config_settings: Options to pass to build backend + + This is a blocking function which will run pip in a subprocess to install + build requirements. + """ + if config_settings is None: + config_settings = {} + requires, backend = _load_pyproject(source_dir) + hooks = Pep517HookCaller(source_dir, backend) + + with BuildEnvironment() as env: + env.pip_install(requires) + reqs = hooks.get_requires_for_build_sdist(config_settings) + env.pip_install(reqs) + return hooks.build_sdist(sdist_dir, config_settings) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/wrappers.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/wrappers.py new file mode 100644 index 0000000..b14b899 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pep517/wrappers.py @@ -0,0 +1,163 @@ +from contextlib import contextmanager +import os +from os.path import dirname, abspath, join as pjoin +import shutil +from subprocess import check_call +import sys +from tempfile import mkdtemp + +from . import compat + +_in_proc_script = pjoin(dirname(abspath(__file__)), '_in_process.py') + + +@contextmanager +def tempdir(): + td = mkdtemp() + try: + yield td + finally: + shutil.rmtree(td) + + +class BackendUnavailable(Exception): + """Will be raised if the backend cannot be imported in the hook process.""" + + +class UnsupportedOperation(Exception): + """May be raised by build_sdist if the backend indicates that it can't.""" + + +def default_subprocess_runner(cmd, cwd=None, extra_environ=None): + """The default method of calling the wrapper subprocess.""" + env = os.environ.copy() + if extra_environ: + env.update(extra_environ) + + check_call(cmd, cwd=cwd, env=env) + + +class Pep517HookCaller(object): + """A wrapper around a source directory to be built with a PEP 517 backend. + + source_dir : The path to the source directory, containing pyproject.toml. + backend : The build backend spec, as per PEP 517, from pyproject.toml. + """ + def __init__(self, source_dir, build_backend): + self.source_dir = abspath(source_dir) + self.build_backend = build_backend + self._subprocess_runner = default_subprocess_runner + + # TODO: Is this over-engineered? Maybe frontends only need to + # set this when creating the wrapper, not on every call. + @contextmanager + def subprocess_runner(self, runner): + prev = self._subprocess_runner + self._subprocess_runner = runner + yield + self._subprocess_runner = prev + + def get_requires_for_build_wheel(self, config_settings=None): + """Identify packages required for building a wheel + + Returns a list of dependency specifications, e.g.: + ["wheel >= 0.25", "setuptools"] + + This does not include requirements specified in pyproject.toml. + It returns the result of calling the equivalently named hook in a + subprocess. + """ + return self._call_hook('get_requires_for_build_wheel', { + 'config_settings': config_settings + }) + + def prepare_metadata_for_build_wheel( + self, metadata_directory, config_settings=None): + """Prepare a *.dist-info folder with metadata for this project. + + Returns the name of the newly created folder. + + If the build backend defines a hook with this name, it will be called + in a subprocess. If not, the backend will be asked to build a wheel, + and the dist-info extracted from that. + """ + return self._call_hook('prepare_metadata_for_build_wheel', { + 'metadata_directory': abspath(metadata_directory), + 'config_settings': config_settings, + }) + + def build_wheel( + self, wheel_directory, config_settings=None, + metadata_directory=None): + """Build a wheel from this project. + + Returns the name of the newly created file. + + In general, this will call the 'build_wheel' hook in the backend. + However, if that was previously called by + 'prepare_metadata_for_build_wheel', and the same metadata_directory is + used, the previously built wheel will be copied to wheel_directory. + """ + if metadata_directory is not None: + metadata_directory = abspath(metadata_directory) + return self._call_hook('build_wheel', { + 'wheel_directory': abspath(wheel_directory), + 'config_settings': config_settings, + 'metadata_directory': metadata_directory, + }) + + def get_requires_for_build_sdist(self, config_settings=None): + """Identify packages required for building a wheel + + Returns a list of dependency specifications, e.g.: + ["setuptools >= 26"] + + This does not include requirements specified in pyproject.toml. + It returns the result of calling the equivalently named hook in a + subprocess. + """ + return self._call_hook('get_requires_for_build_sdist', { + 'config_settings': config_settings + }) + + def build_sdist(self, sdist_directory, config_settings=None): + """Build an sdist from this project. + + Returns the name of the newly created file. + + This calls the 'build_sdist' backend hook in a subprocess. + """ + return self._call_hook('build_sdist', { + 'sdist_directory': abspath(sdist_directory), + 'config_settings': config_settings, + }) + + def _call_hook(self, hook_name, kwargs): + # On Python 2, pytoml returns Unicode values (which is correct) but the + # environment passed to check_call needs to contain string values. We + # convert here by encoding using ASCII (the backend can only contain + # letters, digits and _, . and : characters, and will be used as a + # Python identifier, so non-ASCII content is wrong on Python 2 in + # any case). + if sys.version_info[0] == 2: + build_backend = self.build_backend.encode('ASCII') + else: + build_backend = self.build_backend + + with tempdir() as td: + compat.write_json({'kwargs': kwargs}, pjoin(td, 'input.json'), + indent=2) + + # Run the hook in a subprocess + self._subprocess_runner( + [sys.executable, _in_proc_script, hook_name, td], + cwd=self.source_dir, + extra_environ={'PEP517_BUILD_BACKEND': build_backend} + ) + + data = compat.read_json(pjoin(td, 'output.json')) + if data.get('unsupported'): + raise UnsupportedOperation + if data.get('no_backend'): + raise BackendUnavailable + return data['return_val'] diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pkg_resources/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pkg_resources/__init__.py new file mode 100644 index 0000000..fdd40de --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pkg_resources/__init__.py @@ -0,0 +1,3286 @@ +# coding: utf-8 +""" +Package resource API +-------------------- + +A resource is a logical file contained within a package, or a logical +subdirectory thereof. The package resource API expects resource names +to have their path parts separated with ``/``, *not* whatever the local +path separator is. Do not use os.path operations to manipulate resource +names being passed into the API. + +The package resource API is designed to work with normal filesystem packages, +.egg files, and unpacked .egg files. It can also work in a limited way with +.zip files and with custom PEP 302 loaders that support the ``get_data()`` +method. +""" + +from __future__ import absolute_import + +import sys +import os +import io +import time +import re +import types +import zipfile +import zipimport +import warnings +import stat +import functools +import pkgutil +import operator +import platform +import collections +import plistlib +import email.parser +import errno +import tempfile +import textwrap +import itertools +import inspect +import ntpath +import posixpath +from pkgutil import get_importer + +try: + import _imp +except ImportError: + # Python 3.2 compatibility + import imp as _imp + +try: + FileExistsError +except NameError: + FileExistsError = OSError + +from pip._vendor import six +from pip._vendor.six.moves import urllib, map, filter + +# capture these to bypass sandboxing +from os import utime +try: + from os import mkdir, rename, unlink + WRITE_SUPPORT = True +except ImportError: + # no write support, probably under GAE + WRITE_SUPPORT = False + +from os import open as os_open +from os.path import isdir, split + +try: + import importlib.machinery as importlib_machinery + # access attribute to force import under delayed import mechanisms. + importlib_machinery.__name__ +except ImportError: + importlib_machinery = None + +from . import py31compat +from pip._vendor import appdirs +from pip._vendor import packaging +__import__('pip._vendor.packaging.version') +__import__('pip._vendor.packaging.specifiers') +__import__('pip._vendor.packaging.requirements') +__import__('pip._vendor.packaging.markers') + + +__metaclass__ = type + + +if (3, 0) < sys.version_info < (3, 4): + raise RuntimeError("Python 3.4 or later is required") + +if six.PY2: + # Those builtin exceptions are only defined in Python 3 + PermissionError = None + NotADirectoryError = None + +# declare some globals that will be defined later to +# satisfy the linters. +require = None +working_set = None +add_activation_listener = None +resources_stream = None +cleanup_resources = None +resource_dir = None +resource_stream = None +set_extraction_path = None +resource_isdir = None +resource_string = None +iter_entry_points = None +resource_listdir = None +resource_filename = None +resource_exists = None +_distribution_finders = None +_namespace_handlers = None +_namespace_packages = None + + +class PEP440Warning(RuntimeWarning): + """ + Used when there is an issue with a version or specifier not complying with + PEP 440. + """ + + +def parse_version(v): + try: + return packaging.version.Version(v) + except packaging.version.InvalidVersion: + return packaging.version.LegacyVersion(v) + + +_state_vars = {} + + +def _declare_state(vartype, **kw): + globals().update(kw) + _state_vars.update(dict.fromkeys(kw, vartype)) + + +def __getstate__(): + state = {} + g = globals() + for k, v in _state_vars.items(): + state[k] = g['_sget_' + v](g[k]) + return state + + +def __setstate__(state): + g = globals() + for k, v in state.items(): + g['_sset_' + _state_vars[k]](k, g[k], v) + return state + + +def _sget_dict(val): + return val.copy() + + +def _sset_dict(key, ob, state): + ob.clear() + ob.update(state) + + +def _sget_object(val): + return val.__getstate__() + + +def _sset_object(key, ob, state): + ob.__setstate__(state) + + +_sget_none = _sset_none = lambda *args: None + + +def get_supported_platform(): + """Return this platform's maximum compatible version. + + distutils.util.get_platform() normally reports the minimum version + of Mac OS X that would be required to *use* extensions produced by + distutils. But what we want when checking compatibility is to know the + version of Mac OS X that we are *running*. To allow usage of packages that + explicitly require a newer version of Mac OS X, we must also know the + current version of the OS. + + If this condition occurs for any other platform with a version in its + platform strings, this function should be extended accordingly. + """ + plat = get_build_platform() + m = macosVersionString.match(plat) + if m is not None and sys.platform == "darwin": + try: + plat = 'macosx-%s-%s' % ('.'.join(_macosx_vers()[:2]), m.group(3)) + except ValueError: + # not Mac OS X + pass + return plat + + +__all__ = [ + # Basic resource access and distribution/entry point discovery + 'require', 'run_script', 'get_provider', 'get_distribution', + 'load_entry_point', 'get_entry_map', 'get_entry_info', + 'iter_entry_points', + 'resource_string', 'resource_stream', 'resource_filename', + 'resource_listdir', 'resource_exists', 'resource_isdir', + + # Environmental control + 'declare_namespace', 'working_set', 'add_activation_listener', + 'find_distributions', 'set_extraction_path', 'cleanup_resources', + 'get_default_cache', + + # Primary implementation classes + 'Environment', 'WorkingSet', 'ResourceManager', + 'Distribution', 'Requirement', 'EntryPoint', + + # Exceptions + 'ResolutionError', 'VersionConflict', 'DistributionNotFound', + 'UnknownExtra', 'ExtractionError', + + # Warnings + 'PEP440Warning', + + # Parsing functions and string utilities + 'parse_requirements', 'parse_version', 'safe_name', 'safe_version', + 'get_platform', 'compatible_platforms', 'yield_lines', 'split_sections', + 'safe_extra', 'to_filename', 'invalid_marker', 'evaluate_marker', + + # filesystem utilities + 'ensure_directory', 'normalize_path', + + # Distribution "precedence" constants + 'EGG_DIST', 'BINARY_DIST', 'SOURCE_DIST', 'CHECKOUT_DIST', 'DEVELOP_DIST', + + # "Provider" interfaces, implementations, and registration/lookup APIs + 'IMetadataProvider', 'IResourceProvider', 'FileMetadata', + 'PathMetadata', 'EggMetadata', 'EmptyProvider', 'empty_provider', + 'NullProvider', 'EggProvider', 'DefaultProvider', 'ZipProvider', + 'register_finder', 'register_namespace_handler', 'register_loader_type', + 'fixup_namespace_packages', 'get_importer', + + # Warnings + 'PkgResourcesDeprecationWarning', + + # Deprecated/backward compatibility only + 'run_main', 'AvailableDistributions', +] + + +class ResolutionError(Exception): + """Abstract base for dependency resolution errors""" + + def __repr__(self): + return self.__class__.__name__ + repr(self.args) + + +class VersionConflict(ResolutionError): + """ + An already-installed version conflicts with the requested version. + + Should be initialized with the installed Distribution and the requested + Requirement. + """ + + _template = "{self.dist} is installed but {self.req} is required" + + @property + def dist(self): + return self.args[0] + + @property + def req(self): + return self.args[1] + + def report(self): + return self._template.format(**locals()) + + def with_context(self, required_by): + """ + If required_by is non-empty, return a version of self that is a + ContextualVersionConflict. + """ + if not required_by: + return self + args = self.args + (required_by,) + return ContextualVersionConflict(*args) + + +class ContextualVersionConflict(VersionConflict): + """ + A VersionConflict that accepts a third parameter, the set of the + requirements that required the installed Distribution. + """ + + _template = VersionConflict._template + ' by {self.required_by}' + + @property + def required_by(self): + return self.args[2] + + +class DistributionNotFound(ResolutionError): + """A requested distribution was not found""" + + _template = ("The '{self.req}' distribution was not found " + "and is required by {self.requirers_str}") + + @property + def req(self): + return self.args[0] + + @property + def requirers(self): + return self.args[1] + + @property + def requirers_str(self): + if not self.requirers: + return 'the application' + return ', '.join(self.requirers) + + def report(self): + return self._template.format(**locals()) + + def __str__(self): + return self.report() + + +class UnknownExtra(ResolutionError): + """Distribution doesn't have an "extra feature" of the given name""" + + +_provider_factories = {} + +PY_MAJOR = sys.version[:3] +EGG_DIST = 3 +BINARY_DIST = 2 +SOURCE_DIST = 1 +CHECKOUT_DIST = 0 +DEVELOP_DIST = -1 + + +def register_loader_type(loader_type, provider_factory): + """Register `provider_factory` to make providers for `loader_type` + + `loader_type` is the type or class of a PEP 302 ``module.__loader__``, + and `provider_factory` is a function that, passed a *module* object, + returns an ``IResourceProvider`` for that module. + """ + _provider_factories[loader_type] = provider_factory + + +def get_provider(moduleOrReq): + """Return an IResourceProvider for the named module or requirement""" + if isinstance(moduleOrReq, Requirement): + return working_set.find(moduleOrReq) or require(str(moduleOrReq))[0] + try: + module = sys.modules[moduleOrReq] + except KeyError: + __import__(moduleOrReq) + module = sys.modules[moduleOrReq] + loader = getattr(module, '__loader__', None) + return _find_adapter(_provider_factories, loader)(module) + + +def _macosx_vers(_cache=[]): + if not _cache: + version = platform.mac_ver()[0] + # fallback for MacPorts + if version == '': + plist = '/System/Library/CoreServices/SystemVersion.plist' + if os.path.exists(plist): + if hasattr(plistlib, 'readPlist'): + plist_content = plistlib.readPlist(plist) + if 'ProductVersion' in plist_content: + version = plist_content['ProductVersion'] + + _cache.append(version.split('.')) + return _cache[0] + + +def _macosx_arch(machine): + return {'PowerPC': 'ppc', 'Power_Macintosh': 'ppc'}.get(machine, machine) + + +def get_build_platform(): + """Return this platform's string for platform-specific distributions + + XXX Currently this is the same as ``distutils.util.get_platform()``, but it + needs some hacks for Linux and Mac OS X. + """ + from sysconfig import get_platform + + plat = get_platform() + if sys.platform == "darwin" and not plat.startswith('macosx-'): + try: + version = _macosx_vers() + machine = os.uname()[4].replace(" ", "_") + return "macosx-%d.%d-%s" % ( + int(version[0]), int(version[1]), + _macosx_arch(machine), + ) + except ValueError: + # if someone is running a non-Mac darwin system, this will fall + # through to the default implementation + pass + return plat + + +macosVersionString = re.compile(r"macosx-(\d+)\.(\d+)-(.*)") +darwinVersionString = re.compile(r"darwin-(\d+)\.(\d+)\.(\d+)-(.*)") +# XXX backward compat +get_platform = get_build_platform + + +def compatible_platforms(provided, required): + """Can code for the `provided` platform run on the `required` platform? + + Returns true if either platform is ``None``, or the platforms are equal. + + XXX Needs compatibility checks for Linux and other unixy OSes. + """ + if provided is None or required is None or provided == required: + # easy case + return True + + # Mac OS X special cases + reqMac = macosVersionString.match(required) + if reqMac: + provMac = macosVersionString.match(provided) + + # is this a Mac package? + if not provMac: + # this is backwards compatibility for packages built before + # setuptools 0.6. All packages built after this point will + # use the new macosx designation. + provDarwin = darwinVersionString.match(provided) + if provDarwin: + dversion = int(provDarwin.group(1)) + macosversion = "%s.%s" % (reqMac.group(1), reqMac.group(2)) + if dversion == 7 and macosversion >= "10.3" or \ + dversion == 8 and macosversion >= "10.4": + return True + # egg isn't macosx or legacy darwin + return False + + # are they the same major version and machine type? + if provMac.group(1) != reqMac.group(1) or \ + provMac.group(3) != reqMac.group(3): + return False + + # is the required OS major update >= the provided one? + if int(provMac.group(2)) > int(reqMac.group(2)): + return False + + return True + + # XXX Linux and other platforms' special cases should go here + return False + + +def run_script(dist_spec, script_name): + """Locate distribution `dist_spec` and run its `script_name` script""" + ns = sys._getframe(1).f_globals + name = ns['__name__'] + ns.clear() + ns['__name__'] = name + require(dist_spec)[0].run_script(script_name, ns) + + +# backward compatibility +run_main = run_script + + +def get_distribution(dist): + """Return a current distribution object for a Requirement or string""" + if isinstance(dist, six.string_types): + dist = Requirement.parse(dist) + if isinstance(dist, Requirement): + dist = get_provider(dist) + if not isinstance(dist, Distribution): + raise TypeError("Expected string, Requirement, or Distribution", dist) + return dist + + +def load_entry_point(dist, group, name): + """Return `name` entry point of `group` for `dist` or raise ImportError""" + return get_distribution(dist).load_entry_point(group, name) + + +def get_entry_map(dist, group=None): + """Return the entry point map for `group`, or the full entry map""" + return get_distribution(dist).get_entry_map(group) + + +def get_entry_info(dist, group, name): + """Return the EntryPoint object for `group`+`name`, or ``None``""" + return get_distribution(dist).get_entry_info(group, name) + + +class IMetadataProvider: + def has_metadata(name): + """Does the package's distribution contain the named metadata?""" + + def get_metadata(name): + """The named metadata resource as a string""" + + def get_metadata_lines(name): + """Yield named metadata resource as list of non-blank non-comment lines + + Leading and trailing whitespace is stripped from each line, and lines + with ``#`` as the first non-blank character are omitted.""" + + def metadata_isdir(name): + """Is the named metadata a directory? (like ``os.path.isdir()``)""" + + def metadata_listdir(name): + """List of metadata names in the directory (like ``os.listdir()``)""" + + def run_script(script_name, namespace): + """Execute the named script in the supplied namespace dictionary""" + + +class IResourceProvider(IMetadataProvider): + """An object that provides access to package resources""" + + def get_resource_filename(manager, resource_name): + """Return a true filesystem path for `resource_name` + + `manager` must be an ``IResourceManager``""" + + def get_resource_stream(manager, resource_name): + """Return a readable file-like object for `resource_name` + + `manager` must be an ``IResourceManager``""" + + def get_resource_string(manager, resource_name): + """Return a string containing the contents of `resource_name` + + `manager` must be an ``IResourceManager``""" + + def has_resource(resource_name): + """Does the package contain the named resource?""" + + def resource_isdir(resource_name): + """Is the named resource a directory? (like ``os.path.isdir()``)""" + + def resource_listdir(resource_name): + """List of resource names in the directory (like ``os.listdir()``)""" + + +class WorkingSet: + """A collection of active distributions on sys.path (or a similar list)""" + + def __init__(self, entries=None): + """Create working set from list of path entries (default=sys.path)""" + self.entries = [] + self.entry_keys = {} + self.by_key = {} + self.callbacks = [] + + if entries is None: + entries = sys.path + + for entry in entries: + self.add_entry(entry) + + @classmethod + def _build_master(cls): + """ + Prepare the master working set. + """ + ws = cls() + try: + from __main__ import __requires__ + except ImportError: + # The main program does not list any requirements + return ws + + # ensure the requirements are met + try: + ws.require(__requires__) + except VersionConflict: + return cls._build_from_requirements(__requires__) + + return ws + + @classmethod + def _build_from_requirements(cls, req_spec): + """ + Build a working set from a requirement spec. Rewrites sys.path. + """ + # try it without defaults already on sys.path + # by starting with an empty path + ws = cls([]) + reqs = parse_requirements(req_spec) + dists = ws.resolve(reqs, Environment()) + for dist in dists: + ws.add(dist) + + # add any missing entries from sys.path + for entry in sys.path: + if entry not in ws.entries: + ws.add_entry(entry) + + # then copy back to sys.path + sys.path[:] = ws.entries + return ws + + def add_entry(self, entry): + """Add a path item to ``.entries``, finding any distributions on it + + ``find_distributions(entry, True)`` is used to find distributions + corresponding to the path entry, and they are added. `entry` is + always appended to ``.entries``, even if it is already present. + (This is because ``sys.path`` can contain the same value more than + once, and the ``.entries`` of the ``sys.path`` WorkingSet should always + equal ``sys.path``.) + """ + self.entry_keys.setdefault(entry, []) + self.entries.append(entry) + for dist in find_distributions(entry, True): + self.add(dist, entry, False) + + def __contains__(self, dist): + """True if `dist` is the active distribution for its project""" + return self.by_key.get(dist.key) == dist + + def find(self, req): + """Find a distribution matching requirement `req` + + If there is an active distribution for the requested project, this + returns it as long as it meets the version requirement specified by + `req`. But, if there is an active distribution for the project and it + does *not* meet the `req` requirement, ``VersionConflict`` is raised. + If there is no active distribution for the requested project, ``None`` + is returned. + """ + dist = self.by_key.get(req.key) + if dist is not None and dist not in req: + # XXX add more info + raise VersionConflict(dist, req) + return dist + + def iter_entry_points(self, group, name=None): + """Yield entry point objects from `group` matching `name` + + If `name` is None, yields all entry points in `group` from all + distributions in the working set, otherwise only ones matching + both `group` and `name` are yielded (in distribution order). + """ + return ( + entry + for dist in self + for entry in dist.get_entry_map(group).values() + if name is None or name == entry.name + ) + + def run_script(self, requires, script_name): + """Locate distribution for `requires` and run `script_name` script""" + ns = sys._getframe(1).f_globals + name = ns['__name__'] + ns.clear() + ns['__name__'] = name + self.require(requires)[0].run_script(script_name, ns) + + def __iter__(self): + """Yield distributions for non-duplicate projects in the working set + + The yield order is the order in which the items' path entries were + added to the working set. + """ + seen = {} + for item in self.entries: + if item not in self.entry_keys: + # workaround a cache issue + continue + + for key in self.entry_keys[item]: + if key not in seen: + seen[key] = 1 + yield self.by_key[key] + + def add(self, dist, entry=None, insert=True, replace=False): + """Add `dist` to working set, associated with `entry` + + If `entry` is unspecified, it defaults to the ``.location`` of `dist`. + On exit from this routine, `entry` is added to the end of the working + set's ``.entries`` (if it wasn't already present). + + `dist` is only added to the working set if it's for a project that + doesn't already have a distribution in the set, unless `replace=True`. + If it's added, any callbacks registered with the ``subscribe()`` method + will be called. + """ + if insert: + dist.insert_on(self.entries, entry, replace=replace) + + if entry is None: + entry = dist.location + keys = self.entry_keys.setdefault(entry, []) + keys2 = self.entry_keys.setdefault(dist.location, []) + if not replace and dist.key in self.by_key: + # ignore hidden distros + return + + self.by_key[dist.key] = dist + if dist.key not in keys: + keys.append(dist.key) + if dist.key not in keys2: + keys2.append(dist.key) + self._added_new(dist) + + def resolve(self, requirements, env=None, installer=None, + replace_conflicting=False, extras=None): + """List all distributions needed to (recursively) meet `requirements` + + `requirements` must be a sequence of ``Requirement`` objects. `env`, + if supplied, should be an ``Environment`` instance. If + not supplied, it defaults to all distributions available within any + entry or distribution in the working set. `installer`, if supplied, + will be invoked with each requirement that cannot be met by an + already-installed distribution; it should return a ``Distribution`` or + ``None``. + + Unless `replace_conflicting=True`, raises a VersionConflict exception + if + any requirements are found on the path that have the correct name but + the wrong version. Otherwise, if an `installer` is supplied it will be + invoked to obtain the correct version of the requirement and activate + it. + + `extras` is a list of the extras to be used with these requirements. + This is important because extra requirements may look like `my_req; + extra = "my_extra"`, which would otherwise be interpreted as a purely + optional requirement. Instead, we want to be able to assert that these + requirements are truly required. + """ + + # set up the stack + requirements = list(requirements)[::-1] + # set of processed requirements + processed = {} + # key -> dist + best = {} + to_activate = [] + + req_extras = _ReqExtras() + + # Mapping of requirement to set of distributions that required it; + # useful for reporting info about conflicts. + required_by = collections.defaultdict(set) + + while requirements: + # process dependencies breadth-first + req = requirements.pop(0) + if req in processed: + # Ignore cyclic or redundant dependencies + continue + + if not req_extras.markers_pass(req, extras): + continue + + dist = best.get(req.key) + if dist is None: + # Find the best distribution and add it to the map + dist = self.by_key.get(req.key) + if dist is None or (dist not in req and replace_conflicting): + ws = self + if env is None: + if dist is None: + env = Environment(self.entries) + else: + # Use an empty environment and workingset to avoid + # any further conflicts with the conflicting + # distribution + env = Environment([]) + ws = WorkingSet([]) + dist = best[req.key] = env.best_match( + req, ws, installer, + replace_conflicting=replace_conflicting + ) + if dist is None: + requirers = required_by.get(req, None) + raise DistributionNotFound(req, requirers) + to_activate.append(dist) + if dist not in req: + # Oops, the "best" so far conflicts with a dependency + dependent_req = required_by[req] + raise VersionConflict(dist, req).with_context(dependent_req) + + # push the new requirements onto the stack + new_requirements = dist.requires(req.extras)[::-1] + requirements.extend(new_requirements) + + # Register the new requirements needed by req + for new_requirement in new_requirements: + required_by[new_requirement].add(req.project_name) + req_extras[new_requirement] = req.extras + + processed[req] = True + + # return list of distros to activate + return to_activate + + def find_plugins( + self, plugin_env, full_env=None, installer=None, fallback=True): + """Find all activatable distributions in `plugin_env` + + Example usage:: + + distributions, errors = working_set.find_plugins( + Environment(plugin_dirlist) + ) + # add plugins+libs to sys.path + map(working_set.add, distributions) + # display errors + print('Could not load', errors) + + The `plugin_env` should be an ``Environment`` instance that contains + only distributions that are in the project's "plugin directory" or + directories. The `full_env`, if supplied, should be an ``Environment`` + contains all currently-available distributions. If `full_env` is not + supplied, one is created automatically from the ``WorkingSet`` this + method is called on, which will typically mean that every directory on + ``sys.path`` will be scanned for distributions. + + `installer` is a standard installer callback as used by the + ``resolve()`` method. The `fallback` flag indicates whether we should + attempt to resolve older versions of a plugin if the newest version + cannot be resolved. + + This method returns a 2-tuple: (`distributions`, `error_info`), where + `distributions` is a list of the distributions found in `plugin_env` + that were loadable, along with any other distributions that are needed + to resolve their dependencies. `error_info` is a dictionary mapping + unloadable plugin distributions to an exception instance describing the + error that occurred. Usually this will be a ``DistributionNotFound`` or + ``VersionConflict`` instance. + """ + + plugin_projects = list(plugin_env) + # scan project names in alphabetic order + plugin_projects.sort() + + error_info = {} + distributions = {} + + if full_env is None: + env = Environment(self.entries) + env += plugin_env + else: + env = full_env + plugin_env + + shadow_set = self.__class__([]) + # put all our entries in shadow_set + list(map(shadow_set.add, self)) + + for project_name in plugin_projects: + + for dist in plugin_env[project_name]: + + req = [dist.as_requirement()] + + try: + resolvees = shadow_set.resolve(req, env, installer) + + except ResolutionError as v: + # save error info + error_info[dist] = v + if fallback: + # try the next older version of project + continue + else: + # give up on this project, keep going + break + + else: + list(map(shadow_set.add, resolvees)) + distributions.update(dict.fromkeys(resolvees)) + + # success, no need to try any more versions of this project + break + + distributions = list(distributions) + distributions.sort() + + return distributions, error_info + + def require(self, *requirements): + """Ensure that distributions matching `requirements` are activated + + `requirements` must be a string or a (possibly-nested) sequence + thereof, specifying the distributions and versions required. The + return value is a sequence of the distributions that needed to be + activated to fulfill the requirements; all relevant distributions are + included, even if they were already activated in this working set. + """ + needed = self.resolve(parse_requirements(requirements)) + + for dist in needed: + self.add(dist) + + return needed + + def subscribe(self, callback, existing=True): + """Invoke `callback` for all distributions + + If `existing=True` (default), + call on all existing ones, as well. + """ + if callback in self.callbacks: + return + self.callbacks.append(callback) + if not existing: + return + for dist in self: + callback(dist) + + def _added_new(self, dist): + for callback in self.callbacks: + callback(dist) + + def __getstate__(self): + return ( + self.entries[:], self.entry_keys.copy(), self.by_key.copy(), + self.callbacks[:] + ) + + def __setstate__(self, e_k_b_c): + entries, keys, by_key, callbacks = e_k_b_c + self.entries = entries[:] + self.entry_keys = keys.copy() + self.by_key = by_key.copy() + self.callbacks = callbacks[:] + + +class _ReqExtras(dict): + """ + Map each requirement to the extras that demanded it. + """ + + def markers_pass(self, req, extras=None): + """ + Evaluate markers for req against each extra that + demanded it. + + Return False if the req has a marker and fails + evaluation. Otherwise, return True. + """ + extra_evals = ( + req.marker.evaluate({'extra': extra}) + for extra in self.get(req, ()) + (extras or (None,)) + ) + return not req.marker or any(extra_evals) + + +class Environment: + """Searchable snapshot of distributions on a search path""" + + def __init__( + self, search_path=None, platform=get_supported_platform(), + python=PY_MAJOR): + """Snapshot distributions available on a search path + + Any distributions found on `search_path` are added to the environment. + `search_path` should be a sequence of ``sys.path`` items. If not + supplied, ``sys.path`` is used. + + `platform` is an optional string specifying the name of the platform + that platform-specific distributions must be compatible with. If + unspecified, it defaults to the current platform. `python` is an + optional string naming the desired version of Python (e.g. ``'3.6'``); + it defaults to the current version. + + You may explicitly set `platform` (and/or `python`) to ``None`` if you + wish to map *all* distributions, not just those compatible with the + running platform or Python version. + """ + self._distmap = {} + self.platform = platform + self.python = python + self.scan(search_path) + + def can_add(self, dist): + """Is distribution `dist` acceptable for this environment? + + The distribution must match the platform and python version + requirements specified when this environment was created, or False + is returned. + """ + py_compat = ( + self.python is None + or dist.py_version is None + or dist.py_version == self.python + ) + return py_compat and compatible_platforms(dist.platform, self.platform) + + def remove(self, dist): + """Remove `dist` from the environment""" + self._distmap[dist.key].remove(dist) + + def scan(self, search_path=None): + """Scan `search_path` for distributions usable in this environment + + Any distributions found are added to the environment. + `search_path` should be a sequence of ``sys.path`` items. If not + supplied, ``sys.path`` is used. Only distributions conforming to + the platform/python version defined at initialization are added. + """ + if search_path is None: + search_path = sys.path + + for item in search_path: + for dist in find_distributions(item): + self.add(dist) + + def __getitem__(self, project_name): + """Return a newest-to-oldest list of distributions for `project_name` + + Uses case-insensitive `project_name` comparison, assuming all the + project's distributions use their project's name converted to all + lowercase as their key. + + """ + distribution_key = project_name.lower() + return self._distmap.get(distribution_key, []) + + def add(self, dist): + """Add `dist` if we ``can_add()`` it and it has not already been added + """ + if self.can_add(dist) and dist.has_version(): + dists = self._distmap.setdefault(dist.key, []) + if dist not in dists: + dists.append(dist) + dists.sort(key=operator.attrgetter('hashcmp'), reverse=True) + + def best_match( + self, req, working_set, installer=None, replace_conflicting=False): + """Find distribution best matching `req` and usable on `working_set` + + This calls the ``find(req)`` method of the `working_set` to see if a + suitable distribution is already active. (This may raise + ``VersionConflict`` if an unsuitable version of the project is already + active in the specified `working_set`.) If a suitable distribution + isn't active, this method returns the newest distribution in the + environment that meets the ``Requirement`` in `req`. If no suitable + distribution is found, and `installer` is supplied, then the result of + calling the environment's ``obtain(req, installer)`` method will be + returned. + """ + try: + dist = working_set.find(req) + except VersionConflict: + if not replace_conflicting: + raise + dist = None + if dist is not None: + return dist + for dist in self[req.key]: + if dist in req: + return dist + # try to download/install + return self.obtain(req, installer) + + def obtain(self, requirement, installer=None): + """Obtain a distribution matching `requirement` (e.g. via download) + + Obtain a distro that matches requirement (e.g. via download). In the + base ``Environment`` class, this routine just returns + ``installer(requirement)``, unless `installer` is None, in which case + None is returned instead. This method is a hook that allows subclasses + to attempt other ways of obtaining a distribution before falling back + to the `installer` argument.""" + if installer is not None: + return installer(requirement) + + def __iter__(self): + """Yield the unique project names of the available distributions""" + for key in self._distmap.keys(): + if self[key]: + yield key + + def __iadd__(self, other): + """In-place addition of a distribution or environment""" + if isinstance(other, Distribution): + self.add(other) + elif isinstance(other, Environment): + for project in other: + for dist in other[project]: + self.add(dist) + else: + raise TypeError("Can't add %r to environment" % (other,)) + return self + + def __add__(self, other): + """Add an environment or distribution to an environment""" + new = self.__class__([], platform=None, python=None) + for env in self, other: + new += env + return new + + +# XXX backward compatibility +AvailableDistributions = Environment + + +class ExtractionError(RuntimeError): + """An error occurred extracting a resource + + The following attributes are available from instances of this exception: + + manager + The resource manager that raised this exception + + cache_path + The base directory for resource extraction + + original_error + The exception instance that caused extraction to fail + """ + + +class ResourceManager: + """Manage resource extraction and packages""" + extraction_path = None + + def __init__(self): + self.cached_files = {} + + def resource_exists(self, package_or_requirement, resource_name): + """Does the named resource exist?""" + return get_provider(package_or_requirement).has_resource(resource_name) + + def resource_isdir(self, package_or_requirement, resource_name): + """Is the named resource an existing directory?""" + return get_provider(package_or_requirement).resource_isdir( + resource_name + ) + + def resource_filename(self, package_or_requirement, resource_name): + """Return a true filesystem path for specified resource""" + return get_provider(package_or_requirement).get_resource_filename( + self, resource_name + ) + + def resource_stream(self, package_or_requirement, resource_name): + """Return a readable file-like object for specified resource""" + return get_provider(package_or_requirement).get_resource_stream( + self, resource_name + ) + + def resource_string(self, package_or_requirement, resource_name): + """Return specified resource as a string""" + return get_provider(package_or_requirement).get_resource_string( + self, resource_name + ) + + def resource_listdir(self, package_or_requirement, resource_name): + """List the contents of the named resource directory""" + return get_provider(package_or_requirement).resource_listdir( + resource_name + ) + + def extraction_error(self): + """Give an error message for problems extracting file(s)""" + + old_exc = sys.exc_info()[1] + cache_path = self.extraction_path or get_default_cache() + + tmpl = textwrap.dedent(""" + Can't extract file(s) to egg cache + + The following error occurred while trying to extract file(s) + to the Python egg cache: + + {old_exc} + + The Python egg cache directory is currently set to: + + {cache_path} + + Perhaps your account does not have write access to this directory? + You can change the cache directory by setting the PYTHON_EGG_CACHE + environment variable to point to an accessible directory. + """).lstrip() + err = ExtractionError(tmpl.format(**locals())) + err.manager = self + err.cache_path = cache_path + err.original_error = old_exc + raise err + + def get_cache_path(self, archive_name, names=()): + """Return absolute location in cache for `archive_name` and `names` + + The parent directory of the resulting path will be created if it does + not already exist. `archive_name` should be the base filename of the + enclosing egg (which may not be the name of the enclosing zipfile!), + including its ".egg" extension. `names`, if provided, should be a + sequence of path name parts "under" the egg's extraction location. + + This method should only be called by resource providers that need to + obtain an extraction location, and only for names they intend to + extract, as it tracks the generated names for possible cleanup later. + """ + extract_path = self.extraction_path or get_default_cache() + target_path = os.path.join(extract_path, archive_name + '-tmp', *names) + try: + _bypass_ensure_directory(target_path) + except Exception: + self.extraction_error() + + self._warn_unsafe_extraction_path(extract_path) + + self.cached_files[target_path] = 1 + return target_path + + @staticmethod + def _warn_unsafe_extraction_path(path): + """ + If the default extraction path is overridden and set to an insecure + location, such as /tmp, it opens up an opportunity for an attacker to + replace an extracted file with an unauthorized payload. Warn the user + if a known insecure location is used. + + See Distribute #375 for more details. + """ + if os.name == 'nt' and not path.startswith(os.environ['windir']): + # On Windows, permissions are generally restrictive by default + # and temp directories are not writable by other users, so + # bypass the warning. + return + mode = os.stat(path).st_mode + if mode & stat.S_IWOTH or mode & stat.S_IWGRP: + msg = ( + "%s is writable by group/others and vulnerable to attack " + "when " + "used with get_resource_filename. Consider a more secure " + "location (set with .set_extraction_path or the " + "PYTHON_EGG_CACHE environment variable)." % path + ) + warnings.warn(msg, UserWarning) + + def postprocess(self, tempname, filename): + """Perform any platform-specific postprocessing of `tempname` + + This is where Mac header rewrites should be done; other platforms don't + have anything special they should do. + + Resource providers should call this method ONLY after successfully + extracting a compressed resource. They must NOT call it on resources + that are already in the filesystem. + + `tempname` is the current (temporary) name of the file, and `filename` + is the name it will be renamed to by the caller after this routine + returns. + """ + + if os.name == 'posix': + # Make the resource executable + mode = ((os.stat(tempname).st_mode) | 0o555) & 0o7777 + os.chmod(tempname, mode) + + def set_extraction_path(self, path): + """Set the base path where resources will be extracted to, if needed. + + If you do not call this routine before any extractions take place, the + path defaults to the return value of ``get_default_cache()``. (Which + is based on the ``PYTHON_EGG_CACHE`` environment variable, with various + platform-specific fallbacks. See that routine's documentation for more + details.) + + Resources are extracted to subdirectories of this path based upon + information given by the ``IResourceProvider``. You may set this to a + temporary directory, but then you must call ``cleanup_resources()`` to + delete the extracted files when done. There is no guarantee that + ``cleanup_resources()`` will be able to remove all extracted files. + + (Note: you may not change the extraction path for a given resource + manager once resources have been extracted, unless you first call + ``cleanup_resources()``.) + """ + if self.cached_files: + raise ValueError( + "Can't change extraction path, files already extracted" + ) + + self.extraction_path = path + + def cleanup_resources(self, force=False): + """ + Delete all extracted resource files and directories, returning a list + of the file and directory names that could not be successfully removed. + This function does not have any concurrency protection, so it should + generally only be called when the extraction path is a temporary + directory exclusive to a single process. This method is not + automatically called; you must call it explicitly or register it as an + ``atexit`` function if you wish to ensure cleanup of a temporary + directory used for extractions. + """ + # XXX + + +def get_default_cache(): + """ + Return the ``PYTHON_EGG_CACHE`` environment variable + or a platform-relevant user cache dir for an app + named "Python-Eggs". + """ + return ( + os.environ.get('PYTHON_EGG_CACHE') + or appdirs.user_cache_dir(appname='Python-Eggs') + ) + + +def safe_name(name): + """Convert an arbitrary string to a standard distribution name + + Any runs of non-alphanumeric/. characters are replaced with a single '-'. + """ + return re.sub('[^A-Za-z0-9.]+', '-', name) + + +def safe_version(version): + """ + Convert an arbitrary string to a standard version string + """ + try: + # normalize the version + return str(packaging.version.Version(version)) + except packaging.version.InvalidVersion: + version = version.replace(' ', '.') + return re.sub('[^A-Za-z0-9.]+', '-', version) + + +def safe_extra(extra): + """Convert an arbitrary string to a standard 'extra' name + + Any runs of non-alphanumeric characters are replaced with a single '_', + and the result is always lowercased. + """ + return re.sub('[^A-Za-z0-9.-]+', '_', extra).lower() + + +def to_filename(name): + """Convert a project or version name to its filename-escaped form + + Any '-' characters are currently replaced with '_'. + """ + return name.replace('-', '_') + + +def invalid_marker(text): + """ + Validate text as a PEP 508 environment marker; return an exception + if invalid or False otherwise. + """ + try: + evaluate_marker(text) + except SyntaxError as e: + e.filename = None + e.lineno = None + return e + return False + + +def evaluate_marker(text, extra=None): + """ + Evaluate a PEP 508 environment marker. + Return a boolean indicating the marker result in this environment. + Raise SyntaxError if marker is invalid. + + This implementation uses the 'pyparsing' module. + """ + try: + marker = packaging.markers.Marker(text) + return marker.evaluate() + except packaging.markers.InvalidMarker as e: + raise SyntaxError(e) + + +class NullProvider: + """Try to implement resources and metadata for arbitrary PEP 302 loaders""" + + egg_name = None + egg_info = None + loader = None + + def __init__(self, module): + self.loader = getattr(module, '__loader__', None) + self.module_path = os.path.dirname(getattr(module, '__file__', '')) + + def get_resource_filename(self, manager, resource_name): + return self._fn(self.module_path, resource_name) + + def get_resource_stream(self, manager, resource_name): + return io.BytesIO(self.get_resource_string(manager, resource_name)) + + def get_resource_string(self, manager, resource_name): + return self._get(self._fn(self.module_path, resource_name)) + + def has_resource(self, resource_name): + return self._has(self._fn(self.module_path, resource_name)) + + def _get_metadata_path(self, name): + return self._fn(self.egg_info, name) + + def has_metadata(self, name): + if not self.egg_info: + return self.egg_info + + path = self._get_metadata_path(name) + return self._has(path) + + def get_metadata(self, name): + if not self.egg_info: + return "" + value = self._get(self._fn(self.egg_info, name)) + return value.decode('utf-8') if six.PY3 else value + + def get_metadata_lines(self, name): + return yield_lines(self.get_metadata(name)) + + def resource_isdir(self, resource_name): + return self._isdir(self._fn(self.module_path, resource_name)) + + def metadata_isdir(self, name): + return self.egg_info and self._isdir(self._fn(self.egg_info, name)) + + def resource_listdir(self, resource_name): + return self._listdir(self._fn(self.module_path, resource_name)) + + def metadata_listdir(self, name): + if self.egg_info: + return self._listdir(self._fn(self.egg_info, name)) + return [] + + def run_script(self, script_name, namespace): + script = 'scripts/' + script_name + if not self.has_metadata(script): + raise ResolutionError( + "Script {script!r} not found in metadata at {self.egg_info!r}" + .format(**locals()), + ) + script_text = self.get_metadata(script).replace('\r\n', '\n') + script_text = script_text.replace('\r', '\n') + script_filename = self._fn(self.egg_info, script) + namespace['__file__'] = script_filename + if os.path.exists(script_filename): + source = open(script_filename).read() + code = compile(source, script_filename, 'exec') + exec(code, namespace, namespace) + else: + from linecache import cache + cache[script_filename] = ( + len(script_text), 0, script_text.split('\n'), script_filename + ) + script_code = compile(script_text, script_filename, 'exec') + exec(script_code, namespace, namespace) + + def _has(self, path): + raise NotImplementedError( + "Can't perform this operation for unregistered loader type" + ) + + def _isdir(self, path): + raise NotImplementedError( + "Can't perform this operation for unregistered loader type" + ) + + def _listdir(self, path): + raise NotImplementedError( + "Can't perform this operation for unregistered loader type" + ) + + def _fn(self, base, resource_name): + self._validate_resource_path(resource_name) + if resource_name: + return os.path.join(base, *resource_name.split('/')) + return base + + @staticmethod + def _validate_resource_path(path): + """ + Validate the resource paths according to the docs. + https://setuptools.readthedocs.io/en/latest/pkg_resources.html#basic-resource-access + + >>> warned = getfixture('recwarn') + >>> warnings.simplefilter('always') + >>> vrp = NullProvider._validate_resource_path + >>> vrp('foo/bar.txt') + >>> bool(warned) + False + >>> vrp('../foo/bar.txt') + >>> bool(warned) + True + >>> warned.clear() + >>> vrp('/foo/bar.txt') + >>> bool(warned) + True + >>> vrp('foo/../../bar.txt') + >>> bool(warned) + True + >>> warned.clear() + >>> vrp('foo/f../bar.txt') + >>> bool(warned) + False + + Windows path separators are straight-up disallowed. + >>> vrp(r'\\foo/bar.txt') + Traceback (most recent call last): + ... + ValueError: Use of .. or absolute path in a resource path \ +is not allowed. + + >>> vrp(r'C:\\foo/bar.txt') + Traceback (most recent call last): + ... + ValueError: Use of .. or absolute path in a resource path \ +is not allowed. + + Blank values are allowed + + >>> vrp('') + >>> bool(warned) + False + + Non-string values are not. + + >>> vrp(None) + Traceback (most recent call last): + ... + AttributeError: ... + """ + invalid = ( + os.path.pardir in path.split(posixpath.sep) or + posixpath.isabs(path) or + ntpath.isabs(path) + ) + if not invalid: + return + + msg = "Use of .. or absolute path in a resource path is not allowed." + + # Aggressively disallow Windows absolute paths + if ntpath.isabs(path) and not posixpath.isabs(path): + raise ValueError(msg) + + # for compatibility, warn; in future + # raise ValueError(msg) + warnings.warn( + msg[:-1] + " and will raise exceptions in a future release.", + DeprecationWarning, + stacklevel=4, + ) + + def _get(self, path): + if hasattr(self.loader, 'get_data'): + return self.loader.get_data(path) + raise NotImplementedError( + "Can't perform this operation for loaders without 'get_data()'" + ) + + +register_loader_type(object, NullProvider) + + +class EggProvider(NullProvider): + """Provider based on a virtual filesystem""" + + def __init__(self, module): + NullProvider.__init__(self, module) + self._setup_prefix() + + def _setup_prefix(self): + # we assume here that our metadata may be nested inside a "basket" + # of multiple eggs; that's why we use module_path instead of .archive + path = self.module_path + old = None + while path != old: + if _is_egg_path(path): + self.egg_name = os.path.basename(path) + self.egg_info = os.path.join(path, 'EGG-INFO') + self.egg_root = path + break + old = path + path, base = os.path.split(path) + + +class DefaultProvider(EggProvider): + """Provides access to package resources in the filesystem""" + + def _has(self, path): + return os.path.exists(path) + + def _isdir(self, path): + return os.path.isdir(path) + + def _listdir(self, path): + return os.listdir(path) + + def get_resource_stream(self, manager, resource_name): + return open(self._fn(self.module_path, resource_name), 'rb') + + def _get(self, path): + with open(path, 'rb') as stream: + return stream.read() + + @classmethod + def _register(cls): + loader_names = 'SourceFileLoader', 'SourcelessFileLoader', + for name in loader_names: + loader_cls = getattr(importlib_machinery, name, type(None)) + register_loader_type(loader_cls, cls) + + +DefaultProvider._register() + + +class EmptyProvider(NullProvider): + """Provider that returns nothing for all requests""" + + module_path = None + + _isdir = _has = lambda self, path: False + + def _get(self, path): + return '' + + def _listdir(self, path): + return [] + + def __init__(self): + pass + + +empty_provider = EmptyProvider() + + +class ZipManifests(dict): + """ + zip manifest builder + """ + + @classmethod + def build(cls, path): + """ + Build a dictionary similar to the zipimport directory + caches, except instead of tuples, store ZipInfo objects. + + Use a platform-specific path separator (os.sep) for the path keys + for compatibility with pypy on Windows. + """ + with zipfile.ZipFile(path) as zfile: + items = ( + ( + name.replace('/', os.sep), + zfile.getinfo(name), + ) + for name in zfile.namelist() + ) + return dict(items) + + load = build + + +class MemoizedZipManifests(ZipManifests): + """ + Memoized zipfile manifests. + """ + manifest_mod = collections.namedtuple('manifest_mod', 'manifest mtime') + + def load(self, path): + """ + Load a manifest at path or return a suitable manifest already loaded. + """ + path = os.path.normpath(path) + mtime = os.stat(path).st_mtime + + if path not in self or self[path].mtime != mtime: + manifest = self.build(path) + self[path] = self.manifest_mod(manifest, mtime) + + return self[path].manifest + + +class ZipProvider(EggProvider): + """Resource support for zips and eggs""" + + eagers = None + _zip_manifests = MemoizedZipManifests() + + def __init__(self, module): + EggProvider.__init__(self, module) + self.zip_pre = self.loader.archive + os.sep + + def _zipinfo_name(self, fspath): + # Convert a virtual filename (full path to file) into a zipfile subpath + # usable with the zipimport directory cache for our target archive + fspath = fspath.rstrip(os.sep) + if fspath == self.loader.archive: + return '' + if fspath.startswith(self.zip_pre): + return fspath[len(self.zip_pre):] + raise AssertionError( + "%s is not a subpath of %s" % (fspath, self.zip_pre) + ) + + def _parts(self, zip_path): + # Convert a zipfile subpath into an egg-relative path part list. + # pseudo-fs path + fspath = self.zip_pre + zip_path + if fspath.startswith(self.egg_root + os.sep): + return fspath[len(self.egg_root) + 1:].split(os.sep) + raise AssertionError( + "%s is not a subpath of %s" % (fspath, self.egg_root) + ) + + @property + def zipinfo(self): + return self._zip_manifests.load(self.loader.archive) + + def get_resource_filename(self, manager, resource_name): + if not self.egg_name: + raise NotImplementedError( + "resource_filename() only supported for .egg, not .zip" + ) + # no need to lock for extraction, since we use temp names + zip_path = self._resource_to_zip(resource_name) + eagers = self._get_eager_resources() + if '/'.join(self._parts(zip_path)) in eagers: + for name in eagers: + self._extract_resource(manager, self._eager_to_zip(name)) + return self._extract_resource(manager, zip_path) + + @staticmethod + def _get_date_and_size(zip_stat): + size = zip_stat.file_size + # ymdhms+wday, yday, dst + date_time = zip_stat.date_time + (0, 0, -1) + # 1980 offset already done + timestamp = time.mktime(date_time) + return timestamp, size + + def _extract_resource(self, manager, zip_path): + + if zip_path in self._index(): + for name in self._index()[zip_path]: + last = self._extract_resource( + manager, os.path.join(zip_path, name) + ) + # return the extracted directory name + return os.path.dirname(last) + + timestamp, size = self._get_date_and_size(self.zipinfo[zip_path]) + + if not WRITE_SUPPORT: + raise IOError('"os.rename" and "os.unlink" are not supported ' + 'on this platform') + try: + + real_path = manager.get_cache_path( + self.egg_name, self._parts(zip_path) + ) + + if self._is_current(real_path, zip_path): + return real_path + + outf, tmpnam = _mkstemp( + ".$extract", + dir=os.path.dirname(real_path), + ) + os.write(outf, self.loader.get_data(zip_path)) + os.close(outf) + utime(tmpnam, (timestamp, timestamp)) + manager.postprocess(tmpnam, real_path) + + try: + rename(tmpnam, real_path) + + except os.error: + if os.path.isfile(real_path): + if self._is_current(real_path, zip_path): + # the file became current since it was checked above, + # so proceed. + return real_path + # Windows, del old file and retry + elif os.name == 'nt': + unlink(real_path) + rename(tmpnam, real_path) + return real_path + raise + + except os.error: + # report a user-friendly error + manager.extraction_error() + + return real_path + + def _is_current(self, file_path, zip_path): + """ + Return True if the file_path is current for this zip_path + """ + timestamp, size = self._get_date_and_size(self.zipinfo[zip_path]) + if not os.path.isfile(file_path): + return False + stat = os.stat(file_path) + if stat.st_size != size or stat.st_mtime != timestamp: + return False + # check that the contents match + zip_contents = self.loader.get_data(zip_path) + with open(file_path, 'rb') as f: + file_contents = f.read() + return zip_contents == file_contents + + def _get_eager_resources(self): + if self.eagers is None: + eagers = [] + for name in ('native_libs.txt', 'eager_resources.txt'): + if self.has_metadata(name): + eagers.extend(self.get_metadata_lines(name)) + self.eagers = eagers + return self.eagers + + def _index(self): + try: + return self._dirindex + except AttributeError: + ind = {} + for path in self.zipinfo: + parts = path.split(os.sep) + while parts: + parent = os.sep.join(parts[:-1]) + if parent in ind: + ind[parent].append(parts[-1]) + break + else: + ind[parent] = [parts.pop()] + self._dirindex = ind + return ind + + def _has(self, fspath): + zip_path = self._zipinfo_name(fspath) + return zip_path in self.zipinfo or zip_path in self._index() + + def _isdir(self, fspath): + return self._zipinfo_name(fspath) in self._index() + + def _listdir(self, fspath): + return list(self._index().get(self._zipinfo_name(fspath), ())) + + def _eager_to_zip(self, resource_name): + return self._zipinfo_name(self._fn(self.egg_root, resource_name)) + + def _resource_to_zip(self, resource_name): + return self._zipinfo_name(self._fn(self.module_path, resource_name)) + + +register_loader_type(zipimport.zipimporter, ZipProvider) + + +class FileMetadata(EmptyProvider): + """Metadata handler for standalone PKG-INFO files + + Usage:: + + metadata = FileMetadata("/path/to/PKG-INFO") + + This provider rejects all data and metadata requests except for PKG-INFO, + which is treated as existing, and will be the contents of the file at + the provided location. + """ + + def __init__(self, path): + self.path = path + + def _get_metadata_path(self, name): + return self.path + + def has_metadata(self, name): + return name == 'PKG-INFO' and os.path.isfile(self.path) + + def get_metadata(self, name): + if name != 'PKG-INFO': + raise KeyError("No metadata except PKG-INFO is available") + + with io.open(self.path, encoding='utf-8', errors="replace") as f: + metadata = f.read() + self._warn_on_replacement(metadata) + return metadata + + def _warn_on_replacement(self, metadata): + # Python 2.7 compat for: replacement_char = '�' + replacement_char = b'\xef\xbf\xbd'.decode('utf-8') + if replacement_char in metadata: + tmpl = "{self.path} could not be properly decoded in UTF-8" + msg = tmpl.format(**locals()) + warnings.warn(msg) + + def get_metadata_lines(self, name): + return yield_lines(self.get_metadata(name)) + + +class PathMetadata(DefaultProvider): + """Metadata provider for egg directories + + Usage:: + + # Development eggs: + + egg_info = "/path/to/PackageName.egg-info" + base_dir = os.path.dirname(egg_info) + metadata = PathMetadata(base_dir, egg_info) + dist_name = os.path.splitext(os.path.basename(egg_info))[0] + dist = Distribution(basedir, project_name=dist_name, metadata=metadata) + + # Unpacked egg directories: + + egg_path = "/path/to/PackageName-ver-pyver-etc.egg" + metadata = PathMetadata(egg_path, os.path.join(egg_path,'EGG-INFO')) + dist = Distribution.from_filename(egg_path, metadata=metadata) + """ + + def __init__(self, path, egg_info): + self.module_path = path + self.egg_info = egg_info + + +class EggMetadata(ZipProvider): + """Metadata provider for .egg files""" + + def __init__(self, importer): + """Create a metadata provider from a zipimporter""" + + self.zip_pre = importer.archive + os.sep + self.loader = importer + if importer.prefix: + self.module_path = os.path.join(importer.archive, importer.prefix) + else: + self.module_path = importer.archive + self._setup_prefix() + + +_declare_state('dict', _distribution_finders={}) + + +def register_finder(importer_type, distribution_finder): + """Register `distribution_finder` to find distributions in sys.path items + + `importer_type` is the type or class of a PEP 302 "Importer" (sys.path item + handler), and `distribution_finder` is a callable that, passed a path + item and the importer instance, yields ``Distribution`` instances found on + that path item. See ``pkg_resources.find_on_path`` for an example.""" + _distribution_finders[importer_type] = distribution_finder + + +def find_distributions(path_item, only=False): + """Yield distributions accessible via `path_item`""" + importer = get_importer(path_item) + finder = _find_adapter(_distribution_finders, importer) + return finder(importer, path_item, only) + + +def find_eggs_in_zip(importer, path_item, only=False): + """ + Find eggs in zip files; possibly multiple nested eggs. + """ + if importer.archive.endswith('.whl'): + # wheels are not supported with this finder + # they don't have PKG-INFO metadata, and won't ever contain eggs + return + metadata = EggMetadata(importer) + if metadata.has_metadata('PKG-INFO'): + yield Distribution.from_filename(path_item, metadata=metadata) + if only: + # don't yield nested distros + return + for subitem in metadata.resource_listdir(''): + if _is_egg_path(subitem): + subpath = os.path.join(path_item, subitem) + dists = find_eggs_in_zip(zipimport.zipimporter(subpath), subpath) + for dist in dists: + yield dist + elif subitem.lower().endswith('.dist-info'): + subpath = os.path.join(path_item, subitem) + submeta = EggMetadata(zipimport.zipimporter(subpath)) + submeta.egg_info = subpath + yield Distribution.from_location(path_item, subitem, submeta) + + +register_finder(zipimport.zipimporter, find_eggs_in_zip) + + +def find_nothing(importer, path_item, only=False): + return () + + +register_finder(object, find_nothing) + + +def _by_version_descending(names): + """ + Given a list of filenames, return them in descending order + by version number. + + >>> names = 'bar', 'foo', 'Python-2.7.10.egg', 'Python-2.7.2.egg' + >>> _by_version_descending(names) + ['Python-2.7.10.egg', 'Python-2.7.2.egg', 'foo', 'bar'] + >>> names = 'Setuptools-1.2.3b1.egg', 'Setuptools-1.2.3.egg' + >>> _by_version_descending(names) + ['Setuptools-1.2.3.egg', 'Setuptools-1.2.3b1.egg'] + >>> names = 'Setuptools-1.2.3b1.egg', 'Setuptools-1.2.3.post1.egg' + >>> _by_version_descending(names) + ['Setuptools-1.2.3.post1.egg', 'Setuptools-1.2.3b1.egg'] + """ + def _by_version(name): + """ + Parse each component of the filename + """ + name, ext = os.path.splitext(name) + parts = itertools.chain(name.split('-'), [ext]) + return [packaging.version.parse(part) for part in parts] + + return sorted(names, key=_by_version, reverse=True) + + +def find_on_path(importer, path_item, only=False): + """Yield distributions accessible on a sys.path directory""" + path_item = _normalize_cached(path_item) + + if _is_unpacked_egg(path_item): + yield Distribution.from_filename( + path_item, metadata=PathMetadata( + path_item, os.path.join(path_item, 'EGG-INFO') + ) + ) + return + + entries = safe_listdir(path_item) + + # for performance, before sorting by version, + # screen entries for only those that will yield + # distributions + filtered = ( + entry + for entry in entries + if dist_factory(path_item, entry, only) + ) + + # scan for .egg and .egg-info in directory + path_item_entries = _by_version_descending(filtered) + for entry in path_item_entries: + fullpath = os.path.join(path_item, entry) + factory = dist_factory(path_item, entry, only) + for dist in factory(fullpath): + yield dist + + +def dist_factory(path_item, entry, only): + """ + Return a dist_factory for a path_item and entry + """ + lower = entry.lower() + is_meta = any(map(lower.endswith, ('.egg-info', '.dist-info'))) + return ( + distributions_from_metadata + if is_meta else + find_distributions + if not only and _is_egg_path(entry) else + resolve_egg_link + if not only and lower.endswith('.egg-link') else + NoDists() + ) + + +class NoDists: + """ + >>> bool(NoDists()) + False + + >>> list(NoDists()('anything')) + [] + """ + def __bool__(self): + return False + if six.PY2: + __nonzero__ = __bool__ + + def __call__(self, fullpath): + return iter(()) + + +def safe_listdir(path): + """ + Attempt to list contents of path, but suppress some exceptions. + """ + try: + return os.listdir(path) + except (PermissionError, NotADirectoryError): + pass + except OSError as e: + # Ignore the directory if does not exist, not a directory or + # permission denied + ignorable = ( + e.errno in (errno.ENOTDIR, errno.EACCES, errno.ENOENT) + # Python 2 on Windows needs to be handled this way :( + or getattr(e, "winerror", None) == 267 + ) + if not ignorable: + raise + return () + + +def distributions_from_metadata(path): + root = os.path.dirname(path) + if os.path.isdir(path): + if len(os.listdir(path)) == 0: + # empty metadata dir; skip + return + metadata = PathMetadata(root, path) + else: + metadata = FileMetadata(path) + entry = os.path.basename(path) + yield Distribution.from_location( + root, entry, metadata, precedence=DEVELOP_DIST, + ) + + +def non_empty_lines(path): + """ + Yield non-empty lines from file at path + """ + with open(path) as f: + for line in f: + line = line.strip() + if line: + yield line + + +def resolve_egg_link(path): + """ + Given a path to an .egg-link, resolve distributions + present in the referenced path. + """ + referenced_paths = non_empty_lines(path) + resolved_paths = ( + os.path.join(os.path.dirname(path), ref) + for ref in referenced_paths + ) + dist_groups = map(find_distributions, resolved_paths) + return next(dist_groups, ()) + + +register_finder(pkgutil.ImpImporter, find_on_path) + +if hasattr(importlib_machinery, 'FileFinder'): + register_finder(importlib_machinery.FileFinder, find_on_path) + +_declare_state('dict', _namespace_handlers={}) +_declare_state('dict', _namespace_packages={}) + + +def register_namespace_handler(importer_type, namespace_handler): + """Register `namespace_handler` to declare namespace packages + + `importer_type` is the type or class of a PEP 302 "Importer" (sys.path item + handler), and `namespace_handler` is a callable like this:: + + def namespace_handler(importer, path_entry, moduleName, module): + # return a path_entry to use for child packages + + Namespace handlers are only called if the importer object has already + agreed that it can handle the relevant path item, and they should only + return a subpath if the module __path__ does not already contain an + equivalent subpath. For an example namespace handler, see + ``pkg_resources.file_ns_handler``. + """ + _namespace_handlers[importer_type] = namespace_handler + + +def _handle_ns(packageName, path_item): + """Ensure that named package includes a subpath of path_item (if needed)""" + + importer = get_importer(path_item) + if importer is None: + return None + + # capture warnings due to #1111 + with warnings.catch_warnings(): + warnings.simplefilter("ignore") + loader = importer.find_module(packageName) + + if loader is None: + return None + module = sys.modules.get(packageName) + if module is None: + module = sys.modules[packageName] = types.ModuleType(packageName) + module.__path__ = [] + _set_parent_ns(packageName) + elif not hasattr(module, '__path__'): + raise TypeError("Not a package:", packageName) + handler = _find_adapter(_namespace_handlers, importer) + subpath = handler(importer, path_item, packageName, module) + if subpath is not None: + path = module.__path__ + path.append(subpath) + loader.load_module(packageName) + _rebuild_mod_path(path, packageName, module) + return subpath + + +def _rebuild_mod_path(orig_path, package_name, module): + """ + Rebuild module.__path__ ensuring that all entries are ordered + corresponding to their sys.path order + """ + sys_path = [_normalize_cached(p) for p in sys.path] + + def safe_sys_path_index(entry): + """ + Workaround for #520 and #513. + """ + try: + return sys_path.index(entry) + except ValueError: + return float('inf') + + def position_in_sys_path(path): + """ + Return the ordinal of the path based on its position in sys.path + """ + path_parts = path.split(os.sep) + module_parts = package_name.count('.') + 1 + parts = path_parts[:-module_parts] + return safe_sys_path_index(_normalize_cached(os.sep.join(parts))) + + new_path = sorted(orig_path, key=position_in_sys_path) + new_path = [_normalize_cached(p) for p in new_path] + + if isinstance(module.__path__, list): + module.__path__[:] = new_path + else: + module.__path__ = new_path + + +def declare_namespace(packageName): + """Declare that package 'packageName' is a namespace package""" + + _imp.acquire_lock() + try: + if packageName in _namespace_packages: + return + + path = sys.path + parent, _, _ = packageName.rpartition('.') + + if parent: + declare_namespace(parent) + if parent not in _namespace_packages: + __import__(parent) + try: + path = sys.modules[parent].__path__ + except AttributeError: + raise TypeError("Not a package:", parent) + + # Track what packages are namespaces, so when new path items are added, + # they can be updated + _namespace_packages.setdefault(parent or None, []).append(packageName) + _namespace_packages.setdefault(packageName, []) + + for path_item in path: + # Ensure all the parent's path items are reflected in the child, + # if they apply + _handle_ns(packageName, path_item) + + finally: + _imp.release_lock() + + +def fixup_namespace_packages(path_item, parent=None): + """Ensure that previously-declared namespace packages include path_item""" + _imp.acquire_lock() + try: + for package in _namespace_packages.get(parent, ()): + subpath = _handle_ns(package, path_item) + if subpath: + fixup_namespace_packages(subpath, package) + finally: + _imp.release_lock() + + +def file_ns_handler(importer, path_item, packageName, module): + """Compute an ns-package subpath for a filesystem or zipfile importer""" + + subpath = os.path.join(path_item, packageName.split('.')[-1]) + normalized = _normalize_cached(subpath) + for item in module.__path__: + if _normalize_cached(item) == normalized: + break + else: + # Only return the path if it's not already there + return subpath + + +register_namespace_handler(pkgutil.ImpImporter, file_ns_handler) +register_namespace_handler(zipimport.zipimporter, file_ns_handler) + +if hasattr(importlib_machinery, 'FileFinder'): + register_namespace_handler(importlib_machinery.FileFinder, file_ns_handler) + + +def null_ns_handler(importer, path_item, packageName, module): + return None + + +register_namespace_handler(object, null_ns_handler) + + +def normalize_path(filename): + """Normalize a file/dir name for comparison purposes""" + return os.path.normcase(os.path.realpath(os.path.normpath(_cygwin_patch(filename)))) + + +def _cygwin_patch(filename): # pragma: nocover + """ + Contrary to POSIX 2008, on Cygwin, getcwd (3) contains + symlink components. Using + os.path.abspath() works around this limitation. A fix in os.getcwd() + would probably better, in Cygwin even more so, except + that this seems to be by design... + """ + return os.path.abspath(filename) if sys.platform == 'cygwin' else filename + + +def _normalize_cached(filename, _cache={}): + try: + return _cache[filename] + except KeyError: + _cache[filename] = result = normalize_path(filename) + return result + + +def _is_egg_path(path): + """ + Determine if given path appears to be an egg. + """ + return path.lower().endswith('.egg') + + +def _is_unpacked_egg(path): + """ + Determine if given path appears to be an unpacked egg. + """ + return ( + _is_egg_path(path) and + os.path.isfile(os.path.join(path, 'EGG-INFO', 'PKG-INFO')) + ) + + +def _set_parent_ns(packageName): + parts = packageName.split('.') + name = parts.pop() + if parts: + parent = '.'.join(parts) + setattr(sys.modules[parent], name, sys.modules[packageName]) + + +def yield_lines(strs): + """Yield non-empty/non-comment lines of a string or sequence""" + if isinstance(strs, six.string_types): + for s in strs.splitlines(): + s = s.strip() + # skip blank lines/comments + if s and not s.startswith('#'): + yield s + else: + for ss in strs: + for s in yield_lines(ss): + yield s + + +MODULE = re.compile(r"\w+(\.\w+)*$").match +EGG_NAME = re.compile( + r""" + (?P<name>[^-]+) ( + -(?P<ver>[^-]+) ( + -py(?P<pyver>[^-]+) ( + -(?P<plat>.+) + )? + )? + )? + """, + re.VERBOSE | re.IGNORECASE, +).match + + +class EntryPoint: + """Object representing an advertised importable object""" + + def __init__(self, name, module_name, attrs=(), extras=(), dist=None): + if not MODULE(module_name): + raise ValueError("Invalid module name", module_name) + self.name = name + self.module_name = module_name + self.attrs = tuple(attrs) + self.extras = tuple(extras) + self.dist = dist + + def __str__(self): + s = "%s = %s" % (self.name, self.module_name) + if self.attrs: + s += ':' + '.'.join(self.attrs) + if self.extras: + s += ' [%s]' % ','.join(self.extras) + return s + + def __repr__(self): + return "EntryPoint.parse(%r)" % str(self) + + def load(self, require=True, *args, **kwargs): + """ + Require packages for this EntryPoint, then resolve it. + """ + if not require or args or kwargs: + warnings.warn( + "Parameters to load are deprecated. Call .resolve and " + ".require separately.", + PkgResourcesDeprecationWarning, + stacklevel=2, + ) + if require: + self.require(*args, **kwargs) + return self.resolve() + + def resolve(self): + """ + Resolve the entry point from its module and attrs. + """ + module = __import__(self.module_name, fromlist=['__name__'], level=0) + try: + return functools.reduce(getattr, self.attrs, module) + except AttributeError as exc: + raise ImportError(str(exc)) + + def require(self, env=None, installer=None): + if self.extras and not self.dist: + raise UnknownExtra("Can't require() without a distribution", self) + + # Get the requirements for this entry point with all its extras and + # then resolve them. We have to pass `extras` along when resolving so + # that the working set knows what extras we want. Otherwise, for + # dist-info distributions, the working set will assume that the + # requirements for that extra are purely optional and skip over them. + reqs = self.dist.requires(self.extras) + items = working_set.resolve(reqs, env, installer, extras=self.extras) + list(map(working_set.add, items)) + + pattern = re.compile( + r'\s*' + r'(?P<name>.+?)\s*' + r'=\s*' + r'(?P<module>[\w.]+)\s*' + r'(:\s*(?P<attr>[\w.]+))?\s*' + r'(?P<extras>\[.*\])?\s*$' + ) + + @classmethod + def parse(cls, src, dist=None): + """Parse a single entry point from string `src` + + Entry point syntax follows the form:: + + name = some.module:some.attr [extra1, extra2] + + The entry name and module name are required, but the ``:attrs`` and + ``[extras]`` parts are optional + """ + m = cls.pattern.match(src) + if not m: + msg = "EntryPoint must be in 'name=module:attrs [extras]' format" + raise ValueError(msg, src) + res = m.groupdict() + extras = cls._parse_extras(res['extras']) + attrs = res['attr'].split('.') if res['attr'] else () + return cls(res['name'], res['module'], attrs, extras, dist) + + @classmethod + def _parse_extras(cls, extras_spec): + if not extras_spec: + return () + req = Requirement.parse('x' + extras_spec) + if req.specs: + raise ValueError() + return req.extras + + @classmethod + def parse_group(cls, group, lines, dist=None): + """Parse an entry point group""" + if not MODULE(group): + raise ValueError("Invalid group name", group) + this = {} + for line in yield_lines(lines): + ep = cls.parse(line, dist) + if ep.name in this: + raise ValueError("Duplicate entry point", group, ep.name) + this[ep.name] = ep + return this + + @classmethod + def parse_map(cls, data, dist=None): + """Parse a map of entry point groups""" + if isinstance(data, dict): + data = data.items() + else: + data = split_sections(data) + maps = {} + for group, lines in data: + if group is None: + if not lines: + continue + raise ValueError("Entry points must be listed in groups") + group = group.strip() + if group in maps: + raise ValueError("Duplicate group name", group) + maps[group] = cls.parse_group(group, lines, dist) + return maps + + +def _remove_md5_fragment(location): + if not location: + return '' + parsed = urllib.parse.urlparse(location) + if parsed[-1].startswith('md5='): + return urllib.parse.urlunparse(parsed[:-1] + ('',)) + return location + + +def _version_from_file(lines): + """ + Given an iterable of lines from a Metadata file, return + the value of the Version field, if present, or None otherwise. + """ + def is_version_line(line): + return line.lower().startswith('version:') + version_lines = filter(is_version_line, lines) + line = next(iter(version_lines), '') + _, _, value = line.partition(':') + return safe_version(value.strip()) or None + + +class Distribution: + """Wrap an actual or potential sys.path entry w/metadata""" + PKG_INFO = 'PKG-INFO' + + def __init__( + self, location=None, metadata=None, project_name=None, + version=None, py_version=PY_MAJOR, platform=None, + precedence=EGG_DIST): + self.project_name = safe_name(project_name or 'Unknown') + if version is not None: + self._version = safe_version(version) + self.py_version = py_version + self.platform = platform + self.location = location + self.precedence = precedence + self._provider = metadata or empty_provider + + @classmethod + def from_location(cls, location, basename, metadata=None, **kw): + project_name, version, py_version, platform = [None] * 4 + basename, ext = os.path.splitext(basename) + if ext.lower() in _distributionImpl: + cls = _distributionImpl[ext.lower()] + + match = EGG_NAME(basename) + if match: + project_name, version, py_version, platform = match.group( + 'name', 'ver', 'pyver', 'plat' + ) + return cls( + location, metadata, project_name=project_name, version=version, + py_version=py_version, platform=platform, **kw + )._reload_version() + + def _reload_version(self): + return self + + @property + def hashcmp(self): + return ( + self.parsed_version, + self.precedence, + self.key, + _remove_md5_fragment(self.location), + self.py_version or '', + self.platform or '', + ) + + def __hash__(self): + return hash(self.hashcmp) + + def __lt__(self, other): + return self.hashcmp < other.hashcmp + + def __le__(self, other): + return self.hashcmp <= other.hashcmp + + def __gt__(self, other): + return self.hashcmp > other.hashcmp + + def __ge__(self, other): + return self.hashcmp >= other.hashcmp + + def __eq__(self, other): + if not isinstance(other, self.__class__): + # It's not a Distribution, so they are not equal + return False + return self.hashcmp == other.hashcmp + + def __ne__(self, other): + return not self == other + + # These properties have to be lazy so that we don't have to load any + # metadata until/unless it's actually needed. (i.e., some distributions + # may not know their name or version without loading PKG-INFO) + + @property + def key(self): + try: + return self._key + except AttributeError: + self._key = key = self.project_name.lower() + return key + + @property + def parsed_version(self): + if not hasattr(self, "_parsed_version"): + self._parsed_version = parse_version(self.version) + + return self._parsed_version + + def _warn_legacy_version(self): + LV = packaging.version.LegacyVersion + is_legacy = isinstance(self._parsed_version, LV) + if not is_legacy: + return + + # While an empty version is technically a legacy version and + # is not a valid PEP 440 version, it's also unlikely to + # actually come from someone and instead it is more likely that + # it comes from setuptools attempting to parse a filename and + # including it in the list. So for that we'll gate this warning + # on if the version is anything at all or not. + if not self.version: + return + + tmpl = textwrap.dedent(""" + '{project_name} ({version})' is being parsed as a legacy, + non PEP 440, + version. You may find odd behavior and sort order. + In particular it will be sorted as less than 0.0. It + is recommended to migrate to PEP 440 compatible + versions. + """).strip().replace('\n', ' ') + + warnings.warn(tmpl.format(**vars(self)), PEP440Warning) + + @property + def version(self): + try: + return self._version + except AttributeError: + version = self._get_version() + if version is None: + path = self._get_metadata_path_for_display(self.PKG_INFO) + msg = ( + "Missing 'Version:' header and/or {} file at path: {}" + ).format(self.PKG_INFO, path) + raise ValueError(msg, self) + + return version + + @property + def _dep_map(self): + """ + A map of extra to its list of (direct) requirements + for this distribution, including the null extra. + """ + try: + return self.__dep_map + except AttributeError: + self.__dep_map = self._filter_extras(self._build_dep_map()) + return self.__dep_map + + @staticmethod + def _filter_extras(dm): + """ + Given a mapping of extras to dependencies, strip off + environment markers and filter out any dependencies + not matching the markers. + """ + for extra in list(filter(None, dm)): + new_extra = extra + reqs = dm.pop(extra) + new_extra, _, marker = extra.partition(':') + fails_marker = marker and ( + invalid_marker(marker) + or not evaluate_marker(marker) + ) + if fails_marker: + reqs = [] + new_extra = safe_extra(new_extra) or None + + dm.setdefault(new_extra, []).extend(reqs) + return dm + + def _build_dep_map(self): + dm = {} + for name in 'requires.txt', 'depends.txt': + for extra, reqs in split_sections(self._get_metadata(name)): + dm.setdefault(extra, []).extend(parse_requirements(reqs)) + return dm + + def requires(self, extras=()): + """List of Requirements needed for this distro if `extras` are used""" + dm = self._dep_map + deps = [] + deps.extend(dm.get(None, ())) + for ext in extras: + try: + deps.extend(dm[safe_extra(ext)]) + except KeyError: + raise UnknownExtra( + "%s has no such extra feature %r" % (self, ext) + ) + return deps + + def _get_metadata_path_for_display(self, name): + """ + Return the path to the given metadata file, if available. + """ + try: + # We need to access _get_metadata_path() on the provider object + # directly rather than through this class's __getattr__() + # since _get_metadata_path() is marked private. + path = self._provider._get_metadata_path(name) + + # Handle exceptions e.g. in case the distribution's metadata + # provider doesn't support _get_metadata_path(). + except Exception: + return '[could not detect]' + + return path + + def _get_metadata(self, name): + if self.has_metadata(name): + for line in self.get_metadata_lines(name): + yield line + + def _get_version(self): + lines = self._get_metadata(self.PKG_INFO) + version = _version_from_file(lines) + + return version + + def activate(self, path=None, replace=False): + """Ensure distribution is importable on `path` (default=sys.path)""" + if path is None: + path = sys.path + self.insert_on(path, replace=replace) + if path is sys.path: + fixup_namespace_packages(self.location) + for pkg in self._get_metadata('namespace_packages.txt'): + if pkg in sys.modules: + declare_namespace(pkg) + + def egg_name(self): + """Return what this distribution's standard .egg filename should be""" + filename = "%s-%s-py%s" % ( + to_filename(self.project_name), to_filename(self.version), + self.py_version or PY_MAJOR + ) + + if self.platform: + filename += '-' + self.platform + return filename + + def __repr__(self): + if self.location: + return "%s (%s)" % (self, self.location) + else: + return str(self) + + def __str__(self): + try: + version = getattr(self, 'version', None) + except ValueError: + version = None + version = version or "[unknown version]" + return "%s %s" % (self.project_name, version) + + def __getattr__(self, attr): + """Delegate all unrecognized public attributes to .metadata provider""" + if attr.startswith('_'): + raise AttributeError(attr) + return getattr(self._provider, attr) + + def __dir__(self): + return list( + set(super(Distribution, self).__dir__()) + | set( + attr for attr in self._provider.__dir__() + if not attr.startswith('_') + ) + ) + + if not hasattr(object, '__dir__'): + # python 2.7 not supported + del __dir__ + + @classmethod + def from_filename(cls, filename, metadata=None, **kw): + return cls.from_location( + _normalize_cached(filename), os.path.basename(filename), metadata, + **kw + ) + + def as_requirement(self): + """Return a ``Requirement`` that matches this distribution exactly""" + if isinstance(self.parsed_version, packaging.version.Version): + spec = "%s==%s" % (self.project_name, self.parsed_version) + else: + spec = "%s===%s" % (self.project_name, self.parsed_version) + + return Requirement.parse(spec) + + def load_entry_point(self, group, name): + """Return the `name` entry point of `group` or raise ImportError""" + ep = self.get_entry_info(group, name) + if ep is None: + raise ImportError("Entry point %r not found" % ((group, name),)) + return ep.load() + + def get_entry_map(self, group=None): + """Return the entry point map for `group`, or the full entry map""" + try: + ep_map = self._ep_map + except AttributeError: + ep_map = self._ep_map = EntryPoint.parse_map( + self._get_metadata('entry_points.txt'), self + ) + if group is not None: + return ep_map.get(group, {}) + return ep_map + + def get_entry_info(self, group, name): + """Return the EntryPoint object for `group`+`name`, or ``None``""" + return self.get_entry_map(group).get(name) + + def insert_on(self, path, loc=None, replace=False): + """Ensure self.location is on path + + If replace=False (default): + - If location is already in path anywhere, do nothing. + - Else: + - If it's an egg and its parent directory is on path, + insert just ahead of the parent. + - Else: add to the end of path. + If replace=True: + - If location is already on path anywhere (not eggs) + or higher priority than its parent (eggs) + do nothing. + - Else: + - If it's an egg and its parent directory is on path, + insert just ahead of the parent, + removing any lower-priority entries. + - Else: add it to the front of path. + """ + + loc = loc or self.location + if not loc: + return + + nloc = _normalize_cached(loc) + bdir = os.path.dirname(nloc) + npath = [(p and _normalize_cached(p) or p) for p in path] + + for p, item in enumerate(npath): + if item == nloc: + if replace: + break + else: + # don't modify path (even removing duplicates) if + # found and not replace + return + elif item == bdir and self.precedence == EGG_DIST: + # if it's an .egg, give it precedence over its directory + # UNLESS it's already been added to sys.path and replace=False + if (not replace) and nloc in npath[p:]: + return + if path is sys.path: + self.check_version_conflict() + path.insert(p, loc) + npath.insert(p, nloc) + break + else: + if path is sys.path: + self.check_version_conflict() + if replace: + path.insert(0, loc) + else: + path.append(loc) + return + + # p is the spot where we found or inserted loc; now remove duplicates + while True: + try: + np = npath.index(nloc, p + 1) + except ValueError: + break + else: + del npath[np], path[np] + # ha! + p = np + + return + + def check_version_conflict(self): + if self.key == 'setuptools': + # ignore the inevitable setuptools self-conflicts :( + return + + nsp = dict.fromkeys(self._get_metadata('namespace_packages.txt')) + loc = normalize_path(self.location) + for modname in self._get_metadata('top_level.txt'): + if (modname not in sys.modules or modname in nsp + or modname in _namespace_packages): + continue + if modname in ('pkg_resources', 'setuptools', 'site'): + continue + fn = getattr(sys.modules[modname], '__file__', None) + if fn and (normalize_path(fn).startswith(loc) or + fn.startswith(self.location)): + continue + issue_warning( + "Module %s was already imported from %s, but %s is being added" + " to sys.path" % (modname, fn, self.location), + ) + + def has_version(self): + try: + self.version + except ValueError: + issue_warning("Unbuilt egg for " + repr(self)) + return False + return True + + def clone(self, **kw): + """Copy this distribution, substituting in any changed keyword args""" + names = 'project_name version py_version platform location precedence' + for attr in names.split(): + kw.setdefault(attr, getattr(self, attr, None)) + kw.setdefault('metadata', self._provider) + return self.__class__(**kw) + + @property + def extras(self): + return [dep for dep in self._dep_map if dep] + + +class EggInfoDistribution(Distribution): + def _reload_version(self): + """ + Packages installed by distutils (e.g. numpy or scipy), + which uses an old safe_version, and so + their version numbers can get mangled when + converted to filenames (e.g., 1.11.0.dev0+2329eae to + 1.11.0.dev0_2329eae). These distributions will not be + parsed properly + downstream by Distribution and safe_version, so + take an extra step and try to get the version number from + the metadata file itself instead of the filename. + """ + md_version = self._get_version() + if md_version: + self._version = md_version + return self + + +class DistInfoDistribution(Distribution): + """ + Wrap an actual or potential sys.path entry + w/metadata, .dist-info style. + """ + PKG_INFO = 'METADATA' + EQEQ = re.compile(r"([\(,])\s*(\d.*?)\s*([,\)])") + + @property + def _parsed_pkg_info(self): + """Parse and cache metadata""" + try: + return self._pkg_info + except AttributeError: + metadata = self.get_metadata(self.PKG_INFO) + self._pkg_info = email.parser.Parser().parsestr(metadata) + return self._pkg_info + + @property + def _dep_map(self): + try: + return self.__dep_map + except AttributeError: + self.__dep_map = self._compute_dependencies() + return self.__dep_map + + def _compute_dependencies(self): + """Recompute this distribution's dependencies.""" + dm = self.__dep_map = {None: []} + + reqs = [] + # Including any condition expressions + for req in self._parsed_pkg_info.get_all('Requires-Dist') or []: + reqs.extend(parse_requirements(req)) + + def reqs_for_extra(extra): + for req in reqs: + if not req.marker or req.marker.evaluate({'extra': extra}): + yield req + + common = frozenset(reqs_for_extra(None)) + dm[None].extend(common) + + for extra in self._parsed_pkg_info.get_all('Provides-Extra') or []: + s_extra = safe_extra(extra.strip()) + dm[s_extra] = list(frozenset(reqs_for_extra(extra)) - common) + + return dm + + +_distributionImpl = { + '.egg': Distribution, + '.egg-info': EggInfoDistribution, + '.dist-info': DistInfoDistribution, +} + + +def issue_warning(*args, **kw): + level = 1 + g = globals() + try: + # find the first stack frame that is *not* code in + # the pkg_resources module, to use for the warning + while sys._getframe(level).f_globals is g: + level += 1 + except ValueError: + pass + warnings.warn(stacklevel=level + 1, *args, **kw) + + +class RequirementParseError(ValueError): + def __str__(self): + return ' '.join(self.args) + + +def parse_requirements(strs): + """Yield ``Requirement`` objects for each specification in `strs` + + `strs` must be a string, or a (possibly-nested) iterable thereof. + """ + # create a steppable iterator, so we can handle \-continuations + lines = iter(yield_lines(strs)) + + for line in lines: + # Drop comments -- a hash without a space may be in a URL. + if ' #' in line: + line = line[:line.find(' #')] + # If there is a line continuation, drop it, and append the next line. + if line.endswith('\\'): + line = line[:-2].strip() + try: + line += next(lines) + except StopIteration: + return + yield Requirement(line) + + +class Requirement(packaging.requirements.Requirement): + def __init__(self, requirement_string): + """DO NOT CALL THIS UNDOCUMENTED METHOD; use Requirement.parse()!""" + try: + super(Requirement, self).__init__(requirement_string) + except packaging.requirements.InvalidRequirement as e: + raise RequirementParseError(str(e)) + self.unsafe_name = self.name + project_name = safe_name(self.name) + self.project_name, self.key = project_name, project_name.lower() + self.specs = [ + (spec.operator, spec.version) for spec in self.specifier] + self.extras = tuple(map(safe_extra, self.extras)) + self.hashCmp = ( + self.key, + self.specifier, + frozenset(self.extras), + str(self.marker) if self.marker else None, + ) + self.__hash = hash(self.hashCmp) + + def __eq__(self, other): + return ( + isinstance(other, Requirement) and + self.hashCmp == other.hashCmp + ) + + def __ne__(self, other): + return not self == other + + def __contains__(self, item): + if isinstance(item, Distribution): + if item.key != self.key: + return False + + item = item.version + + # Allow prereleases always in order to match the previous behavior of + # this method. In the future this should be smarter and follow PEP 440 + # more accurately. + return self.specifier.contains(item, prereleases=True) + + def __hash__(self): + return self.__hash + + def __repr__(self): + return "Requirement.parse(%r)" % str(self) + + @staticmethod + def parse(s): + req, = parse_requirements(s) + return req + + +def _always_object(classes): + """ + Ensure object appears in the mro even + for old-style classes. + """ + if object not in classes: + return classes + (object,) + return classes + + +def _find_adapter(registry, ob): + """Return an adapter factory for `ob` from `registry`""" + types = _always_object(inspect.getmro(getattr(ob, '__class__', type(ob)))) + for t in types: + if t in registry: + return registry[t] + + +def ensure_directory(path): + """Ensure that the parent directory of `path` exists""" + dirname = os.path.dirname(path) + py31compat.makedirs(dirname, exist_ok=True) + + +def _bypass_ensure_directory(path): + """Sandbox-bypassing version of ensure_directory()""" + if not WRITE_SUPPORT: + raise IOError('"os.mkdir" not supported on this platform.') + dirname, filename = split(path) + if dirname and filename and not isdir(dirname): + _bypass_ensure_directory(dirname) + try: + mkdir(dirname, 0o755) + except FileExistsError: + pass + + +def split_sections(s): + """Split a string or iterable thereof into (section, content) pairs + + Each ``section`` is a stripped version of the section header ("[section]") + and each ``content`` is a list of stripped lines excluding blank lines and + comment-only lines. If there are any such lines before the first section + header, they're returned in a first ``section`` of ``None``. + """ + section = None + content = [] + for line in yield_lines(s): + if line.startswith("["): + if line.endswith("]"): + if section or content: + yield section, content + section = line[1:-1].strip() + content = [] + else: + raise ValueError("Invalid section heading", line) + else: + content.append(line) + + # wrap up last segment + yield section, content + + +def _mkstemp(*args, **kw): + old_open = os.open + try: + # temporarily bypass sandboxing + os.open = os_open + return tempfile.mkstemp(*args, **kw) + finally: + # and then put it back + os.open = old_open + + +# Silence the PEP440Warning by default, so that end users don't get hit by it +# randomly just because they use pkg_resources. We want to append the rule +# because we want earlier uses of filterwarnings to take precedence over this +# one. +warnings.filterwarnings("ignore", category=PEP440Warning, append=True) + + +# from jaraco.functools 1.3 +def _call_aside(f, *args, **kwargs): + f(*args, **kwargs) + return f + + +@_call_aside +def _initialize(g=globals()): + "Set up global resource manager (deliberately not state-saved)" + manager = ResourceManager() + g['_manager'] = manager + g.update( + (name, getattr(manager, name)) + for name in dir(manager) + if not name.startswith('_') + ) + + +@_call_aside +def _initialize_master_working_set(): + """ + Prepare the master working set and make the ``require()`` + API available. + + This function has explicit effects on the global state + of pkg_resources. It is intended to be invoked once at + the initialization of this module. + + Invocation by other packages is unsupported and done + at their own risk. + """ + working_set = WorkingSet._build_master() + _declare_state('object', working_set=working_set) + + require = working_set.require + iter_entry_points = working_set.iter_entry_points + add_activation_listener = working_set.subscribe + run_script = working_set.run_script + # backward compatibility + run_main = run_script + # Activate all distributions already on sys.path with replace=False and + # ensure that all distributions added to the working set in the future + # (e.g. by calling ``require()``) will get activated as well, + # with higher priority (replace=True). + tuple( + dist.activate(replace=False) + for dist in working_set + ) + add_activation_listener( + lambda dist: dist.activate(replace=True), + existing=False, + ) + working_set.entries = [] + # match order + list(map(working_set.add_entry, sys.path)) + globals().update(locals()) + +class PkgResourcesDeprecationWarning(Warning): + """ + Base class for warning about deprecations in ``pkg_resources`` + + This class is not derived from ``DeprecationWarning``, and as such is + visible by default. + """ diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pkg_resources/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pkg_resources/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..cdebfca9900f85d81b2860217e7b66d6484a5bec GIT binary patch literal 100197 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%0AIHllSP;AOcuO!`V%W^&U{@m^at`Nz5Om1ITG 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 VcM8Qt#g)ay1I!S*Pnm|U{a<IpG3x*T literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pkg_resources/__pycache__/py31compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pkg_resources/__pycache__/py31compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3efddf2bb39eb2feb58158c756b8cf040893e117 GIT binary patch literal 661 zcmYjO&2G~`5T0E-iJK;&C&VlG&^k$>QlttYP^u!Kf|LTSFUDjyiGN~SvyPQSDF?)Z z&?7gVXRn;{0vtFXW&>26)qJxvyV~#DnYZnB6UcskzYY5w;D<@>n?=bpa`k~gfM6;3 ze<SnRF6Ta{$Wv=>`!)mN2wT*?Fux}4xL&*xb;;v~4HhIUKNpPzGMfVf-;oZ!leNs2 z5bybWf{no4+Y$?0xJ+9rTAqzb(VZD3M(Yc5bxyGEl<<{p;Fd9X57}cIN}e?FIfEO{ zVEu5zu)E>0Ra&u~SlItex1Nyp8~%x3!8K%r0*IAexHZjlrJZ@0ND-mZjn|_gVvf2d z5wl#^hr_Fvqf6J)b`h2{?Z{=M${<g)C70uGfcqrq*UBp}s=`uwRfygsPlZI~4VK<C z7*sf4XZ=asoz0f(b&w8DKF+X9HqE?CuZW7nC{tyarib0`Nwuna3sc;AP{~Z>=oQH{ zK&kQtj-~R7)p2i}&q>ZvvC^&JzxLp`=a?4l=E^whumf7yrkcyQri)wK>@Dn2zz3$l zOo5%bO*H3NC!h(el-?%|NB{WIOk?+sw%%O#b*rM^MR^uP*(BGUOiH2dRG{J5b>$wk e%)8F%JQs^pJ~gE3fWTq2c*|<G>g>^PZvO$CjGu1+ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pkg_resources/py31compat.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pkg_resources/py31compat.py new file mode 100644 index 0000000..a2d3007 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pkg_resources/py31compat.py @@ -0,0 +1,23 @@ +import os +import errno +import sys + +from pip._vendor import six + + +def _makedirs_31(path, exist_ok=False): + try: + os.makedirs(path) + except OSError as exc: + if not exist_ok or exc.errno != errno.EEXIST: + raise + + +# rely on compatibility behavior until mode considerations +# and exists_ok considerations are disentangled. +# See https://github.com/pypa/setuptools/pull/1083#issuecomment-315168663 +needs_makedirs = ( + six.PY2 or + (3, 4) <= sys.version_info < (3, 4, 1) +) +makedirs = _makedirs_31 if needs_makedirs else os.makedirs diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__init__.py new file mode 100644 index 0000000..e434c25 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__init__.py @@ -0,0 +1,177 @@ +# Copyright (c) 2012 Giorgos Verigakis <verigak@gmail.com> +# +# Permission to use, copy, modify, and distribute this software for any +# purpose with or without fee is hereby granted, provided that the above +# copyright notice and this permission notice appear in all copies. +# +# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +from __future__ import division, print_function + +from collections import deque +from datetime import timedelta +from math import ceil +from sys import stderr +try: + from time import monotonic +except ImportError: + from time import time as monotonic + + +__version__ = '1.5' + +HIDE_CURSOR = '\x1b[?25l' +SHOW_CURSOR = '\x1b[?25h' + + +class Infinite(object): + file = stderr + sma_window = 10 # Simple Moving Average window + check_tty = True + hide_cursor = True + + def __init__(self, message='', **kwargs): + self.index = 0 + self.start_ts = monotonic() + self.avg = 0 + self._avg_update_ts = self.start_ts + self._ts = self.start_ts + self._xput = deque(maxlen=self.sma_window) + for key, val in kwargs.items(): + setattr(self, key, val) + + self._width = 0 + self.message = message + + if self.file and self.is_tty(): + if self.hide_cursor: + print(HIDE_CURSOR, end='', file=self.file) + print(self.message, end='', file=self.file) + self.file.flush() + + def __getitem__(self, key): + if key.startswith('_'): + return None + return getattr(self, key, None) + + @property + def elapsed(self): + return int(monotonic() - self.start_ts) + + @property + def elapsed_td(self): + return timedelta(seconds=self.elapsed) + + def update_avg(self, n, dt): + if n > 0: + xput_len = len(self._xput) + self._xput.append(dt / n) + now = monotonic() + # update when we're still filling _xput, then after every second + if (xput_len < self.sma_window or + now - self._avg_update_ts > 1): + self.avg = sum(self._xput) / len(self._xput) + self._avg_update_ts = now + + def update(self): + pass + + def start(self): + pass + + def clearln(self): + if self.file and self.is_tty(): + print('\r\x1b[K', end='', file=self.file) + + def write(self, s): + if self.file and self.is_tty(): + line = self.message + s.ljust(self._width) + print('\r' + line, end='', file=self.file) + self._width = max(self._width, len(s)) + self.file.flush() + + def writeln(self, line): + if self.file and self.is_tty(): + self.clearln() + print(line, end='', file=self.file) + self.file.flush() + + def finish(self): + if self.file and self.is_tty(): + print(file=self.file) + if self.hide_cursor: + print(SHOW_CURSOR, end='', file=self.file) + + def is_tty(self): + return self.file.isatty() if self.check_tty else True + + def next(self, n=1): + now = monotonic() + dt = now - self._ts + self.update_avg(n, dt) + self._ts = now + self.index = self.index + n + self.update() + + def iter(self, it): + with self: + for x in it: + yield x + self.next() + + def __enter__(self): + self.start() + return self + + def __exit__(self, exc_type, exc_val, exc_tb): + self.finish() + + +class Progress(Infinite): + def __init__(self, *args, **kwargs): + super(Progress, self).__init__(*args, **kwargs) + self.max = kwargs.get('max', 100) + + @property + def eta(self): + return int(ceil(self.avg * self.remaining)) + + @property + def eta_td(self): + return timedelta(seconds=self.eta) + + @property + def percent(self): + return self.progress * 100 + + @property + def progress(self): + return min(1, self.index / self.max) + + @property + def remaining(self): + return max(self.max - self.index, 0) + + def start(self): + self.update() + + def goto(self, index): + incr = index - self.index + self.next(incr) + + def iter(self, it): + try: + self.max = len(it) + except TypeError: + pass + + with self: + for x in it: + yield x + self.next() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3b4a91c15c090c2541bdd0a205f9b8f9db4453e3 GIT binary patch literal 5630 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 XhE+rA#h-=j9G48+u@DXI#^!$ko@-s5 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__pycache__/bar.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__pycache__/bar.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..38386ac4e33ef65abc2693934bb463bf6ec8e352 GIT binary patch literal 2654 zcmbtV&2Jk;6yMozubtFMKS;}0prnd{)&WGJ2th;yh>KOJz`+-5n_1gy)*CZx=fhe{ zNU5OZQ+y~Dw}c*0ParNF`9J0er~CnM=%xJL?51{`^nlppy*Ix%<C*tn-u&i+sVPsx z_s_3;{<)&2{Y7B%GXa(%$q!Im<1Es;tj-v<^+>Pl+~8(pbj`ZSw0AXbar>Ia?ZDhN z>K3rWU0^q`fNkIc_kg{?26ljpyaZfQ*ae>A)4<bed;$0vF9Vl@0>*p5Gkg|!R^cMo zuV|Iy`-n`dFj*eN;p!R>8d2B}gdZifeU|mOm&IC31WB?=Lnl8SU>TA;4;5&2#x<nG z>IT>ACPxa~tlQkGJKV0jSu*tkFJM_u8gKbxe;&UZ&MYj3F%LE?yt=U1^<jtld^*(A z`8y2%XICkXgU>~SWCfCRp!!;>br?iHp>4AfwOGpLw2_XMk!q*35p>5)*$HiAqGhER zIkM2QRj<w2u9MOjH#Jl87gD=r@3E1SYP(+Q?5XoY(0Wa3m7+AlxG$}ZkoVit?d5wT zoi29BZw1n9hEXKFpxf(jHB{S92F+%;Db3DW7)$S}FB&}&kVm!iUS~sK=cBmdN;3(f zrktW52fPslaSKb8vKccZrjWWcFqO2FUzEvVMqwP>*2JR#ce>S{2-p37P+j*$wYe7Y zKqS>mo7Gn1(z@sl;}@HqrFMIBIBZ0hE?#YmC48;8`hK++_RfcK()Xk2{L<3J^{w?6 z2IN%ISPx>pCNOzc6;%Xrp|>UNL62jxc`TirfYMl*dAi54zgec=we_KgQ@@Z6tf2_p zMkDsSL8BqPMx(pN2NAVPjmF0VKgxOp?v<vp6SLGhPU;w`X;P1qqI4(JV+1XzIY>go zTxO2{bk%pLn5oK^=?C*rhl*K8G2;%RpdD_Z7HnBuY5SrT#x0~YoLX4y1!6Ub`xU;h zARJ6FFrfat{^Q@u?p&``T=4{4;z?5Tr0C3!%<8Cwp2Fbskc22_oRA>@!;_(tIFyWm z1WY;e4(bc>U%_VMdLxZ2<ei^#d#iTadNAbi&L0)yS*-RlBq8FX7zKI$S9B|(SdAv4 zyZK8N-OU>{@eC%PICmA1I{XE6yapM^L7qc#7;rAruxFtTb}2AA=B~xr9usH4V|GkT zhJ)wUHI0}Id*{gM_u^F%baCE(gpHHNMi^HNb?*6je<_~Eq?N)%E$n=gZ|v8({Yori zOb))t?dQ3@p(ePG{7M*IfUH20-=H$`%V|#$9;i+4o2d?;K{hq!G@?FWB0q%{`GM#_ zjiA5|<LtDS8u+D?nq2?L6j#Zcny0lG57fv7vilC#Qw!_4+aT9%qR;~T=))`?H+Dgq zz@W?2O{u4tdM!}rs0b1*rNw(BYS#Ae;uCb;1SM0Mk_Jdk+P$`)1W9(^DN{j(u82<E zcWK~l$ga!`b&T17YP?bsCt;)$XVXY;%%0MUn*(sNrMjdYXN*Y{Du^PavpNt0XDLpT zOWn#d)Ebw#sw(1|w;>5#V-3VsVs1`y)9e(RgQv_)O%dJ6`wQeA=RL>)(nz)vJR_0c zZ?1{1^uW5JpKOHvws;P!Je=Upq4!NlqMk&=V(X?Z$a|>H?@=42c2MWpJB?~Kq<cBs z45*GPZdQDIpXByhZa>ZKXPLcqV1Lf>@45Y>cH4ZAGE^GltsLLdi-_h!%0P#5nIQb% zW53e&`4+`)O<uKcvw(KK%kB5-Hr2!{SYzT`$HBacjymKZ7{Zkjy-UqOe<1KK2?|rZ zM2hNG5XY&fL{YF}Izcp}&Ojw2Xp*B=lkV%;Yxf3~azdqC(p|k|luwr3vW34#%I3e# C*(&J( literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__pycache__/counter.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__pycache__/counter.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..83d0d383ea4795d22c65eacd88f9fb3351359bbe GIT binary patch literal 1486 zcmbVMy>HV%6u<M?iJc}8pr9585EC9+2Zl<O5USJxu|$;$ON3-h?vlFLPI|V}HcAIb z`H&b85+5rav+?)b2vh$7hEBZaIBg2;02jUY{O;Ymdmq1-CzVQx!20$5z<X*C@)MQm zrGv5p6h8yT38w)GX@gS2HO>MpWDOST4V{vQgzMbcC)^Nh$QlOd1zrTbD0I*ZpqtzR z-OBVL=p{Y_`iv-o-Q?wUVpk5~6=G9WO(VbA;ld64L`W})4=EZnWj=~pegvD!T$7!) z6mi@{pXsH6vH}#(0u!V`IcaE|a&4b97-#T~u8OOjG=i&}c<*H4HzvFalsON`H<Hi+ z+0=&g0Fx%`WJK#WQ^vN$AXuD8W%v;nJ0q&}SOl#RkrnVi+H$(m?|F%EdY*Jzoq!7& zJIgyx+g<L-upixPZPqq6cKUrcSYCR*A#1SOk@MK;`rQRTiW4sg7HYMn-fr)1iklg^ zJrVJagv-a-JI!$-i``vSNV^;!yoTXp5eV&H$n#tro9ZK7nXVgop>SPQa^0}Q(*VEA zuDg|b!Pp`%f^(L}6uW?X1z=Z!vinV%>HpOLD+`QwwxfS<fh<A<Hj^esWC2r_6rl&W zh}v=nH?ad_mPL)}+yI(XrF#7Mq%N|0?D2;$g6R6h7cxfu{EX+odIC9s8;l9SPUkwn z&QQjB;x%8`))BpxGC2C<%gbE8%H=SZ`?-9b%Qv}vo6C2n%7%Br_>Pgg1Rn_j)Y2i{ zqlq@4oX(Mi!Hzzlvt&qz+MWj3Ht@_qn<o=&+ge@XRdzwKKt!t0-SA=&D;D~ZVt$k; zbAr39_|Stg99P9CKS=$vN`D*9#E2Y1OLUI*%UKmBrMC@v2~6@bvMb2uk(~=cg!fIL z7)RBlx+Zbwua@92uK>l^+0!k7RxriZd|?~oYJPp6%TKxdn9I+({7|>`Gow5KOZJta z4THObFXIdXVo<N!7LHphO;QQtCefsb#1tepE*qo_TUj=l&r~UoFIVRM@yI^Fn#K6% MU8Yr5HQ;Cc2KR+5F8}}l literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__pycache__/spinner.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/__pycache__/spinner.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8dbdc9fbb95d92f3002e7af1876236f92d218cc2 GIT binary patch literal 1413 zcmbVMNpI6Y6rS;tI9mxj1%wbnNI_~HI8>^HP$Uir38G3Z7YoTUok`-#vD0xJ(x{x; zbH#Gt2qmYU;J_lW{tqAF)IY!>C*HHCkkG0JCVKD9_hvlvy=8L0RLT<=zus;;Oef?g zg7KjNsDXqYC`K6dNSj)e5~eWKQ`)MfQgWLxjp>_&>0I4VEe&vnWdUco23QAdupHoA zf-`{gtN^%>;4I)GD*-Mg*kDtOq;g~zZX^{Nmm}X@4j8vRx66g&g}XFeFz)yb*9Ye^ z?i?QqfEq}69uy}QWyDe#wN$298dI6JNi3b|a7!l6E_Phs=c1yG=*);d7}50+HJ6t0 zlD&cFVJ2>YgqK0BlNHjXpp^}JiadtdD;3c?ohI9u9Rg?5dPR$M*Jr#Rs~-2`OsD09 zJdE{60$5j+SPQw=h^f0nL>W#Ut(qO-_M9#^dyX(0fycNA&H29BwC8)GJ@BtLR;sO5 ze=xAU`MHNJQH9a;%_Xzrc4k~Z>^hz|Q?1VR)_T_>bS7f=xX%IshX+l;!_W-VkY_t< zaVF|8xNsUH!w?BA)4`O?$!xk<hcp?s?K^F5+i~8u+X0I_oEL3-HFCUkMHJ!lxX^N; zR?CqH10jxqCkbs#9Yr7X8aW9PW<VKKqneWV_LcHa1D=76e@lt&$F!yfB~8niUvRl( z9jUPO$BU2BevtOPwD0OWnm7(y#0gZ$B4Iv85sM)bo~L1U0VKp0FsMNM-y93~g2107 z`Baj6ChZexpVtKjd>|*R)g_QUPKft$!o1dS)8rFK^9H$7nwdYjE8KPc$>eQ)N_lL3 zmiCLZUk~AR7OuO3SIS%=-p9)TXAL)91odw{nT~%P%xD_GEeB619~T$gKKCY)HvE>7 z8OjO|-$?v2wcFoQ`&!ze3}Sc~`Ex+$D)N%#5!Wj@?Dj^~jRbVNz@?Z7Y{{fqlWq{0 geu1$H{N|vF#m0^F#oWZ63h|i~X;Cfb${PND14tz+q5uE@ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/bar.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/bar.py new file mode 100644 index 0000000..8819efd --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/bar.py @@ -0,0 +1,91 @@ +# -*- coding: utf-8 -*- + +# Copyright (c) 2012 Giorgos Verigakis <verigak@gmail.com> +# +# Permission to use, copy, modify, and distribute this software for any +# purpose with or without fee is hereby granted, provided that the above +# copyright notice and this permission notice appear in all copies. +# +# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +from __future__ import unicode_literals + +import sys + +from . import Progress + + +class Bar(Progress): + width = 32 + suffix = '%(index)d/%(max)d' + bar_prefix = ' |' + bar_suffix = '| ' + empty_fill = ' ' + fill = '#' + + def update(self): + filled_length = int(self.width * self.progress) + empty_length = self.width - filled_length + + message = self.message % self + bar = self.fill * filled_length + empty = self.empty_fill * empty_length + suffix = self.suffix % self + line = ''.join([message, self.bar_prefix, bar, empty, self.bar_suffix, + suffix]) + self.writeln(line) + + +class ChargingBar(Bar): + suffix = '%(percent)d%%' + bar_prefix = ' ' + bar_suffix = ' ' + empty_fill = '∙' + fill = '█' + + +class FillingSquaresBar(ChargingBar): + empty_fill = '▢' + fill = '▣' + + +class FillingCirclesBar(ChargingBar): + empty_fill = '◯' + fill = '◉' + + +class IncrementalBar(Bar): + if sys.platform.startswith('win'): + phases = (u' ', u'▌', u'█') + else: + phases = (' ', '▏', '▎', '▍', '▌', '▋', '▊', '▉', '█') + + def update(self): + nphases = len(self.phases) + filled_len = self.width * self.progress + nfull = int(filled_len) # Number of full chars + phase = int((filled_len - nfull) * nphases) # Phase of last char + nempty = self.width - nfull # Number of empty chars + + message = self.message % self + bar = self.phases[-1] * nfull + current = self.phases[phase] if phase > 0 else '' + empty = self.empty_fill * max(0, nempty - len(current)) + suffix = self.suffix % self + line = ''.join([message, self.bar_prefix, bar, current, empty, + self.bar_suffix, suffix]) + self.writeln(line) + + +class PixelBar(IncrementalBar): + phases = ('⡀', '⡄', '⡆', '⡇', '⣇', '⣧', '⣷', '⣿') + + +class ShadyBar(IncrementalBar): + phases = (' ', '░', '▒', '▓', '█') diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/counter.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/counter.py new file mode 100644 index 0000000..d955ca4 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/counter.py @@ -0,0 +1,41 @@ +# -*- coding: utf-8 -*- + +# Copyright (c) 2012 Giorgos Verigakis <verigak@gmail.com> +# +# Permission to use, copy, modify, and distribute this software for any +# purpose with or without fee is hereby granted, provided that the above +# copyright notice and this permission notice appear in all copies. +# +# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +from __future__ import unicode_literals +from . import Infinite, Progress + + +class Counter(Infinite): + def update(self): + self.write(str(self.index)) + + +class Countdown(Progress): + def update(self): + self.write(str(self.remaining)) + + +class Stack(Progress): + phases = (' ', '▁', '▂', '▃', '▄', '▅', '▆', '▇', '█') + + def update(self): + nphases = len(self.phases) + i = min(nphases - 1, int(self.progress * nphases)) + self.write(self.phases[i]) + + +class Pie(Stack): + phases = ('○', '◔', '◑', '◕', '●') diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/spinner.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/spinner.py new file mode 100644 index 0000000..4e100ca --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/progress/spinner.py @@ -0,0 +1,43 @@ +# -*- coding: utf-8 -*- + +# Copyright (c) 2012 Giorgos Verigakis <verigak@gmail.com> +# +# Permission to use, copy, modify, and distribute this software for any +# purpose with or without fee is hereby granted, provided that the above +# copyright notice and this permission notice appear in all copies. +# +# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +from __future__ import unicode_literals +from . import Infinite + + +class Spinner(Infinite): + phases = ('-', '\\', '|', '/') + hide_cursor = True + + def update(self): + i = self.index % len(self.phases) + self.write(self.phases[i]) + + +class PieSpinner(Spinner): + phases = ['◷', '◶', '◵', '◴'] + + +class MoonSpinner(Spinner): + phases = ['◑', '◒', '◐', '◓'] + + +class LineSpinner(Spinner): + phases = ['⎺', '⎻', '⎼', '⎽', '⎼', '⎻'] + + +class PixelSpinner(Spinner): + phases = ['⣾', '⣷', '⣯', '⣟', '⡿', '⢿', '⣻', '⣽'] diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pyparsing.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pyparsing.py new file mode 100644 index 0000000..9d6a01d --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pyparsing.py @@ -0,0 +1,6493 @@ +#-*- coding: utf-8 -*- +# module pyparsing.py +# +# Copyright (c) 2003-2019 Paul T. McGuire +# +# Permission is hereby granted, free of charge, to any person obtaining +# a copy of this software and associated documentation files (the +# "Software"), to deal in the Software without restriction, including +# without limitation the rights to use, copy, modify, merge, publish, +# distribute, sublicense, and/or sell copies of the Software, and to +# permit persons to whom the Software is furnished to do so, subject to +# the following conditions: +# +# The above copyright notice and this permission notice shall be +# included in all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +# + +__doc__ = \ +""" +pyparsing module - Classes and methods to define and execute parsing grammars +============================================================================= + +The pyparsing module is an alternative approach to creating and +executing simple grammars, vs. the traditional lex/yacc approach, or the +use of regular expressions. With pyparsing, you don't need to learn +a new syntax for defining grammars or matching expressions - the parsing +module provides a library of classes that you use to construct the +grammar directly in Python. + +Here is a program to parse "Hello, World!" (or any greeting of the form +``"<salutation>, <addressee>!"``), built up using :class:`Word`, +:class:`Literal`, and :class:`And` elements +(the :class:`'+'<ParserElement.__add__>` operators create :class:`And` expressions, +and the strings are auto-converted to :class:`Literal` expressions):: + + from pip._vendor.pyparsing import Word, alphas + + # define grammar of a greeting + greet = Word(alphas) + "," + Word(alphas) + "!" + + hello = "Hello, World!" + print (hello, "->", greet.parseString(hello)) + +The program outputs the following:: + + Hello, World! -> ['Hello', ',', 'World', '!'] + +The Python representation of the grammar is quite readable, owing to the +self-explanatory class names, and the use of '+', '|' and '^' operators. + +The :class:`ParseResults` object returned from +:class:`ParserElement.parseString` can be +accessed as a nested list, a dictionary, or an object with named +attributes. + +The pyparsing module handles some of the problems that are typically +vexing when writing text parsers: + + - extra or missing whitespace (the above program will also handle + "Hello,World!", "Hello , World !", etc.) + - quoted strings + - embedded comments + + +Getting Started - +----------------- +Visit the classes :class:`ParserElement` and :class:`ParseResults` to +see the base classes that most other pyparsing +classes inherit from. Use the docstrings for examples of how to: + + - construct literal match expressions from :class:`Literal` and + :class:`CaselessLiteral` classes + - construct character word-group expressions using the :class:`Word` + class + - see how to create repetitive expressions using :class:`ZeroOrMore` + and :class:`OneOrMore` classes + - use :class:`'+'<And>`, :class:`'|'<MatchFirst>`, :class:`'^'<Or>`, + and :class:`'&'<Each>` operators to combine simple expressions into + more complex ones + - associate names with your parsed results using + :class:`ParserElement.setResultsName` + - find some helpful expression short-cuts like :class:`delimitedList` + and :class:`oneOf` + - find more useful common expressions in the :class:`pyparsing_common` + namespace class +""" + +__version__ = "2.4.0" +__versionTime__ = "07 Apr 2019 18:28 UTC" +__author__ = "Paul McGuire <ptmcg@users.sourceforge.net>" + +import string +from weakref import ref as wkref +import copy +import sys +import warnings +import re +import sre_constants +import collections +import pprint +import traceback +import types +from datetime import datetime + +try: + # Python 3 + from itertools import filterfalse +except ImportError: + from itertools import ifilterfalse as filterfalse + +try: + from _thread import RLock +except ImportError: + from threading import RLock + +try: + # Python 3 + from collections.abc import Iterable + from collections.abc import MutableMapping +except ImportError: + # Python 2.7 + from collections import Iterable + from collections import MutableMapping + +try: + from collections import OrderedDict as _OrderedDict +except ImportError: + try: + from ordereddict import OrderedDict as _OrderedDict + except ImportError: + _OrderedDict = None + +try: + from types import SimpleNamespace +except ImportError: + class SimpleNamespace: pass + +# version compatibility configuration +__compat__ = SimpleNamespace() +__compat__.__doc__ = """ + A cross-version compatibility configuration for pyparsing features that will be + released in a future version. By setting values in this configuration to True, + those features can be enabled in prior versions for compatibility development + and testing. + + - collect_all_And_tokens - flag to enable fix for Issue #63 that fixes erroneous grouping + of results names when an And expression is nested within an Or or MatchFirst; set to + True to enable bugfix to be released in pyparsing 2.4 +""" +__compat__.collect_all_And_tokens = True + + +#~ sys.stderr.write( "testing pyparsing module, version %s, %s\n" % (__version__,__versionTime__ ) ) + +__all__ = [ '__version__', '__versionTime__', '__author__', '__compat__', +'And', 'CaselessKeyword', 'CaselessLiteral', 'CharsNotIn', 'Combine', 'Dict', 'Each', 'Empty', +'FollowedBy', 'Forward', 'GoToColumn', 'Group', 'Keyword', 'LineEnd', 'LineStart', 'Literal', +'PrecededBy', 'MatchFirst', 'NoMatch', 'NotAny', 'OneOrMore', 'OnlyOnce', 'Optional', 'Or', +'ParseBaseException', 'ParseElementEnhance', 'ParseException', 'ParseExpression', 'ParseFatalException', +'ParseResults', 'ParseSyntaxException', 'ParserElement', 'QuotedString', 'RecursiveGrammarException', +'Regex', 'SkipTo', 'StringEnd', 'StringStart', 'Suppress', 'Token', 'TokenConverter', +'White', 'Word', 'WordEnd', 'WordStart', 'ZeroOrMore', 'Char', +'alphanums', 'alphas', 'alphas8bit', 'anyCloseTag', 'anyOpenTag', 'cStyleComment', 'col', +'commaSeparatedList', 'commonHTMLEntity', 'countedArray', 'cppStyleComment', 'dblQuotedString', +'dblSlashComment', 'delimitedList', 'dictOf', 'downcaseTokens', 'empty', 'hexnums', +'htmlComment', 'javaStyleComment', 'line', 'lineEnd', 'lineStart', 'lineno', +'makeHTMLTags', 'makeXMLTags', 'matchOnlyAtCol', 'matchPreviousExpr', 'matchPreviousLiteral', +'nestedExpr', 'nullDebugAction', 'nums', 'oneOf', 'opAssoc', 'operatorPrecedence', 'printables', +'punc8bit', 'pythonStyleComment', 'quotedString', 'removeQuotes', 'replaceHTMLEntity', +'replaceWith', 'restOfLine', 'sglQuotedString', 'srange', 'stringEnd', +'stringStart', 'traceParseAction', 'unicodeString', 'upcaseTokens', 'withAttribute', +'indentedBlock', 'originalTextFor', 'ungroup', 'infixNotation','locatedExpr', 'withClass', +'CloseMatch', 'tokenMap', 'pyparsing_common', 'pyparsing_unicode', 'unicode_set', +] + +system_version = tuple(sys.version_info)[:3] +PY_3 = system_version[0] == 3 +if PY_3: + _MAX_INT = sys.maxsize + basestring = str + unichr = chr + unicode = str + _ustr = str + + # build list of single arg builtins, that can be used as parse actions + singleArgBuiltins = [sum, len, sorted, reversed, list, tuple, set, any, all, min, max] + +else: + _MAX_INT = sys.maxint + range = xrange + + def _ustr(obj): + """Drop-in replacement for str(obj) that tries to be Unicode + friendly. It first tries str(obj). If that fails with + a UnicodeEncodeError, then it tries unicode(obj). It then + < returns the unicode object | encodes it with the default + encoding | ... >. + """ + if isinstance(obj,unicode): + return obj + + try: + # If this works, then _ustr(obj) has the same behaviour as str(obj), so + # it won't break any existing code. + return str(obj) + + except UnicodeEncodeError: + # Else encode it + ret = unicode(obj).encode(sys.getdefaultencoding(), 'xmlcharrefreplace') + xmlcharref = Regex(r'&#\d+;') + xmlcharref.setParseAction(lambda t: '\\u' + hex(int(t[0][2:-1]))[2:]) + return xmlcharref.transformString(ret) + + # build list of single arg builtins, tolerant of Python version, that can be used as parse actions + singleArgBuiltins = [] + import __builtin__ + for fname in "sum len sorted reversed list tuple set any all min max".split(): + try: + singleArgBuiltins.append(getattr(__builtin__,fname)) + except AttributeError: + continue + +_generatorType = type((y for y in range(1))) + +def _xml_escape(data): + """Escape &, <, >, ", ', etc. in a string of data.""" + + # ampersand must be replaced first + from_symbols = '&><"\'' + to_symbols = ('&'+s+';' for s in "amp gt lt quot apos".split()) + for from_,to_ in zip(from_symbols, to_symbols): + data = data.replace(from_, to_) + return data + +alphas = string.ascii_uppercase + string.ascii_lowercase +nums = "0123456789" +hexnums = nums + "ABCDEFabcdef" +alphanums = alphas + nums +_bslash = chr(92) +printables = "".join(c for c in string.printable if c not in string.whitespace) + +class ParseBaseException(Exception): + """base exception class for all parsing runtime exceptions""" + # Performance tuning: we construct a *lot* of these, so keep this + # constructor as small and fast as possible + def __init__( self, pstr, loc=0, msg=None, elem=None ): + self.loc = loc + if msg is None: + self.msg = pstr + self.pstr = "" + else: + self.msg = msg + self.pstr = pstr + self.parserElement = elem + self.args = (pstr, loc, msg) + + @classmethod + def _from_exception(cls, pe): + """ + internal factory method to simplify creating one type of ParseException + from another - avoids having __init__ signature conflicts among subclasses + """ + return cls(pe.pstr, pe.loc, pe.msg, pe.parserElement) + + def __getattr__( self, aname ): + """supported attributes by name are: + - lineno - returns the line number of the exception text + - col - returns the column number of the exception text + - line - returns the line containing the exception text + """ + if( aname == "lineno" ): + return lineno( self.loc, self.pstr ) + elif( aname in ("col", "column") ): + return col( self.loc, self.pstr ) + elif( aname == "line" ): + return line( self.loc, self.pstr ) + else: + raise AttributeError(aname) + + def __str__( self ): + return "%s (at char %d), (line:%d, col:%d)" % \ + ( self.msg, self.loc, self.lineno, self.column ) + def __repr__( self ): + return _ustr(self) + def markInputline( self, markerString = ">!<" ): + """Extracts the exception line from the input string, and marks + the location of the exception with a special symbol. + """ + line_str = self.line + line_column = self.column - 1 + if markerString: + line_str = "".join((line_str[:line_column], + markerString, line_str[line_column:])) + return line_str.strip() + def __dir__(self): + return "lineno col line".split() + dir(type(self)) + +class ParseException(ParseBaseException): + """ + Exception thrown when parse expressions don't match class; + supported attributes by name are: + - lineno - returns the line number of the exception text + - col - returns the column number of the exception text + - line - returns the line containing the exception text + + Example:: + + try: + Word(nums).setName("integer").parseString("ABC") + except ParseException as pe: + print(pe) + print("column: {}".format(pe.col)) + + prints:: + + Expected integer (at char 0), (line:1, col:1) + column: 1 + + """ + + @staticmethod + def explain(exc, depth=16): + """ + Method to take an exception and translate the Python internal traceback into a list + of the pyparsing expressions that caused the exception to be raised. + + Parameters: + + - exc - exception raised during parsing (need not be a ParseException, in support + of Python exceptions that might be raised in a parse action) + - depth (default=16) - number of levels back in the stack trace to list expression + and function names; if None, the full stack trace names will be listed; if 0, only + the failing input line, marker, and exception string will be shown + + Returns a multi-line string listing the ParserElements and/or function names in the + exception's stack trace. + + Note: the diagnostic output will include string representations of the expressions + that failed to parse. These representations will be more helpful if you use `setName` to + give identifiable names to your expressions. Otherwise they will use the default string + forms, which may be cryptic to read. + + explain() is only supported under Python 3. + """ + import inspect + + if depth is None: + depth = sys.getrecursionlimit() + ret = [] + if isinstance(exc, ParseBaseException): + ret.append(exc.line) + ret.append(' ' * (exc.col - 1) + '^') + ret.append("{0}: {1}".format(type(exc).__name__, exc)) + + if depth > 0: + callers = inspect.getinnerframes(exc.__traceback__, context=depth) + seen = set() + for i, ff in enumerate(callers[-depth:]): + frm = ff[0] + + f_self = frm.f_locals.get('self', None) + if isinstance(f_self, ParserElement): + if frm.f_code.co_name not in ('parseImpl', '_parseNoCache'): + continue + if f_self in seen: + continue + seen.add(f_self) + + self_type = type(f_self) + ret.append("{0}.{1} - {2}".format(self_type.__module__, + self_type.__name__, + f_self)) + elif f_self is not None: + self_type = type(f_self) + ret.append("{0}.{1}".format(self_type.__module__, + self_type.__name__)) + else: + code = frm.f_code + if code.co_name in ('wrapper', '<module>'): + continue + + ret.append("{0}".format(code.co_name)) + + depth -= 1 + if not depth: + break + + return '\n'.join(ret) + + +class ParseFatalException(ParseBaseException): + """user-throwable exception thrown when inconsistent parse content + is found; stops all parsing immediately""" + pass + +class ParseSyntaxException(ParseFatalException): + """just like :class:`ParseFatalException`, but thrown internally + when an :class:`ErrorStop<And._ErrorStop>` ('-' operator) indicates + that parsing is to stop immediately because an unbacktrackable + syntax error has been found. + """ + pass + +#~ class ReparseException(ParseBaseException): + #~ """Experimental class - parse actions can raise this exception to cause + #~ pyparsing to reparse the input string: + #~ - with a modified input string, and/or + #~ - with a modified start location + #~ Set the values of the ReparseException in the constructor, and raise the + #~ exception in a parse action to cause pyparsing to use the new string/location. + #~ Setting the values as None causes no change to be made. + #~ """ + #~ def __init_( self, newstring, restartLoc ): + #~ self.newParseText = newstring + #~ self.reparseLoc = restartLoc + +class RecursiveGrammarException(Exception): + """exception thrown by :class:`ParserElement.validate` if the + grammar could be improperly recursive + """ + def __init__( self, parseElementList ): + self.parseElementTrace = parseElementList + + def __str__( self ): + return "RecursiveGrammarException: %s" % self.parseElementTrace + +class _ParseResultsWithOffset(object): + def __init__(self,p1,p2): + self.tup = (p1,p2) + def __getitem__(self,i): + return self.tup[i] + def __repr__(self): + return repr(self.tup[0]) + def setOffset(self,i): + self.tup = (self.tup[0],i) + +class ParseResults(object): + """Structured parse results, to provide multiple means of access to + the parsed data: + + - as a list (``len(results)``) + - by list index (``results[0], results[1]``, etc.) + - by attribute (``results.<resultsName>`` - see :class:`ParserElement.setResultsName`) + + Example:: + + integer = Word(nums) + date_str = (integer.setResultsName("year") + '/' + + integer.setResultsName("month") + '/' + + integer.setResultsName("day")) + # equivalent form: + # date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + # parseString returns a ParseResults object + result = date_str.parseString("1999/12/31") + + def test(s, fn=repr): + print("%s -> %s" % (s, fn(eval(s)))) + test("list(result)") + test("result[0]") + test("result['month']") + test("result.day") + test("'month' in result") + test("'minutes' in result") + test("result.dump()", str) + + prints:: + + list(result) -> ['1999', '/', '12', '/', '31'] + result[0] -> '1999' + result['month'] -> '12' + result.day -> '31' + 'month' in result -> True + 'minutes' in result -> False + result.dump() -> ['1999', '/', '12', '/', '31'] + - day: 31 + - month: 12 + - year: 1999 + """ + def __new__(cls, toklist=None, name=None, asList=True, modal=True ): + if isinstance(toklist, cls): + return toklist + retobj = object.__new__(cls) + retobj.__doinit = True + return retobj + + # Performance tuning: we construct a *lot* of these, so keep this + # constructor as small and fast as possible + def __init__( self, toklist=None, name=None, asList=True, modal=True, isinstance=isinstance ): + if self.__doinit: + self.__doinit = False + self.__name = None + self.__parent = None + self.__accumNames = {} + self.__asList = asList + self.__modal = modal + if toklist is None: + toklist = [] + if isinstance(toklist, list): + self.__toklist = toklist[:] + elif isinstance(toklist, _generatorType): + self.__toklist = list(toklist) + else: + self.__toklist = [toklist] + self.__tokdict = dict() + + if name is not None and name: + if not modal: + self.__accumNames[name] = 0 + if isinstance(name,int): + name = _ustr(name) # will always return a str, but use _ustr for consistency + self.__name = name + if not (isinstance(toklist, (type(None), basestring, list)) and toklist in (None,'',[])): + if isinstance(toklist,basestring): + toklist = [ toklist ] + if asList: + if isinstance(toklist,ParseResults): + self[name] = _ParseResultsWithOffset(ParseResults(toklist.__toklist), 0) + else: + self[name] = _ParseResultsWithOffset(ParseResults(toklist[0]),0) + self[name].__name = name + else: + try: + self[name] = toklist[0] + except (KeyError,TypeError,IndexError): + self[name] = toklist + + def __getitem__( self, i ): + if isinstance( i, (int,slice) ): + return self.__toklist[i] + else: + if i not in self.__accumNames: + return self.__tokdict[i][-1][0] + else: + return ParseResults([ v[0] for v in self.__tokdict[i] ]) + + def __setitem__( self, k, v, isinstance=isinstance ): + if isinstance(v,_ParseResultsWithOffset): + self.__tokdict[k] = self.__tokdict.get(k,list()) + [v] + sub = v[0] + elif isinstance(k,(int,slice)): + self.__toklist[k] = v + sub = v + else: + self.__tokdict[k] = self.__tokdict.get(k,list()) + [_ParseResultsWithOffset(v,0)] + sub = v + if isinstance(sub,ParseResults): + sub.__parent = wkref(self) + + def __delitem__( self, i ): + if isinstance(i,(int,slice)): + mylen = len( self.__toklist ) + del self.__toklist[i] + + # convert int to slice + if isinstance(i, int): + if i < 0: + i += mylen + i = slice(i, i+1) + # get removed indices + removed = list(range(*i.indices(mylen))) + removed.reverse() + # fixup indices in token dictionary + for name,occurrences in self.__tokdict.items(): + for j in removed: + for k, (value, position) in enumerate(occurrences): + occurrences[k] = _ParseResultsWithOffset(value, position - (position > j)) + else: + del self.__tokdict[i] + + def __contains__( self, k ): + return k in self.__tokdict + + def __len__( self ): return len( self.__toklist ) + def __bool__(self): return ( not not self.__toklist ) + __nonzero__ = __bool__ + def __iter__( self ): return iter( self.__toklist ) + def __reversed__( self ): return iter( self.__toklist[::-1] ) + def _iterkeys( self ): + if hasattr(self.__tokdict, "iterkeys"): + return self.__tokdict.iterkeys() + else: + return iter(self.__tokdict) + + def _itervalues( self ): + return (self[k] for k in self._iterkeys()) + + def _iteritems( self ): + return ((k, self[k]) for k in self._iterkeys()) + + if PY_3: + keys = _iterkeys + """Returns an iterator of all named result keys.""" + + values = _itervalues + """Returns an iterator of all named result values.""" + + items = _iteritems + """Returns an iterator of all named result key-value tuples.""" + + else: + iterkeys = _iterkeys + """Returns an iterator of all named result keys (Python 2.x only).""" + + itervalues = _itervalues + """Returns an iterator of all named result values (Python 2.x only).""" + + iteritems = _iteritems + """Returns an iterator of all named result key-value tuples (Python 2.x only).""" + + def keys( self ): + """Returns all named result keys (as a list in Python 2.x, as an iterator in Python 3.x).""" + return list(self.iterkeys()) + + def values( self ): + """Returns all named result values (as a list in Python 2.x, as an iterator in Python 3.x).""" + return list(self.itervalues()) + + def items( self ): + """Returns all named result key-values (as a list of tuples in Python 2.x, as an iterator in Python 3.x).""" + return list(self.iteritems()) + + def haskeys( self ): + """Since keys() returns an iterator, this method is helpful in bypassing + code that looks for the existence of any defined results names.""" + return bool(self.__tokdict) + + def pop( self, *args, **kwargs): + """ + Removes and returns item at specified index (default= ``last``). + Supports both ``list`` and ``dict`` semantics for ``pop()``. If + passed no argument or an integer argument, it will use ``list`` + semantics and pop tokens from the list of parsed tokens. If passed + a non-integer argument (most likely a string), it will use ``dict`` + semantics and pop the corresponding value from any defined results + names. A second default return value argument is supported, just as in + ``dict.pop()``. + + Example:: + + def remove_first(tokens): + tokens.pop(0) + print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321'] + print(OneOrMore(Word(nums)).addParseAction(remove_first).parseString("0 123 321")) # -> ['123', '321'] + + label = Word(alphas) + patt = label("LABEL") + OneOrMore(Word(nums)) + print(patt.parseString("AAB 123 321").dump()) + + # Use pop() in a parse action to remove named result (note that corresponding value is not + # removed from list form of results) + def remove_LABEL(tokens): + tokens.pop("LABEL") + return tokens + patt.addParseAction(remove_LABEL) + print(patt.parseString("AAB 123 321").dump()) + + prints:: + + ['AAB', '123', '321'] + - LABEL: AAB + + ['AAB', '123', '321'] + """ + if not args: + args = [-1] + for k,v in kwargs.items(): + if k == 'default': + args = (args[0], v) + else: + raise TypeError("pop() got an unexpected keyword argument '%s'" % k) + if (isinstance(args[0], int) or + len(args) == 1 or + args[0] in self): + index = args[0] + ret = self[index] + del self[index] + return ret + else: + defaultvalue = args[1] + return defaultvalue + + def get(self, key, defaultValue=None): + """ + Returns named result matching the given key, or if there is no + such name, then returns the given ``defaultValue`` or ``None`` if no + ``defaultValue`` is specified. + + Similar to ``dict.get()``. + + Example:: + + integer = Word(nums) + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + result = date_str.parseString("1999/12/31") + print(result.get("year")) # -> '1999' + print(result.get("hour", "not specified")) # -> 'not specified' + print(result.get("hour")) # -> None + """ + if key in self: + return self[key] + else: + return defaultValue + + def insert( self, index, insStr ): + """ + Inserts new element at location index in the list of parsed tokens. + + Similar to ``list.insert()``. + + Example:: + + print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321'] + + # use a parse action to insert the parse location in the front of the parsed results + def insert_locn(locn, tokens): + tokens.insert(0, locn) + print(OneOrMore(Word(nums)).addParseAction(insert_locn).parseString("0 123 321")) # -> [0, '0', '123', '321'] + """ + self.__toklist.insert(index, insStr) + # fixup indices in token dictionary + for name,occurrences in self.__tokdict.items(): + for k, (value, position) in enumerate(occurrences): + occurrences[k] = _ParseResultsWithOffset(value, position + (position > index)) + + def append( self, item ): + """ + Add single element to end of ParseResults list of elements. + + Example:: + + print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321'] + + # use a parse action to compute the sum of the parsed integers, and add it to the end + def append_sum(tokens): + tokens.append(sum(map(int, tokens))) + print(OneOrMore(Word(nums)).addParseAction(append_sum).parseString("0 123 321")) # -> ['0', '123', '321', 444] + """ + self.__toklist.append(item) + + def extend( self, itemseq ): + """ + Add sequence of elements to end of ParseResults list of elements. + + Example:: + + patt = OneOrMore(Word(alphas)) + + # use a parse action to append the reverse of the matched strings, to make a palindrome + def make_palindrome(tokens): + tokens.extend(reversed([t[::-1] for t in tokens])) + return ''.join(tokens) + print(patt.addParseAction(make_palindrome).parseString("lskdj sdlkjf lksd")) # -> 'lskdjsdlkjflksddsklfjkldsjdksl' + """ + if isinstance(itemseq, ParseResults): + self.__iadd__(itemseq) + else: + self.__toklist.extend(itemseq) + + def clear( self ): + """ + Clear all elements and results names. + """ + del self.__toklist[:] + self.__tokdict.clear() + + def __getattr__( self, name ): + try: + return self[name] + except KeyError: + return "" + + if name in self.__tokdict: + if name not in self.__accumNames: + return self.__tokdict[name][-1][0] + else: + return ParseResults([ v[0] for v in self.__tokdict[name] ]) + else: + return "" + + def __add__( self, other ): + ret = self.copy() + ret += other + return ret + + def __iadd__( self, other ): + if other.__tokdict: + offset = len(self.__toklist) + addoffset = lambda a: offset if a<0 else a+offset + otheritems = other.__tokdict.items() + otherdictitems = [(k, _ParseResultsWithOffset(v[0],addoffset(v[1])) ) + for (k,vlist) in otheritems for v in vlist] + for k,v in otherdictitems: + self[k] = v + if isinstance(v[0],ParseResults): + v[0].__parent = wkref(self) + + self.__toklist += other.__toklist + self.__accumNames.update( other.__accumNames ) + return self + + def __radd__(self, other): + if isinstance(other,int) and other == 0: + # useful for merging many ParseResults using sum() builtin + return self.copy() + else: + # this may raise a TypeError - so be it + return other + self + + def __repr__( self ): + return "(%s, %s)" % ( repr( self.__toklist ), repr( self.__tokdict ) ) + + def __str__( self ): + return '[' + ', '.join(_ustr(i) if isinstance(i, ParseResults) else repr(i) for i in self.__toklist) + ']' + + def _asStringList( self, sep='' ): + out = [] + for item in self.__toklist: + if out and sep: + out.append(sep) + if isinstance( item, ParseResults ): + out += item._asStringList() + else: + out.append( _ustr(item) ) + return out + + def asList( self ): + """ + Returns the parse results as a nested list of matching tokens, all converted to strings. + + Example:: + + patt = OneOrMore(Word(alphas)) + result = patt.parseString("sldkj lsdkj sldkj") + # even though the result prints in string-like form, it is actually a pyparsing ParseResults + print(type(result), result) # -> <class 'pyparsing.ParseResults'> ['sldkj', 'lsdkj', 'sldkj'] + + # Use asList() to create an actual list + result_list = result.asList() + print(type(result_list), result_list) # -> <class 'list'> ['sldkj', 'lsdkj', 'sldkj'] + """ + return [res.asList() if isinstance(res,ParseResults) else res for res in self.__toklist] + + def asDict( self ): + """ + Returns the named parse results as a nested dictionary. + + Example:: + + integer = Word(nums) + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + result = date_str.parseString('12/31/1999') + print(type(result), repr(result)) # -> <class 'pyparsing.ParseResults'> (['12', '/', '31', '/', '1999'], {'day': [('1999', 4)], 'year': [('12', 0)], 'month': [('31', 2)]}) + + result_dict = result.asDict() + print(type(result_dict), repr(result_dict)) # -> <class 'dict'> {'day': '1999', 'year': '12', 'month': '31'} + + # even though a ParseResults supports dict-like access, sometime you just need to have a dict + import json + print(json.dumps(result)) # -> Exception: TypeError: ... is not JSON serializable + print(json.dumps(result.asDict())) # -> {"month": "31", "day": "1999", "year": "12"} + """ + if PY_3: + item_fn = self.items + else: + item_fn = self.iteritems + + def toItem(obj): + if isinstance(obj, ParseResults): + if obj.haskeys(): + return obj.asDict() + else: + return [toItem(v) for v in obj] + else: + return obj + + return dict((k,toItem(v)) for k,v in item_fn()) + + def copy( self ): + """ + Returns a new copy of a :class:`ParseResults` object. + """ + ret = ParseResults( self.__toklist ) + ret.__tokdict = dict(self.__tokdict.items()) + ret.__parent = self.__parent + ret.__accumNames.update( self.__accumNames ) + ret.__name = self.__name + return ret + + def asXML( self, doctag=None, namedItemsOnly=False, indent="", formatted=True ): + """ + (Deprecated) Returns the parse results as XML. Tags are created for tokens and lists that have defined results names. + """ + nl = "\n" + out = [] + namedItems = dict((v[1],k) for (k,vlist) in self.__tokdict.items() + for v in vlist) + nextLevelIndent = indent + " " + + # collapse out indents if formatting is not desired + if not formatted: + indent = "" + nextLevelIndent = "" + nl = "" + + selfTag = None + if doctag is not None: + selfTag = doctag + else: + if self.__name: + selfTag = self.__name + + if not selfTag: + if namedItemsOnly: + return "" + else: + selfTag = "ITEM" + + out += [ nl, indent, "<", selfTag, ">" ] + + for i,res in enumerate(self.__toklist): + if isinstance(res,ParseResults): + if i in namedItems: + out += [ res.asXML(namedItems[i], + namedItemsOnly and doctag is None, + nextLevelIndent, + formatted)] + else: + out += [ res.asXML(None, + namedItemsOnly and doctag is None, + nextLevelIndent, + formatted)] + else: + # individual token, see if there is a name for it + resTag = None + if i in namedItems: + resTag = namedItems[i] + if not resTag: + if namedItemsOnly: + continue + else: + resTag = "ITEM" + xmlBodyText = _xml_escape(_ustr(res)) + out += [ nl, nextLevelIndent, "<", resTag, ">", + xmlBodyText, + "</", resTag, ">" ] + + out += [ nl, indent, "</", selfTag, ">" ] + return "".join(out) + + def __lookup(self,sub): + for k,vlist in self.__tokdict.items(): + for v,loc in vlist: + if sub is v: + return k + return None + + def getName(self): + r""" + Returns the results name for this token expression. Useful when several + different expressions might match at a particular location. + + Example:: + + integer = Word(nums) + ssn_expr = Regex(r"\d\d\d-\d\d-\d\d\d\d") + house_number_expr = Suppress('#') + Word(nums, alphanums) + user_data = (Group(house_number_expr)("house_number") + | Group(ssn_expr)("ssn") + | Group(integer)("age")) + user_info = OneOrMore(user_data) + + result = user_info.parseString("22 111-22-3333 #221B") + for item in result: + print(item.getName(), ':', item[0]) + + prints:: + + age : 22 + ssn : 111-22-3333 + house_number : 221B + """ + if self.__name: + return self.__name + elif self.__parent: + par = self.__parent() + if par: + return par.__lookup(self) + else: + return None + elif (len(self) == 1 and + len(self.__tokdict) == 1 and + next(iter(self.__tokdict.values()))[0][1] in (0,-1)): + return next(iter(self.__tokdict.keys())) + else: + return None + + def dump(self, indent='', depth=0, full=True): + """ + Diagnostic method for listing out the contents of + a :class:`ParseResults`. Accepts an optional ``indent`` argument so + that this string can be embedded in a nested display of other data. + + Example:: + + integer = Word(nums) + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + result = date_str.parseString('12/31/1999') + print(result.dump()) + + prints:: + + ['12', '/', '31', '/', '1999'] + - day: 1999 + - month: 31 + - year: 12 + """ + out = [] + NL = '\n' + out.append( indent+_ustr(self.asList()) ) + if full: + if self.haskeys(): + items = sorted((str(k), v) for k,v in self.items()) + for k,v in items: + if out: + out.append(NL) + out.append( "%s%s- %s: " % (indent,(' '*depth), k) ) + if isinstance(v,ParseResults): + if v: + out.append( v.dump(indent,depth+1) ) + else: + out.append(_ustr(v)) + else: + out.append(repr(v)) + elif any(isinstance(vv,ParseResults) for vv in self): + v = self + for i,vv in enumerate(v): + if isinstance(vv,ParseResults): + out.append("\n%s%s[%d]:\n%s%s%s" % (indent,(' '*(depth)),i,indent,(' '*(depth+1)),vv.dump(indent,depth+1) )) + else: + out.append("\n%s%s[%d]:\n%s%s%s" % (indent,(' '*(depth)),i,indent,(' '*(depth+1)),_ustr(vv))) + + return "".join(out) + + def pprint(self, *args, **kwargs): + """ + Pretty-printer for parsed results as a list, using the + `pprint <https://docs.python.org/3/library/pprint.html>`_ module. + Accepts additional positional or keyword args as defined for + `pprint.pprint <https://docs.python.org/3/library/pprint.html#pprint.pprint>`_ . + + Example:: + + ident = Word(alphas, alphanums) + num = Word(nums) + func = Forward() + term = ident | num | Group('(' + func + ')') + func <<= ident + Group(Optional(delimitedList(term))) + result = func.parseString("fna a,b,(fnb c,d,200),100") + result.pprint(width=40) + + prints:: + + ['fna', + ['a', + 'b', + ['(', 'fnb', ['c', 'd', '200'], ')'], + '100']] + """ + pprint.pprint(self.asList(), *args, **kwargs) + + # add support for pickle protocol + def __getstate__(self): + return ( self.__toklist, + ( self.__tokdict.copy(), + self.__parent is not None and self.__parent() or None, + self.__accumNames, + self.__name ) ) + + def __setstate__(self,state): + self.__toklist = state[0] + (self.__tokdict, + par, + inAccumNames, + self.__name) = state[1] + self.__accumNames = {} + self.__accumNames.update(inAccumNames) + if par is not None: + self.__parent = wkref(par) + else: + self.__parent = None + + def __getnewargs__(self): + return self.__toklist, self.__name, self.__asList, self.__modal + + def __dir__(self): + return (dir(type(self)) + list(self.keys())) + +MutableMapping.register(ParseResults) + +def col (loc,strg): + """Returns current column within a string, counting newlines as line separators. + The first column is number 1. + + Note: the default parsing behavior is to expand tabs in the input string + before starting the parsing process. See + :class:`ParserElement.parseString` for more + information on parsing strings containing ``<TAB>`` s, and suggested + methods to maintain a consistent view of the parsed string, the parse + location, and line and column positions within the parsed string. + """ + s = strg + return 1 if 0<loc<len(s) and s[loc-1] == '\n' else loc - s.rfind("\n", 0, loc) + +def lineno(loc,strg): + """Returns current line number within a string, counting newlines as line separators. + The first line is number 1. + + Note - the default parsing behavior is to expand tabs in the input string + before starting the parsing process. See :class:`ParserElement.parseString` + for more information on parsing strings containing ``<TAB>`` s, and + suggested methods to maintain a consistent view of the parsed string, the + parse location, and line and column positions within the parsed string. + """ + return strg.count("\n",0,loc) + 1 + +def line( loc, strg ): + """Returns the line of text containing loc within a string, counting newlines as line separators. + """ + lastCR = strg.rfind("\n", 0, loc) + nextCR = strg.find("\n", loc) + if nextCR >= 0: + return strg[lastCR+1:nextCR] + else: + return strg[lastCR+1:] + +def _defaultStartDebugAction( instring, loc, expr ): + print (("Match " + _ustr(expr) + " at loc " + _ustr(loc) + "(%d,%d)" % ( lineno(loc,instring), col(loc,instring) ))) + +def _defaultSuccessDebugAction( instring, startloc, endloc, expr, toks ): + print ("Matched " + _ustr(expr) + " -> " + str(toks.asList())) + +def _defaultExceptionDebugAction( instring, loc, expr, exc ): + print ("Exception raised:" + _ustr(exc)) + +def nullDebugAction(*args): + """'Do-nothing' debug action, to suppress debugging output during parsing.""" + pass + +# Only works on Python 3.x - nonlocal is toxic to Python 2 installs +#~ 'decorator to trim function calls to match the arity of the target' +#~ def _trim_arity(func, maxargs=3): + #~ if func in singleArgBuiltins: + #~ return lambda s,l,t: func(t) + #~ limit = 0 + #~ foundArity = False + #~ def wrapper(*args): + #~ nonlocal limit,foundArity + #~ while 1: + #~ try: + #~ ret = func(*args[limit:]) + #~ foundArity = True + #~ return ret + #~ except TypeError: + #~ if limit == maxargs or foundArity: + #~ raise + #~ limit += 1 + #~ continue + #~ return wrapper + +# this version is Python 2.x-3.x cross-compatible +'decorator to trim function calls to match the arity of the target' +def _trim_arity(func, maxargs=2): + if func in singleArgBuiltins: + return lambda s,l,t: func(t) + limit = [0] + foundArity = [False] + + # traceback return data structure changed in Py3.5 - normalize back to plain tuples + if system_version[:2] >= (3,5): + def extract_stack(limit=0): + # special handling for Python 3.5.0 - extra deep call stack by 1 + offset = -3 if system_version == (3,5,0) else -2 + frame_summary = traceback.extract_stack(limit=-offset+limit-1)[offset] + return [frame_summary[:2]] + def extract_tb(tb, limit=0): + frames = traceback.extract_tb(tb, limit=limit) + frame_summary = frames[-1] + return [frame_summary[:2]] + else: + extract_stack = traceback.extract_stack + extract_tb = traceback.extract_tb + + # synthesize what would be returned by traceback.extract_stack at the call to + # user's parse action 'func', so that we don't incur call penalty at parse time + + LINE_DIFF = 6 + # IF ANY CODE CHANGES, EVEN JUST COMMENTS OR BLANK LINES, BETWEEN THE NEXT LINE AND + # THE CALL TO FUNC INSIDE WRAPPER, LINE_DIFF MUST BE MODIFIED!!!! + this_line = extract_stack(limit=2)[-1] + pa_call_line_synth = (this_line[0], this_line[1]+LINE_DIFF) + + def wrapper(*args): + while 1: + try: + ret = func(*args[limit[0]:]) + foundArity[0] = True + return ret + except TypeError: + # re-raise TypeErrors if they did not come from our arity testing + if foundArity[0]: + raise + else: + try: + tb = sys.exc_info()[-1] + if not extract_tb(tb, limit=2)[-1][:2] == pa_call_line_synth: + raise + finally: + del tb + + if limit[0] <= maxargs: + limit[0] += 1 + continue + raise + + # copy func name to wrapper for sensible debug output + func_name = "<parse action>" + try: + func_name = getattr(func, '__name__', + getattr(func, '__class__').__name__) + except Exception: + func_name = str(func) + wrapper.__name__ = func_name + + return wrapper + +class ParserElement(object): + """Abstract base level parser element class.""" + DEFAULT_WHITE_CHARS = " \n\t\r" + verbose_stacktrace = False + + @staticmethod + def setDefaultWhitespaceChars( chars ): + r""" + Overrides the default whitespace chars + + Example:: + + # default whitespace chars are space, <TAB> and newline + OneOrMore(Word(alphas)).parseString("abc def\nghi jkl") # -> ['abc', 'def', 'ghi', 'jkl'] + + # change to just treat newline as significant + ParserElement.setDefaultWhitespaceChars(" \t") + OneOrMore(Word(alphas)).parseString("abc def\nghi jkl") # -> ['abc', 'def'] + """ + ParserElement.DEFAULT_WHITE_CHARS = chars + + @staticmethod + def inlineLiteralsUsing(cls): + """ + Set class to be used for inclusion of string literals into a parser. + + Example:: + + # default literal class used is Literal + integer = Word(nums) + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + date_str.parseString("1999/12/31") # -> ['1999', '/', '12', '/', '31'] + + + # change to Suppress + ParserElement.inlineLiteralsUsing(Suppress) + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + date_str.parseString("1999/12/31") # -> ['1999', '12', '31'] + """ + ParserElement._literalStringClass = cls + + def __init__( self, savelist=False ): + self.parseAction = list() + self.failAction = None + #~ self.name = "<unknown>" # don't define self.name, let subclasses try/except upcall + self.strRepr = None + self.resultsName = None + self.saveAsList = savelist + self.skipWhitespace = True + self.whiteChars = set(ParserElement.DEFAULT_WHITE_CHARS) + self.copyDefaultWhiteChars = True + self.mayReturnEmpty = False # used when checking for left-recursion + self.keepTabs = False + self.ignoreExprs = list() + self.debug = False + self.streamlined = False + self.mayIndexError = True # used to optimize exception handling for subclasses that don't advance parse index + self.errmsg = "" + self.modalResults = True # used to mark results names as modal (report only last) or cumulative (list all) + self.debugActions = ( None, None, None ) #custom debug actions + self.re = None + self.callPreparse = True # used to avoid redundant calls to preParse + self.callDuringTry = False + + def copy( self ): + """ + Make a copy of this :class:`ParserElement`. Useful for defining + different parse actions for the same parsing pattern, using copies of + the original parse element. + + Example:: + + integer = Word(nums).setParseAction(lambda toks: int(toks[0])) + integerK = integer.copy().addParseAction(lambda toks: toks[0]*1024) + Suppress("K") + integerM = integer.copy().addParseAction(lambda toks: toks[0]*1024*1024) + Suppress("M") + + print(OneOrMore(integerK | integerM | integer).parseString("5K 100 640K 256M")) + + prints:: + + [5120, 100, 655360, 268435456] + + Equivalent form of ``expr.copy()`` is just ``expr()``:: + + integerM = integer().addParseAction(lambda toks: toks[0]*1024*1024) + Suppress("M") + """ + cpy = copy.copy( self ) + cpy.parseAction = self.parseAction[:] + cpy.ignoreExprs = self.ignoreExprs[:] + if self.copyDefaultWhiteChars: + cpy.whiteChars = ParserElement.DEFAULT_WHITE_CHARS + return cpy + + def setName( self, name ): + """ + Define name for this expression, makes debugging and exception messages clearer. + + Example:: + + Word(nums).parseString("ABC") # -> Exception: Expected W:(0123...) (at char 0), (line:1, col:1) + Word(nums).setName("integer").parseString("ABC") # -> Exception: Expected integer (at char 0), (line:1, col:1) + """ + self.name = name + self.errmsg = "Expected " + self.name + if hasattr(self,"exception"): + self.exception.msg = self.errmsg + return self + + def setResultsName( self, name, listAllMatches=False ): + """ + Define name for referencing matching tokens as a nested attribute + of the returned parse results. + NOTE: this returns a *copy* of the original :class:`ParserElement` object; + this is so that the client can define a basic element, such as an + integer, and reference it in multiple places with different names. + + You can also set results names using the abbreviated syntax, + ``expr("name")`` in place of ``expr.setResultsName("name")`` + - see :class:`__call__`. + + Example:: + + date_str = (integer.setResultsName("year") + '/' + + integer.setResultsName("month") + '/' + + integer.setResultsName("day")) + + # equivalent form: + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + """ + newself = self.copy() + if name.endswith("*"): + name = name[:-1] + listAllMatches=True + newself.resultsName = name + newself.modalResults = not listAllMatches + return newself + + def setBreak(self,breakFlag = True): + """Method to invoke the Python pdb debugger when this element is + about to be parsed. Set ``breakFlag`` to True to enable, False to + disable. + """ + if breakFlag: + _parseMethod = self._parse + def breaker(instring, loc, doActions=True, callPreParse=True): + import pdb + pdb.set_trace() + return _parseMethod( instring, loc, doActions, callPreParse ) + breaker._originalParseMethod = _parseMethod + self._parse = breaker + else: + if hasattr(self._parse,"_originalParseMethod"): + self._parse = self._parse._originalParseMethod + return self + + def setParseAction( self, *fns, **kwargs ): + """ + Define one or more actions to perform when successfully matching parse element definition. + Parse action fn is a callable method with 0-3 arguments, called as ``fn(s,loc,toks)`` , + ``fn(loc,toks)`` , ``fn(toks)`` , or just ``fn()`` , where: + + - s = the original string being parsed (see note below) + - loc = the location of the matching substring + - toks = a list of the matched tokens, packaged as a :class:`ParseResults` object + + If the functions in fns modify the tokens, they can return them as the return + value from fn, and the modified list of tokens will replace the original. + Otherwise, fn does not need to return any value. + + Optional keyword arguments: + - callDuringTry = (default= ``False`` ) indicate if parse action should be run during lookaheads and alternate testing + + Note: the default parsing behavior is to expand tabs in the input string + before starting the parsing process. See :class:`parseString for more + information on parsing strings containing ``<TAB>`` s, and suggested + methods to maintain a consistent view of the parsed string, the parse + location, and line and column positions within the parsed string. + + Example:: + + integer = Word(nums) + date_str = integer + '/' + integer + '/' + integer + + date_str.parseString("1999/12/31") # -> ['1999', '/', '12', '/', '31'] + + # use parse action to convert to ints at parse time + integer = Word(nums).setParseAction(lambda toks: int(toks[0])) + date_str = integer + '/' + integer + '/' + integer + + # note that integer fields are now ints, not strings + date_str.parseString("1999/12/31") # -> [1999, '/', 12, '/', 31] + """ + self.parseAction = list(map(_trim_arity, list(fns))) + self.callDuringTry = kwargs.get("callDuringTry", False) + return self + + def addParseAction( self, *fns, **kwargs ): + """ + Add one or more parse actions to expression's list of parse actions. See :class:`setParseAction`. + + See examples in :class:`copy`. + """ + self.parseAction += list(map(_trim_arity, list(fns))) + self.callDuringTry = self.callDuringTry or kwargs.get("callDuringTry", False) + return self + + def addCondition(self, *fns, **kwargs): + """Add a boolean predicate function to expression's list of parse actions. See + :class:`setParseAction` for function call signatures. Unlike ``setParseAction``, + functions passed to ``addCondition`` need to return boolean success/fail of the condition. + + Optional keyword arguments: + - message = define a custom message to be used in the raised exception + - fatal = if True, will raise ParseFatalException to stop parsing immediately; otherwise will raise ParseException + + Example:: + + integer = Word(nums).setParseAction(lambda toks: int(toks[0])) + year_int = integer.copy() + year_int.addCondition(lambda toks: toks[0] >= 2000, message="Only support years 2000 and later") + date_str = year_int + '/' + integer + '/' + integer + + result = date_str.parseString("1999/12/31") # -> Exception: Only support years 2000 and later (at char 0), (line:1, col:1) + """ + msg = kwargs.get("message", "failed user-defined condition") + exc_type = ParseFatalException if kwargs.get("fatal", False) else ParseException + for fn in fns: + fn = _trim_arity(fn) + def pa(s,l,t): + if not bool(fn(s,l,t)): + raise exc_type(s,l,msg) + self.parseAction.append(pa) + self.callDuringTry = self.callDuringTry or kwargs.get("callDuringTry", False) + return self + + def setFailAction( self, fn ): + """Define action to perform if parsing fails at this expression. + Fail acton fn is a callable function that takes the arguments + ``fn(s,loc,expr,err)`` where: + - s = string being parsed + - loc = location where expression match was attempted and failed + - expr = the parse expression that failed + - err = the exception thrown + The function returns no value. It may throw :class:`ParseFatalException` + if it is desired to stop parsing immediately.""" + self.failAction = fn + return self + + def _skipIgnorables( self, instring, loc ): + exprsFound = True + while exprsFound: + exprsFound = False + for e in self.ignoreExprs: + try: + while 1: + loc,dummy = e._parse( instring, loc ) + exprsFound = True + except ParseException: + pass + return loc + + def preParse( self, instring, loc ): + if self.ignoreExprs: + loc = self._skipIgnorables( instring, loc ) + + if self.skipWhitespace: + wt = self.whiteChars + instrlen = len(instring) + while loc < instrlen and instring[loc] in wt: + loc += 1 + + return loc + + def parseImpl( self, instring, loc, doActions=True ): + return loc, [] + + def postParse( self, instring, loc, tokenlist ): + return tokenlist + + #~ @profile + def _parseNoCache( self, instring, loc, doActions=True, callPreParse=True ): + debugging = ( self.debug ) #and doActions ) + + if debugging or self.failAction: + #~ print ("Match",self,"at loc",loc,"(%d,%d)" % ( lineno(loc,instring), col(loc,instring) )) + if (self.debugActions[0] ): + self.debugActions[0]( instring, loc, self ) + if callPreParse and self.callPreparse: + preloc = self.preParse( instring, loc ) + else: + preloc = loc + tokensStart = preloc + try: + try: + loc,tokens = self.parseImpl( instring, preloc, doActions ) + except IndexError: + raise ParseException( instring, len(instring), self.errmsg, self ) + except ParseBaseException as err: + #~ print ("Exception raised:", err) + if self.debugActions[2]: + self.debugActions[2]( instring, tokensStart, self, err ) + if self.failAction: + self.failAction( instring, tokensStart, self, err ) + raise + else: + if callPreParse and self.callPreparse: + preloc = self.preParse( instring, loc ) + else: + preloc = loc + tokensStart = preloc + if self.mayIndexError or preloc >= len(instring): + try: + loc,tokens = self.parseImpl( instring, preloc, doActions ) + except IndexError: + raise ParseException( instring, len(instring), self.errmsg, self ) + else: + loc,tokens = self.parseImpl( instring, preloc, doActions ) + + tokens = self.postParse( instring, loc, tokens ) + + retTokens = ParseResults( tokens, self.resultsName, asList=self.saveAsList, modal=self.modalResults ) + if self.parseAction and (doActions or self.callDuringTry): + if debugging: + try: + for fn in self.parseAction: + try: + tokens = fn( instring, tokensStart, retTokens ) + except IndexError as parse_action_exc: + exc = ParseException("exception raised in parse action") + exc.__cause__ = parse_action_exc + raise exc + + if tokens is not None and tokens is not retTokens: + retTokens = ParseResults( tokens, + self.resultsName, + asList=self.saveAsList and isinstance(tokens,(ParseResults,list)), + modal=self.modalResults ) + except ParseBaseException as err: + #~ print "Exception raised in user parse action:", err + if (self.debugActions[2] ): + self.debugActions[2]( instring, tokensStart, self, err ) + raise + else: + for fn in self.parseAction: + try: + tokens = fn( instring, tokensStart, retTokens ) + except IndexError as parse_action_exc: + exc = ParseException("exception raised in parse action") + exc.__cause__ = parse_action_exc + raise exc + + if tokens is not None and tokens is not retTokens: + retTokens = ParseResults( tokens, + self.resultsName, + asList=self.saveAsList and isinstance(tokens,(ParseResults,list)), + modal=self.modalResults ) + if debugging: + #~ print ("Matched",self,"->",retTokens.asList()) + if (self.debugActions[1] ): + self.debugActions[1]( instring, tokensStart, loc, self, retTokens ) + + return loc, retTokens + + def tryParse( self, instring, loc ): + try: + return self._parse( instring, loc, doActions=False )[0] + except ParseFatalException: + raise ParseException( instring, loc, self.errmsg, self) + + def canParseNext(self, instring, loc): + try: + self.tryParse(instring, loc) + except (ParseException, IndexError): + return False + else: + return True + + class _UnboundedCache(object): + def __init__(self): + cache = {} + self.not_in_cache = not_in_cache = object() + + def get(self, key): + return cache.get(key, not_in_cache) + + def set(self, key, value): + cache[key] = value + + def clear(self): + cache.clear() + + def cache_len(self): + return len(cache) + + self.get = types.MethodType(get, self) + self.set = types.MethodType(set, self) + self.clear = types.MethodType(clear, self) + self.__len__ = types.MethodType(cache_len, self) + + if _OrderedDict is not None: + class _FifoCache(object): + def __init__(self, size): + self.not_in_cache = not_in_cache = object() + + cache = _OrderedDict() + + def get(self, key): + return cache.get(key, not_in_cache) + + def set(self, key, value): + cache[key] = value + while len(cache) > size: + try: + cache.popitem(False) + except KeyError: + pass + + def clear(self): + cache.clear() + + def cache_len(self): + return len(cache) + + self.get = types.MethodType(get, self) + self.set = types.MethodType(set, self) + self.clear = types.MethodType(clear, self) + self.__len__ = types.MethodType(cache_len, self) + + else: + class _FifoCache(object): + def __init__(self, size): + self.not_in_cache = not_in_cache = object() + + cache = {} + key_fifo = collections.deque([], size) + + def get(self, key): + return cache.get(key, not_in_cache) + + def set(self, key, value): + cache[key] = value + while len(key_fifo) > size: + cache.pop(key_fifo.popleft(), None) + key_fifo.append(key) + + def clear(self): + cache.clear() + key_fifo.clear() + + def cache_len(self): + return len(cache) + + self.get = types.MethodType(get, self) + self.set = types.MethodType(set, self) + self.clear = types.MethodType(clear, self) + self.__len__ = types.MethodType(cache_len, self) + + # argument cache for optimizing repeated calls when backtracking through recursive expressions + packrat_cache = {} # this is set later by enabledPackrat(); this is here so that resetCache() doesn't fail + packrat_cache_lock = RLock() + packrat_cache_stats = [0, 0] + + # this method gets repeatedly called during backtracking with the same arguments - + # we can cache these arguments and save ourselves the trouble of re-parsing the contained expression + def _parseCache( self, instring, loc, doActions=True, callPreParse=True ): + HIT, MISS = 0, 1 + lookup = (self, instring, loc, callPreParse, doActions) + with ParserElement.packrat_cache_lock: + cache = ParserElement.packrat_cache + value = cache.get(lookup) + if value is cache.not_in_cache: + ParserElement.packrat_cache_stats[MISS] += 1 + try: + value = self._parseNoCache(instring, loc, doActions, callPreParse) + except ParseBaseException as pe: + # cache a copy of the exception, without the traceback + cache.set(lookup, pe.__class__(*pe.args)) + raise + else: + cache.set(lookup, (value[0], value[1].copy())) + return value + else: + ParserElement.packrat_cache_stats[HIT] += 1 + if isinstance(value, Exception): + raise value + return (value[0], value[1].copy()) + + _parse = _parseNoCache + + @staticmethod + def resetCache(): + ParserElement.packrat_cache.clear() + ParserElement.packrat_cache_stats[:] = [0] * len(ParserElement.packrat_cache_stats) + + _packratEnabled = False + @staticmethod + def enablePackrat(cache_size_limit=128): + """Enables "packrat" parsing, which adds memoizing to the parsing logic. + Repeated parse attempts at the same string location (which happens + often in many complex grammars) can immediately return a cached value, + instead of re-executing parsing/validating code. Memoizing is done of + both valid results and parsing exceptions. + + Parameters: + + - cache_size_limit - (default= ``128``) - if an integer value is provided + will limit the size of the packrat cache; if None is passed, then + the cache size will be unbounded; if 0 is passed, the cache will + be effectively disabled. + + This speedup may break existing programs that use parse actions that + have side-effects. For this reason, packrat parsing is disabled when + you first import pyparsing. To activate the packrat feature, your + program must call the class method :class:`ParserElement.enablePackrat`. + For best results, call ``enablePackrat()`` immediately after + importing pyparsing. + + Example:: + + from pip._vendor import pyparsing + pyparsing.ParserElement.enablePackrat() + """ + if not ParserElement._packratEnabled: + ParserElement._packratEnabled = True + if cache_size_limit is None: + ParserElement.packrat_cache = ParserElement._UnboundedCache() + else: + ParserElement.packrat_cache = ParserElement._FifoCache(cache_size_limit) + ParserElement._parse = ParserElement._parseCache + + def parseString( self, instring, parseAll=False ): + """ + Execute the parse expression with the given string. + This is the main interface to the client code, once the complete + expression has been built. + + If you want the grammar to require that the entire input string be + successfully parsed, then set ``parseAll`` to True (equivalent to ending + the grammar with ``StringEnd()``). + + Note: ``parseString`` implicitly calls ``expandtabs()`` on the input string, + in order to report proper column numbers in parse actions. + If the input string contains tabs and + the grammar uses parse actions that use the ``loc`` argument to index into the + string being parsed, you can ensure you have a consistent view of the input + string by: + + - calling ``parseWithTabs`` on your grammar before calling ``parseString`` + (see :class:`parseWithTabs`) + - define your parse action using the full ``(s,loc,toks)`` signature, and + reference the input string using the parse action's ``s`` argument + - explictly expand the tabs in your input string before calling + ``parseString`` + + Example:: + + Word('a').parseString('aaaaabaaa') # -> ['aaaaa'] + Word('a').parseString('aaaaabaaa', parseAll=True) # -> Exception: Expected end of text + """ + ParserElement.resetCache() + if not self.streamlined: + self.streamline() + #~ self.saveAsList = True + for e in self.ignoreExprs: + e.streamline() + if not self.keepTabs: + instring = instring.expandtabs() + try: + loc, tokens = self._parse( instring, 0 ) + if parseAll: + loc = self.preParse( instring, loc ) + se = Empty() + StringEnd() + se._parse( instring, loc ) + except ParseBaseException as exc: + if ParserElement.verbose_stacktrace: + raise + else: + # catch and re-raise exception from here, clears out pyparsing internal stack trace + raise exc + else: + return tokens + + def scanString( self, instring, maxMatches=_MAX_INT, overlap=False ): + """ + Scan the input string for expression matches. Each match will return the + matching tokens, start location, and end location. May be called with optional + ``maxMatches`` argument, to clip scanning after 'n' matches are found. If + ``overlap`` is specified, then overlapping matches will be reported. + + Note that the start and end locations are reported relative to the string + being parsed. See :class:`parseString` for more information on parsing + strings with embedded tabs. + + Example:: + + source = "sldjf123lsdjjkf345sldkjf879lkjsfd987" + print(source) + for tokens,start,end in Word(alphas).scanString(source): + print(' '*start + '^'*(end-start)) + print(' '*start + tokens[0]) + + prints:: + + sldjf123lsdjjkf345sldkjf879lkjsfd987 + ^^^^^ + sldjf + ^^^^^^^ + lsdjjkf + ^^^^^^ + sldkjf + ^^^^^^ + lkjsfd + """ + if not self.streamlined: + self.streamline() + for e in self.ignoreExprs: + e.streamline() + + if not self.keepTabs: + instring = _ustr(instring).expandtabs() + instrlen = len(instring) + loc = 0 + preparseFn = self.preParse + parseFn = self._parse + ParserElement.resetCache() + matches = 0 + try: + while loc <= instrlen and matches < maxMatches: + try: + preloc = preparseFn( instring, loc ) + nextLoc,tokens = parseFn( instring, preloc, callPreParse=False ) + except ParseException: + loc = preloc+1 + else: + if nextLoc > loc: + matches += 1 + yield tokens, preloc, nextLoc + if overlap: + nextloc = preparseFn( instring, loc ) + if nextloc > loc: + loc = nextLoc + else: + loc += 1 + else: + loc = nextLoc + else: + loc = preloc+1 + except ParseBaseException as exc: + if ParserElement.verbose_stacktrace: + raise + else: + # catch and re-raise exception from here, clears out pyparsing internal stack trace + raise exc + + def transformString( self, instring ): + """ + Extension to :class:`scanString`, to modify matching text with modified tokens that may + be returned from a parse action. To use ``transformString``, define a grammar and + attach a parse action to it that modifies the returned token list. + Invoking ``transformString()`` on a target string will then scan for matches, + and replace the matched text patterns according to the logic in the parse + action. ``transformString()`` returns the resulting transformed string. + + Example:: + + wd = Word(alphas) + wd.setParseAction(lambda toks: toks[0].title()) + + print(wd.transformString("now is the winter of our discontent made glorious summer by this sun of york.")) + + prints:: + + Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York. + """ + out = [] + lastE = 0 + # force preservation of <TAB>s, to minimize unwanted transformation of string, and to + # keep string locs straight between transformString and scanString + self.keepTabs = True + try: + for t,s,e in self.scanString( instring ): + out.append( instring[lastE:s] ) + if t: + if isinstance(t,ParseResults): + out += t.asList() + elif isinstance(t,list): + out += t + else: + out.append(t) + lastE = e + out.append(instring[lastE:]) + out = [o for o in out if o] + return "".join(map(_ustr,_flatten(out))) + except ParseBaseException as exc: + if ParserElement.verbose_stacktrace: + raise + else: + # catch and re-raise exception from here, clears out pyparsing internal stack trace + raise exc + + def searchString( self, instring, maxMatches=_MAX_INT ): + """ + Another extension to :class:`scanString`, simplifying the access to the tokens found + to match the given parse expression. May be called with optional + ``maxMatches`` argument, to clip searching after 'n' matches are found. + + Example:: + + # a capitalized word starts with an uppercase letter, followed by zero or more lowercase letters + cap_word = Word(alphas.upper(), alphas.lower()) + + print(cap_word.searchString("More than Iron, more than Lead, more than Gold I need Electricity")) + + # the sum() builtin can be used to merge results into a single ParseResults object + print(sum(cap_word.searchString("More than Iron, more than Lead, more than Gold I need Electricity"))) + + prints:: + + [['More'], ['Iron'], ['Lead'], ['Gold'], ['I'], ['Electricity']] + ['More', 'Iron', 'Lead', 'Gold', 'I', 'Electricity'] + """ + try: + return ParseResults([ t for t,s,e in self.scanString( instring, maxMatches ) ]) + except ParseBaseException as exc: + if ParserElement.verbose_stacktrace: + raise + else: + # catch and re-raise exception from here, clears out pyparsing internal stack trace + raise exc + + def split(self, instring, maxsplit=_MAX_INT, includeSeparators=False): + """ + Generator method to split a string using the given expression as a separator. + May be called with optional ``maxsplit`` argument, to limit the number of splits; + and the optional ``includeSeparators`` argument (default= ``False``), if the separating + matching text should be included in the split results. + + Example:: + + punc = oneOf(list(".,;:/-!?")) + print(list(punc.split("This, this?, this sentence, is badly punctuated!"))) + + prints:: + + ['This', ' this', '', ' this sentence', ' is badly punctuated', ''] + """ + splits = 0 + last = 0 + for t,s,e in self.scanString(instring, maxMatches=maxsplit): + yield instring[last:s] + if includeSeparators: + yield t[0] + last = e + yield instring[last:] + + def __add__(self, other ): + """ + Implementation of + operator - returns :class:`And`. Adding strings to a ParserElement + converts them to :class:`Literal`s by default. + + Example:: + + greet = Word(alphas) + "," + Word(alphas) + "!" + hello = "Hello, World!" + print (hello, "->", greet.parseString(hello)) + + prints:: + + Hello, World! -> ['Hello', ',', 'World', '!'] + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return And( [ self, other ] ) + + def __radd__(self, other ): + """ + Implementation of + operator when left operand is not a :class:`ParserElement` + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return other + self + + def __sub__(self, other): + """ + Implementation of - operator, returns :class:`And` with error stop + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return self + And._ErrorStop() + other + + def __rsub__(self, other ): + """ + Implementation of - operator when left operand is not a :class:`ParserElement` + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return other - self + + def __mul__(self,other): + """ + Implementation of * operator, allows use of ``expr * 3`` in place of + ``expr + expr + expr``. Expressions may also me multiplied by a 2-integer + tuple, similar to ``{min,max}`` multipliers in regular expressions. Tuples + may also include ``None`` as in: + - ``expr*(n,None)`` or ``expr*(n,)`` is equivalent + to ``expr*n + ZeroOrMore(expr)`` + (read as "at least n instances of ``expr``") + - ``expr*(None,n)`` is equivalent to ``expr*(0,n)`` + (read as "0 to n instances of ``expr``") + - ``expr*(None,None)`` is equivalent to ``ZeroOrMore(expr)`` + - ``expr*(1,None)`` is equivalent to ``OneOrMore(expr)`` + + Note that ``expr*(None,n)`` does not raise an exception if + more than n exprs exist in the input stream; that is, + ``expr*(None,n)`` does not enforce a maximum number of expr + occurrences. If this behavior is desired, then write + ``expr*(None,n) + ~expr`` + """ + if isinstance(other,int): + minElements, optElements = other,0 + elif isinstance(other,tuple): + other = (other + (None, None))[:2] + if other[0] is None: + other = (0, other[1]) + if isinstance(other[0],int) and other[1] is None: + if other[0] == 0: + return ZeroOrMore(self) + if other[0] == 1: + return OneOrMore(self) + else: + return self*other[0] + ZeroOrMore(self) + elif isinstance(other[0],int) and isinstance(other[1],int): + minElements, optElements = other + optElements -= minElements + else: + raise TypeError("cannot multiply 'ParserElement' and ('%s','%s') objects", type(other[0]),type(other[1])) + else: + raise TypeError("cannot multiply 'ParserElement' and '%s' objects", type(other)) + + if minElements < 0: + raise ValueError("cannot multiply ParserElement by negative value") + if optElements < 0: + raise ValueError("second tuple value must be greater or equal to first tuple value") + if minElements == optElements == 0: + raise ValueError("cannot multiply ParserElement by 0 or (0,0)") + + if (optElements): + def makeOptionalList(n): + if n>1: + return Optional(self + makeOptionalList(n-1)) + else: + return Optional(self) + if minElements: + if minElements == 1: + ret = self + makeOptionalList(optElements) + else: + ret = And([self]*minElements) + makeOptionalList(optElements) + else: + ret = makeOptionalList(optElements) + else: + if minElements == 1: + ret = self + else: + ret = And([self]*minElements) + return ret + + def __rmul__(self, other): + return self.__mul__(other) + + def __or__(self, other ): + """ + Implementation of | operator - returns :class:`MatchFirst` + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return MatchFirst( [ self, other ] ) + + def __ror__(self, other ): + """ + Implementation of | operator when left operand is not a :class:`ParserElement` + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return other | self + + def __xor__(self, other ): + """ + Implementation of ^ operator - returns :class:`Or` + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return Or( [ self, other ] ) + + def __rxor__(self, other ): + """ + Implementation of ^ operator when left operand is not a :class:`ParserElement` + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return other ^ self + + def __and__(self, other ): + """ + Implementation of & operator - returns :class:`Each` + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return Each( [ self, other ] ) + + def __rand__(self, other ): + """ + Implementation of & operator when left operand is not a :class:`ParserElement` + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return other & self + + def __invert__( self ): + """ + Implementation of ~ operator - returns :class:`NotAny` + """ + return NotAny( self ) + + def __call__(self, name=None): + """ + Shortcut for :class:`setResultsName`, with ``listAllMatches=False``. + + If ``name`` is given with a trailing ``'*'`` character, then ``listAllMatches`` will be + passed as ``True``. + + If ``name` is omitted, same as calling :class:`copy`. + + Example:: + + # these are equivalent + userdata = Word(alphas).setResultsName("name") + Word(nums+"-").setResultsName("socsecno") + userdata = Word(alphas)("name") + Word(nums+"-")("socsecno") + """ + if name is not None: + return self.setResultsName(name) + else: + return self.copy() + + def suppress( self ): + """ + Suppresses the output of this :class:`ParserElement`; useful to keep punctuation from + cluttering up returned output. + """ + return Suppress( self ) + + def leaveWhitespace( self ): + """ + Disables the skipping of whitespace before matching the characters in the + :class:`ParserElement`'s defined pattern. This is normally only used internally by + the pyparsing module, but may be needed in some whitespace-sensitive grammars. + """ + self.skipWhitespace = False + return self + + def setWhitespaceChars( self, chars ): + """ + Overrides the default whitespace chars + """ + self.skipWhitespace = True + self.whiteChars = chars + self.copyDefaultWhiteChars = False + return self + + def parseWithTabs( self ): + """ + Overrides default behavior to expand ``<TAB>``s to spaces before parsing the input string. + Must be called before ``parseString`` when the input grammar contains elements that + match ``<TAB>`` characters. + """ + self.keepTabs = True + return self + + def ignore( self, other ): + """ + Define expression to be ignored (e.g., comments) while doing pattern + matching; may be called repeatedly, to define multiple comment or other + ignorable patterns. + + Example:: + + patt = OneOrMore(Word(alphas)) + patt.parseString('ablaj /* comment */ lskjd') # -> ['ablaj'] + + patt.ignore(cStyleComment) + patt.parseString('ablaj /* comment */ lskjd') # -> ['ablaj', 'lskjd'] + """ + if isinstance(other, basestring): + other = Suppress(other) + + if isinstance( other, Suppress ): + if other not in self.ignoreExprs: + self.ignoreExprs.append(other) + else: + self.ignoreExprs.append( Suppress( other.copy() ) ) + return self + + def setDebugActions( self, startAction, successAction, exceptionAction ): + """ + Enable display of debugging messages while doing pattern matching. + """ + self.debugActions = (startAction or _defaultStartDebugAction, + successAction or _defaultSuccessDebugAction, + exceptionAction or _defaultExceptionDebugAction) + self.debug = True + return self + + def setDebug( self, flag=True ): + """ + Enable display of debugging messages while doing pattern matching. + Set ``flag`` to True to enable, False to disable. + + Example:: + + wd = Word(alphas).setName("alphaword") + integer = Word(nums).setName("numword") + term = wd | integer + + # turn on debugging for wd + wd.setDebug() + + OneOrMore(term).parseString("abc 123 xyz 890") + + prints:: + + Match alphaword at loc 0(1,1) + Matched alphaword -> ['abc'] + Match alphaword at loc 3(1,4) + Exception raised:Expected alphaword (at char 4), (line:1, col:5) + Match alphaword at loc 7(1,8) + Matched alphaword -> ['xyz'] + Match alphaword at loc 11(1,12) + Exception raised:Expected alphaword (at char 12), (line:1, col:13) + Match alphaword at loc 15(1,16) + Exception raised:Expected alphaword (at char 15), (line:1, col:16) + + The output shown is that produced by the default debug actions - custom debug actions can be + specified using :class:`setDebugActions`. Prior to attempting + to match the ``wd`` expression, the debugging message ``"Match <exprname> at loc <n>(<line>,<col>)"`` + is shown. Then if the parse succeeds, a ``"Matched"`` message is shown, or an ``"Exception raised"`` + message is shown. Also note the use of :class:`setName` to assign a human-readable name to the expression, + which makes debugging and exception messages easier to understand - for instance, the default + name created for the :class:`Word` expression without calling ``setName`` is ``"W:(ABCD...)"``. + """ + if flag: + self.setDebugActions( _defaultStartDebugAction, _defaultSuccessDebugAction, _defaultExceptionDebugAction ) + else: + self.debug = False + return self + + def __str__( self ): + return self.name + + def __repr__( self ): + return _ustr(self) + + def streamline( self ): + self.streamlined = True + self.strRepr = None + return self + + def checkRecursion( self, parseElementList ): + pass + + def validate( self, validateTrace=[] ): + """ + Check defined expressions for valid structure, check for infinite recursive definitions. + """ + self.checkRecursion( [] ) + + def parseFile( self, file_or_filename, parseAll=False ): + """ + Execute the parse expression on the given file or filename. + If a filename is specified (instead of a file object), + the entire file is opened, read, and closed before parsing. + """ + try: + file_contents = file_or_filename.read() + except AttributeError: + with open(file_or_filename, "r") as f: + file_contents = f.read() + try: + return self.parseString(file_contents, parseAll) + except ParseBaseException as exc: + if ParserElement.verbose_stacktrace: + raise + else: + # catch and re-raise exception from here, clears out pyparsing internal stack trace + raise exc + + def __eq__(self,other): + if isinstance(other, ParserElement): + return self is other or vars(self) == vars(other) + elif isinstance(other, basestring): + return self.matches(other) + else: + return super(ParserElement,self)==other + + def __ne__(self,other): + return not (self == other) + + def __hash__(self): + return hash(id(self)) + + def __req__(self,other): + return self == other + + def __rne__(self,other): + return not (self == other) + + def matches(self, testString, parseAll=True): + """ + Method for quick testing of a parser against a test string. Good for simple + inline microtests of sub expressions while building up larger parser. + + Parameters: + - testString - to test against this expression for a match + - parseAll - (default= ``True``) - flag to pass to :class:`parseString` when running tests + + Example:: + + expr = Word(nums) + assert expr.matches("100") + """ + try: + self.parseString(_ustr(testString), parseAll=parseAll) + return True + except ParseBaseException: + return False + + def runTests(self, tests, parseAll=True, comment='#', + fullDump=True, printResults=True, failureTests=False, postParse=None): + """ + Execute the parse expression on a series of test strings, showing each + test, the parsed results or where the parse failed. Quick and easy way to + run a parse expression against a list of sample strings. + + Parameters: + - tests - a list of separate test strings, or a multiline string of test strings + - parseAll - (default= ``True``) - flag to pass to :class:`parseString` when running tests + - comment - (default= ``'#'``) - expression for indicating embedded comments in the test + string; pass None to disable comment filtering + - fullDump - (default= ``True``) - dump results as list followed by results names in nested outline; + if False, only dump nested list + - printResults - (default= ``True``) prints test output to stdout + - failureTests - (default= ``False``) indicates if these tests are expected to fail parsing + - postParse - (default= ``None``) optional callback for successful parse results; called as + `fn(test_string, parse_results)` and returns a string to be added to the test output + + Returns: a (success, results) tuple, where success indicates that all tests succeeded + (or failed if ``failureTests`` is True), and the results contain a list of lines of each + test's output + + Example:: + + number_expr = pyparsing_common.number.copy() + + result = number_expr.runTests(''' + # unsigned integer + 100 + # negative integer + -100 + # float with scientific notation + 6.02e23 + # integer with scientific notation + 1e-12 + ''') + print("Success" if result[0] else "Failed!") + + result = number_expr.runTests(''' + # stray character + 100Z + # missing leading digit before '.' + -.100 + # too many '.' + 3.14.159 + ''', failureTests=True) + print("Success" if result[0] else "Failed!") + + prints:: + + # unsigned integer + 100 + [100] + + # negative integer + -100 + [-100] + + # float with scientific notation + 6.02e23 + [6.02e+23] + + # integer with scientific notation + 1e-12 + [1e-12] + + Success + + # stray character + 100Z + ^ + FAIL: Expected end of text (at char 3), (line:1, col:4) + + # missing leading digit before '.' + -.100 + ^ + FAIL: Expected {real number with scientific notation | real number | signed integer} (at char 0), (line:1, col:1) + + # too many '.' + 3.14.159 + ^ + FAIL: Expected end of text (at char 4), (line:1, col:5) + + Success + + Each test string must be on a single line. If you want to test a string that spans multiple + lines, create a test like this:: + + expr.runTest(r"this is a test\\n of strings that spans \\n 3 lines") + + (Note that this is a raw string literal, you must include the leading 'r'.) + """ + if isinstance(tests, basestring): + tests = list(map(str.strip, tests.rstrip().splitlines())) + if isinstance(comment, basestring): + comment = Literal(comment) + allResults = [] + comments = [] + success = True + for t in tests: + if comment is not None and comment.matches(t, False) or comments and not t: + comments.append(t) + continue + if not t: + continue + out = ['\n'.join(comments), t] + comments = [] + try: + # convert newline marks to actual newlines, and strip leading BOM if present + NL = Literal(r'\n').addParseAction(replaceWith('\n')).ignore(quotedString) + BOM = '\ufeff' + t = NL.transformString(t.lstrip(BOM)) + result = self.parseString(t, parseAll=parseAll) + out.append(result.dump(full=fullDump)) + success = success and not failureTests + if postParse is not None: + try: + pp_value = postParse(t, result) + if pp_value is not None: + out.append(str(pp_value)) + except Exception as e: + out.append("{0} failed: {1}: {2}".format(postParse.__name__, type(e).__name__, e)) + except ParseBaseException as pe: + fatal = "(FATAL)" if isinstance(pe, ParseFatalException) else "" + if '\n' in t: + out.append(line(pe.loc, t)) + out.append(' '*(col(pe.loc,t)-1) + '^' + fatal) + else: + out.append(' '*pe.loc + '^' + fatal) + out.append("FAIL: " + str(pe)) + success = success and failureTests + result = pe + except Exception as exc: + out.append("FAIL-EXCEPTION: " + str(exc)) + success = success and failureTests + result = exc + + if printResults: + if fullDump: + out.append('') + print('\n'.join(out)) + + allResults.append((t, result)) + + return success, allResults + + +class Token(ParserElement): + """Abstract :class:`ParserElement` subclass, for defining atomic + matching patterns. + """ + def __init__( self ): + super(Token,self).__init__( savelist=False ) + + +class Empty(Token): + """An empty token, will always match. + """ + def __init__( self ): + super(Empty,self).__init__() + self.name = "Empty" + self.mayReturnEmpty = True + self.mayIndexError = False + + +class NoMatch(Token): + """A token that will never match. + """ + def __init__( self ): + super(NoMatch,self).__init__() + self.name = "NoMatch" + self.mayReturnEmpty = True + self.mayIndexError = False + self.errmsg = "Unmatchable token" + + def parseImpl( self, instring, loc, doActions=True ): + raise ParseException(instring, loc, self.errmsg, self) + + +class Literal(Token): + """Token to exactly match a specified string. + + Example:: + + Literal('blah').parseString('blah') # -> ['blah'] + Literal('blah').parseString('blahfooblah') # -> ['blah'] + Literal('blah').parseString('bla') # -> Exception: Expected "blah" + + For case-insensitive matching, use :class:`CaselessLiteral`. + + For keyword matching (force word break before and after the matched string), + use :class:`Keyword` or :class:`CaselessKeyword`. + """ + def __init__( self, matchString ): + super(Literal,self).__init__() + self.match = matchString + self.matchLen = len(matchString) + try: + self.firstMatchChar = matchString[0] + except IndexError: + warnings.warn("null string passed to Literal; use Empty() instead", + SyntaxWarning, stacklevel=2) + self.__class__ = Empty + self.name = '"%s"' % _ustr(self.match) + self.errmsg = "Expected " + self.name + self.mayReturnEmpty = False + self.mayIndexError = False + + # Performance tuning: this routine gets called a *lot* + # if this is a single character match string and the first character matches, + # short-circuit as quickly as possible, and avoid calling startswith + #~ @profile + def parseImpl( self, instring, loc, doActions=True ): + if (instring[loc] == self.firstMatchChar and + (self.matchLen==1 or instring.startswith(self.match,loc)) ): + return loc+self.matchLen, self.match + raise ParseException(instring, loc, self.errmsg, self) +_L = Literal +ParserElement._literalStringClass = Literal + +class Keyword(Token): + """Token to exactly match a specified string as a keyword, that is, + it must be immediately followed by a non-keyword character. Compare + with :class:`Literal`: + + - ``Literal("if")`` will match the leading ``'if'`` in + ``'ifAndOnlyIf'``. + - ``Keyword("if")`` will not; it will only match the leading + ``'if'`` in ``'if x=1'``, or ``'if(y==2)'`` + + Accepts two optional constructor arguments in addition to the + keyword string: + + - ``identChars`` is a string of characters that would be valid + identifier characters, defaulting to all alphanumerics + "_" and + "$" + - ``caseless`` allows case-insensitive matching, default is ``False``. + + Example:: + + Keyword("start").parseString("start") # -> ['start'] + Keyword("start").parseString("starting") # -> Exception + + For case-insensitive matching, use :class:`CaselessKeyword`. + """ + DEFAULT_KEYWORD_CHARS = alphanums+"_$" + + def __init__( self, matchString, identChars=None, caseless=False ): + super(Keyword,self).__init__() + if identChars is None: + identChars = Keyword.DEFAULT_KEYWORD_CHARS + self.match = matchString + self.matchLen = len(matchString) + try: + self.firstMatchChar = matchString[0] + except IndexError: + warnings.warn("null string passed to Keyword; use Empty() instead", + SyntaxWarning, stacklevel=2) + self.name = '"%s"' % self.match + self.errmsg = "Expected " + self.name + self.mayReturnEmpty = False + self.mayIndexError = False + self.caseless = caseless + if caseless: + self.caselessmatch = matchString.upper() + identChars = identChars.upper() + self.identChars = set(identChars) + + def parseImpl( self, instring, loc, doActions=True ): + if self.caseless: + if ( (instring[ loc:loc+self.matchLen ].upper() == self.caselessmatch) and + (loc >= len(instring)-self.matchLen or instring[loc+self.matchLen].upper() not in self.identChars) and + (loc == 0 or instring[loc-1].upper() not in self.identChars) ): + return loc+self.matchLen, self.match + else: + if (instring[loc] == self.firstMatchChar and + (self.matchLen==1 or instring.startswith(self.match,loc)) and + (loc >= len(instring)-self.matchLen or instring[loc+self.matchLen] not in self.identChars) and + (loc == 0 or instring[loc-1] not in self.identChars) ): + return loc+self.matchLen, self.match + raise ParseException(instring, loc, self.errmsg, self) + + def copy(self): + c = super(Keyword,self).copy() + c.identChars = Keyword.DEFAULT_KEYWORD_CHARS + return c + + @staticmethod + def setDefaultKeywordChars( chars ): + """Overrides the default Keyword chars + """ + Keyword.DEFAULT_KEYWORD_CHARS = chars + +class CaselessLiteral(Literal): + """Token to match a specified string, ignoring case of letters. + Note: the matched results will always be in the case of the given + match string, NOT the case of the input text. + + Example:: + + OneOrMore(CaselessLiteral("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD', 'CMD'] + + (Contrast with example for :class:`CaselessKeyword`.) + """ + def __init__( self, matchString ): + super(CaselessLiteral,self).__init__( matchString.upper() ) + # Preserve the defining literal. + self.returnString = matchString + self.name = "'%s'" % self.returnString + self.errmsg = "Expected " + self.name + + def parseImpl( self, instring, loc, doActions=True ): + if instring[ loc:loc+self.matchLen ].upper() == self.match: + return loc+self.matchLen, self.returnString + raise ParseException(instring, loc, self.errmsg, self) + +class CaselessKeyword(Keyword): + """ + Caseless version of :class:`Keyword`. + + Example:: + + OneOrMore(CaselessKeyword("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD'] + + (Contrast with example for :class:`CaselessLiteral`.) + """ + def __init__( self, matchString, identChars=None ): + super(CaselessKeyword,self).__init__( matchString, identChars, caseless=True ) + +class CloseMatch(Token): + """A variation on :class:`Literal` which matches "close" matches, + that is, strings with at most 'n' mismatching characters. + :class:`CloseMatch` takes parameters: + + - ``match_string`` - string to be matched + - ``maxMismatches`` - (``default=1``) maximum number of + mismatches allowed to count as a match + + The results from a successful parse will contain the matched text + from the input string and the following named results: + + - ``mismatches`` - a list of the positions within the + match_string where mismatches were found + - ``original`` - the original match_string used to compare + against the input string + + If ``mismatches`` is an empty list, then the match was an exact + match. + + Example:: + + patt = CloseMatch("ATCATCGAATGGA") + patt.parseString("ATCATCGAAXGGA") # -> (['ATCATCGAAXGGA'], {'mismatches': [[9]], 'original': ['ATCATCGAATGGA']}) + patt.parseString("ATCAXCGAAXGGA") # -> Exception: Expected 'ATCATCGAATGGA' (with up to 1 mismatches) (at char 0), (line:1, col:1) + + # exact match + patt.parseString("ATCATCGAATGGA") # -> (['ATCATCGAATGGA'], {'mismatches': [[]], 'original': ['ATCATCGAATGGA']}) + + # close match allowing up to 2 mismatches + patt = CloseMatch("ATCATCGAATGGA", maxMismatches=2) + patt.parseString("ATCAXCGAAXGGA") # -> (['ATCAXCGAAXGGA'], {'mismatches': [[4, 9]], 'original': ['ATCATCGAATGGA']}) + """ + def __init__(self, match_string, maxMismatches=1): + super(CloseMatch,self).__init__() + self.name = match_string + self.match_string = match_string + self.maxMismatches = maxMismatches + self.errmsg = "Expected %r (with up to %d mismatches)" % (self.match_string, self.maxMismatches) + self.mayIndexError = False + self.mayReturnEmpty = False + + def parseImpl( self, instring, loc, doActions=True ): + start = loc + instrlen = len(instring) + maxloc = start + len(self.match_string) + + if maxloc <= instrlen: + match_string = self.match_string + match_stringloc = 0 + mismatches = [] + maxMismatches = self.maxMismatches + + for match_stringloc,s_m in enumerate(zip(instring[loc:maxloc], self.match_string)): + src,mat = s_m + if src != mat: + mismatches.append(match_stringloc) + if len(mismatches) > maxMismatches: + break + else: + loc = match_stringloc + 1 + results = ParseResults([instring[start:loc]]) + results['original'] = self.match_string + results['mismatches'] = mismatches + return loc, results + + raise ParseException(instring, loc, self.errmsg, self) + + +class Word(Token): + """Token for matching words composed of allowed character sets. + Defined with string containing all allowed initial characters, an + optional string containing allowed body characters (if omitted, + defaults to the initial character set), and an optional minimum, + maximum, and/or exact length. The default value for ``min`` is + 1 (a minimum value < 1 is not valid); the default values for + ``max`` and ``exact`` are 0, meaning no maximum or exact + length restriction. An optional ``excludeChars`` parameter can + list characters that might be found in the input ``bodyChars`` + string; useful to define a word of all printables except for one or + two characters, for instance. + + :class:`srange` is useful for defining custom character set strings + for defining ``Word`` expressions, using range notation from + regular expression character sets. + + A common mistake is to use :class:`Word` to match a specific literal + string, as in ``Word("Address")``. Remember that :class:`Word` + uses the string argument to define *sets* of matchable characters. + This expression would match "Add", "AAA", "dAred", or any other word + made up of the characters 'A', 'd', 'r', 'e', and 's'. To match an + exact literal string, use :class:`Literal` or :class:`Keyword`. + + pyparsing includes helper strings for building Words: + + - :class:`alphas` + - :class:`nums` + - :class:`alphanums` + - :class:`hexnums` + - :class:`alphas8bit` (alphabetic characters in ASCII range 128-255 + - accented, tilded, umlauted, etc.) + - :class:`punc8bit` (non-alphabetic characters in ASCII range + 128-255 - currency, symbols, superscripts, diacriticals, etc.) + - :class:`printables` (any non-whitespace character) + + Example:: + + # a word composed of digits + integer = Word(nums) # equivalent to Word("0123456789") or Word(srange("0-9")) + + # a word with a leading capital, and zero or more lowercase + capital_word = Word(alphas.upper(), alphas.lower()) + + # hostnames are alphanumeric, with leading alpha, and '-' + hostname = Word(alphas, alphanums+'-') + + # roman numeral (not a strict parser, accepts invalid mix of characters) + roman = Word("IVXLCDM") + + # any string of non-whitespace characters, except for ',' + csv_value = Word(printables, excludeChars=",") + """ + def __init__( self, initChars, bodyChars=None, min=1, max=0, exact=0, asKeyword=False, excludeChars=None ): + super(Word,self).__init__() + if excludeChars: + excludeChars = set(excludeChars) + initChars = ''.join(c for c in initChars if c not in excludeChars) + if bodyChars: + bodyChars = ''.join(c for c in bodyChars if c not in excludeChars) + self.initCharsOrig = initChars + self.initChars = set(initChars) + if bodyChars : + self.bodyCharsOrig = bodyChars + self.bodyChars = set(bodyChars) + else: + self.bodyCharsOrig = initChars + self.bodyChars = set(initChars) + + self.maxSpecified = max > 0 + + if min < 1: + raise ValueError("cannot specify a minimum length < 1; use Optional(Word()) if zero-length word is permitted") + + self.minLen = min + + if max > 0: + self.maxLen = max + else: + self.maxLen = _MAX_INT + + if exact > 0: + self.maxLen = exact + self.minLen = exact + + self.name = _ustr(self) + self.errmsg = "Expected " + self.name + self.mayIndexError = False + self.asKeyword = asKeyword + + if ' ' not in self.initCharsOrig+self.bodyCharsOrig and (min==1 and max==0 and exact==0): + if self.bodyCharsOrig == self.initCharsOrig: + self.reString = "[%s]+" % _escapeRegexRangeChars(self.initCharsOrig) + elif len(self.initCharsOrig) == 1: + self.reString = "%s[%s]*" % \ + (re.escape(self.initCharsOrig), + _escapeRegexRangeChars(self.bodyCharsOrig),) + else: + self.reString = "[%s][%s]*" % \ + (_escapeRegexRangeChars(self.initCharsOrig), + _escapeRegexRangeChars(self.bodyCharsOrig),) + if self.asKeyword: + self.reString = r"\b"+self.reString+r"\b" + try: + self.re = re.compile( self.reString ) + except Exception: + self.re = None + + def parseImpl( self, instring, loc, doActions=True ): + if self.re: + result = self.re.match(instring,loc) + if not result: + raise ParseException(instring, loc, self.errmsg, self) + + loc = result.end() + return loc, result.group() + + if instring[loc] not in self.initChars: + raise ParseException(instring, loc, self.errmsg, self) + + start = loc + loc += 1 + instrlen = len(instring) + bodychars = self.bodyChars + maxloc = start + self.maxLen + maxloc = min( maxloc, instrlen ) + while loc < maxloc and instring[loc] in bodychars: + loc += 1 + + throwException = False + if loc - start < self.minLen: + throwException = True + elif self.maxSpecified and loc < instrlen and instring[loc] in bodychars: + throwException = True + elif self.asKeyword: + if (start>0 and instring[start-1] in bodychars) or (loc<instrlen and instring[loc] in bodychars): + throwException = True + + if throwException: + raise ParseException(instring, loc, self.errmsg, self) + + return loc, instring[start:loc] + + def __str__( self ): + try: + return super(Word,self).__str__() + except Exception: + pass + + + if self.strRepr is None: + + def charsAsStr(s): + if len(s)>4: + return s[:4]+"..." + else: + return s + + if ( self.initCharsOrig != self.bodyCharsOrig ): + self.strRepr = "W:(%s,%s)" % ( charsAsStr(self.initCharsOrig), charsAsStr(self.bodyCharsOrig) ) + else: + self.strRepr = "W:(%s)" % charsAsStr(self.initCharsOrig) + + return self.strRepr + + +class Char(Word): + """A short-cut class for defining ``Word(characters, exact=1)``, + when defining a match of any single character in a string of + characters. + """ + def __init__(self, charset, asKeyword=False, excludeChars=None): + super(Char, self).__init__(charset, exact=1, asKeyword=asKeyword, excludeChars=excludeChars) + self.reString = "[%s]" % _escapeRegexRangeChars(self.initCharsOrig) + self.re = re.compile( self.reString ) + + +class Regex(Token): + r"""Token for matching strings that match a given regular + expression. Defined with string specifying the regular expression in + a form recognized by the stdlib Python `re module <https://docs.python.org/3/library/re.html>`_. + If the given regex contains named groups (defined using ``(?P<name>...)``), + these will be preserved as named parse results. + + Example:: + + realnum = Regex(r"[+-]?\d+\.\d*") + date = Regex(r'(?P<year>\d{4})-(?P<month>\d\d?)-(?P<day>\d\d?)') + # ref: https://stackoverflow.com/questions/267399/how-do-you-match-only-valid-roman-numerals-with-a-regular-expression + roman = Regex(r"M{0,4}(CM|CD|D?{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})") + """ + compiledREtype = type(re.compile("[A-Z]")) + def __init__( self, pattern, flags=0, asGroupList=False, asMatch=False): + """The parameters ``pattern`` and ``flags`` are passed + to the ``re.compile()`` function as-is. See the Python + `re module <https://docs.python.org/3/library/re.html>`_ module for an + explanation of the acceptable patterns and flags. + """ + super(Regex,self).__init__() + + if isinstance(pattern, basestring): + if not pattern: + warnings.warn("null string passed to Regex; use Empty() instead", + SyntaxWarning, stacklevel=2) + + self.pattern = pattern + self.flags = flags + + try: + self.re = re.compile(self.pattern, self.flags) + self.reString = self.pattern + except sre_constants.error: + warnings.warn("invalid pattern (%s) passed to Regex" % pattern, + SyntaxWarning, stacklevel=2) + raise + + elif isinstance(pattern, Regex.compiledREtype): + self.re = pattern + self.pattern = \ + self.reString = str(pattern) + self.flags = flags + + else: + raise ValueError("Regex may only be constructed with a string or a compiled RE object") + + self.name = _ustr(self) + self.errmsg = "Expected " + self.name + self.mayIndexError = False + self.mayReturnEmpty = True + self.asGroupList = asGroupList + self.asMatch = asMatch + if self.asGroupList: + self.parseImpl = self.parseImplAsGroupList + if self.asMatch: + self.parseImpl = self.parseImplAsMatch + + def parseImpl(self, instring, loc, doActions=True): + result = self.re.match(instring,loc) + if not result: + raise ParseException(instring, loc, self.errmsg, self) + + loc = result.end() + ret = ParseResults(result.group()) + d = result.groupdict() + if d: + for k, v in d.items(): + ret[k] = v + return loc, ret + + def parseImplAsGroupList(self, instring, loc, doActions=True): + result = self.re.match(instring,loc) + if not result: + raise ParseException(instring, loc, self.errmsg, self) + + loc = result.end() + ret = result.groups() + return loc, ret + + def parseImplAsMatch(self, instring, loc, doActions=True): + result = self.re.match(instring,loc) + if not result: + raise ParseException(instring, loc, self.errmsg, self) + + loc = result.end() + ret = result + return loc, ret + + def __str__( self ): + try: + return super(Regex,self).__str__() + except Exception: + pass + + if self.strRepr is None: + self.strRepr = "Re:(%s)" % repr(self.pattern) + + return self.strRepr + + def sub(self, repl): + r""" + Return Regex with an attached parse action to transform the parsed + result as if called using `re.sub(expr, repl, string) <https://docs.python.org/3/library/re.html#re.sub>`_. + + Example:: + + make_html = Regex(r"(\w+):(.*?):").sub(r"<\1>\2</\1>") + print(make_html.transformString("h1:main title:")) + # prints "<h1>main title</h1>" + """ + if self.asGroupList: + warnings.warn("cannot use sub() with Regex(asGroupList=True)", + SyntaxWarning, stacklevel=2) + raise SyntaxError() + + if self.asMatch and callable(repl): + warnings.warn("cannot use sub() with a callable with Regex(asMatch=True)", + SyntaxWarning, stacklevel=2) + raise SyntaxError() + + if self.asMatch: + def pa(tokens): + return tokens[0].expand(repl) + else: + def pa(tokens): + return self.re.sub(repl, tokens[0]) + return self.addParseAction(pa) + +class QuotedString(Token): + r""" + Token for matching strings that are delimited by quoting characters. + + Defined with the following parameters: + + - quoteChar - string of one or more characters defining the + quote delimiting string + - escChar - character to escape quotes, typically backslash + (default= ``None`` ) + - escQuote - special quote sequence to escape an embedded quote + string (such as SQL's ``""`` to escape an embedded ``"``) + (default= ``None`` ) + - multiline - boolean indicating whether quotes can span + multiple lines (default= ``False`` ) + - unquoteResults - boolean indicating whether the matched text + should be unquoted (default= ``True`` ) + - endQuoteChar - string of one or more characters defining the + end of the quote delimited string (default= ``None`` => same as + quoteChar) + - convertWhitespaceEscapes - convert escaped whitespace + (``'\t'``, ``'\n'``, etc.) to actual whitespace + (default= ``True`` ) + + Example:: + + qs = QuotedString('"') + print(qs.searchString('lsjdf "This is the quote" sldjf')) + complex_qs = QuotedString('{{', endQuoteChar='}}') + print(complex_qs.searchString('lsjdf {{This is the "quote"}} sldjf')) + sql_qs = QuotedString('"', escQuote='""') + print(sql_qs.searchString('lsjdf "This is the quote with ""embedded"" quotes" sldjf')) + + prints:: + + [['This is the quote']] + [['This is the "quote"']] + [['This is the quote with "embedded" quotes']] + """ + def __init__( self, quoteChar, escChar=None, escQuote=None, multiline=False, unquoteResults=True, endQuoteChar=None, convertWhitespaceEscapes=True): + super(QuotedString,self).__init__() + + # remove white space from quote chars - wont work anyway + quoteChar = quoteChar.strip() + if not quoteChar: + warnings.warn("quoteChar cannot be the empty string",SyntaxWarning,stacklevel=2) + raise SyntaxError() + + if endQuoteChar is None: + endQuoteChar = quoteChar + else: + endQuoteChar = endQuoteChar.strip() + if not endQuoteChar: + warnings.warn("endQuoteChar cannot be the empty string",SyntaxWarning,stacklevel=2) + raise SyntaxError() + + self.quoteChar = quoteChar + self.quoteCharLen = len(quoteChar) + self.firstQuoteChar = quoteChar[0] + self.endQuoteChar = endQuoteChar + self.endQuoteCharLen = len(endQuoteChar) + self.escChar = escChar + self.escQuote = escQuote + self.unquoteResults = unquoteResults + self.convertWhitespaceEscapes = convertWhitespaceEscapes + + if multiline: + self.flags = re.MULTILINE | re.DOTALL + self.pattern = r'%s(?:[^%s%s]' % \ + ( re.escape(self.quoteChar), + _escapeRegexRangeChars(self.endQuoteChar[0]), + (escChar is not None and _escapeRegexRangeChars(escChar) or '') ) + else: + self.flags = 0 + self.pattern = r'%s(?:[^%s\n\r%s]' % \ + ( re.escape(self.quoteChar), + _escapeRegexRangeChars(self.endQuoteChar[0]), + (escChar is not None and _escapeRegexRangeChars(escChar) or '') ) + if len(self.endQuoteChar) > 1: + self.pattern += ( + '|(?:' + ')|(?:'.join("%s[^%s]" % (re.escape(self.endQuoteChar[:i]), + _escapeRegexRangeChars(self.endQuoteChar[i])) + for i in range(len(self.endQuoteChar)-1,0,-1)) + ')' + ) + if escQuote: + self.pattern += (r'|(?:%s)' % re.escape(escQuote)) + if escChar: + self.pattern += (r'|(?:%s.)' % re.escape(escChar)) + self.escCharReplacePattern = re.escape(self.escChar)+"(.)" + self.pattern += (r')*%s' % re.escape(self.endQuoteChar)) + + try: + self.re = re.compile(self.pattern, self.flags) + self.reString = self.pattern + except sre_constants.error: + warnings.warn("invalid pattern (%s) passed to Regex" % self.pattern, + SyntaxWarning, stacklevel=2) + raise + + self.name = _ustr(self) + self.errmsg = "Expected " + self.name + self.mayIndexError = False + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + result = instring[loc] == self.firstQuoteChar and self.re.match(instring,loc) or None + if not result: + raise ParseException(instring, loc, self.errmsg, self) + + loc = result.end() + ret = result.group() + + if self.unquoteResults: + + # strip off quotes + ret = ret[self.quoteCharLen:-self.endQuoteCharLen] + + if isinstance(ret,basestring): + # replace escaped whitespace + if '\\' in ret and self.convertWhitespaceEscapes: + ws_map = { + r'\t' : '\t', + r'\n' : '\n', + r'\f' : '\f', + r'\r' : '\r', + } + for wslit,wschar in ws_map.items(): + ret = ret.replace(wslit, wschar) + + # replace escaped characters + if self.escChar: + ret = re.sub(self.escCharReplacePattern, r"\g<1>", ret) + + # replace escaped quotes + if self.escQuote: + ret = ret.replace(self.escQuote, self.endQuoteChar) + + return loc, ret + + def __str__( self ): + try: + return super(QuotedString,self).__str__() + except Exception: + pass + + if self.strRepr is None: + self.strRepr = "quoted string, starting with %s ending with %s" % (self.quoteChar, self.endQuoteChar) + + return self.strRepr + + +class CharsNotIn(Token): + """Token for matching words composed of characters *not* in a given + set (will include whitespace in matched characters if not listed in + the provided exclusion set - see example). Defined with string + containing all disallowed characters, and an optional minimum, + maximum, and/or exact length. The default value for ``min`` is + 1 (a minimum value < 1 is not valid); the default values for + ``max`` and ``exact`` are 0, meaning no maximum or exact + length restriction. + + Example:: + + # define a comma-separated-value as anything that is not a ',' + csv_value = CharsNotIn(',') + print(delimitedList(csv_value).parseString("dkls,lsdkjf,s12 34,@!#,213")) + + prints:: + + ['dkls', 'lsdkjf', 's12 34', '@!#', '213'] + """ + def __init__( self, notChars, min=1, max=0, exact=0 ): + super(CharsNotIn,self).__init__() + self.skipWhitespace = False + self.notChars = notChars + + if min < 1: + raise ValueError( + "cannot specify a minimum length < 1; use " + + "Optional(CharsNotIn()) if zero-length char group is permitted") + + self.minLen = min + + if max > 0: + self.maxLen = max + else: + self.maxLen = _MAX_INT + + if exact > 0: + self.maxLen = exact + self.minLen = exact + + self.name = _ustr(self) + self.errmsg = "Expected " + self.name + self.mayReturnEmpty = ( self.minLen == 0 ) + self.mayIndexError = False + + def parseImpl( self, instring, loc, doActions=True ): + if instring[loc] in self.notChars: + raise ParseException(instring, loc, self.errmsg, self) + + start = loc + loc += 1 + notchars = self.notChars + maxlen = min( start+self.maxLen, len(instring) ) + while loc < maxlen and \ + (instring[loc] not in notchars): + loc += 1 + + if loc - start < self.minLen: + raise ParseException(instring, loc, self.errmsg, self) + + return loc, instring[start:loc] + + def __str__( self ): + try: + return super(CharsNotIn, self).__str__() + except Exception: + pass + + if self.strRepr is None: + if len(self.notChars) > 4: + self.strRepr = "!W:(%s...)" % self.notChars[:4] + else: + self.strRepr = "!W:(%s)" % self.notChars + + return self.strRepr + +class White(Token): + """Special matching class for matching whitespace. Normally, + whitespace is ignored by pyparsing grammars. This class is included + when some whitespace structures are significant. Define with + a string containing the whitespace characters to be matched; default + is ``" \\t\\r\\n"``. Also takes optional ``min``, + ``max``, and ``exact`` arguments, as defined for the + :class:`Word` class. + """ + whiteStrs = { + ' ' : '<SP>', + '\t': '<TAB>', + '\n': '<LF>', + '\r': '<CR>', + '\f': '<FF>', + 'u\00A0': '<NBSP>', + 'u\1680': '<OGHAM_SPACE_MARK>', + 'u\180E': '<MONGOLIAN_VOWEL_SEPARATOR>', + 'u\2000': '<EN_QUAD>', + 'u\2001': '<EM_QUAD>', + 'u\2002': '<EN_SPACE>', + 'u\2003': '<EM_SPACE>', + 'u\2004': '<THREE-PER-EM_SPACE>', + 'u\2005': '<FOUR-PER-EM_SPACE>', + 'u\2006': '<SIX-PER-EM_SPACE>', + 'u\2007': '<FIGURE_SPACE>', + 'u\2008': '<PUNCTUATION_SPACE>', + 'u\2009': '<THIN_SPACE>', + 'u\200A': '<HAIR_SPACE>', + 'u\200B': '<ZERO_WIDTH_SPACE>', + 'u\202F': '<NNBSP>', + 'u\205F': '<MMSP>', + 'u\3000': '<IDEOGRAPHIC_SPACE>', + } + def __init__(self, ws=" \t\r\n", min=1, max=0, exact=0): + super(White,self).__init__() + self.matchWhite = ws + self.setWhitespaceChars( "".join(c for c in self.whiteChars if c not in self.matchWhite) ) + #~ self.leaveWhitespace() + self.name = ("".join(White.whiteStrs[c] for c in self.matchWhite)) + self.mayReturnEmpty = True + self.errmsg = "Expected " + self.name + + self.minLen = min + + if max > 0: + self.maxLen = max + else: + self.maxLen = _MAX_INT + + if exact > 0: + self.maxLen = exact + self.minLen = exact + + def parseImpl( self, instring, loc, doActions=True ): + if instring[loc] not in self.matchWhite: + raise ParseException(instring, loc, self.errmsg, self) + start = loc + loc += 1 + maxloc = start + self.maxLen + maxloc = min( maxloc, len(instring) ) + while loc < maxloc and instring[loc] in self.matchWhite: + loc += 1 + + if loc - start < self.minLen: + raise ParseException(instring, loc, self.errmsg, self) + + return loc, instring[start:loc] + + +class _PositionToken(Token): + def __init__( self ): + super(_PositionToken,self).__init__() + self.name=self.__class__.__name__ + self.mayReturnEmpty = True + self.mayIndexError = False + +class GoToColumn(_PositionToken): + """Token to advance to a specific column of input text; useful for + tabular report scraping. + """ + def __init__( self, colno ): + super(GoToColumn,self).__init__() + self.col = colno + + def preParse( self, instring, loc ): + if col(loc,instring) != self.col: + instrlen = len(instring) + if self.ignoreExprs: + loc = self._skipIgnorables( instring, loc ) + while loc < instrlen and instring[loc].isspace() and col( loc, instring ) != self.col : + loc += 1 + return loc + + def parseImpl( self, instring, loc, doActions=True ): + thiscol = col( loc, instring ) + if thiscol > self.col: + raise ParseException( instring, loc, "Text not in expected column", self ) + newloc = loc + self.col - thiscol + ret = instring[ loc: newloc ] + return newloc, ret + + +class LineStart(_PositionToken): + r"""Matches if current position is at the beginning of a line within + the parse string + + Example:: + + test = '''\ + AAA this line + AAA and this line + AAA but not this one + B AAA and definitely not this one + ''' + + for t in (LineStart() + 'AAA' + restOfLine).searchString(test): + print(t) + + prints:: + + ['AAA', ' this line'] + ['AAA', ' and this line'] + + """ + def __init__( self ): + super(LineStart,self).__init__() + self.errmsg = "Expected start of line" + + def parseImpl( self, instring, loc, doActions=True ): + if col(loc, instring) == 1: + return loc, [] + raise ParseException(instring, loc, self.errmsg, self) + +class LineEnd(_PositionToken): + """Matches if current position is at the end of a line within the + parse string + """ + def __init__( self ): + super(LineEnd,self).__init__() + self.setWhitespaceChars( ParserElement.DEFAULT_WHITE_CHARS.replace("\n","") ) + self.errmsg = "Expected end of line" + + def parseImpl( self, instring, loc, doActions=True ): + if loc<len(instring): + if instring[loc] == "\n": + return loc+1, "\n" + else: + raise ParseException(instring, loc, self.errmsg, self) + elif loc == len(instring): + return loc+1, [] + else: + raise ParseException(instring, loc, self.errmsg, self) + +class StringStart(_PositionToken): + """Matches if current position is at the beginning of the parse + string + """ + def __init__( self ): + super(StringStart,self).__init__() + self.errmsg = "Expected start of text" + + def parseImpl( self, instring, loc, doActions=True ): + if loc != 0: + # see if entire string up to here is just whitespace and ignoreables + if loc != self.preParse( instring, 0 ): + raise ParseException(instring, loc, self.errmsg, self) + return loc, [] + +class StringEnd(_PositionToken): + """Matches if current position is at the end of the parse string + """ + def __init__( self ): + super(StringEnd,self).__init__() + self.errmsg = "Expected end of text" + + def parseImpl( self, instring, loc, doActions=True ): + if loc < len(instring): + raise ParseException(instring, loc, self.errmsg, self) + elif loc == len(instring): + return loc+1, [] + elif loc > len(instring): + return loc, [] + else: + raise ParseException(instring, loc, self.errmsg, self) + +class WordStart(_PositionToken): + """Matches if the current position is at the beginning of a Word, + and is not preceded by any character in a given set of + ``wordChars`` (default= ``printables``). To emulate the + ``\b`` behavior of regular expressions, use + ``WordStart(alphanums)``. ``WordStart`` will also match at + the beginning of the string being parsed, or at the beginning of + a line. + """ + def __init__(self, wordChars = printables): + super(WordStart,self).__init__() + self.wordChars = set(wordChars) + self.errmsg = "Not at the start of a word" + + def parseImpl(self, instring, loc, doActions=True ): + if loc != 0: + if (instring[loc-1] in self.wordChars or + instring[loc] not in self.wordChars): + raise ParseException(instring, loc, self.errmsg, self) + return loc, [] + +class WordEnd(_PositionToken): + """Matches if the current position is at the end of a Word, and is + not followed by any character in a given set of ``wordChars`` + (default= ``printables``). To emulate the ``\b`` behavior of + regular expressions, use ``WordEnd(alphanums)``. ``WordEnd`` + will also match at the end of the string being parsed, or at the end + of a line. + """ + def __init__(self, wordChars = printables): + super(WordEnd,self).__init__() + self.wordChars = set(wordChars) + self.skipWhitespace = False + self.errmsg = "Not at the end of a word" + + def parseImpl(self, instring, loc, doActions=True ): + instrlen = len(instring) + if instrlen>0 and loc<instrlen: + if (instring[loc] in self.wordChars or + instring[loc-1] not in self.wordChars): + raise ParseException(instring, loc, self.errmsg, self) + return loc, [] + + +class ParseExpression(ParserElement): + """Abstract subclass of ParserElement, for combining and + post-processing parsed tokens. + """ + def __init__( self, exprs, savelist = False ): + super(ParseExpression,self).__init__(savelist) + if isinstance( exprs, _generatorType ): + exprs = list(exprs) + + if isinstance( exprs, basestring ): + self.exprs = [ ParserElement._literalStringClass( exprs ) ] + elif isinstance( exprs, Iterable ): + exprs = list(exprs) + # if sequence of strings provided, wrap with Literal + if all(isinstance(expr, basestring) for expr in exprs): + exprs = map(ParserElement._literalStringClass, exprs) + self.exprs = list(exprs) + else: + try: + self.exprs = list( exprs ) + except TypeError: + self.exprs = [ exprs ] + self.callPreparse = False + + def __getitem__( self, i ): + return self.exprs[i] + + def append( self, other ): + self.exprs.append( other ) + self.strRepr = None + return self + + def leaveWhitespace( self ): + """Extends ``leaveWhitespace`` defined in base class, and also invokes ``leaveWhitespace`` on + all contained expressions.""" + self.skipWhitespace = False + self.exprs = [ e.copy() for e in self.exprs ] + for e in self.exprs: + e.leaveWhitespace() + return self + + def ignore( self, other ): + if isinstance( other, Suppress ): + if other not in self.ignoreExprs: + super( ParseExpression, self).ignore( other ) + for e in self.exprs: + e.ignore( self.ignoreExprs[-1] ) + else: + super( ParseExpression, self).ignore( other ) + for e in self.exprs: + e.ignore( self.ignoreExprs[-1] ) + return self + + def __str__( self ): + try: + return super(ParseExpression,self).__str__() + except Exception: + pass + + if self.strRepr is None: + self.strRepr = "%s:(%s)" % ( self.__class__.__name__, _ustr(self.exprs) ) + return self.strRepr + + def streamline( self ): + super(ParseExpression,self).streamline() + + for e in self.exprs: + e.streamline() + + # collapse nested And's of the form And( And( And( a,b), c), d) to And( a,b,c,d ) + # but only if there are no parse actions or resultsNames on the nested And's + # (likewise for Or's and MatchFirst's) + if ( len(self.exprs) == 2 ): + other = self.exprs[0] + if ( isinstance( other, self.__class__ ) and + not(other.parseAction) and + other.resultsName is None and + not other.debug ): + self.exprs = other.exprs[:] + [ self.exprs[1] ] + self.strRepr = None + self.mayReturnEmpty |= other.mayReturnEmpty + self.mayIndexError |= other.mayIndexError + + other = self.exprs[-1] + if ( isinstance( other, self.__class__ ) and + not(other.parseAction) and + other.resultsName is None and + not other.debug ): + self.exprs = self.exprs[:-1] + other.exprs[:] + self.strRepr = None + self.mayReturnEmpty |= other.mayReturnEmpty + self.mayIndexError |= other.mayIndexError + + self.errmsg = "Expected " + _ustr(self) + + return self + + def validate( self, validateTrace=[] ): + tmp = validateTrace[:]+[self] + for e in self.exprs: + e.validate(tmp) + self.checkRecursion( [] ) + + def copy(self): + ret = super(ParseExpression,self).copy() + ret.exprs = [e.copy() for e in self.exprs] + return ret + +class And(ParseExpression): + """ + Requires all given :class:`ParseExpression` s to be found in the given order. + Expressions may be separated by whitespace. + May be constructed using the ``'+'`` operator. + May also be constructed using the ``'-'`` operator, which will + suppress backtracking. + + Example:: + + integer = Word(nums) + name_expr = OneOrMore(Word(alphas)) + + expr = And([integer("id"),name_expr("name"),integer("age")]) + # more easily written as: + expr = integer("id") + name_expr("name") + integer("age") + """ + + class _ErrorStop(Empty): + def __init__(self, *args, **kwargs): + super(And._ErrorStop,self).__init__(*args, **kwargs) + self.name = '-' + self.leaveWhitespace() + + def __init__( self, exprs, savelist = True ): + super(And,self).__init__(exprs, savelist) + self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) + self.setWhitespaceChars( self.exprs[0].whiteChars ) + self.skipWhitespace = self.exprs[0].skipWhitespace + self.callPreparse = True + + def streamline(self): + super(And, self).streamline() + self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) + return self + + def parseImpl( self, instring, loc, doActions=True ): + # pass False as last arg to _parse for first element, since we already + # pre-parsed the string as part of our And pre-parsing + loc, resultlist = self.exprs[0]._parse( instring, loc, doActions, callPreParse=False ) + errorStop = False + for e in self.exprs[1:]: + if isinstance(e, And._ErrorStop): + errorStop = True + continue + if errorStop: + try: + loc, exprtokens = e._parse( instring, loc, doActions ) + except ParseSyntaxException: + raise + except ParseBaseException as pe: + pe.__traceback__ = None + raise ParseSyntaxException._from_exception(pe) + except IndexError: + raise ParseSyntaxException(instring, len(instring), self.errmsg, self) + else: + loc, exprtokens = e._parse( instring, loc, doActions ) + if exprtokens or exprtokens.haskeys(): + resultlist += exprtokens + return loc, resultlist + + def __iadd__(self, other ): + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + return self.append( other ) #And( [ self, other ] ) + + def checkRecursion( self, parseElementList ): + subRecCheckList = parseElementList[:] + [ self ] + for e in self.exprs: + e.checkRecursion( subRecCheckList ) + if not e.mayReturnEmpty: + break + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "{" + " ".join(_ustr(e) for e in self.exprs) + "}" + + return self.strRepr + + +class Or(ParseExpression): + """Requires that at least one :class:`ParseExpression` is found. If + two expressions match, the expression that matches the longest + string will be used. May be constructed using the ``'^'`` + operator. + + Example:: + + # construct Or using '^' operator + + number = Word(nums) ^ Combine(Word(nums) + '.' + Word(nums)) + print(number.searchString("123 3.1416 789")) + + prints:: + + [['123'], ['3.1416'], ['789']] + """ + def __init__( self, exprs, savelist = False ): + super(Or,self).__init__(exprs, savelist) + if self.exprs: + self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs) + else: + self.mayReturnEmpty = True + + def streamline(self): + super(Or, self).streamline() + if __compat__.collect_all_And_tokens: + self.saveAsList = any(e.saveAsList for e in self.exprs) + return self + + def parseImpl( self, instring, loc, doActions=True ): + maxExcLoc = -1 + maxException = None + matches = [] + for e in self.exprs: + try: + loc2 = e.tryParse( instring, loc ) + except ParseException as err: + err.__traceback__ = None + if err.loc > maxExcLoc: + maxException = err + maxExcLoc = err.loc + except IndexError: + if len(instring) > maxExcLoc: + maxException = ParseException(instring,len(instring),e.errmsg,self) + maxExcLoc = len(instring) + else: + # save match among all matches, to retry longest to shortest + matches.append((loc2, e)) + + if matches: + matches.sort(key=lambda x: -x[0]) + for _,e in matches: + try: + return e._parse( instring, loc, doActions ) + except ParseException as err: + err.__traceback__ = None + if err.loc > maxExcLoc: + maxException = err + maxExcLoc = err.loc + + if maxException is not None: + maxException.msg = self.errmsg + raise maxException + else: + raise ParseException(instring, loc, "no defined alternatives to match", self) + + + def __ixor__(self, other ): + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + return self.append( other ) #Or( [ self, other ] ) + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "{" + " ^ ".join(_ustr(e) for e in self.exprs) + "}" + + return self.strRepr + + def checkRecursion( self, parseElementList ): + subRecCheckList = parseElementList[:] + [ self ] + for e in self.exprs: + e.checkRecursion( subRecCheckList ) + + +class MatchFirst(ParseExpression): + """Requires that at least one :class:`ParseExpression` is found. If + two expressions match, the first one listed is the one that will + match. May be constructed using the ``'|'`` operator. + + Example:: + + # construct MatchFirst using '|' operator + + # watch the order of expressions to match + number = Word(nums) | Combine(Word(nums) + '.' + Word(nums)) + print(number.searchString("123 3.1416 789")) # Fail! -> [['123'], ['3'], ['1416'], ['789']] + + # put more selective expression first + number = Combine(Word(nums) + '.' + Word(nums)) | Word(nums) + print(number.searchString("123 3.1416 789")) # Better -> [['123'], ['3.1416'], ['789']] + """ + def __init__( self, exprs, savelist = False ): + super(MatchFirst,self).__init__(exprs, savelist) + if self.exprs: + self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs) + else: + self.mayReturnEmpty = True + + def streamline(self): + super(MatchFirst, self).streamline() + if __compat__.collect_all_And_tokens: + self.saveAsList = any(e.saveAsList for e in self.exprs) + return self + + def parseImpl( self, instring, loc, doActions=True ): + maxExcLoc = -1 + maxException = None + for e in self.exprs: + try: + ret = e._parse( instring, loc, doActions ) + return ret + except ParseException as err: + if err.loc > maxExcLoc: + maxException = err + maxExcLoc = err.loc + except IndexError: + if len(instring) > maxExcLoc: + maxException = ParseException(instring,len(instring),e.errmsg,self) + maxExcLoc = len(instring) + + # only got here if no expression matched, raise exception for match that made it the furthest + else: + if maxException is not None: + maxException.msg = self.errmsg + raise maxException + else: + raise ParseException(instring, loc, "no defined alternatives to match", self) + + def __ior__(self, other ): + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + return self.append( other ) #MatchFirst( [ self, other ] ) + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "{" + " | ".join(_ustr(e) for e in self.exprs) + "}" + + return self.strRepr + + def checkRecursion( self, parseElementList ): + subRecCheckList = parseElementList[:] + [ self ] + for e in self.exprs: + e.checkRecursion( subRecCheckList ) + + +class Each(ParseExpression): + """Requires all given :class:`ParseExpression` s to be found, but in + any order. Expressions may be separated by whitespace. + + May be constructed using the ``'&'`` operator. + + Example:: + + color = oneOf("RED ORANGE YELLOW GREEN BLUE PURPLE BLACK WHITE BROWN") + shape_type = oneOf("SQUARE CIRCLE TRIANGLE STAR HEXAGON OCTAGON") + integer = Word(nums) + shape_attr = "shape:" + shape_type("shape") + posn_attr = "posn:" + Group(integer("x") + ',' + integer("y"))("posn") + color_attr = "color:" + color("color") + size_attr = "size:" + integer("size") + + # use Each (using operator '&') to accept attributes in any order + # (shape and posn are required, color and size are optional) + shape_spec = shape_attr & posn_attr & Optional(color_attr) & Optional(size_attr) + + shape_spec.runTests(''' + shape: SQUARE color: BLACK posn: 100, 120 + shape: CIRCLE size: 50 color: BLUE posn: 50,80 + color:GREEN size:20 shape:TRIANGLE posn:20,40 + ''' + ) + + prints:: + + shape: SQUARE color: BLACK posn: 100, 120 + ['shape:', 'SQUARE', 'color:', 'BLACK', 'posn:', ['100', ',', '120']] + - color: BLACK + - posn: ['100', ',', '120'] + - x: 100 + - y: 120 + - shape: SQUARE + + + shape: CIRCLE size: 50 color: BLUE posn: 50,80 + ['shape:', 'CIRCLE', 'size:', '50', 'color:', 'BLUE', 'posn:', ['50', ',', '80']] + - color: BLUE + - posn: ['50', ',', '80'] + - x: 50 + - y: 80 + - shape: CIRCLE + - size: 50 + + + color: GREEN size: 20 shape: TRIANGLE posn: 20,40 + ['color:', 'GREEN', 'size:', '20', 'shape:', 'TRIANGLE', 'posn:', ['20', ',', '40']] + - color: GREEN + - posn: ['20', ',', '40'] + - x: 20 + - y: 40 + - shape: TRIANGLE + - size: 20 + """ + def __init__( self, exprs, savelist = True ): + super(Each,self).__init__(exprs, savelist) + self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) + self.skipWhitespace = True + self.initExprGroups = True + self.saveAsList = True + + def streamline(self): + super(Each, self).streamline() + self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) + return self + + def parseImpl( self, instring, loc, doActions=True ): + if self.initExprGroups: + self.opt1map = dict((id(e.expr),e) for e in self.exprs if isinstance(e,Optional)) + opt1 = [ e.expr for e in self.exprs if isinstance(e,Optional) ] + opt2 = [ e for e in self.exprs if e.mayReturnEmpty and not isinstance(e,Optional)] + self.optionals = opt1 + opt2 + self.multioptionals = [ e.expr for e in self.exprs if isinstance(e,ZeroOrMore) ] + self.multirequired = [ e.expr for e in self.exprs if isinstance(e,OneOrMore) ] + self.required = [ e for e in self.exprs if not isinstance(e,(Optional,ZeroOrMore,OneOrMore)) ] + self.required += self.multirequired + self.initExprGroups = False + tmpLoc = loc + tmpReqd = self.required[:] + tmpOpt = self.optionals[:] + matchOrder = [] + + keepMatching = True + while keepMatching: + tmpExprs = tmpReqd + tmpOpt + self.multioptionals + self.multirequired + failed = [] + for e in tmpExprs: + try: + tmpLoc = e.tryParse( instring, tmpLoc ) + except ParseException: + failed.append(e) + else: + matchOrder.append(self.opt1map.get(id(e),e)) + if e in tmpReqd: + tmpReqd.remove(e) + elif e in tmpOpt: + tmpOpt.remove(e) + if len(failed) == len(tmpExprs): + keepMatching = False + + if tmpReqd: + missing = ", ".join(_ustr(e) for e in tmpReqd) + raise ParseException(instring,loc,"Missing one or more required elements (%s)" % missing ) + + # add any unmatched Optionals, in case they have default values defined + matchOrder += [e for e in self.exprs if isinstance(e,Optional) and e.expr in tmpOpt] + + resultlist = [] + for e in matchOrder: + loc,results = e._parse(instring,loc,doActions) + resultlist.append(results) + + finalResults = sum(resultlist, ParseResults([])) + return loc, finalResults + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "{" + " & ".join(_ustr(e) for e in self.exprs) + "}" + + return self.strRepr + + def checkRecursion( self, parseElementList ): + subRecCheckList = parseElementList[:] + [ self ] + for e in self.exprs: + e.checkRecursion( subRecCheckList ) + + +class ParseElementEnhance(ParserElement): + """Abstract subclass of :class:`ParserElement`, for combining and + post-processing parsed tokens. + """ + def __init__( self, expr, savelist=False ): + super(ParseElementEnhance,self).__init__(savelist) + if isinstance( expr, basestring ): + if issubclass(ParserElement._literalStringClass, Token): + expr = ParserElement._literalStringClass(expr) + else: + expr = ParserElement._literalStringClass(Literal(expr)) + self.expr = expr + self.strRepr = None + if expr is not None: + self.mayIndexError = expr.mayIndexError + self.mayReturnEmpty = expr.mayReturnEmpty + self.setWhitespaceChars( expr.whiteChars ) + self.skipWhitespace = expr.skipWhitespace + self.saveAsList = expr.saveAsList + self.callPreparse = expr.callPreparse + self.ignoreExprs.extend(expr.ignoreExprs) + + def parseImpl( self, instring, loc, doActions=True ): + if self.expr is not None: + return self.expr._parse( instring, loc, doActions, callPreParse=False ) + else: + raise ParseException("",loc,self.errmsg,self) + + def leaveWhitespace( self ): + self.skipWhitespace = False + self.expr = self.expr.copy() + if self.expr is not None: + self.expr.leaveWhitespace() + return self + + def ignore( self, other ): + if isinstance( other, Suppress ): + if other not in self.ignoreExprs: + super( ParseElementEnhance, self).ignore( other ) + if self.expr is not None: + self.expr.ignore( self.ignoreExprs[-1] ) + else: + super( ParseElementEnhance, self).ignore( other ) + if self.expr is not None: + self.expr.ignore( self.ignoreExprs[-1] ) + return self + + def streamline( self ): + super(ParseElementEnhance,self).streamline() + if self.expr is not None: + self.expr.streamline() + return self + + def checkRecursion( self, parseElementList ): + if self in parseElementList: + raise RecursiveGrammarException( parseElementList+[self] ) + subRecCheckList = parseElementList[:] + [ self ] + if self.expr is not None: + self.expr.checkRecursion( subRecCheckList ) + + def validate( self, validateTrace=[] ): + tmp = validateTrace[:]+[self] + if self.expr is not None: + self.expr.validate(tmp) + self.checkRecursion( [] ) + + def __str__( self ): + try: + return super(ParseElementEnhance,self).__str__() + except Exception: + pass + + if self.strRepr is None and self.expr is not None: + self.strRepr = "%s:(%s)" % ( self.__class__.__name__, _ustr(self.expr) ) + return self.strRepr + + +class FollowedBy(ParseElementEnhance): + """Lookahead matching of the given parse expression. + ``FollowedBy`` does *not* advance the parsing position within + the input string, it only verifies that the specified parse + expression matches at the current position. ``FollowedBy`` + always returns a null token list. If any results names are defined + in the lookahead expression, those *will* be returned for access by + name. + + Example:: + + # use FollowedBy to match a label only if it is followed by a ':' + data_word = Word(alphas) + label = data_word + FollowedBy(':') + attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) + + OneOrMore(attr_expr).parseString("shape: SQUARE color: BLACK posn: upper left").pprint() + + prints:: + + [['shape', 'SQUARE'], ['color', 'BLACK'], ['posn', 'upper left']] + """ + def __init__( self, expr ): + super(FollowedBy,self).__init__(expr) + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + _, ret = self.expr._parse(instring, loc, doActions=doActions) + del ret[:] + return loc, ret + + +class PrecededBy(ParseElementEnhance): + """Lookbehind matching of the given parse expression. + ``PrecededBy`` does not advance the parsing position within the + input string, it only verifies that the specified parse expression + matches prior to the current position. ``PrecededBy`` always + returns a null token list, but if a results name is defined on the + given expression, it is returned. + + Parameters: + + - expr - expression that must match prior to the current parse + location + - retreat - (default= ``None``) - (int) maximum number of characters + to lookbehind prior to the current parse location + + If the lookbehind expression is a string, Literal, Keyword, or + a Word or CharsNotIn with a specified exact or maximum length, then + the retreat parameter is not required. Otherwise, retreat must be + specified to give a maximum number of characters to look back from + the current parse position for a lookbehind match. + + Example:: + + # VB-style variable names with type prefixes + int_var = PrecededBy("#") + pyparsing_common.identifier + str_var = PrecededBy("$") + pyparsing_common.identifier + + """ + def __init__(self, expr, retreat=None): + super(PrecededBy, self).__init__(expr) + self.expr = self.expr().leaveWhitespace() + self.mayReturnEmpty = True + self.mayIndexError = False + self.exact = False + if isinstance(expr, str): + retreat = len(expr) + self.exact = True + elif isinstance(expr, (Literal, Keyword)): + retreat = expr.matchLen + self.exact = True + elif isinstance(expr, (Word, CharsNotIn)) and expr.maxLen != _MAX_INT: + retreat = expr.maxLen + self.exact = True + elif isinstance(expr, _PositionToken): + retreat = 0 + self.exact = True + self.retreat = retreat + self.errmsg = "not preceded by " + str(expr) + self.skipWhitespace = False + + def parseImpl(self, instring, loc=0, doActions=True): + if self.exact: + if loc < self.retreat: + raise ParseException(instring, loc, self.errmsg) + start = loc - self.retreat + _, ret = self.expr._parse(instring, start) + else: + # retreat specified a maximum lookbehind window, iterate + test_expr = self.expr + StringEnd() + instring_slice = instring[:loc] + last_expr = ParseException(instring, loc, self.errmsg) + for offset in range(1, min(loc, self.retreat+1)): + try: + _, ret = test_expr._parse(instring_slice, loc-offset) + except ParseBaseException as pbe: + last_expr = pbe + else: + break + else: + raise last_expr + # return empty list of tokens, but preserve any defined results names + del ret[:] + return loc, ret + + +class NotAny(ParseElementEnhance): + """Lookahead to disallow matching with the given parse expression. + ``NotAny`` does *not* advance the parsing position within the + input string, it only verifies that the specified parse expression + does *not* match at the current position. Also, ``NotAny`` does + *not* skip over leading whitespace. ``NotAny`` always returns + a null token list. May be constructed using the '~' operator. + + Example:: + + AND, OR, NOT = map(CaselessKeyword, "AND OR NOT".split()) + + # take care not to mistake keywords for identifiers + ident = ~(AND | OR | NOT) + Word(alphas) + boolean_term = Optional(NOT) + ident + + # very crude boolean expression - to support parenthesis groups and + # operation hierarchy, use infixNotation + boolean_expr = boolean_term + ZeroOrMore((AND | OR) + boolean_term) + + # integers that are followed by "." are actually floats + integer = Word(nums) + ~Char(".") + """ + def __init__( self, expr ): + super(NotAny,self).__init__(expr) + #~ self.leaveWhitespace() + self.skipWhitespace = False # do NOT use self.leaveWhitespace(), don't want to propagate to exprs + self.mayReturnEmpty = True + self.errmsg = "Found unwanted token, "+_ustr(self.expr) + + def parseImpl( self, instring, loc, doActions=True ): + if self.expr.canParseNext(instring, loc): + raise ParseException(instring, loc, self.errmsg, self) + return loc, [] + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "~{" + _ustr(self.expr) + "}" + + return self.strRepr + +class _MultipleMatch(ParseElementEnhance): + def __init__( self, expr, stopOn=None): + super(_MultipleMatch, self).__init__(expr) + self.saveAsList = True + ender = stopOn + if isinstance(ender, basestring): + ender = ParserElement._literalStringClass(ender) + self.not_ender = ~ender if ender is not None else None + + def parseImpl( self, instring, loc, doActions=True ): + self_expr_parse = self.expr._parse + self_skip_ignorables = self._skipIgnorables + check_ender = self.not_ender is not None + if check_ender: + try_not_ender = self.not_ender.tryParse + + # must be at least one (but first see if we are the stopOn sentinel; + # if so, fail) + if check_ender: + try_not_ender(instring, loc) + loc, tokens = self_expr_parse( instring, loc, doActions, callPreParse=False ) + try: + hasIgnoreExprs = (not not self.ignoreExprs) + while 1: + if check_ender: + try_not_ender(instring, loc) + if hasIgnoreExprs: + preloc = self_skip_ignorables( instring, loc ) + else: + preloc = loc + loc, tmptokens = self_expr_parse( instring, preloc, doActions ) + if tmptokens or tmptokens.haskeys(): + tokens += tmptokens + except (ParseException,IndexError): + pass + + return loc, tokens + +class OneOrMore(_MultipleMatch): + """Repetition of one or more of the given expression. + + Parameters: + - expr - expression that must match one or more times + - stopOn - (default= ``None``) - expression for a terminating sentinel + (only required if the sentinel would ordinarily match the repetition + expression) + + Example:: + + data_word = Word(alphas) + label = data_word + FollowedBy(':') + attr_expr = Group(label + Suppress(':') + OneOrMore(data_word).setParseAction(' '.join)) + + text = "shape: SQUARE posn: upper left color: BLACK" + OneOrMore(attr_expr).parseString(text).pprint() # Fail! read 'color' as data instead of next label -> [['shape', 'SQUARE color']] + + # use stopOn attribute for OneOrMore to avoid reading label string as part of the data + attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) + OneOrMore(attr_expr).parseString(text).pprint() # Better -> [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'BLACK']] + + # could also be written as + (attr_expr * (1,)).parseString(text).pprint() + """ + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "{" + _ustr(self.expr) + "}..." + + return self.strRepr + +class ZeroOrMore(_MultipleMatch): + """Optional repetition of zero or more of the given expression. + + Parameters: + - expr - expression that must match zero or more times + - stopOn - (default= ``None``) - expression for a terminating sentinel + (only required if the sentinel would ordinarily match the repetition + expression) + + Example: similar to :class:`OneOrMore` + """ + def __init__( self, expr, stopOn=None): + super(ZeroOrMore,self).__init__(expr, stopOn=stopOn) + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + try: + return super(ZeroOrMore, self).parseImpl(instring, loc, doActions) + except (ParseException,IndexError): + return loc, [] + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "[" + _ustr(self.expr) + "]..." + + return self.strRepr + +class _NullToken(object): + def __bool__(self): + return False + __nonzero__ = __bool__ + def __str__(self): + return "" + +_optionalNotMatched = _NullToken() +class Optional(ParseElementEnhance): + """Optional matching of the given expression. + + Parameters: + - expr - expression that must match zero or more times + - default (optional) - value to be returned if the optional expression is not found. + + Example:: + + # US postal code can be a 5-digit zip, plus optional 4-digit qualifier + zip = Combine(Word(nums, exact=5) + Optional('-' + Word(nums, exact=4))) + zip.runTests(''' + # traditional ZIP code + 12345 + + # ZIP+4 form + 12101-0001 + + # invalid ZIP + 98765- + ''') + + prints:: + + # traditional ZIP code + 12345 + ['12345'] + + # ZIP+4 form + 12101-0001 + ['12101-0001'] + + # invalid ZIP + 98765- + ^ + FAIL: Expected end of text (at char 5), (line:1, col:6) + """ + def __init__( self, expr, default=_optionalNotMatched ): + super(Optional,self).__init__( expr, savelist=False ) + self.saveAsList = self.expr.saveAsList + self.defaultValue = default + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + try: + loc, tokens = self.expr._parse( instring, loc, doActions, callPreParse=False ) + except (ParseException,IndexError): + if self.defaultValue is not _optionalNotMatched: + if self.expr.resultsName: + tokens = ParseResults([ self.defaultValue ]) + tokens[self.expr.resultsName] = self.defaultValue + else: + tokens = [ self.defaultValue ] + else: + tokens = [] + return loc, tokens + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "[" + _ustr(self.expr) + "]" + + return self.strRepr + +class SkipTo(ParseElementEnhance): + """Token for skipping over all undefined text until the matched + expression is found. + + Parameters: + - expr - target expression marking the end of the data to be skipped + - include - (default= ``False``) if True, the target expression is also parsed + (the skipped text and target expression are returned as a 2-element list). + - ignore - (default= ``None``) used to define grammars (typically quoted strings and + comments) that might contain false matches to the target expression + - failOn - (default= ``None``) define expressions that are not allowed to be + included in the skipped test; if found before the target expression is found, + the SkipTo is not a match + + Example:: + + report = ''' + Outstanding Issues Report - 1 Jan 2000 + + # | Severity | Description | Days Open + -----+----------+-------------------------------------------+----------- + 101 | Critical | Intermittent system crash | 6 + 94 | Cosmetic | Spelling error on Login ('log|n') | 14 + 79 | Minor | System slow when running too many reports | 47 + ''' + integer = Word(nums) + SEP = Suppress('|') + # use SkipTo to simply match everything up until the next SEP + # - ignore quoted strings, so that a '|' character inside a quoted string does not match + # - parse action will call token.strip() for each matched token, i.e., the description body + string_data = SkipTo(SEP, ignore=quotedString) + string_data.setParseAction(tokenMap(str.strip)) + ticket_expr = (integer("issue_num") + SEP + + string_data("sev") + SEP + + string_data("desc") + SEP + + integer("days_open")) + + for tkt in ticket_expr.searchString(report): + print tkt.dump() + + prints:: + + ['101', 'Critical', 'Intermittent system crash', '6'] + - days_open: 6 + - desc: Intermittent system crash + - issue_num: 101 + - sev: Critical + ['94', 'Cosmetic', "Spelling error on Login ('log|n')", '14'] + - days_open: 14 + - desc: Spelling error on Login ('log|n') + - issue_num: 94 + - sev: Cosmetic + ['79', 'Minor', 'System slow when running too many reports', '47'] + - days_open: 47 + - desc: System slow when running too many reports + - issue_num: 79 + - sev: Minor + """ + def __init__( self, other, include=False, ignore=None, failOn=None ): + super( SkipTo, self ).__init__( other ) + self.ignoreExpr = ignore + self.mayReturnEmpty = True + self.mayIndexError = False + self.includeMatch = include + self.saveAsList = False + if isinstance(failOn, basestring): + self.failOn = ParserElement._literalStringClass(failOn) + else: + self.failOn = failOn + self.errmsg = "No match found for "+_ustr(self.expr) + + def parseImpl( self, instring, loc, doActions=True ): + startloc = loc + instrlen = len(instring) + expr = self.expr + expr_parse = self.expr._parse + self_failOn_canParseNext = self.failOn.canParseNext if self.failOn is not None else None + self_ignoreExpr_tryParse = self.ignoreExpr.tryParse if self.ignoreExpr is not None else None + + tmploc = loc + while tmploc <= instrlen: + if self_failOn_canParseNext is not None: + # break if failOn expression matches + if self_failOn_canParseNext(instring, tmploc): + break + + if self_ignoreExpr_tryParse is not None: + # advance past ignore expressions + while 1: + try: + tmploc = self_ignoreExpr_tryParse(instring, tmploc) + except ParseBaseException: + break + + try: + expr_parse(instring, tmploc, doActions=False, callPreParse=False) + except (ParseException, IndexError): + # no match, advance loc in string + tmploc += 1 + else: + # matched skipto expr, done + break + + else: + # ran off the end of the input string without matching skipto expr, fail + raise ParseException(instring, loc, self.errmsg, self) + + # build up return values + loc = tmploc + skiptext = instring[startloc:loc] + skipresult = ParseResults(skiptext) + + if self.includeMatch: + loc, mat = expr_parse(instring,loc,doActions,callPreParse=False) + skipresult += mat + + return loc, skipresult + +class Forward(ParseElementEnhance): + """Forward declaration of an expression to be defined later - + used for recursive grammars, such as algebraic infix notation. + When the expression is known, it is assigned to the ``Forward`` + variable using the '<<' operator. + + Note: take care when assigning to ``Forward`` not to overlook + precedence of operators. + + Specifically, '|' has a lower precedence than '<<', so that:: + + fwdExpr << a | b | c + + will actually be evaluated as:: + + (fwdExpr << a) | b | c + + thereby leaving b and c out as parseable alternatives. It is recommended that you + explicitly group the values inserted into the ``Forward``:: + + fwdExpr << (a | b | c) + + Converting to use the '<<=' operator instead will avoid this problem. + + See :class:`ParseResults.pprint` for an example of a recursive + parser created using ``Forward``. + """ + def __init__( self, other=None ): + super(Forward,self).__init__( other, savelist=False ) + + def __lshift__( self, other ): + if isinstance( other, basestring ): + other = ParserElement._literalStringClass(other) + self.expr = other + self.strRepr = None + self.mayIndexError = self.expr.mayIndexError + self.mayReturnEmpty = self.expr.mayReturnEmpty + self.setWhitespaceChars( self.expr.whiteChars ) + self.skipWhitespace = self.expr.skipWhitespace + self.saveAsList = self.expr.saveAsList + self.ignoreExprs.extend(self.expr.ignoreExprs) + return self + + def __ilshift__(self, other): + return self << other + + def leaveWhitespace( self ): + self.skipWhitespace = False + return self + + def streamline( self ): + if not self.streamlined: + self.streamlined = True + if self.expr is not None: + self.expr.streamline() + return self + + def validate( self, validateTrace=[] ): + if self not in validateTrace: + tmp = validateTrace[:]+[self] + if self.expr is not None: + self.expr.validate(tmp) + self.checkRecursion([]) + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + # Avoid infinite recursion by setting a temporary name + self.name = self.__class__.__name__ + ": ..." + + # Use the string representation of main expression. + try: + if self.expr is not None: + retString = _ustr(self.expr) + else: + retString = "None" + finally: + del self.name + return self.__class__.__name__ + ": " + retString + + def copy(self): + if self.expr is not None: + return super(Forward,self).copy() + else: + ret = Forward() + ret <<= self + return ret + +class TokenConverter(ParseElementEnhance): + """ + Abstract subclass of :class:`ParseExpression`, for converting parsed results. + """ + def __init__( self, expr, savelist=False ): + super(TokenConverter,self).__init__( expr )#, savelist ) + self.saveAsList = False + +class Combine(TokenConverter): + """Converter to concatenate all matching tokens to a single string. + By default, the matching patterns must also be contiguous in the + input string; this can be disabled by specifying + ``'adjacent=False'`` in the constructor. + + Example:: + + real = Word(nums) + '.' + Word(nums) + print(real.parseString('3.1416')) # -> ['3', '.', '1416'] + # will also erroneously match the following + print(real.parseString('3. 1416')) # -> ['3', '.', '1416'] + + real = Combine(Word(nums) + '.' + Word(nums)) + print(real.parseString('3.1416')) # -> ['3.1416'] + # no match when there are internal spaces + print(real.parseString('3. 1416')) # -> Exception: Expected W:(0123...) + """ + def __init__( self, expr, joinString="", adjacent=True ): + super(Combine,self).__init__( expr ) + # suppress whitespace-stripping in contained parse expressions, but re-enable it on the Combine itself + if adjacent: + self.leaveWhitespace() + self.adjacent = adjacent + self.skipWhitespace = True + self.joinString = joinString + self.callPreparse = True + + def ignore( self, other ): + if self.adjacent: + ParserElement.ignore(self, other) + else: + super( Combine, self).ignore( other ) + return self + + def postParse( self, instring, loc, tokenlist ): + retToks = tokenlist.copy() + del retToks[:] + retToks += ParseResults([ "".join(tokenlist._asStringList(self.joinString)) ], modal=self.modalResults) + + if self.resultsName and retToks.haskeys(): + return [ retToks ] + else: + return retToks + +class Group(TokenConverter): + """Converter to return the matched tokens as a list - useful for + returning tokens of :class:`ZeroOrMore` and :class:`OneOrMore` expressions. + + Example:: + + ident = Word(alphas) + num = Word(nums) + term = ident | num + func = ident + Optional(delimitedList(term)) + print(func.parseString("fn a,b,100")) # -> ['fn', 'a', 'b', '100'] + + func = ident + Group(Optional(delimitedList(term))) + print(func.parseString("fn a,b,100")) # -> ['fn', ['a', 'b', '100']] + """ + def __init__( self, expr ): + super(Group,self).__init__( expr ) + self.saveAsList = True + + def postParse( self, instring, loc, tokenlist ): + return [ tokenlist ] + +class Dict(TokenConverter): + """Converter to return a repetitive expression as a list, but also + as a dictionary. Each element can also be referenced using the first + token in the expression as its key. Useful for tabular report + scraping when the first column can be used as a item key. + + Example:: + + data_word = Word(alphas) + label = data_word + FollowedBy(':') + attr_expr = Group(label + Suppress(':') + OneOrMore(data_word).setParseAction(' '.join)) + + text = "shape: SQUARE posn: upper left color: light blue texture: burlap" + attr_expr = (label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) + + # print attributes as plain groups + print(OneOrMore(attr_expr).parseString(text).dump()) + + # instead of OneOrMore(expr), parse using Dict(OneOrMore(Group(expr))) - Dict will auto-assign names + result = Dict(OneOrMore(Group(attr_expr))).parseString(text) + print(result.dump()) + + # access named fields as dict entries, or output as dict + print(result['shape']) + print(result.asDict()) + + prints:: + + ['shape', 'SQUARE', 'posn', 'upper left', 'color', 'light blue', 'texture', 'burlap'] + [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']] + - color: light blue + - posn: upper left + - shape: SQUARE + - texture: burlap + SQUARE + {'color': 'light blue', 'posn': 'upper left', 'texture': 'burlap', 'shape': 'SQUARE'} + + See more examples at :class:`ParseResults` of accessing fields by results name. + """ + def __init__( self, expr ): + super(Dict,self).__init__( expr ) + self.saveAsList = True + + def postParse( self, instring, loc, tokenlist ): + for i,tok in enumerate(tokenlist): + if len(tok) == 0: + continue + ikey = tok[0] + if isinstance(ikey,int): + ikey = _ustr(tok[0]).strip() + if len(tok)==1: + tokenlist[ikey] = _ParseResultsWithOffset("",i) + elif len(tok)==2 and not isinstance(tok[1],ParseResults): + tokenlist[ikey] = _ParseResultsWithOffset(tok[1],i) + else: + dictvalue = tok.copy() #ParseResults(i) + del dictvalue[0] + if len(dictvalue)!= 1 or (isinstance(dictvalue,ParseResults) and dictvalue.haskeys()): + tokenlist[ikey] = _ParseResultsWithOffset(dictvalue,i) + else: + tokenlist[ikey] = _ParseResultsWithOffset(dictvalue[0],i) + + if self.resultsName: + return [ tokenlist ] + else: + return tokenlist + + +class Suppress(TokenConverter): + """Converter for ignoring the results of a parsed expression. + + Example:: + + source = "a, b, c,d" + wd = Word(alphas) + wd_list1 = wd + ZeroOrMore(',' + wd) + print(wd_list1.parseString(source)) + + # often, delimiters that are useful during parsing are just in the + # way afterward - use Suppress to keep them out of the parsed output + wd_list2 = wd + ZeroOrMore(Suppress(',') + wd) + print(wd_list2.parseString(source)) + + prints:: + + ['a', ',', 'b', ',', 'c', ',', 'd'] + ['a', 'b', 'c', 'd'] + + (See also :class:`delimitedList`.) + """ + def postParse( self, instring, loc, tokenlist ): + return [] + + def suppress( self ): + return self + + +class OnlyOnce(object): + """Wrapper for parse actions, to ensure they are only called once. + """ + def __init__(self, methodCall): + self.callable = _trim_arity(methodCall) + self.called = False + def __call__(self,s,l,t): + if not self.called: + results = self.callable(s,l,t) + self.called = True + return results + raise ParseException(s,l,"") + def reset(self): + self.called = False + +def traceParseAction(f): + """Decorator for debugging parse actions. + + When the parse action is called, this decorator will print + ``">> entering method-name(line:<current_source_line>, <parse_location>, <matched_tokens>)"``. + When the parse action completes, the decorator will print + ``"<<"`` followed by the returned value, or any exception that the parse action raised. + + Example:: + + wd = Word(alphas) + + @traceParseAction + def remove_duplicate_chars(tokens): + return ''.join(sorted(set(''.join(tokens)))) + + wds = OneOrMore(wd).setParseAction(remove_duplicate_chars) + print(wds.parseString("slkdjs sld sldd sdlf sdljf")) + + prints:: + + >>entering remove_duplicate_chars(line: 'slkdjs sld sldd sdlf sdljf', 0, (['slkdjs', 'sld', 'sldd', 'sdlf', 'sdljf'], {})) + <<leaving remove_duplicate_chars (ret: 'dfjkls') + ['dfjkls'] + """ + f = _trim_arity(f) + def z(*paArgs): + thisFunc = f.__name__ + s,l,t = paArgs[-3:] + if len(paArgs)>3: + thisFunc = paArgs[0].__class__.__name__ + '.' + thisFunc + sys.stderr.write( ">>entering %s(line: '%s', %d, %r)\n" % (thisFunc,line(l,s),l,t) ) + try: + ret = f(*paArgs) + except Exception as exc: + sys.stderr.write( "<<leaving %s (exception: %s)\n" % (thisFunc,exc) ) + raise + sys.stderr.write( "<<leaving %s (ret: %r)\n" % (thisFunc,ret) ) + return ret + try: + z.__name__ = f.__name__ + except AttributeError: + pass + return z + +# +# global helpers +# +def delimitedList( expr, delim=",", combine=False ): + """Helper to define a delimited list of expressions - the delimiter + defaults to ','. By default, the list elements and delimiters can + have intervening whitespace, and comments, but this can be + overridden by passing ``combine=True`` in the constructor. If + ``combine`` is set to ``True``, the matching tokens are + returned as a single token string, with the delimiters included; + otherwise, the matching tokens are returned as a list of tokens, + with the delimiters suppressed. + + Example:: + + delimitedList(Word(alphas)).parseString("aa,bb,cc") # -> ['aa', 'bb', 'cc'] + delimitedList(Word(hexnums), delim=':', combine=True).parseString("AA:BB:CC:DD:EE") # -> ['AA:BB:CC:DD:EE'] + """ + dlName = _ustr(expr)+" ["+_ustr(delim)+" "+_ustr(expr)+"]..." + if combine: + return Combine( expr + ZeroOrMore( delim + expr ) ).setName(dlName) + else: + return ( expr + ZeroOrMore( Suppress( delim ) + expr ) ).setName(dlName) + +def countedArray( expr, intExpr=None ): + """Helper to define a counted list of expressions. + + This helper defines a pattern of the form:: + + integer expr expr expr... + + where the leading integer tells how many expr expressions follow. + The matched tokens returns the array of expr tokens as a list - the + leading count token is suppressed. + + If ``intExpr`` is specified, it should be a pyparsing expression + that produces an integer value. + + Example:: + + countedArray(Word(alphas)).parseString('2 ab cd ef') # -> ['ab', 'cd'] + + # in this parser, the leading integer value is given in binary, + # '10' indicating that 2 values are in the array + binaryConstant = Word('01').setParseAction(lambda t: int(t[0], 2)) + countedArray(Word(alphas), intExpr=binaryConstant).parseString('10 ab cd ef') # -> ['ab', 'cd'] + """ + arrayExpr = Forward() + def countFieldParseAction(s,l,t): + n = t[0] + arrayExpr << (n and Group(And([expr]*n)) or Group(empty)) + return [] + if intExpr is None: + intExpr = Word(nums).setParseAction(lambda t:int(t[0])) + else: + intExpr = intExpr.copy() + intExpr.setName("arrayLen") + intExpr.addParseAction(countFieldParseAction, callDuringTry=True) + return ( intExpr + arrayExpr ).setName('(len) ' + _ustr(expr) + '...') + +def _flatten(L): + ret = [] + for i in L: + if isinstance(i,list): + ret.extend(_flatten(i)) + else: + ret.append(i) + return ret + +def matchPreviousLiteral(expr): + """Helper to define an expression that is indirectly defined from + the tokens matched in a previous expression, that is, it looks for + a 'repeat' of a previous expression. For example:: + + first = Word(nums) + second = matchPreviousLiteral(first) + matchExpr = first + ":" + second + + will match ``"1:1"``, but not ``"1:2"``. Because this + matches a previous literal, will also match the leading + ``"1:1"`` in ``"1:10"``. If this is not desired, use + :class:`matchPreviousExpr`. Do *not* use with packrat parsing + enabled. + """ + rep = Forward() + def copyTokenToRepeater(s,l,t): + if t: + if len(t) == 1: + rep << t[0] + else: + # flatten t tokens + tflat = _flatten(t.asList()) + rep << And(Literal(tt) for tt in tflat) + else: + rep << Empty() + expr.addParseAction(copyTokenToRepeater, callDuringTry=True) + rep.setName('(prev) ' + _ustr(expr)) + return rep + +def matchPreviousExpr(expr): + """Helper to define an expression that is indirectly defined from + the tokens matched in a previous expression, that is, it looks for + a 'repeat' of a previous expression. For example:: + + first = Word(nums) + second = matchPreviousExpr(first) + matchExpr = first + ":" + second + + will match ``"1:1"``, but not ``"1:2"``. Because this + matches by expressions, will *not* match the leading ``"1:1"`` + in ``"1:10"``; the expressions are evaluated first, and then + compared, so ``"1"`` is compared with ``"10"``. Do *not* use + with packrat parsing enabled. + """ + rep = Forward() + e2 = expr.copy() + rep <<= e2 + def copyTokenToRepeater(s,l,t): + matchTokens = _flatten(t.asList()) + def mustMatchTheseTokens(s,l,t): + theseTokens = _flatten(t.asList()) + if theseTokens != matchTokens: + raise ParseException("",0,"") + rep.setParseAction( mustMatchTheseTokens, callDuringTry=True ) + expr.addParseAction(copyTokenToRepeater, callDuringTry=True) + rep.setName('(prev) ' + _ustr(expr)) + return rep + +def _escapeRegexRangeChars(s): + #~ escape these chars: ^-] + for c in r"\^-]": + s = s.replace(c,_bslash+c) + s = s.replace("\n",r"\n") + s = s.replace("\t",r"\t") + return _ustr(s) + +def oneOf( strs, caseless=False, useRegex=True ): + """Helper to quickly define a set of alternative Literals, and makes + sure to do longest-first testing when there is a conflict, + regardless of the input order, but returns + a :class:`MatchFirst` for best performance. + + Parameters: + + - strs - a string of space-delimited literals, or a collection of + string literals + - caseless - (default= ``False``) - treat all literals as + caseless + - useRegex - (default= ``True``) - as an optimization, will + generate a Regex object; otherwise, will generate + a :class:`MatchFirst` object (if ``caseless=True``, or if + creating a :class:`Regex` raises an exception) + + Example:: + + comp_oper = oneOf("< = > <= >= !=") + var = Word(alphas) + number = Word(nums) + term = var | number + comparison_expr = term + comp_oper + term + print(comparison_expr.searchString("B = 12 AA=23 B<=AA AA>12")) + + prints:: + + [['B', '=', '12'], ['AA', '=', '23'], ['B', '<=', 'AA'], ['AA', '>', '12']] + """ + if caseless: + isequal = ( lambda a,b: a.upper() == b.upper() ) + masks = ( lambda a,b: b.upper().startswith(a.upper()) ) + parseElementClass = CaselessLiteral + else: + isequal = ( lambda a,b: a == b ) + masks = ( lambda a,b: b.startswith(a) ) + parseElementClass = Literal + + symbols = [] + if isinstance(strs,basestring): + symbols = strs.split() + elif isinstance(strs, Iterable): + symbols = list(strs) + else: + warnings.warn("Invalid argument to oneOf, expected string or iterable", + SyntaxWarning, stacklevel=2) + if not symbols: + return NoMatch() + + i = 0 + while i < len(symbols)-1: + cur = symbols[i] + for j,other in enumerate(symbols[i+1:]): + if ( isequal(other, cur) ): + del symbols[i+j+1] + break + elif ( masks(cur, other) ): + del symbols[i+j+1] + symbols.insert(i,other) + cur = other + break + else: + i += 1 + + if not caseless and useRegex: + #~ print (strs,"->", "|".join( [ _escapeRegexChars(sym) for sym in symbols] )) + try: + if len(symbols)==len("".join(symbols)): + return Regex( "[%s]" % "".join(_escapeRegexRangeChars(sym) for sym in symbols) ).setName(' | '.join(symbols)) + else: + return Regex( "|".join(re.escape(sym) for sym in symbols) ).setName(' | '.join(symbols)) + except Exception: + warnings.warn("Exception creating Regex for oneOf, building MatchFirst", + SyntaxWarning, stacklevel=2) + + + # last resort, just use MatchFirst + return MatchFirst(parseElementClass(sym) for sym in symbols).setName(' | '.join(symbols)) + +def dictOf( key, value ): + """Helper to easily and clearly define a dictionary by specifying + the respective patterns for the key and value. Takes care of + defining the :class:`Dict`, :class:`ZeroOrMore`, and + :class:`Group` tokens in the proper order. The key pattern + can include delimiting markers or punctuation, as long as they are + suppressed, thereby leaving the significant key text. The value + pattern can include named results, so that the :class:`Dict` results + can include named token fields. + + Example:: + + text = "shape: SQUARE posn: upper left color: light blue texture: burlap" + attr_expr = (label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) + print(OneOrMore(attr_expr).parseString(text).dump()) + + attr_label = label + attr_value = Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join) + + # similar to Dict, but simpler call format + result = dictOf(attr_label, attr_value).parseString(text) + print(result.dump()) + print(result['shape']) + print(result.shape) # object attribute access works too + print(result.asDict()) + + prints:: + + [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']] + - color: light blue + - posn: upper left + - shape: SQUARE + - texture: burlap + SQUARE + SQUARE + {'color': 'light blue', 'shape': 'SQUARE', 'posn': 'upper left', 'texture': 'burlap'} + """ + return Dict(OneOrMore(Group(key + value))) + +def originalTextFor(expr, asString=True): + """Helper to return the original, untokenized text for a given + expression. Useful to restore the parsed fields of an HTML start + tag into the raw tag text itself, or to revert separate tokens with + intervening whitespace back to the original matching input text. By + default, returns astring containing the original parsed text. + + If the optional ``asString`` argument is passed as + ``False``, then the return value is + a :class:`ParseResults` containing any results names that + were originally matched, and a single token containing the original + matched text from the input string. So if the expression passed to + :class:`originalTextFor` contains expressions with defined + results names, you must set ``asString`` to ``False`` if you + want to preserve those results name values. + + Example:: + + src = "this is test <b> bold <i>text</i> </b> normal text " + for tag in ("b","i"): + opener,closer = makeHTMLTags(tag) + patt = originalTextFor(opener + SkipTo(closer) + closer) + print(patt.searchString(src)[0]) + + prints:: + + ['<b> bold <i>text</i> </b>'] + ['<i>text</i>'] + """ + locMarker = Empty().setParseAction(lambda s,loc,t: loc) + endlocMarker = locMarker.copy() + endlocMarker.callPreparse = False + matchExpr = locMarker("_original_start") + expr + endlocMarker("_original_end") + if asString: + extractText = lambda s,l,t: s[t._original_start:t._original_end] + else: + def extractText(s,l,t): + t[:] = [s[t.pop('_original_start'):t.pop('_original_end')]] + matchExpr.setParseAction(extractText) + matchExpr.ignoreExprs = expr.ignoreExprs + return matchExpr + +def ungroup(expr): + """Helper to undo pyparsing's default grouping of And expressions, + even if all but one are non-empty. + """ + return TokenConverter(expr).addParseAction(lambda t:t[0]) + +def locatedExpr(expr): + """Helper to decorate a returned token with its starting and ending + locations in the input string. + + This helper adds the following results names: + + - locn_start = location where matched expression begins + - locn_end = location where matched expression ends + - value = the actual parsed results + + Be careful if the input text contains ``<TAB>`` characters, you + may want to call :class:`ParserElement.parseWithTabs` + + Example:: + + wd = Word(alphas) + for match in locatedExpr(wd).searchString("ljsdf123lksdjjf123lkkjj1222"): + print(match) + + prints:: + + [[0, 'ljsdf', 5]] + [[8, 'lksdjjf', 15]] + [[18, 'lkkjj', 23]] + """ + locator = Empty().setParseAction(lambda s,l,t: l) + return Group(locator("locn_start") + expr("value") + locator.copy().leaveWhitespace()("locn_end")) + + +# convenience constants for positional expressions +empty = Empty().setName("empty") +lineStart = LineStart().setName("lineStart") +lineEnd = LineEnd().setName("lineEnd") +stringStart = StringStart().setName("stringStart") +stringEnd = StringEnd().setName("stringEnd") + +_escapedPunc = Word( _bslash, r"\[]-*.$+^?()~ ", exact=2 ).setParseAction(lambda s,l,t:t[0][1]) +_escapedHexChar = Regex(r"\\0?[xX][0-9a-fA-F]+").setParseAction(lambda s,l,t:unichr(int(t[0].lstrip(r'\0x'),16))) +_escapedOctChar = Regex(r"\\0[0-7]+").setParseAction(lambda s,l,t:unichr(int(t[0][1:],8))) +_singleChar = _escapedPunc | _escapedHexChar | _escapedOctChar | CharsNotIn(r'\]', exact=1) +_charRange = Group(_singleChar + Suppress("-") + _singleChar) +_reBracketExpr = Literal("[") + Optional("^").setResultsName("negate") + Group( OneOrMore( _charRange | _singleChar ) ).setResultsName("body") + "]" + +def srange(s): + r"""Helper to easily define string ranges for use in Word + construction. Borrows syntax from regexp '[]' string range + definitions:: + + srange("[0-9]") -> "0123456789" + srange("[a-z]") -> "abcdefghijklmnopqrstuvwxyz" + srange("[a-z$_]") -> "abcdefghijklmnopqrstuvwxyz$_" + + The input string must be enclosed in []'s, and the returned string + is the expanded character set joined into a single string. The + values enclosed in the []'s may be: + + - a single character + - an escaped character with a leading backslash (such as ``\-`` + or ``\]``) + - an escaped hex character with a leading ``'\x'`` + (``\x21``, which is a ``'!'`` character) (``\0x##`` + is also supported for backwards compatibility) + - an escaped octal character with a leading ``'\0'`` + (``\041``, which is a ``'!'`` character) + - a range of any of the above, separated by a dash (``'a-z'``, + etc.) + - any combination of the above (``'aeiouy'``, + ``'a-zA-Z0-9_$'``, etc.) + """ + _expanded = lambda p: p if not isinstance(p,ParseResults) else ''.join(unichr(c) for c in range(ord(p[0]),ord(p[1])+1)) + try: + return "".join(_expanded(part) for part in _reBracketExpr.parseString(s).body) + except Exception: + return "" + +def matchOnlyAtCol(n): + """Helper method for defining parse actions that require matching at + a specific column in the input text. + """ + def verifyCol(strg,locn,toks): + if col(locn,strg) != n: + raise ParseException(strg,locn,"matched token not at column %d" % n) + return verifyCol + +def replaceWith(replStr): + """Helper method for common parse actions that simply return + a literal value. Especially useful when used with + :class:`transformString<ParserElement.transformString>` (). + + Example:: + + num = Word(nums).setParseAction(lambda toks: int(toks[0])) + na = oneOf("N/A NA").setParseAction(replaceWith(math.nan)) + term = na | num + + OneOrMore(term).parseString("324 234 N/A 234") # -> [324, 234, nan, 234] + """ + return lambda s,l,t: [replStr] + +def removeQuotes(s,l,t): + """Helper parse action for removing quotation marks from parsed + quoted strings. + + Example:: + + # by default, quotation marks are included in parsed results + quotedString.parseString("'Now is the Winter of our Discontent'") # -> ["'Now is the Winter of our Discontent'"] + + # use removeQuotes to strip quotation marks from parsed results + quotedString.setParseAction(removeQuotes) + quotedString.parseString("'Now is the Winter of our Discontent'") # -> ["Now is the Winter of our Discontent"] + """ + return t[0][1:-1] + +def tokenMap(func, *args): + """Helper to define a parse action by mapping a function to all + elements of a ParseResults list. If any additional args are passed, + they are forwarded to the given function as additional arguments + after the token, as in + ``hex_integer = Word(hexnums).setParseAction(tokenMap(int, 16))``, + which will convert the parsed data to an integer using base 16. + + Example (compare the last to example in :class:`ParserElement.transformString`:: + + hex_ints = OneOrMore(Word(hexnums)).setParseAction(tokenMap(int, 16)) + hex_ints.runTests(''' + 00 11 22 aa FF 0a 0d 1a + ''') + + upperword = Word(alphas).setParseAction(tokenMap(str.upper)) + OneOrMore(upperword).runTests(''' + my kingdom for a horse + ''') + + wd = Word(alphas).setParseAction(tokenMap(str.title)) + OneOrMore(wd).setParseAction(' '.join).runTests(''' + now is the winter of our discontent made glorious summer by this sun of york + ''') + + prints:: + + 00 11 22 aa FF 0a 0d 1a + [0, 17, 34, 170, 255, 10, 13, 26] + + my kingdom for a horse + ['MY', 'KINGDOM', 'FOR', 'A', 'HORSE'] + + now is the winter of our discontent made glorious summer by this sun of york + ['Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York'] + """ + def pa(s,l,t): + return [func(tokn, *args) for tokn in t] + + try: + func_name = getattr(func, '__name__', + getattr(func, '__class__').__name__) + except Exception: + func_name = str(func) + pa.__name__ = func_name + + return pa + +upcaseTokens = tokenMap(lambda t: _ustr(t).upper()) +"""(Deprecated) Helper parse action to convert tokens to upper case. +Deprecated in favor of :class:`pyparsing_common.upcaseTokens`""" + +downcaseTokens = tokenMap(lambda t: _ustr(t).lower()) +"""(Deprecated) Helper parse action to convert tokens to lower case. +Deprecated in favor of :class:`pyparsing_common.downcaseTokens`""" + +def _makeTags(tagStr, xml, + suppress_LT=Suppress("<"), + suppress_GT=Suppress(">")): + """Internal helper to construct opening and closing tag expressions, given a tag name""" + if isinstance(tagStr,basestring): + resname = tagStr + tagStr = Keyword(tagStr, caseless=not xml) + else: + resname = tagStr.name + + tagAttrName = Word(alphas,alphanums+"_-:") + if (xml): + tagAttrValue = dblQuotedString.copy().setParseAction( removeQuotes ) + openTag = (suppress_LT + + tagStr("tag") + + Dict(ZeroOrMore(Group(tagAttrName + Suppress("=") + tagAttrValue ))) + + Optional("/", default=[False])("empty").setParseAction(lambda s,l,t:t[0]=='/') + + suppress_GT) + else: + tagAttrValue = quotedString.copy().setParseAction( removeQuotes ) | Word(printables, excludeChars=">") + openTag = (suppress_LT + + tagStr("tag") + + Dict(ZeroOrMore(Group(tagAttrName.setParseAction(downcaseTokens) + + Optional(Suppress("=") + tagAttrValue)))) + + Optional("/",default=[False])("empty").setParseAction(lambda s,l,t:t[0]=='/') + + suppress_GT) + closeTag = Combine(_L("</") + tagStr + ">", adjacent=False) + + openTag.setName("<%s>" % resname) + # add start<tagname> results name in parse action now that ungrouped names are not reported at two levels + openTag.addParseAction(lambda t: t.__setitem__("start"+"".join(resname.replace(":"," ").title().split()), t.copy())) + closeTag = closeTag("end"+"".join(resname.replace(":"," ").title().split())).setName("</%s>" % resname) + openTag.tag = resname + closeTag.tag = resname + openTag.tag_body = SkipTo(closeTag()) + return openTag, closeTag + +def makeHTMLTags(tagStr): + """Helper to construct opening and closing tag expressions for HTML, + given a tag name. Matches tags in either upper or lower case, + attributes with namespaces and with quoted or unquoted values. + + Example:: + + text = '<td>More info at the <a href="https://github.com/pyparsing/pyparsing/wiki">pyparsing</a> wiki page</td>' + # makeHTMLTags returns pyparsing expressions for the opening and + # closing tags as a 2-tuple + a,a_end = makeHTMLTags("A") + link_expr = a + SkipTo(a_end)("link_text") + a_end + + for link in link_expr.searchString(text): + # attributes in the <A> tag (like "href" shown here) are + # also accessible as named results + print(link.link_text, '->', link.href) + + prints:: + + pyparsing -> https://github.com/pyparsing/pyparsing/wiki + """ + return _makeTags( tagStr, False ) + +def makeXMLTags(tagStr): + """Helper to construct opening and closing tag expressions for XML, + given a tag name. Matches tags only in the given upper/lower case. + + Example: similar to :class:`makeHTMLTags` + """ + return _makeTags( tagStr, True ) + +def withAttribute(*args,**attrDict): + """Helper to create a validating parse action to be used with start + tags created with :class:`makeXMLTags` or + :class:`makeHTMLTags`. Use ``withAttribute`` to qualify + a starting tag with a required attribute value, to avoid false + matches on common tags such as ``<TD>`` or ``<DIV>``. + + Call ``withAttribute`` with a series of attribute names and + values. Specify the list of filter attributes names and values as: + + - keyword arguments, as in ``(align="right")``, or + - as an explicit dict with ``**`` operator, when an attribute + name is also a Python reserved word, as in ``**{"class":"Customer", "align":"right"}`` + - a list of name-value tuples, as in ``(("ns1:class", "Customer"), ("ns2:align","right"))`` + + For attribute names with a namespace prefix, you must use the second + form. Attribute names are matched insensitive to upper/lower case. + + If just testing for ``class`` (with or without a namespace), use + :class:`withClass`. + + To verify that the attribute exists, but without specifying a value, + pass ``withAttribute.ANY_VALUE`` as the value. + + Example:: + + html = ''' + <div> + Some text + <div type="grid">1 4 0 1 0</div> + <div type="graph">1,3 2,3 1,1</div> + <div>this has no type</div> + </div> + + ''' + div,div_end = makeHTMLTags("div") + + # only match div tag having a type attribute with value "grid" + div_grid = div().setParseAction(withAttribute(type="grid")) + grid_expr = div_grid + SkipTo(div | div_end)("body") + for grid_header in grid_expr.searchString(html): + print(grid_header.body) + + # construct a match with any div tag having a type attribute, regardless of the value + div_any_type = div().setParseAction(withAttribute(type=withAttribute.ANY_VALUE)) + div_expr = div_any_type + SkipTo(div | div_end)("body") + for div_header in div_expr.searchString(html): + print(div_header.body) + + prints:: + + 1 4 0 1 0 + + 1 4 0 1 0 + 1,3 2,3 1,1 + """ + if args: + attrs = args[:] + else: + attrs = attrDict.items() + attrs = [(k,v) for k,v in attrs] + def pa(s,l,tokens): + for attrName,attrValue in attrs: + if attrName not in tokens: + raise ParseException(s,l,"no matching attribute " + attrName) + if attrValue != withAttribute.ANY_VALUE and tokens[attrName] != attrValue: + raise ParseException(s,l,"attribute '%s' has value '%s', must be '%s'" % + (attrName, tokens[attrName], attrValue)) + return pa +withAttribute.ANY_VALUE = object() + +def withClass(classname, namespace=''): + """Simplified version of :class:`withAttribute` when + matching on a div class - made difficult because ``class`` is + a reserved word in Python. + + Example:: + + html = ''' + <div> + Some text + <div class="grid">1 4 0 1 0</div> + <div class="graph">1,3 2,3 1,1</div> + <div>this <div> has no class</div> + </div> + + ''' + div,div_end = makeHTMLTags("div") + div_grid = div().setParseAction(withClass("grid")) + + grid_expr = div_grid + SkipTo(div | div_end)("body") + for grid_header in grid_expr.searchString(html): + print(grid_header.body) + + div_any_type = div().setParseAction(withClass(withAttribute.ANY_VALUE)) + div_expr = div_any_type + SkipTo(div | div_end)("body") + for div_header in div_expr.searchString(html): + print(div_header.body) + + prints:: + + 1 4 0 1 0 + + 1 4 0 1 0 + 1,3 2,3 1,1 + """ + classattr = "%s:class" % namespace if namespace else "class" + return withAttribute(**{classattr : classname}) + +opAssoc = SimpleNamespace() +opAssoc.LEFT = object() +opAssoc.RIGHT = object() + +def infixNotation( baseExpr, opList, lpar=Suppress('('), rpar=Suppress(')') ): + """Helper method for constructing grammars of expressions made up of + operators working in a precedence hierarchy. Operators may be unary + or binary, left- or right-associative. Parse actions can also be + attached to operator expressions. The generated parser will also + recognize the use of parentheses to override operator precedences + (see example below). + + Note: if you define a deep operator list, you may see performance + issues when using infixNotation. See + :class:`ParserElement.enablePackrat` for a mechanism to potentially + improve your parser performance. + + Parameters: + - baseExpr - expression representing the most basic element for the + nested + - opList - list of tuples, one for each operator precedence level + in the expression grammar; each tuple is of the form ``(opExpr, + numTerms, rightLeftAssoc, parseAction)``, where: + + - opExpr is the pyparsing expression for the operator; may also + be a string, which will be converted to a Literal; if numTerms + is 3, opExpr is a tuple of two expressions, for the two + operators separating the 3 terms + - numTerms is the number of terms for this operator (must be 1, + 2, or 3) + - rightLeftAssoc is the indicator whether the operator is right + or left associative, using the pyparsing-defined constants + ``opAssoc.RIGHT`` and ``opAssoc.LEFT``. + - parseAction is the parse action to be associated with + expressions matching this operator expression (the parse action + tuple member may be omitted); if the parse action is passed + a tuple or list of functions, this is equivalent to calling + ``setParseAction(*fn)`` + (:class:`ParserElement.setParseAction`) + - lpar - expression for matching left-parentheses + (default= ``Suppress('(')``) + - rpar - expression for matching right-parentheses + (default= ``Suppress(')')``) + + Example:: + + # simple example of four-function arithmetic with ints and + # variable names + integer = pyparsing_common.signed_integer + varname = pyparsing_common.identifier + + arith_expr = infixNotation(integer | varname, + [ + ('-', 1, opAssoc.RIGHT), + (oneOf('* /'), 2, opAssoc.LEFT), + (oneOf('+ -'), 2, opAssoc.LEFT), + ]) + + arith_expr.runTests(''' + 5+3*6 + (5+3)*6 + -2--11 + ''', fullDump=False) + + prints:: + + 5+3*6 + [[5, '+', [3, '*', 6]]] + + (5+3)*6 + [[[5, '+', 3], '*', 6]] + + -2--11 + [[['-', 2], '-', ['-', 11]]] + """ + # captive version of FollowedBy that does not do parse actions or capture results names + class _FB(FollowedBy): + def parseImpl(self, instring, loc, doActions=True): + self.expr.tryParse(instring, loc) + return loc, [] + + ret = Forward() + lastExpr = baseExpr | ( lpar + ret + rpar ) + for i,operDef in enumerate(opList): + opExpr,arity,rightLeftAssoc,pa = (operDef + (None,))[:4] + termName = "%s term" % opExpr if arity < 3 else "%s%s term" % opExpr + if arity == 3: + if opExpr is None or len(opExpr) != 2: + raise ValueError( + "if numterms=3, opExpr must be a tuple or list of two expressions") + opExpr1, opExpr2 = opExpr + thisExpr = Forward().setName(termName) + if rightLeftAssoc == opAssoc.LEFT: + if arity == 1: + matchExpr = _FB(lastExpr + opExpr) + Group( lastExpr + OneOrMore( opExpr ) ) + elif arity == 2: + if opExpr is not None: + matchExpr = _FB(lastExpr + opExpr + lastExpr) + Group( lastExpr + OneOrMore( opExpr + lastExpr ) ) + else: + matchExpr = _FB(lastExpr+lastExpr) + Group( lastExpr + OneOrMore(lastExpr) ) + elif arity == 3: + matchExpr = _FB(lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr) + \ + Group( lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr ) + else: + raise ValueError("operator must be unary (1), binary (2), or ternary (3)") + elif rightLeftAssoc == opAssoc.RIGHT: + if arity == 1: + # try to avoid LR with this extra test + if not isinstance(opExpr, Optional): + opExpr = Optional(opExpr) + matchExpr = _FB(opExpr.expr + thisExpr) + Group( opExpr + thisExpr ) + elif arity == 2: + if opExpr is not None: + matchExpr = _FB(lastExpr + opExpr + thisExpr) + Group( lastExpr + OneOrMore( opExpr + thisExpr ) ) + else: + matchExpr = _FB(lastExpr + thisExpr) + Group( lastExpr + OneOrMore( thisExpr ) ) + elif arity == 3: + matchExpr = _FB(lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr) + \ + Group( lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr ) + else: + raise ValueError("operator must be unary (1), binary (2), or ternary (3)") + else: + raise ValueError("operator must indicate right or left associativity") + if pa: + if isinstance(pa, (tuple, list)): + matchExpr.setParseAction(*pa) + else: + matchExpr.setParseAction(pa) + thisExpr <<= ( matchExpr.setName(termName) | lastExpr ) + lastExpr = thisExpr + ret <<= lastExpr + return ret + +operatorPrecedence = infixNotation +"""(Deprecated) Former name of :class:`infixNotation`, will be +dropped in a future release.""" + +dblQuotedString = Combine(Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*')+'"').setName("string enclosed in double quotes") +sglQuotedString = Combine(Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*")+"'").setName("string enclosed in single quotes") +quotedString = Combine(Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*')+'"'| + Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*")+"'").setName("quotedString using single or double quotes") +unicodeString = Combine(_L('u') + quotedString.copy()).setName("unicode string literal") + +def nestedExpr(opener="(", closer=")", content=None, ignoreExpr=quotedString.copy()): + """Helper method for defining nested lists enclosed in opening and + closing delimiters ("(" and ")" are the default). + + Parameters: + - opener - opening character for a nested list + (default= ``"("``); can also be a pyparsing expression + - closer - closing character for a nested list + (default= ``")"``); can also be a pyparsing expression + - content - expression for items within the nested lists + (default= ``None``) + - ignoreExpr - expression for ignoring opening and closing + delimiters (default= :class:`quotedString`) + + If an expression is not provided for the content argument, the + nested expression will capture all whitespace-delimited content + between delimiters as a list of separate values. + + Use the ``ignoreExpr`` argument to define expressions that may + contain opening or closing characters that should not be treated as + opening or closing characters for nesting, such as quotedString or + a comment expression. Specify multiple expressions using an + :class:`Or` or :class:`MatchFirst`. The default is + :class:`quotedString`, but if no expressions are to be ignored, then + pass ``None`` for this argument. + + Example:: + + data_type = oneOf("void int short long char float double") + decl_data_type = Combine(data_type + Optional(Word('*'))) + ident = Word(alphas+'_', alphanums+'_') + number = pyparsing_common.number + arg = Group(decl_data_type + ident) + LPAR,RPAR = map(Suppress, "()") + + code_body = nestedExpr('{', '}', ignoreExpr=(quotedString | cStyleComment)) + + c_function = (decl_data_type("type") + + ident("name") + + LPAR + Optional(delimitedList(arg), [])("args") + RPAR + + code_body("body")) + c_function.ignore(cStyleComment) + + source_code = ''' + int is_odd(int x) { + return (x%2); + } + + int dec_to_hex(char hchar) { + if (hchar >= '0' && hchar <= '9') { + return (ord(hchar)-ord('0')); + } else { + return (10+ord(hchar)-ord('A')); + } + } + ''' + for func in c_function.searchString(source_code): + print("%(name)s (%(type)s) args: %(args)s" % func) + + + prints:: + + is_odd (int) args: [['int', 'x']] + dec_to_hex (int) args: [['char', 'hchar']] + """ + if opener == closer: + raise ValueError("opening and closing strings cannot be the same") + if content is None: + if isinstance(opener,basestring) and isinstance(closer,basestring): + if len(opener) == 1 and len(closer)==1: + if ignoreExpr is not None: + content = (Combine(OneOrMore(~ignoreExpr + + CharsNotIn(opener+closer+ParserElement.DEFAULT_WHITE_CHARS,exact=1)) + ).setParseAction(lambda t:t[0].strip())) + else: + content = (empty.copy()+CharsNotIn(opener+closer+ParserElement.DEFAULT_WHITE_CHARS + ).setParseAction(lambda t:t[0].strip())) + else: + if ignoreExpr is not None: + content = (Combine(OneOrMore(~ignoreExpr + + ~Literal(opener) + ~Literal(closer) + + CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS,exact=1)) + ).setParseAction(lambda t:t[0].strip())) + else: + content = (Combine(OneOrMore(~Literal(opener) + ~Literal(closer) + + CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS,exact=1)) + ).setParseAction(lambda t:t[0].strip())) + else: + raise ValueError("opening and closing arguments must be strings if no content expression is given") + ret = Forward() + if ignoreExpr is not None: + ret <<= Group( Suppress(opener) + ZeroOrMore( ignoreExpr | ret | content ) + Suppress(closer) ) + else: + ret <<= Group( Suppress(opener) + ZeroOrMore( ret | content ) + Suppress(closer) ) + ret.setName('nested %s%s expression' % (opener,closer)) + return ret + +def indentedBlock(blockStatementExpr, indentStack, indent=True): + """Helper method for defining space-delimited indentation blocks, + such as those used to define block statements in Python source code. + + Parameters: + + - blockStatementExpr - expression defining syntax of statement that + is repeated within the indented block + - indentStack - list created by caller to manage indentation stack + (multiple statementWithIndentedBlock expressions within a single + grammar should share a common indentStack) + - indent - boolean indicating whether block must be indented beyond + the the current level; set to False for block of left-most + statements (default= ``True``) + + A valid block must contain at least one ``blockStatement``. + + Example:: + + data = ''' + def A(z): + A1 + B = 100 + G = A2 + A2 + A3 + B + def BB(a,b,c): + BB1 + def BBA(): + bba1 + bba2 + bba3 + C + D + def spam(x,y): + def eggs(z): + pass + ''' + + + indentStack = [1] + stmt = Forward() + + identifier = Word(alphas, alphanums) + funcDecl = ("def" + identifier + Group( "(" + Optional( delimitedList(identifier) ) + ")" ) + ":") + func_body = indentedBlock(stmt, indentStack) + funcDef = Group( funcDecl + func_body ) + + rvalue = Forward() + funcCall = Group(identifier + "(" + Optional(delimitedList(rvalue)) + ")") + rvalue << (funcCall | identifier | Word(nums)) + assignment = Group(identifier + "=" + rvalue) + stmt << ( funcDef | assignment | identifier ) + + module_body = OneOrMore(stmt) + + parseTree = module_body.parseString(data) + parseTree.pprint() + + prints:: + + [['def', + 'A', + ['(', 'z', ')'], + ':', + [['A1'], [['B', '=', '100']], [['G', '=', 'A2']], ['A2'], ['A3']]], + 'B', + ['def', + 'BB', + ['(', 'a', 'b', 'c', ')'], + ':', + [['BB1'], [['def', 'BBA', ['(', ')'], ':', [['bba1'], ['bba2'], ['bba3']]]]]], + 'C', + 'D', + ['def', + 'spam', + ['(', 'x', 'y', ')'], + ':', + [[['def', 'eggs', ['(', 'z', ')'], ':', [['pass']]]]]]] + """ + backup_stack = indentStack[:] + + def reset_stack(): + indentStack[:] = backup_stack + + def checkPeerIndent(s,l,t): + if l >= len(s): return + curCol = col(l,s) + if curCol != indentStack[-1]: + if curCol > indentStack[-1]: + raise ParseException(s,l,"illegal nesting") + raise ParseException(s,l,"not a peer entry") + + def checkSubIndent(s,l,t): + curCol = col(l,s) + if curCol > indentStack[-1]: + indentStack.append( curCol ) + else: + raise ParseException(s,l,"not a subentry") + + def checkUnindent(s,l,t): + if l >= len(s): return + curCol = col(l,s) + if not(indentStack and curCol < indentStack[-1] and curCol <= indentStack[-2]): + raise ParseException(s,l,"not an unindent") + indentStack.pop() + + NL = OneOrMore(LineEnd().setWhitespaceChars("\t ").suppress()) + INDENT = (Empty() + Empty().setParseAction(checkSubIndent)).setName('INDENT') + PEER = Empty().setParseAction(checkPeerIndent).setName('') + UNDENT = Empty().setParseAction(checkUnindent).setName('UNINDENT') + if indent: + smExpr = Group( Optional(NL) + + #~ FollowedBy(blockStatementExpr) + + INDENT + (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) + UNDENT) + else: + smExpr = Group( Optional(NL) + + (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) ) + smExpr.setFailAction(lambda a, b, c, d: reset_stack()) + blockStatementExpr.ignore(_bslash + LineEnd()) + return smExpr.setName('indented block') + +alphas8bit = srange(r"[\0xc0-\0xd6\0xd8-\0xf6\0xf8-\0xff]") +punc8bit = srange(r"[\0xa1-\0xbf\0xd7\0xf7]") + +anyOpenTag,anyCloseTag = makeHTMLTags(Word(alphas,alphanums+"_:").setName('any tag')) +_htmlEntityMap = dict(zip("gt lt amp nbsp quot apos".split(),'><& "\'')) +commonHTMLEntity = Regex('&(?P<entity>' + '|'.join(_htmlEntityMap.keys()) +");").setName("common HTML entity") +def replaceHTMLEntity(t): + """Helper parser action to replace common HTML entities with their special characters""" + return _htmlEntityMap.get(t.entity) + +# it's easy to get these comment structures wrong - they're very common, so may as well make them available +cStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/').setName("C style comment") +"Comment of the form ``/* ... */``" + +htmlComment = Regex(r"<!--[\s\S]*?-->").setName("HTML comment") +"Comment of the form ``<!-- ... -->``" + +restOfLine = Regex(r".*").leaveWhitespace().setName("rest of line") +dblSlashComment = Regex(r"//(?:\\\n|[^\n])*").setName("// comment") +"Comment of the form ``// ... (to end of line)``" + +cppStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/'| dblSlashComment).setName("C++ style comment") +"Comment of either form :class:`cStyleComment` or :class:`dblSlashComment`" + +javaStyleComment = cppStyleComment +"Same as :class:`cppStyleComment`" + +pythonStyleComment = Regex(r"#.*").setName("Python style comment") +"Comment of the form ``# ... (to end of line)``" + +_commasepitem = Combine(OneOrMore(Word(printables, excludeChars=',') + + Optional( Word(" \t") + + ~Literal(",") + ~LineEnd() ) ) ).streamline().setName("commaItem") +commaSeparatedList = delimitedList( Optional( quotedString.copy() | _commasepitem, default="") ).setName("commaSeparatedList") +"""(Deprecated) Predefined expression of 1 or more printable words or +quoted strings, separated by commas. + +This expression is deprecated in favor of :class:`pyparsing_common.comma_separated_list`. +""" + +# some other useful expressions - using lower-case class name since we are really using this as a namespace +class pyparsing_common: + """Here are some common low-level expressions that may be useful in + jump-starting parser development: + + - numeric forms (:class:`integers<integer>`, :class:`reals<real>`, + :class:`scientific notation<sci_real>`) + - common :class:`programming identifiers<identifier>` + - network addresses (:class:`MAC<mac_address>`, + :class:`IPv4<ipv4_address>`, :class:`IPv6<ipv6_address>`) + - ISO8601 :class:`dates<iso8601_date>` and + :class:`datetime<iso8601_datetime>` + - :class:`UUID<uuid>` + - :class:`comma-separated list<comma_separated_list>` + + Parse actions: + + - :class:`convertToInteger` + - :class:`convertToFloat` + - :class:`convertToDate` + - :class:`convertToDatetime` + - :class:`stripHTMLTags` + - :class:`upcaseTokens` + - :class:`downcaseTokens` + + Example:: + + pyparsing_common.number.runTests(''' + # any int or real number, returned as the appropriate type + 100 + -100 + +100 + 3.14159 + 6.02e23 + 1e-12 + ''') + + pyparsing_common.fnumber.runTests(''' + # any int or real number, returned as float + 100 + -100 + +100 + 3.14159 + 6.02e23 + 1e-12 + ''') + + pyparsing_common.hex_integer.runTests(''' + # hex numbers + 100 + FF + ''') + + pyparsing_common.fraction.runTests(''' + # fractions + 1/2 + -3/4 + ''') + + pyparsing_common.mixed_integer.runTests(''' + # mixed fractions + 1 + 1/2 + -3/4 + 1-3/4 + ''') + + import uuid + pyparsing_common.uuid.setParseAction(tokenMap(uuid.UUID)) + pyparsing_common.uuid.runTests(''' + # uuid + 12345678-1234-5678-1234-567812345678 + ''') + + prints:: + + # any int or real number, returned as the appropriate type + 100 + [100] + + -100 + [-100] + + +100 + [100] + + 3.14159 + [3.14159] + + 6.02e23 + [6.02e+23] + + 1e-12 + [1e-12] + + # any int or real number, returned as float + 100 + [100.0] + + -100 + [-100.0] + + +100 + [100.0] + + 3.14159 + [3.14159] + + 6.02e23 + [6.02e+23] + + 1e-12 + [1e-12] + + # hex numbers + 100 + [256] + + FF + [255] + + # fractions + 1/2 + [0.5] + + -3/4 + [-0.75] + + # mixed fractions + 1 + [1] + + 1/2 + [0.5] + + -3/4 + [-0.75] + + 1-3/4 + [1.75] + + # uuid + 12345678-1234-5678-1234-567812345678 + [UUID('12345678-1234-5678-1234-567812345678')] + """ + + convertToInteger = tokenMap(int) + """ + Parse action for converting parsed integers to Python int + """ + + convertToFloat = tokenMap(float) + """ + Parse action for converting parsed numbers to Python float + """ + + integer = Word(nums).setName("integer").setParseAction(convertToInteger) + """expression that parses an unsigned integer, returns an int""" + + hex_integer = Word(hexnums).setName("hex integer").setParseAction(tokenMap(int,16)) + """expression that parses a hexadecimal integer, returns an int""" + + signed_integer = Regex(r'[+-]?\d+').setName("signed integer").setParseAction(convertToInteger) + """expression that parses an integer with optional leading sign, returns an int""" + + fraction = (signed_integer().setParseAction(convertToFloat) + '/' + signed_integer().setParseAction(convertToFloat)).setName("fraction") + """fractional expression of an integer divided by an integer, returns a float""" + fraction.addParseAction(lambda t: t[0]/t[-1]) + + mixed_integer = (fraction | signed_integer + Optional(Optional('-').suppress() + fraction)).setName("fraction or mixed integer-fraction") + """mixed integer of the form 'integer - fraction', with optional leading integer, returns float""" + mixed_integer.addParseAction(sum) + + real = Regex(r'[+-]?\d+\.\d*').setName("real number").setParseAction(convertToFloat) + """expression that parses a floating point number and returns a float""" + + sci_real = Regex(r'[+-]?\d+([eE][+-]?\d+|\.\d*([eE][+-]?\d+)?)').setName("real number with scientific notation").setParseAction(convertToFloat) + """expression that parses a floating point number with optional + scientific notation and returns a float""" + + # streamlining this expression makes the docs nicer-looking + number = (sci_real | real | signed_integer).streamline() + """any numeric expression, returns the corresponding Python type""" + + fnumber = Regex(r'[+-]?\d+\.?\d*([eE][+-]?\d+)?').setName("fnumber").setParseAction(convertToFloat) + """any int or real number, returned as float""" + + identifier = Word(alphas+'_', alphanums+'_').setName("identifier") + """typical code identifier (leading alpha or '_', followed by 0 or more alphas, nums, or '_')""" + + ipv4_address = Regex(r'(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})(\.(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})){3}').setName("IPv4 address") + "IPv4 address (``0.0.0.0 - 255.255.255.255``)" + + _ipv6_part = Regex(r'[0-9a-fA-F]{1,4}').setName("hex_integer") + _full_ipv6_address = (_ipv6_part + (':' + _ipv6_part)*7).setName("full IPv6 address") + _short_ipv6_address = (Optional(_ipv6_part + (':' + _ipv6_part)*(0,6)) + "::" + Optional(_ipv6_part + (':' + _ipv6_part)*(0,6))).setName("short IPv6 address") + _short_ipv6_address.addCondition(lambda t: sum(1 for tt in t if pyparsing_common._ipv6_part.matches(tt)) < 8) + _mixed_ipv6_address = ("::ffff:" + ipv4_address).setName("mixed IPv6 address") + ipv6_address = Combine((_full_ipv6_address | _mixed_ipv6_address | _short_ipv6_address).setName("IPv6 address")).setName("IPv6 address") + "IPv6 address (long, short, or mixed form)" + + mac_address = Regex(r'[0-9a-fA-F]{2}([:.-])[0-9a-fA-F]{2}(?:\1[0-9a-fA-F]{2}){4}').setName("MAC address") + "MAC address xx:xx:xx:xx:xx (may also have '-' or '.' delimiters)" + + @staticmethod + def convertToDate(fmt="%Y-%m-%d"): + """ + Helper to create a parse action for converting parsed date string to Python datetime.date + + Params - + - fmt - format to be passed to datetime.strptime (default= ``"%Y-%m-%d"``) + + Example:: + + date_expr = pyparsing_common.iso8601_date.copy() + date_expr.setParseAction(pyparsing_common.convertToDate()) + print(date_expr.parseString("1999-12-31")) + + prints:: + + [datetime.date(1999, 12, 31)] + """ + def cvt_fn(s,l,t): + try: + return datetime.strptime(t[0], fmt).date() + except ValueError as ve: + raise ParseException(s, l, str(ve)) + return cvt_fn + + @staticmethod + def convertToDatetime(fmt="%Y-%m-%dT%H:%M:%S.%f"): + """Helper to create a parse action for converting parsed + datetime string to Python datetime.datetime + + Params - + - fmt - format to be passed to datetime.strptime (default= ``"%Y-%m-%dT%H:%M:%S.%f"``) + + Example:: + + dt_expr = pyparsing_common.iso8601_datetime.copy() + dt_expr.setParseAction(pyparsing_common.convertToDatetime()) + print(dt_expr.parseString("1999-12-31T23:59:59.999")) + + prints:: + + [datetime.datetime(1999, 12, 31, 23, 59, 59, 999000)] + """ + def cvt_fn(s,l,t): + try: + return datetime.strptime(t[0], fmt) + except ValueError as ve: + raise ParseException(s, l, str(ve)) + return cvt_fn + + iso8601_date = Regex(r'(?P<year>\d{4})(?:-(?P<month>\d\d)(?:-(?P<day>\d\d))?)?').setName("ISO8601 date") + "ISO8601 date (``yyyy-mm-dd``)" + + iso8601_datetime = Regex(r'(?P<year>\d{4})-(?P<month>\d\d)-(?P<day>\d\d)[T ](?P<hour>\d\d):(?P<minute>\d\d)(:(?P<second>\d\d(\.\d*)?)?)?(?P<tz>Z|[+-]\d\d:?\d\d)?').setName("ISO8601 datetime") + "ISO8601 datetime (``yyyy-mm-ddThh:mm:ss.s(Z|+-00:00)``) - trailing seconds, milliseconds, and timezone optional; accepts separating ``'T'`` or ``' '``" + + uuid = Regex(r'[0-9a-fA-F]{8}(-[0-9a-fA-F]{4}){3}-[0-9a-fA-F]{12}').setName("UUID") + "UUID (``xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx``)" + + _html_stripper = anyOpenTag.suppress() | anyCloseTag.suppress() + @staticmethod + def stripHTMLTags(s, l, tokens): + """Parse action to remove HTML tags from web page HTML source + + Example:: + + # strip HTML links from normal text + text = '<td>More info at the <a href="https://github.com/pyparsing/pyparsing/wiki">pyparsing</a> wiki page</td>' + td,td_end = makeHTMLTags("TD") + table_text = td + SkipTo(td_end).setParseAction(pyparsing_common.stripHTMLTags)("body") + td_end + print(table_text.parseString(text).body) + + Prints:: + + More info at the pyparsing wiki page + """ + return pyparsing_common._html_stripper.transformString(tokens[0]) + + _commasepitem = Combine(OneOrMore(~Literal(",") + ~LineEnd() + Word(printables, excludeChars=',') + + Optional( White(" \t") ) ) ).streamline().setName("commaItem") + comma_separated_list = delimitedList( Optional( quotedString.copy() | _commasepitem, default="") ).setName("comma separated list") + """Predefined expression of 1 or more printable words or quoted strings, separated by commas.""" + + upcaseTokens = staticmethod(tokenMap(lambda t: _ustr(t).upper())) + """Parse action to convert tokens to upper case.""" + + downcaseTokens = staticmethod(tokenMap(lambda t: _ustr(t).lower())) + """Parse action to convert tokens to lower case.""" + + +class _lazyclassproperty(object): + def __init__(self, fn): + self.fn = fn + self.__doc__ = fn.__doc__ + self.__name__ = fn.__name__ + + def __get__(self, obj, cls): + if cls is None: + cls = type(obj) + if not hasattr(cls, '_intern') or any(cls._intern is getattr(superclass, '_intern', []) for superclass in cls.__mro__[1:]): + cls._intern = {} + attrname = self.fn.__name__ + if attrname not in cls._intern: + cls._intern[attrname] = self.fn(cls) + return cls._intern[attrname] + + +class unicode_set(object): + """ + A set of Unicode characters, for language-specific strings for + ``alphas``, ``nums``, ``alphanums``, and ``printables``. + A unicode_set is defined by a list of ranges in the Unicode character + set, in a class attribute ``_ranges``, such as:: + + _ranges = [(0x0020, 0x007e), (0x00a0, 0x00ff),] + + A unicode set can also be defined using multiple inheritance of other unicode sets:: + + class CJK(Chinese, Japanese, Korean): + pass + """ + _ranges = [] + + @classmethod + def _get_chars_for_ranges(cls): + ret = [] + for cc in cls.__mro__: + if cc is unicode_set: + break + for rr in cc._ranges: + ret.extend(range(rr[0], rr[-1]+1)) + return [unichr(c) for c in sorted(set(ret))] + + @_lazyclassproperty + def printables(cls): + "all non-whitespace characters in this range" + return u''.join(filterfalse(unicode.isspace, cls._get_chars_for_ranges())) + + @_lazyclassproperty + def alphas(cls): + "all alphabetic characters in this range" + return u''.join(filter(unicode.isalpha, cls._get_chars_for_ranges())) + + @_lazyclassproperty + def nums(cls): + "all numeric digit characters in this range" + return u''.join(filter(unicode.isdigit, cls._get_chars_for_ranges())) + + @_lazyclassproperty + def alphanums(cls): + "all alphanumeric characters in this range" + return cls.alphas + cls.nums + + +class pyparsing_unicode(unicode_set): + """ + A namespace class for defining common language unicode_sets. + """ + _ranges = [(32, sys.maxunicode)] + + class Latin1(unicode_set): + "Unicode set for Latin-1 Unicode Character Range" + _ranges = [(0x0020, 0x007e), (0x00a0, 0x00ff),] + + class LatinA(unicode_set): + "Unicode set for Latin-A Unicode Character Range" + _ranges = [(0x0100, 0x017f),] + + class LatinB(unicode_set): + "Unicode set for Latin-B Unicode Character Range" + _ranges = [(0x0180, 0x024f),] + + class Greek(unicode_set): + "Unicode set for Greek Unicode Character Ranges" + _ranges = [ + (0x0370, 0x03ff), (0x1f00, 0x1f15), (0x1f18, 0x1f1d), (0x1f20, 0x1f45), (0x1f48, 0x1f4d), + (0x1f50, 0x1f57), (0x1f59,), (0x1f5b,), (0x1f5d,), (0x1f5f, 0x1f7d), (0x1f80, 0x1fb4), (0x1fb6, 0x1fc4), + (0x1fc6, 0x1fd3), (0x1fd6, 0x1fdb), (0x1fdd, 0x1fef), (0x1ff2, 0x1ff4), (0x1ff6, 0x1ffe), + ] + + class Cyrillic(unicode_set): + "Unicode set for Cyrillic Unicode Character Range" + _ranges = [(0x0400, 0x04ff)] + + class Chinese(unicode_set): + "Unicode set for Chinese Unicode Character Range" + _ranges = [(0x4e00, 0x9fff), (0x3000, 0x303f), ] + + class Japanese(unicode_set): + "Unicode set for Japanese Unicode Character Range, combining Kanji, Hiragana, and Katakana ranges" + _ranges = [ ] + + class Kanji(unicode_set): + "Unicode set for Kanji Unicode Character Range" + _ranges = [(0x4E00, 0x9Fbf), (0x3000, 0x303f), ] + + class Hiragana(unicode_set): + "Unicode set for Hiragana Unicode Character Range" + _ranges = [(0x3040, 0x309f), ] + + class Katakana(unicode_set): + "Unicode set for Katakana Unicode Character Range" + _ranges = [(0x30a0, 0x30ff), ] + + class Korean(unicode_set): + "Unicode set for Korean Unicode Character Range" + _ranges = [(0xac00, 0xd7af), (0x1100, 0x11ff), (0x3130, 0x318f), (0xa960, 0xa97f), (0xd7b0, 0xd7ff), (0x3000, 0x303f), ] + + class CJK(Chinese, Japanese, Korean): + "Unicode set for combined Chinese, Japanese, and Korean (CJK) Unicode Character Range" + pass + + class Thai(unicode_set): + "Unicode set for Thai Unicode Character Range" + _ranges = [(0x0e01, 0x0e3a), (0x0e3f, 0x0e5b), ] + + class Arabic(unicode_set): + "Unicode set for Arabic Unicode Character Range" + _ranges = [(0x0600, 0x061b), (0x061e, 0x06ff), (0x0700, 0x077f), ] + + class Hebrew(unicode_set): + "Unicode set for Hebrew Unicode Character Range" + _ranges = [(0x0590, 0x05ff), ] + + class Devanagari(unicode_set): + "Unicode set for Devanagari Unicode Character Range" + _ranges = [(0x0900, 0x097f), (0xa8e0, 0xa8ff)] + +pyparsing_unicode.Japanese._ranges = (pyparsing_unicode.Japanese.Kanji._ranges + + pyparsing_unicode.Japanese.Hiragana._ranges + + pyparsing_unicode.Japanese.Katakana._ranges) + +# define ranges in language character sets +if PY_3: + setattr(pyparsing_unicode, "العربية", pyparsing_unicode.Arabic) + setattr(pyparsing_unicode, "中文", pyparsing_unicode.Chinese) + setattr(pyparsing_unicode, "кириллица", pyparsing_unicode.Cyrillic) + setattr(pyparsing_unicode, "Ελληνικά", pyparsing_unicode.Greek) + setattr(pyparsing_unicode, "עִברִית", pyparsing_unicode.Hebrew) + setattr(pyparsing_unicode, "日本語", pyparsing_unicode.Japanese) + setattr(pyparsing_unicode.Japanese, "漢字", pyparsing_unicode.Japanese.Kanji) + setattr(pyparsing_unicode.Japanese, "カタカナ", pyparsing_unicode.Japanese.Katakana) + setattr(pyparsing_unicode.Japanese, "ひらがな", pyparsing_unicode.Japanese.Hiragana) + setattr(pyparsing_unicode, "한국어", pyparsing_unicode.Korean) + setattr(pyparsing_unicode, "ไทย", pyparsing_unicode.Thai) + setattr(pyparsing_unicode, "देवनागरी", pyparsing_unicode.Devanagari) + + +if __name__ == "__main__": + + selectToken = CaselessLiteral("select") + fromToken = CaselessLiteral("from") + + ident = Word(alphas, alphanums + "_$") + + columnName = delimitedList(ident, ".", combine=True).setParseAction(upcaseTokens) + columnNameList = Group(delimitedList(columnName)).setName("columns") + columnSpec = ('*' | columnNameList) + + tableName = delimitedList(ident, ".", combine=True).setParseAction(upcaseTokens) + tableNameList = Group(delimitedList(tableName)).setName("tables") + + simpleSQL = selectToken("command") + columnSpec("columns") + fromToken + tableNameList("tables") + + # demo runTests method, including embedded comments in test string + simpleSQL.runTests(""" + # '*' as column list and dotted table name + select * from SYS.XYZZY + + # caseless match on "SELECT", and casts back to "select" + SELECT * from XYZZY, ABC + + # list of column names, and mixed case SELECT keyword + Select AA,BB,CC from Sys.dual + + # multiple tables + Select A, B, C from Sys.dual, Table2 + + # invalid SELECT keyword - should fail + Xelect A, B, C from Sys.dual + + # incomplete command - should fail + Select + + # invalid column name - should fail + Select ^^^ frox Sys.dual + + """) + + pyparsing_common.number.runTests(""" + 100 + -100 + +100 + 3.14159 + 6.02e23 + 1e-12 + """) + + # any int or real number, returned as float + pyparsing_common.fnumber.runTests(""" + 100 + -100 + +100 + 3.14159 + 6.02e23 + 1e-12 + """) + + pyparsing_common.hex_integer.runTests(""" + 100 + FF + """) + + import uuid + pyparsing_common.uuid.setParseAction(tokenMap(uuid.UUID)) + pyparsing_common.uuid.runTests(""" + 12345678-1234-5678-1234-567812345678 + """) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__init__.py new file mode 100644 index 0000000..8ed060f --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__init__.py @@ -0,0 +1,4 @@ +from .core import TomlError +from .parser import load, loads +from .test import translate_to_test +from .writer import dump, dumps \ No newline at end of file diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5183fa2e1e5f4d91a1ef44d420ced597cd7019fe GIT binary patch literal 389 zcmYjNJx{|h5RDTj{ZK2x&&W_57%Ek&5DO~{uw=0UcH1C3w$5&7yYO2W+4wzPnfL<? zO!zYKq<g-1?`)s_IG<0Gh@a2*<}I#YDE=dj;wFY$M-qu3D$%4S1oKp-I;%5HYdYvm z<+`YgA*X7j$MslG>Pgi3eNq<RBpy+cFnKUq-2xaW(?FGJM97g{^v*prol}jM+#Bwt z^VlQy+J+q2-IdcopAAUB$wFZpa1tPk0w`7}Zi0L;U!nEUEYKW9`bc1gInu9X7TP}E z#QFx<#wa1dvDJZX`Kkwf>aI2~)oyn<ow!;ppLS41Y&-VAY-<;7=X|5oqN<ktvA^77 oaR}baP8eYJ=;JdP=WW+|&M)jSjMv(Ty^`1X5e}!Ckux$Qe_ZNmD*ylh literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/core.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/core.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2ba25d38f65949d47912953feffa5b05f51d421a GIT binary patch literal 966 zcmbVKy>1gh5Z=8X`x5L(i6|(EM3Iw-&rn1%LMReKbS@w?ZdQkPZJ%{NX7+rF&*zFf zNL;4ld9LLVkSLIlm|4q~ji{K@%+BoW?tJ&nd}_Ck8OqOZ>+m;c>^lYf;$U!%svo0y z&m@!l4pp(Q_JB+4BlGPcW)8%{=o(c&L!%g;V*^X#={q*Cr7ay?9qGyjuC8q28(w{M zlO^#xfDDE%-r5TJP1Lujx`QTX_q<{iudK?hoVClzXTrjm2^;sAa4H9_D;Yk_`+lQt zeVC_tlqmCj?FkX3Q7%N?OqAB)Sk+D(rK+}vSzLRgC{}5hDBrCet>O_713);SL59#g zFgU{HR~*bBD#Ba^MF_zti=_e`^lpQ(=oOHZ>C4fyJDJ>;rHFf1pC`~o8K=QbFpFlF zQL6JWjxW32t71{SnA4_FQK(dA5X=@ik`fFvP@UNVY%EFCYSS@(#vA4<&vw*xw!b#S zR_=s+f^Il`f{x_(tYTB-ZHlZ-k+Z3@c91QrU!E*i7t7W2r^}W9ii}$~Mj0ewZhm}^ z2cqSHgNKVDV`B(f-4sISAOvxw2{Gg4={`u4{eO(-ySFZu=RjcpvcB)aBP{!`-a(5J z1Z@v7&IG6#LZ;*v@&T`#G))tprTM`5ITj+x<UA(7CB&C`7;iGBRnVpyC%Zz2C4ss^ js;M;|_nMw<_WHgB#F+{9aGL9eUhnm$>KnTL1C{*&4RFxy literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/parser.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/parser.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..74274c0f637bda6609903419582271f545f76996 GIT binary patch literal 10163 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/test.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/test.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f4044132af0548a67a7ec695d679709d43b4410e GIT binary patch literal 1268 zcmah|KW`H;6t{hUl3bGhQ&kC6M3G>~&|FHTqEuCdL|Hm?Xp4Xdbh^e)daZL8d`^_4 z$<lOUL#zxfTQ@!cAA;E<O#K23NJu<iTAG#tpWZva_xzrJ?`Qi(KJOqHKfj#$zYT<b zXk&b&!FUQ1Z-b(UVvZ_^5^8YVAQgg9Z<ZO%tdWYvY?gw5`XvhIO~f*Xj@ZCRf6UO) zO8PYl$ty%nYMr2pL-7tO*cVV2ZCzl{1*|4&k!bkR6SeB{@^ZPV-B*La!~}T;5`PCJ zQ6EV>Bx0UoN>0E!C1+>@4WV!nGa$B04QlF`_789$iA^1&)}2xAW*=5lyN_w=6S>SY z4@}4mX<Ax+$Qp~-;D1juQ0169A)(o^SPEjFX-=kZ<z&GBmFDThsnbVi<JGbd`9>!J z&1ml&of@qf;$ut^&@;Vtg911qWP$8x3hsgmpp~~XZ^!@-NFPIEWQaeKcjgW{N9R~g zOW}tx_a*aW<VhCGf}u#Ur0}7_ZK2sr)GzKfMbL(IZrc}bE#j1k*e!S5x>s(CMlXC^ zJ1Fh%cX~aKmsj@oMF~bdba&lm&|D0{So)kVmP#w_ZhNVvor!pD7Sc$#&900Z+|>Yz z&8~9RXi$~asL@={>rQM?Hhcv29{q#3xW=QZ&*Sytb=D11uI@!b$}E(sYf^FpO$Q$0 z4+$NkUNv_GB2w^ExO3gV(2oFM@gN?-ngl!6^!y*x-yESYtFn9{{BD6LQ+At7S#6)U zm`YRNRt62G%)Kb$5ES6GYS0%`sUVcB&IH&z@@3CHS}iU;87MoJA_(ifxmL(JO;(kR zE+pkv7mgl?K_Rc4AWpast58^Ts;oe=MyyPYN=ySFq3?{C(a;<ZHu5yASQ!u&bJ}Z< zo}9{iqwOvi<hEO(2K-!zNC0OUy%zhoI1~ElvLNw8PzXDC24n)XNgSMm*_Fq^Q!saM zl2OPe*p$_h0gp!z??JvwwZfnp!R5QJEd%gED^XY%^V-gA`Imr_Dq~oZo17eCdaV)B W7H8}FG~y{xX`CYjg9bDvcE}$|Fgr^C literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/utils.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/utils.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2a97f931c037cbe39a4af4403772ea658a787884 GIT binary patch literal 2178 zcmZ`)OK;mo5Z+lnM9GgRiR+|A3Iu6Xm~i!o9i*@jG)8-<FEI+(Jydl;s9MUFO_A!7 z5^R|~6i)j)q@!;=_P6Y{C;x#SeCo{7iXUlKnAzQ#-5JizH>)2P7D^1qzkf~JzuS!c zLz|n!#LXsByoF3K0Rd~}Gqk{m2^V|{EkhW>e8*a*u!N1XB?`j9+5Vo1qA0y%qU5u~ z!kN)>1ne+(?gFi`?ePyQd*bwE=2mH5yPkKi_RTx<%3f_xth#Sj-ZWe3%FnCSU-Emi zb8ZL7@YUcr8%W<F#Vg1XHi48)A%hg;la#(5rYJcw<Ws?RSYo7bM&HM`B^h!}Rg&G# z`uh5YCw*o0+ezm@S^F{?4pe#2ma*?$>s_v3q@aJ!q=T0)`}KkBjoOJ{AGKw@8wJ9b zaed>szVB^}WPcp4bq^Z{2gl>F7i_%x^*}ao?1%N;`k*(c_QE)62SK&bcr`j1y%>^E zlQ;515y|@CB#HV#eVFuuxHdRZ3%9-pYsq5z3<f25047MP^R4udU=B&A=WkpjEWu<< z_*5785B@1T<CrQoF{sG0k(jgf8Du;(g^_VBF;RQ0?;;GQAgnVk?4{hAAqu(V5zCCk zO6*BN7^y+}DMveISe{9RkxNq8vokAWnVl6fCoAF|JGD}l+G!zm(jt1|!dYTxkeX8m z%T?UIpm;9|$aLW@DDn#m@ZvSGBC_7*xA&OqD5KvVD5Do9%GQO9C1G4y-5_cws_5<Z z`hF`4edP$OU4lDRBrg0QX}cv!P83K)L$4zv1^bF8V+AJ)gn}&vZx!rl0OX8ZOAFaN zQoMwW!7|pQ%uQZ`=djGnybSupt?CePDJWf?KXHMXW>ZGc73`=epJEmez*EeEfX`Tn zji`0}h|4vqOjyH{{K%A>!o*!kSXeEXLkq&57%8sl9`R*1)s;LnWrAL?d9f+@BWwu0 zb7nhg5zMu`hhL-9te|xXtCvt6mronn>5FD#Eo+{x(KKGF{8X*<s}-?Z*=knaHY+=| zN_Tw!1F37P;xOq%-EQnB@&TGw3rU2~_hP>jg(6mVH<H+SYECCSmntVtWS7d~8j{ka zOtPTtc-Zasj_>4OE#@X>&H6cBh#w<k;J_2^fUU^{8_QwCBA2VE>(GIlgWi)(r1&dj zK5JniTKIwpjxXIuUqDgBq?P0+c%?%IW`ov5y1s<e6g$ns&f8(<uze1y;N>~NXT^;D zpsVbw91*s!v85c(>xI3<^Io7l)-GWD;603MGxZ1F>4nqYDSs(DM9-2UlT~ErT-I?? zTqJjrDW9YKCDP2-!)ssf3;A(p)NB-F?n=k9hN3%8lp*5e>l;oMuAQLfmU(I}A|1;X zE-01>;46msM$BVp95ML}dje69_@|f4q_x(Y*a@b9CH5FK!kX~ZNKrO5ux$1XtjjOZ zvV4YYym*?OHfsp-oFf8jq^l775}9l1+{twk=;y+aeyrf&Zjg2|4%>adiRa=nG6stX zND~~61oJR1Uq_uE-F6F9aJuDrs^oe7NDKp7&wJi)!*-BsBw;}pN>ZgHW%7n|opt>% z5iA=>`me$P$Dp4Et6P-Is8AgL_zIn<Kj;O%By{ON68&E3E>RdnFU0;LQ~&2fIj{4N U{DuG*(=&*Uc!@i<bKiORA6kIe%>V!Z literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/writer.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/__pycache__/writer.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e773b0d0e2ecd60d8beca1124da021d52a32d218 GIT binary patch literal 3609 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 BDg6Kd literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/core.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/core.py new file mode 100644 index 0000000..c182734 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/core.py @@ -0,0 +1,13 @@ +class TomlError(RuntimeError): + def __init__(self, message, line, col, filename): + RuntimeError.__init__(self, message, line, col, filename) + self.message = message + self.line = line + self.col = col + self.filename = filename + + def __str__(self): + return '{}({}, {}): {}'.format(self.filename, self.line, self.col, self.message) + + def __repr__(self): + return 'TomlError({!r}, {!r}, {!r}, {!r})'.format(self.message, self.line, self.col, self.filename) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/parser.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/parser.py new file mode 100644 index 0000000..3493aa6 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/parser.py @@ -0,0 +1,341 @@ +import string, re, sys, datetime +from .core import TomlError +from .utils import rfc3339_re, parse_rfc3339_re + +if sys.version_info[0] == 2: + _chr = unichr +else: + _chr = chr + +def load(fin, translate=lambda t, x, v: v, object_pairs_hook=dict): + return loads(fin.read(), translate=translate, object_pairs_hook=object_pairs_hook, filename=getattr(fin, 'name', repr(fin))) + +def loads(s, filename='<string>', translate=lambda t, x, v: v, object_pairs_hook=dict): + if isinstance(s, bytes): + s = s.decode('utf-8') + + s = s.replace('\r\n', '\n') + + root = object_pairs_hook() + tables = object_pairs_hook() + scope = root + + src = _Source(s, filename=filename) + ast = _p_toml(src, object_pairs_hook=object_pairs_hook) + + def error(msg): + raise TomlError(msg, pos[0], pos[1], filename) + + def process_value(v, object_pairs_hook): + kind, text, value, pos = v + if kind == 'str' and value.startswith('\n'): + value = value[1:] + if kind == 'array': + if value and any(k != value[0][0] for k, t, v, p in value[1:]): + error('array-type-mismatch') + value = [process_value(item, object_pairs_hook=object_pairs_hook) for item in value] + elif kind == 'table': + value = object_pairs_hook([(k, process_value(value[k], object_pairs_hook=object_pairs_hook)) for k in value]) + return translate(kind, text, value) + + for kind, value, pos in ast: + if kind == 'kv': + k, v = value + if k in scope: + error('duplicate_keys. Key "{0}" was used more than once.'.format(k)) + scope[k] = process_value(v, object_pairs_hook=object_pairs_hook) + else: + is_table_array = (kind == 'table_array') + cur = tables + for name in value[:-1]: + if isinstance(cur.get(name), list): + d, cur = cur[name][-1] + else: + d, cur = cur.setdefault(name, (None, object_pairs_hook())) + + scope = object_pairs_hook() + name = value[-1] + if name not in cur: + if is_table_array: + cur[name] = [(scope, object_pairs_hook())] + else: + cur[name] = (scope, object_pairs_hook()) + elif isinstance(cur[name], list): + if not is_table_array: + error('table_type_mismatch') + cur[name].append((scope, object_pairs_hook())) + else: + if is_table_array: + error('table_type_mismatch') + old_scope, next_table = cur[name] + if old_scope is not None: + error('duplicate_tables') + cur[name] = (scope, next_table) + + def merge_tables(scope, tables): + if scope is None: + scope = object_pairs_hook() + for k in tables: + if k in scope: + error('key_table_conflict') + v = tables[k] + if isinstance(v, list): + scope[k] = [merge_tables(sc, tbl) for sc, tbl in v] + else: + scope[k] = merge_tables(v[0], v[1]) + return scope + + return merge_tables(root, tables) + +class _Source: + def __init__(self, s, filename=None): + self.s = s + self._pos = (1, 1) + self._last = None + self._filename = filename + self.backtrack_stack = [] + + def last(self): + return self._last + + def pos(self): + return self._pos + + def fail(self): + return self._expect(None) + + def consume_dot(self): + if self.s: + self._last = self.s[0] + self.s = self[1:] + self._advance(self._last) + return self._last + return None + + def expect_dot(self): + return self._expect(self.consume_dot()) + + def consume_eof(self): + if not self.s: + self._last = '' + return True + return False + + def expect_eof(self): + return self._expect(self.consume_eof()) + + def consume(self, s): + if self.s.startswith(s): + self.s = self.s[len(s):] + self._last = s + self._advance(s) + return True + return False + + def expect(self, s): + return self._expect(self.consume(s)) + + def consume_re(self, re): + m = re.match(self.s) + if m: + self.s = self.s[len(m.group(0)):] + self._last = m + self._advance(m.group(0)) + return m + return None + + def expect_re(self, re): + return self._expect(self.consume_re(re)) + + def __enter__(self): + self.backtrack_stack.append((self.s, self._pos)) + + def __exit__(self, type, value, traceback): + if type is None: + self.backtrack_stack.pop() + else: + self.s, self._pos = self.backtrack_stack.pop() + return type == TomlError + + def commit(self): + self.backtrack_stack[-1] = (self.s, self._pos) + + def _expect(self, r): + if not r: + raise TomlError('msg', self._pos[0], self._pos[1], self._filename) + return r + + def _advance(self, s): + suffix_pos = s.rfind('\n') + if suffix_pos == -1: + self._pos = (self._pos[0], self._pos[1] + len(s)) + else: + self._pos = (self._pos[0] + s.count('\n'), len(s) - suffix_pos) + +_ews_re = re.compile(r'(?:[ \t]|#[^\n]*\n|#[^\n]*\Z|\n)*') +def _p_ews(s): + s.expect_re(_ews_re) + +_ws_re = re.compile(r'[ \t]*') +def _p_ws(s): + s.expect_re(_ws_re) + +_escapes = { 'b': '\b', 'n': '\n', 'r': '\r', 't': '\t', '"': '"', + '\\': '\\', 'f': '\f' } + +_basicstr_re = re.compile(r'[^"\\\000-\037]*') +_short_uni_re = re.compile(r'u([0-9a-fA-F]{4})') +_long_uni_re = re.compile(r'U([0-9a-fA-F]{8})') +_escapes_re = re.compile(r'[btnfr\"\\]') +_newline_esc_re = re.compile('\n[ \t\n]*') +def _p_basicstr_content(s, content=_basicstr_re): + res = [] + while True: + res.append(s.expect_re(content).group(0)) + if not s.consume('\\'): + break + if s.consume_re(_newline_esc_re): + pass + elif s.consume_re(_short_uni_re) or s.consume_re(_long_uni_re): + v = int(s.last().group(1), 16) + if 0xd800 <= v < 0xe000: + s.fail() + res.append(_chr(v)) + else: + s.expect_re(_escapes_re) + res.append(_escapes[s.last().group(0)]) + return ''.join(res) + +_key_re = re.compile(r'[0-9a-zA-Z-_]+') +def _p_key(s): + with s: + s.expect('"') + r = _p_basicstr_content(s, _basicstr_re) + s.expect('"') + return r + if s.consume('\''): + if s.consume('\'\''): + r = s.expect_re(_litstr_ml_re).group(0) + s.expect('\'\'\'') + else: + r = s.expect_re(_litstr_re).group(0) + s.expect('\'') + return r + return s.expect_re(_key_re).group(0) + +_float_re = re.compile(r'[+-]?(?:0|[1-9](?:_?\d)*)(?:\.\d(?:_?\d)*)?(?:[eE][+-]?(?:\d(?:_?\d)*))?') + +_basicstr_ml_re = re.compile(r'(?:""?(?!")|[^"\\\000-\011\013-\037])*') +_litstr_re = re.compile(r"[^'\000\010\012-\037]*") +_litstr_ml_re = re.compile(r"(?:(?:|'|'')(?:[^'\000-\010\013-\037]))*") +def _p_value(s, object_pairs_hook): + pos = s.pos() + + if s.consume('true'): + return 'bool', s.last(), True, pos + if s.consume('false'): + return 'bool', s.last(), False, pos + + if s.consume('"'): + if s.consume('""'): + r = _p_basicstr_content(s, _basicstr_ml_re) + s.expect('"""') + else: + r = _p_basicstr_content(s, _basicstr_re) + s.expect('"') + return 'str', r, r, pos + + if s.consume('\''): + if s.consume('\'\''): + r = s.expect_re(_litstr_ml_re).group(0) + s.expect('\'\'\'') + else: + r = s.expect_re(_litstr_re).group(0) + s.expect('\'') + return 'str', r, r, pos + + if s.consume_re(rfc3339_re): + m = s.last() + return 'datetime', m.group(0), parse_rfc3339_re(m), pos + + if s.consume_re(_float_re): + m = s.last().group(0) + r = m.replace('_','') + if '.' in m or 'e' in m or 'E' in m: + return 'float', m, float(r), pos + else: + return 'int', m, int(r, 10), pos + + if s.consume('['): + items = [] + with s: + while True: + _p_ews(s) + items.append(_p_value(s, object_pairs_hook=object_pairs_hook)) + s.commit() + _p_ews(s) + s.expect(',') + s.commit() + _p_ews(s) + s.expect(']') + return 'array', None, items, pos + + if s.consume('{'): + _p_ws(s) + items = object_pairs_hook() + if not s.consume('}'): + k = _p_key(s) + _p_ws(s) + s.expect('=') + _p_ws(s) + items[k] = _p_value(s, object_pairs_hook=object_pairs_hook) + _p_ws(s) + while s.consume(','): + _p_ws(s) + k = _p_key(s) + _p_ws(s) + s.expect('=') + _p_ws(s) + items[k] = _p_value(s, object_pairs_hook=object_pairs_hook) + _p_ws(s) + s.expect('}') + return 'table', None, items, pos + + s.fail() + +def _p_stmt(s, object_pairs_hook): + pos = s.pos() + if s.consume( '['): + is_array = s.consume('[') + _p_ws(s) + keys = [_p_key(s)] + _p_ws(s) + while s.consume('.'): + _p_ws(s) + keys.append(_p_key(s)) + _p_ws(s) + s.expect(']') + if is_array: + s.expect(']') + return 'table_array' if is_array else 'table', keys, pos + + key = _p_key(s) + _p_ws(s) + s.expect('=') + _p_ws(s) + value = _p_value(s, object_pairs_hook=object_pairs_hook) + return 'kv', (key, value), pos + +_stmtsep_re = re.compile(r'(?:[ \t]*(?:#[^\n]*)?\n)+[ \t]*') +def _p_toml(s, object_pairs_hook): + stmts = [] + _p_ews(s) + with s: + stmts.append(_p_stmt(s, object_pairs_hook=object_pairs_hook)) + while True: + s.commit() + s.expect_re(_stmtsep_re) + stmts.append(_p_stmt(s, object_pairs_hook=object_pairs_hook)) + _p_ews(s) + s.expect_eof() + return stmts diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/test.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/test.py new file mode 100644 index 0000000..ec8abfc --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/test.py @@ -0,0 +1,30 @@ +import datetime +from .utils import format_rfc3339 + +try: + _string_types = (str, unicode) + _int_types = (int, long) +except NameError: + _string_types = str + _int_types = int + +def translate_to_test(v): + if isinstance(v, dict): + return { k: translate_to_test(v) for k, v in v.items() } + if isinstance(v, list): + a = [translate_to_test(x) for x in v] + if v and isinstance(v[0], dict): + return a + else: + return {'type': 'array', 'value': a} + if isinstance(v, datetime.datetime): + return {'type': 'datetime', 'value': format_rfc3339(v)} + if isinstance(v, bool): + return {'type': 'bool', 'value': 'true' if v else 'false'} + if isinstance(v, _int_types): + return {'type': 'integer', 'value': str(v)} + if isinstance(v, float): + return {'type': 'float', 'value': '{:.17}'.format(v)} + if isinstance(v, _string_types): + return {'type': 'string', 'value': v} + raise RuntimeError('unexpected value: {!r}'.format(v)) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/utils.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/utils.py new file mode 100644 index 0000000..636a680 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/utils.py @@ -0,0 +1,67 @@ +import datetime +import re + +rfc3339_re = re.compile(r'(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2})(\.\d+)?(?:Z|([+-]\d{2}):(\d{2}))') + +def parse_rfc3339(v): + m = rfc3339_re.match(v) + if not m or m.group(0) != v: + return None + return parse_rfc3339_re(m) + +def parse_rfc3339_re(m): + r = map(int, m.groups()[:6]) + if m.group(7): + micro = float(m.group(7)) + else: + micro = 0 + + if m.group(8): + g = int(m.group(8), 10) * 60 + int(m.group(9), 10) + tz = _TimeZone(datetime.timedelta(0, g * 60)) + else: + tz = _TimeZone(datetime.timedelta(0, 0)) + + y, m, d, H, M, S = r + return datetime.datetime(y, m, d, H, M, S, int(micro * 1000000), tz) + + +def format_rfc3339(v): + offs = v.utcoffset() + offs = int(offs.total_seconds()) // 60 if offs is not None else 0 + + if offs == 0: + suffix = 'Z' + else: + if offs > 0: + suffix = '+' + else: + suffix = '-' + offs = -offs + suffix = '{0}{1:02}:{2:02}'.format(suffix, offs // 60, offs % 60) + + if v.microsecond: + return v.strftime('%Y-%m-%dT%H:%M:%S.%f') + suffix + else: + return v.strftime('%Y-%m-%dT%H:%M:%S') + suffix + +class _TimeZone(datetime.tzinfo): + def __init__(self, offset): + self._offset = offset + + def utcoffset(self, dt): + return self._offset + + def dst(self, dt): + return None + + def tzname(self, dt): + m = self._offset.total_seconds() // 60 + if m < 0: + res = '-' + m = -m + else: + res = '+' + h = m // 60 + m = m - h * 60 + return '{}{:.02}{:.02}'.format(res, h, m) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/writer.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/writer.py new file mode 100644 index 0000000..73b5089 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/pytoml/writer.py @@ -0,0 +1,106 @@ +from __future__ import unicode_literals +import io, datetime, math, string, sys + +from .utils import format_rfc3339 + +if sys.version_info[0] == 3: + long = int + unicode = str + + +def dumps(obj, sort_keys=False): + fout = io.StringIO() + dump(obj, fout, sort_keys=sort_keys) + return fout.getvalue() + + +_escapes = {'\n': 'n', '\r': 'r', '\\': '\\', '\t': 't', '\b': 'b', '\f': 'f', '"': '"'} + + +def _escape_string(s): + res = [] + start = 0 + + def flush(): + if start != i: + res.append(s[start:i]) + return i + 1 + + i = 0 + while i < len(s): + c = s[i] + if c in '"\\\n\r\t\b\f': + start = flush() + res.append('\\' + _escapes[c]) + elif ord(c) < 0x20: + start = flush() + res.append('\\u%04x' % ord(c)) + i += 1 + + flush() + return '"' + ''.join(res) + '"' + + +_key_chars = string.digits + string.ascii_letters + '-_' +def _escape_id(s): + if any(c not in _key_chars for c in s): + return _escape_string(s) + return s + + +def _format_value(v): + if isinstance(v, bool): + return 'true' if v else 'false' + if isinstance(v, int) or isinstance(v, long): + return unicode(v) + if isinstance(v, float): + if math.isnan(v) or math.isinf(v): + raise ValueError("{0} is not a valid TOML value".format(v)) + else: + return repr(v) + elif isinstance(v, unicode) or isinstance(v, bytes): + return _escape_string(v) + elif isinstance(v, datetime.datetime): + return format_rfc3339(v) + elif isinstance(v, list): + return '[{0}]'.format(', '.join(_format_value(obj) for obj in v)) + elif isinstance(v, dict): + return '{{{0}}}'.format(', '.join('{} = {}'.format(_escape_id(k), _format_value(obj)) for k, obj in v.items())) + else: + raise RuntimeError(v) + + +def dump(obj, fout, sort_keys=False): + tables = [((), obj, False)] + + while tables: + name, table, is_array = tables.pop() + if name: + section_name = '.'.join(_escape_id(c) for c in name) + if is_array: + fout.write('[[{0}]]\n'.format(section_name)) + else: + fout.write('[{0}]\n'.format(section_name)) + + table_keys = sorted(table.keys()) if sort_keys else table.keys() + new_tables = [] + has_kv = False + for k in table_keys: + v = table[k] + if isinstance(v, dict): + new_tables.append((name + (k,), v, False)) + elif isinstance(v, list) and v and all(isinstance(o, dict) for o in v): + new_tables.extend((name + (k,), d, True) for d in v) + elif v is None: + # based on mojombo's comment: https://github.com/toml-lang/toml/issues/146#issuecomment-25019344 + fout.write( + '#{} = null # To use: uncomment and replace null with value\n'.format(_escape_id(k))) + has_kv = True + else: + fout.write('{0} = {1}\n'.format(_escape_id(k), _format_value(v))) + has_kv = True + + tables.extend(reversed(new_tables)) + + if (name or has_kv) and tables: + fout.write('\n') diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__init__.py new file mode 100644 index 0000000..1d30e3e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__init__.py @@ -0,0 +1,133 @@ +# -*- coding: utf-8 -*- + +# __ +# /__) _ _ _ _ _/ _ +# / ( (- (/ (/ (- _) / _) +# / + +""" +Requests HTTP Library +~~~~~~~~~~~~~~~~~~~~~ + +Requests is an HTTP library, written in Python, for human beings. Basic GET +usage: + + >>> import requests + >>> r = requests.get('https://www.python.org') + >>> r.status_code + 200 + >>> 'Python is a programming language' in r.content + True + +... or POST: + + >>> payload = dict(key1='value1', key2='value2') + >>> r = requests.post('https://httpbin.org/post', data=payload) + >>> print(r.text) + { + ... + "form": { + "key2": "value2", + "key1": "value1" + }, + ... + } + +The other HTTP methods are supported - see `requests.api`. Full documentation +is at <http://python-requests.org>. + +:copyright: (c) 2017 by Kenneth Reitz. +:license: Apache 2.0, see LICENSE for more details. +""" + +from pip._vendor import urllib3 +from pip._vendor import chardet +import warnings +from .exceptions import RequestsDependencyWarning + + +def check_compatibility(urllib3_version, chardet_version): + urllib3_version = urllib3_version.split('.') + assert urllib3_version != ['dev'] # Verify urllib3 isn't installed from git. + + # Sometimes, urllib3 only reports its version as 16.1. + if len(urllib3_version) == 2: + urllib3_version.append('0') + + # Check urllib3 for compatibility. + major, minor, patch = urllib3_version # noqa: F811 + major, minor, patch = int(major), int(minor), int(patch) + # urllib3 >= 1.21.1, <= 1.25 + assert major == 1 + assert minor >= 21 + assert minor <= 25 + + # Check chardet for compatibility. + major, minor, patch = chardet_version.split('.')[:3] + major, minor, patch = int(major), int(minor), int(patch) + # chardet >= 3.0.2, < 3.1.0 + assert major == 3 + assert minor < 1 + assert patch >= 2 + + +def _check_cryptography(cryptography_version): + # cryptography < 1.3.4 + try: + cryptography_version = list(map(int, cryptography_version.split('.'))) + except ValueError: + return + + if cryptography_version < [1, 3, 4]: + warning = 'Old version of cryptography ({}) may cause slowdown.'.format(cryptography_version) + warnings.warn(warning, RequestsDependencyWarning) + +# Check imported dependencies for compatibility. +try: + check_compatibility(urllib3.__version__, chardet.__version__) +except (AssertionError, ValueError): + warnings.warn("urllib3 ({}) or chardet ({}) doesn't match a supported " + "version!".format(urllib3.__version__, chardet.__version__), + RequestsDependencyWarning) + +# Attempt to enable urllib3's SNI support, if possible +from pip._internal.utils.compat import WINDOWS +if not WINDOWS: + try: + from pip._vendor.urllib3.contrib import pyopenssl + pyopenssl.inject_into_urllib3() + + # Check cryptography version + from cryptography import __version__ as cryptography_version + _check_cryptography(cryptography_version) + except ImportError: + pass + +# urllib3's DependencyWarnings should be silenced. +from pip._vendor.urllib3.exceptions import DependencyWarning +warnings.simplefilter('ignore', DependencyWarning) + +from .__version__ import __title__, __description__, __url__, __version__ +from .__version__ import __build__, __author__, __author_email__, __license__ +from .__version__ import __copyright__, __cake__ + +from . import utils +from . import packages +from .models import Request, Response, PreparedRequest +from .api import request, get, head, post, patch, put, delete, options +from .sessions import session, Session +from .status_codes import codes +from .exceptions import ( + RequestException, Timeout, URLRequired, + TooManyRedirects, HTTPError, ConnectionError, + FileModeWarning, ConnectTimeout, ReadTimeout +) + +# Set default logging handler to avoid "No handler found" warnings. +import logging +from logging import NullHandler + +logging.getLogger(__name__).addHandler(NullHandler()) + +# FileModeWarnings go off per the default. +warnings.simplefilter('default', FileModeWarning, append=True) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2930c2f009d16076c94bf2e904168344ee59afc2 GIT binary patch literal 3516 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/__version__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/__version__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3cb4d66194ed6d5e886216a4bba0f4753835bbb0 GIT binary patch literal 563 zcmZ8e&2AGh5O&i1Y_>!oI3OVo7Pm@dz1>5lAcR_Rsf2_o2p3;0H+Hh7Ua#x*t{T4s zZ-7*BqqiRVG&#ZxaN@v;*_5EdSTp+O8-3#$`@?t~Be0*>U-(T2q3>;S*MLKZ;MH>o z0#PJ7v?IE-D|YCP=+U0&)4mwcff&-Eh-f56bR^>UXm58NIeA{o%2(m>$;#)Y!N;@N z30{;AAJ+vpRT7@$-rE<1*iC)16(prwhC!BOS&}OBtc$|<jWkC39KVywhw!M7hiA8p zYl)2@KC*nCOAMm$^mS=hPAzkfvvhxo|B=`CV3}{9zv3U4pRO^0w|nt=#F$rJOUBms z856RaJ7v8p4G=@dYNrA0GS)~}-LjxKt(6wQ$BgkBR&;<L{Kc~1>W@mRxinSVe9YK< zI~$}Cr2GsDSID(vZNjgbSf?89C26=Li&6`?l}s<ll1&>|1d}a3rg?r50@Krj)7+(C zOG9SFDmzi8@?7glnjSQ(W*?d<yKxxah|-bmJCi%>BzCoqUKXXOwS3iYzx*MDUg!Vw E8~UcRZ2$lO literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/_internal_utils.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/_internal_utils.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2e9d27d16033013a9d9b4f79f32f5fe314d51fbd GIT binary patch literal 1333 zcmZ8h&5j&35VpH}erU3zRm6z{@{y6q%(6m}c7#x(5JC<_5xWsEmrhT+X4^@(yHj@0 zZjXi>AP<rpxgZX_1#i$-PP_mIPL$m<D5OTVT<&sJ`TIW4lcS@Uk^TMKoAm35u|J*j zwuR)}p<!k;Nw#E?%b?(8unfv@8J5v9;!M6LBRP1*mjgMJqgQM>l;d+YjkmwX2rn8i z*31&6Euc<|q_L_n@yq{N96!ctqa+yNJ}cXbb)z$@Ds6<#Q!7#gk&)MwAjKh9(TY_o zzTMY|uX2^;LP8B%ib@N(wg@Fq)Ecgw=Nk|?6g8j`ADf24Q$u;nI<?dIFHV=7hTTw^ zq;5~U_g9T7tkQ|G*oAHyq$X1;3n=bj4k0)0(eNl)wqut69N_Ve{TS#EZGd9OUWYsW zhLa!DI_lTEfKcMwKOU$JXpsu4p!B7vR?i@_p9qA@6lDR%h-xitTZ7xP4H70Pt!e}V z+NKUAiiic7$7-KPX>vhm3fRCQd7lP!R!LVYC8Q+movR!Wd>RcIl})joiHlrOIpcsg z;_msqhYv-geN(n72xcmQSIWT5ADj-lSQ({_O?3w7fI){=H}oZ;8~SSCQ1098#)oFQ zuxjit3~x~UKkd9mwMi|^H!057REj8@pIy%{ld}z$TYb8Ic9Q4U+ig;u-CpH*LUyU= z7xP-xw|oOdaqHyd_NLu@+PF<W5<*&5I6vre{*EqZb=w`=D(OLU#1l#rN3H9M4PrhF zB7P%?19ZEYQ_R8KdQ8JBVL^+763oN~Kk+T;;dLlU1)P1yByk@x8$FNlGtS)a2PVUF z_C1pksbaAG{YxOdmP&(AYl2)6N&m4}X%aO(2b<DO_pD@jifKk?%q;d?ENa>)9r2>s z-(>M_B3p?phwS-GeA5^!R&WUL8Jwb=LUd)t<JRV+vs3Yu5<czOUZ9iHLaeH)@CR@} z*S`4b(R6@AS|R<Vux@hK7(l1e`-m0d$Zg(y(%<O5QzG~eQ{Igajd~IE(~%25-UE=( z)AVofBiijb8BKV=i5EWMc$0P?O}TGlI_gGABC9M(x?%ssy%c*<y3Ra>{>)qD9M9-$ Wjz2Fe*%a`FQ?YUPiN+s<@$tVMD1XKP literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/adapters.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/adapters.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d108950e5098a2148a8ff002e4294242410148a8 GIT binary patch literal 16996 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 S6E}ln)lr=fe5r<BIQZ`Zd*rJC literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/api.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/api.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..dee26fded6fab7e56634952f7b9b9500654bb692 GIT binary patch literal 6520 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/auth.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/auth.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..94da14b5de3c934cd91a7b0547a718ed61c91c4b GIT binary patch literal 8342 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/certs.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/certs.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..986b45434b3edbf04eabcb01334d51f37005f31e GIT binary patch literal 646 zcmY*W!HU#C5bb1VbZFg^KTvoO2WFGe!@_`wiy#Q%LC4Epnx1qeX*cPP)txvq2NCuc z`~i>N{1vZr)RRBp!IPa#1TCnd>(N#9Ue%k^Q_h0@`ubUZix~USC;wU;k|)94y$}?; zWGYf|71i-&95FmmCs#4u#R<mO>^h2=n!IN7Y5Od+;)L&7blxQyl6U;Wf5!Q`)DCK^ z+6sZtw`3gn5}_f?kq8wi%w=17czOYS3!UpsdW21DRD}twOC$vCxHZ)dtU>tx@zc<v zf9GWDAsI`dk=d0jFyZ`p4m;a|4An<an*v^qY!`q@kt`s$1QK3o({4d&=Sgo`udRUr zucZmS6i3r(vZhAk7emub8puj%3LJ(93EJpmT@LSi#`ovo?Wj0RaM(x+vZ@^)8LD3J zD3bpSYiIN5Fdb?SGa+iJjSw&A)5A?6l+A=V+-Y=^hz^aiG;BMpiu%j-|Bb9M{FyeS zjsL=E7VshbwrRk+FgxuerMayXl1o?Hv=FO~>b-fGzg?E)cE1<Z>U>kuGFV~KbsFZK wY2&=Cs<Y+tyxVmT+8!KyB$EEUe>&VhX?BO%qvO3FPXY&bBZSGV+wm;=11Y1=;{X5v literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..011e358777fd5fb794472cdead1cc1bcaad1a030 GIT binary patch literal 1625 zcmZuxO>^5e5G6&4q9{u8_gC$PiJK-$Y)P>@nR=$v=}dCz!AWP5UU1=1A|$~92pRxY z%ZL7kUit%iY!96t`&)4B$=4ow=&1`*PSw=pVEJ|dtlk55^=+%=Tk!n#+fVV2b<6t0 zILnU%&Q~zxueN0+7P1mMsZg6$P{lUbp$>Aeb5TV#Tuba-E2+M#Aa{Xlfa}F74|&)X ze*$)CgZap3P1Ixo3RnxZSR1uj2X)vAT4Aebm93$*B72>#vvsu2HqZv!M4N02ZLw{% zUCeoOhwY->1&ckj2e}*cBeswBi<nOj*a12yaFc$_?xA}uL?OG6?z0Ezfo<VK^a+fI z_)~O<AE8J1G4A3gV+TDoXk0-@>F>DygDrl6%mF?A9}~m+LnXKDTC``_-KnZg`)q*r z3T6%ZY>Dy7d&V7LT(E@SUZJPU?B6p##1DZzSm0{dKY=fBAKU0Cao$+n)$2=N;L99K zC3_>zvRL`w|M&6zw^JfR#*>`la2lrx#WEx;<3fey7BVE1sCh`FgiPTOtM4#Q!*Awl z%G2;9ggySkIqms3rg*xxu8*d%NU(Z!Q-Q#ZDWh&f*DiCeu&(E63H;&{Wi*#MSOiP2 zkqe5`5l^u8Cs<{IUl9z8446m5c@|5lcb2^fr!yjW%5bXm*1vm}<K3F}AaNE833&nK zX^HEAFE~kyX_<jwZ5SkYEaC~s=@iSNsZv=)iBu4B&pBkFfV?+KkaY6(>uyzhFJemL zAqA1=ah5??x6gBBBDa3?H5`n<$xAX)U0<}}Xhg@D6=PP7X&6&8#x({S(-NLBYhb!H zv2L(wT+uWpFs20t$TUWrza#h}7F}EHnwTTD%>1@7J0|d%u18VAM^U7k8OeIl45tYf z!rYX0<Q$H9hJ_?NjYvA?x(W+~c8QF#`N`sYs;d{0r`m;6qGWg{*+Rt~Ebo+TltEz> z*-i?9w^AUzc3%{##D)>EX_hueoKieez*2r7u#gQxl+ev#PN*VjWSrV?uAqjX`bb$= z!&pLZn7h*sfvTxe4zM<+JXX4u<_rrmiqt%VT`gFECs-`ppk&%B%cs5Y7Tu<+rclJ5 z;TaeR-DfUE>I&hyv&6g?4@W;+;&UU*n7^}rCde#SxIc?Uf6So-h3ubQ^(WEUOt9<p zWPCB0POq-7BYO6HI28kUCTag|A8zuPq*6is9S;W2XY<*!+yslUxZ?ip-$B3Z?Orz5 z-WO%}e`$JDz64YCf{Isnoxlkio?Eq#oP9g6Js5$#<5cbP^=-f6+5_9nmG4HSobh1o EKX&2F?f?J) literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/cookies.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/cookies.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..427367b0de55a7cd68c861911b4e9afa9c13260d GIT binary patch literal 18847 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/exceptions.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/exceptions.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c52128003e01345d48bb0d006c93040170ebf6da GIT binary patch literal 5257 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/help.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/help.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8f5354706e01948997ec0b868bcddded34dc3fa5 GIT binary patch literal 2743 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/hooks.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/hooks.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..cbdbafa001a7f1a52bf0caa83173286fd20d1999 GIT binary patch literal 1005 zcmY*Y&u`N(6t?rLU0_HcBrXVr3sNW16b_R%O%sS6CJk*89hXT{=EZJmn#P&!hP6t$ zY-cX~1MJ8R{+(R;8{oi+XRp(`7rkfa^Ye?p?>Qe=S3?B$_vaP);~@0gyeu1F=nc4f z27#g@L~(|XFm<SViH;oVQ6EN^27T0N&3=WFolTh1syh^7q{1(EEDR5aTt#C+Cpn8s zDJo8xiu900DJjV*&$;FR41~1cheff-7K_wWX*TYL;oFMvoSZ@pyRaFCCnu7rQWT1v zoNR^>*dY|X!J>>6OcKp#G>~E(k!Vr58#e8mq!b9=F+=?wxOxDA0_97j(GI%6K-Jw( z@lvu$^}ze!>JbEvYIGdVag8(d%{lY>=m(M}tK&3Ix7YZrVuiMd4gW-3N?ySc<BG_5 zAacs2iZ{;VEZL~!cvid~eCiE{=d)RoZ>*mVWe+SX;={P)<x5^DP4fI@ueV-Jt5*{P zT2J6JRLJ<IEwL4>TTYvBi}F;bVq9*U1FHZ+fE;*c&nX*_Nv@OY<gHw!Bv;$r+Z`R; z_`3%Od;MDm*E1igG^=;^KQz@1b%bRbV(Oat!pv8VaC_kDJ%k#U0Y^r-?;zn7HZ!@a zAyRzd$QK}}#dgr~)45lBwKKrA`xVdq+NaKFMXuHU+&NpT9n+=R`VLnm(diIw6|uJ^ zGPJoUh@3{E05IdAQB-o4vPcXfN;K&<?IZ!td6Miy!`zJNrZpsrXe~QI<Br(0@vS(` ziWw5KsR>4(iOf{v8K?=ZdUj<=q=i0<L)nxkhWcX&$Z6vcd*A_X<NM$NmZmrR9j|F6 k2^DFQ$QA%rN4vCC+DI&I{r1-NAGU3jwvF}f1#Ua|54bo6_5c6? literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/models.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/models.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1e73be7fd9c11c30cd6277a69ecca05d674d9a05 GIT binary patch literal 23941 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 YKKMN+FL8TBjqDkDcJ#}}myOf^8@Sbg3IG5A literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/packages.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/packages.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..56c0d2688dfa58f1aed09e7fb75f09ab52278b5c GIT binary patch literal 515 zcmYjMJ#X7E5WSOZOH~siS!!hI?jfR@009gbL5EHmy0lpY6ar(OEhe-ilagv{HTpl2 zF<ZC(7p|T92Rd{LosS|9xOcpVJKnv^{rw0W{{Fn<zdV57yW%wluK4J}w2lM_RFH!3 zKEXGUqVNevkb2~kw?*o0fp7}cC%7JL(e<3C0R`mUc;<qF+mJlb8^Imw#HnwDzeRyR zydy}X-2??ku*;%P(FmrnN>+OUzrc9#$L)sCW8VgiR!Ux-+MW~zx4|suT2S5XRkDh+ zmI_ho*kathe=TTQHDqcNSA2HE7i8k`TkD&RvB9%q51wX8WG_mTWpY`Sy3R5?Q00s( zV|z-P+6K!~G>VM%-NQzv=DIfDWu04JQDKKoQE8gXwfoF9+=D)J*FVxf%_=QhUK4A% zX7f@B(uPgeY>`b`z3hsU`E`=#>#obx<m@WfiNm5`UzziBEDN_wspBL$Yd7tOW+y(z ivvc-hl>IkaZEQGwy7wI28D{7x?1vcQ&>!MEJirHBxS8t! literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/sessions.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/sessions.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9b21d801bfd4d6a22ecfe0bb1780072486e46406 GIT binary patch literal 19555 zcmeHvd2Ae4nqO6Qb#<}3**rv1k`K8oTO+kBk+MDGgCh%;CE3=Dhti7l96k0ln_We+ zn|<k3Q4)KLv%%0oCfRu7%m&FO@gLOQ-Yk;IB0z%8f!tUG$SyDl@<#y)f-H73&IM!< z43YtMoZs)gs_Jf%o=IjfSY)wH)T>voUcK|XzwhzQ@$tNd-*>+Gp!S!9ru{A-hJQ95 zUdHABoUUoER?%GDHClQ_mv^IL$a|)e!9CM5+u2H1*Id)hwybupl9PF>Ww*yFW9@t; z-!4=N?P8_a9<PkIOO=v*pKDFDCo7ZfsmfG)x-#89QaK{a?bb~DXys^owldp3Ryiii z##+bQCn_h}4^<wL&-vEF?MEt)$b6yoX!~U4Wc#toV{ND6$g*PV@%E|8srD0<C)!U| zo@}44oR;O|txvSiRL;nJsdctpu9Rhd0&SeDoNGT-d8&QBa=v|`a-ls}nQPBi=H>gz z*2VVIm8WHX3gdgG@{F!|M)O&BdeeAM7mNM8muY^o@~JOqokvW~du}t2($DA`|M2Gd z%BQ}hb&M}+9ScvH%BQ@-n(iKPXWr2(FUb5+cNX~<U(?)U?(ugt_qeyPo2h&n&nMi6 z@cfYXX*^$YA9f#kN2|Q#8cSOF(f-fog?DGm^8<g*_k6$6?c~3@@0ZUnZ!~<T-F3HG zp3@WEyA9X#otm?xK5)9LO|Kp}LDy;5I<<ArsdZeZ=Lx^z2afLrL8G&d`gPIu{j@vh zY`xpvY<T{8r?wSroM*%L@mQYAe@H-DEbGx&&}e(E*9vMM0*W-0OjK8EexqLHCsjWX zWh)v}?X()Jk=5|4z3peC!cF0N!gH@R>Oqv-60K&p(TQwidNtvDQSNiKUJrvRo6!;V zb+aa_Yogn(y8L9;yB~;JJ*dV*tOngGYD81F<F&dfhyEE9jki6q?j;q=nJ5?6i6(9d z58ZigQZRe%`m0yod}FzK`}(yTx36DauD)^Ob2paDMl|kvYqhObP~AYgJ{}u>uNKrd z<TGYHiT*papmEpZoH_7JG=Z{BZ@YT8)~dF!(9uNNh*!hx(M;0ct(&)(moV4K<!<+L zwa)f!&us|o7^>Xp;QNNVRNwI0wP@z*##U$3bFX*mT^HS47osar+U*2hC%EPfm10y! zuGW0-M#uL$euHD<YNNRD`ttIvD{ie9c-)=>;j0^X)h*G8j;wn@)$81Ch;FAEZ+KK< zVaE%E+Scf(ztP=lxz*L}Ud_jbD!7QISWWJ`+$d}&+rHQ6pk~+IM$cJ{4*;Y`rF4at zmai<|h_a~l>@)QY;VS-FxSP1H;_`b)LQtknTNFcWNee-(kUt*kOIm<8fxc^q^T=t; z`4?p!BQQdJ7k@jMFteAzleVir(1GEGn|Vh=nfXAwhO!+qG_PrI=XbJUCd|I1-B}4U zz&*47?Q0&^sNLugn|hdMPc&+Qm!OQZ))m0Abu4Yi;VJ@4&pSbF6FcKHIzYEtz24pG z1bGL)V8e5~`@L49-bj(o>2^?F3kF{kGg&jnN;DHcO4OfoZmc;q*<4zIh)$#cWvGd5 z^uOV4JNFu`mb2<P68O<#7kjhe31`da*j8A-T5n<ZR%By~b)s+b<2G>VmvH%yAX&%4 zzCH7nv7_%8q2X#+dNb7jqH)Ju(mv1^KhOZ~#@xk7-;DIT;w-+9$#=y(7VIuoZ2oRd z%&&D@1pE0H@6WGSU%V^Y{mwIM&5Iiw_xt^7>&53*H^fE!);sgd^SwszLZjmcwN~rG z#f#6~-M;(u77OK7#d^D4F&{6vKOYlDf3CM3<u4K0>fLtl@(qrkaAe`n*7}btQV_4) z+@)5xUTgW6kx9NNXQO-rON5R)bx)9kilay(YpdsC9#OUtcx@k8GZA-Qja!Q*;z6VZ z`N1MbCAAOfyRlBU<B>Y}Q3mN?$;5f~7SpV_>8DZTpG2Zrwr(1@O#36lu)k-Rrcu;O z=Cp3>wjrKJjS&<|_VFqkco~U8A%8a1_kaWs^mT315DyIyiik7x=93b=^bp^L#x7AJ z)BoTWu)q_oZ3SAsv)T<d67U5m0(|3za3rmq%S!;03<^A|<JG~F0H*-XdTq=1oO>Gs z<Wc0+dFdtRC(j7a?{z`D&MY`zetSoPwQNbQq_Zl#+NPf}IN6m05(u){+MZJ|9ob16 zpx_xGfLtMf>UgquF*Q$iPCklfu~7Rrq@W;2R=CC0l(LmIi|ybgE}^WBYvf1Bdl{F1 z8HuMsveJ}P1@4}4Gp>od=}x+~I|jKR>*n18N-VeNj^mzlOYQ{jwrgSGr=po9#mp1l z@VUnQMyGC|>Ey@l<|VhAa1`oI%mgVY=Lu~G^iZ4(jlB%F9#1AvIkO8X!vz|bv;F69 zV{<^uNKkIat3QWauq8Sy1E-W+$$9hk4F{BOWn~diys{G6L?qIm$ZFx<c{(z;g0&YG zflUQ4{N%eRx1kuH;L1dnM<(Wp89ZQ9Oy6s*MJBgQaKZL(f#gg{Q`MjbrXJK#&o3g; zY)jAQOg)dk{@KG;YL3il-{&L9LU}mlH-8Ne<SXPIxEqp3WSV+tHucSna9r@6Fw-<# z0|@j6a@fyJ3po>IrYtj2mSq|Dk2UZvvzZ}}X&S7DycL*x^4ZNjFx=dlv6Ble{~NM) z4&Q!*--I$JTgmo*E+jPA{a3;3A><KzBwfD(ajPpDeYp*eT4zVGX|e&~wYzscH$gVF zkKhE$k+~5By|VEkp?WdO^2sk7jlU0mu=wg?*%D)T5!oAEKj_rjUS#={M7+rCbwwbK z;iY&HN!b?HSTP404?&_8<vQLynaQ(6N_B3OXJMQ#);DUMbr0{*P*h5u;^vEqtR%Zh zIf^2WQ?dL(QL85<j=SjFe-eoX@@VTt-OSGDAd<WcGgCy#v|fsz`ky!yKn^te>f&;p zvrm2mRO0<6F24fITi15-B$y$jik(6LBH09_G&4KJu<)KCJ`Y@jgt0Ro=CR9C@(A<P zs{XWb0^d}vejd09O$r*tSyKz_U@XY5Wj6CdD6Il-3(X=a#k;z$DeWQ{N2#?7qTDQP zX2o9)CfqFZvuM$^-Zj3agSbyVfKCz?_ND+=y7=c9na+{zlw3QQ4ol4=_`a}a%xZGf z1-zLECjhTwfZT6~MO+ijnXu^Q-^H6wk?+L+WQv(h>>b6N3V51*PxohoV{AJ(9-@_9 zW2exuRUR!*vn(91Lhjl-5n|jA42()|J`_CMd<55{YsO{{I#kOo>`aD}kicekro!>& z$-T$IDbOg?eow!1%Qeu3!}6VJtk|?$e2FVIixqoZ>R{hcs}--$Db#!-gyh#O>}GT= zcv3!V&C|Q=eSGf|e5MqLQJul4fO)_=ZSQP4!trJqcs=%>-u(l2Je=ON-qU-3;Fg%% zIT9Yh&KkkFaD10-j6)!@Q8E)6pU0Zt0W)nr6&h<gBuO*OhE|xv{!P4Zg=2rk_!)gi z4^E-RY4)YYH-Mi|S1m}rZ?gZ&51_{DUdI!)0Cc#!mXd3qboq9oFA8#l#aAhByHpLR z1xZDrKYRUt-Gk!hI;Z`VuKROkUA%x#`o{cxKYQ9=IPFK&>FhO8TW^EAmNVZi#k$6Y zH@wbzu+c9j&&%6A@4HjWqSo=(JaHk>P$EmIV&aQvSbPZygeMD_>($y(j_PA~D~PPS zo@lIXM<#?WD1?bdF#++fdoLy1e)+t3mCZ<+lmVF$U%(^2>O%0dAfZDp1ebv{*A?4Q zE}pG;h~GTSn#J3Y#?hzJn=+zyj~u7wMwyn^f!I~MKj=&x=NH*}s|$rR4~b9&{=G)9 zAsLqVEMMBF-D}nAAd6rxBzqRrBydAPZXzhNMJ3^_ZZ$vy+o054H!7f|V9Uo=fcKGP zMbi)|LFOP7rJYC9kg=evW6jet@d_(vdfi@RQlE<K&wAT(B7!UsgNc=4QQ{+JFSYk* zqNmi{<TXWCHKJshi%9{Mx2PnwHIQX0joprTf~|o&cii%fB=X|A90-Ic@nz)1TTI?& z@)agkBvEO*;bG3PpyfxUn$kC`oA<!EeXt#Dk|6(%rZB#{jV_iX0kdc_9&*}1R8U-_ zD&!)^ETq)if)wCZW3eK#R7Ncn>=;x%YpX49zbG*UA*0)ZuAayP{$IdA{CALO5UKOv z7M5<CdA(#95GZE!8DmnP&e$1>7r29ylu!e8vbH{L*hbzcW@Zc%oM&3M3`^%%le(3i zM7<)pk5$wszh_wZB4gq`Qr!S&GEg)A``@N*{4c98i9SAtKOGqKi1<R0%EWaQmwy`x z2#f~B7sB6;>4F?VoHz$!1O2Tj1(^p1o?+a3352j|iWh=xXzuDAh%^vUvLt|F5v;@t zvr1)_(*K8FptQc~QHe|zk75NB%^H->T1Oh0Bwv<BBTD2-G<0Yapl&K<a|gc|HfWWq z-R(A9rv;Io4cE~!KZI^J=P1jTL>;QsUaQpr<qM#HD4E7j+oS3MT<$@`rU(mA9_k%( zl7MLp_N@j0V$kQHF9&$;E6stUi^fMps>O0nf|UeWv5fVNa`6OU1QT1nw3-NqFNz7m zaSV{4uAxxuG9hstG!xkrhgfMJfQp|)J#Z7vpJXNrP&1BatPJ(MywQLBQ1N9Lhese| z98HiMNyzxO$UyAZvAf04=ok&C1;da6BMG1Yj6NF+FBa~A1_(I0zyeDHJA2pIu>mtV z5r(!O26kFH7LGyC$uf1#2VnOQkMgKx?Tw){PlgU*g^>8?0C_O9^k;%RSY-ADj4-e+ z6n2WrxEd571pTIB>#n8VDE1x}#J3=zd@F#66&805wsT37LUFG4O)S|kya?}t2kY4u z6n9@*QAqH%9k7M9#`+eRC&-(#DhqrF)3n=-Kxk|SBj<Bqz-W+`03>080l?P)PeUj` zD28J623iL%15T`Nr;xdLvwG|H%`blGJik-O0pOJO)P19wb8b?czt`|RRoM%ib^}1$ zSx;M2lc4QD+MfcNe%bL^n2PE!_{9bw!n^FNCkKPkC3H4zDH%R2x@p<)`T+sEn4{!y zY5{L?0WXYTMxty;3`?6y_57ix7eoLVVL=+J(u#|~g03_nZhxQ)(%~oruHQd$NLOWJ zaj`r;Kp-gxNKPzP@u5^i#N*8Uc_xpsu{?|@u`VG_v6QNUAf-f01I#4T8fsW__kz?` zlyOsytT<%x+>R#p+ex!>YhcFqJt37PoA%LrUE%IW@IJbmA%dSnMk|6>;4d%HyNG+y zm<Bf~LYJ|?BWB2NkS`hiC%-T1vwP6K5$xwop{gkCrwkTjyV2AGZ~_SYC&>k%)Sd+8 z&wx9yoGR>dartvY<yn+3qMY9?%5rd+YGOe6+W!@IP@0~^M<o(bfF(Y}^fUzxI1&K5 zKv4>XH9)uD^XgK<T@~GXSYt4vjT%G;F+{e_*RNl>7G++$4%PP7&820iu#u(u5qB_s zC321Vo>zt8$`es`4HjBA%1Q;fY!1PMq}K2An^FB!&>H<xN}f$CGXs-cd>Q>GzV9BX zp_DBsmx~b1#~`-BbI|sx)hJ)BDi;p&#cK7=R;{JpD4~~3NBmhPWDkNMBu6qdIyp{S ze#A>i2-E&765Ftk+9$|R<nN>W9ec(u%R2SAEWJ^7d>NPj+eijRD;TU`ETa3*wcH#{ zRy0@9ROOb|$6>~ra3^7`%DPkTv@~MT@kJvRonACzJujVHdSxtjZ{^)b-II7za36CW z+>7oD?&Iz$7{bQg7u_e^Cy^_;3+`$66Ua@tXWX->HR+b!bGT2rPr2uDpLQ>}bGRRI z=iQ6A&$v&!&)|O4eb)UX?z8Tv+~;sV<{pFm^64lS?@jGbVKJ_xno?r2jENOUkMf`? z5jydd!CnQb4DJEqM%Hnm*X_1Inc*LU=rO`o;)Y(KE6jP*hs$kYA)&FCFJE>V6!=rC ze<H*1jqkjaAc8*^kM?Xi#tB)0maMa9q@iYEexCQ$MrW=o*5~o!Oj7kyV!?C1{LICR zZ(mlu--N${raTNbfD0{l2a3_bQOP-E4E)kx7#a!1B>#sT4Zl_N_CDY&GNlwGHHWM+ z%36@|Yi)m^S41}W*O~{XTV%(|gs=1uN$i_wX2gj>XeaTzipz%s9QM3jh`Lo+VUa@c zL7E9nS(cSg7Q|$&nuEPTtJ<;_>@mm}WJxg?Z$M1Jb19gRUrj=so^mt6^sYwHMn0Lz zlMC-jIlK7ka^Ft2s-I&HdsaRoh?Z*pzsQ_qKhw<p5|dwMB6X{QS~bNo&QdYA0&`qD zkz?|!NJzt=-ik+&2QQV(ZIp76*fctg0EC9*i>@6lYnxWq%GkK@XId7oyi{`flQ96! zC7&HwVXm@VVJ<Zt3E~VgiX{D7noH?YG**Ro5k9qQ^%pq;awbjhPYwEs-;Q*|TD)Gv zCC$B9YK<l?F0$+ph6`Hd%7&aZzzI6$5M3lm<lMdcocpf~^*l5~^>W0bPNj<Cvz*~? zAVcQavne#w+D8ToZ{tZ?(qTh0f-L?l!bVerXllS7Mg=Sf|Dx8k#qH4aZ&PsgZwF&2 z&(o?L6m~T#T+Jd%#`j7O*az)`6SyXEO~H<)H;>@EBf*TTzYBQ7^HDq>-8GPB+c^rt z0o*#xV|Y5Y3nlK|JRmYlrLFeUnD14%QlO^5r3~y}ke<JVm0P3!Z|Bm!g3BwEFk_5| z1CzELDUE_BD{V`;1{wkNH1FfuU2!%@I^r;cv^nJxOZCF^>)XnF<$!`ok19ryIOJrn zu%h^0EHk8yB~yw4X=PaKl$0bPXbb!M8EPFeJZKE6!>&#mNYOg&K~g*Af;lso%|P-< zq}y1E@#pp}X4(*7l`f`oUP#%ZhCGCj22_j4gpaWnnN1&Nmse1(2!W&!64gl@%EuMj z&+&bhACD;u+h=M*NUA^<E(o?leksYL!$)={s8Z6xCg&-K5M{SuITPY<@%1;E{B0(5 zC#q49PN<<=Vor`CR%?Hn1(Jj(F3!XV#l9oGw;u~rYgD{WzeZ%dh`L%n4@-%iG4!Hl zd}NvyEGT){N@!Iv<G)E*X7aF@6u)B?`^OTZ5zi$tHo<C7TABPvX^Xfd4hP84ud}BE z&kQJ~xzOy*fcj5{ncgF~+fYY~z_L6n(KMD!LGgthyY~WczJQWUINda%dX9&saN<E0 z_TVwt^o{q8otbb3%I^_nS#Db4G;F{#u=pMgk4h}m?T^92gYeE!8@WBcgHQqGQth~W z7=T;imP-IXW%nuL2i~Z-pM$udgwO@JaA}f^)kqJ{*?R}EBWZ*1&)<SVC)nW@q}s_C z2ukn&FCQ!3zTlkg_9#fzT4m>28o@vl_Ug7&*}L>z!SWb@0?1B45X3;Q=5VOuLTyh* zF<1^sJ3t3miNAQ<#ITR)_`Jh707+T4dO*kXY8dA^AmZnRR%3HuzG9ndZD>uRc{CX$ zjkAeP^8?32Tpt+^3%*Z_>3rmzVnQB+(81ZpmeG+8hF5ycVJwjIy7J4W-Nw{!bh1Bi zDlz6C=#1-^lBoS__QQ20$>o8L2ug@7fI7Lda)wo?J|TV}-MkBG!~7K$^};3OkHFJL zbXNm#86b)Prg_2?fS_A*4?qw_)se1g4sim43}=dvk`@g`TuclAxsffCD#83U7%}}| z{wnN-u!_n(U@Hguiv1%a-M!wu2U{ggRb5zIK_C*?heiz3Q?iL8y%OqyOQ`8FTuIFi zdJCn2HOvxWOBgyN1BloQD+v6PI*t=}e}1Gb`b&~GW#>{{#|OEQYcMnintPI(*ah~( zZe+Ez$rvy9d3r`>yaX#4Cc7-QJeuobbI$&b4z#ce^=yAPv591)`5}a8!+gxeLA9V; z@3uJHG!H_YHb<~YeBvA%DIkq-u_=Sy#9=6`8P5^43SO^~zF{?^6@pDP+6bj&co}Tl zZuee?z$e><;a^6=jC3wFxDEubYbr7k_PH*={#DrQ5Rx&pHi}#;|Jq2`*CFDdXTSy4 z$*XnFlYZUXXw)~984-}hPDHomr(p)LU#gZy#=^-f;Dcne{Kk?r*fiE?`G>+R0ZWnT zL%L`K1xV##o~#8Mqs`K!di9F43j2)0Cm7cDPnbY)$b4xs8kucl%~_JH0?ZX1akYHE z<<#LU0DEC|NhX}Lb3LyOgDAHx`N813O!PkQoIS&uXU;okV1GSRMpKO;<I@2VFk#AR zYr{gHlCAa$T~hPgC-51{!?pt11zv~=+{E8u@^_I$52?tcAyah{WacY*Z=O|mkd$YY zN|;KWN~DtlpA<Hwh$+V-2k;g@Twx-$Q%ZgNby6uOeibhe4g!fKvJ)X6UQRH?*x4uj zh5O_{LBa7`l>MGV28tW(pUM-)dz^=qmxp%^(jU}6`S+1&q1N{->6`0MBobgOOOEJn z88mC+`YbM~>B5nLs8JPH04)ho?V-K~E$wFz%Y#_Y-&?|nNe^K<Oq7K|^wWU(DO~(` z+3H6UjNUr;);Z-NU2ty3vJpHD>s$0e&;$<(y0Q{acLfx;wh50!3SK`L0Of`*3&uBn zV2E$vCU@e4jDihn2$7{muz$xG=5qpSxX)G9?4sT;B<l~u(~q?FA0}&m^Vaf>n~O_- z+}A(K#S<0(081(UA(MTUnw%1i{U=9OJcao9?T@tTzn`o+P3C{hm;6=nSGmX^yWA!v z<@u4dE+){;S9J;WXo5d#-Ml1eVQ>k^2}p|~C-9Cy9Slu|`$)y_w?O5Rm8M7Hk8Gv? ze^-4D=%z!2Pf0mHe)9R(vD>gRrdATzS;@)D*#Z3=ycGWkul6H00w?`ofslqv(+d3* z&iLYh?=EFw$5D9zXD~?{4McUMP_{J;WpDlokR>wrj~yhU%&j+<)t>)TY|#g?2a%jq zl^zBJnci0LS_%XC0VhTI4-EqMhC$%U^3~V>gwn){*N-0vvbVV4127Q(g8RRZr)TAv zv8ADXA5VCUd~<-CQ-+mHW)hhJ^2ai((f@YBSFT-u<NEUTKeGM)@vpC?W+;eahssM9 zP9fs3RyAE*yI)EcSG^ip-6SYVu5KTQqqGC+1=5#CT>*Z;ri?<C?=pDGr0?i;G5LhB zIUPP9LwqL4x!GME@z=&4&TKHEpWzgHV=kk^aa^j&^JQAIfLzhF5m{{o<M90;;=fsf z=z#BFEw)(}=8kJSW5Gl?=8nCqhjw)`m~!*5R@-Z6k+nj*IgLOlq==fH-N^^^56y&m z_=WP#S;jrz`OUZt->VYTI0pN6tn=&?!VF@sEjsaW7Ouc^a2*2??ZvQ&@^fKv?>M5L zZ8_uOo{gAqJ1k->)BMhF_D=;T1});ON)GJEAUlGO)UG}hM`%ARBeXY$BeX*k-`~Zk zaJDzJAtFumZxD{5da09ix0LZaIhHwWzK$b^Vg<;bJD_0i*HEdt_MiAtcMCR+4q{1Q zTk+Y~zCQdpr5M3CL&A-i=bVp-X()s;X77MEl87l!#}P5*={S1_@}D{pH$Zzx3T0F{ zQ~|z#7w;2V$>A-ixBcWa(;P>5*y%JJ3qWH(g{1tb(%ts?h^3+~9YeGdMETDn_)Wz+ z3wl0OfD{$^r~s9%8oSZulx3JO0=E$phJ%6K`lhrQ2n-P3BCl2JAr?m*VIwXRdQ_Aj zisFx0XTsPNobbh&EyQq}9mE$zSsWY1ZG0){_HMxKD?{#thl)w`mHb??$Q8CBCnQIh zi$@n_W$1OJ3-LRwaUBUyb9K}}MoFw3bc3t<3aV*22I}Gu<^mherMzxsO7L=*5M*1- zOd^NiUSkqDL{}Oz+$uxU!zl*u!u4bs1L2H&Ql~#S`Q?$x;<}2<|8*q522FJ0;L78` zeA*fqP)kflkY#Ae(8*kw+sp9WsXS0=?~I|Q3A`L5rro(1nm9jX`=7_1CtN#0wrQay z1mX5tao!?533BjX!K(}(vw=LR(-{5D$dfkZk!KxAagaxFFY4oTtDAe@1kTz0ucTIk zs~cW@Q(78_tVq)Bq|VyG5Gbwmez#3KpE@mm2v)jq;iQc&%7{7f9u{Ufn!bJgC*Hii zw7gWkdZqfxn~T@pxE__R!d^OfM&y-@b&wz|q2Md{v|Lot4zxYUcs_BFIod5Eqw51Q z)lp^TtQ>qRo01LWhXnIO-mAF20-8yVF^hBT;VCBjVC(Op>^BHo4l-KK!qGp3bpyJj zTk<2r<S`@s0dkCw`lk}^^YI3{5spMMkiyetJP@Afrv#*&LI|vkCD=0_&<APoj*~t4 zFk>JLVoAG`4;bXF&w`474RA-rv;Wm}GZJSZ4Yjavr{|bsJ3qr<V{A*E35pbBiw@c7 zl>8=fICJo7cvn<}f7)sP++ueqS}N%Q#$<-3%BVZp+nLk;85|XqAuMuxqbv@6fD*N^ z2;u~iBr1=jIkI4BTx;AH|Aue(?a;qQ+3#?NY-BWR+L+e!nf{SvCx&R=p%h)B@+0_i zXz7cj>s)RiCk}66VU7M%S9vA`wnCh-PL@F83&R|?U_Vy|ad~2Uv7AxCITj<4J%2b( z<xnWwMF0Peb09!yMoI6dLZUp1GNK+3U|5g*NFFnlL_zzyc1im)+L}&t=R1tm1`r|G z1jpc|xIh8{&<YWw&0J_+((asc)sgpmx4m_EL2*vokzrzStXncq+RbGoF}7d`GUC0* zH`rPqp=}7<gf{_){p+Bc^r#>R7S0BEZ`Af7*q_IT1{(Z<4dK+tZzQ%!7JD40r{KHa zMf!D2XA@z(BP<upyMYf9rb|4Adj9WmQ*d&gIkMevb9qV2$#y4kE<6Dc89#Lx=Uqgj zzsk?aMiXUUwoEXLij2nQ|Da$Hsh~w$_4pr{lihxR+<#0VGfTc>5ACe%_`niySLM!9 z_aE%%*OUDOWD?Ow5AUNBEr(049gS0rZF_r~V9a&HDM4*F^Rx2kejGX#<$xHq0RO8) zi7N=7!h;xuZ*c}VS5Nvb&(;6;;q`;yk{q~2m>62(`6h(34lQH)A>=9qfU$MIT19Wy z*f9A!;7y{k>{E7!0N6oW|BW3=d_XXCKRF3K(%r|?(o^UJD2#xynCFs90`SQXrKD^R z!pICofFS&-1&NjU-$xVTcjaIu7OTO^5hsJi7xBdZ$6&CNBZD1ODVG-24>7>}$-s6U z|4?NS(LH<Y>;aRXXOFpR)$P`+Rq=Z)`WsAsoyp&1LKl!UKq=AgAM^2_F!^Up{w0&& zV)Cz;&<P~S#02T2Bt(L6DgG0a|I9>AX^?Po;unxCL-O=jkU=cYk=PfbJTiLvq#J)| zTK4lc&Pmy2R8>EGD1XUa)BZ63nqA;uemq~y7wx=#!+z8*;Vf0bHf3-1_?z^`kFVmA zNXs}*fW2O;pjdL7guM+S+hT;4@oP!2>jm|{Z|F&hDc9T_C=}=s{gm#)g7fs;#kq?~ zn6876HvUr`6(Yk3wp9;jp9UW|IF(VC{!so?9`&*00{BWQ8k=5EI_Fc4xLT{zwE`~_ z(Fn5eYNOQ%w&$Eh1m5sGU~*y`e$Ld``PG!$g5|KMG%R=!!~mj<gG`u(Q-gpeYb7VA za4ZYn)#Us)+(&TuZy{{Yb6^hk;)O{3M)9)A0fU<U0+#$Rkf3rTJNXVl9Ty_3#D7Iv zzAXL=zlo4U86W@M!en?rWV0{kq&}g-(umHHr4~ZQvC01mprToAHZsN}&*VOn0+S+> zaV89MLtsA^t>r79C{-~r#pIWmOfw-7#J?os!7-f3XjQj@2CC1nG^_Ib?;a`|_ZUm_ z9uCGz$D1$De@gjd=m06sfij8`>*otf3W_T{%G^mNk1=tWJkI14lP8cwMN)_O*rzX^ zWcg{9+c;elATFbgV`H9J!y!$C@Iv_cZN4mB0jX@PZUst-tMD)?G_&XV^(9uYR6vUi z<yYIqZ8&t#>`Ur!!Q~8U_%9<db37}L)AINyB94CCn1L``1c5!y6N`qE#mPnF)LF)o TVP%Ss6(=TtO1q1Tf2aQs@fECl literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/status_codes.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/status_codes.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0f5b5152f8159932eddc9f5f446c77a9d6a4b625 GIT binary patch literal 4201 zcmaJ^U2q&n5#HVV(di^vk}dxvV6p)lqhRUeACfp2C4dtG2_{uGJUC9RR@-xTYwhi< zXZQ4TCG+A`krV_-0to>JWUBZH1qD^SQM>>z{6iIQ^BA7|3<NNR!`HL-=SbwP_S>26 znV#;R?w;9CPfS!T{NDJ<b^q=u%la#KhJO#E^AMi&X8^K%i)?ZtyX9PPY>Nt1q!N{B zgeo*jRT`slnxI`YNmDdUyJ-*2&|ca{`{@APL3h$S=$&+s-bHtjOLx<|={<Ca4%2(- z2)&PH=^lDN9i=&%ry4ELF*;5s=p=oB?xp+aemX@D&<E)>eTWw6L3)TjOdp|-(iwV~ z9-)t2J9D8R9D0;K{+xZGNS~m`p0+NOMCqypEgwH;&3@AVi)~re^G)F{Ed`Q9y0qlV z<x3*SToUy#7OCsIEk8-ZxZ&27Y`KAKwPftZeha+1RPLka&p+X&nV+>&kybP5W=#<) zH*U9t3IjjF49Gp|`avMlG+d5^D?*G>t`Ff^ro!cR23ZgV0);^q%Gg&M)i4vSbiP_$ zTwHXOxZD<Lmd+btPaXj)kqV<cB`8$T_sCP#6ASn4FnB%_ej>B#$z%8Lz<u(_MOnk# z;|mMb>N(jGxw>xCUlnev9c5txg^jf^AtrZOW=*%9Btp%Zek9k>4E$8Mt3svF9j4T) zFtF<*UkTTbco@yQkHAW??zbTHXwT*Ia%E|0(EHS5+{04U?v{Y>Z(v^_1j;ET(nLa$ z+|$GEH>$g^WWIU>+iK0)y85`3EA8YAyoz2WkZ~5qZGrZlbS=z+Cic}!l+0uxqm(D0 zWA-U-a4%?zU?q`ZoXt9VysbhnlhTW1+|V=KJ@JOAvm@G(E4s)k>oPR<(5vKcP)w^K zC3OmLd%FN7U%&Pu78(hZ@H0VZRya@+ZaaEkEMw1aXHBU>L|C{gyfCgyeQ;;GYGI6w zS@BqUY^*SfPrzp)>k)LxbRm8+@l_W3QJ*u?CCnD}xY>L!4{SZz3xytGY`_lnuG_dF z)}Qht7(^VNh|}D#k+9_<N7%-x{)C_@L->2Ppr>1MRgj0kYWXqrjy813kl0sqm{h9E zcFbNGO@;6fhC=C*d4V||%gk#@3hSX+VH7Lz#;$KLGvDiOzo2(-Pai!wpqW+mXrBP( zcK6llC!C&!8<FJL5!3_(bS88;Cqc)tWuGwAWUVfs!)mnS?p}7x?oK8CMhljjaY$m) z@V}v8@F;4_a!4d%wwSFm=64EnaE7CIw*;bsJZ5yWOOFk8AYqs3nqcx#bzsFo;}8>2 zSQf>Jqh+u<$Nu_;Ve6SedoUF1PWGZc3tK|AGd<F6U_nl=dX%SHu_0qlv&l%rjjY*U z1S0k%s8`6~(5znf!w8m-4-+x(KyMvhJ=@6B&Q}eVxwpsbXP#jc^uBhSqBNO+^I9m3 zzL#wzLQij_>*|0F$K2JGi1<@}+z`gCDcqCRL-t+Y?A`$Au+umww_B_yD95>LbK|hU z7-ApFm`be6-S<T3`2#ZM?rDW-Ud?%(Jb2)+nRblb;Ht#Bc)3UP#BEf}E=Mw0F@ZIm zuj`RWM2rXuHgt8+&Lv7k0wIUgk0R)cK+vP@xJ$*5sdmy(K8gO$>5(o4%)P_A)gPfA z<f7~7X|9n-V$S~j*wU3A3GDq%R0g3uWNJj|U}yEzTPYZfn1&Rt_^HrElsy4rRf!Bo z9}0Mriy7J=9$L=r_m-IxlUz$Zlrwm%Ti_Hbyq?}h!qkIE%vHppaWC@Di$nvHP{C5H zt0!*jasUQV2)SMmNz}8Rl_;8faZm^qV{R%Gjzdo<B^Bz=P_I*{$&206|1yM4a+-!* zK)4o|;$@0Q1Lwh-&z9}s>8O(4keYgIsKZja!@XWQI{MCLmL*>IP|hQ|mmGS0n1|{6 zSA7-wFv*Wn>BXWUaW3Fi0@h53q^j4$z?ht7xON~59erRKXY^V~NbV?Xg_$ST10e{x zJlf}Ax+%<J9VZc3oNBSi)}&hbzg1{_cmPho9f!}Jxj_iF8-k(E&|v5={F>o648LXg z9mDS#{=o1@hCea<nc;OncoesVaE@V~p~kSlaE#$N!wH6y3}0q=p5X<C7a6|7@KuJF z7+z-h8pA6LUuXCR!!?Fi8NSKzEru<I>kQv!_zuH&8NSExeTLT<e!%cUh95EfnBnIP zzhL+!!><_r#_)HBe=xkk@K1(+G5nk1Cc}Ri{>yNS;Y|Pn)!buI6mVt5<`wzk7r;gR zA75F@c=(-u7LZw6_I2xw_0;_roh#NAd(%eyo-0n~WQ9#<)4E!)txadENcMF*oyn<N zrR!GCxjb{ZLJk$4ww|@JGFdC5Y8CI|ev67*BcHSCHh)PxUCAn$brq7YLdt$CcJR%C z(YV2noSk)U+81xywEzb6e-2tDJm>JFhX7=6S@}Yly=mP6g;~@Un~Iy(rd@aTv9QwF zj&s!ACdk;zg7yJ6t*3Tj8Yb<tK7;Rw%MRI?>U7FWONa6KaP~DWfzJGbwqx}SCK$N6 zT1!;8ij=A$(`t1Yp#rA0Q|q;ccWPC&I`Q%PrG;j5z0>icQ}-@6)dGHvxOTplgvlII z5LGOiTUfYvbz}8dn~CN@dZW^*TCdR7hBt6N+0dh>8zRP$q!tslpa>{hj@3DgYfG5T zpGM6@$}i573<jP4oKEE)_b@%+9!_CX@e=OAy4(#8^f^j&$$T3OELES!61o6+vbUgR zAFw;Sw=bye>W;oX!4n6*eg?k2YIl9j+hm_L%gs9KS&UR)0=#Cc=ecbh&KjsM0NQv4 zCLef<27N1MN7WZGQkTpZmma}gnZL_)$)tg<!lx?ZD<n=E^W~#QJP!tXo_dbwmDBu+ zTQI8Ncn`Bkq`G9@xk@i$T<)2Y(W1$k9ROJNlwGmM?W#TFR7T3TD)yak79Ho7dKJ90 zvt{)P-mHRZ2U!~@q2kas`l^?>#p8y&-*<qnoW^yy9f?H~zAs={aeBPu*l+VMY~vNT WQQmI;PQ2|hdDKtKPgI@C)c*iH0YfPO literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/structures.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/structures.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1949a43c243c41f04fac00ab8c50e96ef54fa9d5 GIT binary patch literal 4443 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/utils.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__pycache__/utils.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..84910c6b3cded79df3faf1b0ffab3a7c0c597077 GIT binary patch literal 22212 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__version__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__version__.py new file mode 100644 index 0000000..9844f74 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/__version__.py @@ -0,0 +1,14 @@ +# .-. .-. .-. . . .-. .-. .-. .-. +# |( |- |.| | | |- `-. | `-. +# ' ' `-' `-`.`-' `-' `-' ' `-' + +__title__ = 'requests' +__description__ = 'Python HTTP for Humans.' +__url__ = 'http://python-requests.org' +__version__ = '2.22.0' +__build__ = 0x022200 +__author__ = 'Kenneth Reitz' +__author_email__ = 'me@kennethreitz.org' +__license__ = 'Apache 2.0' +__copyright__ = 'Copyright 2019 Kenneth Reitz' +__cake__ = u'\u2728 \U0001f370 \u2728' diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/_internal_utils.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/_internal_utils.py new file mode 100644 index 0000000..759d9a5 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/_internal_utils.py @@ -0,0 +1,42 @@ +# -*- coding: utf-8 -*- + +""" +requests._internal_utils +~~~~~~~~~~~~~~ + +Provides utility functions that are consumed internally by Requests +which depend on extremely few external helpers (such as compat) +""" + +from .compat import is_py2, builtin_str, str + + +def to_native_string(string, encoding='ascii'): + """Given a string object, regardless of type, returns a representation of + that string in the native string type, encoding and decoding where + necessary. This assumes ASCII unless told otherwise. + """ + if isinstance(string, builtin_str): + out = string + else: + if is_py2: + out = string.encode(encoding) + else: + out = string.decode(encoding) + + return out + + +def unicode_is_ascii(u_string): + """Determine if unicode string only contains ASCII characters. + + :param str u_string: unicode string to check. Must be unicode + and not Python 2 `str`. + :rtype: bool + """ + assert isinstance(u_string, str) + try: + u_string.encode('ascii') + return True + except UnicodeEncodeError: + return False diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/adapters.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/adapters.py new file mode 100644 index 0000000..c30e7c9 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/adapters.py @@ -0,0 +1,533 @@ +# -*- coding: utf-8 -*- + +""" +requests.adapters +~~~~~~~~~~~~~~~~~ + +This module contains the transport adapters that Requests uses to define +and maintain connections. +""" + +import os.path +import socket + +from pip._vendor.urllib3.poolmanager import PoolManager, proxy_from_url +from pip._vendor.urllib3.response import HTTPResponse +from pip._vendor.urllib3.util import parse_url +from pip._vendor.urllib3.util import Timeout as TimeoutSauce +from pip._vendor.urllib3.util.retry import Retry +from pip._vendor.urllib3.exceptions import ClosedPoolError +from pip._vendor.urllib3.exceptions import ConnectTimeoutError +from pip._vendor.urllib3.exceptions import HTTPError as _HTTPError +from pip._vendor.urllib3.exceptions import MaxRetryError +from pip._vendor.urllib3.exceptions import NewConnectionError +from pip._vendor.urllib3.exceptions import ProxyError as _ProxyError +from pip._vendor.urllib3.exceptions import ProtocolError +from pip._vendor.urllib3.exceptions import ReadTimeoutError +from pip._vendor.urllib3.exceptions import SSLError as _SSLError +from pip._vendor.urllib3.exceptions import ResponseError +from pip._vendor.urllib3.exceptions import LocationValueError + +from .models import Response +from .compat import urlparse, basestring +from .utils import (DEFAULT_CA_BUNDLE_PATH, extract_zipped_paths, + get_encoding_from_headers, prepend_scheme_if_needed, + get_auth_from_url, urldefragauth, select_proxy) +from .structures import CaseInsensitiveDict +from .cookies import extract_cookies_to_jar +from .exceptions import (ConnectionError, ConnectTimeout, ReadTimeout, SSLError, + ProxyError, RetryError, InvalidSchema, InvalidProxyURL, + InvalidURL) +from .auth import _basic_auth_str + +try: + from pip._vendor.urllib3.contrib.socks import SOCKSProxyManager +except ImportError: + def SOCKSProxyManager(*args, **kwargs): + raise InvalidSchema("Missing dependencies for SOCKS support.") + +DEFAULT_POOLBLOCK = False +DEFAULT_POOLSIZE = 10 +DEFAULT_RETRIES = 0 +DEFAULT_POOL_TIMEOUT = None + + +class BaseAdapter(object): + """The Base Transport Adapter""" + + def __init__(self): + super(BaseAdapter, self).__init__() + + def send(self, request, stream=False, timeout=None, verify=True, + cert=None, proxies=None): + """Sends PreparedRequest object. Returns Response object. + + :param request: The :class:`PreparedRequest <PreparedRequest>` being sent. + :param stream: (optional) Whether to stream the request content. + :param timeout: (optional) How long to wait for the server to send + data before giving up, as a float, or a :ref:`(connect timeout, + read timeout) <timeouts>` tuple. + :type timeout: float or tuple + :param verify: (optional) Either a boolean, in which case it controls whether we verify + the server's TLS certificate, or a string, in which case it must be a path + to a CA bundle to use + :param cert: (optional) Any user-provided SSL certificate to be trusted. + :param proxies: (optional) The proxies dictionary to apply to the request. + """ + raise NotImplementedError + + def close(self): + """Cleans up adapter specific items.""" + raise NotImplementedError + + +class HTTPAdapter(BaseAdapter): + """The built-in HTTP Adapter for urllib3. + + Provides a general-case interface for Requests sessions to contact HTTP and + HTTPS urls by implementing the Transport Adapter interface. This class will + usually be created by the :class:`Session <Session>` class under the + covers. + + :param pool_connections: The number of urllib3 connection pools to cache. + :param pool_maxsize: The maximum number of connections to save in the pool. + :param max_retries: The maximum number of retries each connection + should attempt. Note, this applies only to failed DNS lookups, socket + connections and connection timeouts, never to requests where data has + made it to the server. By default, Requests does not retry failed + connections. If you need granular control over the conditions under + which we retry a request, import urllib3's ``Retry`` class and pass + that instead. + :param pool_block: Whether the connection pool should block for connections. + + Usage:: + + >>> import requests + >>> s = requests.Session() + >>> a = requests.adapters.HTTPAdapter(max_retries=3) + >>> s.mount('http://', a) + """ + __attrs__ = ['max_retries', 'config', '_pool_connections', '_pool_maxsize', + '_pool_block'] + + def __init__(self, pool_connections=DEFAULT_POOLSIZE, + pool_maxsize=DEFAULT_POOLSIZE, max_retries=DEFAULT_RETRIES, + pool_block=DEFAULT_POOLBLOCK): + if max_retries == DEFAULT_RETRIES: + self.max_retries = Retry(0, read=False) + else: + self.max_retries = Retry.from_int(max_retries) + self.config = {} + self.proxy_manager = {} + + super(HTTPAdapter, self).__init__() + + self._pool_connections = pool_connections + self._pool_maxsize = pool_maxsize + self._pool_block = pool_block + + self.init_poolmanager(pool_connections, pool_maxsize, block=pool_block) + + def __getstate__(self): + return {attr: getattr(self, attr, None) for attr in self.__attrs__} + + def __setstate__(self, state): + # Can't handle by adding 'proxy_manager' to self.__attrs__ because + # self.poolmanager uses a lambda function, which isn't pickleable. + self.proxy_manager = {} + self.config = {} + + for attr, value in state.items(): + setattr(self, attr, value) + + self.init_poolmanager(self._pool_connections, self._pool_maxsize, + block=self._pool_block) + + def init_poolmanager(self, connections, maxsize, block=DEFAULT_POOLBLOCK, **pool_kwargs): + """Initializes a urllib3 PoolManager. + + This method should not be called from user code, and is only + exposed for use when subclassing the + :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`. + + :param connections: The number of urllib3 connection pools to cache. + :param maxsize: The maximum number of connections to save in the pool. + :param block: Block when no free connections are available. + :param pool_kwargs: Extra keyword arguments used to initialize the Pool Manager. + """ + # save these values for pickling + self._pool_connections = connections + self._pool_maxsize = maxsize + self._pool_block = block + + self.poolmanager = PoolManager(num_pools=connections, maxsize=maxsize, + block=block, strict=True, **pool_kwargs) + + def proxy_manager_for(self, proxy, **proxy_kwargs): + """Return urllib3 ProxyManager for the given proxy. + + This method should not be called from user code, and is only + exposed for use when subclassing the + :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`. + + :param proxy: The proxy to return a urllib3 ProxyManager for. + :param proxy_kwargs: Extra keyword arguments used to configure the Proxy Manager. + :returns: ProxyManager + :rtype: urllib3.ProxyManager + """ + if proxy in self.proxy_manager: + manager = self.proxy_manager[proxy] + elif proxy.lower().startswith('socks'): + username, password = get_auth_from_url(proxy) + manager = self.proxy_manager[proxy] = SOCKSProxyManager( + proxy, + username=username, + password=password, + num_pools=self._pool_connections, + maxsize=self._pool_maxsize, + block=self._pool_block, + **proxy_kwargs + ) + else: + proxy_headers = self.proxy_headers(proxy) + manager = self.proxy_manager[proxy] = proxy_from_url( + proxy, + proxy_headers=proxy_headers, + num_pools=self._pool_connections, + maxsize=self._pool_maxsize, + block=self._pool_block, + **proxy_kwargs) + + return manager + + def cert_verify(self, conn, url, verify, cert): + """Verify a SSL certificate. This method should not be called from user + code, and is only exposed for use when subclassing the + :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`. + + :param conn: The urllib3 connection object associated with the cert. + :param url: The requested URL. + :param verify: Either a boolean, in which case it controls whether we verify + the server's TLS certificate, or a string, in which case it must be a path + to a CA bundle to use + :param cert: The SSL certificate to verify. + """ + if url.lower().startswith('https') and verify: + + cert_loc = None + + # Allow self-specified cert location. + if verify is not True: + cert_loc = verify + + if not cert_loc: + cert_loc = extract_zipped_paths(DEFAULT_CA_BUNDLE_PATH) + + if not cert_loc or not os.path.exists(cert_loc): + raise IOError("Could not find a suitable TLS CA certificate bundle, " + "invalid path: {}".format(cert_loc)) + + conn.cert_reqs = 'CERT_REQUIRED' + + if not os.path.isdir(cert_loc): + conn.ca_certs = cert_loc + else: + conn.ca_cert_dir = cert_loc + else: + conn.cert_reqs = 'CERT_NONE' + conn.ca_certs = None + conn.ca_cert_dir = None + + if cert: + if not isinstance(cert, basestring): + conn.cert_file = cert[0] + conn.key_file = cert[1] + else: + conn.cert_file = cert + conn.key_file = None + if conn.cert_file and not os.path.exists(conn.cert_file): + raise IOError("Could not find the TLS certificate file, " + "invalid path: {}".format(conn.cert_file)) + if conn.key_file and not os.path.exists(conn.key_file): + raise IOError("Could not find the TLS key file, " + "invalid path: {}".format(conn.key_file)) + + def build_response(self, req, resp): + """Builds a :class:`Response <requests.Response>` object from a urllib3 + response. This should not be called from user code, and is only exposed + for use when subclassing the + :class:`HTTPAdapter <requests.adapters.HTTPAdapter>` + + :param req: The :class:`PreparedRequest <PreparedRequest>` used to generate the response. + :param resp: The urllib3 response object. + :rtype: requests.Response + """ + response = Response() + + # Fallback to None if there's no status_code, for whatever reason. + response.status_code = getattr(resp, 'status', None) + + # Make headers case-insensitive. + response.headers = CaseInsensitiveDict(getattr(resp, 'headers', {})) + + # Set encoding. + response.encoding = get_encoding_from_headers(response.headers) + response.raw = resp + response.reason = response.raw.reason + + if isinstance(req.url, bytes): + response.url = req.url.decode('utf-8') + else: + response.url = req.url + + # Add new cookies from the server. + extract_cookies_to_jar(response.cookies, req, resp) + + # Give the Response some context. + response.request = req + response.connection = self + + return response + + def get_connection(self, url, proxies=None): + """Returns a urllib3 connection for the given URL. This should not be + called from user code, and is only exposed for use when subclassing the + :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`. + + :param url: The URL to connect to. + :param proxies: (optional) A Requests-style dictionary of proxies used on this request. + :rtype: urllib3.ConnectionPool + """ + proxy = select_proxy(url, proxies) + + if proxy: + proxy = prepend_scheme_if_needed(proxy, 'http') + proxy_url = parse_url(proxy) + if not proxy_url.host: + raise InvalidProxyURL("Please check proxy URL. It is malformed" + " and could be missing the host.") + proxy_manager = self.proxy_manager_for(proxy) + conn = proxy_manager.connection_from_url(url) + else: + # Only scheme should be lower case + parsed = urlparse(url) + url = parsed.geturl() + conn = self.poolmanager.connection_from_url(url) + + return conn + + def close(self): + """Disposes of any internal state. + + Currently, this closes the PoolManager and any active ProxyManager, + which closes any pooled connections. + """ + self.poolmanager.clear() + for proxy in self.proxy_manager.values(): + proxy.clear() + + def request_url(self, request, proxies): + """Obtain the url to use when making the final request. + + If the message is being sent through a HTTP proxy, the full URL has to + be used. Otherwise, we should only use the path portion of the URL. + + This should not be called from user code, and is only exposed for use + when subclassing the + :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`. + + :param request: The :class:`PreparedRequest <PreparedRequest>` being sent. + :param proxies: A dictionary of schemes or schemes and hosts to proxy URLs. + :rtype: str + """ + proxy = select_proxy(request.url, proxies) + scheme = urlparse(request.url).scheme + + is_proxied_http_request = (proxy and scheme != 'https') + using_socks_proxy = False + if proxy: + proxy_scheme = urlparse(proxy).scheme.lower() + using_socks_proxy = proxy_scheme.startswith('socks') + + url = request.path_url + if is_proxied_http_request and not using_socks_proxy: + url = urldefragauth(request.url) + + return url + + def add_headers(self, request, **kwargs): + """Add any headers needed by the connection. As of v2.0 this does + nothing by default, but is left for overriding by users that subclass + the :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`. + + This should not be called from user code, and is only exposed for use + when subclassing the + :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`. + + :param request: The :class:`PreparedRequest <PreparedRequest>` to add headers to. + :param kwargs: The keyword arguments from the call to send(). + """ + pass + + def proxy_headers(self, proxy): + """Returns a dictionary of the headers to add to any request sent + through a proxy. This works with urllib3 magic to ensure that they are + correctly sent to the proxy, rather than in a tunnelled request if + CONNECT is being used. + + This should not be called from user code, and is only exposed for use + when subclassing the + :class:`HTTPAdapter <requests.adapters.HTTPAdapter>`. + + :param proxy: The url of the proxy being used for this request. + :rtype: dict + """ + headers = {} + username, password = get_auth_from_url(proxy) + + if username: + headers['Proxy-Authorization'] = _basic_auth_str(username, + password) + + return headers + + def send(self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None): + """Sends PreparedRequest object. Returns Response object. + + :param request: The :class:`PreparedRequest <PreparedRequest>` being sent. + :param stream: (optional) Whether to stream the request content. + :param timeout: (optional) How long to wait for the server to send + data before giving up, as a float, or a :ref:`(connect timeout, + read timeout) <timeouts>` tuple. + :type timeout: float or tuple or urllib3 Timeout object + :param verify: (optional) Either a boolean, in which case it controls whether + we verify the server's TLS certificate, or a string, in which case it + must be a path to a CA bundle to use + :param cert: (optional) Any user-provided SSL certificate to be trusted. + :param proxies: (optional) The proxies dictionary to apply to the request. + :rtype: requests.Response + """ + + try: + conn = self.get_connection(request.url, proxies) + except LocationValueError as e: + raise InvalidURL(e, request=request) + + self.cert_verify(conn, request.url, verify, cert) + url = self.request_url(request, proxies) + self.add_headers(request, stream=stream, timeout=timeout, verify=verify, cert=cert, proxies=proxies) + + chunked = not (request.body is None or 'Content-Length' in request.headers) + + if isinstance(timeout, tuple): + try: + connect, read = timeout + timeout = TimeoutSauce(connect=connect, read=read) + except ValueError as e: + # this may raise a string formatting error. + err = ("Invalid timeout {}. Pass a (connect, read) " + "timeout tuple, or a single float to set " + "both timeouts to the same value".format(timeout)) + raise ValueError(err) + elif isinstance(timeout, TimeoutSauce): + pass + else: + timeout = TimeoutSauce(connect=timeout, read=timeout) + + try: + if not chunked: + resp = conn.urlopen( + method=request.method, + url=url, + body=request.body, + headers=request.headers, + redirect=False, + assert_same_host=False, + preload_content=False, + decode_content=False, + retries=self.max_retries, + timeout=timeout + ) + + # Send the request. + else: + if hasattr(conn, 'proxy_pool'): + conn = conn.proxy_pool + + low_conn = conn._get_conn(timeout=DEFAULT_POOL_TIMEOUT) + + try: + low_conn.putrequest(request.method, + url, + skip_accept_encoding=True) + + for header, value in request.headers.items(): + low_conn.putheader(header, value) + + low_conn.endheaders() + + for i in request.body: + low_conn.send(hex(len(i))[2:].encode('utf-8')) + low_conn.send(b'\r\n') + low_conn.send(i) + low_conn.send(b'\r\n') + low_conn.send(b'0\r\n\r\n') + + # Receive the response from the server + try: + # For Python 2.7, use buffering of HTTP responses + r = low_conn.getresponse(buffering=True) + except TypeError: + # For compatibility with Python 3.3+ + r = low_conn.getresponse() + + resp = HTTPResponse.from_httplib( + r, + pool=conn, + connection=low_conn, + preload_content=False, + decode_content=False + ) + except: + # If we hit any problems here, clean up the connection. + # Then, reraise so that we can handle the actual exception. + low_conn.close() + raise + + except (ProtocolError, socket.error) as err: + raise ConnectionError(err, request=request) + + except MaxRetryError as e: + if isinstance(e.reason, ConnectTimeoutError): + # TODO: Remove this in 3.0.0: see #2811 + if not isinstance(e.reason, NewConnectionError): + raise ConnectTimeout(e, request=request) + + if isinstance(e.reason, ResponseError): + raise RetryError(e, request=request) + + if isinstance(e.reason, _ProxyError): + raise ProxyError(e, request=request) + + if isinstance(e.reason, _SSLError): + # This branch is for urllib3 v1.22 and later. + raise SSLError(e, request=request) + + raise ConnectionError(e, request=request) + + except ClosedPoolError as e: + raise ConnectionError(e, request=request) + + except _ProxyError as e: + raise ProxyError(e) + + except (_SSLError, _HTTPError) as e: + if isinstance(e, _SSLError): + # This branch is for urllib3 versions earlier than v1.22 + raise SSLError(e, request=request) + elif isinstance(e, ReadTimeoutError): + raise ReadTimeout(e, request=request) + else: + raise + + return self.build_response(request, resp) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/api.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/api.py new file mode 100644 index 0000000..ef71d07 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/api.py @@ -0,0 +1,158 @@ +# -*- coding: utf-8 -*- + +""" +requests.api +~~~~~~~~~~~~ + +This module implements the Requests API. + +:copyright: (c) 2012 by Kenneth Reitz. +:license: Apache2, see LICENSE for more details. +""" + +from . import sessions + + +def request(method, url, **kwargs): + """Constructs and sends a :class:`Request <Request>`. + + :param method: method for the new :class:`Request` object. + :param url: URL for the new :class:`Request` object. + :param params: (optional) Dictionary, list of tuples or bytes to send + in the query string for the :class:`Request`. + :param data: (optional) Dictionary, list of tuples, bytes, or file-like + object to send in the body of the :class:`Request`. + :param json: (optional) A JSON serializable Python object to send in the body of the :class:`Request`. + :param headers: (optional) Dictionary of HTTP Headers to send with the :class:`Request`. + :param cookies: (optional) Dict or CookieJar object to send with the :class:`Request`. + :param files: (optional) Dictionary of ``'name': file-like-objects`` (or ``{'name': file-tuple}``) for multipart encoding upload. + ``file-tuple`` can be a 2-tuple ``('filename', fileobj)``, 3-tuple ``('filename', fileobj, 'content_type')`` + or a 4-tuple ``('filename', fileobj, 'content_type', custom_headers)``, where ``'content-type'`` is a string + defining the content type of the given file and ``custom_headers`` a dict-like object containing additional headers + to add for the file. + :param auth: (optional) Auth tuple to enable Basic/Digest/Custom HTTP Auth. + :param timeout: (optional) How many seconds to wait for the server to send data + before giving up, as a float, or a :ref:`(connect timeout, read + timeout) <timeouts>` tuple. + :type timeout: float or tuple + :param allow_redirects: (optional) Boolean. Enable/disable GET/OPTIONS/POST/PUT/PATCH/DELETE/HEAD redirection. Defaults to ``True``. + :type allow_redirects: bool + :param proxies: (optional) Dictionary mapping protocol to the URL of the proxy. + :param verify: (optional) Either a boolean, in which case it controls whether we verify + the server's TLS certificate, or a string, in which case it must be a path + to a CA bundle to use. Defaults to ``True``. + :param stream: (optional) if ``False``, the response content will be immediately downloaded. + :param cert: (optional) if String, path to ssl client cert file (.pem). If Tuple, ('cert', 'key') pair. + :return: :class:`Response <Response>` object + :rtype: requests.Response + + Usage:: + + >>> import requests + >>> req = requests.request('GET', 'https://httpbin.org/get') + <Response [200]> + """ + + # By using the 'with' statement we are sure the session is closed, thus we + # avoid leaving sockets open which can trigger a ResourceWarning in some + # cases, and look like a memory leak in others. + with sessions.Session() as session: + return session.request(method=method, url=url, **kwargs) + + +def get(url, params=None, **kwargs): + r"""Sends a GET request. + + :param url: URL for the new :class:`Request` object. + :param params: (optional) Dictionary, list of tuples or bytes to send + in the query string for the :class:`Request`. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :return: :class:`Response <Response>` object + :rtype: requests.Response + """ + + kwargs.setdefault('allow_redirects', True) + return request('get', url, params=params, **kwargs) + + +def options(url, **kwargs): + r"""Sends an OPTIONS request. + + :param url: URL for the new :class:`Request` object. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :return: :class:`Response <Response>` object + :rtype: requests.Response + """ + + kwargs.setdefault('allow_redirects', True) + return request('options', url, **kwargs) + + +def head(url, **kwargs): + r"""Sends a HEAD request. + + :param url: URL for the new :class:`Request` object. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :return: :class:`Response <Response>` object + :rtype: requests.Response + """ + + kwargs.setdefault('allow_redirects', False) + return request('head', url, **kwargs) + + +def post(url, data=None, json=None, **kwargs): + r"""Sends a POST request. + + :param url: URL for the new :class:`Request` object. + :param data: (optional) Dictionary, list of tuples, bytes, or file-like + object to send in the body of the :class:`Request`. + :param json: (optional) json data to send in the body of the :class:`Request`. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :return: :class:`Response <Response>` object + :rtype: requests.Response + """ + + return request('post', url, data=data, json=json, **kwargs) + + +def put(url, data=None, **kwargs): + r"""Sends a PUT request. + + :param url: URL for the new :class:`Request` object. + :param data: (optional) Dictionary, list of tuples, bytes, or file-like + object to send in the body of the :class:`Request`. + :param json: (optional) json data to send in the body of the :class:`Request`. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :return: :class:`Response <Response>` object + :rtype: requests.Response + """ + + return request('put', url, data=data, **kwargs) + + +def patch(url, data=None, **kwargs): + r"""Sends a PATCH request. + + :param url: URL for the new :class:`Request` object. + :param data: (optional) Dictionary, list of tuples, bytes, or file-like + object to send in the body of the :class:`Request`. + :param json: (optional) json data to send in the body of the :class:`Request`. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :return: :class:`Response <Response>` object + :rtype: requests.Response + """ + + return request('patch', url, data=data, **kwargs) + + +def delete(url, **kwargs): + r"""Sends a DELETE request. + + :param url: URL for the new :class:`Request` object. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :return: :class:`Response <Response>` object + :rtype: requests.Response + """ + + return request('delete', url, **kwargs) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/auth.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/auth.py new file mode 100644 index 0000000..bdde51c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/auth.py @@ -0,0 +1,305 @@ +# -*- coding: utf-8 -*- + +""" +requests.auth +~~~~~~~~~~~~~ + +This module contains the authentication handlers for Requests. +""" + +import os +import re +import time +import hashlib +import threading +import warnings + +from base64 import b64encode + +from .compat import urlparse, str, basestring +from .cookies import extract_cookies_to_jar +from ._internal_utils import to_native_string +from .utils import parse_dict_header + +CONTENT_TYPE_FORM_URLENCODED = 'application/x-www-form-urlencoded' +CONTENT_TYPE_MULTI_PART = 'multipart/form-data' + + +def _basic_auth_str(username, password): + """Returns a Basic Auth string.""" + + # "I want us to put a big-ol' comment on top of it that + # says that this behaviour is dumb but we need to preserve + # it because people are relying on it." + # - Lukasa + # + # These are here solely to maintain backwards compatibility + # for things like ints. This will be removed in 3.0.0. + if not isinstance(username, basestring): + warnings.warn( + "Non-string usernames will no longer be supported in Requests " + "3.0.0. Please convert the object you've passed in ({!r}) to " + "a string or bytes object in the near future to avoid " + "problems.".format(username), + category=DeprecationWarning, + ) + username = str(username) + + if not isinstance(password, basestring): + warnings.warn( + "Non-string passwords will no longer be supported in Requests " + "3.0.0. Please convert the object you've passed in ({!r}) to " + "a string or bytes object in the near future to avoid " + "problems.".format(password), + category=DeprecationWarning, + ) + password = str(password) + # -- End Removal -- + + if isinstance(username, str): + username = username.encode('latin1') + + if isinstance(password, str): + password = password.encode('latin1') + + authstr = 'Basic ' + to_native_string( + b64encode(b':'.join((username, password))).strip() + ) + + return authstr + + +class AuthBase(object): + """Base class that all auth implementations derive from""" + + def __call__(self, r): + raise NotImplementedError('Auth hooks must be callable.') + + +class HTTPBasicAuth(AuthBase): + """Attaches HTTP Basic Authentication to the given Request object.""" + + def __init__(self, username, password): + self.username = username + self.password = password + + def __eq__(self, other): + return all([ + self.username == getattr(other, 'username', None), + self.password == getattr(other, 'password', None) + ]) + + def __ne__(self, other): + return not self == other + + def __call__(self, r): + r.headers['Authorization'] = _basic_auth_str(self.username, self.password) + return r + + +class HTTPProxyAuth(HTTPBasicAuth): + """Attaches HTTP Proxy Authentication to a given Request object.""" + + def __call__(self, r): + r.headers['Proxy-Authorization'] = _basic_auth_str(self.username, self.password) + return r + + +class HTTPDigestAuth(AuthBase): + """Attaches HTTP Digest Authentication to the given Request object.""" + + def __init__(self, username, password): + self.username = username + self.password = password + # Keep state in per-thread local storage + self._thread_local = threading.local() + + def init_per_thread_state(self): + # Ensure state is initialized just once per-thread + if not hasattr(self._thread_local, 'init'): + self._thread_local.init = True + self._thread_local.last_nonce = '' + self._thread_local.nonce_count = 0 + self._thread_local.chal = {} + self._thread_local.pos = None + self._thread_local.num_401_calls = None + + def build_digest_header(self, method, url): + """ + :rtype: str + """ + + realm = self._thread_local.chal['realm'] + nonce = self._thread_local.chal['nonce'] + qop = self._thread_local.chal.get('qop') + algorithm = self._thread_local.chal.get('algorithm') + opaque = self._thread_local.chal.get('opaque') + hash_utf8 = None + + if algorithm is None: + _algorithm = 'MD5' + else: + _algorithm = algorithm.upper() + # lambdas assume digest modules are imported at the top level + if _algorithm == 'MD5' or _algorithm == 'MD5-SESS': + def md5_utf8(x): + if isinstance(x, str): + x = x.encode('utf-8') + return hashlib.md5(x).hexdigest() + hash_utf8 = md5_utf8 + elif _algorithm == 'SHA': + def sha_utf8(x): + if isinstance(x, str): + x = x.encode('utf-8') + return hashlib.sha1(x).hexdigest() + hash_utf8 = sha_utf8 + elif _algorithm == 'SHA-256': + def sha256_utf8(x): + if isinstance(x, str): + x = x.encode('utf-8') + return hashlib.sha256(x).hexdigest() + hash_utf8 = sha256_utf8 + elif _algorithm == 'SHA-512': + def sha512_utf8(x): + if isinstance(x, str): + x = x.encode('utf-8') + return hashlib.sha512(x).hexdigest() + hash_utf8 = sha512_utf8 + + KD = lambda s, d: hash_utf8("%s:%s" % (s, d)) + + if hash_utf8 is None: + return None + + # XXX not implemented yet + entdig = None + p_parsed = urlparse(url) + #: path is request-uri defined in RFC 2616 which should not be empty + path = p_parsed.path or "/" + if p_parsed.query: + path += '?' + p_parsed.query + + A1 = '%s:%s:%s' % (self.username, realm, self.password) + A2 = '%s:%s' % (method, path) + + HA1 = hash_utf8(A1) + HA2 = hash_utf8(A2) + + if nonce == self._thread_local.last_nonce: + self._thread_local.nonce_count += 1 + else: + self._thread_local.nonce_count = 1 + ncvalue = '%08x' % self._thread_local.nonce_count + s = str(self._thread_local.nonce_count).encode('utf-8') + s += nonce.encode('utf-8') + s += time.ctime().encode('utf-8') + s += os.urandom(8) + + cnonce = (hashlib.sha1(s).hexdigest()[:16]) + if _algorithm == 'MD5-SESS': + HA1 = hash_utf8('%s:%s:%s' % (HA1, nonce, cnonce)) + + if not qop: + respdig = KD(HA1, "%s:%s" % (nonce, HA2)) + elif qop == 'auth' or 'auth' in qop.split(','): + noncebit = "%s:%s:%s:%s:%s" % ( + nonce, ncvalue, cnonce, 'auth', HA2 + ) + respdig = KD(HA1, noncebit) + else: + # XXX handle auth-int. + return None + + self._thread_local.last_nonce = nonce + + # XXX should the partial digests be encoded too? + base = 'username="%s", realm="%s", nonce="%s", uri="%s", ' \ + 'response="%s"' % (self.username, realm, nonce, path, respdig) + if opaque: + base += ', opaque="%s"' % opaque + if algorithm: + base += ', algorithm="%s"' % algorithm + if entdig: + base += ', digest="%s"' % entdig + if qop: + base += ', qop="auth", nc=%s, cnonce="%s"' % (ncvalue, cnonce) + + return 'Digest %s' % (base) + + def handle_redirect(self, r, **kwargs): + """Reset num_401_calls counter on redirects.""" + if r.is_redirect: + self._thread_local.num_401_calls = 1 + + def handle_401(self, r, **kwargs): + """ + Takes the given response and tries digest-auth, if needed. + + :rtype: requests.Response + """ + + # If response is not 4xx, do not auth + # See https://github.com/requests/requests/issues/3772 + if not 400 <= r.status_code < 500: + self._thread_local.num_401_calls = 1 + return r + + if self._thread_local.pos is not None: + # Rewind the file position indicator of the body to where + # it was to resend the request. + r.request.body.seek(self._thread_local.pos) + s_auth = r.headers.get('www-authenticate', '') + + if 'digest' in s_auth.lower() and self._thread_local.num_401_calls < 2: + + self._thread_local.num_401_calls += 1 + pat = re.compile(r'digest ', flags=re.IGNORECASE) + self._thread_local.chal = parse_dict_header(pat.sub('', s_auth, count=1)) + + # Consume content and release the original connection + # to allow our new request to reuse the same one. + r.content + r.close() + prep = r.request.copy() + extract_cookies_to_jar(prep._cookies, r.request, r.raw) + prep.prepare_cookies(prep._cookies) + + prep.headers['Authorization'] = self.build_digest_header( + prep.method, prep.url) + _r = r.connection.send(prep, **kwargs) + _r.history.append(r) + _r.request = prep + + return _r + + self._thread_local.num_401_calls = 1 + return r + + def __call__(self, r): + # Initialize per-thread state, if needed + self.init_per_thread_state() + # If we have a saved nonce, skip the 401 + if self._thread_local.last_nonce: + r.headers['Authorization'] = self.build_digest_header(r.method, r.url) + try: + self._thread_local.pos = r.body.tell() + except AttributeError: + # In the case of HTTPDigestAuth being reused and the body of + # the previous request was a file-like object, pos has the + # file position of the previous body. Ensure it's set to + # None. + self._thread_local.pos = None + r.register_hook('response', self.handle_401) + r.register_hook('response', self.handle_redirect) + self._thread_local.num_401_calls = 1 + + return r + + def __eq__(self, other): + return all([ + self.username == getattr(other, 'username', None), + self.password == getattr(other, 'password', None) + ]) + + def __ne__(self, other): + return not self == other diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/certs.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/certs.py new file mode 100644 index 0000000..06a594e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/certs.py @@ -0,0 +1,18 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +""" +requests.certs +~~~~~~~~~~~~~~ + +This module returns the preferred default CA certificate bundle. There is +only one — the one from the certifi package. + +If you are packaging Requests, e.g., for a Linux distribution or a managed +environment, you can change the definition of where() to return a separately +packaged CA bundle. +""" +from pip._vendor.certifi import where + +if __name__ == '__main__': + print(where()) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/compat.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/compat.py new file mode 100644 index 0000000..6a86893 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/compat.py @@ -0,0 +1,74 @@ +# -*- coding: utf-8 -*- + +""" +requests.compat +~~~~~~~~~~~~~~~ + +This module handles import compatibility issues between Python 2 and +Python 3. +""" + +from pip._vendor import chardet + +import sys + +# ------- +# Pythons +# ------- + +# Syntax sugar. +_ver = sys.version_info + +#: Python 2.x? +is_py2 = (_ver[0] == 2) + +#: Python 3.x? +is_py3 = (_ver[0] == 3) + +# Note: We've patched out simplejson support in pip because it prevents +# upgrading simplejson on Windows. +# try: +# import simplejson as json +# except (ImportError, SyntaxError): +# # simplejson does not support Python 3.2, it throws a SyntaxError +# # because of u'...' Unicode literals. +import json + +# --------- +# Specifics +# --------- + +if is_py2: + from urllib import ( + quote, unquote, quote_plus, unquote_plus, urlencode, getproxies, + proxy_bypass, proxy_bypass_environment, getproxies_environment) + from urlparse import urlparse, urlunparse, urljoin, urlsplit, urldefrag + from urllib2 import parse_http_list + import cookielib + from Cookie import Morsel + from StringIO import StringIO + from collections import Callable, Mapping, MutableMapping, OrderedDict + + + builtin_str = str + bytes = str + str = unicode + basestring = basestring + numeric_types = (int, long, float) + integer_types = (int, long) + +elif is_py3: + from urllib.parse import urlparse, urlunparse, urljoin, urlsplit, urlencode, quote, unquote, quote_plus, unquote_plus, urldefrag + from urllib.request import parse_http_list, getproxies, proxy_bypass, proxy_bypass_environment, getproxies_environment + from http import cookiejar as cookielib + from http.cookies import Morsel + from io import StringIO + from collections import OrderedDict + from collections.abc import Callable, Mapping, MutableMapping + + builtin_str = str + str = str + bytes = bytes + basestring = (str, bytes) + numeric_types = (int, float) + integer_types = (int,) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/cookies.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/cookies.py new file mode 100644 index 0000000..56fccd9 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/cookies.py @@ -0,0 +1,549 @@ +# -*- coding: utf-8 -*- + +""" +requests.cookies +~~~~~~~~~~~~~~~~ + +Compatibility code to be able to use `cookielib.CookieJar` with requests. + +requests.utils imports from here, so be careful with imports. +""" + +import copy +import time +import calendar + +from ._internal_utils import to_native_string +from .compat import cookielib, urlparse, urlunparse, Morsel, MutableMapping + +try: + import threading +except ImportError: + import dummy_threading as threading + + +class MockRequest(object): + """Wraps a `requests.Request` to mimic a `urllib2.Request`. + + The code in `cookielib.CookieJar` expects this interface in order to correctly + manage cookie policies, i.e., determine whether a cookie can be set, given the + domains of the request and the cookie. + + The original request object is read-only. The client is responsible for collecting + the new headers via `get_new_headers()` and interpreting them appropriately. You + probably want `get_cookie_header`, defined below. + """ + + def __init__(self, request): + self._r = request + self._new_headers = {} + self.type = urlparse(self._r.url).scheme + + def get_type(self): + return self.type + + def get_host(self): + return urlparse(self._r.url).netloc + + def get_origin_req_host(self): + return self.get_host() + + def get_full_url(self): + # Only return the response's URL if the user hadn't set the Host + # header + if not self._r.headers.get('Host'): + return self._r.url + # If they did set it, retrieve it and reconstruct the expected domain + host = to_native_string(self._r.headers['Host'], encoding='utf-8') + parsed = urlparse(self._r.url) + # Reconstruct the URL as we expect it + return urlunparse([ + parsed.scheme, host, parsed.path, parsed.params, parsed.query, + parsed.fragment + ]) + + def is_unverifiable(self): + return True + + def has_header(self, name): + return name in self._r.headers or name in self._new_headers + + def get_header(self, name, default=None): + return self._r.headers.get(name, self._new_headers.get(name, default)) + + def add_header(self, key, val): + """cookielib has no legitimate use for this method; add it back if you find one.""" + raise NotImplementedError("Cookie headers should be added with add_unredirected_header()") + + def add_unredirected_header(self, name, value): + self._new_headers[name] = value + + def get_new_headers(self): + return self._new_headers + + @property + def unverifiable(self): + return self.is_unverifiable() + + @property + def origin_req_host(self): + return self.get_origin_req_host() + + @property + def host(self): + return self.get_host() + + +class MockResponse(object): + """Wraps a `httplib.HTTPMessage` to mimic a `urllib.addinfourl`. + + ...what? Basically, expose the parsed HTTP headers from the server response + the way `cookielib` expects to see them. + """ + + def __init__(self, headers): + """Make a MockResponse for `cookielib` to read. + + :param headers: a httplib.HTTPMessage or analogous carrying the headers + """ + self._headers = headers + + def info(self): + return self._headers + + def getheaders(self, name): + self._headers.getheaders(name) + + +def extract_cookies_to_jar(jar, request, response): + """Extract the cookies from the response into a CookieJar. + + :param jar: cookielib.CookieJar (not necessarily a RequestsCookieJar) + :param request: our own requests.Request object + :param response: urllib3.HTTPResponse object + """ + if not (hasattr(response, '_original_response') and + response._original_response): + return + # the _original_response field is the wrapped httplib.HTTPResponse object, + req = MockRequest(request) + # pull out the HTTPMessage with the headers and put it in the mock: + res = MockResponse(response._original_response.msg) + jar.extract_cookies(res, req) + + +def get_cookie_header(jar, request): + """ + Produce an appropriate Cookie header string to be sent with `request`, or None. + + :rtype: str + """ + r = MockRequest(request) + jar.add_cookie_header(r) + return r.get_new_headers().get('Cookie') + + +def remove_cookie_by_name(cookiejar, name, domain=None, path=None): + """Unsets a cookie by name, by default over all domains and paths. + + Wraps CookieJar.clear(), is O(n). + """ + clearables = [] + for cookie in cookiejar: + if cookie.name != name: + continue + if domain is not None and domain != cookie.domain: + continue + if path is not None and path != cookie.path: + continue + clearables.append((cookie.domain, cookie.path, cookie.name)) + + for domain, path, name in clearables: + cookiejar.clear(domain, path, name) + + +class CookieConflictError(RuntimeError): + """There are two cookies that meet the criteria specified in the cookie jar. + Use .get and .set and include domain and path args in order to be more specific. + """ + + +class RequestsCookieJar(cookielib.CookieJar, MutableMapping): + """Compatibility class; is a cookielib.CookieJar, but exposes a dict + interface. + + This is the CookieJar we create by default for requests and sessions that + don't specify one, since some clients may expect response.cookies and + session.cookies to support dict operations. + + Requests does not use the dict interface internally; it's just for + compatibility with external client code. All requests code should work + out of the box with externally provided instances of ``CookieJar``, e.g. + ``LWPCookieJar`` and ``FileCookieJar``. + + Unlike a regular CookieJar, this class is pickleable. + + .. warning:: dictionary operations that are normally O(1) may be O(n). + """ + + def get(self, name, default=None, domain=None, path=None): + """Dict-like get() that also supports optional domain and path args in + order to resolve naming collisions from using one cookie jar over + multiple domains. + + .. warning:: operation is O(n), not O(1). + """ + try: + return self._find_no_duplicates(name, domain, path) + except KeyError: + return default + + def set(self, name, value, **kwargs): + """Dict-like set() that also supports optional domain and path args in + order to resolve naming collisions from using one cookie jar over + multiple domains. + """ + # support client code that unsets cookies by assignment of a None value: + if value is None: + remove_cookie_by_name(self, name, domain=kwargs.get('domain'), path=kwargs.get('path')) + return + + if isinstance(value, Morsel): + c = morsel_to_cookie(value) + else: + c = create_cookie(name, value, **kwargs) + self.set_cookie(c) + return c + + def iterkeys(self): + """Dict-like iterkeys() that returns an iterator of names of cookies + from the jar. + + .. seealso:: itervalues() and iteritems(). + """ + for cookie in iter(self): + yield cookie.name + + def keys(self): + """Dict-like keys() that returns a list of names of cookies from the + jar. + + .. seealso:: values() and items(). + """ + return list(self.iterkeys()) + + def itervalues(self): + """Dict-like itervalues() that returns an iterator of values of cookies + from the jar. + + .. seealso:: iterkeys() and iteritems(). + """ + for cookie in iter(self): + yield cookie.value + + def values(self): + """Dict-like values() that returns a list of values of cookies from the + jar. + + .. seealso:: keys() and items(). + """ + return list(self.itervalues()) + + def iteritems(self): + """Dict-like iteritems() that returns an iterator of name-value tuples + from the jar. + + .. seealso:: iterkeys() and itervalues(). + """ + for cookie in iter(self): + yield cookie.name, cookie.value + + def items(self): + """Dict-like items() that returns a list of name-value tuples from the + jar. Allows client-code to call ``dict(RequestsCookieJar)`` and get a + vanilla python dict of key value pairs. + + .. seealso:: keys() and values(). + """ + return list(self.iteritems()) + + def list_domains(self): + """Utility method to list all the domains in the jar.""" + domains = [] + for cookie in iter(self): + if cookie.domain not in domains: + domains.append(cookie.domain) + return domains + + def list_paths(self): + """Utility method to list all the paths in the jar.""" + paths = [] + for cookie in iter(self): + if cookie.path not in paths: + paths.append(cookie.path) + return paths + + def multiple_domains(self): + """Returns True if there are multiple domains in the jar. + Returns False otherwise. + + :rtype: bool + """ + domains = [] + for cookie in iter(self): + if cookie.domain is not None and cookie.domain in domains: + return True + domains.append(cookie.domain) + return False # there is only one domain in jar + + def get_dict(self, domain=None, path=None): + """Takes as an argument an optional domain and path and returns a plain + old Python dict of name-value pairs of cookies that meet the + requirements. + + :rtype: dict + """ + dictionary = {} + for cookie in iter(self): + if ( + (domain is None or cookie.domain == domain) and + (path is None or cookie.path == path) + ): + dictionary[cookie.name] = cookie.value + return dictionary + + def __contains__(self, name): + try: + return super(RequestsCookieJar, self).__contains__(name) + except CookieConflictError: + return True + + def __getitem__(self, name): + """Dict-like __getitem__() for compatibility with client code. Throws + exception if there are more than one cookie with name. In that case, + use the more explicit get() method instead. + + .. warning:: operation is O(n), not O(1). + """ + return self._find_no_duplicates(name) + + def __setitem__(self, name, value): + """Dict-like __setitem__ for compatibility with client code. Throws + exception if there is already a cookie of that name in the jar. In that + case, use the more explicit set() method instead. + """ + self.set(name, value) + + def __delitem__(self, name): + """Deletes a cookie given a name. Wraps ``cookielib.CookieJar``'s + ``remove_cookie_by_name()``. + """ + remove_cookie_by_name(self, name) + + def set_cookie(self, cookie, *args, **kwargs): + if hasattr(cookie.value, 'startswith') and cookie.value.startswith('"') and cookie.value.endswith('"'): + cookie.value = cookie.value.replace('\\"', '') + return super(RequestsCookieJar, self).set_cookie(cookie, *args, **kwargs) + + def update(self, other): + """Updates this jar with cookies from another CookieJar or dict-like""" + if isinstance(other, cookielib.CookieJar): + for cookie in other: + self.set_cookie(copy.copy(cookie)) + else: + super(RequestsCookieJar, self).update(other) + + def _find(self, name, domain=None, path=None): + """Requests uses this method internally to get cookie values. + + If there are conflicting cookies, _find arbitrarily chooses one. + See _find_no_duplicates if you want an exception thrown if there are + conflicting cookies. + + :param name: a string containing name of cookie + :param domain: (optional) string containing domain of cookie + :param path: (optional) string containing path of cookie + :return: cookie.value + """ + for cookie in iter(self): + if cookie.name == name: + if domain is None or cookie.domain == domain: + if path is None or cookie.path == path: + return cookie.value + + raise KeyError('name=%r, domain=%r, path=%r' % (name, domain, path)) + + def _find_no_duplicates(self, name, domain=None, path=None): + """Both ``__get_item__`` and ``get`` call this function: it's never + used elsewhere in Requests. + + :param name: a string containing name of cookie + :param domain: (optional) string containing domain of cookie + :param path: (optional) string containing path of cookie + :raises KeyError: if cookie is not found + :raises CookieConflictError: if there are multiple cookies + that match name and optionally domain and path + :return: cookie.value + """ + toReturn = None + for cookie in iter(self): + if cookie.name == name: + if domain is None or cookie.domain == domain: + if path is None or cookie.path == path: + if toReturn is not None: # if there are multiple cookies that meet passed in criteria + raise CookieConflictError('There are multiple cookies with name, %r' % (name)) + toReturn = cookie.value # we will eventually return this as long as no cookie conflict + + if toReturn: + return toReturn + raise KeyError('name=%r, domain=%r, path=%r' % (name, domain, path)) + + def __getstate__(self): + """Unlike a normal CookieJar, this class is pickleable.""" + state = self.__dict__.copy() + # remove the unpickleable RLock object + state.pop('_cookies_lock') + return state + + def __setstate__(self, state): + """Unlike a normal CookieJar, this class is pickleable.""" + self.__dict__.update(state) + if '_cookies_lock' not in self.__dict__: + self._cookies_lock = threading.RLock() + + def copy(self): + """Return a copy of this RequestsCookieJar.""" + new_cj = RequestsCookieJar() + new_cj.set_policy(self.get_policy()) + new_cj.update(self) + return new_cj + + def get_policy(self): + """Return the CookiePolicy instance used.""" + return self._policy + + +def _copy_cookie_jar(jar): + if jar is None: + return None + + if hasattr(jar, 'copy'): + # We're dealing with an instance of RequestsCookieJar + return jar.copy() + # We're dealing with a generic CookieJar instance + new_jar = copy.copy(jar) + new_jar.clear() + for cookie in jar: + new_jar.set_cookie(copy.copy(cookie)) + return new_jar + + +def create_cookie(name, value, **kwargs): + """Make a cookie from underspecified parameters. + + By default, the pair of `name` and `value` will be set for the domain '' + and sent on every request (this is sometimes called a "supercookie"). + """ + result = { + 'version': 0, + 'name': name, + 'value': value, + 'port': None, + 'domain': '', + 'path': '/', + 'secure': False, + 'expires': None, + 'discard': True, + 'comment': None, + 'comment_url': None, + 'rest': {'HttpOnly': None}, + 'rfc2109': False, + } + + badargs = set(kwargs) - set(result) + if badargs: + err = 'create_cookie() got unexpected keyword arguments: %s' + raise TypeError(err % list(badargs)) + + result.update(kwargs) + result['port_specified'] = bool(result['port']) + result['domain_specified'] = bool(result['domain']) + result['domain_initial_dot'] = result['domain'].startswith('.') + result['path_specified'] = bool(result['path']) + + return cookielib.Cookie(**result) + + +def morsel_to_cookie(morsel): + """Convert a Morsel object into a Cookie containing the one k/v pair.""" + + expires = None + if morsel['max-age']: + try: + expires = int(time.time() + int(morsel['max-age'])) + except ValueError: + raise TypeError('max-age: %s must be integer' % morsel['max-age']) + elif morsel['expires']: + time_template = '%a, %d-%b-%Y %H:%M:%S GMT' + expires = calendar.timegm( + time.strptime(morsel['expires'], time_template) + ) + return create_cookie( + comment=morsel['comment'], + comment_url=bool(morsel['comment']), + discard=False, + domain=morsel['domain'], + expires=expires, + name=morsel.key, + path=morsel['path'], + port=None, + rest={'HttpOnly': morsel['httponly']}, + rfc2109=False, + secure=bool(morsel['secure']), + value=morsel.value, + version=morsel['version'] or 0, + ) + + +def cookiejar_from_dict(cookie_dict, cookiejar=None, overwrite=True): + """Returns a CookieJar from a key/value dictionary. + + :param cookie_dict: Dict of key/values to insert into CookieJar. + :param cookiejar: (optional) A cookiejar to add the cookies to. + :param overwrite: (optional) If False, will not replace cookies + already in the jar with new ones. + :rtype: CookieJar + """ + if cookiejar is None: + cookiejar = RequestsCookieJar() + + if cookie_dict is not None: + names_from_jar = [cookie.name for cookie in cookiejar] + for name in cookie_dict: + if overwrite or (name not in names_from_jar): + cookiejar.set_cookie(create_cookie(name, cookie_dict[name])) + + return cookiejar + + +def merge_cookies(cookiejar, cookies): + """Add cookies to cookiejar and returns a merged CookieJar. + + :param cookiejar: CookieJar object to add the cookies to. + :param cookies: Dictionary or CookieJar object to be added. + :rtype: CookieJar + """ + if not isinstance(cookiejar, cookielib.CookieJar): + raise ValueError('You can only merge into CookieJar') + + if isinstance(cookies, dict): + cookiejar = cookiejar_from_dict( + cookies, cookiejar=cookiejar, overwrite=False) + elif isinstance(cookies, cookielib.CookieJar): + try: + cookiejar.update(cookies) + except AttributeError: + for cookie_in_jar in cookies: + cookiejar.set_cookie(cookie_in_jar) + + return cookiejar diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/exceptions.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/exceptions.py new file mode 100644 index 0000000..a91e1fd --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/exceptions.py @@ -0,0 +1,126 @@ +# -*- coding: utf-8 -*- + +""" +requests.exceptions +~~~~~~~~~~~~~~~~~~~ + +This module contains the set of Requests' exceptions. +""" +from pip._vendor.urllib3.exceptions import HTTPError as BaseHTTPError + + +class RequestException(IOError): + """There was an ambiguous exception that occurred while handling your + request. + """ + + def __init__(self, *args, **kwargs): + """Initialize RequestException with `request` and `response` objects.""" + response = kwargs.pop('response', None) + self.response = response + self.request = kwargs.pop('request', None) + if (response is not None and not self.request and + hasattr(response, 'request')): + self.request = self.response.request + super(RequestException, self).__init__(*args, **kwargs) + + +class HTTPError(RequestException): + """An HTTP error occurred.""" + + +class ConnectionError(RequestException): + """A Connection error occurred.""" + + +class ProxyError(ConnectionError): + """A proxy error occurred.""" + + +class SSLError(ConnectionError): + """An SSL error occurred.""" + + +class Timeout(RequestException): + """The request timed out. + + Catching this error will catch both + :exc:`~requests.exceptions.ConnectTimeout` and + :exc:`~requests.exceptions.ReadTimeout` errors. + """ + + +class ConnectTimeout(ConnectionError, Timeout): + """The request timed out while trying to connect to the remote server. + + Requests that produced this error are safe to retry. + """ + + +class ReadTimeout(Timeout): + """The server did not send any data in the allotted amount of time.""" + + +class URLRequired(RequestException): + """A valid URL is required to make a request.""" + + +class TooManyRedirects(RequestException): + """Too many redirects.""" + + +class MissingSchema(RequestException, ValueError): + """The URL schema (e.g. http or https) is missing.""" + + +class InvalidSchema(RequestException, ValueError): + """See defaults.py for valid schemas.""" + + +class InvalidURL(RequestException, ValueError): + """The URL provided was somehow invalid.""" + + +class InvalidHeader(RequestException, ValueError): + """The header value provided was somehow invalid.""" + + +class InvalidProxyURL(InvalidURL): + """The proxy URL provided is invalid.""" + + +class ChunkedEncodingError(RequestException): + """The server declared chunked encoding but sent an invalid chunk.""" + + +class ContentDecodingError(RequestException, BaseHTTPError): + """Failed to decode response content""" + + +class StreamConsumedError(RequestException, TypeError): + """The content for this response was already consumed""" + + +class RetryError(RequestException): + """Custom retries logic failed""" + + +class UnrewindableBodyError(RequestException): + """Requests encountered an error when trying to rewind a body""" + +# Warnings + + +class RequestsWarning(Warning): + """Base warning for Requests.""" + pass + + +class FileModeWarning(RequestsWarning, DeprecationWarning): + """A file was opened in text mode, but Requests determined its binary length.""" + pass + + +class RequestsDependencyWarning(RequestsWarning): + """An imported dependency doesn't match the expected version range.""" + pass diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/help.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/help.py new file mode 100644 index 0000000..3c3072b --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/help.py @@ -0,0 +1,119 @@ +"""Module containing bug report helper(s).""" +from __future__ import print_function + +import json +import platform +import sys +import ssl + +from pip._vendor import idna +from pip._vendor import urllib3 +from pip._vendor import chardet + +from . import __version__ as requests_version + +try: + from pip._vendor.urllib3.contrib import pyopenssl +except ImportError: + pyopenssl = None + OpenSSL = None + cryptography = None +else: + import OpenSSL + import cryptography + + +def _implementation(): + """Return a dict with the Python implementation and version. + + Provide both the name and the version of the Python implementation + currently running. For example, on CPython 2.7.5 it will return + {'name': 'CPython', 'version': '2.7.5'}. + + This function works best on CPython and PyPy: in particular, it probably + doesn't work for Jython or IronPython. Future investigation should be done + to work out the correct shape of the code for those platforms. + """ + implementation = platform.python_implementation() + + if implementation == 'CPython': + implementation_version = platform.python_version() + elif implementation == 'PyPy': + implementation_version = '%s.%s.%s' % (sys.pypy_version_info.major, + sys.pypy_version_info.minor, + sys.pypy_version_info.micro) + if sys.pypy_version_info.releaselevel != 'final': + implementation_version = ''.join([ + implementation_version, sys.pypy_version_info.releaselevel + ]) + elif implementation == 'Jython': + implementation_version = platform.python_version() # Complete Guess + elif implementation == 'IronPython': + implementation_version = platform.python_version() # Complete Guess + else: + implementation_version = 'Unknown' + + return {'name': implementation, 'version': implementation_version} + + +def info(): + """Generate information for a bug report.""" + try: + platform_info = { + 'system': platform.system(), + 'release': platform.release(), + } + except IOError: + platform_info = { + 'system': 'Unknown', + 'release': 'Unknown', + } + + implementation_info = _implementation() + urllib3_info = {'version': urllib3.__version__} + chardet_info = {'version': chardet.__version__} + + pyopenssl_info = { + 'version': None, + 'openssl_version': '', + } + if OpenSSL: + pyopenssl_info = { + 'version': OpenSSL.__version__, + 'openssl_version': '%x' % OpenSSL.SSL.OPENSSL_VERSION_NUMBER, + } + cryptography_info = { + 'version': getattr(cryptography, '__version__', ''), + } + idna_info = { + 'version': getattr(idna, '__version__', ''), + } + + system_ssl = ssl.OPENSSL_VERSION_NUMBER + system_ssl_info = { + 'version': '%x' % system_ssl if system_ssl is not None else '' + } + + return { + 'platform': platform_info, + 'implementation': implementation_info, + 'system_ssl': system_ssl_info, + 'using_pyopenssl': pyopenssl is not None, + 'pyOpenSSL': pyopenssl_info, + 'urllib3': urllib3_info, + 'chardet': chardet_info, + 'cryptography': cryptography_info, + 'idna': idna_info, + 'requests': { + 'version': requests_version, + }, + } + + +def main(): + """Pretty-print the bug information as JSON.""" + print(json.dumps(info(), sort_keys=True, indent=2)) + + +if __name__ == '__main__': + main() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/hooks.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/hooks.py new file mode 100644 index 0000000..7a51f21 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/hooks.py @@ -0,0 +1,34 @@ +# -*- coding: utf-8 -*- + +""" +requests.hooks +~~~~~~~~~~~~~~ + +This module provides the capabilities for the Requests hooks system. + +Available hooks: + +``response``: + The response generated from a Request. +""" +HOOKS = ['response'] + + +def default_hooks(): + return {event: [] for event in HOOKS} + +# TODO: response is the only one + + +def dispatch_hook(key, hooks, hook_data, **kwargs): + """Dispatches a hook dictionary on a given piece of data.""" + hooks = hooks or {} + hooks = hooks.get(key) + if hooks: + if hasattr(hooks, '__call__'): + hooks = [hooks] + for hook in hooks: + _hook_data = hook(hook_data, **kwargs) + if _hook_data is not None: + hook_data = _hook_data + return hook_data diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/models.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/models.py new file mode 100644 index 0000000..0839957 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/models.py @@ -0,0 +1,953 @@ +# -*- coding: utf-8 -*- + +""" +requests.models +~~~~~~~~~~~~~~~ + +This module contains the primary objects that power Requests. +""" + +import datetime +import sys + +# Import encoding now, to avoid implicit import later. +# Implicit import within threads may cause LookupError when standard library is in a ZIP, +# such as in Embedded Python. See https://github.com/requests/requests/issues/3578. +import encodings.idna + +from pip._vendor.urllib3.fields import RequestField +from pip._vendor.urllib3.filepost import encode_multipart_formdata +from pip._vendor.urllib3.util import parse_url +from pip._vendor.urllib3.exceptions import ( + DecodeError, ReadTimeoutError, ProtocolError, LocationParseError) + +from io import UnsupportedOperation +from .hooks import default_hooks +from .structures import CaseInsensitiveDict + +from .auth import HTTPBasicAuth +from .cookies import cookiejar_from_dict, get_cookie_header, _copy_cookie_jar +from .exceptions import ( + HTTPError, MissingSchema, InvalidURL, ChunkedEncodingError, + ContentDecodingError, ConnectionError, StreamConsumedError) +from ._internal_utils import to_native_string, unicode_is_ascii +from .utils import ( + guess_filename, get_auth_from_url, requote_uri, + stream_decode_response_unicode, to_key_val_list, parse_header_links, + iter_slices, guess_json_utf, super_len, check_header_validity) +from .compat import ( + Callable, Mapping, + cookielib, urlunparse, urlsplit, urlencode, str, bytes, + is_py2, chardet, builtin_str, basestring) +from .compat import json as complexjson +from .status_codes import codes + +#: The set of HTTP status codes that indicate an automatically +#: processable redirect. +REDIRECT_STATI = ( + codes.moved, # 301 + codes.found, # 302 + codes.other, # 303 + codes.temporary_redirect, # 307 + codes.permanent_redirect, # 308 +) + +DEFAULT_REDIRECT_LIMIT = 30 +CONTENT_CHUNK_SIZE = 10 * 1024 +ITER_CHUNK_SIZE = 512 + + +class RequestEncodingMixin(object): + @property + def path_url(self): + """Build the path URL to use.""" + + url = [] + + p = urlsplit(self.url) + + path = p.path + if not path: + path = '/' + + url.append(path) + + query = p.query + if query: + url.append('?') + url.append(query) + + return ''.join(url) + + @staticmethod + def _encode_params(data): + """Encode parameters in a piece of data. + + Will successfully encode parameters when passed as a dict or a list of + 2-tuples. Order is retained if data is a list of 2-tuples but arbitrary + if parameters are supplied as a dict. + """ + + if isinstance(data, (str, bytes)): + return data + elif hasattr(data, 'read'): + return data + elif hasattr(data, '__iter__'): + result = [] + for k, vs in to_key_val_list(data): + if isinstance(vs, basestring) or not hasattr(vs, '__iter__'): + vs = [vs] + for v in vs: + if v is not None: + result.append( + (k.encode('utf-8') if isinstance(k, str) else k, + v.encode('utf-8') if isinstance(v, str) else v)) + return urlencode(result, doseq=True) + else: + return data + + @staticmethod + def _encode_files(files, data): + """Build the body for a multipart/form-data request. + + Will successfully encode files when passed as a dict or a list of + tuples. Order is retained if data is a list of tuples but arbitrary + if parameters are supplied as a dict. + The tuples may be 2-tuples (filename, fileobj), 3-tuples (filename, fileobj, contentype) + or 4-tuples (filename, fileobj, contentype, custom_headers). + """ + if (not files): + raise ValueError("Files must be provided.") + elif isinstance(data, basestring): + raise ValueError("Data must not be a string.") + + new_fields = [] + fields = to_key_val_list(data or {}) + files = to_key_val_list(files or {}) + + for field, val in fields: + if isinstance(val, basestring) or not hasattr(val, '__iter__'): + val = [val] + for v in val: + if v is not None: + # Don't call str() on bytestrings: in Py3 it all goes wrong. + if not isinstance(v, bytes): + v = str(v) + + new_fields.append( + (field.decode('utf-8') if isinstance(field, bytes) else field, + v.encode('utf-8') if isinstance(v, str) else v)) + + for (k, v) in files: + # support for explicit filename + ft = None + fh = None + if isinstance(v, (tuple, list)): + if len(v) == 2: + fn, fp = v + elif len(v) == 3: + fn, fp, ft = v + else: + fn, fp, ft, fh = v + else: + fn = guess_filename(v) or k + fp = v + + if isinstance(fp, (str, bytes, bytearray)): + fdata = fp + elif hasattr(fp, 'read'): + fdata = fp.read() + elif fp is None: + continue + else: + fdata = fp + + rf = RequestField(name=k, data=fdata, filename=fn, headers=fh) + rf.make_multipart(content_type=ft) + new_fields.append(rf) + + body, content_type = encode_multipart_formdata(new_fields) + + return body, content_type + + +class RequestHooksMixin(object): + def register_hook(self, event, hook): + """Properly register a hook.""" + + if event not in self.hooks: + raise ValueError('Unsupported event specified, with event name "%s"' % (event)) + + if isinstance(hook, Callable): + self.hooks[event].append(hook) + elif hasattr(hook, '__iter__'): + self.hooks[event].extend(h for h in hook if isinstance(h, Callable)) + + def deregister_hook(self, event, hook): + """Deregister a previously registered hook. + Returns True if the hook existed, False if not. + """ + + try: + self.hooks[event].remove(hook) + return True + except ValueError: + return False + + +class Request(RequestHooksMixin): + """A user-created :class:`Request <Request>` object. + + Used to prepare a :class:`PreparedRequest <PreparedRequest>`, which is sent to the server. + + :param method: HTTP method to use. + :param url: URL to send. + :param headers: dictionary of headers to send. + :param files: dictionary of {filename: fileobject} files to multipart upload. + :param data: the body to attach to the request. If a dictionary or + list of tuples ``[(key, value)]`` is provided, form-encoding will + take place. + :param json: json for the body to attach to the request (if files or data is not specified). + :param params: URL parameters to append to the URL. If a dictionary or + list of tuples ``[(key, value)]`` is provided, form-encoding will + take place. + :param auth: Auth handler or (user, pass) tuple. + :param cookies: dictionary or CookieJar of cookies to attach to this request. + :param hooks: dictionary of callback hooks, for internal usage. + + Usage:: + + >>> import requests + >>> req = requests.Request('GET', 'https://httpbin.org/get') + >>> req.prepare() + <PreparedRequest [GET]> + """ + + def __init__(self, + method=None, url=None, headers=None, files=None, data=None, + params=None, auth=None, cookies=None, hooks=None, json=None): + + # Default empty dicts for dict params. + data = [] if data is None else data + files = [] if files is None else files + headers = {} if headers is None else headers + params = {} if params is None else params + hooks = {} if hooks is None else hooks + + self.hooks = default_hooks() + for (k, v) in list(hooks.items()): + self.register_hook(event=k, hook=v) + + self.method = method + self.url = url + self.headers = headers + self.files = files + self.data = data + self.json = json + self.params = params + self.auth = auth + self.cookies = cookies + + def __repr__(self): + return '<Request [%s]>' % (self.method) + + def prepare(self): + """Constructs a :class:`PreparedRequest <PreparedRequest>` for transmission and returns it.""" + p = PreparedRequest() + p.prepare( + method=self.method, + url=self.url, + headers=self.headers, + files=self.files, + data=self.data, + json=self.json, + params=self.params, + auth=self.auth, + cookies=self.cookies, + hooks=self.hooks, + ) + return p + + +class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): + """The fully mutable :class:`PreparedRequest <PreparedRequest>` object, + containing the exact bytes that will be sent to the server. + + Generated from either a :class:`Request <Request>` object or manually. + + Usage:: + + >>> import requests + >>> req = requests.Request('GET', 'https://httpbin.org/get') + >>> r = req.prepare() + <PreparedRequest [GET]> + + >>> s = requests.Session() + >>> s.send(r) + <Response [200]> + """ + + def __init__(self): + #: HTTP verb to send to the server. + self.method = None + #: HTTP URL to send the request to. + self.url = None + #: dictionary of HTTP headers. + self.headers = None + # The `CookieJar` used to create the Cookie header will be stored here + # after prepare_cookies is called + self._cookies = None + #: request body to send to the server. + self.body = None + #: dictionary of callback hooks, for internal usage. + self.hooks = default_hooks() + #: integer denoting starting position of a readable file-like body. + self._body_position = None + + def prepare(self, + method=None, url=None, headers=None, files=None, data=None, + params=None, auth=None, cookies=None, hooks=None, json=None): + """Prepares the entire request with the given parameters.""" + + self.prepare_method(method) + self.prepare_url(url, params) + self.prepare_headers(headers) + self.prepare_cookies(cookies) + self.prepare_body(data, files, json) + self.prepare_auth(auth, url) + + # Note that prepare_auth must be last to enable authentication schemes + # such as OAuth to work on a fully prepared request. + + # This MUST go after prepare_auth. Authenticators could add a hook + self.prepare_hooks(hooks) + + def __repr__(self): + return '<PreparedRequest [%s]>' % (self.method) + + def copy(self): + p = PreparedRequest() + p.method = self.method + p.url = self.url + p.headers = self.headers.copy() if self.headers is not None else None + p._cookies = _copy_cookie_jar(self._cookies) + p.body = self.body + p.hooks = self.hooks + p._body_position = self._body_position + return p + + def prepare_method(self, method): + """Prepares the given HTTP method.""" + self.method = method + if self.method is not None: + self.method = to_native_string(self.method.upper()) + + @staticmethod + def _get_idna_encoded_host(host): + from pip._vendor import idna + + try: + host = idna.encode(host, uts46=True).decode('utf-8') + except idna.IDNAError: + raise UnicodeError + return host + + def prepare_url(self, url, params): + """Prepares the given HTTP URL.""" + #: Accept objects that have string representations. + #: We're unable to blindly call unicode/str functions + #: as this will include the bytestring indicator (b'') + #: on python 3.x. + #: https://github.com/requests/requests/pull/2238 + if isinstance(url, bytes): + url = url.decode('utf8') + else: + url = unicode(url) if is_py2 else str(url) + + # Remove leading whitespaces from url + url = url.lstrip() + + # Don't do any URL preparation for non-HTTP schemes like `mailto`, + # `data` etc to work around exceptions from `url_parse`, which + # handles RFC 3986 only. + if ':' in url and not url.lower().startswith('http'): + self.url = url + return + + # Support for unicode domain names and paths. + try: + scheme, auth, host, port, path, query, fragment = parse_url(url) + except LocationParseError as e: + raise InvalidURL(*e.args) + + if not scheme: + error = ("Invalid URL {0!r}: No schema supplied. Perhaps you meant http://{0}?") + error = error.format(to_native_string(url, 'utf8')) + + raise MissingSchema(error) + + if not host: + raise InvalidURL("Invalid URL %r: No host supplied" % url) + + # In general, we want to try IDNA encoding the hostname if the string contains + # non-ASCII characters. This allows users to automatically get the correct IDNA + # behaviour. For strings containing only ASCII characters, we need to also verify + # it doesn't start with a wildcard (*), before allowing the unencoded hostname. + if not unicode_is_ascii(host): + try: + host = self._get_idna_encoded_host(host) + except UnicodeError: + raise InvalidURL('URL has an invalid label.') + elif host.startswith(u'*'): + raise InvalidURL('URL has an invalid label.') + + # Carefully reconstruct the network location + netloc = auth or '' + if netloc: + netloc += '@' + netloc += host + if port: + netloc += ':' + str(port) + + # Bare domains aren't valid URLs. + if not path: + path = '/' + + if is_py2: + if isinstance(scheme, str): + scheme = scheme.encode('utf-8') + if isinstance(netloc, str): + netloc = netloc.encode('utf-8') + if isinstance(path, str): + path = path.encode('utf-8') + if isinstance(query, str): + query = query.encode('utf-8') + if isinstance(fragment, str): + fragment = fragment.encode('utf-8') + + if isinstance(params, (str, bytes)): + params = to_native_string(params) + + enc_params = self._encode_params(params) + if enc_params: + if query: + query = '%s&%s' % (query, enc_params) + else: + query = enc_params + + url = requote_uri(urlunparse([scheme, netloc, path, None, query, fragment])) + self.url = url + + def prepare_headers(self, headers): + """Prepares the given HTTP headers.""" + + self.headers = CaseInsensitiveDict() + if headers: + for header in headers.items(): + # Raise exception on invalid header value. + check_header_validity(header) + name, value = header + self.headers[to_native_string(name)] = value + + def prepare_body(self, data, files, json=None): + """Prepares the given HTTP body data.""" + + # Check if file, fo, generator, iterator. + # If not, run through normal process. + + # Nottin' on you. + body = None + content_type = None + + if not data and json is not None: + # urllib3 requires a bytes-like body. Python 2's json.dumps + # provides this natively, but Python 3 gives a Unicode string. + content_type = 'application/json' + body = complexjson.dumps(json) + if not isinstance(body, bytes): + body = body.encode('utf-8') + + is_stream = all([ + hasattr(data, '__iter__'), + not isinstance(data, (basestring, list, tuple, Mapping)) + ]) + + try: + length = super_len(data) + except (TypeError, AttributeError, UnsupportedOperation): + length = None + + if is_stream: + body = data + + if getattr(body, 'tell', None) is not None: + # Record the current file position before reading. + # This will allow us to rewind a file in the event + # of a redirect. + try: + self._body_position = body.tell() + except (IOError, OSError): + # This differentiates from None, allowing us to catch + # a failed `tell()` later when trying to rewind the body + self._body_position = object() + + if files: + raise NotImplementedError('Streamed bodies and files are mutually exclusive.') + + if length: + self.headers['Content-Length'] = builtin_str(length) + else: + self.headers['Transfer-Encoding'] = 'chunked' + else: + # Multi-part file uploads. + if files: + (body, content_type) = self._encode_files(files, data) + else: + if data: + body = self._encode_params(data) + if isinstance(data, basestring) or hasattr(data, 'read'): + content_type = None + else: + content_type = 'application/x-www-form-urlencoded' + + self.prepare_content_length(body) + + # Add content-type if it wasn't explicitly provided. + if content_type and ('content-type' not in self.headers): + self.headers['Content-Type'] = content_type + + self.body = body + + def prepare_content_length(self, body): + """Prepare Content-Length header based on request method and body""" + if body is not None: + length = super_len(body) + if length: + # If length exists, set it. Otherwise, we fallback + # to Transfer-Encoding: chunked. + self.headers['Content-Length'] = builtin_str(length) + elif self.method not in ('GET', 'HEAD') and self.headers.get('Content-Length') is None: + # Set Content-Length to 0 for methods that can have a body + # but don't provide one. (i.e. not GET or HEAD) + self.headers['Content-Length'] = '0' + + def prepare_auth(self, auth, url=''): + """Prepares the given HTTP auth data.""" + + # If no Auth is explicitly provided, extract it from the URL first. + if auth is None: + url_auth = get_auth_from_url(self.url) + auth = url_auth if any(url_auth) else None + + if auth: + if isinstance(auth, tuple) and len(auth) == 2: + # special-case basic HTTP auth + auth = HTTPBasicAuth(*auth) + + # Allow auth to make its changes. + r = auth(self) + + # Update self to reflect the auth changes. + self.__dict__.update(r.__dict__) + + # Recompute Content-Length + self.prepare_content_length(self.body) + + def prepare_cookies(self, cookies): + """Prepares the given HTTP cookie data. + + This function eventually generates a ``Cookie`` header from the + given cookies using cookielib. Due to cookielib's design, the header + will not be regenerated if it already exists, meaning this function + can only be called once for the life of the + :class:`PreparedRequest <PreparedRequest>` object. Any subsequent calls + to ``prepare_cookies`` will have no actual effect, unless the "Cookie" + header is removed beforehand. + """ + if isinstance(cookies, cookielib.CookieJar): + self._cookies = cookies + else: + self._cookies = cookiejar_from_dict(cookies) + + cookie_header = get_cookie_header(self._cookies, self) + if cookie_header is not None: + self.headers['Cookie'] = cookie_header + + def prepare_hooks(self, hooks): + """Prepares the given hooks.""" + # hooks can be passed as None to the prepare method and to this + # method. To prevent iterating over None, simply use an empty list + # if hooks is False-y + hooks = hooks or [] + for event in hooks: + self.register_hook(event, hooks[event]) + + +class Response(object): + """The :class:`Response <Response>` object, which contains a + server's response to an HTTP request. + """ + + __attrs__ = [ + '_content', 'status_code', 'headers', 'url', 'history', + 'encoding', 'reason', 'cookies', 'elapsed', 'request' + ] + + def __init__(self): + self._content = False + self._content_consumed = False + self._next = None + + #: Integer Code of responded HTTP Status, e.g. 404 or 200. + self.status_code = None + + #: Case-insensitive Dictionary of Response Headers. + #: For example, ``headers['content-encoding']`` will return the + #: value of a ``'Content-Encoding'`` response header. + self.headers = CaseInsensitiveDict() + + #: File-like object representation of response (for advanced usage). + #: Use of ``raw`` requires that ``stream=True`` be set on the request. + # This requirement does not apply for use internally to Requests. + self.raw = None + + #: Final URL location of Response. + self.url = None + + #: Encoding to decode with when accessing r.text. + self.encoding = None + + #: A list of :class:`Response <Response>` objects from + #: the history of the Request. Any redirect responses will end + #: up here. The list is sorted from the oldest to the most recent request. + self.history = [] + + #: Textual reason of responded HTTP Status, e.g. "Not Found" or "OK". + self.reason = None + + #: A CookieJar of Cookies the server sent back. + self.cookies = cookiejar_from_dict({}) + + #: The amount of time elapsed between sending the request + #: and the arrival of the response (as a timedelta). + #: This property specifically measures the time taken between sending + #: the first byte of the request and finishing parsing the headers. It + #: is therefore unaffected by consuming the response content or the + #: value of the ``stream`` keyword argument. + self.elapsed = datetime.timedelta(0) + + #: The :class:`PreparedRequest <PreparedRequest>` object to which this + #: is a response. + self.request = None + + def __enter__(self): + return self + + def __exit__(self, *args): + self.close() + + def __getstate__(self): + # Consume everything; accessing the content attribute makes + # sure the content has been fully read. + if not self._content_consumed: + self.content + + return {attr: getattr(self, attr, None) for attr in self.__attrs__} + + def __setstate__(self, state): + for name, value in state.items(): + setattr(self, name, value) + + # pickled objects do not have .raw + setattr(self, '_content_consumed', True) + setattr(self, 'raw', None) + + def __repr__(self): + return '<Response [%s]>' % (self.status_code) + + def __bool__(self): + """Returns True if :attr:`status_code` is less than 400. + + This attribute checks if the status code of the response is between + 400 and 600 to see if there was a client error or a server error. If + the status code, is between 200 and 400, this will return True. This + is **not** a check to see if the response code is ``200 OK``. + """ + return self.ok + + def __nonzero__(self): + """Returns True if :attr:`status_code` is less than 400. + + This attribute checks if the status code of the response is between + 400 and 600 to see if there was a client error or a server error. If + the status code, is between 200 and 400, this will return True. This + is **not** a check to see if the response code is ``200 OK``. + """ + return self.ok + + def __iter__(self): + """Allows you to use a response as an iterator.""" + return self.iter_content(128) + + @property + def ok(self): + """Returns True if :attr:`status_code` is less than 400, False if not. + + This attribute checks if the status code of the response is between + 400 and 600 to see if there was a client error or a server error. If + the status code is between 200 and 400, this will return True. This + is **not** a check to see if the response code is ``200 OK``. + """ + try: + self.raise_for_status() + except HTTPError: + return False + return True + + @property + def is_redirect(self): + """True if this Response is a well-formed HTTP redirect that could have + been processed automatically (by :meth:`Session.resolve_redirects`). + """ + return ('location' in self.headers and self.status_code in REDIRECT_STATI) + + @property + def is_permanent_redirect(self): + """True if this Response one of the permanent versions of redirect.""" + return ('location' in self.headers and self.status_code in (codes.moved_permanently, codes.permanent_redirect)) + + @property + def next(self): + """Returns a PreparedRequest for the next request in a redirect chain, if there is one.""" + return self._next + + @property + def apparent_encoding(self): + """The apparent encoding, provided by the chardet library.""" + return chardet.detect(self.content)['encoding'] + + def iter_content(self, chunk_size=1, decode_unicode=False): + """Iterates over the response data. When stream=True is set on the + request, this avoids reading the content at once into memory for + large responses. The chunk size is the number of bytes it should + read into memory. This is not necessarily the length of each item + returned as decoding can take place. + + chunk_size must be of type int or None. A value of None will + function differently depending on the value of `stream`. + stream=True will read data as it arrives in whatever size the + chunks are received. If stream=False, data is returned as + a single chunk. + + If decode_unicode is True, content will be decoded using the best + available encoding based on the response. + """ + + def generate(): + # Special case for urllib3. + if hasattr(self.raw, 'stream'): + try: + for chunk in self.raw.stream(chunk_size, decode_content=True): + yield chunk + except ProtocolError as e: + raise ChunkedEncodingError(e) + except DecodeError as e: + raise ContentDecodingError(e) + except ReadTimeoutError as e: + raise ConnectionError(e) + else: + # Standard file-like object. + while True: + chunk = self.raw.read(chunk_size) + if not chunk: + break + yield chunk + + self._content_consumed = True + + if self._content_consumed and isinstance(self._content, bool): + raise StreamConsumedError() + elif chunk_size is not None and not isinstance(chunk_size, int): + raise TypeError("chunk_size must be an int, it is instead a %s." % type(chunk_size)) + # simulate reading small chunks of the content + reused_chunks = iter_slices(self._content, chunk_size) + + stream_chunks = generate() + + chunks = reused_chunks if self._content_consumed else stream_chunks + + if decode_unicode: + chunks = stream_decode_response_unicode(chunks, self) + + return chunks + + def iter_lines(self, chunk_size=ITER_CHUNK_SIZE, decode_unicode=False, delimiter=None): + """Iterates over the response data, one line at a time. When + stream=True is set on the request, this avoids reading the + content at once into memory for large responses. + + .. note:: This method is not reentrant safe. + """ + + pending = None + + for chunk in self.iter_content(chunk_size=chunk_size, decode_unicode=decode_unicode): + + if pending is not None: + chunk = pending + chunk + + if delimiter: + lines = chunk.split(delimiter) + else: + lines = chunk.splitlines() + + if lines and lines[-1] and chunk and lines[-1][-1] == chunk[-1]: + pending = lines.pop() + else: + pending = None + + for line in lines: + yield line + + if pending is not None: + yield pending + + @property + def content(self): + """Content of the response, in bytes.""" + + if self._content is False: + # Read the contents. + if self._content_consumed: + raise RuntimeError( + 'The content for this response was already consumed') + + if self.status_code == 0 or self.raw is None: + self._content = None + else: + self._content = b''.join(self.iter_content(CONTENT_CHUNK_SIZE)) or b'' + + self._content_consumed = True + # don't need to release the connection; that's been handled by urllib3 + # since we exhausted the data. + return self._content + + @property + def text(self): + """Content of the response, in unicode. + + If Response.encoding is None, encoding will be guessed using + ``chardet``. + + The encoding of the response content is determined based solely on HTTP + headers, following RFC 2616 to the letter. If you can take advantage of + non-HTTP knowledge to make a better guess at the encoding, you should + set ``r.encoding`` appropriately before accessing this property. + """ + + # Try charset from content-type + content = None + encoding = self.encoding + + if not self.content: + return str('') + + # Fallback to auto-detected encoding. + if self.encoding is None: + encoding = self.apparent_encoding + + # Decode unicode from given encoding. + try: + content = str(self.content, encoding, errors='replace') + except (LookupError, TypeError): + # A LookupError is raised if the encoding was not found which could + # indicate a misspelling or similar mistake. + # + # A TypeError can be raised if encoding is None + # + # So we try blindly encoding. + content = str(self.content, errors='replace') + + return content + + def json(self, **kwargs): + r"""Returns the json-encoded content of a response, if any. + + :param \*\*kwargs: Optional arguments that ``json.loads`` takes. + :raises ValueError: If the response body does not contain valid json. + """ + + if not self.encoding and self.content and len(self.content) > 3: + # No encoding set. JSON RFC 4627 section 3 states we should expect + # UTF-8, -16 or -32. Detect which one to use; If the detection or + # decoding fails, fall back to `self.text` (using chardet to make + # a best guess). + encoding = guess_json_utf(self.content) + if encoding is not None: + try: + return complexjson.loads( + self.content.decode(encoding), **kwargs + ) + except UnicodeDecodeError: + # Wrong UTF codec detected; usually because it's not UTF-8 + # but some other 8-bit codec. This is an RFC violation, + # and the server didn't bother to tell us what codec *was* + # used. + pass + return complexjson.loads(self.text, **kwargs) + + @property + def links(self): + """Returns the parsed header links of the response, if any.""" + + header = self.headers.get('link') + + # l = MultiDict() + l = {} + + if header: + links = parse_header_links(header) + + for link in links: + key = link.get('rel') or link.get('url') + l[key] = link + + return l + + def raise_for_status(self): + """Raises stored :class:`HTTPError`, if one occurred.""" + + http_error_msg = '' + if isinstance(self.reason, bytes): + # We attempt to decode utf-8 first because some servers + # choose to localize their reason strings. If the string + # isn't utf-8, we fall back to iso-8859-1 for all other + # encodings. (See PR #3538) + try: + reason = self.reason.decode('utf-8') + except UnicodeDecodeError: + reason = self.reason.decode('iso-8859-1') + else: + reason = self.reason + + if 400 <= self.status_code < 500: + http_error_msg = u'%s Client Error: %s for url: %s' % (self.status_code, reason, self.url) + + elif 500 <= self.status_code < 600: + http_error_msg = u'%s Server Error: %s for url: %s' % (self.status_code, reason, self.url) + + if http_error_msg: + raise HTTPError(http_error_msg, response=self) + + def close(self): + """Releases the connection back to the pool. Once this method has been + called the underlying ``raw`` object must not be accessed again. + + *Note: Should not normally need to be called explicitly.* + """ + if not self._content_consumed: + self.raw.close() + + release_conn = getattr(self.raw, 'release_conn', None) + if release_conn is not None: + release_conn() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/packages.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/packages.py new file mode 100644 index 0000000..9582fa7 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/packages.py @@ -0,0 +1,16 @@ +import sys + +# This code exists for backwards compatibility reasons. +# I don't like it either. Just look the other way. :) + +for package in ('urllib3', 'idna', 'chardet'): + vendored_package = "pip._vendor." + package + locals()[package] = __import__(vendored_package) + # This traversal is apparently necessary such that the identities are + # preserved (requests.packages.urllib3.* is urllib3.*) + for mod in list(sys.modules): + if mod == vendored_package or mod.startswith(vendored_package + '.'): + unprefixed_mod = mod[len("pip._vendor."):] + sys.modules['pip._vendor.requests.packages.' + unprefixed_mod] = sys.modules[mod] + +# Kinda cool, though, right? diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/sessions.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/sessions.py new file mode 100644 index 0000000..d73d700 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/sessions.py @@ -0,0 +1,770 @@ +# -*- coding: utf-8 -*- + +""" +requests.session +~~~~~~~~~~~~~~~~ + +This module provides a Session object to manage and persist settings across +requests (cookies, auth, proxies). +""" +import os +import sys +import time +from datetime import timedelta + +from .auth import _basic_auth_str +from .compat import cookielib, is_py3, OrderedDict, urljoin, urlparse, Mapping +from .cookies import ( + cookiejar_from_dict, extract_cookies_to_jar, RequestsCookieJar, merge_cookies) +from .models import Request, PreparedRequest, DEFAULT_REDIRECT_LIMIT +from .hooks import default_hooks, dispatch_hook +from ._internal_utils import to_native_string +from .utils import to_key_val_list, default_headers, DEFAULT_PORTS +from .exceptions import ( + TooManyRedirects, InvalidSchema, ChunkedEncodingError, ContentDecodingError) + +from .structures import CaseInsensitiveDict +from .adapters import HTTPAdapter + +from .utils import ( + requote_uri, get_environ_proxies, get_netrc_auth, should_bypass_proxies, + get_auth_from_url, rewind_body +) + +from .status_codes import codes + +# formerly defined here, reexposed here for backward compatibility +from .models import REDIRECT_STATI + +# Preferred clock, based on which one is more accurate on a given system. +if sys.platform == 'win32': + try: # Python 3.4+ + preferred_clock = time.perf_counter + except AttributeError: # Earlier than Python 3. + preferred_clock = time.clock +else: + preferred_clock = time.time + + +def merge_setting(request_setting, session_setting, dict_class=OrderedDict): + """Determines appropriate setting for a given request, taking into account + the explicit setting on that request, and the setting in the session. If a + setting is a dictionary, they will be merged together using `dict_class` + """ + + if session_setting is None: + return request_setting + + if request_setting is None: + return session_setting + + # Bypass if not a dictionary (e.g. verify) + if not ( + isinstance(session_setting, Mapping) and + isinstance(request_setting, Mapping) + ): + return request_setting + + merged_setting = dict_class(to_key_val_list(session_setting)) + merged_setting.update(to_key_val_list(request_setting)) + + # Remove keys that are set to None. Extract keys first to avoid altering + # the dictionary during iteration. + none_keys = [k for (k, v) in merged_setting.items() if v is None] + for key in none_keys: + del merged_setting[key] + + return merged_setting + + +def merge_hooks(request_hooks, session_hooks, dict_class=OrderedDict): + """Properly merges both requests and session hooks. + + This is necessary because when request_hooks == {'response': []}, the + merge breaks Session hooks entirely. + """ + if session_hooks is None or session_hooks.get('response') == []: + return request_hooks + + if request_hooks is None or request_hooks.get('response') == []: + return session_hooks + + return merge_setting(request_hooks, session_hooks, dict_class) + + +class SessionRedirectMixin(object): + + def get_redirect_target(self, resp): + """Receives a Response. Returns a redirect URI or ``None``""" + # Due to the nature of how requests processes redirects this method will + # be called at least once upon the original response and at least twice + # on each subsequent redirect response (if any). + # If a custom mixin is used to handle this logic, it may be advantageous + # to cache the redirect location onto the response object as a private + # attribute. + if resp.is_redirect: + location = resp.headers['location'] + # Currently the underlying http module on py3 decode headers + # in latin1, but empirical evidence suggests that latin1 is very + # rarely used with non-ASCII characters in HTTP headers. + # It is more likely to get UTF8 header rather than latin1. + # This causes incorrect handling of UTF8 encoded location headers. + # To solve this, we re-encode the location in latin1. + if is_py3: + location = location.encode('latin1') + return to_native_string(location, 'utf8') + return None + + def should_strip_auth(self, old_url, new_url): + """Decide whether Authorization header should be removed when redirecting""" + old_parsed = urlparse(old_url) + new_parsed = urlparse(new_url) + if old_parsed.hostname != new_parsed.hostname: + return True + # Special case: allow http -> https redirect when using the standard + # ports. This isn't specified by RFC 7235, but is kept to avoid + # breaking backwards compatibility with older versions of requests + # that allowed any redirects on the same host. + if (old_parsed.scheme == 'http' and old_parsed.port in (80, None) + and new_parsed.scheme == 'https' and new_parsed.port in (443, None)): + return False + + # Handle default port usage corresponding to scheme. + changed_port = old_parsed.port != new_parsed.port + changed_scheme = old_parsed.scheme != new_parsed.scheme + default_port = (DEFAULT_PORTS.get(old_parsed.scheme, None), None) + if (not changed_scheme and old_parsed.port in default_port + and new_parsed.port in default_port): + return False + + # Standard case: root URI must match + return changed_port or changed_scheme + + def resolve_redirects(self, resp, req, stream=False, timeout=None, + verify=True, cert=None, proxies=None, yield_requests=False, **adapter_kwargs): + """Receives a Response. Returns a generator of Responses or Requests.""" + + hist = [] # keep track of history + + url = self.get_redirect_target(resp) + previous_fragment = urlparse(req.url).fragment + while url: + prepared_request = req.copy() + + # Update history and keep track of redirects. + # resp.history must ignore the original request in this loop + hist.append(resp) + resp.history = hist[1:] + + try: + resp.content # Consume socket so it can be released + except (ChunkedEncodingError, ContentDecodingError, RuntimeError): + resp.raw.read(decode_content=False) + + if len(resp.history) >= self.max_redirects: + raise TooManyRedirects('Exceeded %s redirects.' % self.max_redirects, response=resp) + + # Release the connection back into the pool. + resp.close() + + # Handle redirection without scheme (see: RFC 1808 Section 4) + if url.startswith('//'): + parsed_rurl = urlparse(resp.url) + url = '%s:%s' % (to_native_string(parsed_rurl.scheme), url) + + # Normalize url case and attach previous fragment if needed (RFC 7231 7.1.2) + parsed = urlparse(url) + if parsed.fragment == '' and previous_fragment: + parsed = parsed._replace(fragment=previous_fragment) + elif parsed.fragment: + previous_fragment = parsed.fragment + url = parsed.geturl() + + # Facilitate relative 'location' headers, as allowed by RFC 7231. + # (e.g. '/path/to/resource' instead of 'http://domain.tld/path/to/resource') + # Compliant with RFC3986, we percent encode the url. + if not parsed.netloc: + url = urljoin(resp.url, requote_uri(url)) + else: + url = requote_uri(url) + + prepared_request.url = to_native_string(url) + + self.rebuild_method(prepared_request, resp) + + # https://github.com/requests/requests/issues/1084 + if resp.status_code not in (codes.temporary_redirect, codes.permanent_redirect): + # https://github.com/requests/requests/issues/3490 + purged_headers = ('Content-Length', 'Content-Type', 'Transfer-Encoding') + for header in purged_headers: + prepared_request.headers.pop(header, None) + prepared_request.body = None + + headers = prepared_request.headers + try: + del headers['Cookie'] + except KeyError: + pass + + # Extract any cookies sent on the response to the cookiejar + # in the new request. Because we've mutated our copied prepared + # request, use the old one that we haven't yet touched. + extract_cookies_to_jar(prepared_request._cookies, req, resp.raw) + merge_cookies(prepared_request._cookies, self.cookies) + prepared_request.prepare_cookies(prepared_request._cookies) + + # Rebuild auth and proxy information. + proxies = self.rebuild_proxies(prepared_request, proxies) + self.rebuild_auth(prepared_request, resp) + + # A failed tell() sets `_body_position` to `object()`. This non-None + # value ensures `rewindable` will be True, allowing us to raise an + # UnrewindableBodyError, instead of hanging the connection. + rewindable = ( + prepared_request._body_position is not None and + ('Content-Length' in headers or 'Transfer-Encoding' in headers) + ) + + # Attempt to rewind consumed file-like object. + if rewindable: + rewind_body(prepared_request) + + # Override the original request. + req = prepared_request + + if yield_requests: + yield req + else: + + resp = self.send( + req, + stream=stream, + timeout=timeout, + verify=verify, + cert=cert, + proxies=proxies, + allow_redirects=False, + **adapter_kwargs + ) + + extract_cookies_to_jar(self.cookies, prepared_request, resp.raw) + + # extract redirect url, if any, for the next loop + url = self.get_redirect_target(resp) + yield resp + + def rebuild_auth(self, prepared_request, response): + """When being redirected we may want to strip authentication from the + request to avoid leaking credentials. This method intelligently removes + and reapplies authentication where possible to avoid credential loss. + """ + headers = prepared_request.headers + url = prepared_request.url + + if 'Authorization' in headers and self.should_strip_auth(response.request.url, url): + # If we get redirected to a new host, we should strip out any + # authentication headers. + del headers['Authorization'] + + # .netrc might have more auth for us on our new host. + new_auth = get_netrc_auth(url) if self.trust_env else None + if new_auth is not None: + prepared_request.prepare_auth(new_auth) + + return + + def rebuild_proxies(self, prepared_request, proxies): + """This method re-evaluates the proxy configuration by considering the + environment variables. If we are redirected to a URL covered by + NO_PROXY, we strip the proxy configuration. Otherwise, we set missing + proxy keys for this URL (in case they were stripped by a previous + redirect). + + This method also replaces the Proxy-Authorization header where + necessary. + + :rtype: dict + """ + proxies = proxies if proxies is not None else {} + headers = prepared_request.headers + url = prepared_request.url + scheme = urlparse(url).scheme + new_proxies = proxies.copy() + no_proxy = proxies.get('no_proxy') + + bypass_proxy = should_bypass_proxies(url, no_proxy=no_proxy) + if self.trust_env and not bypass_proxy: + environ_proxies = get_environ_proxies(url, no_proxy=no_proxy) + + proxy = environ_proxies.get(scheme, environ_proxies.get('all')) + + if proxy: + new_proxies.setdefault(scheme, proxy) + + if 'Proxy-Authorization' in headers: + del headers['Proxy-Authorization'] + + try: + username, password = get_auth_from_url(new_proxies[scheme]) + except KeyError: + username, password = None, None + + if username and password: + headers['Proxy-Authorization'] = _basic_auth_str(username, password) + + return new_proxies + + def rebuild_method(self, prepared_request, response): + """When being redirected we may want to change the method of the request + based on certain specs or browser behavior. + """ + method = prepared_request.method + + # https://tools.ietf.org/html/rfc7231#section-6.4.4 + if response.status_code == codes.see_other and method != 'HEAD': + method = 'GET' + + # Do what the browsers do, despite standards... + # First, turn 302s into GETs. + if response.status_code == codes.found and method != 'HEAD': + method = 'GET' + + # Second, if a POST is responded to with a 301, turn it into a GET. + # This bizarre behaviour is explained in Issue 1704. + if response.status_code == codes.moved and method == 'POST': + method = 'GET' + + prepared_request.method = method + + +class Session(SessionRedirectMixin): + """A Requests session. + + Provides cookie persistence, connection-pooling, and configuration. + + Basic Usage:: + + >>> import requests + >>> s = requests.Session() + >>> s.get('https://httpbin.org/get') + <Response [200]> + + Or as a context manager:: + + >>> with requests.Session() as s: + >>> s.get('https://httpbin.org/get') + <Response [200]> + """ + + __attrs__ = [ + 'headers', 'cookies', 'auth', 'proxies', 'hooks', 'params', 'verify', + 'cert', 'prefetch', 'adapters', 'stream', 'trust_env', + 'max_redirects', + ] + + def __init__(self): + + #: A case-insensitive dictionary of headers to be sent on each + #: :class:`Request <Request>` sent from this + #: :class:`Session <Session>`. + self.headers = default_headers() + + #: Default Authentication tuple or object to attach to + #: :class:`Request <Request>`. + self.auth = None + + #: Dictionary mapping protocol or protocol and host to the URL of the proxy + #: (e.g. {'http': 'foo.bar:3128', 'http://host.name': 'foo.bar:4012'}) to + #: be used on each :class:`Request <Request>`. + self.proxies = {} + + #: Event-handling hooks. + self.hooks = default_hooks() + + #: Dictionary of querystring data to attach to each + #: :class:`Request <Request>`. The dictionary values may be lists for + #: representing multivalued query parameters. + self.params = {} + + #: Stream response content default. + self.stream = False + + #: SSL Verification default. + self.verify = True + + #: SSL client certificate default, if String, path to ssl client + #: cert file (.pem). If Tuple, ('cert', 'key') pair. + self.cert = None + + #: Maximum number of redirects allowed. If the request exceeds this + #: limit, a :class:`TooManyRedirects` exception is raised. + #: This defaults to requests.models.DEFAULT_REDIRECT_LIMIT, which is + #: 30. + self.max_redirects = DEFAULT_REDIRECT_LIMIT + + #: Trust environment settings for proxy configuration, default + #: authentication and similar. + self.trust_env = True + + #: A CookieJar containing all currently outstanding cookies set on this + #: session. By default it is a + #: :class:`RequestsCookieJar <requests.cookies.RequestsCookieJar>`, but + #: may be any other ``cookielib.CookieJar`` compatible object. + self.cookies = cookiejar_from_dict({}) + + # Default connection adapters. + self.adapters = OrderedDict() + self.mount('https://', HTTPAdapter()) + self.mount('http://', HTTPAdapter()) + + def __enter__(self): + return self + + def __exit__(self, *args): + self.close() + + def prepare_request(self, request): + """Constructs a :class:`PreparedRequest <PreparedRequest>` for + transmission and returns it. The :class:`PreparedRequest` has settings + merged from the :class:`Request <Request>` instance and those of the + :class:`Session`. + + :param request: :class:`Request` instance to prepare with this + session's settings. + :rtype: requests.PreparedRequest + """ + cookies = request.cookies or {} + + # Bootstrap CookieJar. + if not isinstance(cookies, cookielib.CookieJar): + cookies = cookiejar_from_dict(cookies) + + # Merge with session cookies + merged_cookies = merge_cookies( + merge_cookies(RequestsCookieJar(), self.cookies), cookies) + + # Set environment's basic authentication if not explicitly set. + auth = request.auth + if self.trust_env and not auth and not self.auth: + auth = get_netrc_auth(request.url) + + p = PreparedRequest() + p.prepare( + method=request.method.upper(), + url=request.url, + files=request.files, + data=request.data, + json=request.json, + headers=merge_setting(request.headers, self.headers, dict_class=CaseInsensitiveDict), + params=merge_setting(request.params, self.params), + auth=merge_setting(auth, self.auth), + cookies=merged_cookies, + hooks=merge_hooks(request.hooks, self.hooks), + ) + return p + + def request(self, method, url, + params=None, data=None, headers=None, cookies=None, files=None, + auth=None, timeout=None, allow_redirects=True, proxies=None, + hooks=None, stream=None, verify=None, cert=None, json=None): + """Constructs a :class:`Request <Request>`, prepares it and sends it. + Returns :class:`Response <Response>` object. + + :param method: method for the new :class:`Request` object. + :param url: URL for the new :class:`Request` object. + :param params: (optional) Dictionary or bytes to be sent in the query + string for the :class:`Request`. + :param data: (optional) Dictionary, list of tuples, bytes, or file-like + object to send in the body of the :class:`Request`. + :param json: (optional) json to send in the body of the + :class:`Request`. + :param headers: (optional) Dictionary of HTTP Headers to send with the + :class:`Request`. + :param cookies: (optional) Dict or CookieJar object to send with the + :class:`Request`. + :param files: (optional) Dictionary of ``'filename': file-like-objects`` + for multipart encoding upload. + :param auth: (optional) Auth tuple or callable to enable + Basic/Digest/Custom HTTP Auth. + :param timeout: (optional) How long to wait for the server to send + data before giving up, as a float, or a :ref:`(connect timeout, + read timeout) <timeouts>` tuple. + :type timeout: float or tuple + :param allow_redirects: (optional) Set to True by default. + :type allow_redirects: bool + :param proxies: (optional) Dictionary mapping protocol or protocol and + hostname to the URL of the proxy. + :param stream: (optional) whether to immediately download the response + content. Defaults to ``False``. + :param verify: (optional) Either a boolean, in which case it controls whether we verify + the server's TLS certificate, or a string, in which case it must be a path + to a CA bundle to use. Defaults to ``True``. + :param cert: (optional) if String, path to ssl client cert file (.pem). + If Tuple, ('cert', 'key') pair. + :rtype: requests.Response + """ + # Create the Request. + req = Request( + method=method.upper(), + url=url, + headers=headers, + files=files, + data=data or {}, + json=json, + params=params or {}, + auth=auth, + cookies=cookies, + hooks=hooks, + ) + prep = self.prepare_request(req) + + proxies = proxies or {} + + settings = self.merge_environment_settings( + prep.url, proxies, stream, verify, cert + ) + + # Send the request. + send_kwargs = { + 'timeout': timeout, + 'allow_redirects': allow_redirects, + } + send_kwargs.update(settings) + resp = self.send(prep, **send_kwargs) + + return resp + + def get(self, url, **kwargs): + r"""Sends a GET request. Returns :class:`Response` object. + + :param url: URL for the new :class:`Request` object. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :rtype: requests.Response + """ + + kwargs.setdefault('allow_redirects', True) + return self.request('GET', url, **kwargs) + + def options(self, url, **kwargs): + r"""Sends a OPTIONS request. Returns :class:`Response` object. + + :param url: URL for the new :class:`Request` object. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :rtype: requests.Response + """ + + kwargs.setdefault('allow_redirects', True) + return self.request('OPTIONS', url, **kwargs) + + def head(self, url, **kwargs): + r"""Sends a HEAD request. Returns :class:`Response` object. + + :param url: URL for the new :class:`Request` object. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :rtype: requests.Response + """ + + kwargs.setdefault('allow_redirects', False) + return self.request('HEAD', url, **kwargs) + + def post(self, url, data=None, json=None, **kwargs): + r"""Sends a POST request. Returns :class:`Response` object. + + :param url: URL for the new :class:`Request` object. + :param data: (optional) Dictionary, list of tuples, bytes, or file-like + object to send in the body of the :class:`Request`. + :param json: (optional) json to send in the body of the :class:`Request`. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :rtype: requests.Response + """ + + return self.request('POST', url, data=data, json=json, **kwargs) + + def put(self, url, data=None, **kwargs): + r"""Sends a PUT request. Returns :class:`Response` object. + + :param url: URL for the new :class:`Request` object. + :param data: (optional) Dictionary, list of tuples, bytes, or file-like + object to send in the body of the :class:`Request`. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :rtype: requests.Response + """ + + return self.request('PUT', url, data=data, **kwargs) + + def patch(self, url, data=None, **kwargs): + r"""Sends a PATCH request. Returns :class:`Response` object. + + :param url: URL for the new :class:`Request` object. + :param data: (optional) Dictionary, list of tuples, bytes, or file-like + object to send in the body of the :class:`Request`. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :rtype: requests.Response + """ + + return self.request('PATCH', url, data=data, **kwargs) + + def delete(self, url, **kwargs): + r"""Sends a DELETE request. Returns :class:`Response` object. + + :param url: URL for the new :class:`Request` object. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :rtype: requests.Response + """ + + return self.request('DELETE', url, **kwargs) + + def send(self, request, **kwargs): + """Send a given PreparedRequest. + + :rtype: requests.Response + """ + # Set defaults that the hooks can utilize to ensure they always have + # the correct parameters to reproduce the previous request. + kwargs.setdefault('stream', self.stream) + kwargs.setdefault('verify', self.verify) + kwargs.setdefault('cert', self.cert) + kwargs.setdefault('proxies', self.proxies) + + # It's possible that users might accidentally send a Request object. + # Guard against that specific failure case. + if isinstance(request, Request): + raise ValueError('You can only send PreparedRequests.') + + # Set up variables needed for resolve_redirects and dispatching of hooks + allow_redirects = kwargs.pop('allow_redirects', True) + stream = kwargs.get('stream') + hooks = request.hooks + + # Get the appropriate adapter to use + adapter = self.get_adapter(url=request.url) + + # Start time (approximately) of the request + start = preferred_clock() + + # Send the request + r = adapter.send(request, **kwargs) + + # Total elapsed time of the request (approximately) + elapsed = preferred_clock() - start + r.elapsed = timedelta(seconds=elapsed) + + # Response manipulation hooks + r = dispatch_hook('response', hooks, r, **kwargs) + + # Persist cookies + if r.history: + + # If the hooks create history then we want those cookies too + for resp in r.history: + extract_cookies_to_jar(self.cookies, resp.request, resp.raw) + + extract_cookies_to_jar(self.cookies, request, r.raw) + + # Redirect resolving generator. + gen = self.resolve_redirects(r, request, **kwargs) + + # Resolve redirects if allowed. + history = [resp for resp in gen] if allow_redirects else [] + + # Shuffle things around if there's history. + if history: + # Insert the first (original) request at the start + history.insert(0, r) + # Get the last request made + r = history.pop() + r.history = history + + # If redirects aren't being followed, store the response on the Request for Response.next(). + if not allow_redirects: + try: + r._next = next(self.resolve_redirects(r, request, yield_requests=True, **kwargs)) + except StopIteration: + pass + + if not stream: + r.content + + return r + + def merge_environment_settings(self, url, proxies, stream, verify, cert): + """ + Check the environment and merge it with some settings. + + :rtype: dict + """ + # Gather clues from the surrounding environment. + if self.trust_env: + # Set environment's proxies. + no_proxy = proxies.get('no_proxy') if proxies is not None else None + env_proxies = get_environ_proxies(url, no_proxy=no_proxy) + for (k, v) in env_proxies.items(): + proxies.setdefault(k, v) + + # Look for requests environment configuration and be compatible + # with cURL. + if verify is True or verify is None: + verify = (os.environ.get('REQUESTS_CA_BUNDLE') or + os.environ.get('CURL_CA_BUNDLE')) + + # Merge all the kwargs. + proxies = merge_setting(proxies, self.proxies) + stream = merge_setting(stream, self.stream) + verify = merge_setting(verify, self.verify) + cert = merge_setting(cert, self.cert) + + return {'verify': verify, 'proxies': proxies, 'stream': stream, + 'cert': cert} + + def get_adapter(self, url): + """ + Returns the appropriate connection adapter for the given URL. + + :rtype: requests.adapters.BaseAdapter + """ + for (prefix, adapter) in self.adapters.items(): + + if url.lower().startswith(prefix.lower()): + return adapter + + # Nothing matches :-/ + raise InvalidSchema("No connection adapters were found for '%s'" % url) + + def close(self): + """Closes all adapters and as such the session""" + for v in self.adapters.values(): + v.close() + + def mount(self, prefix, adapter): + """Registers a connection adapter to a prefix. + + Adapters are sorted in descending order by prefix length. + """ + self.adapters[prefix] = adapter + keys_to_move = [k for k in self.adapters if len(k) < len(prefix)] + + for key in keys_to_move: + self.adapters[key] = self.adapters.pop(key) + + def __getstate__(self): + state = {attr: getattr(self, attr, None) for attr in self.__attrs__} + return state + + def __setstate__(self, state): + for attr, value in state.items(): + setattr(self, attr, value) + + +def session(): + """ + Returns a :class:`Session` for context-management. + + .. deprecated:: 1.0.0 + + This method has been deprecated since version 1.0.0 and is only kept for + backwards compatibility. New code should use :class:`~requests.sessions.Session` + to create a session. This may be removed at a future date. + + :rtype: Session + """ + return Session() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/status_codes.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/status_codes.py new file mode 100644 index 0000000..813e8c4 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/status_codes.py @@ -0,0 +1,120 @@ +# -*- coding: utf-8 -*- + +r""" +The ``codes`` object defines a mapping from common names for HTTP statuses +to their numerical codes, accessible either as attributes or as dictionary +items. + +>>> requests.codes['temporary_redirect'] +307 +>>> requests.codes.teapot +418 +>>> requests.codes['\o/'] +200 + +Some codes have multiple names, and both upper- and lower-case versions of +the names are allowed. For example, ``codes.ok``, ``codes.OK``, and +``codes.okay`` all correspond to the HTTP status code 200. +""" + +from .structures import LookupDict + +_codes = { + + # Informational. + 100: ('continue',), + 101: ('switching_protocols',), + 102: ('processing',), + 103: ('checkpoint',), + 122: ('uri_too_long', 'request_uri_too_long'), + 200: ('ok', 'okay', 'all_ok', 'all_okay', 'all_good', '\\o/', '✓'), + 201: ('created',), + 202: ('accepted',), + 203: ('non_authoritative_info', 'non_authoritative_information'), + 204: ('no_content',), + 205: ('reset_content', 'reset'), + 206: ('partial_content', 'partial'), + 207: ('multi_status', 'multiple_status', 'multi_stati', 'multiple_stati'), + 208: ('already_reported',), + 226: ('im_used',), + + # Redirection. + 300: ('multiple_choices',), + 301: ('moved_permanently', 'moved', '\\o-'), + 302: ('found',), + 303: ('see_other', 'other'), + 304: ('not_modified',), + 305: ('use_proxy',), + 306: ('switch_proxy',), + 307: ('temporary_redirect', 'temporary_moved', 'temporary'), + 308: ('permanent_redirect', + 'resume_incomplete', 'resume',), # These 2 to be removed in 3.0 + + # Client Error. + 400: ('bad_request', 'bad'), + 401: ('unauthorized',), + 402: ('payment_required', 'payment'), + 403: ('forbidden',), + 404: ('not_found', '-o-'), + 405: ('method_not_allowed', 'not_allowed'), + 406: ('not_acceptable',), + 407: ('proxy_authentication_required', 'proxy_auth', 'proxy_authentication'), + 408: ('request_timeout', 'timeout'), + 409: ('conflict',), + 410: ('gone',), + 411: ('length_required',), + 412: ('precondition_failed', 'precondition'), + 413: ('request_entity_too_large',), + 414: ('request_uri_too_large',), + 415: ('unsupported_media_type', 'unsupported_media', 'media_type'), + 416: ('requested_range_not_satisfiable', 'requested_range', 'range_not_satisfiable'), + 417: ('expectation_failed',), + 418: ('im_a_teapot', 'teapot', 'i_am_a_teapot'), + 421: ('misdirected_request',), + 422: ('unprocessable_entity', 'unprocessable'), + 423: ('locked',), + 424: ('failed_dependency', 'dependency'), + 425: ('unordered_collection', 'unordered'), + 426: ('upgrade_required', 'upgrade'), + 428: ('precondition_required', 'precondition'), + 429: ('too_many_requests', 'too_many'), + 431: ('header_fields_too_large', 'fields_too_large'), + 444: ('no_response', 'none'), + 449: ('retry_with', 'retry'), + 450: ('blocked_by_windows_parental_controls', 'parental_controls'), + 451: ('unavailable_for_legal_reasons', 'legal_reasons'), + 499: ('client_closed_request',), + + # Server Error. + 500: ('internal_server_error', 'server_error', '/o\\', '✗'), + 501: ('not_implemented',), + 502: ('bad_gateway',), + 503: ('service_unavailable', 'unavailable'), + 504: ('gateway_timeout',), + 505: ('http_version_not_supported', 'http_version'), + 506: ('variant_also_negotiates',), + 507: ('insufficient_storage',), + 509: ('bandwidth_limit_exceeded', 'bandwidth'), + 510: ('not_extended',), + 511: ('network_authentication_required', 'network_auth', 'network_authentication'), +} + +codes = LookupDict(name='status_codes') + +def _init(): + for code, titles in _codes.items(): + for title in titles: + setattr(codes, title, code) + if not title.startswith(('\\', '/')): + setattr(codes, title.upper(), code) + + def doc(code): + names = ', '.join('``%s``' % n for n in _codes[code]) + return '* %d: %s' % (code, names) + + global __doc__ + __doc__ = (__doc__ + '\n' + + '\n'.join(doc(code) for code in sorted(_codes)) + if __doc__ is not None else None) + +_init() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/structures.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/structures.py new file mode 100644 index 0000000..da930e2 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/structures.py @@ -0,0 +1,103 @@ +# -*- coding: utf-8 -*- + +""" +requests.structures +~~~~~~~~~~~~~~~~~~~ + +Data structures that power Requests. +""" + +from .compat import OrderedDict, Mapping, MutableMapping + + +class CaseInsensitiveDict(MutableMapping): + """A case-insensitive ``dict``-like object. + + Implements all methods and operations of + ``MutableMapping`` as well as dict's ``copy``. Also + provides ``lower_items``. + + All keys are expected to be strings. The structure remembers the + case of the last key to be set, and ``iter(instance)``, + ``keys()``, ``items()``, ``iterkeys()``, and ``iteritems()`` + will contain case-sensitive keys. However, querying and contains + testing is case insensitive:: + + cid = CaseInsensitiveDict() + cid['Accept'] = 'application/json' + cid['aCCEPT'] == 'application/json' # True + list(cid) == ['Accept'] # True + + For example, ``headers['content-encoding']`` will return the + value of a ``'Content-Encoding'`` response header, regardless + of how the header name was originally stored. + + If the constructor, ``.update``, or equality comparison + operations are given keys that have equal ``.lower()``s, the + behavior is undefined. + """ + + def __init__(self, data=None, **kwargs): + self._store = OrderedDict() + if data is None: + data = {} + self.update(data, **kwargs) + + def __setitem__(self, key, value): + # Use the lowercased key for lookups, but store the actual + # key alongside the value. + self._store[key.lower()] = (key, value) + + def __getitem__(self, key): + return self._store[key.lower()][1] + + def __delitem__(self, key): + del self._store[key.lower()] + + def __iter__(self): + return (casedkey for casedkey, mappedvalue in self._store.values()) + + def __len__(self): + return len(self._store) + + def lower_items(self): + """Like iteritems(), but with all lowercase keys.""" + return ( + (lowerkey, keyval[1]) + for (lowerkey, keyval) + in self._store.items() + ) + + def __eq__(self, other): + if isinstance(other, Mapping): + other = CaseInsensitiveDict(other) + else: + return NotImplemented + # Compare insensitively + return dict(self.lower_items()) == dict(other.lower_items()) + + # Copy is required + def copy(self): + return CaseInsensitiveDict(self._store.values()) + + def __repr__(self): + return str(dict(self.items())) + + +class LookupDict(dict): + """Dictionary lookup object.""" + + def __init__(self, name=None): + self.name = name + super(LookupDict, self).__init__() + + def __repr__(self): + return '<lookup \'%s\'>' % (self.name) + + def __getitem__(self, key): + # We allow fall-through here, so values default to None + + return self.__dict__.get(key, None) + + def get(self, key, default=None): + return self.__dict__.get(key, default) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/utils.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/utils.py new file mode 100644 index 0000000..8170a8d --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/requests/utils.py @@ -0,0 +1,977 @@ +# -*- coding: utf-8 -*- + +""" +requests.utils +~~~~~~~~~~~~~~ + +This module provides utility functions that are used within Requests +that are also useful for external consumption. +""" + +import codecs +import contextlib +import io +import os +import re +import socket +import struct +import sys +import tempfile +import warnings +import zipfile + +from .__version__ import __version__ +from . import certs +# to_native_string is unused here, but imported here for backwards compatibility +from ._internal_utils import to_native_string +from .compat import parse_http_list as _parse_list_header +from .compat import ( + quote, urlparse, bytes, str, OrderedDict, unquote, getproxies, + proxy_bypass, urlunparse, basestring, integer_types, is_py3, + proxy_bypass_environment, getproxies_environment, Mapping) +from .cookies import cookiejar_from_dict +from .structures import CaseInsensitiveDict +from .exceptions import ( + InvalidURL, InvalidHeader, FileModeWarning, UnrewindableBodyError) + +NETRC_FILES = ('.netrc', '_netrc') + +DEFAULT_CA_BUNDLE_PATH = certs.where() + +DEFAULT_PORTS = {'http': 80, 'https': 443} + + +if sys.platform == 'win32': + # provide a proxy_bypass version on Windows without DNS lookups + + def proxy_bypass_registry(host): + try: + if is_py3: + import winreg + else: + import _winreg as winreg + except ImportError: + return False + + try: + internetSettings = winreg.OpenKey(winreg.HKEY_CURRENT_USER, + r'Software\Microsoft\Windows\CurrentVersion\Internet Settings') + # ProxyEnable could be REG_SZ or REG_DWORD, normalizing it + proxyEnable = int(winreg.QueryValueEx(internetSettings, + 'ProxyEnable')[0]) + # ProxyOverride is almost always a string + proxyOverride = winreg.QueryValueEx(internetSettings, + 'ProxyOverride')[0] + except OSError: + return False + if not proxyEnable or not proxyOverride: + return False + + # make a check value list from the registry entry: replace the + # '<local>' string by the localhost entry and the corresponding + # canonical entry. + proxyOverride = proxyOverride.split(';') + # now check if we match one of the registry values. + for test in proxyOverride: + if test == '<local>': + if '.' not in host: + return True + test = test.replace(".", r"\.") # mask dots + test = test.replace("*", r".*") # change glob sequence + test = test.replace("?", r".") # change glob char + if re.match(test, host, re.I): + return True + return False + + def proxy_bypass(host): # noqa + """Return True, if the host should be bypassed. + + Checks proxy settings gathered from the environment, if specified, + or the registry. + """ + if getproxies_environment(): + return proxy_bypass_environment(host) + else: + return proxy_bypass_registry(host) + + +def dict_to_sequence(d): + """Returns an internal sequence dictionary update.""" + + if hasattr(d, 'items'): + d = d.items() + + return d + + +def super_len(o): + total_length = None + current_position = 0 + + if hasattr(o, '__len__'): + total_length = len(o) + + elif hasattr(o, 'len'): + total_length = o.len + + elif hasattr(o, 'fileno'): + try: + fileno = o.fileno() + except io.UnsupportedOperation: + pass + else: + total_length = os.fstat(fileno).st_size + + # Having used fstat to determine the file length, we need to + # confirm that this file was opened up in binary mode. + if 'b' not in o.mode: + warnings.warn(( + "Requests has determined the content-length for this " + "request using the binary size of the file: however, the " + "file has been opened in text mode (i.e. without the 'b' " + "flag in the mode). This may lead to an incorrect " + "content-length. In Requests 3.0, support will be removed " + "for files in text mode."), + FileModeWarning + ) + + if hasattr(o, 'tell'): + try: + current_position = o.tell() + except (OSError, IOError): + # This can happen in some weird situations, such as when the file + # is actually a special file descriptor like stdin. In this + # instance, we don't know what the length is, so set it to zero and + # let requests chunk it instead. + if total_length is not None: + current_position = total_length + else: + if hasattr(o, 'seek') and total_length is None: + # StringIO and BytesIO have seek but no useable fileno + try: + # seek to end of file + o.seek(0, 2) + total_length = o.tell() + + # seek back to current position to support + # partially read file-like objects + o.seek(current_position or 0) + except (OSError, IOError): + total_length = 0 + + if total_length is None: + total_length = 0 + + return max(0, total_length - current_position) + + +def get_netrc_auth(url, raise_errors=False): + """Returns the Requests tuple auth for a given url from netrc.""" + + try: + from netrc import netrc, NetrcParseError + + netrc_path = None + + for f in NETRC_FILES: + try: + loc = os.path.expanduser('~/{}'.format(f)) + except KeyError: + # os.path.expanduser can fail when $HOME is undefined and + # getpwuid fails. See https://bugs.python.org/issue20164 & + # https://github.com/requests/requests/issues/1846 + return + + if os.path.exists(loc): + netrc_path = loc + break + + # Abort early if there isn't one. + if netrc_path is None: + return + + ri = urlparse(url) + + # Strip port numbers from netloc. This weird `if...encode`` dance is + # used for Python 3.2, which doesn't support unicode literals. + splitstr = b':' + if isinstance(url, str): + splitstr = splitstr.decode('ascii') + host = ri.netloc.split(splitstr)[0] + + try: + _netrc = netrc(netrc_path).authenticators(host) + if _netrc: + # Return with login / password + login_i = (0 if _netrc[0] else 1) + return (_netrc[login_i], _netrc[2]) + except (NetrcParseError, IOError): + # If there was a parsing error or a permissions issue reading the file, + # we'll just skip netrc auth unless explicitly asked to raise errors. + if raise_errors: + raise + + # AppEngine hackiness. + except (ImportError, AttributeError): + pass + + +def guess_filename(obj): + """Tries to guess the filename of the given object.""" + name = getattr(obj, 'name', None) + if (name and isinstance(name, basestring) and name[0] != '<' and + name[-1] != '>'): + return os.path.basename(name) + + +def extract_zipped_paths(path): + """Replace nonexistent paths that look like they refer to a member of a zip + archive with the location of an extracted copy of the target, or else + just return the provided path unchanged. + """ + if os.path.exists(path): + # this is already a valid path, no need to do anything further + return path + + # find the first valid part of the provided path and treat that as a zip archive + # assume the rest of the path is the name of a member in the archive + archive, member = os.path.split(path) + while archive and not os.path.exists(archive): + archive, prefix = os.path.split(archive) + member = '/'.join([prefix, member]) + + if not zipfile.is_zipfile(archive): + return path + + zip_file = zipfile.ZipFile(archive) + if member not in zip_file.namelist(): + return path + + # we have a valid zip archive and a valid member of that archive + tmp = tempfile.gettempdir() + extracted_path = os.path.join(tmp, *member.split('/')) + if not os.path.exists(extracted_path): + extracted_path = zip_file.extract(member, path=tmp) + + return extracted_path + + +def from_key_val_list(value): + """Take an object and test to see if it can be represented as a + dictionary. Unless it can not be represented as such, return an + OrderedDict, e.g., + + :: + + >>> from_key_val_list([('key', 'val')]) + OrderedDict([('key', 'val')]) + >>> from_key_val_list('string') + ValueError: cannot encode objects that are not 2-tuples + >>> from_key_val_list({'key': 'val'}) + OrderedDict([('key', 'val')]) + + :rtype: OrderedDict + """ + if value is None: + return None + + if isinstance(value, (str, bytes, bool, int)): + raise ValueError('cannot encode objects that are not 2-tuples') + + return OrderedDict(value) + + +def to_key_val_list(value): + """Take an object and test to see if it can be represented as a + dictionary. If it can be, return a list of tuples, e.g., + + :: + + >>> to_key_val_list([('key', 'val')]) + [('key', 'val')] + >>> to_key_val_list({'key': 'val'}) + [('key', 'val')] + >>> to_key_val_list('string') + ValueError: cannot encode objects that are not 2-tuples. + + :rtype: list + """ + if value is None: + return None + + if isinstance(value, (str, bytes, bool, int)): + raise ValueError('cannot encode objects that are not 2-tuples') + + if isinstance(value, Mapping): + value = value.items() + + return list(value) + + +# From mitsuhiko/werkzeug (used with permission). +def parse_list_header(value): + """Parse lists as described by RFC 2068 Section 2. + + In particular, parse comma-separated lists where the elements of + the list may include quoted-strings. A quoted-string could + contain a comma. A non-quoted string could have quotes in the + middle. Quotes are removed automatically after parsing. + + It basically works like :func:`parse_set_header` just that items + may appear multiple times and case sensitivity is preserved. + + The return value is a standard :class:`list`: + + >>> parse_list_header('token, "quoted value"') + ['token', 'quoted value'] + + To create a header from the :class:`list` again, use the + :func:`dump_header` function. + + :param value: a string with a list header. + :return: :class:`list` + :rtype: list + """ + result = [] + for item in _parse_list_header(value): + if item[:1] == item[-1:] == '"': + item = unquote_header_value(item[1:-1]) + result.append(item) + return result + + +# From mitsuhiko/werkzeug (used with permission). +def parse_dict_header(value): + """Parse lists of key, value pairs as described by RFC 2068 Section 2 and + convert them into a python dict: + + >>> d = parse_dict_header('foo="is a fish", bar="as well"') + >>> type(d) is dict + True + >>> sorted(d.items()) + [('bar', 'as well'), ('foo', 'is a fish')] + + If there is no value for a key it will be `None`: + + >>> parse_dict_header('key_without_value') + {'key_without_value': None} + + To create a header from the :class:`dict` again, use the + :func:`dump_header` function. + + :param value: a string with a dict header. + :return: :class:`dict` + :rtype: dict + """ + result = {} + for item in _parse_list_header(value): + if '=' not in item: + result[item] = None + continue + name, value = item.split('=', 1) + if value[:1] == value[-1:] == '"': + value = unquote_header_value(value[1:-1]) + result[name] = value + return result + + +# From mitsuhiko/werkzeug (used with permission). +def unquote_header_value(value, is_filename=False): + r"""Unquotes a header value. (Reversal of :func:`quote_header_value`). + This does not use the real unquoting but what browsers are actually + using for quoting. + + :param value: the header value to unquote. + :rtype: str + """ + if value and value[0] == value[-1] == '"': + # this is not the real unquoting, but fixing this so that the + # RFC is met will result in bugs with internet explorer and + # probably some other browsers as well. IE for example is + # uploading files with "C:\foo\bar.txt" as filename + value = value[1:-1] + + # if this is a filename and the starting characters look like + # a UNC path, then just return the value without quotes. Using the + # replace sequence below on a UNC path has the effect of turning + # the leading double slash into a single slash and then + # _fix_ie_filename() doesn't work correctly. See #458. + if not is_filename or value[:2] != '\\\\': + return value.replace('\\\\', '\\').replace('\\"', '"') + return value + + +def dict_from_cookiejar(cj): + """Returns a key/value dictionary from a CookieJar. + + :param cj: CookieJar object to extract cookies from. + :rtype: dict + """ + + cookie_dict = {} + + for cookie in cj: + cookie_dict[cookie.name] = cookie.value + + return cookie_dict + + +def add_dict_to_cookiejar(cj, cookie_dict): + """Returns a CookieJar from a key/value dictionary. + + :param cj: CookieJar to insert cookies into. + :param cookie_dict: Dict of key/values to insert into CookieJar. + :rtype: CookieJar + """ + + return cookiejar_from_dict(cookie_dict, cj) + + +def get_encodings_from_content(content): + """Returns encodings from given content string. + + :param content: bytestring to extract encodings from. + """ + warnings.warn(( + 'In requests 3.0, get_encodings_from_content will be removed. For ' + 'more information, please see the discussion on issue #2266. (This' + ' warning should only appear once.)'), + DeprecationWarning) + + charset_re = re.compile(r'<meta.*?charset=["\']*(.+?)["\'>]', flags=re.I) + pragma_re = re.compile(r'<meta.*?content=["\']*;?charset=(.+?)["\'>]', flags=re.I) + xml_re = re.compile(r'^<\?xml.*?encoding=["\']*(.+?)["\'>]') + + return (charset_re.findall(content) + + pragma_re.findall(content) + + xml_re.findall(content)) + + +def _parse_content_type_header(header): + """Returns content type and parameters from given header + + :param header: string + :return: tuple containing content type and dictionary of + parameters + """ + + tokens = header.split(';') + content_type, params = tokens[0].strip(), tokens[1:] + params_dict = {} + items_to_strip = "\"' " + + for param in params: + param = param.strip() + if param: + key, value = param, True + index_of_equals = param.find("=") + if index_of_equals != -1: + key = param[:index_of_equals].strip(items_to_strip) + value = param[index_of_equals + 1:].strip(items_to_strip) + params_dict[key.lower()] = value + return content_type, params_dict + + +def get_encoding_from_headers(headers): + """Returns encodings from given HTTP Header Dict. + + :param headers: dictionary to extract encoding from. + :rtype: str + """ + + content_type = headers.get('content-type') + + if not content_type: + return None + + content_type, params = _parse_content_type_header(content_type) + + if 'charset' in params: + return params['charset'].strip("'\"") + + if 'text' in content_type: + return 'ISO-8859-1' + + +def stream_decode_response_unicode(iterator, r): + """Stream decodes a iterator.""" + + if r.encoding is None: + for item in iterator: + yield item + return + + decoder = codecs.getincrementaldecoder(r.encoding)(errors='replace') + for chunk in iterator: + rv = decoder.decode(chunk) + if rv: + yield rv + rv = decoder.decode(b'', final=True) + if rv: + yield rv + + +def iter_slices(string, slice_length): + """Iterate over slices of a string.""" + pos = 0 + if slice_length is None or slice_length <= 0: + slice_length = len(string) + while pos < len(string): + yield string[pos:pos + slice_length] + pos += slice_length + + +def get_unicode_from_response(r): + """Returns the requested content back in unicode. + + :param r: Response object to get unicode content from. + + Tried: + + 1. charset from content-type + 2. fall back and replace all unicode characters + + :rtype: str + """ + warnings.warn(( + 'In requests 3.0, get_unicode_from_response will be removed. For ' + 'more information, please see the discussion on issue #2266. (This' + ' warning should only appear once.)'), + DeprecationWarning) + + tried_encodings = [] + + # Try charset from content-type + encoding = get_encoding_from_headers(r.headers) + + if encoding: + try: + return str(r.content, encoding) + except UnicodeError: + tried_encodings.append(encoding) + + # Fall back: + try: + return str(r.content, encoding, errors='replace') + except TypeError: + return r.content + + +# The unreserved URI characters (RFC 3986) +UNRESERVED_SET = frozenset( + "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz" + "0123456789-._~") + + +def unquote_unreserved(uri): + """Un-escape any percent-escape sequences in a URI that are unreserved + characters. This leaves all reserved, illegal and non-ASCII bytes encoded. + + :rtype: str + """ + parts = uri.split('%') + for i in range(1, len(parts)): + h = parts[i][0:2] + if len(h) == 2 and h.isalnum(): + try: + c = chr(int(h, 16)) + except ValueError: + raise InvalidURL("Invalid percent-escape sequence: '%s'" % h) + + if c in UNRESERVED_SET: + parts[i] = c + parts[i][2:] + else: + parts[i] = '%' + parts[i] + else: + parts[i] = '%' + parts[i] + return ''.join(parts) + + +def requote_uri(uri): + """Re-quote the given URI. + + This function passes the given URI through an unquote/quote cycle to + ensure that it is fully and consistently quoted. + + :rtype: str + """ + safe_with_percent = "!#$%&'()*+,/:;=?@[]~" + safe_without_percent = "!#$&'()*+,/:;=?@[]~" + try: + # Unquote only the unreserved characters + # Then quote only illegal characters (do not quote reserved, + # unreserved, or '%') + return quote(unquote_unreserved(uri), safe=safe_with_percent) + except InvalidURL: + # We couldn't unquote the given URI, so let's try quoting it, but + # there may be unquoted '%'s in the URI. We need to make sure they're + # properly quoted so they do not cause issues elsewhere. + return quote(uri, safe=safe_without_percent) + + +def address_in_network(ip, net): + """This function allows you to check if an IP belongs to a network subnet + + Example: returns True if ip = 192.168.1.1 and net = 192.168.1.0/24 + returns False if ip = 192.168.1.1 and net = 192.168.100.0/24 + + :rtype: bool + """ + ipaddr = struct.unpack('=L', socket.inet_aton(ip))[0] + netaddr, bits = net.split('/') + netmask = struct.unpack('=L', socket.inet_aton(dotted_netmask(int(bits))))[0] + network = struct.unpack('=L', socket.inet_aton(netaddr))[0] & netmask + return (ipaddr & netmask) == (network & netmask) + + +def dotted_netmask(mask): + """Converts mask from /xx format to xxx.xxx.xxx.xxx + + Example: if mask is 24 function returns 255.255.255.0 + + :rtype: str + """ + bits = 0xffffffff ^ (1 << 32 - mask) - 1 + return socket.inet_ntoa(struct.pack('>I', bits)) + + +def is_ipv4_address(string_ip): + """ + :rtype: bool + """ + try: + socket.inet_aton(string_ip) + except socket.error: + return False + return True + + +def is_valid_cidr(string_network): + """ + Very simple check of the cidr format in no_proxy variable. + + :rtype: bool + """ + if string_network.count('/') == 1: + try: + mask = int(string_network.split('/')[1]) + except ValueError: + return False + + if mask < 1 or mask > 32: + return False + + try: + socket.inet_aton(string_network.split('/')[0]) + except socket.error: + return False + else: + return False + return True + + +@contextlib.contextmanager +def set_environ(env_name, value): + """Set the environment variable 'env_name' to 'value' + + Save previous value, yield, and then restore the previous value stored in + the environment variable 'env_name'. + + If 'value' is None, do nothing""" + value_changed = value is not None + if value_changed: + old_value = os.environ.get(env_name) + os.environ[env_name] = value + try: + yield + finally: + if value_changed: + if old_value is None: + del os.environ[env_name] + else: + os.environ[env_name] = old_value + + +def should_bypass_proxies(url, no_proxy): + """ + Returns whether we should bypass proxies or not. + + :rtype: bool + """ + # Prioritize lowercase environment variables over uppercase + # to keep a consistent behaviour with other http projects (curl, wget). + get_proxy = lambda k: os.environ.get(k) or os.environ.get(k.upper()) + + # First check whether no_proxy is defined. If it is, check that the URL + # we're getting isn't in the no_proxy list. + no_proxy_arg = no_proxy + if no_proxy is None: + no_proxy = get_proxy('no_proxy') + parsed = urlparse(url) + + if parsed.hostname is None: + # URLs don't always have hostnames, e.g. file:/// urls. + return True + + if no_proxy: + # We need to check whether we match here. We need to see if we match + # the end of the hostname, both with and without the port. + no_proxy = ( + host for host in no_proxy.replace(' ', '').split(',') if host + ) + + if is_ipv4_address(parsed.hostname): + for proxy_ip in no_proxy: + if is_valid_cidr(proxy_ip): + if address_in_network(parsed.hostname, proxy_ip): + return True + elif parsed.hostname == proxy_ip: + # If no_proxy ip was defined in plain IP notation instead of cidr notation & + # matches the IP of the index + return True + else: + host_with_port = parsed.hostname + if parsed.port: + host_with_port += ':{}'.format(parsed.port) + + for host in no_proxy: + if parsed.hostname.endswith(host) or host_with_port.endswith(host): + # The URL does match something in no_proxy, so we don't want + # to apply the proxies on this URL. + return True + + with set_environ('no_proxy', no_proxy_arg): + # parsed.hostname can be `None` in cases such as a file URI. + try: + bypass = proxy_bypass(parsed.hostname) + except (TypeError, socket.gaierror): + bypass = False + + if bypass: + return True + + return False + + +def get_environ_proxies(url, no_proxy=None): + """ + Return a dict of environment proxies. + + :rtype: dict + """ + if should_bypass_proxies(url, no_proxy=no_proxy): + return {} + else: + return getproxies() + + +def select_proxy(url, proxies): + """Select a proxy for the url, if applicable. + + :param url: The url being for the request + :param proxies: A dictionary of schemes or schemes and hosts to proxy URLs + """ + proxies = proxies or {} + urlparts = urlparse(url) + if urlparts.hostname is None: + return proxies.get(urlparts.scheme, proxies.get('all')) + + proxy_keys = [ + urlparts.scheme + '://' + urlparts.hostname, + urlparts.scheme, + 'all://' + urlparts.hostname, + 'all', + ] + proxy = None + for proxy_key in proxy_keys: + if proxy_key in proxies: + proxy = proxies[proxy_key] + break + + return proxy + + +def default_user_agent(name="python-requests"): + """ + Return a string representing the default user agent. + + :rtype: str + """ + return '%s/%s' % (name, __version__) + + +def default_headers(): + """ + :rtype: requests.structures.CaseInsensitiveDict + """ + return CaseInsensitiveDict({ + 'User-Agent': default_user_agent(), + 'Accept-Encoding': ', '.join(('gzip', 'deflate')), + 'Accept': '*/*', + 'Connection': 'keep-alive', + }) + + +def parse_header_links(value): + """Return a list of parsed link headers proxies. + + i.e. Link: <http:/.../front.jpeg>; rel=front; type="image/jpeg",<http://.../back.jpeg>; rel=back;type="image/jpeg" + + :rtype: list + """ + + links = [] + + replace_chars = ' \'"' + + value = value.strip(replace_chars) + if not value: + return links + + for val in re.split(', *<', value): + try: + url, params = val.split(';', 1) + except ValueError: + url, params = val, '' + + link = {'url': url.strip('<> \'"')} + + for param in params.split(';'): + try: + key, value = param.split('=') + except ValueError: + break + + link[key.strip(replace_chars)] = value.strip(replace_chars) + + links.append(link) + + return links + + +# Null bytes; no need to recreate these on each call to guess_json_utf +_null = '\x00'.encode('ascii') # encoding to ASCII for Python 3 +_null2 = _null * 2 +_null3 = _null * 3 + + +def guess_json_utf(data): + """ + :rtype: str + """ + # JSON always starts with two ASCII characters, so detection is as + # easy as counting the nulls and from their location and count + # determine the encoding. Also detect a BOM, if present. + sample = data[:4] + if sample in (codecs.BOM_UTF32_LE, codecs.BOM_UTF32_BE): + return 'utf-32' # BOM included + if sample[:3] == codecs.BOM_UTF8: + return 'utf-8-sig' # BOM included, MS style (discouraged) + if sample[:2] in (codecs.BOM_UTF16_LE, codecs.BOM_UTF16_BE): + return 'utf-16' # BOM included + nullcount = sample.count(_null) + if nullcount == 0: + return 'utf-8' + if nullcount == 2: + if sample[::2] == _null2: # 1st and 3rd are null + return 'utf-16-be' + if sample[1::2] == _null2: # 2nd and 4th are null + return 'utf-16-le' + # Did not detect 2 valid UTF-16 ascii-range characters + if nullcount == 3: + if sample[:3] == _null3: + return 'utf-32-be' + if sample[1:] == _null3: + return 'utf-32-le' + # Did not detect a valid UTF-32 ascii-range character + return None + + +def prepend_scheme_if_needed(url, new_scheme): + """Given a URL that may or may not have a scheme, prepend the given scheme. + Does not replace a present scheme with the one provided as an argument. + + :rtype: str + """ + scheme, netloc, path, params, query, fragment = urlparse(url, new_scheme) + + # urlparse is a finicky beast, and sometimes decides that there isn't a + # netloc present. Assume that it's being over-cautious, and switch netloc + # and path if urlparse decided there was no netloc. + if not netloc: + netloc, path = path, netloc + + return urlunparse((scheme, netloc, path, params, query, fragment)) + + +def get_auth_from_url(url): + """Given a url with authentication components, extract them into a tuple of + username,password. + + :rtype: (str,str) + """ + parsed = urlparse(url) + + try: + auth = (unquote(parsed.username), unquote(parsed.password)) + except (AttributeError, TypeError): + auth = ('', '') + + return auth + + +# Moved outside of function to avoid recompile every call +_CLEAN_HEADER_REGEX_BYTE = re.compile(b'^\\S[^\\r\\n]*$|^$') +_CLEAN_HEADER_REGEX_STR = re.compile(r'^\S[^\r\n]*$|^$') + + +def check_header_validity(header): + """Verifies that header value is a string which doesn't contain + leading whitespace or return characters. This prevents unintended + header injection. + + :param header: tuple, in the format (name, value). + """ + name, value = header + + if isinstance(value, bytes): + pat = _CLEAN_HEADER_REGEX_BYTE + else: + pat = _CLEAN_HEADER_REGEX_STR + try: + if not pat.match(value): + raise InvalidHeader("Invalid return character or leading space in header: %s" % name) + except TypeError: + raise InvalidHeader("Value for header {%s: %s} must be of type str or " + "bytes, not %s" % (name, value, type(value))) + + +def urldefragauth(url): + """ + Given a url remove the fragment and the authentication part. + + :rtype: str + """ + scheme, netloc, path, params, query, fragment = urlparse(url) + + # see func:`prepend_scheme_if_needed` + if not netloc: + netloc, path = path, netloc + + netloc = netloc.rsplit('@', 1)[-1] + + return urlunparse((scheme, netloc, path, params, query, '')) + + +def rewind_body(prepared_request): + """Move file pointer back to its recorded starting position + so it can be read again on redirect. + """ + body_seek = getattr(prepared_request.body, 'seek', None) + if body_seek is not None and isinstance(prepared_request._body_position, integer_types): + try: + body_seek(prepared_request._body_position) + except (IOError, OSError): + raise UnrewindableBodyError("An error occurred when rewinding request " + "body for redirect.") + else: + raise UnrewindableBodyError("Unable to rewind request body for redirect.") diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/retrying.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/retrying.py new file mode 100644 index 0000000..6d1e627 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/retrying.py @@ -0,0 +1,267 @@ +## Copyright 2013-2014 Ray Holder +## +## Licensed under the Apache License, Version 2.0 (the "License"); +## you may not use this file except in compliance with the License. +## You may obtain a copy of the License at +## +## http://www.apache.org/licenses/LICENSE-2.0 +## +## Unless required by applicable law or agreed to in writing, software +## distributed under the License is distributed on an "AS IS" BASIS, +## WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +## See the License for the specific language governing permissions and +## limitations under the License. + +import random +from pip._vendor import six +import sys +import time +import traceback + + +# sys.maxint / 2, since Python 3.2 doesn't have a sys.maxint... +MAX_WAIT = 1073741823 + + +def retry(*dargs, **dkw): + """ + Decorator function that instantiates the Retrying object + @param *dargs: positional arguments passed to Retrying object + @param **dkw: keyword arguments passed to the Retrying object + """ + # support both @retry and @retry() as valid syntax + if len(dargs) == 1 and callable(dargs[0]): + def wrap_simple(f): + + @six.wraps(f) + def wrapped_f(*args, **kw): + return Retrying().call(f, *args, **kw) + + return wrapped_f + + return wrap_simple(dargs[0]) + + else: + def wrap(f): + + @six.wraps(f) + def wrapped_f(*args, **kw): + return Retrying(*dargs, **dkw).call(f, *args, **kw) + + return wrapped_f + + return wrap + + +class Retrying(object): + + def __init__(self, + stop=None, wait=None, + stop_max_attempt_number=None, + stop_max_delay=None, + wait_fixed=None, + wait_random_min=None, wait_random_max=None, + wait_incrementing_start=None, wait_incrementing_increment=None, + wait_exponential_multiplier=None, wait_exponential_max=None, + retry_on_exception=None, + retry_on_result=None, + wrap_exception=False, + stop_func=None, + wait_func=None, + wait_jitter_max=None): + + self._stop_max_attempt_number = 5 if stop_max_attempt_number is None else stop_max_attempt_number + self._stop_max_delay = 100 if stop_max_delay is None else stop_max_delay + self._wait_fixed = 1000 if wait_fixed is None else wait_fixed + self._wait_random_min = 0 if wait_random_min is None else wait_random_min + self._wait_random_max = 1000 if wait_random_max is None else wait_random_max + self._wait_incrementing_start = 0 if wait_incrementing_start is None else wait_incrementing_start + self._wait_incrementing_increment = 100 if wait_incrementing_increment is None else wait_incrementing_increment + self._wait_exponential_multiplier = 1 if wait_exponential_multiplier is None else wait_exponential_multiplier + self._wait_exponential_max = MAX_WAIT if wait_exponential_max is None else wait_exponential_max + self._wait_jitter_max = 0 if wait_jitter_max is None else wait_jitter_max + + # TODO add chaining of stop behaviors + # stop behavior + stop_funcs = [] + if stop_max_attempt_number is not None: + stop_funcs.append(self.stop_after_attempt) + + if stop_max_delay is not None: + stop_funcs.append(self.stop_after_delay) + + if stop_func is not None: + self.stop = stop_func + + elif stop is None: + self.stop = lambda attempts, delay: any(f(attempts, delay) for f in stop_funcs) + + else: + self.stop = getattr(self, stop) + + # TODO add chaining of wait behaviors + # wait behavior + wait_funcs = [lambda *args, **kwargs: 0] + if wait_fixed is not None: + wait_funcs.append(self.fixed_sleep) + + if wait_random_min is not None or wait_random_max is not None: + wait_funcs.append(self.random_sleep) + + if wait_incrementing_start is not None or wait_incrementing_increment is not None: + wait_funcs.append(self.incrementing_sleep) + + if wait_exponential_multiplier is not None or wait_exponential_max is not None: + wait_funcs.append(self.exponential_sleep) + + if wait_func is not None: + self.wait = wait_func + + elif wait is None: + self.wait = lambda attempts, delay: max(f(attempts, delay) for f in wait_funcs) + + else: + self.wait = getattr(self, wait) + + # retry on exception filter + if retry_on_exception is None: + self._retry_on_exception = self.always_reject + else: + self._retry_on_exception = retry_on_exception + + # TODO simplify retrying by Exception types + # retry on result filter + if retry_on_result is None: + self._retry_on_result = self.never_reject + else: + self._retry_on_result = retry_on_result + + self._wrap_exception = wrap_exception + + def stop_after_attempt(self, previous_attempt_number, delay_since_first_attempt_ms): + """Stop after the previous attempt >= stop_max_attempt_number.""" + return previous_attempt_number >= self._stop_max_attempt_number + + def stop_after_delay(self, previous_attempt_number, delay_since_first_attempt_ms): + """Stop after the time from the first attempt >= stop_max_delay.""" + return delay_since_first_attempt_ms >= self._stop_max_delay + + def no_sleep(self, previous_attempt_number, delay_since_first_attempt_ms): + """Don't sleep at all before retrying.""" + return 0 + + def fixed_sleep(self, previous_attempt_number, delay_since_first_attempt_ms): + """Sleep a fixed amount of time between each retry.""" + return self._wait_fixed + + def random_sleep(self, previous_attempt_number, delay_since_first_attempt_ms): + """Sleep a random amount of time between wait_random_min and wait_random_max""" + return random.randint(self._wait_random_min, self._wait_random_max) + + def incrementing_sleep(self, previous_attempt_number, delay_since_first_attempt_ms): + """ + Sleep an incremental amount of time after each attempt, starting at + wait_incrementing_start and incrementing by wait_incrementing_increment + """ + result = self._wait_incrementing_start + (self._wait_incrementing_increment * (previous_attempt_number - 1)) + if result < 0: + result = 0 + return result + + def exponential_sleep(self, previous_attempt_number, delay_since_first_attempt_ms): + exp = 2 ** previous_attempt_number + result = self._wait_exponential_multiplier * exp + if result > self._wait_exponential_max: + result = self._wait_exponential_max + if result < 0: + result = 0 + return result + + def never_reject(self, result): + return False + + def always_reject(self, result): + return True + + def should_reject(self, attempt): + reject = False + if attempt.has_exception: + reject |= self._retry_on_exception(attempt.value[1]) + else: + reject |= self._retry_on_result(attempt.value) + + return reject + + def call(self, fn, *args, **kwargs): + start_time = int(round(time.time() * 1000)) + attempt_number = 1 + while True: + try: + attempt = Attempt(fn(*args, **kwargs), attempt_number, False) + except: + tb = sys.exc_info() + attempt = Attempt(tb, attempt_number, True) + + if not self.should_reject(attempt): + return attempt.get(self._wrap_exception) + + delay_since_first_attempt_ms = int(round(time.time() * 1000)) - start_time + if self.stop(attempt_number, delay_since_first_attempt_ms): + if not self._wrap_exception and attempt.has_exception: + # get() on an attempt with an exception should cause it to be raised, but raise just in case + raise attempt.get() + else: + raise RetryError(attempt) + else: + sleep = self.wait(attempt_number, delay_since_first_attempt_ms) + if self._wait_jitter_max: + jitter = random.random() * self._wait_jitter_max + sleep = sleep + max(0, jitter) + time.sleep(sleep / 1000.0) + + attempt_number += 1 + + +class Attempt(object): + """ + An Attempt encapsulates a call to a target function that may end as a + normal return value from the function or an Exception depending on what + occurred during the execution. + """ + + def __init__(self, value, attempt_number, has_exception): + self.value = value + self.attempt_number = attempt_number + self.has_exception = has_exception + + def get(self, wrap_exception=False): + """ + Return the return value of this Attempt instance or raise an Exception. + If wrap_exception is true, this Attempt is wrapped inside of a + RetryError before being raised. + """ + if self.has_exception: + if wrap_exception: + raise RetryError(self) + else: + six.reraise(self.value[0], self.value[1], self.value[2]) + else: + return self.value + + def __repr__(self): + if self.has_exception: + return "Attempts: {0}, Error:\n{1}".format(self.attempt_number, "".join(traceback.format_tb(self.value[2]))) + else: + return "Attempts: {0}, Value: {1}".format(self.attempt_number, self.value) + + +class RetryError(Exception): + """ + A RetryError encapsulates the last Attempt instance right before giving up. + """ + + def __init__(self, last_attempt): + self.last_attempt = last_attempt + + def __str__(self): + return "RetryError[{0}]".format(self.last_attempt) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/six.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/six.py new file mode 100644 index 0000000..89b2188 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/six.py @@ -0,0 +1,952 @@ +# Copyright (c) 2010-2018 Benjamin Peterson +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in all +# copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. + +"""Utilities for writing code that runs on Python 2 and 3""" + +from __future__ import absolute_import + +import functools +import itertools +import operator +import sys +import types + +__author__ = "Benjamin Peterson <benjamin@python.org>" +__version__ = "1.12.0" + + +# Useful for very coarse version differentiation. +PY2 = sys.version_info[0] == 2 +PY3 = sys.version_info[0] == 3 +PY34 = sys.version_info[0:2] >= (3, 4) + +if PY3: + string_types = str, + integer_types = int, + class_types = type, + text_type = str + binary_type = bytes + + MAXSIZE = sys.maxsize +else: + string_types = basestring, + integer_types = (int, long) + class_types = (type, types.ClassType) + text_type = unicode + binary_type = str + + if sys.platform.startswith("java"): + # Jython always uses 32 bits. + MAXSIZE = int((1 << 31) - 1) + else: + # It's possible to have sizeof(long) != sizeof(Py_ssize_t). + class X(object): + + def __len__(self): + return 1 << 31 + try: + len(X()) + except OverflowError: + # 32-bit + MAXSIZE = int((1 << 31) - 1) + else: + # 64-bit + MAXSIZE = int((1 << 63) - 1) + del X + + +def _add_doc(func, doc): + """Add documentation to a function.""" + func.__doc__ = doc + + +def _import_module(name): + """Import module, returning the module after the last dot.""" + __import__(name) + return sys.modules[name] + + +class _LazyDescr(object): + + def __init__(self, name): + self.name = name + + def __get__(self, obj, tp): + result = self._resolve() + setattr(obj, self.name, result) # Invokes __set__. + try: + # This is a bit ugly, but it avoids running this again by + # removing this descriptor. + delattr(obj.__class__, self.name) + except AttributeError: + pass + return result + + +class MovedModule(_LazyDescr): + + def __init__(self, name, old, new=None): + super(MovedModule, self).__init__(name) + if PY3: + if new is None: + new = name + self.mod = new + else: + self.mod = old + + def _resolve(self): + return _import_module(self.mod) + + def __getattr__(self, attr): + _module = self._resolve() + value = getattr(_module, attr) + setattr(self, attr, value) + return value + + +class _LazyModule(types.ModuleType): + + def __init__(self, name): + super(_LazyModule, self).__init__(name) + self.__doc__ = self.__class__.__doc__ + + def __dir__(self): + attrs = ["__doc__", "__name__"] + attrs += [attr.name for attr in self._moved_attributes] + return attrs + + # Subclasses should override this + _moved_attributes = [] + + +class MovedAttribute(_LazyDescr): + + def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None): + super(MovedAttribute, self).__init__(name) + if PY3: + if new_mod is None: + new_mod = name + self.mod = new_mod + if new_attr is None: + if old_attr is None: + new_attr = name + else: + new_attr = old_attr + self.attr = new_attr + else: + self.mod = old_mod + if old_attr is None: + old_attr = name + self.attr = old_attr + + def _resolve(self): + module = _import_module(self.mod) + return getattr(module, self.attr) + + +class _SixMetaPathImporter(object): + + """ + A meta path importer to import six.moves and its submodules. + + This class implements a PEP302 finder and loader. It should be compatible + with Python 2.5 and all existing versions of Python3 + """ + + def __init__(self, six_module_name): + self.name = six_module_name + self.known_modules = {} + + def _add_module(self, mod, *fullnames): + for fullname in fullnames: + self.known_modules[self.name + "." + fullname] = mod + + def _get_module(self, fullname): + return self.known_modules[self.name + "." + fullname] + + def find_module(self, fullname, path=None): + if fullname in self.known_modules: + return self + return None + + def __get_module(self, fullname): + try: + return self.known_modules[fullname] + except KeyError: + raise ImportError("This loader does not know module " + fullname) + + def load_module(self, fullname): + try: + # in case of a reload + return sys.modules[fullname] + except KeyError: + pass + mod = self.__get_module(fullname) + if isinstance(mod, MovedModule): + mod = mod._resolve() + else: + mod.__loader__ = self + sys.modules[fullname] = mod + return mod + + def is_package(self, fullname): + """ + Return true, if the named module is a package. + + We need this method to get correct spec objects with + Python 3.4 (see PEP451) + """ + return hasattr(self.__get_module(fullname), "__path__") + + def get_code(self, fullname): + """Return None + + Required, if is_package is implemented""" + self.__get_module(fullname) # eventually raises ImportError + return None + get_source = get_code # same as get_code + +_importer = _SixMetaPathImporter(__name__) + + +class _MovedItems(_LazyModule): + + """Lazy loading of moved objects""" + __path__ = [] # mark as package + + +_moved_attributes = [ + MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"), + MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"), + MovedAttribute("filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse"), + MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"), + MovedAttribute("intern", "__builtin__", "sys"), + MovedAttribute("map", "itertools", "builtins", "imap", "map"), + MovedAttribute("getcwd", "os", "os", "getcwdu", "getcwd"), + MovedAttribute("getcwdb", "os", "os", "getcwd", "getcwdb"), + MovedAttribute("getoutput", "commands", "subprocess"), + MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"), + MovedAttribute("reload_module", "__builtin__", "importlib" if PY34 else "imp", "reload"), + MovedAttribute("reduce", "__builtin__", "functools"), + MovedAttribute("shlex_quote", "pipes", "shlex", "quote"), + MovedAttribute("StringIO", "StringIO", "io"), + MovedAttribute("UserDict", "UserDict", "collections"), + MovedAttribute("UserList", "UserList", "collections"), + MovedAttribute("UserString", "UserString", "collections"), + MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"), + MovedAttribute("zip", "itertools", "builtins", "izip", "zip"), + MovedAttribute("zip_longest", "itertools", "itertools", "izip_longest", "zip_longest"), + MovedModule("builtins", "__builtin__"), + MovedModule("configparser", "ConfigParser"), + MovedModule("copyreg", "copy_reg"), + MovedModule("dbm_gnu", "gdbm", "dbm.gnu"), + MovedModule("_dummy_thread", "dummy_thread", "_dummy_thread"), + MovedModule("http_cookiejar", "cookielib", "http.cookiejar"), + MovedModule("http_cookies", "Cookie", "http.cookies"), + MovedModule("html_entities", "htmlentitydefs", "html.entities"), + MovedModule("html_parser", "HTMLParser", "html.parser"), + MovedModule("http_client", "httplib", "http.client"), + MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"), + MovedModule("email_mime_image", "email.MIMEImage", "email.mime.image"), + MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"), + MovedModule("email_mime_nonmultipart", "email.MIMENonMultipart", "email.mime.nonmultipart"), + MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"), + MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"), + MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"), + MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"), + MovedModule("cPickle", "cPickle", "pickle"), + MovedModule("queue", "Queue"), + MovedModule("reprlib", "repr"), + MovedModule("socketserver", "SocketServer"), + MovedModule("_thread", "thread", "_thread"), + MovedModule("tkinter", "Tkinter"), + MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"), + MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"), + MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"), + MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"), + MovedModule("tkinter_tix", "Tix", "tkinter.tix"), + MovedModule("tkinter_ttk", "ttk", "tkinter.ttk"), + MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"), + MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"), + MovedModule("tkinter_colorchooser", "tkColorChooser", + "tkinter.colorchooser"), + MovedModule("tkinter_commondialog", "tkCommonDialog", + "tkinter.commondialog"), + MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"), + MovedModule("tkinter_font", "tkFont", "tkinter.font"), + MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"), + MovedModule("tkinter_tksimpledialog", "tkSimpleDialog", + "tkinter.simpledialog"), + MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"), + MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"), + MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"), + MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"), + MovedModule("xmlrpc_client", "xmlrpclib", "xmlrpc.client"), + MovedModule("xmlrpc_server", "SimpleXMLRPCServer", "xmlrpc.server"), +] +# Add windows specific modules. +if sys.platform == "win32": + _moved_attributes += [ + MovedModule("winreg", "_winreg"), + ] + +for attr in _moved_attributes: + setattr(_MovedItems, attr.name, attr) + if isinstance(attr, MovedModule): + _importer._add_module(attr, "moves." + attr.name) +del attr + +_MovedItems._moved_attributes = _moved_attributes + +moves = _MovedItems(__name__ + ".moves") +_importer._add_module(moves, "moves") + + +class Module_six_moves_urllib_parse(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_parse""" + + +_urllib_parse_moved_attributes = [ + MovedAttribute("ParseResult", "urlparse", "urllib.parse"), + MovedAttribute("SplitResult", "urlparse", "urllib.parse"), + MovedAttribute("parse_qs", "urlparse", "urllib.parse"), + MovedAttribute("parse_qsl", "urlparse", "urllib.parse"), + MovedAttribute("urldefrag", "urlparse", "urllib.parse"), + MovedAttribute("urljoin", "urlparse", "urllib.parse"), + MovedAttribute("urlparse", "urlparse", "urllib.parse"), + MovedAttribute("urlsplit", "urlparse", "urllib.parse"), + MovedAttribute("urlunparse", "urlparse", "urllib.parse"), + MovedAttribute("urlunsplit", "urlparse", "urllib.parse"), + MovedAttribute("quote", "urllib", "urllib.parse"), + MovedAttribute("quote_plus", "urllib", "urllib.parse"), + MovedAttribute("unquote", "urllib", "urllib.parse"), + MovedAttribute("unquote_plus", "urllib", "urllib.parse"), + MovedAttribute("unquote_to_bytes", "urllib", "urllib.parse", "unquote", "unquote_to_bytes"), + MovedAttribute("urlencode", "urllib", "urllib.parse"), + MovedAttribute("splitquery", "urllib", "urllib.parse"), + MovedAttribute("splittag", "urllib", "urllib.parse"), + MovedAttribute("splituser", "urllib", "urllib.parse"), + MovedAttribute("splitvalue", "urllib", "urllib.parse"), + MovedAttribute("uses_fragment", "urlparse", "urllib.parse"), + MovedAttribute("uses_netloc", "urlparse", "urllib.parse"), + MovedAttribute("uses_params", "urlparse", "urllib.parse"), + MovedAttribute("uses_query", "urlparse", "urllib.parse"), + MovedAttribute("uses_relative", "urlparse", "urllib.parse"), +] +for attr in _urllib_parse_moved_attributes: + setattr(Module_six_moves_urllib_parse, attr.name, attr) +del attr + +Module_six_moves_urllib_parse._moved_attributes = _urllib_parse_moved_attributes + +_importer._add_module(Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse"), + "moves.urllib_parse", "moves.urllib.parse") + + +class Module_six_moves_urllib_error(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_error""" + + +_urllib_error_moved_attributes = [ + MovedAttribute("URLError", "urllib2", "urllib.error"), + MovedAttribute("HTTPError", "urllib2", "urllib.error"), + MovedAttribute("ContentTooShortError", "urllib", "urllib.error"), +] +for attr in _urllib_error_moved_attributes: + setattr(Module_six_moves_urllib_error, attr.name, attr) +del attr + +Module_six_moves_urllib_error._moved_attributes = _urllib_error_moved_attributes + +_importer._add_module(Module_six_moves_urllib_error(__name__ + ".moves.urllib.error"), + "moves.urllib_error", "moves.urllib.error") + + +class Module_six_moves_urllib_request(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_request""" + + +_urllib_request_moved_attributes = [ + MovedAttribute("urlopen", "urllib2", "urllib.request"), + MovedAttribute("install_opener", "urllib2", "urllib.request"), + MovedAttribute("build_opener", "urllib2", "urllib.request"), + MovedAttribute("pathname2url", "urllib", "urllib.request"), + MovedAttribute("url2pathname", "urllib", "urllib.request"), + MovedAttribute("getproxies", "urllib", "urllib.request"), + MovedAttribute("Request", "urllib2", "urllib.request"), + MovedAttribute("OpenerDirector", "urllib2", "urllib.request"), + MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"), + MovedAttribute("ProxyHandler", "urllib2", "urllib.request"), + MovedAttribute("BaseHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"), + MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"), + MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"), + MovedAttribute("FileHandler", "urllib2", "urllib.request"), + MovedAttribute("FTPHandler", "urllib2", "urllib.request"), + MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"), + MovedAttribute("UnknownHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"), + MovedAttribute("urlretrieve", "urllib", "urllib.request"), + MovedAttribute("urlcleanup", "urllib", "urllib.request"), + MovedAttribute("URLopener", "urllib", "urllib.request"), + MovedAttribute("FancyURLopener", "urllib", "urllib.request"), + MovedAttribute("proxy_bypass", "urllib", "urllib.request"), + MovedAttribute("parse_http_list", "urllib2", "urllib.request"), + MovedAttribute("parse_keqv_list", "urllib2", "urllib.request"), +] +for attr in _urllib_request_moved_attributes: + setattr(Module_six_moves_urllib_request, attr.name, attr) +del attr + +Module_six_moves_urllib_request._moved_attributes = _urllib_request_moved_attributes + +_importer._add_module(Module_six_moves_urllib_request(__name__ + ".moves.urllib.request"), + "moves.urllib_request", "moves.urllib.request") + + +class Module_six_moves_urllib_response(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_response""" + + +_urllib_response_moved_attributes = [ + MovedAttribute("addbase", "urllib", "urllib.response"), + MovedAttribute("addclosehook", "urllib", "urllib.response"), + MovedAttribute("addinfo", "urllib", "urllib.response"), + MovedAttribute("addinfourl", "urllib", "urllib.response"), +] +for attr in _urllib_response_moved_attributes: + setattr(Module_six_moves_urllib_response, attr.name, attr) +del attr + +Module_six_moves_urllib_response._moved_attributes = _urllib_response_moved_attributes + +_importer._add_module(Module_six_moves_urllib_response(__name__ + ".moves.urllib.response"), + "moves.urllib_response", "moves.urllib.response") + + +class Module_six_moves_urllib_robotparser(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_robotparser""" + + +_urllib_robotparser_moved_attributes = [ + MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"), +] +for attr in _urllib_robotparser_moved_attributes: + setattr(Module_six_moves_urllib_robotparser, attr.name, attr) +del attr + +Module_six_moves_urllib_robotparser._moved_attributes = _urllib_robotparser_moved_attributes + +_importer._add_module(Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser"), + "moves.urllib_robotparser", "moves.urllib.robotparser") + + +class Module_six_moves_urllib(types.ModuleType): + + """Create a six.moves.urllib namespace that resembles the Python 3 namespace""" + __path__ = [] # mark as package + parse = _importer._get_module("moves.urllib_parse") + error = _importer._get_module("moves.urllib_error") + request = _importer._get_module("moves.urllib_request") + response = _importer._get_module("moves.urllib_response") + robotparser = _importer._get_module("moves.urllib_robotparser") + + def __dir__(self): + return ['parse', 'error', 'request', 'response', 'robotparser'] + +_importer._add_module(Module_six_moves_urllib(__name__ + ".moves.urllib"), + "moves.urllib") + + +def add_move(move): + """Add an item to six.moves.""" + setattr(_MovedItems, move.name, move) + + +def remove_move(name): + """Remove item from six.moves.""" + try: + delattr(_MovedItems, name) + except AttributeError: + try: + del moves.__dict__[name] + except KeyError: + raise AttributeError("no such move, %r" % (name,)) + + +if PY3: + _meth_func = "__func__" + _meth_self = "__self__" + + _func_closure = "__closure__" + _func_code = "__code__" + _func_defaults = "__defaults__" + _func_globals = "__globals__" +else: + _meth_func = "im_func" + _meth_self = "im_self" + + _func_closure = "func_closure" + _func_code = "func_code" + _func_defaults = "func_defaults" + _func_globals = "func_globals" + + +try: + advance_iterator = next +except NameError: + def advance_iterator(it): + return it.next() +next = advance_iterator + + +try: + callable = callable +except NameError: + def callable(obj): + return any("__call__" in klass.__dict__ for klass in type(obj).__mro__) + + +if PY3: + def get_unbound_function(unbound): + return unbound + + create_bound_method = types.MethodType + + def create_unbound_method(func, cls): + return func + + Iterator = object +else: + def get_unbound_function(unbound): + return unbound.im_func + + def create_bound_method(func, obj): + return types.MethodType(func, obj, obj.__class__) + + def create_unbound_method(func, cls): + return types.MethodType(func, None, cls) + + class Iterator(object): + + def next(self): + return type(self).__next__(self) + + callable = callable +_add_doc(get_unbound_function, + """Get the function out of a possibly unbound function""") + + +get_method_function = operator.attrgetter(_meth_func) +get_method_self = operator.attrgetter(_meth_self) +get_function_closure = operator.attrgetter(_func_closure) +get_function_code = operator.attrgetter(_func_code) +get_function_defaults = operator.attrgetter(_func_defaults) +get_function_globals = operator.attrgetter(_func_globals) + + +if PY3: + def iterkeys(d, **kw): + return iter(d.keys(**kw)) + + def itervalues(d, **kw): + return iter(d.values(**kw)) + + def iteritems(d, **kw): + return iter(d.items(**kw)) + + def iterlists(d, **kw): + return iter(d.lists(**kw)) + + viewkeys = operator.methodcaller("keys") + + viewvalues = operator.methodcaller("values") + + viewitems = operator.methodcaller("items") +else: + def iterkeys(d, **kw): + return d.iterkeys(**kw) + + def itervalues(d, **kw): + return d.itervalues(**kw) + + def iteritems(d, **kw): + return d.iteritems(**kw) + + def iterlists(d, **kw): + return d.iterlists(**kw) + + viewkeys = operator.methodcaller("viewkeys") + + viewvalues = operator.methodcaller("viewvalues") + + viewitems = operator.methodcaller("viewitems") + +_add_doc(iterkeys, "Return an iterator over the keys of a dictionary.") +_add_doc(itervalues, "Return an iterator over the values of a dictionary.") +_add_doc(iteritems, + "Return an iterator over the (key, value) pairs of a dictionary.") +_add_doc(iterlists, + "Return an iterator over the (key, [values]) pairs of a dictionary.") + + +if PY3: + def b(s): + return s.encode("latin-1") + + def u(s): + return s + unichr = chr + import struct + int2byte = struct.Struct(">B").pack + del struct + byte2int = operator.itemgetter(0) + indexbytes = operator.getitem + iterbytes = iter + import io + StringIO = io.StringIO + BytesIO = io.BytesIO + _assertCountEqual = "assertCountEqual" + if sys.version_info[1] <= 1: + _assertRaisesRegex = "assertRaisesRegexp" + _assertRegex = "assertRegexpMatches" + else: + _assertRaisesRegex = "assertRaisesRegex" + _assertRegex = "assertRegex" +else: + def b(s): + return s + # Workaround for standalone backslash + + def u(s): + return unicode(s.replace(r'\\', r'\\\\'), "unicode_escape") + unichr = unichr + int2byte = chr + + def byte2int(bs): + return ord(bs[0]) + + def indexbytes(buf, i): + return ord(buf[i]) + iterbytes = functools.partial(itertools.imap, ord) + import StringIO + StringIO = BytesIO = StringIO.StringIO + _assertCountEqual = "assertItemsEqual" + _assertRaisesRegex = "assertRaisesRegexp" + _assertRegex = "assertRegexpMatches" +_add_doc(b, """Byte literal""") +_add_doc(u, """Text literal""") + + +def assertCountEqual(self, *args, **kwargs): + return getattr(self, _assertCountEqual)(*args, **kwargs) + + +def assertRaisesRegex(self, *args, **kwargs): + return getattr(self, _assertRaisesRegex)(*args, **kwargs) + + +def assertRegex(self, *args, **kwargs): + return getattr(self, _assertRegex)(*args, **kwargs) + + +if PY3: + exec_ = getattr(moves.builtins, "exec") + + def reraise(tp, value, tb=None): + try: + if value is None: + value = tp() + if value.__traceback__ is not tb: + raise value.with_traceback(tb) + raise value + finally: + value = None + tb = None + +else: + def exec_(_code_, _globs_=None, _locs_=None): + """Execute code in a namespace.""" + if _globs_ is None: + frame = sys._getframe(1) + _globs_ = frame.f_globals + if _locs_ is None: + _locs_ = frame.f_locals + del frame + elif _locs_ is None: + _locs_ = _globs_ + exec("""exec _code_ in _globs_, _locs_""") + + exec_("""def reraise(tp, value, tb=None): + try: + raise tp, value, tb + finally: + tb = None +""") + + +if sys.version_info[:2] == (3, 2): + exec_("""def raise_from(value, from_value): + try: + if from_value is None: + raise value + raise value from from_value + finally: + value = None +""") +elif sys.version_info[:2] > (3, 2): + exec_("""def raise_from(value, from_value): + try: + raise value from from_value + finally: + value = None +""") +else: + def raise_from(value, from_value): + raise value + + +print_ = getattr(moves.builtins, "print", None) +if print_ is None: + def print_(*args, **kwargs): + """The new-style print function for Python 2.4 and 2.5.""" + fp = kwargs.pop("file", sys.stdout) + if fp is None: + return + + def write(data): + if not isinstance(data, basestring): + data = str(data) + # If the file has an encoding, encode unicode with it. + if (isinstance(fp, file) and + isinstance(data, unicode) and + fp.encoding is not None): + errors = getattr(fp, "errors", None) + if errors is None: + errors = "strict" + data = data.encode(fp.encoding, errors) + fp.write(data) + want_unicode = False + sep = kwargs.pop("sep", None) + if sep is not None: + if isinstance(sep, unicode): + want_unicode = True + elif not isinstance(sep, str): + raise TypeError("sep must be None or a string") + end = kwargs.pop("end", None) + if end is not None: + if isinstance(end, unicode): + want_unicode = True + elif not isinstance(end, str): + raise TypeError("end must be None or a string") + if kwargs: + raise TypeError("invalid keyword arguments to print()") + if not want_unicode: + for arg in args: + if isinstance(arg, unicode): + want_unicode = True + break + if want_unicode: + newline = unicode("\n") + space = unicode(" ") + else: + newline = "\n" + space = " " + if sep is None: + sep = space + if end is None: + end = newline + for i, arg in enumerate(args): + if i: + write(sep) + write(arg) + write(end) +if sys.version_info[:2] < (3, 3): + _print = print_ + + def print_(*args, **kwargs): + fp = kwargs.get("file", sys.stdout) + flush = kwargs.pop("flush", False) + _print(*args, **kwargs) + if flush and fp is not None: + fp.flush() + +_add_doc(reraise, """Reraise an exception.""") + +if sys.version_info[0:2] < (3, 4): + def wraps(wrapped, assigned=functools.WRAPPER_ASSIGNMENTS, + updated=functools.WRAPPER_UPDATES): + def wrapper(f): + f = functools.wraps(wrapped, assigned, updated)(f) + f.__wrapped__ = wrapped + return f + return wrapper +else: + wraps = functools.wraps + + +def with_metaclass(meta, *bases): + """Create a base class with a metaclass.""" + # This requires a bit of explanation: the basic idea is to make a dummy + # metaclass for one level of class instantiation that replaces itself with + # the actual metaclass. + class metaclass(type): + + def __new__(cls, name, this_bases, d): + return meta(name, bases, d) + + @classmethod + def __prepare__(cls, name, this_bases): + return meta.__prepare__(name, bases) + return type.__new__(metaclass, 'temporary_class', (), {}) + + +def add_metaclass(metaclass): + """Class decorator for creating a class with a metaclass.""" + def wrapper(cls): + orig_vars = cls.__dict__.copy() + slots = orig_vars.get('__slots__') + if slots is not None: + if isinstance(slots, str): + slots = [slots] + for slots_var in slots: + orig_vars.pop(slots_var) + orig_vars.pop('__dict__', None) + orig_vars.pop('__weakref__', None) + if hasattr(cls, '__qualname__'): + orig_vars['__qualname__'] = cls.__qualname__ + return metaclass(cls.__name__, cls.__bases__, orig_vars) + return wrapper + + +def ensure_binary(s, encoding='utf-8', errors='strict'): + """Coerce **s** to six.binary_type. + + For Python 2: + - `unicode` -> encoded to `str` + - `str` -> `str` + + For Python 3: + - `str` -> encoded to `bytes` + - `bytes` -> `bytes` + """ + if isinstance(s, text_type): + return s.encode(encoding, errors) + elif isinstance(s, binary_type): + return s + else: + raise TypeError("not expecting type '%s'" % type(s)) + + +def ensure_str(s, encoding='utf-8', errors='strict'): + """Coerce *s* to `str`. + + For Python 2: + - `unicode` -> encoded to `str` + - `str` -> `str` + + For Python 3: + - `str` -> `str` + - `bytes` -> decoded to `str` + """ + if not isinstance(s, (text_type, binary_type)): + raise TypeError("not expecting type '%s'" % type(s)) + if PY2 and isinstance(s, text_type): + s = s.encode(encoding, errors) + elif PY3 and isinstance(s, binary_type): + s = s.decode(encoding, errors) + return s + + +def ensure_text(s, encoding='utf-8', errors='strict'): + """Coerce *s* to six.text_type. + + For Python 2: + - `unicode` -> `unicode` + - `str` -> `unicode` + + For Python 3: + - `str` -> `str` + - `bytes` -> decoded to `str` + """ + if isinstance(s, binary_type): + return s.decode(encoding, errors) + elif isinstance(s, text_type): + return s + else: + raise TypeError("not expecting type '%s'" % type(s)) + + + +def python_2_unicode_compatible(klass): + """ + A decorator that defines __unicode__ and __str__ methods under Python 2. + Under Python 3 it does nothing. + + To support Python 2 and 3 with a single code base, define a __str__ method + returning text and apply this decorator to the class. + """ + if PY2: + if '__str__' not in klass.__dict__: + raise ValueError("@python_2_unicode_compatible cannot be applied " + "to %s because it doesn't define __str__()." % + klass.__name__) + klass.__unicode__ = klass.__str__ + klass.__str__ = lambda self: self.__unicode__().encode('utf-8') + return klass + + +# Complete the moves implementation. +# This code is at the end of this module to speed up module loading. +# Turn this module into a package. +__path__ = [] # required for PEP 302 and PEP 451 +__package__ = __name__ # see PEP 366 @ReservedAssignment +if globals().get("__spec__") is not None: + __spec__.submodule_search_locations = [] # PEP 451 @UndefinedVariable +# Remove other six meta path importers, since they cause problems. This can +# happen if six is removed from sys.modules and then reloaded. (Setuptools does +# this for some reason.) +if sys.meta_path: + for i, importer in enumerate(sys.meta_path): + # Here's some real nastiness: Another "instance" of the six module might + # be floating around. Therefore, we can't use isinstance() to check for + # the six meta path importer, since the other six instance will have + # inserted an importer with different class. + if (type(importer).__name__ == "_SixMetaPathImporter" and + importer.name == __name__): + del sys.meta_path[i] + break + del i, importer +# Finally, add the importer to the meta path import hook. +sys.meta_path.append(_importer) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__init__.py new file mode 100644 index 0000000..c4c0dde --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__init__.py @@ -0,0 +1,91 @@ +""" +urllib3 - Thread-safe connection pooling and re-using. +""" +from __future__ import absolute_import +import warnings + +from .connectionpool import ( + HTTPConnectionPool, + HTTPSConnectionPool, + connection_from_url +) + +from . import exceptions +from .filepost import encode_multipart_formdata +from .poolmanager import PoolManager, ProxyManager, proxy_from_url +from .response import HTTPResponse +from .util.request import make_headers +from .util.url import get_host +from .util.timeout import Timeout +from .util.retry import Retry + + +# Set default logging handler to avoid "No handler found" warnings. +import logging +from logging import NullHandler + +__author__ = 'Andrey Petrov (andrey.petrov@shazow.net)' +__license__ = 'MIT' +__version__ = '1.25.3' + +__all__ = ( + 'HTTPConnectionPool', + 'HTTPSConnectionPool', + 'PoolManager', + 'ProxyManager', + 'HTTPResponse', + 'Retry', + 'Timeout', + 'add_stderr_logger', + 'connection_from_url', + 'disable_warnings', + 'encode_multipart_formdata', + 'get_host', + 'make_headers', + 'proxy_from_url', +) + +logging.getLogger(__name__).addHandler(NullHandler()) + + +def add_stderr_logger(level=logging.DEBUG): + """ + Helper for quickly adding a StreamHandler to the logger. Useful for + debugging. + + Returns the handler after adding it. + """ + # This method needs to be in this __init__.py to get the __name__ correct + # even if urllib3 is vendored within another package. + logger = logging.getLogger(__name__) + handler = logging.StreamHandler() + handler.setFormatter(logging.Formatter('%(asctime)s %(levelname)s %(message)s')) + logger.addHandler(handler) + logger.setLevel(level) + logger.debug('Added a stderr logging handler to logger: %s', __name__) + return handler + + +# ... Clean up. +del NullHandler + + +# All warning filters *must* be appended unless you're really certain that they +# shouldn't be: otherwise, it's very hard for users to use most Python +# mechanisms to silence them. +# SecurityWarning's always go off by default. +warnings.simplefilter('always', exceptions.SecurityWarning, append=True) +# SubjectAltNameWarning's should go off once per host +warnings.simplefilter('default', exceptions.SubjectAltNameWarning, append=True) +# InsecurePlatformWarning's don't vary between requests, so we keep it default. +warnings.simplefilter('default', exceptions.InsecurePlatformWarning, + append=True) +# SNIMissingWarnings should go off only once. +warnings.simplefilter('default', exceptions.SNIMissingWarning, append=True) + + +def disable_warnings(category=exceptions.HTTPWarning): + """ + Helper for quickly disabling all urllib3 warnings. + """ + warnings.simplefilter('ignore', category) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8cc73d3b1ac23a1ae61a8ca8cc2370886451d34b GIT binary patch literal 2138 zcmZ`)OLG%P5Z;F#tEVm5#@NndA#t!0EE!0skfKr$5&~7=a$!+aZ4O&w%}81^v%AdB z3QJ{9N#&ORU>$SI@7Zfk{DB;DNxDZ8m{6ImX?6F^^z?Lp-FjN9l?@nw{V^p|;QmD6 z{K$iF2WIl6X&BV-3~Ew~o5J!e6M384o=tN!&vPR0<we0Oh@w}7wHz&QN0hvh=8L>6 zDqcnN4zG%uR}*!wE|$C{tt;_m(eN6YFY~5Y@m4fn;j3cJThn}%Ul8lwy5?*AqS){@ zfJYxTy-oP7^G&hkZGmpd`+zQcAJT^R5p8-Ov&}P?U7DI_m)X|O#?&+owt4(X-=r&a z^%v9o^rtOmA8*q&RyzKSUZCs0*{}mO7eRC7J<ZO0n${al>G*T7yFoX>?ibWPG+JAe zugj_AJUF`H?z-KfWQ6V}q|e-56o#y)f+%$3DB?jla7jpA$#&BOgm(EgW};<gOXMht zc&eBmh&YmJ|1~7TXxUlwLAQHw?~R!Qu#&By?(o0Lw|Dt{83`Xe0>fo?(ql1tkbtzo z!d^s~FH)|8m`LUKBPl3R1g@%}@y8@2117WTfs9VZ3#lHXblz?ieR#r>7z{J8TovRw z^M~+qCh;a`z?46X5(Rv*8weJq$mX9gCC9*2_EXLuKrlFylbyREm2B)Dz+yCVcR&qd zJJ#ZzWJo5_%XY|AE3+Rz>`n^T+Sk8o-)Plk4uT{Rz_Nq{fi9~^mXRz0$r^-GKT+V8 z^m#OZx5)zPmuZlYBhLJnM23)yL^^n;j--a90;GpoSPUB&yz3s!<USB(oSDj+ny*aY z?5Xj}I<?Mnz~`wsh0ioj&9lNO?9g2CR09)q4z=JMl-H>R@UbVqmR%SR7>}8BAtUaK zH0V9&V;6kam~jskfJ)5c<*LY4L*~w&({`UGte<i`sO?a8lnw?OURs8br!q|Rk>M=j zF6k?{YHmJIZM|`_y}d&cfU97w#NFQEY{Ym-=8|AZ0?=qBldE?rWz;3^EUelObaP=G z+?%=fjk}$+N?8#l*pQU~6pwTcGRODPvhQcLcixs&6Q=G1D2W0Ov(j6(4BpNIkU6mF z5qg*9^=kpWdF^dhnBANe=g$0Y$V-r_zh87>8H|Wxoe`0pe#8-{om(fJfq!cx#U#Am zKi(S-PbL$e-@17;lzT7+VW-=PgLpRx6Gb@R-P^l48jr4}sMOORv5-cxGcW&+?+0O^ ze7_x!<qF(;1F?dbGD>CBF_+CUd{tAgWd*`tl5x_7aww2E21{9yvOa<0d<S?4LPWX- z9wHloM@@hecIX*|ZvP*IW-!+%;@n-dsRig~iO&kbAdDp2Z&{hMSb|JIFXF5paL5Gs z==30bgGi2bL}%nOcq3PVJcF57K#ZK0TUWE9@6)IU87}*NKLrdzwk2+nSAb;ow+#z> z<GEVa^=Zf=?sDLI7DFG=<(XA*tC;nub2X2(nmKabj&uv~s;LTiTe24^gVR{jo}*O| z16}6x9SC=5PP$uo<@q6KQnMbi2Ipi0&BH55s)mt-7gc<p2R#O@ZzhZYOweLMfJXyR z;Gq}r;5w2mJe~jkhwq;LsPis&P_cB#dZ`T5_}Q%gWNU}%(J}m4+~sN?Dr2Eue+ak0 zPIkbFf)W>tg~s9j!^c5_|04@k1)K6*&{;T_DXapC>B^kjBBCj0-y*J(n?Q1Q)pV@Y lLKUF73UmJD9J6ZWO!%x^qiNSytYXt@T4mGvr(ieje*vYaUvvNf literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/_collections.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/_collections.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5391c6ef4e12bb80f9831461266842566685eea1 GIT binary patch literal 10788 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/connection.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/connection.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..620b7795819127ae53fb359178b9084a1b500217 GIT binary patch literal 10581 zcmb7K+i%=fdgpC8oQp;mJC<*;nZ%Ag8(DG^Cvlu?YDbn6BktI1$+>WwQq=H_h7yMy zA95^fcC=lrvgl&b1dDBfrp2O_`cNPbE&7y)_Fu?jfdYJ66e!^S0mUM1;{Luv&P9_L zXgT5$d3gApbH4L^zwdH*Z(^b-;rOqA+IRlyiX{Cz-HaXu++4*OeJM+lE4i{SwPZ_{ z>00p>OA-H7OBMe$OB4TdRu2DFKiAT&e9N#3S^J_@bTv2Ums(}3j5^KL{fSn^niSW0 zTu)h3vecasRHm(IHoY-p9r{2D<}`^NW=}Pg%_9GMS)!k-Skv!FuHhCwk=z11va4E$ zK9U0EL#b=9S!)(=oxxj2@y5TVZ=iM2EunRZ9YgEcv^7Ri_K&wtSSMO1t&^>%t*2Y3 ztW#n{6aMLzX_>8OtY^f1#ecT-ob_DmjCH1U);imI-g>@u&N?TaP5S3sRjVqlr~DtZ zUa($}C8qApu?zdMHSbQlGwz|^D%Jv1_Aa`I-KX3m`>ORK#x(05#h8w=moTQ6aevG` zj{D<m5;dAtLCp#GBx+8w3R+yk{nPF#+@E5XaQ}*X+BH9stXJ9euVwy^?2`2wd&RmG zXzXR{lB+CB)n^{jidN-h(pif_zY{atYqdij*Q!dAW1NRP$;V!cg`M~jmYJHWk@pb) zD(|kW+*u5RfYoC!3{W#cHA@fctW6blqC9%g>sN6`WfV-ZWLJWW$QXr^l;3tDw!D06 ziF&Mkp(ciH2TqIGc2czMR_Jzox-Q%H{f^_OPri_N1(Zbbb+pjt-UBCQ3lAK=&<K5( z@o3@ohYRcW>koLV8@$xmxY%qy>~?Mc^;g%L{34F^U}0sU?X@p>K@>Z_f8pZAS08LY zc(Fs3;<O*Izzz9Ahx@*__VPk~FyHz1HYW|3p&2PC3|ZX&zotDo<X<{-PAWH?R(dr_ zbyFx#;OzHB_f;*Ksj;mwBFUkwVkKQSK{<J9xwE!`rMl+FH8A!AhX-D;o=h)qM=@(r z)2s@sQE54Gy=gbYC?-}XQ;UqpUc;+{zk*sdmrQd8fqB5}I-c2_-H(z({i-PP!8jg4 z3X&Noil{{cy)lkO3gYBQoimWKGp^d;YRn$S$t1nF#htbth4oDqL#B#&Hk2?SbMG<- zi+kOx$B*uS3EsazurO$?8OQA;M`h&wE-y)sbUb}@3dNJxgt#~qML-oPg_=xW@3dOm zL%wz|+>4lN#-Zu57)&%Bv*CC?s)lVA{m4vpXTDa|cnOp_NjjfEk>qXL4ePf3y=(g% zTD*-j(oh((CUdI!&Zt#XUd0);QH+k7X|8fivT{t{$m29zwV|%dR>9Q(sySB&1e93W z&AY}Y(ynYxu!)U|Tj<}Vz-LXmWp@HCr`(D=iT~5?Ap)jPWNXHq0#^=m@Kkbun^Mul zK^p6tVPF!+p&auE@xWZ`#Acg^4?LGerW2T0VD6Y$&M4-cdK_{=WzDH?ZaLhIF4V(T z+ljq3&-dbO(|5KRH`iFa#aLhpbp{dF4A>Ux?`+3S5SlLv8rNLcBgAohbCYdvh1@mU z4u{~zkU`Vo%<N>Vhu$0BdIvR59CHst#Mr`y88;b?EEBZ(lxm%T3{xDT<pp)W<FYGh zzovP?TwTR<Ad0K2SIlL`1SKqVr^SL8vjKbXcctz_3$CnY@;*Q8svU;@7~}4sYE_IN zqaSv7o!O4-LcOB2pIG!0i6>_E#B78-ok)js^!}X*^~sTD*`dJb0lBEn>ZIUiR!^fQ zrgQ?Rn!gR*HB*(GH*Yq~AdJoI4d%{K!yp^52?c359Y0R_?uSrS*KF{x1x_6lkol}- zrt8BInOjY--ZV2_N2cpV&YF)Q4Em@!>pnY&F8uY7dvUX6o{t#1Tv@zh*KS{5x^?X% z($yEM7{3purED3jujxgQtfmKXa!5oUZfAl-VtoT#WDlKI+h=p8*D$xkj=AMUO(Mtw z41`fP=6j5_&1=5*fMKAt1VRF-5wWe$gt@_xiA>8|Z$c+X6b2GRU7F_qi8JO4=8p&T z()UbETp;EA^6gvp^6ka<mR9EaE46&ves5{%&b3=N-(Q*oGlqkqmp|^yuxZ}rVwNpu z+uU*>I0SQo=b1S7S9EP#44#C6^tsh0J@um4JkRFW=jX7(KmK@iwVJ9AKMl0tITSbQ zWcm9Cff&KuZJg0{6tT1+^O>Hq2VcOI_7z#eHGp_u?n$;L>eZgKk=s{rugCcfqbD`w zp8PjTPx(xSPbC4Iv|6I4ikMVVwdgAh-H%FqwZO?PB<h`yUQX0@*iO`S7W3z+?#TCx zBtJ(FC+&l)L@tUKc(HB6U}zEZ8;R!d^(av`w?<H281D-p(8L)Dk6PB{vRc-rl<w?7 zlJk9v2RKIDBd#qH0kSCIhO{TU^1kq$oWI4xfn2=9VxXQ0>}!U?U~$$8A*4>QZ32G* zu2?-cgtEj<Cx-00!m10Y?c00O4=nJFA6>7FD8|jeTxS8}jz4F@Q!~l#XFdURGz`uW zH35%;*l1_{ZiM6vhT7=({`Lj(=RgK1;f5^-x<nqwoWT0H*@*<YY-jWzps5STft0pQ zxCE#efu4GkVWpwe>!1U%bVf<`=PO2-A_CX|I2&p&X-<m`#s{~BoEVezf)I~A1V{?) z;H=I_^GVeY%#()GH+t>}@7@i!7-)&fm;*L%0lE&p560I4Xjl@TwD5Xu*%Urihb+k( zn9e~C`eC@)X#<{!&UeP*`TmemVE}Gr{+Vd&w26t_BX-hC577aWfO`fJFh}Ua|3}5a z$x;Uqb2z}7dXI!B30ThR()Ap$laONGToG&P#b}l~OBvv75}pzj0Q$N|rkvOW;~l~T z3DX7}4y%M&ctc|YAxCW;o=8NZ0J|<IkIwD9H_w1gVr5eP5m&RB5vIfQhjk%<Zw}Yq zsmG8@f%HRTZ8~)x!kVP^X^Wjhf9qmNKqo?=AaER9zTW}WC<8(Q+eDs+hgz`RAQE16 zqH{v4c2(x{Q0OtZfGdl+cSzkSu#l#^hsJP%p4Y`QdX9sx>0HDqK&D6NiI|+CtM0!I z7GXJshrX+@N`zK3DTznT;0J(=D1sXUwg4vt<1_b#ys1=y2J;!ZQ*ZR$L97H};-Kf0 z0==1bnyR=5M}o0d1g1F=JUBA1X@^)14(qbU9q!>JM09?*Wkww@PVEb^wFdsZgc(;A z!Nw#9fatI>Zt_cL@k`>1V3=_LTgeg;CJVmp;lh)4z_|^HAEvSglzo%%R_14@#J%#S z)IAj|8)TC-oVf<<(uR&w{!HFckXiUplj1xw3x1keh+(f>YF$X%9g%jGpUcQETtvGf z+WoaG?WmO5h)Zax_0+V*2huB&o7+);s(vV?*@zwmCwjMSE)8VX$&CGovnQYv?hr7` zWpJax;5Y_uz|jq`C?lwJg|oQBgDWOt$nVk_vRN2MVFbGu7l&RHg#Ik#0FfiYfDUx~ ze5NX*4mCeK8&$jKZ=`|J0abIzj~^NH6;P^G%fpWNNvuUOoyCbm6%@;zXq2Jgw06nF zvas%1sLLrD7Ym-0(gz}3<<qD}Oh&qv7$Oj{H@6av=qB>Gz(7wiItogI-{6IaBuvU_ zu-Zk1P6Yv4QPLhOvhvtaD>D8|id=k*J8eqb>5q@7-J@eVJ0SWU#ifY|0X&0?RB>Yn zA-O}lDmQ!5p0Y2JT2N^u(;x(D4XKd0gMh^sc*4m?KsG=lUnj}Kp`rK&L1)?~DL9=t zgon+7FH%+EZ{US7MM);?HfM--5YuDs|9}>efkKjXrK}iA_vHADMw=f{E7CL-r<m0d zTwo5;zEG__DAB&0xotAiO#Fv<&aYEJ&Bq6o&ldknJQMM;BpY(~$k<S_MzuOQoc)7* zCGz#eC=9SDmU@~iZx(o^rv-|KSa=7Kb5GmUcXCis`maMtF~XkG%k^|u`&5HFsuBOM zOCKNpBV{MQ19je0d-<M0uIl}_+#KG^^Cs20x|<gcthA@miuF{{+t+b!1CDD$o|SeA zfCIHx*j4yn^wfsDqxMu#Ufn77iqYTQ{~S+?aeh~czU&qE5TWnOJH@yNU?}d&yE0;S z`4@=vcK{T7<z5Lbiu;0_bnljkui^=6)2p=Z{^#O(S@4}q!bEp>0L(}TF&-dRC5I*r zUl5A702Y}c%bZEFp%j;qp%d^wps*IY@WjXosW&?Td0;H4hpzBdC}fB41a~3~n7QUd zJ_qmBx|5CwvM==83)O|CJREI$Z99Ev_a7z&QA;MPI}J}Hh#HI!UhPh=^sAP#-jjSb zo<!@!jmwWnD!VycUbrl5!9+14ak)5AoG4Z&_|v#fitSFE%{$3?$c#lv0aZ<rb4rSs zdwLnAQAC-{c(88A+ieylxwUO16q2GBiG*TMXNfLG&l0uC9ww^K0tyuZ7g#62NKYO0 zM1^flG-70u?{{zm<Kgenp!Bqgzd|>YX_xR=`n`%-CV3FI@oZdyCbQ|-88iMFL?Yz# zfoX@KN|bH_g3<4PbbU&$pr$Mv3YA4*Ui!R<>%;OC$|7Qy?x`{L8|$K~)N0j3V<|9B z=$2Fny6v@XJA${4)MB|Ga#1~EIDzI#>E@j~cW<xUwh?M4rIE0nzd%GvUPSpt5jJp& ztr8=R2;%J&{B^Q<jE_Le5?b*;recsYPOn6KMwu<*baWgAW;_cdS2e|$0Itsf?F+^U zqhM$v16D_q0|#N`Rh-eADEetR2GvJO4)B8g4yFI21RY&BkfL)nq}GfqJy#Hk$9ytL zj9p$F7+G$DX00y5MqJTBiA56I_izpZ=pNY(rJ?rpUfz{|tMrP0DS~5QjbsDi$Z`PD zD4+&@*|{E^5nBiLNp?Q7C_v(~ASukM=(cKz`DP48W(_%9pCtv6@D-P3s-%1d<=m1I zWp4q*St?gVPs1E?0mdba!+PjfOR3XKei?s_3JQ(6N5uve!(nXFtxv^8Duzoph^qes z^$}SZDF;jZ7_$6WS9Qp(_-UyX9%1PBhuCC+X&Hs3_!TaIm*e&d&K+z6Hnlbl{+6rk zD6tv~2XI%8$!g?*&+4bdQPB>_E^Qc517!iF!W(fB_CN#jH+t$`iR?pMCTqVjfwO{h z5+}Vo<>o#GMSEJTj9$C3@`aLex1Ur`*8o}<B{P&`v-?^^YZFy<{s)*tlE?Chbuy@$ zu2TLExLTbV(GXEf^3RV_5mGTr1!bEPqwa`If0UH6E8F$pVKkkHTn&DoTGIZ+_+pCH zqv2%!m+(B2L;V4d$_$x$5}xsOUc%eI#~IC`AoE|;ppyc(fM4Glc^$}PJXYYN5RPg6 z-`8n=Wpwq?10{K@#c^=5L7A^oAtvtNDw(z4xpn*PYq#v{OE<3FyR~Ak-2B6(+xJ$4 zMsOO{$Vi233b9<rgWutd4x_*T6%B49xrh)>N%^KY!>PrSVdPaj?Zb#G)1E{hMl5Ko z1ponT<TC&%WB^hW0AeJw?`OC;1|;1yb@;tW`w<3-tUc|(qyb(E$HKM?t9>x<gPcSf zB-HA(6V^ZITE!`piG)YEL57H+;MBtXItd|%o3*0`My$ASY@jR@uc~mn2%-qI;8vm3 z0ce0IxLcBK^m5_*abcslSL)?NcCg$t!e&+jR|#z<vWWM?fs?V)L{cS7hege><I|o6 zvIuLGH}Gi-2V0d$IIS@R#T0yw?gUUKjP?$Ou~4mA;iM@^Nf@AQ+M8slo(xfpCM{GA z+p6jA7db7I*y6|NT_ubV!#Hsh4#mSZwl&ZP=P|uSQ9n|Y<Q$A>(tu#vs7FtUl4w36 zgd~570pllh^;x*Q5h=4&fX*OtF(8P;-;CTfpCB#seG&(}dP2xSu>2bkAEG1{Q;D&7 zS<G@NTh7c67Ip^KXF~^uDgqf{bsz}uqAtIq#>PfruedM8rA=u^>uKDN%X<^9x>t$e z)5eqg@U&fRhbT-5{QVq(aW0;YXHatp_)Ee1Q@~$c;O`W*+tK^AJ>5Qnn%U?plt)qK z_*d~Uc=zzL`By!C@3_F?69S7#G@r(Kir%315JufKJ|(M3h<+Ly=~MA(T&Wu-bg%F! zA^7QCj4*I}`o@v?nT=;RRkVu14;_1J+Ai**7_FXjwao%Op||%;#6uA5y)$mfE$=I6 zvnFOeu~+FK`5m97S;x<l=x;ptYq{O-snko>$GJ_s(f$?nO`OE&&I@Z%sqwe4Od=rc zevoeNig=tvc?;Qqu+cEjXTtuIi#t_H$<d=MTeyZ446^!gcPSVkeHU_0Nn+Z}f|!Op zy0O9o>V!ZaUIL*z=Tt;g2pc{S=G1(X%3wFQw1(6kha(a4R#Fl9+M$O~i4N>g3$gD0 z=i)HUEYg4&vk9YvsKQ)5_`>QOHf6C*j|4aED$@8x58^e)Tuq}I+WcM>RYACwO}>HM zXxbD6AJ!PXpC-*+6FVL)X9GJzYdqY7j#6G6iE4(xm-fO%gS$5t&6h5}cp3Q*+5i;$ z&sP=}))5bN*09yrT8NrXH{2S0L*OB=#-fEwufHaSfgNRJNTT^_wVGOE;TK&cP720e zqpP>65DQE8G%+X(PMMcPqpKtrhpw}ol<qDqF4b1->(^G65(C?+w8amop{qnEraLhw zt0W+dKgrnhpHP$G3O=CQCmMKxXeFc^+KgeN5?;Itqn;ENm+r1$H?FqC1zi1rh#W$J zjg+y^3noO<yGuX1ck}Mjb?%}Oq)I>_r703)fSzLV<o(m!ZHO}8BC-#ul}3G!VWBY6 zR|p1wiY5|*8eJ{p1Q4paLQaIPRD`>rz<p4@RaE60%{bs(<gi(Tw9faq7Zfu6-Y6Of znY715r}!8l!?&7Vq#9WREtvlQ*77q*5*goiPd^E4`%Z~b%MN(RC7M^63i^CN#7@Ey z8(9|Ns0b_YGivfgf2512v&4f_xIl0N=PCOs@ImRIQkK3c9_7^bKz@o0`2h28;ig+b z76s7;VG)v@myyJjk;J@#BqnOQ$79;OqYR3)kEAAADz^4>v_vu!Eq;nmu(D69D37Jo zx>rXP-1X9Qfe?^v!v$K_Uw=vy&YL4IP(?MzpTf8}1p$b#!*xz$#%Dt$kHQXCRZfY# zWI8p*%pG73r;u%2W<EpRXT&ek6bY+bfqN-}WJ$s5>N2Mm)ywo{Qlmq_fzLW9x4=I^ zfjB%|#}39i-=Qjp3K|f9oeByx_+=`7i2`9OfXZ2CX*R(+)xVv`Csy;cZx_uIp4fHY z!;XF$j?K~AWQzHp2@?IUro`7rh@8deTO#e5RIc^Ea!Btd$o(69pd~&jN(uys>EpuS z5&0$AXIzm;o~DUaQeS}|)`{Ur5%e9@=izc#1#DdT^W@{FE)qE-spBHBhvEgw&3JyA z?=2&Igi9vACyUa2OaZ`h3k-$f5i0TLL_s*~zo4r>B?@{dzHAa7%?RIGh_P6u<k-C+ zHDJsg^N2^5y+Wi?-|5ZtTeG)FC88P%<U+C^Kma)r{19c3KQ$w3$`K7whg`w`qxzI` hvQS2*w5S3YzSRpAbt*UWC(?<jSEsg&3c-!8{4Xc}_n!a& literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/connectionpool.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/connectionpool.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ef8a3743df11f9925c0420ad3583115f799e11ed GIT binary patch literal 23893 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 Bx|jd} literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/exceptions.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/exceptions.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b6395d36e2fcdf0280de671da2af51731caff739 GIT binary patch literal 10081 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 Njm}JC#Mt!6{{pD&;0FKz literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/fields.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/fields.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c7127900b99fedab333485173ebd7e9e73770892 GIT binary patch literal 8146 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 BoR<Iq literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/filepost.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/filepost.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e92ea6a914b0e3ac9212e08271175d9d981ac72f GIT binary patch literal 2783 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/poolmanager.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/poolmanager.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..90ebf722b02661cc54f1c0bc11a047d39e288392 GIT binary patch literal 12959 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 QxePmm>+JWHX!gVZ0aL^&g8%>k literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/request.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/request.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b310556315d7e5dd40e27cc6fbc32a42b2bf06da GIT binary patch literal 5637 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 R0dW&iJHPI%+v}BD<)3fEbPoUk literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/response.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/__pycache__/response.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6879f37777736bffc55c76d3a5c41f562c0c4ca8 GIT binary patch literal 20148 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�>BKP2h0&O#K+BkWz7?_L$+hsx?t9vak7}DgvXXE z8fGM<ymQ$n${UC_;VWtB^d8rnst`ZK&Lc`o0m*<HKg@%;kIq?PArSpL0&v4aCA2bH zB=o6Pari$$K@J!xCYC>gk5WW_q88p$|JlHSI>4Na)OH5m)IStoepbJQ5G{P72-3dA z^LCyiFd9HV==b0=6>=EcEJzp_JTlp`Js!<igvZs^zk2(3G5&;X4jm7Zuybq%hTo^< z<7geZ95lYQ{~>zrfe)AUKQ#4t0yAw-(X$KR?Z3JG;~xHF1IGQ~?H}JpfB0_ybT^bB zF8))Ed<E|`u$OlGSQEHS1~lwjg<<v6T&trztGn&%pWXX#{r~$=o9ly56U0e?qI)g2 zyeMoK*oiy<@Q7gJ;O988D_gpsx^jZgG-^IQDs$a+NuT#kA}G8gBV{7xCO<B4qkiI~ zk^*?K)*ebokZ&MINV++b%zYK?n1NaG7>YVGQJCFp+>-QjXo`CgV44C*f0xAuivujk z-Unhp|8w4oX!sGY#7oKer2c&raWMFMtdKc>h%4G#%sf@21cLr;^!QEkqpP?`P3B>0 zFzo9f@Gobl02Kx<5eGp})D=(*CnkDi;Uvl1j>GT4vuI_22-iqW++ny53-*M}rQpNN zM&{1p0)!0x5W$q=Mq%A#rifT8oA6N{7V89koG5Ob?*6E+kt_-`HlcwpF5Z9=gYQ`R zK?Z#eK0fz>|3jSMK!n(2AGi@fbL<!8J)4K)PiOf}?9fB#WU_!6;gA;N^z1`2>@Vb? zYy6m||I{GqxBtMxhacky*+RB0sT>gJ_@uOje;czmo~@r|tGC!|gboyDVbZ{9^Y6Kt zlmw~l4CB;EKbGl}*am9lJVa_RQ$Shkh)~OBAO`)u1qX8TfsMo-8;LP@km(0yhZ?nt zzE&qcKa6m`at_KD2e`*)5$|Ec@Z=-~ecW>U2HJ9mQ@U-=oagqhtV4;qJ&lALNCsvW z@>>5|JUSiHqAKMV<h$}^@feEMR4@t?UsnGi3Rqfym)F#gLT9s8!*>JxG^wf3BH{fk z!uv?()It~5y`5s3{{aUs+;W-!Ekyp)PxN09fb)l-5m8DPZDv`)L6}tQ<0ogQBu&K7 zz6nA|xxBo<-_?Z$d?%0p_<|2i044sH(*mrah1pX(zG2mG@<qPI;<GH?X7Ln@UuN-D z6k$FNx)}E+Gj5D!{w}XHi|?@b$1IMppmwJJI*S40Nb~l)EX3O30*2%A<&!~d{X1;? z0gJ!S;vcXOu0*$hn5*Us<A1{2-(&GxEQC}2h*!VO;$O1(*DRh)7A|j>Q4m(2P7!bs zmthk+VzK%BnbMqj{l5w?<R|hu@S;2pe6gF)=g;Q%k~1MMZhw9pwXYWD3rBE1nok!H zrk37?{1~nrlw<kH{7m6;eq83BeV+fxW~~DP!hf>S*nNJ;!Hlwd_@5H1S{8{*7}~WK z()3#E_(pCWE@X+vYm$%t+bm>-w|T{F3&*d^Kk*W~A0L0<e{I#x2P3}u@TD+FSTNk5 z>YJwhXoCA98zeGCUrMRiM)m>z2be$S*Y4>(>{e$n#m4F3#<>O(nti>Ot$)Bmu!B0j zX0AYKBKnrie5+`@=#)3&gu8*)1Cg9&@4w8-tocw+zDPFzmgFV2z0Tq?i!0LW`prv7 ztCs~Gwaa1tHS^8q>)b;B911GD+-htaHje*`i0O+(>o{@=iXgZtyO5rGYAQGNWWk!6 Jo;r}9_&-5+RQCV? literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/_collections.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/_collections.py new file mode 100644 index 0000000..34f2381 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/_collections.py @@ -0,0 +1,329 @@ +from __future__ import absolute_import +try: + from collections.abc import Mapping, MutableMapping +except ImportError: + from collections import Mapping, MutableMapping +try: + from threading import RLock +except ImportError: # Platform-specific: No threads available + class RLock: + def __enter__(self): + pass + + def __exit__(self, exc_type, exc_value, traceback): + pass + + +from collections import OrderedDict +from .exceptions import InvalidHeader +from .packages.six import iterkeys, itervalues, PY3 + + +__all__ = ['RecentlyUsedContainer', 'HTTPHeaderDict'] + + +_Null = object() + + +class RecentlyUsedContainer(MutableMapping): + """ + Provides a thread-safe dict-like container which maintains up to + ``maxsize`` keys while throwing away the least-recently-used keys beyond + ``maxsize``. + + :param maxsize: + Maximum number of recent elements to retain. + + :param dispose_func: + Every time an item is evicted from the container, + ``dispose_func(value)`` is called. Callback which will get called + """ + + ContainerCls = OrderedDict + + def __init__(self, maxsize=10, dispose_func=None): + self._maxsize = maxsize + self.dispose_func = dispose_func + + self._container = self.ContainerCls() + self.lock = RLock() + + def __getitem__(self, key): + # Re-insert the item, moving it to the end of the eviction line. + with self.lock: + item = self._container.pop(key) + self._container[key] = item + return item + + def __setitem__(self, key, value): + evicted_value = _Null + with self.lock: + # Possibly evict the existing value of 'key' + evicted_value = self._container.get(key, _Null) + self._container[key] = value + + # If we didn't evict an existing value, we might have to evict the + # least recently used item from the beginning of the container. + if len(self._container) > self._maxsize: + _key, evicted_value = self._container.popitem(last=False) + + if self.dispose_func and evicted_value is not _Null: + self.dispose_func(evicted_value) + + def __delitem__(self, key): + with self.lock: + value = self._container.pop(key) + + if self.dispose_func: + self.dispose_func(value) + + def __len__(self): + with self.lock: + return len(self._container) + + def __iter__(self): + raise NotImplementedError('Iteration over this class is unlikely to be threadsafe.') + + def clear(self): + with self.lock: + # Copy pointers to all values, then wipe the mapping + values = list(itervalues(self._container)) + self._container.clear() + + if self.dispose_func: + for value in values: + self.dispose_func(value) + + def keys(self): + with self.lock: + return list(iterkeys(self._container)) + + +class HTTPHeaderDict(MutableMapping): + """ + :param headers: + An iterable of field-value pairs. Must not contain multiple field names + when compared case-insensitively. + + :param kwargs: + Additional field-value pairs to pass in to ``dict.update``. + + A ``dict`` like container for storing HTTP Headers. + + Field names are stored and compared case-insensitively in compliance with + RFC 7230. Iteration provides the first case-sensitive key seen for each + case-insensitive pair. + + Using ``__setitem__`` syntax overwrites fields that compare equal + case-insensitively in order to maintain ``dict``'s api. For fields that + compare equal, instead create a new ``HTTPHeaderDict`` and use ``.add`` + in a loop. + + If multiple fields that are equal case-insensitively are passed to the + constructor or ``.update``, the behavior is undefined and some will be + lost. + + >>> headers = HTTPHeaderDict() + >>> headers.add('Set-Cookie', 'foo=bar') + >>> headers.add('set-cookie', 'baz=quxx') + >>> headers['content-length'] = '7' + >>> headers['SET-cookie'] + 'foo=bar, baz=quxx' + >>> headers['Content-Length'] + '7' + """ + + def __init__(self, headers=None, **kwargs): + super(HTTPHeaderDict, self).__init__() + self._container = OrderedDict() + if headers is not None: + if isinstance(headers, HTTPHeaderDict): + self._copy_from(headers) + else: + self.extend(headers) + if kwargs: + self.extend(kwargs) + + def __setitem__(self, key, val): + self._container[key.lower()] = [key, val] + return self._container[key.lower()] + + def __getitem__(self, key): + val = self._container[key.lower()] + return ', '.join(val[1:]) + + def __delitem__(self, key): + del self._container[key.lower()] + + def __contains__(self, key): + return key.lower() in self._container + + def __eq__(self, other): + if not isinstance(other, Mapping) and not hasattr(other, 'keys'): + return False + if not isinstance(other, type(self)): + other = type(self)(other) + return (dict((k.lower(), v) for k, v in self.itermerged()) == + dict((k.lower(), v) for k, v in other.itermerged())) + + def __ne__(self, other): + return not self.__eq__(other) + + if not PY3: # Python 2 + iterkeys = MutableMapping.iterkeys + itervalues = MutableMapping.itervalues + + __marker = object() + + def __len__(self): + return len(self._container) + + def __iter__(self): + # Only provide the originally cased names + for vals in self._container.values(): + yield vals[0] + + def pop(self, key, default=__marker): + '''D.pop(k[,d]) -> v, remove specified key and return the corresponding value. + If key is not found, d is returned if given, otherwise KeyError is raised. + ''' + # Using the MutableMapping function directly fails due to the private marker. + # Using ordinary dict.pop would expose the internal structures. + # So let's reinvent the wheel. + try: + value = self[key] + except KeyError: + if default is self.__marker: + raise + return default + else: + del self[key] + return value + + def discard(self, key): + try: + del self[key] + except KeyError: + pass + + def add(self, key, val): + """Adds a (name, value) pair, doesn't overwrite the value if it already + exists. + + >>> headers = HTTPHeaderDict(foo='bar') + >>> headers.add('Foo', 'baz') + >>> headers['foo'] + 'bar, baz' + """ + key_lower = key.lower() + new_vals = [key, val] + # Keep the common case aka no item present as fast as possible + vals = self._container.setdefault(key_lower, new_vals) + if new_vals is not vals: + vals.append(val) + + def extend(self, *args, **kwargs): + """Generic import function for any type of header-like object. + Adapted version of MutableMapping.update in order to insert items + with self.add instead of self.__setitem__ + """ + if len(args) > 1: + raise TypeError("extend() takes at most 1 positional " + "arguments ({0} given)".format(len(args))) + other = args[0] if len(args) >= 1 else () + + if isinstance(other, HTTPHeaderDict): + for key, val in other.iteritems(): + self.add(key, val) + elif isinstance(other, Mapping): + for key in other: + self.add(key, other[key]) + elif hasattr(other, "keys"): + for key in other.keys(): + self.add(key, other[key]) + else: + for key, value in other: + self.add(key, value) + + for key, value in kwargs.items(): + self.add(key, value) + + def getlist(self, key, default=__marker): + """Returns a list of all the values for the named field. Returns an + empty list if the key doesn't exist.""" + try: + vals = self._container[key.lower()] + except KeyError: + if default is self.__marker: + return [] + return default + else: + return vals[1:] + + # Backwards compatibility for httplib + getheaders = getlist + getallmatchingheaders = getlist + iget = getlist + + # Backwards compatibility for http.cookiejar + get_all = getlist + + def __repr__(self): + return "%s(%s)" % (type(self).__name__, dict(self.itermerged())) + + def _copy_from(self, other): + for key in other: + val = other.getlist(key) + if isinstance(val, list): + # Don't need to convert tuples + val = list(val) + self._container[key.lower()] = [key] + val + + def copy(self): + clone = type(self)() + clone._copy_from(self) + return clone + + def iteritems(self): + """Iterate over all header lines, including duplicate ones.""" + for key in self: + vals = self._container[key.lower()] + for val in vals[1:]: + yield vals[0], val + + def itermerged(self): + """Iterate over all headers, merging duplicate ones together.""" + for key in self: + val = self._container[key.lower()] + yield val[0], ', '.join(val[1:]) + + def items(self): + return list(self.iteritems()) + + @classmethod + def from_httplib(cls, message): # Python 2 + """Read headers from a Python 2 httplib message object.""" + # python2.7 does not expose a proper API for exporting multiheaders + # efficiently. This function re-reads raw lines from the message + # object and extracts the multiheaders properly. + obs_fold_continued_leaders = (' ', '\t') + headers = [] + + for line in message.headers: + if line.startswith(obs_fold_continued_leaders): + if not headers: + # We received a header line that starts with OWS as described + # in RFC-7230 S3.2.4. This indicates a multiline header, but + # there exists no previous header to which we can attach it. + raise InvalidHeader( + 'Header continuation with no previous header: %s' % line + ) + else: + key, value = headers[-1] + headers[-1] = (key, value + ' ' + line.strip()) + continue + + key, value = line.split(':', 1) + headers.append((key, value.strip())) + + return cls(headers) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/connection.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/connection.py new file mode 100644 index 0000000..57c58fe --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/connection.py @@ -0,0 +1,417 @@ +from __future__ import absolute_import +import datetime +import logging +import os +import socket +from socket import error as SocketError, timeout as SocketTimeout +import warnings +from .packages import six +from .packages.six.moves.http_client import HTTPConnection as _HTTPConnection +from .packages.six.moves.http_client import HTTPException # noqa: F401 + +try: # Compiled with SSL? + import ssl + BaseSSLError = ssl.SSLError +except (ImportError, AttributeError): # Platform-specific: No SSL. + ssl = None + + class BaseSSLError(BaseException): + pass + + +try: + # Python 3: not a no-op, we're adding this to the namespace so it can be imported. + ConnectionError = ConnectionError +except NameError: + # Python 2 + class ConnectionError(Exception): + pass + + +from .exceptions import ( + NewConnectionError, + ConnectTimeoutError, + SubjectAltNameWarning, + SystemTimeWarning, +) +from .packages.ssl_match_hostname import match_hostname, CertificateError + +from .util.ssl_ import ( + resolve_cert_reqs, + resolve_ssl_version, + assert_fingerprint, + create_urllib3_context, + ssl_wrap_socket +) + + +from .util import connection + +from ._collections import HTTPHeaderDict + +log = logging.getLogger(__name__) + +port_by_scheme = { + 'http': 80, + 'https': 443, +} + +# When updating RECENT_DATE, move it to within two years of the current date, +# and not less than 6 months ago. +# Example: if Today is 2018-01-01, then RECENT_DATE should be any date on or +# after 2016-01-01 (today - 2 years) AND before 2017-07-01 (today - 6 months) +RECENT_DATE = datetime.date(2017, 6, 30) + + +class DummyConnection(object): + """Used to detect a failed ConnectionCls import.""" + pass + + +class HTTPConnection(_HTTPConnection, object): + """ + Based on httplib.HTTPConnection but provides an extra constructor + backwards-compatibility layer between older and newer Pythons. + + Additional keyword parameters are used to configure attributes of the connection. + Accepted parameters include: + + - ``strict``: See the documentation on :class:`urllib3.connectionpool.HTTPConnectionPool` + - ``source_address``: Set the source address for the current connection. + - ``socket_options``: Set specific options on the underlying socket. If not specified, then + defaults are loaded from ``HTTPConnection.default_socket_options`` which includes disabling + Nagle's algorithm (sets TCP_NODELAY to 1) unless the connection is behind a proxy. + + For example, if you wish to enable TCP Keep Alive in addition to the defaults, + you might pass:: + + HTTPConnection.default_socket_options + [ + (socket.SOL_SOCKET, socket.SO_KEEPALIVE, 1), + ] + + Or you may want to disable the defaults by passing an empty list (e.g., ``[]``). + """ + + default_port = port_by_scheme['http'] + + #: Disable Nagle's algorithm by default. + #: ``[(socket.IPPROTO_TCP, socket.TCP_NODELAY, 1)]`` + default_socket_options = [(socket.IPPROTO_TCP, socket.TCP_NODELAY, 1)] + + #: Whether this connection verifies the host's certificate. + is_verified = False + + def __init__(self, *args, **kw): + if six.PY3: + kw.pop('strict', None) + + # Pre-set source_address. + self.source_address = kw.get('source_address') + + #: The socket options provided by the user. If no options are + #: provided, we use the default options. + self.socket_options = kw.pop('socket_options', self.default_socket_options) + + _HTTPConnection.__init__(self, *args, **kw) + + @property + def host(self): + """ + Getter method to remove any trailing dots that indicate the hostname is an FQDN. + + In general, SSL certificates don't include the trailing dot indicating a + fully-qualified domain name, and thus, they don't validate properly when + checked against a domain name that includes the dot. In addition, some + servers may not expect to receive the trailing dot when provided. + + However, the hostname with trailing dot is critical to DNS resolution; doing a + lookup with the trailing dot will properly only resolve the appropriate FQDN, + whereas a lookup without a trailing dot will search the system's search domain + list. Thus, it's important to keep the original host around for use only in + those cases where it's appropriate (i.e., when doing DNS lookup to establish the + actual TCP connection across which we're going to send HTTP requests). + """ + return self._dns_host.rstrip('.') + + @host.setter + def host(self, value): + """ + Setter for the `host` property. + + We assume that only urllib3 uses the _dns_host attribute; httplib itself + only uses `host`, and it seems reasonable that other libraries follow suit. + """ + self._dns_host = value + + def _new_conn(self): + """ Establish a socket connection and set nodelay settings on it. + + :return: New socket connection. + """ + extra_kw = {} + if self.source_address: + extra_kw['source_address'] = self.source_address + + if self.socket_options: + extra_kw['socket_options'] = self.socket_options + + try: + conn = connection.create_connection( + (self._dns_host, self.port), self.timeout, **extra_kw) + + except SocketTimeout: + raise ConnectTimeoutError( + self, "Connection to %s timed out. (connect timeout=%s)" % + (self.host, self.timeout)) + + except SocketError as e: + raise NewConnectionError( + self, "Failed to establish a new connection: %s" % e) + + return conn + + def _prepare_conn(self, conn): + self.sock = conn + # Google App Engine's httplib does not define _tunnel_host + if getattr(self, '_tunnel_host', None): + # TODO: Fix tunnel so it doesn't depend on self.sock state. + self._tunnel() + # Mark this connection as not reusable + self.auto_open = 0 + + def connect(self): + conn = self._new_conn() + self._prepare_conn(conn) + + def request_chunked(self, method, url, body=None, headers=None): + """ + Alternative to the common request method, which sends the + body with chunked encoding and not as one block + """ + headers = HTTPHeaderDict(headers if headers is not None else {}) + skip_accept_encoding = 'accept-encoding' in headers + skip_host = 'host' in headers + self.putrequest( + method, + url, + skip_accept_encoding=skip_accept_encoding, + skip_host=skip_host + ) + for header, value in headers.items(): + self.putheader(header, value) + if 'transfer-encoding' not in headers: + self.putheader('Transfer-Encoding', 'chunked') + self.endheaders() + + if body is not None: + stringish_types = six.string_types + (bytes,) + if isinstance(body, stringish_types): + body = (body,) + for chunk in body: + if not chunk: + continue + if not isinstance(chunk, bytes): + chunk = chunk.encode('utf8') + len_str = hex(len(chunk))[2:] + self.send(len_str.encode('utf-8')) + self.send(b'\r\n') + self.send(chunk) + self.send(b'\r\n') + + # After the if clause, to always have a closed body + self.send(b'0\r\n\r\n') + + +class HTTPSConnection(HTTPConnection): + default_port = port_by_scheme['https'] + + ssl_version = None + + def __init__(self, host, port=None, key_file=None, cert_file=None, + key_password=None, strict=None, + timeout=socket._GLOBAL_DEFAULT_TIMEOUT, + ssl_context=None, server_hostname=None, **kw): + + HTTPConnection.__init__(self, host, port, strict=strict, + timeout=timeout, **kw) + + self.key_file = key_file + self.cert_file = cert_file + self.key_password = key_password + self.ssl_context = ssl_context + self.server_hostname = server_hostname + + # Required property for Google AppEngine 1.9.0 which otherwise causes + # HTTPS requests to go out as HTTP. (See Issue #356) + self._protocol = 'https' + + def connect(self): + conn = self._new_conn() + self._prepare_conn(conn) + + # Wrap socket using verification with the root certs in + # trusted_root_certs + default_ssl_context = False + if self.ssl_context is None: + default_ssl_context = True + self.ssl_context = create_urllib3_context( + ssl_version=resolve_ssl_version(self.ssl_version), + cert_reqs=resolve_cert_reqs(self.cert_reqs), + ) + + # Try to load OS default certs if none are given. + # Works well on Windows (requires Python3.4+) + context = self.ssl_context + if (not self.ca_certs and not self.ca_cert_dir and default_ssl_context + and hasattr(context, 'load_default_certs')): + context.load_default_certs() + + self.sock = ssl_wrap_socket( + sock=conn, + keyfile=self.key_file, + certfile=self.cert_file, + key_password=self.key_password, + ssl_context=self.ssl_context, + server_hostname=self.server_hostname + ) + + +class VerifiedHTTPSConnection(HTTPSConnection): + """ + Based on httplib.HTTPSConnection but wraps the socket with + SSL certification. + """ + cert_reqs = None + ca_certs = None + ca_cert_dir = None + ssl_version = None + assert_fingerprint = None + + def set_cert(self, key_file=None, cert_file=None, + cert_reqs=None, key_password=None, ca_certs=None, + assert_hostname=None, assert_fingerprint=None, + ca_cert_dir=None): + """ + This method should only be called once, before the connection is used. + """ + # If cert_reqs is not provided we'll assume CERT_REQUIRED unless we also + # have an SSLContext object in which case we'll use its verify_mode. + if cert_reqs is None: + if self.ssl_context is not None: + cert_reqs = self.ssl_context.verify_mode + else: + cert_reqs = resolve_cert_reqs(None) + + self.key_file = key_file + self.cert_file = cert_file + self.cert_reqs = cert_reqs + self.key_password = key_password + self.assert_hostname = assert_hostname + self.assert_fingerprint = assert_fingerprint + self.ca_certs = ca_certs and os.path.expanduser(ca_certs) + self.ca_cert_dir = ca_cert_dir and os.path.expanduser(ca_cert_dir) + + def connect(self): + # Add certificate verification + conn = self._new_conn() + hostname = self.host + + # Google App Engine's httplib does not define _tunnel_host + if getattr(self, '_tunnel_host', None): + self.sock = conn + # Calls self._set_hostport(), so self.host is + # self._tunnel_host below. + self._tunnel() + # Mark this connection as not reusable + self.auto_open = 0 + + # Override the host with the one we're requesting data from. + hostname = self._tunnel_host + + server_hostname = hostname + if self.server_hostname is not None: + server_hostname = self.server_hostname + + is_time_off = datetime.date.today() < RECENT_DATE + if is_time_off: + warnings.warn(( + 'System time is way off (before {0}). This will probably ' + 'lead to SSL verification errors').format(RECENT_DATE), + SystemTimeWarning + ) + + # Wrap socket using verification with the root certs in + # trusted_root_certs + default_ssl_context = False + if self.ssl_context is None: + default_ssl_context = True + self.ssl_context = create_urllib3_context( + ssl_version=resolve_ssl_version(self.ssl_version), + cert_reqs=resolve_cert_reqs(self.cert_reqs), + ) + + context = self.ssl_context + context.verify_mode = resolve_cert_reqs(self.cert_reqs) + + # Try to load OS default certs if none are given. + # Works well on Windows (requires Python3.4+) + if (not self.ca_certs and not self.ca_cert_dir and default_ssl_context + and hasattr(context, 'load_default_certs')): + context.load_default_certs() + + self.sock = ssl_wrap_socket( + sock=conn, + keyfile=self.key_file, + certfile=self.cert_file, + key_password=self.key_password, + ca_certs=self.ca_certs, + ca_cert_dir=self.ca_cert_dir, + server_hostname=server_hostname, + ssl_context=context) + + if self.assert_fingerprint: + assert_fingerprint(self.sock.getpeercert(binary_form=True), + self.assert_fingerprint) + elif context.verify_mode != ssl.CERT_NONE \ + and not getattr(context, 'check_hostname', False) \ + and self.assert_hostname is not False: + # While urllib3 attempts to always turn off hostname matching from + # the TLS library, this cannot always be done. So we check whether + # the TLS Library still thinks it's matching hostnames. + cert = self.sock.getpeercert() + if not cert.get('subjectAltName', ()): + warnings.warn(( + 'Certificate for {0} has no `subjectAltName`, falling back to check for a ' + '`commonName` for now. This feature is being removed by major browsers and ' + 'deprecated by RFC 2818. (See https://github.com/shazow/urllib3/issues/497 ' + 'for details.)'.format(hostname)), + SubjectAltNameWarning + ) + _match_hostname(cert, self.assert_hostname or server_hostname) + + self.is_verified = ( + context.verify_mode == ssl.CERT_REQUIRED or + self.assert_fingerprint is not None + ) + + +def _match_hostname(cert, asserted_hostname): + try: + match_hostname(cert, asserted_hostname) + except CertificateError as e: + log.error( + 'Certificate did not match expected hostname: %s. ' + 'Certificate: %s', asserted_hostname, cert + ) + # Add cert to exception and reraise so client code can inspect + # the cert when catching the exception, if they want to + e._peer_cert = cert + raise + + +if ssl: + # Make a copy for testing. + UnverifiedHTTPSConnection = HTTPSConnection + HTTPSConnection = VerifiedHTTPSConnection +else: + HTTPSConnection = DummyConnection diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/connectionpool.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/connectionpool.py new file mode 100644 index 0000000..157568a --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/connectionpool.py @@ -0,0 +1,897 @@ +from __future__ import absolute_import +import errno +import logging +import sys +import warnings + +from socket import error as SocketError, timeout as SocketTimeout +import socket + + +from .exceptions import ( + ClosedPoolError, + ProtocolError, + EmptyPoolError, + HeaderParsingError, + HostChangedError, + LocationValueError, + MaxRetryError, + ProxyError, + ReadTimeoutError, + SSLError, + TimeoutError, + InsecureRequestWarning, + NewConnectionError, +) +from .packages.ssl_match_hostname import CertificateError +from .packages import six +from .packages.six.moves import queue +from .packages.rfc3986.normalizers import normalize_host +from .connection import ( + port_by_scheme, + DummyConnection, + HTTPConnection, HTTPSConnection, VerifiedHTTPSConnection, + HTTPException, BaseSSLError, +) +from .request import RequestMethods +from .response import HTTPResponse + +from .util.connection import is_connection_dropped +from .util.request import set_file_position +from .util.response import assert_header_parsing +from .util.retry import Retry +from .util.timeout import Timeout +from .util.url import get_host, Url, NORMALIZABLE_SCHEMES +from .util.queue import LifoQueue + + +xrange = six.moves.xrange + +log = logging.getLogger(__name__) + +_Default = object() + + +# Pool objects +class ConnectionPool(object): + """ + Base class for all connection pools, such as + :class:`.HTTPConnectionPool` and :class:`.HTTPSConnectionPool`. + """ + + scheme = None + QueueCls = LifoQueue + + def __init__(self, host, port=None): + if not host: + raise LocationValueError("No host specified.") + + self.host = _normalize_host(host, scheme=self.scheme) + self._proxy_host = host.lower() + self.port = port + + def __str__(self): + return '%s(host=%r, port=%r)' % (type(self).__name__, + self.host, self.port) + + def __enter__(self): + return self + + def __exit__(self, exc_type, exc_val, exc_tb): + self.close() + # Return False to re-raise any potential exceptions + return False + + def close(self): + """ + Close all pooled connections and disable the pool. + """ + pass + + +# This is taken from http://hg.python.org/cpython/file/7aaba721ebc0/Lib/socket.py#l252 +_blocking_errnos = {errno.EAGAIN, errno.EWOULDBLOCK} + + +class HTTPConnectionPool(ConnectionPool, RequestMethods): + """ + Thread-safe connection pool for one host. + + :param host: + Host used for this HTTP Connection (e.g. "localhost"), passed into + :class:`httplib.HTTPConnection`. + + :param port: + Port used for this HTTP Connection (None is equivalent to 80), passed + into :class:`httplib.HTTPConnection`. + + :param strict: + Causes BadStatusLine to be raised if the status line can't be parsed + as a valid HTTP/1.0 or 1.1 status line, passed into + :class:`httplib.HTTPConnection`. + + .. note:: + Only works in Python 2. This parameter is ignored in Python 3. + + :param timeout: + Socket timeout in seconds for each individual connection. This can + be a float or integer, which sets the timeout for the HTTP request, + or an instance of :class:`urllib3.util.Timeout` which gives you more + fine-grained control over request timeouts. After the constructor has + been parsed, this is always a `urllib3.util.Timeout` object. + + :param maxsize: + Number of connections to save that can be reused. More than 1 is useful + in multithreaded situations. If ``block`` is set to False, more + connections will be created but they will not be saved once they've + been used. + + :param block: + If set to True, no more than ``maxsize`` connections will be used at + a time. When no free connections are available, the call will block + until a connection has been released. This is a useful side effect for + particular multithreaded situations where one does not want to use more + than maxsize connections per host to prevent flooding. + + :param headers: + Headers to include with all requests, unless other headers are given + explicitly. + + :param retries: + Retry configuration to use by default with requests in this pool. + + :param _proxy: + Parsed proxy URL, should not be used directly, instead, see + :class:`urllib3.connectionpool.ProxyManager`" + + :param _proxy_headers: + A dictionary with proxy headers, should not be used directly, + instead, see :class:`urllib3.connectionpool.ProxyManager`" + + :param \\**conn_kw: + Additional parameters are used to create fresh :class:`urllib3.connection.HTTPConnection`, + :class:`urllib3.connection.HTTPSConnection` instances. + """ + + scheme = 'http' + ConnectionCls = HTTPConnection + ResponseCls = HTTPResponse + + def __init__(self, host, port=None, strict=False, + timeout=Timeout.DEFAULT_TIMEOUT, maxsize=1, block=False, + headers=None, retries=None, + _proxy=None, _proxy_headers=None, + **conn_kw): + ConnectionPool.__init__(self, host, port) + RequestMethods.__init__(self, headers) + + self.strict = strict + + if not isinstance(timeout, Timeout): + timeout = Timeout.from_float(timeout) + + if retries is None: + retries = Retry.DEFAULT + + self.timeout = timeout + self.retries = retries + + self.pool = self.QueueCls(maxsize) + self.block = block + + self.proxy = _proxy + self.proxy_headers = _proxy_headers or {} + + # Fill the queue up so that doing get() on it will block properly + for _ in xrange(maxsize): + self.pool.put(None) + + # These are mostly for testing and debugging purposes. + self.num_connections = 0 + self.num_requests = 0 + self.conn_kw = conn_kw + + if self.proxy: + # Enable Nagle's algorithm for proxies, to avoid packet fragmentation. + # We cannot know if the user has added default socket options, so we cannot replace the + # list. + self.conn_kw.setdefault('socket_options', []) + + def _new_conn(self): + """ + Return a fresh :class:`HTTPConnection`. + """ + self.num_connections += 1 + log.debug("Starting new HTTP connection (%d): %s:%s", + self.num_connections, self.host, self.port or "80") + + conn = self.ConnectionCls(host=self.host, port=self.port, + timeout=self.timeout.connect_timeout, + strict=self.strict, **self.conn_kw) + return conn + + def _get_conn(self, timeout=None): + """ + Get a connection. Will return a pooled connection if one is available. + + If no connections are available and :prop:`.block` is ``False``, then a + fresh connection is returned. + + :param timeout: + Seconds to wait before giving up and raising + :class:`urllib3.exceptions.EmptyPoolError` if the pool is empty and + :prop:`.block` is ``True``. + """ + conn = None + try: + conn = self.pool.get(block=self.block, timeout=timeout) + + except AttributeError: # self.pool is None + raise ClosedPoolError(self, "Pool is closed.") + + except queue.Empty: + if self.block: + raise EmptyPoolError(self, + "Pool reached maximum size and no more " + "connections are allowed.") + pass # Oh well, we'll create a new connection then + + # If this is a persistent connection, check if it got disconnected + if conn and is_connection_dropped(conn): + log.debug("Resetting dropped connection: %s", self.host) + conn.close() + if getattr(conn, 'auto_open', 1) == 0: + # This is a proxied connection that has been mutated by + # httplib._tunnel() and cannot be reused (since it would + # attempt to bypass the proxy) + conn = None + + return conn or self._new_conn() + + def _put_conn(self, conn): + """ + Put a connection back into the pool. + + :param conn: + Connection object for the current host and port as returned by + :meth:`._new_conn` or :meth:`._get_conn`. + + If the pool is already full, the connection is closed and discarded + because we exceeded maxsize. If connections are discarded frequently, + then maxsize should be increased. + + If the pool is closed, then the connection will be closed and discarded. + """ + try: + self.pool.put(conn, block=False) + return # Everything is dandy, done. + except AttributeError: + # self.pool is None. + pass + except queue.Full: + # This should never happen if self.block == True + log.warning( + "Connection pool is full, discarding connection: %s", + self.host) + + # Connection never got put back into the pool, close it. + if conn: + conn.close() + + def _validate_conn(self, conn): + """ + Called right before a request is made, after the socket is created. + """ + pass + + def _prepare_proxy(self, conn): + # Nothing to do for HTTP connections. + pass + + def _get_timeout(self, timeout): + """ Helper that always returns a :class:`urllib3.util.Timeout` """ + if timeout is _Default: + return self.timeout.clone() + + if isinstance(timeout, Timeout): + return timeout.clone() + else: + # User passed us an int/float. This is for backwards compatibility, + # can be removed later + return Timeout.from_float(timeout) + + def _raise_timeout(self, err, url, timeout_value): + """Is the error actually a timeout? Will raise a ReadTimeout or pass""" + + if isinstance(err, SocketTimeout): + raise ReadTimeoutError(self, url, "Read timed out. (read timeout=%s)" % timeout_value) + + # See the above comment about EAGAIN in Python 3. In Python 2 we have + # to specifically catch it and throw the timeout error + if hasattr(err, 'errno') and err.errno in _blocking_errnos: + raise ReadTimeoutError(self, url, "Read timed out. (read timeout=%s)" % timeout_value) + + # Catch possible read timeouts thrown as SSL errors. If not the + # case, rethrow the original. We need to do this because of: + # http://bugs.python.org/issue10272 + if 'timed out' in str(err) or 'did not complete (read)' in str(err): # Python < 2.7.4 + raise ReadTimeoutError(self, url, "Read timed out. (read timeout=%s)" % timeout_value) + + def _make_request(self, conn, method, url, timeout=_Default, chunked=False, + **httplib_request_kw): + """ + Perform a request on a given urllib connection object taken from our + pool. + + :param conn: + a connection from one of our connection pools + + :param timeout: + Socket timeout in seconds for the request. This can be a + float or integer, which will set the same timeout value for + the socket connect and the socket read, or an instance of + :class:`urllib3.util.Timeout`, which gives you more fine-grained + control over your timeouts. + """ + self.num_requests += 1 + + timeout_obj = self._get_timeout(timeout) + timeout_obj.start_connect() + conn.timeout = timeout_obj.connect_timeout + + # Trigger any extra validation we need to do. + try: + self._validate_conn(conn) + except (SocketTimeout, BaseSSLError) as e: + # Py2 raises this as a BaseSSLError, Py3 raises it as socket timeout. + self._raise_timeout(err=e, url=url, timeout_value=conn.timeout) + raise + + # conn.request() calls httplib.*.request, not the method in + # urllib3.request. It also calls makefile (recv) on the socket. + if chunked: + conn.request_chunked(method, url, **httplib_request_kw) + else: + conn.request(method, url, **httplib_request_kw) + + # Reset the timeout for the recv() on the socket + read_timeout = timeout_obj.read_timeout + + # App Engine doesn't have a sock attr + if getattr(conn, 'sock', None): + # In Python 3 socket.py will catch EAGAIN and return None when you + # try and read into the file pointer created by http.client, which + # instead raises a BadStatusLine exception. Instead of catching + # the exception and assuming all BadStatusLine exceptions are read + # timeouts, check for a zero timeout before making the request. + if read_timeout == 0: + raise ReadTimeoutError( + self, url, "Read timed out. (read timeout=%s)" % read_timeout) + if read_timeout is Timeout.DEFAULT_TIMEOUT: + conn.sock.settimeout(socket.getdefaulttimeout()) + else: # None or a value + conn.sock.settimeout(read_timeout) + + # Receive the response from the server + try: + try: + # Python 2.7, use buffering of HTTP responses + httplib_response = conn.getresponse(buffering=True) + except TypeError: + # Python 3 + try: + httplib_response = conn.getresponse() + except Exception as e: + # Remove the TypeError from the exception chain in Python 3; + # otherwise it looks like a programming error was the cause. + six.raise_from(e, None) + except (SocketTimeout, BaseSSLError, SocketError) as e: + self._raise_timeout(err=e, url=url, timeout_value=read_timeout) + raise + + # AppEngine doesn't have a version attr. + http_version = getattr(conn, '_http_vsn_str', 'HTTP/?') + log.debug("%s://%s:%s \"%s %s %s\" %s %s", self.scheme, self.host, self.port, + method, url, http_version, httplib_response.status, + httplib_response.length) + + try: + assert_header_parsing(httplib_response.msg) + except (HeaderParsingError, TypeError) as hpe: # Platform-specific: Python 3 + log.warning( + 'Failed to parse headers (url=%s): %s', + self._absolute_url(url), hpe, exc_info=True) + + return httplib_response + + def _absolute_url(self, path): + return Url(scheme=self.scheme, host=self.host, port=self.port, path=path).url + + def close(self): + """ + Close all pooled connections and disable the pool. + """ + if self.pool is None: + return + # Disable access to the pool + old_pool, self.pool = self.pool, None + + try: + while True: + conn = old_pool.get(block=False) + if conn: + conn.close() + + except queue.Empty: + pass # Done. + + def is_same_host(self, url): + """ + Check if the given ``url`` is a member of the same host as this + connection pool. + """ + if url.startswith('/'): + return True + + # TODO: Add optional support for socket.gethostbyname checking. + scheme, host, port = get_host(url) + if host is not None: + host = _normalize_host(host, scheme=scheme) + + # Use explicit default port for comparison when none is given + if self.port and not port: + port = port_by_scheme.get(scheme) + elif not self.port and port == port_by_scheme.get(scheme): + port = None + + return (scheme, host, port) == (self.scheme, self.host, self.port) + + def urlopen(self, method, url, body=None, headers=None, retries=None, + redirect=True, assert_same_host=True, timeout=_Default, + pool_timeout=None, release_conn=None, chunked=False, + body_pos=None, **response_kw): + """ + Get a connection from the pool and perform an HTTP request. This is the + lowest level call for making a request, so you'll need to specify all + the raw details. + + .. note:: + + More commonly, it's appropriate to use a convenience method provided + by :class:`.RequestMethods`, such as :meth:`request`. + + .. note:: + + `release_conn` will only behave as expected if + `preload_content=False` because we want to make + `preload_content=False` the default behaviour someday soon without + breaking backwards compatibility. + + :param method: + HTTP request method (such as GET, POST, PUT, etc.) + + :param body: + Data to send in the request body (useful for creating + POST requests, see HTTPConnectionPool.post_url for + more convenience). + + :param headers: + Dictionary of custom headers to send, such as User-Agent, + If-None-Match, etc. If None, pool headers are used. If provided, + these headers completely replace any pool-specific headers. + + :param retries: + Configure the number of retries to allow before raising a + :class:`~urllib3.exceptions.MaxRetryError` exception. + + Pass ``None`` to retry until you receive a response. Pass a + :class:`~urllib3.util.retry.Retry` object for fine-grained control + over different types of retries. + Pass an integer number to retry connection errors that many times, + but no other types of errors. Pass zero to never retry. + + If ``False``, then retries are disabled and any exception is raised + immediately. Also, instead of raising a MaxRetryError on redirects, + the redirect response will be returned. + + :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. + + :param redirect: + If True, automatically handle redirects (status codes 301, 302, + 303, 307, 308). Each redirect counts as a retry. Disabling retries + will disable redirect, too. + + :param assert_same_host: + If ``True``, will make sure that the host of the pool requests is + consistent else will raise HostChangedError. When False, you can + use the pool on an HTTP proxy and request foreign hosts. + + :param timeout: + If specified, overrides the default timeout for this one + request. It may be a float (in seconds) or an instance of + :class:`urllib3.util.Timeout`. + + :param pool_timeout: + If set and the pool is set to block=True, then this method will + block for ``pool_timeout`` seconds and raise EmptyPoolError if no + connection is available within the time period. + + :param release_conn: + If False, then the urlopen call will not release the connection + back into the pool once a response is received (but will release if + you read the entire contents of the response such as when + `preload_content=True`). This is useful if you're not preloading + the response's content immediately. You will need to call + ``r.release_conn()`` on the response ``r`` to return the connection + back into the pool. If None, it takes the value of + ``response_kw.get('preload_content', True)``. + + :param chunked: + If True, urllib3 will send the body using chunked transfer + encoding. Otherwise, urllib3 will send the body using the standard + content-length form. Defaults to False. + + :param int body_pos: + Position to seek to in file-like body in the event of a retry or + redirect. Typically this won't need to be set because urllib3 will + auto-populate the value when needed. + + :param \\**response_kw: + Additional parameters are passed to + :meth:`urllib3.response.HTTPResponse.from_httplib` + """ + if headers is None: + headers = self.headers + + if not isinstance(retries, Retry): + retries = Retry.from_int(retries, redirect=redirect, default=self.retries) + + if release_conn is None: + release_conn = response_kw.get('preload_content', True) + + # Check host + if assert_same_host and not self.is_same_host(url): + raise HostChangedError(self, url, retries) + + conn = None + + # Track whether `conn` needs to be released before + # returning/raising/recursing. Update this variable if necessary, and + # leave `release_conn` constant throughout the function. That way, if + # the function recurses, the original value of `release_conn` will be + # passed down into the recursive call, and its value will be respected. + # + # See issue #651 [1] for details. + # + # [1] <https://github.com/shazow/urllib3/issues/651> + release_this_conn = release_conn + + # Merge the proxy headers. Only do this in HTTP. We have to copy the + # headers dict so we can safely change it without those changes being + # reflected in anyone else's copy. + if self.scheme == 'http': + headers = headers.copy() + headers.update(self.proxy_headers) + + # Must keep the exception bound to a separate variable or else Python 3 + # complains about UnboundLocalError. + err = None + + # Keep track of whether we cleanly exited the except block. This + # ensures we do proper cleanup in finally. + clean_exit = False + + # Rewind body position, if needed. Record current position + # for future rewinds in the event of a redirect/retry. + body_pos = set_file_position(body, body_pos) + + try: + # Request a connection from the queue. + timeout_obj = self._get_timeout(timeout) + conn = self._get_conn(timeout=pool_timeout) + + conn.timeout = timeout_obj.connect_timeout + + is_new_proxy_conn = self.proxy is not None and not getattr(conn, 'sock', None) + if is_new_proxy_conn: + self._prepare_proxy(conn) + + # Make the request on the httplib connection object. + httplib_response = self._make_request(conn, method, url, + timeout=timeout_obj, + body=body, headers=headers, + chunked=chunked) + + # If we're going to release the connection in ``finally:``, then + # the response doesn't need to know about the connection. Otherwise + # it will also try to release it and we'll have a double-release + # mess. + response_conn = conn if not release_conn else None + + # Pass method to Response for length checking + response_kw['request_method'] = method + + # Import httplib's response into our own wrapper object + response = self.ResponseCls.from_httplib(httplib_response, + pool=self, + connection=response_conn, + retries=retries, + **response_kw) + + # Everything went great! + clean_exit = True + + except queue.Empty: + # Timed out by queue. + raise EmptyPoolError(self, "No pool connections are available.") + + except (TimeoutError, HTTPException, SocketError, ProtocolError, + BaseSSLError, SSLError, CertificateError) as e: + # Discard the connection for these exceptions. It will be + # replaced during the next _get_conn() call. + clean_exit = False + if isinstance(e, (BaseSSLError, CertificateError)): + e = SSLError(e) + elif isinstance(e, (SocketError, NewConnectionError)) and self.proxy: + e = ProxyError('Cannot connect to proxy.', e) + elif isinstance(e, (SocketError, HTTPException)): + e = ProtocolError('Connection aborted.', e) + + retries = retries.increment(method, url, error=e, _pool=self, + _stacktrace=sys.exc_info()[2]) + retries.sleep() + + # Keep track of the error for the retry warning. + err = e + + finally: + if not clean_exit: + # We hit some kind of exception, handled or otherwise. We need + # to throw the connection away unless explicitly told not to. + # Close the connection, set the variable to None, and make sure + # we put the None back in the pool to avoid leaking it. + conn = conn and conn.close() + release_this_conn = True + + if release_this_conn: + # Put the connection back to be reused. If the connection is + # expired then it will be None, which will get replaced with a + # fresh connection during _get_conn. + self._put_conn(conn) + + if not conn: + # Try again + log.warning("Retrying (%r) after connection " + "broken by '%r': %s", retries, err, url) + return self.urlopen(method, url, body, headers, retries, + redirect, assert_same_host, + timeout=timeout, pool_timeout=pool_timeout, + release_conn=release_conn, body_pos=body_pos, + **response_kw) + + def drain_and_release_conn(response): + try: + # discard any remaining response body, the connection will be + # released back to the pool once the entire response is read + response.read() + except (TimeoutError, HTTPException, SocketError, ProtocolError, + BaseSSLError, SSLError): + pass + + # Handle redirect? + redirect_location = redirect and response.get_redirect_location() + if redirect_location: + if response.status == 303: + method = 'GET' + + try: + retries = retries.increment(method, url, response=response, _pool=self) + except MaxRetryError: + if retries.raise_on_redirect: + # Drain and release the connection for this response, since + # we're not returning it to be released manually. + drain_and_release_conn(response) + raise + return response + + # drain and return the connection to the pool before recursing + drain_and_release_conn(response) + + retries.sleep_for_retry(response) + log.debug("Redirecting %s -> %s", url, redirect_location) + return self.urlopen( + method, redirect_location, body, headers, + retries=retries, redirect=redirect, + assert_same_host=assert_same_host, + timeout=timeout, pool_timeout=pool_timeout, + release_conn=release_conn, body_pos=body_pos, + **response_kw) + + # Check if we should retry the HTTP response. + has_retry_after = bool(response.getheader('Retry-After')) + if retries.is_retry(method, response.status, has_retry_after): + try: + retries = retries.increment(method, url, response=response, _pool=self) + except MaxRetryError: + if retries.raise_on_status: + # Drain and release the connection for this response, since + # we're not returning it to be released manually. + drain_and_release_conn(response) + raise + return response + + # drain and return the connection to the pool before recursing + drain_and_release_conn(response) + + retries.sleep(response) + log.debug("Retry: %s", url) + return self.urlopen( + method, url, body, headers, + retries=retries, redirect=redirect, + assert_same_host=assert_same_host, + timeout=timeout, pool_timeout=pool_timeout, + release_conn=release_conn, + body_pos=body_pos, **response_kw) + + return response + + +class HTTPSConnectionPool(HTTPConnectionPool): + """ + Same as :class:`.HTTPConnectionPool`, but HTTPS. + + When Python is compiled with the :mod:`ssl` module, then + :class:`.VerifiedHTTPSConnection` is used, which *can* verify certificates, + instead of :class:`.HTTPSConnection`. + + :class:`.VerifiedHTTPSConnection` uses one of ``assert_fingerprint``, + ``assert_hostname`` and ``host`` in this order to verify connections. + If ``assert_hostname`` is False, no verification is done. + + The ``key_file``, ``cert_file``, ``cert_reqs``, ``ca_certs``, + ``ca_cert_dir``, ``ssl_version``, ``key_password`` are only used if :mod:`ssl` + is available and are fed into :meth:`urllib3.util.ssl_wrap_socket` to upgrade + the connection socket into an SSL socket. + """ + + scheme = 'https' + ConnectionCls = HTTPSConnection + + def __init__(self, host, port=None, + strict=False, timeout=Timeout.DEFAULT_TIMEOUT, maxsize=1, + block=False, headers=None, retries=None, + _proxy=None, _proxy_headers=None, + key_file=None, cert_file=None, cert_reqs=None, + key_password=None, ca_certs=None, ssl_version=None, + assert_hostname=None, assert_fingerprint=None, + ca_cert_dir=None, **conn_kw): + + HTTPConnectionPool.__init__(self, host, port, strict, timeout, maxsize, + block, headers, retries, _proxy, _proxy_headers, + **conn_kw) + + self.key_file = key_file + self.cert_file = cert_file + self.cert_reqs = cert_reqs + self.key_password = key_password + self.ca_certs = ca_certs + self.ca_cert_dir = ca_cert_dir + self.ssl_version = ssl_version + self.assert_hostname = assert_hostname + self.assert_fingerprint = assert_fingerprint + + def _prepare_conn(self, conn): + """ + Prepare the ``connection`` for :meth:`urllib3.util.ssl_wrap_socket` + and establish the tunnel if proxy is used. + """ + + if isinstance(conn, VerifiedHTTPSConnection): + conn.set_cert(key_file=self.key_file, + key_password=self.key_password, + cert_file=self.cert_file, + cert_reqs=self.cert_reqs, + ca_certs=self.ca_certs, + ca_cert_dir=self.ca_cert_dir, + assert_hostname=self.assert_hostname, + assert_fingerprint=self.assert_fingerprint) + conn.ssl_version = self.ssl_version + return conn + + def _prepare_proxy(self, conn): + """ + Establish tunnel connection early, because otherwise httplib + would improperly set Host: header to proxy's IP:port. + """ + conn.set_tunnel(self._proxy_host, self.port, self.proxy_headers) + conn.connect() + + def _new_conn(self): + """ + Return a fresh :class:`httplib.HTTPSConnection`. + """ + self.num_connections += 1 + log.debug("Starting new HTTPS connection (%d): %s:%s", + self.num_connections, self.host, self.port or "443") + + if not self.ConnectionCls or self.ConnectionCls is DummyConnection: + raise SSLError("Can't connect to HTTPS URL because the SSL " + "module is not available.") + + actual_host = self.host + actual_port = self.port + if self.proxy is not None: + actual_host = self.proxy.host + actual_port = self.proxy.port + + conn = self.ConnectionCls(host=actual_host, port=actual_port, + timeout=self.timeout.connect_timeout, + strict=self.strict, cert_file=self.cert_file, + key_file=self.key_file, key_password=self.key_password, + **self.conn_kw) + + return self._prepare_conn(conn) + + def _validate_conn(self, conn): + """ + Called right before a request is made, after the socket is created. + """ + super(HTTPSConnectionPool, self)._validate_conn(conn) + + # Force connect early to allow us to validate the connection. + if not getattr(conn, 'sock', None): # AppEngine might not have `.sock` + conn.connect() + + if not conn.is_verified: + warnings.warn(( + 'Unverified HTTPS request is being made. ' + 'Adding certificate verification is strongly advised. See: ' + 'https://urllib3.readthedocs.io/en/latest/advanced-usage.html' + '#ssl-warnings'), + InsecureRequestWarning) + + +def connection_from_url(url, **kw): + """ + Given a url, return an :class:`.ConnectionPool` instance of its host. + + This is a shortcut for not having to parse out the scheme, host, and port + of the url before creating an :class:`.ConnectionPool` instance. + + :param url: + Absolute URL string that must include the scheme. Port is optional. + + :param \\**kw: + Passes additional parameters to the constructor of the appropriate + :class:`.ConnectionPool`. Useful for specifying things like + timeout, maxsize, headers, etc. + + Example:: + + >>> conn = connection_from_url('http://google.com/') + >>> r = conn.request('GET', '/') + """ + scheme, host, port = get_host(url) + port = port or port_by_scheme.get(scheme, 80) + if scheme == 'https': + return HTTPSConnectionPool(host, port=port, **kw) + else: + return HTTPConnectionPool(host, port=port, **kw) + + +def _normalize_host(host, scheme): + """ + Normalize hosts for comparisons and use with sockets. + """ + + # httplib doesn't like it when we include brackets in IPv6 addresses + # Specifically, if we include brackets but also pass the port then + # httplib crazily doubles up the square brackets on the Host header. + # Instead, we need to make sure we never pass ``None`` as the port. + # However, for backward compatibility reasons we can't actually + # *assert* that. See http://bugs.python.org/issue28539 + if host.startswith('[') and host.endswith(']'): + host = host.strip('[]') + if scheme in NORMALIZABLE_SCHEMES: + host = normalize_host(host) + return host diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5bcf16a53489ff3a3f27912b91c4feee93546316 GIT binary patch literal 212 zcmWIL<>g`kf^QoZCW7e4AOaaM0yz#qT+9L_QW%06G#UL?G8BP?5yY=b{eq&*vc!^9 z{j$U&{j~g?l+>bPeai~{^mxm%qTH%HqqHo8jEst^s`wmBv!sk710YDx(+|-v$Sly! z%quQQ%*oL;Ffc2tEHf+x34(EaS!!NNevy7@QBF=~lCgereqKpYW|Dq<d}dx|NqoFs WLFFwDo80`A(wtN~kdr<GF#`ZzwmLQd literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1009d426fc24ccb703f23df79361727b135e742a GIT binary patch literal 1140 zcmZ`&Pfy!06t|r;4JF+Mn%H(2%C!eb*(5ZiX<D}h#DNaAg-Kkjv^H%@8b^*BL9gtC zj3c*wk$r(&ciI=&VF%cAT0teKCBJ9?{O|XE@A;@&tsrQBe_jQ@2tvR0WWE80K0;65 zfnn$bG0aGWPcSo>`5m1QR$>--gO!;L-egOx0=~qSnFHQpq>XCT$)`$Z5T@=(uyMrQ zM2akA9OgWTQ&$O>am9PeRRiuelEn4nei(C?$5|*vJmRt1to#86sM*tYzG0YrhMum1 zQRosS&lD~!xkPPrjhi(iUky_liCz%VAW3*}dA<S|5MguB+5?D=vQc`Cqy?83=HI24 z$S?~O_p(5Gry^oprryrE*QYy~98Kakr^EVSa6XyPXlJ`SkacMN*z0&nm~4b`s)8um zsMoi%i)?GG!J^ZQ$4p3XETbswzV&({Rx<2*_w49Qjm_jDcYx?!B({#eNF%nec}s|S zBQ>^IswXq4grlW$KqjdZT_eRgS%UF>#M4n3u>AS_vosB2))nXavQ!^OST2Em@T>t~ zk)f9`U|69cKC{FcBYMP)SLn=w8Zn#sO5^a*Z|?0kecC!|cJ>eaiSvbLJQ9g60WW{r z_FKn(i?+Y+cD^-QevRZrq<ML!%wwFTeqEPFs#Az?1v|F|wwR_1`|fD2&(jp^3W`eW z1$3pBe6qSHL?24}zG^+W3=1_wI^bkgn?-_36INe9pQTTeBgDEX@CO9-=0eA5r4R8B zqJQHRVaA#MWuTz7*YN4_!ESCUIp*^ma-+}HqXKDiuQi8R4)wfN&dZcC(W7)4hOVa~ gyM=ZIzlBld_WS8S|DgY7s%0=u+psO$v`e=2A1{jWlK=n! literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..79f7d35c2d366605952541e83e033ac4e3c2ed12 GIT binary patch literal 8453 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..96543ba0dd2556d600e52dad906deacdf767d334 GIT binary patch literal 3279 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 V{c!5}M+8T`9S~>;PL)j8{4ZxVg&6<< literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f74e20dc26d5990f387957dd03f14cee08d04d04 GIT binary patch literal 14984 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..cf333e24de5ce82e85cd92c64ee0dd1a0c1f7298 GIT binary patch literal 19912 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 F{vQY$eZl|$ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..33a2fec2cefae67401eee91d94cf22f46725c1f7 GIT binary patch literal 5598 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 LpSd|}%;5K5uM7i5 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py new file mode 100644 index 0000000..f3e0094 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py @@ -0,0 +1,30 @@ +""" +This module provides means to detect the App Engine environment. +""" + +import os + + +def is_appengine(): + return (is_local_appengine() or + is_prod_appengine() or + is_prod_appengine_mvms()) + + +def is_appengine_sandbox(): + return is_appengine() and not is_prod_appengine_mvms() + + +def is_local_appengine(): + return ('APPENGINE_RUNTIME' in os.environ and + 'Development/' in os.environ['SERVER_SOFTWARE']) + + +def is_prod_appengine(): + return ('APPENGINE_RUNTIME' in os.environ and + 'Google App Engine/' in os.environ['SERVER_SOFTWARE'] and + not is_prod_appengine_mvms()) + + +def is_prod_appengine_mvms(): + return os.environ.get('GAE_VM', False) == 'true' diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5cee168a48ac99dde197044cbf9d1605a636a7f0 GIT binary patch literal 229 zcmYk0F$%&k6oyl95W#~u)K?XRf`}(@QRk4_Xd^KRFKMtng12yV^E|E|L2z&~anT>X z@8|u~+w}WA67srTSnNmCf0A%40=5%Wk`);w%PYY+|MWhCLE)L>;2FYB%aWso`~-WN zdpx#kygOu7b!uBG^J!6G7P42c1|v)=lyywXG|Q&G@uND9U#RD*)Ce_7DT)bfwQ?v5 ipq6iI<PMp#Mxz5tg%Xa^p=s{j*-@9Z<n#FBGeADRXhBH; literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9e6e09d75da868bca95a29e13261da5dc520ab74 GIT binary patch literal 10384 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c9478824b2eaf08f9a6316564c9f21c93e0713d6 GIT binary patch literal 7581 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 B0E++s literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py new file mode 100644 index 0000000..be34215 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py @@ -0,0 +1,593 @@ +""" +This module uses ctypes to bind a whole bunch of functions and constants from +SecureTransport. The goal here is to provide the low-level API to +SecureTransport. These are essentially the C-level functions and constants, and +they're pretty gross to work with. + +This code is a bastardised version of the code found in Will Bond's oscrypto +library. An enormous debt is owed to him for blazing this trail for us. For +that reason, this code should be considered to be covered both by urllib3's +license and by oscrypto's: + + Copyright (c) 2015-2016 Will Bond <will@wbond.net> + + Permission is hereby granted, free of charge, to any person obtaining a + copy of this software and associated documentation files (the "Software"), + to deal in the Software without restriction, including without limitation + the rights to use, copy, modify, merge, publish, distribute, sublicense, + and/or sell copies of the Software, and to permit persons to whom the + Software is furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in + all copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + DEALINGS IN THE SOFTWARE. +""" +from __future__ import absolute_import + +import platform +from ctypes.util import find_library +from ctypes import ( + c_void_p, c_int32, c_char_p, c_size_t, c_byte, c_uint32, c_ulong, c_long, + c_bool +) +from ctypes import CDLL, POINTER, CFUNCTYPE + + +security_path = find_library('Security') +if not security_path: + raise ImportError('The library Security could not be found') + + +core_foundation_path = find_library('CoreFoundation') +if not core_foundation_path: + raise ImportError('The library CoreFoundation could not be found') + + +version = platform.mac_ver()[0] +version_info = tuple(map(int, version.split('.'))) +if version_info < (10, 8): + raise OSError( + 'Only OS X 10.8 and newer are supported, not %s.%s' % ( + version_info[0], version_info[1] + ) + ) + +Security = CDLL(security_path, use_errno=True) +CoreFoundation = CDLL(core_foundation_path, use_errno=True) + +Boolean = c_bool +CFIndex = c_long +CFStringEncoding = c_uint32 +CFData = c_void_p +CFString = c_void_p +CFArray = c_void_p +CFMutableArray = c_void_p +CFDictionary = c_void_p +CFError = c_void_p +CFType = c_void_p +CFTypeID = c_ulong + +CFTypeRef = POINTER(CFType) +CFAllocatorRef = c_void_p + +OSStatus = c_int32 + +CFDataRef = POINTER(CFData) +CFStringRef = POINTER(CFString) +CFArrayRef = POINTER(CFArray) +CFMutableArrayRef = POINTER(CFMutableArray) +CFDictionaryRef = POINTER(CFDictionary) +CFArrayCallBacks = c_void_p +CFDictionaryKeyCallBacks = c_void_p +CFDictionaryValueCallBacks = c_void_p + +SecCertificateRef = POINTER(c_void_p) +SecExternalFormat = c_uint32 +SecExternalItemType = c_uint32 +SecIdentityRef = POINTER(c_void_p) +SecItemImportExportFlags = c_uint32 +SecItemImportExportKeyParameters = c_void_p +SecKeychainRef = POINTER(c_void_p) +SSLProtocol = c_uint32 +SSLCipherSuite = c_uint32 +SSLContextRef = POINTER(c_void_p) +SecTrustRef = POINTER(c_void_p) +SSLConnectionRef = c_uint32 +SecTrustResultType = c_uint32 +SecTrustOptionFlags = c_uint32 +SSLProtocolSide = c_uint32 +SSLConnectionType = c_uint32 +SSLSessionOption = c_uint32 + + +try: + Security.SecItemImport.argtypes = [ + CFDataRef, + CFStringRef, + POINTER(SecExternalFormat), + POINTER(SecExternalItemType), + SecItemImportExportFlags, + POINTER(SecItemImportExportKeyParameters), + SecKeychainRef, + POINTER(CFArrayRef), + ] + Security.SecItemImport.restype = OSStatus + + Security.SecCertificateGetTypeID.argtypes = [] + Security.SecCertificateGetTypeID.restype = CFTypeID + + Security.SecIdentityGetTypeID.argtypes = [] + Security.SecIdentityGetTypeID.restype = CFTypeID + + Security.SecKeyGetTypeID.argtypes = [] + Security.SecKeyGetTypeID.restype = CFTypeID + + Security.SecCertificateCreateWithData.argtypes = [ + CFAllocatorRef, + CFDataRef + ] + Security.SecCertificateCreateWithData.restype = SecCertificateRef + + Security.SecCertificateCopyData.argtypes = [ + SecCertificateRef + ] + Security.SecCertificateCopyData.restype = CFDataRef + + Security.SecCopyErrorMessageString.argtypes = [ + OSStatus, + c_void_p + ] + Security.SecCopyErrorMessageString.restype = CFStringRef + + Security.SecIdentityCreateWithCertificate.argtypes = [ + CFTypeRef, + SecCertificateRef, + POINTER(SecIdentityRef) + ] + Security.SecIdentityCreateWithCertificate.restype = OSStatus + + Security.SecKeychainCreate.argtypes = [ + c_char_p, + c_uint32, + c_void_p, + Boolean, + c_void_p, + POINTER(SecKeychainRef) + ] + Security.SecKeychainCreate.restype = OSStatus + + Security.SecKeychainDelete.argtypes = [ + SecKeychainRef + ] + Security.SecKeychainDelete.restype = OSStatus + + Security.SecPKCS12Import.argtypes = [ + CFDataRef, + CFDictionaryRef, + POINTER(CFArrayRef) + ] + Security.SecPKCS12Import.restype = OSStatus + + SSLReadFunc = CFUNCTYPE(OSStatus, SSLConnectionRef, c_void_p, POINTER(c_size_t)) + SSLWriteFunc = CFUNCTYPE(OSStatus, SSLConnectionRef, POINTER(c_byte), POINTER(c_size_t)) + + Security.SSLSetIOFuncs.argtypes = [ + SSLContextRef, + SSLReadFunc, + SSLWriteFunc + ] + Security.SSLSetIOFuncs.restype = OSStatus + + Security.SSLSetPeerID.argtypes = [ + SSLContextRef, + c_char_p, + c_size_t + ] + Security.SSLSetPeerID.restype = OSStatus + + Security.SSLSetCertificate.argtypes = [ + SSLContextRef, + CFArrayRef + ] + Security.SSLSetCertificate.restype = OSStatus + + Security.SSLSetCertificateAuthorities.argtypes = [ + SSLContextRef, + CFTypeRef, + Boolean + ] + Security.SSLSetCertificateAuthorities.restype = OSStatus + + Security.SSLSetConnection.argtypes = [ + SSLContextRef, + SSLConnectionRef + ] + Security.SSLSetConnection.restype = OSStatus + + Security.SSLSetPeerDomainName.argtypes = [ + SSLContextRef, + c_char_p, + c_size_t + ] + Security.SSLSetPeerDomainName.restype = OSStatus + + Security.SSLHandshake.argtypes = [ + SSLContextRef + ] + Security.SSLHandshake.restype = OSStatus + + Security.SSLRead.argtypes = [ + SSLContextRef, + c_char_p, + c_size_t, + POINTER(c_size_t) + ] + Security.SSLRead.restype = OSStatus + + Security.SSLWrite.argtypes = [ + SSLContextRef, + c_char_p, + c_size_t, + POINTER(c_size_t) + ] + Security.SSLWrite.restype = OSStatus + + Security.SSLClose.argtypes = [ + SSLContextRef + ] + Security.SSLClose.restype = OSStatus + + Security.SSLGetNumberSupportedCiphers.argtypes = [ + SSLContextRef, + POINTER(c_size_t) + ] + Security.SSLGetNumberSupportedCiphers.restype = OSStatus + + Security.SSLGetSupportedCiphers.argtypes = [ + SSLContextRef, + POINTER(SSLCipherSuite), + POINTER(c_size_t) + ] + Security.SSLGetSupportedCiphers.restype = OSStatus + + Security.SSLSetEnabledCiphers.argtypes = [ + SSLContextRef, + POINTER(SSLCipherSuite), + c_size_t + ] + Security.SSLSetEnabledCiphers.restype = OSStatus + + Security.SSLGetNumberEnabledCiphers.argtype = [ + SSLContextRef, + POINTER(c_size_t) + ] + Security.SSLGetNumberEnabledCiphers.restype = OSStatus + + Security.SSLGetEnabledCiphers.argtypes = [ + SSLContextRef, + POINTER(SSLCipherSuite), + POINTER(c_size_t) + ] + Security.SSLGetEnabledCiphers.restype = OSStatus + + Security.SSLGetNegotiatedCipher.argtypes = [ + SSLContextRef, + POINTER(SSLCipherSuite) + ] + Security.SSLGetNegotiatedCipher.restype = OSStatus + + Security.SSLGetNegotiatedProtocolVersion.argtypes = [ + SSLContextRef, + POINTER(SSLProtocol) + ] + Security.SSLGetNegotiatedProtocolVersion.restype = OSStatus + + Security.SSLCopyPeerTrust.argtypes = [ + SSLContextRef, + POINTER(SecTrustRef) + ] + Security.SSLCopyPeerTrust.restype = OSStatus + + Security.SecTrustSetAnchorCertificates.argtypes = [ + SecTrustRef, + CFArrayRef + ] + Security.SecTrustSetAnchorCertificates.restype = OSStatus + + Security.SecTrustSetAnchorCertificatesOnly.argstypes = [ + SecTrustRef, + Boolean + ] + Security.SecTrustSetAnchorCertificatesOnly.restype = OSStatus + + Security.SecTrustEvaluate.argtypes = [ + SecTrustRef, + POINTER(SecTrustResultType) + ] + Security.SecTrustEvaluate.restype = OSStatus + + Security.SecTrustGetCertificateCount.argtypes = [ + SecTrustRef + ] + Security.SecTrustGetCertificateCount.restype = CFIndex + + Security.SecTrustGetCertificateAtIndex.argtypes = [ + SecTrustRef, + CFIndex + ] + Security.SecTrustGetCertificateAtIndex.restype = SecCertificateRef + + Security.SSLCreateContext.argtypes = [ + CFAllocatorRef, + SSLProtocolSide, + SSLConnectionType + ] + Security.SSLCreateContext.restype = SSLContextRef + + Security.SSLSetSessionOption.argtypes = [ + SSLContextRef, + SSLSessionOption, + Boolean + ] + Security.SSLSetSessionOption.restype = OSStatus + + Security.SSLSetProtocolVersionMin.argtypes = [ + SSLContextRef, + SSLProtocol + ] + Security.SSLSetProtocolVersionMin.restype = OSStatus + + Security.SSLSetProtocolVersionMax.argtypes = [ + SSLContextRef, + SSLProtocol + ] + Security.SSLSetProtocolVersionMax.restype = OSStatus + + Security.SecCopyErrorMessageString.argtypes = [ + OSStatus, + c_void_p + ] + Security.SecCopyErrorMessageString.restype = CFStringRef + + Security.SSLReadFunc = SSLReadFunc + Security.SSLWriteFunc = SSLWriteFunc + Security.SSLContextRef = SSLContextRef + Security.SSLProtocol = SSLProtocol + Security.SSLCipherSuite = SSLCipherSuite + Security.SecIdentityRef = SecIdentityRef + Security.SecKeychainRef = SecKeychainRef + Security.SecTrustRef = SecTrustRef + Security.SecTrustResultType = SecTrustResultType + Security.SecExternalFormat = SecExternalFormat + Security.OSStatus = OSStatus + + Security.kSecImportExportPassphrase = CFStringRef.in_dll( + Security, 'kSecImportExportPassphrase' + ) + Security.kSecImportItemIdentity = CFStringRef.in_dll( + Security, 'kSecImportItemIdentity' + ) + + # CoreFoundation time! + CoreFoundation.CFRetain.argtypes = [ + CFTypeRef + ] + CoreFoundation.CFRetain.restype = CFTypeRef + + CoreFoundation.CFRelease.argtypes = [ + CFTypeRef + ] + CoreFoundation.CFRelease.restype = None + + CoreFoundation.CFGetTypeID.argtypes = [ + CFTypeRef + ] + CoreFoundation.CFGetTypeID.restype = CFTypeID + + CoreFoundation.CFStringCreateWithCString.argtypes = [ + CFAllocatorRef, + c_char_p, + CFStringEncoding + ] + CoreFoundation.CFStringCreateWithCString.restype = CFStringRef + + CoreFoundation.CFStringGetCStringPtr.argtypes = [ + CFStringRef, + CFStringEncoding + ] + CoreFoundation.CFStringGetCStringPtr.restype = c_char_p + + CoreFoundation.CFStringGetCString.argtypes = [ + CFStringRef, + c_char_p, + CFIndex, + CFStringEncoding + ] + CoreFoundation.CFStringGetCString.restype = c_bool + + CoreFoundation.CFDataCreate.argtypes = [ + CFAllocatorRef, + c_char_p, + CFIndex + ] + CoreFoundation.CFDataCreate.restype = CFDataRef + + CoreFoundation.CFDataGetLength.argtypes = [ + CFDataRef + ] + CoreFoundation.CFDataGetLength.restype = CFIndex + + CoreFoundation.CFDataGetBytePtr.argtypes = [ + CFDataRef + ] + CoreFoundation.CFDataGetBytePtr.restype = c_void_p + + CoreFoundation.CFDictionaryCreate.argtypes = [ + CFAllocatorRef, + POINTER(CFTypeRef), + POINTER(CFTypeRef), + CFIndex, + CFDictionaryKeyCallBacks, + CFDictionaryValueCallBacks + ] + CoreFoundation.CFDictionaryCreate.restype = CFDictionaryRef + + CoreFoundation.CFDictionaryGetValue.argtypes = [ + CFDictionaryRef, + CFTypeRef + ] + CoreFoundation.CFDictionaryGetValue.restype = CFTypeRef + + CoreFoundation.CFArrayCreate.argtypes = [ + CFAllocatorRef, + POINTER(CFTypeRef), + CFIndex, + CFArrayCallBacks, + ] + CoreFoundation.CFArrayCreate.restype = CFArrayRef + + CoreFoundation.CFArrayCreateMutable.argtypes = [ + CFAllocatorRef, + CFIndex, + CFArrayCallBacks + ] + CoreFoundation.CFArrayCreateMutable.restype = CFMutableArrayRef + + CoreFoundation.CFArrayAppendValue.argtypes = [ + CFMutableArrayRef, + c_void_p + ] + CoreFoundation.CFArrayAppendValue.restype = None + + CoreFoundation.CFArrayGetCount.argtypes = [ + CFArrayRef + ] + CoreFoundation.CFArrayGetCount.restype = CFIndex + + CoreFoundation.CFArrayGetValueAtIndex.argtypes = [ + CFArrayRef, + CFIndex + ] + CoreFoundation.CFArrayGetValueAtIndex.restype = c_void_p + + CoreFoundation.kCFAllocatorDefault = CFAllocatorRef.in_dll( + CoreFoundation, 'kCFAllocatorDefault' + ) + CoreFoundation.kCFTypeArrayCallBacks = c_void_p.in_dll(CoreFoundation, 'kCFTypeArrayCallBacks') + CoreFoundation.kCFTypeDictionaryKeyCallBacks = c_void_p.in_dll( + CoreFoundation, 'kCFTypeDictionaryKeyCallBacks' + ) + CoreFoundation.kCFTypeDictionaryValueCallBacks = c_void_p.in_dll( + CoreFoundation, 'kCFTypeDictionaryValueCallBacks' + ) + + CoreFoundation.CFTypeRef = CFTypeRef + CoreFoundation.CFArrayRef = CFArrayRef + CoreFoundation.CFStringRef = CFStringRef + CoreFoundation.CFDictionaryRef = CFDictionaryRef + +except (AttributeError): + raise ImportError('Error initializing ctypes') + + +class CFConst(object): + """ + A class object that acts as essentially a namespace for CoreFoundation + constants. + """ + kCFStringEncodingUTF8 = CFStringEncoding(0x08000100) + + +class SecurityConst(object): + """ + A class object that acts as essentially a namespace for Security constants. + """ + kSSLSessionOptionBreakOnServerAuth = 0 + + kSSLProtocol2 = 1 + kSSLProtocol3 = 2 + kTLSProtocol1 = 4 + kTLSProtocol11 = 7 + kTLSProtocol12 = 8 + kTLSProtocol13 = 10 + kTLSProtocolMaxSupported = 999 + + kSSLClientSide = 1 + kSSLStreamType = 0 + + kSecFormatPEMSequence = 10 + + kSecTrustResultInvalid = 0 + kSecTrustResultProceed = 1 + # This gap is present on purpose: this was kSecTrustResultConfirm, which + # is deprecated. + kSecTrustResultDeny = 3 + kSecTrustResultUnspecified = 4 + kSecTrustResultRecoverableTrustFailure = 5 + kSecTrustResultFatalTrustFailure = 6 + kSecTrustResultOtherError = 7 + + errSSLProtocol = -9800 + errSSLWouldBlock = -9803 + errSSLClosedGraceful = -9805 + errSSLClosedNoNotify = -9816 + errSSLClosedAbort = -9806 + + errSSLXCertChainInvalid = -9807 + errSSLCrypto = -9809 + errSSLInternal = -9810 + errSSLCertExpired = -9814 + errSSLCertNotYetValid = -9815 + errSSLUnknownRootCert = -9812 + errSSLNoRootCert = -9813 + errSSLHostNameMismatch = -9843 + errSSLPeerHandshakeFail = -9824 + errSSLPeerUserCancelled = -9839 + errSSLWeakPeerEphemeralDHKey = -9850 + errSSLServerAuthCompleted = -9841 + errSSLRecordOverflow = -9847 + + errSecVerifyFailed = -67808 + errSecNoTrustSettings = -25263 + errSecItemNotFound = -25300 + errSecInvalidTrustSettings = -25262 + + # Cipher suites. We only pick the ones our default cipher string allows. + # Source: https://developer.apple.com/documentation/security/1550981-ssl_cipher_suite_values + TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384 = 0xC02C + TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 = 0xC030 + TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256 = 0xC02B + TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 = 0xC02F + TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305_SHA256 = 0xCCA9 + TLS_ECDHE_RSA_WITH_CHACHA20_POLY1305_SHA256 = 0xCCA8 + TLS_DHE_RSA_WITH_AES_256_GCM_SHA384 = 0x009F + TLS_DHE_RSA_WITH_AES_128_GCM_SHA256 = 0x009E + TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384 = 0xC024 + TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384 = 0xC028 + TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA = 0xC00A + TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA = 0xC014 + TLS_DHE_RSA_WITH_AES_256_CBC_SHA256 = 0x006B + TLS_DHE_RSA_WITH_AES_256_CBC_SHA = 0x0039 + TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256 = 0xC023 + TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256 = 0xC027 + TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA = 0xC009 + TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA = 0xC013 + TLS_DHE_RSA_WITH_AES_128_CBC_SHA256 = 0x0067 + TLS_DHE_RSA_WITH_AES_128_CBC_SHA = 0x0033 + TLS_RSA_WITH_AES_256_GCM_SHA384 = 0x009D + TLS_RSA_WITH_AES_128_GCM_SHA256 = 0x009C + TLS_RSA_WITH_AES_256_CBC_SHA256 = 0x003D + TLS_RSA_WITH_AES_128_CBC_SHA256 = 0x003C + TLS_RSA_WITH_AES_256_CBC_SHA = 0x0035 + TLS_RSA_WITH_AES_128_CBC_SHA = 0x002F + TLS_AES_128_GCM_SHA256 = 0x1301 + TLS_AES_256_GCM_SHA384 = 0x1302 + TLS_AES_128_CCM_8_SHA256 = 0x1305 + TLS_AES_128_CCM_SHA256 = 0x1304 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py new file mode 100644 index 0000000..b13cd9e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py @@ -0,0 +1,346 @@ +""" +Low-level helpers for the SecureTransport bindings. + +These are Python functions that are not directly related to the high-level APIs +but are necessary to get them to work. They include a whole bunch of low-level +CoreFoundation messing about and memory management. The concerns in this module +are almost entirely about trying to avoid memory leaks and providing +appropriate and useful assistance to the higher-level code. +""" +import base64 +import ctypes +import itertools +import re +import os +import ssl +import tempfile + +from .bindings import Security, CoreFoundation, CFConst + + +# This regular expression is used to grab PEM data out of a PEM bundle. +_PEM_CERTS_RE = re.compile( + b"-----BEGIN CERTIFICATE-----\n(.*?)\n-----END CERTIFICATE-----", re.DOTALL +) + + +def _cf_data_from_bytes(bytestring): + """ + Given a bytestring, create a CFData object from it. This CFData object must + be CFReleased by the caller. + """ + return CoreFoundation.CFDataCreate( + CoreFoundation.kCFAllocatorDefault, bytestring, len(bytestring) + ) + + +def _cf_dictionary_from_tuples(tuples): + """ + Given a list of Python tuples, create an associated CFDictionary. + """ + dictionary_size = len(tuples) + + # We need to get the dictionary keys and values out in the same order. + keys = (t[0] for t in tuples) + values = (t[1] for t in tuples) + cf_keys = (CoreFoundation.CFTypeRef * dictionary_size)(*keys) + cf_values = (CoreFoundation.CFTypeRef * dictionary_size)(*values) + + return CoreFoundation.CFDictionaryCreate( + CoreFoundation.kCFAllocatorDefault, + cf_keys, + cf_values, + dictionary_size, + CoreFoundation.kCFTypeDictionaryKeyCallBacks, + CoreFoundation.kCFTypeDictionaryValueCallBacks, + ) + + +def _cf_string_to_unicode(value): + """ + Creates a Unicode string from a CFString object. Used entirely for error + reporting. + + Yes, it annoys me quite a lot that this function is this complex. + """ + value_as_void_p = ctypes.cast(value, ctypes.POINTER(ctypes.c_void_p)) + + string = CoreFoundation.CFStringGetCStringPtr( + value_as_void_p, + CFConst.kCFStringEncodingUTF8 + ) + if string is None: + buffer = ctypes.create_string_buffer(1024) + result = CoreFoundation.CFStringGetCString( + value_as_void_p, + buffer, + 1024, + CFConst.kCFStringEncodingUTF8 + ) + if not result: + raise OSError('Error copying C string from CFStringRef') + string = buffer.value + if string is not None: + string = string.decode('utf-8') + return string + + +def _assert_no_error(error, exception_class=None): + """ + Checks the return code and throws an exception if there is an error to + report + """ + if error == 0: + return + + cf_error_string = Security.SecCopyErrorMessageString(error, None) + output = _cf_string_to_unicode(cf_error_string) + CoreFoundation.CFRelease(cf_error_string) + + if output is None or output == u'': + output = u'OSStatus %s' % error + + if exception_class is None: + exception_class = ssl.SSLError + + raise exception_class(output) + + +def _cert_array_from_pem(pem_bundle): + """ + Given a bundle of certs in PEM format, turns them into a CFArray of certs + that can be used to validate a cert chain. + """ + # Normalize the PEM bundle's line endings. + pem_bundle = pem_bundle.replace(b"\r\n", b"\n") + + der_certs = [ + base64.b64decode(match.group(1)) + for match in _PEM_CERTS_RE.finditer(pem_bundle) + ] + if not der_certs: + raise ssl.SSLError("No root certificates specified") + + cert_array = CoreFoundation.CFArrayCreateMutable( + CoreFoundation.kCFAllocatorDefault, + 0, + ctypes.byref(CoreFoundation.kCFTypeArrayCallBacks) + ) + if not cert_array: + raise ssl.SSLError("Unable to allocate memory!") + + try: + for der_bytes in der_certs: + certdata = _cf_data_from_bytes(der_bytes) + if not certdata: + raise ssl.SSLError("Unable to allocate memory!") + cert = Security.SecCertificateCreateWithData( + CoreFoundation.kCFAllocatorDefault, certdata + ) + CoreFoundation.CFRelease(certdata) + if not cert: + raise ssl.SSLError("Unable to build cert object!") + + CoreFoundation.CFArrayAppendValue(cert_array, cert) + CoreFoundation.CFRelease(cert) + except Exception: + # We need to free the array before the exception bubbles further. + # We only want to do that if an error occurs: otherwise, the caller + # should free. + CoreFoundation.CFRelease(cert_array) + + return cert_array + + +def _is_cert(item): + """ + Returns True if a given CFTypeRef is a certificate. + """ + expected = Security.SecCertificateGetTypeID() + return CoreFoundation.CFGetTypeID(item) == expected + + +def _is_identity(item): + """ + Returns True if a given CFTypeRef is an identity. + """ + expected = Security.SecIdentityGetTypeID() + return CoreFoundation.CFGetTypeID(item) == expected + + +def _temporary_keychain(): + """ + This function creates a temporary Mac keychain that we can use to work with + credentials. This keychain uses a one-time password and a temporary file to + store the data. We expect to have one keychain per socket. The returned + SecKeychainRef must be freed by the caller, including calling + SecKeychainDelete. + + Returns a tuple of the SecKeychainRef and the path to the temporary + directory that contains it. + """ + # Unfortunately, SecKeychainCreate requires a path to a keychain. This + # means we cannot use mkstemp to use a generic temporary file. Instead, + # we're going to create a temporary directory and a filename to use there. + # This filename will be 8 random bytes expanded into base64. We also need + # some random bytes to password-protect the keychain we're creating, so we + # ask for 40 random bytes. + random_bytes = os.urandom(40) + filename = base64.b16encode(random_bytes[:8]).decode('utf-8') + password = base64.b16encode(random_bytes[8:]) # Must be valid UTF-8 + tempdirectory = tempfile.mkdtemp() + + keychain_path = os.path.join(tempdirectory, filename).encode('utf-8') + + # We now want to create the keychain itself. + keychain = Security.SecKeychainRef() + status = Security.SecKeychainCreate( + keychain_path, + len(password), + password, + False, + None, + ctypes.byref(keychain) + ) + _assert_no_error(status) + + # Having created the keychain, we want to pass it off to the caller. + return keychain, tempdirectory + + +def _load_items_from_file(keychain, path): + """ + Given a single file, loads all the trust objects from it into arrays and + the keychain. + Returns a tuple of lists: the first list is a list of identities, the + second a list of certs. + """ + certificates = [] + identities = [] + result_array = None + + with open(path, 'rb') as f: + raw_filedata = f.read() + + try: + filedata = CoreFoundation.CFDataCreate( + CoreFoundation.kCFAllocatorDefault, + raw_filedata, + len(raw_filedata) + ) + result_array = CoreFoundation.CFArrayRef() + result = Security.SecItemImport( + filedata, # cert data + None, # Filename, leaving it out for now + None, # What the type of the file is, we don't care + None, # what's in the file, we don't care + 0, # import flags + None, # key params, can include passphrase in the future + keychain, # The keychain to insert into + ctypes.byref(result_array) # Results + ) + _assert_no_error(result) + + # A CFArray is not very useful to us as an intermediary + # representation, so we are going to extract the objects we want + # and then free the array. We don't need to keep hold of keys: the + # keychain already has them! + result_count = CoreFoundation.CFArrayGetCount(result_array) + for index in range(result_count): + item = CoreFoundation.CFArrayGetValueAtIndex( + result_array, index + ) + item = ctypes.cast(item, CoreFoundation.CFTypeRef) + + if _is_cert(item): + CoreFoundation.CFRetain(item) + certificates.append(item) + elif _is_identity(item): + CoreFoundation.CFRetain(item) + identities.append(item) + finally: + if result_array: + CoreFoundation.CFRelease(result_array) + + CoreFoundation.CFRelease(filedata) + + return (identities, certificates) + + +def _load_client_cert_chain(keychain, *paths): + """ + Load certificates and maybe keys from a number of files. Has the end goal + of returning a CFArray containing one SecIdentityRef, and then zero or more + SecCertificateRef objects, suitable for use as a client certificate trust + chain. + """ + # Ok, the strategy. + # + # This relies on knowing that macOS will not give you a SecIdentityRef + # unless you have imported a key into a keychain. This is a somewhat + # artificial limitation of macOS (for example, it doesn't necessarily + # affect iOS), but there is nothing inside Security.framework that lets you + # get a SecIdentityRef without having a key in a keychain. + # + # So the policy here is we take all the files and iterate them in order. + # Each one will use SecItemImport to have one or more objects loaded from + # it. We will also point at a keychain that macOS can use to work with the + # private key. + # + # Once we have all the objects, we'll check what we actually have. If we + # already have a SecIdentityRef in hand, fab: we'll use that. Otherwise, + # we'll take the first certificate (which we assume to be our leaf) and + # ask the keychain to give us a SecIdentityRef with that cert's associated + # key. + # + # We'll then return a CFArray containing the trust chain: one + # SecIdentityRef and then zero-or-more SecCertificateRef objects. The + # responsibility for freeing this CFArray will be with the caller. This + # CFArray must remain alive for the entire connection, so in practice it + # will be stored with a single SSLSocket, along with the reference to the + # keychain. + certificates = [] + identities = [] + + # Filter out bad paths. + paths = (path for path in paths if path) + + try: + for file_path in paths: + new_identities, new_certs = _load_items_from_file( + keychain, file_path + ) + identities.extend(new_identities) + certificates.extend(new_certs) + + # Ok, we have everything. The question is: do we have an identity? If + # not, we want to grab one from the first cert we have. + if not identities: + new_identity = Security.SecIdentityRef() + status = Security.SecIdentityCreateWithCertificate( + keychain, + certificates[0], + ctypes.byref(new_identity) + ) + _assert_no_error(status) + identities.append(new_identity) + + # We now want to release the original certificate, as we no longer + # need it. + CoreFoundation.CFRelease(certificates.pop(0)) + + # We now need to build a new CFArray that holds the trust chain. + trust_chain = CoreFoundation.CFArrayCreateMutable( + CoreFoundation.kCFAllocatorDefault, + 0, + ctypes.byref(CoreFoundation.kCFTypeArrayCallBacks), + ) + for item in itertools.chain(identities, certificates): + # ArrayAppendValue does a CFRetain on the item. That's fine, + # because the finally block will release our other refs to them. + CoreFoundation.CFArrayAppendValue(trust_chain, item) + + return trust_chain + finally: + for obj in itertools.chain(identities, certificates): + CoreFoundation.CFRelease(obj) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/appengine.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/appengine.py new file mode 100644 index 0000000..9b42952 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/appengine.py @@ -0,0 +1,289 @@ +""" +This module provides a pool manager that uses Google App Engine's +`URLFetch Service <https://cloud.google.com/appengine/docs/python/urlfetch>`_. + +Example usage:: + + from pip._vendor.urllib3 import PoolManager + from pip._vendor.urllib3.contrib.appengine import AppEngineManager, is_appengine_sandbox + + if is_appengine_sandbox(): + # AppEngineManager uses AppEngine's URLFetch API behind the scenes + http = AppEngineManager() + else: + # PoolManager uses a socket-level API behind the scenes + http = PoolManager() + + r = http.request('GET', 'https://google.com/') + +There are `limitations <https://cloud.google.com/appengine/docs/python/\ +urlfetch/#Python_Quotas_and_limits>`_ to the URLFetch service and it may not be +the best choice for your application. There are three options for using +urllib3 on Google App Engine: + +1. You can use :class:`AppEngineManager` with URLFetch. URLFetch is + cost-effective in many circumstances as long as your usage is within the + limitations. +2. You can use a normal :class:`~urllib3.PoolManager` by enabling sockets. + Sockets also have `limitations and restrictions + <https://cloud.google.com/appengine/docs/python/sockets/\ + #limitations-and-restrictions>`_ and have a lower free quota than URLFetch. + To use sockets, be sure to specify the following in your ``app.yaml``:: + + env_variables: + GAE_USE_SOCKETS_HTTPLIB : 'true' + +3. If you are using `App Engine Flexible +<https://cloud.google.com/appengine/docs/flexible/>`_, you can use the standard +:class:`PoolManager` without any configuration or special environment variables. +""" + +from __future__ import absolute_import +import io +import logging +import warnings +from ..packages.six.moves.urllib.parse import urljoin + +from ..exceptions import ( + HTTPError, + HTTPWarning, + MaxRetryError, + ProtocolError, + TimeoutError, + SSLError +) + +from ..request import RequestMethods +from ..response import HTTPResponse +from ..util.timeout import Timeout +from ..util.retry import Retry +from . import _appengine_environ + +try: + from google.appengine.api import urlfetch +except ImportError: + urlfetch = None + + +log = logging.getLogger(__name__) + + +class AppEnginePlatformWarning(HTTPWarning): + pass + + +class AppEnginePlatformError(HTTPError): + pass + + +class AppEngineManager(RequestMethods): + """ + Connection manager for Google App Engine sandbox applications. + + This manager uses the URLFetch service directly instead of using the + emulated httplib, and is subject to URLFetch limitations as described in + the App Engine documentation `here + <https://cloud.google.com/appengine/docs/python/urlfetch>`_. + + Notably it will raise an :class:`AppEnginePlatformError` if: + * URLFetch is not available. + * If you attempt to use this on App Engine Flexible, as full socket + support is available. + * If a request size is more than 10 megabytes. + * If a response size is more than 32 megabtyes. + * If you use an unsupported request method such as OPTIONS. + + Beyond those cases, it will raise normal urllib3 errors. + """ + + def __init__(self, headers=None, retries=None, validate_certificate=True, + urlfetch_retries=True): + if not urlfetch: + raise AppEnginePlatformError( + "URLFetch is not available in this environment.") + + if is_prod_appengine_mvms(): + raise AppEnginePlatformError( + "Use normal urllib3.PoolManager instead of AppEngineManager" + "on Managed VMs, as using URLFetch is not necessary in " + "this environment.") + + warnings.warn( + "urllib3 is using URLFetch on Google App Engine sandbox instead " + "of sockets. To use sockets directly instead of URLFetch see " + "https://urllib3.readthedocs.io/en/latest/reference/urllib3.contrib.html.", + AppEnginePlatformWarning) + + RequestMethods.__init__(self, headers) + self.validate_certificate = validate_certificate + self.urlfetch_retries = urlfetch_retries + + self.retries = retries or Retry.DEFAULT + + def __enter__(self): + return self + + def __exit__(self, exc_type, exc_val, exc_tb): + # Return False to re-raise any potential exceptions + return False + + def urlopen(self, method, url, body=None, headers=None, + retries=None, redirect=True, timeout=Timeout.DEFAULT_TIMEOUT, + **response_kw): + + retries = self._get_retries(retries, redirect) + + try: + follow_redirects = ( + redirect and + retries.redirect != 0 and + retries.total) + response = urlfetch.fetch( + url, + payload=body, + method=method, + headers=headers or {}, + allow_truncated=False, + follow_redirects=self.urlfetch_retries and follow_redirects, + deadline=self._get_absolute_timeout(timeout), + validate_certificate=self.validate_certificate, + ) + except urlfetch.DeadlineExceededError as e: + raise TimeoutError(self, e) + + except urlfetch.InvalidURLError as e: + if 'too large' in str(e): + raise AppEnginePlatformError( + "URLFetch request too large, URLFetch only " + "supports requests up to 10mb in size.", e) + raise ProtocolError(e) + + except urlfetch.DownloadError as e: + if 'Too many redirects' in str(e): + raise MaxRetryError(self, url, reason=e) + raise ProtocolError(e) + + except urlfetch.ResponseTooLargeError as e: + raise AppEnginePlatformError( + "URLFetch response too large, URLFetch only supports" + "responses up to 32mb in size.", e) + + except urlfetch.SSLCertificateError as e: + raise SSLError(e) + + except urlfetch.InvalidMethodError as e: + raise AppEnginePlatformError( + "URLFetch does not support method: %s" % method, e) + + http_response = self._urlfetch_response_to_http_response( + response, retries=retries, **response_kw) + + # Handle redirect? + redirect_location = redirect and http_response.get_redirect_location() + if redirect_location: + # Check for redirect response + if (self.urlfetch_retries and retries.raise_on_redirect): + raise MaxRetryError(self, url, "too many redirects") + else: + if http_response.status == 303: + method = 'GET' + + try: + retries = retries.increment(method, url, response=http_response, _pool=self) + except MaxRetryError: + if retries.raise_on_redirect: + raise MaxRetryError(self, url, "too many redirects") + return http_response + + retries.sleep_for_retry(http_response) + log.debug("Redirecting %s -> %s", url, redirect_location) + redirect_url = urljoin(url, redirect_location) + return self.urlopen( + method, redirect_url, body, headers, + retries=retries, redirect=redirect, + timeout=timeout, **response_kw) + + # Check if we should retry the HTTP response. + has_retry_after = bool(http_response.getheader('Retry-After')) + if retries.is_retry(method, http_response.status, has_retry_after): + retries = retries.increment( + method, url, response=http_response, _pool=self) + log.debug("Retry: %s", url) + retries.sleep(http_response) + return self.urlopen( + method, url, + body=body, headers=headers, + retries=retries, redirect=redirect, + timeout=timeout, **response_kw) + + return http_response + + def _urlfetch_response_to_http_response(self, urlfetch_resp, **response_kw): + + if is_prod_appengine(): + # Production GAE handles deflate encoding automatically, but does + # not remove the encoding header. + content_encoding = urlfetch_resp.headers.get('content-encoding') + + if content_encoding == 'deflate': + del urlfetch_resp.headers['content-encoding'] + + transfer_encoding = urlfetch_resp.headers.get('transfer-encoding') + # We have a full response's content, + # so let's make sure we don't report ourselves as chunked data. + if transfer_encoding == 'chunked': + encodings = transfer_encoding.split(",") + encodings.remove('chunked') + urlfetch_resp.headers['transfer-encoding'] = ','.join(encodings) + + original_response = HTTPResponse( + # In order for decoding to work, we must present the content as + # a file-like object. + body=io.BytesIO(urlfetch_resp.content), + msg=urlfetch_resp.header_msg, + headers=urlfetch_resp.headers, + status=urlfetch_resp.status_code, + **response_kw + ) + + return HTTPResponse( + body=io.BytesIO(urlfetch_resp.content), + headers=urlfetch_resp.headers, + status=urlfetch_resp.status_code, + original_response=original_response, + **response_kw + ) + + def _get_absolute_timeout(self, timeout): + if timeout is Timeout.DEFAULT_TIMEOUT: + return None # Defer to URLFetch's default. + if isinstance(timeout, Timeout): + if timeout._read is not None or timeout._connect is not None: + warnings.warn( + "URLFetch does not support granular timeout settings, " + "reverting to total or default URLFetch timeout.", + AppEnginePlatformWarning) + return timeout.total + return timeout + + def _get_retries(self, retries, redirect): + if not isinstance(retries, Retry): + retries = Retry.from_int( + retries, redirect=redirect, default=self.retries) + + if retries.connect or retries.read or retries.redirect: + warnings.warn( + "URLFetch only supports total retries and does not " + "recognize connect, read, or redirect retry parameters.", + AppEnginePlatformWarning) + + return retries + + +# Alias methods from _appengine_environ to maintain public API interface. + +is_appengine = _appengine_environ.is_appengine +is_appengine_sandbox = _appengine_environ.is_appengine_sandbox +is_local_appengine = _appengine_environ.is_local_appengine +is_prod_appengine = _appengine_environ.is_prod_appengine +is_prod_appengine_mvms = _appengine_environ.is_prod_appengine_mvms diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py new file mode 100644 index 0000000..8ea127c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py @@ -0,0 +1,111 @@ +""" +NTLM authenticating pool, contributed by erikcederstran + +Issue #10, see: http://code.google.com/p/urllib3/issues/detail?id=10 +""" +from __future__ import absolute_import + +from logging import getLogger +from ntlm import ntlm + +from .. import HTTPSConnectionPool +from ..packages.six.moves.http_client import HTTPSConnection + + +log = getLogger(__name__) + + +class NTLMConnectionPool(HTTPSConnectionPool): + """ + Implements an NTLM authentication version of an urllib3 connection pool + """ + + scheme = 'https' + + def __init__(self, user, pw, authurl, *args, **kwargs): + """ + authurl is a random URL on the server that is protected by NTLM. + user is the Windows user, probably in the DOMAIN\\username format. + pw is the password for the user. + """ + super(NTLMConnectionPool, self).__init__(*args, **kwargs) + self.authurl = authurl + self.rawuser = user + user_parts = user.split('\\', 1) + self.domain = user_parts[0].upper() + self.user = user_parts[1] + self.pw = pw + + def _new_conn(self): + # Performs the NTLM handshake that secures the connection. The socket + # must be kept open while requests are performed. + self.num_connections += 1 + log.debug('Starting NTLM HTTPS connection no. %d: https://%s%s', + self.num_connections, self.host, self.authurl) + + headers = {'Connection': 'Keep-Alive'} + req_header = 'Authorization' + resp_header = 'www-authenticate' + + conn = HTTPSConnection(host=self.host, port=self.port) + + # Send negotiation message + headers[req_header] = ( + 'NTLM %s' % ntlm.create_NTLM_NEGOTIATE_MESSAGE(self.rawuser)) + log.debug('Request headers: %s', headers) + conn.request('GET', self.authurl, None, headers) + res = conn.getresponse() + reshdr = dict(res.getheaders()) + log.debug('Response status: %s %s', res.status, res.reason) + log.debug('Response headers: %s', reshdr) + log.debug('Response data: %s [...]', res.read(100)) + + # Remove the reference to the socket, so that it can not be closed by + # the response object (we want to keep the socket open) + res.fp = None + + # Server should respond with a challenge message + auth_header_values = reshdr[resp_header].split(', ') + auth_header_value = None + for s in auth_header_values: + if s[:5] == 'NTLM ': + auth_header_value = s[5:] + if auth_header_value is None: + raise Exception('Unexpected %s response header: %s' % + (resp_header, reshdr[resp_header])) + + # Send authentication message + ServerChallenge, NegotiateFlags = \ + ntlm.parse_NTLM_CHALLENGE_MESSAGE(auth_header_value) + auth_msg = ntlm.create_NTLM_AUTHENTICATE_MESSAGE(ServerChallenge, + self.user, + self.domain, + self.pw, + NegotiateFlags) + headers[req_header] = 'NTLM %s' % auth_msg + log.debug('Request headers: %s', headers) + conn.request('GET', self.authurl, None, headers) + res = conn.getresponse() + log.debug('Response status: %s %s', res.status, res.reason) + log.debug('Response headers: %s', dict(res.getheaders())) + log.debug('Response data: %s [...]', res.read()[:100]) + if res.status != 200: + if res.status == 401: + raise Exception('Server rejected request: wrong ' + 'username or password') + raise Exception('Wrong server response: %s %s' % + (res.status, res.reason)) + + res.fp = None + log.debug('Connection established') + return conn + + def urlopen(self, method, url, body=None, headers=None, retries=3, + redirect=True, assert_same_host=True): + if headers is None: + headers = {} + headers['Connection'] = 'Keep-Alive' + return super(NTLMConnectionPool, self).urlopen(method, url, body, + headers, retries, + redirect, + assert_same_host) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py new file mode 100644 index 0000000..abfc319 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py @@ -0,0 +1,485 @@ +""" +SSL with SNI_-support for Python 2. Follow these instructions if you would +like to verify SSL certificates in Python 2. Note, the default libraries do +*not* do certificate checking; you need to do additional work to validate +certificates yourself. + +This needs the following packages installed: + +* pyOpenSSL (tested with 16.0.0) +* cryptography (minimum 1.3.4, from pyopenssl) +* idna (minimum 2.0, from cryptography) + +However, pyopenssl depends on cryptography, which depends on idna, so while we +use all three directly here we end up having relatively few packages required. + +You can install them with the following command: + + pip install pyopenssl cryptography idna + +To activate certificate checking, call +:func:`~urllib3.contrib.pyopenssl.inject_into_urllib3` from your Python code +before you begin making HTTP requests. This can be done in a ``sitecustomize`` +module, or at any other time before your application begins using ``urllib3``, +like this:: + + try: + import urllib3.contrib.pyopenssl + urllib3.contrib.pyopenssl.inject_into_urllib3() + except ImportError: + pass + +Now you can use :mod:`urllib3` as you normally would, and it will support SNI +when the required modules are installed. + +Activating this module also has the positive side effect of disabling SSL/TLS +compression in Python 2 (see `CRIME attack`_). + +If you want to configure the default list of supported cipher suites, you can +set the ``urllib3.contrib.pyopenssl.DEFAULT_SSL_CIPHER_LIST`` variable. + +.. _sni: https://en.wikipedia.org/wiki/Server_Name_Indication +.. _crime attack: https://en.wikipedia.org/wiki/CRIME_(security_exploit) +""" +from __future__ import absolute_import + +import OpenSSL.SSL +from cryptography import x509 +from cryptography.hazmat.backends.openssl import backend as openssl_backend +from cryptography.hazmat.backends.openssl.x509 import _Certificate +try: + from cryptography.x509 import UnsupportedExtension +except ImportError: + # UnsupportedExtension is gone in cryptography >= 2.1.0 + class UnsupportedExtension(Exception): + pass + +from socket import timeout, error as SocketError +from io import BytesIO + +try: # Platform-specific: Python 2 + from socket import _fileobject +except ImportError: # Platform-specific: Python 3 + _fileobject = None + from ..packages.backports.makefile import backport_makefile + +import logging +import ssl +from ..packages import six +import sys + +from .. import util + + +__all__ = ['inject_into_urllib3', 'extract_from_urllib3'] + +# SNI always works. +HAS_SNI = True + +# Map from urllib3 to PyOpenSSL compatible parameter-values. +_openssl_versions = { + util.PROTOCOL_TLS: OpenSSL.SSL.SSLv23_METHOD, + ssl.PROTOCOL_TLSv1: OpenSSL.SSL.TLSv1_METHOD, +} + +if hasattr(ssl, 'PROTOCOL_SSLv3') and hasattr(OpenSSL.SSL, 'SSLv3_METHOD'): + _openssl_versions[ssl.PROTOCOL_SSLv3] = OpenSSL.SSL.SSLv3_METHOD + +if hasattr(ssl, 'PROTOCOL_TLSv1_1') and hasattr(OpenSSL.SSL, 'TLSv1_1_METHOD'): + _openssl_versions[ssl.PROTOCOL_TLSv1_1] = OpenSSL.SSL.TLSv1_1_METHOD + +if hasattr(ssl, 'PROTOCOL_TLSv1_2') and hasattr(OpenSSL.SSL, 'TLSv1_2_METHOD'): + _openssl_versions[ssl.PROTOCOL_TLSv1_2] = OpenSSL.SSL.TLSv1_2_METHOD + + +_stdlib_to_openssl_verify = { + ssl.CERT_NONE: OpenSSL.SSL.VERIFY_NONE, + ssl.CERT_OPTIONAL: OpenSSL.SSL.VERIFY_PEER, + ssl.CERT_REQUIRED: + OpenSSL.SSL.VERIFY_PEER + OpenSSL.SSL.VERIFY_FAIL_IF_NO_PEER_CERT, +} +_openssl_to_stdlib_verify = dict( + (v, k) for k, v in _stdlib_to_openssl_verify.items() +) + +# OpenSSL will only write 16K at a time +SSL_WRITE_BLOCKSIZE = 16384 + +orig_util_HAS_SNI = util.HAS_SNI +orig_util_SSLContext = util.ssl_.SSLContext + + +log = logging.getLogger(__name__) + + +def inject_into_urllib3(): + 'Monkey-patch urllib3 with PyOpenSSL-backed SSL-support.' + + _validate_dependencies_met() + + util.SSLContext = PyOpenSSLContext + util.ssl_.SSLContext = PyOpenSSLContext + util.HAS_SNI = HAS_SNI + util.ssl_.HAS_SNI = HAS_SNI + util.IS_PYOPENSSL = True + util.ssl_.IS_PYOPENSSL = True + + +def extract_from_urllib3(): + 'Undo monkey-patching by :func:`inject_into_urllib3`.' + + util.SSLContext = orig_util_SSLContext + util.ssl_.SSLContext = orig_util_SSLContext + util.HAS_SNI = orig_util_HAS_SNI + util.ssl_.HAS_SNI = orig_util_HAS_SNI + util.IS_PYOPENSSL = False + util.ssl_.IS_PYOPENSSL = False + + +def _validate_dependencies_met(): + """ + Verifies that PyOpenSSL's package-level dependencies have been met. + Throws `ImportError` if they are not met. + """ + # Method added in `cryptography==1.1`; not available in older versions + from cryptography.x509.extensions import Extensions + if getattr(Extensions, "get_extension_for_class", None) is None: + raise ImportError("'cryptography' module missing required functionality. " + "Try upgrading to v1.3.4 or newer.") + + # pyOpenSSL 0.14 and above use cryptography for OpenSSL bindings. The _x509 + # attribute is only present on those versions. + from OpenSSL.crypto import X509 + x509 = X509() + if getattr(x509, "_x509", None) is None: + raise ImportError("'pyOpenSSL' module missing required functionality. " + "Try upgrading to v0.14 or newer.") + + +def _dnsname_to_stdlib(name): + """ + Converts a dNSName SubjectAlternativeName field to the form used by the + standard library on the given Python version. + + Cryptography produces a dNSName as a unicode string that was idna-decoded + from ASCII bytes. We need to idna-encode that string to get it back, and + then on Python 3 we also need to convert to unicode via UTF-8 (the stdlib + uses PyUnicode_FromStringAndSize on it, which decodes via UTF-8). + + If the name cannot be idna-encoded then we return None signalling that + the name given should be skipped. + """ + def idna_encode(name): + """ + Borrowed wholesale from the Python Cryptography Project. It turns out + that we can't just safely call `idna.encode`: it can explode for + wildcard names. This avoids that problem. + """ + from pip._vendor import idna + + try: + for prefix in [u'*.', u'.']: + if name.startswith(prefix): + name = name[len(prefix):] + return prefix.encode('ascii') + idna.encode(name) + return idna.encode(name) + except idna.core.IDNAError: + return None + + # Don't send IPv6 addresses through the IDNA encoder. + if ':' in name: + return name + + name = idna_encode(name) + if name is None: + return None + elif sys.version_info >= (3, 0): + name = name.decode('utf-8') + return name + + +def get_subj_alt_name(peer_cert): + """ + Given an PyOpenSSL certificate, provides all the subject alternative names. + """ + # Pass the cert to cryptography, which has much better APIs for this. + if hasattr(peer_cert, "to_cryptography"): + cert = peer_cert.to_cryptography() + else: + # This is technically using private APIs, but should work across all + # relevant versions before PyOpenSSL got a proper API for this. + cert = _Certificate(openssl_backend, peer_cert._x509) + + # We want to find the SAN extension. Ask Cryptography to locate it (it's + # faster than looping in Python) + try: + ext = cert.extensions.get_extension_for_class( + x509.SubjectAlternativeName + ).value + except x509.ExtensionNotFound: + # No such extension, return the empty list. + return [] + except (x509.DuplicateExtension, UnsupportedExtension, + x509.UnsupportedGeneralNameType, UnicodeError) as e: + # A problem has been found with the quality of the certificate. Assume + # no SAN field is present. + log.warning( + "A problem was encountered with the certificate that prevented " + "urllib3 from finding the SubjectAlternativeName field. This can " + "affect certificate validation. The error was %s", + e, + ) + return [] + + # We want to return dNSName and iPAddress fields. We need to cast the IPs + # back to strings because the match_hostname function wants them as + # strings. + # Sadly the DNS names need to be idna encoded and then, on Python 3, UTF-8 + # decoded. This is pretty frustrating, but that's what the standard library + # does with certificates, and so we need to attempt to do the same. + # We also want to skip over names which cannot be idna encoded. + names = [ + ('DNS', name) for name in map(_dnsname_to_stdlib, ext.get_values_for_type(x509.DNSName)) + if name is not None + ] + names.extend( + ('IP Address', str(name)) + for name in ext.get_values_for_type(x509.IPAddress) + ) + + return names + + +class WrappedSocket(object): + '''API-compatibility wrapper for Python OpenSSL's Connection-class. + + Note: _makefile_refs, _drop() and _reuse() are needed for the garbage + collector of pypy. + ''' + + def __init__(self, connection, socket, suppress_ragged_eofs=True): + self.connection = connection + self.socket = socket + self.suppress_ragged_eofs = suppress_ragged_eofs + self._makefile_refs = 0 + self._closed = False + + def fileno(self): + return self.socket.fileno() + + # Copy-pasted from Python 3.5 source code + def _decref_socketios(self): + if self._makefile_refs > 0: + self._makefile_refs -= 1 + if self._closed: + self.close() + + def recv(self, *args, **kwargs): + try: + data = self.connection.recv(*args, **kwargs) + except OpenSSL.SSL.SysCallError as e: + if self.suppress_ragged_eofs and e.args == (-1, 'Unexpected EOF'): + return b'' + else: + raise SocketError(str(e)) + except OpenSSL.SSL.ZeroReturnError: + if self.connection.get_shutdown() == OpenSSL.SSL.RECEIVED_SHUTDOWN: + return b'' + else: + raise + except OpenSSL.SSL.WantReadError: + if not util.wait_for_read(self.socket, self.socket.gettimeout()): + raise timeout('The read operation timed out') + else: + return self.recv(*args, **kwargs) + + # TLS 1.3 post-handshake authentication + except OpenSSL.SSL.Error as e: + raise ssl.SSLError("read error: %r" % e) + else: + return data + + def recv_into(self, *args, **kwargs): + try: + return self.connection.recv_into(*args, **kwargs) + except OpenSSL.SSL.SysCallError as e: + if self.suppress_ragged_eofs and e.args == (-1, 'Unexpected EOF'): + return 0 + else: + raise SocketError(str(e)) + except OpenSSL.SSL.ZeroReturnError: + if self.connection.get_shutdown() == OpenSSL.SSL.RECEIVED_SHUTDOWN: + return 0 + else: + raise + except OpenSSL.SSL.WantReadError: + if not util.wait_for_read(self.socket, self.socket.gettimeout()): + raise timeout('The read operation timed out') + else: + return self.recv_into(*args, **kwargs) + + # TLS 1.3 post-handshake authentication + except OpenSSL.SSL.Error as e: + raise ssl.SSLError("read error: %r" % e) + + def settimeout(self, timeout): + return self.socket.settimeout(timeout) + + def _send_until_done(self, data): + while True: + try: + return self.connection.send(data) + except OpenSSL.SSL.WantWriteError: + if not util.wait_for_write(self.socket, self.socket.gettimeout()): + raise timeout() + continue + except OpenSSL.SSL.SysCallError as e: + raise SocketError(str(e)) + + def sendall(self, data): + total_sent = 0 + while total_sent < len(data): + sent = self._send_until_done(data[total_sent:total_sent + SSL_WRITE_BLOCKSIZE]) + total_sent += sent + + def shutdown(self): + # FIXME rethrow compatible exceptions should we ever use this + self.connection.shutdown() + + def close(self): + if self._makefile_refs < 1: + try: + self._closed = True + return self.connection.close() + except OpenSSL.SSL.Error: + return + else: + self._makefile_refs -= 1 + + def getpeercert(self, binary_form=False): + x509 = self.connection.get_peer_certificate() + + if not x509: + return x509 + + if binary_form: + return OpenSSL.crypto.dump_certificate( + OpenSSL.crypto.FILETYPE_ASN1, + x509) + + return { + 'subject': ( + (('commonName', x509.get_subject().CN),), + ), + 'subjectAltName': get_subj_alt_name(x509) + } + + def version(self): + return self.connection.get_protocol_version_name() + + def _reuse(self): + self._makefile_refs += 1 + + def _drop(self): + if self._makefile_refs < 1: + self.close() + else: + self._makefile_refs -= 1 + + +if _fileobject: # Platform-specific: Python 2 + def makefile(self, mode, bufsize=-1): + self._makefile_refs += 1 + return _fileobject(self, mode, bufsize, close=True) +else: # Platform-specific: Python 3 + makefile = backport_makefile + +WrappedSocket.makefile = makefile + + +class PyOpenSSLContext(object): + """ + I am a wrapper class for the PyOpenSSL ``Context`` object. I am responsible + for translating the interface of the standard library ``SSLContext`` object + to calls into PyOpenSSL. + """ + def __init__(self, protocol): + self.protocol = _openssl_versions[protocol] + self._ctx = OpenSSL.SSL.Context(self.protocol) + self._options = 0 + self.check_hostname = False + + @property + def options(self): + return self._options + + @options.setter + def options(self, value): + self._options = value + self._ctx.set_options(value) + + @property + def verify_mode(self): + return _openssl_to_stdlib_verify[self._ctx.get_verify_mode()] + + @verify_mode.setter + def verify_mode(self, value): + self._ctx.set_verify( + _stdlib_to_openssl_verify[value], + _verify_callback + ) + + def set_default_verify_paths(self): + self._ctx.set_default_verify_paths() + + def set_ciphers(self, ciphers): + if isinstance(ciphers, six.text_type): + ciphers = ciphers.encode('utf-8') + self._ctx.set_cipher_list(ciphers) + + def load_verify_locations(self, cafile=None, capath=None, cadata=None): + if cafile is not None: + cafile = cafile.encode('utf-8') + if capath is not None: + capath = capath.encode('utf-8') + self._ctx.load_verify_locations(cafile, capath) + if cadata is not None: + self._ctx.load_verify_locations(BytesIO(cadata)) + + def load_cert_chain(self, certfile, keyfile=None, password=None): + self._ctx.use_certificate_chain_file(certfile) + if password is not None: + if not isinstance(password, six.binary_type): + password = password.encode('utf-8') + self._ctx.set_passwd_cb(lambda *_: password) + self._ctx.use_privatekey_file(keyfile or certfile) + + def wrap_socket(self, sock, server_side=False, + do_handshake_on_connect=True, suppress_ragged_eofs=True, + server_hostname=None): + cnx = OpenSSL.SSL.Connection(self._ctx, sock) + + if isinstance(server_hostname, six.text_type): # Platform-specific: Python 3 + server_hostname = server_hostname.encode('utf-8') + + if server_hostname is not None: + cnx.set_tlsext_host_name(server_hostname) + + cnx.set_connect_state() + + while True: + try: + cnx.do_handshake() + except OpenSSL.SSL.WantReadError: + if not util.wait_for_read(sock, sock.gettimeout()): + raise timeout('select timed out') + continue + except OpenSSL.SSL.Error as e: + raise ssl.SSLError('bad handshake: %r' % e) + break + + return WrappedSocket(cnx, sock) + + +def _verify_callback(cnx, x509, err_no, err_depth, return_code): + return err_no == 0 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/securetransport.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/securetransport.py new file mode 100644 index 0000000..4dc4848 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/securetransport.py @@ -0,0 +1,853 @@ +""" +SecureTranport support for urllib3 via ctypes. + +This makes platform-native TLS available to urllib3 users on macOS without the +use of a compiler. This is an important feature because the Python Package +Index is moving to become a TLSv1.2-or-higher server, and the default OpenSSL +that ships with macOS is not capable of doing TLSv1.2. The only way to resolve +this is to give macOS users an alternative solution to the problem, and that +solution is to use SecureTransport. + +We use ctypes here because this solution must not require a compiler. That's +because pip is not allowed to require a compiler either. + +This is not intended to be a seriously long-term solution to this problem. +The hope is that PEP 543 will eventually solve this issue for us, at which +point we can retire this contrib module. But in the short term, we need to +solve the impending tire fire that is Python on Mac without this kind of +contrib module. So...here we are. + +To use this module, simply import and inject it:: + + import urllib3.contrib.securetransport + urllib3.contrib.securetransport.inject_into_urllib3() + +Happy TLSing! + +This code is a bastardised version of the code found in Will Bond's oscrypto +library. An enormous debt is owed to him for blazing this trail for us. For +that reason, this code should be considered to be covered both by urllib3's +license and by oscrypto's: + + Copyright (c) 2015-2016 Will Bond <will@wbond.net> + + Permission is hereby granted, free of charge, to any person obtaining a + copy of this software and associated documentation files (the "Software"), + to deal in the Software without restriction, including without limitation + the rights to use, copy, modify, merge, publish, distribute, sublicense, + and/or sell copies of the Software, and to permit persons to whom the + Software is furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in + all copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + DEALINGS IN THE SOFTWARE. +""" +from __future__ import absolute_import + +import contextlib +import ctypes +import errno +import os.path +import shutil +import socket +import ssl +import threading +import weakref + +from .. import util +from ._securetransport.bindings import ( + Security, SecurityConst, CoreFoundation +) +from ._securetransport.low_level import ( + _assert_no_error, _cert_array_from_pem, _temporary_keychain, + _load_client_cert_chain +) + +try: # Platform-specific: Python 2 + from socket import _fileobject +except ImportError: # Platform-specific: Python 3 + _fileobject = None + from ..packages.backports.makefile import backport_makefile + +__all__ = ['inject_into_urllib3', 'extract_from_urllib3'] + +# SNI always works +HAS_SNI = True + +orig_util_HAS_SNI = util.HAS_SNI +orig_util_SSLContext = util.ssl_.SSLContext + +# This dictionary is used by the read callback to obtain a handle to the +# calling wrapped socket. This is a pretty silly approach, but for now it'll +# do. I feel like I should be able to smuggle a handle to the wrapped socket +# directly in the SSLConnectionRef, but for now this approach will work I +# guess. +# +# We need to lock around this structure for inserts, but we don't do it for +# reads/writes in the callbacks. The reasoning here goes as follows: +# +# 1. It is not possible to call into the callbacks before the dictionary is +# populated, so once in the callback the id must be in the dictionary. +# 2. The callbacks don't mutate the dictionary, they only read from it, and +# so cannot conflict with any of the insertions. +# +# This is good: if we had to lock in the callbacks we'd drastically slow down +# the performance of this code. +_connection_refs = weakref.WeakValueDictionary() +_connection_ref_lock = threading.Lock() + +# Limit writes to 16kB. This is OpenSSL's limit, but we'll cargo-cult it over +# for no better reason than we need *a* limit, and this one is right there. +SSL_WRITE_BLOCKSIZE = 16384 + +# This is our equivalent of util.ssl_.DEFAULT_CIPHERS, but expanded out to +# individual cipher suites. We need to do this because this is how +# SecureTransport wants them. +CIPHER_SUITES = [ + SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384, + SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256, + SecurityConst.TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384, + SecurityConst.TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256, + SecurityConst.TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305_SHA256, + SecurityConst.TLS_ECDHE_RSA_WITH_CHACHA20_POLY1305_SHA256, + SecurityConst.TLS_DHE_RSA_WITH_AES_256_GCM_SHA384, + SecurityConst.TLS_DHE_RSA_WITH_AES_128_GCM_SHA256, + SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384, + SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA, + SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256, + SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA, + SecurityConst.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384, + SecurityConst.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA, + SecurityConst.TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256, + SecurityConst.TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA, + SecurityConst.TLS_DHE_RSA_WITH_AES_256_CBC_SHA256, + SecurityConst.TLS_DHE_RSA_WITH_AES_256_CBC_SHA, + SecurityConst.TLS_DHE_RSA_WITH_AES_128_CBC_SHA256, + SecurityConst.TLS_DHE_RSA_WITH_AES_128_CBC_SHA, + SecurityConst.TLS_AES_256_GCM_SHA384, + SecurityConst.TLS_AES_128_GCM_SHA256, + SecurityConst.TLS_RSA_WITH_AES_256_GCM_SHA384, + SecurityConst.TLS_RSA_WITH_AES_128_GCM_SHA256, + SecurityConst.TLS_AES_128_CCM_8_SHA256, + SecurityConst.TLS_AES_128_CCM_SHA256, + SecurityConst.TLS_RSA_WITH_AES_256_CBC_SHA256, + SecurityConst.TLS_RSA_WITH_AES_128_CBC_SHA256, + SecurityConst.TLS_RSA_WITH_AES_256_CBC_SHA, + SecurityConst.TLS_RSA_WITH_AES_128_CBC_SHA, +] + +# Basically this is simple: for PROTOCOL_SSLv23 we turn it into a low of +# TLSv1 and a high of TLSv1.3. For everything else, we pin to that version. +# TLSv1 to 1.2 are supported on macOS 10.8+ and TLSv1.3 is macOS 10.13+ +_protocol_to_min_max = { + util.PROTOCOL_TLS: (SecurityConst.kTLSProtocol1, SecurityConst.kTLSProtocolMaxSupported), +} + +if hasattr(ssl, "PROTOCOL_SSLv2"): + _protocol_to_min_max[ssl.PROTOCOL_SSLv2] = ( + SecurityConst.kSSLProtocol2, SecurityConst.kSSLProtocol2 + ) +if hasattr(ssl, "PROTOCOL_SSLv3"): + _protocol_to_min_max[ssl.PROTOCOL_SSLv3] = ( + SecurityConst.kSSLProtocol3, SecurityConst.kSSLProtocol3 + ) +if hasattr(ssl, "PROTOCOL_TLSv1"): + _protocol_to_min_max[ssl.PROTOCOL_TLSv1] = ( + SecurityConst.kTLSProtocol1, SecurityConst.kTLSProtocol1 + ) +if hasattr(ssl, "PROTOCOL_TLSv1_1"): + _protocol_to_min_max[ssl.PROTOCOL_TLSv1_1] = ( + SecurityConst.kTLSProtocol11, SecurityConst.kTLSProtocol11 + ) +if hasattr(ssl, "PROTOCOL_TLSv1_2"): + _protocol_to_min_max[ssl.PROTOCOL_TLSv1_2] = ( + SecurityConst.kTLSProtocol12, SecurityConst.kTLSProtocol12 + ) + + +def inject_into_urllib3(): + """ + Monkey-patch urllib3 with SecureTransport-backed SSL-support. + """ + util.SSLContext = SecureTransportContext + util.ssl_.SSLContext = SecureTransportContext + util.HAS_SNI = HAS_SNI + util.ssl_.HAS_SNI = HAS_SNI + util.IS_SECURETRANSPORT = True + util.ssl_.IS_SECURETRANSPORT = True + + +def extract_from_urllib3(): + """ + Undo monkey-patching by :func:`inject_into_urllib3`. + """ + util.SSLContext = orig_util_SSLContext + util.ssl_.SSLContext = orig_util_SSLContext + util.HAS_SNI = orig_util_HAS_SNI + util.ssl_.HAS_SNI = orig_util_HAS_SNI + util.IS_SECURETRANSPORT = False + util.ssl_.IS_SECURETRANSPORT = False + + +def _read_callback(connection_id, data_buffer, data_length_pointer): + """ + SecureTransport read callback. This is called by ST to request that data + be returned from the socket. + """ + wrapped_socket = None + try: + wrapped_socket = _connection_refs.get(connection_id) + if wrapped_socket is None: + return SecurityConst.errSSLInternal + base_socket = wrapped_socket.socket + + requested_length = data_length_pointer[0] + + timeout = wrapped_socket.gettimeout() + error = None + read_count = 0 + + try: + while read_count < requested_length: + if timeout is None or timeout >= 0: + if not util.wait_for_read(base_socket, timeout): + raise socket.error(errno.EAGAIN, 'timed out') + + remaining = requested_length - read_count + buffer = (ctypes.c_char * remaining).from_address( + data_buffer + read_count + ) + chunk_size = base_socket.recv_into(buffer, remaining) + read_count += chunk_size + if not chunk_size: + if not read_count: + return SecurityConst.errSSLClosedGraceful + break + except (socket.error) as e: + error = e.errno + + if error is not None and error != errno.EAGAIN: + data_length_pointer[0] = read_count + if error == errno.ECONNRESET or error == errno.EPIPE: + return SecurityConst.errSSLClosedAbort + raise + + data_length_pointer[0] = read_count + + if read_count != requested_length: + return SecurityConst.errSSLWouldBlock + + return 0 + except Exception as e: + if wrapped_socket is not None: + wrapped_socket._exception = e + return SecurityConst.errSSLInternal + + +def _write_callback(connection_id, data_buffer, data_length_pointer): + """ + SecureTransport write callback. This is called by ST to request that data + actually be sent on the network. + """ + wrapped_socket = None + try: + wrapped_socket = _connection_refs.get(connection_id) + if wrapped_socket is None: + return SecurityConst.errSSLInternal + base_socket = wrapped_socket.socket + + bytes_to_write = data_length_pointer[0] + data = ctypes.string_at(data_buffer, bytes_to_write) + + timeout = wrapped_socket.gettimeout() + error = None + sent = 0 + + try: + while sent < bytes_to_write: + if timeout is None or timeout >= 0: + if not util.wait_for_write(base_socket, timeout): + raise socket.error(errno.EAGAIN, 'timed out') + chunk_sent = base_socket.send(data) + sent += chunk_sent + + # This has some needless copying here, but I'm not sure there's + # much value in optimising this data path. + data = data[chunk_sent:] + except (socket.error) as e: + error = e.errno + + if error is not None and error != errno.EAGAIN: + data_length_pointer[0] = sent + if error == errno.ECONNRESET or error == errno.EPIPE: + return SecurityConst.errSSLClosedAbort + raise + + data_length_pointer[0] = sent + + if sent != bytes_to_write: + return SecurityConst.errSSLWouldBlock + + return 0 + except Exception as e: + if wrapped_socket is not None: + wrapped_socket._exception = e + return SecurityConst.errSSLInternal + + +# We need to keep these two objects references alive: if they get GC'd while +# in use then SecureTransport could attempt to call a function that is in freed +# memory. That would be...uh...bad. Yeah, that's the word. Bad. +_read_callback_pointer = Security.SSLReadFunc(_read_callback) +_write_callback_pointer = Security.SSLWriteFunc(_write_callback) + + +class WrappedSocket(object): + """ + API-compatibility wrapper for Python's OpenSSL wrapped socket object. + + Note: _makefile_refs, _drop(), and _reuse() are needed for the garbage + collector of PyPy. + """ + def __init__(self, socket): + self.socket = socket + self.context = None + self._makefile_refs = 0 + self._closed = False + self._exception = None + self._keychain = None + self._keychain_dir = None + self._client_cert_chain = None + + # We save off the previously-configured timeout and then set it to + # zero. This is done because we use select and friends to handle the + # timeouts, but if we leave the timeout set on the lower socket then + # Python will "kindly" call select on that socket again for us. Avoid + # that by forcing the timeout to zero. + self._timeout = self.socket.gettimeout() + self.socket.settimeout(0) + + @contextlib.contextmanager + def _raise_on_error(self): + """ + A context manager that can be used to wrap calls that do I/O from + SecureTransport. If any of the I/O callbacks hit an exception, this + context manager will correctly propagate the exception after the fact. + This avoids silently swallowing those exceptions. + + It also correctly forces the socket closed. + """ + self._exception = None + + # We explicitly don't catch around this yield because in the unlikely + # event that an exception was hit in the block we don't want to swallow + # it. + yield + if self._exception is not None: + exception, self._exception = self._exception, None + self.close() + raise exception + + def _set_ciphers(self): + """ + Sets up the allowed ciphers. By default this matches the set in + util.ssl_.DEFAULT_CIPHERS, at least as supported by macOS. This is done + custom and doesn't allow changing at this time, mostly because parsing + OpenSSL cipher strings is going to be a freaking nightmare. + """ + ciphers = (Security.SSLCipherSuite * len(CIPHER_SUITES))(*CIPHER_SUITES) + result = Security.SSLSetEnabledCiphers( + self.context, ciphers, len(CIPHER_SUITES) + ) + _assert_no_error(result) + + def _custom_validate(self, verify, trust_bundle): + """ + Called when we have set custom validation. We do this in two cases: + first, when cert validation is entirely disabled; and second, when + using a custom trust DB. + """ + # If we disabled cert validation, just say: cool. + if not verify: + return + + # We want data in memory, so load it up. + if os.path.isfile(trust_bundle): + with open(trust_bundle, 'rb') as f: + trust_bundle = f.read() + + cert_array = None + trust = Security.SecTrustRef() + + try: + # Get a CFArray that contains the certs we want. + cert_array = _cert_array_from_pem(trust_bundle) + + # Ok, now the hard part. We want to get the SecTrustRef that ST has + # created for this connection, shove our CAs into it, tell ST to + # ignore everything else it knows, and then ask if it can build a + # chain. This is a buuuunch of code. + result = Security.SSLCopyPeerTrust( + self.context, ctypes.byref(trust) + ) + _assert_no_error(result) + if not trust: + raise ssl.SSLError("Failed to copy trust reference") + + result = Security.SecTrustSetAnchorCertificates(trust, cert_array) + _assert_no_error(result) + + result = Security.SecTrustSetAnchorCertificatesOnly(trust, True) + _assert_no_error(result) + + trust_result = Security.SecTrustResultType() + result = Security.SecTrustEvaluate( + trust, ctypes.byref(trust_result) + ) + _assert_no_error(result) + finally: + if trust: + CoreFoundation.CFRelease(trust) + + if cert_array is not None: + CoreFoundation.CFRelease(cert_array) + + # Ok, now we can look at what the result was. + successes = ( + SecurityConst.kSecTrustResultUnspecified, + SecurityConst.kSecTrustResultProceed + ) + if trust_result.value not in successes: + raise ssl.SSLError( + "certificate verify failed, error code: %d" % + trust_result.value + ) + + def handshake(self, + server_hostname, + verify, + trust_bundle, + min_version, + max_version, + client_cert, + client_key, + client_key_passphrase): + """ + Actually performs the TLS handshake. This is run automatically by + wrapped socket, and shouldn't be needed in user code. + """ + # First, we do the initial bits of connection setup. We need to create + # a context, set its I/O funcs, and set the connection reference. + self.context = Security.SSLCreateContext( + None, SecurityConst.kSSLClientSide, SecurityConst.kSSLStreamType + ) + result = Security.SSLSetIOFuncs( + self.context, _read_callback_pointer, _write_callback_pointer + ) + _assert_no_error(result) + + # Here we need to compute the handle to use. We do this by taking the + # id of self modulo 2**31 - 1. If this is already in the dictionary, we + # just keep incrementing by one until we find a free space. + with _connection_ref_lock: + handle = id(self) % 2147483647 + while handle in _connection_refs: + handle = (handle + 1) % 2147483647 + _connection_refs[handle] = self + + result = Security.SSLSetConnection(self.context, handle) + _assert_no_error(result) + + # If we have a server hostname, we should set that too. + if server_hostname: + if not isinstance(server_hostname, bytes): + server_hostname = server_hostname.encode('utf-8') + + result = Security.SSLSetPeerDomainName( + self.context, server_hostname, len(server_hostname) + ) + _assert_no_error(result) + + # Setup the ciphers. + self._set_ciphers() + + # Set the minimum and maximum TLS versions. + result = Security.SSLSetProtocolVersionMin(self.context, min_version) + _assert_no_error(result) + + # TLS 1.3 isn't necessarily enabled by the OS + # so we have to detect when we error out and try + # setting TLS 1.3 if it's allowed. kTLSProtocolMaxSupported + # was added in macOS 10.13 along with kTLSProtocol13. + result = Security.SSLSetProtocolVersionMax(self.context, max_version) + if result != 0 and max_version == SecurityConst.kTLSProtocolMaxSupported: + result = Security.SSLSetProtocolVersionMax(self.context, SecurityConst.kTLSProtocol12) + _assert_no_error(result) + + # If there's a trust DB, we need to use it. We do that by telling + # SecureTransport to break on server auth. We also do that if we don't + # want to validate the certs at all: we just won't actually do any + # authing in that case. + if not verify or trust_bundle is not None: + result = Security.SSLSetSessionOption( + self.context, + SecurityConst.kSSLSessionOptionBreakOnServerAuth, + True + ) + _assert_no_error(result) + + # If there's a client cert, we need to use it. + if client_cert: + self._keychain, self._keychain_dir = _temporary_keychain() + self._client_cert_chain = _load_client_cert_chain( + self._keychain, client_cert, client_key + ) + result = Security.SSLSetCertificate( + self.context, self._client_cert_chain + ) + _assert_no_error(result) + + while True: + with self._raise_on_error(): + result = Security.SSLHandshake(self.context) + + if result == SecurityConst.errSSLWouldBlock: + raise socket.timeout("handshake timed out") + elif result == SecurityConst.errSSLServerAuthCompleted: + self._custom_validate(verify, trust_bundle) + continue + else: + _assert_no_error(result) + break + + def fileno(self): + return self.socket.fileno() + + # Copy-pasted from Python 3.5 source code + def _decref_socketios(self): + if self._makefile_refs > 0: + self._makefile_refs -= 1 + if self._closed: + self.close() + + def recv(self, bufsiz): + buffer = ctypes.create_string_buffer(bufsiz) + bytes_read = self.recv_into(buffer, bufsiz) + data = buffer[:bytes_read] + return data + + def recv_into(self, buffer, nbytes=None): + # Read short on EOF. + if self._closed: + return 0 + + if nbytes is None: + nbytes = len(buffer) + + buffer = (ctypes.c_char * nbytes).from_buffer(buffer) + processed_bytes = ctypes.c_size_t(0) + + with self._raise_on_error(): + result = Security.SSLRead( + self.context, buffer, nbytes, ctypes.byref(processed_bytes) + ) + + # There are some result codes that we want to treat as "not always + # errors". Specifically, those are errSSLWouldBlock, + # errSSLClosedGraceful, and errSSLClosedNoNotify. + if (result == SecurityConst.errSSLWouldBlock): + # If we didn't process any bytes, then this was just a time out. + # However, we can get errSSLWouldBlock in situations when we *did* + # read some data, and in those cases we should just read "short" + # and return. + if processed_bytes.value == 0: + # Timed out, no data read. + raise socket.timeout("recv timed out") + elif result in (SecurityConst.errSSLClosedGraceful, SecurityConst.errSSLClosedNoNotify): + # The remote peer has closed this connection. We should do so as + # well. Note that we don't actually return here because in + # principle this could actually be fired along with return data. + # It's unlikely though. + self.close() + else: + _assert_no_error(result) + + # Ok, we read and probably succeeded. We should return whatever data + # was actually read. + return processed_bytes.value + + def settimeout(self, timeout): + self._timeout = timeout + + def gettimeout(self): + return self._timeout + + def send(self, data): + processed_bytes = ctypes.c_size_t(0) + + with self._raise_on_error(): + result = Security.SSLWrite( + self.context, data, len(data), ctypes.byref(processed_bytes) + ) + + if result == SecurityConst.errSSLWouldBlock and processed_bytes.value == 0: + # Timed out + raise socket.timeout("send timed out") + else: + _assert_no_error(result) + + # We sent, and probably succeeded. Tell them how much we sent. + return processed_bytes.value + + def sendall(self, data): + total_sent = 0 + while total_sent < len(data): + sent = self.send(data[total_sent:total_sent + SSL_WRITE_BLOCKSIZE]) + total_sent += sent + + def shutdown(self): + with self._raise_on_error(): + Security.SSLClose(self.context) + + def close(self): + # TODO: should I do clean shutdown here? Do I have to? + if self._makefile_refs < 1: + self._closed = True + if self.context: + CoreFoundation.CFRelease(self.context) + self.context = None + if self._client_cert_chain: + CoreFoundation.CFRelease(self._client_cert_chain) + self._client_cert_chain = None + if self._keychain: + Security.SecKeychainDelete(self._keychain) + CoreFoundation.CFRelease(self._keychain) + shutil.rmtree(self._keychain_dir) + self._keychain = self._keychain_dir = None + return self.socket.close() + else: + self._makefile_refs -= 1 + + def getpeercert(self, binary_form=False): + # Urgh, annoying. + # + # Here's how we do this: + # + # 1. Call SSLCopyPeerTrust to get hold of the trust object for this + # connection. + # 2. Call SecTrustGetCertificateAtIndex for index 0 to get the leaf. + # 3. To get the CN, call SecCertificateCopyCommonName and process that + # string so that it's of the appropriate type. + # 4. To get the SAN, we need to do something a bit more complex: + # a. Call SecCertificateCopyValues to get the data, requesting + # kSecOIDSubjectAltName. + # b. Mess about with this dictionary to try to get the SANs out. + # + # This is gross. Really gross. It's going to be a few hundred LoC extra + # just to repeat something that SecureTransport can *already do*. So my + # operating assumption at this time is that what we want to do is + # instead to just flag to urllib3 that it shouldn't do its own hostname + # validation when using SecureTransport. + if not binary_form: + raise ValueError( + "SecureTransport only supports dumping binary certs" + ) + trust = Security.SecTrustRef() + certdata = None + der_bytes = None + + try: + # Grab the trust store. + result = Security.SSLCopyPeerTrust( + self.context, ctypes.byref(trust) + ) + _assert_no_error(result) + if not trust: + # Probably we haven't done the handshake yet. No biggie. + return None + + cert_count = Security.SecTrustGetCertificateCount(trust) + if not cert_count: + # Also a case that might happen if we haven't handshaked. + # Handshook? Handshaken? + return None + + leaf = Security.SecTrustGetCertificateAtIndex(trust, 0) + assert leaf + + # Ok, now we want the DER bytes. + certdata = Security.SecCertificateCopyData(leaf) + assert certdata + + data_length = CoreFoundation.CFDataGetLength(certdata) + data_buffer = CoreFoundation.CFDataGetBytePtr(certdata) + der_bytes = ctypes.string_at(data_buffer, data_length) + finally: + if certdata: + CoreFoundation.CFRelease(certdata) + if trust: + CoreFoundation.CFRelease(trust) + + return der_bytes + + def version(self): + protocol = Security.SSLProtocol() + result = Security.SSLGetNegotiatedProtocolVersion(self.context, ctypes.byref(protocol)) + _assert_no_error(result) + if protocol.value == SecurityConst.kTLSProtocol13: + return 'TLSv1.3' + elif protocol.value == SecurityConst.kTLSProtocol12: + return 'TLSv1.2' + elif protocol.value == SecurityConst.kTLSProtocol11: + return 'TLSv1.1' + elif protocol.value == SecurityConst.kTLSProtocol1: + return 'TLSv1' + elif protocol.value == SecurityConst.kSSLProtocol3: + return 'SSLv3' + elif protocol.value == SecurityConst.kSSLProtocol2: + return 'SSLv2' + else: + raise ssl.SSLError('Unknown TLS version: %r' % protocol) + + def _reuse(self): + self._makefile_refs += 1 + + def _drop(self): + if self._makefile_refs < 1: + self.close() + else: + self._makefile_refs -= 1 + + +if _fileobject: # Platform-specific: Python 2 + def makefile(self, mode, bufsize=-1): + self._makefile_refs += 1 + return _fileobject(self, mode, bufsize, close=True) +else: # Platform-specific: Python 3 + def makefile(self, mode="r", buffering=None, *args, **kwargs): + # We disable buffering with SecureTransport because it conflicts with + # the buffering that ST does internally (see issue #1153 for more). + buffering = 0 + return backport_makefile(self, mode, buffering, *args, **kwargs) + +WrappedSocket.makefile = makefile + + +class SecureTransportContext(object): + """ + I am a wrapper class for the SecureTransport library, to translate the + interface of the standard library ``SSLContext`` object to calls into + SecureTransport. + """ + def __init__(self, protocol): + self._min_version, self._max_version = _protocol_to_min_max[protocol] + self._options = 0 + self._verify = False + self._trust_bundle = None + self._client_cert = None + self._client_key = None + self._client_key_passphrase = None + + @property + def check_hostname(self): + """ + SecureTransport cannot have its hostname checking disabled. For more, + see the comment on getpeercert() in this file. + """ + return True + + @check_hostname.setter + def check_hostname(self, value): + """ + SecureTransport cannot have its hostname checking disabled. For more, + see the comment on getpeercert() in this file. + """ + pass + + @property + def options(self): + # TODO: Well, crap. + # + # So this is the bit of the code that is the most likely to cause us + # trouble. Essentially we need to enumerate all of the SSL options that + # users might want to use and try to see if we can sensibly translate + # them, or whether we should just ignore them. + return self._options + + @options.setter + def options(self, value): + # TODO: Update in line with above. + self._options = value + + @property + def verify_mode(self): + return ssl.CERT_REQUIRED if self._verify else ssl.CERT_NONE + + @verify_mode.setter + def verify_mode(self, value): + self._verify = True if value == ssl.CERT_REQUIRED else False + + def set_default_verify_paths(self): + # So, this has to do something a bit weird. Specifically, what it does + # is nothing. + # + # This means that, if we had previously had load_verify_locations + # called, this does not undo that. We need to do that because it turns + # out that the rest of the urllib3 code will attempt to load the + # default verify paths if it hasn't been told about any paths, even if + # the context itself was sometime earlier. We resolve that by just + # ignoring it. + pass + + def load_default_certs(self): + return self.set_default_verify_paths() + + def set_ciphers(self, ciphers): + # For now, we just require the default cipher string. + if ciphers != util.ssl_.DEFAULT_CIPHERS: + raise ValueError( + "SecureTransport doesn't support custom cipher strings" + ) + + def load_verify_locations(self, cafile=None, capath=None, cadata=None): + # OK, we only really support cadata and cafile. + if capath is not None: + raise ValueError( + "SecureTransport does not support cert directories" + ) + + self._trust_bundle = cafile or cadata + + def load_cert_chain(self, certfile, keyfile=None, password=None): + self._client_cert = certfile + self._client_key = keyfile + self._client_cert_passphrase = password + + def wrap_socket(self, sock, server_side=False, + do_handshake_on_connect=True, suppress_ragged_eofs=True, + server_hostname=None): + # So, what do we do here? Firstly, we assert some properties. This is a + # stripped down shim, so there is some functionality we don't support. + # See PEP 543 for the real deal. + assert not server_side + assert do_handshake_on_connect + assert suppress_ragged_eofs + + # Ok, we're good to go. Now we want to create the wrapped socket object + # and store it in the appropriate place. + wrapped_socket = WrappedSocket(sock) + + # Now we can handshake + wrapped_socket.handshake( + server_hostname, self._verify, self._trust_bundle, + self._min_version, self._max_version, self._client_cert, + self._client_key, self._client_key_passphrase + ) + return wrapped_socket diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/socks.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/socks.py new file mode 100644 index 0000000..636d261 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/contrib/socks.py @@ -0,0 +1,205 @@ +# -*- coding: utf-8 -*- +""" +This module contains provisional support for SOCKS proxies from within +urllib3. This module supports SOCKS4, SOCKS4A (an extension of SOCKS4), and +SOCKS5. To enable its functionality, either install PySocks or install this +module with the ``socks`` extra. + +The SOCKS implementation supports the full range of urllib3 features. It also +supports the following SOCKS features: + +- SOCKS4A (``proxy_url='socks4a://...``) +- SOCKS4 (``proxy_url='socks4://...``) +- SOCKS5 with remote DNS (``proxy_url='socks5h://...``) +- SOCKS5 with local DNS (``proxy_url='socks5://...``) +- Usernames and passwords for the SOCKS proxy + + .. note:: + It is recommended to use ``socks5h://`` or ``socks4a://`` schemes in + your ``proxy_url`` to ensure that DNS resolution is done from the remote + server instead of client-side when connecting to a domain name. + +SOCKS4 supports IPv4 and domain names with the SOCKS4A extension. SOCKS5 +supports IPv4, IPv6, and domain names. + +When connecting to a SOCKS4 proxy the ``username`` portion of the ``proxy_url`` +will be sent as the ``userid`` section of the SOCKS request:: + + proxy_url="socks4a://<userid>@proxy-host" + +When connecting to a SOCKS5 proxy the ``username`` and ``password`` portion +of the ``proxy_url`` will be sent as the username/password to authenticate +with the proxy:: + + proxy_url="socks5h://<username>:<password>@proxy-host" + +""" +from __future__ import absolute_import + +try: + import socks +except ImportError: + import warnings + from ..exceptions import DependencyWarning + + warnings.warn(( + 'SOCKS support in urllib3 requires the installation of optional ' + 'dependencies: specifically, PySocks. For more information, see ' + 'https://urllib3.readthedocs.io/en/latest/contrib.html#socks-proxies' + ), + DependencyWarning + ) + raise + +from socket import error as SocketError, timeout as SocketTimeout + +from ..connection import ( + HTTPConnection, HTTPSConnection +) +from ..connectionpool import ( + HTTPConnectionPool, HTTPSConnectionPool +) +from ..exceptions import ConnectTimeoutError, NewConnectionError +from ..poolmanager import PoolManager +from ..util.url import parse_url + +try: + import ssl +except ImportError: + ssl = None + + +class SOCKSConnection(HTTPConnection): + """ + A plain-text HTTP connection that connects via a SOCKS proxy. + """ + def __init__(self, *args, **kwargs): + self._socks_options = kwargs.pop('_socks_options') + super(SOCKSConnection, self).__init__(*args, **kwargs) + + def _new_conn(self): + """ + Establish a new connection via the SOCKS proxy. + """ + extra_kw = {} + if self.source_address: + extra_kw['source_address'] = self.source_address + + if self.socket_options: + extra_kw['socket_options'] = self.socket_options + + try: + conn = socks.create_connection( + (self.host, self.port), + proxy_type=self._socks_options['socks_version'], + proxy_addr=self._socks_options['proxy_host'], + proxy_port=self._socks_options['proxy_port'], + proxy_username=self._socks_options['username'], + proxy_password=self._socks_options['password'], + proxy_rdns=self._socks_options['rdns'], + timeout=self.timeout, + **extra_kw + ) + + except SocketTimeout: + raise ConnectTimeoutError( + self, "Connection to %s timed out. (connect timeout=%s)" % + (self.host, self.timeout)) + + except socks.ProxyError as e: + # This is fragile as hell, but it seems to be the only way to raise + # useful errors here. + if e.socket_err: + error = e.socket_err + if isinstance(error, SocketTimeout): + raise ConnectTimeoutError( + self, + "Connection to %s timed out. (connect timeout=%s)" % + (self.host, self.timeout) + ) + else: + raise NewConnectionError( + self, + "Failed to establish a new connection: %s" % error + ) + else: + raise NewConnectionError( + self, + "Failed to establish a new connection: %s" % e + ) + + except SocketError as e: # Defensive: PySocks should catch all these. + raise NewConnectionError( + self, "Failed to establish a new connection: %s" % e) + + return conn + + +# We don't need to duplicate the Verified/Unverified distinction from +# urllib3/connection.py here because the HTTPSConnection will already have been +# correctly set to either the Verified or Unverified form by that module. This +# means the SOCKSHTTPSConnection will automatically be the correct type. +class SOCKSHTTPSConnection(SOCKSConnection, HTTPSConnection): + pass + + +class SOCKSHTTPConnectionPool(HTTPConnectionPool): + ConnectionCls = SOCKSConnection + + +class SOCKSHTTPSConnectionPool(HTTPSConnectionPool): + ConnectionCls = SOCKSHTTPSConnection + + +class SOCKSProxyManager(PoolManager): + """ + A version of the urllib3 ProxyManager that routes connections via the + defined SOCKS proxy. + """ + pool_classes_by_scheme = { + 'http': SOCKSHTTPConnectionPool, + 'https': SOCKSHTTPSConnectionPool, + } + + def __init__(self, proxy_url, username=None, password=None, + num_pools=10, headers=None, **connection_pool_kw): + parsed = parse_url(proxy_url) + + if username is None and password is None and parsed.auth is not None: + split = parsed.auth.split(':') + if len(split) == 2: + username, password = split + if parsed.scheme == 'socks5': + socks_version = socks.PROXY_TYPE_SOCKS5 + rdns = False + elif parsed.scheme == 'socks5h': + socks_version = socks.PROXY_TYPE_SOCKS5 + rdns = True + elif parsed.scheme == 'socks4': + socks_version = socks.PROXY_TYPE_SOCKS4 + rdns = False + elif parsed.scheme == 'socks4a': + socks_version = socks.PROXY_TYPE_SOCKS4 + rdns = True + else: + raise ValueError( + "Unable to determine SOCKS version from %s" % proxy_url + ) + + self.proxy_url = proxy_url + + socks_options = { + 'socks_version': socks_version, + 'proxy_host': parsed.host, + 'proxy_port': parsed.port, + 'username': username, + 'password': password, + 'rdns': rdns + } + connection_pool_kw['_socks_options'] = socks_options + + super(SOCKSProxyManager, self).__init__( + num_pools, headers, **connection_pool_kw + ) + + self.pool_classes_by_scheme = SOCKSProxyManager.pool_classes_by_scheme diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/exceptions.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/exceptions.py new file mode 100644 index 0000000..7bbaa98 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/exceptions.py @@ -0,0 +1,246 @@ +from __future__ import absolute_import +from .packages.six.moves.http_client import ( + IncompleteRead as httplib_IncompleteRead +) +# Base Exceptions + + +class HTTPError(Exception): + "Base exception used by this module." + pass + + +class HTTPWarning(Warning): + "Base warning used by this module." + pass + + +class PoolError(HTTPError): + "Base exception for errors caused within a pool." + def __init__(self, pool, message): + self.pool = pool + HTTPError.__init__(self, "%s: %s" % (pool, message)) + + def __reduce__(self): + # For pickling purposes. + return self.__class__, (None, None) + + +class RequestError(PoolError): + "Base exception for PoolErrors that have associated URLs." + def __init__(self, pool, url, message): + self.url = url + PoolError.__init__(self, pool, message) + + def __reduce__(self): + # For pickling purposes. + return self.__class__, (None, self.url, None) + + +class SSLError(HTTPError): + "Raised when SSL certificate fails in an HTTPS connection." + pass + + +class ProxyError(HTTPError): + "Raised when the connection to a proxy fails." + pass + + +class DecodeError(HTTPError): + "Raised when automatic decoding based on Content-Type fails." + pass + + +class ProtocolError(HTTPError): + "Raised when something unexpected happens mid-request/response." + pass + + +#: Renamed to ProtocolError but aliased for backwards compatibility. +ConnectionError = ProtocolError + + +# Leaf Exceptions + +class MaxRetryError(RequestError): + """Raised when the maximum number of retries is exceeded. + + :param pool: The connection pool + :type pool: :class:`~urllib3.connectionpool.HTTPConnectionPool` + :param string url: The requested Url + :param exceptions.Exception reason: The underlying error + + """ + + def __init__(self, pool, url, reason=None): + self.reason = reason + + message = "Max retries exceeded with url: %s (Caused by %r)" % ( + url, reason) + + RequestError.__init__(self, pool, url, message) + + +class HostChangedError(RequestError): + "Raised when an existing pool gets a request for a foreign host." + + def __init__(self, pool, url, retries=3): + message = "Tried to open a foreign host with url: %s" % url + RequestError.__init__(self, pool, url, message) + self.retries = retries + + +class TimeoutStateError(HTTPError): + """ Raised when passing an invalid state to a timeout """ + pass + + +class TimeoutError(HTTPError): + """ Raised when a socket timeout error occurs. + + Catching this error will catch both :exc:`ReadTimeoutErrors + <ReadTimeoutError>` and :exc:`ConnectTimeoutErrors <ConnectTimeoutError>`. + """ + pass + + +class ReadTimeoutError(TimeoutError, RequestError): + "Raised when a socket timeout occurs while receiving data from a server" + pass + + +# This timeout error does not have a URL attached and needs to inherit from the +# base HTTPError +class ConnectTimeoutError(TimeoutError): + "Raised when a socket timeout occurs while connecting to a server" + pass + + +class NewConnectionError(ConnectTimeoutError, PoolError): + "Raised when we fail to establish a new connection. Usually ECONNREFUSED." + pass + + +class EmptyPoolError(PoolError): + "Raised when a pool runs out of connections and no more are allowed." + pass + + +class ClosedPoolError(PoolError): + "Raised when a request enters a pool after the pool has been closed." + pass + + +class LocationValueError(ValueError, HTTPError): + "Raised when there is something wrong with a given URL input." + pass + + +class LocationParseError(LocationValueError): + "Raised when get_host or similar fails to parse the URL input." + + def __init__(self, location): + message = "Failed to parse: %s" % location + HTTPError.__init__(self, message) + + self.location = location + + +class ResponseError(HTTPError): + "Used as a container for an error reason supplied in a MaxRetryError." + GENERIC_ERROR = 'too many error responses' + SPECIFIC_ERROR = 'too many {status_code} error responses' + + +class SecurityWarning(HTTPWarning): + "Warned when performing security reducing actions" + pass + + +class SubjectAltNameWarning(SecurityWarning): + "Warned when connecting to a host with a certificate missing a SAN." + pass + + +class InsecureRequestWarning(SecurityWarning): + "Warned when making an unverified HTTPS request." + pass + + +class SystemTimeWarning(SecurityWarning): + "Warned when system time is suspected to be wrong" + pass + + +class InsecurePlatformWarning(SecurityWarning): + "Warned when certain SSL configuration is not available on a platform." + pass + + +class SNIMissingWarning(HTTPWarning): + "Warned when making a HTTPS request without SNI available." + pass + + +class DependencyWarning(HTTPWarning): + """ + Warned when an attempt is made to import a module with missing optional + dependencies. + """ + pass + + +class ResponseNotChunked(ProtocolError, ValueError): + "Response needs to be chunked in order to read it as chunks." + pass + + +class BodyNotHttplibCompatible(HTTPError): + """ + Body should be httplib.HTTPResponse like (have an fp attribute which + returns raw chunks) for read_chunked(). + """ + pass + + +class IncompleteRead(HTTPError, httplib_IncompleteRead): + """ + Response length doesn't match expected Content-Length + + Subclass of http_client.IncompleteRead to allow int value + for `partial` to avoid creating large objects on streamed + reads. + """ + def __init__(self, partial, expected): + super(IncompleteRead, self).__init__(partial, expected) + + def __repr__(self): + return ('IncompleteRead(%i bytes read, ' + '%i more expected)' % (self.partial, self.expected)) + + +class InvalidHeader(HTTPError): + "The header provided was somehow invalid." + pass + + +class ProxySchemeUnknown(AssertionError, ValueError): + "ProxyManager does not support the supplied scheme" + # TODO(t-8ch): Stop inheriting from AssertionError in v2.0. + + def __init__(self, scheme): + message = "Not supported proxy scheme %s" % scheme + super(ProxySchemeUnknown, self).__init__(message) + + +class HeaderParsingError(HTTPError): + "Raised by assert_header_parsing, but we convert it to a log.warning statement." + def __init__(self, defects, unparsed_data): + message = '%s, unparsed data: %r' % (defects or 'Unknown', unparsed_data) + super(HeaderParsingError, self).__init__(message) + + +class UnrewindableBodyError(HTTPError): + "urllib3 encountered an error when trying to rewind a body" + pass diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/fields.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/fields.py new file mode 100644 index 0000000..6a9a5a7 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/fields.py @@ -0,0 +1,272 @@ +from __future__ import absolute_import +import email.utils +import mimetypes +import re + +from .packages import six + + +def guess_content_type(filename, default='application/octet-stream'): + """ + Guess the "Content-Type" of a file. + + :param filename: + The filename to guess the "Content-Type" of using :mod:`mimetypes`. + :param default: + If no "Content-Type" can be guessed, default to `default`. + """ + if filename: + return mimetypes.guess_type(filename)[0] or default + return default + + +def format_header_param_rfc2231(name, value): + """ + Helper function to format and quote a single header parameter using the + strategy defined in RFC 2231. + + Particularly useful for header parameters which might contain + non-ASCII values, like file names. This follows RFC 2388 Section 4.4. + + :param name: + The name of the parameter, a string expected to be ASCII only. + :param value: + The value of the parameter, provided as ``bytes`` or `str``. + :ret: + An RFC-2231-formatted unicode string. + """ + if isinstance(value, six.binary_type): + value = value.decode("utf-8") + + if not any(ch in value for ch in '"\\\r\n'): + result = u'%s="%s"' % (name, value) + try: + result.encode('ascii') + except (UnicodeEncodeError, UnicodeDecodeError): + pass + else: + return result + + if not six.PY3: # Python 2: + value = value.encode('utf-8') + + # encode_rfc2231 accepts an encoded string and returns an ascii-encoded + # string in Python 2 but accepts and returns unicode strings in Python 3 + value = email.utils.encode_rfc2231(value, 'utf-8') + value = '%s*=%s' % (name, value) + + if not six.PY3: # Python 2: + value = value.decode('utf-8') + + return value + + +_HTML5_REPLACEMENTS = { + u"\u0022": u"%22", + # Replace "\" with "\\". + u"\u005C": u"\u005C\u005C", + u"\u005C": u"\u005C\u005C", +} + +# All control characters from 0x00 to 0x1F *except* 0x1B. +_HTML5_REPLACEMENTS.update({ + six.unichr(cc): u"%{:02X}".format(cc) + for cc + in range(0x00, 0x1F+1) + if cc not in (0x1B,) +}) + + +def _replace_multiple(value, needles_and_replacements): + + def replacer(match): + return needles_and_replacements[match.group(0)] + + pattern = re.compile( + r"|".join([ + re.escape(needle) for needle in needles_and_replacements.keys() + ]) + ) + + result = pattern.sub(replacer, value) + + return result + + +def format_header_param_html5(name, value): + """ + Helper function to format and quote a single header parameter using the + HTML5 strategy. + + Particularly useful for header parameters which might contain + non-ASCII values, like file names. This follows the `HTML5 Working Draft + Section 4.10.22.7`_ and matches the behavior of curl and modern browsers. + + .. _HTML5 Working Draft Section 4.10.22.7: + https://w3c.github.io/html/sec-forms.html#multipart-form-data + + :param name: + The name of the parameter, a string expected to be ASCII only. + :param value: + The value of the parameter, provided as ``bytes`` or `str``. + :ret: + A unicode string, stripped of troublesome characters. + """ + if isinstance(value, six.binary_type): + value = value.decode("utf-8") + + value = _replace_multiple(value, _HTML5_REPLACEMENTS) + + return u'%s="%s"' % (name, value) + + +# For backwards-compatibility. +format_header_param = format_header_param_html5 + + +class RequestField(object): + """ + A data container for request body parameters. + + :param name: + The name of this request field. Must be unicode. + :param data: + The data/value body. + :param filename: + An optional filename of the request field. Must be unicode. + :param headers: + An optional dict-like object of headers to initially use for the field. + :param header_formatter: + An optional callable that is used to encode and format the headers. By + default, this is :func:`format_header_param_html5`. + """ + def __init__( + self, + name, + data, + filename=None, + headers=None, + header_formatter=format_header_param_html5): + self._name = name + self._filename = filename + self.data = data + self.headers = {} + if headers: + self.headers = dict(headers) + self.header_formatter = header_formatter + + @classmethod + def from_tuples( + cls, + fieldname, + value, + header_formatter=format_header_param_html5): + """ + A :class:`~urllib3.fields.RequestField` factory from old-style tuple parameters. + + Supports constructing :class:`~urllib3.fields.RequestField` from + parameter of key/value strings AND key/filetuple. A filetuple is a + (filename, data, MIME type) tuple where the MIME type is optional. + For example:: + + 'foo': 'bar', + 'fakefile': ('foofile.txt', 'contents of foofile'), + 'realfile': ('barfile.txt', open('realfile').read()), + 'typedfile': ('bazfile.bin', open('bazfile').read(), 'image/jpeg'), + 'nonamefile': 'contents of nonamefile field', + + Field names and filenames must be unicode. + """ + if isinstance(value, tuple): + if len(value) == 3: + filename, data, content_type = value + else: + filename, data = value + content_type = guess_content_type(filename) + else: + filename = None + content_type = None + data = value + + request_param = cls( + fieldname, data, filename=filename, header_formatter=header_formatter) + request_param.make_multipart(content_type=content_type) + + return request_param + + def _render_part(self, name, value): + """ + Overridable helper function to format a single header parameter. By + default, this calls ``self.header_formatter``. + + :param name: + The name of the parameter, a string expected to be ASCII only. + :param value: + The value of the parameter, provided as a unicode string. + """ + + return self.header_formatter(name, value) + + def _render_parts(self, header_parts): + """ + Helper function to format and quote a single header. + + Useful for single headers that are composed of multiple items. E.g., + 'Content-Disposition' fields. + + :param header_parts: + A sequence of (k, v) tuples or a :class:`dict` of (k, v) to format + as `k1="v1"; k2="v2"; ...`. + """ + parts = [] + iterable = header_parts + if isinstance(header_parts, dict): + iterable = header_parts.items() + + for name, value in iterable: + if value is not None: + parts.append(self._render_part(name, value)) + + return u'; '.join(parts) + + def render_headers(self): + """ + Renders the headers for this request field. + """ + lines = [] + + sort_keys = ['Content-Disposition', 'Content-Type', 'Content-Location'] + for sort_key in sort_keys: + if self.headers.get(sort_key, False): + lines.append(u'%s: %s' % (sort_key, self.headers[sort_key])) + + for header_name, header_value in self.headers.items(): + if header_name not in sort_keys: + if header_value: + lines.append(u'%s: %s' % (header_name, header_value)) + + lines.append(u'\r\n') + return u'\r\n'.join(lines) + + def make_multipart(self, content_disposition=None, content_type=None, + content_location=None): + """ + Makes this request field into a multipart request field. + + This method overrides "Content-Disposition", "Content-Type" and + "Content-Location" headers to the request parameter. + + :param content_type: + The 'Content-Type' of the request body. + :param content_location: + The 'Content-Location' of the request body. + + """ + self.headers['Content-Disposition'] = content_disposition or u'form-data' + self.headers['Content-Disposition'] += u'; '.join([ + u'', self._render_parts( + ((u'name', self._name), (u'filename', self._filename)) + ) + ]) + self.headers['Content-Type'] = content_type + self.headers['Content-Location'] = content_location diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/filepost.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/filepost.py new file mode 100644 index 0000000..78f1e19 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/filepost.py @@ -0,0 +1,98 @@ +from __future__ import absolute_import +import binascii +import codecs +import os + +from io import BytesIO + +from .packages import six +from .packages.six import b +from .fields import RequestField + +writer = codecs.lookup('utf-8')[3] + + +def choose_boundary(): + """ + Our embarrassingly-simple replacement for mimetools.choose_boundary. + """ + boundary = binascii.hexlify(os.urandom(16)) + if six.PY3: + boundary = boundary.decode('ascii') + return boundary + + +def iter_field_objects(fields): + """ + Iterate over fields. + + Supports list of (k, v) tuples and dicts, and lists of + :class:`~urllib3.fields.RequestField`. + + """ + if isinstance(fields, dict): + i = six.iteritems(fields) + else: + i = iter(fields) + + for field in i: + if isinstance(field, RequestField): + yield field + else: + yield RequestField.from_tuples(*field) + + +def iter_fields(fields): + """ + .. deprecated:: 1.6 + + Iterate over fields. + + The addition of :class:`~urllib3.fields.RequestField` makes this function + obsolete. Instead, use :func:`iter_field_objects`, which returns + :class:`~urllib3.fields.RequestField` objects. + + Supports list of (k, v) tuples and dicts. + """ + if isinstance(fields, dict): + return ((k, v) for k, v in six.iteritems(fields)) + + return ((k, v) for k, v in fields) + + +def encode_multipart_formdata(fields, boundary=None): + """ + Encode a dictionary of ``fields`` using the multipart/form-data MIME format. + + :param fields: + Dictionary of fields or list of (key, :class:`~urllib3.fields.RequestField`). + + :param boundary: + If not specified, then a random boundary will be generated using + :func:`urllib3.filepost.choose_boundary`. + """ + body = BytesIO() + if boundary is None: + boundary = choose_boundary() + + for field in iter_field_objects(fields): + body.write(b('--%s\r\n' % (boundary))) + + writer(body).write(field.render_headers()) + data = field.data + + if isinstance(data, int): + data = str(data) # Backwards compatibility + + if isinstance(data, six.text_type): + writer(body).write(data) + else: + body.write(data) + + body.write(b'\r\n') + + body.write(b('--%s--\r\n' % (boundary))) + + content_type = str('multipart/form-data; boundary=%s' % boundary) + + return body.getvalue(), content_type diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/__init__.py new file mode 100644 index 0000000..170e974 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/__init__.py @@ -0,0 +1,5 @@ +from __future__ import absolute_import + +from . import ssl_match_hostname + +__all__ = ('ssl_match_hostname', ) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9e16d1845a4907eecd99a60db15e97e5e99f0eb3 GIT binary patch literal 326 zcmYjMy-ve05Vn(4R8=b^o`5w&aR8}OB!qYZ7GTM8a%(3s*p6j8QJc46WaD|VGW7)* zn6S&jC*61VeLCIG%WAbi0pFkRRE7K%#eXD0JcMwUff!;~B84lA5ldJq6O~qJsM9KA z*%QiV$IyjxJe||6>tyda2xU6!kND5Oa881ve%C_VIj^bWkNIp`0MxzjEeEi1<AiJ$ z(-{Dj65s>bdC({N8HurCpq`U~T2gnCaqCFACk>Q?RinPCUyHWgk0Z!(vu$k=&}i~Z zj4*4VoewkDMX?zU!*w6cQ^3GA>n!Q5lwx~J4BfrahC2cvwD15|<}l6gRL6SB@8dr% J-ndMb$uG~(TXO&a literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/__pycache__/six.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/__pycache__/six.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..16155696a16c92dedeb55f617fcf03ff64dc9ff1 GIT binary patch literal 24486 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/backports/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/backports/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e0531f0f09bf09447d208158031a58eabf86e7ff GIT binary patch literal 223 zcmYk0u?oU45QZZ-h|mXds8<z)f{0JxqRt^TX&a4cxU@k#`y!5RK98%9AUHUgxabGp ze|P_Mn<(lN&+B$!VLn3q)A7f`Yr8%;S&>0!c_kR?U%by?P&!r%a10@@6c=bAJwicK zhlf^=^IcMw$F`*^on|E_o<hSKj5M*-wq{DjNiuaOH)=xpl{%q$h0vf<GMj*5+dV6U fh0HIe!rB6*Qp=jsp*h`qvqQxjCFbF~r<Z&H8tFcV literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..373d68c8a462cf30a291b210d086ca896d4bbc66 GIT binary patch literal 1327 zcmZuxPjA~c6elHFlI1_hx?$I`1s2ReYh~-!BEvAOUK1d|kQQ~a0KO=)NyUm~$slPv zHs~Fep7sfL8L%7&?2wPq&%on$$`|Nim+aAwjR4ydNWS;u<NHhMxK;}g(EIDF__~D9 z-$uAkfT8bTh;5iC>L7}#mEjJC)y}M;-LWyE9xYM#E$%qfYNLif|1Idoy}_v9QZ$G0 zfF)_hf}j3FLC{*O5!q+t^-T7QoIE9`r=sW$nA{vbJtad1o0KF4Cu70LG?jf4=Wrs; z&){?{gK3;gL1aOCoW+unm^@0r`6IG2MvCq^>&a$t1F4|H2G)Li>E+;+#=Pem^p0w< z8u@z|VhbZAk;0cIXN%f>dw{_WrjEi1{uo{2p8;2R;4WN>%{uy0xmC3AlqXus6)kCj zhP~AAX=zbb9`C3!#m^D&E>D2B3@>ekRQb|c1PVFm+@bDsWTD7W7WD=`|AqPs3;6N? z@n2=>+`W@5eyx1*CqxvOSX9tP;NcxuekV)6dn$m>y0RCQd>e2Ln7>3UKt6)_{xb0a zT3(~d=kHaejQ|T&McK+xr7LGqRajM{imF17EAy`d0<>-*DU$!~TEdIrrmxMfn#)7n zhPrAz)wny~PV-5erIZW{%E+gjd{*SyjPS=~`j~V{oMpw7(S}Ah&<1pPa|^@`JAXLN zyW=EboKYeqw0tPYa4aP0GSW@+n9mwjZ3`xK@MD~f*&gQw*Yy`dFfP*~U&`D9Q=NLW zzNHaoiO^PB=nr4+?Y}tw;V5by@9*!uiP{I9Jza0zd3<y7I!?jbMrJW(_v90vN|0+u z>_Q&AI^pqX1fpY-Y}B+PSeEbyrV8a%4seOJ&+=YD4d*fwtI%G~rdgUZ?M=a++3_IH zmC7nb0OF~!s%>DjyRxPo34Z@T{1b5T&)aas(+RwYa1!${DKdyugu55vS+qOh!+HKi za=z2=U(DxGw)?Ex=Q}`Wd3Y3#($SMN7ZSSgWM}8uWH$MHY{2D+CM>4~563*q((co6 z1aCP$V<OzV{cv5?=4hrrSi_rI*C9CZ5++o7fGzCbI<}ANxQc!3z-MM32Y{?N_ii=l z7VOn6A9Ri87Iraz2zDB!<<&X_YLv7WMYQNe5wF6Qc2|FaWy6=s%i`Rdh|%)Dfnts` U_N}=W!W?uw->TZkT)EqS0qV<xMgRZ+ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py new file mode 100644 index 0000000..740db37 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py @@ -0,0 +1,53 @@ +# -*- coding: utf-8 -*- +""" +backports.makefile +~~~~~~~~~~~~~~~~~~ + +Backports the Python 3 ``socket.makefile`` method for use with anything that +wants to create a "fake" socket object. +""" +import io + +from socket import SocketIO + + +def backport_makefile(self, mode="r", buffering=None, encoding=None, + errors=None, newline=None): + """ + Backport of ``socket.makefile`` from Python 3.5. + """ + if not set(mode) <= {"r", "w", "b"}: + raise ValueError( + "invalid mode %r (only r, w, b allowed)" % (mode,) + ) + writing = "w" in mode + reading = "r" in mode or not writing + assert reading or writing + binary = "b" in mode + rawmode = "" + if reading: + rawmode += "r" + if writing: + rawmode += "w" + raw = SocketIO(self, rawmode) + self._makefile_refs += 1 + if buffering is None: + buffering = -1 + if buffering < 0: + buffering = io.DEFAULT_BUFFER_SIZE + if buffering == 0: + if not binary: + raise ValueError("unbuffered streams must be binary") + return raw + if reading and writing: + buffer = io.BufferedRWPair(raw, raw, buffering) + elif reading: + buffer = io.BufferedReader(raw, buffering) + else: + assert writing + buffer = io.BufferedWriter(raw, buffering) + if binary: + return buffer + text = io.TextIOWrapper(buffer, encoding, errors, newline) + text.mode = mode + return text diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__init__.py new file mode 100644 index 0000000..371c6dd --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__init__.py @@ -0,0 +1,56 @@ +# -*- coding: utf-8 -*- +# Copyright (c) 2014 Rackspace +# 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. + +""" +An implementation of semantics and validations described in RFC 3986. + +See http://rfc3986.readthedocs.io/ for detailed documentation. + +:copyright: (c) 2014 Rackspace +:license: Apache v2.0, see LICENSE for details +""" + +from .api import iri_reference +from .api import IRIReference +from .api import is_valid_uri +from .api import normalize_uri +from .api import uri_reference +from .api import URIReference +from .api import urlparse +from .parseresult import ParseResult + +__title__ = 'rfc3986' +__author__ = 'Ian Stapleton Cordasco' +__author_email__ = 'graffatcolmingov@gmail.com' +__license__ = 'Apache v2.0' +__copyright__ = 'Copyright 2014 Rackspace' +__version__ = '1.3.2' + +__all__ = ( + 'ParseResult', + 'URIReference', + 'IRIReference', + 'is_valid_uri', + 'normalize_uri', + 'uri_reference', + 'iri_reference', + 'urlparse', + '__title__', + '__author__', + '__author_email__', + '__license__', + '__copyright__', + '__version__', +) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..11fe7ae10799961c8c50af36b7aff97f5ed9f6f8 GIT binary patch literal 1060 zcmZuvO=}x55M6)UYddiQEhUGdV-1bhaZ0F7DG4S8LkY!hF1iS1rS+=WT`iKlBzr9V zBR%%kU(<uHJ@pUt&{Id7#5koAdb}B-(bLmhcDt?v<M;Qk^q}rIKW(r*$`G8w(q90W zgB@04<){>wak*r91$YHl3SI?X#npn>fY)%X;C0}2TrYS7cmp>I-UQyn&4Rb0R_tOI zxQpAYjXSJ^yR3_M*bd%hyST@Cc#rKZoc@0P!#zuoh|`G2JTcS=nIIV;&10Gv;cG+_ zhB6unR_tlSxb~H};tYud&EHMY@%Z)0z;zd#qtKXi;(03Yi=^U|nUFK->w%CS3Z#PL zhKdMILw2>f63$P2ncga~49x_+@cU>qJbH!Z)W6m#^|?EVgwGSrC+G~~kfUrg7`_CZ z9KD}S&o36|TjjO;s{|JJOY5#sf+!wv#S@=HqBEP%=G(E*q<9`#DPa#JQpNDxoIfNW z|G2{C;|k4{ic+eyt=|4%$(-v|WY&#)AM&R&nxKWDV6p*wr&2MheVHFD6%7Jvd>O?e zS<38m8G|_kU&eWR>zVnp>4P`_*pk<d2FHU@e@C_8y{ciMVxelGW&s+}QMU6`6JXsU z#0V2{Le?%JbY()RfcG{WK3+tSX%lj9IRsroHs5o%mvN<`R|vW2@2?w#z<0t%g{I=} zvj3?l<P|E~g<-1j=}vmvD(qP3TG+9$YoP~VFQ5^q`sS!7HfiC{XD?MEqlSAKRbC(? z2AaI_jkhG@OvQOJ3O)_P@FvemG(Ncs)ey!q@jiN~NDoD#4b(gw4o|Y%>}X|^#UdF` zm{cBoYb36YJ!rRUy5#zytvy0SA`Bse^mg5R6HB&=_**MeKL@C`I;BUmTrF*8`7hMa BEsFpE literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/_mixin.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/_mixin.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..187adca77aa09bc450d43edc123c8f13600f07f5 GIT binary patch literal 10661 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 N7*Lo6U;=;o{{W^OD>488 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/abnf_regexp.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/abnf_regexp.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..412ecf321388489b2d80a100833ada042cad6a56 GIT binary patch literal 4164 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/api.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/api.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0b82e0dd6bee092da23b62bf8c9b5aa21e262518 GIT binary patch literal 3725 zcmc&%O>Y}T7~Zwh#PLU)LRvsv=0+?LJ5VV!7D7}-l_EqHwdsKzu*W-Nd(!>t%&b#K zDJQP*8xn54@q2vji9f)hC!U%0uGi@YshWzlc0D^E@8>hmy!)ups5-d*`Rk0fuQ|>O z^HRLZc=;Z;`UMZ>95~EnCEpE72PN0E%YHdnI#{ypCI3pWe6Wo6b+*h_esd32*hj3w zR?(`kk6D$~&{}2dtj-!}RoM-8m0d%t#?~G>&6~%6R)30E;&b9fp{61f;gIMNCrSh{ zdTGeWAPGG!qLBLJ&fYE=M3TsXcWdYNcB@+59|=W*R0QJ#5ptC;P<DANqp@J<rk=-@ zB091P;-v2jk5H|p=qH-1s?p{7R4L4j26G*My9h+noz{0B>^|TFE_vv2yw~=qRQv%~ ziLcG@qr&jZD~TR#-u6mZnq8*7g!?XTRmVd+r|yY!;+~Zd3YYew$BHDBKo(K34ABrF zEVezla`;VfS>NG4HNhM6P#D8<?_1>OD8WeLGq^qye9Y6x(tr~VU;7i1C}^;<dcC6g zt$~b!Zfd|rB1N;;o9XPtRMNoMM$q4Z4cr=gG!ov3gq$-Q;XWsrs5r~ams#LiR$W01 zjE)%0NM&VjCIc1+X%J>fWa(nbbs|I6A$Kw@Fn%_qCo%7kj!k4|!Kt2|(JV=mglVnd z;`7q93~#2DO#5?3noaWZSv!_uOf_$hsca7-pK+<$J5Srg?#@^S$Klt5!>!Ti>G5&b z-`Vbu<QA@B*xql)BHk3C($x1ix3;#&lkr!H>9ltj$zqXgC(`#t|5iJu-eWrCsy)MX zo5rFQPo@nR)y*UKxxtMER81QAyc4**0=R(VMR0|r2<;Dot_1~!&~J!0pbPyeB8;{F zGrC~HYtdD7Do2;ekX**22~@!gxoSELoYF@Pt!V=T^UOBUm1XuS+6$R2qr)KfM>A<1 zk2!4|mIlsA=?~Y^#|upSfom=UkRTE1_Axv%6o4B6PmHNA*gI!8QJ@Qfy(n!Adc6fu zT6Sm&)wRMmKolg(Ccc$X7S|YxJI_(lGV6cv4i<uIta5BqcxQ<5{n#aCxPBD*MDizz zki4tB5f4Bs54kqyN3XXp6Ao7q<q1gkNT`wNpG`N!W$iGw#Bjs%az<!Y6nHs^qmYMs z!Qus_G|{6-3O%_Ly}7iDsE(-~U5ZvC=pqWABwSvOpH|XER1PE^21vlA_?ZcNMR9&q z6)|HDHnTIcJ^3XNb&vYWKq@jj4S?b^V94}9Gsv)*YL@N!Wf^8#$u=H(E1(9;HPhwC zM^p~gdCsY4le^f#-xxNrhsjNO9qrdr&RsL<Q#|IBb6Prco|R5Yr{y!p(oTqj<$fds zaLaL8V5EEl|2_!Sgqg05W-AF*><j%atn;Sj=B(y4W5)u4AXf7#CuN&l#--3rj*xwz zVlLVMWDx?Wxl#ly6%eqRub8gP!m)sb^?aPo&ztkeXylU&H1<r^&57gG*Iao6{|n$S zpt*wEf@2L0?Ht-N)_f=YUIr-2v{R@yayZy(JoT1PVk_OWczy*ZU|=m!?n@r~)C2Q| zdR`BrOsA3&6i$-L$rlQBsBde{dF7jy$8S%fUGkm@%<^;La`e~i!^LW!9dLW|&xo{$ zxQDNaWm9~68r3R}^|YRlE2ed>kf>zd_b`}l=&Jk#?fXqvnl!!juRdMrc3I?gyRw0~ z(&TnpD;Sq*x71<~Ve3w5N)$^P793Vv!7OW_EpjT~rXObC;WN`w1}aM{br-*K^(ua! HRoDInv}8)J literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/builder.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/builder.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..bf49cd52903f260164e158add338b273300ea5dc GIT binary patch literal 8167 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 W&dWyDdunC3>1IgukkOauXZ{DgwJ?AH literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4272c641cc4e05577eeea7f03f00a47d89f30004 GIT binary patch literal 1162 zcmb_b&2G~`5Z<+&pQcG0O1bn<t++*~acHHekt&2#^}q#H0tC&)a=e?wjk9ZJH&GK6 z38@@-49bmLAA@J`l~Z1TLr=^)qzZS|n%U3u?W||MOy1RM6@u&c-EFui5c12utgkY@ zyhPJK(Q(oxoN_0jT{^ELaua9lc0Eeo6UjUx3Zn{~P-35)EiTy$BApK;&+ss#)Ghs! zAs;flq_||48NARf^P-@a8y<1Vh^nu=G$PV-@cwRvm)Dr@eB*)H6cxA=)ozV%^G#m; zLc3eM&TD)N(KdJ9kjA5V>r{=?(8RqsiOr0S6`v%6^%b!5nHeg{4p}HUJ7Rj0rV31R zf&G)$4Vo1`PLvS{HYSh=87VFrURE|L=*^7KSrL&okd=|nkAjPt4QF9DpiAtnVF&S| zn8#tmVypRmVPg6R$B`vh%VK-UDVlzY&X8-=`Nn~LL$8T(ZXCUTO}@F;^p<`?4m)+` ztuv`7Aeb43hV@vinGsip#S$Ze=~P5<KNg(jt;BNB%!*w6?W!~kb!f1eN~~k4O(-Lg zl_oN_Jk+p+hLh1=R$e9lAn+KY_n-X~;%R7vKMld}s|1g0zjNgeg3c7ib9vamYz>E3 z^LdbT+PxvPa1EsY)=%T~Apca79JE^P>1_IZVuQH_Qz5wmAEiy=-jSb%(I^}U?L$90 z>KwQIDF0QP=?rj~$ul%<l_kzDt<XI79~5n`E2^!ck&;sZ230hQ<zvA5pvJkvD``;I z)wIACmIT}AvO<0uo*=eTYS^)q)o|%{Ewa;ch_>E~jWsA#*S30A3IeX8Ajn)j(^+*X zQ!@=g3$W7zR*Y=()!2^o8GwSUxIB~(sm%|Q1oNxdj*gWKV%b-jdwy|b-67s<0P6N8 tt8ZS|TCsWAw&JXOviwKAuuW=)&ZA|=p>?`NcOG`Hv`6<`k9uyU^an588~FeL literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/exceptions.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/exceptions.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..757f7e86e1f7b771b31132cb84b14d4735b7f099 GIT binary patch literal 4801 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 KR~qw;tN#Og>}inz literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/iri.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/iri.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3e774ec62d3b3d6b5d2e13248b3ca6a73c0fbefc GIT binary patch literal 4516 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 CrkzCq literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/misc.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/misc.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1a2fdb8467b609194a5689b3f4937bfc7d304569 GIT binary patch literal 2281 zcmZuz-E!JS6xJUg^XETo;x=t*gB#N(hQukUGa0)MmSfEraD~WB)YKZ8T|kZybOqEV zc5d3fMK9vZ-t|5D2D<H4UZ6AeOq!lu1HoyfIm<cU`S$GDb9QA{W3ey?&tJcvTmMXR z+@I8#d}J`b0r6h)9EUiALp%~3-r$jlBu8k8hRAa$fPyH5WHi+X7!nqb0w6(<5Qq#i zg~GoEj4)^sgZiQd^~Q`ijMD~X%owwne>Df%{5fwVsE#797QkKvNrGHE7s0c{JW;Se zNOCBa<N*6{j9njNA2E!^{}`}o#`}a}Gk~QQ>AX*=4c2F%-x%s?(3kPD@j2tpvJ7sX z^MI}}gz_^WX^=1KB8&4S^UMQs3k8-q_`OXTP@%*x!V))Rtqxb1$NW+DTrhHM*5w}W z0RJus>~ZK_Lkno}XU@2Xzxs(Y@<^y~ndIP)aIuYg4o=nDZr8G1+iif_>evoODS{h4 z$08|w+#%TW?6&KrEEiF(*R|ZPw;B%XP1{SguEg+CcB|7Sl<|&wE7h^OT})i>)-cA^ zMZ%Md)Y}B;#G~2J1^bp`Bdbfzs-|8h(QRUzuw2_NX1Tnk$E@@kjun^T{fKqw)=k&~ z1oneot%+OMpR#)0W}DdE6JLUSnttGi9wsNgTqjne1z|D)f3AUDOzfJ8uw%Du$l3Gb zUhi<yo+a3P51Q$@P$W$H7@4&uB=5(7^bQ>44^}oGtZeQ->;cPm>+OvfxwFhSnN5l{ z+g^9$#htUv17_0lZM?X9mf1{S@CO%sdLSM=`)(jU`#wF8L0k5y7C3+i>A~#5vbXYV zbJ>GXH|Uri!~uFRM$@m~!c!AyeTI(&zamHh#M_18lskf(_*^E}LE}N2BG-{{$|t!B z^L60#oe8JHD**}T{F!(vApTUOrx6KB?vjUiI8)MKt%ykjr>xYW<zd>en;va`Gxehl zg9XRRfnN3}U8|)FKI?NCkpv+Z5`e)Ekh<-njO5ESj@ctNt?1=clg49QKL8|r{2ND- zFzMoDwnOZ`)y3JqMY8p_gP?uc_2X>AT<??Cz`a{P$~BwEgMsO+=MS4C2T#Mz>e-In zxoy*P?Krn{xqSbmf2T)5CT1VIs7<mx;yCu<TDD`=o?8v<Wl6oZw*GZK+p@jdYUjj{ zwCLVhdLDs<JoYgZ61*&g`7lqG0L$F>L#Bz^HPiG3g2^0Ugf_#EL$S<4xwv00DJ8w) z&plR3il!FKZDmg_s=A_8{CK7MXwsg&YMYwk&s0mAQc<)g%C=e9-GWK62?Pj<@daf^ z)vB>WzWCqO%!;D>bMLLdu&WC&Ui>QNCngqUX)xA&sa!Jm3%aS43gvCckcOLn5A;LB zj}R@%p1BWuP)m>L-XgR_#Vx(Ct7v`@J`^ph3n1)PE$x&kBf49z=rBcxa+Unhep%Bg zoPb?yRrTGnrs_|}5kibSo;3;_Quq7!STLrH;03Vq=GOMMW|-Pe;a)Cxe?-cUL&hda zil1a=2~rzQ7zGPKio0w&Q%11-ZB@~pQapC4jT|#O+ScPDoQv^FQx&K}QK8)UP#u#s zWp7JYpD46;Z2yt*bXttDTT^z%@fOENZ&W^WTP^5NQB~2#ff8GfD&@VZu9%ap2vtie z?WZ46CmIx0Cp#mnqiQdx|JMz6JN#h#@CesvQ$4I4+aCSwv&%g(T%)%|et7wJX9NDt z;5-KgDI^O~DK1L9Bry3q7!C69iXcK1FyXBrfrpnaf>Q||Uhqh7gMnxWyyBby7Jc8y Xp&&1V7JVa!XRgc>g3^T)mc#!7#ATmk literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/normalizers.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/normalizers.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..62e10de3df8ebc5d315bbd11f166688a3137806f GIT binary patch literal 3594 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 GFZ~y@c8&)C literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/parseresult.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/parseresult.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6a2dbc28930936aee3e5e1a12f293e2d0fc40098 GIT binary patch literal 9908 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/uri.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/uri.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6de7cdd054f862bad7ac759540ac2e75092e80eb GIT binary patch literal 4289 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/validators.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/__pycache__/validators.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..781d5c3b916734434227c1ea84dde5f7fe89cd54 GIT binary patch literal 13049 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 U6rW-FDHMW)^nd5_V6~I~16l?J(EtDd literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/_mixin.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/_mixin.py new file mode 100644 index 0000000..543925c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/_mixin.py @@ -0,0 +1,353 @@ +"""Module containing the implementation of the URIMixin class.""" +import warnings + +from . import exceptions as exc +from . import misc +from . import normalizers +from . import validators + + +class URIMixin(object): + """Mixin with all shared methods for URIs and IRIs.""" + + __hash__ = tuple.__hash__ + + def authority_info(self): + """Return a dictionary with the ``userinfo``, ``host``, and ``port``. + + If the authority is not valid, it will raise a + :class:`~rfc3986.exceptions.InvalidAuthority` Exception. + + :returns: + ``{'userinfo': 'username:password', 'host': 'www.example.com', + 'port': '80'}`` + :rtype: dict + :raises rfc3986.exceptions.InvalidAuthority: + If the authority is not ``None`` and can not be parsed. + """ + if not self.authority: + return {'userinfo': None, 'host': None, 'port': None} + + match = self._match_subauthority() + + if match is None: + # In this case, we have an authority that was parsed from the URI + # Reference, but it cannot be further parsed by our + # misc.SUBAUTHORITY_MATCHER. In this case it must not be a valid + # authority. + raise exc.InvalidAuthority(self.authority.encode(self.encoding)) + + # We had a match, now let's ensure that it is actually a valid host + # address if it is IPv4 + matches = match.groupdict() + host = matches.get('host') + + if (host and misc.IPv4_MATCHER.match(host) and not + validators.valid_ipv4_host_address(host)): + # If we have a host, it appears to be IPv4 and it does not have + # valid bytes, it is an InvalidAuthority. + raise exc.InvalidAuthority(self.authority.encode(self.encoding)) + + return matches + + def _match_subauthority(self): + return misc.SUBAUTHORITY_MATCHER.match(self.authority) + + @property + def host(self): + """If present, a string representing the host.""" + try: + authority = self.authority_info() + except exc.InvalidAuthority: + return None + return authority['host'] + + @property + def port(self): + """If present, the port extracted from the authority.""" + try: + authority = self.authority_info() + except exc.InvalidAuthority: + return None + return authority['port'] + + @property + def userinfo(self): + """If present, the userinfo extracted from the authority.""" + try: + authority = self.authority_info() + except exc.InvalidAuthority: + return None + return authority['userinfo'] + + def is_absolute(self): + """Determine if this URI Reference is an absolute URI. + + See http://tools.ietf.org/html/rfc3986#section-4.3 for explanation. + + :returns: ``True`` if it is an absolute URI, ``False`` otherwise. + :rtype: bool + """ + return bool(misc.ABSOLUTE_URI_MATCHER.match(self.unsplit())) + + def is_valid(self, **kwargs): + """Determine if the URI is valid. + + .. deprecated:: 1.1.0 + + Use the :class:`~rfc3986.validators.Validator` object instead. + + :param bool require_scheme: Set to ``True`` if you wish to require the + presence of the scheme component. + :param bool require_authority: Set to ``True`` if you wish to require + the presence of the authority component. + :param bool require_path: Set to ``True`` if you wish to require the + presence of the path component. + :param bool require_query: Set to ``True`` if you wish to require the + presence of the query component. + :param bool require_fragment: Set to ``True`` if you wish to require + the presence of the fragment component. + :returns: ``True`` if the URI is valid. ``False`` otherwise. + :rtype: bool + """ + warnings.warn("Please use rfc3986.validators.Validator instead. " + "This method will be eventually removed.", + DeprecationWarning) + validators = [ + (self.scheme_is_valid, kwargs.get('require_scheme', False)), + (self.authority_is_valid, kwargs.get('require_authority', False)), + (self.path_is_valid, kwargs.get('require_path', False)), + (self.query_is_valid, kwargs.get('require_query', False)), + (self.fragment_is_valid, kwargs.get('require_fragment', False)), + ] + return all(v(r) for v, r in validators) + + def authority_is_valid(self, require=False): + """Determine if the authority component is valid. + + .. deprecated:: 1.1.0 + + Use the :class:`~rfc3986.validators.Validator` object instead. + + :param bool require: + Set to ``True`` to require the presence of this component. + :returns: + ``True`` if the authority is valid. ``False`` otherwise. + :rtype: + bool + """ + warnings.warn("Please use rfc3986.validators.Validator instead. " + "This method will be eventually removed.", + DeprecationWarning) + try: + self.authority_info() + except exc.InvalidAuthority: + return False + + return validators.authority_is_valid( + self.authority, + host=self.host, + require=require, + ) + + def scheme_is_valid(self, require=False): + """Determine if the scheme component is valid. + + .. deprecated:: 1.1.0 + + Use the :class:`~rfc3986.validators.Validator` object instead. + + :param str require: Set to ``True`` to require the presence of this + component. + :returns: ``True`` if the scheme is valid. ``False`` otherwise. + :rtype: bool + """ + warnings.warn("Please use rfc3986.validators.Validator instead. " + "This method will be eventually removed.", + DeprecationWarning) + return validators.scheme_is_valid(self.scheme, require) + + def path_is_valid(self, require=False): + """Determine if the path component is valid. + + .. deprecated:: 1.1.0 + + Use the :class:`~rfc3986.validators.Validator` object instead. + + :param str require: Set to ``True`` to require the presence of this + component. + :returns: ``True`` if the path is valid. ``False`` otherwise. + :rtype: bool + """ + warnings.warn("Please use rfc3986.validators.Validator instead. " + "This method will be eventually removed.", + DeprecationWarning) + return validators.path_is_valid(self.path, require) + + def query_is_valid(self, require=False): + """Determine if the query component is valid. + + .. deprecated:: 1.1.0 + + Use the :class:`~rfc3986.validators.Validator` object instead. + + :param str require: Set to ``True`` to require the presence of this + component. + :returns: ``True`` if the query is valid. ``False`` otherwise. + :rtype: bool + """ + warnings.warn("Please use rfc3986.validators.Validator instead. " + "This method will be eventually removed.", + DeprecationWarning) + return validators.query_is_valid(self.query, require) + + def fragment_is_valid(self, require=False): + """Determine if the fragment component is valid. + + .. deprecated:: 1.1.0 + + Use the Validator object instead. + + :param str require: Set to ``True`` to require the presence of this + component. + :returns: ``True`` if the fragment is valid. ``False`` otherwise. + :rtype: bool + """ + warnings.warn("Please use rfc3986.validators.Validator instead. " + "This method will be eventually removed.", + DeprecationWarning) + return validators.fragment_is_valid(self.fragment, require) + + def normalized_equality(self, other_ref): + """Compare this URIReference to another URIReference. + + :param URIReference other_ref: (required), The reference with which + we're comparing. + :returns: ``True`` if the references are equal, ``False`` otherwise. + :rtype: bool + """ + return tuple(self.normalize()) == tuple(other_ref.normalize()) + + def resolve_with(self, base_uri, strict=False): + """Use an absolute URI Reference to resolve this relative reference. + + Assuming this is a relative reference that you would like to resolve, + use the provided base URI to resolve it. + + See http://tools.ietf.org/html/rfc3986#section-5 for more information. + + :param base_uri: Either a string or URIReference. It must be an + absolute URI or it will raise an exception. + :returns: A new URIReference which is the result of resolving this + reference using ``base_uri``. + :rtype: :class:`URIReference` + :raises rfc3986.exceptions.ResolutionError: + If the ``base_uri`` is not an absolute URI. + """ + if not isinstance(base_uri, URIMixin): + base_uri = type(self).from_string(base_uri) + + if not base_uri.is_absolute(): + raise exc.ResolutionError(base_uri) + + # This is optional per + # http://tools.ietf.org/html/rfc3986#section-5.2.1 + base_uri = base_uri.normalize() + + # The reference we're resolving + resolving = self + + if not strict and resolving.scheme == base_uri.scheme: + resolving = resolving.copy_with(scheme=None) + + # http://tools.ietf.org/html/rfc3986#page-32 + if resolving.scheme is not None: + target = resolving.copy_with( + path=normalizers.normalize_path(resolving.path) + ) + else: + if resolving.authority is not None: + target = resolving.copy_with( + scheme=base_uri.scheme, + path=normalizers.normalize_path(resolving.path) + ) + else: + if resolving.path is None: + if resolving.query is not None: + query = resolving.query + else: + query = base_uri.query + target = resolving.copy_with( + scheme=base_uri.scheme, + authority=base_uri.authority, + path=base_uri.path, + query=query + ) + else: + if resolving.path.startswith('/'): + path = normalizers.normalize_path(resolving.path) + else: + path = normalizers.normalize_path( + misc.merge_paths(base_uri, resolving.path) + ) + target = resolving.copy_with( + scheme=base_uri.scheme, + authority=base_uri.authority, + path=path, + query=resolving.query + ) + return target + + def unsplit(self): + """Create a URI string from the components. + + :returns: The URI Reference reconstituted as a string. + :rtype: str + """ + # See http://tools.ietf.org/html/rfc3986#section-5.3 + result_list = [] + if self.scheme: + result_list.extend([self.scheme, ':']) + if self.authority: + result_list.extend(['//', self.authority]) + if self.path: + result_list.append(self.path) + if self.query is not None: + result_list.extend(['?', self.query]) + if self.fragment is not None: + result_list.extend(['#', self.fragment]) + return ''.join(result_list) + + def copy_with(self, scheme=misc.UseExisting, authority=misc.UseExisting, + path=misc.UseExisting, query=misc.UseExisting, + fragment=misc.UseExisting): + """Create a copy of this reference with the new components. + + :param str scheme: + (optional) The scheme to use for the new reference. + :param str authority: + (optional) The authority to use for the new reference. + :param str path: + (optional) The path to use for the new reference. + :param str query: + (optional) The query to use for the new reference. + :param str fragment: + (optional) The fragment to use for the new reference. + :returns: + New URIReference with provided components. + :rtype: + URIReference + """ + attributes = { + 'scheme': scheme, + 'authority': authority, + 'path': path, + 'query': query, + 'fragment': fragment, + } + for key, value in list(attributes.items()): + if value is misc.UseExisting: + del attributes[key] + uri = self._replace(**attributes) + uri.encoding = self.encoding + return uri diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/abnf_regexp.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/abnf_regexp.py new file mode 100644 index 0000000..24c9c3d --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/abnf_regexp.py @@ -0,0 +1,267 @@ +# -*- coding: utf-8 -*- +# 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. +"""Module for the regular expressions crafted from ABNF.""" + +import sys + +# https://tools.ietf.org/html/rfc3986#page-13 +GEN_DELIMS = GENERIC_DELIMITERS = ":/?#[]@" +GENERIC_DELIMITERS_SET = set(GENERIC_DELIMITERS) +# https://tools.ietf.org/html/rfc3986#page-13 +SUB_DELIMS = SUB_DELIMITERS = "!$&'()*+,;=" +SUB_DELIMITERS_SET = set(SUB_DELIMITERS) +# Escape the '*' for use in regular expressions +SUB_DELIMITERS_RE = r"!$&'()\*+,;=" +RESERVED_CHARS_SET = GENERIC_DELIMITERS_SET.union(SUB_DELIMITERS_SET) +ALPHA = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz' +DIGIT = '0123456789' +# https://tools.ietf.org/html/rfc3986#section-2.3 +UNRESERVED = UNRESERVED_CHARS = ALPHA + DIGIT + r'._!-' +UNRESERVED_CHARS_SET = set(UNRESERVED_CHARS) +NON_PCT_ENCODED_SET = RESERVED_CHARS_SET.union(UNRESERVED_CHARS_SET) +# We need to escape the '-' in this case: +UNRESERVED_RE = r'A-Za-z0-9._~\-' + +# Percent encoded character values +PERCENT_ENCODED = PCT_ENCODED = '%[A-Fa-f0-9]{2}' +PCHAR = '([' + UNRESERVED_RE + SUB_DELIMITERS_RE + ':@]|%s)' % PCT_ENCODED + +# NOTE(sigmavirus24): We're going to use more strict regular expressions +# than appear in Appendix B for scheme. This will prevent over-eager +# consuming of items that aren't schemes. +SCHEME_RE = '[a-zA-Z][a-zA-Z0-9+.-]*' +_AUTHORITY_RE = '[^/?#]*' +_PATH_RE = '[^?#]*' +_QUERY_RE = '[^#]*' +_FRAGMENT_RE = '.*' + +# Extracted from http://tools.ietf.org/html/rfc3986#appendix-B +COMPONENT_PATTERN_DICT = { + 'scheme': SCHEME_RE, + 'authority': _AUTHORITY_RE, + 'path': _PATH_RE, + 'query': _QUERY_RE, + 'fragment': _FRAGMENT_RE, +} + +# See http://tools.ietf.org/html/rfc3986#appendix-B +# In this case, we name each of the important matches so we can use +# SRE_Match#groupdict to parse the values out if we so choose. This is also +# modified to ignore other matches that are not important to the parsing of +# the reference so we can also simply use SRE_Match#groups. +URL_PARSING_RE = ( + r'(?:(?P<scheme>{scheme}):)?(?://(?P<authority>{authority}))?' + r'(?P<path>{path})(?:\?(?P<query>{query}))?' + r'(?:#(?P<fragment>{fragment}))?' +).format(**COMPONENT_PATTERN_DICT) + + +# ######################### +# Authority Matcher Section +# ######################### + +# Host patterns, see: http://tools.ietf.org/html/rfc3986#section-3.2.2 +# The pattern for a regular name, e.g., www.google.com, api.github.com +REGULAR_NAME_RE = REG_NAME = '((?:{0}|[{1}])*)'.format( + '%[0-9A-Fa-f]{2}', SUB_DELIMITERS_RE + UNRESERVED_RE +) +# The pattern for an IPv4 address, e.g., 192.168.255.255, 127.0.0.1, +IPv4_RE = r'([0-9]{1,3}\.){3}[0-9]{1,3}' +# Hexadecimal characters used in each piece of an IPv6 address +HEXDIG_RE = '[0-9A-Fa-f]{1,4}' +# Least-significant 32 bits of an IPv6 address +LS32_RE = '({hex}:{hex}|{ipv4})'.format(hex=HEXDIG_RE, ipv4=IPv4_RE) +# Substitutions into the following patterns for IPv6 patterns defined +# http://tools.ietf.org/html/rfc3986#page-20 +_subs = {'hex': HEXDIG_RE, 'ls32': LS32_RE} + +# Below: h16 = hexdig, see: https://tools.ietf.org/html/rfc5234 for details +# about ABNF (Augmented Backus-Naur Form) use in the comments +variations = [ + # 6( h16 ":" ) ls32 + '(%(hex)s:){6}%(ls32)s' % _subs, + # "::" 5( h16 ":" ) ls32 + '::(%(hex)s:){5}%(ls32)s' % _subs, + # [ h16 ] "::" 4( h16 ":" ) ls32 + '(%(hex)s)?::(%(hex)s:){4}%(ls32)s' % _subs, + # [ *1( h16 ":" ) h16 ] "::" 3( h16 ":" ) ls32 + '((%(hex)s:)?%(hex)s)?::(%(hex)s:){3}%(ls32)s' % _subs, + # [ *2( h16 ":" ) h16 ] "::" 2( h16 ":" ) ls32 + '((%(hex)s:){0,2}%(hex)s)?::(%(hex)s:){2}%(ls32)s' % _subs, + # [ *3( h16 ":" ) h16 ] "::" h16 ":" ls32 + '((%(hex)s:){0,3}%(hex)s)?::%(hex)s:%(ls32)s' % _subs, + # [ *4( h16 ":" ) h16 ] "::" ls32 + '((%(hex)s:){0,4}%(hex)s)?::%(ls32)s' % _subs, + # [ *5( h16 ":" ) h16 ] "::" h16 + '((%(hex)s:){0,5}%(hex)s)?::%(hex)s' % _subs, + # [ *6( h16 ":" ) h16 ] "::" + '((%(hex)s:){0,6}%(hex)s)?::' % _subs, +] + +IPv6_RE = '(({0})|({1})|({2})|({3})|({4})|({5})|({6})|({7})|({8}))'.format( + *variations +) + +IPv_FUTURE_RE = r'v[0-9A-Fa-f]+\.[%s]+' % ( + UNRESERVED_RE + SUB_DELIMITERS_RE + ':' +) + +# RFC 6874 Zone ID ABNF +ZONE_ID = '(?:[' + UNRESERVED_RE + ']|' + PCT_ENCODED + ')+' + +IPv6_ADDRZ_RFC4007_RE = IPv6_RE + '(?:(?:%25|%)' + ZONE_ID + ')?' +IPv6_ADDRZ_RE = IPv6_RE + '(?:%25' + ZONE_ID + ')?' + +IP_LITERAL_RE = r'\[({0}|{1})\]'.format( + IPv6_ADDRZ_RFC4007_RE, + IPv_FUTURE_RE, +) + +# Pattern for matching the host piece of the authority +HOST_RE = HOST_PATTERN = '({0}|{1}|{2})'.format( + REG_NAME, + IPv4_RE, + IP_LITERAL_RE, +) +USERINFO_RE = '^([' + UNRESERVED_RE + SUB_DELIMITERS_RE + ':]|%s)+' % ( + PCT_ENCODED +) +PORT_RE = '[0-9]{1,5}' + +# #################### +# Path Matcher Section +# #################### + +# See http://tools.ietf.org/html/rfc3986#section-3.3 for more information +# about the path patterns defined below. +segments = { + 'segment': PCHAR + '*', + # Non-zero length segment + 'segment-nz': PCHAR + '+', + # Non-zero length segment without ":" + 'segment-nz-nc': PCHAR.replace(':', '') + '+' +} + +# Path types taken from Section 3.3 (linked above) +PATH_EMPTY = '^$' +PATH_ROOTLESS = '%(segment-nz)s(/%(segment)s)*' % segments +PATH_NOSCHEME = '%(segment-nz-nc)s(/%(segment)s)*' % segments +PATH_ABSOLUTE = '/(%s)?' % PATH_ROOTLESS +PATH_ABEMPTY = '(/%(segment)s)*' % segments +PATH_RE = '^(%s|%s|%s|%s|%s)$' % ( + PATH_ABEMPTY, PATH_ABSOLUTE, PATH_NOSCHEME, PATH_ROOTLESS, PATH_EMPTY +) + +FRAGMENT_RE = QUERY_RE = ( + '^([/?:@' + UNRESERVED_RE + SUB_DELIMITERS_RE + ']|%s)*$' % PCT_ENCODED +) + +# ########################## +# Relative reference matcher +# ########################## + +# See http://tools.ietf.org/html/rfc3986#section-4.2 for details +RELATIVE_PART_RE = '(//%s%s|%s|%s|%s)' % ( + COMPONENT_PATTERN_DICT['authority'], + PATH_ABEMPTY, + PATH_ABSOLUTE, + PATH_NOSCHEME, + PATH_EMPTY, +) + +# See http://tools.ietf.org/html/rfc3986#section-3 for definition +HIER_PART_RE = '(//%s%s|%s|%s|%s)' % ( + COMPONENT_PATTERN_DICT['authority'], + PATH_ABEMPTY, + PATH_ABSOLUTE, + PATH_ROOTLESS, + PATH_EMPTY, +) + +# ############### +# IRIs / RFC 3987 +# ############### + +# Only wide-unicode gets the high-ranges of UCSCHAR +if sys.maxunicode > 0xFFFF: # pragma: no cover + IPRIVATE = u'\uE000-\uF8FF\U000F0000-\U000FFFFD\U00100000-\U0010FFFD' + UCSCHAR_RE = ( + u'\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF' + u'\U00010000-\U0001FFFD\U00020000-\U0002FFFD' + u'\U00030000-\U0003FFFD\U00040000-\U0004FFFD' + u'\U00050000-\U0005FFFD\U00060000-\U0006FFFD' + u'\U00070000-\U0007FFFD\U00080000-\U0008FFFD' + u'\U00090000-\U0009FFFD\U000A0000-\U000AFFFD' + u'\U000B0000-\U000BFFFD\U000C0000-\U000CFFFD' + u'\U000D0000-\U000DFFFD\U000E1000-\U000EFFFD' + ) +else: # pragma: no cover + IPRIVATE = u'\uE000-\uF8FF' + UCSCHAR_RE = ( + u'\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF' + ) + +IUNRESERVED_RE = u'A-Za-z0-9\\._~\\-' + UCSCHAR_RE +IPCHAR = u'([' + IUNRESERVED_RE + SUB_DELIMITERS_RE + u':@]|%s)' % PCT_ENCODED + +isegments = { + 'isegment': IPCHAR + u'*', + # Non-zero length segment + 'isegment-nz': IPCHAR + u'+', + # Non-zero length segment without ":" + 'isegment-nz-nc': IPCHAR.replace(':', '') + u'+' +} + +IPATH_ROOTLESS = u'%(isegment-nz)s(/%(isegment)s)*' % isegments +IPATH_NOSCHEME = u'%(isegment-nz-nc)s(/%(isegment)s)*' % isegments +IPATH_ABSOLUTE = u'/(?:%s)?' % IPATH_ROOTLESS +IPATH_ABEMPTY = u'(?:/%(isegment)s)*' % isegments +IPATH_RE = u'^(?:%s|%s|%s|%s|%s)$' % ( + IPATH_ABEMPTY, IPATH_ABSOLUTE, IPATH_NOSCHEME, IPATH_ROOTLESS, PATH_EMPTY +) + +IREGULAR_NAME_RE = IREG_NAME = u'(?:{0}|[{1}])*'.format( + u'%[0-9A-Fa-f]{2}', SUB_DELIMITERS_RE + IUNRESERVED_RE +) + +IHOST_RE = IHOST_PATTERN = u'({0}|{1}|{2})'.format( + IREG_NAME, + IPv4_RE, + IP_LITERAL_RE, +) + +IUSERINFO_RE = u'^(?:[' + IUNRESERVED_RE + SUB_DELIMITERS_RE + u':]|%s)+' % ( + PCT_ENCODED +) + +IFRAGMENT_RE = (u'^(?:[/?:@' + IUNRESERVED_RE + SUB_DELIMITERS_RE + + u']|%s)*$' % PCT_ENCODED) +IQUERY_RE = (u'^(?:[/?:@' + IUNRESERVED_RE + SUB_DELIMITERS_RE + + IPRIVATE + u']|%s)*$' % PCT_ENCODED) + +IRELATIVE_PART_RE = u'(//%s%s|%s|%s|%s)' % ( + COMPONENT_PATTERN_DICT['authority'], + IPATH_ABEMPTY, + IPATH_ABSOLUTE, + IPATH_NOSCHEME, + PATH_EMPTY, +) + +IHIER_PART_RE = u'(//%s%s|%s|%s|%s)' % ( + COMPONENT_PATTERN_DICT['authority'], + IPATH_ABEMPTY, + IPATH_ABSOLUTE, + IPATH_ROOTLESS, + PATH_EMPTY, +) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/api.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/api.py new file mode 100644 index 0000000..ddc4a1c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/api.py @@ -0,0 +1,106 @@ +# -*- coding: utf-8 -*- +# Copyright (c) 2014 Rackspace +# 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. +""" +Module containing the simple and functional API for rfc3986. + +This module defines functions and provides access to the public attributes +and classes of rfc3986. +""" + +from .iri import IRIReference +from .parseresult import ParseResult +from .uri import URIReference + + +def uri_reference(uri, encoding='utf-8'): + """Parse a URI string into a URIReference. + + This is a convenience function. You could achieve the same end by using + ``URIReference.from_string(uri)``. + + :param str uri: The URI which needs to be parsed into a reference. + :param str encoding: The encoding of the string provided + :returns: A parsed URI + :rtype: :class:`URIReference` + """ + return URIReference.from_string(uri, encoding) + + +def iri_reference(iri, encoding='utf-8'): + """Parse a IRI string into an IRIReference. + + This is a convenience function. You could achieve the same end by using + ``IRIReference.from_string(iri)``. + + :param str iri: The IRI which needs to be parsed into a reference. + :param str encoding: The encoding of the string provided + :returns: A parsed IRI + :rtype: :class:`IRIReference` + """ + return IRIReference.from_string(iri, encoding) + + +def is_valid_uri(uri, encoding='utf-8', **kwargs): + """Determine if the URI given is valid. + + This is a convenience function. You could use either + ``uri_reference(uri).is_valid()`` or + ``URIReference.from_string(uri).is_valid()`` to achieve the same result. + + :param str uri: The URI to be validated. + :param str encoding: The encoding of the string provided + :param bool require_scheme: Set to ``True`` if you wish to require the + presence of the scheme component. + :param bool require_authority: Set to ``True`` if you wish to require the + presence of the authority component. + :param bool require_path: Set to ``True`` if you wish to require the + presence of the path component. + :param bool require_query: Set to ``True`` if you wish to require the + presence of the query component. + :param bool require_fragment: Set to ``True`` if you wish to require the + presence of the fragment component. + :returns: ``True`` if the URI is valid, ``False`` otherwise. + :rtype: bool + """ + return URIReference.from_string(uri, encoding).is_valid(**kwargs) + + +def normalize_uri(uri, encoding='utf-8'): + """Normalize the given URI. + + This is a convenience function. You could use either + ``uri_reference(uri).normalize().unsplit()`` or + ``URIReference.from_string(uri).normalize().unsplit()`` instead. + + :param str uri: The URI to be normalized. + :param str encoding: The encoding of the string provided + :returns: The normalized URI. + :rtype: str + """ + normalized_reference = URIReference.from_string(uri, encoding).normalize() + return normalized_reference.unsplit() + + +def urlparse(uri, encoding='utf-8'): + """Parse a given URI and return a ParseResult. + + This is a partial replacement of the standard library's urlparse function. + + :param str uri: The URI to be parsed. + :param str encoding: The encoding of the string provided. + :returns: A parsed URI + :rtype: :class:`~rfc3986.parseresult.ParseResult` + """ + return ParseResult.from_string(uri, encoding, strict=False) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/builder.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/builder.py new file mode 100644 index 0000000..7934279 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/builder.py @@ -0,0 +1,298 @@ +# -*- coding: utf-8 -*- +# Copyright (c) 2017 Ian Stapleton Cordasco +# 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. +"""Module containing the logic for the URIBuilder object.""" +from . import compat +from . import normalizers +from . import uri + + +class URIBuilder(object): + """Object to aid in building up a URI Reference from parts. + + .. note:: + + This object should be instantiated by the user, but it's recommended + that it is not provided with arguments. Instead, use the available + method to populate the fields. + + """ + + def __init__(self, scheme=None, userinfo=None, host=None, port=None, + path=None, query=None, fragment=None): + """Initialize our URI builder. + + :param str scheme: + (optional) + :param str userinfo: + (optional) + :param str host: + (optional) + :param int port: + (optional) + :param str path: + (optional) + :param str query: + (optional) + :param str fragment: + (optional) + """ + self.scheme = scheme + self.userinfo = userinfo + self.host = host + self.port = port + self.path = path + self.query = query + self.fragment = fragment + + def __repr__(self): + """Provide a convenient view of our builder object.""" + formatstr = ('URIBuilder(scheme={b.scheme}, userinfo={b.userinfo}, ' + 'host={b.host}, port={b.port}, path={b.path}, ' + 'query={b.query}, fragment={b.fragment})') + return formatstr.format(b=self) + + def add_scheme(self, scheme): + """Add a scheme to our builder object. + + After normalizing, this will generate a new URIBuilder instance with + the specified scheme and all other attributes the same. + + .. code-block:: python + + >>> URIBuilder().add_scheme('HTTPS') + URIBuilder(scheme='https', userinfo=None, host=None, port=None, + path=None, query=None, fragment=None) + + """ + scheme = normalizers.normalize_scheme(scheme) + return URIBuilder( + scheme=scheme, + userinfo=self.userinfo, + host=self.host, + port=self.port, + path=self.path, + query=self.query, + fragment=self.fragment, + ) + + def add_credentials(self, username, password): + """Add credentials as the userinfo portion of the URI. + + .. code-block:: python + + >>> URIBuilder().add_credentials('root', 's3crete') + URIBuilder(scheme=None, userinfo='root:s3crete', host=None, + port=None, path=None, query=None, fragment=None) + + >>> URIBuilder().add_credentials('root', None) + URIBuilder(scheme=None, userinfo='root', host=None, + port=None, path=None, query=None, fragment=None) + """ + if username is None: + raise ValueError('Username cannot be None') + userinfo = normalizers.normalize_username(username) + + if password is not None: + userinfo = '{}:{}'.format( + userinfo, + normalizers.normalize_password(password), + ) + + return URIBuilder( + scheme=self.scheme, + userinfo=userinfo, + host=self.host, + port=self.port, + path=self.path, + query=self.query, + fragment=self.fragment, + ) + + def add_host(self, host): + """Add hostname to the URI. + + .. code-block:: python + + >>> URIBuilder().add_host('google.com') + URIBuilder(scheme=None, userinfo=None, host='google.com', + port=None, path=None, query=None, fragment=None) + + """ + return URIBuilder( + scheme=self.scheme, + userinfo=self.userinfo, + host=normalizers.normalize_host(host), + port=self.port, + path=self.path, + query=self.query, + fragment=self.fragment, + ) + + def add_port(self, port): + """Add port to the URI. + + .. code-block:: python + + >>> URIBuilder().add_port(80) + URIBuilder(scheme=None, userinfo=None, host=None, port='80', + path=None, query=None, fragment=None) + + >>> URIBuilder().add_port(443) + URIBuilder(scheme=None, userinfo=None, host=None, port='443', + path=None, query=None, fragment=None) + + """ + port_int = int(port) + if port_int < 0: + raise ValueError( + 'ports are not allowed to be negative. You provided {}'.format( + port_int, + ) + ) + if port_int > 65535: + raise ValueError( + 'ports are not allowed to be larger than 65535. ' + 'You provided {}'.format( + port_int, + ) + ) + + return URIBuilder( + scheme=self.scheme, + userinfo=self.userinfo, + host=self.host, + port='{}'.format(port_int), + path=self.path, + query=self.query, + fragment=self.fragment, + ) + + def add_path(self, path): + """Add a path to the URI. + + .. code-block:: python + + >>> URIBuilder().add_path('sigmavirus24/rfc3985') + URIBuilder(scheme=None, userinfo=None, host=None, port=None, + path='/sigmavirus24/rfc3986', query=None, fragment=None) + + >>> URIBuilder().add_path('/checkout.php') + URIBuilder(scheme=None, userinfo=None, host=None, port=None, + path='/checkout.php', query=None, fragment=None) + + """ + if not path.startswith('/'): + path = '/{}'.format(path) + + return URIBuilder( + scheme=self.scheme, + userinfo=self.userinfo, + host=self.host, + port=self.port, + path=normalizers.normalize_path(path), + query=self.query, + fragment=self.fragment, + ) + + def add_query_from(self, query_items): + """Generate and add a query a dictionary or list of tuples. + + .. code-block:: python + + >>> URIBuilder().add_query_from({'a': 'b c'}) + URIBuilder(scheme=None, userinfo=None, host=None, port=None, + path=None, query='a=b+c', fragment=None) + + >>> URIBuilder().add_query_from([('a', 'b c')]) + URIBuilder(scheme=None, userinfo=None, host=None, port=None, + path=None, query='a=b+c', fragment=None) + + """ + query = normalizers.normalize_query(compat.urlencode(query_items)) + + return URIBuilder( + scheme=self.scheme, + userinfo=self.userinfo, + host=self.host, + port=self.port, + path=self.path, + query=query, + fragment=self.fragment, + ) + + def add_query(self, query): + """Add a pre-formated query string to the URI. + + .. code-block:: python + + >>> URIBuilder().add_query('a=b&c=d') + URIBuilder(scheme=None, userinfo=None, host=None, port=None, + path=None, query='a=b&c=d', fragment=None) + + """ + return URIBuilder( + scheme=self.scheme, + userinfo=self.userinfo, + host=self.host, + port=self.port, + path=self.path, + query=normalizers.normalize_query(query), + fragment=self.fragment, + ) + + def add_fragment(self, fragment): + """Add a fragment to the URI. + + .. code-block:: python + + >>> URIBuilder().add_fragment('section-2.6.1') + URIBuilder(scheme=None, userinfo=None, host=None, port=None, + path=None, query=None, fragment='section-2.6.1') + + """ + return URIBuilder( + scheme=self.scheme, + userinfo=self.userinfo, + host=self.host, + port=self.port, + path=self.path, + query=self.query, + fragment=normalizers.normalize_fragment(fragment), + ) + + def finalize(self): + """Create a URIReference from our builder. + + .. code-block:: python + + >>> URIBuilder().add_scheme('https').add_host('github.com' + ... ).add_path('sigmavirus24/rfc3986').finalize().unsplit() + 'https://github.com/sigmavirus24/rfc3986' + + >>> URIBuilder().add_scheme('https').add_host('github.com' + ... ).add_path('sigmavirus24/rfc3986').add_credentials( + ... 'sigmavirus24', 'not-re@l').finalize().unsplit() + 'https://sigmavirus24:not-re%40l@github.com/sigmavirus24/rfc3986' + + """ + return uri.URIReference( + self.scheme, + normalizers.normalize_authority( + (self.userinfo, self.host, self.port) + ), + self.path, + self.query, + self.fragment, + ) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/compat.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/compat.py new file mode 100644 index 0000000..8968c38 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/compat.py @@ -0,0 +1,54 @@ +# -*- coding: utf-8 -*- +# Copyright (c) 2014 Rackspace +# 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. +"""Compatibility module for Python 2 and 3 support.""" +import sys + +try: + from urllib.parse import quote as urlquote +except ImportError: # Python 2.x + from urllib import quote as urlquote + +try: + from urllib.parse import urlencode +except ImportError: # Python 2.x + from urllib import urlencode + +__all__ = ( + 'to_bytes', + 'to_str', + 'urlquote', + 'urlencode', +) + +PY3 = (3, 0) <= sys.version_info < (4, 0) +PY2 = (2, 6) <= sys.version_info < (2, 8) + + +if PY3: + unicode = str # Python 3.x + + +def to_str(b, encoding='utf-8'): + """Ensure that b is text in the specified encoding.""" + if hasattr(b, 'decode') and not isinstance(b, unicode): + b = b.decode(encoding) + return b + + +def to_bytes(s, encoding='utf-8'): + """Ensure that s is converted to bytes from the encoding.""" + if hasattr(s, 'encode') and not isinstance(s, bytes): + s = s.encode(encoding) + return s diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/exceptions.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/exceptions.py new file mode 100644 index 0000000..da8ca7c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/exceptions.py @@ -0,0 +1,118 @@ +# -*- coding: utf-8 -*- +"""Exceptions module for rfc3986.""" + +from . import compat + + +class RFC3986Exception(Exception): + """Base class for all rfc3986 exception classes.""" + + pass + + +class InvalidAuthority(RFC3986Exception): + """Exception when the authority string is invalid.""" + + def __init__(self, authority): + """Initialize the exception with the invalid authority.""" + super(InvalidAuthority, self).__init__( + u"The authority ({0}) is not valid.".format( + compat.to_str(authority))) + + +class InvalidPort(RFC3986Exception): + """Exception when the port is invalid.""" + + def __init__(self, port): + """Initialize the exception with the invalid port.""" + super(InvalidPort, self).__init__( + 'The port ("{0}") is not valid.'.format(port)) + + +class ResolutionError(RFC3986Exception): + """Exception to indicate a failure to resolve a URI.""" + + def __init__(self, uri): + """Initialize the error with the failed URI.""" + super(ResolutionError, self).__init__( + "{0} is not an absolute URI.".format(uri.unsplit())) + + +class ValidationError(RFC3986Exception): + """Exception raised during Validation of a URI.""" + + pass + + +class MissingComponentError(ValidationError): + """Exception raised when a required component is missing.""" + + def __init__(self, uri, *component_names): + """Initialize the error with the missing component name.""" + verb = 'was' + if len(component_names) > 1: + verb = 'were' + + self.uri = uri + self.components = sorted(component_names) + components = ', '.join(self.components) + super(MissingComponentError, self).__init__( + "{} {} required but missing".format(components, verb), + uri, + self.components, + ) + + +class UnpermittedComponentError(ValidationError): + """Exception raised when a component has an unpermitted value.""" + + def __init__(self, component_name, component_value, allowed_values): + """Initialize the error with the unpermitted component.""" + super(UnpermittedComponentError, self).__init__( + "{} was required to be one of {!r} but was {!r}".format( + component_name, list(sorted(allowed_values)), component_value, + ), + component_name, + component_value, + allowed_values, + ) + self.component_name = component_name + self.component_value = component_value + self.allowed_values = allowed_values + + +class PasswordForbidden(ValidationError): + """Exception raised when a URL has a password in the userinfo section.""" + + def __init__(self, uri): + """Initialize the error with the URI that failed validation.""" + unsplit = getattr(uri, 'unsplit', lambda: uri) + super(PasswordForbidden, self).__init__( + '"{}" contained a password when validation forbade it'.format( + unsplit() + ) + ) + self.uri = uri + + +class InvalidComponentsError(ValidationError): + """Exception raised when one or more components are invalid.""" + + def __init__(self, uri, *component_names): + """Initialize the error with the invalid component name(s).""" + verb = 'was' + if len(component_names) > 1: + verb = 'were' + + self.uri = uri + self.components = sorted(component_names) + components = ', '.join(self.components) + super(InvalidComponentsError, self).__init__( + "{} {} found to be invalid".format(components, verb), + uri, + self.components, + ) + + +class MissingDependencyError(RFC3986Exception): + """Exception raised when an IRI is encoded without the 'idna' module.""" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/iri.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/iri.py new file mode 100644 index 0000000..416cae4 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/iri.py @@ -0,0 +1,147 @@ +"""Module containing the implementation of the IRIReference class.""" +# -*- coding: utf-8 -*- +# Copyright (c) 2014 Rackspace +# Copyright (c) 2015 Ian Stapleton Cordasco +# 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. +from collections import namedtuple + +from . import compat +from . import exceptions +from . import misc +from . import normalizers +from . import uri + + +try: + from pip._vendor import idna +except ImportError: # pragma: no cover + idna = None + + +class IRIReference(namedtuple('IRIReference', misc.URI_COMPONENTS), + uri.URIMixin): + """Immutable object representing a parsed IRI Reference. + + Can be encoded into an URIReference object via the procedure + specified in RFC 3987 Section 3.1 + + .. note:: + The IRI submodule is a new interface and may possibly change in + the future. Check for changes to the interface when upgrading. + """ + + slots = () + + def __new__(cls, scheme, authority, path, query, fragment, + encoding='utf-8'): + """Create a new IRIReference.""" + ref = super(IRIReference, cls).__new__( + cls, + scheme or None, + authority or None, + path or None, + query, + fragment) + ref.encoding = encoding + return ref + + def __eq__(self, other): + """Compare this reference to another.""" + other_ref = other + if isinstance(other, tuple): + other_ref = self.__class__(*other) + elif not isinstance(other, IRIReference): + try: + other_ref = self.__class__.from_string(other) + except TypeError: + raise TypeError( + 'Unable to compare {0}() to {1}()'.format( + type(self).__name__, type(other).__name__)) + + # See http://tools.ietf.org/html/rfc3986#section-6.2 + return tuple(self) == tuple(other_ref) + + def _match_subauthority(self): + return misc.ISUBAUTHORITY_MATCHER.match(self.authority) + + @classmethod + def from_string(cls, iri_string, encoding='utf-8'): + """Parse a IRI reference from the given unicode IRI string. + + :param str iri_string: Unicode IRI to be parsed into a reference. + :param str encoding: The encoding of the string provided + :returns: :class:`IRIReference` or subclass thereof + """ + iri_string = compat.to_str(iri_string, encoding) + + split_iri = misc.IRI_MATCHER.match(iri_string).groupdict() + return cls( + split_iri['scheme'], split_iri['authority'], + normalizers.encode_component(split_iri['path'], encoding), + normalizers.encode_component(split_iri['query'], encoding), + normalizers.encode_component(split_iri['fragment'], encoding), + encoding, + ) + + def encode(self, idna_encoder=None): # noqa: C901 + """Encode an IRIReference into a URIReference instance. + + If the ``idna`` module is installed or the ``rfc3986[idna]`` + extra is used then unicode characters in the IRI host + component will be encoded with IDNA2008. + + :param idna_encoder: + Function that encodes each part of the host component + If not given will raise an exception if the IRI + contains a host component. + :rtype: uri.URIReference + :returns: A URI reference + """ + authority = self.authority + if authority: + if idna_encoder is None: + if idna is None: # pragma: no cover + raise exceptions.MissingDependencyError( + "Could not import the 'idna' module " + "and the IRI hostname requires encoding" + ) + + def idna_encoder(name): + if any(ord(c) > 128 for c in name): + try: + return idna.encode(name.lower(), + strict=True, + std3_rules=True) + except idna.IDNAError: + raise exceptions.InvalidAuthority(self.authority) + return name + + authority = "" + if self.host: + authority = ".".join([compat.to_str(idna_encoder(part)) + for part in self.host.split(".")]) + + if self.userinfo is not None: + authority = (normalizers.encode_component( + self.userinfo, self.encoding) + '@' + authority) + + if self.port is not None: + authority += ":" + str(self.port) + + return uri.URIReference(self.scheme, + authority, + path=self.path, + query=self.query, + fragment=self.fragment, + encoding=self.encoding) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/misc.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/misc.py new file mode 100644 index 0000000..b735e04 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/misc.py @@ -0,0 +1,124 @@ +# -*- coding: utf-8 -*- +# Copyright (c) 2014 Rackspace +# 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. +""" +Module containing compiled regular expressions and constants. + +This module contains important constants, patterns, and compiled regular +expressions for parsing and validating URIs and their components. +""" + +import re + +from . import abnf_regexp + +# These are enumerated for the named tuple used as a superclass of +# URIReference +URI_COMPONENTS = ['scheme', 'authority', 'path', 'query', 'fragment'] + +important_characters = { + 'generic_delimiters': abnf_regexp.GENERIC_DELIMITERS, + 'sub_delimiters': abnf_regexp.SUB_DELIMITERS, + # We need to escape the '*' in this case + 're_sub_delimiters': abnf_regexp.SUB_DELIMITERS_RE, + 'unreserved_chars': abnf_regexp.UNRESERVED_CHARS, + # We need to escape the '-' in this case: + 're_unreserved': abnf_regexp.UNRESERVED_RE, +} + +# For details about delimiters and reserved characters, see: +# http://tools.ietf.org/html/rfc3986#section-2.2 +GENERIC_DELIMITERS = abnf_regexp.GENERIC_DELIMITERS_SET +SUB_DELIMITERS = abnf_regexp.SUB_DELIMITERS_SET +RESERVED_CHARS = abnf_regexp.RESERVED_CHARS_SET +# For details about unreserved characters, see: +# http://tools.ietf.org/html/rfc3986#section-2.3 +UNRESERVED_CHARS = abnf_regexp.UNRESERVED_CHARS_SET +NON_PCT_ENCODED = abnf_regexp.NON_PCT_ENCODED_SET + +URI_MATCHER = re.compile(abnf_regexp.URL_PARSING_RE) + +SUBAUTHORITY_MATCHER = re.compile(( + '^(?:(?P<userinfo>{0})@)?' # userinfo + '(?P<host>{1})' # host + ':?(?P<port>{2})?$' # port + ).format(abnf_regexp.USERINFO_RE, + abnf_regexp.HOST_PATTERN, + abnf_regexp.PORT_RE)) + + +HOST_MATCHER = re.compile('^' + abnf_regexp.HOST_RE + '$') +IPv4_MATCHER = re.compile('^' + abnf_regexp.IPv4_RE + '$') +IPv6_MATCHER = re.compile(r'^\[' + abnf_regexp.IPv6_ADDRZ_RFC4007_RE + r'\]$') + +# Used by host validator +IPv6_NO_RFC4007_MATCHER = re.compile(r'^\[%s\]$' % ( + abnf_regexp.IPv6_ADDRZ_RE +)) + +# Matcher used to validate path components +PATH_MATCHER = re.compile(abnf_regexp.PATH_RE) + + +# ################################## +# Query and Fragment Matcher Section +# ################################## + +QUERY_MATCHER = re.compile(abnf_regexp.QUERY_RE) + +FRAGMENT_MATCHER = QUERY_MATCHER + +# Scheme validation, see: http://tools.ietf.org/html/rfc3986#section-3.1 +SCHEME_MATCHER = re.compile('^{0}$'.format(abnf_regexp.SCHEME_RE)) + +RELATIVE_REF_MATCHER = re.compile(r'^%s(\?%s)?(#%s)?$' % ( + abnf_regexp.RELATIVE_PART_RE, + abnf_regexp.QUERY_RE, + abnf_regexp.FRAGMENT_RE, +)) + +# See http://tools.ietf.org/html/rfc3986#section-4.3 +ABSOLUTE_URI_MATCHER = re.compile(r'^%s:%s(\?%s)?$' % ( + abnf_regexp.COMPONENT_PATTERN_DICT['scheme'], + abnf_regexp.HIER_PART_RE, + abnf_regexp.QUERY_RE[1:-1], +)) + +# ############### +# IRIs / RFC 3987 +# ############### + +IRI_MATCHER = re.compile(abnf_regexp.URL_PARSING_RE, re.UNICODE) + +ISUBAUTHORITY_MATCHER = re.compile(( + u'^(?:(?P<userinfo>{0})@)?' # iuserinfo + u'(?P<host>{1})' # ihost + u':?(?P<port>{2})?$' # port + ).format(abnf_regexp.IUSERINFO_RE, + abnf_regexp.IHOST_RE, + abnf_regexp.PORT_RE), re.UNICODE) + + +# Path merger as defined in http://tools.ietf.org/html/rfc3986#section-5.2.3 +def merge_paths(base_uri, relative_path): + """Merge a base URI's path with a relative URI's path.""" + if base_uri.path is None and base_uri.authority is not None: + return '/' + relative_path + else: + path = base_uri.path or '' + index = path.rfind('/') + return path[:index] + '/' + relative_path + + +UseExisting = object() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/normalizers.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/normalizers.py new file mode 100644 index 0000000..2eb1bb3 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/normalizers.py @@ -0,0 +1,167 @@ +# -*- coding: utf-8 -*- +# Copyright (c) 2014 Rackspace +# 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. +"""Module with functions to normalize components.""" +import re + +from . import compat +from . import misc + + +def normalize_scheme(scheme): + """Normalize the scheme component.""" + return scheme.lower() + + +def normalize_authority(authority): + """Normalize an authority tuple to a string.""" + userinfo, host, port = authority + result = '' + if userinfo: + result += normalize_percent_characters(userinfo) + '@' + if host: + result += normalize_host(host) + if port: + result += ':' + port + return result + + +def normalize_username(username): + """Normalize a username to make it safe to include in userinfo.""" + return compat.urlquote(username) + + +def normalize_password(password): + """Normalize a password to make safe for userinfo.""" + return compat.urlquote(password) + + +def normalize_host(host): + """Normalize a host string.""" + if misc.IPv6_MATCHER.match(host): + percent = host.find('%') + if percent != -1: + percent_25 = host.find('%25') + + # Replace RFC 4007 IPv6 Zone ID delimiter '%' with '%25' + # from RFC 6874. If the host is '[<IPv6 addr>%25]' then we + # assume RFC 4007 and normalize to '[<IPV6 addr>%2525]' + if percent_25 == -1 or percent < percent_25 or \ + (percent == percent_25 and percent_25 == len(host) - 4): + host = host.replace('%', '%25', 1) + + # Don't normalize the casing of the Zone ID + return host[:percent].lower() + host[percent:] + + return host.lower() + + +def normalize_path(path): + """Normalize the path string.""" + if not path: + return path + + path = normalize_percent_characters(path) + return remove_dot_segments(path) + + +def normalize_query(query): + """Normalize the query string.""" + if not query: + return query + return normalize_percent_characters(query) + + +def normalize_fragment(fragment): + """Normalize the fragment string.""" + if not fragment: + return fragment + return normalize_percent_characters(fragment) + + +PERCENT_MATCHER = re.compile('%[A-Fa-f0-9]{2}') + + +def normalize_percent_characters(s): + """All percent characters should be upper-cased. + + For example, ``"%3afoo%DF%ab"`` should be turned into ``"%3Afoo%DF%AB"``. + """ + matches = set(PERCENT_MATCHER.findall(s)) + for m in matches: + if not m.isupper(): + s = s.replace(m, m.upper()) + return s + + +def remove_dot_segments(s): + """Remove dot segments from the string. + + See also Section 5.2.4 of :rfc:`3986`. + """ + # See http://tools.ietf.org/html/rfc3986#section-5.2.4 for pseudo-code + segments = s.split('/') # Turn the path into a list of segments + output = [] # Initialize the variable to use to store output + + for segment in segments: + # '.' is the current directory, so ignore it, it is superfluous + if segment == '.': + continue + # Anything other than '..', should be appended to the output + elif segment != '..': + output.append(segment) + # In this case segment == '..', if we can, we should pop the last + # element + elif output: + output.pop() + + # If the path starts with '/' and the output is empty or the first string + # is non-empty + if s.startswith('/') and (not output or output[0]): + output.insert(0, '') + + # If the path starts with '/.' or '/..' ensure we add one more empty + # string to add a trailing '/' + if s.endswith(('/.', '/..')): + output.append('') + + return '/'.join(output) + + +def encode_component(uri_component, encoding): + """Encode the specific component in the provided encoding.""" + if uri_component is None: + return uri_component + + # Try to see if the component we're encoding is already percent-encoded + # so we can skip all '%' characters but still encode all others. + percent_encodings = len(PERCENT_MATCHER.findall( + compat.to_str(uri_component, encoding))) + + uri_bytes = compat.to_bytes(uri_component, encoding) + is_percent_encoded = percent_encodings == uri_bytes.count(b'%') + + encoded_uri = bytearray() + + for i in range(0, len(uri_bytes)): + # Will return a single character bytestring on both Python 2 & 3 + byte = uri_bytes[i:i+1] + byte_ord = ord(byte) + if ((is_percent_encoded and byte == b'%') + or (byte_ord < 128 and byte.decode() in misc.NON_PCT_ENCODED)): + encoded_uri.extend(byte) + continue + encoded_uri.extend('%{0:02x}'.format(byte_ord).encode().upper()) + + return encoded_uri.decode(encoding) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/parseresult.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/parseresult.py new file mode 100644 index 0000000..0a73456 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/parseresult.py @@ -0,0 +1,385 @@ +# -*- coding: utf-8 -*- +# Copyright (c) 2015 Ian Stapleton Cordasco +# 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. +"""Module containing the urlparse compatibility logic.""" +from collections import namedtuple + +from . import compat +from . import exceptions +from . import misc +from . import normalizers +from . import uri + +__all__ = ('ParseResult', 'ParseResultBytes') + +PARSED_COMPONENTS = ('scheme', 'userinfo', 'host', 'port', 'path', 'query', + 'fragment') + + +class ParseResultMixin(object): + def _generate_authority(self, attributes): + # I swear I did not align the comparisons below. That's just how they + # happened to align based on pep8 and attribute lengths. + userinfo, host, port = (attributes[p] + for p in ('userinfo', 'host', 'port')) + if (self.userinfo != userinfo or + self.host != host or + self.port != port): + if port: + port = '{0}'.format(port) + return normalizers.normalize_authority( + (compat.to_str(userinfo, self.encoding), + compat.to_str(host, self.encoding), + port) + ) + return self.authority + + def geturl(self): + """Shim to match the standard library method.""" + return self.unsplit() + + @property + def hostname(self): + """Shim to match the standard library.""" + return self.host + + @property + def netloc(self): + """Shim to match the standard library.""" + return self.authority + + @property + def params(self): + """Shim to match the standard library.""" + return self.query + + +class ParseResult(namedtuple('ParseResult', PARSED_COMPONENTS), + ParseResultMixin): + """Implementation of urlparse compatibility class. + + This uses the URIReference logic to handle compatibility with the + urlparse.ParseResult class. + """ + + slots = () + + def __new__(cls, scheme, userinfo, host, port, path, query, fragment, + uri_ref, encoding='utf-8'): + """Create a new ParseResult.""" + parse_result = super(ParseResult, cls).__new__( + cls, + scheme or None, + userinfo or None, + host, + port or None, + path or None, + query, + fragment) + parse_result.encoding = encoding + parse_result.reference = uri_ref + return parse_result + + @classmethod + def from_parts(cls, scheme=None, userinfo=None, host=None, port=None, + path=None, query=None, fragment=None, encoding='utf-8'): + """Create a ParseResult instance from its parts.""" + authority = '' + if userinfo is not None: + authority += userinfo + '@' + if host is not None: + authority += host + if port is not None: + authority += ':{0}'.format(port) + uri_ref = uri.URIReference(scheme=scheme, + authority=authority, + path=path, + query=query, + fragment=fragment, + encoding=encoding).normalize() + userinfo, host, port = authority_from(uri_ref, strict=True) + return cls(scheme=uri_ref.scheme, + userinfo=userinfo, + host=host, + port=port, + path=uri_ref.path, + query=uri_ref.query, + fragment=uri_ref.fragment, + uri_ref=uri_ref, + encoding=encoding) + + @classmethod + def from_string(cls, uri_string, encoding='utf-8', strict=True, + lazy_normalize=True): + """Parse a URI from the given unicode URI string. + + :param str uri_string: Unicode URI to be parsed into a reference. + :param str encoding: The encoding of the string provided + :param bool strict: Parse strictly according to :rfc:`3986` if True. + If False, parse similarly to the standard library's urlparse + function. + :returns: :class:`ParseResult` or subclass thereof + """ + reference = uri.URIReference.from_string(uri_string, encoding) + if not lazy_normalize: + reference = reference.normalize() + userinfo, host, port = authority_from(reference, strict) + + return cls(scheme=reference.scheme, + userinfo=userinfo, + host=host, + port=port, + path=reference.path, + query=reference.query, + fragment=reference.fragment, + uri_ref=reference, + encoding=encoding) + + @property + def authority(self): + """Return the normalized authority.""" + return self.reference.authority + + def copy_with(self, scheme=misc.UseExisting, userinfo=misc.UseExisting, + host=misc.UseExisting, port=misc.UseExisting, + path=misc.UseExisting, query=misc.UseExisting, + fragment=misc.UseExisting): + """Create a copy of this instance replacing with specified parts.""" + attributes = zip(PARSED_COMPONENTS, + (scheme, userinfo, host, port, path, query, fragment)) + attrs_dict = {} + for name, value in attributes: + if value is misc.UseExisting: + value = getattr(self, name) + attrs_dict[name] = value + authority = self._generate_authority(attrs_dict) + ref = self.reference.copy_with(scheme=attrs_dict['scheme'], + authority=authority, + path=attrs_dict['path'], + query=attrs_dict['query'], + fragment=attrs_dict['fragment']) + return ParseResult(uri_ref=ref, encoding=self.encoding, **attrs_dict) + + def encode(self, encoding=None): + """Convert to an instance of ParseResultBytes.""" + encoding = encoding or self.encoding + attrs = dict( + zip(PARSED_COMPONENTS, + (attr.encode(encoding) if hasattr(attr, 'encode') else attr + for attr in self))) + return ParseResultBytes( + uri_ref=self.reference, + encoding=encoding, + **attrs + ) + + def unsplit(self, use_idna=False): + """Create a URI string from the components. + + :returns: The parsed URI reconstituted as a string. + :rtype: str + """ + parse_result = self + if use_idna and self.host: + hostbytes = self.host.encode('idna') + host = hostbytes.decode(self.encoding) + parse_result = self.copy_with(host=host) + return parse_result.reference.unsplit() + + +class ParseResultBytes(namedtuple('ParseResultBytes', PARSED_COMPONENTS), + ParseResultMixin): + """Compatibility shim for the urlparse.ParseResultBytes object.""" + + def __new__(cls, scheme, userinfo, host, port, path, query, fragment, + uri_ref, encoding='utf-8', lazy_normalize=True): + """Create a new ParseResultBytes instance.""" + parse_result = super(ParseResultBytes, cls).__new__( + cls, + scheme or None, + userinfo or None, + host, + port or None, + path or None, + query or None, + fragment or None) + parse_result.encoding = encoding + parse_result.reference = uri_ref + parse_result.lazy_normalize = lazy_normalize + return parse_result + + @classmethod + def from_parts(cls, scheme=None, userinfo=None, host=None, port=None, + path=None, query=None, fragment=None, encoding='utf-8', + lazy_normalize=True): + """Create a ParseResult instance from its parts.""" + authority = '' + if userinfo is not None: + authority += userinfo + '@' + if host is not None: + authority += host + if port is not None: + authority += ':{0}'.format(int(port)) + uri_ref = uri.URIReference(scheme=scheme, + authority=authority, + path=path, + query=query, + fragment=fragment, + encoding=encoding) + if not lazy_normalize: + uri_ref = uri_ref.normalize() + to_bytes = compat.to_bytes + userinfo, host, port = authority_from(uri_ref, strict=True) + return cls(scheme=to_bytes(scheme, encoding), + userinfo=to_bytes(userinfo, encoding), + host=to_bytes(host, encoding), + port=port, + path=to_bytes(path, encoding), + query=to_bytes(query, encoding), + fragment=to_bytes(fragment, encoding), + uri_ref=uri_ref, + encoding=encoding, + lazy_normalize=lazy_normalize) + + @classmethod + def from_string(cls, uri_string, encoding='utf-8', strict=True, + lazy_normalize=True): + """Parse a URI from the given unicode URI string. + + :param str uri_string: Unicode URI to be parsed into a reference. + :param str encoding: The encoding of the string provided + :param bool strict: Parse strictly according to :rfc:`3986` if True. + If False, parse similarly to the standard library's urlparse + function. + :returns: :class:`ParseResultBytes` or subclass thereof + """ + reference = uri.URIReference.from_string(uri_string, encoding) + if not lazy_normalize: + reference = reference.normalize() + userinfo, host, port = authority_from(reference, strict) + + to_bytes = compat.to_bytes + return cls(scheme=to_bytes(reference.scheme, encoding), + userinfo=to_bytes(userinfo, encoding), + host=to_bytes(host, encoding), + port=port, + path=to_bytes(reference.path, encoding), + query=to_bytes(reference.query, encoding), + fragment=to_bytes(reference.fragment, encoding), + uri_ref=reference, + encoding=encoding, + lazy_normalize=lazy_normalize) + + @property + def authority(self): + """Return the normalized authority.""" + return self.reference.authority.encode(self.encoding) + + def copy_with(self, scheme=misc.UseExisting, userinfo=misc.UseExisting, + host=misc.UseExisting, port=misc.UseExisting, + path=misc.UseExisting, query=misc.UseExisting, + fragment=misc.UseExisting, lazy_normalize=True): + """Create a copy of this instance replacing with specified parts.""" + attributes = zip(PARSED_COMPONENTS, + (scheme, userinfo, host, port, path, query, fragment)) + attrs_dict = {} + for name, value in attributes: + if value is misc.UseExisting: + value = getattr(self, name) + if not isinstance(value, bytes) and hasattr(value, 'encode'): + value = value.encode(self.encoding) + attrs_dict[name] = value + authority = self._generate_authority(attrs_dict) + to_str = compat.to_str + ref = self.reference.copy_with( + scheme=to_str(attrs_dict['scheme'], self.encoding), + authority=to_str(authority, self.encoding), + path=to_str(attrs_dict['path'], self.encoding), + query=to_str(attrs_dict['query'], self.encoding), + fragment=to_str(attrs_dict['fragment'], self.encoding) + ) + if not lazy_normalize: + ref = ref.normalize() + return ParseResultBytes( + uri_ref=ref, + encoding=self.encoding, + lazy_normalize=lazy_normalize, + **attrs_dict + ) + + def unsplit(self, use_idna=False): + """Create a URI bytes object from the components. + + :returns: The parsed URI reconstituted as a string. + :rtype: bytes + """ + parse_result = self + if use_idna and self.host: + # self.host is bytes, to encode to idna, we need to decode it + # first + host = self.host.decode(self.encoding) + hostbytes = host.encode('idna') + parse_result = self.copy_with(host=hostbytes) + if self.lazy_normalize: + parse_result = parse_result.copy_with(lazy_normalize=False) + uri = parse_result.reference.unsplit() + return uri.encode(self.encoding) + + +def split_authority(authority): + # Initialize our expected return values + userinfo = host = port = None + # Initialize an extra var we may need to use + extra_host = None + # Set-up rest in case there is no userinfo portion + rest = authority + + if '@' in authority: + userinfo, rest = authority.rsplit('@', 1) + + # Handle IPv6 host addresses + if rest.startswith('['): + host, rest = rest.split(']', 1) + host += ']' + + if ':' in rest: + extra_host, port = rest.split(':', 1) + elif not host and rest: + host = rest + + if extra_host and not host: + host = extra_host + + return userinfo, host, port + + +def authority_from(reference, strict): + try: + subauthority = reference.authority_info() + except exceptions.InvalidAuthority: + if strict: + raise + userinfo, host, port = split_authority(reference.authority) + else: + # Thanks to Richard Barrell for this idea: + # https://twitter.com/0x2ba22e11/status/617338811975139328 + userinfo, host, port = (subauthority.get(p) + for p in ('userinfo', 'host', 'port')) + + if port: + try: + port = int(port) + except ValueError: + raise exceptions.InvalidPort(port) + return userinfo, host, port diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/uri.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/uri.py new file mode 100644 index 0000000..d1d7150 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/uri.py @@ -0,0 +1,153 @@ +"""Module containing the implementation of the URIReference class.""" +# -*- coding: utf-8 -*- +# Copyright (c) 2014 Rackspace +# Copyright (c) 2015 Ian Stapleton Cordasco +# 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. +from collections import namedtuple + +from . import compat +from . import misc +from . import normalizers +from ._mixin import URIMixin + + +class URIReference(namedtuple('URIReference', misc.URI_COMPONENTS), URIMixin): + """Immutable object representing a parsed URI Reference. + + .. note:: + + This class is not intended to be directly instantiated by the user. + + This object exposes attributes for the following components of a + URI: + + - scheme + - authority + - path + - query + - fragment + + .. attribute:: scheme + + The scheme that was parsed for the URI Reference. For example, + ``http``, ``https``, ``smtp``, ``imap``, etc. + + .. attribute:: authority + + Component of the URI that contains the user information, host, + and port sub-components. For example, + ``google.com``, ``127.0.0.1:5000``, ``username@[::1]``, + ``username:password@example.com:443``, etc. + + .. attribute:: path + + The path that was parsed for the given URI Reference. For example, + ``/``, ``/index.php``, etc. + + .. attribute:: query + + The query component for a given URI Reference. For example, ``a=b``, + ``a=b%20c``, ``a=b+c``, ``a=b,c=d,e=%20f``, etc. + + .. attribute:: fragment + + The fragment component of a URI. For example, ``section-3.1``. + + This class also provides extra attributes for easier access to information + like the subcomponents of the authority component. + + .. attribute:: userinfo + + The user information parsed from the authority. + + .. attribute:: host + + The hostname, IPv4, or IPv6 adddres parsed from the authority. + + .. attribute:: port + + The port parsed from the authority. + """ + + slots = () + + def __new__(cls, scheme, authority, path, query, fragment, + encoding='utf-8'): + """Create a new URIReference.""" + ref = super(URIReference, cls).__new__( + cls, + scheme or None, + authority or None, + path or None, + query, + fragment) + ref.encoding = encoding + return ref + + __hash__ = tuple.__hash__ + + def __eq__(self, other): + """Compare this reference to another.""" + other_ref = other + if isinstance(other, tuple): + other_ref = URIReference(*other) + elif not isinstance(other, URIReference): + try: + other_ref = URIReference.from_string(other) + except TypeError: + raise TypeError( + 'Unable to compare URIReference() to {0}()'.format( + type(other).__name__)) + + # See http://tools.ietf.org/html/rfc3986#section-6.2 + naive_equality = tuple(self) == tuple(other_ref) + return naive_equality or self.normalized_equality(other_ref) + + def normalize(self): + """Normalize this reference as described in Section 6.2.2. + + This is not an in-place normalization. Instead this creates a new + URIReference. + + :returns: A new reference object with normalized components. + :rtype: URIReference + """ + # See http://tools.ietf.org/html/rfc3986#section-6.2.2 for logic in + # this method. + return URIReference(normalizers.normalize_scheme(self.scheme or ''), + normalizers.normalize_authority( + (self.userinfo, self.host, self.port)), + normalizers.normalize_path(self.path or ''), + normalizers.normalize_query(self.query), + normalizers.normalize_fragment(self.fragment), + self.encoding) + + @classmethod + def from_string(cls, uri_string, encoding='utf-8'): + """Parse a URI reference from the given unicode URI string. + + :param str uri_string: Unicode URI to be parsed into a reference. + :param str encoding: The encoding of the string provided + :returns: :class:`URIReference` or subclass thereof + """ + uri_string = compat.to_str(uri_string, encoding) + + split_uri = misc.URI_MATCHER.match(uri_string).groupdict() + return cls( + split_uri['scheme'], split_uri['authority'], + normalizers.encode_component(split_uri['path'], encoding), + normalizers.encode_component(split_uri['query'], encoding), + normalizers.encode_component(split_uri['fragment'], encoding), + encoding, + ) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/validators.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/validators.py new file mode 100644 index 0000000..7fc9721 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/rfc3986/validators.py @@ -0,0 +1,450 @@ +# -*- coding: utf-8 -*- +# Copyright (c) 2017 Ian Stapleton Cordasco +# 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. +"""Module containing the validation logic for rfc3986.""" +from . import exceptions +from . import misc +from . import normalizers + + +class Validator(object): + """Object used to configure validation of all objects in rfc3986. + + .. versionadded:: 1.0 + + Example usage:: + + >>> from rfc3986 import api, validators + >>> uri = api.uri_reference('https://github.com/') + >>> validator = validators.Validator().require_presence_of( + ... 'scheme', 'host', 'path', + ... ).allow_schemes( + ... 'http', 'https', + ... ).allow_hosts( + ... '127.0.0.1', 'github.com', + ... ) + >>> validator.validate(uri) + >>> invalid_uri = rfc3986.uri_reference('imap://mail.google.com') + >>> validator.validate(invalid_uri) + Traceback (most recent call last): + ... + rfc3986.exceptions.MissingComponentError: ('path was required but + missing', URIReference(scheme=u'imap', authority=u'mail.google.com', + path=None, query=None, fragment=None), ['path']) + + """ + + COMPONENT_NAMES = frozenset([ + 'scheme', + 'userinfo', + 'host', + 'port', + 'path', + 'query', + 'fragment', + ]) + + def __init__(self): + """Initialize our default validations.""" + self.allowed_schemes = set() + self.allowed_hosts = set() + self.allowed_ports = set() + self.allow_password = True + self.required_components = { + 'scheme': False, + 'userinfo': False, + 'host': False, + 'port': False, + 'path': False, + 'query': False, + 'fragment': False, + } + self.validated_components = self.required_components.copy() + + def allow_schemes(self, *schemes): + """Require the scheme to be one of the provided schemes. + + .. versionadded:: 1.0 + + :param schemes: + Schemes, without ``://`` that are allowed. + :returns: + The validator instance. + :rtype: + Validator + """ + for scheme in schemes: + self.allowed_schemes.add(normalizers.normalize_scheme(scheme)) + return self + + def allow_hosts(self, *hosts): + """Require the host to be one of the provided hosts. + + .. versionadded:: 1.0 + + :param hosts: + Hosts that are allowed. + :returns: + The validator instance. + :rtype: + Validator + """ + for host in hosts: + self.allowed_hosts.add(normalizers.normalize_host(host)) + return self + + def allow_ports(self, *ports): + """Require the port to be one of the provided ports. + + .. versionadded:: 1.0 + + :param ports: + Ports that are allowed. + :returns: + The validator instance. + :rtype: + Validator + """ + for port in ports: + port_int = int(port, base=10) + if 0 <= port_int <= 65535: + self.allowed_ports.add(port) + return self + + def allow_use_of_password(self): + """Allow passwords to be present in the URI. + + .. versionadded:: 1.0 + + :returns: + The validator instance. + :rtype: + Validator + """ + self.allow_password = True + return self + + def forbid_use_of_password(self): + """Prevent passwords from being included in the URI. + + .. versionadded:: 1.0 + + :returns: + The validator instance. + :rtype: + Validator + """ + self.allow_password = False + return self + + def check_validity_of(self, *components): + """Check the validity of the components provided. + + This can be specified repeatedly. + + .. versionadded:: 1.1 + + :param components: + Names of components from :attr:`Validator.COMPONENT_NAMES`. + :returns: + The validator instance. + :rtype: + Validator + """ + components = [c.lower() for c in components] + for component in components: + if component not in self.COMPONENT_NAMES: + raise ValueError( + '"{}" is not a valid component'.format(component) + ) + self.validated_components.update({ + component: True for component in components + }) + return self + + def require_presence_of(self, *components): + """Require the components provided. + + This can be specified repeatedly. + + .. versionadded:: 1.0 + + :param components: + Names of components from :attr:`Validator.COMPONENT_NAMES`. + :returns: + The validator instance. + :rtype: + Validator + """ + components = [c.lower() for c in components] + for component in components: + if component not in self.COMPONENT_NAMES: + raise ValueError( + '"{}" is not a valid component'.format(component) + ) + self.required_components.update({ + component: True for component in components + }) + return self + + def validate(self, uri): + """Check a URI for conditions specified on this validator. + + .. versionadded:: 1.0 + + :param uri: + Parsed URI to validate. + :type uri: + rfc3986.uri.URIReference + :raises MissingComponentError: + When a required component is missing. + :raises UnpermittedComponentError: + When a component is not one of those allowed. + :raises PasswordForbidden: + When a password is present in the userinfo component but is + not permitted by configuration. + :raises InvalidComponentsError: + When a component was found to be invalid. + """ + if not self.allow_password: + check_password(uri) + + required_components = [ + component + for component, required in self.required_components.items() + if required + ] + validated_components = [ + component + for component, required in self.validated_components.items() + if required + ] + if required_components: + ensure_required_components_exist(uri, required_components) + if validated_components: + ensure_components_are_valid(uri, validated_components) + + ensure_one_of(self.allowed_schemes, uri, 'scheme') + ensure_one_of(self.allowed_hosts, uri, 'host') + ensure_one_of(self.allowed_ports, uri, 'port') + + +def check_password(uri): + """Assert that there is no password present in the uri.""" + userinfo = uri.userinfo + if not userinfo: + return + credentials = userinfo.split(':', 1) + if len(credentials) <= 1: + return + raise exceptions.PasswordForbidden(uri) + + +def ensure_one_of(allowed_values, uri, attribute): + """Assert that the uri's attribute is one of the allowed values.""" + value = getattr(uri, attribute) + if value is not None and allowed_values and value not in allowed_values: + raise exceptions.UnpermittedComponentError( + attribute, value, allowed_values, + ) + + +def ensure_required_components_exist(uri, required_components): + """Assert that all required components are present in the URI.""" + missing_components = sorted([ + component + for component in required_components + if getattr(uri, component) is None + ]) + if missing_components: + raise exceptions.MissingComponentError(uri, *missing_components) + + +def is_valid(value, matcher, require): + """Determine if a value is valid based on the provided matcher. + + :param str value: + Value to validate. + :param matcher: + Compiled regular expression to use to validate the value. + :param require: + Whether or not the value is required. + """ + if require: + return (value is not None + and matcher.match(value)) + + # require is False and value is not None + return value is None or matcher.match(value) + + +def authority_is_valid(authority, host=None, require=False): + """Determine if the authority string is valid. + + :param str authority: + The authority to validate. + :param str host: + (optional) The host portion of the authority to validate. + :param bool require: + (optional) Specify if authority must not be None. + :returns: + ``True`` if valid, ``False`` otherwise + :rtype: + bool + """ + validated = is_valid(authority, misc.SUBAUTHORITY_MATCHER, require) + if validated and host is not None: + return host_is_valid(host, require) + return validated + + +def host_is_valid(host, require=False): + """Determine if the host string is valid. + + :param str host: + The host to validate. + :param bool require: + (optional) Specify if host must not be None. + :returns: + ``True`` if valid, ``False`` otherwise + :rtype: + bool + """ + validated = is_valid(host, misc.HOST_MATCHER, require) + if validated and host is not None and misc.IPv4_MATCHER.match(host): + return valid_ipv4_host_address(host) + elif validated and host is not None and misc.IPv6_MATCHER.match(host): + return misc.IPv6_NO_RFC4007_MATCHER.match(host) is not None + return validated + + +def scheme_is_valid(scheme, require=False): + """Determine if the scheme is valid. + + :param str scheme: + The scheme string to validate. + :param bool require: + (optional) Set to ``True`` to require the presence of a scheme. + :returns: + ``True`` if the scheme is valid. ``False`` otherwise. + :rtype: + bool + """ + return is_valid(scheme, misc.SCHEME_MATCHER, require) + + +def path_is_valid(path, require=False): + """Determine if the path component is valid. + + :param str path: + The path string to validate. + :param bool require: + (optional) Set to ``True`` to require the presence of a path. + :returns: + ``True`` if the path is valid. ``False`` otherwise. + :rtype: + bool + """ + return is_valid(path, misc.PATH_MATCHER, require) + + +def query_is_valid(query, require=False): + """Determine if the query component is valid. + + :param str query: + The query string to validate. + :param bool require: + (optional) Set to ``True`` to require the presence of a query. + :returns: + ``True`` if the query is valid. ``False`` otherwise. + :rtype: + bool + """ + return is_valid(query, misc.QUERY_MATCHER, require) + + +def fragment_is_valid(fragment, require=False): + """Determine if the fragment component is valid. + + :param str fragment: + The fragment string to validate. + :param bool require: + (optional) Set to ``True`` to require the presence of a fragment. + :returns: + ``True`` if the fragment is valid. ``False`` otherwise. + :rtype: + bool + """ + return is_valid(fragment, misc.FRAGMENT_MATCHER, require) + + +def valid_ipv4_host_address(host): + """Determine if the given host is a valid IPv4 address.""" + # If the host exists, and it might be IPv4, check each byte in the + # address. + return all([0 <= int(byte, base=10) <= 255 for byte in host.split('.')]) + + +_COMPONENT_VALIDATORS = { + 'scheme': scheme_is_valid, + 'path': path_is_valid, + 'query': query_is_valid, + 'fragment': fragment_is_valid, +} + +_SUBAUTHORITY_VALIDATORS = set(['userinfo', 'host', 'port']) + + +def subauthority_component_is_valid(uri, component): + """Determine if the userinfo, host, and port are valid.""" + try: + subauthority_dict = uri.authority_info() + except exceptions.InvalidAuthority: + return False + + # If we can parse the authority into sub-components and we're not + # validating the port, we can assume it's valid. + if component == 'host': + return host_is_valid(subauthority_dict['host']) + elif component != 'port': + return True + + try: + port = int(subauthority_dict['port']) + except TypeError: + # If the port wasn't provided it'll be None and int(None) raises a + # TypeError + return True + + return (0 <= port <= 65535) + + +def ensure_components_are_valid(uri, validated_components): + """Assert that all components are valid in the URI.""" + invalid_components = set([]) + for component in validated_components: + if component in _SUBAUTHORITY_VALIDATORS: + if not subauthority_component_is_valid(uri, component): + invalid_components.add(component) + # Python's peephole optimizer means that while this continue *is* + # actually executed, coverage.py cannot detect that. See also, + # https://bitbucket.org/ned/coveragepy/issues/198/continue-marked-as-not-covered + continue # nocov: Python 2.7, 3.3, 3.4 + + validator = _COMPONENT_VALIDATORS[component] + if not validator(getattr(uri, component)): + invalid_components.add(component) + + if invalid_components: + raise exceptions.InvalidComponentsError(uri, *invalid_components) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/six.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/six.py new file mode 100644 index 0000000..190c023 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/six.py @@ -0,0 +1,868 @@ +"""Utilities for writing code that runs on Python 2 and 3""" + +# Copyright (c) 2010-2015 Benjamin Peterson +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in all +# copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. + +from __future__ import absolute_import + +import functools +import itertools +import operator +import sys +import types + +__author__ = "Benjamin Peterson <benjamin@python.org>" +__version__ = "1.10.0" + + +# Useful for very coarse version differentiation. +PY2 = sys.version_info[0] == 2 +PY3 = sys.version_info[0] == 3 +PY34 = sys.version_info[0:2] >= (3, 4) + +if PY3: + string_types = str, + integer_types = int, + class_types = type, + text_type = str + binary_type = bytes + + MAXSIZE = sys.maxsize +else: + string_types = basestring, + integer_types = (int, long) + class_types = (type, types.ClassType) + text_type = unicode + binary_type = str + + if sys.platform.startswith("java"): + # Jython always uses 32 bits. + MAXSIZE = int((1 << 31) - 1) + else: + # It's possible to have sizeof(long) != sizeof(Py_ssize_t). + class X(object): + + def __len__(self): + return 1 << 31 + try: + len(X()) + except OverflowError: + # 32-bit + MAXSIZE = int((1 << 31) - 1) + else: + # 64-bit + MAXSIZE = int((1 << 63) - 1) + del X + + +def _add_doc(func, doc): + """Add documentation to a function.""" + func.__doc__ = doc + + +def _import_module(name): + """Import module, returning the module after the last dot.""" + __import__(name) + return sys.modules[name] + + +class _LazyDescr(object): + + def __init__(self, name): + self.name = name + + def __get__(self, obj, tp): + result = self._resolve() + setattr(obj, self.name, result) # Invokes __set__. + try: + # This is a bit ugly, but it avoids running this again by + # removing this descriptor. + delattr(obj.__class__, self.name) + except AttributeError: + pass + return result + + +class MovedModule(_LazyDescr): + + def __init__(self, name, old, new=None): + super(MovedModule, self).__init__(name) + if PY3: + if new is None: + new = name + self.mod = new + else: + self.mod = old + + def _resolve(self): + return _import_module(self.mod) + + def __getattr__(self, attr): + _module = self._resolve() + value = getattr(_module, attr) + setattr(self, attr, value) + return value + + +class _LazyModule(types.ModuleType): + + def __init__(self, name): + super(_LazyModule, self).__init__(name) + self.__doc__ = self.__class__.__doc__ + + def __dir__(self): + attrs = ["__doc__", "__name__"] + attrs += [attr.name for attr in self._moved_attributes] + return attrs + + # Subclasses should override this + _moved_attributes = [] + + +class MovedAttribute(_LazyDescr): + + def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None): + super(MovedAttribute, self).__init__(name) + if PY3: + if new_mod is None: + new_mod = name + self.mod = new_mod + if new_attr is None: + if old_attr is None: + new_attr = name + else: + new_attr = old_attr + self.attr = new_attr + else: + self.mod = old_mod + if old_attr is None: + old_attr = name + self.attr = old_attr + + def _resolve(self): + module = _import_module(self.mod) + return getattr(module, self.attr) + + +class _SixMetaPathImporter(object): + + """ + A meta path importer to import six.moves and its submodules. + + This class implements a PEP302 finder and loader. It should be compatible + with Python 2.5 and all existing versions of Python3 + """ + + def __init__(self, six_module_name): + self.name = six_module_name + self.known_modules = {} + + def _add_module(self, mod, *fullnames): + for fullname in fullnames: + self.known_modules[self.name + "." + fullname] = mod + + def _get_module(self, fullname): + return self.known_modules[self.name + "." + fullname] + + def find_module(self, fullname, path=None): + if fullname in self.known_modules: + return self + return None + + def __get_module(self, fullname): + try: + return self.known_modules[fullname] + except KeyError: + raise ImportError("This loader does not know module " + fullname) + + def load_module(self, fullname): + try: + # in case of a reload + return sys.modules[fullname] + except KeyError: + pass + mod = self.__get_module(fullname) + if isinstance(mod, MovedModule): + mod = mod._resolve() + else: + mod.__loader__ = self + sys.modules[fullname] = mod + return mod + + def is_package(self, fullname): + """ + Return true, if the named module is a package. + + We need this method to get correct spec objects with + Python 3.4 (see PEP451) + """ + return hasattr(self.__get_module(fullname), "__path__") + + def get_code(self, fullname): + """Return None + + Required, if is_package is implemented""" + self.__get_module(fullname) # eventually raises ImportError + return None + get_source = get_code # same as get_code + +_importer = _SixMetaPathImporter(__name__) + + +class _MovedItems(_LazyModule): + + """Lazy loading of moved objects""" + __path__ = [] # mark as package + + +_moved_attributes = [ + MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"), + MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"), + MovedAttribute("filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse"), + MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"), + MovedAttribute("intern", "__builtin__", "sys"), + MovedAttribute("map", "itertools", "builtins", "imap", "map"), + MovedAttribute("getcwd", "os", "os", "getcwdu", "getcwd"), + MovedAttribute("getcwdb", "os", "os", "getcwd", "getcwdb"), + MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"), + MovedAttribute("reload_module", "__builtin__", "importlib" if PY34 else "imp", "reload"), + MovedAttribute("reduce", "__builtin__", "functools"), + MovedAttribute("shlex_quote", "pipes", "shlex", "quote"), + MovedAttribute("StringIO", "StringIO", "io"), + MovedAttribute("UserDict", "UserDict", "collections"), + MovedAttribute("UserList", "UserList", "collections"), + MovedAttribute("UserString", "UserString", "collections"), + MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"), + MovedAttribute("zip", "itertools", "builtins", "izip", "zip"), + MovedAttribute("zip_longest", "itertools", "itertools", "izip_longest", "zip_longest"), + MovedModule("builtins", "__builtin__"), + MovedModule("configparser", "ConfigParser"), + MovedModule("copyreg", "copy_reg"), + MovedModule("dbm_gnu", "gdbm", "dbm.gnu"), + MovedModule("_dummy_thread", "dummy_thread", "_dummy_thread"), + MovedModule("http_cookiejar", "cookielib", "http.cookiejar"), + MovedModule("http_cookies", "Cookie", "http.cookies"), + MovedModule("html_entities", "htmlentitydefs", "html.entities"), + MovedModule("html_parser", "HTMLParser", "html.parser"), + MovedModule("http_client", "httplib", "http.client"), + MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"), + MovedModule("email_mime_nonmultipart", "email.MIMENonMultipart", "email.mime.nonmultipart"), + MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"), + MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"), + MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"), + MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"), + MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"), + MovedModule("cPickle", "cPickle", "pickle"), + MovedModule("queue", "Queue"), + MovedModule("reprlib", "repr"), + MovedModule("socketserver", "SocketServer"), + MovedModule("_thread", "thread", "_thread"), + MovedModule("tkinter", "Tkinter"), + MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"), + MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"), + MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"), + MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"), + MovedModule("tkinter_tix", "Tix", "tkinter.tix"), + MovedModule("tkinter_ttk", "ttk", "tkinter.ttk"), + MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"), + MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"), + MovedModule("tkinter_colorchooser", "tkColorChooser", + "tkinter.colorchooser"), + MovedModule("tkinter_commondialog", "tkCommonDialog", + "tkinter.commondialog"), + MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"), + MovedModule("tkinter_font", "tkFont", "tkinter.font"), + MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"), + MovedModule("tkinter_tksimpledialog", "tkSimpleDialog", + "tkinter.simpledialog"), + MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"), + MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"), + MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"), + MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"), + MovedModule("xmlrpc_client", "xmlrpclib", "xmlrpc.client"), + MovedModule("xmlrpc_server", "SimpleXMLRPCServer", "xmlrpc.server"), +] +# Add windows specific modules. +if sys.platform == "win32": + _moved_attributes += [ + MovedModule("winreg", "_winreg"), + ] + +for attr in _moved_attributes: + setattr(_MovedItems, attr.name, attr) + if isinstance(attr, MovedModule): + _importer._add_module(attr, "moves." + attr.name) +del attr + +_MovedItems._moved_attributes = _moved_attributes + +moves = _MovedItems(__name__ + ".moves") +_importer._add_module(moves, "moves") + + +class Module_six_moves_urllib_parse(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_parse""" + + +_urllib_parse_moved_attributes = [ + MovedAttribute("ParseResult", "urlparse", "urllib.parse"), + MovedAttribute("SplitResult", "urlparse", "urllib.parse"), + MovedAttribute("parse_qs", "urlparse", "urllib.parse"), + MovedAttribute("parse_qsl", "urlparse", "urllib.parse"), + MovedAttribute("urldefrag", "urlparse", "urllib.parse"), + MovedAttribute("urljoin", "urlparse", "urllib.parse"), + MovedAttribute("urlparse", "urlparse", "urllib.parse"), + MovedAttribute("urlsplit", "urlparse", "urllib.parse"), + MovedAttribute("urlunparse", "urlparse", "urllib.parse"), + MovedAttribute("urlunsplit", "urlparse", "urllib.parse"), + MovedAttribute("quote", "urllib", "urllib.parse"), + MovedAttribute("quote_plus", "urllib", "urllib.parse"), + MovedAttribute("unquote", "urllib", "urllib.parse"), + MovedAttribute("unquote_plus", "urllib", "urllib.parse"), + MovedAttribute("urlencode", "urllib", "urllib.parse"), + MovedAttribute("splitquery", "urllib", "urllib.parse"), + MovedAttribute("splittag", "urllib", "urllib.parse"), + MovedAttribute("splituser", "urllib", "urllib.parse"), + MovedAttribute("uses_fragment", "urlparse", "urllib.parse"), + MovedAttribute("uses_netloc", "urlparse", "urllib.parse"), + MovedAttribute("uses_params", "urlparse", "urllib.parse"), + MovedAttribute("uses_query", "urlparse", "urllib.parse"), + MovedAttribute("uses_relative", "urlparse", "urllib.parse"), +] +for attr in _urllib_parse_moved_attributes: + setattr(Module_six_moves_urllib_parse, attr.name, attr) +del attr + +Module_six_moves_urllib_parse._moved_attributes = _urllib_parse_moved_attributes + +_importer._add_module(Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse"), + "moves.urllib_parse", "moves.urllib.parse") + + +class Module_six_moves_urllib_error(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_error""" + + +_urllib_error_moved_attributes = [ + MovedAttribute("URLError", "urllib2", "urllib.error"), + MovedAttribute("HTTPError", "urllib2", "urllib.error"), + MovedAttribute("ContentTooShortError", "urllib", "urllib.error"), +] +for attr in _urllib_error_moved_attributes: + setattr(Module_six_moves_urllib_error, attr.name, attr) +del attr + +Module_six_moves_urllib_error._moved_attributes = _urllib_error_moved_attributes + +_importer._add_module(Module_six_moves_urllib_error(__name__ + ".moves.urllib.error"), + "moves.urllib_error", "moves.urllib.error") + + +class Module_six_moves_urllib_request(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_request""" + + +_urllib_request_moved_attributes = [ + MovedAttribute("urlopen", "urllib2", "urllib.request"), + MovedAttribute("install_opener", "urllib2", "urllib.request"), + MovedAttribute("build_opener", "urllib2", "urllib.request"), + MovedAttribute("pathname2url", "urllib", "urllib.request"), + MovedAttribute("url2pathname", "urllib", "urllib.request"), + MovedAttribute("getproxies", "urllib", "urllib.request"), + MovedAttribute("Request", "urllib2", "urllib.request"), + MovedAttribute("OpenerDirector", "urllib2", "urllib.request"), + MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"), + MovedAttribute("ProxyHandler", "urllib2", "urllib.request"), + MovedAttribute("BaseHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"), + MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"), + MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"), + MovedAttribute("FileHandler", "urllib2", "urllib.request"), + MovedAttribute("FTPHandler", "urllib2", "urllib.request"), + MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"), + MovedAttribute("UnknownHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"), + MovedAttribute("urlretrieve", "urllib", "urllib.request"), + MovedAttribute("urlcleanup", "urllib", "urllib.request"), + MovedAttribute("URLopener", "urllib", "urllib.request"), + MovedAttribute("FancyURLopener", "urllib", "urllib.request"), + MovedAttribute("proxy_bypass", "urllib", "urllib.request"), +] +for attr in _urllib_request_moved_attributes: + setattr(Module_six_moves_urllib_request, attr.name, attr) +del attr + +Module_six_moves_urllib_request._moved_attributes = _urllib_request_moved_attributes + +_importer._add_module(Module_six_moves_urllib_request(__name__ + ".moves.urllib.request"), + "moves.urllib_request", "moves.urllib.request") + + +class Module_six_moves_urllib_response(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_response""" + + +_urllib_response_moved_attributes = [ + MovedAttribute("addbase", "urllib", "urllib.response"), + MovedAttribute("addclosehook", "urllib", "urllib.response"), + MovedAttribute("addinfo", "urllib", "urllib.response"), + MovedAttribute("addinfourl", "urllib", "urllib.response"), +] +for attr in _urllib_response_moved_attributes: + setattr(Module_six_moves_urllib_response, attr.name, attr) +del attr + +Module_six_moves_urllib_response._moved_attributes = _urllib_response_moved_attributes + +_importer._add_module(Module_six_moves_urllib_response(__name__ + ".moves.urllib.response"), + "moves.urllib_response", "moves.urllib.response") + + +class Module_six_moves_urllib_robotparser(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_robotparser""" + + +_urllib_robotparser_moved_attributes = [ + MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"), +] +for attr in _urllib_robotparser_moved_attributes: + setattr(Module_six_moves_urllib_robotparser, attr.name, attr) +del attr + +Module_six_moves_urllib_robotparser._moved_attributes = _urllib_robotparser_moved_attributes + +_importer._add_module(Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser"), + "moves.urllib_robotparser", "moves.urllib.robotparser") + + +class Module_six_moves_urllib(types.ModuleType): + + """Create a six.moves.urllib namespace that resembles the Python 3 namespace""" + __path__ = [] # mark as package + parse = _importer._get_module("moves.urllib_parse") + error = _importer._get_module("moves.urllib_error") + request = _importer._get_module("moves.urllib_request") + response = _importer._get_module("moves.urllib_response") + robotparser = _importer._get_module("moves.urllib_robotparser") + + def __dir__(self): + return ['parse', 'error', 'request', 'response', 'robotparser'] + +_importer._add_module(Module_six_moves_urllib(__name__ + ".moves.urllib"), + "moves.urllib") + + +def add_move(move): + """Add an item to six.moves.""" + setattr(_MovedItems, move.name, move) + + +def remove_move(name): + """Remove item from six.moves.""" + try: + delattr(_MovedItems, name) + except AttributeError: + try: + del moves.__dict__[name] + except KeyError: + raise AttributeError("no such move, %r" % (name,)) + + +if PY3: + _meth_func = "__func__" + _meth_self = "__self__" + + _func_closure = "__closure__" + _func_code = "__code__" + _func_defaults = "__defaults__" + _func_globals = "__globals__" +else: + _meth_func = "im_func" + _meth_self = "im_self" + + _func_closure = "func_closure" + _func_code = "func_code" + _func_defaults = "func_defaults" + _func_globals = "func_globals" + + +try: + advance_iterator = next +except NameError: + def advance_iterator(it): + return it.next() +next = advance_iterator + + +try: + callable = callable +except NameError: + def callable(obj): + return any("__call__" in klass.__dict__ for klass in type(obj).__mro__) + + +if PY3: + def get_unbound_function(unbound): + return unbound + + create_bound_method = types.MethodType + + def create_unbound_method(func, cls): + return func + + Iterator = object +else: + def get_unbound_function(unbound): + return unbound.im_func + + def create_bound_method(func, obj): + return types.MethodType(func, obj, obj.__class__) + + def create_unbound_method(func, cls): + return types.MethodType(func, None, cls) + + class Iterator(object): + + def next(self): + return type(self).__next__(self) + + callable = callable +_add_doc(get_unbound_function, + """Get the function out of a possibly unbound function""") + + +get_method_function = operator.attrgetter(_meth_func) +get_method_self = operator.attrgetter(_meth_self) +get_function_closure = operator.attrgetter(_func_closure) +get_function_code = operator.attrgetter(_func_code) +get_function_defaults = operator.attrgetter(_func_defaults) +get_function_globals = operator.attrgetter(_func_globals) + + +if PY3: + def iterkeys(d, **kw): + return iter(d.keys(**kw)) + + def itervalues(d, **kw): + return iter(d.values(**kw)) + + def iteritems(d, **kw): + return iter(d.items(**kw)) + + def iterlists(d, **kw): + return iter(d.lists(**kw)) + + viewkeys = operator.methodcaller("keys") + + viewvalues = operator.methodcaller("values") + + viewitems = operator.methodcaller("items") +else: + def iterkeys(d, **kw): + return d.iterkeys(**kw) + + def itervalues(d, **kw): + return d.itervalues(**kw) + + def iteritems(d, **kw): + return d.iteritems(**kw) + + def iterlists(d, **kw): + return d.iterlists(**kw) + + viewkeys = operator.methodcaller("viewkeys") + + viewvalues = operator.methodcaller("viewvalues") + + viewitems = operator.methodcaller("viewitems") + +_add_doc(iterkeys, "Return an iterator over the keys of a dictionary.") +_add_doc(itervalues, "Return an iterator over the values of a dictionary.") +_add_doc(iteritems, + "Return an iterator over the (key, value) pairs of a dictionary.") +_add_doc(iterlists, + "Return an iterator over the (key, [values]) pairs of a dictionary.") + + +if PY3: + def b(s): + return s.encode("latin-1") + + def u(s): + return s + unichr = chr + import struct + int2byte = struct.Struct(">B").pack + del struct + byte2int = operator.itemgetter(0) + indexbytes = operator.getitem + iterbytes = iter + import io + StringIO = io.StringIO + BytesIO = io.BytesIO + _assertCountEqual = "assertCountEqual" + if sys.version_info[1] <= 1: + _assertRaisesRegex = "assertRaisesRegexp" + _assertRegex = "assertRegexpMatches" + else: + _assertRaisesRegex = "assertRaisesRegex" + _assertRegex = "assertRegex" +else: + def b(s): + return s + # Workaround for standalone backslash + + def u(s): + return unicode(s.replace(r'\\', r'\\\\'), "unicode_escape") + unichr = unichr + int2byte = chr + + def byte2int(bs): + return ord(bs[0]) + + def indexbytes(buf, i): + return ord(buf[i]) + iterbytes = functools.partial(itertools.imap, ord) + import StringIO + StringIO = BytesIO = StringIO.StringIO + _assertCountEqual = "assertItemsEqual" + _assertRaisesRegex = "assertRaisesRegexp" + _assertRegex = "assertRegexpMatches" +_add_doc(b, """Byte literal""") +_add_doc(u, """Text literal""") + + +def assertCountEqual(self, *args, **kwargs): + return getattr(self, _assertCountEqual)(*args, **kwargs) + + +def assertRaisesRegex(self, *args, **kwargs): + return getattr(self, _assertRaisesRegex)(*args, **kwargs) + + +def assertRegex(self, *args, **kwargs): + return getattr(self, _assertRegex)(*args, **kwargs) + + +if PY3: + exec_ = getattr(moves.builtins, "exec") + + def reraise(tp, value, tb=None): + if value is None: + value = tp() + if value.__traceback__ is not tb: + raise value.with_traceback(tb) + raise value + +else: + def exec_(_code_, _globs_=None, _locs_=None): + """Execute code in a namespace.""" + if _globs_ is None: + frame = sys._getframe(1) + _globs_ = frame.f_globals + if _locs_ is None: + _locs_ = frame.f_locals + del frame + elif _locs_ is None: + _locs_ = _globs_ + exec("""exec _code_ in _globs_, _locs_""") + + exec_("""def reraise(tp, value, tb=None): + raise tp, value, tb +""") + + +if sys.version_info[:2] == (3, 2): + exec_("""def raise_from(value, from_value): + if from_value is None: + raise value + raise value from from_value +""") +elif sys.version_info[:2] > (3, 2): + exec_("""def raise_from(value, from_value): + raise value from from_value +""") +else: + def raise_from(value, from_value): + raise value + + +print_ = getattr(moves.builtins, "print", None) +if print_ is None: + def print_(*args, **kwargs): + """The new-style print function for Python 2.4 and 2.5.""" + fp = kwargs.pop("file", sys.stdout) + if fp is None: + return + + def write(data): + if not isinstance(data, basestring): + data = str(data) + # If the file has an encoding, encode unicode with it. + if (isinstance(fp, file) and + isinstance(data, unicode) and + fp.encoding is not None): + errors = getattr(fp, "errors", None) + if errors is None: + errors = "strict" + data = data.encode(fp.encoding, errors) + fp.write(data) + want_unicode = False + sep = kwargs.pop("sep", None) + if sep is not None: + if isinstance(sep, unicode): + want_unicode = True + elif not isinstance(sep, str): + raise TypeError("sep must be None or a string") + end = kwargs.pop("end", None) + if end is not None: + if isinstance(end, unicode): + want_unicode = True + elif not isinstance(end, str): + raise TypeError("end must be None or a string") + if kwargs: + raise TypeError("invalid keyword arguments to print()") + if not want_unicode: + for arg in args: + if isinstance(arg, unicode): + want_unicode = True + break + if want_unicode: + newline = unicode("\n") + space = unicode(" ") + else: + newline = "\n" + space = " " + if sep is None: + sep = space + if end is None: + end = newline + for i, arg in enumerate(args): + if i: + write(sep) + write(arg) + write(end) +if sys.version_info[:2] < (3, 3): + _print = print_ + + def print_(*args, **kwargs): + fp = kwargs.get("file", sys.stdout) + flush = kwargs.pop("flush", False) + _print(*args, **kwargs) + if flush and fp is not None: + fp.flush() + +_add_doc(reraise, """Reraise an exception.""") + +if sys.version_info[0:2] < (3, 4): + def wraps(wrapped, assigned=functools.WRAPPER_ASSIGNMENTS, + updated=functools.WRAPPER_UPDATES): + def wrapper(f): + f = functools.wraps(wrapped, assigned, updated)(f) + f.__wrapped__ = wrapped + return f + return wrapper +else: + wraps = functools.wraps + + +def with_metaclass(meta, *bases): + """Create a base class with a metaclass.""" + # This requires a bit of explanation: the basic idea is to make a dummy + # metaclass for one level of class instantiation that replaces itself with + # the actual metaclass. + class metaclass(meta): + + def __new__(cls, name, this_bases, d): + return meta(name, bases, d) + return type.__new__(metaclass, 'temporary_class', (), {}) + + +def add_metaclass(metaclass): + """Class decorator for creating a class with a metaclass.""" + def wrapper(cls): + orig_vars = cls.__dict__.copy() + slots = orig_vars.get('__slots__') + if slots is not None: + if isinstance(slots, str): + slots = [slots] + for slots_var in slots: + orig_vars.pop(slots_var) + orig_vars.pop('__dict__', None) + orig_vars.pop('__weakref__', None) + return metaclass(cls.__name__, cls.__bases__, orig_vars) + return wrapper + + +def python_2_unicode_compatible(klass): + """ + A decorator that defines __unicode__ and __str__ methods under Python 2. + Under Python 3 it does nothing. + + To support Python 2 and 3 with a single code base, define a __str__ method + returning text and apply this decorator to the class. + """ + if PY2: + if '__str__' not in klass.__dict__: + raise ValueError("@python_2_unicode_compatible cannot be applied " + "to %s because it doesn't define __str__()." % + klass.__name__) + klass.__unicode__ = klass.__str__ + klass.__str__ = lambda self: self.__unicode__().encode('utf-8') + return klass + + +# Complete the moves implementation. +# This code is at the end of this module to speed up module loading. +# Turn this module into a package. +__path__ = [] # required for PEP 302 and PEP 451 +__package__ = __name__ # see PEP 366 @ReservedAssignment +if globals().get("__spec__") is not None: + __spec__.submodule_search_locations = [] # PEP 451 @UndefinedVariable +# Remove other six meta path importers, since they cause problems. This can +# happen if six is removed from sys.modules and then reloaded. (Setuptools does +# this for some reason.) +if sys.meta_path: + for i, importer in enumerate(sys.meta_path): + # Here's some real nastiness: Another "instance" of the six module might + # be floating around. Therefore, we can't use isinstance() to check for + # the six meta path importer, since the other six instance will have + # inserted an importer with different class. + if (type(importer).__name__ == "_SixMetaPathImporter" and + importer.name == __name__): + del sys.meta_path[i] + break + del i, importer +# Finally, add the importer to the meta path import hook. +sys.meta_path.append(_importer) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py new file mode 100644 index 0000000..d6594eb --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py @@ -0,0 +1,19 @@ +import sys + +try: + # Our match_hostname function is the same as 3.5's, so we only want to + # import the match_hostname function if it's at least that good. + if sys.version_info < (3, 5): + raise ImportError("Fallback to vendored code") + + from ssl import CertificateError, match_hostname +except ImportError: + try: + # Backport of the function from a pypi module + from backports.ssl_match_hostname import CertificateError, match_hostname + except ImportError: + # Our vendored copy + from ._implementation import CertificateError, match_hostname + +# Not needed, but documenting what we provide. +__all__ = ('CertificateError', 'match_hostname') diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..62f39a4441c0a75c3dd3b475e7df828094ed4d9f GIT binary patch literal 567 zcmZWlJ#SMn6t(?c+K_%RWT})P147EsI)GFu5<*CbN?p1D0^VXdv6JV<A5XUP)I2eP z#Kw<c?AG7&R;K&`1}3f>B&fL7J=XO-KKIz~4i0(<;^*ymeoGMgk&1s~4~mzN;VXbZ z0&7&D=CMRqSdb<114%^o1%JlS%XMb*A~&6)gVB3rFLNZxvgbcxlvdNf<LunyJo>|_ zw;a&{mEFILkI0e_Xp15*x&psJqn!<SL6;-4$zb1f0Gi`-uJx49mc!_VwY0){DTXsA z<cPEnUr8U;T+Mituf2D^Jv2PdN>;iMEjMz5L1Xlw&B8jg`?d5zIm?utyLRuwRL;lk zwJZefbKv?kv>2p;sT)qA!R~7oM@*SYOCxRM5%k(!#=s<FH^}cNjRe2G(aNhDjM18V zI(J&YbUL}F3pS~}Y3$Sa)wnFLn}+Gh*|hXyh=rwZX{D+YWkUqblkxbhUe`}n>F_Su z_7CXFYptfwXa!FBLI(Q3QOe+@Dl&Fjt=sN%<HSnK7wJbrAD~M}*27)W$A_3CB!lcX DX|$eD literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..26c4965c0163b6236e0558cc26567b03dede18d6 GIT binary patch literal 3340 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 F{tG-?hXVir literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py new file mode 100644 index 0000000..970cf65 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py @@ -0,0 +1,156 @@ +"""The match_hostname() function from Python 3.3.3, essential when using SSL.""" + +# Note: This file is under the PSF license as the code comes from the python +# stdlib. http://docs.python.org/3/license.html + +import re +import sys + +# ipaddress has been backported to 2.6+ in pypi. If it is installed on the +# system, use it to handle IPAddress ServerAltnames (this was added in +# python-3.5) otherwise only do DNS matching. This allows +# backports.ssl_match_hostname to continue to be used in Python 2.7. +try: + from pip._vendor import ipaddress +except ImportError: + ipaddress = None + +__version__ = '3.5.0.1' + + +class CertificateError(ValueError): + pass + + +def _dnsname_match(dn, hostname, max_wildcards=1): + """Matching according to RFC 6125, section 6.4.3 + + http://tools.ietf.org/html/rfc6125#section-6.4.3 + """ + pats = [] + if not dn: + return False + + # Ported from python3-syntax: + # leftmost, *remainder = dn.split(r'.') + parts = dn.split(r'.') + leftmost = parts[0] + remainder = parts[1:] + + wildcards = leftmost.count('*') + if wildcards > max_wildcards: + # Issue #17980: avoid denials of service by refusing more + # than one wildcard per fragment. A survey of established + # policy among SSL implementations showed it to be a + # reasonable choice. + raise CertificateError( + "too many wildcards in certificate DNS name: " + repr(dn)) + + # speed up common case w/o wildcards + if not wildcards: + return dn.lower() == hostname.lower() + + # RFC 6125, section 6.4.3, subitem 1. + # The client SHOULD NOT attempt to match a presented identifier in which + # the wildcard character comprises a label other than the left-most label. + if leftmost == '*': + # When '*' is a fragment by itself, it matches a non-empty dotless + # fragment. + pats.append('[^.]+') + elif leftmost.startswith('xn--') or hostname.startswith('xn--'): + # RFC 6125, section 6.4.3, subitem 3. + # The client SHOULD NOT attempt to match a presented identifier + # where the wildcard character is embedded within an A-label or + # U-label of an internationalized domain name. + pats.append(re.escape(leftmost)) + else: + # Otherwise, '*' matches any dotless string, e.g. www* + pats.append(re.escape(leftmost).replace(r'\*', '[^.]*')) + + # add the remaining fragments, ignore any wildcards + for frag in remainder: + pats.append(re.escape(frag)) + + pat = re.compile(r'\A' + r'\.'.join(pats) + r'\Z', re.IGNORECASE) + return pat.match(hostname) + + +def _to_unicode(obj): + if isinstance(obj, str) and sys.version_info < (3,): + obj = unicode(obj, encoding='ascii', errors='strict') + return obj + +def _ipaddress_match(ipname, host_ip): + """Exact matching of IP addresses. + + RFC 6125 explicitly doesn't define an algorithm for this + (section 1.7.2 - "Out of Scope"). + """ + # OpenSSL may add a trailing newline to a subjectAltName's IP address + # Divergence from upstream: ipaddress can't handle byte str + ip = ipaddress.ip_address(_to_unicode(ipname).rstrip()) + return ip == host_ip + + +def match_hostname(cert, hostname): + """Verify that *cert* (in decoded format as returned by + SSLSocket.getpeercert()) matches the *hostname*. RFC 2818 and RFC 6125 + rules are followed, but IP addresses are not accepted for *hostname*. + + CertificateError is raised on failure. On success, the function + returns nothing. + """ + if not cert: + raise ValueError("empty or no certificate, match_hostname needs a " + "SSL socket or SSL context with either " + "CERT_OPTIONAL or CERT_REQUIRED") + try: + # Divergence from upstream: ipaddress can't handle byte str + host_ip = ipaddress.ip_address(_to_unicode(hostname)) + except ValueError: + # Not an IP address (common case) + host_ip = None + except UnicodeError: + # Divergence from upstream: Have to deal with ipaddress not taking + # byte strings. addresses should be all ascii, so we consider it not + # an ipaddress in this case + host_ip = None + except AttributeError: + # Divergence from upstream: Make ipaddress library optional + if ipaddress is None: + host_ip = None + else: + raise + dnsnames = [] + san = cert.get('subjectAltName', ()) + for key, value in san: + if key == 'DNS': + if host_ip is None and _dnsname_match(value, hostname): + return + dnsnames.append(value) + elif key == 'IP Address': + if host_ip is not None and _ipaddress_match(value, host_ip): + return + dnsnames.append(value) + if not dnsnames: + # The subject is only checked when there is no dNSName entry + # in subjectAltName + for sub in cert.get('subject', ()): + for key, value in sub: + # XXX according to RFC 2818, the most specific Common Name + # must be used. + if key == 'commonName': + if _dnsname_match(value, hostname): + return + dnsnames.append(value) + if len(dnsnames) > 1: + raise CertificateError("hostname %r " + "doesn't match either of %s" + % (hostname, ', '.join(map(repr, dnsnames)))) + elif len(dnsnames) == 1: + raise CertificateError("hostname %r " + "doesn't match %r" + % (hostname, dnsnames[0])) + else: + raise CertificateError("no appropriate commonName or " + "subjectAltName fields were found") diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/poolmanager.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/poolmanager.py new file mode 100644 index 0000000..a6ade6e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/poolmanager.py @@ -0,0 +1,455 @@ +from __future__ import absolute_import +import collections +import functools +import logging + +from ._collections import RecentlyUsedContainer +from .connectionpool import HTTPConnectionPool, HTTPSConnectionPool +from .connectionpool import port_by_scheme +from .exceptions import LocationValueError, MaxRetryError, ProxySchemeUnknown +from .packages import six +from .packages.six.moves.urllib.parse import urljoin +from .request import RequestMethods +from .util.url import parse_url +from .util.retry import Retry + + +__all__ = ['PoolManager', 'ProxyManager', 'proxy_from_url'] + + +log = logging.getLogger(__name__) + +SSL_KEYWORDS = ('key_file', 'cert_file', 'cert_reqs', 'ca_certs', + 'ssl_version', 'ca_cert_dir', 'ssl_context', + 'key_password') + +# All known keyword arguments that could be provided to the pool manager, its +# pools, or the underlying connections. This is used to construct a pool key. +_key_fields = ( + 'key_scheme', # str + 'key_host', # str + 'key_port', # int + 'key_timeout', # int or float or Timeout + 'key_retries', # int or Retry + 'key_strict', # bool + 'key_block', # bool + 'key_source_address', # str + 'key_key_file', # str + 'key_key_password', # str + 'key_cert_file', # str + 'key_cert_reqs', # str + 'key_ca_certs', # str + 'key_ssl_version', # str + 'key_ca_cert_dir', # str + 'key_ssl_context', # instance of ssl.SSLContext or urllib3.util.ssl_.SSLContext + 'key_maxsize', # int + 'key_headers', # dict + 'key__proxy', # parsed proxy url + 'key__proxy_headers', # dict + 'key_socket_options', # list of (level (int), optname (int), value (int or str)) tuples + 'key__socks_options', # dict + 'key_assert_hostname', # bool or string + 'key_assert_fingerprint', # str + 'key_server_hostname', # str +) + +#: The namedtuple class used to construct keys for the connection pool. +#: All custom key schemes should include the fields in this key at a minimum. +PoolKey = collections.namedtuple('PoolKey', _key_fields) + + +def _default_key_normalizer(key_class, request_context): + """ + Create a pool key out of a request context dictionary. + + According to RFC 3986, both the scheme and host are case-insensitive. + Therefore, this function normalizes both before constructing the pool + key for an HTTPS request. If you wish to change this behaviour, provide + alternate callables to ``key_fn_by_scheme``. + + :param key_class: + The class to use when constructing the key. This should be a namedtuple + with the ``scheme`` and ``host`` keys at a minimum. + :type key_class: namedtuple + :param request_context: + A dictionary-like object that contain the context for a request. + :type request_context: dict + + :return: A namedtuple that can be used as a connection pool key. + :rtype: PoolKey + """ + # Since we mutate the dictionary, make a copy first + context = request_context.copy() + context['scheme'] = context['scheme'].lower() + context['host'] = context['host'].lower() + + # These are both dictionaries and need to be transformed into frozensets + for key in ('headers', '_proxy_headers', '_socks_options'): + if key in context and context[key] is not None: + context[key] = frozenset(context[key].items()) + + # The socket_options key may be a list and needs to be transformed into a + # tuple. + socket_opts = context.get('socket_options') + if socket_opts is not None: + context['socket_options'] = tuple(socket_opts) + + # Map the kwargs to the names in the namedtuple - this is necessary since + # namedtuples can't have fields starting with '_'. + for key in list(context.keys()): + context['key_' + key] = context.pop(key) + + # Default to ``None`` for keys missing from the context + for field in key_class._fields: + if field not in context: + context[field] = None + + return key_class(**context) + + +#: A dictionary that maps a scheme to a callable that creates a pool key. +#: This can be used to alter the way pool keys are constructed, if desired. +#: Each PoolManager makes a copy of this dictionary so they can be configured +#: globally here, or individually on the instance. +key_fn_by_scheme = { + 'http': functools.partial(_default_key_normalizer, PoolKey), + 'https': functools.partial(_default_key_normalizer, PoolKey), +} + +pool_classes_by_scheme = { + 'http': HTTPConnectionPool, + 'https': HTTPSConnectionPool, +} + + +class PoolManager(RequestMethods): + """ + Allows for arbitrary requests while transparently keeping track of + necessary connection pools for you. + + :param num_pools: + Number of connection pools to cache before discarding the least + recently used pool. + + :param headers: + Headers to include with all requests, unless other headers are given + explicitly. + + :param \\**connection_pool_kw: + Additional parameters are used to create fresh + :class:`urllib3.connectionpool.ConnectionPool` instances. + + Example:: + + >>> manager = PoolManager(num_pools=2) + >>> r = manager.request('GET', 'http://google.com/') + >>> r = manager.request('GET', 'http://google.com/mail') + >>> r = manager.request('GET', 'http://yahoo.com/') + >>> len(manager.pools) + 2 + + """ + + proxy = None + + def __init__(self, num_pools=10, headers=None, **connection_pool_kw): + RequestMethods.__init__(self, headers) + self.connection_pool_kw = connection_pool_kw + self.pools = RecentlyUsedContainer(num_pools, + dispose_func=lambda p: p.close()) + + # Locally set the pool classes and keys so other PoolManagers can + # override them. + self.pool_classes_by_scheme = pool_classes_by_scheme + self.key_fn_by_scheme = key_fn_by_scheme.copy() + + def __enter__(self): + return self + + def __exit__(self, exc_type, exc_val, exc_tb): + self.clear() + # Return False to re-raise any potential exceptions + return False + + def _new_pool(self, scheme, host, port, request_context=None): + """ + Create a new :class:`ConnectionPool` based on host, port, scheme, and + any additional pool keyword arguments. + + If ``request_context`` is provided, it is provided as keyword arguments + to the pool class used. This method is used to actually create the + connection pools handed out by :meth:`connection_from_url` and + companion methods. It is intended to be overridden for customization. + """ + pool_cls = self.pool_classes_by_scheme[scheme] + if request_context is None: + request_context = self.connection_pool_kw.copy() + + # Although the context has everything necessary to create the pool, + # this function has historically only used the scheme, host, and port + # in the positional args. When an API change is acceptable these can + # be removed. + for key in ('scheme', 'host', 'port'): + request_context.pop(key, None) + + if scheme == 'http': + for kw in SSL_KEYWORDS: + request_context.pop(kw, None) + + return pool_cls(host, port, **request_context) + + def clear(self): + """ + Empty our store of pools and direct them all to close. + + This will not affect in-flight connections, but they will not be + re-used after completion. + """ + self.pools.clear() + + def connection_from_host(self, host, port=None, scheme='http', pool_kwargs=None): + """ + Get a :class:`ConnectionPool` based on the host, port, and scheme. + + If ``port`` isn't given, it will be derived from the ``scheme`` using + ``urllib3.connectionpool.port_by_scheme``. If ``pool_kwargs`` is + provided, it is merged with the instance's ``connection_pool_kw`` + variable and used to create the new connection pool, if one is + needed. + """ + + if not host: + raise LocationValueError("No host specified.") + + request_context = self._merge_pool_kwargs(pool_kwargs) + request_context['scheme'] = scheme or 'http' + if not port: + port = port_by_scheme.get(request_context['scheme'].lower(), 80) + request_context['port'] = port + request_context['host'] = host + + return self.connection_from_context(request_context) + + def connection_from_context(self, request_context): + """ + Get a :class:`ConnectionPool` based on the request context. + + ``request_context`` must at least contain the ``scheme`` key and its + value must be a key in ``key_fn_by_scheme`` instance variable. + """ + scheme = request_context['scheme'].lower() + pool_key_constructor = self.key_fn_by_scheme[scheme] + pool_key = pool_key_constructor(request_context) + + return self.connection_from_pool_key(pool_key, request_context=request_context) + + def connection_from_pool_key(self, pool_key, request_context=None): + """ + Get a :class:`ConnectionPool` based on the provided pool key. + + ``pool_key`` should be a namedtuple that only contains immutable + objects. At a minimum it must have the ``scheme``, ``host``, and + ``port`` fields. + """ + with self.pools.lock: + # If the scheme, host, or port doesn't match existing open + # connections, open a new ConnectionPool. + pool = self.pools.get(pool_key) + if pool: + return pool + + # Make a fresh ConnectionPool of the desired type + scheme = request_context['scheme'] + host = request_context['host'] + port = request_context['port'] + pool = self._new_pool(scheme, host, port, request_context=request_context) + self.pools[pool_key] = pool + + return pool + + def connection_from_url(self, url, pool_kwargs=None): + """ + Similar to :func:`urllib3.connectionpool.connection_from_url`. + + If ``pool_kwargs`` is not provided and a new pool needs to be + constructed, ``self.connection_pool_kw`` is used to initialize + the :class:`urllib3.connectionpool.ConnectionPool`. If ``pool_kwargs`` + is provided, it is used instead. Note that if a new pool does not + need to be created for the request, the provided ``pool_kwargs`` are + not used. + """ + u = parse_url(url) + return self.connection_from_host(u.host, port=u.port, scheme=u.scheme, + pool_kwargs=pool_kwargs) + + def _merge_pool_kwargs(self, override): + """ + Merge a dictionary of override values for self.connection_pool_kw. + + This does not modify self.connection_pool_kw and returns a new dict. + Any keys in the override dictionary with a value of ``None`` are + removed from the merged dictionary. + """ + base_pool_kwargs = self.connection_pool_kw.copy() + if override: + for key, value in override.items(): + if value is None: + try: + del base_pool_kwargs[key] + except KeyError: + pass + else: + base_pool_kwargs[key] = value + return base_pool_kwargs + + def urlopen(self, method, url, redirect=True, **kw): + """ + Same as :meth:`urllib3.connectionpool.HTTPConnectionPool.urlopen` + with custom cross-host redirect logic and only sends the request-uri + portion of the ``url``. + + The given ``url`` parameter must be absolute, such that an appropriate + :class:`urllib3.connectionpool.ConnectionPool` can be chosen for it. + """ + u = parse_url(url) + conn = self.connection_from_host(u.host, port=u.port, scheme=u.scheme) + + kw['assert_same_host'] = False + kw['redirect'] = False + + if 'headers' not in kw: + kw['headers'] = self.headers.copy() + + if self.proxy is not None and u.scheme == "http": + response = conn.urlopen(method, url, **kw) + else: + response = conn.urlopen(method, u.request_uri, **kw) + + redirect_location = redirect and response.get_redirect_location() + if not redirect_location: + return response + + # Support relative URLs for redirecting. + redirect_location = urljoin(url, redirect_location) + + # RFC 7231, Section 6.4.4 + if response.status == 303: + method = 'GET' + + retries = kw.get('retries') + if not isinstance(retries, Retry): + retries = Retry.from_int(retries, redirect=redirect) + + # Strip headers marked as unsafe to forward to the redirected location. + # Check remove_headers_on_redirect to avoid a potential network call within + # conn.is_same_host() which may use socket.gethostbyname() in the future. + if (retries.remove_headers_on_redirect + and not conn.is_same_host(redirect_location)): + headers = list(six.iterkeys(kw['headers'])) + for header in headers: + if header.lower() in retries.remove_headers_on_redirect: + kw['headers'].pop(header, None) + + try: + retries = retries.increment(method, url, response=response, _pool=conn) + except MaxRetryError: + if retries.raise_on_redirect: + raise + return response + + kw['retries'] = retries + kw['redirect'] = redirect + + log.info("Redirecting %s -> %s", url, redirect_location) + return self.urlopen(method, redirect_location, **kw) + + +class ProxyManager(PoolManager): + """ + Behaves just like :class:`PoolManager`, but sends all requests through + the defined proxy, using the CONNECT method for HTTPS URLs. + + :param proxy_url: + The URL of the proxy to be used. + + :param proxy_headers: + A dictionary containing headers that will be sent to the proxy. In case + of HTTP they are being sent with each request, while in the + HTTPS/CONNECT case they are sent only once. Could be used for proxy + authentication. + + Example: + >>> proxy = urllib3.ProxyManager('http://localhost:3128/') + >>> r1 = proxy.request('GET', 'http://google.com/') + >>> r2 = proxy.request('GET', 'http://httpbin.org/') + >>> len(proxy.pools) + 1 + >>> r3 = proxy.request('GET', 'https://httpbin.org/') + >>> r4 = proxy.request('GET', 'https://twitter.com/') + >>> len(proxy.pools) + 3 + + """ + + def __init__(self, proxy_url, num_pools=10, headers=None, + proxy_headers=None, **connection_pool_kw): + + if isinstance(proxy_url, HTTPConnectionPool): + proxy_url = '%s://%s:%i' % (proxy_url.scheme, proxy_url.host, + proxy_url.port) + proxy = parse_url(proxy_url) + if not proxy.port: + port = port_by_scheme.get(proxy.scheme, 80) + proxy = proxy._replace(port=port) + + if proxy.scheme not in ("http", "https"): + raise ProxySchemeUnknown(proxy.scheme) + + self.proxy = proxy + self.proxy_headers = proxy_headers or {} + + connection_pool_kw['_proxy'] = self.proxy + connection_pool_kw['_proxy_headers'] = self.proxy_headers + + super(ProxyManager, self).__init__( + num_pools, headers, **connection_pool_kw) + + def connection_from_host(self, host, port=None, scheme='http', pool_kwargs=None): + if scheme == "https": + return super(ProxyManager, self).connection_from_host( + host, port, scheme, pool_kwargs=pool_kwargs) + + return super(ProxyManager, self).connection_from_host( + self.proxy.host, self.proxy.port, self.proxy.scheme, pool_kwargs=pool_kwargs) + + def _set_proxy_headers(self, url, headers=None): + """ + Sets headers needed by proxies: specifically, the Accept and Host + headers. Only sets headers not provided by the user. + """ + headers_ = {'Accept': '*/*'} + + netloc = parse_url(url).netloc + if netloc: + headers_['Host'] = netloc + + if headers: + headers_.update(headers) + return headers_ + + def urlopen(self, method, url, redirect=True, **kw): + "Same as HTTP(S)ConnectionPool.urlopen, ``url`` must be absolute." + u = parse_url(url) + + if u.scheme == "http": + # For proxied HTTPS requests, httplib sets the necessary headers + # on the CONNECT to the proxy. For HTTP, we'll definitely + # need to set 'Host' at the very least. + headers = kw.get('headers', self.headers) + kw['headers'] = self._set_proxy_headers(url, headers) + + return super(ProxyManager, self).urlopen(method, url, redirect=redirect, **kw) + + +def proxy_from_url(url, **kw): + return ProxyManager(proxy_url=url, **kw) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/request.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/request.py new file mode 100644 index 0000000..8f2f44b --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/request.py @@ -0,0 +1,150 @@ +from __future__ import absolute_import + +from .filepost import encode_multipart_formdata +from .packages.six.moves.urllib.parse import urlencode + + +__all__ = ['RequestMethods'] + + +class RequestMethods(object): + """ + Convenience mixin for classes who implement a :meth:`urlopen` method, such + as :class:`~urllib3.connectionpool.HTTPConnectionPool` and + :class:`~urllib3.poolmanager.PoolManager`. + + Provides behavior for making common types of HTTP request methods and + decides which type of request field encoding to use. + + Specifically, + + :meth:`.request_encode_url` is for sending requests whose fields are + encoded in the URL (such as GET, HEAD, DELETE). + + :meth:`.request_encode_body` is for sending requests whose fields are + encoded in the *body* of the request using multipart or www-form-urlencoded + (such as for POST, PUT, PATCH). + + :meth:`.request` is for making any kind of request, it will look up the + appropriate encoding format and use one of the above two methods to make + the request. + + Initializer parameters: + + :param headers: + Headers to include with all requests, unless other headers are given + explicitly. + """ + + _encode_url_methods = {'DELETE', 'GET', 'HEAD', 'OPTIONS'} + + def __init__(self, headers=None): + self.headers = headers or {} + + def urlopen(self, method, url, body=None, headers=None, + encode_multipart=True, multipart_boundary=None, + **kw): # Abstract + raise NotImplementedError("Classes extending RequestMethods must implement " + "their own ``urlopen`` method.") + + def request(self, method, url, fields=None, headers=None, **urlopen_kw): + """ + Make a request using :meth:`urlopen` with the appropriate encoding of + ``fields`` based on the ``method`` used. + + This is a convenience method that requires the least amount of manual + effort. It can be used in most situations, while still having the + option to drop down to more specific methods when necessary, such as + :meth:`request_encode_url`, :meth:`request_encode_body`, + or even the lowest level :meth:`urlopen`. + """ + method = method.upper() + + urlopen_kw['request_url'] = url + + if method in self._encode_url_methods: + return self.request_encode_url(method, url, fields=fields, + headers=headers, + **urlopen_kw) + else: + return self.request_encode_body(method, url, fields=fields, + headers=headers, + **urlopen_kw) + + def request_encode_url(self, method, url, fields=None, headers=None, + **urlopen_kw): + """ + Make a request using :meth:`urlopen` with the ``fields`` encoded in + the url. This is useful for request methods like GET, HEAD, DELETE, etc. + """ + if headers is None: + headers = self.headers + + extra_kw = {'headers': headers} + extra_kw.update(urlopen_kw) + + if fields: + url += '?' + urlencode(fields) + + return self.urlopen(method, url, **extra_kw) + + def request_encode_body(self, method, url, fields=None, headers=None, + encode_multipart=True, multipart_boundary=None, + **urlopen_kw): + """ + Make a request using :meth:`urlopen` with the ``fields`` encoded in + the body. This is useful for request methods like POST, PUT, PATCH, etc. + + When ``encode_multipart=True`` (default), then + :meth:`urllib3.filepost.encode_multipart_formdata` is used to encode + the payload with the appropriate content type. Otherwise + :meth:`urllib.urlencode` is used with the + 'application/x-www-form-urlencoded' content type. + + Multipart encoding must be used when posting files, and it's reasonably + safe to use it in other times too. However, it may break request + signing, such as with OAuth. + + Supports an optional ``fields`` parameter of key/value strings AND + key/filetuple. A filetuple is a (filename, data, MIME type) tuple where + the MIME type is optional. For example:: + + fields = { + 'foo': 'bar', + 'fakefile': ('foofile.txt', 'contents of foofile'), + 'realfile': ('barfile.txt', open('realfile').read()), + 'typedfile': ('bazfile.bin', open('bazfile').read(), + 'image/jpeg'), + 'nonamefile': 'contents of nonamefile field', + } + + When uploading a file, providing a filename (the first parameter of the + tuple) is optional but recommended to best mimic behavior of browsers. + + Note that if ``headers`` are supplied, the 'Content-Type' header will + be overwritten because it depends on the dynamic random boundary string + which is used to compose the body of the request. The random boundary + string can be explicitly set with the ``multipart_boundary`` parameter. + """ + if headers is None: + headers = self.headers + + extra_kw = {'headers': {}} + + if fields: + if 'body' in urlopen_kw: + raise TypeError( + "request got values for both 'fields' and 'body', can only specify one.") + + if encode_multipart: + body, content_type = encode_multipart_formdata(fields, boundary=multipart_boundary) + else: + body, content_type = urlencode(fields), 'application/x-www-form-urlencoded' + + extra_kw['body'] = body + extra_kw['headers'] = {'Content-Type': content_type} + + extra_kw['headers'].update(headers) + extra_kw.update(urlopen_kw) + + return self.urlopen(method, url, **extra_kw) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/response.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/response.py new file mode 100644 index 0000000..4f85793 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/response.py @@ -0,0 +1,760 @@ +from __future__ import absolute_import +from contextlib import contextmanager +import zlib +import io +import logging +from socket import timeout as SocketTimeout +from socket import error as SocketError + +try: + import brotli +except ImportError: + brotli = None + +from ._collections import HTTPHeaderDict +from .exceptions import ( + BodyNotHttplibCompatible, ProtocolError, DecodeError, ReadTimeoutError, + ResponseNotChunked, IncompleteRead, InvalidHeader +) +from .packages.six import string_types as basestring, PY3 +from .packages.six.moves import http_client as httplib +from .connection import HTTPException, BaseSSLError +from .util.response import is_fp_closed, is_response_to_head + +log = logging.getLogger(__name__) + + +class DeflateDecoder(object): + + def __init__(self): + self._first_try = True + self._data = b'' + self._obj = zlib.decompressobj() + + def __getattr__(self, name): + return getattr(self._obj, name) + + def decompress(self, data): + if not data: + return data + + if not self._first_try: + return self._obj.decompress(data) + + self._data += data + try: + decompressed = self._obj.decompress(data) + if decompressed: + self._first_try = False + self._data = None + return decompressed + except zlib.error: + self._first_try = False + self._obj = zlib.decompressobj(-zlib.MAX_WBITS) + try: + return self.decompress(self._data) + finally: + self._data = None + + +class GzipDecoderState(object): + + FIRST_MEMBER = 0 + OTHER_MEMBERS = 1 + SWALLOW_DATA = 2 + + +class GzipDecoder(object): + + def __init__(self): + self._obj = zlib.decompressobj(16 + zlib.MAX_WBITS) + self._state = GzipDecoderState.FIRST_MEMBER + + def __getattr__(self, name): + return getattr(self._obj, name) + + def decompress(self, data): + ret = bytearray() + if self._state == GzipDecoderState.SWALLOW_DATA or not data: + return bytes(ret) + while True: + try: + ret += self._obj.decompress(data) + except zlib.error: + previous_state = self._state + # Ignore data after the first error + self._state = GzipDecoderState.SWALLOW_DATA + if previous_state == GzipDecoderState.OTHER_MEMBERS: + # Allow trailing garbage acceptable in other gzip clients + return bytes(ret) + raise + data = self._obj.unused_data + if not data: + return bytes(ret) + self._state = GzipDecoderState.OTHER_MEMBERS + self._obj = zlib.decompressobj(16 + zlib.MAX_WBITS) + + +if brotli is not None: + class BrotliDecoder(object): + # Supports both 'brotlipy' and 'Brotli' packages + # since they share an import name. The top branches + # are for 'brotlipy' and bottom branches for 'Brotli' + def __init__(self): + self._obj = brotli.Decompressor() + + def decompress(self, data): + if hasattr(self._obj, 'decompress'): + return self._obj.decompress(data) + return self._obj.process(data) + + def flush(self): + if hasattr(self._obj, 'flush'): + return self._obj.flush() + return b'' + + +class MultiDecoder(object): + """ + From RFC7231: + If one or more encodings have been applied to a representation, the + sender that applied the encodings MUST generate a Content-Encoding + header field that lists the content codings in the order in which + they were applied. + """ + + def __init__(self, modes): + self._decoders = [_get_decoder(m.strip()) for m in modes.split(',')] + + def flush(self): + return self._decoders[0].flush() + + def decompress(self, data): + for d in reversed(self._decoders): + data = d.decompress(data) + return data + + +def _get_decoder(mode): + if ',' in mode: + return MultiDecoder(mode) + + if mode == 'gzip': + return GzipDecoder() + + if brotli is not None and mode == 'br': + return BrotliDecoder() + + return DeflateDecoder() + + +class HTTPResponse(io.IOBase): + """ + HTTP Response container. + + Backwards-compatible to httplib's HTTPResponse but the response ``body`` is + loaded and decoded on-demand when the ``data`` property is accessed. This + class is also compatible with the Python standard library's :mod:`io` + module, and can hence be treated as a readable object in the context of that + framework. + + Extra parameters for behaviour not present in httplib.HTTPResponse: + + :param preload_content: + If True, the response's body will be preloaded during construction. + + :param decode_content: + If True, will attempt to decode the body based on the + 'content-encoding' header. + + :param original_response: + When this HTTPResponse wrapper is generated from an httplib.HTTPResponse + object, it's convenient to include the original for debug purposes. It's + otherwise unused. + + :param retries: + The retries contains the last :class:`~urllib3.util.retry.Retry` that + was used during the request. + + :param enforce_content_length: + Enforce content length checking. Body returned by server must match + value of Content-Length header, if present. Otherwise, raise error. + """ + + CONTENT_DECODERS = ['gzip', 'deflate'] + if brotli is not None: + CONTENT_DECODERS += ['br'] + REDIRECT_STATUSES = [301, 302, 303, 307, 308] + + def __init__(self, body='', headers=None, status=0, version=0, reason=None, + strict=0, preload_content=True, decode_content=True, + original_response=None, pool=None, connection=None, msg=None, + retries=None, enforce_content_length=False, + request_method=None, request_url=None): + + if isinstance(headers, HTTPHeaderDict): + self.headers = headers + else: + self.headers = HTTPHeaderDict(headers) + self.status = status + self.version = version + self.reason = reason + self.strict = strict + self.decode_content = decode_content + self.retries = retries + self.enforce_content_length = enforce_content_length + + self._decoder = None + self._body = None + self._fp = None + self._original_response = original_response + self._fp_bytes_read = 0 + self.msg = msg + self._request_url = request_url + + if body and isinstance(body, (basestring, bytes)): + self._body = body + + self._pool = pool + self._connection = connection + + if hasattr(body, 'read'): + self._fp = body + + # Are we using the chunked-style of transfer encoding? + self.chunked = False + self.chunk_left = None + tr_enc = self.headers.get('transfer-encoding', '').lower() + # Don't incur the penalty of creating a list and then discarding it + encodings = (enc.strip() for enc in tr_enc.split(",")) + if "chunked" in encodings: + self.chunked = True + + # Determine length of response + self.length_remaining = self._init_length(request_method) + + # If requested, preload the body. + if preload_content and not self._body: + self._body = self.read(decode_content=decode_content) + + def get_redirect_location(self): + """ + Should we redirect and where to? + + :returns: Truthy redirect location string if we got a redirect status + code and valid location. ``None`` if redirect status and no + location. ``False`` if not a redirect status code. + """ + if self.status in self.REDIRECT_STATUSES: + return self.headers.get('location') + + return False + + def release_conn(self): + if not self._pool or not self._connection: + return + + self._pool._put_conn(self._connection) + self._connection = None + + @property + def data(self): + # For backwords-compat with earlier urllib3 0.4 and earlier. + if self._body: + return self._body + + if self._fp: + return self.read(cache_content=True) + + @property + def connection(self): + return self._connection + + def isclosed(self): + return is_fp_closed(self._fp) + + def tell(self): + """ + Obtain the number of bytes pulled over the wire so far. May differ from + the amount of content returned by :meth:``HTTPResponse.read`` if bytes + are encoded on the wire (e.g, compressed). + """ + return self._fp_bytes_read + + def _init_length(self, request_method): + """ + Set initial length value for Response content if available. + """ + length = self.headers.get('content-length') + + if length is not None: + if self.chunked: + # This Response will fail with an IncompleteRead if it can't be + # received as chunked. This method falls back to attempt reading + # the response before raising an exception. + log.warning("Received response with both Content-Length and " + "Transfer-Encoding set. This is expressly forbidden " + "by RFC 7230 sec 3.3.2. Ignoring Content-Length and " + "attempting to process response as Transfer-Encoding: " + "chunked.") + return None + + try: + # RFC 7230 section 3.3.2 specifies multiple content lengths can + # be sent in a single Content-Length header + # (e.g. Content-Length: 42, 42). This line ensures the values + # are all valid ints and that as long as the `set` length is 1, + # all values are the same. Otherwise, the header is invalid. + lengths = set([int(val) for val in length.split(',')]) + if len(lengths) > 1: + raise InvalidHeader("Content-Length contained multiple " + "unmatching values (%s)" % length) + length = lengths.pop() + except ValueError: + length = None + else: + if length < 0: + length = None + + # Convert status to int for comparison + # In some cases, httplib returns a status of "_UNKNOWN" + try: + status = int(self.status) + except ValueError: + status = 0 + + # Check for responses that shouldn't include a body + if status in (204, 304) or 100 <= status < 200 or request_method == 'HEAD': + length = 0 + + return length + + def _init_decoder(self): + """ + Set-up the _decoder attribute if necessary. + """ + # Note: content-encoding value should be case-insensitive, per RFC 7230 + # Section 3.2 + content_encoding = self.headers.get('content-encoding', '').lower() + if self._decoder is None: + if content_encoding in self.CONTENT_DECODERS: + self._decoder = _get_decoder(content_encoding) + elif ',' in content_encoding: + encodings = [ + e.strip() for e in content_encoding.split(',') + if e.strip() in self.CONTENT_DECODERS] + if len(encodings): + self._decoder = _get_decoder(content_encoding) + + DECODER_ERROR_CLASSES = (IOError, zlib.error) + if brotli is not None: + DECODER_ERROR_CLASSES += (brotli.error,) + + def _decode(self, data, decode_content, flush_decoder): + """ + Decode the data passed in and potentially flush the decoder. + """ + if not decode_content: + return data + + try: + if self._decoder: + data = self._decoder.decompress(data) + except self.DECODER_ERROR_CLASSES as e: + content_encoding = self.headers.get('content-encoding', '').lower() + raise DecodeError( + "Received response with content-encoding: %s, but " + "failed to decode it." % content_encoding, e) + if flush_decoder: + data += self._flush_decoder() + + return data + + def _flush_decoder(self): + """ + Flushes the decoder. Should only be called if the decoder is actually + being used. + """ + if self._decoder: + buf = self._decoder.decompress(b'') + return buf + self._decoder.flush() + + return b'' + + @contextmanager + def _error_catcher(self): + """ + Catch low-level python exceptions, instead re-raising urllib3 + variants, so that low-level exceptions are not leaked in the + high-level api. + + On exit, release the connection back to the pool. + """ + clean_exit = False + + try: + try: + yield + + except SocketTimeout: + # FIXME: Ideally we'd like to include the url in the ReadTimeoutError but + # there is yet no clean way to get at it from this context. + raise ReadTimeoutError(self._pool, None, 'Read timed out.') + + except BaseSSLError as e: + # FIXME: Is there a better way to differentiate between SSLErrors? + if 'read operation timed out' not in str(e): # Defensive: + # This shouldn't happen but just in case we're missing an edge + # case, let's avoid swallowing SSL errors. + raise + + raise ReadTimeoutError(self._pool, None, 'Read timed out.') + + except (HTTPException, SocketError) as e: + # This includes IncompleteRead. + raise ProtocolError('Connection broken: %r' % e, e) + + # If no exception is thrown, we should avoid cleaning up + # unnecessarily. + clean_exit = True + finally: + # If we didn't terminate cleanly, we need to throw away our + # connection. + if not clean_exit: + # The response may not be closed but we're not going to use it + # anymore so close it now to ensure that the connection is + # released back to the pool. + if self._original_response: + self._original_response.close() + + # Closing the response may not actually be sufficient to close + # everything, so if we have a hold of the connection close that + # too. + if self._connection: + self._connection.close() + + # If we hold the original response but it's closed now, we should + # return the connection back to the pool. + if self._original_response and self._original_response.isclosed(): + self.release_conn() + + def read(self, amt=None, decode_content=None, cache_content=False): + """ + Similar to :meth:`httplib.HTTPResponse.read`, but with two additional + parameters: ``decode_content`` and ``cache_content``. + + :param amt: + How much of the content to read. If specified, caching is skipped + because it doesn't make sense to cache partial content as the full + response. + + :param decode_content: + If True, will attempt to decode the body based on the + 'content-encoding' header. + + :param cache_content: + If True, will save the returned data such that the same result is + returned despite of the state of the underlying file object. This + is useful if you want the ``.data`` property to continue working + after having ``.read()`` the file object. (Overridden if ``amt`` is + set.) + """ + self._init_decoder() + if decode_content is None: + decode_content = self.decode_content + + if self._fp is None: + return + + flush_decoder = False + data = None + + with self._error_catcher(): + if amt is None: + # cStringIO doesn't like amt=None + data = self._fp.read() + flush_decoder = True + else: + cache_content = False + data = self._fp.read(amt) + if amt != 0 and not data: # Platform-specific: Buggy versions of Python. + # Close the connection when no data is returned + # + # This is redundant to what httplib/http.client _should_ + # already do. However, versions of python released before + # December 15, 2012 (http://bugs.python.org/issue16298) do + # not properly close the connection in all cases. There is + # no harm in redundantly calling close. + self._fp.close() + flush_decoder = True + if self.enforce_content_length and self.length_remaining not in (0, None): + # This is an edge case that httplib failed to cover due + # to concerns of backward compatibility. We're + # addressing it here to make sure IncompleteRead is + # raised during streaming, so all calls with incorrect + # Content-Length are caught. + raise IncompleteRead(self._fp_bytes_read, self.length_remaining) + + if data: + self._fp_bytes_read += len(data) + if self.length_remaining is not None: + self.length_remaining -= len(data) + + data = self._decode(data, decode_content, flush_decoder) + + if cache_content: + self._body = data + + return data + + def stream(self, amt=2**16, decode_content=None): + """ + A generator wrapper for the read() method. A call will block until + ``amt`` bytes have been read from the connection or until the + connection is closed. + + :param amt: + How much of the content to read. The generator will return up to + much data per iteration, but may return less. This is particularly + likely when using compressed data. However, the empty string will + never be returned. + + :param decode_content: + If True, will attempt to decode the body based on the + 'content-encoding' header. + """ + if self.chunked and self.supports_chunked_reads(): + for line in self.read_chunked(amt, decode_content=decode_content): + yield line + else: + while not is_fp_closed(self._fp): + data = self.read(amt=amt, decode_content=decode_content) + + if data: + yield data + + @classmethod + def from_httplib(ResponseCls, r, **response_kw): + """ + Given an :class:`httplib.HTTPResponse` instance ``r``, return a + corresponding :class:`urllib3.response.HTTPResponse` object. + + Remaining parameters are passed to the HTTPResponse constructor, along + with ``original_response=r``. + """ + headers = r.msg + + if not isinstance(headers, HTTPHeaderDict): + if PY3: + headers = HTTPHeaderDict(headers.items()) + else: + # Python 2.7 + headers = HTTPHeaderDict.from_httplib(headers) + + # HTTPResponse objects in Python 3 don't have a .strict attribute + strict = getattr(r, 'strict', 0) + resp = ResponseCls(body=r, + headers=headers, + status=r.status, + version=r.version, + reason=r.reason, + strict=strict, + original_response=r, + **response_kw) + return resp + + # Backwards-compatibility methods for httplib.HTTPResponse + def getheaders(self): + return self.headers + + def getheader(self, name, default=None): + return self.headers.get(name, default) + + # Backwards compatibility for http.cookiejar + def info(self): + return self.headers + + # Overrides from io.IOBase + def close(self): + if not self.closed: + self._fp.close() + + if self._connection: + self._connection.close() + + @property + def closed(self): + if self._fp is None: + return True + elif hasattr(self._fp, 'isclosed'): + return self._fp.isclosed() + elif hasattr(self._fp, 'closed'): + return self._fp.closed + else: + return True + + def fileno(self): + if self._fp is None: + raise IOError("HTTPResponse has no file to get a fileno from") + elif hasattr(self._fp, "fileno"): + return self._fp.fileno() + else: + raise IOError("The file-like object this HTTPResponse is wrapped " + "around has no file descriptor") + + def flush(self): + if self._fp is not None and hasattr(self._fp, 'flush'): + return self._fp.flush() + + def readable(self): + # This method is required for `io` module compatibility. + return True + + def readinto(self, b): + # This method is required for `io` module compatibility. + temp = self.read(len(b)) + if len(temp) == 0: + return 0 + else: + b[:len(temp)] = temp + return len(temp) + + def supports_chunked_reads(self): + """ + Checks if the underlying file-like object looks like a + httplib.HTTPResponse object. We do this by testing for the fp + attribute. If it is present we assume it returns raw chunks as + processed by read_chunked(). + """ + return hasattr(self._fp, 'fp') + + def _update_chunk_length(self): + # First, we'll figure out length of a chunk and then + # we'll try to read it from socket. + if self.chunk_left is not None: + return + line = self._fp.fp.readline() + line = line.split(b';', 1)[0] + try: + self.chunk_left = int(line, 16) + except ValueError: + # Invalid chunked protocol response, abort. + self.close() + raise httplib.IncompleteRead(line) + + def _handle_chunk(self, amt): + returned_chunk = None + if amt is None: + chunk = self._fp._safe_read(self.chunk_left) + returned_chunk = chunk + self._fp._safe_read(2) # Toss the CRLF at the end of the chunk. + self.chunk_left = None + elif amt < self.chunk_left: + value = self._fp._safe_read(amt) + self.chunk_left = self.chunk_left - amt + returned_chunk = value + elif amt == self.chunk_left: + value = self._fp._safe_read(amt) + self._fp._safe_read(2) # Toss the CRLF at the end of the chunk. + self.chunk_left = None + returned_chunk = value + else: # amt > self.chunk_left + returned_chunk = self._fp._safe_read(self.chunk_left) + self._fp._safe_read(2) # Toss the CRLF at the end of the chunk. + self.chunk_left = None + return returned_chunk + + def read_chunked(self, amt=None, decode_content=None): + """ + Similar to :meth:`HTTPResponse.read`, but with an additional + parameter: ``decode_content``. + + :param amt: + How much of the content to read. If specified, caching is skipped + because it doesn't make sense to cache partial content as the full + response. + + :param decode_content: + If True, will attempt to decode the body based on the + 'content-encoding' header. + """ + self._init_decoder() + # FIXME: Rewrite this method and make it a class with a better structured logic. + if not self.chunked: + raise ResponseNotChunked( + "Response is not chunked. " + "Header 'transfer-encoding: chunked' is missing.") + if not self.supports_chunked_reads(): + raise BodyNotHttplibCompatible( + "Body should be httplib.HTTPResponse like. " + "It should have have an fp attribute which returns raw chunks.") + + with self._error_catcher(): + # Don't bother reading the body of a HEAD request. + if self._original_response and is_response_to_head(self._original_response): + self._original_response.close() + return + + # If a response is already read and closed + # then return immediately. + if self._fp.fp is None: + return + + while True: + self._update_chunk_length() + if self.chunk_left == 0: + break + chunk = self._handle_chunk(amt) + decoded = self._decode(chunk, decode_content=decode_content, + flush_decoder=False) + if decoded: + yield decoded + + if decode_content: + # On CPython and PyPy, we should never need to flush the + # decoder. However, on Jython we *might* need to, so + # lets defensively do it anyway. + decoded = self._flush_decoder() + if decoded: # Platform-specific: Jython. + yield decoded + + # Chunk content ends with \r\n: discard it. + while True: + line = self._fp.fp.readline() + if not line: + # Some sites may not end with '\r\n'. + break + if line == b'\r\n': + break + + # We read everything; close the "file". + if self._original_response: + self._original_response.close() + + def geturl(self): + """ + Returns the URL that was the source of this response. + If the request that generated this response redirected, this method + will return the final redirect location. + """ + if self.retries is not None and len(self.retries.history): + return self.retries.history[-1].redirect_location + else: + return self._request_url + + def __iter__(self): + buffer = [b""] + for chunk in self.stream(decode_content=True): + if b"\n" in chunk: + chunk = chunk.split(b"\n") + yield b"".join(buffer) + chunk[0] + b"\n" + for x in chunk[1:-1]: + yield x + b"\n" + if chunk[-1]: + buffer = [chunk[-1]] + else: + buffer = [] + else: + buffer.append(chunk) + if buffer: + yield b"".join(buffer) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__init__.py new file mode 100644 index 0000000..2914bb4 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__init__.py @@ -0,0 +1,56 @@ +from __future__ import absolute_import +# For backwards compatibility, provide imports that used to be here. +from .connection import is_connection_dropped +from .request import make_headers +from .response import is_fp_closed +from .ssl_ import ( + SSLContext, + HAS_SNI, + IS_PYOPENSSL, + IS_SECURETRANSPORT, + assert_fingerprint, + resolve_cert_reqs, + resolve_ssl_version, + ssl_wrap_socket, + PROTOCOL_TLS, +) +from .timeout import ( + current_time, + Timeout, +) + +from .retry import Retry +from .url import ( + get_host, + parse_url, + split_first, + Url, +) +from .wait import ( + wait_for_read, + wait_for_write +) + +__all__ = ( + 'HAS_SNI', + 'IS_PYOPENSSL', + 'IS_SECURETRANSPORT', + 'SSLContext', + 'PROTOCOL_TLS', + 'Retry', + 'Timeout', + 'Url', + 'assert_fingerprint', + 'current_time', + 'is_connection_dropped', + 'is_fp_closed', + 'get_host', + 'parse_url', + 'make_headers', + 'resolve_cert_reqs', + 'resolve_ssl_version', + 'split_first', + 'ssl_wrap_socket', + 'wait_for_read', + 'wait_for_write' +) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..49531036229254d92a4d3e4a2498a4af38b1189d GIT binary patch literal 1032 zcmZ9K%Wl&^6o#Fvb8(t9Y1*`<1&LK8iUUZMiV&izDp9FQqBvbJn~@t&8q*ou%#72^ z+pvQj&of(AeE}A%IL8&VVl01}bH<+e&p+p^(WqH4e*O6Bzb#tUPYfQ9JOm%$Ro?)C z738=jawM0tf_zZmc~KyRY+mF=Q6i;mUgBk86FZxic|}x7Rn$mL)Ja`9#1ReB5G!Ow zG)YsmNK34e)$CiFw?&6^#2Q)4;tKDIb+Vq#t9(QBNKb5%O|eC`#5UQ^@-_ZM?2sL? zOLifylc#~>S^dTxsI~ez)AY|(%u~&1D3Vy}yWD-g8!9@BqlnFP7)LaaagwkAesF|; z$>@Ul0h0=2_;8-k8IKjLS53|HPLJY9vukbakB1)hh9|~3@#y%|XnZ_`RnvyZJ3cy_ z98V{QLvK8qOikNYib+l9VRXS{BEv|VRmnixlF=EiNcKgU&fk<$oGw8Dh%-$LuB4w( z70)i2HqLl5nvRY}r*wMi_4CG=rBbp;QymIs>?tr#HHa@wn3gyFqN!XkO&77!rkeOt zF`7zl>MG$ON|KN-oJkH_HLiS2#S--Rfm!(%Udd3iepgn&KUqa!-$)zLM6?mBh;>9A z(Lz91S+b1iAl48igo9`xx`-9T2BHTT_Me#=rSnv$l2IzL4^8di%Cc>Z4X&k3>1;z& z0r!$P0;BObQ$*kH75=9>6Zdd@b}|-WY;+L3yH}3Yn36;fv+_&<Y<pBiCL60YMfB-G zys;_uIj8iyC7;83hTlsU?tSTN<}Q8d&SQ=(<{n(T7xZ8$#clL@{&}!iT;JYOez1SO zkOLSOkvnyhFxd+urD4y#!C-%RvwW3eGJBy<q9B$oXyf7e8#mP<cPR}cxJddkxiOV@ cA`Vi{-ed18yeB8`<nVb>Z<U-}uiPsA0R@&9K>z>% literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/connection.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/connection.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f954b98ab7f34a61d5b7a5baf7b0416d20500fee GIT binary patch literal 3205 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/queue.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/queue.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c95c4c5731d2118b5a512b62cd2bbecd62d108fa GIT binary patch literal 1077 zcmZ`&J#X7E5G6%PRubo<ZTcfL#Bx)hK!BnM&;nhGpheoDS_s9Y9l5lmkdlxX-jW{@ zkJ<WrxOU3er9-FQ(QqIn=mGa|yc78D-cjGSw>JscpP$R@Hznj39=hhk;TYU}01!k_ zMN%R>!4#c&sYfyP6`T2~Pl@!VfgZT8!nF61h(LrlM1<0xhSw~O1U)5j?;dU<C-)v; zOf56{<sG%bMI#$I!cx~59FD=w5I~ZY3X*z)3h#!bO!{LgnDB3C8my?&Q1nCuwVv1j zs!hA`DIb?#+||gpHjL5VgPR?In%vSQSrG0Ca!T&#NzClls8mXh>bxwB4TOXabpYSS zp7o7XV@vrR(S6ALHA$uOHmhaQW;z*{N=R*zqswH%k6JyO7l-5N@cjI8KIiJ_&Dpsg zf=!C#Yf|OaL0*_TQ|e$ieA8aFuNq7`=dCP6sgp)4m7l#%nmSjB6KYUh*?{LoUT@(D zZZ<mKeVBIOYNP+oj7wk81(}j-*op4JQRAv(Ph-h4B?~v&3brv9@(YvCCCarX-0Kj! z;uA((pi_Ad0_3};3%aE6Za`<p3zVp;4YR6(an~LAc`av;Tkv_+)XzE%>~tD{(g>dL zgJJxzWH+#*Up^*gRawQ<&Ha>bBI|v)XFYJ24@xI-WFyXtY$iFko1D)|(I|}joL@AV zT2(Y^rgsrg2K@rzB?7*l4xr9D1i*Gp1Q5}P^;yJRHr~*fvr(0eeq<AAG|HPkUmpkX zFAZj83k4@B`~3aT2JZQ%`@AU{BgMK!mvy&x_+2}0+0on8DDO~3gY87LPy1fzMeHBR CmgdR; literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/request.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/request.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..417063d8c46f0a89a8ee6f116d543d3728548453 GIT binary patch literal 3359 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 Zy3VI6Z0{h)bWO*C|4Gz%?d`gE{|jsP#_#|D literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/response.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/response.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..702e66aeb97475b0e0d24832a1648ad04585ef00 GIT binary patch literal 2002 zcmZXVO>f&a7{^ITwiU%myA}h6V(5rr8(?6uvlS>%qZk%+0Wu8hf;HVs4pC{5vXxLT zB`G)dl*_W~zC&}|t)EBNo%#iK*kyZ2$*Z%<AVu-zA^AMN|Kq1yTLFUSuUA*}4z&I> zAM1|;A74UIrecU;fl_>oF=7sLg_F9+o^5-glXj20(C)DAZ|Jzkdd!En&o)>9?+v#3 z1P%JH!3rAS`Uah-T$GxJNm}Gmzc%|o|K?2VB8)`BGYy}&4mf389#W~2Y`QOHE+cGA zw2x`~P#!^10;*+Dp_k|i{fM3*4{3ZB$h#Ps-_Iy>enLyXLZ{B!=)-HHeHe8aKJ(XR zoUG5#9&;}7ub5%Djl0wVf#=bTM`wz>m~lPhl29^D<~$>DBKVF-&N#^@r##XmQ6v(% z;%pe$b>o6cnwrtE{Wi9aX8i4iIwz6YV`!&6UJjmSbRsx`e#SMIX_E2(wvUUojRu|C zPgJvOy}hTkOeWxU>&d#?_B(M=2R~3zHvQmt7tZttl6~;#-}6x+lR4FVG^cVD=K=zv zMi0(M)9}GurpxT}_;hzRJ6|qC@!<YsCU@bPW}~A~krX>grZg2|XLtAhd@=v5G@Z7D z;3AgGQ7MH;Cih0APQ*xZRpgoC!(vhQ6BWjW1>>=v3Gf}Lkngww-o{<Was1}(_U&74 z!{{|SI?!Q?rDF~ajVfT`)VXxjT@7)5>FG{|F7XvMG1cA5Qhn)OG;NQ$&<4&g+{%$B zKvwSxsgugNL>C^|^0covVz35d9?Zciu3RZ~P~pmDo!=ec#05^e^bkO`vD;IMOTEU5 z5M*W<S7b)#oJ=^7qsl1aO2wrR3j&Z>WDFhq=UUPT*7GdN%M3!#8R142io`Nc2>?jI ziKWmakL^;>&1#1hyYDiv`XZNrY@U(Bg`UCd-gPG1GmS|jKxI&ybD6}8hQYC36ntfO zOr9CpLKue!M@NU>!qMrJKU-OpG*MiUHqb+U9`Qma5a!|A>V6}HuiqTMy&#n!4Y)PP z$M|CTAwMrbR^Wlv?(NQ>l4-8VFS{4Ry2p47bJXK{bINsC(1pk;8#wX?;81UsS>xT1 zQB4P%b&x=w0bsL;*S*$iy}5R&dgBN#-pVJ=WlDAJ8DG>ruunl>mfI8pkbr4jcP0zX zRqZM*rC|{S*=wC^&meC?r+mkprq`a%%C4!lO#i#oLK8O2;0`t!egZ@4eW=jQKJMb~ zKV8s4-|?{L`k;<&?14VyT^PTn36p1CC{`06K?5=#0^V_jwITVv3Ub?-^8{7+rF#W> zFm1?mudL7im+2bXo|jx%+^9j%>K9m64a$@p?C*WGBe|W`MDBoQOaKvP`SUWdAjV{` zDE6}{WU>`Ea8byPQJ!TD6%BLtn~Wm?UKwBG?)!H0XZEPC%`I!s>^|`7UYJ61&Y8Sr zdfg<0$dpCF<-n=^)v4=lJIUm|wE*0POthL4>f8q68<?WZUk}>o;sArIO+X$Gf;tGp zxYVWOVJMBak8c$;Is-wdp-Rq&X+GyldN3ewLsbWF^k4z8Y0SpWT3my{p2`y8KTLC0 V3jT%p|5N4<+=RaG`XBfo{|hudELH#j literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/retry.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/retry.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..38b2a667ca50939b76c84983fd77881f728eb46f GIT binary patch literal 12953 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 D`%OSZ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d78ef6bddee046969c9827a840069ec77715048d GIT binary patch literal 9831 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 be>Fb}D_v2(FMKH8l*bJbp6?2u<cI$kQ+}Ua literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/timeout.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/timeout.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ef3aae1eb62842ae536c7fce6da15cfd526f9e47 GIT binary patch literal 8833 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 JTC1*9{sVp89Pa=C literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/url.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/url.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..691476be0e008d1976f8b7f33924e0d6e634c1f2 GIT binary patch literal 7898 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 z¥Rr<3gZo4C&YTG>69WJtrn`!aZ28-?Gf{JrnxoLN5)ZO{EijeKyqK<hw#74?g0 zoj2J?FBcdr-^<Ai3*}5qSOkTlg!Pj<s=WWGf4_u#X8m%1?BB*S^t7V}8q1?!uHWlI z|9%nsF#b&rc3{H!J^a2@(19BTTDmgGp*Sh#WmZK7|CPrj;Hk$JA(%8n1|>&mIOjH? z6y(|@C5STVh(z}(0gB@w#=aX%_z#cpzUTTZlD-mfXA{nWrT82epZrUjIg!DNgx#F{ z<{+&ijg0R(LEQJcz{K2Xkt3xTph6iTO2f#JgDB{gOGrK0L-=Mmu$R*TfDqEFRe<9v zk3n8iecb2#3U@90P@d_BgbLWx*)#`rL&gShu>`np%<P93Xrj3H25k+h0QEO!`XR>^ z3rK%I?jZMmfcriPVD|%l{Q%FD=Bqd&tVsE#-M)_((m)|F3IC&P`m1<pK^TvP%Glxt z!52IX`E|8&`H)E>yh^EvWim-$p-2?|^B8WKY0pr<2W8(;`OmwPz?z1ywzOWVqGzC@ zI!wczzJelkxubriey#-CXA0C>U567V$B9%Xl9}J=pMr$}N4uWGsAM?GOq6Nx7>pz! zP|R0fnj*nyIYq)9Yna%VlSt)(9CT3GF#cM5Vql=kDG!L-1G;HKE6oe_B`i~T&-bF3 zH0kEQqF+R`vx=s4uMSVV^d99-{OD%MV}a9m2m6it1f(Y=bVdETbB_WEmWN718Z<xv z1XpLM+YAx~6w9n&hFOB!^_Y^4>>Zn<HR@ihQkXw;DViZ|r8Iy;X;_b0_wQ8~EZ<pm zeabpI!L}Gd%CFQ<_wmPAh#0vqbMP`#&NFD?_o+BX@A5=oka#!9{>U*${olxeMgI%N zMU=u+RHO(I7>?twp+2cjsok^Rzhg2!6?w|HhaBm^{ZyGuh|+h0(F44=1gwY7p5O|3 zOUk516vF{ADufsr#Nn4pbQv-rapR5_U53CRAR=TY#R#cfLO}RJQ1Bv|D-G%{r=U!X zta^dNx9xZvR+jb$GDCU!Z;_$}ib!LibX#N&atv5UMj3KM0ket-%PR2t26m#LcK5Bt zzL*>uRLuQ=XuUWqqe#91+H$6xz_u7&2L5`mXfG{(u=p8d2KcJp<m2>e<o?qAAwbK> zcuK-E{vo~1uOSW9W{@yWxLb^(_mbOiIbe}1@rfurTv++gzWd?A(y|!&vqy_dpZ6ce z-(Onz-~r)3`I37eAoofXKB12Ssf3a35C!gd_#n{WVJj863F<3F?nL$Dr3VWi-LEa& z`DoEj*Rd?}`}mdiQ5-`QSl_UvltWJJupuVye*EC!$5rBAU3jp#EKK<pIF=KHIwDHK zq;!iHz+(>6?+9e@5htGp{7qt$Poo%*dm@Jd-;5e!tm#DdP(nqH@Fcb8`|LuVvI>bQ zCGB~O3Mm%(q4@tD+M-ny%5ejLa6E^YNHa%CQ4kd=S%5?Q|JTSCq~c8L$h#XSRWp-? zG9ik3VQAX_nfjzUoz1G$+eAxNGmO!k1|g&WNwnksKm2QOIiw_H!%0c*;)*CiOiF=( z2Z`-<wLJ+4iNFe1nhnspKau$2-Y^d!Kl@lOecOS{j{xOa3L^M42p0{>J(c8HG|0>` z63AuLh1x!9Nz64jw#g@+A(bIRs{lCjU*QgoliGQKk~@tKeValKhL$2U?uwCm==-ir zuST2}CkpQ1i(n*$3>hALba2+(DAg1a@Y)-Lw$dO{Ixvc4RSM4^=r%m<h?7LtCXW*0 zBQ%-<qg217_96Q4Z6}U-#D9i2B1c}u^IhJirxTB=ON+~kOP?&>OLfRzUR)7V%a88Z z_ZC08|KR@0;?gp;aY_#Hr&MfFL1!p~XsM#<meZac*j_1#QV7lWQg?C_TbyR}(yZMm bByAFsbW)!(418#qR>$?}W%FX;oEiK-QUwbr literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/wait.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/__pycache__/wait.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..14a15167cb5b2001e34f31a40cb8762a423f624a GIT binary patch literal 3126 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/connection.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/connection.py new file mode 100644 index 0000000..5ad70b2 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/connection.py @@ -0,0 +1,134 @@ +from __future__ import absolute_import +import socket +from .wait import NoWayToWaitForSocketError, wait_for_read +from ..contrib import _appengine_environ + + +def is_connection_dropped(conn): # Platform-specific + """ + Returns True if the connection is dropped and should be closed. + + :param conn: + :class:`httplib.HTTPConnection` object. + + Note: For platforms like AppEngine, this will always return ``False`` to + let the platform handle connection recycling transparently for us. + """ + sock = getattr(conn, 'sock', False) + if sock is False: # Platform-specific: AppEngine + return False + if sock is None: # Connection already closed (such as by httplib). + return True + try: + # Returns True if readable, which here means it's been dropped + return wait_for_read(sock, timeout=0.0) + except NoWayToWaitForSocketError: # Platform-specific: AppEngine + return False + + +# This function is copied from socket.py in the Python 2.7 standard +# library test suite. Added to its signature is only `socket_options`. +# One additional modification is that we avoid binding to IPv6 servers +# discovered in DNS if the system doesn't have IPv6 functionality. +def create_connection(address, timeout=socket._GLOBAL_DEFAULT_TIMEOUT, + source_address=None, socket_options=None): + """Connect to *address* and return the socket object. + + Convenience function. Connect to *address* (a 2-tuple ``(host, + port)``) and return the socket object. Passing the optional + *timeout* parameter will set the timeout on the socket instance + before attempting to connect. If no *timeout* is supplied, the + global default timeout setting returned by :func:`getdefaulttimeout` + is used. If *source_address* is set it must be a tuple of (host, port) + for the socket to bind as a source address before making the connection. + An host of '' or port 0 tells the OS to use the default. + """ + + host, port = address + if host.startswith('['): + host = host.strip('[]') + err = None + + # Using the value from allowed_gai_family() in the context of getaddrinfo lets + # us select whether to work with IPv4 DNS records, IPv6 records, or both. + # The original create_connection function always returns all records. + family = allowed_gai_family() + + for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): + af, socktype, proto, canonname, sa = res + sock = None + try: + sock = socket.socket(af, socktype, proto) + + # If provided, set socket level options before connecting. + _set_socket_options(sock, socket_options) + + if timeout is not socket._GLOBAL_DEFAULT_TIMEOUT: + sock.settimeout(timeout) + if source_address: + sock.bind(source_address) + sock.connect(sa) + return sock + + except socket.error as e: + err = e + if sock is not None: + sock.close() + sock = None + + if err is not None: + raise err + + raise socket.error("getaddrinfo returns an empty list") + + +def _set_socket_options(sock, options): + if options is None: + return + + for opt in options: + sock.setsockopt(*opt) + + +def allowed_gai_family(): + """This function is designed to work in the context of + getaddrinfo, where family=socket.AF_UNSPEC is the default and + will perform a DNS search for both IPv6 and IPv4 records.""" + + family = socket.AF_INET + if HAS_IPV6: + family = socket.AF_UNSPEC + return family + + +def _has_ipv6(host): + """ Returns True if the system can bind an IPv6 address. """ + sock = None + has_ipv6 = False + + # App Engine doesn't support IPV6 sockets and actually has a quota on the + # number of sockets that can be used, so just early out here instead of + # creating a socket needlessly. + # See https://github.com/urllib3/urllib3/issues/1446 + if _appengine_environ.is_appengine_sandbox(): + return False + + if socket.has_ipv6: + # has_ipv6 returns true if cPython was compiled with IPv6 support. + # It does not tell us if the system has IPv6 support enabled. To + # determine that we must bind to an IPv6 address. + # https://github.com/shazow/urllib3/pull/611 + # https://bugs.python.org/issue658327 + try: + sock = socket.socket(socket.AF_INET6) + sock.bind((host, 0)) + has_ipv6 = True + except Exception: + pass + + if sock: + sock.close() + return has_ipv6 + + +HAS_IPV6 = _has_ipv6('::1') diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/queue.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/queue.py new file mode 100644 index 0000000..d3d379a --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/queue.py @@ -0,0 +1,21 @@ +import collections +from ..packages import six +from ..packages.six.moves import queue + +if six.PY2: + # Queue is imported for side effects on MS Windows. See issue #229. + import Queue as _unused_module_Queue # noqa: F401 + + +class LifoQueue(queue.Queue): + def _init(self, _): + self.queue = collections.deque() + + def _qsize(self, len=len): + return len(self.queue) + + def _put(self, item): + self.queue.append(item) + + def _get(self): + return self.queue.pop() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/request.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/request.py new file mode 100644 index 0000000..280b853 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/request.py @@ -0,0 +1,125 @@ +from __future__ import absolute_import +from base64 import b64encode + +from ..packages.six import b, integer_types +from ..exceptions import UnrewindableBodyError + +ACCEPT_ENCODING = 'gzip,deflate' +try: + import brotli as _unused_module_brotli # noqa: F401 +except ImportError: + pass +else: + ACCEPT_ENCODING += ',br' + +_FAILEDTELL = object() + + +def make_headers(keep_alive=None, accept_encoding=None, user_agent=None, + basic_auth=None, proxy_basic_auth=None, disable_cache=None): + """ + Shortcuts for generating request headers. + + :param keep_alive: + If ``True``, adds 'connection: keep-alive' header. + + :param accept_encoding: + Can be a boolean, list, or string. + ``True`` translates to 'gzip,deflate'. + List will get joined by comma. + String will be used as provided. + + :param user_agent: + String representing the user-agent you want, such as + "python-urllib3/0.6" + + :param basic_auth: + Colon-separated username:password string for 'authorization: basic ...' + auth header. + + :param proxy_basic_auth: + Colon-separated username:password string for 'proxy-authorization: basic ...' + auth header. + + :param disable_cache: + If ``True``, adds 'cache-control: no-cache' header. + + Example:: + + >>> make_headers(keep_alive=True, user_agent="Batman/1.0") + {'connection': 'keep-alive', 'user-agent': 'Batman/1.0'} + >>> make_headers(accept_encoding=True) + {'accept-encoding': 'gzip,deflate'} + """ + headers = {} + if accept_encoding: + if isinstance(accept_encoding, str): + pass + elif isinstance(accept_encoding, list): + accept_encoding = ','.join(accept_encoding) + else: + accept_encoding = ACCEPT_ENCODING + headers['accept-encoding'] = accept_encoding + + if user_agent: + headers['user-agent'] = user_agent + + if keep_alive: + headers['connection'] = 'keep-alive' + + if basic_auth: + headers['authorization'] = 'Basic ' + \ + b64encode(b(basic_auth)).decode('utf-8') + + if proxy_basic_auth: + headers['proxy-authorization'] = 'Basic ' + \ + b64encode(b(proxy_basic_auth)).decode('utf-8') + + if disable_cache: + headers['cache-control'] = 'no-cache' + + return headers + + +def set_file_position(body, pos): + """ + If a position is provided, move file to that point. + Otherwise, we'll attempt to record a position for future use. + """ + if pos is not None: + rewind_body(body, pos) + elif getattr(body, 'tell', None) is not None: + try: + pos = body.tell() + except (IOError, OSError): + # This differentiates from None, allowing us to catch + # a failed `tell()` later when trying to rewind the body. + pos = _FAILEDTELL + + return pos + + +def rewind_body(body, body_pos): + """ + Attempt to rewind body to a certain position. + Primarily used for request redirects and retries. + + :param body: + File-like object that supports seek. + + :param int pos: + Position to seek to in file. + """ + body_seek = getattr(body, 'seek', None) + if body_seek is not None and isinstance(body_pos, integer_types): + try: + body_seek(body_pos) + except (IOError, OSError): + raise UnrewindableBodyError("An error occurred when rewinding request " + "body for redirect/retry.") + elif body_pos is _FAILEDTELL: + raise UnrewindableBodyError("Unable to record file position for rewinding " + "request body during a redirect/retry.") + else: + raise ValueError("body_pos must be of type integer, " + "instead it was %s." % type(body_pos)) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/response.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/response.py new file mode 100644 index 0000000..3d54864 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/response.py @@ -0,0 +1,87 @@ +from __future__ import absolute_import +from ..packages.six.moves import http_client as httplib + +from ..exceptions import HeaderParsingError + + +def is_fp_closed(obj): + """ + Checks whether a given file-like object is closed. + + :param obj: + The file-like object to check. + """ + + try: + # Check `isclosed()` first, in case Python3 doesn't set `closed`. + # GH Issue #928 + return obj.isclosed() + except AttributeError: + pass + + try: + # Check via the official file-like-object way. + return obj.closed + except AttributeError: + pass + + try: + # Check if the object is a container for another file-like object that + # gets released on exhaustion (e.g. HTTPResponse). + return obj.fp is None + except AttributeError: + pass + + raise ValueError("Unable to determine whether fp is closed.") + + +def assert_header_parsing(headers): + """ + Asserts whether all headers have been successfully parsed. + Extracts encountered errors from the result of parsing headers. + + Only works on Python 3. + + :param headers: Headers to verify. + :type headers: `httplib.HTTPMessage`. + + :raises urllib3.exceptions.HeaderParsingError: + If parsing errors are found. + """ + + # This will fail silently if we pass in the wrong kind of parameter. + # To make debugging easier add an explicit check. + if not isinstance(headers, httplib.HTTPMessage): + raise TypeError('expected httplib.Message, got {0}.'.format( + type(headers))) + + defects = getattr(headers, 'defects', None) + get_payload = getattr(headers, 'get_payload', None) + + unparsed_data = None + if get_payload: + # get_payload is actually email.message.Message.get_payload; + # we're only interested in the result if it's not a multipart message + if not headers.is_multipart(): + payload = get_payload() + + if isinstance(payload, (bytes, str)): + unparsed_data = payload + + if defects or unparsed_data: + raise HeaderParsingError(defects=defects, unparsed_data=unparsed_data) + + +def is_response_to_head(response): + """ + Checks whether the request of a response has been a HEAD-request. + Handles the quirks of AppEngine. + + :param conn: + :type conn: :class:`httplib.HTTPResponse` + """ + # FIXME: Can we do this somehow without accessing private httplib _method? + method = response._method + if isinstance(method, int): # Platform-specific: Appengine + return method == 3 + return method.upper() == 'HEAD' diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/retry.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/retry.py new file mode 100644 index 0000000..02429ee --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/retry.py @@ -0,0 +1,412 @@ +from __future__ import absolute_import +import time +import logging +from collections import namedtuple +from itertools import takewhile +import email +import re + +from ..exceptions import ( + ConnectTimeoutError, + MaxRetryError, + ProtocolError, + ReadTimeoutError, + ResponseError, + InvalidHeader, +) +from ..packages import six + + +log = logging.getLogger(__name__) + + +# Data structure for representing the metadata of requests that result in a retry. +RequestHistory = namedtuple('RequestHistory', ["method", "url", "error", + "status", "redirect_location"]) + + +class Retry(object): + """ Retry configuration. + + Each retry attempt will create a new Retry object with updated values, so + they can be safely reused. + + Retries can be defined as a default for a pool:: + + retries = Retry(connect=5, read=2, redirect=5) + http = PoolManager(retries=retries) + response = http.request('GET', 'http://example.com/') + + Or per-request (which overrides the default for the pool):: + + response = http.request('GET', 'http://example.com/', retries=Retry(10)) + + Retries can be disabled by passing ``False``:: + + response = http.request('GET', 'http://example.com/', retries=False) + + Errors will be wrapped in :class:`~urllib3.exceptions.MaxRetryError` unless + retries are disabled, in which case the causing exception will be raised. + + :param int total: + Total number of retries to allow. Takes precedence over other counts. + + Set to ``None`` to remove this constraint and fall back on other + counts. It's a good idea to set this to some sensibly-high value to + account for unexpected edge cases and avoid infinite retry loops. + + Set to ``0`` to fail on the first retry. + + Set to ``False`` to disable and imply ``raise_on_redirect=False``. + + :param int connect: + How many connection-related errors to retry on. + + These are errors raised before the request is sent to the remote server, + which we assume has not triggered the server to process the request. + + Set to ``0`` to fail on the first retry of this type. + + :param int read: + How many times to retry on read errors. + + These errors are raised after the request was sent to the server, so the + request may have side-effects. + + Set to ``0`` to fail on the first retry of this type. + + :param int redirect: + How many redirects to perform. Limit this to avoid infinite redirect + loops. + + A redirect is a HTTP response with a status code 301, 302, 303, 307 or + 308. + + Set to ``0`` to fail on the first retry of this type. + + Set to ``False`` to disable and imply ``raise_on_redirect=False``. + + :param int status: + How many times to retry on bad status codes. + + These are retries made on responses, where status code matches + ``status_forcelist``. + + Set to ``0`` to fail on the first retry of this type. + + :param iterable method_whitelist: + Set of uppercased HTTP method verbs that we should retry on. + + By default, we only retry on methods which are considered to be + idempotent (multiple requests with the same parameters end with the + same state). See :attr:`Retry.DEFAULT_METHOD_WHITELIST`. + + Set to a ``False`` value to retry on any verb. + + :param iterable status_forcelist: + A set of integer HTTP status codes that we should force a retry on. + A retry is initiated if the request method is in ``method_whitelist`` + and the response status code is in ``status_forcelist``. + + By default, this is disabled with ``None``. + + :param float backoff_factor: + A backoff factor to apply between attempts after the second try + (most errors are resolved immediately by a second try without a + delay). urllib3 will sleep for:: + + {backoff factor} * (2 ** ({number of total retries} - 1)) + + seconds. If the backoff_factor is 0.1, then :func:`.sleep` will sleep + for [0.0s, 0.2s, 0.4s, ...] between retries. It will never be longer + than :attr:`Retry.BACKOFF_MAX`. + + By default, backoff is disabled (set to 0). + + :param bool raise_on_redirect: Whether, if the number of redirects is + exhausted, to raise a MaxRetryError, or to return a response with a + response code in the 3xx range. + + :param bool raise_on_status: Similar meaning to ``raise_on_redirect``: + whether we should raise an exception, or return a response, + if status falls in ``status_forcelist`` range and retries have + been exhausted. + + :param tuple history: The history of the request encountered during + each call to :meth:`~Retry.increment`. The list is in the order + the requests occurred. Each list item is of class :class:`RequestHistory`. + + :param bool respect_retry_after_header: + Whether to respect Retry-After header on status codes defined as + :attr:`Retry.RETRY_AFTER_STATUS_CODES` or not. + + :param iterable remove_headers_on_redirect: + Sequence of headers to remove from the request when a response + indicating a redirect is returned before firing off the redirected + request. + """ + + DEFAULT_METHOD_WHITELIST = frozenset([ + 'HEAD', 'GET', 'PUT', 'DELETE', 'OPTIONS', 'TRACE']) + + RETRY_AFTER_STATUS_CODES = frozenset([413, 429, 503]) + + DEFAULT_REDIRECT_HEADERS_BLACKLIST = frozenset(['Authorization']) + + #: Maximum backoff time. + BACKOFF_MAX = 120 + + def __init__(self, total=10, connect=None, read=None, redirect=None, status=None, + method_whitelist=DEFAULT_METHOD_WHITELIST, status_forcelist=None, + backoff_factor=0, raise_on_redirect=True, raise_on_status=True, + history=None, respect_retry_after_header=True, + remove_headers_on_redirect=DEFAULT_REDIRECT_HEADERS_BLACKLIST): + + self.total = total + self.connect = connect + self.read = read + self.status = status + + if redirect is False or total is False: + redirect = 0 + raise_on_redirect = False + + self.redirect = redirect + self.status_forcelist = status_forcelist or set() + self.method_whitelist = method_whitelist + self.backoff_factor = backoff_factor + self.raise_on_redirect = raise_on_redirect + self.raise_on_status = raise_on_status + self.history = history or tuple() + self.respect_retry_after_header = respect_retry_after_header + self.remove_headers_on_redirect = frozenset([ + h.lower() for h in remove_headers_on_redirect]) + + def new(self, **kw): + params = dict( + total=self.total, + connect=self.connect, read=self.read, redirect=self.redirect, status=self.status, + method_whitelist=self.method_whitelist, + status_forcelist=self.status_forcelist, + backoff_factor=self.backoff_factor, + raise_on_redirect=self.raise_on_redirect, + raise_on_status=self.raise_on_status, + history=self.history, + remove_headers_on_redirect=self.remove_headers_on_redirect + ) + params.update(kw) + return type(self)(**params) + + @classmethod + def from_int(cls, retries, redirect=True, default=None): + """ Backwards-compatibility for the old retries format.""" + if retries is None: + retries = default if default is not None else cls.DEFAULT + + if isinstance(retries, Retry): + return retries + + redirect = bool(redirect) and None + new_retries = cls(retries, redirect=redirect) + log.debug("Converted retries value: %r -> %r", retries, new_retries) + return new_retries + + def get_backoff_time(self): + """ Formula for computing the current backoff + + :rtype: float + """ + # We want to consider only the last consecutive errors sequence (Ignore redirects). + consecutive_errors_len = len(list(takewhile(lambda x: x.redirect_location is None, + reversed(self.history)))) + if consecutive_errors_len <= 1: + return 0 + + backoff_value = self.backoff_factor * (2 ** (consecutive_errors_len - 1)) + return min(self.BACKOFF_MAX, backoff_value) + + def parse_retry_after(self, retry_after): + # Whitespace: https://tools.ietf.org/html/rfc7230#section-3.2.4 + if re.match(r"^\s*[0-9]+\s*$", retry_after): + seconds = int(retry_after) + else: + retry_date_tuple = email.utils.parsedate(retry_after) + if retry_date_tuple is None: + raise InvalidHeader("Invalid Retry-After header: %s" % retry_after) + retry_date = time.mktime(retry_date_tuple) + seconds = retry_date - time.time() + + if seconds < 0: + seconds = 0 + + return seconds + + def get_retry_after(self, response): + """ Get the value of Retry-After in seconds. """ + + retry_after = response.getheader("Retry-After") + + if retry_after is None: + return None + + return self.parse_retry_after(retry_after) + + def sleep_for_retry(self, response=None): + retry_after = self.get_retry_after(response) + if retry_after: + time.sleep(retry_after) + return True + + return False + + def _sleep_backoff(self): + backoff = self.get_backoff_time() + if backoff <= 0: + return + time.sleep(backoff) + + def sleep(self, response=None): + """ Sleep between retry attempts. + + This method will respect a server's ``Retry-After`` response header + and sleep the duration of the time requested. If that is not present, it + will use an exponential backoff. By default, the backoff factor is 0 and + this method will return immediately. + """ + + if response: + slept = self.sleep_for_retry(response) + if slept: + return + + self._sleep_backoff() + + def _is_connection_error(self, err): + """ Errors when we're fairly sure that the server did not receive the + request, so it should be safe to retry. + """ + return isinstance(err, ConnectTimeoutError) + + def _is_read_error(self, err): + """ Errors that occur after the request has been started, so we should + assume that the server began processing it. + """ + return isinstance(err, (ReadTimeoutError, ProtocolError)) + + def _is_method_retryable(self, method): + """ Checks if a given HTTP method should be retried upon, depending if + it is included on the method whitelist. + """ + if self.method_whitelist and method.upper() not in self.method_whitelist: + return False + + return True + + def is_retry(self, method, status_code, has_retry_after=False): + """ Is this method/status code retryable? (Based on whitelists and control + variables such as the number of total retries to allow, whether to + respect the Retry-After header, whether this header is present, and + whether the returned status code is on the list of status codes to + be retried upon on the presence of the aforementioned header) + """ + if not self._is_method_retryable(method): + return False + + if self.status_forcelist and status_code in self.status_forcelist: + return True + + return (self.total and self.respect_retry_after_header and + has_retry_after and (status_code in self.RETRY_AFTER_STATUS_CODES)) + + def is_exhausted(self): + """ Are we out of retries? """ + retry_counts = (self.total, self.connect, self.read, self.redirect, self.status) + retry_counts = list(filter(None, retry_counts)) + if not retry_counts: + return False + + return min(retry_counts) < 0 + + def increment(self, method=None, url=None, response=None, error=None, + _pool=None, _stacktrace=None): + """ Return a new Retry object with incremented retry counters. + + :param response: A response object, or None, if the server did not + return a response. + :type response: :class:`~urllib3.response.HTTPResponse` + :param Exception error: An error encountered during the request, or + None if the response was received successfully. + + :return: A new ``Retry`` object. + """ + if self.total is False and error: + # Disabled, indicate to re-raise the error. + raise six.reraise(type(error), error, _stacktrace) + + total = self.total + if total is not None: + total -= 1 + + connect = self.connect + read = self.read + redirect = self.redirect + status_count = self.status + cause = 'unknown' + status = None + redirect_location = None + + if error and self._is_connection_error(error): + # Connect retry? + if connect is False: + raise six.reraise(type(error), error, _stacktrace) + elif connect is not None: + connect -= 1 + + elif error and self._is_read_error(error): + # Read retry? + if read is False or not self._is_method_retryable(method): + raise six.reraise(type(error), error, _stacktrace) + elif read is not None: + read -= 1 + + elif response and response.get_redirect_location(): + # Redirect retry? + if redirect is not None: + redirect -= 1 + cause = 'too many redirects' + redirect_location = response.get_redirect_location() + status = response.status + + else: + # Incrementing because of a server error like a 500 in + # status_forcelist and a the given method is in the whitelist + cause = ResponseError.GENERIC_ERROR + if response and response.status: + if status_count is not None: + status_count -= 1 + cause = ResponseError.SPECIFIC_ERROR.format( + status_code=response.status) + status = response.status + + history = self.history + (RequestHistory(method, url, error, status, redirect_location),) + + new_retry = self.new( + total=total, + connect=connect, read=read, redirect=redirect, status=status_count, + history=history) + + if new_retry.is_exhausted(): + raise MaxRetryError(_pool, url, error or ResponseError(cause)) + + log.debug("Incremented Retry for (url='%s'): %r", url, new_retry) + + return new_retry + + def __repr__(self): + return ('{cls.__name__}(total={self.total}, connect={self.connect}, ' + 'read={self.read}, redirect={self.redirect}, status={self.status})').format( + cls=type(self), self=self) + + +# For backwards compatibility (equivalent to pre-v1.9): +Retry.DEFAULT = Retry(3) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/ssl_.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/ssl_.py new file mode 100644 index 0000000..fbdef65 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/ssl_.py @@ -0,0 +1,392 @@ +from __future__ import absolute_import +import errno +import warnings +import hmac +import re + +from binascii import hexlify, unhexlify +from hashlib import md5, sha1, sha256 + +from ..exceptions import SSLError, InsecurePlatformWarning, SNIMissingWarning +from ..packages import six +from ..packages.rfc3986 import abnf_regexp + + +SSLContext = None +HAS_SNI = False +IS_PYOPENSSL = False +IS_SECURETRANSPORT = False + +# Maps the length of a digest to a possible hash function producing this digest +HASHFUNC_MAP = { + 32: md5, + 40: sha1, + 64: sha256, +} + + +def _const_compare_digest_backport(a, b): + """ + Compare two digests of equal length in constant time. + + The digests must be of type str/bytes. + Returns True if the digests match, and False otherwise. + """ + result = abs(len(a) - len(b)) + for l, r in zip(bytearray(a), bytearray(b)): + result |= l ^ r + return result == 0 + + +_const_compare_digest = getattr(hmac, 'compare_digest', + _const_compare_digest_backport) + +# Borrow rfc3986's regular expressions for IPv4 +# and IPv6 addresses for use in is_ipaddress() +_IP_ADDRESS_REGEX = re.compile( + r'^(?:%s|%s|%s)$' % ( + abnf_regexp.IPv4_RE, + abnf_regexp.IPv6_RE, + abnf_regexp.IPv6_ADDRZ_RFC4007_RE + ) +) + +try: # Test for SSL features + import ssl + from ssl import wrap_socket, CERT_REQUIRED + from ssl import HAS_SNI # Has SNI? +except ImportError: + pass + +try: # Platform-specific: Python 3.6 + from ssl import PROTOCOL_TLS + PROTOCOL_SSLv23 = PROTOCOL_TLS +except ImportError: + try: + from ssl import PROTOCOL_SSLv23 as PROTOCOL_TLS + PROTOCOL_SSLv23 = PROTOCOL_TLS + except ImportError: + PROTOCOL_SSLv23 = PROTOCOL_TLS = 2 + + +try: + from ssl import OP_NO_SSLv2, OP_NO_SSLv3, OP_NO_COMPRESSION +except ImportError: + OP_NO_SSLv2, OP_NO_SSLv3 = 0x1000000, 0x2000000 + OP_NO_COMPRESSION = 0x20000 + + +# A secure default. +# Sources for more information on TLS ciphers: +# +# - https://wiki.mozilla.org/Security/Server_Side_TLS +# - https://www.ssllabs.com/projects/best-practices/index.html +# - https://hynek.me/articles/hardening-your-web-servers-ssl-ciphers/ +# +# The general intent is: +# - prefer cipher suites that offer perfect forward secrecy (DHE/ECDHE), +# - prefer ECDHE over DHE for better performance, +# - prefer any AES-GCM and ChaCha20 over any AES-CBC for better performance and +# security, +# - prefer AES-GCM over ChaCha20 because hardware-accelerated AES is common, +# - disable NULL authentication, MD5 MACs, DSS, and other +# insecure ciphers for security reasons. +# - NOTE: TLS 1.3 cipher suites are managed through a different interface +# not exposed by CPython (yet!) and are enabled by default if they're available. +DEFAULT_CIPHERS = ':'.join([ + 'ECDHE+AESGCM', + 'ECDHE+CHACHA20', + 'DHE+AESGCM', + 'DHE+CHACHA20', + 'ECDH+AESGCM', + 'DH+AESGCM', + 'ECDH+AES', + 'DH+AES', + 'RSA+AESGCM', + 'RSA+AES', + '!aNULL', + '!eNULL', + '!MD5', + '!DSS', +]) + +try: + from ssl import SSLContext # Modern SSL? +except ImportError: + class SSLContext(object): # Platform-specific: Python 2 + def __init__(self, protocol_version): + self.protocol = protocol_version + # Use default values from a real SSLContext + self.check_hostname = False + self.verify_mode = ssl.CERT_NONE + self.ca_certs = None + self.options = 0 + self.certfile = None + self.keyfile = None + self.ciphers = None + + def load_cert_chain(self, certfile, keyfile): + self.certfile = certfile + self.keyfile = keyfile + + def load_verify_locations(self, cafile=None, capath=None): + self.ca_certs = cafile + + if capath is not None: + raise SSLError("CA directories not supported in older Pythons") + + def set_ciphers(self, cipher_suite): + self.ciphers = cipher_suite + + def wrap_socket(self, socket, server_hostname=None, server_side=False): + warnings.warn( + 'A true SSLContext object is not available. This prevents ' + 'urllib3 from configuring SSL appropriately and may cause ' + 'certain SSL connections to fail. You can upgrade to a newer ' + 'version of Python to solve this. For more information, see ' + 'https://urllib3.readthedocs.io/en/latest/advanced-usage.html' + '#ssl-warnings', + InsecurePlatformWarning + ) + kwargs = { + 'keyfile': self.keyfile, + 'certfile': self.certfile, + 'ca_certs': self.ca_certs, + 'cert_reqs': self.verify_mode, + 'ssl_version': self.protocol, + 'server_side': server_side, + } + return wrap_socket(socket, ciphers=self.ciphers, **kwargs) + + +def assert_fingerprint(cert, fingerprint): + """ + Checks if given fingerprint matches the supplied certificate. + + :param cert: + Certificate as bytes object. + :param fingerprint: + Fingerprint as string of hexdigits, can be interspersed by colons. + """ + + fingerprint = fingerprint.replace(':', '').lower() + digest_length = len(fingerprint) + hashfunc = HASHFUNC_MAP.get(digest_length) + if not hashfunc: + raise SSLError( + 'Fingerprint of invalid length: {0}'.format(fingerprint)) + + # We need encode() here for py32; works on py2 and p33. + fingerprint_bytes = unhexlify(fingerprint.encode()) + + cert_digest = hashfunc(cert).digest() + + if not _const_compare_digest(cert_digest, fingerprint_bytes): + raise SSLError('Fingerprints did not match. Expected "{0}", got "{1}".' + .format(fingerprint, hexlify(cert_digest))) + + +def resolve_cert_reqs(candidate): + """ + Resolves the argument to a numeric constant, which can be passed to + the wrap_socket function/method from the ssl module. + Defaults to :data:`ssl.CERT_NONE`. + If given a string it is assumed to be the name of the constant in the + :mod:`ssl` module or its abbreviation. + (So you can specify `REQUIRED` instead of `CERT_REQUIRED`. + If it's neither `None` nor a string we assume it is already the numeric + constant which can directly be passed to wrap_socket. + """ + if candidate is None: + return CERT_REQUIRED + + if isinstance(candidate, str): + res = getattr(ssl, candidate, None) + if res is None: + res = getattr(ssl, 'CERT_' + candidate) + return res + + return candidate + + +def resolve_ssl_version(candidate): + """ + like resolve_cert_reqs + """ + if candidate is None: + return PROTOCOL_TLS + + if isinstance(candidate, str): + res = getattr(ssl, candidate, None) + if res is None: + res = getattr(ssl, 'PROTOCOL_' + candidate) + return res + + return candidate + + +def create_urllib3_context(ssl_version=None, cert_reqs=None, + options=None, ciphers=None): + """All arguments have the same meaning as ``ssl_wrap_socket``. + + By default, this function does a lot of the same work that + ``ssl.create_default_context`` does on Python 3.4+. It: + + - Disables SSLv2, SSLv3, and compression + - Sets a restricted set of server ciphers + + If you wish to enable SSLv3, you can do:: + + from pip._vendor.urllib3.util import ssl_ + context = ssl_.create_urllib3_context() + context.options &= ~ssl_.OP_NO_SSLv3 + + You can do the same to enable compression (substituting ``COMPRESSION`` + for ``SSLv3`` in the last line above). + + :param ssl_version: + The desired protocol version to use. This will default to + PROTOCOL_SSLv23 which will negotiate the highest protocol that both + the server and your installation of OpenSSL support. + :param cert_reqs: + Whether to require the certificate verification. This defaults to + ``ssl.CERT_REQUIRED``. + :param options: + Specific OpenSSL options. These default to ``ssl.OP_NO_SSLv2``, + ``ssl.OP_NO_SSLv3``, ``ssl.OP_NO_COMPRESSION``. + :param ciphers: + Which cipher suites to allow the server to select. + :returns: + Constructed SSLContext object with specified options + :rtype: SSLContext + """ + context = SSLContext(ssl_version or PROTOCOL_TLS) + + context.set_ciphers(ciphers or DEFAULT_CIPHERS) + + # Setting the default here, as we may have no ssl module on import + cert_reqs = ssl.CERT_REQUIRED if cert_reqs is None else cert_reqs + + if options is None: + options = 0 + # SSLv2 is easily broken and is considered harmful and dangerous + options |= OP_NO_SSLv2 + # SSLv3 has several problems and is now dangerous + options |= OP_NO_SSLv3 + # Disable compression to prevent CRIME attacks for OpenSSL 1.0+ + # (issue #309) + options |= OP_NO_COMPRESSION + + context.options |= options + + context.verify_mode = cert_reqs + if getattr(context, 'check_hostname', None) is not None: # Platform-specific: Python 3.2 + # We do our own verification, including fingerprints and alternative + # hostnames. So disable it here + context.check_hostname = False + return context + + +def ssl_wrap_socket(sock, keyfile=None, certfile=None, cert_reqs=None, + ca_certs=None, server_hostname=None, + ssl_version=None, ciphers=None, ssl_context=None, + ca_cert_dir=None, key_password=None): + """ + All arguments except for server_hostname, ssl_context, and ca_cert_dir have + the same meaning as they do when using :func:`ssl.wrap_socket`. + + :param server_hostname: + When SNI is supported, the expected hostname of the certificate + :param ssl_context: + A pre-made :class:`SSLContext` object. If none is provided, one will + be created using :func:`create_urllib3_context`. + :param ciphers: + A string of ciphers we wish the client to support. + :param ca_cert_dir: + A directory containing CA certificates in multiple separate files, as + supported by OpenSSL's -CApath flag or the capath argument to + SSLContext.load_verify_locations(). + :param key_password: + Optional password if the keyfile is encrypted. + """ + context = ssl_context + if context is None: + # Note: This branch of code and all the variables in it are no longer + # used by urllib3 itself. We should consider deprecating and removing + # this code. + context = create_urllib3_context(ssl_version, cert_reqs, + ciphers=ciphers) + + if ca_certs or ca_cert_dir: + try: + context.load_verify_locations(ca_certs, ca_cert_dir) + except IOError as e: # Platform-specific: Python 2.7 + raise SSLError(e) + # Py33 raises FileNotFoundError which subclasses OSError + # These are not equivalent unless we check the errno attribute + except OSError as e: # Platform-specific: Python 3.3 and beyond + if e.errno == errno.ENOENT: + raise SSLError(e) + raise + + elif ssl_context is None and hasattr(context, 'load_default_certs'): + # try to load OS default certs; works well on Windows (require Python3.4+) + context.load_default_certs() + + # Attempt to detect if we get the goofy behavior of the + # keyfile being encrypted and OpenSSL asking for the + # passphrase via the terminal and instead error out. + if keyfile and key_password is None and _is_key_file_encrypted(keyfile): + raise SSLError("Client private key is encrypted, password is required") + + if certfile: + if key_password is None: + context.load_cert_chain(certfile, keyfile) + else: + context.load_cert_chain(certfile, keyfile, key_password) + + # If we detect server_hostname is an IP address then the SNI + # extension should not be used according to RFC3546 Section 3.1 + # We shouldn't warn the user if SNI isn't available but we would + # not be using SNI anyways due to IP address for server_hostname. + if ((server_hostname is not None and not is_ipaddress(server_hostname)) + or IS_SECURETRANSPORT): + if HAS_SNI and server_hostname is not None: + return context.wrap_socket(sock, server_hostname=server_hostname) + + warnings.warn( + 'An HTTPS request has been made, but the SNI (Server Name ' + 'Indication) extension to TLS is not available on this platform. ' + 'This may cause the server to present an incorrect TLS ' + 'certificate, which can cause validation failures. You can upgrade to ' + 'a newer version of Python to solve this. For more information, see ' + 'https://urllib3.readthedocs.io/en/latest/advanced-usage.html' + '#ssl-warnings', + SNIMissingWarning + ) + + return context.wrap_socket(sock) + + +def is_ipaddress(hostname): + """Detects whether the hostname given is an IPv4 or IPv6 address. + Also detects IPv6 addresses with Zone IDs. + + :param str hostname: Hostname to examine. + :return: True if the hostname is an IP address, False otherwise. + """ + if six.PY3 and isinstance(hostname, bytes): + # IDN A-label bytes are ASCII compatible. + hostname = hostname.decode('ascii') + return _IP_ADDRESS_REGEX.match(hostname) is not None + + +def _is_key_file_encrypted(key_file): + """Detects if a key file is encrypted or not.""" + with open(key_file, 'r') as f: + for line in f: + # Look for Proc-Type: 4,ENCRYPTED + if 'ENCRYPTED' in line: + return True + + return False diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/timeout.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/timeout.py new file mode 100644 index 0000000..a4d004a --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/timeout.py @@ -0,0 +1,243 @@ +from __future__ import absolute_import +# The default socket timeout, used by httplib to indicate that no timeout was +# specified by the user +from socket import _GLOBAL_DEFAULT_TIMEOUT +import time + +from ..exceptions import TimeoutStateError + +# A sentinel value to indicate that no timeout was specified by the user in +# urllib3 +_Default = object() + + +# Use time.monotonic if available. +current_time = getattr(time, "monotonic", time.time) + + +class Timeout(object): + """ Timeout configuration. + + Timeouts can be defined as a default for a pool:: + + timeout = Timeout(connect=2.0, read=7.0) + http = PoolManager(timeout=timeout) + response = http.request('GET', 'http://example.com/') + + Or per-request (which overrides the default for the pool):: + + response = http.request('GET', 'http://example.com/', timeout=Timeout(10)) + + Timeouts can be disabled by setting all the parameters to ``None``:: + + no_timeout = Timeout(connect=None, read=None) + response = http.request('GET', 'http://example.com/, timeout=no_timeout) + + + :param total: + This combines the connect and read timeouts into one; the read timeout + will be set to the time leftover from the connect attempt. In the + event that both a connect timeout and a total are specified, or a read + timeout and a total are specified, the shorter timeout will be applied. + + Defaults to None. + + :type total: integer, float, or None + + :param connect: + The maximum amount of time to wait for a connection attempt to a server + to succeed. Omitting the parameter will default the connect timeout to + the system default, probably `the global default timeout in socket.py + <http://hg.python.org/cpython/file/603b4d593758/Lib/socket.py#l535>`_. + None will set an infinite timeout for connection attempts. + + :type connect: integer, float, or None + + :param read: + The maximum amount of time to wait between consecutive + read operations for a response from the server. Omitting + the parameter will default the read timeout to the system + default, probably `the global default timeout in socket.py + <http://hg.python.org/cpython/file/603b4d593758/Lib/socket.py#l535>`_. + None will set an infinite timeout. + + :type read: integer, float, or None + + .. note:: + + Many factors can affect the total amount of time for urllib3 to return + an HTTP response. + + For example, Python's DNS resolver does not obey the timeout specified + on the socket. Other factors that can affect total request time include + high CPU load, high swap, the program running at a low priority level, + or other behaviors. + + In addition, the read and total timeouts only measure the time between + read operations on the socket connecting the client and the server, + not the total amount of time for the request to return a complete + response. For most requests, the timeout is raised because the server + has not sent the first byte in the specified time. This is not always + the case; if a server streams one byte every fifteen seconds, a timeout + of 20 seconds will not trigger, even though the request will take + several minutes to complete. + + If your goal is to cut off any request after a set amount of wall clock + time, consider having a second "watcher" thread to cut off a slow + request. + """ + + #: A sentinel object representing the default timeout value + DEFAULT_TIMEOUT = _GLOBAL_DEFAULT_TIMEOUT + + def __init__(self, total=None, connect=_Default, read=_Default): + self._connect = self._validate_timeout(connect, 'connect') + self._read = self._validate_timeout(read, 'read') + self.total = self._validate_timeout(total, 'total') + self._start_connect = None + + def __str__(self): + return '%s(connect=%r, read=%r, total=%r)' % ( + type(self).__name__, self._connect, self._read, self.total) + + @classmethod + def _validate_timeout(cls, value, name): + """ Check that a timeout attribute is valid. + + :param value: The timeout value to validate + :param name: The name of the timeout attribute to validate. This is + used to specify in error messages. + :return: The validated and casted version of the given value. + :raises ValueError: If it is a numeric value less than or equal to + zero, or the type is not an integer, float, or None. + """ + if value is _Default: + return cls.DEFAULT_TIMEOUT + + if value is None or value is cls.DEFAULT_TIMEOUT: + return value + + if isinstance(value, bool): + raise ValueError("Timeout cannot be a boolean value. It must " + "be an int, float or None.") + try: + float(value) + except (TypeError, ValueError): + raise ValueError("Timeout value %s was %s, but it must be an " + "int, float or None." % (name, value)) + + try: + if value <= 0: + raise ValueError("Attempted to set %s timeout to %s, but the " + "timeout cannot be set to a value less " + "than or equal to 0." % (name, value)) + except TypeError: + # Python 3 + raise ValueError("Timeout value %s was %s, but it must be an " + "int, float or None." % (name, value)) + + return value + + @classmethod + def from_float(cls, timeout): + """ Create a new Timeout from a legacy timeout value. + + The timeout value used by httplib.py sets the same timeout on the + connect(), and recv() socket requests. This creates a :class:`Timeout` + object that sets the individual timeouts to the ``timeout`` value + passed to this function. + + :param timeout: The legacy timeout value. + :type timeout: integer, float, sentinel default object, or None + :return: Timeout object + :rtype: :class:`Timeout` + """ + return Timeout(read=timeout, connect=timeout) + + def clone(self): + """ Create a copy of the timeout object + + Timeout properties are stored per-pool but each request needs a fresh + Timeout object to ensure each one has its own start/stop configured. + + :return: a copy of the timeout object + :rtype: :class:`Timeout` + """ + # We can't use copy.deepcopy because that will also create a new object + # for _GLOBAL_DEFAULT_TIMEOUT, which socket.py uses as a sentinel to + # detect the user default. + return Timeout(connect=self._connect, read=self._read, + total=self.total) + + def start_connect(self): + """ Start the timeout clock, used during a connect() attempt + + :raises urllib3.exceptions.TimeoutStateError: if you attempt + to start a timer that has been started already. + """ + if self._start_connect is not None: + raise TimeoutStateError("Timeout timer has already been started.") + self._start_connect = current_time() + return self._start_connect + + def get_connect_duration(self): + """ Gets the time elapsed since the call to :meth:`start_connect`. + + :return: Elapsed time. + :rtype: float + :raises urllib3.exceptions.TimeoutStateError: if you attempt + to get duration for a timer that hasn't been started. + """ + if self._start_connect is None: + raise TimeoutStateError("Can't get connect duration for timer " + "that has not started.") + return current_time() - self._start_connect + + @property + def connect_timeout(self): + """ Get the value to use when setting a connection timeout. + + This will be a positive float or integer, the value None + (never timeout), or the default system timeout. + + :return: Connect timeout. + :rtype: int, float, :attr:`Timeout.DEFAULT_TIMEOUT` or None + """ + if self.total is None: + return self._connect + + if self._connect is None or self._connect is self.DEFAULT_TIMEOUT: + return self.total + + return min(self._connect, self.total) + + @property + def read_timeout(self): + """ Get the value for the read timeout. + + This assumes some time has elapsed in the connection timeout and + computes the read timeout appropriately. + + If self.total is set, the read timeout is dependent on the amount of + time taken by the connect timeout. If the connection time has not been + established, a :exc:`~urllib3.exceptions.TimeoutStateError` will be + raised. + + :return: Value to use for the read timeout. + :rtype: int, float, :attr:`Timeout.DEFAULT_TIMEOUT` or None + :raises urllib3.exceptions.TimeoutStateError: If :meth:`start_connect` + has not yet been called on this object. + """ + if (self.total is not None and + self.total is not self.DEFAULT_TIMEOUT and + self._read is not None and + self._read is not self.DEFAULT_TIMEOUT): + # In case the connect timeout has not yet been established. + if self._start_connect is None: + return self._read + return max(0, min(self.total - self.get_connect_duration(), + self._read)) + elif self.total is not None and self.total is not self.DEFAULT_TIMEOUT: + return max(0, self.total - self.get_connect_duration()) + else: + return self._read diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/url.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/url.py new file mode 100644 index 0000000..aefa119 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/url.py @@ -0,0 +1,289 @@ +from __future__ import absolute_import +import re +from collections import namedtuple + +from ..exceptions import LocationParseError +from ..packages import six, rfc3986 +from ..packages.rfc3986.exceptions import RFC3986Exception, ValidationError +from ..packages.rfc3986.validators import Validator +from ..packages.rfc3986 import abnf_regexp, normalizers, compat, misc + + +url_attrs = ['scheme', 'auth', 'host', 'port', 'path', 'query', 'fragment'] + +# We only want to normalize urls with an HTTP(S) scheme. +# urllib3 infers URLs without a scheme (None) to be http. +NORMALIZABLE_SCHEMES = ('http', 'https', None) + +# Regex for detecting URLs with schemes. RFC 3986 Section 3.1 +SCHEME_REGEX = re.compile(r"^(?:[a-zA-Z][a-zA-Z0-9+\-]*:|/)") + +PATH_CHARS = abnf_regexp.UNRESERVED_CHARS_SET | abnf_regexp.SUB_DELIMITERS_SET | {':', '@', '/'} +QUERY_CHARS = FRAGMENT_CHARS = PATH_CHARS | {'?'} + + +class Url(namedtuple('Url', url_attrs)): + """ + Data structure for representing an HTTP URL. Used as a return value for + :func:`parse_url`. Both the scheme and host are normalized as they are + both case-insensitive according to RFC 3986. + """ + __slots__ = () + + def __new__(cls, scheme=None, auth=None, host=None, port=None, path=None, + query=None, fragment=None): + if path and not path.startswith('/'): + path = '/' + path + if scheme is not None: + scheme = scheme.lower() + return super(Url, cls).__new__(cls, scheme, auth, host, port, path, + query, fragment) + + @property + def hostname(self): + """For backwards-compatibility with urlparse. We're nice like that.""" + return self.host + + @property + def request_uri(self): + """Absolute path including the query string.""" + uri = self.path or '/' + + if self.query is not None: + uri += '?' + self.query + + return uri + + @property + def netloc(self): + """Network location including host and port""" + if self.port: + return '%s:%d' % (self.host, self.port) + return self.host + + @property + def url(self): + """ + Convert self into a url + + This function should more or less round-trip with :func:`.parse_url`. The + returned url may not be exactly the same as the url inputted to + :func:`.parse_url`, but it should be equivalent by the RFC (e.g., urls + with a blank port will have : removed). + + Example: :: + + >>> U = parse_url('http://google.com/mail/') + >>> U.url + 'http://google.com/mail/' + >>> Url('http', 'username:password', 'host.com', 80, + ... '/path', 'query', 'fragment').url + 'http://username:password@host.com:80/path?query#fragment' + """ + scheme, auth, host, port, path, query, fragment = self + url = u'' + + # We use "is not None" we want things to happen with empty strings (or 0 port) + if scheme is not None: + url += scheme + u'://' + if auth is not None: + url += auth + u'@' + if host is not None: + url += host + if port is not None: + url += u':' + str(port) + if path is not None: + url += path + if query is not None: + url += u'?' + query + if fragment is not None: + url += u'#' + fragment + + return url + + def __str__(self): + return self.url + + +def split_first(s, delims): + """ + .. deprecated:: 1.25 + + Given a string and an iterable of delimiters, split on the first found + delimiter. Return two split parts and the matched delimiter. + + If not found, then the first part is the full input string. + + Example:: + + >>> split_first('foo/bar?baz', '?/=') + ('foo', 'bar?baz', '/') + >>> split_first('foo/bar?baz', '123') + ('foo/bar?baz', '', None) + + Scales linearly with number of delims. Not ideal for large number of delims. + """ + min_idx = None + min_delim = None + for d in delims: + idx = s.find(d) + if idx < 0: + continue + + if min_idx is None or idx < min_idx: + min_idx = idx + min_delim = d + + if min_idx is None or min_idx < 0: + return s, '', None + + return s[:min_idx], s[min_idx + 1:], min_delim + + +def _encode_invalid_chars(component, allowed_chars, encoding='utf-8'): + """Percent-encodes a URI component without reapplying + onto an already percent-encoded component. Based on + rfc3986.normalizers.encode_component() + """ + if component is None: + return component + + # Try to see if the component we're encoding is already percent-encoded + # so we can skip all '%' characters but still encode all others. + percent_encodings = len(normalizers.PERCENT_MATCHER.findall( + compat.to_str(component, encoding))) + + uri_bytes = component.encode('utf-8', 'surrogatepass') + is_percent_encoded = percent_encodings == uri_bytes.count(b'%') + + encoded_component = bytearray() + + for i in range(0, len(uri_bytes)): + # Will return a single character bytestring on both Python 2 & 3 + byte = uri_bytes[i:i+1] + byte_ord = ord(byte) + if ((is_percent_encoded and byte == b'%') + or (byte_ord < 128 and byte.decode() in allowed_chars)): + encoded_component.extend(byte) + continue + encoded_component.extend('%{0:02x}'.format(byte_ord).encode().upper()) + + return encoded_component.decode(encoding) + + +def parse_url(url): + """ + Given a url, return a parsed :class:`.Url` namedtuple. Best-effort is + performed to parse incomplete urls. Fields not provided will be None. + This parser is RFC 3986 compliant. + + :param str url: URL to parse into a :class:`.Url` namedtuple. + + Partly backwards-compatible with :mod:`urlparse`. + + Example:: + + >>> parse_url('http://google.com/mail/') + Url(scheme='http', host='google.com', port=None, path='/mail/', ...) + >>> parse_url('google.com:80') + Url(scheme=None, host='google.com', port=80, path=None, ...) + >>> parse_url('/foo?bar') + Url(scheme=None, host=None, port=None, path='/foo', query='bar', ...) + """ + if not url: + # Empty + return Url() + + is_string = not isinstance(url, six.binary_type) + + # RFC 3986 doesn't like URLs that have a host but don't start + # with a scheme and we support URLs like that so we need to + # detect that problem and add an empty scheme indication. + # We don't get hurt on path-only URLs here as it's stripped + # off and given an empty scheme anyways. + if not SCHEME_REGEX.search(url): + url = "//" + url + + def idna_encode(name): + if name and any([ord(x) > 128 for x in name]): + try: + from pip._vendor import idna + except ImportError: + raise LocationParseError("Unable to parse URL without the 'idna' module") + try: + return idna.encode(name.lower(), strict=True, std3_rules=True) + except idna.IDNAError: + raise LocationParseError(u"Name '%s' is not a valid IDNA label" % name) + return name + + try: + split_iri = misc.IRI_MATCHER.match(compat.to_str(url)).groupdict() + iri_ref = rfc3986.IRIReference( + split_iri['scheme'], split_iri['authority'], + _encode_invalid_chars(split_iri['path'], PATH_CHARS), + _encode_invalid_chars(split_iri['query'], QUERY_CHARS), + _encode_invalid_chars(split_iri['fragment'], FRAGMENT_CHARS) + ) + has_authority = iri_ref.authority is not None + uri_ref = iri_ref.encode(idna_encoder=idna_encode) + except (ValueError, RFC3986Exception): + return six.raise_from(LocationParseError(url), None) + + # rfc3986 strips the authority if it's invalid + if has_authority and uri_ref.authority is None: + raise LocationParseError(url) + + # Only normalize schemes we understand to not break http+unix + # or other schemes that don't follow RFC 3986. + if uri_ref.scheme is None or uri_ref.scheme.lower() in NORMALIZABLE_SCHEMES: + uri_ref = uri_ref.normalize() + + # Validate all URIReference components and ensure that all + # components that were set before are still set after + # normalization has completed. + validator = Validator() + try: + validator.check_validity_of( + *validator.COMPONENT_NAMES + ).validate(uri_ref) + except ValidationError: + return six.raise_from(LocationParseError(url), None) + + # For the sake of backwards compatibility we put empty + # string values for path if there are any defined values + # beyond the path in the URL. + # TODO: Remove this when we break backwards compatibility. + path = uri_ref.path + if not path: + if (uri_ref.query is not None + or uri_ref.fragment is not None): + path = "" + else: + path = None + + # Ensure that each part of the URL is a `str` for + # backwards compatibility. + def to_input_type(x): + if x is None: + return None + elif not is_string and not isinstance(x, six.binary_type): + return x.encode('utf-8') + return x + + return Url( + scheme=to_input_type(uri_ref.scheme), + auth=to_input_type(uri_ref.userinfo), + host=to_input_type(uri_ref.host), + port=int(uri_ref.port) if uri_ref.port is not None else None, + path=to_input_type(path), + query=to_input_type(uri_ref.query), + fragment=to_input_type(uri_ref.fragment) + ) + + +def get_host(url): + """ + Deprecated. Use :func:`parse_url` instead. + """ + p = parse_url(url) + return p.scheme or 'http', p.hostname, p.port diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/wait.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/wait.py new file mode 100644 index 0000000..4db71ba --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/urllib3/util/wait.py @@ -0,0 +1,150 @@ +import errno +from functools import partial +import select +import sys +try: + from time import monotonic +except ImportError: + from time import time as monotonic + +__all__ = ["NoWayToWaitForSocketError", "wait_for_read", "wait_for_write"] + + +class NoWayToWaitForSocketError(Exception): + pass + + +# How should we wait on sockets? +# +# There are two types of APIs you can use for waiting on sockets: the fancy +# modern stateful APIs like epoll/kqueue, and the older stateless APIs like +# select/poll. The stateful APIs are more efficient when you have a lots of +# sockets to keep track of, because you can set them up once and then use them +# lots of times. But we only ever want to wait on a single socket at a time +# and don't want to keep track of state, so the stateless APIs are actually +# more efficient. So we want to use select() or poll(). +# +# Now, how do we choose between select() and poll()? On traditional Unixes, +# select() has a strange calling convention that makes it slow, or fail +# altogether, for high-numbered file descriptors. The point of poll() is to fix +# that, so on Unixes, we prefer poll(). +# +# On Windows, there is no poll() (or at least Python doesn't provide a wrapper +# for it), but that's OK, because on Windows, select() doesn't have this +# strange calling convention; plain select() works fine. +# +# So: on Windows we use select(), and everywhere else we use poll(). We also +# fall back to select() in case poll() is somehow broken or missing. + +if sys.version_info >= (3, 5): + # Modern Python, that retries syscalls by default + def _retry_on_intr(fn, timeout): + return fn(timeout) +else: + # Old and broken Pythons. + def _retry_on_intr(fn, timeout): + if timeout is None: + deadline = float("inf") + else: + deadline = monotonic() + timeout + + while True: + try: + return fn(timeout) + # OSError for 3 <= pyver < 3.5, select.error for pyver <= 2.7 + except (OSError, select.error) as e: + # 'e.args[0]' incantation works for both OSError and select.error + if e.args[0] != errno.EINTR: + raise + else: + timeout = deadline - monotonic() + if timeout < 0: + timeout = 0 + if timeout == float("inf"): + timeout = None + continue + + +def select_wait_for_socket(sock, read=False, write=False, timeout=None): + if not read and not write: + raise RuntimeError("must specify at least one of read=True, write=True") + rcheck = [] + wcheck = [] + if read: + rcheck.append(sock) + if write: + wcheck.append(sock) + # When doing a non-blocking connect, most systems signal success by + # marking the socket writable. Windows, though, signals success by marked + # it as "exceptional". We paper over the difference by checking the write + # sockets for both conditions. (The stdlib selectors module does the same + # thing.) + fn = partial(select.select, rcheck, wcheck, wcheck) + rready, wready, xready = _retry_on_intr(fn, timeout) + return bool(rready or wready or xready) + + +def poll_wait_for_socket(sock, read=False, write=False, timeout=None): + if not read and not write: + raise RuntimeError("must specify at least one of read=True, write=True") + mask = 0 + if read: + mask |= select.POLLIN + if write: + mask |= select.POLLOUT + poll_obj = select.poll() + poll_obj.register(sock, mask) + + # For some reason, poll() takes timeout in milliseconds + def do_poll(t): + if t is not None: + t *= 1000 + return poll_obj.poll(t) + + return bool(_retry_on_intr(do_poll, timeout)) + + +def null_wait_for_socket(*args, **kwargs): + raise NoWayToWaitForSocketError("no select-equivalent available") + + +def _have_working_poll(): + # Apparently some systems have a select.poll that fails as soon as you try + # to use it, either due to strange configuration or broken monkeypatching + # from libraries like eventlet/greenlet. + try: + poll_obj = select.poll() + _retry_on_intr(poll_obj.poll, 0) + except (AttributeError, OSError): + return False + else: + return True + + +def wait_for_socket(*args, **kwargs): + # We delay choosing which implementation to use until the first time we're + # called. We could do it at import time, but then we might make the wrong + # decision if someone goes wild with monkeypatching select.poll after + # we're imported. + global wait_for_socket + if _have_working_poll(): + wait_for_socket = poll_wait_for_socket + elif hasattr(select, "select"): + wait_for_socket = select_wait_for_socket + else: # Platform-specific: Appengine. + wait_for_socket = null_wait_for_socket + return wait_for_socket(*args, **kwargs) + + +def wait_for_read(sock, timeout=None): + """ Waits for reading to be available on a given socket. + Returns True if the socket is readable, or False if the timeout expired. + """ + return wait_for_socket(sock, read=True, timeout=timeout) + + +def wait_for_write(sock, timeout=None): + """ Waits for writing to be available on a given socket. + Returns True if the socket is readable, or False if the timeout expired. + """ + return wait_for_socket(sock, write=True, timeout=timeout) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__init__.py new file mode 100644 index 0000000..d21d697 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__init__.py @@ -0,0 +1,342 @@ +# coding: utf-8 +""" + + webencodings + ~~~~~~~~~~~~ + + This is a Python implementation of the `WHATWG Encoding standard + <http://encoding.spec.whatwg.org/>`. See README for details. + + :copyright: Copyright 2012 by Simon Sapin + :license: BSD, see LICENSE for details. + +""" + +from __future__ import unicode_literals + +import codecs + +from .labels import LABELS + + +VERSION = '0.5.1' + + +# Some names in Encoding are not valid Python aliases. Remap these. +PYTHON_NAMES = { + 'iso-8859-8-i': 'iso-8859-8', + 'x-mac-cyrillic': 'mac-cyrillic', + 'macintosh': 'mac-roman', + 'windows-874': 'cp874'} + +CACHE = {} + + +def ascii_lower(string): + r"""Transform (only) ASCII letters to lower case: A-Z is mapped to a-z. + + :param string: An Unicode string. + :returns: A new Unicode string. + + This is used for `ASCII case-insensitive + <http://encoding.spec.whatwg.org/#ascii-case-insensitive>`_ + matching of encoding labels. + The same matching is also used, among other things, + for `CSS keywords <http://dev.w3.org/csswg/css-values/#keywords>`_. + + This is different from the :meth:`~py:str.lower` method of Unicode strings + which also affect non-ASCII characters, + sometimes mapping them into the ASCII range: + + >>> keyword = u'Bac\N{KELVIN SIGN}ground' + >>> assert keyword.lower() == u'background' + >>> assert ascii_lower(keyword) != keyword.lower() + >>> assert ascii_lower(keyword) == u'bac\N{KELVIN SIGN}ground' + + """ + # This turns out to be faster than unicode.translate() + return string.encode('utf8').lower().decode('utf8') + + +def lookup(label): + """ + Look for an encoding by its label. + This is the spec’s `get an encoding + <http://encoding.spec.whatwg.org/#concept-encoding-get>`_ algorithm. + Supported labels are listed there. + + :param label: A string. + :returns: + An :class:`Encoding` object, or :obj:`None` for an unknown label. + + """ + # Only strip ASCII whitespace: U+0009, U+000A, U+000C, U+000D, and U+0020. + label = ascii_lower(label.strip('\t\n\f\r ')) + name = LABELS.get(label) + if name is None: + return None + encoding = CACHE.get(name) + if encoding is None: + if name == 'x-user-defined': + from .x_user_defined import codec_info + else: + python_name = PYTHON_NAMES.get(name, name) + # Any python_name value that gets to here should be valid. + codec_info = codecs.lookup(python_name) + encoding = Encoding(name, codec_info) + CACHE[name] = encoding + return encoding + + +def _get_encoding(encoding_or_label): + """ + Accept either an encoding object or label. + + :param encoding: An :class:`Encoding` object or a label string. + :returns: An :class:`Encoding` object. + :raises: :exc:`~exceptions.LookupError` for an unknown label. + + """ + if hasattr(encoding_or_label, 'codec_info'): + return encoding_or_label + + encoding = lookup(encoding_or_label) + if encoding is None: + raise LookupError('Unknown encoding label: %r' % encoding_or_label) + return encoding + + +class Encoding(object): + """Reresents a character encoding such as UTF-8, + that can be used for decoding or encoding. + + .. attribute:: name + + Canonical name of the encoding + + .. attribute:: codec_info + + The actual implementation of the encoding, + a stdlib :class:`~codecs.CodecInfo` object. + See :func:`codecs.register`. + + """ + def __init__(self, name, codec_info): + self.name = name + self.codec_info = codec_info + + def __repr__(self): + return '<Encoding %s>' % self.name + + +#: The UTF-8 encoding. Should be used for new content and formats. +UTF8 = lookup('utf-8') + +_UTF16LE = lookup('utf-16le') +_UTF16BE = lookup('utf-16be') + + +def decode(input, fallback_encoding, errors='replace'): + """ + Decode a single string. + + :param input: A byte string + :param fallback_encoding: + An :class:`Encoding` object or a label string. + The encoding to use if :obj:`input` does note have a BOM. + :param errors: Type of error handling. See :func:`codecs.register`. + :raises: :exc:`~exceptions.LookupError` for an unknown encoding label. + :return: + A ``(output, encoding)`` tuple of an Unicode string + and an :obj:`Encoding`. + + """ + # Fail early if `encoding` is an invalid label. + fallback_encoding = _get_encoding(fallback_encoding) + bom_encoding, input = _detect_bom(input) + encoding = bom_encoding or fallback_encoding + return encoding.codec_info.decode(input, errors)[0], encoding + + +def _detect_bom(input): + """Return (bom_encoding, input), with any BOM removed from the input.""" + if input.startswith(b'\xFF\xFE'): + return _UTF16LE, input[2:] + if input.startswith(b'\xFE\xFF'): + return _UTF16BE, input[2:] + if input.startswith(b'\xEF\xBB\xBF'): + return UTF8, input[3:] + return None, input + + +def encode(input, encoding=UTF8, errors='strict'): + """ + Encode a single string. + + :param input: An Unicode string. + :param encoding: An :class:`Encoding` object or a label string. + :param errors: Type of error handling. See :func:`codecs.register`. + :raises: :exc:`~exceptions.LookupError` for an unknown encoding label. + :return: A byte string. + + """ + return _get_encoding(encoding).codec_info.encode(input, errors)[0] + + +def iter_decode(input, fallback_encoding, errors='replace'): + """ + "Pull"-based decoder. + + :param input: + An iterable of byte strings. + + The input is first consumed just enough to determine the encoding + based on the precense of a BOM, + then consumed on demand when the return value is. + :param fallback_encoding: + An :class:`Encoding` object or a label string. + The encoding to use if :obj:`input` does note have a BOM. + :param errors: Type of error handling. See :func:`codecs.register`. + :raises: :exc:`~exceptions.LookupError` for an unknown encoding label. + :returns: + An ``(output, encoding)`` tuple. + :obj:`output` is an iterable of Unicode strings, + :obj:`encoding` is the :obj:`Encoding` that is being used. + + """ + + decoder = IncrementalDecoder(fallback_encoding, errors) + generator = _iter_decode_generator(input, decoder) + encoding = next(generator) + return generator, encoding + + +def _iter_decode_generator(input, decoder): + """Return a generator that first yields the :obj:`Encoding`, + then yields output chukns as Unicode strings. + + """ + decode = decoder.decode + input = iter(input) + for chunck in input: + output = decode(chunck) + if output: + assert decoder.encoding is not None + yield decoder.encoding + yield output + break + else: + # Input exhausted without determining the encoding + output = decode(b'', final=True) + assert decoder.encoding is not None + yield decoder.encoding + if output: + yield output + return + + for chunck in input: + output = decode(chunck) + if output: + yield output + output = decode(b'', final=True) + if output: + yield output + + +def iter_encode(input, encoding=UTF8, errors='strict'): + """ + “Pull”-based encoder. + + :param input: An iterable of Unicode strings. + :param encoding: An :class:`Encoding` object or a label string. + :param errors: Type of error handling. See :func:`codecs.register`. + :raises: :exc:`~exceptions.LookupError` for an unknown encoding label. + :returns: An iterable of byte strings. + + """ + # Fail early if `encoding` is an invalid label. + encode = IncrementalEncoder(encoding, errors).encode + return _iter_encode_generator(input, encode) + + +def _iter_encode_generator(input, encode): + for chunck in input: + output = encode(chunck) + if output: + yield output + output = encode('', final=True) + if output: + yield output + + +class IncrementalDecoder(object): + """ + “Push”-based decoder. + + :param fallback_encoding: + An :class:`Encoding` object or a label string. + The encoding to use if :obj:`input` does note have a BOM. + :param errors: Type of error handling. See :func:`codecs.register`. + :raises: :exc:`~exceptions.LookupError` for an unknown encoding label. + + """ + def __init__(self, fallback_encoding, errors='replace'): + # Fail early if `encoding` is an invalid label. + self._fallback_encoding = _get_encoding(fallback_encoding) + self._errors = errors + self._buffer = b'' + self._decoder = None + #: The actual :class:`Encoding` that is being used, + #: or :obj:`None` if that is not determined yet. + #: (Ie. if there is not enough input yet to determine + #: if there is a BOM.) + self.encoding = None # Not known yet. + + def decode(self, input, final=False): + """Decode one chunk of the input. + + :param input: A byte string. + :param final: + Indicate that no more input is available. + Must be :obj:`True` if this is the last call. + :returns: An Unicode string. + + """ + decoder = self._decoder + if decoder is not None: + return decoder(input, final) + + input = self._buffer + input + encoding, input = _detect_bom(input) + if encoding is None: + if len(input) < 3 and not final: # Not enough data yet. + self._buffer = input + return '' + else: # No BOM + encoding = self._fallback_encoding + decoder = encoding.codec_info.incrementaldecoder(self._errors).decode + self._decoder = decoder + self.encoding = encoding + return decoder(input, final) + + +class IncrementalEncoder(object): + """ + “Push”-based encoder. + + :param encoding: An :class:`Encoding` object or a label string. + :param errors: Type of error handling. See :func:`codecs.register`. + :raises: :exc:`~exceptions.LookupError` for an unknown encoding label. + + .. method:: encode(input, final=False) + + :param input: An Unicode string. + :param final: + Indicate that no more input is available. + Must be :obj:`True` if this is the last call. + :returns: A byte string. + + """ + def __init__(self, encoding=UTF8, errors='strict'): + encoding = _get_encoding(encoding) + self.encode = encoding.codec_info.incrementalencoder(errors).encode diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e9e3b71e8acdb4807f402b06891edd26b737ffb1 GIT binary patch literal 9752 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__pycache__/labels.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__pycache__/labels.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..a398a1dcc299c3a12fe6a2eb4eaaeb73d3cee7d0 GIT binary patch literal 3850 zcmeHJJCoZs5SH&D>2xo@-w*ojOH7O4OXN)^lh|>Q8OO~fjT;U{;3S+VQUgfmGmA{B z{E9Rwlgd?!{19gbZT>?FRl$Q2LED+snF+s<u)A39E`Y@@zuVsKH2Cw^+n?iecN>jA z1*1QIaOMmCqrabOG+^UZ1D=vtfeNeeeXPOvu@2uy6V}m!|BN>LI5yzN(18M*HEcnF zZHXONVHciW;tV`n;vB4S9tvELxCs9Zm!QDqf4~(ea8=?O6u2&N1Kxl)Kfo<$z}rjQ zfdY3q?$vM~euxL~0elD_aqPiQetP%n6#Vp{vG=(6t<y31^BVP0mgEp;1NtP5`zWPS z{{4rKdf}URVl3V;)C<NmH>N{`iIK%)^hD|HC;8+J!Gqy+-*~nl4ch{?(SKtc;BlTA z2k``F(%pWF6O>W3Z#+Ht>ajr)GG2WB?D@-s=f+`942Y&NPANA%U!P46&44v=e;oM! zyn|_O27wovwnjS|?P|2A(fYeRO&-j*mNo+u&o`GGuyn@J8CPdKo$=?*QH}$Xl;ezT zjN=4n)0__Ho3C*O^Vif2dhUE{!2sK{Y8<F>c8zmtT-}OSoAYa2uf_%QofDJCWhVU0 zQhpe0b<iKN)}Rjp%dzI2VPOvXrtJWmt@ZK1n>W!cF^?u{skUX?oM9Vuh!3aH5vFQ> zM6`L%w8h~8zmFDFiiG1CMZ|>Y5N8PPy(`YlGR#vFnSetcH{sQ$!PYn(uvLESY(1HX zp`B2b2V_MkY;u<7X*|W5O;)+2km-Sm2`o@-@Hv$!tX-0}REU(c*yYla-UngOV=Jl6 zn#!DR+aYUp+hJwfS=x3q+m2@25w-(v+bL~3x^0)N*K7l;vh6NyyP9oRv+XWyyQOWH zovrp{dA98ZMVd8du3I_tmd-rQnWs7Pl(S|`;yzA_c1*{)*|UOjIbu_Nq%)YEu7X*- zg_3b>0^pLC2&KAuzKLoamQk4EEbU$uCeMNLEPX9ZUklS$XSrLs9uR~^MZ5GIur^Bb zX%yN4TbEO;DTjcxYrA9nmD}FZZBKLC)7<uy+bufFA~cJXVU?g_X9A>e#t`)hdd-?@ zBpdau2>4bk6WIx>D0t}Q;sY&;K#L+M&*&J_S)6Kz5nv)ZJ!_@;04K{Sne0B<tS#JA zYm~PHSZr~RIJuJgWup0HYw?cKb1FTDY}e=9YR=V@KO{SKMXyry3Q>sF^#mUG9FkqG z%vuQ*^_8$yKCm@OpB59c>_&u~5e(n>Wz}V?oFr$3r%hG#NIs6Uq6KqVh@~UdQvi_r zs#XN5U_jBDVru%fMb1fI$wU-wa$Xp1pO}heO*sN`K^KE!C(bC2PMjyM2|}M|T}%^< zOKn@$HW2Fj0#v&Lp-KZ4PL&dtRwKYNB~<9;hG{7QRAR2A+^RfoP_$>%lrfNtdZfJg z$ptv%k}l?TONwhpr;3EywK7a`Rb4Gx!)0hnL4_7-p@kx}ke{trhUSsWx@TV1q-T#@ z(ZyU_ihXib7xUDV;vTuCi+iOwAlG$qKyC<jS7pR(L}HxbIOF*><ZX!}(Q5{M*#K23 z@dCvL7Oxj-g15^^XcV22FawL+6lTSp5w*(;iuDuTNk`-s7ZXGL-4+TR(NxXhh$ggX zC7CH$9w-%~$fy$~IhRo0cPArwIG!HGlUPJX?g#^1M|I>faYRc#nh^dG-(a1D%Erw5 zGHZ`%G>Wq$T&QMkav`}VwALsmi{&SY1CEO3i7ABQl5yiB!nXNsqlxERKr~2lUxr?; z4Y;AWbOiCcv@@bn5(zz?;z92{K4h)Z3Ttyh>Q#<IZbubLv4#;L54acdP`GNU?+5Zo zNcQ;O%e@uWiXxaNQN)@rzI^)p#lbHP@}rm+fAeW~Lhx}sMcw0=bPw|sB0{_2Np}#1 z$7Eb&_TiB=9G(<Kl!ktPNG$#gvhKIt37(iZqtiG|P0R9+-yDOP5XxV4jQEEe>FS@) mUG+8mWb%f!KO5(8mZHzacME;X|JP2hocbUCksbJ<@$28-k`9sp literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2652e27e7a826aad6ab2a19be601809c82f0af37 GIT binary patch literal 1946 zcmcIlL2uhO6ecBEmenRO(jsWq0%Ow^n1R%GGax{MELfZ5P$0`;?zSvgA;>0etC1yz zWSqpacUS^!JMJIY$K3WC_A_+dX@6jcVq5o~6n6<0>^2H~BKgF}_ulvM>GPQxmq7dd z=ZU{iAmmq^Tx||aK7p><AUN44oN^<i`*cu-kr^62bKj)oOA;}Q2<yO=>y+S=X$!gb zD-s!dgj>9DPWEkX^CG;9!r{(=A)BHkioA42&nWCN8l>V5esNs}?N~HL)QWi!byT%? z5c*9Ks!a3kO)cN_ndpefm%bKEcg1xZxdqmX`B5mU`S)wBI60L;r>oc4=5)xG>ra<i z^OQA$UL3K8p9E2M@LCwOM5M$Td*0YuVoC_M^I~&*x3SIIv1D9mKL{0={tfa)b}KY3 z9?39HAP$Nvmkq}z^iAmME{GvKV=^HJhAM0N9UYPexuClhBQ1pSv5@KPGo^&oK^$#M z8A~v1D=i^27ep4pz?*(8kwG8AuJwIcYsVoMQq@*ZY8`L2FMES%x&6A{?Vbz<Ubwo_ z?8-W{PE>nYOM>J{5Gn14;gfoOrGMIgdW4Hv_xd8@v8-LiqBg~%nw+M${md~ha}z^R z76?MiRF>d<Eo=<ghK}!?QM5xxz$k8>6HUfc8$)tN$L55LEpAQdgl@rnWat7faQmDL z4V<6RAIXr8?e9sO@*=D|`T7JH1nWia;E0#T&JZjhqjvo}kn+XF#T$tA-?Yj%eCj7` zN=0_bA{`^a0?8u3_dk;<bNmt8+uLJXF^gi&1P}B>_Yr&94HRn!p<wX#k96Ggb<hGN zPZ?YTf!BZ|kFOx+x;xLFZ|^kN$Lt&T8axObUib#Wvjd_7tbDaKqC?8b0@)(3Rz}9q z;4~Y5I5IWSbZ8<VV}lzLssSKwE+B;2ylwns9X>cLA6fu{m6oO{RH>aOF{MYTh54(P zsU<}sGtPh(xt+ikqgqd$7DUmB<!S0n4Zy9yVvsRE7wC8Du7`ort+<zLEMW{~5VmPh zmt_5qGA+LyJeVe?x*o=mDzyQF>9(}st5y(POAE3!V=S6{4+JD-?rUR&yac|T(J!Fh z9U2_+Ch@xqnwp`AE=-B%%R4A$P~bhi;%#XiJvm9_#xf|fYh%In7~H?X!ReR(atv*L zgxfJ-aO{KJF%FJ#`U6}lbnqUz3&^z1d2;D0mRWN!i$(UaT6?TOF1c?g+m-WRM&1Jf zQ51Xri3gGV<Fi}<O?Dh|#WL)-DIKMxQcA7YDvq#N`CLf@l!&L#Q=1E@;374_R%(kA z4do=Y{RAo^hfQ%10rV!+$h467QY(22_T~rP$5Do>GtCGdpVdo3?K#_=|I@bT=&WJ< z<(Mv&6+G7Qyq+IKo;Rp=wNBP*wJB+;DiN*fao5+!ooXyQ?-Z(v&R5*D=y^PDd7gY9 zE!p5z7&P-}ZoTLwvD8`dO=ojWRf@wS0aV38_wID0v*$rLP@VM^%ro@!aMtrb&<6en W)Eo%wwnGglnX`1xbPCQxhyD$M?)vWl literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__pycache__/tests.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__pycache__/tests.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..18b70f40f07e17595dc8577916f575630f60a516 GIT binary patch literal 5112 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 PX?riOv^|RZpq=|4u&$s* literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b488e37b4ee5df5735e9c7002a216e9648527ca3 GIT binary patch literal 2680 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/labels.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/labels.py new file mode 100644 index 0000000..29cbf91 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/labels.py @@ -0,0 +1,231 @@ +""" + + webencodings.labels + ~~~~~~~~~~~~~~~~~~~ + + Map encoding labels to their name. + + :copyright: Copyright 2012 by Simon Sapin + :license: BSD, see LICENSE for details. + +""" + +# XXX Do not edit! +# This file is automatically generated by mklabels.py + +LABELS = { + 'unicode-1-1-utf-8': 'utf-8', + 'utf-8': 'utf-8', + 'utf8': 'utf-8', + '866': 'ibm866', + 'cp866': 'ibm866', + 'csibm866': 'ibm866', + 'ibm866': 'ibm866', + 'csisolatin2': 'iso-8859-2', + 'iso-8859-2': 'iso-8859-2', + 'iso-ir-101': 'iso-8859-2', + 'iso8859-2': 'iso-8859-2', + 'iso88592': 'iso-8859-2', + 'iso_8859-2': 'iso-8859-2', + 'iso_8859-2:1987': 'iso-8859-2', + 'l2': 'iso-8859-2', + 'latin2': 'iso-8859-2', + 'csisolatin3': 'iso-8859-3', + 'iso-8859-3': 'iso-8859-3', + 'iso-ir-109': 'iso-8859-3', + 'iso8859-3': 'iso-8859-3', + 'iso88593': 'iso-8859-3', + 'iso_8859-3': 'iso-8859-3', + 'iso_8859-3:1988': 'iso-8859-3', + 'l3': 'iso-8859-3', + 'latin3': 'iso-8859-3', + 'csisolatin4': 'iso-8859-4', + 'iso-8859-4': 'iso-8859-4', + 'iso-ir-110': 'iso-8859-4', + 'iso8859-4': 'iso-8859-4', + 'iso88594': 'iso-8859-4', + 'iso_8859-4': 'iso-8859-4', + 'iso_8859-4:1988': 'iso-8859-4', + 'l4': 'iso-8859-4', + 'latin4': 'iso-8859-4', + 'csisolatincyrillic': 'iso-8859-5', + 'cyrillic': 'iso-8859-5', + 'iso-8859-5': 'iso-8859-5', + 'iso-ir-144': 'iso-8859-5', + 'iso8859-5': 'iso-8859-5', + 'iso88595': 'iso-8859-5', + 'iso_8859-5': 'iso-8859-5', + 'iso_8859-5:1988': 'iso-8859-5', + 'arabic': 'iso-8859-6', + 'asmo-708': 'iso-8859-6', + 'csiso88596e': 'iso-8859-6', + 'csiso88596i': 'iso-8859-6', + 'csisolatinarabic': 'iso-8859-6', + 'ecma-114': 'iso-8859-6', + 'iso-8859-6': 'iso-8859-6', + 'iso-8859-6-e': 'iso-8859-6', + 'iso-8859-6-i': 'iso-8859-6', + 'iso-ir-127': 'iso-8859-6', + 'iso8859-6': 'iso-8859-6', + 'iso88596': 'iso-8859-6', + 'iso_8859-6': 'iso-8859-6', + 'iso_8859-6:1987': 'iso-8859-6', + 'csisolatingreek': 'iso-8859-7', + 'ecma-118': 'iso-8859-7', + 'elot_928': 'iso-8859-7', + 'greek': 'iso-8859-7', + 'greek8': 'iso-8859-7', + 'iso-8859-7': 'iso-8859-7', + 'iso-ir-126': 'iso-8859-7', + 'iso8859-7': 'iso-8859-7', + 'iso88597': 'iso-8859-7', + 'iso_8859-7': 'iso-8859-7', + 'iso_8859-7:1987': 'iso-8859-7', + 'sun_eu_greek': 'iso-8859-7', + 'csiso88598e': 'iso-8859-8', + 'csisolatinhebrew': 'iso-8859-8', + 'hebrew': 'iso-8859-8', + 'iso-8859-8': 'iso-8859-8', + 'iso-8859-8-e': 'iso-8859-8', + 'iso-ir-138': 'iso-8859-8', + 'iso8859-8': 'iso-8859-8', + 'iso88598': 'iso-8859-8', + 'iso_8859-8': 'iso-8859-8', + 'iso_8859-8:1988': 'iso-8859-8', + 'visual': 'iso-8859-8', + 'csiso88598i': 'iso-8859-8-i', + 'iso-8859-8-i': 'iso-8859-8-i', + 'logical': 'iso-8859-8-i', + 'csisolatin6': 'iso-8859-10', + 'iso-8859-10': 'iso-8859-10', + 'iso-ir-157': 'iso-8859-10', + 'iso8859-10': 'iso-8859-10', + 'iso885910': 'iso-8859-10', + 'l6': 'iso-8859-10', + 'latin6': 'iso-8859-10', + 'iso-8859-13': 'iso-8859-13', + 'iso8859-13': 'iso-8859-13', + 'iso885913': 'iso-8859-13', + 'iso-8859-14': 'iso-8859-14', + 'iso8859-14': 'iso-8859-14', + 'iso885914': 'iso-8859-14', + 'csisolatin9': 'iso-8859-15', + 'iso-8859-15': 'iso-8859-15', + 'iso8859-15': 'iso-8859-15', + 'iso885915': 'iso-8859-15', + 'iso_8859-15': 'iso-8859-15', + 'l9': 'iso-8859-15', + 'iso-8859-16': 'iso-8859-16', + 'cskoi8r': 'koi8-r', + 'koi': 'koi8-r', + 'koi8': 'koi8-r', + 'koi8-r': 'koi8-r', + 'koi8_r': 'koi8-r', + 'koi8-u': 'koi8-u', + 'csmacintosh': 'macintosh', + 'mac': 'macintosh', + 'macintosh': 'macintosh', + 'x-mac-roman': 'macintosh', + 'dos-874': 'windows-874', + 'iso-8859-11': 'windows-874', + 'iso8859-11': 'windows-874', + 'iso885911': 'windows-874', + 'tis-620': 'windows-874', + 'windows-874': 'windows-874', + 'cp1250': 'windows-1250', + 'windows-1250': 'windows-1250', + 'x-cp1250': 'windows-1250', + 'cp1251': 'windows-1251', + 'windows-1251': 'windows-1251', + 'x-cp1251': 'windows-1251', + 'ansi_x3.4-1968': 'windows-1252', + 'ascii': 'windows-1252', + 'cp1252': 'windows-1252', + 'cp819': 'windows-1252', + 'csisolatin1': 'windows-1252', + 'ibm819': 'windows-1252', + 'iso-8859-1': 'windows-1252', + 'iso-ir-100': 'windows-1252', + 'iso8859-1': 'windows-1252', + 'iso88591': 'windows-1252', + 'iso_8859-1': 'windows-1252', + 'iso_8859-1:1987': 'windows-1252', + 'l1': 'windows-1252', + 'latin1': 'windows-1252', + 'us-ascii': 'windows-1252', + 'windows-1252': 'windows-1252', + 'x-cp1252': 'windows-1252', + 'cp1253': 'windows-1253', + 'windows-1253': 'windows-1253', + 'x-cp1253': 'windows-1253', + 'cp1254': 'windows-1254', + 'csisolatin5': 'windows-1254', + 'iso-8859-9': 'windows-1254', + 'iso-ir-148': 'windows-1254', + 'iso8859-9': 'windows-1254', + 'iso88599': 'windows-1254', + 'iso_8859-9': 'windows-1254', + 'iso_8859-9:1989': 'windows-1254', + 'l5': 'windows-1254', + 'latin5': 'windows-1254', + 'windows-1254': 'windows-1254', + 'x-cp1254': 'windows-1254', + 'cp1255': 'windows-1255', + 'windows-1255': 'windows-1255', + 'x-cp1255': 'windows-1255', + 'cp1256': 'windows-1256', + 'windows-1256': 'windows-1256', + 'x-cp1256': 'windows-1256', + 'cp1257': 'windows-1257', + 'windows-1257': 'windows-1257', + 'x-cp1257': 'windows-1257', + 'cp1258': 'windows-1258', + 'windows-1258': 'windows-1258', + 'x-cp1258': 'windows-1258', + 'x-mac-cyrillic': 'x-mac-cyrillic', + 'x-mac-ukrainian': 'x-mac-cyrillic', + 'chinese': 'gbk', + 'csgb2312': 'gbk', + 'csiso58gb231280': 'gbk', + 'gb2312': 'gbk', + 'gb_2312': 'gbk', + 'gb_2312-80': 'gbk', + 'gbk': 'gbk', + 'iso-ir-58': 'gbk', + 'x-gbk': 'gbk', + 'gb18030': 'gb18030', + 'hz-gb-2312': 'hz-gb-2312', + 'big5': 'big5', + 'big5-hkscs': 'big5', + 'cn-big5': 'big5', + 'csbig5': 'big5', + 'x-x-big5': 'big5', + 'cseucpkdfmtjapanese': 'euc-jp', + 'euc-jp': 'euc-jp', + 'x-euc-jp': 'euc-jp', + 'csiso2022jp': 'iso-2022-jp', + 'iso-2022-jp': 'iso-2022-jp', + 'csshiftjis': 'shift_jis', + 'ms_kanji': 'shift_jis', + 'shift-jis': 'shift_jis', + 'shift_jis': 'shift_jis', + 'sjis': 'shift_jis', + 'windows-31j': 'shift_jis', + 'x-sjis': 'shift_jis', + 'cseuckr': 'euc-kr', + 'csksc56011987': 'euc-kr', + 'euc-kr': 'euc-kr', + 'iso-ir-149': 'euc-kr', + 'korean': 'euc-kr', + 'ks_c_5601-1987': 'euc-kr', + 'ks_c_5601-1989': 'euc-kr', + 'ksc5601': 'euc-kr', + 'ksc_5601': 'euc-kr', + 'windows-949': 'euc-kr', + 'csiso2022kr': 'iso-2022-kr', + 'iso-2022-kr': 'iso-2022-kr', + 'utf-16be': 'utf-16be', + 'utf-16': 'utf-16le', + 'utf-16le': 'utf-16le', + 'x-user-defined': 'x-user-defined', +} diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/mklabels.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/mklabels.py new file mode 100644 index 0000000..295dc92 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/mklabels.py @@ -0,0 +1,59 @@ +""" + + webencodings.mklabels + ~~~~~~~~~~~~~~~~~~~~~ + + Regenarate the webencodings.labels module. + + :copyright: Copyright 2012 by Simon Sapin + :license: BSD, see LICENSE for details. + +""" + +import json +try: + from urllib import urlopen +except ImportError: + from urllib.request import urlopen + + +def assert_lower(string): + assert string == string.lower() + return string + + +def generate(url): + parts = ['''\ +""" + + webencodings.labels + ~~~~~~~~~~~~~~~~~~~ + + Map encoding labels to their name. + + :copyright: Copyright 2012 by Simon Sapin + :license: BSD, see LICENSE for details. + +""" + +# XXX Do not edit! +# This file is automatically generated by mklabels.py + +LABELS = { +'''] + labels = [ + (repr(assert_lower(label)).lstrip('u'), + repr(encoding['name']).lstrip('u')) + for category in json.loads(urlopen(url).read().decode('ascii')) + for encoding in category['encodings'] + for label in encoding['labels']] + max_len = max(len(label) for label, name in labels) + parts.extend( + ' %s:%s %s,\n' % (label, ' ' * (max_len - len(label)), name) + for label, name in labels) + parts.append('}') + return ''.join(parts) + + +if __name__ == '__main__': + print(generate('http://encoding.spec.whatwg.org/encodings.json')) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/tests.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/tests.py new file mode 100644 index 0000000..e12c10d --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/tests.py @@ -0,0 +1,153 @@ +# coding: utf-8 +""" + + webencodings.tests + ~~~~~~~~~~~~~~~~~~ + + A basic test suite for Encoding. + + :copyright: Copyright 2012 by Simon Sapin + :license: BSD, see LICENSE for details. + +""" + +from __future__ import unicode_literals + +from . import (lookup, LABELS, decode, encode, iter_decode, iter_encode, + IncrementalDecoder, IncrementalEncoder, UTF8) + + +def assert_raises(exception, function, *args, **kwargs): + try: + function(*args, **kwargs) + except exception: + return + else: # pragma: no cover + raise AssertionError('Did not raise %s.' % exception) + + +def test_labels(): + assert lookup('utf-8').name == 'utf-8' + assert lookup('Utf-8').name == 'utf-8' + assert lookup('UTF-8').name == 'utf-8' + assert lookup('utf8').name == 'utf-8' + assert lookup('utf8').name == 'utf-8' + assert lookup('utf8 ').name == 'utf-8' + assert lookup(' \r\nutf8\t').name == 'utf-8' + assert lookup('u8') is None # Python label. + assert lookup('utf-8 ') is None # Non-ASCII white space. + + assert lookup('US-ASCII').name == 'windows-1252' + assert lookup('iso-8859-1').name == 'windows-1252' + assert lookup('latin1').name == 'windows-1252' + assert lookup('LATIN1').name == 'windows-1252' + assert lookup('latin-1') is None + assert lookup('LATİN1') is None # ASCII-only case insensitivity. + + +def test_all_labels(): + for label in LABELS: + assert decode(b'', label) == ('', lookup(label)) + assert encode('', label) == b'' + for repeat in [0, 1, 12]: + output, _ = iter_decode([b''] * repeat, label) + assert list(output) == [] + assert list(iter_encode([''] * repeat, label)) == [] + decoder = IncrementalDecoder(label) + assert decoder.decode(b'') == '' + assert decoder.decode(b'', final=True) == '' + encoder = IncrementalEncoder(label) + assert encoder.encode('') == b'' + assert encoder.encode('', final=True) == b'' + # All encoding names are valid labels too: + for name in set(LABELS.values()): + assert lookup(name).name == name + + +def test_invalid_label(): + assert_raises(LookupError, decode, b'\xEF\xBB\xBF\xc3\xa9', 'invalid') + assert_raises(LookupError, encode, 'é', 'invalid') + assert_raises(LookupError, iter_decode, [], 'invalid') + assert_raises(LookupError, iter_encode, [], 'invalid') + assert_raises(LookupError, IncrementalDecoder, 'invalid') + assert_raises(LookupError, IncrementalEncoder, 'invalid') + + +def test_decode(): + assert decode(b'\x80', 'latin1') == ('€', lookup('latin1')) + assert decode(b'\x80', lookup('latin1')) == ('€', lookup('latin1')) + assert decode(b'\xc3\xa9', 'utf8') == ('é', lookup('utf8')) + assert decode(b'\xc3\xa9', UTF8) == ('é', lookup('utf8')) + assert decode(b'\xc3\xa9', 'ascii') == ('é', lookup('ascii')) + assert decode(b'\xEF\xBB\xBF\xc3\xa9', 'ascii') == ('é', lookup('utf8')) # UTF-8 with BOM + + assert decode(b'\xFE\xFF\x00\xe9', 'ascii') == ('é', lookup('utf-16be')) # UTF-16-BE with BOM + assert decode(b'\xFF\xFE\xe9\x00', 'ascii') == ('é', lookup('utf-16le')) # UTF-16-LE with BOM + assert decode(b'\xFE\xFF\xe9\x00', 'ascii') == ('\ue900', lookup('utf-16be')) + assert decode(b'\xFF\xFE\x00\xe9', 'ascii') == ('\ue900', lookup('utf-16le')) + + assert decode(b'\x00\xe9', 'UTF-16BE') == ('é', lookup('utf-16be')) + assert decode(b'\xe9\x00', 'UTF-16LE') == ('é', lookup('utf-16le')) + assert decode(b'\xe9\x00', 'UTF-16') == ('é', lookup('utf-16le')) + + assert decode(b'\xe9\x00', 'UTF-16BE') == ('\ue900', lookup('utf-16be')) + assert decode(b'\x00\xe9', 'UTF-16LE') == ('\ue900', lookup('utf-16le')) + assert decode(b'\x00\xe9', 'UTF-16') == ('\ue900', lookup('utf-16le')) + + +def test_encode(): + assert encode('é', 'latin1') == b'\xe9' + assert encode('é', 'utf8') == b'\xc3\xa9' + assert encode('é', 'utf8') == b'\xc3\xa9' + assert encode('é', 'utf-16') == b'\xe9\x00' + assert encode('é', 'utf-16le') == b'\xe9\x00' + assert encode('é', 'utf-16be') == b'\x00\xe9' + + +def test_iter_decode(): + def iter_decode_to_string(input, fallback_encoding): + output, _encoding = iter_decode(input, fallback_encoding) + return ''.join(output) + assert iter_decode_to_string([], 'latin1') == '' + assert iter_decode_to_string([b''], 'latin1') == '' + assert iter_decode_to_string([b'\xe9'], 'latin1') == 'é' + assert iter_decode_to_string([b'hello'], 'latin1') == 'hello' + assert iter_decode_to_string([b'he', b'llo'], 'latin1') == 'hello' + assert iter_decode_to_string([b'hell', b'o'], 'latin1') == 'hello' + assert iter_decode_to_string([b'\xc3\xa9'], 'latin1') == 'é' + assert iter_decode_to_string([b'\xEF\xBB\xBF\xc3\xa9'], 'latin1') == 'é' + assert iter_decode_to_string([ + b'\xEF\xBB\xBF', b'\xc3', b'\xa9'], 'latin1') == 'é' + assert iter_decode_to_string([ + b'\xEF\xBB\xBF', b'a', b'\xc3'], 'latin1') == 'a\uFFFD' + assert iter_decode_to_string([ + b'', b'\xEF', b'', b'', b'\xBB\xBF\xc3', b'\xa9'], 'latin1') == 'é' + assert iter_decode_to_string([b'\xEF\xBB\xBF'], 'latin1') == '' + assert iter_decode_to_string([b'\xEF\xBB'], 'latin1') == 'ï»' + assert iter_decode_to_string([b'\xFE\xFF\x00\xe9'], 'latin1') == 'é' + assert iter_decode_to_string([b'\xFF\xFE\xe9\x00'], 'latin1') == 'é' + assert iter_decode_to_string([ + b'', b'\xFF', b'', b'', b'\xFE\xe9', b'\x00'], 'latin1') == 'é' + assert iter_decode_to_string([ + b'', b'h\xe9', b'llo'], 'x-user-defined') == 'h\uF7E9llo' + + +def test_iter_encode(): + assert b''.join(iter_encode([], 'latin1')) == b'' + assert b''.join(iter_encode([''], 'latin1')) == b'' + assert b''.join(iter_encode(['é'], 'latin1')) == b'\xe9' + assert b''.join(iter_encode(['', 'é', '', ''], 'latin1')) == b'\xe9' + assert b''.join(iter_encode(['', 'é', '', ''], 'utf-16')) == b'\xe9\x00' + assert b''.join(iter_encode(['', 'é', '', ''], 'utf-16le')) == b'\xe9\x00' + assert b''.join(iter_encode(['', 'é', '', ''], 'utf-16be')) == b'\x00\xe9' + assert b''.join(iter_encode([ + '', 'h\uF7E9', '', 'llo'], 'x-user-defined')) == b'h\xe9llo' + + +def test_x_user_defined(): + encoded = b'2,\x0c\x0b\x1aO\xd9#\xcb\x0f\xc9\xbbt\xcf\xa8\xca' + decoded = '2,\x0c\x0b\x1aO\uf7d9#\uf7cb\x0f\uf7c9\uf7bbt\uf7cf\uf7a8\uf7ca' + encoded = b'aa' + decoded = 'aa' + assert decode(encoded, 'x-user-defined') == (decoded, lookup('x-user-defined')) + assert encode(decoded, 'x-user-defined') == encoded diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/x_user_defined.py b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/x_user_defined.py new file mode 100644 index 0000000..d16e326 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pip/_vendor/webencodings/x_user_defined.py @@ -0,0 +1,325 @@ +# coding: utf-8 +""" + + webencodings.x_user_defined + ~~~~~~~~~~~~~~~~~~~~~~~~~~~ + + An implementation of the x-user-defined encoding. + + :copyright: Copyright 2012 by Simon Sapin + :license: BSD, see LICENSE for details. + +""" + +from __future__ import unicode_literals + +import codecs + + +### Codec APIs + +class Codec(codecs.Codec): + + def encode(self, input, errors='strict'): + return codecs.charmap_encode(input, errors, encoding_table) + + def decode(self, input, errors='strict'): + return codecs.charmap_decode(input, errors, decoding_table) + + +class IncrementalEncoder(codecs.IncrementalEncoder): + def encode(self, input, final=False): + return codecs.charmap_encode(input, self.errors, encoding_table)[0] + + +class IncrementalDecoder(codecs.IncrementalDecoder): + def decode(self, input, final=False): + return codecs.charmap_decode(input, self.errors, decoding_table)[0] + + +class StreamWriter(Codec, codecs.StreamWriter): + pass + + +class StreamReader(Codec, codecs.StreamReader): + pass + + +### encodings module API + +codec_info = codecs.CodecInfo( + name='x-user-defined', + encode=Codec().encode, + decode=Codec().decode, + incrementalencoder=IncrementalEncoder, + incrementaldecoder=IncrementalDecoder, + streamreader=StreamReader, + streamwriter=StreamWriter, +) + + +### Decoding Table + +# Python 3: +# for c in range(256): print(' %r' % chr(c if c < 128 else c + 0xF700)) +decoding_table = ( + '\x00' + '\x01' + '\x02' + '\x03' + '\x04' + '\x05' + '\x06' + '\x07' + '\x08' + '\t' + '\n' + '\x0b' + '\x0c' + '\r' + '\x0e' + '\x0f' + '\x10' + '\x11' + '\x12' + '\x13' + '\x14' + '\x15' + '\x16' + '\x17' + '\x18' + '\x19' + '\x1a' + '\x1b' + '\x1c' + '\x1d' + '\x1e' + '\x1f' + ' ' + '!' + '"' + '#' + '$' + '%' + '&' + "'" + '(' + ')' + '*' + '+' + ',' + '-' + '.' + '/' + '0' + '1' + '2' + '3' + '4' + '5' + '6' + '7' + '8' + '9' + ':' + ';' + '<' + '=' + '>' + '?' + '@' + 'A' + 'B' + 'C' + 'D' + 'E' + 'F' + 'G' + 'H' + 'I' + 'J' + 'K' + 'L' + 'M' + 'N' + 'O' + 'P' + 'Q' + 'R' + 'S' + 'T' + 'U' + 'V' + 'W' + 'X' + 'Y' + 'Z' + '[' + '\\' + ']' + '^' + '_' + '`' + 'a' + 'b' + 'c' + 'd' + 'e' + 'f' + 'g' + 'h' + 'i' + 'j' + 'k' + 'l' + 'm' + 'n' + 'o' + 'p' + 'q' + 'r' + 's' + 't' + 'u' + 'v' + 'w' + 'x' + 'y' + 'z' + '{' + '|' + '}' + '~' + '\x7f' + '\uf780' + '\uf781' + '\uf782' + '\uf783' + '\uf784' + '\uf785' + '\uf786' + '\uf787' + '\uf788' + '\uf789' + '\uf78a' + '\uf78b' + '\uf78c' + '\uf78d' + '\uf78e' + '\uf78f' + '\uf790' + '\uf791' + '\uf792' + '\uf793' + '\uf794' + '\uf795' + '\uf796' + '\uf797' + '\uf798' + '\uf799' + '\uf79a' + '\uf79b' + '\uf79c' + '\uf79d' + '\uf79e' + '\uf79f' + '\uf7a0' + '\uf7a1' + '\uf7a2' + '\uf7a3' + '\uf7a4' + '\uf7a5' + '\uf7a6' + '\uf7a7' + '\uf7a8' + '\uf7a9' + '\uf7aa' + '\uf7ab' + '\uf7ac' + '\uf7ad' + '\uf7ae' + '\uf7af' + '\uf7b0' + '\uf7b1' + '\uf7b2' + '\uf7b3' + '\uf7b4' + '\uf7b5' + '\uf7b6' + '\uf7b7' + '\uf7b8' + '\uf7b9' + '\uf7ba' + '\uf7bb' + '\uf7bc' + '\uf7bd' + '\uf7be' + '\uf7bf' + '\uf7c0' + '\uf7c1' + '\uf7c2' + '\uf7c3' + '\uf7c4' + '\uf7c5' + '\uf7c6' + '\uf7c7' + '\uf7c8' + '\uf7c9' + '\uf7ca' + '\uf7cb' + '\uf7cc' + '\uf7cd' + '\uf7ce' + '\uf7cf' + '\uf7d0' + '\uf7d1' + '\uf7d2' + '\uf7d3' + '\uf7d4' + '\uf7d5' + '\uf7d6' + '\uf7d7' + '\uf7d8' + '\uf7d9' + '\uf7da' + '\uf7db' + '\uf7dc' + '\uf7dd' + '\uf7de' + '\uf7df' + '\uf7e0' + '\uf7e1' + '\uf7e2' + '\uf7e3' + '\uf7e4' + '\uf7e5' + '\uf7e6' + '\uf7e7' + '\uf7e8' + '\uf7e9' + '\uf7ea' + '\uf7eb' + '\uf7ec' + '\uf7ed' + '\uf7ee' + '\uf7ef' + '\uf7f0' + '\uf7f1' + '\uf7f2' + '\uf7f3' + '\uf7f4' + '\uf7f5' + '\uf7f6' + '\uf7f7' + '\uf7f8' + '\uf7f9' + '\uf7fa' + '\uf7fb' + '\uf7fc' + '\uf7fd' + '\uf7fe' + '\uf7ff' +) + +### Encoding table +encoding_table = codecs.charmap_build(decoding_table) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/__init__.py new file mode 100644 index 0000000..1f170cf --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/__init__.py @@ -0,0 +1,3295 @@ +# coding: utf-8 +""" +Package resource API +-------------------- + +A resource is a logical file contained within a package, or a logical +subdirectory thereof. The package resource API expects resource names +to have their path parts separated with ``/``, *not* whatever the local +path separator is. Do not use os.path operations to manipulate resource +names being passed into the API. + +The package resource API is designed to work with normal filesystem packages, +.egg files, and unpacked .egg files. It can also work in a limited way with +.zip files and with custom PEP 302 loaders that support the ``get_data()`` +method. +""" + +from __future__ import absolute_import + +import sys +import os +import io +import time +import re +import types +import zipfile +import zipimport +import warnings +import stat +import functools +import pkgutil +import operator +import platform +import collections +import plistlib +import email.parser +import errno +import tempfile +import textwrap +import itertools +import inspect +import ntpath +import posixpath +from pkgutil import get_importer + +try: + import _imp +except ImportError: + # Python 3.2 compatibility + import imp as _imp + +try: + FileExistsError +except NameError: + FileExistsError = OSError + +from pkg_resources.extern import six +from pkg_resources.extern.six.moves import urllib, map, filter + +# capture these to bypass sandboxing +from os import utime +try: + from os import mkdir, rename, unlink + WRITE_SUPPORT = True +except ImportError: + # no write support, probably under GAE + WRITE_SUPPORT = False + +from os import open as os_open +from os.path import isdir, split + +try: + import importlib.machinery as importlib_machinery + # access attribute to force import under delayed import mechanisms. + importlib_machinery.__name__ +except ImportError: + importlib_machinery = None + +from . import py31compat +from pkg_resources.extern import appdirs +from pkg_resources.extern import packaging +__import__('pkg_resources.extern.packaging.version') +__import__('pkg_resources.extern.packaging.specifiers') +__import__('pkg_resources.extern.packaging.requirements') +__import__('pkg_resources.extern.packaging.markers') + + +__metaclass__ = type + + +if (3, 0) < sys.version_info < (3, 4): + raise RuntimeError("Python 3.4 or later is required") + +if six.PY2: + # Those builtin exceptions are only defined in Python 3 + PermissionError = None + NotADirectoryError = None + +# declare some globals that will be defined later to +# satisfy the linters. +require = None +working_set = None +add_activation_listener = None +resources_stream = None +cleanup_resources = None +resource_dir = None +resource_stream = None +set_extraction_path = None +resource_isdir = None +resource_string = None +iter_entry_points = None +resource_listdir = None +resource_filename = None +resource_exists = None +_distribution_finders = None +_namespace_handlers = None +_namespace_packages = None + + +class PEP440Warning(RuntimeWarning): + """ + Used when there is an issue with a version or specifier not complying with + PEP 440. + """ + + +def parse_version(v): + try: + return packaging.version.Version(v) + except packaging.version.InvalidVersion: + return packaging.version.LegacyVersion(v) + + +_state_vars = {} + + +def _declare_state(vartype, **kw): + globals().update(kw) + _state_vars.update(dict.fromkeys(kw, vartype)) + + +def __getstate__(): + state = {} + g = globals() + for k, v in _state_vars.items(): + state[k] = g['_sget_' + v](g[k]) + return state + + +def __setstate__(state): + g = globals() + for k, v in state.items(): + g['_sset_' + _state_vars[k]](k, g[k], v) + return state + + +def _sget_dict(val): + return val.copy() + + +def _sset_dict(key, ob, state): + ob.clear() + ob.update(state) + + +def _sget_object(val): + return val.__getstate__() + + +def _sset_object(key, ob, state): + ob.__setstate__(state) + + +_sget_none = _sset_none = lambda *args: None + + +def get_supported_platform(): + """Return this platform's maximum compatible version. + + distutils.util.get_platform() normally reports the minimum version + of Mac OS X that would be required to *use* extensions produced by + distutils. But what we want when checking compatibility is to know the + version of Mac OS X that we are *running*. To allow usage of packages that + explicitly require a newer version of Mac OS X, we must also know the + current version of the OS. + + If this condition occurs for any other platform with a version in its + platform strings, this function should be extended accordingly. + """ + plat = get_build_platform() + m = macosVersionString.match(plat) + if m is not None and sys.platform == "darwin": + try: + plat = 'macosx-%s-%s' % ('.'.join(_macosx_vers()[:2]), m.group(3)) + except ValueError: + # not Mac OS X + pass + return plat + + +__all__ = [ + # Basic resource access and distribution/entry point discovery + 'require', 'run_script', 'get_provider', 'get_distribution', + 'load_entry_point', 'get_entry_map', 'get_entry_info', + 'iter_entry_points', + 'resource_string', 'resource_stream', 'resource_filename', + 'resource_listdir', 'resource_exists', 'resource_isdir', + + # Environmental control + 'declare_namespace', 'working_set', 'add_activation_listener', + 'find_distributions', 'set_extraction_path', 'cleanup_resources', + 'get_default_cache', + + # Primary implementation classes + 'Environment', 'WorkingSet', 'ResourceManager', + 'Distribution', 'Requirement', 'EntryPoint', + + # Exceptions + 'ResolutionError', 'VersionConflict', 'DistributionNotFound', + 'UnknownExtra', 'ExtractionError', + + # Warnings + 'PEP440Warning', + + # Parsing functions and string utilities + 'parse_requirements', 'parse_version', 'safe_name', 'safe_version', + 'get_platform', 'compatible_platforms', 'yield_lines', 'split_sections', + 'safe_extra', 'to_filename', 'invalid_marker', 'evaluate_marker', + + # filesystem utilities + 'ensure_directory', 'normalize_path', + + # Distribution "precedence" constants + 'EGG_DIST', 'BINARY_DIST', 'SOURCE_DIST', 'CHECKOUT_DIST', 'DEVELOP_DIST', + + # "Provider" interfaces, implementations, and registration/lookup APIs + 'IMetadataProvider', 'IResourceProvider', 'FileMetadata', + 'PathMetadata', 'EggMetadata', 'EmptyProvider', 'empty_provider', + 'NullProvider', 'EggProvider', 'DefaultProvider', 'ZipProvider', + 'register_finder', 'register_namespace_handler', 'register_loader_type', + 'fixup_namespace_packages', 'get_importer', + + # Warnings + 'PkgResourcesDeprecationWarning', + + # Deprecated/backward compatibility only + 'run_main', 'AvailableDistributions', +] + + +class ResolutionError(Exception): + """Abstract base for dependency resolution errors""" + + def __repr__(self): + return self.__class__.__name__ + repr(self.args) + + +class VersionConflict(ResolutionError): + """ + An already-installed version conflicts with the requested version. + + Should be initialized with the installed Distribution and the requested + Requirement. + """ + + _template = "{self.dist} is installed but {self.req} is required" + + @property + def dist(self): + return self.args[0] + + @property + def req(self): + return self.args[1] + + def report(self): + return self._template.format(**locals()) + + def with_context(self, required_by): + """ + If required_by is non-empty, return a version of self that is a + ContextualVersionConflict. + """ + if not required_by: + return self + args = self.args + (required_by,) + return ContextualVersionConflict(*args) + + +class ContextualVersionConflict(VersionConflict): + """ + A VersionConflict that accepts a third parameter, the set of the + requirements that required the installed Distribution. + """ + + _template = VersionConflict._template + ' by {self.required_by}' + + @property + def required_by(self): + return self.args[2] + + +class DistributionNotFound(ResolutionError): + """A requested distribution was not found""" + + _template = ("The '{self.req}' distribution was not found " + "and is required by {self.requirers_str}") + + @property + def req(self): + return self.args[0] + + @property + def requirers(self): + return self.args[1] + + @property + def requirers_str(self): + if not self.requirers: + return 'the application' + return ', '.join(self.requirers) + + def report(self): + return self._template.format(**locals()) + + def __str__(self): + return self.report() + + +class UnknownExtra(ResolutionError): + """Distribution doesn't have an "extra feature" of the given name""" + + +_provider_factories = {} + +PY_MAJOR = sys.version[:3] +EGG_DIST = 3 +BINARY_DIST = 2 +SOURCE_DIST = 1 +CHECKOUT_DIST = 0 +DEVELOP_DIST = -1 + + +def register_loader_type(loader_type, provider_factory): + """Register `provider_factory` to make providers for `loader_type` + + `loader_type` is the type or class of a PEP 302 ``module.__loader__``, + and `provider_factory` is a function that, passed a *module* object, + returns an ``IResourceProvider`` for that module. + """ + _provider_factories[loader_type] = provider_factory + + +def get_provider(moduleOrReq): + """Return an IResourceProvider for the named module or requirement""" + if isinstance(moduleOrReq, Requirement): + return working_set.find(moduleOrReq) or require(str(moduleOrReq))[0] + try: + module = sys.modules[moduleOrReq] + except KeyError: + __import__(moduleOrReq) + module = sys.modules[moduleOrReq] + loader = getattr(module, '__loader__', None) + return _find_adapter(_provider_factories, loader)(module) + + +def _macosx_vers(_cache=[]): + if not _cache: + version = platform.mac_ver()[0] + # fallback for MacPorts + if version == '': + plist = '/System/Library/CoreServices/SystemVersion.plist' + if os.path.exists(plist): + if hasattr(plistlib, 'readPlist'): + plist_content = plistlib.readPlist(plist) + if 'ProductVersion' in plist_content: + version = plist_content['ProductVersion'] + + _cache.append(version.split('.')) + return _cache[0] + + +def _macosx_arch(machine): + return {'PowerPC': 'ppc', 'Power_Macintosh': 'ppc'}.get(machine, machine) + + +def get_build_platform(): + """Return this platform's string for platform-specific distributions + + XXX Currently this is the same as ``distutils.util.get_platform()``, but it + needs some hacks for Linux and Mac OS X. + """ + from sysconfig import get_platform + + plat = get_platform() + if sys.platform == "darwin" and not plat.startswith('macosx-'): + try: + version = _macosx_vers() + machine = os.uname()[4].replace(" ", "_") + return "macosx-%d.%d-%s" % ( + int(version[0]), int(version[1]), + _macosx_arch(machine), + ) + except ValueError: + # if someone is running a non-Mac darwin system, this will fall + # through to the default implementation + pass + return plat + + +macosVersionString = re.compile(r"macosx-(\d+)\.(\d+)-(.*)") +darwinVersionString = re.compile(r"darwin-(\d+)\.(\d+)\.(\d+)-(.*)") +# XXX backward compat +get_platform = get_build_platform + + +def compatible_platforms(provided, required): + """Can code for the `provided` platform run on the `required` platform? + + Returns true if either platform is ``None``, or the platforms are equal. + + XXX Needs compatibility checks for Linux and other unixy OSes. + """ + if provided is None or required is None or provided == required: + # easy case + return True + + # Mac OS X special cases + reqMac = macosVersionString.match(required) + if reqMac: + provMac = macosVersionString.match(provided) + + # is this a Mac package? + if not provMac: + # this is backwards compatibility for packages built before + # setuptools 0.6. All packages built after this point will + # use the new macosx designation. + provDarwin = darwinVersionString.match(provided) + if provDarwin: + dversion = int(provDarwin.group(1)) + macosversion = "%s.%s" % (reqMac.group(1), reqMac.group(2)) + if dversion == 7 and macosversion >= "10.3" or \ + dversion == 8 and macosversion >= "10.4": + return True + # egg isn't macosx or legacy darwin + return False + + # are they the same major version and machine type? + if provMac.group(1) != reqMac.group(1) or \ + provMac.group(3) != reqMac.group(3): + return False + + # is the required OS major update >= the provided one? + if int(provMac.group(2)) > int(reqMac.group(2)): + return False + + return True + + # XXX Linux and other platforms' special cases should go here + return False + + +def run_script(dist_spec, script_name): + """Locate distribution `dist_spec` and run its `script_name` script""" + ns = sys._getframe(1).f_globals + name = ns['__name__'] + ns.clear() + ns['__name__'] = name + require(dist_spec)[0].run_script(script_name, ns) + + +# backward compatibility +run_main = run_script + + +def get_distribution(dist): + """Return a current distribution object for a Requirement or string""" + if isinstance(dist, six.string_types): + dist = Requirement.parse(dist) + if isinstance(dist, Requirement): + dist = get_provider(dist) + if not isinstance(dist, Distribution): + raise TypeError("Expected string, Requirement, or Distribution", dist) + return dist + + +def load_entry_point(dist, group, name): + """Return `name` entry point of `group` for `dist` or raise ImportError""" + return get_distribution(dist).load_entry_point(group, name) + + +def get_entry_map(dist, group=None): + """Return the entry point map for `group`, or the full entry map""" + return get_distribution(dist).get_entry_map(group) + + +def get_entry_info(dist, group, name): + """Return the EntryPoint object for `group`+`name`, or ``None``""" + return get_distribution(dist).get_entry_info(group, name) + + +class IMetadataProvider: + def has_metadata(name): + """Does the package's distribution contain the named metadata?""" + + def get_metadata(name): + """The named metadata resource as a string""" + + def get_metadata_lines(name): + """Yield named metadata resource as list of non-blank non-comment lines + + Leading and trailing whitespace is stripped from each line, and lines + with ``#`` as the first non-blank character are omitted.""" + + def metadata_isdir(name): + """Is the named metadata a directory? (like ``os.path.isdir()``)""" + + def metadata_listdir(name): + """List of metadata names in the directory (like ``os.listdir()``)""" + + def run_script(script_name, namespace): + """Execute the named script in the supplied namespace dictionary""" + + +class IResourceProvider(IMetadataProvider): + """An object that provides access to package resources""" + + def get_resource_filename(manager, resource_name): + """Return a true filesystem path for `resource_name` + + `manager` must be an ``IResourceManager``""" + + def get_resource_stream(manager, resource_name): + """Return a readable file-like object for `resource_name` + + `manager` must be an ``IResourceManager``""" + + def get_resource_string(manager, resource_name): + """Return a string containing the contents of `resource_name` + + `manager` must be an ``IResourceManager``""" + + def has_resource(resource_name): + """Does the package contain the named resource?""" + + def resource_isdir(resource_name): + """Is the named resource a directory? (like ``os.path.isdir()``)""" + + def resource_listdir(resource_name): + """List of resource names in the directory (like ``os.listdir()``)""" + + +class WorkingSet: + """A collection of active distributions on sys.path (or a similar list)""" + + def __init__(self, entries=None): + """Create working set from list of path entries (default=sys.path)""" + self.entries = [] + self.entry_keys = {} + self.by_key = {} + self.callbacks = [] + + if entries is None: + entries = sys.path + + for entry in entries: + self.add_entry(entry) + + @classmethod + def _build_master(cls): + """ + Prepare the master working set. + """ + ws = cls() + try: + from __main__ import __requires__ + except ImportError: + # The main program does not list any requirements + return ws + + # ensure the requirements are met + try: + ws.require(__requires__) + except VersionConflict: + return cls._build_from_requirements(__requires__) + + return ws + + @classmethod + def _build_from_requirements(cls, req_spec): + """ + Build a working set from a requirement spec. Rewrites sys.path. + """ + # try it without defaults already on sys.path + # by starting with an empty path + ws = cls([]) + reqs = parse_requirements(req_spec) + dists = ws.resolve(reqs, Environment()) + for dist in dists: + ws.add(dist) + + # add any missing entries from sys.path + for entry in sys.path: + if entry not in ws.entries: + ws.add_entry(entry) + + # then copy back to sys.path + sys.path[:] = ws.entries + return ws + + def add_entry(self, entry): + """Add a path item to ``.entries``, finding any distributions on it + + ``find_distributions(entry, True)`` is used to find distributions + corresponding to the path entry, and they are added. `entry` is + always appended to ``.entries``, even if it is already present. + (This is because ``sys.path`` can contain the same value more than + once, and the ``.entries`` of the ``sys.path`` WorkingSet should always + equal ``sys.path``.) + """ + self.entry_keys.setdefault(entry, []) + self.entries.append(entry) + for dist in find_distributions(entry, True): + self.add(dist, entry, False) + + def __contains__(self, dist): + """True if `dist` is the active distribution for its project""" + return self.by_key.get(dist.key) == dist + + def find(self, req): + """Find a distribution matching requirement `req` + + If there is an active distribution for the requested project, this + returns it as long as it meets the version requirement specified by + `req`. But, if there is an active distribution for the project and it + does *not* meet the `req` requirement, ``VersionConflict`` is raised. + If there is no active distribution for the requested project, ``None`` + is returned. + """ + dist = self.by_key.get(req.key) + if dist is not None and dist not in req: + # XXX add more info + raise VersionConflict(dist, req) + return dist + + def iter_entry_points(self, group, name=None): + """Yield entry point objects from `group` matching `name` + + If `name` is None, yields all entry points in `group` from all + distributions in the working set, otherwise only ones matching + both `group` and `name` are yielded (in distribution order). + """ + return ( + entry + for dist in self + for entry in dist.get_entry_map(group).values() + if name is None or name == entry.name + ) + + def run_script(self, requires, script_name): + """Locate distribution for `requires` and run `script_name` script""" + ns = sys._getframe(1).f_globals + name = ns['__name__'] + ns.clear() + ns['__name__'] = name + self.require(requires)[0].run_script(script_name, ns) + + def __iter__(self): + """Yield distributions for non-duplicate projects in the working set + + The yield order is the order in which the items' path entries were + added to the working set. + """ + seen = {} + for item in self.entries: + if item not in self.entry_keys: + # workaround a cache issue + continue + + for key in self.entry_keys[item]: + if key not in seen: + seen[key] = 1 + yield self.by_key[key] + + def add(self, dist, entry=None, insert=True, replace=False): + """Add `dist` to working set, associated with `entry` + + If `entry` is unspecified, it defaults to the ``.location`` of `dist`. + On exit from this routine, `entry` is added to the end of the working + set's ``.entries`` (if it wasn't already present). + + `dist` is only added to the working set if it's for a project that + doesn't already have a distribution in the set, unless `replace=True`. + If it's added, any callbacks registered with the ``subscribe()`` method + will be called. + """ + if insert: + dist.insert_on(self.entries, entry, replace=replace) + + if entry is None: + entry = dist.location + keys = self.entry_keys.setdefault(entry, []) + keys2 = self.entry_keys.setdefault(dist.location, []) + if not replace and dist.key in self.by_key: + # ignore hidden distros + return + + self.by_key[dist.key] = dist + if dist.key not in keys: + keys.append(dist.key) + if dist.key not in keys2: + keys2.append(dist.key) + self._added_new(dist) + + def resolve(self, requirements, env=None, installer=None, + replace_conflicting=False, extras=None): + """List all distributions needed to (recursively) meet `requirements` + + `requirements` must be a sequence of ``Requirement`` objects. `env`, + if supplied, should be an ``Environment`` instance. If + not supplied, it defaults to all distributions available within any + entry or distribution in the working set. `installer`, if supplied, + will be invoked with each requirement that cannot be met by an + already-installed distribution; it should return a ``Distribution`` or + ``None``. + + Unless `replace_conflicting=True`, raises a VersionConflict exception + if + any requirements are found on the path that have the correct name but + the wrong version. Otherwise, if an `installer` is supplied it will be + invoked to obtain the correct version of the requirement and activate + it. + + `extras` is a list of the extras to be used with these requirements. + This is important because extra requirements may look like `my_req; + extra = "my_extra"`, which would otherwise be interpreted as a purely + optional requirement. Instead, we want to be able to assert that these + requirements are truly required. + """ + + # set up the stack + requirements = list(requirements)[::-1] + # set of processed requirements + processed = {} + # key -> dist + best = {} + to_activate = [] + + req_extras = _ReqExtras() + + # Mapping of requirement to set of distributions that required it; + # useful for reporting info about conflicts. + required_by = collections.defaultdict(set) + + while requirements: + # process dependencies breadth-first + req = requirements.pop(0) + if req in processed: + # Ignore cyclic or redundant dependencies + continue + + if not req_extras.markers_pass(req, extras): + continue + + dist = best.get(req.key) + if dist is None: + # Find the best distribution and add it to the map + dist = self.by_key.get(req.key) + if dist is None or (dist not in req and replace_conflicting): + ws = self + if env is None: + if dist is None: + env = Environment(self.entries) + else: + # Use an empty environment and workingset to avoid + # any further conflicts with the conflicting + # distribution + env = Environment([]) + ws = WorkingSet([]) + dist = best[req.key] = env.best_match( + req, ws, installer, + replace_conflicting=replace_conflicting + ) + if dist is None: + requirers = required_by.get(req, None) + raise DistributionNotFound(req, requirers) + to_activate.append(dist) + if dist not in req: + # Oops, the "best" so far conflicts with a dependency + dependent_req = required_by[req] + raise VersionConflict(dist, req).with_context(dependent_req) + + # push the new requirements onto the stack + new_requirements = dist.requires(req.extras)[::-1] + requirements.extend(new_requirements) + + # Register the new requirements needed by req + for new_requirement in new_requirements: + required_by[new_requirement].add(req.project_name) + req_extras[new_requirement] = req.extras + + processed[req] = True + + # return list of distros to activate + return to_activate + + def find_plugins( + self, plugin_env, full_env=None, installer=None, fallback=True): + """Find all activatable distributions in `plugin_env` + + Example usage:: + + distributions, errors = working_set.find_plugins( + Environment(plugin_dirlist) + ) + # add plugins+libs to sys.path + map(working_set.add, distributions) + # display errors + print('Could not load', errors) + + The `plugin_env` should be an ``Environment`` instance that contains + only distributions that are in the project's "plugin directory" or + directories. The `full_env`, if supplied, should be an ``Environment`` + contains all currently-available distributions. If `full_env` is not + supplied, one is created automatically from the ``WorkingSet`` this + method is called on, which will typically mean that every directory on + ``sys.path`` will be scanned for distributions. + + `installer` is a standard installer callback as used by the + ``resolve()`` method. The `fallback` flag indicates whether we should + attempt to resolve older versions of a plugin if the newest version + cannot be resolved. + + This method returns a 2-tuple: (`distributions`, `error_info`), where + `distributions` is a list of the distributions found in `plugin_env` + that were loadable, along with any other distributions that are needed + to resolve their dependencies. `error_info` is a dictionary mapping + unloadable plugin distributions to an exception instance describing the + error that occurred. Usually this will be a ``DistributionNotFound`` or + ``VersionConflict`` instance. + """ + + plugin_projects = list(plugin_env) + # scan project names in alphabetic order + plugin_projects.sort() + + error_info = {} + distributions = {} + + if full_env is None: + env = Environment(self.entries) + env += plugin_env + else: + env = full_env + plugin_env + + shadow_set = self.__class__([]) + # put all our entries in shadow_set + list(map(shadow_set.add, self)) + + for project_name in plugin_projects: + + for dist in plugin_env[project_name]: + + req = [dist.as_requirement()] + + try: + resolvees = shadow_set.resolve(req, env, installer) + + except ResolutionError as v: + # save error info + error_info[dist] = v + if fallback: + # try the next older version of project + continue + else: + # give up on this project, keep going + break + + else: + list(map(shadow_set.add, resolvees)) + distributions.update(dict.fromkeys(resolvees)) + + # success, no need to try any more versions of this project + break + + distributions = list(distributions) + distributions.sort() + + return distributions, error_info + + def require(self, *requirements): + """Ensure that distributions matching `requirements` are activated + + `requirements` must be a string or a (possibly-nested) sequence + thereof, specifying the distributions and versions required. The + return value is a sequence of the distributions that needed to be + activated to fulfill the requirements; all relevant distributions are + included, even if they were already activated in this working set. + """ + needed = self.resolve(parse_requirements(requirements)) + + for dist in needed: + self.add(dist) + + return needed + + def subscribe(self, callback, existing=True): + """Invoke `callback` for all distributions + + If `existing=True` (default), + call on all existing ones, as well. + """ + if callback in self.callbacks: + return + self.callbacks.append(callback) + if not existing: + return + for dist in self: + callback(dist) + + def _added_new(self, dist): + for callback in self.callbacks: + callback(dist) + + def __getstate__(self): + return ( + self.entries[:], self.entry_keys.copy(), self.by_key.copy(), + self.callbacks[:] + ) + + def __setstate__(self, e_k_b_c): + entries, keys, by_key, callbacks = e_k_b_c + self.entries = entries[:] + self.entry_keys = keys.copy() + self.by_key = by_key.copy() + self.callbacks = callbacks[:] + + +class _ReqExtras(dict): + """ + Map each requirement to the extras that demanded it. + """ + + def markers_pass(self, req, extras=None): + """ + Evaluate markers for req against each extra that + demanded it. + + Return False if the req has a marker and fails + evaluation. Otherwise, return True. + """ + extra_evals = ( + req.marker.evaluate({'extra': extra}) + for extra in self.get(req, ()) + (extras or (None,)) + ) + return not req.marker or any(extra_evals) + + +class Environment: + """Searchable snapshot of distributions on a search path""" + + def __init__( + self, search_path=None, platform=get_supported_platform(), + python=PY_MAJOR): + """Snapshot distributions available on a search path + + Any distributions found on `search_path` are added to the environment. + `search_path` should be a sequence of ``sys.path`` items. If not + supplied, ``sys.path`` is used. + + `platform` is an optional string specifying the name of the platform + that platform-specific distributions must be compatible with. If + unspecified, it defaults to the current platform. `python` is an + optional string naming the desired version of Python (e.g. ``'3.6'``); + it defaults to the current version. + + You may explicitly set `platform` (and/or `python`) to ``None`` if you + wish to map *all* distributions, not just those compatible with the + running platform or Python version. + """ + self._distmap = {} + self.platform = platform + self.python = python + self.scan(search_path) + + def can_add(self, dist): + """Is distribution `dist` acceptable for this environment? + + The distribution must match the platform and python version + requirements specified when this environment was created, or False + is returned. + """ + py_compat = ( + self.python is None + or dist.py_version is None + or dist.py_version == self.python + ) + return py_compat and compatible_platforms(dist.platform, self.platform) + + def remove(self, dist): + """Remove `dist` from the environment""" + self._distmap[dist.key].remove(dist) + + def scan(self, search_path=None): + """Scan `search_path` for distributions usable in this environment + + Any distributions found are added to the environment. + `search_path` should be a sequence of ``sys.path`` items. If not + supplied, ``sys.path`` is used. Only distributions conforming to + the platform/python version defined at initialization are added. + """ + if search_path is None: + search_path = sys.path + + for item in search_path: + for dist in find_distributions(item): + self.add(dist) + + def __getitem__(self, project_name): + """Return a newest-to-oldest list of distributions for `project_name` + + Uses case-insensitive `project_name` comparison, assuming all the + project's distributions use their project's name converted to all + lowercase as their key. + + """ + distribution_key = project_name.lower() + return self._distmap.get(distribution_key, []) + + def add(self, dist): + """Add `dist` if we ``can_add()`` it and it has not already been added + """ + if self.can_add(dist) and dist.has_version(): + dists = self._distmap.setdefault(dist.key, []) + if dist not in dists: + dists.append(dist) + dists.sort(key=operator.attrgetter('hashcmp'), reverse=True) + + def best_match( + self, req, working_set, installer=None, replace_conflicting=False): + """Find distribution best matching `req` and usable on `working_set` + + This calls the ``find(req)`` method of the `working_set` to see if a + suitable distribution is already active. (This may raise + ``VersionConflict`` if an unsuitable version of the project is already + active in the specified `working_set`.) If a suitable distribution + isn't active, this method returns the newest distribution in the + environment that meets the ``Requirement`` in `req`. If no suitable + distribution is found, and `installer` is supplied, then the result of + calling the environment's ``obtain(req, installer)`` method will be + returned. + """ + try: + dist = working_set.find(req) + except VersionConflict: + if not replace_conflicting: + raise + dist = None + if dist is not None: + return dist + for dist in self[req.key]: + if dist in req: + return dist + # try to download/install + return self.obtain(req, installer) + + def obtain(self, requirement, installer=None): + """Obtain a distribution matching `requirement` (e.g. via download) + + Obtain a distro that matches requirement (e.g. via download). In the + base ``Environment`` class, this routine just returns + ``installer(requirement)``, unless `installer` is None, in which case + None is returned instead. This method is a hook that allows subclasses + to attempt other ways of obtaining a distribution before falling back + to the `installer` argument.""" + if installer is not None: + return installer(requirement) + + def __iter__(self): + """Yield the unique project names of the available distributions""" + for key in self._distmap.keys(): + if self[key]: + yield key + + def __iadd__(self, other): + """In-place addition of a distribution or environment""" + if isinstance(other, Distribution): + self.add(other) + elif isinstance(other, Environment): + for project in other: + for dist in other[project]: + self.add(dist) + else: + raise TypeError("Can't add %r to environment" % (other,)) + return self + + def __add__(self, other): + """Add an environment or distribution to an environment""" + new = self.__class__([], platform=None, python=None) + for env in self, other: + new += env + return new + + +# XXX backward compatibility +AvailableDistributions = Environment + + +class ExtractionError(RuntimeError): + """An error occurred extracting a resource + + The following attributes are available from instances of this exception: + + manager + The resource manager that raised this exception + + cache_path + The base directory for resource extraction + + original_error + The exception instance that caused extraction to fail + """ + + +class ResourceManager: + """Manage resource extraction and packages""" + extraction_path = None + + def __init__(self): + self.cached_files = {} + + def resource_exists(self, package_or_requirement, resource_name): + """Does the named resource exist?""" + return get_provider(package_or_requirement).has_resource(resource_name) + + def resource_isdir(self, package_or_requirement, resource_name): + """Is the named resource an existing directory?""" + return get_provider(package_or_requirement).resource_isdir( + resource_name + ) + + def resource_filename(self, package_or_requirement, resource_name): + """Return a true filesystem path for specified resource""" + return get_provider(package_or_requirement).get_resource_filename( + self, resource_name + ) + + def resource_stream(self, package_or_requirement, resource_name): + """Return a readable file-like object for specified resource""" + return get_provider(package_or_requirement).get_resource_stream( + self, resource_name + ) + + def resource_string(self, package_or_requirement, resource_name): + """Return specified resource as a string""" + return get_provider(package_or_requirement).get_resource_string( + self, resource_name + ) + + def resource_listdir(self, package_or_requirement, resource_name): + """List the contents of the named resource directory""" + return get_provider(package_or_requirement).resource_listdir( + resource_name + ) + + def extraction_error(self): + """Give an error message for problems extracting file(s)""" + + old_exc = sys.exc_info()[1] + cache_path = self.extraction_path or get_default_cache() + + tmpl = textwrap.dedent(""" + Can't extract file(s) to egg cache + + The following error occurred while trying to extract file(s) + to the Python egg cache: + + {old_exc} + + The Python egg cache directory is currently set to: + + {cache_path} + + Perhaps your account does not have write access to this directory? + You can change the cache directory by setting the PYTHON_EGG_CACHE + environment variable to point to an accessible directory. + """).lstrip() + err = ExtractionError(tmpl.format(**locals())) + err.manager = self + err.cache_path = cache_path + err.original_error = old_exc + raise err + + def get_cache_path(self, archive_name, names=()): + """Return absolute location in cache for `archive_name` and `names` + + The parent directory of the resulting path will be created if it does + not already exist. `archive_name` should be the base filename of the + enclosing egg (which may not be the name of the enclosing zipfile!), + including its ".egg" extension. `names`, if provided, should be a + sequence of path name parts "under" the egg's extraction location. + + This method should only be called by resource providers that need to + obtain an extraction location, and only for names they intend to + extract, as it tracks the generated names for possible cleanup later. + """ + extract_path = self.extraction_path or get_default_cache() + target_path = os.path.join(extract_path, archive_name + '-tmp', *names) + try: + _bypass_ensure_directory(target_path) + except Exception: + self.extraction_error() + + self._warn_unsafe_extraction_path(extract_path) + + self.cached_files[target_path] = 1 + return target_path + + @staticmethod + def _warn_unsafe_extraction_path(path): + """ + If the default extraction path is overridden and set to an insecure + location, such as /tmp, it opens up an opportunity for an attacker to + replace an extracted file with an unauthorized payload. Warn the user + if a known insecure location is used. + + See Distribute #375 for more details. + """ + if os.name == 'nt' and not path.startswith(os.environ['windir']): + # On Windows, permissions are generally restrictive by default + # and temp directories are not writable by other users, so + # bypass the warning. + return + mode = os.stat(path).st_mode + if mode & stat.S_IWOTH or mode & stat.S_IWGRP: + msg = ( + "%s is writable by group/others and vulnerable to attack " + "when " + "used with get_resource_filename. Consider a more secure " + "location (set with .set_extraction_path or the " + "PYTHON_EGG_CACHE environment variable)." % path + ) + warnings.warn(msg, UserWarning) + + def postprocess(self, tempname, filename): + """Perform any platform-specific postprocessing of `tempname` + + This is where Mac header rewrites should be done; other platforms don't + have anything special they should do. + + Resource providers should call this method ONLY after successfully + extracting a compressed resource. They must NOT call it on resources + that are already in the filesystem. + + `tempname` is the current (temporary) name of the file, and `filename` + is the name it will be renamed to by the caller after this routine + returns. + """ + + if os.name == 'posix': + # Make the resource executable + mode = ((os.stat(tempname).st_mode) | 0o555) & 0o7777 + os.chmod(tempname, mode) + + def set_extraction_path(self, path): + """Set the base path where resources will be extracted to, if needed. + + If you do not call this routine before any extractions take place, the + path defaults to the return value of ``get_default_cache()``. (Which + is based on the ``PYTHON_EGG_CACHE`` environment variable, with various + platform-specific fallbacks. See that routine's documentation for more + details.) + + Resources are extracted to subdirectories of this path based upon + information given by the ``IResourceProvider``. You may set this to a + temporary directory, but then you must call ``cleanup_resources()`` to + delete the extracted files when done. There is no guarantee that + ``cleanup_resources()`` will be able to remove all extracted files. + + (Note: you may not change the extraction path for a given resource + manager once resources have been extracted, unless you first call + ``cleanup_resources()``.) + """ + if self.cached_files: + raise ValueError( + "Can't change extraction path, files already extracted" + ) + + self.extraction_path = path + + def cleanup_resources(self, force=False): + """ + Delete all extracted resource files and directories, returning a list + of the file and directory names that could not be successfully removed. + This function does not have any concurrency protection, so it should + generally only be called when the extraction path is a temporary + directory exclusive to a single process. This method is not + automatically called; you must call it explicitly or register it as an + ``atexit`` function if you wish to ensure cleanup of a temporary + directory used for extractions. + """ + # XXX + + +def get_default_cache(): + """ + Return the ``PYTHON_EGG_CACHE`` environment variable + or a platform-relevant user cache dir for an app + named "Python-Eggs". + """ + return ( + os.environ.get('PYTHON_EGG_CACHE') + or appdirs.user_cache_dir(appname='Python-Eggs') + ) + + +def safe_name(name): + """Convert an arbitrary string to a standard distribution name + + Any runs of non-alphanumeric/. characters are replaced with a single '-'. + """ + return re.sub('[^A-Za-z0-9.]+', '-', name) + + +def safe_version(version): + """ + Convert an arbitrary string to a standard version string + """ + try: + # normalize the version + return str(packaging.version.Version(version)) + except packaging.version.InvalidVersion: + version = version.replace(' ', '.') + return re.sub('[^A-Za-z0-9.]+', '-', version) + + +def safe_extra(extra): + """Convert an arbitrary string to a standard 'extra' name + + Any runs of non-alphanumeric characters are replaced with a single '_', + and the result is always lowercased. + """ + return re.sub('[^A-Za-z0-9.-]+', '_', extra).lower() + + +def to_filename(name): + """Convert a project or version name to its filename-escaped form + + Any '-' characters are currently replaced with '_'. + """ + return name.replace('-', '_') + + +def invalid_marker(text): + """ + Validate text as a PEP 508 environment marker; return an exception + if invalid or False otherwise. + """ + try: + evaluate_marker(text) + except SyntaxError as e: + e.filename = None + e.lineno = None + return e + return False + + +def evaluate_marker(text, extra=None): + """ + Evaluate a PEP 508 environment marker. + Return a boolean indicating the marker result in this environment. + Raise SyntaxError if marker is invalid. + + This implementation uses the 'pyparsing' module. + """ + try: + marker = packaging.markers.Marker(text) + return marker.evaluate() + except packaging.markers.InvalidMarker as e: + raise SyntaxError(e) + + +class NullProvider: + """Try to implement resources and metadata for arbitrary PEP 302 loaders""" + + egg_name = None + egg_info = None + loader = None + + def __init__(self, module): + self.loader = getattr(module, '__loader__', None) + self.module_path = os.path.dirname(getattr(module, '__file__', '')) + + def get_resource_filename(self, manager, resource_name): + return self._fn(self.module_path, resource_name) + + def get_resource_stream(self, manager, resource_name): + return io.BytesIO(self.get_resource_string(manager, resource_name)) + + def get_resource_string(self, manager, resource_name): + return self._get(self._fn(self.module_path, resource_name)) + + def has_resource(self, resource_name): + return self._has(self._fn(self.module_path, resource_name)) + + def _get_metadata_path(self, name): + return self._fn(self.egg_info, name) + + def has_metadata(self, name): + if not self.egg_info: + return self.egg_info + + path = self._get_metadata_path(name) + return self._has(path) + + def get_metadata(self, name): + if not self.egg_info: + return "" + path = self._get_metadata_path(name) + value = self._get(path) + if six.PY2: + return value + try: + return value.decode('utf-8') + except UnicodeDecodeError as exc: + # Include the path in the error message to simplify + # troubleshooting, and without changing the exception type. + exc.reason += ' in {} file at path: {}'.format(name, path) + raise + + def get_metadata_lines(self, name): + return yield_lines(self.get_metadata(name)) + + def resource_isdir(self, resource_name): + return self._isdir(self._fn(self.module_path, resource_name)) + + def metadata_isdir(self, name): + return self.egg_info and self._isdir(self._fn(self.egg_info, name)) + + def resource_listdir(self, resource_name): + return self._listdir(self._fn(self.module_path, resource_name)) + + def metadata_listdir(self, name): + if self.egg_info: + return self._listdir(self._fn(self.egg_info, name)) + return [] + + def run_script(self, script_name, namespace): + script = 'scripts/' + script_name + if not self.has_metadata(script): + raise ResolutionError( + "Script {script!r} not found in metadata at {self.egg_info!r}" + .format(**locals()), + ) + script_text = self.get_metadata(script).replace('\r\n', '\n') + script_text = script_text.replace('\r', '\n') + script_filename = self._fn(self.egg_info, script) + namespace['__file__'] = script_filename + if os.path.exists(script_filename): + source = open(script_filename).read() + code = compile(source, script_filename, 'exec') + exec(code, namespace, namespace) + else: + from linecache import cache + cache[script_filename] = ( + len(script_text), 0, script_text.split('\n'), script_filename + ) + script_code = compile(script_text, script_filename, 'exec') + exec(script_code, namespace, namespace) + + def _has(self, path): + raise NotImplementedError( + "Can't perform this operation for unregistered loader type" + ) + + def _isdir(self, path): + raise NotImplementedError( + "Can't perform this operation for unregistered loader type" + ) + + def _listdir(self, path): + raise NotImplementedError( + "Can't perform this operation for unregistered loader type" + ) + + def _fn(self, base, resource_name): + self._validate_resource_path(resource_name) + if resource_name: + return os.path.join(base, *resource_name.split('/')) + return base + + @staticmethod + def _validate_resource_path(path): + """ + Validate the resource paths according to the docs. + https://setuptools.readthedocs.io/en/latest/pkg_resources.html#basic-resource-access + + >>> warned = getfixture('recwarn') + >>> warnings.simplefilter('always') + >>> vrp = NullProvider._validate_resource_path + >>> vrp('foo/bar.txt') + >>> bool(warned) + False + >>> vrp('../foo/bar.txt') + >>> bool(warned) + True + >>> warned.clear() + >>> vrp('/foo/bar.txt') + >>> bool(warned) + True + >>> vrp('foo/../../bar.txt') + >>> bool(warned) + True + >>> warned.clear() + >>> vrp('foo/f../bar.txt') + >>> bool(warned) + False + + Windows path separators are straight-up disallowed. + >>> vrp(r'\\foo/bar.txt') + Traceback (most recent call last): + ... + ValueError: Use of .. or absolute path in a resource path \ +is not allowed. + + >>> vrp(r'C:\\foo/bar.txt') + Traceback (most recent call last): + ... + ValueError: Use of .. or absolute path in a resource path \ +is not allowed. + + Blank values are allowed + + >>> vrp('') + >>> bool(warned) + False + + Non-string values are not. + + >>> vrp(None) + Traceback (most recent call last): + ... + AttributeError: ... + """ + invalid = ( + os.path.pardir in path.split(posixpath.sep) or + posixpath.isabs(path) or + ntpath.isabs(path) + ) + if not invalid: + return + + msg = "Use of .. or absolute path in a resource path is not allowed." + + # Aggressively disallow Windows absolute paths + if ntpath.isabs(path) and not posixpath.isabs(path): + raise ValueError(msg) + + # for compatibility, warn; in future + # raise ValueError(msg) + warnings.warn( + msg[:-1] + " and will raise exceptions in a future release.", + DeprecationWarning, + stacklevel=4, + ) + + def _get(self, path): + if hasattr(self.loader, 'get_data'): + return self.loader.get_data(path) + raise NotImplementedError( + "Can't perform this operation for loaders without 'get_data()'" + ) + + +register_loader_type(object, NullProvider) + + +class EggProvider(NullProvider): + """Provider based on a virtual filesystem""" + + def __init__(self, module): + NullProvider.__init__(self, module) + self._setup_prefix() + + def _setup_prefix(self): + # we assume here that our metadata may be nested inside a "basket" + # of multiple eggs; that's why we use module_path instead of .archive + path = self.module_path + old = None + while path != old: + if _is_egg_path(path): + self.egg_name = os.path.basename(path) + self.egg_info = os.path.join(path, 'EGG-INFO') + self.egg_root = path + break + old = path + path, base = os.path.split(path) + + +class DefaultProvider(EggProvider): + """Provides access to package resources in the filesystem""" + + def _has(self, path): + return os.path.exists(path) + + def _isdir(self, path): + return os.path.isdir(path) + + def _listdir(self, path): + return os.listdir(path) + + def get_resource_stream(self, manager, resource_name): + return open(self._fn(self.module_path, resource_name), 'rb') + + def _get(self, path): + with open(path, 'rb') as stream: + return stream.read() + + @classmethod + def _register(cls): + loader_names = 'SourceFileLoader', 'SourcelessFileLoader', + for name in loader_names: + loader_cls = getattr(importlib_machinery, name, type(None)) + register_loader_type(loader_cls, cls) + + +DefaultProvider._register() + + +class EmptyProvider(NullProvider): + """Provider that returns nothing for all requests""" + + module_path = None + + _isdir = _has = lambda self, path: False + + def _get(self, path): + return '' + + def _listdir(self, path): + return [] + + def __init__(self): + pass + + +empty_provider = EmptyProvider() + + +class ZipManifests(dict): + """ + zip manifest builder + """ + + @classmethod + def build(cls, path): + """ + Build a dictionary similar to the zipimport directory + caches, except instead of tuples, store ZipInfo objects. + + Use a platform-specific path separator (os.sep) for the path keys + for compatibility with pypy on Windows. + """ + with zipfile.ZipFile(path) as zfile: + items = ( + ( + name.replace('/', os.sep), + zfile.getinfo(name), + ) + for name in zfile.namelist() + ) + return dict(items) + + load = build + + +class MemoizedZipManifests(ZipManifests): + """ + Memoized zipfile manifests. + """ + manifest_mod = collections.namedtuple('manifest_mod', 'manifest mtime') + + def load(self, path): + """ + Load a manifest at path or return a suitable manifest already loaded. + """ + path = os.path.normpath(path) + mtime = os.stat(path).st_mtime + + if path not in self or self[path].mtime != mtime: + manifest = self.build(path) + self[path] = self.manifest_mod(manifest, mtime) + + return self[path].manifest + + +class ZipProvider(EggProvider): + """Resource support for zips and eggs""" + + eagers = None + _zip_manifests = MemoizedZipManifests() + + def __init__(self, module): + EggProvider.__init__(self, module) + self.zip_pre = self.loader.archive + os.sep + + def _zipinfo_name(self, fspath): + # Convert a virtual filename (full path to file) into a zipfile subpath + # usable with the zipimport directory cache for our target archive + fspath = fspath.rstrip(os.sep) + if fspath == self.loader.archive: + return '' + if fspath.startswith(self.zip_pre): + return fspath[len(self.zip_pre):] + raise AssertionError( + "%s is not a subpath of %s" % (fspath, self.zip_pre) + ) + + def _parts(self, zip_path): + # Convert a zipfile subpath into an egg-relative path part list. + # pseudo-fs path + fspath = self.zip_pre + zip_path + if fspath.startswith(self.egg_root + os.sep): + return fspath[len(self.egg_root) + 1:].split(os.sep) + raise AssertionError( + "%s is not a subpath of %s" % (fspath, self.egg_root) + ) + + @property + def zipinfo(self): + return self._zip_manifests.load(self.loader.archive) + + def get_resource_filename(self, manager, resource_name): + if not self.egg_name: + raise NotImplementedError( + "resource_filename() only supported for .egg, not .zip" + ) + # no need to lock for extraction, since we use temp names + zip_path = self._resource_to_zip(resource_name) + eagers = self._get_eager_resources() + if '/'.join(self._parts(zip_path)) in eagers: + for name in eagers: + self._extract_resource(manager, self._eager_to_zip(name)) + return self._extract_resource(manager, zip_path) + + @staticmethod + def _get_date_and_size(zip_stat): + size = zip_stat.file_size + # ymdhms+wday, yday, dst + date_time = zip_stat.date_time + (0, 0, -1) + # 1980 offset already done + timestamp = time.mktime(date_time) + return timestamp, size + + def _extract_resource(self, manager, zip_path): + + if zip_path in self._index(): + for name in self._index()[zip_path]: + last = self._extract_resource( + manager, os.path.join(zip_path, name) + ) + # return the extracted directory name + return os.path.dirname(last) + + timestamp, size = self._get_date_and_size(self.zipinfo[zip_path]) + + if not WRITE_SUPPORT: + raise IOError('"os.rename" and "os.unlink" are not supported ' + 'on this platform') + try: + + real_path = manager.get_cache_path( + self.egg_name, self._parts(zip_path) + ) + + if self._is_current(real_path, zip_path): + return real_path + + outf, tmpnam = _mkstemp( + ".$extract", + dir=os.path.dirname(real_path), + ) + os.write(outf, self.loader.get_data(zip_path)) + os.close(outf) + utime(tmpnam, (timestamp, timestamp)) + manager.postprocess(tmpnam, real_path) + + try: + rename(tmpnam, real_path) + + except os.error: + if os.path.isfile(real_path): + if self._is_current(real_path, zip_path): + # the file became current since it was checked above, + # so proceed. + return real_path + # Windows, del old file and retry + elif os.name == 'nt': + unlink(real_path) + rename(tmpnam, real_path) + return real_path + raise + + except os.error: + # report a user-friendly error + manager.extraction_error() + + return real_path + + def _is_current(self, file_path, zip_path): + """ + Return True if the file_path is current for this zip_path + """ + timestamp, size = self._get_date_and_size(self.zipinfo[zip_path]) + if not os.path.isfile(file_path): + return False + stat = os.stat(file_path) + if stat.st_size != size or stat.st_mtime != timestamp: + return False + # check that the contents match + zip_contents = self.loader.get_data(zip_path) + with open(file_path, 'rb') as f: + file_contents = f.read() + return zip_contents == file_contents + + def _get_eager_resources(self): + if self.eagers is None: + eagers = [] + for name in ('native_libs.txt', 'eager_resources.txt'): + if self.has_metadata(name): + eagers.extend(self.get_metadata_lines(name)) + self.eagers = eagers + return self.eagers + + def _index(self): + try: + return self._dirindex + except AttributeError: + ind = {} + for path in self.zipinfo: + parts = path.split(os.sep) + while parts: + parent = os.sep.join(parts[:-1]) + if parent in ind: + ind[parent].append(parts[-1]) + break + else: + ind[parent] = [parts.pop()] + self._dirindex = ind + return ind + + def _has(self, fspath): + zip_path = self._zipinfo_name(fspath) + return zip_path in self.zipinfo or zip_path in self._index() + + def _isdir(self, fspath): + return self._zipinfo_name(fspath) in self._index() + + def _listdir(self, fspath): + return list(self._index().get(self._zipinfo_name(fspath), ())) + + def _eager_to_zip(self, resource_name): + return self._zipinfo_name(self._fn(self.egg_root, resource_name)) + + def _resource_to_zip(self, resource_name): + return self._zipinfo_name(self._fn(self.module_path, resource_name)) + + +register_loader_type(zipimport.zipimporter, ZipProvider) + + +class FileMetadata(EmptyProvider): + """Metadata handler for standalone PKG-INFO files + + Usage:: + + metadata = FileMetadata("/path/to/PKG-INFO") + + This provider rejects all data and metadata requests except for PKG-INFO, + which is treated as existing, and will be the contents of the file at + the provided location. + """ + + def __init__(self, path): + self.path = path + + def _get_metadata_path(self, name): + return self.path + + def has_metadata(self, name): + return name == 'PKG-INFO' and os.path.isfile(self.path) + + def get_metadata(self, name): + if name != 'PKG-INFO': + raise KeyError("No metadata except PKG-INFO is available") + + with io.open(self.path, encoding='utf-8', errors="replace") as f: + metadata = f.read() + self._warn_on_replacement(metadata) + return metadata + + def _warn_on_replacement(self, metadata): + # Python 2.7 compat for: replacement_char = '�' + replacement_char = b'\xef\xbf\xbd'.decode('utf-8') + if replacement_char in metadata: + tmpl = "{self.path} could not be properly decoded in UTF-8" + msg = tmpl.format(**locals()) + warnings.warn(msg) + + def get_metadata_lines(self, name): + return yield_lines(self.get_metadata(name)) + + +class PathMetadata(DefaultProvider): + """Metadata provider for egg directories + + Usage:: + + # Development eggs: + + egg_info = "/path/to/PackageName.egg-info" + base_dir = os.path.dirname(egg_info) + metadata = PathMetadata(base_dir, egg_info) + dist_name = os.path.splitext(os.path.basename(egg_info))[0] + dist = Distribution(basedir, project_name=dist_name, metadata=metadata) + + # Unpacked egg directories: + + egg_path = "/path/to/PackageName-ver-pyver-etc.egg" + metadata = PathMetadata(egg_path, os.path.join(egg_path,'EGG-INFO')) + dist = Distribution.from_filename(egg_path, metadata=metadata) + """ + + def __init__(self, path, egg_info): + self.module_path = path + self.egg_info = egg_info + + +class EggMetadata(ZipProvider): + """Metadata provider for .egg files""" + + def __init__(self, importer): + """Create a metadata provider from a zipimporter""" + + self.zip_pre = importer.archive + os.sep + self.loader = importer + if importer.prefix: + self.module_path = os.path.join(importer.archive, importer.prefix) + else: + self.module_path = importer.archive + self._setup_prefix() + + +_declare_state('dict', _distribution_finders={}) + + +def register_finder(importer_type, distribution_finder): + """Register `distribution_finder` to find distributions in sys.path items + + `importer_type` is the type or class of a PEP 302 "Importer" (sys.path item + handler), and `distribution_finder` is a callable that, passed a path + item and the importer instance, yields ``Distribution`` instances found on + that path item. See ``pkg_resources.find_on_path`` for an example.""" + _distribution_finders[importer_type] = distribution_finder + + +def find_distributions(path_item, only=False): + """Yield distributions accessible via `path_item`""" + importer = get_importer(path_item) + finder = _find_adapter(_distribution_finders, importer) + return finder(importer, path_item, only) + + +def find_eggs_in_zip(importer, path_item, only=False): + """ + Find eggs in zip files; possibly multiple nested eggs. + """ + if importer.archive.endswith('.whl'): + # wheels are not supported with this finder + # they don't have PKG-INFO metadata, and won't ever contain eggs + return + metadata = EggMetadata(importer) + if metadata.has_metadata('PKG-INFO'): + yield Distribution.from_filename(path_item, metadata=metadata) + if only: + # don't yield nested distros + return + for subitem in metadata.resource_listdir(''): + if _is_egg_path(subitem): + subpath = os.path.join(path_item, subitem) + dists = find_eggs_in_zip(zipimport.zipimporter(subpath), subpath) + for dist in dists: + yield dist + elif subitem.lower().endswith('.dist-info'): + subpath = os.path.join(path_item, subitem) + submeta = EggMetadata(zipimport.zipimporter(subpath)) + submeta.egg_info = subpath + yield Distribution.from_location(path_item, subitem, submeta) + + +register_finder(zipimport.zipimporter, find_eggs_in_zip) + + +def find_nothing(importer, path_item, only=False): + return () + + +register_finder(object, find_nothing) + + +def _by_version_descending(names): + """ + Given a list of filenames, return them in descending order + by version number. + + >>> names = 'bar', 'foo', 'Python-2.7.10.egg', 'Python-2.7.2.egg' + >>> _by_version_descending(names) + ['Python-2.7.10.egg', 'Python-2.7.2.egg', 'foo', 'bar'] + >>> names = 'Setuptools-1.2.3b1.egg', 'Setuptools-1.2.3.egg' + >>> _by_version_descending(names) + ['Setuptools-1.2.3.egg', 'Setuptools-1.2.3b1.egg'] + >>> names = 'Setuptools-1.2.3b1.egg', 'Setuptools-1.2.3.post1.egg' + >>> _by_version_descending(names) + ['Setuptools-1.2.3.post1.egg', 'Setuptools-1.2.3b1.egg'] + """ + def _by_version(name): + """ + Parse each component of the filename + """ + name, ext = os.path.splitext(name) + parts = itertools.chain(name.split('-'), [ext]) + return [packaging.version.parse(part) for part in parts] + + return sorted(names, key=_by_version, reverse=True) + + +def find_on_path(importer, path_item, only=False): + """Yield distributions accessible on a sys.path directory""" + path_item = _normalize_cached(path_item) + + if _is_unpacked_egg(path_item): + yield Distribution.from_filename( + path_item, metadata=PathMetadata( + path_item, os.path.join(path_item, 'EGG-INFO') + ) + ) + return + + entries = safe_listdir(path_item) + + # for performance, before sorting by version, + # screen entries for only those that will yield + # distributions + filtered = ( + entry + for entry in entries + if dist_factory(path_item, entry, only) + ) + + # scan for .egg and .egg-info in directory + path_item_entries = _by_version_descending(filtered) + for entry in path_item_entries: + fullpath = os.path.join(path_item, entry) + factory = dist_factory(path_item, entry, only) + for dist in factory(fullpath): + yield dist + + +def dist_factory(path_item, entry, only): + """ + Return a dist_factory for a path_item and entry + """ + lower = entry.lower() + is_meta = any(map(lower.endswith, ('.egg-info', '.dist-info'))) + return ( + distributions_from_metadata + if is_meta else + find_distributions + if not only and _is_egg_path(entry) else + resolve_egg_link + if not only and lower.endswith('.egg-link') else + NoDists() + ) + + +class NoDists: + """ + >>> bool(NoDists()) + False + + >>> list(NoDists()('anything')) + [] + """ + def __bool__(self): + return False + if six.PY2: + __nonzero__ = __bool__ + + def __call__(self, fullpath): + return iter(()) + + +def safe_listdir(path): + """ + Attempt to list contents of path, but suppress some exceptions. + """ + try: + return os.listdir(path) + except (PermissionError, NotADirectoryError): + pass + except OSError as e: + # Ignore the directory if does not exist, not a directory or + # permission denied + ignorable = ( + e.errno in (errno.ENOTDIR, errno.EACCES, errno.ENOENT) + # Python 2 on Windows needs to be handled this way :( + or getattr(e, "winerror", None) == 267 + ) + if not ignorable: + raise + return () + + +def distributions_from_metadata(path): + root = os.path.dirname(path) + if os.path.isdir(path): + if len(os.listdir(path)) == 0: + # empty metadata dir; skip + return + metadata = PathMetadata(root, path) + else: + metadata = FileMetadata(path) + entry = os.path.basename(path) + yield Distribution.from_location( + root, entry, metadata, precedence=DEVELOP_DIST, + ) + + +def non_empty_lines(path): + """ + Yield non-empty lines from file at path + """ + with open(path) as f: + for line in f: + line = line.strip() + if line: + yield line + + +def resolve_egg_link(path): + """ + Given a path to an .egg-link, resolve distributions + present in the referenced path. + """ + referenced_paths = non_empty_lines(path) + resolved_paths = ( + os.path.join(os.path.dirname(path), ref) + for ref in referenced_paths + ) + dist_groups = map(find_distributions, resolved_paths) + return next(dist_groups, ()) + + +register_finder(pkgutil.ImpImporter, find_on_path) + +if hasattr(importlib_machinery, 'FileFinder'): + register_finder(importlib_machinery.FileFinder, find_on_path) + +_declare_state('dict', _namespace_handlers={}) +_declare_state('dict', _namespace_packages={}) + + +def register_namespace_handler(importer_type, namespace_handler): + """Register `namespace_handler` to declare namespace packages + + `importer_type` is the type or class of a PEP 302 "Importer" (sys.path item + handler), and `namespace_handler` is a callable like this:: + + def namespace_handler(importer, path_entry, moduleName, module): + # return a path_entry to use for child packages + + Namespace handlers are only called if the importer object has already + agreed that it can handle the relevant path item, and they should only + return a subpath if the module __path__ does not already contain an + equivalent subpath. For an example namespace handler, see + ``pkg_resources.file_ns_handler``. + """ + _namespace_handlers[importer_type] = namespace_handler + + +def _handle_ns(packageName, path_item): + """Ensure that named package includes a subpath of path_item (if needed)""" + + importer = get_importer(path_item) + if importer is None: + return None + + # capture warnings due to #1111 + with warnings.catch_warnings(): + warnings.simplefilter("ignore") + loader = importer.find_module(packageName) + + if loader is None: + return None + module = sys.modules.get(packageName) + if module is None: + module = sys.modules[packageName] = types.ModuleType(packageName) + module.__path__ = [] + _set_parent_ns(packageName) + elif not hasattr(module, '__path__'): + raise TypeError("Not a package:", packageName) + handler = _find_adapter(_namespace_handlers, importer) + subpath = handler(importer, path_item, packageName, module) + if subpath is not None: + path = module.__path__ + path.append(subpath) + loader.load_module(packageName) + _rebuild_mod_path(path, packageName, module) + return subpath + + +def _rebuild_mod_path(orig_path, package_name, module): + """ + Rebuild module.__path__ ensuring that all entries are ordered + corresponding to their sys.path order + """ + sys_path = [_normalize_cached(p) for p in sys.path] + + def safe_sys_path_index(entry): + """ + Workaround for #520 and #513. + """ + try: + return sys_path.index(entry) + except ValueError: + return float('inf') + + def position_in_sys_path(path): + """ + Return the ordinal of the path based on its position in sys.path + """ + path_parts = path.split(os.sep) + module_parts = package_name.count('.') + 1 + parts = path_parts[:-module_parts] + return safe_sys_path_index(_normalize_cached(os.sep.join(parts))) + + new_path = sorted(orig_path, key=position_in_sys_path) + new_path = [_normalize_cached(p) for p in new_path] + + if isinstance(module.__path__, list): + module.__path__[:] = new_path + else: + module.__path__ = new_path + + +def declare_namespace(packageName): + """Declare that package 'packageName' is a namespace package""" + + _imp.acquire_lock() + try: + if packageName in _namespace_packages: + return + + path = sys.path + parent, _, _ = packageName.rpartition('.') + + if parent: + declare_namespace(parent) + if parent not in _namespace_packages: + __import__(parent) + try: + path = sys.modules[parent].__path__ + except AttributeError: + raise TypeError("Not a package:", parent) + + # Track what packages are namespaces, so when new path items are added, + # they can be updated + _namespace_packages.setdefault(parent or None, []).append(packageName) + _namespace_packages.setdefault(packageName, []) + + for path_item in path: + # Ensure all the parent's path items are reflected in the child, + # if they apply + _handle_ns(packageName, path_item) + + finally: + _imp.release_lock() + + +def fixup_namespace_packages(path_item, parent=None): + """Ensure that previously-declared namespace packages include path_item""" + _imp.acquire_lock() + try: + for package in _namespace_packages.get(parent, ()): + subpath = _handle_ns(package, path_item) + if subpath: + fixup_namespace_packages(subpath, package) + finally: + _imp.release_lock() + + +def file_ns_handler(importer, path_item, packageName, module): + """Compute an ns-package subpath for a filesystem or zipfile importer""" + + subpath = os.path.join(path_item, packageName.split('.')[-1]) + normalized = _normalize_cached(subpath) + for item in module.__path__: + if _normalize_cached(item) == normalized: + break + else: + # Only return the path if it's not already there + return subpath + + +register_namespace_handler(pkgutil.ImpImporter, file_ns_handler) +register_namespace_handler(zipimport.zipimporter, file_ns_handler) + +if hasattr(importlib_machinery, 'FileFinder'): + register_namespace_handler(importlib_machinery.FileFinder, file_ns_handler) + + +def null_ns_handler(importer, path_item, packageName, module): + return None + + +register_namespace_handler(object, null_ns_handler) + + +def normalize_path(filename): + """Normalize a file/dir name for comparison purposes""" + return os.path.normcase(os.path.realpath(os.path.normpath(_cygwin_patch(filename)))) + + +def _cygwin_patch(filename): # pragma: nocover + """ + Contrary to POSIX 2008, on Cygwin, getcwd (3) contains + symlink components. Using + os.path.abspath() works around this limitation. A fix in os.getcwd() + would probably better, in Cygwin even more so, except + that this seems to be by design... + """ + return os.path.abspath(filename) if sys.platform == 'cygwin' else filename + + +def _normalize_cached(filename, _cache={}): + try: + return _cache[filename] + except KeyError: + _cache[filename] = result = normalize_path(filename) + return result + + +def _is_egg_path(path): + """ + Determine if given path appears to be an egg. + """ + return path.lower().endswith('.egg') + + +def _is_unpacked_egg(path): + """ + Determine if given path appears to be an unpacked egg. + """ + return ( + _is_egg_path(path) and + os.path.isfile(os.path.join(path, 'EGG-INFO', 'PKG-INFO')) + ) + + +def _set_parent_ns(packageName): + parts = packageName.split('.') + name = parts.pop() + if parts: + parent = '.'.join(parts) + setattr(sys.modules[parent], name, sys.modules[packageName]) + + +def yield_lines(strs): + """Yield non-empty/non-comment lines of a string or sequence""" + if isinstance(strs, six.string_types): + for s in strs.splitlines(): + s = s.strip() + # skip blank lines/comments + if s and not s.startswith('#'): + yield s + else: + for ss in strs: + for s in yield_lines(ss): + yield s + + +MODULE = re.compile(r"\w+(\.\w+)*$").match +EGG_NAME = re.compile( + r""" + (?P<name>[^-]+) ( + -(?P<ver>[^-]+) ( + -py(?P<pyver>[^-]+) ( + -(?P<plat>.+) + )? + )? + )? + """, + re.VERBOSE | re.IGNORECASE, +).match + + +class EntryPoint: + """Object representing an advertised importable object""" + + def __init__(self, name, module_name, attrs=(), extras=(), dist=None): + if not MODULE(module_name): + raise ValueError("Invalid module name", module_name) + self.name = name + self.module_name = module_name + self.attrs = tuple(attrs) + self.extras = tuple(extras) + self.dist = dist + + def __str__(self): + s = "%s = %s" % (self.name, self.module_name) + if self.attrs: + s += ':' + '.'.join(self.attrs) + if self.extras: + s += ' [%s]' % ','.join(self.extras) + return s + + def __repr__(self): + return "EntryPoint.parse(%r)" % str(self) + + def load(self, require=True, *args, **kwargs): + """ + Require packages for this EntryPoint, then resolve it. + """ + if not require or args or kwargs: + warnings.warn( + "Parameters to load are deprecated. Call .resolve and " + ".require separately.", + PkgResourcesDeprecationWarning, + stacklevel=2, + ) + if require: + self.require(*args, **kwargs) + return self.resolve() + + def resolve(self): + """ + Resolve the entry point from its module and attrs. + """ + module = __import__(self.module_name, fromlist=['__name__'], level=0) + try: + return functools.reduce(getattr, self.attrs, module) + except AttributeError as exc: + raise ImportError(str(exc)) + + def require(self, env=None, installer=None): + if self.extras and not self.dist: + raise UnknownExtra("Can't require() without a distribution", self) + + # Get the requirements for this entry point with all its extras and + # then resolve them. We have to pass `extras` along when resolving so + # that the working set knows what extras we want. Otherwise, for + # dist-info distributions, the working set will assume that the + # requirements for that extra are purely optional and skip over them. + reqs = self.dist.requires(self.extras) + items = working_set.resolve(reqs, env, installer, extras=self.extras) + list(map(working_set.add, items)) + + pattern = re.compile( + r'\s*' + r'(?P<name>.+?)\s*' + r'=\s*' + r'(?P<module>[\w.]+)\s*' + r'(:\s*(?P<attr>[\w.]+))?\s*' + r'(?P<extras>\[.*\])?\s*$' + ) + + @classmethod + def parse(cls, src, dist=None): + """Parse a single entry point from string `src` + + Entry point syntax follows the form:: + + name = some.module:some.attr [extra1, extra2] + + The entry name and module name are required, but the ``:attrs`` and + ``[extras]`` parts are optional + """ + m = cls.pattern.match(src) + if not m: + msg = "EntryPoint must be in 'name=module:attrs [extras]' format" + raise ValueError(msg, src) + res = m.groupdict() + extras = cls._parse_extras(res['extras']) + attrs = res['attr'].split('.') if res['attr'] else () + return cls(res['name'], res['module'], attrs, extras, dist) + + @classmethod + def _parse_extras(cls, extras_spec): + if not extras_spec: + return () + req = Requirement.parse('x' + extras_spec) + if req.specs: + raise ValueError() + return req.extras + + @classmethod + def parse_group(cls, group, lines, dist=None): + """Parse an entry point group""" + if not MODULE(group): + raise ValueError("Invalid group name", group) + this = {} + for line in yield_lines(lines): + ep = cls.parse(line, dist) + if ep.name in this: + raise ValueError("Duplicate entry point", group, ep.name) + this[ep.name] = ep + return this + + @classmethod + def parse_map(cls, data, dist=None): + """Parse a map of entry point groups""" + if isinstance(data, dict): + data = data.items() + else: + data = split_sections(data) + maps = {} + for group, lines in data: + if group is None: + if not lines: + continue + raise ValueError("Entry points must be listed in groups") + group = group.strip() + if group in maps: + raise ValueError("Duplicate group name", group) + maps[group] = cls.parse_group(group, lines, dist) + return maps + + +def _remove_md5_fragment(location): + if not location: + return '' + parsed = urllib.parse.urlparse(location) + if parsed[-1].startswith('md5='): + return urllib.parse.urlunparse(parsed[:-1] + ('',)) + return location + + +def _version_from_file(lines): + """ + Given an iterable of lines from a Metadata file, return + the value of the Version field, if present, or None otherwise. + """ + def is_version_line(line): + return line.lower().startswith('version:') + version_lines = filter(is_version_line, lines) + line = next(iter(version_lines), '') + _, _, value = line.partition(':') + return safe_version(value.strip()) or None + + +class Distribution: + """Wrap an actual or potential sys.path entry w/metadata""" + PKG_INFO = 'PKG-INFO' + + def __init__( + self, location=None, metadata=None, project_name=None, + version=None, py_version=PY_MAJOR, platform=None, + precedence=EGG_DIST): + self.project_name = safe_name(project_name or 'Unknown') + if version is not None: + self._version = safe_version(version) + self.py_version = py_version + self.platform = platform + self.location = location + self.precedence = precedence + self._provider = metadata or empty_provider + + @classmethod + def from_location(cls, location, basename, metadata=None, **kw): + project_name, version, py_version, platform = [None] * 4 + basename, ext = os.path.splitext(basename) + if ext.lower() in _distributionImpl: + cls = _distributionImpl[ext.lower()] + + match = EGG_NAME(basename) + if match: + project_name, version, py_version, platform = match.group( + 'name', 'ver', 'pyver', 'plat' + ) + return cls( + location, metadata, project_name=project_name, version=version, + py_version=py_version, platform=platform, **kw + )._reload_version() + + def _reload_version(self): + return self + + @property + def hashcmp(self): + return ( + self.parsed_version, + self.precedence, + self.key, + _remove_md5_fragment(self.location), + self.py_version or '', + self.platform or '', + ) + + def __hash__(self): + return hash(self.hashcmp) + + def __lt__(self, other): + return self.hashcmp < other.hashcmp + + def __le__(self, other): + return self.hashcmp <= other.hashcmp + + def __gt__(self, other): + return self.hashcmp > other.hashcmp + + def __ge__(self, other): + return self.hashcmp >= other.hashcmp + + def __eq__(self, other): + if not isinstance(other, self.__class__): + # It's not a Distribution, so they are not equal + return False + return self.hashcmp == other.hashcmp + + def __ne__(self, other): + return not self == other + + # These properties have to be lazy so that we don't have to load any + # metadata until/unless it's actually needed. (i.e., some distributions + # may not know their name or version without loading PKG-INFO) + + @property + def key(self): + try: + return self._key + except AttributeError: + self._key = key = self.project_name.lower() + return key + + @property + def parsed_version(self): + if not hasattr(self, "_parsed_version"): + self._parsed_version = parse_version(self.version) + + return self._parsed_version + + def _warn_legacy_version(self): + LV = packaging.version.LegacyVersion + is_legacy = isinstance(self._parsed_version, LV) + if not is_legacy: + return + + # While an empty version is technically a legacy version and + # is not a valid PEP 440 version, it's also unlikely to + # actually come from someone and instead it is more likely that + # it comes from setuptools attempting to parse a filename and + # including it in the list. So for that we'll gate this warning + # on if the version is anything at all or not. + if not self.version: + return + + tmpl = textwrap.dedent(""" + '{project_name} ({version})' is being parsed as a legacy, + non PEP 440, + version. You may find odd behavior and sort order. + In particular it will be sorted as less than 0.0. It + is recommended to migrate to PEP 440 compatible + versions. + """).strip().replace('\n', ' ') + + warnings.warn(tmpl.format(**vars(self)), PEP440Warning) + + @property + def version(self): + try: + return self._version + except AttributeError: + version = self._get_version() + if version is None: + path = self._get_metadata_path_for_display(self.PKG_INFO) + msg = ( + "Missing 'Version:' header and/or {} file at path: {}" + ).format(self.PKG_INFO, path) + raise ValueError(msg, self) + + return version + + @property + def _dep_map(self): + """ + A map of extra to its list of (direct) requirements + for this distribution, including the null extra. + """ + try: + return self.__dep_map + except AttributeError: + self.__dep_map = self._filter_extras(self._build_dep_map()) + return self.__dep_map + + @staticmethod + def _filter_extras(dm): + """ + Given a mapping of extras to dependencies, strip off + environment markers and filter out any dependencies + not matching the markers. + """ + for extra in list(filter(None, dm)): + new_extra = extra + reqs = dm.pop(extra) + new_extra, _, marker = extra.partition(':') + fails_marker = marker and ( + invalid_marker(marker) + or not evaluate_marker(marker) + ) + if fails_marker: + reqs = [] + new_extra = safe_extra(new_extra) or None + + dm.setdefault(new_extra, []).extend(reqs) + return dm + + def _build_dep_map(self): + dm = {} + for name in 'requires.txt', 'depends.txt': + for extra, reqs in split_sections(self._get_metadata(name)): + dm.setdefault(extra, []).extend(parse_requirements(reqs)) + return dm + + def requires(self, extras=()): + """List of Requirements needed for this distro if `extras` are used""" + dm = self._dep_map + deps = [] + deps.extend(dm.get(None, ())) + for ext in extras: + try: + deps.extend(dm[safe_extra(ext)]) + except KeyError: + raise UnknownExtra( + "%s has no such extra feature %r" % (self, ext) + ) + return deps + + def _get_metadata_path_for_display(self, name): + """ + Return the path to the given metadata file, if available. + """ + try: + # We need to access _get_metadata_path() on the provider object + # directly rather than through this class's __getattr__() + # since _get_metadata_path() is marked private. + path = self._provider._get_metadata_path(name) + + # Handle exceptions e.g. in case the distribution's metadata + # provider doesn't support _get_metadata_path(). + except Exception: + return '[could not detect]' + + return path + + def _get_metadata(self, name): + if self.has_metadata(name): + for line in self.get_metadata_lines(name): + yield line + + def _get_version(self): + lines = self._get_metadata(self.PKG_INFO) + version = _version_from_file(lines) + + return version + + def activate(self, path=None, replace=False): + """Ensure distribution is importable on `path` (default=sys.path)""" + if path is None: + path = sys.path + self.insert_on(path, replace=replace) + if path is sys.path: + fixup_namespace_packages(self.location) + for pkg in self._get_metadata('namespace_packages.txt'): + if pkg in sys.modules: + declare_namespace(pkg) + + def egg_name(self): + """Return what this distribution's standard .egg filename should be""" + filename = "%s-%s-py%s" % ( + to_filename(self.project_name), to_filename(self.version), + self.py_version or PY_MAJOR + ) + + if self.platform: + filename += '-' + self.platform + return filename + + def __repr__(self): + if self.location: + return "%s (%s)" % (self, self.location) + else: + return str(self) + + def __str__(self): + try: + version = getattr(self, 'version', None) + except ValueError: + version = None + version = version or "[unknown version]" + return "%s %s" % (self.project_name, version) + + def __getattr__(self, attr): + """Delegate all unrecognized public attributes to .metadata provider""" + if attr.startswith('_'): + raise AttributeError(attr) + return getattr(self._provider, attr) + + def __dir__(self): + return list( + set(super(Distribution, self).__dir__()) + | set( + attr for attr in self._provider.__dir__() + if not attr.startswith('_') + ) + ) + + if not hasattr(object, '__dir__'): + # python 2.7 not supported + del __dir__ + + @classmethod + def from_filename(cls, filename, metadata=None, **kw): + return cls.from_location( + _normalize_cached(filename), os.path.basename(filename), metadata, + **kw + ) + + def as_requirement(self): + """Return a ``Requirement`` that matches this distribution exactly""" + if isinstance(self.parsed_version, packaging.version.Version): + spec = "%s==%s" % (self.project_name, self.parsed_version) + else: + spec = "%s===%s" % (self.project_name, self.parsed_version) + + return Requirement.parse(spec) + + def load_entry_point(self, group, name): + """Return the `name` entry point of `group` or raise ImportError""" + ep = self.get_entry_info(group, name) + if ep is None: + raise ImportError("Entry point %r not found" % ((group, name),)) + return ep.load() + + def get_entry_map(self, group=None): + """Return the entry point map for `group`, or the full entry map""" + try: + ep_map = self._ep_map + except AttributeError: + ep_map = self._ep_map = EntryPoint.parse_map( + self._get_metadata('entry_points.txt'), self + ) + if group is not None: + return ep_map.get(group, {}) + return ep_map + + def get_entry_info(self, group, name): + """Return the EntryPoint object for `group`+`name`, or ``None``""" + return self.get_entry_map(group).get(name) + + def insert_on(self, path, loc=None, replace=False): + """Ensure self.location is on path + + If replace=False (default): + - If location is already in path anywhere, do nothing. + - Else: + - If it's an egg and its parent directory is on path, + insert just ahead of the parent. + - Else: add to the end of path. + If replace=True: + - If location is already on path anywhere (not eggs) + or higher priority than its parent (eggs) + do nothing. + - Else: + - If it's an egg and its parent directory is on path, + insert just ahead of the parent, + removing any lower-priority entries. + - Else: add it to the front of path. + """ + + loc = loc or self.location + if not loc: + return + + nloc = _normalize_cached(loc) + bdir = os.path.dirname(nloc) + npath = [(p and _normalize_cached(p) or p) for p in path] + + for p, item in enumerate(npath): + if item == nloc: + if replace: + break + else: + # don't modify path (even removing duplicates) if + # found and not replace + return + elif item == bdir and self.precedence == EGG_DIST: + # if it's an .egg, give it precedence over its directory + # UNLESS it's already been added to sys.path and replace=False + if (not replace) and nloc in npath[p:]: + return + if path is sys.path: + self.check_version_conflict() + path.insert(p, loc) + npath.insert(p, nloc) + break + else: + if path is sys.path: + self.check_version_conflict() + if replace: + path.insert(0, loc) + else: + path.append(loc) + return + + # p is the spot where we found or inserted loc; now remove duplicates + while True: + try: + np = npath.index(nloc, p + 1) + except ValueError: + break + else: + del npath[np], path[np] + # ha! + p = np + + return + + def check_version_conflict(self): + if self.key == 'setuptools': + # ignore the inevitable setuptools self-conflicts :( + return + + nsp = dict.fromkeys(self._get_metadata('namespace_packages.txt')) + loc = normalize_path(self.location) + for modname in self._get_metadata('top_level.txt'): + if (modname not in sys.modules or modname in nsp + or modname in _namespace_packages): + continue + if modname in ('pkg_resources', 'setuptools', 'site'): + continue + fn = getattr(sys.modules[modname], '__file__', None) + if fn and (normalize_path(fn).startswith(loc) or + fn.startswith(self.location)): + continue + issue_warning( + "Module %s was already imported from %s, but %s is being added" + " to sys.path" % (modname, fn, self.location), + ) + + def has_version(self): + try: + self.version + except ValueError: + issue_warning("Unbuilt egg for " + repr(self)) + return False + return True + + def clone(self, **kw): + """Copy this distribution, substituting in any changed keyword args""" + names = 'project_name version py_version platform location precedence' + for attr in names.split(): + kw.setdefault(attr, getattr(self, attr, None)) + kw.setdefault('metadata', self._provider) + return self.__class__(**kw) + + @property + def extras(self): + return [dep for dep in self._dep_map if dep] + + +class EggInfoDistribution(Distribution): + def _reload_version(self): + """ + Packages installed by distutils (e.g. numpy or scipy), + which uses an old safe_version, and so + their version numbers can get mangled when + converted to filenames (e.g., 1.11.0.dev0+2329eae to + 1.11.0.dev0_2329eae). These distributions will not be + parsed properly + downstream by Distribution and safe_version, so + take an extra step and try to get the version number from + the metadata file itself instead of the filename. + """ + md_version = self._get_version() + if md_version: + self._version = md_version + return self + + +class DistInfoDistribution(Distribution): + """ + Wrap an actual or potential sys.path entry + w/metadata, .dist-info style. + """ + PKG_INFO = 'METADATA' + EQEQ = re.compile(r"([\(,])\s*(\d.*?)\s*([,\)])") + + @property + def _parsed_pkg_info(self): + """Parse and cache metadata""" + try: + return self._pkg_info + except AttributeError: + metadata = self.get_metadata(self.PKG_INFO) + self._pkg_info = email.parser.Parser().parsestr(metadata) + return self._pkg_info + + @property + def _dep_map(self): + try: + return self.__dep_map + except AttributeError: + self.__dep_map = self._compute_dependencies() + return self.__dep_map + + def _compute_dependencies(self): + """Recompute this distribution's dependencies.""" + dm = self.__dep_map = {None: []} + + reqs = [] + # Including any condition expressions + for req in self._parsed_pkg_info.get_all('Requires-Dist') or []: + reqs.extend(parse_requirements(req)) + + def reqs_for_extra(extra): + for req in reqs: + if not req.marker or req.marker.evaluate({'extra': extra}): + yield req + + common = frozenset(reqs_for_extra(None)) + dm[None].extend(common) + + for extra in self._parsed_pkg_info.get_all('Provides-Extra') or []: + s_extra = safe_extra(extra.strip()) + dm[s_extra] = list(frozenset(reqs_for_extra(extra)) - common) + + return dm + + +_distributionImpl = { + '.egg': Distribution, + '.egg-info': EggInfoDistribution, + '.dist-info': DistInfoDistribution, +} + + +def issue_warning(*args, **kw): + level = 1 + g = globals() + try: + # find the first stack frame that is *not* code in + # the pkg_resources module, to use for the warning + while sys._getframe(level).f_globals is g: + level += 1 + except ValueError: + pass + warnings.warn(stacklevel=level + 1, *args, **kw) + + +class RequirementParseError(ValueError): + def __str__(self): + return ' '.join(self.args) + + +def parse_requirements(strs): + """Yield ``Requirement`` objects for each specification in `strs` + + `strs` must be a string, or a (possibly-nested) iterable thereof. + """ + # create a steppable iterator, so we can handle \-continuations + lines = iter(yield_lines(strs)) + + for line in lines: + # Drop comments -- a hash without a space may be in a URL. + if ' #' in line: + line = line[:line.find(' #')] + # If there is a line continuation, drop it, and append the next line. + if line.endswith('\\'): + line = line[:-2].strip() + try: + line += next(lines) + except StopIteration: + return + yield Requirement(line) + + +class Requirement(packaging.requirements.Requirement): + def __init__(self, requirement_string): + """DO NOT CALL THIS UNDOCUMENTED METHOD; use Requirement.parse()!""" + try: + super(Requirement, self).__init__(requirement_string) + except packaging.requirements.InvalidRequirement as e: + raise RequirementParseError(str(e)) + self.unsafe_name = self.name + project_name = safe_name(self.name) + self.project_name, self.key = project_name, project_name.lower() + self.specs = [ + (spec.operator, spec.version) for spec in self.specifier] + self.extras = tuple(map(safe_extra, self.extras)) + self.hashCmp = ( + self.key, + self.specifier, + frozenset(self.extras), + str(self.marker) if self.marker else None, + ) + self.__hash = hash(self.hashCmp) + + def __eq__(self, other): + return ( + isinstance(other, Requirement) and + self.hashCmp == other.hashCmp + ) + + def __ne__(self, other): + return not self == other + + def __contains__(self, item): + if isinstance(item, Distribution): + if item.key != self.key: + return False + + item = item.version + + # Allow prereleases always in order to match the previous behavior of + # this method. In the future this should be smarter and follow PEP 440 + # more accurately. + return self.specifier.contains(item, prereleases=True) + + def __hash__(self): + return self.__hash + + def __repr__(self): + return "Requirement.parse(%r)" % str(self) + + @staticmethod + def parse(s): + req, = parse_requirements(s) + return req + + +def _always_object(classes): + """ + Ensure object appears in the mro even + for old-style classes. + """ + if object not in classes: + return classes + (object,) + return classes + + +def _find_adapter(registry, ob): + """Return an adapter factory for `ob` from `registry`""" + types = _always_object(inspect.getmro(getattr(ob, '__class__', type(ob)))) + for t in types: + if t in registry: + return registry[t] + + +def ensure_directory(path): + """Ensure that the parent directory of `path` exists""" + dirname = os.path.dirname(path) + py31compat.makedirs(dirname, exist_ok=True) + + +def _bypass_ensure_directory(path): + """Sandbox-bypassing version of ensure_directory()""" + if not WRITE_SUPPORT: + raise IOError('"os.mkdir" not supported on this platform.') + dirname, filename = split(path) + if dirname and filename and not isdir(dirname): + _bypass_ensure_directory(dirname) + try: + mkdir(dirname, 0o755) + except FileExistsError: + pass + + +def split_sections(s): + """Split a string or iterable thereof into (section, content) pairs + + Each ``section`` is a stripped version of the section header ("[section]") + and each ``content`` is a list of stripped lines excluding blank lines and + comment-only lines. If there are any such lines before the first section + header, they're returned in a first ``section`` of ``None``. + """ + section = None + content = [] + for line in yield_lines(s): + if line.startswith("["): + if line.endswith("]"): + if section or content: + yield section, content + section = line[1:-1].strip() + content = [] + else: + raise ValueError("Invalid section heading", line) + else: + content.append(line) + + # wrap up last segment + yield section, content + + +def _mkstemp(*args, **kw): + old_open = os.open + try: + # temporarily bypass sandboxing + os.open = os_open + return tempfile.mkstemp(*args, **kw) + finally: + # and then put it back + os.open = old_open + + +# Silence the PEP440Warning by default, so that end users don't get hit by it +# randomly just because they use pkg_resources. We want to append the rule +# because we want earlier uses of filterwarnings to take precedence over this +# one. +warnings.filterwarnings("ignore", category=PEP440Warning, append=True) + + +# from jaraco.functools 1.3 +def _call_aside(f, *args, **kwargs): + f(*args, **kwargs) + return f + + +@_call_aside +def _initialize(g=globals()): + "Set up global resource manager (deliberately not state-saved)" + manager = ResourceManager() + g['_manager'] = manager + g.update( + (name, getattr(manager, name)) + for name in dir(manager) + if not name.startswith('_') + ) + + +@_call_aside +def _initialize_master_working_set(): + """ + Prepare the master working set and make the ``require()`` + API available. + + This function has explicit effects on the global state + of pkg_resources. It is intended to be invoked once at + the initialization of this module. + + Invocation by other packages is unsupported and done + at their own risk. + """ + working_set = WorkingSet._build_master() + _declare_state('object', working_set=working_set) + + require = working_set.require + iter_entry_points = working_set.iter_entry_points + add_activation_listener = working_set.subscribe + run_script = working_set.run_script + # backward compatibility + run_main = run_script + # Activate all distributions already on sys.path with replace=False and + # ensure that all distributions added to the working set in the future + # (e.g. by calling ``require()``) will get activated as well, + # with higher priority (replace=True). + tuple( + dist.activate(replace=False) + for dist in working_set + ) + add_activation_listener( + lambda dist: dist.activate(replace=True), + existing=False, + ) + working_set.entries = [] + # match order + list(map(working_set.add_entry, sys.path)) + globals().update(locals()) + +class PkgResourcesDeprecationWarning(Warning): + """ + Base class for warning about deprecations in ``pkg_resources`` + + This class is not derived from ``DeprecationWarning``, and as such is + visible by default. + """ diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..badcde8a4bb597892e4422f3a94b9a93f9d3651b GIT binary patch literal 100394 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 Qiqhg<W(aMlj78V}FT=8H8~^|S literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/__pycache__/py31compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/__pycache__/py31compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..bba963d62df54a64ecebfed1e5e35829973cb687 GIT binary patch literal 656 zcmYjO&2G~`5T4z&6DLYSPl#9Wp>>i%rAi1PP^u!Kf|LTSFUDjyiDSoW%{rD7r5q3s zLXX^dp1pF)3vl3o*bSoUtmfOD{hM#TdDrc>!Pu`KxA74L_-TXt#!T?sxcX>-11A}T z|7H@BeN02jDQ6j5I-x^=x46q2UrFc+XVEBL^QNGSrUML8BG0*(Lheu?5PHJH_rlE` z0gG1H;$#edduOu1#f}*CiDoLP&nAY}omo1T@Jr+B+`y(+!Z)&oTSDLi<c}RFY1+mY z1a2sS&BHCh{+2FS$ret^aQMaCdSVK=p`Ym$TtjY<gGo&;d{<Mcw6}~?!4p)v`DQ#q zl&D>Sm`mLljjmpeFMXz+A};6J6Lq4>NT!;Jdh#8xV+j2&g94K(E=5qq7))ix1*+h* z4rbA5h09GooG$wFdA-?0+3CrrIrfds^58NklHxGQRT*d5VZVP;t*gN*P@-HFrIeWp zigXsCP;!M6VWRc%U?P`>$x*S^o#;R9=y>2+b@qKFl=R4f8Q3#>KHXUXcaB{%d|)O# zuwW(j$(i3qdxT8`M*Ou38=@`+=4hYoztHUM^-y;zQ&S@ID9NW%_i`b)x+8$Dy==9( g2VMK6_jD=wDihCaf0fPb5i@9qwL1;+=nr-N0=~nXA^-pY literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ea1e1ec8cce0d8028c6ba16cb945d4538457cf5f GIT binary patch literal 213 zcmYk0u?oU46h%{T5TPI9P+xTr3L<`ii#msB(>9tW;Ux`i|HjeH?{W1L1P3S6Ne|rf zcz3#oIG&Ke`+jA^eGd933eP6Qj)HQsBhzSmBRJGQeR?n`JaZg8LnyS&Ia<hCC~4-g z?$x3=r&ZPVJ(bz=SYa9{73{$XlL%!UlQK!urSJT_0n1%uoYvBUxs(*S)eWAw1?suV ZH3FqV2}kM7bdT|>)_EiOdf4;|Az#SQJ9hv8 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/appdirs.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/appdirs.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9136023a2e84afd533b80ff7edaea6cb41a3506d GIT binary patch literal 20566 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 S!NneYQ=}$+(;t0PP5%ewJyZ+; literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/pyparsing.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/pyparsing.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c512598d28728ae58c181c345b68ac55eb727265 GIT binary patch literal 201690 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/six.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/six.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..75b0826f399ecdd09f37042d2126c95d8e5ff773 GIT binary patch literal 24486 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/appdirs.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/appdirs.py new file mode 100644 index 0000000..ae67001 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/appdirs.py @@ -0,0 +1,608 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- +# Copyright (c) 2005-2010 ActiveState Software Inc. +# Copyright (c) 2013 Eddy Petrișor + +"""Utilities for determining application-specific dirs. + +See <http://github.com/ActiveState/appdirs> for details and usage. +""" +# Dev Notes: +# - MSDN on where to store app data files: +# http://support.microsoft.com/default.aspx?scid=kb;en-us;310294#XSLTH3194121123120121120120 +# - Mac OS X: http://developer.apple.com/documentation/MacOSX/Conceptual/BPFileSystem/index.html +# - XDG spec for Un*x: http://standards.freedesktop.org/basedir-spec/basedir-spec-latest.html + +__version_info__ = (1, 4, 3) +__version__ = '.'.join(map(str, __version_info__)) + + +import sys +import os + +PY3 = sys.version_info[0] == 3 + +if PY3: + unicode = str + +if sys.platform.startswith('java'): + import platform + os_name = platform.java_ver()[3][0] + if os_name.startswith('Windows'): # "Windows XP", "Windows 7", etc. + system = 'win32' + elif os_name.startswith('Mac'): # "Mac OS X", etc. + system = 'darwin' + else: # "Linux", "SunOS", "FreeBSD", etc. + # Setting this to "linux2" is not ideal, but only Windows or Mac + # are actually checked for and the rest of the module expects + # *sys.platform* style strings. + system = 'linux2' +else: + system = sys.platform + + + +def user_data_dir(appname=None, appauthor=None, version=None, roaming=False): + r"""Return full path to the user-specific data dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "appauthor" (only used on Windows) is the name of the + appauthor or distributing body for this application. Typically + it is the owning company name. This falls back to appname. You may + pass False to disable it. + "version" is an optional version path element to append to the + path. You might want to use this if you want multiple versions + of your app to be able to run independently. If used, this + would typically be "<major>.<minor>". + Only applied when appname is present. + "roaming" (boolean, default False) can be set True to use the Windows + roaming appdata directory. That means that for users on a Windows + network setup for roaming profiles, this user data will be + sync'd on login. See + <http://technet.microsoft.com/en-us/library/cc766489(WS.10).aspx> + for a discussion of issues. + + Typical user data directories are: + Mac OS X: ~/Library/Application Support/<AppName> + Unix: ~/.local/share/<AppName> # or in $XDG_DATA_HOME, if defined + Win XP (not roaming): C:\Documents and Settings\<username>\Application Data\<AppAuthor>\<AppName> + Win XP (roaming): C:\Documents and Settings\<username>\Local Settings\Application Data\<AppAuthor>\<AppName> + Win 7 (not roaming): C:\Users\<username>\AppData\Local\<AppAuthor>\<AppName> + Win 7 (roaming): C:\Users\<username>\AppData\Roaming\<AppAuthor>\<AppName> + + For Unix, we follow the XDG spec and support $XDG_DATA_HOME. + That means, by default "~/.local/share/<AppName>". + """ + if system == "win32": + if appauthor is None: + appauthor = appname + const = roaming and "CSIDL_APPDATA" or "CSIDL_LOCAL_APPDATA" + path = os.path.normpath(_get_win_folder(const)) + if appname: + if appauthor is not False: + path = os.path.join(path, appauthor, appname) + else: + path = os.path.join(path, appname) + elif system == 'darwin': + path = os.path.expanduser('~/Library/Application Support/') + if appname: + path = os.path.join(path, appname) + else: + path = os.getenv('XDG_DATA_HOME', os.path.expanduser("~/.local/share")) + if appname: + path = os.path.join(path, appname) + if appname and version: + path = os.path.join(path, version) + return path + + +def site_data_dir(appname=None, appauthor=None, version=None, multipath=False): + r"""Return full path to the user-shared data dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "appauthor" (only used on Windows) is the name of the + appauthor or distributing body for this application. Typically + it is the owning company name. This falls back to appname. You may + pass False to disable it. + "version" is an optional version path element to append to the + path. You might want to use this if you want multiple versions + of your app to be able to run independently. If used, this + would typically be "<major>.<minor>". + Only applied when appname is present. + "multipath" is an optional parameter only applicable to *nix + which indicates that the entire list of data dirs should be + returned. By default, the first item from XDG_DATA_DIRS is + returned, or '/usr/local/share/<AppName>', + if XDG_DATA_DIRS is not set + + Typical site data directories are: + Mac OS X: /Library/Application Support/<AppName> + Unix: /usr/local/share/<AppName> or /usr/share/<AppName> + Win XP: C:\Documents and Settings\All Users\Application Data\<AppAuthor>\<AppName> + Vista: (Fail! "C:\ProgramData" is a hidden *system* directory on Vista.) + Win 7: C:\ProgramData\<AppAuthor>\<AppName> # Hidden, but writeable on Win 7. + + For Unix, this is using the $XDG_DATA_DIRS[0] default. + + WARNING: Do not use this on Windows. See the Vista-Fail note above for why. + """ + if system == "win32": + if appauthor is None: + appauthor = appname + path = os.path.normpath(_get_win_folder("CSIDL_COMMON_APPDATA")) + if appname: + if appauthor is not False: + path = os.path.join(path, appauthor, appname) + else: + path = os.path.join(path, appname) + elif system == 'darwin': + path = os.path.expanduser('/Library/Application Support') + if appname: + path = os.path.join(path, appname) + else: + # XDG default for $XDG_DATA_DIRS + # only first, if multipath is False + path = os.getenv('XDG_DATA_DIRS', + os.pathsep.join(['/usr/local/share', '/usr/share'])) + pathlist = [os.path.expanduser(x.rstrip(os.sep)) for x in path.split(os.pathsep)] + if appname: + if version: + appname = os.path.join(appname, version) + pathlist = [os.sep.join([x, appname]) for x in pathlist] + + if multipath: + path = os.pathsep.join(pathlist) + else: + path = pathlist[0] + return path + + if appname and version: + path = os.path.join(path, version) + return path + + +def user_config_dir(appname=None, appauthor=None, version=None, roaming=False): + r"""Return full path to the user-specific config dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "appauthor" (only used on Windows) is the name of the + appauthor or distributing body for this application. Typically + it is the owning company name. This falls back to appname. You may + pass False to disable it. + "version" is an optional version path element to append to the + path. You might want to use this if you want multiple versions + of your app to be able to run independently. If used, this + would typically be "<major>.<minor>". + Only applied when appname is present. + "roaming" (boolean, default False) can be set True to use the Windows + roaming appdata directory. That means that for users on a Windows + network setup for roaming profiles, this user data will be + sync'd on login. See + <http://technet.microsoft.com/en-us/library/cc766489(WS.10).aspx> + for a discussion of issues. + + Typical user config directories are: + Mac OS X: same as user_data_dir + Unix: ~/.config/<AppName> # or in $XDG_CONFIG_HOME, if defined + Win *: same as user_data_dir + + For Unix, we follow the XDG spec and support $XDG_CONFIG_HOME. + That means, by default "~/.config/<AppName>". + """ + if system in ["win32", "darwin"]: + path = user_data_dir(appname, appauthor, None, roaming) + else: + path = os.getenv('XDG_CONFIG_HOME', os.path.expanduser("~/.config")) + if appname: + path = os.path.join(path, appname) + if appname and version: + path = os.path.join(path, version) + return path + + +def site_config_dir(appname=None, appauthor=None, version=None, multipath=False): + r"""Return full path to the user-shared data dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "appauthor" (only used on Windows) is the name of the + appauthor or distributing body for this application. Typically + it is the owning company name. This falls back to appname. You may + pass False to disable it. + "version" is an optional version path element to append to the + path. You might want to use this if you want multiple versions + of your app to be able to run independently. If used, this + would typically be "<major>.<minor>". + Only applied when appname is present. + "multipath" is an optional parameter only applicable to *nix + which indicates that the entire list of config dirs should be + returned. By default, the first item from XDG_CONFIG_DIRS is + returned, or '/etc/xdg/<AppName>', if XDG_CONFIG_DIRS is not set + + Typical site config directories are: + Mac OS X: same as site_data_dir + Unix: /etc/xdg/<AppName> or $XDG_CONFIG_DIRS[i]/<AppName> for each value in + $XDG_CONFIG_DIRS + Win *: same as site_data_dir + Vista: (Fail! "C:\ProgramData" is a hidden *system* directory on Vista.) + + For Unix, this is using the $XDG_CONFIG_DIRS[0] default, if multipath=False + + WARNING: Do not use this on Windows. See the Vista-Fail note above for why. + """ + if system in ["win32", "darwin"]: + path = site_data_dir(appname, appauthor) + if appname and version: + path = os.path.join(path, version) + else: + # XDG default for $XDG_CONFIG_DIRS + # only first, if multipath is False + path = os.getenv('XDG_CONFIG_DIRS', '/etc/xdg') + pathlist = [os.path.expanduser(x.rstrip(os.sep)) for x in path.split(os.pathsep)] + if appname: + if version: + appname = os.path.join(appname, version) + pathlist = [os.sep.join([x, appname]) for x in pathlist] + + if multipath: + path = os.pathsep.join(pathlist) + else: + path = pathlist[0] + return path + + +def user_cache_dir(appname=None, appauthor=None, version=None, opinion=True): + r"""Return full path to the user-specific cache dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "appauthor" (only used on Windows) is the name of the + appauthor or distributing body for this application. Typically + it is the owning company name. This falls back to appname. You may + pass False to disable it. + "version" is an optional version path element to append to the + path. You might want to use this if you want multiple versions + of your app to be able to run independently. If used, this + would typically be "<major>.<minor>". + Only applied when appname is present. + "opinion" (boolean) can be False to disable the appending of + "Cache" to the base app data dir for Windows. See + discussion below. + + Typical user cache directories are: + Mac OS X: ~/Library/Caches/<AppName> + Unix: ~/.cache/<AppName> (XDG default) + Win XP: C:\Documents and Settings\<username>\Local Settings\Application Data\<AppAuthor>\<AppName>\Cache + Vista: C:\Users\<username>\AppData\Local\<AppAuthor>\<AppName>\Cache + + On Windows the only suggestion in the MSDN docs is that local settings go in + the `CSIDL_LOCAL_APPDATA` directory. This is identical to the non-roaming + app data dir (the default returned by `user_data_dir` above). Apps typically + put cache data somewhere *under* the given dir here. Some examples: + ...\Mozilla\Firefox\Profiles\<ProfileName>\Cache + ...\Acme\SuperApp\Cache\1.0 + OPINION: This function appends "Cache" to the `CSIDL_LOCAL_APPDATA` value. + This can be disabled with the `opinion=False` option. + """ + if system == "win32": + if appauthor is None: + appauthor = appname + path = os.path.normpath(_get_win_folder("CSIDL_LOCAL_APPDATA")) + if appname: + if appauthor is not False: + path = os.path.join(path, appauthor, appname) + else: + path = os.path.join(path, appname) + if opinion: + path = os.path.join(path, "Cache") + elif system == 'darwin': + path = os.path.expanduser('~/Library/Caches') + if appname: + path = os.path.join(path, appname) + else: + path = os.getenv('XDG_CACHE_HOME', os.path.expanduser('~/.cache')) + if appname: + path = os.path.join(path, appname) + if appname and version: + path = os.path.join(path, version) + return path + + +def user_state_dir(appname=None, appauthor=None, version=None, roaming=False): + r"""Return full path to the user-specific state dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "appauthor" (only used on Windows) is the name of the + appauthor or distributing body for this application. Typically + it is the owning company name. This falls back to appname. You may + pass False to disable it. + "version" is an optional version path element to append to the + path. You might want to use this if you want multiple versions + of your app to be able to run independently. If used, this + would typically be "<major>.<minor>". + Only applied when appname is present. + "roaming" (boolean, default False) can be set True to use the Windows + roaming appdata directory. That means that for users on a Windows + network setup for roaming profiles, this user data will be + sync'd on login. See + <http://technet.microsoft.com/en-us/library/cc766489(WS.10).aspx> + for a discussion of issues. + + Typical user state directories are: + Mac OS X: same as user_data_dir + Unix: ~/.local/state/<AppName> # or in $XDG_STATE_HOME, if defined + Win *: same as user_data_dir + + For Unix, we follow this Debian proposal <https://wiki.debian.org/XDGBaseDirectorySpecification#state> + to extend the XDG spec and support $XDG_STATE_HOME. + + That means, by default "~/.local/state/<AppName>". + """ + if system in ["win32", "darwin"]: + path = user_data_dir(appname, appauthor, None, roaming) + else: + path = os.getenv('XDG_STATE_HOME', os.path.expanduser("~/.local/state")) + if appname: + path = os.path.join(path, appname) + if appname and version: + path = os.path.join(path, version) + return path + + +def user_log_dir(appname=None, appauthor=None, version=None, opinion=True): + r"""Return full path to the user-specific log dir for this application. + + "appname" is the name of application. + If None, just the system directory is returned. + "appauthor" (only used on Windows) is the name of the + appauthor or distributing body for this application. Typically + it is the owning company name. This falls back to appname. You may + pass False to disable it. + "version" is an optional version path element to append to the + path. You might want to use this if you want multiple versions + of your app to be able to run independently. If used, this + would typically be "<major>.<minor>". + Only applied when appname is present. + "opinion" (boolean) can be False to disable the appending of + "Logs" to the base app data dir for Windows, and "log" to the + base cache dir for Unix. See discussion below. + + Typical user log directories are: + Mac OS X: ~/Library/Logs/<AppName> + Unix: ~/.cache/<AppName>/log # or under $XDG_CACHE_HOME if defined + Win XP: C:\Documents and Settings\<username>\Local Settings\Application Data\<AppAuthor>\<AppName>\Logs + Vista: C:\Users\<username>\AppData\Local\<AppAuthor>\<AppName>\Logs + + On Windows the only suggestion in the MSDN docs is that local settings + go in the `CSIDL_LOCAL_APPDATA` directory. (Note: I'm interested in + examples of what some windows apps use for a logs dir.) + + OPINION: This function appends "Logs" to the `CSIDL_LOCAL_APPDATA` + value for Windows and appends "log" to the user cache dir for Unix. + This can be disabled with the `opinion=False` option. + """ + if system == "darwin": + path = os.path.join( + os.path.expanduser('~/Library/Logs'), + appname) + elif system == "win32": + path = user_data_dir(appname, appauthor, version) + version = False + if opinion: + path = os.path.join(path, "Logs") + else: + path = user_cache_dir(appname, appauthor, version) + version = False + if opinion: + path = os.path.join(path, "log") + if appname and version: + path = os.path.join(path, version) + return path + + +class AppDirs(object): + """Convenience wrapper for getting application dirs.""" + def __init__(self, appname=None, appauthor=None, version=None, + roaming=False, multipath=False): + self.appname = appname + self.appauthor = appauthor + self.version = version + self.roaming = roaming + self.multipath = multipath + + @property + def user_data_dir(self): + return user_data_dir(self.appname, self.appauthor, + version=self.version, roaming=self.roaming) + + @property + def site_data_dir(self): + return site_data_dir(self.appname, self.appauthor, + version=self.version, multipath=self.multipath) + + @property + def user_config_dir(self): + return user_config_dir(self.appname, self.appauthor, + version=self.version, roaming=self.roaming) + + @property + def site_config_dir(self): + return site_config_dir(self.appname, self.appauthor, + version=self.version, multipath=self.multipath) + + @property + def user_cache_dir(self): + return user_cache_dir(self.appname, self.appauthor, + version=self.version) + + @property + def user_state_dir(self): + return user_state_dir(self.appname, self.appauthor, + version=self.version) + + @property + def user_log_dir(self): + return user_log_dir(self.appname, self.appauthor, + version=self.version) + + +#---- internal support stuff + +def _get_win_folder_from_registry(csidl_name): + """This is a fallback technique at best. I'm not sure if using the + registry for this guarantees us the correct answer for all CSIDL_* + names. + """ + if PY3: + import winreg as _winreg + else: + import _winreg + + shell_folder_name = { + "CSIDL_APPDATA": "AppData", + "CSIDL_COMMON_APPDATA": "Common AppData", + "CSIDL_LOCAL_APPDATA": "Local AppData", + }[csidl_name] + + key = _winreg.OpenKey( + _winreg.HKEY_CURRENT_USER, + r"Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders" + ) + dir, type = _winreg.QueryValueEx(key, shell_folder_name) + return dir + + +def _get_win_folder_with_pywin32(csidl_name): + from win32com.shell import shellcon, shell + dir = shell.SHGetFolderPath(0, getattr(shellcon, csidl_name), 0, 0) + # Try to make this a unicode path because SHGetFolderPath does + # not return unicode strings when there is unicode data in the + # path. + try: + dir = unicode(dir) + + # Downgrade to short path name if have highbit chars. See + # <http://bugs.activestate.com/show_bug.cgi?id=85099>. + has_high_char = False + for c in dir: + if ord(c) > 255: + has_high_char = True + break + if has_high_char: + try: + import win32api + dir = win32api.GetShortPathName(dir) + except ImportError: + pass + except UnicodeError: + pass + return dir + + +def _get_win_folder_with_ctypes(csidl_name): + import ctypes + + csidl_const = { + "CSIDL_APPDATA": 26, + "CSIDL_COMMON_APPDATA": 35, + "CSIDL_LOCAL_APPDATA": 28, + }[csidl_name] + + buf = ctypes.create_unicode_buffer(1024) + ctypes.windll.shell32.SHGetFolderPathW(None, csidl_const, None, 0, buf) + + # Downgrade to short path name if have highbit chars. See + # <http://bugs.activestate.com/show_bug.cgi?id=85099>. + has_high_char = False + for c in buf: + if ord(c) > 255: + has_high_char = True + break + if has_high_char: + buf2 = ctypes.create_unicode_buffer(1024) + if ctypes.windll.kernel32.GetShortPathNameW(buf.value, buf2, 1024): + buf = buf2 + + return buf.value + +def _get_win_folder_with_jna(csidl_name): + import array + from com.sun import jna + from com.sun.jna.platform import win32 + + buf_size = win32.WinDef.MAX_PATH * 2 + buf = array.zeros('c', buf_size) + shell = win32.Shell32.INSTANCE + shell.SHGetFolderPath(None, getattr(win32.ShlObj, csidl_name), None, win32.ShlObj.SHGFP_TYPE_CURRENT, buf) + dir = jna.Native.toString(buf.tostring()).rstrip("\0") + + # Downgrade to short path name if have highbit chars. See + # <http://bugs.activestate.com/show_bug.cgi?id=85099>. + has_high_char = False + for c in dir: + if ord(c) > 255: + has_high_char = True + break + if has_high_char: + buf = array.zeros('c', buf_size) + kernel = win32.Kernel32.INSTANCE + if kernel.GetShortPathName(dir, buf, buf_size): + dir = jna.Native.toString(buf.tostring()).rstrip("\0") + + return dir + +if system == "win32": + try: + import win32com.shell + _get_win_folder = _get_win_folder_with_pywin32 + except ImportError: + try: + from ctypes import windll + _get_win_folder = _get_win_folder_with_ctypes + except ImportError: + try: + import com.sun.jna + _get_win_folder = _get_win_folder_with_jna + except ImportError: + _get_win_folder = _get_win_folder_from_registry + + +#---- self test code + +if __name__ == "__main__": + appname = "MyApp" + appauthor = "MyCompany" + + props = ("user_data_dir", + "user_config_dir", + "user_cache_dir", + "user_state_dir", + "user_log_dir", + "site_data_dir", + "site_config_dir") + + print("-- app dirs %s --" % __version__) + + print("-- app dirs (with optional 'version')") + dirs = AppDirs(appname, appauthor, version="1.0") + for prop in props: + print("%s: %s" % (prop, getattr(dirs, prop))) + + print("\n-- app dirs (without optional 'version')") + dirs = AppDirs(appname, appauthor) + for prop in props: + print("%s: %s" % (prop, getattr(dirs, prop))) + + print("\n-- app dirs (without optional 'appauthor')") + dirs = AppDirs(appname) + for prop in props: + print("%s: %s" % (prop, getattr(dirs, prop))) + + print("\n-- app dirs (with disabled 'appauthor')") + dirs = AppDirs(appname, appauthor=False) + for prop in props: + print("%s: %s" % (prop, getattr(dirs, prop))) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__about__.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__about__.py new file mode 100644 index 0000000..95d330e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__about__.py @@ -0,0 +1,21 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +__all__ = [ + "__title__", "__summary__", "__uri__", "__version__", "__author__", + "__email__", "__license__", "__copyright__", +] + +__title__ = "packaging" +__summary__ = "Core utilities for Python packages" +__uri__ = "https://github.com/pypa/packaging" + +__version__ = "16.8" + +__author__ = "Donald Stufft and individual contributors" +__email__ = "donald@stufft.io" + +__license__ = "BSD or Apache License, Version 2.0" +__copyright__ = "Copyright 2014-2016 %s" % __author__ diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__init__.py new file mode 100644 index 0000000..5ee6220 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__init__.py @@ -0,0 +1,14 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +from .__about__ import ( + __author__, __copyright__, __email__, __license__, __summary__, __title__, + __uri__, __version__ +) + +__all__ = [ + "__title__", "__summary__", "__uri__", "__version__", "__author__", + "__email__", "__license__", "__copyright__", +] diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__about__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__about__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6b30fd1f01748ecf351de67ee1bcd7fd526dca21 GIT binary patch literal 763 zcmYk4OK;RL5P*|?bYI=JJk+zP#9<}6-mTDzB7_R<5ur*24!Ky~j5je&?8uL(n>#;* zBR75u=e=^`4{+ds7<WNsM)~5g#^ZVT{dhc#P=0>>%)hmw=zB2!mp&S2_}NPYL=YEI z87FbsN?K(*X~z+?pbZ`9!VdJH4}+|qbYPftVU+B^ZqkEs(ucid0Q<=h4w4bv6NAGj z*@gR8(d5Aoj2cban|;2ty6{dgSytM(O&??}t<-9>R~e}sTX~hbU=J8`(iMWS&4@AU z%aWTl8a>9mk=xx`m~a-2A!FRTTpL{DNl|iHY<&uu3S~o>F=MH&)<$Nz3vLxpuX!d_ z)*PK{BZzmhkWLCqR@#uuHHK4U>m+RRD0i;1&neBM%l&ei>XKILiqpF=o%v$=teISB z#S0);&aYOEa0NuFP$qa@kW?#Y<kCBBY;yp&u4nevbt-jp^!n<8;O(z4YA(o|ZSqgZ zhi#?gWIAgO&;M0HPG<9`$A|@aY~N1Cp$#kVyuoq}jyW>zfDR(`jThJx(+yiY0lk1Q zc{2zIFT{)jb`f79a}d@6zdli%PR*U5H8*sn3&4En=?%@;X>H0zovc32^8BW0SaG^o z=4OVHDf*69vO1Q^I=uUMHe1x|dhV$e&R0(B!qVzGV@6o*O)4y9wNRkVT~8@yz0@A( lHLcd0{)<wBFT~4Gkv&2@Y`3Dn8sGkZce<SzwS^iO{{ajI<Prb? literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..883a3eae47213b41f69398aeefd72fb2f0df58b3 GIT binary patch literal 601 zcmYk4yN=W_6o#G5Epy2tq<sjcSUgayG!jBQ0S!yz=EyVlWX#%ebZkdEQ}ZH}bUaU5 zs(k?p3dHdaLVK)y@*kbcpQC)P>jk6u_2Zi?O2&R>@jNOLALt2p1jSTgnJYx$N>RFz z7!^#FYGlW5A|`Gsrfw!?t`e1-i@95fg<FcHTZt9rjnza=)l5}tt`=(9RH9a^Pi$R3 zQfIav4KL&_c$=aI<2sLVsFdkVFuonGIy7yBLu&Vt^kb1Ls$l^jQ#^VE7;1pM?@nl% zV<b5T&`ugl*Cl{8d))?o5g|Dz@pMUwCffXd29VHP5_*k!DgZ8N4(0{nDx=PrX5_Wt zJYz=qxW39>4k;$2W=M-<ILa6kvKP7YiELepbIG#~PyL@J{U4I;NK59wGklq|Gk$;N zw1!?r&3lRb;H@H~eEYx~*!Jko?c2kb&GGnfK7-xf?vA*jXj*>9JJa2mHbm-qv)SDC zr~XaiLC4fZ?``1SeFLb2Pq^2CL$6!qk#}-`FB{V~9Kf`O{J-u_L-o#im8^cBzb#x7 QuFF@`lKngM7t#6i7x_)1?*IS* literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/_compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/_compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8c8b3acc838927c289d56f69b181dad8b7542df3 GIT binary patch literal 1037 zcmah{J8K(35Z=d0IxDgqh)Kw!P?~@W>l6nJ24eyVq%(m$AV*+1->#&y@0Hy>*%D4= zgZ(q&(p`SfwyFFFQl!ev$vASAftj0`z5V8!nf<i7+9n{se_lpkIU&C=SQZAsYf$qU zj3kn#B%>kCSjaLSa*8>YdZDMhgN7uJiR6bYY~Ds5L@m|QZ<Rly;Y!|AZT!lHY@U(u zo@5_LzjY1Rq|e=2v~P;EvPvXbS!nBgnM@Ot6uIk`I?1gVRe5Y7-n&L(*T9&>6mQ=M zCYqovQ1b%JJ919W>4-@x*_kid1wG~8nI%8y36orU3AyxuLSr7ZdmwMLimd8Iz5U3j zUYth8^o|lcflQ`sR3`@YpD}>n5iE^jo`6v#q>_Yexp>GWhf?1BIU<UGcspqkN2%Ez z+@@l$hFTc(Q6GSs4wwsiLNCY(KSemYcLkV^$Ek5%9%ah4?IbY*8!(Q_E9M#t-$Qtf zllgNRz&NMSX)uj+Fe*~1v<bG4gR$72>TI5Gjt+*C$?<$H((SGNi5`NC^WbApCgnzw z8yltR#&EbbolRd>fl;<9ZBe8qC=bU%D^pZDRwfWrmCHg0WfUJq<0KykA}+ErvV(Hw zT0-RNNQh_H7p{}gdH=to8Qk33gQk7(p<^LjTZpWXRf>K`h;LPtE>84)z^$9sIJ$+m z2A*5Fo%T}*YXUyi>v*(g6~4bn&qTfP`c|Jg&(2C!BlfxOBHSt(yt7oIM(^Hj1b;F0 zQd<wXegsj!gQQ25tu&C<*uTanr13Au&CIyY6t)77T_pLaaQyw3O*F6I&}!EK0|OOE m$+&jC;yP2KFX-T|mpb-$7Bkw#5(fFNGoN>9*Yl{)n*1-1$qM5D literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/_structures.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/_structures.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3b466a26f16589a195f5e31ed448d950ab207dee GIT binary patch literal 2819 zcmcImO>fgk7#`b+<D_YuLRZV@uJ*KwL~*GEqS_TI0)e>XLidu($n{Jd7soa;<EV|e z1!?zh>@m0fJ-%|{4{+eb`%W;Vt(}w=Of(<%`_4S`em%}#>+3B7?ZbcndjHf3d4~^+ ztp*PV(B)GY7-2?4Mn>NlnSFC)^(})uC(LBlTf!_}n_B%kuTM$84sUC$4sYxFt<7zC zYcu;L={DZONu+D#o8FO3qD*lbj?zS^++pE3lwlI*8>t9mMF&~zD|q&C$6_<#;Q+ck zgn^U3!ARd^1~cE1zQrt7gBkFd4Rf6}m;<xTnydwLgRQYP%nn;;8!$K7ChNf5Vq5GA z%xml_+;Tg2Uc`ei4%Mk|07%hrjr|F9iOyjLXq!C&&LcB2GxD0`(LmVnsE3b#yI{=N zQ`{YU!W|?L<3hUoCvHIZ$6_>z_Xfwi!{NzfLZkf$M?<j-Er{JiHx1LBFqX=TqMhB{ z2jkQ6z08$dWvNP%NV@5(fC?^?O!!>7bj)Lx2sicoS6&dtflH+lnXfX?xtpHm4h8L0 zP};=1qYH^K*($8OTSzaMYk{IRw+#zLl<|g4jVYKtGkP;KuMIsp%xieGXn@97(**({ zENW1S+sk0*QeR&PRIuUtf|qAz@0mV)W(o%s@_M3%T%5<VDUB4Ro1jskZ7vvzvej6k z1KZ~(Z+%(mm};94gHw8?3Ik*pFwVL04Y={xn3^w%Sc7B0kuAu5jCSnvya@+Ho|F)j z3Vi;W(w{2uQC5w=0lO3_@Z03`4FsN6g%*QF*DBCZb^)y{dWTCL8bDxfRzRR^HH5f< z7U(EdI4yvy{!)d3X5h7phU+tCsKQlUBk%Nh;HhxTi_|L3{RX8m4=DW&jw+I|Q|y3> z)56}YjYSfBBe+4{qI8t74AU!bQ~EmdqPavMQ436KaTSMc955#0Iu7VMaSI1DaG@x^ zWUZzstWb%0>zIyp_NV1Oh|V-D#RKR+kZQ$kIDfh8KeOzlxl?#=Zea=GXg_uF#+p%# z$@TN0`X5xMYg8bEmBm>{<<1Jo%hKHPEY`7i7odJFvF?%_x3pYze(kLS!kW=;21RVR zUQTqCG^2C*KI|{zR%Y4vWj0+o4_825j^37kFm!ePu>$ClB)9a-q#5ARDxhy+I?W2D zNsm19cme8KNhZz-PW%dLrIdt~|2v*hK}jg@bsNZvgAD)4zy}d?Okk1;{Qs5P$<Z<Q c)%>2QUj~#rf6iI;5$=)r_hH-W+_s^A0;9(KX#fBK literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/markers.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/markers.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0d9ca9e480613887de60c0519c11040980351541 GIT binary patch literal 8975 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 Iah!?&2R|6yT>t<8 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/requirements.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/requirements.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..68eecf81fceb3140b994c64a78e1d8f60404d643 GIT binary patch literal 3934 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4333ca68e9bb9921453092e841bc2c5dce84928a GIT binary patch literal 19843 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 SM++nP{gO6`gIuG9d;S{}0rBww literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/utils.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/utils.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e6465a91a473175b86fa5df402bb2542cd77d38b GIT binary patch literal 522 zcmY*Wy^a$x5VpOWTogEd1TPVxoWm6-MM4OP{u-cJge+(6Y|MFWYiuvM70pTaAW1<% z$Md+Q;sq$K!lppSC(Wms@r=Hi@rTpXIm-C`<H)~ZgnpLbKB^qN$>z^92_&#aJ#KJM z8q!xyg-ed;x~XM-n273#o2jV9<Q6q2g1keE>95>}7FBx8H{R+PBvZY!5YkMjL3w3O zdgMTvz_!t}A;*{F^y8A9eR|R6f&QWRb+)(J{F6)p9k9S((UBa;5oIZId54!-=^1Oe zu|~CAt5GtLo!qC&$4#1O`$fV6r`qsden(Jtzq_GXf8asVfdk!IEhKol-qVh)2k1w0 zzWuz~?e^oy^!j46gH=Xn=zHpvTPouN*Lt~HT@2U5%SgQp(FJR@r|zoD^4>;hrKfC= zMp&SZw^zJVrlT<^?a$nGdivkQWw?iBO_B)_DE?xW<}9BmM39U@d4cjbP;Qb4$aK=$ j-YG3%TGFNG?|S#>K`EWR>aB=czAlZv)IKM(YF_;T2i1&! literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/version.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/version.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1180634b590ad7548e2e9daedd91ca0bbb7a6123 GIT binary patch literal 10690 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_compat.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_compat.py new file mode 100644 index 0000000..210bb80 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_compat.py @@ -0,0 +1,30 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import sys + + +PY2 = sys.version_info[0] == 2 +PY3 = sys.version_info[0] == 3 + +# flake8: noqa + +if PY3: + string_types = str, +else: + string_types = basestring, + + +def with_metaclass(meta, *bases): + """ + Create a base class with a metaclass. + """ + # This requires a bit of explanation: the basic idea is to make a dummy + # metaclass for one level of class instantiation that replaces itself with + # the actual metaclass. + class metaclass(meta): + def __new__(cls, name, this_bases, d): + return meta(name, bases, d) + return type.__new__(metaclass, 'temporary_class', (), {}) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_structures.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_structures.py new file mode 100644 index 0000000..ccc2786 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_structures.py @@ -0,0 +1,68 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + + +class Infinity(object): + + def __repr__(self): + return "Infinity" + + def __hash__(self): + return hash(repr(self)) + + def __lt__(self, other): + return False + + def __le__(self, other): + return False + + def __eq__(self, other): + return isinstance(other, self.__class__) + + def __ne__(self, other): + return not isinstance(other, self.__class__) + + def __gt__(self, other): + return True + + def __ge__(self, other): + return True + + def __neg__(self): + return NegativeInfinity + +Infinity = Infinity() + + +class NegativeInfinity(object): + + def __repr__(self): + return "-Infinity" + + def __hash__(self): + return hash(repr(self)) + + def __lt__(self, other): + return True + + def __le__(self, other): + return True + + def __eq__(self, other): + return isinstance(other, self.__class__) + + def __ne__(self, other): + return not isinstance(other, self.__class__) + + def __gt__(self, other): + return False + + def __ge__(self, other): + return False + + def __neg__(self): + return Infinity + +NegativeInfinity = NegativeInfinity() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/markers.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/markers.py new file mode 100644 index 0000000..892e578 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/markers.py @@ -0,0 +1,301 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import operator +import os +import platform +import sys + +from pkg_resources.extern.pyparsing import ParseException, ParseResults, stringStart, stringEnd +from pkg_resources.extern.pyparsing import ZeroOrMore, Group, Forward, QuotedString +from pkg_resources.extern.pyparsing import Literal as L # noqa + +from ._compat import string_types +from .specifiers import Specifier, InvalidSpecifier + + +__all__ = [ + "InvalidMarker", "UndefinedComparison", "UndefinedEnvironmentName", + "Marker", "default_environment", +] + + +class InvalidMarker(ValueError): + """ + An invalid marker was found, users should refer to PEP 508. + """ + + +class UndefinedComparison(ValueError): + """ + An invalid operation was attempted on a value that doesn't support it. + """ + + +class UndefinedEnvironmentName(ValueError): + """ + A name was attempted to be used that does not exist inside of the + environment. + """ + + +class Node(object): + + def __init__(self, value): + self.value = value + + def __str__(self): + return str(self.value) + + def __repr__(self): + return "<{0}({1!r})>".format(self.__class__.__name__, str(self)) + + def serialize(self): + raise NotImplementedError + + +class Variable(Node): + + def serialize(self): + return str(self) + + +class Value(Node): + + def serialize(self): + return '"{0}"'.format(self) + + +class Op(Node): + + def serialize(self): + return str(self) + + +VARIABLE = ( + L("implementation_version") | + L("platform_python_implementation") | + L("implementation_name") | + L("python_full_version") | + L("platform_release") | + L("platform_version") | + L("platform_machine") | + L("platform_system") | + L("python_version") | + L("sys_platform") | + L("os_name") | + L("os.name") | # PEP-345 + L("sys.platform") | # PEP-345 + L("platform.version") | # PEP-345 + L("platform.machine") | # PEP-345 + L("platform.python_implementation") | # PEP-345 + L("python_implementation") | # undocumented setuptools legacy + L("extra") +) +ALIASES = { + 'os.name': 'os_name', + 'sys.platform': 'sys_platform', + 'platform.version': 'platform_version', + 'platform.machine': 'platform_machine', + 'platform.python_implementation': 'platform_python_implementation', + 'python_implementation': 'platform_python_implementation' +} +VARIABLE.setParseAction(lambda s, l, t: Variable(ALIASES.get(t[0], t[0]))) + +VERSION_CMP = ( + L("===") | + L("==") | + L(">=") | + L("<=") | + L("!=") | + L("~=") | + L(">") | + L("<") +) + +MARKER_OP = VERSION_CMP | L("not in") | L("in") +MARKER_OP.setParseAction(lambda s, l, t: Op(t[0])) + +MARKER_VALUE = QuotedString("'") | QuotedString('"') +MARKER_VALUE.setParseAction(lambda s, l, t: Value(t[0])) + +BOOLOP = L("and") | L("or") + +MARKER_VAR = VARIABLE | MARKER_VALUE + +MARKER_ITEM = Group(MARKER_VAR + MARKER_OP + MARKER_VAR) +MARKER_ITEM.setParseAction(lambda s, l, t: tuple(t[0])) + +LPAREN = L("(").suppress() +RPAREN = L(")").suppress() + +MARKER_EXPR = Forward() +MARKER_ATOM = MARKER_ITEM | Group(LPAREN + MARKER_EXPR + RPAREN) +MARKER_EXPR << MARKER_ATOM + ZeroOrMore(BOOLOP + MARKER_EXPR) + +MARKER = stringStart + MARKER_EXPR + stringEnd + + +def _coerce_parse_result(results): + if isinstance(results, ParseResults): + return [_coerce_parse_result(i) for i in results] + else: + return results + + +def _format_marker(marker, first=True): + assert isinstance(marker, (list, tuple, string_types)) + + # Sometimes we have a structure like [[...]] which is a single item list + # where the single item is itself it's own list. In that case we want skip + # the rest of this function so that we don't get extraneous () on the + # outside. + if (isinstance(marker, list) and len(marker) == 1 and + isinstance(marker[0], (list, tuple))): + return _format_marker(marker[0]) + + if isinstance(marker, list): + inner = (_format_marker(m, first=False) for m in marker) + if first: + return " ".join(inner) + else: + return "(" + " ".join(inner) + ")" + elif isinstance(marker, tuple): + return " ".join([m.serialize() for m in marker]) + else: + return marker + + +_operators = { + "in": lambda lhs, rhs: lhs in rhs, + "not in": lambda lhs, rhs: lhs not in rhs, + "<": operator.lt, + "<=": operator.le, + "==": operator.eq, + "!=": operator.ne, + ">=": operator.ge, + ">": operator.gt, +} + + +def _eval_op(lhs, op, rhs): + try: + spec = Specifier("".join([op.serialize(), rhs])) + except InvalidSpecifier: + pass + else: + return spec.contains(lhs) + + oper = _operators.get(op.serialize()) + if oper is None: + raise UndefinedComparison( + "Undefined {0!r} on {1!r} and {2!r}.".format(op, lhs, rhs) + ) + + return oper(lhs, rhs) + + +_undefined = object() + + +def _get_env(environment, name): + value = environment.get(name, _undefined) + + if value is _undefined: + raise UndefinedEnvironmentName( + "{0!r} does not exist in evaluation environment.".format(name) + ) + + return value + + +def _evaluate_markers(markers, environment): + groups = [[]] + + for marker in markers: + assert isinstance(marker, (list, tuple, string_types)) + + if isinstance(marker, list): + groups[-1].append(_evaluate_markers(marker, environment)) + elif isinstance(marker, tuple): + lhs, op, rhs = marker + + if isinstance(lhs, Variable): + lhs_value = _get_env(environment, lhs.value) + rhs_value = rhs.value + else: + lhs_value = lhs.value + rhs_value = _get_env(environment, rhs.value) + + groups[-1].append(_eval_op(lhs_value, op, rhs_value)) + else: + assert marker in ["and", "or"] + if marker == "or": + groups.append([]) + + return any(all(item) for item in groups) + + +def format_full_version(info): + version = '{0.major}.{0.minor}.{0.micro}'.format(info) + kind = info.releaselevel + if kind != 'final': + version += kind[0] + str(info.serial) + return version + + +def default_environment(): + if hasattr(sys, 'implementation'): + iver = format_full_version(sys.implementation.version) + implementation_name = sys.implementation.name + else: + iver = '0' + implementation_name = '' + + return { + "implementation_name": implementation_name, + "implementation_version": iver, + "os_name": os.name, + "platform_machine": platform.machine(), + "platform_release": platform.release(), + "platform_system": platform.system(), + "platform_version": platform.version(), + "python_full_version": platform.python_version(), + "platform_python_implementation": platform.python_implementation(), + "python_version": platform.python_version()[:3], + "sys_platform": sys.platform, + } + + +class Marker(object): + + def __init__(self, marker): + try: + self._markers = _coerce_parse_result(MARKER.parseString(marker)) + except ParseException as e: + err_str = "Invalid marker: {0!r}, parse error at {1!r}".format( + marker, marker[e.loc:e.loc + 8]) + raise InvalidMarker(err_str) + + def __str__(self): + return _format_marker(self._markers) + + def __repr__(self): + return "<Marker({0!r})>".format(str(self)) + + def evaluate(self, environment=None): + """Evaluate a marker. + + Return the boolean from evaluating the given marker against the + environment. environment is an optional argument to override all or + part of the determined environment. + + The environment is determined from the current Python process. + """ + current_environment = default_environment() + if environment is not None: + current_environment.update(environment) + + return _evaluate_markers(self._markers, current_environment) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/requirements.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/requirements.py new file mode 100644 index 0000000..0c8c4a3 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/requirements.py @@ -0,0 +1,127 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import string +import re + +from pkg_resources.extern.pyparsing import stringStart, stringEnd, originalTextFor, ParseException +from pkg_resources.extern.pyparsing import ZeroOrMore, Word, Optional, Regex, Combine +from pkg_resources.extern.pyparsing import Literal as L # noqa +from pkg_resources.extern.six.moves.urllib import parse as urlparse + +from .markers import MARKER_EXPR, Marker +from .specifiers import LegacySpecifier, Specifier, SpecifierSet + + +class InvalidRequirement(ValueError): + """ + An invalid requirement was found, users should refer to PEP 508. + """ + + +ALPHANUM = Word(string.ascii_letters + string.digits) + +LBRACKET = L("[").suppress() +RBRACKET = L("]").suppress() +LPAREN = L("(").suppress() +RPAREN = L(")").suppress() +COMMA = L(",").suppress() +SEMICOLON = L(";").suppress() +AT = L("@").suppress() + +PUNCTUATION = Word("-_.") +IDENTIFIER_END = ALPHANUM | (ZeroOrMore(PUNCTUATION) + ALPHANUM) +IDENTIFIER = Combine(ALPHANUM + ZeroOrMore(IDENTIFIER_END)) + +NAME = IDENTIFIER("name") +EXTRA = IDENTIFIER + +URI = Regex(r'[^ ]+')("url") +URL = (AT + URI) + +EXTRAS_LIST = EXTRA + ZeroOrMore(COMMA + EXTRA) +EXTRAS = (LBRACKET + Optional(EXTRAS_LIST) + RBRACKET)("extras") + +VERSION_PEP440 = Regex(Specifier._regex_str, re.VERBOSE | re.IGNORECASE) +VERSION_LEGACY = Regex(LegacySpecifier._regex_str, re.VERBOSE | re.IGNORECASE) + +VERSION_ONE = VERSION_PEP440 ^ VERSION_LEGACY +VERSION_MANY = Combine(VERSION_ONE + ZeroOrMore(COMMA + VERSION_ONE), + joinString=",", adjacent=False)("_raw_spec") +_VERSION_SPEC = Optional(((LPAREN + VERSION_MANY + RPAREN) | VERSION_MANY)) +_VERSION_SPEC.setParseAction(lambda s, l, t: t._raw_spec or '') + +VERSION_SPEC = originalTextFor(_VERSION_SPEC)("specifier") +VERSION_SPEC.setParseAction(lambda s, l, t: t[1]) + +MARKER_EXPR = originalTextFor(MARKER_EXPR())("marker") +MARKER_EXPR.setParseAction( + lambda s, l, t: Marker(s[t._original_start:t._original_end]) +) +MARKER_SEPERATOR = SEMICOLON +MARKER = MARKER_SEPERATOR + MARKER_EXPR + +VERSION_AND_MARKER = VERSION_SPEC + Optional(MARKER) +URL_AND_MARKER = URL + Optional(MARKER) + +NAMED_REQUIREMENT = \ + NAME + Optional(EXTRAS) + (URL_AND_MARKER | VERSION_AND_MARKER) + +REQUIREMENT = stringStart + NAMED_REQUIREMENT + stringEnd + + +class Requirement(object): + """Parse a requirement. + + Parse a given requirement string into its parts, such as name, specifier, + URL, and extras. Raises InvalidRequirement on a badly-formed requirement + string. + """ + + # TODO: Can we test whether something is contained within a requirement? + # If so how do we do that? Do we need to test against the _name_ of + # the thing as well as the version? What about the markers? + # TODO: Can we normalize the name and extra name? + + def __init__(self, requirement_string): + try: + req = REQUIREMENT.parseString(requirement_string) + except ParseException as e: + raise InvalidRequirement( + "Invalid requirement, parse error at \"{0!r}\"".format( + requirement_string[e.loc:e.loc + 8])) + + self.name = req.name + if req.url: + parsed_url = urlparse.urlparse(req.url) + if not (parsed_url.scheme and parsed_url.netloc) or ( + not parsed_url.scheme and not parsed_url.netloc): + raise InvalidRequirement("Invalid URL given") + self.url = req.url + else: + self.url = None + self.extras = set(req.extras.asList() if req.extras else []) + self.specifier = SpecifierSet(req.specifier) + self.marker = req.marker if req.marker else None + + def __str__(self): + parts = [self.name] + + if self.extras: + parts.append("[{0}]".format(",".join(sorted(self.extras)))) + + if self.specifier: + parts.append(str(self.specifier)) + + if self.url: + parts.append("@ {0}".format(self.url)) + + if self.marker: + parts.append("; {0}".format(self.marker)) + + return "".join(parts) + + def __repr__(self): + return "<Requirement({0!r})>".format(str(self)) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/specifiers.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/specifiers.py new file mode 100644 index 0000000..7f5a76c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/specifiers.py @@ -0,0 +1,774 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import abc +import functools +import itertools +import re + +from ._compat import string_types, with_metaclass +from .version import Version, LegacyVersion, parse + + +class InvalidSpecifier(ValueError): + """ + An invalid specifier was found, users should refer to PEP 440. + """ + + +class BaseSpecifier(with_metaclass(abc.ABCMeta, object)): + + @abc.abstractmethod + def __str__(self): + """ + Returns the str representation of this Specifier like object. This + should be representative of the Specifier itself. + """ + + @abc.abstractmethod + def __hash__(self): + """ + Returns a hash value for this Specifier like object. + """ + + @abc.abstractmethod + def __eq__(self, other): + """ + Returns a boolean representing whether or not the two Specifier like + objects are equal. + """ + + @abc.abstractmethod + def __ne__(self, other): + """ + Returns a boolean representing whether or not the two Specifier like + objects are not equal. + """ + + @abc.abstractproperty + def prereleases(self): + """ + Returns whether or not pre-releases as a whole are allowed by this + specifier. + """ + + @prereleases.setter + def prereleases(self, value): + """ + Sets whether or not pre-releases as a whole are allowed by this + specifier. + """ + + @abc.abstractmethod + def contains(self, item, prereleases=None): + """ + Determines if the given item is contained within this specifier. + """ + + @abc.abstractmethod + def filter(self, iterable, prereleases=None): + """ + Takes an iterable of items and filters them so that only items which + are contained within this specifier are allowed in it. + """ + + +class _IndividualSpecifier(BaseSpecifier): + + _operators = {} + + def __init__(self, spec="", prereleases=None): + match = self._regex.search(spec) + if not match: + raise InvalidSpecifier("Invalid specifier: '{0}'".format(spec)) + + self._spec = ( + match.group("operator").strip(), + match.group("version").strip(), + ) + + # Store whether or not this Specifier should accept prereleases + self._prereleases = prereleases + + def __repr__(self): + pre = ( + ", prereleases={0!r}".format(self.prereleases) + if self._prereleases is not None + else "" + ) + + return "<{0}({1!r}{2})>".format( + self.__class__.__name__, + str(self), + pre, + ) + + def __str__(self): + return "{0}{1}".format(*self._spec) + + def __hash__(self): + return hash(self._spec) + + def __eq__(self, other): + if isinstance(other, string_types): + try: + other = self.__class__(other) + except InvalidSpecifier: + return NotImplemented + elif not isinstance(other, self.__class__): + return NotImplemented + + return self._spec == other._spec + + def __ne__(self, other): + if isinstance(other, string_types): + try: + other = self.__class__(other) + except InvalidSpecifier: + return NotImplemented + elif not isinstance(other, self.__class__): + return NotImplemented + + return self._spec != other._spec + + def _get_operator(self, op): + return getattr(self, "_compare_{0}".format(self._operators[op])) + + def _coerce_version(self, version): + if not isinstance(version, (LegacyVersion, Version)): + version = parse(version) + return version + + @property + def operator(self): + return self._spec[0] + + @property + def version(self): + return self._spec[1] + + @property + def prereleases(self): + return self._prereleases + + @prereleases.setter + def prereleases(self, value): + self._prereleases = value + + def __contains__(self, item): + return self.contains(item) + + def contains(self, item, prereleases=None): + # Determine if prereleases are to be allowed or not. + if prereleases is None: + prereleases = self.prereleases + + # Normalize item to a Version or LegacyVersion, this allows us to have + # a shortcut for ``"2.0" in Specifier(">=2") + item = self._coerce_version(item) + + # Determine if we should be supporting prereleases in this specifier + # or not, if we do not support prereleases than we can short circuit + # logic if this version is a prereleases. + if item.is_prerelease and not prereleases: + return False + + # Actually do the comparison to determine if this item is contained + # within this Specifier or not. + return self._get_operator(self.operator)(item, self.version) + + def filter(self, iterable, prereleases=None): + yielded = False + found_prereleases = [] + + kw = {"prereleases": prereleases if prereleases is not None else True} + + # Attempt to iterate over all the values in the iterable and if any of + # them match, yield them. + for version in iterable: + parsed_version = self._coerce_version(version) + + if self.contains(parsed_version, **kw): + # If our version is a prerelease, and we were not set to allow + # prereleases, then we'll store it for later incase nothing + # else matches this specifier. + if (parsed_version.is_prerelease and not + (prereleases or self.prereleases)): + found_prereleases.append(version) + # Either this is not a prerelease, or we should have been + # accepting prereleases from the begining. + else: + yielded = True + yield version + + # Now that we've iterated over everything, determine if we've yielded + # any values, and if we have not and we have any prereleases stored up + # then we will go ahead and yield the prereleases. + if not yielded and found_prereleases: + for version in found_prereleases: + yield version + + +class LegacySpecifier(_IndividualSpecifier): + + _regex_str = ( + r""" + (?P<operator>(==|!=|<=|>=|<|>)) + \s* + (?P<version> + [^,;\s)]* # Since this is a "legacy" specifier, and the version + # string can be just about anything, we match everything + # except for whitespace, a semi-colon for marker support, + # a closing paren since versions can be enclosed in + # them, and a comma since it's a version separator. + ) + """ + ) + + _regex = re.compile( + r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE) + + _operators = { + "==": "equal", + "!=": "not_equal", + "<=": "less_than_equal", + ">=": "greater_than_equal", + "<": "less_than", + ">": "greater_than", + } + + def _coerce_version(self, version): + if not isinstance(version, LegacyVersion): + version = LegacyVersion(str(version)) + return version + + def _compare_equal(self, prospective, spec): + return prospective == self._coerce_version(spec) + + def _compare_not_equal(self, prospective, spec): + return prospective != self._coerce_version(spec) + + def _compare_less_than_equal(self, prospective, spec): + return prospective <= self._coerce_version(spec) + + def _compare_greater_than_equal(self, prospective, spec): + return prospective >= self._coerce_version(spec) + + def _compare_less_than(self, prospective, spec): + return prospective < self._coerce_version(spec) + + def _compare_greater_than(self, prospective, spec): + return prospective > self._coerce_version(spec) + + +def _require_version_compare(fn): + @functools.wraps(fn) + def wrapped(self, prospective, spec): + if not isinstance(prospective, Version): + return False + return fn(self, prospective, spec) + return wrapped + + +class Specifier(_IndividualSpecifier): + + _regex_str = ( + r""" + (?P<operator>(~=|==|!=|<=|>=|<|>|===)) + (?P<version> + (?: + # The identity operators allow for an escape hatch that will + # do an exact string match of the version you wish to install. + # This will not be parsed by PEP 440 and we cannot determine + # any semantic meaning from it. This operator is discouraged + # but included entirely as an escape hatch. + (?<====) # Only match for the identity operator + \s* + [^\s]* # We just match everything, except for whitespace + # since we are only testing for strict identity. + ) + | + (?: + # The (non)equality operators allow for wild card and local + # versions to be specified so we have to define these two + # operators separately to enable that. + (?<===|!=) # Only match for equals and not equals + + \s* + v? + (?:[0-9]+!)? # epoch + [0-9]+(?:\.[0-9]+)* # release + (?: # pre release + [-_\.]? + (a|b|c|rc|alpha|beta|pre|preview) + [-_\.]? + [0-9]* + )? + (?: # post release + (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) + )? + + # You cannot use a wild card and a dev or local version + # together so group them with a | and make them optional. + (?: + (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release + (?:\+[a-z0-9]+(?:[-_\.][a-z0-9]+)*)? # local + | + \.\* # Wild card syntax of .* + )? + ) + | + (?: + # The compatible operator requires at least two digits in the + # release segment. + (?<=~=) # Only match for the compatible operator + + \s* + v? + (?:[0-9]+!)? # epoch + [0-9]+(?:\.[0-9]+)+ # release (We have a + instead of a *) + (?: # pre release + [-_\.]? + (a|b|c|rc|alpha|beta|pre|preview) + [-_\.]? + [0-9]* + )? + (?: # post release + (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) + )? + (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release + ) + | + (?: + # All other operators only allow a sub set of what the + # (non)equality operators do. Specifically they do not allow + # local versions to be specified nor do they allow the prefix + # matching wild cards. + (?<!==|!=|~=) # We have special cases for these + # operators so we want to make sure they + # don't match here. + + \s* + v? + (?:[0-9]+!)? # epoch + [0-9]+(?:\.[0-9]+)* # release + (?: # pre release + [-_\.]? + (a|b|c|rc|alpha|beta|pre|preview) + [-_\.]? + [0-9]* + )? + (?: # post release + (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) + )? + (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release + ) + ) + """ + ) + + _regex = re.compile( + r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE) + + _operators = { + "~=": "compatible", + "==": "equal", + "!=": "not_equal", + "<=": "less_than_equal", + ">=": "greater_than_equal", + "<": "less_than", + ">": "greater_than", + "===": "arbitrary", + } + + @_require_version_compare + def _compare_compatible(self, prospective, spec): + # Compatible releases have an equivalent combination of >= and ==. That + # is that ~=2.2 is equivalent to >=2.2,==2.*. This allows us to + # implement this in terms of the other specifiers instead of + # implementing it ourselves. The only thing we need to do is construct + # the other specifiers. + + # We want everything but the last item in the version, but we want to + # ignore post and dev releases and we want to treat the pre-release as + # it's own separate segment. + prefix = ".".join( + list( + itertools.takewhile( + lambda x: (not x.startswith("post") and not + x.startswith("dev")), + _version_split(spec), + ) + )[:-1] + ) + + # Add the prefix notation to the end of our string + prefix += ".*" + + return (self._get_operator(">=")(prospective, spec) and + self._get_operator("==")(prospective, prefix)) + + @_require_version_compare + def _compare_equal(self, prospective, spec): + # We need special logic to handle prefix matching + if spec.endswith(".*"): + # In the case of prefix matching we want to ignore local segment. + prospective = Version(prospective.public) + # Split the spec out by dots, and pretend that there is an implicit + # dot in between a release segment and a pre-release segment. + spec = _version_split(spec[:-2]) # Remove the trailing .* + + # Split the prospective version out by dots, and pretend that there + # is an implicit dot in between a release segment and a pre-release + # segment. + prospective = _version_split(str(prospective)) + + # Shorten the prospective version to be the same length as the spec + # so that we can determine if the specifier is a prefix of the + # prospective version or not. + prospective = prospective[:len(spec)] + + # Pad out our two sides with zeros so that they both equal the same + # length. + spec, prospective = _pad_version(spec, prospective) + else: + # Convert our spec string into a Version + spec = Version(spec) + + # If the specifier does not have a local segment, then we want to + # act as if the prospective version also does not have a local + # segment. + if not spec.local: + prospective = Version(prospective.public) + + return prospective == spec + + @_require_version_compare + def _compare_not_equal(self, prospective, spec): + return not self._compare_equal(prospective, spec) + + @_require_version_compare + def _compare_less_than_equal(self, prospective, spec): + return prospective <= Version(spec) + + @_require_version_compare + def _compare_greater_than_equal(self, prospective, spec): + return prospective >= Version(spec) + + @_require_version_compare + def _compare_less_than(self, prospective, spec): + # Convert our spec to a Version instance, since we'll want to work with + # it as a version. + spec = Version(spec) + + # Check to see if the prospective version is less than the spec + # version. If it's not we can short circuit and just return False now + # instead of doing extra unneeded work. + if not prospective < spec: + return False + + # This special case is here so that, unless the specifier itself + # includes is a pre-release version, that we do not accept pre-release + # versions for the version mentioned in the specifier (e.g. <3.1 should + # not match 3.1.dev0, but should match 3.0.dev0). + if not spec.is_prerelease and prospective.is_prerelease: + if Version(prospective.base_version) == Version(spec.base_version): + return False + + # If we've gotten to here, it means that prospective version is both + # less than the spec version *and* it's not a pre-release of the same + # version in the spec. + return True + + @_require_version_compare + def _compare_greater_than(self, prospective, spec): + # Convert our spec to a Version instance, since we'll want to work with + # it as a version. + spec = Version(spec) + + # Check to see if the prospective version is greater than the spec + # version. If it's not we can short circuit and just return False now + # instead of doing extra unneeded work. + if not prospective > spec: + return False + + # This special case is here so that, unless the specifier itself + # includes is a post-release version, that we do not accept + # post-release versions for the version mentioned in the specifier + # (e.g. >3.1 should not match 3.0.post0, but should match 3.2.post0). + if not spec.is_postrelease and prospective.is_postrelease: + if Version(prospective.base_version) == Version(spec.base_version): + return False + + # Ensure that we do not allow a local version of the version mentioned + # in the specifier, which is techincally greater than, to match. + if prospective.local is not None: + if Version(prospective.base_version) == Version(spec.base_version): + return False + + # If we've gotten to here, it means that prospective version is both + # greater than the spec version *and* it's not a pre-release of the + # same version in the spec. + return True + + def _compare_arbitrary(self, prospective, spec): + return str(prospective).lower() == str(spec).lower() + + @property + def prereleases(self): + # If there is an explicit prereleases set for this, then we'll just + # blindly use that. + if self._prereleases is not None: + return self._prereleases + + # Look at all of our specifiers and determine if they are inclusive + # operators, and if they are if they are including an explicit + # prerelease. + operator, version = self._spec + if operator in ["==", ">=", "<=", "~=", "==="]: + # The == specifier can include a trailing .*, if it does we + # want to remove before parsing. + if operator == "==" and version.endswith(".*"): + version = version[:-2] + + # Parse the version, and if it is a pre-release than this + # specifier allows pre-releases. + if parse(version).is_prerelease: + return True + + return False + + @prereleases.setter + def prereleases(self, value): + self._prereleases = value + + +_prefix_regex = re.compile(r"^([0-9]+)((?:a|b|c|rc)[0-9]+)$") + + +def _version_split(version): + result = [] + for item in version.split("."): + match = _prefix_regex.search(item) + if match: + result.extend(match.groups()) + else: + result.append(item) + return result + + +def _pad_version(left, right): + left_split, right_split = [], [] + + # Get the release segment of our versions + left_split.append(list(itertools.takewhile(lambda x: x.isdigit(), left))) + right_split.append(list(itertools.takewhile(lambda x: x.isdigit(), right))) + + # Get the rest of our versions + left_split.append(left[len(left_split[0]):]) + right_split.append(right[len(right_split[0]):]) + + # Insert our padding + left_split.insert( + 1, + ["0"] * max(0, len(right_split[0]) - len(left_split[0])), + ) + right_split.insert( + 1, + ["0"] * max(0, len(left_split[0]) - len(right_split[0])), + ) + + return ( + list(itertools.chain(*left_split)), + list(itertools.chain(*right_split)), + ) + + +class SpecifierSet(BaseSpecifier): + + def __init__(self, specifiers="", prereleases=None): + # Split on , to break each indidivual specifier into it's own item, and + # strip each item to remove leading/trailing whitespace. + specifiers = [s.strip() for s in specifiers.split(",") if s.strip()] + + # Parsed each individual specifier, attempting first to make it a + # Specifier and falling back to a LegacySpecifier. + parsed = set() + for specifier in specifiers: + try: + parsed.add(Specifier(specifier)) + except InvalidSpecifier: + parsed.add(LegacySpecifier(specifier)) + + # Turn our parsed specifiers into a frozen set and save them for later. + self._specs = frozenset(parsed) + + # Store our prereleases value so we can use it later to determine if + # we accept prereleases or not. + self._prereleases = prereleases + + def __repr__(self): + pre = ( + ", prereleases={0!r}".format(self.prereleases) + if self._prereleases is not None + else "" + ) + + return "<SpecifierSet({0!r}{1})>".format(str(self), pre) + + def __str__(self): + return ",".join(sorted(str(s) for s in self._specs)) + + def __hash__(self): + return hash(self._specs) + + def __and__(self, other): + if isinstance(other, string_types): + other = SpecifierSet(other) + elif not isinstance(other, SpecifierSet): + return NotImplemented + + specifier = SpecifierSet() + specifier._specs = frozenset(self._specs | other._specs) + + if self._prereleases is None and other._prereleases is not None: + specifier._prereleases = other._prereleases + elif self._prereleases is not None and other._prereleases is None: + specifier._prereleases = self._prereleases + elif self._prereleases == other._prereleases: + specifier._prereleases = self._prereleases + else: + raise ValueError( + "Cannot combine SpecifierSets with True and False prerelease " + "overrides." + ) + + return specifier + + def __eq__(self, other): + if isinstance(other, string_types): + other = SpecifierSet(other) + elif isinstance(other, _IndividualSpecifier): + other = SpecifierSet(str(other)) + elif not isinstance(other, SpecifierSet): + return NotImplemented + + return self._specs == other._specs + + def __ne__(self, other): + if isinstance(other, string_types): + other = SpecifierSet(other) + elif isinstance(other, _IndividualSpecifier): + other = SpecifierSet(str(other)) + elif not isinstance(other, SpecifierSet): + return NotImplemented + + return self._specs != other._specs + + def __len__(self): + return len(self._specs) + + def __iter__(self): + return iter(self._specs) + + @property + def prereleases(self): + # If we have been given an explicit prerelease modifier, then we'll + # pass that through here. + if self._prereleases is not None: + return self._prereleases + + # If we don't have any specifiers, and we don't have a forced value, + # then we'll just return None since we don't know if this should have + # pre-releases or not. + if not self._specs: + return None + + # Otherwise we'll see if any of the given specifiers accept + # prereleases, if any of them do we'll return True, otherwise False. + return any(s.prereleases for s in self._specs) + + @prereleases.setter + def prereleases(self, value): + self._prereleases = value + + def __contains__(self, item): + return self.contains(item) + + def contains(self, item, prereleases=None): + # Ensure that our item is a Version or LegacyVersion instance. + if not isinstance(item, (LegacyVersion, Version)): + item = parse(item) + + # Determine if we're forcing a prerelease or not, if we're not forcing + # one for this particular filter call, then we'll use whatever the + # SpecifierSet thinks for whether or not we should support prereleases. + if prereleases is None: + prereleases = self.prereleases + + # We can determine if we're going to allow pre-releases by looking to + # see if any of the underlying items supports them. If none of them do + # and this item is a pre-release then we do not allow it and we can + # short circuit that here. + # Note: This means that 1.0.dev1 would not be contained in something + # like >=1.0.devabc however it would be in >=1.0.debabc,>0.0.dev0 + if not prereleases and item.is_prerelease: + return False + + # We simply dispatch to the underlying specs here to make sure that the + # given version is contained within all of them. + # Note: This use of all() here means that an empty set of specifiers + # will always return True, this is an explicit design decision. + return all( + s.contains(item, prereleases=prereleases) + for s in self._specs + ) + + def filter(self, iterable, prereleases=None): + # Determine if we're forcing a prerelease or not, if we're not forcing + # one for this particular filter call, then we'll use whatever the + # SpecifierSet thinks for whether or not we should support prereleases. + if prereleases is None: + prereleases = self.prereleases + + # If we have any specifiers, then we want to wrap our iterable in the + # filter method for each one, this will act as a logical AND amongst + # each specifier. + if self._specs: + for spec in self._specs: + iterable = spec.filter(iterable, prereleases=bool(prereleases)) + return iterable + # If we do not have any specifiers, then we need to have a rough filter + # which will filter out any pre-releases, unless there are no final + # releases, and which will filter out LegacyVersion in general. + else: + filtered = [] + found_prereleases = [] + + for item in iterable: + # Ensure that we some kind of Version class for this item. + if not isinstance(item, (LegacyVersion, Version)): + parsed_version = parse(item) + else: + parsed_version = item + + # Filter out any item which is parsed as a LegacyVersion + if isinstance(parsed_version, LegacyVersion): + continue + + # Store any item which is a pre-release for later unless we've + # already found a final version or we are accepting prereleases + if parsed_version.is_prerelease and not prereleases: + if not filtered: + found_prereleases.append(item) + else: + filtered.append(item) + + # If we've found no items except for pre-releases, then we'll go + # ahead and use the pre-releases + if not filtered and found_prereleases and prereleases is None: + return found_prereleases + + return filtered diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/utils.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/utils.py new file mode 100644 index 0000000..942387c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/utils.py @@ -0,0 +1,14 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import re + + +_canonicalize_regex = re.compile(r"[-_.]+") + + +def canonicalize_name(name): + # This is taken from PEP 503. + return _canonicalize_regex.sub("-", name).lower() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/version.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/version.py new file mode 100644 index 0000000..83b5ee8 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/version.py @@ -0,0 +1,393 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import collections +import itertools +import re + +from ._structures import Infinity + + +__all__ = [ + "parse", "Version", "LegacyVersion", "InvalidVersion", "VERSION_PATTERN" +] + + +_Version = collections.namedtuple( + "_Version", + ["epoch", "release", "dev", "pre", "post", "local"], +) + + +def parse(version): + """ + Parse the given version string and return either a :class:`Version` object + or a :class:`LegacyVersion` object depending on if the given version is + a valid PEP 440 version or a legacy version. + """ + try: + return Version(version) + except InvalidVersion: + return LegacyVersion(version) + + +class InvalidVersion(ValueError): + """ + An invalid version was found, users should refer to PEP 440. + """ + + +class _BaseVersion(object): + + def __hash__(self): + return hash(self._key) + + def __lt__(self, other): + return self._compare(other, lambda s, o: s < o) + + def __le__(self, other): + return self._compare(other, lambda s, o: s <= o) + + def __eq__(self, other): + return self._compare(other, lambda s, o: s == o) + + def __ge__(self, other): + return self._compare(other, lambda s, o: s >= o) + + def __gt__(self, other): + return self._compare(other, lambda s, o: s > o) + + def __ne__(self, other): + return self._compare(other, lambda s, o: s != o) + + def _compare(self, other, method): + if not isinstance(other, _BaseVersion): + return NotImplemented + + return method(self._key, other._key) + + +class LegacyVersion(_BaseVersion): + + def __init__(self, version): + self._version = str(version) + self._key = _legacy_cmpkey(self._version) + + def __str__(self): + return self._version + + def __repr__(self): + return "<LegacyVersion({0})>".format(repr(str(self))) + + @property + def public(self): + return self._version + + @property + def base_version(self): + return self._version + + @property + def local(self): + return None + + @property + def is_prerelease(self): + return False + + @property + def is_postrelease(self): + return False + + +_legacy_version_component_re = re.compile( + r"(\d+ | [a-z]+ | \.| -)", re.VERBOSE, +) + +_legacy_version_replacement_map = { + "pre": "c", "preview": "c", "-": "final-", "rc": "c", "dev": "@", +} + + +def _parse_version_parts(s): + for part in _legacy_version_component_re.split(s): + part = _legacy_version_replacement_map.get(part, part) + + if not part or part == ".": + continue + + if part[:1] in "0123456789": + # pad for numeric comparison + yield part.zfill(8) + else: + yield "*" + part + + # ensure that alpha/beta/candidate are before final + yield "*final" + + +def _legacy_cmpkey(version): + # We hardcode an epoch of -1 here. A PEP 440 version can only have a epoch + # greater than or equal to 0. This will effectively put the LegacyVersion, + # which uses the defacto standard originally implemented by setuptools, + # as before all PEP 440 versions. + epoch = -1 + + # This scheme is taken from pkg_resources.parse_version setuptools prior to + # it's adoption of the packaging library. + parts = [] + for part in _parse_version_parts(version.lower()): + if part.startswith("*"): + # remove "-" before a prerelease tag + if part < "*final": + while parts and parts[-1] == "*final-": + parts.pop() + + # remove trailing zeros from each series of numeric parts + while parts and parts[-1] == "00000000": + parts.pop() + + parts.append(part) + parts = tuple(parts) + + return epoch, parts + +# Deliberately not anchored to the start and end of the string, to make it +# easier for 3rd party code to reuse +VERSION_PATTERN = r""" + v? + (?: + (?:(?P<epoch>[0-9]+)!)? # epoch + (?P<release>[0-9]+(?:\.[0-9]+)*) # release segment + (?P<pre> # pre-release + [-_\.]? + (?P<pre_l>(a|b|c|rc|alpha|beta|pre|preview)) + [-_\.]? + (?P<pre_n>[0-9]+)? + )? + (?P<post> # post release + (?:-(?P<post_n1>[0-9]+)) + | + (?: + [-_\.]? + (?P<post_l>post|rev|r) + [-_\.]? + (?P<post_n2>[0-9]+)? + ) + )? + (?P<dev> # dev release + [-_\.]? + (?P<dev_l>dev) + [-_\.]? + (?P<dev_n>[0-9]+)? + )? + ) + (?:\+(?P<local>[a-z0-9]+(?:[-_\.][a-z0-9]+)*))? # local version +""" + + +class Version(_BaseVersion): + + _regex = re.compile( + r"^\s*" + VERSION_PATTERN + r"\s*$", + re.VERBOSE | re.IGNORECASE, + ) + + def __init__(self, version): + # Validate the version and parse it into pieces + match = self._regex.search(version) + if not match: + raise InvalidVersion("Invalid version: '{0}'".format(version)) + + # Store the parsed out pieces of the version + self._version = _Version( + epoch=int(match.group("epoch")) if match.group("epoch") else 0, + release=tuple(int(i) for i in match.group("release").split(".")), + pre=_parse_letter_version( + match.group("pre_l"), + match.group("pre_n"), + ), + post=_parse_letter_version( + match.group("post_l"), + match.group("post_n1") or match.group("post_n2"), + ), + dev=_parse_letter_version( + match.group("dev_l"), + match.group("dev_n"), + ), + local=_parse_local_version(match.group("local")), + ) + + # Generate a key which will be used for sorting + self._key = _cmpkey( + self._version.epoch, + self._version.release, + self._version.pre, + self._version.post, + self._version.dev, + self._version.local, + ) + + def __repr__(self): + return "<Version({0})>".format(repr(str(self))) + + def __str__(self): + parts = [] + + # Epoch + if self._version.epoch != 0: + parts.append("{0}!".format(self._version.epoch)) + + # Release segment + parts.append(".".join(str(x) for x in self._version.release)) + + # Pre-release + if self._version.pre is not None: + parts.append("".join(str(x) for x in self._version.pre)) + + # Post-release + if self._version.post is not None: + parts.append(".post{0}".format(self._version.post[1])) + + # Development release + if self._version.dev is not None: + parts.append(".dev{0}".format(self._version.dev[1])) + + # Local version segment + if self._version.local is not None: + parts.append( + "+{0}".format(".".join(str(x) for x in self._version.local)) + ) + + return "".join(parts) + + @property + def public(self): + return str(self).split("+", 1)[0] + + @property + def base_version(self): + parts = [] + + # Epoch + if self._version.epoch != 0: + parts.append("{0}!".format(self._version.epoch)) + + # Release segment + parts.append(".".join(str(x) for x in self._version.release)) + + return "".join(parts) + + @property + def local(self): + version_string = str(self) + if "+" in version_string: + return version_string.split("+", 1)[1] + + @property + def is_prerelease(self): + return bool(self._version.dev or self._version.pre) + + @property + def is_postrelease(self): + return bool(self._version.post) + + +def _parse_letter_version(letter, number): + if letter: + # We consider there to be an implicit 0 in a pre-release if there is + # not a numeral associated with it. + if number is None: + number = 0 + + # We normalize any letters to their lower case form + letter = letter.lower() + + # We consider some words to be alternate spellings of other words and + # in those cases we want to normalize the spellings to our preferred + # spelling. + if letter == "alpha": + letter = "a" + elif letter == "beta": + letter = "b" + elif letter in ["c", "pre", "preview"]: + letter = "rc" + elif letter in ["rev", "r"]: + letter = "post" + + return letter, int(number) + if not letter and number: + # We assume if we are given a number, but we are not given a letter + # then this is using the implicit post release syntax (e.g. 1.0-1) + letter = "post" + + return letter, int(number) + + +_local_version_seperators = re.compile(r"[\._-]") + + +def _parse_local_version(local): + """ + Takes a string like abc.1.twelve and turns it into ("abc", 1, "twelve"). + """ + if local is not None: + return tuple( + part.lower() if not part.isdigit() else int(part) + for part in _local_version_seperators.split(local) + ) + + +def _cmpkey(epoch, release, pre, post, dev, local): + # When we compare a release version, we want to compare it with all of the + # trailing zeros removed. So we'll use a reverse the list, drop all the now + # leading zeros until we come to something non zero, then take the rest + # re-reverse it back into the correct order and make it a tuple and use + # that for our sorting key. + release = tuple( + reversed(list( + itertools.dropwhile( + lambda x: x == 0, + reversed(release), + ) + )) + ) + + # We need to "trick" the sorting algorithm to put 1.0.dev0 before 1.0a0. + # We'll do this by abusing the pre segment, but we _only_ want to do this + # if there is not a pre or a post segment. If we have one of those then + # the normal sorting rules will handle this case correctly. + if pre is None and post is None and dev is not None: + pre = -Infinity + # Versions without a pre-release (except as noted above) should sort after + # those with one. + elif pre is None: + pre = Infinity + + # Versions without a post segment should sort before those with one. + if post is None: + post = -Infinity + + # Versions without a development segment should sort after those with one. + if dev is None: + dev = Infinity + + if local is None: + # Versions without a local segment should sort before those with one. + local = -Infinity + else: + # Versions with a local segment need that segment parsed to implement + # the sorting rules in PEP440. + # - Alpha numeric segments sort before numeric segments + # - Alpha numeric segments sort lexicographically + # - Numeric segments sort numerically + # - Shorter versions sort before longer versions when the prefixes + # match exactly + local = tuple( + (i, "") if isinstance(i, int) else (-Infinity, i) + for i in local + ) + + return epoch, release, pre, post, dev, local diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/pyparsing.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/pyparsing.py new file mode 100644 index 0000000..cf75e1e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/pyparsing.py @@ -0,0 +1,5742 @@ +# module pyparsing.py +# +# Copyright (c) 2003-2018 Paul T. McGuire +# +# Permission is hereby granted, free of charge, to any person obtaining +# a copy of this software and associated documentation files (the +# "Software"), to deal in the Software without restriction, including +# without limitation the rights to use, copy, modify, merge, publish, +# distribute, sublicense, and/or sell copies of the Software, and to +# permit persons to whom the Software is furnished to do so, subject to +# the following conditions: +# +# The above copyright notice and this permission notice shall be +# included in all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +# + +__doc__ = \ +""" +pyparsing module - Classes and methods to define and execute parsing grammars +============================================================================= + +The pyparsing module is an alternative approach to creating and executing simple grammars, +vs. the traditional lex/yacc approach, or the use of regular expressions. With pyparsing, you +don't need to learn a new syntax for defining grammars or matching expressions - the parsing module +provides a library of classes that you use to construct the grammar directly in Python. + +Here is a program to parse "Hello, World!" (or any greeting of the form +C{"<salutation>, <addressee>!"}), built up using L{Word}, L{Literal}, and L{And} elements +(L{'+'<ParserElement.__add__>} operator gives L{And} expressions, strings are auto-converted to +L{Literal} expressions):: + + from pyparsing import Word, alphas + + # define grammar of a greeting + greet = Word(alphas) + "," + Word(alphas) + "!" + + hello = "Hello, World!" + print (hello, "->", greet.parseString(hello)) + +The program outputs the following:: + + Hello, World! -> ['Hello', ',', 'World', '!'] + +The Python representation of the grammar is quite readable, owing to the self-explanatory +class names, and the use of '+', '|' and '^' operators. + +The L{ParseResults} object returned from L{ParserElement.parseString<ParserElement.parseString>} can be accessed as a nested list, a dictionary, or an +object with named attributes. + +The pyparsing module handles some of the problems that are typically vexing when writing text parsers: + - extra or missing whitespace (the above program will also handle "Hello,World!", "Hello , World !", etc.) + - quoted strings + - embedded comments + + +Getting Started - +----------------- +Visit the classes L{ParserElement} and L{ParseResults} to see the base classes that most other pyparsing +classes inherit from. Use the docstrings for examples of how to: + - construct literal match expressions from L{Literal} and L{CaselessLiteral} classes + - construct character word-group expressions using the L{Word} class + - see how to create repetitive expressions using L{ZeroOrMore} and L{OneOrMore} classes + - use L{'+'<And>}, L{'|'<MatchFirst>}, L{'^'<Or>}, and L{'&'<Each>} operators to combine simple expressions into more complex ones + - associate names with your parsed results using L{ParserElement.setResultsName} + - find some helpful expression short-cuts like L{delimitedList} and L{oneOf} + - find more useful common expressions in the L{pyparsing_common} namespace class +""" + +__version__ = "2.2.1" +__versionTime__ = "18 Sep 2018 00:49 UTC" +__author__ = "Paul McGuire <ptmcg@users.sourceforge.net>" + +import string +from weakref import ref as wkref +import copy +import sys +import warnings +import re +import sre_constants +import collections +import pprint +import traceback +import types +from datetime import datetime + +try: + from _thread import RLock +except ImportError: + from threading import RLock + +try: + # Python 3 + from collections.abc import Iterable + from collections.abc import MutableMapping +except ImportError: + # Python 2.7 + from collections import Iterable + from collections import MutableMapping + +try: + from collections import OrderedDict as _OrderedDict +except ImportError: + try: + from ordereddict import OrderedDict as _OrderedDict + except ImportError: + _OrderedDict = None + +#~ sys.stderr.write( "testing pyparsing module, version %s, %s\n" % (__version__,__versionTime__ ) ) + +__all__ = [ +'And', 'CaselessKeyword', 'CaselessLiteral', 'CharsNotIn', 'Combine', 'Dict', 'Each', 'Empty', +'FollowedBy', 'Forward', 'GoToColumn', 'Group', 'Keyword', 'LineEnd', 'LineStart', 'Literal', +'MatchFirst', 'NoMatch', 'NotAny', 'OneOrMore', 'OnlyOnce', 'Optional', 'Or', +'ParseBaseException', 'ParseElementEnhance', 'ParseException', 'ParseExpression', 'ParseFatalException', +'ParseResults', 'ParseSyntaxException', 'ParserElement', 'QuotedString', 'RecursiveGrammarException', +'Regex', 'SkipTo', 'StringEnd', 'StringStart', 'Suppress', 'Token', 'TokenConverter', +'White', 'Word', 'WordEnd', 'WordStart', 'ZeroOrMore', +'alphanums', 'alphas', 'alphas8bit', 'anyCloseTag', 'anyOpenTag', 'cStyleComment', 'col', +'commaSeparatedList', 'commonHTMLEntity', 'countedArray', 'cppStyleComment', 'dblQuotedString', +'dblSlashComment', 'delimitedList', 'dictOf', 'downcaseTokens', 'empty', 'hexnums', +'htmlComment', 'javaStyleComment', 'line', 'lineEnd', 'lineStart', 'lineno', +'makeHTMLTags', 'makeXMLTags', 'matchOnlyAtCol', 'matchPreviousExpr', 'matchPreviousLiteral', +'nestedExpr', 'nullDebugAction', 'nums', 'oneOf', 'opAssoc', 'operatorPrecedence', 'printables', +'punc8bit', 'pythonStyleComment', 'quotedString', 'removeQuotes', 'replaceHTMLEntity', +'replaceWith', 'restOfLine', 'sglQuotedString', 'srange', 'stringEnd', +'stringStart', 'traceParseAction', 'unicodeString', 'upcaseTokens', 'withAttribute', +'indentedBlock', 'originalTextFor', 'ungroup', 'infixNotation','locatedExpr', 'withClass', +'CloseMatch', 'tokenMap', 'pyparsing_common', +] + +system_version = tuple(sys.version_info)[:3] +PY_3 = system_version[0] == 3 +if PY_3: + _MAX_INT = sys.maxsize + basestring = str + unichr = chr + _ustr = str + + # build list of single arg builtins, that can be used as parse actions + singleArgBuiltins = [sum, len, sorted, reversed, list, tuple, set, any, all, min, max] + +else: + _MAX_INT = sys.maxint + range = xrange + + def _ustr(obj): + """Drop-in replacement for str(obj) that tries to be Unicode friendly. It first tries + str(obj). If that fails with a UnicodeEncodeError, then it tries unicode(obj). It + then < returns the unicode object | encodes it with the default encoding | ... >. + """ + if isinstance(obj,unicode): + return obj + + try: + # If this works, then _ustr(obj) has the same behaviour as str(obj), so + # it won't break any existing code. + return str(obj) + + except UnicodeEncodeError: + # Else encode it + ret = unicode(obj).encode(sys.getdefaultencoding(), 'xmlcharrefreplace') + xmlcharref = Regex(r'&#\d+;') + xmlcharref.setParseAction(lambda t: '\\u' + hex(int(t[0][2:-1]))[2:]) + return xmlcharref.transformString(ret) + + # build list of single arg builtins, tolerant of Python version, that can be used as parse actions + singleArgBuiltins = [] + import __builtin__ + for fname in "sum len sorted reversed list tuple set any all min max".split(): + try: + singleArgBuiltins.append(getattr(__builtin__,fname)) + except AttributeError: + continue + +_generatorType = type((y for y in range(1))) + +def _xml_escape(data): + """Escape &, <, >, ", ', etc. in a string of data.""" + + # ampersand must be replaced first + from_symbols = '&><"\'' + to_symbols = ('&'+s+';' for s in "amp gt lt quot apos".split()) + for from_,to_ in zip(from_symbols, to_symbols): + data = data.replace(from_, to_) + return data + +class _Constants(object): + pass + +alphas = string.ascii_uppercase + string.ascii_lowercase +nums = "0123456789" +hexnums = nums + "ABCDEFabcdef" +alphanums = alphas + nums +_bslash = chr(92) +printables = "".join(c for c in string.printable if c not in string.whitespace) + +class ParseBaseException(Exception): + """base exception class for all parsing runtime exceptions""" + # Performance tuning: we construct a *lot* of these, so keep this + # constructor as small and fast as possible + def __init__( self, pstr, loc=0, msg=None, elem=None ): + self.loc = loc + if msg is None: + self.msg = pstr + self.pstr = "" + else: + self.msg = msg + self.pstr = pstr + self.parserElement = elem + self.args = (pstr, loc, msg) + + @classmethod + def _from_exception(cls, pe): + """ + internal factory method to simplify creating one type of ParseException + from another - avoids having __init__ signature conflicts among subclasses + """ + return cls(pe.pstr, pe.loc, pe.msg, pe.parserElement) + + def __getattr__( self, aname ): + """supported attributes by name are: + - lineno - returns the line number of the exception text + - col - returns the column number of the exception text + - line - returns the line containing the exception text + """ + if( aname == "lineno" ): + return lineno( self.loc, self.pstr ) + elif( aname in ("col", "column") ): + return col( self.loc, self.pstr ) + elif( aname == "line" ): + return line( self.loc, self.pstr ) + else: + raise AttributeError(aname) + + def __str__( self ): + return "%s (at char %d), (line:%d, col:%d)" % \ + ( self.msg, self.loc, self.lineno, self.column ) + def __repr__( self ): + return _ustr(self) + def markInputline( self, markerString = ">!<" ): + """Extracts the exception line from the input string, and marks + the location of the exception with a special symbol. + """ + line_str = self.line + line_column = self.column - 1 + if markerString: + line_str = "".join((line_str[:line_column], + markerString, line_str[line_column:])) + return line_str.strip() + def __dir__(self): + return "lineno col line".split() + dir(type(self)) + +class ParseException(ParseBaseException): + """ + Exception thrown when parse expressions don't match class; + supported attributes by name are: + - lineno - returns the line number of the exception text + - col - returns the column number of the exception text + - line - returns the line containing the exception text + + Example:: + try: + Word(nums).setName("integer").parseString("ABC") + except ParseException as pe: + print(pe) + print("column: {}".format(pe.col)) + + prints:: + Expected integer (at char 0), (line:1, col:1) + column: 1 + """ + pass + +class ParseFatalException(ParseBaseException): + """user-throwable exception thrown when inconsistent parse content + is found; stops all parsing immediately""" + pass + +class ParseSyntaxException(ParseFatalException): + """just like L{ParseFatalException}, but thrown internally when an + L{ErrorStop<And._ErrorStop>} ('-' operator) indicates that parsing is to stop + immediately because an unbacktrackable syntax error has been found""" + pass + +#~ class ReparseException(ParseBaseException): + #~ """Experimental class - parse actions can raise this exception to cause + #~ pyparsing to reparse the input string: + #~ - with a modified input string, and/or + #~ - with a modified start location + #~ Set the values of the ReparseException in the constructor, and raise the + #~ exception in a parse action to cause pyparsing to use the new string/location. + #~ Setting the values as None causes no change to be made. + #~ """ + #~ def __init_( self, newstring, restartLoc ): + #~ self.newParseText = newstring + #~ self.reparseLoc = restartLoc + +class RecursiveGrammarException(Exception): + """exception thrown by L{ParserElement.validate} if the grammar could be improperly recursive""" + def __init__( self, parseElementList ): + self.parseElementTrace = parseElementList + + def __str__( self ): + return "RecursiveGrammarException: %s" % self.parseElementTrace + +class _ParseResultsWithOffset(object): + def __init__(self,p1,p2): + self.tup = (p1,p2) + def __getitem__(self,i): + return self.tup[i] + def __repr__(self): + return repr(self.tup[0]) + def setOffset(self,i): + self.tup = (self.tup[0],i) + +class ParseResults(object): + """ + Structured parse results, to provide multiple means of access to the parsed data: + - as a list (C{len(results)}) + - by list index (C{results[0], results[1]}, etc.) + - by attribute (C{results.<resultsName>} - see L{ParserElement.setResultsName}) + + Example:: + integer = Word(nums) + date_str = (integer.setResultsName("year") + '/' + + integer.setResultsName("month") + '/' + + integer.setResultsName("day")) + # equivalent form: + # date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + # parseString returns a ParseResults object + result = date_str.parseString("1999/12/31") + + def test(s, fn=repr): + print("%s -> %s" % (s, fn(eval(s)))) + test("list(result)") + test("result[0]") + test("result['month']") + test("result.day") + test("'month' in result") + test("'minutes' in result") + test("result.dump()", str) + prints:: + list(result) -> ['1999', '/', '12', '/', '31'] + result[0] -> '1999' + result['month'] -> '12' + result.day -> '31' + 'month' in result -> True + 'minutes' in result -> False + result.dump() -> ['1999', '/', '12', '/', '31'] + - day: 31 + - month: 12 + - year: 1999 + """ + def __new__(cls, toklist=None, name=None, asList=True, modal=True ): + if isinstance(toklist, cls): + return toklist + retobj = object.__new__(cls) + retobj.__doinit = True + return retobj + + # Performance tuning: we construct a *lot* of these, so keep this + # constructor as small and fast as possible + def __init__( self, toklist=None, name=None, asList=True, modal=True, isinstance=isinstance ): + if self.__doinit: + self.__doinit = False + self.__name = None + self.__parent = None + self.__accumNames = {} + self.__asList = asList + self.__modal = modal + if toklist is None: + toklist = [] + if isinstance(toklist, list): + self.__toklist = toklist[:] + elif isinstance(toklist, _generatorType): + self.__toklist = list(toklist) + else: + self.__toklist = [toklist] + self.__tokdict = dict() + + if name is not None and name: + if not modal: + self.__accumNames[name] = 0 + if isinstance(name,int): + name = _ustr(name) # will always return a str, but use _ustr for consistency + self.__name = name + if not (isinstance(toklist, (type(None), basestring, list)) and toklist in (None,'',[])): + if isinstance(toklist,basestring): + toklist = [ toklist ] + if asList: + if isinstance(toklist,ParseResults): + self[name] = _ParseResultsWithOffset(toklist.copy(),0) + else: + self[name] = _ParseResultsWithOffset(ParseResults(toklist[0]),0) + self[name].__name = name + else: + try: + self[name] = toklist[0] + except (KeyError,TypeError,IndexError): + self[name] = toklist + + def __getitem__( self, i ): + if isinstance( i, (int,slice) ): + return self.__toklist[i] + else: + if i not in self.__accumNames: + return self.__tokdict[i][-1][0] + else: + return ParseResults([ v[0] for v in self.__tokdict[i] ]) + + def __setitem__( self, k, v, isinstance=isinstance ): + if isinstance(v,_ParseResultsWithOffset): + self.__tokdict[k] = self.__tokdict.get(k,list()) + [v] + sub = v[0] + elif isinstance(k,(int,slice)): + self.__toklist[k] = v + sub = v + else: + self.__tokdict[k] = self.__tokdict.get(k,list()) + [_ParseResultsWithOffset(v,0)] + sub = v + if isinstance(sub,ParseResults): + sub.__parent = wkref(self) + + def __delitem__( self, i ): + if isinstance(i,(int,slice)): + mylen = len( self.__toklist ) + del self.__toklist[i] + + # convert int to slice + if isinstance(i, int): + if i < 0: + i += mylen + i = slice(i, i+1) + # get removed indices + removed = list(range(*i.indices(mylen))) + removed.reverse() + # fixup indices in token dictionary + for name,occurrences in self.__tokdict.items(): + for j in removed: + for k, (value, position) in enumerate(occurrences): + occurrences[k] = _ParseResultsWithOffset(value, position - (position > j)) + else: + del self.__tokdict[i] + + def __contains__( self, k ): + return k in self.__tokdict + + def __len__( self ): return len( self.__toklist ) + def __bool__(self): return ( not not self.__toklist ) + __nonzero__ = __bool__ + def __iter__( self ): return iter( self.__toklist ) + def __reversed__( self ): return iter( self.__toklist[::-1] ) + def _iterkeys( self ): + if hasattr(self.__tokdict, "iterkeys"): + return self.__tokdict.iterkeys() + else: + return iter(self.__tokdict) + + def _itervalues( self ): + return (self[k] for k in self._iterkeys()) + + def _iteritems( self ): + return ((k, self[k]) for k in self._iterkeys()) + + if PY_3: + keys = _iterkeys + """Returns an iterator of all named result keys (Python 3.x only).""" + + values = _itervalues + """Returns an iterator of all named result values (Python 3.x only).""" + + items = _iteritems + """Returns an iterator of all named result key-value tuples (Python 3.x only).""" + + else: + iterkeys = _iterkeys + """Returns an iterator of all named result keys (Python 2.x only).""" + + itervalues = _itervalues + """Returns an iterator of all named result values (Python 2.x only).""" + + iteritems = _iteritems + """Returns an iterator of all named result key-value tuples (Python 2.x only).""" + + def keys( self ): + """Returns all named result keys (as a list in Python 2.x, as an iterator in Python 3.x).""" + return list(self.iterkeys()) + + def values( self ): + """Returns all named result values (as a list in Python 2.x, as an iterator in Python 3.x).""" + return list(self.itervalues()) + + def items( self ): + """Returns all named result key-values (as a list of tuples in Python 2.x, as an iterator in Python 3.x).""" + return list(self.iteritems()) + + def haskeys( self ): + """Since keys() returns an iterator, this method is helpful in bypassing + code that looks for the existence of any defined results names.""" + return bool(self.__tokdict) + + def pop( self, *args, **kwargs): + """ + Removes and returns item at specified index (default=C{last}). + Supports both C{list} and C{dict} semantics for C{pop()}. If passed no + argument or an integer argument, it will use C{list} semantics + and pop tokens from the list of parsed tokens. If passed a + non-integer argument (most likely a string), it will use C{dict} + semantics and pop the corresponding value from any defined + results names. A second default return value argument is + supported, just as in C{dict.pop()}. + + Example:: + def remove_first(tokens): + tokens.pop(0) + print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321'] + print(OneOrMore(Word(nums)).addParseAction(remove_first).parseString("0 123 321")) # -> ['123', '321'] + + label = Word(alphas) + patt = label("LABEL") + OneOrMore(Word(nums)) + print(patt.parseString("AAB 123 321").dump()) + + # Use pop() in a parse action to remove named result (note that corresponding value is not + # removed from list form of results) + def remove_LABEL(tokens): + tokens.pop("LABEL") + return tokens + patt.addParseAction(remove_LABEL) + print(patt.parseString("AAB 123 321").dump()) + prints:: + ['AAB', '123', '321'] + - LABEL: AAB + + ['AAB', '123', '321'] + """ + if not args: + args = [-1] + for k,v in kwargs.items(): + if k == 'default': + args = (args[0], v) + else: + raise TypeError("pop() got an unexpected keyword argument '%s'" % k) + if (isinstance(args[0], int) or + len(args) == 1 or + args[0] in self): + index = args[0] + ret = self[index] + del self[index] + return ret + else: + defaultvalue = args[1] + return defaultvalue + + def get(self, key, defaultValue=None): + """ + Returns named result matching the given key, or if there is no + such name, then returns the given C{defaultValue} or C{None} if no + C{defaultValue} is specified. + + Similar to C{dict.get()}. + + Example:: + integer = Word(nums) + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + result = date_str.parseString("1999/12/31") + print(result.get("year")) # -> '1999' + print(result.get("hour", "not specified")) # -> 'not specified' + print(result.get("hour")) # -> None + """ + if key in self: + return self[key] + else: + return defaultValue + + def insert( self, index, insStr ): + """ + Inserts new element at location index in the list of parsed tokens. + + Similar to C{list.insert()}. + + Example:: + print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321'] + + # use a parse action to insert the parse location in the front of the parsed results + def insert_locn(locn, tokens): + tokens.insert(0, locn) + print(OneOrMore(Word(nums)).addParseAction(insert_locn).parseString("0 123 321")) # -> [0, '0', '123', '321'] + """ + self.__toklist.insert(index, insStr) + # fixup indices in token dictionary + for name,occurrences in self.__tokdict.items(): + for k, (value, position) in enumerate(occurrences): + occurrences[k] = _ParseResultsWithOffset(value, position + (position > index)) + + def append( self, item ): + """ + Add single element to end of ParseResults list of elements. + + Example:: + print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321'] + + # use a parse action to compute the sum of the parsed integers, and add it to the end + def append_sum(tokens): + tokens.append(sum(map(int, tokens))) + print(OneOrMore(Word(nums)).addParseAction(append_sum).parseString("0 123 321")) # -> ['0', '123', '321', 444] + """ + self.__toklist.append(item) + + def extend( self, itemseq ): + """ + Add sequence of elements to end of ParseResults list of elements. + + Example:: + patt = OneOrMore(Word(alphas)) + + # use a parse action to append the reverse of the matched strings, to make a palindrome + def make_palindrome(tokens): + tokens.extend(reversed([t[::-1] for t in tokens])) + return ''.join(tokens) + print(patt.addParseAction(make_palindrome).parseString("lskdj sdlkjf lksd")) # -> 'lskdjsdlkjflksddsklfjkldsjdksl' + """ + if isinstance(itemseq, ParseResults): + self += itemseq + else: + self.__toklist.extend(itemseq) + + def clear( self ): + """ + Clear all elements and results names. + """ + del self.__toklist[:] + self.__tokdict.clear() + + def __getattr__( self, name ): + try: + return self[name] + except KeyError: + return "" + + if name in self.__tokdict: + if name not in self.__accumNames: + return self.__tokdict[name][-1][0] + else: + return ParseResults([ v[0] for v in self.__tokdict[name] ]) + else: + return "" + + def __add__( self, other ): + ret = self.copy() + ret += other + return ret + + def __iadd__( self, other ): + if other.__tokdict: + offset = len(self.__toklist) + addoffset = lambda a: offset if a<0 else a+offset + otheritems = other.__tokdict.items() + otherdictitems = [(k, _ParseResultsWithOffset(v[0],addoffset(v[1])) ) + for (k,vlist) in otheritems for v in vlist] + for k,v in otherdictitems: + self[k] = v + if isinstance(v[0],ParseResults): + v[0].__parent = wkref(self) + + self.__toklist += other.__toklist + self.__accumNames.update( other.__accumNames ) + return self + + def __radd__(self, other): + if isinstance(other,int) and other == 0: + # useful for merging many ParseResults using sum() builtin + return self.copy() + else: + # this may raise a TypeError - so be it + return other + self + + def __repr__( self ): + return "(%s, %s)" % ( repr( self.__toklist ), repr( self.__tokdict ) ) + + def __str__( self ): + return '[' + ', '.join(_ustr(i) if isinstance(i, ParseResults) else repr(i) for i in self.__toklist) + ']' + + def _asStringList( self, sep='' ): + out = [] + for item in self.__toklist: + if out and sep: + out.append(sep) + if isinstance( item, ParseResults ): + out += item._asStringList() + else: + out.append( _ustr(item) ) + return out + + def asList( self ): + """ + Returns the parse results as a nested list of matching tokens, all converted to strings. + + Example:: + patt = OneOrMore(Word(alphas)) + result = patt.parseString("sldkj lsdkj sldkj") + # even though the result prints in string-like form, it is actually a pyparsing ParseResults + print(type(result), result) # -> <class 'pyparsing.ParseResults'> ['sldkj', 'lsdkj', 'sldkj'] + + # Use asList() to create an actual list + result_list = result.asList() + print(type(result_list), result_list) # -> <class 'list'> ['sldkj', 'lsdkj', 'sldkj'] + """ + return [res.asList() if isinstance(res,ParseResults) else res for res in self.__toklist] + + def asDict( self ): + """ + Returns the named parse results as a nested dictionary. + + Example:: + integer = Word(nums) + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + result = date_str.parseString('12/31/1999') + print(type(result), repr(result)) # -> <class 'pyparsing.ParseResults'> (['12', '/', '31', '/', '1999'], {'day': [('1999', 4)], 'year': [('12', 0)], 'month': [('31', 2)]}) + + result_dict = result.asDict() + print(type(result_dict), repr(result_dict)) # -> <class 'dict'> {'day': '1999', 'year': '12', 'month': '31'} + + # even though a ParseResults supports dict-like access, sometime you just need to have a dict + import json + print(json.dumps(result)) # -> Exception: TypeError: ... is not JSON serializable + print(json.dumps(result.asDict())) # -> {"month": "31", "day": "1999", "year": "12"} + """ + if PY_3: + item_fn = self.items + else: + item_fn = self.iteritems + + def toItem(obj): + if isinstance(obj, ParseResults): + if obj.haskeys(): + return obj.asDict() + else: + return [toItem(v) for v in obj] + else: + return obj + + return dict((k,toItem(v)) for k,v in item_fn()) + + def copy( self ): + """ + Returns a new copy of a C{ParseResults} object. + """ + ret = ParseResults( self.__toklist ) + ret.__tokdict = self.__tokdict.copy() + ret.__parent = self.__parent + ret.__accumNames.update( self.__accumNames ) + ret.__name = self.__name + return ret + + def asXML( self, doctag=None, namedItemsOnly=False, indent="", formatted=True ): + """ + (Deprecated) Returns the parse results as XML. Tags are created for tokens and lists that have defined results names. + """ + nl = "\n" + out = [] + namedItems = dict((v[1],k) for (k,vlist) in self.__tokdict.items() + for v in vlist) + nextLevelIndent = indent + " " + + # collapse out indents if formatting is not desired + if not formatted: + indent = "" + nextLevelIndent = "" + nl = "" + + selfTag = None + if doctag is not None: + selfTag = doctag + else: + if self.__name: + selfTag = self.__name + + if not selfTag: + if namedItemsOnly: + return "" + else: + selfTag = "ITEM" + + out += [ nl, indent, "<", selfTag, ">" ] + + for i,res in enumerate(self.__toklist): + if isinstance(res,ParseResults): + if i in namedItems: + out += [ res.asXML(namedItems[i], + namedItemsOnly and doctag is None, + nextLevelIndent, + formatted)] + else: + out += [ res.asXML(None, + namedItemsOnly and doctag is None, + nextLevelIndent, + formatted)] + else: + # individual token, see if there is a name for it + resTag = None + if i in namedItems: + resTag = namedItems[i] + if not resTag: + if namedItemsOnly: + continue + else: + resTag = "ITEM" + xmlBodyText = _xml_escape(_ustr(res)) + out += [ nl, nextLevelIndent, "<", resTag, ">", + xmlBodyText, + "</", resTag, ">" ] + + out += [ nl, indent, "</", selfTag, ">" ] + return "".join(out) + + def __lookup(self,sub): + for k,vlist in self.__tokdict.items(): + for v,loc in vlist: + if sub is v: + return k + return None + + def getName(self): + r""" + Returns the results name for this token expression. Useful when several + different expressions might match at a particular location. + + Example:: + integer = Word(nums) + ssn_expr = Regex(r"\d\d\d-\d\d-\d\d\d\d") + house_number_expr = Suppress('#') + Word(nums, alphanums) + user_data = (Group(house_number_expr)("house_number") + | Group(ssn_expr)("ssn") + | Group(integer)("age")) + user_info = OneOrMore(user_data) + + result = user_info.parseString("22 111-22-3333 #221B") + for item in result: + print(item.getName(), ':', item[0]) + prints:: + age : 22 + ssn : 111-22-3333 + house_number : 221B + """ + if self.__name: + return self.__name + elif self.__parent: + par = self.__parent() + if par: + return par.__lookup(self) + else: + return None + elif (len(self) == 1 and + len(self.__tokdict) == 1 and + next(iter(self.__tokdict.values()))[0][1] in (0,-1)): + return next(iter(self.__tokdict.keys())) + else: + return None + + def dump(self, indent='', depth=0, full=True): + """ + Diagnostic method for listing out the contents of a C{ParseResults}. + Accepts an optional C{indent} argument so that this string can be embedded + in a nested display of other data. + + Example:: + integer = Word(nums) + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + result = date_str.parseString('12/31/1999') + print(result.dump()) + prints:: + ['12', '/', '31', '/', '1999'] + - day: 1999 + - month: 31 + - year: 12 + """ + out = [] + NL = '\n' + out.append( indent+_ustr(self.asList()) ) + if full: + if self.haskeys(): + items = sorted((str(k), v) for k,v in self.items()) + for k,v in items: + if out: + out.append(NL) + out.append( "%s%s- %s: " % (indent,(' '*depth), k) ) + if isinstance(v,ParseResults): + if v: + out.append( v.dump(indent,depth+1) ) + else: + out.append(_ustr(v)) + else: + out.append(repr(v)) + elif any(isinstance(vv,ParseResults) for vv in self): + v = self + for i,vv in enumerate(v): + if isinstance(vv,ParseResults): + out.append("\n%s%s[%d]:\n%s%s%s" % (indent,(' '*(depth)),i,indent,(' '*(depth+1)),vv.dump(indent,depth+1) )) + else: + out.append("\n%s%s[%d]:\n%s%s%s" % (indent,(' '*(depth)),i,indent,(' '*(depth+1)),_ustr(vv))) + + return "".join(out) + + def pprint(self, *args, **kwargs): + """ + Pretty-printer for parsed results as a list, using the C{pprint} module. + Accepts additional positional or keyword args as defined for the + C{pprint.pprint} method. (U{http://docs.python.org/3/library/pprint.html#pprint.pprint}) + + Example:: + ident = Word(alphas, alphanums) + num = Word(nums) + func = Forward() + term = ident | num | Group('(' + func + ')') + func <<= ident + Group(Optional(delimitedList(term))) + result = func.parseString("fna a,b,(fnb c,d,200),100") + result.pprint(width=40) + prints:: + ['fna', + ['a', + 'b', + ['(', 'fnb', ['c', 'd', '200'], ')'], + '100']] + """ + pprint.pprint(self.asList(), *args, **kwargs) + + # add support for pickle protocol + def __getstate__(self): + return ( self.__toklist, + ( self.__tokdict.copy(), + self.__parent is not None and self.__parent() or None, + self.__accumNames, + self.__name ) ) + + def __setstate__(self,state): + self.__toklist = state[0] + (self.__tokdict, + par, + inAccumNames, + self.__name) = state[1] + self.__accumNames = {} + self.__accumNames.update(inAccumNames) + if par is not None: + self.__parent = wkref(par) + else: + self.__parent = None + + def __getnewargs__(self): + return self.__toklist, self.__name, self.__asList, self.__modal + + def __dir__(self): + return (dir(type(self)) + list(self.keys())) + +MutableMapping.register(ParseResults) + +def col (loc,strg): + """Returns current column within a string, counting newlines as line separators. + The first column is number 1. + + Note: the default parsing behavior is to expand tabs in the input string + before starting the parsing process. See L{I{ParserElement.parseString}<ParserElement.parseString>} for more information + on parsing strings containing C{<TAB>}s, and suggested methods to maintain a + consistent view of the parsed string, the parse location, and line and column + positions within the parsed string. + """ + s = strg + return 1 if 0<loc<len(s) and s[loc-1] == '\n' else loc - s.rfind("\n", 0, loc) + +def lineno(loc,strg): + """Returns current line number within a string, counting newlines as line separators. + The first line is number 1. + + Note: the default parsing behavior is to expand tabs in the input string + before starting the parsing process. See L{I{ParserElement.parseString}<ParserElement.parseString>} for more information + on parsing strings containing C{<TAB>}s, and suggested methods to maintain a + consistent view of the parsed string, the parse location, and line and column + positions within the parsed string. + """ + return strg.count("\n",0,loc) + 1 + +def line( loc, strg ): + """Returns the line of text containing loc within a string, counting newlines as line separators. + """ + lastCR = strg.rfind("\n", 0, loc) + nextCR = strg.find("\n", loc) + if nextCR >= 0: + return strg[lastCR+1:nextCR] + else: + return strg[lastCR+1:] + +def _defaultStartDebugAction( instring, loc, expr ): + print (("Match " + _ustr(expr) + " at loc " + _ustr(loc) + "(%d,%d)" % ( lineno(loc,instring), col(loc,instring) ))) + +def _defaultSuccessDebugAction( instring, startloc, endloc, expr, toks ): + print ("Matched " + _ustr(expr) + " -> " + str(toks.asList())) + +def _defaultExceptionDebugAction( instring, loc, expr, exc ): + print ("Exception raised:" + _ustr(exc)) + +def nullDebugAction(*args): + """'Do-nothing' debug action, to suppress debugging output during parsing.""" + pass + +# Only works on Python 3.x - nonlocal is toxic to Python 2 installs +#~ 'decorator to trim function calls to match the arity of the target' +#~ def _trim_arity(func, maxargs=3): + #~ if func in singleArgBuiltins: + #~ return lambda s,l,t: func(t) + #~ limit = 0 + #~ foundArity = False + #~ def wrapper(*args): + #~ nonlocal limit,foundArity + #~ while 1: + #~ try: + #~ ret = func(*args[limit:]) + #~ foundArity = True + #~ return ret + #~ except TypeError: + #~ if limit == maxargs or foundArity: + #~ raise + #~ limit += 1 + #~ continue + #~ return wrapper + +# this version is Python 2.x-3.x cross-compatible +'decorator to trim function calls to match the arity of the target' +def _trim_arity(func, maxargs=2): + if func in singleArgBuiltins: + return lambda s,l,t: func(t) + limit = [0] + foundArity = [False] + + # traceback return data structure changed in Py3.5 - normalize back to plain tuples + if system_version[:2] >= (3,5): + def extract_stack(limit=0): + # special handling for Python 3.5.0 - extra deep call stack by 1 + offset = -3 if system_version == (3,5,0) else -2 + frame_summary = traceback.extract_stack(limit=-offset+limit-1)[offset] + return [frame_summary[:2]] + def extract_tb(tb, limit=0): + frames = traceback.extract_tb(tb, limit=limit) + frame_summary = frames[-1] + return [frame_summary[:2]] + else: + extract_stack = traceback.extract_stack + extract_tb = traceback.extract_tb + + # synthesize what would be returned by traceback.extract_stack at the call to + # user's parse action 'func', so that we don't incur call penalty at parse time + + LINE_DIFF = 6 + # IF ANY CODE CHANGES, EVEN JUST COMMENTS OR BLANK LINES, BETWEEN THE NEXT LINE AND + # THE CALL TO FUNC INSIDE WRAPPER, LINE_DIFF MUST BE MODIFIED!!!! + this_line = extract_stack(limit=2)[-1] + pa_call_line_synth = (this_line[0], this_line[1]+LINE_DIFF) + + def wrapper(*args): + while 1: + try: + ret = func(*args[limit[0]:]) + foundArity[0] = True + return ret + except TypeError: + # re-raise TypeErrors if they did not come from our arity testing + if foundArity[0]: + raise + else: + try: + tb = sys.exc_info()[-1] + if not extract_tb(tb, limit=2)[-1][:2] == pa_call_line_synth: + raise + finally: + del tb + + if limit[0] <= maxargs: + limit[0] += 1 + continue + raise + + # copy func name to wrapper for sensible debug output + func_name = "<parse action>" + try: + func_name = getattr(func, '__name__', + getattr(func, '__class__').__name__) + except Exception: + func_name = str(func) + wrapper.__name__ = func_name + + return wrapper + +class ParserElement(object): + """Abstract base level parser element class.""" + DEFAULT_WHITE_CHARS = " \n\t\r" + verbose_stacktrace = False + + @staticmethod + def setDefaultWhitespaceChars( chars ): + r""" + Overrides the default whitespace chars + + Example:: + # default whitespace chars are space, <TAB> and newline + OneOrMore(Word(alphas)).parseString("abc def\nghi jkl") # -> ['abc', 'def', 'ghi', 'jkl'] + + # change to just treat newline as significant + ParserElement.setDefaultWhitespaceChars(" \t") + OneOrMore(Word(alphas)).parseString("abc def\nghi jkl") # -> ['abc', 'def'] + """ + ParserElement.DEFAULT_WHITE_CHARS = chars + + @staticmethod + def inlineLiteralsUsing(cls): + """ + Set class to be used for inclusion of string literals into a parser. + + Example:: + # default literal class used is Literal + integer = Word(nums) + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + date_str.parseString("1999/12/31") # -> ['1999', '/', '12', '/', '31'] + + + # change to Suppress + ParserElement.inlineLiteralsUsing(Suppress) + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + date_str.parseString("1999/12/31") # -> ['1999', '12', '31'] + """ + ParserElement._literalStringClass = cls + + def __init__( self, savelist=False ): + self.parseAction = list() + self.failAction = None + #~ self.name = "<unknown>" # don't define self.name, let subclasses try/except upcall + self.strRepr = None + self.resultsName = None + self.saveAsList = savelist + self.skipWhitespace = True + self.whiteChars = ParserElement.DEFAULT_WHITE_CHARS + self.copyDefaultWhiteChars = True + self.mayReturnEmpty = False # used when checking for left-recursion + self.keepTabs = False + self.ignoreExprs = list() + self.debug = False + self.streamlined = False + self.mayIndexError = True # used to optimize exception handling for subclasses that don't advance parse index + self.errmsg = "" + self.modalResults = True # used to mark results names as modal (report only last) or cumulative (list all) + self.debugActions = ( None, None, None ) #custom debug actions + self.re = None + self.callPreparse = True # used to avoid redundant calls to preParse + self.callDuringTry = False + + def copy( self ): + """ + Make a copy of this C{ParserElement}. Useful for defining different parse actions + for the same parsing pattern, using copies of the original parse element. + + Example:: + integer = Word(nums).setParseAction(lambda toks: int(toks[0])) + integerK = integer.copy().addParseAction(lambda toks: toks[0]*1024) + Suppress("K") + integerM = integer.copy().addParseAction(lambda toks: toks[0]*1024*1024) + Suppress("M") + + print(OneOrMore(integerK | integerM | integer).parseString("5K 100 640K 256M")) + prints:: + [5120, 100, 655360, 268435456] + Equivalent form of C{expr.copy()} is just C{expr()}:: + integerM = integer().addParseAction(lambda toks: toks[0]*1024*1024) + Suppress("M") + """ + cpy = copy.copy( self ) + cpy.parseAction = self.parseAction[:] + cpy.ignoreExprs = self.ignoreExprs[:] + if self.copyDefaultWhiteChars: + cpy.whiteChars = ParserElement.DEFAULT_WHITE_CHARS + return cpy + + def setName( self, name ): + """ + Define name for this expression, makes debugging and exception messages clearer. + + Example:: + Word(nums).parseString("ABC") # -> Exception: Expected W:(0123...) (at char 0), (line:1, col:1) + Word(nums).setName("integer").parseString("ABC") # -> Exception: Expected integer (at char 0), (line:1, col:1) + """ + self.name = name + self.errmsg = "Expected " + self.name + if hasattr(self,"exception"): + self.exception.msg = self.errmsg + return self + + def setResultsName( self, name, listAllMatches=False ): + """ + Define name for referencing matching tokens as a nested attribute + of the returned parse results. + NOTE: this returns a *copy* of the original C{ParserElement} object; + this is so that the client can define a basic element, such as an + integer, and reference it in multiple places with different names. + + You can also set results names using the abbreviated syntax, + C{expr("name")} in place of C{expr.setResultsName("name")} - + see L{I{__call__}<__call__>}. + + Example:: + date_str = (integer.setResultsName("year") + '/' + + integer.setResultsName("month") + '/' + + integer.setResultsName("day")) + + # equivalent form: + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + """ + newself = self.copy() + if name.endswith("*"): + name = name[:-1] + listAllMatches=True + newself.resultsName = name + newself.modalResults = not listAllMatches + return newself + + def setBreak(self,breakFlag = True): + """Method to invoke the Python pdb debugger when this element is + about to be parsed. Set C{breakFlag} to True to enable, False to + disable. + """ + if breakFlag: + _parseMethod = self._parse + def breaker(instring, loc, doActions=True, callPreParse=True): + import pdb + pdb.set_trace() + return _parseMethod( instring, loc, doActions, callPreParse ) + breaker._originalParseMethod = _parseMethod + self._parse = breaker + else: + if hasattr(self._parse,"_originalParseMethod"): + self._parse = self._parse._originalParseMethod + return self + + def setParseAction( self, *fns, **kwargs ): + """ + Define one or more actions to perform when successfully matching parse element definition. + Parse action fn is a callable method with 0-3 arguments, called as C{fn(s,loc,toks)}, + C{fn(loc,toks)}, C{fn(toks)}, or just C{fn()}, where: + - s = the original string being parsed (see note below) + - loc = the location of the matching substring + - toks = a list of the matched tokens, packaged as a C{L{ParseResults}} object + If the functions in fns modify the tokens, they can return them as the return + value from fn, and the modified list of tokens will replace the original. + Otherwise, fn does not need to return any value. + + Optional keyword arguments: + - callDuringTry = (default=C{False}) indicate if parse action should be run during lookaheads and alternate testing + + Note: the default parsing behavior is to expand tabs in the input string + before starting the parsing process. See L{I{parseString}<parseString>} for more information + on parsing strings containing C{<TAB>}s, and suggested methods to maintain a + consistent view of the parsed string, the parse location, and line and column + positions within the parsed string. + + Example:: + integer = Word(nums) + date_str = integer + '/' + integer + '/' + integer + + date_str.parseString("1999/12/31") # -> ['1999', '/', '12', '/', '31'] + + # use parse action to convert to ints at parse time + integer = Word(nums).setParseAction(lambda toks: int(toks[0])) + date_str = integer + '/' + integer + '/' + integer + + # note that integer fields are now ints, not strings + date_str.parseString("1999/12/31") # -> [1999, '/', 12, '/', 31] + """ + self.parseAction = list(map(_trim_arity, list(fns))) + self.callDuringTry = kwargs.get("callDuringTry", False) + return self + + def addParseAction( self, *fns, **kwargs ): + """ + Add one or more parse actions to expression's list of parse actions. See L{I{setParseAction}<setParseAction>}. + + See examples in L{I{copy}<copy>}. + """ + self.parseAction += list(map(_trim_arity, list(fns))) + self.callDuringTry = self.callDuringTry or kwargs.get("callDuringTry", False) + return self + + def addCondition(self, *fns, **kwargs): + """Add a boolean predicate function to expression's list of parse actions. See + L{I{setParseAction}<setParseAction>} for function call signatures. Unlike C{setParseAction}, + functions passed to C{addCondition} need to return boolean success/fail of the condition. + + Optional keyword arguments: + - message = define a custom message to be used in the raised exception + - fatal = if True, will raise ParseFatalException to stop parsing immediately; otherwise will raise ParseException + + Example:: + integer = Word(nums).setParseAction(lambda toks: int(toks[0])) + year_int = integer.copy() + year_int.addCondition(lambda toks: toks[0] >= 2000, message="Only support years 2000 and later") + date_str = year_int + '/' + integer + '/' + integer + + result = date_str.parseString("1999/12/31") # -> Exception: Only support years 2000 and later (at char 0), (line:1, col:1) + """ + msg = kwargs.get("message", "failed user-defined condition") + exc_type = ParseFatalException if kwargs.get("fatal", False) else ParseException + for fn in fns: + def pa(s,l,t): + if not bool(_trim_arity(fn)(s,l,t)): + raise exc_type(s,l,msg) + self.parseAction.append(pa) + self.callDuringTry = self.callDuringTry or kwargs.get("callDuringTry", False) + return self + + def setFailAction( self, fn ): + """Define action to perform if parsing fails at this expression. + Fail acton fn is a callable function that takes the arguments + C{fn(s,loc,expr,err)} where: + - s = string being parsed + - loc = location where expression match was attempted and failed + - expr = the parse expression that failed + - err = the exception thrown + The function returns no value. It may throw C{L{ParseFatalException}} + if it is desired to stop parsing immediately.""" + self.failAction = fn + return self + + def _skipIgnorables( self, instring, loc ): + exprsFound = True + while exprsFound: + exprsFound = False + for e in self.ignoreExprs: + try: + while 1: + loc,dummy = e._parse( instring, loc ) + exprsFound = True + except ParseException: + pass + return loc + + def preParse( self, instring, loc ): + if self.ignoreExprs: + loc = self._skipIgnorables( instring, loc ) + + if self.skipWhitespace: + wt = self.whiteChars + instrlen = len(instring) + while loc < instrlen and instring[loc] in wt: + loc += 1 + + return loc + + def parseImpl( self, instring, loc, doActions=True ): + return loc, [] + + def postParse( self, instring, loc, tokenlist ): + return tokenlist + + #~ @profile + def _parseNoCache( self, instring, loc, doActions=True, callPreParse=True ): + debugging = ( self.debug ) #and doActions ) + + if debugging or self.failAction: + #~ print ("Match",self,"at loc",loc,"(%d,%d)" % ( lineno(loc,instring), col(loc,instring) )) + if (self.debugActions[0] ): + self.debugActions[0]( instring, loc, self ) + if callPreParse and self.callPreparse: + preloc = self.preParse( instring, loc ) + else: + preloc = loc + tokensStart = preloc + try: + try: + loc,tokens = self.parseImpl( instring, preloc, doActions ) + except IndexError: + raise ParseException( instring, len(instring), self.errmsg, self ) + except ParseBaseException as err: + #~ print ("Exception raised:", err) + if self.debugActions[2]: + self.debugActions[2]( instring, tokensStart, self, err ) + if self.failAction: + self.failAction( instring, tokensStart, self, err ) + raise + else: + if callPreParse and self.callPreparse: + preloc = self.preParse( instring, loc ) + else: + preloc = loc + tokensStart = preloc + if self.mayIndexError or preloc >= len(instring): + try: + loc,tokens = self.parseImpl( instring, preloc, doActions ) + except IndexError: + raise ParseException( instring, len(instring), self.errmsg, self ) + else: + loc,tokens = self.parseImpl( instring, preloc, doActions ) + + tokens = self.postParse( instring, loc, tokens ) + + retTokens = ParseResults( tokens, self.resultsName, asList=self.saveAsList, modal=self.modalResults ) + if self.parseAction and (doActions or self.callDuringTry): + if debugging: + try: + for fn in self.parseAction: + tokens = fn( instring, tokensStart, retTokens ) + if tokens is not None: + retTokens = ParseResults( tokens, + self.resultsName, + asList=self.saveAsList and isinstance(tokens,(ParseResults,list)), + modal=self.modalResults ) + except ParseBaseException as err: + #~ print "Exception raised in user parse action:", err + if (self.debugActions[2] ): + self.debugActions[2]( instring, tokensStart, self, err ) + raise + else: + for fn in self.parseAction: + tokens = fn( instring, tokensStart, retTokens ) + if tokens is not None: + retTokens = ParseResults( tokens, + self.resultsName, + asList=self.saveAsList and isinstance(tokens,(ParseResults,list)), + modal=self.modalResults ) + if debugging: + #~ print ("Matched",self,"->",retTokens.asList()) + if (self.debugActions[1] ): + self.debugActions[1]( instring, tokensStart, loc, self, retTokens ) + + return loc, retTokens + + def tryParse( self, instring, loc ): + try: + return self._parse( instring, loc, doActions=False )[0] + except ParseFatalException: + raise ParseException( instring, loc, self.errmsg, self) + + def canParseNext(self, instring, loc): + try: + self.tryParse(instring, loc) + except (ParseException, IndexError): + return False + else: + return True + + class _UnboundedCache(object): + def __init__(self): + cache = {} + self.not_in_cache = not_in_cache = object() + + def get(self, key): + return cache.get(key, not_in_cache) + + def set(self, key, value): + cache[key] = value + + def clear(self): + cache.clear() + + def cache_len(self): + return len(cache) + + self.get = types.MethodType(get, self) + self.set = types.MethodType(set, self) + self.clear = types.MethodType(clear, self) + self.__len__ = types.MethodType(cache_len, self) + + if _OrderedDict is not None: + class _FifoCache(object): + def __init__(self, size): + self.not_in_cache = not_in_cache = object() + + cache = _OrderedDict() + + def get(self, key): + return cache.get(key, not_in_cache) + + def set(self, key, value): + cache[key] = value + while len(cache) > size: + try: + cache.popitem(False) + except KeyError: + pass + + def clear(self): + cache.clear() + + def cache_len(self): + return len(cache) + + self.get = types.MethodType(get, self) + self.set = types.MethodType(set, self) + self.clear = types.MethodType(clear, self) + self.__len__ = types.MethodType(cache_len, self) + + else: + class _FifoCache(object): + def __init__(self, size): + self.not_in_cache = not_in_cache = object() + + cache = {} + key_fifo = collections.deque([], size) + + def get(self, key): + return cache.get(key, not_in_cache) + + def set(self, key, value): + cache[key] = value + while len(key_fifo) > size: + cache.pop(key_fifo.popleft(), None) + key_fifo.append(key) + + def clear(self): + cache.clear() + key_fifo.clear() + + def cache_len(self): + return len(cache) + + self.get = types.MethodType(get, self) + self.set = types.MethodType(set, self) + self.clear = types.MethodType(clear, self) + self.__len__ = types.MethodType(cache_len, self) + + # argument cache for optimizing repeated calls when backtracking through recursive expressions + packrat_cache = {} # this is set later by enabledPackrat(); this is here so that resetCache() doesn't fail + packrat_cache_lock = RLock() + packrat_cache_stats = [0, 0] + + # this method gets repeatedly called during backtracking with the same arguments - + # we can cache these arguments and save ourselves the trouble of re-parsing the contained expression + def _parseCache( self, instring, loc, doActions=True, callPreParse=True ): + HIT, MISS = 0, 1 + lookup = (self, instring, loc, callPreParse, doActions) + with ParserElement.packrat_cache_lock: + cache = ParserElement.packrat_cache + value = cache.get(lookup) + if value is cache.not_in_cache: + ParserElement.packrat_cache_stats[MISS] += 1 + try: + value = self._parseNoCache(instring, loc, doActions, callPreParse) + except ParseBaseException as pe: + # cache a copy of the exception, without the traceback + cache.set(lookup, pe.__class__(*pe.args)) + raise + else: + cache.set(lookup, (value[0], value[1].copy())) + return value + else: + ParserElement.packrat_cache_stats[HIT] += 1 + if isinstance(value, Exception): + raise value + return (value[0], value[1].copy()) + + _parse = _parseNoCache + + @staticmethod + def resetCache(): + ParserElement.packrat_cache.clear() + ParserElement.packrat_cache_stats[:] = [0] * len(ParserElement.packrat_cache_stats) + + _packratEnabled = False + @staticmethod + def enablePackrat(cache_size_limit=128): + """Enables "packrat" parsing, which adds memoizing to the parsing logic. + Repeated parse attempts at the same string location (which happens + often in many complex grammars) can immediately return a cached value, + instead of re-executing parsing/validating code. Memoizing is done of + both valid results and parsing exceptions. + + Parameters: + - cache_size_limit - (default=C{128}) - if an integer value is provided + will limit the size of the packrat cache; if None is passed, then + the cache size will be unbounded; if 0 is passed, the cache will + be effectively disabled. + + This speedup may break existing programs that use parse actions that + have side-effects. For this reason, packrat parsing is disabled when + you first import pyparsing. To activate the packrat feature, your + program must call the class method C{ParserElement.enablePackrat()}. If + your program uses C{psyco} to "compile as you go", you must call + C{enablePackrat} before calling C{psyco.full()}. If you do not do this, + Python will crash. For best results, call C{enablePackrat()} immediately + after importing pyparsing. + + Example:: + import pyparsing + pyparsing.ParserElement.enablePackrat() + """ + if not ParserElement._packratEnabled: + ParserElement._packratEnabled = True + if cache_size_limit is None: + ParserElement.packrat_cache = ParserElement._UnboundedCache() + else: + ParserElement.packrat_cache = ParserElement._FifoCache(cache_size_limit) + ParserElement._parse = ParserElement._parseCache + + def parseString( self, instring, parseAll=False ): + """ + Execute the parse expression with the given string. + This is the main interface to the client code, once the complete + expression has been built. + + If you want the grammar to require that the entire input string be + successfully parsed, then set C{parseAll} to True (equivalent to ending + the grammar with C{L{StringEnd()}}). + + Note: C{parseString} implicitly calls C{expandtabs()} on the input string, + in order to report proper column numbers in parse actions. + If the input string contains tabs and + the grammar uses parse actions that use the C{loc} argument to index into the + string being parsed, you can ensure you have a consistent view of the input + string by: + - calling C{parseWithTabs} on your grammar before calling C{parseString} + (see L{I{parseWithTabs}<parseWithTabs>}) + - define your parse action using the full C{(s,loc,toks)} signature, and + reference the input string using the parse action's C{s} argument + - explictly expand the tabs in your input string before calling + C{parseString} + + Example:: + Word('a').parseString('aaaaabaaa') # -> ['aaaaa'] + Word('a').parseString('aaaaabaaa', parseAll=True) # -> Exception: Expected end of text + """ + ParserElement.resetCache() + if not self.streamlined: + self.streamline() + #~ self.saveAsList = True + for e in self.ignoreExprs: + e.streamline() + if not self.keepTabs: + instring = instring.expandtabs() + try: + loc, tokens = self._parse( instring, 0 ) + if parseAll: + loc = self.preParse( instring, loc ) + se = Empty() + StringEnd() + se._parse( instring, loc ) + except ParseBaseException as exc: + if ParserElement.verbose_stacktrace: + raise + else: + # catch and re-raise exception from here, clears out pyparsing internal stack trace + raise exc + else: + return tokens + + def scanString( self, instring, maxMatches=_MAX_INT, overlap=False ): + """ + Scan the input string for expression matches. Each match will return the + matching tokens, start location, and end location. May be called with optional + C{maxMatches} argument, to clip scanning after 'n' matches are found. If + C{overlap} is specified, then overlapping matches will be reported. + + Note that the start and end locations are reported relative to the string + being parsed. See L{I{parseString}<parseString>} for more information on parsing + strings with embedded tabs. + + Example:: + source = "sldjf123lsdjjkf345sldkjf879lkjsfd987" + print(source) + for tokens,start,end in Word(alphas).scanString(source): + print(' '*start + '^'*(end-start)) + print(' '*start + tokens[0]) + + prints:: + + sldjf123lsdjjkf345sldkjf879lkjsfd987 + ^^^^^ + sldjf + ^^^^^^^ + lsdjjkf + ^^^^^^ + sldkjf + ^^^^^^ + lkjsfd + """ + if not self.streamlined: + self.streamline() + for e in self.ignoreExprs: + e.streamline() + + if not self.keepTabs: + instring = _ustr(instring).expandtabs() + instrlen = len(instring) + loc = 0 + preparseFn = self.preParse + parseFn = self._parse + ParserElement.resetCache() + matches = 0 + try: + while loc <= instrlen and matches < maxMatches: + try: + preloc = preparseFn( instring, loc ) + nextLoc,tokens = parseFn( instring, preloc, callPreParse=False ) + except ParseException: + loc = preloc+1 + else: + if nextLoc > loc: + matches += 1 + yield tokens, preloc, nextLoc + if overlap: + nextloc = preparseFn( instring, loc ) + if nextloc > loc: + loc = nextLoc + else: + loc += 1 + else: + loc = nextLoc + else: + loc = preloc+1 + except ParseBaseException as exc: + if ParserElement.verbose_stacktrace: + raise + else: + # catch and re-raise exception from here, clears out pyparsing internal stack trace + raise exc + + def transformString( self, instring ): + """ + Extension to C{L{scanString}}, to modify matching text with modified tokens that may + be returned from a parse action. To use C{transformString}, define a grammar and + attach a parse action to it that modifies the returned token list. + Invoking C{transformString()} on a target string will then scan for matches, + and replace the matched text patterns according to the logic in the parse + action. C{transformString()} returns the resulting transformed string. + + Example:: + wd = Word(alphas) + wd.setParseAction(lambda toks: toks[0].title()) + + print(wd.transformString("now is the winter of our discontent made glorious summer by this sun of york.")) + Prints:: + Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York. + """ + out = [] + lastE = 0 + # force preservation of <TAB>s, to minimize unwanted transformation of string, and to + # keep string locs straight between transformString and scanString + self.keepTabs = True + try: + for t,s,e in self.scanString( instring ): + out.append( instring[lastE:s] ) + if t: + if isinstance(t,ParseResults): + out += t.asList() + elif isinstance(t,list): + out += t + else: + out.append(t) + lastE = e + out.append(instring[lastE:]) + out = [o for o in out if o] + return "".join(map(_ustr,_flatten(out))) + except ParseBaseException as exc: + if ParserElement.verbose_stacktrace: + raise + else: + # catch and re-raise exception from here, clears out pyparsing internal stack trace + raise exc + + def searchString( self, instring, maxMatches=_MAX_INT ): + """ + Another extension to C{L{scanString}}, simplifying the access to the tokens found + to match the given parse expression. May be called with optional + C{maxMatches} argument, to clip searching after 'n' matches are found. + + Example:: + # a capitalized word starts with an uppercase letter, followed by zero or more lowercase letters + cap_word = Word(alphas.upper(), alphas.lower()) + + print(cap_word.searchString("More than Iron, more than Lead, more than Gold I need Electricity")) + + # the sum() builtin can be used to merge results into a single ParseResults object + print(sum(cap_word.searchString("More than Iron, more than Lead, more than Gold I need Electricity"))) + prints:: + [['More'], ['Iron'], ['Lead'], ['Gold'], ['I'], ['Electricity']] + ['More', 'Iron', 'Lead', 'Gold', 'I', 'Electricity'] + """ + try: + return ParseResults([ t for t,s,e in self.scanString( instring, maxMatches ) ]) + except ParseBaseException as exc: + if ParserElement.verbose_stacktrace: + raise + else: + # catch and re-raise exception from here, clears out pyparsing internal stack trace + raise exc + + def split(self, instring, maxsplit=_MAX_INT, includeSeparators=False): + """ + Generator method to split a string using the given expression as a separator. + May be called with optional C{maxsplit} argument, to limit the number of splits; + and the optional C{includeSeparators} argument (default=C{False}), if the separating + matching text should be included in the split results. + + Example:: + punc = oneOf(list(".,;:/-!?")) + print(list(punc.split("This, this?, this sentence, is badly punctuated!"))) + prints:: + ['This', ' this', '', ' this sentence', ' is badly punctuated', ''] + """ + splits = 0 + last = 0 + for t,s,e in self.scanString(instring, maxMatches=maxsplit): + yield instring[last:s] + if includeSeparators: + yield t[0] + last = e + yield instring[last:] + + def __add__(self, other ): + """ + Implementation of + operator - returns C{L{And}}. Adding strings to a ParserElement + converts them to L{Literal}s by default. + + Example:: + greet = Word(alphas) + "," + Word(alphas) + "!" + hello = "Hello, World!" + print (hello, "->", greet.parseString(hello)) + Prints:: + Hello, World! -> ['Hello', ',', 'World', '!'] + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return And( [ self, other ] ) + + def __radd__(self, other ): + """ + Implementation of + operator when left operand is not a C{L{ParserElement}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return other + self + + def __sub__(self, other): + """ + Implementation of - operator, returns C{L{And}} with error stop + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return self + And._ErrorStop() + other + + def __rsub__(self, other ): + """ + Implementation of - operator when left operand is not a C{L{ParserElement}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return other - self + + def __mul__(self,other): + """ + Implementation of * operator, allows use of C{expr * 3} in place of + C{expr + expr + expr}. Expressions may also me multiplied by a 2-integer + tuple, similar to C{{min,max}} multipliers in regular expressions. Tuples + may also include C{None} as in: + - C{expr*(n,None)} or C{expr*(n,)} is equivalent + to C{expr*n + L{ZeroOrMore}(expr)} + (read as "at least n instances of C{expr}") + - C{expr*(None,n)} is equivalent to C{expr*(0,n)} + (read as "0 to n instances of C{expr}") + - C{expr*(None,None)} is equivalent to C{L{ZeroOrMore}(expr)} + - C{expr*(1,None)} is equivalent to C{L{OneOrMore}(expr)} + + Note that C{expr*(None,n)} does not raise an exception if + more than n exprs exist in the input stream; that is, + C{expr*(None,n)} does not enforce a maximum number of expr + occurrences. If this behavior is desired, then write + C{expr*(None,n) + ~expr} + """ + if isinstance(other,int): + minElements, optElements = other,0 + elif isinstance(other,tuple): + other = (other + (None, None))[:2] + if other[0] is None: + other = (0, other[1]) + if isinstance(other[0],int) and other[1] is None: + if other[0] == 0: + return ZeroOrMore(self) + if other[0] == 1: + return OneOrMore(self) + else: + return self*other[0] + ZeroOrMore(self) + elif isinstance(other[0],int) and isinstance(other[1],int): + minElements, optElements = other + optElements -= minElements + else: + raise TypeError("cannot multiply 'ParserElement' and ('%s','%s') objects", type(other[0]),type(other[1])) + else: + raise TypeError("cannot multiply 'ParserElement' and '%s' objects", type(other)) + + if minElements < 0: + raise ValueError("cannot multiply ParserElement by negative value") + if optElements < 0: + raise ValueError("second tuple value must be greater or equal to first tuple value") + if minElements == optElements == 0: + raise ValueError("cannot multiply ParserElement by 0 or (0,0)") + + if (optElements): + def makeOptionalList(n): + if n>1: + return Optional(self + makeOptionalList(n-1)) + else: + return Optional(self) + if minElements: + if minElements == 1: + ret = self + makeOptionalList(optElements) + else: + ret = And([self]*minElements) + makeOptionalList(optElements) + else: + ret = makeOptionalList(optElements) + else: + if minElements == 1: + ret = self + else: + ret = And([self]*minElements) + return ret + + def __rmul__(self, other): + return self.__mul__(other) + + def __or__(self, other ): + """ + Implementation of | operator - returns C{L{MatchFirst}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return MatchFirst( [ self, other ] ) + + def __ror__(self, other ): + """ + Implementation of | operator when left operand is not a C{L{ParserElement}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return other | self + + def __xor__(self, other ): + """ + Implementation of ^ operator - returns C{L{Or}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return Or( [ self, other ] ) + + def __rxor__(self, other ): + """ + Implementation of ^ operator when left operand is not a C{L{ParserElement}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return other ^ self + + def __and__(self, other ): + """ + Implementation of & operator - returns C{L{Each}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return Each( [ self, other ] ) + + def __rand__(self, other ): + """ + Implementation of & operator when left operand is not a C{L{ParserElement}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return other & self + + def __invert__( self ): + """ + Implementation of ~ operator - returns C{L{NotAny}} + """ + return NotAny( self ) + + def __call__(self, name=None): + """ + Shortcut for C{L{setResultsName}}, with C{listAllMatches=False}. + + If C{name} is given with a trailing C{'*'} character, then C{listAllMatches} will be + passed as C{True}. + + If C{name} is omitted, same as calling C{L{copy}}. + + Example:: + # these are equivalent + userdata = Word(alphas).setResultsName("name") + Word(nums+"-").setResultsName("socsecno") + userdata = Word(alphas)("name") + Word(nums+"-")("socsecno") + """ + if name is not None: + return self.setResultsName(name) + else: + return self.copy() + + def suppress( self ): + """ + Suppresses the output of this C{ParserElement}; useful to keep punctuation from + cluttering up returned output. + """ + return Suppress( self ) + + def leaveWhitespace( self ): + """ + Disables the skipping of whitespace before matching the characters in the + C{ParserElement}'s defined pattern. This is normally only used internally by + the pyparsing module, but may be needed in some whitespace-sensitive grammars. + """ + self.skipWhitespace = False + return self + + def setWhitespaceChars( self, chars ): + """ + Overrides the default whitespace chars + """ + self.skipWhitespace = True + self.whiteChars = chars + self.copyDefaultWhiteChars = False + return self + + def parseWithTabs( self ): + """ + Overrides default behavior to expand C{<TAB>}s to spaces before parsing the input string. + Must be called before C{parseString} when the input grammar contains elements that + match C{<TAB>} characters. + """ + self.keepTabs = True + return self + + def ignore( self, other ): + """ + Define expression to be ignored (e.g., comments) while doing pattern + matching; may be called repeatedly, to define multiple comment or other + ignorable patterns. + + Example:: + patt = OneOrMore(Word(alphas)) + patt.parseString('ablaj /* comment */ lskjd') # -> ['ablaj'] + + patt.ignore(cStyleComment) + patt.parseString('ablaj /* comment */ lskjd') # -> ['ablaj', 'lskjd'] + """ + if isinstance(other, basestring): + other = Suppress(other) + + if isinstance( other, Suppress ): + if other not in self.ignoreExprs: + self.ignoreExprs.append(other) + else: + self.ignoreExprs.append( Suppress( other.copy() ) ) + return self + + def setDebugActions( self, startAction, successAction, exceptionAction ): + """ + Enable display of debugging messages while doing pattern matching. + """ + self.debugActions = (startAction or _defaultStartDebugAction, + successAction or _defaultSuccessDebugAction, + exceptionAction or _defaultExceptionDebugAction) + self.debug = True + return self + + def setDebug( self, flag=True ): + """ + Enable display of debugging messages while doing pattern matching. + Set C{flag} to True to enable, False to disable. + + Example:: + wd = Word(alphas).setName("alphaword") + integer = Word(nums).setName("numword") + term = wd | integer + + # turn on debugging for wd + wd.setDebug() + + OneOrMore(term).parseString("abc 123 xyz 890") + + prints:: + Match alphaword at loc 0(1,1) + Matched alphaword -> ['abc'] + Match alphaword at loc 3(1,4) + Exception raised:Expected alphaword (at char 4), (line:1, col:5) + Match alphaword at loc 7(1,8) + Matched alphaword -> ['xyz'] + Match alphaword at loc 11(1,12) + Exception raised:Expected alphaword (at char 12), (line:1, col:13) + Match alphaword at loc 15(1,16) + Exception raised:Expected alphaword (at char 15), (line:1, col:16) + + The output shown is that produced by the default debug actions - custom debug actions can be + specified using L{setDebugActions}. Prior to attempting + to match the C{wd} expression, the debugging message C{"Match <exprname> at loc <n>(<line>,<col>)"} + is shown. Then if the parse succeeds, a C{"Matched"} message is shown, or an C{"Exception raised"} + message is shown. Also note the use of L{setName} to assign a human-readable name to the expression, + which makes debugging and exception messages easier to understand - for instance, the default + name created for the C{Word} expression without calling C{setName} is C{"W:(ABCD...)"}. + """ + if flag: + self.setDebugActions( _defaultStartDebugAction, _defaultSuccessDebugAction, _defaultExceptionDebugAction ) + else: + self.debug = False + return self + + def __str__( self ): + return self.name + + def __repr__( self ): + return _ustr(self) + + def streamline( self ): + self.streamlined = True + self.strRepr = None + return self + + def checkRecursion( self, parseElementList ): + pass + + def validate( self, validateTrace=[] ): + """ + Check defined expressions for valid structure, check for infinite recursive definitions. + """ + self.checkRecursion( [] ) + + def parseFile( self, file_or_filename, parseAll=False ): + """ + Execute the parse expression on the given file or filename. + If a filename is specified (instead of a file object), + the entire file is opened, read, and closed before parsing. + """ + try: + file_contents = file_or_filename.read() + except AttributeError: + with open(file_or_filename, "r") as f: + file_contents = f.read() + try: + return self.parseString(file_contents, parseAll) + except ParseBaseException as exc: + if ParserElement.verbose_stacktrace: + raise + else: + # catch and re-raise exception from here, clears out pyparsing internal stack trace + raise exc + + def __eq__(self,other): + if isinstance(other, ParserElement): + return self is other or vars(self) == vars(other) + elif isinstance(other, basestring): + return self.matches(other) + else: + return super(ParserElement,self)==other + + def __ne__(self,other): + return not (self == other) + + def __hash__(self): + return hash(id(self)) + + def __req__(self,other): + return self == other + + def __rne__(self,other): + return not (self == other) + + def matches(self, testString, parseAll=True): + """ + Method for quick testing of a parser against a test string. Good for simple + inline microtests of sub expressions while building up larger parser. + + Parameters: + - testString - to test against this expression for a match + - parseAll - (default=C{True}) - flag to pass to C{L{parseString}} when running tests + + Example:: + expr = Word(nums) + assert expr.matches("100") + """ + try: + self.parseString(_ustr(testString), parseAll=parseAll) + return True + except ParseBaseException: + return False + + def runTests(self, tests, parseAll=True, comment='#', fullDump=True, printResults=True, failureTests=False): + """ + Execute the parse expression on a series of test strings, showing each + test, the parsed results or where the parse failed. Quick and easy way to + run a parse expression against a list of sample strings. + + Parameters: + - tests - a list of separate test strings, or a multiline string of test strings + - parseAll - (default=C{True}) - flag to pass to C{L{parseString}} when running tests + - comment - (default=C{'#'}) - expression for indicating embedded comments in the test + string; pass None to disable comment filtering + - fullDump - (default=C{True}) - dump results as list followed by results names in nested outline; + if False, only dump nested list + - printResults - (default=C{True}) prints test output to stdout + - failureTests - (default=C{False}) indicates if these tests are expected to fail parsing + + Returns: a (success, results) tuple, where success indicates that all tests succeeded + (or failed if C{failureTests} is True), and the results contain a list of lines of each + test's output + + Example:: + number_expr = pyparsing_common.number.copy() + + result = number_expr.runTests(''' + # unsigned integer + 100 + # negative integer + -100 + # float with scientific notation + 6.02e23 + # integer with scientific notation + 1e-12 + ''') + print("Success" if result[0] else "Failed!") + + result = number_expr.runTests(''' + # stray character + 100Z + # missing leading digit before '.' + -.100 + # too many '.' + 3.14.159 + ''', failureTests=True) + print("Success" if result[0] else "Failed!") + prints:: + # unsigned integer + 100 + [100] + + # negative integer + -100 + [-100] + + # float with scientific notation + 6.02e23 + [6.02e+23] + + # integer with scientific notation + 1e-12 + [1e-12] + + Success + + # stray character + 100Z + ^ + FAIL: Expected end of text (at char 3), (line:1, col:4) + + # missing leading digit before '.' + -.100 + ^ + FAIL: Expected {real number with scientific notation | real number | signed integer} (at char 0), (line:1, col:1) + + # too many '.' + 3.14.159 + ^ + FAIL: Expected end of text (at char 4), (line:1, col:5) + + Success + + Each test string must be on a single line. If you want to test a string that spans multiple + lines, create a test like this:: + + expr.runTest(r"this is a test\\n of strings that spans \\n 3 lines") + + (Note that this is a raw string literal, you must include the leading 'r'.) + """ + if isinstance(tests, basestring): + tests = list(map(str.strip, tests.rstrip().splitlines())) + if isinstance(comment, basestring): + comment = Literal(comment) + allResults = [] + comments = [] + success = True + for t in tests: + if comment is not None and comment.matches(t, False) or comments and not t: + comments.append(t) + continue + if not t: + continue + out = ['\n'.join(comments), t] + comments = [] + try: + t = t.replace(r'\n','\n') + result = self.parseString(t, parseAll=parseAll) + out.append(result.dump(full=fullDump)) + success = success and not failureTests + except ParseBaseException as pe: + fatal = "(FATAL)" if isinstance(pe, ParseFatalException) else "" + if '\n' in t: + out.append(line(pe.loc, t)) + out.append(' '*(col(pe.loc,t)-1) + '^' + fatal) + else: + out.append(' '*pe.loc + '^' + fatal) + out.append("FAIL: " + str(pe)) + success = success and failureTests + result = pe + except Exception as exc: + out.append("FAIL-EXCEPTION: " + str(exc)) + success = success and failureTests + result = exc + + if printResults: + if fullDump: + out.append('') + print('\n'.join(out)) + + allResults.append((t, result)) + + return success, allResults + + +class Token(ParserElement): + """ + Abstract C{ParserElement} subclass, for defining atomic matching patterns. + """ + def __init__( self ): + super(Token,self).__init__( savelist=False ) + + +class Empty(Token): + """ + An empty token, will always match. + """ + def __init__( self ): + super(Empty,self).__init__() + self.name = "Empty" + self.mayReturnEmpty = True + self.mayIndexError = False + + +class NoMatch(Token): + """ + A token that will never match. + """ + def __init__( self ): + super(NoMatch,self).__init__() + self.name = "NoMatch" + self.mayReturnEmpty = True + self.mayIndexError = False + self.errmsg = "Unmatchable token" + + def parseImpl( self, instring, loc, doActions=True ): + raise ParseException(instring, loc, self.errmsg, self) + + +class Literal(Token): + """ + Token to exactly match a specified string. + + Example:: + Literal('blah').parseString('blah') # -> ['blah'] + Literal('blah').parseString('blahfooblah') # -> ['blah'] + Literal('blah').parseString('bla') # -> Exception: Expected "blah" + + For case-insensitive matching, use L{CaselessLiteral}. + + For keyword matching (force word break before and after the matched string), + use L{Keyword} or L{CaselessKeyword}. + """ + def __init__( self, matchString ): + super(Literal,self).__init__() + self.match = matchString + self.matchLen = len(matchString) + try: + self.firstMatchChar = matchString[0] + except IndexError: + warnings.warn("null string passed to Literal; use Empty() instead", + SyntaxWarning, stacklevel=2) + self.__class__ = Empty + self.name = '"%s"' % _ustr(self.match) + self.errmsg = "Expected " + self.name + self.mayReturnEmpty = False + self.mayIndexError = False + + # Performance tuning: this routine gets called a *lot* + # if this is a single character match string and the first character matches, + # short-circuit as quickly as possible, and avoid calling startswith + #~ @profile + def parseImpl( self, instring, loc, doActions=True ): + if (instring[loc] == self.firstMatchChar and + (self.matchLen==1 or instring.startswith(self.match,loc)) ): + return loc+self.matchLen, self.match + raise ParseException(instring, loc, self.errmsg, self) +_L = Literal +ParserElement._literalStringClass = Literal + +class Keyword(Token): + """ + Token to exactly match a specified string as a keyword, that is, it must be + immediately followed by a non-keyword character. Compare with C{L{Literal}}: + - C{Literal("if")} will match the leading C{'if'} in C{'ifAndOnlyIf'}. + - C{Keyword("if")} will not; it will only match the leading C{'if'} in C{'if x=1'}, or C{'if(y==2)'} + Accepts two optional constructor arguments in addition to the keyword string: + - C{identChars} is a string of characters that would be valid identifier characters, + defaulting to all alphanumerics + "_" and "$" + - C{caseless} allows case-insensitive matching, default is C{False}. + + Example:: + Keyword("start").parseString("start") # -> ['start'] + Keyword("start").parseString("starting") # -> Exception + + For case-insensitive matching, use L{CaselessKeyword}. + """ + DEFAULT_KEYWORD_CHARS = alphanums+"_$" + + def __init__( self, matchString, identChars=None, caseless=False ): + super(Keyword,self).__init__() + if identChars is None: + identChars = Keyword.DEFAULT_KEYWORD_CHARS + self.match = matchString + self.matchLen = len(matchString) + try: + self.firstMatchChar = matchString[0] + except IndexError: + warnings.warn("null string passed to Keyword; use Empty() instead", + SyntaxWarning, stacklevel=2) + self.name = '"%s"' % self.match + self.errmsg = "Expected " + self.name + self.mayReturnEmpty = False + self.mayIndexError = False + self.caseless = caseless + if caseless: + self.caselessmatch = matchString.upper() + identChars = identChars.upper() + self.identChars = set(identChars) + + def parseImpl( self, instring, loc, doActions=True ): + if self.caseless: + if ( (instring[ loc:loc+self.matchLen ].upper() == self.caselessmatch) and + (loc >= len(instring)-self.matchLen or instring[loc+self.matchLen].upper() not in self.identChars) and + (loc == 0 or instring[loc-1].upper() not in self.identChars) ): + return loc+self.matchLen, self.match + else: + if (instring[loc] == self.firstMatchChar and + (self.matchLen==1 or instring.startswith(self.match,loc)) and + (loc >= len(instring)-self.matchLen or instring[loc+self.matchLen] not in self.identChars) and + (loc == 0 or instring[loc-1] not in self.identChars) ): + return loc+self.matchLen, self.match + raise ParseException(instring, loc, self.errmsg, self) + + def copy(self): + c = super(Keyword,self).copy() + c.identChars = Keyword.DEFAULT_KEYWORD_CHARS + return c + + @staticmethod + def setDefaultKeywordChars( chars ): + """Overrides the default Keyword chars + """ + Keyword.DEFAULT_KEYWORD_CHARS = chars + +class CaselessLiteral(Literal): + """ + Token to match a specified string, ignoring case of letters. + Note: the matched results will always be in the case of the given + match string, NOT the case of the input text. + + Example:: + OneOrMore(CaselessLiteral("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD', 'CMD'] + + (Contrast with example for L{CaselessKeyword}.) + """ + def __init__( self, matchString ): + super(CaselessLiteral,self).__init__( matchString.upper() ) + # Preserve the defining literal. + self.returnString = matchString + self.name = "'%s'" % self.returnString + self.errmsg = "Expected " + self.name + + def parseImpl( self, instring, loc, doActions=True ): + if instring[ loc:loc+self.matchLen ].upper() == self.match: + return loc+self.matchLen, self.returnString + raise ParseException(instring, loc, self.errmsg, self) + +class CaselessKeyword(Keyword): + """ + Caseless version of L{Keyword}. + + Example:: + OneOrMore(CaselessKeyword("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD'] + + (Contrast with example for L{CaselessLiteral}.) + """ + def __init__( self, matchString, identChars=None ): + super(CaselessKeyword,self).__init__( matchString, identChars, caseless=True ) + + def parseImpl( self, instring, loc, doActions=True ): + if ( (instring[ loc:loc+self.matchLen ].upper() == self.caselessmatch) and + (loc >= len(instring)-self.matchLen or instring[loc+self.matchLen].upper() not in self.identChars) ): + return loc+self.matchLen, self.match + raise ParseException(instring, loc, self.errmsg, self) + +class CloseMatch(Token): + """ + A variation on L{Literal} which matches "close" matches, that is, + strings with at most 'n' mismatching characters. C{CloseMatch} takes parameters: + - C{match_string} - string to be matched + - C{maxMismatches} - (C{default=1}) maximum number of mismatches allowed to count as a match + + The results from a successful parse will contain the matched text from the input string and the following named results: + - C{mismatches} - a list of the positions within the match_string where mismatches were found + - C{original} - the original match_string used to compare against the input string + + If C{mismatches} is an empty list, then the match was an exact match. + + Example:: + patt = CloseMatch("ATCATCGAATGGA") + patt.parseString("ATCATCGAAXGGA") # -> (['ATCATCGAAXGGA'], {'mismatches': [[9]], 'original': ['ATCATCGAATGGA']}) + patt.parseString("ATCAXCGAAXGGA") # -> Exception: Expected 'ATCATCGAATGGA' (with up to 1 mismatches) (at char 0), (line:1, col:1) + + # exact match + patt.parseString("ATCATCGAATGGA") # -> (['ATCATCGAATGGA'], {'mismatches': [[]], 'original': ['ATCATCGAATGGA']}) + + # close match allowing up to 2 mismatches + patt = CloseMatch("ATCATCGAATGGA", maxMismatches=2) + patt.parseString("ATCAXCGAAXGGA") # -> (['ATCAXCGAAXGGA'], {'mismatches': [[4, 9]], 'original': ['ATCATCGAATGGA']}) + """ + def __init__(self, match_string, maxMismatches=1): + super(CloseMatch,self).__init__() + self.name = match_string + self.match_string = match_string + self.maxMismatches = maxMismatches + self.errmsg = "Expected %r (with up to %d mismatches)" % (self.match_string, self.maxMismatches) + self.mayIndexError = False + self.mayReturnEmpty = False + + def parseImpl( self, instring, loc, doActions=True ): + start = loc + instrlen = len(instring) + maxloc = start + len(self.match_string) + + if maxloc <= instrlen: + match_string = self.match_string + match_stringloc = 0 + mismatches = [] + maxMismatches = self.maxMismatches + + for match_stringloc,s_m in enumerate(zip(instring[loc:maxloc], self.match_string)): + src,mat = s_m + if src != mat: + mismatches.append(match_stringloc) + if len(mismatches) > maxMismatches: + break + else: + loc = match_stringloc + 1 + results = ParseResults([instring[start:loc]]) + results['original'] = self.match_string + results['mismatches'] = mismatches + return loc, results + + raise ParseException(instring, loc, self.errmsg, self) + + +class Word(Token): + """ + Token for matching words composed of allowed character sets. + Defined with string containing all allowed initial characters, + an optional string containing allowed body characters (if omitted, + defaults to the initial character set), and an optional minimum, + maximum, and/or exact length. The default value for C{min} is 1 (a + minimum value < 1 is not valid); the default values for C{max} and C{exact} + are 0, meaning no maximum or exact length restriction. An optional + C{excludeChars} parameter can list characters that might be found in + the input C{bodyChars} string; useful to define a word of all printables + except for one or two characters, for instance. + + L{srange} is useful for defining custom character set strings for defining + C{Word} expressions, using range notation from regular expression character sets. + + A common mistake is to use C{Word} to match a specific literal string, as in + C{Word("Address")}. Remember that C{Word} uses the string argument to define + I{sets} of matchable characters. This expression would match "Add", "AAA", + "dAred", or any other word made up of the characters 'A', 'd', 'r', 'e', and 's'. + To match an exact literal string, use L{Literal} or L{Keyword}. + + pyparsing includes helper strings for building Words: + - L{alphas} + - L{nums} + - L{alphanums} + - L{hexnums} + - L{alphas8bit} (alphabetic characters in ASCII range 128-255 - accented, tilded, umlauted, etc.) + - L{punc8bit} (non-alphabetic characters in ASCII range 128-255 - currency, symbols, superscripts, diacriticals, etc.) + - L{printables} (any non-whitespace character) + + Example:: + # a word composed of digits + integer = Word(nums) # equivalent to Word("0123456789") or Word(srange("0-9")) + + # a word with a leading capital, and zero or more lowercase + capital_word = Word(alphas.upper(), alphas.lower()) + + # hostnames are alphanumeric, with leading alpha, and '-' + hostname = Word(alphas, alphanums+'-') + + # roman numeral (not a strict parser, accepts invalid mix of characters) + roman = Word("IVXLCDM") + + # any string of non-whitespace characters, except for ',' + csv_value = Word(printables, excludeChars=",") + """ + def __init__( self, initChars, bodyChars=None, min=1, max=0, exact=0, asKeyword=False, excludeChars=None ): + super(Word,self).__init__() + if excludeChars: + initChars = ''.join(c for c in initChars if c not in excludeChars) + if bodyChars: + bodyChars = ''.join(c for c in bodyChars if c not in excludeChars) + self.initCharsOrig = initChars + self.initChars = set(initChars) + if bodyChars : + self.bodyCharsOrig = bodyChars + self.bodyChars = set(bodyChars) + else: + self.bodyCharsOrig = initChars + self.bodyChars = set(initChars) + + self.maxSpecified = max > 0 + + if min < 1: + raise ValueError("cannot specify a minimum length < 1; use Optional(Word()) if zero-length word is permitted") + + self.minLen = min + + if max > 0: + self.maxLen = max + else: + self.maxLen = _MAX_INT + + if exact > 0: + self.maxLen = exact + self.minLen = exact + + self.name = _ustr(self) + self.errmsg = "Expected " + self.name + self.mayIndexError = False + self.asKeyword = asKeyword + + if ' ' not in self.initCharsOrig+self.bodyCharsOrig and (min==1 and max==0 and exact==0): + if self.bodyCharsOrig == self.initCharsOrig: + self.reString = "[%s]+" % _escapeRegexRangeChars(self.initCharsOrig) + elif len(self.initCharsOrig) == 1: + self.reString = "%s[%s]*" % \ + (re.escape(self.initCharsOrig), + _escapeRegexRangeChars(self.bodyCharsOrig),) + else: + self.reString = "[%s][%s]*" % \ + (_escapeRegexRangeChars(self.initCharsOrig), + _escapeRegexRangeChars(self.bodyCharsOrig),) + if self.asKeyword: + self.reString = r"\b"+self.reString+r"\b" + try: + self.re = re.compile( self.reString ) + except Exception: + self.re = None + + def parseImpl( self, instring, loc, doActions=True ): + if self.re: + result = self.re.match(instring,loc) + if not result: + raise ParseException(instring, loc, self.errmsg, self) + + loc = result.end() + return loc, result.group() + + if not(instring[ loc ] in self.initChars): + raise ParseException(instring, loc, self.errmsg, self) + + start = loc + loc += 1 + instrlen = len(instring) + bodychars = self.bodyChars + maxloc = start + self.maxLen + maxloc = min( maxloc, instrlen ) + while loc < maxloc and instring[loc] in bodychars: + loc += 1 + + throwException = False + if loc - start < self.minLen: + throwException = True + if self.maxSpecified and loc < instrlen and instring[loc] in bodychars: + throwException = True + if self.asKeyword: + if (start>0 and instring[start-1] in bodychars) or (loc<instrlen and instring[loc] in bodychars): + throwException = True + + if throwException: + raise ParseException(instring, loc, self.errmsg, self) + + return loc, instring[start:loc] + + def __str__( self ): + try: + return super(Word,self).__str__() + except Exception: + pass + + + if self.strRepr is None: + + def charsAsStr(s): + if len(s)>4: + return s[:4]+"..." + else: + return s + + if ( self.initCharsOrig != self.bodyCharsOrig ): + self.strRepr = "W:(%s,%s)" % ( charsAsStr(self.initCharsOrig), charsAsStr(self.bodyCharsOrig) ) + else: + self.strRepr = "W:(%s)" % charsAsStr(self.initCharsOrig) + + return self.strRepr + + +class Regex(Token): + r""" + Token for matching strings that match a given regular expression. + Defined with string specifying the regular expression in a form recognized by the inbuilt Python re module. + If the given regex contains named groups (defined using C{(?P<name>...)}), these will be preserved as + named parse results. + + Example:: + realnum = Regex(r"[+-]?\d+\.\d*") + date = Regex(r'(?P<year>\d{4})-(?P<month>\d\d?)-(?P<day>\d\d?)') + # ref: http://stackoverflow.com/questions/267399/how-do-you-match-only-valid-roman-numerals-with-a-regular-expression + roman = Regex(r"M{0,4}(CM|CD|D?C{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})") + """ + compiledREtype = type(re.compile("[A-Z]")) + def __init__( self, pattern, flags=0): + """The parameters C{pattern} and C{flags} are passed to the C{re.compile()} function as-is. See the Python C{re} module for an explanation of the acceptable patterns and flags.""" + super(Regex,self).__init__() + + if isinstance(pattern, basestring): + if not pattern: + warnings.warn("null string passed to Regex; use Empty() instead", + SyntaxWarning, stacklevel=2) + + self.pattern = pattern + self.flags = flags + + try: + self.re = re.compile(self.pattern, self.flags) + self.reString = self.pattern + except sre_constants.error: + warnings.warn("invalid pattern (%s) passed to Regex" % pattern, + SyntaxWarning, stacklevel=2) + raise + + elif isinstance(pattern, Regex.compiledREtype): + self.re = pattern + self.pattern = \ + self.reString = str(pattern) + self.flags = flags + + else: + raise ValueError("Regex may only be constructed with a string or a compiled RE object") + + self.name = _ustr(self) + self.errmsg = "Expected " + self.name + self.mayIndexError = False + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + result = self.re.match(instring,loc) + if not result: + raise ParseException(instring, loc, self.errmsg, self) + + loc = result.end() + d = result.groupdict() + ret = ParseResults(result.group()) + if d: + for k in d: + ret[k] = d[k] + return loc,ret + + def __str__( self ): + try: + return super(Regex,self).__str__() + except Exception: + pass + + if self.strRepr is None: + self.strRepr = "Re:(%s)" % repr(self.pattern) + + return self.strRepr + + +class QuotedString(Token): + r""" + Token for matching strings that are delimited by quoting characters. + + Defined with the following parameters: + - quoteChar - string of one or more characters defining the quote delimiting string + - escChar - character to escape quotes, typically backslash (default=C{None}) + - escQuote - special quote sequence to escape an embedded quote string (such as SQL's "" to escape an embedded ") (default=C{None}) + - multiline - boolean indicating whether quotes can span multiple lines (default=C{False}) + - unquoteResults - boolean indicating whether the matched text should be unquoted (default=C{True}) + - endQuoteChar - string of one or more characters defining the end of the quote delimited string (default=C{None} => same as quoteChar) + - convertWhitespaceEscapes - convert escaped whitespace (C{'\t'}, C{'\n'}, etc.) to actual whitespace (default=C{True}) + + Example:: + qs = QuotedString('"') + print(qs.searchString('lsjdf "This is the quote" sldjf')) + complex_qs = QuotedString('{{', endQuoteChar='}}') + print(complex_qs.searchString('lsjdf {{This is the "quote"}} sldjf')) + sql_qs = QuotedString('"', escQuote='""') + print(sql_qs.searchString('lsjdf "This is the quote with ""embedded"" quotes" sldjf')) + prints:: + [['This is the quote']] + [['This is the "quote"']] + [['This is the quote with "embedded" quotes']] + """ + def __init__( self, quoteChar, escChar=None, escQuote=None, multiline=False, unquoteResults=True, endQuoteChar=None, convertWhitespaceEscapes=True): + super(QuotedString,self).__init__() + + # remove white space from quote chars - wont work anyway + quoteChar = quoteChar.strip() + if not quoteChar: + warnings.warn("quoteChar cannot be the empty string",SyntaxWarning,stacklevel=2) + raise SyntaxError() + + if endQuoteChar is None: + endQuoteChar = quoteChar + else: + endQuoteChar = endQuoteChar.strip() + if not endQuoteChar: + warnings.warn("endQuoteChar cannot be the empty string",SyntaxWarning,stacklevel=2) + raise SyntaxError() + + self.quoteChar = quoteChar + self.quoteCharLen = len(quoteChar) + self.firstQuoteChar = quoteChar[0] + self.endQuoteChar = endQuoteChar + self.endQuoteCharLen = len(endQuoteChar) + self.escChar = escChar + self.escQuote = escQuote + self.unquoteResults = unquoteResults + self.convertWhitespaceEscapes = convertWhitespaceEscapes + + if multiline: + self.flags = re.MULTILINE | re.DOTALL + self.pattern = r'%s(?:[^%s%s]' % \ + ( re.escape(self.quoteChar), + _escapeRegexRangeChars(self.endQuoteChar[0]), + (escChar is not None and _escapeRegexRangeChars(escChar) or '') ) + else: + self.flags = 0 + self.pattern = r'%s(?:[^%s\n\r%s]' % \ + ( re.escape(self.quoteChar), + _escapeRegexRangeChars(self.endQuoteChar[0]), + (escChar is not None and _escapeRegexRangeChars(escChar) or '') ) + if len(self.endQuoteChar) > 1: + self.pattern += ( + '|(?:' + ')|(?:'.join("%s[^%s]" % (re.escape(self.endQuoteChar[:i]), + _escapeRegexRangeChars(self.endQuoteChar[i])) + for i in range(len(self.endQuoteChar)-1,0,-1)) + ')' + ) + if escQuote: + self.pattern += (r'|(?:%s)' % re.escape(escQuote)) + if escChar: + self.pattern += (r'|(?:%s.)' % re.escape(escChar)) + self.escCharReplacePattern = re.escape(self.escChar)+"(.)" + self.pattern += (r')*%s' % re.escape(self.endQuoteChar)) + + try: + self.re = re.compile(self.pattern, self.flags) + self.reString = self.pattern + except sre_constants.error: + warnings.warn("invalid pattern (%s) passed to Regex" % self.pattern, + SyntaxWarning, stacklevel=2) + raise + + self.name = _ustr(self) + self.errmsg = "Expected " + self.name + self.mayIndexError = False + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + result = instring[loc] == self.firstQuoteChar and self.re.match(instring,loc) or None + if not result: + raise ParseException(instring, loc, self.errmsg, self) + + loc = result.end() + ret = result.group() + + if self.unquoteResults: + + # strip off quotes + ret = ret[self.quoteCharLen:-self.endQuoteCharLen] + + if isinstance(ret,basestring): + # replace escaped whitespace + if '\\' in ret and self.convertWhitespaceEscapes: + ws_map = { + r'\t' : '\t', + r'\n' : '\n', + r'\f' : '\f', + r'\r' : '\r', + } + for wslit,wschar in ws_map.items(): + ret = ret.replace(wslit, wschar) + + # replace escaped characters + if self.escChar: + ret = re.sub(self.escCharReplacePattern, r"\g<1>", ret) + + # replace escaped quotes + if self.escQuote: + ret = ret.replace(self.escQuote, self.endQuoteChar) + + return loc, ret + + def __str__( self ): + try: + return super(QuotedString,self).__str__() + except Exception: + pass + + if self.strRepr is None: + self.strRepr = "quoted string, starting with %s ending with %s" % (self.quoteChar, self.endQuoteChar) + + return self.strRepr + + +class CharsNotIn(Token): + """ + Token for matching words composed of characters I{not} in a given set (will + include whitespace in matched characters if not listed in the provided exclusion set - see example). + Defined with string containing all disallowed characters, and an optional + minimum, maximum, and/or exact length. The default value for C{min} is 1 (a + minimum value < 1 is not valid); the default values for C{max} and C{exact} + are 0, meaning no maximum or exact length restriction. + + Example:: + # define a comma-separated-value as anything that is not a ',' + csv_value = CharsNotIn(',') + print(delimitedList(csv_value).parseString("dkls,lsdkjf,s12 34,@!#,213")) + prints:: + ['dkls', 'lsdkjf', 's12 34', '@!#', '213'] + """ + def __init__( self, notChars, min=1, max=0, exact=0 ): + super(CharsNotIn,self).__init__() + self.skipWhitespace = False + self.notChars = notChars + + if min < 1: + raise ValueError("cannot specify a minimum length < 1; use Optional(CharsNotIn()) if zero-length char group is permitted") + + self.minLen = min + + if max > 0: + self.maxLen = max + else: + self.maxLen = _MAX_INT + + if exact > 0: + self.maxLen = exact + self.minLen = exact + + self.name = _ustr(self) + self.errmsg = "Expected " + self.name + self.mayReturnEmpty = ( self.minLen == 0 ) + self.mayIndexError = False + + def parseImpl( self, instring, loc, doActions=True ): + if instring[loc] in self.notChars: + raise ParseException(instring, loc, self.errmsg, self) + + start = loc + loc += 1 + notchars = self.notChars + maxlen = min( start+self.maxLen, len(instring) ) + while loc < maxlen and \ + (instring[loc] not in notchars): + loc += 1 + + if loc - start < self.minLen: + raise ParseException(instring, loc, self.errmsg, self) + + return loc, instring[start:loc] + + def __str__( self ): + try: + return super(CharsNotIn, self).__str__() + except Exception: + pass + + if self.strRepr is None: + if len(self.notChars) > 4: + self.strRepr = "!W:(%s...)" % self.notChars[:4] + else: + self.strRepr = "!W:(%s)" % self.notChars + + return self.strRepr + +class White(Token): + """ + Special matching class for matching whitespace. Normally, whitespace is ignored + by pyparsing grammars. This class is included when some whitespace structures + are significant. Define with a string containing the whitespace characters to be + matched; default is C{" \\t\\r\\n"}. Also takes optional C{min}, C{max}, and C{exact} arguments, + as defined for the C{L{Word}} class. + """ + whiteStrs = { + " " : "<SPC>", + "\t": "<TAB>", + "\n": "<LF>", + "\r": "<CR>", + "\f": "<FF>", + } + def __init__(self, ws=" \t\r\n", min=1, max=0, exact=0): + super(White,self).__init__() + self.matchWhite = ws + self.setWhitespaceChars( "".join(c for c in self.whiteChars if c not in self.matchWhite) ) + #~ self.leaveWhitespace() + self.name = ("".join(White.whiteStrs[c] for c in self.matchWhite)) + self.mayReturnEmpty = True + self.errmsg = "Expected " + self.name + + self.minLen = min + + if max > 0: + self.maxLen = max + else: + self.maxLen = _MAX_INT + + if exact > 0: + self.maxLen = exact + self.minLen = exact + + def parseImpl( self, instring, loc, doActions=True ): + if not(instring[ loc ] in self.matchWhite): + raise ParseException(instring, loc, self.errmsg, self) + start = loc + loc += 1 + maxloc = start + self.maxLen + maxloc = min( maxloc, len(instring) ) + while loc < maxloc and instring[loc] in self.matchWhite: + loc += 1 + + if loc - start < self.minLen: + raise ParseException(instring, loc, self.errmsg, self) + + return loc, instring[start:loc] + + +class _PositionToken(Token): + def __init__( self ): + super(_PositionToken,self).__init__() + self.name=self.__class__.__name__ + self.mayReturnEmpty = True + self.mayIndexError = False + +class GoToColumn(_PositionToken): + """ + Token to advance to a specific column of input text; useful for tabular report scraping. + """ + def __init__( self, colno ): + super(GoToColumn,self).__init__() + self.col = colno + + def preParse( self, instring, loc ): + if col(loc,instring) != self.col: + instrlen = len(instring) + if self.ignoreExprs: + loc = self._skipIgnorables( instring, loc ) + while loc < instrlen and instring[loc].isspace() and col( loc, instring ) != self.col : + loc += 1 + return loc + + def parseImpl( self, instring, loc, doActions=True ): + thiscol = col( loc, instring ) + if thiscol > self.col: + raise ParseException( instring, loc, "Text not in expected column", self ) + newloc = loc + self.col - thiscol + ret = instring[ loc: newloc ] + return newloc, ret + + +class LineStart(_PositionToken): + """ + Matches if current position is at the beginning of a line within the parse string + + Example:: + + test = '''\ + AAA this line + AAA and this line + AAA but not this one + B AAA and definitely not this one + ''' + + for t in (LineStart() + 'AAA' + restOfLine).searchString(test): + print(t) + + Prints:: + ['AAA', ' this line'] + ['AAA', ' and this line'] + + """ + def __init__( self ): + super(LineStart,self).__init__() + self.errmsg = "Expected start of line" + + def parseImpl( self, instring, loc, doActions=True ): + if col(loc, instring) == 1: + return loc, [] + raise ParseException(instring, loc, self.errmsg, self) + +class LineEnd(_PositionToken): + """ + Matches if current position is at the end of a line within the parse string + """ + def __init__( self ): + super(LineEnd,self).__init__() + self.setWhitespaceChars( ParserElement.DEFAULT_WHITE_CHARS.replace("\n","") ) + self.errmsg = "Expected end of line" + + def parseImpl( self, instring, loc, doActions=True ): + if loc<len(instring): + if instring[loc] == "\n": + return loc+1, "\n" + else: + raise ParseException(instring, loc, self.errmsg, self) + elif loc == len(instring): + return loc+1, [] + else: + raise ParseException(instring, loc, self.errmsg, self) + +class StringStart(_PositionToken): + """ + Matches if current position is at the beginning of the parse string + """ + def __init__( self ): + super(StringStart,self).__init__() + self.errmsg = "Expected start of text" + + def parseImpl( self, instring, loc, doActions=True ): + if loc != 0: + # see if entire string up to here is just whitespace and ignoreables + if loc != self.preParse( instring, 0 ): + raise ParseException(instring, loc, self.errmsg, self) + return loc, [] + +class StringEnd(_PositionToken): + """ + Matches if current position is at the end of the parse string + """ + def __init__( self ): + super(StringEnd,self).__init__() + self.errmsg = "Expected end of text" + + def parseImpl( self, instring, loc, doActions=True ): + if loc < len(instring): + raise ParseException(instring, loc, self.errmsg, self) + elif loc == len(instring): + return loc+1, [] + elif loc > len(instring): + return loc, [] + else: + raise ParseException(instring, loc, self.errmsg, self) + +class WordStart(_PositionToken): + """ + Matches if the current position is at the beginning of a Word, and + is not preceded by any character in a given set of C{wordChars} + (default=C{printables}). To emulate the C{\b} behavior of regular expressions, + use C{WordStart(alphanums)}. C{WordStart} will also match at the beginning of + the string being parsed, or at the beginning of a line. + """ + def __init__(self, wordChars = printables): + super(WordStart,self).__init__() + self.wordChars = set(wordChars) + self.errmsg = "Not at the start of a word" + + def parseImpl(self, instring, loc, doActions=True ): + if loc != 0: + if (instring[loc-1] in self.wordChars or + instring[loc] not in self.wordChars): + raise ParseException(instring, loc, self.errmsg, self) + return loc, [] + +class WordEnd(_PositionToken): + """ + Matches if the current position is at the end of a Word, and + is not followed by any character in a given set of C{wordChars} + (default=C{printables}). To emulate the C{\b} behavior of regular expressions, + use C{WordEnd(alphanums)}. C{WordEnd} will also match at the end of + the string being parsed, or at the end of a line. + """ + def __init__(self, wordChars = printables): + super(WordEnd,self).__init__() + self.wordChars = set(wordChars) + self.skipWhitespace = False + self.errmsg = "Not at the end of a word" + + def parseImpl(self, instring, loc, doActions=True ): + instrlen = len(instring) + if instrlen>0 and loc<instrlen: + if (instring[loc] in self.wordChars or + instring[loc-1] not in self.wordChars): + raise ParseException(instring, loc, self.errmsg, self) + return loc, [] + + +class ParseExpression(ParserElement): + """ + Abstract subclass of ParserElement, for combining and post-processing parsed tokens. + """ + def __init__( self, exprs, savelist = False ): + super(ParseExpression,self).__init__(savelist) + if isinstance( exprs, _generatorType ): + exprs = list(exprs) + + if isinstance( exprs, basestring ): + self.exprs = [ ParserElement._literalStringClass( exprs ) ] + elif isinstance( exprs, Iterable ): + exprs = list(exprs) + # if sequence of strings provided, wrap with Literal + if all(isinstance(expr, basestring) for expr in exprs): + exprs = map(ParserElement._literalStringClass, exprs) + self.exprs = list(exprs) + else: + try: + self.exprs = list( exprs ) + except TypeError: + self.exprs = [ exprs ] + self.callPreparse = False + + def __getitem__( self, i ): + return self.exprs[i] + + def append( self, other ): + self.exprs.append( other ) + self.strRepr = None + return self + + def leaveWhitespace( self ): + """Extends C{leaveWhitespace} defined in base class, and also invokes C{leaveWhitespace} on + all contained expressions.""" + self.skipWhitespace = False + self.exprs = [ e.copy() for e in self.exprs ] + for e in self.exprs: + e.leaveWhitespace() + return self + + def ignore( self, other ): + if isinstance( other, Suppress ): + if other not in self.ignoreExprs: + super( ParseExpression, self).ignore( other ) + for e in self.exprs: + e.ignore( self.ignoreExprs[-1] ) + else: + super( ParseExpression, self).ignore( other ) + for e in self.exprs: + e.ignore( self.ignoreExprs[-1] ) + return self + + def __str__( self ): + try: + return super(ParseExpression,self).__str__() + except Exception: + pass + + if self.strRepr is None: + self.strRepr = "%s:(%s)" % ( self.__class__.__name__, _ustr(self.exprs) ) + return self.strRepr + + def streamline( self ): + super(ParseExpression,self).streamline() + + for e in self.exprs: + e.streamline() + + # collapse nested And's of the form And( And( And( a,b), c), d) to And( a,b,c,d ) + # but only if there are no parse actions or resultsNames on the nested And's + # (likewise for Or's and MatchFirst's) + if ( len(self.exprs) == 2 ): + other = self.exprs[0] + if ( isinstance( other, self.__class__ ) and + not(other.parseAction) and + other.resultsName is None and + not other.debug ): + self.exprs = other.exprs[:] + [ self.exprs[1] ] + self.strRepr = None + self.mayReturnEmpty |= other.mayReturnEmpty + self.mayIndexError |= other.mayIndexError + + other = self.exprs[-1] + if ( isinstance( other, self.__class__ ) and + not(other.parseAction) and + other.resultsName is None and + not other.debug ): + self.exprs = self.exprs[:-1] + other.exprs[:] + self.strRepr = None + self.mayReturnEmpty |= other.mayReturnEmpty + self.mayIndexError |= other.mayIndexError + + self.errmsg = "Expected " + _ustr(self) + + return self + + def setResultsName( self, name, listAllMatches=False ): + ret = super(ParseExpression,self).setResultsName(name,listAllMatches) + return ret + + def validate( self, validateTrace=[] ): + tmp = validateTrace[:]+[self] + for e in self.exprs: + e.validate(tmp) + self.checkRecursion( [] ) + + def copy(self): + ret = super(ParseExpression,self).copy() + ret.exprs = [e.copy() for e in self.exprs] + return ret + +class And(ParseExpression): + """ + Requires all given C{ParseExpression}s to be found in the given order. + Expressions may be separated by whitespace. + May be constructed using the C{'+'} operator. + May also be constructed using the C{'-'} operator, which will suppress backtracking. + + Example:: + integer = Word(nums) + name_expr = OneOrMore(Word(alphas)) + + expr = And([integer("id"),name_expr("name"),integer("age")]) + # more easily written as: + expr = integer("id") + name_expr("name") + integer("age") + """ + + class _ErrorStop(Empty): + def __init__(self, *args, **kwargs): + super(And._ErrorStop,self).__init__(*args, **kwargs) + self.name = '-' + self.leaveWhitespace() + + def __init__( self, exprs, savelist = True ): + super(And,self).__init__(exprs, savelist) + self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) + self.setWhitespaceChars( self.exprs[0].whiteChars ) + self.skipWhitespace = self.exprs[0].skipWhitespace + self.callPreparse = True + + def parseImpl( self, instring, loc, doActions=True ): + # pass False as last arg to _parse for first element, since we already + # pre-parsed the string as part of our And pre-parsing + loc, resultlist = self.exprs[0]._parse( instring, loc, doActions, callPreParse=False ) + errorStop = False + for e in self.exprs[1:]: + if isinstance(e, And._ErrorStop): + errorStop = True + continue + if errorStop: + try: + loc, exprtokens = e._parse( instring, loc, doActions ) + except ParseSyntaxException: + raise + except ParseBaseException as pe: + pe.__traceback__ = None + raise ParseSyntaxException._from_exception(pe) + except IndexError: + raise ParseSyntaxException(instring, len(instring), self.errmsg, self) + else: + loc, exprtokens = e._parse( instring, loc, doActions ) + if exprtokens or exprtokens.haskeys(): + resultlist += exprtokens + return loc, resultlist + + def __iadd__(self, other ): + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + return self.append( other ) #And( [ self, other ] ) + + def checkRecursion( self, parseElementList ): + subRecCheckList = parseElementList[:] + [ self ] + for e in self.exprs: + e.checkRecursion( subRecCheckList ) + if not e.mayReturnEmpty: + break + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "{" + " ".join(_ustr(e) for e in self.exprs) + "}" + + return self.strRepr + + +class Or(ParseExpression): + """ + Requires that at least one C{ParseExpression} is found. + If two expressions match, the expression that matches the longest string will be used. + May be constructed using the C{'^'} operator. + + Example:: + # construct Or using '^' operator + + number = Word(nums) ^ Combine(Word(nums) + '.' + Word(nums)) + print(number.searchString("123 3.1416 789")) + prints:: + [['123'], ['3.1416'], ['789']] + """ + def __init__( self, exprs, savelist = False ): + super(Or,self).__init__(exprs, savelist) + if self.exprs: + self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs) + else: + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + maxExcLoc = -1 + maxException = None + matches = [] + for e in self.exprs: + try: + loc2 = e.tryParse( instring, loc ) + except ParseException as err: + err.__traceback__ = None + if err.loc > maxExcLoc: + maxException = err + maxExcLoc = err.loc + except IndexError: + if len(instring) > maxExcLoc: + maxException = ParseException(instring,len(instring),e.errmsg,self) + maxExcLoc = len(instring) + else: + # save match among all matches, to retry longest to shortest + matches.append((loc2, e)) + + if matches: + matches.sort(key=lambda x: -x[0]) + for _,e in matches: + try: + return e._parse( instring, loc, doActions ) + except ParseException as err: + err.__traceback__ = None + if err.loc > maxExcLoc: + maxException = err + maxExcLoc = err.loc + + if maxException is not None: + maxException.msg = self.errmsg + raise maxException + else: + raise ParseException(instring, loc, "no defined alternatives to match", self) + + + def __ixor__(self, other ): + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + return self.append( other ) #Or( [ self, other ] ) + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "{" + " ^ ".join(_ustr(e) for e in self.exprs) + "}" + + return self.strRepr + + def checkRecursion( self, parseElementList ): + subRecCheckList = parseElementList[:] + [ self ] + for e in self.exprs: + e.checkRecursion( subRecCheckList ) + + +class MatchFirst(ParseExpression): + """ + Requires that at least one C{ParseExpression} is found. + If two expressions match, the first one listed is the one that will match. + May be constructed using the C{'|'} operator. + + Example:: + # construct MatchFirst using '|' operator + + # watch the order of expressions to match + number = Word(nums) | Combine(Word(nums) + '.' + Word(nums)) + print(number.searchString("123 3.1416 789")) # Fail! -> [['123'], ['3'], ['1416'], ['789']] + + # put more selective expression first + number = Combine(Word(nums) + '.' + Word(nums)) | Word(nums) + print(number.searchString("123 3.1416 789")) # Better -> [['123'], ['3.1416'], ['789']] + """ + def __init__( self, exprs, savelist = False ): + super(MatchFirst,self).__init__(exprs, savelist) + if self.exprs: + self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs) + else: + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + maxExcLoc = -1 + maxException = None + for e in self.exprs: + try: + ret = e._parse( instring, loc, doActions ) + return ret + except ParseException as err: + if err.loc > maxExcLoc: + maxException = err + maxExcLoc = err.loc + except IndexError: + if len(instring) > maxExcLoc: + maxException = ParseException(instring,len(instring),e.errmsg,self) + maxExcLoc = len(instring) + + # only got here if no expression matched, raise exception for match that made it the furthest + else: + if maxException is not None: + maxException.msg = self.errmsg + raise maxException + else: + raise ParseException(instring, loc, "no defined alternatives to match", self) + + def __ior__(self, other ): + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + return self.append( other ) #MatchFirst( [ self, other ] ) + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "{" + " | ".join(_ustr(e) for e in self.exprs) + "}" + + return self.strRepr + + def checkRecursion( self, parseElementList ): + subRecCheckList = parseElementList[:] + [ self ] + for e in self.exprs: + e.checkRecursion( subRecCheckList ) + + +class Each(ParseExpression): + """ + Requires all given C{ParseExpression}s to be found, but in any order. + Expressions may be separated by whitespace. + May be constructed using the C{'&'} operator. + + Example:: + color = oneOf("RED ORANGE YELLOW GREEN BLUE PURPLE BLACK WHITE BROWN") + shape_type = oneOf("SQUARE CIRCLE TRIANGLE STAR HEXAGON OCTAGON") + integer = Word(nums) + shape_attr = "shape:" + shape_type("shape") + posn_attr = "posn:" + Group(integer("x") + ',' + integer("y"))("posn") + color_attr = "color:" + color("color") + size_attr = "size:" + integer("size") + + # use Each (using operator '&') to accept attributes in any order + # (shape and posn are required, color and size are optional) + shape_spec = shape_attr & posn_attr & Optional(color_attr) & Optional(size_attr) + + shape_spec.runTests(''' + shape: SQUARE color: BLACK posn: 100, 120 + shape: CIRCLE size: 50 color: BLUE posn: 50,80 + color:GREEN size:20 shape:TRIANGLE posn:20,40 + ''' + ) + prints:: + shape: SQUARE color: BLACK posn: 100, 120 + ['shape:', 'SQUARE', 'color:', 'BLACK', 'posn:', ['100', ',', '120']] + - color: BLACK + - posn: ['100', ',', '120'] + - x: 100 + - y: 120 + - shape: SQUARE + + + shape: CIRCLE size: 50 color: BLUE posn: 50,80 + ['shape:', 'CIRCLE', 'size:', '50', 'color:', 'BLUE', 'posn:', ['50', ',', '80']] + - color: BLUE + - posn: ['50', ',', '80'] + - x: 50 + - y: 80 + - shape: CIRCLE + - size: 50 + + + color: GREEN size: 20 shape: TRIANGLE posn: 20,40 + ['color:', 'GREEN', 'size:', '20', 'shape:', 'TRIANGLE', 'posn:', ['20', ',', '40']] + - color: GREEN + - posn: ['20', ',', '40'] + - x: 20 + - y: 40 + - shape: TRIANGLE + - size: 20 + """ + def __init__( self, exprs, savelist = True ): + super(Each,self).__init__(exprs, savelist) + self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) + self.skipWhitespace = True + self.initExprGroups = True + + def parseImpl( self, instring, loc, doActions=True ): + if self.initExprGroups: + self.opt1map = dict((id(e.expr),e) for e in self.exprs if isinstance(e,Optional)) + opt1 = [ e.expr for e in self.exprs if isinstance(e,Optional) ] + opt2 = [ e for e in self.exprs if e.mayReturnEmpty and not isinstance(e,Optional)] + self.optionals = opt1 + opt2 + self.multioptionals = [ e.expr for e in self.exprs if isinstance(e,ZeroOrMore) ] + self.multirequired = [ e.expr for e in self.exprs if isinstance(e,OneOrMore) ] + self.required = [ e for e in self.exprs if not isinstance(e,(Optional,ZeroOrMore,OneOrMore)) ] + self.required += self.multirequired + self.initExprGroups = False + tmpLoc = loc + tmpReqd = self.required[:] + tmpOpt = self.optionals[:] + matchOrder = [] + + keepMatching = True + while keepMatching: + tmpExprs = tmpReqd + tmpOpt + self.multioptionals + self.multirequired + failed = [] + for e in tmpExprs: + try: + tmpLoc = e.tryParse( instring, tmpLoc ) + except ParseException: + failed.append(e) + else: + matchOrder.append(self.opt1map.get(id(e),e)) + if e in tmpReqd: + tmpReqd.remove(e) + elif e in tmpOpt: + tmpOpt.remove(e) + if len(failed) == len(tmpExprs): + keepMatching = False + + if tmpReqd: + missing = ", ".join(_ustr(e) for e in tmpReqd) + raise ParseException(instring,loc,"Missing one or more required elements (%s)" % missing ) + + # add any unmatched Optionals, in case they have default values defined + matchOrder += [e for e in self.exprs if isinstance(e,Optional) and e.expr in tmpOpt] + + resultlist = [] + for e in matchOrder: + loc,results = e._parse(instring,loc,doActions) + resultlist.append(results) + + finalResults = sum(resultlist, ParseResults([])) + return loc, finalResults + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "{" + " & ".join(_ustr(e) for e in self.exprs) + "}" + + return self.strRepr + + def checkRecursion( self, parseElementList ): + subRecCheckList = parseElementList[:] + [ self ] + for e in self.exprs: + e.checkRecursion( subRecCheckList ) + + +class ParseElementEnhance(ParserElement): + """ + Abstract subclass of C{ParserElement}, for combining and post-processing parsed tokens. + """ + def __init__( self, expr, savelist=False ): + super(ParseElementEnhance,self).__init__(savelist) + if isinstance( expr, basestring ): + if issubclass(ParserElement._literalStringClass, Token): + expr = ParserElement._literalStringClass(expr) + else: + expr = ParserElement._literalStringClass(Literal(expr)) + self.expr = expr + self.strRepr = None + if expr is not None: + self.mayIndexError = expr.mayIndexError + self.mayReturnEmpty = expr.mayReturnEmpty + self.setWhitespaceChars( expr.whiteChars ) + self.skipWhitespace = expr.skipWhitespace + self.saveAsList = expr.saveAsList + self.callPreparse = expr.callPreparse + self.ignoreExprs.extend(expr.ignoreExprs) + + def parseImpl( self, instring, loc, doActions=True ): + if self.expr is not None: + return self.expr._parse( instring, loc, doActions, callPreParse=False ) + else: + raise ParseException("",loc,self.errmsg,self) + + def leaveWhitespace( self ): + self.skipWhitespace = False + self.expr = self.expr.copy() + if self.expr is not None: + self.expr.leaveWhitespace() + return self + + def ignore( self, other ): + if isinstance( other, Suppress ): + if other not in self.ignoreExprs: + super( ParseElementEnhance, self).ignore( other ) + if self.expr is not None: + self.expr.ignore( self.ignoreExprs[-1] ) + else: + super( ParseElementEnhance, self).ignore( other ) + if self.expr is not None: + self.expr.ignore( self.ignoreExprs[-1] ) + return self + + def streamline( self ): + super(ParseElementEnhance,self).streamline() + if self.expr is not None: + self.expr.streamline() + return self + + def checkRecursion( self, parseElementList ): + if self in parseElementList: + raise RecursiveGrammarException( parseElementList+[self] ) + subRecCheckList = parseElementList[:] + [ self ] + if self.expr is not None: + self.expr.checkRecursion( subRecCheckList ) + + def validate( self, validateTrace=[] ): + tmp = validateTrace[:]+[self] + if self.expr is not None: + self.expr.validate(tmp) + self.checkRecursion( [] ) + + def __str__( self ): + try: + return super(ParseElementEnhance,self).__str__() + except Exception: + pass + + if self.strRepr is None and self.expr is not None: + self.strRepr = "%s:(%s)" % ( self.__class__.__name__, _ustr(self.expr) ) + return self.strRepr + + +class FollowedBy(ParseElementEnhance): + """ + Lookahead matching of the given parse expression. C{FollowedBy} + does I{not} advance the parsing position within the input string, it only + verifies that the specified parse expression matches at the current + position. C{FollowedBy} always returns a null token list. + + Example:: + # use FollowedBy to match a label only if it is followed by a ':' + data_word = Word(alphas) + label = data_word + FollowedBy(':') + attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) + + OneOrMore(attr_expr).parseString("shape: SQUARE color: BLACK posn: upper left").pprint() + prints:: + [['shape', 'SQUARE'], ['color', 'BLACK'], ['posn', 'upper left']] + """ + def __init__( self, expr ): + super(FollowedBy,self).__init__(expr) + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + self.expr.tryParse( instring, loc ) + return loc, [] + + +class NotAny(ParseElementEnhance): + """ + Lookahead to disallow matching with the given parse expression. C{NotAny} + does I{not} advance the parsing position within the input string, it only + verifies that the specified parse expression does I{not} match at the current + position. Also, C{NotAny} does I{not} skip over leading whitespace. C{NotAny} + always returns a null token list. May be constructed using the '~' operator. + + Example:: + + """ + def __init__( self, expr ): + super(NotAny,self).__init__(expr) + #~ self.leaveWhitespace() + self.skipWhitespace = False # do NOT use self.leaveWhitespace(), don't want to propagate to exprs + self.mayReturnEmpty = True + self.errmsg = "Found unwanted token, "+_ustr(self.expr) + + def parseImpl( self, instring, loc, doActions=True ): + if self.expr.canParseNext(instring, loc): + raise ParseException(instring, loc, self.errmsg, self) + return loc, [] + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "~{" + _ustr(self.expr) + "}" + + return self.strRepr + +class _MultipleMatch(ParseElementEnhance): + def __init__( self, expr, stopOn=None): + super(_MultipleMatch, self).__init__(expr) + self.saveAsList = True + ender = stopOn + if isinstance(ender, basestring): + ender = ParserElement._literalStringClass(ender) + self.not_ender = ~ender if ender is not None else None + + def parseImpl( self, instring, loc, doActions=True ): + self_expr_parse = self.expr._parse + self_skip_ignorables = self._skipIgnorables + check_ender = self.not_ender is not None + if check_ender: + try_not_ender = self.not_ender.tryParse + + # must be at least one (but first see if we are the stopOn sentinel; + # if so, fail) + if check_ender: + try_not_ender(instring, loc) + loc, tokens = self_expr_parse( instring, loc, doActions, callPreParse=False ) + try: + hasIgnoreExprs = (not not self.ignoreExprs) + while 1: + if check_ender: + try_not_ender(instring, loc) + if hasIgnoreExprs: + preloc = self_skip_ignorables( instring, loc ) + else: + preloc = loc + loc, tmptokens = self_expr_parse( instring, preloc, doActions ) + if tmptokens or tmptokens.haskeys(): + tokens += tmptokens + except (ParseException,IndexError): + pass + + return loc, tokens + +class OneOrMore(_MultipleMatch): + """ + Repetition of one or more of the given expression. + + Parameters: + - expr - expression that must match one or more times + - stopOn - (default=C{None}) - expression for a terminating sentinel + (only required if the sentinel would ordinarily match the repetition + expression) + + Example:: + data_word = Word(alphas) + label = data_word + FollowedBy(':') + attr_expr = Group(label + Suppress(':') + OneOrMore(data_word).setParseAction(' '.join)) + + text = "shape: SQUARE posn: upper left color: BLACK" + OneOrMore(attr_expr).parseString(text).pprint() # Fail! read 'color' as data instead of next label -> [['shape', 'SQUARE color']] + + # use stopOn attribute for OneOrMore to avoid reading label string as part of the data + attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) + OneOrMore(attr_expr).parseString(text).pprint() # Better -> [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'BLACK']] + + # could also be written as + (attr_expr * (1,)).parseString(text).pprint() + """ + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "{" + _ustr(self.expr) + "}..." + + return self.strRepr + +class ZeroOrMore(_MultipleMatch): + """ + Optional repetition of zero or more of the given expression. + + Parameters: + - expr - expression that must match zero or more times + - stopOn - (default=C{None}) - expression for a terminating sentinel + (only required if the sentinel would ordinarily match the repetition + expression) + + Example: similar to L{OneOrMore} + """ + def __init__( self, expr, stopOn=None): + super(ZeroOrMore,self).__init__(expr, stopOn=stopOn) + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + try: + return super(ZeroOrMore, self).parseImpl(instring, loc, doActions) + except (ParseException,IndexError): + return loc, [] + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "[" + _ustr(self.expr) + "]..." + + return self.strRepr + +class _NullToken(object): + def __bool__(self): + return False + __nonzero__ = __bool__ + def __str__(self): + return "" + +_optionalNotMatched = _NullToken() +class Optional(ParseElementEnhance): + """ + Optional matching of the given expression. + + Parameters: + - expr - expression that must match zero or more times + - default (optional) - value to be returned if the optional expression is not found. + + Example:: + # US postal code can be a 5-digit zip, plus optional 4-digit qualifier + zip = Combine(Word(nums, exact=5) + Optional('-' + Word(nums, exact=4))) + zip.runTests(''' + # traditional ZIP code + 12345 + + # ZIP+4 form + 12101-0001 + + # invalid ZIP + 98765- + ''') + prints:: + # traditional ZIP code + 12345 + ['12345'] + + # ZIP+4 form + 12101-0001 + ['12101-0001'] + + # invalid ZIP + 98765- + ^ + FAIL: Expected end of text (at char 5), (line:1, col:6) + """ + def __init__( self, expr, default=_optionalNotMatched ): + super(Optional,self).__init__( expr, savelist=False ) + self.saveAsList = self.expr.saveAsList + self.defaultValue = default + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + try: + loc, tokens = self.expr._parse( instring, loc, doActions, callPreParse=False ) + except (ParseException,IndexError): + if self.defaultValue is not _optionalNotMatched: + if self.expr.resultsName: + tokens = ParseResults([ self.defaultValue ]) + tokens[self.expr.resultsName] = self.defaultValue + else: + tokens = [ self.defaultValue ] + else: + tokens = [] + return loc, tokens + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "[" + _ustr(self.expr) + "]" + + return self.strRepr + +class SkipTo(ParseElementEnhance): + """ + Token for skipping over all undefined text until the matched expression is found. + + Parameters: + - expr - target expression marking the end of the data to be skipped + - include - (default=C{False}) if True, the target expression is also parsed + (the skipped text and target expression are returned as a 2-element list). + - ignore - (default=C{None}) used to define grammars (typically quoted strings and + comments) that might contain false matches to the target expression + - failOn - (default=C{None}) define expressions that are not allowed to be + included in the skipped test; if found before the target expression is found, + the SkipTo is not a match + + Example:: + report = ''' + Outstanding Issues Report - 1 Jan 2000 + + # | Severity | Description | Days Open + -----+----------+-------------------------------------------+----------- + 101 | Critical | Intermittent system crash | 6 + 94 | Cosmetic | Spelling error on Login ('log|n') | 14 + 79 | Minor | System slow when running too many reports | 47 + ''' + integer = Word(nums) + SEP = Suppress('|') + # use SkipTo to simply match everything up until the next SEP + # - ignore quoted strings, so that a '|' character inside a quoted string does not match + # - parse action will call token.strip() for each matched token, i.e., the description body + string_data = SkipTo(SEP, ignore=quotedString) + string_data.setParseAction(tokenMap(str.strip)) + ticket_expr = (integer("issue_num") + SEP + + string_data("sev") + SEP + + string_data("desc") + SEP + + integer("days_open")) + + for tkt in ticket_expr.searchString(report): + print tkt.dump() + prints:: + ['101', 'Critical', 'Intermittent system crash', '6'] + - days_open: 6 + - desc: Intermittent system crash + - issue_num: 101 + - sev: Critical + ['94', 'Cosmetic', "Spelling error on Login ('log|n')", '14'] + - days_open: 14 + - desc: Spelling error on Login ('log|n') + - issue_num: 94 + - sev: Cosmetic + ['79', 'Minor', 'System slow when running too many reports', '47'] + - days_open: 47 + - desc: System slow when running too many reports + - issue_num: 79 + - sev: Minor + """ + def __init__( self, other, include=False, ignore=None, failOn=None ): + super( SkipTo, self ).__init__( other ) + self.ignoreExpr = ignore + self.mayReturnEmpty = True + self.mayIndexError = False + self.includeMatch = include + self.asList = False + if isinstance(failOn, basestring): + self.failOn = ParserElement._literalStringClass(failOn) + else: + self.failOn = failOn + self.errmsg = "No match found for "+_ustr(self.expr) + + def parseImpl( self, instring, loc, doActions=True ): + startloc = loc + instrlen = len(instring) + expr = self.expr + expr_parse = self.expr._parse + self_failOn_canParseNext = self.failOn.canParseNext if self.failOn is not None else None + self_ignoreExpr_tryParse = self.ignoreExpr.tryParse if self.ignoreExpr is not None else None + + tmploc = loc + while tmploc <= instrlen: + if self_failOn_canParseNext is not None: + # break if failOn expression matches + if self_failOn_canParseNext(instring, tmploc): + break + + if self_ignoreExpr_tryParse is not None: + # advance past ignore expressions + while 1: + try: + tmploc = self_ignoreExpr_tryParse(instring, tmploc) + except ParseBaseException: + break + + try: + expr_parse(instring, tmploc, doActions=False, callPreParse=False) + except (ParseException, IndexError): + # no match, advance loc in string + tmploc += 1 + else: + # matched skipto expr, done + break + + else: + # ran off the end of the input string without matching skipto expr, fail + raise ParseException(instring, loc, self.errmsg, self) + + # build up return values + loc = tmploc + skiptext = instring[startloc:loc] + skipresult = ParseResults(skiptext) + + if self.includeMatch: + loc, mat = expr_parse(instring,loc,doActions,callPreParse=False) + skipresult += mat + + return loc, skipresult + +class Forward(ParseElementEnhance): + """ + Forward declaration of an expression to be defined later - + used for recursive grammars, such as algebraic infix notation. + When the expression is known, it is assigned to the C{Forward} variable using the '<<' operator. + + Note: take care when assigning to C{Forward} not to overlook precedence of operators. + Specifically, '|' has a lower precedence than '<<', so that:: + fwdExpr << a | b | c + will actually be evaluated as:: + (fwdExpr << a) | b | c + thereby leaving b and c out as parseable alternatives. It is recommended that you + explicitly group the values inserted into the C{Forward}:: + fwdExpr << (a | b | c) + Converting to use the '<<=' operator instead will avoid this problem. + + See L{ParseResults.pprint} for an example of a recursive parser created using + C{Forward}. + """ + def __init__( self, other=None ): + super(Forward,self).__init__( other, savelist=False ) + + def __lshift__( self, other ): + if isinstance( other, basestring ): + other = ParserElement._literalStringClass(other) + self.expr = other + self.strRepr = None + self.mayIndexError = self.expr.mayIndexError + self.mayReturnEmpty = self.expr.mayReturnEmpty + self.setWhitespaceChars( self.expr.whiteChars ) + self.skipWhitespace = self.expr.skipWhitespace + self.saveAsList = self.expr.saveAsList + self.ignoreExprs.extend(self.expr.ignoreExprs) + return self + + def __ilshift__(self, other): + return self << other + + def leaveWhitespace( self ): + self.skipWhitespace = False + return self + + def streamline( self ): + if not self.streamlined: + self.streamlined = True + if self.expr is not None: + self.expr.streamline() + return self + + def validate( self, validateTrace=[] ): + if self not in validateTrace: + tmp = validateTrace[:]+[self] + if self.expr is not None: + self.expr.validate(tmp) + self.checkRecursion([]) + + def __str__( self ): + if hasattr(self,"name"): + return self.name + return self.__class__.__name__ + ": ..." + + # stubbed out for now - creates awful memory and perf issues + self._revertClass = self.__class__ + self.__class__ = _ForwardNoRecurse + try: + if self.expr is not None: + retString = _ustr(self.expr) + else: + retString = "None" + finally: + self.__class__ = self._revertClass + return self.__class__.__name__ + ": " + retString + + def copy(self): + if self.expr is not None: + return super(Forward,self).copy() + else: + ret = Forward() + ret <<= self + return ret + +class _ForwardNoRecurse(Forward): + def __str__( self ): + return "..." + +class TokenConverter(ParseElementEnhance): + """ + Abstract subclass of C{ParseExpression}, for converting parsed results. + """ + def __init__( self, expr, savelist=False ): + super(TokenConverter,self).__init__( expr )#, savelist ) + self.saveAsList = False + +class Combine(TokenConverter): + """ + Converter to concatenate all matching tokens to a single string. + By default, the matching patterns must also be contiguous in the input string; + this can be disabled by specifying C{'adjacent=False'} in the constructor. + + Example:: + real = Word(nums) + '.' + Word(nums) + print(real.parseString('3.1416')) # -> ['3', '.', '1416'] + # will also erroneously match the following + print(real.parseString('3. 1416')) # -> ['3', '.', '1416'] + + real = Combine(Word(nums) + '.' + Word(nums)) + print(real.parseString('3.1416')) # -> ['3.1416'] + # no match when there are internal spaces + print(real.parseString('3. 1416')) # -> Exception: Expected W:(0123...) + """ + def __init__( self, expr, joinString="", adjacent=True ): + super(Combine,self).__init__( expr ) + # suppress whitespace-stripping in contained parse expressions, but re-enable it on the Combine itself + if adjacent: + self.leaveWhitespace() + self.adjacent = adjacent + self.skipWhitespace = True + self.joinString = joinString + self.callPreparse = True + + def ignore( self, other ): + if self.adjacent: + ParserElement.ignore(self, other) + else: + super( Combine, self).ignore( other ) + return self + + def postParse( self, instring, loc, tokenlist ): + retToks = tokenlist.copy() + del retToks[:] + retToks += ParseResults([ "".join(tokenlist._asStringList(self.joinString)) ], modal=self.modalResults) + + if self.resultsName and retToks.haskeys(): + return [ retToks ] + else: + return retToks + +class Group(TokenConverter): + """ + Converter to return the matched tokens as a list - useful for returning tokens of C{L{ZeroOrMore}} and C{L{OneOrMore}} expressions. + + Example:: + ident = Word(alphas) + num = Word(nums) + term = ident | num + func = ident + Optional(delimitedList(term)) + print(func.parseString("fn a,b,100")) # -> ['fn', 'a', 'b', '100'] + + func = ident + Group(Optional(delimitedList(term))) + print(func.parseString("fn a,b,100")) # -> ['fn', ['a', 'b', '100']] + """ + def __init__( self, expr ): + super(Group,self).__init__( expr ) + self.saveAsList = True + + def postParse( self, instring, loc, tokenlist ): + return [ tokenlist ] + +class Dict(TokenConverter): + """ + Converter to return a repetitive expression as a list, but also as a dictionary. + Each element can also be referenced using the first token in the expression as its key. + Useful for tabular report scraping when the first column can be used as a item key. + + Example:: + data_word = Word(alphas) + label = data_word + FollowedBy(':') + attr_expr = Group(label + Suppress(':') + OneOrMore(data_word).setParseAction(' '.join)) + + text = "shape: SQUARE posn: upper left color: light blue texture: burlap" + attr_expr = (label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) + + # print attributes as plain groups + print(OneOrMore(attr_expr).parseString(text).dump()) + + # instead of OneOrMore(expr), parse using Dict(OneOrMore(Group(expr))) - Dict will auto-assign names + result = Dict(OneOrMore(Group(attr_expr))).parseString(text) + print(result.dump()) + + # access named fields as dict entries, or output as dict + print(result['shape']) + print(result.asDict()) + prints:: + ['shape', 'SQUARE', 'posn', 'upper left', 'color', 'light blue', 'texture', 'burlap'] + + [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']] + - color: light blue + - posn: upper left + - shape: SQUARE + - texture: burlap + SQUARE + {'color': 'light blue', 'posn': 'upper left', 'texture': 'burlap', 'shape': 'SQUARE'} + See more examples at L{ParseResults} of accessing fields by results name. + """ + def __init__( self, expr ): + super(Dict,self).__init__( expr ) + self.saveAsList = True + + def postParse( self, instring, loc, tokenlist ): + for i,tok in enumerate(tokenlist): + if len(tok) == 0: + continue + ikey = tok[0] + if isinstance(ikey,int): + ikey = _ustr(tok[0]).strip() + if len(tok)==1: + tokenlist[ikey] = _ParseResultsWithOffset("",i) + elif len(tok)==2 and not isinstance(tok[1],ParseResults): + tokenlist[ikey] = _ParseResultsWithOffset(tok[1],i) + else: + dictvalue = tok.copy() #ParseResults(i) + del dictvalue[0] + if len(dictvalue)!= 1 or (isinstance(dictvalue,ParseResults) and dictvalue.haskeys()): + tokenlist[ikey] = _ParseResultsWithOffset(dictvalue,i) + else: + tokenlist[ikey] = _ParseResultsWithOffset(dictvalue[0],i) + + if self.resultsName: + return [ tokenlist ] + else: + return tokenlist + + +class Suppress(TokenConverter): + """ + Converter for ignoring the results of a parsed expression. + + Example:: + source = "a, b, c,d" + wd = Word(alphas) + wd_list1 = wd + ZeroOrMore(',' + wd) + print(wd_list1.parseString(source)) + + # often, delimiters that are useful during parsing are just in the + # way afterward - use Suppress to keep them out of the parsed output + wd_list2 = wd + ZeroOrMore(Suppress(',') + wd) + print(wd_list2.parseString(source)) + prints:: + ['a', ',', 'b', ',', 'c', ',', 'd'] + ['a', 'b', 'c', 'd'] + (See also L{delimitedList}.) + """ + def postParse( self, instring, loc, tokenlist ): + return [] + + def suppress( self ): + return self + + +class OnlyOnce(object): + """ + Wrapper for parse actions, to ensure they are only called once. + """ + def __init__(self, methodCall): + self.callable = _trim_arity(methodCall) + self.called = False + def __call__(self,s,l,t): + if not self.called: + results = self.callable(s,l,t) + self.called = True + return results + raise ParseException(s,l,"") + def reset(self): + self.called = False + +def traceParseAction(f): + """ + Decorator for debugging parse actions. + + When the parse action is called, this decorator will print C{">> entering I{method-name}(line:I{current_source_line}, I{parse_location}, I{matched_tokens})".} + When the parse action completes, the decorator will print C{"<<"} followed by the returned value, or any exception that the parse action raised. + + Example:: + wd = Word(alphas) + + @traceParseAction + def remove_duplicate_chars(tokens): + return ''.join(sorted(set(''.join(tokens)))) + + wds = OneOrMore(wd).setParseAction(remove_duplicate_chars) + print(wds.parseString("slkdjs sld sldd sdlf sdljf")) + prints:: + >>entering remove_duplicate_chars(line: 'slkdjs sld sldd sdlf sdljf', 0, (['slkdjs', 'sld', 'sldd', 'sdlf', 'sdljf'], {})) + <<leaving remove_duplicate_chars (ret: 'dfjkls') + ['dfjkls'] + """ + f = _trim_arity(f) + def z(*paArgs): + thisFunc = f.__name__ + s,l,t = paArgs[-3:] + if len(paArgs)>3: + thisFunc = paArgs[0].__class__.__name__ + '.' + thisFunc + sys.stderr.write( ">>entering %s(line: '%s', %d, %r)\n" % (thisFunc,line(l,s),l,t) ) + try: + ret = f(*paArgs) + except Exception as exc: + sys.stderr.write( "<<leaving %s (exception: %s)\n" % (thisFunc,exc) ) + raise + sys.stderr.write( "<<leaving %s (ret: %r)\n" % (thisFunc,ret) ) + return ret + try: + z.__name__ = f.__name__ + except AttributeError: + pass + return z + +# +# global helpers +# +def delimitedList( expr, delim=",", combine=False ): + """ + Helper to define a delimited list of expressions - the delimiter defaults to ','. + By default, the list elements and delimiters can have intervening whitespace, and + comments, but this can be overridden by passing C{combine=True} in the constructor. + If C{combine} is set to C{True}, the matching tokens are returned as a single token + string, with the delimiters included; otherwise, the matching tokens are returned + as a list of tokens, with the delimiters suppressed. + + Example:: + delimitedList(Word(alphas)).parseString("aa,bb,cc") # -> ['aa', 'bb', 'cc'] + delimitedList(Word(hexnums), delim=':', combine=True).parseString("AA:BB:CC:DD:EE") # -> ['AA:BB:CC:DD:EE'] + """ + dlName = _ustr(expr)+" ["+_ustr(delim)+" "+_ustr(expr)+"]..." + if combine: + return Combine( expr + ZeroOrMore( delim + expr ) ).setName(dlName) + else: + return ( expr + ZeroOrMore( Suppress( delim ) + expr ) ).setName(dlName) + +def countedArray( expr, intExpr=None ): + """ + Helper to define a counted list of expressions. + This helper defines a pattern of the form:: + integer expr expr expr... + where the leading integer tells how many expr expressions follow. + The matched tokens returns the array of expr tokens as a list - the leading count token is suppressed. + + If C{intExpr} is specified, it should be a pyparsing expression that produces an integer value. + + Example:: + countedArray(Word(alphas)).parseString('2 ab cd ef') # -> ['ab', 'cd'] + + # in this parser, the leading integer value is given in binary, + # '10' indicating that 2 values are in the array + binaryConstant = Word('01').setParseAction(lambda t: int(t[0], 2)) + countedArray(Word(alphas), intExpr=binaryConstant).parseString('10 ab cd ef') # -> ['ab', 'cd'] + """ + arrayExpr = Forward() + def countFieldParseAction(s,l,t): + n = t[0] + arrayExpr << (n and Group(And([expr]*n)) or Group(empty)) + return [] + if intExpr is None: + intExpr = Word(nums).setParseAction(lambda t:int(t[0])) + else: + intExpr = intExpr.copy() + intExpr.setName("arrayLen") + intExpr.addParseAction(countFieldParseAction, callDuringTry=True) + return ( intExpr + arrayExpr ).setName('(len) ' + _ustr(expr) + '...') + +def _flatten(L): + ret = [] + for i in L: + if isinstance(i,list): + ret.extend(_flatten(i)) + else: + ret.append(i) + return ret + +def matchPreviousLiteral(expr): + """ + Helper to define an expression that is indirectly defined from + the tokens matched in a previous expression, that is, it looks + for a 'repeat' of a previous expression. For example:: + first = Word(nums) + second = matchPreviousLiteral(first) + matchExpr = first + ":" + second + will match C{"1:1"}, but not C{"1:2"}. Because this matches a + previous literal, will also match the leading C{"1:1"} in C{"1:10"}. + If this is not desired, use C{matchPreviousExpr}. + Do I{not} use with packrat parsing enabled. + """ + rep = Forward() + def copyTokenToRepeater(s,l,t): + if t: + if len(t) == 1: + rep << t[0] + else: + # flatten t tokens + tflat = _flatten(t.asList()) + rep << And(Literal(tt) for tt in tflat) + else: + rep << Empty() + expr.addParseAction(copyTokenToRepeater, callDuringTry=True) + rep.setName('(prev) ' + _ustr(expr)) + return rep + +def matchPreviousExpr(expr): + """ + Helper to define an expression that is indirectly defined from + the tokens matched in a previous expression, that is, it looks + for a 'repeat' of a previous expression. For example:: + first = Word(nums) + second = matchPreviousExpr(first) + matchExpr = first + ":" + second + will match C{"1:1"}, but not C{"1:2"}. Because this matches by + expressions, will I{not} match the leading C{"1:1"} in C{"1:10"}; + the expressions are evaluated first, and then compared, so + C{"1"} is compared with C{"10"}. + Do I{not} use with packrat parsing enabled. + """ + rep = Forward() + e2 = expr.copy() + rep <<= e2 + def copyTokenToRepeater(s,l,t): + matchTokens = _flatten(t.asList()) + def mustMatchTheseTokens(s,l,t): + theseTokens = _flatten(t.asList()) + if theseTokens != matchTokens: + raise ParseException("",0,"") + rep.setParseAction( mustMatchTheseTokens, callDuringTry=True ) + expr.addParseAction(copyTokenToRepeater, callDuringTry=True) + rep.setName('(prev) ' + _ustr(expr)) + return rep + +def _escapeRegexRangeChars(s): + #~ escape these chars: ^-] + for c in r"\^-]": + s = s.replace(c,_bslash+c) + s = s.replace("\n",r"\n") + s = s.replace("\t",r"\t") + return _ustr(s) + +def oneOf( strs, caseless=False, useRegex=True ): + """ + Helper to quickly define a set of alternative Literals, and makes sure to do + longest-first testing when there is a conflict, regardless of the input order, + but returns a C{L{MatchFirst}} for best performance. + + Parameters: + - strs - a string of space-delimited literals, or a collection of string literals + - caseless - (default=C{False}) - treat all literals as caseless + - useRegex - (default=C{True}) - as an optimization, will generate a Regex + object; otherwise, will generate a C{MatchFirst} object (if C{caseless=True}, or + if creating a C{Regex} raises an exception) + + Example:: + comp_oper = oneOf("< = > <= >= !=") + var = Word(alphas) + number = Word(nums) + term = var | number + comparison_expr = term + comp_oper + term + print(comparison_expr.searchString("B = 12 AA=23 B<=AA AA>12")) + prints:: + [['B', '=', '12'], ['AA', '=', '23'], ['B', '<=', 'AA'], ['AA', '>', '12']] + """ + if caseless: + isequal = ( lambda a,b: a.upper() == b.upper() ) + masks = ( lambda a,b: b.upper().startswith(a.upper()) ) + parseElementClass = CaselessLiteral + else: + isequal = ( lambda a,b: a == b ) + masks = ( lambda a,b: b.startswith(a) ) + parseElementClass = Literal + + symbols = [] + if isinstance(strs,basestring): + symbols = strs.split() + elif isinstance(strs, Iterable): + symbols = list(strs) + else: + warnings.warn("Invalid argument to oneOf, expected string or iterable", + SyntaxWarning, stacklevel=2) + if not symbols: + return NoMatch() + + i = 0 + while i < len(symbols)-1: + cur = symbols[i] + for j,other in enumerate(symbols[i+1:]): + if ( isequal(other, cur) ): + del symbols[i+j+1] + break + elif ( masks(cur, other) ): + del symbols[i+j+1] + symbols.insert(i,other) + cur = other + break + else: + i += 1 + + if not caseless and useRegex: + #~ print (strs,"->", "|".join( [ _escapeRegexChars(sym) for sym in symbols] )) + try: + if len(symbols)==len("".join(symbols)): + return Regex( "[%s]" % "".join(_escapeRegexRangeChars(sym) for sym in symbols) ).setName(' | '.join(symbols)) + else: + return Regex( "|".join(re.escape(sym) for sym in symbols) ).setName(' | '.join(symbols)) + except Exception: + warnings.warn("Exception creating Regex for oneOf, building MatchFirst", + SyntaxWarning, stacklevel=2) + + + # last resort, just use MatchFirst + return MatchFirst(parseElementClass(sym) for sym in symbols).setName(' | '.join(symbols)) + +def dictOf( key, value ): + """ + Helper to easily and clearly define a dictionary by specifying the respective patterns + for the key and value. Takes care of defining the C{L{Dict}}, C{L{ZeroOrMore}}, and C{L{Group}} tokens + in the proper order. The key pattern can include delimiting markers or punctuation, + as long as they are suppressed, thereby leaving the significant key text. The value + pattern can include named results, so that the C{Dict} results can include named token + fields. + + Example:: + text = "shape: SQUARE posn: upper left color: light blue texture: burlap" + attr_expr = (label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) + print(OneOrMore(attr_expr).parseString(text).dump()) + + attr_label = label + attr_value = Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join) + + # similar to Dict, but simpler call format + result = dictOf(attr_label, attr_value).parseString(text) + print(result.dump()) + print(result['shape']) + print(result.shape) # object attribute access works too + print(result.asDict()) + prints:: + [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']] + - color: light blue + - posn: upper left + - shape: SQUARE + - texture: burlap + SQUARE + SQUARE + {'color': 'light blue', 'shape': 'SQUARE', 'posn': 'upper left', 'texture': 'burlap'} + """ + return Dict( ZeroOrMore( Group ( key + value ) ) ) + +def originalTextFor(expr, asString=True): + """ + Helper to return the original, untokenized text for a given expression. Useful to + restore the parsed fields of an HTML start tag into the raw tag text itself, or to + revert separate tokens with intervening whitespace back to the original matching + input text. By default, returns astring containing the original parsed text. + + If the optional C{asString} argument is passed as C{False}, then the return value is a + C{L{ParseResults}} containing any results names that were originally matched, and a + single token containing the original matched text from the input string. So if + the expression passed to C{L{originalTextFor}} contains expressions with defined + results names, you must set C{asString} to C{False} if you want to preserve those + results name values. + + Example:: + src = "this is test <b> bold <i>text</i> </b> normal text " + for tag in ("b","i"): + opener,closer = makeHTMLTags(tag) + patt = originalTextFor(opener + SkipTo(closer) + closer) + print(patt.searchString(src)[0]) + prints:: + ['<b> bold <i>text</i> </b>'] + ['<i>text</i>'] + """ + locMarker = Empty().setParseAction(lambda s,loc,t: loc) + endlocMarker = locMarker.copy() + endlocMarker.callPreparse = False + matchExpr = locMarker("_original_start") + expr + endlocMarker("_original_end") + if asString: + extractText = lambda s,l,t: s[t._original_start:t._original_end] + else: + def extractText(s,l,t): + t[:] = [s[t.pop('_original_start'):t.pop('_original_end')]] + matchExpr.setParseAction(extractText) + matchExpr.ignoreExprs = expr.ignoreExprs + return matchExpr + +def ungroup(expr): + """ + Helper to undo pyparsing's default grouping of And expressions, even + if all but one are non-empty. + """ + return TokenConverter(expr).setParseAction(lambda t:t[0]) + +def locatedExpr(expr): + """ + Helper to decorate a returned token with its starting and ending locations in the input string. + This helper adds the following results names: + - locn_start = location where matched expression begins + - locn_end = location where matched expression ends + - value = the actual parsed results + + Be careful if the input text contains C{<TAB>} characters, you may want to call + C{L{ParserElement.parseWithTabs}} + + Example:: + wd = Word(alphas) + for match in locatedExpr(wd).searchString("ljsdf123lksdjjf123lkkjj1222"): + print(match) + prints:: + [[0, 'ljsdf', 5]] + [[8, 'lksdjjf', 15]] + [[18, 'lkkjj', 23]] + """ + locator = Empty().setParseAction(lambda s,l,t: l) + return Group(locator("locn_start") + expr("value") + locator.copy().leaveWhitespace()("locn_end")) + + +# convenience constants for positional expressions +empty = Empty().setName("empty") +lineStart = LineStart().setName("lineStart") +lineEnd = LineEnd().setName("lineEnd") +stringStart = StringStart().setName("stringStart") +stringEnd = StringEnd().setName("stringEnd") + +_escapedPunc = Word( _bslash, r"\[]-*.$+^?()~ ", exact=2 ).setParseAction(lambda s,l,t:t[0][1]) +_escapedHexChar = Regex(r"\\0?[xX][0-9a-fA-F]+").setParseAction(lambda s,l,t:unichr(int(t[0].lstrip(r'\0x'),16))) +_escapedOctChar = Regex(r"\\0[0-7]+").setParseAction(lambda s,l,t:unichr(int(t[0][1:],8))) +_singleChar = _escapedPunc | _escapedHexChar | _escapedOctChar | CharsNotIn(r'\]', exact=1) +_charRange = Group(_singleChar + Suppress("-") + _singleChar) +_reBracketExpr = Literal("[") + Optional("^").setResultsName("negate") + Group( OneOrMore( _charRange | _singleChar ) ).setResultsName("body") + "]" + +def srange(s): + r""" + Helper to easily define string ranges for use in Word construction. Borrows + syntax from regexp '[]' string range definitions:: + srange("[0-9]") -> "0123456789" + srange("[a-z]") -> "abcdefghijklmnopqrstuvwxyz" + srange("[a-z$_]") -> "abcdefghijklmnopqrstuvwxyz$_" + The input string must be enclosed in []'s, and the returned string is the expanded + character set joined into a single string. + The values enclosed in the []'s may be: + - a single character + - an escaped character with a leading backslash (such as C{\-} or C{\]}) + - an escaped hex character with a leading C{'\x'} (C{\x21}, which is a C{'!'} character) + (C{\0x##} is also supported for backwards compatibility) + - an escaped octal character with a leading C{'\0'} (C{\041}, which is a C{'!'} character) + - a range of any of the above, separated by a dash (C{'a-z'}, etc.) + - any combination of the above (C{'aeiouy'}, C{'a-zA-Z0-9_$'}, etc.) + """ + _expanded = lambda p: p if not isinstance(p,ParseResults) else ''.join(unichr(c) for c in range(ord(p[0]),ord(p[1])+1)) + try: + return "".join(_expanded(part) for part in _reBracketExpr.parseString(s).body) + except Exception: + return "" + +def matchOnlyAtCol(n): + """ + Helper method for defining parse actions that require matching at a specific + column in the input text. + """ + def verifyCol(strg,locn,toks): + if col(locn,strg) != n: + raise ParseException(strg,locn,"matched token not at column %d" % n) + return verifyCol + +def replaceWith(replStr): + """ + Helper method for common parse actions that simply return a literal value. Especially + useful when used with C{L{transformString<ParserElement.transformString>}()}. + + Example:: + num = Word(nums).setParseAction(lambda toks: int(toks[0])) + na = oneOf("N/A NA").setParseAction(replaceWith(math.nan)) + term = na | num + + OneOrMore(term).parseString("324 234 N/A 234") # -> [324, 234, nan, 234] + """ + return lambda s,l,t: [replStr] + +def removeQuotes(s,l,t): + """ + Helper parse action for removing quotation marks from parsed quoted strings. + + Example:: + # by default, quotation marks are included in parsed results + quotedString.parseString("'Now is the Winter of our Discontent'") # -> ["'Now is the Winter of our Discontent'"] + + # use removeQuotes to strip quotation marks from parsed results + quotedString.setParseAction(removeQuotes) + quotedString.parseString("'Now is the Winter of our Discontent'") # -> ["Now is the Winter of our Discontent"] + """ + return t[0][1:-1] + +def tokenMap(func, *args): + """ + Helper to define a parse action by mapping a function to all elements of a ParseResults list.If any additional + args are passed, they are forwarded to the given function as additional arguments after + the token, as in C{hex_integer = Word(hexnums).setParseAction(tokenMap(int, 16))}, which will convert the + parsed data to an integer using base 16. + + Example (compare the last to example in L{ParserElement.transformString}:: + hex_ints = OneOrMore(Word(hexnums)).setParseAction(tokenMap(int, 16)) + hex_ints.runTests(''' + 00 11 22 aa FF 0a 0d 1a + ''') + + upperword = Word(alphas).setParseAction(tokenMap(str.upper)) + OneOrMore(upperword).runTests(''' + my kingdom for a horse + ''') + + wd = Word(alphas).setParseAction(tokenMap(str.title)) + OneOrMore(wd).setParseAction(' '.join).runTests(''' + now is the winter of our discontent made glorious summer by this sun of york + ''') + prints:: + 00 11 22 aa FF 0a 0d 1a + [0, 17, 34, 170, 255, 10, 13, 26] + + my kingdom for a horse + ['MY', 'KINGDOM', 'FOR', 'A', 'HORSE'] + + now is the winter of our discontent made glorious summer by this sun of york + ['Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York'] + """ + def pa(s,l,t): + return [func(tokn, *args) for tokn in t] + + try: + func_name = getattr(func, '__name__', + getattr(func, '__class__').__name__) + except Exception: + func_name = str(func) + pa.__name__ = func_name + + return pa + +upcaseTokens = tokenMap(lambda t: _ustr(t).upper()) +"""(Deprecated) Helper parse action to convert tokens to upper case. Deprecated in favor of L{pyparsing_common.upcaseTokens}""" + +downcaseTokens = tokenMap(lambda t: _ustr(t).lower()) +"""(Deprecated) Helper parse action to convert tokens to lower case. Deprecated in favor of L{pyparsing_common.downcaseTokens}""" + +def _makeTags(tagStr, xml): + """Internal helper to construct opening and closing tag expressions, given a tag name""" + if isinstance(tagStr,basestring): + resname = tagStr + tagStr = Keyword(tagStr, caseless=not xml) + else: + resname = tagStr.name + + tagAttrName = Word(alphas,alphanums+"_-:") + if (xml): + tagAttrValue = dblQuotedString.copy().setParseAction( removeQuotes ) + openTag = Suppress("<") + tagStr("tag") + \ + Dict(ZeroOrMore(Group( tagAttrName + Suppress("=") + tagAttrValue ))) + \ + Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">") + else: + printablesLessRAbrack = "".join(c for c in printables if c not in ">") + tagAttrValue = quotedString.copy().setParseAction( removeQuotes ) | Word(printablesLessRAbrack) + openTag = Suppress("<") + tagStr("tag") + \ + Dict(ZeroOrMore(Group( tagAttrName.setParseAction(downcaseTokens) + \ + Optional( Suppress("=") + tagAttrValue ) ))) + \ + Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">") + closeTag = Combine(_L("</") + tagStr + ">") + + openTag = openTag.setResultsName("start"+"".join(resname.replace(":"," ").title().split())).setName("<%s>" % resname) + closeTag = closeTag.setResultsName("end"+"".join(resname.replace(":"," ").title().split())).setName("</%s>" % resname) + openTag.tag = resname + closeTag.tag = resname + return openTag, closeTag + +def makeHTMLTags(tagStr): + """ + Helper to construct opening and closing tag expressions for HTML, given a tag name. Matches + tags in either upper or lower case, attributes with namespaces and with quoted or unquoted values. + + Example:: + text = '<td>More info at the <a href="http://pyparsing.wikispaces.com">pyparsing</a> wiki page</td>' + # makeHTMLTags returns pyparsing expressions for the opening and closing tags as a 2-tuple + a,a_end = makeHTMLTags("A") + link_expr = a + SkipTo(a_end)("link_text") + a_end + + for link in link_expr.searchString(text): + # attributes in the <A> tag (like "href" shown here) are also accessible as named results + print(link.link_text, '->', link.href) + prints:: + pyparsing -> http://pyparsing.wikispaces.com + """ + return _makeTags( tagStr, False ) + +def makeXMLTags(tagStr): + """ + Helper to construct opening and closing tag expressions for XML, given a tag name. Matches + tags only in the given upper/lower case. + + Example: similar to L{makeHTMLTags} + """ + return _makeTags( tagStr, True ) + +def withAttribute(*args,**attrDict): + """ + Helper to create a validating parse action to be used with start tags created + with C{L{makeXMLTags}} or C{L{makeHTMLTags}}. Use C{withAttribute} to qualify a starting tag + with a required attribute value, to avoid false matches on common tags such as + C{<TD>} or C{<DIV>}. + + Call C{withAttribute} with a series of attribute names and values. Specify the list + of filter attributes names and values as: + - keyword arguments, as in C{(align="right")}, or + - as an explicit dict with C{**} operator, when an attribute name is also a Python + reserved word, as in C{**{"class":"Customer", "align":"right"}} + - a list of name-value tuples, as in ( ("ns1:class", "Customer"), ("ns2:align","right") ) + For attribute names with a namespace prefix, you must use the second form. Attribute + names are matched insensitive to upper/lower case. + + If just testing for C{class} (with or without a namespace), use C{L{withClass}}. + + To verify that the attribute exists, but without specifying a value, pass + C{withAttribute.ANY_VALUE} as the value. + + Example:: + html = ''' + <div> + Some text + <div type="grid">1 4 0 1 0</div> + <div type="graph">1,3 2,3 1,1</div> + <div>this has no type</div> + </div> + + ''' + div,div_end = makeHTMLTags("div") + + # only match div tag having a type attribute with value "grid" + div_grid = div().setParseAction(withAttribute(type="grid")) + grid_expr = div_grid + SkipTo(div | div_end)("body") + for grid_header in grid_expr.searchString(html): + print(grid_header.body) + + # construct a match with any div tag having a type attribute, regardless of the value + div_any_type = div().setParseAction(withAttribute(type=withAttribute.ANY_VALUE)) + div_expr = div_any_type + SkipTo(div | div_end)("body") + for div_header in div_expr.searchString(html): + print(div_header.body) + prints:: + 1 4 0 1 0 + + 1 4 0 1 0 + 1,3 2,3 1,1 + """ + if args: + attrs = args[:] + else: + attrs = attrDict.items() + attrs = [(k,v) for k,v in attrs] + def pa(s,l,tokens): + for attrName,attrValue in attrs: + if attrName not in tokens: + raise ParseException(s,l,"no matching attribute " + attrName) + if attrValue != withAttribute.ANY_VALUE and tokens[attrName] != attrValue: + raise ParseException(s,l,"attribute '%s' has value '%s', must be '%s'" % + (attrName, tokens[attrName], attrValue)) + return pa +withAttribute.ANY_VALUE = object() + +def withClass(classname, namespace=''): + """ + Simplified version of C{L{withAttribute}} when matching on a div class - made + difficult because C{class} is a reserved word in Python. + + Example:: + html = ''' + <div> + Some text + <div class="grid">1 4 0 1 0</div> + <div class="graph">1,3 2,3 1,1</div> + <div>this <div> has no class</div> + </div> + + ''' + div,div_end = makeHTMLTags("div") + div_grid = div().setParseAction(withClass("grid")) + + grid_expr = div_grid + SkipTo(div | div_end)("body") + for grid_header in grid_expr.searchString(html): + print(grid_header.body) + + div_any_type = div().setParseAction(withClass(withAttribute.ANY_VALUE)) + div_expr = div_any_type + SkipTo(div | div_end)("body") + for div_header in div_expr.searchString(html): + print(div_header.body) + prints:: + 1 4 0 1 0 + + 1 4 0 1 0 + 1,3 2,3 1,1 + """ + classattr = "%s:class" % namespace if namespace else "class" + return withAttribute(**{classattr : classname}) + +opAssoc = _Constants() +opAssoc.LEFT = object() +opAssoc.RIGHT = object() + +def infixNotation( baseExpr, opList, lpar=Suppress('('), rpar=Suppress(')') ): + """ + Helper method for constructing grammars of expressions made up of + operators working in a precedence hierarchy. Operators may be unary or + binary, left- or right-associative. Parse actions can also be attached + to operator expressions. The generated parser will also recognize the use + of parentheses to override operator precedences (see example below). + + Note: if you define a deep operator list, you may see performance issues + when using infixNotation. See L{ParserElement.enablePackrat} for a + mechanism to potentially improve your parser performance. + + Parameters: + - baseExpr - expression representing the most basic element for the nested + - opList - list of tuples, one for each operator precedence level in the + expression grammar; each tuple is of the form + (opExpr, numTerms, rightLeftAssoc, parseAction), where: + - opExpr is the pyparsing expression for the operator; + may also be a string, which will be converted to a Literal; + if numTerms is 3, opExpr is a tuple of two expressions, for the + two operators separating the 3 terms + - numTerms is the number of terms for this operator (must + be 1, 2, or 3) + - rightLeftAssoc is the indicator whether the operator is + right or left associative, using the pyparsing-defined + constants C{opAssoc.RIGHT} and C{opAssoc.LEFT}. + - parseAction is the parse action to be associated with + expressions matching this operator expression (the + parse action tuple member may be omitted); if the parse action + is passed a tuple or list of functions, this is equivalent to + calling C{setParseAction(*fn)} (L{ParserElement.setParseAction}) + - lpar - expression for matching left-parentheses (default=C{Suppress('(')}) + - rpar - expression for matching right-parentheses (default=C{Suppress(')')}) + + Example:: + # simple example of four-function arithmetic with ints and variable names + integer = pyparsing_common.signed_integer + varname = pyparsing_common.identifier + + arith_expr = infixNotation(integer | varname, + [ + ('-', 1, opAssoc.RIGHT), + (oneOf('* /'), 2, opAssoc.LEFT), + (oneOf('+ -'), 2, opAssoc.LEFT), + ]) + + arith_expr.runTests(''' + 5+3*6 + (5+3)*6 + -2--11 + ''', fullDump=False) + prints:: + 5+3*6 + [[5, '+', [3, '*', 6]]] + + (5+3)*6 + [[[5, '+', 3], '*', 6]] + + -2--11 + [[['-', 2], '-', ['-', 11]]] + """ + ret = Forward() + lastExpr = baseExpr | ( lpar + ret + rpar ) + for i,operDef in enumerate(opList): + opExpr,arity,rightLeftAssoc,pa = (operDef + (None,))[:4] + termName = "%s term" % opExpr if arity < 3 else "%s%s term" % opExpr + if arity == 3: + if opExpr is None or len(opExpr) != 2: + raise ValueError("if numterms=3, opExpr must be a tuple or list of two expressions") + opExpr1, opExpr2 = opExpr + thisExpr = Forward().setName(termName) + if rightLeftAssoc == opAssoc.LEFT: + if arity == 1: + matchExpr = FollowedBy(lastExpr + opExpr) + Group( lastExpr + OneOrMore( opExpr ) ) + elif arity == 2: + if opExpr is not None: + matchExpr = FollowedBy(lastExpr + opExpr + lastExpr) + Group( lastExpr + OneOrMore( opExpr + lastExpr ) ) + else: + matchExpr = FollowedBy(lastExpr+lastExpr) + Group( lastExpr + OneOrMore(lastExpr) ) + elif arity == 3: + matchExpr = FollowedBy(lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr) + \ + Group( lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr ) + else: + raise ValueError("operator must be unary (1), binary (2), or ternary (3)") + elif rightLeftAssoc == opAssoc.RIGHT: + if arity == 1: + # try to avoid LR with this extra test + if not isinstance(opExpr, Optional): + opExpr = Optional(opExpr) + matchExpr = FollowedBy(opExpr.expr + thisExpr) + Group( opExpr + thisExpr ) + elif arity == 2: + if opExpr is not None: + matchExpr = FollowedBy(lastExpr + opExpr + thisExpr) + Group( lastExpr + OneOrMore( opExpr + thisExpr ) ) + else: + matchExpr = FollowedBy(lastExpr + thisExpr) + Group( lastExpr + OneOrMore( thisExpr ) ) + elif arity == 3: + matchExpr = FollowedBy(lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr) + \ + Group( lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr ) + else: + raise ValueError("operator must be unary (1), binary (2), or ternary (3)") + else: + raise ValueError("operator must indicate right or left associativity") + if pa: + if isinstance(pa, (tuple, list)): + matchExpr.setParseAction(*pa) + else: + matchExpr.setParseAction(pa) + thisExpr <<= ( matchExpr.setName(termName) | lastExpr ) + lastExpr = thisExpr + ret <<= lastExpr + return ret + +operatorPrecedence = infixNotation +"""(Deprecated) Former name of C{L{infixNotation}}, will be dropped in a future release.""" + +dblQuotedString = Combine(Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*')+'"').setName("string enclosed in double quotes") +sglQuotedString = Combine(Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*")+"'").setName("string enclosed in single quotes") +quotedString = Combine(Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*')+'"'| + Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*")+"'").setName("quotedString using single or double quotes") +unicodeString = Combine(_L('u') + quotedString.copy()).setName("unicode string literal") + +def nestedExpr(opener="(", closer=")", content=None, ignoreExpr=quotedString.copy()): + """ + Helper method for defining nested lists enclosed in opening and closing + delimiters ("(" and ")" are the default). + + Parameters: + - opener - opening character for a nested list (default=C{"("}); can also be a pyparsing expression + - closer - closing character for a nested list (default=C{")"}); can also be a pyparsing expression + - content - expression for items within the nested lists (default=C{None}) + - ignoreExpr - expression for ignoring opening and closing delimiters (default=C{quotedString}) + + If an expression is not provided for the content argument, the nested + expression will capture all whitespace-delimited content between delimiters + as a list of separate values. + + Use the C{ignoreExpr} argument to define expressions that may contain + opening or closing characters that should not be treated as opening + or closing characters for nesting, such as quotedString or a comment + expression. Specify multiple expressions using an C{L{Or}} or C{L{MatchFirst}}. + The default is L{quotedString}, but if no expressions are to be ignored, + then pass C{None} for this argument. + + Example:: + data_type = oneOf("void int short long char float double") + decl_data_type = Combine(data_type + Optional(Word('*'))) + ident = Word(alphas+'_', alphanums+'_') + number = pyparsing_common.number + arg = Group(decl_data_type + ident) + LPAR,RPAR = map(Suppress, "()") + + code_body = nestedExpr('{', '}', ignoreExpr=(quotedString | cStyleComment)) + + c_function = (decl_data_type("type") + + ident("name") + + LPAR + Optional(delimitedList(arg), [])("args") + RPAR + + code_body("body")) + c_function.ignore(cStyleComment) + + source_code = ''' + int is_odd(int x) { + return (x%2); + } + + int dec_to_hex(char hchar) { + if (hchar >= '0' && hchar <= '9') { + return (ord(hchar)-ord('0')); + } else { + return (10+ord(hchar)-ord('A')); + } + } + ''' + for func in c_function.searchString(source_code): + print("%(name)s (%(type)s) args: %(args)s" % func) + + prints:: + is_odd (int) args: [['int', 'x']] + dec_to_hex (int) args: [['char', 'hchar']] + """ + if opener == closer: + raise ValueError("opening and closing strings cannot be the same") + if content is None: + if isinstance(opener,basestring) and isinstance(closer,basestring): + if len(opener) == 1 and len(closer)==1: + if ignoreExpr is not None: + content = (Combine(OneOrMore(~ignoreExpr + + CharsNotIn(opener+closer+ParserElement.DEFAULT_WHITE_CHARS,exact=1)) + ).setParseAction(lambda t:t[0].strip())) + else: + content = (empty.copy()+CharsNotIn(opener+closer+ParserElement.DEFAULT_WHITE_CHARS + ).setParseAction(lambda t:t[0].strip())) + else: + if ignoreExpr is not None: + content = (Combine(OneOrMore(~ignoreExpr + + ~Literal(opener) + ~Literal(closer) + + CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS,exact=1)) + ).setParseAction(lambda t:t[0].strip())) + else: + content = (Combine(OneOrMore(~Literal(opener) + ~Literal(closer) + + CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS,exact=1)) + ).setParseAction(lambda t:t[0].strip())) + else: + raise ValueError("opening and closing arguments must be strings if no content expression is given") + ret = Forward() + if ignoreExpr is not None: + ret <<= Group( Suppress(opener) + ZeroOrMore( ignoreExpr | ret | content ) + Suppress(closer) ) + else: + ret <<= Group( Suppress(opener) + ZeroOrMore( ret | content ) + Suppress(closer) ) + ret.setName('nested %s%s expression' % (opener,closer)) + return ret + +def indentedBlock(blockStatementExpr, indentStack, indent=True): + """ + Helper method for defining space-delimited indentation blocks, such as + those used to define block statements in Python source code. + + Parameters: + - blockStatementExpr - expression defining syntax of statement that + is repeated within the indented block + - indentStack - list created by caller to manage indentation stack + (multiple statementWithIndentedBlock expressions within a single grammar + should share a common indentStack) + - indent - boolean indicating whether block must be indented beyond the + the current level; set to False for block of left-most statements + (default=C{True}) + + A valid block must contain at least one C{blockStatement}. + + Example:: + data = ''' + def A(z): + A1 + B = 100 + G = A2 + A2 + A3 + B + def BB(a,b,c): + BB1 + def BBA(): + bba1 + bba2 + bba3 + C + D + def spam(x,y): + def eggs(z): + pass + ''' + + + indentStack = [1] + stmt = Forward() + + identifier = Word(alphas, alphanums) + funcDecl = ("def" + identifier + Group( "(" + Optional( delimitedList(identifier) ) + ")" ) + ":") + func_body = indentedBlock(stmt, indentStack) + funcDef = Group( funcDecl + func_body ) + + rvalue = Forward() + funcCall = Group(identifier + "(" + Optional(delimitedList(rvalue)) + ")") + rvalue << (funcCall | identifier | Word(nums)) + assignment = Group(identifier + "=" + rvalue) + stmt << ( funcDef | assignment | identifier ) + + module_body = OneOrMore(stmt) + + parseTree = module_body.parseString(data) + parseTree.pprint() + prints:: + [['def', + 'A', + ['(', 'z', ')'], + ':', + [['A1'], [['B', '=', '100']], [['G', '=', 'A2']], ['A2'], ['A3']]], + 'B', + ['def', + 'BB', + ['(', 'a', 'b', 'c', ')'], + ':', + [['BB1'], [['def', 'BBA', ['(', ')'], ':', [['bba1'], ['bba2'], ['bba3']]]]]], + 'C', + 'D', + ['def', + 'spam', + ['(', 'x', 'y', ')'], + ':', + [[['def', 'eggs', ['(', 'z', ')'], ':', [['pass']]]]]]] + """ + def checkPeerIndent(s,l,t): + if l >= len(s): return + curCol = col(l,s) + if curCol != indentStack[-1]: + if curCol > indentStack[-1]: + raise ParseFatalException(s,l,"illegal nesting") + raise ParseException(s,l,"not a peer entry") + + def checkSubIndent(s,l,t): + curCol = col(l,s) + if curCol > indentStack[-1]: + indentStack.append( curCol ) + else: + raise ParseException(s,l,"not a subentry") + + def checkUnindent(s,l,t): + if l >= len(s): return + curCol = col(l,s) + if not(indentStack and curCol < indentStack[-1] and curCol <= indentStack[-2]): + raise ParseException(s,l,"not an unindent") + indentStack.pop() + + NL = OneOrMore(LineEnd().setWhitespaceChars("\t ").suppress()) + INDENT = (Empty() + Empty().setParseAction(checkSubIndent)).setName('INDENT') + PEER = Empty().setParseAction(checkPeerIndent).setName('') + UNDENT = Empty().setParseAction(checkUnindent).setName('UNINDENT') + if indent: + smExpr = Group( Optional(NL) + + #~ FollowedBy(blockStatementExpr) + + INDENT + (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) + UNDENT) + else: + smExpr = Group( Optional(NL) + + (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) ) + blockStatementExpr.ignore(_bslash + LineEnd()) + return smExpr.setName('indented block') + +alphas8bit = srange(r"[\0xc0-\0xd6\0xd8-\0xf6\0xf8-\0xff]") +punc8bit = srange(r"[\0xa1-\0xbf\0xd7\0xf7]") + +anyOpenTag,anyCloseTag = makeHTMLTags(Word(alphas,alphanums+"_:").setName('any tag')) +_htmlEntityMap = dict(zip("gt lt amp nbsp quot apos".split(),'><& "\'')) +commonHTMLEntity = Regex('&(?P<entity>' + '|'.join(_htmlEntityMap.keys()) +");").setName("common HTML entity") +def replaceHTMLEntity(t): + """Helper parser action to replace common HTML entities with their special characters""" + return _htmlEntityMap.get(t.entity) + +# it's easy to get these comment structures wrong - they're very common, so may as well make them available +cStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/').setName("C style comment") +"Comment of the form C{/* ... */}" + +htmlComment = Regex(r"<!--[\s\S]*?-->").setName("HTML comment") +"Comment of the form C{<!-- ... -->}" + +restOfLine = Regex(r".*").leaveWhitespace().setName("rest of line") +dblSlashComment = Regex(r"//(?:\\\n|[^\n])*").setName("// comment") +"Comment of the form C{// ... (to end of line)}" + +cppStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/'| dblSlashComment).setName("C++ style comment") +"Comment of either form C{L{cStyleComment}} or C{L{dblSlashComment}}" + +javaStyleComment = cppStyleComment +"Same as C{L{cppStyleComment}}" + +pythonStyleComment = Regex(r"#.*").setName("Python style comment") +"Comment of the form C{# ... (to end of line)}" + +_commasepitem = Combine(OneOrMore(Word(printables, excludeChars=',') + + Optional( Word(" \t") + + ~Literal(",") + ~LineEnd() ) ) ).streamline().setName("commaItem") +commaSeparatedList = delimitedList( Optional( quotedString.copy() | _commasepitem, default="") ).setName("commaSeparatedList") +"""(Deprecated) Predefined expression of 1 or more printable words or quoted strings, separated by commas. + This expression is deprecated in favor of L{pyparsing_common.comma_separated_list}.""" + +# some other useful expressions - using lower-case class name since we are really using this as a namespace +class pyparsing_common: + """ + Here are some common low-level expressions that may be useful in jump-starting parser development: + - numeric forms (L{integers<integer>}, L{reals<real>}, L{scientific notation<sci_real>}) + - common L{programming identifiers<identifier>} + - network addresses (L{MAC<mac_address>}, L{IPv4<ipv4_address>}, L{IPv6<ipv6_address>}) + - ISO8601 L{dates<iso8601_date>} and L{datetime<iso8601_datetime>} + - L{UUID<uuid>} + - L{comma-separated list<comma_separated_list>} + Parse actions: + - C{L{convertToInteger}} + - C{L{convertToFloat}} + - C{L{convertToDate}} + - C{L{convertToDatetime}} + - C{L{stripHTMLTags}} + - C{L{upcaseTokens}} + - C{L{downcaseTokens}} + + Example:: + pyparsing_common.number.runTests(''' + # any int or real number, returned as the appropriate type + 100 + -100 + +100 + 3.14159 + 6.02e23 + 1e-12 + ''') + + pyparsing_common.fnumber.runTests(''' + # any int or real number, returned as float + 100 + -100 + +100 + 3.14159 + 6.02e23 + 1e-12 + ''') + + pyparsing_common.hex_integer.runTests(''' + # hex numbers + 100 + FF + ''') + + pyparsing_common.fraction.runTests(''' + # fractions + 1/2 + -3/4 + ''') + + pyparsing_common.mixed_integer.runTests(''' + # mixed fractions + 1 + 1/2 + -3/4 + 1-3/4 + ''') + + import uuid + pyparsing_common.uuid.setParseAction(tokenMap(uuid.UUID)) + pyparsing_common.uuid.runTests(''' + # uuid + 12345678-1234-5678-1234-567812345678 + ''') + prints:: + # any int or real number, returned as the appropriate type + 100 + [100] + + -100 + [-100] + + +100 + [100] + + 3.14159 + [3.14159] + + 6.02e23 + [6.02e+23] + + 1e-12 + [1e-12] + + # any int or real number, returned as float + 100 + [100.0] + + -100 + [-100.0] + + +100 + [100.0] + + 3.14159 + [3.14159] + + 6.02e23 + [6.02e+23] + + 1e-12 + [1e-12] + + # hex numbers + 100 + [256] + + FF + [255] + + # fractions + 1/2 + [0.5] + + -3/4 + [-0.75] + + # mixed fractions + 1 + [1] + + 1/2 + [0.5] + + -3/4 + [-0.75] + + 1-3/4 + [1.75] + + # uuid + 12345678-1234-5678-1234-567812345678 + [UUID('12345678-1234-5678-1234-567812345678')] + """ + + convertToInteger = tokenMap(int) + """ + Parse action for converting parsed integers to Python int + """ + + convertToFloat = tokenMap(float) + """ + Parse action for converting parsed numbers to Python float + """ + + integer = Word(nums).setName("integer").setParseAction(convertToInteger) + """expression that parses an unsigned integer, returns an int""" + + hex_integer = Word(hexnums).setName("hex integer").setParseAction(tokenMap(int,16)) + """expression that parses a hexadecimal integer, returns an int""" + + signed_integer = Regex(r'[+-]?\d+').setName("signed integer").setParseAction(convertToInteger) + """expression that parses an integer with optional leading sign, returns an int""" + + fraction = (signed_integer().setParseAction(convertToFloat) + '/' + signed_integer().setParseAction(convertToFloat)).setName("fraction") + """fractional expression of an integer divided by an integer, returns a float""" + fraction.addParseAction(lambda t: t[0]/t[-1]) + + mixed_integer = (fraction | signed_integer + Optional(Optional('-').suppress() + fraction)).setName("fraction or mixed integer-fraction") + """mixed integer of the form 'integer - fraction', with optional leading integer, returns float""" + mixed_integer.addParseAction(sum) + + real = Regex(r'[+-]?\d+\.\d*').setName("real number").setParseAction(convertToFloat) + """expression that parses a floating point number and returns a float""" + + sci_real = Regex(r'[+-]?\d+([eE][+-]?\d+|\.\d*([eE][+-]?\d+)?)').setName("real number with scientific notation").setParseAction(convertToFloat) + """expression that parses a floating point number with optional scientific notation and returns a float""" + + # streamlining this expression makes the docs nicer-looking + number = (sci_real | real | signed_integer).streamline() + """any numeric expression, returns the corresponding Python type""" + + fnumber = Regex(r'[+-]?\d+\.?\d*([eE][+-]?\d+)?').setName("fnumber").setParseAction(convertToFloat) + """any int or real number, returned as float""" + + identifier = Word(alphas+'_', alphanums+'_').setName("identifier") + """typical code identifier (leading alpha or '_', followed by 0 or more alphas, nums, or '_')""" + + ipv4_address = Regex(r'(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})(\.(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})){3}').setName("IPv4 address") + "IPv4 address (C{0.0.0.0 - 255.255.255.255})" + + _ipv6_part = Regex(r'[0-9a-fA-F]{1,4}').setName("hex_integer") + _full_ipv6_address = (_ipv6_part + (':' + _ipv6_part)*7).setName("full IPv6 address") + _short_ipv6_address = (Optional(_ipv6_part + (':' + _ipv6_part)*(0,6)) + "::" + Optional(_ipv6_part + (':' + _ipv6_part)*(0,6))).setName("short IPv6 address") + _short_ipv6_address.addCondition(lambda t: sum(1 for tt in t if pyparsing_common._ipv6_part.matches(tt)) < 8) + _mixed_ipv6_address = ("::ffff:" + ipv4_address).setName("mixed IPv6 address") + ipv6_address = Combine((_full_ipv6_address | _mixed_ipv6_address | _short_ipv6_address).setName("IPv6 address")).setName("IPv6 address") + "IPv6 address (long, short, or mixed form)" + + mac_address = Regex(r'[0-9a-fA-F]{2}([:.-])[0-9a-fA-F]{2}(?:\1[0-9a-fA-F]{2}){4}').setName("MAC address") + "MAC address xx:xx:xx:xx:xx (may also have '-' or '.' delimiters)" + + @staticmethod + def convertToDate(fmt="%Y-%m-%d"): + """ + Helper to create a parse action for converting parsed date string to Python datetime.date + + Params - + - fmt - format to be passed to datetime.strptime (default=C{"%Y-%m-%d"}) + + Example:: + date_expr = pyparsing_common.iso8601_date.copy() + date_expr.setParseAction(pyparsing_common.convertToDate()) + print(date_expr.parseString("1999-12-31")) + prints:: + [datetime.date(1999, 12, 31)] + """ + def cvt_fn(s,l,t): + try: + return datetime.strptime(t[0], fmt).date() + except ValueError as ve: + raise ParseException(s, l, str(ve)) + return cvt_fn + + @staticmethod + def convertToDatetime(fmt="%Y-%m-%dT%H:%M:%S.%f"): + """ + Helper to create a parse action for converting parsed datetime string to Python datetime.datetime + + Params - + - fmt - format to be passed to datetime.strptime (default=C{"%Y-%m-%dT%H:%M:%S.%f"}) + + Example:: + dt_expr = pyparsing_common.iso8601_datetime.copy() + dt_expr.setParseAction(pyparsing_common.convertToDatetime()) + print(dt_expr.parseString("1999-12-31T23:59:59.999")) + prints:: + [datetime.datetime(1999, 12, 31, 23, 59, 59, 999000)] + """ + def cvt_fn(s,l,t): + try: + return datetime.strptime(t[0], fmt) + except ValueError as ve: + raise ParseException(s, l, str(ve)) + return cvt_fn + + iso8601_date = Regex(r'(?P<year>\d{4})(?:-(?P<month>\d\d)(?:-(?P<day>\d\d))?)?').setName("ISO8601 date") + "ISO8601 date (C{yyyy-mm-dd})" + + iso8601_datetime = Regex(r'(?P<year>\d{4})-(?P<month>\d\d)-(?P<day>\d\d)[T ](?P<hour>\d\d):(?P<minute>\d\d)(:(?P<second>\d\d(\.\d*)?)?)?(?P<tz>Z|[+-]\d\d:?\d\d)?').setName("ISO8601 datetime") + "ISO8601 datetime (C{yyyy-mm-ddThh:mm:ss.s(Z|+-00:00)}) - trailing seconds, milliseconds, and timezone optional; accepts separating C{'T'} or C{' '}" + + uuid = Regex(r'[0-9a-fA-F]{8}(-[0-9a-fA-F]{4}){3}-[0-9a-fA-F]{12}').setName("UUID") + "UUID (C{xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx})" + + _html_stripper = anyOpenTag.suppress() | anyCloseTag.suppress() + @staticmethod + def stripHTMLTags(s, l, tokens): + """ + Parse action to remove HTML tags from web page HTML source + + Example:: + # strip HTML links from normal text + text = '<td>More info at the <a href="http://pyparsing.wikispaces.com">pyparsing</a> wiki page</td>' + td,td_end = makeHTMLTags("TD") + table_text = td + SkipTo(td_end).setParseAction(pyparsing_common.stripHTMLTags)("body") + td_end + + print(table_text.parseString(text).body) # -> 'More info at the pyparsing wiki page' + """ + return pyparsing_common._html_stripper.transformString(tokens[0]) + + _commasepitem = Combine(OneOrMore(~Literal(",") + ~LineEnd() + Word(printables, excludeChars=',') + + Optional( White(" \t") ) ) ).streamline().setName("commaItem") + comma_separated_list = delimitedList( Optional( quotedString.copy() | _commasepitem, default="") ).setName("comma separated list") + """Predefined expression of 1 or more printable words or quoted strings, separated by commas.""" + + upcaseTokens = staticmethod(tokenMap(lambda t: _ustr(t).upper())) + """Parse action to convert tokens to upper case.""" + + downcaseTokens = staticmethod(tokenMap(lambda t: _ustr(t).lower())) + """Parse action to convert tokens to lower case.""" + + +if __name__ == "__main__": + + selectToken = CaselessLiteral("select") + fromToken = CaselessLiteral("from") + + ident = Word(alphas, alphanums + "_$") + + columnName = delimitedList(ident, ".", combine=True).setParseAction(upcaseTokens) + columnNameList = Group(delimitedList(columnName)).setName("columns") + columnSpec = ('*' | columnNameList) + + tableName = delimitedList(ident, ".", combine=True).setParseAction(upcaseTokens) + tableNameList = Group(delimitedList(tableName)).setName("tables") + + simpleSQL = selectToken("command") + columnSpec("columns") + fromToken + tableNameList("tables") + + # demo runTests method, including embedded comments in test string + simpleSQL.runTests(""" + # '*' as column list and dotted table name + select * from SYS.XYZZY + + # caseless match on "SELECT", and casts back to "select" + SELECT * from XYZZY, ABC + + # list of column names, and mixed case SELECT keyword + Select AA,BB,CC from Sys.dual + + # multiple tables + Select A, B, C from Sys.dual, Table2 + + # invalid SELECT keyword - should fail + Xelect A, B, C from Sys.dual + + # incomplete command - should fail + Select + + # invalid column name - should fail + Select ^^^ frox Sys.dual + + """) + + pyparsing_common.number.runTests(""" + 100 + -100 + +100 + 3.14159 + 6.02e23 + 1e-12 + """) + + # any int or real number, returned as float + pyparsing_common.fnumber.runTests(""" + 100 + -100 + +100 + 3.14159 + 6.02e23 + 1e-12 + """) + + pyparsing_common.hex_integer.runTests(""" + 100 + FF + """) + + import uuid + pyparsing_common.uuid.setParseAction(tokenMap(uuid.UUID)) + pyparsing_common.uuid.runTests(""" + 12345678-1234-5678-1234-567812345678 + """) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/six.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/six.py new file mode 100644 index 0000000..190c023 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/_vendor/six.py @@ -0,0 +1,868 @@ +"""Utilities for writing code that runs on Python 2 and 3""" + +# Copyright (c) 2010-2015 Benjamin Peterson +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in all +# copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. + +from __future__ import absolute_import + +import functools +import itertools +import operator +import sys +import types + +__author__ = "Benjamin Peterson <benjamin@python.org>" +__version__ = "1.10.0" + + +# Useful for very coarse version differentiation. +PY2 = sys.version_info[0] == 2 +PY3 = sys.version_info[0] == 3 +PY34 = sys.version_info[0:2] >= (3, 4) + +if PY3: + string_types = str, + integer_types = int, + class_types = type, + text_type = str + binary_type = bytes + + MAXSIZE = sys.maxsize +else: + string_types = basestring, + integer_types = (int, long) + class_types = (type, types.ClassType) + text_type = unicode + binary_type = str + + if sys.platform.startswith("java"): + # Jython always uses 32 bits. + MAXSIZE = int((1 << 31) - 1) + else: + # It's possible to have sizeof(long) != sizeof(Py_ssize_t). + class X(object): + + def __len__(self): + return 1 << 31 + try: + len(X()) + except OverflowError: + # 32-bit + MAXSIZE = int((1 << 31) - 1) + else: + # 64-bit + MAXSIZE = int((1 << 63) - 1) + del X + + +def _add_doc(func, doc): + """Add documentation to a function.""" + func.__doc__ = doc + + +def _import_module(name): + """Import module, returning the module after the last dot.""" + __import__(name) + return sys.modules[name] + + +class _LazyDescr(object): + + def __init__(self, name): + self.name = name + + def __get__(self, obj, tp): + result = self._resolve() + setattr(obj, self.name, result) # Invokes __set__. + try: + # This is a bit ugly, but it avoids running this again by + # removing this descriptor. + delattr(obj.__class__, self.name) + except AttributeError: + pass + return result + + +class MovedModule(_LazyDescr): + + def __init__(self, name, old, new=None): + super(MovedModule, self).__init__(name) + if PY3: + if new is None: + new = name + self.mod = new + else: + self.mod = old + + def _resolve(self): + return _import_module(self.mod) + + def __getattr__(self, attr): + _module = self._resolve() + value = getattr(_module, attr) + setattr(self, attr, value) + return value + + +class _LazyModule(types.ModuleType): + + def __init__(self, name): + super(_LazyModule, self).__init__(name) + self.__doc__ = self.__class__.__doc__ + + def __dir__(self): + attrs = ["__doc__", "__name__"] + attrs += [attr.name for attr in self._moved_attributes] + return attrs + + # Subclasses should override this + _moved_attributes = [] + + +class MovedAttribute(_LazyDescr): + + def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None): + super(MovedAttribute, self).__init__(name) + if PY3: + if new_mod is None: + new_mod = name + self.mod = new_mod + if new_attr is None: + if old_attr is None: + new_attr = name + else: + new_attr = old_attr + self.attr = new_attr + else: + self.mod = old_mod + if old_attr is None: + old_attr = name + self.attr = old_attr + + def _resolve(self): + module = _import_module(self.mod) + return getattr(module, self.attr) + + +class _SixMetaPathImporter(object): + + """ + A meta path importer to import six.moves and its submodules. + + This class implements a PEP302 finder and loader. It should be compatible + with Python 2.5 and all existing versions of Python3 + """ + + def __init__(self, six_module_name): + self.name = six_module_name + self.known_modules = {} + + def _add_module(self, mod, *fullnames): + for fullname in fullnames: + self.known_modules[self.name + "." + fullname] = mod + + def _get_module(self, fullname): + return self.known_modules[self.name + "." + fullname] + + def find_module(self, fullname, path=None): + if fullname in self.known_modules: + return self + return None + + def __get_module(self, fullname): + try: + return self.known_modules[fullname] + except KeyError: + raise ImportError("This loader does not know module " + fullname) + + def load_module(self, fullname): + try: + # in case of a reload + return sys.modules[fullname] + except KeyError: + pass + mod = self.__get_module(fullname) + if isinstance(mod, MovedModule): + mod = mod._resolve() + else: + mod.__loader__ = self + sys.modules[fullname] = mod + return mod + + def is_package(self, fullname): + """ + Return true, if the named module is a package. + + We need this method to get correct spec objects with + Python 3.4 (see PEP451) + """ + return hasattr(self.__get_module(fullname), "__path__") + + def get_code(self, fullname): + """Return None + + Required, if is_package is implemented""" + self.__get_module(fullname) # eventually raises ImportError + return None + get_source = get_code # same as get_code + +_importer = _SixMetaPathImporter(__name__) + + +class _MovedItems(_LazyModule): + + """Lazy loading of moved objects""" + __path__ = [] # mark as package + + +_moved_attributes = [ + MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"), + MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"), + MovedAttribute("filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse"), + MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"), + MovedAttribute("intern", "__builtin__", "sys"), + MovedAttribute("map", "itertools", "builtins", "imap", "map"), + MovedAttribute("getcwd", "os", "os", "getcwdu", "getcwd"), + MovedAttribute("getcwdb", "os", "os", "getcwd", "getcwdb"), + MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"), + MovedAttribute("reload_module", "__builtin__", "importlib" if PY34 else "imp", "reload"), + MovedAttribute("reduce", "__builtin__", "functools"), + MovedAttribute("shlex_quote", "pipes", "shlex", "quote"), + MovedAttribute("StringIO", "StringIO", "io"), + MovedAttribute("UserDict", "UserDict", "collections"), + MovedAttribute("UserList", "UserList", "collections"), + MovedAttribute("UserString", "UserString", "collections"), + MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"), + MovedAttribute("zip", "itertools", "builtins", "izip", "zip"), + MovedAttribute("zip_longest", "itertools", "itertools", "izip_longest", "zip_longest"), + MovedModule("builtins", "__builtin__"), + MovedModule("configparser", "ConfigParser"), + MovedModule("copyreg", "copy_reg"), + MovedModule("dbm_gnu", "gdbm", "dbm.gnu"), + MovedModule("_dummy_thread", "dummy_thread", "_dummy_thread"), + MovedModule("http_cookiejar", "cookielib", "http.cookiejar"), + MovedModule("http_cookies", "Cookie", "http.cookies"), + MovedModule("html_entities", "htmlentitydefs", "html.entities"), + MovedModule("html_parser", "HTMLParser", "html.parser"), + MovedModule("http_client", "httplib", "http.client"), + MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"), + MovedModule("email_mime_nonmultipart", "email.MIMENonMultipart", "email.mime.nonmultipart"), + MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"), + MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"), + MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"), + MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"), + MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"), + MovedModule("cPickle", "cPickle", "pickle"), + MovedModule("queue", "Queue"), + MovedModule("reprlib", "repr"), + MovedModule("socketserver", "SocketServer"), + MovedModule("_thread", "thread", "_thread"), + MovedModule("tkinter", "Tkinter"), + MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"), + MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"), + MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"), + MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"), + MovedModule("tkinter_tix", "Tix", "tkinter.tix"), + MovedModule("tkinter_ttk", "ttk", "tkinter.ttk"), + MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"), + MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"), + MovedModule("tkinter_colorchooser", "tkColorChooser", + "tkinter.colorchooser"), + MovedModule("tkinter_commondialog", "tkCommonDialog", + "tkinter.commondialog"), + MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"), + MovedModule("tkinter_font", "tkFont", "tkinter.font"), + MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"), + MovedModule("tkinter_tksimpledialog", "tkSimpleDialog", + "tkinter.simpledialog"), + MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"), + MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"), + MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"), + MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"), + MovedModule("xmlrpc_client", "xmlrpclib", "xmlrpc.client"), + MovedModule("xmlrpc_server", "SimpleXMLRPCServer", "xmlrpc.server"), +] +# Add windows specific modules. +if sys.platform == "win32": + _moved_attributes += [ + MovedModule("winreg", "_winreg"), + ] + +for attr in _moved_attributes: + setattr(_MovedItems, attr.name, attr) + if isinstance(attr, MovedModule): + _importer._add_module(attr, "moves." + attr.name) +del attr + +_MovedItems._moved_attributes = _moved_attributes + +moves = _MovedItems(__name__ + ".moves") +_importer._add_module(moves, "moves") + + +class Module_six_moves_urllib_parse(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_parse""" + + +_urllib_parse_moved_attributes = [ + MovedAttribute("ParseResult", "urlparse", "urllib.parse"), + MovedAttribute("SplitResult", "urlparse", "urllib.parse"), + MovedAttribute("parse_qs", "urlparse", "urllib.parse"), + MovedAttribute("parse_qsl", "urlparse", "urllib.parse"), + MovedAttribute("urldefrag", "urlparse", "urllib.parse"), + MovedAttribute("urljoin", "urlparse", "urllib.parse"), + MovedAttribute("urlparse", "urlparse", "urllib.parse"), + MovedAttribute("urlsplit", "urlparse", "urllib.parse"), + MovedAttribute("urlunparse", "urlparse", "urllib.parse"), + MovedAttribute("urlunsplit", "urlparse", "urllib.parse"), + MovedAttribute("quote", "urllib", "urllib.parse"), + MovedAttribute("quote_plus", "urllib", "urllib.parse"), + MovedAttribute("unquote", "urllib", "urllib.parse"), + MovedAttribute("unquote_plus", "urllib", "urllib.parse"), + MovedAttribute("urlencode", "urllib", "urllib.parse"), + MovedAttribute("splitquery", "urllib", "urllib.parse"), + MovedAttribute("splittag", "urllib", "urllib.parse"), + MovedAttribute("splituser", "urllib", "urllib.parse"), + MovedAttribute("uses_fragment", "urlparse", "urllib.parse"), + MovedAttribute("uses_netloc", "urlparse", "urllib.parse"), + MovedAttribute("uses_params", "urlparse", "urllib.parse"), + MovedAttribute("uses_query", "urlparse", "urllib.parse"), + MovedAttribute("uses_relative", "urlparse", "urllib.parse"), +] +for attr in _urllib_parse_moved_attributes: + setattr(Module_six_moves_urllib_parse, attr.name, attr) +del attr + +Module_six_moves_urllib_parse._moved_attributes = _urllib_parse_moved_attributes + +_importer._add_module(Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse"), + "moves.urllib_parse", "moves.urllib.parse") + + +class Module_six_moves_urllib_error(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_error""" + + +_urllib_error_moved_attributes = [ + MovedAttribute("URLError", "urllib2", "urllib.error"), + MovedAttribute("HTTPError", "urllib2", "urllib.error"), + MovedAttribute("ContentTooShortError", "urllib", "urllib.error"), +] +for attr in _urllib_error_moved_attributes: + setattr(Module_six_moves_urllib_error, attr.name, attr) +del attr + +Module_six_moves_urllib_error._moved_attributes = _urllib_error_moved_attributes + +_importer._add_module(Module_six_moves_urllib_error(__name__ + ".moves.urllib.error"), + "moves.urllib_error", "moves.urllib.error") + + +class Module_six_moves_urllib_request(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_request""" + + +_urllib_request_moved_attributes = [ + MovedAttribute("urlopen", "urllib2", "urllib.request"), + MovedAttribute("install_opener", "urllib2", "urllib.request"), + MovedAttribute("build_opener", "urllib2", "urllib.request"), + MovedAttribute("pathname2url", "urllib", "urllib.request"), + MovedAttribute("url2pathname", "urllib", "urllib.request"), + MovedAttribute("getproxies", "urllib", "urllib.request"), + MovedAttribute("Request", "urllib2", "urllib.request"), + MovedAttribute("OpenerDirector", "urllib2", "urllib.request"), + MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"), + MovedAttribute("ProxyHandler", "urllib2", "urllib.request"), + MovedAttribute("BaseHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"), + MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"), + MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"), + MovedAttribute("FileHandler", "urllib2", "urllib.request"), + MovedAttribute("FTPHandler", "urllib2", "urllib.request"), + MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"), + MovedAttribute("UnknownHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"), + MovedAttribute("urlretrieve", "urllib", "urllib.request"), + MovedAttribute("urlcleanup", "urllib", "urllib.request"), + MovedAttribute("URLopener", "urllib", "urllib.request"), + MovedAttribute("FancyURLopener", "urllib", "urllib.request"), + MovedAttribute("proxy_bypass", "urllib", "urllib.request"), +] +for attr in _urllib_request_moved_attributes: + setattr(Module_six_moves_urllib_request, attr.name, attr) +del attr + +Module_six_moves_urllib_request._moved_attributes = _urllib_request_moved_attributes + +_importer._add_module(Module_six_moves_urllib_request(__name__ + ".moves.urllib.request"), + "moves.urllib_request", "moves.urllib.request") + + +class Module_six_moves_urllib_response(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_response""" + + +_urllib_response_moved_attributes = [ + MovedAttribute("addbase", "urllib", "urllib.response"), + MovedAttribute("addclosehook", "urllib", "urllib.response"), + MovedAttribute("addinfo", "urllib", "urllib.response"), + MovedAttribute("addinfourl", "urllib", "urllib.response"), +] +for attr in _urllib_response_moved_attributes: + setattr(Module_six_moves_urllib_response, attr.name, attr) +del attr + +Module_six_moves_urllib_response._moved_attributes = _urllib_response_moved_attributes + +_importer._add_module(Module_six_moves_urllib_response(__name__ + ".moves.urllib.response"), + "moves.urllib_response", "moves.urllib.response") + + +class Module_six_moves_urllib_robotparser(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_robotparser""" + + +_urllib_robotparser_moved_attributes = [ + MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"), +] +for attr in _urllib_robotparser_moved_attributes: + setattr(Module_six_moves_urllib_robotparser, attr.name, attr) +del attr + +Module_six_moves_urllib_robotparser._moved_attributes = _urllib_robotparser_moved_attributes + +_importer._add_module(Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser"), + "moves.urllib_robotparser", "moves.urllib.robotparser") + + +class Module_six_moves_urllib(types.ModuleType): + + """Create a six.moves.urllib namespace that resembles the Python 3 namespace""" + __path__ = [] # mark as package + parse = _importer._get_module("moves.urllib_parse") + error = _importer._get_module("moves.urllib_error") + request = _importer._get_module("moves.urllib_request") + response = _importer._get_module("moves.urllib_response") + robotparser = _importer._get_module("moves.urllib_robotparser") + + def __dir__(self): + return ['parse', 'error', 'request', 'response', 'robotparser'] + +_importer._add_module(Module_six_moves_urllib(__name__ + ".moves.urllib"), + "moves.urllib") + + +def add_move(move): + """Add an item to six.moves.""" + setattr(_MovedItems, move.name, move) + + +def remove_move(name): + """Remove item from six.moves.""" + try: + delattr(_MovedItems, name) + except AttributeError: + try: + del moves.__dict__[name] + except KeyError: + raise AttributeError("no such move, %r" % (name,)) + + +if PY3: + _meth_func = "__func__" + _meth_self = "__self__" + + _func_closure = "__closure__" + _func_code = "__code__" + _func_defaults = "__defaults__" + _func_globals = "__globals__" +else: + _meth_func = "im_func" + _meth_self = "im_self" + + _func_closure = "func_closure" + _func_code = "func_code" + _func_defaults = "func_defaults" + _func_globals = "func_globals" + + +try: + advance_iterator = next +except NameError: + def advance_iterator(it): + return it.next() +next = advance_iterator + + +try: + callable = callable +except NameError: + def callable(obj): + return any("__call__" in klass.__dict__ for klass in type(obj).__mro__) + + +if PY3: + def get_unbound_function(unbound): + return unbound + + create_bound_method = types.MethodType + + def create_unbound_method(func, cls): + return func + + Iterator = object +else: + def get_unbound_function(unbound): + return unbound.im_func + + def create_bound_method(func, obj): + return types.MethodType(func, obj, obj.__class__) + + def create_unbound_method(func, cls): + return types.MethodType(func, None, cls) + + class Iterator(object): + + def next(self): + return type(self).__next__(self) + + callable = callable +_add_doc(get_unbound_function, + """Get the function out of a possibly unbound function""") + + +get_method_function = operator.attrgetter(_meth_func) +get_method_self = operator.attrgetter(_meth_self) +get_function_closure = operator.attrgetter(_func_closure) +get_function_code = operator.attrgetter(_func_code) +get_function_defaults = operator.attrgetter(_func_defaults) +get_function_globals = operator.attrgetter(_func_globals) + + +if PY3: + def iterkeys(d, **kw): + return iter(d.keys(**kw)) + + def itervalues(d, **kw): + return iter(d.values(**kw)) + + def iteritems(d, **kw): + return iter(d.items(**kw)) + + def iterlists(d, **kw): + return iter(d.lists(**kw)) + + viewkeys = operator.methodcaller("keys") + + viewvalues = operator.methodcaller("values") + + viewitems = operator.methodcaller("items") +else: + def iterkeys(d, **kw): + return d.iterkeys(**kw) + + def itervalues(d, **kw): + return d.itervalues(**kw) + + def iteritems(d, **kw): + return d.iteritems(**kw) + + def iterlists(d, **kw): + return d.iterlists(**kw) + + viewkeys = operator.methodcaller("viewkeys") + + viewvalues = operator.methodcaller("viewvalues") + + viewitems = operator.methodcaller("viewitems") + +_add_doc(iterkeys, "Return an iterator over the keys of a dictionary.") +_add_doc(itervalues, "Return an iterator over the values of a dictionary.") +_add_doc(iteritems, + "Return an iterator over the (key, value) pairs of a dictionary.") +_add_doc(iterlists, + "Return an iterator over the (key, [values]) pairs of a dictionary.") + + +if PY3: + def b(s): + return s.encode("latin-1") + + def u(s): + return s + unichr = chr + import struct + int2byte = struct.Struct(">B").pack + del struct + byte2int = operator.itemgetter(0) + indexbytes = operator.getitem + iterbytes = iter + import io + StringIO = io.StringIO + BytesIO = io.BytesIO + _assertCountEqual = "assertCountEqual" + if sys.version_info[1] <= 1: + _assertRaisesRegex = "assertRaisesRegexp" + _assertRegex = "assertRegexpMatches" + else: + _assertRaisesRegex = "assertRaisesRegex" + _assertRegex = "assertRegex" +else: + def b(s): + return s + # Workaround for standalone backslash + + def u(s): + return unicode(s.replace(r'\\', r'\\\\'), "unicode_escape") + unichr = unichr + int2byte = chr + + def byte2int(bs): + return ord(bs[0]) + + def indexbytes(buf, i): + return ord(buf[i]) + iterbytes = functools.partial(itertools.imap, ord) + import StringIO + StringIO = BytesIO = StringIO.StringIO + _assertCountEqual = "assertItemsEqual" + _assertRaisesRegex = "assertRaisesRegexp" + _assertRegex = "assertRegexpMatches" +_add_doc(b, """Byte literal""") +_add_doc(u, """Text literal""") + + +def assertCountEqual(self, *args, **kwargs): + return getattr(self, _assertCountEqual)(*args, **kwargs) + + +def assertRaisesRegex(self, *args, **kwargs): + return getattr(self, _assertRaisesRegex)(*args, **kwargs) + + +def assertRegex(self, *args, **kwargs): + return getattr(self, _assertRegex)(*args, **kwargs) + + +if PY3: + exec_ = getattr(moves.builtins, "exec") + + def reraise(tp, value, tb=None): + if value is None: + value = tp() + if value.__traceback__ is not tb: + raise value.with_traceback(tb) + raise value + +else: + def exec_(_code_, _globs_=None, _locs_=None): + """Execute code in a namespace.""" + if _globs_ is None: + frame = sys._getframe(1) + _globs_ = frame.f_globals + if _locs_ is None: + _locs_ = frame.f_locals + del frame + elif _locs_ is None: + _locs_ = _globs_ + exec("""exec _code_ in _globs_, _locs_""") + + exec_("""def reraise(tp, value, tb=None): + raise tp, value, tb +""") + + +if sys.version_info[:2] == (3, 2): + exec_("""def raise_from(value, from_value): + if from_value is None: + raise value + raise value from from_value +""") +elif sys.version_info[:2] > (3, 2): + exec_("""def raise_from(value, from_value): + raise value from from_value +""") +else: + def raise_from(value, from_value): + raise value + + +print_ = getattr(moves.builtins, "print", None) +if print_ is None: + def print_(*args, **kwargs): + """The new-style print function for Python 2.4 and 2.5.""" + fp = kwargs.pop("file", sys.stdout) + if fp is None: + return + + def write(data): + if not isinstance(data, basestring): + data = str(data) + # If the file has an encoding, encode unicode with it. + if (isinstance(fp, file) and + isinstance(data, unicode) and + fp.encoding is not None): + errors = getattr(fp, "errors", None) + if errors is None: + errors = "strict" + data = data.encode(fp.encoding, errors) + fp.write(data) + want_unicode = False + sep = kwargs.pop("sep", None) + if sep is not None: + if isinstance(sep, unicode): + want_unicode = True + elif not isinstance(sep, str): + raise TypeError("sep must be None or a string") + end = kwargs.pop("end", None) + if end is not None: + if isinstance(end, unicode): + want_unicode = True + elif not isinstance(end, str): + raise TypeError("end must be None or a string") + if kwargs: + raise TypeError("invalid keyword arguments to print()") + if not want_unicode: + for arg in args: + if isinstance(arg, unicode): + want_unicode = True + break + if want_unicode: + newline = unicode("\n") + space = unicode(" ") + else: + newline = "\n" + space = " " + if sep is None: + sep = space + if end is None: + end = newline + for i, arg in enumerate(args): + if i: + write(sep) + write(arg) + write(end) +if sys.version_info[:2] < (3, 3): + _print = print_ + + def print_(*args, **kwargs): + fp = kwargs.get("file", sys.stdout) + flush = kwargs.pop("flush", False) + _print(*args, **kwargs) + if flush and fp is not None: + fp.flush() + +_add_doc(reraise, """Reraise an exception.""") + +if sys.version_info[0:2] < (3, 4): + def wraps(wrapped, assigned=functools.WRAPPER_ASSIGNMENTS, + updated=functools.WRAPPER_UPDATES): + def wrapper(f): + f = functools.wraps(wrapped, assigned, updated)(f) + f.__wrapped__ = wrapped + return f + return wrapper +else: + wraps = functools.wraps + + +def with_metaclass(meta, *bases): + """Create a base class with a metaclass.""" + # This requires a bit of explanation: the basic idea is to make a dummy + # metaclass for one level of class instantiation that replaces itself with + # the actual metaclass. + class metaclass(meta): + + def __new__(cls, name, this_bases, d): + return meta(name, bases, d) + return type.__new__(metaclass, 'temporary_class', (), {}) + + +def add_metaclass(metaclass): + """Class decorator for creating a class with a metaclass.""" + def wrapper(cls): + orig_vars = cls.__dict__.copy() + slots = orig_vars.get('__slots__') + if slots is not None: + if isinstance(slots, str): + slots = [slots] + for slots_var in slots: + orig_vars.pop(slots_var) + orig_vars.pop('__dict__', None) + orig_vars.pop('__weakref__', None) + return metaclass(cls.__name__, cls.__bases__, orig_vars) + return wrapper + + +def python_2_unicode_compatible(klass): + """ + A decorator that defines __unicode__ and __str__ methods under Python 2. + Under Python 3 it does nothing. + + To support Python 2 and 3 with a single code base, define a __str__ method + returning text and apply this decorator to the class. + """ + if PY2: + if '__str__' not in klass.__dict__: + raise ValueError("@python_2_unicode_compatible cannot be applied " + "to %s because it doesn't define __str__()." % + klass.__name__) + klass.__unicode__ = klass.__str__ + klass.__str__ = lambda self: self.__unicode__().encode('utf-8') + return klass + + +# Complete the moves implementation. +# This code is at the end of this module to speed up module loading. +# Turn this module into a package. +__path__ = [] # required for PEP 302 and PEP 451 +__package__ = __name__ # see PEP 366 @ReservedAssignment +if globals().get("__spec__") is not None: + __spec__.submodule_search_locations = [] # PEP 451 @UndefinedVariable +# Remove other six meta path importers, since they cause problems. This can +# happen if six is removed from sys.modules and then reloaded. (Setuptools does +# this for some reason.) +if sys.meta_path: + for i, importer in enumerate(sys.meta_path): + # Here's some real nastiness: Another "instance" of the six module might + # be floating around. Therefore, we can't use isinstance() to check for + # the six meta path importer, since the other six instance will have + # inserted an importer with different class. + if (type(importer).__name__ == "_SixMetaPathImporter" and + importer.name == __name__): + del sys.meta_path[i] + break + del i, importer +# Finally, add the importer to the meta path import hook. +sys.meta_path.append(_importer) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/extern/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/extern/__init__.py new file mode 100644 index 0000000..c1eb9e9 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/extern/__init__.py @@ -0,0 +1,73 @@ +import sys + + +class VendorImporter: + """ + A PEP 302 meta path importer for finding optionally-vendored + or otherwise naturally-installed packages from root_name. + """ + + def __init__(self, root_name, vendored_names=(), vendor_pkg=None): + self.root_name = root_name + self.vendored_names = set(vendored_names) + self.vendor_pkg = vendor_pkg or root_name.replace('extern', '_vendor') + + @property + def search_path(self): + """ + Search first the vendor package then as a natural package. + """ + yield self.vendor_pkg + '.' + yield '' + + def find_module(self, fullname, path=None): + """ + Return self when fullname starts with root_name and the + target module is one vendored through this importer. + """ + root, base, target = fullname.partition(self.root_name + '.') + if root: + return + if not any(map(target.startswith, self.vendored_names)): + return + return self + + def load_module(self, fullname): + """ + Iterate over the search path to locate and load fullname. + """ + root, base, target = fullname.partition(self.root_name + '.') + for prefix in self.search_path: + try: + extant = prefix + target + __import__(extant) + mod = sys.modules[extant] + sys.modules[fullname] = mod + # mysterious hack: + # Remove the reference to the extant package/module + # on later Python versions to cause relative imports + # in the vendor package to resolve the same modules + # as those going through this importer. + if prefix and sys.version_info > (3, 3): + del sys.modules[extant] + return mod + except ImportError: + pass + else: + raise ImportError( + "The '{target}' package is required; " + "normally this is bundled with this package so if you get " + "this warning, consult the packager of your " + "distribution.".format(**locals()) + ) + + def install(self): + """ + Install this importer into sys.meta_path if not already present. + """ + if self not in sys.meta_path: + sys.meta_path.append(self) + + +names = 'packaging', 'pyparsing', 'six', 'appdirs' +VendorImporter(__name__, names).install() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/extern/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/extern/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f8d2f5f68b0af44c6be617efd2506e3f3f0d8c91 GIT binary patch literal 2462 zcmZ`)TW=dh6rS0e9p}=5L_!O#Mj$Ab+Bg(cQBhD)TcHXRRc$F?6;>P1INoHvvz-|` zvDv)fh({ifcyAv2#&6(f%qvg)0UnSLoHJ`XX(Gm&<C&e?Ip_Q4o3ECa8wAQ<za1sN zFA(wvc1{)_I=7+ft6(_cG$U>DIpH4n4+-}tUYqiu?FlM;;Z3~f!4aV_>k(;&f5Hl~ z*+F}<%y+yEUj>2nr0sFq_W24Acz8(Lfe3lTYlmb)+Yvv<>wE#e)_8+29+GyQFY#sg zU*JBRa^9{y5jmIYe!q~)2sJ)zFesm~2lpPZ4>qo|zAy<Z64PVpbPDTA#ky(E(|nuB z!lW`!vTSs1=r$7EZ2(iG=?S%$YQgfv43wLb=Gs6*aM-f5n`{fsx=Qw$lG4O^(iiJ) z^$Q3*I1x3rvEG5I-vv|BlElQ&(wkt*EB)efNuT?ia_`84F99bIp1;|S#6E<T+ge=t z*9`5#{50!pVeHDxbLWA!H6@BH=?L4X2I69OyBXL(i>#|cI9=7y0Nz9)9M1ebY85IS zCPuV|iE4Fa#)Z<YoBOTp_~uac$NBZ{&PK1dKOV=~%^O=iwE<;2Z#`}mX>o0um}?sw zH-@9(`-2uZHYkjgnQp=Hu@YJiR7dDm6;CUU(>yhCyk3lKebzxT>Ie*>5pB@%+LM>S zU7yYCP@FR@*!G|z)$}TulI#En*T@s(qUS7fB^ZC{z(IaI5{c^cfCWk$1~{`SQ!`ZY zQ_d32k{R~1kqTej!qRn1Hk;Jt@dZ`r`*AweB6RJdcIU*%zjNrGBSpAG#}`jUc4A@& zF_{%i#+*4HK?hiZ0a6U`h(7fX{Da^iEPZvEdyk0mj9-R30n7*|z%BhDek~oB#y`!& ze+b~HoFO6D9){W-WEs+z0lk&cY%hfiGp89#a*ipPuZKz7!mz&NgG{hgGnvm)2v@`O zlpJjL;2%b2x9&J`Y8k@VY({pWfU{D(e~y*bPx6uV`$=INl^f`V<7zW<>9zHlpEkgh z+5la&!B(P$jVh<kK!7(rt~_0XgY^;^60Xt!ey>731I3929pu%l)S-cQ<_=W-3z#!d zcnAih-n&b_`~Dyt-z~#3SR)4!fD%n8B_`Mj%jg0*sFgL>rng8Ls;AJ7xVIa)7R>mB zl(nyc)D(aVh^g&1)INnCCEt=~Z+-*S)VRM>?-H{xAwSaz{SkB+Rd@Ww9Hjf88*rVO z914Z#0o;!CP7IA?ne5;&Vw=f?&pB`ksiyZQ5>mYZX8h}8*yqX*RjLoJ%x(ozK#6CA zR0;ku%cbh0T22X|+14QEsF{vcjulh&WLmPc%SLj*kWX%CFHt!t^HtW7xgKQI^_<QJ zQFgNx<Eb_(-5MZ!);F6C^$Pmv#O*w^Yy+gi>3tl7NRB`hD+*}41nJPQ3iPKd?PB$C z+*3*_8^O!aPmGN)HJNVKt4sYFZjIbgucNtu`$vTm-E`l{bCMgNt>kB@hiRQs?`>G5 z-vUE|RZupM*5TKnjcCRFgY`Tb`N2Qlzh?+}Vw*F<htN1eUW7(T3@F2HO|9bpb9hIN zfOPIT_Qns7iBUabFW*m==D-Qa)H=SHPO%W0TpE^SN+f*5AY?6abIgy;rmrr+xprZ` z#zsj|fM_d}yVD7&O<#%IFjh%n03yG7N(!fwnx0z@3JdV!6M^~!Xaceol+a#^<7b1! zDHrr=am-~Wjul>UTQ8I>gfb(Agix3t^$wc%&^SsT8&qqBmmRfMuYjr3AZ&ylZPXe| z^-FFH-cXP%eD;B#&>Vq&X>9sB-M2LeoWpz43|&s#3LB!+S~YR||2x;#Z&d+(iZ7Xa L{_6h9-GKfF0p^Bz literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/py31compat.py b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/py31compat.py new file mode 100644 index 0000000..a381c42 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/pkg_resources/py31compat.py @@ -0,0 +1,23 @@ +import os +import errno +import sys + +from .extern import six + + +def _makedirs_31(path, exist_ok=False): + try: + os.makedirs(path) + except OSError as exc: + if not exist_ok or exc.errno != errno.EEXIST: + raise + + +# rely on compatibility behavior until mode considerations +# and exists_ok considerations are disentangled. +# See https://github.com/pypa/setuptools/pull/1083#issuecomment-315168663 +needs_makedirs = ( + six.PY2 or + (3, 4) <= sys.version_info < (3, 4, 1) +) +makedirs = _makedirs_31 if needs_makedirs else os.makedirs diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/INSTALLER b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/LICENSE b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/LICENSE new file mode 100644 index 0000000..6e0693b --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/LICENSE @@ -0,0 +1,19 @@ +Copyright (C) 2016 Jason R Coombs <jaraco@jaraco.com> + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies +of the Software, and to permit persons to whom the Software is furnished to do +so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/METADATA b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/METADATA new file mode 100644 index 0000000..96f2587 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/METADATA @@ -0,0 +1,77 @@ +Metadata-Version: 2.1 +Name: setuptools +Version: 41.2.0 +Summary: Easily download, build, install, upgrade, and uninstall Python packages +Home-page: https://github.com/pypa/setuptools +Author: Python Packaging Authority +Author-email: distutils-sig@python.org +License: UNKNOWN +Project-URL: Documentation, https://setuptools.readthedocs.io/ +Keywords: CPAN PyPI distutils eggs package management +Platform: UNKNOWN +Classifier: Development Status :: 5 - Production/Stable +Classifier: Intended Audience :: Developers +Classifier: License :: OSI Approved :: MIT License +Classifier: Operating System :: OS Independent +Classifier: Programming Language :: Python :: 2 +Classifier: Programming Language :: Python :: 2.7 +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3.4 +Classifier: Programming Language :: Python :: 3.5 +Classifier: Programming Language :: Python :: 3.6 +Classifier: Programming Language :: Python :: 3.7 +Classifier: Topic :: Software Development :: Libraries :: Python Modules +Classifier: Topic :: System :: Archiving :: Packaging +Classifier: Topic :: System :: Systems Administration +Classifier: Topic :: Utilities +Requires-Python: >=2.7,!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.* +Description-Content-Type: text/x-rst; charset=UTF-8 +Provides-Extra: certs +Requires-Dist: certifi (==2016.9.26) ; extra == 'certs' +Provides-Extra: ssl +Requires-Dist: wincertstore (==0.2) ; (sys_platform == "win32") and extra == 'ssl' + +.. image:: https://img.shields.io/pypi/v/setuptools.svg + :target: https://pypi.org/project/setuptools + +.. image:: https://img.shields.io/readthedocs/setuptools/latest.svg + :target: https://setuptools.readthedocs.io + +.. image:: https://img.shields.io/travis/pypa/setuptools/master.svg?label=Linux%20CI&logo=travis&logoColor=white + :target: https://travis-ci.org/pypa/setuptools + +.. image:: https://img.shields.io/appveyor/ci/pypa/setuptools/master.svg?label=Windows%20CI&logo=appveyor&logoColor=white + :target: https://ci.appveyor.com/project/pypa/setuptools/branch/master + +.. image:: https://img.shields.io/codecov/c/github/pypa/setuptools/master.svg?logo=codecov&logoColor=white + :target: https://codecov.io/gh/pypa/setuptools + +.. image:: https://tidelift.com/badges/github/pypa/setuptools?style=flat + :target: https://tidelift.com/subscription/pkg/pypi-setuptools?utm_source=pypi-setuptools&utm_medium=readme + +.. image:: https://img.shields.io/pypi/pyversions/setuptools.svg + +See the `Installation Instructions +<https://packaging.python.org/installing/>`_ in the Python Packaging +User's Guide for instructions on installing, upgrading, and uninstalling +Setuptools. + +Questions and comments should be directed to the `distutils-sig +mailing list <http://mail.python.org/pipermail/distutils-sig/>`_. +Bug reports and especially tested patches may be +submitted directly to the `bug tracker +<https://github.com/pypa/setuptools/issues>`_. + +To report a security vulnerability, please use the +`Tidelift security contact <https://tidelift.com/security>`_. +Tidelift will coordinate the fix and disclosure. + + +Code of Conduct +--------------- + +Everyone interacting in the setuptools project's codebases, issue trackers, +chat rooms, and mailing lists is expected to follow the +`PyPA Code of Conduct <https://www.pypa.io/en/latest/code-of-conduct/>`_. + + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/RECORD b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/RECORD new file mode 100644 index 0000000..ca96281 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/RECORD @@ -0,0 +1,186 @@ +../../../bin/easy_install,sha256=bMNdNldL515_JDxqarMGO3GoMaibQXXabU3Du1zfBRE,300 +../../../bin/easy_install-3.8,sha256=bMNdNldL515_JDxqarMGO3GoMaibQXXabU3Du1zfBRE,300 +__pycache__/easy_install.cpython-38.pyc,, +easy_install.py,sha256=MDC9vt5AxDsXX5qcKlBz2TnW6Tpuv_AobnfhCJ9X3PM,126 +pkg_resources/__init__.py,sha256=6Kq6B-JSGEFSg_2FAnl6Lmoa5by2RyjDxPBiWuAh-dw,108309 +pkg_resources/__pycache__/__init__.cpython-38.pyc,, +pkg_resources/__pycache__/py31compat.cpython-38.pyc,, +pkg_resources/_vendor/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +pkg_resources/_vendor/__pycache__/__init__.cpython-38.pyc,, +pkg_resources/_vendor/__pycache__/appdirs.cpython-38.pyc,, +pkg_resources/_vendor/__pycache__/pyparsing.cpython-38.pyc,, +pkg_resources/_vendor/__pycache__/six.cpython-38.pyc,, +pkg_resources/_vendor/appdirs.py,sha256=MievUEuv3l_mQISH5SF0shDk_BNhHHzYiAPrT3ITN4I,24701 +pkg_resources/_vendor/packaging/__about__.py,sha256=zkcCPTN_6TcLW0Nrlg0176-R1QQ_WVPTm8sz1R4-HjM,720 +pkg_resources/_vendor/packaging/__init__.py,sha256=_vNac5TrzwsrzbOFIbF-5cHqc_Y2aPT2D7zrIR06BOo,513 +pkg_resources/_vendor/packaging/__pycache__/__about__.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/__init__.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/_compat.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/_structures.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/markers.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/requirements.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/utils.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/version.cpython-38.pyc,, +pkg_resources/_vendor/packaging/_compat.py,sha256=Vi_A0rAQeHbU-a9X0tt1yQm9RqkgQbDSxzRw8WlU9kA,860 +pkg_resources/_vendor/packaging/_structures.py,sha256=RImECJ4c_wTlaTYYwZYLHEiebDMaAJmK1oPARhw1T5o,1416 +pkg_resources/_vendor/packaging/markers.py,sha256=uEcBBtGvzqltgnArqb9c4RrcInXezDLos14zbBHhWJo,8248 +pkg_resources/_vendor/packaging/requirements.py,sha256=SikL2UynbsT0qtY9ltqngndha_sfo0w6XGFhAhoSoaQ,4355 +pkg_resources/_vendor/packaging/specifiers.py,sha256=SAMRerzO3fK2IkFZCaZkuwZaL_EGqHNOz4pni4vhnN0,28025 +pkg_resources/_vendor/packaging/utils.py,sha256=3m6WvPm6NNxE8rkTGmn0r75B_GZSGg7ikafxHsBN1WA,421 +pkg_resources/_vendor/packaging/version.py,sha256=OwGnxYfr2ghNzYx59qWIBkrK3SnB6n-Zfd1XaLpnnM0,11556 +pkg_resources/_vendor/pyparsing.py,sha256=tmrp-lu-qO1i75ZzIN5A12nKRRD1Cm4Vpk-5LR9rims,232055 +pkg_resources/_vendor/six.py,sha256=A6hdJZVjI3t_geebZ9BzUvwRrIXo0lfwzQlM2LcKyas,30098 +pkg_resources/extern/__init__.py,sha256=cHiEfHuLmm6rs5Ve_ztBfMI7Lr31vss-D4wkqF5xzlI,2498 +pkg_resources/extern/__pycache__/__init__.cpython-38.pyc,, +pkg_resources/py31compat.py,sha256=-WQ0e4c3RG_acdhwC3gLiXhP_lg4G5q7XYkZkQg0gxU,558 +setuptools-41.2.0.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +setuptools-41.2.0.dist-info/LICENSE,sha256=wyo6w5WvYyHv0ovnPQagDw22q4h9HCHU_sRhKNIFbVo,1078 +setuptools-41.2.0.dist-info/METADATA,sha256=_t0DvK_bLLT2yjvvNOCXiSIoNJvjX6dTWT8fLNVrUQk,3305 +setuptools-41.2.0.dist-info/RECORD,, +setuptools-41.2.0.dist-info/WHEEL,sha256=8zNYZbwQSXoB9IfXOjPfeNwvAsALAjffgk27FqvCWbo,110 +setuptools-41.2.0.dist-info/dependency_links.txt,sha256=HlkCFkoK5TbZ5EMLbLKYhLcY_E31kBWD8TqW2EgmatQ,239 +setuptools-41.2.0.dist-info/entry_points.txt,sha256=jBqCYDlVjl__sjYFGXo1JQGIMAYFJE-prYWUtnMZEew,2990 +setuptools-41.2.0.dist-info/top_level.txt,sha256=2HUXVVwA4Pff1xgTFr3GsTXXKaPaO6vlG6oNJ_4u4Tg,38 +setuptools-41.2.0.dist-info/zip-safe,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1 +setuptools/__init__.py,sha256=WBpCcn2lvdckotabeae1TTYonPOcgCIF3raD2zRWzBc,7283 +setuptools/__pycache__/__init__.cpython-38.pyc,, +setuptools/__pycache__/_deprecation_warning.cpython-38.pyc,, +setuptools/__pycache__/archive_util.cpython-38.pyc,, +setuptools/__pycache__/build_meta.cpython-38.pyc,, +setuptools/__pycache__/config.cpython-38.pyc,, +setuptools/__pycache__/dep_util.cpython-38.pyc,, +setuptools/__pycache__/depends.cpython-38.pyc,, +setuptools/__pycache__/dist.cpython-38.pyc,, +setuptools/__pycache__/extension.cpython-38.pyc,, +setuptools/__pycache__/glibc.cpython-38.pyc,, +setuptools/__pycache__/glob.cpython-38.pyc,, +setuptools/__pycache__/launch.cpython-38.pyc,, +setuptools/__pycache__/lib2to3_ex.cpython-38.pyc,, +setuptools/__pycache__/monkey.cpython-38.pyc,, +setuptools/__pycache__/msvc.cpython-38.pyc,, +setuptools/__pycache__/namespaces.cpython-38.pyc,, +setuptools/__pycache__/package_index.cpython-38.pyc,, +setuptools/__pycache__/pep425tags.cpython-38.pyc,, +setuptools/__pycache__/py27compat.cpython-38.pyc,, +setuptools/__pycache__/py31compat.cpython-38.pyc,, +setuptools/__pycache__/py33compat.cpython-38.pyc,, +setuptools/__pycache__/sandbox.cpython-38.pyc,, +setuptools/__pycache__/site-patch.cpython-38.pyc,, +setuptools/__pycache__/ssl_support.cpython-38.pyc,, +setuptools/__pycache__/unicode_utils.cpython-38.pyc,, +setuptools/__pycache__/version.cpython-38.pyc,, +setuptools/__pycache__/wheel.cpython-38.pyc,, +setuptools/__pycache__/windows_support.cpython-38.pyc,, +setuptools/_deprecation_warning.py,sha256=jU9-dtfv6cKmtQJOXN8nP1mm7gONw5kKEtiPtbwnZyI,218 +setuptools/_vendor/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +setuptools/_vendor/__pycache__/__init__.cpython-38.pyc,, +setuptools/_vendor/__pycache__/pyparsing.cpython-38.pyc,, +setuptools/_vendor/__pycache__/six.cpython-38.pyc,, +setuptools/_vendor/packaging/__about__.py,sha256=zkcCPTN_6TcLW0Nrlg0176-R1QQ_WVPTm8sz1R4-HjM,720 +setuptools/_vendor/packaging/__init__.py,sha256=_vNac5TrzwsrzbOFIbF-5cHqc_Y2aPT2D7zrIR06BOo,513 +setuptools/_vendor/packaging/__pycache__/__about__.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/__init__.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/_compat.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/_structures.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/markers.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/requirements.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/utils.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/version.cpython-38.pyc,, +setuptools/_vendor/packaging/_compat.py,sha256=Vi_A0rAQeHbU-a9X0tt1yQm9RqkgQbDSxzRw8WlU9kA,860 +setuptools/_vendor/packaging/_structures.py,sha256=RImECJ4c_wTlaTYYwZYLHEiebDMaAJmK1oPARhw1T5o,1416 +setuptools/_vendor/packaging/markers.py,sha256=Gvpk9EY20yKaMTiKgQZ8yFEEpodqVgVYtfekoic1Yts,8239 +setuptools/_vendor/packaging/requirements.py,sha256=t44M2HVWtr8phIz2OhnILzuGT3rTATaovctV1dpnVIg,4343 +setuptools/_vendor/packaging/specifiers.py,sha256=SAMRerzO3fK2IkFZCaZkuwZaL_EGqHNOz4pni4vhnN0,28025 +setuptools/_vendor/packaging/utils.py,sha256=3m6WvPm6NNxE8rkTGmn0r75B_GZSGg7ikafxHsBN1WA,421 +setuptools/_vendor/packaging/version.py,sha256=OwGnxYfr2ghNzYx59qWIBkrK3SnB6n-Zfd1XaLpnnM0,11556 +setuptools/_vendor/pyparsing.py,sha256=tmrp-lu-qO1i75ZzIN5A12nKRRD1Cm4Vpk-5LR9rims,232055 +setuptools/_vendor/six.py,sha256=A6hdJZVjI3t_geebZ9BzUvwRrIXo0lfwzQlM2LcKyas,30098 +setuptools/archive_util.py,sha256=kw8Ib_lKjCcnPKNbS7h8HztRVK0d5RacU3r_KRdVnmM,6592 +setuptools/build_meta.py,sha256=-9Nmj9YdbW4zX3TssPJZhsENrTa4fw3k86Jm1cdKMik,9597 +setuptools/cli-32.exe,sha256=dfEuovMNnA2HLa3jRfMPVi5tk4R7alCbpTvuxtCyw0Y,65536 +setuptools/cli-64.exe,sha256=KLABu5pyrnokJCv6skjXZ6GsXeyYHGcqOUT3oHI3Xpo,74752 +setuptools/cli.exe,sha256=dfEuovMNnA2HLa3jRfMPVi5tk4R7alCbpTvuxtCyw0Y,65536 +setuptools/command/__init__.py,sha256=NWzJ0A1BEengZpVeqUyWLNm2bk4P3F4iL5QUErHy7kA,594 +setuptools/command/__pycache__/__init__.cpython-38.pyc,, +setuptools/command/__pycache__/alias.cpython-38.pyc,, +setuptools/command/__pycache__/bdist_egg.cpython-38.pyc,, +setuptools/command/__pycache__/bdist_rpm.cpython-38.pyc,, +setuptools/command/__pycache__/bdist_wininst.cpython-38.pyc,, +setuptools/command/__pycache__/build_clib.cpython-38.pyc,, +setuptools/command/__pycache__/build_ext.cpython-38.pyc,, +setuptools/command/__pycache__/build_py.cpython-38.pyc,, +setuptools/command/__pycache__/develop.cpython-38.pyc,, +setuptools/command/__pycache__/dist_info.cpython-38.pyc,, +setuptools/command/__pycache__/easy_install.cpython-38.pyc,, +setuptools/command/__pycache__/egg_info.cpython-38.pyc,, +setuptools/command/__pycache__/install.cpython-38.pyc,, +setuptools/command/__pycache__/install_egg_info.cpython-38.pyc,, +setuptools/command/__pycache__/install_lib.cpython-38.pyc,, +setuptools/command/__pycache__/install_scripts.cpython-38.pyc,, +setuptools/command/__pycache__/py36compat.cpython-38.pyc,, +setuptools/command/__pycache__/register.cpython-38.pyc,, +setuptools/command/__pycache__/rotate.cpython-38.pyc,, +setuptools/command/__pycache__/saveopts.cpython-38.pyc,, +setuptools/command/__pycache__/sdist.cpython-38.pyc,, +setuptools/command/__pycache__/setopt.cpython-38.pyc,, +setuptools/command/__pycache__/test.cpython-38.pyc,, +setuptools/command/__pycache__/upload.cpython-38.pyc,, +setuptools/command/__pycache__/upload_docs.cpython-38.pyc,, +setuptools/command/alias.py,sha256=KjpE0sz_SDIHv3fpZcIQK-sCkJz-SrC6Gmug6b9Nkc8,2426 +setuptools/command/bdist_egg.py,sha256=be-IBpr1zhS9i6GjKANJgzkbH3ChImdWY7S-j0r2BK8,18167 +setuptools/command/bdist_rpm.py,sha256=B7l0TnzCGb-0nLlm6rS00jWLkojASwVmdhW2w5Qz_Ak,1508 +setuptools/command/bdist_wininst.py,sha256=_6dz3lpB1tY200LxKPLM7qgwTCceOMgaWFF-jW2-pm0,637 +setuptools/command/build_clib.py,sha256=bQ9aBr-5ZSO-9fGsGsDLz0mnnFteHUZnftVLkhvHDq0,4484 +setuptools/command/build_ext.py,sha256=Ib42YUGksBswm2mL5xmQPF6NeTA6HcqrvAtEgFCv32A,13019 +setuptools/command/build_py.py,sha256=yWyYaaS9F3o9JbIczn064A5g1C5_UiKRDxGaTqYbtLE,9596 +setuptools/command/develop.py,sha256=MQlnGS6uP19erK2JCNOyQYoYyquk3PADrqrrinqqLtA,8184 +setuptools/command/dist_info.py,sha256=5t6kOfrdgALT-P3ogss6PF9k-Leyesueycuk3dUyZnI,960 +setuptools/command/easy_install.py,sha256=telww7CuPsoTtvlpY-ktnZGT85cZ6xGCGZa0vHvFJ-Q,87273 +setuptools/command/egg_info.py,sha256=w73EdxYSOk2gsaAiHGL2dZrCldoPiuRr2eTfqcFvCds,25570 +setuptools/command/install.py,sha256=a0EZpL_A866KEdhicTGbuyD_TYl1sykfzdrri-zazT4,4683 +setuptools/command/install_egg_info.py,sha256=bMgeIeRiXzQ4DAGPV1328kcjwQjHjOWU4FngAWLV78Q,2203 +setuptools/command/install_lib.py,sha256=r5NuasaSxvmIrjgZNj38Iq-1UJG1o1ms7CuHq6MCTbQ,3862 +setuptools/command/install_scripts.py,sha256=UD0rEZ6861mTYhIdzcsqKnUl8PozocXWl9VBQ1VTWnc,2439 +setuptools/command/launcher manifest.xml,sha256=xlLbjWrB01tKC0-hlVkOKkiSPbzMml2eOPtJ_ucCnbE,628 +setuptools/command/py36compat.py,sha256=SzjZcOxF7zdFUT47Zv2n7AM3H8koDys_0OpS-n9gIfc,4986 +setuptools/command/register.py,sha256=LO3MvYKPE8dN1m-KkrBRHC68ZFoPvA_vI8Xgp7vv6zI,534 +setuptools/command/rotate.py,sha256=co5C1EkI7P0GGT6Tqz-T2SIj2LBJTZXYELpmao6d4KQ,2164 +setuptools/command/saveopts.py,sha256=za7QCBcQimKKriWcoCcbhxPjUz30gSB74zuTL47xpP4,658 +setuptools/command/sdist.py,sha256=gr5hFrDzUtGfp_0tu0sllzIyr3jMQegIkFmlDauQJxw,7388 +setuptools/command/setopt.py,sha256=NTWDyx-gjDF-txf4dO577s7LOzHVoKR0Mq33rFxaRr8,5085 +setuptools/command/test.py,sha256=oePJ49u17ENKtrM-rOrrLlRhtNnrzcSr0IW-gE9XVq0,9285 +setuptools/command/upload.py,sha256=GxtNkIl7SA0r8mACkbDcSCN1m2_WPppK9gZXJmQSiow,6811 +setuptools/command/upload_docs.py,sha256=oXiGplM_cUKLwE4CWWw98RzCufAu8tBhMC97GegFcms,7311 +setuptools/config.py,sha256=lz19l1AtoHctpp1_tbYZv176nrEj4Gpf7ykNIYTIkAQ,20425 +setuptools/dep_util.py,sha256=fgixvC1R7sH3r13ktyf7N0FALoqEXL1cBarmNpSEoWg,935 +setuptools/depends.py,sha256=hC8QIDcM3VDpRXvRVA6OfL9AaQfxvhxHcN_w6sAyNq8,5837 +setuptools/dist.py,sha256=MRrBrgBFEwzUvrJrIgW79IepDuAeRxetGuSPky-MawQ,50248 +setuptools/extension.py,sha256=uc6nHI-MxwmNCNPbUiBnybSyqhpJqjbhvOQ-emdvt_E,1729 +setuptools/extern/__init__.py,sha256=TxeNKFMSfBMzBpBDiHx8Dh3RzsdVmvWaXhtZ03DZMs0,2499 +setuptools/extern/__pycache__/__init__.cpython-38.pyc,, +setuptools/glibc.py,sha256=X64VvGPL2AbURKwYRsWJOXXGAYOiF_v2qixeTkAULuU,3146 +setuptools/glob.py,sha256=o75cHrOxYsvn854thSxE0x9k8JrKDuhP_rRXlVB00Q4,5084 +setuptools/gui-32.exe,sha256=XBr0bHMA6Hpz2s9s9Bzjl-PwXfa9nH4ie0rFn4V2kWA,65536 +setuptools/gui-64.exe,sha256=aYKMhX1IJLn4ULHgWX0sE0yREUt6B3TEHf_jOw6yNyE,75264 +setuptools/gui.exe,sha256=XBr0bHMA6Hpz2s9s9Bzjl-PwXfa9nH4ie0rFn4V2kWA,65536 +setuptools/launch.py,sha256=sd7ejwhBocCDx_wG9rIs0OaZ8HtmmFU8ZC6IR_S0Lvg,787 +setuptools/lib2to3_ex.py,sha256=t5e12hbR2pi9V4ezWDTB4JM-AISUnGOkmcnYHek3xjg,2013 +setuptools/monkey.py,sha256=FGc9fffh7gAxMLFmJs2DW_OYWpBjkdbNS2n14UAK4NA,5264 +setuptools/msvc.py,sha256=uuRFaZzjJt5Fv3ZmyKUUuLtjx12_8G9RILigGec4irI,40838 +setuptools/namespaces.py,sha256=F0Nrbv8KCT2OrO7rwa03om4N4GZKAlnce-rr-cgDQa8,3199 +setuptools/package_index.py,sha256=F9LBC-hQ5fkjeEVflxif0mo_DzRMrepahdFTPenOtGM,40587 +setuptools/pep425tags.py,sha256=o_D_WVeWcXZiI2xjPSg7pouGOvaWRgGRxEDK9DzAXIA,10861 +setuptools/py27compat.py,sha256=3mwxRMDk5Q5O1rSXOERbQDXhFqwDJhhUitfMW_qpUCo,536 +setuptools/py31compat.py,sha256=h2rtZghOfwoGYd8sQ0-auaKiF3TcL3qX0bX3VessqcE,838 +setuptools/py33compat.py,sha256=SMF9Z8wnGicTOkU1uRNwZ_kz5Z_bj29PUBbqdqeeNsc,1330 +setuptools/sandbox.py,sha256=9UbwfEL5QY436oMI1LtFWohhoZ-UzwHvGyZjUH_qhkw,14276 +setuptools/script (dev).tmpl,sha256=RUzQzCQUaXtwdLtYHWYbIQmOaES5Brqq1FvUA_tu-5I,218 +setuptools/script.tmpl,sha256=WGTt5piezO27c-Dbx6l5Q4T3Ff20A5z7872hv3aAhYY,138 +setuptools/site-patch.py,sha256=OumkIHMuoSenRSW1382kKWI1VAwxNE86E5W8iDd34FY,2302 +setuptools/ssl_support.py,sha256=nLjPUBBw7RTTx6O4RJZ5eAMGgjJG8beiDbkFXDZpLuM,8493 +setuptools/unicode_utils.py,sha256=NOiZ_5hD72A6w-4wVj8awHFM3n51Kmw1Ic_vx15XFqw,996 +setuptools/version.py,sha256=og_cuZQb0QI6ukKZFfZWPlr1HgJBPPn2vO2m_bI9ZTE,144 +setuptools/wheel.py,sha256=94uqXsOaKt91d9hW5z6ZppZmNSs_nO66R4uiwhcr4V0,8094 +setuptools/windows_support.py,sha256=5GrfqSP2-dLGJoZTq2g6dCKkyQxxa2n5IQiXlJCoYEE,714 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/WHEEL b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/WHEEL new file mode 100644 index 0000000..8b701e9 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/WHEEL @@ -0,0 +1,6 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.33.6) +Root-Is-Purelib: true +Tag: py2-none-any +Tag: py3-none-any + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/dependency_links.txt b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/dependency_links.txt new file mode 100644 index 0000000..e87d021 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/dependency_links.txt @@ -0,0 +1,2 @@ +https://files.pythonhosted.org/packages/source/c/certifi/certifi-2016.9.26.tar.gz#md5=baa81e951a29958563689d868ef1064d +https://files.pythonhosted.org/packages/source/w/wincertstore/wincertstore-0.2.zip#md5=ae728f2f007185648d0c7a8679b361e2 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/entry_points.txt b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/entry_points.txt new file mode 100644 index 0000000..4159fd0 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/entry_points.txt @@ -0,0 +1,65 @@ +[console_scripts] +easy_install = setuptools.command.easy_install:main +easy_install-3.6 = setuptools.command.easy_install:main + +[distutils.commands] +alias = setuptools.command.alias:alias +bdist_egg = setuptools.command.bdist_egg:bdist_egg +bdist_rpm = setuptools.command.bdist_rpm:bdist_rpm +bdist_wininst = setuptools.command.bdist_wininst:bdist_wininst +build_clib = setuptools.command.build_clib:build_clib +build_ext = setuptools.command.build_ext:build_ext +build_py = setuptools.command.build_py:build_py +develop = setuptools.command.develop:develop +dist_info = setuptools.command.dist_info:dist_info +easy_install = setuptools.command.easy_install:easy_install +egg_info = setuptools.command.egg_info:egg_info +install = setuptools.command.install:install +install_egg_info = setuptools.command.install_egg_info:install_egg_info +install_lib = setuptools.command.install_lib:install_lib +install_scripts = setuptools.command.install_scripts:install_scripts +register = setuptools.command.register:register +rotate = setuptools.command.rotate:rotate +saveopts = setuptools.command.saveopts:saveopts +sdist = setuptools.command.sdist:sdist +setopt = setuptools.command.setopt:setopt +test = setuptools.command.test:test +upload = setuptools.command.upload:upload +upload_docs = setuptools.command.upload_docs:upload_docs + +[distutils.setup_keywords] +convert_2to3_doctests = setuptools.dist:assert_string_list +dependency_links = setuptools.dist:assert_string_list +eager_resources = setuptools.dist:assert_string_list +entry_points = setuptools.dist:check_entry_points +exclude_package_data = setuptools.dist:check_package_data +extras_require = setuptools.dist:check_extras +include_package_data = setuptools.dist:assert_bool +install_requires = setuptools.dist:check_requirements +namespace_packages = setuptools.dist:check_nsp +package_data = setuptools.dist:check_package_data +packages = setuptools.dist:check_packages +python_requires = setuptools.dist:check_specifier +setup_requires = setuptools.dist:check_requirements +test_loader = setuptools.dist:check_importable +test_runner = setuptools.dist:check_importable +test_suite = setuptools.dist:check_test_suite +tests_require = setuptools.dist:check_requirements +use_2to3 = setuptools.dist:assert_bool +use_2to3_exclude_fixers = setuptools.dist:assert_string_list +use_2to3_fixers = setuptools.dist:assert_string_list +zip_safe = setuptools.dist:assert_bool + +[egg_info.writers] +PKG-INFO = setuptools.command.egg_info:write_pkg_info +dependency_links.txt = setuptools.command.egg_info:overwrite_arg +depends.txt = setuptools.command.egg_info:warn_depends_obsolete +eager_resources.txt = setuptools.command.egg_info:overwrite_arg +entry_points.txt = setuptools.command.egg_info:write_entries +namespace_packages.txt = setuptools.command.egg_info:overwrite_arg +requires.txt = setuptools.command.egg_info:write_requirements +top_level.txt = setuptools.command.egg_info:write_toplevel_names + +[setuptools.installation] +eggsecutable = setuptools.command.easy_install:bootstrap + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/top_level.txt b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/top_level.txt new file mode 100644 index 0000000..4577c6a --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/top_level.txt @@ -0,0 +1,3 @@ +easy_install +pkg_resources +setuptools diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/zip-safe b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/zip-safe new file mode 100644 index 0000000..8b13789 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools-41.2.0.dist-info/zip-safe @@ -0,0 +1 @@ + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__init__.py new file mode 100644 index 0000000..a71b2bb --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__init__.py @@ -0,0 +1,228 @@ +"""Extensions to the 'distutils' for large or complex distributions""" + +import os +import sys +import functools +import distutils.core +import distutils.filelist +import re +from distutils.errors import DistutilsOptionError +from distutils.util import convert_path +from fnmatch import fnmatchcase + +from ._deprecation_warning import SetuptoolsDeprecationWarning + +from setuptools.extern.six import PY3, string_types +from setuptools.extern.six.moves import filter, map + +import setuptools.version +from setuptools.extension import Extension +from setuptools.dist import Distribution, Feature +from setuptools.depends import Require +from . import monkey + +__metaclass__ = type + + +__all__ = [ + 'setup', 'Distribution', 'Feature', 'Command', 'Extension', 'Require', + 'SetuptoolsDeprecationWarning', + 'find_packages' +] + +if PY3: + __all__.append('find_namespace_packages') + +__version__ = setuptools.version.__version__ + +bootstrap_install_from = None + +# If we run 2to3 on .py files, should we also convert docstrings? +# Default: yes; assume that we can detect doctests reliably +run_2to3_on_doctests = True +# Standard package names for fixer packages +lib2to3_fixer_packages = ['lib2to3.fixes'] + + +class PackageFinder: + """ + Generate a list of all Python packages found within a directory + """ + + @classmethod + def find(cls, where='.', exclude=(), include=('*',)): + """Return a list all Python packages found within directory 'where' + + 'where' is the root directory which will be searched for packages. It + should be supplied as a "cross-platform" (i.e. URL-style) path; it will + be converted to the appropriate local path syntax. + + 'exclude' is a sequence of package names to exclude; '*' can be used + as a wildcard in the names, such that 'foo.*' will exclude all + subpackages of 'foo' (but not 'foo' itself). + + 'include' is a sequence of package names to include. If it's + specified, only the named packages will be included. If it's not + specified, all found packages will be included. 'include' can contain + shell style wildcard patterns just like 'exclude'. + """ + + return list(cls._find_packages_iter( + convert_path(where), + cls._build_filter('ez_setup', '*__pycache__', *exclude), + cls._build_filter(*include))) + + @classmethod + def _find_packages_iter(cls, where, exclude, include): + """ + All the packages found in 'where' that pass the 'include' filter, but + not the 'exclude' filter. + """ + for root, dirs, files in os.walk(where, followlinks=True): + # Copy dirs to iterate over it, then empty dirs. + all_dirs = dirs[:] + dirs[:] = [] + + for dir in all_dirs: + full_path = os.path.join(root, dir) + rel_path = os.path.relpath(full_path, where) + package = rel_path.replace(os.path.sep, '.') + + # Skip directory trees that are not valid packages + if ('.' in dir or not cls._looks_like_package(full_path)): + continue + + # Should this package be included? + if include(package) and not exclude(package): + yield package + + # Keep searching subdirectories, as there may be more packages + # down there, even if the parent was excluded. + dirs.append(dir) + + @staticmethod + def _looks_like_package(path): + """Does a directory look like a package?""" + return os.path.isfile(os.path.join(path, '__init__.py')) + + @staticmethod + def _build_filter(*patterns): + """ + Given a list of patterns, return a callable that will be true only if + the input matches at least one of the patterns. + """ + return lambda name: any(fnmatchcase(name, pat=pat) for pat in patterns) + + +class PEP420PackageFinder(PackageFinder): + @staticmethod + def _looks_like_package(path): + return True + + +find_packages = PackageFinder.find + +if PY3: + find_namespace_packages = PEP420PackageFinder.find + + +def _install_setup_requires(attrs): + # Note: do not use `setuptools.Distribution` directly, as + # our PEP 517 backend patch `distutils.core.Distribution`. + dist = distutils.core.Distribution(dict( + (k, v) for k, v in attrs.items() + if k in ('dependency_links', 'setup_requires') + )) + # Honor setup.cfg's options. + dist.parse_config_files(ignore_option_errors=True) + if dist.setup_requires: + dist.fetch_build_eggs(dist.setup_requires) + + +def setup(**attrs): + # Make sure we have any requirements needed to interpret 'attrs'. + _install_setup_requires(attrs) + return distutils.core.setup(**attrs) + +setup.__doc__ = distutils.core.setup.__doc__ + + +_Command = monkey.get_unpatched(distutils.core.Command) + + +class Command(_Command): + __doc__ = _Command.__doc__ + + command_consumes_arguments = False + + def __init__(self, dist, **kw): + """ + Construct the command for dist, updating + vars(self) with any keyword parameters. + """ + _Command.__init__(self, dist) + vars(self).update(kw) + + def _ensure_stringlike(self, option, what, default=None): + val = getattr(self, option) + if val is None: + setattr(self, option, default) + return default + elif not isinstance(val, string_types): + raise DistutilsOptionError("'%s' must be a %s (got `%s`)" + % (option, what, val)) + return val + + def ensure_string_list(self, option): + r"""Ensure that 'option' is a list of strings. If 'option' is + currently a string, we split it either on /,\s*/ or /\s+/, so + "foo bar baz", "foo,bar,baz", and "foo, bar baz" all become + ["foo", "bar", "baz"]. + """ + val = getattr(self, option) + if val is None: + return + elif isinstance(val, string_types): + setattr(self, option, re.split(r',\s*|\s+', val)) + else: + if isinstance(val, list): + ok = all(isinstance(v, string_types) for v in val) + else: + ok = False + if not ok: + raise DistutilsOptionError( + "'%s' must be a list of strings (got %r)" + % (option, val)) + + def reinitialize_command(self, command, reinit_subcommands=0, **kw): + cmd = _Command.reinitialize_command(self, command, reinit_subcommands) + vars(cmd).update(kw) + return cmd + + +def _find_all_simple(path): + """ + Find all files under 'path' + """ + results = ( + os.path.join(base, file) + for base, dirs, files in os.walk(path, followlinks=True) + for file in files + ) + return filter(os.path.isfile, results) + + +def findall(dir=os.curdir): + """ + Find all files under 'dir' and return the list of full filenames. + Unless dir is '.', return full filenames with dir prepended. + """ + files = _find_all_simple(dir) + if dir == os.curdir: + make_rel = functools.partial(os.path.relpath, start=dir) + files = map(make_rel, files) + return list(files) + + +# Apply monkey patches +monkey.patch_all() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..cf5fd4d225051bbf78c70d4a8a963d00d8a4759b GIT binary patch literal 7824 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/_deprecation_warning.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/_deprecation_warning.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..28af2e016437ff0c9ca6867e987e7383869741e8 GIT binary patch literal 572 zcmZWmu};G<5Ovy$Ruz>P7#X})qD^6_R0*L9A+dF75mFb&jh)8Gv4foiT1NO0*x2}< ztb76z0~41tqD4IEUG9AMF6Z-gr_)A&ulE<4!}p^IcF}-f477(}t`I}ac?NRyRG&Mn zHbvdK51Bu3AQ}Vh0T_;;4$W)Knb$Y<`O%aoX`E;+?In*5_h}-ux}io1wOqfpG2nt) zj(th3#ep{Xev`y(TW_&Y*z@dfFVAb2(pe~MB?U+61XM<3oZ-Oe2qgc1>UqbQDu$`W zHuXa+Y}qLjRxBjPixsp8XeyI_c|Pej@)jYAMx2nmO-Q6!Dhq#~kh_%1D$^u{X`hfc zWcFYcrTKnzW0-~}+|8(Q11(`X>y94WB^hNVTC3CGb`XXS>ot+1;UY8xz*4z0Hx_YE zD4S3zdxOC+TV*GyyS@LeOLi7Ts^#_Ll_{R4psj&vIb}TQ*79bx{qkTt?8a+CZQeTD LT=Kk-e*)1DD!`)? literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/archive_util.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/archive_util.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..eed11e371aae44649bb0c0c6e6964453f9ff8b9c GIT binary patch literal 5184 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/build_meta.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/build_meta.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b0ca1acbc4b4d94b0c428e471ef6c2312351632d GIT binary patch literal 8551 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/config.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/config.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7f09af128be6618574712484f8122b93ede6f69b GIT binary patch literal 17832 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/dep_util.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/dep_util.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..dca33b0d949a32940cdfbb97b60b2f38469fce76 GIT binary patch literal 875 zcmY*X&2AGh5Vm)dP|~J~A`a!|+jgZi8!AyL5<*D8l>@(0BosNZvuo<L7u%b(QF<Xf z2t6TgJkMS^@d6y+!t8D$r6bK~e!m&d_+6*dMnHdl-qP<rLcdC5pFA+00oxN03^6QG zipLlu<}v>(8hfnq28GSv5Je#_4i#T=Gl`APvsqcYqb4XNKL@r62#3~agF)gAzVywB z!wj@9I7T-fu<yJ&V}oCykLNcH=daPa@euM$x$#VY?R{(1zFU}Q?SoatO6xO3*Z$mt z*}T=i4^&=~sdfpWCeBl?oFzh$j2bE>mwn>6bwb5N%n7Hngjk)M87I{<h_Ix3Rht00 zgeoGSex{A#Hq(lgg${tZ8<5xB<wjXT0bCfO=R^t%*{3z4tv6%)HC9z*L$XY`;oGJ# z*|uNZt48h<I)jdNFAWh$=P6ZA%xr}Por1mHpN7Gp@~<8TcUlL8Dn^1D)dnQZts_%j zBhr);$yMx<uvz$^747#_=KQ5G+7wMgRm@F!)uKhSj4Kv4$H#ZzZE<f4UEEibZKzat zUMzkfa|jTBb(9&gppHiiYNEN8j2jz`uA+D{T9|aD&gY+oNpiJXP2}ienwTL_tfIG3 zCbBc3tb^m74Tl$t>&2ryvatEgX)W!(%6K-(osfg<x_D6Ur##G3SYDr^RsP2w2-NE0 z1HXYAxQl!E7<WC>0q?8OFM14aSfbd$4zJoml~6rqPaHu}aquM7ESLN#2FsQkJ8J$1 D66XLq literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/depends.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/depends.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8371ddc3bb83010de00946fa04bdfcf0d1128f55 GIT binary patch literal 5344 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 Qtu5a0&UzQUx0|Q_2Z6$MB>(^b literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/dist.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/dist.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2748b5e971cea5499e054bc554c20ea72d62cf8f GIT binary patch literal 42203 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/extension.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/extension.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..beecbcf3af77a1aefe5d783b4bd118befe20becf GIT binary patch literal 2017 zcmaJ?&5j#I5bo|7+hgzASrQZhi9|zI1S@2`AQXrMC{iFu2rUv>1k7bLJKeU&JDwT3 zdmMY@J#DV=2q=5x#w+j|EpD9h0vtF|HU8O+h-j;-|7yCws`{$^UANmI(Ek4YJo=+a z$X__Q++3JE0MScOf(V+DVAa!r)^ip(b?>hGM%}ZtIc)_kN`xca)SI@0HjEph`IH15 z*$H-JTRM~7N%xEfy)TJq3GXQpp6s1DK^Nw2(SdnKc42-+(8r{|^BfS6!#=gnG%B7` zn83I@k|r#(A~Nw<iWp5c4J|y7hambxP=cP4>bfCIBG`xu=VvydlzdNw`<S@Iu#=AR zDZ$^5Bx64ST)4Jb9dtOfZ>1?!#*b7fc{1b=7iOGiJdQGc3=7jDS4IlIHm%-R?fRc5 z+LR_qwSQbDsR-rV*!Fe^=)IxJrzuz+J?cBQ6NamU!ca8;uWf%Zk7Z$!JnPe7C$6tV zlk_*D+F<ZcF(_0ri;Nu1A~hK1sgOz!?#~CK@cv9qtL%f}<X}9WS5=tazjr)V2hc{@ z;Al`J#oZ*+CQ8%02M70Ni`o0-K!cBk$@5fS9s+8aX#n9D3%eVRqnQj>Savb8Jy67T zDPw!INqZn_2UcE41)4CB2Oye*k_6ckFhPMWOgO*_SGb}9J#YlV-a_Zs_f{Wmhun-K z!%HnSzwO7j`7lXgm}I<2qge8M2+PG{zTSu(xN6fdqR8fNK=iwymhLm4gka}vNkVGa z#95LhU9zFGbbe(^_ZJ|CAb`a=w7p^xrpYvc9EVYnJnFmFDe^*f;T*`@7N7MXhgo96 zu-~w*mg&&CSu~ZlrSnq7Qd>7tBW>BqlRASdg(ax=K-~h-2$DEGT3y{9>u*ktk<^=p zhUisI@Ix3Faz<1Kt7S<hw74qRDP7WM>>R4_gsFYuW=u3rnQ@-ErZH)X=8~N|r;ceE zZwcN{+Gp&HLNwZS#kHzGYd){&zl!kM4gMrCV~(Nba+4;_P0nA~H)F{S_$$r!oHWWt zWi*l(pZWY~oM=9k@i@v7J>@{j{E6mU%cz7>Q>)X<qDU9p!wMzu#(6fASbN*6k4u9{ zU~?!H5Js+Wu92-u6kR&Bq;ldrcPiJ9i=twFTs6?6{eGuru=O?&Yy%KUW!u9ti|hKZ zts+t;iBijyw2m&1t&4T6kmc$csJ^RSfex0z<Djz&1HJ(2CYoURUL@b%4A*{y03cjL z4NV^6*L|?nSZk!&WG?N{SLq(D-nqn%|M~c^-$YU(3BwSdm}xG`6vw+^_){6B>z!5@ ziadsw2YIO8M0J6&9@Q*G7#u{yp9S%#%e<z-wf~em67>Oy#`9h*cPuH}`Z_sQky=!r zepPD2)8s_*h$}fN(@62HZ|`wTC%&16M;a{B)n`!i+Q>*8LYz6=px#3DHmX~wUWR=i zHa-T?m?V!XocH(C4d~SCplnZUAM7}XytcP<ySE+sQYoOLy>@A3Qv$(_izn2_!cdv7 zles_5XHwVP2%6J8JCO^8#aq)X=+rN2u~2euUA(srsJem%2=QgUSnrcn9zVl4>+7IA Ry8f|Uw(EFTT+n;3{R>2`5gq^l literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/glibc.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/glibc.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..21aa26f3dc15b7d4eb33e6af56dd80f7a24dc830 GIT binary patch literal 1586 zcmZ8h-EJH;6t+FHyVGfsrlmv(5LhBe9Z0gFLY0C_0hLAwMJtpP71E;7WbECU?96zu zJ)2}Txe9N<3nZ7^@jSleiWlI5n{w>UmLzB8pFOs}IX>U{{Nv(ch`|2&^CJ0v0inO_ zpQ}dT&)3k@chE7!aDhs^kFlMTg6tDFdi$Om{e7Q#%>NDTcUXsYVeGOV3t;TATP%bz zU}O(PxBmt-6k&5GIZ&c#G>`ML7E%vVyD&EoCIPgk(9|w;8l7W?FYqavhAlcIr}zb` zR(zzraVS5*$o_tYAotKuu=mh!aolO~89F7p+Y;S7BWlo+a|i-3NNYp!rdzvQH?mT6 zROAOKop7mgQBkF3UX9kMkaQp_PV*tHgr<!G?`-SFz;qIo=6Q6>bW?p&b7lOe-|p;~ z`=hFfM_k7iF}_4JOW$a~Jb>FilTt_%q;Z-hGOkTea%In(Fb8<0lPcxLg9uEQ@l-G# zdFE~{Maq?mtEA+rPEszrkP>tI5<Z6Qe;|1WeE$~xTIQ2P^Zq1}{h=rrT&lly+#khT z6Io8Hhr`3oEIXb~<6`U4K_)lBMpgfLzs~D*7eP_1Z*D%CoJ>Az`U(<MYat4Cb?VZ! zQJ=tVuU^x}0V%R&rS3zAdLbq_#7kb_1-MH>91?jK{HdjPZaz$Gb5z?}n^E1O3v%kU zo?6x9++(CgD@gkn1nSS*L%P#?=UwJs;4|FfF%jFBo{sa7aR&(Q4yLOQzWU*DnH&oF z<mKl2)-Rt%uQr@3ul{#UzkGIF^Hg(oqY#dAozaIh6;PoSue72LYNNEL*XT&-FX+c= z+jN{82J4S{hDdIGI?YUQl*kH_0`*~MW@)#nbYAioGq>^bN}J9|il&ZyxdhiYOOpTE z<dU;^2D=EbdD)b)gEzQzOwYPyd*H1!<LNlQ#>FZus1@i?Zvp$bi^*#O%_ly-hnHW= z4`3y=5}%u;<P8mWRU@mO7GypS<UOk_ja#4rR0RY?WUw90*mPKtC*OlZ@_pOcYupU- z?JSw_*rqbk`9Z;F;eHM~l@&UI5CaHQehBl_I_8F9Vgq&c@g^|Tg4kVPAZ6yYXlO?W zGV-UtKbI#|3(C0W5|YNL&iHj|!;pf_<)2Wf@`6(_ywtv;51_Eu<}X4-kFq??0C1Qz zg|^tdto6x!w*$*7nkH)YtwM-#Q`2FR7iz<;4kBWZq;L;l+lnT_P73f6E?y(<X5NCi z!gk>7ELB~XDk47u4?I9&91k0K$9Nn|n<!~%lvaS!7J&PV<H+UKox1W7`)Wv6M#1A! Yu%_ToY$+(q;Q|SO6cF#b!E*4<e?{AyLI3~& literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/glob.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/glob.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..bc61b0d7f49541de34954fca8ea22e6028f43f0f GIT binary patch literal 3789 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/launch.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/launch.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b23b79cd57693b1f459c8a8cbb985043ca86da2f GIT binary patch literal 880 zcmYjQJ#X7E5aowtD^Aj-D4KNQ>H@Kx4g~@PMS-qG5cFelQV6t2+e{=%peP|0?8)ue z|B#H``g^!`${*-Zpg@mSi{=QP-tkW2d*boq{{8@g{rrB%A5(;W_~4-t2wuaiM&JaR zAb|zR@C0w4WI_ZL!Dlp~G7#Z4G0!F4AdCcgkA}VWV(^yNI$bckknDVE7lme3YE)?% zAitOvdCs+9nbMN+nU!WxNn4k;D6)#FicO2cR@U&cl!7&iGnJQxv7^B~5JG3E_y4R1 zAcXk_W@W%xpknbA5%>_Tk)<mj<_UkLYuv31`h^^JHPqu%WCI(D(DpWTO;%)uHu$!G zht_mOZzItY{X4P_?9M8HZ$(fO+QBMZ;SB-N6h!Z|=K}`zuI>c>m8(GbvKnzSZ!V5M zF%H^hOj)+zVp~3yQZuES;u>UXZfnD{Y&qKI?lDMlQIh0b=_ENDQXkAzCX>V?&2x|X zNg|3AKv0xYx51^k)GfKxE|51e9qzilB$?JKvr1P`MS+hCJRuhdm0H)IOUtb_F0#Nv zt5%x6-#9Rm3)eTY%y=qYAC9bqy-ftkVbAS$3b!oWj^|R9zAp4E64&d}lU-eyJm~@# zq=k^*ka-H9_?5?{Q4O~;Zn%kOMJA-F;**<ro}4r$Z}p4W)p)VEY1<?_c{yE}G1y$k zAL3G#M<B++uR0o!UpC9;xQ_p~&qJ7P`*2h)9W}MyhkdJO;7}Og0Vdt}-3t%M9`1%Y xgsg!pfrg>+jb$Er=Wk1w@{P6?@W36wnu|{JLe!aj<&UlMF9cD9BN{!4@E=|i@-qMc literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/lib2to3_ex.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/lib2to3_ex.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7293680bd338c67027c22561dc2e3d72a22152ab GIT binary patch literal 2467 zcmbtV&2Jk;6rb4-d%bZ!T0&Aq6qc$~+Df%UkSdB0iqz5yBm$xVp_R~T;~6{ataqK6 zvFljwDZRp<fShA*{5>Oa;>16|p(oy(wH>Ewdtp}d=6l|o-}}9{Kdr9%1j@gEUL=22 z3Hcib%f*4gK2-S&2u32pD6=x!vm%>f-_D$#8@Z<MWR+eus`k9dGh;WaMYSh{Rao@} zVO3r|w<90M9;?B)#%&l|%za8ie|+XY97t94(lKYjcj+k2_f+v&AP4<^A=DSXAKVKP z#^ih^Xcr=A75R`0mFAs*6)nZ3lD_XB9;Y(s6>O04KqRT;GDz~^n;u^DwGeQw$b%ow z)G;)B4gVi_7zwGaEwsYG&WcWG>GdCZJ87vxfQrMS$n<uHtGJzxxR7yM6ur2gv`&%^ zKWO1C%f*7hK2&)d1Sb&%@GJ!H1&M5CGY49SxvT=M%c=l^r*Aw;r5dO-ldtJ*;cfGR zF0rA04^?i0P^3#Iv`r`0AJ*>#peIksOL`Dm0=H?G<D)}IJCbK@ZTDnHJBjE>ZJj)O zNyI8_dUe|Di*%SM-W(>P*)B2$Pi#IIH9PTxq3DhCy>@r^_;@rP$JvAXN5^6pN+)j~ zHv4J+UYbjlWZAvl-TT9{;irS9<Z94YfS6qFX6X@nHRhv6|4i2a<Jj1C9baOeNXNI{ zhCySo{R$fRM66Hnj<=y9fZAk^hm+>*;-xKWFei}xVg&`lP>MC^=@nGh<5Gfm--n60 zeYf9f-|WEuw9sYzXwVVY78V)Xj9CUWvwUO8sCR>AwjYEQ?Zt7P^mrU=KaR@?fqp%X zPX|d>u84J1iVhJ7<`OCk8$<;b&^C!3k9xLeo4FPYuN3slK2&)J#3BZ2%wqNn3Q++3 zH&I{`1Vn*{sX!nR9=Gu9yddLI*F&gMfS8ajaGueVn%F?LPpG_st+J*z-ad6E^nz}a z3rb<{)V+YHfVN^<OB|_c*Auy_!9D&teQr<e?#cx2gU|U55?fwZ_37#a?!B<ecnaNv z!*TU7CZ<mCiUyDz+-D+HJX)Qnp18=fvv5t<8AP#2k06kXJn{yT$H;mUjA8?<*G{)c zbA2;jWSlrY8l)L3GmG(&)H}<|eALPYjL%Y!_Alcr+7yG_C;<KO+!o^xy<#%e>^@J- zav3;(p;&wK)1hMmLc8rW<1+H*H)$%CNPrv^w?N#4Dv^T3u2aW+n-sVJy$bc|b!&Wm zp`<a_(V}=@R?y8ZRO8eLI_Om4qZ>QWkBOpP>k;{N^Et(psja}N=ipXKPPbsj?N%58 z0{mR|-?DQb?<>Q<Dn0@&;zJP8);txJ2+gv%)D=EbJZAz86FazbeeS;*_K-y|acJ6q z4VLJ=H+ZoDTP6CO04y_TXdS-s%}aRRaPA6H7z!8y2B~kMqW~X9JLKFp*Z@uji8~WI zwE+zn8{$*IWaqgxv0%<QsffGSPTh%FJ-v&_gw{c{c9mR^C#vw5OOz5N0^17&u5J{c zfGGx3T@k!j40%{4)o6XTaYkqv`Ikg|9kq=Zeh16s{v2+Vbr8e=wFaE>>3C-uuB!(Q zLi#wY2u#vq3&l1HB&qlS1yXfM>t!B82I7uc9`mnxW%3DEbT!6Mg5<b{!EAoX4U{H1 ziI3rst}Rx|-|WVWQjK|>3G`XXB;=e4$v4@dy)VmL{1t|WdAd_Wj%-+-y|MBi|E5{} literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/monkey.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/monkey.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9616e4fe5c394642b08221f33d88c9fac45dd186 GIT binary patch literal 4700 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 F{1-S_@cjS) literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/msvc.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/msvc.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ae857ece5cdf70723cafd2eae3e052f8907399be GIT binary patch literal 34496 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/namespaces.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/namespaces.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b103dd4cf7dcc64cb4c9dcf7605ed91e9df5f2da GIT binary patch literal 3672 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 Wi<+i;gqunHd@$U%Hyq#DI`}V*DY2~p literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/package_index.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/package_index.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2a62e2d86f111444e7c6beea1067c61f74875610 GIT binary patch literal 33017 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 N59~|gESqHX{{V_bVr~Ec literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/pep425tags.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/pep425tags.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0a71597e29e5bbf4eebd98a53b54ffd3aea2df07 GIT binary patch literal 7259 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 CSqC}* literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/py27compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/py27compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3ff88a3b27d0906043eabf160bdcd3a8f33b292b GIT binary patch literal 840 zcma)4J#X7E5G5tqQq-hriw*_4a1GE{u7?B$il9J-dT5IPaffOV7?HM_P#+;_K{7n{ zhs0yH{vNHJIv42Bq3BU@(4bQfxYLn3zI*S;PkVbI0{i)OLti)ueY1;)27Bl&xSm2_ zC`Jr3N8%X6*OgA@#x6$8W4$jZ_PBf5Qv=rDuJBENgP4Ei6espi>~mjDc#!v5z;>X1 zhdJlyAY6^Y(;_RW5f?%V(~$FJSr*EWS)s^TV-`hDMuTHQb4EB-Qg9W12R7*A0d8F_ z>eQ0FH=DcQr{LOZTcaDa#v2T+@M;nguy>;3IpC4Wbb9uIYfb0;6;a$Q6>LjM7MwD! zG|8w*7b2e%O6J{}E8Yw`2x#rkxk;e<)@l9h4y1LV;1($#`u@6(N+l|4cvMjp%?fED zqj4S0lX0c8RX&<s4i}4hwMyjp=whLUVDmhhMx`hZMXn8i9}b5{Ra3oQMjGgqrYNL- zn3m1xIPIo4D4TYFODWk3u=;g39Z&5*{=bvD#dfwKplyMa2d6t(cOkG#i}(!ut^;m+ z??t|>Qw&@8W^?P^ZCH#oI!DUV>TsY5uK$5;gEx|97mS{~gt8ytNIiyd5Vn4jup&*8 zHYg=E@I12k>EE#ocx|}KmDSsEYu&TYqqeUbZFm;%OUo{SfhAO@Lcr58Dt@Fgqc~4A po$&`m>;)<-64+z~TS|UnW$5P+JTGu|-N5hTptp;?-%jrd{sT!C&Ab2r literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/py31compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/py31compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8b7db042e430c7912d7df82903bbe2224c6fa2da GIT binary patch literal 1247 zcmZ`(OK%e~5VpO}W?LwNiUSfH_Jmjonzl$tl@O}LOMq06T3&mx%-Tt}^**qjG>LkH zGrs|DaO3yvl@ot}11DxS4TRT39*@`K`R19YD=W(c=-cNH@?Jp57d$Ld1cz-{?g_8~ zNr|Q@o1RrfQ4<tA<&-=p<t8V(bGU3DQi4CYWhP9+b`R3vK2d?<Z;9e>Sju0LlDz<p zU6ORZf>n~xW_3>&b!DZU+{vxZd}Sv)8Qv`tgTpo~cLkUxDODt8il%{LDtJp$uDI&J z-ch0I!XBy!FqSO7n|@r5Pw1Jpli1}&ZFKDCu(6us##vQ*J@#=SOF7VX?dQYixiPVa z$G(b{Hrnf0_Pw@8(yFWRtD%pNP(vD5#rdGDtd1Y=#<En1mK$k*TGG~5*2Pshvy)fl zFO-aeyK_R<p)BMPEO!BzBF97!PY+n19Mg9cPm1i4Pjn{<8eYmmHxWkF&y8-n#i7DO z!W!<h={MmaI6H8kh+P6>-(UA?n~$W|y^*xNer1%luD3Pr4aC;S7SnRGf3Uv4Kb}s7 z*}Cy+->w4<%HCeD&g*M=>AW=N+WPv9(PXqS>^bd+wXZ7U7R7pUeIu)iTKctm(nLb! zW$uMIk0Ehjgobo_@$Uv$n`{1-5zG#*+pt^+?3f%t{1&s6P>Tj(>%!KCIAhr3&5{rr zDr<$nL^@0@q0>wM1U^yBTK`ZH2xT0H7I_nd>8dC1p#lfcgdbQt2<JKR0Sv<B*&v*> zI@XL~l@hkIm+&TZ`$M0bCbWgOTDML&-N(Cku`Lqbdf#;QIP;TQrx6GvX@)b&Tbb!U zLxZI1F(&mQxaHc3ri`xAGyhNROn)coVnwiRglLw9C@M8HD4!PM^-!9Vo30S5%7n0| z0KlF`b`BYK(E>x{cHCA#aG0!!@-X62(0&ClFa#|F_BqDZtN^0+GBeUSu-=)!Z%#eH l{{!D<#G<tYloqrtX>@bu?=9>IcLo?|JYeiBL>|$I{Q$hrFE{`I literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/py33compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/py33compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..592938fd5b49749fdcb8cd54bee721ca3e1150a7 GIT binary patch literal 1464 zcmZuxPjB2*5PyH{U9aO!lM>NZAY_$FVWl>kwo*}~s%oIC7KsJ~X=#129KV;1H(uL$ z?`4%;c~9wy55N&6hy&dCJnzaWUw{J_nDHti0%kSindh0=ncvLwt8UjPK!5ypo;+{~ z`5ld`<bm-NSpNh<5J7ViEuJ)@jm;u93mT0_{5w+Ibcl2gef5|U{0SQIx1?ZiFpA~w zxD~bFln9=;$6n-7B0G^U+1ZkCgnQ1S;5iX3(SAon`;<jpxh#qBWcQRu*Ffi@BPi%A zaz)TXPyHypv(<AlT8Y5^mh}7!sFUpUsO364fydH;8Rv18C@qzBzpA#?aORg)S_&B^ zYM7$?RbpT~1=b&ekOZ5In4p5aBM}!|IPio*;jdcu+GkTEF;kqD<0>&J2452D$e#mi z1i7X)iJ@}{rC6YYkv(P|E%SZV0*_ybLcISx>Q^e8Bu4fpiR$l{xsXctw@&)Qcx$4@ zv*N-2X!GFUWHyWQtw(zYY7=N!^mqGJR^7`AZIV2{x4HRfGM(H%?rUj|D^r%azN%K! zhYuHJZ&Xw3#c@_-CXV03a+^Nr?B>7v+qiT}DR^BHmh1o{l=>GChMd9JYcirEcFyM1 z@P&R#=S;9U2X<;+vqPeO22l7dGIwj&I3xGaRo~-@;5W!E1Pt&-O}K012B|@xx8SVx zDVg&oqIJmB52iixL>scS>sH+s-YH!pbLZ$z5r|IX&(Ys>YPW8kve&SbM|VUAmu2?k zZ6<ROu76TicVQcP>tU5-D%>wsD3kOcEGwxJla)o76=Ab8<=#l9CR|5j-O@dUP+T+u zQM-Wb<btF27f?pP-s$<)O_WNe&6I6BEn#7Vv^<xE<s#Fz`(pd`Am0Aw`Ky<Mon0FY z-s}!`o(-Pik;1&Tn-xY5rHak8l3F3)Jx{gqmAeOPs4bV}zU7rsHjpPq7D9>`da|sn zEC(g(<Yh5z;+r*Fhz@4J=^Mx$zYmrUK@h$|1LjbNdGPaDNI_Dc2GrpW=>NMLO^ThK zi}{LVEaTYvaXc=?agKTr$4AFWzIdbXN~n)e-~wF{SdoHn5xEYmu~CnDyg9Mn<wjcX zxR5$cD%rcP)-Ylfgk4I@Jcs$f#I$wr>f5C+##O1zK&etitN+}E4FpLQ4Z6_>|2f}) z&&S5NoB-B1P3s`;whQe@lcaf~HFk%+2)JFjY$mcOvONSBW0bm$b$yJ{{)^q0Uw++u pgsybjG`<+X;{{4jaFH~k0zCuF3;<uIJ_~RdEa1zx10Dbxe*@|Dal`-s literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/sandbox.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/sandbox.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6353fc36ab2dd87eb3555d1517a7fdc6414e1280 GIT binary patch literal 15592 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 UBkl1Q@x24mAd<J8+fMR-0c043<p2Nx literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/site-patch.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/site-patch.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..86515c6255d4d0778aaec377c78a547a9b682d3d GIT binary patch literal 1530 zcmY*Z&2Jk;6rY)0uh;93B#sjj#K8xo%7?@uh_;cU2-G6VB~)rq6Vqtfc*gd|>)rLt z#A&SA3l8@n@dr3ZZio}>+FPDq@3<-mbM#hW#a+OcN*zTfYC*k4zx9)k1F&$q#A z7oool^Y$UYd<s{501rhJU!x9Un35sk8w|}5M&BT6Jwq+K3l?{04X6^_M{tD)Q7EP; zLfPUQXISBLGPfwX#TikAqM<8x6*{-61(6>rA|CcpM&gPh^8(m9#!eO$qIQU8R%U^% zD@%&ZAnx~M6J<77xpPmJ!Lp$2$LREz%u$Xi42j^%5!Yj`thuF3q@pT9#uEQc73URN z0Ew&IT=J`O=T#%YP}vP0Z;$!3nPabIB~>!k%IV`<^1{lztejPzqj<wca%t%Czl{$@ zCuq!1P)v@I@=RU)HN<FuFT_=zDyzz^jnQ-T3Fzm`x8QMnmrE{DXNJGSa)lPDdyPz$ zkI@Xza8}K$FHsED*C<xVuPXvo)-p$~D)7qj9xG&{^SY`%Km;sgL)jE>LWCD2TgsLx z%2uGS^+nv%Gw^K~U(l{*4b@P~Lvn-p?`p*$Hx%@^4%t^gR~<SxSp0FP`%~5DYo?zV z#SNg>)e3L~Be3uuKqlzlk1Edvn*&qYhZi=beE7=jiT0kJ96kB!@abnqPjuljj6dGh zt7#wyemF`KE*bZ`L3hBkEkenrA3jPhA{yV5&0ZMOrW~*)XF=4wXSDa4ql8{Wtcy+L z|Bu;S8}2i>`Tq8ypQnusOQfKq6m0^Y9{GWcZ9s)z8Q&Jx?kE^CgQG<>+1}AM#2@{H zxcQ;{J8q{uoCK1!CjoEwl87=c+IuhCeSdGlN7Hz>cfK<iyqr$`Xz%{nfbYQR$L*tb z8m3!eEMyQxTRS`VCs&h?F4}_0i&Q2_B;Fw*;}#(34z|-P?d?aQklkdI9<)p)rX&ZZ zJAL2x&yqxL??*{Dh{OR9Zwz(W_gTLW`52enF@?RSEpa6@NrW!4coOm?)>fZM?WR#6 zdkG)uf=HuK>Y^!Luv8a89Z1QwZ6w-?SgeaQ<Z&=!+V%Zj7%|`1Wit?eF#uhTlHiW9 zV3NB0Wj@Z&IZwDQbfZMTNNL!Wyb8Fq7f@<O2yuDQ2%I2ISxmLFK;K&9H4yV9^O%u# ztTgO)ib7I@s#6$U8CUaXqun=~qa6c-ac=&$v?C;}%80KUra+nKa$O$A$z|;4rD_M} zm_lPP?U0yuN{h^X0L_WnWp1Q#s!5#YTd;V_dFaIq%<715;X&AiPX(`Ihg3)f*Kvgy zo?s8;aEZAD=nY)UWdsw_$fYiPSHKVKNsTOH8`~hSfD|;iVpV|VTaben;5lq97&8bn c5Z`|bo7q*K19bNngE`0{noV%OaIu5`1A<49g8%>k literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/ssl_support.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/ssl_support.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8994ab2931bd68b5dac36f14c960ecfa47df7fa1 GIT binary patch literal 6911 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 M-6HPSPP?W50dID-{Qv*} literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/unicode_utils.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/unicode_utils.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..747af0b47d3771ed6574b8e327f08bb6f1a48224 GIT binary patch literal 1207 zcmZ8hL2uJA6t<l-OS^20Z3x6ELP)F<TMCD1lMq5;<yermv8@7Cp?2GBsgv1G*GBCL zen@-d#_!1$F8l!wJMo;f+rXBepP!$d_rC8r$15up1ntj{ng7c`=%-%XZ3Gr?V8}fX z6j2<aW-;R?hBXOE-)I^bQG=S_P}8I(YQbEhOVozhqWBP1%fI0?YE*G%$Y9vUdNpra zw_&`6AwPmpXp9s-Ctrzpq>QOa@fgj>AxfW)(X>R#3{TLleFEN7tFWFRzG))0bWsr> zFw*@DadHYC5Q5QY8jW`c*QG>tw)d)bRtaRlrSf^337utDR&1zRY810<IpIM&qKx{= z&&oU!eLoCRmRXc(b7nD~&(3k-R~I4@kewO(s`niU2kyI8UMzxvub4ORh1ZEf%7pax zhhDd}KM?(tzwDgXdc9$qw!;10FFjF%*5%%j7YFfn9$Of0*J`_i(cnemNv4umMNug4 zs`Efwi3&ow6OXd84zV9cl4(@sItYXv=mb|lu0pr4SOx1pG?-v0!^mm)1j-#6)--?` z@)?RBQ#`?AOmT-y$e0|U&pQ(%1&?WIY|QWpA^`g#0var!;b=j_<<=Rx+&YCpfy%0p zo>g3EbuJUZT-Eax2<CQ!0pqR)(G8?qfK8w0u8sGNx_i}wZ63L77_+uw)XjMac-Os( z#D&Zq1(Y$A+LF*I<;;o_Xi#}0nLX$-)d@ldx?=ssX`!LY*5_m%<Qx~2nqnEYnpQ`) zz&We5eNF?Y3MMlH3^~z-SkYIk&hKs&p>Kk%V8C*)NgQkw8+cd)4usxo>$+Pst=~L^ zEm))upo+#=qnaa%0nsN5MD@Emh4%<(lGIa);O@K@Zb1pSid^6AB)qMHi2I={A}AEj z8dV}R+c!Da^Lj3FCYdFb08qsSxcr}DMTwEd0-nJ$*p@nEL`Ys*;vwjOyakiE2cmiZ vwrY3abuqyUMs)q<5adVhd_%t+kz;AU>PIvQ*=zlWkoqrW1AdNaJNCw3PuwIV literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/version.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/version.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6c03f29510172fa7261426f0591244058bee435f GIT binary patch literal 348 zcmYjNy-ve05Vq5xwn0T5d4&$efgw^QgjiTv00CL7w04s;u5I~`Hc!DL(2<Sj@yf&t zFfieuO7uJ3-FMP=x=;5o8YLj$`(szUhW^<NhZuz6I;74*A%H*za?p+`c!MO`!Bv#^ z9sxg%0ganPr4V#MdU@{|@aQS%@4zJf3cKLeCz={7jSx)xzU2)UFMM+3N3togqFPwB zpxTd1YA~s_QT5!KT5#WYROyZ!W4xyr`{B)IL1ia+2Wl7&{FNV$q^ezEC~}2DOTkE3 zMzakn@yw}p%P*Fzw5m33i`gujS1JuCIl4!(meZPRQ!qA7)68w%xkdk$59!{;ncVup V<ysKS=oJhWboZ`76u~h(fxiG$W}N^4 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/wheel.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/wheel.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7b448f159cc8b78983d9a9c5e85cff5729c3da5c GIT binary patch literal 7110 zcmb7J&vP8db)N2-ota%M79a>gw4~T8N2IwDxqu{7krawFEkZOS5vE0&v^P{ni=A0u z7W)f5z4$RTxCpEwc%W4k-%=?T)~Rxp%9k8-NF~SI@(1+6hvbxhAO|HP^Sz$gT>zBJ zl|@ZYcTfNB_rCYNho4VR7YzLV`yYq(-+a$7{*wwve-;Wq!V~=q65ps9KJ$5-b$E?4 z%A0MoX6m<9v-CSx%jvgWv-R7lIr{C^T>Z}1^7>t<74Wv&`OZ{rN{^Lm7dz9nX`Q#* zrOr%kM(3S&p)*^X)p@slsxw!cV@7bgHXk^LFZlVuX)O$S>&4m`zfk**Kjjx68nu^h z82+?hdT98ieO`OnH}4pgnRw>@dJwduay01odqP(K3!5@3OcmDx>Gj)n+3bnV3M!`i zbrA*LRv@CV*G0vtM!nnXhK+hVj03M*?*yncZ~yXbybArG|HHQ~$@*G^(%iNPW#EZm za}bK46Le)1fAKfxuin1g7rj={kh=Gk>Kj)p7pXRz<H`fS`uf#Mp^V@8^ZLu`AZ+_t zedVgI>hF%$G#Q}28cqtMP3RguSmi-=d%gWy{C869zOQRMFYM6vJ@5Pv`WtIlYSbHu zMiBj=QuTvIyDrilM*VstIPdB8dS0av>@<SDEZ@|fmxbtw(Rls3T=%^42jvq(4`kTJ zpuvs|y1qxPFkIUB0@~6s(!dQ)_mKUj@OJQgh$s335@{T=#2B*c#%I5MVD9lfbI+1S ziyxW^M?K%mB^JI__iSBjq1HyNla*MKL)qMOF-|UV5_bs6-8?64=}0#*_Zj`6|Mdra zFTYn9k5M==Mj;&o^X4%Ii<(ErOUxwyfw9@#r2befB%43s81<FWiW5uxyDWUc&}%B; zLxwf{vzAILzJ9B>6_f)A!meBoyKCh^*AGPb^GGy2KNO#rWv~3XA4y%fP_B3VvLCbq z8I<LEP$rQLMD;F2&yl^p-`no4REmoCB4usY+Z)QF16Pg++B##kdSRD}bo!BU1x*|U zzOve3Bvn4>4lrI_2Feb0P!p-rwI~XNgd*rmS2@wavMN)`$yNvrPgkcLe9*JF$fOhG zn_)Yf%Z>)Cs8_71OmtNyx+&IG%>T*|Kp*4l_F`XzTbO)tt1cFsy*3UaT6}M3am{;g zOLXGyTg}$e`ua{Bd+qn$SzQ-P_^ovp?=JSk{>88x$$GneacSwDt=+9R2a8c42YuP= zwWFiiZ32O6e^=RqE<}9eEJ@mTkr;fQm6(fX7S9>|E}BJF;Ac=PUPX%rH9Pt<QTP#_ zXdOvl)EGdL)Aa*{OyBe^ye&WH+j!@E$9M6z{k&hm+sVMnO`)om4+{Q_Kl{+wXSFHh zPx*5?Uqt@2Kd<xC{tJMz1(nlKc1&|}SOGm+b8aIe4au~gupwl8k0;zWHeB(V1X3q# z0n>becVc+Cgdf^N<IouzklA@?0_m8W7?5jg--N8b;~SWkufz*scMBlsm-Q)@>5kto zpB0t7D%}6c^71F%%C%d|B9GYxX|i%x>yf^GRk&Ag4}w&L+>ubI{F>+u`hM7uDhJ%` zM3AaL)}<7coU)>z-4y3&oLr|a8|#W~D7K|#B~8kD4!}+~1fG3>QdC4@;09e*WHy^; zaY-Llb=0WAs6qCl{1|O$q7-fD)O?&;VzjJrE|=zpWJ`E_<r64JnLxjMegex-&(-ik zc?83ik*Nv%^6D=1HH^}Ot14El*eZ`L3oW3^fqC!;IEKPxG?k0`?NBNcgDQ74=vPd< zj+LG~1&h|Qj1Q4E>D*!k`uip>r2D7O&+VP;JBe`g8WP(3(0FV}{>W%DEyR$4LzARp zAGUs<W9L?U>1L#nCzSx~sL|^{>BH4_P~HyZy8hT02tbS+pTyN;Qxo9Rv~SbYFCj^c z&*t_Zj0eVsEg+`%3<w?ch>rU1ir#94D_&hvOn${wDYM{#@6oo7$U^?|TF?!4`r-;{ zKx8Aa3~snad@enPF!CnrtzK^TVAG>3)p56vDwd#LYMMyFcphb8R4M)fU&K3<5MGJ* zDJdgS)5pfWg{p|o*5EFSPk+nI$Bu)faICo(P)Myv3-+yLk_`H6gNv7Zqif0Bz5&}} zlD_)pi=>s-3IwFPTQODfD8*1tMlHl8j2K(hU~R49fZ7~2`KovwVl2W{nCf0vTtiFo zV@jxxplebt`e{>rWZ!!8WokkK_bHyJgv4MLvkZ&PJ#|g~%}DV^{f~ha9nN^me}zKA z4h;=IKiuPz9RjR|Y|l*0ROy5(Ei%@JIlPUQy$|ISFy9<<a>v+orQ>sgGYwPbN?fS= z*cU89vlmwf-SIVMuti3*F0189t8%v|VM}3pE3R@0)>3oW??vHGYC$uTh6CyP5ed4W zO{fBlj*w}EKEJc5g%FXBDjqkL-3dCYfe=4I#Yv^rLPkpkf;D@;K#OP&iNRrY@aHo3 z8Gpvj!dQq%D97!Ooha!O;jV`N^T>>#Y{<Tx1NcLc0rs5e&wb;P@iSc8FF;f@n0^0d zYC5yysYhTLW!zgCdj@6giQVc-#Zpcj_6fO_Qw#eaA(LYB3>L2~uUC&ek}@;h{G1;| zGVB5xdR?l=VB%ve?BpSoj(1;0lT3L^ES}Gl=hzGl+U)2@_)QwCH~s(_ST~~uNNKSq zUoap<MkY>{&l3|hIcWmda|tjFEYHSw8?2Ef7MP;N(DTqiDMv?zyqnkwqr4U_YbDN| zjV_*zV&`mB_3N_!wYz-d#>JZ}AN{nFKcYc|0TV+grcqR<fIVHPrSv*5a@1MPc^%L{ zkMbS>Q-mO8FM7>zN9&yC;GoQnjrv*;Rh$(0e?~*oN!F&dER1bzek>X)&FU$%29tc9 zICw!2xrQfG-dQbiB|Zzw8NZO8`-!V<Xi!5J`jMTX!>7xL&H=<8u}4-jWk2qol~^zt z42NwbxkI>mnuLI)`?-CV*cQ5Nu-+Avq0JkBHqzxiCvl>?lKW0#rvycshZc?>g!w>U z8Rc+&HeJyHuH`Y4ZY$p^P)WKV*SgkspO}x0lxICQWl>Jc(t&wk9L@}leIUg?dkiD@ zh(9u$re<O8fzg^JGY3b(JUn&45{L%Pba*P8&Ge^-e4H;0wI<2AR$iVy;EC(cJmLQA z6SkL^^GP0#>8T;mXxx5o$cad45jwqc4E^c&=qOLqG2TUT04O8~Jb?6J8usP8drX?* z93avHOM`zsWL?N4l>nA@%Q<vWpC`z?4`Y`q_dfs_GbPWsTW%nm7vHTEl-278U2y|b zX|WUp#L5yu-B&g|z@8tdT+pe9ZDngmSSb58Im7}agx;_iur?N<q~guK%7GFNf(jS+ zX~>C+muXz>T#v*(LX9@c2AJ7PEWVgY*-5pS7-j;zQE#wb;+XNY?sf5A>Ym5uo7JV* zd8@kQ2U|<=Ykv&x%b7g{UnNJ~9gTYIGRPE@*}FpvC7b5s5<FZ-0@=7@e8pD4L+nmn zY~VCZItau8;Ow7JEjU>9Z3+VXipJ4O12P()|C8Izx*b~+t!FGCZ=n!kO`p9^d`Uv* zK-B<w4_(O)AToeD)IitZev+L3nr~W!@z0G&V)r(!?gamG1V+gC7mh&?K<M4!e&3~h z3kh~TJ3{R&)NzD`iOXp6Ydk6c;+(lp<4b>X@0ZC9AaZtujzP}s2*C<CsAi|$Cx2B3 zR-$Y*5LD2zI*B7;pJ>wxHz*l%6jhiE{I|3yI!oK;|HF+UpM4s?@&8zua&Il)y>|WD z-D|OX`{NAtxt>*(^h%;p=m$rXBR?h*zr=iTakTKN+>w<9LC3F5NVg!qpbZ6_oDK4i z5oy7e8sy7rCn{Ca52@L8>NVXIy^crBl`N|&-iCvJE3+qJmYQ`a=~B|84)EkLV5IES z>jz~SJH~Wu4Jio5)ePwx&cA~YgV$SaRSKytYjdMjn|306B(>5udC?QioKDM`iq+h# z_@<E5I-O7xmsFH;Vv~l_gHEnYBS)D&5DZd_=o2IcFXdcb;@<@mvKVLfGYgEUz)Mgm zZg5t3YP+tvz)H6Dwe1!`LW`{U)Uv28{+?RTaNFQgoE5)`U;HDteT+*HopABcB}M;% zga|n_%Qyfa!$H!e185!S1J@-4qrgc2e$>u~6-2<u1P23e)i#U5PiRA-CbEr(HpmAP zeYBuZm1ew&MQ{(#=M&T-U^S`D@^HsfyQ5oZz=w^}L8q3foi@Z89=g7*b)N!ICD`97 zgur0+Fz!F;abO2A^B*uro^r5C4iLhPFX%uNQHFBHL@4xxAX6yd<H4V6$nr?)s_@er zBJ9gZ5LCjw=<hb3!x%Cw8e?8T2ADMuLzbN#QK}Ot1Kv0e9B7#zAr1v+;Pnzco~X43 znSVu<hF6R8XJbu%j!{j_$=J^WowYPOa@Jw@U`gPC4-g~^SCK&|7#YOTPAo_eITzbV zltcajG1{9{LMW*nb~i*q-{*A=h%%ge9W|=hLhBH1pms`gG|l(26RgdWi$ny?%W8mX zpn|*NJ2adIvM(rCrsU^Hevc=rA~DPo!c-LKfFc<DnZ*mNWER*0+<#I6+bXa*&Yu=7 zlvsQw6aME8=$P~q7!XDh;zYkgl1bn5^8Q<RV_;M8FUV8NfrQvZNhbb9LNd6j1GWf7 zk!8}74=Mi*{}mDORK{~D5l^KP#G485LP);}Le8Qqn8o(3eg5UFo(F+jlG@2En^!ci z${{?ZgN_uq9+PImTd{~;#8aaX5C#9(HrV=caZ7KvhNj}LDIv*KIUUbe3l!J7bNkwd z%N~-CuiaSoZm!(C3r4Onk*>Ek_x$8ymBuhTJ-_B4p%8A(r3?kE(wiOIDRB>N{|%3} z$OhMUiW?<YZ~^c|0m(CTi+`5g;<q~qE0vORN5OSf@ZewggEj)~s_1!}gL<1*>3M?0 zCyi%ZrQ9+l+GqKca^xDQBD^{oHb9itd%nhGEq!{SM;1TX!S~VYFY)LdxZI^*&b8eF z(gJ|`Jv=XSCa7KI73FxI-)mrHCDIA{Z$VV0R0kf!XJ{mrDACt+13AS-AXcbKTf;rd z5k}Wuome#e?*`GWrcM*$>3YaWJL|O<o^J>LUK3y)^{Kslq(Np1DR82-GqsYI-0cTy z8s`d=i~p8H5jNluZPA|bz2#4T{L?$j;tg8cpHuRLl2<9AZGYRjDfe=ENmqz|Mic>} cYlrtg`a>9r;+ff>X^|Z?t^c)c%XJt253~_5DF6Tf literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/windows_support.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/__pycache__/windows_support.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5727bd2f40362ade2a2a54e9bc042510862ed8b0 GIT binary patch literal 1045 zcmZWoK~LK-6t<I)hElW*ZQ4##j_ZL2iiFe&p}_!wgvvyVD&-PF?b5VPoY`(mt8y9K z_9x)D+kVG>LasY;p0vYGdrrs3wkP?$&ri>vpFi6ti;G1B_Wkp1_{BiztDZbG6DDt9 z$XDP9BA6k67O{_sLCkC98`K~cnY%_;*f$Aopt5}j)u`UaI{Y$?VF&aUhI|1|p&NV) zjD1r)oiR1g6v1k%o)ubALik9wq3*Zo)tV)MAuVu3SL6C8R5mgz6z4Lt`y(BNZaa5B zhF&V7VW_A#429R>j8GxH+J$!>)P^FSB-KuDrQ5xjOafM0KkJGWu=B)gdTEp{M~PG+ zW6LWm>%;MIb>K;=2C3ql$%k+>>o$;sH0457(sAZ&urNL&;bs9^`33_`Uf!4SgpDg3 zjJHE3Hv!BF;Sf&BLe=3S&TKiBipFJ}S)D=B{&OH<165XfNHqr;snZCTu!BVj&|lJP zt+XP!^oIZx$bN+}Qn+XI%${|L0nPR7+!s2=6bDX@=K&RoaS53zni^Ner8za_zQQ*P zx99^VroOJp$D#|?pvqNU>UJYSXyS%SiRf&gsLNsEb|MByxFiy^t+*IhiutNN!DF|p zRQlTUK<jp&52@%dKB}~N?7bgQsUn_8Z?(2wt*)-Ed9!7wX{frVZak36J)^Fo7pju; zO&+z?IHj@z3gzHVKbv~Flof*@iuLsbL1xd2GF$7&SmyMpNGMyY`b%((J?M4ozJ1y9 zoqI0dK77||G>`qcoz~IuPUgU4%Qx|@?W3c^tRSFW*xh$pQL-xp7iBB6bgTZ8|9G=! zdk2TR!B(?*e6W4e+zs{*c6N5_nJK9H_rB*rR2pav7vMDVF*r2u;38haMZ+?R*uvsD p<jR(qhaetlr{6)IeZZD~jQj~X8!;yXMmP1Bk`6crJEmhB_$MCC4le)z literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_deprecation_warning.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_deprecation_warning.py new file mode 100644 index 0000000..086b64d --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_deprecation_warning.py @@ -0,0 +1,7 @@ +class SetuptoolsDeprecationWarning(Warning): + """ + Base class for warning deprecations in ``setuptools`` + + This class is not derived from ``DeprecationWarning``, and as such is + visible by default. + """ diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..187d18a134b93d6d723d138711e088a14c29e3c5 GIT binary patch literal 210 zcmWIL<>g`kf^QoZCW7e4AOaaM0yz#qT+9L_QW%06G#UL?G8BP?5yY=@{eq&*vc!^9 z{j$U&{j~g?l+>bPeai~{^mxm%qTH%HqqHo8jEst^s`wmBv!sk710YDx(+|-v$Sly! z%quQQ%*oL;Ffc2tEHf<CFHS8fEhx#)&nZS`#+Rk$rQ{ds$H!;pWtPOp>lIYq;;_lh QPbtkwwF5cmGY~TX01;n0S^xk5 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/pyparsing.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/pyparsing.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..dc85a309847a7dbade3e2f382a51afee4a82572c GIT binary patch literal 201687 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/six.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/six.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8e992735e48ed816df6f7d46513843f5f37c729c GIT binary patch literal 24483 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__about__.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__about__.py new file mode 100644 index 0000000..95d330e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__about__.py @@ -0,0 +1,21 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +__all__ = [ + "__title__", "__summary__", "__uri__", "__version__", "__author__", + "__email__", "__license__", "__copyright__", +] + +__title__ = "packaging" +__summary__ = "Core utilities for Python packages" +__uri__ = "https://github.com/pypa/packaging" + +__version__ = "16.8" + +__author__ = "Donald Stufft and individual contributors" +__email__ = "donald@stufft.io" + +__license__ = "BSD or Apache License, Version 2.0" +__copyright__ = "Copyright 2014-2016 %s" % __author__ diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__init__.py new file mode 100644 index 0000000..5ee6220 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__init__.py @@ -0,0 +1,14 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +from .__about__ import ( + __author__, __copyright__, __email__, __license__, __summary__, __title__, + __uri__, __version__ +) + +__all__ = [ + "__title__", "__summary__", "__uri__", "__version__", "__author__", + "__email__", "__license__", "__copyright__", +] diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__about__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__about__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..a6c680baaea3ba059876031f92145fa1dd896d66 GIT binary patch literal 760 zcmYk4OK;RL5P*|?bYI=JJk+zP#9<}6-mTDzB7_R<5ur*24!Ky~9Vam)cH~FY&5?h? zksCjS^Ikde2RLv*jJu%LqkNgM#^ZVT{dhc#aQ*uBg@12F(T`x<U41mp@Uxc)h#)Sa zGEU;Mm9)xs(vBl&K^r>Ig&pWY9|l=J>A*1Q!YJ8+-J}QOqz`+^0QQq193&&SCkBU6 zvJ3aGqRE4w7&V%-H~V~Pb>W?0vaGamn?A@|TB+4$uQF0OmU^{v!5%Q?q$>ntn-OEy zmnAoAG<uAABe%P?FySm3L&mswxi+ZdNl|iHY<&v363T`!W5!mxS{s?=F1S^E^@(Rv zWzEsKHiCF33+be=B-Msot}&b<TPI<gN4ayAeNJg6UGA6Dl`d(ut~k97)0r=(&zi}F zR=fam<$Rht!W9syLYd%sK~`EhBbVN3W19oGaXqs)u2ZR-qt{m#1aE(ZQFB4wY?FUN zK5Q!`C(~JTc>cc%ax$AgJw`0ZWBYb84sA%i^9IW`IOfQ-13HM%H(p>*OgC)p1oQ&J z<jo);ybv=A*hPGe%t6otet)JootisAYi?+&3&4En={3#RX>H0zounUUd4AnAtT<gP zb2G!0Df*69vO1Q^I=uUMHe1x|dhV$e&R0(B!roO`Efi>T+fa%rFSW;EO{?{$|Dx33 d3-L0PV~-FI+pXxI#5eyxoo**aX`uwhe*rig;`IOk literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..882ae131b919b33a14b5072fc15da0dcd021bada GIT binary patch literal 598 zcmYk4zi!(w5XLFV)?X_@fjmS#q;xw3Fi;eIf-X%LE(h9_CAOp}P^1uh>!Wnc*5}dM zDKC(rL(yYg6h1;f@PxbXJ{|O>u1kXP{PPEoVnTj}<T7$hKH@XpBLoqVB06G`j#;b| zmPACvB2f#yWJ{g0RA(&HIm>my3SF{NSFF-2w!*rFSc+6+A{T`yMb+l47OT%>T|c2R zSts)~-;G9j*MQW6v2M<Voa87?KVJ=2_6`od-#g5oqR^4gB>?xXGZtX30rqA%TG@6E z(*mH;Tq?X)07~wger(Rk=(XndcrJ3%sqj7n@K&A+rpAV;0Jg$8HY~`l0_uP?Agsj} z0U6@c`YL!ic;_vOSzIKsNx%XTyzrgzXzSb@S}qh`^j{|Z9}?_vh2|fLeHE$$et)O9 zhKaj|PTbOiQ38$9?E`ILJ6V0|-yObgy6)k00=2!{b#{Z%_Vk_(a=4ZK=uq=^v$>m& z(_2r+#`(b+qsGfCOieG0r32r8<E`vl3Ltxl=HCp*Ie)K>@T&O`K5V=}+{CZbnEX5V I3*q_m7x*fn(f|Me literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/_compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/_compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8429a1a8b5fb0db7d81326fb16ef159766a1b8fd GIT binary patch literal 1034 zcmah{OKaOe5Z;GuE3V@d8d~}|xR-(twcHc}fe;EU^cD(zKt*9uv};?5Ufo?eu}Ptj zK=L!1V{ZLDd+jNIpogA1BZt&Ebznv_v)XUInc0u4t8D`E`{zaUg%k1%gJoe5yaF|! zz(^u#N-`SKjD;-YA*YyQsTX?6+iytnkVt;O!sbonLDW(${YLpC8m{C`)yA)E$mS^t z?@0EZ^jlYeP5RueMSG@5E2~73m4&v>m&r6SNs+s5sgvA_QI*FQ;@vAGb_I+{O!4-$ zV4?}y0yWRTyd`JkjE<P3lAZdJozoNkjal-89y7_Mmyin&C^Y6ly9e@GtH`Qe)Z2@U z>cwefOz$wU6Ub!BMs;FP{}}`LEy2<#<`Ec0LMlnfmWzj6awz4^pCY38hqs*;ag>^! z!A&amYN&-lAN3xn>3}(>$Ml>W^Am)lyO)6Jc$^yN<x!?w+fEWAumR(!ykxGi@I8dr zIGI1+0~qHNIt`|g4n{>Pl{UfFQ7{%;Q=QH8jnV#aGC7*hMY^@QH_=0oaUOgK%A|ar z<i<v6`g}OtoX(~%s=z2)m9{8Sv+Rng%4MO0GKvqPagvV%5f@n**+DsTEg^DsD8v(N z3U^89y#L?146bkOLdQP%(5?`!EkstxDn-8|#MdfH7bp5I;MN^$oZG@%1JAA8jQTNz zH36UMbv#<L3LjsjXQEzreXGx$XJ@6V5&K+s5pER?-dQS9qjzsNg1?x0qpkZ~KY*y; zLDHkjRvJia>|f*i(fF6+W@cPx3M+w^E|PpyIR5VQ2AY>}XtnErfq@F7WL&%6Z=I>p e7j$sZOC9^$iy7@;34{FCna{hl>v_~?P5u|`aS6r% literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/_structures.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/_structures.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..eae5af20271dbffb72bd591d31874c3b6027568b GIT binary patch literal 2816 zcmcIm%Wl&^6dl`%<D_YuLJ`k`SfNO?E=V9M5Gn$J*kseP$!6qwCW(t<hnaCiBX;S6 z-(Z;?-{UPSet-ol?ww#rTRSNTCYpzR@64I|I?kKr<r;zZ?eiz^W0{aI_%Pc_@URPA zzJP%dW`v|~w2i*mHv3lFGRP~!OlBPuX7SS4YL|I=Oxk65TViE+Th?!FZo^xf*?Xi} z`3fhIrj@RG2Qm&5#c9wV#6qPG3x<IV;wW7ih#*q5lSICPXCHUWHWMCpq04<3IB6S< zv`uC(^O&?PX0Z~?fX{50%dEm2m~B>NHJB@GiPd3t*fLvzxyn{q1LhiAV;5jvVi)0- z>#6fP>I6}sj(h_^vW9Ey&!J0n4l_X8Yzc54nUIN*mLv~5!iGmZd_Q)<n4zb*JM@Ix zi9^PPba&pnUAi+A{ZVwkbGY5>y&sKexbyI!C$^z=BX{2&1cS{WlFAFi&F$@n!=vH7 z#Fbnn0~N=ioL$l(k60|+f#<*Vx<S-+sZ=8IRU)|D8XTn#rGgIxrB%E*`i~f+wamn= zOnSyv3lz1jbyz5(j1OdNjKSuK(VCcPsprXFTEe461vGx!Ef5G{QG-(4o(DUX`uakk zf(_SaTs$#bFZJOQQ#hcImSff9;xwL3X{ab&1&s`Cb;d}PEyfZJ*gidZ?bk{NRNI6Y zoYD(L7$7@?amtM!z>SB-*xVyx3623r)*$gQ)RE8ADjX1cQbJG)@cBDRFBRaUtQda< zb}5qK*U8Tt2t2I_Edq<K6riE(3|e0F_UAgZ3xT;_0D-c_5aJqIprcgav@TrrW)TLO zf!EF&u1}buGFLT?w9(>SPX$AsrB-h4S165mm(tsCRF;g5YzI`F7PcmJERx9U!wu3J zrTv&Cm|kg}(szj$P9*|aT3}j>i#V*~fH4tQaX{CJ8#thWGez+$Yc)S%g-Xm@$8@Zd zKP~q`bfRG??n3{MJS#Tf{Q0i`NwK5qX6C)Ag*k+y{nW%8Yeq3fS5JrPFQ`t}s6YnG zi?fc(-35^6rMdZ8tYh!aKwZwU?wlMqw_J37-CqQRHKW}Oir8>HpXdr{M(6Sa*q_BM z&$55ZY`StDEr2{9z0Ln%=<0mD0O*_~H}}h=8Q|$6pg&<c%?i0mk392i2I@*qCQb=X z+yb>+O2W#&gJ%>_63Sc63bJA+!GALFLBt#rm}CO~e5H1LaL9c%y(jAD0j189DXTuk OJre&utXqu@8~P6yr~6C* literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/markers.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/markers.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b1917bcdf5fcc939e956a20852e0ff1dda971268 GIT binary patch literal 8969 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/requirements.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/requirements.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1e76a8e4a528d7770d1997460d81c6f195f26642 GIT binary patch literal 3925 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..bfeb98d81d2bc084fc19e7f95b70373e67142fb2 GIT binary patch literal 19840 zcmeHPU2GiJb)K1>{o!&+Q6lwgTOLV{#g!#Wc3j7HC0UkjB~BgMl@!OOWp9@|LvpG8 zq3#SNkzOWgq|{29xJjC}d2j;>Ezk%k&;V)E1PzKl^q~)ZEDCh`STulNTc9lj*y{J4 z`PtdsS(`4L6ezmOxqD~k{+)BrJ@>okp3BdVjTJR~{^N(Ys%uS6`xo9MKRMi-!sY%P zfvwqkLu=}DdefLQnwhzb&Syr$oHOM&JC~K;++0q6^K*GSW1Edab7XF$S)3~(ea6l< zMw_L%Qgdu>tT{e6u4|vx?3|syuGx8K%eBnh1nvv=2<}ImqGK*^b+%nI@O%=_i}om< zk2;gMpTd2~9>e{ZGll!@_PD*}x;D21&nN7yc)nGh?{xAvciG!+>2tg7NqY(@_SoC) z9r(QmDR<htkaCxlc&}}o)5^Qw1+7{+<8P_XyY0rR=Tz#=mA3Nyf?dB{ckAtzKfa>s zEw8e$+NycDpM6(n7Q-*O9$qX~ytNg_^~bN&y`@Ui@v5~()pb#1{$)o=0b?&Xi`Cj% zbemnND%Yv8;^c>=p2Fo$AaJxf-PYy|Tc68FLo@!w^R3I(M%_NQ;?(L3bw{m#rfA{w zbjzv-Z!9-@WnHPd)<S!=WgoUyT{OdTm)ffh+fvSgqb#p&z4Y8m)}xOen~@@B%cftb zR9e-hQ>pmHN~PJhR~w9%DwRvC)kgRxU#ZybTBUMZQ*5LJcdi`;e=b)&=ji3CI=awq z*r@O56IYKeR-U-5n(M7c7M71KEnQt-uQZ-`Y<@`{!)LK|^!(A4`pS`d%k`>_#*t&k z9=p7D`Qg>0uH&t)c<pw>O-3u1otE8JM^~z~i`7MN{b)?9JF~K;M$w!tWS)Vbpv(OL zhfTaY#YA655OLVaESt7&8`rgK`dn7-AjWc+le?^)le@g!<?Vvp6>v9VkJv@ID>}vH zQF}DLW0_m+F?;;Fj#5jKbDO=zo{;-7y9Cjj^v6zDT_^6&8U-NwFwW~4TrS&f>&RlP zzb*a6Za)h?sg`SbOO6FWM9;1$$8}m>l|pK@7x1R;T5<7Kqkhq`+Vjg!&6}~#<6T@- zC>!%mPa&6)nuR!tGU}e|G!_D(VIyWm1a9lT$>&|6P+QStAL4?RRVq741Up7E*0=Z2 zJQJqa6zyl?21m44t);5FWMNpWIuLgV_HdHp%t4#gB%0ITV2lA4SgGtyw0K8<i-ROJ zA&5lb!+2VEU5ab%HhCVh?NnP`UPGF#D@zVItt`;cYJ0+U?@BwtdG=mhSkQ~ERaK7V zaC{E*h@qy?BtP3`sr_W;Di!BarSbq$MBOsgPb3p;ip15pRlhJ2$&pkt6(uW$x)xN| zLmxyP6KqQ676+*7>nRMnBg#RCx(@mSf9Oi|uXGLcTKkG)Tk~rom~m0D>gw;dRG}P2 z6;Tb3B#7GG+hvJVo9Z_^Zq7N!bNdDGV<qc$B#kmq`}#}W1Dc-b(luMl;3oPoo;I+~ z#;t$W@f_8xx4`~-psp6{m@KTi=QJ%Sz*-wB5wC5F6Lh^5=!l_Ra61!>9FzH_ZGG+a z3t@@wDYPvbKYdCfO0p?helMoweDxxwNE)xI^AICwU^avgZEK<40Ij0(o0i)KB~{OA zw;F3<nk!57+EQE?mBWV+-y@}9P2KC4$a2Vz0$L$0N@YndXxW(rL;4g-kf5y3@^4&~ zkW!5?7)Rh|s`E8}90<%))tUzkwbZuNcD~-hU^jz3OgIsxSyAm3M|o?~96txpfc7bi z3HLLI;YkqVbfmT+V4<#spkSDKF^4M~{xTk3B|MYVH6-l$P#jO;a&IDt5JX)AMzaWh zuj>HEf)@ae1t|a=3q}Aq9<@t=p#?z&+T4hs0d1}boUjegN1ajtSb-PD5Esyj_&DMM zTM^&lY+0VLcN4_&&fa6+gPdFKefGWfeW-hzz2Dwz-;da&V8#RfROR^=ajcCwB1Qtf z);q=sFL*tJ%Vi&Sv}Nt4-qCOA8<|eV-Rl8{-pug+n*J5NleuZy#x4D3_Le5`Ob}l% zI$9;yVVJiypcQj=eOHKCyU6rO>)@NmHV*m)_FvU&D?fiZfXU^8pQ|Wm(Yeb0tg70Q zpg2E=iM?6%{OqD?udeu6qHg?DID~;u6MC;~hGUnn0?EiCCkpC{g8&oE^YvEUt5nXC zWQw4smvmDf&y@7i`?=iueQA6HSP63V%p9Ehv$%wN#}Fa+Z0+KR+5xWVxC5_RhHY%< zc1G?24!vv#T?me5gim)S4_gU3PP}<+pW0B<C~SSpaj<Lp&4=;e%||xMC(AkYFrKR; z45&K&5lm%Vaa1ZYto#fZ6lvTHOC2PhSg}&6Ah*jwp=Anp#|`5>1M;84*LZIz1A?4A z44`@@6NCXA*tWh*Cg^Wd2#neF94L76;f=BpG@3k0o9JY~H}Ephsrvf8Lpnh)<?tqO zk?TnVt^qUOhQ2X;lbB5nt(jV;ov3+O_YXmS1!NWKUka+$J^h-Y9$g>rXg3WRM*0`D zOV65`m$_I}$8^kSy5^ZV?NxB-6|FUa=8B+PGu&rA^BfzW?dZ$di&&znUqzv}bAAzv zQLdF*HAiu!t{!8+b&o$j+xDJst~8t`;J;%Bbf!R~K#?McEHO2`s2ln?z7TrdG}iAK z!tYcl_=}?%Lqcd)CrDr#8Jr3>J~A1C`6#H-hjDUJx{e}1sfosHN8hbM-_b?@5iV6~ z?IxD(P6e{erTrq-`JSglqOo9(l$i@57vOEQSNg}@SOuBlls8acB<TCo8J|o(0O?|d zO=eJjJl!)E3`o!p532f_z5(?TauRy+BvPpn2JAS+F%s$sb%+o8bi@|W>!_N8Ww)3x zej90A@=Ala6!i56(p%h{>4S%;s7Wwc7_6v7ZtKHGXc_Ong)72a=_54ihL2J+b+_WI zm#UM<obM*;P1i{wmj<ehkt<n8f}`QA2TD9;4JtbQdx;vYR8}WuiviJyl`(snilu`2 zC>m6s#xr#<gWfKedf(~RJ5Xu{?_{J%soG7Hd@B+#^qhs)kwo2(cwg}}Bt@XOQn`r) zk?`+Jr7xL!07S=4c@pJx3{18K1zo$WZ2)|Pzy;F3Y^Vo2hWj8*CwQJg3iB48<2TEJ zecPBlgXxr$sCo{8KUQ}Wa6*w<MZpV(2yFs=R0-98gy$~jJ<TZSIkT88>ZUnl0*zSE zLlQ?MhjR^=`(*?+aMz-?0hA@g0ZDWWAc#y|-@vr+toHipjT{KlIyoS;Jjl^I`31d` zeH-1-$%E`yK=vzmo<V5dG?`A<E&-wf&*fgm<a5aauIqG6g$v~sQC{$TB}8s#ge~XG zS>a3otY1LW<guTtuB^ZwS1yRMQ~Tl<`L((O`=9M^72{)qo33wMydsQ*J(c!PJJK!v zJl&7devHdyL<1@_jVZIB7maZf(B!V6n|BSPWSV**Tc9pVpSHpUhao6RRviEWQ+*2$ z^)zZwk20Vrr7bxEDG>1}#EXuuP>Aq6$h@CrU@>636GX{4lLg2@yqLx1P9wkq#3+sx z#tIpHNAb-RvW8yFL>HDLcvGBI%tg`Y`Q&kT3YU8sL9`H|vDh(hW^KdC?1c4wrv{69 z4p;uPcFVxhLl!4om~c_@P7aHZU{O*G7bT<NqNEfqO2$GP`gmwV-x4fE=CBBX+TP=D z2@Kou%A)$u(0K6zbo!~6jz=2#<n)OXoqZ=d$4_)lBJ7+jm*aF7+(U7kc|vV^GJZ%) z<7;mm{?!X^`SnBA0qa~HAShVJV}W0__BR~b*Y|f<8HZ)POxtBxSWj6jFZdjw>6G@j z8W!EKe=e`Oo>iT1uOe)%(Oj^2*t+6avWl=A6c#)jTAXvW=B#*Pi^OW&b6gm#9kj-B zoo4+=t=)iWmWIk^Rb7O+&s|;NX2ap3<yEa(qYdD<Xc2w1EJQ(iNED14L9?9}Q^CYh zZw)O8%xDH|L7DAl6HSt`>fS-}Ff0=7L`7Vebu9tip1NbcfzG;PB6z^hib>8Nfpre% zL@Y4<Ee!|D5LhKz;e&09%E88fN<JHj6Zxg&>vHanapJ@sV;`>LxK5t9qaVMcpBz3B zb&-#t9^fD1o?hgWNg$t3VW_BQ8T3tk9NqthD?~U&z~S}#`$T)D4-xff@C-7?fQ-vY zPBPHXSow7!ye_IVvM<4^*XA<SgRx3If-HTF^2cMyDa`#(w$DJI>Faw_+7_TwNxJE# z#YlUe_175ma>m~lHzMxkJ4hBaWdG2H#K||^m<UU#p^e!UHzpRLK+fJvG--Nhlln4k zx?$M}It^{uJ#oX50v)sslWokdhlaLoFyE$|7bCl&&Fgkz%z{j!Rl_?mPQK~JVC@>L z-G(-1dn&JTiS~SAQ(T%YZ|$4Ru?!RI5%-*YLpgq)Yqoj=k(Zx4d-}z5&-umYKRx^6 z+2@{l`rLDh`vbxJ&*85e1`7-p87wiVGgxNO9Twf${2X5VBd%aJ&j6W>W6su!cTLm4 z!aDrk$&CP~aE_O+Vy>Qbf`JFr9n>Lipwe#YH?a16OIy%oW3mvbv~s4`a2Kha$!=Dz z1ECGaiFt1T^+FM0I~~39Ye<8|sjLHK3CQ7&jXPtZ6;LOJvHTT9XlIYIKe%Yo44_$k zy$se~TCHRK8_p9^FU}lqv}@IddvYes31iEM?38l{*U$1P7sZ!Qlu`_Yfh&wjjk|`G z4F7>hAs6&<Q>`Kk+uZXR!QClb?oSZ>&tMQC&^v`WxE}-{2$t1R#JN{XD{BdHvCtwu zhPXHtAU=+GWTV}Jcx0oUKzz5oNAhm9@3HTNg?5`WY2Rn>m1k4V)be)w{^-uO0HpT$ zBV7oU#Wr?4iT6UNFP`Z1p(xy+NFb@9=xO??C*v}^*ylX(QQd~ksP3&<5mEyf;I@^Z z6rc;otyNbX?6bm*8f-XRsW%!ah1qRxTsT)@z>h#xfSSTh<OpD_wO6qdgI!xVA%vU% zU8s?48=xJllKoIXvtZG{y|mDEK_DKm888rL8_SONfl}HAEJpxV1*J8siOp96ss+`? z22r>d9+S^4BfIX_+N-L%=yW&9x-FXrI0SNPtYV#Gk$KphTa&H7UTzIiHT~3a^w){9 z1q}Nlw`~Fj1sm5XT`@pO5-CRwdJT{as2HCE))ztq+YeU{qhC^R=|K5WnJg<nhu|;w zkz|tzXx0<P0lyM9qoX6~>7}&`7+GMar<&oCINfTu$^u}9i6g|pMt3V)x?U7dPuZ;P zK!jwmP1Yu)C&;3^jLjW0kh4^UV*_5<&H{D?A<}S~u&~#jQc`zFgs7MujjT>f_U5?# z)=M}W5OgxuI_T!^XQ0D{&|q7S(i_|s2O5#q<CmWrNCvLHcI?O#uRpY}{8X}1XQiFk z5scmhNs;HmOb{&}!m9)DNRWN(w9=!jiQfa<vKX3&312%>xiItkU~Bnqy4soV)H<rx zsWw)Ya07#C2L<xFTz9VY$`Et#^FbvFDczN1kioLbgY|>*=xyQ`^t7@18^#2tM8+c_ z$2w$rK;Ja;b<pgNDu<7PwhYpM#td-xfb}X=VyMO7tYyK4phwWFkk!ld3=xTs<U6Gt zuMLwiy+|PGvROvyZpywl3hl_KX<~~xc-&s0qfpX!Bw_|g8z?;_Kco*0>ZP<RbqA!i zAHu~854~1BvMv%E^D%x>J_I2?5Kx=ij$Vxtwfe%$g+rnQW9GSQ*!sW9J@lCmm5biK z>a8J-9|zz<#r<`xyS%#W)Q9_-5FkNH7~7u3@dR%kc=FiwML17k;vn+}sEWrPrm02l z;-u@9FZL=GP(GknP<mRc2F31|q*)%4Muy^m5rip9G;q~=NTz?MYO{l?)}h`W2<0v6 z+{EwyHNBG{O`^XfJ=9-qJPx1wfWZxUqb^Dt-M!tnnE~`Pz@7M~#o)^gfJOj7tFVsE zV?4mcWdZI<7)|LTXBcj<+cS~>99AftxtE+Z3ow=QtyGaR40}}UAcSZ^3!?-nDQG3f z8>Xy<`qh-u1cwna#R}a`9oYK<Sf3o;0_J3-2!N?JFhkJAECh@0pbqKp(BS?+g1G?z zx&jzX6eBZ%yNWrS<P5ZaSaEi{b<hiuE9M$!=6_AK96}Rg#W~P^$a4w_|F1kg77)|V z*^f_obk&GDk2SseJOaPiooCg{eEJ0juP}I(!5o9v5cnfiHD8ApnOZ9s?igP@p)T;% z>kQstK%W=&8w{!l?qskW>oIQ85<~OIGq_yt)xaM><JS63xZ&HG>u}qEK}ElX%hqi3 zs|LLU=p|)mKc(SU!|n@q+r;c*v|o_>yxeERm!L4~>oYy}ADB7B_Cv#vy9)s=$2Rs> zOImw}#9>7)!O92gk8cuc`WfipvhEk*4Wc}kZjCVH=vNa~Dlx4TjyI~!dAoY@TQsGR zvXWl7yM8pbHPEIV*p0jV?HY8V-0$AS=Z-ORC}18LTF&|Aa=YI0%|;#V8KHBaxa|8Q z9`Gf0K45hlk8MTnN&|gDmWCc$%0^tQ-hM7np8ai~OljIzNCvmAwNVr1HTWtSx%Z5_ zX3n@{-Ze)H#)Lk8cm2K(B(JBlGboB|k<O+`s$&GKS1)<8e@w$0yeY85Y#Z!q+#6m7 zA`tI0*cx29APjtqv~+)i{q2IW0e7#~E|h|I*p)Vx^X^i&Oo|6L2GFJI8tQ%beXtn* zZv||sN`H!%26(eN->BEr4J1+Az3?*)r$wK)YP@^uXJyJtv)+qM^AE{1x}<2CqEXCD zWJ}oza{_yfIqaye?@D2oEJcU&Nwzn*xd9q(85B&h_?Gp+gj!=;#l|NA1yRhZf5Udr z)`>F!_omc3e8YgfBt67EcGx%3OV{*^(RKk`4`Op>f4#Ki{%xY({VDavHtxV&KR|bS z?eU(#w^2nZ@0al6?-F%?BBkz4SpDPbkE6VRbchqh2fZqe4aTzWJ`QIGT|G`Wpk*+J z>G*rmP>(YWok4GBX3w05H?J^@JNbTT9)Kbmqp38|{{8o)fqkx-+;2B?C4EXav#EU; z^Kv*Bsf2sTFgH&Ih|7p$<y;D(a}lBHJE#JBhJ^a#^yq-f3<0b9T|89ZVo+nyC#N*^ z|10U0@sgz1ECy8H{~^6NoN#J(Hv1ZULT`mEU@YDrgppi^IL7l8xH6}-FR>dJ&vGV) zRJ0qHHmu@=J#!AFDweFXxPh-o;Ilfxm^dKnP-0YF*n_y3Q?vMm%2KDGA~6r%(iw|p zKq^HJ%4Ji{+87#k4yr9b3+EA;ePzy-*>??9sdWbO;u>RgEjxb(X&>g@F$UjYKsO^r zK@DBd6P`GI-9{gbJo&H<5e;3Hg9}a}vrR7{4!_3j-A=<~6N-X6u&+$z^b9VSHDicv z-fimsxD$-o@{Yc3DRmLWsRjcay3|yQ0i8_~J5b!)P+w>8!P`*3&m`=xz-dYRPP)vH zm?&I2g-lYApGBm=t*J`N))cp>{wp^Mhm$?H_D7B<;qNZ|?nPd`xD(#+EOCAB8`Gin zYZ`zrGT@cNXAks<80Xb2F5&1YMBvaQo8p8va5*{*q0!+T3vfgDq>gpyVh-2xTL4sW zP#VWQX4WVUfih;*n<xj^BP)QyAESE_7GA-&pE`_}e$Kh-VG{LoV*hg0=a|C`{El)s zAGg}@l(?sT5-<A4{|!7l$i5VPM}Kg*$eQ|uQPO1&?hzRhNJ$X_e~!o^z6M;-Kn`F; zh#BQzVF%tfz>FXZ1V(RwC$B@y;y1|C5p-#r1RAy$V9Ov6racoFv;U0&v<bYq2;gCx z-4w*ALE2r~HDe03ODVl+!xY_I-L!1`a=v4{jdq0b4C4!gEcw}<euk8Z_qV`T>RdwB zTM;S%F3s0nv3;p8;blL^e-qCh1IPazzmTsauo(oRAE93L4l5g0<EK!g`aV;z^@?KZ z>&M{DMrl!BW$;@J-eT}J0zZeHDnML6)2v?gv$Z80D8i9hv*9e@T!N}EE_r^DH#n34 zsOyi)qu{2W<ljMgk5I@gMBsy+*`x1~i<ox*`z9RQ<QEfd>3zl2H6~1cGPpT~%cY`> zcRlxpCs42y;fYn8L<vryWWy6ExzO1wA3A##LT9g$(Ag{8+mw?i(az?WGqyaAy-ggT z=KiO>%ifKWw_yL0XHRrEf?46&ldW>%WS?J(l`W2y1<rRplOmbTU0WG8)P=#>Ta0!% ztWh%v=GL!qF-1M`<c7Jv4a0_0j2R3f_|oq+F;w77|8n3<FYmL_`&aS)6<k2$862{} zaTGa}QV3led&CGGAxi)e-+OVh2myY5iq6v%V+E+s-)|e2=-NOH3!r-xKer9vm^tR_ zZeRcU#p7HPaY1$REW0^}#5oL+g0@~x@+Lk_k`(kP=N<iUc|`pIvf?<01G%f(w&-AS z_!lPvY_qHOx&yiNaBjxME|)7)C}vW^7pxA$jW6YfPMg6Fsy`CH=xe$-LcYj0%S4)) zg1=<}!nh53a7U(SCMHt!ZQTA;eoFTqLOWt)k$M^ior(^p7KCOoXVtGDM{w?C*YPB? zrsYHo50RXNHW#E2AAk|qq#kF^?p!F-;FEY}lOF2n?je@}I))r-p{NQS^vVeA0D%nv zG#M0Bieu33KShcGK5&@2ymlafRE=YSC<stIaDkq>OD7^f^#caIB={r87oC=Kbw!<Q zkq}NgCWLAIV3Ir0De8nIMY#Z;t|JdlRKd*<M?-$dIwl7z64%!ztH4Dcv#GQSdPs~k zzp#iL261pj=AoNlMQEtwtY~PJWXnpT$}Ua|#4F{r4Oz-d>iixeWT>3BnF_rBu<9O{ zXFLh9--G9iXF!)2nC8MWHK!?XMg<43mhq1(;5q&Z))kD61TnnJwT_2xN7Uu;Z2>Xl zkhgm!hFk!|--w?Uyu1zSaX^m3j6)-5o(Vh?pbO@?)tuxgeH*+b>%79jbsp_J10NbO zBu6_XZTL$lY_GdBn3qn1(%{g~pD^|mgFj;+yybB4i!bvK{BugRRRoy1<WN6i&?i(l zmybGe^q$POkbp;l_%)53zRj3Ij8_R30zkyOSnc&ogJkc4Llm31XU^azrDq<LXE21R z!ybDC+@iKm^w^UgmJeO-hLUtU-_L=As2~{k!V6);PCo0UR1Q3Som2*hE}&9Sov}Wd z><<i~)MHK`H%YO}<xkk!v?f#8e0P&gPCdrXo{;g8J|>B0hK@=8%LbU3DwXfE1uQ8= z6-a`Qs0w_Zr&h!3<%vu>3Ri9=D(+VZL5hKz<35@}b0ItfD_M6BbuCY^3g(8A3bZ$d zDLm?^$D$7@<|S&I(<sz-iC|z^>r>jWJBjaqiqckpj*LGd9kIH8s7KZktI%|nEfXAt z8WVqOEmdE$@;_!BGPlX1H^*})U5g%-XriWp(MmdFIr&KI-M?VH%&r*&rN*7Xc5y9` zI3}b%gJ<e_27Tl7vv~H?xKw?8cMrcl@Gua0%u3xC5O{EU<ccLa2zLX@{%hI|tfrvo zAAoF_U(;{s?jtua8K_5SGV*e7X>Va=BQtveDe|#wn6qaFgoBvildO$cF+z&VsFihm z(+GtG<-(lvGbEV}Xr`3hHiDI>h>g%MAcey64<ucL#W3!!PxlZX9T`fKlyGJso(>Fq zWO^W%<OZat(Fn%eUcQh@|C%wW*+T4RtXbfmfrEW8@Z}1a26E$u`F<ZvirUeG<_jny zhDj7yIk1#CjRmvhV_+(g{0^@3mtjx}j77HoO&FLi?cpg!9(KYN9Bz7PBZs*m=ViT| zbmJRdzLUc|k#FJYMjr3-9?oy6)}_-p>{L)UaM<Za$8^8b$=)0Zk2;;kv8P1b{Xr+I zeh{_|am+D*^Rga*Re}9fE(UBP4Qf9E-{k*kNt_-asa>N~U|8rs{}gO#6oRuyKwB>| z&;1O3oq_OQ0^vWa`6u%K5F#+I!fpklycimJ=&67nDH>)5r*vt@(n~n>G(me-@5GgQ z&}m!05$aLaPduDB<MfxjjsLfT`YCV!iosb1BBl>A#=)s925fPHiY_UHC7&ZHOja<8 z+Y2M&@4T~6#222=Fe6QbCz|e4OkKW@|7U7p75~Ht|BFQ-uckPR6^DU3z<^3PSco?e z!_*Y)QUyRL&zEFeAowx_MEZZsXQPtg>C?}A4sK<BF8F^r@-H3aIF&4*#G^P^REc4Z za5C6x;i6j_nMSK$I3E0Wtdnf1OAbxp;GcZ412vVI$nAP!;!E1d#G{1~{C-KB#6hmn H!ae^DgRbz@ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/utils.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/utils.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1fee74cee25e0331af3f0db8a690dcf8cacf3bf6 GIT binary patch literal 519 zcmY*W%}yIJ5VpOW5QRdi+Lwq>aNvLx2~|kkxwO4(Raws3*_e9m)!4g)72?zfNe(^q z*5~oHCtiR9r`jA)_@w#t&3H!h<8KECV-)f9cgufcg#IOG7g=;Jqq(z40tu{9jSF0p zg49`&;S?h}FLIf01|r+yVkmMk_=So+LB62L@G;h*NfzGog|oW#lBv3};KN9$PB~>w zIBY-}&z7wzee|#U;rA&!`EgvvfnJex9_=ccJBsAd1`B+Twq!%LD7GTk&v+U;ePks! z)~J$e)k_AllIxJUb`b{J-b$F@kQ-jhKM2z9&kr>A@3@z=<3N{I3ki<S*R*2u4(i^V zEpKM4)w=JQo}VvPFpH=R{Yo3vOqFq-YdxLK&bzzrw53k^w(-_#w<}pEjj%u)UjF2j zG8JvT((a_W3m@K$n<jggb|jGyfutv+FlO;Sz6Hq`q!&mZ1L+`vfDC)3tsA8!3{yDO byzI6^`zdvFQCrb!`8gH3l>3Q{vT^nwCYy_5 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/version.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/version.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..cad414b9094089975c08b319ca6d9ed772c50ced GIT binary patch literal 10687 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 bJC1h^bhEZ#Y|Gj095vmsW#{9(;SB#jd4!Z$ literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/_compat.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/_compat.py new file mode 100644 index 0000000..210bb80 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/_compat.py @@ -0,0 +1,30 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import sys + + +PY2 = sys.version_info[0] == 2 +PY3 = sys.version_info[0] == 3 + +# flake8: noqa + +if PY3: + string_types = str, +else: + string_types = basestring, + + +def with_metaclass(meta, *bases): + """ + Create a base class with a metaclass. + """ + # This requires a bit of explanation: the basic idea is to make a dummy + # metaclass for one level of class instantiation that replaces itself with + # the actual metaclass. + class metaclass(meta): + def __new__(cls, name, this_bases, d): + return meta(name, bases, d) + return type.__new__(metaclass, 'temporary_class', (), {}) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/_structures.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/_structures.py new file mode 100644 index 0000000..ccc2786 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/_structures.py @@ -0,0 +1,68 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + + +class Infinity(object): + + def __repr__(self): + return "Infinity" + + def __hash__(self): + return hash(repr(self)) + + def __lt__(self, other): + return False + + def __le__(self, other): + return False + + def __eq__(self, other): + return isinstance(other, self.__class__) + + def __ne__(self, other): + return not isinstance(other, self.__class__) + + def __gt__(self, other): + return True + + def __ge__(self, other): + return True + + def __neg__(self): + return NegativeInfinity + +Infinity = Infinity() + + +class NegativeInfinity(object): + + def __repr__(self): + return "-Infinity" + + def __hash__(self): + return hash(repr(self)) + + def __lt__(self, other): + return True + + def __le__(self, other): + return True + + def __eq__(self, other): + return isinstance(other, self.__class__) + + def __ne__(self, other): + return not isinstance(other, self.__class__) + + def __gt__(self, other): + return False + + def __ge__(self, other): + return False + + def __neg__(self): + return Infinity + +NegativeInfinity = NegativeInfinity() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/markers.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/markers.py new file mode 100644 index 0000000..031332a --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/markers.py @@ -0,0 +1,301 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import operator +import os +import platform +import sys + +from setuptools.extern.pyparsing import ParseException, ParseResults, stringStart, stringEnd +from setuptools.extern.pyparsing import ZeroOrMore, Group, Forward, QuotedString +from setuptools.extern.pyparsing import Literal as L # noqa + +from ._compat import string_types +from .specifiers import Specifier, InvalidSpecifier + + +__all__ = [ + "InvalidMarker", "UndefinedComparison", "UndefinedEnvironmentName", + "Marker", "default_environment", +] + + +class InvalidMarker(ValueError): + """ + An invalid marker was found, users should refer to PEP 508. + """ + + +class UndefinedComparison(ValueError): + """ + An invalid operation was attempted on a value that doesn't support it. + """ + + +class UndefinedEnvironmentName(ValueError): + """ + A name was attempted to be used that does not exist inside of the + environment. + """ + + +class Node(object): + + def __init__(self, value): + self.value = value + + def __str__(self): + return str(self.value) + + def __repr__(self): + return "<{0}({1!r})>".format(self.__class__.__name__, str(self)) + + def serialize(self): + raise NotImplementedError + + +class Variable(Node): + + def serialize(self): + return str(self) + + +class Value(Node): + + def serialize(self): + return '"{0}"'.format(self) + + +class Op(Node): + + def serialize(self): + return str(self) + + +VARIABLE = ( + L("implementation_version") | + L("platform_python_implementation") | + L("implementation_name") | + L("python_full_version") | + L("platform_release") | + L("platform_version") | + L("platform_machine") | + L("platform_system") | + L("python_version") | + L("sys_platform") | + L("os_name") | + L("os.name") | # PEP-345 + L("sys.platform") | # PEP-345 + L("platform.version") | # PEP-345 + L("platform.machine") | # PEP-345 + L("platform.python_implementation") | # PEP-345 + L("python_implementation") | # undocumented setuptools legacy + L("extra") +) +ALIASES = { + 'os.name': 'os_name', + 'sys.platform': 'sys_platform', + 'platform.version': 'platform_version', + 'platform.machine': 'platform_machine', + 'platform.python_implementation': 'platform_python_implementation', + 'python_implementation': 'platform_python_implementation' +} +VARIABLE.setParseAction(lambda s, l, t: Variable(ALIASES.get(t[0], t[0]))) + +VERSION_CMP = ( + L("===") | + L("==") | + L(">=") | + L("<=") | + L("!=") | + L("~=") | + L(">") | + L("<") +) + +MARKER_OP = VERSION_CMP | L("not in") | L("in") +MARKER_OP.setParseAction(lambda s, l, t: Op(t[0])) + +MARKER_VALUE = QuotedString("'") | QuotedString('"') +MARKER_VALUE.setParseAction(lambda s, l, t: Value(t[0])) + +BOOLOP = L("and") | L("or") + +MARKER_VAR = VARIABLE | MARKER_VALUE + +MARKER_ITEM = Group(MARKER_VAR + MARKER_OP + MARKER_VAR) +MARKER_ITEM.setParseAction(lambda s, l, t: tuple(t[0])) + +LPAREN = L("(").suppress() +RPAREN = L(")").suppress() + +MARKER_EXPR = Forward() +MARKER_ATOM = MARKER_ITEM | Group(LPAREN + MARKER_EXPR + RPAREN) +MARKER_EXPR << MARKER_ATOM + ZeroOrMore(BOOLOP + MARKER_EXPR) + +MARKER = stringStart + MARKER_EXPR + stringEnd + + +def _coerce_parse_result(results): + if isinstance(results, ParseResults): + return [_coerce_parse_result(i) for i in results] + else: + return results + + +def _format_marker(marker, first=True): + assert isinstance(marker, (list, tuple, string_types)) + + # Sometimes we have a structure like [[...]] which is a single item list + # where the single item is itself it's own list. In that case we want skip + # the rest of this function so that we don't get extraneous () on the + # outside. + if (isinstance(marker, list) and len(marker) == 1 and + isinstance(marker[0], (list, tuple))): + return _format_marker(marker[0]) + + if isinstance(marker, list): + inner = (_format_marker(m, first=False) for m in marker) + if first: + return " ".join(inner) + else: + return "(" + " ".join(inner) + ")" + elif isinstance(marker, tuple): + return " ".join([m.serialize() for m in marker]) + else: + return marker + + +_operators = { + "in": lambda lhs, rhs: lhs in rhs, + "not in": lambda lhs, rhs: lhs not in rhs, + "<": operator.lt, + "<=": operator.le, + "==": operator.eq, + "!=": operator.ne, + ">=": operator.ge, + ">": operator.gt, +} + + +def _eval_op(lhs, op, rhs): + try: + spec = Specifier("".join([op.serialize(), rhs])) + except InvalidSpecifier: + pass + else: + return spec.contains(lhs) + + oper = _operators.get(op.serialize()) + if oper is None: + raise UndefinedComparison( + "Undefined {0!r} on {1!r} and {2!r}.".format(op, lhs, rhs) + ) + + return oper(lhs, rhs) + + +_undefined = object() + + +def _get_env(environment, name): + value = environment.get(name, _undefined) + + if value is _undefined: + raise UndefinedEnvironmentName( + "{0!r} does not exist in evaluation environment.".format(name) + ) + + return value + + +def _evaluate_markers(markers, environment): + groups = [[]] + + for marker in markers: + assert isinstance(marker, (list, tuple, string_types)) + + if isinstance(marker, list): + groups[-1].append(_evaluate_markers(marker, environment)) + elif isinstance(marker, tuple): + lhs, op, rhs = marker + + if isinstance(lhs, Variable): + lhs_value = _get_env(environment, lhs.value) + rhs_value = rhs.value + else: + lhs_value = lhs.value + rhs_value = _get_env(environment, rhs.value) + + groups[-1].append(_eval_op(lhs_value, op, rhs_value)) + else: + assert marker in ["and", "or"] + if marker == "or": + groups.append([]) + + return any(all(item) for item in groups) + + +def format_full_version(info): + version = '{0.major}.{0.minor}.{0.micro}'.format(info) + kind = info.releaselevel + if kind != 'final': + version += kind[0] + str(info.serial) + return version + + +def default_environment(): + if hasattr(sys, 'implementation'): + iver = format_full_version(sys.implementation.version) + implementation_name = sys.implementation.name + else: + iver = '0' + implementation_name = '' + + return { + "implementation_name": implementation_name, + "implementation_version": iver, + "os_name": os.name, + "platform_machine": platform.machine(), + "platform_release": platform.release(), + "platform_system": platform.system(), + "platform_version": platform.version(), + "python_full_version": platform.python_version(), + "platform_python_implementation": platform.python_implementation(), + "python_version": platform.python_version()[:3], + "sys_platform": sys.platform, + } + + +class Marker(object): + + def __init__(self, marker): + try: + self._markers = _coerce_parse_result(MARKER.parseString(marker)) + except ParseException as e: + err_str = "Invalid marker: {0!r}, parse error at {1!r}".format( + marker, marker[e.loc:e.loc + 8]) + raise InvalidMarker(err_str) + + def __str__(self): + return _format_marker(self._markers) + + def __repr__(self): + return "<Marker({0!r})>".format(str(self)) + + def evaluate(self, environment=None): + """Evaluate a marker. + + Return the boolean from evaluating the given marker against the + environment. environment is an optional argument to override all or + part of the determined environment. + + The environment is determined from the current Python process. + """ + current_environment = default_environment() + if environment is not None: + current_environment.update(environment) + + return _evaluate_markers(self._markers, current_environment) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/requirements.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/requirements.py new file mode 100644 index 0000000..5b49341 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/requirements.py @@ -0,0 +1,127 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import string +import re + +from setuptools.extern.pyparsing import stringStart, stringEnd, originalTextFor, ParseException +from setuptools.extern.pyparsing import ZeroOrMore, Word, Optional, Regex, Combine +from setuptools.extern.pyparsing import Literal as L # noqa +from setuptools.extern.six.moves.urllib import parse as urlparse + +from .markers import MARKER_EXPR, Marker +from .specifiers import LegacySpecifier, Specifier, SpecifierSet + + +class InvalidRequirement(ValueError): + """ + An invalid requirement was found, users should refer to PEP 508. + """ + + +ALPHANUM = Word(string.ascii_letters + string.digits) + +LBRACKET = L("[").suppress() +RBRACKET = L("]").suppress() +LPAREN = L("(").suppress() +RPAREN = L(")").suppress() +COMMA = L(",").suppress() +SEMICOLON = L(";").suppress() +AT = L("@").suppress() + +PUNCTUATION = Word("-_.") +IDENTIFIER_END = ALPHANUM | (ZeroOrMore(PUNCTUATION) + ALPHANUM) +IDENTIFIER = Combine(ALPHANUM + ZeroOrMore(IDENTIFIER_END)) + +NAME = IDENTIFIER("name") +EXTRA = IDENTIFIER + +URI = Regex(r'[^ ]+')("url") +URL = (AT + URI) + +EXTRAS_LIST = EXTRA + ZeroOrMore(COMMA + EXTRA) +EXTRAS = (LBRACKET + Optional(EXTRAS_LIST) + RBRACKET)("extras") + +VERSION_PEP440 = Regex(Specifier._regex_str, re.VERBOSE | re.IGNORECASE) +VERSION_LEGACY = Regex(LegacySpecifier._regex_str, re.VERBOSE | re.IGNORECASE) + +VERSION_ONE = VERSION_PEP440 ^ VERSION_LEGACY +VERSION_MANY = Combine(VERSION_ONE + ZeroOrMore(COMMA + VERSION_ONE), + joinString=",", adjacent=False)("_raw_spec") +_VERSION_SPEC = Optional(((LPAREN + VERSION_MANY + RPAREN) | VERSION_MANY)) +_VERSION_SPEC.setParseAction(lambda s, l, t: t._raw_spec or '') + +VERSION_SPEC = originalTextFor(_VERSION_SPEC)("specifier") +VERSION_SPEC.setParseAction(lambda s, l, t: t[1]) + +MARKER_EXPR = originalTextFor(MARKER_EXPR())("marker") +MARKER_EXPR.setParseAction( + lambda s, l, t: Marker(s[t._original_start:t._original_end]) +) +MARKER_SEPERATOR = SEMICOLON +MARKER = MARKER_SEPERATOR + MARKER_EXPR + +VERSION_AND_MARKER = VERSION_SPEC + Optional(MARKER) +URL_AND_MARKER = URL + Optional(MARKER) + +NAMED_REQUIREMENT = \ + NAME + Optional(EXTRAS) + (URL_AND_MARKER | VERSION_AND_MARKER) + +REQUIREMENT = stringStart + NAMED_REQUIREMENT + stringEnd + + +class Requirement(object): + """Parse a requirement. + + Parse a given requirement string into its parts, such as name, specifier, + URL, and extras. Raises InvalidRequirement on a badly-formed requirement + string. + """ + + # TODO: Can we test whether something is contained within a requirement? + # If so how do we do that? Do we need to test against the _name_ of + # the thing as well as the version? What about the markers? + # TODO: Can we normalize the name and extra name? + + def __init__(self, requirement_string): + try: + req = REQUIREMENT.parseString(requirement_string) + except ParseException as e: + raise InvalidRequirement( + "Invalid requirement, parse error at \"{0!r}\"".format( + requirement_string[e.loc:e.loc + 8])) + + self.name = req.name + if req.url: + parsed_url = urlparse.urlparse(req.url) + if not (parsed_url.scheme and parsed_url.netloc) or ( + not parsed_url.scheme and not parsed_url.netloc): + raise InvalidRequirement("Invalid URL given") + self.url = req.url + else: + self.url = None + self.extras = set(req.extras.asList() if req.extras else []) + self.specifier = SpecifierSet(req.specifier) + self.marker = req.marker if req.marker else None + + def __str__(self): + parts = [self.name] + + if self.extras: + parts.append("[{0}]".format(",".join(sorted(self.extras)))) + + if self.specifier: + parts.append(str(self.specifier)) + + if self.url: + parts.append("@ {0}".format(self.url)) + + if self.marker: + parts.append("; {0}".format(self.marker)) + + return "".join(parts) + + def __repr__(self): + return "<Requirement({0!r})>".format(str(self)) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/specifiers.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/specifiers.py new file mode 100644 index 0000000..7f5a76c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/specifiers.py @@ -0,0 +1,774 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import abc +import functools +import itertools +import re + +from ._compat import string_types, with_metaclass +from .version import Version, LegacyVersion, parse + + +class InvalidSpecifier(ValueError): + """ + An invalid specifier was found, users should refer to PEP 440. + """ + + +class BaseSpecifier(with_metaclass(abc.ABCMeta, object)): + + @abc.abstractmethod + def __str__(self): + """ + Returns the str representation of this Specifier like object. This + should be representative of the Specifier itself. + """ + + @abc.abstractmethod + def __hash__(self): + """ + Returns a hash value for this Specifier like object. + """ + + @abc.abstractmethod + def __eq__(self, other): + """ + Returns a boolean representing whether or not the two Specifier like + objects are equal. + """ + + @abc.abstractmethod + def __ne__(self, other): + """ + Returns a boolean representing whether or not the two Specifier like + objects are not equal. + """ + + @abc.abstractproperty + def prereleases(self): + """ + Returns whether or not pre-releases as a whole are allowed by this + specifier. + """ + + @prereleases.setter + def prereleases(self, value): + """ + Sets whether or not pre-releases as a whole are allowed by this + specifier. + """ + + @abc.abstractmethod + def contains(self, item, prereleases=None): + """ + Determines if the given item is contained within this specifier. + """ + + @abc.abstractmethod + def filter(self, iterable, prereleases=None): + """ + Takes an iterable of items and filters them so that only items which + are contained within this specifier are allowed in it. + """ + + +class _IndividualSpecifier(BaseSpecifier): + + _operators = {} + + def __init__(self, spec="", prereleases=None): + match = self._regex.search(spec) + if not match: + raise InvalidSpecifier("Invalid specifier: '{0}'".format(spec)) + + self._spec = ( + match.group("operator").strip(), + match.group("version").strip(), + ) + + # Store whether or not this Specifier should accept prereleases + self._prereleases = prereleases + + def __repr__(self): + pre = ( + ", prereleases={0!r}".format(self.prereleases) + if self._prereleases is not None + else "" + ) + + return "<{0}({1!r}{2})>".format( + self.__class__.__name__, + str(self), + pre, + ) + + def __str__(self): + return "{0}{1}".format(*self._spec) + + def __hash__(self): + return hash(self._spec) + + def __eq__(self, other): + if isinstance(other, string_types): + try: + other = self.__class__(other) + except InvalidSpecifier: + return NotImplemented + elif not isinstance(other, self.__class__): + return NotImplemented + + return self._spec == other._spec + + def __ne__(self, other): + if isinstance(other, string_types): + try: + other = self.__class__(other) + except InvalidSpecifier: + return NotImplemented + elif not isinstance(other, self.__class__): + return NotImplemented + + return self._spec != other._spec + + def _get_operator(self, op): + return getattr(self, "_compare_{0}".format(self._operators[op])) + + def _coerce_version(self, version): + if not isinstance(version, (LegacyVersion, Version)): + version = parse(version) + return version + + @property + def operator(self): + return self._spec[0] + + @property + def version(self): + return self._spec[1] + + @property + def prereleases(self): + return self._prereleases + + @prereleases.setter + def prereleases(self, value): + self._prereleases = value + + def __contains__(self, item): + return self.contains(item) + + def contains(self, item, prereleases=None): + # Determine if prereleases are to be allowed or not. + if prereleases is None: + prereleases = self.prereleases + + # Normalize item to a Version or LegacyVersion, this allows us to have + # a shortcut for ``"2.0" in Specifier(">=2") + item = self._coerce_version(item) + + # Determine if we should be supporting prereleases in this specifier + # or not, if we do not support prereleases than we can short circuit + # logic if this version is a prereleases. + if item.is_prerelease and not prereleases: + return False + + # Actually do the comparison to determine if this item is contained + # within this Specifier or not. + return self._get_operator(self.operator)(item, self.version) + + def filter(self, iterable, prereleases=None): + yielded = False + found_prereleases = [] + + kw = {"prereleases": prereleases if prereleases is not None else True} + + # Attempt to iterate over all the values in the iterable and if any of + # them match, yield them. + for version in iterable: + parsed_version = self._coerce_version(version) + + if self.contains(parsed_version, **kw): + # If our version is a prerelease, and we were not set to allow + # prereleases, then we'll store it for later incase nothing + # else matches this specifier. + if (parsed_version.is_prerelease and not + (prereleases or self.prereleases)): + found_prereleases.append(version) + # Either this is not a prerelease, or we should have been + # accepting prereleases from the begining. + else: + yielded = True + yield version + + # Now that we've iterated over everything, determine if we've yielded + # any values, and if we have not and we have any prereleases stored up + # then we will go ahead and yield the prereleases. + if not yielded and found_prereleases: + for version in found_prereleases: + yield version + + +class LegacySpecifier(_IndividualSpecifier): + + _regex_str = ( + r""" + (?P<operator>(==|!=|<=|>=|<|>)) + \s* + (?P<version> + [^,;\s)]* # Since this is a "legacy" specifier, and the version + # string can be just about anything, we match everything + # except for whitespace, a semi-colon for marker support, + # a closing paren since versions can be enclosed in + # them, and a comma since it's a version separator. + ) + """ + ) + + _regex = re.compile( + r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE) + + _operators = { + "==": "equal", + "!=": "not_equal", + "<=": "less_than_equal", + ">=": "greater_than_equal", + "<": "less_than", + ">": "greater_than", + } + + def _coerce_version(self, version): + if not isinstance(version, LegacyVersion): + version = LegacyVersion(str(version)) + return version + + def _compare_equal(self, prospective, spec): + return prospective == self._coerce_version(spec) + + def _compare_not_equal(self, prospective, spec): + return prospective != self._coerce_version(spec) + + def _compare_less_than_equal(self, prospective, spec): + return prospective <= self._coerce_version(spec) + + def _compare_greater_than_equal(self, prospective, spec): + return prospective >= self._coerce_version(spec) + + def _compare_less_than(self, prospective, spec): + return prospective < self._coerce_version(spec) + + def _compare_greater_than(self, prospective, spec): + return prospective > self._coerce_version(spec) + + +def _require_version_compare(fn): + @functools.wraps(fn) + def wrapped(self, prospective, spec): + if not isinstance(prospective, Version): + return False + return fn(self, prospective, spec) + return wrapped + + +class Specifier(_IndividualSpecifier): + + _regex_str = ( + r""" + (?P<operator>(~=|==|!=|<=|>=|<|>|===)) + (?P<version> + (?: + # The identity operators allow for an escape hatch that will + # do an exact string match of the version you wish to install. + # This will not be parsed by PEP 440 and we cannot determine + # any semantic meaning from it. This operator is discouraged + # but included entirely as an escape hatch. + (?<====) # Only match for the identity operator + \s* + [^\s]* # We just match everything, except for whitespace + # since we are only testing for strict identity. + ) + | + (?: + # The (non)equality operators allow for wild card and local + # versions to be specified so we have to define these two + # operators separately to enable that. + (?<===|!=) # Only match for equals and not equals + + \s* + v? + (?:[0-9]+!)? # epoch + [0-9]+(?:\.[0-9]+)* # release + (?: # pre release + [-_\.]? + (a|b|c|rc|alpha|beta|pre|preview) + [-_\.]? + [0-9]* + )? + (?: # post release + (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) + )? + + # You cannot use a wild card and a dev or local version + # together so group them with a | and make them optional. + (?: + (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release + (?:\+[a-z0-9]+(?:[-_\.][a-z0-9]+)*)? # local + | + \.\* # Wild card syntax of .* + )? + ) + | + (?: + # The compatible operator requires at least two digits in the + # release segment. + (?<=~=) # Only match for the compatible operator + + \s* + v? + (?:[0-9]+!)? # epoch + [0-9]+(?:\.[0-9]+)+ # release (We have a + instead of a *) + (?: # pre release + [-_\.]? + (a|b|c|rc|alpha|beta|pre|preview) + [-_\.]? + [0-9]* + )? + (?: # post release + (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) + )? + (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release + ) + | + (?: + # All other operators only allow a sub set of what the + # (non)equality operators do. Specifically they do not allow + # local versions to be specified nor do they allow the prefix + # matching wild cards. + (?<!==|!=|~=) # We have special cases for these + # operators so we want to make sure they + # don't match here. + + \s* + v? + (?:[0-9]+!)? # epoch + [0-9]+(?:\.[0-9]+)* # release + (?: # pre release + [-_\.]? + (a|b|c|rc|alpha|beta|pre|preview) + [-_\.]? + [0-9]* + )? + (?: # post release + (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) + )? + (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release + ) + ) + """ + ) + + _regex = re.compile( + r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE) + + _operators = { + "~=": "compatible", + "==": "equal", + "!=": "not_equal", + "<=": "less_than_equal", + ">=": "greater_than_equal", + "<": "less_than", + ">": "greater_than", + "===": "arbitrary", + } + + @_require_version_compare + def _compare_compatible(self, prospective, spec): + # Compatible releases have an equivalent combination of >= and ==. That + # is that ~=2.2 is equivalent to >=2.2,==2.*. This allows us to + # implement this in terms of the other specifiers instead of + # implementing it ourselves. The only thing we need to do is construct + # the other specifiers. + + # We want everything but the last item in the version, but we want to + # ignore post and dev releases and we want to treat the pre-release as + # it's own separate segment. + prefix = ".".join( + list( + itertools.takewhile( + lambda x: (not x.startswith("post") and not + x.startswith("dev")), + _version_split(spec), + ) + )[:-1] + ) + + # Add the prefix notation to the end of our string + prefix += ".*" + + return (self._get_operator(">=")(prospective, spec) and + self._get_operator("==")(prospective, prefix)) + + @_require_version_compare + def _compare_equal(self, prospective, spec): + # We need special logic to handle prefix matching + if spec.endswith(".*"): + # In the case of prefix matching we want to ignore local segment. + prospective = Version(prospective.public) + # Split the spec out by dots, and pretend that there is an implicit + # dot in between a release segment and a pre-release segment. + spec = _version_split(spec[:-2]) # Remove the trailing .* + + # Split the prospective version out by dots, and pretend that there + # is an implicit dot in between a release segment and a pre-release + # segment. + prospective = _version_split(str(prospective)) + + # Shorten the prospective version to be the same length as the spec + # so that we can determine if the specifier is a prefix of the + # prospective version or not. + prospective = prospective[:len(spec)] + + # Pad out our two sides with zeros so that they both equal the same + # length. + spec, prospective = _pad_version(spec, prospective) + else: + # Convert our spec string into a Version + spec = Version(spec) + + # If the specifier does not have a local segment, then we want to + # act as if the prospective version also does not have a local + # segment. + if not spec.local: + prospective = Version(prospective.public) + + return prospective == spec + + @_require_version_compare + def _compare_not_equal(self, prospective, spec): + return not self._compare_equal(prospective, spec) + + @_require_version_compare + def _compare_less_than_equal(self, prospective, spec): + return prospective <= Version(spec) + + @_require_version_compare + def _compare_greater_than_equal(self, prospective, spec): + return prospective >= Version(spec) + + @_require_version_compare + def _compare_less_than(self, prospective, spec): + # Convert our spec to a Version instance, since we'll want to work with + # it as a version. + spec = Version(spec) + + # Check to see if the prospective version is less than the spec + # version. If it's not we can short circuit and just return False now + # instead of doing extra unneeded work. + if not prospective < spec: + return False + + # This special case is here so that, unless the specifier itself + # includes is a pre-release version, that we do not accept pre-release + # versions for the version mentioned in the specifier (e.g. <3.1 should + # not match 3.1.dev0, but should match 3.0.dev0). + if not spec.is_prerelease and prospective.is_prerelease: + if Version(prospective.base_version) == Version(spec.base_version): + return False + + # If we've gotten to here, it means that prospective version is both + # less than the spec version *and* it's not a pre-release of the same + # version in the spec. + return True + + @_require_version_compare + def _compare_greater_than(self, prospective, spec): + # Convert our spec to a Version instance, since we'll want to work with + # it as a version. + spec = Version(spec) + + # Check to see if the prospective version is greater than the spec + # version. If it's not we can short circuit and just return False now + # instead of doing extra unneeded work. + if not prospective > spec: + return False + + # This special case is here so that, unless the specifier itself + # includes is a post-release version, that we do not accept + # post-release versions for the version mentioned in the specifier + # (e.g. >3.1 should not match 3.0.post0, but should match 3.2.post0). + if not spec.is_postrelease and prospective.is_postrelease: + if Version(prospective.base_version) == Version(spec.base_version): + return False + + # Ensure that we do not allow a local version of the version mentioned + # in the specifier, which is techincally greater than, to match. + if prospective.local is not None: + if Version(prospective.base_version) == Version(spec.base_version): + return False + + # If we've gotten to here, it means that prospective version is both + # greater than the spec version *and* it's not a pre-release of the + # same version in the spec. + return True + + def _compare_arbitrary(self, prospective, spec): + return str(prospective).lower() == str(spec).lower() + + @property + def prereleases(self): + # If there is an explicit prereleases set for this, then we'll just + # blindly use that. + if self._prereleases is not None: + return self._prereleases + + # Look at all of our specifiers and determine if they are inclusive + # operators, and if they are if they are including an explicit + # prerelease. + operator, version = self._spec + if operator in ["==", ">=", "<=", "~=", "==="]: + # The == specifier can include a trailing .*, if it does we + # want to remove before parsing. + if operator == "==" and version.endswith(".*"): + version = version[:-2] + + # Parse the version, and if it is a pre-release than this + # specifier allows pre-releases. + if parse(version).is_prerelease: + return True + + return False + + @prereleases.setter + def prereleases(self, value): + self._prereleases = value + + +_prefix_regex = re.compile(r"^([0-9]+)((?:a|b|c|rc)[0-9]+)$") + + +def _version_split(version): + result = [] + for item in version.split("."): + match = _prefix_regex.search(item) + if match: + result.extend(match.groups()) + else: + result.append(item) + return result + + +def _pad_version(left, right): + left_split, right_split = [], [] + + # Get the release segment of our versions + left_split.append(list(itertools.takewhile(lambda x: x.isdigit(), left))) + right_split.append(list(itertools.takewhile(lambda x: x.isdigit(), right))) + + # Get the rest of our versions + left_split.append(left[len(left_split[0]):]) + right_split.append(right[len(right_split[0]):]) + + # Insert our padding + left_split.insert( + 1, + ["0"] * max(0, len(right_split[0]) - len(left_split[0])), + ) + right_split.insert( + 1, + ["0"] * max(0, len(left_split[0]) - len(right_split[0])), + ) + + return ( + list(itertools.chain(*left_split)), + list(itertools.chain(*right_split)), + ) + + +class SpecifierSet(BaseSpecifier): + + def __init__(self, specifiers="", prereleases=None): + # Split on , to break each indidivual specifier into it's own item, and + # strip each item to remove leading/trailing whitespace. + specifiers = [s.strip() for s in specifiers.split(",") if s.strip()] + + # Parsed each individual specifier, attempting first to make it a + # Specifier and falling back to a LegacySpecifier. + parsed = set() + for specifier in specifiers: + try: + parsed.add(Specifier(specifier)) + except InvalidSpecifier: + parsed.add(LegacySpecifier(specifier)) + + # Turn our parsed specifiers into a frozen set and save them for later. + self._specs = frozenset(parsed) + + # Store our prereleases value so we can use it later to determine if + # we accept prereleases or not. + self._prereleases = prereleases + + def __repr__(self): + pre = ( + ", prereleases={0!r}".format(self.prereleases) + if self._prereleases is not None + else "" + ) + + return "<SpecifierSet({0!r}{1})>".format(str(self), pre) + + def __str__(self): + return ",".join(sorted(str(s) for s in self._specs)) + + def __hash__(self): + return hash(self._specs) + + def __and__(self, other): + if isinstance(other, string_types): + other = SpecifierSet(other) + elif not isinstance(other, SpecifierSet): + return NotImplemented + + specifier = SpecifierSet() + specifier._specs = frozenset(self._specs | other._specs) + + if self._prereleases is None and other._prereleases is not None: + specifier._prereleases = other._prereleases + elif self._prereleases is not None and other._prereleases is None: + specifier._prereleases = self._prereleases + elif self._prereleases == other._prereleases: + specifier._prereleases = self._prereleases + else: + raise ValueError( + "Cannot combine SpecifierSets with True and False prerelease " + "overrides." + ) + + return specifier + + def __eq__(self, other): + if isinstance(other, string_types): + other = SpecifierSet(other) + elif isinstance(other, _IndividualSpecifier): + other = SpecifierSet(str(other)) + elif not isinstance(other, SpecifierSet): + return NotImplemented + + return self._specs == other._specs + + def __ne__(self, other): + if isinstance(other, string_types): + other = SpecifierSet(other) + elif isinstance(other, _IndividualSpecifier): + other = SpecifierSet(str(other)) + elif not isinstance(other, SpecifierSet): + return NotImplemented + + return self._specs != other._specs + + def __len__(self): + return len(self._specs) + + def __iter__(self): + return iter(self._specs) + + @property + def prereleases(self): + # If we have been given an explicit prerelease modifier, then we'll + # pass that through here. + if self._prereleases is not None: + return self._prereleases + + # If we don't have any specifiers, and we don't have a forced value, + # then we'll just return None since we don't know if this should have + # pre-releases or not. + if not self._specs: + return None + + # Otherwise we'll see if any of the given specifiers accept + # prereleases, if any of them do we'll return True, otherwise False. + return any(s.prereleases for s in self._specs) + + @prereleases.setter + def prereleases(self, value): + self._prereleases = value + + def __contains__(self, item): + return self.contains(item) + + def contains(self, item, prereleases=None): + # Ensure that our item is a Version or LegacyVersion instance. + if not isinstance(item, (LegacyVersion, Version)): + item = parse(item) + + # Determine if we're forcing a prerelease or not, if we're not forcing + # one for this particular filter call, then we'll use whatever the + # SpecifierSet thinks for whether or not we should support prereleases. + if prereleases is None: + prereleases = self.prereleases + + # We can determine if we're going to allow pre-releases by looking to + # see if any of the underlying items supports them. If none of them do + # and this item is a pre-release then we do not allow it and we can + # short circuit that here. + # Note: This means that 1.0.dev1 would not be contained in something + # like >=1.0.devabc however it would be in >=1.0.debabc,>0.0.dev0 + if not prereleases and item.is_prerelease: + return False + + # We simply dispatch to the underlying specs here to make sure that the + # given version is contained within all of them. + # Note: This use of all() here means that an empty set of specifiers + # will always return True, this is an explicit design decision. + return all( + s.contains(item, prereleases=prereleases) + for s in self._specs + ) + + def filter(self, iterable, prereleases=None): + # Determine if we're forcing a prerelease or not, if we're not forcing + # one for this particular filter call, then we'll use whatever the + # SpecifierSet thinks for whether or not we should support prereleases. + if prereleases is None: + prereleases = self.prereleases + + # If we have any specifiers, then we want to wrap our iterable in the + # filter method for each one, this will act as a logical AND amongst + # each specifier. + if self._specs: + for spec in self._specs: + iterable = spec.filter(iterable, prereleases=bool(prereleases)) + return iterable + # If we do not have any specifiers, then we need to have a rough filter + # which will filter out any pre-releases, unless there are no final + # releases, and which will filter out LegacyVersion in general. + else: + filtered = [] + found_prereleases = [] + + for item in iterable: + # Ensure that we some kind of Version class for this item. + if not isinstance(item, (LegacyVersion, Version)): + parsed_version = parse(item) + else: + parsed_version = item + + # Filter out any item which is parsed as a LegacyVersion + if isinstance(parsed_version, LegacyVersion): + continue + + # Store any item which is a pre-release for later unless we've + # already found a final version or we are accepting prereleases + if parsed_version.is_prerelease and not prereleases: + if not filtered: + found_prereleases.append(item) + else: + filtered.append(item) + + # If we've found no items except for pre-releases, then we'll go + # ahead and use the pre-releases + if not filtered and found_prereleases and prereleases is None: + return found_prereleases + + return filtered diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/utils.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/utils.py new file mode 100644 index 0000000..942387c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/utils.py @@ -0,0 +1,14 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import re + + +_canonicalize_regex = re.compile(r"[-_.]+") + + +def canonicalize_name(name): + # This is taken from PEP 503. + return _canonicalize_regex.sub("-", name).lower() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/version.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/version.py new file mode 100644 index 0000000..83b5ee8 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/packaging/version.py @@ -0,0 +1,393 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. +from __future__ import absolute_import, division, print_function + +import collections +import itertools +import re + +from ._structures import Infinity + + +__all__ = [ + "parse", "Version", "LegacyVersion", "InvalidVersion", "VERSION_PATTERN" +] + + +_Version = collections.namedtuple( + "_Version", + ["epoch", "release", "dev", "pre", "post", "local"], +) + + +def parse(version): + """ + Parse the given version string and return either a :class:`Version` object + or a :class:`LegacyVersion` object depending on if the given version is + a valid PEP 440 version or a legacy version. + """ + try: + return Version(version) + except InvalidVersion: + return LegacyVersion(version) + + +class InvalidVersion(ValueError): + """ + An invalid version was found, users should refer to PEP 440. + """ + + +class _BaseVersion(object): + + def __hash__(self): + return hash(self._key) + + def __lt__(self, other): + return self._compare(other, lambda s, o: s < o) + + def __le__(self, other): + return self._compare(other, lambda s, o: s <= o) + + def __eq__(self, other): + return self._compare(other, lambda s, o: s == o) + + def __ge__(self, other): + return self._compare(other, lambda s, o: s >= o) + + def __gt__(self, other): + return self._compare(other, lambda s, o: s > o) + + def __ne__(self, other): + return self._compare(other, lambda s, o: s != o) + + def _compare(self, other, method): + if not isinstance(other, _BaseVersion): + return NotImplemented + + return method(self._key, other._key) + + +class LegacyVersion(_BaseVersion): + + def __init__(self, version): + self._version = str(version) + self._key = _legacy_cmpkey(self._version) + + def __str__(self): + return self._version + + def __repr__(self): + return "<LegacyVersion({0})>".format(repr(str(self))) + + @property + def public(self): + return self._version + + @property + def base_version(self): + return self._version + + @property + def local(self): + return None + + @property + def is_prerelease(self): + return False + + @property + def is_postrelease(self): + return False + + +_legacy_version_component_re = re.compile( + r"(\d+ | [a-z]+ | \.| -)", re.VERBOSE, +) + +_legacy_version_replacement_map = { + "pre": "c", "preview": "c", "-": "final-", "rc": "c", "dev": "@", +} + + +def _parse_version_parts(s): + for part in _legacy_version_component_re.split(s): + part = _legacy_version_replacement_map.get(part, part) + + if not part or part == ".": + continue + + if part[:1] in "0123456789": + # pad for numeric comparison + yield part.zfill(8) + else: + yield "*" + part + + # ensure that alpha/beta/candidate are before final + yield "*final" + + +def _legacy_cmpkey(version): + # We hardcode an epoch of -1 here. A PEP 440 version can only have a epoch + # greater than or equal to 0. This will effectively put the LegacyVersion, + # which uses the defacto standard originally implemented by setuptools, + # as before all PEP 440 versions. + epoch = -1 + + # This scheme is taken from pkg_resources.parse_version setuptools prior to + # it's adoption of the packaging library. + parts = [] + for part in _parse_version_parts(version.lower()): + if part.startswith("*"): + # remove "-" before a prerelease tag + if part < "*final": + while parts and parts[-1] == "*final-": + parts.pop() + + # remove trailing zeros from each series of numeric parts + while parts and parts[-1] == "00000000": + parts.pop() + + parts.append(part) + parts = tuple(parts) + + return epoch, parts + +# Deliberately not anchored to the start and end of the string, to make it +# easier for 3rd party code to reuse +VERSION_PATTERN = r""" + v? + (?: + (?:(?P<epoch>[0-9]+)!)? # epoch + (?P<release>[0-9]+(?:\.[0-9]+)*) # release segment + (?P<pre> # pre-release + [-_\.]? + (?P<pre_l>(a|b|c|rc|alpha|beta|pre|preview)) + [-_\.]? + (?P<pre_n>[0-9]+)? + )? + (?P<post> # post release + (?:-(?P<post_n1>[0-9]+)) + | + (?: + [-_\.]? + (?P<post_l>post|rev|r) + [-_\.]? + (?P<post_n2>[0-9]+)? + ) + )? + (?P<dev> # dev release + [-_\.]? + (?P<dev_l>dev) + [-_\.]? + (?P<dev_n>[0-9]+)? + )? + ) + (?:\+(?P<local>[a-z0-9]+(?:[-_\.][a-z0-9]+)*))? # local version +""" + + +class Version(_BaseVersion): + + _regex = re.compile( + r"^\s*" + VERSION_PATTERN + r"\s*$", + re.VERBOSE | re.IGNORECASE, + ) + + def __init__(self, version): + # Validate the version and parse it into pieces + match = self._regex.search(version) + if not match: + raise InvalidVersion("Invalid version: '{0}'".format(version)) + + # Store the parsed out pieces of the version + self._version = _Version( + epoch=int(match.group("epoch")) if match.group("epoch") else 0, + release=tuple(int(i) for i in match.group("release").split(".")), + pre=_parse_letter_version( + match.group("pre_l"), + match.group("pre_n"), + ), + post=_parse_letter_version( + match.group("post_l"), + match.group("post_n1") or match.group("post_n2"), + ), + dev=_parse_letter_version( + match.group("dev_l"), + match.group("dev_n"), + ), + local=_parse_local_version(match.group("local")), + ) + + # Generate a key which will be used for sorting + self._key = _cmpkey( + self._version.epoch, + self._version.release, + self._version.pre, + self._version.post, + self._version.dev, + self._version.local, + ) + + def __repr__(self): + return "<Version({0})>".format(repr(str(self))) + + def __str__(self): + parts = [] + + # Epoch + if self._version.epoch != 0: + parts.append("{0}!".format(self._version.epoch)) + + # Release segment + parts.append(".".join(str(x) for x in self._version.release)) + + # Pre-release + if self._version.pre is not None: + parts.append("".join(str(x) for x in self._version.pre)) + + # Post-release + if self._version.post is not None: + parts.append(".post{0}".format(self._version.post[1])) + + # Development release + if self._version.dev is not None: + parts.append(".dev{0}".format(self._version.dev[1])) + + # Local version segment + if self._version.local is not None: + parts.append( + "+{0}".format(".".join(str(x) for x in self._version.local)) + ) + + return "".join(parts) + + @property + def public(self): + return str(self).split("+", 1)[0] + + @property + def base_version(self): + parts = [] + + # Epoch + if self._version.epoch != 0: + parts.append("{0}!".format(self._version.epoch)) + + # Release segment + parts.append(".".join(str(x) for x in self._version.release)) + + return "".join(parts) + + @property + def local(self): + version_string = str(self) + if "+" in version_string: + return version_string.split("+", 1)[1] + + @property + def is_prerelease(self): + return bool(self._version.dev or self._version.pre) + + @property + def is_postrelease(self): + return bool(self._version.post) + + +def _parse_letter_version(letter, number): + if letter: + # We consider there to be an implicit 0 in a pre-release if there is + # not a numeral associated with it. + if number is None: + number = 0 + + # We normalize any letters to their lower case form + letter = letter.lower() + + # We consider some words to be alternate spellings of other words and + # in those cases we want to normalize the spellings to our preferred + # spelling. + if letter == "alpha": + letter = "a" + elif letter == "beta": + letter = "b" + elif letter in ["c", "pre", "preview"]: + letter = "rc" + elif letter in ["rev", "r"]: + letter = "post" + + return letter, int(number) + if not letter and number: + # We assume if we are given a number, but we are not given a letter + # then this is using the implicit post release syntax (e.g. 1.0-1) + letter = "post" + + return letter, int(number) + + +_local_version_seperators = re.compile(r"[\._-]") + + +def _parse_local_version(local): + """ + Takes a string like abc.1.twelve and turns it into ("abc", 1, "twelve"). + """ + if local is not None: + return tuple( + part.lower() if not part.isdigit() else int(part) + for part in _local_version_seperators.split(local) + ) + + +def _cmpkey(epoch, release, pre, post, dev, local): + # When we compare a release version, we want to compare it with all of the + # trailing zeros removed. So we'll use a reverse the list, drop all the now + # leading zeros until we come to something non zero, then take the rest + # re-reverse it back into the correct order and make it a tuple and use + # that for our sorting key. + release = tuple( + reversed(list( + itertools.dropwhile( + lambda x: x == 0, + reversed(release), + ) + )) + ) + + # We need to "trick" the sorting algorithm to put 1.0.dev0 before 1.0a0. + # We'll do this by abusing the pre segment, but we _only_ want to do this + # if there is not a pre or a post segment. If we have one of those then + # the normal sorting rules will handle this case correctly. + if pre is None and post is None and dev is not None: + pre = -Infinity + # Versions without a pre-release (except as noted above) should sort after + # those with one. + elif pre is None: + pre = Infinity + + # Versions without a post segment should sort before those with one. + if post is None: + post = -Infinity + + # Versions without a development segment should sort after those with one. + if dev is None: + dev = Infinity + + if local is None: + # Versions without a local segment should sort before those with one. + local = -Infinity + else: + # Versions with a local segment need that segment parsed to implement + # the sorting rules in PEP440. + # - Alpha numeric segments sort before numeric segments + # - Alpha numeric segments sort lexicographically + # - Numeric segments sort numerically + # - Shorter versions sort before longer versions when the prefixes + # match exactly + local = tuple( + (i, "") if isinstance(i, int) else (-Infinity, i) + for i in local + ) + + return epoch, release, pre, post, dev, local diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/pyparsing.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/pyparsing.py new file mode 100644 index 0000000..cf75e1e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/pyparsing.py @@ -0,0 +1,5742 @@ +# module pyparsing.py +# +# Copyright (c) 2003-2018 Paul T. McGuire +# +# Permission is hereby granted, free of charge, to any person obtaining +# a copy of this software and associated documentation files (the +# "Software"), to deal in the Software without restriction, including +# without limitation the rights to use, copy, modify, merge, publish, +# distribute, sublicense, and/or sell copies of the Software, and to +# permit persons to whom the Software is furnished to do so, subject to +# the following conditions: +# +# The above copyright notice and this permission notice shall be +# included in all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +# + +__doc__ = \ +""" +pyparsing module - Classes and methods to define and execute parsing grammars +============================================================================= + +The pyparsing module is an alternative approach to creating and executing simple grammars, +vs. the traditional lex/yacc approach, or the use of regular expressions. With pyparsing, you +don't need to learn a new syntax for defining grammars or matching expressions - the parsing module +provides a library of classes that you use to construct the grammar directly in Python. + +Here is a program to parse "Hello, World!" (or any greeting of the form +C{"<salutation>, <addressee>!"}), built up using L{Word}, L{Literal}, and L{And} elements +(L{'+'<ParserElement.__add__>} operator gives L{And} expressions, strings are auto-converted to +L{Literal} expressions):: + + from pyparsing import Word, alphas + + # define grammar of a greeting + greet = Word(alphas) + "," + Word(alphas) + "!" + + hello = "Hello, World!" + print (hello, "->", greet.parseString(hello)) + +The program outputs the following:: + + Hello, World! -> ['Hello', ',', 'World', '!'] + +The Python representation of the grammar is quite readable, owing to the self-explanatory +class names, and the use of '+', '|' and '^' operators. + +The L{ParseResults} object returned from L{ParserElement.parseString<ParserElement.parseString>} can be accessed as a nested list, a dictionary, or an +object with named attributes. + +The pyparsing module handles some of the problems that are typically vexing when writing text parsers: + - extra or missing whitespace (the above program will also handle "Hello,World!", "Hello , World !", etc.) + - quoted strings + - embedded comments + + +Getting Started - +----------------- +Visit the classes L{ParserElement} and L{ParseResults} to see the base classes that most other pyparsing +classes inherit from. Use the docstrings for examples of how to: + - construct literal match expressions from L{Literal} and L{CaselessLiteral} classes + - construct character word-group expressions using the L{Word} class + - see how to create repetitive expressions using L{ZeroOrMore} and L{OneOrMore} classes + - use L{'+'<And>}, L{'|'<MatchFirst>}, L{'^'<Or>}, and L{'&'<Each>} operators to combine simple expressions into more complex ones + - associate names with your parsed results using L{ParserElement.setResultsName} + - find some helpful expression short-cuts like L{delimitedList} and L{oneOf} + - find more useful common expressions in the L{pyparsing_common} namespace class +""" + +__version__ = "2.2.1" +__versionTime__ = "18 Sep 2018 00:49 UTC" +__author__ = "Paul McGuire <ptmcg@users.sourceforge.net>" + +import string +from weakref import ref as wkref +import copy +import sys +import warnings +import re +import sre_constants +import collections +import pprint +import traceback +import types +from datetime import datetime + +try: + from _thread import RLock +except ImportError: + from threading import RLock + +try: + # Python 3 + from collections.abc import Iterable + from collections.abc import MutableMapping +except ImportError: + # Python 2.7 + from collections import Iterable + from collections import MutableMapping + +try: + from collections import OrderedDict as _OrderedDict +except ImportError: + try: + from ordereddict import OrderedDict as _OrderedDict + except ImportError: + _OrderedDict = None + +#~ sys.stderr.write( "testing pyparsing module, version %s, %s\n" % (__version__,__versionTime__ ) ) + +__all__ = [ +'And', 'CaselessKeyword', 'CaselessLiteral', 'CharsNotIn', 'Combine', 'Dict', 'Each', 'Empty', +'FollowedBy', 'Forward', 'GoToColumn', 'Group', 'Keyword', 'LineEnd', 'LineStart', 'Literal', +'MatchFirst', 'NoMatch', 'NotAny', 'OneOrMore', 'OnlyOnce', 'Optional', 'Or', +'ParseBaseException', 'ParseElementEnhance', 'ParseException', 'ParseExpression', 'ParseFatalException', +'ParseResults', 'ParseSyntaxException', 'ParserElement', 'QuotedString', 'RecursiveGrammarException', +'Regex', 'SkipTo', 'StringEnd', 'StringStart', 'Suppress', 'Token', 'TokenConverter', +'White', 'Word', 'WordEnd', 'WordStart', 'ZeroOrMore', +'alphanums', 'alphas', 'alphas8bit', 'anyCloseTag', 'anyOpenTag', 'cStyleComment', 'col', +'commaSeparatedList', 'commonHTMLEntity', 'countedArray', 'cppStyleComment', 'dblQuotedString', +'dblSlashComment', 'delimitedList', 'dictOf', 'downcaseTokens', 'empty', 'hexnums', +'htmlComment', 'javaStyleComment', 'line', 'lineEnd', 'lineStart', 'lineno', +'makeHTMLTags', 'makeXMLTags', 'matchOnlyAtCol', 'matchPreviousExpr', 'matchPreviousLiteral', +'nestedExpr', 'nullDebugAction', 'nums', 'oneOf', 'opAssoc', 'operatorPrecedence', 'printables', +'punc8bit', 'pythonStyleComment', 'quotedString', 'removeQuotes', 'replaceHTMLEntity', +'replaceWith', 'restOfLine', 'sglQuotedString', 'srange', 'stringEnd', +'stringStart', 'traceParseAction', 'unicodeString', 'upcaseTokens', 'withAttribute', +'indentedBlock', 'originalTextFor', 'ungroup', 'infixNotation','locatedExpr', 'withClass', +'CloseMatch', 'tokenMap', 'pyparsing_common', +] + +system_version = tuple(sys.version_info)[:3] +PY_3 = system_version[0] == 3 +if PY_3: + _MAX_INT = sys.maxsize + basestring = str + unichr = chr + _ustr = str + + # build list of single arg builtins, that can be used as parse actions + singleArgBuiltins = [sum, len, sorted, reversed, list, tuple, set, any, all, min, max] + +else: + _MAX_INT = sys.maxint + range = xrange + + def _ustr(obj): + """Drop-in replacement for str(obj) that tries to be Unicode friendly. It first tries + str(obj). If that fails with a UnicodeEncodeError, then it tries unicode(obj). It + then < returns the unicode object | encodes it with the default encoding | ... >. + """ + if isinstance(obj,unicode): + return obj + + try: + # If this works, then _ustr(obj) has the same behaviour as str(obj), so + # it won't break any existing code. + return str(obj) + + except UnicodeEncodeError: + # Else encode it + ret = unicode(obj).encode(sys.getdefaultencoding(), 'xmlcharrefreplace') + xmlcharref = Regex(r'&#\d+;') + xmlcharref.setParseAction(lambda t: '\\u' + hex(int(t[0][2:-1]))[2:]) + return xmlcharref.transformString(ret) + + # build list of single arg builtins, tolerant of Python version, that can be used as parse actions + singleArgBuiltins = [] + import __builtin__ + for fname in "sum len sorted reversed list tuple set any all min max".split(): + try: + singleArgBuiltins.append(getattr(__builtin__,fname)) + except AttributeError: + continue + +_generatorType = type((y for y in range(1))) + +def _xml_escape(data): + """Escape &, <, >, ", ', etc. in a string of data.""" + + # ampersand must be replaced first + from_symbols = '&><"\'' + to_symbols = ('&'+s+';' for s in "amp gt lt quot apos".split()) + for from_,to_ in zip(from_symbols, to_symbols): + data = data.replace(from_, to_) + return data + +class _Constants(object): + pass + +alphas = string.ascii_uppercase + string.ascii_lowercase +nums = "0123456789" +hexnums = nums + "ABCDEFabcdef" +alphanums = alphas + nums +_bslash = chr(92) +printables = "".join(c for c in string.printable if c not in string.whitespace) + +class ParseBaseException(Exception): + """base exception class for all parsing runtime exceptions""" + # Performance tuning: we construct a *lot* of these, so keep this + # constructor as small and fast as possible + def __init__( self, pstr, loc=0, msg=None, elem=None ): + self.loc = loc + if msg is None: + self.msg = pstr + self.pstr = "" + else: + self.msg = msg + self.pstr = pstr + self.parserElement = elem + self.args = (pstr, loc, msg) + + @classmethod + def _from_exception(cls, pe): + """ + internal factory method to simplify creating one type of ParseException + from another - avoids having __init__ signature conflicts among subclasses + """ + return cls(pe.pstr, pe.loc, pe.msg, pe.parserElement) + + def __getattr__( self, aname ): + """supported attributes by name are: + - lineno - returns the line number of the exception text + - col - returns the column number of the exception text + - line - returns the line containing the exception text + """ + if( aname == "lineno" ): + return lineno( self.loc, self.pstr ) + elif( aname in ("col", "column") ): + return col( self.loc, self.pstr ) + elif( aname == "line" ): + return line( self.loc, self.pstr ) + else: + raise AttributeError(aname) + + def __str__( self ): + return "%s (at char %d), (line:%d, col:%d)" % \ + ( self.msg, self.loc, self.lineno, self.column ) + def __repr__( self ): + return _ustr(self) + def markInputline( self, markerString = ">!<" ): + """Extracts the exception line from the input string, and marks + the location of the exception with a special symbol. + """ + line_str = self.line + line_column = self.column - 1 + if markerString: + line_str = "".join((line_str[:line_column], + markerString, line_str[line_column:])) + return line_str.strip() + def __dir__(self): + return "lineno col line".split() + dir(type(self)) + +class ParseException(ParseBaseException): + """ + Exception thrown when parse expressions don't match class; + supported attributes by name are: + - lineno - returns the line number of the exception text + - col - returns the column number of the exception text + - line - returns the line containing the exception text + + Example:: + try: + Word(nums).setName("integer").parseString("ABC") + except ParseException as pe: + print(pe) + print("column: {}".format(pe.col)) + + prints:: + Expected integer (at char 0), (line:1, col:1) + column: 1 + """ + pass + +class ParseFatalException(ParseBaseException): + """user-throwable exception thrown when inconsistent parse content + is found; stops all parsing immediately""" + pass + +class ParseSyntaxException(ParseFatalException): + """just like L{ParseFatalException}, but thrown internally when an + L{ErrorStop<And._ErrorStop>} ('-' operator) indicates that parsing is to stop + immediately because an unbacktrackable syntax error has been found""" + pass + +#~ class ReparseException(ParseBaseException): + #~ """Experimental class - parse actions can raise this exception to cause + #~ pyparsing to reparse the input string: + #~ - with a modified input string, and/or + #~ - with a modified start location + #~ Set the values of the ReparseException in the constructor, and raise the + #~ exception in a parse action to cause pyparsing to use the new string/location. + #~ Setting the values as None causes no change to be made. + #~ """ + #~ def __init_( self, newstring, restartLoc ): + #~ self.newParseText = newstring + #~ self.reparseLoc = restartLoc + +class RecursiveGrammarException(Exception): + """exception thrown by L{ParserElement.validate} if the grammar could be improperly recursive""" + def __init__( self, parseElementList ): + self.parseElementTrace = parseElementList + + def __str__( self ): + return "RecursiveGrammarException: %s" % self.parseElementTrace + +class _ParseResultsWithOffset(object): + def __init__(self,p1,p2): + self.tup = (p1,p2) + def __getitem__(self,i): + return self.tup[i] + def __repr__(self): + return repr(self.tup[0]) + def setOffset(self,i): + self.tup = (self.tup[0],i) + +class ParseResults(object): + """ + Structured parse results, to provide multiple means of access to the parsed data: + - as a list (C{len(results)}) + - by list index (C{results[0], results[1]}, etc.) + - by attribute (C{results.<resultsName>} - see L{ParserElement.setResultsName}) + + Example:: + integer = Word(nums) + date_str = (integer.setResultsName("year") + '/' + + integer.setResultsName("month") + '/' + + integer.setResultsName("day")) + # equivalent form: + # date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + # parseString returns a ParseResults object + result = date_str.parseString("1999/12/31") + + def test(s, fn=repr): + print("%s -> %s" % (s, fn(eval(s)))) + test("list(result)") + test("result[0]") + test("result['month']") + test("result.day") + test("'month' in result") + test("'minutes' in result") + test("result.dump()", str) + prints:: + list(result) -> ['1999', '/', '12', '/', '31'] + result[0] -> '1999' + result['month'] -> '12' + result.day -> '31' + 'month' in result -> True + 'minutes' in result -> False + result.dump() -> ['1999', '/', '12', '/', '31'] + - day: 31 + - month: 12 + - year: 1999 + """ + def __new__(cls, toklist=None, name=None, asList=True, modal=True ): + if isinstance(toklist, cls): + return toklist + retobj = object.__new__(cls) + retobj.__doinit = True + return retobj + + # Performance tuning: we construct a *lot* of these, so keep this + # constructor as small and fast as possible + def __init__( self, toklist=None, name=None, asList=True, modal=True, isinstance=isinstance ): + if self.__doinit: + self.__doinit = False + self.__name = None + self.__parent = None + self.__accumNames = {} + self.__asList = asList + self.__modal = modal + if toklist is None: + toklist = [] + if isinstance(toklist, list): + self.__toklist = toklist[:] + elif isinstance(toklist, _generatorType): + self.__toklist = list(toklist) + else: + self.__toklist = [toklist] + self.__tokdict = dict() + + if name is not None and name: + if not modal: + self.__accumNames[name] = 0 + if isinstance(name,int): + name = _ustr(name) # will always return a str, but use _ustr for consistency + self.__name = name + if not (isinstance(toklist, (type(None), basestring, list)) and toklist in (None,'',[])): + if isinstance(toklist,basestring): + toklist = [ toklist ] + if asList: + if isinstance(toklist,ParseResults): + self[name] = _ParseResultsWithOffset(toklist.copy(),0) + else: + self[name] = _ParseResultsWithOffset(ParseResults(toklist[0]),0) + self[name].__name = name + else: + try: + self[name] = toklist[0] + except (KeyError,TypeError,IndexError): + self[name] = toklist + + def __getitem__( self, i ): + if isinstance( i, (int,slice) ): + return self.__toklist[i] + else: + if i not in self.__accumNames: + return self.__tokdict[i][-1][0] + else: + return ParseResults([ v[0] for v in self.__tokdict[i] ]) + + def __setitem__( self, k, v, isinstance=isinstance ): + if isinstance(v,_ParseResultsWithOffset): + self.__tokdict[k] = self.__tokdict.get(k,list()) + [v] + sub = v[0] + elif isinstance(k,(int,slice)): + self.__toklist[k] = v + sub = v + else: + self.__tokdict[k] = self.__tokdict.get(k,list()) + [_ParseResultsWithOffset(v,0)] + sub = v + if isinstance(sub,ParseResults): + sub.__parent = wkref(self) + + def __delitem__( self, i ): + if isinstance(i,(int,slice)): + mylen = len( self.__toklist ) + del self.__toklist[i] + + # convert int to slice + if isinstance(i, int): + if i < 0: + i += mylen + i = slice(i, i+1) + # get removed indices + removed = list(range(*i.indices(mylen))) + removed.reverse() + # fixup indices in token dictionary + for name,occurrences in self.__tokdict.items(): + for j in removed: + for k, (value, position) in enumerate(occurrences): + occurrences[k] = _ParseResultsWithOffset(value, position - (position > j)) + else: + del self.__tokdict[i] + + def __contains__( self, k ): + return k in self.__tokdict + + def __len__( self ): return len( self.__toklist ) + def __bool__(self): return ( not not self.__toklist ) + __nonzero__ = __bool__ + def __iter__( self ): return iter( self.__toklist ) + def __reversed__( self ): return iter( self.__toklist[::-1] ) + def _iterkeys( self ): + if hasattr(self.__tokdict, "iterkeys"): + return self.__tokdict.iterkeys() + else: + return iter(self.__tokdict) + + def _itervalues( self ): + return (self[k] for k in self._iterkeys()) + + def _iteritems( self ): + return ((k, self[k]) for k in self._iterkeys()) + + if PY_3: + keys = _iterkeys + """Returns an iterator of all named result keys (Python 3.x only).""" + + values = _itervalues + """Returns an iterator of all named result values (Python 3.x only).""" + + items = _iteritems + """Returns an iterator of all named result key-value tuples (Python 3.x only).""" + + else: + iterkeys = _iterkeys + """Returns an iterator of all named result keys (Python 2.x only).""" + + itervalues = _itervalues + """Returns an iterator of all named result values (Python 2.x only).""" + + iteritems = _iteritems + """Returns an iterator of all named result key-value tuples (Python 2.x only).""" + + def keys( self ): + """Returns all named result keys (as a list in Python 2.x, as an iterator in Python 3.x).""" + return list(self.iterkeys()) + + def values( self ): + """Returns all named result values (as a list in Python 2.x, as an iterator in Python 3.x).""" + return list(self.itervalues()) + + def items( self ): + """Returns all named result key-values (as a list of tuples in Python 2.x, as an iterator in Python 3.x).""" + return list(self.iteritems()) + + def haskeys( self ): + """Since keys() returns an iterator, this method is helpful in bypassing + code that looks for the existence of any defined results names.""" + return bool(self.__tokdict) + + def pop( self, *args, **kwargs): + """ + Removes and returns item at specified index (default=C{last}). + Supports both C{list} and C{dict} semantics for C{pop()}. If passed no + argument or an integer argument, it will use C{list} semantics + and pop tokens from the list of parsed tokens. If passed a + non-integer argument (most likely a string), it will use C{dict} + semantics and pop the corresponding value from any defined + results names. A second default return value argument is + supported, just as in C{dict.pop()}. + + Example:: + def remove_first(tokens): + tokens.pop(0) + print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321'] + print(OneOrMore(Word(nums)).addParseAction(remove_first).parseString("0 123 321")) # -> ['123', '321'] + + label = Word(alphas) + patt = label("LABEL") + OneOrMore(Word(nums)) + print(patt.parseString("AAB 123 321").dump()) + + # Use pop() in a parse action to remove named result (note that corresponding value is not + # removed from list form of results) + def remove_LABEL(tokens): + tokens.pop("LABEL") + return tokens + patt.addParseAction(remove_LABEL) + print(patt.parseString("AAB 123 321").dump()) + prints:: + ['AAB', '123', '321'] + - LABEL: AAB + + ['AAB', '123', '321'] + """ + if not args: + args = [-1] + for k,v in kwargs.items(): + if k == 'default': + args = (args[0], v) + else: + raise TypeError("pop() got an unexpected keyword argument '%s'" % k) + if (isinstance(args[0], int) or + len(args) == 1 or + args[0] in self): + index = args[0] + ret = self[index] + del self[index] + return ret + else: + defaultvalue = args[1] + return defaultvalue + + def get(self, key, defaultValue=None): + """ + Returns named result matching the given key, or if there is no + such name, then returns the given C{defaultValue} or C{None} if no + C{defaultValue} is specified. + + Similar to C{dict.get()}. + + Example:: + integer = Word(nums) + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + result = date_str.parseString("1999/12/31") + print(result.get("year")) # -> '1999' + print(result.get("hour", "not specified")) # -> 'not specified' + print(result.get("hour")) # -> None + """ + if key in self: + return self[key] + else: + return defaultValue + + def insert( self, index, insStr ): + """ + Inserts new element at location index in the list of parsed tokens. + + Similar to C{list.insert()}. + + Example:: + print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321'] + + # use a parse action to insert the parse location in the front of the parsed results + def insert_locn(locn, tokens): + tokens.insert(0, locn) + print(OneOrMore(Word(nums)).addParseAction(insert_locn).parseString("0 123 321")) # -> [0, '0', '123', '321'] + """ + self.__toklist.insert(index, insStr) + # fixup indices in token dictionary + for name,occurrences in self.__tokdict.items(): + for k, (value, position) in enumerate(occurrences): + occurrences[k] = _ParseResultsWithOffset(value, position + (position > index)) + + def append( self, item ): + """ + Add single element to end of ParseResults list of elements. + + Example:: + print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321'] + + # use a parse action to compute the sum of the parsed integers, and add it to the end + def append_sum(tokens): + tokens.append(sum(map(int, tokens))) + print(OneOrMore(Word(nums)).addParseAction(append_sum).parseString("0 123 321")) # -> ['0', '123', '321', 444] + """ + self.__toklist.append(item) + + def extend( self, itemseq ): + """ + Add sequence of elements to end of ParseResults list of elements. + + Example:: + patt = OneOrMore(Word(alphas)) + + # use a parse action to append the reverse of the matched strings, to make a palindrome + def make_palindrome(tokens): + tokens.extend(reversed([t[::-1] for t in tokens])) + return ''.join(tokens) + print(patt.addParseAction(make_palindrome).parseString("lskdj sdlkjf lksd")) # -> 'lskdjsdlkjflksddsklfjkldsjdksl' + """ + if isinstance(itemseq, ParseResults): + self += itemseq + else: + self.__toklist.extend(itemseq) + + def clear( self ): + """ + Clear all elements and results names. + """ + del self.__toklist[:] + self.__tokdict.clear() + + def __getattr__( self, name ): + try: + return self[name] + except KeyError: + return "" + + if name in self.__tokdict: + if name not in self.__accumNames: + return self.__tokdict[name][-1][0] + else: + return ParseResults([ v[0] for v in self.__tokdict[name] ]) + else: + return "" + + def __add__( self, other ): + ret = self.copy() + ret += other + return ret + + def __iadd__( self, other ): + if other.__tokdict: + offset = len(self.__toklist) + addoffset = lambda a: offset if a<0 else a+offset + otheritems = other.__tokdict.items() + otherdictitems = [(k, _ParseResultsWithOffset(v[0],addoffset(v[1])) ) + for (k,vlist) in otheritems for v in vlist] + for k,v in otherdictitems: + self[k] = v + if isinstance(v[0],ParseResults): + v[0].__parent = wkref(self) + + self.__toklist += other.__toklist + self.__accumNames.update( other.__accumNames ) + return self + + def __radd__(self, other): + if isinstance(other,int) and other == 0: + # useful for merging many ParseResults using sum() builtin + return self.copy() + else: + # this may raise a TypeError - so be it + return other + self + + def __repr__( self ): + return "(%s, %s)" % ( repr( self.__toklist ), repr( self.__tokdict ) ) + + def __str__( self ): + return '[' + ', '.join(_ustr(i) if isinstance(i, ParseResults) else repr(i) for i in self.__toklist) + ']' + + def _asStringList( self, sep='' ): + out = [] + for item in self.__toklist: + if out and sep: + out.append(sep) + if isinstance( item, ParseResults ): + out += item._asStringList() + else: + out.append( _ustr(item) ) + return out + + def asList( self ): + """ + Returns the parse results as a nested list of matching tokens, all converted to strings. + + Example:: + patt = OneOrMore(Word(alphas)) + result = patt.parseString("sldkj lsdkj sldkj") + # even though the result prints in string-like form, it is actually a pyparsing ParseResults + print(type(result), result) # -> <class 'pyparsing.ParseResults'> ['sldkj', 'lsdkj', 'sldkj'] + + # Use asList() to create an actual list + result_list = result.asList() + print(type(result_list), result_list) # -> <class 'list'> ['sldkj', 'lsdkj', 'sldkj'] + """ + return [res.asList() if isinstance(res,ParseResults) else res for res in self.__toklist] + + def asDict( self ): + """ + Returns the named parse results as a nested dictionary. + + Example:: + integer = Word(nums) + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + result = date_str.parseString('12/31/1999') + print(type(result), repr(result)) # -> <class 'pyparsing.ParseResults'> (['12', '/', '31', '/', '1999'], {'day': [('1999', 4)], 'year': [('12', 0)], 'month': [('31', 2)]}) + + result_dict = result.asDict() + print(type(result_dict), repr(result_dict)) # -> <class 'dict'> {'day': '1999', 'year': '12', 'month': '31'} + + # even though a ParseResults supports dict-like access, sometime you just need to have a dict + import json + print(json.dumps(result)) # -> Exception: TypeError: ... is not JSON serializable + print(json.dumps(result.asDict())) # -> {"month": "31", "day": "1999", "year": "12"} + """ + if PY_3: + item_fn = self.items + else: + item_fn = self.iteritems + + def toItem(obj): + if isinstance(obj, ParseResults): + if obj.haskeys(): + return obj.asDict() + else: + return [toItem(v) for v in obj] + else: + return obj + + return dict((k,toItem(v)) for k,v in item_fn()) + + def copy( self ): + """ + Returns a new copy of a C{ParseResults} object. + """ + ret = ParseResults( self.__toklist ) + ret.__tokdict = self.__tokdict.copy() + ret.__parent = self.__parent + ret.__accumNames.update( self.__accumNames ) + ret.__name = self.__name + return ret + + def asXML( self, doctag=None, namedItemsOnly=False, indent="", formatted=True ): + """ + (Deprecated) Returns the parse results as XML. Tags are created for tokens and lists that have defined results names. + """ + nl = "\n" + out = [] + namedItems = dict((v[1],k) for (k,vlist) in self.__tokdict.items() + for v in vlist) + nextLevelIndent = indent + " " + + # collapse out indents if formatting is not desired + if not formatted: + indent = "" + nextLevelIndent = "" + nl = "" + + selfTag = None + if doctag is not None: + selfTag = doctag + else: + if self.__name: + selfTag = self.__name + + if not selfTag: + if namedItemsOnly: + return "" + else: + selfTag = "ITEM" + + out += [ nl, indent, "<", selfTag, ">" ] + + for i,res in enumerate(self.__toklist): + if isinstance(res,ParseResults): + if i in namedItems: + out += [ res.asXML(namedItems[i], + namedItemsOnly and doctag is None, + nextLevelIndent, + formatted)] + else: + out += [ res.asXML(None, + namedItemsOnly and doctag is None, + nextLevelIndent, + formatted)] + else: + # individual token, see if there is a name for it + resTag = None + if i in namedItems: + resTag = namedItems[i] + if not resTag: + if namedItemsOnly: + continue + else: + resTag = "ITEM" + xmlBodyText = _xml_escape(_ustr(res)) + out += [ nl, nextLevelIndent, "<", resTag, ">", + xmlBodyText, + "</", resTag, ">" ] + + out += [ nl, indent, "</", selfTag, ">" ] + return "".join(out) + + def __lookup(self,sub): + for k,vlist in self.__tokdict.items(): + for v,loc in vlist: + if sub is v: + return k + return None + + def getName(self): + r""" + Returns the results name for this token expression. Useful when several + different expressions might match at a particular location. + + Example:: + integer = Word(nums) + ssn_expr = Regex(r"\d\d\d-\d\d-\d\d\d\d") + house_number_expr = Suppress('#') + Word(nums, alphanums) + user_data = (Group(house_number_expr)("house_number") + | Group(ssn_expr)("ssn") + | Group(integer)("age")) + user_info = OneOrMore(user_data) + + result = user_info.parseString("22 111-22-3333 #221B") + for item in result: + print(item.getName(), ':', item[0]) + prints:: + age : 22 + ssn : 111-22-3333 + house_number : 221B + """ + if self.__name: + return self.__name + elif self.__parent: + par = self.__parent() + if par: + return par.__lookup(self) + else: + return None + elif (len(self) == 1 and + len(self.__tokdict) == 1 and + next(iter(self.__tokdict.values()))[0][1] in (0,-1)): + return next(iter(self.__tokdict.keys())) + else: + return None + + def dump(self, indent='', depth=0, full=True): + """ + Diagnostic method for listing out the contents of a C{ParseResults}. + Accepts an optional C{indent} argument so that this string can be embedded + in a nested display of other data. + + Example:: + integer = Word(nums) + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + result = date_str.parseString('12/31/1999') + print(result.dump()) + prints:: + ['12', '/', '31', '/', '1999'] + - day: 1999 + - month: 31 + - year: 12 + """ + out = [] + NL = '\n' + out.append( indent+_ustr(self.asList()) ) + if full: + if self.haskeys(): + items = sorted((str(k), v) for k,v in self.items()) + for k,v in items: + if out: + out.append(NL) + out.append( "%s%s- %s: " % (indent,(' '*depth), k) ) + if isinstance(v,ParseResults): + if v: + out.append( v.dump(indent,depth+1) ) + else: + out.append(_ustr(v)) + else: + out.append(repr(v)) + elif any(isinstance(vv,ParseResults) for vv in self): + v = self + for i,vv in enumerate(v): + if isinstance(vv,ParseResults): + out.append("\n%s%s[%d]:\n%s%s%s" % (indent,(' '*(depth)),i,indent,(' '*(depth+1)),vv.dump(indent,depth+1) )) + else: + out.append("\n%s%s[%d]:\n%s%s%s" % (indent,(' '*(depth)),i,indent,(' '*(depth+1)),_ustr(vv))) + + return "".join(out) + + def pprint(self, *args, **kwargs): + """ + Pretty-printer for parsed results as a list, using the C{pprint} module. + Accepts additional positional or keyword args as defined for the + C{pprint.pprint} method. (U{http://docs.python.org/3/library/pprint.html#pprint.pprint}) + + Example:: + ident = Word(alphas, alphanums) + num = Word(nums) + func = Forward() + term = ident | num | Group('(' + func + ')') + func <<= ident + Group(Optional(delimitedList(term))) + result = func.parseString("fna a,b,(fnb c,d,200),100") + result.pprint(width=40) + prints:: + ['fna', + ['a', + 'b', + ['(', 'fnb', ['c', 'd', '200'], ')'], + '100']] + """ + pprint.pprint(self.asList(), *args, **kwargs) + + # add support for pickle protocol + def __getstate__(self): + return ( self.__toklist, + ( self.__tokdict.copy(), + self.__parent is not None and self.__parent() or None, + self.__accumNames, + self.__name ) ) + + def __setstate__(self,state): + self.__toklist = state[0] + (self.__tokdict, + par, + inAccumNames, + self.__name) = state[1] + self.__accumNames = {} + self.__accumNames.update(inAccumNames) + if par is not None: + self.__parent = wkref(par) + else: + self.__parent = None + + def __getnewargs__(self): + return self.__toklist, self.__name, self.__asList, self.__modal + + def __dir__(self): + return (dir(type(self)) + list(self.keys())) + +MutableMapping.register(ParseResults) + +def col (loc,strg): + """Returns current column within a string, counting newlines as line separators. + The first column is number 1. + + Note: the default parsing behavior is to expand tabs in the input string + before starting the parsing process. See L{I{ParserElement.parseString}<ParserElement.parseString>} for more information + on parsing strings containing C{<TAB>}s, and suggested methods to maintain a + consistent view of the parsed string, the parse location, and line and column + positions within the parsed string. + """ + s = strg + return 1 if 0<loc<len(s) and s[loc-1] == '\n' else loc - s.rfind("\n", 0, loc) + +def lineno(loc,strg): + """Returns current line number within a string, counting newlines as line separators. + The first line is number 1. + + Note: the default parsing behavior is to expand tabs in the input string + before starting the parsing process. See L{I{ParserElement.parseString}<ParserElement.parseString>} for more information + on parsing strings containing C{<TAB>}s, and suggested methods to maintain a + consistent view of the parsed string, the parse location, and line and column + positions within the parsed string. + """ + return strg.count("\n",0,loc) + 1 + +def line( loc, strg ): + """Returns the line of text containing loc within a string, counting newlines as line separators. + """ + lastCR = strg.rfind("\n", 0, loc) + nextCR = strg.find("\n", loc) + if nextCR >= 0: + return strg[lastCR+1:nextCR] + else: + return strg[lastCR+1:] + +def _defaultStartDebugAction( instring, loc, expr ): + print (("Match " + _ustr(expr) + " at loc " + _ustr(loc) + "(%d,%d)" % ( lineno(loc,instring), col(loc,instring) ))) + +def _defaultSuccessDebugAction( instring, startloc, endloc, expr, toks ): + print ("Matched " + _ustr(expr) + " -> " + str(toks.asList())) + +def _defaultExceptionDebugAction( instring, loc, expr, exc ): + print ("Exception raised:" + _ustr(exc)) + +def nullDebugAction(*args): + """'Do-nothing' debug action, to suppress debugging output during parsing.""" + pass + +# Only works on Python 3.x - nonlocal is toxic to Python 2 installs +#~ 'decorator to trim function calls to match the arity of the target' +#~ def _trim_arity(func, maxargs=3): + #~ if func in singleArgBuiltins: + #~ return lambda s,l,t: func(t) + #~ limit = 0 + #~ foundArity = False + #~ def wrapper(*args): + #~ nonlocal limit,foundArity + #~ while 1: + #~ try: + #~ ret = func(*args[limit:]) + #~ foundArity = True + #~ return ret + #~ except TypeError: + #~ if limit == maxargs or foundArity: + #~ raise + #~ limit += 1 + #~ continue + #~ return wrapper + +# this version is Python 2.x-3.x cross-compatible +'decorator to trim function calls to match the arity of the target' +def _trim_arity(func, maxargs=2): + if func in singleArgBuiltins: + return lambda s,l,t: func(t) + limit = [0] + foundArity = [False] + + # traceback return data structure changed in Py3.5 - normalize back to plain tuples + if system_version[:2] >= (3,5): + def extract_stack(limit=0): + # special handling for Python 3.5.0 - extra deep call stack by 1 + offset = -3 if system_version == (3,5,0) else -2 + frame_summary = traceback.extract_stack(limit=-offset+limit-1)[offset] + return [frame_summary[:2]] + def extract_tb(tb, limit=0): + frames = traceback.extract_tb(tb, limit=limit) + frame_summary = frames[-1] + return [frame_summary[:2]] + else: + extract_stack = traceback.extract_stack + extract_tb = traceback.extract_tb + + # synthesize what would be returned by traceback.extract_stack at the call to + # user's parse action 'func', so that we don't incur call penalty at parse time + + LINE_DIFF = 6 + # IF ANY CODE CHANGES, EVEN JUST COMMENTS OR BLANK LINES, BETWEEN THE NEXT LINE AND + # THE CALL TO FUNC INSIDE WRAPPER, LINE_DIFF MUST BE MODIFIED!!!! + this_line = extract_stack(limit=2)[-1] + pa_call_line_synth = (this_line[0], this_line[1]+LINE_DIFF) + + def wrapper(*args): + while 1: + try: + ret = func(*args[limit[0]:]) + foundArity[0] = True + return ret + except TypeError: + # re-raise TypeErrors if they did not come from our arity testing + if foundArity[0]: + raise + else: + try: + tb = sys.exc_info()[-1] + if not extract_tb(tb, limit=2)[-1][:2] == pa_call_line_synth: + raise + finally: + del tb + + if limit[0] <= maxargs: + limit[0] += 1 + continue + raise + + # copy func name to wrapper for sensible debug output + func_name = "<parse action>" + try: + func_name = getattr(func, '__name__', + getattr(func, '__class__').__name__) + except Exception: + func_name = str(func) + wrapper.__name__ = func_name + + return wrapper + +class ParserElement(object): + """Abstract base level parser element class.""" + DEFAULT_WHITE_CHARS = " \n\t\r" + verbose_stacktrace = False + + @staticmethod + def setDefaultWhitespaceChars( chars ): + r""" + Overrides the default whitespace chars + + Example:: + # default whitespace chars are space, <TAB> and newline + OneOrMore(Word(alphas)).parseString("abc def\nghi jkl") # -> ['abc', 'def', 'ghi', 'jkl'] + + # change to just treat newline as significant + ParserElement.setDefaultWhitespaceChars(" \t") + OneOrMore(Word(alphas)).parseString("abc def\nghi jkl") # -> ['abc', 'def'] + """ + ParserElement.DEFAULT_WHITE_CHARS = chars + + @staticmethod + def inlineLiteralsUsing(cls): + """ + Set class to be used for inclusion of string literals into a parser. + + Example:: + # default literal class used is Literal + integer = Word(nums) + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + date_str.parseString("1999/12/31") # -> ['1999', '/', '12', '/', '31'] + + + # change to Suppress + ParserElement.inlineLiteralsUsing(Suppress) + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + + date_str.parseString("1999/12/31") # -> ['1999', '12', '31'] + """ + ParserElement._literalStringClass = cls + + def __init__( self, savelist=False ): + self.parseAction = list() + self.failAction = None + #~ self.name = "<unknown>" # don't define self.name, let subclasses try/except upcall + self.strRepr = None + self.resultsName = None + self.saveAsList = savelist + self.skipWhitespace = True + self.whiteChars = ParserElement.DEFAULT_WHITE_CHARS + self.copyDefaultWhiteChars = True + self.mayReturnEmpty = False # used when checking for left-recursion + self.keepTabs = False + self.ignoreExprs = list() + self.debug = False + self.streamlined = False + self.mayIndexError = True # used to optimize exception handling for subclasses that don't advance parse index + self.errmsg = "" + self.modalResults = True # used to mark results names as modal (report only last) or cumulative (list all) + self.debugActions = ( None, None, None ) #custom debug actions + self.re = None + self.callPreparse = True # used to avoid redundant calls to preParse + self.callDuringTry = False + + def copy( self ): + """ + Make a copy of this C{ParserElement}. Useful for defining different parse actions + for the same parsing pattern, using copies of the original parse element. + + Example:: + integer = Word(nums).setParseAction(lambda toks: int(toks[0])) + integerK = integer.copy().addParseAction(lambda toks: toks[0]*1024) + Suppress("K") + integerM = integer.copy().addParseAction(lambda toks: toks[0]*1024*1024) + Suppress("M") + + print(OneOrMore(integerK | integerM | integer).parseString("5K 100 640K 256M")) + prints:: + [5120, 100, 655360, 268435456] + Equivalent form of C{expr.copy()} is just C{expr()}:: + integerM = integer().addParseAction(lambda toks: toks[0]*1024*1024) + Suppress("M") + """ + cpy = copy.copy( self ) + cpy.parseAction = self.parseAction[:] + cpy.ignoreExprs = self.ignoreExprs[:] + if self.copyDefaultWhiteChars: + cpy.whiteChars = ParserElement.DEFAULT_WHITE_CHARS + return cpy + + def setName( self, name ): + """ + Define name for this expression, makes debugging and exception messages clearer. + + Example:: + Word(nums).parseString("ABC") # -> Exception: Expected W:(0123...) (at char 0), (line:1, col:1) + Word(nums).setName("integer").parseString("ABC") # -> Exception: Expected integer (at char 0), (line:1, col:1) + """ + self.name = name + self.errmsg = "Expected " + self.name + if hasattr(self,"exception"): + self.exception.msg = self.errmsg + return self + + def setResultsName( self, name, listAllMatches=False ): + """ + Define name for referencing matching tokens as a nested attribute + of the returned parse results. + NOTE: this returns a *copy* of the original C{ParserElement} object; + this is so that the client can define a basic element, such as an + integer, and reference it in multiple places with different names. + + You can also set results names using the abbreviated syntax, + C{expr("name")} in place of C{expr.setResultsName("name")} - + see L{I{__call__}<__call__>}. + + Example:: + date_str = (integer.setResultsName("year") + '/' + + integer.setResultsName("month") + '/' + + integer.setResultsName("day")) + + # equivalent form: + date_str = integer("year") + '/' + integer("month") + '/' + integer("day") + """ + newself = self.copy() + if name.endswith("*"): + name = name[:-1] + listAllMatches=True + newself.resultsName = name + newself.modalResults = not listAllMatches + return newself + + def setBreak(self,breakFlag = True): + """Method to invoke the Python pdb debugger when this element is + about to be parsed. Set C{breakFlag} to True to enable, False to + disable. + """ + if breakFlag: + _parseMethod = self._parse + def breaker(instring, loc, doActions=True, callPreParse=True): + import pdb + pdb.set_trace() + return _parseMethod( instring, loc, doActions, callPreParse ) + breaker._originalParseMethod = _parseMethod + self._parse = breaker + else: + if hasattr(self._parse,"_originalParseMethod"): + self._parse = self._parse._originalParseMethod + return self + + def setParseAction( self, *fns, **kwargs ): + """ + Define one or more actions to perform when successfully matching parse element definition. + Parse action fn is a callable method with 0-3 arguments, called as C{fn(s,loc,toks)}, + C{fn(loc,toks)}, C{fn(toks)}, or just C{fn()}, where: + - s = the original string being parsed (see note below) + - loc = the location of the matching substring + - toks = a list of the matched tokens, packaged as a C{L{ParseResults}} object + If the functions in fns modify the tokens, they can return them as the return + value from fn, and the modified list of tokens will replace the original. + Otherwise, fn does not need to return any value. + + Optional keyword arguments: + - callDuringTry = (default=C{False}) indicate if parse action should be run during lookaheads and alternate testing + + Note: the default parsing behavior is to expand tabs in the input string + before starting the parsing process. See L{I{parseString}<parseString>} for more information + on parsing strings containing C{<TAB>}s, and suggested methods to maintain a + consistent view of the parsed string, the parse location, and line and column + positions within the parsed string. + + Example:: + integer = Word(nums) + date_str = integer + '/' + integer + '/' + integer + + date_str.parseString("1999/12/31") # -> ['1999', '/', '12', '/', '31'] + + # use parse action to convert to ints at parse time + integer = Word(nums).setParseAction(lambda toks: int(toks[0])) + date_str = integer + '/' + integer + '/' + integer + + # note that integer fields are now ints, not strings + date_str.parseString("1999/12/31") # -> [1999, '/', 12, '/', 31] + """ + self.parseAction = list(map(_trim_arity, list(fns))) + self.callDuringTry = kwargs.get("callDuringTry", False) + return self + + def addParseAction( self, *fns, **kwargs ): + """ + Add one or more parse actions to expression's list of parse actions. See L{I{setParseAction}<setParseAction>}. + + See examples in L{I{copy}<copy>}. + """ + self.parseAction += list(map(_trim_arity, list(fns))) + self.callDuringTry = self.callDuringTry or kwargs.get("callDuringTry", False) + return self + + def addCondition(self, *fns, **kwargs): + """Add a boolean predicate function to expression's list of parse actions. See + L{I{setParseAction}<setParseAction>} for function call signatures. Unlike C{setParseAction}, + functions passed to C{addCondition} need to return boolean success/fail of the condition. + + Optional keyword arguments: + - message = define a custom message to be used in the raised exception + - fatal = if True, will raise ParseFatalException to stop parsing immediately; otherwise will raise ParseException + + Example:: + integer = Word(nums).setParseAction(lambda toks: int(toks[0])) + year_int = integer.copy() + year_int.addCondition(lambda toks: toks[0] >= 2000, message="Only support years 2000 and later") + date_str = year_int + '/' + integer + '/' + integer + + result = date_str.parseString("1999/12/31") # -> Exception: Only support years 2000 and later (at char 0), (line:1, col:1) + """ + msg = kwargs.get("message", "failed user-defined condition") + exc_type = ParseFatalException if kwargs.get("fatal", False) else ParseException + for fn in fns: + def pa(s,l,t): + if not bool(_trim_arity(fn)(s,l,t)): + raise exc_type(s,l,msg) + self.parseAction.append(pa) + self.callDuringTry = self.callDuringTry or kwargs.get("callDuringTry", False) + return self + + def setFailAction( self, fn ): + """Define action to perform if parsing fails at this expression. + Fail acton fn is a callable function that takes the arguments + C{fn(s,loc,expr,err)} where: + - s = string being parsed + - loc = location where expression match was attempted and failed + - expr = the parse expression that failed + - err = the exception thrown + The function returns no value. It may throw C{L{ParseFatalException}} + if it is desired to stop parsing immediately.""" + self.failAction = fn + return self + + def _skipIgnorables( self, instring, loc ): + exprsFound = True + while exprsFound: + exprsFound = False + for e in self.ignoreExprs: + try: + while 1: + loc,dummy = e._parse( instring, loc ) + exprsFound = True + except ParseException: + pass + return loc + + def preParse( self, instring, loc ): + if self.ignoreExprs: + loc = self._skipIgnorables( instring, loc ) + + if self.skipWhitespace: + wt = self.whiteChars + instrlen = len(instring) + while loc < instrlen and instring[loc] in wt: + loc += 1 + + return loc + + def parseImpl( self, instring, loc, doActions=True ): + return loc, [] + + def postParse( self, instring, loc, tokenlist ): + return tokenlist + + #~ @profile + def _parseNoCache( self, instring, loc, doActions=True, callPreParse=True ): + debugging = ( self.debug ) #and doActions ) + + if debugging or self.failAction: + #~ print ("Match",self,"at loc",loc,"(%d,%d)" % ( lineno(loc,instring), col(loc,instring) )) + if (self.debugActions[0] ): + self.debugActions[0]( instring, loc, self ) + if callPreParse and self.callPreparse: + preloc = self.preParse( instring, loc ) + else: + preloc = loc + tokensStart = preloc + try: + try: + loc,tokens = self.parseImpl( instring, preloc, doActions ) + except IndexError: + raise ParseException( instring, len(instring), self.errmsg, self ) + except ParseBaseException as err: + #~ print ("Exception raised:", err) + if self.debugActions[2]: + self.debugActions[2]( instring, tokensStart, self, err ) + if self.failAction: + self.failAction( instring, tokensStart, self, err ) + raise + else: + if callPreParse and self.callPreparse: + preloc = self.preParse( instring, loc ) + else: + preloc = loc + tokensStart = preloc + if self.mayIndexError or preloc >= len(instring): + try: + loc,tokens = self.parseImpl( instring, preloc, doActions ) + except IndexError: + raise ParseException( instring, len(instring), self.errmsg, self ) + else: + loc,tokens = self.parseImpl( instring, preloc, doActions ) + + tokens = self.postParse( instring, loc, tokens ) + + retTokens = ParseResults( tokens, self.resultsName, asList=self.saveAsList, modal=self.modalResults ) + if self.parseAction and (doActions or self.callDuringTry): + if debugging: + try: + for fn in self.parseAction: + tokens = fn( instring, tokensStart, retTokens ) + if tokens is not None: + retTokens = ParseResults( tokens, + self.resultsName, + asList=self.saveAsList and isinstance(tokens,(ParseResults,list)), + modal=self.modalResults ) + except ParseBaseException as err: + #~ print "Exception raised in user parse action:", err + if (self.debugActions[2] ): + self.debugActions[2]( instring, tokensStart, self, err ) + raise + else: + for fn in self.parseAction: + tokens = fn( instring, tokensStart, retTokens ) + if tokens is not None: + retTokens = ParseResults( tokens, + self.resultsName, + asList=self.saveAsList and isinstance(tokens,(ParseResults,list)), + modal=self.modalResults ) + if debugging: + #~ print ("Matched",self,"->",retTokens.asList()) + if (self.debugActions[1] ): + self.debugActions[1]( instring, tokensStart, loc, self, retTokens ) + + return loc, retTokens + + def tryParse( self, instring, loc ): + try: + return self._parse( instring, loc, doActions=False )[0] + except ParseFatalException: + raise ParseException( instring, loc, self.errmsg, self) + + def canParseNext(self, instring, loc): + try: + self.tryParse(instring, loc) + except (ParseException, IndexError): + return False + else: + return True + + class _UnboundedCache(object): + def __init__(self): + cache = {} + self.not_in_cache = not_in_cache = object() + + def get(self, key): + return cache.get(key, not_in_cache) + + def set(self, key, value): + cache[key] = value + + def clear(self): + cache.clear() + + def cache_len(self): + return len(cache) + + self.get = types.MethodType(get, self) + self.set = types.MethodType(set, self) + self.clear = types.MethodType(clear, self) + self.__len__ = types.MethodType(cache_len, self) + + if _OrderedDict is not None: + class _FifoCache(object): + def __init__(self, size): + self.not_in_cache = not_in_cache = object() + + cache = _OrderedDict() + + def get(self, key): + return cache.get(key, not_in_cache) + + def set(self, key, value): + cache[key] = value + while len(cache) > size: + try: + cache.popitem(False) + except KeyError: + pass + + def clear(self): + cache.clear() + + def cache_len(self): + return len(cache) + + self.get = types.MethodType(get, self) + self.set = types.MethodType(set, self) + self.clear = types.MethodType(clear, self) + self.__len__ = types.MethodType(cache_len, self) + + else: + class _FifoCache(object): + def __init__(self, size): + self.not_in_cache = not_in_cache = object() + + cache = {} + key_fifo = collections.deque([], size) + + def get(self, key): + return cache.get(key, not_in_cache) + + def set(self, key, value): + cache[key] = value + while len(key_fifo) > size: + cache.pop(key_fifo.popleft(), None) + key_fifo.append(key) + + def clear(self): + cache.clear() + key_fifo.clear() + + def cache_len(self): + return len(cache) + + self.get = types.MethodType(get, self) + self.set = types.MethodType(set, self) + self.clear = types.MethodType(clear, self) + self.__len__ = types.MethodType(cache_len, self) + + # argument cache for optimizing repeated calls when backtracking through recursive expressions + packrat_cache = {} # this is set later by enabledPackrat(); this is here so that resetCache() doesn't fail + packrat_cache_lock = RLock() + packrat_cache_stats = [0, 0] + + # this method gets repeatedly called during backtracking with the same arguments - + # we can cache these arguments and save ourselves the trouble of re-parsing the contained expression + def _parseCache( self, instring, loc, doActions=True, callPreParse=True ): + HIT, MISS = 0, 1 + lookup = (self, instring, loc, callPreParse, doActions) + with ParserElement.packrat_cache_lock: + cache = ParserElement.packrat_cache + value = cache.get(lookup) + if value is cache.not_in_cache: + ParserElement.packrat_cache_stats[MISS] += 1 + try: + value = self._parseNoCache(instring, loc, doActions, callPreParse) + except ParseBaseException as pe: + # cache a copy of the exception, without the traceback + cache.set(lookup, pe.__class__(*pe.args)) + raise + else: + cache.set(lookup, (value[0], value[1].copy())) + return value + else: + ParserElement.packrat_cache_stats[HIT] += 1 + if isinstance(value, Exception): + raise value + return (value[0], value[1].copy()) + + _parse = _parseNoCache + + @staticmethod + def resetCache(): + ParserElement.packrat_cache.clear() + ParserElement.packrat_cache_stats[:] = [0] * len(ParserElement.packrat_cache_stats) + + _packratEnabled = False + @staticmethod + def enablePackrat(cache_size_limit=128): + """Enables "packrat" parsing, which adds memoizing to the parsing logic. + Repeated parse attempts at the same string location (which happens + often in many complex grammars) can immediately return a cached value, + instead of re-executing parsing/validating code. Memoizing is done of + both valid results and parsing exceptions. + + Parameters: + - cache_size_limit - (default=C{128}) - if an integer value is provided + will limit the size of the packrat cache; if None is passed, then + the cache size will be unbounded; if 0 is passed, the cache will + be effectively disabled. + + This speedup may break existing programs that use parse actions that + have side-effects. For this reason, packrat parsing is disabled when + you first import pyparsing. To activate the packrat feature, your + program must call the class method C{ParserElement.enablePackrat()}. If + your program uses C{psyco} to "compile as you go", you must call + C{enablePackrat} before calling C{psyco.full()}. If you do not do this, + Python will crash. For best results, call C{enablePackrat()} immediately + after importing pyparsing. + + Example:: + import pyparsing + pyparsing.ParserElement.enablePackrat() + """ + if not ParserElement._packratEnabled: + ParserElement._packratEnabled = True + if cache_size_limit is None: + ParserElement.packrat_cache = ParserElement._UnboundedCache() + else: + ParserElement.packrat_cache = ParserElement._FifoCache(cache_size_limit) + ParserElement._parse = ParserElement._parseCache + + def parseString( self, instring, parseAll=False ): + """ + Execute the parse expression with the given string. + This is the main interface to the client code, once the complete + expression has been built. + + If you want the grammar to require that the entire input string be + successfully parsed, then set C{parseAll} to True (equivalent to ending + the grammar with C{L{StringEnd()}}). + + Note: C{parseString} implicitly calls C{expandtabs()} on the input string, + in order to report proper column numbers in parse actions. + If the input string contains tabs and + the grammar uses parse actions that use the C{loc} argument to index into the + string being parsed, you can ensure you have a consistent view of the input + string by: + - calling C{parseWithTabs} on your grammar before calling C{parseString} + (see L{I{parseWithTabs}<parseWithTabs>}) + - define your parse action using the full C{(s,loc,toks)} signature, and + reference the input string using the parse action's C{s} argument + - explictly expand the tabs in your input string before calling + C{parseString} + + Example:: + Word('a').parseString('aaaaabaaa') # -> ['aaaaa'] + Word('a').parseString('aaaaabaaa', parseAll=True) # -> Exception: Expected end of text + """ + ParserElement.resetCache() + if not self.streamlined: + self.streamline() + #~ self.saveAsList = True + for e in self.ignoreExprs: + e.streamline() + if not self.keepTabs: + instring = instring.expandtabs() + try: + loc, tokens = self._parse( instring, 0 ) + if parseAll: + loc = self.preParse( instring, loc ) + se = Empty() + StringEnd() + se._parse( instring, loc ) + except ParseBaseException as exc: + if ParserElement.verbose_stacktrace: + raise + else: + # catch and re-raise exception from here, clears out pyparsing internal stack trace + raise exc + else: + return tokens + + def scanString( self, instring, maxMatches=_MAX_INT, overlap=False ): + """ + Scan the input string for expression matches. Each match will return the + matching tokens, start location, and end location. May be called with optional + C{maxMatches} argument, to clip scanning after 'n' matches are found. If + C{overlap} is specified, then overlapping matches will be reported. + + Note that the start and end locations are reported relative to the string + being parsed. See L{I{parseString}<parseString>} for more information on parsing + strings with embedded tabs. + + Example:: + source = "sldjf123lsdjjkf345sldkjf879lkjsfd987" + print(source) + for tokens,start,end in Word(alphas).scanString(source): + print(' '*start + '^'*(end-start)) + print(' '*start + tokens[0]) + + prints:: + + sldjf123lsdjjkf345sldkjf879lkjsfd987 + ^^^^^ + sldjf + ^^^^^^^ + lsdjjkf + ^^^^^^ + sldkjf + ^^^^^^ + lkjsfd + """ + if not self.streamlined: + self.streamline() + for e in self.ignoreExprs: + e.streamline() + + if not self.keepTabs: + instring = _ustr(instring).expandtabs() + instrlen = len(instring) + loc = 0 + preparseFn = self.preParse + parseFn = self._parse + ParserElement.resetCache() + matches = 0 + try: + while loc <= instrlen and matches < maxMatches: + try: + preloc = preparseFn( instring, loc ) + nextLoc,tokens = parseFn( instring, preloc, callPreParse=False ) + except ParseException: + loc = preloc+1 + else: + if nextLoc > loc: + matches += 1 + yield tokens, preloc, nextLoc + if overlap: + nextloc = preparseFn( instring, loc ) + if nextloc > loc: + loc = nextLoc + else: + loc += 1 + else: + loc = nextLoc + else: + loc = preloc+1 + except ParseBaseException as exc: + if ParserElement.verbose_stacktrace: + raise + else: + # catch and re-raise exception from here, clears out pyparsing internal stack trace + raise exc + + def transformString( self, instring ): + """ + Extension to C{L{scanString}}, to modify matching text with modified tokens that may + be returned from a parse action. To use C{transformString}, define a grammar and + attach a parse action to it that modifies the returned token list. + Invoking C{transformString()} on a target string will then scan for matches, + and replace the matched text patterns according to the logic in the parse + action. C{transformString()} returns the resulting transformed string. + + Example:: + wd = Word(alphas) + wd.setParseAction(lambda toks: toks[0].title()) + + print(wd.transformString("now is the winter of our discontent made glorious summer by this sun of york.")) + Prints:: + Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York. + """ + out = [] + lastE = 0 + # force preservation of <TAB>s, to minimize unwanted transformation of string, and to + # keep string locs straight between transformString and scanString + self.keepTabs = True + try: + for t,s,e in self.scanString( instring ): + out.append( instring[lastE:s] ) + if t: + if isinstance(t,ParseResults): + out += t.asList() + elif isinstance(t,list): + out += t + else: + out.append(t) + lastE = e + out.append(instring[lastE:]) + out = [o for o in out if o] + return "".join(map(_ustr,_flatten(out))) + except ParseBaseException as exc: + if ParserElement.verbose_stacktrace: + raise + else: + # catch and re-raise exception from here, clears out pyparsing internal stack trace + raise exc + + def searchString( self, instring, maxMatches=_MAX_INT ): + """ + Another extension to C{L{scanString}}, simplifying the access to the tokens found + to match the given parse expression. May be called with optional + C{maxMatches} argument, to clip searching after 'n' matches are found. + + Example:: + # a capitalized word starts with an uppercase letter, followed by zero or more lowercase letters + cap_word = Word(alphas.upper(), alphas.lower()) + + print(cap_word.searchString("More than Iron, more than Lead, more than Gold I need Electricity")) + + # the sum() builtin can be used to merge results into a single ParseResults object + print(sum(cap_word.searchString("More than Iron, more than Lead, more than Gold I need Electricity"))) + prints:: + [['More'], ['Iron'], ['Lead'], ['Gold'], ['I'], ['Electricity']] + ['More', 'Iron', 'Lead', 'Gold', 'I', 'Electricity'] + """ + try: + return ParseResults([ t for t,s,e in self.scanString( instring, maxMatches ) ]) + except ParseBaseException as exc: + if ParserElement.verbose_stacktrace: + raise + else: + # catch and re-raise exception from here, clears out pyparsing internal stack trace + raise exc + + def split(self, instring, maxsplit=_MAX_INT, includeSeparators=False): + """ + Generator method to split a string using the given expression as a separator. + May be called with optional C{maxsplit} argument, to limit the number of splits; + and the optional C{includeSeparators} argument (default=C{False}), if the separating + matching text should be included in the split results. + + Example:: + punc = oneOf(list(".,;:/-!?")) + print(list(punc.split("This, this?, this sentence, is badly punctuated!"))) + prints:: + ['This', ' this', '', ' this sentence', ' is badly punctuated', ''] + """ + splits = 0 + last = 0 + for t,s,e in self.scanString(instring, maxMatches=maxsplit): + yield instring[last:s] + if includeSeparators: + yield t[0] + last = e + yield instring[last:] + + def __add__(self, other ): + """ + Implementation of + operator - returns C{L{And}}. Adding strings to a ParserElement + converts them to L{Literal}s by default. + + Example:: + greet = Word(alphas) + "," + Word(alphas) + "!" + hello = "Hello, World!" + print (hello, "->", greet.parseString(hello)) + Prints:: + Hello, World! -> ['Hello', ',', 'World', '!'] + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return And( [ self, other ] ) + + def __radd__(self, other ): + """ + Implementation of + operator when left operand is not a C{L{ParserElement}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return other + self + + def __sub__(self, other): + """ + Implementation of - operator, returns C{L{And}} with error stop + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return self + And._ErrorStop() + other + + def __rsub__(self, other ): + """ + Implementation of - operator when left operand is not a C{L{ParserElement}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return other - self + + def __mul__(self,other): + """ + Implementation of * operator, allows use of C{expr * 3} in place of + C{expr + expr + expr}. Expressions may also me multiplied by a 2-integer + tuple, similar to C{{min,max}} multipliers in regular expressions. Tuples + may also include C{None} as in: + - C{expr*(n,None)} or C{expr*(n,)} is equivalent + to C{expr*n + L{ZeroOrMore}(expr)} + (read as "at least n instances of C{expr}") + - C{expr*(None,n)} is equivalent to C{expr*(0,n)} + (read as "0 to n instances of C{expr}") + - C{expr*(None,None)} is equivalent to C{L{ZeroOrMore}(expr)} + - C{expr*(1,None)} is equivalent to C{L{OneOrMore}(expr)} + + Note that C{expr*(None,n)} does not raise an exception if + more than n exprs exist in the input stream; that is, + C{expr*(None,n)} does not enforce a maximum number of expr + occurrences. If this behavior is desired, then write + C{expr*(None,n) + ~expr} + """ + if isinstance(other,int): + minElements, optElements = other,0 + elif isinstance(other,tuple): + other = (other + (None, None))[:2] + if other[0] is None: + other = (0, other[1]) + if isinstance(other[0],int) and other[1] is None: + if other[0] == 0: + return ZeroOrMore(self) + if other[0] == 1: + return OneOrMore(self) + else: + return self*other[0] + ZeroOrMore(self) + elif isinstance(other[0],int) and isinstance(other[1],int): + minElements, optElements = other + optElements -= minElements + else: + raise TypeError("cannot multiply 'ParserElement' and ('%s','%s') objects", type(other[0]),type(other[1])) + else: + raise TypeError("cannot multiply 'ParserElement' and '%s' objects", type(other)) + + if minElements < 0: + raise ValueError("cannot multiply ParserElement by negative value") + if optElements < 0: + raise ValueError("second tuple value must be greater or equal to first tuple value") + if minElements == optElements == 0: + raise ValueError("cannot multiply ParserElement by 0 or (0,0)") + + if (optElements): + def makeOptionalList(n): + if n>1: + return Optional(self + makeOptionalList(n-1)) + else: + return Optional(self) + if minElements: + if minElements == 1: + ret = self + makeOptionalList(optElements) + else: + ret = And([self]*minElements) + makeOptionalList(optElements) + else: + ret = makeOptionalList(optElements) + else: + if minElements == 1: + ret = self + else: + ret = And([self]*minElements) + return ret + + def __rmul__(self, other): + return self.__mul__(other) + + def __or__(self, other ): + """ + Implementation of | operator - returns C{L{MatchFirst}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return MatchFirst( [ self, other ] ) + + def __ror__(self, other ): + """ + Implementation of | operator when left operand is not a C{L{ParserElement}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return other | self + + def __xor__(self, other ): + """ + Implementation of ^ operator - returns C{L{Or}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return Or( [ self, other ] ) + + def __rxor__(self, other ): + """ + Implementation of ^ operator when left operand is not a C{L{ParserElement}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return other ^ self + + def __and__(self, other ): + """ + Implementation of & operator - returns C{L{Each}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return Each( [ self, other ] ) + + def __rand__(self, other ): + """ + Implementation of & operator when left operand is not a C{L{ParserElement}} + """ + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + if not isinstance( other, ParserElement ): + warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), + SyntaxWarning, stacklevel=2) + return None + return other & self + + def __invert__( self ): + """ + Implementation of ~ operator - returns C{L{NotAny}} + """ + return NotAny( self ) + + def __call__(self, name=None): + """ + Shortcut for C{L{setResultsName}}, with C{listAllMatches=False}. + + If C{name} is given with a trailing C{'*'} character, then C{listAllMatches} will be + passed as C{True}. + + If C{name} is omitted, same as calling C{L{copy}}. + + Example:: + # these are equivalent + userdata = Word(alphas).setResultsName("name") + Word(nums+"-").setResultsName("socsecno") + userdata = Word(alphas)("name") + Word(nums+"-")("socsecno") + """ + if name is not None: + return self.setResultsName(name) + else: + return self.copy() + + def suppress( self ): + """ + Suppresses the output of this C{ParserElement}; useful to keep punctuation from + cluttering up returned output. + """ + return Suppress( self ) + + def leaveWhitespace( self ): + """ + Disables the skipping of whitespace before matching the characters in the + C{ParserElement}'s defined pattern. This is normally only used internally by + the pyparsing module, but may be needed in some whitespace-sensitive grammars. + """ + self.skipWhitespace = False + return self + + def setWhitespaceChars( self, chars ): + """ + Overrides the default whitespace chars + """ + self.skipWhitespace = True + self.whiteChars = chars + self.copyDefaultWhiteChars = False + return self + + def parseWithTabs( self ): + """ + Overrides default behavior to expand C{<TAB>}s to spaces before parsing the input string. + Must be called before C{parseString} when the input grammar contains elements that + match C{<TAB>} characters. + """ + self.keepTabs = True + return self + + def ignore( self, other ): + """ + Define expression to be ignored (e.g., comments) while doing pattern + matching; may be called repeatedly, to define multiple comment or other + ignorable patterns. + + Example:: + patt = OneOrMore(Word(alphas)) + patt.parseString('ablaj /* comment */ lskjd') # -> ['ablaj'] + + patt.ignore(cStyleComment) + patt.parseString('ablaj /* comment */ lskjd') # -> ['ablaj', 'lskjd'] + """ + if isinstance(other, basestring): + other = Suppress(other) + + if isinstance( other, Suppress ): + if other not in self.ignoreExprs: + self.ignoreExprs.append(other) + else: + self.ignoreExprs.append( Suppress( other.copy() ) ) + return self + + def setDebugActions( self, startAction, successAction, exceptionAction ): + """ + Enable display of debugging messages while doing pattern matching. + """ + self.debugActions = (startAction or _defaultStartDebugAction, + successAction or _defaultSuccessDebugAction, + exceptionAction or _defaultExceptionDebugAction) + self.debug = True + return self + + def setDebug( self, flag=True ): + """ + Enable display of debugging messages while doing pattern matching. + Set C{flag} to True to enable, False to disable. + + Example:: + wd = Word(alphas).setName("alphaword") + integer = Word(nums).setName("numword") + term = wd | integer + + # turn on debugging for wd + wd.setDebug() + + OneOrMore(term).parseString("abc 123 xyz 890") + + prints:: + Match alphaword at loc 0(1,1) + Matched alphaword -> ['abc'] + Match alphaword at loc 3(1,4) + Exception raised:Expected alphaword (at char 4), (line:1, col:5) + Match alphaword at loc 7(1,8) + Matched alphaword -> ['xyz'] + Match alphaword at loc 11(1,12) + Exception raised:Expected alphaword (at char 12), (line:1, col:13) + Match alphaword at loc 15(1,16) + Exception raised:Expected alphaword (at char 15), (line:1, col:16) + + The output shown is that produced by the default debug actions - custom debug actions can be + specified using L{setDebugActions}. Prior to attempting + to match the C{wd} expression, the debugging message C{"Match <exprname> at loc <n>(<line>,<col>)"} + is shown. Then if the parse succeeds, a C{"Matched"} message is shown, or an C{"Exception raised"} + message is shown. Also note the use of L{setName} to assign a human-readable name to the expression, + which makes debugging and exception messages easier to understand - for instance, the default + name created for the C{Word} expression without calling C{setName} is C{"W:(ABCD...)"}. + """ + if flag: + self.setDebugActions( _defaultStartDebugAction, _defaultSuccessDebugAction, _defaultExceptionDebugAction ) + else: + self.debug = False + return self + + def __str__( self ): + return self.name + + def __repr__( self ): + return _ustr(self) + + def streamline( self ): + self.streamlined = True + self.strRepr = None + return self + + def checkRecursion( self, parseElementList ): + pass + + def validate( self, validateTrace=[] ): + """ + Check defined expressions for valid structure, check for infinite recursive definitions. + """ + self.checkRecursion( [] ) + + def parseFile( self, file_or_filename, parseAll=False ): + """ + Execute the parse expression on the given file or filename. + If a filename is specified (instead of a file object), + the entire file is opened, read, and closed before parsing. + """ + try: + file_contents = file_or_filename.read() + except AttributeError: + with open(file_or_filename, "r") as f: + file_contents = f.read() + try: + return self.parseString(file_contents, parseAll) + except ParseBaseException as exc: + if ParserElement.verbose_stacktrace: + raise + else: + # catch and re-raise exception from here, clears out pyparsing internal stack trace + raise exc + + def __eq__(self,other): + if isinstance(other, ParserElement): + return self is other or vars(self) == vars(other) + elif isinstance(other, basestring): + return self.matches(other) + else: + return super(ParserElement,self)==other + + def __ne__(self,other): + return not (self == other) + + def __hash__(self): + return hash(id(self)) + + def __req__(self,other): + return self == other + + def __rne__(self,other): + return not (self == other) + + def matches(self, testString, parseAll=True): + """ + Method for quick testing of a parser against a test string. Good for simple + inline microtests of sub expressions while building up larger parser. + + Parameters: + - testString - to test against this expression for a match + - parseAll - (default=C{True}) - flag to pass to C{L{parseString}} when running tests + + Example:: + expr = Word(nums) + assert expr.matches("100") + """ + try: + self.parseString(_ustr(testString), parseAll=parseAll) + return True + except ParseBaseException: + return False + + def runTests(self, tests, parseAll=True, comment='#', fullDump=True, printResults=True, failureTests=False): + """ + Execute the parse expression on a series of test strings, showing each + test, the parsed results or where the parse failed. Quick and easy way to + run a parse expression against a list of sample strings. + + Parameters: + - tests - a list of separate test strings, or a multiline string of test strings + - parseAll - (default=C{True}) - flag to pass to C{L{parseString}} when running tests + - comment - (default=C{'#'}) - expression for indicating embedded comments in the test + string; pass None to disable comment filtering + - fullDump - (default=C{True}) - dump results as list followed by results names in nested outline; + if False, only dump nested list + - printResults - (default=C{True}) prints test output to stdout + - failureTests - (default=C{False}) indicates if these tests are expected to fail parsing + + Returns: a (success, results) tuple, where success indicates that all tests succeeded + (or failed if C{failureTests} is True), and the results contain a list of lines of each + test's output + + Example:: + number_expr = pyparsing_common.number.copy() + + result = number_expr.runTests(''' + # unsigned integer + 100 + # negative integer + -100 + # float with scientific notation + 6.02e23 + # integer with scientific notation + 1e-12 + ''') + print("Success" if result[0] else "Failed!") + + result = number_expr.runTests(''' + # stray character + 100Z + # missing leading digit before '.' + -.100 + # too many '.' + 3.14.159 + ''', failureTests=True) + print("Success" if result[0] else "Failed!") + prints:: + # unsigned integer + 100 + [100] + + # negative integer + -100 + [-100] + + # float with scientific notation + 6.02e23 + [6.02e+23] + + # integer with scientific notation + 1e-12 + [1e-12] + + Success + + # stray character + 100Z + ^ + FAIL: Expected end of text (at char 3), (line:1, col:4) + + # missing leading digit before '.' + -.100 + ^ + FAIL: Expected {real number with scientific notation | real number | signed integer} (at char 0), (line:1, col:1) + + # too many '.' + 3.14.159 + ^ + FAIL: Expected end of text (at char 4), (line:1, col:5) + + Success + + Each test string must be on a single line. If you want to test a string that spans multiple + lines, create a test like this:: + + expr.runTest(r"this is a test\\n of strings that spans \\n 3 lines") + + (Note that this is a raw string literal, you must include the leading 'r'.) + """ + if isinstance(tests, basestring): + tests = list(map(str.strip, tests.rstrip().splitlines())) + if isinstance(comment, basestring): + comment = Literal(comment) + allResults = [] + comments = [] + success = True + for t in tests: + if comment is not None and comment.matches(t, False) or comments and not t: + comments.append(t) + continue + if not t: + continue + out = ['\n'.join(comments), t] + comments = [] + try: + t = t.replace(r'\n','\n') + result = self.parseString(t, parseAll=parseAll) + out.append(result.dump(full=fullDump)) + success = success and not failureTests + except ParseBaseException as pe: + fatal = "(FATAL)" if isinstance(pe, ParseFatalException) else "" + if '\n' in t: + out.append(line(pe.loc, t)) + out.append(' '*(col(pe.loc,t)-1) + '^' + fatal) + else: + out.append(' '*pe.loc + '^' + fatal) + out.append("FAIL: " + str(pe)) + success = success and failureTests + result = pe + except Exception as exc: + out.append("FAIL-EXCEPTION: " + str(exc)) + success = success and failureTests + result = exc + + if printResults: + if fullDump: + out.append('') + print('\n'.join(out)) + + allResults.append((t, result)) + + return success, allResults + + +class Token(ParserElement): + """ + Abstract C{ParserElement} subclass, for defining atomic matching patterns. + """ + def __init__( self ): + super(Token,self).__init__( savelist=False ) + + +class Empty(Token): + """ + An empty token, will always match. + """ + def __init__( self ): + super(Empty,self).__init__() + self.name = "Empty" + self.mayReturnEmpty = True + self.mayIndexError = False + + +class NoMatch(Token): + """ + A token that will never match. + """ + def __init__( self ): + super(NoMatch,self).__init__() + self.name = "NoMatch" + self.mayReturnEmpty = True + self.mayIndexError = False + self.errmsg = "Unmatchable token" + + def parseImpl( self, instring, loc, doActions=True ): + raise ParseException(instring, loc, self.errmsg, self) + + +class Literal(Token): + """ + Token to exactly match a specified string. + + Example:: + Literal('blah').parseString('blah') # -> ['blah'] + Literal('blah').parseString('blahfooblah') # -> ['blah'] + Literal('blah').parseString('bla') # -> Exception: Expected "blah" + + For case-insensitive matching, use L{CaselessLiteral}. + + For keyword matching (force word break before and after the matched string), + use L{Keyword} or L{CaselessKeyword}. + """ + def __init__( self, matchString ): + super(Literal,self).__init__() + self.match = matchString + self.matchLen = len(matchString) + try: + self.firstMatchChar = matchString[0] + except IndexError: + warnings.warn("null string passed to Literal; use Empty() instead", + SyntaxWarning, stacklevel=2) + self.__class__ = Empty + self.name = '"%s"' % _ustr(self.match) + self.errmsg = "Expected " + self.name + self.mayReturnEmpty = False + self.mayIndexError = False + + # Performance tuning: this routine gets called a *lot* + # if this is a single character match string and the first character matches, + # short-circuit as quickly as possible, and avoid calling startswith + #~ @profile + def parseImpl( self, instring, loc, doActions=True ): + if (instring[loc] == self.firstMatchChar and + (self.matchLen==1 or instring.startswith(self.match,loc)) ): + return loc+self.matchLen, self.match + raise ParseException(instring, loc, self.errmsg, self) +_L = Literal +ParserElement._literalStringClass = Literal + +class Keyword(Token): + """ + Token to exactly match a specified string as a keyword, that is, it must be + immediately followed by a non-keyword character. Compare with C{L{Literal}}: + - C{Literal("if")} will match the leading C{'if'} in C{'ifAndOnlyIf'}. + - C{Keyword("if")} will not; it will only match the leading C{'if'} in C{'if x=1'}, or C{'if(y==2)'} + Accepts two optional constructor arguments in addition to the keyword string: + - C{identChars} is a string of characters that would be valid identifier characters, + defaulting to all alphanumerics + "_" and "$" + - C{caseless} allows case-insensitive matching, default is C{False}. + + Example:: + Keyword("start").parseString("start") # -> ['start'] + Keyword("start").parseString("starting") # -> Exception + + For case-insensitive matching, use L{CaselessKeyword}. + """ + DEFAULT_KEYWORD_CHARS = alphanums+"_$" + + def __init__( self, matchString, identChars=None, caseless=False ): + super(Keyword,self).__init__() + if identChars is None: + identChars = Keyword.DEFAULT_KEYWORD_CHARS + self.match = matchString + self.matchLen = len(matchString) + try: + self.firstMatchChar = matchString[0] + except IndexError: + warnings.warn("null string passed to Keyword; use Empty() instead", + SyntaxWarning, stacklevel=2) + self.name = '"%s"' % self.match + self.errmsg = "Expected " + self.name + self.mayReturnEmpty = False + self.mayIndexError = False + self.caseless = caseless + if caseless: + self.caselessmatch = matchString.upper() + identChars = identChars.upper() + self.identChars = set(identChars) + + def parseImpl( self, instring, loc, doActions=True ): + if self.caseless: + if ( (instring[ loc:loc+self.matchLen ].upper() == self.caselessmatch) and + (loc >= len(instring)-self.matchLen or instring[loc+self.matchLen].upper() not in self.identChars) and + (loc == 0 or instring[loc-1].upper() not in self.identChars) ): + return loc+self.matchLen, self.match + else: + if (instring[loc] == self.firstMatchChar and + (self.matchLen==1 or instring.startswith(self.match,loc)) and + (loc >= len(instring)-self.matchLen or instring[loc+self.matchLen] not in self.identChars) and + (loc == 0 or instring[loc-1] not in self.identChars) ): + return loc+self.matchLen, self.match + raise ParseException(instring, loc, self.errmsg, self) + + def copy(self): + c = super(Keyword,self).copy() + c.identChars = Keyword.DEFAULT_KEYWORD_CHARS + return c + + @staticmethod + def setDefaultKeywordChars( chars ): + """Overrides the default Keyword chars + """ + Keyword.DEFAULT_KEYWORD_CHARS = chars + +class CaselessLiteral(Literal): + """ + Token to match a specified string, ignoring case of letters. + Note: the matched results will always be in the case of the given + match string, NOT the case of the input text. + + Example:: + OneOrMore(CaselessLiteral("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD', 'CMD'] + + (Contrast with example for L{CaselessKeyword}.) + """ + def __init__( self, matchString ): + super(CaselessLiteral,self).__init__( matchString.upper() ) + # Preserve the defining literal. + self.returnString = matchString + self.name = "'%s'" % self.returnString + self.errmsg = "Expected " + self.name + + def parseImpl( self, instring, loc, doActions=True ): + if instring[ loc:loc+self.matchLen ].upper() == self.match: + return loc+self.matchLen, self.returnString + raise ParseException(instring, loc, self.errmsg, self) + +class CaselessKeyword(Keyword): + """ + Caseless version of L{Keyword}. + + Example:: + OneOrMore(CaselessKeyword("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD'] + + (Contrast with example for L{CaselessLiteral}.) + """ + def __init__( self, matchString, identChars=None ): + super(CaselessKeyword,self).__init__( matchString, identChars, caseless=True ) + + def parseImpl( self, instring, loc, doActions=True ): + if ( (instring[ loc:loc+self.matchLen ].upper() == self.caselessmatch) and + (loc >= len(instring)-self.matchLen or instring[loc+self.matchLen].upper() not in self.identChars) ): + return loc+self.matchLen, self.match + raise ParseException(instring, loc, self.errmsg, self) + +class CloseMatch(Token): + """ + A variation on L{Literal} which matches "close" matches, that is, + strings with at most 'n' mismatching characters. C{CloseMatch} takes parameters: + - C{match_string} - string to be matched + - C{maxMismatches} - (C{default=1}) maximum number of mismatches allowed to count as a match + + The results from a successful parse will contain the matched text from the input string and the following named results: + - C{mismatches} - a list of the positions within the match_string where mismatches were found + - C{original} - the original match_string used to compare against the input string + + If C{mismatches} is an empty list, then the match was an exact match. + + Example:: + patt = CloseMatch("ATCATCGAATGGA") + patt.parseString("ATCATCGAAXGGA") # -> (['ATCATCGAAXGGA'], {'mismatches': [[9]], 'original': ['ATCATCGAATGGA']}) + patt.parseString("ATCAXCGAAXGGA") # -> Exception: Expected 'ATCATCGAATGGA' (with up to 1 mismatches) (at char 0), (line:1, col:1) + + # exact match + patt.parseString("ATCATCGAATGGA") # -> (['ATCATCGAATGGA'], {'mismatches': [[]], 'original': ['ATCATCGAATGGA']}) + + # close match allowing up to 2 mismatches + patt = CloseMatch("ATCATCGAATGGA", maxMismatches=2) + patt.parseString("ATCAXCGAAXGGA") # -> (['ATCAXCGAAXGGA'], {'mismatches': [[4, 9]], 'original': ['ATCATCGAATGGA']}) + """ + def __init__(self, match_string, maxMismatches=1): + super(CloseMatch,self).__init__() + self.name = match_string + self.match_string = match_string + self.maxMismatches = maxMismatches + self.errmsg = "Expected %r (with up to %d mismatches)" % (self.match_string, self.maxMismatches) + self.mayIndexError = False + self.mayReturnEmpty = False + + def parseImpl( self, instring, loc, doActions=True ): + start = loc + instrlen = len(instring) + maxloc = start + len(self.match_string) + + if maxloc <= instrlen: + match_string = self.match_string + match_stringloc = 0 + mismatches = [] + maxMismatches = self.maxMismatches + + for match_stringloc,s_m in enumerate(zip(instring[loc:maxloc], self.match_string)): + src,mat = s_m + if src != mat: + mismatches.append(match_stringloc) + if len(mismatches) > maxMismatches: + break + else: + loc = match_stringloc + 1 + results = ParseResults([instring[start:loc]]) + results['original'] = self.match_string + results['mismatches'] = mismatches + return loc, results + + raise ParseException(instring, loc, self.errmsg, self) + + +class Word(Token): + """ + Token for matching words composed of allowed character sets. + Defined with string containing all allowed initial characters, + an optional string containing allowed body characters (if omitted, + defaults to the initial character set), and an optional minimum, + maximum, and/or exact length. The default value for C{min} is 1 (a + minimum value < 1 is not valid); the default values for C{max} and C{exact} + are 0, meaning no maximum or exact length restriction. An optional + C{excludeChars} parameter can list characters that might be found in + the input C{bodyChars} string; useful to define a word of all printables + except for one or two characters, for instance. + + L{srange} is useful for defining custom character set strings for defining + C{Word} expressions, using range notation from regular expression character sets. + + A common mistake is to use C{Word} to match a specific literal string, as in + C{Word("Address")}. Remember that C{Word} uses the string argument to define + I{sets} of matchable characters. This expression would match "Add", "AAA", + "dAred", or any other word made up of the characters 'A', 'd', 'r', 'e', and 's'. + To match an exact literal string, use L{Literal} or L{Keyword}. + + pyparsing includes helper strings for building Words: + - L{alphas} + - L{nums} + - L{alphanums} + - L{hexnums} + - L{alphas8bit} (alphabetic characters in ASCII range 128-255 - accented, tilded, umlauted, etc.) + - L{punc8bit} (non-alphabetic characters in ASCII range 128-255 - currency, symbols, superscripts, diacriticals, etc.) + - L{printables} (any non-whitespace character) + + Example:: + # a word composed of digits + integer = Word(nums) # equivalent to Word("0123456789") or Word(srange("0-9")) + + # a word with a leading capital, and zero or more lowercase + capital_word = Word(alphas.upper(), alphas.lower()) + + # hostnames are alphanumeric, with leading alpha, and '-' + hostname = Word(alphas, alphanums+'-') + + # roman numeral (not a strict parser, accepts invalid mix of characters) + roman = Word("IVXLCDM") + + # any string of non-whitespace characters, except for ',' + csv_value = Word(printables, excludeChars=",") + """ + def __init__( self, initChars, bodyChars=None, min=1, max=0, exact=0, asKeyword=False, excludeChars=None ): + super(Word,self).__init__() + if excludeChars: + initChars = ''.join(c for c in initChars if c not in excludeChars) + if bodyChars: + bodyChars = ''.join(c for c in bodyChars if c not in excludeChars) + self.initCharsOrig = initChars + self.initChars = set(initChars) + if bodyChars : + self.bodyCharsOrig = bodyChars + self.bodyChars = set(bodyChars) + else: + self.bodyCharsOrig = initChars + self.bodyChars = set(initChars) + + self.maxSpecified = max > 0 + + if min < 1: + raise ValueError("cannot specify a minimum length < 1; use Optional(Word()) if zero-length word is permitted") + + self.minLen = min + + if max > 0: + self.maxLen = max + else: + self.maxLen = _MAX_INT + + if exact > 0: + self.maxLen = exact + self.minLen = exact + + self.name = _ustr(self) + self.errmsg = "Expected " + self.name + self.mayIndexError = False + self.asKeyword = asKeyword + + if ' ' not in self.initCharsOrig+self.bodyCharsOrig and (min==1 and max==0 and exact==0): + if self.bodyCharsOrig == self.initCharsOrig: + self.reString = "[%s]+" % _escapeRegexRangeChars(self.initCharsOrig) + elif len(self.initCharsOrig) == 1: + self.reString = "%s[%s]*" % \ + (re.escape(self.initCharsOrig), + _escapeRegexRangeChars(self.bodyCharsOrig),) + else: + self.reString = "[%s][%s]*" % \ + (_escapeRegexRangeChars(self.initCharsOrig), + _escapeRegexRangeChars(self.bodyCharsOrig),) + if self.asKeyword: + self.reString = r"\b"+self.reString+r"\b" + try: + self.re = re.compile( self.reString ) + except Exception: + self.re = None + + def parseImpl( self, instring, loc, doActions=True ): + if self.re: + result = self.re.match(instring,loc) + if not result: + raise ParseException(instring, loc, self.errmsg, self) + + loc = result.end() + return loc, result.group() + + if not(instring[ loc ] in self.initChars): + raise ParseException(instring, loc, self.errmsg, self) + + start = loc + loc += 1 + instrlen = len(instring) + bodychars = self.bodyChars + maxloc = start + self.maxLen + maxloc = min( maxloc, instrlen ) + while loc < maxloc and instring[loc] in bodychars: + loc += 1 + + throwException = False + if loc - start < self.minLen: + throwException = True + if self.maxSpecified and loc < instrlen and instring[loc] in bodychars: + throwException = True + if self.asKeyword: + if (start>0 and instring[start-1] in bodychars) or (loc<instrlen and instring[loc] in bodychars): + throwException = True + + if throwException: + raise ParseException(instring, loc, self.errmsg, self) + + return loc, instring[start:loc] + + def __str__( self ): + try: + return super(Word,self).__str__() + except Exception: + pass + + + if self.strRepr is None: + + def charsAsStr(s): + if len(s)>4: + return s[:4]+"..." + else: + return s + + if ( self.initCharsOrig != self.bodyCharsOrig ): + self.strRepr = "W:(%s,%s)" % ( charsAsStr(self.initCharsOrig), charsAsStr(self.bodyCharsOrig) ) + else: + self.strRepr = "W:(%s)" % charsAsStr(self.initCharsOrig) + + return self.strRepr + + +class Regex(Token): + r""" + Token for matching strings that match a given regular expression. + Defined with string specifying the regular expression in a form recognized by the inbuilt Python re module. + If the given regex contains named groups (defined using C{(?P<name>...)}), these will be preserved as + named parse results. + + Example:: + realnum = Regex(r"[+-]?\d+\.\d*") + date = Regex(r'(?P<year>\d{4})-(?P<month>\d\d?)-(?P<day>\d\d?)') + # ref: http://stackoverflow.com/questions/267399/how-do-you-match-only-valid-roman-numerals-with-a-regular-expression + roman = Regex(r"M{0,4}(CM|CD|D?C{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})") + """ + compiledREtype = type(re.compile("[A-Z]")) + def __init__( self, pattern, flags=0): + """The parameters C{pattern} and C{flags} are passed to the C{re.compile()} function as-is. See the Python C{re} module for an explanation of the acceptable patterns and flags.""" + super(Regex,self).__init__() + + if isinstance(pattern, basestring): + if not pattern: + warnings.warn("null string passed to Regex; use Empty() instead", + SyntaxWarning, stacklevel=2) + + self.pattern = pattern + self.flags = flags + + try: + self.re = re.compile(self.pattern, self.flags) + self.reString = self.pattern + except sre_constants.error: + warnings.warn("invalid pattern (%s) passed to Regex" % pattern, + SyntaxWarning, stacklevel=2) + raise + + elif isinstance(pattern, Regex.compiledREtype): + self.re = pattern + self.pattern = \ + self.reString = str(pattern) + self.flags = flags + + else: + raise ValueError("Regex may only be constructed with a string or a compiled RE object") + + self.name = _ustr(self) + self.errmsg = "Expected " + self.name + self.mayIndexError = False + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + result = self.re.match(instring,loc) + if not result: + raise ParseException(instring, loc, self.errmsg, self) + + loc = result.end() + d = result.groupdict() + ret = ParseResults(result.group()) + if d: + for k in d: + ret[k] = d[k] + return loc,ret + + def __str__( self ): + try: + return super(Regex,self).__str__() + except Exception: + pass + + if self.strRepr is None: + self.strRepr = "Re:(%s)" % repr(self.pattern) + + return self.strRepr + + +class QuotedString(Token): + r""" + Token for matching strings that are delimited by quoting characters. + + Defined with the following parameters: + - quoteChar - string of one or more characters defining the quote delimiting string + - escChar - character to escape quotes, typically backslash (default=C{None}) + - escQuote - special quote sequence to escape an embedded quote string (such as SQL's "" to escape an embedded ") (default=C{None}) + - multiline - boolean indicating whether quotes can span multiple lines (default=C{False}) + - unquoteResults - boolean indicating whether the matched text should be unquoted (default=C{True}) + - endQuoteChar - string of one or more characters defining the end of the quote delimited string (default=C{None} => same as quoteChar) + - convertWhitespaceEscapes - convert escaped whitespace (C{'\t'}, C{'\n'}, etc.) to actual whitespace (default=C{True}) + + Example:: + qs = QuotedString('"') + print(qs.searchString('lsjdf "This is the quote" sldjf')) + complex_qs = QuotedString('{{', endQuoteChar='}}') + print(complex_qs.searchString('lsjdf {{This is the "quote"}} sldjf')) + sql_qs = QuotedString('"', escQuote='""') + print(sql_qs.searchString('lsjdf "This is the quote with ""embedded"" quotes" sldjf')) + prints:: + [['This is the quote']] + [['This is the "quote"']] + [['This is the quote with "embedded" quotes']] + """ + def __init__( self, quoteChar, escChar=None, escQuote=None, multiline=False, unquoteResults=True, endQuoteChar=None, convertWhitespaceEscapes=True): + super(QuotedString,self).__init__() + + # remove white space from quote chars - wont work anyway + quoteChar = quoteChar.strip() + if not quoteChar: + warnings.warn("quoteChar cannot be the empty string",SyntaxWarning,stacklevel=2) + raise SyntaxError() + + if endQuoteChar is None: + endQuoteChar = quoteChar + else: + endQuoteChar = endQuoteChar.strip() + if not endQuoteChar: + warnings.warn("endQuoteChar cannot be the empty string",SyntaxWarning,stacklevel=2) + raise SyntaxError() + + self.quoteChar = quoteChar + self.quoteCharLen = len(quoteChar) + self.firstQuoteChar = quoteChar[0] + self.endQuoteChar = endQuoteChar + self.endQuoteCharLen = len(endQuoteChar) + self.escChar = escChar + self.escQuote = escQuote + self.unquoteResults = unquoteResults + self.convertWhitespaceEscapes = convertWhitespaceEscapes + + if multiline: + self.flags = re.MULTILINE | re.DOTALL + self.pattern = r'%s(?:[^%s%s]' % \ + ( re.escape(self.quoteChar), + _escapeRegexRangeChars(self.endQuoteChar[0]), + (escChar is not None and _escapeRegexRangeChars(escChar) or '') ) + else: + self.flags = 0 + self.pattern = r'%s(?:[^%s\n\r%s]' % \ + ( re.escape(self.quoteChar), + _escapeRegexRangeChars(self.endQuoteChar[0]), + (escChar is not None and _escapeRegexRangeChars(escChar) or '') ) + if len(self.endQuoteChar) > 1: + self.pattern += ( + '|(?:' + ')|(?:'.join("%s[^%s]" % (re.escape(self.endQuoteChar[:i]), + _escapeRegexRangeChars(self.endQuoteChar[i])) + for i in range(len(self.endQuoteChar)-1,0,-1)) + ')' + ) + if escQuote: + self.pattern += (r'|(?:%s)' % re.escape(escQuote)) + if escChar: + self.pattern += (r'|(?:%s.)' % re.escape(escChar)) + self.escCharReplacePattern = re.escape(self.escChar)+"(.)" + self.pattern += (r')*%s' % re.escape(self.endQuoteChar)) + + try: + self.re = re.compile(self.pattern, self.flags) + self.reString = self.pattern + except sre_constants.error: + warnings.warn("invalid pattern (%s) passed to Regex" % self.pattern, + SyntaxWarning, stacklevel=2) + raise + + self.name = _ustr(self) + self.errmsg = "Expected " + self.name + self.mayIndexError = False + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + result = instring[loc] == self.firstQuoteChar and self.re.match(instring,loc) or None + if not result: + raise ParseException(instring, loc, self.errmsg, self) + + loc = result.end() + ret = result.group() + + if self.unquoteResults: + + # strip off quotes + ret = ret[self.quoteCharLen:-self.endQuoteCharLen] + + if isinstance(ret,basestring): + # replace escaped whitespace + if '\\' in ret and self.convertWhitespaceEscapes: + ws_map = { + r'\t' : '\t', + r'\n' : '\n', + r'\f' : '\f', + r'\r' : '\r', + } + for wslit,wschar in ws_map.items(): + ret = ret.replace(wslit, wschar) + + # replace escaped characters + if self.escChar: + ret = re.sub(self.escCharReplacePattern, r"\g<1>", ret) + + # replace escaped quotes + if self.escQuote: + ret = ret.replace(self.escQuote, self.endQuoteChar) + + return loc, ret + + def __str__( self ): + try: + return super(QuotedString,self).__str__() + except Exception: + pass + + if self.strRepr is None: + self.strRepr = "quoted string, starting with %s ending with %s" % (self.quoteChar, self.endQuoteChar) + + return self.strRepr + + +class CharsNotIn(Token): + """ + Token for matching words composed of characters I{not} in a given set (will + include whitespace in matched characters if not listed in the provided exclusion set - see example). + Defined with string containing all disallowed characters, and an optional + minimum, maximum, and/or exact length. The default value for C{min} is 1 (a + minimum value < 1 is not valid); the default values for C{max} and C{exact} + are 0, meaning no maximum or exact length restriction. + + Example:: + # define a comma-separated-value as anything that is not a ',' + csv_value = CharsNotIn(',') + print(delimitedList(csv_value).parseString("dkls,lsdkjf,s12 34,@!#,213")) + prints:: + ['dkls', 'lsdkjf', 's12 34', '@!#', '213'] + """ + def __init__( self, notChars, min=1, max=0, exact=0 ): + super(CharsNotIn,self).__init__() + self.skipWhitespace = False + self.notChars = notChars + + if min < 1: + raise ValueError("cannot specify a minimum length < 1; use Optional(CharsNotIn()) if zero-length char group is permitted") + + self.minLen = min + + if max > 0: + self.maxLen = max + else: + self.maxLen = _MAX_INT + + if exact > 0: + self.maxLen = exact + self.minLen = exact + + self.name = _ustr(self) + self.errmsg = "Expected " + self.name + self.mayReturnEmpty = ( self.minLen == 0 ) + self.mayIndexError = False + + def parseImpl( self, instring, loc, doActions=True ): + if instring[loc] in self.notChars: + raise ParseException(instring, loc, self.errmsg, self) + + start = loc + loc += 1 + notchars = self.notChars + maxlen = min( start+self.maxLen, len(instring) ) + while loc < maxlen and \ + (instring[loc] not in notchars): + loc += 1 + + if loc - start < self.minLen: + raise ParseException(instring, loc, self.errmsg, self) + + return loc, instring[start:loc] + + def __str__( self ): + try: + return super(CharsNotIn, self).__str__() + except Exception: + pass + + if self.strRepr is None: + if len(self.notChars) > 4: + self.strRepr = "!W:(%s...)" % self.notChars[:4] + else: + self.strRepr = "!W:(%s)" % self.notChars + + return self.strRepr + +class White(Token): + """ + Special matching class for matching whitespace. Normally, whitespace is ignored + by pyparsing grammars. This class is included when some whitespace structures + are significant. Define with a string containing the whitespace characters to be + matched; default is C{" \\t\\r\\n"}. Also takes optional C{min}, C{max}, and C{exact} arguments, + as defined for the C{L{Word}} class. + """ + whiteStrs = { + " " : "<SPC>", + "\t": "<TAB>", + "\n": "<LF>", + "\r": "<CR>", + "\f": "<FF>", + } + def __init__(self, ws=" \t\r\n", min=1, max=0, exact=0): + super(White,self).__init__() + self.matchWhite = ws + self.setWhitespaceChars( "".join(c for c in self.whiteChars if c not in self.matchWhite) ) + #~ self.leaveWhitespace() + self.name = ("".join(White.whiteStrs[c] for c in self.matchWhite)) + self.mayReturnEmpty = True + self.errmsg = "Expected " + self.name + + self.minLen = min + + if max > 0: + self.maxLen = max + else: + self.maxLen = _MAX_INT + + if exact > 0: + self.maxLen = exact + self.minLen = exact + + def parseImpl( self, instring, loc, doActions=True ): + if not(instring[ loc ] in self.matchWhite): + raise ParseException(instring, loc, self.errmsg, self) + start = loc + loc += 1 + maxloc = start + self.maxLen + maxloc = min( maxloc, len(instring) ) + while loc < maxloc and instring[loc] in self.matchWhite: + loc += 1 + + if loc - start < self.minLen: + raise ParseException(instring, loc, self.errmsg, self) + + return loc, instring[start:loc] + + +class _PositionToken(Token): + def __init__( self ): + super(_PositionToken,self).__init__() + self.name=self.__class__.__name__ + self.mayReturnEmpty = True + self.mayIndexError = False + +class GoToColumn(_PositionToken): + """ + Token to advance to a specific column of input text; useful for tabular report scraping. + """ + def __init__( self, colno ): + super(GoToColumn,self).__init__() + self.col = colno + + def preParse( self, instring, loc ): + if col(loc,instring) != self.col: + instrlen = len(instring) + if self.ignoreExprs: + loc = self._skipIgnorables( instring, loc ) + while loc < instrlen and instring[loc].isspace() and col( loc, instring ) != self.col : + loc += 1 + return loc + + def parseImpl( self, instring, loc, doActions=True ): + thiscol = col( loc, instring ) + if thiscol > self.col: + raise ParseException( instring, loc, "Text not in expected column", self ) + newloc = loc + self.col - thiscol + ret = instring[ loc: newloc ] + return newloc, ret + + +class LineStart(_PositionToken): + """ + Matches if current position is at the beginning of a line within the parse string + + Example:: + + test = '''\ + AAA this line + AAA and this line + AAA but not this one + B AAA and definitely not this one + ''' + + for t in (LineStart() + 'AAA' + restOfLine).searchString(test): + print(t) + + Prints:: + ['AAA', ' this line'] + ['AAA', ' and this line'] + + """ + def __init__( self ): + super(LineStart,self).__init__() + self.errmsg = "Expected start of line" + + def parseImpl( self, instring, loc, doActions=True ): + if col(loc, instring) == 1: + return loc, [] + raise ParseException(instring, loc, self.errmsg, self) + +class LineEnd(_PositionToken): + """ + Matches if current position is at the end of a line within the parse string + """ + def __init__( self ): + super(LineEnd,self).__init__() + self.setWhitespaceChars( ParserElement.DEFAULT_WHITE_CHARS.replace("\n","") ) + self.errmsg = "Expected end of line" + + def parseImpl( self, instring, loc, doActions=True ): + if loc<len(instring): + if instring[loc] == "\n": + return loc+1, "\n" + else: + raise ParseException(instring, loc, self.errmsg, self) + elif loc == len(instring): + return loc+1, [] + else: + raise ParseException(instring, loc, self.errmsg, self) + +class StringStart(_PositionToken): + """ + Matches if current position is at the beginning of the parse string + """ + def __init__( self ): + super(StringStart,self).__init__() + self.errmsg = "Expected start of text" + + def parseImpl( self, instring, loc, doActions=True ): + if loc != 0: + # see if entire string up to here is just whitespace and ignoreables + if loc != self.preParse( instring, 0 ): + raise ParseException(instring, loc, self.errmsg, self) + return loc, [] + +class StringEnd(_PositionToken): + """ + Matches if current position is at the end of the parse string + """ + def __init__( self ): + super(StringEnd,self).__init__() + self.errmsg = "Expected end of text" + + def parseImpl( self, instring, loc, doActions=True ): + if loc < len(instring): + raise ParseException(instring, loc, self.errmsg, self) + elif loc == len(instring): + return loc+1, [] + elif loc > len(instring): + return loc, [] + else: + raise ParseException(instring, loc, self.errmsg, self) + +class WordStart(_PositionToken): + """ + Matches if the current position is at the beginning of a Word, and + is not preceded by any character in a given set of C{wordChars} + (default=C{printables}). To emulate the C{\b} behavior of regular expressions, + use C{WordStart(alphanums)}. C{WordStart} will also match at the beginning of + the string being parsed, or at the beginning of a line. + """ + def __init__(self, wordChars = printables): + super(WordStart,self).__init__() + self.wordChars = set(wordChars) + self.errmsg = "Not at the start of a word" + + def parseImpl(self, instring, loc, doActions=True ): + if loc != 0: + if (instring[loc-1] in self.wordChars or + instring[loc] not in self.wordChars): + raise ParseException(instring, loc, self.errmsg, self) + return loc, [] + +class WordEnd(_PositionToken): + """ + Matches if the current position is at the end of a Word, and + is not followed by any character in a given set of C{wordChars} + (default=C{printables}). To emulate the C{\b} behavior of regular expressions, + use C{WordEnd(alphanums)}. C{WordEnd} will also match at the end of + the string being parsed, or at the end of a line. + """ + def __init__(self, wordChars = printables): + super(WordEnd,self).__init__() + self.wordChars = set(wordChars) + self.skipWhitespace = False + self.errmsg = "Not at the end of a word" + + def parseImpl(self, instring, loc, doActions=True ): + instrlen = len(instring) + if instrlen>0 and loc<instrlen: + if (instring[loc] in self.wordChars or + instring[loc-1] not in self.wordChars): + raise ParseException(instring, loc, self.errmsg, self) + return loc, [] + + +class ParseExpression(ParserElement): + """ + Abstract subclass of ParserElement, for combining and post-processing parsed tokens. + """ + def __init__( self, exprs, savelist = False ): + super(ParseExpression,self).__init__(savelist) + if isinstance( exprs, _generatorType ): + exprs = list(exprs) + + if isinstance( exprs, basestring ): + self.exprs = [ ParserElement._literalStringClass( exprs ) ] + elif isinstance( exprs, Iterable ): + exprs = list(exprs) + # if sequence of strings provided, wrap with Literal + if all(isinstance(expr, basestring) for expr in exprs): + exprs = map(ParserElement._literalStringClass, exprs) + self.exprs = list(exprs) + else: + try: + self.exprs = list( exprs ) + except TypeError: + self.exprs = [ exprs ] + self.callPreparse = False + + def __getitem__( self, i ): + return self.exprs[i] + + def append( self, other ): + self.exprs.append( other ) + self.strRepr = None + return self + + def leaveWhitespace( self ): + """Extends C{leaveWhitespace} defined in base class, and also invokes C{leaveWhitespace} on + all contained expressions.""" + self.skipWhitespace = False + self.exprs = [ e.copy() for e in self.exprs ] + for e in self.exprs: + e.leaveWhitespace() + return self + + def ignore( self, other ): + if isinstance( other, Suppress ): + if other not in self.ignoreExprs: + super( ParseExpression, self).ignore( other ) + for e in self.exprs: + e.ignore( self.ignoreExprs[-1] ) + else: + super( ParseExpression, self).ignore( other ) + for e in self.exprs: + e.ignore( self.ignoreExprs[-1] ) + return self + + def __str__( self ): + try: + return super(ParseExpression,self).__str__() + except Exception: + pass + + if self.strRepr is None: + self.strRepr = "%s:(%s)" % ( self.__class__.__name__, _ustr(self.exprs) ) + return self.strRepr + + def streamline( self ): + super(ParseExpression,self).streamline() + + for e in self.exprs: + e.streamline() + + # collapse nested And's of the form And( And( And( a,b), c), d) to And( a,b,c,d ) + # but only if there are no parse actions or resultsNames on the nested And's + # (likewise for Or's and MatchFirst's) + if ( len(self.exprs) == 2 ): + other = self.exprs[0] + if ( isinstance( other, self.__class__ ) and + not(other.parseAction) and + other.resultsName is None and + not other.debug ): + self.exprs = other.exprs[:] + [ self.exprs[1] ] + self.strRepr = None + self.mayReturnEmpty |= other.mayReturnEmpty + self.mayIndexError |= other.mayIndexError + + other = self.exprs[-1] + if ( isinstance( other, self.__class__ ) and + not(other.parseAction) and + other.resultsName is None and + not other.debug ): + self.exprs = self.exprs[:-1] + other.exprs[:] + self.strRepr = None + self.mayReturnEmpty |= other.mayReturnEmpty + self.mayIndexError |= other.mayIndexError + + self.errmsg = "Expected " + _ustr(self) + + return self + + def setResultsName( self, name, listAllMatches=False ): + ret = super(ParseExpression,self).setResultsName(name,listAllMatches) + return ret + + def validate( self, validateTrace=[] ): + tmp = validateTrace[:]+[self] + for e in self.exprs: + e.validate(tmp) + self.checkRecursion( [] ) + + def copy(self): + ret = super(ParseExpression,self).copy() + ret.exprs = [e.copy() for e in self.exprs] + return ret + +class And(ParseExpression): + """ + Requires all given C{ParseExpression}s to be found in the given order. + Expressions may be separated by whitespace. + May be constructed using the C{'+'} operator. + May also be constructed using the C{'-'} operator, which will suppress backtracking. + + Example:: + integer = Word(nums) + name_expr = OneOrMore(Word(alphas)) + + expr = And([integer("id"),name_expr("name"),integer("age")]) + # more easily written as: + expr = integer("id") + name_expr("name") + integer("age") + """ + + class _ErrorStop(Empty): + def __init__(self, *args, **kwargs): + super(And._ErrorStop,self).__init__(*args, **kwargs) + self.name = '-' + self.leaveWhitespace() + + def __init__( self, exprs, savelist = True ): + super(And,self).__init__(exprs, savelist) + self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) + self.setWhitespaceChars( self.exprs[0].whiteChars ) + self.skipWhitespace = self.exprs[0].skipWhitespace + self.callPreparse = True + + def parseImpl( self, instring, loc, doActions=True ): + # pass False as last arg to _parse for first element, since we already + # pre-parsed the string as part of our And pre-parsing + loc, resultlist = self.exprs[0]._parse( instring, loc, doActions, callPreParse=False ) + errorStop = False + for e in self.exprs[1:]: + if isinstance(e, And._ErrorStop): + errorStop = True + continue + if errorStop: + try: + loc, exprtokens = e._parse( instring, loc, doActions ) + except ParseSyntaxException: + raise + except ParseBaseException as pe: + pe.__traceback__ = None + raise ParseSyntaxException._from_exception(pe) + except IndexError: + raise ParseSyntaxException(instring, len(instring), self.errmsg, self) + else: + loc, exprtokens = e._parse( instring, loc, doActions ) + if exprtokens or exprtokens.haskeys(): + resultlist += exprtokens + return loc, resultlist + + def __iadd__(self, other ): + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + return self.append( other ) #And( [ self, other ] ) + + def checkRecursion( self, parseElementList ): + subRecCheckList = parseElementList[:] + [ self ] + for e in self.exprs: + e.checkRecursion( subRecCheckList ) + if not e.mayReturnEmpty: + break + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "{" + " ".join(_ustr(e) for e in self.exprs) + "}" + + return self.strRepr + + +class Or(ParseExpression): + """ + Requires that at least one C{ParseExpression} is found. + If two expressions match, the expression that matches the longest string will be used. + May be constructed using the C{'^'} operator. + + Example:: + # construct Or using '^' operator + + number = Word(nums) ^ Combine(Word(nums) + '.' + Word(nums)) + print(number.searchString("123 3.1416 789")) + prints:: + [['123'], ['3.1416'], ['789']] + """ + def __init__( self, exprs, savelist = False ): + super(Or,self).__init__(exprs, savelist) + if self.exprs: + self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs) + else: + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + maxExcLoc = -1 + maxException = None + matches = [] + for e in self.exprs: + try: + loc2 = e.tryParse( instring, loc ) + except ParseException as err: + err.__traceback__ = None + if err.loc > maxExcLoc: + maxException = err + maxExcLoc = err.loc + except IndexError: + if len(instring) > maxExcLoc: + maxException = ParseException(instring,len(instring),e.errmsg,self) + maxExcLoc = len(instring) + else: + # save match among all matches, to retry longest to shortest + matches.append((loc2, e)) + + if matches: + matches.sort(key=lambda x: -x[0]) + for _,e in matches: + try: + return e._parse( instring, loc, doActions ) + except ParseException as err: + err.__traceback__ = None + if err.loc > maxExcLoc: + maxException = err + maxExcLoc = err.loc + + if maxException is not None: + maxException.msg = self.errmsg + raise maxException + else: + raise ParseException(instring, loc, "no defined alternatives to match", self) + + + def __ixor__(self, other ): + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + return self.append( other ) #Or( [ self, other ] ) + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "{" + " ^ ".join(_ustr(e) for e in self.exprs) + "}" + + return self.strRepr + + def checkRecursion( self, parseElementList ): + subRecCheckList = parseElementList[:] + [ self ] + for e in self.exprs: + e.checkRecursion( subRecCheckList ) + + +class MatchFirst(ParseExpression): + """ + Requires that at least one C{ParseExpression} is found. + If two expressions match, the first one listed is the one that will match. + May be constructed using the C{'|'} operator. + + Example:: + # construct MatchFirst using '|' operator + + # watch the order of expressions to match + number = Word(nums) | Combine(Word(nums) + '.' + Word(nums)) + print(number.searchString("123 3.1416 789")) # Fail! -> [['123'], ['3'], ['1416'], ['789']] + + # put more selective expression first + number = Combine(Word(nums) + '.' + Word(nums)) | Word(nums) + print(number.searchString("123 3.1416 789")) # Better -> [['123'], ['3.1416'], ['789']] + """ + def __init__( self, exprs, savelist = False ): + super(MatchFirst,self).__init__(exprs, savelist) + if self.exprs: + self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs) + else: + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + maxExcLoc = -1 + maxException = None + for e in self.exprs: + try: + ret = e._parse( instring, loc, doActions ) + return ret + except ParseException as err: + if err.loc > maxExcLoc: + maxException = err + maxExcLoc = err.loc + except IndexError: + if len(instring) > maxExcLoc: + maxException = ParseException(instring,len(instring),e.errmsg,self) + maxExcLoc = len(instring) + + # only got here if no expression matched, raise exception for match that made it the furthest + else: + if maxException is not None: + maxException.msg = self.errmsg + raise maxException + else: + raise ParseException(instring, loc, "no defined alternatives to match", self) + + def __ior__(self, other ): + if isinstance( other, basestring ): + other = ParserElement._literalStringClass( other ) + return self.append( other ) #MatchFirst( [ self, other ] ) + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "{" + " | ".join(_ustr(e) for e in self.exprs) + "}" + + return self.strRepr + + def checkRecursion( self, parseElementList ): + subRecCheckList = parseElementList[:] + [ self ] + for e in self.exprs: + e.checkRecursion( subRecCheckList ) + + +class Each(ParseExpression): + """ + Requires all given C{ParseExpression}s to be found, but in any order. + Expressions may be separated by whitespace. + May be constructed using the C{'&'} operator. + + Example:: + color = oneOf("RED ORANGE YELLOW GREEN BLUE PURPLE BLACK WHITE BROWN") + shape_type = oneOf("SQUARE CIRCLE TRIANGLE STAR HEXAGON OCTAGON") + integer = Word(nums) + shape_attr = "shape:" + shape_type("shape") + posn_attr = "posn:" + Group(integer("x") + ',' + integer("y"))("posn") + color_attr = "color:" + color("color") + size_attr = "size:" + integer("size") + + # use Each (using operator '&') to accept attributes in any order + # (shape and posn are required, color and size are optional) + shape_spec = shape_attr & posn_attr & Optional(color_attr) & Optional(size_attr) + + shape_spec.runTests(''' + shape: SQUARE color: BLACK posn: 100, 120 + shape: CIRCLE size: 50 color: BLUE posn: 50,80 + color:GREEN size:20 shape:TRIANGLE posn:20,40 + ''' + ) + prints:: + shape: SQUARE color: BLACK posn: 100, 120 + ['shape:', 'SQUARE', 'color:', 'BLACK', 'posn:', ['100', ',', '120']] + - color: BLACK + - posn: ['100', ',', '120'] + - x: 100 + - y: 120 + - shape: SQUARE + + + shape: CIRCLE size: 50 color: BLUE posn: 50,80 + ['shape:', 'CIRCLE', 'size:', '50', 'color:', 'BLUE', 'posn:', ['50', ',', '80']] + - color: BLUE + - posn: ['50', ',', '80'] + - x: 50 + - y: 80 + - shape: CIRCLE + - size: 50 + + + color: GREEN size: 20 shape: TRIANGLE posn: 20,40 + ['color:', 'GREEN', 'size:', '20', 'shape:', 'TRIANGLE', 'posn:', ['20', ',', '40']] + - color: GREEN + - posn: ['20', ',', '40'] + - x: 20 + - y: 40 + - shape: TRIANGLE + - size: 20 + """ + def __init__( self, exprs, savelist = True ): + super(Each,self).__init__(exprs, savelist) + self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) + self.skipWhitespace = True + self.initExprGroups = True + + def parseImpl( self, instring, loc, doActions=True ): + if self.initExprGroups: + self.opt1map = dict((id(e.expr),e) for e in self.exprs if isinstance(e,Optional)) + opt1 = [ e.expr for e in self.exprs if isinstance(e,Optional) ] + opt2 = [ e for e in self.exprs if e.mayReturnEmpty and not isinstance(e,Optional)] + self.optionals = opt1 + opt2 + self.multioptionals = [ e.expr for e in self.exprs if isinstance(e,ZeroOrMore) ] + self.multirequired = [ e.expr for e in self.exprs if isinstance(e,OneOrMore) ] + self.required = [ e for e in self.exprs if not isinstance(e,(Optional,ZeroOrMore,OneOrMore)) ] + self.required += self.multirequired + self.initExprGroups = False + tmpLoc = loc + tmpReqd = self.required[:] + tmpOpt = self.optionals[:] + matchOrder = [] + + keepMatching = True + while keepMatching: + tmpExprs = tmpReqd + tmpOpt + self.multioptionals + self.multirequired + failed = [] + for e in tmpExprs: + try: + tmpLoc = e.tryParse( instring, tmpLoc ) + except ParseException: + failed.append(e) + else: + matchOrder.append(self.opt1map.get(id(e),e)) + if e in tmpReqd: + tmpReqd.remove(e) + elif e in tmpOpt: + tmpOpt.remove(e) + if len(failed) == len(tmpExprs): + keepMatching = False + + if tmpReqd: + missing = ", ".join(_ustr(e) for e in tmpReqd) + raise ParseException(instring,loc,"Missing one or more required elements (%s)" % missing ) + + # add any unmatched Optionals, in case they have default values defined + matchOrder += [e for e in self.exprs if isinstance(e,Optional) and e.expr in tmpOpt] + + resultlist = [] + for e in matchOrder: + loc,results = e._parse(instring,loc,doActions) + resultlist.append(results) + + finalResults = sum(resultlist, ParseResults([])) + return loc, finalResults + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "{" + " & ".join(_ustr(e) for e in self.exprs) + "}" + + return self.strRepr + + def checkRecursion( self, parseElementList ): + subRecCheckList = parseElementList[:] + [ self ] + for e in self.exprs: + e.checkRecursion( subRecCheckList ) + + +class ParseElementEnhance(ParserElement): + """ + Abstract subclass of C{ParserElement}, for combining and post-processing parsed tokens. + """ + def __init__( self, expr, savelist=False ): + super(ParseElementEnhance,self).__init__(savelist) + if isinstance( expr, basestring ): + if issubclass(ParserElement._literalStringClass, Token): + expr = ParserElement._literalStringClass(expr) + else: + expr = ParserElement._literalStringClass(Literal(expr)) + self.expr = expr + self.strRepr = None + if expr is not None: + self.mayIndexError = expr.mayIndexError + self.mayReturnEmpty = expr.mayReturnEmpty + self.setWhitespaceChars( expr.whiteChars ) + self.skipWhitespace = expr.skipWhitespace + self.saveAsList = expr.saveAsList + self.callPreparse = expr.callPreparse + self.ignoreExprs.extend(expr.ignoreExprs) + + def parseImpl( self, instring, loc, doActions=True ): + if self.expr is not None: + return self.expr._parse( instring, loc, doActions, callPreParse=False ) + else: + raise ParseException("",loc,self.errmsg,self) + + def leaveWhitespace( self ): + self.skipWhitespace = False + self.expr = self.expr.copy() + if self.expr is not None: + self.expr.leaveWhitespace() + return self + + def ignore( self, other ): + if isinstance( other, Suppress ): + if other not in self.ignoreExprs: + super( ParseElementEnhance, self).ignore( other ) + if self.expr is not None: + self.expr.ignore( self.ignoreExprs[-1] ) + else: + super( ParseElementEnhance, self).ignore( other ) + if self.expr is not None: + self.expr.ignore( self.ignoreExprs[-1] ) + return self + + def streamline( self ): + super(ParseElementEnhance,self).streamline() + if self.expr is not None: + self.expr.streamline() + return self + + def checkRecursion( self, parseElementList ): + if self in parseElementList: + raise RecursiveGrammarException( parseElementList+[self] ) + subRecCheckList = parseElementList[:] + [ self ] + if self.expr is not None: + self.expr.checkRecursion( subRecCheckList ) + + def validate( self, validateTrace=[] ): + tmp = validateTrace[:]+[self] + if self.expr is not None: + self.expr.validate(tmp) + self.checkRecursion( [] ) + + def __str__( self ): + try: + return super(ParseElementEnhance,self).__str__() + except Exception: + pass + + if self.strRepr is None and self.expr is not None: + self.strRepr = "%s:(%s)" % ( self.__class__.__name__, _ustr(self.expr) ) + return self.strRepr + + +class FollowedBy(ParseElementEnhance): + """ + Lookahead matching of the given parse expression. C{FollowedBy} + does I{not} advance the parsing position within the input string, it only + verifies that the specified parse expression matches at the current + position. C{FollowedBy} always returns a null token list. + + Example:: + # use FollowedBy to match a label only if it is followed by a ':' + data_word = Word(alphas) + label = data_word + FollowedBy(':') + attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) + + OneOrMore(attr_expr).parseString("shape: SQUARE color: BLACK posn: upper left").pprint() + prints:: + [['shape', 'SQUARE'], ['color', 'BLACK'], ['posn', 'upper left']] + """ + def __init__( self, expr ): + super(FollowedBy,self).__init__(expr) + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + self.expr.tryParse( instring, loc ) + return loc, [] + + +class NotAny(ParseElementEnhance): + """ + Lookahead to disallow matching with the given parse expression. C{NotAny} + does I{not} advance the parsing position within the input string, it only + verifies that the specified parse expression does I{not} match at the current + position. Also, C{NotAny} does I{not} skip over leading whitespace. C{NotAny} + always returns a null token list. May be constructed using the '~' operator. + + Example:: + + """ + def __init__( self, expr ): + super(NotAny,self).__init__(expr) + #~ self.leaveWhitespace() + self.skipWhitespace = False # do NOT use self.leaveWhitespace(), don't want to propagate to exprs + self.mayReturnEmpty = True + self.errmsg = "Found unwanted token, "+_ustr(self.expr) + + def parseImpl( self, instring, loc, doActions=True ): + if self.expr.canParseNext(instring, loc): + raise ParseException(instring, loc, self.errmsg, self) + return loc, [] + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "~{" + _ustr(self.expr) + "}" + + return self.strRepr + +class _MultipleMatch(ParseElementEnhance): + def __init__( self, expr, stopOn=None): + super(_MultipleMatch, self).__init__(expr) + self.saveAsList = True + ender = stopOn + if isinstance(ender, basestring): + ender = ParserElement._literalStringClass(ender) + self.not_ender = ~ender if ender is not None else None + + def parseImpl( self, instring, loc, doActions=True ): + self_expr_parse = self.expr._parse + self_skip_ignorables = self._skipIgnorables + check_ender = self.not_ender is not None + if check_ender: + try_not_ender = self.not_ender.tryParse + + # must be at least one (but first see if we are the stopOn sentinel; + # if so, fail) + if check_ender: + try_not_ender(instring, loc) + loc, tokens = self_expr_parse( instring, loc, doActions, callPreParse=False ) + try: + hasIgnoreExprs = (not not self.ignoreExprs) + while 1: + if check_ender: + try_not_ender(instring, loc) + if hasIgnoreExprs: + preloc = self_skip_ignorables( instring, loc ) + else: + preloc = loc + loc, tmptokens = self_expr_parse( instring, preloc, doActions ) + if tmptokens or tmptokens.haskeys(): + tokens += tmptokens + except (ParseException,IndexError): + pass + + return loc, tokens + +class OneOrMore(_MultipleMatch): + """ + Repetition of one or more of the given expression. + + Parameters: + - expr - expression that must match one or more times + - stopOn - (default=C{None}) - expression for a terminating sentinel + (only required if the sentinel would ordinarily match the repetition + expression) + + Example:: + data_word = Word(alphas) + label = data_word + FollowedBy(':') + attr_expr = Group(label + Suppress(':') + OneOrMore(data_word).setParseAction(' '.join)) + + text = "shape: SQUARE posn: upper left color: BLACK" + OneOrMore(attr_expr).parseString(text).pprint() # Fail! read 'color' as data instead of next label -> [['shape', 'SQUARE color']] + + # use stopOn attribute for OneOrMore to avoid reading label string as part of the data + attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) + OneOrMore(attr_expr).parseString(text).pprint() # Better -> [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'BLACK']] + + # could also be written as + (attr_expr * (1,)).parseString(text).pprint() + """ + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "{" + _ustr(self.expr) + "}..." + + return self.strRepr + +class ZeroOrMore(_MultipleMatch): + """ + Optional repetition of zero or more of the given expression. + + Parameters: + - expr - expression that must match zero or more times + - stopOn - (default=C{None}) - expression for a terminating sentinel + (only required if the sentinel would ordinarily match the repetition + expression) + + Example: similar to L{OneOrMore} + """ + def __init__( self, expr, stopOn=None): + super(ZeroOrMore,self).__init__(expr, stopOn=stopOn) + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + try: + return super(ZeroOrMore, self).parseImpl(instring, loc, doActions) + except (ParseException,IndexError): + return loc, [] + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "[" + _ustr(self.expr) + "]..." + + return self.strRepr + +class _NullToken(object): + def __bool__(self): + return False + __nonzero__ = __bool__ + def __str__(self): + return "" + +_optionalNotMatched = _NullToken() +class Optional(ParseElementEnhance): + """ + Optional matching of the given expression. + + Parameters: + - expr - expression that must match zero or more times + - default (optional) - value to be returned if the optional expression is not found. + + Example:: + # US postal code can be a 5-digit zip, plus optional 4-digit qualifier + zip = Combine(Word(nums, exact=5) + Optional('-' + Word(nums, exact=4))) + zip.runTests(''' + # traditional ZIP code + 12345 + + # ZIP+4 form + 12101-0001 + + # invalid ZIP + 98765- + ''') + prints:: + # traditional ZIP code + 12345 + ['12345'] + + # ZIP+4 form + 12101-0001 + ['12101-0001'] + + # invalid ZIP + 98765- + ^ + FAIL: Expected end of text (at char 5), (line:1, col:6) + """ + def __init__( self, expr, default=_optionalNotMatched ): + super(Optional,self).__init__( expr, savelist=False ) + self.saveAsList = self.expr.saveAsList + self.defaultValue = default + self.mayReturnEmpty = True + + def parseImpl( self, instring, loc, doActions=True ): + try: + loc, tokens = self.expr._parse( instring, loc, doActions, callPreParse=False ) + except (ParseException,IndexError): + if self.defaultValue is not _optionalNotMatched: + if self.expr.resultsName: + tokens = ParseResults([ self.defaultValue ]) + tokens[self.expr.resultsName] = self.defaultValue + else: + tokens = [ self.defaultValue ] + else: + tokens = [] + return loc, tokens + + def __str__( self ): + if hasattr(self,"name"): + return self.name + + if self.strRepr is None: + self.strRepr = "[" + _ustr(self.expr) + "]" + + return self.strRepr + +class SkipTo(ParseElementEnhance): + """ + Token for skipping over all undefined text until the matched expression is found. + + Parameters: + - expr - target expression marking the end of the data to be skipped + - include - (default=C{False}) if True, the target expression is also parsed + (the skipped text and target expression are returned as a 2-element list). + - ignore - (default=C{None}) used to define grammars (typically quoted strings and + comments) that might contain false matches to the target expression + - failOn - (default=C{None}) define expressions that are not allowed to be + included in the skipped test; if found before the target expression is found, + the SkipTo is not a match + + Example:: + report = ''' + Outstanding Issues Report - 1 Jan 2000 + + # | Severity | Description | Days Open + -----+----------+-------------------------------------------+----------- + 101 | Critical | Intermittent system crash | 6 + 94 | Cosmetic | Spelling error on Login ('log|n') | 14 + 79 | Minor | System slow when running too many reports | 47 + ''' + integer = Word(nums) + SEP = Suppress('|') + # use SkipTo to simply match everything up until the next SEP + # - ignore quoted strings, so that a '|' character inside a quoted string does not match + # - parse action will call token.strip() for each matched token, i.e., the description body + string_data = SkipTo(SEP, ignore=quotedString) + string_data.setParseAction(tokenMap(str.strip)) + ticket_expr = (integer("issue_num") + SEP + + string_data("sev") + SEP + + string_data("desc") + SEP + + integer("days_open")) + + for tkt in ticket_expr.searchString(report): + print tkt.dump() + prints:: + ['101', 'Critical', 'Intermittent system crash', '6'] + - days_open: 6 + - desc: Intermittent system crash + - issue_num: 101 + - sev: Critical + ['94', 'Cosmetic', "Spelling error on Login ('log|n')", '14'] + - days_open: 14 + - desc: Spelling error on Login ('log|n') + - issue_num: 94 + - sev: Cosmetic + ['79', 'Minor', 'System slow when running too many reports', '47'] + - days_open: 47 + - desc: System slow when running too many reports + - issue_num: 79 + - sev: Minor + """ + def __init__( self, other, include=False, ignore=None, failOn=None ): + super( SkipTo, self ).__init__( other ) + self.ignoreExpr = ignore + self.mayReturnEmpty = True + self.mayIndexError = False + self.includeMatch = include + self.asList = False + if isinstance(failOn, basestring): + self.failOn = ParserElement._literalStringClass(failOn) + else: + self.failOn = failOn + self.errmsg = "No match found for "+_ustr(self.expr) + + def parseImpl( self, instring, loc, doActions=True ): + startloc = loc + instrlen = len(instring) + expr = self.expr + expr_parse = self.expr._parse + self_failOn_canParseNext = self.failOn.canParseNext if self.failOn is not None else None + self_ignoreExpr_tryParse = self.ignoreExpr.tryParse if self.ignoreExpr is not None else None + + tmploc = loc + while tmploc <= instrlen: + if self_failOn_canParseNext is not None: + # break if failOn expression matches + if self_failOn_canParseNext(instring, tmploc): + break + + if self_ignoreExpr_tryParse is not None: + # advance past ignore expressions + while 1: + try: + tmploc = self_ignoreExpr_tryParse(instring, tmploc) + except ParseBaseException: + break + + try: + expr_parse(instring, tmploc, doActions=False, callPreParse=False) + except (ParseException, IndexError): + # no match, advance loc in string + tmploc += 1 + else: + # matched skipto expr, done + break + + else: + # ran off the end of the input string without matching skipto expr, fail + raise ParseException(instring, loc, self.errmsg, self) + + # build up return values + loc = tmploc + skiptext = instring[startloc:loc] + skipresult = ParseResults(skiptext) + + if self.includeMatch: + loc, mat = expr_parse(instring,loc,doActions,callPreParse=False) + skipresult += mat + + return loc, skipresult + +class Forward(ParseElementEnhance): + """ + Forward declaration of an expression to be defined later - + used for recursive grammars, such as algebraic infix notation. + When the expression is known, it is assigned to the C{Forward} variable using the '<<' operator. + + Note: take care when assigning to C{Forward} not to overlook precedence of operators. + Specifically, '|' has a lower precedence than '<<', so that:: + fwdExpr << a | b | c + will actually be evaluated as:: + (fwdExpr << a) | b | c + thereby leaving b and c out as parseable alternatives. It is recommended that you + explicitly group the values inserted into the C{Forward}:: + fwdExpr << (a | b | c) + Converting to use the '<<=' operator instead will avoid this problem. + + See L{ParseResults.pprint} for an example of a recursive parser created using + C{Forward}. + """ + def __init__( self, other=None ): + super(Forward,self).__init__( other, savelist=False ) + + def __lshift__( self, other ): + if isinstance( other, basestring ): + other = ParserElement._literalStringClass(other) + self.expr = other + self.strRepr = None + self.mayIndexError = self.expr.mayIndexError + self.mayReturnEmpty = self.expr.mayReturnEmpty + self.setWhitespaceChars( self.expr.whiteChars ) + self.skipWhitespace = self.expr.skipWhitespace + self.saveAsList = self.expr.saveAsList + self.ignoreExprs.extend(self.expr.ignoreExprs) + return self + + def __ilshift__(self, other): + return self << other + + def leaveWhitespace( self ): + self.skipWhitespace = False + return self + + def streamline( self ): + if not self.streamlined: + self.streamlined = True + if self.expr is not None: + self.expr.streamline() + return self + + def validate( self, validateTrace=[] ): + if self not in validateTrace: + tmp = validateTrace[:]+[self] + if self.expr is not None: + self.expr.validate(tmp) + self.checkRecursion([]) + + def __str__( self ): + if hasattr(self,"name"): + return self.name + return self.__class__.__name__ + ": ..." + + # stubbed out for now - creates awful memory and perf issues + self._revertClass = self.__class__ + self.__class__ = _ForwardNoRecurse + try: + if self.expr is not None: + retString = _ustr(self.expr) + else: + retString = "None" + finally: + self.__class__ = self._revertClass + return self.__class__.__name__ + ": " + retString + + def copy(self): + if self.expr is not None: + return super(Forward,self).copy() + else: + ret = Forward() + ret <<= self + return ret + +class _ForwardNoRecurse(Forward): + def __str__( self ): + return "..." + +class TokenConverter(ParseElementEnhance): + """ + Abstract subclass of C{ParseExpression}, for converting parsed results. + """ + def __init__( self, expr, savelist=False ): + super(TokenConverter,self).__init__( expr )#, savelist ) + self.saveAsList = False + +class Combine(TokenConverter): + """ + Converter to concatenate all matching tokens to a single string. + By default, the matching patterns must also be contiguous in the input string; + this can be disabled by specifying C{'adjacent=False'} in the constructor. + + Example:: + real = Word(nums) + '.' + Word(nums) + print(real.parseString('3.1416')) # -> ['3', '.', '1416'] + # will also erroneously match the following + print(real.parseString('3. 1416')) # -> ['3', '.', '1416'] + + real = Combine(Word(nums) + '.' + Word(nums)) + print(real.parseString('3.1416')) # -> ['3.1416'] + # no match when there are internal spaces + print(real.parseString('3. 1416')) # -> Exception: Expected W:(0123...) + """ + def __init__( self, expr, joinString="", adjacent=True ): + super(Combine,self).__init__( expr ) + # suppress whitespace-stripping in contained parse expressions, but re-enable it on the Combine itself + if adjacent: + self.leaveWhitespace() + self.adjacent = adjacent + self.skipWhitespace = True + self.joinString = joinString + self.callPreparse = True + + def ignore( self, other ): + if self.adjacent: + ParserElement.ignore(self, other) + else: + super( Combine, self).ignore( other ) + return self + + def postParse( self, instring, loc, tokenlist ): + retToks = tokenlist.copy() + del retToks[:] + retToks += ParseResults([ "".join(tokenlist._asStringList(self.joinString)) ], modal=self.modalResults) + + if self.resultsName and retToks.haskeys(): + return [ retToks ] + else: + return retToks + +class Group(TokenConverter): + """ + Converter to return the matched tokens as a list - useful for returning tokens of C{L{ZeroOrMore}} and C{L{OneOrMore}} expressions. + + Example:: + ident = Word(alphas) + num = Word(nums) + term = ident | num + func = ident + Optional(delimitedList(term)) + print(func.parseString("fn a,b,100")) # -> ['fn', 'a', 'b', '100'] + + func = ident + Group(Optional(delimitedList(term))) + print(func.parseString("fn a,b,100")) # -> ['fn', ['a', 'b', '100']] + """ + def __init__( self, expr ): + super(Group,self).__init__( expr ) + self.saveAsList = True + + def postParse( self, instring, loc, tokenlist ): + return [ tokenlist ] + +class Dict(TokenConverter): + """ + Converter to return a repetitive expression as a list, but also as a dictionary. + Each element can also be referenced using the first token in the expression as its key. + Useful for tabular report scraping when the first column can be used as a item key. + + Example:: + data_word = Word(alphas) + label = data_word + FollowedBy(':') + attr_expr = Group(label + Suppress(':') + OneOrMore(data_word).setParseAction(' '.join)) + + text = "shape: SQUARE posn: upper left color: light blue texture: burlap" + attr_expr = (label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) + + # print attributes as plain groups + print(OneOrMore(attr_expr).parseString(text).dump()) + + # instead of OneOrMore(expr), parse using Dict(OneOrMore(Group(expr))) - Dict will auto-assign names + result = Dict(OneOrMore(Group(attr_expr))).parseString(text) + print(result.dump()) + + # access named fields as dict entries, or output as dict + print(result['shape']) + print(result.asDict()) + prints:: + ['shape', 'SQUARE', 'posn', 'upper left', 'color', 'light blue', 'texture', 'burlap'] + + [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']] + - color: light blue + - posn: upper left + - shape: SQUARE + - texture: burlap + SQUARE + {'color': 'light blue', 'posn': 'upper left', 'texture': 'burlap', 'shape': 'SQUARE'} + See more examples at L{ParseResults} of accessing fields by results name. + """ + def __init__( self, expr ): + super(Dict,self).__init__( expr ) + self.saveAsList = True + + def postParse( self, instring, loc, tokenlist ): + for i,tok in enumerate(tokenlist): + if len(tok) == 0: + continue + ikey = tok[0] + if isinstance(ikey,int): + ikey = _ustr(tok[0]).strip() + if len(tok)==1: + tokenlist[ikey] = _ParseResultsWithOffset("",i) + elif len(tok)==2 and not isinstance(tok[1],ParseResults): + tokenlist[ikey] = _ParseResultsWithOffset(tok[1],i) + else: + dictvalue = tok.copy() #ParseResults(i) + del dictvalue[0] + if len(dictvalue)!= 1 or (isinstance(dictvalue,ParseResults) and dictvalue.haskeys()): + tokenlist[ikey] = _ParseResultsWithOffset(dictvalue,i) + else: + tokenlist[ikey] = _ParseResultsWithOffset(dictvalue[0],i) + + if self.resultsName: + return [ tokenlist ] + else: + return tokenlist + + +class Suppress(TokenConverter): + """ + Converter for ignoring the results of a parsed expression. + + Example:: + source = "a, b, c,d" + wd = Word(alphas) + wd_list1 = wd + ZeroOrMore(',' + wd) + print(wd_list1.parseString(source)) + + # often, delimiters that are useful during parsing are just in the + # way afterward - use Suppress to keep them out of the parsed output + wd_list2 = wd + ZeroOrMore(Suppress(',') + wd) + print(wd_list2.parseString(source)) + prints:: + ['a', ',', 'b', ',', 'c', ',', 'd'] + ['a', 'b', 'c', 'd'] + (See also L{delimitedList}.) + """ + def postParse( self, instring, loc, tokenlist ): + return [] + + def suppress( self ): + return self + + +class OnlyOnce(object): + """ + Wrapper for parse actions, to ensure they are only called once. + """ + def __init__(self, methodCall): + self.callable = _trim_arity(methodCall) + self.called = False + def __call__(self,s,l,t): + if not self.called: + results = self.callable(s,l,t) + self.called = True + return results + raise ParseException(s,l,"") + def reset(self): + self.called = False + +def traceParseAction(f): + """ + Decorator for debugging parse actions. + + When the parse action is called, this decorator will print C{">> entering I{method-name}(line:I{current_source_line}, I{parse_location}, I{matched_tokens})".} + When the parse action completes, the decorator will print C{"<<"} followed by the returned value, or any exception that the parse action raised. + + Example:: + wd = Word(alphas) + + @traceParseAction + def remove_duplicate_chars(tokens): + return ''.join(sorted(set(''.join(tokens)))) + + wds = OneOrMore(wd).setParseAction(remove_duplicate_chars) + print(wds.parseString("slkdjs sld sldd sdlf sdljf")) + prints:: + >>entering remove_duplicate_chars(line: 'slkdjs sld sldd sdlf sdljf', 0, (['slkdjs', 'sld', 'sldd', 'sdlf', 'sdljf'], {})) + <<leaving remove_duplicate_chars (ret: 'dfjkls') + ['dfjkls'] + """ + f = _trim_arity(f) + def z(*paArgs): + thisFunc = f.__name__ + s,l,t = paArgs[-3:] + if len(paArgs)>3: + thisFunc = paArgs[0].__class__.__name__ + '.' + thisFunc + sys.stderr.write( ">>entering %s(line: '%s', %d, %r)\n" % (thisFunc,line(l,s),l,t) ) + try: + ret = f(*paArgs) + except Exception as exc: + sys.stderr.write( "<<leaving %s (exception: %s)\n" % (thisFunc,exc) ) + raise + sys.stderr.write( "<<leaving %s (ret: %r)\n" % (thisFunc,ret) ) + return ret + try: + z.__name__ = f.__name__ + except AttributeError: + pass + return z + +# +# global helpers +# +def delimitedList( expr, delim=",", combine=False ): + """ + Helper to define a delimited list of expressions - the delimiter defaults to ','. + By default, the list elements and delimiters can have intervening whitespace, and + comments, but this can be overridden by passing C{combine=True} in the constructor. + If C{combine} is set to C{True}, the matching tokens are returned as a single token + string, with the delimiters included; otherwise, the matching tokens are returned + as a list of tokens, with the delimiters suppressed. + + Example:: + delimitedList(Word(alphas)).parseString("aa,bb,cc") # -> ['aa', 'bb', 'cc'] + delimitedList(Word(hexnums), delim=':', combine=True).parseString("AA:BB:CC:DD:EE") # -> ['AA:BB:CC:DD:EE'] + """ + dlName = _ustr(expr)+" ["+_ustr(delim)+" "+_ustr(expr)+"]..." + if combine: + return Combine( expr + ZeroOrMore( delim + expr ) ).setName(dlName) + else: + return ( expr + ZeroOrMore( Suppress( delim ) + expr ) ).setName(dlName) + +def countedArray( expr, intExpr=None ): + """ + Helper to define a counted list of expressions. + This helper defines a pattern of the form:: + integer expr expr expr... + where the leading integer tells how many expr expressions follow. + The matched tokens returns the array of expr tokens as a list - the leading count token is suppressed. + + If C{intExpr} is specified, it should be a pyparsing expression that produces an integer value. + + Example:: + countedArray(Word(alphas)).parseString('2 ab cd ef') # -> ['ab', 'cd'] + + # in this parser, the leading integer value is given in binary, + # '10' indicating that 2 values are in the array + binaryConstant = Word('01').setParseAction(lambda t: int(t[0], 2)) + countedArray(Word(alphas), intExpr=binaryConstant).parseString('10 ab cd ef') # -> ['ab', 'cd'] + """ + arrayExpr = Forward() + def countFieldParseAction(s,l,t): + n = t[0] + arrayExpr << (n and Group(And([expr]*n)) or Group(empty)) + return [] + if intExpr is None: + intExpr = Word(nums).setParseAction(lambda t:int(t[0])) + else: + intExpr = intExpr.copy() + intExpr.setName("arrayLen") + intExpr.addParseAction(countFieldParseAction, callDuringTry=True) + return ( intExpr + arrayExpr ).setName('(len) ' + _ustr(expr) + '...') + +def _flatten(L): + ret = [] + for i in L: + if isinstance(i,list): + ret.extend(_flatten(i)) + else: + ret.append(i) + return ret + +def matchPreviousLiteral(expr): + """ + Helper to define an expression that is indirectly defined from + the tokens matched in a previous expression, that is, it looks + for a 'repeat' of a previous expression. For example:: + first = Word(nums) + second = matchPreviousLiteral(first) + matchExpr = first + ":" + second + will match C{"1:1"}, but not C{"1:2"}. Because this matches a + previous literal, will also match the leading C{"1:1"} in C{"1:10"}. + If this is not desired, use C{matchPreviousExpr}. + Do I{not} use with packrat parsing enabled. + """ + rep = Forward() + def copyTokenToRepeater(s,l,t): + if t: + if len(t) == 1: + rep << t[0] + else: + # flatten t tokens + tflat = _flatten(t.asList()) + rep << And(Literal(tt) for tt in tflat) + else: + rep << Empty() + expr.addParseAction(copyTokenToRepeater, callDuringTry=True) + rep.setName('(prev) ' + _ustr(expr)) + return rep + +def matchPreviousExpr(expr): + """ + Helper to define an expression that is indirectly defined from + the tokens matched in a previous expression, that is, it looks + for a 'repeat' of a previous expression. For example:: + first = Word(nums) + second = matchPreviousExpr(first) + matchExpr = first + ":" + second + will match C{"1:1"}, but not C{"1:2"}. Because this matches by + expressions, will I{not} match the leading C{"1:1"} in C{"1:10"}; + the expressions are evaluated first, and then compared, so + C{"1"} is compared with C{"10"}. + Do I{not} use with packrat parsing enabled. + """ + rep = Forward() + e2 = expr.copy() + rep <<= e2 + def copyTokenToRepeater(s,l,t): + matchTokens = _flatten(t.asList()) + def mustMatchTheseTokens(s,l,t): + theseTokens = _flatten(t.asList()) + if theseTokens != matchTokens: + raise ParseException("",0,"") + rep.setParseAction( mustMatchTheseTokens, callDuringTry=True ) + expr.addParseAction(copyTokenToRepeater, callDuringTry=True) + rep.setName('(prev) ' + _ustr(expr)) + return rep + +def _escapeRegexRangeChars(s): + #~ escape these chars: ^-] + for c in r"\^-]": + s = s.replace(c,_bslash+c) + s = s.replace("\n",r"\n") + s = s.replace("\t",r"\t") + return _ustr(s) + +def oneOf( strs, caseless=False, useRegex=True ): + """ + Helper to quickly define a set of alternative Literals, and makes sure to do + longest-first testing when there is a conflict, regardless of the input order, + but returns a C{L{MatchFirst}} for best performance. + + Parameters: + - strs - a string of space-delimited literals, or a collection of string literals + - caseless - (default=C{False}) - treat all literals as caseless + - useRegex - (default=C{True}) - as an optimization, will generate a Regex + object; otherwise, will generate a C{MatchFirst} object (if C{caseless=True}, or + if creating a C{Regex} raises an exception) + + Example:: + comp_oper = oneOf("< = > <= >= !=") + var = Word(alphas) + number = Word(nums) + term = var | number + comparison_expr = term + comp_oper + term + print(comparison_expr.searchString("B = 12 AA=23 B<=AA AA>12")) + prints:: + [['B', '=', '12'], ['AA', '=', '23'], ['B', '<=', 'AA'], ['AA', '>', '12']] + """ + if caseless: + isequal = ( lambda a,b: a.upper() == b.upper() ) + masks = ( lambda a,b: b.upper().startswith(a.upper()) ) + parseElementClass = CaselessLiteral + else: + isequal = ( lambda a,b: a == b ) + masks = ( lambda a,b: b.startswith(a) ) + parseElementClass = Literal + + symbols = [] + if isinstance(strs,basestring): + symbols = strs.split() + elif isinstance(strs, Iterable): + symbols = list(strs) + else: + warnings.warn("Invalid argument to oneOf, expected string or iterable", + SyntaxWarning, stacklevel=2) + if not symbols: + return NoMatch() + + i = 0 + while i < len(symbols)-1: + cur = symbols[i] + for j,other in enumerate(symbols[i+1:]): + if ( isequal(other, cur) ): + del symbols[i+j+1] + break + elif ( masks(cur, other) ): + del symbols[i+j+1] + symbols.insert(i,other) + cur = other + break + else: + i += 1 + + if not caseless and useRegex: + #~ print (strs,"->", "|".join( [ _escapeRegexChars(sym) for sym in symbols] )) + try: + if len(symbols)==len("".join(symbols)): + return Regex( "[%s]" % "".join(_escapeRegexRangeChars(sym) for sym in symbols) ).setName(' | '.join(symbols)) + else: + return Regex( "|".join(re.escape(sym) for sym in symbols) ).setName(' | '.join(symbols)) + except Exception: + warnings.warn("Exception creating Regex for oneOf, building MatchFirst", + SyntaxWarning, stacklevel=2) + + + # last resort, just use MatchFirst + return MatchFirst(parseElementClass(sym) for sym in symbols).setName(' | '.join(symbols)) + +def dictOf( key, value ): + """ + Helper to easily and clearly define a dictionary by specifying the respective patterns + for the key and value. Takes care of defining the C{L{Dict}}, C{L{ZeroOrMore}}, and C{L{Group}} tokens + in the proper order. The key pattern can include delimiting markers or punctuation, + as long as they are suppressed, thereby leaving the significant key text. The value + pattern can include named results, so that the C{Dict} results can include named token + fields. + + Example:: + text = "shape: SQUARE posn: upper left color: light blue texture: burlap" + attr_expr = (label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) + print(OneOrMore(attr_expr).parseString(text).dump()) + + attr_label = label + attr_value = Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join) + + # similar to Dict, but simpler call format + result = dictOf(attr_label, attr_value).parseString(text) + print(result.dump()) + print(result['shape']) + print(result.shape) # object attribute access works too + print(result.asDict()) + prints:: + [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']] + - color: light blue + - posn: upper left + - shape: SQUARE + - texture: burlap + SQUARE + SQUARE + {'color': 'light blue', 'shape': 'SQUARE', 'posn': 'upper left', 'texture': 'burlap'} + """ + return Dict( ZeroOrMore( Group ( key + value ) ) ) + +def originalTextFor(expr, asString=True): + """ + Helper to return the original, untokenized text for a given expression. Useful to + restore the parsed fields of an HTML start tag into the raw tag text itself, or to + revert separate tokens with intervening whitespace back to the original matching + input text. By default, returns astring containing the original parsed text. + + If the optional C{asString} argument is passed as C{False}, then the return value is a + C{L{ParseResults}} containing any results names that were originally matched, and a + single token containing the original matched text from the input string. So if + the expression passed to C{L{originalTextFor}} contains expressions with defined + results names, you must set C{asString} to C{False} if you want to preserve those + results name values. + + Example:: + src = "this is test <b> bold <i>text</i> </b> normal text " + for tag in ("b","i"): + opener,closer = makeHTMLTags(tag) + patt = originalTextFor(opener + SkipTo(closer) + closer) + print(patt.searchString(src)[0]) + prints:: + ['<b> bold <i>text</i> </b>'] + ['<i>text</i>'] + """ + locMarker = Empty().setParseAction(lambda s,loc,t: loc) + endlocMarker = locMarker.copy() + endlocMarker.callPreparse = False + matchExpr = locMarker("_original_start") + expr + endlocMarker("_original_end") + if asString: + extractText = lambda s,l,t: s[t._original_start:t._original_end] + else: + def extractText(s,l,t): + t[:] = [s[t.pop('_original_start'):t.pop('_original_end')]] + matchExpr.setParseAction(extractText) + matchExpr.ignoreExprs = expr.ignoreExprs + return matchExpr + +def ungroup(expr): + """ + Helper to undo pyparsing's default grouping of And expressions, even + if all but one are non-empty. + """ + return TokenConverter(expr).setParseAction(lambda t:t[0]) + +def locatedExpr(expr): + """ + Helper to decorate a returned token with its starting and ending locations in the input string. + This helper adds the following results names: + - locn_start = location where matched expression begins + - locn_end = location where matched expression ends + - value = the actual parsed results + + Be careful if the input text contains C{<TAB>} characters, you may want to call + C{L{ParserElement.parseWithTabs}} + + Example:: + wd = Word(alphas) + for match in locatedExpr(wd).searchString("ljsdf123lksdjjf123lkkjj1222"): + print(match) + prints:: + [[0, 'ljsdf', 5]] + [[8, 'lksdjjf', 15]] + [[18, 'lkkjj', 23]] + """ + locator = Empty().setParseAction(lambda s,l,t: l) + return Group(locator("locn_start") + expr("value") + locator.copy().leaveWhitespace()("locn_end")) + + +# convenience constants for positional expressions +empty = Empty().setName("empty") +lineStart = LineStart().setName("lineStart") +lineEnd = LineEnd().setName("lineEnd") +stringStart = StringStart().setName("stringStart") +stringEnd = StringEnd().setName("stringEnd") + +_escapedPunc = Word( _bslash, r"\[]-*.$+^?()~ ", exact=2 ).setParseAction(lambda s,l,t:t[0][1]) +_escapedHexChar = Regex(r"\\0?[xX][0-9a-fA-F]+").setParseAction(lambda s,l,t:unichr(int(t[0].lstrip(r'\0x'),16))) +_escapedOctChar = Regex(r"\\0[0-7]+").setParseAction(lambda s,l,t:unichr(int(t[0][1:],8))) +_singleChar = _escapedPunc | _escapedHexChar | _escapedOctChar | CharsNotIn(r'\]', exact=1) +_charRange = Group(_singleChar + Suppress("-") + _singleChar) +_reBracketExpr = Literal("[") + Optional("^").setResultsName("negate") + Group( OneOrMore( _charRange | _singleChar ) ).setResultsName("body") + "]" + +def srange(s): + r""" + Helper to easily define string ranges for use in Word construction. Borrows + syntax from regexp '[]' string range definitions:: + srange("[0-9]") -> "0123456789" + srange("[a-z]") -> "abcdefghijklmnopqrstuvwxyz" + srange("[a-z$_]") -> "abcdefghijklmnopqrstuvwxyz$_" + The input string must be enclosed in []'s, and the returned string is the expanded + character set joined into a single string. + The values enclosed in the []'s may be: + - a single character + - an escaped character with a leading backslash (such as C{\-} or C{\]}) + - an escaped hex character with a leading C{'\x'} (C{\x21}, which is a C{'!'} character) + (C{\0x##} is also supported for backwards compatibility) + - an escaped octal character with a leading C{'\0'} (C{\041}, which is a C{'!'} character) + - a range of any of the above, separated by a dash (C{'a-z'}, etc.) + - any combination of the above (C{'aeiouy'}, C{'a-zA-Z0-9_$'}, etc.) + """ + _expanded = lambda p: p if not isinstance(p,ParseResults) else ''.join(unichr(c) for c in range(ord(p[0]),ord(p[1])+1)) + try: + return "".join(_expanded(part) for part in _reBracketExpr.parseString(s).body) + except Exception: + return "" + +def matchOnlyAtCol(n): + """ + Helper method for defining parse actions that require matching at a specific + column in the input text. + """ + def verifyCol(strg,locn,toks): + if col(locn,strg) != n: + raise ParseException(strg,locn,"matched token not at column %d" % n) + return verifyCol + +def replaceWith(replStr): + """ + Helper method for common parse actions that simply return a literal value. Especially + useful when used with C{L{transformString<ParserElement.transformString>}()}. + + Example:: + num = Word(nums).setParseAction(lambda toks: int(toks[0])) + na = oneOf("N/A NA").setParseAction(replaceWith(math.nan)) + term = na | num + + OneOrMore(term).parseString("324 234 N/A 234") # -> [324, 234, nan, 234] + """ + return lambda s,l,t: [replStr] + +def removeQuotes(s,l,t): + """ + Helper parse action for removing quotation marks from parsed quoted strings. + + Example:: + # by default, quotation marks are included in parsed results + quotedString.parseString("'Now is the Winter of our Discontent'") # -> ["'Now is the Winter of our Discontent'"] + + # use removeQuotes to strip quotation marks from parsed results + quotedString.setParseAction(removeQuotes) + quotedString.parseString("'Now is the Winter of our Discontent'") # -> ["Now is the Winter of our Discontent"] + """ + return t[0][1:-1] + +def tokenMap(func, *args): + """ + Helper to define a parse action by mapping a function to all elements of a ParseResults list.If any additional + args are passed, they are forwarded to the given function as additional arguments after + the token, as in C{hex_integer = Word(hexnums).setParseAction(tokenMap(int, 16))}, which will convert the + parsed data to an integer using base 16. + + Example (compare the last to example in L{ParserElement.transformString}:: + hex_ints = OneOrMore(Word(hexnums)).setParseAction(tokenMap(int, 16)) + hex_ints.runTests(''' + 00 11 22 aa FF 0a 0d 1a + ''') + + upperword = Word(alphas).setParseAction(tokenMap(str.upper)) + OneOrMore(upperword).runTests(''' + my kingdom for a horse + ''') + + wd = Word(alphas).setParseAction(tokenMap(str.title)) + OneOrMore(wd).setParseAction(' '.join).runTests(''' + now is the winter of our discontent made glorious summer by this sun of york + ''') + prints:: + 00 11 22 aa FF 0a 0d 1a + [0, 17, 34, 170, 255, 10, 13, 26] + + my kingdom for a horse + ['MY', 'KINGDOM', 'FOR', 'A', 'HORSE'] + + now is the winter of our discontent made glorious summer by this sun of york + ['Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York'] + """ + def pa(s,l,t): + return [func(tokn, *args) for tokn in t] + + try: + func_name = getattr(func, '__name__', + getattr(func, '__class__').__name__) + except Exception: + func_name = str(func) + pa.__name__ = func_name + + return pa + +upcaseTokens = tokenMap(lambda t: _ustr(t).upper()) +"""(Deprecated) Helper parse action to convert tokens to upper case. Deprecated in favor of L{pyparsing_common.upcaseTokens}""" + +downcaseTokens = tokenMap(lambda t: _ustr(t).lower()) +"""(Deprecated) Helper parse action to convert tokens to lower case. Deprecated in favor of L{pyparsing_common.downcaseTokens}""" + +def _makeTags(tagStr, xml): + """Internal helper to construct opening and closing tag expressions, given a tag name""" + if isinstance(tagStr,basestring): + resname = tagStr + tagStr = Keyword(tagStr, caseless=not xml) + else: + resname = tagStr.name + + tagAttrName = Word(alphas,alphanums+"_-:") + if (xml): + tagAttrValue = dblQuotedString.copy().setParseAction( removeQuotes ) + openTag = Suppress("<") + tagStr("tag") + \ + Dict(ZeroOrMore(Group( tagAttrName + Suppress("=") + tagAttrValue ))) + \ + Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">") + else: + printablesLessRAbrack = "".join(c for c in printables if c not in ">") + tagAttrValue = quotedString.copy().setParseAction( removeQuotes ) | Word(printablesLessRAbrack) + openTag = Suppress("<") + tagStr("tag") + \ + Dict(ZeroOrMore(Group( tagAttrName.setParseAction(downcaseTokens) + \ + Optional( Suppress("=") + tagAttrValue ) ))) + \ + Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">") + closeTag = Combine(_L("</") + tagStr + ">") + + openTag = openTag.setResultsName("start"+"".join(resname.replace(":"," ").title().split())).setName("<%s>" % resname) + closeTag = closeTag.setResultsName("end"+"".join(resname.replace(":"," ").title().split())).setName("</%s>" % resname) + openTag.tag = resname + closeTag.tag = resname + return openTag, closeTag + +def makeHTMLTags(tagStr): + """ + Helper to construct opening and closing tag expressions for HTML, given a tag name. Matches + tags in either upper or lower case, attributes with namespaces and with quoted or unquoted values. + + Example:: + text = '<td>More info at the <a href="http://pyparsing.wikispaces.com">pyparsing</a> wiki page</td>' + # makeHTMLTags returns pyparsing expressions for the opening and closing tags as a 2-tuple + a,a_end = makeHTMLTags("A") + link_expr = a + SkipTo(a_end)("link_text") + a_end + + for link in link_expr.searchString(text): + # attributes in the <A> tag (like "href" shown here) are also accessible as named results + print(link.link_text, '->', link.href) + prints:: + pyparsing -> http://pyparsing.wikispaces.com + """ + return _makeTags( tagStr, False ) + +def makeXMLTags(tagStr): + """ + Helper to construct opening and closing tag expressions for XML, given a tag name. Matches + tags only in the given upper/lower case. + + Example: similar to L{makeHTMLTags} + """ + return _makeTags( tagStr, True ) + +def withAttribute(*args,**attrDict): + """ + Helper to create a validating parse action to be used with start tags created + with C{L{makeXMLTags}} or C{L{makeHTMLTags}}. Use C{withAttribute} to qualify a starting tag + with a required attribute value, to avoid false matches on common tags such as + C{<TD>} or C{<DIV>}. + + Call C{withAttribute} with a series of attribute names and values. Specify the list + of filter attributes names and values as: + - keyword arguments, as in C{(align="right")}, or + - as an explicit dict with C{**} operator, when an attribute name is also a Python + reserved word, as in C{**{"class":"Customer", "align":"right"}} + - a list of name-value tuples, as in ( ("ns1:class", "Customer"), ("ns2:align","right") ) + For attribute names with a namespace prefix, you must use the second form. Attribute + names are matched insensitive to upper/lower case. + + If just testing for C{class} (with or without a namespace), use C{L{withClass}}. + + To verify that the attribute exists, but without specifying a value, pass + C{withAttribute.ANY_VALUE} as the value. + + Example:: + html = ''' + <div> + Some text + <div type="grid">1 4 0 1 0</div> + <div type="graph">1,3 2,3 1,1</div> + <div>this has no type</div> + </div> + + ''' + div,div_end = makeHTMLTags("div") + + # only match div tag having a type attribute with value "grid" + div_grid = div().setParseAction(withAttribute(type="grid")) + grid_expr = div_grid + SkipTo(div | div_end)("body") + for grid_header in grid_expr.searchString(html): + print(grid_header.body) + + # construct a match with any div tag having a type attribute, regardless of the value + div_any_type = div().setParseAction(withAttribute(type=withAttribute.ANY_VALUE)) + div_expr = div_any_type + SkipTo(div | div_end)("body") + for div_header in div_expr.searchString(html): + print(div_header.body) + prints:: + 1 4 0 1 0 + + 1 4 0 1 0 + 1,3 2,3 1,1 + """ + if args: + attrs = args[:] + else: + attrs = attrDict.items() + attrs = [(k,v) for k,v in attrs] + def pa(s,l,tokens): + for attrName,attrValue in attrs: + if attrName not in tokens: + raise ParseException(s,l,"no matching attribute " + attrName) + if attrValue != withAttribute.ANY_VALUE and tokens[attrName] != attrValue: + raise ParseException(s,l,"attribute '%s' has value '%s', must be '%s'" % + (attrName, tokens[attrName], attrValue)) + return pa +withAttribute.ANY_VALUE = object() + +def withClass(classname, namespace=''): + """ + Simplified version of C{L{withAttribute}} when matching on a div class - made + difficult because C{class} is a reserved word in Python. + + Example:: + html = ''' + <div> + Some text + <div class="grid">1 4 0 1 0</div> + <div class="graph">1,3 2,3 1,1</div> + <div>this <div> has no class</div> + </div> + + ''' + div,div_end = makeHTMLTags("div") + div_grid = div().setParseAction(withClass("grid")) + + grid_expr = div_grid + SkipTo(div | div_end)("body") + for grid_header in grid_expr.searchString(html): + print(grid_header.body) + + div_any_type = div().setParseAction(withClass(withAttribute.ANY_VALUE)) + div_expr = div_any_type + SkipTo(div | div_end)("body") + for div_header in div_expr.searchString(html): + print(div_header.body) + prints:: + 1 4 0 1 0 + + 1 4 0 1 0 + 1,3 2,3 1,1 + """ + classattr = "%s:class" % namespace if namespace else "class" + return withAttribute(**{classattr : classname}) + +opAssoc = _Constants() +opAssoc.LEFT = object() +opAssoc.RIGHT = object() + +def infixNotation( baseExpr, opList, lpar=Suppress('('), rpar=Suppress(')') ): + """ + Helper method for constructing grammars of expressions made up of + operators working in a precedence hierarchy. Operators may be unary or + binary, left- or right-associative. Parse actions can also be attached + to operator expressions. The generated parser will also recognize the use + of parentheses to override operator precedences (see example below). + + Note: if you define a deep operator list, you may see performance issues + when using infixNotation. See L{ParserElement.enablePackrat} for a + mechanism to potentially improve your parser performance. + + Parameters: + - baseExpr - expression representing the most basic element for the nested + - opList - list of tuples, one for each operator precedence level in the + expression grammar; each tuple is of the form + (opExpr, numTerms, rightLeftAssoc, parseAction), where: + - opExpr is the pyparsing expression for the operator; + may also be a string, which will be converted to a Literal; + if numTerms is 3, opExpr is a tuple of two expressions, for the + two operators separating the 3 terms + - numTerms is the number of terms for this operator (must + be 1, 2, or 3) + - rightLeftAssoc is the indicator whether the operator is + right or left associative, using the pyparsing-defined + constants C{opAssoc.RIGHT} and C{opAssoc.LEFT}. + - parseAction is the parse action to be associated with + expressions matching this operator expression (the + parse action tuple member may be omitted); if the parse action + is passed a tuple or list of functions, this is equivalent to + calling C{setParseAction(*fn)} (L{ParserElement.setParseAction}) + - lpar - expression for matching left-parentheses (default=C{Suppress('(')}) + - rpar - expression for matching right-parentheses (default=C{Suppress(')')}) + + Example:: + # simple example of four-function arithmetic with ints and variable names + integer = pyparsing_common.signed_integer + varname = pyparsing_common.identifier + + arith_expr = infixNotation(integer | varname, + [ + ('-', 1, opAssoc.RIGHT), + (oneOf('* /'), 2, opAssoc.LEFT), + (oneOf('+ -'), 2, opAssoc.LEFT), + ]) + + arith_expr.runTests(''' + 5+3*6 + (5+3)*6 + -2--11 + ''', fullDump=False) + prints:: + 5+3*6 + [[5, '+', [3, '*', 6]]] + + (5+3)*6 + [[[5, '+', 3], '*', 6]] + + -2--11 + [[['-', 2], '-', ['-', 11]]] + """ + ret = Forward() + lastExpr = baseExpr | ( lpar + ret + rpar ) + for i,operDef in enumerate(opList): + opExpr,arity,rightLeftAssoc,pa = (operDef + (None,))[:4] + termName = "%s term" % opExpr if arity < 3 else "%s%s term" % opExpr + if arity == 3: + if opExpr is None or len(opExpr) != 2: + raise ValueError("if numterms=3, opExpr must be a tuple or list of two expressions") + opExpr1, opExpr2 = opExpr + thisExpr = Forward().setName(termName) + if rightLeftAssoc == opAssoc.LEFT: + if arity == 1: + matchExpr = FollowedBy(lastExpr + opExpr) + Group( lastExpr + OneOrMore( opExpr ) ) + elif arity == 2: + if opExpr is not None: + matchExpr = FollowedBy(lastExpr + opExpr + lastExpr) + Group( lastExpr + OneOrMore( opExpr + lastExpr ) ) + else: + matchExpr = FollowedBy(lastExpr+lastExpr) + Group( lastExpr + OneOrMore(lastExpr) ) + elif arity == 3: + matchExpr = FollowedBy(lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr) + \ + Group( lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr ) + else: + raise ValueError("operator must be unary (1), binary (2), or ternary (3)") + elif rightLeftAssoc == opAssoc.RIGHT: + if arity == 1: + # try to avoid LR with this extra test + if not isinstance(opExpr, Optional): + opExpr = Optional(opExpr) + matchExpr = FollowedBy(opExpr.expr + thisExpr) + Group( opExpr + thisExpr ) + elif arity == 2: + if opExpr is not None: + matchExpr = FollowedBy(lastExpr + opExpr + thisExpr) + Group( lastExpr + OneOrMore( opExpr + thisExpr ) ) + else: + matchExpr = FollowedBy(lastExpr + thisExpr) + Group( lastExpr + OneOrMore( thisExpr ) ) + elif arity == 3: + matchExpr = FollowedBy(lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr) + \ + Group( lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr ) + else: + raise ValueError("operator must be unary (1), binary (2), or ternary (3)") + else: + raise ValueError("operator must indicate right or left associativity") + if pa: + if isinstance(pa, (tuple, list)): + matchExpr.setParseAction(*pa) + else: + matchExpr.setParseAction(pa) + thisExpr <<= ( matchExpr.setName(termName) | lastExpr ) + lastExpr = thisExpr + ret <<= lastExpr + return ret + +operatorPrecedence = infixNotation +"""(Deprecated) Former name of C{L{infixNotation}}, will be dropped in a future release.""" + +dblQuotedString = Combine(Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*')+'"').setName("string enclosed in double quotes") +sglQuotedString = Combine(Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*")+"'").setName("string enclosed in single quotes") +quotedString = Combine(Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*')+'"'| + Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*")+"'").setName("quotedString using single or double quotes") +unicodeString = Combine(_L('u') + quotedString.copy()).setName("unicode string literal") + +def nestedExpr(opener="(", closer=")", content=None, ignoreExpr=quotedString.copy()): + """ + Helper method for defining nested lists enclosed in opening and closing + delimiters ("(" and ")" are the default). + + Parameters: + - opener - opening character for a nested list (default=C{"("}); can also be a pyparsing expression + - closer - closing character for a nested list (default=C{")"}); can also be a pyparsing expression + - content - expression for items within the nested lists (default=C{None}) + - ignoreExpr - expression for ignoring opening and closing delimiters (default=C{quotedString}) + + If an expression is not provided for the content argument, the nested + expression will capture all whitespace-delimited content between delimiters + as a list of separate values. + + Use the C{ignoreExpr} argument to define expressions that may contain + opening or closing characters that should not be treated as opening + or closing characters for nesting, such as quotedString or a comment + expression. Specify multiple expressions using an C{L{Or}} or C{L{MatchFirst}}. + The default is L{quotedString}, but if no expressions are to be ignored, + then pass C{None} for this argument. + + Example:: + data_type = oneOf("void int short long char float double") + decl_data_type = Combine(data_type + Optional(Word('*'))) + ident = Word(alphas+'_', alphanums+'_') + number = pyparsing_common.number + arg = Group(decl_data_type + ident) + LPAR,RPAR = map(Suppress, "()") + + code_body = nestedExpr('{', '}', ignoreExpr=(quotedString | cStyleComment)) + + c_function = (decl_data_type("type") + + ident("name") + + LPAR + Optional(delimitedList(arg), [])("args") + RPAR + + code_body("body")) + c_function.ignore(cStyleComment) + + source_code = ''' + int is_odd(int x) { + return (x%2); + } + + int dec_to_hex(char hchar) { + if (hchar >= '0' && hchar <= '9') { + return (ord(hchar)-ord('0')); + } else { + return (10+ord(hchar)-ord('A')); + } + } + ''' + for func in c_function.searchString(source_code): + print("%(name)s (%(type)s) args: %(args)s" % func) + + prints:: + is_odd (int) args: [['int', 'x']] + dec_to_hex (int) args: [['char', 'hchar']] + """ + if opener == closer: + raise ValueError("opening and closing strings cannot be the same") + if content is None: + if isinstance(opener,basestring) and isinstance(closer,basestring): + if len(opener) == 1 and len(closer)==1: + if ignoreExpr is not None: + content = (Combine(OneOrMore(~ignoreExpr + + CharsNotIn(opener+closer+ParserElement.DEFAULT_WHITE_CHARS,exact=1)) + ).setParseAction(lambda t:t[0].strip())) + else: + content = (empty.copy()+CharsNotIn(opener+closer+ParserElement.DEFAULT_WHITE_CHARS + ).setParseAction(lambda t:t[0].strip())) + else: + if ignoreExpr is not None: + content = (Combine(OneOrMore(~ignoreExpr + + ~Literal(opener) + ~Literal(closer) + + CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS,exact=1)) + ).setParseAction(lambda t:t[0].strip())) + else: + content = (Combine(OneOrMore(~Literal(opener) + ~Literal(closer) + + CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS,exact=1)) + ).setParseAction(lambda t:t[0].strip())) + else: + raise ValueError("opening and closing arguments must be strings if no content expression is given") + ret = Forward() + if ignoreExpr is not None: + ret <<= Group( Suppress(opener) + ZeroOrMore( ignoreExpr | ret | content ) + Suppress(closer) ) + else: + ret <<= Group( Suppress(opener) + ZeroOrMore( ret | content ) + Suppress(closer) ) + ret.setName('nested %s%s expression' % (opener,closer)) + return ret + +def indentedBlock(blockStatementExpr, indentStack, indent=True): + """ + Helper method for defining space-delimited indentation blocks, such as + those used to define block statements in Python source code. + + Parameters: + - blockStatementExpr - expression defining syntax of statement that + is repeated within the indented block + - indentStack - list created by caller to manage indentation stack + (multiple statementWithIndentedBlock expressions within a single grammar + should share a common indentStack) + - indent - boolean indicating whether block must be indented beyond the + the current level; set to False for block of left-most statements + (default=C{True}) + + A valid block must contain at least one C{blockStatement}. + + Example:: + data = ''' + def A(z): + A1 + B = 100 + G = A2 + A2 + A3 + B + def BB(a,b,c): + BB1 + def BBA(): + bba1 + bba2 + bba3 + C + D + def spam(x,y): + def eggs(z): + pass + ''' + + + indentStack = [1] + stmt = Forward() + + identifier = Word(alphas, alphanums) + funcDecl = ("def" + identifier + Group( "(" + Optional( delimitedList(identifier) ) + ")" ) + ":") + func_body = indentedBlock(stmt, indentStack) + funcDef = Group( funcDecl + func_body ) + + rvalue = Forward() + funcCall = Group(identifier + "(" + Optional(delimitedList(rvalue)) + ")") + rvalue << (funcCall | identifier | Word(nums)) + assignment = Group(identifier + "=" + rvalue) + stmt << ( funcDef | assignment | identifier ) + + module_body = OneOrMore(stmt) + + parseTree = module_body.parseString(data) + parseTree.pprint() + prints:: + [['def', + 'A', + ['(', 'z', ')'], + ':', + [['A1'], [['B', '=', '100']], [['G', '=', 'A2']], ['A2'], ['A3']]], + 'B', + ['def', + 'BB', + ['(', 'a', 'b', 'c', ')'], + ':', + [['BB1'], [['def', 'BBA', ['(', ')'], ':', [['bba1'], ['bba2'], ['bba3']]]]]], + 'C', + 'D', + ['def', + 'spam', + ['(', 'x', 'y', ')'], + ':', + [[['def', 'eggs', ['(', 'z', ')'], ':', [['pass']]]]]]] + """ + def checkPeerIndent(s,l,t): + if l >= len(s): return + curCol = col(l,s) + if curCol != indentStack[-1]: + if curCol > indentStack[-1]: + raise ParseFatalException(s,l,"illegal nesting") + raise ParseException(s,l,"not a peer entry") + + def checkSubIndent(s,l,t): + curCol = col(l,s) + if curCol > indentStack[-1]: + indentStack.append( curCol ) + else: + raise ParseException(s,l,"not a subentry") + + def checkUnindent(s,l,t): + if l >= len(s): return + curCol = col(l,s) + if not(indentStack and curCol < indentStack[-1] and curCol <= indentStack[-2]): + raise ParseException(s,l,"not an unindent") + indentStack.pop() + + NL = OneOrMore(LineEnd().setWhitespaceChars("\t ").suppress()) + INDENT = (Empty() + Empty().setParseAction(checkSubIndent)).setName('INDENT') + PEER = Empty().setParseAction(checkPeerIndent).setName('') + UNDENT = Empty().setParseAction(checkUnindent).setName('UNINDENT') + if indent: + smExpr = Group( Optional(NL) + + #~ FollowedBy(blockStatementExpr) + + INDENT + (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) + UNDENT) + else: + smExpr = Group( Optional(NL) + + (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) ) + blockStatementExpr.ignore(_bslash + LineEnd()) + return smExpr.setName('indented block') + +alphas8bit = srange(r"[\0xc0-\0xd6\0xd8-\0xf6\0xf8-\0xff]") +punc8bit = srange(r"[\0xa1-\0xbf\0xd7\0xf7]") + +anyOpenTag,anyCloseTag = makeHTMLTags(Word(alphas,alphanums+"_:").setName('any tag')) +_htmlEntityMap = dict(zip("gt lt amp nbsp quot apos".split(),'><& "\'')) +commonHTMLEntity = Regex('&(?P<entity>' + '|'.join(_htmlEntityMap.keys()) +");").setName("common HTML entity") +def replaceHTMLEntity(t): + """Helper parser action to replace common HTML entities with their special characters""" + return _htmlEntityMap.get(t.entity) + +# it's easy to get these comment structures wrong - they're very common, so may as well make them available +cStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/').setName("C style comment") +"Comment of the form C{/* ... */}" + +htmlComment = Regex(r"<!--[\s\S]*?-->").setName("HTML comment") +"Comment of the form C{<!-- ... -->}" + +restOfLine = Regex(r".*").leaveWhitespace().setName("rest of line") +dblSlashComment = Regex(r"//(?:\\\n|[^\n])*").setName("// comment") +"Comment of the form C{// ... (to end of line)}" + +cppStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/'| dblSlashComment).setName("C++ style comment") +"Comment of either form C{L{cStyleComment}} or C{L{dblSlashComment}}" + +javaStyleComment = cppStyleComment +"Same as C{L{cppStyleComment}}" + +pythonStyleComment = Regex(r"#.*").setName("Python style comment") +"Comment of the form C{# ... (to end of line)}" + +_commasepitem = Combine(OneOrMore(Word(printables, excludeChars=',') + + Optional( Word(" \t") + + ~Literal(",") + ~LineEnd() ) ) ).streamline().setName("commaItem") +commaSeparatedList = delimitedList( Optional( quotedString.copy() | _commasepitem, default="") ).setName("commaSeparatedList") +"""(Deprecated) Predefined expression of 1 or more printable words or quoted strings, separated by commas. + This expression is deprecated in favor of L{pyparsing_common.comma_separated_list}.""" + +# some other useful expressions - using lower-case class name since we are really using this as a namespace +class pyparsing_common: + """ + Here are some common low-level expressions that may be useful in jump-starting parser development: + - numeric forms (L{integers<integer>}, L{reals<real>}, L{scientific notation<sci_real>}) + - common L{programming identifiers<identifier>} + - network addresses (L{MAC<mac_address>}, L{IPv4<ipv4_address>}, L{IPv6<ipv6_address>}) + - ISO8601 L{dates<iso8601_date>} and L{datetime<iso8601_datetime>} + - L{UUID<uuid>} + - L{comma-separated list<comma_separated_list>} + Parse actions: + - C{L{convertToInteger}} + - C{L{convertToFloat}} + - C{L{convertToDate}} + - C{L{convertToDatetime}} + - C{L{stripHTMLTags}} + - C{L{upcaseTokens}} + - C{L{downcaseTokens}} + + Example:: + pyparsing_common.number.runTests(''' + # any int or real number, returned as the appropriate type + 100 + -100 + +100 + 3.14159 + 6.02e23 + 1e-12 + ''') + + pyparsing_common.fnumber.runTests(''' + # any int or real number, returned as float + 100 + -100 + +100 + 3.14159 + 6.02e23 + 1e-12 + ''') + + pyparsing_common.hex_integer.runTests(''' + # hex numbers + 100 + FF + ''') + + pyparsing_common.fraction.runTests(''' + # fractions + 1/2 + -3/4 + ''') + + pyparsing_common.mixed_integer.runTests(''' + # mixed fractions + 1 + 1/2 + -3/4 + 1-3/4 + ''') + + import uuid + pyparsing_common.uuid.setParseAction(tokenMap(uuid.UUID)) + pyparsing_common.uuid.runTests(''' + # uuid + 12345678-1234-5678-1234-567812345678 + ''') + prints:: + # any int or real number, returned as the appropriate type + 100 + [100] + + -100 + [-100] + + +100 + [100] + + 3.14159 + [3.14159] + + 6.02e23 + [6.02e+23] + + 1e-12 + [1e-12] + + # any int or real number, returned as float + 100 + [100.0] + + -100 + [-100.0] + + +100 + [100.0] + + 3.14159 + [3.14159] + + 6.02e23 + [6.02e+23] + + 1e-12 + [1e-12] + + # hex numbers + 100 + [256] + + FF + [255] + + # fractions + 1/2 + [0.5] + + -3/4 + [-0.75] + + # mixed fractions + 1 + [1] + + 1/2 + [0.5] + + -3/4 + [-0.75] + + 1-3/4 + [1.75] + + # uuid + 12345678-1234-5678-1234-567812345678 + [UUID('12345678-1234-5678-1234-567812345678')] + """ + + convertToInteger = tokenMap(int) + """ + Parse action for converting parsed integers to Python int + """ + + convertToFloat = tokenMap(float) + """ + Parse action for converting parsed numbers to Python float + """ + + integer = Word(nums).setName("integer").setParseAction(convertToInteger) + """expression that parses an unsigned integer, returns an int""" + + hex_integer = Word(hexnums).setName("hex integer").setParseAction(tokenMap(int,16)) + """expression that parses a hexadecimal integer, returns an int""" + + signed_integer = Regex(r'[+-]?\d+').setName("signed integer").setParseAction(convertToInteger) + """expression that parses an integer with optional leading sign, returns an int""" + + fraction = (signed_integer().setParseAction(convertToFloat) + '/' + signed_integer().setParseAction(convertToFloat)).setName("fraction") + """fractional expression of an integer divided by an integer, returns a float""" + fraction.addParseAction(lambda t: t[0]/t[-1]) + + mixed_integer = (fraction | signed_integer + Optional(Optional('-').suppress() + fraction)).setName("fraction or mixed integer-fraction") + """mixed integer of the form 'integer - fraction', with optional leading integer, returns float""" + mixed_integer.addParseAction(sum) + + real = Regex(r'[+-]?\d+\.\d*').setName("real number").setParseAction(convertToFloat) + """expression that parses a floating point number and returns a float""" + + sci_real = Regex(r'[+-]?\d+([eE][+-]?\d+|\.\d*([eE][+-]?\d+)?)').setName("real number with scientific notation").setParseAction(convertToFloat) + """expression that parses a floating point number with optional scientific notation and returns a float""" + + # streamlining this expression makes the docs nicer-looking + number = (sci_real | real | signed_integer).streamline() + """any numeric expression, returns the corresponding Python type""" + + fnumber = Regex(r'[+-]?\d+\.?\d*([eE][+-]?\d+)?').setName("fnumber").setParseAction(convertToFloat) + """any int or real number, returned as float""" + + identifier = Word(alphas+'_', alphanums+'_').setName("identifier") + """typical code identifier (leading alpha or '_', followed by 0 or more alphas, nums, or '_')""" + + ipv4_address = Regex(r'(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})(\.(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})){3}').setName("IPv4 address") + "IPv4 address (C{0.0.0.0 - 255.255.255.255})" + + _ipv6_part = Regex(r'[0-9a-fA-F]{1,4}').setName("hex_integer") + _full_ipv6_address = (_ipv6_part + (':' + _ipv6_part)*7).setName("full IPv6 address") + _short_ipv6_address = (Optional(_ipv6_part + (':' + _ipv6_part)*(0,6)) + "::" + Optional(_ipv6_part + (':' + _ipv6_part)*(0,6))).setName("short IPv6 address") + _short_ipv6_address.addCondition(lambda t: sum(1 for tt in t if pyparsing_common._ipv6_part.matches(tt)) < 8) + _mixed_ipv6_address = ("::ffff:" + ipv4_address).setName("mixed IPv6 address") + ipv6_address = Combine((_full_ipv6_address | _mixed_ipv6_address | _short_ipv6_address).setName("IPv6 address")).setName("IPv6 address") + "IPv6 address (long, short, or mixed form)" + + mac_address = Regex(r'[0-9a-fA-F]{2}([:.-])[0-9a-fA-F]{2}(?:\1[0-9a-fA-F]{2}){4}').setName("MAC address") + "MAC address xx:xx:xx:xx:xx (may also have '-' or '.' delimiters)" + + @staticmethod + def convertToDate(fmt="%Y-%m-%d"): + """ + Helper to create a parse action for converting parsed date string to Python datetime.date + + Params - + - fmt - format to be passed to datetime.strptime (default=C{"%Y-%m-%d"}) + + Example:: + date_expr = pyparsing_common.iso8601_date.copy() + date_expr.setParseAction(pyparsing_common.convertToDate()) + print(date_expr.parseString("1999-12-31")) + prints:: + [datetime.date(1999, 12, 31)] + """ + def cvt_fn(s,l,t): + try: + return datetime.strptime(t[0], fmt).date() + except ValueError as ve: + raise ParseException(s, l, str(ve)) + return cvt_fn + + @staticmethod + def convertToDatetime(fmt="%Y-%m-%dT%H:%M:%S.%f"): + """ + Helper to create a parse action for converting parsed datetime string to Python datetime.datetime + + Params - + - fmt - format to be passed to datetime.strptime (default=C{"%Y-%m-%dT%H:%M:%S.%f"}) + + Example:: + dt_expr = pyparsing_common.iso8601_datetime.copy() + dt_expr.setParseAction(pyparsing_common.convertToDatetime()) + print(dt_expr.parseString("1999-12-31T23:59:59.999")) + prints:: + [datetime.datetime(1999, 12, 31, 23, 59, 59, 999000)] + """ + def cvt_fn(s,l,t): + try: + return datetime.strptime(t[0], fmt) + except ValueError as ve: + raise ParseException(s, l, str(ve)) + return cvt_fn + + iso8601_date = Regex(r'(?P<year>\d{4})(?:-(?P<month>\d\d)(?:-(?P<day>\d\d))?)?').setName("ISO8601 date") + "ISO8601 date (C{yyyy-mm-dd})" + + iso8601_datetime = Regex(r'(?P<year>\d{4})-(?P<month>\d\d)-(?P<day>\d\d)[T ](?P<hour>\d\d):(?P<minute>\d\d)(:(?P<second>\d\d(\.\d*)?)?)?(?P<tz>Z|[+-]\d\d:?\d\d)?').setName("ISO8601 datetime") + "ISO8601 datetime (C{yyyy-mm-ddThh:mm:ss.s(Z|+-00:00)}) - trailing seconds, milliseconds, and timezone optional; accepts separating C{'T'} or C{' '}" + + uuid = Regex(r'[0-9a-fA-F]{8}(-[0-9a-fA-F]{4}){3}-[0-9a-fA-F]{12}').setName("UUID") + "UUID (C{xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx})" + + _html_stripper = anyOpenTag.suppress() | anyCloseTag.suppress() + @staticmethod + def stripHTMLTags(s, l, tokens): + """ + Parse action to remove HTML tags from web page HTML source + + Example:: + # strip HTML links from normal text + text = '<td>More info at the <a href="http://pyparsing.wikispaces.com">pyparsing</a> wiki page</td>' + td,td_end = makeHTMLTags("TD") + table_text = td + SkipTo(td_end).setParseAction(pyparsing_common.stripHTMLTags)("body") + td_end + + print(table_text.parseString(text).body) # -> 'More info at the pyparsing wiki page' + """ + return pyparsing_common._html_stripper.transformString(tokens[0]) + + _commasepitem = Combine(OneOrMore(~Literal(",") + ~LineEnd() + Word(printables, excludeChars=',') + + Optional( White(" \t") ) ) ).streamline().setName("commaItem") + comma_separated_list = delimitedList( Optional( quotedString.copy() | _commasepitem, default="") ).setName("comma separated list") + """Predefined expression of 1 or more printable words or quoted strings, separated by commas.""" + + upcaseTokens = staticmethod(tokenMap(lambda t: _ustr(t).upper())) + """Parse action to convert tokens to upper case.""" + + downcaseTokens = staticmethod(tokenMap(lambda t: _ustr(t).lower())) + """Parse action to convert tokens to lower case.""" + + +if __name__ == "__main__": + + selectToken = CaselessLiteral("select") + fromToken = CaselessLiteral("from") + + ident = Word(alphas, alphanums + "_$") + + columnName = delimitedList(ident, ".", combine=True).setParseAction(upcaseTokens) + columnNameList = Group(delimitedList(columnName)).setName("columns") + columnSpec = ('*' | columnNameList) + + tableName = delimitedList(ident, ".", combine=True).setParseAction(upcaseTokens) + tableNameList = Group(delimitedList(tableName)).setName("tables") + + simpleSQL = selectToken("command") + columnSpec("columns") + fromToken + tableNameList("tables") + + # demo runTests method, including embedded comments in test string + simpleSQL.runTests(""" + # '*' as column list and dotted table name + select * from SYS.XYZZY + + # caseless match on "SELECT", and casts back to "select" + SELECT * from XYZZY, ABC + + # list of column names, and mixed case SELECT keyword + Select AA,BB,CC from Sys.dual + + # multiple tables + Select A, B, C from Sys.dual, Table2 + + # invalid SELECT keyword - should fail + Xelect A, B, C from Sys.dual + + # incomplete command - should fail + Select + + # invalid column name - should fail + Select ^^^ frox Sys.dual + + """) + + pyparsing_common.number.runTests(""" + 100 + -100 + +100 + 3.14159 + 6.02e23 + 1e-12 + """) + + # any int or real number, returned as float + pyparsing_common.fnumber.runTests(""" + 100 + -100 + +100 + 3.14159 + 6.02e23 + 1e-12 + """) + + pyparsing_common.hex_integer.runTests(""" + 100 + FF + """) + + import uuid + pyparsing_common.uuid.setParseAction(tokenMap(uuid.UUID)) + pyparsing_common.uuid.runTests(""" + 12345678-1234-5678-1234-567812345678 + """) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/six.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/six.py new file mode 100644 index 0000000..190c023 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/_vendor/six.py @@ -0,0 +1,868 @@ +"""Utilities for writing code that runs on Python 2 and 3""" + +# Copyright (c) 2010-2015 Benjamin Peterson +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in all +# copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. + +from __future__ import absolute_import + +import functools +import itertools +import operator +import sys +import types + +__author__ = "Benjamin Peterson <benjamin@python.org>" +__version__ = "1.10.0" + + +# Useful for very coarse version differentiation. +PY2 = sys.version_info[0] == 2 +PY3 = sys.version_info[0] == 3 +PY34 = sys.version_info[0:2] >= (3, 4) + +if PY3: + string_types = str, + integer_types = int, + class_types = type, + text_type = str + binary_type = bytes + + MAXSIZE = sys.maxsize +else: + string_types = basestring, + integer_types = (int, long) + class_types = (type, types.ClassType) + text_type = unicode + binary_type = str + + if sys.platform.startswith("java"): + # Jython always uses 32 bits. + MAXSIZE = int((1 << 31) - 1) + else: + # It's possible to have sizeof(long) != sizeof(Py_ssize_t). + class X(object): + + def __len__(self): + return 1 << 31 + try: + len(X()) + except OverflowError: + # 32-bit + MAXSIZE = int((1 << 31) - 1) + else: + # 64-bit + MAXSIZE = int((1 << 63) - 1) + del X + + +def _add_doc(func, doc): + """Add documentation to a function.""" + func.__doc__ = doc + + +def _import_module(name): + """Import module, returning the module after the last dot.""" + __import__(name) + return sys.modules[name] + + +class _LazyDescr(object): + + def __init__(self, name): + self.name = name + + def __get__(self, obj, tp): + result = self._resolve() + setattr(obj, self.name, result) # Invokes __set__. + try: + # This is a bit ugly, but it avoids running this again by + # removing this descriptor. + delattr(obj.__class__, self.name) + except AttributeError: + pass + return result + + +class MovedModule(_LazyDescr): + + def __init__(self, name, old, new=None): + super(MovedModule, self).__init__(name) + if PY3: + if new is None: + new = name + self.mod = new + else: + self.mod = old + + def _resolve(self): + return _import_module(self.mod) + + def __getattr__(self, attr): + _module = self._resolve() + value = getattr(_module, attr) + setattr(self, attr, value) + return value + + +class _LazyModule(types.ModuleType): + + def __init__(self, name): + super(_LazyModule, self).__init__(name) + self.__doc__ = self.__class__.__doc__ + + def __dir__(self): + attrs = ["__doc__", "__name__"] + attrs += [attr.name for attr in self._moved_attributes] + return attrs + + # Subclasses should override this + _moved_attributes = [] + + +class MovedAttribute(_LazyDescr): + + def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None): + super(MovedAttribute, self).__init__(name) + if PY3: + if new_mod is None: + new_mod = name + self.mod = new_mod + if new_attr is None: + if old_attr is None: + new_attr = name + else: + new_attr = old_attr + self.attr = new_attr + else: + self.mod = old_mod + if old_attr is None: + old_attr = name + self.attr = old_attr + + def _resolve(self): + module = _import_module(self.mod) + return getattr(module, self.attr) + + +class _SixMetaPathImporter(object): + + """ + A meta path importer to import six.moves and its submodules. + + This class implements a PEP302 finder and loader. It should be compatible + with Python 2.5 and all existing versions of Python3 + """ + + def __init__(self, six_module_name): + self.name = six_module_name + self.known_modules = {} + + def _add_module(self, mod, *fullnames): + for fullname in fullnames: + self.known_modules[self.name + "." + fullname] = mod + + def _get_module(self, fullname): + return self.known_modules[self.name + "." + fullname] + + def find_module(self, fullname, path=None): + if fullname in self.known_modules: + return self + return None + + def __get_module(self, fullname): + try: + return self.known_modules[fullname] + except KeyError: + raise ImportError("This loader does not know module " + fullname) + + def load_module(self, fullname): + try: + # in case of a reload + return sys.modules[fullname] + except KeyError: + pass + mod = self.__get_module(fullname) + if isinstance(mod, MovedModule): + mod = mod._resolve() + else: + mod.__loader__ = self + sys.modules[fullname] = mod + return mod + + def is_package(self, fullname): + """ + Return true, if the named module is a package. + + We need this method to get correct spec objects with + Python 3.4 (see PEP451) + """ + return hasattr(self.__get_module(fullname), "__path__") + + def get_code(self, fullname): + """Return None + + Required, if is_package is implemented""" + self.__get_module(fullname) # eventually raises ImportError + return None + get_source = get_code # same as get_code + +_importer = _SixMetaPathImporter(__name__) + + +class _MovedItems(_LazyModule): + + """Lazy loading of moved objects""" + __path__ = [] # mark as package + + +_moved_attributes = [ + MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"), + MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"), + MovedAttribute("filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse"), + MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"), + MovedAttribute("intern", "__builtin__", "sys"), + MovedAttribute("map", "itertools", "builtins", "imap", "map"), + MovedAttribute("getcwd", "os", "os", "getcwdu", "getcwd"), + MovedAttribute("getcwdb", "os", "os", "getcwd", "getcwdb"), + MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"), + MovedAttribute("reload_module", "__builtin__", "importlib" if PY34 else "imp", "reload"), + MovedAttribute("reduce", "__builtin__", "functools"), + MovedAttribute("shlex_quote", "pipes", "shlex", "quote"), + MovedAttribute("StringIO", "StringIO", "io"), + MovedAttribute("UserDict", "UserDict", "collections"), + MovedAttribute("UserList", "UserList", "collections"), + MovedAttribute("UserString", "UserString", "collections"), + MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"), + MovedAttribute("zip", "itertools", "builtins", "izip", "zip"), + MovedAttribute("zip_longest", "itertools", "itertools", "izip_longest", "zip_longest"), + MovedModule("builtins", "__builtin__"), + MovedModule("configparser", "ConfigParser"), + MovedModule("copyreg", "copy_reg"), + MovedModule("dbm_gnu", "gdbm", "dbm.gnu"), + MovedModule("_dummy_thread", "dummy_thread", "_dummy_thread"), + MovedModule("http_cookiejar", "cookielib", "http.cookiejar"), + MovedModule("http_cookies", "Cookie", "http.cookies"), + MovedModule("html_entities", "htmlentitydefs", "html.entities"), + MovedModule("html_parser", "HTMLParser", "html.parser"), + MovedModule("http_client", "httplib", "http.client"), + MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"), + MovedModule("email_mime_nonmultipart", "email.MIMENonMultipart", "email.mime.nonmultipart"), + MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"), + MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"), + MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"), + MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"), + MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"), + MovedModule("cPickle", "cPickle", "pickle"), + MovedModule("queue", "Queue"), + MovedModule("reprlib", "repr"), + MovedModule("socketserver", "SocketServer"), + MovedModule("_thread", "thread", "_thread"), + MovedModule("tkinter", "Tkinter"), + MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"), + MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"), + MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"), + MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"), + MovedModule("tkinter_tix", "Tix", "tkinter.tix"), + MovedModule("tkinter_ttk", "ttk", "tkinter.ttk"), + MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"), + MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"), + MovedModule("tkinter_colorchooser", "tkColorChooser", + "tkinter.colorchooser"), + MovedModule("tkinter_commondialog", "tkCommonDialog", + "tkinter.commondialog"), + MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"), + MovedModule("tkinter_font", "tkFont", "tkinter.font"), + MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"), + MovedModule("tkinter_tksimpledialog", "tkSimpleDialog", + "tkinter.simpledialog"), + MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"), + MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"), + MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"), + MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"), + MovedModule("xmlrpc_client", "xmlrpclib", "xmlrpc.client"), + MovedModule("xmlrpc_server", "SimpleXMLRPCServer", "xmlrpc.server"), +] +# Add windows specific modules. +if sys.platform == "win32": + _moved_attributes += [ + MovedModule("winreg", "_winreg"), + ] + +for attr in _moved_attributes: + setattr(_MovedItems, attr.name, attr) + if isinstance(attr, MovedModule): + _importer._add_module(attr, "moves." + attr.name) +del attr + +_MovedItems._moved_attributes = _moved_attributes + +moves = _MovedItems(__name__ + ".moves") +_importer._add_module(moves, "moves") + + +class Module_six_moves_urllib_parse(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_parse""" + + +_urllib_parse_moved_attributes = [ + MovedAttribute("ParseResult", "urlparse", "urllib.parse"), + MovedAttribute("SplitResult", "urlparse", "urllib.parse"), + MovedAttribute("parse_qs", "urlparse", "urllib.parse"), + MovedAttribute("parse_qsl", "urlparse", "urllib.parse"), + MovedAttribute("urldefrag", "urlparse", "urllib.parse"), + MovedAttribute("urljoin", "urlparse", "urllib.parse"), + MovedAttribute("urlparse", "urlparse", "urllib.parse"), + MovedAttribute("urlsplit", "urlparse", "urllib.parse"), + MovedAttribute("urlunparse", "urlparse", "urllib.parse"), + MovedAttribute("urlunsplit", "urlparse", "urllib.parse"), + MovedAttribute("quote", "urllib", "urllib.parse"), + MovedAttribute("quote_plus", "urllib", "urllib.parse"), + MovedAttribute("unquote", "urllib", "urllib.parse"), + MovedAttribute("unquote_plus", "urllib", "urllib.parse"), + MovedAttribute("urlencode", "urllib", "urllib.parse"), + MovedAttribute("splitquery", "urllib", "urllib.parse"), + MovedAttribute("splittag", "urllib", "urllib.parse"), + MovedAttribute("splituser", "urllib", "urllib.parse"), + MovedAttribute("uses_fragment", "urlparse", "urllib.parse"), + MovedAttribute("uses_netloc", "urlparse", "urllib.parse"), + MovedAttribute("uses_params", "urlparse", "urllib.parse"), + MovedAttribute("uses_query", "urlparse", "urllib.parse"), + MovedAttribute("uses_relative", "urlparse", "urllib.parse"), +] +for attr in _urllib_parse_moved_attributes: + setattr(Module_six_moves_urllib_parse, attr.name, attr) +del attr + +Module_six_moves_urllib_parse._moved_attributes = _urllib_parse_moved_attributes + +_importer._add_module(Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse"), + "moves.urllib_parse", "moves.urllib.parse") + + +class Module_six_moves_urllib_error(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_error""" + + +_urllib_error_moved_attributes = [ + MovedAttribute("URLError", "urllib2", "urllib.error"), + MovedAttribute("HTTPError", "urllib2", "urllib.error"), + MovedAttribute("ContentTooShortError", "urllib", "urllib.error"), +] +for attr in _urllib_error_moved_attributes: + setattr(Module_six_moves_urllib_error, attr.name, attr) +del attr + +Module_six_moves_urllib_error._moved_attributes = _urllib_error_moved_attributes + +_importer._add_module(Module_six_moves_urllib_error(__name__ + ".moves.urllib.error"), + "moves.urllib_error", "moves.urllib.error") + + +class Module_six_moves_urllib_request(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_request""" + + +_urllib_request_moved_attributes = [ + MovedAttribute("urlopen", "urllib2", "urllib.request"), + MovedAttribute("install_opener", "urllib2", "urllib.request"), + MovedAttribute("build_opener", "urllib2", "urllib.request"), + MovedAttribute("pathname2url", "urllib", "urllib.request"), + MovedAttribute("url2pathname", "urllib", "urllib.request"), + MovedAttribute("getproxies", "urllib", "urllib.request"), + MovedAttribute("Request", "urllib2", "urllib.request"), + MovedAttribute("OpenerDirector", "urllib2", "urllib.request"), + MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"), + MovedAttribute("ProxyHandler", "urllib2", "urllib.request"), + MovedAttribute("BaseHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"), + MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"), + MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"), + MovedAttribute("FileHandler", "urllib2", "urllib.request"), + MovedAttribute("FTPHandler", "urllib2", "urllib.request"), + MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"), + MovedAttribute("UnknownHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"), + MovedAttribute("urlretrieve", "urllib", "urllib.request"), + MovedAttribute("urlcleanup", "urllib", "urllib.request"), + MovedAttribute("URLopener", "urllib", "urllib.request"), + MovedAttribute("FancyURLopener", "urllib", "urllib.request"), + MovedAttribute("proxy_bypass", "urllib", "urllib.request"), +] +for attr in _urllib_request_moved_attributes: + setattr(Module_six_moves_urllib_request, attr.name, attr) +del attr + +Module_six_moves_urllib_request._moved_attributes = _urllib_request_moved_attributes + +_importer._add_module(Module_six_moves_urllib_request(__name__ + ".moves.urllib.request"), + "moves.urllib_request", "moves.urllib.request") + + +class Module_six_moves_urllib_response(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_response""" + + +_urllib_response_moved_attributes = [ + MovedAttribute("addbase", "urllib", "urllib.response"), + MovedAttribute("addclosehook", "urllib", "urllib.response"), + MovedAttribute("addinfo", "urllib", "urllib.response"), + MovedAttribute("addinfourl", "urllib", "urllib.response"), +] +for attr in _urllib_response_moved_attributes: + setattr(Module_six_moves_urllib_response, attr.name, attr) +del attr + +Module_six_moves_urllib_response._moved_attributes = _urllib_response_moved_attributes + +_importer._add_module(Module_six_moves_urllib_response(__name__ + ".moves.urllib.response"), + "moves.urllib_response", "moves.urllib.response") + + +class Module_six_moves_urllib_robotparser(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_robotparser""" + + +_urllib_robotparser_moved_attributes = [ + MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"), +] +for attr in _urllib_robotparser_moved_attributes: + setattr(Module_six_moves_urllib_robotparser, attr.name, attr) +del attr + +Module_six_moves_urllib_robotparser._moved_attributes = _urllib_robotparser_moved_attributes + +_importer._add_module(Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser"), + "moves.urllib_robotparser", "moves.urllib.robotparser") + + +class Module_six_moves_urllib(types.ModuleType): + + """Create a six.moves.urllib namespace that resembles the Python 3 namespace""" + __path__ = [] # mark as package + parse = _importer._get_module("moves.urllib_parse") + error = _importer._get_module("moves.urllib_error") + request = _importer._get_module("moves.urllib_request") + response = _importer._get_module("moves.urllib_response") + robotparser = _importer._get_module("moves.urllib_robotparser") + + def __dir__(self): + return ['parse', 'error', 'request', 'response', 'robotparser'] + +_importer._add_module(Module_six_moves_urllib(__name__ + ".moves.urllib"), + "moves.urllib") + + +def add_move(move): + """Add an item to six.moves.""" + setattr(_MovedItems, move.name, move) + + +def remove_move(name): + """Remove item from six.moves.""" + try: + delattr(_MovedItems, name) + except AttributeError: + try: + del moves.__dict__[name] + except KeyError: + raise AttributeError("no such move, %r" % (name,)) + + +if PY3: + _meth_func = "__func__" + _meth_self = "__self__" + + _func_closure = "__closure__" + _func_code = "__code__" + _func_defaults = "__defaults__" + _func_globals = "__globals__" +else: + _meth_func = "im_func" + _meth_self = "im_self" + + _func_closure = "func_closure" + _func_code = "func_code" + _func_defaults = "func_defaults" + _func_globals = "func_globals" + + +try: + advance_iterator = next +except NameError: + def advance_iterator(it): + return it.next() +next = advance_iterator + + +try: + callable = callable +except NameError: + def callable(obj): + return any("__call__" in klass.__dict__ for klass in type(obj).__mro__) + + +if PY3: + def get_unbound_function(unbound): + return unbound + + create_bound_method = types.MethodType + + def create_unbound_method(func, cls): + return func + + Iterator = object +else: + def get_unbound_function(unbound): + return unbound.im_func + + def create_bound_method(func, obj): + return types.MethodType(func, obj, obj.__class__) + + def create_unbound_method(func, cls): + return types.MethodType(func, None, cls) + + class Iterator(object): + + def next(self): + return type(self).__next__(self) + + callable = callable +_add_doc(get_unbound_function, + """Get the function out of a possibly unbound function""") + + +get_method_function = operator.attrgetter(_meth_func) +get_method_self = operator.attrgetter(_meth_self) +get_function_closure = operator.attrgetter(_func_closure) +get_function_code = operator.attrgetter(_func_code) +get_function_defaults = operator.attrgetter(_func_defaults) +get_function_globals = operator.attrgetter(_func_globals) + + +if PY3: + def iterkeys(d, **kw): + return iter(d.keys(**kw)) + + def itervalues(d, **kw): + return iter(d.values(**kw)) + + def iteritems(d, **kw): + return iter(d.items(**kw)) + + def iterlists(d, **kw): + return iter(d.lists(**kw)) + + viewkeys = operator.methodcaller("keys") + + viewvalues = operator.methodcaller("values") + + viewitems = operator.methodcaller("items") +else: + def iterkeys(d, **kw): + return d.iterkeys(**kw) + + def itervalues(d, **kw): + return d.itervalues(**kw) + + def iteritems(d, **kw): + return d.iteritems(**kw) + + def iterlists(d, **kw): + return d.iterlists(**kw) + + viewkeys = operator.methodcaller("viewkeys") + + viewvalues = operator.methodcaller("viewvalues") + + viewitems = operator.methodcaller("viewitems") + +_add_doc(iterkeys, "Return an iterator over the keys of a dictionary.") +_add_doc(itervalues, "Return an iterator over the values of a dictionary.") +_add_doc(iteritems, + "Return an iterator over the (key, value) pairs of a dictionary.") +_add_doc(iterlists, + "Return an iterator over the (key, [values]) pairs of a dictionary.") + + +if PY3: + def b(s): + return s.encode("latin-1") + + def u(s): + return s + unichr = chr + import struct + int2byte = struct.Struct(">B").pack + del struct + byte2int = operator.itemgetter(0) + indexbytes = operator.getitem + iterbytes = iter + import io + StringIO = io.StringIO + BytesIO = io.BytesIO + _assertCountEqual = "assertCountEqual" + if sys.version_info[1] <= 1: + _assertRaisesRegex = "assertRaisesRegexp" + _assertRegex = "assertRegexpMatches" + else: + _assertRaisesRegex = "assertRaisesRegex" + _assertRegex = "assertRegex" +else: + def b(s): + return s + # Workaround for standalone backslash + + def u(s): + return unicode(s.replace(r'\\', r'\\\\'), "unicode_escape") + unichr = unichr + int2byte = chr + + def byte2int(bs): + return ord(bs[0]) + + def indexbytes(buf, i): + return ord(buf[i]) + iterbytes = functools.partial(itertools.imap, ord) + import StringIO + StringIO = BytesIO = StringIO.StringIO + _assertCountEqual = "assertItemsEqual" + _assertRaisesRegex = "assertRaisesRegexp" + _assertRegex = "assertRegexpMatches" +_add_doc(b, """Byte literal""") +_add_doc(u, """Text literal""") + + +def assertCountEqual(self, *args, **kwargs): + return getattr(self, _assertCountEqual)(*args, **kwargs) + + +def assertRaisesRegex(self, *args, **kwargs): + return getattr(self, _assertRaisesRegex)(*args, **kwargs) + + +def assertRegex(self, *args, **kwargs): + return getattr(self, _assertRegex)(*args, **kwargs) + + +if PY3: + exec_ = getattr(moves.builtins, "exec") + + def reraise(tp, value, tb=None): + if value is None: + value = tp() + if value.__traceback__ is not tb: + raise value.with_traceback(tb) + raise value + +else: + def exec_(_code_, _globs_=None, _locs_=None): + """Execute code in a namespace.""" + if _globs_ is None: + frame = sys._getframe(1) + _globs_ = frame.f_globals + if _locs_ is None: + _locs_ = frame.f_locals + del frame + elif _locs_ is None: + _locs_ = _globs_ + exec("""exec _code_ in _globs_, _locs_""") + + exec_("""def reraise(tp, value, tb=None): + raise tp, value, tb +""") + + +if sys.version_info[:2] == (3, 2): + exec_("""def raise_from(value, from_value): + if from_value is None: + raise value + raise value from from_value +""") +elif sys.version_info[:2] > (3, 2): + exec_("""def raise_from(value, from_value): + raise value from from_value +""") +else: + def raise_from(value, from_value): + raise value + + +print_ = getattr(moves.builtins, "print", None) +if print_ is None: + def print_(*args, **kwargs): + """The new-style print function for Python 2.4 and 2.5.""" + fp = kwargs.pop("file", sys.stdout) + if fp is None: + return + + def write(data): + if not isinstance(data, basestring): + data = str(data) + # If the file has an encoding, encode unicode with it. + if (isinstance(fp, file) and + isinstance(data, unicode) and + fp.encoding is not None): + errors = getattr(fp, "errors", None) + if errors is None: + errors = "strict" + data = data.encode(fp.encoding, errors) + fp.write(data) + want_unicode = False + sep = kwargs.pop("sep", None) + if sep is not None: + if isinstance(sep, unicode): + want_unicode = True + elif not isinstance(sep, str): + raise TypeError("sep must be None or a string") + end = kwargs.pop("end", None) + if end is not None: + if isinstance(end, unicode): + want_unicode = True + elif not isinstance(end, str): + raise TypeError("end must be None or a string") + if kwargs: + raise TypeError("invalid keyword arguments to print()") + if not want_unicode: + for arg in args: + if isinstance(arg, unicode): + want_unicode = True + break + if want_unicode: + newline = unicode("\n") + space = unicode(" ") + else: + newline = "\n" + space = " " + if sep is None: + sep = space + if end is None: + end = newline + for i, arg in enumerate(args): + if i: + write(sep) + write(arg) + write(end) +if sys.version_info[:2] < (3, 3): + _print = print_ + + def print_(*args, **kwargs): + fp = kwargs.get("file", sys.stdout) + flush = kwargs.pop("flush", False) + _print(*args, **kwargs) + if flush and fp is not None: + fp.flush() + +_add_doc(reraise, """Reraise an exception.""") + +if sys.version_info[0:2] < (3, 4): + def wraps(wrapped, assigned=functools.WRAPPER_ASSIGNMENTS, + updated=functools.WRAPPER_UPDATES): + def wrapper(f): + f = functools.wraps(wrapped, assigned, updated)(f) + f.__wrapped__ = wrapped + return f + return wrapper +else: + wraps = functools.wraps + + +def with_metaclass(meta, *bases): + """Create a base class with a metaclass.""" + # This requires a bit of explanation: the basic idea is to make a dummy + # metaclass for one level of class instantiation that replaces itself with + # the actual metaclass. + class metaclass(meta): + + def __new__(cls, name, this_bases, d): + return meta(name, bases, d) + return type.__new__(metaclass, 'temporary_class', (), {}) + + +def add_metaclass(metaclass): + """Class decorator for creating a class with a metaclass.""" + def wrapper(cls): + orig_vars = cls.__dict__.copy() + slots = orig_vars.get('__slots__') + if slots is not None: + if isinstance(slots, str): + slots = [slots] + for slots_var in slots: + orig_vars.pop(slots_var) + orig_vars.pop('__dict__', None) + orig_vars.pop('__weakref__', None) + return metaclass(cls.__name__, cls.__bases__, orig_vars) + return wrapper + + +def python_2_unicode_compatible(klass): + """ + A decorator that defines __unicode__ and __str__ methods under Python 2. + Under Python 3 it does nothing. + + To support Python 2 and 3 with a single code base, define a __str__ method + returning text and apply this decorator to the class. + """ + if PY2: + if '__str__' not in klass.__dict__: + raise ValueError("@python_2_unicode_compatible cannot be applied " + "to %s because it doesn't define __str__()." % + klass.__name__) + klass.__unicode__ = klass.__str__ + klass.__str__ = lambda self: self.__unicode__().encode('utf-8') + return klass + + +# Complete the moves implementation. +# This code is at the end of this module to speed up module loading. +# Turn this module into a package. +__path__ = [] # required for PEP 302 and PEP 451 +__package__ = __name__ # see PEP 366 @ReservedAssignment +if globals().get("__spec__") is not None: + __spec__.submodule_search_locations = [] # PEP 451 @UndefinedVariable +# Remove other six meta path importers, since they cause problems. This can +# happen if six is removed from sys.modules and then reloaded. (Setuptools does +# this for some reason.) +if sys.meta_path: + for i, importer in enumerate(sys.meta_path): + # Here's some real nastiness: Another "instance" of the six module might + # be floating around. Therefore, we can't use isinstance() to check for + # the six meta path importer, since the other six instance will have + # inserted an importer with different class. + if (type(importer).__name__ == "_SixMetaPathImporter" and + importer.name == __name__): + del sys.meta_path[i] + break + del i, importer +# Finally, add the importer to the meta path import hook. +sys.meta_path.append(_importer) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/archive_util.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/archive_util.py new file mode 100644 index 0000000..8143604 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/archive_util.py @@ -0,0 +1,173 @@ +"""Utilities for extracting common archive formats""" + +import zipfile +import tarfile +import os +import shutil +import posixpath +import contextlib +from distutils.errors import DistutilsError + +from pkg_resources import ensure_directory + +__all__ = [ + "unpack_archive", "unpack_zipfile", "unpack_tarfile", "default_filter", + "UnrecognizedFormat", "extraction_drivers", "unpack_directory", +] + + +class UnrecognizedFormat(DistutilsError): + """Couldn't recognize the archive type""" + + +def default_filter(src, dst): + """The default progress/filter callback; returns True for all files""" + return dst + + +def unpack_archive(filename, extract_dir, progress_filter=default_filter, + drivers=None): + """Unpack `filename` to `extract_dir`, or raise ``UnrecognizedFormat`` + + `progress_filter` is a function taking two arguments: a source path + internal to the archive ('/'-separated), and a filesystem path where it + will be extracted. The callback must return the desired extract path + (which may be the same as the one passed in), or else ``None`` to skip + that file or directory. The callback can thus be used to report on the + progress of the extraction, as well as to filter the items extracted or + alter their extraction paths. + + `drivers`, if supplied, must be a non-empty sequence of functions with the + same signature as this function (minus the `drivers` argument), that raise + ``UnrecognizedFormat`` if they do not support extracting the designated + archive type. The `drivers` are tried in sequence until one is found that + does not raise an error, or until all are exhausted (in which case + ``UnrecognizedFormat`` is raised). If you do not supply a sequence of + drivers, the module's ``extraction_drivers`` constant will be used, which + means that ``unpack_zipfile`` and ``unpack_tarfile`` will be tried, in that + order. + """ + for driver in drivers or extraction_drivers: + try: + driver(filename, extract_dir, progress_filter) + except UnrecognizedFormat: + continue + else: + return + else: + raise UnrecognizedFormat( + "Not a recognized archive type: %s" % filename + ) + + +def unpack_directory(filename, extract_dir, progress_filter=default_filter): + """"Unpack" a directory, using the same interface as for archives + + Raises ``UnrecognizedFormat`` if `filename` is not a directory + """ + if not os.path.isdir(filename): + raise UnrecognizedFormat("%s is not a directory" % filename) + + paths = { + filename: ('', extract_dir), + } + for base, dirs, files in os.walk(filename): + src, dst = paths[base] + for d in dirs: + paths[os.path.join(base, d)] = src + d + '/', os.path.join(dst, d) + for f in files: + target = os.path.join(dst, f) + target = progress_filter(src + f, target) + if not target: + # skip non-files + continue + ensure_directory(target) + f = os.path.join(base, f) + shutil.copyfile(f, target) + shutil.copystat(f, target) + + +def unpack_zipfile(filename, extract_dir, progress_filter=default_filter): + """Unpack zip `filename` to `extract_dir` + + Raises ``UnrecognizedFormat`` if `filename` is not a zipfile (as determined + by ``zipfile.is_zipfile()``). See ``unpack_archive()`` for an explanation + of the `progress_filter` argument. + """ + + if not zipfile.is_zipfile(filename): + raise UnrecognizedFormat("%s is not a zip file" % (filename,)) + + with zipfile.ZipFile(filename) as z: + for info in z.infolist(): + name = info.filename + + # don't extract absolute paths or ones with .. in them + if name.startswith('/') or '..' in name.split('/'): + continue + + target = os.path.join(extract_dir, *name.split('/')) + target = progress_filter(name, target) + if not target: + continue + if name.endswith('/'): + # directory + ensure_directory(target) + else: + # file + ensure_directory(target) + data = z.read(info.filename) + with open(target, 'wb') as f: + f.write(data) + unix_attributes = info.external_attr >> 16 + if unix_attributes: + os.chmod(target, unix_attributes) + + +def unpack_tarfile(filename, extract_dir, progress_filter=default_filter): + """Unpack tar/tar.gz/tar.bz2 `filename` to `extract_dir` + + Raises ``UnrecognizedFormat`` if `filename` is not a tarfile (as determined + by ``tarfile.open()``). See ``unpack_archive()`` for an explanation + of the `progress_filter` argument. + """ + try: + tarobj = tarfile.open(filename) + except tarfile.TarError: + raise UnrecognizedFormat( + "%s is not a compressed or uncompressed tar file" % (filename,) + ) + with contextlib.closing(tarobj): + # don't do any chowning! + tarobj.chown = lambda *args: None + for member in tarobj: + name = member.name + # don't extract absolute paths or ones with .. in them + if not name.startswith('/') and '..' not in name.split('/'): + prelim_dst = os.path.join(extract_dir, *name.split('/')) + + # resolve any links and to extract the link targets as normal + # files + while member is not None and (member.islnk() or member.issym()): + linkpath = member.linkname + if member.issym(): + base = posixpath.dirname(member.name) + linkpath = posixpath.join(base, linkpath) + linkpath = posixpath.normpath(linkpath) + member = tarobj._getmember(linkpath) + + if member is not None and (member.isfile() or member.isdir()): + final_dst = progress_filter(name, prelim_dst) + if final_dst: + if final_dst.endswith(os.sep): + final_dst = final_dst[:-1] + try: + # XXX Ugh + tarobj._extract_member(member, final_dst) + except tarfile.ExtractError: + # chown/chmod/mkfifo/mknode/makedev failed + pass + return True + + +extraction_drivers = unpack_directory, unpack_zipfile, unpack_tarfile diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/build_meta.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/build_meta.py new file mode 100644 index 0000000..10c4b52 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/build_meta.py @@ -0,0 +1,257 @@ +"""A PEP 517 interface to setuptools + +Previously, when a user or a command line tool (let's call it a "frontend") +needed to make a request of setuptools to take a certain action, for +example, generating a list of installation requirements, the frontend would +would call "setup.py egg_info" or "setup.py bdist_wheel" on the command line. + +PEP 517 defines a different method of interfacing with setuptools. Rather +than calling "setup.py" directly, the frontend should: + + 1. Set the current directory to the directory with a setup.py file + 2. Import this module into a safe python interpreter (one in which + setuptools can potentially set global variables or crash hard). + 3. Call one of the functions defined in PEP 517. + +What each function does is defined in PEP 517. However, here is a "casual" +definition of the functions (this definition should not be relied on for +bug reports or API stability): + + - `build_wheel`: build a wheel in the folder and return the basename + - `get_requires_for_build_wheel`: get the `setup_requires` to build + - `prepare_metadata_for_build_wheel`: get the `install_requires` + - `build_sdist`: build an sdist in the folder and return the basename + - `get_requires_for_build_sdist`: get the `setup_requires` to build + +Again, this is not a formal definition! Just a "taste" of the module. +""" + +import io +import os +import sys +import tokenize +import shutil +import contextlib + +import setuptools +import distutils +from setuptools.py31compat import TemporaryDirectory + +from pkg_resources import parse_requirements +from pkg_resources.py31compat import makedirs + +__all__ = ['get_requires_for_build_sdist', + 'get_requires_for_build_wheel', + 'prepare_metadata_for_build_wheel', + 'build_wheel', + 'build_sdist', + '__legacy__', + 'SetupRequirementsError'] + +class SetupRequirementsError(BaseException): + def __init__(self, specifiers): + self.specifiers = specifiers + + +class Distribution(setuptools.dist.Distribution): + def fetch_build_eggs(self, specifiers): + specifier_list = list(map(str, parse_requirements(specifiers))) + + raise SetupRequirementsError(specifier_list) + + @classmethod + @contextlib.contextmanager + def patch(cls): + """ + Replace + distutils.dist.Distribution with this class + for the duration of this context. + """ + orig = distutils.core.Distribution + distutils.core.Distribution = cls + try: + yield + finally: + distutils.core.Distribution = orig + + +def _to_str(s): + """ + Convert a filename to a string (on Python 2, explicitly + a byte string, not Unicode) as distutils checks for the + exact type str. + """ + if sys.version_info[0] == 2 and not isinstance(s, str): + # Assume it's Unicode, as that's what the PEP says + # should be provided. + return s.encode(sys.getfilesystemencoding()) + return s + + +def _get_immediate_subdirectories(a_dir): + return [name for name in os.listdir(a_dir) + if os.path.isdir(os.path.join(a_dir, name))] + + +def _file_with_extension(directory, extension): + matching = ( + f for f in os.listdir(directory) + if f.endswith(extension) + ) + file, = matching + return file + + +def _open_setup_script(setup_script): + if not os.path.exists(setup_script): + # Supply a default setup.py + return io.StringIO(u"from setuptools import setup; setup()") + + return getattr(tokenize, 'open', open)(setup_script) + + +class _BuildMetaBackend(object): + + def _fix_config(self, config_settings): + config_settings = config_settings or {} + config_settings.setdefault('--global-option', []) + return config_settings + + def _get_build_requires(self, config_settings, requirements): + config_settings = self._fix_config(config_settings) + + sys.argv = sys.argv[:1] + ['egg_info'] + \ + config_settings["--global-option"] + try: + with Distribution.patch(): + self.run_setup() + except SetupRequirementsError as e: + requirements += e.specifiers + + return requirements + + def run_setup(self, setup_script='setup.py'): + # Note that we can reuse our build directory between calls + # Correctness comes first, then optimization later + __file__ = setup_script + __name__ = '__main__' + + with _open_setup_script(__file__) as f: + code = f.read().replace(r'\r\n', r'\n') + + exec(compile(code, __file__, 'exec'), locals()) + + def get_requires_for_build_wheel(self, config_settings=None): + config_settings = self._fix_config(config_settings) + return self._get_build_requires(config_settings, requirements=['wheel']) + + def get_requires_for_build_sdist(self, config_settings=None): + config_settings = self._fix_config(config_settings) + return self._get_build_requires(config_settings, requirements=[]) + + def prepare_metadata_for_build_wheel(self, metadata_directory, + config_settings=None): + sys.argv = sys.argv[:1] + ['dist_info', '--egg-base', + _to_str(metadata_directory)] + self.run_setup() + + dist_info_directory = metadata_directory + while True: + dist_infos = [f for f in os.listdir(dist_info_directory) + if f.endswith('.dist-info')] + + if (len(dist_infos) == 0 and + len(_get_immediate_subdirectories(dist_info_directory)) == 1): + + dist_info_directory = os.path.join( + dist_info_directory, os.listdir(dist_info_directory)[0]) + continue + + assert len(dist_infos) == 1 + break + + # PEP 517 requires that the .dist-info directory be placed in the + # metadata_directory. To comply, we MUST copy the directory to the root + if dist_info_directory != metadata_directory: + shutil.move( + os.path.join(dist_info_directory, dist_infos[0]), + metadata_directory) + shutil.rmtree(dist_info_directory, ignore_errors=True) + + return dist_infos[0] + + def _build_with_temp_dir(self, setup_command, result_extension, + result_directory, config_settings): + config_settings = self._fix_config(config_settings) + result_directory = os.path.abspath(result_directory) + + # Build in a temporary directory, then copy to the target. + makedirs(result_directory, exist_ok=True) + with TemporaryDirectory(dir=result_directory) as tmp_dist_dir: + sys.argv = (sys.argv[:1] + setup_command + + ['--dist-dir', tmp_dist_dir] + + config_settings["--global-option"]) + self.run_setup() + + result_basename = _file_with_extension(tmp_dist_dir, result_extension) + result_path = os.path.join(result_directory, result_basename) + if os.path.exists(result_path): + # os.rename will fail overwriting on non-Unix. + os.remove(result_path) + os.rename(os.path.join(tmp_dist_dir, result_basename), result_path) + + return result_basename + + + def build_wheel(self, wheel_directory, config_settings=None, + metadata_directory=None): + return self._build_with_temp_dir(['bdist_wheel'], '.whl', + wheel_directory, config_settings) + + def build_sdist(self, sdist_directory, config_settings=None): + return self._build_with_temp_dir(['sdist', '--formats', 'gztar'], + '.tar.gz', sdist_directory, + config_settings) + + +class _BuildMetaLegacyBackend(_BuildMetaBackend): + """Compatibility backend for setuptools + + This is a version of setuptools.build_meta that endeavors to maintain backwards + compatibility with pre-PEP 517 modes of invocation. It exists as a temporary + bridge between the old packaging mechanism and the new packaging mechanism, + and will eventually be removed. + """ + def run_setup(self, setup_script='setup.py'): + # In order to maintain compatibility with scripts assuming that + # the setup.py script is in a directory on the PYTHONPATH, inject + # '' into sys.path. (pypa/setuptools#1642) + sys_path = list(sys.path) # Save the original path + + script_dir = os.path.dirname(os.path.abspath(setup_script)) + if script_dir not in sys.path: + sys.path.insert(0, script_dir) + + try: + super(_BuildMetaLegacyBackend, + self).run_setup(setup_script=setup_script) + finally: + # While PEP 517 frontends should be calling each hook in a fresh + # subprocess according to the standard (and thus it should not be + # strictly necessary to restore the old sys.path), we'll restore + # the original path so that the path manipulation does not persist + # within the hook after run_setup is called. + sys.path[:] = sys_path + +# The primary backend +_BACKEND = _BuildMetaBackend() + +get_requires_for_build_wheel = _BACKEND.get_requires_for_build_wheel +get_requires_for_build_sdist = _BACKEND.get_requires_for_build_sdist +prepare_metadata_for_build_wheel = _BACKEND.prepare_metadata_for_build_wheel +build_wheel = _BACKEND.build_wheel +build_sdist = _BACKEND.build_sdist + + +# The legacy backend +__legacy__ = _BuildMetaLegacyBackend() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/cli-32.exe b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/cli-32.exe new file mode 100644 index 0000000000000000000000000000000000000000..b1487b7819e7286577a043c7726fbe0ca1543083 GIT binary patch literal 65536 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[c}i<OXTz6k>I#RErv3nvcIClH@!{vM)zJ_weD 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/cli-64.exe b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/cli-64.exe new file mode 100644 index 0000000000000000000000000000000000000000..675e6bf3743f3d3011c238657e7128ee9960ef7f GIT binary patch literal 74752 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 &sjKl@1{;unAiW2w^OujNoW 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/cli.exe b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/cli.exe new file mode 100644 index 0000000000000000000000000000000000000000..b1487b7819e7286577a043c7726fbe0ca1543083 GIT binary patch literal 65536 zcmeFae|%KMxj%k3yGc&ShO@v10t8qfC>m5WpovRhA=wa=z=p_%6%z1@blsvwI0vv2 zNIY4alVK~j)mwY3trY!Sy|tffZ$+^cObBMdpZutbN^PuECoa`kXb2K>zVBzw<_Fq) zU-$d^{_*|%@qt&)nVIv<%rnnC&oeX6JTqHy>n_PINs<G9rYTAL@TPx0@%--}9r!$a z((i^#&t<$Zd7o|Z8<TGd-?_=NVdM9{v+=gOJh$I=_ub!9J^yrvXQOtv=gzx5rAw<k zcYSZ|9am>%4a-Xw9jfY!Ot@}WQUBkK=MqH|Mf{(O%J6=?F0E)R-u5-_q9XB5EmFjL zRMB1HZ7a&fd)b}0hpCKjVjS>G(qfxk>Uow`_J8Y;?6yo>h9td;lqFW`r_=Cu;je?@ zJ}aCeNvRaYzy7!6vsuJK8t7Ip04X137Vm)<B}y|cNYZo>`v3N5I`@q}=|CK){8#_3 zR`1xV;$zJbJP0ppD|Paae;!F%bM?lxx2d-wfQV@O6ujTW-;jSkRCTolCLPMh2Nx=) zGP{NVA?TB&mP=FqZ|whc3RJSvJUJGyHOs!nBie<k<-z=e)r`kVud+vM0lsONB<Y9b z0<+))qcqReE=`GTutop6y*iN=`x&*3EzZknc4W?3rP&uIJaeXK<D%wvS9N4nkT;0D zPW$-+vpsE9St6ytWVaCXsHU`%GVdR^wE=Xv01fto0vp%r_OvPOWj3j{W@V_Y;fxbp zySskme5v4&(U>PA7G%%m<=|b-UJ~!-boN$bi#jT{Hcy&A=Niq?KHpr`Y-?=MzKk{I zIl-)f*v>o`q`5M7OP+gKtTfLZsOCS(qPDr~x8=!_5`6-VLD0EMY5XaI$Uqq@V-Jap zR-V}6Ja=V~*CHdz@F4Rb<?;{KZ*yd>ij_JtwPEG;g{#zT!Uq*Py$3gDv`Z2tYF|X8 zYEi!^3#I2mi!9?8K!AuX>_C;=ltI=m5eE7*@I4UZ&p}=3ho&bc^h3P|C;`K|s)PJt z@!8GLOb})@Yp*SMou>fLhC@WZw%7ar>1Sm0aW&hPm&@Wqv5z<cJW4gM&zmkfJJ+a@ zj6&r=dVrlbR^{dLe--p{MqAX8%7LY}g_XQXq&T82+UL#6!luP}xs6BE?<fb3E#r6f ze^S%+ZFw$9UEExnmrHC?k~jf28Qa}v(?%Aw6cJb9i=;f%LL7GNV)O&mRYm+WAK2)J zoc6N?AE0A$CG}^`sG(_iS>i_&0GwOEjRhPMrYB*+WA64e$@ELiFO?ay?gvgcC<n$Y z<L^1CK%h$vSZG@q;PL(x?eqG1V1nyS(*z5;SA+M!_HB5xgCaCQzioLANgKIa^30b| zP)0-wnAuW?PuhpB1D*9VD+*d7r2(|XN$tU(8-F?I^V~ojiGY&$x^&Sr^ySP^J_*UW zrARijT__0kuL5&8h*xu#MI`axM$bS5AWndQ;JM+aKJrO?BE}`X#TVcgz$PT9E&8Dq zZ6JXIg6WKy%Zx0-)XbKtWRx0n<OM3tY=>1!dbl2?B=#{!9_2$Llg!~3%n@58CG`RW z1LPlkk=p2eFSa3N`&F?g@~A1mHitQyVq0yNK4^CN8joui^5gTpuf^0f+qMtEYVL?F z$fu`~#PaZA)VQ4Amx;XbZ%EJqQT~UlXZwx7HHW!>vn=MgCVU7v0(=qWSe%!~9KS(N zgLM=3LHzO$mU+*{wx!#)wXd#auhgvU=lF&*IVnT+hZ`~0nCHPOETKA3I;S!sQ8$^{ zZcv4UbEsTEpxvZ3yazYCQD1%G)vA+(ndH~oy5$RmDNA{h9?j)8QlvdBd-|V!63d!_ zr{P-1vS(7D+|itM9Rk61MnI<ijY!Ly%7^jv=YUlg`cLmOwOJ@HClJm79G^?wO8q+) z2vf7m?6nYbY6S#*GNiuY5H+x^+G@?tJP#TL9re>+K~KhBa?C)KKh+E*p-K?e54p;H z-uNb0vkbWyR)1lbnp%G$OG`vjpo}PU*o}&pp;`PEODluTuiNcFBFmELneD_AsyG+G zkGm*r)oMJHmxrXL#=Plxfj%;6&nXBm<I#%{teK#)2aU^vKFj+G2|d8ZfX<DYT4pfZ zfo|^HD@jrnxXrnoJ(D*BEsHtwkuBFp`spvA2GpIQLK~G_Fij)vWt2{I(c2x~KW)!t zCOE{y+%GQUQ^og%kazlaaoZ=NV(uK8O?>)d`#6i)km>UtDzrb-*V{hPU&@;WB&3=+ zxL1-^s(vuM%+x$5wc!b>TMmX_2j=|8Kt*)b-4;r#_ff_ny|oEKpX@DE=!THWD9l;8 zEWjV=HO&BTAtLP*tp;IMlM0_Vn8(sUqI$?Nv_U1G^tEZC@of=jxa%BH_{Ai!MYo}y zE@)vjviC#f;TCVZ=HXtX$EDFgCrJNz+eAX#tsgc!-#{X?u;vu7>K}|6xr+Y+O$ixV zZ+D5)r){a?S581&?=jW!dQYD^njLNZDwQ49Kbq9~QJUTP@Z(p`mlCNjK7uj2dw$*y z?Fs@NOQ3Fcxb;G+-Z81QBhBuJS%CWlpf9gp&E>m+$xzI$NMcrT+APveYg4QEVhkj# zC+2qrf~MxI;{Q2Zk_`Xps%rkG7-Dkc{@y;QZ4Oz0#y`#fgd*BZP3DWK6>a+@*L<mM zcZ+wv6pXlQp*qv|N$8nGnzy|!owe_wFT`9w_5eJz=cRm7?ApYLBWTQ~Z~Xh0d`OLq zTT$CqaQsCoH<7xV;0<Sr-s;g0IvOs}L}lA&k-l0$xByYj4z~8BGDno!&c4z=oz(hi z8grx*iDYlPN`q&LaV@ehXt=Ne8MeK-x}c@DjsM$J%twl6LU~JSD&H^}!^3Q<i@!_g zv@vrzI}>D@EZXPo+Bl`5Zw>0+GLF5OFNogis^p(SM>i~SO7+N+7^b&-f@XG3hYwRL zs{rPg^&WTKXuZW1;J*Vf^E(^LEqH+VoqCH0;~Qle%pqFtZQVGjSX7wPu*PZbFwOi{ zG*lGy6QCZdX|wX?4#`^~>lfT8wQf{0k4{L2{|oR+{f=JfFn@0V9WOeR5QLU=M!U6~ zB7d(sir<zi(J(xWuRwrR^cpgzK1ceMKSTyn=7h94qQ})c3tBJ-kufbC-S8FZ{*A-+ z;wE$p2;6zcG#Z^Q=wCTDUVHvM{Uf{T%s<wYuE%Y9r%meyA9u+1R(iScdR70ky|pt% zO*{K56g<p=`;6dF!Rj_V9Z4Kex3fBWL}~ny1nH|{??HFC&$rtV!@%g$GEs~YjUt-3 zyg5y8xAoVl=3`2GjRmRwg}nzj?Kb^myE<wR3=lWy37hs;ROnh+ySnXsoC;P)_ZOlx zK7zQFs(oe^qFNu3t$Ssyg|9J2k2}y#^%uW0`}(%CH2YD#%Pcs^MniW#E!k`h>Z!)# z>Ws#2b>jJh;6zDv(pxgML&lgyPQ#zcbb!!sgpiDoqu{tG6%!Ja>nvz7KufAa>qaA# z=oV|HC9oE}Y-%~C<~B7KIy+)gcYDw!`k|a8<5gBx6?_n^Hfnl`YGk#JRXDw`Y3W5Z zF72K~Dqd=&sK!kRIocXZ$WcQ@HMx}F(UwwzM=dX^$<yW*)lApsLU0ONe1#L$wDK}< z+m`P7xi@OFy|1a`^g5Sax&QBIL?i`BM9fM)?J~l{Rc2^%VhrUz829&peWXrWCnHlz z(^x9cG-`TL;&SCcT7aJf@*!}hy(}@hIc?50YSx@pYQ~(aH5qypGnehQvcielAG{aU zX~0_@&*J%hxyYZhxenZpYC#MBj39u^sFM>J%<uNLp{5+>??vDyuV3EiM+4QdBA;io zzdv6tSFL<#t<s2TfRwNG7HQKrPlW>QrIPdbG7F+JhObn}j(kln(mY$%K{!!5k#)1E ziz+3WTCrR!=CNXVR%|-O_{kh9N!CV3M%Px+KVv3eg)|H^tUYmMQB9Bbm&lY5<g+!A z3q(W{bNLa7G-%8GR2a%BXjxsm@<>uSRpgw1Z~T#cB&t&nSAs!Ug_}|kVHMz$WCS?l zqwD<1@hy6X9b^#7A}+?pyqY#|7U^Uy<!oE$R#G6OIHC7~?928tC#m||`Rwb!vt=?X zUvCU&<zZuqgAMm)Z5TgaQb)3^o#QYflyA_|`O&KZm&VE*-qc-V@o_Xmrh)G=FTI?~ zaUiwZw;@Gy>*X6#P>C%ujL9h3=b(@6wKWGF78?2)w89yy=;G^09Q<ASzGu)Qw(X;0 z{;ohoCMo#dETWJz;bQfN@r_l;$_tKiy+f|A>y^}WR?(y1w&Cj}$@F5L2YsfEL<3pY z8Z-dF^8sAbhP4Aqi=v(obhDs>e#QftDyng66L`)T%)98HH5&8BF<Y>v2#E?5hTb_9 zH2mD~chFE=MQHmw0&)Lo6u2YqKeGV1@zG*g<1#Bwv#zb_%-_+JlMrxKd<~ir3Ze1+ zy(_eP6{~SYKhV+(S~~v~1yt)79UHaSeZ5h0^WBheRNU;+TO4|;1L|kljg`GxMRVY5 zgy-B?`L%XKbD$65%Wkaf(<V0uOoUxGf)z4#f3Kscu6N_X#60DBpQ${*$V`+W)Q3=C zVh%!IBlLCRI)r)=>P<|yYD*~1E|lWFafIgb%{TqMMK!$}&wwd`weq~AJfD%@n)sU_ zUiHfyy0+TP&cgr)(wf;G1RCO$+F-8vOp><HO7p|jNn-Q6t|xsd^WT9I=Ikc$B){h> zOt(p4nn%&aNx*RFpHZMF4f(Ufvk=7?JRPMYo=R06O@dN!hp9(J{WAdZdPL@b!%!G% zLqHJ$fo+g=B{EqW3P?d+m=J67#;*QZ08JwbS`rFm!NrD0j{xSFfN^d-(+{H;KZnVO zq>c^Kn`akV>TQ^)nUX?$=?!SjnvZ-^xEv3@Td*3+ToB$GLi`Q1f1eLu;*Pvh0=OLj zdhtFgHl&UZQ-JSB8KgFySnsCLa+gvITEM<JVb|Z0=_NNbv&@H6(`bHB@Igt@ghI@c zl*U&;NMph*gq!`YU((D;uXAEi{}>T?_A^wxGy~aKk5P9rYN}h!*-ueoBA*hw4DFOr zciPZ8^v@j#d(UsI=5c%~N>l%e$W7+;ycJQ_!+(R9k!HS|Ec90*HCfot5kX%T)t%N- zi~Jqxa4NIzB;-ca!0JvWei7b)=I>ieG+2$PYbd;x;wr_LQoMggi&;CG;F7fIhG-(% zJ!c$nrEc$qdPCdkvnu1mRQk}y|2ztlU(w@aFd)D-lsL#-NVQSwulrLY!m_|0v*K-t zB7y%f8D%CG3s<7iT|s_@7ZVu%+>P|Sc?3OwD#DH8xgHD=<f-VsApaaa9sX=8nv;#Z z`k}l%#O<|7rBhsro=L%+c2xoT1-LwYZBh#O<!BUXr-(Z|lREpYkzkpMTP0~-Q7W02 zwZh$V@M_pc5wh%Sm%o^4qt8t_^m(klPsMxqW>>+Hq9%@@@^GtBaXR79?>LQ?^WZ#C z2`ni`a{1lFpInCsiUb$05edblZ^2mnBP=hXEp>8aJojRG7BaJEcKD<{j}yzhTP#U? z=Aa#XBtim8=Gg?r4Uj`5WN-&1pw{2h8%&)Z;9p{i7uubJoO^Qd2$-{7c$u@ERF>y& zqN~6wdfjPB!z|)D^aBs!k+_=q&oG%~7!{|m@ca2}v;&KPJ2>;78Umj~@P&9JSqLha zzlFYP<2&bKzVZaVB-Mc?2YHnu!LA|`O$fbh{3s#N;_-HA4$=p_MZ|rGufc4|OmzUu z^JPvljA~1&s$+Aa<w()zNx!G<0L@dyGr)f#BOMeS6)ST`QZT9-X)BDf9E^O4EH=;B zE*o==+8m?Sfptj=P=j*yt%Pm3WkA!^$&z|GbdnQQQMu~aAXl=XRo6Mq&w=2&97(@S z($~pS2zk2aJAG=JelIfRnTs4-Gueoy6w{_W-;!`D2U;p&H9!}KX!)wyGt%13G>Z>O zBaXr}qS-H-6;8gFl+j!hB|&HG__QCH?uAZY6+qd0>UH`KS<+@;OtPgV@|*2uh0NaK zb;wtOjM^yvHpr<LUa2YUt!L-)wNxOQvg7UAl}UBoaAs>tzb)z&!{3Y1&uQu2YF0;6 z-&pJkNPw~TIeP9tMbGFy@$3@M*Ts{I=TY%&5zoVT@~P)d6APo+yaISwqj*6}fd26l zSTkcVuiyVH03~%8i#~&ZzGlPMWCA!0Gf#IJR{FI;?gP_@en$)RA<KPQ>9elZzErW? z-z!$}DeP6T*8k_BYkgYiUq~IY)=yyvyM1}}O7uIRM!^y9drD&sLd~O$*hyeu#5%<D zB|MuR{sPa&<4WTs;8UXSCjiNK>=0hc&P=2=ADrQtvtr8#<-kGZK>Z2~i+YDr(2b== zcR`DCps{r;k|OD?J&uqOeF)jSt;!F64YPom7yZ+9fQ}L6K;B(=8G8lk_6m~j6~x@z zCDMtQotu#j_2}HA-lTK8dcDqNby|73nvIwet;T0PM(}dy%>!Xa=e&Wit+N2(1_4tK zJ>Ho&@F}G;2jTj!uGD5=No4gi+tKUoGxifUO6&p|zC}*Q`Nt@!^HZd-C<VXUGE6z} zYOGW~YKVB}>-c2srIvNJB1pwv_RV7Hs}lRAC|1y*^It@P6dqcjDCIs;$|7}n{a0bN zwEnC0YEJ!ETa@VSNVnP}A=G&bfqB<!qf3&BkW{O;I*ahh!r#?-)j-(OIT_(*`<&~w z3HA5cW@%$e`m=&S$*g^tLCz@<0M`kCCyB^pUPuD`kpR{zjc?QYPNne;dVddtKfN`j zaX-DcDvf*Ty+UdHHQvTv;)Yn1ge#yte=uO|J&YiKVh)%++R_{)&I_qiSd0WOwwE}M zKLJhMY%j5@ZER5*pMVy>1mb=`bXK5zVw9e>%7YwwQE9vvGOqVjDG&Y)-L5pEZIaIC zt1d9l3jE3C<x2EN7|!Ysdg9Sts0z6xi~B92`HDn$#vVI|kHS`EJa!sEBl<X=N~|0e z#G}+#WRvWC64CQfBGXLJSBXA?#3B7;AUgP28#eff33<>jm|E(KL}PG`1?WOK18iyR zr@EEK-#D<=?b9-MKLq7qL@AMpXFN*8q(*e^0F2H-_4k1j+Inw(tI~Km%BD8|oIZZL z3U#LP!ouD_m~3*fC^b0{i;`Lh@J}(6VsVI}X;M5&;!2eyMl~<&Z4!WS0Y`~eMhmOX z*{Fz-wZUowjBH+3?(n{;&a#?E?5n&i88K>u>i%i|!DBr`8qsAZj-fVnlD&ENu7UOj zcr8tPJKsdI-m^h@@FMC~8b8KU@3}+S`I1Qgj`G7<7-#jKJJoyip1alQde8Ti=;Qd- zEqbZmLK{d(>TSv1K-&|`*$o3Y^LH_kih}8`ftlRO=24yNSd>_EospK1t)P)MNSMz5 zMFbXV!)H|iohdPqaK2TlCsdyXsw|yVJM_5R`8Fcji2AR-qupV#6XH@LR3unydzvBM z4f~1F_TbC*c}(zSLwgMXgM4Bpq**9!s9VzD=qH!e1;$?DRCY2k%qp0&7j#pf$VRk@ zJ}vAuqB{{t3Z*G@GUUh<RahMtFhwyjk)sMzr4_lDBo%wm1?Ew<pEzDWl-uxWJxW(S zme6Q9$r7u~*=q@WxCI^x)$b=M|BjXmCLRK`hJZRJi82A?y-FLA>=QH+(oZ~6)oG_G zm7oW8n-SZG)I^@nHz|$JLoI;48x87n8XKNR#<&=^F9+-;eGV0gPPh}0%>uwt*&h7^ zikjIJeH*WM^eCR-1*y{y7<3vkDAAj#<hY}|)uZNEl<988lt+1aVQ<1g!t+y1WES>P zqW!0sNgW>q8t;8)$CzynZ~LYZ=TGX#rStC(HZCa)yTB3evmPy_-~(OswN&RE!Vcqf zp@Gi}J#;B+uy|&hmNr=+9n;P-K_62nm1xV3H2SPw#e|IhbXfof`+6|7-a1piP-HwN z7^H{2zdg+^sM$1pNn(G@e>T6pEQuKCV2I4dULmNrfxpt(oApIA)u1V4mx*V)ZKf|V zchNeer}=!|H??#5LN6WbNlX_CYfykKg_THOR9^_2FTwuZg0(8r_mh$V#aE#VnGn{e zeCl;DfP%p?tggB$k@J+TKa!uwd@4m9VSVvf-3M5SiBUWMu?`fM{}^?u#Rg7oj438} zF(JrR5f9(+cj98FDW)K7zZihT$5@OwgKx%nE3=G6vK4Y@Bde<-Gp$1S)m91meo|RL zn<`b;MO(K26BC3>4jV6|nK2@IAd(jIpM#El1d*~p8E?Q^LTFiSdXY#}J?38eXq6wU zILE&{2PF4XZYiYgP2}og_GW_ZL=T`a(o6hRfQ6D1w{88ns)Va232{Fagx$LRq%S0O zl)0Az+ySZ5pA=~!CT4ui_9ihZH^Qxh#U26>6Z7Hbqn#h2z5ie)Ybiu*0bt+kjg>s@ zjA<Te+x6L%J}EKXCyl?tC*6y`SMYZff1{CJnvdz?E#UyIH1B}!gaNm%H|Bp7#ui@( z%oNtXQp6YWU}CIctPO>{aix*=UiZ)(*qFTw&sY<UCyANuK8K{sX1gzSn6XuE_vK0L zzG=hSeU~9x*zTJ}dxI>C@-?(l4s4*jzOJb5O{H-dahv}rm2DF96vkFyo8F5}t^)$F zZ(9oMi~Bo>vl1%_AO0!k4`R(0WECATr`T9CY<emo<caMP7+pC8BYll5)vw8`??*{r zQwa1doJQE+frH9%)8A24O!>DxmPlhFq~FmY!A0jT?5Z*B+?Z-mztE>vHrpWqH$Nq7 znQ$bS14=<K=P<2<wbKUBCzDz~Nwd$g_PdY~mJ)PknIrr-mL;(=XMopVX(6vP9zl!D zG8t8u=>F3%*>!CDalr@dER`@@Y?!6d@*<PA64UCJIO-D{+shmcuo$LBx>vxe+Ey;C zzAb-8pA`ZV>?nizOJLlY2g_U%w^_#AX+&7PCq<)De2EOb$F4aLln1f;?205wZvaM# zVFVXXgXYER?xJ1UNedWLbhw#43pHVVJOXQCT7oAT1xqP@drH6g1<S->K{s|^C-D8~ zII-`VG_Cp(PnuTk%;)M~Y9hy;0G87Oi^b`fGFXmJv{=-iJc*G;s){U*MNc7w4PZX$ zFG5NYGosTWBeCdAJRx94bOr)R^%*-w;fF~?jmJo-7}k16tTxu|e7FZm>vqP@h}UDJ zMb_<%9ulu7Tg2<vB$|&tC^RDTJ7N`%xTwhn&1g*%jMzDVutmMrtSTNQWXCw9mbgHc zSQk?Rq?y?(K)r~>PMX=bAQTgbqx%Agz--_|=gN^3-U*{nC`=`o*^BWB5aoD5zDc^L zbCPah$}ndW(fDOKfCnSmYs?O0|98q>)A^t1Kmi5fV)^NK<0K|?>Ztkpg{wAx87u#* zeqqFx;gPHrpt<9XQ}|ZXmRbrVBf~@9!{b|~w(2b~o%2V>(ripi+vjs*FBxfV+~`j# zwUV4ks{+SXm<c0&r6KeC5rkopzl66j6a9?+$nen{e9~GIIv0{&3jd(>d9E1#@;j=6 z)uOkr_4gLM5-{%ICcH@ey-Dse{MZBUT1zu282Bo>*21v||3a&=U&8)UQ`x`eDO#(a z$+2t;o8*GowEI!b(%StdRN6V}iP(KElBg`U#9@D{z*)%O`vf>Iabn-XiXWl4ADbAC zbxL$JvcOIfTh5KDUbfOny8snu^oxD!YWTy%94p!42i&pJ2V91~3)1fIfdSdg-sO4d z0#s^?wrun5SjhZ6>?CT{-mI^K=Fel0?4c+GlPClQ3ODjHfx<bfb!|YLTAMfm$~F|; zzUi(GI2jc0gto%WFHCQ)PbR4%le@x}%Msf$Gn>-kp8?Z8kIzIS{LZ2kPIYA1qR0t$ zn7?WzV-v+FcYYJ4Hb@syr5~l=QXFk8m(jW!<oq3}hoUN{(zpzPWU;St4WBx5kz$$J zstdZw%J~Xa)f0lN%jHF>w}53gPr_z=9*MvMv}fS8675hU*yDz=>Qxqp`&p8$PzafG z#m<%=%AZ_k$Zh6-SXSFN%1V}W(ZY$4no;C;s{g~%TEA5qZDWZ>Vk4~|HI(T3pO(1a zDly^=Z=limT__6dNkqF<O)qXlFWR+|h=Y&CAT5mkLH;f(3SopqcV`3xyoaI#cJoZI zim;&G0GtxTkTVqo4z&eA!rAH-<PNvS(l(>HhpOr_vsaOh;YYEgH_}4<XGm>}xWc;# zn?;DgBeLc+Ou7F;1!12zVqb04b$E-(L8Pvlop1dlMR<bP+lzA4QYLl#oVuz6cm(EQ z;W=YB{ik))y=}SxV~#Y-JE9cTiWGBJ8vh#n6tWyja?=(jex4Nl0ne6Hft8KlkV35y z+y&dDCbKdpJ6!*f9e$D*QZ(PwG9*?lf;3mNx%oX9!Dm#%Tj>sXK7|7O2c;w@PH!A` z$}(qT%e{);@wHLrOr+~eoF4r(b2T#R>l_%jYgt>r>5{5}aWNyvNppn~*97@Ca5!n) zRB&u!64`2fsMa0iy>Oxm@QbJ?bpB*$d`r@}3#0zCM9#0Uq@}4Awna{XqNUUrOuWc% zslzKgZj_jgN(3Qdj%SMs)!HOMgJ?$SA5m?n;P?V#d2f=I&$4o7cdM>mQ?y*xMg;gx zgc(g7CW7dRu|;*V=I(Ayq5ilg`3a_A7|!c@Ic8!~S)viH$y!IUBc2WN3Q-Bvj^$c3 z5<sx!+AtAP?XbA>`_KmLmGEEV1Gd_1d=iz5E(t<VUtR&}*5~|vF-8WPHZkV-dpSZz zp_pr!Gxc~5uY<A@^EYRi-j}!SIA#*7YuofZ0ZDU<FPT}zCJ=W74^VFOBqlYZ^z9Ct znpJI{sOCq(3^0R-^me(SFPx2e+bIFLTI}*=5Tu69@DqdIKdD`5F%49^IqMZF*38aD z71(fbhEG!8)PhF}%!TM2><dpIQPFbva~SF(6L|_oSg~2j>p!M007t}T351I#sty)U z+#Si`84w_Buz4?P3V#KB5SPf|6%DG44C5i97KEp0qBcViqnfK8ixAqFYTieA`GW(w zAaRLIV{Rh7ntx26`g<b-#gL;{Hz3<k?DQn<ll%HHt7-aNNgEa5Q|P1E;2FVHjLjkQ z`T-Xxw7Q2{9Y#SISPD$<Tbr+rbgU>ie*R0Z-#Na;r%mD}%<5Jvs_7s90pggwVaNJy z;Gz5ncB#LFXNdQ_W-sV26M91L>)3K<zv8-CZ&&nBu)9dR+1}I*&}Lh1fJ$0Sh=Bu1 zZIV!tHtTQUYHDH4Y44xZ5%^qP#jpQBOzXUV(rydFEg-4H)}rs&NhB^VDy~OgsRcp) zBQj;caunT&@|oX7tBL@ERuek?2okS5fdLs%LT$*NCE(OF3x;97gEqE-ocb9DFl2Q! zgtm63uT#EgNyte@*InzB9Z1=+&_xdqJ!aCwM~?tK*3e@^?B#m2W|4N3p`^dmSjEDp zr5EJ*DeEctDj!a93cWB2&A~*29n=53!&rXK`>HxJ|5fbYYy!?SjKig2`8l{-`R#sJ z{y|JM;N@7?!z#|5{daszTz&pedK?9JQ8F;@qU0|0D_iceAI?7tSL#Z>U6e&#kwgbP zkkbtwSlf+Cu<f@_ncfPo253+zF_re*BqkMOz=e-l@dSF=3tHNe6Mx!NOm-RZ<2n>! z2^i*I1ua#Wv>X0&z_aSn73?s&*dqlVd-T@)W9p>J$FO7ZOZr;Fjpb*IiZ0<kj-=(t z)3frtzZVEN)Zu&;5GEyyDoKyR4}t#_Nqfj|4VZ{Qpi+zi1s_y<&#G{Aa&GbPMOY+9 zMu&t)2l!LwN5#q;zBt0;6CDn2Z&SxMOE<QuqarD*i|U-p1COE7rnIv5v>VIdYQtLL z+vF=8tIkQ-iCW8@Pz=4^uQuJ=>}nca<}1w6IQAlU`d|lyHiM6o3qDTHh2A>nrl2_S zA+q^%P|?VQl|Hvwh66uk?P7j%C%U{@zVS76a{Yy?)f|yCw>|CZvLrN|l>4FS+vXAI zH~1Q@M_VFOIwyh-O%sQD3<-Z4nfz%+pMuT$dA}3f(Y)N<c#Ca<Hc{-Aj|5{d<1iXZ zo-tGXE}|+3jBfS)BafO0JZ&L^nBNGx!%&i(k|jT2v%Ep@)Id7GlWuGz+R=G5+`2DW z)a`k83dV!1XXu&z6g?+ALC@Kb)3f+dJlE~aJ}h2YFNxQLN5m`jA@Q2FOT4byiPxhK zrncaPvkrTn6K}_!eR#*Pnmk1DXa@$0c&dc34gYu3$34$Yo-f5ypTaYP)@Z5EAVe%L z79fULyzOojc5hm0T5GmFJpjT`w=@qL21F6dx9}hS>_d<iZ+bBSNLanucs{{|sq9Nu zZ%5j$dIA$Db&Ad%>KL78sm^jCQ2QJXENk|S6i>1Swe1^0VH!|z6vhVJ3d~qpZgqg? zzXJ`{qP%dJwHn(Uw4c1)+4_+yvo*He^{Zd~>O~p~F~0$D{+lmT#%8yz$>m$BosT^* z0nr20&}O%cv?bbkjJiUE8qVZG$Ol*3*xZhC4DtbUv%|~|qj@h=J~GK)1f2?6ni^AS zZU9&Mjpv%9p98c#N(mlVtgend_5~7@=MO8-+r5XkjLvWM1!50n(f5dF84tfLw0Q}( zm*9+g613dxj758q1+@iGGXVyKBgR-iD*K=c=}3jXt{(VYjZ9Vis|CbfrAYwv)gXY_ zQ4v6I3!prr+D<=J)7@%Qhu1Goo8W5RnM%bbM$r5yo02?~go2uOrV+Uka(kl)NYvB= ziJ(Qrc=R;N`2{d8IC6yuvxg}q);OGU*^kC<_2?JJZgJKx9*$a$VY4ft=wFT9f@+7O zj$`$od74}ad%Gmf_rA69AldC`VZZbwE$pF`3rQ)z)dl0=BiP1ZJ-dY$-og#)1bxSP zNgczsgfSnLVGH~D`xwSpJO32GZILW~7K4{qB>)7j@ZQ<NRquK%CdOgGwE<m;>40L* znbh<k|G`<n?<OE)VVDVMWCQ4WfcB5bU=AtqL#CZZ1^b}qlhbb~9C*-Gk;ZxAT`V0Y zybkv}y{}K37*C}jNCD~Cih>GjdU1BZa@I@C(fhvEMh*p00h0JY@9QPky)JkP4t`7= zqP*~?>!A&M*52<x2k*Th{F-zns1|+)7*@OCH45wZaE#_Jpf@pHc?`&iqX9+x9zkQ3 z#(yT{uqtVpS=@!-#!nke{xxk-Yyf0~*(t(n5msJ^!~C*MP!4Ndq{RF@00SGz1&Krf zl7x`PN^-FpYdVe!k1rrQ)O`+Ple1_!S03m=74>zWqxiQFifLao4{wB9^g%?F=gS~0 zM>_u(!b6Igk78KGX%zF_BQvo$i2dd%>Ll%S;>zYS8{}-d^88%#^8m>@n(H6JN4eBH z0j1d%dV4m1hFL&aSv{tK$Ix%EF=8gH*LA?R>-5G>76)qa5?U!q{5zOkM$(KDXRO2( zGaf}bx2|K?&R=KDobU79gq@AE{9S-_z5ubTUu>V?@OfJ|ccbj>v{^6<LJ%vN_+lT5 zs+VQoBJBbzaqyAIfg+76Ibk<ohp|+arK#>CO_g}6Xg2YP5?z6EY1!XzyS@qf0Ycyo zuOK0K^{@C^(P8ojvDHkzYo|CVWwttu893J<y#^+hB@U&rn!3T0f)?HX1<Az8=m$z; z84_P?0&WlocJb_!`cw(tn=;==vp-BaJ7}^<vkj)5GB<|@BxD3D3m20zCAX#9AzLA% zHeAJuNh-{DyURAfZT&N3>rN%fv?<X)A_D19F*sY|SK`=n3hiSh@}3UycJ4WiH(bHN zbUmqcI2E<H#I??F`i~;nm*C<{G3o5OtmefzxlK(?W9UPt^?{_R4jL<mG)z;|t{nRI z35>GnumQA32}vG6{NITX#smVXGT-f&W{?OLdm#JQzu|LRVj9_7JPjAE=2mf)a`9Ab zAy_6`@*nHK5Zl4;M_QX+{4AWn;AI>6ng`K$p?E4K0IPv1nYAu|;3Z1JysS<AUUB&Z z&@#*(cou0$s4dFTZe<VbvtnZq!)oOs{F}_@DHn%f0h22Bz;l-Xygvx=wvPbJ=czn? za4`J^1Sw++(os(-O7^h_4k30Gv1ow*3jo*yuOlp`=K1je*G1A%BvDKgg|#5YBM4&7 z6Fcw+#8`T96Shm$F-4CMRvOmRzlU3yc>^y2SSS?R4u@cwoDv##^y~sxs3TZ9P{;%d zV4{fxRJ6JmKGh2ygURWXjF~(9skC^I_ki6)F#9EEOd#ZJVmWw7$<^jN><83bny&>Y zLev|G5KaS;mcdAD^#EG;S!iW2dlFE;4^Gs>Ag}%LHh~9<rUs`{k*H`89YP}tZwN9_ z5Nb4>{Qrg)EWdHM7sD`c1JExBvYFoV>hx-(khc<7V#FIC<h0_$S~x^Q-Xqi}81h0S z`z(%QOf59lZteEL8@Cf<Egd#yUDjAzwgL0B?HFrwc{U|)Sf3nluR1}w+xceXKz4pV zDF<3R#md&RV)B~jccRiE>scXhtpKePdPzHNO}c{S>_$Md+4Z2J`3~AJd3QY$$aFIX z`~CFMe8)VB4>GIofqW${KcIdLn~0fokH)b<em8~*vP0#B*Wwcfs_7_=ve2~sD0Cwh z4X~qPqW%M5l^nSL-&NiFUsQeeSbx>K{=2Hp>_(s@oc@#bn%UH3)&+`=hYRR5kn9dZ z4t}=DW@k4MKznW507XWFA~^)<B}jO2XA!N;-9#m#*l;v`Co<_-f^MC^gCL=EAEC~D z;8WB52Ias8vj}~36ULEv*{WTgK1{L~8r$6<UY<ovHi3v~o-iID>W8V7CdN|4i6qAM z4ebxmQmUl=ftwL8iI;^*g+j63Erc38A%+wZ;C|f;g&~0xDhNPW0h~tJdNR=LCeA_F z+`OLKFu)Did$N&(XP^abKo7X0_}Qc+i1%iQ04)<N6RtU%hyow&e})9WON1!ABurbj zSe5(+yGE=FcDHWzM$lQ1Z?>CA%1Iyuqv1qukiSCW1Bc&-h@49tFbOAM`K$%MhYGq; z(=Mdb8GBlv@Exc~)FVe+e8f?}(3glDZXwD$X&-}Zr%EHufLK``s0(E{f(m10Gpv~1 zip{cOe+QoUHphy6YQ=n3>^&=1YQ<i&V&ztBzZF|mOkGKpJVOZ}R|iHdYfRoAhPD`o zCJfAjO>5Ar<~s<uzn7}5Uivr6h%|Jr#I~<T-l^66Eav$kuMl+A-Czo(;)D~h21A_* zQ`$fw6Ok*(FQ;<(B5a<J1c>h2oIp|=g`GTNh0%lGX3!tM2{;A|w$fM&6xeLy#&FBW zLg$8`qxT*s`p<kP{FI20Bq8#+h)~a(@94z@fxIM8dq{xP(RwifN@|u~OhA%2g_*aT zWO5IE*-dg3Po<1&m-?_UCn%BE66HNfnNu2R6tx5x!vsx*e~$$I3b+71-N?j8VH#)w z2u!(M#6@{R?1`9`T<@Vo{xRYha7AVO8L$Pq_Kxt1N(i1+U@-~+tM2Jnl;!>0eF79t za`&uDxqFzE1tpCq?*5dbmvA>3m(ux<kWSVVOF6@ag?XYYR>Ap^S5b0}94oOE(<En$ z!u;GijRYIYiiCzU!>x6)Op5~OTCvw2;0wtUob>WYcvweLn*2RYH5c0bU(rF-f+I~e zJ?;Jr(tMPJ0|^`4<^~5H^sJ2edjcqjt{$0)Qv~`U4^)Gz(0`5=KwY!|f-Tvtyx{Mh z>UY-HodcW0prhZm;p_foQ6+hf2l<u`8iBB-=?pz}zcz*!!uA`N$aE~WIpFqu4VnV? zo-95=e42t!iI1_GgLA`ZxTinmQW}4NG`2+6JNk^_*djq;ddC;~VR*GW0Rc<))4~;g z2LDMLdW{_CRVQa6OiuGzWHovkZVzODhQ2)jTTloaCA8|ORvPQ6bQ~a?8!NZrbl8%d z{GLVLi#U9?eL^*zV&kXaC_#%Te{Z5fKkPxRwAFGijIrd5F`k?;MzdBpU9)32kS*M< zlV`D$N30zl6+ZY?Rh9fosNJat!B{j>Ohc{B6>^iD7!8eD4O5Y*?yiCAaCS<~NYV+e zhRHr%y%HyDErVkvwwGnv>kvLO-rTR7pmo&@vJdL!n2n#~q3B!C%!r+T--lM~JvOCr zmX&ZPC4eH3zMZf!;lp@*Xt+p=5T$WG!r={2V83@`)=~Ac2U1bZXBG-lfSt0eBkU(X zBsp=58&D1u0S23U?Wx6=&4)aSdmK=~W#JVlCwwu5)X?WQ^p~LYyTw0bl>rj~{NsJV zan9z#Apbr&%YW{*w@2(R&YC`73g3c4@(;rh-7PqhhQ|>F-4+^^RuM2Fc83FigO{62 zKsg6dy~={YUOskRc7jj<O28b9t{nuDlkIVNY*KhSN~-23iv>*Ly2!btcgsodhiaaF z(Nrfzump#s%=((j!^xyq;0+K8nAcaC*^fYXVZw?9q@DMn+llsSHX>hA1Z0_%q`Njc zOeE)5^kMVbq|hXU=vWCIk%UpXI(fk9RTw<1<4v^u?B%~hoHUL1ymCKHgxQDre~Ohj z^d85?E!F&ORD%QiC617{XH)q;;lk9jDTT%DaafQPuv#zQ^bu7ATt>$hVvAy<Po&l) zQ`Ku*FQ%YzkMOr)#t!YFqg%9OjU#5@jI<-jUlJea_!hV`L^fQ}WQ@nK%X)Ym(obiW z9tIf5EK1lz(3lRSMsjd~A6sX1%pMaYPQ&yaAU|(83}~9OpspSw#gHj%|E5y|0NeO4 z0BMnlU|#@v$PWp-o#nJ_3GVAS=aUZ5qZ)f*?VA*a6EWiCUEJaA+xVr>vB7<upy=`6 zK~=->`GOD2F7$Fc8S&#d-jJr7(>HPy^SbCOY;q)zN!e7K+yM^r=h#~t3dIqrFK`n< zCWLBTQF)H?&_Q-k_@P+0N#J~Z@;EFjpJP9)yfEKg6;xihC#~Q(ZYh#;qTQRvvpOgC zSG^ZDX0R2q{XOr+jl&k`Ez`a4Y{Y_Htc?20qPHk7(ifJ`L-K^L%WiOp6rg*D1{_>^ z;NUXg%>qvs%rFQj3@McOm7u2O$gv!KdljX@JDk1*#1|Q)^fF&wE1z`!sNP{qPFaTf z#0ZxdTwg#Zrfdbr#r}<G`Ve<5>=F&}qOo#d(l#A<^XgOJ1`lz$Z!2mWEtukH0>@N` zI(+e;%#kF%0kCc1td+=iIaw0-kj`l9*ONiM1}sR^L(3Awf~$6`=uBEivRA8$iqzrk z<aa-C>a9-u``*_!e*WDSr~RP!@FuyaNORz<w6!}i45Y_!lRPR*7HIuqs^%oOKH$_z zb{PF46zPWuuqA7Z3T%rxjU{W~_pV=%l_;%~SymVo!+=B2WA+Q)ckA-Ld&J4MuhQ4z z#0D!CpC{1g1@=DyA@7N8e`Ynk*a6$Vw)ltG`_eMvWot>`6Sc*=`r{20Us4QXqV>Iz z;&Y3C+#iop{OaOZfBb%mPb_}0KmGv4hZp~d;^`>A8F6#-TI_P32pQYg!Yu)ftTa!+ z{uwgL)?fr&xw?NG0)Ol&1iAOjp@)wirFbMw2l&deh}glRfCFAZUw*gSY1d@E#p!L| zcm_?kSID*A)=jDO8Fa2`GiOs7{QWP{k8Kf8xSW{bCfJvg{t72C>gg9VcPv)3Sz9C} zl;5gO!Jmx3wfU`DDc=MRNFFc6>2FLjZiC<*AQX4gBeBNZvWlG$Ck^4`(=M~L#I3AN z=ZZQ<=V@wwITqVLe6Qc^)IUzSk%F-<@xKocdb{b77=3`+yqg}0VF#$yyXleKx(x8q zXoKPJ2;u&Px(;y0NszV3-=U>rAo$xWa9e^a16By_P?Ufn|H6y1It-12KgUIfHl8g7 z7yZFlxCZI4A1z&LR2+>jT)Pv+P|DR7H{moQ%MuKgP26LDwW#7$-B?y}iWsYUl~FnZ z&Yh<cAMow45#X>w(w`zbS;{1H%i1b)c}FNQ7L>)=Sn}GzaaLSC^e5^9@$FK?um#wU zRT`XTjfHCqTKF048dwrX9I+U57-WGxD=v+$5>fc}gsF4yLQYHNlmC*L{dfna`*0e$ zCb{(s5*8dO9s}l79%^N+q(2(!Iw+3C3*c!b_>FDg)t4Z%X0Ud1HbwY0vVlOWC{*E5 z3eo0n4Qw%kNHeLSP<Xjrsc&`JwLIo?7kg5FJXXyvo=mUd#Z%~&UM%^3YSU7AiI}?6 zy#nDMuEtV9?9IWr({HIv<>gpr!CpmYRxzSr7|bE|d>kDyr&zTu400V?93i@~t2qsu zQlCW}3*oR2#)HpV$S9^0t62TLW|dHtSP<mPkb#{nsh?XMQm>8Js`xTM1D1xmCBdoy z-*z>4Ma*#qW?WO=7MzSR%zl<E^DmkLBW{O`>C*@~NxvK`uO|k~sUb)^<dW*=e<V4W zMnQ=t!l$iy3S0)N3R;3jI{O>8sN-Zl2B*tv1_`TQb{M0;-Su;)XfE7y<nR6M6x=jd zMsw;pW;(nH<mR-d6gU$(n<pyIx4|ENB6*3R4WrC-ItvQxV1=_e&Gb8)Y-Okb)ir*A z!=Si*L3_IXq6gP!UChvafs!2U3rulz7%fv8JAno+{_v=dIT>17S>o)H#K+<TSy|~| zC=kT$JA|OiwBaas!I4Bt+5GystJDjG?Pb`c!&HqfdBA3-t-f#y#)GazRzV9~bNsz@ zU7o-9SSOq<M=lbTr>t6l1|8A9q_&_B)#U<587SO5CqrF``|^r$AT|Ktsl14$T4-ce za~hgwHO|CRs=uX)EIv93VlOk(@oBlUtTTuK7}?X?QzW7oWpH&4M<QBMyAs9Ob&q7) z`Y)q6<HT|*SY0%MtmEL)L$Cx`6ZS9!Az0NkVLiN7tm*o0I#+GXo{r9iX*eBigO7k6 zccrl9@X7B9R8__5&hcTGmC;7nA!jjaoww;G?C)bOv}pnBY5g=M=1|~Oe?83E?*ObT z1b2ullG*Kj)j=xY2n;<|0p)w>%(WrTUt>*4ewWE9BqqPRHvlmm_(No#gNRobd_evZ z+SM>R!?{Uy##0G`SS>NtvOMWMTeV@4lofmE1MY<qC1BMPZ2%DYLs?nHT^Fw+iN)6y zO;U&ZeCuExzhJ%o#%4c@+TgX3AFn#r;|o;d9u@yN^BwqvfGXDn_|p&|OiOzan_PwU zc@HMe=Kw{<2Xeve<@?Zfa<an64KvR(D2}xyR>AjOh0R^N-^_lBlDfQSmBx*rAug;L zM(!9F>Cv6v?hBwUz5vxg@PW1yw$>+*LwF9MzF;+fI$y|j@&kEp_OHE3z@WXsn_)V- z1cT&0WZgr4WI!*4bewMw`Ew>U9kx%!7N&kjj}V-y>X(;%;`=>pC^)<uSF@sRYR37a zd&m<Zu?9Cmp|#ns6Z%?jf!1SYA4a&K%d*qa`;drZW(l|!g7cp%@OKq-!8t4az*3Z) z$c&!VaOoFramws6glqKqcZ}IoLG9}PR*+c2QCZ;*Se7lD0qJJp&c6*VTy#icV=n&$ z)>E+vv_SaXhzrNC#5mlI)<GwsnRPM)D|6*Qsm-Bx_+W^(T71}sD+*G#f-=^?(m#i$ zyQ<E&V&w}T>1LbWO8cBktOV@~+J%;q{#VHtvxzI4k{34Nq7>`8CeG&fBIk9Dr`5ct zK~6Zm<0YADO5%;!e7Ysik>A=Do8LDO`g$PLn+yr{iY|f>Xin^6u{xLctmgJ!-0T90 zz=0_S+?+ba3Q)xDIRDZBo-%iA9?#>jfepC}D1a!agS&um`A-gQm~YxgqS#fm!mUIf z1#Y-|$o(QML)T$<^?Jyzf|@d`tAf1nIm+wgD$0mUuu@=y0YN4<)%$P25nPB|*Lg2) znZXxP?NbJBB0Bz-s2v;WIG+mylbh+CcOl$_c?7iv?r$W|0%qC}n6U`QDx8&7)xn4@ zR^hI!GHRT#SDD!)tH|hv%aszXr7RUPT&DILw#1A5O5yuTlnxY-xX}?3??vT-)p%30 zZu_lhR_9X0t!2}tu0z|P>_D<XS%FQ62zMjaoA7NS7q>xArfE_=?XQ3PN+99B#9u@m zbhF0mK^!`8XSQh5(aA1^o#gDuP9h}Z-No9@uSNP{)=qExvBW}zS0RP2Q3K4e&SM`O z`|Q}s%p=;l^JiHXpm4_@zPQeRVn4QVxEF9+<c*3Ku$wcM<m1D5T%K9*0YWlD&hzi% zAmaNHdzGEQU1+GM_Ml7Br`1EI#4WX0B%&_D%nb~4mM;rbR)#%y4xE{=TpkYLN=SLF zF%A7irzmD(c?9Sg1!LI;C)_WvKD;Gwmi|>Abl%@KUmcsZIkxJzE|v)=fBimO-}<`n zGQh?(Pr)ID7pdDR;zlI#?Aix~nBnFzuv8n#!uk0Q+SJ@faB2bS!%b0g!D0T(y(U)A z;T&@V_`wA$CZ7v3gHvk+44Pr2>?2Wz(<5%fWLKE?<eK;7nD<QQ*-1dm*l-(f75j{a z^@8JMP&1EV%7ae-jD5*kv1_q<Cial&>k)i6%}+2qfk<?{OE?a?RPvux;>KUvFkOzj zd*x-7CT^JH&k5#n)*O_v+Y)Y~xo*Q7K<<vy(4Mk)w(vup0x!@*e*kCD6c`Mdi7DVe zuzAFgu??Uvp8%*e&nACxxVb7n*p22@RkPx?kOjS%G(EWtH(*-^F2iqO(rH<iD!{X$ z&~DQGFh^;_u?2&huoC2T7r=Q!9LK^=UKKGZ8HF%CwUt?Zvx7eS?~*@*c6G#ATa+ri zU9-vd@=J0zz|2DdLY?=a0KVjPEH!5Gh2pguF6;^Tq~AwiyZ~vIldHIH1dD*Dh%jL! zW3q_Shm+ZLJfYF~I(i#=52(P+>UQXlQ0EIsO1kwbQM&F^EDHr0nh^tqwh)D2B7?_n zilAi&`QQE=G)hu@5lxJ9;K%_k0oJMH<2)NCd6<`o@)-0kXC=MmSfHk`cDiQkG`}$q z6y~3x0xU+5+li9FoOHubIR>^gcpbyJc)-h;taj85W;S(+Ri@{gWqvXhWtv(Cf0>$e z$lbp%!;Bqs(+)|yc1RbX^k5a#NV3>Jpjg%eryF=Q*T`t}QyBQb7ImkwPZNC^B_zF( zX9T(9EIyHg$#JkFe-8TyIOC_SA3Sie8c8r`C00{j8cFzr7LXdYIx2CGz~tKqz*{(& zWQ18k{xfpq06{0AH#WZ!<c#9H1ZDO2H;*II#%JQ$xeYyx{G<64#0HT$euNgO*ceY7 z7y1~}VN77XuWg<l=_ok9f}Fx#n{xSI0VW)4t)jVxIB1AT<b1e;yP&|nq$>(Di9HWr zfsSP->B2i6qq!$mQ&>m2y&rCJ<(~y}+y7L>SNvLN4Kb7IUjt@^Au7Aq<MG`iZu{ZH z2pnq44>)mgC1zF|GxQc*KD;q8ux7+CO`gv4T{Ko#v%dU$!4bW!U*Im9JC8WPF|nPt zQeq*D8N(MD6*w)9sp$!PsEXxY%SOT9ngx4}<vnn*#_-mC(59)aUpa2lznZt%9+`J5 zyV>ErS=JWN_Ex?Am1omf_Ueg5Y;lU?{E5k{_LcT!Xj6f}<gtm|*i9V+Umo2@ekb^d zRfaq{<banNtCHDD2Yj9E73Yjw9kimtbD0cBDWF9=8AEEV>Cr#788zpWDC|YJ$FPUh z^t4`dMCO4fZ?5%zxH*M=Xos;&<U)4uJ4kuQ`#w&Lz%TzEhxZ;?^Bxd5U-WDm!(Kb_ z`T2JytH5`$-Jwk;q^?bji{0EI(x0=irB4Fidw?cNk=Y^#T?r^kWQ$~Di3}pcCmQQZ z>_9=AzOOXaqY@0rG3PNB0<=u~L&(1bPZ>||5?Nc*401J9D1EI>2oMpc)z>K!eDq!w zWId4pJ{e<0SWvfgUui~8;tB!e0$GPZg&c_gjv992vsk0RI|H+_UL(yYoe9_aE)!P2 zv-rMyo0xoC1|XKT4GhI*zXTBuOFl_z{YbHwJAY4ehpI{}P{enUC0TYxKo(J)Q?)+o zPc%`NTIC|Oue`(pD0kK0TOw&0`Wi={NYS^#1LF=-92g$o5lI*&2ldDrAOR~9u{q%g zHfPzy@A-#gi$|QPjFr2w<?`2jkQMWBoRAlw-c*9!?9lI$-9kF{sMI1@eJI^1ruGT@ z;O?ymVf9Ak!{CA4xLLTH_PZ@^cu`O-16q>Q84g3yg;!hkRLbSDa_teq*X_0o`0%0m z(D0WWy)eqKb)m*1j<Dnr#%mW{2Y3?YVW$p7jx;yB2CAXfCVr+bkxkrxwcTN+5@M{( zg()+`mF4~RVsHSP4@)__$AvX#!ftOV!DV6>SlgW~LW&z_k`#mg{XMrDKH2a&a2oX{ z?OepcE{Zi*>!*tSUT2tkG>HrbRGDl&kD=FMKan;-2`q;f|CSQ=YW`cTolfk)%-73% zOugw0wkplou3o$h7v3;b#eKb96b(4y^&A0;q|(}Mk@gyv)|f}9l4nS4sS|gb8}sGZ zO$f-we22dF=cU4(<fWezzciPXG#~D3ZEQhTH7zN@@vE&4!D0}}&(0s89FQ3<+wWh2 zVdX6dA(kF4EIgd--TX>uv@xxpDeTp6XtZ-|X)jLLEb@LC+g8-eCK(kjtbdgsE(c=x zl>sG62d=SkaaMWIix5;#>jejNV2^%b-sZH(ybzhoS3A6`Wv#^0Zx=k9#*sAk#1`9x zg4;z3?lMvrV-u6~Rw%f^kB{!61`g42OJ$U1K-n#IupP2-FDB}){5NeCy=0G3e)uGy z={N<B)R>N?vBlS7%Ty@Y)vV@REcc>O<AQ>u{538kBpWw7NTb{=<LM2_T6Oc{bZC)L zq(#yly6M@JTVFSdw8&dS^uyR#>8?`tR>C8`xnfJdp*$J|(n#)?bC)n}^~OrC!yU@T zVjJ$LMG6d0#)4j>^tztTIUpTYdxdx@G1@zaF24f)0ZVMg&AqWz1-(pjwe~rdVDvzO z-Y1$=+YR3lC0b8S)_Uo4{|6AqyL4bc>7xPVO$-}qT0gyq4-P0x#DF5ce2dr^P(bf3 zLfLMSQ7Y+M4K~wW!@_5v!isY-=a=kWA|<&cgT6Q8DJMrZkTtDeIj1>vAOx}s<@_d1 zY3fgWLCU#Eko8R>E54!e9Ya3e>xd=Ex?~7h{Vv09l;-qeraP3u-MfVXsF0zO?5U(` z^wu%@M_m}8!JSo$^b4L~bzP?Zrg`FXy`slVWP$DUSIvU%6Q9vAoh9_%dzcqgIhc3q z@}8-EneS@D^fouVF}x=?a_>oP2b(|z{}(Xt0p>kzWdchg+-o<OvkN(|P3FwF<lB22 zyO1NBKMo%ib`td@_oFgWXoh+tY|tTgv&*ot5|>_Rs(&#i2qa5f%mtOBe}#Du+bI~2 zZQE5kwSsVd3kSKe_+S=4mY1@k{<aLq^{eck8$o<nH4>kaw)wW?FWyyJU`~A#Uh`JL zC^X_(4ZV3}Ve|;}X2m&n%LNA;mXCSQmr4GExNpatrWV`RjbtrmH#xjF$=WK&l8~Uf z%h+2a;JvYJh2Tb`=FHSpO{E6@`V_5zRh+@VKRGio1JYxG?G!_z1wDCepMo4(CV&7s z`DRCQqR@kSWcGcBajydvvhR~(P#Uo<28GnmnK#J>04fQ<sFag<)mogH+1CoLYyy|o zO|7rXl(bC2dXSngGQ4b%NqaN4HI>q&0U%j}44QEt&ADPPS*R}Q5R;-4pJ&_vMFtyk zrZLP|Jc5KCx=`z~A0xR&(sdB)b8L9*UYju&w&ii&2{g`v+?Z>L$%2-yPopGKtA-p~ z;230bvKz@5dvT^1>y%u+_W<l3^e=f2Mls@;H)pmb7U23pUA+On5dz<tAUnwqO(&O) z-@Zf#i4(X+NvB)D>QYe>n7J$$!|t#Ef3ua=4%>5a07wiT;uz~;TG0K3O2$tJV2_vX z<wi&2hY;episL$buxb~G@ZaqhD9~<#ldeEiom3dk^8G6S+k*UG9;YhmdV^wDdg$7i zYy^q7QGAe}CLn77-*<W(mN11dQ4Jo=z_kM~9U9SD@Xs>#7K-OgJc~4!Fa~$Rwt#y= zF6U1H87y3Xh*#3CI2x7k(E~Vk9snp7+t@me<EoX|EbEe$H0wtN?D6Imc_|+py=d&6 zj^djhyByE@i@0gE{-RBri9zW6G1^nOjL$=fz-T6)`i-i71%jhTI!jOwE`RW-Bj^%d z%Yt+}P64AEXd&~?XJ{}vyFCWMXKCG~>5h7(aTg*yL6&#lde}D0-LYscFo1b8z|zcF z=|;?hsF~e?nGj`O19-rRR8?-oQH20f%<NP6&K?ug5(Qv)GCBu2ah-tjzyi?Sh?XMS z9HsW*V!r5iAj8d>OtiY71;1!Qdm~Y*3>VqQ^{u$;DZ4o^t7-YUri#DQ%{Ta|6WoB5 zxLG;S8sP7q5sguAWHG8U|22CBHi~@S!^#6sqF}&AeMrZ`dk&Zq6H$0jS-0Vpm;#Z+ zcx--IKv>!jfr&Y2#0&%?sklR_61Kw_6;z39&4@0^+?Ey5au8UB3~=lbtqs83eJ;SF z)RjyE`7FmCBHR@KW1?ynBSx~f7VRYh8Bt;`WoI_N>-(ww67EL?3k{SB9EKFy?mw4x zNx?^9tJ3#VQ8s1gTZouZD&G|43Onx{_?OH{(IzV|6cij;r}u%>ttBP8Kqkf5OYO6| zISIJT6lr|gG%SPHc?BhvXqf5|g{CC&RIk7#ECEA&=RJ8tfxQ9`YMF%%j;<Do`jq=G ze2umI<@nBqH;=NgY`R66#fBTDN@3@4d?+|VEC5ypf4&UvVwMz&jsV9+X(J}dT@~Oi z53=C$Bf&{5MugCxBwmy91#iTn<%oDIT$_s6!}Qe@UDZ5te*IU&@WTayTJ2Jn&teRm zFth><`>7BU4v{$McG4;(AIJV;(HTe&fO)7~OG*a2d4a%}AZ&tG-Zo|DjUtVz&KE6# zK|;BIG0N`r;EN>~5P2nf3=J!yCRHGPut|i6{v_r9R+Gxu!{V#em&ywx=g(iKqgkVM z(X5n6*2;B8j?bryHm4+C>kOCA*C2SNkJ`8Qf8M@-qM=t%V6c6+iZsGwNc-kd`+WE! z8nlf-V&7^A$!Ylo)2yZLnPasDjj-({Nc)?jDY)r}+F)<D33;)eXo0=mYQa-bdmCRa z=ne+M%d@bkiFLt#Ss9B_x%sW)p2z@e4Ftn<G%hK)C-EygjXy~WndnZ|mfs$THO{8Y z|44vUr+qI0dOzIpTEc1V6Ih&&lvS2sTdlVQTJ-TS&>%4nEEA)w^m7O1UQ$=)%zlP} zONt<-{v=5uc!5Ob((?8FlqPBG_5A`yy(*GgTO=eDzcw)%Cfejy)<gu2nTdHx>77Ex z+r+g=xe)r^2ZO8N!1}^*V(pyA-+7+$=YkacLj-k?*razdfk?h!qSY%gODK4wmWO{X zPPn<koQ7)-a9ZSJ(``KerInZeKokeNC>0|XuNcVV1N(22`Mm(ZQJ2*NaMqCiDU9+M z!*Ep){R&PjSKN&TXB%-Z8Ou}-EWXyEe`Hf%4)7vUG#K5Py}NWKF4h=LWVJ4`xw?l+ zf$Qz*#Ax1&B9oMHh)QX0(Qh&(3~9y?#uxFkLpqg8m&eFGXqyws$+nH+za1!u+Vt<p z3G-sxK%2(#9}NHq10x@oY|K%sF>@|$jDp4t7maBT@by!vG1&J_?=DS4W3Hu<x?>6w zu^D>0gT`DfGs$gel^vGnqMFm{Sbi<)U=^ovM}T{v_J7pCAK<HK;4i5rYraFfgY*j$ zGNyO$V3#gw78UcBTEs20XoQTC*g71?|MMF#H(D_Gc^3R00hwTMkv3e;yLj+XLh4+s z%q$AYYHm69mA4F2o_BSZ4x8Y>-2wQGBXnZ^mrGc?bvo8MSvz1spgD`Uk!U$&1RXiB ziRLDk1WeoL$6{zZ(?vgjfdRksQ|J|JABy`ECh`m*He~nmN52(q!R-kxq=%5#(KIn} zL~My()Fw7f<R<|!B!jiL=kA;iaIxQchU-5gPQZSrtYPQET@3_-e9tiO_aRp&{Z^HZ zJHTlb-mWRlN|Wqch>H;>;rMA{+(1;m2|oZ);nqGU6zokoKJN)7dKi3EIEij9ciXht zv8{BCA-qf{#{6gCkKc>mtqAa$FGGaMK#t4K@nbN(oBm8cIMe$S7UyjwVs!oZt(d7| zb7u36v2AI6Mx7gFOt#8!i!#n&PTXIHyGV1R3^>@om0y9&buceznv`%ftx7WsYkJ68 z{~S5%M*=IvZ_I!|FZ|~vJF-4R!5u?^u^+US9nODKzmT%6BDOV&Lb4ea3U_`R1vJAA zm;KzPN&FU+$qq-ZTw&O#+%e=Ff|CJ>;X`W~@D#>A8Uzz08Hu~S8w&sUN9<g|BW^3$ zeDDWS+=KJ@svzxwe_1r4kyb#3RaN9WA71+znNrbv@VxF4Ql`pAF@Yqq`}ct17!psV zq!f@EJ-2-d-LBzxEh@}WWgmXVs9Qe*)^O*ymV5o~I-Ae%yLS^jyf&1^XHYoC{>CSW zMaZFqcBaJ7AbD{0QyR{S8-5R)eFl}o|Dq<3+(O(~@Q@@qUI8rpFf@<leWElzh=lDW z)_%r$l)v$YSm`{uSi+of%P9Ush&DTfJ?-4M^g7PABt~Gr2|w`?LQ+OtA{xQo2$vMn zALoi-m~Whm0>R7YtXnVW*CkLFO;bNc&1^Q&q^imS5H5D_u)|n@dtbATexLU{scQ8K z{0foM_$;z`D{_?w{|y0C%Z20&&Dpt&zQ4BJpWKci^kI?7NTNTQzcmF_o`V!e;%S6F zJS-FAa39pi-)sRKso=2>!1=<ZMWAmv04DozN>vs8dX%H8Dv@R(LV%#G#~Sxxe+^nk zsF9cd2PUF0g@!sqqHC~&(nUH^^o|=R5a~Cl2D*y$vd2Tp+J6RX39$y8jC@|dM``>3 zErhERybREN)Ngz)K(XBinxhZ?z-DtnP*59RErJ3Uc=n_hba%dh+}n%wo{lYr=q9UE zNAnjagDSo7TKZ!=T~H-1s4|QE+%D-??CRk+dI9(x8jC{;Ek6>v6A|<R6a@NsXpOjc zKQRr&fnN?f3iknkINBK=n}q6c-%%H^KL6qP?y1PmW4)*>F|MDKC@eYBn%UGK26~-S zGl-TwzX2rlBrtR0_pr!G^)Di+J$6S2j0<80!7u-pfeRop27#nBXiP?;sZB=^zi}n7 zAr7(_6R7j)KmsR<{*jkNW#yot?{0$VS<-$1guRjcj<CrZ6tWJlryd|on$(z0fQeZ{ z#GL%UL}IEaM9A-3=oFIQINm~jIRZj{bHEhoLVj}w<<~><>k{(o9F*Uje);_sb@7}A zvkP7}TkuPvgR*;^=>84a4Ul{9rG1P|boI`dV;+7?wu*naOZ0FxRS61_^r9v-4);#E zY5N&2uGCzxSQS4)W<PLwLM!Md;Sk7!y>sa|*9KaGF6Q$mfW3*gX-Hq_MK4Yyrgnj; zodHzA?*st-l3xx)@D%p)2KtC<gxqJJBc|xVR~(!A<Ufcb;;}o<40QkWhyFqLPeCF& zUUWY=@zTB@-A65jP50X#GBh0^|NI6BAud|sn^B*+S>|_(x0A0EZx^o>Z#NH$cMe}d z@9X(O5%utS;+@BD5bx>y8u6aNFBk8be3E$2;$y@+mn-63$kWAp4mbZdVdyhA`}jEo z&CR9!jChyx)8f6DpAzo?|ATnn!e1Bf75tERui`I>_Zt43c(3Kph<BJjA>QlxqvE}R zKP28N-znZ(d82r5<J<5i6rQgKm+`wP_4!5$-Y$Yo6kH*K<Oj|xM39s+Um$`HQSb&4 ze1w8CM39`j_+$}$oPwi8@CgcLir`Zeln~Sp%^0}xQgn(so27YE#mx!O1AoLmInKr6 z*Vh))T?$BfO{8pwKTANQ1o?}U@{K~a<KP~y*G%U5iB*cro4O*I617s?-qcmelucGj zjyH8pGUYZaCD)s}Hkq>2O7VD8!^xClk+M0@JA1uI3G#eO>Bk1M4dD+9c}&Na7W~x4 z^W9I2X`?aIn(tqUC}u^N3E@Iznw~oF3u^DPqlM#C$AYCAxt@OBJiKYxf-=kv?Mt<@ z@X&POMyy+@81d_RUncfmaw-S2oM7@C!T;0Vxd290UW<AsGbBR@%pgI-dk|0*#3&CF z0ydEZf)W@AB&3QG$zT#g5|h1oSON(XY?3jR+SaPa(~79Ix3<SVL~XStKodZUAXZU1 z6_itV&TupyBg7h+`>lV^B$Ei%bK85*z2}~RmA&`>e*f!VYyE3s2}W2t*mRDL+r|C9 z-BHe;*vF%45dPr)Anr&THpVEgmMG^A`}nF4xLvr{9lmX$=(*rPy-;UNcrz=pvd2^n zSL)zXy(+bgPpeXY3}em*(8-p1R3Xtv6xu5|ZyY%94b*Ei^$HB@{&Xygz<DtdNR|Bx zU*#HVe2GU;&gE_E8LA+eOC;w|J8TKbaD*ED<(~3Q?p?lTe-tiXQn=BF(db8%VEA10 zqjfj*F!LkAhBIjH)zBdUP6W@y^tR*dZX2T-g?7<1ql_su>SZ$vqKpY~r}R<HrfX(; zv@s0F!7~eNh70}%wqxT?8Hk-Aw7+e{t|KRWyQ21--OY-m>4}Ze^cBgxPX`g{_}Sgj z;{Nz*KOU0)AzWJ|{oj-ROTOmlKz&%Al>X0?;}_&#p&K`I^QR^C95bfVxkWI_+D`>} zt>jK%J**<`M(5?Cj?edJXX?3IZ!;XX-nOD`GBoXw3DKcgA;t75cZw>n{P>CB`0p+K zcAB=$-}-B*tgp>p$pu-PZ65}AingU;cc-aP{CS#uZd=cv$ANvoIBDKk^!U`zi)x%3 zO}h2-qJ1qkU#m*}V0Y?_%kHo$RFtnJ+SeK_Wq7hX)HW*&_EV*V7;VM3zT1~HZlWN` zKoT$!a07{e3vdAbjBlN4$hhwmPm`y~^EA)XJllD;^X%Z+!LyTRCr|jI_jNVdg@vQp z+HIYo=I{rl(xt$9;9f}^>G<1FMlUsve79;Ja*=r%*&;MYIBb)C4ZNt7u23h8@9Bhr zpMU&B7x}i|PcFf;Z_?6_@=99aKKaz@lS$Gi9h8L-5_p@PKNA5D&^XsN?nwPSo9_eF zdLOFR`$a_3QnpZ-p1%4Z+V`RAh5Cq)+akhI18NxRvkz>(52a_FTXLDI5iv;namw&C z@GIa&U@veGcnx?Tpsh#J)+2c)@=WBJz%zlTizmXO--_pnfa<p#Jh7_%Ejv$?=tuUA z)kfNP=x-nqm<)v5m~zts5q+V)scl3*SYa%;UVRsyY&^f(dg~9Wg%*hhYoYxJLPx|( zyLhoMjaZk#yErH2VR^I5Oc=}*dj)i^)fj9R?+BBm{H^{s0yly{HDz~!Ux|pkc2Z$% z1RP@FrXY0vJ?72C$q&4u)bxi8Qd?B9Ca7OE?$5#PV6w{Px{`#Vi9)<uL<~64Vi^(j z{uYI9q^XIkTQmRVvF<Xo_+M{3%rxjjqI;bXkmz3Q4rr0+GWcdg2<-cE5*?hX?^y|a zqfY`hD*@Qy{@sC_J!XYVj#E8^JW#)$6NdR?h5ES~Q24v-L}0jiRd;IUbd|m@`?%7u z6(;G$QxmlO`j?$B?<asFdi_+gu!vrk9Xus%V-9;<P?BsUUWAe`&^JHc(VCtp0y2TY zeAt`P6Y#=GR%|4Dd<7_0j*6g0ai8LLgtLVQ?wh@h^8|OQoLjkV2~~lc!NH-AC`?#X zU|h*U9a4eO@iBK&tYdZpu4wu|m>#>Dr^J1SBolnyV}9RqJggkQ8*<!YIsQsHJ{WRb zgJb@VNBN=_2}O@s$$QLY%KZ`Cx62<emqjU~B$z(WWBwA);B@&y$NiHMQgn5k(I+F| zI8mJ<hBak(E-pc6{WR<^Pw)*Ak2!-5dZT}BHcjN#0x8?2T%?<Xk}*kwAQMDuPZuvE zw@dl(9O5zOhCDeQbSZ!Ie&K0O3AuB8krRwMKM+9f&4QPNZX(e^a(m;@#?jE0HlaPi zW+ZISaC3N@s2&Xi)yD|)B3QYRyw`_+s75N(T97zMx>+(SQV0ZRd4+J6-wAV;j}bDG zv%Io9W*{f53OE^I*<~OQmV|J^>++U~gs?uqU)AONpuecLv!SalJPu)+X(BJ{f_@Sb zzO^&8k<xE5KP7$i;fRz0N(t@exF<=CJE`V<4f3LJpW4$C*_V3`wrBcn122ur<%VUP zIaNq$X58;#VsVx&x!8>7HQx#X)yd+Fi7lCizq9=a15F?HhL8a-u~!iV24Y#T^QU!{ zzy%a@KNyVRv@S+2W^M_82|+%>&P54kmL$+nE{9_yh&RjZ#d!=%aOw5)#$eD|pOKzl zro`tR4>7@@#^heAX)EMxiF)EM$opT5EPsMOt83~$^A}r{yuZuunYhI78Nb9#po4sS z9bXXlmrD%Xd|2k;BD{-CLiQf4p4jVY!aTfX$$?N4<?e#qS_tYheH+J5#sp=mK7R7r ztGKn`kN;%@_T%N+!p2{6Z{ZT_-a^JN9p-#lPvqq`UINcau?sDe5S*&13s<cQ{V=h> z@HW_`44C#^9PeKepR(9t^ix+E_T()7&373PfdQcx5<zy$(J;r}aA*9o#h&H)EAnsV zhC=XgnA)F!bh*%4PMgox2{FJ0W+`hvSAozyW=uAZJkndnBcE@U`kLxa(bQrQg(0>d zW6?^fPSE2)<fAw4=kNH<ShYBv(>R)C9OLM|7oMi*QJXFi0yOtBOB^24%Q{IIMghjK zzr7ECJkUUM1NN;M!~Gh^%nP*Ee0G%)<I7Hr4j}e0$*|!FWfgkly*H7k&|m6qP%q=1 z_oeUxSLDi?&yt{SW+p(3hn&+GJ8M1G+LtRQhd7PJkL8Ms*1k@cF@)g8AQj3!Yq?>c zCt3Vlio;UG%JAx0$gewJc0L!s@JzE^cQ}9hvac;EFoH{5<fmWL_;O8KLCvSba9?Nh zwYh!G`%|+Ms)kW$2NydlFE{L|2iA_|)2@vFqJ=tf5!QCxN`EmbmE&cz2;9sCKj%NK zNU*&L(?_cAXF>-zKgHecr=pD6z7x@U|5~UW$gZvHPc0`w^<R6LnFJT&OlD$KtHz+$ zU>an11p`i85cF8iVrFY$?WJRB(CCI_ao25US9JC2K$r@F#Bi9TUS4RZ?!KMRv9o(o zPU$Cx$&J{e^&=Q?X!rREbDV+EOBaQpQGbW?%0`C$h0ZJXAAtLYapTDIO5#5%+&Dq} z!I2;2bK6AzECtpB-Di+5JFiIU;IrLf&wpM~Ww_vZC6vZz<Y@vYfMdX6U>~pxcpd=9 z{X3jjBr|_dDm@aI2+R_f|Ly0MM}H{!s`HA6*9)9i9;YmFq9Me#U-5nn(D(?SG0uBl zk<ef5yrR+#r`3(sf7y8@l=f1xxCJN#N&y|%2-E@J2k4u>!+AwA^9P^d@AJSu;JCPi z`{r*suPE$5&KG&P=1Z_&gjTD2wu{9r-#M_eGc`i>i!uiI&P5v|&!lC*8wa(xpP(gC zDA#L{I2=Uuk-28IymRPqfSIt[c}i<OXTz6k>I#RErv3nvcIClH@!{vM)zJ_weD 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__init__.py new file mode 100644 index 0000000..fe619e2 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__init__.py @@ -0,0 +1,18 @@ +__all__ = [ + 'alias', 'bdist_egg', 'bdist_rpm', 'build_ext', 'build_py', 'develop', + 'easy_install', 'egg_info', 'install', 'install_lib', 'rotate', 'saveopts', + 'sdist', 'setopt', 'test', 'install_egg_info', 'install_scripts', + 'register', 'bdist_wininst', 'upload_docs', 'upload', 'build_clib', + 'dist_info', +] + +from distutils.command.bdist import bdist +import sys + +from setuptools.command import install_scripts + +if 'egg' not in bdist.format_commands: + bdist.format_command['egg'] = ('bdist_egg', "Python .egg file") + bdist.format_commands.append('egg') + +del bdist, sys diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..36c813808b35b0be585bc5dcd674cf14940351a8 GIT binary patch literal 794 zcmZuu%Wl&^6!q9~?7W&#C?OQ2ZnJ2dvZxd(LVN*2JT~rP<m65qm$Ap18M{fohA!Fh zJ+o!S53qm@*Ljd4F_!O~do<@hKXp1y3(wDQ_tAUXvc6Z&!_!CS4gP9_1}q?8g99~i zp$;DS(10eipbZ^3fiCpm5uCzfcmikeH13BM^x+vNsU6y+!UOJv4&KjsEp<Z|xpQXU z)<1hv!V5$moKLNa`QpR*Jt5YOedEC3gEf3<+=wTUGL0D|N>dic2PpFtVUcj4Y^9CA zgZbKcz)HqNZrUtTYno(AN1PiUwdgE_@eWjL4=7J&rY?n!Gz)zdl}zMX8CO*~!@6P` zeN)p+Y12Ds{)X!w7&VtkrSm0=QOKm}?5e&?vg%FPDsnC&pdjYT)OU_)?h2n{4Pj&3 zWL4x3oVzt7#@$AEJ0!A;MCf4Fp)GM`)~5Gvt(PLZ7$JADNH`ldj7KT<N@>`yA{9E} zYBU#V8f7rrMv`YJHI7=V@D%$haxKL1%`QoIA!Hh9x)-YO<X^(nqdaFBe6{2NqixNv zyC9cIi31GENCpeRfk_oiRzXZBrA#;3tHtejxm;~Fluxc_OF709XTirHPx8zC2rtLu z>vCOQ6~VE#hj3p}Kyi_YrgVhs_NS?Ug0t7vP}CHSef-FO@sTC=@0#BxzTLK)q)FQL EADo8rLI3~& literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/alias.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/alias.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..fa67f09a722e8d461863f5e8ffd111c412c48c9a GIT binary patch literal 2448 zcmZ`*O>-MH7?!jj-q=nPN@zX`orTg+1C9f9I&=n@LQ3I6fJwRRl-b!>va`v4IFcNa z9ft!hcYZ>1?2Q9Ig!5iG^$&2!f%3juCv{qoM_TD!N&D(~pZAe}n4PT?D1ZNc5*0Iq z{Dp(*V#DArRP`M+oN$_ulm?VypCv4{0?YKR#7>>SN!`FrYe5ZcHg_J8!261Dm)9N< zUK8%v3TC*+XTV<P^)1qBJcV6Ji<S%bVx@;VPSm#p9p~AXQsxruRvHajR@o3d)?qi# zdU3yO<Yr2^9Vt;ZDr4A-6Vau(+oUjfT2MEjs*j=J^d9+f>6nh_i0rx2)?`G+lo3j{ z$i6)ykLd|m`gG5dx2ktrFa{@CaqIhGu7w|EekA+DRAk!k<<d_gEu=q)q>8h?zkTGZ zokSe2sX-F!o2{08O5ZxA@0`+yr}TP@m9`WESvux53@zBJq}?Y(&VhHQx-*dR0qod0 zh-9aiCtOI?xpUa*hj$KST4W#gcGq`y4vQj8?%dwqk?T<US?57#5D(gMrgW4f?e+EB z2S*1V3_D8b;XvnkqNcmuJWZpFccLVY)Y{;vtf`%SJe!9oHK8HQqaM8kKaa{+VBAIH zbU|S6LRDWwBS=6w2^gn=#aUo;D{#2or^4N>Es_9YzUy(PPoeKsJeXzxZvYb-ya^!B zmX2|%_~@SK#TkGNXy#IPhuYUWk@n;4Am0<p&*2?lpXO5dljEpjoxi*&pDg*$6%T+^ zt`up0AWABWrK;=S9A*Gq3%&>rAV%_4IOGLhA;->nwE_bT%o&jrlM*8mG7hW>Eso5g zn=M;9FsHm6XR(f9%R+<|eN|}#0jdu?p{1=v(lbn`nt50yUxVfvROLcLXq~#WSgK<8 z@_zsC<-4%>xtAld%jBxI;AxL3N4~FWhqE#L1wsj4Tbobukj4FPhD!TtAi8ny$QOrE zS0_gX&GRg{c@C7HMX6}{KkbOjADVn<w<}OvZUw<Sg!KXd2HVm~L?*Am_aqWaE@FcT zF$Dvnd>yJXQUx$9P)6Ca;z|X@i~C*x0`;o~bpzM`2@M<@0><eH1t|b1)LjkC9Ygrw zY2kB(La}hnU~Fr9#71<?#*C8vRfI=7xC(%C_L%$)`w!_cgQqLEIXSlW|G*U>Fh9Sz z-mJE`J7QNrcu+OBNcJ}Fz-!Com~roMO?!IASR77%Wy@sDz)wrp!PejucD7;~qu<T3 zRqfE4*(_@Y2%(C(jVi(Y&yl=nXkRSFB_j-w`V)RH10;pNnO8&K<Pk76&p_dZ88<q2 zLrNsXDfJ;un;eu{#@is)c~;K#g`N;P<Z)M<NR|#rS*FV-h-4b+(0C`W!WLD??cF@i zBqotj7>O||JydWcQCZ{iD3rqta%TzWypGLfoKu@5{0jsrEtvftOi-)P5ZYues2Bb& zQ=6fZx$yJoJdB#uWp%p3ikXT$uyV82EWI$qZ--%755qL)!vy=yFx($T$>dEf40+xK zbAt=jm9e>nf|ZF+csnV$8&r6f9jfAebEt$oPx`rS&}0#1X9knw5*aSh`KgncBrr07 zXUD2AO*}Y+O>K)kW6b`?wwugzJkQ|M#SA(t2<o{`1u(#SZ<#z~$L!b|F%9?Om;!~b zaj<0X8w=1MEbH6`%Zjl$#_|Ps!Q$~6QWwY$bYCRgTO=cE5fuX{==PI*J4%ZAcDw4e ztBct$Z9IQ*solosxz$PXZj_Xym~FSuBL686?G5m>MI{Pe%Pwt%-VmU4RX&tmA#cE& zDU=LAZ-VVURD~!({Nd-GRk+V2zTa#$%6a6j`IoUK@DGMEniE`oep#-GL%7qkH5DJO z;pLzVO@rmB8IyRgfeDn{kk<s-_*@Yh-7p`Wa`Zf$rT0liu+K25jHWeNlPy?Yeg4+J D5A|aq literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_egg.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_egg.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..454b70b3310236e53ce55f3e754a1614a5773cd3 GIT binary patch literal 14234 zcma)jTW};tc3o9<b$9gxj{z|6Az8%CaM0wSF&s<uE;&n)oCi4+4bIMBxy#<=HXEJQ zKsWk@tisHoU5J$gYL}MH)rKsu9S+C3q40<4580v6mqMWrMc8`SpN_Diex;Da4ShLe z$sUJ2KIc|-H-KF`+=$A`%F4{j$IW}sJ(>90)KuQU?{EIyLG5qv7{;IS;qcGF!yCB# z$EIN@qhcsiS#7gpRV<V7R6EtND|RPcNz1d{&UCVsti;o8r<1GXB%W#KD|zJ4v<sDj z+>4c>+@~s2a-XhD<DPBLbY?5FQpRbY=*(5-I`ftJ&O&8D(sD>USve{3eEU@Abmg?f z3+*$Vvz4=^F}Q$QitTfq^Of_R3zZ9aJEf*SF)Gh|-RNGm4e!~ly#6cG;2(0%w4dv^ z6*tK_8|VDc=vv<})Co0*a?h)IwSfDgI;l?Ke(`NXomOW)G1M9F?0%|p$-6v!L7g35 zIWP{)%91*#&LdYzT~N>9{-SzTJ%{^C%2m&+#eZQ{uBwab5>l4cW%UB?Wpza@;l83u z>P7XEy1HRkuBn&Rin{iRS$SDy9vG$TgI9bn*y#toUfVC%d!0_LtIF%D=?7JBV<Vq` zYp2;(ZW(cxiMqMI6Eu5W{|nA#$&BW2Ar(n&{{ic{t#wbAtf-*9PVb>t4YcP)na)<f z7HlGSs@>bb&AHiA-r8>8TV<Nxd|XOJa~obzUFX-T{dO&A^mHdGvhvX<qgk)(?`W^8 zn%b)eJ-v&<`P<z<@80V*y8)iE?={zTO<rVg#(hCs9M;SR#NX)e2AjQZ^`WPIbfnIH z9R68&xQWZBfCiY!eG}tktwz~CKHhGwmrOm4SDzdD1a1;MdA!os&4;zXTX|U1D~(=T zq4t$8KVI3We)*y947%4Ft!tZ`j|YQl`^&GaZ|ZCKZFE=GR{G8Ua<l6PwRU^?+O=06 z?mm2ZXJs-ahoi~ttc+);+~19gRq0*av~z4XJ7Ac49w9nEEwAG)qw#tM$^YMdzJtCl zpunW3acquh{J?X#k`LCgjK@F5Q@CUxuOp(&(Adi8Gl9`EhgJxIR@PZ#&j^iSN~I1= zT@IlHl>N&|Duz708kuFynjk<uwbS;RPo6$~TCyXn=SQ|osN?tB&A@vcM2^>0{-dTy znbT;ty>6}J9cnk592F@|{c2p>MWpzmqfEz~HS=cC)EAI;q$4&GcyY-5R}cio5M4Pi zZy6uG@U7IIxo7RALThLpVAY4I<Zgymm};axK-xBR6Xj>Heyiv9{PLq(d&_Nh-I}Yt zzDBp|&GokDKC10r&Aa$DyUOdMFJ3ordkuLEJl$z_u@ahfmp$`${lM#>d`)2~xIGPF zld`L&ls=6%MmE0^*?vz47_Jm@MfQ5l_aYlnKT1n2#|Njt?4GK!>`Uw}7l2_eV00W) zbF}IrT1>@{qmsjQ6W4fTlzD*ZJuvpHAQfVY_pM)D!1$zwHb%rag>f^DuNyyWeAT#b zKo1%inbd0SJ|<Z@zyVNR!>v}=d%XaYRqI!)OQl!GFPUMZ-CM7<kLJ0G$9AuVfv8p) zX9ug*BgLAXKKkck@UFW3t&OVo{N9ePdw9gFBUwk~-LD+YSss;<`YB*b)hciN=w)3x zR>`PAsAjd-^<G2Q{vXXgQWz~Nvv^hQqW)%m@|{uJCLcRCSmSyk^HC`sIb0o&FpyD3 zd6cRs)0R~b**(ZvlzybKfFLE#sB=-KzsvEfOjn`V*Q<~<Dr7G*8^=W^FNG!B&r%FB z2n=&Nhn2L97#GcvAK$-$%l|$C�Kns94IZq?Dyn%2sL5-iMSlQYxde%2BzEOeL-I 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_rpm.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_rpm.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..458bd232e08780e7e9ae0a4b9b7cfea968d6cc7a GIT binary patch literal 1840 zcma)6Pmdcl6t_K-NjAGnDSuRGk?>_{bC@LELZz)%t0Is%v7i<%BURQUc9IFs%+#LA zCez8Om0FH`gXGv7pJ%Rc=?9>oA|ak<lKsPighzh%*w63%{Cn^D``z6pg7*67mH%rE zp<m3;`DVk<edziY2#z?GXo3mCXhJ*-qpuJr+<Jz%C9E-dYI%g?hp1)00&R5MH}ZTV z@N*x!rXU3JFh}NuXH`}_o7=qh40$!~fR%c&)#HIqn2IO<03+0-(7u@pr2;N!G7^-F zfuG8Rp6bz_82Qs6QZ$Juk4mLMBxQ6Ggu{Ey(!%XFeUOG!42LWT2cQ#C5$aS`CPRNB zs2_3)esmCp)Q62&MX^wFPW!&>r_xUZZ<n_A+w^mJ;?FfzVDe@V>cp4wCQUW?qpoWP zDcrR!SIiQjLeQAI6F>Baf`j+c5Znyz>i48Dz%&g)`rzBI&03;@UYY<BUAepi@I@^B zK3w0|BYF}fBbtUB;PxZH3MUOU8~9;5>A@Bq04F_>fPZ6n<Fg-4Vm}Fbfeey)Wxo$h zpEfhMpnm~fUk8z+C1k-0W0c@ASz0+VbB-Wh<hW>TNNw50HZa1#K3tR+cBF!#GVw1g zSa0FN)<O<mBGrJkH?vNxf+^72nfj^&0W-Jh9LzdHb}&_wEZiTAyQ9%8%a}a4+Z(Aa zv|-r!t`i5byJp?(cJEH-)7xoBizJPcD3bd8bd9BRnk?;jt{iZG1-dqwj!2VayJ!1= z^a2}3+2|QYv;>i(F<RmkTHqWnA(J^-kp)StvAwJrW)>E=a(oT_2o;hO81ZxT91lpD z=Z)O@5<LZ-+*&#>fK%>VLkpYN&51<~R_nQ)*H#3h+yZ_Z$8WG(V3xhT2YDZaXEDA2 z(vWO`zH2~sK@0)rqgy4!vV>OzLI`DBj!<xBe1QM}`H4KX!I6`F{4h#YUv%%$y(gw1 z7Vh4YbwVxLiLbKOzbK?3gc`D)vkR(M%V+@CkeOw5(Co8IOaG@*GH0(mmwi%=)D6$U zyX+m3tgfm`X_11oyM--*wU@+m%(#DNJ$_o|pxOeeisqq&iZfMlbi?rX5eR3SytXmH z<S*L>`KMh6`G>tl5cxfG&$5M0{2v6<vFNiwAVvF7M(|wdBbaP#zB2WcUEjp-5@y<J z6g%f@zStg$WW%T0fzt|}X;f9xm4A3FY5_b0v%&$Qg-TkEs)KG(Ux&kM!b7^AL-_$t zuUTm_K<Zt+gr?%fR7XjUdJksrL)RaGK)8u_;A_CQvrT?;cHc5HoPGG8j2yR|qQRI+ zD8`B=W0Q!d(#&@ldz|`my;En5M}5Z1;w-&ZNX%1l7ORp2Q;phWdjs3ehEuM!Z10BQ o5FSmb+v}=tpQ0-2>!nh;qVvphIV)44aah4SGBMMps@}2w1`VD9+yDRo literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_wininst.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_wininst.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b72117e9d96e05d39952ac05219dc7af244eb9f0 GIT binary patch literal 1010 zcmZuvJ8u&~5Z=f6AwN)vC=pnQf-B;4A`xMPP$VSi+$0F(W_9*n>~rqL?wymIE*1G9 zaY@JT*_MhwKtTgD=S#3rMw-#g?mWJEeC&2x1nAfIm3zeq`GLkJSzsIi>lYv-ku)G7 zWrUKDjX5PBh-8vq6UjZkU|;!|NqS6d>nC`V(G=w-aWIa6^%D>t8B<9hqEY6cV=gUO zyC!2x)*(mJbSKi+sW|r|Khmk95HrOLw}jY`-vR3$h=MH04J~NFR_uxwRMNA$dMsJN z1u*2~`J&aU=r~J~zze-7?I{mRq`n*YxhJM^7`l<{rE%{(R%bm|#aSfp!scn3ymp*P zHq-s&GM&d!KUOox*E;hK2Cw#qcb+yg4Fv86foWHY2>i*&=B9(4DSwisejJ%c_W@AY znr#_Nd%>w`RItqM+E?goQax$Ir=k2tR2u?*7fz!5rJH)r(pAoB97s=TXL#Yv#Biy? zJUTdC4CeETJQu<6a57f|pjqUcIEkO^RWSDkgTv+JazAslmu5*C$AR8dtIE#Sf?yn~ z4iIX<`T+=1tHY_VKNf4!I?bPLd*9dd6nA_}s5gPj^*#qh(t-$*@1%6WZg@dfl#);6 zC7d9>e}?nK6^~Bd+t#=(d@WQK!RgG56)S(H;Jk_9@Mcrh0KJ^oT6EAv$UDFqixNQ0 z=nl&t{)ak?Mi7tK?3!r`5xJo!glP#8#xe^~?+EcFbA$CyIg&E>Mm^k=DvKg0T(m~f vq^))d6B>Am7Xs%I=zcZr{uUC2C`)J6MXgNvPhfJ>e6z;%7U60vwafnk8tD5o literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/build_clib.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/build_clib.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..668eea6edc87719a6437c64b5ad7bee2954ac36e GIT binary patch literal 2493 zcma)8OOM+&5T<BJ)_T2<Jen3oTJTah4!ZUxhX7d=MT({<3KVI9Bo`rpAd8f&jb0%s z@7j<r-CP6Y7Zkg__152`LoYq`5A+ZeX@`_w8}v{bqK4ynd>qaU^>k;agJAsi+lBw? z3POLV#pW<!@c<t2Jxml)BSEQwk%3a|whYC=iJ4lirRi2;r){^bX)|%sEqBX6-y&*J z`xT-#YaQdWmW!$J81>tKf<^SGZ`9Ww#zK}dPQ+s-%i<f(a}MlQl1K2mp0N|gy~2<A zNi3Kb@w_YorMo#WEFQokK7xrM*PuxGaa$DA)+^+i)C8Ya-5Hf}LcJh~NB#tqIt0cK z6UKQ=8IfZ~C=2~Ekz_4MMr`a);=JTU=7i>2EX<Q6KZ&#GsH1J%8IbSNB4H`ZB=HF^ zX{<<}Pl*IdNIxwOM!sMaJQOUWEDNSYOoe2rHUKz8PI^I}7IDIE^?TrniL58VRz?^= zY%C45^xXmZic*s1oRJr7Dikt>zSqExvoHq(aUkP70}Mw?7vwg{N5>vO5afV}f(3Cn zT_cK_AYsl4^MkPxWPv0LM6_|N;&o}raV&@!=Vd}6P_Xs2SCaZg0U-h=U|d1Cq<#|1 zu|_T+z5yd4Y(Dc-IEx(A637gahySg*iX)&Nkf#EiL!i<^LR=+Re$`f@Bp><7|FEzU zxlMvF@go5^*CASAAwH$C4r@XhF+f`QLLI@%#HB5&b6EtDH$e<kx-Q2)5L@tk4Ugak zLY46ly)mAL&+r`2TUF~E%I?CLo0Un?3r7s3QJE6UR*28AIFcsC6~2MajGqjNEAtE_ zrFCx8R)sIHfwaCU+h^zk&n?ikfX0G@p0(7A(A=&p@MBA?<=P<EUitWWQ?@c6qUS%( zoyv)f`Bt@c?o{my1N?w~<t+3&px;^P|9(kdX>_!PeGdAHdihI*jyuQOl?m@IZNJ9z zZMjp~)%F>VP=rGKqV>k$PxM|Kh(%XZpgZ5u6xf^ZY8$(ajjCJiREo1lw_n@yJ^kN) zwOwJLu4sPuwF#afrqCF69@Xt80mUqgGtz_pz<myh)gyVKPMh3nSX0vbO!WGnliotU zN753K6jHz7Oz7&*pfDG_b=tg_-(vQGE>)GL$|9t?@;I%XWqr<`{ZAlEg*B2(MVN;~ zP77!a4T2+GRJ|HOZ|&rzEK2FonAdjd2Rs*bH_n2jq)ahIZ8xRRx424Ct}Y9{4U@ae zP9^ufB8Se#BT-wFjmoHx8@U}2>0hl|5tDT%7I6krS-@&j6?APumrod1MZjAy)u!rK zwW&HsZG&NGkF^cGL%p44>A3q%L-Lj_LM*#Ew9ta9o2qUvg%tqzO2C;fnFr2g9C#|i z7V!J~wJBH<)?2Gnb{!x+)py**4WSTm8>D$#nd)vf8+W^DD!Pr<b`w|E5j@Zwx6{N% zHCcC`okEk9jCu`vv5q0{D$DH!|5wCs!usuWSnzlPu!j?$58;}jjEmv@(_!S@pYU{+ z-3^Zq$K%u4%uDXy8;$uPj3^sE85VJIpd+0m2Zx9ECez8Cawyc5D)T%Mn<RuO^)otL zUvh(DTJJT>Ra8C%JYoV9GIouQal^m{#`qon$21+>wG?m7G0k0&TCLlTVZ;BIcxK1w zVjE=4ceZsMR_dqMN>B0M+Fi8<$}s<)eY^qhJ!p^ME_XbAVxCubJTJ{@nJ}Qcp7*l! z6LprbYI`2d1JC21!Y*`xH>OV%Pi2HUVxbbqG0eRtM>_6Jy8J8|EW$Nd<I$O>La3!{ zGv{$s@2@rBgCgfbr+B@!V(V;oudUBy06F5RPamDW8_-lLaD}gSzG$}gCEN^1I51r` Iy6V^Z7p;K9CIA2c literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/build_ext.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/build_ext.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d370063823c1c100f785433cc8490be5a9db7d82 GIT binary patch literal 9951 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/build_py.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/build_py.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..dc16fae9374d781e95e9ddaec323862bc1058b56 GIT binary patch literal 8697 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 Gm;VR;sg}b4 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/develop.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/develop.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..555709536bd4b345c341d80c8adf65ce94a4375c GIT binary patch literal 6557 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/dist_info.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/dist_info.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3b2399369ce2eef5c8ed26cf63a3a3fa0023769c GIT binary patch literal 1417 zcmZux%aY?X6qPI|cAR7wsG6dARe3jf(Qz}2DVhRmsHTby)tiBhH!8QKBu+WDk>t>A z(yJN%BU$#2PvASWWyKG$U<3C$lcbwLDP3PZtaFa;aef?+0|M=@-?r)RjF3NYaKE`Q zcmZ914ndHF2r8U{CKR5maF#4#6zAN+UG|b5CEpRz6aCjj^d)=6lD=?WlE`bn4K9>S zjSSOJ<l6AOoK}!2nVCx61mEaT$Z1|m5$0uR<}&<wE@ctwT4wn)&r*|DW$-6(AeRxf z-bJ-srlo+C71b=m`TNa*!3*em0zndBOA<%Wgb8Ox6IU?dz9va;#}qhv!iTXZ2EaA2 zg9F3%lWfm=f|I8YX-BLb$l2`lD%J8UOJ)20K~b1hrAhNLFK6Kd_dIwrmpc3u1gA}5 zz6ecKht;%Gt*b_5GBircD5F4r-!Mm27tl49OprC<5MPozidW(T2uC7!)Vf+0(>tPY z-{049t@0IIeY{FlJgo{Lm5$G^;~76+sbyO}n=a1g^Xs<d#rgBAxjKV3E8`#HI<JAY zHfd3uo}E2k-K;)qVl7Qmo2n}G{WROvBR<^Rq`tB5fqavvMcztY)mTCO1nHv=Lfemz zo8R8}mUz5?PCPmiWvf0UokZmyGE}UF5bR@c(*x)enB7Bvc!d7%wg<q7<w5U&OGwsa z18(2aTe>C-x~3fZ#@P}|;K_E+g)4~Z3Fj3Zl3$$<h+yxNTgUV_o^Ut587zX$aP4g2 zlr4q#@WdXR$kuE#TGNFKYYu!<ATjD+?&^x>X$J=%wZYMi?YOfj`t0d1w@>Zxs?*ke zKGE1dnMuR<8U=q-CxxQa7=mT0Db=GcD`cq{W-j8{{<Kod)L5s|)~!=Bw_bXsF-g#D z&k!ea)c}ve1CsIKRylkJ>K$C@3Ua85dKczCg03G!AT*$U_dB5{PC(n^0TW<#8Tr=d zyiAvpa~p8JtVB~_KH~hRCN18q429I0$~%MEQKO~WyG@M%q?6eJ-y?HmgeAsp8iVh+ z%=yRd`OIeuS0c}PoQo>sT%mXEBh=WKywH=ZQc|IpcYhe&WOskvoBs!9{V#VKzD74| Mv@KvcBRXRL0<P9^uK)l5 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/easy_install.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/easy_install.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7b1a79053fce2564d3afff0d00b936e95062b088 GIT binary patch literal 65318 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 PalEJ2*S8&#v-y7kkL@5t literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/egg_info.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/egg_info.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..aadfb9f7e24eb43ece302b34f0af40121984e78e GIT binary patch literal 21820 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 J>+W*L{}1iSVhjKP literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/install.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/install.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..31f56712ae2d1a233328bce76ac1596a724cba73 GIT binary patch literal 4047 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/install_egg_info.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/install_egg_info.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c6656bf7816468dbf500698f78a819c33dfe2c27 GIT binary patch literal 2459 zcmZ`*Pmj|^6rZsj$N9G`6xc!$4XP?NR3u9)A%Q4DU8IW39!kr>YGrvdldQ9j9cJuw z*ILvANbRMcpgkl<Zv8yI_S7%X1BcSz8z-=^)Y80p^Ze$`oA-Y2+240MO@`;6KbPU} z9%Fye;^b4q;y#A{0YostV>abJpIW}fX>G-}Z)3J&XIk@XM&^Kbeb?}{xIXoKZ>8Jt z8{aVDiu!XV>e8JwW$l^cw}kbG^}N4v0_$0&9jD{c6Ojt?EQ)t~ysYn}(`lFpu+1c# zN<9mQQe(A|CtwePP!0E^xg3&(laGbPeGL6Ih-5w&%(n!G$J}>>HRgUz*ur_vd{@+j zi@7f9!o%!|hG=4Lh?Zz$Zi)_k+$cArL}y_f2XZ_PqGXg7{fCvL8z$X8q&G;~h5K@t zrRu0VN>w-8mtAr+9Lt_vv{yE6K<TTJi(>1Ic9wQmZ@XDK<Zyfa5Ks5n!O)a6!H!t~ z`iQ;Y6s6YMHCTJWOGnFi^n$4lRA2r)n5k$UW^ynO)nJsyLMlDDeK;5gx94hFBwvgs z+xz>6MG?feZ|&`?Z9L;-@ZDe*&2S@g=NsGGx8_IloB2S?ET3g*8taqnu*%Y4?Z-Mq z{n=4@E=r;-3gf7dK|0H#G|?Z>Md(J17oVKkb6WqcXxP~1Vwh+=26N07K&P;lz$JJt z>?ME7GiyQUWXF8sVAPh*!dWumY_X>n)-EDg&%8-v(L838)-iTN(jHS}I~3VoZTC%F z<7lsEDGI$IrMJFd(RiJBK;#0V6Xc1IqbQMLecSTF7-EP_3`DRBR@s>yi~}Wgnk!(s zY(I!}rlLJSKTWC=2=RW4&YB}>5UaCrp>(S)rIqT^nT6SY=}ginsa$ijP~p6?p61ys z&vegLZEW&g83n_sD80Q<OEPTWQIQR@y1Djn?e|4U^;HnYU2eT{tR{E31tdDmdF5Kx zzmDzkbG*2ADueG@dMkf~<~oMS-ydMA{4F_W8J{3)$cMA!>W*2}s+GQzxsy8a7@n|x zL#~t0j7DRnzXv-_NLsWW0R=Q~v87F@n0PwN+KW!5Yj8q&-w=+V6V8x)WL;coFE*Eq z`W8^&?wXjR$m&8J1u9R9#<y~s&ZA`9ttxDDC!HP9@>7k<1?`<JTTomlT78I1s!Jec zEz&4a^%3!Iq~j<#P=sgblT8_9N=o&yc`Xlt2VK_Xp&aI!EZsaY`seBGrc89MWbnFu zl->|tnC)9o@KJSDw|dhxRSPfP&AJUouR*RagD~FYSNM6p!7n4_ZKT^lx;I`qc5!}f zZ;kvuHlE5W<<{ht3KTI#1XTlUkE<(~-s?e&s$&J#K9tst;mWBKPbj{1GIbIMgCeQB zAipr=A06Sjhd#i5WfP8ps(%J7n5^2nL(_hsOAl?N&z<Q@55Nfifc@A-qd;pxYvB5- zu#T-QT<O47PG#hYLxvYHYoKc{9D*EH1UL@pIJ-TosP*+c85GXW<41#+e4x6p-m8^O zBu8cXrzqPuktyA9Hj{}^<W^Y|axWkE?9$e1SlU8o=;;U1>_q%b$<`s9qLRPFCQVh& z9FJe*9#Xf#i|eNXxQ0moZk!IoSl{cf44_F+#uP!vpcCDW>>0}yWDI!dRMi8yiJ>Xx z%xbraOaFV)Zm(5(K|ml3g0dL|(^TX!@$DdZl85o?O+5%iI)u0-q#mlsd?(6wuBBSH zBXtI+De6b+I+4$bkS`}7O<z1^oTLsz{aT*`@wj6-Hd>hD*<Q=*c($VVy>{6UC^Gul z&?fSx7)`w*L$AMdiY}@MApX`HX@B+WVg6OB@R`zVJgh2DDs#yDyeqxCRUGb7!I;c# Na?ffbZ*A_`{{h3QbxHsL literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/install_lib.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/install_lib.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3c4853b21df9f30dea457d017e4e6f1266e6649b GIT binary patch literal 4180 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 F`Y+$7GY|j( literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/install_scripts.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/install_scripts.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..00e6e7d8cbcbaf98dc77a4cb282086279c72eba3 GIT binary patch literal 2329 zcmZuyOOG2x5bmD0U&&_kBm~8P0x}}&O^_lY5Q-p5#DNu3KtUs+*4W*)XELvJw|8S} zHU~BmH-3YCgcE0eN+03GAIO0NP&KwUn}u0bZFhCKy1M%Ns=w`YngqU=zb>O68-)CU zlarqVlY1cQJ5Zc(nv#r$l;YS*t<1IvC7BbtYl|0p^@<<*@ZU~@tPwV{X4uSHVT+Q7 zgge}QLAWd2#5uA<hg*+G&-)XilO8p8T8#I4wrSswm6q{fs^cOz?XM#}`AX=BM>;ZF zB3Dx>7>}hG>O#(j_~VnG4U>By>H|=Mgp`xe;xx3m#qAdaHm#EgUEbtA4_;76x&djl z%-J|sI!aTfhB7X-ntyV?=;npYqO`j*b=MvrcFT0Cx=}vsit(7m`Kag~$fzuZTzje^ zh3z*Vjxnz<K-48rnj~~#Rb+|9q!nQ{Cy;}+_n_w(r;zbjdf;ZZ<2=@Jl*V(xiW2Lg zjGGrslu$26iFEWckuC82>v_MF@qVO5e?OA_QIT>XRsZg@{+Qj}m)ShOJxX>blV|fe zOYhzpOyn+n<GlY(zl_V9>vP@Q-MzCv+rKsKE1{>QE{as091e>ti*nvSRj8eECId*K z4WbY<gtqDYozq_bJ<DrF!eh7~b&+1efWy@x;%byxhfu1DEZ`ckXcbAE#Fe+Tm-vfd zRmj{MgPk>Cttmgpf`Wew{SPhOuB@b^&!7f5dt`y$0y%f&9NM*?4StT^t`H#P$Ubyy zs|!{StRDBc4_3dT$@#;e^5ri)03VuMfSIc=CYPRA^0&$zQ?Le$%S!_GAi090#TymI zX@LD|Wmk>Gn@h5^?vwA&95x}_YgO|nVA9jyYY;T{B;v&c8)%u%U>c`<1548s&%|)5 zqd_WQi33^K0n`@28@5=in4IP?8$Xyg%bA`O`40H^-ZIx;-RaKyB6mcjW&qzB_QqdZ zP5U)-3*xckCEV_qoBo<9(uagsh_%7n1jSU3;#4RJZH1VNW1-n7&TAa=O)QCw2<uZ0 zA|)gOM|RM^w&hVK!WPzGACQclz=trA)-r5AstNj7##+em{Np(1#eq6$G`5;4c@~2? z0|ABEULSy|QViKJjg&IYkt{M+Ml#C608@<QScQ#9v5AO)KBj$uJFM&8Yf0>u#u9Pp ziI@#DZXB#e=nWLk!unp;@w~yo$_Dqbz8vG#;iR$apW<dUbyo_xBQJy60#P4>B6Qno z(tw_^JnC5vj4kSrHi+}L<1~R{C?0j-&!bJ-vjVzBFVOk<)5OCop?X*|69dDCM?tbZ z1W`YL0<u|1wnI0w4n0b=y>Pf)L2pXjr492n(Gr0C(gGTgq_JpLeoaR22*FO0mU<3E z^N)a_x>NbwsqD+-$O7Ou7C^n)x3M_81h7{wtOHT5z&i9m54xW}zg1r;^wsVwh<6c4 zU0rnbL~NRC_qhGnROwm99Zs@>o6c}5rN}j#W|4X_zxw40+Q5eH4Yg_F5bK6A^dSBR zc(&KulIP(3@;y}Vqq0C52b+4>+LRJDG*+REQ^IRxoTP|zc?JDE?D{!3K9@6Op2Vs` z3kRcd>kEh6(n5(|bA_MQiZcxHZGvHuYseP@L;520<1suqg1^efcp8u*G&sPC3>}@u z%yroBBar%CA=Z|)1t@4EW)M4ok$}#xZH}?#>&{7F@Aas>0Reix30R#LW2VU%Bs5J0 zjN6Pookl4p3^SiGUJMzlJARE=i7A{&3mdtt@r-X6b^wL1LqHuXaDsR1KGAEN29gKf z_*B&u58pnXAGfDdY0GVlj6qio2VZ!34V3AWPsU6NRZQg&x(;@hRX@So_`lRl@agJ& SpJA_6NQXAvhFS&I1^Zu2u!DI3 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/py36compat.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/py36compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1bbf45bd896d9f79198675c0024bc108ec396fcb GIT binary patch literal 4666 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/register.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/register.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b25c80b5ccf95b46fd6ca6b6be3c3b5e99578239 GIT binary patch literal 811 zcmZ8fL2uJA6t*3A&AJXD4jd*9IZ}z$1;M0F2!S|ETzVLwp>VK5?53%lIM_+IM!T^e zvL3nddvfK(AK-w5#B<tC6;JZ>dw%x&zVFE&4-b0??DvmV^pGI*(<Qq`A$bkUJ_jd| zzzStJ#Ms3|k<23qql|_fjLwko1ie9m%FdjA^Fk`fdo<|$f|qE38&BzE61!yA0CWxT z2m*;hEKo?KH>dMX*b!Ke8x-yd4;s<NH!?|WDNT%bTDaJWcniypz|}|B=++Zt1vE?O zbGvtqTzr9EAgF+d63@wsVDt%OKxc1Kf4+EgK6y7eI}Oe^7-^masSSiIjEtjFiYGy3 zWl&zGId~mZh0>7-(i{lE{&-fFg*|1gSQhC}n}ijty~_rTFO!6)`BV?OjUVN?uJTwK zr@WyKw>dCX&SRZrQ7#&)O_~_bRXsR|$x$oS^gA*KaQ5et6((H(A-0GNn`$Mbv21+B z5<Xs-tj?cJ=cC!|s;;>jpM05_5m=J553ERwV@Eeq>UcCdSu7V%D`sU`6{Xh7?uHvK zY&-B_u{8UD?!&V8z#&XX58o#gcKWyO-(3X86DO1NJjx{JO^@?Ti%Pk;&-vFXQtOIw z&DJ`*oC_Uu-eR;ecU*satpkB|AJWG@X&(;untcI3qAF8m+ku8hclmH5Vz}kjbT=pM Z+cmr!>3>*_|8h<EmHSyOU>`s5{sB~n%gz7* literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/rotate.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/rotate.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f79adcc4cb7e54734ad643a17646dbab97b69254 GIT binary patch literal 2576 zcmZ`*OK%%D5GJ_~tygm5xNg!EZn{O2+Dc=|$st7wHwX|HJ=JZIK7|HbS)}B(_aT#% zV=v@OodUV`A4tda)N_ABe*v#O^$+wAph#yZySDP!1&6c4A?Lx5!~JG<HYD);^ZU51 z14917kF$>pANQcCpMY?}X-YEMq7-?Svdn2YmUmJ&^ID$e-PCXSFz%+6Rt0)54YHZm zj2-jSFsrtzlzc{bg$Iub4@C9IY1O#<fYfLH1}mgaO|4VpdqV2C-_~33?W9Eyx`p*b z>48pC^+jJNMgFOjh1|e#mFz=TxnE>iJLer-=IrCZ$31B3V<3XGC?_q(Y0KfP<#LC+ z-0L|luSdXfpI06ea6I5M&<8x^Rp@7U4IG>`zASWGi}LMtkqRxMBIQCx9Q=~WCb(AQ zs=UQtJ9Z=55u%^uy=WuK#Ur6~)J;;M>Q3orZQa@W#L%o<gs`=cxr%fVS#h*1#qJ=H zg4aQH2JNlzM1nRiuK^=Ex{wFaqb(stq_@PhM^Re}nC78vn6gtY=Ywn${4Tna<<X(3 z7|<|kcPJ$6<UyW6yAMrW1j5OX#1je`1)gyNS)v<t$9UFn6X3EjcxYT)?<qB|5^47- zk#n%Xvq7^jlRZdibFVF%U7JnSytCiz#dr2(R_3?5+pAk!`(+uYcW!TP$yIoIdGqUL zKk2U|xzg=4U0Gedy?3y8bI?>m5Bj<&QgxQ?Oi<CBY+a*&VCIuN(MdZ^N)Z<pO6n~P z$_GNI4{v$-So>womvRCJXOfdAzzoSYWMn6h^O|ycM1Q6rfxLj^Do7Yg$~o<z^a#dc z_8rL=U83EcP<}}XzM$uz-VY>a-xKZOn%dv495K0%Sbc1*i~{bD={m8ifMhg-M{3OQ zpy6TKD8KrA002{c(Mh@oQIP{&Wt0^Fk!72c6(#y@3EAiMW0?I9yk*hoHKL_Pne>-% z)>1?CdQ0{4>eP~_FtR8<K}~siWd(OT%FzC%h}wCS<XZHEoJt;o$%FO)n%#gNgz<3h zkZLldBRYoAer3B*87x@pOyUIN;aTg~nPH7pL;H4YLN4HNxRwIsAin<H>$onKFrP9~ zet5j2-6Wsd`NmpWblR!93(U#PXY_{gHW9mEwFWC#QV(Snd0bM?0x=GRWx{XU=|I?G zWWq#QROTHaF*H*{Z}VQP5BfrZ@BK8<=1l-<Jjl5KUj#papgf1`;<-2z&fJUcz60ax z3J^j=$|!s8x*-jKo1^FK>(lUg;FOnM6YkUwAmFjtBmE~Z03)dKW32FuJ1NcRA@B&+ zb@K4HLk65Pa>r2JFOea;L_k8dx9yKAFcJ*e7(jjKaF6={QU}3#=nS3F%otz|eTcoT zj%vK3XNLfCnBm|E%s$7-FYGcweXzCmBRg~tJ*yiGJ%lyroL5h*wK<Sb`G>wRnn#Y3 zU67C7IN^5}kB@)}0Jd?GcMFNt3+@QFmlm6bUY|<C6c86d(E@P+fw)aa5aO5)X_uV^ zqhna1jEfhP33@_jI>`ipWdUXz+I?XgC6>$E&?az%GFo0a-XA&0UxmQ(;x%sXhGlhp zII&1yQ)SiOJd=<5f~ms%__)H!_rQXMsHvST=hneEZ)ZZjj~Z8j7<ao!atmuH$%WLW zA_d&JN=Updjf+Wxi&x|mq*u5+h{2Ze5{2d5S6g@!!-be>DTMI{d79)qbzh!G6X=Pl z9G4U0+45khmLK5Y3lMi;*(S(U1O!oCV<DZV3xMW;25cVs8oWMIR)(i}+o*>oh;3kT zY{EFs3O+~$@U=MJ9kf#n8NMoU%!>{%RW4KqiU;1)rZ#|BPtKk>zX{idXy+#aIS;<b zcaeOA<kV-&VX2W7AXpp}ZhAmn<}x^tl>O`aE(^S1-fF;K!#Ugy`{U9;I;ms!7PrDl z#^+9z1pe5lNu9Afb`uP=E}UL(4Y7|u2$K>Mp2{U2W^46T4x3<YlA*hJ7!;NpOl-}j IxyEYFe|#;f;Q#;t literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/saveopts.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/saveopts.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..126f9dc795d3a4f8fb11bbfc2d1731ac1e185d47 GIT binary patch literal 945 zcmYjP&2AGh5cba|S<+OEpd3I5twb-8+HBxZRH;G;kht|yxU4|dcI_lC`xo0A+GulX zpMWQ5j@)=2Upest95^vfw~&!$G#-z?nQz7)x3{|p<oAzN{EZ;=(;YU&gTrf3y$6OP zj#HH32xlZB7`;cFaC(h6737LWlzXRW(E0_LXh7_i;L@<9$j5SGw~ErpB4=l@7KuyP z6exUK<Ow(eMVO<Aa14MX@;Ja=qo~DO0N%E~j^_fv^y1kmctKKRS)B8OROTYMEusTc z1aUBysaU*p>4C1wGL?dFCTL-*a+r)KL7{@eOoak0*X#OWf;SrMfbaAzsGfqU(K%XT ziI$|s=lC7^{ANjO%JCPXp3eF;z9BVT;TyU_aJTn~EIrWHvR$`0ft>xiU6UKHrV_14 z?H!}p{;Y3WfC_Q2ohyoA*ua;bD7S${ub~+@ngieVxYS0;v&s$C?liZo;cs^)!ZZiQ zWnyeg8j)$+1=3uM<0>`E4c+=~NO_zI+u`bxsVX0Itfxgfww@~i;}*uqe4;H)GHxkU zuvDwW(s`VIN9qBf{P`M|O3q^=!g;L1aglPNba-?TPT0|0WsCg9_<S^-UMv<YJvuy_ zsu9Q}4?l#ZEDvO^O`N6&qtW5~a{jyu*PAg#k?Kvi;TYcSe^_2x3Ju?b4)lF62)D6E zy2QtXJjOoWC5zs_WJo-5zlSl$mNDC9EGu}GI={!*tcug-ro$L75(sZ`p%W$7A6Gqu z0&BJ#X4l2sew^wy7#}+D$U1g1@S;cmsSKO`hY*4xuE($F9l!>to2YWg)<3@O@Rj?E J+U=`P{{r~v1k(Tj literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/sdist.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/sdist.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..fe1ccba602920f06556a66e1afb9dfeea5a43d55 GIT binary patch literal 6863 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 D^?2BL literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/setopt.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/setopt.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2980cd93255987f3c692ba6eba10c3ae64cff912 GIT binary patch literal 4593 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/test.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/test.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..608833759a49fde761253235ccc2c9904189f035 GIT binary patch literal 8296 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 Qm(tQM=~OfHR;OA2fA3mF&Hw-a literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/upload.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/upload.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..a78518a43629c47f78db13836cbf6ac1b6b2e6a9 GIT binary patch literal 5259 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/upload_docs.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/__pycache__/upload_docs.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e30d414ba1e32995bb1ac787c19c09e977e738b6 GIT binary patch literal 6196 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/alias.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/alias.py new file mode 100644 index 0000000..4532b1c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/alias.py @@ -0,0 +1,80 @@ +from distutils.errors import DistutilsOptionError + +from setuptools.extern.six.moves import map + +from setuptools.command.setopt import edit_config, option_base, config_file + + +def shquote(arg): + """Quote an argument for later parsing by shlex.split()""" + for c in '"', "'", "\\", "#": + if c in arg: + return repr(arg) + if arg.split() != [arg]: + return repr(arg) + return arg + + +class alias(option_base): + """Define a shortcut that invokes one or more commands""" + + description = "define a shortcut to invoke one or more commands" + command_consumes_arguments = True + + user_options = [ + ('remove', 'r', 'remove (unset) the alias'), + ] + option_base.user_options + + boolean_options = option_base.boolean_options + ['remove'] + + def initialize_options(self): + option_base.initialize_options(self) + self.args = None + self.remove = None + + def finalize_options(self): + option_base.finalize_options(self) + if self.remove and len(self.args) != 1: + raise DistutilsOptionError( + "Must specify exactly one argument (the alias name) when " + "using --remove" + ) + + def run(self): + aliases = self.distribution.get_option_dict('aliases') + + if not self.args: + print("Command Aliases") + print("---------------") + for alias in aliases: + print("setup.py alias", format_alias(alias, aliases)) + return + + elif len(self.args) == 1: + alias, = self.args + if self.remove: + command = None + elif alias in aliases: + print("setup.py alias", format_alias(alias, aliases)) + return + else: + print("No alias definition found for %r" % alias) + return + else: + alias = self.args[0] + command = ' '.join(map(shquote, self.args[1:])) + + edit_config(self.filename, {'aliases': {alias: command}}, self.dry_run) + + +def format_alias(name, aliases): + source, command = aliases[name] + if source == config_file('global'): + source = '--global-config ' + elif source == config_file('user'): + source = '--user-config ' + elif source == config_file('local'): + source = '' + else: + source = '--filename=%r' % source + return source + name + ' ' + command diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/bdist_egg.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/bdist_egg.py new file mode 100644 index 0000000..9f8df91 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/bdist_egg.py @@ -0,0 +1,502 @@ +"""setuptools.command.bdist_egg + +Build .egg distributions""" + +from distutils.errors import DistutilsSetupError +from distutils.dir_util import remove_tree, mkpath +from distutils import log +from types import CodeType +import sys +import os +import re +import textwrap +import marshal + +from setuptools.extern import six + +from pkg_resources import get_build_platform, Distribution, ensure_directory +from pkg_resources import EntryPoint +from setuptools.extension import Library +from setuptools import Command + +try: + # Python 2.7 or >=3.2 + from sysconfig import get_path, get_python_version + + def _get_purelib(): + return get_path("purelib") +except ImportError: + from distutils.sysconfig import get_python_lib, get_python_version + + def _get_purelib(): + return get_python_lib(False) + + +def strip_module(filename): + if '.' in filename: + filename = os.path.splitext(filename)[0] + if filename.endswith('module'): + filename = filename[:-6] + return filename + + +def sorted_walk(dir): + """Do os.walk in a reproducible way, + independent of indeterministic filesystem readdir order + """ + for base, dirs, files in os.walk(dir): + dirs.sort() + files.sort() + yield base, dirs, files + + +def write_stub(resource, pyfile): + _stub_template = textwrap.dedent(""" + def __bootstrap__(): + global __bootstrap__, __loader__, __file__ + import sys, pkg_resources, imp + __file__ = pkg_resources.resource_filename(__name__, %r) + __loader__ = None; del __bootstrap__, __loader__ + imp.load_dynamic(__name__,__file__) + __bootstrap__() + """).lstrip() + with open(pyfile, 'w') as f: + f.write(_stub_template % resource) + + +class bdist_egg(Command): + description = "create an \"egg\" distribution" + + user_options = [ + ('bdist-dir=', 'b', + "temporary directory for creating the distribution"), + ('plat-name=', 'p', "platform name to embed in generated filenames " + "(default: %s)" % get_build_platform()), + ('exclude-source-files', None, + "remove all .py files from the generated egg"), + ('keep-temp', 'k', + "keep the pseudo-installation tree around after " + + "creating the distribution archive"), + ('dist-dir=', 'd', + "directory to put final built distributions in"), + ('skip-build', None, + "skip rebuilding everything (for testing/debugging)"), + ] + + boolean_options = [ + 'keep-temp', 'skip-build', 'exclude-source-files' + ] + + def initialize_options(self): + self.bdist_dir = None + self.plat_name = None + self.keep_temp = 0 + self.dist_dir = None + self.skip_build = 0 + self.egg_output = None + self.exclude_source_files = None + + def finalize_options(self): + ei_cmd = self.ei_cmd = self.get_finalized_command("egg_info") + self.egg_info = ei_cmd.egg_info + + if self.bdist_dir is None: + bdist_base = self.get_finalized_command('bdist').bdist_base + self.bdist_dir = os.path.join(bdist_base, 'egg') + + if self.plat_name is None: + self.plat_name = get_build_platform() + + self.set_undefined_options('bdist', ('dist_dir', 'dist_dir')) + + if self.egg_output is None: + + # Compute filename of the output egg + basename = Distribution( + None, None, ei_cmd.egg_name, ei_cmd.egg_version, + get_python_version(), + self.distribution.has_ext_modules() and self.plat_name + ).egg_name() + + self.egg_output = os.path.join(self.dist_dir, basename + '.egg') + + def do_install_data(self): + # Hack for packages that install data to install's --install-lib + self.get_finalized_command('install').install_lib = self.bdist_dir + + site_packages = os.path.normcase(os.path.realpath(_get_purelib())) + old, self.distribution.data_files = self.distribution.data_files, [] + + for item in old: + if isinstance(item, tuple) and len(item) == 2: + if os.path.isabs(item[0]): + realpath = os.path.realpath(item[0]) + normalized = os.path.normcase(realpath) + if normalized == site_packages or normalized.startswith( + site_packages + os.sep + ): + item = realpath[len(site_packages) + 1:], item[1] + # XXX else: raise ??? + self.distribution.data_files.append(item) + + try: + log.info("installing package data to %s", self.bdist_dir) + self.call_command('install_data', force=0, root=None) + finally: + self.distribution.data_files = old + + def get_outputs(self): + return [self.egg_output] + + def call_command(self, cmdname, **kw): + """Invoke reinitialized command `cmdname` with keyword args""" + for dirname in INSTALL_DIRECTORY_ATTRS: + kw.setdefault(dirname, self.bdist_dir) + kw.setdefault('skip_build', self.skip_build) + kw.setdefault('dry_run', self.dry_run) + cmd = self.reinitialize_command(cmdname, **kw) + self.run_command(cmdname) + return cmd + + def run(self): + # Generate metadata first + self.run_command("egg_info") + # We run install_lib before install_data, because some data hacks + # pull their data path from the install_lib command. + log.info("installing library code to %s", self.bdist_dir) + instcmd = self.get_finalized_command('install') + old_root = instcmd.root + instcmd.root = None + if self.distribution.has_c_libraries() and not self.skip_build: + self.run_command('build_clib') + cmd = self.call_command('install_lib', warn_dir=0) + instcmd.root = old_root + + all_outputs, ext_outputs = self.get_ext_outputs() + self.stubs = [] + to_compile = [] + for (p, ext_name) in enumerate(ext_outputs): + filename, ext = os.path.splitext(ext_name) + pyfile = os.path.join(self.bdist_dir, strip_module(filename) + + '.py') + self.stubs.append(pyfile) + log.info("creating stub loader for %s", ext_name) + if not self.dry_run: + write_stub(os.path.basename(ext_name), pyfile) + to_compile.append(pyfile) + ext_outputs[p] = ext_name.replace(os.sep, '/') + + if to_compile: + cmd.byte_compile(to_compile) + if self.distribution.data_files: + self.do_install_data() + + # Make the EGG-INFO directory + archive_root = self.bdist_dir + egg_info = os.path.join(archive_root, 'EGG-INFO') + self.mkpath(egg_info) + if self.distribution.scripts: + script_dir = os.path.join(egg_info, 'scripts') + log.info("installing scripts to %s", script_dir) + self.call_command('install_scripts', install_dir=script_dir, + no_ep=1) + + self.copy_metadata_to(egg_info) + native_libs = os.path.join(egg_info, "native_libs.txt") + if all_outputs: + log.info("writing %s", native_libs) + if not self.dry_run: + ensure_directory(native_libs) + libs_file = open(native_libs, 'wt') + libs_file.write('\n'.join(all_outputs)) + libs_file.write('\n') + libs_file.close() + elif os.path.isfile(native_libs): + log.info("removing %s", native_libs) + if not self.dry_run: + os.unlink(native_libs) + + write_safety_flag( + os.path.join(archive_root, 'EGG-INFO'), self.zip_safe() + ) + + if os.path.exists(os.path.join(self.egg_info, 'depends.txt')): + log.warn( + "WARNING: 'depends.txt' will not be used by setuptools 0.6!\n" + "Use the install_requires/extras_require setup() args instead." + ) + + if self.exclude_source_files: + self.zap_pyfiles() + + # Make the archive + make_zipfile(self.egg_output, archive_root, verbose=self.verbose, + dry_run=self.dry_run, mode=self.gen_header()) + if not self.keep_temp: + remove_tree(self.bdist_dir, dry_run=self.dry_run) + + # Add to 'Distribution.dist_files' so that the "upload" command works + getattr(self.distribution, 'dist_files', []).append( + ('bdist_egg', get_python_version(), self.egg_output)) + + def zap_pyfiles(self): + log.info("Removing .py files from temporary directory") + for base, dirs, files in walk_egg(self.bdist_dir): + for name in files: + path = os.path.join(base, name) + + if name.endswith('.py'): + log.debug("Deleting %s", path) + os.unlink(path) + + if base.endswith('__pycache__'): + path_old = path + + pattern = r'(?P<name>.+)\.(?P<magic>[^.]+)\.pyc' + m = re.match(pattern, name) + path_new = os.path.join( + base, os.pardir, m.group('name') + '.pyc') + log.info( + "Renaming file from [%s] to [%s]" + % (path_old, path_new)) + try: + os.remove(path_new) + except OSError: + pass + os.rename(path_old, path_new) + + def zip_safe(self): + safe = getattr(self.distribution, 'zip_safe', None) + if safe is not None: + return safe + log.warn("zip_safe flag not set; analyzing archive contents...") + return analyze_egg(self.bdist_dir, self.stubs) + + def gen_header(self): + epm = EntryPoint.parse_map(self.distribution.entry_points or '') + ep = epm.get('setuptools.installation', {}).get('eggsecutable') + if ep is None: + return 'w' # not an eggsecutable, do it the usual way. + + if not ep.attrs or ep.extras: + raise DistutilsSetupError( + "eggsecutable entry point (%r) cannot have 'extras' " + "or refer to a module" % (ep,) + ) + + pyver = sys.version[:3] + pkg = ep.module_name + full = '.'.join(ep.attrs) + base = ep.attrs[0] + basename = os.path.basename(self.egg_output) + + header = ( + "#!/bin/sh\n" + 'if [ `basename $0` = "%(basename)s" ]\n' + 'then exec python%(pyver)s -c "' + "import sys, os; sys.path.insert(0, os.path.abspath('$0')); " + "from %(pkg)s import %(base)s; sys.exit(%(full)s())" + '" "$@"\n' + 'else\n' + ' echo $0 is not the correct name for this egg file.\n' + ' echo Please rename it back to %(basename)s and try again.\n' + ' exec false\n' + 'fi\n' + ) % locals() + + if not self.dry_run: + mkpath(os.path.dirname(self.egg_output), dry_run=self.dry_run) + f = open(self.egg_output, 'w') + f.write(header) + f.close() + return 'a' + + def copy_metadata_to(self, target_dir): + "Copy metadata (egg info) to the target_dir" + # normalize the path (so that a forward-slash in egg_info will + # match using startswith below) + norm_egg_info = os.path.normpath(self.egg_info) + prefix = os.path.join(norm_egg_info, '') + for path in self.ei_cmd.filelist.files: + if path.startswith(prefix): + target = os.path.join(target_dir, path[len(prefix):]) + ensure_directory(target) + self.copy_file(path, target) + + def get_ext_outputs(self): + """Get a list of relative paths to C extensions in the output distro""" + + all_outputs = [] + ext_outputs = [] + + paths = {self.bdist_dir: ''} + for base, dirs, files in sorted_walk(self.bdist_dir): + for filename in files: + if os.path.splitext(filename)[1].lower() in NATIVE_EXTENSIONS: + all_outputs.append(paths[base] + filename) + for filename in dirs: + paths[os.path.join(base, filename)] = (paths[base] + + filename + '/') + + if self.distribution.has_ext_modules(): + build_cmd = self.get_finalized_command('build_ext') + for ext in build_cmd.extensions: + if isinstance(ext, Library): + continue + fullname = build_cmd.get_ext_fullname(ext.name) + filename = build_cmd.get_ext_filename(fullname) + if not os.path.basename(filename).startswith('dl-'): + if os.path.exists(os.path.join(self.bdist_dir, filename)): + ext_outputs.append(filename) + + return all_outputs, ext_outputs + + +NATIVE_EXTENSIONS = dict.fromkeys('.dll .so .dylib .pyd'.split()) + + +def walk_egg(egg_dir): + """Walk an unpacked egg's contents, skipping the metadata directory""" + walker = sorted_walk(egg_dir) + base, dirs, files = next(walker) + if 'EGG-INFO' in dirs: + dirs.remove('EGG-INFO') + yield base, dirs, files + for bdf in walker: + yield bdf + + +def analyze_egg(egg_dir, stubs): + # check for existing flag in EGG-INFO + for flag, fn in safety_flags.items(): + if os.path.exists(os.path.join(egg_dir, 'EGG-INFO', fn)): + return flag + if not can_scan(): + return False + safe = True + for base, dirs, files in walk_egg(egg_dir): + for name in files: + if name.endswith('.py') or name.endswith('.pyw'): + continue + elif name.endswith('.pyc') or name.endswith('.pyo'): + # always scan, even if we already know we're not safe + safe = scan_module(egg_dir, base, name, stubs) and safe + return safe + + +def write_safety_flag(egg_dir, safe): + # Write or remove zip safety flag file(s) + for flag, fn in safety_flags.items(): + fn = os.path.join(egg_dir, fn) + if os.path.exists(fn): + if safe is None or bool(safe) != flag: + os.unlink(fn) + elif safe is not None and bool(safe) == flag: + f = open(fn, 'wt') + f.write('\n') + f.close() + + +safety_flags = { + True: 'zip-safe', + False: 'not-zip-safe', +} + + +def scan_module(egg_dir, base, name, stubs): + """Check whether module possibly uses unsafe-for-zipfile stuff""" + + filename = os.path.join(base, name) + if filename[:-1] in stubs: + return True # Extension module + pkg = base[len(egg_dir) + 1:].replace(os.sep, '.') + module = pkg + (pkg and '.' or '') + os.path.splitext(name)[0] + if six.PY2: + skip = 8 # skip magic & date + elif sys.version_info < (3, 7): + skip = 12 # skip magic & date & file size + else: + skip = 16 # skip magic & reserved? & date & file size + f = open(filename, 'rb') + f.read(skip) + code = marshal.load(f) + f.close() + safe = True + symbols = dict.fromkeys(iter_symbols(code)) + for bad in ['__file__', '__path__']: + if bad in symbols: + log.warn("%s: module references %s", module, bad) + safe = False + if 'inspect' in symbols: + for bad in [ + 'getsource', 'getabsfile', 'getsourcefile', 'getfile' + 'getsourcelines', 'findsource', 'getcomments', 'getframeinfo', + 'getinnerframes', 'getouterframes', 'stack', 'trace' + ]: + if bad in symbols: + log.warn("%s: module MAY be using inspect.%s", module, bad) + safe = False + return safe + + +def iter_symbols(code): + """Yield names and strings used by `code` and its nested code objects""" + for name in code.co_names: + yield name + for const in code.co_consts: + if isinstance(const, six.string_types): + yield const + elif isinstance(const, CodeType): + for name in iter_symbols(const): + yield name + + +def can_scan(): + if not sys.platform.startswith('java') and sys.platform != 'cli': + # CPython, PyPy, etc. + return True + log.warn("Unable to analyze compiled code on this platform.") + log.warn("Please ask the author to include a 'zip_safe'" + " setting (either True or False) in the package's setup.py") + + +# Attribute names of options for commands that might need to be convinced to +# install to the egg build directory + +INSTALL_DIRECTORY_ATTRS = [ + 'install_lib', 'install_dir', 'install_data', 'install_base' +] + + +def make_zipfile(zip_filename, base_dir, verbose=0, dry_run=0, compress=True, + mode='w'): + """Create a zip file from all the files under 'base_dir'. The output + zip file will be named 'base_dir' + ".zip". Uses either the "zipfile" + Python module (if available) or the InfoZIP "zip" utility (if installed + and found on the default search path). If neither tool is available, + raises DistutilsExecError. Returns the name of the output zip file. + """ + import zipfile + + mkpath(os.path.dirname(zip_filename), dry_run=dry_run) + log.info("creating '%s' and adding '%s' to it", zip_filename, base_dir) + + def visit(z, dirname, names): + for name in names: + path = os.path.normpath(os.path.join(dirname, name)) + if os.path.isfile(path): + p = path[len(base_dir) + 1:] + if not dry_run: + z.write(path, p) + log.debug("adding '%s'", p) + + compression = zipfile.ZIP_DEFLATED if compress else zipfile.ZIP_STORED + if not dry_run: + z = zipfile.ZipFile(zip_filename, mode, compression=compression) + for dirname, dirs, files in sorted_walk(base_dir): + visit(z, dirname, files) + z.close() + else: + for dirname, dirs, files in sorted_walk(base_dir): + visit(None, dirname, files) + return zip_filename diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/bdist_rpm.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/bdist_rpm.py new file mode 100644 index 0000000..7073092 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/bdist_rpm.py @@ -0,0 +1,43 @@ +import distutils.command.bdist_rpm as orig + + +class bdist_rpm(orig.bdist_rpm): + """ + Override the default bdist_rpm behavior to do the following: + + 1. Run egg_info to ensure the name and version are properly calculated. + 2. Always run 'install' using --single-version-externally-managed to + disable eggs in RPM distributions. + 3. Replace dash with underscore in the version numbers for better RPM + compatibility. + """ + + def run(self): + # ensure distro name is up-to-date + self.run_command('egg_info') + + orig.bdist_rpm.run(self) + + def _make_spec_file(self): + version = self.distribution.get_version() + rpmversion = version.replace('-', '_') + spec = orig.bdist_rpm._make_spec_file(self) + line23 = '%define version ' + version + line24 = '%define version ' + rpmversion + spec = [ + line.replace( + "Source0: %{name}-%{version}.tar", + "Source0: %{name}-%{unmangled_version}.tar" + ).replace( + "setup.py install ", + "setup.py install --single-version-externally-managed " + ).replace( + "%setup", + "%setup -n %{name}-%{unmangled_version}" + ).replace(line23, line24) + for line in spec + ] + insert_loc = spec.index(line24) + 1 + unmangled_version = "%define unmangled_version " + version + spec.insert(insert_loc, unmangled_version) + return spec diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/bdist_wininst.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/bdist_wininst.py new file mode 100644 index 0000000..073de97 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/bdist_wininst.py @@ -0,0 +1,21 @@ +import distutils.command.bdist_wininst as orig + + +class bdist_wininst(orig.bdist_wininst): + def reinitialize_command(self, command, reinit_subcommands=0): + """ + Supplement reinitialize_command to work around + http://bugs.python.org/issue20819 + """ + cmd = self.distribution.reinitialize_command( + command, reinit_subcommands) + if command in ('install', 'install_lib'): + cmd.install_lib = None + return cmd + + def run(self): + self._is_running = True + try: + orig.bdist_wininst.run(self) + finally: + self._is_running = False diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/build_clib.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/build_clib.py new file mode 100644 index 0000000..09caff6 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/build_clib.py @@ -0,0 +1,98 @@ +import distutils.command.build_clib as orig +from distutils.errors import DistutilsSetupError +from distutils import log +from setuptools.dep_util import newer_pairwise_group + + +class build_clib(orig.build_clib): + """ + Override the default build_clib behaviour to do the following: + + 1. Implement a rudimentary timestamp-based dependency system + so 'compile()' doesn't run every time. + 2. Add more keys to the 'build_info' dictionary: + * obj_deps - specify dependencies for each object compiled. + this should be a dictionary mapping a key + with the source filename to a list of + dependencies. Use an empty string for global + dependencies. + * cflags - specify a list of additional flags to pass to + the compiler. + """ + + def build_libraries(self, libraries): + for (lib_name, build_info) in libraries: + sources = build_info.get('sources') + if sources is None or not isinstance(sources, (list, tuple)): + raise DistutilsSetupError( + "in 'libraries' option (library '%s'), " + "'sources' must be present and must be " + "a list of source filenames" % lib_name) + sources = list(sources) + + log.info("building '%s' library", lib_name) + + # Make sure everything is the correct type. + # obj_deps should be a dictionary of keys as sources + # and a list/tuple of files that are its dependencies. + obj_deps = build_info.get('obj_deps', dict()) + if not isinstance(obj_deps, dict): + raise DistutilsSetupError( + "in 'libraries' option (library '%s'), " + "'obj_deps' must be a dictionary of " + "type 'source: list'" % lib_name) + dependencies = [] + + # Get the global dependencies that are specified by the '' key. + # These will go into every source's dependency list. + global_deps = obj_deps.get('', list()) + if not isinstance(global_deps, (list, tuple)): + raise DistutilsSetupError( + "in 'libraries' option (library '%s'), " + "'obj_deps' must be a dictionary of " + "type 'source: list'" % lib_name) + + # Build the list to be used by newer_pairwise_group + # each source will be auto-added to its dependencies. + for source in sources: + src_deps = [source] + src_deps.extend(global_deps) + extra_deps = obj_deps.get(source, list()) + if not isinstance(extra_deps, (list, tuple)): + raise DistutilsSetupError( + "in 'libraries' option (library '%s'), " + "'obj_deps' must be a dictionary of " + "type 'source: list'" % lib_name) + src_deps.extend(extra_deps) + dependencies.append(src_deps) + + expected_objects = self.compiler.object_filenames( + sources, + output_dir=self.build_temp + ) + + if newer_pairwise_group(dependencies, expected_objects) != ([], []): + # First, compile the source code to object files in the library + # directory. (This should probably change to putting object + # files in a temporary build directory.) + macros = build_info.get('macros') + include_dirs = build_info.get('include_dirs') + cflags = build_info.get('cflags') + objects = self.compiler.compile( + sources, + output_dir=self.build_temp, + macros=macros, + include_dirs=include_dirs, + extra_postargs=cflags, + debug=self.debug + ) + + # Now "link" the object files together into a static library. + # (On Unix at least, this isn't really linking -- it just + # builds an archive. Whatever.) + self.compiler.create_static_lib( + expected_objects, + lib_name, + output_dir=self.build_clib, + debug=self.debug + ) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/build_ext.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/build_ext.py new file mode 100644 index 0000000..daa8e4f --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/build_ext.py @@ -0,0 +1,327 @@ +import os +import sys +import itertools +from distutils.command.build_ext import build_ext as _du_build_ext +from distutils.file_util import copy_file +from distutils.ccompiler import new_compiler +from distutils.sysconfig import customize_compiler, get_config_var +from distutils.errors import DistutilsError +from distutils import log + +from setuptools.extension import Library +from setuptools.extern import six + +if six.PY2: + import imp + + EXTENSION_SUFFIXES = [s for s, _, tp in imp.get_suffixes() if tp == imp.C_EXTENSION] +else: + from importlib.machinery import EXTENSION_SUFFIXES + +try: + # Attempt to use Cython for building extensions, if available + from Cython.Distutils.build_ext import build_ext as _build_ext + # Additionally, assert that the compiler module will load + # also. Ref #1229. + __import__('Cython.Compiler.Main') +except ImportError: + _build_ext = _du_build_ext + +# make sure _config_vars is initialized +get_config_var("LDSHARED") +from distutils.sysconfig import _config_vars as _CONFIG_VARS + + +def _customize_compiler_for_shlib(compiler): + if sys.platform == "darwin": + # building .dylib requires additional compiler flags on OSX; here we + # temporarily substitute the pyconfig.h variables so that distutils' + # 'customize_compiler' uses them before we build the shared libraries. + tmp = _CONFIG_VARS.copy() + try: + # XXX Help! I don't have any idea whether these are right... + _CONFIG_VARS['LDSHARED'] = ( + "gcc -Wl,-x -dynamiclib -undefined dynamic_lookup") + _CONFIG_VARS['CCSHARED'] = " -dynamiclib" + _CONFIG_VARS['SO'] = ".dylib" + customize_compiler(compiler) + finally: + _CONFIG_VARS.clear() + _CONFIG_VARS.update(tmp) + else: + customize_compiler(compiler) + + +have_rtld = False +use_stubs = False +libtype = 'shared' + +if sys.platform == "darwin": + use_stubs = True +elif os.name != 'nt': + try: + import dl + use_stubs = have_rtld = hasattr(dl, 'RTLD_NOW') + except ImportError: + pass + +if_dl = lambda s: s if have_rtld else '' + + +def get_abi3_suffix(): + """Return the file extension for an abi3-compliant Extension()""" + for suffix in EXTENSION_SUFFIXES: + if '.abi3' in suffix: # Unix + return suffix + elif suffix == '.pyd': # Windows + return suffix + + +class build_ext(_build_ext): + def run(self): + """Build extensions in build directory, then copy if --inplace""" + old_inplace, self.inplace = self.inplace, 0 + _build_ext.run(self) + self.inplace = old_inplace + if old_inplace: + self.copy_extensions_to_source() + + def copy_extensions_to_source(self): + build_py = self.get_finalized_command('build_py') + for ext in self.extensions: + fullname = self.get_ext_fullname(ext.name) + filename = self.get_ext_filename(fullname) + modpath = fullname.split('.') + package = '.'.join(modpath[:-1]) + package_dir = build_py.get_package_dir(package) + dest_filename = os.path.join(package_dir, + os.path.basename(filename)) + src_filename = os.path.join(self.build_lib, filename) + + # Always copy, even if source is older than destination, to ensure + # that the right extensions for the current Python/platform are + # used. + copy_file( + src_filename, dest_filename, verbose=self.verbose, + dry_run=self.dry_run + ) + if ext._needs_stub: + self.write_stub(package_dir or os.curdir, ext, True) + + def get_ext_filename(self, fullname): + filename = _build_ext.get_ext_filename(self, fullname) + if fullname in self.ext_map: + ext = self.ext_map[fullname] + use_abi3 = ( + six.PY3 + and getattr(ext, 'py_limited_api') + and get_abi3_suffix() + ) + if use_abi3: + so_ext = get_config_var('EXT_SUFFIX') + filename = filename[:-len(so_ext)] + filename = filename + get_abi3_suffix() + if isinstance(ext, Library): + fn, ext = os.path.splitext(filename) + return self.shlib_compiler.library_filename(fn, libtype) + elif use_stubs and ext._links_to_dynamic: + d, fn = os.path.split(filename) + return os.path.join(d, 'dl-' + fn) + return filename + + def initialize_options(self): + _build_ext.initialize_options(self) + self.shlib_compiler = None + self.shlibs = [] + self.ext_map = {} + + def finalize_options(self): + _build_ext.finalize_options(self) + self.extensions = self.extensions or [] + self.check_extensions_list(self.extensions) + self.shlibs = [ext for ext in self.extensions + if isinstance(ext, Library)] + if self.shlibs: + self.setup_shlib_compiler() + for ext in self.extensions: + ext._full_name = self.get_ext_fullname(ext.name) + for ext in self.extensions: + fullname = ext._full_name + self.ext_map[fullname] = ext + + # distutils 3.1 will also ask for module names + # XXX what to do with conflicts? + self.ext_map[fullname.split('.')[-1]] = ext + + ltd = self.shlibs and self.links_to_dynamic(ext) or False + ns = ltd and use_stubs and not isinstance(ext, Library) + ext._links_to_dynamic = ltd + ext._needs_stub = ns + filename = ext._file_name = self.get_ext_filename(fullname) + libdir = os.path.dirname(os.path.join(self.build_lib, filename)) + if ltd and libdir not in ext.library_dirs: + ext.library_dirs.append(libdir) + if ltd and use_stubs and os.curdir not in ext.runtime_library_dirs: + ext.runtime_library_dirs.append(os.curdir) + + def setup_shlib_compiler(self): + compiler = self.shlib_compiler = new_compiler( + compiler=self.compiler, dry_run=self.dry_run, force=self.force + ) + _customize_compiler_for_shlib(compiler) + + if self.include_dirs is not None: + compiler.set_include_dirs(self.include_dirs) + if self.define is not None: + # 'define' option is a list of (name,value) tuples + for (name, value) in self.define: + compiler.define_macro(name, value) + if self.undef is not None: + for macro in self.undef: + compiler.undefine_macro(macro) + if self.libraries is not None: + compiler.set_libraries(self.libraries) + if self.library_dirs is not None: + compiler.set_library_dirs(self.library_dirs) + if self.rpath is not None: + compiler.set_runtime_library_dirs(self.rpath) + if self.link_objects is not None: + compiler.set_link_objects(self.link_objects) + + # hack so distutils' build_extension() builds a library instead + compiler.link_shared_object = link_shared_object.__get__(compiler) + + def get_export_symbols(self, ext): + if isinstance(ext, Library): + return ext.export_symbols + return _build_ext.get_export_symbols(self, ext) + + def build_extension(self, ext): + ext._convert_pyx_sources_to_lang() + _compiler = self.compiler + try: + if isinstance(ext, Library): + self.compiler = self.shlib_compiler + _build_ext.build_extension(self, ext) + if ext._needs_stub: + cmd = self.get_finalized_command('build_py').build_lib + self.write_stub(cmd, ext) + finally: + self.compiler = _compiler + + def links_to_dynamic(self, ext): + """Return true if 'ext' links to a dynamic lib in the same package""" + # XXX this should check to ensure the lib is actually being built + # XXX as dynamic, and not just using a locally-found version or a + # XXX static-compiled version + libnames = dict.fromkeys([lib._full_name for lib in self.shlibs]) + pkg = '.'.join(ext._full_name.split('.')[:-1] + ['']) + return any(pkg + libname in libnames for libname in ext.libraries) + + def get_outputs(self): + return _build_ext.get_outputs(self) + self.__get_stubs_outputs() + + def __get_stubs_outputs(self): + # assemble the base name for each extension that needs a stub + ns_ext_bases = ( + os.path.join(self.build_lib, *ext._full_name.split('.')) + for ext in self.extensions + if ext._needs_stub + ) + # pair each base with the extension + pairs = itertools.product(ns_ext_bases, self.__get_output_extensions()) + return list(base + fnext for base, fnext in pairs) + + def __get_output_extensions(self): + yield '.py' + yield '.pyc' + if self.get_finalized_command('build_py').optimize: + yield '.pyo' + + def write_stub(self, output_dir, ext, compile=False): + log.info("writing stub loader for %s to %s", ext._full_name, + output_dir) + stub_file = (os.path.join(output_dir, *ext._full_name.split('.')) + + '.py') + if compile and os.path.exists(stub_file): + raise DistutilsError(stub_file + " already exists! Please delete.") + if not self.dry_run: + f = open(stub_file, 'w') + f.write( + '\n'.join([ + "def __bootstrap__():", + " global __bootstrap__, __file__, __loader__", + " import sys, os, pkg_resources, imp" + if_dl(", dl"), + " __file__ = pkg_resources.resource_filename" + "(__name__,%r)" + % os.path.basename(ext._file_name), + " del __bootstrap__", + " if '__loader__' in globals():", + " del __loader__", + if_dl(" old_flags = sys.getdlopenflags()"), + " old_dir = os.getcwd()", + " try:", + " os.chdir(os.path.dirname(__file__))", + if_dl(" sys.setdlopenflags(dl.RTLD_NOW)"), + " imp.load_dynamic(__name__,__file__)", + " finally:", + if_dl(" sys.setdlopenflags(old_flags)"), + " os.chdir(old_dir)", + "__bootstrap__()", + "" # terminal \n + ]) + ) + f.close() + if compile: + from distutils.util import byte_compile + + byte_compile([stub_file], optimize=0, + force=True, dry_run=self.dry_run) + optimize = self.get_finalized_command('install_lib').optimize + if optimize > 0: + byte_compile([stub_file], optimize=optimize, + force=True, dry_run=self.dry_run) + if os.path.exists(stub_file) and not self.dry_run: + os.unlink(stub_file) + + +if use_stubs or os.name == 'nt': + # Build shared libraries + # + def link_shared_object( + self, objects, output_libname, output_dir=None, libraries=None, + library_dirs=None, runtime_library_dirs=None, export_symbols=None, + debug=0, extra_preargs=None, extra_postargs=None, build_temp=None, + target_lang=None): + self.link( + self.SHARED_LIBRARY, objects, output_libname, + output_dir, libraries, library_dirs, runtime_library_dirs, + export_symbols, debug, extra_preargs, extra_postargs, + build_temp, target_lang + ) +else: + # Build static libraries everywhere else + libtype = 'static' + + def link_shared_object( + self, objects, output_libname, output_dir=None, libraries=None, + library_dirs=None, runtime_library_dirs=None, export_symbols=None, + debug=0, extra_preargs=None, extra_postargs=None, build_temp=None, + target_lang=None): + # XXX we need to either disallow these attrs on Library instances, + # or warn/abort here if set, or something... + # libraries=None, library_dirs=None, runtime_library_dirs=None, + # export_symbols=None, extra_preargs=None, extra_postargs=None, + # build_temp=None + + assert output_dir is None # distutils build_ext doesn't pass this + output_dir, filename = os.path.split(output_libname) + basename, ext = os.path.splitext(filename) + if self.library_filename("x").startswith('lib'): + # strip 'lib' prefix; this is kludgy if some platform uses + # a different prefix + basename = basename[3:] + + self.create_static_lib( + objects, basename, output_dir, debug, target_lang + ) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/build_py.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/build_py.py new file mode 100644 index 0000000..b0314fd --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/build_py.py @@ -0,0 +1,270 @@ +from glob import glob +from distutils.util import convert_path +import distutils.command.build_py as orig +import os +import fnmatch +import textwrap +import io +import distutils.errors +import itertools + +from setuptools.extern import six +from setuptools.extern.six.moves import map, filter, filterfalse + +try: + from setuptools.lib2to3_ex import Mixin2to3 +except ImportError: + + class Mixin2to3: + def run_2to3(self, files, doctests=True): + "do nothing" + + +class build_py(orig.build_py, Mixin2to3): + """Enhanced 'build_py' command that includes data files with packages + + The data files are specified via a 'package_data' argument to 'setup()'. + See 'setuptools.dist.Distribution' for more details. + + Also, this version of the 'build_py' command allows you to specify both + 'py_modules' and 'packages' in the same setup operation. + """ + + def finalize_options(self): + orig.build_py.finalize_options(self) + self.package_data = self.distribution.package_data + self.exclude_package_data = (self.distribution.exclude_package_data or + {}) + if 'data_files' in self.__dict__: + del self.__dict__['data_files'] + self.__updated_files = [] + self.__doctests_2to3 = [] + + def run(self): + """Build modules, packages, and copy data files to build directory""" + if not self.py_modules and not self.packages: + return + + if self.py_modules: + self.build_modules() + + if self.packages: + self.build_packages() + self.build_package_data() + + self.run_2to3(self.__updated_files, False) + self.run_2to3(self.__updated_files, True) + self.run_2to3(self.__doctests_2to3, True) + + # Only compile actual .py files, using our base class' idea of what our + # output files are. + self.byte_compile(orig.build_py.get_outputs(self, include_bytecode=0)) + + def __getattr__(self, attr): + "lazily compute data files" + if attr == 'data_files': + self.data_files = self._get_data_files() + return self.data_files + return orig.build_py.__getattr__(self, attr) + + def build_module(self, module, module_file, package): + if six.PY2 and isinstance(package, six.string_types): + # avoid errors on Python 2 when unicode is passed (#190) + package = package.split('.') + outfile, copied = orig.build_py.build_module(self, module, module_file, + package) + if copied: + self.__updated_files.append(outfile) + return outfile, copied + + def _get_data_files(self): + """Generate list of '(package,src_dir,build_dir,filenames)' tuples""" + self.analyze_manifest() + return list(map(self._get_pkg_data_files, self.packages or ())) + + def _get_pkg_data_files(self, package): + # Locate package source directory + src_dir = self.get_package_dir(package) + + # Compute package build directory + build_dir = os.path.join(*([self.build_lib] + package.split('.'))) + + # Strip directory from globbed filenames + filenames = [ + os.path.relpath(file, src_dir) + for file in self.find_data_files(package, src_dir) + ] + return package, src_dir, build_dir, filenames + + def find_data_files(self, package, src_dir): + """Return filenames for package's data files in 'src_dir'""" + patterns = self._get_platform_patterns( + self.package_data, + package, + src_dir, + ) + globs_expanded = map(glob, patterns) + # flatten the expanded globs into an iterable of matches + globs_matches = itertools.chain.from_iterable(globs_expanded) + glob_files = filter(os.path.isfile, globs_matches) + files = itertools.chain( + self.manifest_files.get(package, []), + glob_files, + ) + return self.exclude_data_files(package, src_dir, files) + + def build_package_data(self): + """Copy data files into build directory""" + for package, src_dir, build_dir, filenames in self.data_files: + for filename in filenames: + target = os.path.join(build_dir, filename) + self.mkpath(os.path.dirname(target)) + srcfile = os.path.join(src_dir, filename) + outf, copied = self.copy_file(srcfile, target) + srcfile = os.path.abspath(srcfile) + if (copied and + srcfile in self.distribution.convert_2to3_doctests): + self.__doctests_2to3.append(outf) + + def analyze_manifest(self): + self.manifest_files = mf = {} + if not self.distribution.include_package_data: + return + src_dirs = {} + for package in self.packages or (): + # Locate package source directory + src_dirs[assert_relative(self.get_package_dir(package))] = package + + self.run_command('egg_info') + ei_cmd = self.get_finalized_command('egg_info') + for path in ei_cmd.filelist.files: + d, f = os.path.split(assert_relative(path)) + prev = None + oldf = f + while d and d != prev and d not in src_dirs: + prev = d + d, df = os.path.split(d) + f = os.path.join(df, f) + if d in src_dirs: + if path.endswith('.py') and f == oldf: + continue # it's a module, not data + mf.setdefault(src_dirs[d], []).append(path) + + def get_data_files(self): + pass # Lazily compute data files in _get_data_files() function. + + def check_package(self, package, package_dir): + """Check namespace packages' __init__ for declare_namespace""" + try: + return self.packages_checked[package] + except KeyError: + pass + + init_py = orig.build_py.check_package(self, package, package_dir) + self.packages_checked[package] = init_py + + if not init_py or not self.distribution.namespace_packages: + return init_py + + for pkg in self.distribution.namespace_packages: + if pkg == package or pkg.startswith(package + '.'): + break + else: + return init_py + + with io.open(init_py, 'rb') as f: + contents = f.read() + if b'declare_namespace' not in contents: + raise distutils.errors.DistutilsError( + "Namespace package problem: %s is a namespace package, but " + "its\n__init__.py does not call declare_namespace()! Please " + 'fix it.\n(See the setuptools manual under ' + '"Namespace Packages" for details.)\n"' % (package,) + ) + return init_py + + def initialize_options(self): + self.packages_checked = {} + orig.build_py.initialize_options(self) + + def get_package_dir(self, package): + res = orig.build_py.get_package_dir(self, package) + if self.distribution.src_root is not None: + return os.path.join(self.distribution.src_root, res) + return res + + def exclude_data_files(self, package, src_dir, files): + """Filter filenames for package's data files in 'src_dir'""" + files = list(files) + patterns = self._get_platform_patterns( + self.exclude_package_data, + package, + src_dir, + ) + match_groups = ( + fnmatch.filter(files, pattern) + for pattern in patterns + ) + # flatten the groups of matches into an iterable of matches + matches = itertools.chain.from_iterable(match_groups) + bad = set(matches) + keepers = ( + fn + for fn in files + if fn not in bad + ) + # ditch dupes + return list(_unique_everseen(keepers)) + + @staticmethod + def _get_platform_patterns(spec, package, src_dir): + """ + yield platform-specific path patterns (suitable for glob + or fn_match) from a glob-based spec (such as + self.package_data or self.exclude_package_data) + matching package in src_dir. + """ + raw_patterns = itertools.chain( + spec.get('', []), + spec.get(package, []), + ) + return ( + # Each pattern has to be converted to a platform-specific path + os.path.join(src_dir, convert_path(pattern)) + for pattern in raw_patterns + ) + + +# from Python docs +def _unique_everseen(iterable, key=None): + "List unique elements, preserving order. Remember all elements ever seen." + # unique_everseen('AAAABBBCCDAABBB') --> A B C D + # unique_everseen('ABBCcAD', str.lower) --> A B C D + seen = set() + seen_add = seen.add + if key is None: + for element in filterfalse(seen.__contains__, iterable): + seen_add(element) + yield element + else: + for element in iterable: + k = key(element) + if k not in seen: + seen_add(k) + yield element + + +def assert_relative(path): + if not os.path.isabs(path): + return path + from distutils.errors import DistutilsSetupError + + msg = textwrap.dedent(""" + Error: setup script specifies an absolute path: + + %s + + setup() arguments must *always* be /-separated paths relative to the + setup.py directory, *never* absolute paths. + """).lstrip() % path + raise DistutilsSetupError(msg) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/develop.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/develop.py new file mode 100644 index 0000000..009e4f9 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/develop.py @@ -0,0 +1,221 @@ +from distutils.util import convert_path +from distutils import log +from distutils.errors import DistutilsError, DistutilsOptionError +import os +import glob +import io + +from setuptools.extern import six + +import pkg_resources +from setuptools.command.easy_install import easy_install +from setuptools import namespaces +import setuptools + +__metaclass__ = type + + +class develop(namespaces.DevelopInstaller, easy_install): + """Set up package for development""" + + description = "install package in 'development mode'" + + user_options = easy_install.user_options + [ + ("uninstall", "u", "Uninstall this source package"), + ("egg-path=", None, "Set the path to be used in the .egg-link file"), + ] + + boolean_options = easy_install.boolean_options + ['uninstall'] + + command_consumes_arguments = False # override base + + def run(self): + if self.uninstall: + self.multi_version = True + self.uninstall_link() + self.uninstall_namespaces() + else: + self.install_for_development() + self.warn_deprecated_options() + + def initialize_options(self): + self.uninstall = None + self.egg_path = None + easy_install.initialize_options(self) + self.setup_path = None + self.always_copy_from = '.' # always copy eggs installed in curdir + + def finalize_options(self): + ei = self.get_finalized_command("egg_info") + if ei.broken_egg_info: + template = "Please rename %r to %r before using 'develop'" + args = ei.egg_info, ei.broken_egg_info + raise DistutilsError(template % args) + self.args = [ei.egg_name] + + easy_install.finalize_options(self) + self.expand_basedirs() + self.expand_dirs() + # pick up setup-dir .egg files only: no .egg-info + self.package_index.scan(glob.glob('*.egg')) + + egg_link_fn = ei.egg_name + '.egg-link' + self.egg_link = os.path.join(self.install_dir, egg_link_fn) + self.egg_base = ei.egg_base + if self.egg_path is None: + self.egg_path = os.path.abspath(ei.egg_base) + + target = pkg_resources.normalize_path(self.egg_base) + egg_path = pkg_resources.normalize_path( + os.path.join(self.install_dir, self.egg_path)) + if egg_path != target: + raise DistutilsOptionError( + "--egg-path must be a relative path from the install" + " directory to " + target + ) + + # Make a distribution for the package's source + self.dist = pkg_resources.Distribution( + target, + pkg_resources.PathMetadata(target, os.path.abspath(ei.egg_info)), + project_name=ei.egg_name + ) + + self.setup_path = self._resolve_setup_path( + self.egg_base, + self.install_dir, + self.egg_path, + ) + + @staticmethod + def _resolve_setup_path(egg_base, install_dir, egg_path): + """ + Generate a path from egg_base back to '.' where the + setup script resides and ensure that path points to the + setup path from $install_dir/$egg_path. + """ + path_to_setup = egg_base.replace(os.sep, '/').rstrip('/') + if path_to_setup != os.curdir: + path_to_setup = '../' * (path_to_setup.count('/') + 1) + resolved = pkg_resources.normalize_path( + os.path.join(install_dir, egg_path, path_to_setup) + ) + if resolved != pkg_resources.normalize_path(os.curdir): + raise DistutilsOptionError( + "Can't get a consistent path to setup script from" + " installation directory", resolved, + pkg_resources.normalize_path(os.curdir)) + return path_to_setup + + def install_for_development(self): + if six.PY3 and getattr(self.distribution, 'use_2to3', False): + # If we run 2to3 we can not do this inplace: + + # Ensure metadata is up-to-date + self.reinitialize_command('build_py', inplace=0) + self.run_command('build_py') + bpy_cmd = self.get_finalized_command("build_py") + build_path = pkg_resources.normalize_path(bpy_cmd.build_lib) + + # Build extensions + self.reinitialize_command('egg_info', egg_base=build_path) + self.run_command('egg_info') + + self.reinitialize_command('build_ext', inplace=0) + self.run_command('build_ext') + + # Fixup egg-link and easy-install.pth + ei_cmd = self.get_finalized_command("egg_info") + self.egg_path = build_path + self.dist.location = build_path + # XXX + self.dist._provider = pkg_resources.PathMetadata( + build_path, ei_cmd.egg_info) + else: + # Without 2to3 inplace works fine: + self.run_command('egg_info') + + # Build extensions in-place + self.reinitialize_command('build_ext', inplace=1) + self.run_command('build_ext') + + self.install_site_py() # ensure that target dir is site-safe + if setuptools.bootstrap_install_from: + self.easy_install(setuptools.bootstrap_install_from) + setuptools.bootstrap_install_from = None + + self.install_namespaces() + + # create an .egg-link in the installation dir, pointing to our egg + log.info("Creating %s (link to %s)", self.egg_link, self.egg_base) + if not self.dry_run: + with open(self.egg_link, "w") as f: + f.write(self.egg_path + "\n" + self.setup_path) + # postprocess the installed distro, fixing up .pth, installing scripts, + # and handling requirements + self.process_distribution(None, self.dist, not self.no_deps) + + def uninstall_link(self): + if os.path.exists(self.egg_link): + log.info("Removing %s (link to %s)", self.egg_link, self.egg_base) + egg_link_file = open(self.egg_link) + contents = [line.rstrip() for line in egg_link_file] + egg_link_file.close() + if contents not in ([self.egg_path], + [self.egg_path, self.setup_path]): + log.warn("Link points to %s: uninstall aborted", contents) + return + if not self.dry_run: + os.unlink(self.egg_link) + if not self.dry_run: + self.update_pth(self.dist) # remove any .pth link to us + if self.distribution.scripts: + # XXX should also check for entry point scripts! + log.warn("Note: you must uninstall or replace scripts manually!") + + def install_egg_scripts(self, dist): + if dist is not self.dist: + # Installing a dependency, so fall back to normal behavior + return easy_install.install_egg_scripts(self, dist) + + # create wrapper scripts in the script dir, pointing to dist.scripts + + # new-style... + self.install_wrapper_scripts(dist) + + # ...and old-style + for script_name in self.distribution.scripts or []: + script_path = os.path.abspath(convert_path(script_name)) + script_name = os.path.basename(script_path) + with io.open(script_path) as strm: + script_text = strm.read() + self.install_script(dist, script_name, script_text, script_path) + + def install_wrapper_scripts(self, dist): + dist = VersionlessRequirement(dist) + return easy_install.install_wrapper_scripts(self, dist) + + +class VersionlessRequirement: + """ + Adapt a pkg_resources.Distribution to simply return the project + name as the 'requirement' so that scripts will work across + multiple versions. + + >>> from pkg_resources import Distribution + >>> dist = Distribution(project_name='foo', version='1.0') + >>> str(dist.as_requirement()) + 'foo==1.0' + >>> adapted_dist = VersionlessRequirement(dist) + >>> str(adapted_dist.as_requirement()) + 'foo' + """ + + def __init__(self, dist): + self.__dist = dist + + def __getattr__(self, name): + return getattr(self.__dist, name) + + def as_requirement(self): + return self.project_name diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/dist_info.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/dist_info.py new file mode 100644 index 0000000..c45258f --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/dist_info.py @@ -0,0 +1,36 @@ +""" +Create a dist_info directory +As defined in the wheel specification +""" + +import os + +from distutils.core import Command +from distutils import log + + +class dist_info(Command): + + description = 'create a .dist-info directory' + + user_options = [ + ('egg-base=', 'e', "directory containing .egg-info directories" + " (default: top of the source tree)"), + ] + + def initialize_options(self): + self.egg_base = None + + def finalize_options(self): + pass + + def run(self): + egg_info = self.get_finalized_command('egg_info') + egg_info.egg_base = self.egg_base + egg_info.finalize_options() + egg_info.run() + dist_info_dir = egg_info.egg_info[:-len('.egg-info')] + '.dist-info' + log.info("creating '{}'".format(os.path.abspath(dist_info_dir))) + + bdist_wheel = self.get_finalized_command('bdist_wheel') + bdist_wheel.egg2dist(egg_info.egg_info, dist_info_dir) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/easy_install.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/easy_install.py new file mode 100644 index 0000000..06c9827 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/easy_install.py @@ -0,0 +1,2342 @@ +#!/usr/bin/env python +""" +Easy Install +------------ + +A tool for doing automatic download/extract/build of distutils-based Python +packages. For detailed documentation, see the accompanying EasyInstall.txt +file, or visit the `EasyInstall home page`__. + +__ https://setuptools.readthedocs.io/en/latest/easy_install.html + +""" + +from glob import glob +from distutils.util import get_platform +from distutils.util import convert_path, subst_vars +from distutils.errors import ( + DistutilsArgError, DistutilsOptionError, + DistutilsError, DistutilsPlatformError, +) +from distutils.command.install import INSTALL_SCHEMES, SCHEME_KEYS +from distutils import log, dir_util +from distutils.command.build_scripts import first_line_re +from distutils.spawn import find_executable +import sys +import os +import zipimport +import shutil +import tempfile +import zipfile +import re +import stat +import random +import textwrap +import warnings +import site +import struct +import contextlib +import subprocess +import shlex +import io + + +from sysconfig import get_config_vars, get_path + +from setuptools import SetuptoolsDeprecationWarning + +from setuptools.extern import six +from setuptools.extern.six.moves import configparser, map + +from setuptools import Command +from setuptools.sandbox import run_setup +from setuptools.py27compat import rmtree_safe +from setuptools.command import setopt +from setuptools.archive_util import unpack_archive +from setuptools.package_index import ( + PackageIndex, parse_requirement_arg, URL_SCHEME, +) +from setuptools.command import bdist_egg, egg_info +from setuptools.wheel import Wheel +from pkg_resources import ( + yield_lines, normalize_path, resource_string, ensure_directory, + get_distribution, find_distributions, Environment, Requirement, + Distribution, PathMetadata, EggMetadata, WorkingSet, DistributionNotFound, + VersionConflict, DEVELOP_DIST, +) +import pkg_resources.py31compat + +__metaclass__ = type + +# Turn on PEP440Warnings +warnings.filterwarnings("default", category=pkg_resources.PEP440Warning) + +__all__ = [ + 'samefile', 'easy_install', 'PthDistributions', 'extract_wininst_cfg', + 'main', 'get_exe_prefixes', +] + + +def is_64bit(): + return struct.calcsize("P") == 8 + + +def samefile(p1, p2): + """ + Determine if two paths reference the same file. + + Augments os.path.samefile to work on Windows and + suppresses errors if the path doesn't exist. + """ + both_exist = os.path.exists(p1) and os.path.exists(p2) + use_samefile = hasattr(os.path, 'samefile') and both_exist + if use_samefile: + return os.path.samefile(p1, p2) + norm_p1 = os.path.normpath(os.path.normcase(p1)) + norm_p2 = os.path.normpath(os.path.normcase(p2)) + return norm_p1 == norm_p2 + + +if six.PY2: + + def _to_bytes(s): + return s + + def isascii(s): + try: + six.text_type(s, 'ascii') + return True + except UnicodeError: + return False +else: + + def _to_bytes(s): + return s.encode('utf8') + + def isascii(s): + try: + s.encode('ascii') + return True + except UnicodeError: + return False + + +_one_liner = lambda text: textwrap.dedent(text).strip().replace('\n', '; ') + + +class easy_install(Command): + """Manage a download/build/install process""" + description = "Find/get/install Python packages" + command_consumes_arguments = True + + user_options = [ + ('prefix=', None, "installation prefix"), + ("zip-ok", "z", "install package as a zipfile"), + ("multi-version", "m", "make apps have to require() a version"), + ("upgrade", "U", "force upgrade (searches PyPI for latest versions)"), + ("install-dir=", "d", "install package to DIR"), + ("script-dir=", "s", "install scripts to DIR"), + ("exclude-scripts", "x", "Don't install scripts"), + ("always-copy", "a", "Copy all needed packages to install dir"), + ("index-url=", "i", "base URL of Python Package Index"), + ("find-links=", "f", "additional URL(s) to search for packages"), + ("build-directory=", "b", + "download/extract/build in DIR; keep the results"), + ('optimize=', 'O', + "also compile with optimization: -O1 for \"python -O\", " + "-O2 for \"python -OO\", and -O0 to disable [default: -O0]"), + ('record=', None, + "filename in which to record list of installed files"), + ('always-unzip', 'Z', "don't install as a zipfile, no matter what"), + ('site-dirs=', 'S', "list of directories where .pth files work"), + ('editable', 'e', "Install specified packages in editable form"), + ('no-deps', 'N', "don't install dependencies"), + ('allow-hosts=', 'H', "pattern(s) that hostnames must match"), + ('local-snapshots-ok', 'l', + "allow building eggs from local checkouts"), + ('version', None, "print version information and exit"), + ('no-find-links', None, + "Don't load find-links defined in packages being installed") + ] + boolean_options = [ + 'zip-ok', 'multi-version', 'exclude-scripts', 'upgrade', 'always-copy', + 'editable', + 'no-deps', 'local-snapshots-ok', 'version' + ] + + if site.ENABLE_USER_SITE: + help_msg = "install in user site-package '%s'" % site.USER_SITE + user_options.append(('user', None, help_msg)) + boolean_options.append('user') + + negative_opt = {'always-unzip': 'zip-ok'} + create_index = PackageIndex + + def initialize_options(self): + # the --user option seems to be an opt-in one, + # so the default should be False. + self.user = 0 + self.zip_ok = self.local_snapshots_ok = None + self.install_dir = self.script_dir = self.exclude_scripts = None + self.index_url = None + self.find_links = None + self.build_directory = None + self.args = None + self.optimize = self.record = None + self.upgrade = self.always_copy = self.multi_version = None + self.editable = self.no_deps = self.allow_hosts = None + self.root = self.prefix = self.no_report = None + self.version = None + self.install_purelib = None # for pure module distributions + self.install_platlib = None # non-pure (dists w/ extensions) + self.install_headers = None # for C/C++ headers + self.install_lib = None # set to either purelib or platlib + self.install_scripts = None + self.install_data = None + self.install_base = None + self.install_platbase = None + if site.ENABLE_USER_SITE: + self.install_userbase = site.USER_BASE + self.install_usersite = site.USER_SITE + else: + self.install_userbase = None + self.install_usersite = None + self.no_find_links = None + + # Options not specifiable via command line + self.package_index = None + self.pth_file = self.always_copy_from = None + self.site_dirs = None + self.installed_projects = {} + self.sitepy_installed = False + # Always read easy_install options, even if we are subclassed, or have + # an independent instance created. This ensures that defaults will + # always come from the standard configuration file(s)' "easy_install" + # section, even if this is a "develop" or "install" command, or some + # other embedding. + self._dry_run = None + self.verbose = self.distribution.verbose + self.distribution._set_command_options( + self, self.distribution.get_option_dict('easy_install') + ) + + def delete_blockers(self, blockers): + extant_blockers = ( + filename for filename in blockers + if os.path.exists(filename) or os.path.islink(filename) + ) + list(map(self._delete_path, extant_blockers)) + + def _delete_path(self, path): + log.info("Deleting %s", path) + if self.dry_run: + return + + is_tree = os.path.isdir(path) and not os.path.islink(path) + remover = rmtree if is_tree else os.unlink + remover(path) + + @staticmethod + def _render_version(): + """ + Render the Setuptools version and installation details, then exit. + """ + ver = sys.version[:3] + dist = get_distribution('setuptools') + tmpl = 'setuptools {dist.version} from {dist.location} (Python {ver})' + print(tmpl.format(**locals())) + raise SystemExit() + + def finalize_options(self): + self.version and self._render_version() + + py_version = sys.version.split()[0] + prefix, exec_prefix = get_config_vars('prefix', 'exec_prefix') + + self.config_vars = { + 'dist_name': self.distribution.get_name(), + 'dist_version': self.distribution.get_version(), + 'dist_fullname': self.distribution.get_fullname(), + 'py_version': py_version, + 'py_version_short': py_version[0:3], + 'py_version_nodot': py_version[0] + py_version[2], + 'sys_prefix': prefix, + 'prefix': prefix, + 'sys_exec_prefix': exec_prefix, + 'exec_prefix': exec_prefix, + # Only python 3.2+ has abiflags + 'abiflags': getattr(sys, 'abiflags', ''), + } + + if site.ENABLE_USER_SITE: + self.config_vars['userbase'] = self.install_userbase + self.config_vars['usersite'] = self.install_usersite + + self._fix_install_dir_for_user_site() + + self.expand_basedirs() + self.expand_dirs() + + self._expand( + 'install_dir', 'script_dir', 'build_directory', + 'site_dirs', + ) + # If a non-default installation directory was specified, default the + # script directory to match it. + if self.script_dir is None: + self.script_dir = self.install_dir + + if self.no_find_links is None: + self.no_find_links = False + + # Let install_dir get set by install_lib command, which in turn + # gets its info from the install command, and takes into account + # --prefix and --home and all that other crud. + self.set_undefined_options( + 'install_lib', ('install_dir', 'install_dir') + ) + # Likewise, set default script_dir from 'install_scripts.install_dir' + self.set_undefined_options( + 'install_scripts', ('install_dir', 'script_dir') + ) + + if self.user and self.install_purelib: + self.install_dir = self.install_purelib + self.script_dir = self.install_scripts + # default --record from the install command + self.set_undefined_options('install', ('record', 'record')) + # Should this be moved to the if statement below? It's not used + # elsewhere + normpath = map(normalize_path, sys.path) + self.all_site_dirs = get_site_dirs() + if self.site_dirs is not None: + site_dirs = [ + os.path.expanduser(s.strip()) for s in + self.site_dirs.split(',') + ] + for d in site_dirs: + if not os.path.isdir(d): + log.warn("%s (in --site-dirs) does not exist", d) + elif normalize_path(d) not in normpath: + raise DistutilsOptionError( + d + " (in --site-dirs) is not on sys.path" + ) + else: + self.all_site_dirs.append(normalize_path(d)) + if not self.editable: + self.check_site_dir() + self.index_url = self.index_url or "https://pypi.org/simple/" + self.shadow_path = self.all_site_dirs[:] + for path_item in self.install_dir, normalize_path(self.script_dir): + if path_item not in self.shadow_path: + self.shadow_path.insert(0, path_item) + + if self.allow_hosts is not None: + hosts = [s.strip() for s in self.allow_hosts.split(',')] + else: + hosts = ['*'] + if self.package_index is None: + self.package_index = self.create_index( + self.index_url, search_path=self.shadow_path, hosts=hosts, + ) + self.local_index = Environment(self.shadow_path + sys.path) + + if self.find_links is not None: + if isinstance(self.find_links, six.string_types): + self.find_links = self.find_links.split() + else: + self.find_links = [] + if self.local_snapshots_ok: + self.package_index.scan_egg_links(self.shadow_path + sys.path) + if not self.no_find_links: + self.package_index.add_find_links(self.find_links) + self.set_undefined_options('install_lib', ('optimize', 'optimize')) + if not isinstance(self.optimize, int): + try: + self.optimize = int(self.optimize) + if not (0 <= self.optimize <= 2): + raise ValueError + except ValueError: + raise DistutilsOptionError("--optimize must be 0, 1, or 2") + + if self.editable and not self.build_directory: + raise DistutilsArgError( + "Must specify a build directory (-b) when using --editable" + ) + if not self.args: + raise DistutilsArgError( + "No urls, filenames, or requirements specified (see --help)") + + self.outputs = [] + + def _fix_install_dir_for_user_site(self): + """ + Fix the install_dir if "--user" was used. + """ + if not self.user or not site.ENABLE_USER_SITE: + return + + self.create_home_path() + if self.install_userbase is None: + msg = "User base directory is not specified" + raise DistutilsPlatformError(msg) + self.install_base = self.install_platbase = self.install_userbase + scheme_name = os.name.replace('posix', 'unix') + '_user' + self.select_scheme(scheme_name) + + def _expand_attrs(self, attrs): + for attr in attrs: + val = getattr(self, attr) + if val is not None: + if os.name == 'posix' or os.name == 'nt': + val = os.path.expanduser(val) + val = subst_vars(val, self.config_vars) + setattr(self, attr, val) + + def expand_basedirs(self): + """Calls `os.path.expanduser` on install_base, install_platbase and + root.""" + self._expand_attrs(['install_base', 'install_platbase', 'root']) + + def expand_dirs(self): + """Calls `os.path.expanduser` on install dirs.""" + dirs = [ + 'install_purelib', + 'install_platlib', + 'install_lib', + 'install_headers', + 'install_scripts', + 'install_data', + ] + self._expand_attrs(dirs) + + def run(self): + if self.verbose != self.distribution.verbose: + log.set_verbosity(self.verbose) + try: + for spec in self.args: + self.easy_install(spec, not self.no_deps) + if self.record: + outputs = self.outputs + if self.root: # strip any package prefix + root_len = len(self.root) + for counter in range(len(outputs)): + outputs[counter] = outputs[counter][root_len:] + from distutils import file_util + + self.execute( + file_util.write_file, (self.record, outputs), + "writing list of installed files to '%s'" % + self.record + ) + self.warn_deprecated_options() + finally: + log.set_verbosity(self.distribution.verbose) + + def pseudo_tempname(self): + """Return a pseudo-tempname base in the install directory. + This code is intentionally naive; if a malicious party can write to + the target directory you're already in deep doodoo. + """ + try: + pid = os.getpid() + except Exception: + pid = random.randint(0, sys.maxsize) + return os.path.join(self.install_dir, "test-easy-install-%s" % pid) + + def warn_deprecated_options(self): + pass + + def check_site_dir(self): + """Verify that self.install_dir is .pth-capable dir, if needed""" + + instdir = normalize_path(self.install_dir) + pth_file = os.path.join(instdir, 'easy-install.pth') + + # Is it a configured, PYTHONPATH, implicit, or explicit site dir? + is_site_dir = instdir in self.all_site_dirs + + if not is_site_dir and not self.multi_version: + # No? Then directly test whether it does .pth file processing + is_site_dir = self.check_pth_processing() + else: + # make sure we can write to target dir + testfile = self.pseudo_tempname() + '.write-test' + test_exists = os.path.exists(testfile) + try: + if test_exists: + os.unlink(testfile) + open(testfile, 'w').close() + os.unlink(testfile) + except (OSError, IOError): + self.cant_write_to_target() + + if not is_site_dir and not self.multi_version: + # Can't install non-multi to non-site dir + raise DistutilsError(self.no_default_version_msg()) + + if is_site_dir: + if self.pth_file is None: + self.pth_file = PthDistributions(pth_file, self.all_site_dirs) + else: + self.pth_file = None + + if instdir not in map(normalize_path, _pythonpath()): + # only PYTHONPATH dirs need a site.py, so pretend it's there + self.sitepy_installed = True + elif self.multi_version and not os.path.exists(pth_file): + self.sitepy_installed = True # don't need site.py in this case + self.pth_file = None # and don't create a .pth file + self.install_dir = instdir + + __cant_write_msg = textwrap.dedent(""" + can't create or remove files in install directory + + The following error occurred while trying to add or remove files in the + installation directory: + + %s + + The installation directory you specified (via --install-dir, --prefix, or + the distutils default setting) was: + + %s + """).lstrip() + + __not_exists_id = textwrap.dedent(""" + This directory does not currently exist. Please create it and try again, or + choose a different installation directory (using the -d or --install-dir + option). + """).lstrip() + + __access_msg = textwrap.dedent(""" + Perhaps your account does not have write access to this directory? If the + installation directory is a system-owned directory, you may need to sign in + as the administrator or "root" account. If you do not have administrative + access to this machine, you may wish to choose a different installation + directory, preferably one that is listed in your PYTHONPATH environment + variable. + + For information on other options, you may wish to consult the + documentation at: + + https://setuptools.readthedocs.io/en/latest/easy_install.html + + Please make the appropriate changes for your system and try again. + """).lstrip() + + def cant_write_to_target(self): + msg = self.__cant_write_msg % (sys.exc_info()[1], self.install_dir,) + + if not os.path.exists(self.install_dir): + msg += '\n' + self.__not_exists_id + else: + msg += '\n' + self.__access_msg + raise DistutilsError(msg) + + def check_pth_processing(self): + """Empirically verify whether .pth files are supported in inst. dir""" + instdir = self.install_dir + log.info("Checking .pth file support in %s", instdir) + pth_file = self.pseudo_tempname() + ".pth" + ok_file = pth_file + '.ok' + ok_exists = os.path.exists(ok_file) + tmpl = _one_liner(""" + import os + f = open({ok_file!r}, 'w') + f.write('OK') + f.close() + """) + '\n' + try: + if ok_exists: + os.unlink(ok_file) + dirname = os.path.dirname(ok_file) + pkg_resources.py31compat.makedirs(dirname, exist_ok=True) + f = open(pth_file, 'w') + except (OSError, IOError): + self.cant_write_to_target() + else: + try: + f.write(tmpl.format(**locals())) + f.close() + f = None + executable = sys.executable + if os.name == 'nt': + dirname, basename = os.path.split(executable) + alt = os.path.join(dirname, 'pythonw.exe') + use_alt = ( + basename.lower() == 'python.exe' and + os.path.exists(alt) + ) + if use_alt: + # use pythonw.exe to avoid opening a console window + executable = alt + + from distutils.spawn import spawn + + spawn([executable, '-E', '-c', 'pass'], 0) + + if os.path.exists(ok_file): + log.info( + "TEST PASSED: %s appears to support .pth files", + instdir + ) + return True + finally: + if f: + f.close() + if os.path.exists(ok_file): + os.unlink(ok_file) + if os.path.exists(pth_file): + os.unlink(pth_file) + if not self.multi_version: + log.warn("TEST FAILED: %s does NOT support .pth files", instdir) + return False + + def install_egg_scripts(self, dist): + """Write all the scripts for `dist`, unless scripts are excluded""" + if not self.exclude_scripts and dist.metadata_isdir('scripts'): + for script_name in dist.metadata_listdir('scripts'): + if dist.metadata_isdir('scripts/' + script_name): + # The "script" is a directory, likely a Python 3 + # __pycache__ directory, so skip it. + continue + self.install_script( + dist, script_name, + dist.get_metadata('scripts/' + script_name) + ) + self.install_wrapper_scripts(dist) + + def add_output(self, path): + if os.path.isdir(path): + for base, dirs, files in os.walk(path): + for filename in files: + self.outputs.append(os.path.join(base, filename)) + else: + self.outputs.append(path) + + def not_editable(self, spec): + if self.editable: + raise DistutilsArgError( + "Invalid argument %r: you can't use filenames or URLs " + "with --editable (except via the --find-links option)." + % (spec,) + ) + + def check_editable(self, spec): + if not self.editable: + return + + if os.path.exists(os.path.join(self.build_directory, spec.key)): + raise DistutilsArgError( + "%r already exists in %s; can't do a checkout there" % + (spec.key, self.build_directory) + ) + + @contextlib.contextmanager + def _tmpdir(self): + tmpdir = tempfile.mkdtemp(prefix=u"easy_install-") + try: + # cast to str as workaround for #709 and #710 and #712 + yield str(tmpdir) + finally: + os.path.exists(tmpdir) and rmtree(rmtree_safe(tmpdir)) + + def easy_install(self, spec, deps=False): + if not self.editable: + self.install_site_py() + + with self._tmpdir() as tmpdir: + if not isinstance(spec, Requirement): + if URL_SCHEME(spec): + # It's a url, download it to tmpdir and process + self.not_editable(spec) + dl = self.package_index.download(spec, tmpdir) + return self.install_item(None, dl, tmpdir, deps, True) + + elif os.path.exists(spec): + # Existing file or directory, just process it directly + self.not_editable(spec) + return self.install_item(None, spec, tmpdir, deps, True) + else: + spec = parse_requirement_arg(spec) + + self.check_editable(spec) + dist = self.package_index.fetch_distribution( + spec, tmpdir, self.upgrade, self.editable, + not self.always_copy, self.local_index + ) + if dist is None: + msg = "Could not find suitable distribution for %r" % spec + if self.always_copy: + msg += " (--always-copy skips system and development eggs)" + raise DistutilsError(msg) + elif dist.precedence == DEVELOP_DIST: + # .egg-info dists don't need installing, just process deps + self.process_distribution(spec, dist, deps, "Using") + return dist + else: + return self.install_item(spec, dist.location, tmpdir, deps) + + def install_item(self, spec, download, tmpdir, deps, install_needed=False): + + # Installation is also needed if file in tmpdir or is not an egg + install_needed = install_needed or self.always_copy + install_needed = install_needed or os.path.dirname(download) == tmpdir + install_needed = install_needed or not download.endswith('.egg') + install_needed = install_needed or ( + self.always_copy_from is not None and + os.path.dirname(normalize_path(download)) == + normalize_path(self.always_copy_from) + ) + + if spec and not install_needed: + # at this point, we know it's a local .egg, we just don't know if + # it's already installed. + for dist in self.local_index[spec.project_name]: + if dist.location == download: + break + else: + install_needed = True # it's not in the local index + + log.info("Processing %s", os.path.basename(download)) + + if install_needed: + dists = self.install_eggs(spec, download, tmpdir) + for dist in dists: + self.process_distribution(spec, dist, deps) + else: + dists = [self.egg_distribution(download)] + self.process_distribution(spec, dists[0], deps, "Using") + + if spec is not None: + for dist in dists: + if dist in spec: + return dist + + def select_scheme(self, name): + """Sets the install directories by applying the install schemes.""" + # it's the caller's problem if they supply a bad name! + scheme = INSTALL_SCHEMES[name] + for key in SCHEME_KEYS: + attrname = 'install_' + key + if getattr(self, attrname) is None: + setattr(self, attrname, scheme[key]) + + def process_distribution(self, requirement, dist, deps=True, *info): + self.update_pth(dist) + self.package_index.add(dist) + if dist in self.local_index[dist.key]: + self.local_index.remove(dist) + self.local_index.add(dist) + self.install_egg_scripts(dist) + self.installed_projects[dist.key] = dist + log.info(self.installation_report(requirement, dist, *info)) + if (dist.has_metadata('dependency_links.txt') and + not self.no_find_links): + self.package_index.add_find_links( + dist.get_metadata_lines('dependency_links.txt') + ) + if not deps and not self.always_copy: + return + elif requirement is not None and dist.key != requirement.key: + log.warn("Skipping dependencies for %s", dist) + return # XXX this is not the distribution we were looking for + elif requirement is None or dist not in requirement: + # if we wound up with a different version, resolve what we've got + distreq = dist.as_requirement() + requirement = Requirement(str(distreq)) + log.info("Processing dependencies for %s", requirement) + try: + distros = WorkingSet([]).resolve( + [requirement], self.local_index, self.easy_install + ) + except DistributionNotFound as e: + raise DistutilsError(str(e)) + except VersionConflict as e: + raise DistutilsError(e.report()) + if self.always_copy or self.always_copy_from: + # Force all the relevant distros to be copied or activated + for dist in distros: + if dist.key not in self.installed_projects: + self.easy_install(dist.as_requirement()) + log.info("Finished processing dependencies for %s", requirement) + + def should_unzip(self, dist): + if self.zip_ok is not None: + return not self.zip_ok + if dist.has_metadata('not-zip-safe'): + return True + if not dist.has_metadata('zip-safe'): + return True + return False + + def maybe_move(self, spec, dist_filename, setup_base): + dst = os.path.join(self.build_directory, spec.key) + if os.path.exists(dst): + msg = ( + "%r already exists in %s; build directory %s will not be kept" + ) + log.warn(msg, spec.key, self.build_directory, setup_base) + return setup_base + if os.path.isdir(dist_filename): + setup_base = dist_filename + else: + if os.path.dirname(dist_filename) == setup_base: + os.unlink(dist_filename) # get it out of the tmp dir + contents = os.listdir(setup_base) + if len(contents) == 1: + dist_filename = os.path.join(setup_base, contents[0]) + if os.path.isdir(dist_filename): + # if the only thing there is a directory, move it instead + setup_base = dist_filename + ensure_directory(dst) + shutil.move(setup_base, dst) + return dst + + def install_wrapper_scripts(self, dist): + if self.exclude_scripts: + return + for args in ScriptWriter.best().get_args(dist): + self.write_script(*args) + + def install_script(self, dist, script_name, script_text, dev_path=None): + """Generate a legacy script wrapper and install it""" + spec = str(dist.as_requirement()) + is_script = is_python_script(script_text, script_name) + + if is_script: + body = self._load_template(dev_path) % locals() + script_text = ScriptWriter.get_header(script_text) + body + self.write_script(script_name, _to_bytes(script_text), 'b') + + @staticmethod + def _load_template(dev_path): + """ + There are a couple of template scripts in the package. This + function loads one of them and prepares it for use. + """ + # See https://github.com/pypa/setuptools/issues/134 for info + # on script file naming and downstream issues with SVR4 + name = 'script.tmpl' + if dev_path: + name = name.replace('.tmpl', ' (dev).tmpl') + + raw_bytes = resource_string('setuptools', name) + return raw_bytes.decode('utf-8') + + def write_script(self, script_name, contents, mode="t", blockers=()): + """Write an executable file to the scripts directory""" + self.delete_blockers( # clean up old .py/.pyw w/o a script + [os.path.join(self.script_dir, x) for x in blockers] + ) + log.info("Installing %s script to %s", script_name, self.script_dir) + target = os.path.join(self.script_dir, script_name) + self.add_output(target) + + if self.dry_run: + return + + mask = current_umask() + ensure_directory(target) + if os.path.exists(target): + os.unlink(target) + with open(target, "w" + mode) as f: + f.write(contents) + chmod(target, 0o777 - mask) + + def install_eggs(self, spec, dist_filename, tmpdir): + # .egg dirs or files are already built, so just return them + if dist_filename.lower().endswith('.egg'): + return [self.install_egg(dist_filename, tmpdir)] + elif dist_filename.lower().endswith('.exe'): + return [self.install_exe(dist_filename, tmpdir)] + elif dist_filename.lower().endswith('.whl'): + return [self.install_wheel(dist_filename, tmpdir)] + + # Anything else, try to extract and build + setup_base = tmpdir + if os.path.isfile(dist_filename) and not dist_filename.endswith('.py'): + unpack_archive(dist_filename, tmpdir, self.unpack_progress) + elif os.path.isdir(dist_filename): + setup_base = os.path.abspath(dist_filename) + + if (setup_base.startswith(tmpdir) # something we downloaded + and self.build_directory and spec is not None): + setup_base = self.maybe_move(spec, dist_filename, setup_base) + + # Find the setup.py file + setup_script = os.path.join(setup_base, 'setup.py') + + if not os.path.exists(setup_script): + setups = glob(os.path.join(setup_base, '*', 'setup.py')) + if not setups: + raise DistutilsError( + "Couldn't find a setup script in %s" % + os.path.abspath(dist_filename) + ) + if len(setups) > 1: + raise DistutilsError( + "Multiple setup scripts in %s" % + os.path.abspath(dist_filename) + ) + setup_script = setups[0] + + # Now run it, and return the result + if self.editable: + log.info(self.report_editable(spec, setup_script)) + return [] + else: + return self.build_and_install(setup_script, setup_base) + + def egg_distribution(self, egg_path): + if os.path.isdir(egg_path): + metadata = PathMetadata(egg_path, os.path.join(egg_path, + 'EGG-INFO')) + else: + metadata = EggMetadata(zipimport.zipimporter(egg_path)) + return Distribution.from_filename(egg_path, metadata=metadata) + + def install_egg(self, egg_path, tmpdir): + destination = os.path.join( + self.install_dir, + os.path.basename(egg_path), + ) + destination = os.path.abspath(destination) + if not self.dry_run: + ensure_directory(destination) + + dist = self.egg_distribution(egg_path) + if not samefile(egg_path, destination): + if os.path.isdir(destination) and not os.path.islink(destination): + dir_util.remove_tree(destination, dry_run=self.dry_run) + elif os.path.exists(destination): + self.execute( + os.unlink, + (destination,), + "Removing " + destination, + ) + try: + new_dist_is_zipped = False + if os.path.isdir(egg_path): + if egg_path.startswith(tmpdir): + f, m = shutil.move, "Moving" + else: + f, m = shutil.copytree, "Copying" + elif self.should_unzip(dist): + self.mkpath(destination) + f, m = self.unpack_and_compile, "Extracting" + else: + new_dist_is_zipped = True + if egg_path.startswith(tmpdir): + f, m = shutil.move, "Moving" + else: + f, m = shutil.copy2, "Copying" + self.execute( + f, + (egg_path, destination), + (m + " %s to %s") % ( + os.path.basename(egg_path), + os.path.dirname(destination) + ), + ) + update_dist_caches( + destination, + fix_zipimporter_caches=new_dist_is_zipped, + ) + except Exception: + update_dist_caches(destination, fix_zipimporter_caches=False) + raise + + self.add_output(destination) + return self.egg_distribution(destination) + + def install_exe(self, dist_filename, tmpdir): + # See if it's valid, get data + cfg = extract_wininst_cfg(dist_filename) + if cfg is None: + raise DistutilsError( + "%s is not a valid distutils Windows .exe" % dist_filename + ) + # Create a dummy distribution object until we build the real distro + dist = Distribution( + None, + project_name=cfg.get('metadata', 'name'), + version=cfg.get('metadata', 'version'), platform=get_platform(), + ) + + # Convert the .exe to an unpacked egg + egg_path = os.path.join(tmpdir, dist.egg_name() + '.egg') + dist.location = egg_path + egg_tmp = egg_path + '.tmp' + _egg_info = os.path.join(egg_tmp, 'EGG-INFO') + pkg_inf = os.path.join(_egg_info, 'PKG-INFO') + ensure_directory(pkg_inf) # make sure EGG-INFO dir exists + dist._provider = PathMetadata(egg_tmp, _egg_info) # XXX + self.exe_to_egg(dist_filename, egg_tmp) + + # Write EGG-INFO/PKG-INFO + if not os.path.exists(pkg_inf): + f = open(pkg_inf, 'w') + f.write('Metadata-Version: 1.0\n') + for k, v in cfg.items('metadata'): + if k != 'target_version': + f.write('%s: %s\n' % (k.replace('_', '-').title(), v)) + f.close() + script_dir = os.path.join(_egg_info, 'scripts') + # delete entry-point scripts to avoid duping + self.delete_blockers([ + os.path.join(script_dir, args[0]) + for args in ScriptWriter.get_args(dist) + ]) + # Build .egg file from tmpdir + bdist_egg.make_zipfile( + egg_path, egg_tmp, verbose=self.verbose, dry_run=self.dry_run, + ) + # install the .egg + return self.install_egg(egg_path, tmpdir) + + def exe_to_egg(self, dist_filename, egg_tmp): + """Extract a bdist_wininst to the directories an egg would use""" + # Check for .pth file and set up prefix translations + prefixes = get_exe_prefixes(dist_filename) + to_compile = [] + native_libs = [] + top_level = {} + + def process(src, dst): + s = src.lower() + for old, new in prefixes: + if s.startswith(old): + src = new + src[len(old):] + parts = src.split('/') + dst = os.path.join(egg_tmp, *parts) + dl = dst.lower() + if dl.endswith('.pyd') or dl.endswith('.dll'): + parts[-1] = bdist_egg.strip_module(parts[-1]) + top_level[os.path.splitext(parts[0])[0]] = 1 + native_libs.append(src) + elif dl.endswith('.py') and old != 'SCRIPTS/': + top_level[os.path.splitext(parts[0])[0]] = 1 + to_compile.append(dst) + return dst + if not src.endswith('.pth'): + log.warn("WARNING: can't process %s", src) + return None + + # extract, tracking .pyd/.dll->native_libs and .py -> to_compile + unpack_archive(dist_filename, egg_tmp, process) + stubs = [] + for res in native_libs: + if res.lower().endswith('.pyd'): # create stubs for .pyd's + parts = res.split('/') + resource = parts[-1] + parts[-1] = bdist_egg.strip_module(parts[-1]) + '.py' + pyfile = os.path.join(egg_tmp, *parts) + to_compile.append(pyfile) + stubs.append(pyfile) + bdist_egg.write_stub(resource, pyfile) + self.byte_compile(to_compile) # compile .py's + bdist_egg.write_safety_flag( + os.path.join(egg_tmp, 'EGG-INFO'), + bdist_egg.analyze_egg(egg_tmp, stubs)) # write zip-safety flag + + for name in 'top_level', 'native_libs': + if locals()[name]: + txt = os.path.join(egg_tmp, 'EGG-INFO', name + '.txt') + if not os.path.exists(txt): + f = open(txt, 'w') + f.write('\n'.join(locals()[name]) + '\n') + f.close() + + def install_wheel(self, wheel_path, tmpdir): + wheel = Wheel(wheel_path) + assert wheel.is_compatible() + destination = os.path.join(self.install_dir, wheel.egg_name()) + destination = os.path.abspath(destination) + if not self.dry_run: + ensure_directory(destination) + if os.path.isdir(destination) and not os.path.islink(destination): + dir_util.remove_tree(destination, dry_run=self.dry_run) + elif os.path.exists(destination): + self.execute( + os.unlink, + (destination,), + "Removing " + destination, + ) + try: + self.execute( + wheel.install_as_egg, + (destination,), + ("Installing %s to %s") % ( + os.path.basename(wheel_path), + os.path.dirname(destination) + ), + ) + finally: + update_dist_caches(destination, fix_zipimporter_caches=False) + self.add_output(destination) + return self.egg_distribution(destination) + + __mv_warning = textwrap.dedent(""" + Because this distribution was installed --multi-version, before you can + import modules from this package in an application, you will need to + 'import pkg_resources' and then use a 'require()' call similar to one of + these examples, in order to select the desired version: + + pkg_resources.require("%(name)s") # latest installed version + pkg_resources.require("%(name)s==%(version)s") # this exact version + pkg_resources.require("%(name)s>=%(version)s") # this version or higher + """).lstrip() + + __id_warning = textwrap.dedent(""" + Note also that the installation directory must be on sys.path at runtime for + this to work. (e.g. by being the application's script directory, by being on + PYTHONPATH, or by being added to sys.path by your code.) + """) + + def installation_report(self, req, dist, what="Installed"): + """Helpful installation message for display to package users""" + msg = "\n%(what)s %(eggloc)s%(extras)s" + if self.multi_version and not self.no_report: + msg += '\n' + self.__mv_warning + if self.install_dir not in map(normalize_path, sys.path): + msg += '\n' + self.__id_warning + + eggloc = dist.location + name = dist.project_name + version = dist.version + extras = '' # TODO: self.report_extras(req, dist) + return msg % locals() + + __editable_msg = textwrap.dedent(""" + Extracted editable version of %(spec)s to %(dirname)s + + If it uses setuptools in its setup script, you can activate it in + "development" mode by going to that directory and running:: + + %(python)s setup.py develop + + See the setuptools documentation for the "develop" command for more info. + """).lstrip() + + def report_editable(self, spec, setup_script): + dirname = os.path.dirname(setup_script) + python = sys.executable + return '\n' + self.__editable_msg % locals() + + def run_setup(self, setup_script, setup_base, args): + sys.modules.setdefault('distutils.command.bdist_egg', bdist_egg) + sys.modules.setdefault('distutils.command.egg_info', egg_info) + + args = list(args) + if self.verbose > 2: + v = 'v' * (self.verbose - 1) + args.insert(0, '-' + v) + elif self.verbose < 2: + args.insert(0, '-q') + if self.dry_run: + args.insert(0, '-n') + log.info( + "Running %s %s", setup_script[len(setup_base) + 1:], ' '.join(args) + ) + try: + run_setup(setup_script, args) + except SystemExit as v: + raise DistutilsError("Setup script exited with %s" % (v.args[0],)) + + def build_and_install(self, setup_script, setup_base): + args = ['bdist_egg', '--dist-dir'] + + dist_dir = tempfile.mkdtemp( + prefix='egg-dist-tmp-', dir=os.path.dirname(setup_script) + ) + try: + self._set_fetcher_options(os.path.dirname(setup_script)) + args.append(dist_dir) + + self.run_setup(setup_script, setup_base, args) + all_eggs = Environment([dist_dir]) + eggs = [] + for key in all_eggs: + for dist in all_eggs[key]: + eggs.append(self.install_egg(dist.location, setup_base)) + if not eggs and not self.dry_run: + log.warn("No eggs found in %s (setup script problem?)", + dist_dir) + return eggs + finally: + rmtree(dist_dir) + log.set_verbosity(self.verbose) # restore our log verbosity + + def _set_fetcher_options(self, base): + """ + When easy_install is about to run bdist_egg on a source dist, that + source dist might have 'setup_requires' directives, requiring + additional fetching. Ensure the fetcher options given to easy_install + are available to that command as well. + """ + # find the fetch options from easy_install and write them out + # to the setup.cfg file. + ei_opts = self.distribution.get_option_dict('easy_install').copy() + fetch_directives = ( + 'find_links', 'site_dirs', 'index_url', 'optimize', + 'site_dirs', 'allow_hosts', + ) + fetch_options = {} + for key, val in ei_opts.items(): + if key not in fetch_directives: + continue + fetch_options[key.replace('_', '-')] = val[1] + # create a settings dictionary suitable for `edit_config` + settings = dict(easy_install=fetch_options) + cfg_filename = os.path.join(base, 'setup.cfg') + setopt.edit_config(cfg_filename, settings) + + def update_pth(self, dist): + if self.pth_file is None: + return + + for d in self.pth_file[dist.key]: # drop old entries + if self.multi_version or d.location != dist.location: + log.info("Removing %s from easy-install.pth file", d) + self.pth_file.remove(d) + if d.location in self.shadow_path: + self.shadow_path.remove(d.location) + + if not self.multi_version: + if dist.location in self.pth_file.paths: + log.info( + "%s is already the active version in easy-install.pth", + dist, + ) + else: + log.info("Adding %s to easy-install.pth file", dist) + self.pth_file.add(dist) # add new entry + if dist.location not in self.shadow_path: + self.shadow_path.append(dist.location) + + if not self.dry_run: + + self.pth_file.save() + + if dist.key == 'setuptools': + # Ensure that setuptools itself never becomes unavailable! + # XXX should this check for latest version? + filename = os.path.join(self.install_dir, 'setuptools.pth') + if os.path.islink(filename): + os.unlink(filename) + f = open(filename, 'wt') + f.write(self.pth_file.make_relative(dist.location) + '\n') + f.close() + + def unpack_progress(self, src, dst): + # Progress filter for unpacking + log.debug("Unpacking %s to %s", src, dst) + return dst # only unpack-and-compile skips files for dry run + + def unpack_and_compile(self, egg_path, destination): + to_compile = [] + to_chmod = [] + + def pf(src, dst): + if dst.endswith('.py') and not src.startswith('EGG-INFO/'): + to_compile.append(dst) + elif dst.endswith('.dll') or dst.endswith('.so'): + to_chmod.append(dst) + self.unpack_progress(src, dst) + return not self.dry_run and dst or None + + unpack_archive(egg_path, destination, pf) + self.byte_compile(to_compile) + if not self.dry_run: + for f in to_chmod: + mode = ((os.stat(f)[stat.ST_MODE]) | 0o555) & 0o7755 + chmod(f, mode) + + def byte_compile(self, to_compile): + if sys.dont_write_bytecode: + return + + from distutils.util import byte_compile + + try: + # try to make the byte compile messages quieter + log.set_verbosity(self.verbose - 1) + + byte_compile(to_compile, optimize=0, force=1, dry_run=self.dry_run) + if self.optimize: + byte_compile( + to_compile, optimize=self.optimize, force=1, + dry_run=self.dry_run, + ) + finally: + log.set_verbosity(self.verbose) # restore original verbosity + + __no_default_msg = textwrap.dedent(""" + bad install directory or PYTHONPATH + + You are attempting to install a package to a directory that is not + on PYTHONPATH and which Python does not read ".pth" files from. The + installation directory you specified (via --install-dir, --prefix, or + the distutils default setting) was: + + %s + + and your PYTHONPATH environment variable currently contains: + + %r + + Here are some of your options for correcting the problem: + + * You can choose a different installation directory, i.e., one that is + on PYTHONPATH or supports .pth files + + * You can add the installation directory to the PYTHONPATH environment + variable. (It must then also be on PYTHONPATH whenever you run + Python and want to use the package(s) you are installing.) + + * You can set up the installation directory to support ".pth" files by + using one of the approaches described here: + + https://setuptools.readthedocs.io/en/latest/easy_install.html#custom-installation-locations + + + Please make the appropriate changes for your system and try again.""").lstrip() + + def no_default_version_msg(self): + template = self.__no_default_msg + return template % (self.install_dir, os.environ.get('PYTHONPATH', '')) + + def install_site_py(self): + """Make sure there's a site.py in the target dir, if needed""" + + if self.sitepy_installed: + return # already did it, or don't need to + + sitepy = os.path.join(self.install_dir, "site.py") + source = resource_string("setuptools", "site-patch.py") + source = source.decode('utf-8') + current = "" + + if os.path.exists(sitepy): + log.debug("Checking existing site.py in %s", self.install_dir) + with io.open(sitepy) as strm: + current = strm.read() + + if not current.startswith('def __boot():'): + raise DistutilsError( + "%s is not a setuptools-generated site.py; please" + " remove it." % sitepy + ) + + if current != source: + log.info("Creating %s", sitepy) + if not self.dry_run: + ensure_directory(sitepy) + with io.open(sitepy, 'w', encoding='utf-8') as strm: + strm.write(source) + self.byte_compile([sitepy]) + + self.sitepy_installed = True + + def create_home_path(self): + """Create directories under ~.""" + if not self.user: + return + home = convert_path(os.path.expanduser("~")) + for name, path in six.iteritems(self.config_vars): + if path.startswith(home) and not os.path.isdir(path): + self.debug_print("os.makedirs('%s', 0o700)" % path) + os.makedirs(path, 0o700) + + INSTALL_SCHEMES = dict( + posix=dict( + install_dir='$base/lib/python$py_version_short/site-packages', + script_dir='$base/bin', + ), + ) + + DEFAULT_SCHEME = dict( + install_dir='$base/Lib/site-packages', + script_dir='$base/Scripts', + ) + + def _expand(self, *attrs): + config_vars = self.get_finalized_command('install').config_vars + + if self.prefix: + # Set default install_dir/scripts from --prefix + config_vars = config_vars.copy() + config_vars['base'] = self.prefix + scheme = self.INSTALL_SCHEMES.get(os.name, self.DEFAULT_SCHEME) + for attr, val in scheme.items(): + if getattr(self, attr, None) is None: + setattr(self, attr, val) + + from distutils.util import subst_vars + + for attr in attrs: + val = getattr(self, attr) + if val is not None: + val = subst_vars(val, config_vars) + if os.name == 'posix': + val = os.path.expanduser(val) + setattr(self, attr, val) + + +def _pythonpath(): + items = os.environ.get('PYTHONPATH', '').split(os.pathsep) + return filter(None, items) + + +def get_site_dirs(): + """ + Return a list of 'site' dirs + """ + + sitedirs = [] + + # start with PYTHONPATH + sitedirs.extend(_pythonpath()) + + prefixes = [sys.prefix] + if sys.exec_prefix != sys.prefix: + prefixes.append(sys.exec_prefix) + for prefix in prefixes: + if prefix: + if sys.platform in ('os2emx', 'riscos'): + sitedirs.append(os.path.join(prefix, "Lib", "site-packages")) + elif os.sep == '/': + sitedirs.extend([ + os.path.join( + prefix, + "lib", + "python" + sys.version[:3], + "site-packages", + ), + os.path.join(prefix, "lib", "site-python"), + ]) + else: + sitedirs.extend([ + prefix, + os.path.join(prefix, "lib", "site-packages"), + ]) + if sys.platform == 'darwin': + # for framework builds *only* we add the standard Apple + # locations. Currently only per-user, but /Library and + # /Network/Library could be added too + if 'Python.framework' in prefix: + home = os.environ.get('HOME') + if home: + home_sp = os.path.join( + home, + 'Library', + 'Python', + sys.version[:3], + 'site-packages', + ) + sitedirs.append(home_sp) + lib_paths = get_path('purelib'), get_path('platlib') + for site_lib in lib_paths: + if site_lib not in sitedirs: + sitedirs.append(site_lib) + + if site.ENABLE_USER_SITE: + sitedirs.append(site.USER_SITE) + + try: + sitedirs.extend(site.getsitepackages()) + except AttributeError: + pass + + sitedirs = list(map(normalize_path, sitedirs)) + + return sitedirs + + +def expand_paths(inputs): + """Yield sys.path directories that might contain "old-style" packages""" + + seen = {} + + for dirname in inputs: + dirname = normalize_path(dirname) + if dirname in seen: + continue + + seen[dirname] = 1 + if not os.path.isdir(dirname): + continue + + files = os.listdir(dirname) + yield dirname, files + + for name in files: + if not name.endswith('.pth'): + # We only care about the .pth files + continue + if name in ('easy-install.pth', 'setuptools.pth'): + # Ignore .pth files that we control + continue + + # Read the .pth file + f = open(os.path.join(dirname, name)) + lines = list(yield_lines(f)) + f.close() + + # Yield existing non-dupe, non-import directory lines from it + for line in lines: + if not line.startswith("import"): + line = normalize_path(line.rstrip()) + if line not in seen: + seen[line] = 1 + if not os.path.isdir(line): + continue + yield line, os.listdir(line) + + +def extract_wininst_cfg(dist_filename): + """Extract configuration data from a bdist_wininst .exe + + Returns a configparser.RawConfigParser, or None + """ + f = open(dist_filename, 'rb') + try: + endrec = zipfile._EndRecData(f) + if endrec is None: + return None + + prepended = (endrec[9] - endrec[5]) - endrec[6] + if prepended < 12: # no wininst data here + return None + f.seek(prepended - 12) + + tag, cfglen, bmlen = struct.unpack("<iii", f.read(12)) + if tag not in (0x1234567A, 0x1234567B): + return None # not a valid tag + + f.seek(prepended - (12 + cfglen)) + init = {'version': '', 'target_version': ''} + cfg = configparser.RawConfigParser(init) + try: + part = f.read(cfglen) + # Read up to the first null byte. + config = part.split(b'\0', 1)[0] + # Now the config is in bytes, but for RawConfigParser, it should + # be text, so decode it. + config = config.decode(sys.getfilesystemencoding()) + cfg.readfp(six.StringIO(config)) + except configparser.Error: + return None + if not cfg.has_section('metadata') or not cfg.has_section('Setup'): + return None + return cfg + + finally: + f.close() + + +def get_exe_prefixes(exe_filename): + """Get exe->egg path translations for a given .exe file""" + + prefixes = [ + ('PURELIB/', ''), + ('PLATLIB/pywin32_system32', ''), + ('PLATLIB/', ''), + ('SCRIPTS/', 'EGG-INFO/scripts/'), + ('DATA/lib/site-packages', ''), + ] + z = zipfile.ZipFile(exe_filename) + try: + for info in z.infolist(): + name = info.filename + parts = name.split('/') + if len(parts) == 3 and parts[2] == 'PKG-INFO': + if parts[1].endswith('.egg-info'): + prefixes.insert(0, ('/'.join(parts[:2]), 'EGG-INFO/')) + break + if len(parts) != 2 or not name.endswith('.pth'): + continue + if name.endswith('-nspkg.pth'): + continue + if parts[0].upper() in ('PURELIB', 'PLATLIB'): + contents = z.read(name) + if six.PY3: + contents = contents.decode() + for pth in yield_lines(contents): + pth = pth.strip().replace('\\', '/') + if not pth.startswith('import'): + prefixes.append((('%s/%s/' % (parts[0], pth)), '')) + finally: + z.close() + prefixes = [(x.lower(), y) for x, y in prefixes] + prefixes.sort() + prefixes.reverse() + return prefixes + + +class PthDistributions(Environment): + """A .pth file with Distribution paths in it""" + + dirty = False + + def __init__(self, filename, sitedirs=()): + self.filename = filename + self.sitedirs = list(map(normalize_path, sitedirs)) + self.basedir = normalize_path(os.path.dirname(self.filename)) + self._load() + Environment.__init__(self, [], None, None) + for path in yield_lines(self.paths): + list(map(self.add, find_distributions(path, True))) + + def _load(self): + self.paths = [] + saw_import = False + seen = dict.fromkeys(self.sitedirs) + if os.path.isfile(self.filename): + f = open(self.filename, 'rt') + for line in f: + if line.startswith('import'): + saw_import = True + continue + path = line.rstrip() + self.paths.append(path) + if not path.strip() or path.strip().startswith('#'): + continue + # skip non-existent paths, in case somebody deleted a package + # manually, and duplicate paths as well + path = self.paths[-1] = normalize_path( + os.path.join(self.basedir, path) + ) + if not os.path.exists(path) or path in seen: + self.paths.pop() # skip it + self.dirty = True # we cleaned up, so we're dirty now :) + continue + seen[path] = 1 + f.close() + + if self.paths and not saw_import: + self.dirty = True # ensure anything we touch has import wrappers + while self.paths and not self.paths[-1].strip(): + self.paths.pop() + + def save(self): + """Write changed .pth file back to disk""" + if not self.dirty: + return + + rel_paths = list(map(self.make_relative, self.paths)) + if rel_paths: + log.debug("Saving %s", self.filename) + lines = self._wrap_lines(rel_paths) + data = '\n'.join(lines) + '\n' + + if os.path.islink(self.filename): + os.unlink(self.filename) + with open(self.filename, 'wt') as f: + f.write(data) + + elif os.path.exists(self.filename): + log.debug("Deleting empty %s", self.filename) + os.unlink(self.filename) + + self.dirty = False + + @staticmethod + def _wrap_lines(lines): + return lines + + def add(self, dist): + """Add `dist` to the distribution map""" + new_path = ( + dist.location not in self.paths and ( + dist.location not in self.sitedirs or + # account for '.' being in PYTHONPATH + dist.location == os.getcwd() + ) + ) + if new_path: + self.paths.append(dist.location) + self.dirty = True + Environment.add(self, dist) + + def remove(self, dist): + """Remove `dist` from the distribution map""" + while dist.location in self.paths: + self.paths.remove(dist.location) + self.dirty = True + Environment.remove(self, dist) + + def make_relative(self, path): + npath, last = os.path.split(normalize_path(path)) + baselen = len(self.basedir) + parts = [last] + sep = os.altsep == '/' and '/' or os.sep + while len(npath) >= baselen: + if npath == self.basedir: + parts.append(os.curdir) + parts.reverse() + return sep.join(parts) + npath, last = os.path.split(npath) + parts.append(last) + else: + return path + + +class RewritePthDistributions(PthDistributions): + @classmethod + def _wrap_lines(cls, lines): + yield cls.prelude + for line in lines: + yield line + yield cls.postlude + + prelude = _one_liner(""" + import sys + sys.__plen = len(sys.path) + """) + postlude = _one_liner(""" + import sys + new = sys.path[sys.__plen:] + del sys.path[sys.__plen:] + p = getattr(sys, '__egginsert', 0) + sys.path[p:p] = new + sys.__egginsert = p + len(new) + """) + + +if os.environ.get('SETUPTOOLS_SYS_PATH_TECHNIQUE', 'raw') == 'rewrite': + PthDistributions = RewritePthDistributions + + +def _first_line_re(): + """ + Return a regular expression based on first_line_re suitable for matching + strings. + """ + if isinstance(first_line_re.pattern, str): + return first_line_re + + # first_line_re in Python >=3.1.4 and >=3.2.1 is a bytes pattern. + return re.compile(first_line_re.pattern.decode()) + + +def auto_chmod(func, arg, exc): + if func in [os.unlink, os.remove] and os.name == 'nt': + chmod(arg, stat.S_IWRITE) + return func(arg) + et, ev, _ = sys.exc_info() + six.reraise(et, (ev[0], ev[1] + (" %s %s" % (func, arg)))) + + +def update_dist_caches(dist_path, fix_zipimporter_caches): + """ + Fix any globally cached `dist_path` related data + + `dist_path` should be a path of a newly installed egg distribution (zipped + or unzipped). + + sys.path_importer_cache contains finder objects that have been cached when + importing data from the original distribution. Any such finders need to be + cleared since the replacement distribution might be packaged differently, + e.g. a zipped egg distribution might get replaced with an unzipped egg + folder or vice versa. Having the old finders cached may then cause Python + to attempt loading modules from the replacement distribution using an + incorrect loader. + + zipimport.zipimporter objects are Python loaders charged with importing + data packaged inside zip archives. If stale loaders referencing the + original distribution, are left behind, they can fail to load modules from + the replacement distribution. E.g. if an old zipimport.zipimporter instance + is used to load data from a new zipped egg archive, it may cause the + operation to attempt to locate the requested data in the wrong location - + one indicated by the original distribution's zip archive directory + information. Such an operation may then fail outright, e.g. report having + read a 'bad local file header', or even worse, it may fail silently & + return invalid data. + + zipimport._zip_directory_cache contains cached zip archive directory + information for all existing zipimport.zipimporter instances and all such + instances connected to the same archive share the same cached directory + information. + + If asked, and the underlying Python implementation allows it, we can fix + all existing zipimport.zipimporter instances instead of having to track + them down and remove them one by one, by updating their shared cached zip + archive directory information. This, of course, assumes that the + replacement distribution is packaged as a zipped egg. + + If not asked to fix existing zipimport.zipimporter instances, we still do + our best to clear any remaining zipimport.zipimporter related cached data + that might somehow later get used when attempting to load data from the new + distribution and thus cause such load operations to fail. Note that when + tracking down such remaining stale data, we can not catch every conceivable + usage from here, and we clear only those that we know of and have found to + cause problems if left alive. Any remaining caches should be updated by + whomever is in charge of maintaining them, i.e. they should be ready to + handle us replacing their zip archives with new distributions at runtime. + + """ + # There are several other known sources of stale zipimport.zipimporter + # instances that we do not clear here, but might if ever given a reason to + # do so: + # * Global setuptools pkg_resources.working_set (a.k.a. 'master working + # set') may contain distributions which may in turn contain their + # zipimport.zipimporter loaders. + # * Several zipimport.zipimporter loaders held by local variables further + # up the function call stack when running the setuptools installation. + # * Already loaded modules may have their __loader__ attribute set to the + # exact loader instance used when importing them. Python 3.4 docs state + # that this information is intended mostly for introspection and so is + # not expected to cause us problems. + normalized_path = normalize_path(dist_path) + _uncache(normalized_path, sys.path_importer_cache) + if fix_zipimporter_caches: + _replace_zip_directory_cache_data(normalized_path) + else: + # Here, even though we do not want to fix existing and now stale + # zipimporter cache information, we still want to remove it. Related to + # Python's zip archive directory information cache, we clear each of + # its stale entries in two phases: + # 1. Clear the entry so attempting to access zip archive information + # via any existing stale zipimport.zipimporter instances fails. + # 2. Remove the entry from the cache so any newly constructed + # zipimport.zipimporter instances do not end up using old stale + # zip archive directory information. + # This whole stale data removal step does not seem strictly necessary, + # but has been left in because it was done before we started replacing + # the zip archive directory information cache content if possible, and + # there are no relevant unit tests that we can depend on to tell us if + # this is really needed. + _remove_and_clear_zip_directory_cache_data(normalized_path) + + +def _collect_zipimporter_cache_entries(normalized_path, cache): + """ + Return zipimporter cache entry keys related to a given normalized path. + + Alternative path spellings (e.g. those using different character case or + those using alternative path separators) related to the same path are + included. Any sub-path entries are included as well, i.e. those + corresponding to zip archives embedded in other zip archives. + + """ + result = [] + prefix_len = len(normalized_path) + for p in cache: + np = normalize_path(p) + if (np.startswith(normalized_path) and + np[prefix_len:prefix_len + 1] in (os.sep, '')): + result.append(p) + return result + + +def _update_zipimporter_cache(normalized_path, cache, updater=None): + """ + Update zipimporter cache data for a given normalized path. + + Any sub-path entries are processed as well, i.e. those corresponding to zip + archives embedded in other zip archives. + + Given updater is a callable taking a cache entry key and the original entry + (after already removing the entry from the cache), and expected to update + the entry and possibly return a new one to be inserted in its place. + Returning None indicates that the entry should not be replaced with a new + one. If no updater is given, the cache entries are simply removed without + any additional processing, the same as if the updater simply returned None. + + """ + for p in _collect_zipimporter_cache_entries(normalized_path, cache): + # N.B. pypy's custom zipimport._zip_directory_cache implementation does + # not support the complete dict interface: + # * Does not support item assignment, thus not allowing this function + # to be used only for removing existing cache entries. + # * Does not support the dict.pop() method, forcing us to use the + # get/del patterns instead. For more detailed information see the + # following links: + # https://github.com/pypa/setuptools/issues/202#issuecomment-202913420 + # http://bit.ly/2h9itJX + old_entry = cache[p] + del cache[p] + new_entry = updater and updater(p, old_entry) + if new_entry is not None: + cache[p] = new_entry + + +def _uncache(normalized_path, cache): + _update_zipimporter_cache(normalized_path, cache) + + +def _remove_and_clear_zip_directory_cache_data(normalized_path): + def clear_and_remove_cached_zip_archive_directory_data(path, old_entry): + old_entry.clear() + + _update_zipimporter_cache( + normalized_path, zipimport._zip_directory_cache, + updater=clear_and_remove_cached_zip_archive_directory_data) + + +# PyPy Python implementation does not allow directly writing to the +# zipimport._zip_directory_cache and so prevents us from attempting to correct +# its content. The best we can do there is clear the problematic cache content +# and have PyPy repopulate it as needed. The downside is that if there are any +# stale zipimport.zipimporter instances laying around, attempting to use them +# will fail due to not having its zip archive directory information available +# instead of being automatically corrected to use the new correct zip archive +# directory information. +if '__pypy__' in sys.builtin_module_names: + _replace_zip_directory_cache_data = \ + _remove_and_clear_zip_directory_cache_data +else: + + def _replace_zip_directory_cache_data(normalized_path): + def replace_cached_zip_archive_directory_data(path, old_entry): + # N.B. In theory, we could load the zip directory information just + # once for all updated path spellings, and then copy it locally and + # update its contained path strings to contain the correct + # spelling, but that seems like a way too invasive move (this cache + # structure is not officially documented anywhere and could in + # theory change with new Python releases) for no significant + # benefit. + old_entry.clear() + zipimport.zipimporter(path) + old_entry.update(zipimport._zip_directory_cache[path]) + return old_entry + + _update_zipimporter_cache( + normalized_path, zipimport._zip_directory_cache, + updater=replace_cached_zip_archive_directory_data) + + +def is_python(text, filename='<string>'): + "Is this string a valid Python script?" + try: + compile(text, filename, 'exec') + except (SyntaxError, TypeError): + return False + else: + return True + + +def is_sh(executable): + """Determine if the specified executable is a .sh (contains a #! line)""" + try: + with io.open(executable, encoding='latin-1') as fp: + magic = fp.read(2) + except (OSError, IOError): + return executable + return magic == '#!' + + +def nt_quote_arg(arg): + """Quote a command line argument according to Windows parsing rules""" + return subprocess.list2cmdline([arg]) + + +def is_python_script(script_text, filename): + """Is this text, as a whole, a Python script? (as opposed to shell/bat/etc. + """ + if filename.endswith('.py') or filename.endswith('.pyw'): + return True # extension says it's Python + if is_python(script_text, filename): + return True # it's syntactically valid Python + if script_text.startswith('#!'): + # It begins with a '#!' line, so check if 'python' is in it somewhere + return 'python' in script_text.splitlines()[0].lower() + + return False # Not any Python I can recognize + + +try: + from os import chmod as _chmod +except ImportError: + # Jython compatibility + def _chmod(*args): + pass + + +def chmod(path, mode): + log.debug("changing mode of %s to %o", path, mode) + try: + _chmod(path, mode) + except os.error as e: + log.debug("chmod failed: %s", e) + + +class CommandSpec(list): + """ + A command spec for a #! header, specified as a list of arguments akin to + those passed to Popen. + """ + + options = [] + split_args = dict() + + @classmethod + def best(cls): + """ + Choose the best CommandSpec class based on environmental conditions. + """ + return cls + + @classmethod + def _sys_executable(cls): + _default = os.path.normpath(sys.executable) + return os.environ.get('__PYVENV_LAUNCHER__', _default) + + @classmethod + def from_param(cls, param): + """ + Construct a CommandSpec from a parameter to build_scripts, which may + be None. + """ + if isinstance(param, cls): + return param + if isinstance(param, list): + return cls(param) + if param is None: + return cls.from_environment() + # otherwise, assume it's a string. + return cls.from_string(param) + + @classmethod + def from_environment(cls): + return cls([cls._sys_executable()]) + + @classmethod + def from_string(cls, string): + """ + Construct a command spec from a simple string representing a command + line parseable by shlex.split. + """ + items = shlex.split(string, **cls.split_args) + return cls(items) + + def install_options(self, script_text): + self.options = shlex.split(self._extract_options(script_text)) + cmdline = subprocess.list2cmdline(self) + if not isascii(cmdline): + self.options[:0] = ['-x'] + + @staticmethod + def _extract_options(orig_script): + """ + Extract any options from the first line of the script. + """ + first = (orig_script + '\n').splitlines()[0] + match = _first_line_re().match(first) + options = match.group(1) or '' if match else '' + return options.strip() + + def as_header(self): + return self._render(self + list(self.options)) + + @staticmethod + def _strip_quotes(item): + _QUOTES = '"\'' + for q in _QUOTES: + if item.startswith(q) and item.endswith(q): + return item[1:-1] + return item + + @staticmethod + def _render(items): + cmdline = subprocess.list2cmdline( + CommandSpec._strip_quotes(item.strip()) for item in items) + return '#!' + cmdline + '\n' + + +# For pbr compat; will be removed in a future version. +sys_executable = CommandSpec._sys_executable() + + +class WindowsCommandSpec(CommandSpec): + split_args = dict(posix=False) + + +class ScriptWriter: + """ + Encapsulates behavior around writing entry point scripts for console and + gui apps. + """ + + template = textwrap.dedent(r""" + # EASY-INSTALL-ENTRY-SCRIPT: %(spec)r,%(group)r,%(name)r + __requires__ = %(spec)r + import re + import sys + from pkg_resources import load_entry_point + + if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0]) + sys.exit( + load_entry_point(%(spec)r, %(group)r, %(name)r)() + ) + """).lstrip() + + command_spec_class = CommandSpec + + @classmethod + def get_script_args(cls, dist, executable=None, wininst=False): + # for backward compatibility + warnings.warn("Use get_args", EasyInstallDeprecationWarning) + writer = (WindowsScriptWriter if wininst else ScriptWriter).best() + header = cls.get_script_header("", executable, wininst) + return writer.get_args(dist, header) + + @classmethod + def get_script_header(cls, script_text, executable=None, wininst=False): + # for backward compatibility + warnings.warn("Use get_header", EasyInstallDeprecationWarning, stacklevel=2) + if wininst: + executable = "python.exe" + return cls.get_header(script_text, executable) + + @classmethod + def get_args(cls, dist, header=None): + """ + Yield write_script() argument tuples for a distribution's + console_scripts and gui_scripts entry points. + """ + if header is None: + header = cls.get_header() + spec = str(dist.as_requirement()) + for type_ in 'console', 'gui': + group = type_ + '_scripts' + for name, ep in dist.get_entry_map(group).items(): + cls._ensure_safe_name(name) + script_text = cls.template % locals() + args = cls._get_script_args(type_, name, header, script_text) + for res in args: + yield res + + @staticmethod + def _ensure_safe_name(name): + """ + Prevent paths in *_scripts entry point names. + """ + has_path_sep = re.search(r'[\\/]', name) + if has_path_sep: + raise ValueError("Path separators not allowed in script names") + + @classmethod + def get_writer(cls, force_windows): + # for backward compatibility + warnings.warn("Use best", EasyInstallDeprecationWarning) + return WindowsScriptWriter.best() if force_windows else cls.best() + + @classmethod + def best(cls): + """ + Select the best ScriptWriter for this environment. + """ + if sys.platform == 'win32' or (os.name == 'java' and os._name == 'nt'): + return WindowsScriptWriter.best() + else: + return cls + + @classmethod + def _get_script_args(cls, type_, name, header, script_text): + # Simply write the stub with no extension. + yield (name, header + script_text) + + @classmethod + def get_header(cls, script_text="", executable=None): + """Create a #! line, getting options (if any) from script_text""" + cmd = cls.command_spec_class.best().from_param(executable) + cmd.install_options(script_text) + return cmd.as_header() + + +class WindowsScriptWriter(ScriptWriter): + command_spec_class = WindowsCommandSpec + + @classmethod + def get_writer(cls): + # for backward compatibility + warnings.warn("Use best", EasyInstallDeprecationWarning) + return cls.best() + + @classmethod + def best(cls): + """ + Select the best ScriptWriter suitable for Windows + """ + writer_lookup = dict( + executable=WindowsExecutableLauncherWriter, + natural=cls, + ) + # for compatibility, use the executable launcher by default + launcher = os.environ.get('SETUPTOOLS_LAUNCHER', 'executable') + return writer_lookup[launcher] + + @classmethod + def _get_script_args(cls, type_, name, header, script_text): + "For Windows, add a .py extension" + ext = dict(console='.pya', gui='.pyw')[type_] + if ext not in os.environ['PATHEXT'].lower().split(';'): + msg = ( + "{ext} not listed in PATHEXT; scripts will not be " + "recognized as executables." + ).format(**locals()) + warnings.warn(msg, UserWarning) + old = ['.pya', '.py', '-script.py', '.pyc', '.pyo', '.pyw', '.exe'] + old.remove(ext) + header = cls._adjust_header(type_, header) + blockers = [name + x for x in old] + yield name + ext, header + script_text, 't', blockers + + @classmethod + def _adjust_header(cls, type_, orig_header): + """ + Make sure 'pythonw' is used for gui and and 'python' is used for + console (regardless of what sys.executable is). + """ + pattern = 'pythonw.exe' + repl = 'python.exe' + if type_ == 'gui': + pattern, repl = repl, pattern + pattern_ob = re.compile(re.escape(pattern), re.IGNORECASE) + new_header = pattern_ob.sub(string=orig_header, repl=repl) + return new_header if cls._use_header(new_header) else orig_header + + @staticmethod + def _use_header(new_header): + """ + Should _adjust_header use the replaced header? + + On non-windows systems, always use. On + Windows systems, only use the replaced header if it resolves + to an executable on the system. + """ + clean_header = new_header[2:-1].strip('"') + return sys.platform != 'win32' or find_executable(clean_header) + + +class WindowsExecutableLauncherWriter(WindowsScriptWriter): + @classmethod + def _get_script_args(cls, type_, name, header, script_text): + """ + For Windows, add a .py extension and an .exe launcher + """ + if type_ == 'gui': + launcher_type = 'gui' + ext = '-script.pyw' + old = ['.pyw'] + else: + launcher_type = 'cli' + ext = '-script.py' + old = ['.py', '.pyc', '.pyo'] + hdr = cls._adjust_header(type_, header) + blockers = [name + x for x in old] + yield (name + ext, hdr + script_text, 't', blockers) + yield ( + name + '.exe', get_win_launcher(launcher_type), + 'b' # write in binary mode + ) + if not is_64bit(): + # install a manifest for the launcher to prevent Windows + # from detecting it as an installer (which it will for + # launchers like easy_install.exe). Consider only + # adding a manifest for launchers detected as installers. + # See Distribute #143 for details. + m_name = name + '.exe.manifest' + yield (m_name, load_launcher_manifest(name), 't') + + +# for backward-compatibility +get_script_args = ScriptWriter.get_script_args +get_script_header = ScriptWriter.get_script_header + + +def get_win_launcher(type): + """ + Load the Windows launcher (executable) suitable for launching a script. + + `type` should be either 'cli' or 'gui' + + Returns the executable as a byte string. + """ + launcher_fn = '%s.exe' % type + if is_64bit(): + launcher_fn = launcher_fn.replace(".", "-64.") + else: + launcher_fn = launcher_fn.replace(".", "-32.") + return resource_string('setuptools', launcher_fn) + + +def load_launcher_manifest(name): + manifest = pkg_resources.resource_string(__name__, 'launcher manifest.xml') + if six.PY2: + return manifest % vars() + else: + return manifest.decode('utf-8') % vars() + + +def rmtree(path, ignore_errors=False, onerror=auto_chmod): + return shutil.rmtree(path, ignore_errors, onerror) + + +def current_umask(): + tmp = os.umask(0o022) + os.umask(tmp) + return tmp + + +def bootstrap(): + # This function is called when setuptools*.egg is run using /bin/sh + import setuptools + + argv0 = os.path.dirname(setuptools.__path__[0]) + sys.argv[0] = argv0 + sys.argv.append(argv0) + main() + + +def main(argv=None, **kw): + from setuptools import setup + from setuptools.dist import Distribution + + class DistributionWithoutHelpCommands(Distribution): + common_usage = "" + + def _show_help(self, *args, **kw): + with _patch_usage(): + Distribution._show_help(self, *args, **kw) + + if argv is None: + argv = sys.argv[1:] + + with _patch_usage(): + setup( + script_args=['-q', 'easy_install', '-v'] + argv, + script_name=sys.argv[0] or 'easy_install', + distclass=DistributionWithoutHelpCommands, + **kw + ) + + +@contextlib.contextmanager +def _patch_usage(): + import distutils.core + USAGE = textwrap.dedent(""" + usage: %(script)s [options] requirement_or_url ... + or: %(script)s --help + """).lstrip() + + def gen_usage(script_name): + return USAGE % dict( + script=os.path.basename(script_name), + ) + + saved = distutils.core.gen_usage + distutils.core.gen_usage = gen_usage + try: + yield + finally: + distutils.core.gen_usage = saved + +class EasyInstallDeprecationWarning(SetuptoolsDeprecationWarning): + """Class for warning about deprecations in EasyInstall in SetupTools. Not ignored by default, unlike DeprecationWarning.""" + diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/egg_info.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/egg_info.py new file mode 100644 index 0000000..5d8f451 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/egg_info.py @@ -0,0 +1,717 @@ +"""setuptools.command.egg_info + +Create a distribution's .egg-info directory and contents""" + +from distutils.filelist import FileList as _FileList +from distutils.errors import DistutilsInternalError +from distutils.util import convert_path +from distutils import log +import distutils.errors +import distutils.filelist +import os +import re +import sys +import io +import warnings +import time +import collections + +from setuptools.extern import six +from setuptools.extern.six.moves import map + +from setuptools import Command +from setuptools.command.sdist import sdist +from setuptools.command.sdist import walk_revctrl +from setuptools.command.setopt import edit_config +from setuptools.command import bdist_egg +from pkg_resources import ( + parse_requirements, safe_name, parse_version, + safe_version, yield_lines, EntryPoint, iter_entry_points, to_filename) +import setuptools.unicode_utils as unicode_utils +from setuptools.glob import glob + +from setuptools.extern import packaging +from setuptools import SetuptoolsDeprecationWarning + +def translate_pattern(glob): + """ + Translate a file path glob like '*.txt' in to a regular expression. + This differs from fnmatch.translate which allows wildcards to match + directory separators. It also knows about '**/' which matches any number of + directories. + """ + pat = '' + + # This will split on '/' within [character classes]. This is deliberate. + chunks = glob.split(os.path.sep) + + sep = re.escape(os.sep) + valid_char = '[^%s]' % (sep,) + + for c, chunk in enumerate(chunks): + last_chunk = c == len(chunks) - 1 + + # Chunks that are a literal ** are globstars. They match anything. + if chunk == '**': + if last_chunk: + # Match anything if this is the last component + pat += '.*' + else: + # Match '(name/)*' + pat += '(?:%s+%s)*' % (valid_char, sep) + continue # Break here as the whole path component has been handled + + # Find any special characters in the remainder + i = 0 + chunk_len = len(chunk) + while i < chunk_len: + char = chunk[i] + if char == '*': + # Match any number of name characters + pat += valid_char + '*' + elif char == '?': + # Match a name character + pat += valid_char + elif char == '[': + # Character class + inner_i = i + 1 + # Skip initial !/] chars + if inner_i < chunk_len and chunk[inner_i] == '!': + inner_i = inner_i + 1 + if inner_i < chunk_len and chunk[inner_i] == ']': + inner_i = inner_i + 1 + + # Loop till the closing ] is found + while inner_i < chunk_len and chunk[inner_i] != ']': + inner_i = inner_i + 1 + + if inner_i >= chunk_len: + # Got to the end of the string without finding a closing ] + # Do not treat this as a matching group, but as a literal [ + pat += re.escape(char) + else: + # Grab the insides of the [brackets] + inner = chunk[i + 1:inner_i] + char_class = '' + + # Class negation + if inner[0] == '!': + char_class = '^' + inner = inner[1:] + + char_class += re.escape(inner) + pat += '[%s]' % (char_class,) + + # Skip to the end ] + i = inner_i + else: + pat += re.escape(char) + i += 1 + + # Join each chunk with the dir separator + if not last_chunk: + pat += sep + + pat += r'\Z' + return re.compile(pat, flags=re.MULTILINE|re.DOTALL) + + +class InfoCommon: + tag_build = None + tag_date = None + + @property + def name(self): + return safe_name(self.distribution.get_name()) + + def tagged_version(self): + version = self.distribution.get_version() + # egg_info may be called more than once for a distribution, + # in which case the version string already contains all tags. + if self.vtags and version.endswith(self.vtags): + return safe_version(version) + return safe_version(version + self.vtags) + + def tags(self): + version = '' + if self.tag_build: + version += self.tag_build + if self.tag_date: + version += time.strftime("-%Y%m%d") + return version + vtags = property(tags) + + +class egg_info(InfoCommon, Command): + description = "create a distribution's .egg-info directory" + + user_options = [ + ('egg-base=', 'e', "directory containing .egg-info directories" + " (default: top of the source tree)"), + ('tag-date', 'd', "Add date stamp (e.g. 20050528) to version number"), + ('tag-build=', 'b', "Specify explicit tag to add to version number"), + ('no-date', 'D', "Don't include date stamp [default]"), + ] + + boolean_options = ['tag-date'] + negative_opt = { + 'no-date': 'tag-date', + } + + def initialize_options(self): + self.egg_base = None + self.egg_name = None + self.egg_info = None + self.egg_version = None + self.broken_egg_info = False + + #################################### + # allow the 'tag_svn_revision' to be detected and + # set, supporting sdists built on older Setuptools. + @property + def tag_svn_revision(self): + pass + + @tag_svn_revision.setter + def tag_svn_revision(self, value): + pass + #################################### + + def save_version_info(self, filename): + """ + Materialize the value of date into the + build tag. Install build keys in a deterministic order + to avoid arbitrary reordering on subsequent builds. + """ + egg_info = collections.OrderedDict() + # follow the order these keys would have been added + # when PYTHONHASHSEED=0 + egg_info['tag_build'] = self.tags() + egg_info['tag_date'] = 0 + edit_config(filename, dict(egg_info=egg_info)) + + def finalize_options(self): + # Note: we need to capture the current value returned + # by `self.tagged_version()`, so we can later update + # `self.distribution.metadata.version` without + # repercussions. + self.egg_name = self.name + self.egg_version = self.tagged_version() + parsed_version = parse_version(self.egg_version) + + try: + is_version = isinstance(parsed_version, packaging.version.Version) + spec = ( + "%s==%s" if is_version else "%s===%s" + ) + list( + parse_requirements(spec % (self.egg_name, self.egg_version)) + ) + except ValueError: + raise distutils.errors.DistutilsOptionError( + "Invalid distribution name or version syntax: %s-%s" % + (self.egg_name, self.egg_version) + ) + + if self.egg_base is None: + dirs = self.distribution.package_dir + self.egg_base = (dirs or {}).get('', os.curdir) + + self.ensure_dirname('egg_base') + self.egg_info = to_filename(self.egg_name) + '.egg-info' + if self.egg_base != os.curdir: + self.egg_info = os.path.join(self.egg_base, self.egg_info) + if '-' in self.egg_name: + self.check_broken_egg_info() + + # Set package version for the benefit of dumber commands + # (e.g. sdist, bdist_wininst, etc.) + # + self.distribution.metadata.version = self.egg_version + + # If we bootstrapped around the lack of a PKG-INFO, as might be the + # case in a fresh checkout, make sure that any special tags get added + # to the version info + # + pd = self.distribution._patched_dist + if pd is not None and pd.key == self.egg_name.lower(): + pd._version = self.egg_version + pd._parsed_version = parse_version(self.egg_version) + self.distribution._patched_dist = None + + def write_or_delete_file(self, what, filename, data, force=False): + """Write `data` to `filename` or delete if empty + + If `data` is non-empty, this routine is the same as ``write_file()``. + If `data` is empty but not ``None``, this is the same as calling + ``delete_file(filename)`. If `data` is ``None``, then this is a no-op + unless `filename` exists, in which case a warning is issued about the + orphaned file (if `force` is false), or deleted (if `force` is true). + """ + if data: + self.write_file(what, filename, data) + elif os.path.exists(filename): + if data is None and not force: + log.warn( + "%s not set in setup(), but %s exists", what, filename + ) + return + else: + self.delete_file(filename) + + def write_file(self, what, filename, data): + """Write `data` to `filename` (if not a dry run) after announcing it + + `what` is used in a log message to identify what is being written + to the file. + """ + log.info("writing %s to %s", what, filename) + if six.PY3: + data = data.encode("utf-8") + if not self.dry_run: + f = open(filename, 'wb') + f.write(data) + f.close() + + def delete_file(self, filename): + """Delete `filename` (if not a dry run) after announcing it""" + log.info("deleting %s", filename) + if not self.dry_run: + os.unlink(filename) + + def run(self): + self.mkpath(self.egg_info) + os.utime(self.egg_info, None) + installer = self.distribution.fetch_build_egg + for ep in iter_entry_points('egg_info.writers'): + ep.require(installer=installer) + writer = ep.resolve() + writer(self, ep.name, os.path.join(self.egg_info, ep.name)) + + # Get rid of native_libs.txt if it was put there by older bdist_egg + nl = os.path.join(self.egg_info, "native_libs.txt") + if os.path.exists(nl): + self.delete_file(nl) + + self.find_sources() + + def find_sources(self): + """Generate SOURCES.txt manifest file""" + manifest_filename = os.path.join(self.egg_info, "SOURCES.txt") + mm = manifest_maker(self.distribution) + mm.manifest = manifest_filename + mm.run() + self.filelist = mm.filelist + + def check_broken_egg_info(self): + bei = self.egg_name + '.egg-info' + if self.egg_base != os.curdir: + bei = os.path.join(self.egg_base, bei) + if os.path.exists(bei): + log.warn( + "-" * 78 + '\n' + "Note: Your current .egg-info directory has a '-' in its name;" + '\nthis will not work correctly with "setup.py develop".\n\n' + 'Please rename %s to %s to correct this problem.\n' + '-' * 78, + bei, self.egg_info + ) + self.broken_egg_info = self.egg_info + self.egg_info = bei # make it work for now + + +class FileList(_FileList): + # Implementations of the various MANIFEST.in commands + + def process_template_line(self, line): + # Parse the line: split it up, make sure the right number of words + # is there, and return the relevant words. 'action' is always + # defined: it's the first word of the line. Which of the other + # three are defined depends on the action; it'll be either + # patterns, (dir and patterns), or (dir_pattern). + (action, patterns, dir, dir_pattern) = self._parse_template_line(line) + + # OK, now we know that the action is valid and we have the + # right number of words on the line for that action -- so we + # can proceed with minimal error-checking. + if action == 'include': + self.debug_print("include " + ' '.join(patterns)) + for pattern in patterns: + if not self.include(pattern): + log.warn("warning: no files found matching '%s'", pattern) + + elif action == 'exclude': + self.debug_print("exclude " + ' '.join(patterns)) + for pattern in patterns: + if not self.exclude(pattern): + log.warn(("warning: no previously-included files " + "found matching '%s'"), pattern) + + elif action == 'global-include': + self.debug_print("global-include " + ' '.join(patterns)) + for pattern in patterns: + if not self.global_include(pattern): + log.warn(("warning: no files found matching '%s' " + "anywhere in distribution"), pattern) + + elif action == 'global-exclude': + self.debug_print("global-exclude " + ' '.join(patterns)) + for pattern in patterns: + if not self.global_exclude(pattern): + log.warn(("warning: no previously-included files matching " + "'%s' found anywhere in distribution"), + pattern) + + elif action == 'recursive-include': + self.debug_print("recursive-include %s %s" % + (dir, ' '.join(patterns))) + for pattern in patterns: + if not self.recursive_include(dir, pattern): + log.warn(("warning: no files found matching '%s' " + "under directory '%s'"), + pattern, dir) + + elif action == 'recursive-exclude': + self.debug_print("recursive-exclude %s %s" % + (dir, ' '.join(patterns))) + for pattern in patterns: + if not self.recursive_exclude(dir, pattern): + log.warn(("warning: no previously-included files matching " + "'%s' found under directory '%s'"), + pattern, dir) + + elif action == 'graft': + self.debug_print("graft " + dir_pattern) + if not self.graft(dir_pattern): + log.warn("warning: no directories found matching '%s'", + dir_pattern) + + elif action == 'prune': + self.debug_print("prune " + dir_pattern) + if not self.prune(dir_pattern): + log.warn(("no previously-included directories found " + "matching '%s'"), dir_pattern) + + else: + raise DistutilsInternalError( + "this cannot happen: invalid action '%s'" % action) + + def _remove_files(self, predicate): + """ + Remove all files from the file list that match the predicate. + Return True if any matching files were removed + """ + found = False + for i in range(len(self.files) - 1, -1, -1): + if predicate(self.files[i]): + self.debug_print(" removing " + self.files[i]) + del self.files[i] + found = True + return found + + def include(self, pattern): + """Include files that match 'pattern'.""" + found = [f for f in glob(pattern) if not os.path.isdir(f)] + self.extend(found) + return bool(found) + + def exclude(self, pattern): + """Exclude files that match 'pattern'.""" + match = translate_pattern(pattern) + return self._remove_files(match.match) + + def recursive_include(self, dir, pattern): + """ + Include all files anywhere in 'dir/' that match the pattern. + """ + full_pattern = os.path.join(dir, '**', pattern) + found = [f for f in glob(full_pattern, recursive=True) + if not os.path.isdir(f)] + self.extend(found) + return bool(found) + + def recursive_exclude(self, dir, pattern): + """ + Exclude any file anywhere in 'dir/' that match the pattern. + """ + match = translate_pattern(os.path.join(dir, '**', pattern)) + return self._remove_files(match.match) + + def graft(self, dir): + """Include all files from 'dir/'.""" + found = [ + item + for match_dir in glob(dir) + for item in distutils.filelist.findall(match_dir) + ] + self.extend(found) + return bool(found) + + def prune(self, dir): + """Filter out files from 'dir/'.""" + match = translate_pattern(os.path.join(dir, '**')) + return self._remove_files(match.match) + + def global_include(self, pattern): + """ + Include all files anywhere in the current directory that match the + pattern. This is very inefficient on large file trees. + """ + if self.allfiles is None: + self.findall() + match = translate_pattern(os.path.join('**', pattern)) + found = [f for f in self.allfiles if match.match(f)] + self.extend(found) + return bool(found) + + def global_exclude(self, pattern): + """ + Exclude all files anywhere that match the pattern. + """ + match = translate_pattern(os.path.join('**', pattern)) + return self._remove_files(match.match) + + def append(self, item): + if item.endswith('\r'): # Fix older sdists built on Windows + item = item[:-1] + path = convert_path(item) + + if self._safe_path(path): + self.files.append(path) + + def extend(self, paths): + self.files.extend(filter(self._safe_path, paths)) + + def _repair(self): + """ + Replace self.files with only safe paths + + Because some owners of FileList manipulate the underlying + ``files`` attribute directly, this method must be called to + repair those paths. + """ + self.files = list(filter(self._safe_path, self.files)) + + def _safe_path(self, path): + enc_warn = "'%s' not %s encodable -- skipping" + + # To avoid accidental trans-codings errors, first to unicode + u_path = unicode_utils.filesys_decode(path) + if u_path is None: + log.warn("'%s' in unexpected encoding -- skipping" % path) + return False + + # Must ensure utf-8 encodability + utf8_path = unicode_utils.try_encode(u_path, "utf-8") + if utf8_path is None: + log.warn(enc_warn, path, 'utf-8') + return False + + try: + # accept is either way checks out + if os.path.exists(u_path) or os.path.exists(utf8_path): + return True + # this will catch any encode errors decoding u_path + except UnicodeEncodeError: + log.warn(enc_warn, path, sys.getfilesystemencoding()) + + +class manifest_maker(sdist): + template = "MANIFEST.in" + + def initialize_options(self): + self.use_defaults = 1 + self.prune = 1 + self.manifest_only = 1 + self.force_manifest = 1 + + def finalize_options(self): + pass + + def run(self): + self.filelist = FileList() + if not os.path.exists(self.manifest): + self.write_manifest() # it must exist so it'll get in the list + self.add_defaults() + if os.path.exists(self.template): + self.read_template() + self.prune_file_list() + self.filelist.sort() + self.filelist.remove_duplicates() + self.write_manifest() + + def _manifest_normalize(self, path): + path = unicode_utils.filesys_decode(path) + return path.replace(os.sep, '/') + + def write_manifest(self): + """ + Write the file list in 'self.filelist' to the manifest file + named by 'self.manifest'. + """ + self.filelist._repair() + + # Now _repairs should encodability, but not unicode + files = [self._manifest_normalize(f) for f in self.filelist.files] + msg = "writing manifest file '%s'" % self.manifest + self.execute(write_file, (self.manifest, files), msg) + + def warn(self, msg): + if not self._should_suppress_warning(msg): + sdist.warn(self, msg) + + @staticmethod + def _should_suppress_warning(msg): + """ + suppress missing-file warnings from sdist + """ + return re.match(r"standard file .*not found", msg) + + def add_defaults(self): + sdist.add_defaults(self) + self.check_license() + self.filelist.append(self.template) + self.filelist.append(self.manifest) + rcfiles = list(walk_revctrl()) + if rcfiles: + self.filelist.extend(rcfiles) + elif os.path.exists(self.manifest): + self.read_manifest() + + if os.path.exists("setup.py"): + # setup.py should be included by default, even if it's not + # the script called to create the sdist + self.filelist.append("setup.py") + + ei_cmd = self.get_finalized_command('egg_info') + self.filelist.graft(ei_cmd.egg_info) + + def prune_file_list(self): + build = self.get_finalized_command('build') + base_dir = self.distribution.get_fullname() + self.filelist.prune(build.build_base) + self.filelist.prune(base_dir) + sep = re.escape(os.sep) + self.filelist.exclude_pattern(r'(^|' + sep + r')(RCS|CVS|\.svn)' + sep, + is_regex=1) + + +def write_file(filename, contents): + """Create a file with the specified name and write 'contents' (a + sequence of strings without line terminators) to it. + """ + contents = "\n".join(contents) + + # assuming the contents has been vetted for utf-8 encoding + contents = contents.encode("utf-8") + + with open(filename, "wb") as f: # always write POSIX-style manifest + f.write(contents) + + +def write_pkg_info(cmd, basename, filename): + log.info("writing %s", filename) + if not cmd.dry_run: + metadata = cmd.distribution.metadata + metadata.version, oldver = cmd.egg_version, metadata.version + metadata.name, oldname = cmd.egg_name, metadata.name + + try: + # write unescaped data to PKG-INFO, so older pkg_resources + # can still parse it + metadata.write_pkg_info(cmd.egg_info) + finally: + metadata.name, metadata.version = oldname, oldver + + safe = getattr(cmd.distribution, 'zip_safe', None) + + bdist_egg.write_safety_flag(cmd.egg_info, safe) + + +def warn_depends_obsolete(cmd, basename, filename): + if os.path.exists(filename): + log.warn( + "WARNING: 'depends.txt' is not used by setuptools 0.6!\n" + "Use the install_requires/extras_require setup() args instead." + ) + + +def _write_requirements(stream, reqs): + lines = yield_lines(reqs or ()) + append_cr = lambda line: line + '\n' + lines = map(append_cr, lines) + stream.writelines(lines) + + +def write_requirements(cmd, basename, filename): + dist = cmd.distribution + data = six.StringIO() + _write_requirements(data, dist.install_requires) + extras_require = dist.extras_require or {} + for extra in sorted(extras_require): + data.write('\n[{extra}]\n'.format(**vars())) + _write_requirements(data, extras_require[extra]) + cmd.write_or_delete_file("requirements", filename, data.getvalue()) + + +def write_setup_requirements(cmd, basename, filename): + data = io.StringIO() + _write_requirements(data, cmd.distribution.setup_requires) + cmd.write_or_delete_file("setup-requirements", filename, data.getvalue()) + + +def write_toplevel_names(cmd, basename, filename): + pkgs = dict.fromkeys( + [ + k.split('.', 1)[0] + for k in cmd.distribution.iter_distribution_names() + ] + ) + cmd.write_file("top-level names", filename, '\n'.join(sorted(pkgs)) + '\n') + + +def overwrite_arg(cmd, basename, filename): + write_arg(cmd, basename, filename, True) + + +def write_arg(cmd, basename, filename, force=False): + argname = os.path.splitext(basename)[0] + value = getattr(cmd.distribution, argname, None) + if value is not None: + value = '\n'.join(value) + '\n' + cmd.write_or_delete_file(argname, filename, value, force) + + +def write_entries(cmd, basename, filename): + ep = cmd.distribution.entry_points + + if isinstance(ep, six.string_types) or ep is None: + data = ep + elif ep is not None: + data = [] + for section, contents in sorted(ep.items()): + if not isinstance(contents, six.string_types): + contents = EntryPoint.parse_group(section, contents) + contents = '\n'.join(sorted(map(str, contents.values()))) + data.append('[%s]\n%s\n\n' % (section, contents)) + data = ''.join(data) + + cmd.write_or_delete_file('entry points', filename, data, True) + + +def get_pkg_info_revision(): + """ + Get a -r### off of PKG-INFO Version in case this is an sdist of + a subversion revision. + """ + warnings.warn("get_pkg_info_revision is deprecated.", EggInfoDeprecationWarning) + if os.path.exists('PKG-INFO'): + with io.open('PKG-INFO') as f: + for line in f: + match = re.match(r"Version:.*-r(\d+)\s*$", line) + if match: + return int(match.group(1)) + return 0 + + +class EggInfoDeprecationWarning(SetuptoolsDeprecationWarning): + """Class for warning about deprecations in eggInfo in setupTools. Not ignored by default, unlike DeprecationWarning.""" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install.py new file mode 100644 index 0000000..31a5ddb --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install.py @@ -0,0 +1,125 @@ +from distutils.errors import DistutilsArgError +import inspect +import glob +import warnings +import platform +import distutils.command.install as orig + +import setuptools + +# Prior to numpy 1.9, NumPy relies on the '_install' name, so provide it for +# now. See https://github.com/pypa/setuptools/issues/199/ +_install = orig.install + + +class install(orig.install): + """Use easy_install to install the package, w/dependencies""" + + user_options = orig.install.user_options + [ + ('old-and-unmanageable', None, "Try not to use this!"), + ('single-version-externally-managed', None, + "used by system package builders to create 'flat' eggs"), + ] + boolean_options = orig.install.boolean_options + [ + 'old-and-unmanageable', 'single-version-externally-managed', + ] + new_commands = [ + ('install_egg_info', lambda self: True), + ('install_scripts', lambda self: True), + ] + _nc = dict(new_commands) + + def initialize_options(self): + orig.install.initialize_options(self) + self.old_and_unmanageable = None + self.single_version_externally_managed = None + + def finalize_options(self): + orig.install.finalize_options(self) + if self.root: + self.single_version_externally_managed = True + elif self.single_version_externally_managed: + if not self.root and not self.record: + raise DistutilsArgError( + "You must specify --record or --root when building system" + " packages" + ) + + def handle_extra_path(self): + if self.root or self.single_version_externally_managed: + # explicit backward-compatibility mode, allow extra_path to work + return orig.install.handle_extra_path(self) + + # Ignore extra_path when installing an egg (or being run by another + # command without --root or --single-version-externally-managed + self.path_file = None + self.extra_dirs = '' + + def run(self): + # Explicit request for old-style install? Just do it + if self.old_and_unmanageable or self.single_version_externally_managed: + return orig.install.run(self) + + if not self._called_from_setup(inspect.currentframe()): + # Run in backward-compatibility mode to support bdist_* commands. + orig.install.run(self) + else: + self.do_egg_install() + + @staticmethod + def _called_from_setup(run_frame): + """ + Attempt to detect whether run() was called from setup() or by another + command. If called by setup(), the parent caller will be the + 'run_command' method in 'distutils.dist', and *its* caller will be + the 'run_commands' method. If called any other way, the + immediate caller *might* be 'run_command', but it won't have been + called by 'run_commands'. Return True in that case or if a call stack + is unavailable. Return False otherwise. + """ + if run_frame is None: + msg = "Call stack not available. bdist_* commands may fail." + warnings.warn(msg) + if platform.python_implementation() == 'IronPython': + msg = "For best results, pass -X:Frames to enable call stack." + warnings.warn(msg) + return True + res = inspect.getouterframes(run_frame)[2] + caller, = res[:1] + info = inspect.getframeinfo(caller) + caller_module = caller.f_globals.get('__name__', '') + return ( + caller_module == 'distutils.dist' + and info.function == 'run_commands' + ) + + def do_egg_install(self): + + easy_install = self.distribution.get_command_class('easy_install') + + cmd = easy_install( + self.distribution, args="x", root=self.root, record=self.record, + ) + cmd.ensure_finalized() # finalize before bdist_egg munges install cmd + cmd.always_copy_from = '.' # make sure local-dir eggs get installed + + # pick up setup-dir .egg files only: no .egg-info + cmd.package_index.scan(glob.glob('*.egg')) + + self.run_command('bdist_egg') + args = [self.distribution.get_command_obj('bdist_egg').egg_output] + + if setuptools.bootstrap_install_from: + # Bootstrap self-installation of setuptools + args.insert(0, setuptools.bootstrap_install_from) + + cmd.args = args + cmd.run() + setuptools.bootstrap_install_from = None + + +# XXX Python 3.1 doesn't see _nc if this is inside the class +install.sub_commands = ( + [cmd for cmd in orig.install.sub_commands if cmd[0] not in install._nc] + + install.new_commands +) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install_egg_info.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install_egg_info.py new file mode 100644 index 0000000..edc4718 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install_egg_info.py @@ -0,0 +1,62 @@ +from distutils import log, dir_util +import os + +from setuptools import Command +from setuptools import namespaces +from setuptools.archive_util import unpack_archive +import pkg_resources + + +class install_egg_info(namespaces.Installer, Command): + """Install an .egg-info directory for the package""" + + description = "Install an .egg-info directory for the package" + + user_options = [ + ('install-dir=', 'd', "directory to install to"), + ] + + def initialize_options(self): + self.install_dir = None + + def finalize_options(self): + self.set_undefined_options('install_lib', + ('install_dir', 'install_dir')) + ei_cmd = self.get_finalized_command("egg_info") + basename = pkg_resources.Distribution( + None, None, ei_cmd.egg_name, ei_cmd.egg_version + ).egg_name() + '.egg-info' + self.source = ei_cmd.egg_info + self.target = os.path.join(self.install_dir, basename) + self.outputs = [] + + def run(self): + self.run_command('egg_info') + if os.path.isdir(self.target) and not os.path.islink(self.target): + dir_util.remove_tree(self.target, dry_run=self.dry_run) + elif os.path.exists(self.target): + self.execute(os.unlink, (self.target,), "Removing " + self.target) + if not self.dry_run: + pkg_resources.ensure_directory(self.target) + self.execute( + self.copytree, (), "Copying %s to %s" % (self.source, self.target) + ) + self.install_namespaces() + + def get_outputs(self): + return self.outputs + + def copytree(self): + # Copy the .egg-info tree to site-packages + def skimmer(src, dst): + # filter out source-control directories; note that 'src' is always + # a '/'-separated path, regardless of platform. 'dst' is a + # platform-specific path. + for skip in '.svn/', 'CVS/': + if src.startswith(skip) or '/' + skip in src: + return None + self.outputs.append(dst) + log.debug("Copying %s to %s", src, dst) + return dst + + unpack_archive(self.source, self.target, skimmer) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install_lib.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install_lib.py new file mode 100644 index 0000000..07d6593 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install_lib.py @@ -0,0 +1,121 @@ +import os +import sys +from itertools import product, starmap +import distutils.command.install_lib as orig + + +class install_lib(orig.install_lib): + """Don't add compiled flags to filenames of non-Python files""" + + def run(self): + self.build() + outfiles = self.install() + if outfiles is not None: + # always compile, in case we have any extension stubs to deal with + self.byte_compile(outfiles) + + def get_exclusions(self): + """ + Return a collections.Sized collections.Container of paths to be + excluded for single_version_externally_managed installations. + """ + all_packages = ( + pkg + for ns_pkg in self._get_SVEM_NSPs() + for pkg in self._all_packages(ns_pkg) + ) + + excl_specs = product(all_packages, self._gen_exclusion_paths()) + return set(starmap(self._exclude_pkg_path, excl_specs)) + + def _exclude_pkg_path(self, pkg, exclusion_path): + """ + Given a package name and exclusion path within that package, + compute the full exclusion path. + """ + parts = pkg.split('.') + [exclusion_path] + return os.path.join(self.install_dir, *parts) + + @staticmethod + def _all_packages(pkg_name): + """ + >>> list(install_lib._all_packages('foo.bar.baz')) + ['foo.bar.baz', 'foo.bar', 'foo'] + """ + while pkg_name: + yield pkg_name + pkg_name, sep, child = pkg_name.rpartition('.') + + def _get_SVEM_NSPs(self): + """ + Get namespace packages (list) but only for + single_version_externally_managed installations and empty otherwise. + """ + # TODO: is it necessary to short-circuit here? i.e. what's the cost + # if get_finalized_command is called even when namespace_packages is + # False? + if not self.distribution.namespace_packages: + return [] + + install_cmd = self.get_finalized_command('install') + svem = install_cmd.single_version_externally_managed + + return self.distribution.namespace_packages if svem else [] + + @staticmethod + def _gen_exclusion_paths(): + """ + Generate file paths to be excluded for namespace packages (bytecode + cache files). + """ + # always exclude the package module itself + yield '__init__.py' + + yield '__init__.pyc' + yield '__init__.pyo' + + if not hasattr(sys, 'implementation'): + return + + base = os.path.join('__pycache__', '__init__.' + sys.implementation.cache_tag) + yield base + '.pyc' + yield base + '.pyo' + yield base + '.opt-1.pyc' + yield base + '.opt-2.pyc' + + def copy_tree( + self, infile, outfile, + preserve_mode=1, preserve_times=1, preserve_symlinks=0, level=1 + ): + assert preserve_mode and preserve_times and not preserve_symlinks + exclude = self.get_exclusions() + + if not exclude: + return orig.install_lib.copy_tree(self, infile, outfile) + + # Exclude namespace package __init__.py* files from the output + + from setuptools.archive_util import unpack_directory + from distutils import log + + outfiles = [] + + def pf(src, dst): + if dst in exclude: + log.warn("Skipping installation of %s (namespace package)", + dst) + return False + + log.info("copying %s -> %s", src, os.path.dirname(dst)) + outfiles.append(dst) + return dst + + unpack_directory(infile, outfile, pf) + return outfiles + + def get_outputs(self): + outputs = orig.install_lib.get_outputs(self) + exclude = self.get_exclusions() + if exclude: + return [f for f in outputs if f not in exclude] + return outputs diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install_scripts.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install_scripts.py new file mode 100644 index 0000000..1623427 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/install_scripts.py @@ -0,0 +1,65 @@ +from distutils import log +import distutils.command.install_scripts as orig +import os +import sys + +from pkg_resources import Distribution, PathMetadata, ensure_directory + + +class install_scripts(orig.install_scripts): + """Do normal script install, plus any egg_info wrapper scripts""" + + def initialize_options(self): + orig.install_scripts.initialize_options(self) + self.no_ep = False + + def run(self): + import setuptools.command.easy_install as ei + + self.run_command("egg_info") + if self.distribution.scripts: + orig.install_scripts.run(self) # run first to set up self.outfiles + else: + self.outfiles = [] + if self.no_ep: + # don't install entry point scripts into .egg file! + return + + ei_cmd = self.get_finalized_command("egg_info") + dist = Distribution( + ei_cmd.egg_base, PathMetadata(ei_cmd.egg_base, ei_cmd.egg_info), + ei_cmd.egg_name, ei_cmd.egg_version, + ) + bs_cmd = self.get_finalized_command('build_scripts') + exec_param = getattr(bs_cmd, 'executable', None) + bw_cmd = self.get_finalized_command("bdist_wininst") + is_wininst = getattr(bw_cmd, '_is_running', False) + writer = ei.ScriptWriter + if is_wininst: + exec_param = "python.exe" + writer = ei.WindowsScriptWriter + if exec_param == sys.executable: + # In case the path to the Python executable contains a space, wrap + # it so it's not split up. + exec_param = [exec_param] + # resolve the writer to the environment + writer = writer.best() + cmd = writer.command_spec_class.best().from_param(exec_param) + for args in writer.get_args(dist, cmd.as_header()): + self.write_script(*args) + + def write_script(self, script_name, contents, mode="t", *ignored): + """Write an executable file to the scripts directory""" + from setuptools.command.easy_install import chmod, current_umask + + log.info("Installing %s script to %s", script_name, self.install_dir) + target = os.path.join(self.install_dir, script_name) + self.outfiles.append(target) + + mask = current_umask() + if not self.dry_run: + ensure_directory(target) + f = open(target, "w" + mode) + f.write(contents) + f.close() + chmod(target, 0o777 - mask) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/launcher manifest.xml b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/launcher manifest.xml new file mode 100644 index 0000000..5972a96 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/launcher manifest.xml @@ -0,0 +1,15 @@ +<?xml version="1.0" encoding="UTF-8" standalone="yes"?> +<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0"> + <assemblyIdentity version="1.0.0.0" + processorArchitecture="X86" + name="%(name)s" + type="win32"/> + <!-- Identify the application security requirements. --> + <trustInfo xmlns="urn:schemas-microsoft-com:asm.v3"> + <security> + <requestedPrivileges> + <requestedExecutionLevel level="asInvoker" uiAccess="false"/> + </requestedPrivileges> + </security> + </trustInfo> +</assembly> diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/py36compat.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/py36compat.py new file mode 100644 index 0000000..61063e7 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/py36compat.py @@ -0,0 +1,136 @@ +import os +from glob import glob +from distutils.util import convert_path +from distutils.command import sdist + +from setuptools.extern.six.moves import filter + + +class sdist_add_defaults: + """ + Mix-in providing forward-compatibility for functionality as found in + distutils on Python 3.7. + + Do not edit the code in this class except to update functionality + as implemented in distutils. Instead, override in the subclass. + """ + + def add_defaults(self): + """Add all the default files to self.filelist: + - README or README.txt + - setup.py + - test/test*.py + - all pure Python modules mentioned in setup script + - all files pointed by package_data (build_py) + - all files defined in data_files. + - all files defined as scripts. + - all C sources listed as part of extensions or C libraries + in the setup script (doesn't catch C headers!) + Warns if (README or README.txt) or setup.py are missing; everything + else is optional. + """ + self._add_defaults_standards() + self._add_defaults_optional() + self._add_defaults_python() + self._add_defaults_data_files() + self._add_defaults_ext() + self._add_defaults_c_libs() + self._add_defaults_scripts() + + @staticmethod + def _cs_path_exists(fspath): + """ + Case-sensitive path existence check + + >>> sdist_add_defaults._cs_path_exists(__file__) + True + >>> sdist_add_defaults._cs_path_exists(__file__.upper()) + False + """ + if not os.path.exists(fspath): + return False + # make absolute so we always have a directory + abspath = os.path.abspath(fspath) + directory, filename = os.path.split(abspath) + return filename in os.listdir(directory) + + def _add_defaults_standards(self): + standards = [self.READMES, self.distribution.script_name] + for fn in standards: + if isinstance(fn, tuple): + alts = fn + got_it = False + for fn in alts: + if self._cs_path_exists(fn): + got_it = True + self.filelist.append(fn) + break + + if not got_it: + self.warn("standard file not found: should have one of " + + ', '.join(alts)) + else: + if self._cs_path_exists(fn): + self.filelist.append(fn) + else: + self.warn("standard file '%s' not found" % fn) + + def _add_defaults_optional(self): + optional = ['test/test*.py', 'setup.cfg'] + for pattern in optional: + files = filter(os.path.isfile, glob(pattern)) + self.filelist.extend(files) + + def _add_defaults_python(self): + # build_py is used to get: + # - python modules + # - files defined in package_data + build_py = self.get_finalized_command('build_py') + + # getting python files + if self.distribution.has_pure_modules(): + self.filelist.extend(build_py.get_source_files()) + + # getting package_data files + # (computed in build_py.data_files by build_py.finalize_options) + for pkg, src_dir, build_dir, filenames in build_py.data_files: + for filename in filenames: + self.filelist.append(os.path.join(src_dir, filename)) + + def _add_defaults_data_files(self): + # getting distribution.data_files + if self.distribution.has_data_files(): + for item in self.distribution.data_files: + if isinstance(item, str): + # plain file + item = convert_path(item) + if os.path.isfile(item): + self.filelist.append(item) + else: + # a (dirname, filenames) tuple + dirname, filenames = item + for f in filenames: + f = convert_path(f) + if os.path.isfile(f): + self.filelist.append(f) + + def _add_defaults_ext(self): + if self.distribution.has_ext_modules(): + build_ext = self.get_finalized_command('build_ext') + self.filelist.extend(build_ext.get_source_files()) + + def _add_defaults_c_libs(self): + if self.distribution.has_c_libraries(): + build_clib = self.get_finalized_command('build_clib') + self.filelist.extend(build_clib.get_source_files()) + + def _add_defaults_scripts(self): + if self.distribution.has_scripts(): + build_scripts = self.get_finalized_command('build_scripts') + self.filelist.extend(build_scripts.get_source_files()) + + +if hasattr(sdist.sdist, '_add_defaults_standards'): + # disable the functionality already available upstream + class sdist_add_defaults: + pass diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/register.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/register.py new file mode 100644 index 0000000..98bc015 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/register.py @@ -0,0 +1,18 @@ +from distutils import log +import distutils.command.register as orig + + +class register(orig.register): + __doc__ = orig.register.__doc__ + + def run(self): + try: + # Make sure that we are using valid current name/version info + self.run_command('egg_info') + orig.register.run(self) + finally: + self.announce( + "WARNING: Registering is deprecated, use twine to " + "upload instead (https://pypi.org/p/twine/)", + log.WARN + ) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/rotate.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/rotate.py new file mode 100644 index 0000000..b89353f --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/rotate.py @@ -0,0 +1,66 @@ +from distutils.util import convert_path +from distutils import log +from distutils.errors import DistutilsOptionError +import os +import shutil + +from setuptools.extern import six + +from setuptools import Command + + +class rotate(Command): + """Delete older distributions""" + + description = "delete older distributions, keeping N newest files" + user_options = [ + ('match=', 'm', "patterns to match (required)"), + ('dist-dir=', 'd', "directory where the distributions are"), + ('keep=', 'k', "number of matching distributions to keep"), + ] + + boolean_options = [] + + def initialize_options(self): + self.match = None + self.dist_dir = None + self.keep = None + + def finalize_options(self): + if self.match is None: + raise DistutilsOptionError( + "Must specify one or more (comma-separated) match patterns " + "(e.g. '.zip' or '.egg')" + ) + if self.keep is None: + raise DistutilsOptionError("Must specify number of files to keep") + try: + self.keep = int(self.keep) + except ValueError: + raise DistutilsOptionError("--keep must be an integer") + if isinstance(self.match, six.string_types): + self.match = [ + convert_path(p.strip()) for p in self.match.split(',') + ] + self.set_undefined_options('bdist', ('dist_dir', 'dist_dir')) + + def run(self): + self.run_command("egg_info") + from glob import glob + + for pattern in self.match: + pattern = self.distribution.get_name() + '*' + pattern + files = glob(os.path.join(self.dist_dir, pattern)) + files = [(os.path.getmtime(f), f) for f in files] + files.sort() + files.reverse() + + log.info("%d file(s) matching %s", len(files), pattern) + files = files[self.keep:] + for (t, f) in files: + log.info("Deleting %s", f) + if not self.dry_run: + if os.path.isdir(f): + shutil.rmtree(f) + else: + os.unlink(f) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/saveopts.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/saveopts.py new file mode 100644 index 0000000..611cec5 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/saveopts.py @@ -0,0 +1,22 @@ +from setuptools.command.setopt import edit_config, option_base + + +class saveopts(option_base): + """Save command-line options to a file""" + + description = "save supplied options to setup.cfg or other config file" + + def run(self): + dist = self.distribution + settings = {} + + for cmd in dist.command_options: + + if cmd == 'saveopts': + continue # don't save our own options! + + for opt, (src, val) in dist.get_option_dict(cmd).items(): + if src == "command line": + settings.setdefault(cmd, {})[opt] = val + + edit_config(self.filename, settings, self.dry_run) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/sdist.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/sdist.py new file mode 100644 index 0000000..dc25398 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/sdist.py @@ -0,0 +1,221 @@ +from distutils import log +import distutils.command.sdist as orig +import os +import sys +import io +import contextlib + +from setuptools.extern import six + +from .py36compat import sdist_add_defaults + +import pkg_resources + +_default_revctrl = list + + +def walk_revctrl(dirname=''): + """Find all files under revision control""" + for ep in pkg_resources.iter_entry_points('setuptools.file_finders'): + for item in ep.load()(dirname): + yield item + + +class sdist(sdist_add_defaults, orig.sdist): + """Smart sdist that finds anything supported by revision control""" + + user_options = [ + ('formats=', None, + "formats for source distribution (comma-separated list)"), + ('keep-temp', 'k', + "keep the distribution tree around after creating " + + "archive file(s)"), + ('dist-dir=', 'd', + "directory to put the source distribution archive(s) in " + "[default: dist]"), + ] + + negative_opt = {} + + README_EXTENSIONS = ['', '.rst', '.txt', '.md'] + READMES = tuple('README{0}'.format(ext) for ext in README_EXTENSIONS) + + def run(self): + self.run_command('egg_info') + ei_cmd = self.get_finalized_command('egg_info') + self.filelist = ei_cmd.filelist + self.filelist.append(os.path.join(ei_cmd.egg_info, 'SOURCES.txt')) + self.check_readme() + + # Run sub commands + for cmd_name in self.get_sub_commands(): + self.run_command(cmd_name) + + self.make_distribution() + + dist_files = getattr(self.distribution, 'dist_files', []) + for file in self.archive_files: + data = ('sdist', '', file) + if data not in dist_files: + dist_files.append(data) + + def initialize_options(self): + orig.sdist.initialize_options(self) + + self._default_to_gztar() + + def _default_to_gztar(self): + # only needed on Python prior to 3.6. + if sys.version_info >= (3, 6, 0, 'beta', 1): + return + self.formats = ['gztar'] + + def make_distribution(self): + """ + Workaround for #516 + """ + with self._remove_os_link(): + orig.sdist.make_distribution(self) + + @staticmethod + @contextlib.contextmanager + def _remove_os_link(): + """ + In a context, remove and restore os.link if it exists + """ + + class NoValue: + pass + + orig_val = getattr(os, 'link', NoValue) + try: + del os.link + except Exception: + pass + try: + yield + finally: + if orig_val is not NoValue: + setattr(os, 'link', orig_val) + + def __read_template_hack(self): + # This grody hack closes the template file (MANIFEST.in) if an + # exception occurs during read_template. + # Doing so prevents an error when easy_install attempts to delete the + # file. + try: + orig.sdist.read_template(self) + except Exception: + _, _, tb = sys.exc_info() + tb.tb_next.tb_frame.f_locals['template'].close() + raise + + # Beginning with Python 2.7.2, 3.1.4, and 3.2.1, this leaky file handle + # has been fixed, so only override the method if we're using an earlier + # Python. + has_leaky_handle = ( + sys.version_info < (2, 7, 2) + or (3, 0) <= sys.version_info < (3, 1, 4) + or (3, 2) <= sys.version_info < (3, 2, 1) + ) + if has_leaky_handle: + read_template = __read_template_hack + + def _add_defaults_python(self): + """getting python files""" + if self.distribution.has_pure_modules(): + build_py = self.get_finalized_command('build_py') + self.filelist.extend(build_py.get_source_files()) + # This functionality is incompatible with include_package_data, and + # will in fact create an infinite recursion if include_package_data + # is True. Use of include_package_data will imply that + # distutils-style automatic handling of package_data is disabled + if not self.distribution.include_package_data: + for _, src_dir, _, filenames in build_py.data_files: + self.filelist.extend([os.path.join(src_dir, filename) + for filename in filenames]) + + def _add_defaults_data_files(self): + try: + if six.PY2: + sdist_add_defaults._add_defaults_data_files(self) + else: + super()._add_defaults_data_files() + except TypeError: + log.warn("data_files contains unexpected objects") + + def check_readme(self): + for f in self.READMES: + if os.path.exists(f): + return + else: + self.warn( + "standard file not found: should have one of " + + ', '.join(self.READMES) + ) + + def make_release_tree(self, base_dir, files): + orig.sdist.make_release_tree(self, base_dir, files) + + # Save any egg_info command line options used to create this sdist + dest = os.path.join(base_dir, 'setup.cfg') + if hasattr(os, 'link') and os.path.exists(dest): + # unlink and re-copy, since it might be hard-linked, and + # we don't want to change the source version + os.unlink(dest) + self.copy_file('setup.cfg', dest) + + self.get_finalized_command('egg_info').save_version_info(dest) + + def _manifest_is_not_generated(self): + # check for special comment used in 2.7.1 and higher + if not os.path.isfile(self.manifest): + return False + + with io.open(self.manifest, 'rb') as fp: + first_line = fp.readline() + return (first_line != + '# file GENERATED by distutils, do NOT edit\n'.encode()) + + def read_manifest(self): + """Read the manifest file (named by 'self.manifest') and use it to + fill in 'self.filelist', the list of files to include in the source + distribution. + """ + log.info("reading manifest file '%s'", self.manifest) + manifest = open(self.manifest, 'rb') + for line in manifest: + # The manifest must contain UTF-8. See #303. + if six.PY3: + try: + line = line.decode('UTF-8') + except UnicodeDecodeError: + log.warn("%r not UTF-8 decodable -- skipping" % line) + continue + # ignore comments and blank lines + line = line.strip() + if line.startswith('#') or not line: + continue + self.filelist.append(line) + manifest.close() + + def check_license(self): + """Checks if license_file' is configured and adds it to + 'self.filelist' if the value contains a valid path. + """ + + opts = self.distribution.get_option_dict('metadata') + + # ignore the source of the value + _, license_file = opts.get('license_file', (None, None)) + + if license_file is None: + log.debug("'license_file' option was not specified") + return + + if not os.path.exists(license_file): + log.warn("warning: Failed to find the configured license file '%s'", + license_file) + return + + self.filelist.append(license_file) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/setopt.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/setopt.py new file mode 100644 index 0000000..7e57cc0 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/setopt.py @@ -0,0 +1,149 @@ +from distutils.util import convert_path +from distutils import log +from distutils.errors import DistutilsOptionError +import distutils +import os + +from setuptools.extern.six.moves import configparser + +from setuptools import Command + +__all__ = ['config_file', 'edit_config', 'option_base', 'setopt'] + + +def config_file(kind="local"): + """Get the filename of the distutils, local, global, or per-user config + + `kind` must be one of "local", "global", or "user" + """ + if kind == 'local': + return 'setup.cfg' + if kind == 'global': + return os.path.join( + os.path.dirname(distutils.__file__), 'distutils.cfg' + ) + if kind == 'user': + dot = os.name == 'posix' and '.' or '' + return os.path.expanduser(convert_path("~/%spydistutils.cfg" % dot)) + raise ValueError( + "config_file() type must be 'local', 'global', or 'user'", kind + ) + + +def edit_config(filename, settings, dry_run=False): + """Edit a configuration file to include `settings` + + `settings` is a dictionary of dictionaries or ``None`` values, keyed by + command/section name. A ``None`` value means to delete the entire section, + while a dictionary lists settings to be changed or deleted in that section. + A setting of ``None`` means to delete that setting. + """ + log.debug("Reading configuration from %s", filename) + opts = configparser.RawConfigParser() + opts.read([filename]) + for section, options in settings.items(): + if options is None: + log.info("Deleting section [%s] from %s", section, filename) + opts.remove_section(section) + else: + if not opts.has_section(section): + log.debug("Adding new section [%s] to %s", section, filename) + opts.add_section(section) + for option, value in options.items(): + if value is None: + log.debug( + "Deleting %s.%s from %s", + section, option, filename + ) + opts.remove_option(section, option) + if not opts.options(section): + log.info("Deleting empty [%s] section from %s", + section, filename) + opts.remove_section(section) + else: + log.debug( + "Setting %s.%s to %r in %s", + section, option, value, filename + ) + opts.set(section, option, value) + + log.info("Writing %s", filename) + if not dry_run: + with open(filename, 'w') as f: + opts.write(f) + + +class option_base(Command): + """Abstract base class for commands that mess with config files""" + + user_options = [ + ('global-config', 'g', + "save options to the site-wide distutils.cfg file"), + ('user-config', 'u', + "save options to the current user's pydistutils.cfg file"), + ('filename=', 'f', + "configuration file to use (default=setup.cfg)"), + ] + + boolean_options = [ + 'global-config', 'user-config', + ] + + def initialize_options(self): + self.global_config = None + self.user_config = None + self.filename = None + + def finalize_options(self): + filenames = [] + if self.global_config: + filenames.append(config_file('global')) + if self.user_config: + filenames.append(config_file('user')) + if self.filename is not None: + filenames.append(self.filename) + if not filenames: + filenames.append(config_file('local')) + if len(filenames) > 1: + raise DistutilsOptionError( + "Must specify only one configuration file option", + filenames + ) + self.filename, = filenames + + +class setopt(option_base): + """Save command-line options to a file""" + + description = "set an option in setup.cfg or another config file" + + user_options = [ + ('command=', 'c', 'command to set an option for'), + ('option=', 'o', 'option to set'), + ('set-value=', 's', 'value of the option'), + ('remove', 'r', 'remove (unset) the value'), + ] + option_base.user_options + + boolean_options = option_base.boolean_options + ['remove'] + + def initialize_options(self): + option_base.initialize_options(self) + self.command = None + self.option = None + self.set_value = None + self.remove = None + + def finalize_options(self): + option_base.finalize_options(self) + if self.command is None or self.option is None: + raise DistutilsOptionError("Must specify --command *and* --option") + if self.set_value is None and not self.remove: + raise DistutilsOptionError("Must specify --set-value or --remove") + + def run(self): + edit_config( + self.filename, { + self.command: {self.option.replace('-', '_'): self.set_value} + }, + self.dry_run + ) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/test.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/test.py new file mode 100644 index 0000000..973e4eb --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/test.py @@ -0,0 +1,271 @@ +import os +import operator +import sys +import contextlib +import itertools +import unittest +from distutils.errors import DistutilsError, DistutilsOptionError +from distutils import log +from unittest import TestLoader + +from setuptools.extern import six +from setuptools.extern.six.moves import map, filter + +from pkg_resources import (resource_listdir, resource_exists, normalize_path, + working_set, _namespace_packages, evaluate_marker, + add_activation_listener, require, EntryPoint) +from setuptools import Command +from .build_py import _unique_everseen + +__metaclass__ = type + + +class ScanningLoader(TestLoader): + + def __init__(self): + TestLoader.__init__(self) + self._visited = set() + + def loadTestsFromModule(self, module, pattern=None): + """Return a suite of all tests cases contained in the given module + + If the module is a package, load tests from all the modules in it. + If the module has an ``additional_tests`` function, call it and add + the return value to the tests. + """ + if module in self._visited: + return None + self._visited.add(module) + + tests = [] + tests.append(TestLoader.loadTestsFromModule(self, module)) + + if hasattr(module, "additional_tests"): + tests.append(module.additional_tests()) + + if hasattr(module, '__path__'): + for file in resource_listdir(module.__name__, ''): + if file.endswith('.py') and file != '__init__.py': + submodule = module.__name__ + '.' + file[:-3] + else: + if resource_exists(module.__name__, file + '/__init__.py'): + submodule = module.__name__ + '.' + file + else: + continue + tests.append(self.loadTestsFromName(submodule)) + + if len(tests) != 1: + return self.suiteClass(tests) + else: + return tests[0] # don't create a nested suite for only one return + + +# adapted from jaraco.classes.properties:NonDataProperty +class NonDataProperty: + def __init__(self, fget): + self.fget = fget + + def __get__(self, obj, objtype=None): + if obj is None: + return self + return self.fget(obj) + + +class test(Command): + """Command to run unit tests after in-place build""" + + description = "run unit tests after in-place build" + + user_options = [ + ('test-module=', 'm', "Run 'test_suite' in specified module"), + ('test-suite=', 's', + "Run single test, case or suite (e.g. 'module.test_suite')"), + ('test-runner=', 'r', "Test runner to use"), + ] + + def initialize_options(self): + self.test_suite = None + self.test_module = None + self.test_loader = None + self.test_runner = None + + def finalize_options(self): + + if self.test_suite and self.test_module: + msg = "You may specify a module or a suite, but not both" + raise DistutilsOptionError(msg) + + if self.test_suite is None: + if self.test_module is None: + self.test_suite = self.distribution.test_suite + else: + self.test_suite = self.test_module + ".test_suite" + + if self.test_loader is None: + self.test_loader = getattr(self.distribution, 'test_loader', None) + if self.test_loader is None: + self.test_loader = "setuptools.command.test:ScanningLoader" + if self.test_runner is None: + self.test_runner = getattr(self.distribution, 'test_runner', None) + + @NonDataProperty + def test_args(self): + return list(self._test_args()) + + def _test_args(self): + if not self.test_suite and sys.version_info >= (2, 7): + yield 'discover' + if self.verbose: + yield '--verbose' + if self.test_suite: + yield self.test_suite + + def with_project_on_sys_path(self, func): + """ + Backward compatibility for project_on_sys_path context. + """ + with self.project_on_sys_path(): + func() + + @contextlib.contextmanager + def project_on_sys_path(self, include_dists=[]): + with_2to3 = six.PY3 and getattr(self.distribution, 'use_2to3', False) + + if with_2to3: + # If we run 2to3 we can not do this inplace: + + # Ensure metadata is up-to-date + self.reinitialize_command('build_py', inplace=0) + self.run_command('build_py') + bpy_cmd = self.get_finalized_command("build_py") + build_path = normalize_path(bpy_cmd.build_lib) + + # Build extensions + self.reinitialize_command('egg_info', egg_base=build_path) + self.run_command('egg_info') + + self.reinitialize_command('build_ext', inplace=0) + self.run_command('build_ext') + else: + # Without 2to3 inplace works fine: + self.run_command('egg_info') + + # Build extensions in-place + self.reinitialize_command('build_ext', inplace=1) + self.run_command('build_ext') + + ei_cmd = self.get_finalized_command("egg_info") + + old_path = sys.path[:] + old_modules = sys.modules.copy() + + try: + project_path = normalize_path(ei_cmd.egg_base) + sys.path.insert(0, project_path) + working_set.__init__() + add_activation_listener(lambda dist: dist.activate()) + require('%s==%s' % (ei_cmd.egg_name, ei_cmd.egg_version)) + with self.paths_on_pythonpath([project_path]): + yield + finally: + sys.path[:] = old_path + sys.modules.clear() + sys.modules.update(old_modules) + working_set.__init__() + + @staticmethod + @contextlib.contextmanager + def paths_on_pythonpath(paths): + """ + Add the indicated paths to the head of the PYTHONPATH environment + variable so that subprocesses will also see the packages at + these paths. + + Do this in a context that restores the value on exit. + """ + nothing = object() + orig_pythonpath = os.environ.get('PYTHONPATH', nothing) + current_pythonpath = os.environ.get('PYTHONPATH', '') + try: + prefix = os.pathsep.join(_unique_everseen(paths)) + to_join = filter(None, [prefix, current_pythonpath]) + new_path = os.pathsep.join(to_join) + if new_path: + os.environ['PYTHONPATH'] = new_path + yield + finally: + if orig_pythonpath is nothing: + os.environ.pop('PYTHONPATH', None) + else: + os.environ['PYTHONPATH'] = orig_pythonpath + + @staticmethod + def install_dists(dist): + """ + Install the requirements indicated by self.distribution and + return an iterable of the dists that were built. + """ + ir_d = dist.fetch_build_eggs(dist.install_requires) + tr_d = dist.fetch_build_eggs(dist.tests_require or []) + er_d = dist.fetch_build_eggs( + v for k, v in dist.extras_require.items() + if k.startswith(':') and evaluate_marker(k[1:]) + ) + return itertools.chain(ir_d, tr_d, er_d) + + def run(self): + installed_dists = self.install_dists(self.distribution) + + cmd = ' '.join(self._argv) + if self.dry_run: + self.announce('skipping "%s" (dry run)' % cmd) + return + + self.announce('running "%s"' % cmd) + + paths = map(operator.attrgetter('location'), installed_dists) + with self.paths_on_pythonpath(paths): + with self.project_on_sys_path(): + self.run_tests() + + def run_tests(self): + # Purge modules under test from sys.modules. The test loader will + # re-import them from the build location. Required when 2to3 is used + # with namespace packages. + if six.PY3 and getattr(self.distribution, 'use_2to3', False): + module = self.test_suite.split('.')[0] + if module in _namespace_packages: + del_modules = [] + if module in sys.modules: + del_modules.append(module) + module += '.' + for name in sys.modules: + if name.startswith(module): + del_modules.append(name) + list(map(sys.modules.__delitem__, del_modules)) + + test = unittest.main( + None, None, self._argv, + testLoader=self._resolve_as_ep(self.test_loader), + testRunner=self._resolve_as_ep(self.test_runner), + exit=False, + ) + if not test.result.wasSuccessful(): + msg = 'Test failed: %s' % test.result + self.announce(msg, log.ERROR) + raise DistutilsError(msg) + + @property + def _argv(self): + return ['unittest'] + self.test_args + + @staticmethod + def _resolve_as_ep(val): + """ + Load the indicated attribute value, called, as a as if it were + specified as an entry point. + """ + if val is None: + return + parsed = EntryPoint.parse("x=" + val) + return parsed.resolve()() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/upload.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/upload.py new file mode 100644 index 0000000..6db8888 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/upload.py @@ -0,0 +1,196 @@ +import io +import os +import hashlib +import getpass + +from base64 import standard_b64encode + +from distutils import log +from distutils.command import upload as orig +from distutils.spawn import spawn + +from distutils.errors import DistutilsError + +from setuptools.extern.six.moves.urllib.request import urlopen, Request +from setuptools.extern.six.moves.urllib.error import HTTPError +from setuptools.extern.six.moves.urllib.parse import urlparse + + +class upload(orig.upload): + """ + Override default upload behavior to obtain password + in a variety of different ways. + """ + def run(self): + try: + orig.upload.run(self) + finally: + self.announce( + "WARNING: Uploading via this command is deprecated, use twine " + "to upload instead (https://pypi.org/p/twine/)", + log.WARN + ) + + def finalize_options(self): + orig.upload.finalize_options(self) + self.username = ( + self.username or + getpass.getuser() + ) + # Attempt to obtain password. Short circuit evaluation at the first + # sign of success. + self.password = ( + self.password or + self._load_password_from_keyring() or + self._prompt_for_password() + ) + + def upload_file(self, command, pyversion, filename): + # Makes sure the repository URL is compliant + schema, netloc, url, params, query, fragments = \ + urlparse(self.repository) + if params or query or fragments: + raise AssertionError("Incompatible url %s" % self.repository) + + if schema not in ('http', 'https'): + raise AssertionError("unsupported schema " + schema) + + # Sign if requested + if self.sign: + gpg_args = ["gpg", "--detach-sign", "-a", filename] + if self.identity: + gpg_args[2:2] = ["--local-user", self.identity] + spawn(gpg_args, + dry_run=self.dry_run) + + # Fill in the data - send all the meta-data in case we need to + # register a new release + with open(filename, 'rb') as f: + content = f.read() + + meta = self.distribution.metadata + + data = { + # action + ':action': 'file_upload', + 'protocol_version': '1', + + # identify release + 'name': meta.get_name(), + 'version': meta.get_version(), + + # file content + 'content': (os.path.basename(filename), content), + 'filetype': command, + 'pyversion': pyversion, + 'md5_digest': hashlib.md5(content).hexdigest(), + + # additional meta-data + 'metadata_version': str(meta.get_metadata_version()), + 'summary': meta.get_description(), + 'home_page': meta.get_url(), + 'author': meta.get_contact(), + 'author_email': meta.get_contact_email(), + 'license': meta.get_licence(), + 'description': meta.get_long_description(), + 'keywords': meta.get_keywords(), + 'platform': meta.get_platforms(), + 'classifiers': meta.get_classifiers(), + 'download_url': meta.get_download_url(), + # PEP 314 + 'provides': meta.get_provides(), + 'requires': meta.get_requires(), + 'obsoletes': meta.get_obsoletes(), + } + + data['comment'] = '' + + if self.sign: + data['gpg_signature'] = (os.path.basename(filename) + ".asc", + open(filename+".asc", "rb").read()) + + # set up the authentication + user_pass = (self.username + ":" + self.password).encode('ascii') + # The exact encoding of the authentication string is debated. + # Anyway PyPI only accepts ascii for both username or password. + auth = "Basic " + standard_b64encode(user_pass).decode('ascii') + + # Build up the MIME payload for the POST data + boundary = '--------------GHSKFJDLGDS7543FJKLFHRE75642756743254' + sep_boundary = b'\r\n--' + boundary.encode('ascii') + end_boundary = sep_boundary + b'--\r\n' + body = io.BytesIO() + for key, value in data.items(): + title = '\r\nContent-Disposition: form-data; name="%s"' % key + # handle multiple entries for the same name + if not isinstance(value, list): + value = [value] + for value in value: + if type(value) is tuple: + title += '; filename="%s"' % value[0] + value = value[1] + else: + value = str(value).encode('utf-8') + body.write(sep_boundary) + body.write(title.encode('utf-8')) + body.write(b"\r\n\r\n") + body.write(value) + body.write(end_boundary) + body = body.getvalue() + + msg = "Submitting %s to %s" % (filename, self.repository) + self.announce(msg, log.INFO) + + # build the Request + headers = { + 'Content-type': 'multipart/form-data; boundary=%s' % boundary, + 'Content-length': str(len(body)), + 'Authorization': auth, + } + + request = Request(self.repository, data=body, + headers=headers) + # send the data + try: + result = urlopen(request) + status = result.getcode() + reason = result.msg + except HTTPError as e: + status = e.code + reason = e.msg + except OSError as e: + self.announce(str(e), log.ERROR) + raise + + if status == 200: + self.announce('Server response (%s): %s' % (status, reason), + log.INFO) + if self.show_response: + text = getattr(self, '_read_pypi_response', + lambda x: None)(result) + if text is not None: + msg = '\n'.join(('-' * 75, text, '-' * 75)) + self.announce(msg, log.INFO) + else: + msg = 'Upload failed (%s): %s' % (status, reason) + self.announce(msg, log.ERROR) + raise DistutilsError(msg) + + def _load_password_from_keyring(self): + """ + Attempt to load password from keyring. Suppress Exceptions. + """ + try: + keyring = __import__('keyring') + return keyring.get_password(self.repository, self.username) + except Exception: + pass + + def _prompt_for_password(self): + """ + Prompt for a password on the tty. Suppress Exceptions. + """ + try: + return getpass.getpass() + except (Exception, KeyboardInterrupt): + pass diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/upload_docs.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/upload_docs.py new file mode 100644 index 0000000..07aa564 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/command/upload_docs.py @@ -0,0 +1,206 @@ +# -*- coding: utf-8 -*- +"""upload_docs + +Implements a Distutils 'upload_docs' subcommand (upload documentation to +PyPI's pythonhosted.org). +""" + +from base64 import standard_b64encode +from distutils import log +from distutils.errors import DistutilsOptionError +import os +import socket +import zipfile +import tempfile +import shutil +import itertools +import functools + +from setuptools.extern import six +from setuptools.extern.six.moves import http_client, urllib + +from pkg_resources import iter_entry_points +from .upload import upload + + +def _encode(s): + errors = 'surrogateescape' if six.PY3 else 'strict' + return s.encode('utf-8', errors) + + +class upload_docs(upload): + # override the default repository as upload_docs isn't + # supported by Warehouse (and won't be). + DEFAULT_REPOSITORY = 'https://pypi.python.org/pypi/' + + description = 'Upload documentation to PyPI' + + user_options = [ + ('repository=', 'r', + "url of repository [default: %s]" % upload.DEFAULT_REPOSITORY), + ('show-response', None, + 'display full response text from server'), + ('upload-dir=', None, 'directory to upload'), + ] + boolean_options = upload.boolean_options + + def has_sphinx(self): + if self.upload_dir is None: + for ep in iter_entry_points('distutils.commands', 'build_sphinx'): + return True + + sub_commands = [('build_sphinx', has_sphinx)] + + def initialize_options(self): + upload.initialize_options(self) + self.upload_dir = None + self.target_dir = None + + def finalize_options(self): + upload.finalize_options(self) + if self.upload_dir is None: + if self.has_sphinx(): + build_sphinx = self.get_finalized_command('build_sphinx') + self.target_dir = build_sphinx.builder_target_dir + else: + build = self.get_finalized_command('build') + self.target_dir = os.path.join(build.build_base, 'docs') + else: + self.ensure_dirname('upload_dir') + self.target_dir = self.upload_dir + if 'pypi.python.org' in self.repository: + log.warn("Upload_docs command is deprecated. Use RTD instead.") + self.announce('Using upload directory %s' % self.target_dir) + + def create_zipfile(self, filename): + zip_file = zipfile.ZipFile(filename, "w") + try: + self.mkpath(self.target_dir) # just in case + for root, dirs, files in os.walk(self.target_dir): + if root == self.target_dir and not files: + tmpl = "no files found in upload directory '%s'" + raise DistutilsOptionError(tmpl % self.target_dir) + for name in files: + full = os.path.join(root, name) + relative = root[len(self.target_dir):].lstrip(os.path.sep) + dest = os.path.join(relative, name) + zip_file.write(full, dest) + finally: + zip_file.close() + + def run(self): + # Run sub commands + for cmd_name in self.get_sub_commands(): + self.run_command(cmd_name) + + tmp_dir = tempfile.mkdtemp() + name = self.distribution.metadata.get_name() + zip_file = os.path.join(tmp_dir, "%s.zip" % name) + try: + self.create_zipfile(zip_file) + self.upload_file(zip_file) + finally: + shutil.rmtree(tmp_dir) + + @staticmethod + def _build_part(item, sep_boundary): + key, values = item + title = '\nContent-Disposition: form-data; name="%s"' % key + # handle multiple entries for the same name + if not isinstance(values, list): + values = [values] + for value in values: + if isinstance(value, tuple): + title += '; filename="%s"' % value[0] + value = value[1] + else: + value = _encode(value) + yield sep_boundary + yield _encode(title) + yield b"\n\n" + yield value + if value and value[-1:] == b'\r': + yield b'\n' # write an extra newline (lurve Macs) + + @classmethod + def _build_multipart(cls, data): + """ + Build up the MIME payload for the POST data + """ + boundary = b'--------------GHSKFJDLGDS7543FJKLFHRE75642756743254' + sep_boundary = b'\n--' + boundary + end_boundary = sep_boundary + b'--' + end_items = end_boundary, b"\n", + builder = functools.partial( + cls._build_part, + sep_boundary=sep_boundary, + ) + part_groups = map(builder, data.items()) + parts = itertools.chain.from_iterable(part_groups) + body_items = itertools.chain(parts, end_items) + content_type = 'multipart/form-data; boundary=%s' % boundary.decode('ascii') + return b''.join(body_items), content_type + + def upload_file(self, filename): + with open(filename, 'rb') as f: + content = f.read() + meta = self.distribution.metadata + data = { + ':action': 'doc_upload', + 'name': meta.get_name(), + 'content': (os.path.basename(filename), content), + } + # set up the authentication + credentials = _encode(self.username + ':' + self.password) + credentials = standard_b64encode(credentials) + if six.PY3: + credentials = credentials.decode('ascii') + auth = "Basic " + credentials + + body, ct = self._build_multipart(data) + + msg = "Submitting documentation to %s" % (self.repository) + self.announce(msg, log.INFO) + + # build the Request + # We can't use urllib2 since we need to send the Basic + # auth right with the first request + schema, netloc, url, params, query, fragments = \ + urllib.parse.urlparse(self.repository) + assert not params and not query and not fragments + if schema == 'http': + conn = http_client.HTTPConnection(netloc) + elif schema == 'https': + conn = http_client.HTTPSConnection(netloc) + else: + raise AssertionError("unsupported schema " + schema) + + data = '' + try: + conn.connect() + conn.putrequest("POST", url) + content_type = ct + conn.putheader('Content-type', content_type) + conn.putheader('Content-length', str(len(body))) + conn.putheader('Authorization', auth) + conn.endheaders() + conn.send(body) + except socket.error as e: + self.announce(str(e), log.ERROR) + return + + r = conn.getresponse() + if r.status == 200: + msg = 'Server response (%s): %s' % (r.status, r.reason) + self.announce(msg, log.INFO) + elif r.status == 301: + location = r.getheader('Location') + if location is None: + location = 'https://pythonhosted.org/%s/' % meta.get_name() + msg = 'Upload successful. Visit %s' % location + self.announce(msg, log.INFO) + else: + msg = 'Upload failed (%s): %s' % (r.status, r.reason) + self.announce(msg, log.ERROR) + if self.show_response: + print('-' * 75, r.read(), '-' * 75) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/config.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/config.py new file mode 100644 index 0000000..b662604 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/config.py @@ -0,0 +1,656 @@ +from __future__ import absolute_import, unicode_literals +import io +import os +import sys + +import warnings +import functools +from collections import defaultdict +from functools import partial +from functools import wraps +from importlib import import_module + +from distutils.errors import DistutilsOptionError, DistutilsFileError +from setuptools.extern.packaging.version import LegacyVersion, parse +from setuptools.extern.six import string_types, PY3 + + +__metaclass__ = type + + +def read_configuration( + filepath, find_others=False, ignore_option_errors=False): + """Read given configuration file and returns options from it as a dict. + + :param str|unicode filepath: Path to configuration file + to get options from. + + :param bool find_others: Whether to search for other configuration files + which could be on in various places. + + :param bool ignore_option_errors: Whether to silently ignore + options, values of which could not be resolved (e.g. due to exceptions + in directives such as file:, attr:, etc.). + If False exceptions are propagated as expected. + + :rtype: dict + """ + from setuptools.dist import Distribution, _Distribution + + filepath = os.path.abspath(filepath) + + if not os.path.isfile(filepath): + raise DistutilsFileError( + 'Configuration file %s does not exist.' % filepath) + + current_directory = os.getcwd() + os.chdir(os.path.dirname(filepath)) + + try: + dist = Distribution() + + filenames = dist.find_config_files() if find_others else [] + if filepath not in filenames: + filenames.append(filepath) + + _Distribution.parse_config_files(dist, filenames=filenames) + + handlers = parse_configuration( + dist, dist.command_options, + ignore_option_errors=ignore_option_errors) + + finally: + os.chdir(current_directory) + + return configuration_to_dict(handlers) + + +def _get_option(target_obj, key): + """ + Given a target object and option key, get that option from + the target object, either through a get_{key} method or + from an attribute directly. + """ + getter_name = 'get_{key}'.format(**locals()) + by_attribute = functools.partial(getattr, target_obj, key) + getter = getattr(target_obj, getter_name, by_attribute) + return getter() + + +def configuration_to_dict(handlers): + """Returns configuration data gathered by given handlers as a dict. + + :param list[ConfigHandler] handlers: Handlers list, + usually from parse_configuration() + + :rtype: dict + """ + config_dict = defaultdict(dict) + + for handler in handlers: + for option in handler.set_options: + value = _get_option(handler.target_obj, option) + config_dict[handler.section_prefix][option] = value + + return config_dict + + +def parse_configuration( + distribution, command_options, ignore_option_errors=False): + """Performs additional parsing of configuration options + for a distribution. + + Returns a list of used option handlers. + + :param Distribution distribution: + :param dict command_options: + :param bool ignore_option_errors: Whether to silently ignore + options, values of which could not be resolved (e.g. due to exceptions + in directives such as file:, attr:, etc.). + If False exceptions are propagated as expected. + :rtype: list + """ + options = ConfigOptionsHandler( + distribution, command_options, ignore_option_errors) + options.parse() + + meta = ConfigMetadataHandler( + distribution.metadata, command_options, ignore_option_errors, + distribution.package_dir) + meta.parse() + + return meta, options + + +class ConfigHandler: + """Handles metadata supplied in configuration files.""" + + section_prefix = None + """Prefix for config sections handled by this handler. + Must be provided by class heirs. + + """ + + aliases = {} + """Options aliases. + For compatibility with various packages. E.g.: d2to1 and pbr. + Note: `-` in keys is replaced with `_` by config parser. + + """ + + def __init__(self, target_obj, options, ignore_option_errors=False): + sections = {} + + section_prefix = self.section_prefix + for section_name, section_options in options.items(): + if not section_name.startswith(section_prefix): + continue + + section_name = section_name.replace(section_prefix, '').strip('.') + sections[section_name] = section_options + + self.ignore_option_errors = ignore_option_errors + self.target_obj = target_obj + self.sections = sections + self.set_options = [] + + @property + def parsers(self): + """Metadata item name to parser function mapping.""" + raise NotImplementedError( + '%s must provide .parsers property' % self.__class__.__name__) + + def __setitem__(self, option_name, value): + unknown = tuple() + target_obj = self.target_obj + + # Translate alias into real name. + option_name = self.aliases.get(option_name, option_name) + + current_value = getattr(target_obj, option_name, unknown) + + if current_value is unknown: + raise KeyError(option_name) + + if current_value: + # Already inhabited. Skipping. + return + + skip_option = False + parser = self.parsers.get(option_name) + if parser: + try: + value = parser(value) + + except Exception: + skip_option = True + if not self.ignore_option_errors: + raise + + if skip_option: + return + + setter = getattr(target_obj, 'set_%s' % option_name, None) + if setter is None: + setattr(target_obj, option_name, value) + else: + setter(value) + + self.set_options.append(option_name) + + @classmethod + def _parse_list(cls, value, separator=','): + """Represents value as a list. + + Value is split either by separator (defaults to comma) or by lines. + + :param value: + :param separator: List items separator character. + :rtype: list + """ + if isinstance(value, list): # _get_parser_compound case + return value + + if '\n' in value: + value = value.splitlines() + else: + value = value.split(separator) + + return [chunk.strip() for chunk in value if chunk.strip()] + + @classmethod + def _parse_dict(cls, value): + """Represents value as a dict. + + :param value: + :rtype: dict + """ + separator = '=' + result = {} + for line in cls._parse_list(value): + key, sep, val = line.partition(separator) + if sep != separator: + raise DistutilsOptionError( + 'Unable to parse option value to dict: %s' % value) + result[key.strip()] = val.strip() + + return result + + @classmethod + def _parse_bool(cls, value): + """Represents value as boolean. + + :param value: + :rtype: bool + """ + value = value.lower() + return value in ('1', 'true', 'yes') + + @classmethod + def _exclude_files_parser(cls, key): + """Returns a parser function to make sure field inputs + are not files. + + Parses a value after getting the key so error messages are + more informative. + + :param key: + :rtype: callable + """ + def parser(value): + exclude_directive = 'file:' + if value.startswith(exclude_directive): + raise ValueError( + 'Only strings are accepted for the {0} field, ' + 'files are not accepted'.format(key)) + return value + return parser + + @classmethod + def _parse_file(cls, value): + """Represents value as a string, allowing including text + from nearest files using `file:` directive. + + Directive is sandboxed and won't reach anything outside + directory with setup.py. + + Examples: + file: README.rst, CHANGELOG.md, src/file.txt + + :param str value: + :rtype: str + """ + include_directive = 'file:' + + if not isinstance(value, string_types): + return value + + if not value.startswith(include_directive): + return value + + spec = value[len(include_directive):] + filepaths = (os.path.abspath(path.strip()) for path in spec.split(',')) + return '\n'.join( + cls._read_file(path) + for path in filepaths + if (cls._assert_local(path) or True) + and os.path.isfile(path) + ) + + @staticmethod + def _assert_local(filepath): + if not filepath.startswith(os.getcwd()): + raise DistutilsOptionError( + '`file:` directive can not access %s' % filepath) + + @staticmethod + def _read_file(filepath): + with io.open(filepath, encoding='utf-8') as f: + return f.read() + + @classmethod + def _parse_attr(cls, value, package_dir=None): + """Represents value as a module attribute. + + Examples: + attr: package.attr + attr: package.module.attr + + :param str value: + :rtype: str + """ + attr_directive = 'attr:' + if not value.startswith(attr_directive): + return value + + attrs_path = value.replace(attr_directive, '').strip().split('.') + attr_name = attrs_path.pop() + + module_name = '.'.join(attrs_path) + module_name = module_name or '__init__' + + parent_path = os.getcwd() + if package_dir: + if attrs_path[0] in package_dir: + # A custom path was specified for the module we want to import + custom_path = package_dir[attrs_path[0]] + parts = custom_path.rsplit('/', 1) + if len(parts) > 1: + parent_path = os.path.join(os.getcwd(), parts[0]) + module_name = parts[1] + else: + module_name = custom_path + elif '' in package_dir: + # A custom parent directory was specified for all root modules + parent_path = os.path.join(os.getcwd(), package_dir['']) + sys.path.insert(0, parent_path) + try: + module = import_module(module_name) + value = getattr(module, attr_name) + + finally: + sys.path = sys.path[1:] + + return value + + @classmethod + def _get_parser_compound(cls, *parse_methods): + """Returns parser function to represents value as a list. + + Parses a value applying given methods one after another. + + :param parse_methods: + :rtype: callable + """ + def parse(value): + parsed = value + + for method in parse_methods: + parsed = method(parsed) + + return parsed + + return parse + + @classmethod + def _parse_section_to_dict(cls, section_options, values_parser=None): + """Parses section options into a dictionary. + + Optionally applies a given parser to values. + + :param dict section_options: + :param callable values_parser: + :rtype: dict + """ + value = {} + values_parser = values_parser or (lambda val: val) + for key, (_, val) in section_options.items(): + value[key] = values_parser(val) + return value + + def parse_section(self, section_options): + """Parses configuration file section. + + :param dict section_options: + """ + for (name, (_, value)) in section_options.items(): + try: + self[name] = value + + except KeyError: + pass # Keep silent for a new option may appear anytime. + + def parse(self): + """Parses configuration file items from one + or more related sections. + + """ + for section_name, section_options in self.sections.items(): + + method_postfix = '' + if section_name: # [section.option] variant + method_postfix = '_%s' % section_name + + section_parser_method = getattr( + self, + # Dots in section names are translated into dunderscores. + ('parse_section%s' % method_postfix).replace('.', '__'), + None) + + if section_parser_method is None: + raise DistutilsOptionError( + 'Unsupported distribution option section: [%s.%s]' % ( + self.section_prefix, section_name)) + + section_parser_method(section_options) + + def _deprecated_config_handler(self, func, msg, warning_class): + """ this function will wrap around parameters that are deprecated + + :param msg: deprecation message + :param warning_class: class of warning exception to be raised + :param func: function to be wrapped around + """ + @wraps(func) + def config_handler(*args, **kwargs): + warnings.warn(msg, warning_class) + return func(*args, **kwargs) + + return config_handler + + +class ConfigMetadataHandler(ConfigHandler): + + section_prefix = 'metadata' + + aliases = { + 'home_page': 'url', + 'summary': 'description', + 'classifier': 'classifiers', + 'platform': 'platforms', + } + + strict_mode = False + """We need to keep it loose, to be partially compatible with + `pbr` and `d2to1` packages which also uses `metadata` section. + + """ + + def __init__(self, target_obj, options, ignore_option_errors=False, + package_dir=None): + super(ConfigMetadataHandler, self).__init__(target_obj, options, + ignore_option_errors) + self.package_dir = package_dir + + @property + def parsers(self): + """Metadata item name to parser function mapping.""" + parse_list = self._parse_list + parse_file = self._parse_file + parse_dict = self._parse_dict + exclude_files_parser = self._exclude_files_parser + + return { + 'platforms': parse_list, + 'keywords': parse_list, + 'provides': parse_list, + 'requires': self._deprecated_config_handler( + parse_list, + "The requires parameter is deprecated, please use " + "install_requires for runtime dependencies.", + DeprecationWarning), + 'obsoletes': parse_list, + 'classifiers': self._get_parser_compound(parse_file, parse_list), + 'license': exclude_files_parser('license'), + 'description': parse_file, + 'long_description': parse_file, + 'version': self._parse_version, + 'project_urls': parse_dict, + } + + def _parse_version(self, value): + """Parses `version` option value. + + :param value: + :rtype: str + + """ + version = self._parse_file(value) + + if version != value: + version = version.strip() + # Be strict about versions loaded from file because it's easy to + # accidentally include newlines and other unintended content + if isinstance(parse(version), LegacyVersion): + tmpl = ( + 'Version loaded from {value} does not ' + 'comply with PEP 440: {version}' + ) + raise DistutilsOptionError(tmpl.format(**locals())) + + return version + + version = self._parse_attr(value, self.package_dir) + + if callable(version): + version = version() + + if not isinstance(version, string_types): + if hasattr(version, '__iter__'): + version = '.'.join(map(str, version)) + else: + version = '%s' % version + + return version + + +class ConfigOptionsHandler(ConfigHandler): + + section_prefix = 'options' + + @property + def parsers(self): + """Metadata item name to parser function mapping.""" + parse_list = self._parse_list + parse_list_semicolon = partial(self._parse_list, separator=';') + parse_bool = self._parse_bool + parse_dict = self._parse_dict + + return { + 'zip_safe': parse_bool, + 'use_2to3': parse_bool, + 'include_package_data': parse_bool, + 'package_dir': parse_dict, + 'use_2to3_fixers': parse_list, + 'use_2to3_exclude_fixers': parse_list, + 'convert_2to3_doctests': parse_list, + 'scripts': parse_list, + 'eager_resources': parse_list, + 'dependency_links': parse_list, + 'namespace_packages': parse_list, + 'install_requires': parse_list_semicolon, + 'setup_requires': parse_list_semicolon, + 'tests_require': parse_list_semicolon, + 'packages': self._parse_packages, + 'entry_points': self._parse_file, + 'py_modules': parse_list, + } + + def _parse_packages(self, value): + """Parses `packages` option value. + + :param value: + :rtype: list + """ + find_directives = ['find:', 'find_namespace:'] + trimmed_value = value.strip() + + if trimmed_value not in find_directives: + return self._parse_list(value) + + findns = trimmed_value == find_directives[1] + if findns and not PY3: + raise DistutilsOptionError( + 'find_namespace: directive is unsupported on Python < 3.3') + + # Read function arguments from a dedicated section. + find_kwargs = self.parse_section_packages__find( + self.sections.get('packages.find', {})) + + if findns: + from setuptools import find_namespace_packages as find_packages + else: + from setuptools import find_packages + + return find_packages(**find_kwargs) + + def parse_section_packages__find(self, section_options): + """Parses `packages.find` configuration file section. + + To be used in conjunction with _parse_packages(). + + :param dict section_options: + """ + section_data = self._parse_section_to_dict( + section_options, self._parse_list) + + valid_keys = ['where', 'include', 'exclude'] + + find_kwargs = dict( + [(k, v) for k, v in section_data.items() if k in valid_keys and v]) + + where = find_kwargs.get('where') + if where is not None: + find_kwargs['where'] = where[0] # cast list to single val + + return find_kwargs + + def parse_section_entry_points(self, section_options): + """Parses `entry_points` configuration file section. + + :param dict section_options: + """ + parsed = self._parse_section_to_dict(section_options, self._parse_list) + self['entry_points'] = parsed + + def _parse_package_data(self, section_options): + parsed = self._parse_section_to_dict(section_options, self._parse_list) + + root = parsed.get('*') + if root: + parsed[''] = root + del parsed['*'] + + return parsed + + def parse_section_package_data(self, section_options): + """Parses `package_data` configuration file section. + + :param dict section_options: + """ + self['package_data'] = self._parse_package_data(section_options) + + def parse_section_exclude_package_data(self, section_options): + """Parses `exclude_package_data` configuration file section. + + :param dict section_options: + """ + self['exclude_package_data'] = self._parse_package_data( + section_options) + + def parse_section_extras_require(self, section_options): + """Parses `extras_require` configuration file section. + + :param dict section_options: + """ + parse_list = partial(self._parse_list, separator=';') + self['extras_require'] = self._parse_section_to_dict( + section_options, parse_list) + + def parse_section_data_files(self, section_options): + """Parses `data_files` configuration file section. + + :param dict section_options: + """ + parsed = self._parse_section_to_dict(section_options, self._parse_list) + self['data_files'] = [(k, v) for k, v in parsed.items()] diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/dep_util.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/dep_util.py new file mode 100644 index 0000000..2931c13 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/dep_util.py @@ -0,0 +1,23 @@ +from distutils.dep_util import newer_group + +# yes, this is was almost entirely copy-pasted from +# 'newer_pairwise()', this is just another convenience +# function. +def newer_pairwise_group(sources_groups, targets): + """Walk both arguments in parallel, testing if each source group is newer + than its corresponding target. Returns a pair of lists (sources_groups, + targets) where sources is newer than target, according to the semantics + of 'newer_group()'. + """ + if len(sources_groups) != len(targets): + raise ValueError("'sources_group' and 'targets' must be the same length") + + # build a pair of lists (sources_groups, targets) where source is newer + n_sources = [] + n_targets = [] + for i in range(len(sources_groups)): + if newer_group(sources_groups[i], targets[i]): + n_sources.append(sources_groups[i]) + n_targets.append(targets[i]) + + return n_sources, n_targets diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/depends.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/depends.py new file mode 100644 index 0000000..45e7052 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/depends.py @@ -0,0 +1,186 @@ +import sys +import imp +import marshal +from distutils.version import StrictVersion +from imp import PKG_DIRECTORY, PY_COMPILED, PY_SOURCE, PY_FROZEN + +from .py33compat import Bytecode + + +__all__ = [ + 'Require', 'find_module', 'get_module_constant', 'extract_constant' +] + + +class Require: + """A prerequisite to building or installing a distribution""" + + def __init__(self, name, requested_version, module, homepage='', + attribute=None, format=None): + + if format is None and requested_version is not None: + format = StrictVersion + + if format is not None: + requested_version = format(requested_version) + if attribute is None: + attribute = '__version__' + + self.__dict__.update(locals()) + del self.self + + def full_name(self): + """Return full package/distribution name, w/version""" + if self.requested_version is not None: + return '%s-%s' % (self.name, self.requested_version) + return self.name + + def version_ok(self, version): + """Is 'version' sufficiently up-to-date?""" + return self.attribute is None or self.format is None or \ + str(version) != "unknown" and version >= self.requested_version + + def get_version(self, paths=None, default="unknown"): + """Get version number of installed module, 'None', or 'default' + + Search 'paths' for module. If not found, return 'None'. If found, + return the extracted version attribute, or 'default' if no version + attribute was specified, or the value cannot be determined without + importing the module. The version is formatted according to the + requirement's version format (if any), unless it is 'None' or the + supplied 'default'. + """ + + if self.attribute is None: + try: + f, p, i = find_module(self.module, paths) + if f: + f.close() + return default + except ImportError: + return None + + v = get_module_constant(self.module, self.attribute, default, paths) + + if v is not None and v is not default and self.format is not None: + return self.format(v) + + return v + + def is_present(self, paths=None): + """Return true if dependency is present on 'paths'""" + return self.get_version(paths) is not None + + def is_current(self, paths=None): + """Return true if dependency is present and up-to-date on 'paths'""" + version = self.get_version(paths) + if version is None: + return False + return self.version_ok(version) + + +def find_module(module, paths=None): + """Just like 'imp.find_module()', but with package support""" + + parts = module.split('.') + + while parts: + part = parts.pop(0) + f, path, (suffix, mode, kind) = info = imp.find_module(part, paths) + + if kind == PKG_DIRECTORY: + parts = parts or ['__init__'] + paths = [path] + + elif parts: + raise ImportError("Can't find %r in %s" % (parts, module)) + + return info + + +def get_module_constant(module, symbol, default=-1, paths=None): + """Find 'module' by searching 'paths', and extract 'symbol' + + Return 'None' if 'module' does not exist on 'paths', or it does not define + 'symbol'. If the module defines 'symbol' as a constant, return the + constant. Otherwise, return 'default'.""" + + try: + f, path, (suffix, mode, kind) = find_module(module, paths) + except ImportError: + # Module doesn't exist + return None + + try: + if kind == PY_COMPILED: + f.read(8) # skip magic & date + code = marshal.load(f) + elif kind == PY_FROZEN: + code = imp.get_frozen_object(module) + elif kind == PY_SOURCE: + code = compile(f.read(), path, 'exec') + else: + # Not something we can parse; we'll have to import it. :( + if module not in sys.modules: + imp.load_module(module, f, path, (suffix, mode, kind)) + return getattr(sys.modules[module], symbol, None) + + finally: + if f: + f.close() + + return extract_constant(code, symbol, default) + + +def extract_constant(code, symbol, default=-1): + """Extract the constant value of 'symbol' from 'code' + + If the name 'symbol' is bound to a constant value by the Python code + object 'code', return that value. If 'symbol' is bound to an expression, + return 'default'. Otherwise, return 'None'. + + Return value is based on the first assignment to 'symbol'. 'symbol' must + be a global, or at least a non-"fast" local in the code block. That is, + only 'STORE_NAME' and 'STORE_GLOBAL' opcodes are checked, and 'symbol' + must be present in 'code.co_names'. + """ + if symbol not in code.co_names: + # name's not there, can't possibly be an assignment + return None + + name_idx = list(code.co_names).index(symbol) + + STORE_NAME = 90 + STORE_GLOBAL = 97 + LOAD_CONST = 100 + + const = default + + for byte_code in Bytecode(code): + op = byte_code.opcode + arg = byte_code.arg + + if op == LOAD_CONST: + const = code.co_consts[arg] + elif arg == name_idx and (op == STORE_NAME or op == STORE_GLOBAL): + return const + else: + const = default + + +def _update_globals(): + """ + Patch the globals to remove the objects not available on some platforms. + + XXX it'd be better to test assertions about bytecode instead. + """ + + if not sys.platform.startswith('java') and sys.platform != 'cli': + return + incompatible = 'extract_constant', 'get_module_constant' + for name in incompatible: + del globals()[name] + __all__.remove(name) + + +_update_globals() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/dist.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/dist.py new file mode 100644 index 0000000..f0f030b --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/dist.py @@ -0,0 +1,1280 @@ +# -*- coding: utf-8 -*- +__all__ = ['Distribution'] + +import io +import sys +import re +import os +import warnings +import numbers +import distutils.log +import distutils.core +import distutils.cmd +import distutils.dist +from distutils.util import strtobool +from distutils.debug import DEBUG +from distutils.fancy_getopt import translate_longopt +import itertools + +from collections import defaultdict +from email import message_from_file + +from distutils.errors import ( + DistutilsOptionError, DistutilsPlatformError, DistutilsSetupError, +) +from distutils.util import rfc822_escape +from distutils.version import StrictVersion + +from setuptools.extern import six +from setuptools.extern import packaging +from setuptools.extern.six.moves import map, filter, filterfalse + +from . import SetuptoolsDeprecationWarning + +from setuptools.depends import Require +from setuptools import windows_support +from setuptools.monkey import get_unpatched +from setuptools.config import parse_configuration +import pkg_resources + +__import__('setuptools.extern.packaging.specifiers') +__import__('setuptools.extern.packaging.version') + + +def _get_unpatched(cls): + warnings.warn("Do not call this function", DistDeprecationWarning) + return get_unpatched(cls) + + +def get_metadata_version(self): + mv = getattr(self, 'metadata_version', None) + + if mv is None: + if self.long_description_content_type or self.provides_extras: + mv = StrictVersion('2.1') + elif (self.maintainer is not None or + self.maintainer_email is not None or + getattr(self, 'python_requires', None) is not None or + self.project_urls): + mv = StrictVersion('1.2') + elif (self.provides or self.requires or self.obsoletes or + self.classifiers or self.download_url): + mv = StrictVersion('1.1') + else: + mv = StrictVersion('1.0') + + self.metadata_version = mv + + return mv + + +def read_pkg_file(self, file): + """Reads the metadata values from a file object.""" + msg = message_from_file(file) + + def _read_field(name): + value = msg[name] + if value == 'UNKNOWN': + return None + return value + + def _read_list(name): + values = msg.get_all(name, None) + if values == []: + return None + return values + + self.metadata_version = StrictVersion(msg['metadata-version']) + self.name = _read_field('name') + self.version = _read_field('version') + self.description = _read_field('summary') + # we are filling author only. + self.author = _read_field('author') + self.maintainer = None + self.author_email = _read_field('author-email') + self.maintainer_email = None + self.url = _read_field('home-page') + self.license = _read_field('license') + + if 'download-url' in msg: + self.download_url = _read_field('download-url') + else: + self.download_url = None + + self.long_description = _read_field('description') + self.description = _read_field('summary') + + if 'keywords' in msg: + self.keywords = _read_field('keywords').split(',') + + self.platforms = _read_list('platform') + self.classifiers = _read_list('classifier') + + # PEP 314 - these fields only exist in 1.1 + if self.metadata_version == StrictVersion('1.1'): + self.requires = _read_list('requires') + self.provides = _read_list('provides') + self.obsoletes = _read_list('obsoletes') + else: + self.requires = None + self.provides = None + self.obsoletes = None + + +# Based on Python 3.5 version +def write_pkg_file(self, file): + """Write the PKG-INFO format data to a file object. + """ + version = self.get_metadata_version() + + if six.PY2: + def write_field(key, value): + file.write("%s: %s\n" % (key, self._encode_field(value))) + else: + def write_field(key, value): + file.write("%s: %s\n" % (key, value)) + + write_field('Metadata-Version', str(version)) + write_field('Name', self.get_name()) + write_field('Version', self.get_version()) + write_field('Summary', self.get_description()) + write_field('Home-page', self.get_url()) + + if version < StrictVersion('1.2'): + write_field('Author', self.get_contact()) + write_field('Author-email', self.get_contact_email()) + else: + optional_fields = ( + ('Author', 'author'), + ('Author-email', 'author_email'), + ('Maintainer', 'maintainer'), + ('Maintainer-email', 'maintainer_email'), + ) + + for field, attr in optional_fields: + attr_val = getattr(self, attr) + + if attr_val is not None: + write_field(field, attr_val) + + write_field('License', self.get_license()) + if self.download_url: + write_field('Download-URL', self.download_url) + for project_url in self.project_urls.items(): + write_field('Project-URL', '%s, %s' % project_url) + + long_desc = rfc822_escape(self.get_long_description()) + write_field('Description', long_desc) + + keywords = ','.join(self.get_keywords()) + if keywords: + write_field('Keywords', keywords) + + if version >= StrictVersion('1.2'): + for platform in self.get_platforms(): + write_field('Platform', platform) + else: + self._write_list(file, 'Platform', self.get_platforms()) + + self._write_list(file, 'Classifier', self.get_classifiers()) + + # PEP 314 + self._write_list(file, 'Requires', self.get_requires()) + self._write_list(file, 'Provides', self.get_provides()) + self._write_list(file, 'Obsoletes', self.get_obsoletes()) + + # Setuptools specific for PEP 345 + if hasattr(self, 'python_requires'): + write_field('Requires-Python', self.python_requires) + + # PEP 566 + if self.long_description_content_type: + write_field( + 'Description-Content-Type', + self.long_description_content_type + ) + if self.provides_extras: + for extra in self.provides_extras: + write_field('Provides-Extra', extra) + + +sequence = tuple, list + + +def check_importable(dist, attr, value): + try: + ep = pkg_resources.EntryPoint.parse('x=' + value) + assert not ep.extras + except (TypeError, ValueError, AttributeError, AssertionError): + raise DistutilsSetupError( + "%r must be importable 'module:attrs' string (got %r)" + % (attr, value) + ) + + +def assert_string_list(dist, attr, value): + """Verify that value is a string list""" + try: + # verify that value is a list or tuple to exclude unordered + # or single-use iterables + assert isinstance(value, (list, tuple)) + # verify that elements of value are strings + assert ''.join(value) != value + except (TypeError, ValueError, AttributeError, AssertionError): + raise DistutilsSetupError( + "%r must be a list of strings (got %r)" % (attr, value) + ) + + +def check_nsp(dist, attr, value): + """Verify that namespace packages are valid""" + ns_packages = value + assert_string_list(dist, attr, ns_packages) + for nsp in ns_packages: + if not dist.has_contents_for(nsp): + raise DistutilsSetupError( + "Distribution contains no modules or packages for " + + "namespace package %r" % nsp + ) + parent, sep, child = nsp.rpartition('.') + if parent and parent not in ns_packages: + distutils.log.warn( + "WARNING: %r is declared as a package namespace, but %r" + " is not: please correct this in setup.py", nsp, parent + ) + + +def check_extras(dist, attr, value): + """Verify that extras_require mapping is valid""" + try: + list(itertools.starmap(_check_extra, value.items())) + except (TypeError, ValueError, AttributeError): + raise DistutilsSetupError( + "'extras_require' must be a dictionary whose values are " + "strings or lists of strings containing valid project/version " + "requirement specifiers." + ) + + +def _check_extra(extra, reqs): + name, sep, marker = extra.partition(':') + if marker and pkg_resources.invalid_marker(marker): + raise DistutilsSetupError("Invalid environment marker: " + marker) + list(pkg_resources.parse_requirements(reqs)) + + +def assert_bool(dist, attr, value): + """Verify that value is True, False, 0, or 1""" + if bool(value) != value: + tmpl = "{attr!r} must be a boolean value (got {value!r})" + raise DistutilsSetupError(tmpl.format(attr=attr, value=value)) + + +def check_requirements(dist, attr, value): + """Verify that install_requires is a valid requirements list""" + try: + list(pkg_resources.parse_requirements(value)) + if isinstance(value, (dict, set)): + raise TypeError("Unordered types are not allowed") + except (TypeError, ValueError) as error: + tmpl = ( + "{attr!r} must be a string or list of strings " + "containing valid project/version requirement specifiers; {error}" + ) + raise DistutilsSetupError(tmpl.format(attr=attr, error=error)) + + +def check_specifier(dist, attr, value): + """Verify that value is a valid version specifier""" + try: + packaging.specifiers.SpecifierSet(value) + except packaging.specifiers.InvalidSpecifier as error: + tmpl = ( + "{attr!r} must be a string " + "containing valid version specifiers; {error}" + ) + raise DistutilsSetupError(tmpl.format(attr=attr, error=error)) + + +def check_entry_points(dist, attr, value): + """Verify that entry_points map is parseable""" + try: + pkg_resources.EntryPoint.parse_map(value) + except ValueError as e: + raise DistutilsSetupError(e) + + +def check_test_suite(dist, attr, value): + if not isinstance(value, six.string_types): + raise DistutilsSetupError("test_suite must be a string") + + +def check_package_data(dist, attr, value): + """Verify that value is a dictionary of package names to glob lists""" + if not isinstance(value, dict): + raise DistutilsSetupError( + "{!r} must be a dictionary mapping package names to lists of " + "string wildcard patterns".format(attr)) + for k, v in value.items(): + if not isinstance(k, six.string_types): + raise DistutilsSetupError( + "keys of {!r} dict must be strings (got {!r})" + .format(attr, k) + ) + assert_string_list(dist, 'values of {!r} dict'.format(attr), v) + + +def check_packages(dist, attr, value): + for pkgname in value: + if not re.match(r'\w+(\.\w+)*', pkgname): + distutils.log.warn( + "WARNING: %r not a valid package name; please use only " + ".-separated package names in setup.py", pkgname + ) + + +_Distribution = get_unpatched(distutils.core.Distribution) + + +class Distribution(_Distribution): + """Distribution with support for features, tests, and package data + + This is an enhanced version of 'distutils.dist.Distribution' that + effectively adds the following new optional keyword arguments to 'setup()': + + 'install_requires' -- a string or sequence of strings specifying project + versions that the distribution requires when installed, in the format + used by 'pkg_resources.require()'. They will be installed + automatically when the package is installed. If you wish to use + packages that are not available in PyPI, or want to give your users an + alternate download location, you can add a 'find_links' option to the + '[easy_install]' section of your project's 'setup.cfg' file, and then + setuptools will scan the listed web pages for links that satisfy the + requirements. + + 'extras_require' -- a dictionary mapping names of optional "extras" to the + additional requirement(s) that using those extras incurs. For example, + this:: + + extras_require = dict(reST = ["docutils>=0.3", "reSTedit"]) + + indicates that the distribution can optionally provide an extra + capability called "reST", but it can only be used if docutils and + reSTedit are installed. If the user installs your package using + EasyInstall and requests one of your extras, the corresponding + additional requirements will be installed if needed. + + 'features' **deprecated** -- a dictionary mapping option names to + 'setuptools.Feature' + objects. Features are a portion of the distribution that can be + included or excluded based on user options, inter-feature dependencies, + and availability on the current system. Excluded features are omitted + from all setup commands, including source and binary distributions, so + you can create multiple distributions from the same source tree. + Feature names should be valid Python identifiers, except that they may + contain the '-' (minus) sign. Features can be included or excluded + via the command line options '--with-X' and '--without-X', where 'X' is + the name of the feature. Whether a feature is included by default, and + whether you are allowed to control this from the command line, is + determined by the Feature object. See the 'Feature' class for more + information. + + 'test_suite' -- the name of a test suite to run for the 'test' command. + If the user runs 'python setup.py test', the package will be installed, + and the named test suite will be run. The format is the same as + would be used on a 'unittest.py' command line. That is, it is the + dotted name of an object to import and call to generate a test suite. + + 'package_data' -- a dictionary mapping package names to lists of filenames + or globs to use to find data files contained in the named packages. + If the dictionary has filenames or globs listed under '""' (the empty + string), those names will be searched for in every package, in addition + to any names for the specific package. Data files found using these + names/globs will be installed along with the package, in the same + location as the package. Note that globs are allowed to reference + the contents of non-package subdirectories, as long as you use '/' as + a path separator. (Globs are automatically converted to + platform-specific paths at runtime.) + + In addition to these new keywords, this class also has several new methods + for manipulating the distribution's contents. For example, the 'include()' + and 'exclude()' methods can be thought of as in-place add and subtract + commands that add or remove packages, modules, extensions, and so on from + the distribution. They are used by the feature subsystem to configure the + distribution for the included and excluded features. + """ + + _DISTUTILS_UNSUPPORTED_METADATA = { + 'long_description_content_type': None, + 'project_urls': dict, + 'provides_extras': set, + } + + _patched_dist = None + + def patch_missing_pkg_info(self, attrs): + # Fake up a replacement for the data that would normally come from + # PKG-INFO, but which might not yet be built if this is a fresh + # checkout. + # + if not attrs or 'name' not in attrs or 'version' not in attrs: + return + key = pkg_resources.safe_name(str(attrs['name'])).lower() + dist = pkg_resources.working_set.by_key.get(key) + if dist is not None and not dist.has_metadata('PKG-INFO'): + dist._version = pkg_resources.safe_version(str(attrs['version'])) + self._patched_dist = dist + + def __init__(self, attrs=None): + have_package_data = hasattr(self, "package_data") + if not have_package_data: + self.package_data = {} + attrs = attrs or {} + if 'features' in attrs or 'require_features' in attrs: + Feature.warn_deprecated() + self.require_features = [] + self.features = {} + self.dist_files = [] + # Filter-out setuptools' specific options. + self.src_root = attrs.pop("src_root", None) + self.patch_missing_pkg_info(attrs) + self.dependency_links = attrs.pop('dependency_links', []) + self.setup_requires = attrs.pop('setup_requires', []) + for ep in pkg_resources.iter_entry_points('distutils.setup_keywords'): + vars(self).setdefault(ep.name, None) + _Distribution.__init__(self, { + k: v for k, v in attrs.items() + if k not in self._DISTUTILS_UNSUPPORTED_METADATA + }) + + # Fill-in missing metadata fields not supported by distutils. + # Note some fields may have been set by other tools (e.g. pbr) + # above; they are taken preferrentially to setup() arguments + for option, default in self._DISTUTILS_UNSUPPORTED_METADATA.items(): + for source in self.metadata.__dict__, attrs: + if option in source: + value = source[option] + break + else: + value = default() if default else None + setattr(self.metadata, option, value) + + if isinstance(self.metadata.version, numbers.Number): + # Some people apparently take "version number" too literally :) + self.metadata.version = str(self.metadata.version) + + if self.metadata.version is not None: + try: + ver = packaging.version.Version(self.metadata.version) + normalized_version = str(ver) + if self.metadata.version != normalized_version: + warnings.warn( + "Normalizing '%s' to '%s'" % ( + self.metadata.version, + normalized_version, + ) + ) + self.metadata.version = normalized_version + except (packaging.version.InvalidVersion, TypeError): + warnings.warn( + "The version specified (%r) is an invalid version, this " + "may not work as expected with newer versions of " + "setuptools, pip, and PyPI. Please see PEP 440 for more " + "details." % self.metadata.version + ) + self._finalize_requires() + + def _finalize_requires(self): + """ + Set `metadata.python_requires` and fix environment markers + in `install_requires` and `extras_require`. + """ + if getattr(self, 'python_requires', None): + self.metadata.python_requires = self.python_requires + + if getattr(self, 'extras_require', None): + for extra in self.extras_require.keys(): + # Since this gets called multiple times at points where the + # keys have become 'converted' extras, ensure that we are only + # truly adding extras we haven't seen before here. + extra = extra.split(':')[0] + if extra: + self.metadata.provides_extras.add(extra) + + self._convert_extras_requirements() + self._move_install_requirements_markers() + + def _convert_extras_requirements(self): + """ + Convert requirements in `extras_require` of the form + `"extra": ["barbazquux; {marker}"]` to + `"extra:{marker}": ["barbazquux"]`. + """ + spec_ext_reqs = getattr(self, 'extras_require', None) or {} + self._tmp_extras_require = defaultdict(list) + for section, v in spec_ext_reqs.items(): + # Do not strip empty sections. + self._tmp_extras_require[section] + for r in pkg_resources.parse_requirements(v): + suffix = self._suffix_for(r) + self._tmp_extras_require[section + suffix].append(r) + + @staticmethod + def _suffix_for(req): + """ + For a requirement, return the 'extras_require' suffix for + that requirement. + """ + return ':' + str(req.marker) if req.marker else '' + + def _move_install_requirements_markers(self): + """ + Move requirements in `install_requires` that are using environment + markers `extras_require`. + """ + + # divide the install_requires into two sets, simple ones still + # handled by install_requires and more complex ones handled + # by extras_require. + + def is_simple_req(req): + return not req.marker + + spec_inst_reqs = getattr(self, 'install_requires', None) or () + inst_reqs = list(pkg_resources.parse_requirements(spec_inst_reqs)) + simple_reqs = filter(is_simple_req, inst_reqs) + complex_reqs = filterfalse(is_simple_req, inst_reqs) + self.install_requires = list(map(str, simple_reqs)) + + for r in complex_reqs: + self._tmp_extras_require[':' + str(r.marker)].append(r) + self.extras_require = dict( + (k, [str(r) for r in map(self._clean_req, v)]) + for k, v in self._tmp_extras_require.items() + ) + + def _clean_req(self, req): + """ + Given a Requirement, remove environment markers and return it. + """ + req.marker = None + return req + + def _parse_config_files(self, filenames=None): + """ + Adapted from distutils.dist.Distribution.parse_config_files, + this method provides the same functionality in subtly-improved + ways. + """ + from setuptools.extern.six.moves.configparser import ConfigParser + + # Ignore install directory options if we have a venv + if six.PY3 and sys.prefix != sys.base_prefix: + ignore_options = [ + 'install-base', 'install-platbase', 'install-lib', + 'install-platlib', 'install-purelib', 'install-headers', + 'install-scripts', 'install-data', 'prefix', 'exec-prefix', + 'home', 'user', 'root'] + else: + ignore_options = [] + + ignore_options = frozenset(ignore_options) + + if filenames is None: + filenames = self.find_config_files() + + if DEBUG: + self.announce("Distribution.parse_config_files():") + + parser = ConfigParser() + for filename in filenames: + with io.open(filename, encoding='utf-8') as reader: + if DEBUG: + self.announce(" reading {filename}".format(**locals())) + (parser.read_file if six.PY3 else parser.readfp)(reader) + for section in parser.sections(): + options = parser.options(section) + opt_dict = self.get_option_dict(section) + + for opt in options: + if opt != '__name__' and opt not in ignore_options: + val = self._try_str(parser.get(section, opt)) + opt = opt.replace('-', '_') + opt_dict[opt] = (filename, val) + + # Make the ConfigParser forget everything (so we retain + # the original filenames that options come from) + parser.__init__() + + # If there was a "global" section in the config file, use it + # to set Distribution options. + + if 'global' in self.command_options: + for (opt, (src, val)) in self.command_options['global'].items(): + alias = self.negative_opt.get(opt) + try: + if alias: + setattr(self, alias, not strtobool(val)) + elif opt in ('verbose', 'dry_run'): # ugh! + setattr(self, opt, strtobool(val)) + else: + setattr(self, opt, val) + except ValueError as msg: + raise DistutilsOptionError(msg) + + @staticmethod + def _try_str(val): + """ + On Python 2, much of distutils relies on string values being of + type 'str' (bytes) and not unicode text. If the value can be safely + encoded to bytes using the default encoding, prefer that. + + Why the default encoding? Because that value can be implicitly + decoded back to text if needed. + + Ref #1653 + """ + if six.PY3: + return val + try: + return val.encode() + except UnicodeEncodeError: + pass + return val + + def _set_command_options(self, command_obj, option_dict=None): + """ + Set the options for 'command_obj' from 'option_dict'. Basically + this means copying elements of a dictionary ('option_dict') to + attributes of an instance ('command'). + + 'command_obj' must be a Command instance. If 'option_dict' is not + supplied, uses the standard option dictionary for this command + (from 'self.command_options'). + + (Adopted from distutils.dist.Distribution._set_command_options) + """ + command_name = command_obj.get_command_name() + if option_dict is None: + option_dict = self.get_option_dict(command_name) + + if DEBUG: + self.announce(" setting options for '%s' command:" % command_name) + for (option, (source, value)) in option_dict.items(): + if DEBUG: + self.announce(" %s = %s (from %s)" % (option, value, + source)) + try: + bool_opts = [translate_longopt(o) + for o in command_obj.boolean_options] + except AttributeError: + bool_opts = [] + try: + neg_opt = command_obj.negative_opt + except AttributeError: + neg_opt = {} + + try: + is_string = isinstance(value, six.string_types) + if option in neg_opt and is_string: + setattr(command_obj, neg_opt[option], not strtobool(value)) + elif option in bool_opts and is_string: + setattr(command_obj, option, strtobool(value)) + elif hasattr(command_obj, option): + setattr(command_obj, option, value) + else: + raise DistutilsOptionError( + "error in %s: command '%s' has no such option '%s'" + % (source, command_name, option)) + except ValueError as msg: + raise DistutilsOptionError(msg) + + def parse_config_files(self, filenames=None, ignore_option_errors=False): + """Parses configuration files from various levels + and loads configuration. + + """ + self._parse_config_files(filenames=filenames) + + parse_configuration(self, self.command_options, + ignore_option_errors=ignore_option_errors) + self._finalize_requires() + + def parse_command_line(self): + """Process features after parsing command line options""" + result = _Distribution.parse_command_line(self) + if self.features: + self._finalize_features() + return result + + def _feature_attrname(self, name): + """Convert feature name to corresponding option attribute name""" + return 'with_' + name.replace('-', '_') + + def fetch_build_eggs(self, requires): + """Resolve pre-setup requirements""" + resolved_dists = pkg_resources.working_set.resolve( + pkg_resources.parse_requirements(requires), + installer=self.fetch_build_egg, + replace_conflicting=True, + ) + for dist in resolved_dists: + pkg_resources.working_set.add(dist, replace=True) + return resolved_dists + + def finalize_options(self): + _Distribution.finalize_options(self) + if self.features: + self._set_global_opts_from_features() + + for ep in pkg_resources.iter_entry_points('distutils.setup_keywords'): + value = getattr(self, ep.name, None) + if value is not None: + ep.require(installer=self.fetch_build_egg) + ep.load()(self, ep.name, value) + if getattr(self, 'convert_2to3_doctests', None): + # XXX may convert to set here when we can rely on set being builtin + self.convert_2to3_doctests = [ + os.path.abspath(p) + for p in self.convert_2to3_doctests + ] + else: + self.convert_2to3_doctests = [] + + def get_egg_cache_dir(self): + egg_cache_dir = os.path.join(os.curdir, '.eggs') + if not os.path.exists(egg_cache_dir): + os.mkdir(egg_cache_dir) + windows_support.hide_file(egg_cache_dir) + readme_txt_filename = os.path.join(egg_cache_dir, 'README.txt') + with open(readme_txt_filename, 'w') as f: + f.write('This directory contains eggs that were downloaded ' + 'by setuptools to build, test, and run plug-ins.\n\n') + f.write('This directory caches those eggs to prevent ' + 'repeated downloads.\n\n') + f.write('However, it is safe to delete this directory.\n\n') + + return egg_cache_dir + + def fetch_build_egg(self, req): + """Fetch an egg needed for building""" + from setuptools.command.easy_install import easy_install + dist = self.__class__({'script_args': ['easy_install']}) + opts = dist.get_option_dict('easy_install') + opts.clear() + opts.update( + (k, v) + for k, v in self.get_option_dict('easy_install').items() + if k in ( + # don't use any other settings + 'find_links', 'site_dirs', 'index_url', + 'optimize', 'site_dirs', 'allow_hosts', + )) + if self.dependency_links: + links = self.dependency_links[:] + if 'find_links' in opts: + links = opts['find_links'][1] + links + opts['find_links'] = ('setup', links) + install_dir = self.get_egg_cache_dir() + cmd = easy_install( + dist, args=["x"], install_dir=install_dir, + exclude_scripts=True, + always_copy=False, build_directory=None, editable=False, + upgrade=False, multi_version=True, no_report=True, user=False + ) + cmd.ensure_finalized() + return cmd.easy_install(req) + + def _set_global_opts_from_features(self): + """Add --with-X/--without-X options based on optional features""" + + go = [] + no = self.negative_opt.copy() + + for name, feature in self.features.items(): + self._set_feature(name, None) + feature.validate(self) + + if feature.optional: + descr = feature.description + incdef = ' (default)' + excdef = '' + if not feature.include_by_default(): + excdef, incdef = incdef, excdef + + new = ( + ('with-' + name, None, 'include ' + descr + incdef), + ('without-' + name, None, 'exclude ' + descr + excdef), + ) + go.extend(new) + no['without-' + name] = 'with-' + name + + self.global_options = self.feature_options = go + self.global_options + self.negative_opt = self.feature_negopt = no + + def _finalize_features(self): + """Add/remove features and resolve dependencies between them""" + + # First, flag all the enabled items (and thus their dependencies) + for name, feature in self.features.items(): + enabled = self.feature_is_included(name) + if enabled or (enabled is None and feature.include_by_default()): + feature.include_in(self) + self._set_feature(name, 1) + + # Then disable the rest, so that off-by-default features don't + # get flagged as errors when they're required by an enabled feature + for name, feature in self.features.items(): + if not self.feature_is_included(name): + feature.exclude_from(self) + self._set_feature(name, 0) + + def get_command_class(self, command): + """Pluggable version of get_command_class()""" + if command in self.cmdclass: + return self.cmdclass[command] + + eps = pkg_resources.iter_entry_points('distutils.commands', command) + for ep in eps: + ep.require(installer=self.fetch_build_egg) + self.cmdclass[command] = cmdclass = ep.load() + return cmdclass + else: + return _Distribution.get_command_class(self, command) + + def print_commands(self): + for ep in pkg_resources.iter_entry_points('distutils.commands'): + if ep.name not in self.cmdclass: + # don't require extras as the commands won't be invoked + cmdclass = ep.resolve() + self.cmdclass[ep.name] = cmdclass + return _Distribution.print_commands(self) + + def get_command_list(self): + for ep in pkg_resources.iter_entry_points('distutils.commands'): + if ep.name not in self.cmdclass: + # don't require extras as the commands won't be invoked + cmdclass = ep.resolve() + self.cmdclass[ep.name] = cmdclass + return _Distribution.get_command_list(self) + + def _set_feature(self, name, status): + """Set feature's inclusion status""" + setattr(self, self._feature_attrname(name), status) + + def feature_is_included(self, name): + """Return 1 if feature is included, 0 if excluded, 'None' if unknown""" + return getattr(self, self._feature_attrname(name)) + + def include_feature(self, name): + """Request inclusion of feature named 'name'""" + + if self.feature_is_included(name) == 0: + descr = self.features[name].description + raise DistutilsOptionError( + descr + " is required, but was excluded or is not available" + ) + self.features[name].include_in(self) + self._set_feature(name, 1) + + def include(self, **attrs): + """Add items to distribution that are named in keyword arguments + + For example, 'dist.include(py_modules=["x"])' would add 'x' to + the distribution's 'py_modules' attribute, if it was not already + there. + + Currently, this method only supports inclusion for attributes that are + lists or tuples. If you need to add support for adding to other + attributes in this or a subclass, you can add an '_include_X' method, + where 'X' is the name of the attribute. The method will be called with + the value passed to 'include()'. So, 'dist.include(foo={"bar":"baz"})' + will try to call 'dist._include_foo({"bar":"baz"})', which can then + handle whatever special inclusion logic is needed. + """ + for k, v in attrs.items(): + include = getattr(self, '_include_' + k, None) + if include: + include(v) + else: + self._include_misc(k, v) + + def exclude_package(self, package): + """Remove packages, modules, and extensions in named package""" + + pfx = package + '.' + if self.packages: + self.packages = [ + p for p in self.packages + if p != package and not p.startswith(pfx) + ] + + if self.py_modules: + self.py_modules = [ + p for p in self.py_modules + if p != package and not p.startswith(pfx) + ] + + if self.ext_modules: + self.ext_modules = [ + p for p in self.ext_modules + if p.name != package and not p.name.startswith(pfx) + ] + + def has_contents_for(self, package): + """Return true if 'exclude_package(package)' would do something""" + + pfx = package + '.' + + for p in self.iter_distribution_names(): + if p == package or p.startswith(pfx): + return True + + def _exclude_misc(self, name, value): + """Handle 'exclude()' for list/tuple attrs without a special handler""" + if not isinstance(value, sequence): + raise DistutilsSetupError( + "%s: setting must be a list or tuple (%r)" % (name, value) + ) + try: + old = getattr(self, name) + except AttributeError: + raise DistutilsSetupError( + "%s: No such distribution setting" % name + ) + if old is not None and not isinstance(old, sequence): + raise DistutilsSetupError( + name + ": this setting cannot be changed via include/exclude" + ) + elif old: + setattr(self, name, [item for item in old if item not in value]) + + def _include_misc(self, name, value): + """Handle 'include()' for list/tuple attrs without a special handler""" + + if not isinstance(value, sequence): + raise DistutilsSetupError( + "%s: setting must be a list (%r)" % (name, value) + ) + try: + old = getattr(self, name) + except AttributeError: + raise DistutilsSetupError( + "%s: No such distribution setting" % name + ) + if old is None: + setattr(self, name, value) + elif not isinstance(old, sequence): + raise DistutilsSetupError( + name + ": this setting cannot be changed via include/exclude" + ) + else: + new = [item for item in value if item not in old] + setattr(self, name, old + new) + + def exclude(self, **attrs): + """Remove items from distribution that are named in keyword arguments + + For example, 'dist.exclude(py_modules=["x"])' would remove 'x' from + the distribution's 'py_modules' attribute. Excluding packages uses + the 'exclude_package()' method, so all of the package's contained + packages, modules, and extensions are also excluded. + + Currently, this method only supports exclusion from attributes that are + lists or tuples. If you need to add support for excluding from other + attributes in this or a subclass, you can add an '_exclude_X' method, + where 'X' is the name of the attribute. The method will be called with + the value passed to 'exclude()'. So, 'dist.exclude(foo={"bar":"baz"})' + will try to call 'dist._exclude_foo({"bar":"baz"})', which can then + handle whatever special exclusion logic is needed. + """ + for k, v in attrs.items(): + exclude = getattr(self, '_exclude_' + k, None) + if exclude: + exclude(v) + else: + self._exclude_misc(k, v) + + def _exclude_packages(self, packages): + if not isinstance(packages, sequence): + raise DistutilsSetupError( + "packages: setting must be a list or tuple (%r)" % (packages,) + ) + list(map(self.exclude_package, packages)) + + def _parse_command_opts(self, parser, args): + # Remove --with-X/--without-X options when processing command args + self.global_options = self.__class__.global_options + self.negative_opt = self.__class__.negative_opt + + # First, expand any aliases + command = args[0] + aliases = self.get_option_dict('aliases') + while command in aliases: + src, alias = aliases[command] + del aliases[command] # ensure each alias can expand only once! + import shlex + args[:1] = shlex.split(alias, True) + command = args[0] + + nargs = _Distribution._parse_command_opts(self, parser, args) + + # Handle commands that want to consume all remaining arguments + cmd_class = self.get_command_class(command) + if getattr(cmd_class, 'command_consumes_arguments', None): + self.get_option_dict(command)['args'] = ("command line", nargs) + if nargs is not None: + return [] + + return nargs + + def get_cmdline_options(self): + """Return a '{cmd: {opt:val}}' map of all command-line options + + Option names are all long, but do not include the leading '--', and + contain dashes rather than underscores. If the option doesn't take + an argument (e.g. '--quiet'), the 'val' is 'None'. + + Note that options provided by config files are intentionally excluded. + """ + + d = {} + + for cmd, opts in self.command_options.items(): + + for opt, (src, val) in opts.items(): + + if src != "command line": + continue + + opt = opt.replace('_', '-') + + if val == 0: + cmdobj = self.get_command_obj(cmd) + neg_opt = self.negative_opt.copy() + neg_opt.update(getattr(cmdobj, 'negative_opt', {})) + for neg, pos in neg_opt.items(): + if pos == opt: + opt = neg + val = None + break + else: + raise AssertionError("Shouldn't be able to get here") + + elif val == 1: + val = None + + d.setdefault(cmd, {})[opt] = val + + return d + + def iter_distribution_names(self): + """Yield all packages, modules, and extension names in distribution""" + + for pkg in self.packages or (): + yield pkg + + for module in self.py_modules or (): + yield module + + for ext in self.ext_modules or (): + if isinstance(ext, tuple): + name, buildinfo = ext + else: + name = ext.name + if name.endswith('module'): + name = name[:-6] + yield name + + def handle_display_options(self, option_order): + """If there were any non-global "display-only" options + (--help-commands or the metadata display options) on the command + line, display the requested info and return true; else return + false. + """ + import sys + + if six.PY2 or self.help_commands: + return _Distribution.handle_display_options(self, option_order) + + # Stdout may be StringIO (e.g. in tests) + if not isinstance(sys.stdout, io.TextIOWrapper): + return _Distribution.handle_display_options(self, option_order) + + # Don't wrap stdout if utf-8 is already the encoding. Provides + # workaround for #334. + if sys.stdout.encoding.lower() in ('utf-8', 'utf8'): + return _Distribution.handle_display_options(self, option_order) + + # Print metadata in UTF-8 no matter the platform + encoding = sys.stdout.encoding + errors = sys.stdout.errors + newline = sys.platform != 'win32' and '\n' or None + line_buffering = sys.stdout.line_buffering + + sys.stdout = io.TextIOWrapper( + sys.stdout.detach(), 'utf-8', errors, newline, line_buffering) + try: + return _Distribution.handle_display_options(self, option_order) + finally: + sys.stdout = io.TextIOWrapper( + sys.stdout.detach(), encoding, errors, newline, line_buffering) + + +class Feature: + """ + **deprecated** -- The `Feature` facility was never completely implemented + or supported, `has reported issues + <https://github.com/pypa/setuptools/issues/58>`_ and will be removed in + a future version. + + A subset of the distribution that can be excluded if unneeded/wanted + + Features are created using these keyword arguments: + + 'description' -- a short, human readable description of the feature, to + be used in error messages, and option help messages. + + 'standard' -- if true, the feature is included by default if it is + available on the current system. Otherwise, the feature is only + included if requested via a command line '--with-X' option, or if + another included feature requires it. The default setting is 'False'. + + 'available' -- if true, the feature is available for installation on the + current system. The default setting is 'True'. + + 'optional' -- if true, the feature's inclusion can be controlled from the + command line, using the '--with-X' or '--without-X' options. If + false, the feature's inclusion status is determined automatically, + based on 'availabile', 'standard', and whether any other feature + requires it. The default setting is 'True'. + + 'require_features' -- a string or sequence of strings naming features + that should also be included if this feature is included. Defaults to + empty list. May also contain 'Require' objects that should be + added/removed from the distribution. + + 'remove' -- a string or list of strings naming packages to be removed + from the distribution if this feature is *not* included. If the + feature *is* included, this argument is ignored. This argument exists + to support removing features that "crosscut" a distribution, such as + defining a 'tests' feature that removes all the 'tests' subpackages + provided by other features. The default for this argument is an empty + list. (Note: the named package(s) or modules must exist in the base + distribution when the 'setup()' function is initially called.) + + other keywords -- any other keyword arguments are saved, and passed to + the distribution's 'include()' and 'exclude()' methods when the + feature is included or excluded, respectively. So, for example, you + could pass 'packages=["a","b"]' to cause packages 'a' and 'b' to be + added or removed from the distribution as appropriate. + + A feature must include at least one 'requires', 'remove', or other + keyword argument. Otherwise, it can't affect the distribution in any way. + Note also that you can subclass 'Feature' to create your own specialized + feature types that modify the distribution in other ways when included or + excluded. See the docstrings for the various methods here for more detail. + Aside from the methods, the only feature attributes that distributions look + at are 'description' and 'optional'. + """ + + @staticmethod + def warn_deprecated(): + msg = ( + "Features are deprecated and will be removed in a future " + "version. See https://github.com/pypa/setuptools/issues/65." + ) + warnings.warn(msg, DistDeprecationWarning, stacklevel=3) + + def __init__( + self, description, standard=False, available=True, + optional=True, require_features=(), remove=(), **extras): + self.warn_deprecated() + + self.description = description + self.standard = standard + self.available = available + self.optional = optional + if isinstance(require_features, (str, Require)): + require_features = require_features, + + self.require_features = [ + r for r in require_features if isinstance(r, str) + ] + er = [r for r in require_features if not isinstance(r, str)] + if er: + extras['require_features'] = er + + if isinstance(remove, str): + remove = remove, + self.remove = remove + self.extras = extras + + if not remove and not require_features and not extras: + raise DistutilsSetupError( + "Feature %s: must define 'require_features', 'remove', or " + "at least one of 'packages', 'py_modules', etc." + ) + + def include_by_default(self): + """Should this feature be included by default?""" + return self.available and self.standard + + def include_in(self, dist): + """Ensure feature and its requirements are included in distribution + + You may override this in a subclass to perform additional operations on + the distribution. Note that this method may be called more than once + per feature, and so should be idempotent. + + """ + + if not self.available: + raise DistutilsPlatformError( + self.description + " is required, " + "but is not available on this platform" + ) + + dist.include(**self.extras) + + for f in self.require_features: + dist.include_feature(f) + + def exclude_from(self, dist): + """Ensure feature is excluded from distribution + + You may override this in a subclass to perform additional operations on + the distribution. This method will be called at most once per + feature, and only after all included features have been asked to + include themselves. + """ + + dist.exclude(**self.extras) + + if self.remove: + for item in self.remove: + dist.exclude_package(item) + + def validate(self, dist): + """Verify that feature makes sense in context of distribution + + This method is called by the distribution just before it parses its + command line. It checks to ensure that the 'remove' attribute, if any, + contains only valid package/module names that are present in the base + distribution when 'setup()' is called. You may override it in a + subclass to perform any other required validation of the feature + against a target distribution. + """ + + for item in self.remove: + if not dist.has_contents_for(item): + raise DistutilsSetupError( + "%s wants to be able to remove %s, but the distribution" + " doesn't contain any packages or modules under %s" + % (self.description, item, item) + ) + + +class DistDeprecationWarning(SetuptoolsDeprecationWarning): + """Class for warning about deprecations in dist in + setuptools. Not ignored by default, unlike DeprecationWarning.""" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/extension.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/extension.py new file mode 100644 index 0000000..2946889 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/extension.py @@ -0,0 +1,57 @@ +import re +import functools +import distutils.core +import distutils.errors +import distutils.extension + +from setuptools.extern.six.moves import map + +from .monkey import get_unpatched + + +def _have_cython(): + """ + Return True if Cython can be imported. + """ + cython_impl = 'Cython.Distutils.build_ext' + try: + # from (cython_impl) import build_ext + __import__(cython_impl, fromlist=['build_ext']).build_ext + return True + except Exception: + pass + return False + + +# for compatibility +have_pyrex = _have_cython + +_Extension = get_unpatched(distutils.core.Extension) + + +class Extension(_Extension): + """Extension that uses '.c' files in place of '.pyx' files""" + + def __init__(self, name, sources, *args, **kw): + # The *args is needed for compatibility as calls may use positional + # arguments. py_limited_api may be set only via keyword. + self.py_limited_api = kw.pop("py_limited_api", False) + _Extension.__init__(self, name, sources, *args, **kw) + + def _convert_pyx_sources_to_lang(self): + """ + Replace sources with .pyx extensions to sources with the target + language extension. This mechanism allows language authors to supply + pre-converted sources but to prefer the .pyx sources. + """ + if _have_cython(): + # the build has Cython, so allow it to compile the .pyx files + return + lang = self.language or '' + target_ext = '.cpp' if lang.lower() == 'c++' else '.c' + sub = functools.partial(re.sub, '.pyx$', target_ext) + self.sources = list(map(sub, self.sources)) + + +class Library(Extension): + """Just like a regular Extension, but built as a library instead""" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/extern/__init__.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/extern/__init__.py new file mode 100644 index 0000000..cb2fa32 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/extern/__init__.py @@ -0,0 +1,73 @@ +import sys + + +class VendorImporter: + """ + A PEP 302 meta path importer for finding optionally-vendored + or otherwise naturally-installed packages from root_name. + """ + + def __init__(self, root_name, vendored_names=(), vendor_pkg=None): + self.root_name = root_name + self.vendored_names = set(vendored_names) + self.vendor_pkg = vendor_pkg or root_name.replace('extern', '_vendor') + + @property + def search_path(self): + """ + Search first the vendor package then as a natural package. + """ + yield self.vendor_pkg + '.' + yield '' + + def find_module(self, fullname, path=None): + """ + Return self when fullname starts with root_name and the + target module is one vendored through this importer. + """ + root, base, target = fullname.partition(self.root_name + '.') + if root: + return + if not any(map(target.startswith, self.vendored_names)): + return + return self + + def load_module(self, fullname): + """ + Iterate over the search path to locate and load fullname. + """ + root, base, target = fullname.partition(self.root_name + '.') + for prefix in self.search_path: + try: + extant = prefix + target + __import__(extant) + mod = sys.modules[extant] + sys.modules[fullname] = mod + # mysterious hack: + # Remove the reference to the extant package/module + # on later Python versions to cause relative imports + # in the vendor package to resolve the same modules + # as those going through this importer. + if sys.version_info >= (3, ): + del sys.modules[extant] + return mod + except ImportError: + pass + else: + raise ImportError( + "The '{target}' package is required; " + "normally this is bundled with this package so if you get " + "this warning, consult the packager of your " + "distribution.".format(**locals()) + ) + + def install(self): + """ + Install this importer into sys.meta_path if not already present. + """ + if self not in sys.meta_path: + sys.meta_path.append(self) + + +names = 'six', 'packaging', 'pyparsing', +VendorImporter(__name__, names, 'setuptools._vendor').install() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/extern/__pycache__/__init__.cpython-38.pyc b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/extern/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..837086a43e1cf29e7251702ba670cfb1dee60d5d GIT binary patch literal 2463 zcmZ`)TW=dh6rS0eoz11C5(%wnH3C7gMD0*eMMXhDZG|dOgxXSy1zK%9V|$bJ?sjJE z#Afq?BOd$4d-K>g{saGFUU}*t-~kE2IkUEtCSt5Pp4qvbIp24_`EGSJBvAhP{W$(( ziI6|BbGmrY*@CK?U^wA4C2jH*;SP6?2zRGWn{u!12r69RaDVE)@Qw+Ed5=gVcm-?7 zb_eb0;zDN&szM_O>_FNMr)`(7agX~)wCxF>2fTJfrnDXK3%t&k;A@SCeEEp9>wJZ; z!v7L?;gpMJ?TN^EE*}hvTxuaFM<IjqCHwaNx9sE1n`|I-%!*j|Su&f#y18WCB;!fe zV|k&IJd4wGd}Cxc65MV8Q*zxGaz9amWw9PgJ15DMhKAs<WoIw$3B|fHA26BcI?CdK zXxh~;;o=y)dBHZ;yHM5pU`kq&h-g|mQ*1e<TU;yY3zt*w96RvE;{>kfZnpz*0N2V) zEvo!$_-1KwnsJrTW^L}d^+1`L6h#_$gbAyGsMzZ@JmV>mcBK!e%NiO$oJfSjn!iV_ zLMEeFi`FQXt!|!jAyw=4L8}+t9?8KZyV>2{?Dr2QlPJA?Yo{+aq4cuW<5rOrH)esk zvAKC`G#-64Y=L9LLg#s^PB*K|w4x}<5*<a&Vr=U34suZiU<eIpNGBUlUPHDypVy%{ zXI8N7Kt-OZbucB_1p;o6CrCucS|o}$`NkrH<ai`v+35oXq|yvPW>uKxkm9F|#frsq z;O8S1xVVL(O+&UD)CTb-mFW9PEaftE&9buRL`c31=$>VSzd|Qh&fM(O#0~;7FBpsk zZ9at#Py{bX@q)+nNB7V@^bY;fmDjlQh-gQ<rN8UJ41Ws5QlH@0(h_O%>*D$k0U4Pw zWCPpBt9FNJiri(uZK)O8Pas<s9Ak0DF(ixiFsUar8{~YL3YI9AXY&w3Ug*BehrK@h z!^k}4P68)a;TqeGz$_JTR)WcADQVm|8yj~J7bdLSKrbv&8-We4sn7j19){F-=%Vp< zVkJyaIdu*KO!KJnbOR1nD`1GfPCfWtf_e^$QwuuCt9hwI0~6*hRP`LpIVc<i148fI zBR{nd{mEA8m)-_B3;>j1N-5Fau3rY1$ziRm**3j{-vaLJ`SNKs`Z+0U-vgm3faVch z+Y6<p(4*uB^6c%WP<4&FyY(*7OH=ZkPU$Zo!N6~S^7R6s2Ot=b$1EQSiO2!emhe^u zb<WbfgTshxn#X*B{~44T^c9kE^4nwB;`+~3gb%OJlL3*J;@L2ff`7)cTn<nnXSgf2 zGt4;Zq$QIj!%Q)m%30E7<9x`FMs{dFmKmt=hpdxlYM548IhzkcY-dZx6QyOcGepuf zw;Q2+1Kg_w?IN^H2nt~}K8ipX#~_3i^2)40BowRy+3DtHxq2+_OPNa(z-uswwFxjP zscO`#Tz(U`M#{*y&|Jp-gF=dKa$qGn&NQ$!=jRxQ5uGvaU09^v0YkiX5HyF@;TO^{ z2<`tGtve14T<;&}-*Y@Xwaq!bLsTpeuRx<D8U$glCfD)*1-u={z%}~>JClbeoTwhI z*VB?E8PEYD)x=lQ3Kc?=<(kE*6fqw&xUv$NKB2~T!<ARzT(h)TV}iISK&vIH+}VKC zW-r4Qj8zKgfwr%oQNY=xhGUn5umZgJGN3F0nt*HtCA3$f=-Du~f(5-=6!E+hMG`aH z)C-vxLh7+ZLP(5{d=JeBXfST442rbG97l;&Yhdcs^F!aEVJ%##U$tWm7pRmRpj_d5 z4<v==7_>`4b8_kAm1{2EXB!^7*!bwbk_|lR|6DNjJJsF3z_-jkfOU86o=5)!R04<# literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/glibc.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/glibc.py new file mode 100644 index 0000000..a134591 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/glibc.py @@ -0,0 +1,86 @@ +# This file originally from pip: +# https://github.com/pypa/pip/blob/8f4f15a5a95d7d5b511ceaee9ed261176c181970/src/pip/_internal/utils/glibc.py +from __future__ import absolute_import + +import ctypes +import re +import warnings + + +def glibc_version_string(): + "Returns glibc version string, or None if not using glibc." + + # ctypes.CDLL(None) internally calls dlopen(NULL), and as the dlopen + # manpage says, "If filename is NULL, then the returned handle is for the + # main program". This way we can let the linker do the work to figure out + # which libc our process is actually using. + process_namespace = ctypes.CDLL(None) + try: + gnu_get_libc_version = process_namespace.gnu_get_libc_version + except AttributeError: + # Symbol doesn't exist -> therefore, we are not linked to + # glibc. + return None + + # Call gnu_get_libc_version, which returns a string like "2.5" + gnu_get_libc_version.restype = ctypes.c_char_p + version_str = gnu_get_libc_version() + # py2 / py3 compatibility: + if not isinstance(version_str, str): + version_str = version_str.decode("ascii") + + return version_str + + +# Separated out from have_compatible_glibc for easier unit testing +def check_glibc_version(version_str, required_major, minimum_minor): + # Parse string and check against requested version. + # + # We use a regexp instead of str.split because we want to discard any + # random junk that might come after the minor version -- this might happen + # in patched/forked versions of glibc (e.g. Linaro's version of glibc + # uses version strings like "2.20-2014.11"). See gh-3588. + m = re.match(r"(?P<major>[0-9]+)\.(?P<minor>[0-9]+)", version_str) + if not m: + warnings.warn("Expected glibc version with 2 components major.minor," + " got: %s" % version_str, RuntimeWarning) + return False + return (int(m.group("major")) == required_major and + int(m.group("minor")) >= minimum_minor) + + +def have_compatible_glibc(required_major, minimum_minor): + version_str = glibc_version_string() + if version_str is None: + return False + return check_glibc_version(version_str, required_major, minimum_minor) + + +# platform.libc_ver regularly returns completely nonsensical glibc +# versions. E.g. on my computer, platform says: +# +# ~$ python2.7 -c 'import platform; print(platform.libc_ver())' +# ('glibc', '2.7') +# ~$ python3.5 -c 'import platform; print(platform.libc_ver())' +# ('glibc', '2.9') +# +# But the truth is: +# +# ~$ ldd --version +# ldd (Debian GLIBC 2.22-11) 2.22 +# +# This is unfortunate, because it means that the linehaul data on libc +# versions that was generated by pip 8.1.2 and earlier is useless and +# misleading. Solution: instead of using platform, use our code that actually +# works. +def libc_ver(): + """Try to determine the glibc version + + Returns a tuple of strings (lib, version) which default to empty strings + in case the lookup fails. + """ + glibc_version = glibc_version_string() + if glibc_version is None: + return ("", "") + else: + return ("glibc", glibc_version) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/glob.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/glob.py new file mode 100644 index 0000000..9d7cbc5 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/glob.py @@ -0,0 +1,174 @@ +""" +Filename globbing utility. Mostly a copy of `glob` from Python 3.5. + +Changes include: + * `yield from` and PEP3102 `*` removed. + * Hidden files are not ignored. +""" + +import os +import re +import fnmatch + +__all__ = ["glob", "iglob", "escape"] + + +def glob(pathname, recursive=False): + """Return a list of paths matching a pathname pattern. + + The pattern may contain simple shell-style wildcards a la + fnmatch. However, unlike fnmatch, filenames starting with a + dot are special cases that are not matched by '*' and '?' + patterns. + + If recursive is true, the pattern '**' will match any files and + zero or more directories and subdirectories. + """ + return list(iglob(pathname, recursive=recursive)) + + +def iglob(pathname, recursive=False): + """Return an iterator which yields the paths matching a pathname pattern. + + The pattern may contain simple shell-style wildcards a la + fnmatch. However, unlike fnmatch, filenames starting with a + dot are special cases that are not matched by '*' and '?' + patterns. + + If recursive is true, the pattern '**' will match any files and + zero or more directories and subdirectories. + """ + it = _iglob(pathname, recursive) + if recursive and _isrecursive(pathname): + s = next(it) # skip empty string + assert not s + return it + + +def _iglob(pathname, recursive): + dirname, basename = os.path.split(pathname) + if not has_magic(pathname): + if basename: + if os.path.lexists(pathname): + yield pathname + else: + # Patterns ending with a slash should match only directories + if os.path.isdir(dirname): + yield pathname + return + if not dirname: + if recursive and _isrecursive(basename): + for x in glob2(dirname, basename): + yield x + else: + for x in glob1(dirname, basename): + yield x + return + # `os.path.split()` returns the argument itself as a dirname if it is a + # drive or UNC path. Prevent an infinite recursion if a drive or UNC path + # contains magic characters (i.e. r'\\?\C:'). + if dirname != pathname and has_magic(dirname): + dirs = _iglob(dirname, recursive) + else: + dirs = [dirname] + if has_magic(basename): + if recursive and _isrecursive(basename): + glob_in_dir = glob2 + else: + glob_in_dir = glob1 + else: + glob_in_dir = glob0 + for dirname in dirs: + for name in glob_in_dir(dirname, basename): + yield os.path.join(dirname, name) + + +# These 2 helper functions non-recursively glob inside a literal directory. +# They return a list of basenames. `glob1` accepts a pattern while `glob0` +# takes a literal basename (so it only has to check for its existence). + + +def glob1(dirname, pattern): + if not dirname: + if isinstance(pattern, bytes): + dirname = os.curdir.encode('ASCII') + else: + dirname = os.curdir + try: + names = os.listdir(dirname) + except OSError: + return [] + return fnmatch.filter(names, pattern) + + +def glob0(dirname, basename): + if not basename: + # `os.path.split()` returns an empty basename for paths ending with a + # directory separator. 'q*x/' should match only directories. + if os.path.isdir(dirname): + return [basename] + else: + if os.path.lexists(os.path.join(dirname, basename)): + return [basename] + return [] + + +# This helper function recursively yields relative pathnames inside a literal +# directory. + + +def glob2(dirname, pattern): + assert _isrecursive(pattern) + yield pattern[:0] + for x in _rlistdir(dirname): + yield x + + +# Recursively yields relative pathnames inside a literal directory. +def _rlistdir(dirname): + if not dirname: + if isinstance(dirname, bytes): + dirname = os.curdir.encode('ASCII') + else: + dirname = os.curdir + try: + names = os.listdir(dirname) + except os.error: + return + for x in names: + yield x + path = os.path.join(dirname, x) if dirname else x + for y in _rlistdir(path): + yield os.path.join(x, y) + + +magic_check = re.compile('([*?[])') +magic_check_bytes = re.compile(b'([*?[])') + + +def has_magic(s): + if isinstance(s, bytes): + match = magic_check_bytes.search(s) + else: + match = magic_check.search(s) + return match is not None + + +def _isrecursive(pattern): + if isinstance(pattern, bytes): + return pattern == b'**' + else: + return pattern == '**' + + +def escape(pathname): + """Escape all special characters. + """ + # Escaping is done by wrapping any of "*?[" between square brackets. + # Metacharacters do not work in the drive part and shouldn't be escaped. + drive, pathname = os.path.splitdrive(pathname) + if isinstance(pathname, bytes): + pathname = magic_check_bytes.sub(br'[\1]', pathname) + else: + pathname = magic_check.sub(r'[\1]', pathname) + return drive + pathname diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/gui-32.exe b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/gui-32.exe new file mode 100644 index 0000000000000000000000000000000000000000..f8d3509653ba8f80ca7f3aa7f95616142ba83a94 GIT binary patch literal 65536 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/gui-64.exe b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/gui-64.exe new file mode 100644 index 0000000000000000000000000000000000000000..330c51a5dde15a0bb610a48cd0ca11770c914dae GIT binary patch literal 75264 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/gui.exe b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/gui.exe new file mode 100644 index 0000000000000000000000000000000000000000..f8d3509653ba8f80ca7f3aa7f95616142ba83a94 GIT binary patch literal 65536 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 literal 0 HcmV?d00001 diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/launch.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/launch.py new file mode 100644 index 0000000..308283e --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/launch.py @@ -0,0 +1,35 @@ +""" +Launch the Python script on the command line after +setuptools is bootstrapped via import. +""" + +# Note that setuptools gets imported implicitly by the +# invocation of this script using python -m setuptools.launch + +import tokenize +import sys + + +def run(): + """ + Run the script in sys.argv[1] as if it had + been invoked naturally. + """ + __builtins__ + script_name = sys.argv[1] + namespace = dict( + __file__=script_name, + __name__='__main__', + __doc__=None, + ) + sys.argv[:] = sys.argv[1:] + + open_ = getattr(tokenize, 'open', open) + script = open_(script_name).read() + norm_script = script.replace('\\r\\n', '\\n') + code = compile(norm_script, script_name, 'exec') + exec(code, namespace) + + +if __name__ == '__main__': + run() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/lib2to3_ex.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/lib2to3_ex.py new file mode 100644 index 0000000..4b1a73f --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/lib2to3_ex.py @@ -0,0 +1,62 @@ +""" +Customized Mixin2to3 support: + + - adds support for converting doctests + + +This module raises an ImportError on Python 2. +""" + +from distutils.util import Mixin2to3 as _Mixin2to3 +from distutils import log +from lib2to3.refactor import RefactoringTool, get_fixers_from_package + +import setuptools + + +class DistutilsRefactoringTool(RefactoringTool): + def log_error(self, msg, *args, **kw): + log.error(msg, *args) + + def log_message(self, msg, *args): + log.info(msg, *args) + + def log_debug(self, msg, *args): + log.debug(msg, *args) + + +class Mixin2to3(_Mixin2to3): + def run_2to3(self, files, doctests=False): + # See of the distribution option has been set, otherwise check the + # setuptools default. + if self.distribution.use_2to3 is not True: + return + if not files: + return + log.info("Fixing " + " ".join(files)) + self.__build_fixer_names() + self.__exclude_fixers() + if doctests: + if setuptools.run_2to3_on_doctests: + r = DistutilsRefactoringTool(self.fixer_names) + r.refactor(files, write=True, doctests_only=True) + else: + _Mixin2to3.run_2to3(self, files) + + def __build_fixer_names(self): + if self.fixer_names: + return + self.fixer_names = [] + for p in setuptools.lib2to3_fixer_packages: + self.fixer_names.extend(get_fixers_from_package(p)) + if self.distribution.use_2to3_fixers is not None: + for p in self.distribution.use_2to3_fixers: + self.fixer_names.extend(get_fixers_from_package(p)) + + def __exclude_fixers(self): + excluded_fixers = getattr(self, 'exclude_fixers', []) + if self.distribution.use_2to3_exclude_fixers is not None: + excluded_fixers.extend(self.distribution.use_2to3_exclude_fixers) + for fixer_name in excluded_fixers: + if fixer_name in self.fixer_names: + self.fixer_names.remove(fixer_name) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/monkey.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/monkey.py new file mode 100644 index 0000000..3c77f8c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/monkey.py @@ -0,0 +1,179 @@ +""" +Monkey patching of distutils. +""" + +import sys +import distutils.filelist +import platform +import types +import functools +from importlib import import_module +import inspect + +from setuptools.extern import six + +import setuptools + +__all__ = [] +""" +Everything is private. Contact the project team +if you think you need this functionality. +""" + + +def _get_mro(cls): + """ + Returns the bases classes for cls sorted by the MRO. + + Works around an issue on Jython where inspect.getmro will not return all + base classes if multiple classes share the same name. Instead, this + function will return a tuple containing the class itself, and the contents + of cls.__bases__. See https://github.com/pypa/setuptools/issues/1024. + """ + if platform.python_implementation() == "Jython": + return (cls,) + cls.__bases__ + return inspect.getmro(cls) + + +def get_unpatched(item): + lookup = ( + get_unpatched_class if isinstance(item, six.class_types) else + get_unpatched_function if isinstance(item, types.FunctionType) else + lambda item: None + ) + return lookup(item) + + +def get_unpatched_class(cls): + """Protect against re-patching the distutils if reloaded + + Also ensures that no other distutils extension monkeypatched the distutils + first. + """ + external_bases = ( + cls + for cls in _get_mro(cls) + if not cls.__module__.startswith('setuptools') + ) + base = next(external_bases) + if not base.__module__.startswith('distutils'): + msg = "distutils has already been patched by %r" % cls + raise AssertionError(msg) + return base + + +def patch_all(): + # we can't patch distutils.cmd, alas + distutils.core.Command = setuptools.Command + + has_issue_12885 = sys.version_info <= (3, 5, 3) + + if has_issue_12885: + # fix findall bug in distutils (http://bugs.python.org/issue12885) + distutils.filelist.findall = setuptools.findall + + needs_warehouse = ( + sys.version_info < (2, 7, 13) + or + (3, 4) < sys.version_info < (3, 4, 6) + or + (3, 5) < sys.version_info <= (3, 5, 3) + ) + + if needs_warehouse: + warehouse = 'https://upload.pypi.org/legacy/' + distutils.config.PyPIRCCommand.DEFAULT_REPOSITORY = warehouse + + _patch_distribution_metadata() + + # Install Distribution throughout the distutils + for module in distutils.dist, distutils.core, distutils.cmd: + module.Distribution = setuptools.dist.Distribution + + # Install the patched Extension + distutils.core.Extension = setuptools.extension.Extension + distutils.extension.Extension = setuptools.extension.Extension + if 'distutils.command.build_ext' in sys.modules: + sys.modules['distutils.command.build_ext'].Extension = ( + setuptools.extension.Extension + ) + + patch_for_msvc_specialized_compiler() + + +def _patch_distribution_metadata(): + """Patch write_pkg_file and read_pkg_file for higher metadata standards""" + for attr in ('write_pkg_file', 'read_pkg_file', 'get_metadata_version'): + new_val = getattr(setuptools.dist, attr) + setattr(distutils.dist.DistributionMetadata, attr, new_val) + + +def patch_func(replacement, target_mod, func_name): + """ + Patch func_name in target_mod with replacement + + Important - original must be resolved by name to avoid + patching an already patched function. + """ + original = getattr(target_mod, func_name) + + # set the 'unpatched' attribute on the replacement to + # point to the original. + vars(replacement).setdefault('unpatched', original) + + # replace the function in the original module + setattr(target_mod, func_name, replacement) + + +def get_unpatched_function(candidate): + return getattr(candidate, 'unpatched') + + +def patch_for_msvc_specialized_compiler(): + """ + Patch functions in distutils to use standalone Microsoft Visual C++ + compilers. + """ + # import late to avoid circular imports on Python < 3.5 + msvc = import_module('setuptools.msvc') + + if platform.system() != 'Windows': + # Compilers only availables on Microsoft Windows + return + + def patch_params(mod_name, func_name): + """ + Prepare the parameters for patch_func to patch indicated function. + """ + repl_prefix = 'msvc9_' if 'msvc9' in mod_name else 'msvc14_' + repl_name = repl_prefix + func_name.lstrip('_') + repl = getattr(msvc, repl_name) + mod = import_module(mod_name) + if not hasattr(mod, func_name): + raise ImportError(func_name) + return repl, mod, func_name + + # Python 2.7 to 3.4 + msvc9 = functools.partial(patch_params, 'distutils.msvc9compiler') + + # Python 3.5+ + msvc14 = functools.partial(patch_params, 'distutils._msvccompiler') + + try: + # Patch distutils.msvc9compiler + patch_func(*msvc9('find_vcvarsall')) + patch_func(*msvc9('query_vcvarsall')) + except ImportError: + pass + + try: + # Patch distutils._msvccompiler._get_vc_env + patch_func(*msvc14('_get_vc_env')) + except ImportError: + pass + + try: + # Patch distutils._msvccompiler.gen_lib_options for Numpy + patch_func(*msvc14('gen_lib_options')) + except ImportError: + pass diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/msvc.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/msvc.py new file mode 100644 index 0000000..b9c472f --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/msvc.py @@ -0,0 +1,1301 @@ +""" +Improved support for Microsoft Visual C++ compilers. + +Known supported compilers: +-------------------------- +Microsoft Visual C++ 9.0: + Microsoft Visual C++ Compiler for Python 2.7 (x86, amd64) + Microsoft Windows SDK 6.1 (x86, x64, ia64) + Microsoft Windows SDK 7.0 (x86, x64, ia64) + +Microsoft Visual C++ 10.0: + Microsoft Windows SDK 7.1 (x86, x64, ia64) + +Microsoft Visual C++ 14.0: + Microsoft Visual C++ Build Tools 2015 (x86, x64, arm) + Microsoft Visual Studio 2017 (x86, x64, arm, arm64) + Microsoft Visual Studio Build Tools 2017 (x86, x64, arm, arm64) +""" + +import os +import sys +import platform +import itertools +import distutils.errors +from setuptools.extern.packaging.version import LegacyVersion + +from setuptools.extern.six.moves import filterfalse + +from .monkey import get_unpatched + +if platform.system() == 'Windows': + from setuptools.extern.six.moves import winreg + safe_env = os.environ +else: + """ + Mock winreg and environ so the module can be imported + on this platform. + """ + + class winreg: + HKEY_USERS = None + HKEY_CURRENT_USER = None + HKEY_LOCAL_MACHINE = None + HKEY_CLASSES_ROOT = None + + safe_env = dict() + +_msvc9_suppress_errors = ( + # msvc9compiler isn't available on some platforms + ImportError, + + # msvc9compiler raises DistutilsPlatformError in some + # environments. See #1118. + distutils.errors.DistutilsPlatformError, +) + +try: + from distutils.msvc9compiler import Reg +except _msvc9_suppress_errors: + pass + + +def msvc9_find_vcvarsall(version): + """ + Patched "distutils.msvc9compiler.find_vcvarsall" to use the standalone + compiler build for Python (VCForPython). Fall back to original behavior + when the standalone compiler is not available. + + Redirect the path of "vcvarsall.bat". + + Known supported compilers + ------------------------- + Microsoft Visual C++ 9.0: + Microsoft Visual C++ Compiler for Python 2.7 (x86, amd64) + + Parameters + ---------- + version: float + Required Microsoft Visual C++ version. + + Return + ------ + vcvarsall.bat path: str + """ + VC_BASE = r'Software\%sMicrosoft\DevDiv\VCForPython\%0.1f' + key = VC_BASE % ('', version) + try: + # Per-user installs register the compiler path here + productdir = Reg.get_value(key, "installdir") + except KeyError: + try: + # All-user installs on a 64-bit system register here + key = VC_BASE % ('Wow6432Node\\', version) + productdir = Reg.get_value(key, "installdir") + except KeyError: + productdir = None + + if productdir: + vcvarsall = os.path.os.path.join(productdir, "vcvarsall.bat") + if os.path.isfile(vcvarsall): + return vcvarsall + + return get_unpatched(msvc9_find_vcvarsall)(version) + + +def msvc9_query_vcvarsall(ver, arch='x86', *args, **kwargs): + """ + Patched "distutils.msvc9compiler.query_vcvarsall" for support extra + compilers. + + Set environment without use of "vcvarsall.bat". + + Known supported compilers + ------------------------- + Microsoft Visual C++ 9.0: + Microsoft Visual C++ Compiler for Python 2.7 (x86, amd64) + Microsoft Windows SDK 6.1 (x86, x64, ia64) + Microsoft Windows SDK 7.0 (x86, x64, ia64) + + Microsoft Visual C++ 10.0: + Microsoft Windows SDK 7.1 (x86, x64, ia64) + + Parameters + ---------- + ver: float + Required Microsoft Visual C++ version. + arch: str + Target architecture. + + Return + ------ + environment: dict + """ + # Try to get environement from vcvarsall.bat (Classical way) + try: + orig = get_unpatched(msvc9_query_vcvarsall) + return orig(ver, arch, *args, **kwargs) + except distutils.errors.DistutilsPlatformError: + # Pass error if Vcvarsall.bat is missing + pass + except ValueError: + # Pass error if environment not set after executing vcvarsall.bat + pass + + # If error, try to set environment directly + try: + return EnvironmentInfo(arch, ver).return_env() + except distutils.errors.DistutilsPlatformError as exc: + _augment_exception(exc, ver, arch) + raise + + +def msvc14_get_vc_env(plat_spec): + """ + Patched "distutils._msvccompiler._get_vc_env" for support extra + compilers. + + Set environment without use of "vcvarsall.bat". + + Known supported compilers + ------------------------- + Microsoft Visual C++ 14.0: + Microsoft Visual C++ Build Tools 2015 (x86, x64, arm) + Microsoft Visual Studio 2017 (x86, x64, arm, arm64) + Microsoft Visual Studio Build Tools 2017 (x86, x64, arm, arm64) + + Parameters + ---------- + plat_spec: str + Target architecture. + + Return + ------ + environment: dict + """ + # Try to get environment from vcvarsall.bat (Classical way) + try: + return get_unpatched(msvc14_get_vc_env)(plat_spec) + except distutils.errors.DistutilsPlatformError: + # Pass error Vcvarsall.bat is missing + pass + + # If error, try to set environment directly + try: + return EnvironmentInfo(plat_spec, vc_min_ver=14.0).return_env() + except distutils.errors.DistutilsPlatformError as exc: + _augment_exception(exc, 14.0) + raise + + +def msvc14_gen_lib_options(*args, **kwargs): + """ + Patched "distutils._msvccompiler.gen_lib_options" for fix + compatibility between "numpy.distutils" and "distutils._msvccompiler" + (for Numpy < 1.11.2) + """ + if "numpy.distutils" in sys.modules: + import numpy as np + if LegacyVersion(np.__version__) < LegacyVersion('1.11.2'): + return np.distutils.ccompiler.gen_lib_options(*args, **kwargs) + return get_unpatched(msvc14_gen_lib_options)(*args, **kwargs) + + +def _augment_exception(exc, version, arch=''): + """ + Add details to the exception message to help guide the user + as to what action will resolve it. + """ + # Error if MSVC++ directory not found or environment not set + message = exc.args[0] + + if "vcvarsall" in message.lower() or "visual c" in message.lower(): + # Special error message if MSVC++ not installed + tmpl = 'Microsoft Visual C++ {version:0.1f} is required.' + message = tmpl.format(**locals()) + msdownload = 'www.microsoft.com/download/details.aspx?id=%d' + if version == 9.0: + if arch.lower().find('ia64') > -1: + # For VC++ 9.0, if IA64 support is needed, redirect user + # to Windows SDK 7.0 + message += ' Get it with "Microsoft Windows SDK 7.0": ' + message += msdownload % 3138 + else: + # For VC++ 9.0 redirect user to Vc++ for Python 2.7 : + # This redirection link is maintained by Microsoft. + # Contact vspython@microsoft.com if it needs updating. + message += ' Get it from http://aka.ms/vcpython27' + elif version == 10.0: + # For VC++ 10.0 Redirect user to Windows SDK 7.1 + message += ' Get it with "Microsoft Windows SDK 7.1": ' + message += msdownload % 8279 + elif version >= 14.0: + # For VC++ 14.0 Redirect user to Visual C++ Build Tools + message += (' Get it with "Microsoft Visual C++ Build Tools": ' + r'https://visualstudio.microsoft.com/downloads/') + + exc.args = (message, ) + + +class PlatformInfo: + """ + Current and Target Architectures informations. + + Parameters + ---------- + arch: str + Target architecture. + """ + current_cpu = safe_env.get('processor_architecture', '').lower() + + def __init__(self, arch): + self.arch = arch.lower().replace('x64', 'amd64') + + @property + def target_cpu(self): + return self.arch[self.arch.find('_') + 1:] + + def target_is_x86(self): + return self.target_cpu == 'x86' + + def current_is_x86(self): + return self.current_cpu == 'x86' + + def current_dir(self, hidex86=False, x64=False): + """ + Current platform specific subfolder. + + Parameters + ---------- + hidex86: bool + return '' and not '\x86' if architecture is x86. + x64: bool + return '\x64' and not '\amd64' if architecture is amd64. + + Return + ------ + subfolder: str + '\target', or '' (see hidex86 parameter) + """ + return ( + '' if (self.current_cpu == 'x86' and hidex86) else + r'\x64' if (self.current_cpu == 'amd64' and x64) else + r'\%s' % self.current_cpu + ) + + def target_dir(self, hidex86=False, x64=False): + r""" + Target platform specific subfolder. + + Parameters + ---------- + hidex86: bool + return '' and not '\x86' if architecture is x86. + x64: bool + return '\x64' and not '\amd64' if architecture is amd64. + + Return + ------ + subfolder: str + '\current', or '' (see hidex86 parameter) + """ + return ( + '' if (self.target_cpu == 'x86' and hidex86) else + r'\x64' if (self.target_cpu == 'amd64' and x64) else + r'\%s' % self.target_cpu + ) + + def cross_dir(self, forcex86=False): + r""" + Cross platform specific subfolder. + + Parameters + ---------- + forcex86: bool + Use 'x86' as current architecture even if current acritecture is + not x86. + + Return + ------ + subfolder: str + '' if target architecture is current architecture, + '\current_target' if not. + """ + current = 'x86' if forcex86 else self.current_cpu + return ( + '' if self.target_cpu == current else + self.target_dir().replace('\\', '\\%s_' % current) + ) + + +class RegistryInfo: + """ + Microsoft Visual Studio related registry informations. + + Parameters + ---------- + platform_info: PlatformInfo + "PlatformInfo" instance. + """ + HKEYS = (winreg.HKEY_USERS, + winreg.HKEY_CURRENT_USER, + winreg.HKEY_LOCAL_MACHINE, + winreg.HKEY_CLASSES_ROOT) + + def __init__(self, platform_info): + self.pi = platform_info + + @property + def visualstudio(self): + """ + Microsoft Visual Studio root registry key. + """ + return 'VisualStudio' + + @property + def sxs(self): + """ + Microsoft Visual Studio SxS registry key. + """ + return os.path.join(self.visualstudio, 'SxS') + + @property + def vc(self): + """ + Microsoft Visual C++ VC7 registry key. + """ + return os.path.join(self.sxs, 'VC7') + + @property + def vs(self): + """ + Microsoft Visual Studio VS7 registry key. + """ + return os.path.join(self.sxs, 'VS7') + + @property + def vc_for_python(self): + """ + Microsoft Visual C++ for Python registry key. + """ + return r'DevDiv\VCForPython' + + @property + def microsoft_sdk(self): + """ + Microsoft SDK registry key. + """ + return 'Microsoft SDKs' + + @property + def windows_sdk(self): + """ + Microsoft Windows/Platform SDK registry key. + """ + return os.path.join(self.microsoft_sdk, 'Windows') + + @property + def netfx_sdk(self): + """ + Microsoft .NET Framework SDK registry key. + """ + return os.path.join(self.microsoft_sdk, 'NETFXSDK') + + @property + def windows_kits_roots(self): + """ + Microsoft Windows Kits Roots registry key. + """ + return r'Windows Kits\Installed Roots' + + def microsoft(self, key, x86=False): + """ + Return key in Microsoft software registry. + + Parameters + ---------- + key: str + Registry key path where look. + x86: str + Force x86 software registry. + + Return + ------ + str: value + """ + node64 = '' if self.pi.current_is_x86() or x86 else 'Wow6432Node' + return os.path.join('Software', node64, 'Microsoft', key) + + def lookup(self, key, name): + """ + Look for values in registry in Microsoft software registry. + + Parameters + ---------- + key: str + Registry key path where look. + name: str + Value name to find. + + Return + ------ + str: value + """ + KEY_READ = winreg.KEY_READ + openkey = winreg.OpenKey + ms = self.microsoft + for hkey in self.HKEYS: + try: + bkey = openkey(hkey, ms(key), 0, KEY_READ) + except (OSError, IOError): + if not self.pi.current_is_x86(): + try: + bkey = openkey(hkey, ms(key, True), 0, KEY_READ) + except (OSError, IOError): + continue + else: + continue + try: + return winreg.QueryValueEx(bkey, name)[0] + except (OSError, IOError): + pass + + +class SystemInfo: + """ + Microsoft Windows and Visual Studio related system inormations. + + Parameters + ---------- + registry_info: RegistryInfo + "RegistryInfo" instance. + vc_ver: float + Required Microsoft Visual C++ version. + """ + + # Variables and properties in this class use originals CamelCase variables + # names from Microsoft source files for more easy comparaison. + WinDir = safe_env.get('WinDir', '') + ProgramFiles = safe_env.get('ProgramFiles', '') + ProgramFilesx86 = safe_env.get('ProgramFiles(x86)', ProgramFiles) + + def __init__(self, registry_info, vc_ver=None): + self.ri = registry_info + self.pi = self.ri.pi + self.vc_ver = vc_ver or self._find_latest_available_vc_ver() + + def _find_latest_available_vc_ver(self): + try: + return self.find_available_vc_vers()[-1] + except IndexError: + err = 'No Microsoft Visual C++ version found' + raise distutils.errors.DistutilsPlatformError(err) + + def find_available_vc_vers(self): + """ + Find all available Microsoft Visual C++ versions. + """ + ms = self.ri.microsoft + vckeys = (self.ri.vc, self.ri.vc_for_python, self.ri.vs) + vc_vers = [] + for hkey in self.ri.HKEYS: + for key in vckeys: + try: + bkey = winreg.OpenKey(hkey, ms(key), 0, winreg.KEY_READ) + except (OSError, IOError): + continue + subkeys, values, _ = winreg.QueryInfoKey(bkey) + for i in range(values): + try: + ver = float(winreg.EnumValue(bkey, i)[0]) + if ver not in vc_vers: + vc_vers.append(ver) + except ValueError: + pass + for i in range(subkeys): + try: + ver = float(winreg.EnumKey(bkey, i)) + if ver not in vc_vers: + vc_vers.append(ver) + except ValueError: + pass + return sorted(vc_vers) + + @property + def VSInstallDir(self): + """ + Microsoft Visual Studio directory. + """ + # Default path + name = 'Microsoft Visual Studio %0.1f' % self.vc_ver + default = os.path.join(self.ProgramFilesx86, name) + + # Try to get path from registry, if fail use default path + return self.ri.lookup(self.ri.vs, '%0.1f' % self.vc_ver) or default + + @property + def VCInstallDir(self): + """ + Microsoft Visual C++ directory. + """ + self.VSInstallDir + + guess_vc = self._guess_vc() or self._guess_vc_legacy() + + # Try to get "VC++ for Python" path from registry as default path + reg_path = os.path.join(self.ri.vc_for_python, '%0.1f' % self.vc_ver) + python_vc = self.ri.lookup(reg_path, 'installdir') + default_vc = os.path.join(python_vc, 'VC') if python_vc else guess_vc + + # Try to get path from registry, if fail use default path + path = self.ri.lookup(self.ri.vc, '%0.1f' % self.vc_ver) or default_vc + + if not os.path.isdir(path): + msg = 'Microsoft Visual C++ directory not found' + raise distutils.errors.DistutilsPlatformError(msg) + + return path + + def _guess_vc(self): + """ + Locate Visual C for 2017 + """ + if self.vc_ver <= 14.0: + return + + default = r'VC\Tools\MSVC' + guess_vc = os.path.join(self.VSInstallDir, default) + # Subdir with VC exact version as name + try: + vc_exact_ver = os.listdir(guess_vc)[-1] + return os.path.join(guess_vc, vc_exact_ver) + except (OSError, IOError, IndexError): + pass + + def _guess_vc_legacy(self): + """ + Locate Visual C for versions prior to 2017 + """ + default = r'Microsoft Visual Studio %0.1f\VC' % self.vc_ver + return os.path.join(self.ProgramFilesx86, default) + + @property + def WindowsSdkVersion(self): + """ + Microsoft Windows SDK versions for specified MSVC++ version. + """ + if self.vc_ver <= 9.0: + return ('7.0', '6.1', '6.0a') + elif self.vc_ver == 10.0: + return ('7.1', '7.0a') + elif self.vc_ver == 11.0: + return ('8.0', '8.0a') + elif self.vc_ver == 12.0: + return ('8.1', '8.1a') + elif self.vc_ver >= 14.0: + return ('10.0', '8.1') + + @property + def WindowsSdkLastVersion(self): + """ + Microsoft Windows SDK last version + """ + return self._use_last_dir_name(os.path.join( + self.WindowsSdkDir, 'lib')) + + @property + def WindowsSdkDir(self): + """ + Microsoft Windows SDK directory. + """ + sdkdir = '' + for ver in self.WindowsSdkVersion: + # Try to get it from registry + loc = os.path.join(self.ri.windows_sdk, 'v%s' % ver) + sdkdir = self.ri.lookup(loc, 'installationfolder') + if sdkdir: + break + if not sdkdir or not os.path.isdir(sdkdir): + # Try to get "VC++ for Python" version from registry + path = os.path.join(self.ri.vc_for_python, '%0.1f' % self.vc_ver) + install_base = self.ri.lookup(path, 'installdir') + if install_base: + sdkdir = os.path.join(install_base, 'WinSDK') + if not sdkdir or not os.path.isdir(sdkdir): + # If fail, use default new path + for ver in self.WindowsSdkVersion: + intver = ver[:ver.rfind('.')] + path = r'Microsoft SDKs\Windows Kits\%s' % (intver) + d = os.path.join(self.ProgramFiles, path) + if os.path.isdir(d): + sdkdir = d + if not sdkdir or not os.path.isdir(sdkdir): + # If fail, use default old path + for ver in self.WindowsSdkVersion: + path = r'Microsoft SDKs\Windows\v%s' % ver + d = os.path.join(self.ProgramFiles, path) + if os.path.isdir(d): + sdkdir = d + if not sdkdir: + # If fail, use Platform SDK + sdkdir = os.path.join(self.VCInstallDir, 'PlatformSDK') + return sdkdir + + @property + def WindowsSDKExecutablePath(self): + """ + Microsoft Windows SDK executable directory. + """ + # Find WinSDK NetFx Tools registry dir name + if self.vc_ver <= 11.0: + netfxver = 35 + arch = '' + else: + netfxver = 40 + hidex86 = True if self.vc_ver <= 12.0 else False + arch = self.pi.current_dir(x64=True, hidex86=hidex86) + fx = 'WinSDK-NetFx%dTools%s' % (netfxver, arch.replace('\\', '-')) + + # liste all possibles registry paths + regpaths = [] + if self.vc_ver >= 14.0: + for ver in self.NetFxSdkVersion: + regpaths += [os.path.join(self.ri.netfx_sdk, ver, fx)] + + for ver in self.WindowsSdkVersion: + regpaths += [os.path.join(self.ri.windows_sdk, 'v%sA' % ver, fx)] + + # Return installation folder from the more recent path + for path in regpaths: + execpath = self.ri.lookup(path, 'installationfolder') + if execpath: + break + return execpath + + @property + def FSharpInstallDir(self): + """ + Microsoft Visual F# directory. + """ + path = r'%0.1f\Setup\F#' % self.vc_ver + path = os.path.join(self.ri.visualstudio, path) + return self.ri.lookup(path, 'productdir') or '' + + @property + def UniversalCRTSdkDir(self): + """ + Microsoft Universal CRT SDK directory. + """ + # Set Kit Roots versions for specified MSVC++ version + if self.vc_ver >= 14.0: + vers = ('10', '81') + else: + vers = () + + # Find path of the more recent Kit + for ver in vers: + sdkdir = self.ri.lookup(self.ri.windows_kits_roots, + 'kitsroot%s' % ver) + if sdkdir: + break + return sdkdir or '' + + @property + def UniversalCRTSdkLastVersion(self): + """ + Microsoft Universal C Runtime SDK last version + """ + return self._use_last_dir_name(os.path.join( + self.UniversalCRTSdkDir, 'lib')) + + @property + def NetFxSdkVersion(self): + """ + Microsoft .NET Framework SDK versions. + """ + # Set FxSdk versions for specified MSVC++ version + if self.vc_ver >= 14.0: + return ('4.6.1', '4.6') + else: + return () + + @property + def NetFxSdkDir(self): + """ + Microsoft .NET Framework SDK directory. + """ + for ver in self.NetFxSdkVersion: + loc = os.path.join(self.ri.netfx_sdk, ver) + sdkdir = self.ri.lookup(loc, 'kitsinstallationfolder') + if sdkdir: + break + return sdkdir or '' + + @property + def FrameworkDir32(self): + """ + Microsoft .NET Framework 32bit directory. + """ + # Default path + guess_fw = os.path.join(self.WinDir, r'Microsoft.NET\Framework') + + # Try to get path from registry, if fail use default path + return self.ri.lookup(self.ri.vc, 'frameworkdir32') or guess_fw + + @property + def FrameworkDir64(self): + """ + Microsoft .NET Framework 64bit directory. + """ + # Default path + guess_fw = os.path.join(self.WinDir, r'Microsoft.NET\Framework64') + + # Try to get path from registry, if fail use default path + return self.ri.lookup(self.ri.vc, 'frameworkdir64') or guess_fw + + @property + def FrameworkVersion32(self): + """ + Microsoft .NET Framework 32bit versions. + """ + return self._find_dot_net_versions(32) + + @property + def FrameworkVersion64(self): + """ + Microsoft .NET Framework 64bit versions. + """ + return self._find_dot_net_versions(64) + + def _find_dot_net_versions(self, bits): + """ + Find Microsoft .NET Framework versions. + + Parameters + ---------- + bits: int + Platform number of bits: 32 or 64. + """ + # Find actual .NET version in registry + reg_ver = self.ri.lookup(self.ri.vc, 'frameworkver%d' % bits) + dot_net_dir = getattr(self, 'FrameworkDir%d' % bits) + ver = reg_ver or self._use_last_dir_name(dot_net_dir, 'v') or '' + + # Set .NET versions for specified MSVC++ version + if self.vc_ver >= 12.0: + frameworkver = (ver, 'v4.0') + elif self.vc_ver >= 10.0: + frameworkver = ('v4.0.30319' if ver.lower()[:2] != 'v4' else ver, + 'v3.5') + elif self.vc_ver == 9.0: + frameworkver = ('v3.5', 'v2.0.50727') + if self.vc_ver == 8.0: + frameworkver = ('v3.0', 'v2.0.50727') + return frameworkver + + def _use_last_dir_name(self, path, prefix=''): + """ + Return name of the last dir in path or '' if no dir found. + + Parameters + ---------- + path: str + Use dirs in this path + prefix: str + Use only dirs startings by this prefix + """ + matching_dirs = ( + dir_name + for dir_name in reversed(os.listdir(path)) + if os.path.isdir(os.path.join(path, dir_name)) and + dir_name.startswith(prefix) + ) + return next(matching_dirs, None) or '' + + +class EnvironmentInfo: + """ + Return environment variables for specified Microsoft Visual C++ version + and platform : Lib, Include, Path and libpath. + + This function is compatible with Microsoft Visual C++ 9.0 to 14.0. + + Script created by analysing Microsoft environment configuration files like + "vcvars[...].bat", "SetEnv.Cmd", "vcbuildtools.bat", ... + + Parameters + ---------- + arch: str + Target architecture. + vc_ver: float + Required Microsoft Visual C++ version. If not set, autodetect the last + version. + vc_min_ver: float + Minimum Microsoft Visual C++ version. + """ + + # Variables and properties in this class use originals CamelCase variables + # names from Microsoft source files for more easy comparaison. + + def __init__(self, arch, vc_ver=None, vc_min_ver=0): + self.pi = PlatformInfo(arch) + self.ri = RegistryInfo(self.pi) + self.si = SystemInfo(self.ri, vc_ver) + + if self.vc_ver < vc_min_ver: + err = 'No suitable Microsoft Visual C++ version found' + raise distutils.errors.DistutilsPlatformError(err) + + @property + def vc_ver(self): + """ + Microsoft Visual C++ version. + """ + return self.si.vc_ver + + @property + def VSTools(self): + """ + Microsoft Visual Studio Tools + """ + paths = [r'Common7\IDE', r'Common7\Tools'] + + if self.vc_ver >= 14.0: + arch_subdir = self.pi.current_dir(hidex86=True, x64=True) + paths += [r'Common7\IDE\CommonExtensions\Microsoft\TestWindow'] + paths += [r'Team Tools\Performance Tools'] + paths += [r'Team Tools\Performance Tools%s' % arch_subdir] + + return [os.path.join(self.si.VSInstallDir, path) for path in paths] + + @property + def VCIncludes(self): + """ + Microsoft Visual C++ & Microsoft Foundation Class Includes + """ + return [os.path.join(self.si.VCInstallDir, 'Include'), + os.path.join(self.si.VCInstallDir, r'ATLMFC\Include')] + + @property + def VCLibraries(self): + """ + Microsoft Visual C++ & Microsoft Foundation Class Libraries + """ + if self.vc_ver >= 15.0: + arch_subdir = self.pi.target_dir(x64=True) + else: + arch_subdir = self.pi.target_dir(hidex86=True) + paths = ['Lib%s' % arch_subdir, r'ATLMFC\Lib%s' % arch_subdir] + + if self.vc_ver >= 14.0: + paths += [r'Lib\store%s' % arch_subdir] + + return [os.path.join(self.si.VCInstallDir, path) for path in paths] + + @property + def VCStoreRefs(self): + """ + Microsoft Visual C++ store references Libraries + """ + if self.vc_ver < 14.0: + return [] + return [os.path.join(self.si.VCInstallDir, r'Lib\store\references')] + + @property + def VCTools(self): + """ + Microsoft Visual C++ Tools + """ + si = self.si + tools = [os.path.join(si.VCInstallDir, 'VCPackages')] + + forcex86 = True if self.vc_ver <= 10.0 else False + arch_subdir = self.pi.cross_dir(forcex86) + if arch_subdir: + tools += [os.path.join(si.VCInstallDir, 'Bin%s' % arch_subdir)] + + if self.vc_ver == 14.0: + path = 'Bin%s' % self.pi.current_dir(hidex86=True) + tools += [os.path.join(si.VCInstallDir, path)] + + elif self.vc_ver >= 15.0: + host_dir = (r'bin\HostX86%s' if self.pi.current_is_x86() else + r'bin\HostX64%s') + tools += [os.path.join( + si.VCInstallDir, host_dir % self.pi.target_dir(x64=True))] + + if self.pi.current_cpu != self.pi.target_cpu: + tools += [os.path.join( + si.VCInstallDir, host_dir % self.pi.current_dir(x64=True))] + + else: + tools += [os.path.join(si.VCInstallDir, 'Bin')] + + return tools + + @property + def OSLibraries(self): + """ + Microsoft Windows SDK Libraries + """ + if self.vc_ver <= 10.0: + arch_subdir = self.pi.target_dir(hidex86=True, x64=True) + return [os.path.join(self.si.WindowsSdkDir, 'Lib%s' % arch_subdir)] + + else: + arch_subdir = self.pi.target_dir(x64=True) + lib = os.path.join(self.si.WindowsSdkDir, 'lib') + libver = self._sdk_subdir + return [os.path.join(lib, '%sum%s' % (libver , arch_subdir))] + + @property + def OSIncludes(self): + """ + Microsoft Windows SDK Include + """ + include = os.path.join(self.si.WindowsSdkDir, 'include') + + if self.vc_ver <= 10.0: + return [include, os.path.join(include, 'gl')] + + else: + if self.vc_ver >= 14.0: + sdkver = self._sdk_subdir + else: + sdkver = '' + return [os.path.join(include, '%sshared' % sdkver), + os.path.join(include, '%sum' % sdkver), + os.path.join(include, '%swinrt' % sdkver)] + + @property + def OSLibpath(self): + """ + Microsoft Windows SDK Libraries Paths + """ + ref = os.path.join(self.si.WindowsSdkDir, 'References') + libpath = [] + + if self.vc_ver <= 9.0: + libpath += self.OSLibraries + + if self.vc_ver >= 11.0: + libpath += [os.path.join(ref, r'CommonConfiguration\Neutral')] + + if self.vc_ver >= 14.0: + libpath += [ + ref, + os.path.join(self.si.WindowsSdkDir, 'UnionMetadata'), + os.path.join( + ref, + 'Windows.Foundation.UniversalApiContract', + '1.0.0.0', + ), + os.path.join( + ref, + 'Windows.Foundation.FoundationContract', + '1.0.0.0', + ), + os.path.join( + ref, + 'Windows.Networking.Connectivity.WwanContract', + '1.0.0.0', + ), + os.path.join( + self.si.WindowsSdkDir, + 'ExtensionSDKs', + 'Microsoft.VCLibs', + '%0.1f' % self.vc_ver, + 'References', + 'CommonConfiguration', + 'neutral', + ), + ] + return libpath + + @property + def SdkTools(self): + """ + Microsoft Windows SDK Tools + """ + return list(self._sdk_tools()) + + def _sdk_tools(self): + """ + Microsoft Windows SDK Tools paths generator + """ + if self.vc_ver < 15.0: + bin_dir = 'Bin' if self.vc_ver <= 11.0 else r'Bin\x86' + yield os.path.join(self.si.WindowsSdkDir, bin_dir) + + if not self.pi.current_is_x86(): + arch_subdir = self.pi.current_dir(x64=True) + path = 'Bin%s' % arch_subdir + yield os.path.join(self.si.WindowsSdkDir, path) + + if self.vc_ver == 10.0 or self.vc_ver == 11.0: + if self.pi.target_is_x86(): + arch_subdir = '' + else: + arch_subdir = self.pi.current_dir(hidex86=True, x64=True) + path = r'Bin\NETFX 4.0 Tools%s' % arch_subdir + yield os.path.join(self.si.WindowsSdkDir, path) + + elif self.vc_ver >= 15.0: + path = os.path.join(self.si.WindowsSdkDir, 'Bin') + arch_subdir = self.pi.current_dir(x64=True) + sdkver = self.si.WindowsSdkLastVersion + yield os.path.join(path, '%s%s' % (sdkver, arch_subdir)) + + if self.si.WindowsSDKExecutablePath: + yield self.si.WindowsSDKExecutablePath + + @property + def _sdk_subdir(self): + """ + Microsoft Windows SDK version subdir + """ + ucrtver = self.si.WindowsSdkLastVersion + return ('%s\\' % ucrtver) if ucrtver else '' + + @property + def SdkSetup(self): + """ + Microsoft Windows SDK Setup + """ + if self.vc_ver > 9.0: + return [] + + return [os.path.join(self.si.WindowsSdkDir, 'Setup')] + + @property + def FxTools(self): + """ + Microsoft .NET Framework Tools + """ + pi = self.pi + si = self.si + + if self.vc_ver <= 10.0: + include32 = True + include64 = not pi.target_is_x86() and not pi.current_is_x86() + else: + include32 = pi.target_is_x86() or pi.current_is_x86() + include64 = pi.current_cpu == 'amd64' or pi.target_cpu == 'amd64' + + tools = [] + if include32: + tools += [os.path.join(si.FrameworkDir32, ver) + for ver in si.FrameworkVersion32] + if include64: + tools += [os.path.join(si.FrameworkDir64, ver) + for ver in si.FrameworkVersion64] + return tools + + @property + def NetFxSDKLibraries(self): + """ + Microsoft .Net Framework SDK Libraries + """ + if self.vc_ver < 14.0 or not self.si.NetFxSdkDir: + return [] + + arch_subdir = self.pi.target_dir(x64=True) + return [os.path.join(self.si.NetFxSdkDir, r'lib\um%s' % arch_subdir)] + + @property + def NetFxSDKIncludes(self): + """ + Microsoft .Net Framework SDK Includes + """ + if self.vc_ver < 14.0 or not self.si.NetFxSdkDir: + return [] + + return [os.path.join(self.si.NetFxSdkDir, r'include\um')] + + @property + def VsTDb(self): + """ + Microsoft Visual Studio Team System Database + """ + return [os.path.join(self.si.VSInstallDir, r'VSTSDB\Deploy')] + + @property + def MSBuild(self): + """ + Microsoft Build Engine + """ + if self.vc_ver < 12.0: + return [] + elif self.vc_ver < 15.0: + base_path = self.si.ProgramFilesx86 + arch_subdir = self.pi.current_dir(hidex86=True) + else: + base_path = self.si.VSInstallDir + arch_subdir = '' + + path = r'MSBuild\%0.1f\bin%s' % (self.vc_ver, arch_subdir) + build = [os.path.join(base_path, path)] + + if self.vc_ver >= 15.0: + # Add Roslyn C# & Visual Basic Compiler + build += [os.path.join(base_path, path, 'Roslyn')] + + return build + + @property + def HTMLHelpWorkshop(self): + """ + Microsoft HTML Help Workshop + """ + if self.vc_ver < 11.0: + return [] + + return [os.path.join(self.si.ProgramFilesx86, 'HTML Help Workshop')] + + @property + def UCRTLibraries(self): + """ + Microsoft Universal C Runtime SDK Libraries + """ + if self.vc_ver < 14.0: + return [] + + arch_subdir = self.pi.target_dir(x64=True) + lib = os.path.join(self.si.UniversalCRTSdkDir, 'lib') + ucrtver = self._ucrt_subdir + return [os.path.join(lib, '%sucrt%s' % (ucrtver, arch_subdir))] + + @property + def UCRTIncludes(self): + """ + Microsoft Universal C Runtime SDK Include + """ + if self.vc_ver < 14.0: + return [] + + include = os.path.join(self.si.UniversalCRTSdkDir, 'include') + return [os.path.join(include, '%sucrt' % self._ucrt_subdir)] + + @property + def _ucrt_subdir(self): + """ + Microsoft Universal C Runtime SDK version subdir + """ + ucrtver = self.si.UniversalCRTSdkLastVersion + return ('%s\\' % ucrtver) if ucrtver else '' + + @property + def FSharp(self): + """ + Microsoft Visual F# + """ + if self.vc_ver < 11.0 and self.vc_ver > 12.0: + return [] + + return self.si.FSharpInstallDir + + @property + def VCRuntimeRedist(self): + """ + Microsoft Visual C++ runtime redistribuable dll + """ + arch_subdir = self.pi.target_dir(x64=True) + if self.vc_ver < 15: + redist_path = self.si.VCInstallDir + vcruntime = 'redist%s\\Microsoft.VC%d0.CRT\\vcruntime%d0.dll' + else: + redist_path = self.si.VCInstallDir.replace('\\Tools', '\\Redist') + vcruntime = 'onecore%s\\Microsoft.VC%d0.CRT\\vcruntime%d0.dll' + + # Visual Studio 2017 is still Visual C++ 14.0 + dll_ver = 14.0 if self.vc_ver == 15 else self.vc_ver + + vcruntime = vcruntime % (arch_subdir, self.vc_ver, dll_ver) + return os.path.join(redist_path, vcruntime) + + def return_env(self, exists=True): + """ + Return environment dict. + + Parameters + ---------- + exists: bool + It True, only return existing paths. + """ + env = dict( + include=self._build_paths('include', + [self.VCIncludes, + self.OSIncludes, + self.UCRTIncludes, + self.NetFxSDKIncludes], + exists), + lib=self._build_paths('lib', + [self.VCLibraries, + self.OSLibraries, + self.FxTools, + self.UCRTLibraries, + self.NetFxSDKLibraries], + exists), + libpath=self._build_paths('libpath', + [self.VCLibraries, + self.FxTools, + self.VCStoreRefs, + self.OSLibpath], + exists), + path=self._build_paths('path', + [self.VCTools, + self.VSTools, + self.VsTDb, + self.SdkTools, + self.SdkSetup, + self.FxTools, + self.MSBuild, + self.HTMLHelpWorkshop, + self.FSharp], + exists), + ) + if self.vc_ver >= 14 and os.path.isfile(self.VCRuntimeRedist): + env['py_vcruntime_redist'] = self.VCRuntimeRedist + return env + + def _build_paths(self, name, spec_path_lists, exists): + """ + Given an environment variable name and specified paths, + return a pathsep-separated string of paths containing + unique, extant, directories from those paths and from + the environment variable. Raise an error if no paths + are resolved. + """ + # flatten spec_path_lists + spec_paths = itertools.chain.from_iterable(spec_path_lists) + env_paths = safe_env.get(name, '').split(os.pathsep) + paths = itertools.chain(spec_paths, env_paths) + extant_paths = list(filter(os.path.isdir, paths)) if exists else paths + if not extant_paths: + msg = "%s environment variable is empty" % name.upper() + raise distutils.errors.DistutilsPlatformError(msg) + unique_paths = self._unique_everseen(extant_paths) + return os.pathsep.join(unique_paths) + + # from Python docs + def _unique_everseen(self, iterable, key=None): + """ + List unique elements, preserving order. + Remember all elements ever seen. + + _unique_everseen('AAAABBBCCDAABBB') --> A B C D + + _unique_everseen('ABBCcAD', str.lower) --> A B C D + """ + seen = set() + seen_add = seen.add + if key is None: + for element in filterfalse(seen.__contains__, iterable): + seen_add(element) + yield element + else: + for element in iterable: + k = key(element) + if k not in seen: + seen_add(k) + yield element diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/namespaces.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/namespaces.py new file mode 100644 index 0000000..dc16106 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/namespaces.py @@ -0,0 +1,107 @@ +import os +from distutils import log +import itertools + +from setuptools.extern.six.moves import map + + +flatten = itertools.chain.from_iterable + + +class Installer: + + nspkg_ext = '-nspkg.pth' + + def install_namespaces(self): + nsp = self._get_all_ns_packages() + if not nsp: + return + filename, ext = os.path.splitext(self._get_target()) + filename += self.nspkg_ext + self.outputs.append(filename) + log.info("Installing %s", filename) + lines = map(self._gen_nspkg_line, nsp) + + if self.dry_run: + # always generate the lines, even in dry run + list(lines) + return + + with open(filename, 'wt') as f: + f.writelines(lines) + + def uninstall_namespaces(self): + filename, ext = os.path.splitext(self._get_target()) + filename += self.nspkg_ext + if not os.path.exists(filename): + return + log.info("Removing %s", filename) + os.remove(filename) + + def _get_target(self): + return self.target + + _nspkg_tmpl = ( + "import sys, types, os", + "has_mfs = sys.version_info > (3, 5)", + "p = os.path.join(%(root)s, *%(pth)r)", + "importlib = has_mfs and __import__('importlib.util')", + "has_mfs and __import__('importlib.machinery')", + "m = has_mfs and " + "sys.modules.setdefault(%(pkg)r, " + "importlib.util.module_from_spec(" + "importlib.machinery.PathFinder.find_spec(%(pkg)r, " + "[os.path.dirname(p)])))", + "m = m or " + "sys.modules.setdefault(%(pkg)r, types.ModuleType(%(pkg)r))", + "mp = (m or []) and m.__dict__.setdefault('__path__',[])", + "(p not in mp) and mp.append(p)", + ) + "lines for the namespace installer" + + _nspkg_tmpl_multi = ( + 'm and setattr(sys.modules[%(parent)r], %(child)r, m)', + ) + "additional line(s) when a parent package is indicated" + + def _get_root(self): + return "sys._getframe(1).f_locals['sitedir']" + + def _gen_nspkg_line(self, pkg): + # ensure pkg is not a unicode string under Python 2.7 + pkg = str(pkg) + pth = tuple(pkg.split('.')) + root = self._get_root() + tmpl_lines = self._nspkg_tmpl + parent, sep, child = pkg.rpartition('.') + if parent: + tmpl_lines += self._nspkg_tmpl_multi + return ';'.join(tmpl_lines) % locals() + '\n' + + def _get_all_ns_packages(self): + """Return sorted list of all package namespaces""" + pkgs = self.distribution.namespace_packages or [] + return sorted(flatten(map(self._pkg_names, pkgs))) + + @staticmethod + def _pkg_names(pkg): + """ + Given a namespace package, yield the components of that + package. + + >>> names = Installer._pkg_names('a.b.c') + >>> set(names) == set(['a', 'a.b', 'a.b.c']) + True + """ + parts = pkg.split('.') + while parts: + yield '.'.join(parts) + parts.pop() + + +class DevelopInstaller(Installer): + def _get_root(self): + return repr(str(self.egg_path)) + + def _get_target(self): + return self.egg_link diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/package_index.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/package_index.py new file mode 100644 index 0000000..6b06f2c --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/package_index.py @@ -0,0 +1,1136 @@ +"""PyPI and direct package downloading""" +import sys +import os +import re +import shutil +import socket +import base64 +import hashlib +import itertools +import warnings +from functools import wraps + +from setuptools.extern import six +from setuptools.extern.six.moves import urllib, http_client, configparser, map + +import setuptools +from pkg_resources import ( + CHECKOUT_DIST, Distribution, BINARY_DIST, normalize_path, SOURCE_DIST, + Environment, find_distributions, safe_name, safe_version, + to_filename, Requirement, DEVELOP_DIST, EGG_DIST, +) +from setuptools import ssl_support +from distutils import log +from distutils.errors import DistutilsError +from fnmatch import translate +from setuptools.py27compat import get_all_headers +from setuptools.py33compat import unescape +from setuptools.wheel import Wheel + +__metaclass__ = type + +EGG_FRAGMENT = re.compile(r'^egg=([-A-Za-z0-9_.+!]+)$') +HREF = re.compile(r"""href\s*=\s*['"]?([^'"> ]+)""", re.I) +PYPI_MD5 = re.compile( + r'<a href="([^"#]+)">([^<]+)</a>\n\s+\(<a (?:title="MD5 hash"\n\s+)' + r'href="[^?]+\?:action=show_md5&digest=([0-9a-f]{32})">md5</a>\)' +) +URL_SCHEME = re.compile('([-+.a-z0-9]{2,}):', re.I).match +EXTENSIONS = ".tar.gz .tar.bz2 .tar .zip .tgz".split() + +__all__ = [ + 'PackageIndex', 'distros_for_url', 'parse_bdist_wininst', + 'interpret_distro_name', +] + +_SOCKET_TIMEOUT = 15 + +_tmpl = "setuptools/{setuptools.__version__} Python-urllib/{py_major}" +user_agent = _tmpl.format(py_major=sys.version[:3], setuptools=setuptools) + + +def parse_requirement_arg(spec): + try: + return Requirement.parse(spec) + except ValueError: + raise DistutilsError( + "Not a URL, existing file, or requirement spec: %r" % (spec,) + ) + + +def parse_bdist_wininst(name): + """Return (base,pyversion) or (None,None) for possible .exe name""" + + lower = name.lower() + base, py_ver, plat = None, None, None + + if lower.endswith('.exe'): + if lower.endswith('.win32.exe'): + base = name[:-10] + plat = 'win32' + elif lower.startswith('.win32-py', -16): + py_ver = name[-7:-4] + base = name[:-16] + plat = 'win32' + elif lower.endswith('.win-amd64.exe'): + base = name[:-14] + plat = 'win-amd64' + elif lower.startswith('.win-amd64-py', -20): + py_ver = name[-7:-4] + base = name[:-20] + plat = 'win-amd64' + return base, py_ver, plat + + +def egg_info_for_url(url): + parts = urllib.parse.urlparse(url) + scheme, server, path, parameters, query, fragment = parts + base = urllib.parse.unquote(path.split('/')[-1]) + if server == 'sourceforge.net' and base == 'download': # XXX Yuck + base = urllib.parse.unquote(path.split('/')[-2]) + if '#' in base: + base, fragment = base.split('#', 1) + return base, fragment + + +def distros_for_url(url, metadata=None): + """Yield egg or source distribution objects that might be found at a URL""" + base, fragment = egg_info_for_url(url) + for dist in distros_for_location(url, base, metadata): + yield dist + if fragment: + match = EGG_FRAGMENT.match(fragment) + if match: + for dist in interpret_distro_name( + url, match.group(1), metadata, precedence=CHECKOUT_DIST + ): + yield dist + + +def distros_for_location(location, basename, metadata=None): + """Yield egg or source distribution objects based on basename""" + if basename.endswith('.egg.zip'): + basename = basename[:-4] # strip the .zip + if basename.endswith('.egg') and '-' in basename: + # only one, unambiguous interpretation + return [Distribution.from_location(location, basename, metadata)] + if basename.endswith('.whl') and '-' in basename: + wheel = Wheel(basename) + if not wheel.is_compatible(): + return [] + return [Distribution( + location=location, + project_name=wheel.project_name, + version=wheel.version, + # Increase priority over eggs. + precedence=EGG_DIST + 1, + )] + if basename.endswith('.exe'): + win_base, py_ver, platform = parse_bdist_wininst(basename) + if win_base is not None: + return interpret_distro_name( + location, win_base, metadata, py_ver, BINARY_DIST, platform + ) + # Try source distro extensions (.zip, .tgz, etc.) + # + for ext in EXTENSIONS: + if basename.endswith(ext): + basename = basename[:-len(ext)] + return interpret_distro_name(location, basename, metadata) + return [] # no extension matched + + +def distros_for_filename(filename, metadata=None): + """Yield possible egg or source distribution objects based on a filename""" + return distros_for_location( + normalize_path(filename), os.path.basename(filename), metadata + ) + + +def interpret_distro_name( + location, basename, metadata, py_version=None, precedence=SOURCE_DIST, + platform=None +): + """Generate alternative interpretations of a source distro name + + Note: if `location` is a filesystem filename, you should call + ``pkg_resources.normalize_path()`` on it before passing it to this + routine! + """ + # Generate alternative interpretations of a source distro name + # Because some packages are ambiguous as to name/versions split + # e.g. "adns-python-1.1.0", "egenix-mx-commercial", etc. + # So, we generate each possible interepretation (e.g. "adns, python-1.1.0" + # "adns-python, 1.1.0", and "adns-python-1.1.0, no version"). In practice, + # the spurious interpretations should be ignored, because in the event + # there's also an "adns" package, the spurious "python-1.1.0" version will + # compare lower than any numeric version number, and is therefore unlikely + # to match a request for it. It's still a potential problem, though, and + # in the long run PyPI and the distutils should go for "safe" names and + # versions in distribution archive names (sdist and bdist). + + parts = basename.split('-') + if not py_version and any(re.match(r'py\d\.\d$', p) for p in parts[2:]): + # it is a bdist_dumb, not an sdist -- bail out + return + + for p in range(1, len(parts) + 1): + yield Distribution( + location, metadata, '-'.join(parts[:p]), '-'.join(parts[p:]), + py_version=py_version, precedence=precedence, + platform=platform + ) + + +# From Python 2.7 docs +def unique_everseen(iterable, key=None): + "List unique elements, preserving order. Remember all elements ever seen." + # unique_everseen('AAAABBBCCDAABBB') --> A B C D + # unique_everseen('ABBCcAD', str.lower) --> A B C D + seen = set() + seen_add = seen.add + if key is None: + for element in six.moves.filterfalse(seen.__contains__, iterable): + seen_add(element) + yield element + else: + for element in iterable: + k = key(element) + if k not in seen: + seen_add(k) + yield element + + +def unique_values(func): + """ + Wrap a function returning an iterable such that the resulting iterable + only ever yields unique items. + """ + + @wraps(func) + def wrapper(*args, **kwargs): + return unique_everseen(func(*args, **kwargs)) + + return wrapper + + +REL = re.compile(r"""<([^>]*\srel\s*=\s*['"]?([^'">]+)[^>]*)>""", re.I) +# this line is here to fix emacs' cruddy broken syntax highlighting + + +@unique_values +def find_external_links(url, page): + """Find rel="homepage" and rel="download" links in `page`, yielding URLs""" + + for match in REL.finditer(page): + tag, rel = match.groups() + rels = set(map(str.strip, rel.lower().split(','))) + if 'homepage' in rels or 'download' in rels: + for match in HREF.finditer(tag): + yield urllib.parse.urljoin(url, htmldecode(match.group(1))) + + for tag in ("<th>Home Page", "<th>Download URL"): + pos = page.find(tag) + if pos != -1: + match = HREF.search(page, pos) + if match: + yield urllib.parse.urljoin(url, htmldecode(match.group(1))) + + +class ContentChecker: + """ + A null content checker that defines the interface for checking content + """ + + def feed(self, block): + """ + Feed a block of data to the hash. + """ + return + + def is_valid(self): + """ + Check the hash. Return False if validation fails. + """ + return True + + def report(self, reporter, template): + """ + Call reporter with information about the checker (hash name) + substituted into the template. + """ + return + + +class HashChecker(ContentChecker): + pattern = re.compile( + r'(?P<hash_name>sha1|sha224|sha384|sha256|sha512|md5)=' + r'(?P<expected>[a-f0-9]+)' + ) + + def __init__(self, hash_name, expected): + self.hash_name = hash_name + self.hash = hashlib.new(hash_name) + self.expected = expected + + @classmethod + def from_url(cls, url): + "Construct a (possibly null) ContentChecker from a URL" + fragment = urllib.parse.urlparse(url)[-1] + if not fragment: + return ContentChecker() + match = cls.pattern.search(fragment) + if not match: + return ContentChecker() + return cls(**match.groupdict()) + + def feed(self, block): + self.hash.update(block) + + def is_valid(self): + return self.hash.hexdigest() == self.expected + + def report(self, reporter, template): + msg = template % self.hash_name + return reporter(msg) + + +class PackageIndex(Environment): + """A distribution index that scans web pages for download URLs""" + + def __init__( + self, index_url="https://pypi.org/simple/", hosts=('*',), + ca_bundle=None, verify_ssl=True, *args, **kw + ): + Environment.__init__(self, *args, **kw) + self.index_url = index_url + "/" [:not index_url.endswith('/')] + self.scanned_urls = {} + self.fetched_urls = {} + self.package_pages = {} + self.allows = re.compile('|'.join(map(translate, hosts))).match + self.to_scan = [] + use_ssl = ( + verify_ssl + and ssl_support.is_available + and (ca_bundle or ssl_support.find_ca_bundle()) + ) + if use_ssl: + self.opener = ssl_support.opener_for(ca_bundle) + else: + self.opener = urllib.request.urlopen + + def process_url(self, url, retrieve=False): + """Evaluate a URL as a possible download, and maybe retrieve it""" + if url in self.scanned_urls and not retrieve: + return + self.scanned_urls[url] = True + if not URL_SCHEME(url): + self.process_filename(url) + return + else: + dists = list(distros_for_url(url)) + if dists: + if not self.url_ok(url): + return + self.debug("Found link: %s", url) + + if dists or not retrieve or url in self.fetched_urls: + list(map(self.add, dists)) + return # don't need the actual page + + if not self.url_ok(url): + self.fetched_urls[url] = True + return + + self.info("Reading %s", url) + self.fetched_urls[url] = True # prevent multiple fetch attempts + tmpl = "Download error on %s: %%s -- Some packages may not be found!" + f = self.open_url(url, tmpl % url) + if f is None: + return + self.fetched_urls[f.url] = True + if 'html' not in f.headers.get('content-type', '').lower(): + f.close() # not html, we can't process it + return + + base = f.url # handle redirects + page = f.read() + if not isinstance(page, str): + # In Python 3 and got bytes but want str. + if isinstance(f, urllib.error.HTTPError): + # Errors have no charset, assume latin1: + charset = 'latin-1' + else: + charset = f.headers.get_param('charset') or 'latin-1' + page = page.decode(charset, "ignore") + f.close() + for match in HREF.finditer(page): + link = urllib.parse.urljoin(base, htmldecode(match.group(1))) + self.process_url(link) + if url.startswith(self.index_url) and getattr(f, 'code', None) != 404: + page = self.process_index(url, page) + + def process_filename(self, fn, nested=False): + # process filenames or directories + if not os.path.exists(fn): + self.warn("Not found: %s", fn) + return + + if os.path.isdir(fn) and not nested: + path = os.path.realpath(fn) + for item in os.listdir(path): + self.process_filename(os.path.join(path, item), True) + + dists = distros_for_filename(fn) + if dists: + self.debug("Found: %s", fn) + list(map(self.add, dists)) + + def url_ok(self, url, fatal=False): + s = URL_SCHEME(url) + is_file = s and s.group(1).lower() == 'file' + if is_file or self.allows(urllib.parse.urlparse(url)[1]): + return True + msg = ( + "\nNote: Bypassing %s (disallowed host; see " + "http://bit.ly/2hrImnY for details).\n") + if fatal: + raise DistutilsError(msg % url) + else: + self.warn(msg, url) + + def scan_egg_links(self, search_path): + dirs = filter(os.path.isdir, search_path) + egg_links = ( + (path, entry) + for path in dirs + for entry in os.listdir(path) + if entry.endswith('.egg-link') + ) + list(itertools.starmap(self.scan_egg_link, egg_links)) + + def scan_egg_link(self, path, entry): + with open(os.path.join(path, entry)) as raw_lines: + # filter non-empty lines + lines = list(filter(None, map(str.strip, raw_lines))) + + if len(lines) != 2: + # format is not recognized; punt + return + + egg_path, setup_path = lines + + for dist in find_distributions(os.path.join(path, egg_path)): + dist.location = os.path.join(path, *lines) + dist.precedence = SOURCE_DIST + self.add(dist) + + def process_index(self, url, page): + """Process the contents of a PyPI page""" + + def scan(link): + # Process a URL to see if it's for a package page + if link.startswith(self.index_url): + parts = list(map( + urllib.parse.unquote, link[len(self.index_url):].split('/') + )) + if len(parts) == 2 and '#' not in parts[1]: + # it's a package page, sanitize and index it + pkg = safe_name(parts[0]) + ver = safe_version(parts[1]) + self.package_pages.setdefault(pkg.lower(), {})[link] = True + return to_filename(pkg), to_filename(ver) + return None, None + + # process an index page into the package-page index + for match in HREF.finditer(page): + try: + scan(urllib.parse.urljoin(url, htmldecode(match.group(1)))) + except ValueError: + pass + + pkg, ver = scan(url) # ensure this page is in the page index + if pkg: + # process individual package page + for new_url in find_external_links(url, page): + # Process the found URL + base, frag = egg_info_for_url(new_url) + if base.endswith('.py') and not frag: + if ver: + new_url += '#egg=%s-%s' % (pkg, ver) + else: + self.need_version_info(url) + self.scan_url(new_url) + + return PYPI_MD5.sub( + lambda m: '<a href="%s#md5=%s">%s</a>' % m.group(1, 3, 2), page + ) + else: + return "" # no sense double-scanning non-package pages + + def need_version_info(self, url): + self.scan_all( + "Page at %s links to .py file(s) without version info; an index " + "scan is required.", url + ) + + def scan_all(self, msg=None, *args): + if self.index_url not in self.fetched_urls: + if msg: + self.warn(msg, *args) + self.info( + "Scanning index of all packages (this may take a while)" + ) + self.scan_url(self.index_url) + + def find_packages(self, requirement): + self.scan_url(self.index_url + requirement.unsafe_name + '/') + + if not self.package_pages.get(requirement.key): + # Fall back to safe version of the name + self.scan_url(self.index_url + requirement.project_name + '/') + + if not self.package_pages.get(requirement.key): + # We couldn't find the target package, so search the index page too + self.not_found_in_index(requirement) + + for url in list(self.package_pages.get(requirement.key, ())): + # scan each page that might be related to the desired package + self.scan_url(url) + + def obtain(self, requirement, installer=None): + self.prescan() + self.find_packages(requirement) + for dist in self[requirement.key]: + if dist in requirement: + return dist + self.debug("%s does not match %s", requirement, dist) + return super(PackageIndex, self).obtain(requirement, installer) + + def check_hash(self, checker, filename, tfp): + """ + checker is a ContentChecker + """ + checker.report( + self.debug, + "Validating %%s checksum for %s" % filename) + if not checker.is_valid(): + tfp.close() + os.unlink(filename) + raise DistutilsError( + "%s validation failed for %s; " + "possible download problem?" + % (checker.hash.name, os.path.basename(filename)) + ) + + def add_find_links(self, urls): + """Add `urls` to the list that will be prescanned for searches""" + for url in urls: + if ( + self.to_scan is None # if we have already "gone online" + or not URL_SCHEME(url) # or it's a local file/directory + or url.startswith('file:') + or list(distros_for_url(url)) # or a direct package link + ): + # then go ahead and process it now + self.scan_url(url) + else: + # otherwise, defer retrieval till later + self.to_scan.append(url) + + def prescan(self): + """Scan urls scheduled for prescanning (e.g. --find-links)""" + if self.to_scan: + list(map(self.scan_url, self.to_scan)) + self.to_scan = None # from now on, go ahead and process immediately + + def not_found_in_index(self, requirement): + if self[requirement.key]: # we've seen at least one distro + meth, msg = self.info, "Couldn't retrieve index page for %r" + else: # no distros seen for this name, might be misspelled + meth, msg = ( + self.warn, + "Couldn't find index page for %r (maybe misspelled?)") + meth(msg, requirement.unsafe_name) + self.scan_all() + + def download(self, spec, tmpdir): + """Locate and/or download `spec` to `tmpdir`, returning a local path + + `spec` may be a ``Requirement`` object, or a string containing a URL, + an existing local filename, or a project/version requirement spec + (i.e. the string form of a ``Requirement`` object). If it is the URL + of a .py file with an unambiguous ``#egg=name-version`` tag (i.e., one + that escapes ``-`` as ``_`` throughout), a trivial ``setup.py`` is + automatically created alongside the downloaded file. + + If `spec` is a ``Requirement`` object or a string containing a + project/version requirement spec, this method returns the location of + a matching distribution (possibly after downloading it to `tmpdir`). + If `spec` is a locally existing file or directory name, it is simply + returned unchanged. If `spec` is a URL, it is downloaded to a subpath + of `tmpdir`, and the local filename is returned. Various errors may be + raised if a problem occurs during downloading. + """ + if not isinstance(spec, Requirement): + scheme = URL_SCHEME(spec) + if scheme: + # It's a url, download it to tmpdir + found = self._download_url(scheme.group(1), spec, tmpdir) + base, fragment = egg_info_for_url(spec) + if base.endswith('.py'): + found = self.gen_setup(found, fragment, tmpdir) + return found + elif os.path.exists(spec): + # Existing file or directory, just return it + return spec + else: + spec = parse_requirement_arg(spec) + return getattr(self.fetch_distribution(spec, tmpdir), 'location', None) + + def fetch_distribution( + self, requirement, tmpdir, force_scan=False, source=False, + develop_ok=False, local_index=None): + """Obtain a distribution suitable for fulfilling `requirement` + + `requirement` must be a ``pkg_resources.Requirement`` instance. + If necessary, or if the `force_scan` flag is set, the requirement is + searched for in the (online) package index as well as the locally + installed packages. If a distribution matching `requirement` is found, + the returned distribution's ``location`` is the value you would have + gotten from calling the ``download()`` method with the matching + distribution's URL or filename. If no matching distribution is found, + ``None`` is returned. + + If the `source` flag is set, only source distributions and source + checkout links will be considered. Unless the `develop_ok` flag is + set, development and system eggs (i.e., those using the ``.egg-info`` + format) will be ignored. + """ + # process a Requirement + self.info("Searching for %s", requirement) + skipped = {} + dist = None + + def find(req, env=None): + if env is None: + env = self + # Find a matching distribution; may be called more than once + + for dist in env[req.key]: + + if dist.precedence == DEVELOP_DIST and not develop_ok: + if dist not in skipped: + self.warn( + "Skipping development or system egg: %s", dist, + ) + skipped[dist] = 1 + continue + + test = ( + dist in req + and (dist.precedence <= SOURCE_DIST or not source) + ) + if test: + loc = self.download(dist.location, tmpdir) + dist.download_location = loc + if os.path.exists(dist.download_location): + return dist + + if force_scan: + self.prescan() + self.find_packages(requirement) + dist = find(requirement) + + if not dist and local_index is not None: + dist = find(requirement, local_index) + + if dist is None: + if self.to_scan is not None: + self.prescan() + dist = find(requirement) + + if dist is None and not force_scan: + self.find_packages(requirement) + dist = find(requirement) + + if dist is None: + self.warn( + "No local packages or working download links found for %s%s", + (source and "a source distribution of " or ""), + requirement, + ) + else: + self.info("Best match: %s", dist) + return dist.clone(location=dist.download_location) + + def fetch(self, requirement, tmpdir, force_scan=False, source=False): + """Obtain a file suitable for fulfilling `requirement` + + DEPRECATED; use the ``fetch_distribution()`` method now instead. For + backward compatibility, this routine is identical but returns the + ``location`` of the downloaded distribution instead of a distribution + object. + """ + dist = self.fetch_distribution(requirement, tmpdir, force_scan, source) + if dist is not None: + return dist.location + return None + + def gen_setup(self, filename, fragment, tmpdir): + match = EGG_FRAGMENT.match(fragment) + dists = match and [ + d for d in + interpret_distro_name(filename, match.group(1), None) if d.version + ] or [] + + if len(dists) == 1: # unambiguous ``#egg`` fragment + basename = os.path.basename(filename) + + # Make sure the file has been downloaded to the temp dir. + if os.path.dirname(filename) != tmpdir: + dst = os.path.join(tmpdir, basename) + from setuptools.command.easy_install import samefile + if not samefile(filename, dst): + shutil.copy2(filename, dst) + filename = dst + + with open(os.path.join(tmpdir, 'setup.py'), 'w') as file: + file.write( + "from setuptools import setup\n" + "setup(name=%r, version=%r, py_modules=[%r])\n" + % ( + dists[0].project_name, dists[0].version, + os.path.splitext(basename)[0] + ) + ) + return filename + + elif match: + raise DistutilsError( + "Can't unambiguously interpret project/version identifier %r; " + "any dashes in the name or version should be escaped using " + "underscores. %r" % (fragment, dists) + ) + else: + raise DistutilsError( + "Can't process plain .py files without an '#egg=name-version'" + " suffix to enable automatic setup script generation." + ) + + dl_blocksize = 8192 + + def _download_to(self, url, filename): + self.info("Downloading %s", url) + # Download the file + fp = None + try: + checker = HashChecker.from_url(url) + fp = self.open_url(url) + if isinstance(fp, urllib.error.HTTPError): + raise DistutilsError( + "Can't download %s: %s %s" % (url, fp.code, fp.msg) + ) + headers = fp.info() + blocknum = 0 + bs = self.dl_blocksize + size = -1 + if "content-length" in headers: + # Some servers return multiple Content-Length headers :( + sizes = get_all_headers(headers, 'Content-Length') + size = max(map(int, sizes)) + self.reporthook(url, filename, blocknum, bs, size) + with open(filename, 'wb') as tfp: + while True: + block = fp.read(bs) + if block: + checker.feed(block) + tfp.write(block) + blocknum += 1 + self.reporthook(url, filename, blocknum, bs, size) + else: + break + self.check_hash(checker, filename, tfp) + return headers + finally: + if fp: + fp.close() + + def reporthook(self, url, filename, blocknum, blksize, size): + pass # no-op + + def open_url(self, url, warning=None): + if url.startswith('file:'): + return local_open(url) + try: + return open_with_auth(url, self.opener) + except (ValueError, http_client.InvalidURL) as v: + msg = ' '.join([str(arg) for arg in v.args]) + if warning: + self.warn(warning, msg) + else: + raise DistutilsError('%s %s' % (url, msg)) + except urllib.error.HTTPError as v: + return v + except urllib.error.URLError as v: + if warning: + self.warn(warning, v.reason) + else: + raise DistutilsError("Download error for %s: %s" + % (url, v.reason)) + except http_client.BadStatusLine as v: + if warning: + self.warn(warning, v.line) + else: + raise DistutilsError( + '%s returned a bad status line. The server might be ' + 'down, %s' % + (url, v.line) + ) + except (http_client.HTTPException, socket.error) as v: + if warning: + self.warn(warning, v) + else: + raise DistutilsError("Download error for %s: %s" + % (url, v)) + + def _download_url(self, scheme, url, tmpdir): + # Determine download filename + # + name, fragment = egg_info_for_url(url) + if name: + while '..' in name: + name = name.replace('..', '.').replace('\\', '_') + else: + name = "__downloaded__" # default if URL has no path contents + + if name.endswith('.egg.zip'): + name = name[:-4] # strip the extra .zip before download + + filename = os.path.join(tmpdir, name) + + # Download the file + # + if scheme == 'svn' or scheme.startswith('svn+'): + return self._download_svn(url, filename) + elif scheme == 'git' or scheme.startswith('git+'): + return self._download_git(url, filename) + elif scheme.startswith('hg+'): + return self._download_hg(url, filename) + elif scheme == 'file': + return urllib.request.url2pathname(urllib.parse.urlparse(url)[2]) + else: + self.url_ok(url, True) # raises error if not allowed + return self._attempt_download(url, filename) + + def scan_url(self, url): + self.process_url(url, True) + + def _attempt_download(self, url, filename): + headers = self._download_to(url, filename) + if 'html' in headers.get('content-type', '').lower(): + return self._download_html(url, headers, filename) + else: + return filename + + def _download_html(self, url, headers, filename): + file = open(filename) + for line in file: + if line.strip(): + # Check for a subversion index page + if re.search(r'<title>([^- ]+ - )?Revision \d+:', line): + # it's a subversion index page: + file.close() + os.unlink(filename) + return self._download_svn(url, filename) + break # not an index page + file.close() + os.unlink(filename) + raise DistutilsError("Unexpected HTML page found at " + url) + + def _download_svn(self, url, filename): + warnings.warn("SVN download support is deprecated", UserWarning) + url = url.split('#', 1)[0] # remove any fragment for svn's sake + creds = '' + if url.lower().startswith('svn:') and '@' in url: + scheme, netloc, path, p, q, f = urllib.parse.urlparse(url) + if not netloc and path.startswith('//') and '/' in path[2:]: + netloc, path = path[2:].split('/', 1) + auth, host = _splituser(netloc) + if auth: + if ':' in auth: + user, pw = auth.split(':', 1) + creds = " --username=%s --password=%s" % (user, pw) + else: + creds = " --username=" + auth + netloc = host + parts = scheme, netloc, url, p, q, f + url = urllib.parse.urlunparse(parts) + self.info("Doing subversion checkout from %s to %s", url, filename) + os.system("svn checkout%s -q %s %s" % (creds, url, filename)) + return filename + + @staticmethod + def _vcs_split_rev_from_url(url, pop_prefix=False): + scheme, netloc, path, query, frag = urllib.parse.urlsplit(url) + + scheme = scheme.split('+', 1)[-1] + + # Some fragment identification fails + path = path.split('#', 1)[0] + + rev = None + if '@' in path: + path, rev = path.rsplit('@', 1) + + # Also, discard fragment + url = urllib.parse.urlunsplit((scheme, netloc, path, query, '')) + + return url, rev + + def _download_git(self, url, filename): + filename = filename.split('#', 1)[0] + url, rev = self._vcs_split_rev_from_url(url, pop_prefix=True) + + self.info("Doing git clone from %s to %s", url, filename) + os.system("git clone --quiet %s %s" % (url, filename)) + + if rev is not None: + self.info("Checking out %s", rev) + os.system("git -C %s checkout --quiet %s" % ( + filename, + rev, + )) + + return filename + + def _download_hg(self, url, filename): + filename = filename.split('#', 1)[0] + url, rev = self._vcs_split_rev_from_url(url, pop_prefix=True) + + self.info("Doing hg clone from %s to %s", url, filename) + os.system("hg clone --quiet %s %s" % (url, filename)) + + if rev is not None: + self.info("Updating to %s", rev) + os.system("hg --cwd %s up -C -r %s -q" % ( + filename, + rev, + )) + + return filename + + def debug(self, msg, *args): + log.debug(msg, *args) + + def info(self, msg, *args): + log.info(msg, *args) + + def warn(self, msg, *args): + log.warn(msg, *args) + + +# This pattern matches a character entity reference (a decimal numeric +# references, a hexadecimal numeric reference, or a named reference). +entity_sub = re.compile(r'&(#(\d+|x[\da-fA-F]+)|[\w.:-]+);?').sub + + +def decode_entity(match): + what = match.group(0) + return unescape(what) + + +def htmldecode(text): + """ + Decode HTML entities in the given text. + + >>> htmldecode( + ... 'https://../package_name-0.1.2.tar.gz' + ... '?tokena=A&tokenb=B">package_name-0.1.2.tar.gz') + 'https://../package_name-0.1.2.tar.gz?tokena=A&tokenb=B">package_name-0.1.2.tar.gz' + """ + return entity_sub(decode_entity, text) + + +def socket_timeout(timeout=15): + def _socket_timeout(func): + def _socket_timeout(*args, **kwargs): + old_timeout = socket.getdefaulttimeout() + socket.setdefaulttimeout(timeout) + try: + return func(*args, **kwargs) + finally: + socket.setdefaulttimeout(old_timeout) + + return _socket_timeout + + return _socket_timeout + + +def _encode_auth(auth): + """ + A function compatible with Python 2.3-3.3 that will encode + auth from a URL suitable for an HTTP header. + >>> str(_encode_auth('username%3Apassword')) + 'dXNlcm5hbWU6cGFzc3dvcmQ=' + + Long auth strings should not cause a newline to be inserted. + >>> long_auth = 'username:' + 'password'*10 + >>> chr(10) in str(_encode_auth(long_auth)) + False + """ + auth_s = urllib.parse.unquote(auth) + # convert to bytes + auth_bytes = auth_s.encode() + encoded_bytes = base64.b64encode(auth_bytes) + # convert back to a string + encoded = encoded_bytes.decode() + # strip the trailing carriage return + return encoded.replace('\n', '') + + +class Credential: + """ + A username/password pair. Use like a namedtuple. + """ + + def __init__(self, username, password): + self.username = username + self.password = password + + def __iter__(self): + yield self.username + yield self.password + + def __str__(self): + return '%(username)s:%(password)s' % vars(self) + + +class PyPIConfig(configparser.RawConfigParser): + def __init__(self): + """ + Load from ~/.pypirc + """ + defaults = dict.fromkeys(['username', 'password', 'repository'], '') + configparser.RawConfigParser.__init__(self, defaults) + + rc = os.path.join(os.path.expanduser('~'), '.pypirc') + if os.path.exists(rc): + self.read(rc) + + @property + def creds_by_repository(self): + sections_with_repositories = [ + section for section in self.sections() + if self.get(section, 'repository').strip() + ] + + return dict(map(self._get_repo_cred, sections_with_repositories)) + + def _get_repo_cred(self, section): + repo = self.get(section, 'repository').strip() + return repo, Credential( + self.get(section, 'username').strip(), + self.get(section, 'password').strip(), + ) + + def find_credential(self, url): + """ + If the URL indicated appears to be a repository defined in this + config, return the credential for that repository. + """ + for repository, cred in self.creds_by_repository.items(): + if url.startswith(repository): + return cred + + +def open_with_auth(url, opener=urllib.request.urlopen): + """Open a urllib2 request, handling HTTP authentication""" + + parsed = urllib.parse.urlparse(url) + scheme, netloc, path, params, query, frag = parsed + + # Double scheme does not raise on Mac OS X as revealed by a + # failing test. We would expect "nonnumeric port". Refs #20. + if netloc.endswith(':'): + raise http_client.InvalidURL("nonnumeric port: ''") + + if scheme in ('http', 'https'): + auth, address = _splituser(netloc) + else: + auth = None + + if not auth: + cred = PyPIConfig().find_credential(url) + if cred: + auth = str(cred) + info = cred.username, url + log.info('Authenticating as %s for %s (from .pypirc)', *info) + + if auth: + auth = "Basic " + _encode_auth(auth) + parts = scheme, address, path, params, query, frag + new_url = urllib.parse.urlunparse(parts) + request = urllib.request.Request(new_url) + request.add_header("Authorization", auth) + else: + request = urllib.request.Request(url) + + request.add_header('User-Agent', user_agent) + fp = opener(request) + + if auth: + # Put authentication info back into request URL if same host, + # so that links found on the page will work + s2, h2, path2, param2, query2, frag2 = urllib.parse.urlparse(fp.url) + if s2 == scheme and h2 == address: + parts = s2, netloc, path2, param2, query2, frag2 + fp.url = urllib.parse.urlunparse(parts) + + return fp + + +# copy of urllib.parse._splituser from Python 3.8 +def _splituser(host): + """splituser('user[:passwd]@host[:port]') --> 'user[:passwd]', 'host[:port]'.""" + user, delim, host = host.rpartition('@') + return (user if delim else None), host + + +# adding a timeout to avoid freezing package_index +open_with_auth = socket_timeout(_SOCKET_TIMEOUT)(open_with_auth) + + +def fix_sf_url(url): + return url # backward compatibility + + +def local_open(url): + """Read a local path, with special support for directories""" + scheme, server, path, param, query, frag = urllib.parse.urlparse(url) + filename = urllib.request.url2pathname(path) + if os.path.isfile(filename): + return urllib.request.urlopen(url) + elif path.endswith('/') and os.path.isdir(filename): + files = [] + for f in os.listdir(filename): + filepath = os.path.join(filename, f) + if f == 'index.html': + with open(filepath, 'r') as fp: + body = fp.read() + break + elif os.path.isdir(filepath): + f += '/' + files.append('<a href="{name}">{name}</a>'.format(name=f)) + else: + tmpl = ( + "<html><head><title>{url}" + "{files}") + body = tmpl.format(url=url, files='\n'.join(files)) + status, message = 200, "OK" + else: + status, message, body = 404, "Path not found", "Not found" + + headers = {'content-type': 'text/html'} + body_stream = six.StringIO(body) + return urllib.error.HTTPError(url, status, message, headers, body_stream) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/pep425tags.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/pep425tags.py new file mode 100644 index 0000000..48745a2 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/pep425tags.py @@ -0,0 +1,319 @@ +# This file originally from pip: +# https://github.com/pypa/pip/blob/8f4f15a5a95d7d5b511ceaee9ed261176c181970/src/pip/_internal/pep425tags.py +"""Generate and work with PEP 425 Compatibility Tags.""" +from __future__ import absolute_import + +import distutils.util +from distutils import log +import platform +import re +import sys +import sysconfig +import warnings +from collections import OrderedDict + +from .extern import six + +from . import glibc + +_osx_arch_pat = re.compile(r'(.+)_(\d+)_(\d+)_(.+)') + + +def get_config_var(var): + try: + return sysconfig.get_config_var(var) + except IOError as e: # Issue #1074 + warnings.warn("{}".format(e), RuntimeWarning) + return None + + +def get_abbr_impl(): + """Return abbreviated implementation name.""" + if hasattr(sys, 'pypy_version_info'): + pyimpl = 'pp' + elif sys.platform.startswith('java'): + pyimpl = 'jy' + elif sys.platform == 'cli': + pyimpl = 'ip' + else: + pyimpl = 'cp' + return pyimpl + + +def get_impl_ver(): + """Return implementation version.""" + impl_ver = get_config_var("py_version_nodot") + if not impl_ver or get_abbr_impl() == 'pp': + impl_ver = ''.join(map(str, get_impl_version_info())) + return impl_ver + + +def get_impl_version_info(): + """Return sys.version_info-like tuple for use in decrementing the minor + version.""" + if get_abbr_impl() == 'pp': + # as per https://github.com/pypa/pip/issues/2882 + return (sys.version_info[0], sys.pypy_version_info.major, + sys.pypy_version_info.minor) + else: + return sys.version_info[0], sys.version_info[1] + + +def get_impl_tag(): + """ + Returns the Tag for this specific implementation. + """ + return "{}{}".format(get_abbr_impl(), get_impl_ver()) + + +def get_flag(var, fallback, expected=True, warn=True): + """Use a fallback method for determining SOABI flags if the needed config + var is unset or unavailable.""" + val = get_config_var(var) + if val is None: + if warn: + log.debug("Config variable '%s' is unset, Python ABI tag may " + "be incorrect", var) + return fallback() + return val == expected + + +def get_abi_tag(): + """Return the ABI tag based on SOABI (if available) or emulate SOABI + (CPython 2, PyPy).""" + soabi = get_config_var('SOABI') + impl = get_abbr_impl() + if not soabi and impl in {'cp', 'pp'} and hasattr(sys, 'maxunicode'): + d = '' + m = '' + u = '' + if get_flag('Py_DEBUG', + lambda: hasattr(sys, 'gettotalrefcount'), + warn=(impl == 'cp')): + d = 'd' + if get_flag('WITH_PYMALLOC', + lambda: impl == 'cp', + warn=(impl == 'cp')): + m = 'm' + if get_flag('Py_UNICODE_SIZE', + lambda: sys.maxunicode == 0x10ffff, + expected=4, + warn=(impl == 'cp' and + six.PY2)) \ + and six.PY2: + u = 'u' + abi = '%s%s%s%s%s' % (impl, get_impl_ver(), d, m, u) + elif soabi and soabi.startswith('cpython-'): + abi = 'cp' + soabi.split('-')[1] + elif soabi: + abi = soabi.replace('.', '_').replace('-', '_') + else: + abi = None + return abi + + +def _is_running_32bit(): + return sys.maxsize == 2147483647 + + +def get_platform(): + """Return our platform name 'win32', 'linux_x86_64'""" + if sys.platform == 'darwin': + # distutils.util.get_platform() returns the release based on the value + # of MACOSX_DEPLOYMENT_TARGET on which Python was built, which may + # be significantly older than the user's current machine. + release, _, machine = platform.mac_ver() + split_ver = release.split('.') + + if machine == "x86_64" and _is_running_32bit(): + machine = "i386" + elif machine == "ppc64" and _is_running_32bit(): + machine = "ppc" + + return 'macosx_{}_{}_{}'.format(split_ver[0], split_ver[1], machine) + + # XXX remove distutils dependency + result = distutils.util.get_platform().replace('.', '_').replace('-', '_') + if result == "linux_x86_64" and _is_running_32bit(): + # 32 bit Python program (running on a 64 bit Linux): pip should only + # install and run 32 bit compiled extensions in that case. + result = "linux_i686" + + return result + + +def is_manylinux1_compatible(): + # Only Linux, and only x86-64 / i686 + if get_platform() not in {"linux_x86_64", "linux_i686"}: + return False + + # Check for presence of _manylinux module + try: + import _manylinux + return bool(_manylinux.manylinux1_compatible) + except (ImportError, AttributeError): + # Fall through to heuristic check below + pass + + # Check glibc version. CentOS 5 uses glibc 2.5. + return glibc.have_compatible_glibc(2, 5) + + +def get_darwin_arches(major, minor, machine): + """Return a list of supported arches (including group arches) for + the given major, minor and machine architecture of a macOS machine. + """ + arches = [] + + def _supports_arch(major, minor, arch): + # Looking at the application support for macOS versions in the chart + # provided by https://en.wikipedia.org/wiki/OS_X#Versions it appears + # our timeline looks roughly like: + # + # 10.0 - Introduces ppc support. + # 10.4 - Introduces ppc64, i386, and x86_64 support, however the ppc64 + # and x86_64 support is CLI only, and cannot be used for GUI + # applications. + # 10.5 - Extends ppc64 and x86_64 support to cover GUI applications. + # 10.6 - Drops support for ppc64 + # 10.7 - Drops support for ppc + # + # Given that we do not know if we're installing a CLI or a GUI + # application, we must be conservative and assume it might be a GUI + # application and behave as if ppc64 and x86_64 support did not occur + # until 10.5. + # + # Note: The above information is taken from the "Application support" + # column in the chart not the "Processor support" since I believe + # that we care about what instruction sets an application can use + # not which processors the OS supports. + if arch == 'ppc': + return (major, minor) <= (10, 5) + if arch == 'ppc64': + return (major, minor) == (10, 5) + if arch == 'i386': + return (major, minor) >= (10, 4) + if arch == 'x86_64': + return (major, minor) >= (10, 5) + if arch in groups: + for garch in groups[arch]: + if _supports_arch(major, minor, garch): + return True + return False + + groups = OrderedDict([ + ("fat", ("i386", "ppc")), + ("intel", ("x86_64", "i386")), + ("fat64", ("x86_64", "ppc64")), + ("fat32", ("x86_64", "i386", "ppc")), + ]) + + if _supports_arch(major, minor, machine): + arches.append(machine) + + for garch in groups: + if machine in groups[garch] and _supports_arch(major, minor, garch): + arches.append(garch) + + arches.append('universal') + + return arches + + +def get_supported(versions=None, noarch=False, platform=None, + impl=None, abi=None): + """Return a list of supported tags for each version specified in + `versions`. + + :param versions: a list of string versions, of the form ["33", "32"], + or None. The first version will be assumed to support our ABI. + :param platform: specify the exact platform you want valid + tags for, or None. If None, use the local system platform. + :param impl: specify the exact implementation you want valid + tags for, or None. If None, use the local interpreter impl. + :param abi: specify the exact abi you want valid + tags for, or None. If None, use the local interpreter abi. + """ + supported = [] + + # Versions must be given with respect to the preference + if versions is None: + versions = [] + version_info = get_impl_version_info() + major = version_info[:-1] + # Support all previous minor Python versions. + for minor in range(version_info[-1], -1, -1): + versions.append(''.join(map(str, major + (minor,)))) + + impl = impl or get_abbr_impl() + + abis = [] + + abi = abi or get_abi_tag() + if abi: + abis[0:0] = [abi] + + abi3s = set() + import imp + for suffix in imp.get_suffixes(): + if suffix[0].startswith('.abi'): + abi3s.add(suffix[0].split('.', 2)[1]) + + abis.extend(sorted(list(abi3s))) + + abis.append('none') + + if not noarch: + arch = platform or get_platform() + if arch.startswith('macosx'): + # support macosx-10.6-intel on macosx-10.9-x86_64 + match = _osx_arch_pat.match(arch) + if match: + name, major, minor, actual_arch = match.groups() + tpl = '{}_{}_%i_%s'.format(name, major) + arches = [] + for m in reversed(range(int(minor) + 1)): + for a in get_darwin_arches(int(major), m, actual_arch): + arches.append(tpl % (m, a)) + else: + # arch pattern didn't match (?!) + arches = [arch] + elif platform is None and is_manylinux1_compatible(): + arches = [arch.replace('linux', 'manylinux1'), arch] + else: + arches = [arch] + + # Current version, current API (built specifically for our Python): + for abi in abis: + for arch in arches: + supported.append(('%s%s' % (impl, versions[0]), abi, arch)) + + # abi3 modules compatible with older version of Python + for version in versions[1:]: + # abi3 was introduced in Python 3.2 + if version in {'31', '30'}: + break + for abi in abi3s: # empty set if not Python 3 + for arch in arches: + supported.append(("%s%s" % (impl, version), abi, arch)) + + # Has binaries, does not use the Python API: + for arch in arches: + supported.append(('py%s' % (versions[0][0]), 'none', arch)) + + # No abi / arch, but requires our implementation: + supported.append(('%s%s' % (impl, versions[0]), 'none', 'any')) + # Tagged specifically as being cross-version compatible + # (with just the major version specified) + supported.append(('%s%s' % (impl, versions[0][0]), 'none', 'any')) + + # No abi / arch, generic Python + for i, version in enumerate(versions): + supported.append(('py%s' % (version,), 'none', 'any')) + if i == 0: + supported.append(('py%s' % (version[0]), 'none', 'any')) + + return supported + + +implementation_tag = get_impl_tag() diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/py27compat.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/py27compat.py new file mode 100644 index 0000000..2985011 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/py27compat.py @@ -0,0 +1,28 @@ +""" +Compatibility Support for Python 2.7 and earlier +""" + +import platform + +from setuptools.extern import six + + +def get_all_headers(message, key): + """ + Given an HTTPMessage, return all headers matching a given key. + """ + return message.get_all(key) + + +if six.PY2: + def get_all_headers(message, key): + return message.getheaders(key) + + +linux_py2_ascii = ( + platform.system() == 'Linux' and + six.PY2 +) + +rmtree_safe = str if linux_py2_ascii else lambda x: x +"""Workaround for http://bugs.python.org/issue24672""" diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/py31compat.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/py31compat.py new file mode 100644 index 0000000..e1da7ee --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/py31compat.py @@ -0,0 +1,32 @@ +__all__ = [] + +__metaclass__ = type + + +try: + # Python >=3.2 + from tempfile import TemporaryDirectory +except ImportError: + import shutil + import tempfile + + class TemporaryDirectory: + """ + Very simple temporary directory context manager. + Will try to delete afterward, but will also ignore OS and similar + errors on deletion. + """ + + def __init__(self, **kwargs): + self.name = None # Handle mkdtemp raising an exception + self.name = tempfile.mkdtemp(**kwargs) + + def __enter__(self): + return self.name + + def __exit__(self, exctype, excvalue, exctrace): + try: + shutil.rmtree(self.name, True) + except OSError: # removal errors are not the only possible + pass + self.name = None diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/py33compat.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/py33compat.py new file mode 100644 index 0000000..cb69443 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/py33compat.py @@ -0,0 +1,59 @@ +import dis +import array +import collections + +try: + import html +except ImportError: + html = None + +from setuptools.extern import six +from setuptools.extern.six.moves import html_parser + +__metaclass__ = type + +OpArg = collections.namedtuple('OpArg', 'opcode arg') + + +class Bytecode_compat: + def __init__(self, code): + self.code = code + + def __iter__(self): + """Yield '(op,arg)' pair for each operation in code object 'code'""" + + bytes = array.array('b', self.code.co_code) + eof = len(self.code.co_code) + + ptr = 0 + extended_arg = 0 + + while ptr < eof: + + op = bytes[ptr] + + if op >= dis.HAVE_ARGUMENT: + + arg = bytes[ptr + 1] + bytes[ptr + 2] * 256 + extended_arg + ptr += 3 + + if op == dis.EXTENDED_ARG: + long_type = six.integer_types[-1] + extended_arg = arg * long_type(65536) + continue + + else: + arg = None + ptr += 1 + + yield OpArg(op, arg) + + +Bytecode = getattr(dis, 'Bytecode', Bytecode_compat) + + +unescape = getattr(html, 'unescape', None) +if unescape is None: + # HTMLParser.unescape is deprecated since Python 3.4, and will be removed + # from 3.9. + unescape = html_parser.HTMLParser().unescape diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/sandbox.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/sandbox.py new file mode 100644 index 0000000..685f3f7 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/sandbox.py @@ -0,0 +1,491 @@ +import os +import sys +import tempfile +import operator +import functools +import itertools +import re +import contextlib +import pickle +import textwrap + +from setuptools.extern import six +from setuptools.extern.six.moves import builtins, map + +import pkg_resources.py31compat + +if sys.platform.startswith('java'): + import org.python.modules.posix.PosixModule as _os +else: + _os = sys.modules[os.name] +try: + _file = file +except NameError: + _file = None +_open = open +from distutils.errors import DistutilsError +from pkg_resources import working_set + + +__all__ = [ + "AbstractSandbox", "DirectorySandbox", "SandboxViolation", "run_setup", +] + + +def _execfile(filename, globals, locals=None): + """ + Python 3 implementation of execfile. + """ + mode = 'rb' + with open(filename, mode) as stream: + script = stream.read() + if locals is None: + locals = globals + code = compile(script, filename, 'exec') + exec(code, globals, locals) + + +@contextlib.contextmanager +def save_argv(repl=None): + saved = sys.argv[:] + if repl is not None: + sys.argv[:] = repl + try: + yield saved + finally: + sys.argv[:] = saved + + +@contextlib.contextmanager +def save_path(): + saved = sys.path[:] + try: + yield saved + finally: + sys.path[:] = saved + + +@contextlib.contextmanager +def override_temp(replacement): + """ + Monkey-patch tempfile.tempdir with replacement, ensuring it exists + """ + pkg_resources.py31compat.makedirs(replacement, exist_ok=True) + + saved = tempfile.tempdir + + tempfile.tempdir = replacement + + try: + yield + finally: + tempfile.tempdir = saved + + +@contextlib.contextmanager +def pushd(target): + saved = os.getcwd() + os.chdir(target) + try: + yield saved + finally: + os.chdir(saved) + + +class UnpickleableException(Exception): + """ + An exception representing another Exception that could not be pickled. + """ + + @staticmethod + def dump(type, exc): + """ + Always return a dumped (pickled) type and exc. If exc can't be pickled, + wrap it in UnpickleableException first. + """ + try: + return pickle.dumps(type), pickle.dumps(exc) + except Exception: + # get UnpickleableException inside the sandbox + from setuptools.sandbox import UnpickleableException as cls + return cls.dump(cls, cls(repr(exc))) + + +class ExceptionSaver: + """ + A Context Manager that will save an exception, serialized, and restore it + later. + """ + + def __enter__(self): + return self + + def __exit__(self, type, exc, tb): + if not exc: + return + + # dump the exception + self._saved = UnpickleableException.dump(type, exc) + self._tb = tb + + # suppress the exception + return True + + def resume(self): + "restore and re-raise any exception" + + if '_saved' not in vars(self): + return + + type, exc = map(pickle.loads, self._saved) + six.reraise(type, exc, self._tb) + + +@contextlib.contextmanager +def save_modules(): + """ + Context in which imported modules are saved. + + Translates exceptions internal to the context into the equivalent exception + outside the context. + """ + saved = sys.modules.copy() + with ExceptionSaver() as saved_exc: + yield saved + + sys.modules.update(saved) + # remove any modules imported since + del_modules = ( + mod_name for mod_name in sys.modules + if mod_name not in saved + # exclude any encodings modules. See #285 + and not mod_name.startswith('encodings.') + ) + _clear_modules(del_modules) + + saved_exc.resume() + + +def _clear_modules(module_names): + for mod_name in list(module_names): + del sys.modules[mod_name] + + +@contextlib.contextmanager +def save_pkg_resources_state(): + saved = pkg_resources.__getstate__() + try: + yield saved + finally: + pkg_resources.__setstate__(saved) + + +@contextlib.contextmanager +def setup_context(setup_dir): + temp_dir = os.path.join(setup_dir, 'temp') + with save_pkg_resources_state(): + with save_modules(): + hide_setuptools() + with save_path(): + with save_argv(): + with override_temp(temp_dir): + with pushd(setup_dir): + # ensure setuptools commands are available + __import__('setuptools') + yield + + +def _needs_hiding(mod_name): + """ + >>> _needs_hiding('setuptools') + True + >>> _needs_hiding('pkg_resources') + True + >>> _needs_hiding('setuptools_plugin') + False + >>> _needs_hiding('setuptools.__init__') + True + >>> _needs_hiding('distutils') + True + >>> _needs_hiding('os') + False + >>> _needs_hiding('Cython') + True + """ + pattern = re.compile(r'(setuptools|pkg_resources|distutils|Cython)(\.|$)') + return bool(pattern.match(mod_name)) + + +def hide_setuptools(): + """ + Remove references to setuptools' modules from sys.modules to allow the + invocation to import the most appropriate setuptools. This technique is + necessary to avoid issues such as #315 where setuptools upgrading itself + would fail to find a function declared in the metadata. + """ + modules = filter(_needs_hiding, sys.modules) + _clear_modules(modules) + + +def run_setup(setup_script, args): + """Run a distutils setup script, sandboxed in its directory""" + setup_dir = os.path.abspath(os.path.dirname(setup_script)) + with setup_context(setup_dir): + try: + sys.argv[:] = [setup_script] + list(args) + sys.path.insert(0, setup_dir) + # reset to include setup dir, w/clean callback list + working_set.__init__() + working_set.callbacks.append(lambda dist: dist.activate()) + + # __file__ should be a byte string on Python 2 (#712) + dunder_file = ( + setup_script + if isinstance(setup_script, str) else + setup_script.encode(sys.getfilesystemencoding()) + ) + + with DirectorySandbox(setup_dir): + ns = dict(__file__=dunder_file, __name__='__main__') + _execfile(setup_script, ns) + except SystemExit as v: + if v.args and v.args[0]: + raise + # Normal exit, just return + + +class AbstractSandbox: + """Wrap 'os' module and 'open()' builtin for virtualizing setup scripts""" + + _active = False + + def __init__(self): + self._attrs = [ + name for name in dir(_os) + if not name.startswith('_') and hasattr(self, name) + ] + + def _copy(self, source): + for name in self._attrs: + setattr(os, name, getattr(source, name)) + + def __enter__(self): + self._copy(self) + if _file: + builtins.file = self._file + builtins.open = self._open + self._active = True + + def __exit__(self, exc_type, exc_value, traceback): + self._active = False + if _file: + builtins.file = _file + builtins.open = _open + self._copy(_os) + + def run(self, func): + """Run 'func' under os sandboxing""" + with self: + return func() + + def _mk_dual_path_wrapper(name): + original = getattr(_os, name) + + def wrap(self, src, dst, *args, **kw): + if self._active: + src, dst = self._remap_pair(name, src, dst, *args, **kw) + return original(src, dst, *args, **kw) + + return wrap + + for name in ["rename", "link", "symlink"]: + if hasattr(_os, name): + locals()[name] = _mk_dual_path_wrapper(name) + + def _mk_single_path_wrapper(name, original=None): + original = original or getattr(_os, name) + + def wrap(self, path, *args, **kw): + if self._active: + path = self._remap_input(name, path, *args, **kw) + return original(path, *args, **kw) + + return wrap + + if _file: + _file = _mk_single_path_wrapper('file', _file) + _open = _mk_single_path_wrapper('open', _open) + for name in [ + "stat", "listdir", "chdir", "open", "chmod", "chown", "mkdir", + "remove", "unlink", "rmdir", "utime", "lchown", "chroot", "lstat", + "startfile", "mkfifo", "mknod", "pathconf", "access" + ]: + if hasattr(_os, name): + locals()[name] = _mk_single_path_wrapper(name) + + def _mk_single_with_return(name): + original = getattr(_os, name) + + def wrap(self, path, *args, **kw): + if self._active: + path = self._remap_input(name, path, *args, **kw) + return self._remap_output(name, original(path, *args, **kw)) + return original(path, *args, **kw) + + return wrap + + for name in ['readlink', 'tempnam']: + if hasattr(_os, name): + locals()[name] = _mk_single_with_return(name) + + def _mk_query(name): + original = getattr(_os, name) + + def wrap(self, *args, **kw): + retval = original(*args, **kw) + if self._active: + return self._remap_output(name, retval) + return retval + + return wrap + + for name in ['getcwd', 'tmpnam']: + if hasattr(_os, name): + locals()[name] = _mk_query(name) + + def _validate_path(self, path): + """Called to remap or validate any path, whether input or output""" + return path + + def _remap_input(self, operation, path, *args, **kw): + """Called for path inputs""" + return self._validate_path(path) + + def _remap_output(self, operation, path): + """Called for path outputs""" + return self._validate_path(path) + + def _remap_pair(self, operation, src, dst, *args, **kw): + """Called for path pairs like rename, link, and symlink operations""" + return ( + self._remap_input(operation + '-from', src, *args, **kw), + self._remap_input(operation + '-to', dst, *args, **kw) + ) + + +if hasattr(os, 'devnull'): + _EXCEPTIONS = [os.devnull,] +else: + _EXCEPTIONS = [] + + +class DirectorySandbox(AbstractSandbox): + """Restrict operations to a single subdirectory - pseudo-chroot""" + + write_ops = dict.fromkeys([ + "open", "chmod", "chown", "mkdir", "remove", "unlink", "rmdir", + "utime", "lchown", "chroot", "mkfifo", "mknod", "tempnam", + ]) + + _exception_patterns = [ + # Allow lib2to3 to attempt to save a pickled grammar object (#121) + r'.*lib2to3.*\.pickle$', + ] + "exempt writing to paths that match the pattern" + + def __init__(self, sandbox, exceptions=_EXCEPTIONS): + self._sandbox = os.path.normcase(os.path.realpath(sandbox)) + self._prefix = os.path.join(self._sandbox, '') + self._exceptions = [ + os.path.normcase(os.path.realpath(path)) + for path in exceptions + ] + AbstractSandbox.__init__(self) + + def _violation(self, operation, *args, **kw): + from setuptools.sandbox import SandboxViolation + raise SandboxViolation(operation, args, kw) + + if _file: + + def _file(self, path, mode='r', *args, **kw): + if mode not in ('r', 'rt', 'rb', 'rU', 'U') and not self._ok(path): + self._violation("file", path, mode, *args, **kw) + return _file(path, mode, *args, **kw) + + def _open(self, path, mode='r', *args, **kw): + if mode not in ('r', 'rt', 'rb', 'rU', 'U') and not self._ok(path): + self._violation("open", path, mode, *args, **kw) + return _open(path, mode, *args, **kw) + + def tmpnam(self): + self._violation("tmpnam") + + def _ok(self, path): + active = self._active + try: + self._active = False + realpath = os.path.normcase(os.path.realpath(path)) + return ( + self._exempted(realpath) + or realpath == self._sandbox + or realpath.startswith(self._prefix) + ) + finally: + self._active = active + + def _exempted(self, filepath): + start_matches = ( + filepath.startswith(exception) + for exception in self._exceptions + ) + pattern_matches = ( + re.match(pattern, filepath) + for pattern in self._exception_patterns + ) + candidates = itertools.chain(start_matches, pattern_matches) + return any(candidates) + + def _remap_input(self, operation, path, *args, **kw): + """Called for path inputs""" + if operation in self.write_ops and not self._ok(path): + self._violation(operation, os.path.realpath(path), *args, **kw) + return path + + def _remap_pair(self, operation, src, dst, *args, **kw): + """Called for path pairs like rename, link, and symlink operations""" + if not self._ok(src) or not self._ok(dst): + self._violation(operation, src, dst, *args, **kw) + return (src, dst) + + def open(self, file, flags, mode=0o777, *args, **kw): + """Called for low-level os.open()""" + if flags & WRITE_FLAGS and not self._ok(file): + self._violation("os.open", file, flags, mode, *args, **kw) + return _os.open(file, flags, mode, *args, **kw) + + +WRITE_FLAGS = functools.reduce( + operator.or_, [getattr(_os, a, 0) for a in + "O_WRONLY O_RDWR O_APPEND O_CREAT O_TRUNC O_TEMPORARY".split()] +) + + +class SandboxViolation(DistutilsError): + """A setup script attempted to modify the filesystem outside the sandbox""" + + tmpl = textwrap.dedent(""" + SandboxViolation: {cmd}{args!r} {kwargs} + + The package setup script has attempted to modify files on your system + that are not within the EasyInstall build area, and has been aborted. + + This package cannot be safely installed by EasyInstall, and may not + support alternate installation locations even if you run its setup + script by hand. Please inform the package's author and the EasyInstall + maintainers to find out if a fix or workaround is available. + """).lstrip() + + def __str__(self): + cmd, args, kwargs = self.args + return self.tmpl.format(**locals()) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/script (dev).tmpl b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/script (dev).tmpl new file mode 100644 index 0000000..39a24b0 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/script (dev).tmpl @@ -0,0 +1,6 @@ +# EASY-INSTALL-DEV-SCRIPT: %(spec)r,%(script_name)r +__requires__ = %(spec)r +__import__('pkg_resources').require(%(spec)r) +__file__ = %(dev_path)r +with open(__file__) as f: + exec(compile(f.read(), __file__, 'exec')) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/script.tmpl b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/script.tmpl new file mode 100644 index 0000000..ff5efbc --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/script.tmpl @@ -0,0 +1,3 @@ +# EASY-INSTALL-SCRIPT: %(spec)r,%(script_name)r +__requires__ = %(spec)r +__import__('pkg_resources').run_script(%(spec)r, %(script_name)r) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/site-patch.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/site-patch.py new file mode 100644 index 0000000..40b00de --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/site-patch.py @@ -0,0 +1,74 @@ +def __boot(): + import sys + import os + PYTHONPATH = os.environ.get('PYTHONPATH') + if PYTHONPATH is None or (sys.platform == 'win32' and not PYTHONPATH): + PYTHONPATH = [] + else: + PYTHONPATH = PYTHONPATH.split(os.pathsep) + + pic = getattr(sys, 'path_importer_cache', {}) + stdpath = sys.path[len(PYTHONPATH):] + mydir = os.path.dirname(__file__) + + for item in stdpath: + if item == mydir or not item: + continue # skip if current dir. on Windows, or my own directory + importer = pic.get(item) + if importer is not None: + loader = importer.find_module('site') + if loader is not None: + # This should actually reload the current module + loader.load_module('site') + break + else: + try: + import imp # Avoid import loop in Python 3 + stream, path, descr = imp.find_module('site', [item]) + except ImportError: + continue + if stream is None: + continue + try: + # This should actually reload the current module + imp.load_module('site', stream, path, descr) + finally: + stream.close() + break + else: + raise ImportError("Couldn't find the real 'site' module") + + known_paths = dict([(makepath(item)[1], 1) for item in sys.path]) # 2.2 comp + + oldpos = getattr(sys, '__egginsert', 0) # save old insertion position + sys.__egginsert = 0 # and reset the current one + + for item in PYTHONPATH: + addsitedir(item) + + sys.__egginsert += oldpos # restore effective old position + + d, nd = makepath(stdpath[0]) + insert_at = None + new_path = [] + + for item in sys.path: + p, np = makepath(item) + + if np == nd and insert_at is None: + # We've hit the first 'system' path entry, so added entries go here + insert_at = len(new_path) + + if np in known_paths or insert_at is None: + new_path.append(item) + else: + # new path after the insert point, back-insert it + new_path.insert(insert_at, item) + insert_at += 1 + + sys.path[:] = new_path + + +if __name__ == 'site': + __boot() + del __boot diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/ssl_support.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/ssl_support.py new file mode 100644 index 0000000..226db69 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/ssl_support.py @@ -0,0 +1,260 @@ +import os +import socket +import atexit +import re +import functools + +from setuptools.extern.six.moves import urllib, http_client, map, filter + +from pkg_resources import ResolutionError, ExtractionError + +try: + import ssl +except ImportError: + ssl = None + +__all__ = [ + 'VerifyingHTTPSHandler', 'find_ca_bundle', 'is_available', 'cert_paths', + 'opener_for' +] + +cert_paths = """ +/etc/pki/tls/certs/ca-bundle.crt +/etc/ssl/certs/ca-certificates.crt +/usr/share/ssl/certs/ca-bundle.crt +/usr/local/share/certs/ca-root.crt +/etc/ssl/cert.pem +/System/Library/OpenSSL/certs/cert.pem +/usr/local/share/certs/ca-root-nss.crt +/etc/ssl/ca-bundle.pem +""".strip().split() + +try: + HTTPSHandler = urllib.request.HTTPSHandler + HTTPSConnection = http_client.HTTPSConnection +except AttributeError: + HTTPSHandler = HTTPSConnection = object + +is_available = ssl is not None and object not in (HTTPSHandler, HTTPSConnection) + + +try: + from ssl import CertificateError, match_hostname +except ImportError: + try: + from backports.ssl_match_hostname import CertificateError + from backports.ssl_match_hostname import match_hostname + except ImportError: + CertificateError = None + match_hostname = None + +if not CertificateError: + + class CertificateError(ValueError): + pass + + +if not match_hostname: + + def _dnsname_match(dn, hostname, max_wildcards=1): + """Matching according to RFC 6125, section 6.4.3 + + https://tools.ietf.org/html/rfc6125#section-6.4.3 + """ + pats = [] + if not dn: + return False + + # Ported from python3-syntax: + # leftmost, *remainder = dn.split(r'.') + parts = dn.split(r'.') + leftmost = parts[0] + remainder = parts[1:] + + wildcards = leftmost.count('*') + if wildcards > max_wildcards: + # Issue #17980: avoid denials of service by refusing more + # than one wildcard per fragment. A survey of established + # policy among SSL implementations showed it to be a + # reasonable choice. + raise CertificateError( + "too many wildcards in certificate DNS name: " + repr(dn)) + + # speed up common case w/o wildcards + if not wildcards: + return dn.lower() == hostname.lower() + + # RFC 6125, section 6.4.3, subitem 1. + # The client SHOULD NOT attempt to match a presented identifier in which + # the wildcard character comprises a label other than the left-most label. + if leftmost == '*': + # When '*' is a fragment by itself, it matches a non-empty dotless + # fragment. + pats.append('[^.]+') + elif leftmost.startswith('xn--') or hostname.startswith('xn--'): + # RFC 6125, section 6.4.3, subitem 3. + # The client SHOULD NOT attempt to match a presented identifier + # where the wildcard character is embedded within an A-label or + # U-label of an internationalized domain name. + pats.append(re.escape(leftmost)) + else: + # Otherwise, '*' matches any dotless string, e.g. www* + pats.append(re.escape(leftmost).replace(r'\*', '[^.]*')) + + # add the remaining fragments, ignore any wildcards + for frag in remainder: + pats.append(re.escape(frag)) + + pat = re.compile(r'\A' + r'\.'.join(pats) + r'\Z', re.IGNORECASE) + return pat.match(hostname) + + def match_hostname(cert, hostname): + """Verify that *cert* (in decoded format as returned by + SSLSocket.getpeercert()) matches the *hostname*. RFC 2818 and RFC 6125 + rules are followed, but IP addresses are not accepted for *hostname*. + + CertificateError is raised on failure. On success, the function + returns nothing. + """ + if not cert: + raise ValueError("empty or no certificate") + dnsnames = [] + san = cert.get('subjectAltName', ()) + for key, value in san: + if key == 'DNS': + if _dnsname_match(value, hostname): + return + dnsnames.append(value) + if not dnsnames: + # The subject is only checked when there is no dNSName entry + # in subjectAltName + for sub in cert.get('subject', ()): + for key, value in sub: + # XXX according to RFC 2818, the most specific Common Name + # must be used. + if key == 'commonName': + if _dnsname_match(value, hostname): + return + dnsnames.append(value) + if len(dnsnames) > 1: + raise CertificateError("hostname %r " + "doesn't match either of %s" + % (hostname, ', '.join(map(repr, dnsnames)))) + elif len(dnsnames) == 1: + raise CertificateError("hostname %r " + "doesn't match %r" + % (hostname, dnsnames[0])) + else: + raise CertificateError("no appropriate commonName or " + "subjectAltName fields were found") + + +class VerifyingHTTPSHandler(HTTPSHandler): + """Simple verifying handler: no auth, subclasses, timeouts, etc.""" + + def __init__(self, ca_bundle): + self.ca_bundle = ca_bundle + HTTPSHandler.__init__(self) + + def https_open(self, req): + return self.do_open( + lambda host, **kw: VerifyingHTTPSConn(host, self.ca_bundle, **kw), req + ) + + +class VerifyingHTTPSConn(HTTPSConnection): + """Simple verifying connection: no auth, subclasses, timeouts, etc.""" + + def __init__(self, host, ca_bundle, **kw): + HTTPSConnection.__init__(self, host, **kw) + self.ca_bundle = ca_bundle + + def connect(self): + sock = socket.create_connection( + (self.host, self.port), getattr(self, 'source_address', None) + ) + + # Handle the socket if a (proxy) tunnel is present + if hasattr(self, '_tunnel') and getattr(self, '_tunnel_host', None): + self.sock = sock + self._tunnel() + # http://bugs.python.org/issue7776: Python>=3.4.1 and >=2.7.7 + # change self.host to mean the proxy server host when tunneling is + # being used. Adapt, since we are interested in the destination + # host for the match_hostname() comparison. + actual_host = self._tunnel_host + else: + actual_host = self.host + + if hasattr(ssl, 'create_default_context'): + ctx = ssl.create_default_context(cafile=self.ca_bundle) + self.sock = ctx.wrap_socket(sock, server_hostname=actual_host) + else: + # This is for python < 2.7.9 and < 3.4? + self.sock = ssl.wrap_socket( + sock, cert_reqs=ssl.CERT_REQUIRED, ca_certs=self.ca_bundle + ) + try: + match_hostname(self.sock.getpeercert(), actual_host) + except CertificateError: + self.sock.shutdown(socket.SHUT_RDWR) + self.sock.close() + raise + + +def opener_for(ca_bundle=None): + """Get a urlopen() replacement that uses ca_bundle for verification""" + return urllib.request.build_opener( + VerifyingHTTPSHandler(ca_bundle or find_ca_bundle()) + ).open + + +# from jaraco.functools +def once(func): + @functools.wraps(func) + def wrapper(*args, **kwargs): + if not hasattr(func, 'always_returns'): + func.always_returns = func(*args, **kwargs) + return func.always_returns + return wrapper + + +@once +def get_win_certfile(): + try: + import wincertstore + except ImportError: + return None + + class CertFile(wincertstore.CertFile): + def __init__(self): + super(CertFile, self).__init__() + atexit.register(self.close) + + def close(self): + try: + super(CertFile, self).close() + except OSError: + pass + + _wincerts = CertFile() + _wincerts.addstore('CA') + _wincerts.addstore('ROOT') + return _wincerts.name + + +def find_ca_bundle(): + """Return an existing CA bundle path, or None""" + extant_cert_paths = filter(os.path.isfile, cert_paths) + return ( + get_win_certfile() + or next(extant_cert_paths, None) + or _certifi_where() + ) + + +def _certifi_where(): + try: + return __import__('certifi').where() + except (ImportError, ResolutionError, ExtractionError): + pass diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/unicode_utils.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/unicode_utils.py new file mode 100644 index 0000000..7c63efd --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/unicode_utils.py @@ -0,0 +1,44 @@ +import unicodedata +import sys + +from setuptools.extern import six + + +# HFS Plus uses decomposed UTF-8 +def decompose(path): + if isinstance(path, six.text_type): + return unicodedata.normalize('NFD', path) + try: + path = path.decode('utf-8') + path = unicodedata.normalize('NFD', path) + path = path.encode('utf-8') + except UnicodeError: + pass # Not UTF-8 + return path + + +def filesys_decode(path): + """ + Ensure that the given path is decoded, + NONE when no expected encoding works + """ + + if isinstance(path, six.text_type): + return path + + fs_enc = sys.getfilesystemencoding() or 'utf-8' + candidates = fs_enc, 'utf-8' + + for enc in candidates: + try: + return path.decode(enc) + except UnicodeDecodeError: + continue + + +def try_encode(string, enc): + "turn unicode encoding into a functional routine" + try: + return string.encode(enc) + except UnicodeEncodeError: + return None diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/version.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/version.py new file mode 100644 index 0000000..95e1869 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/version.py @@ -0,0 +1,6 @@ +import pkg_resources + +try: + __version__ = pkg_resources.get_distribution('setuptools').version +except Exception: + __version__ = 'unknown' diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/wheel.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/wheel.py new file mode 100644 index 0000000..e11f0a1 --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/wheel.py @@ -0,0 +1,211 @@ +"""Wheels support.""" + +from distutils.util import get_platform +import email +import itertools +import os +import posixpath +import re +import zipfile + +import pkg_resources +import setuptools +from pkg_resources import parse_version +from setuptools.extern.packaging.utils import canonicalize_name +from setuptools.extern.six import PY3 +from setuptools import pep425tags +from setuptools.command.egg_info import write_requirements + + +__metaclass__ = type + + +WHEEL_NAME = re.compile( + r"""^(?P.+?)-(?P\d.*?) + ((-(?P\d.*?))?-(?P.+?)-(?P.+?)-(?P.+?) + )\.whl$""", + re.VERBOSE).match + +NAMESPACE_PACKAGE_INIT = '''\ +try: + __import__('pkg_resources').declare_namespace(__name__) +except ImportError: + __path__ = __import__('pkgutil').extend_path(__path__, __name__) +''' + + +def unpack(src_dir, dst_dir): + '''Move everything under `src_dir` to `dst_dir`, and delete the former.''' + for dirpath, dirnames, filenames in os.walk(src_dir): + subdir = os.path.relpath(dirpath, src_dir) + for f in filenames: + src = os.path.join(dirpath, f) + dst = os.path.join(dst_dir, subdir, f) + os.renames(src, dst) + for n, d in reversed(list(enumerate(dirnames))): + src = os.path.join(dirpath, d) + dst = os.path.join(dst_dir, subdir, d) + if not os.path.exists(dst): + # Directory does not exist in destination, + # rename it and prune it from os.walk list. + os.renames(src, dst) + del dirnames[n] + # Cleanup. + for dirpath, dirnames, filenames in os.walk(src_dir, topdown=True): + assert not filenames + os.rmdir(dirpath) + + +class Wheel: + + def __init__(self, filename): + match = WHEEL_NAME(os.path.basename(filename)) + if match is None: + raise ValueError('invalid wheel name: %r' % filename) + self.filename = filename + for k, v in match.groupdict().items(): + setattr(self, k, v) + + def tags(self): + '''List tags (py_version, abi, platform) supported by this wheel.''' + return itertools.product( + self.py_version.split('.'), + self.abi.split('.'), + self.platform.split('.'), + ) + + def is_compatible(self): + '''Is the wheel is compatible with the current platform?''' + supported_tags = pep425tags.get_supported() + return next((True for t in self.tags() if t in supported_tags), False) + + def egg_name(self): + return pkg_resources.Distribution( + project_name=self.project_name, version=self.version, + platform=(None if self.platform == 'any' else get_platform()), + ).egg_name() + '.egg' + + def get_dist_info(self, zf): + # find the correct name of the .dist-info dir in the wheel file + for member in zf.namelist(): + dirname = posixpath.dirname(member) + if (dirname.endswith('.dist-info') and + canonicalize_name(dirname).startswith( + canonicalize_name(self.project_name))): + return dirname + raise ValueError("unsupported wheel format. .dist-info not found") + + def install_as_egg(self, destination_eggdir): + '''Install wheel as an egg directory.''' + with zipfile.ZipFile(self.filename) as zf: + self._install_as_egg(destination_eggdir, zf) + + def _install_as_egg(self, destination_eggdir, zf): + dist_basename = '%s-%s' % (self.project_name, self.version) + dist_info = self.get_dist_info(zf) + dist_data = '%s.data' % dist_basename + egg_info = os.path.join(destination_eggdir, 'EGG-INFO') + + self._convert_metadata(zf, destination_eggdir, dist_info, egg_info) + self._move_data_entries(destination_eggdir, dist_data) + self._fix_namespace_packages(egg_info, destination_eggdir) + + @staticmethod + def _convert_metadata(zf, destination_eggdir, dist_info, egg_info): + def get_metadata(name): + with zf.open(posixpath.join(dist_info, name)) as fp: + value = fp.read().decode('utf-8') if PY3 else fp.read() + return email.parser.Parser().parsestr(value) + + wheel_metadata = get_metadata('WHEEL') + # Check wheel format version is supported. + wheel_version = parse_version(wheel_metadata.get('Wheel-Version')) + wheel_v1 = ( + parse_version('1.0') <= wheel_version < parse_version('2.0dev0') + ) + if not wheel_v1: + raise ValueError( + 'unsupported wheel format version: %s' % wheel_version) + # Extract to target directory. + os.mkdir(destination_eggdir) + zf.extractall(destination_eggdir) + # Convert metadata. + dist_info = os.path.join(destination_eggdir, dist_info) + dist = pkg_resources.Distribution.from_location( + destination_eggdir, dist_info, + metadata=pkg_resources.PathMetadata(destination_eggdir, dist_info), + ) + + # Note: Evaluate and strip markers now, + # as it's difficult to convert back from the syntax: + # foobar; "linux" in sys_platform and extra == 'test' + def raw_req(req): + req.marker = None + return str(req) + install_requires = list(sorted(map(raw_req, dist.requires()))) + extras_require = { + extra: sorted( + req + for req in map(raw_req, dist.requires((extra,))) + if req not in install_requires + ) + for extra in dist.extras + } + os.rename(dist_info, egg_info) + os.rename( + os.path.join(egg_info, 'METADATA'), + os.path.join(egg_info, 'PKG-INFO'), + ) + setup_dist = setuptools.Distribution( + attrs=dict( + install_requires=install_requires, + extras_require=extras_require, + ), + ) + write_requirements( + setup_dist.get_command_obj('egg_info'), + None, + os.path.join(egg_info, 'requires.txt'), + ) + + @staticmethod + def _move_data_entries(destination_eggdir, dist_data): + """Move data entries to their correct location.""" + dist_data = os.path.join(destination_eggdir, dist_data) + dist_data_scripts = os.path.join(dist_data, 'scripts') + if os.path.exists(dist_data_scripts): + egg_info_scripts = os.path.join( + destination_eggdir, 'EGG-INFO', 'scripts') + os.mkdir(egg_info_scripts) + for entry in os.listdir(dist_data_scripts): + # Remove bytecode, as it's not properly handled + # during easy_install scripts install phase. + if entry.endswith('.pyc'): + os.unlink(os.path.join(dist_data_scripts, entry)) + else: + os.rename( + os.path.join(dist_data_scripts, entry), + os.path.join(egg_info_scripts, entry), + ) + os.rmdir(dist_data_scripts) + for subdir in filter(os.path.exists, ( + os.path.join(dist_data, d) + for d in ('data', 'headers', 'purelib', 'platlib') + )): + unpack(subdir, destination_eggdir) + if os.path.exists(dist_data): + os.rmdir(dist_data) + + @staticmethod + def _fix_namespace_packages(egg_info, destination_eggdir): + namespace_packages = os.path.join( + egg_info, 'namespace_packages.txt') + if os.path.exists(namespace_packages): + with open(namespace_packages) as fp: + namespace_packages = fp.read().split() + for mod in namespace_packages: + mod_dir = os.path.join(destination_eggdir, *mod.split('.')) + mod_init = os.path.join(mod_dir, '__init__.py') + if os.path.exists(mod_dir) and not os.path.exists(mod_init): + with open(mod_init, 'w') as fp: + fp.write(NAMESPACE_PACKAGE_INIT) diff --git a/Front-end/apis-env/lib/python3.8/site-packages/setuptools/windows_support.py b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/windows_support.py new file mode 100644 index 0000000..cb977cf --- /dev/null +++ b/Front-end/apis-env/lib/python3.8/site-packages/setuptools/windows_support.py @@ -0,0 +1,29 @@ +import platform +import ctypes + + +def windows_only(func): + if platform.system() != 'Windows': + return lambda *args, **kwargs: None + return func + + +@windows_only +def hide_file(path): + """ + Set the hidden attribute on a file or directory. + + From http://stackoverflow.com/questions/19622133/ + + `path` must be text. + """ + __import__('ctypes.wintypes') + SetFileAttributes = ctypes.windll.kernel32.SetFileAttributesW + SetFileAttributes.argtypes = ctypes.wintypes.LPWSTR, ctypes.wintypes.DWORD + SetFileAttributes.restype = ctypes.wintypes.BOOL + + FILE_ATTRIBUTE_HIDDEN = 0x02 + + ret = SetFileAttributes(path, FILE_ATTRIBUTE_HIDDEN) + if not ret: + raise ctypes.WinError() diff --git a/Front-end/apis-env/pyvenv.cfg b/Front-end/apis-env/pyvenv.cfg new file mode 100644 index 0000000..e95d8ce --- /dev/null +++ b/Front-end/apis-env/pyvenv.cfg @@ -0,0 +1,3 @@ +home = /Users/hanieharabzadeh/opt/anaconda3/bin +include-system-site-packages = false +version = 3.8.3 diff --git a/Front-end/app.py b/Front-end/app.py new file mode 100644 index 0000000..e72744a --- /dev/null +++ b/Front-end/app.py @@ -0,0 +1,72 @@ +# from _typeshed import Self +from datetime import datetime +from typing import Optional +import flask +import requests +import json +from flask.wrappers import Response +from flask import Flask, config,redirect,url_for,render_template , request +from requests.api import post +import json +import ast + +from requests.sessions import Request + + + +app = Flask(__name__, template_folder="./templates") +geturl = "https://localhost:5001/books" +headings = ('id','Title' , 'Authors' , 'AverageRating' , 'NumPage' , 'RatingCount' , 'ReviewCount', 'PublicationDate' , 'Publisher','CreatedDate') +request_object = request("https://localhost:5001") +# POST /index +@app.route("/index/" , methods=["GET"]) +def index(): + print("1") + r = request_object.get_request('/books') + if r != None: + print("2") + data_table = json.loads(r) + print("3") + return render_template("index.html" ,headings=headings , data=data_table) + else: + return render_template("index.html" ) + +# POST /createbook +@app.route("/createbook/", methods=["GET","POST"]) +def createbook(): + if request.method == "POST" and request.form.get('submit_book') == "submit": + data_json = {} + data_json['Title'] = request.form["Title"] + data_json['Authors'] = request.form["Authors"] + data_json['AverageRating'] = request.form["AverageRating"] + data_json['NumPage'] = request.form["NumPage"] + data_json['RatingCount'] = request.form["RatingCount"] + data_json['TextReviewCount'] = request.form["TextReviewCount"] + data_json['PublicationDate'] = request.form["PublicationDate"] + data_json['Publisher'] = request.form["Publisher"] + headers = {'Content-type': 'application/json'} + r = requests.post(url = "https://localhost:5001/books", data = json.dumps(data_json) , verify=False, headers=headers) + if r.status_code == 200: + return redirect('/index/') + else: + pass + + else: + return render_template("createbook.html") + +# GET /search +@app.route("/search", methods=["GET"]) +def search(): + if request.form.get('search') == "search": + headers = {'Content-type': 'application/json'} + r = requests.get(url = "https://localhost:5001/books/search", verify=False, headers=headers) + if r.status_code == 200: + data_table = json.loads(r.text) + return render_template("search.html" ,headings=headings , data=data_table) + else: + print('something is wrong on the request', r.status_code) + else: + return render_template("search.html") + +if __name__== "__main__": + app.run(debug=True, port="3000") \ No newline at end of file diff --git a/Front-end/config.py b/Front-end/config.py new file mode 100644 index 0000000..e69de29 diff --git a/Front-end/request.py b/Front-end/request.py new file mode 100644 index 0000000..5ba355f --- /dev/null +++ b/Front-end/request.py @@ -0,0 +1,30 @@ +from enum import Enum +from requests + +class methods(Enum): + POST = "POST" + GET = "GET" + PUT = 'PUT' + +class Request: + def __init__(self,base_url) -> None: + self.base_url = base_url + self.method = methods.GET + + def error_handlerer(self): + return "somthing is wrong , try again" + def get_request(self,postfix_url, method= methods.GET ,url_params = None ): + if method == methods.GET: + headers = {'Content-type': 'application/json'} + if url_params != None: + r = requests.get(url = self.baseUrl + postfix_url, verify=False, headers=headers) + else: + r = requests.get(url = self.baseUrl + postfix_url, params=url_params , verify=False, headers=headers) + + if r.status_code == 200: + return r.text + else: + return error_handlerer() + + + diff --git a/Front-end/templates/createbook.html b/Front-end/templates/createbook.html new file mode 100644 index 0000000..4e25bd5 --- /dev/null +++ b/Front-end/templates/createbook.html @@ -0,0 +1,27 @@ +{ % extends "base.html" % } +{% block title %} Create book{%endblock%} +{% block content %} +

+

title:

+

+

authors:

+

+

averageRating:

+

+

numPage:

+

+

ratingCount:

+

+

textReviewCount:

+

+

publicationDate:

+

+

publisher:

+

+ +

+ + +{%endblock%} + + diff --git a/Front-end/templates/home.html b/Front-end/templates/home.html new file mode 100644 index 0000000..0de3ba6 --- /dev/null +++ b/Front-end/templates/home.html @@ -0,0 +1,52 @@ + + + + + + + + +
+ +
+

Top Navigation Example

+

Some content..

+
+ + + + diff --git a/Front-end/templates/index.html b/Front-end/templates/index.html new file mode 100644 index 0000000..2167963 --- /dev/null +++ b/Front-end/templates/index.html @@ -0,0 +1,31 @@ + + + + + + Document + + + + + + {% for header in headings %} + + {% endfor %} + + + {% for row in data %} + + {% for key in row %} + + {% endfor %} + + {% endfor %} + +
{{header}}{{header}}
{{row[key]}}
+ + \ No newline at end of file diff --git a/Front-end/templates/search.html b/Front-end/templates/search.html new file mode 100644 index 0000000..8cd11b5 --- /dev/null +++ b/Front-end/templates/search.html @@ -0,0 +1,32 @@ +{ % extends "base.html" % } +{% block title %} search book{%endblock%} +{% block content %} +
+

title:

+

+

authors:

+

+

minNumPage:

+

+

maxNumPage:

+

+

+ + + + + {% for header in headings %} + + {% endfor %} + + + {% for row in data %} + + {% for key in row %} + + {% endfor %} + + {% endfor %} + +
{{header}}{{header}}
{{row[key]}}
+{%endblock%} diff --git a/MongoBookApis/bin/Debug/net5.0/MongoBookApis.dll b/MongoBookApis/bin/Debug/net5.0/MongoBookApis.dll deleted file mode 100644 index d1701bd256344bc418909c60597a1232926ca112..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 32768 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 diff --git a/MongoBookApis/bin/Debug/net5.0/ref/MongoBookApis.dll b/MongoBookApis/bin/Debug/net5.0/ref/MongoBookApis.dll deleted file mode 100644 index b25313123de59298baeb21a31ce71f55344ee172..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15360 zcmeHO3vgUldH&Dchjz7+EU#tb*iN#R9Y11cE!(o47}?&{!}cbY?O3vn6N0o_T}z8s zyPLhcvV;rSjEzg27BDoPK%iBImXc5cnLwI^M-&Jl85$_hp=l`!hK}1QPzuvF&}sVp z|9!3>iAg&h%4FsH-T!s|^Plsdd+xdCUiaSeUh)xQ4~;autzc;cNKSx4exy`)=%1mIt0^#@pj<@%3%%*WSPm1H@Gp=Myb?2hrc*yr>a$ zU%8acj~Hz6AJ>>u_>%p7^q-)4j$E>1e~JfZ!!n|Cn5UO?<_be>j31^jb@1w`NSNoc zU#ayp&y4?iunTdl#qmKLx8mS*LT)=kGUrHoBxv?UkP`kM zg@SZW@WBAncl(|U&7sCH`xzI>EdRFxK{_26uM5%{KVzR@Q7|O(hkfI9^|UVVL?lRW z^0A*U1fCBD>46BN;bVLWbQ5)ic7Z-b&j+KF3atswqpRwE9b7=~s_U)0idKaFx-LrV z8`cEtX?f&P)k^Ck-wrOLd68}ETJndoD7%k784l9-75m&o!zxIB7W`y5P74|yM7{TD zEPqyF_*b+gNNJ7Z`AHq)3O`GRi0K~05Tr;0(+fhMYgk9yeY5H}(o)~1@J2eV-B-7f zKI7jMuBUJKA64~q*2nlojd5{+@fb1Q1Ug864sYmS+9+KsV?{MnyYJp`61@*0xIaNu z%yD*`={EFk60{$ZW;zl+74Ai@0>XVcXmSy{6P7=;bWNgrw$9YeqWe+bUo|X3u6#5{ zbl(TZUfv+w$LhKx%q`Z2EoCHHw!gy-T>5aP#PHkL8v0ZqdD8yu|1| z!aXG15_+F-PYJi2?h)>saI5HET1K~pbHJ|!inNi|DFYWwJslPL4$#-oao{P`HxIq> zeqfyL!wA2^_YvTc&_{t&!H)y0;ZJ(xk604+`IJZgWzauRU$eBXAGUAPz6CrJVGIgA zTaZ1opYNjfIrM@=@&at^7=8@88vcbx^6#MSTF#e0S{J~mtF>njm#+O6v^Rkcqm%O= z5Ald}xv=tbO*NcH7rMWp#npu#Y-o19gx=FIUum|_(7g=-jBKlh&`$y_%4c&@yUm@U ze+w>hbZ6*Ls1++`H!_9m!Q{@+7wT3jo8vaLq5XCZ*VS!Qbv8%e4876AJ*Fj5Lb zaGy%ynl*pV1U{zrtBAwhtuh|&4s}E|*gjF;+cDnF`u;(&fJLTct5ouBL9m`XZQywl7Y*AM@x+{aHJls!Ji(265ex*)% zxE;vfLPvM7;gp9Pfo_qbI|iN0{Ty*#>F5H!W^%cSP>Z_C(VYyPa=2$mL!4Jzx~J8_ z$om}bOsJvp11e_e&V&eDtHnJ-KUDM8Qippce80=7XTl#<*VsCY#=lU@Ebaty^svL3 zqkOrgGkf0VPKLg&{!+Qzch%=T9A{;PRqkYnv*L1`m6eW;v*L1`m1`XxXT{|>E2|tG zXT{|>E2|wHXT{|>E7v(X&Wg)%R^pD1v*L1`l{Jozv*L2!K)E(Y_oCKJHfLsRt)(+F zW^=! za-1=j_GpgItamHrUc8fDJw$tG_ zV-AOmol_}Whm8GH-Dq)~v0pfxnX#KJ9p|V;x!iX#U%K2zv|*QH*^N=>aPXc5RHNo{r-D~$dmP<8!ML{9=EP_JWpFR5M;a8_mM^NZ*6MI(`}SL2 zOiPzzOPez-57g9Wb7nc0<8n4Os;R-|%o<#d%h{Y+?odq)F2|NO zXIkD;W9f2iX>+FKtu>Y|$CmtDqUc#X)!29pt5iiMPGP02Xj>hlU*u1N*63M0!YHhG z7^i~G%?hiT=4K6Rspe)M)>6&QewxjTXId_nrk@|ESF-fRa5;1lO9cb~|9EzkTDN#H7xuc!Bbej|Mu*hSw1-b81C zee^HDTScA`JVL+Ly2wDOF7)*wEhBWsqL0zZz@6yjV}au$KQ8j)c)I;WU`iwpAUD1K zX`!E^kHf=^&}SvWe-sJfnd^|Y7^}@=fx8sjOk*v5NP7-z;a>k)^(D|})mQ1;crai~ zpWqU~F2Ri8alwxWeo64GAo-3{tB-tlb6FpIh(S{D#YD11BrAPfR|4`UdLJta6TI3q}Y@h_MV92Bey-sOJ;wcq9cEd3xbC6Z~ur~O>}jL;Mi z4}uB7LBXovbbxE00rvSR$e0iu6s!WFwUGT#9ityRBfb8Z&6NxbjUwAi^t^PtZxCUkbKBr z6-jm0-_qavryw~8WSgm3XMxj@tO!htWLip1&-yBj1_qly!dk(^Y^J9KV^OB7f-{1N zIV|Cwq7ZhEB6vn_!2HpOS+NOoD$zp?3CzPEYUl?3JizqYx}CstkzU}n8cW_CVO$(! zY!S(=QtA%Du#e@ZLX2jq7gQhU-?Z$H#qEp z!%kWlxCp(X;VHEd+N*#XT}`t<$AB8{8?!;T0yWI2ymPh`s9~3AF6d=Ijh4$E+6tgX zE77xxt_5nCdl!OU4b-svcqQ<9_~!f1)u1=Sx5Avf7<31GE6n^$KyQU_tayMLCE#1( zPPH6#Cwwc+-YY?O!?(h&n(%(J<2O-zlsj zvDkEeJ82)rORel?`rt)m1F{+9EqgOyM?|jJHr7Pv!*OV z+i-_JKfbKkX)<0-JE8|=>&hG7PWlO2OXznV*Y@u|te|i+H9P;bv$`$hZ)}_?3^@f3gwF7M?vCbwo*hKrlT2r+FM5-rW8PiMY zp`1R*-0hWg*<$+B#u3PpnR2#}XTq4wXIR*)mq!c3ot12EST8vi`*fp{D}$B#+XvQB z#}2*RStuMaq~zA&0m!yj@|i(be{T+eY*M{i-clGC?R-_f)&I#kIV$?5T=QQWPUy9y;e4)Mr{UfQ36b%y#T zjj}!#?<(YSy7Y<>-=XLAQWh$SO1zWX5R<{dIUVUz5vKU>b3wkA~;o;7=pq6xdx zW2V;Stk&+U>ghqEIU zlPZ_EYfGJJ!)&72lf&JpQ<~}JIrP1ip^RzQAP){l-TF{vWQ4CGSGK#7%hgJf zhM|uQ>TEfp#wqpq?)T|x(K$LB8k(L(8ntFTM$ z%%bIaSKc#G*7F8B(iPbeZb$nM=%tG*Q~AS%(wL+mox7x!on^6eYv6?J(~BkD(DN8O zwY3+sC}oWZw}_b!vE8TV(i1`%uHFuMZwXg+rtB(qmdnK*x<`;K7VW{aH(l~5*m7^d z@JQ_JaX|R&#dW$*KdhJZd`7pcbyc>615W2BU4?Z)iM*U0%I30Vk9ItrtLU^nmmZJKIG-iIoB)c*jgSK7&34FG8ARXHAeN43^bQ3lv&0Z zHqhJFrR;P^cPWcOO7Tp&P_jF+JDVQK^C-+1?w!HvQNuQ}E+E`L%&FPY8)nxV)(ngR ziQBtwoHx)g;S`K4D$Uv|D>rdC%BFMKx5*%gJ6Ehh_Vv$~rRA=B2zNgo^9Et6HLyNt z9~da(GsD{2JbC0BcM{`%(twe5ZDZcn)5Gu*=S#yNUVr7za}no8KdK*%(~Fy$swa$N}KB(Pcz&w>?z?gENd>d%do%5wRWje z-pDa=*P1!&w>?F^yP#*sGd5}IFpb!f+6f6)q=6X;ms2lp)VTlEW){QG9@2(f1<4AQ z#juje)}qtaSyokDxwK)BGpx*8G`u>~m!~O+Gw!)k`37ayA|nKM45=O2p*=%98BtC@ zTqew{qh(4NoTCzkS}LCfE6wW4Wie1_jOSd7PFYuaPkuaGD&)sl&oiTW)95N-;U|sp z@~rRIC(8Tu@vMH-wK-qLc6$pY(}55y;h`lih3GAe>$~C09<1zx^gNzMWy)}_(@AT} z7&>1(P_i%ONh%Zv?5<%tmB&gB*K&E%d^(~Fz9;m>Ncm$*g#v)tbD3-svL^^KT0L!^ zK3q39TK$BIuC~r?*14V4v#U>qKDBM&j@jR--yHhHAQ9N+f$jrXRlLIjO5V%mzZE{1Nr z3yPTEBW=RZ?AkvJz+3e+%&x9JtXQZ;tDnL4j}~1macPTC6&S8{wbTkE)Dt#~fD-Gr zXqyOZgd4J%qEz)v?kKFX0r{5n|lRrXVnOzt81Fj#!c|8Kwqt(kbedD z2%vfzh@yVp62L16dE%$5_#2&mZQj9By12WL@0rNxG86HF{ivZ}S0`Ht8x+lt@9yd6 zXChqptF6V}mhlboHaKW%ahCGkS)-UsPs#&ZR8eEiq=nDY@v)7p@$vQx&e!4#NBo&` zVF(*EwD^^ucX?@ruit4$jq|v3MdHqhyAo!S?(?t7Ri4NABySk-vpn9R+=xA~*Whf& z`8x<3iSTZv`?b4rg4%?gNNn1@22Y-6eQq7T<_vI_8L^YoiQU3lr=A-{{Jh1`stb27 z))6HYZ%lX>$Cu;6Y1w+BFkZj@6KSykQ&zv@e**2 zA$ue;6wyzz`G=u+;s|eo^=pmET&{4m7kfzAB6ceJwQwqru5 zm}alz|6&jD8v&viQ5BzM(_Wl$^8Dob!yf*HayF`ZEKSn1AH6^&b1_X|)Azk7bWVn; zS>l|=|7qm_-pdXEduSi16#j?KZtyAKcJqJh(C7U>`!91}+w^7cac?u-kRNATV~Oz2 zfMo};lV5_LEWSg>b{plfcV7^brBbRN+BBpF^l2)?t^m&beag>oh7@ALA`qH9cKk2& zv{Y=`@THjf*N(RaxHaG%2Y-{?1%G2ylsYESqBJ;N-1kaNc)G`%jspIU;Qc}oweUyr z-BQ-Bs~aT@yoKNxiZwC5l8-jrER_@Q0rzo*=OB3ujHr%Cjqfi{jI(>b&*hEZ1A zyKWioW1@E*C;BJP0R7o#pX}H+F_w$rS)F$Px3ppv(Hg@xNP(YQx3uo>-+tZotugGd z=7-b#3Svv^q;9ls+uB&)Sl@vs9@*uL!A0KK(po9yHyfEzeJpKUH)cQhT$d?~ZB83w z@$t2-v9WYMdssKh_6kVqgR@x7ahAd^4EC=lYhvPMPHQZW4bLsDy_242r+B(pY+Yk| zD3>ZmnYS!2GoE#=QVw++dZvP#(WJ#gQo<7k;?#%nj5v-h(h=RbOt0&0uQB{wKe(x6 zu#Hy8@6yNhTr9`9r8RA&^5cagdZ{&5$tE)y-9R@U#x8+wHAZExFD6yE6CQMQ(KUAv8qt?RaSlycpsFXLqc(if_Vc2sK%-w;lGlbR*A@pZOk zUjTuSkU)Z;zz;xtnZ#c}f}g`AB!t9soa^MqxpAD*m03Dp3N8~J7+jN5P|7frf+4~ ztg+&V<)9%XKKLXI$03B_dC13UF}P0AwQ?*cT*tsD=UArI|E#e|W-Ci<31+J6ez+pn6dH1U z0+Q>}wdLFQxu3%MN@%FMrwFU=2k>0lmwT3XeV!h}GOSe~gE1g4;@RyI2&P<_K6Bo$ zdNd6)$)VU#%~dR?B$grEDJG{OpQOYhutdDPTlRb|gfYW1bGo%KV{DV%vb0m34@>7~ zq;p!1UmQ*A{eda=a+UnO5@)9Hu>L42Ogu1)Ma+-|w%Ax5^v3i&!ndt7%L?xf55n+3 zP0dtvqY~X&iS8Wk-y96OB6s!)aE&)Dsq-<6FX8#?gTYv__X%-#UHys|VhAtd`Nz}< zt0LfK=2x7+E^{oqvS*jDLv#PWo#%p89AOqXaLypIJ}<;~;q6-cyRtpaL2ADpwcicf zt8ibIa4+Fb>)|rw%P!#t{9(YjlXorKDFU>`z3|wWXA3wPS`G`$$r{WZYPTA-TSmJr zYNx^*1034Ju0ROhI3&90bUD}9`<2O^^}NW4)_Z^ba3bwgqsi*SfIGr=9l>yFtZHXZlTVS5GGo-!wj zAn7=f4$>4L9RgR1VClG$4%VxHb*LOF0;uCqI)Kvvc-Y)3!l>g`I*hLY<5TBc5hxw! z(t%>9EfL`?JB_BIG*mrb9jp$ydJ*g~z==~m9qf77Q8I6)Bm-rc#Md%u(9=dLD`O&z z2exB4W`IIW-x<~sr9ef*tIlPT zV7>+SI+&zCRG5qNNic7xwp5ttv*@4(_{vp_>DwC%9P%!CivzgM_QBDCN5$=rQUx(EfA0o{{s@fZtWCym)U~k=#ZN}s%+7@VAlU8(t>gtV_hHa{=P5EtK ztu%VIrEzO%G?oTmPiWF8XzCK>sm?9KTpcq`pHGJa&P*qCv!QMtw1YLL-+i?L;I)<> zGzGv8xp;3_yqlLj$-_Tg@vd_Uf3w?eWy!5$+P~Os$F)LP%CZ2y35r~||5K5xLs_9W zEKn`z0@$%Y)t?oD2Rl`dAD8<_|FY{|4cX?DH`kHY)lnR^z)H^BR+G7nhHncXFR#6LnhagP2@DWmTXmv`K{)u z(jBjzN>72ulj}${s>@B=eJknftEtX5hi}F9c|LIc>KR@0p}Vz$>$-*ik=X^C`#m^I z#&o7CaZ50$QKpG{4~bl5RBzTBHkz!zOlA;`fhl%9_&r|lpzWESZ8B*a>x3h;IV!C^ F{0qEWc?kdj diff --git a/MongoBookApis/obj/Debug/net5.0/MongoBookApis.csproj.AssemblyReference.cache b/MongoBookApis/obj/Debug/net5.0/MongoBookApis.csproj.AssemblyReference.cache deleted file mode 100644 index b78dce94aef5f5c5deea95bb2d152ae69ff9d235..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 138058 zcmd^|3wRVowt#1N2#W$Dpoj*+^~G!QP6!w=gr_7B^WY)R&P*p6GU*;>dI(`b;uXOM zzCd9`QND|cpnz9aMQ{})s9aDK5Wy8xkSi*yu!`%V=&hb~byv?+%}j>V`9hif7J{jo z)T#ee)u~gbPUR0OEXuXpueIB3_OXd2e$nSotPmu(SRwd?(piE_tVnc7fpSqv^a{>O zpc6hB*;>@vY>%LCFKCATK>sc*%1O4N z`gZica(VfbQ%5ScPx+)|=GP~my8h*}XFlz{kYZ7&$T{z#e_G0Ql9PX8*uSmuiQMc=S>%XdPmAf&PuoAlUE;EyYh5q zhs&n4?7sKFs2+27T(|s4(sv72x9I$z%WoYvBX`2@6JN_)duie7c5C~|TkWk;n}#Tx zOZ?kAU1QJFW$e>^4C++3EM*6K%aPQldv3s^1bkw)BnA|p;OW!7AW-UYJ4cE&#d4)6 zWv8WQrj?ear)Q=*)05Lu($EJ7zwG5P5~^}LeX?IJQyj8almxFEkxFr-hLcK4%-4&K zMn!YHZiCoc8C}NZ1&MVCD-|TCQfQ9bhW~CjxkqRJ?al=+J#%{W#G{K!PCa-?uzBW$}L3nU?EYomshN&#@t0`o1~y_JMnQk9lGBq*E*F zzM6F6(pv_0%@ebiUSa=z+mjpWg5(B{&3(i<fhv7$Y@i46dZ{5!DMx#8|vE=OFu{fj|cxIduan@clq2iL|+Wj4-OVI zv^xrTSi zNXn<2bHB(9>=(4=RH?e}^woIPbtonB_{bxR8(njK;NhD`1_w%KER?CFKFh^CV)Ce; zV{}ijr41fAQ)BEMKU%fDPPxkK6aD_gBu5IGtiq>_q{Je%T&`Bm=#G7Vo%hod`_*}) zt*JzCGPn$nV>~;ke>Z%xAOFIc%l3E%&&qFpN?POF(PegvQ(aJ7`G4zgIx=tj zr>%b+ro2+~W>(J!#(saa?MU0Y-A|5|=M8^pr+w&wN2`8)eyZo~TiR?}ICa&>_q7%G zzIOkX;AFr4#T7mMixZaEZ#BtjV5;xBSU3q~rAb0kN>*lSR%)^AYuEywR2B`U#TkN&e-&4Bvr z*xheT39jPZB3H4uL~XwS{U2aSzp(a$W+!uJJyQ46$8&z|`F`JyVb z+3?V;s^6wAYxVoS$Co|pzv}4Ehx1o0U4D4gO^-Y=|NCD@o)|dviEYx%g{Kz|s(T|a z`E1v-k9q$0wUhryE7_RVQ4MKrTzXXy9%!AIB9$4#~&=;mC$Q! z-)nvzvTXj)C$|SFmx^-~<)Of0yAWA$1ADNqW1*grl98V2%1p~l%Sy^j&q~#)&xfI2 zE=qBNA0`rpK+k(V(Af8g+y$r>B>oN^H|D7E1s-BvvI{>Wz&_y6|&&4c6#U-vt_>!LY>@4jNq zJ0-ch4?fX)^~Ih0-|^30|JSRyJ}4OhiT~?=E^7Z@`}^$~)cwVo|DJwLpVEPKyE42#7VUZE zKF>JUj92gQOk1{ie)3Nr9`-Cr*l=cX>+9bfdU*a9ttQNF_Vlg}7q6K8?G~l*^_z~? z{_@M3!=r9k_05ShpZ{su_TFQ!b+zx`V{6HvLr-_R%b!zO`OUW}_f@pX-q$yI!L|4G zX*=k>@A4DwPyZl@e^APfhp*r8Rl%i}$^JoEkWQ?7}57cJiU{9`vvD($mI?2~Y2f3`A7?tARi?UUEHuUnFR-Ie!V zk}G!UUbSU$TK;W&76&Q5IB?3`4j;AYZ!ZcJm86EcE|yulGzsm?$}-E6lU?aaLaH%l z%PpWb#_bOXo+i2v}6E=47yuSyba!#3~0`L~~_H5oanilpVrK@k_8cOjby66QIEj3Y3*0?>LQG zJ53U;2qdzR^XqobEPgy~(<@yEbg>;7@Y~B9PGs4X7M(Lz9o>0w?vxh0+ut?4f7i49hINxpPv5oZY2ilO z#xvsnE8qWo=dmB0Njp|tm2+pwQ&)U{&90u8y?wCb(Pwf}`zN$K_{N^z{dNW|n_YkD z`1^Z(58aA<5cNu|2^t44r!%uOIkl|J=}K|ATnz%SYTLBl^&`go2hfY>gWHvZW1MLvBd8l~xYhBCqIl3m*3@(M6-%jiSLs6@Kvw zkp+k3JH<-Alo5MLxM=)xED0ADlAQ$4uF5M*$VAGQU82X4BT2F%)SFKfls$CmShe^i z>xwEnBxs+-pa%dtpkjI;!H)yb z6ziAiK1X~UpcUbF;Njx{O;Cf^x!XeH;71%8Xl$&87wVda0*qta!CZ{(bo4i_65KJo zI&0#X%hNu;$3BYqRHIvBSL4h~A>Emtk(`y9CMNaE!oSZB?y*t#aOilX3PmW>rXlRH zA&T*<&e&r^2y3uAca;Wrl?U6Y{!t_j9#CReIlV@h+B4#JqN_c2P1Apm z(V6Ey5Wwe$V3R4v6rLZ{pNDl6!^081qwxHoekx?QfFHCCb_?Z_>{r~*;3+D)1Ljny zDuxf*s1^8~Gw?whRcwRoxz8RV^nysXc(7O+D5uT;U9@#9tT4YsC$L0@qzUc>FagrX zY>^!BIjQI3*a;A+9wg(Y6~}^|0Fk7R12;3cMYeMA4t0A(?cVMPsZ6E~bsZELk|ucE8fhm6$1&Tm#&K(mD*Tegacd00A^BQr zVyS%H5_LCBGqJSd{Bot4Senp~Ov}JmVV_W~ax?-MXp8RUc)bZL%`ef3Oqn5pf}gkz z)(}ygwD`nLD-x@pc7=Mba!ur1T}^8*i%;A%K@DE9d(>GMi=E&DutpN9Q0RVPKvLXQ z)XmMMSQE`f`5k)W=>i)Z&)rcx6`JEv*;geXr+e3|Y+5A^Ufw>k1T z@Ku`fvg+_lxHO97kch#f#mu-U_79F0GZo|)CXN;}i3>>({1|=2Xf? zWW__IFEzrE@G&~ILaaoi#~AuU!6W@cszVr-T-hj z)!gRDPC0C*vg+_l7@Mgq$srM2VdM})c&wl}E9fVkgpm_ofnT_U(G@N>Bw6qch*=#e z3mV>lmughKV{U7_ucXyy5ZIyr*WkXR>LfVIHwrK4^WI`2~jW z=c-adV!91_;j1?|Y13p|ZSt=#0g0+<1>_W%)TU<(+R-^dA8EyFKBa)MPQg+vDKY*Do=ax@KgwwO!uiw`?n%<@7)1ixaV zHnmWk9uWQXeC77}CA-64_^$AOZ$Lj+G}s!kb2va?d8&!d-UzCxlHB*3P%!NBQE z31Q=4$J|+1;vF3;mgaigjCcA-@2Fl7l3&vrfTVX+7dH-q%+UuP!>?)@YUyxMaEU(S zHAUKzh-3H}RUoN0tx<_%_!)x7!IwEgEiqFOUzCJyW>h-|mxCnPw8kfCrebO1z{eb( z;PLsI%Hj2qJ<;O$d};+qpiOIN;`n^3*m00$4opj&07wNfS<2xQ=>#xJ^2?HR0vPf_ zLL3Wyl&`8Cg>iKuGE#DB*U=;g3S=KE!_^o1~N_~#j?-+xgmX_&RH1w@v zNLhXdn|_!WBC&xo_FK9vl<>Z8+*rz((|z4qnOFy2^lRd}Z&~|fql;qKcGg8^@ZI$2 z(rHM|>)!*V^b+1p6UF$|alD%*gf-ZmyLyA)N+=Y|JP4k8HaFPq_o|mMnRYwAmB6aQ zFI9Xifh9R4V(^^*M5BjPxfREVyx?o;%mZ1R^FLBOeo^C`|B!Cfw7TO+>E zgF4&1G(Mu)2})%j5roO*UlTS>87HMA_h5V2b|RANY!7R|)5oQ#$p)0ac8j@<$in0z}kqw#S0LqND29L06*IW`3WYdbS#u2$@ zdElPdBUH|p{WJ@Obg zdH@nV{Hc?+7MVxuxGHL@F#XhtRf%8N`l%C3bV$nZ@j291Q#ML^d=9Mw++_|u9)|X7 zjGjFAn;qb9sbeFY(s%eRb*%`$V*$UVt_f=JI``Wg;0|7#N5zrr5!_W&YZW_qLyGdt z4?B261cu}YZlV}%_0@P4x!fmsD{34$o^l!G4yvGo#U@I$y8M#HCQ7s(fJ6^&qR<-W;kQf#6yEAa~(nc-ZI zHo_y%>PB6D!AG9ejUIqRKdW)Z`?&O^tX$EjxXav5^yDJdUh5lC??XRLMDPDMKej(#iyl|Nzfr2|6^yUV?5z)JTj71zf9HubRy*U(l_(|AU9`>Gy8JzGj=m*SaT69e>l3xuHa7b>e z<3|U~yRK9Ax*eyN+$k@8_us<`jxC+&I@0B-A%}mg?A7~{VQaUEy-#mz-Ez`uduyA` zmi%VFF>5nMrQ7joY^cO>piE6JElcf}o*}qWGt$J=bo6V2Uv}{52(7UwAql$kL$!`@ zbcDGiB*vy09buL?4v5U?2=JJ+VsWP8(08`EvP&#LPvBB%;+Ql>6@C{;9FxWn+~9le zK4lhBzmZ3u0G9%m4>9+ zM5oy>nd1P;oMtP)r&+zZqi2XdkKpx+F51d@1)hc|5YO+%~iSr~Qr#jEdG7?MLG1`p>h4rz4cjVTW2X4itm+_a`<9L~*_ zJr2;!DcbU}Tp;)ak4L1QsjD1`lft)l7;90*5t*6y+Bv z4r>e%7?LCS(G1bn;OtCWZt>AfXjy(q;-i^Ri6K#1Xc*TwyFiwyGj6zHY?S90X}Do* zNDYbA%9+-Uo-m;eP|8fJ7UdTvWu{dHhU5tE9@MR0%37(r2XP^O+3D^jqu3`&R(vD)o!qf*$t71) z50>zqT&)Pdtni&&O;AW);333nc7Z&%G@Z7W!Xd=COsvGBul+b=7k_d*UBp`V!TmyN zBkMD|M^6(SS{8BvX<8E!_6vndY@m#J1!1~sMd$-lwXrBTl}MgMF?+jc>q%H)IQ^f% z`V~g+#Xh&Q1_F4Xo!TMe2Fp&ANKB%>)`kP^Oa=KJ0yxmlB(6d5-1Q&)y{BMH3k0Pi zGRLljdX6&}=a(ja?}^e!kW9gyX-0b~a~XD~>4o^^hn;Dp zQj}kUcuyK4FeFDyEDF?KY*f$>B}j|HRG43uq=jP=8ImTrhe6dm$}EaK4Cu#jHXz>7 zqYpLukB50eL(jOPp+XrxcF{1thA^Tw*SU+gn_(6i7>iE5o_<5{7vO;xBMREBy zts9!72r1*h#JrVR0*0x|@05KWH}&dBYy87l0Y!IVjKm)qM{ks}wrp@pD~XCUjfpl&Xq}zqdEsY1*{TDMk@e8kkZX$&RFRI-&5!se|47VtJAJZWE>j$2X$hrWk$vT&uf|xAnt!vW*{lPt?RIXqz`4N?4iS>&XFY{?V!HW$)bn!*=n|W%NfT)v>!p3T9l z;%i^4>DTknx~X<&G|>&vF>k;HS7}yeR%*YLESF0VGm_LnpnlnF?beeHC>6+^qNdn! z%aS9f)Q?Wfv_p1%>2=>YPa~g17oYth{Az-~p`~jgPKnC zj-?~C`uwVc)PP=q)P$LhuL)>5(Wi#d*S@c*!40u>fKTLC2P$Lj0!Rg@X>0`;or9)( zLj%72?0}{LJ!26+SesuJ@Wk8)kU9|agQld7*D#CFyu|C{e^TB@8vQ@VAUVI>%VLlo zl6d2cdX!OlR=r_ZAfw3{D_fwxo9rdBL`K8Yu^`U(LsRJ=5-aV&LZ%BX#eQk?( z-__t>%~X568o$)V=)yzdo@4n!uRdQbOK3ajcc^Q;j!<9hYwZ^u(#ZFv3eWlkewD!6 zpnibVhd^WMgZj!B5mxur<8_)ITpLaPU`>AcSHvVgB=;GO$z9E*N1iGUJ=Lapy%X@d zXoA;Q<(IrWwhn+qZ@ryQOyH(?=U3N#tPOa&oo}wkFLb({ZHe<^u;=D-hMYb>zicNmWrk!L^AjoY zGbP_XL+`nZK8d&xT|2GoENvk7q6~EtE^L9|irPa~@j2U+tW#p zkeU&5X85>0%2*J*;@56m_@1T&S5o)CS_OWAPl+TpBwXtwdWI|LYB_bR+w#8)Xqf2{ zJz-V(1x}CX3G0CK4ZY%Jpg;0lZ4~q&RsVSCLplHw{cOvQAO2rW0s7GAI{F9js|IpIx&cxdtPkc5QwCiNzWDP$H7%eA^M=;s7e76iH&lK| z?n>iK0Aw$>XJ`K4YSi};Yx8^N=qPTWI9K}~^e_;GEk3hfa`cszR(?s~%e4!i&9=YJP*|zuBV;XDvDGRMOzuf7kEVMp= z)B)>nSC}Nw+3(-@p~jwmyMnC6FLV0s3Q~4R*4EGG`Jy7YP`s_~RU^_P(C2epgI~t< z`5em)$=7lC8I!pt_j$?J zaEaD_*zII2d^x@n8Ii9alCSl-D%HtH4b9JyBv}dGgCkJ)zT;mSYI?3pN@adWH9c1) zr3=nK1yC~%2?~m8^*e6ylgHi0%FR}Qkjj5V1qkT^NCl|2+`Xo1Fd=~HNezSl^;Cyb zcwK(+Pm8e!An7;GW{q?u7@P8p6K%D`RqV|gS(9J#?9Cb}KO}dlQAT~CFiR%3Y5uD( z(tvkks(P>rzodo8fUy5 zdhn7-cu3sSEFZu1P1i@TkvgO+Rh@&y`NcblEi@$7JFI^ltWfl$gz$bbS8!IaZw`OF zhgnoO5G!l&@71xkba0#Z4wKOYU%4Sn=akUrDYfqp(3QjuQ`pr4P1hz|+f`tudN z@#v)ppXm3iZw6xUHX~YjOv~XoLYC8nK*o#XfC0XAJQA z3jC604DfofA>mr@L)VhNsCOsOllS_{U0eM+z5z`4sG95Xi<<63H%kvm-1^r&w6>2J zQDo3QVn3>lX!`3OMjd`hmr{3UhUAcxtm7C>5)}Ic33>2* zilaz&R*L9dM}4#2={=m{H$Bo+h;=FKllaw*nQ`?8q@pyMA&BYfT4AJuiD(FF_4w6+ zh=!mhJtT4K_jN^~-a6wpB7I+{Rp6H~eP5@E4GFgqhO@gIJ^xdPR(w-_uiDAIc50SB zV>p}Y@r#-(S>i9({C7)wfLn?zhO+u4$1m2mY=TUma8xN z$WGZ4dadE=A9rb^yf@u+(R9UJpI`n`19|~c6B=O=*GOV}t@gLkry@FMHPzvlHDeL4 z?m2WDUt7DO+!$p>~%jZjW1W6XUt|rxo~>Wx9n%*5a2m-9jT}hh*)teCnpG$DL?% z7QaNt(!_;?Xi@Zok>A!4G04$&a@#ADlmo5pb~_RM5T$k)?&-GrFZ*2ljrzBJh5F|; zHd~8Yo9z+w?FG%yAL!qOMLEf~7N`LF-w*wJwivzo7#Alcqn0Iey=A7tocW$u9v-Y`w!d2Lz9oS z9Qp8W=jI!yZ5-%(zW@5Kv)gZbEA74+qu0OqKU@6S$2yH)_x#Xt&F8(jT&X*9hwIh% zjtu+x;Z3dXxpMh}UVAp%Tcb9ueXXWn&qM2`+KK3gD188_0~R?_C=%q0RkDvr(Ra}$ z+co-xBZXOyU+#n>g(*EGaf@D1CfhDcW$yBTc4SJAd@{y9@q%(ppTVyt5HBdl)Dw_e z(FkjSNh=1qB^Q|i>Xz$Xi@X+4YV)fJjJ1H$2aq~o(Obz(T~=M|g5=6`ONPJIHZFgQ zrU=Aa$+3I{zuG{&l^jb)K&r$7i_X`Xatx7XxP7uzg%bLX5qxf;)a1G`lq1tHjvMq@ z{A$UpIC}(AU97r4#YC*S_J|+iO{49u+qY`72yuUkD2QJ0AxsqWr|_#H#Qmul`vOuq zEP9fSDai=QZN%m*e&$_GA+C#IoS>@wY60;iTco~&L~l`!DrWP|Im*hEcQp1yj;e@t z`Grs9sEXJFko4zR<1A#hf23GbAo|ov-5CGIp%3xgdJLZsrU`cBvr)g!dw-KRhI!EF zNl1NY?0rUwU-T7;PM;}QbIbl64cKQ89}%Vz+;|{k*=GGuAi6V_YI~X1W;%-mm%KT~raknRO z7eFe&z1I642fKxGN%o@{F~4KDD0q~L+zQcI>8DQ@wX0TtqD2(-ry9>OeO#E9aI>SB z6Mv^b>W%f=O(ti3_PA-#KQv9DZ#P+=z^`)9x0|effYb-;54=@Z1BwKnfu0pbNmc2l z#)q%Hu34M(18??cgy{q~8&3LxH@hbwwPLpAPARh-=&;i(`^h{%w%@+_yQUI-s52+y z1NhYkxgp&EsSFlfI3a8$Gs_`WrJ~Cvx^({}5v)vHIEh+6Ocl7XC5Q_rQG4Nh)`WtJ z8o%2qcyvu5W`$TZ0oM=H1a20ISTq6m0;DEbe`cl52`FcfB32Fa$fc!fHc;JwG@MiP zGpq2r{AvLG%qqMGAn98l4>w%hcOv9;bMY6)9?dqO$41j?^Q!^$csN=gKEkXF`?fub+1PDa;lZ9mgX1hM5fG; zOszjk8i9@#6t_}iP6TE9>hU_w-9tZ0GF1zs%#G1bKT0wQ4~g5Ngxtiuqc^=sK@S!a zsh)Cv!|zlR3Ax!7`9)47peT!!j9ul`j?_*M?sUb7a&K}7@ z^VnQV^{L-ff|53W&{8Rvx zhTAEIDu7|(MOFZ!@*hTUoe)ytQ;1@Lg@I@0F60SuF0g1(F zbg3HoUm(jyWJPWE*E7Qt0#fUQA?C(KPb37SN)AbRp7jCTqrK|w4nI1MA@1`Nf>FkH z8r7JK@MGVAbd;q^nK@Y@a zbOWR^SikCHA$0h|ro9(2hO!0zUmv2LsGUVt2eQzqolS&B&Qs_Y=MU{kp-B@>P@c{#+e)Ij>zgw7abC`)0zmX zTZ+^N_k6MuJ5}55v)eVpy`wRN^>X~;97B;7lHfFJ2#yjJM=ib2N}$ z4bei2^UHG*TWCnE71m%K>y}be9ED=J8@+`{B=RkI@*!=3?PADhE*ysR9JWubK0GtF zZr#C?D;@LJv|o3&?bpZ8PCN17f?t}?@Z6dA*rIMP4ftx=!H+)OdT806jE+5;J#?Y( z#{bklI=AkN>Wd$IyH)k*p2t(#E&8VAi7$`$*z(Nx$4|K?=3TUS>+_G@FsZc98nI8p znf=+yB)RXgQ@2lE-@a~1_H|d@dr7X?rF+$u#cBDs?O7bm+Wg|cDRVn~)TY0E0!!pL zfR-kumZg_vmL(^<(vyT#p+3@Iw=;-!*IzpR{$Afhx7sI1kU9>s zPG@Fma%x$b)0N_Kxzdw$vY>0I*5(nT9R+T$=s{^!i9POTpKsGfX-7&qeo2m@NDE1@ z%7U?pl2rwKYLsz~(}~^~M9wY6M>sNVJKEf@u}sjUqt}3>+O($KsS)LlgD-RL1>Mes zwmR2W<5gtzxU{zdg_M)`zb0>Asv+(ktrEYKozX-;KS7(4k9E!36%%OSv|~+cxs41u zzJz1UHP;GjN}qpG;>jwv-*5IW|JPd|X^gQoMJo?Ej++)7izU*B97hU-cO#J67ox>M={utB>n+5WJ z=4z2jg$}^(M#fJN9n7+r&dX_{T+rRO5j8vcZ-ocau8XDz^cqK*s$}?J67=_a03egL zT7H9)Pk^YkDxQe9gA(6P05O@s*YR17fK z5hH4Qm{@BOdznB(MAFFw#*z?GCN^0_HxpZ!kha!aZ6yQ`T_e$ytBP4ae3nmHVisBy zL@!rTS)z(@bWSB1`USHL))LjsLU=2u8$q-Zm&3DRPeO#E2+{jkZ7$TN^|K^64=A)? z%c*q}Yt@PtOM>%RYbN&}PbqX~A(#um^qR9SCL?&USSb!Jl2P%TU`5!}G0q-|SaD~D|zcld*7ur2t;wpQ}Rl|rjsW>#u7Uwp0WLFG0ws{y6mOn=Pb7=)5{?!bwa~3vZO4E$6o6 zegUZ3YDkNN+t9X4o&YzPX|SQ1y`4oE^tOl_ZODv`iRk8xh#PLm+!fKRgO)XJxgk?n z@mnoEH{Fn#toUmzKDXVF39a}w7M~k$$h=nkGKT zghombWTj%8AqW^)+Em^W1dI}!AqW_yHbW3F%4~)pV3gYoLBJSmGXw!+oXrpfjPW)@ zkP&lZPkP!7$&HvhZ#Oso9=Q<#DKz5Or>zaiD_FuzY-2B!Am?e4S5-nDoGC|5t#v$w z-$`o45;kIiQBx}x#1RX;Hd<=MnmJ;DQBx~c-VqConp!U#rNF4Eb^Ry>Moq07M=9{W z(YkSSx`4{X$Sgy1F%pO~7ypNvqINFE9%fK3zEW~A&zsm)!*Vgto)How&!G|6Jd;LX z^L!eC&9iC*HqWgQ*gV5VVDmg1fz7i`u_beJuHYobX-jhVRBJDR+&vDcafu&Lk8x}a zfhu?Z9qPeMfQ&u~(+k>AETuoKq)8|y$Tioc_Eply@_ zqpkxTqZD{;v~^(DCfz2~)1UApJ5!gK26kFB-&J{5Z%Ui4i92+CXaM(J)0W$g|OheZJ4w4}mN7AQr z9pFG2l6#cMu?}#s49P-D;sDTO9@T$anV6`7{baV)xOd=AM(`QyCjA4P2=}17)`))>^0=l`cMz_E#TCI@9A~D_ zx^XOz^T{uu&A4eS)cfY3Y83y{z`?3M_zIlMfe*MCjxwt9v#L!xA4Ds;h z__ZKXvUm1!y=0nK4j^@RYCf0A)743&<~M@qo=Q5~toN}bM?b`u3u927rjN0T!4Oil zm(GqYa_N&UC{tpg&=tH!B*laI!8mhgk_PL1!aDF?8e0vMj>CMk&!F!>irp95w*b{z z?c0g=VIZsaC9rew29p5AeD+`IH&jEjgNRFI>;MG0em#hU=$&0B4P{HZC$)$#@K+s| z>V8)c6``dey^lq?`XRnt7*mEwOG~93OuY-HQkQV)K887Hbr!cyg>-R`Qy9Xx_Ag~d!Kr+a%Gp54sRh_LZQEEYpaVv)7*vm8HN@54lL z^?3olhmouHit#BtfKsS2*YiD0bTfDuc(NC@2j2~>^w`Bfr`t-nSIRV`G4( zmIJeFsxib2E4~N`4PSx`Tp;3p(hCeGWgE2ctaf&Z!cu<*_J?rwf6VZ+dczNrVO~Js!=aqLCWntRf%;O~O5N0>VsCVo!Ouupb?3M@5z0*qd zKJMImrQ`n5&2Q>d2f@81^J{Ze$C640FydDaz)VEAnDB z3yM=RMvK*`Dpq|^tlXDM3$v}{y6_zr&E(%Yc+DR-z7YdAUHC2mu5v?F;-i=V{hQ%q zCKpdMc!4ly+E+(zcG2Ha7X5+z(TqaYI<*=Rxg2EQ3;-UdX6#mU1usV*#C7%xi7Xeu zasg;q!0@mZVTK@&Ir0t-falr#Ueudx|K^ z&Tf!d!cE7X0;yAN+OQP5{025{0qOkPI2wH{#lYZ;V~5H`F`v3Q+^WL(Wk}b0pHzrW zHxu_lrfBKe*eTFfk6Ya<^%pCr<;G)h_YM{>YvuMDos`;OTEvvzqYETYF^E}IhUYac>4sAp-q?!Qw|e-8P}V~0&hyj zBhlRn)>yZUXpauw)+TzmPQC9oW%bs^2FM-*U6uz~eP;~AO+HZ7u9$RhPPPx^>)Jd{ z`sgx3wjy)@A%gTEz8He?ei;T5-*3}D@I}AMdNUo@RrnU*8^D*#Bd3c#;}!T4_2)8< z$kNxcA1pL!ub1J>9EN}Lyr-~;eptxTTe2fLCKcwmeI}K88U8Sv;hzK^70x{1UV7N8 zmznfc4_o+~_dS4H%Z}%o6oECA&1U!sflG6kf2Ne-&pgL-ee}ot=TJ+xc03nP*YY3F zDWNTS)p=v7+;=u_B7HQ!I^Rz@<&Wn~rt@V~IGrx|j^|FM=YV_ZiIQ5JKm5MrWNsDx zTS?TIOYh2m1J-tE-}IYwy^Cw9)9yFG$^E8(GWBXyIGG+1_=cO{)d$?HvsU7e6c2l0 z-=wSD+?KNi44=;32Al2qjQ?7Duy6rQ(%I%cz!%ZDywI4*bQ5fvv=OZ^=~x+S-kkrf z@}=}C&s}5c>3yE5en9sTUp-yyo$B{elegC8rEoUGSKJIw38z43{3+lj9oE^}ZbWhc zJtM6+F43Em&-^ulPlt|=K2iQ$j*ljfc`j!aJqmm+-BtWtPCexp#!BmHV&OnuJ^fi@ zxE!3ZR8n*{Zv!0w^wJgiXY*##9l(9m01G~Pz3jQ1Ep&NNb^hfPDP~Be`wFV)$KYH^ zkAO3m#sTi6)qo}RDEh07t|+L^n@m|cM|h8);bB0Nc1k=SFpuZ%qHBvE&)G{4`hM%5 zNv{;2&8wmx!h)Cn1j}CfSM>E{dbWfL>uGlR5#MC`auM6PUTi)Mev~c&CrYyr?L{;d zkw=fXc}(68`zD?AxqXXp(-<1Fh}t#om)tRI?Jv1Ud~y1%=)50rKOHfDgK_&WWgP9( z0>1#rvm$ITl$np^vjkJ6E=}F#`J8_<>6jb5w3-+-Ou2>nC1%lPyj7SD?E>27|CqlH z@A!Fzx;2+66Z`>`yL^nIibVEvpQ4KCB)5vIbNgs0l(n;wvq!!+TLv zg!+n4E2_f@#!{g+cvp*9M&f{r^hH`7N%)-E=i(K@c-6GB}{ z_X+g_p+a=OPz7RTH+=$m>ZofgO{cZ~Gv;(^%6Z(>==H2`06w4fEwh4}vc6+(?)SRC z0ayxHL9=|%0Dht1=YWs7m~#yJ6;vzmlfwD9;9nOzMS{l#e#rIwJ1(WsU&ZD>Q?^3N zYV;vk(CFu4r*-TL<^l>CFPkM8Gk+BPHQ=|=KLBUxrn>~0KOgW5ROU9R-}5cgq(DIh z@TT19fOq+4x;4tzsvOdJX}(9R6X{wv*Rsu_vjg~h5CPl5A1DmX1NwB)k2*BjnhVi3 z>C>eQn@ol~1*+Pgm9iUkw(voLj|%*?!1;#LhXZKKZ0eJC^*L&}0r*}1+hF1E^kMPj zqu+>=vTRC z5slAVl&|2k$Ue_GG(Gf^CHs!=dAEnIpKQ0`MRzvcp(sx%?~iUTolq1VFZ?U0SyM!l ze(wIeJBJ<-YJk>}%Y%)Oe4fa9*~szmo`ye9WW8>bdGZwj>RIC=2lcd3?J1yFlufju z-cw99*o6`OMq|w}bjYIEN(r5|D6XM|a;GUxwo*!6LJeT0TH_fS5*dfcMcqHibBQx8liN+}uU*db3PU2jp%u4_TP-=erzX3-rM#l13%?y)HDmDzN^MRBjprq5aw z_evE#Vo}^HRdmLpxL2y_NsHoMsitQvihHGoer8eJD>d{hi{f6HLoZqs_sSgli$!s- z%%#6u6!*$p%BqyMd$?ETQJzI{uVCwMQDafAmL^)%Oq8o7{yhOlo_lOQ9TH0Q*nHYQ zn`PW%H+dG&wHCDx)I$2OP^!lk(Op%_3isF|dQeg5vD-YC(l4q-h8{caSxnCh#XWWp zsO}n;shqWhdWBLwwuG)%GU>4;bj+f-$Cl6?7R5cbls;-v++$1Wev9HBTSlL;DDJUk z^oT`qk1eOu7R5cboSw8O?y)+0+M>9}>gZ<{#XVL}&sh}rSUtUHQQTuI=+73#J+^}W zZc*H04dj|5t@Ut^HBg>KagVJeeokf2qm?w#qPWLa(R7QN>1palfns+Kj?y0VTQRup>dQ=awo{Ctt2$3ExTKrac! zJ@yEwg9})udTb*NC<=Xa6u-E-(W07N1)y%VsOj#bw26*eRIR%J)G0;5rbe6T!8G+1 z&t^KUD0KR}frs6q?KH>I{0J3gZ>Pl;HD4c_eI@O&s2EjbUq$?6kME~X z<5vee=z5`4T&|{@g*vZ&tz5$%x9;slu7zTTp;Km%E@q$6mGoHy%x9L4gZ< zS(g63Oz9~7H`8RVY){?}KCOWD_rtzU{QBNt{1Wm1A<+p5{&sARrt|+wT`gl(oEbjh zd$VY-lOD`3WzEZ^9~JzYa1QfrI1PttR46!HdKi1rAkN23y#MXRd72Ly=M0{OpTY6l z89Y-sgFEpvG#1}+_>RXnn>Ys+0%k$Rcm<#rYybAb0=h(Coxnzcn+0wc7!nu}cnzRN zy@KBYIEL;N&O?CXD57mIte|TEHJlmn+!&B-bY3_w2z(82HEBBQWCIpZx!?>7XolcZ zc7bU zEG>rgD>R@#Q~DU)2+OPK7JYW%kLaY}4I+I&zuEUUV(8P>3FjewbLlj#S@1LZ*K-$Z zPwJD(H)ucABj#4^yneJ`hqgncf7Cx<#I@J-wZ5&IW{l6>s%0B@=WW$GM5-AtmcCbe zn!cZRLMu1g%kI}Sw7mdlu&)+;P5UGHJm1!~Ym0q9((csSJbwVZwft4UZMnLhq&Cl3 zK;|TATkZ_~kZ=wO=a6tNF}Up^?Yrhi{ihP!pK4>xoxsPMVf{LZ+jSDLn*_f}@Q}7| z>>>RoiRW#?zfJhJ38zrvf49_ix72mF)ODY5?i0>^!f7;q;`_0lt-VqByuMjH*=)RS z7SLwnx48wh-I(EeK@S;=%KxHAjMmbB=nvA@j0r}a_Pc^g<3=s+nq%ClUFDh&{HZdH z?$q}C)`0V4-~(dqVHzmgZ`^29m`9A0#st?%;b7(*f@`=DNO3zw&K&oi{wLr0WM_=NDqi%O{vF^zy4lq5i47d8QBZ`X0aleIAgPI3MyWm7l=oR;DiK*1x5sJ)|kIl z;C6vm16EKU?Z>Hf4mD?2A*XBy97k<{Q)mFNl8yq-qtk$w()R&Z&{@FC=taOL;a?@N zo&K7=94mKo_6pi3FhNIiTZPju9IVpdciWWbWTC%+1xY2IU~|1#qtaEIn-ik+@fra@#Px((<%^i0eDE`R`&}&U_s`b z5d5SCne%{HI3t`hQtG_m=LLU3ne%nQ&s&f=zY?5`weXV+@za7VH3YA) zAakY&US~n(tPs4>;Fg924;jpF7kt2i%sC?XNeeRPwDCcj;yrELg*KiM{uwEI4*YKK zIpLod{(0e(>x1+qFS%G>bBVVuwi5t9D<>fQ3gK4>zfSNv!CPJ2##Z5kEXZa11s|{= zb500;(t^x+!1X26_<-x{l%IE6_-8E0(sP2Jw;*#UOMJ5+a{_`d7ub-+v1%1OlvPjf z&g~ccguv4R&j}<`?3k<*5PZ47R)Hr>ZqaGL4LRoo2HcD<7uX6o!FwI$aS3-81Qqx?H3p*5?o+wG2^EN2F3_q;C8x}K1@&3TI~+)VeNOC zN1vy!)VJw3=(p<+>R;EN(oJKd@t?-0T`RIapQV|LO&xnx6L$gGIG0ts&wQ*RV=14e zVO81YT98e6l6NWK$I6!hz9)zAaNY{QhO#w)7fj}Syp-V=L>dy#PAPS*z%3q@-e15_ zmD=Xo0Q{Yntr9!`eGA)M?8!p+rPWG6IcpjjRSY!i^fkelOnFlx( zvC$BneBjfu|JLw)3x9M0yLWz$HUm({Q>`(;D*<)va7%&D2GnuZ$IsKM0d<_;jRQUh zP{(@5PuAuE>Nu5}1h@<NrQ42Yd^lj#GyDfII18a9RL$ z-0NQgJOrpy8(j*#9Z<)8_Y&Y?KppqX%Yg3&)M*d=)hGg}(_Z+iVFh0Syc7Ov)CH(h z6#i-y1H@Y@@E2#YfI6NNUIsh`h`$p6e>HkHU=aoI)Ub#qYn8Yonhv~}g1}3t26ze0 z1zt)EfS1xj;N{c+yqs16AB(v#18^PiakL5eINAbyJY5caJZ%GBjdm_WT-xY8c&hb# znxNHcd$oS;-?cn_q28(Y=r`%d^@sE^M%4I{@r<$Ab*t;Rt0k*5>uA=wtV+|>&v$&z z&&O~YkmX=R%zE4v4(7$p+eYBMIA*xsnGtwnN`~vL9D&C_+T*)?9=Yic&Ljr=5;6DU zKA(9e|2-P{^qD7z@vbwYB6hYdZoVOBB2He!ymy!{5i>Nb9TBrvc!T{rg42@0{>9Db zhSd=_pBN#2>e;!|m$?K#TQ-sj5E?saL}_whBe%C*9*N%;Pm=4Q>% zdb6sv&t%QlzJu=+bB4A}+C+<2bjG6LrBi9~(o0%e=Css+6Ay=y;We>Dvc4zM*%6K} zZL=h-GM80Whm-ZO*uF$vqBq*kV&SfcMR!GZ_r$|Z;rRYYdpN<8TGr=+^ToEU!Xn`` zg+uZ7J!~z_V(r?NIq<~R9&8X2WzeajN`uqJrsl(ATAYj|JHx9Yok_GoadtTg)=XG} zr3opqv`1ZbwY1blW6|EOSWlw4w>wqeb88Wusa@3BqFgWh`RQqLK@e{qPt@&Vx65~o249W2=9tSBbJub$adC; zlY3$vR)4_GP~D7VB|PYiBzsrHy1GO0a2(2Ppzc5@f-rz;tWU(E2xtUq?-GtxIFa^m zOE}TfnFP5mlHf~YG&ygs3VLk|kWu;tl28x)j3+WN2XF9T>A+xtDTI42t?G%kx6Y-; zRgq}Ns?MHpGzn^PS0uWjr)yJax1;OkrOl`z2P{Q ziP)~BvkmL_x6|%$vZb+u66zu&Zfi6V+7;dy<97W{O<4;s6=-UFK^Edu`paL<`a96l7=;;PR*X-0#((DSWh%LT-c01O}Hhz zKN3DLio&K?e1u}0;D;HLR6upn4yx3k$-4Nc7KYG|5j;}n}9`5Gw@*Jm30;Pr+LLa6rXlA4zq-Rbv5rY{XqB2~>WrfKqK^>g8Ly0gC7-~=FWg)p#dNfJN3}sbd z`Ak>Dk!IH+*;va(QxaoreW-m8vzo%mL3F|?zP!m5JtH)ox3-UbDJI0L|W~nSw3W@h|W-+Dnkw7wjNG$ z_3_w&1TT;h2qd>TEiDoT;`TRo)Fts^bX!jn50Uh98Mz^T3G==NYxWRXU3Vli$}&Y%SBdVHaA)YCV2O;} zc6w7Bi)DK7|2X^e%=&{I|Qt`30WppYe>e#Grra(7>2sLWh0$La_H%%mDku~56kj3vd`Sx($b9XO*ax_ zZhr(fx)>&M-$S4oac)0u!e=8JXvLfDQRVQch(qv0Z zn>q#T zdg3~7e0j85_rPLb-JuTIO%dOT*prYgV^TUuBn{jTh2stuwoBn=>{U1J+J)O5hoGuG z8H-a@yIe*bHVu)`?kFee_Jln^oh&BAIT$zDR#f-2s~VT(O@6V?_7(};6yVn~j~ zvK>oA;9LYEzEx}L>6RoYMOCF2zy#S#EiZp|nKn#x zUP^4*+Gh^tW^zcHk3CQVTf^FxmL&c{{on>TMj_vZ)M0JuO+abrid)4~E`iyP;}Dog zCvGc?RLS}?#J0^uKXOQ&o(Ut9MMpRcatKGh({U&uJq)YEABZ$2x+*1t&P^S zcZf0*#m*eg1msY3iqVI|Q;|b=&^iUp;niAA8ZH=|f*dxj0}e+vatLLq*%ZS*uy?pg ztFEn$8|5xD;V74h>~NXm7|KzC>*waTC6e)wENcm74bfN`-5-g^qP)-nbqK9t$xBaF zW+Ravu7kHjRdxJNFvwy*ng$Y1$f=bX*p3y+^0~_Cv||cn+_N`=Z$s10N8;Vv&>vx& zFweO_kuAz?b%D4$o@c=~9}W(@0n+mx*kQv+sj#;L-lB7uD= z)@rp$9GW#UQ!2q57$>orJ1!OAq$js79=U!#zX3Sh~)HPMP~?qcPO2K z)s15!z4V5yiDj+-30`3BDV?COwfS&nMn^XwpjD0u&$n3#TAieINw$x(F;W{N@icSd zj3pRTgf_PEz7o4U-c0hsOM{n5>J0Bn5^fCkBq`S2!dt{hdn8GXGE?Ko=#4l57u%Ni z=@Te*GHu;?;BH^7Qx+FBSr}Fl3$v1BX9P2oy5!7V;j$5OOxyHkXb>-9rE;FwvK_zy zD9-yqSYyc!sd(!+rjvei(z~(L4mqh4ouND&A;eYN`PfcW1QCCw7M|V07i4{Ge|SUq zARJO>#B2}UyI)kdCfhgQ&rf0F5l)0-^Mjctxk#g}2f%jbLtwgW2k7^sr zZi(Bwjb83)d!$IOM{$}XPb&D952u3sN1^Z|^gg^v7QnOS4!|Y&_Tf2v3fC0=qbXf@ zCLP6d>=@*2c-yQR|0#_{xXxjnN$b-(4bW-A6YwPdi%2>A;2ytoj^V$3lmItIamZPZ z@GEGWPvceyKLm|1p6e@qgXoi+eG1@j+42|lL;=_&KifnX+cFMt&XjK(a?_ zLCxdp@XyACVL5~r;FuFv+b_!B0NpM;?^iM^bxK#jLJ#~;qIJzEc@WqZT=%2qFde|t z`;2@OG~3`!1aAQ-`y8<#4)X<-&epGuuE=*U>ewzVm1KO#=!GV!)0 zb$DkWg80&$YQO{1CT?*Yy~SmQa;xwjLIQ1w;&sT;tp%hk;a3T&KgeB;_cicSDK|s> z_y{kG)PU+mO{lwkHLjSnmUbO@y{MrbgN&&E#`$OeWBHv8kN)I`$75YzZsp$8Tmen< zWC0Y8Vbmw+N`YHVF#P=wsmmGn7=Qn-HGhqDt+lQTSzOrvnmNYr(Td10i^${F6akfi z3NZ0ni-oxZx?Y4Q$Ed(lgx?rI2pW#~vdQrI2WI#tj5pjGezR`)eB;Mw1;{@z-z4}U z7ys20e5fd-`NLTOT^nDPOS=DR|J8~GbN-AGp!yMuR4jKf+#? zWub}vpF+ujTQvVdiEIA@9N~ZtJ_2~VuLge~(BJ|kt%2QBY^ zsBqw<`1mq=-~X~tUB-LhaRtlKdqB|JIvjoo|3e#nq~t)@UWd~e{0#zdn7zkl4-}%G znZ1YEos4xd*3DQq$IBn~hnbklV_L^MsHplzgyR8^pvQbZ_IBWl{{CBh?krDX|Ko-I zPx{yS`yWMU5j+3Fynunw6k+&13K0SY9Sl?5Tchh7zk-RH+pB}=U&j*wB`3N~v_j&C z06opI{2>gn;Z2s|^PqEyCFc=L|G=3E1)70?JgHB_Z(XHkxt!+?A9$)90~O5Ml_{1C z{16gY%+0Vd3eY`VVG;hGgQMaCukIxMn_K}k@t|1hc68{p(k=8aWCORu0FSVzam}%s0NJ*wZm%6))T`@x&c<<&cffyd z+MV%|L3~Ig=;v2`2Qti= zTH76-KmHE*lI|nsq^ui>|HqH*-y86ezN|~|J3F;c|G-WpS}Ud0CQS-csxVNS@>P5kfEO^;#vBOYWInZ1JW zP;{9Xmkwba>tihX*yptzMLrS>vxAWU>~*BLb^`~-WsPoiAxO`T+R|9*Y z8!G)LF{lGBa3mSA7e0K%RS znXR-rb+BTszg84$S&>orE&`+m5iDeZYK(%x!M@h2Da$@eY+$&+YMI4>GlQB@%gw;c zahlW?R;m1Yb-7Vpj;YHnxNs<4{7S76Bp<#W5Qr!M*0CTG^PMgY8!eA!{gaRrHSEut z^^z;%q3#W_X!`u0pMV}nXwbtS=D=sZMrBnSRyOm)Zrp;-vYy&3*+0Lk1_pe^>1U(X zvpac0kAGGoPaY)L&yw)R(=^JG$9(v!RxmyXf0PUVDZUW+0|y#a;6Cn6-pS!dN_er3 z-yU73(dt1}RHg5KaFmLpLw+tl^bV-fdYew%l9%P=ts=bhN-O^fW4ObWTP!)NT?$hR zh#K*>@jq`WZ3#cIUZc^9f5MXEl_PcuzmG=1bfS8VmJBxMI0~tfc4Qcp_S;m}JB2WW zzu;G=@yk;Ptlh16-@!iTPmF3J-KKf?$LjFw-M&Z%?$efOwCEk!$~M&U>F@34I4 zi71z!PsBsCx{dFfs}u6HR3--xc^Q)kn7pK1sgZ9-U!buguq4pe*pUjPc+|W2&5(k{ z>30$XOfSXwy>1`BJlw43)pd5p4y?z!TM;~P10%aJiYFy_8Kr}V`MTn_R^tgH{)uDq z8Z7%ntG+PdOQfye#2(&+?_;;&yPqZM!_&41-;40wbUVHW6yJvGtyh~O+S1g}^xB8! z^uJouS%2*tFa19L%=GbWqZ%hv@kI5WP&5+WgNLte?+SH<_f$886Z?{}Zd~Q{AwGOb zRIiv)Eqz%n!w63^!gZS(6N+b#m1;brMk%~^QXLH^kv;~CtGYXII$EU$X-9yH7Te39{hO%1-<|2(VWwjhVCJcze{@Bq3i(GDlW@`zic zZ%m`W^1-FwF{R5J#R1&T;wR!bJD~o-CM0k1-`gL?XT2dzaFqU@VIuAw{4=*V;9 z^jjIK!UB$&L6_r{r3G*$P9>UfcC!)h>bKy!0l$6ND2k7|{%}EtH)m4$sH^!cj1nnKU1Ytvz({k2|whS^A1s<&$`yYSNw_}=Kyh7 z;FF`_mZpkM4bGX=f3-M2!8(CoGW$@L&sMr{o)JRnUbH9#DlFzlKdE5fxvX7RgPcgT zix1uK1+P!Q8h_r*Mh#ZZjE&1-0}rSjW#{1ZqbB|3I{nb+2=S>^9M=$HlJR)-x~g#A z(~1A^ZI$Z}nFdzn&EdOLNhIB$Y2 zKGo~N2~E=B^;^XVyE=?~XW5~V%ESr3D3X}+SrE>^;Uk}v^`b?im*E%_z4sK+?;Hd4 z4`2G~;$;WBIs^OF`&COOV@okPfVV1Q{JPJQ$y=LO&0aV;fLGh19U*?je#zwCaANYZ zrFq^w?_!+X%R6KNn208pOzw$C7bV*Fgu6nC*U!OC5NZv3HP9yyux5h~h!+lF93P9cTJgq3-U<)yhIL-jhi3dlhff zpShEz9O_Pl+k3Fc^jb7HaUAQy&u|AGnC!>%`Q72f+q62*wi>`EV+R?u9WNxsqU(48 z2y`-BGC7oJjPA$#J@Ltbo=9Cger$j+?!u$qu+=CrQayqvJ( cT8hs9pY*v|{f*Xd&;Os~)c^P8|5gP43(l|tQ~&?~ diff --git a/MongoBookApis/obj/Debug/net5.0/ref/MongoBookApis.dll b/MongoBookApis/obj/Debug/net5.0/ref/MongoBookApis.dll deleted file mode 100644 index b25313123de59298baeb21a31ce71f55344ee172..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15360 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 2.13.2", - "Swashbuckle.AspNetCore >= 5.6.3" - ] - }, - "packageFolders": { - "/Users/hanieharabzadeh/.nuget/packages/": {} - }, - "project": { - "version": "1.0.0", - "restore": { - "projectUniqueName": "/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/MongoBookApis.csproj", - "projectName": "MongoBookApis", - "projectPath": "/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/MongoBookApis.csproj", - "packagesPath": "/Users/hanieharabzadeh/.nuget/packages/", - "outputPath": "/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/obj/", - "projectStyle": "PackageReference", - "configFilePaths": [ - "/Users/hanieharabzadeh/.config/NuGet/NuGet.Config" - ], - "originalTargetFrameworks": [ - "net5.0" - ], - "sources": { - "https://api.nuget.org/v3/index.json": {} - }, - "frameworks": { - "net5.0": { - "targetAlias": "net5.0", - "projectReferences": {} - } - }, - "warningProperties": { - "warnAsError": [ - "NU1605" - ] - } - }, - "frameworks": { - "net5.0": { - "targetAlias": "net5.0", - "dependencies": { - "MongoDB.Driver": { - "target": "Package", - "version": "[2.13.2, )" - }, - "Swashbuckle.AspNetCore": { - "target": "Package", - "version": "[5.6.3, )" - } - }, - "imports": [ - "net461", - "net462", - "net47", - "net471", - "net472", - "net48" - ], - "assetTargetFallback": true, - "warn": true, - "frameworkReferences": { - "Microsoft.AspNetCore.App": { - "privateAssets": "none" - }, - "Microsoft.NETCore.App": { - "privateAssets": "all" - } - }, - "runtimeIdentifierGraphPath": "/usr/local/share/dotnet/sdk/5.0.403/RuntimeIdentifierGraph.json" - } - } - } -} \ No newline at end of file diff --git a/MongoBookApis/obj/project.nuget.cache b/MongoBookApis/obj/project.nuget.cache deleted file mode 100644 index 9f1c571..0000000 --- a/MongoBookApis/obj/project.nuget.cache +++ /dev/null @@ -1,25 +0,0 @@ -{ - "version": 2, - "dgSpecHash": "YeVA/2FfMyL2oc8MaimmXNiBnHDnrOfDXZhg9RVx6lqYxAlhw5bkt3hgZyCQxdcLyKDNhRel2VtUujO5P1chIg==", - "success": true, - "projectFilePath": "/Users/hanieharabzadeh/Desktop/Developments/C#/Mongo/BookstoreAPIs/MongoBookApis/MongoBookApis.csproj", - "expectedPackageFiles": [ - "/Users/hanieharabzadeh/.nuget/packages/dnsclient/1.4.0/dnsclient.1.4.0.nupkg.sha512", - "/Users/hanieharabzadeh/.nuget/packages/microsoft.extensions.apidescription.server/3.0.0/microsoft.extensions.apidescription.server.3.0.0.nupkg.sha512", - "/Users/hanieharabzadeh/.nuget/packages/microsoft.netcore.platforms/2.1.2/microsoft.netcore.platforms.2.1.2.nupkg.sha512", - "/Users/hanieharabzadeh/.nuget/packages/microsoft.openapi/1.2.3/microsoft.openapi.1.2.3.nupkg.sha512", - "/Users/hanieharabzadeh/.nuget/packages/mongodb.bson/2.13.2/mongodb.bson.2.13.2.nupkg.sha512", - "/Users/hanieharabzadeh/.nuget/packages/mongodb.driver/2.13.2/mongodb.driver.2.13.2.nupkg.sha512", - "/Users/hanieharabzadeh/.nuget/packages/mongodb.driver.core/2.13.2/mongodb.driver.core.2.13.2.nupkg.sha512", - "/Users/hanieharabzadeh/.nuget/packages/mongodb.libmongocrypt/1.2.2/mongodb.libmongocrypt.1.2.2.nupkg.sha512", - "/Users/hanieharabzadeh/.nuget/packages/sharpcompress/0.23.0/sharpcompress.0.23.0.nupkg.sha512", - "/Users/hanieharabzadeh/.nuget/packages/swashbuckle.aspnetcore/5.6.3/swashbuckle.aspnetcore.5.6.3.nupkg.sha512", - "/Users/hanieharabzadeh/.nuget/packages/swashbuckle.aspnetcore.swagger/5.6.3/swashbuckle.aspnetcore.swagger.5.6.3.nupkg.sha512", - "/Users/hanieharabzadeh/.nuget/packages/swashbuckle.aspnetcore.swaggergen/5.6.3/swashbuckle.aspnetcore.swaggergen.5.6.3.nupkg.sha512", - "/Users/hanieharabzadeh/.nuget/packages/swashbuckle.aspnetcore.swaggerui/5.6.3/swashbuckle.aspnetcore.swaggerui.5.6.3.nupkg.sha512", - "/Users/hanieharabzadeh/.nuget/packages/system.buffers/4.5.1/system.buffers.4.5.1.nupkg.sha512", - "/Users/hanieharabzadeh/.nuget/packages/system.runtime.compilerservices.unsafe/5.0.0/system.runtime.compilerservices.unsafe.5.0.0.nupkg.sha512", - "/Users/hanieharabzadeh/.nuget/packages/system.text.encoding.codepages/4.5.1/system.text.encoding.codepages.4.5.1.nupkg.sha512" - ], - "logs": [] -} \ No newline at end of file