From 9ce006cf020d99a0e96217500c4457c12ca800ad Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Clint=20Air=C3=A9?= <111376518+clintaire@users.noreply.github.com> Date: Thu, 19 Sep 2024 19:45:42 +0100 Subject: [PATCH] Add PyGC project files --- PyGC/.github/workflows/python-checkers.yaml | 35 + PyGC/.gitignore | 5 + PyGC/.pygcconfig | 10 + PyGC/.venv/bin/Activate.ps1 | 247 + PyGC/.venv/bin/activate | 69 + PyGC/.venv/bin/activate.csh | 26 + PyGC/.venv/bin/activate.fish | 69 + PyGC/.venv/bin/normalizer | 8 + PyGC/.venv/bin/pip | 8 + PyGC/.venv/bin/pip3 | 8 + PyGC/.venv/bin/pip3.11 | 8 + PyGC/.venv/bin/py.test | 8 + PyGC/.venv/bin/pytest | 8 + PyGC/.venv/bin/python | 1 + PyGC/.venv/bin/python3 | 1 + PyGC/.venv/bin/python3.11 | 1 + .../Deprecated-1.2.14.dist-info/INSTALLER | 1 + .../Deprecated-1.2.14.dist-info/LICENSE.rst | 21 + .../Deprecated-1.2.14.dist-info/METADATA | 181 + .../Deprecated-1.2.14.dist-info/RECORD | 12 + .../Deprecated-1.2.14.dist-info/WHEEL | 6 + .../Deprecated-1.2.14.dist-info/top_level.txt | 1 + .../PyGithub-2.4.0.dist-info/COPYING | 674 ++ .../PyGithub-2.4.0.dist-info/COPYING.LESSER | 165 + .../PyGithub-2.4.0.dist-info/INSTALLER | 1 + .../PyGithub-2.4.0.dist-info/METADATA | 103 + .../PyGithub-2.4.0.dist-info/RECORD | 309 + .../PyGithub-2.4.0.dist-info/REQUESTED | 0 .../PyGithub-2.4.0.dist-info/WHEEL | 5 + .../PyGithub-2.4.0.dist-info/top_level.txt | 1 + .../PyJWT-2.9.0.dist-info/AUTHORS.rst | 7 + .../PyJWT-2.9.0.dist-info/INSTALLER | 1 + .../PyJWT-2.9.0.dist-info/LICENSE | 21 + .../PyJWT-2.9.0.dist-info/METADATA | 97 + .../PyJWT-2.9.0.dist-info/RECORD | 32 + .../site-packages/PyJWT-2.9.0.dist-info/WHEEL | 5 + .../PyJWT-2.9.0.dist-info/top_level.txt | 1 + .../PyNaCl-1.5.0.dist-info/INSTALLER | 1 + .../PyNaCl-1.5.0.dist-info/LICENSE | 174 + .../PyNaCl-1.5.0.dist-info/METADATA | 245 + .../PyNaCl-1.5.0.dist-info/RECORD | 68 + .../PyNaCl-1.5.0.dist-info/WHEEL | 7 + .../PyNaCl-1.5.0.dist-info/top_level.txt | 2 + ...i_backend.cpython-311-aarch64-linux-gnu.so | Bin 0 -> 1187880 bytes .../site-packages/_distutils_hack/__init__.py | 222 + .../site-packages/_distutils_hack/override.py | 1 + .../site-packages/_pytest/__init__.py | 13 + .../site-packages/_pytest/_argcomplete.py | 117 + .../site-packages/_pytest/_code/__init__.py | 26 + .../site-packages/_pytest/_code/code.py | 1403 +++ .../site-packages/_pytest/_code/source.py | 215 + .../site-packages/_pytest/_io/__init__.py | 10 + .../site-packages/_pytest/_io/pprint.py | 673 ++ .../site-packages/_pytest/_io/saferepr.py | 130 + .../_pytest/_io/terminalwriter.py | 274 + .../site-packages/_pytest/_io/wcwidth.py | 57 + .../site-packages/_pytest/_py/__init__.py | 0 .../site-packages/_pytest/_py/error.py | 111 + .../site-packages/_pytest/_py/path.py | 1475 +++ .../site-packages/_pytest/_version.py | 16 + .../_pytest/assertion/__init__.py | 192 + .../_pytest/assertion/rewrite.py | 1204 +++ .../_pytest/assertion/truncate.py | 117 + .../site-packages/_pytest/assertion/util.py | 609 ++ .../site-packages/_pytest/cacheprovider.py | 626 ++ .../site-packages/_pytest/capture.py | 1087 +++ .../site-packages/_pytest/compat.py | 351 + .../site-packages/_pytest/config/__init__.py | 1972 ++++ .../_pytest/config/argparsing.py | 551 ++ .../site-packages/_pytest/config/compat.py | 85 + .../_pytest/config/exceptions.py | 13 + .../site-packages/_pytest/config/findpaths.py | 228 + .../site-packages/_pytest/debugging.py | 385 + .../site-packages/_pytest/deprecated.py | 91 + .../site-packages/_pytest/doctest.py | 755 ++ .../site-packages/_pytest/faulthandler.py | 105 + .../site-packages/_pytest/fixtures.py | 1932 ++++ .../site-packages/_pytest/freeze_support.py | 45 + .../site-packages/_pytest/helpconfig.py | 276 + .../site-packages/_pytest/hookspec.py | 1333 +++ .../site-packages/_pytest/junitxml.py | 697 ++ .../site-packages/_pytest/legacypath.py | 473 + .../site-packages/_pytest/logging.py | 955 ++ .../python3.11/site-packages/_pytest/main.py | 1072 ++ .../site-packages/_pytest/mark/__init__.py | 292 + .../site-packages/_pytest/mark/expression.py | 333 + .../site-packages/_pytest/mark/structures.py | 615 ++ .../site-packages/_pytest/monkeypatch.py | 415 + .../python3.11/site-packages/_pytest/nodes.py | 766 ++ .../site-packages/_pytest/outcomes.py | 318 + .../site-packages/_pytest/pastebin.py | 113 + .../site-packages/_pytest/pathlib.py | 975 ++ .../python3.11/site-packages/_pytest/py.typed | 0 .../site-packages/_pytest/pytester.py | 1766 ++++ .../_pytest/pytester_assertions.py | 74 + .../site-packages/_pytest/python.py | 1679 ++++ .../site-packages/_pytest/python_api.py | 1020 ++ .../site-packages/_pytest/python_path.py | 26 + .../site-packages/_pytest/recwarn.py | 365 + .../site-packages/_pytest/reports.py | 636 ++ .../site-packages/_pytest/runner.py | 571 ++ .../python3.11/site-packages/_pytest/scope.py | 91 + .../site-packages/_pytest/setuponly.py | 102 + .../site-packages/_pytest/setupplan.py | 39 + .../site-packages/_pytest/skipping.py | 301 + .../python3.11/site-packages/_pytest/stash.py | 116 + .../site-packages/_pytest/stepwise.py | 125 + .../site-packages/_pytest/terminal.py | 1577 +++ .../site-packages/_pytest/threadexception.py | 97 + .../site-packages/_pytest/timing.py | 16 + .../site-packages/_pytest/tmpdir.py | 322 + .../site-packages/_pytest/unittest.py | 435 + .../_pytest/unraisableexception.py | 100 + .../site-packages/_pytest/warning_types.py | 166 + .../site-packages/_pytest/warnings.py | 151 + .../certifi-2024.8.30.dist-info/INSTALLER | 1 + .../certifi-2024.8.30.dist-info/LICENSE | 20 + .../certifi-2024.8.30.dist-info/METADATA | 67 + .../certifi-2024.8.30.dist-info/RECORD | 14 + .../certifi-2024.8.30.dist-info/WHEEL | 5 + .../certifi-2024.8.30.dist-info/top_level.txt | 1 + .../site-packages/certifi/__init__.py | 4 + .../site-packages/certifi/__main__.py | 12 + .../site-packages/certifi/cacert.pem | 4929 ++++++++++ .../python3.11/site-packages/certifi/core.py | 114 + .../python3.11/site-packages/certifi/py.typed | 0 .../cffi-1.17.1.dist-info/INSTALLER | 1 + .../cffi-1.17.1.dist-info/LICENSE | 26 + .../cffi-1.17.1.dist-info/METADATA | 40 + .../cffi-1.17.1.dist-info/RECORD | 48 + .../site-packages/cffi-1.17.1.dist-info/WHEEL | 6 + .../cffi-1.17.1.dist-info/entry_points.txt | 2 + .../cffi-1.17.1.dist-info/top_level.txt | 2 + .../python3.11/site-packages/cffi/__init__.py | 14 + .../site-packages/cffi/_cffi_errors.h | 149 + .../site-packages/cffi/_cffi_include.h | 389 + .../site-packages/cffi/_embedding.h | 550 ++ .../site-packages/cffi/_imp_emulation.py | 83 + .../site-packages/cffi/_shimmed_dist_utils.py | 45 + .../lib/python3.11/site-packages/cffi/api.py | 967 ++ .../site-packages/cffi/backend_ctypes.py | 1121 +++ .../site-packages/cffi/cffi_opcode.py | 187 + .../site-packages/cffi/commontypes.py | 82 + .../python3.11/site-packages/cffi/cparser.py | 1015 ++ .../python3.11/site-packages/cffi/error.py | 31 + .../site-packages/cffi/ffiplatform.py | 113 + .../lib/python3.11/site-packages/cffi/lock.py | 30 + .../python3.11/site-packages/cffi/model.py | 618 ++ .../site-packages/cffi/parse_c_type.h | 181 + .../site-packages/cffi/pkgconfig.py | 121 + .../site-packages/cffi/recompiler.py | 1598 +++ .../site-packages/cffi/setuptools_ext.py | 216 + .../site-packages/cffi/vengine_cpy.py | 1084 ++ .../site-packages/cffi/vengine_gen.py | 679 ++ .../python3.11/site-packages/cffi/verifier.py | 306 + .../INSTALLER | 1 + .../LICENSE | 4 +- .../METADATA | 683 ++ .../charset_normalizer-3.3.2.dist-info/RECORD | 35 + .../charset_normalizer-3.3.2.dist-info/WHEEL | 6 + .../entry_points.txt | 2 + .../top_level.txt | 1 + .../charset_normalizer/__init__.py | 46 + .../charset_normalizer/__main__.py | 4 + .../site-packages/charset_normalizer/api.py | 626 ++ .../site-packages/charset_normalizer/cd.py | 395 + .../charset_normalizer/cli/__init__.py | 6 + .../charset_normalizer/cli/__main__.py | 296 + .../charset_normalizer/constant.py | 1995 ++++ .../charset_normalizer/legacy.py | 54 + .../md.cpython-311-aarch64-linux-gnu.so | Bin 0 -> 69800 bytes .../site-packages/charset_normalizer/md.py | 615 ++ ...md__mypyc.cpython-311-aarch64-linux-gnu.so | Bin 0 -> 321776 bytes .../charset_normalizer/models.py | 340 + .../site-packages/charset_normalizer/py.typed | 0 .../site-packages/charset_normalizer/utils.py | 421 + .../charset_normalizer/version.py | 6 + .../cryptography-43.0.1.dist-info/INSTALLER | 1 + .../cryptography-43.0.1.dist-info/METADATA | 138 + .../cryptography-43.0.1.dist-info/RECORD | 173 + .../cryptography-43.0.1.dist-info/WHEEL | 5 + .../license_files/LICENSE | 3 + .../license_files/LICENSE.APACHE | 202 + .../license_files/LICENSE.BSD | 27 + .../site-packages/cryptography/__about__.py | 17 + .../site-packages/cryptography/__init__.py | 13 + .../site-packages/cryptography/exceptions.py | 52 + .../site-packages/cryptography/fernet.py | 215 + .../cryptography/hazmat/__init__.py | 13 + .../site-packages/cryptography/hazmat/_oid.py | 313 + .../cryptography/hazmat/backends/__init__.py | 13 + .../hazmat/backends/openssl/__init__.py | 9 + .../hazmat/backends/openssl/backend.py | 291 + .../cryptography/hazmat/bindings/__init__.py | 3 + .../hazmat/bindings/_rust.abi3.so | Bin 0 -> 9866904 bytes .../hazmat/bindings/_rust/__init__.pyi | 24 + .../hazmat/bindings/_rust/_openssl.pyi | 8 + .../hazmat/bindings/_rust/asn1.pyi | 7 + .../hazmat/bindings/_rust/exceptions.pyi | 17 + .../hazmat/bindings/_rust/ocsp.pyi | 23 + .../bindings/_rust/openssl/__init__.pyi | 71 + .../hazmat/bindings/_rust/openssl/aead.pyi | 103 + .../hazmat/bindings/_rust/openssl/ciphers.pyi | 38 + .../hazmat/bindings/_rust/openssl/cmac.pyi | 18 + .../hazmat/bindings/_rust/openssl/dh.pyi | 51 + .../hazmat/bindings/_rust/openssl/dsa.pyi | 41 + .../hazmat/bindings/_rust/openssl/ec.pyi | 52 + .../hazmat/bindings/_rust/openssl/ed25519.pyi | 12 + .../hazmat/bindings/_rust/openssl/ed448.pyi | 12 + .../hazmat/bindings/_rust/openssl/hashes.pyi | 17 + .../hazmat/bindings/_rust/openssl/hmac.pyi | 21 + .../hazmat/bindings/_rust/openssl/kdf.pyi | 22 + .../hazmat/bindings/_rust/openssl/keys.pyi | 33 + .../bindings/_rust/openssl/poly1305.pyi | 13 + .../hazmat/bindings/_rust/openssl/rsa.pyi | 55 + .../hazmat/bindings/_rust/openssl/x25519.pyi | 12 + .../hazmat/bindings/_rust/openssl/x448.pyi | 12 + .../hazmat/bindings/_rust/pkcs12.pyi | 46 + .../hazmat/bindings/_rust/pkcs7.pyi | 30 + .../hazmat/bindings/_rust/test_support.pyi | 29 + .../hazmat/bindings/_rust/x509.pyi | 108 + .../hazmat/bindings/openssl/__init__.py | 3 + .../hazmat/bindings/openssl/_conditional.py | 183 + .../hazmat/bindings/openssl/binding.py | 121 + .../cryptography/hazmat/decrepit/__init__.py | 5 + .../hazmat/decrepit/ciphers/__init__.py | 5 + .../hazmat/decrepit/ciphers/algorithms.py | 107 + .../hazmat/primitives/__init__.py | 3 + .../hazmat/primitives/_asymmetric.py | 19 + .../hazmat/primitives/_cipheralgorithm.py | 58 + .../hazmat/primitives/_serialization.py | 169 + .../hazmat/primitives/asymmetric/__init__.py | 3 + .../hazmat/primitives/asymmetric/dh.py | 135 + .../hazmat/primitives/asymmetric/dsa.py | 154 + .../hazmat/primitives/asymmetric/ec.py | 403 + .../hazmat/primitives/asymmetric/ed25519.py | 116 + .../hazmat/primitives/asymmetric/ed448.py | 118 + .../hazmat/primitives/asymmetric/padding.py | 113 + .../hazmat/primitives/asymmetric/rsa.py | 260 + .../hazmat/primitives/asymmetric/types.py | 111 + .../hazmat/primitives/asymmetric/utils.py | 24 + .../hazmat/primitives/asymmetric/x25519.py | 109 + .../hazmat/primitives/asymmetric/x448.py | 112 + .../hazmat/primitives/ciphers/__init__.py | 27 + .../hazmat/primitives/ciphers/aead.py | 23 + .../hazmat/primitives/ciphers/algorithms.py | 177 + .../hazmat/primitives/ciphers/base.py | 145 + .../hazmat/primitives/ciphers/modes.py | 268 + .../cryptography/hazmat/primitives/cmac.py | 10 + .../hazmat/primitives/constant_time.py | 14 + .../cryptography/hazmat/primitives/hashes.py | 242 + .../cryptography/hazmat/primitives/hmac.py | 13 + .../hazmat/primitives/kdf/__init__.py | 23 + .../hazmat/primitives/kdf/concatkdf.py | 124 + .../hazmat/primitives/kdf/hkdf.py | 101 + .../hazmat/primitives/kdf/kbkdf.py | 302 + .../hazmat/primitives/kdf/pbkdf2.py | 62 + .../hazmat/primitives/kdf/scrypt.py | 80 + .../hazmat/primitives/kdf/x963kdf.py | 61 + .../cryptography/hazmat/primitives/keywrap.py | 177 + .../cryptography/hazmat/primitives/padding.py | 204 + .../hazmat/primitives/poly1305.py | 11 + .../primitives/serialization/__init__.py | 63 + .../hazmat/primitives/serialization/base.py | 14 + .../hazmat/primitives/serialization/pkcs12.py | 156 + .../hazmat/primitives/serialization/pkcs7.py | 336 + .../hazmat/primitives/serialization/ssh.py | 1569 +++ .../hazmat/primitives/twofactor/__init__.py | 9 + .../hazmat/primitives/twofactor/hotp.py | 92 + .../hazmat/primitives/twofactor/totp.py | 50 + .../site-packages/cryptography/py.typed | 0 .../site-packages/cryptography/utils.py | 127 + .../cryptography/x509/__init__.py | 259 + .../site-packages/cryptography/x509/base.py | 1226 +++ .../x509/certificate_transparency.py | 97 + .../cryptography/x509/extensions.py | 2196 +++++ .../cryptography/x509/general_name.py | 281 + .../site-packages/cryptography/x509/name.py | 465 + .../site-packages/cryptography/x509/ocsp.py | 678 ++ .../site-packages/cryptography/x509/oid.py | 35 + .../cryptography/x509/verification.py | 28 + .../site-packages/deprecated/__init__.py | 15 + .../site-packages/deprecated/classic.py | 292 + .../site-packages/deprecated/sphinx.py | 262 + .../site-packages/distutils-precedence.pth | 1 + .../site-packages/github/AccessToken.py | 157 + .../site-packages/github/AdvisoryBase.py | 149 + .../site-packages/github/AdvisoryCredit.py | 114 + .../github/AdvisoryCreditDetailed.py | 91 + .../github/AdvisoryVulnerability.py | 175 + .../github/AdvisoryVulnerabilityPackage.py | 82 + .../site-packages/github/AppAuthentication.py | 57 + .../site-packages/github/ApplicationOAuth.py | 200 + .../site-packages/github/Artifact.py | 167 + .../python3.11/site-packages/github/Auth.py | 532 + .../site-packages/github/AuthenticatedUser.py | 1154 +++ .../site-packages/github/Authorization.py | 191 + .../github/AuthorizationApplication.py | 69 + .../site-packages/github/Autolink.py | 88 + .../python3.11/site-packages/github/Branch.py | 590 ++ .../site-packages/github/BranchProtection.py | 174 + .../python3.11/site-packages/github/CVSS.py | 79 + .../python3.11/site-packages/github/CWE.py | 72 + .../site-packages/github/CheckRun.py | 268 + .../github/CheckRunAnnotation.py | 110 + .../site-packages/github/CheckRunOutput.py | 90 + .../site-packages/github/CheckSuite.py | 285 + .../python3.11/site-packages/github/Clones.py | 87 + .../site-packages/github/CodeScanAlert.py | 160 + .../github/CodeScanAlertInstance.py | 114 + .../github/CodeScanAlertInstanceLocation.py | 94 + .../site-packages/github/CodeScanRule.py | 97 + .../site-packages/github/CodeScanTool.py | 86 + .../python3.11/site-packages/github/Commit.py | 313 + .../github/CommitCombinedStatus.py | 113 + .../site-packages/github/CommitComment.py | 225 + .../site-packages/github/CommitStats.py | 68 + .../site-packages/github/CommitStatus.py | 129 + .../site-packages/github/Comparison.py | 170 + .../python3.11/site-packages/github/Consts.py | 181 + .../site-packages/github/ContentFile.py | 194 + .../site-packages/github/DependabotAlert.py | 162 + .../github/DependabotAlertAdvisory.py | 69 + .../github/DependabotAlertDependency.py | 68 + .../github/DependabotAlertVulnerability.py | 75 + .../site-packages/github/Deployment.py | 270 + .../site-packages/github/DeploymentStatus.py | 171 + .../site-packages/github/Download.py | 249 + .../site-packages/github/Enterprise.py | 95 + .../github/EnterpriseConsumedLicenses.py | 108 + .../site-packages/github/Environment.py | 298 + .../EnvironmentDeploymentBranchPolicy.py | 79 + .../github/EnvironmentProtectionRule.py | 107 + .../EnvironmentProtectionRuleReviewer.py | 100 + .../python3.11/site-packages/github/Event.py | 122 + .../python3.11/site-packages/github/File.py | 133 + .../python3.11/site-packages/github/Gist.py | 312 + .../site-packages/github/GistComment.py | 130 + .../site-packages/github/GistFile.py | 95 + .../site-packages/github/GistHistoryState.py | 226 + .../site-packages/github/GitAuthor.py | 75 + .../site-packages/github/GitBlob.py | 98 + .../site-packages/github/GitCommit.py | 132 + .../site-packages/github/GitObject.py | 74 + .../python3.11/site-packages/github/GitRef.py | 107 + .../site-packages/github/GitRelease.py | 341 + .../site-packages/github/GitReleaseAsset.py | 178 + .../python3.11/site-packages/github/GitTag.py | 117 + .../site-packages/github/GitTree.py | 93 + .../site-packages/github/GitTreeElement.py | 95 + .../site-packages/github/GithubApp.py | 164 + .../site-packages/github/GithubException.py | 191 + .../site-packages/github/GithubIntegration.py | 303 + .../site-packages/github/GithubObject.py | 452 + .../site-packages/github/GithubRetry.py | 231 + .../site-packages/github/GitignoreTemplate.py | 72 + .../site-packages/github/GlobalAdvisory.py | 122 + .../python3.11/site-packages/github/Hook.py | 206 + .../site-packages/github/HookDelivery.py | 213 + .../site-packages/github/HookDescription.py | 84 + .../site-packages/github/HookResponse.py | 74 + .../site-packages/github/InputFileContent.py | 62 + .../site-packages/github/InputGitAuthor.py | 70 + .../github/InputGitTreeElement.py | 78 + .../site-packages/github/Installation.py | 146 + .../github/InstallationAuthorization.py | 99 + .../site-packages/github/Invitation.py | 135 + .../python3.11/site-packages/github/Issue.py | 583 ++ .../site-packages/github/IssueComment.py | 248 + .../site-packages/github/IssueEvent.py | 217 + .../site-packages/github/IssuePullRequest.py | 71 + .../python3.11/site-packages/github/Label.py | 122 + .../site-packages/github/License.py | 153 + .../site-packages/github/MainClass.py | 1015 ++ .../site-packages/github/Membership.py | 119 + .../site-packages/github/Migration.py | 196 + .../site-packages/github/Milestone.py | 213 + .../github/NamedEnterpriseUser.py | 203 + .../site-packages/github/NamedUser.py | 634 ++ .../site-packages/github/Notification.py | 171 + .../github/NotificationSubject.py | 89 + .../site-packages/github/Organization.py | 1535 +++ .../github/OrganizationCustomProperty.py | 169 + .../github/OrganizationDependabotAlert.py | 54 + .../github/OrganizationSecret.py | 137 + .../github/OrganizationVariable.py | 133 + .../site-packages/github/PaginatedList.py | 319 + .../python3.11/site-packages/github/Path.py | 94 + .../site-packages/github/Permissions.py | 97 + .../python3.11/site-packages/github/Plan.py | 96 + .../site-packages/github/Project.py | 245 + .../site-packages/github/ProjectCard.py | 218 + .../site-packages/github/ProjectColumn.py | 217 + .../site-packages/github/PublicKey.py | 100 + .../site-packages/github/PullRequest.py | 1013 ++ .../github/PullRequestComment.py | 271 + .../github/PullRequestMergeStatus.py | 81 + .../site-packages/github/PullRequestPart.py | 97 + .../site-packages/github/PullRequestReview.py | 159 + .../python3.11/site-packages/github/Rate.py | 95 + .../site-packages/github/RateLimit.py | 95 + .../site-packages/github/Reaction.py | 113 + .../site-packages/github/Referrer.py | 86 + .../site-packages/github/Repository.py | 4439 +++++++++ .../github/RepositoryAdvisory.py | 371 + .../site-packages/github/RepositoryKey.py | 146 + .../github/RepositoryPreferences.py | 76 + .../site-packages/github/Requester.py | 1023 ++ .../github/RequiredPullRequestReviews.py | 141 + .../github/RequiredStatusChecks.py | 86 + .../python3.11/site-packages/github/Secret.py | 123 + .../github/SecurityAndAnalysis.py | 121 + .../github/SecurityAndAnalysisFeature.py | 61 + .../github/SelfHostedActionsRunner.py | 101 + .../site-packages/github/SourceImport.py | 171 + .../site-packages/github/Stargazer.py | 86 + .../github/StatsCodeFrequency.py | 75 + .../github/StatsCommitActivity.py | 78 + .../site-packages/github/StatsContributor.py | 116 + .../github/StatsParticipation.py | 72 + .../site-packages/github/StatsPunchCard.py | 68 + .../python3.11/site-packages/github/Tag.py | 95 + .../python3.11/site-packages/github/Team.py | 472 + .../site-packages/github/TeamDiscussion.py | 205 + .../site-packages/github/TimelineEvent.py | 153 + .../github/TimelineEventSource.py | 79 + .../python3.11/site-packages/github/Topic.py | 135 + .../site-packages/github/UserKey.py | 108 + .../site-packages/github/Variable.py | 142 + .../python3.11/site-packages/github/View.py | 87 + .../site-packages/github/Workflow.py | 220 + .../site-packages/github/WorkflowJob.py | 241 + .../site-packages/github/WorkflowRun.py | 364 + .../site-packages/github/WorkflowStep.py | 109 + .../site-packages/github/__init__.py | 111 + .../python3.11/site-packages/github/py.typed | 0 .../idna-3.10.dist-info/INSTALLER | 1 + .../idna-3.10.dist-info/LICENSE.md | 31 + .../idna-3.10.dist-info/METADATA | 250 + .../site-packages/idna-3.10.dist-info/RECORD | 22 + .../site-packages/idna-3.10.dist-info/WHEEL | 4 + .../python3.11/site-packages/idna/__init__.py | 45 + .../python3.11/site-packages/idna/codec.py | 122 + .../python3.11/site-packages/idna/compat.py | 15 + .../lib/python3.11/site-packages/idna/core.py | 437 + .../python3.11/site-packages/idna/idnadata.py | 4243 ++++++++ .../site-packages/idna/intranges.py | 57 + .../site-packages/idna/package_data.py | 1 + .../python3.11/site-packages/idna/py.typed | 0 .../site-packages/idna/uts46data.py | 8681 +++++++++++++++++ .../iniconfig-2.0.0.dist-info/INSTALLER | 1 + .../iniconfig-2.0.0.dist-info/METADATA | 80 + .../iniconfig-2.0.0.dist-info/RECORD | 14 + .../iniconfig-2.0.0.dist-info/WHEEL | 4 + .../licenses/LICENSE | 19 + .../site-packages/iniconfig/__init__.py | 216 + .../site-packages/iniconfig/_parse.py | 82 + .../site-packages/iniconfig/_version.py | 4 + .../site-packages/iniconfig/exceptions.py | 20 + .../site-packages/iniconfig/py.typed | 0 .../python3.11/site-packages/jwt/__init__.py | 74 + .../site-packages/jwt/algorithms.py | 860 ++ .../python3.11/site-packages/jwt/api_jwk.py | 144 + .../python3.11/site-packages/jwt/api_jws.py | 335 + .../python3.11/site-packages/jwt/api_jwt.py | 377 + .../site-packages/jwt/exceptions.py | 74 + .../lib/python3.11/site-packages/jwt/help.py | 64 + .../site-packages/jwt/jwk_set_cache.py | 31 + .../site-packages/jwt/jwks_client.py | 124 + .../lib/python3.11/site-packages/jwt/py.typed | 0 .../lib/python3.11/site-packages/jwt/types.py | 5 + .../lib/python3.11/site-packages/jwt/utils.py | 145 + .../python3.11/site-packages/jwt/warnings.py | 2 + .../python3.11/site-packages/nacl/__init__.py | 39 + .../site-packages/nacl/_sodium.abi3.so | Bin 0 -> 1823144 bytes .../site-packages/nacl/bindings/__init__.py | 451 + .../nacl/bindings/crypto_aead.py | 559 ++ .../site-packages/nacl/bindings/crypto_box.py | 324 + .../nacl/bindings/crypto_core.py | 412 + .../nacl/bindings/crypto_generichash.py | 281 + .../nacl/bindings/crypto_hash.py | 63 + .../site-packages/nacl/bindings/crypto_kx.py | 200 + .../nacl/bindings/crypto_pwhash.py | 600 ++ .../nacl/bindings/crypto_scalarmult.py | 240 + .../nacl/bindings/crypto_secretbox.py | 86 + .../nacl/bindings/crypto_secretstream.py | 357 + .../nacl/bindings/crypto_shorthash.py | 81 + .../nacl/bindings/crypto_sign.py | 327 + .../nacl/bindings/randombytes.py | 51 + .../nacl/bindings/sodium_core.py | 33 + .../site-packages/nacl/bindings/utils.py | 141 + .../python3.11/site-packages/nacl/encoding.py | 105 + .../site-packages/nacl/exceptions.py | 88 + .../lib/python3.11/site-packages/nacl/hash.py | 182 + .../python3.11/site-packages/nacl/hashlib.py | 143 + .../python3.11/site-packages/nacl/public.py | 423 + .../site-packages/nacl/pwhash/__init__.py | 75 + .../site-packages/nacl/pwhash/_argon2.py | 49 + .../site-packages/nacl/pwhash/argon2i.py | 132 + .../site-packages/nacl/pwhash/argon2id.py | 135 + .../site-packages/nacl/pwhash/scrypt.py | 211 + .../python3.11/site-packages/nacl/py.typed | 0 .../python3.11/site-packages/nacl/secret.py | 305 + .../python3.11/site-packages/nacl/signing.py | 250 + .../python3.11/site-packages/nacl/utils.py | 88 + .../packaging-24.1.dist-info/INSTALLER | 1 + .../packaging-24.1.dist-info/LICENSE | 3 + .../packaging-24.1.dist-info/LICENSE.APACHE | 177 + .../packaging-24.1.dist-info/LICENSE.BSD | 23 + .../packaging-24.1.dist-info/METADATA | 102 + .../packaging-24.1.dist-info/RECORD | 36 + .../packaging-24.1.dist-info/WHEEL | 4 + .../site-packages/packaging/__init__.py | 15 + .../site-packages/packaging/_elffile.py | 110 + .../site-packages/packaging/_manylinux.py | 262 + .../site-packages/packaging/_musllinux.py | 85 + .../site-packages/packaging/_parser.py | 354 + .../site-packages/packaging/_structures.py | 61 + .../site-packages/packaging/_tokenizer.py | 194 + .../site-packages/packaging/markers.py | 325 + .../site-packages/packaging/metadata.py | 804 ++ .../site-packages/packaging/py.typed | 0 .../site-packages/packaging/requirements.py | 91 + .../site-packages/packaging/specifiers.py | 1009 ++ .../site-packages/packaging/tags.py | 568 ++ .../site-packages/packaging/utils.py | 174 + .../site-packages/packaging/version.py | 563 ++ .../pip-24.2.dist-info/AUTHORS.txt | 796 ++ .../pip-24.2.dist-info/INSTALLER | 1 + .../pip-24.2.dist-info/LICENSE.txt | 20 + .../site-packages/pip-24.2.dist-info/METADATA | 89 + .../site-packages/pip-24.2.dist-info/RECORD | 853 ++ .../pip-24.2.dist-info/REQUESTED | 0 .../site-packages/pip-24.2.dist-info/WHEEL | 5 + .../pip-24.2.dist-info/entry_points.txt | 3 + .../pip-24.2.dist-info/top_level.txt | 1 + .../python3.11/site-packages/pip/__init__.py | 13 + .../python3.11/site-packages/pip/__main__.py | 24 + .../site-packages/pip/__pip-runner__.py | 50 + .../site-packages/pip/_internal/__init__.py | 18 + .../site-packages/pip/_internal/build_env.py | 315 + .../site-packages/pip/_internal/cache.py | 290 + .../pip/_internal/cli/__init__.py | 4 + .../pip/_internal/cli/autocompletion.py | 176 + .../pip/_internal/cli/base_command.py | 231 + .../pip/_internal/cli/cmdoptions.py | 1075 ++ .../pip/_internal/cli/command_context.py | 27 + .../pip/_internal/cli/index_command.py | 170 + .../site-packages/pip/_internal/cli/main.py | 80 + .../pip/_internal/cli/main_parser.py | 134 + .../site-packages/pip/_internal/cli/parser.py | 294 + .../pip/_internal/cli/progress_bars.py | 94 + .../pip/_internal/cli/req_command.py | 329 + .../pip/_internal/cli/spinners.py | 159 + .../pip/_internal/cli/status_codes.py | 6 + .../pip/_internal/commands/__init__.py | 132 + .../pip/_internal/commands/cache.py | 225 + .../pip/_internal/commands/check.py | 67 + .../pip/_internal/commands/completion.py | 130 + .../pip/_internal/commands/configuration.py | 280 + .../pip/_internal/commands/debug.py | 201 + .../pip/_internal/commands/download.py | 146 + .../pip/_internal/commands/freeze.py | 109 + .../pip/_internal/commands/hash.py | 59 + .../pip/_internal/commands/help.py | 41 + .../pip/_internal/commands/index.py | 139 + .../pip/_internal/commands/inspect.py | 92 + .../pip/_internal/commands/install.py | 783 ++ .../pip/_internal/commands/list.py | 375 + .../pip/_internal/commands/search.py | 172 + .../pip/_internal/commands/show.py | 217 + .../pip/_internal/commands/uninstall.py | 114 + .../pip/_internal/commands/wheel.py | 182 + .../pip/_internal/configuration.py | 383 + .../pip/_internal/distributions/__init__.py | 21 + .../pip/_internal/distributions/base.py | 53 + .../pip/_internal/distributions/installed.py | 29 + .../pip/_internal/distributions/sdist.py | 158 + .../pip/_internal/distributions/wheel.py | 42 + .../site-packages/pip/_internal/exceptions.py | 777 ++ .../pip/_internal/index/__init__.py | 2 + .../pip/_internal/index/collector.py | 494 + .../pip/_internal/index/package_finder.py | 1020 ++ .../pip/_internal/index/sources.py | 285 + .../pip/_internal/locations/__init__.py | 456 + .../pip/_internal/locations/_distutils.py | 172 + .../pip/_internal/locations/_sysconfig.py | 214 + .../pip/_internal/locations/base.py | 81 + .../site-packages/pip/_internal/main.py | 12 + .../pip/_internal/metadata/__init__.py | 128 + .../pip/_internal/metadata/_json.py | 84 + .../pip/_internal/metadata/base.py | 688 ++ .../_internal/metadata/importlib/__init__.py | 6 + .../_internal/metadata/importlib/_compat.py | 85 + .../_internal/metadata/importlib/_dists.py | 221 + .../pip/_internal/metadata/importlib/_envs.py | 189 + .../pip/_internal/metadata/pkg_resources.py | 301 + .../pip/_internal/models/__init__.py | 2 + .../pip/_internal/models/candidate.py | 25 + .../pip/_internal/models/direct_url.py | 224 + .../pip/_internal/models/format_control.py | 78 + .../pip/_internal/models/index.py | 28 + .../_internal/models/installation_report.py | 56 + .../pip/_internal/models/link.py | 590 ++ .../pip/_internal/models/scheme.py | 25 + .../pip/_internal/models/search_scope.py | 127 + .../pip/_internal/models/selection_prefs.py | 53 + .../pip/_internal/models/target_python.py | 121 + .../pip/_internal/models/wheel.py | 93 + .../pip/_internal/network/__init__.py | 2 + .../pip/_internal/network/auth.py | 566 ++ .../pip/_internal/network/cache.py | 106 + .../pip/_internal/network/download.py | 187 + .../pip/_internal/network/lazy_wheel.py | 210 + .../pip/_internal/network/session.py | 522 + .../pip/_internal/network/utils.py | 98 + .../pip/_internal/network/xmlrpc.py | 62 + .../pip/_internal/operations/__init__.py | 0 .../_internal/operations/build/__init__.py | 0 .../operations/build/build_tracker.py | 138 + .../_internal/operations/build/metadata.py | 39 + .../operations/build/metadata_editable.py | 41 + .../operations/build/metadata_legacy.py | 74 + .../pip/_internal/operations/build/wheel.py | 37 + .../operations/build/wheel_editable.py | 46 + .../operations/build/wheel_legacy.py | 102 + .../pip/_internal/operations/check.py | 181 + .../pip/_internal/operations/freeze.py | 258 + .../_internal/operations/install/__init__.py | 2 + .../operations/install/editable_legacy.py | 47 + .../pip/_internal/operations/install/wheel.py | 741 ++ .../pip/_internal/operations/prepare.py | 732 ++ .../site-packages/pip/_internal/pyproject.py | 185 + .../pip/_internal/req/__init__.py | 90 + .../pip/_internal/req/constructors.py | 560 ++ .../pip/_internal/req/req_file.py | 551 ++ .../pip/_internal/req/req_install.py | 934 ++ .../pip/_internal/req/req_set.py | 82 + .../pip/_internal/req/req_uninstall.py | 633 ++ .../pip/_internal/resolution/__init__.py | 0 .../pip/_internal/resolution/base.py | 20 + .../_internal/resolution/legacy/__init__.py | 0 .../_internal/resolution/legacy/resolver.py | 597 ++ .../resolution/resolvelib/__init__.py | 0 .../_internal/resolution/resolvelib/base.py | 139 + .../resolution/resolvelib/candidates.py | 569 ++ .../resolution/resolvelib/factory.py | 817 ++ .../resolution/resolvelib/found_candidates.py | 174 + .../resolution/resolvelib/provider.py | 258 + .../resolution/resolvelib/reporter.py | 81 + .../resolution/resolvelib/requirements.py | 245 + .../resolution/resolvelib/resolver.py | 317 + .../pip/_internal/self_outdated_check.py | 244 + .../pip/_internal/utils/__init__.py | 0 .../pip/_internal/utils/_jaraco_text.py | 109 + .../site-packages/pip/_internal/utils/_log.py | 38 + .../pip/_internal/utils/appdirs.py | 52 + .../pip/_internal/utils/compat.py | 79 + .../pip/_internal/utils/compatibility_tags.py | 165 + .../pip/_internal/utils/datetime.py | 11 + .../pip/_internal/utils/deprecation.py | 124 + .../pip/_internal/utils/direct_url_helpers.py | 87 + .../pip/_internal/utils/egg_link.py | 80 + .../pip/_internal/utils/encoding.py | 36 + .../pip/_internal/utils/entrypoints.py | 84 + .../pip/_internal/utils/filesystem.py | 149 + .../pip/_internal/utils/filetypes.py | 27 + .../pip/_internal/utils/glibc.py | 101 + .../pip/_internal/utils/hashes.py | 147 + .../pip/_internal/utils/logging.py | 347 + .../site-packages/pip/_internal/utils/misc.py | 777 ++ .../pip/_internal/utils/packaging.py | 57 + .../pip/_internal/utils/retry.py | 42 + .../pip/_internal/utils/setuptools_build.py | 146 + .../pip/_internal/utils/subprocess.py | 245 + .../pip/_internal/utils/temp_dir.py | 296 + .../pip/_internal/utils/unpacking.py | 337 + .../site-packages/pip/_internal/utils/urls.py | 55 + .../pip/_internal/utils/virtualenv.py | 104 + .../pip/_internal/utils/wheel.py | 134 + .../pip/_internal/vcs/__init__.py | 15 + .../site-packages/pip/_internal/vcs/bazaar.py | 112 + .../site-packages/pip/_internal/vcs/git.py | 527 + .../pip/_internal/vcs/mercurial.py | 163 + .../pip/_internal/vcs/subversion.py | 324 + .../pip/_internal/vcs/versioncontrol.py | 688 ++ .../pip/_internal/wheel_builder.py | 354 + .../site-packages/pip/_vendor/__init__.py | 116 + .../pip/_vendor/cachecontrol/__init__.py | 28 + .../pip/_vendor/cachecontrol/_cmd.py | 70 + .../pip/_vendor/cachecontrol/adapter.py | 161 + .../pip/_vendor/cachecontrol/cache.py | 74 + .../_vendor/cachecontrol/caches/__init__.py | 8 + .../_vendor/cachecontrol/caches/file_cache.py | 182 + .../cachecontrol/caches/redis_cache.py | 48 + .../pip/_vendor/cachecontrol/controller.py | 499 + .../pip/_vendor/cachecontrol/filewrapper.py | 119 + .../pip/_vendor/cachecontrol/heuristics.py | 154 + .../pip/_vendor/cachecontrol/py.typed | 0 .../pip/_vendor/cachecontrol/serialize.py | 146 + .../pip/_vendor/cachecontrol/wrapper.py | 43 + .../pip/_vendor/certifi/__init__.py | 4 + .../pip/_vendor/certifi/__main__.py | 12 + .../pip/_vendor/certifi/cacert.pem | 4798 +++++++++ .../site-packages/pip/_vendor/certifi/core.py | 114 + .../pip/_vendor/certifi/py.typed | 0 .../pip/_vendor/distlib/__init__.py | 33 + .../pip/_vendor/distlib/compat.py | 1138 +++ .../pip/_vendor/distlib/database.py | 1359 +++ .../pip/_vendor/distlib/index.py | 508 + .../pip/_vendor/distlib/locators.py | 1303 +++ .../pip/_vendor/distlib/manifest.py | 384 + .../pip/_vendor/distlib/markers.py | 167 + .../pip/_vendor/distlib/metadata.py | 1068 ++ .../pip/_vendor/distlib/resources.py | 358 + .../pip/_vendor/distlib/scripts.py | 466 + .../site-packages/pip/_vendor/distlib/t32.exe | Bin 0 -> 97792 bytes .../pip/_vendor/distlib/t64-arm.exe | Bin 0 -> 182784 bytes .../site-packages/pip/_vendor/distlib/t64.exe | Bin 0 -> 108032 bytes .../site-packages/pip/_vendor/distlib/util.py | 2025 ++++ .../pip/_vendor/distlib/version.py | 751 ++ .../site-packages/pip/_vendor/distlib/w32.exe | Bin 0 -> 91648 bytes .../pip/_vendor/distlib/w64-arm.exe | Bin 0 -> 168448 bytes .../site-packages/pip/_vendor/distlib/w64.exe | Bin 0 -> 101888 bytes .../pip/_vendor/distlib/wheel.py | 1099 +++ .../pip/_vendor/distro/__init__.py | 54 + .../pip/_vendor/distro/__main__.py | 4 + .../pip/_vendor/distro/distro.py | 1403 +++ .../site-packages/pip/_vendor/distro/py.typed | 0 .../pip/_vendor/idna/__init__.py | 44 + .../site-packages/pip/_vendor/idna/codec.py | 118 + .../site-packages/pip/_vendor/idna/compat.py | 13 + .../site-packages/pip/_vendor/idna/core.py | 395 + .../pip/_vendor/idna/idnadata.py | 4245 ++++++++ .../pip/_vendor/idna/intranges.py | 54 + .../pip/_vendor/idna/package_data.py | 2 + .../site-packages/pip/_vendor/idna/py.typed | 0 .../pip/_vendor/idna/uts46data.py | 8598 ++++++++++++++++ .../pip/_vendor/msgpack/__init__.py | 55 + .../pip/_vendor/msgpack/exceptions.py | 48 + .../site-packages/pip/_vendor/msgpack/ext.py | 168 + .../pip/_vendor/msgpack/fallback.py | 951 ++ .../pip/_vendor/packaging/__init__.py | 15 + .../pip/_vendor/packaging/_elffile.py | 110 + .../pip/_vendor/packaging/_manylinux.py | 262 + .../pip/_vendor/packaging/_musllinux.py | 85 + .../pip/_vendor/packaging/_parser.py | 354 + .../pip/_vendor/packaging/_structures.py | 61 + .../pip/_vendor/packaging/_tokenizer.py | 194 + .../pip/_vendor/packaging/markers.py | 325 + .../pip/_vendor/packaging/metadata.py | 804 ++ .../pip/_vendor/packaging/py.typed | 0 .../pip/_vendor/packaging/requirements.py | 91 + .../pip/_vendor/packaging/specifiers.py | 1009 ++ .../pip/_vendor/packaging/tags.py | 568 ++ .../pip/_vendor/packaging/utils.py | 174 + .../pip/_vendor/packaging/version.py | 563 ++ .../pip/_vendor/pkg_resources/__init__.py | 3676 +++++++ .../pip/_vendor/platformdirs/__init__.py | 627 ++ .../pip/_vendor/platformdirs/__main__.py | 55 + .../pip/_vendor/platformdirs/android.py | 249 + .../pip/_vendor/platformdirs/api.py | 292 + .../pip/_vendor/platformdirs/macos.py | 130 + .../pip/_vendor/platformdirs/py.typed | 0 .../pip/_vendor/platformdirs/unix.py | 275 + .../pip/_vendor/platformdirs/version.py | 16 + .../pip/_vendor/platformdirs/windows.py | 272 + .../pip/_vendor/pygments/__init__.py | 82 + .../pip/_vendor/pygments/__main__.py | 17 + .../pip/_vendor/pygments/cmdline.py | 668 ++ .../pip/_vendor/pygments/console.py | 70 + .../pip/_vendor/pygments/filter.py | 70 + .../pip/_vendor/pygments/filters/__init__.py | 940 ++ .../pip/_vendor/pygments/formatter.py | 129 + .../_vendor/pygments/formatters/__init__.py | 157 + .../_vendor/pygments/formatters/_mapping.py | 23 + .../pip/_vendor/pygments/formatters/bbcode.py | 108 + .../pip/_vendor/pygments/formatters/groff.py | 170 + .../pip/_vendor/pygments/formatters/html.py | 987 ++ .../pip/_vendor/pygments/formatters/img.py | 685 ++ .../pip/_vendor/pygments/formatters/irc.py | 154 + .../pip/_vendor/pygments/formatters/latex.py | 518 + .../pip/_vendor/pygments/formatters/other.py | 160 + .../pygments/formatters/pangomarkup.py | 83 + .../pip/_vendor/pygments/formatters/rtf.py | 349 + .../pip/_vendor/pygments/formatters/svg.py | 185 + .../_vendor/pygments/formatters/terminal.py | 127 + .../pygments/formatters/terminal256.py | 338 + .../pip/_vendor/pygments/lexer.py | 963 ++ .../pip/_vendor/pygments/lexers/__init__.py | 362 + .../pip/_vendor/pygments/lexers/_mapping.py | 589 ++ .../pip/_vendor/pygments/lexers/python.py | 1198 +++ .../pip/_vendor/pygments/modeline.py | 43 + .../pip/_vendor/pygments/plugin.py | 72 + .../pip/_vendor/pygments/regexopt.py | 91 + .../pip/_vendor/pygments/scanner.py | 104 + .../pip/_vendor/pygments/sphinxext.py | 247 + .../pip/_vendor/pygments/style.py | 203 + .../pip/_vendor/pygments/styles/__init__.py | 61 + .../pip/_vendor/pygments/styles/_mapping.py | 54 + .../pip/_vendor/pygments/token.py | 214 + .../pip/_vendor/pygments/unistring.py | 153 + .../pip/_vendor/pygments/util.py | 324 + .../pip/_vendor/pyproject_hooks/__init__.py | 23 + .../pip/_vendor/pyproject_hooks/_compat.py | 8 + .../pip/_vendor/pyproject_hooks/_impl.py | 330 + .../pyproject_hooks/_in_process/__init__.py | 18 + .../_in_process/_in_process.py | 353 + .../pip/_vendor/requests/__init__.py | 179 + .../pip/_vendor/requests/__version__.py | 14 + .../pip/_vendor/requests/_internal_utils.py | 50 + .../pip/_vendor/requests/adapters.py | 719 ++ .../site-packages/pip/_vendor/requests/api.py | 157 + .../pip/_vendor/requests/auth.py | 314 + .../pip/_vendor/requests/certs.py | 24 + .../pip/_vendor/requests/compat.py | 78 + .../pip/_vendor/requests/cookies.py | 561 ++ .../pip/_vendor/requests/exceptions.py | 151 + .../pip/_vendor/requests/help.py | 127 + .../pip/_vendor/requests/hooks.py | 33 + .../pip/_vendor/requests/models.py | 1037 ++ .../pip/_vendor/requests/packages.py | 25 + .../pip/_vendor/requests/sessions.py | 831 ++ .../pip/_vendor/requests/status_codes.py | 128 + .../pip/_vendor/requests/structures.py | 99 + .../pip/_vendor/requests/utils.py | 1096 +++ .../pip/_vendor/resolvelib/__init__.py | 26 + .../pip/_vendor/resolvelib/compat/__init__.py | 0 .../resolvelib/compat/collections_abc.py | 6 + .../pip/_vendor/resolvelib/providers.py | 133 + .../pip/_vendor/resolvelib/py.typed | 0 .../pip/_vendor/resolvelib/reporters.py | 43 + .../pip/_vendor/resolvelib/resolvers.py | 547 ++ .../pip/_vendor/resolvelib/structs.py | 170 + .../pip/_vendor/rich/__init__.py | 177 + .../pip/_vendor/rich/__main__.py | 273 + .../pip/_vendor/rich/_cell_widths.py | 454 + .../pip/_vendor/rich/_emoji_codes.py | 3610 +++++++ .../pip/_vendor/rich/_emoji_replace.py | 32 + .../pip/_vendor/rich/_export_format.py | 76 + .../pip/_vendor/rich/_extension.py | 10 + .../site-packages/pip/_vendor/rich/_fileno.py | 24 + .../pip/_vendor/rich/_inspect.py | 270 + .../pip/_vendor/rich/_log_render.py | 94 + .../site-packages/pip/_vendor/rich/_loop.py | 43 + .../pip/_vendor/rich/_null_file.py | 69 + .../pip/_vendor/rich/_palettes.py | 309 + .../site-packages/pip/_vendor/rich/_pick.py | 17 + .../site-packages/pip/_vendor/rich/_ratio.py | 159 + .../pip/_vendor/rich/_spinners.py | 482 + .../site-packages/pip/_vendor/rich/_stack.py | 16 + .../site-packages/pip/_vendor/rich/_timer.py | 19 + .../pip/_vendor/rich/_win32_console.py | 662 ++ .../pip/_vendor/rich/_windows.py | 71 + .../pip/_vendor/rich/_windows_renderer.py | 56 + .../site-packages/pip/_vendor/rich/_wrap.py | 93 + .../site-packages/pip/_vendor/rich/abc.py | 33 + .../site-packages/pip/_vendor/rich/align.py | 311 + .../site-packages/pip/_vendor/rich/ansi.py | 240 + .../site-packages/pip/_vendor/rich/bar.py | 93 + .../site-packages/pip/_vendor/rich/box.py | 480 + .../site-packages/pip/_vendor/rich/cells.py | 167 + .../site-packages/pip/_vendor/rich/color.py | 621 ++ .../pip/_vendor/rich/color_triplet.py | 38 + .../site-packages/pip/_vendor/rich/columns.py | 187 + .../site-packages/pip/_vendor/rich/console.py | 2633 +++++ .../pip/_vendor/rich/constrain.py | 37 + .../pip/_vendor/rich/containers.py | 167 + .../site-packages/pip/_vendor/rich/control.py | 225 + .../pip/_vendor/rich/default_styles.py | 190 + .../pip/_vendor/rich/diagnose.py | 37 + .../site-packages/pip/_vendor/rich/emoji.py | 96 + .../site-packages/pip/_vendor/rich/errors.py | 34 + .../pip/_vendor/rich/file_proxy.py | 57 + .../pip/_vendor/rich/filesize.py | 89 + .../pip/_vendor/rich/highlighter.py | 232 + .../site-packages/pip/_vendor/rich/json.py | 139 + .../site-packages/pip/_vendor/rich/jupyter.py | 101 + .../site-packages/pip/_vendor/rich/layout.py | 442 + .../site-packages/pip/_vendor/rich/live.py | 375 + .../pip/_vendor/rich/live_render.py | 112 + .../site-packages/pip/_vendor/rich/logging.py | 289 + .../site-packages/pip/_vendor/rich/markup.py | 251 + .../site-packages/pip/_vendor/rich/measure.py | 151 + .../site-packages/pip/_vendor/rich/padding.py | 141 + .../site-packages/pip/_vendor/rich/pager.py | 34 + .../site-packages/pip/_vendor/rich/palette.py | 100 + .../site-packages/pip/_vendor/rich/panel.py | 312 + .../site-packages/pip/_vendor/rich/pretty.py | 995 ++ .../pip/_vendor/rich/progress.py | 1699 ++++ .../pip/_vendor/rich/progress_bar.py | 223 + .../site-packages/pip/_vendor/rich/prompt.py | 375 + .../pip/_vendor/rich/protocol.py | 42 + .../site-packages/pip/_vendor/rich/py.typed | 0 .../site-packages/pip/_vendor/rich/region.py | 10 + .../site-packages/pip/_vendor/rich/repr.py | 149 + .../site-packages/pip/_vendor/rich/rule.py | 130 + .../site-packages/pip/_vendor/rich/scope.py | 86 + .../site-packages/pip/_vendor/rich/screen.py | 54 + .../site-packages/pip/_vendor/rich/segment.py | 738 ++ .../site-packages/pip/_vendor/rich/spinner.py | 137 + .../site-packages/pip/_vendor/rich/status.py | 131 + .../site-packages/pip/_vendor/rich/style.py | 796 ++ .../site-packages/pip/_vendor/rich/styled.py | 42 + .../site-packages/pip/_vendor/rich/syntax.py | 958 ++ .../site-packages/pip/_vendor/rich/table.py | 1000 ++ .../pip/_vendor/rich/terminal_theme.py | 153 + .../site-packages/pip/_vendor/rich/text.py | 1357 +++ .../site-packages/pip/_vendor/rich/theme.py | 115 + .../site-packages/pip/_vendor/rich/themes.py | 5 + .../pip/_vendor/rich/traceback.py | 753 ++ .../site-packages/pip/_vendor/rich/tree.py | 249 + .../pip/_vendor/tomli/__init__.py | 11 + .../pip/_vendor/tomli/_parser.py | 691 ++ .../site-packages/pip/_vendor/tomli/_re.py | 107 + .../site-packages/pip/_vendor/tomli/_types.py | 10 + .../site-packages/pip/_vendor/tomli/py.typed | 1 + .../pip/_vendor/truststore/__init__.py | 13 + .../pip/_vendor/truststore/_api.py | 313 + .../pip/_vendor/truststore/_macos.py | 499 + .../pip/_vendor/truststore/_openssl.py | 66 + .../pip/_vendor/truststore/_ssl_constants.py | 31 + .../pip/_vendor/truststore/_windows.py | 564 ++ .../pip/_vendor/truststore/py.typed | 0 .../pip/_vendor/typing_extensions.py | 3641 +++++++ .../pip/_vendor/urllib3/__init__.py | 102 + .../pip/_vendor/urllib3/_collections.py | 355 + .../pip/_vendor/urllib3/_version.py | 2 + .../pip/_vendor/urllib3/connection.py | 572 ++ .../pip/_vendor/urllib3/connectionpool.py | 1137 +++ .../pip/_vendor/urllib3/contrib/__init__.py | 0 .../urllib3/contrib/_appengine_environ.py | 36 + .../contrib/_securetransport/__init__.py | 0 .../contrib/_securetransport/bindings.py | 519 + .../contrib/_securetransport/low_level.py | 397 + .../pip/_vendor/urllib3/contrib/appengine.py | 314 + .../pip/_vendor/urllib3/contrib/ntlmpool.py | 130 + .../pip/_vendor/urllib3/contrib/pyopenssl.py | 518 + .../urllib3/contrib/securetransport.py | 920 ++ .../pip/_vendor/urllib3/contrib/socks.py | 216 + .../pip/_vendor/urllib3/exceptions.py | 323 + .../pip/_vendor/urllib3/fields.py | 274 + .../pip/_vendor/urllib3/filepost.py | 98 + .../pip/_vendor/urllib3/packages/__init__.py | 0 .../urllib3/packages/backports/__init__.py | 0 .../urllib3/packages/backports/makefile.py | 51 + .../packages/backports/weakref_finalize.py | 155 + .../pip/_vendor/urllib3/packages/six.py | 1076 ++ .../pip/_vendor/urllib3/poolmanager.py | 540 + .../pip/_vendor/urllib3/request.py | 191 + .../pip/_vendor/urllib3/response.py | 879 ++ .../pip/_vendor/urllib3/util/__init__.py | 49 + .../pip/_vendor/urllib3/util/connection.py | 149 + .../pip/_vendor/urllib3/util/proxy.py | 57 + .../pip/_vendor/urllib3/util/queue.py | 22 + .../pip/_vendor/urllib3/util/request.py | 137 + .../pip/_vendor/urllib3/util/response.py | 107 + .../pip/_vendor/urllib3/util/retry.py | 620 ++ .../pip/_vendor/urllib3/util/ssl_.py | 495 + .../urllib3/util/ssl_match_hostname.py | 159 + .../pip/_vendor/urllib3/util/ssltransport.py | 221 + .../pip/_vendor/urllib3/util/timeout.py | 271 + .../pip/_vendor/urllib3/util/url.py | 435 + .../pip/_vendor/urllib3/util/wait.py | 152 + .../site-packages/pip/_vendor/vendor.txt | 18 + .../lib/python3.11/site-packages/pip/py.typed | 4 + .../site-packages/pkg_resources/__init__.py | 3282 +++++++ .../pkg_resources/_vendor/__init__.py | 0 .../_vendor/importlib_resources/__init__.py | 36 + .../_vendor/importlib_resources/_adapters.py | 170 + .../_vendor/importlib_resources/_common.py | 104 + .../_vendor/importlib_resources/_compat.py | 98 + .../_vendor/importlib_resources/_itertools.py | 35 + .../_vendor/importlib_resources/_legacy.py | 121 + .../_vendor/importlib_resources/abc.py | 137 + .../_vendor/importlib_resources/readers.py | 122 + .../_vendor/importlib_resources/simple.py | 116 + .../pkg_resources/_vendor/jaraco/__init__.py | 0 .../pkg_resources/_vendor/jaraco/context.py | 253 + .../pkg_resources/_vendor/jaraco/functools.py | 525 + .../_vendor/jaraco/text/__init__.py | 599 ++ .../_vendor/more_itertools/__init__.py | 6 + .../_vendor/more_itertools/more.py | 4346 +++++++++ .../_vendor/more_itertools/recipes.py | 841 ++ .../_vendor/packaging/__about__.py | 26 + .../_vendor/packaging/__init__.py | 25 + .../_vendor/packaging/_manylinux.py | 301 + .../_vendor/packaging/_musllinux.py | 136 + .../_vendor/packaging/_structures.py | 61 + .../_vendor/packaging/markers.py | 304 + .../_vendor/packaging/requirements.py | 146 + .../_vendor/packaging/specifiers.py | 802 ++ .../pkg_resources/_vendor/packaging/tags.py | 487 + .../pkg_resources/_vendor/packaging/utils.py | 136 + .../_vendor/packaging/version.py | 504 + .../_vendor/platformdirs/__init__.py | 342 + .../_vendor/platformdirs/__main__.py | 46 + .../_vendor/platformdirs/android.py | 120 + .../pkg_resources/_vendor/platformdirs/api.py | 156 + .../_vendor/platformdirs/macos.py | 64 + .../_vendor/platformdirs/unix.py | 181 + .../_vendor/platformdirs/version.py | 4 + .../_vendor/platformdirs/windows.py | 184 + .../_vendor/pyparsing/__init__.py | 331 + .../_vendor/pyparsing/actions.py | 207 + .../pkg_resources/_vendor/pyparsing/common.py | 424 + .../pkg_resources/_vendor/pyparsing/core.py | 5814 +++++++++++ .../_vendor/pyparsing/diagram/__init__.py | 642 ++ .../_vendor/pyparsing/exceptions.py | 267 + .../_vendor/pyparsing/helpers.py | 1088 +++ .../_vendor/pyparsing/results.py | 760 ++ .../_vendor/pyparsing/testing.py | 331 + .../_vendor/pyparsing/unicode.py | 352 + .../pkg_resources/_vendor/pyparsing/util.py | 235 + .../_vendor/typing_extensions.py | 2209 +++++ .../pkg_resources/_vendor/zipp.py | 329 + .../pkg_resources/extern/__init__.py | 81 + .../pluggy-1.5.0.dist-info/INSTALLER | 1 + .../pluggy-1.5.0.dist-info/LICENSE | 21 + .../pluggy-1.5.0.dist-info/METADATA | 155 + .../pluggy-1.5.0.dist-info/RECORD | 23 + .../pluggy-1.5.0.dist-info/WHEEL | 5 + .../pluggy-1.5.0.dist-info/top_level.txt | 1 + .../site-packages/pluggy/__init__.py | 37 + .../site-packages/pluggy/_callers.py | 182 + .../python3.11/site-packages/pluggy/_hooks.py | 715 ++ .../site-packages/pluggy/_manager.py | 528 + .../site-packages/pluggy/_result.py | 104 + .../site-packages/pluggy/_tracing.py | 73 + .../site-packages/pluggy/_version.py | 16 + .../site-packages/pluggy/_warnings.py | 27 + .../python3.11/site-packages/pluggy/py.typed | 0 PyGC/.venv/lib/python3.11/site-packages/py.py | 15 + .../pycparser-2.22.dist-info/INSTALLER | 1 + .../pycparser-2.22.dist-info/LICENSE | 27 + .../pycparser-2.22.dist-info/METADATA | 28 + .../pycparser-2.22.dist-info/RECORD | 41 + .../pycparser-2.22.dist-info/WHEEL | 5 + .../pycparser-2.22.dist-info/top_level.txt | 1 + .../site-packages/pycparser/__init__.py | 93 + .../site-packages/pycparser/_ast_gen.py | 336 + .../site-packages/pycparser/_build_tables.py | 40 + .../site-packages/pycparser/_c_ast.cfg | 195 + .../site-packages/pycparser/ast_transforms.py | 164 + .../site-packages/pycparser/c_ast.py | 1125 +++ .../site-packages/pycparser/c_generator.py | 502 + .../site-packages/pycparser/c_lexer.py | 555 ++ .../site-packages/pycparser/c_parser.py | 1950 ++++ .../site-packages/pycparser/lextab.py | 10 + .../site-packages/pycparser/ply/__init__.py | 5 + .../site-packages/pycparser/ply/cpp.py | 905 ++ .../site-packages/pycparser/ply/ctokens.py | 133 + .../site-packages/pycparser/ply/lex.py | 1099 +++ .../site-packages/pycparser/ply/yacc.py | 3494 +++++++ .../site-packages/pycparser/ply/ygen.py | 74 + .../site-packages/pycparser/plyparser.py | 133 + .../site-packages/pycparser/yacctab.py | 369 + .../pytest-8.3.3.dist-info/AUTHORS | 469 + .../pytest-8.3.3.dist-info/INSTALLER | 1 + .../pytest-8.3.3.dist-info/LICENSE | 21 + .../pytest-8.3.3.dist-info/METADATA | 212 + .../pytest-8.3.3.dist-info/RECORD | 155 + .../pytest-8.3.3.dist-info/REQUESTED | 0 .../pytest-8.3.3.dist-info/WHEEL | 5 + .../pytest-8.3.3.dist-info/entry_points.txt | 3 + .../pytest-8.3.3.dist-info/top_level.txt | 3 + .../site-packages/pytest/__init__.py | 172 + .../site-packages/pytest/__main__.py | 9 + .../python3.11/site-packages/pytest/py.typed | 0 .../requests-2.32.3.dist-info/INSTALLER | 1 + .../requests-2.32.3.dist-info/LICENSE | 175 + .../requests-2.32.3.dist-info/METADATA | 119 + .../requests-2.32.3.dist-info/RECORD | 42 + .../requests-2.32.3.dist-info/WHEEL | 5 + .../requests-2.32.3.dist-info/top_level.txt | 1 + .../site-packages/requests/__init__.py | 184 + .../site-packages/requests/__version__.py | 14 + .../site-packages/requests/_internal_utils.py | 50 + .../site-packages/requests/adapters.py | 719 ++ .../python3.11/site-packages/requests/api.py | 157 + .../python3.11/site-packages/requests/auth.py | 314 + .../site-packages/requests/certs.py | 17 + .../site-packages/requests/compat.py | 94 + .../site-packages/requests/cookies.py | 561 ++ .../site-packages/requests/exceptions.py | 151 + .../python3.11/site-packages/requests/help.py | 134 + .../site-packages/requests/hooks.py | 33 + .../site-packages/requests/models.py | 1037 ++ .../site-packages/requests/packages.py | 23 + .../site-packages/requests/sessions.py | 831 ++ .../site-packages/requests/status_codes.py | 128 + .../site-packages/requests/structures.py | 99 + .../site-packages/requests/utils.py | 1096 +++ .../setuptools-66.1.1.dist-info/INSTALLER | 1 + .../setuptools-66.1.1.dist-info/LICENSE | 19 + .../setuptools-66.1.1.dist-info/METADATA | 137 + .../setuptools-66.1.1.dist-info/RECORD | 484 + .../setuptools-66.1.1.dist-info/REQUESTED | 0 .../setuptools-66.1.1.dist-info/WHEEL | 5 + .../entry_points.txt | 57 + .../setuptools-66.1.1.dist-info/top_level.txt | 4 + .../site-packages/setuptools/__init__.py | 268 + .../setuptools/_deprecation_warning.py | 7 + .../setuptools/_distutils/__init__.py | 14 + .../setuptools/_distutils/_collections.py | 194 + .../setuptools/_distutils/_functools.py | 20 + .../setuptools/_distutils/_log.py | 4 + .../setuptools/_distutils/_macos_compat.py | 12 + .../setuptools/_distutils/_msvccompiler.py | 572 ++ .../setuptools/_distutils/archive_util.py | 280 + .../setuptools/_distutils/bcppcompiler.py | 408 + .../setuptools/_distutils/ccompiler.py | 1220 +++ .../setuptools/_distutils/cmd.py | 435 + .../setuptools/_distutils/command/__init__.py | 25 + .../_distutils/command/_framework_compat.py | 55 + .../setuptools/_distutils/command/bdist.py | 157 + .../_distutils/command/bdist_dumb.py | 144 + .../_distutils/command/bdist_rpm.py | 615 ++ .../setuptools/_distutils/command/build.py | 153 + .../_distutils/command/build_clib.py | 208 + .../_distutils/command/build_ext.py | 789 ++ .../setuptools/_distutils/command/build_py.py | 407 + .../_distutils/command/build_scripts.py | 173 + .../setuptools/_distutils/command/check.py | 151 + .../setuptools/_distutils/command/clean.py | 76 + .../setuptools/_distutils/command/config.py | 377 + .../setuptools/_distutils/command/install.py | 814 ++ .../_distutils/command/install_data.py | 84 + .../_distutils/command/install_egg_info.py | 92 + .../_distutils/command/install_headers.py | 45 + .../_distutils/command/install_lib.py | 238 + .../_distutils/command/install_scripts.py | 61 + .../_distutils/command/py37compat.py | 31 + .../setuptools/_distutils/command/register.py | 321 + .../setuptools/_distutils/command/sdist.py | 531 + .../setuptools/_distutils/command/upload.py | 207 + .../setuptools/_distutils/config.py | 139 + .../setuptools/_distutils/core.py | 291 + .../setuptools/_distutils/cygwinccompiler.py | 358 + .../setuptools/_distutils/debug.py | 5 + .../setuptools/_distutils/dep_util.py | 96 + .../setuptools/_distutils/dir_util.py | 243 + .../setuptools/_distutils/dist.py | 1287 +++ .../setuptools/_distutils/errors.py | 127 + .../setuptools/_distutils/extension.py | 248 + .../setuptools/_distutils/fancy_getopt.py | 470 + .../setuptools/_distutils/file_util.py | 249 + .../setuptools/_distutils/filelist.py | 371 + .../setuptools/_distutils/log.py | 57 + .../setuptools/_distutils/msvc9compiler.py | 832 ++ .../setuptools/_distutils/msvccompiler.py | 695 ++ .../setuptools/_distutils/py38compat.py | 8 + .../setuptools/_distutils/py39compat.py | 22 + .../setuptools/_distutils/spawn.py | 109 + .../setuptools/_distutils/sysconfig.py | 552 ++ .../setuptools/_distutils/text_file.py | 287 + .../setuptools/_distutils/unixccompiler.py | 401 + .../setuptools/_distutils/util.py | 513 + .../setuptools/_distutils/version.py | 358 + .../setuptools/_distutils/versionpredicate.py | 175 + .../site-packages/setuptools/_entry_points.py | 94 + .../site-packages/setuptools/_imp.py | 82 + .../site-packages/setuptools/_importlib.py | 47 + .../site-packages/setuptools/_itertools.py | 23 + .../site-packages/setuptools/_path.py | 29 + .../site-packages/setuptools/_reqs.py | 19 + .../setuptools/_vendor/__init__.py | 0 .../_vendor/importlib_metadata/__init__.py | 1047 ++ .../_vendor/importlib_metadata/_adapters.py | 68 + .../importlib_metadata/_collections.py | 30 + .../_vendor/importlib_metadata/_compat.py | 71 + .../_vendor/importlib_metadata/_functools.py | 104 + .../_vendor/importlib_metadata/_itertools.py | 73 + .../_vendor/importlib_metadata/_meta.py | 48 + .../_vendor/importlib_metadata/_text.py | 99 + .../_vendor/importlib_resources/__init__.py | 36 + .../_vendor/importlib_resources/_adapters.py | 170 + .../_vendor/importlib_resources/_common.py | 104 + .../_vendor/importlib_resources/_compat.py | 98 + .../_vendor/importlib_resources/_itertools.py | 35 + .../_vendor/importlib_resources/_legacy.py | 121 + .../_vendor/importlib_resources/abc.py | 137 + .../_vendor/importlib_resources/readers.py | 122 + .../_vendor/importlib_resources/simple.py | 116 + .../setuptools/_vendor/jaraco/__init__.py | 0 .../setuptools/_vendor/jaraco/context.py | 253 + .../setuptools/_vendor/jaraco/functools.py | 525 + .../_vendor/jaraco/text/__init__.py | 599 ++ .../_vendor/more_itertools/__init__.py | 4 + .../setuptools/_vendor/more_itertools/more.py | 3824 ++++++++ .../_vendor/more_itertools/recipes.py | 620 ++ .../setuptools/_vendor/ordered_set.py | 488 + .../setuptools/_vendor/packaging/__about__.py | 26 + .../setuptools/_vendor/packaging/__init__.py | 25 + .../_vendor/packaging/_manylinux.py | 301 + .../_vendor/packaging/_musllinux.py | 136 + .../_vendor/packaging/_structures.py | 61 + .../setuptools/_vendor/packaging/markers.py | 304 + .../_vendor/packaging/requirements.py | 146 + .../_vendor/packaging/specifiers.py | 802 ++ .../setuptools/_vendor/packaging/tags.py | 487 + .../setuptools/_vendor/packaging/utils.py | 136 + .../setuptools/_vendor/packaging/version.py | 504 + .../setuptools/_vendor/pyparsing/__init__.py | 331 + .../setuptools/_vendor/pyparsing/actions.py | 207 + .../setuptools/_vendor/pyparsing/common.py | 424 + .../setuptools/_vendor/pyparsing/core.py | 5814 +++++++++++ .../_vendor/pyparsing/diagram/__init__.py | 642 ++ .../_vendor/pyparsing/exceptions.py | 267 + .../setuptools/_vendor/pyparsing/helpers.py | 1088 +++ .../setuptools/_vendor/pyparsing/results.py | 760 ++ .../setuptools/_vendor/pyparsing/testing.py | 331 + .../setuptools/_vendor/pyparsing/unicode.py | 352 + .../setuptools/_vendor/pyparsing/util.py | 235 + .../setuptools/_vendor/tomli/__init__.py | 11 + .../setuptools/_vendor/tomli/_parser.py | 691 ++ .../setuptools/_vendor/tomli/_re.py | 107 + .../setuptools/_vendor/tomli/_types.py | 10 + .../setuptools/_vendor/typing_extensions.py | 2296 +++++ .../site-packages/setuptools/_vendor/zipp.py | 329 + .../site-packages/setuptools/archive_util.py | 213 + .../site-packages/setuptools/build_meta.py | 512 + .../site-packages/setuptools/cli-32.exe | Bin 0 -> 65536 bytes .../site-packages/setuptools/cli-64.exe | Bin 0 -> 74752 bytes .../site-packages/setuptools/cli-arm64.exe | Bin 0 -> 137216 bytes .../site-packages/setuptools/cli.exe | Bin 0 -> 65536 bytes .../setuptools/command/__init__.py | 12 + .../site-packages/setuptools/command/alias.py | 78 + .../setuptools/command/bdist_egg.py | 457 + .../setuptools/command/bdist_rpm.py | 40 + .../site-packages/setuptools/command/build.py | 146 + .../setuptools/command/build_clib.py | 101 + .../setuptools/command/build_ext.py | 383 + .../setuptools/command/build_py.py | 368 + .../setuptools/command/develop.py | 193 + .../setuptools/command/dist_info.py | 142 + .../setuptools/command/easy_install.py | 2366 +++++ .../setuptools/command/editable_wheel.py | 844 ++ .../setuptools/command/egg_info.py | 775 ++ .../setuptools/command/install.py | 139 + .../setuptools/command/install_egg_info.py | 83 + .../setuptools/command/install_lib.py | 148 + .../setuptools/command/install_scripts.py | 70 + .../setuptools/command/launcher manifest.xml | 15 + .../setuptools/command/py36compat.py | 134 + .../setuptools/command/register.py | 18 + .../setuptools/command/rotate.py | 64 + .../setuptools/command/saveopts.py | 22 + .../site-packages/setuptools/command/sdist.py | 210 + .../setuptools/command/setopt.py | 149 + .../site-packages/setuptools/command/test.py | 251 + .../setuptools/command/upload.py | 17 + .../setuptools/command/upload_docs.py | 212 + .../setuptools/config/__init__.py | 35 + .../setuptools/config/_apply_pyprojecttoml.py | 384 + .../config/_validate_pyproject/__init__.py | 34 + .../_validate_pyproject/error_reporting.py | 318 + .../_validate_pyproject/extra_validations.py | 36 + .../fastjsonschema_exceptions.py | 51 + .../fastjsonschema_validations.py | 1035 ++ .../config/_validate_pyproject/formats.py | 259 + .../site-packages/setuptools/config/expand.py | 462 + .../setuptools/config/pyprojecttoml.py | 498 + .../setuptools/config/setupcfg.py | 769 ++ .../site-packages/setuptools/dep_util.py | 25 + .../site-packages/setuptools/depends.py | 176 + .../site-packages/setuptools/discovery.py | 601 ++ .../site-packages/setuptools/dist.py | 1218 +++ .../site-packages/setuptools/errors.py | 58 + .../site-packages/setuptools/extension.py | 148 + .../setuptools/extern/__init__.py | 76 + .../site-packages/setuptools/glob.py | 167 + .../site-packages/setuptools/gui-32.exe | Bin 0 -> 65536 bytes .../site-packages/setuptools/gui-64.exe | Bin 0 -> 75264 bytes .../site-packages/setuptools/gui-arm64.exe | Bin 0 -> 137728 bytes .../site-packages/setuptools/gui.exe | Bin 0 -> 65536 bytes .../site-packages/setuptools/installer.py | 104 + .../site-packages/setuptools/launch.py | 36 + .../site-packages/setuptools/logging.py | 37 + .../site-packages/setuptools/monkey.py | 165 + .../site-packages/setuptools/msvc.py | 1703 ++++ .../site-packages/setuptools/namespaces.py | 107 + .../site-packages/setuptools/package_index.py | 1162 +++ .../site-packages/setuptools/py34compat.py | 13 + .../site-packages/setuptools/sandbox.py | 530 + .../setuptools/script (dev).tmpl | 6 + .../site-packages/setuptools/script.tmpl | 3 + .../site-packages/setuptools/unicode_utils.py | 42 + .../site-packages/setuptools/version.py | 6 + .../site-packages/setuptools/wheel.py | 222 + .../setuptools/windows_support.py | 29 + .../INSTALLER | 1 + .../LICENSE | 279 + .../METADATA | 67 + .../typing_extensions-4.12.2.dist-info/RECORD | 7 + .../typing_extensions-4.12.2.dist-info/WHEEL | 4 + .../site-packages/typing_extensions.py | 3641 +++++++ .../urllib3-2.2.3.dist-info/INSTALLER | 1 + .../urllib3-2.2.3.dist-info/METADATA | 155 + .../urllib3-2.2.3.dist-info/RECORD | 79 + .../urllib3-2.2.3.dist-info/WHEEL | 4 + .../licenses/LICENSE.txt | 21 + .../site-packages/urllib3/__init__.py | 211 + .../site-packages/urllib3/_base_connection.py | 172 + .../site-packages/urllib3/_collections.py | 483 + .../site-packages/urllib3/_request_methods.py | 278 + .../site-packages/urllib3/_version.py | 16 + .../site-packages/urllib3/connection.py | 1033 ++ .../site-packages/urllib3/connectionpool.py | 1182 +++ .../site-packages/urllib3/contrib/__init__.py | 0 .../urllib3/contrib/emscripten/__init__.py | 16 + .../urllib3/contrib/emscripten/connection.py | 254 + .../emscripten/emscripten_fetch_worker.js | 110 + .../urllib3/contrib/emscripten/fetch.py | 418 + .../urllib3/contrib/emscripten/request.py | 22 + .../urllib3/contrib/emscripten/response.py | 285 + .../urllib3/contrib/pyopenssl.py | 552 ++ .../site-packages/urllib3/contrib/socks.py | 228 + .../site-packages/urllib3/exceptions.py | 321 + .../site-packages/urllib3/fields.py | 341 + .../site-packages/urllib3/filepost.py | 89 + .../site-packages/urllib3/http2/__init__.py | 53 + .../site-packages/urllib3/http2/connection.py | 356 + .../site-packages/urllib3/http2/probe.py | 87 + .../site-packages/urllib3/poolmanager.py | 637 ++ .../python3.11/site-packages/urllib3/py.typed | 2 + .../site-packages/urllib3/response.py | 1265 +++ .../site-packages/urllib3/util/__init__.py | 42 + .../site-packages/urllib3/util/connection.py | 137 + .../site-packages/urllib3/util/proxy.py | 43 + .../site-packages/urllib3/util/request.py | 256 + .../site-packages/urllib3/util/response.py | 101 + .../site-packages/urllib3/util/retry.py | 533 + .../site-packages/urllib3/util/ssl_.py | 513 + .../urllib3/util/ssl_match_hostname.py | 159 + .../urllib3/util/ssltransport.py | 276 + .../site-packages/urllib3/util/timeout.py | 275 + .../site-packages/urllib3/util/url.py | 471 + .../site-packages/urllib3/util/util.py | 42 + .../site-packages/urllib3/util/wait.py | 124 + .../wrapt-1.16.0.dist-info/INSTALLER | 1 + .../wrapt-1.16.0.dist-info/LICENSE | 24 + .../wrapt-1.16.0.dist-info/METADATA | 170 + .../wrapt-1.16.0.dist-info/RECORD | 23 + .../wrapt-1.16.0.dist-info/WHEEL | 6 + .../wrapt-1.16.0.dist-info/top_level.txt | 1 + .../site-packages/wrapt/__init__.py | 30 + .../site-packages/wrapt/__wrapt__.py | 14 + ..._wrappers.cpython-311-aarch64-linux-gnu.so | Bin 0 -> 220424 bytes .../site-packages/wrapt/arguments.py | 38 + .../site-packages/wrapt/decorators.py | 541 + .../site-packages/wrapt/importer.py | 295 + .../python3.11/site-packages/wrapt/patches.py | 141 + .../site-packages/wrapt/weakrefs.py | 98 + .../site-packages/wrapt/wrappers.py | 784 ++ PyGC/.venv/lib64 | 1 + PyGC/.venv/pyvenv.cfg | 5 + PyGC/README.md | 0 PyGC/bot/__init__.py | 0 PyGC/bot/arithmetic/__init__.py | 0 PyGC/bot/arithmetic/arithmetic_checker.py | 18 + PyGC/bot/bitwise/__init__.py | 0 PyGC/bot/bitwise/bitwise_checker.py | 20 + PyGC/bot/comparison/__init__.py | 0 PyGC/bot/comparison/comparison_checker.py | 24 + PyGC/bot/config_parser.py | 30 + PyGC/bot/guideline_parser.py | 25 + PyGC/bot/identity_membership/__init__.py | 0 .../identity_membership/identity_checker.py | 16 + .../identity_membership/membership_checker.py | 16 + PyGC/bot/logical/__init__.py | 0 PyGC/bot/logical/logical_checker.py | 16 + PyGC/bot/utils.py | 7 + PyGC/pytest.ini | 2 + PyGC/requirements.txt | 0 PyGC/sample_code/sample_code.py | 8 + PyGC/tests/test_arithmetic_checker.py | 20 + PyGC/tests/test_bitwise_checker.py | 23 + PyGC/tests/test_comparison_checker.py | 21 + PyGC/tests/test_identity_checker.py | 21 + PyGC/tests/test_logical_checker.py | 23 + PyGC/tests/test_membership_checker.py | 21 + PyGC/tests/test_operator_detection.py | 21 + README.md | 17 - calculator.js | 15 - index.html | 41 - styles.css | 18 - 1387 files changed, 398900 insertions(+), 93 deletions(-) create mode 100644 PyGC/.github/workflows/python-checkers.yaml create mode 100644 PyGC/.gitignore create mode 100644 PyGC/.pygcconfig create mode 100644 PyGC/.venv/bin/Activate.ps1 create mode 100644 PyGC/.venv/bin/activate create mode 100644 PyGC/.venv/bin/activate.csh create mode 100644 PyGC/.venv/bin/activate.fish create mode 100755 PyGC/.venv/bin/normalizer create mode 100755 PyGC/.venv/bin/pip create mode 100755 PyGC/.venv/bin/pip3 create mode 100755 PyGC/.venv/bin/pip3.11 create mode 100755 PyGC/.venv/bin/py.test create mode 100755 PyGC/.venv/bin/pytest create mode 120000 PyGC/.venv/bin/python create mode 120000 PyGC/.venv/bin/python3 create mode 120000 PyGC/.venv/bin/python3.11 create mode 100644 PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/LICENSE.rst create mode 100644 PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/top_level.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/COPYING create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/COPYING.LESSER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/REQUESTED create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/top_level.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/AUTHORS.rst create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/LICENSE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/top_level.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/LICENSE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/top_level.txt create mode 100755 PyGC/.venv/lib/python3.11/site-packages/_cffi_backend.cpython-311-aarch64-linux-gnu.so create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_distutils_hack/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_distutils_hack/override.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/_argcomplete.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/_code/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/_code/code.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/_code/source.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/pprint.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/saferepr.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/terminalwriter.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/wcwidth.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/_py/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/_py/error.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/_py/path.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/_version.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/rewrite.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/truncate.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/util.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/cacheprovider.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/capture.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/config/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/config/argparsing.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/config/compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/config/exceptions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/config/findpaths.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/debugging.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/deprecated.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/doctest.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/faulthandler.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/fixtures.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/freeze_support.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/helpconfig.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/hookspec.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/junitxml.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/legacypath.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/logging.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/main.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/mark/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/mark/expression.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/mark/structures.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/monkeypatch.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/nodes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/outcomes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/pastebin.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/pathlib.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/pytester.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/pytester_assertions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/python.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/python_api.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/python_path.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/recwarn.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/reports.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/runner.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/scope.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/setuponly.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/setupplan.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/skipping.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/stash.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/stepwise.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/terminal.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/threadexception.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/timing.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/tmpdir.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/unittest.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/unraisableexception.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/warning_types.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/_pytest/warnings.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/LICENSE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/top_level.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/certifi/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/certifi/__main__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/certifi/cacert.pem create mode 100644 PyGC/.venv/lib/python3.11/site-packages/certifi/core.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/certifi/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/LICENSE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/entry_points.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/top_level.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/_cffi_errors.h create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/_cffi_include.h create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/_embedding.h create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/_imp_emulation.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/_shimmed_dist_utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/api.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/backend_ctypes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/cffi_opcode.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/commontypes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/cparser.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/error.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/ffiplatform.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/lock.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/model.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/parse_c_type.h create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/pkgconfig.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/recompiler.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/setuptools_ext.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/vengine_cpy.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/vengine_gen.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cffi/verifier.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/INSTALLER rename LICENSE => PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/LICENSE (95%) create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/entry_points.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/top_level.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/__main__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/api.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/cd.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/cli/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/cli/__main__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/constant.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/legacy.py create mode 100755 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/md.cpython-311-aarch64-linux-gnu.so create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/md.py create mode 100755 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/md__mypyc.cpython-311-aarch64-linux-gnu.so create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/models.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/version.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/license_files/LICENSE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/license_files/LICENSE.APACHE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/license_files/LICENSE.BSD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/__about__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/exceptions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/fernet.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/_oid.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/backends/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/backends/openssl/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/backends/openssl/backend.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/__init__.py create mode 100755 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust.abi3.so create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/__init__.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/_openssl.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/asn1.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/exceptions.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/ocsp.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/__init__.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/aead.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/ciphers.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/cmac.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/dh.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/dsa.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/ec.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/ed25519.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/ed448.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/hashes.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/hmac.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/kdf.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/keys.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/poly1305.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/rsa.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/x25519.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/openssl/x448.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/pkcs12.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/pkcs7.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/test_support.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust/x509.pyi create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/openssl/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/openssl/_conditional.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/openssl/binding.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/decrepit/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/decrepit/ciphers/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/decrepit/ciphers/algorithms.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/_asymmetric.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/_cipheralgorithm.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/_serialization.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/asymmetric/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/asymmetric/dh.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/asymmetric/dsa.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/asymmetric/ec.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/asymmetric/ed25519.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/asymmetric/ed448.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/asymmetric/padding.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/asymmetric/rsa.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/asymmetric/types.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/asymmetric/utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/asymmetric/x25519.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/asymmetric/x448.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/ciphers/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/ciphers/aead.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/ciphers/algorithms.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/ciphers/base.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/ciphers/modes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/cmac.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/constant_time.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/hashes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/hmac.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/kdf/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/kdf/concatkdf.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/kdf/hkdf.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/kdf/kbkdf.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/kdf/pbkdf2.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/kdf/scrypt.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/kdf/x963kdf.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/keywrap.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/padding.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/poly1305.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/serialization/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/serialization/base.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/serialization/pkcs12.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/serialization/pkcs7.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/serialization/ssh.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/twofactor/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/twofactor/hotp.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/primitives/twofactor/totp.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/x509/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/x509/base.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/x509/certificate_transparency.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/x509/extensions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/x509/general_name.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/x509/name.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/x509/ocsp.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/x509/oid.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/cryptography/x509/verification.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/deprecated/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/deprecated/classic.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/deprecated/sphinx.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/distutils-precedence.pth create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/AccessToken.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/AdvisoryBase.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/AdvisoryCredit.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/AdvisoryCreditDetailed.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/AdvisoryVulnerability.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/AdvisoryVulnerabilityPackage.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/AppAuthentication.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/ApplicationOAuth.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Artifact.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Auth.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/AuthenticatedUser.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Authorization.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/AuthorizationApplication.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Autolink.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Branch.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/BranchProtection.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/CVSS.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/CWE.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/CheckRun.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/CheckRunAnnotation.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/CheckRunOutput.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/CheckSuite.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Clones.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/CodeScanAlert.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/CodeScanAlertInstance.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/CodeScanAlertInstanceLocation.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/CodeScanRule.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/CodeScanTool.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Commit.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/CommitCombinedStatus.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/CommitComment.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/CommitStats.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/CommitStatus.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Comparison.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Consts.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/ContentFile.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/DependabotAlert.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/DependabotAlertAdvisory.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/DependabotAlertDependency.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/DependabotAlertVulnerability.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Deployment.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/DeploymentStatus.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Download.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Enterprise.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/EnterpriseConsumedLicenses.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Environment.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/EnvironmentDeploymentBranchPolicy.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/EnvironmentProtectionRule.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/EnvironmentProtectionRuleReviewer.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Event.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/File.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Gist.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GistComment.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GistFile.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GistHistoryState.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GitAuthor.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GitBlob.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GitCommit.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GitObject.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GitRef.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GitRelease.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GitReleaseAsset.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GitTag.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GitTree.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GitTreeElement.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GithubApp.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GithubException.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GithubIntegration.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GithubObject.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GithubRetry.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GitignoreTemplate.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/GlobalAdvisory.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Hook.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/HookDelivery.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/HookDescription.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/HookResponse.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/InputFileContent.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/InputGitAuthor.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/InputGitTreeElement.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Installation.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/InstallationAuthorization.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Invitation.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Issue.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/IssueComment.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/IssueEvent.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/IssuePullRequest.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Label.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/License.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/MainClass.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Membership.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Migration.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Milestone.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/NamedEnterpriseUser.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/NamedUser.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Notification.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/NotificationSubject.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Organization.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/OrganizationCustomProperty.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/OrganizationDependabotAlert.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/OrganizationSecret.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/OrganizationVariable.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/PaginatedList.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Path.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Permissions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Plan.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Project.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/ProjectCard.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/ProjectColumn.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/PublicKey.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/PullRequest.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/PullRequestComment.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/PullRequestMergeStatus.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/PullRequestPart.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/PullRequestReview.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Rate.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/RateLimit.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Reaction.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Referrer.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Repository.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/RepositoryAdvisory.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/RepositoryKey.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/RepositoryPreferences.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Requester.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/RequiredPullRequestReviews.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/RequiredStatusChecks.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Secret.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/SecurityAndAnalysis.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/SecurityAndAnalysisFeature.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/SelfHostedActionsRunner.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/SourceImport.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Stargazer.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/StatsCodeFrequency.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/StatsCommitActivity.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/StatsContributor.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/StatsParticipation.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/StatsPunchCard.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Tag.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Team.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/TeamDiscussion.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/TimelineEvent.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/TimelineEventSource.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Topic.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/UserKey.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Variable.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/View.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/Workflow.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/WorkflowJob.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/WorkflowRun.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/WorkflowStep.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/github/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/idna-3.10.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/idna-3.10.dist-info/LICENSE.md create mode 100644 PyGC/.venv/lib/python3.11/site-packages/idna-3.10.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/idna-3.10.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/idna-3.10.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/idna/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/idna/codec.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/idna/compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/idna/core.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/idna/idnadata.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/idna/intranges.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/idna/package_data.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/idna/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/idna/uts46data.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/iniconfig-2.0.0.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/iniconfig-2.0.0.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/iniconfig-2.0.0.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/iniconfig-2.0.0.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/iniconfig-2.0.0.dist-info/licenses/LICENSE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/iniconfig/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/iniconfig/_parse.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/iniconfig/_version.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/iniconfig/exceptions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/iniconfig/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/jwt/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/jwt/algorithms.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/jwt/api_jwk.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/jwt/api_jws.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/jwt/api_jwt.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/jwt/exceptions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/jwt/help.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/jwt/jwk_set_cache.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/jwt/jwks_client.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/jwt/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/jwt/types.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/jwt/utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/jwt/warnings.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/__init__.py create mode 100755 PyGC/.venv/lib/python3.11/site-packages/nacl/_sodium.abi3.so create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/crypto_aead.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/crypto_box.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/crypto_core.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/crypto_generichash.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/crypto_hash.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/crypto_kx.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/crypto_pwhash.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/crypto_scalarmult.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/crypto_secretbox.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/crypto_secretstream.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/crypto_shorthash.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/crypto_sign.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/randombytes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/sodium_core.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/bindings/utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/encoding.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/exceptions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/hash.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/hashlib.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/public.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/pwhash/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/pwhash/_argon2.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/pwhash/argon2i.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/pwhash/argon2id.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/pwhash/scrypt.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/secret.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/signing.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/nacl/utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging-24.1.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging-24.1.dist-info/LICENSE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging-24.1.dist-info/LICENSE.APACHE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging-24.1.dist-info/LICENSE.BSD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging-24.1.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging-24.1.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging-24.1.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging/_elffile.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging/_manylinux.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging/_musllinux.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging/_parser.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging/_structures.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging/_tokenizer.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging/markers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging/metadata.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging/requirements.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging/specifiers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging/tags.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging/utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/packaging/version.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip-24.2.dist-info/AUTHORS.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip-24.2.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip-24.2.dist-info/LICENSE.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip-24.2.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip-24.2.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip-24.2.dist-info/REQUESTED create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip-24.2.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip-24.2.dist-info/entry_points.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip-24.2.dist-info/top_level.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/__main__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/__pip-runner__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/build_env.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/cache.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/cli/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/cli/autocompletion.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/cli/base_command.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/cli/cmdoptions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/cli/command_context.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/cli/index_command.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/cli/main.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/cli/main_parser.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/cli/parser.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/cli/progress_bars.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/cli/req_command.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/cli/spinners.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/cli/status_codes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/cache.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/check.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/completion.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/configuration.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/debug.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/download.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/freeze.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/hash.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/help.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/index.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/inspect.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/install.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/list.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/search.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/show.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/uninstall.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/commands/wheel.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/configuration.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/distributions/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/distributions/base.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/distributions/installed.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/distributions/sdist.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/distributions/wheel.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/exceptions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/index/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/index/collector.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/index/package_finder.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/index/sources.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/locations/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/locations/_distutils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/locations/_sysconfig.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/locations/base.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/main.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/metadata/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/metadata/_json.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/metadata/base.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/metadata/importlib/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/metadata/importlib/_compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/metadata/importlib/_dists.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/metadata/importlib/_envs.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/metadata/pkg_resources.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/models/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/models/candidate.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/models/direct_url.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/models/format_control.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/models/index.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/models/installation_report.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/models/link.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/models/scheme.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/models/search_scope.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/models/selection_prefs.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/models/target_python.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/models/wheel.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/network/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/network/auth.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/network/cache.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/network/download.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/network/lazy_wheel.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/network/session.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/network/utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/network/xmlrpc.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/operations/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/operations/build/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/operations/build/build_tracker.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/operations/build/metadata.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/operations/build/metadata_editable.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/operations/build/metadata_legacy.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/operations/build/wheel.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/operations/build/wheel_editable.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/operations/build/wheel_legacy.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/operations/check.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/operations/freeze.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/operations/install/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/operations/install/editable_legacy.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/operations/install/wheel.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/operations/prepare.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/pyproject.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/req/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/req/constructors.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/req/req_file.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/req/req_install.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/req/req_set.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/req/req_uninstall.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/resolution/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/resolution/base.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/resolution/legacy/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/resolution/legacy/resolver.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/resolution/resolvelib/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/resolution/resolvelib/base.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/resolution/resolvelib/candidates.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/resolution/resolvelib/factory.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/resolution/resolvelib/provider.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/resolution/resolvelib/reporter.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/resolution/resolvelib/requirements.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/resolution/resolvelib/resolver.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/self_outdated_check.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/_jaraco_text.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/_log.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/appdirs.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/compatibility_tags.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/datetime.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/deprecation.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/direct_url_helpers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/egg_link.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/encoding.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/entrypoints.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/filesystem.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/filetypes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/glibc.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/hashes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/logging.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/misc.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/packaging.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/retry.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/setuptools_build.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/subprocess.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/temp_dir.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/unpacking.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/urls.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/virtualenv.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/utils/wheel.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/vcs/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/vcs/bazaar.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/vcs/git.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/vcs/mercurial.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/vcs/subversion.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/vcs/versioncontrol.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_internal/wheel_builder.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/cachecontrol/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/cachecontrol/_cmd.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/cachecontrol/adapter.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/cachecontrol/cache.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/cachecontrol/caches/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/cachecontrol/controller.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/cachecontrol/filewrapper.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/cachecontrol/heuristics.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/cachecontrol/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/cachecontrol/serialize.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/cachecontrol/wrapper.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/certifi/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/certifi/__main__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/certifi/cacert.pem create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/certifi/core.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/certifi/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/database.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/index.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/locators.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/manifest.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/markers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/metadata.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/resources.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/scripts.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/t32.exe create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/t64-arm.exe create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/t64.exe create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/util.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/version.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/w32.exe create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/w64-arm.exe create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/w64.exe create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distlib/wheel.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distro/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distro/__main__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distro/distro.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/distro/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/idna/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/idna/codec.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/idna/compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/idna/core.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/idna/idnadata.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/idna/intranges.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/idna/package_data.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/idna/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/idna/uts46data.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/msgpack/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/msgpack/exceptions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/msgpack/ext.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/msgpack/fallback.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/packaging/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/packaging/_elffile.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/packaging/_manylinux.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/packaging/_musllinux.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/packaging/_parser.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/packaging/_structures.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/packaging/_tokenizer.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/packaging/markers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/packaging/metadata.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/packaging/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/packaging/requirements.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/packaging/specifiers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/packaging/tags.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/packaging/utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/packaging/version.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pkg_resources/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/platformdirs/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/platformdirs/__main__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/platformdirs/android.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/platformdirs/api.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/platformdirs/macos.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/platformdirs/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/platformdirs/unix.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/platformdirs/version.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/platformdirs/windows.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/__main__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/cmdline.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/console.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/filter.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/filters/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/formatter.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/formatters/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/formatters/_mapping.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/formatters/bbcode.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/formatters/groff.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/formatters/html.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/formatters/img.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/formatters/irc.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/formatters/latex.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/formatters/other.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/formatters/pangomarkup.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/formatters/rtf.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/formatters/svg.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/formatters/terminal.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/formatters/terminal256.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/lexer.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/lexers/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/lexers/_mapping.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/lexers/python.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/modeline.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/plugin.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/regexopt.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/scanner.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/sphinxext.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/style.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/styles/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/styles/_mapping.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/token.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/unistring.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pygments/util.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pyproject_hooks/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pyproject_hooks/_compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pyproject_hooks/_impl.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pyproject_hooks/_in_process/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/__version__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/_internal_utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/adapters.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/api.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/auth.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/certs.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/cookies.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/exceptions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/help.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/hooks.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/models.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/packages.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/sessions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/status_codes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/structures.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/requests/utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/resolvelib/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/resolvelib/compat/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/resolvelib/compat/collections_abc.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/resolvelib/providers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/resolvelib/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/resolvelib/reporters.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/resolvelib/resolvers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/resolvelib/structs.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/__main__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_cell_widths.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_emoji_codes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_emoji_replace.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_export_format.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_extension.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_fileno.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_inspect.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_log_render.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_loop.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_null_file.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_palettes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_pick.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_ratio.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_spinners.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_stack.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_timer.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_win32_console.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_windows.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_windows_renderer.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/_wrap.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/abc.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/align.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/ansi.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/bar.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/box.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/cells.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/color.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/color_triplet.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/columns.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/console.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/constrain.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/containers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/control.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/default_styles.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/diagnose.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/emoji.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/errors.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/file_proxy.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/filesize.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/highlighter.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/json.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/jupyter.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/layout.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/live.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/live_render.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/logging.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/markup.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/measure.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/padding.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/pager.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/palette.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/panel.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/pretty.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/progress.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/progress_bar.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/prompt.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/protocol.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/region.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/repr.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/rule.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/scope.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/screen.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/segment.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/spinner.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/status.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/style.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/styled.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/syntax.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/table.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/terminal_theme.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/text.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/theme.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/themes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/traceback.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/rich/tree.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/tomli/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/tomli/_parser.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/tomli/_re.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/tomli/_types.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/tomli/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/truststore/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/truststore/_api.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/truststore/_macos.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/truststore/_openssl.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/truststore/_ssl_constants.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/truststore/_windows.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/truststore/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/typing_extensions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/_collections.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/_version.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/connection.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/connectionpool.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/contrib/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/contrib/appengine.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/contrib/securetransport.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/contrib/socks.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/exceptions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/fields.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/filepost.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/packages/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/packages/backports/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/packages/backports/weakref_finalize.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/packages/six.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/poolmanager.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/request.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/response.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/util/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/util/connection.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/util/proxy.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/util/queue.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/util/request.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/util/response.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/util/retry.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/util/ssl_.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/util/ssl_match_hostname.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/util/ssltransport.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/util/timeout.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/util/url.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/urllib3/util/wait.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/_vendor/vendor.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pip/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/importlib_resources/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/importlib_resources/_adapters.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/importlib_resources/_common.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/importlib_resources/_compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/importlib_resources/_itertools.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/importlib_resources/_legacy.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/importlib_resources/abc.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/importlib_resources/readers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/importlib_resources/simple.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/jaraco/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/jaraco/context.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/jaraco/functools.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/jaraco/text/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/more_itertools/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/more_itertools/more.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/more_itertools/recipes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/packaging/__about__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/packaging/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/packaging/_manylinux.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/packaging/_musllinux.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/packaging/_structures.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/packaging/markers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/packaging/requirements.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/packaging/specifiers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/packaging/tags.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/packaging/utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/packaging/version.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/platformdirs/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/platformdirs/__main__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/platformdirs/android.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/platformdirs/api.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/platformdirs/macos.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/platformdirs/unix.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/platformdirs/version.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/platformdirs/windows.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/pyparsing/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/pyparsing/actions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/pyparsing/common.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/pyparsing/core.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/pyparsing/diagram/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/pyparsing/exceptions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/pyparsing/helpers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/pyparsing/results.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/pyparsing/testing.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/pyparsing/unicode.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/pyparsing/util.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/typing_extensions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/_vendor/zipp.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pkg_resources/extern/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pluggy-1.5.0.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pluggy-1.5.0.dist-info/LICENSE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pluggy-1.5.0.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pluggy-1.5.0.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pluggy-1.5.0.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pluggy-1.5.0.dist-info/top_level.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pluggy/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pluggy/_callers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pluggy/_hooks.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pluggy/_manager.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pluggy/_result.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pluggy/_tracing.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pluggy/_version.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pluggy/_warnings.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pluggy/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/py.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser-2.22.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser-2.22.dist-info/LICENSE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser-2.22.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser-2.22.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser-2.22.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser-2.22.dist-info/top_level.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/_ast_gen.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/_build_tables.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/_c_ast.cfg create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/ast_transforms.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/c_ast.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/c_generator.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/c_lexer.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/c_parser.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/lextab.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/ply/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/ply/cpp.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/ply/ctokens.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/ply/lex.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/ply/yacc.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/ply/ygen.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/plyparser.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pycparser/yacctab.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pytest-8.3.3.dist-info/AUTHORS create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pytest-8.3.3.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pytest-8.3.3.dist-info/LICENSE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pytest-8.3.3.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pytest-8.3.3.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pytest-8.3.3.dist-info/REQUESTED create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pytest-8.3.3.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pytest-8.3.3.dist-info/entry_points.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pytest-8.3.3.dist-info/top_level.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pytest/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pytest/__main__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/pytest/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests-2.32.3.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests-2.32.3.dist-info/LICENSE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests-2.32.3.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests-2.32.3.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests-2.32.3.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests-2.32.3.dist-info/top_level.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/__version__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/_internal_utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/adapters.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/api.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/auth.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/certs.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/cookies.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/exceptions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/help.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/hooks.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/models.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/packages.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/sessions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/status_codes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/structures.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/requests/utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools-66.1.1.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools-66.1.1.dist-info/LICENSE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools-66.1.1.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools-66.1.1.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools-66.1.1.dist-info/REQUESTED create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools-66.1.1.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools-66.1.1.dist-info/entry_points.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools-66.1.1.dist-info/top_level.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_deprecation_warning.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/_collections.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/_functools.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/_log.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/_macos_compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/_msvccompiler.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/archive_util.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/bcppcompiler.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/ccompiler.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/cmd.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/_framework_compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/bdist.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/bdist_dumb.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/bdist_rpm.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/build.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/build_clib.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/build_ext.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/build_py.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/build_scripts.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/check.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/clean.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/config.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/install.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/install_data.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/install_egg_info.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/install_headers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/install_lib.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/install_scripts.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/py37compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/register.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/sdist.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/command/upload.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/config.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/core.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/cygwinccompiler.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/debug.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/dep_util.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/dir_util.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/dist.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/errors.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/extension.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/fancy_getopt.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/file_util.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/filelist.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/log.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/msvc9compiler.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/msvccompiler.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/py38compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/py39compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/spawn.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/sysconfig.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/text_file.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/unixccompiler.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/util.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/version.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_distutils/versionpredicate.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_entry_points.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_imp.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_importlib.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_itertools.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_path.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_reqs.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_metadata/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_metadata/_adapters.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_metadata/_collections.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_metadata/_compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_metadata/_functools.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_metadata/_itertools.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_metadata/_meta.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_metadata/_text.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_resources/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_resources/_adapters.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_resources/_common.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_resources/_compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_resources/_itertools.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_resources/_legacy.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_resources/abc.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_resources/readers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/importlib_resources/simple.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/jaraco/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/jaraco/context.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/jaraco/functools.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/jaraco/text/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/more_itertools/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/more_itertools/more.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/more_itertools/recipes.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/ordered_set.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/packaging/__about__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/packaging/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/packaging/_manylinux.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/packaging/_musllinux.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/packaging/_structures.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/packaging/markers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/packaging/requirements.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/packaging/specifiers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/packaging/tags.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/packaging/utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/packaging/version.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/pyparsing/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/pyparsing/actions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/pyparsing/common.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/pyparsing/core.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/pyparsing/diagram/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/pyparsing/exceptions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/pyparsing/helpers.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/pyparsing/results.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/pyparsing/testing.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/pyparsing/unicode.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/pyparsing/util.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/tomli/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/tomli/_parser.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/tomli/_re.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/tomli/_types.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/typing_extensions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/_vendor/zipp.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/archive_util.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/build_meta.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/cli-32.exe create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/cli-64.exe create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/cli-arm64.exe create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/cli.exe create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/alias.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/bdist_egg.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/bdist_rpm.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/build.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/build_clib.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/build_ext.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/build_py.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/develop.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/dist_info.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/easy_install.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/editable_wheel.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/egg_info.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/install.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/install_egg_info.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/install_lib.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/install_scripts.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/launcher manifest.xml create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/py36compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/register.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/rotate.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/saveopts.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/sdist.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/setopt.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/test.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/upload.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/command/upload_docs.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/config/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/config/_apply_pyprojecttoml.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/config/_validate_pyproject/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/config/_validate_pyproject/error_reporting.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/config/_validate_pyproject/extra_validations.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/config/_validate_pyproject/fastjsonschema_exceptions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/config/_validate_pyproject/fastjsonschema_validations.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/config/_validate_pyproject/formats.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/config/expand.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/config/pyprojecttoml.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/config/setupcfg.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/dep_util.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/depends.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/discovery.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/dist.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/errors.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/extension.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/extern/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/glob.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/gui-32.exe create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/gui-64.exe create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/gui-arm64.exe create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/gui.exe create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/installer.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/launch.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/logging.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/monkey.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/msvc.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/namespaces.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/package_index.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/py34compat.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/sandbox.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/script (dev).tmpl create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/script.tmpl create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/unicode_utils.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/version.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/wheel.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/setuptools/windows_support.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/typing_extensions-4.12.2.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/typing_extensions-4.12.2.dist-info/LICENSE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/typing_extensions-4.12.2.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/typing_extensions-4.12.2.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/typing_extensions-4.12.2.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/typing_extensions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3-2.2.3.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3-2.2.3.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3-2.2.3.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3-2.2.3.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3-2.2.3.dist-info/licenses/LICENSE.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/_base_connection.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/_collections.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/_request_methods.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/_version.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/connection.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/connectionpool.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/contrib/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/contrib/emscripten/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/contrib/emscripten/connection.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/contrib/emscripten/emscripten_fetch_worker.js create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/contrib/emscripten/fetch.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/contrib/emscripten/request.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/contrib/emscripten/response.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/contrib/pyopenssl.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/contrib/socks.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/exceptions.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/fields.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/filepost.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/http2/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/http2/connection.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/http2/probe.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/poolmanager.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/py.typed create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/response.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/util/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/util/connection.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/util/proxy.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/util/request.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/util/response.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/util/retry.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/util/ssl_.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/util/ssl_match_hostname.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/util/ssltransport.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/util/timeout.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/util/url.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/util/util.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/urllib3/util/wait.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/wrapt-1.16.0.dist-info/INSTALLER create mode 100644 PyGC/.venv/lib/python3.11/site-packages/wrapt-1.16.0.dist-info/LICENSE create mode 100644 PyGC/.venv/lib/python3.11/site-packages/wrapt-1.16.0.dist-info/METADATA create mode 100644 PyGC/.venv/lib/python3.11/site-packages/wrapt-1.16.0.dist-info/RECORD create mode 100644 PyGC/.venv/lib/python3.11/site-packages/wrapt-1.16.0.dist-info/WHEEL create mode 100644 PyGC/.venv/lib/python3.11/site-packages/wrapt-1.16.0.dist-info/top_level.txt create mode 100644 PyGC/.venv/lib/python3.11/site-packages/wrapt/__init__.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/wrapt/__wrapt__.py create mode 100755 PyGC/.venv/lib/python3.11/site-packages/wrapt/_wrappers.cpython-311-aarch64-linux-gnu.so create mode 100644 PyGC/.venv/lib/python3.11/site-packages/wrapt/arguments.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/wrapt/decorators.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/wrapt/importer.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/wrapt/patches.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/wrapt/weakrefs.py create mode 100644 PyGC/.venv/lib/python3.11/site-packages/wrapt/wrappers.py create mode 120000 PyGC/.venv/lib64 create mode 100644 PyGC/.venv/pyvenv.cfg create mode 100644 PyGC/README.md create mode 100644 PyGC/bot/__init__.py create mode 100644 PyGC/bot/arithmetic/__init__.py create mode 100644 PyGC/bot/arithmetic/arithmetic_checker.py create mode 100644 PyGC/bot/bitwise/__init__.py create mode 100644 PyGC/bot/bitwise/bitwise_checker.py create mode 100644 PyGC/bot/comparison/__init__.py create mode 100644 PyGC/bot/comparison/comparison_checker.py create mode 100644 PyGC/bot/config_parser.py create mode 100644 PyGC/bot/guideline_parser.py create mode 100644 PyGC/bot/identity_membership/__init__.py create mode 100644 PyGC/bot/identity_membership/identity_checker.py create mode 100644 PyGC/bot/identity_membership/membership_checker.py create mode 100644 PyGC/bot/logical/__init__.py create mode 100644 PyGC/bot/logical/logical_checker.py create mode 100644 PyGC/bot/utils.py create mode 100644 PyGC/pytest.ini create mode 100644 PyGC/requirements.txt create mode 100644 PyGC/sample_code/sample_code.py create mode 100644 PyGC/tests/test_arithmetic_checker.py create mode 100644 PyGC/tests/test_bitwise_checker.py create mode 100644 PyGC/tests/test_comparison_checker.py create mode 100644 PyGC/tests/test_identity_checker.py create mode 100644 PyGC/tests/test_logical_checker.py create mode 100644 PyGC/tests/test_membership_checker.py create mode 100644 PyGC/tests/test_operator_detection.py delete mode 100644 README.md delete mode 100644 calculator.js delete mode 100644 index.html delete mode 100644 styles.css diff --git a/PyGC/.github/workflows/python-checkers.yaml b/PyGC/.github/workflows/python-checkers.yaml new file mode 100644 index 0000000..9228654 --- /dev/null +++ b/PyGC/.github/workflows/python-checkers.yaml @@ -0,0 +1,35 @@ +name: PyGC Operator Checker CI + +on: + push: + branches: + - main + pull_request: + branches: + - main + +jobs: + test: + runs-on: ubuntu-latest + + strategy: + matrix: + python-version: [3.8, 3.9, 3.10, 3.11] + + steps: + - name: Checkout code + uses: actions/checkout@v3 + + - name: Set up Python ${{ matrix.python-version }} + uses: actions/setup-python@v4 + with: + python-version: ${{ matrix.python-version }} + + - name: Install dependencies + run: | + python -m pip install --upgrade pip + pip install pytest + + - name: Run tests + run: | + PYTHONPATH=. pytest tests/ \ No newline at end of file diff --git a/PyGC/.gitignore b/PyGC/.gitignore new file mode 100644 index 0000000..1235610 --- /dev/null +++ b/PyGC/.gitignore @@ -0,0 +1,5 @@ +.cache +.__pycache__/ +.pytest_cache/ +*.py[cod] +*$py.class \ No newline at end of file diff --git a/PyGC/.pygcconfig b/PyGC/.pygcconfig new file mode 100644 index 0000000..af72be1 --- /dev/null +++ b/PyGC/.pygcconfig @@ -0,0 +1,10 @@ +[operators] +exclude_files = tests/, examples/ +exclude_operators = bitwise, identity + +[guidelines] +read_readme = true +read_contributing = true + +[comparison] +custom_message = "Please avoid using '==' for comparison with None. Use 'is' instead." \ No newline at end of file diff --git a/PyGC/.venv/bin/Activate.ps1 b/PyGC/.venv/bin/Activate.ps1 new file mode 100644 index 0000000..b49d77b --- /dev/null +++ b/PyGC/.venv/bin/Activate.ps1 @@ -0,0 +1,247 @@ +<# +.Synopsis +Activate a Python virtual environment for the current PowerShell session. + +.Description +Pushes the python executable for a virtual environment to the front of the +$Env:PATH environment variable and sets the prompt to signify that you are +in a Python virtual environment. Makes use of the command line switches as +well as the `pyvenv.cfg` file values present in the virtual environment. + +.Parameter VenvDir +Path to the directory that contains the virtual environment to activate. The +default value for this is the parent of the directory that the Activate.ps1 +script is located within. + +.Parameter Prompt +The prompt prefix to display when this virtual environment is activated. By +default, this prompt is the name of the virtual environment folder (VenvDir) +surrounded by parentheses and followed by a single space (ie. '(.venv) '). + +.Example +Activate.ps1 +Activates the Python virtual environment that contains the Activate.ps1 script. + +.Example +Activate.ps1 -Verbose +Activates the Python virtual environment that contains the Activate.ps1 script, +and shows extra information about the activation as it executes. + +.Example +Activate.ps1 -VenvDir C:\Users\MyUser\Common\.venv +Activates the Python virtual environment located in the specified location. + +.Example +Activate.ps1 -Prompt "MyPython" +Activates the Python virtual environment that contains the Activate.ps1 script, +and prefixes the current prompt with the specified string (surrounded in +parentheses) while the virtual environment is active. + +.Notes +On Windows, it may be required to enable this Activate.ps1 script by setting the +execution policy for the user. You can do this by issuing the following PowerShell +command: + +PS C:\> Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser + +For more information on Execution Policies: +https://go.microsoft.com/fwlink/?LinkID=135170 + +#> +Param( + [Parameter(Mandatory = $false)] + [String] + $VenvDir, + [Parameter(Mandatory = $false)] + [String] + $Prompt +) + +<# Function declarations --------------------------------------------------- #> + +<# +.Synopsis +Remove all shell session elements added by the Activate script, including the +addition of the virtual environment's Python executable from the beginning of +the PATH variable. + +.Parameter NonDestructive +If present, do not remove this function from the global namespace for the +session. + +#> +function global:deactivate ([switch]$NonDestructive) { + # Revert to original values + + # The prior prompt: + if (Test-Path -Path Function:_OLD_VIRTUAL_PROMPT) { + Copy-Item -Path Function:_OLD_VIRTUAL_PROMPT -Destination Function:prompt + Remove-Item -Path Function:_OLD_VIRTUAL_PROMPT + } + + # The prior PYTHONHOME: + if (Test-Path -Path Env:_OLD_VIRTUAL_PYTHONHOME) { + Copy-Item -Path Env:_OLD_VIRTUAL_PYTHONHOME -Destination Env:PYTHONHOME + Remove-Item -Path Env:_OLD_VIRTUAL_PYTHONHOME + } + + # The prior PATH: + if (Test-Path -Path Env:_OLD_VIRTUAL_PATH) { + Copy-Item -Path Env:_OLD_VIRTUAL_PATH -Destination Env:PATH + Remove-Item -Path Env:_OLD_VIRTUAL_PATH + } + + # Just remove the VIRTUAL_ENV altogether: + if (Test-Path -Path Env:VIRTUAL_ENV) { + Remove-Item -Path env:VIRTUAL_ENV + } + + # Just remove VIRTUAL_ENV_PROMPT altogether. + if (Test-Path -Path Env:VIRTUAL_ENV_PROMPT) { + Remove-Item -Path env:VIRTUAL_ENV_PROMPT + } + + # Just remove the _PYTHON_VENV_PROMPT_PREFIX altogether: + if (Get-Variable -Name "_PYTHON_VENV_PROMPT_PREFIX" -ErrorAction SilentlyContinue) { + Remove-Variable -Name _PYTHON_VENV_PROMPT_PREFIX -Scope Global -Force + } + + # 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 virtual 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 + } + $env:VIRTUAL_ENV_PROMPT = $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/PyGC/.venv/bin/activate b/PyGC/.venv/bin/activate new file mode 100644 index 0000000..a788fea --- /dev/null +++ b/PyGC/.venv/bin/activate @@ -0,0 +1,69 @@ +# This file must be used with "source bin/activate" *from bash* +# you cannot run it directly + +deactivate () { + # reset old environment variables + if [ -n "${_OLD_VIRTUAL_PATH:-}" ] ; then + PATH="${_OLD_VIRTUAL_PATH:-}" + export PATH + unset _OLD_VIRTUAL_PATH + fi + if [ -n "${_OLD_VIRTUAL_PYTHONHOME:-}" ] ; then + PYTHONHOME="${_OLD_VIRTUAL_PYTHONHOME:-}" + export PYTHONHOME + unset _OLD_VIRTUAL_PYTHONHOME + fi + + # This should detect bash and zsh, which have a hash command that must + # be called to get it to forget past commands. Without forgetting + # past commands the $PATH changes we made may not be respected + if [ -n "${BASH:-}" -o -n "${ZSH_VERSION:-}" ] ; then + hash -r 2> /dev/null + fi + + if [ -n "${_OLD_VIRTUAL_PS1:-}" ] ; then + PS1="${_OLD_VIRTUAL_PS1:-}" + export PS1 + unset _OLD_VIRTUAL_PS1 + fi + + unset VIRTUAL_ENV + unset VIRTUAL_ENV_PROMPT + if [ ! "${1:-}" = "nondestructive" ] ; then + # Self destruct! + unset -f deactivate + fi +} + +# unset irrelevant variables +deactivate nondestructive + +VIRTUAL_ENV="/home/ciao/Desktop/PyGC/.venv" +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:-}" + PS1="(.venv) ${PS1:-}" + export PS1 + VIRTUAL_ENV_PROMPT="(.venv) " + export VIRTUAL_ENV_PROMPT +fi + +# This should detect bash and zsh, which have a hash command that must +# be called to get it to forget past commands. Without forgetting +# past commands the $PATH changes we made may not be respected +if [ -n "${BASH:-}" -o -n "${ZSH_VERSION:-}" ] ; then + hash -r 2> /dev/null +fi diff --git a/PyGC/.venv/bin/activate.csh b/PyGC/.venv/bin/activate.csh new file mode 100644 index 0000000..73945ca --- /dev/null +++ b/PyGC/.venv/bin/activate.csh @@ -0,0 +1,26 @@ +# 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; unsetenv VIRTUAL_ENV_PROMPT; test "\!:*" != "nondestructive" && unalias deactivate' + +# Unset irrelevant variables. +deactivate nondestructive + +setenv VIRTUAL_ENV "/home/ciao/Desktop/PyGC/.venv" + +set _OLD_VIRTUAL_PATH="$PATH" +setenv PATH "$VIRTUAL_ENV/bin:$PATH" + + +set _OLD_VIRTUAL_PROMPT="$prompt" + +if (! "$?VIRTUAL_ENV_DISABLE_PROMPT") then + set prompt = "(.venv) $prompt" + setenv VIRTUAL_ENV_PROMPT "(.venv) " +endif + +alias pydoc python -m pydoc + +rehash diff --git a/PyGC/.venv/bin/activate.fish b/PyGC/.venv/bin/activate.fish new file mode 100644 index 0000000..480fcbc --- /dev/null +++ b/PyGC/.venv/bin/activate.fish @@ -0,0 +1,69 @@ +# This file must be used with "source /bin/activate.fish" *from fish* +# (https://fishshell.com/); you cannot run it directly. + +function deactivate -d "Exit virtual environment 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" + set -e _OLD_FISH_PROMPT_OVERRIDE + # prevents error when using nested fish instances (Issue #93858) + if functions -q _old_fish_prompt + functions -e fish_prompt + functions -c _old_fish_prompt fish_prompt + functions -e _old_fish_prompt + end + end + + set -e VIRTUAL_ENV + set -e VIRTUAL_ENV_PROMPT + if test "$argv[1]" != "nondestructive" + # Self-destruct! + functions -e deactivate + end +end + +# Unset irrelevant variables. +deactivate nondestructive + +set -gx VIRTUAL_ENV "/home/ciao/Desktop/PyGC/.venv" + +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 + + # Output the venv prompt; color taken from the blue of the Python logo. + printf "%s%s%s" (set_color 4B8BBE) "(.venv) " (set_color normal) + + # Restore the return status of the previous command. + echo "exit $old_status" | . + # Output the original/"old" prompt. + _old_fish_prompt + end + + set -gx _OLD_FISH_PROMPT_OVERRIDE "$VIRTUAL_ENV" + set -gx VIRTUAL_ENV_PROMPT "(.venv) " +end diff --git a/PyGC/.venv/bin/normalizer b/PyGC/.venv/bin/normalizer new file mode 100755 index 0000000..3a5404c --- /dev/null +++ b/PyGC/.venv/bin/normalizer @@ -0,0 +1,8 @@ +#!/home/ciao/Desktop/PyGC/.venv/bin/python +# -*- coding: utf-8 -*- +import re +import sys +from charset_normalizer.cli import cli_detect +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(cli_detect()) diff --git a/PyGC/.venv/bin/pip b/PyGC/.venv/bin/pip new file mode 100755 index 0000000..490a00c --- /dev/null +++ b/PyGC/.venv/bin/pip @@ -0,0 +1,8 @@ +#!/home/ciao/Desktop/PyGC/.venv/bin/python +# -*- coding: utf-8 -*- +import re +import sys +from pip._internal.cli.main import main +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/PyGC/.venv/bin/pip3 b/PyGC/.venv/bin/pip3 new file mode 100755 index 0000000..490a00c --- /dev/null +++ b/PyGC/.venv/bin/pip3 @@ -0,0 +1,8 @@ +#!/home/ciao/Desktop/PyGC/.venv/bin/python +# -*- coding: utf-8 -*- +import re +import sys +from pip._internal.cli.main import main +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/PyGC/.venv/bin/pip3.11 b/PyGC/.venv/bin/pip3.11 new file mode 100755 index 0000000..490a00c --- /dev/null +++ b/PyGC/.venv/bin/pip3.11 @@ -0,0 +1,8 @@ +#!/home/ciao/Desktop/PyGC/.venv/bin/python +# -*- coding: utf-8 -*- +import re +import sys +from pip._internal.cli.main import main +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/PyGC/.venv/bin/py.test b/PyGC/.venv/bin/py.test new file mode 100755 index 0000000..a667de8 --- /dev/null +++ b/PyGC/.venv/bin/py.test @@ -0,0 +1,8 @@ +#!/home/ciao/Desktop/PyGC/.venv/bin/python +# -*- coding: utf-8 -*- +import re +import sys +from pytest import console_main +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(console_main()) diff --git a/PyGC/.venv/bin/pytest b/PyGC/.venv/bin/pytest new file mode 100755 index 0000000..a667de8 --- /dev/null +++ b/PyGC/.venv/bin/pytest @@ -0,0 +1,8 @@ +#!/home/ciao/Desktop/PyGC/.venv/bin/python +# -*- coding: utf-8 -*- +import re +import sys +from pytest import console_main +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(console_main()) diff --git a/PyGC/.venv/bin/python b/PyGC/.venv/bin/python new file mode 120000 index 0000000..b8a0adb --- /dev/null +++ b/PyGC/.venv/bin/python @@ -0,0 +1 @@ +python3 \ No newline at end of file diff --git a/PyGC/.venv/bin/python3 b/PyGC/.venv/bin/python3 new file mode 120000 index 0000000..ae65fda --- /dev/null +++ b/PyGC/.venv/bin/python3 @@ -0,0 +1 @@ +/usr/bin/python3 \ No newline at end of file diff --git a/PyGC/.venv/bin/python3.11 b/PyGC/.venv/bin/python3.11 new file mode 120000 index 0000000..b8a0adb --- /dev/null +++ b/PyGC/.venv/bin/python3.11 @@ -0,0 +1 @@ +python3 \ No newline at end of file diff --git a/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/INSTALLER b/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/LICENSE.rst b/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/LICENSE.rst new file mode 100644 index 0000000..191ddaf --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/LICENSE.rst @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2017 Laurent LAPORTE + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. \ No newline at end of file diff --git a/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/METADATA b/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/METADATA new file mode 100644 index 0000000..9ecede2 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/METADATA @@ -0,0 +1,181 @@ +Metadata-Version: 2.1 +Name: Deprecated +Version: 1.2.14 +Summary: Python @deprecated decorator to deprecate old python classes, functions or methods. +Home-page: https://github.com/tantale/deprecated +Author: Laurent LAPORTE +Author-email: tantale.solutions@gmail.com +License: MIT +Project-URL: Documentation, https://deprecated.readthedocs.io/en/latest/ +Project-URL: Source, https://github.com/tantale/deprecated +Project-URL: Bug Tracker, https://github.com/tantale/deprecated/issues +Keywords: deprecate,deprecated,deprecation,warning,warn,decorator +Platform: any +Classifier: Development Status :: 5 - Production/Stable +Classifier: Environment :: Web Environment +Classifier: Intended Audience :: Developers +Classifier: License :: OSI Approved :: MIT License +Classifier: Operating System :: OS Independent +Classifier: Programming Language :: Python +Classifier: Programming Language :: Python :: 2 +Classifier: Programming Language :: Python :: 2.7 +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3.4 +Classifier: Programming Language :: Python :: 3.5 +Classifier: Programming Language :: Python :: 3.6 +Classifier: Programming Language :: Python :: 3.7 +Classifier: Programming Language :: Python :: 3.8 +Classifier: Programming Language :: Python :: 3.9 +Classifier: Programming Language :: Python :: 3.10 +Classifier: Programming Language :: Python :: 3.11 +Classifier: Programming Language :: Python :: 3.12 +Classifier: Topic :: Software Development :: Libraries :: Python Modules +Requires-Python: >=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.* +Description-Content-Type: text/x-rst +License-File: LICENSE.rst +Requires-Dist: wrapt (<2,>=1.10) +Provides-Extra: dev +Requires-Dist: tox ; extra == 'dev' +Requires-Dist: PyTest ; extra == 'dev' +Requires-Dist: PyTest-Cov ; extra == 'dev' +Requires-Dist: bump2version (<1) ; extra == 'dev' +Requires-Dist: sphinx (<2) ; extra == 'dev' + + +Deprecated Library +------------------ + +Deprecated is Easy to Use +````````````````````````` + +If you need to mark a function or a method as deprecated, +you can use the ``@deprecated`` decorator: + +Save in a hello.py: + +.. code:: python + + from deprecated import deprecated + + + @deprecated(version='1.2.1', reason="You should use another function") + def some_old_function(x, y): + return x + y + + + class SomeClass(object): + @deprecated(version='1.3.0', reason="This method is deprecated") + def some_old_method(self, x, y): + return x + y + + + some_old_function(12, 34) + obj = SomeClass() + obj.some_old_method(5, 8) + + +And Easy to Setup +````````````````` + +And run it: + +.. code:: bash + + $ pip install Deprecated + $ python hello.py + hello.py:15: DeprecationWarning: Call to deprecated function (or staticmethod) some_old_function. + (You should use another function) -- Deprecated since version 1.2.0. + some_old_function(12, 34) + hello.py:17: DeprecationWarning: Call to deprecated method some_old_method. + (This method is deprecated) -- Deprecated since version 1.3.0. + obj.some_old_method(5, 8) + + +You can document your code +`````````````````````````` + +Have you ever wonder how to document that some functions, classes, methods, etc. are deprecated? +This is now possible with the integrated Sphinx directives: + +For instance, in hello_sphinx.py: + +.. code:: python + + from deprecated.sphinx import deprecated + from deprecated.sphinx import versionadded + from deprecated.sphinx import versionchanged + + + @versionadded(version='1.0', reason="This function is new") + def function_one(): + '''This is the function one''' + + + @versionchanged(version='1.0', reason="This function is modified") + def function_two(): + '''This is the function two''' + + + @deprecated(version='1.0', reason="This function will be removed soon") + def function_three(): + '''This is the function three''' + + + function_one() + function_two() + function_three() # warns + + help(function_one) + help(function_two) + help(function_three) + + +The result it immediate +``````````````````````` + +Run it: + +.. code:: bash + + $ python hello_sphinx.py + + hello_sphinx.py:23: DeprecationWarning: Call to deprecated function (or staticmethod) function_three. + (This function will be removed soon) -- Deprecated since version 1.0. + function_three() # warns + + Help on function function_one in module __main__: + + function_one() + This is the function one + + .. versionadded:: 1.0 + This function is new + + Help on function function_two in module __main__: + + function_two() + This is the function two + + .. versionchanged:: 1.0 + This function is modified + + Help on function function_three in module __main__: + + function_three() + This is the function three + + .. deprecated:: 1.0 + This function will be removed soon + + +Links +````` + +* `Python package index (PyPi) `_ +* `GitHub website `_ +* `Read The Docs `_ +* `EBook on Lulu.com `_ +* `StackOverFlow Q&A `_ +* `Development version + `_ + diff --git a/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/RECORD b/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/RECORD new file mode 100644 index 0000000..61d27b0 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/RECORD @@ -0,0 +1,12 @@ +Deprecated-1.2.14.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +Deprecated-1.2.14.dist-info/LICENSE.rst,sha256=HoPt0VvkGbXVveNy4yXlJ_9PmRX1SOfHUxS0H2aZ6Dw,1081 +Deprecated-1.2.14.dist-info/METADATA,sha256=xQYvk5nwOfnkxxRD-VHkpE-sMu0IBHRZ8ayspypfkTs,5354 +Deprecated-1.2.14.dist-info/RECORD,, +Deprecated-1.2.14.dist-info/WHEEL,sha256=a-zpFRIJzOq5QfuhBzbhiA1eHTzNCJn8OdRvhdNX0Rk,110 +Deprecated-1.2.14.dist-info/top_level.txt,sha256=nHbOYawKPQQE5lQl-toUB1JBRJjUyn_m_Mb8RVJ0RjA,11 +deprecated/__init__.py,sha256=ZphiULqDVrESSB0mLV2WA88JyhQxZSK44zuDGbV5k-g,349 +deprecated/__pycache__/__init__.cpython-311.pyc,, +deprecated/__pycache__/classic.cpython-311.pyc,, +deprecated/__pycache__/sphinx.cpython-311.pyc,, +deprecated/classic.py,sha256=QugmUi7IhBvp2nDvMtyWqFDPRR43-9nfSZG1ZJSDpFM,9880 +deprecated/sphinx.py,sha256=NqQ0oKGcVn6yUe23iGbCieCgvWbEDQSPt9QelbXJnDU,10258 diff --git a/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/WHEEL b/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/WHEEL new file mode 100644 index 0000000..f771c29 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/WHEEL @@ -0,0 +1,6 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.40.0) +Root-Is-Purelib: true +Tag: py2-none-any +Tag: py3-none-any + diff --git a/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/top_level.txt b/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/top_level.txt new file mode 100644 index 0000000..9f8d550 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/Deprecated-1.2.14.dist-info/top_level.txt @@ -0,0 +1 @@ +deprecated diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/COPYING b/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/COPYING new file mode 100644 index 0000000..94a9ed0 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/COPYING @@ -0,0 +1,674 @@ + GNU GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The GNU General Public License is a free, copyleft license for +software and other kinds of works. + + The licenses for most software and other practical works are designed +to take away your freedom to share and change the works. By contrast, +the GNU General Public License is intended to guarantee your freedom to +share and change all versions of a program--to make sure it remains free +software for all its users. We, the Free Software Foundation, use the +GNU General Public License for most of our software; it applies also to +any other work released this way by its authors. You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +them if you wish), that you receive source code or can get it if you +want it, that you can change the software or use pieces of it in new +free programs, and that you know you can do these things. + + To protect your rights, we need to prevent others from denying you +these rights or asking you to surrender the rights. Therefore, you have +certain responsibilities if you distribute copies of the software, or if +you modify it: responsibilities to respect the freedom of others. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must pass on to the recipients the same +freedoms that you received. You must make sure that they, too, receive +or can get the source code. And you must show them these terms so they +know their rights. + + Developers that use the GNU GPL protect your rights with two steps: +(1) assert copyright on the software, and (2) offer you this License +giving you legal permission to copy, distribute and/or modify it. + + For the developers' and authors' protection, the GPL clearly explains +that there is no warranty for this free software. For both users' and +authors' sake, the GPL requires that modified versions be marked as +changed, so that their problems will not be attributed erroneously to +authors of previous versions. + + Some devices are designed to deny users access to install or run +modified versions of the software inside them, although the manufacturer +can do so. This is fundamentally incompatible with the aim of +protecting users' freedom to change the software. The systematic +pattern of such abuse occurs in the area of products for individuals to +use, which is precisely where it is most unacceptable. Therefore, we +have designed this version of the GPL to prohibit the practice for those +products. If such problems arise substantially in other domains, we +stand ready to extend this provision to those domains in future versions +of the GPL, as needed to protect the freedom of users. + + Finally, every program is threatened constantly by software patents. +States should not allow patents to restrict development and use of +software on general-purpose computers, but in those that do, we wish to +avoid the special danger that patents applied to a free program could +make it effectively proprietary. To prevent this, the GPL assures that +patents cannot be used to render the program non-free. + + The precise terms and conditions for copying, distribution and +modification follow. + + TERMS AND CONDITIONS + + 0. Definitions. + + "This License" refers to version 3 of the GNU General Public License. + + "Copyright" also means copyright-like laws that apply to other kinds of +works, such as semiconductor masks. + + "The Program" refers to any copyrightable work licensed under this +License. Each licensee is addressed as "you". "Licensees" and +"recipients" may be individuals or organizations. + + To "modify" a work means to copy from or adapt all or part of the work +in a fashion requiring copyright permission, other than the making of an +exact copy. The resulting work is called a "modified version" of the +earlier work or a work "based on" the earlier work. + + A "covered work" means either the unmodified Program or a work based +on the Program. + + To "propagate" a work means to do anything with it that, without +permission, would make you directly or secondarily liable for +infringement under applicable copyright law, except executing it on a +computer or modifying a private copy. Propagation includes copying, +distribution (with or without modification), making available to the +public, and in some countries other activities as well. + + To "convey" a work means any kind of propagation that enables other +parties to make or receive copies. Mere interaction with a user through +a computer network, with no transfer of a copy, is not conveying. + + An interactive user interface displays "Appropriate Legal Notices" +to the extent that it includes a convenient and prominently visible +feature that (1) displays an appropriate copyright notice, and (2) +tells the user that there is no warranty for the work (except to the +extent that warranties are provided), that licensees may convey the +work under this License, and how to view a copy of this License. If +the interface presents a list of user commands or options, such as a +menu, a prominent item in the list meets this criterion. + + 1. Source Code. + + The "source code" for a work means the preferred form of the work +for making modifications to it. "Object code" means any non-source +form of a work. + + A "Standard Interface" means an interface that either is an official +standard defined by a recognized standards body, or, in the case of +interfaces specified for a particular programming language, one that +is widely used among developers working in that language. + + The "System Libraries" of an executable work include anything, other +than the work as a whole, that (a) is included in the normal form of +packaging a Major Component, but which is not part of that Major +Component, and (b) serves only to enable use of the work with that +Major Component, or to implement a Standard Interface for which an +implementation is available to the public in source code form. A +"Major Component", in this context, means a major essential component +(kernel, window system, and so on) of the specific operating system +(if any) on which the executable work runs, or a compiler used to +produce the work, or an object code interpreter used to run it. + + The "Corresponding Source" for a work in object code form means all +the source code needed to generate, install, and (for an executable +work) run the object code and to modify the work, including scripts to +control those activities. However, it does not include the work's +System Libraries, or general-purpose tools or generally available free +programs which are used unmodified in performing those activities but +which are not part of the work. For example, Corresponding Source +includes interface definition files associated with source files for +the work, and the source code for shared libraries and dynamically +linked subprograms that the work is specifically designed to require, +such as by intimate data communication or control flow between those +subprograms and other parts of the work. + + The Corresponding Source need not include anything that users +can regenerate automatically from other parts of the Corresponding +Source. + + The Corresponding Source for a work in source code form is that +same work. + + 2. Basic Permissions. + + All rights granted under this License are granted for the term of +copyright on the Program, and are irrevocable provided the stated +conditions are met. This License explicitly affirms your unlimited +permission to run the unmodified Program. The output from running a +covered work is covered by this License only if the output, given its +content, constitutes a covered work. This License acknowledges your +rights of fair use or other equivalent, as provided by copyright law. + + You may make, run and propagate covered works that you do not +convey, without conditions so long as your license otherwise remains +in force. You may convey covered works to others for the sole purpose +of having them make modifications exclusively for you, or provide you +with facilities for running those works, provided that you comply with +the terms of this License in conveying all material for which you do +not control copyright. Those thus making or running the covered works +for you must do so exclusively on your behalf, under your direction +and control, on terms that prohibit them from making any copies of +your copyrighted material outside their relationship with you. + + Conveying under any other circumstances is permitted solely under +the conditions stated below. Sublicensing is not allowed; section 10 +makes it unnecessary. + + 3. Protecting Users' Legal Rights From Anti-Circumvention Law. + + No covered work shall be deemed part of an effective technological +measure under any applicable law fulfilling obligations under article +11 of the WIPO copyright treaty adopted on 20 December 1996, or +similar laws prohibiting or restricting circumvention of such +measures. + + When you convey a covered work, you waive any legal power to forbid +circumvention of technological measures to the extent such circumvention +is effected by exercising rights under this License with respect to +the covered work, and you disclaim any intention to limit operation or +modification of the work as a means of enforcing, against the work's +users, your or third parties' legal rights to forbid circumvention of +technological measures. + + 4. Conveying Verbatim Copies. + + You may convey verbatim copies of the Program's source code as you +receive it, in any medium, provided that you conspicuously and +appropriately publish on each copy an appropriate copyright notice; +keep intact all notices stating that this License and any +non-permissive terms added in accord with section 7 apply to the code; +keep intact all notices of the absence of any warranty; and give all +recipients a copy of this License along with the Program. + + You may charge any price or no price for each copy that you convey, +and you may offer support or warranty protection for a fee. + + 5. Conveying Modified Source Versions. + + You may convey a work based on the Program, or the modifications to +produce it from the Program, in the form of source code under the +terms of section 4, provided that you also meet all of these conditions: + + a) The work must carry prominent notices stating that you modified + it, and giving a relevant date. + + b) The work must carry prominent notices stating that it is + released under this License and any conditions added under section + 7. This requirement modifies the requirement in section 4 to + "keep intact all notices". + + c) You must license the entire work, as a whole, under this + License to anyone who comes into possession of a copy. This + License will therefore apply, along with any applicable section 7 + additional terms, to the whole of the work, and all its parts, + regardless of how they are packaged. This License gives no + permission to license the work in any other way, but it does not + invalidate such permission if you have separately received it. + + d) If the work has interactive user interfaces, each must display + Appropriate Legal Notices; however, if the Program has interactive + interfaces that do not display Appropriate Legal Notices, your + work need not make them do so. + + A compilation of a covered work with other separate and independent +works, which are not by their nature extensions of the covered work, +and which are not combined with it such as to form a larger program, +in or on a volume of a storage or distribution medium, is called an +"aggregate" if the compilation and its resulting copyright are not +used to limit the access or legal rights of the compilation's users +beyond what the individual works permit. Inclusion of a covered work +in an aggregate does not cause this License to apply to the other +parts of the aggregate. + + 6. Conveying Non-Source Forms. + + You may convey a covered work in object code form under the terms +of sections 4 and 5, provided that you also convey the +machine-readable Corresponding Source under the terms of this License, +in one of these ways: + + a) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by the + Corresponding Source fixed on a durable physical medium + customarily used for software interchange. + + b) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by a + written offer, valid for at least three years and valid for as + long as you offer spare parts or customer support for that product + model, to give anyone who possesses the object code either (1) a + copy of the Corresponding Source for all the software in the + product that is covered by this License, on a durable physical + medium customarily used for software interchange, for a price no + more than your reasonable cost of physically performing this + conveying of source, or (2) access to copy the + Corresponding Source from a network server at no charge. + + c) Convey individual copies of the object code with a copy of the + written offer to provide the Corresponding Source. This + alternative is allowed only occasionally and noncommercially, and + only if you received the object code with such an offer, in accord + with subsection 6b. + + d) Convey the object code by offering access from a designated + place (gratis or for a charge), and offer equivalent access to the + Corresponding Source in the same way through the same place at no + further charge. You need not require recipients to copy the + Corresponding Source along with the object code. If the place to + copy the object code is a network server, the Corresponding Source + may be on a different server (operated by you or a third party) + that supports equivalent copying facilities, provided you maintain + clear directions next to the object code saying where to find the + Corresponding Source. Regardless of what server hosts the + Corresponding Source, you remain obligated to ensure that it is + available for as long as needed to satisfy these requirements. + + e) Convey the object code using peer-to-peer transmission, provided + you inform other peers where the object code and Corresponding + Source of the work are being offered to the general public at no + charge under subsection 6d. + + A separable portion of the object code, whose source code is excluded +from the Corresponding Source as a System Library, need not be +included in conveying the object code work. + + A "User Product" is either (1) a "consumer product", which means any +tangible personal property which is normally used for personal, family, +or household purposes, or (2) anything designed or sold for incorporation +into a dwelling. In determining whether a product is a consumer product, +doubtful cases shall be resolved in favor of coverage. For a particular +product received by a particular user, "normally used" refers to a +typical or common use of that class of product, regardless of the status +of the particular user or of the way in which the particular user +actually uses, or expects or is expected to use, the product. A product +is a consumer product regardless of whether the product has substantial +commercial, industrial or non-consumer uses, unless such uses represent +the only significant mode of use of the product. + + "Installation Information" for a User Product means any methods, +procedures, authorization keys, or other information required to install +and execute modified versions of a covered work in that User Product from +a modified version of its Corresponding Source. The information must +suffice to ensure that the continued functioning of the modified object +code is in no case prevented or interfered with solely because +modification has been made. + + If you convey an object code work under this section in, or with, or +specifically for use in, a User Product, and the conveying occurs as +part of a transaction in which the right of possession and use of the +User Product is transferred to the recipient in perpetuity or for a +fixed term (regardless of how the transaction is characterized), the +Corresponding Source conveyed under this section must be accompanied +by the Installation Information. But this requirement does not apply +if neither you nor any third party retains the ability to install +modified object code on the User Product (for example, the work has +been installed in ROM). + + The requirement to provide Installation Information does not include a +requirement to continue to provide support service, warranty, or updates +for a work that has been modified or installed by the recipient, or for +the User Product in which it has been modified or installed. Access to a +network may be denied when the modification itself materially and +adversely affects the operation of the network or violates the rules and +protocols for communication across the network. + + Corresponding Source conveyed, and Installation Information provided, +in accord with this section must be in a format that is publicly +documented (and with an implementation available to the public in +source code form), and must require no special password or key for +unpacking, reading or copying. + + 7. Additional Terms. + + "Additional permissions" are terms that supplement the terms of this +License by making exceptions from one or more of its conditions. +Additional permissions that are applicable to the entire Program shall +be treated as though they were included in this License, to the extent +that they are valid under applicable law. If additional permissions +apply only to part of the Program, that part may be used separately +under those permissions, but the entire Program remains governed by +this License without regard to the additional permissions. + + When you convey a copy of a covered work, you may at your option +remove any additional permissions from that copy, or from any part of +it. (Additional permissions may be written to require their own +removal in certain cases when you modify the work.) You may place +additional permissions on material, added by you to a covered work, +for which you have or can give appropriate copyright permission. + + Notwithstanding any other provision of this License, for material you +add to a covered work, you may (if authorized by the copyright holders of +that material) supplement the terms of this License with terms: + + a) Disclaiming warranty or limiting liability differently from the + terms of sections 15 and 16 of this License; or + + b) Requiring preservation of specified reasonable legal notices or + author attributions in that material or in the Appropriate Legal + Notices displayed by works containing it; or + + c) Prohibiting misrepresentation of the origin of that material, or + requiring that modified versions of such material be marked in + reasonable ways as different from the original version; or + + d) Limiting the use for publicity purposes of names of licensors or + authors of the material; or + + e) Declining to grant rights under trademark law for use of some + trade names, trademarks, or service marks; or + + f) Requiring indemnification of licensors and authors of that + material by anyone who conveys the material (or modified versions of + it) with contractual assumptions of liability to the recipient, for + any liability that these contractual assumptions directly impose on + those licensors and authors. + + All other non-permissive additional terms are considered "further +restrictions" within the meaning of section 10. If the Program as you +received it, or any part of it, contains a notice stating that it is +governed by this License along with a term that is a further +restriction, you may remove that term. If a license document contains +a further restriction but permits relicensing or conveying under this +License, you may add to a covered work material governed by the terms +of that license document, provided that the further restriction does +not survive such relicensing or conveying. + + If you add terms to a covered work in accord with this section, you +must place, in the relevant source files, a statement of the +additional terms that apply to those files, or a notice indicating +where to find the applicable terms. + + Additional terms, permissive or non-permissive, may be stated in the +form of a separately written license, or stated as exceptions; +the above requirements apply either way. + + 8. Termination. + + You may not propagate or modify a covered work except as expressly +provided under this License. Any attempt otherwise to propagate or +modify it is void, and will automatically terminate your rights under +this License (including any patent licenses granted under the third +paragraph of section 11). + + However, if you cease all violation of this License, then your +license from a particular copyright holder is reinstated (a) +provisionally, unless and until the copyright holder explicitly and +finally terminates your license, and (b) permanently, if the copyright +holder fails to notify you of the violation by some reasonable means +prior to 60 days after the cessation. + + Moreover, your license from a particular copyright holder is +reinstated permanently if the copyright holder notifies you of the +violation by some reasonable means, this is the first time you have +received notice of violation of this License (for any work) from that +copyright holder, and you cure the violation prior to 30 days after +your receipt of the notice. + + Termination of your rights under this section does not terminate the +licenses of parties who have received copies or rights from you under +this License. If your rights have been terminated and not permanently +reinstated, you do not qualify to receive new licenses for the same +material under section 10. + + 9. Acceptance Not Required for Having Copies. + + You are not required to accept this License in order to receive or +run a copy of the Program. Ancillary propagation of a covered work +occurring solely as a consequence of using peer-to-peer transmission +to receive a copy likewise does not require acceptance. However, +nothing other than this License grants you permission to propagate or +modify any covered work. These actions infringe copyright if you do +not accept this License. Therefore, by modifying or propagating a +covered work, you indicate your acceptance of this License to do so. + + 10. Automatic Licensing of Downstream Recipients. + + Each time you convey a covered work, the recipient automatically +receives a license from the original licensors, to run, modify and +propagate that work, subject to this License. You are not responsible +for enforcing compliance by third parties with this License. + + An "entity transaction" is a transaction transferring control of an +organization, or substantially all assets of one, or subdividing an +organization, or merging organizations. If propagation of a covered +work results from an entity transaction, each party to that +transaction who receives a copy of the work also receives whatever +licenses to the work the party's predecessor in interest had or could +give under the previous paragraph, plus a right to possession of the +Corresponding Source of the work from the predecessor in interest, if +the predecessor has it or can get it with reasonable efforts. + + You may not impose any further restrictions on the exercise of the +rights granted or affirmed under this License. For example, you may +not impose a license fee, royalty, or other charge for exercise of +rights granted under this License, and you may not initiate litigation +(including a cross-claim or counterclaim in a lawsuit) alleging that +any patent claim is infringed by making, using, selling, offering for +sale, or importing the Program or any portion of it. + + 11. Patents. + + A "contributor" is a copyright holder who authorizes use under this +License of the Program or a work on which the Program is based. The +work thus licensed is called the contributor's "contributor version". + + A contributor's "essential patent claims" are all patent claims +owned or controlled by the contributor, whether already acquired or +hereafter acquired, that would be infringed by some manner, permitted +by this License, of making, using, or selling its contributor version, +but do not include claims that would be infringed only as a +consequence of further modification of the contributor version. For +purposes of this definition, "control" includes the right to grant +patent sublicenses in a manner consistent with the requirements of +this License. + + Each contributor grants you a non-exclusive, worldwide, royalty-free +patent license under the contributor's essential patent claims, to +make, use, sell, offer for sale, import and otherwise run, modify and +propagate the contents of its contributor version. + + In the following three paragraphs, a "patent license" is any express +agreement or commitment, however denominated, not to enforce a patent +(such as an express permission to practice a patent or covenant not to +sue for patent infringement). To "grant" such a patent license to a +party means to make such an agreement or commitment not to enforce a +patent against the party. + + If you convey a covered work, knowingly relying on a patent license, +and the Corresponding Source of the work is not available for anyone +to copy, free of charge and under the terms of this License, through a +publicly available network server or other readily accessible means, +then you must either (1) cause the Corresponding Source to be so +available, or (2) arrange to deprive yourself of the benefit of the +patent license for this particular work, or (3) arrange, in a manner +consistent with the requirements of this License, to extend the patent +license to downstream recipients. "Knowingly relying" means you have +actual knowledge that, but for the patent license, your conveying the +covered work in a country, or your recipient's use of the covered work +in a country, would infringe one or more identifiable patents in that +country that you have reason to believe are valid. + + If, pursuant to or in connection with a single transaction or +arrangement, you convey, or propagate by procuring conveyance of, a +covered work, and grant a patent license to some of the parties +receiving the covered work authorizing them to use, propagate, modify +or convey a specific copy of the covered work, then the patent license +you grant is automatically extended to all recipients of the covered +work and works based on it. + + A patent license is "discriminatory" if it does not include within +the scope of its coverage, prohibits the exercise of, or is +conditioned on the non-exercise of one or more of the rights that are +specifically granted under this License. You may not convey a covered +work if you are a party to an arrangement with a third party that is +in the business of distributing software, under which you make payment +to the third party based on the extent of your activity of conveying +the work, and under which the third party grants, to any of the +parties who would receive the covered work from you, a discriminatory +patent license (a) in connection with copies of the covered work +conveyed by you (or copies made from those copies), or (b) primarily +for and in connection with specific products or compilations that +contain the covered work, unless you entered into that arrangement, +or that patent license was granted, prior to 28 March 2007. + + Nothing in this License shall be construed as excluding or limiting +any implied license or other defenses to infringement that may +otherwise be available to you under applicable patent law. + + 12. No Surrender of Others' Freedom. + + If conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot convey a +covered work so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you may +not convey it at all. For example, if you agree to terms that obligate you +to collect a royalty for further conveying from those to whom you convey +the Program, the only way you could satisfy both those terms and this +License would be to refrain entirely from conveying the Program. + + 13. Use with the GNU Affero General Public License. + + Notwithstanding any other provision of this License, you have +permission to link or combine any covered work with a work licensed +under version 3 of the GNU Affero General Public License into a single +combined work, and to convey the resulting work. The terms of this +License will continue to apply to the part which is the covered work, +but the special requirements of the GNU Affero General Public License, +section 13, concerning interaction through a network will apply to the +combination as such. + + 14. Revised Versions of this License. + + The Free Software Foundation may publish revised and/or new versions of +the GNU General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + + Each version is given a distinguishing version number. If the +Program specifies that a certain numbered version of the GNU General +Public License "or any later version" applies to it, you have the +option of following the terms and conditions either of that numbered +version or of any later version published by the Free Software +Foundation. If the Program does not specify a version number of the +GNU General Public License, you may choose any version ever published +by the Free Software Foundation. + + If the Program specifies that a proxy can decide which future +versions of the GNU General Public License can be used, that proxy's +public statement of acceptance of a version permanently authorizes you +to choose that version for the Program. + + Later license versions may give you additional or different +permissions. However, no additional obligations are imposed on any +author or copyright holder as a result of your choosing to follow a +later version. + + 15. Disclaimer of Warranty. + + THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY +APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT +HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY +OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, +THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM +IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF +ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. Limitation of Liability. + + IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS +THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY +GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE +USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF +DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD +PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), +EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF +SUCH DAMAGES. + + 17. Interpretation of Sections 15 and 16. + + If the disclaimer of warranty and limitation of liability provided +above cannot be given local legal effect according to their terms, +reviewing courts shall apply local law that most closely approximates +an absolute waiver of all civil liability in connection with the +Program, unless a warranty or assumption of liability accompanies a +copy of the Program in return for a fee. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +state the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program 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 General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . + +Also add information on how to contact you by electronic and paper mail. + + If the program does terminal interaction, make it output a short +notice like this when it starts in an interactive mode: + + Copyright (C) + This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, your program's commands +might be different; for a GUI interface, you would use an "about box". + + You should also get your employer (if you work as a programmer) or school, +if any, to sign a "copyright disclaimer" for the program, if necessary. +For more information on this, and how to apply and follow the GNU GPL, see +. + + The GNU General Public License does not permit incorporating your program +into proprietary programs. If your program is a subroutine library, you +may consider it more useful to permit linking proprietary applications with +the library. If this is what you want to do, use the GNU Lesser General +Public License instead of this License. But first, please read +. diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/COPYING.LESSER b/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/COPYING.LESSER new file mode 100644 index 0000000..65c5ca8 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/COPYING.LESSER @@ -0,0 +1,165 @@ + GNU LESSER GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + + This version of the GNU Lesser General Public License incorporates +the terms and conditions of version 3 of the GNU General Public +License, supplemented by the additional permissions listed below. + + 0. Additional Definitions. + + As used herein, "this License" refers to version 3 of the GNU Lesser +General Public License, and the "GNU GPL" refers to version 3 of the GNU +General Public License. + + "The Library" refers to a covered work governed by this License, +other than an Application or a Combined Work as defined below. + + An "Application" is any work that makes use of an interface provided +by the Library, but which is not otherwise based on the Library. +Defining a subclass of a class defined by the Library is deemed a mode +of using an interface provided by the Library. + + A "Combined Work" is a work produced by combining or linking an +Application with the Library. The particular version of the Library +with which the Combined Work was made is also called the "Linked +Version". + + The "Minimal Corresponding Source" for a Combined Work means the +Corresponding Source for the Combined Work, excluding any source code +for portions of the Combined Work that, considered in isolation, are +based on the Application, and not on the Linked Version. + + The "Corresponding Application Code" for a Combined Work means the +object code and/or source code for the Application, including any data +and utility programs needed for reproducing the Combined Work from the +Application, but excluding the System Libraries of the Combined Work. + + 1. Exception to Section 3 of the GNU GPL. + + You may convey a covered work under sections 3 and 4 of this License +without being bound by section 3 of the GNU GPL. + + 2. Conveying Modified Versions. + + If you modify a copy of the Library, and, in your modifications, a +facility refers to a function or data to be supplied by an Application +that uses the facility (other than as an argument passed when the +facility is invoked), then you may convey a copy of the modified +version: + + a) under this License, provided that you make a good faith effort to + ensure that, in the event an Application does not supply the + function or data, the facility still operates, and performs + whatever part of its purpose remains meaningful, or + + b) under the GNU GPL, with none of the additional permissions of + this License applicable to that copy. + + 3. Object Code Incorporating Material from Library Header Files. + + The object code form of an Application may incorporate material from +a header file that is part of the Library. You may convey such object +code under terms of your choice, provided that, if the incorporated +material is not limited to numerical parameters, data structure +layouts and accessors, or small macros, inline functions and templates +(ten or fewer lines in length), you do both of the following: + + a) Give prominent notice with each copy of the object code that the + Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the object code with a copy of the GNU GPL and this license + document. + + 4. Combined Works. + + You may convey a Combined Work under terms of your choice that, +taken together, effectively do not restrict modification of the +portions of the Library contained in the Combined Work and reverse +engineering for debugging such modifications, if you also do each of +the following: + + a) Give prominent notice with each copy of the Combined Work that + the Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the Combined Work with a copy of the GNU GPL and this license + document. + + c) For a Combined Work that displays copyright notices during + execution, include the copyright notice for the Library among + these notices, as well as a reference directing the user to the + copies of the GNU GPL and this license document. + + d) Do one of the following: + + 0) Convey the Minimal Corresponding Source under the terms of this + License, and the Corresponding Application Code in a form + suitable for, and under terms that permit, the user to + recombine or relink the Application with a modified version of + the Linked Version to produce a modified Combined Work, in the + manner specified by section 6 of the GNU GPL for conveying + Corresponding Source. + + 1) Use a suitable shared library mechanism for linking with the + Library. A suitable mechanism is one that (a) uses at run time + a copy of the Library already present on the user's computer + system, and (b) will operate properly with a modified version + of the Library that is interface-compatible with the Linked + Version. + + e) Provide Installation Information, but only if you would otherwise + be required to provide such information under section 6 of the + GNU GPL, and only to the extent that such information is + necessary to install and execute a modified version of the + Combined Work produced by recombining or relinking the + Application with a modified version of the Linked Version. (If + you use option 4d0, the Installation Information must accompany + the Minimal Corresponding Source and Corresponding Application + Code. If you use option 4d1, you must provide the Installation + Information in the manner specified by section 6 of the GNU GPL + for conveying Corresponding Source.) + + 5. Combined Libraries. + + You may place library facilities that are a work based on the +Library side by side in a single library together with other library +facilities that are not Applications and are not covered by this +License, and convey such a combined library under terms of your +choice, if you do both of the following: + + a) Accompany the combined library with a copy of the same work based + on the Library, uncombined with any other library facilities, + conveyed under the terms of this License. + + b) Give prominent notice with the combined library that part of it + is a work based on the Library, and explaining where to find the + accompanying uncombined form of the same work. + + 6. Revised Versions of the GNU Lesser General Public License. + + The Free Software Foundation may publish revised and/or new versions +of the GNU Lesser General Public License from time to time. Such new +versions will be similar in spirit to the present version, but may +differ in detail to address new problems or concerns. + + Each version is given a distinguishing version number. If the +Library as you received it specifies that a certain numbered version +of the GNU Lesser General Public License "or any later version" +applies to it, you have the option of following the terms and +conditions either of that published version or of any later version +published by the Free Software Foundation. If the Library as you +received it does not specify a version number of the GNU Lesser +General Public License, you may choose any version of the GNU Lesser +General Public License ever published by the Free Software Foundation. + + If the Library as you received it specifies that a proxy can decide +whether future versions of the GNU Lesser General Public License shall +apply, that proxy's public statement of acceptance of any version is +permanent authorization for you to choose that version for the +Library. diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/INSTALLER b/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/METADATA b/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/METADATA new file mode 100644 index 0000000..1fe34fe --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/METADATA @@ -0,0 +1,103 @@ +Metadata-Version: 2.1 +Name: PyGithub +Version: 2.4.0 +Summary: Use the full Github API v3 +Author-email: Vincent Jacques +Project-URL: Documentation, https://pygithub.readthedocs.io/en/stable/ +Project-URL: Source, https://github.com/pygithub/pygithub +Project-URL: Tracker, https://github.com/pygithub/pygithub/issues +Keywords: github +Classifier: Development Status :: 5 - Production/Stable +Classifier: Environment :: Web Environment +Classifier: Intended Audience :: Developers +Classifier: License :: OSI Approved :: GNU Library or Lesser General Public License (LGPL) +Classifier: Operating System :: OS Independent +Classifier: Programming Language :: Python +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3.8 +Classifier: Programming Language :: Python :: 3.9 +Classifier: Programming Language :: Python :: 3.10 +Classifier: Programming Language :: Python :: 3.11 +Classifier: Programming Language :: Python :: 3.12 +Classifier: Topic :: Software Development +Requires-Python: >=3.8 +Description-Content-Type: text/markdown +License-File: COPYING +License-File: COPYING.LESSER +Requires-Dist: pynacl >=1.4.0 +Requires-Dist: requests >=2.14.0 +Requires-Dist: pyjwt[crypto] >=2.4.0 +Requires-Dist: typing-extensions >=4.0.0 +Requires-Dist: urllib3 >=1.26.0 +Requires-Dist: Deprecated +Provides-Extra: integrations + +# PyGitHub + +[![PyPI](https://img.shields.io/pypi/v/PyGithub.svg)](https://pypi.python.org/pypi/PyGithub) +![CI](https://github.com/PyGithub/PyGithub/workflows/CI/badge.svg) +[![readthedocs](https://img.shields.io/badge/docs-stable-brightgreen.svg?style=flat)](https://pygithub.readthedocs.io/en/stable/?badge=stable) +[![License](https://img.shields.io/badge/license-LGPL-blue.svg)](https://en.wikipedia.org/wiki/GNU_Lesser_General_Public_License) +[![Slack](https://img.shields.io/badge/Slack%20channel-%20%20-blue.svg)](https://join.slack.com/t/pygithub-project/shared_invite/zt-duj89xtx-uKFZtgAg209o6Vweqm8xeQ) +[![Open Source Helpers](https://www.codetriage.com/pygithub/pygithub/badges/users.svg)](https://www.codetriage.com/pygithub/pygithub) +[![codecov](https://codecov.io/gh/PyGithub/PyGithub/branch/master/graph/badge.svg)](https://codecov.io/gh/PyGithub/PyGithub) +[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black) + +PyGitHub is a Python library to access the [GitHub REST API]. +This library enables you to manage [GitHub] resources such as repositories, user profiles, and organizations in your Python applications. + +[GitHub REST API]: https://docs.github.com/en/rest +[GitHub]: https://github.com + +## Install + +```bash +pip install PyGithub +``` + +## Simple Demo + +```python +from github import Github + +# Authentication is defined via github.Auth +from github import Auth + +# using an access token +auth = Auth.Token("access_token") + +# First create a Github instance: + +# Public Web Github +g = Github(auth=auth) + +# Github Enterprise with custom hostname +g = Github(base_url="https://{hostname}/api/v3", auth=auth) + +# Then play with your Github objects: +for repo in g.get_user().get_repos(): + print(repo.name) + +# To close connections after use +g.close() +``` + +## Documentation + +More information can be found on the [PyGitHub documentation site.](https://pygithub.readthedocs.io/en/stable/introduction.html) + +## Development + +### Contributing + +Long-term discussion and bug reports are maintained via GitHub Issues. +Code review is done via GitHub Pull Requests. + +For more information read [CONTRIBUTING.md]. + +[CONTRIBUTING.md]: https://github.com/PyGithub/PyGithub/blob/main/CONTRIBUTING.md + +### Maintainership + +We're actively seeking maintainers that will triage issues and pull requests and cut releases. +If you work on a project that leverages PyGitHub and have a vested interest in keeping the code alive and well, send an email to someone in the MAINTAINERS file. diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/RECORD b/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/RECORD new file mode 100644 index 0000000..7cebe8a --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/RECORD @@ -0,0 +1,309 @@ +PyGithub-2.4.0.dist-info/COPYING,sha256=jOtLnuWt7d5Hsx6XXB2QxzrSe2sWWh3NgMfFRetluQM,35147 +PyGithub-2.4.0.dist-info/COPYING.LESSER,sha256=2n6rt7r999OuXp8iOqW9we7ORaxWncIbOwN1ILRGR2g,7651 +PyGithub-2.4.0.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +PyGithub-2.4.0.dist-info/METADATA,sha256=m4mDrekWsYyAw-chw_7f-1SUQBWo4wNzvnKuEWQXiVw,3894 +PyGithub-2.4.0.dist-info/RECORD,, +PyGithub-2.4.0.dist-info/REQUESTED,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +PyGithub-2.4.0.dist-info/WHEEL,sha256=Mdi9PDNwEZptOjTlUcAth7XJDFtKrHYaQMPulZeBCiQ,91 +PyGithub-2.4.0.dist-info/top_level.txt,sha256=X_Dn8Q-zPGudQV37mRBM5uHhwhEsv4x1AeAuB1dfEls,7 +github/AccessToken.py,sha256=Ho5squigT1eqknZ-zh9W6NBuSOV0O24ChhbeQ7AHo00,6675 +github/AdvisoryBase.py,sha256=QFIgDxvQShhYL6SBY7-1ruUHNjTmhiQ1oRqUdaM___0,6789 +github/AdvisoryCredit.py,sha256=HbQb7H0suCep7qB6fZtbNJWWd54H4TYhhwJaa275yjs,4846 +github/AdvisoryCreditDetailed.py,sha256=zCADaDC1v814Lbuu9Zl9VrBZhMrVKQw1_AdiT1aJOJk,4749 +github/AdvisoryVulnerability.py,sha256=MkvdNNl4smtNduKf0hCn4YhdxXlIo-Kwet1jabNm4-k,7951 +github/AdvisoryVulnerabilityPackage.py,sha256=xU9S1LN8OgjzW_f87cHT846W4nvoVLoEZscyBlu82RA,4577 +github/AppAuthentication.py,sha256=8ItYtxH1Z3qUCFiI5pIrUgWkfxrNfDtv_PTLlhAUhCs,3362 +github/ApplicationOAuth.py,sha256=ekjprfBqJvSwNraI_os-NHk37BF8TAWb12b5TaB58uw,8213 +github/Artifact.py,sha256=NbWSK1drsl0Rdj9u3yLn_vdCo0pwl1YQ0zZR1kNNTuQ,8207 +github/Auth.py,sha256=wWkgkDac6HCChuaIe-qehr5LkWYolIJ791pt5XyaLew,17581 +github/AuthenticatedUser.py,sha256=OSb3HhKNP9WlvLxZ09vBee7rY3XZxqUjN9qpIHo76GQ,51025 +github/Authorization.py,sha256=X1HngQla9ail9EMVvd7hIYe3D7iD8bkP7VOEyEn5Oi8,8589 +github/AuthorizationApplication.py,sha256=AO_iJkla_Z-SlGBdjDgU4vdIhQvC-xyi3g9ZavwLPXY,3912 +github/Autolink.py,sha256=T-p1YyP6tRxes4gpe2DiTrYKajJlyaZ238MI0Mg3rG8,4789 +github/Branch.py,sha256=x28hQIkzbHyMVplgRFKnYg-YQnKmtJHS-rgmTeSl5T0,29018 +github/BranchProtection.py,sha256=R-ga8zqAnoLr63WLCoEFK0LdctTyl6u_ytowV2WMRrI,8743 +github/CVSS.py,sha256=hruE5zu6KDJP35Bb5SkkEmdry73hWktgxQWucTUDwEg,4577 +github/CWE.py,sha256=liISfggat6zcylarfj0SB67SIBNuTHJjVcPmoOUuzxg,4072 +github/CheckRun.py,sha256=XGBq2lZtlOeWiuvK7-1rbyRZGDNO1emFrOBuUyDDMWk,11581 +github/CheckRunAnnotation.py,sha256=M63swAYDM__Og-gxdhpr5SKZ55Rj7_My0iNdWc47jkU,5181 +github/CheckRunOutput.py,sha256=ULETFVUqpbbumPz4I7gowu-11za2jX6DHfjHxFMF9Dg,4882 +github/CheckSuite.py,sha256=PK5V6SVpr7t1p4LlMJ0ibPVCw6950ik6Ra9IMr5djpw,11437 +github/Clones.py,sha256=yTfOrwLuD0vYW11KvvasfiS5J6mhAR5kCkGc_Gs-KLg,4595 +github/CodeScanAlert.py,sha256=wYT57fX9lbIvL8Be1PiB6WLneo08hz1GVGAtrZBBkpY,7086 +github/CodeScanAlertInstance.py,sha256=TKjb7xxMOjI6pZjr8u-kB6-kzSyRuRcqku7xC6739i8,5382 +github/CodeScanAlertInstanceLocation.py,sha256=NLWa7MT9CAxviNYgZpUQOagvYOremlgdrz9zhxJn744,4458 +github/CodeScanRule.py,sha256=pIDnP6hoEIs44OMu9j2uS2fZwx2vZrjKYSS2NWbDTQs,5101 +github/CodeScanTool.py,sha256=ZmAjad3HPKH_z8qljLT1REy7EIGbEe6UAeJKA3p9jQo,4464 +github/Commit.py,sha256=WeDe5lcuuY1RE1T0S5NGnQCuijtAmVWIsBJNhdl0hbY,13743 +github/CommitCombinedStatus.py,sha256=2BhQh7xXol3p-gkJ1to23bTVf1uTOmr38uj3agZ7LlQ,5811 +github/CommitComment.py,sha256=4D7z-JhEBioCvink3z-YWb2rTrnTDIOeXNP5_f90Ohc,10200 +github/CommitStats.py,sha256=jAet09FSHhVIRjJN0Tu5nHvGHrbIN5BcwI_kgrmY0gM,3776 +github/CommitStatus.py,sha256=XY6ZstVmEHDR9qkgLJfF3AXBV0NuDYl_yjHc8gdK_30,6280 +github/Comparison.py,sha256=T8nCZoh7GtLynoFkcZZNhP5lHFSmEUb6vkuE8JhFAFo,7952 +github/Consts.py,sha256=GJUQi2O4WHJTjNyB42fYj5x2eQFDrm8aQhfB7ahicRQ,10492 +github/ContentFile.py,sha256=25V55p_fpsH5oEO3Fq1OKjnUj9F3rOp4xtfxGHvuLa8,9058 +github/DependabotAlert.py,sha256=o5YU4saJm2iphVUCiCSNqCshFvMMRsioZCHgevazCQs,7215 +github/DependabotAlertAdvisory.py,sha256=ufe1jqrCeaURRoDo7aXmCN9xFvo9UpeGat4b9AoO8xo,3411 +github/DependabotAlertDependency.py,sha256=oGwuVs7I0d43T8q5lY1MEh-vnV_qjLvXCj_LJmF-kJ8,3282 +github/DependabotAlertVulnerability.py,sha256=sf-vdO-D6bRK4_49VtivA0ctmw3MgiH3S9xRPWxGAjw,3682 +github/Deployment.py,sha256=LRhK3v5ktdIRV7TvKrDYy8dsG4BY5AlhyhGDs81-97U,12542 +github/DeploymentStatus.py,sha256=5fLtZAmehuWWCgmJOZ-Xc2JlExYNkP7rQgCLjvctcLQ,8295 +github/Download.py,sha256=MKVNGIqD4kZo5fhdF2HUnyweLnPcgs7nWuQSMAbo1Kk,11218 +github/Enterprise.py,sha256=OaXJMTwQyHCIq2nAi3PUdUkLDTe2Nngmuw-bB2BaiHw,5252 +github/EnterpriseConsumedLicenses.py,sha256=b1w7g1vpWqEwToXodOyuxiNyU1ifN7CRfZz1UJg69iE,5663 +github/Environment.py,sha256=gJGYOBOztzSA39mtl0EXUTUjQ1VHR5RvMZ340-dUxWs,13542 +github/EnvironmentDeploymentBranchPolicy.py,sha256=9DbudPyaSoEMld0av2r_9eojRo4mVcCCkP-sOiaLhp0,4009 +github/EnvironmentProtectionRule.py,sha256=Fv6ZzXkmByCVcWzOXIjW-_XM54S31eq9MeXT_HasBhw,5493 +github/EnvironmentProtectionRuleReviewer.py,sha256=yu3YKe78WdtiyT4K-pJV8-7eP17j5c8QwXtGWiXsk00,5105 +github/Event.py,sha256=yCOOwMYFjuGmBuh1sOJghjVR_NQbpe7SHBDgYQgEOCs,6029 +github/File.py,sha256=b1xzGlMyYAFjiVI2T-UXX9zcqscKg9HungQJcxNprt8,6525 +github/Gist.py,sha256=lEzoMg42L-L7zwNaam0VS4UCX8coaNgLDXBZO_QxcEE,14291 +github/GistComment.py,sha256=U3nK6gtFot_tyrZCFPCt8ad2J_yt_X3AtRrPQSh8GL4,6338 +github/GistFile.py,sha256=1mjWgmwm1orgjdgjgetJC51mTGB6ioJxaI-hv5SjEno,4864 +github/GistHistoryState.py,sha256=RYv-56WZXYAkOru-yXPrwgEugV5zvEK7z0N7SyFep9s,10499 +github/GitAuthor.py,sha256=nTJ3Pn4Hw3g1bpQIL5_RFQbR3c0QMyruHgKBYIVbw-A,4099 +github/GitBlob.py,sha256=YPqxfh9XXFP_di1fOGGJFx43exrZ-CCadPqQ1hnuw8A,4945 +github/GitCommit.py,sha256=Z2Fz01wAxrX-l5L_coI9egf4wmCQNoydczF4FKDmJMI,6383 +github/GitObject.py,sha256=0e5lurO5fHHbjmrYoz_NXbWpx2KMCLjE5FLXBIYoI60,4037 +github/GitRef.py,sha256=i1HoWMFuoyrAKfPvnO0-KbEdbcw2Z2435sZCM1zc7p4,5497 +github/GitRelease.py,sha256=yWOvQJrlwPOXfxuQpBMkcMy64h3TQhXykXYxgmkBTq0,16200 +github/GitReleaseAsset.py,sha256=zFBtQ7V38GKC42cqNXiRbzlRCwJgwKi3QitfX8TtitY,8337 +github/GitTag.py,sha256=6fX_ONq9ZN3TXQdPBoFFM35oCwyQ1Z9ETehkt-gCMWE,5660 +github/GitTree.py,sha256=uZMyCueicuPc4Z99QMGIE2hvTzcCbHfdVJ8FTUSi08A,4706 +github/GitTreeElement.py,sha256=Usn78cYBE8m9B8ttS97jC7rAUHAuhGCxSO5nkkOovBs,4796 +github/GithubApp.py,sha256=7c8Kk0wF3tMeu3YHC76Jr_61c_Xg1ky4aM5cA6YhgUs,7864 +github/GithubException.py,sha256=OBCphJtOygdOID_-6pekI13tFoO1xPF_-B6TbvIP-jI,7175 +github/GithubIntegration.py,sha256=Zw52A5KyNwGn_s-L_cwEXCARf9I6GzTyMflGZtj0Dqo,13481 +github/GithubObject.py,sha256=V5m2sZ_Ln8cUX-3AfyHdCAsimQxGuEcPOgsNEgAcV-g,17594 +github/GithubRetry.py,sha256=Rzz4pN-0x5tEZ9Z-q9VrhS04y6rficm9SnSmru6dLH0,12063 +github/GitignoreTemplate.py,sha256=86WW_ZJzSxVCokfzIMymV9ZCwg1Tv4nFoblqTepah4Y,4012 +github/GlobalAdvisory.py,sha256=1SH1AtZEN5dGrKS8OeniBpOF4Hgm1iL2wrOlRderH1c,5840 +github/Hook.py,sha256=8v5DDKqFhhtDNe7gaitwQcgQd1Wkfx_vk1HMYaXnvqY,9370 +github/HookDelivery.py,sha256=COQsBLT650Ch3qn5wIRawrG5BRhZJgCxCx-chLq9ZmY,8838 +github/HookDescription.py,sha256=uiAtb4k8CDPcNG63aal3zyQTTEer7b3cPqh9hm517Lk,4587 +github/HookResponse.py,sha256=LXLXPKk8-R8U4kTvnIl3D6wbO-xwQQUAI5Im4VtNfzo,4088 +github/InputFileContent.py,sha256=U8bCrl2z9KHQhWtxc-fwliIwJDZlcvUbzY8WbhKfIx0,3480 +github/InputGitAuthor.py,sha256=iW7vxND5eUq6Ull_aH7J8iMKfTZ2ejGLtoSoSGGDX2E,3820 +github/InputGitTreeElement.py,sha256=gAq3OTo0NOOmyjqqtNbwk3wagrmaOp1n-XK990tcYss,3933 +github/Installation.py,sha256=YjCsJ3PCsLsx26n9dfZ2-K_xLemn5HDwOsA3btTNnw0,6834 +github/InstallationAuthorization.py,sha256=DRVSfVWZBdH3dsMZWt9qFmcma06XZFnJeSmp1kWiRpU,5290 +github/Invitation.py,sha256=oaITWWB68xjbDFSjv8BeM680ScFm7skCw1ak8JOyKZE,6524 +github/Issue.py,sha256=eM5P39idzNV_E8YM7Gf4QhKnm93hyzzdnq4_oKQBPWc,26781 +github/IssueComment.py,sha256=VCtP4W3CHYKFSb0qP1sLEu38Huh69pv5iUUf57TKtV0,11443 +github/IssueEvent.py,sha256=mzJnY7BPTeTpMMhSe-GTNS48PGh-5leNHSqSbvnwrXI,10216 +github/IssuePullRequest.py,sha256=f9VtOmEOcH25KI7VKn49zdV2Vns23Y03WB-91KWq0vE,3971 +github/Label.py,sha256=JLdiED7vHkg2sjGLA7uxWHxeqNf_xulbPqo_2VtUmqI,6165 +github/License.py,sha256=XjYEBbf9cHeY55G0DOit-du-Auonl-hkh820Zuut6w8,7410 +github/MainClass.py,sha256=itIEvVykpJJpVTLRdm74FVoMUpnmFs0cdzHDquWrVqo,47196 +github/Membership.py,sha256=i5lKaNXi-FNZUpYHATcVXNkge5T5e0dvPO7lIzCsPRE,6059 +github/Migration.py,sha256=r-gJLLtxi4vF0mAPp78LKg-N9Z-Lx9ToPZEDFC-ikEU,9019 +github/Milestone.py,sha256=IbkJmKIwf3ACNd4ZW0KJHkO-71Xy5NTbjfJEl4q1GBs,9784 +github/NamedEnterpriseUser.py,sha256=Gm7LD3YAgZ73aooMnCgXTcuc9QGton-HbuvCk5wOEs0,10462 +github/NamedUser.py,sha256=_JJeAg3p5pCfks-7_BEOoD1WE5p6qVelD1jWXZq0C5Y,28105 +github/Notification.py,sha256=QiCkBqtLBLtcJbVmyiT40eJeEbRcZzIbfbHAZhGnMbQ,8280 +github/NotificationSubject.py,sha256=lsurwDy425VNpbiDw7RA-jpIoZtrMNihz5XGv3CKgig,4787 +github/Organization.py,sha256=j5F8jyeJuWfbpkFksKEk3JAcblPd0tSdziIXSEBt8Qs,70535 +github/OrganizationCustomProperty.py,sha256=Ot-XBO2xBCi0buAGkQfT63AcwaNpYb2ky7jSUxxoRiQ,7333 +github/OrganizationDependabotAlert.py,sha256=EMRkHGQPj_njR0q5_rSH2AzztSF9B4rRP4UCHZdgQn4,2803 +github/OrganizationSecret.py,sha256=91PZWdUnKX5yBA-0VcgeNOOIZmWi-Cw3tcfLoLhWfR4,6255 +github/OrganizationVariable.py,sha256=ab3GQRM9cyZpQZ6gWp5iTO_ImXxd6IkK2pNgO35mQME,5984 +github/PaginatedList.py,sha256=5t05uX5YWria479UbrDF7xVVsuSAd57JKgJB0jzQx-I,13663 +github/Path.py,sha256=3cbofs57awlHG3pHCT_3Ew9-CwG_kBxvelpqmVUQ9Fo,4789 +github/Permissions.py,sha256=ldChLq6KBv7wKFnvmbNl3O0G0IeIlDisl2Qs4vnx2Ng,4899 +github/Plan.py,sha256=k6fybL9UB_Km-OYAlcOSF-xW8TIFWAV_ByPdbmzwbO4,5001 +github/Project.py,sha256=uFtrMahteQC9wuxi451PublSMpoCoTkcMxZW6N5cKuE,11104 +github/ProjectCard.py,sha256=gxfGjFjRFR4nDTWOPCbU7iNoShDj6NewZsxEGM2Yptg,10524 +github/ProjectColumn.py,sha256=KJQO18pGzojC-VNXiPnr5QOKpxNHVLqZZWmfvNo1OD4,9971 +github/PublicKey.py,sha256=qvntkMEHO7AYPW7knQEGw7Hyc0NpPfE47wb-46u_AQE,5256 +github/PullRequest.py,sha256=kr2z8HFf0k7R2AimLS-DITVkybqn2pGrsttypBmXmzE,46492 +github/PullRequestComment.py,sha256=dzxDD9-guYB8M5mb86r-IxKQgdJMPV0vKQ71p3a5oR8,12679 +github/PullRequestMergeStatus.py,sha256=o2x4A_YxXAF-1dMiOAZLP8rbfl-6nbsgkVgU5iYc8c0,4503 +github/PullRequestPart.py,sha256=oy750Cq8bjWcshJGgpN2Q-8V76sugooF8fk2TsdSRn8,4903 +github/PullRequestReview.py,sha256=1QaoLywXUC34yOgt81og_vn6Qv2bmeD6GAtARwjJnzo,7685 +github/Rate.py,sha256=VszVKmsIEpoW_8srh-AgiluV4UpgiQcsfoCIC2cRz6M,4848 +github/RateLimit.py,sha256=QohsNYHFLJi50Pra4InnAEjrYuEskapOpbr5ayxQnz4,4742 +github/Reaction.py,sha256=YauwrJTcoPhUfP85sgMg0FuLRvJceloqktJ6wfXesu8,5576 +github/Referrer.py,sha256=DKTSz4u1bGQhWgff7LAG_mZqZPaXmcqR-AYmYU-l3bE,4537 +github/Repository.py,sha256=tDAWQju-QRtP2yMZsgI9k8uQZ1lt8IErHQCVbGvP2WA,195466 +github/RepositoryAdvisory.py,sha256=FLWLm7NSLUgFqxHrhnsciac931Rt3FM24RcE5eE87AY,16007 +github/RepositoryKey.py,sha256=VMLmB-QV5rz52X2_3KCfd14a2R1ZyPyOFKGUAlOgG74,7320 +github/RepositoryPreferences.py,sha256=RD23UL5LPASlFB_0Opg2BF3nymK3On2ieGzyZ7DAVhM,4385 +github/Requester.py,sha256=XzoGL9h1n3VTwOtQNlh2bEWxDnq02diXBb51ftrcbCY,40675 +github/RequiredPullRequestReviews.py,sha256=p7aYG6w1T1n1BWP2YW21RZ_ay_ZjTxzTXE016D7LTT0,7436 +github/RequiredStatusChecks.py,sha256=c8uS0ojGpbnCMIxwwWn1AzkqUjgeIOrzjb7t1LKnq0w,4671 +github/Secret.py,sha256=BPkv_t48HECRSqpgfpodqoAL0esFeG7KjKLkNb7ePgg,5660 +github/SecurityAndAnalysis.py,sha256=7O369HLCMxz7aCjHEo7bwGLroF-IVpM50uP8vr8HFoE,6878 +github/SecurityAndAnalysisFeature.py,sha256=zXmCPROmfEro-HDfL-zuoIkGXiRhdLEYy5AazkE6VYk,3709 +github/SelfHostedActionsRunner.py,sha256=Hi6d53Aq1sOzgt18NJEbBb-2Tym3HzQKUzd5VrvZqqo,5051 +github/SourceImport.py,sha256=Yjj-UY8sb5bUsoK7cE_XwIHe470RANxjKk8TP0aN_YM,7834 +github/Stargazer.py,sha256=9529EWIPFQJBoFBsxjUu17GmspHkB3GAUetjPxs52Gc,4744 +github/StatsCodeFrequency.py,sha256=VLPEfu-jaz2LY0PMNEy-laEep6HFrbqOTq2gxC0I32E,4123 +github/StatsCommitActivity.py,sha256=9p9mHCRzoDys-e228J0Ztc5BBVfGJrm0Mn6wVh-O3hM,4309 +github/StatsContributor.py,sha256=251xasbUrvsoXv_B4EM0PJrlDRqqUtHCu4LhAyHUJJk,5518 +github/StatsParticipation.py,sha256=kXcqWNA8EyHvxDhFsDy-4tec2GLF1-HuBdvJdd-mhbU,4077 +github/StatsPunchCard.py,sha256=Wn27w7wY6zTTCLHo0Usn08agmZ0VOLJWOYIr0135o-w,3845 +github/Tag.py,sha256=QKOr6qdri-X_TMuLtYq8Vuf8JaVSaeNrYIuwx7SO6d4,4991 +github/Team.py,sha256=7Bvh-c7y-985H6PWLdVe5lMFrZZ3b5Q-lkCwVnI4JkE,21929 +github/TeamDiscussion.py,sha256=Ae_uEV8ixN8-Hcmj6bN8om8jb7xnf8oI-BXcsIPYbcI,9580 +github/TimelineEvent.py,sha256=fRr1iFpXmJZV68Q9h6Fq_TXxxoerK1p1nUvH0YYYnAc,7452 +github/TimelineEventSource.py,sha256=KLWhUDC2YnCcmcVQ29jgXrEQiFjMFA5myVIjVACGATE,4243 +github/Topic.py,sha256=r4aHmZOZ6bLE4sNDl19NY6bOmueG8ZXhLH4PJuET09s,6715 +github/UserKey.py,sha256=9eX8q0FtY69OJSl8rjcCvRyW2oYVEQ8I5ehJg6vCF8A,5516 +github/Variable.py,sha256=xUkJOYEb3mjUUhVyeh-EHjj7j3G6htuUGGiI64AWPoU,5618 +github/View.py,sha256=CGZ7-OF8SPFpM9--DKIzoD2VdBb6b2HkH5Q5B2t1eIE,4579 +github/Workflow.py,sha256=nM8nIpx9vadggJP0KP-NAVNEWd4Nrfv9DsW-xG1PzYw,10471 +github/WorkflowJob.py,sha256=Plwc2Ev6oUPwtDTwhYvbPDhDCDYQQCgiXMOtFemUlGw,10476 +github/WorkflowRun.py,sha256=eoBQmmRMMStal38E9O1HNtwReYUlkwZkBzO8jWRTkPA,15721 +github/WorkflowStep.py,sha256=vloX2qGP9tzjpeAIcU1B_EoY9TLn-Z15QZQnx8I4LeQ,5643 +github/__init__.py,sha256=qsHQlwQf2suIUvPIUo7sEIivU7kWoo3iDwL3XKH261M,5320 +github/__pycache__/AccessToken.cpython-311.pyc,, +github/__pycache__/AdvisoryBase.cpython-311.pyc,, +github/__pycache__/AdvisoryCredit.cpython-311.pyc,, +github/__pycache__/AdvisoryCreditDetailed.cpython-311.pyc,, +github/__pycache__/AdvisoryVulnerability.cpython-311.pyc,, +github/__pycache__/AdvisoryVulnerabilityPackage.cpython-311.pyc,, +github/__pycache__/AppAuthentication.cpython-311.pyc,, +github/__pycache__/ApplicationOAuth.cpython-311.pyc,, +github/__pycache__/Artifact.cpython-311.pyc,, +github/__pycache__/Auth.cpython-311.pyc,, +github/__pycache__/AuthenticatedUser.cpython-311.pyc,, +github/__pycache__/Authorization.cpython-311.pyc,, +github/__pycache__/AuthorizationApplication.cpython-311.pyc,, +github/__pycache__/Autolink.cpython-311.pyc,, +github/__pycache__/Branch.cpython-311.pyc,, +github/__pycache__/BranchProtection.cpython-311.pyc,, +github/__pycache__/CVSS.cpython-311.pyc,, +github/__pycache__/CWE.cpython-311.pyc,, +github/__pycache__/CheckRun.cpython-311.pyc,, +github/__pycache__/CheckRunAnnotation.cpython-311.pyc,, +github/__pycache__/CheckRunOutput.cpython-311.pyc,, +github/__pycache__/CheckSuite.cpython-311.pyc,, +github/__pycache__/Clones.cpython-311.pyc,, +github/__pycache__/CodeScanAlert.cpython-311.pyc,, +github/__pycache__/CodeScanAlertInstance.cpython-311.pyc,, +github/__pycache__/CodeScanAlertInstanceLocation.cpython-311.pyc,, +github/__pycache__/CodeScanRule.cpython-311.pyc,, +github/__pycache__/CodeScanTool.cpython-311.pyc,, +github/__pycache__/Commit.cpython-311.pyc,, +github/__pycache__/CommitCombinedStatus.cpython-311.pyc,, +github/__pycache__/CommitComment.cpython-311.pyc,, +github/__pycache__/CommitStats.cpython-311.pyc,, +github/__pycache__/CommitStatus.cpython-311.pyc,, +github/__pycache__/Comparison.cpython-311.pyc,, +github/__pycache__/Consts.cpython-311.pyc,, +github/__pycache__/ContentFile.cpython-311.pyc,, +github/__pycache__/DependabotAlert.cpython-311.pyc,, +github/__pycache__/DependabotAlertAdvisory.cpython-311.pyc,, +github/__pycache__/DependabotAlertDependency.cpython-311.pyc,, +github/__pycache__/DependabotAlertVulnerability.cpython-311.pyc,, +github/__pycache__/Deployment.cpython-311.pyc,, +github/__pycache__/DeploymentStatus.cpython-311.pyc,, +github/__pycache__/Download.cpython-311.pyc,, +github/__pycache__/Enterprise.cpython-311.pyc,, +github/__pycache__/EnterpriseConsumedLicenses.cpython-311.pyc,, +github/__pycache__/Environment.cpython-311.pyc,, +github/__pycache__/EnvironmentDeploymentBranchPolicy.cpython-311.pyc,, +github/__pycache__/EnvironmentProtectionRule.cpython-311.pyc,, +github/__pycache__/EnvironmentProtectionRuleReviewer.cpython-311.pyc,, +github/__pycache__/Event.cpython-311.pyc,, +github/__pycache__/File.cpython-311.pyc,, +github/__pycache__/Gist.cpython-311.pyc,, +github/__pycache__/GistComment.cpython-311.pyc,, +github/__pycache__/GistFile.cpython-311.pyc,, +github/__pycache__/GistHistoryState.cpython-311.pyc,, +github/__pycache__/GitAuthor.cpython-311.pyc,, +github/__pycache__/GitBlob.cpython-311.pyc,, +github/__pycache__/GitCommit.cpython-311.pyc,, +github/__pycache__/GitObject.cpython-311.pyc,, +github/__pycache__/GitRef.cpython-311.pyc,, +github/__pycache__/GitRelease.cpython-311.pyc,, +github/__pycache__/GitReleaseAsset.cpython-311.pyc,, +github/__pycache__/GitTag.cpython-311.pyc,, +github/__pycache__/GitTree.cpython-311.pyc,, +github/__pycache__/GitTreeElement.cpython-311.pyc,, +github/__pycache__/GithubApp.cpython-311.pyc,, +github/__pycache__/GithubException.cpython-311.pyc,, +github/__pycache__/GithubIntegration.cpython-311.pyc,, +github/__pycache__/GithubObject.cpython-311.pyc,, +github/__pycache__/GithubRetry.cpython-311.pyc,, +github/__pycache__/GitignoreTemplate.cpython-311.pyc,, +github/__pycache__/GlobalAdvisory.cpython-311.pyc,, +github/__pycache__/Hook.cpython-311.pyc,, +github/__pycache__/HookDelivery.cpython-311.pyc,, +github/__pycache__/HookDescription.cpython-311.pyc,, +github/__pycache__/HookResponse.cpython-311.pyc,, +github/__pycache__/InputFileContent.cpython-311.pyc,, +github/__pycache__/InputGitAuthor.cpython-311.pyc,, +github/__pycache__/InputGitTreeElement.cpython-311.pyc,, +github/__pycache__/Installation.cpython-311.pyc,, +github/__pycache__/InstallationAuthorization.cpython-311.pyc,, +github/__pycache__/Invitation.cpython-311.pyc,, +github/__pycache__/Issue.cpython-311.pyc,, +github/__pycache__/IssueComment.cpython-311.pyc,, +github/__pycache__/IssueEvent.cpython-311.pyc,, +github/__pycache__/IssuePullRequest.cpython-311.pyc,, +github/__pycache__/Label.cpython-311.pyc,, +github/__pycache__/License.cpython-311.pyc,, +github/__pycache__/MainClass.cpython-311.pyc,, +github/__pycache__/Membership.cpython-311.pyc,, +github/__pycache__/Migration.cpython-311.pyc,, +github/__pycache__/Milestone.cpython-311.pyc,, +github/__pycache__/NamedEnterpriseUser.cpython-311.pyc,, +github/__pycache__/NamedUser.cpython-311.pyc,, +github/__pycache__/Notification.cpython-311.pyc,, +github/__pycache__/NotificationSubject.cpython-311.pyc,, +github/__pycache__/Organization.cpython-311.pyc,, +github/__pycache__/OrganizationCustomProperty.cpython-311.pyc,, +github/__pycache__/OrganizationDependabotAlert.cpython-311.pyc,, +github/__pycache__/OrganizationSecret.cpython-311.pyc,, +github/__pycache__/OrganizationVariable.cpython-311.pyc,, +github/__pycache__/PaginatedList.cpython-311.pyc,, +github/__pycache__/Path.cpython-311.pyc,, +github/__pycache__/Permissions.cpython-311.pyc,, +github/__pycache__/Plan.cpython-311.pyc,, +github/__pycache__/Project.cpython-311.pyc,, +github/__pycache__/ProjectCard.cpython-311.pyc,, +github/__pycache__/ProjectColumn.cpython-311.pyc,, +github/__pycache__/PublicKey.cpython-311.pyc,, +github/__pycache__/PullRequest.cpython-311.pyc,, +github/__pycache__/PullRequestComment.cpython-311.pyc,, +github/__pycache__/PullRequestMergeStatus.cpython-311.pyc,, +github/__pycache__/PullRequestPart.cpython-311.pyc,, +github/__pycache__/PullRequestReview.cpython-311.pyc,, +github/__pycache__/Rate.cpython-311.pyc,, +github/__pycache__/RateLimit.cpython-311.pyc,, +github/__pycache__/Reaction.cpython-311.pyc,, +github/__pycache__/Referrer.cpython-311.pyc,, +github/__pycache__/Repository.cpython-311.pyc,, +github/__pycache__/RepositoryAdvisory.cpython-311.pyc,, +github/__pycache__/RepositoryKey.cpython-311.pyc,, +github/__pycache__/RepositoryPreferences.cpython-311.pyc,, +github/__pycache__/Requester.cpython-311.pyc,, +github/__pycache__/RequiredPullRequestReviews.cpython-311.pyc,, +github/__pycache__/RequiredStatusChecks.cpython-311.pyc,, +github/__pycache__/Secret.cpython-311.pyc,, +github/__pycache__/SecurityAndAnalysis.cpython-311.pyc,, +github/__pycache__/SecurityAndAnalysisFeature.cpython-311.pyc,, +github/__pycache__/SelfHostedActionsRunner.cpython-311.pyc,, +github/__pycache__/SourceImport.cpython-311.pyc,, +github/__pycache__/Stargazer.cpython-311.pyc,, +github/__pycache__/StatsCodeFrequency.cpython-311.pyc,, +github/__pycache__/StatsCommitActivity.cpython-311.pyc,, +github/__pycache__/StatsContributor.cpython-311.pyc,, +github/__pycache__/StatsParticipation.cpython-311.pyc,, +github/__pycache__/StatsPunchCard.cpython-311.pyc,, +github/__pycache__/Tag.cpython-311.pyc,, +github/__pycache__/Team.cpython-311.pyc,, +github/__pycache__/TeamDiscussion.cpython-311.pyc,, +github/__pycache__/TimelineEvent.cpython-311.pyc,, +github/__pycache__/TimelineEventSource.cpython-311.pyc,, +github/__pycache__/Topic.cpython-311.pyc,, +github/__pycache__/UserKey.cpython-311.pyc,, +github/__pycache__/Variable.cpython-311.pyc,, +github/__pycache__/View.cpython-311.pyc,, +github/__pycache__/Workflow.cpython-311.pyc,, +github/__pycache__/WorkflowJob.cpython-311.pyc,, +github/__pycache__/WorkflowRun.cpython-311.pyc,, +github/__pycache__/WorkflowStep.cpython-311.pyc,, +github/__pycache__/__init__.cpython-311.pyc,, +github/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/REQUESTED b/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/REQUESTED new file mode 100644 index 0000000..e69de29 diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/WHEEL b/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/WHEEL new file mode 100644 index 0000000..50e1e84 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/WHEEL @@ -0,0 +1,5 @@ +Wheel-Version: 1.0 +Generator: setuptools (73.0.1) +Root-Is-Purelib: true +Tag: py3-none-any + diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/top_level.txt b/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/top_level.txt new file mode 100644 index 0000000..345dcda --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyGithub-2.4.0.dist-info/top_level.txt @@ -0,0 +1 @@ +github diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/AUTHORS.rst b/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/AUTHORS.rst new file mode 100644 index 0000000..88e2b6a --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/AUTHORS.rst @@ -0,0 +1,7 @@ +Authors +======= + +``pyjwt`` is currently written and maintained by `Jose Padilla `_. +Originally written and maintained by `Jeff Lindsay `_. + +A full list of contributors can be found on GitHub’s `overview `_. diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/INSTALLER b/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/LICENSE b/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/LICENSE new file mode 100644 index 0000000..fd0ecbc --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2015-2022 José Padilla + +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/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/METADATA b/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/METADATA new file mode 100644 index 0000000..5af31fe --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/METADATA @@ -0,0 +1,97 @@ +Metadata-Version: 2.1 +Name: PyJWT +Version: 2.9.0 +Summary: JSON Web Token implementation in Python +Home-page: https://github.com/jpadilla/pyjwt +Author: Jose Padilla +Author-email: hello@jpadilla.com +License: MIT +Keywords: json,jwt,security,signing,token,web +Classifier: Development Status :: 5 - Production/Stable +Classifier: Intended Audience :: Developers +Classifier: Natural Language :: English +Classifier: License :: OSI Approved :: MIT License +Classifier: Programming Language :: Python +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3 :: Only +Classifier: Programming Language :: Python :: 3.8 +Classifier: Programming Language :: Python :: 3.9 +Classifier: Programming Language :: Python :: 3.10 +Classifier: Programming Language :: Python :: 3.11 +Classifier: Programming Language :: Python :: 3.12 +Classifier: Topic :: Utilities +Requires-Python: >=3.8 +Description-Content-Type: text/x-rst +License-File: LICENSE +License-File: AUTHORS.rst +Provides-Extra: crypto +Requires-Dist: cryptography >=3.4.0 ; extra == 'crypto' +Provides-Extra: dev +Requires-Dist: sphinx ; extra == 'dev' +Requires-Dist: sphinx-rtd-theme ; extra == 'dev' +Requires-Dist: zope.interface ; extra == 'dev' +Requires-Dist: cryptography >=3.4.0 ; extra == 'dev' +Requires-Dist: pytest <7.0.0,>=6.0.0 ; extra == 'dev' +Requires-Dist: coverage[toml] ==5.0.4 ; extra == 'dev' +Requires-Dist: pre-commit ; extra == 'dev' +Provides-Extra: docs +Requires-Dist: sphinx ; extra == 'docs' +Requires-Dist: sphinx-rtd-theme ; extra == 'docs' +Requires-Dist: zope.interface ; extra == 'docs' +Provides-Extra: tests +Requires-Dist: pytest <7.0.0,>=6.0.0 ; extra == 'tests' +Requires-Dist: coverage[toml] ==5.0.4 ; extra == 'tests' + +PyJWT +===== + +.. image:: https://github.com/jpadilla/pyjwt/workflows/CI/badge.svg + :target: https://github.com/jpadilla/pyjwt/actions?query=workflow%3ACI + +.. image:: https://img.shields.io/pypi/v/pyjwt.svg + :target: https://pypi.python.org/pypi/pyjwt + +.. image:: https://codecov.io/gh/jpadilla/pyjwt/branch/master/graph/badge.svg + :target: https://codecov.io/gh/jpadilla/pyjwt + +.. image:: https://readthedocs.org/projects/pyjwt/badge/?version=stable + :target: https://pyjwt.readthedocs.io/en/stable/ + +A Python implementation of `RFC 7519 `_. Original implementation was written by `@progrium `_. + +Installing +---------- + +Install with **pip**: + +.. code-block:: console + + $ pip install PyJWT + + +Usage +----- + +.. code-block:: pycon + + >>> import jwt + >>> encoded = jwt.encode({"some": "payload"}, "secret", algorithm="HS256") + >>> print(encoded) + eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzb21lIjoicGF5bG9hZCJ9.4twFt5NiznN84AWoo1d7KO1T_yoc0Z6XOpOVswacPZg + >>> jwt.decode(encoded, "secret", algorithms=["HS256"]) + {'some': 'payload'} + +Documentation +------------- + +View the full docs online at https://pyjwt.readthedocs.io/en/stable/ + + +Tests +----- + +You can run tests from the project root after cloning with: + +.. code-block:: console + + $ tox diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/RECORD b/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/RECORD new file mode 100644 index 0000000..311a650 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/RECORD @@ -0,0 +1,32 @@ +PyJWT-2.9.0.dist-info/AUTHORS.rst,sha256=klzkNGECnu2_VY7At89_xLBF3vUSDruXk3xwgUBxzwc,322 +PyJWT-2.9.0.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +PyJWT-2.9.0.dist-info/LICENSE,sha256=eXp6ICMdTEM-nxkR2xcx0GtYKLmPSZgZoDT3wPVvXOU,1085 +PyJWT-2.9.0.dist-info/METADATA,sha256=YRmm4Pcq065Rja5Gzuh80YA2groQSgOR8I1Cx0MF8EM,3048 +PyJWT-2.9.0.dist-info/RECORD,, +PyJWT-2.9.0.dist-info/WHEEL,sha256=R0nc6qTxuoLk7ShA2_Y-UWkN8ZdfDBG2B6Eqpz2WXbs,91 +PyJWT-2.9.0.dist-info/top_level.txt,sha256=RP5DHNyJbMq2ka0FmfTgoSaQzh7e3r5XuCWCO8a00k8,4 +jwt/__init__.py,sha256=TlvdnR8JPnAKjXE3Yt4qSA4AApcb0_9fh4RppJfnMcU,1670 +jwt/__pycache__/__init__.cpython-311.pyc,, +jwt/__pycache__/algorithms.cpython-311.pyc,, +jwt/__pycache__/api_jwk.cpython-311.pyc,, +jwt/__pycache__/api_jws.cpython-311.pyc,, +jwt/__pycache__/api_jwt.cpython-311.pyc,, +jwt/__pycache__/exceptions.cpython-311.pyc,, +jwt/__pycache__/help.cpython-311.pyc,, +jwt/__pycache__/jwk_set_cache.cpython-311.pyc,, +jwt/__pycache__/jwks_client.cpython-311.pyc,, +jwt/__pycache__/types.cpython-311.pyc,, +jwt/__pycache__/utils.cpython-311.pyc,, +jwt/__pycache__/warnings.cpython-311.pyc,, +jwt/algorithms.py,sha256=5MLQ2WIhHPiN--67afLk4yXOLsYfx2OiNeLVORZT3G8,29851 +jwt/api_jwk.py,sha256=6F1r7rmm8V5qEnBKA_xMjS9R7VoANe1_BL1oD2FrAjE,4451 +jwt/api_jws.py,sha256=1cBVJuYxo6UrDU6UH4VTA2EqctBj1x7mNlnNb-Ocn4g,11425 +jwt/api_jwt.py,sha256=gsmF7wVxKFfsDBjrMq-M2UiyUBzl6U6YwaEqNdN1zkM,12875 +jwt/exceptions.py,sha256=xaWnosa-cREyXMyb7PYmLfQv9weZ7Q9XUYMiLJvN0hA,1101 +jwt/help.py,sha256=Jrp84fG43sCwmSIaDtY08I6ZR2VE7NhrTff89tYSE40,1749 +jwt/jwk_set_cache.py,sha256=hBKmN-giU7-G37L_XKgc_OZu2ah4wdbj1ZNG_GkoSE8,959 +jwt/jwks_client.py,sha256=9W8JVyGByQgoLbBN1u5iY1_jlgfnnukeOBTpqaM_9SE,4222 +jwt/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +jwt/types.py,sha256=VnhGv_VFu5a7_mrPoSCB7HaNLrJdhM8Sq1sSfEg0gLU,99 +jwt/utils.py,sha256=efS6RKCALEBeBw-uZj8VtzfZFFcECTd28q9ndNn9huw,3544 +jwt/warnings.py,sha256=50XWOnyNsIaqzUJTk6XHNiIDykiL763GYA92MjTKmok,59 diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/WHEEL b/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/WHEEL new file mode 100644 index 0000000..1a9c535 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/WHEEL @@ -0,0 +1,5 @@ +Wheel-Version: 1.0 +Generator: setuptools (72.1.0) +Root-Is-Purelib: true +Tag: py3-none-any + diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/top_level.txt b/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/top_level.txt new file mode 100644 index 0000000..27ccc9b --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyJWT-2.9.0.dist-info/top_level.txt @@ -0,0 +1 @@ +jwt diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/INSTALLER b/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/LICENSE b/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/LICENSE new file mode 100644 index 0000000..91e18a6 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/LICENSE @@ -0,0 +1,174 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + +TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + +1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + +2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + +3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + +4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + +5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + +6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + +7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + +8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + +9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/METADATA b/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/METADATA new file mode 100644 index 0000000..fb216d4 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/METADATA @@ -0,0 +1,245 @@ +Metadata-Version: 2.1 +Name: PyNaCl +Version: 1.5.0 +Summary: Python binding to the Networking and Cryptography (NaCl) library +Home-page: https://github.com/pyca/pynacl/ +Author: The PyNaCl developers +Author-email: cryptography-dev@python.org +License: Apache License 2.0 +Platform: UNKNOWN +Classifier: Programming Language :: Python :: Implementation :: CPython +Classifier: Programming Language :: Python :: Implementation :: PyPy +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3.6 +Classifier: Programming Language :: Python :: 3.7 +Classifier: Programming Language :: Python :: 3.8 +Classifier: Programming Language :: Python :: 3.9 +Classifier: Programming Language :: Python :: 3.10 +Requires-Python: >=3.6 +Requires-Dist: cffi (>=1.4.1) +Provides-Extra: docs +Requires-Dist: sphinx (>=1.6.5) ; extra == 'docs' +Requires-Dist: sphinx-rtd-theme ; extra == 'docs' +Provides-Extra: tests +Requires-Dist: pytest (!=3.3.0,>=3.2.1) ; extra == 'tests' +Requires-Dist: hypothesis (>=3.27.0) ; extra == 'tests' + +=============================================== +PyNaCl: Python binding to the libsodium library +=============================================== + +.. image:: https://img.shields.io/pypi/v/pynacl.svg + :target: https://pypi.org/project/PyNaCl/ + :alt: Latest Version + +.. image:: https://codecov.io/github/pyca/pynacl/coverage.svg?branch=main + :target: https://codecov.io/github/pyca/pynacl?branch=main + +.. image:: https://img.shields.io/pypi/pyversions/pynacl.svg + :target: https://pypi.org/project/PyNaCl/ + :alt: Compatible Python Versions + +PyNaCl is a Python binding to `libsodium`_, which is a fork of the +`Networking and Cryptography library`_. These libraries have a stated goal of +improving usability, security and speed. It supports Python 3.6+ as well as +PyPy 3. + +.. _libsodium: https://github.com/jedisct1/libsodium +.. _Networking and Cryptography library: https://nacl.cr.yp.to/ + +Features +-------- + +* Digital signatures +* Secret-key encryption +* Public-key encryption +* Hashing and message authentication +* Password based key derivation and password hashing + +`Changelog`_ +------------ + +.. _Changelog: https://pynacl.readthedocs.io/en/stable/changelog/ + +Installation +============ + +Binary wheel install +-------------------- + +PyNaCl ships as a binary wheel on macOS, Windows and Linux ``manylinux1`` [#many]_ , +so all dependencies are included. Make sure you have an up-to-date pip +and run: + +.. code-block:: console + + $ pip install pynacl + +Faster wheel build +------------------ + +You can define the environment variable ``LIBSODIUM_MAKE_ARGS`` to pass arguments to ``make`` +and enable `parallelization`_: + +.. code-block:: console + + $ LIBSODIUM_MAKE_ARGS=-j4 pip install pynacl + +Linux source build +------------------ + +PyNaCl relies on `libsodium`_, a portable C library. A copy is bundled +with PyNaCl so to install you can run: + +.. code-block:: console + + $ pip install pynacl + +If you'd prefer to use the version of ``libsodium`` provided by your +distribution, you can disable the bundled copy during install by running: + +.. code-block:: console + + $ SODIUM_INSTALL=system pip install pynacl + +.. warning:: Usage of the legacy ``easy_install`` command provided by setuptools + is generally discouraged, and is completely unsupported in PyNaCl's case. + +.. _parallelization: https://www.gnu.org/software/make/manual/html_node/Parallel.html + +.. _libsodium: https://github.com/jedisct1/libsodium + +.. [#many] `manylinux1 wheels `_ + are built on a baseline linux environment based on Centos 5.11 + and should work on most x86 and x86_64 glibc based linux environments. + +Changelog +========= + +1.5.0 (2022-01-07) +------------------ + +* **BACKWARDS INCOMPATIBLE:** Removed support for Python 2.7 and Python 3.5. +* **BACKWARDS INCOMPATIBLE:** We no longer distribute ``manylinux1`` + wheels. +* Added ``manylinux2014``, ``manylinux_2_24``, ``musllinux``, and macOS + ``universal2`` wheels (the latter supports macOS ``arm64``). +* Update ``libsodium`` to 1.0.18-stable (July 25, 2021 release). +* Add inline type hints. + +1.4.0 (2020-05-25) +------------------ + +* Update ``libsodium`` to 1.0.18. +* **BACKWARDS INCOMPATIBLE:** We no longer distribute 32-bit ``manylinux1`` + wheels. Continuing to produce them was a maintenance burden. +* Added support for Python 3.8, and removed support for Python 3.4. +* Add low level bindings for extracting the seed and the public key + from crypto_sign_ed25519 secret key +* Add low level bindings for deterministic random generation. +* Add ``wheel`` and ``setuptools`` setup_requirements in ``setup.py`` (#485) +* Fix checks on very slow builders (#481, #495) +* Add low-level bindings to ed25519 arithmetic functions +* Update low-level blake2b state implementation +* Fix wrong short-input behavior of SealedBox.decrypt() (#517) +* Raise CryptPrefixError exception instead of InvalidkeyError when trying + to check a password against a verifier stored in a unknown format (#519) +* Add support for minimal builds of libsodium. Trying to call functions + not available in a minimal build will raise an UnavailableError + exception. To compile a minimal build of the bundled libsodium, set + the SODIUM_INSTALL_MINIMAL environment variable to any non-empty + string (e.g. ``SODIUM_INSTALL_MINIMAL=1``) for setup. + +1.3.0 2018-09-26 +---------------- + +* Added support for Python 3.7. +* Update ``libsodium`` to 1.0.16. +* Run and test all code examples in PyNaCl docs through sphinx's + doctest builder. +* Add low-level bindings for chacha20-poly1305 AEAD constructions. +* Add low-level bindings for the chacha20-poly1305 secretstream constructions. +* Add low-level bindings for ed25519ph pre-hashed signing construction. +* Add low-level bindings for constant-time increment and addition + on fixed-precision big integers represented as little-endian + byte sequences. +* Add low-level bindings for the ISO/IEC 7816-4 compatible padding API. +* Add low-level bindings for libsodium's crypto_kx... key exchange + construction. +* Set hypothesis deadline to None in tests/test_pwhash.py to avoid + incorrect test failures on slower processor architectures. GitHub + issue #370 + +1.2.1 - 2017-12-04 +------------------ + +* Update hypothesis minimum allowed version. +* Infrastructure: add proper configuration for readthedocs builder + runtime environment. + +1.2.0 - 2017-11-01 +------------------ + +* Update ``libsodium`` to 1.0.15. +* Infrastructure: add jenkins support for automatic build of + ``manylinux1`` binary wheels +* Added support for ``SealedBox`` construction. +* Added support for ``argon2i`` and ``argon2id`` password hashing constructs + and restructured high-level password hashing implementation to expose + the same interface for all hashers. +* Added support for 128 bit ``siphashx24`` variant of ``siphash24``. +* Added support for ``from_seed`` APIs for X25519 keypair generation. +* Dropped support for Python 3.3. + +1.1.2 - 2017-03-31 +------------------ + +* reorder link time library search path when using bundled + libsodium + +1.1.1 - 2017-03-15 +------------------ + +* Fixed a circular import bug in ``nacl.utils``. + +1.1.0 - 2017-03-14 +------------------ + +* Dropped support for Python 2.6. +* Added ``shared_key()`` method on ``Box``. +* You can now pass ``None`` to ``nonce`` when encrypting with ``Box`` or + ``SecretBox`` and it will automatically generate a random nonce. +* Added support for ``siphash24``. +* Added support for ``blake2b``. +* Added support for ``scrypt``. +* Update ``libsodium`` to 1.0.11. +* Default to the bundled ``libsodium`` when compiling. +* All raised exceptions are defined mixing-in + ``nacl.exceptions.CryptoError`` + +1.0.1 - 2016-01-24 +------------------ + +* Fix an issue with absolute paths that prevented the creation of wheels. + +1.0 - 2016-01-23 +---------------- + +* PyNaCl has been ported to use the new APIs available in cffi 1.0+. + Due to this change we no longer support PyPy releases older than 2.6. +* Python 3.2 support has been dropped. +* Functions to convert between Ed25519 and Curve25519 keys have been added. + +0.3.0 - 2015-03-04 +------------------ + +* The low-level API (`nacl.c.*`) has been changed to match the + upstream NaCl C/C++ conventions (as well as those of other NaCl bindings). + The order of arguments and return values has changed significantly. To + avoid silent failures, `nacl.c` has been removed, and replaced with + `nacl.bindings` (with the new argument ordering). If you have code which + calls these functions (e.g. `nacl.c.crypto_box_keypair()`), you must review + the new docstrings and update your code/imports to match the new + conventions. + + diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/RECORD b/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/RECORD new file mode 100644 index 0000000..70b1bff --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/RECORD @@ -0,0 +1,68 @@ +PyNaCl-1.5.0.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +PyNaCl-1.5.0.dist-info/LICENSE,sha256=0xdK1j5yHUydzLitQyCEiZLTFDabxGMZcgtYAskVP-k,9694 +PyNaCl-1.5.0.dist-info/METADATA,sha256=OJaXCiHgNRywLY9cj3X2euddUPZ4dnyyqAQMU01X4j0,8634 +PyNaCl-1.5.0.dist-info/RECORD,, +PyNaCl-1.5.0.dist-info/WHEEL,sha256=nUMM3xxG4VI9UdMilsynb4sYlCfPsONGGXzvdP2xr2U,188 +PyNaCl-1.5.0.dist-info/top_level.txt,sha256=wfdEOI_G2RIzmzsMyhpqP17HUh6Jcqi99to9aHLEslo,13 +nacl/__init__.py,sha256=0IUunzBT8_Jn0DUdHacBExOYeAEMggo8slkfjo7O0XM,1116 +nacl/__pycache__/__init__.cpython-311.pyc,, +nacl/__pycache__/encoding.cpython-311.pyc,, +nacl/__pycache__/exceptions.cpython-311.pyc,, +nacl/__pycache__/hash.cpython-311.pyc,, +nacl/__pycache__/hashlib.cpython-311.pyc,, +nacl/__pycache__/public.cpython-311.pyc,, +nacl/__pycache__/secret.cpython-311.pyc,, +nacl/__pycache__/signing.cpython-311.pyc,, +nacl/__pycache__/utils.cpython-311.pyc,, +nacl/_sodium.abi3.so,sha256=LAZTFkwOq92YNMoj-EHDg3nH9sSgR8Bz7ycygtk_JC4,1823144 +nacl/bindings/__init__.py,sha256=BDlStrds2EuUS4swOL4pnf92PWVS_CHRCptX3KhEX-s,16997 +nacl/bindings/__pycache__/__init__.cpython-311.pyc,, +nacl/bindings/__pycache__/crypto_aead.cpython-311.pyc,, +nacl/bindings/__pycache__/crypto_box.cpython-311.pyc,, +nacl/bindings/__pycache__/crypto_core.cpython-311.pyc,, +nacl/bindings/__pycache__/crypto_generichash.cpython-311.pyc,, +nacl/bindings/__pycache__/crypto_hash.cpython-311.pyc,, +nacl/bindings/__pycache__/crypto_kx.cpython-311.pyc,, +nacl/bindings/__pycache__/crypto_pwhash.cpython-311.pyc,, +nacl/bindings/__pycache__/crypto_scalarmult.cpython-311.pyc,, +nacl/bindings/__pycache__/crypto_secretbox.cpython-311.pyc,, +nacl/bindings/__pycache__/crypto_secretstream.cpython-311.pyc,, +nacl/bindings/__pycache__/crypto_shorthash.cpython-311.pyc,, +nacl/bindings/__pycache__/crypto_sign.cpython-311.pyc,, +nacl/bindings/__pycache__/randombytes.cpython-311.pyc,, +nacl/bindings/__pycache__/sodium_core.cpython-311.pyc,, +nacl/bindings/__pycache__/utils.cpython-311.pyc,, +nacl/bindings/crypto_aead.py,sha256=BIw1k_JCfr5ylZk0RF5rCFIM1fhfLkEa-aiWkrfffNE,15597 +nacl/bindings/crypto_box.py,sha256=Ox0NG2t4MsGhBAa7Kgah4o0gc99ULMsqkdX56ofOouY,10139 +nacl/bindings/crypto_core.py,sha256=6u9G3y7H-QrawO785UkFFFtwDoCkeHE63GOUl9p5-eA,13736 +nacl/bindings/crypto_generichash.py,sha256=9mX0DGIIzicr-uXrqFM1nU4tirasbixDwbcdfV7W1fc,8852 +nacl/bindings/crypto_hash.py,sha256=Rg1rsEwE3azhsQT-dNVPA4NB9VogJAKn1EfxYt0pPe0,2175 +nacl/bindings/crypto_kx.py,sha256=oZNVlNgROpHOa1XQ_uZe0tqIkdfuApeJlRnwR23_74k,6723 +nacl/bindings/crypto_pwhash.py,sha256=laVDo4xFUuGyEjtZAU510AklBF6ablBy7Z3HN1WDYjY,18848 +nacl/bindings/crypto_scalarmult.py,sha256=_DX-mst2uCnzjo6fP5HRTnhv1BC95B9gmJc3L_or16g,8244 +nacl/bindings/crypto_secretbox.py,sha256=KgZ1VvkCJDlQ85jtfe9c02VofPvuEgZEhWni-aX3MsM,2914 +nacl/bindings/crypto_secretstream.py,sha256=G0FgZS01qA5RzWzm5Bdms8Yy_lvgdZDoUYYBActPmvQ,11165 +nacl/bindings/crypto_shorthash.py,sha256=PQU7djHTLDGdVs-w_TsivjFHHp5EK5k2Yh6p-6z0T60,2603 +nacl/bindings/crypto_sign.py,sha256=53j2im9E4F79qT_2U8IfCAc3lzg0VMwEjvAPEUccVDg,10342 +nacl/bindings/randombytes.py,sha256=uBK3W4WcjgnjZdWanrX0fjYZpr9KHbBgNMl9rui-Ojc,1563 +nacl/bindings/sodium_core.py,sha256=9Y9CX--sq-TaPaQRPRpx8SWDSS9PJOja_Cqb-yqyJNQ,1039 +nacl/bindings/utils.py,sha256=KDwQnadXeNMbqEA1SmpNyCVo5k8MiUQa07QM66VzfXM,4298 +nacl/encoding.py,sha256=qTAPc2MXSkdh4cqDVY0ra6kHyViHMCmEo_re7cgGk5w,2915 +nacl/exceptions.py,sha256=GZH32aJtZgqCO4uz0LRsev8z0WyvAYuV3YVqT9AAQq4,2451 +nacl/hash.py,sha256=EYBOe6UVc9SUQINEmyuRSa1QGRSvdwdrBzTL1tdFLU8,6392 +nacl/hashlib.py,sha256=L5Fv75St8AMPvb-GhA4YqX5p1mC_Sb4HhC1NxNQMpJA,4400 +nacl/public.py,sha256=RVGCWQRjIJOmW-8sNrVLtsDjMMGx30i6UyfViGCnQNA,14792 +nacl/pwhash/__init__.py,sha256=XSDXd7wQHNLEHl0mkHfVb5lFQsp6ygHkhen718h0BSM,2675 +nacl/pwhash/__pycache__/__init__.cpython-311.pyc,, +nacl/pwhash/__pycache__/_argon2.cpython-311.pyc,, +nacl/pwhash/__pycache__/argon2i.cpython-311.pyc,, +nacl/pwhash/__pycache__/argon2id.cpython-311.pyc,, +nacl/pwhash/__pycache__/scrypt.cpython-311.pyc,, +nacl/pwhash/_argon2.py,sha256=jL1ChR9biwYh3RSuc-LJ2-W4DlVLHpir-XHGX8cpeJQ,1779 +nacl/pwhash/argon2i.py,sha256=IIvIuO9siKUu5-Wpz0SGiltLQv7Du_mi9BUE8INRK_4,4405 +nacl/pwhash/argon2id.py,sha256=H22i8O4j9Ws4L3JsXl9TRcJzDcyaVumhQRPzINAgJWM,4433 +nacl/pwhash/scrypt.py,sha256=fMr3Qht1a1EY8aebNNntfLRjinIPXtKYKKrrBhY5LDc,6986 +nacl/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +nacl/secret.py,sha256=kauBNuP-0rb3TjU2EMBMu5Vnmzjnscp1bRqMspy5LzU,12108 +nacl/signing.py,sha256=kbTEUyHLUMaNLv1nCjxzGxCs82Qs5w8gxE_CnEwPuIU,8337 +nacl/utils.py,sha256=gmlTD1x9ZNwzHd8LpALH1CHud-Htv8ejRb3y7TyS9f0,2341 diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/WHEEL b/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/WHEEL new file mode 100644 index 0000000..0aea1c5 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/WHEEL @@ -0,0 +1,7 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.37.1) +Root-Is-Purelib: false +Tag: cp36-abi3-manylinux_2_17_aarch64 +Tag: cp36-abi3-manylinux2014_aarch64 +Tag: cp36-abi3-manylinux_2_24_aarch64 + diff --git a/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/top_level.txt b/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/top_level.txt new file mode 100644 index 0000000..f52507f --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/PyNaCl-1.5.0.dist-info/top_level.txt @@ -0,0 +1,2 @@ +_sodium +nacl diff --git a/PyGC/.venv/lib/python3.11/site-packages/_cffi_backend.cpython-311-aarch64-linux-gnu.so b/PyGC/.venv/lib/python3.11/site-packages/_cffi_backend.cpython-311-aarch64-linux-gnu.so new file mode 100755 index 0000000000000000000000000000000000000000..09c013b5d3d42c95aa8f99661955d8b1a64e341b GIT binary patch literal 1187880 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

|~ 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

2N9)Bq}r`2<$1H; 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 literal 0 HcmV?d00001 diff --git a/PyGC/.venv/lib/python3.11/site-packages/_distutils_hack/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/_distutils_hack/__init__.py new file mode 100644 index 0000000..f987a53 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_distutils_hack/__init__.py @@ -0,0 +1,222 @@ +# don't import any costly modules +import sys +import os + + +is_pypy = '__pypy__' in sys.builtin_module_names + + +def warn_distutils_present(): + if 'distutils' not in sys.modules: + return + if is_pypy and sys.version_info < (3, 7): + # PyPy for 3.6 unconditionally imports distutils, so bypass the warning + # https://foss.heptapod.net/pypy/pypy/-/blob/be829135bc0d758997b3566062999ee8b23872b4/lib-python/3/site.py#L250 + return + import warnings + + warnings.warn( + "Distutils was imported before Setuptools, but importing Setuptools " + "also replaces the `distutils` module in `sys.modules`. This may lead " + "to undesirable behaviors or errors. To avoid these issues, avoid " + "using distutils directly, ensure that setuptools is installed in the " + "traditional way (e.g. not an editable install), and/or make sure " + "that setuptools is always imported before distutils." + ) + + +def clear_distutils(): + if 'distutils' not in sys.modules: + return + import warnings + + warnings.warn("Setuptools is replacing distutils.") + mods = [ + name + for name in sys.modules + if name == "distutils" or name.startswith("distutils.") + ] + for name in mods: + del sys.modules[name] + + +def enabled(): + """ + Allow selection of distutils by environment variable. + """ + which = os.environ.get('SETUPTOOLS_USE_DISTUTILS', 'local') + return which == 'local' + + +def ensure_local_distutils(): + import importlib + + clear_distutils() + + # With the DistutilsMetaFinder in place, + # perform an import to cause distutils to be + # loaded from setuptools._distutils. Ref #2906. + with shim(): + importlib.import_module('distutils') + + # check that submodules load as expected + core = importlib.import_module('distutils.core') + assert '_distutils' in core.__file__, core.__file__ + assert 'setuptools._distutils.log' not in sys.modules + + +def do_override(): + """ + Ensure that the local copy of distutils is preferred over stdlib. + + See https://github.com/pypa/setuptools/issues/417#issuecomment-392298401 + for more motivation. + """ + if enabled(): + warn_distutils_present() + ensure_local_distutils() + + +class _TrivialRe: + def __init__(self, *patterns): + self._patterns = patterns + + def match(self, string): + return all(pat in string for pat in self._patterns) + + +class DistutilsMetaFinder: + def find_spec(self, fullname, path, target=None): + # optimization: only consider top level modules and those + # found in the CPython test suite. + if path is not None and not fullname.startswith('test.'): + return + + method_name = 'spec_for_{fullname}'.format(**locals()) + method = getattr(self, method_name, lambda: None) + return method() + + def spec_for_distutils(self): + if self.is_cpython(): + return + + import importlib + import importlib.abc + import importlib.util + + try: + mod = importlib.import_module('setuptools._distutils') + except Exception: + # There are a couple of cases where setuptools._distutils + # may not be present: + # - An older Setuptools without a local distutils is + # taking precedence. Ref #2957. + # - Path manipulation during sitecustomize removes + # setuptools from the path but only after the hook + # has been loaded. Ref #2980. + # In either case, fall back to stdlib behavior. + return + + class DistutilsLoader(importlib.abc.Loader): + def create_module(self, spec): + mod.__name__ = 'distutils' + return mod + + def exec_module(self, module): + pass + + return importlib.util.spec_from_loader( + 'distutils', DistutilsLoader(), origin=mod.__file__ + ) + + @staticmethod + def is_cpython(): + """ + Suppress supplying distutils for CPython (build and tests). + Ref #2965 and #3007. + """ + return os.path.isfile('pybuilddir.txt') + + def spec_for_pip(self): + """ + Ensure stdlib distutils when running under pip. + See pypa/pip#8761 for rationale. + """ + if self.pip_imported_during_build(): + return + clear_distutils() + self.spec_for_distutils = lambda: None + + @classmethod + def pip_imported_during_build(cls): + """ + Detect if pip is being imported in a build script. Ref #2355. + """ + import traceback + + return any( + cls.frame_file_is_setup(frame) for frame, line in traceback.walk_stack(None) + ) + + @staticmethod + def frame_file_is_setup(frame): + """ + Return True if the indicated frame suggests a setup.py file. + """ + # some frames may not have __file__ (#2940) + return frame.f_globals.get('__file__', '').endswith('setup.py') + + def spec_for_sensitive_tests(self): + """ + Ensure stdlib distutils when running select tests under CPython. + + python/cpython#91169 + """ + clear_distutils() + self.spec_for_distutils = lambda: None + + sensitive_tests = ( + [ + 'test.test_distutils', + 'test.test_peg_generator', + 'test.test_importlib', + ] + if sys.version_info < (3, 10) + else [ + 'test.test_distutils', + ] + ) + + +for name in DistutilsMetaFinder.sensitive_tests: + setattr( + DistutilsMetaFinder, + f'spec_for_{name}', + DistutilsMetaFinder.spec_for_sensitive_tests, + ) + + +DISTUTILS_FINDER = DistutilsMetaFinder() + + +def add_shim(): + DISTUTILS_FINDER in sys.meta_path or insert_shim() + + +class shim: + def __enter__(self): + insert_shim() + + def __exit__(self, exc, value, tb): + remove_shim() + + +def insert_shim(): + sys.meta_path.insert(0, DISTUTILS_FINDER) + + +def remove_shim(): + try: + sys.meta_path.remove(DISTUTILS_FINDER) + except ValueError: + pass diff --git a/PyGC/.venv/lib/python3.11/site-packages/_distutils_hack/override.py b/PyGC/.venv/lib/python3.11/site-packages/_distutils_hack/override.py new file mode 100644 index 0000000..2cc433a --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_distutils_hack/override.py @@ -0,0 +1 @@ +__import__('_distutils_hack').do_override() diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/__init__.py new file mode 100644 index 0000000..8eb8ec9 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/__init__.py @@ -0,0 +1,13 @@ +from __future__ import annotations + + +__all__ = ["__version__", "version_tuple"] + +try: + from ._version import version as __version__ + from ._version import version_tuple +except ImportError: # pragma: no cover + # broken installation, we don't even try + # unknown only works because we do poor mans version compare + __version__ = "unknown" + version_tuple = (0, 0, "unknown") diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/_argcomplete.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_argcomplete.py new file mode 100644 index 0000000..59426ef --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_argcomplete.py @@ -0,0 +1,117 @@ +"""Allow bash-completion for argparse with argcomplete if installed. + +Needs argcomplete>=0.5.6 for python 3.2/3.3 (older versions fail +to find the magic string, so _ARGCOMPLETE env. var is never set, and +this does not need special code). + +Function try_argcomplete(parser) should be called directly before +the call to ArgumentParser.parse_args(). + +The filescompleter is what you normally would use on the positional +arguments specification, in order to get "dirname/" after "dirn" +instead of the default "dirname ": + + optparser.add_argument(Config._file_or_dir, nargs='*').completer=filescompleter + +Other, application specific, completers should go in the file +doing the add_argument calls as they need to be specified as .completer +attributes as well. (If argcomplete is not installed, the function the +attribute points to will not be used). + +SPEEDUP +======= + +The generic argcomplete script for bash-completion +(/etc/bash_completion.d/python-argcomplete.sh) +uses a python program to determine startup script generated by pip. +You can speed up completion somewhat by changing this script to include + # PYTHON_ARGCOMPLETE_OK +so the python-argcomplete-check-easy-install-script does not +need to be called to find the entry point of the code and see if that is +marked with PYTHON_ARGCOMPLETE_OK. + +INSTALL/DEBUGGING +================= + +To include this support in another application that has setup.py generated +scripts: + +- Add the line: + # PYTHON_ARGCOMPLETE_OK + near the top of the main python entry point. + +- Include in the file calling parse_args(): + from _argcomplete import try_argcomplete, filescompleter + Call try_argcomplete just before parse_args(), and optionally add + filescompleter to the positional arguments' add_argument(). + +If things do not work right away: + +- Switch on argcomplete debugging with (also helpful when doing custom + completers): + export _ARC_DEBUG=1 + +- Run: + python-argcomplete-check-easy-install-script $(which appname) + echo $? + will echo 0 if the magic line has been found, 1 if not. + +- Sometimes it helps to find early on errors using: + _ARGCOMPLETE=1 _ARC_DEBUG=1 appname + which should throw a KeyError: 'COMPLINE' (which is properly set by the + global argcomplete script). +""" + +from __future__ import annotations + +import argparse +from glob import glob +import os +import sys +from typing import Any + + +class FastFilesCompleter: + """Fast file completer class.""" + + def __init__(self, directories: bool = True) -> None: + self.directories = directories + + def __call__(self, prefix: str, **kwargs: Any) -> list[str]: + # Only called on non option completions. + if os.sep in prefix[1:]: + prefix_dir = len(os.path.dirname(prefix) + os.sep) + else: + prefix_dir = 0 + completion = [] + globbed = [] + if "*" not in prefix and "?" not in prefix: + # We are on unix, otherwise no bash. + if not prefix or prefix[-1] == os.sep: + globbed.extend(glob(prefix + ".*")) + prefix += "*" + globbed.extend(glob(prefix)) + for x in sorted(globbed): + if os.path.isdir(x): + x += "/" + # Append stripping the prefix (like bash, not like compgen). + completion.append(x[prefix_dir:]) + return completion + + +if os.environ.get("_ARGCOMPLETE"): + try: + import argcomplete.completers + except ImportError: + sys.exit(-1) + filescompleter: FastFilesCompleter | None = FastFilesCompleter() + + def try_argcomplete(parser: argparse.ArgumentParser) -> None: + argcomplete.autocomplete(parser, always_complete_options=False) + +else: + + def try_argcomplete(parser: argparse.ArgumentParser) -> None: + pass + + filescompleter = None diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/_code/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_code/__init__.py new file mode 100644 index 0000000..0bfde42 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_code/__init__.py @@ -0,0 +1,26 @@ +"""Python inspection/code generation API.""" + +from __future__ import annotations + +from .code import Code +from .code import ExceptionInfo +from .code import filter_traceback +from .code import Frame +from .code import getfslineno +from .code import Traceback +from .code import TracebackEntry +from .source import getrawcode +from .source import Source + + +__all__ = [ + "Code", + "ExceptionInfo", + "filter_traceback", + "Frame", + "getfslineno", + "getrawcode", + "Traceback", + "TracebackEntry", + "Source", +] diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/_code/code.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_code/code.py new file mode 100644 index 0000000..8fac39e --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_code/code.py @@ -0,0 +1,1403 @@ +# mypy: allow-untyped-defs +from __future__ import annotations + +import ast +import dataclasses +import inspect +from inspect import CO_VARARGS +from inspect import CO_VARKEYWORDS +from io import StringIO +import os +from pathlib import Path +import re +import sys +import traceback +from traceback import format_exception_only +from types import CodeType +from types import FrameType +from types import TracebackType +from typing import Any +from typing import Callable +from typing import ClassVar +from typing import Final +from typing import final +from typing import Generic +from typing import Iterable +from typing import List +from typing import Literal +from typing import Mapping +from typing import overload +from typing import Pattern +from typing import Sequence +from typing import SupportsIndex +from typing import Tuple +from typing import Type +from typing import TypeVar +from typing import Union + +import pluggy + +import _pytest +from _pytest._code.source import findsource +from _pytest._code.source import getrawcode +from _pytest._code.source import getstatementrange_ast +from _pytest._code.source import Source +from _pytest._io import TerminalWriter +from _pytest._io.saferepr import safeformat +from _pytest._io.saferepr import saferepr +from _pytest.compat import get_real_func +from _pytest.deprecated import check_ispytest +from _pytest.pathlib import absolutepath +from _pytest.pathlib import bestrelpath + + +if sys.version_info < (3, 11): + from exceptiongroup import BaseExceptionGroup + +TracebackStyle = Literal["long", "short", "line", "no", "native", "value", "auto"] + +EXCEPTION_OR_MORE = Union[Type[BaseException], Tuple[Type[BaseException], ...]] + + +class Code: + """Wrapper around Python code objects.""" + + __slots__ = ("raw",) + + def __init__(self, obj: CodeType) -> None: + self.raw = obj + + @classmethod + def from_function(cls, obj: object) -> Code: + return cls(getrawcode(obj)) + + def __eq__(self, other): + return self.raw == other.raw + + # Ignore type because of https://github.com/python/mypy/issues/4266. + __hash__ = None # type: ignore + + @property + def firstlineno(self) -> int: + return self.raw.co_firstlineno - 1 + + @property + def name(self) -> str: + return self.raw.co_name + + @property + def path(self) -> Path | str: + """Return a path object pointing to source code, or an ``str`` in + case of ``OSError`` / non-existing file.""" + if not self.raw.co_filename: + return "" + try: + p = absolutepath(self.raw.co_filename) + # maybe don't try this checking + if not p.exists(): + raise OSError("path check failed.") + return p + except OSError: + # XXX maybe try harder like the weird logic + # in the standard lib [linecache.updatecache] does? + return self.raw.co_filename + + @property + def fullsource(self) -> Source | None: + """Return a _pytest._code.Source object for the full source file of the code.""" + full, _ = findsource(self.raw) + return full + + def source(self) -> Source: + """Return a _pytest._code.Source object for the code object's source only.""" + # return source only for that part of code + return Source(self.raw) + + def getargs(self, var: bool = False) -> tuple[str, ...]: + """Return a tuple with the argument names for the code object. + + If 'var' is set True also return the names of the variable and + keyword arguments when present. + """ + # Handy shortcut for getting args. + raw = self.raw + argcount = raw.co_argcount + if var: + argcount += raw.co_flags & CO_VARARGS + argcount += raw.co_flags & CO_VARKEYWORDS + return raw.co_varnames[:argcount] + + +class Frame: + """Wrapper around a Python frame holding f_locals and f_globals + in which expressions can be evaluated.""" + + __slots__ = ("raw",) + + def __init__(self, frame: FrameType) -> None: + self.raw = frame + + @property + def lineno(self) -> int: + return self.raw.f_lineno - 1 + + @property + def f_globals(self) -> dict[str, Any]: + return self.raw.f_globals + + @property + def f_locals(self) -> dict[str, Any]: + return self.raw.f_locals + + @property + def code(self) -> Code: + return Code(self.raw.f_code) + + @property + def statement(self) -> Source: + """Statement this frame is at.""" + if self.code.fullsource is None: + return Source("") + return self.code.fullsource.getstatement(self.lineno) + + def eval(self, code, **vars): + """Evaluate 'code' in the frame. + + 'vars' are optional additional local variables. + + Returns the result of the evaluation. + """ + f_locals = self.f_locals.copy() + f_locals.update(vars) + return eval(code, self.f_globals, f_locals) + + def repr(self, object: object) -> str: + """Return a 'safe' (non-recursive, one-line) string repr for 'object'.""" + return saferepr(object) + + def getargs(self, var: bool = False): + """Return a list of tuples (name, value) for all arguments. + + If 'var' is set True, also include the variable and keyword arguments + when present. + """ + retval = [] + for arg in self.code.getargs(var): + try: + retval.append((arg, self.f_locals[arg])) + except KeyError: + pass # this can occur when using Psyco + return retval + + +class TracebackEntry: + """A single entry in a Traceback.""" + + __slots__ = ("_rawentry", "_repr_style") + + def __init__( + self, + rawentry: TracebackType, + repr_style: Literal["short", "long"] | None = None, + ) -> None: + self._rawentry: Final = rawentry + self._repr_style: Final = repr_style + + def with_repr_style( + self, repr_style: Literal["short", "long"] | None + ) -> TracebackEntry: + return TracebackEntry(self._rawentry, repr_style) + + @property + def lineno(self) -> int: + return self._rawentry.tb_lineno - 1 + + @property + def frame(self) -> Frame: + return Frame(self._rawentry.tb_frame) + + @property + def relline(self) -> int: + return self.lineno - self.frame.code.firstlineno + + def __repr__(self) -> str: + return "" % (self.frame.code.path, self.lineno + 1) + + @property + def statement(self) -> Source: + """_pytest._code.Source object for the current statement.""" + source = self.frame.code.fullsource + assert source is not None + return source.getstatement(self.lineno) + + @property + def path(self) -> Path | str: + """Path to the source code.""" + return self.frame.code.path + + @property + def locals(self) -> dict[str, Any]: + """Locals of underlying frame.""" + return self.frame.f_locals + + def getfirstlinesource(self) -> int: + return self.frame.code.firstlineno + + def getsource( + self, astcache: dict[str | Path, ast.AST] | None = None + ) -> Source | None: + """Return failing source code.""" + # we use the passed in astcache to not reparse asttrees + # within exception info printing + source = self.frame.code.fullsource + if source is None: + return None + key = astnode = None + if astcache is not None: + key = self.frame.code.path + if key is not None: + astnode = astcache.get(key, None) + start = self.getfirstlinesource() + try: + astnode, _, end = getstatementrange_ast( + self.lineno, source, astnode=astnode + ) + except SyntaxError: + end = self.lineno + 1 + else: + if key is not None and astcache is not None: + astcache[key] = astnode + return source[start:end] + + source = property(getsource) + + def ishidden(self, excinfo: ExceptionInfo[BaseException] | None) -> bool: + """Return True if the current frame has a var __tracebackhide__ + resolving to True. + + If __tracebackhide__ is a callable, it gets called with the + ExceptionInfo instance and can decide whether to hide the traceback. + + Mostly for internal use. + """ + tbh: bool | Callable[[ExceptionInfo[BaseException] | None], bool] = False + for maybe_ns_dct in (self.frame.f_locals, self.frame.f_globals): + # in normal cases, f_locals and f_globals are dictionaries + # however via `exec(...)` / `eval(...)` they can be other types + # (even incorrect types!). + # as such, we suppress all exceptions while accessing __tracebackhide__ + try: + tbh = maybe_ns_dct["__tracebackhide__"] + except Exception: + pass + else: + break + if tbh and callable(tbh): + return tbh(excinfo) + return tbh + + def __str__(self) -> str: + name = self.frame.code.name + try: + line = str(self.statement).lstrip() + except KeyboardInterrupt: + raise + except BaseException: + line = "???" + # This output does not quite match Python's repr for traceback entries, + # but changing it to do so would break certain plugins. See + # https://github.com/pytest-dev/pytest/pull/7535/ for details. + return " File %r:%d in %s\n %s\n" % ( + str(self.path), + self.lineno + 1, + name, + line, + ) + + @property + def name(self) -> str: + """co_name of underlying code.""" + return self.frame.code.raw.co_name + + +class Traceback(List[TracebackEntry]): + """Traceback objects encapsulate and offer higher level access to Traceback entries.""" + + def __init__( + self, + tb: TracebackType | Iterable[TracebackEntry], + ) -> None: + """Initialize from given python traceback object and ExceptionInfo.""" + if isinstance(tb, TracebackType): + + def f(cur: TracebackType) -> Iterable[TracebackEntry]: + cur_: TracebackType | None = cur + while cur_ is not None: + yield TracebackEntry(cur_) + cur_ = cur_.tb_next + + super().__init__(f(tb)) + else: + super().__init__(tb) + + def cut( + self, + path: os.PathLike[str] | str | None = None, + lineno: int | None = None, + firstlineno: int | None = None, + excludepath: os.PathLike[str] | None = None, + ) -> Traceback: + """Return a Traceback instance wrapping part of this Traceback. + + By providing any combination of path, lineno and firstlineno, the + first frame to start the to-be-returned traceback is determined. + + This allows cutting the first part of a Traceback instance e.g. + for formatting reasons (removing some uninteresting bits that deal + with handling of the exception/traceback). + """ + path_ = None if path is None else os.fspath(path) + excludepath_ = None if excludepath is None else os.fspath(excludepath) + for x in self: + code = x.frame.code + codepath = code.path + if path is not None and str(codepath) != path_: + continue + if ( + excludepath is not None + and isinstance(codepath, Path) + and excludepath_ in (str(p) for p in codepath.parents) # type: ignore[operator] + ): + continue + if lineno is not None and x.lineno != lineno: + continue + if firstlineno is not None and x.frame.code.firstlineno != firstlineno: + continue + return Traceback(x._rawentry) + return self + + @overload + def __getitem__(self, key: SupportsIndex) -> TracebackEntry: ... + + @overload + def __getitem__(self, key: slice) -> Traceback: ... + + def __getitem__(self, key: SupportsIndex | slice) -> TracebackEntry | Traceback: + if isinstance(key, slice): + return self.__class__(super().__getitem__(key)) + else: + return super().__getitem__(key) + + def filter( + self, + excinfo_or_fn: ExceptionInfo[BaseException] | Callable[[TracebackEntry], bool], + /, + ) -> Traceback: + """Return a Traceback instance with certain items removed. + + If the filter is an `ExceptionInfo`, removes all the ``TracebackEntry``s + which are hidden (see ishidden() above). + + Otherwise, the filter is a function that gets a single argument, a + ``TracebackEntry`` instance, and should return True when the item should + be added to the ``Traceback``, False when not. + """ + if isinstance(excinfo_or_fn, ExceptionInfo): + fn = lambda x: not x.ishidden(excinfo_or_fn) # noqa: E731 + else: + fn = excinfo_or_fn + return Traceback(filter(fn, self)) + + def recursionindex(self) -> int | None: + """Return the index of the frame/TracebackEntry where recursion originates if + appropriate, None if no recursion occurred.""" + cache: dict[tuple[Any, int, int], list[dict[str, Any]]] = {} + for i, entry in enumerate(self): + # id for the code.raw is needed to work around + # the strange metaprogramming in the decorator lib from pypi + # which generates code objects that have hash/value equality + # XXX needs a test + key = entry.frame.code.path, id(entry.frame.code.raw), entry.lineno + values = cache.setdefault(key, []) + # Since Python 3.13 f_locals is a proxy, freeze it. + loc = dict(entry.frame.f_locals) + if values: + for otherloc in values: + if otherloc == loc: + return i + values.append(loc) + return None + + +E = TypeVar("E", bound=BaseException, covariant=True) + + +@final +@dataclasses.dataclass +class ExceptionInfo(Generic[E]): + """Wraps sys.exc_info() objects and offers help for navigating the traceback.""" + + _assert_start_repr: ClassVar = "AssertionError('assert " + + _excinfo: tuple[type[E], E, TracebackType] | None + _striptext: str + _traceback: Traceback | None + + def __init__( + self, + excinfo: tuple[type[E], E, TracebackType] | None, + striptext: str = "", + traceback: Traceback | None = None, + *, + _ispytest: bool = False, + ) -> None: + check_ispytest(_ispytest) + self._excinfo = excinfo + self._striptext = striptext + self._traceback = traceback + + @classmethod + def from_exception( + cls, + # Ignoring error: "Cannot use a covariant type variable as a parameter". + # This is OK to ignore because this class is (conceptually) readonly. + # See https://github.com/python/mypy/issues/7049. + exception: E, # type: ignore[misc] + exprinfo: str | None = None, + ) -> ExceptionInfo[E]: + """Return an ExceptionInfo for an existing exception. + + The exception must have a non-``None`` ``__traceback__`` attribute, + otherwise this function fails with an assertion error. This means that + the exception must have been raised, or added a traceback with the + :py:meth:`~BaseException.with_traceback()` method. + + :param exprinfo: + A text string helping to determine if we should strip + ``AssertionError`` from the output. Defaults to the exception + message/``__str__()``. + + .. versionadded:: 7.4 + """ + assert exception.__traceback__, ( + "Exceptions passed to ExcInfo.from_exception(...)" + " must have a non-None __traceback__." + ) + exc_info = (type(exception), exception, exception.__traceback__) + return cls.from_exc_info(exc_info, exprinfo) + + @classmethod + def from_exc_info( + cls, + exc_info: tuple[type[E], E, TracebackType], + exprinfo: str | None = None, + ) -> ExceptionInfo[E]: + """Like :func:`from_exception`, but using old-style exc_info tuple.""" + _striptext = "" + if exprinfo is None and isinstance(exc_info[1], AssertionError): + exprinfo = getattr(exc_info[1], "msg", None) + if exprinfo is None: + exprinfo = saferepr(exc_info[1]) + if exprinfo and exprinfo.startswith(cls._assert_start_repr): + _striptext = "AssertionError: " + + return cls(exc_info, _striptext, _ispytest=True) + + @classmethod + def from_current(cls, exprinfo: str | None = None) -> ExceptionInfo[BaseException]: + """Return an ExceptionInfo matching the current traceback. + + .. warning:: + + Experimental API + + :param exprinfo: + A text string helping to determine if we should strip + ``AssertionError`` from the output. Defaults to the exception + message/``__str__()``. + """ + tup = sys.exc_info() + assert tup[0] is not None, "no current exception" + assert tup[1] is not None, "no current exception" + assert tup[2] is not None, "no current exception" + exc_info = (tup[0], tup[1], tup[2]) + return ExceptionInfo.from_exc_info(exc_info, exprinfo) + + @classmethod + def for_later(cls) -> ExceptionInfo[E]: + """Return an unfilled ExceptionInfo.""" + return cls(None, _ispytest=True) + + def fill_unfilled(self, exc_info: tuple[type[E], E, TracebackType]) -> None: + """Fill an unfilled ExceptionInfo created with ``for_later()``.""" + assert self._excinfo is None, "ExceptionInfo was already filled" + self._excinfo = exc_info + + @property + def type(self) -> type[E]: + """The exception class.""" + assert ( + self._excinfo is not None + ), ".type can only be used after the context manager exits" + return self._excinfo[0] + + @property + def value(self) -> E: + """The exception value.""" + assert ( + self._excinfo is not None + ), ".value can only be used after the context manager exits" + return self._excinfo[1] + + @property + def tb(self) -> TracebackType: + """The exception raw traceback.""" + assert ( + self._excinfo is not None + ), ".tb can only be used after the context manager exits" + return self._excinfo[2] + + @property + def typename(self) -> str: + """The type name of the exception.""" + assert ( + self._excinfo is not None + ), ".typename can only be used after the context manager exits" + return self.type.__name__ + + @property + def traceback(self) -> Traceback: + """The traceback.""" + if self._traceback is None: + self._traceback = Traceback(self.tb) + return self._traceback + + @traceback.setter + def traceback(self, value: Traceback) -> None: + self._traceback = value + + def __repr__(self) -> str: + if self._excinfo is None: + return "" + return f"<{self.__class__.__name__} {saferepr(self._excinfo[1])} tblen={len(self.traceback)}>" + + def exconly(self, tryshort: bool = False) -> str: + """Return the exception as a string. + + When 'tryshort' resolves to True, and the exception is an + AssertionError, only the actual exception part of the exception + representation is returned (so 'AssertionError: ' is removed from + the beginning). + """ + lines = format_exception_only(self.type, self.value) + text = "".join(lines) + text = text.rstrip() + if tryshort: + if text.startswith(self._striptext): + text = text[len(self._striptext) :] + return text + + def errisinstance(self, exc: EXCEPTION_OR_MORE) -> bool: + """Return True if the exception is an instance of exc. + + Consider using ``isinstance(excinfo.value, exc)`` instead. + """ + return isinstance(self.value, exc) + + def _getreprcrash(self) -> ReprFileLocation | None: + # Find last non-hidden traceback entry that led to the exception of the + # traceback, or None if all hidden. + for i in range(-1, -len(self.traceback) - 1, -1): + entry = self.traceback[i] + if not entry.ishidden(self): + path, lineno = entry.frame.code.raw.co_filename, entry.lineno + exconly = self.exconly(tryshort=True) + return ReprFileLocation(path, lineno + 1, exconly) + return None + + def getrepr( + self, + showlocals: bool = False, + style: TracebackStyle = "long", + abspath: bool = False, + tbfilter: bool + | Callable[[ExceptionInfo[BaseException]], _pytest._code.code.Traceback] = True, + funcargs: bool = False, + truncate_locals: bool = True, + truncate_args: bool = True, + chain: bool = True, + ) -> ReprExceptionInfo | ExceptionChainRepr: + """Return str()able representation of this exception info. + + :param bool showlocals: + Show locals per traceback entry. + Ignored if ``style=="native"``. + + :param str style: + long|short|line|no|native|value traceback style. + + :param bool abspath: + If paths should be changed to absolute or left unchanged. + + :param tbfilter: + A filter for traceback entries. + + * If false, don't hide any entries. + * If true, hide internal entries and entries that contain a local + variable ``__tracebackhide__ = True``. + * If a callable, delegates the filtering to the callable. + + Ignored if ``style`` is ``"native"``. + + :param bool funcargs: + Show fixtures ("funcargs" for legacy purposes) per traceback entry. + + :param bool truncate_locals: + With ``showlocals==True``, make sure locals can be safely represented as strings. + + :param bool truncate_args: + With ``showargs==True``, make sure args can be safely represented as strings. + + :param bool chain: + If chained exceptions in Python 3 should be shown. + + .. versionchanged:: 3.9 + + Added the ``chain`` parameter. + """ + if style == "native": + return ReprExceptionInfo( + reprtraceback=ReprTracebackNative( + traceback.format_exception( + self.type, + self.value, + self.traceback[0]._rawentry if self.traceback else None, + ) + ), + reprcrash=self._getreprcrash(), + ) + + fmt = FormattedExcinfo( + showlocals=showlocals, + style=style, + abspath=abspath, + tbfilter=tbfilter, + funcargs=funcargs, + truncate_locals=truncate_locals, + truncate_args=truncate_args, + chain=chain, + ) + return fmt.repr_excinfo(self) + + def _stringify_exception(self, exc: BaseException) -> str: + try: + notes = getattr(exc, "__notes__", []) + except KeyError: + # Workaround for https://github.com/python/cpython/issues/98778 on + # Python <= 3.9, and some 3.10 and 3.11 patch versions. + HTTPError = getattr(sys.modules.get("urllib.error", None), "HTTPError", ()) + if sys.version_info < (3, 12) and isinstance(exc, HTTPError): + notes = [] + else: + raise + + return "\n".join( + [ + str(exc), + *notes, + ] + ) + + def match(self, regexp: str | Pattern[str]) -> Literal[True]: + """Check whether the regular expression `regexp` matches the string + representation of the exception using :func:`python:re.search`. + + If it matches `True` is returned, otherwise an `AssertionError` is raised. + """ + __tracebackhide__ = True + value = self._stringify_exception(self.value) + msg = f"Regex pattern did not match.\n Regex: {regexp!r}\n Input: {value!r}" + if regexp == value: + msg += "\n Did you mean to `re.escape()` the regex?" + assert re.search(regexp, value), msg + # Return True to allow for "assert excinfo.match()". + return True + + def _group_contains( + self, + exc_group: BaseExceptionGroup[BaseException], + expected_exception: EXCEPTION_OR_MORE, + match: str | Pattern[str] | None, + target_depth: int | None = None, + current_depth: int = 1, + ) -> bool: + """Return `True` if a `BaseExceptionGroup` contains a matching exception.""" + if (target_depth is not None) and (current_depth > target_depth): + # already descended past the target depth + return False + for exc in exc_group.exceptions: + if isinstance(exc, BaseExceptionGroup): + if self._group_contains( + exc, expected_exception, match, target_depth, current_depth + 1 + ): + return True + if (target_depth is not None) and (current_depth != target_depth): + # not at the target depth, no match + continue + if not isinstance(exc, expected_exception): + continue + if match is not None: + value = self._stringify_exception(exc) + if not re.search(match, value): + continue + return True + return False + + def group_contains( + self, + expected_exception: EXCEPTION_OR_MORE, + *, + match: str | Pattern[str] | None = None, + depth: int | None = None, + ) -> bool: + """Check whether a captured exception group contains a matching exception. + + :param Type[BaseException] | Tuple[Type[BaseException]] expected_exception: + The expected exception type, or a tuple if one of multiple possible + exception types are expected. + + :param str | Pattern[str] | None match: + If specified, a string containing a regular expression, + or a regular expression object, that is tested against the string + representation of the exception and its `PEP-678 ` `__notes__` + using :func:`re.search`. + + To match a literal string that may contain :ref:`special characters + `, the pattern can first be escaped with :func:`re.escape`. + + :param Optional[int] depth: + If `None`, will search for a matching exception at any nesting depth. + If >= 1, will only match an exception if it's at the specified depth (depth = 1 being + the exceptions contained within the topmost exception group). + + .. versionadded:: 8.0 + """ + msg = "Captured exception is not an instance of `BaseExceptionGroup`" + assert isinstance(self.value, BaseExceptionGroup), msg + msg = "`depth` must be >= 1 if specified" + assert (depth is None) or (depth >= 1), msg + return self._group_contains(self.value, expected_exception, match, depth) + + +@dataclasses.dataclass +class FormattedExcinfo: + """Presenting information about failing Functions and Generators.""" + + # for traceback entries + flow_marker: ClassVar = ">" + fail_marker: ClassVar = "E" + + showlocals: bool = False + style: TracebackStyle = "long" + abspath: bool = True + tbfilter: bool | Callable[[ExceptionInfo[BaseException]], Traceback] = True + funcargs: bool = False + truncate_locals: bool = True + truncate_args: bool = True + chain: bool = True + astcache: dict[str | Path, ast.AST] = dataclasses.field( + default_factory=dict, init=False, repr=False + ) + + def _getindent(self, source: Source) -> int: + # Figure out indent for the given source. + try: + s = str(source.getstatement(len(source) - 1)) + except KeyboardInterrupt: + raise + except BaseException: + try: + s = str(source[-1]) + except KeyboardInterrupt: + raise + except BaseException: + return 0 + return 4 + (len(s) - len(s.lstrip())) + + def _getentrysource(self, entry: TracebackEntry) -> Source | None: + source = entry.getsource(self.astcache) + if source is not None: + source = source.deindent() + return source + + def repr_args(self, entry: TracebackEntry) -> ReprFuncArgs | None: + if self.funcargs: + args = [] + for argname, argvalue in entry.frame.getargs(var=True): + if self.truncate_args: + str_repr = saferepr(argvalue) + else: + str_repr = saferepr(argvalue, maxsize=None) + args.append((argname, str_repr)) + return ReprFuncArgs(args) + return None + + def get_source( + self, + source: Source | None, + line_index: int = -1, + excinfo: ExceptionInfo[BaseException] | None = None, + short: bool = False, + ) -> list[str]: + """Return formatted and marked up source lines.""" + lines = [] + if source is not None and line_index < 0: + line_index += len(source) + if source is None or line_index >= len(source.lines) or line_index < 0: + # `line_index` could still be outside `range(len(source.lines))` if + # we're processing AST with pathological position attributes. + source = Source("???") + line_index = 0 + space_prefix = " " + if short: + lines.append(space_prefix + source.lines[line_index].strip()) + else: + for line in source.lines[:line_index]: + lines.append(space_prefix + line) + lines.append(self.flow_marker + " " + source.lines[line_index]) + for line in source.lines[line_index + 1 :]: + lines.append(space_prefix + line) + if excinfo is not None: + indent = 4 if short else self._getindent(source) + lines.extend(self.get_exconly(excinfo, indent=indent, markall=True)) + return lines + + def get_exconly( + self, + excinfo: ExceptionInfo[BaseException], + indent: int = 4, + markall: bool = False, + ) -> list[str]: + lines = [] + indentstr = " " * indent + # Get the real exception information out. + exlines = excinfo.exconly(tryshort=True).split("\n") + failindent = self.fail_marker + indentstr[1:] + for line in exlines: + lines.append(failindent + line) + if not markall: + failindent = indentstr + return lines + + def repr_locals(self, locals: Mapping[str, object]) -> ReprLocals | None: + if self.showlocals: + lines = [] + keys = [loc for loc in locals if loc[0] != "@"] + keys.sort() + for name in keys: + value = locals[name] + if name == "__builtins__": + lines.append("__builtins__ = ") + else: + # This formatting could all be handled by the + # _repr() function, which is only reprlib.Repr in + # disguise, so is very configurable. + if self.truncate_locals: + str_repr = saferepr(value) + else: + str_repr = safeformat(value) + # if len(str_repr) < 70 or not isinstance(value, (list, tuple, dict)): + lines.append(f"{name:<10} = {str_repr}") + # else: + # self._line("%-10s =\\" % (name,)) + # # XXX + # pprint.pprint(value, stream=self.excinfowriter) + return ReprLocals(lines) + return None + + def repr_traceback_entry( + self, + entry: TracebackEntry | None, + excinfo: ExceptionInfo[BaseException] | None = None, + ) -> ReprEntry: + lines: list[str] = [] + style = ( + entry._repr_style + if entry is not None and entry._repr_style is not None + else self.style + ) + if style in ("short", "long") and entry is not None: + source = self._getentrysource(entry) + if source is None: + source = Source("???") + line_index = 0 + else: + line_index = entry.lineno - entry.getfirstlinesource() + short = style == "short" + reprargs = self.repr_args(entry) if not short else None + s = self.get_source(source, line_index, excinfo, short=short) + lines.extend(s) + if short: + message = f"in {entry.name}" + else: + message = excinfo and excinfo.typename or "" + entry_path = entry.path + path = self._makepath(entry_path) + reprfileloc = ReprFileLocation(path, entry.lineno + 1, message) + localsrepr = self.repr_locals(entry.locals) + return ReprEntry(lines, reprargs, localsrepr, reprfileloc, style) + elif style == "value": + if excinfo: + lines.extend(str(excinfo.value).split("\n")) + return ReprEntry(lines, None, None, None, style) + else: + if excinfo: + lines.extend(self.get_exconly(excinfo, indent=4)) + return ReprEntry(lines, None, None, None, style) + + def _makepath(self, path: Path | str) -> str: + if not self.abspath and isinstance(path, Path): + try: + np = bestrelpath(Path.cwd(), path) + except OSError: + return str(path) + if len(np) < len(str(path)): + return np + return str(path) + + def repr_traceback(self, excinfo: ExceptionInfo[BaseException]) -> ReprTraceback: + traceback = excinfo.traceback + if callable(self.tbfilter): + traceback = self.tbfilter(excinfo) + elif self.tbfilter: + traceback = traceback.filter(excinfo) + + if isinstance(excinfo.value, RecursionError): + traceback, extraline = self._truncate_recursive_traceback(traceback) + else: + extraline = None + + if not traceback: + if extraline is None: + extraline = "All traceback entries are hidden. Pass `--full-trace` to see hidden and internal frames." + entries = [self.repr_traceback_entry(None, excinfo)] + return ReprTraceback(entries, extraline, style=self.style) + + last = traceback[-1] + if self.style == "value": + entries = [self.repr_traceback_entry(last, excinfo)] + return ReprTraceback(entries, None, style=self.style) + + entries = [ + self.repr_traceback_entry(entry, excinfo if last == entry else None) + for entry in traceback + ] + return ReprTraceback(entries, extraline, style=self.style) + + def _truncate_recursive_traceback( + self, traceback: Traceback + ) -> tuple[Traceback, str | None]: + """Truncate the given recursive traceback trying to find the starting + point of the recursion. + + The detection is done by going through each traceback entry and + finding the point in which the locals of the frame are equal to the + locals of a previous frame (see ``recursionindex()``). + + Handle the situation where the recursion process might raise an + exception (for example comparing numpy arrays using equality raises a + TypeError), in which case we do our best to warn the user of the + error and show a limited traceback. + """ + try: + recursionindex = traceback.recursionindex() + except Exception as e: + max_frames = 10 + extraline: str | None = ( + "!!! Recursion error detected, but an error occurred locating the origin of recursion.\n" + " The following exception happened when comparing locals in the stack frame:\n" + f" {type(e).__name__}: {e!s}\n" + f" Displaying first and last {max_frames} stack frames out of {len(traceback)}." + ) + # Type ignored because adding two instances of a List subtype + # currently incorrectly has type List instead of the subtype. + traceback = traceback[:max_frames] + traceback[-max_frames:] # type: ignore + else: + if recursionindex is not None: + extraline = "!!! Recursion detected (same locals & position)" + traceback = traceback[: recursionindex + 1] + else: + extraline = None + + return traceback, extraline + + def repr_excinfo(self, excinfo: ExceptionInfo[BaseException]) -> ExceptionChainRepr: + repr_chain: list[tuple[ReprTraceback, ReprFileLocation | None, str | None]] = [] + e: BaseException | None = excinfo.value + excinfo_: ExceptionInfo[BaseException] | None = excinfo + descr = None + seen: set[int] = set() + while e is not None and id(e) not in seen: + seen.add(id(e)) + + if excinfo_: + # Fall back to native traceback as a temporary workaround until + # full support for exception groups added to ExceptionInfo. + # See https://github.com/pytest-dev/pytest/issues/9159 + if isinstance(e, BaseExceptionGroup): + reprtraceback: ReprTracebackNative | ReprTraceback = ( + ReprTracebackNative( + traceback.format_exception( + type(excinfo_.value), + excinfo_.value, + excinfo_.traceback[0]._rawentry, + ) + ) + ) + else: + reprtraceback = self.repr_traceback(excinfo_) + reprcrash = excinfo_._getreprcrash() + else: + # Fallback to native repr if the exception doesn't have a traceback: + # ExceptionInfo objects require a full traceback to work. + reprtraceback = ReprTracebackNative( + traceback.format_exception(type(e), e, None) + ) + reprcrash = None + repr_chain += [(reprtraceback, reprcrash, descr)] + + if e.__cause__ is not None and self.chain: + e = e.__cause__ + excinfo_ = ExceptionInfo.from_exception(e) if e.__traceback__ else None + descr = "The above exception was the direct cause of the following exception:" + elif ( + e.__context__ is not None and not e.__suppress_context__ and self.chain + ): + e = e.__context__ + excinfo_ = ExceptionInfo.from_exception(e) if e.__traceback__ else None + descr = "During handling of the above exception, another exception occurred:" + else: + e = None + repr_chain.reverse() + return ExceptionChainRepr(repr_chain) + + +@dataclasses.dataclass(eq=False) +class TerminalRepr: + def __str__(self) -> str: + # FYI this is called from pytest-xdist's serialization of exception + # information. + io = StringIO() + tw = TerminalWriter(file=io) + self.toterminal(tw) + return io.getvalue().strip() + + def __repr__(self) -> str: + return f"<{self.__class__} instance at {id(self):0x}>" + + def toterminal(self, tw: TerminalWriter) -> None: + raise NotImplementedError() + + +# This class is abstract -- only subclasses are instantiated. +@dataclasses.dataclass(eq=False) +class ExceptionRepr(TerminalRepr): + # Provided by subclasses. + reprtraceback: ReprTraceback + reprcrash: ReprFileLocation | None + sections: list[tuple[str, str, str]] = dataclasses.field( + init=False, default_factory=list + ) + + def addsection(self, name: str, content: str, sep: str = "-") -> None: + self.sections.append((name, content, sep)) + + def toterminal(self, tw: TerminalWriter) -> None: + for name, content, sep in self.sections: + tw.sep(sep, name) + tw.line(content) + + +@dataclasses.dataclass(eq=False) +class ExceptionChainRepr(ExceptionRepr): + chain: Sequence[tuple[ReprTraceback, ReprFileLocation | None, str | None]] + + def __init__( + self, + chain: Sequence[tuple[ReprTraceback, ReprFileLocation | None, str | None]], + ) -> None: + # reprcrash and reprtraceback of the outermost (the newest) exception + # in the chain. + super().__init__( + reprtraceback=chain[-1][0], + reprcrash=chain[-1][1], + ) + self.chain = chain + + def toterminal(self, tw: TerminalWriter) -> None: + for element in self.chain: + element[0].toterminal(tw) + if element[2] is not None: + tw.line("") + tw.line(element[2], yellow=True) + super().toterminal(tw) + + +@dataclasses.dataclass(eq=False) +class ReprExceptionInfo(ExceptionRepr): + reprtraceback: ReprTraceback + reprcrash: ReprFileLocation | None + + def toterminal(self, tw: TerminalWriter) -> None: + self.reprtraceback.toterminal(tw) + super().toterminal(tw) + + +@dataclasses.dataclass(eq=False) +class ReprTraceback(TerminalRepr): + reprentries: Sequence[ReprEntry | ReprEntryNative] + extraline: str | None + style: TracebackStyle + + entrysep: ClassVar = "_ " + + def toterminal(self, tw: TerminalWriter) -> None: + # The entries might have different styles. + for i, entry in enumerate(self.reprentries): + if entry.style == "long": + tw.line("") + entry.toterminal(tw) + if i < len(self.reprentries) - 1: + next_entry = self.reprentries[i + 1] + if ( + entry.style == "long" + or entry.style == "short" + and next_entry.style == "long" + ): + tw.sep(self.entrysep) + + if self.extraline: + tw.line(self.extraline) + + +class ReprTracebackNative(ReprTraceback): + def __init__(self, tblines: Sequence[str]) -> None: + self.reprentries = [ReprEntryNative(tblines)] + self.extraline = None + self.style = "native" + + +@dataclasses.dataclass(eq=False) +class ReprEntryNative(TerminalRepr): + lines: Sequence[str] + + style: ClassVar[TracebackStyle] = "native" + + def toterminal(self, tw: TerminalWriter) -> None: + tw.write("".join(self.lines)) + + +@dataclasses.dataclass(eq=False) +class ReprEntry(TerminalRepr): + lines: Sequence[str] + reprfuncargs: ReprFuncArgs | None + reprlocals: ReprLocals | None + reprfileloc: ReprFileLocation | None + style: TracebackStyle + + def _write_entry_lines(self, tw: TerminalWriter) -> None: + """Write the source code portions of a list of traceback entries with syntax highlighting. + + Usually entries are lines like these: + + " x = 1" + "> assert x == 2" + "E assert 1 == 2" + + This function takes care of rendering the "source" portions of it (the lines without + the "E" prefix) using syntax highlighting, taking care to not highlighting the ">" + character, as doing so might break line continuations. + """ + if not self.lines: + return + + # separate indents and source lines that are not failures: we want to + # highlight the code but not the indentation, which may contain markers + # such as "> assert 0" + fail_marker = f"{FormattedExcinfo.fail_marker} " + indent_size = len(fail_marker) + indents: list[str] = [] + source_lines: list[str] = [] + failure_lines: list[str] = [] + for index, line in enumerate(self.lines): + is_failure_line = line.startswith(fail_marker) + if is_failure_line: + # from this point on all lines are considered part of the failure + failure_lines.extend(self.lines[index:]) + break + else: + if self.style == "value": + source_lines.append(line) + else: + indents.append(line[:indent_size]) + source_lines.append(line[indent_size:]) + + tw._write_source(source_lines, indents) + + # failure lines are always completely red and bold + for line in failure_lines: + tw.line(line, bold=True, red=True) + + def toterminal(self, tw: TerminalWriter) -> None: + if self.style == "short": + if self.reprfileloc: + self.reprfileloc.toterminal(tw) + self._write_entry_lines(tw) + if self.reprlocals: + self.reprlocals.toterminal(tw, indent=" " * 8) + return + + if self.reprfuncargs: + self.reprfuncargs.toterminal(tw) + + self._write_entry_lines(tw) + + if self.reprlocals: + tw.line("") + self.reprlocals.toterminal(tw) + if self.reprfileloc: + if self.lines: + tw.line("") + self.reprfileloc.toterminal(tw) + + def __str__(self) -> str: + return "{}\n{}\n{}".format( + "\n".join(self.lines), self.reprlocals, self.reprfileloc + ) + + +@dataclasses.dataclass(eq=False) +class ReprFileLocation(TerminalRepr): + path: str + lineno: int + message: str + + def __post_init__(self) -> None: + self.path = str(self.path) + + def toterminal(self, tw: TerminalWriter) -> None: + # Filename and lineno output for each entry, using an output format + # that most editors understand. + msg = self.message + i = msg.find("\n") + if i != -1: + msg = msg[:i] + tw.write(self.path, bold=True, red=True) + tw.line(f":{self.lineno}: {msg}") + + +@dataclasses.dataclass(eq=False) +class ReprLocals(TerminalRepr): + lines: Sequence[str] + + def toterminal(self, tw: TerminalWriter, indent="") -> None: + for line in self.lines: + tw.line(indent + line) + + +@dataclasses.dataclass(eq=False) +class ReprFuncArgs(TerminalRepr): + args: Sequence[tuple[str, object]] + + def toterminal(self, tw: TerminalWriter) -> None: + if self.args: + linesofar = "" + for name, value in self.args: + ns = f"{name} = {value}" + if len(ns) + len(linesofar) + 2 > tw.fullwidth: + if linesofar: + tw.line(linesofar) + linesofar = ns + else: + if linesofar: + linesofar += ", " + ns + else: + linesofar = ns + if linesofar: + tw.line(linesofar) + tw.line("") + + +def getfslineno(obj: object) -> tuple[str | Path, int]: + """Return source location (path, lineno) for the given object. + + If the source cannot be determined return ("", -1). + + The line number is 0-based. + """ + # xxx let decorators etc specify a sane ordering + # NOTE: this used to be done in _pytest.compat.getfslineno, initially added + # in 6ec13a2b9. It ("place_as") appears to be something very custom. + obj = get_real_func(obj) + if hasattr(obj, "place_as"): + obj = obj.place_as + + try: + code = Code.from_function(obj) + except TypeError: + try: + fn = inspect.getsourcefile(obj) or inspect.getfile(obj) # type: ignore[arg-type] + except TypeError: + return "", -1 + + fspath = fn and absolutepath(fn) or "" + lineno = -1 + if fspath: + try: + _, lineno = findsource(obj) + except OSError: + pass + return fspath, lineno + + return code.path, code.firstlineno + + +# Relative paths that we use to filter traceback entries from appearing to the user; +# see filter_traceback. +# note: if we need to add more paths than what we have now we should probably use a list +# for better maintenance. + +_PLUGGY_DIR = Path(pluggy.__file__.rstrip("oc")) +# pluggy is either a package or a single module depending on the version +if _PLUGGY_DIR.name == "__init__.py": + _PLUGGY_DIR = _PLUGGY_DIR.parent +_PYTEST_DIR = Path(_pytest.__file__).parent + + +def filter_traceback(entry: TracebackEntry) -> bool: + """Return True if a TracebackEntry instance should be included in tracebacks. + + We hide traceback entries of: + + * dynamically generated code (no code to show up for it); + * internal traceback from pytest or its internal libraries, py and pluggy. + """ + # entry.path might sometimes return a str object when the entry + # points to dynamically generated code. + # See https://bitbucket.org/pytest-dev/py/issues/71. + raw_filename = entry.frame.code.raw.co_filename + is_generated = "<" in raw_filename and ">" in raw_filename + if is_generated: + return False + + # entry.path might point to a non-existing file, in which case it will + # also return a str object. See #1133. + p = Path(entry.path) + + parents = p.parents + if _PLUGGY_DIR in parents: + return False + if _PYTEST_DIR in parents: + return False + + return True diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/_code/source.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_code/source.py new file mode 100644 index 0000000..604aff8 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_code/source.py @@ -0,0 +1,215 @@ +# mypy: allow-untyped-defs +from __future__ import annotations + +import ast +from bisect import bisect_right +import inspect +import textwrap +import tokenize +import types +from typing import Iterable +from typing import Iterator +from typing import overload +import warnings + + +class Source: + """An immutable object holding a source code fragment. + + When using Source(...), the source lines are deindented. + """ + + def __init__(self, obj: object = None) -> None: + if not obj: + self.lines: list[str] = [] + elif isinstance(obj, Source): + self.lines = obj.lines + elif isinstance(obj, (tuple, list)): + self.lines = deindent(x.rstrip("\n") for x in obj) + elif isinstance(obj, str): + self.lines = deindent(obj.split("\n")) + else: + try: + rawcode = getrawcode(obj) + src = inspect.getsource(rawcode) + except TypeError: + src = inspect.getsource(obj) # type: ignore[arg-type] + self.lines = deindent(src.split("\n")) + + def __eq__(self, other: object) -> bool: + if not isinstance(other, Source): + return NotImplemented + return self.lines == other.lines + + # Ignore type because of https://github.com/python/mypy/issues/4266. + __hash__ = None # type: ignore + + @overload + def __getitem__(self, key: int) -> str: ... + + @overload + def __getitem__(self, key: slice) -> Source: ... + + def __getitem__(self, key: int | slice) -> str | Source: + if isinstance(key, int): + return self.lines[key] + else: + if key.step not in (None, 1): + raise IndexError("cannot slice a Source with a step") + newsource = Source() + newsource.lines = self.lines[key.start : key.stop] + return newsource + + def __iter__(self) -> Iterator[str]: + return iter(self.lines) + + def __len__(self) -> int: + return len(self.lines) + + def strip(self) -> Source: + """Return new Source object with trailing and leading blank lines removed.""" + start, end = 0, len(self) + while start < end and not self.lines[start].strip(): + start += 1 + while end > start and not self.lines[end - 1].strip(): + end -= 1 + source = Source() + source.lines[:] = self.lines[start:end] + return source + + def indent(self, indent: str = " " * 4) -> Source: + """Return a copy of the source object with all lines indented by the + given indent-string.""" + newsource = Source() + newsource.lines = [(indent + line) for line in self.lines] + return newsource + + def getstatement(self, lineno: int) -> Source: + """Return Source statement which contains the given linenumber + (counted from 0).""" + start, end = self.getstatementrange(lineno) + return self[start:end] + + def getstatementrange(self, lineno: int) -> tuple[int, int]: + """Return (start, end) tuple which spans the minimal statement region + which containing the given lineno.""" + if not (0 <= lineno < len(self)): + raise IndexError("lineno out of range") + ast, start, end = getstatementrange_ast(lineno, self) + return start, end + + def deindent(self) -> Source: + """Return a new Source object deindented.""" + newsource = Source() + newsource.lines[:] = deindent(self.lines) + return newsource + + def __str__(self) -> str: + return "\n".join(self.lines) + + +# +# helper functions +# + + +def findsource(obj) -> tuple[Source | None, int]: + try: + sourcelines, lineno = inspect.findsource(obj) + except Exception: + return None, -1 + source = Source() + source.lines = [line.rstrip() for line in sourcelines] + return source, lineno + + +def getrawcode(obj: object, trycall: bool = True) -> types.CodeType: + """Return code object for given function.""" + try: + return obj.__code__ # type: ignore[attr-defined,no-any-return] + except AttributeError: + pass + if trycall: + call = getattr(obj, "__call__", None) + if call and not isinstance(obj, type): + return getrawcode(call, trycall=False) + raise TypeError(f"could not get code object for {obj!r}") + + +def deindent(lines: Iterable[str]) -> list[str]: + return textwrap.dedent("\n".join(lines)).splitlines() + + +def get_statement_startend2(lineno: int, node: ast.AST) -> tuple[int, int | None]: + # Flatten all statements and except handlers into one lineno-list. + # AST's line numbers start indexing at 1. + values: list[int] = [] + for x in ast.walk(node): + if isinstance(x, (ast.stmt, ast.ExceptHandler)): + # The lineno points to the class/def, so need to include the decorators. + if isinstance(x, (ast.ClassDef, ast.FunctionDef, ast.AsyncFunctionDef)): + for d in x.decorator_list: + values.append(d.lineno - 1) + values.append(x.lineno - 1) + for name in ("finalbody", "orelse"): + val: list[ast.stmt] | None = getattr(x, name, None) + if val: + # Treat the finally/orelse part as its own statement. + values.append(val[0].lineno - 1 - 1) + values.sort() + insert_index = bisect_right(values, lineno) + start = values[insert_index - 1] + if insert_index >= len(values): + end = None + else: + end = values[insert_index] + return start, end + + +def getstatementrange_ast( + lineno: int, + source: Source, + assertion: bool = False, + astnode: ast.AST | None = None, +) -> tuple[ast.AST, int, int]: + if astnode is None: + content = str(source) + # See #4260: + # Don't produce duplicate warnings when compiling source to find AST. + with warnings.catch_warnings(): + warnings.simplefilter("ignore") + astnode = ast.parse(content, "source", "exec") + + start, end = get_statement_startend2(lineno, astnode) + # We need to correct the end: + # - ast-parsing strips comments + # - there might be empty lines + # - we might have lesser indented code blocks at the end + if end is None: + end = len(source.lines) + + if end > start + 1: + # Make sure we don't span differently indented code blocks + # by using the BlockFinder helper used which inspect.getsource() uses itself. + block_finder = inspect.BlockFinder() + # If we start with an indented line, put blockfinder to "started" mode. + block_finder.started = ( + bool(source.lines[start]) and source.lines[start][0].isspace() + ) + it = ((x + "\n") for x in source.lines[start:end]) + try: + for tok in tokenize.generate_tokens(lambda: next(it)): + block_finder.tokeneater(*tok) + except (inspect.EndOfBlock, IndentationError): + end = block_finder.last + start + except Exception: + pass + + # The end might still point to a comment or empty line, correct it. + while end: + line = source.lines[end - 1].lstrip() + if line.startswith("#") or not line: + end -= 1 + else: + break + return astnode, start, end diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/__init__.py new file mode 100644 index 0000000..b0155b1 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/__init__.py @@ -0,0 +1,10 @@ +from __future__ import annotations + +from .terminalwriter import get_terminal_width +from .terminalwriter import TerminalWriter + + +__all__ = [ + "TerminalWriter", + "get_terminal_width", +] diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/pprint.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/pprint.py new file mode 100644 index 0000000..fc29989 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/pprint.py @@ -0,0 +1,673 @@ +# mypy: allow-untyped-defs +# This module was imported from the cpython standard library +# (https://github.com/python/cpython/) at commit +# c5140945c723ae6c4b7ee81ff720ac8ea4b52cfd (python3.12). +# +# +# Original Author: Fred L. Drake, Jr. +# fdrake@acm.org +# +# This is a simple little module I wrote to make life easier. I didn't +# see anything quite like it in the library, though I may have overlooked +# something. I wrote this when I was trying to read some heavily nested +# tuples with fairly non-descriptive content. This is modeled very much +# after Lisp/Scheme - style pretty-printing of lists. If you find it +# useful, thank small children who sleep at night. +from __future__ import annotations + +import collections as _collections +import dataclasses as _dataclasses +from io import StringIO as _StringIO +import re +import types as _types +from typing import Any +from typing import Callable +from typing import IO +from typing import Iterator + + +class _safe_key: + """Helper function for key functions when sorting unorderable objects. + + The wrapped-object will fallback to a Py2.x style comparison for + unorderable types (sorting first comparing the type name and then by + the obj ids). Does not work recursively, so dict.items() must have + _safe_key applied to both the key and the value. + + """ + + __slots__ = ["obj"] + + def __init__(self, obj): + self.obj = obj + + def __lt__(self, other): + try: + return self.obj < other.obj + except TypeError: + return (str(type(self.obj)), id(self.obj)) < ( + str(type(other.obj)), + id(other.obj), + ) + + +def _safe_tuple(t): + """Helper function for comparing 2-tuples""" + return _safe_key(t[0]), _safe_key(t[1]) + + +class PrettyPrinter: + def __init__( + self, + indent: int = 4, + width: int = 80, + depth: int | None = None, + ) -> None: + """Handle pretty printing operations onto a stream using a set of + configured parameters. + + indent + Number of spaces to indent for each level of nesting. + + width + Attempted maximum number of columns in the output. + + depth + The maximum depth to print out nested structures. + + """ + if indent < 0: + raise ValueError("indent must be >= 0") + if depth is not None and depth <= 0: + raise ValueError("depth must be > 0") + if not width: + raise ValueError("width must be != 0") + self._depth = depth + self._indent_per_level = indent + self._width = width + + def pformat(self, object: Any) -> str: + sio = _StringIO() + self._format(object, sio, 0, 0, set(), 0) + return sio.getvalue() + + def _format( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + objid = id(object) + if objid in context: + stream.write(_recursion(object)) + return + + p = self._dispatch.get(type(object).__repr__, None) + if p is not None: + context.add(objid) + p(self, object, stream, indent, allowance, context, level + 1) + context.remove(objid) + elif ( + _dataclasses.is_dataclass(object) # type:ignore[unreachable] + and not isinstance(object, type) + and object.__dataclass_params__.repr + and + # Check dataclass has generated repr method. + hasattr(object.__repr__, "__wrapped__") + and "__create_fn__" in object.__repr__.__wrapped__.__qualname__ + ): + context.add(objid) # type:ignore[unreachable] + self._pprint_dataclass( + object, stream, indent, allowance, context, level + 1 + ) + context.remove(objid) + else: + stream.write(self._repr(object, context, level)) + + def _pprint_dataclass( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + cls_name = object.__class__.__name__ + items = [ + (f.name, getattr(object, f.name)) + for f in _dataclasses.fields(object) + if f.repr + ] + stream.write(cls_name + "(") + self._format_namespace_items(items, stream, indent, allowance, context, level) + stream.write(")") + + _dispatch: dict[ + Callable[..., str], + Callable[[PrettyPrinter, Any, IO[str], int, int, set[int], int], None], + ] = {} + + def _pprint_dict( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + write = stream.write + write("{") + items = sorted(object.items(), key=_safe_tuple) + self._format_dict_items(items, stream, indent, allowance, context, level) + write("}") + + _dispatch[dict.__repr__] = _pprint_dict + + def _pprint_ordered_dict( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + if not len(object): + stream.write(repr(object)) + return + cls = object.__class__ + stream.write(cls.__name__ + "(") + self._pprint_dict(object, stream, indent, allowance, context, level) + stream.write(")") + + _dispatch[_collections.OrderedDict.__repr__] = _pprint_ordered_dict + + def _pprint_list( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + stream.write("[") + self._format_items(object, stream, indent, allowance, context, level) + stream.write("]") + + _dispatch[list.__repr__] = _pprint_list + + def _pprint_tuple( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + stream.write("(") + self._format_items(object, stream, indent, allowance, context, level) + stream.write(")") + + _dispatch[tuple.__repr__] = _pprint_tuple + + def _pprint_set( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + if not len(object): + stream.write(repr(object)) + return + typ = object.__class__ + if typ is set: + stream.write("{") + endchar = "}" + else: + stream.write(typ.__name__ + "({") + endchar = "})" + object = sorted(object, key=_safe_key) + self._format_items(object, stream, indent, allowance, context, level) + stream.write(endchar) + + _dispatch[set.__repr__] = _pprint_set + _dispatch[frozenset.__repr__] = _pprint_set + + def _pprint_str( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + write = stream.write + if not len(object): + write(repr(object)) + return + chunks = [] + lines = object.splitlines(True) + if level == 1: + indent += 1 + allowance += 1 + max_width1 = max_width = self._width - indent + for i, line in enumerate(lines): + rep = repr(line) + if i == len(lines) - 1: + max_width1 -= allowance + if len(rep) <= max_width1: + chunks.append(rep) + else: + # A list of alternating (non-space, space) strings + parts = re.findall(r"\S*\s*", line) + assert parts + assert not parts[-1] + parts.pop() # drop empty last part + max_width2 = max_width + current = "" + for j, part in enumerate(parts): + candidate = current + part + if j == len(parts) - 1 and i == len(lines) - 1: + max_width2 -= allowance + if len(repr(candidate)) > max_width2: + if current: + chunks.append(repr(current)) + current = part + else: + current = candidate + if current: + chunks.append(repr(current)) + if len(chunks) == 1: + write(rep) + return + if level == 1: + write("(") + for i, rep in enumerate(chunks): + if i > 0: + write("\n" + " " * indent) + write(rep) + if level == 1: + write(")") + + _dispatch[str.__repr__] = _pprint_str + + def _pprint_bytes( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + write = stream.write + if len(object) <= 4: + write(repr(object)) + return + parens = level == 1 + if parens: + indent += 1 + allowance += 1 + write("(") + delim = "" + for rep in _wrap_bytes_repr(object, self._width - indent, allowance): + write(delim) + write(rep) + if not delim: + delim = "\n" + " " * indent + if parens: + write(")") + + _dispatch[bytes.__repr__] = _pprint_bytes + + def _pprint_bytearray( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + write = stream.write + write("bytearray(") + self._pprint_bytes( + bytes(object), stream, indent + 10, allowance + 1, context, level + 1 + ) + write(")") + + _dispatch[bytearray.__repr__] = _pprint_bytearray + + def _pprint_mappingproxy( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + stream.write("mappingproxy(") + self._format(object.copy(), stream, indent, allowance, context, level) + stream.write(")") + + _dispatch[_types.MappingProxyType.__repr__] = _pprint_mappingproxy + + def _pprint_simplenamespace( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + if type(object) is _types.SimpleNamespace: + # The SimpleNamespace repr is "namespace" instead of the class + # name, so we do the same here. For subclasses; use the class name. + cls_name = "namespace" + else: + cls_name = object.__class__.__name__ + items = object.__dict__.items() + stream.write(cls_name + "(") + self._format_namespace_items(items, stream, indent, allowance, context, level) + stream.write(")") + + _dispatch[_types.SimpleNamespace.__repr__] = _pprint_simplenamespace + + def _format_dict_items( + self, + items: list[tuple[Any, Any]], + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + if not items: + return + + write = stream.write + item_indent = indent + self._indent_per_level + delimnl = "\n" + " " * item_indent + for key, ent in items: + write(delimnl) + write(self._repr(key, context, level)) + write(": ") + self._format(ent, stream, item_indent, 1, context, level) + write(",") + + write("\n" + " " * indent) + + def _format_namespace_items( + self, + items: list[tuple[Any, Any]], + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + if not items: + return + + write = stream.write + item_indent = indent + self._indent_per_level + delimnl = "\n" + " " * item_indent + for key, ent in items: + write(delimnl) + write(key) + write("=") + if id(ent) in context: + # Special-case representation of recursion to match standard + # recursive dataclass repr. + write("...") + else: + self._format( + ent, + stream, + item_indent + len(key) + 1, + 1, + context, + level, + ) + + write(",") + + write("\n" + " " * indent) + + def _format_items( + self, + items: list[Any], + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + if not items: + return + + write = stream.write + item_indent = indent + self._indent_per_level + delimnl = "\n" + " " * item_indent + + for item in items: + write(delimnl) + self._format(item, stream, item_indent, 1, context, level) + write(",") + + write("\n" + " " * indent) + + def _repr(self, object: Any, context: set[int], level: int) -> str: + return self._safe_repr(object, context.copy(), self._depth, level) + + def _pprint_default_dict( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + rdf = self._repr(object.default_factory, context, level) + stream.write(f"{object.__class__.__name__}({rdf}, ") + self._pprint_dict(object, stream, indent, allowance, context, level) + stream.write(")") + + _dispatch[_collections.defaultdict.__repr__] = _pprint_default_dict + + def _pprint_counter( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + stream.write(object.__class__.__name__ + "(") + + if object: + stream.write("{") + items = object.most_common() + self._format_dict_items(items, stream, indent, allowance, context, level) + stream.write("}") + + stream.write(")") + + _dispatch[_collections.Counter.__repr__] = _pprint_counter + + def _pprint_chain_map( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + if not len(object.maps) or (len(object.maps) == 1 and not len(object.maps[0])): + stream.write(repr(object)) + return + + stream.write(object.__class__.__name__ + "(") + self._format_items(object.maps, stream, indent, allowance, context, level) + stream.write(")") + + _dispatch[_collections.ChainMap.__repr__] = _pprint_chain_map + + def _pprint_deque( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + stream.write(object.__class__.__name__ + "(") + if object.maxlen is not None: + stream.write("maxlen=%d, " % object.maxlen) + stream.write("[") + + self._format_items(object, stream, indent, allowance + 1, context, level) + stream.write("])") + + _dispatch[_collections.deque.__repr__] = _pprint_deque + + def _pprint_user_dict( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + self._format(object.data, stream, indent, allowance, context, level - 1) + + _dispatch[_collections.UserDict.__repr__] = _pprint_user_dict + + def _pprint_user_list( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + self._format(object.data, stream, indent, allowance, context, level - 1) + + _dispatch[_collections.UserList.__repr__] = _pprint_user_list + + def _pprint_user_string( + self, + object: Any, + stream: IO[str], + indent: int, + allowance: int, + context: set[int], + level: int, + ) -> None: + self._format(object.data, stream, indent, allowance, context, level - 1) + + _dispatch[_collections.UserString.__repr__] = _pprint_user_string + + def _safe_repr( + self, object: Any, context: set[int], maxlevels: int | None, level: int + ) -> str: + typ = type(object) + if typ in _builtin_scalars: + return repr(object) + + r = getattr(typ, "__repr__", None) + + if issubclass(typ, dict) and r is dict.__repr__: + if not object: + return "{}" + objid = id(object) + if maxlevels and level >= maxlevels: + return "{...}" + if objid in context: + return _recursion(object) + context.add(objid) + components: list[str] = [] + append = components.append + level += 1 + for k, v in sorted(object.items(), key=_safe_tuple): + krepr = self._safe_repr(k, context, maxlevels, level) + vrepr = self._safe_repr(v, context, maxlevels, level) + append(f"{krepr}: {vrepr}") + context.remove(objid) + return "{{{}}}".format(", ".join(components)) + + if (issubclass(typ, list) and r is list.__repr__) or ( + issubclass(typ, tuple) and r is tuple.__repr__ + ): + if issubclass(typ, list): + if not object: + return "[]" + format = "[%s]" + elif len(object) == 1: + format = "(%s,)" + else: + if not object: + return "()" + format = "(%s)" + objid = id(object) + if maxlevels and level >= maxlevels: + return format % "..." + if objid in context: + return _recursion(object) + context.add(objid) + components = [] + append = components.append + level += 1 + for o in object: + orepr = self._safe_repr(o, context, maxlevels, level) + append(orepr) + context.remove(objid) + return format % ", ".join(components) + + return repr(object) + + +_builtin_scalars = frozenset( + {str, bytes, bytearray, float, complex, bool, type(None), int} +) + + +def _recursion(object: Any) -> str: + return f"" + + +def _wrap_bytes_repr(object: Any, width: int, allowance: int) -> Iterator[str]: + current = b"" + last = len(object) // 4 * 4 + for i in range(0, len(object), 4): + part = object[i : i + 4] + candidate = current + part + if i == last: + width -= allowance + if len(repr(candidate)) > width: + if current: + yield repr(current) + current = part + else: + current = candidate + if current: + yield repr(current) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/saferepr.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/saferepr.py new file mode 100644 index 0000000..cee70e3 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/saferepr.py @@ -0,0 +1,130 @@ +from __future__ import annotations + +import pprint +import reprlib + + +def _try_repr_or_str(obj: object) -> str: + try: + return repr(obj) + except (KeyboardInterrupt, SystemExit): + raise + except BaseException: + return f'{type(obj).__name__}("{obj}")' + + +def _format_repr_exception(exc: BaseException, obj: object) -> str: + try: + exc_info = _try_repr_or_str(exc) + except (KeyboardInterrupt, SystemExit): + raise + except BaseException as inner_exc: + exc_info = f"unpresentable exception ({_try_repr_or_str(inner_exc)})" + return ( + f"<[{exc_info} raised in repr()] {type(obj).__name__} object at 0x{id(obj):x}>" + ) + + +def _ellipsize(s: str, maxsize: int) -> str: + if len(s) > maxsize: + i = max(0, (maxsize - 3) // 2) + j = max(0, maxsize - 3 - i) + return s[:i] + "..." + s[len(s) - j :] + return s + + +class SafeRepr(reprlib.Repr): + """ + repr.Repr that limits the resulting size of repr() and includes + information on exceptions raised during the call. + """ + + def __init__(self, maxsize: int | None, use_ascii: bool = False) -> None: + """ + :param maxsize: + If not None, will truncate the resulting repr to that specific size, using ellipsis + somewhere in the middle to hide the extra text. + If None, will not impose any size limits on the returning repr. + """ + super().__init__() + # ``maxstring`` is used by the superclass, and needs to be an int; using a + # very large number in case maxsize is None, meaning we want to disable + # truncation. + self.maxstring = maxsize if maxsize is not None else 1_000_000_000 + self.maxsize = maxsize + self.use_ascii = use_ascii + + def repr(self, x: object) -> str: + try: + if self.use_ascii: + s = ascii(x) + else: + s = super().repr(x) + except (KeyboardInterrupt, SystemExit): + raise + except BaseException as exc: + s = _format_repr_exception(exc, x) + if self.maxsize is not None: + s = _ellipsize(s, self.maxsize) + return s + + def repr_instance(self, x: object, level: int) -> str: + try: + s = repr(x) + except (KeyboardInterrupt, SystemExit): + raise + except BaseException as exc: + s = _format_repr_exception(exc, x) + if self.maxsize is not None: + s = _ellipsize(s, self.maxsize) + return s + + +def safeformat(obj: object) -> str: + """Return a pretty printed string for the given object. + + Failing __repr__ functions of user instances will be represented + with a short exception info. + """ + try: + return pprint.pformat(obj) + except Exception as exc: + return _format_repr_exception(exc, obj) + + +# Maximum size of overall repr of objects to display during assertion errors. +DEFAULT_REPR_MAX_SIZE = 240 + + +def saferepr( + obj: object, maxsize: int | None = DEFAULT_REPR_MAX_SIZE, use_ascii: bool = False +) -> str: + """Return a size-limited safe repr-string for the given object. + + Failing __repr__ functions of user instances will be represented + with a short exception info and 'saferepr' generally takes + care to never raise exceptions itself. + + This function is a wrapper around the Repr/reprlib functionality of the + stdlib. + """ + return SafeRepr(maxsize, use_ascii).repr(obj) + + +def saferepr_unlimited(obj: object, use_ascii: bool = True) -> str: + """Return an unlimited-size safe repr-string for the given object. + + As with saferepr, failing __repr__ functions of user instances + will be represented with a short exception info. + + This function is a wrapper around simple repr. + + Note: a cleaner solution would be to alter ``saferepr``this way + when maxsize=None, but that might affect some other code. + """ + try: + if use_ascii: + return ascii(obj) + return repr(obj) + except Exception as exc: + return _format_repr_exception(exc, obj) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/terminalwriter.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/terminalwriter.py new file mode 100644 index 0000000..70ebd3d --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/terminalwriter.py @@ -0,0 +1,274 @@ +"""Helper functions for writing to terminals and files.""" + +from __future__ import annotations + +import os +import shutil +import sys +from typing import final +from typing import Literal +from typing import Sequence +from typing import TextIO +from typing import TYPE_CHECKING + +from ..compat import assert_never +from .wcwidth import wcswidth + + +if TYPE_CHECKING: + from pygments.formatter import Formatter + from pygments.lexer import Lexer + + +# This code was initially copied from py 1.8.1, file _io/terminalwriter.py. + + +def get_terminal_width() -> int: + width, _ = shutil.get_terminal_size(fallback=(80, 24)) + + # The Windows get_terminal_size may be bogus, let's sanify a bit. + if width < 40: + width = 80 + + return width + + +def should_do_markup(file: TextIO) -> bool: + if os.environ.get("PY_COLORS") == "1": + return True + if os.environ.get("PY_COLORS") == "0": + return False + if os.environ.get("NO_COLOR"): + return False + if os.environ.get("FORCE_COLOR"): + return True + return ( + hasattr(file, "isatty") and file.isatty() and os.environ.get("TERM") != "dumb" + ) + + +@final +class TerminalWriter: + _esctable = dict( + black=30, + red=31, + green=32, + yellow=33, + blue=34, + purple=35, + cyan=36, + white=37, + Black=40, + Red=41, + Green=42, + Yellow=43, + Blue=44, + Purple=45, + Cyan=46, + White=47, + bold=1, + light=2, + blink=5, + invert=7, + ) + + def __init__(self, file: TextIO | None = None) -> None: + if file is None: + file = sys.stdout + if hasattr(file, "isatty") and file.isatty() and sys.platform == "win32": + try: + import colorama + except ImportError: + pass + else: + file = colorama.AnsiToWin32(file).stream + assert file is not None + self._file = file + self.hasmarkup = should_do_markup(file) + self._current_line = "" + self._terminal_width: int | None = None + self.code_highlight = True + + @property + def fullwidth(self) -> int: + if self._terminal_width is not None: + return self._terminal_width + return get_terminal_width() + + @fullwidth.setter + def fullwidth(self, value: int) -> None: + self._terminal_width = value + + @property + def width_of_current_line(self) -> int: + """Return an estimate of the width so far in the current line.""" + return wcswidth(self._current_line) + + def markup(self, text: str, **markup: bool) -> str: + for name in markup: + if name not in self._esctable: + raise ValueError(f"unknown markup: {name!r}") + if self.hasmarkup: + esc = [self._esctable[name] for name, on in markup.items() if on] + if esc: + text = "".join(f"\x1b[{cod}m" for cod in esc) + text + "\x1b[0m" + return text + + def sep( + self, + sepchar: str, + title: str | None = None, + fullwidth: int | None = None, + **markup: bool, + ) -> None: + if fullwidth is None: + fullwidth = self.fullwidth + # The goal is to have the line be as long as possible + # under the condition that len(line) <= fullwidth. + if sys.platform == "win32": + # If we print in the last column on windows we are on a + # new line but there is no way to verify/neutralize this + # (we may not know the exact line width). + # So let's be defensive to avoid empty lines in the output. + fullwidth -= 1 + if title is not None: + # we want 2 + 2*len(fill) + len(title) <= fullwidth + # i.e. 2 + 2*len(sepchar)*N + len(title) <= fullwidth + # 2*len(sepchar)*N <= fullwidth - len(title) - 2 + # N <= (fullwidth - len(title) - 2) // (2*len(sepchar)) + N = max((fullwidth - len(title) - 2) // (2 * len(sepchar)), 1) + fill = sepchar * N + line = f"{fill} {title} {fill}" + else: + # we want len(sepchar)*N <= fullwidth + # i.e. N <= fullwidth // len(sepchar) + line = sepchar * (fullwidth // len(sepchar)) + # In some situations there is room for an extra sepchar at the right, + # in particular if we consider that with a sepchar like "_ " the + # trailing space is not important at the end of the line. + if len(line) + len(sepchar.rstrip()) <= fullwidth: + line += sepchar.rstrip() + + self.line(line, **markup) + + def write(self, msg: str, *, flush: bool = False, **markup: bool) -> None: + if msg: + current_line = msg.rsplit("\n", 1)[-1] + if "\n" in msg: + self._current_line = current_line + else: + self._current_line += current_line + + msg = self.markup(msg, **markup) + + try: + self._file.write(msg) + except UnicodeEncodeError: + # Some environments don't support printing general Unicode + # strings, due to misconfiguration or otherwise; in that case, + # print the string escaped to ASCII. + # When the Unicode situation improves we should consider + # letting the error propagate instead of masking it (see #7475 + # for one brief attempt). + msg = msg.encode("unicode-escape").decode("ascii") + self._file.write(msg) + + if flush: + self.flush() + + def line(self, s: str = "", **markup: bool) -> None: + self.write(s, **markup) + self.write("\n") + + def flush(self) -> None: + self._file.flush() + + def _write_source(self, lines: Sequence[str], indents: Sequence[str] = ()) -> None: + """Write lines of source code possibly highlighted. + + Keeping this private for now because the API is clunky. We should discuss how + to evolve the terminal writer so we can have more precise color support, for example + being able to write part of a line in one color and the rest in another, and so on. + """ + if indents and len(indents) != len(lines): + raise ValueError( + f"indents size ({len(indents)}) should have same size as lines ({len(lines)})" + ) + if not indents: + indents = [""] * len(lines) + source = "\n".join(lines) + new_lines = self._highlight(source).splitlines() + for indent, new_line in zip(indents, new_lines): + self.line(indent + new_line) + + def _get_pygments_lexer(self, lexer: Literal["python", "diff"]) -> Lexer | None: + try: + if lexer == "python": + from pygments.lexers.python import PythonLexer + + return PythonLexer() + elif lexer == "diff": + from pygments.lexers.diff import DiffLexer + + return DiffLexer() + else: + assert_never(lexer) + except ModuleNotFoundError: + return None + + def _get_pygments_formatter(self) -> Formatter | None: + try: + import pygments.util + except ModuleNotFoundError: + return None + + from _pytest.config.exceptions import UsageError + + theme = os.getenv("PYTEST_THEME") + theme_mode = os.getenv("PYTEST_THEME_MODE", "dark") + + try: + from pygments.formatters.terminal import TerminalFormatter + + return TerminalFormatter(bg=theme_mode, style=theme) + + except pygments.util.ClassNotFound as e: + raise UsageError( + f"PYTEST_THEME environment variable has an invalid value: '{theme}'. " + "Hint: See available pygments styles with `pygmentize -L styles`." + ) from e + except pygments.util.OptionError as e: + raise UsageError( + f"PYTEST_THEME_MODE environment variable has an invalid value: '{theme_mode}'. " + "The allowed values are 'dark' (default) and 'light'." + ) from e + + def _highlight( + self, source: str, lexer: Literal["diff", "python"] = "python" + ) -> str: + """Highlight the given source if we have markup support.""" + if not source or not self.hasmarkup or not self.code_highlight: + return source + + pygments_lexer = self._get_pygments_lexer(lexer) + if pygments_lexer is None: + return source + + pygments_formatter = self._get_pygments_formatter() + if pygments_formatter is None: + return source + + from pygments import highlight + + highlighted: str = highlight(source, pygments_lexer, pygments_formatter) + # pygments terminal formatter may add a newline when there wasn't one. + # We don't want this, remove. + if highlighted[-1] == "\n" and source[-1] != "\n": + highlighted = highlighted[:-1] + + # Some lexers will not set the initial color explicitly + # which may lead to the previous color being propagated to the + # start of the expression, so reset first. + highlighted = "\x1b[0m" + highlighted + + return highlighted diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/wcwidth.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/wcwidth.py new file mode 100644 index 0000000..23886ff --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_io/wcwidth.py @@ -0,0 +1,57 @@ +from __future__ import annotations + +from functools import lru_cache +import unicodedata + + +@lru_cache(100) +def wcwidth(c: str) -> int: + """Determine how many columns are needed to display a character in a terminal. + + Returns -1 if the character is not printable. + Returns 0, 1 or 2 for other characters. + """ + o = ord(c) + + # ASCII fast path. + if 0x20 <= o < 0x07F: + return 1 + + # Some Cf/Zp/Zl characters which should be zero-width. + if ( + o == 0x0000 + or 0x200B <= o <= 0x200F + or 0x2028 <= o <= 0x202E + or 0x2060 <= o <= 0x2063 + ): + return 0 + + category = unicodedata.category(c) + + # Control characters. + if category == "Cc": + return -1 + + # Combining characters with zero width. + if category in ("Me", "Mn"): + return 0 + + # Full/Wide east asian characters. + if unicodedata.east_asian_width(c) in ("F", "W"): + return 2 + + return 1 + + +def wcswidth(s: str) -> int: + """Determine how many columns are needed to display a string in a terminal. + + Returns -1 if the string contains non-printable characters. + """ + width = 0 + for c in unicodedata.normalize("NFC", s): + wc = wcwidth(c) + if wc < 0: + return -1 + width += wc + return width diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/_py/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_py/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/_py/error.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_py/error.py new file mode 100644 index 0000000..ab3a4ed --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_py/error.py @@ -0,0 +1,111 @@ +"""create errno-specific classes for IO or os calls.""" + +from __future__ import annotations + +import errno +import os +import sys +from typing import Callable +from typing import TYPE_CHECKING +from typing import TypeVar + + +if TYPE_CHECKING: + from typing_extensions import ParamSpec + + P = ParamSpec("P") + +R = TypeVar("R") + + +class Error(EnvironmentError): + def __repr__(self) -> str: + return "{}.{} {!r}: {} ".format( + self.__class__.__module__, + self.__class__.__name__, + self.__class__.__doc__, + " ".join(map(str, self.args)), + # repr(self.args) + ) + + def __str__(self) -> str: + s = "[{}]: {}".format( + self.__class__.__doc__, + " ".join(map(str, self.args)), + ) + return s + + +_winerrnomap = { + 2: errno.ENOENT, + 3: errno.ENOENT, + 17: errno.EEXIST, + 18: errno.EXDEV, + 13: errno.EBUSY, # empty cd drive, but ENOMEDIUM seems unavailable + 22: errno.ENOTDIR, + 20: errno.ENOTDIR, + 267: errno.ENOTDIR, + 5: errno.EACCES, # anything better? +} + + +class ErrorMaker: + """lazily provides Exception classes for each possible POSIX errno + (as defined per the 'errno' module). All such instances + subclass EnvironmentError. + """ + + _errno2class: dict[int, type[Error]] = {} + + def __getattr__(self, name: str) -> type[Error]: + if name[0] == "_": + raise AttributeError(name) + eno = getattr(errno, name) + cls = self._geterrnoclass(eno) + setattr(self, name, cls) + return cls + + def _geterrnoclass(self, eno: int) -> type[Error]: + try: + return self._errno2class[eno] + except KeyError: + clsname = errno.errorcode.get(eno, "UnknownErrno%d" % (eno,)) + errorcls = type( + clsname, + (Error,), + {"__module__": "py.error", "__doc__": os.strerror(eno)}, + ) + self._errno2class[eno] = errorcls + return errorcls + + def checked_call( + self, func: Callable[P, R], *args: P.args, **kwargs: P.kwargs + ) -> R: + """Call a function and raise an errno-exception if applicable.""" + __tracebackhide__ = True + try: + return func(*args, **kwargs) + except Error: + raise + except OSError as value: + if not hasattr(value, "errno"): + raise + errno = value.errno + if sys.platform == "win32": + try: + cls = self._geterrnoclass(_winerrnomap[errno]) + except KeyError: + raise value + else: + # we are not on Windows, or we got a proper OSError + cls = self._geterrnoclass(errno) + + raise cls(f"{func.__name__}{args!r}") + + +_error_maker = ErrorMaker() +checked_call = _error_maker.checked_call + + +def __getattr__(attr: str) -> type[Error]: + return getattr(_error_maker, attr) # type: ignore[no-any-return] diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/_py/path.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_py/path.py new file mode 100644 index 0000000..c7ab118 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_py/path.py @@ -0,0 +1,1475 @@ +# mypy: allow-untyped-defs +"""local path implementation.""" + +from __future__ import annotations + +import atexit +from contextlib import contextmanager +import fnmatch +import importlib.util +import io +import os +from os.path import abspath +from os.path import dirname +from os.path import exists +from os.path import isabs +from os.path import isdir +from os.path import isfile +from os.path import islink +from os.path import normpath +import posixpath +from stat import S_ISDIR +from stat import S_ISLNK +from stat import S_ISREG +import sys +from typing import Any +from typing import Callable +from typing import cast +from typing import Literal +from typing import overload +from typing import TYPE_CHECKING +import uuid +import warnings + +from . import error + + +# Moved from local.py. +iswin32 = sys.platform == "win32" or (getattr(os, "_name", False) == "nt") + + +class Checkers: + _depend_on_existence = "exists", "link", "dir", "file" + + def __init__(self, path): + self.path = path + + def dotfile(self): + return self.path.basename.startswith(".") + + def ext(self, arg): + if not arg.startswith("."): + arg = "." + arg + return self.path.ext == arg + + def basename(self, arg): + return self.path.basename == arg + + def basestarts(self, arg): + return self.path.basename.startswith(arg) + + def relto(self, arg): + return self.path.relto(arg) + + def fnmatch(self, arg): + return self.path.fnmatch(arg) + + def endswith(self, arg): + return str(self.path).endswith(arg) + + def _evaluate(self, kw): + from .._code.source import getrawcode + + for name, value in kw.items(): + invert = False + meth = None + try: + meth = getattr(self, name) + except AttributeError: + if name[:3] == "not": + invert = True + try: + meth = getattr(self, name[3:]) + except AttributeError: + pass + if meth is None: + raise TypeError(f"no {name!r} checker available for {self.path!r}") + try: + if getrawcode(meth).co_argcount > 1: + if (not meth(value)) ^ invert: + return False + else: + if bool(value) ^ bool(meth()) ^ invert: + return False + except (error.ENOENT, error.ENOTDIR, error.EBUSY): + # EBUSY feels not entirely correct, + # but its kind of necessary since ENOMEDIUM + # is not accessible in python + for name in self._depend_on_existence: + if name in kw: + if kw.get(name): + return False + name = "not" + name + if name in kw: + if not kw.get(name): + return False + return True + + _statcache: Stat + + def _stat(self) -> Stat: + try: + return self._statcache + except AttributeError: + try: + self._statcache = self.path.stat() + except error.ELOOP: + self._statcache = self.path.lstat() + return self._statcache + + def dir(self): + return S_ISDIR(self._stat().mode) + + def file(self): + return S_ISREG(self._stat().mode) + + def exists(self): + return self._stat() + + def link(self): + st = self.path.lstat() + return S_ISLNK(st.mode) + + +class NeverRaised(Exception): + pass + + +class Visitor: + def __init__(self, fil, rec, ignore, bf, sort): + if isinstance(fil, str): + fil = FNMatcher(fil) + if isinstance(rec, str): + self.rec: Callable[[LocalPath], bool] = FNMatcher(rec) + elif not hasattr(rec, "__call__") and rec: + self.rec = lambda path: True + else: + self.rec = rec + self.fil = fil + self.ignore = ignore + self.breadthfirst = bf + self.optsort = cast(Callable[[Any], Any], sorted) if sort else (lambda x: x) + + def gen(self, path): + try: + entries = path.listdir() + except self.ignore: + return + rec = self.rec + dirs = self.optsort( + [p for p in entries if p.check(dir=1) and (rec is None or rec(p))] + ) + if not self.breadthfirst: + for subdir in dirs: + yield from self.gen(subdir) + for p in self.optsort(entries): + if self.fil is None or self.fil(p): + yield p + if self.breadthfirst: + for subdir in dirs: + yield from self.gen(subdir) + + +class FNMatcher: + def __init__(self, pattern): + self.pattern = pattern + + def __call__(self, path): + pattern = self.pattern + + if ( + pattern.find(path.sep) == -1 + and iswin32 + and pattern.find(posixpath.sep) != -1 + ): + # Running on Windows, the pattern has no Windows path separators, + # and the pattern has one or more Posix path separators. Replace + # the Posix path separators with the Windows path separator. + pattern = pattern.replace(posixpath.sep, path.sep) + + if pattern.find(path.sep) == -1: + name = path.basename + else: + name = str(path) # path.strpath # XXX svn? + if not os.path.isabs(pattern): + pattern = "*" + path.sep + pattern + return fnmatch.fnmatch(name, pattern) + + +def map_as_list(func, iter): + return list(map(func, iter)) + + +class Stat: + if TYPE_CHECKING: + + @property + def size(self) -> int: ... + + @property + def mtime(self) -> float: ... + + def __getattr__(self, name: str) -> Any: + return getattr(self._osstatresult, "st_" + name) + + def __init__(self, path, osstatresult): + self.path = path + self._osstatresult = osstatresult + + @property + def owner(self): + if iswin32: + raise NotImplementedError("XXX win32") + import pwd + + entry = error.checked_call(pwd.getpwuid, self.uid) # type:ignore[attr-defined,unused-ignore] + return entry[0] + + @property + def group(self): + """Return group name of file.""" + if iswin32: + raise NotImplementedError("XXX win32") + import grp + + entry = error.checked_call(grp.getgrgid, self.gid) # type:ignore[attr-defined,unused-ignore] + return entry[0] + + def isdir(self): + return S_ISDIR(self._osstatresult.st_mode) + + def isfile(self): + return S_ISREG(self._osstatresult.st_mode) + + def islink(self): + self.path.lstat() + return S_ISLNK(self._osstatresult.st_mode) + + +def getuserid(user): + import pwd + + if not isinstance(user, int): + user = pwd.getpwnam(user)[2] # type:ignore[attr-defined,unused-ignore] + return user + + +def getgroupid(group): + import grp + + if not isinstance(group, int): + group = grp.getgrnam(group)[2] # type:ignore[attr-defined,unused-ignore] + return group + + +class LocalPath: + """Object oriented interface to os.path and other local filesystem + related information. + """ + + class ImportMismatchError(ImportError): + """raised on pyimport() if there is a mismatch of __file__'s""" + + sep = os.sep + + def __init__(self, path=None, expanduser=False): + """Initialize and return a local Path instance. + + Path can be relative to the current directory. + If path is None it defaults to the current working directory. + If expanduser is True, tilde-expansion is performed. + Note that Path instances always carry an absolute path. + Note also that passing in a local path object will simply return + the exact same path object. Use new() to get a new copy. + """ + if path is None: + self.strpath = error.checked_call(os.getcwd) + else: + try: + path = os.fspath(path) + except TypeError: + raise ValueError( + "can only pass None, Path instances " + "or non-empty strings to LocalPath" + ) + if expanduser: + path = os.path.expanduser(path) + self.strpath = abspath(path) + + if sys.platform != "win32": + + def chown(self, user, group, rec=0): + """Change ownership to the given user and group. + user and group may be specified by a number or + by a name. if rec is True change ownership + recursively. + """ + uid = getuserid(user) + gid = getgroupid(group) + if rec: + for x in self.visit(rec=lambda x: x.check(link=0)): + if x.check(link=0): + error.checked_call(os.chown, str(x), uid, gid) + error.checked_call(os.chown, str(self), uid, gid) + + def readlink(self) -> str: + """Return value of a symbolic link.""" + # https://github.com/python/mypy/issues/12278 + return error.checked_call(os.readlink, self.strpath) # type: ignore[arg-type,return-value,unused-ignore] + + def mklinkto(self, oldname): + """Posix style hard link to another name.""" + error.checked_call(os.link, str(oldname), str(self)) + + def mksymlinkto(self, value, absolute=1): + """Create a symbolic link with the given value (pointing to another name).""" + if absolute: + error.checked_call(os.symlink, str(value), self.strpath) + else: + base = self.common(value) + # with posix local paths '/' is always a common base + relsource = self.__class__(value).relto(base) + reldest = self.relto(base) + n = reldest.count(self.sep) + target = self.sep.join(("..",) * n + (relsource,)) + error.checked_call(os.symlink, target, self.strpath) + + def __div__(self, other): + return self.join(os.fspath(other)) + + __truediv__ = __div__ # py3k + + @property + def basename(self): + """Basename part of path.""" + return self._getbyspec("basename")[0] + + @property + def dirname(self): + """Dirname part of path.""" + return self._getbyspec("dirname")[0] + + @property + def purebasename(self): + """Pure base name of the path.""" + return self._getbyspec("purebasename")[0] + + @property + def ext(self): + """Extension of the path (including the '.').""" + return self._getbyspec("ext")[0] + + def read_binary(self): + """Read and return a bytestring from reading the path.""" + with self.open("rb") as f: + return f.read() + + def read_text(self, encoding): + """Read and return a Unicode string from reading the path.""" + with self.open("r", encoding=encoding) as f: + return f.read() + + def read(self, mode="r"): + """Read and return a bytestring from reading the path.""" + with self.open(mode) as f: + return f.read() + + def readlines(self, cr=1): + """Read and return a list of lines from the path. if cr is False, the + newline will be removed from the end of each line.""" + mode = "r" + + if not cr: + content = self.read(mode) + return content.split("\n") + else: + f = self.open(mode) + try: + return f.readlines() + finally: + f.close() + + def load(self): + """(deprecated) return object unpickled from self.read()""" + f = self.open("rb") + try: + import pickle + + return error.checked_call(pickle.load, f) + finally: + f.close() + + def move(self, target): + """Move this path to target.""" + if target.relto(self): + raise error.EINVAL(target, "cannot move path into a subdirectory of itself") + try: + self.rename(target) + except error.EXDEV: # invalid cross-device link + self.copy(target) + self.remove() + + def fnmatch(self, pattern): + """Return true if the basename/fullname matches the glob-'pattern'. + + valid pattern characters:: + + * matches everything + ? matches any single character + [seq] matches any character in seq + [!seq] matches any char not in seq + + If the pattern contains a path-separator then the full path + is used for pattern matching and a '*' is prepended to the + pattern. + + if the pattern doesn't contain a path-separator the pattern + is only matched against the basename. + """ + return FNMatcher(pattern)(self) + + def relto(self, relpath): + """Return a string which is the relative part of the path + to the given 'relpath'. + """ + if not isinstance(relpath, (str, LocalPath)): + raise TypeError(f"{relpath!r}: not a string or path object") + strrelpath = str(relpath) + if strrelpath and strrelpath[-1] != self.sep: + strrelpath += self.sep + # assert strrelpath[-1] == self.sep + # assert strrelpath[-2] != self.sep + strself = self.strpath + if sys.platform == "win32" or getattr(os, "_name", None) == "nt": + if os.path.normcase(strself).startswith(os.path.normcase(strrelpath)): + return strself[len(strrelpath) :] + elif strself.startswith(strrelpath): + return strself[len(strrelpath) :] + return "" + + def ensure_dir(self, *args): + """Ensure the path joined with args is a directory.""" + return self.ensure(*args, dir=True) + + def bestrelpath(self, dest): + """Return a string which is a relative path from self + (assumed to be a directory) to dest such that + self.join(bestrelpath) == dest and if not such + path can be determined return dest. + """ + try: + if self == dest: + return os.curdir + base = self.common(dest) + if not base: # can be the case on windows + return str(dest) + self2base = self.relto(base) + reldest = dest.relto(base) + if self2base: + n = self2base.count(self.sep) + 1 + else: + n = 0 + lst = [os.pardir] * n + if reldest: + lst.append(reldest) + target = dest.sep.join(lst) + return target + except AttributeError: + return str(dest) + + def exists(self): + return self.check() + + def isdir(self): + return self.check(dir=1) + + def isfile(self): + return self.check(file=1) + + def parts(self, reverse=False): + """Return a root-first list of all ancestor directories + plus the path itself. + """ + current = self + lst = [self] + while 1: + last = current + current = current.dirpath() + if last == current: + break + lst.append(current) + if not reverse: + lst.reverse() + return lst + + def common(self, other): + """Return the common part shared with the other path + or None if there is no common part. + """ + last = None + for x, y in zip(self.parts(), other.parts()): + if x != y: + return last + last = x + return last + + def __add__(self, other): + """Return new path object with 'other' added to the basename""" + return self.new(basename=self.basename + str(other)) + + def visit(self, fil=None, rec=None, ignore=NeverRaised, bf=False, sort=False): + """Yields all paths below the current one + + fil is a filter (glob pattern or callable), if not matching the + path will not be yielded, defaulting to None (everything is + returned) + + rec is a filter (glob pattern or callable) that controls whether + a node is descended, defaulting to None + + ignore is an Exception class that is ignoredwhen calling dirlist() + on any of the paths (by default, all exceptions are reported) + + bf if True will cause a breadthfirst search instead of the + default depthfirst. Default: False + + sort if True will sort entries within each directory level. + """ + yield from Visitor(fil, rec, ignore, bf, sort).gen(self) + + def _sortlist(self, res, sort): + if sort: + if hasattr(sort, "__call__"): + warnings.warn( + DeprecationWarning( + "listdir(sort=callable) is deprecated and breaks on python3" + ), + stacklevel=3, + ) + res.sort(sort) + else: + res.sort() + + def __fspath__(self): + return self.strpath + + def __hash__(self): + s = self.strpath + if iswin32: + s = s.lower() + return hash(s) + + def __eq__(self, other): + s1 = os.fspath(self) + try: + s2 = os.fspath(other) + except TypeError: + return False + if iswin32: + s1 = s1.lower() + try: + s2 = s2.lower() + except AttributeError: + return False + return s1 == s2 + + def __ne__(self, other): + return not (self == other) + + def __lt__(self, other): + return os.fspath(self) < os.fspath(other) + + def __gt__(self, other): + return os.fspath(self) > os.fspath(other) + + def samefile(self, other): + """Return True if 'other' references the same file as 'self'.""" + other = os.fspath(other) + if not isabs(other): + other = abspath(other) + if self == other: + return True + if not hasattr(os.path, "samefile"): + return False + return error.checked_call(os.path.samefile, self.strpath, other) + + def remove(self, rec=1, ignore_errors=False): + """Remove a file or directory (or a directory tree if rec=1). + if ignore_errors is True, errors while removing directories will + be ignored. + """ + if self.check(dir=1, link=0): + if rec: + # force remove of readonly files on windows + if iswin32: + self.chmod(0o700, rec=1) + import shutil + + error.checked_call( + shutil.rmtree, self.strpath, ignore_errors=ignore_errors + ) + else: + error.checked_call(os.rmdir, self.strpath) + else: + if iswin32: + self.chmod(0o700) + error.checked_call(os.remove, self.strpath) + + def computehash(self, hashtype="md5", chunksize=524288): + """Return hexdigest of hashvalue for this file.""" + try: + try: + import hashlib as mod + except ImportError: + if hashtype == "sha1": + hashtype = "sha" + mod = __import__(hashtype) + hash = getattr(mod, hashtype)() + except (AttributeError, ImportError): + raise ValueError(f"Don't know how to compute {hashtype!r} hash") + f = self.open("rb") + try: + while 1: + buf = f.read(chunksize) + if not buf: + return hash.hexdigest() + hash.update(buf) + finally: + f.close() + + def new(self, **kw): + """Create a modified version of this path. + the following keyword arguments modify various path parts:: + + a:/some/path/to/a/file.ext + xx drive + xxxxxxxxxxxxxxxxx dirname + xxxxxxxx basename + xxxx purebasename + xxx ext + """ + obj = object.__new__(self.__class__) + if not kw: + obj.strpath = self.strpath + return obj + drive, dirname, basename, purebasename, ext = self._getbyspec( + "drive,dirname,basename,purebasename,ext" + ) + if "basename" in kw: + if "purebasename" in kw or "ext" in kw: + raise ValueError(f"invalid specification {kw!r}") + else: + pb = kw.setdefault("purebasename", purebasename) + try: + ext = kw["ext"] + except KeyError: + pass + else: + if ext and not ext.startswith("."): + ext = "." + ext + kw["basename"] = pb + ext + + if "dirname" in kw and not kw["dirname"]: + kw["dirname"] = drive + else: + kw.setdefault("dirname", dirname) + kw.setdefault("sep", self.sep) + obj.strpath = normpath("{dirname}{sep}{basename}".format(**kw)) + return obj + + def _getbyspec(self, spec: str) -> list[str]: + """See new for what 'spec' can be.""" + res = [] + parts = self.strpath.split(self.sep) + + args = filter(None, spec.split(",")) + for name in args: + if name == "drive": + res.append(parts[0]) + elif name == "dirname": + res.append(self.sep.join(parts[:-1])) + else: + basename = parts[-1] + if name == "basename": + res.append(basename) + else: + i = basename.rfind(".") + if i == -1: + purebasename, ext = basename, "" + else: + purebasename, ext = basename[:i], basename[i:] + if name == "purebasename": + res.append(purebasename) + elif name == "ext": + res.append(ext) + else: + raise ValueError(f"invalid part specification {name!r}") + return res + + def dirpath(self, *args, **kwargs): + """Return the directory path joined with any given path arguments.""" + if not kwargs: + path = object.__new__(self.__class__) + path.strpath = dirname(self.strpath) + if args: + path = path.join(*args) + return path + return self.new(basename="").join(*args, **kwargs) + + def join(self, *args: os.PathLike[str], abs: bool = False) -> LocalPath: + """Return a new path by appending all 'args' as path + components. if abs=1 is used restart from root if any + of the args is an absolute path. + """ + sep = self.sep + strargs = [os.fspath(arg) for arg in args] + strpath = self.strpath + if abs: + newargs: list[str] = [] + for arg in reversed(strargs): + if isabs(arg): + strpath = arg + strargs = newargs + break + newargs.insert(0, arg) + # special case for when we have e.g. strpath == "/" + actual_sep = "" if strpath.endswith(sep) else sep + for arg in strargs: + arg = arg.strip(sep) + if iswin32: + # allow unix style paths even on windows. + arg = arg.strip("/") + arg = arg.replace("/", sep) + strpath = strpath + actual_sep + arg + actual_sep = sep + obj = object.__new__(self.__class__) + obj.strpath = normpath(strpath) + return obj + + def open(self, mode="r", ensure=False, encoding=None): + """Return an opened file with the given mode. + + If ensure is True, create parent directories if needed. + """ + if ensure: + self.dirpath().ensure(dir=1) + if encoding: + return error.checked_call( + io.open, + self.strpath, + mode, + encoding=encoding, + ) + return error.checked_call(open, self.strpath, mode) + + def _fastjoin(self, name): + child = object.__new__(self.__class__) + child.strpath = self.strpath + self.sep + name + return child + + def islink(self): + return islink(self.strpath) + + def check(self, **kw): + """Check a path for existence and properties. + + Without arguments, return True if the path exists, otherwise False. + + valid checkers:: + + file = 1 # is a file + file = 0 # is not a file (may not even exist) + dir = 1 # is a dir + link = 1 # is a link + exists = 1 # exists + + You can specify multiple checker definitions, for example:: + + path.check(file=1, link=1) # a link pointing to a file + """ + if not kw: + return exists(self.strpath) + if len(kw) == 1: + if "dir" in kw: + return not kw["dir"] ^ isdir(self.strpath) + if "file" in kw: + return not kw["file"] ^ isfile(self.strpath) + if not kw: + kw = {"exists": 1} + return Checkers(self)._evaluate(kw) + + _patternchars = set("*?[" + os.sep) + + def listdir(self, fil=None, sort=None): + """List directory contents, possibly filter by the given fil func + and possibly sorted. + """ + if fil is None and sort is None: + names = error.checked_call(os.listdir, self.strpath) + return map_as_list(self._fastjoin, names) + if isinstance(fil, str): + if not self._patternchars.intersection(fil): + child = self._fastjoin(fil) + if exists(child.strpath): + return [child] + return [] + fil = FNMatcher(fil) + names = error.checked_call(os.listdir, self.strpath) + res = [] + for name in names: + child = self._fastjoin(name) + if fil is None or fil(child): + res.append(child) + self._sortlist(res, sort) + return res + + def size(self) -> int: + """Return size of the underlying file object""" + return self.stat().size + + def mtime(self) -> float: + """Return last modification time of the path.""" + return self.stat().mtime + + def copy(self, target, mode=False, stat=False): + """Copy path to target. + + If mode is True, will copy permission from path to target. + If stat is True, copy permission, last modification + time, last access time, and flags from path to target. + """ + if self.check(file=1): + if target.check(dir=1): + target = target.join(self.basename) + assert self != target + copychunked(self, target) + if mode: + copymode(self.strpath, target.strpath) + if stat: + copystat(self, target) + else: + + def rec(p): + return p.check(link=0) + + for x in self.visit(rec=rec): + relpath = x.relto(self) + newx = target.join(relpath) + newx.dirpath().ensure(dir=1) + if x.check(link=1): + newx.mksymlinkto(x.readlink()) + continue + elif x.check(file=1): + copychunked(x, newx) + elif x.check(dir=1): + newx.ensure(dir=1) + if mode: + copymode(x.strpath, newx.strpath) + if stat: + copystat(x, newx) + + def rename(self, target): + """Rename this path to target.""" + target = os.fspath(target) + return error.checked_call(os.rename, self.strpath, target) + + def dump(self, obj, bin=1): + """Pickle object into path location""" + f = self.open("wb") + import pickle + + try: + error.checked_call(pickle.dump, obj, f, bin) + finally: + f.close() + + def mkdir(self, *args): + """Create & return the directory joined with args.""" + p = self.join(*args) + error.checked_call(os.mkdir, os.fspath(p)) + return p + + def write_binary(self, data, ensure=False): + """Write binary data into path. If ensure is True create + missing parent directories. + """ + if ensure: + self.dirpath().ensure(dir=1) + with self.open("wb") as f: + f.write(data) + + def write_text(self, data, encoding, ensure=False): + """Write text data into path using the specified encoding. + If ensure is True create missing parent directories. + """ + if ensure: + self.dirpath().ensure(dir=1) + with self.open("w", encoding=encoding) as f: + f.write(data) + + def write(self, data, mode="w", ensure=False): + """Write data into path. If ensure is True create + missing parent directories. + """ + if ensure: + self.dirpath().ensure(dir=1) + if "b" in mode: + if not isinstance(data, bytes): + raise ValueError("can only process bytes") + else: + if not isinstance(data, str): + if not isinstance(data, bytes): + data = str(data) + else: + data = data.decode(sys.getdefaultencoding()) + f = self.open(mode) + try: + f.write(data) + finally: + f.close() + + def _ensuredirs(self): + parent = self.dirpath() + if parent == self: + return self + if parent.check(dir=0): + parent._ensuredirs() + if self.check(dir=0): + try: + self.mkdir() + except error.EEXIST: + # race condition: file/dir created by another thread/process. + # complain if it is not a dir + if self.check(dir=0): + raise + return self + + def ensure(self, *args, **kwargs): + """Ensure that an args-joined path exists (by default as + a file). if you specify a keyword argument 'dir=True' + then the path is forced to be a directory path. + """ + p = self.join(*args) + if kwargs.get("dir", 0): + return p._ensuredirs() + else: + p.dirpath()._ensuredirs() + if not p.check(file=1): + p.open("wb").close() + return p + + @overload + def stat(self, raising: Literal[True] = ...) -> Stat: ... + + @overload + def stat(self, raising: Literal[False]) -> Stat | None: ... + + def stat(self, raising: bool = True) -> Stat | None: + """Return an os.stat() tuple.""" + if raising: + return Stat(self, error.checked_call(os.stat, self.strpath)) + try: + return Stat(self, os.stat(self.strpath)) + except KeyboardInterrupt: + raise + except Exception: + return None + + def lstat(self) -> Stat: + """Return an os.lstat() tuple.""" + return Stat(self, error.checked_call(os.lstat, self.strpath)) + + def setmtime(self, mtime=None): + """Set modification time for the given path. if 'mtime' is None + (the default) then the file's mtime is set to current time. + + Note that the resolution for 'mtime' is platform dependent. + """ + if mtime is None: + return error.checked_call(os.utime, self.strpath, mtime) + try: + return error.checked_call(os.utime, self.strpath, (-1, mtime)) + except error.EINVAL: + return error.checked_call(os.utime, self.strpath, (self.atime(), mtime)) + + def chdir(self): + """Change directory to self and return old current directory""" + try: + old = self.__class__() + except error.ENOENT: + old = None + error.checked_call(os.chdir, self.strpath) + return old + + @contextmanager + def as_cwd(self): + """ + Return a context manager, which changes to the path's dir during the + managed "with" context. + On __enter__ it returns the old dir, which might be ``None``. + """ + old = self.chdir() + try: + yield old + finally: + if old is not None: + old.chdir() + + def realpath(self): + """Return a new path which contains no symbolic links.""" + return self.__class__(os.path.realpath(self.strpath)) + + def atime(self): + """Return last access time of the path.""" + return self.stat().atime + + def __repr__(self): + return f"local({self.strpath!r})" + + def __str__(self): + """Return string representation of the Path.""" + return self.strpath + + def chmod(self, mode, rec=0): + """Change permissions to the given mode. If mode is an + integer it directly encodes the os-specific modes. + if rec is True perform recursively. + """ + if not isinstance(mode, int): + raise TypeError(f"mode {mode!r} must be an integer") + if rec: + for x in self.visit(rec=rec): + error.checked_call(os.chmod, str(x), mode) + error.checked_call(os.chmod, self.strpath, mode) + + def pypkgpath(self): + """Return the Python package path by looking for the last + directory upwards which still contains an __init__.py. + Return None if a pkgpath cannot be determined. + """ + pkgpath = None + for parent in self.parts(reverse=True): + if parent.isdir(): + if not parent.join("__init__.py").exists(): + break + if not isimportable(parent.basename): + break + pkgpath = parent + return pkgpath + + def _ensuresyspath(self, ensuremode, path): + if ensuremode: + s = str(path) + if ensuremode == "append": + if s not in sys.path: + sys.path.append(s) + else: + if s != sys.path[0]: + sys.path.insert(0, s) + + def pyimport(self, modname=None, ensuresyspath=True): + """Return path as an imported python module. + + If modname is None, look for the containing package + and construct an according module name. + The module will be put/looked up in sys.modules. + if ensuresyspath is True then the root dir for importing + the file (taking __init__.py files into account) will + be prepended to sys.path if it isn't there already. + If ensuresyspath=="append" the root dir will be appended + if it isn't already contained in sys.path. + if ensuresyspath is False no modification of syspath happens. + + Special value of ensuresyspath=="importlib" is intended + purely for using in pytest, it is capable only of importing + separate .py files outside packages, e.g. for test suite + without any __init__.py file. It effectively allows having + same-named test modules in different places and offers + mild opt-in via this option. Note that it works only in + recent versions of python. + """ + if not self.check(): + raise error.ENOENT(self) + + if ensuresyspath == "importlib": + if modname is None: + modname = self.purebasename + spec = importlib.util.spec_from_file_location(modname, str(self)) + if spec is None or spec.loader is None: + raise ImportError(f"Can't find module {modname} at location {self!s}") + mod = importlib.util.module_from_spec(spec) + spec.loader.exec_module(mod) + return mod + + pkgpath = None + if modname is None: + pkgpath = self.pypkgpath() + if pkgpath is not None: + pkgroot = pkgpath.dirpath() + names = self.new(ext="").relto(pkgroot).split(self.sep) + if names[-1] == "__init__": + names.pop() + modname = ".".join(names) + else: + pkgroot = self.dirpath() + modname = self.purebasename + + self._ensuresyspath(ensuresyspath, pkgroot) + __import__(modname) + mod = sys.modules[modname] + if self.basename == "__init__.py": + return mod # we don't check anything as we might + # be in a namespace package ... too icky to check + modfile = mod.__file__ + assert modfile is not None + if modfile[-4:] in (".pyc", ".pyo"): + modfile = modfile[:-1] + elif modfile.endswith("$py.class"): + modfile = modfile[:-9] + ".py" + if modfile.endswith(os.sep + "__init__.py"): + if self.basename != "__init__.py": + modfile = modfile[:-12] + try: + issame = self.samefile(modfile) + except error.ENOENT: + issame = False + if not issame: + ignore = os.getenv("PY_IGNORE_IMPORTMISMATCH") + if ignore != "1": + raise self.ImportMismatchError(modname, modfile, self) + return mod + else: + try: + return sys.modules[modname] + except KeyError: + # we have a custom modname, do a pseudo-import + import types + + mod = types.ModuleType(modname) + mod.__file__ = str(self) + sys.modules[modname] = mod + try: + with open(str(self), "rb") as f: + exec(f.read(), mod.__dict__) + except BaseException: + del sys.modules[modname] + raise + return mod + + def sysexec(self, *argv: os.PathLike[str], **popen_opts: Any) -> str: + """Return stdout text from executing a system child process, + where the 'self' path points to executable. + The process is directly invoked and not through a system shell. + """ + from subprocess import PIPE + from subprocess import Popen + + popen_opts.pop("stdout", None) + popen_opts.pop("stderr", None) + proc = Popen( + [str(self)] + [str(arg) for arg in argv], + **popen_opts, + stdout=PIPE, + stderr=PIPE, + ) + stdout: str | bytes + stdout, stderr = proc.communicate() + ret = proc.wait() + if isinstance(stdout, bytes): + stdout = stdout.decode(sys.getdefaultencoding()) + if ret != 0: + if isinstance(stderr, bytes): + stderr = stderr.decode(sys.getdefaultencoding()) + raise RuntimeError( + ret, + ret, + str(self), + stdout, + stderr, + ) + return stdout + + @classmethod + def sysfind(cls, name, checker=None, paths=None): + """Return a path object found by looking at the systems + underlying PATH specification. If the checker is not None + it will be invoked to filter matching paths. If a binary + cannot be found, None is returned + Note: This is probably not working on plain win32 systems + but may work on cygwin. + """ + if isabs(name): + p = local(name) + if p.check(file=1): + return p + else: + if paths is None: + if iswin32: + paths = os.environ["Path"].split(";") + if "" not in paths and "." not in paths: + paths.append(".") + try: + systemroot = os.environ["SYSTEMROOT"] + except KeyError: + pass + else: + paths = [ + path.replace("%SystemRoot%", systemroot) for path in paths + ] + else: + paths = os.environ["PATH"].split(":") + tryadd = [] + if iswin32: + tryadd += os.environ["PATHEXT"].split(os.pathsep) + tryadd.append("") + + for x in paths: + for addext in tryadd: + p = local(x).join(name, abs=True) + addext + try: + if p.check(file=1): + if checker: + if not checker(p): + continue + return p + except error.EACCES: + pass + return None + + @classmethod + def _gethomedir(cls): + try: + x = os.environ["HOME"] + except KeyError: + try: + x = os.environ["HOMEDRIVE"] + os.environ["HOMEPATH"] + except KeyError: + return None + return cls(x) + + # """ + # special class constructors for local filesystem paths + # """ + @classmethod + def get_temproot(cls): + """Return the system's temporary directory + (where tempfiles are usually created in) + """ + import tempfile + + return local(tempfile.gettempdir()) + + @classmethod + def mkdtemp(cls, rootdir=None): + """Return a Path object pointing to a fresh new temporary directory + (which we created ourselves). + """ + import tempfile + + if rootdir is None: + rootdir = cls.get_temproot() + path = error.checked_call(tempfile.mkdtemp, dir=str(rootdir)) + return cls(path) + + @classmethod + def make_numbered_dir( + cls, prefix="session-", rootdir=None, keep=3, lock_timeout=172800 + ): # two days + """Return unique directory with a number greater than the current + maximum one. The number is assumed to start directly after prefix. + if keep is true directories with a number less than (maxnum-keep) + will be removed. If .lock files are used (lock_timeout non-zero), + algorithm is multi-process safe. + """ + if rootdir is None: + rootdir = cls.get_temproot() + + nprefix = prefix.lower() + + def parse_num(path): + """Parse the number out of a path (if it matches the prefix)""" + nbasename = path.basename.lower() + if nbasename.startswith(nprefix): + try: + return int(nbasename[len(nprefix) :]) + except ValueError: + pass + + def create_lockfile(path): + """Exclusively create lockfile. Throws when failed""" + mypid = os.getpid() + lockfile = path.join(".lock") + if hasattr(lockfile, "mksymlinkto"): + lockfile.mksymlinkto(str(mypid)) + else: + fd = error.checked_call( + os.open, str(lockfile), os.O_WRONLY | os.O_CREAT | os.O_EXCL, 0o644 + ) + with os.fdopen(fd, "w") as f: + f.write(str(mypid)) + return lockfile + + def atexit_remove_lockfile(lockfile): + """Ensure lockfile is removed at process exit""" + mypid = os.getpid() + + def try_remove_lockfile(): + # in a fork() situation, only the last process should + # remove the .lock, otherwise the other processes run the + # risk of seeing their temporary dir disappear. For now + # we remove the .lock in the parent only (i.e. we assume + # that the children finish before the parent). + if os.getpid() != mypid: + return + try: + lockfile.remove() + except error.Error: + pass + + atexit.register(try_remove_lockfile) + + # compute the maximum number currently in use with the prefix + lastmax = None + while True: + maxnum = -1 + for path in rootdir.listdir(): + num = parse_num(path) + if num is not None: + maxnum = max(maxnum, num) + + # make the new directory + try: + udir = rootdir.mkdir(prefix + str(maxnum + 1)) + if lock_timeout: + lockfile = create_lockfile(udir) + atexit_remove_lockfile(lockfile) + except (error.EEXIST, error.ENOENT, error.EBUSY): + # race condition (1): another thread/process created the dir + # in the meantime - try again + # race condition (2): another thread/process spuriously acquired + # lock treating empty directory as candidate + # for removal - try again + # race condition (3): another thread/process tried to create the lock at + # the same time (happened in Python 3.3 on Windows) + # https://ci.appveyor.com/project/pytestbot/py/build/1.0.21/job/ffi85j4c0lqwsfwa + if lastmax == maxnum: + raise + lastmax = maxnum + continue + break + + def get_mtime(path): + """Read file modification time""" + try: + return path.lstat().mtime + except error.Error: + pass + + garbage_prefix = prefix + "garbage-" + + def is_garbage(path): + """Check if path denotes directory scheduled for removal""" + bn = path.basename + return bn.startswith(garbage_prefix) + + # prune old directories + udir_time = get_mtime(udir) + if keep and udir_time: + for path in rootdir.listdir(): + num = parse_num(path) + if num is not None and num <= (maxnum - keep): + try: + # try acquiring lock to remove directory as exclusive user + if lock_timeout: + create_lockfile(path) + except (error.EEXIST, error.ENOENT, error.EBUSY): + path_time = get_mtime(path) + if not path_time: + # assume directory doesn't exist now + continue + if abs(udir_time - path_time) < lock_timeout: + # assume directory with lockfile exists + # and lock timeout hasn't expired yet + continue + + # path dir locked for exclusive use + # and scheduled for removal to avoid another thread/process + # treating it as a new directory or removal candidate + garbage_path = rootdir.join(garbage_prefix + str(uuid.uuid4())) + try: + path.rename(garbage_path) + garbage_path.remove(rec=1) + except KeyboardInterrupt: + raise + except Exception: # this might be error.Error, WindowsError ... + pass + if is_garbage(path): + try: + path.remove(rec=1) + except KeyboardInterrupt: + raise + except Exception: # this might be error.Error, WindowsError ... + pass + + # make link... + try: + username = os.environ["USER"] # linux, et al + except KeyError: + try: + username = os.environ["USERNAME"] # windows + except KeyError: + username = "current" + + src = str(udir) + dest = src[: src.rfind("-")] + "-" + username + try: + os.unlink(dest) + except OSError: + pass + try: + os.symlink(src, dest) + except (OSError, AttributeError, NotImplementedError): + pass + + return udir + + +def copymode(src, dest): + """Copy permission from src to dst.""" + import shutil + + shutil.copymode(src, dest) + + +def copystat(src, dest): + """Copy permission, last modification time, + last access time, and flags from src to dst.""" + import shutil + + shutil.copystat(str(src), str(dest)) + + +def copychunked(src, dest): + chunksize = 524288 # half a meg of bytes + fsrc = src.open("rb") + try: + fdest = dest.open("wb") + try: + while 1: + buf = fsrc.read(chunksize) + if not buf: + break + fdest.write(buf) + finally: + fdest.close() + finally: + fsrc.close() + + +def isimportable(name): + if name and (name[0].isalpha() or name[0] == "_"): + name = name.replace("_", "") + return not name or name.isalnum() + + +local = LocalPath diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/_version.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_version.py new file mode 100644 index 0000000..cf258c1 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/_version.py @@ -0,0 +1,16 @@ +# file generated by setuptools_scm +# don't change, don't track in version control +TYPE_CHECKING = False +if TYPE_CHECKING: + from typing import Tuple, Union + VERSION_TUPLE = Tuple[Union[int, str], ...] +else: + VERSION_TUPLE = object + +version: str +__version__: str +__version_tuple__: VERSION_TUPLE +version_tuple: VERSION_TUPLE + +__version__ = version = '8.3.3' +__version_tuple__ = version_tuple = (8, 3, 3) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/__init__.py new file mode 100644 index 0000000..f2f1d02 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/__init__.py @@ -0,0 +1,192 @@ +# mypy: allow-untyped-defs +"""Support for presenting detailed information in failing assertions.""" + +from __future__ import annotations + +import sys +from typing import Any +from typing import Generator +from typing import TYPE_CHECKING + +from _pytest.assertion import rewrite +from _pytest.assertion import truncate +from _pytest.assertion import util +from _pytest.assertion.rewrite import assertstate_key +from _pytest.config import Config +from _pytest.config import hookimpl +from _pytest.config.argparsing import Parser +from _pytest.nodes import Item + + +if TYPE_CHECKING: + from _pytest.main import Session + + +def pytest_addoption(parser: Parser) -> None: + group = parser.getgroup("debugconfig") + group.addoption( + "--assert", + action="store", + dest="assertmode", + choices=("rewrite", "plain"), + default="rewrite", + metavar="MODE", + help=( + "Control assertion debugging tools.\n" + "'plain' performs no assertion debugging.\n" + "'rewrite' (the default) rewrites assert statements in test modules" + " on import to provide assert expression information." + ), + ) + parser.addini( + "enable_assertion_pass_hook", + type="bool", + default=False, + help="Enables the pytest_assertion_pass hook. " + "Make sure to delete any previously generated pyc cache files.", + ) + Config._add_verbosity_ini( + parser, + Config.VERBOSITY_ASSERTIONS, + help=( + "Specify a verbosity level for assertions, overriding the main level. " + "Higher levels will provide more detailed explanation when an assertion fails." + ), + ) + + +def register_assert_rewrite(*names: str) -> None: + """Register one or more module names to be rewritten on import. + + This function will make sure that this module or all modules inside + the package will get their assert statements rewritten. + Thus you should make sure to call this before the module is + actually imported, usually in your __init__.py if you are a plugin + using a package. + + :param names: The module names to register. + """ + for name in names: + if not isinstance(name, str): + msg = "expected module names as *args, got {0} instead" # type: ignore[unreachable] + raise TypeError(msg.format(repr(names))) + for hook in sys.meta_path: + if isinstance(hook, rewrite.AssertionRewritingHook): + importhook = hook + break + else: + # TODO(typing): Add a protocol for mark_rewrite() and use it + # for importhook and for PytestPluginManager.rewrite_hook. + importhook = DummyRewriteHook() # type: ignore + importhook.mark_rewrite(*names) + + +class DummyRewriteHook: + """A no-op import hook for when rewriting is disabled.""" + + def mark_rewrite(self, *names: str) -> None: + pass + + +class AssertionState: + """State for the assertion plugin.""" + + def __init__(self, config: Config, mode) -> None: + self.mode = mode + self.trace = config.trace.root.get("assertion") + self.hook: rewrite.AssertionRewritingHook | None = None + + +def install_importhook(config: Config) -> rewrite.AssertionRewritingHook: + """Try to install the rewrite hook, raise SystemError if it fails.""" + config.stash[assertstate_key] = AssertionState(config, "rewrite") + config.stash[assertstate_key].hook = hook = rewrite.AssertionRewritingHook(config) + sys.meta_path.insert(0, hook) + config.stash[assertstate_key].trace("installed rewrite import hook") + + def undo() -> None: + hook = config.stash[assertstate_key].hook + if hook is not None and hook in sys.meta_path: + sys.meta_path.remove(hook) + + config.add_cleanup(undo) + return hook + + +def pytest_collection(session: Session) -> None: + # This hook is only called when test modules are collected + # so for example not in the managing process of pytest-xdist + # (which does not collect test modules). + assertstate = session.config.stash.get(assertstate_key, None) + if assertstate: + if assertstate.hook is not None: + assertstate.hook.set_session(session) + + +@hookimpl(wrapper=True, tryfirst=True) +def pytest_runtest_protocol(item: Item) -> Generator[None, object, object]: + """Setup the pytest_assertrepr_compare and pytest_assertion_pass hooks. + + The rewrite module will use util._reprcompare if it exists to use custom + reporting via the pytest_assertrepr_compare hook. This sets up this custom + comparison for the test. + """ + ihook = item.ihook + + def callbinrepr(op, left: object, right: object) -> str | None: + """Call the pytest_assertrepr_compare hook and prepare the result. + + This uses the first result from the hook and then ensures the + following: + * Overly verbose explanations are truncated unless configured otherwise + (eg. if running in verbose mode). + * Embedded newlines are escaped to help util.format_explanation() + later. + * If the rewrite mode is used embedded %-characters are replaced + to protect later % formatting. + + The result can be formatted by util.format_explanation() for + pretty printing. + """ + hook_result = ihook.pytest_assertrepr_compare( + config=item.config, op=op, left=left, right=right + ) + for new_expl in hook_result: + if new_expl: + new_expl = truncate.truncate_if_required(new_expl, item) + new_expl = [line.replace("\n", "\\n") for line in new_expl] + res = "\n~".join(new_expl) + if item.config.getvalue("assertmode") == "rewrite": + res = res.replace("%", "%%") + return res + return None + + saved_assert_hooks = util._reprcompare, util._assertion_pass + util._reprcompare = callbinrepr + util._config = item.config + + if ihook.pytest_assertion_pass.get_hookimpls(): + + def call_assertion_pass_hook(lineno: int, orig: str, expl: str) -> None: + ihook.pytest_assertion_pass(item=item, lineno=lineno, orig=orig, expl=expl) + + util._assertion_pass = call_assertion_pass_hook + + try: + return (yield) + finally: + util._reprcompare, util._assertion_pass = saved_assert_hooks + util._config = None + + +def pytest_sessionfinish(session: Session) -> None: + assertstate = session.config.stash.get(assertstate_key, None) + if assertstate: + if assertstate.hook is not None: + assertstate.hook.set_session(None) + + +def pytest_assertrepr_compare( + config: Config, op: str, left: Any, right: Any +) -> list[str] | None: + return util.assertrepr_compare(config=config, op=op, left=left, right=right) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/rewrite.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/rewrite.py new file mode 100644 index 0000000..a7a92c0 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/rewrite.py @@ -0,0 +1,1204 @@ +"""Rewrite assertion AST to produce nice error messages.""" + +from __future__ import annotations + +import ast +from collections import defaultdict +import errno +import functools +import importlib.abc +import importlib.machinery +import importlib.util +import io +import itertools +import marshal +import os +from pathlib import Path +from pathlib import PurePath +import struct +import sys +import tokenize +import types +from typing import Callable +from typing import IO +from typing import Iterable +from typing import Iterator +from typing import Sequence +from typing import TYPE_CHECKING + +from _pytest._io.saferepr import DEFAULT_REPR_MAX_SIZE +from _pytest._io.saferepr import saferepr +from _pytest._version import version +from _pytest.assertion import util +from _pytest.config import Config +from _pytest.main import Session +from _pytest.pathlib import absolutepath +from _pytest.pathlib import fnmatch_ex +from _pytest.stash import StashKey + + +# fmt: off +from _pytest.assertion.util import format_explanation as _format_explanation # noqa:F401, isort:skip +# fmt:on + +if TYPE_CHECKING: + from _pytest.assertion import AssertionState + + +class Sentinel: + pass + + +assertstate_key = StashKey["AssertionState"]() + +# pytest caches rewritten pycs in pycache dirs +PYTEST_TAG = f"{sys.implementation.cache_tag}-pytest-{version}" +PYC_EXT = ".py" + (__debug__ and "c" or "o") +PYC_TAIL = "." + PYTEST_TAG + PYC_EXT + +# Special marker that denotes we have just left a scope definition +_SCOPE_END_MARKER = Sentinel() + + +class AssertionRewritingHook(importlib.abc.MetaPathFinder, importlib.abc.Loader): + """PEP302/PEP451 import hook which rewrites asserts.""" + + def __init__(self, config: Config) -> None: + self.config = config + try: + self.fnpats = config.getini("python_files") + except ValueError: + self.fnpats = ["test_*.py", "*_test.py"] + self.session: Session | None = None + self._rewritten_names: dict[str, Path] = {} + self._must_rewrite: set[str] = set() + # flag to guard against trying to rewrite a pyc file while we are already writing another pyc file, + # which might result in infinite recursion (#3506) + self._writing_pyc = False + self._basenames_to_check_rewrite = {"conftest"} + self._marked_for_rewrite_cache: dict[str, bool] = {} + self._session_paths_checked = False + + def set_session(self, session: Session | None) -> None: + self.session = session + self._session_paths_checked = False + + # Indirection so we can mock calls to find_spec originated from the hook during testing + _find_spec = importlib.machinery.PathFinder.find_spec + + def find_spec( + self, + name: str, + path: Sequence[str | bytes] | None = None, + target: types.ModuleType | None = None, + ) -> importlib.machinery.ModuleSpec | None: + if self._writing_pyc: + return None + state = self.config.stash[assertstate_key] + if self._early_rewrite_bailout(name, state): + return None + state.trace(f"find_module called for: {name}") + + # Type ignored because mypy is confused about the `self` binding here. + spec = self._find_spec(name, path) # type: ignore + + if spec is None and path is not None: + # With --import-mode=importlib, PathFinder cannot find spec without modifying `sys.path`, + # causing inability to assert rewriting (#12659). + # At this point, try using the file path to find the module spec. + for _path_str in path: + spec = importlib.util.spec_from_file_location(name, _path_str) + if spec is not None: + break + + if ( + # the import machinery could not find a file to import + spec is None + # this is a namespace package (without `__init__.py`) + # there's nothing to rewrite there + or spec.origin is None + # we can only rewrite source files + or not isinstance(spec.loader, importlib.machinery.SourceFileLoader) + # if the file doesn't exist, we can't rewrite it + or not os.path.exists(spec.origin) + ): + return None + else: + fn = spec.origin + + if not self._should_rewrite(name, fn, state): + return None + + return importlib.util.spec_from_file_location( + name, + fn, + loader=self, + submodule_search_locations=spec.submodule_search_locations, + ) + + def create_module( + self, spec: importlib.machinery.ModuleSpec + ) -> types.ModuleType | None: + return None # default behaviour is fine + + def exec_module(self, module: types.ModuleType) -> None: + assert module.__spec__ is not None + assert module.__spec__.origin is not None + fn = Path(module.__spec__.origin) + state = self.config.stash[assertstate_key] + + self._rewritten_names[module.__name__] = fn + + # The requested module looks like a test file, so rewrite it. This is + # the most magical part of the process: load the source, rewrite the + # asserts, and load the rewritten source. We also cache the rewritten + # module code in a special pyc. We must be aware of the possibility of + # concurrent pytest processes rewriting and loading pycs. To avoid + # tricky race conditions, we maintain the following invariant: The + # cached pyc is always a complete, valid pyc. Operations on it must be + # atomic. POSIX's atomic rename comes in handy. + write = not sys.dont_write_bytecode + cache_dir = get_cache_dir(fn) + if write: + ok = try_makedirs(cache_dir) + if not ok: + write = False + state.trace(f"read only directory: {cache_dir}") + + cache_name = fn.name[:-3] + PYC_TAIL + pyc = cache_dir / cache_name + # Notice that even if we're in a read-only directory, I'm going + # to check for a cached pyc. This may not be optimal... + co = _read_pyc(fn, pyc, state.trace) + if co is None: + state.trace(f"rewriting {fn!r}") + source_stat, co = _rewrite_test(fn, self.config) + if write: + self._writing_pyc = True + try: + _write_pyc(state, co, source_stat, pyc) + finally: + self._writing_pyc = False + else: + state.trace(f"found cached rewritten pyc for {fn}") + exec(co, module.__dict__) + + def _early_rewrite_bailout(self, name: str, state: AssertionState) -> bool: + """A fast way to get out of rewriting modules. + + Profiling has shown that the call to PathFinder.find_spec (inside of + the find_spec from this class) is a major slowdown, so, this method + tries to filter what we're sure won't be rewritten before getting to + it. + """ + if self.session is not None and not self._session_paths_checked: + self._session_paths_checked = True + for initial_path in self.session._initialpaths: + # Make something as c:/projects/my_project/path.py -> + # ['c:', 'projects', 'my_project', 'path.py'] + parts = str(initial_path).split(os.sep) + # add 'path' to basenames to be checked. + self._basenames_to_check_rewrite.add(os.path.splitext(parts[-1])[0]) + + # Note: conftest already by default in _basenames_to_check_rewrite. + parts = name.split(".") + if parts[-1] in self._basenames_to_check_rewrite: + return False + + # For matching the name it must be as if it was a filename. + path = PurePath(*parts).with_suffix(".py") + + for pat in self.fnpats: + # if the pattern contains subdirectories ("tests/**.py" for example) we can't bail out based + # on the name alone because we need to match against the full path + if os.path.dirname(pat): + return False + if fnmatch_ex(pat, path): + return False + + if self._is_marked_for_rewrite(name, state): + return False + + state.trace(f"early skip of rewriting module: {name}") + return True + + def _should_rewrite(self, name: str, fn: str, state: AssertionState) -> bool: + # always rewrite conftest files + if os.path.basename(fn) == "conftest.py": + state.trace(f"rewriting conftest file: {fn!r}") + return True + + if self.session is not None: + if self.session.isinitpath(absolutepath(fn)): + state.trace(f"matched test file (was specified on cmdline): {fn!r}") + return True + + # modules not passed explicitly on the command line are only + # rewritten if they match the naming convention for test files + fn_path = PurePath(fn) + for pat in self.fnpats: + if fnmatch_ex(pat, fn_path): + state.trace(f"matched test file {fn!r}") + return True + + return self._is_marked_for_rewrite(name, state) + + def _is_marked_for_rewrite(self, name: str, state: AssertionState) -> bool: + try: + return self._marked_for_rewrite_cache[name] + except KeyError: + for marked in self._must_rewrite: + if name == marked or name.startswith(marked + "."): + state.trace(f"matched marked file {name!r} (from {marked!r})") + self._marked_for_rewrite_cache[name] = True + return True + + self._marked_for_rewrite_cache[name] = False + return False + + def mark_rewrite(self, *names: str) -> None: + """Mark import names as needing to be rewritten. + + The named module or package as well as any nested modules will + be rewritten on import. + """ + already_imported = ( + set(names).intersection(sys.modules).difference(self._rewritten_names) + ) + for name in already_imported: + mod = sys.modules[name] + if not AssertionRewriter.is_rewrite_disabled( + mod.__doc__ or "" + ) and not isinstance(mod.__loader__, type(self)): + self._warn_already_imported(name) + self._must_rewrite.update(names) + self._marked_for_rewrite_cache.clear() + + def _warn_already_imported(self, name: str) -> None: + from _pytest.warning_types import PytestAssertRewriteWarning + + self.config.issue_config_time_warning( + PytestAssertRewriteWarning( + f"Module already imported so cannot be rewritten: {name}" + ), + stacklevel=5, + ) + + def get_data(self, pathname: str | bytes) -> bytes: + """Optional PEP302 get_data API.""" + with open(pathname, "rb") as f: + return f.read() + + if sys.version_info >= (3, 10): + if sys.version_info >= (3, 12): + from importlib.resources.abc import TraversableResources + else: + from importlib.abc import TraversableResources + + def get_resource_reader(self, name: str) -> TraversableResources: + if sys.version_info < (3, 11): + from importlib.readers import FileReader + else: + from importlib.resources.readers import FileReader + + return FileReader(types.SimpleNamespace(path=self._rewritten_names[name])) + + +def _write_pyc_fp( + fp: IO[bytes], source_stat: os.stat_result, co: types.CodeType +) -> None: + # Technically, we don't have to have the same pyc format as + # (C)Python, since these "pycs" should never be seen by builtin + # import. However, there's little reason to deviate. + fp.write(importlib.util.MAGIC_NUMBER) + # https://www.python.org/dev/peps/pep-0552/ + flags = b"\x00\x00\x00\x00" + fp.write(flags) + # as of now, bytecode header expects 32-bit numbers for size and mtime (#4903) + mtime = int(source_stat.st_mtime) & 0xFFFFFFFF + size = source_stat.st_size & 0xFFFFFFFF + # " bool: + proc_pyc = f"{pyc}.{os.getpid()}" + try: + with open(proc_pyc, "wb") as fp: + _write_pyc_fp(fp, source_stat, co) + except OSError as e: + state.trace(f"error writing pyc file at {proc_pyc}: errno={e.errno}") + return False + + try: + os.replace(proc_pyc, pyc) + except OSError as e: + state.trace(f"error writing pyc file at {pyc}: {e}") + # we ignore any failure to write the cache file + # there are many reasons, permission-denied, pycache dir being a + # file etc. + return False + return True + + +def _rewrite_test(fn: Path, config: Config) -> tuple[os.stat_result, types.CodeType]: + """Read and rewrite *fn* and return the code object.""" + stat = os.stat(fn) + source = fn.read_bytes() + strfn = str(fn) + tree = ast.parse(source, filename=strfn) + rewrite_asserts(tree, source, strfn, config) + co = compile(tree, strfn, "exec", dont_inherit=True) + return stat, co + + +def _read_pyc( + source: Path, pyc: Path, trace: Callable[[str], None] = lambda x: None +) -> types.CodeType | None: + """Possibly read a pytest pyc containing rewritten code. + + Return rewritten code if successful or None if not. + """ + try: + fp = open(pyc, "rb") + except OSError: + return None + with fp: + try: + stat_result = os.stat(source) + mtime = int(stat_result.st_mtime) + size = stat_result.st_size + data = fp.read(16) + except OSError as e: + trace(f"_read_pyc({source}): OSError {e}") + return None + # Check for invalid or out of date pyc file. + if len(data) != (16): + trace(f"_read_pyc({source}): invalid pyc (too short)") + return None + if data[:4] != importlib.util.MAGIC_NUMBER: + trace(f"_read_pyc({source}): invalid pyc (bad magic number)") + return None + if data[4:8] != b"\x00\x00\x00\x00": + trace(f"_read_pyc({source}): invalid pyc (unsupported flags)") + return None + mtime_data = data[8:12] + if int.from_bytes(mtime_data, "little") != mtime & 0xFFFFFFFF: + trace(f"_read_pyc({source}): out of date") + return None + size_data = data[12:16] + if int.from_bytes(size_data, "little") != size & 0xFFFFFFFF: + trace(f"_read_pyc({source}): invalid pyc (incorrect size)") + return None + try: + co = marshal.load(fp) + except Exception as e: + trace(f"_read_pyc({source}): marshal.load error {e}") + return None + if not isinstance(co, types.CodeType): + trace(f"_read_pyc({source}): not a code object") + return None + return co + + +def rewrite_asserts( + mod: ast.Module, + source: bytes, + module_path: str | None = None, + config: Config | None = None, +) -> None: + """Rewrite the assert statements in mod.""" + AssertionRewriter(module_path, config, source).run(mod) + + +def _saferepr(obj: object) -> str: + r"""Get a safe repr of an object for assertion error messages. + + The assertion formatting (util.format_explanation()) requires + newlines to be escaped since they are a special character for it. + Normally assertion.util.format_explanation() does this but for a + custom repr it is possible to contain one of the special escape + sequences, especially '\n{' and '\n}' are likely to be present in + JSON reprs. + """ + if isinstance(obj, types.MethodType): + # for bound methods, skip redundant information + return obj.__name__ + + maxsize = _get_maxsize_for_saferepr(util._config) + return saferepr(obj, maxsize=maxsize).replace("\n", "\\n") + + +def _get_maxsize_for_saferepr(config: Config | None) -> int | None: + """Get `maxsize` configuration for saferepr based on the given config object.""" + if config is None: + verbosity = 0 + else: + verbosity = config.get_verbosity(Config.VERBOSITY_ASSERTIONS) + if verbosity >= 2: + return None + if verbosity >= 1: + return DEFAULT_REPR_MAX_SIZE * 10 + return DEFAULT_REPR_MAX_SIZE + + +def _format_assertmsg(obj: object) -> str: + r"""Format the custom assertion message given. + + For strings this simply replaces newlines with '\n~' so that + util.format_explanation() will preserve them instead of escaping + newlines. For other objects saferepr() is used first. + """ + # reprlib appears to have a bug which means that if a string + # contains a newline it gets escaped, however if an object has a + # .__repr__() which contains newlines it does not get escaped. + # However in either case we want to preserve the newline. + replaces = [("\n", "\n~"), ("%", "%%")] + if not isinstance(obj, str): + obj = saferepr(obj, _get_maxsize_for_saferepr(util._config)) + replaces.append(("\\n", "\n~")) + + for r1, r2 in replaces: + obj = obj.replace(r1, r2) + + return obj + + +def _should_repr_global_name(obj: object) -> bool: + if callable(obj): + return False + + try: + return not hasattr(obj, "__name__") + except Exception: + return True + + +def _format_boolop(explanations: Iterable[str], is_or: bool) -> str: + explanation = "(" + (is_or and " or " or " and ").join(explanations) + ")" + return explanation.replace("%", "%%") + + +def _call_reprcompare( + ops: Sequence[str], + results: Sequence[bool], + expls: Sequence[str], + each_obj: Sequence[object], +) -> str: + for i, res, expl in zip(range(len(ops)), results, expls): + try: + done = not res + except Exception: + done = True + if done: + break + if util._reprcompare is not None: + custom = util._reprcompare(ops[i], each_obj[i], each_obj[i + 1]) + if custom is not None: + return custom + return expl + + +def _call_assertion_pass(lineno: int, orig: str, expl: str) -> None: + if util._assertion_pass is not None: + util._assertion_pass(lineno, orig, expl) + + +def _check_if_assertion_pass_impl() -> bool: + """Check if any plugins implement the pytest_assertion_pass hook + in order not to generate explanation unnecessarily (might be expensive).""" + return True if util._assertion_pass else False + + +UNARY_MAP = {ast.Not: "not %s", ast.Invert: "~%s", ast.USub: "-%s", ast.UAdd: "+%s"} + +BINOP_MAP = { + ast.BitOr: "|", + ast.BitXor: "^", + ast.BitAnd: "&", + ast.LShift: "<<", + ast.RShift: ">>", + ast.Add: "+", + ast.Sub: "-", + ast.Mult: "*", + ast.Div: "/", + ast.FloorDiv: "//", + ast.Mod: "%%", # escaped for string formatting + ast.Eq: "==", + ast.NotEq: "!=", + ast.Lt: "<", + ast.LtE: "<=", + ast.Gt: ">", + ast.GtE: ">=", + ast.Pow: "**", + ast.Is: "is", + ast.IsNot: "is not", + ast.In: "in", + ast.NotIn: "not in", + ast.MatMult: "@", +} + + +def traverse_node(node: ast.AST) -> Iterator[ast.AST]: + """Recursively yield node and all its children in depth-first order.""" + yield node + for child in ast.iter_child_nodes(node): + yield from traverse_node(child) + + +@functools.lru_cache(maxsize=1) +def _get_assertion_exprs(src: bytes) -> dict[int, str]: + """Return a mapping from {lineno: "assertion test expression"}.""" + ret: dict[int, str] = {} + + depth = 0 + lines: list[str] = [] + assert_lineno: int | None = None + seen_lines: set[int] = set() + + def _write_and_reset() -> None: + nonlocal depth, lines, assert_lineno, seen_lines + assert assert_lineno is not None + ret[assert_lineno] = "".join(lines).rstrip().rstrip("\\") + depth = 0 + lines = [] + assert_lineno = None + seen_lines = set() + + tokens = tokenize.tokenize(io.BytesIO(src).readline) + for tp, source, (lineno, offset), _, line in tokens: + if tp == tokenize.NAME and source == "assert": + assert_lineno = lineno + elif assert_lineno is not None: + # keep track of depth for the assert-message `,` lookup + if tp == tokenize.OP and source in "([{": + depth += 1 + elif tp == tokenize.OP and source in ")]}": + depth -= 1 + + if not lines: + lines.append(line[offset:]) + seen_lines.add(lineno) + # a non-nested comma separates the expression from the message + elif depth == 0 and tp == tokenize.OP and source == ",": + # one line assert with message + if lineno in seen_lines and len(lines) == 1: + offset_in_trimmed = offset + len(lines[-1]) - len(line) + lines[-1] = lines[-1][:offset_in_trimmed] + # multi-line assert with message + elif lineno in seen_lines: + lines[-1] = lines[-1][:offset] + # multi line assert with escaped newline before message + else: + lines.append(line[:offset]) + _write_and_reset() + elif tp in {tokenize.NEWLINE, tokenize.ENDMARKER}: + _write_and_reset() + elif lines and lineno not in seen_lines: + lines.append(line) + seen_lines.add(lineno) + + return ret + + +class AssertionRewriter(ast.NodeVisitor): + """Assertion rewriting implementation. + + The main entrypoint is to call .run() with an ast.Module instance, + this will then find all the assert statements and rewrite them to + provide intermediate values and a detailed assertion error. See + http://pybites.blogspot.be/2011/07/behind-scenes-of-pytests-new-assertion.html + for an overview of how this works. + + The entry point here is .run() which will iterate over all the + statements in an ast.Module and for each ast.Assert statement it + finds call .visit() with it. Then .visit_Assert() takes over and + is responsible for creating new ast statements to replace the + original assert statement: it rewrites the test of an assertion + to provide intermediate values and replace it with an if statement + which raises an assertion error with a detailed explanation in + case the expression is false and calls pytest_assertion_pass hook + if expression is true. + + For this .visit_Assert() uses the visitor pattern to visit all the + AST nodes of the ast.Assert.test field, each visit call returning + an AST node and the corresponding explanation string. During this + state is kept in several instance attributes: + + :statements: All the AST statements which will replace the assert + statement. + + :variables: This is populated by .variable() with each variable + used by the statements so that they can all be set to None at + the end of the statements. + + :variable_counter: Counter to create new unique variables needed + by statements. Variables are created using .variable() and + have the form of "@py_assert0". + + :expl_stmts: The AST statements which will be executed to get + data from the assertion. This is the code which will construct + the detailed assertion message that is used in the AssertionError + or for the pytest_assertion_pass hook. + + :explanation_specifiers: A dict filled by .explanation_param() + with %-formatting placeholders and their corresponding + expressions to use in the building of an assertion message. + This is used by .pop_format_context() to build a message. + + :stack: A stack of the explanation_specifiers dicts maintained by + .push_format_context() and .pop_format_context() which allows + to build another %-formatted string while already building one. + + :scope: A tuple containing the current scope used for variables_overwrite. + + :variables_overwrite: A dict filled with references to variables + that change value within an assert. This happens when a variable is + reassigned with the walrus operator + + This state, except the variables_overwrite, is reset on every new assert + statement visited and used by the other visitors. + """ + + def __init__( + self, module_path: str | None, config: Config | None, source: bytes + ) -> None: + super().__init__() + self.module_path = module_path + self.config = config + if config is not None: + self.enable_assertion_pass_hook = config.getini( + "enable_assertion_pass_hook" + ) + else: + self.enable_assertion_pass_hook = False + self.source = source + self.scope: tuple[ast.AST, ...] = () + self.variables_overwrite: defaultdict[tuple[ast.AST, ...], dict[str, str]] = ( + defaultdict(dict) + ) + + def run(self, mod: ast.Module) -> None: + """Find all assert statements in *mod* and rewrite them.""" + if not mod.body: + # Nothing to do. + return + + # We'll insert some special imports at the top of the module, but after any + # docstrings and __future__ imports, so first figure out where that is. + doc = getattr(mod, "docstring", None) + expect_docstring = doc is None + if doc is not None and self.is_rewrite_disabled(doc): + return + pos = 0 + item = None + for item in mod.body: + if ( + expect_docstring + and isinstance(item, ast.Expr) + and isinstance(item.value, ast.Constant) + and isinstance(item.value.value, str) + ): + doc = item.value.value + if self.is_rewrite_disabled(doc): + return + expect_docstring = False + elif ( + isinstance(item, ast.ImportFrom) + and item.level == 0 + and item.module == "__future__" + ): + pass + else: + break + pos += 1 + # Special case: for a decorated function, set the lineno to that of the + # first decorator, not the `def`. Issue #4984. + if isinstance(item, ast.FunctionDef) and item.decorator_list: + lineno = item.decorator_list[0].lineno + else: + lineno = item.lineno + # Now actually insert the special imports. + if sys.version_info >= (3, 10): + aliases = [ + ast.alias("builtins", "@py_builtins", lineno=lineno, col_offset=0), + ast.alias( + "_pytest.assertion.rewrite", + "@pytest_ar", + lineno=lineno, + col_offset=0, + ), + ] + else: + aliases = [ + ast.alias("builtins", "@py_builtins"), + ast.alias("_pytest.assertion.rewrite", "@pytest_ar"), + ] + imports = [ + ast.Import([alias], lineno=lineno, col_offset=0) for alias in aliases + ] + mod.body[pos:pos] = imports + + # Collect asserts. + self.scope = (mod,) + nodes: list[ast.AST | Sentinel] = [mod] + while nodes: + node = nodes.pop() + if isinstance(node, (ast.FunctionDef, ast.AsyncFunctionDef, ast.ClassDef)): + self.scope = tuple((*self.scope, node)) + nodes.append(_SCOPE_END_MARKER) + if node == _SCOPE_END_MARKER: + self.scope = self.scope[:-1] + continue + assert isinstance(node, ast.AST) + for name, field in ast.iter_fields(node): + if isinstance(field, list): + new: list[ast.AST] = [] + for i, child in enumerate(field): + if isinstance(child, ast.Assert): + # Transform assert. + new.extend(self.visit(child)) + else: + new.append(child) + if isinstance(child, ast.AST): + nodes.append(child) + setattr(node, name, new) + elif ( + isinstance(field, ast.AST) + # Don't recurse into expressions as they can't contain + # asserts. + and not isinstance(field, ast.expr) + ): + nodes.append(field) + + @staticmethod + def is_rewrite_disabled(docstring: str) -> bool: + return "PYTEST_DONT_REWRITE" in docstring + + def variable(self) -> str: + """Get a new variable.""" + # Use a character invalid in python identifiers to avoid clashing. + name = "@py_assert" + str(next(self.variable_counter)) + self.variables.append(name) + return name + + def assign(self, expr: ast.expr) -> ast.Name: + """Give *expr* a name.""" + name = self.variable() + self.statements.append(ast.Assign([ast.Name(name, ast.Store())], expr)) + return ast.Name(name, ast.Load()) + + def display(self, expr: ast.expr) -> ast.expr: + """Call saferepr on the expression.""" + return self.helper("_saferepr", expr) + + def helper(self, name: str, *args: ast.expr) -> ast.expr: + """Call a helper in this module.""" + py_name = ast.Name("@pytest_ar", ast.Load()) + attr = ast.Attribute(py_name, name, ast.Load()) + return ast.Call(attr, list(args), []) + + def builtin(self, name: str) -> ast.Attribute: + """Return the builtin called *name*.""" + builtin_name = ast.Name("@py_builtins", ast.Load()) + return ast.Attribute(builtin_name, name, ast.Load()) + + def explanation_param(self, expr: ast.expr) -> str: + """Return a new named %-formatting placeholder for expr. + + This creates a %-formatting placeholder for expr in the + current formatting context, e.g. ``%(py0)s``. The placeholder + and expr are placed in the current format context so that it + can be used on the next call to .pop_format_context(). + """ + specifier = "py" + str(next(self.variable_counter)) + self.explanation_specifiers[specifier] = expr + return "%(" + specifier + ")s" + + def push_format_context(self) -> None: + """Create a new formatting context. + + The format context is used for when an explanation wants to + have a variable value formatted in the assertion message. In + this case the value required can be added using + .explanation_param(). Finally .pop_format_context() is used + to format a string of %-formatted values as added by + .explanation_param(). + """ + self.explanation_specifiers: dict[str, ast.expr] = {} + self.stack.append(self.explanation_specifiers) + + def pop_format_context(self, expl_expr: ast.expr) -> ast.Name: + """Format the %-formatted string with current format context. + + The expl_expr should be an str ast.expr instance constructed from + the %-placeholders created by .explanation_param(). This will + add the required code to format said string to .expl_stmts and + return the ast.Name instance of the formatted string. + """ + current = self.stack.pop() + if self.stack: + self.explanation_specifiers = self.stack[-1] + keys: list[ast.expr | None] = [ast.Constant(key) for key in current.keys()] + format_dict = ast.Dict(keys, list(current.values())) + form = ast.BinOp(expl_expr, ast.Mod(), format_dict) + name = "@py_format" + str(next(self.variable_counter)) + if self.enable_assertion_pass_hook: + self.format_variables.append(name) + self.expl_stmts.append(ast.Assign([ast.Name(name, ast.Store())], form)) + return ast.Name(name, ast.Load()) + + def generic_visit(self, node: ast.AST) -> tuple[ast.Name, str]: + """Handle expressions we don't have custom code for.""" + assert isinstance(node, ast.expr) + res = self.assign(node) + return res, self.explanation_param(self.display(res)) + + def visit_Assert(self, assert_: ast.Assert) -> list[ast.stmt]: + """Return the AST statements to replace the ast.Assert instance. + + This rewrites the test of an assertion to provide + intermediate values and replace it with an if statement which + raises an assertion error with a detailed explanation in case + the expression is false. + """ + if isinstance(assert_.test, ast.Tuple) and len(assert_.test.elts) >= 1: + import warnings + + from _pytest.warning_types import PytestAssertRewriteWarning + + # TODO: This assert should not be needed. + assert self.module_path is not None + warnings.warn_explicit( + PytestAssertRewriteWarning( + "assertion is always true, perhaps remove parentheses?" + ), + category=None, + filename=self.module_path, + lineno=assert_.lineno, + ) + + self.statements: list[ast.stmt] = [] + self.variables: list[str] = [] + self.variable_counter = itertools.count() + + if self.enable_assertion_pass_hook: + self.format_variables: list[str] = [] + + self.stack: list[dict[str, ast.expr]] = [] + self.expl_stmts: list[ast.stmt] = [] + self.push_format_context() + # Rewrite assert into a bunch of statements. + top_condition, explanation = self.visit(assert_.test) + + negation = ast.UnaryOp(ast.Not(), top_condition) + + if self.enable_assertion_pass_hook: # Experimental pytest_assertion_pass hook + msg = self.pop_format_context(ast.Constant(explanation)) + + # Failed + if assert_.msg: + assertmsg = self.helper("_format_assertmsg", assert_.msg) + gluestr = "\n>assert " + else: + assertmsg = ast.Constant("") + gluestr = "assert " + err_explanation = ast.BinOp(ast.Constant(gluestr), ast.Add(), msg) + err_msg = ast.BinOp(assertmsg, ast.Add(), err_explanation) + err_name = ast.Name("AssertionError", ast.Load()) + fmt = self.helper("_format_explanation", err_msg) + exc = ast.Call(err_name, [fmt], []) + raise_ = ast.Raise(exc, None) + statements_fail = [] + statements_fail.extend(self.expl_stmts) + statements_fail.append(raise_) + + # Passed + fmt_pass = self.helper("_format_explanation", msg) + orig = _get_assertion_exprs(self.source)[assert_.lineno] + hook_call_pass = ast.Expr( + self.helper( + "_call_assertion_pass", + ast.Constant(assert_.lineno), + ast.Constant(orig), + fmt_pass, + ) + ) + # If any hooks implement assert_pass hook + hook_impl_test = ast.If( + self.helper("_check_if_assertion_pass_impl"), + [*self.expl_stmts, hook_call_pass], + [], + ) + statements_pass: list[ast.stmt] = [hook_impl_test] + + # Test for assertion condition + main_test = ast.If(negation, statements_fail, statements_pass) + self.statements.append(main_test) + if self.format_variables: + variables: list[ast.expr] = [ + ast.Name(name, ast.Store()) for name in self.format_variables + ] + clear_format = ast.Assign(variables, ast.Constant(None)) + self.statements.append(clear_format) + + else: # Original assertion rewriting + # Create failure message. + body = self.expl_stmts + self.statements.append(ast.If(negation, body, [])) + if assert_.msg: + assertmsg = self.helper("_format_assertmsg", assert_.msg) + explanation = "\n>assert " + explanation + else: + assertmsg = ast.Constant("") + explanation = "assert " + explanation + template = ast.BinOp(assertmsg, ast.Add(), ast.Constant(explanation)) + msg = self.pop_format_context(template) + fmt = self.helper("_format_explanation", msg) + err_name = ast.Name("AssertionError", ast.Load()) + exc = ast.Call(err_name, [fmt], []) + raise_ = ast.Raise(exc, None) + + body.append(raise_) + + # Clear temporary variables by setting them to None. + if self.variables: + variables = [ast.Name(name, ast.Store()) for name in self.variables] + clear = ast.Assign(variables, ast.Constant(None)) + self.statements.append(clear) + # Fix locations (line numbers/column offsets). + for stmt in self.statements: + for node in traverse_node(stmt): + ast.copy_location(node, assert_) + return self.statements + + def visit_NamedExpr(self, name: ast.NamedExpr) -> tuple[ast.NamedExpr, str]: + # This method handles the 'walrus operator' repr of the target + # name if it's a local variable or _should_repr_global_name() + # thinks it's acceptable. + locs = ast.Call(self.builtin("locals"), [], []) + target_id = name.target.id + inlocs = ast.Compare(ast.Constant(target_id), [ast.In()], [locs]) + dorepr = self.helper("_should_repr_global_name", name) + test = ast.BoolOp(ast.Or(), [inlocs, dorepr]) + expr = ast.IfExp(test, self.display(name), ast.Constant(target_id)) + return name, self.explanation_param(expr) + + def visit_Name(self, name: ast.Name) -> tuple[ast.Name, str]: + # Display the repr of the name if it's a local variable or + # _should_repr_global_name() thinks it's acceptable. + locs = ast.Call(self.builtin("locals"), [], []) + inlocs = ast.Compare(ast.Constant(name.id), [ast.In()], [locs]) + dorepr = self.helper("_should_repr_global_name", name) + test = ast.BoolOp(ast.Or(), [inlocs, dorepr]) + expr = ast.IfExp(test, self.display(name), ast.Constant(name.id)) + return name, self.explanation_param(expr) + + def visit_BoolOp(self, boolop: ast.BoolOp) -> tuple[ast.Name, str]: + res_var = self.variable() + expl_list = self.assign(ast.List([], ast.Load())) + app = ast.Attribute(expl_list, "append", ast.Load()) + is_or = int(isinstance(boolop.op, ast.Or)) + body = save = self.statements + fail_save = self.expl_stmts + levels = len(boolop.values) - 1 + self.push_format_context() + # Process each operand, short-circuiting if needed. + for i, v in enumerate(boolop.values): + if i: + fail_inner: list[ast.stmt] = [] + # cond is set in a prior loop iteration below + self.expl_stmts.append(ast.If(cond, fail_inner, [])) # noqa: F821 + self.expl_stmts = fail_inner + # Check if the left operand is a ast.NamedExpr and the value has already been visited + if ( + isinstance(v, ast.Compare) + and isinstance(v.left, ast.NamedExpr) + and v.left.target.id + in [ + ast_expr.id + for ast_expr in boolop.values[:i] + if hasattr(ast_expr, "id") + ] + ): + pytest_temp = self.variable() + self.variables_overwrite[self.scope][v.left.target.id] = v.left # type:ignore[assignment] + v.left.target.id = pytest_temp + self.push_format_context() + res, expl = self.visit(v) + body.append(ast.Assign([ast.Name(res_var, ast.Store())], res)) + expl_format = self.pop_format_context(ast.Constant(expl)) + call = ast.Call(app, [expl_format], []) + self.expl_stmts.append(ast.Expr(call)) + if i < levels: + cond: ast.expr = res + if is_or: + cond = ast.UnaryOp(ast.Not(), cond) + inner: list[ast.stmt] = [] + self.statements.append(ast.If(cond, inner, [])) + self.statements = body = inner + self.statements = save + self.expl_stmts = fail_save + expl_template = self.helper("_format_boolop", expl_list, ast.Constant(is_or)) + expl = self.pop_format_context(expl_template) + return ast.Name(res_var, ast.Load()), self.explanation_param(expl) + + def visit_UnaryOp(self, unary: ast.UnaryOp) -> tuple[ast.Name, str]: + pattern = UNARY_MAP[unary.op.__class__] + operand_res, operand_expl = self.visit(unary.operand) + res = self.assign(ast.UnaryOp(unary.op, operand_res)) + return res, pattern % (operand_expl,) + + def visit_BinOp(self, binop: ast.BinOp) -> tuple[ast.Name, str]: + symbol = BINOP_MAP[binop.op.__class__] + left_expr, left_expl = self.visit(binop.left) + right_expr, right_expl = self.visit(binop.right) + explanation = f"({left_expl} {symbol} {right_expl})" + res = self.assign(ast.BinOp(left_expr, binop.op, right_expr)) + return res, explanation + + def visit_Call(self, call: ast.Call) -> tuple[ast.Name, str]: + new_func, func_expl = self.visit(call.func) + arg_expls = [] + new_args = [] + new_kwargs = [] + for arg in call.args: + if isinstance(arg, ast.Name) and arg.id in self.variables_overwrite.get( + self.scope, {} + ): + arg = self.variables_overwrite[self.scope][arg.id] # type:ignore[assignment] + res, expl = self.visit(arg) + arg_expls.append(expl) + new_args.append(res) + for keyword in call.keywords: + if isinstance( + keyword.value, ast.Name + ) and keyword.value.id in self.variables_overwrite.get(self.scope, {}): + keyword.value = self.variables_overwrite[self.scope][keyword.value.id] # type:ignore[assignment] + res, expl = self.visit(keyword.value) + new_kwargs.append(ast.keyword(keyword.arg, res)) + if keyword.arg: + arg_expls.append(keyword.arg + "=" + expl) + else: # **args have `arg` keywords with an .arg of None + arg_expls.append("**" + expl) + + expl = "{}({})".format(func_expl, ", ".join(arg_expls)) + new_call = ast.Call(new_func, new_args, new_kwargs) + res = self.assign(new_call) + res_expl = self.explanation_param(self.display(res)) + outer_expl = f"{res_expl}\n{{{res_expl} = {expl}\n}}" + return res, outer_expl + + def visit_Starred(self, starred: ast.Starred) -> tuple[ast.Starred, str]: + # A Starred node can appear in a function call. + res, expl = self.visit(starred.value) + new_starred = ast.Starred(res, starred.ctx) + return new_starred, "*" + expl + + def visit_Attribute(self, attr: ast.Attribute) -> tuple[ast.Name, str]: + if not isinstance(attr.ctx, ast.Load): + return self.generic_visit(attr) + value, value_expl = self.visit(attr.value) + res = self.assign(ast.Attribute(value, attr.attr, ast.Load())) + res_expl = self.explanation_param(self.display(res)) + pat = "%s\n{%s = %s.%s\n}" + expl = pat % (res_expl, res_expl, value_expl, attr.attr) + return res, expl + + def visit_Compare(self, comp: ast.Compare) -> tuple[ast.expr, str]: + self.push_format_context() + # We first check if we have overwritten a variable in the previous assert + if isinstance( + comp.left, ast.Name + ) and comp.left.id in self.variables_overwrite.get(self.scope, {}): + comp.left = self.variables_overwrite[self.scope][comp.left.id] # type:ignore[assignment] + if isinstance(comp.left, ast.NamedExpr): + self.variables_overwrite[self.scope][comp.left.target.id] = comp.left # type:ignore[assignment] + left_res, left_expl = self.visit(comp.left) + if isinstance(comp.left, (ast.Compare, ast.BoolOp)): + left_expl = f"({left_expl})" + res_variables = [self.variable() for i in range(len(comp.ops))] + load_names: list[ast.expr] = [ast.Name(v, ast.Load()) for v in res_variables] + store_names = [ast.Name(v, ast.Store()) for v in res_variables] + it = zip(range(len(comp.ops)), comp.ops, comp.comparators) + expls: list[ast.expr] = [] + syms: list[ast.expr] = [] + results = [left_res] + for i, op, next_operand in it: + if ( + isinstance(next_operand, ast.NamedExpr) + and isinstance(left_res, ast.Name) + and next_operand.target.id == left_res.id + ): + next_operand.target.id = self.variable() + self.variables_overwrite[self.scope][left_res.id] = next_operand # type:ignore[assignment] + next_res, next_expl = self.visit(next_operand) + if isinstance(next_operand, (ast.Compare, ast.BoolOp)): + next_expl = f"({next_expl})" + results.append(next_res) + sym = BINOP_MAP[op.__class__] + syms.append(ast.Constant(sym)) + expl = f"{left_expl} {sym} {next_expl}" + expls.append(ast.Constant(expl)) + res_expr = ast.Compare(left_res, [op], [next_res]) + self.statements.append(ast.Assign([store_names[i]], res_expr)) + left_res, left_expl = next_res, next_expl + # Use pytest.assertion.util._reprcompare if that's available. + expl_call = self.helper( + "_call_reprcompare", + ast.Tuple(syms, ast.Load()), + ast.Tuple(load_names, ast.Load()), + ast.Tuple(expls, ast.Load()), + ast.Tuple(results, ast.Load()), + ) + if len(comp.ops) > 1: + res: ast.expr = ast.BoolOp(ast.And(), load_names) + else: + res = load_names[0] + + return res, self.explanation_param(self.pop_format_context(expl_call)) + + +def try_makedirs(cache_dir: Path) -> bool: + """Attempt to create the given directory and sub-directories exist. + + Returns True if successful or if it already exists. + """ + try: + os.makedirs(cache_dir, exist_ok=True) + except (FileNotFoundError, NotADirectoryError, FileExistsError): + # One of the path components was not a directory: + # - we're in a zip file + # - it is a file + return False + except PermissionError: + return False + except OSError as e: + # as of now, EROFS doesn't have an equivalent OSError-subclass + # + # squashfuse_ll returns ENOSYS "OSError: [Errno 38] Function not + # implemented" for a read-only error + if e.errno in {errno.EROFS, errno.ENOSYS}: + return False + raise + return True + + +def get_cache_dir(file_path: Path) -> Path: + """Return the cache directory to write .pyc files for the given .py file path.""" + if sys.pycache_prefix: + # given: + # prefix = '/tmp/pycs' + # path = '/home/user/proj/test_app.py' + # we want: + # '/tmp/pycs/home/user/proj' + return Path(sys.pycache_prefix) / Path(*file_path.parts[1:-1]) + else: + # classic pycache directory + return file_path.parent / "__pycache__" diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/truncate.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/truncate.py new file mode 100644 index 0000000..b67f02c --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/truncate.py @@ -0,0 +1,117 @@ +"""Utilities for truncating assertion output. + +Current default behaviour is to truncate assertion explanations at +terminal lines, unless running with an assertions verbosity level of at least 2 or running on CI. +""" + +from __future__ import annotations + +from _pytest.assertion import util +from _pytest.config import Config +from _pytest.nodes import Item + + +DEFAULT_MAX_LINES = 8 +DEFAULT_MAX_CHARS = 8 * 80 +USAGE_MSG = "use '-vv' to show" + + +def truncate_if_required( + explanation: list[str], item: Item, max_length: int | None = None +) -> list[str]: + """Truncate this assertion explanation if the given test item is eligible.""" + if _should_truncate_item(item): + return _truncate_explanation(explanation) + return explanation + + +def _should_truncate_item(item: Item) -> bool: + """Whether or not this test item is eligible for truncation.""" + verbose = item.config.get_verbosity(Config.VERBOSITY_ASSERTIONS) + return verbose < 2 and not util.running_on_ci() + + +def _truncate_explanation( + input_lines: list[str], + max_lines: int | None = None, + max_chars: int | None = None, +) -> list[str]: + """Truncate given list of strings that makes up the assertion explanation. + + Truncates to either 8 lines, or 640 characters - whichever the input reaches + first, taking the truncation explanation into account. The remaining lines + will be replaced by a usage message. + """ + if max_lines is None: + max_lines = DEFAULT_MAX_LINES + if max_chars is None: + max_chars = DEFAULT_MAX_CHARS + + # Check if truncation required + input_char_count = len("".join(input_lines)) + # The length of the truncation explanation depends on the number of lines + # removed but is at least 68 characters: + # The real value is + # 64 (for the base message: + # '...\n...Full output truncated (1 line hidden), use '-vv' to show")' + # ) + # + 1 (for plural) + # + int(math.log10(len(input_lines) - max_lines)) (number of hidden line, at least 1) + # + 3 for the '...' added to the truncated line + # But if there's more than 100 lines it's very likely that we're going to + # truncate, so we don't need the exact value using log10. + tolerable_max_chars = ( + max_chars + 70 # 64 + 1 (for plural) + 2 (for '99') + 3 for '...' + ) + # The truncation explanation add two lines to the output + tolerable_max_lines = max_lines + 2 + if ( + len(input_lines) <= tolerable_max_lines + and input_char_count <= tolerable_max_chars + ): + return input_lines + # Truncate first to max_lines, and then truncate to max_chars if necessary + truncated_explanation = input_lines[:max_lines] + truncated_char = True + # We reevaluate the need to truncate chars following removal of some lines + if len("".join(truncated_explanation)) > tolerable_max_chars: + truncated_explanation = _truncate_by_char_count( + truncated_explanation, max_chars + ) + else: + truncated_char = False + + truncated_line_count = len(input_lines) - len(truncated_explanation) + if truncated_explanation[-1]: + # Add ellipsis and take into account part-truncated final line + truncated_explanation[-1] = truncated_explanation[-1] + "..." + if truncated_char: + # It's possible that we did not remove any char from this line + truncated_line_count += 1 + else: + # Add proper ellipsis when we were able to fit a full line exactly + truncated_explanation[-1] = "..." + return [ + *truncated_explanation, + "", + f"...Full output truncated ({truncated_line_count} line" + f"{'' if truncated_line_count == 1 else 's'} hidden), {USAGE_MSG}", + ] + + +def _truncate_by_char_count(input_lines: list[str], max_chars: int) -> list[str]: + # Find point at which input length exceeds total allowed length + iterated_char_count = 0 + for iterated_index, input_line in enumerate(input_lines): + if iterated_char_count + len(input_line) > max_chars: + break + iterated_char_count += len(input_line) + + # Create truncated explanation with modified final line + truncated_result = input_lines[:iterated_index] + final_line = input_lines[iterated_index] + if final_line: + final_line_truncate_point = max_chars - iterated_char_count + final_line = final_line[:final_line_truncate_point] + truncated_result.append(final_line) + return truncated_result diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/util.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/util.py new file mode 100644 index 0000000..4dc1af4 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/assertion/util.py @@ -0,0 +1,609 @@ +# mypy: allow-untyped-defs +"""Utilities for assertion debugging.""" + +from __future__ import annotations + +import collections.abc +import os +import pprint +from typing import AbstractSet +from typing import Any +from typing import Callable +from typing import Iterable +from typing import Literal +from typing import Mapping +from typing import Protocol +from typing import Sequence +from unicodedata import normalize + +from _pytest import outcomes +import _pytest._code +from _pytest._io.pprint import PrettyPrinter +from _pytest._io.saferepr import saferepr +from _pytest._io.saferepr import saferepr_unlimited +from _pytest.config import Config + + +# The _reprcompare attribute on the util module is used by the new assertion +# interpretation code and assertion rewriter to detect this plugin was +# loaded and in turn call the hooks defined here as part of the +# DebugInterpreter. +_reprcompare: Callable[[str, object, object], str | None] | None = None + +# Works similarly as _reprcompare attribute. Is populated with the hook call +# when pytest_runtest_setup is called. +_assertion_pass: Callable[[int, str, str], None] | None = None + +# Config object which is assigned during pytest_runtest_protocol. +_config: Config | None = None + + +class _HighlightFunc(Protocol): + def __call__(self, source: str, lexer: Literal["diff", "python"] = "python") -> str: + """Apply highlighting to the given source.""" + + +def format_explanation(explanation: str) -> str: + r"""Format an explanation. + + Normally all embedded newlines are escaped, however there are + three exceptions: \n{, \n} and \n~. The first two are intended + cover nested explanations, see function and attribute explanations + for examples (.visit_Call(), visit_Attribute()). The last one is + for when one explanation needs to span multiple lines, e.g. when + displaying diffs. + """ + lines = _split_explanation(explanation) + result = _format_lines(lines) + return "\n".join(result) + + +def _split_explanation(explanation: str) -> list[str]: + r"""Return a list of individual lines in the explanation. + + This will return a list of lines split on '\n{', '\n}' and '\n~'. + Any other newlines will be escaped and appear in the line as the + literal '\n' characters. + """ + raw_lines = (explanation or "").split("\n") + lines = [raw_lines[0]] + for values in raw_lines[1:]: + if values and values[0] in ["{", "}", "~", ">"]: + lines.append(values) + else: + lines[-1] += "\\n" + values + return lines + + +def _format_lines(lines: Sequence[str]) -> list[str]: + """Format the individual lines. + + This will replace the '{', '}' and '~' characters of our mini formatting + language with the proper 'where ...', 'and ...' and ' + ...' text, taking + care of indentation along the way. + + Return a list of formatted lines. + """ + result = list(lines[:1]) + stack = [0] + stackcnt = [0] + for line in lines[1:]: + if line.startswith("{"): + if stackcnt[-1]: + s = "and " + else: + s = "where " + stack.append(len(result)) + stackcnt[-1] += 1 + stackcnt.append(0) + result.append(" +" + " " * (len(stack) - 1) + s + line[1:]) + elif line.startswith("}"): + stack.pop() + stackcnt.pop() + result[stack[-1]] += line[1:] + else: + assert line[0] in ["~", ">"] + stack[-1] += 1 + indent = len(stack) if line.startswith("~") else len(stack) - 1 + result.append(" " * indent + line[1:]) + assert len(stack) == 1 + return result + + +def issequence(x: Any) -> bool: + return isinstance(x, collections.abc.Sequence) and not isinstance(x, str) + + +def istext(x: Any) -> bool: + return isinstance(x, str) + + +def isdict(x: Any) -> bool: + return isinstance(x, dict) + + +def isset(x: Any) -> bool: + return isinstance(x, (set, frozenset)) + + +def isnamedtuple(obj: Any) -> bool: + return isinstance(obj, tuple) and getattr(obj, "_fields", None) is not None + + +def isdatacls(obj: Any) -> bool: + return getattr(obj, "__dataclass_fields__", None) is not None + + +def isattrs(obj: Any) -> bool: + return getattr(obj, "__attrs_attrs__", None) is not None + + +def isiterable(obj: Any) -> bool: + try: + iter(obj) + return not istext(obj) + except Exception: + return False + + +def has_default_eq( + obj: object, +) -> bool: + """Check if an instance of an object contains the default eq + + First, we check if the object's __eq__ attribute has __code__, + if so, we check the equally of the method code filename (__code__.co_filename) + to the default one generated by the dataclass and attr module + for dataclasses the default co_filename is , for attrs class, the __eq__ should contain "attrs eq generated" + """ + # inspired from https://github.com/willmcgugan/rich/blob/07d51ffc1aee6f16bd2e5a25b4e82850fb9ed778/rich/pretty.py#L68 + if hasattr(obj.__eq__, "__code__") and hasattr(obj.__eq__.__code__, "co_filename"): + code_filename = obj.__eq__.__code__.co_filename + + if isattrs(obj): + return "attrs generated eq" in code_filename + + return code_filename == "" # data class + return True + + +def assertrepr_compare( + config, op: str, left: Any, right: Any, use_ascii: bool = False +) -> list[str] | None: + """Return specialised explanations for some operators/operands.""" + verbose = config.get_verbosity(Config.VERBOSITY_ASSERTIONS) + + # Strings which normalize equal are often hard to distinguish when printed; use ascii() to make this easier. + # See issue #3246. + use_ascii = ( + isinstance(left, str) + and isinstance(right, str) + and normalize("NFD", left) == normalize("NFD", right) + ) + + if verbose > 1: + left_repr = saferepr_unlimited(left, use_ascii=use_ascii) + right_repr = saferepr_unlimited(right, use_ascii=use_ascii) + else: + # XXX: "15 chars indentation" is wrong + # ("E AssertionError: assert "); should use term width. + maxsize = ( + 80 - 15 - len(op) - 2 + ) // 2 # 15 chars indentation, 1 space around op + + left_repr = saferepr(left, maxsize=maxsize, use_ascii=use_ascii) + right_repr = saferepr(right, maxsize=maxsize, use_ascii=use_ascii) + + summary = f"{left_repr} {op} {right_repr}" + highlighter = config.get_terminal_writer()._highlight + + explanation = None + try: + if op == "==": + explanation = _compare_eq_any(left, right, highlighter, verbose) + elif op == "not in": + if istext(left) and istext(right): + explanation = _notin_text(left, right, verbose) + elif op == "!=": + if isset(left) and isset(right): + explanation = ["Both sets are equal"] + elif op == ">=": + if isset(left) and isset(right): + explanation = _compare_gte_set(left, right, highlighter, verbose) + elif op == "<=": + if isset(left) and isset(right): + explanation = _compare_lte_set(left, right, highlighter, verbose) + elif op == ">": + if isset(left) and isset(right): + explanation = _compare_gt_set(left, right, highlighter, verbose) + elif op == "<": + if isset(left) and isset(right): + explanation = _compare_lt_set(left, right, highlighter, verbose) + + except outcomes.Exit: + raise + except Exception: + repr_crash = _pytest._code.ExceptionInfo.from_current()._getreprcrash() + explanation = [ + f"(pytest_assertion plugin: representation of details failed: {repr_crash}.", + " Probably an object has a faulty __repr__.)", + ] + + if not explanation: + return None + + if explanation[0] != "": + explanation = ["", *explanation] + return [summary, *explanation] + + +def _compare_eq_any( + left: Any, right: Any, highlighter: _HighlightFunc, verbose: int = 0 +) -> list[str]: + explanation = [] + if istext(left) and istext(right): + explanation = _diff_text(left, right, verbose) + else: + from _pytest.python_api import ApproxBase + + if isinstance(left, ApproxBase) or isinstance(right, ApproxBase): + # Although the common order should be obtained == expected, this ensures both ways + approx_side = left if isinstance(left, ApproxBase) else right + other_side = right if isinstance(left, ApproxBase) else left + + explanation = approx_side._repr_compare(other_side) + elif type(left) is type(right) and ( + isdatacls(left) or isattrs(left) or isnamedtuple(left) + ): + # Note: unlike dataclasses/attrs, namedtuples compare only the + # field values, not the type or field names. But this branch + # intentionally only handles the same-type case, which was often + # used in older code bases before dataclasses/attrs were available. + explanation = _compare_eq_cls(left, right, highlighter, verbose) + elif issequence(left) and issequence(right): + explanation = _compare_eq_sequence(left, right, highlighter, verbose) + elif isset(left) and isset(right): + explanation = _compare_eq_set(left, right, highlighter, verbose) + elif isdict(left) and isdict(right): + explanation = _compare_eq_dict(left, right, highlighter, verbose) + + if isiterable(left) and isiterable(right): + expl = _compare_eq_iterable(left, right, highlighter, verbose) + explanation.extend(expl) + + return explanation + + +def _diff_text(left: str, right: str, verbose: int = 0) -> list[str]: + """Return the explanation for the diff between text. + + Unless --verbose is used this will skip leading and trailing + characters which are identical to keep the diff minimal. + """ + from difflib import ndiff + + explanation: list[str] = [] + + if verbose < 1: + i = 0 # just in case left or right has zero length + for i in range(min(len(left), len(right))): + if left[i] != right[i]: + break + if i > 42: + i -= 10 # Provide some context + explanation = [ + f"Skipping {i} identical leading characters in diff, use -v to show" + ] + left = left[i:] + right = right[i:] + if len(left) == len(right): + for i in range(len(left)): + if left[-i] != right[-i]: + break + if i > 42: + i -= 10 # Provide some context + explanation += [ + f"Skipping {i} identical trailing " + "characters in diff, use -v to show" + ] + left = left[:-i] + right = right[:-i] + keepends = True + if left.isspace() or right.isspace(): + left = repr(str(left)) + right = repr(str(right)) + explanation += ["Strings contain only whitespace, escaping them using repr()"] + # "right" is the expected base against which we compare "left", + # see https://github.com/pytest-dev/pytest/issues/3333 + explanation += [ + line.strip("\n") + for line in ndiff(right.splitlines(keepends), left.splitlines(keepends)) + ] + return explanation + + +def _compare_eq_iterable( + left: Iterable[Any], + right: Iterable[Any], + highlighter: _HighlightFunc, + verbose: int = 0, +) -> list[str]: + if verbose <= 0 and not running_on_ci(): + return ["Use -v to get more diff"] + # dynamic import to speedup pytest + import difflib + + left_formatting = PrettyPrinter().pformat(left).splitlines() + right_formatting = PrettyPrinter().pformat(right).splitlines() + + explanation = ["", "Full diff:"] + # "right" is the expected base against which we compare "left", + # see https://github.com/pytest-dev/pytest/issues/3333 + explanation.extend( + highlighter( + "\n".join( + line.rstrip() + for line in difflib.ndiff(right_formatting, left_formatting) + ), + lexer="diff", + ).splitlines() + ) + return explanation + + +def _compare_eq_sequence( + left: Sequence[Any], + right: Sequence[Any], + highlighter: _HighlightFunc, + verbose: int = 0, +) -> list[str]: + comparing_bytes = isinstance(left, bytes) and isinstance(right, bytes) + explanation: list[str] = [] + len_left = len(left) + len_right = len(right) + for i in range(min(len_left, len_right)): + if left[i] != right[i]: + if comparing_bytes: + # when comparing bytes, we want to see their ascii representation + # instead of their numeric values (#5260) + # using a slice gives us the ascii representation: + # >>> s = b'foo' + # >>> s[0] + # 102 + # >>> s[0:1] + # b'f' + left_value = left[i : i + 1] + right_value = right[i : i + 1] + else: + left_value = left[i] + right_value = right[i] + + explanation.append( + f"At index {i} diff:" + f" {highlighter(repr(left_value))} != {highlighter(repr(right_value))}" + ) + break + + if comparing_bytes: + # when comparing bytes, it doesn't help to show the "sides contain one or more + # items" longer explanation, so skip it + + return explanation + + len_diff = len_left - len_right + if len_diff: + if len_diff > 0: + dir_with_more = "Left" + extra = saferepr(left[len_right]) + else: + len_diff = 0 - len_diff + dir_with_more = "Right" + extra = saferepr(right[len_left]) + + if len_diff == 1: + explanation += [ + f"{dir_with_more} contains one more item: {highlighter(extra)}" + ] + else: + explanation += [ + "%s contains %d more items, first extra item: %s" + % (dir_with_more, len_diff, highlighter(extra)) + ] + return explanation + + +def _compare_eq_set( + left: AbstractSet[Any], + right: AbstractSet[Any], + highlighter: _HighlightFunc, + verbose: int = 0, +) -> list[str]: + explanation = [] + explanation.extend(_set_one_sided_diff("left", left, right, highlighter)) + explanation.extend(_set_one_sided_diff("right", right, left, highlighter)) + return explanation + + +def _compare_gt_set( + left: AbstractSet[Any], + right: AbstractSet[Any], + highlighter: _HighlightFunc, + verbose: int = 0, +) -> list[str]: + explanation = _compare_gte_set(left, right, highlighter) + if not explanation: + return ["Both sets are equal"] + return explanation + + +def _compare_lt_set( + left: AbstractSet[Any], + right: AbstractSet[Any], + highlighter: _HighlightFunc, + verbose: int = 0, +) -> list[str]: + explanation = _compare_lte_set(left, right, highlighter) + if not explanation: + return ["Both sets are equal"] + return explanation + + +def _compare_gte_set( + left: AbstractSet[Any], + right: AbstractSet[Any], + highlighter: _HighlightFunc, + verbose: int = 0, +) -> list[str]: + return _set_one_sided_diff("right", right, left, highlighter) + + +def _compare_lte_set( + left: AbstractSet[Any], + right: AbstractSet[Any], + highlighter: _HighlightFunc, + verbose: int = 0, +) -> list[str]: + return _set_one_sided_diff("left", left, right, highlighter) + + +def _set_one_sided_diff( + posn: str, + set1: AbstractSet[Any], + set2: AbstractSet[Any], + highlighter: _HighlightFunc, +) -> list[str]: + explanation = [] + diff = set1 - set2 + if diff: + explanation.append(f"Extra items in the {posn} set:") + for item in diff: + explanation.append(highlighter(saferepr(item))) + return explanation + + +def _compare_eq_dict( + left: Mapping[Any, Any], + right: Mapping[Any, Any], + highlighter: _HighlightFunc, + verbose: int = 0, +) -> list[str]: + explanation: list[str] = [] + set_left = set(left) + set_right = set(right) + common = set_left.intersection(set_right) + same = {k: left[k] for k in common if left[k] == right[k]} + if same and verbose < 2: + explanation += [f"Omitting {len(same)} identical items, use -vv to show"] + elif same: + explanation += ["Common items:"] + explanation += highlighter(pprint.pformat(same)).splitlines() + diff = {k for k in common if left[k] != right[k]} + if diff: + explanation += ["Differing items:"] + for k in diff: + explanation += [ + highlighter(saferepr({k: left[k]})) + + " != " + + highlighter(saferepr({k: right[k]})) + ] + extra_left = set_left - set_right + len_extra_left = len(extra_left) + if len_extra_left: + explanation.append( + "Left contains %d more item%s:" + % (len_extra_left, "" if len_extra_left == 1 else "s") + ) + explanation.extend( + highlighter(pprint.pformat({k: left[k] for k in extra_left})).splitlines() + ) + extra_right = set_right - set_left + len_extra_right = len(extra_right) + if len_extra_right: + explanation.append( + "Right contains %d more item%s:" + % (len_extra_right, "" if len_extra_right == 1 else "s") + ) + explanation.extend( + highlighter(pprint.pformat({k: right[k] for k in extra_right})).splitlines() + ) + return explanation + + +def _compare_eq_cls( + left: Any, right: Any, highlighter: _HighlightFunc, verbose: int +) -> list[str]: + if not has_default_eq(left): + return [] + if isdatacls(left): + import dataclasses + + all_fields = dataclasses.fields(left) + fields_to_check = [info.name for info in all_fields if info.compare] + elif isattrs(left): + all_fields = left.__attrs_attrs__ + fields_to_check = [field.name for field in all_fields if getattr(field, "eq")] + elif isnamedtuple(left): + fields_to_check = left._fields + else: + assert False + + indent = " " + same = [] + diff = [] + for field in fields_to_check: + if getattr(left, field) == getattr(right, field): + same.append(field) + else: + diff.append(field) + + explanation = [] + if same or diff: + explanation += [""] + if same and verbose < 2: + explanation.append(f"Omitting {len(same)} identical items, use -vv to show") + elif same: + explanation += ["Matching attributes:"] + explanation += highlighter(pprint.pformat(same)).splitlines() + if diff: + explanation += ["Differing attributes:"] + explanation += highlighter(pprint.pformat(diff)).splitlines() + for field in diff: + field_left = getattr(left, field) + field_right = getattr(right, field) + explanation += [ + "", + f"Drill down into differing attribute {field}:", + f"{indent}{field}: {highlighter(repr(field_left))} != {highlighter(repr(field_right))}", + ] + explanation += [ + indent + line + for line in _compare_eq_any( + field_left, field_right, highlighter, verbose + ) + ] + return explanation + + +def _notin_text(term: str, text: str, verbose: int = 0) -> list[str]: + index = text.find(term) + head = text[:index] + tail = text[index + len(term) :] + correct_text = head + tail + diff = _diff_text(text, correct_text, verbose) + newdiff = [f"{saferepr(term, maxsize=42)} is contained here:"] + for line in diff: + if line.startswith("Skipping"): + continue + if line.startswith("- "): + continue + if line.startswith("+ "): + newdiff.append(" " + line[2:]) + else: + newdiff.append(line) + return newdiff + + +def running_on_ci() -> bool: + """Check if we're currently running on a CI system.""" + env_vars = ["CI", "BUILD_NUMBER"] + return any(var in os.environ for var in env_vars) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/cacheprovider.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/cacheprovider.py new file mode 100644 index 0000000..1b236ef --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/cacheprovider.py @@ -0,0 +1,626 @@ +# mypy: allow-untyped-defs +"""Implementation of the cache provider.""" + +# This plugin was not named "cache" to avoid conflicts with the external +# pytest-cache version. +from __future__ import annotations + +import dataclasses +import errno +import json +import os +from pathlib import Path +import tempfile +from typing import final +from typing import Generator +from typing import Iterable + +from .pathlib import resolve_from_str +from .pathlib import rm_rf +from .reports import CollectReport +from _pytest import nodes +from _pytest._io import TerminalWriter +from _pytest.config import Config +from _pytest.config import ExitCode +from _pytest.config import hookimpl +from _pytest.config.argparsing import Parser +from _pytest.deprecated import check_ispytest +from _pytest.fixtures import fixture +from _pytest.fixtures import FixtureRequest +from _pytest.main import Session +from _pytest.nodes import Directory +from _pytest.nodes import File +from _pytest.reports import TestReport + + +README_CONTENT = """\ +# pytest cache directory # + +This directory contains data from the pytest's cache plugin, +which provides the `--lf` and `--ff` options, as well as the `cache` fixture. + +**Do not** commit this to version control. + +See [the docs](https://docs.pytest.org/en/stable/how-to/cache.html) for more information. +""" + +CACHEDIR_TAG_CONTENT = b"""\ +Signature: 8a477f597d28d172789f06886806bc55 +# This file is a cache directory tag created by pytest. +# For information about cache directory tags, see: +# https://bford.info/cachedir/spec.html +""" + + +@final +@dataclasses.dataclass +class Cache: + """Instance of the `cache` fixture.""" + + _cachedir: Path = dataclasses.field(repr=False) + _config: Config = dataclasses.field(repr=False) + + # Sub-directory under cache-dir for directories created by `mkdir()`. + _CACHE_PREFIX_DIRS = "d" + + # Sub-directory under cache-dir for values created by `set()`. + _CACHE_PREFIX_VALUES = "v" + + def __init__( + self, cachedir: Path, config: Config, *, _ispytest: bool = False + ) -> None: + check_ispytest(_ispytest) + self._cachedir = cachedir + self._config = config + + @classmethod + def for_config(cls, config: Config, *, _ispytest: bool = False) -> Cache: + """Create the Cache instance for a Config. + + :meta private: + """ + check_ispytest(_ispytest) + cachedir = cls.cache_dir_from_config(config, _ispytest=True) + if config.getoption("cacheclear") and cachedir.is_dir(): + cls.clear_cache(cachedir, _ispytest=True) + return cls(cachedir, config, _ispytest=True) + + @classmethod + def clear_cache(cls, cachedir: Path, _ispytest: bool = False) -> None: + """Clear the sub-directories used to hold cached directories and values. + + :meta private: + """ + check_ispytest(_ispytest) + for prefix in (cls._CACHE_PREFIX_DIRS, cls._CACHE_PREFIX_VALUES): + d = cachedir / prefix + if d.is_dir(): + rm_rf(d) + + @staticmethod + def cache_dir_from_config(config: Config, *, _ispytest: bool = False) -> Path: + """Get the path to the cache directory for a Config. + + :meta private: + """ + check_ispytest(_ispytest) + return resolve_from_str(config.getini("cache_dir"), config.rootpath) + + def warn(self, fmt: str, *, _ispytest: bool = False, **args: object) -> None: + """Issue a cache warning. + + :meta private: + """ + check_ispytest(_ispytest) + import warnings + + from _pytest.warning_types import PytestCacheWarning + + warnings.warn( + PytestCacheWarning(fmt.format(**args) if args else fmt), + self._config.hook, + stacklevel=3, + ) + + def _mkdir(self, path: Path) -> None: + self._ensure_cache_dir_and_supporting_files() + path.mkdir(exist_ok=True, parents=True) + + def mkdir(self, name: str) -> Path: + """Return a directory path object with the given name. + + If the directory does not yet exist, it will be created. You can use + it to manage files to e.g. store/retrieve database dumps across test + sessions. + + .. versionadded:: 7.0 + + :param name: + Must be a string not containing a ``/`` separator. + Make sure the name contains your plugin or application + identifiers to prevent clashes with other cache users. + """ + path = Path(name) + if len(path.parts) > 1: + raise ValueError("name is not allowed to contain path separators") + res = self._cachedir.joinpath(self._CACHE_PREFIX_DIRS, path) + self._mkdir(res) + return res + + def _getvaluepath(self, key: str) -> Path: + return self._cachedir.joinpath(self._CACHE_PREFIX_VALUES, Path(key)) + + def get(self, key: str, default): + """Return the cached value for the given key. + + If no value was yet cached or the value cannot be read, the specified + default is returned. + + :param key: + Must be a ``/`` separated value. Usually the first + name is the name of your plugin or your application. + :param default: + The value to return in case of a cache-miss or invalid cache value. + """ + path = self._getvaluepath(key) + try: + with path.open("r", encoding="UTF-8") as f: + return json.load(f) + except (ValueError, OSError): + return default + + def set(self, key: str, value: object) -> None: + """Save value for the given key. + + :param key: + Must be a ``/`` separated value. Usually the first + name is the name of your plugin or your application. + :param value: + Must be of any combination of basic python types, + including nested types like lists of dictionaries. + """ + path = self._getvaluepath(key) + try: + self._mkdir(path.parent) + except OSError as exc: + self.warn( + f"could not create cache path {path}: {exc}", + _ispytest=True, + ) + return + data = json.dumps(value, ensure_ascii=False, indent=2) + try: + f = path.open("w", encoding="UTF-8") + except OSError as exc: + self.warn( + f"cache could not write path {path}: {exc}", + _ispytest=True, + ) + else: + with f: + f.write(data) + + def _ensure_cache_dir_and_supporting_files(self) -> None: + """Create the cache dir and its supporting files.""" + if self._cachedir.is_dir(): + return + + self._cachedir.parent.mkdir(parents=True, exist_ok=True) + with tempfile.TemporaryDirectory( + prefix="pytest-cache-files-", + dir=self._cachedir.parent, + ) as newpath: + path = Path(newpath) + + # Reset permissions to the default, see #12308. + # Note: there's no way to get the current umask atomically, eek. + umask = os.umask(0o022) + os.umask(umask) + path.chmod(0o777 - umask) + + with open(path.joinpath("README.md"), "x", encoding="UTF-8") as f: + f.write(README_CONTENT) + with open(path.joinpath(".gitignore"), "x", encoding="UTF-8") as f: + f.write("# Created by pytest automatically.\n*\n") + with open(path.joinpath("CACHEDIR.TAG"), "xb") as f: + f.write(CACHEDIR_TAG_CONTENT) + + try: + path.rename(self._cachedir) + except OSError as e: + # If 2 concurrent pytests both race to the rename, the loser + # gets "Directory not empty" from the rename. In this case, + # everything is handled so just continue (while letting the + # temporary directory be cleaned up). + # On Windows, the error is a FileExistsError which translates to EEXIST. + if e.errno not in (errno.ENOTEMPTY, errno.EEXIST): + raise + else: + # Create a directory in place of the one we just moved so that + # `TemporaryDirectory`'s cleanup doesn't complain. + # + # TODO: pass ignore_cleanup_errors=True when we no longer support python < 3.10. + # See https://github.com/python/cpython/issues/74168. Note that passing + # delete=False would do the wrong thing in case of errors and isn't supported + # until python 3.12. + path.mkdir() + + +class LFPluginCollWrapper: + def __init__(self, lfplugin: LFPlugin) -> None: + self.lfplugin = lfplugin + self._collected_at_least_one_failure = False + + @hookimpl(wrapper=True) + def pytest_make_collect_report( + self, collector: nodes.Collector + ) -> Generator[None, CollectReport, CollectReport]: + res = yield + if isinstance(collector, (Session, Directory)): + # Sort any lf-paths to the beginning. + lf_paths = self.lfplugin._last_failed_paths + + # Use stable sort to prioritize last failed. + def sort_key(node: nodes.Item | nodes.Collector) -> bool: + return node.path in lf_paths + + res.result = sorted( + res.result, + key=sort_key, + reverse=True, + ) + + elif isinstance(collector, File): + if collector.path in self.lfplugin._last_failed_paths: + result = res.result + lastfailed = self.lfplugin.lastfailed + + # Only filter with known failures. + if not self._collected_at_least_one_failure: + if not any(x.nodeid in lastfailed for x in result): + return res + self.lfplugin.config.pluginmanager.register( + LFPluginCollSkipfiles(self.lfplugin), "lfplugin-collskip" + ) + self._collected_at_least_one_failure = True + + session = collector.session + result[:] = [ + x + for x in result + if x.nodeid in lastfailed + # Include any passed arguments (not trivial to filter). + or session.isinitpath(x.path) + # Keep all sub-collectors. + or isinstance(x, nodes.Collector) + ] + + return res + + +class LFPluginCollSkipfiles: + def __init__(self, lfplugin: LFPlugin) -> None: + self.lfplugin = lfplugin + + @hookimpl + def pytest_make_collect_report( + self, collector: nodes.Collector + ) -> CollectReport | None: + if isinstance(collector, File): + if collector.path not in self.lfplugin._last_failed_paths: + self.lfplugin._skipped_files += 1 + + return CollectReport( + collector.nodeid, "passed", longrepr=None, result=[] + ) + return None + + +class LFPlugin: + """Plugin which implements the --lf (run last-failing) option.""" + + def __init__(self, config: Config) -> None: + self.config = config + active_keys = "lf", "failedfirst" + self.active = any(config.getoption(key) for key in active_keys) + assert config.cache + self.lastfailed: dict[str, bool] = config.cache.get("cache/lastfailed", {}) + self._previously_failed_count: int | None = None + self._report_status: str | None = None + self._skipped_files = 0 # count skipped files during collection due to --lf + + if config.getoption("lf"): + self._last_failed_paths = self.get_last_failed_paths() + config.pluginmanager.register( + LFPluginCollWrapper(self), "lfplugin-collwrapper" + ) + + def get_last_failed_paths(self) -> set[Path]: + """Return a set with all Paths of the previously failed nodeids and + their parents.""" + rootpath = self.config.rootpath + result = set() + for nodeid in self.lastfailed: + path = rootpath / nodeid.split("::")[0] + result.add(path) + result.update(path.parents) + return {x for x in result if x.exists()} + + def pytest_report_collectionfinish(self) -> str | None: + if self.active and self.config.get_verbosity() >= 0: + return f"run-last-failure: {self._report_status}" + return None + + def pytest_runtest_logreport(self, report: TestReport) -> None: + if (report.when == "call" and report.passed) or report.skipped: + self.lastfailed.pop(report.nodeid, None) + elif report.failed: + self.lastfailed[report.nodeid] = True + + def pytest_collectreport(self, report: CollectReport) -> None: + passed = report.outcome in ("passed", "skipped") + if passed: + if report.nodeid in self.lastfailed: + self.lastfailed.pop(report.nodeid) + self.lastfailed.update((item.nodeid, True) for item in report.result) + else: + self.lastfailed[report.nodeid] = True + + @hookimpl(wrapper=True, tryfirst=True) + def pytest_collection_modifyitems( + self, config: Config, items: list[nodes.Item] + ) -> Generator[None]: + res = yield + + if not self.active: + return res + + if self.lastfailed: + previously_failed = [] + previously_passed = [] + for item in items: + if item.nodeid in self.lastfailed: + previously_failed.append(item) + else: + previously_passed.append(item) + self._previously_failed_count = len(previously_failed) + + if not previously_failed: + # Running a subset of all tests with recorded failures + # only outside of it. + self._report_status = "%d known failures not in selected tests" % ( + len(self.lastfailed), + ) + else: + if self.config.getoption("lf"): + items[:] = previously_failed + config.hook.pytest_deselected(items=previously_passed) + else: # --failedfirst + items[:] = previously_failed + previously_passed + + noun = "failure" if self._previously_failed_count == 1 else "failures" + suffix = " first" if self.config.getoption("failedfirst") else "" + self._report_status = ( + f"rerun previous {self._previously_failed_count} {noun}{suffix}" + ) + + if self._skipped_files > 0: + files_noun = "file" if self._skipped_files == 1 else "files" + self._report_status += f" (skipped {self._skipped_files} {files_noun})" + else: + self._report_status = "no previously failed tests, " + if self.config.getoption("last_failed_no_failures") == "none": + self._report_status += "deselecting all items." + config.hook.pytest_deselected(items=items[:]) + items[:] = [] + else: + self._report_status += "not deselecting items." + + return res + + def pytest_sessionfinish(self, session: Session) -> None: + config = self.config + if config.getoption("cacheshow") or hasattr(config, "workerinput"): + return + + assert config.cache is not None + saved_lastfailed = config.cache.get("cache/lastfailed", {}) + if saved_lastfailed != self.lastfailed: + config.cache.set("cache/lastfailed", self.lastfailed) + + +class NFPlugin: + """Plugin which implements the --nf (run new-first) option.""" + + def __init__(self, config: Config) -> None: + self.config = config + self.active = config.option.newfirst + assert config.cache is not None + self.cached_nodeids = set(config.cache.get("cache/nodeids", [])) + + @hookimpl(wrapper=True, tryfirst=True) + def pytest_collection_modifyitems(self, items: list[nodes.Item]) -> Generator[None]: + res = yield + + if self.active: + new_items: dict[str, nodes.Item] = {} + other_items: dict[str, nodes.Item] = {} + for item in items: + if item.nodeid not in self.cached_nodeids: + new_items[item.nodeid] = item + else: + other_items[item.nodeid] = item + + items[:] = self._get_increasing_order( + new_items.values() + ) + self._get_increasing_order(other_items.values()) + self.cached_nodeids.update(new_items) + else: + self.cached_nodeids.update(item.nodeid for item in items) + + return res + + def _get_increasing_order(self, items: Iterable[nodes.Item]) -> list[nodes.Item]: + return sorted(items, key=lambda item: item.path.stat().st_mtime, reverse=True) + + def pytest_sessionfinish(self) -> None: + config = self.config + if config.getoption("cacheshow") or hasattr(config, "workerinput"): + return + + if config.getoption("collectonly"): + return + + assert config.cache is not None + config.cache.set("cache/nodeids", sorted(self.cached_nodeids)) + + +def pytest_addoption(parser: Parser) -> None: + group = parser.getgroup("general") + group.addoption( + "--lf", + "--last-failed", + action="store_true", + dest="lf", + help="Rerun only the tests that failed " + "at the last run (or all if none failed)", + ) + group.addoption( + "--ff", + "--failed-first", + action="store_true", + dest="failedfirst", + help="Run all tests, but run the last failures first. " + "This may re-order tests and thus lead to " + "repeated fixture setup/teardown.", + ) + group.addoption( + "--nf", + "--new-first", + action="store_true", + dest="newfirst", + help="Run tests from new files first, then the rest of the tests " + "sorted by file mtime", + ) + group.addoption( + "--cache-show", + action="append", + nargs="?", + dest="cacheshow", + help=( + "Show cache contents, don't perform collection or tests. " + "Optional argument: glob (default: '*')." + ), + ) + group.addoption( + "--cache-clear", + action="store_true", + dest="cacheclear", + help="Remove all cache contents at start of test run", + ) + cache_dir_default = ".pytest_cache" + if "TOX_ENV_DIR" in os.environ: + cache_dir_default = os.path.join(os.environ["TOX_ENV_DIR"], cache_dir_default) + parser.addini("cache_dir", default=cache_dir_default, help="Cache directory path") + group.addoption( + "--lfnf", + "--last-failed-no-failures", + action="store", + dest="last_failed_no_failures", + choices=("all", "none"), + default="all", + help="With ``--lf``, determines whether to execute tests when there " + "are no previously (known) failures or when no " + "cached ``lastfailed`` data was found. " + "``all`` (the default) runs the full test suite again. " + "``none`` just emits a message about no known failures and exits successfully.", + ) + + +def pytest_cmdline_main(config: Config) -> int | ExitCode | None: + if config.option.cacheshow and not config.option.help: + from _pytest.main import wrap_session + + return wrap_session(config, cacheshow) + return None + + +@hookimpl(tryfirst=True) +def pytest_configure(config: Config) -> None: + config.cache = Cache.for_config(config, _ispytest=True) + config.pluginmanager.register(LFPlugin(config), "lfplugin") + config.pluginmanager.register(NFPlugin(config), "nfplugin") + + +@fixture +def cache(request: FixtureRequest) -> Cache: + """Return a cache object that can persist state between testing sessions. + + cache.get(key, default) + cache.set(key, value) + + Keys must be ``/`` separated strings, where the first part is usually the + name of your plugin or application to avoid clashes with other cache users. + + Values can be any object handled by the json stdlib module. + """ + assert request.config.cache is not None + return request.config.cache + + +def pytest_report_header(config: Config) -> str | None: + """Display cachedir with --cache-show and if non-default.""" + if config.option.verbose > 0 or config.getini("cache_dir") != ".pytest_cache": + assert config.cache is not None + cachedir = config.cache._cachedir + # TODO: evaluate generating upward relative paths + # starting with .., ../.. if sensible + + try: + displaypath = cachedir.relative_to(config.rootpath) + except ValueError: + displaypath = cachedir + return f"cachedir: {displaypath}" + return None + + +def cacheshow(config: Config, session: Session) -> int: + from pprint import pformat + + assert config.cache is not None + + tw = TerminalWriter() + tw.line("cachedir: " + str(config.cache._cachedir)) + if not config.cache._cachedir.is_dir(): + tw.line("cache is empty") + return 0 + + glob = config.option.cacheshow[0] + if glob is None: + glob = "*" + + dummy = object() + basedir = config.cache._cachedir + vdir = basedir / Cache._CACHE_PREFIX_VALUES + tw.sep("-", f"cache values for {glob!r}") + for valpath in sorted(x for x in vdir.rglob(glob) if x.is_file()): + key = str(valpath.relative_to(vdir)) + val = config.cache.get(key, dummy) + if val is dummy: + tw.line(f"{key} contains unreadable content, will be ignored") + else: + tw.line(f"{key} contains:") + for line in pformat(val).splitlines(): + tw.line(" " + line) + + ddir = basedir / Cache._CACHE_PREFIX_DIRS + if ddir.is_dir(): + contents = sorted(ddir.rglob(glob)) + tw.sep("-", f"cache directories for {glob!r}") + for p in contents: + # if p.is_dir(): + # print("%s/" % p.relative_to(basedir)) + if p.is_file(): + key = str(p.relative_to(basedir)) + tw.line(f"{key} is a file of length {p.stat().st_size:d}") + return 0 diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/capture.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/capture.py new file mode 100644 index 0000000..506c0b3 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/capture.py @@ -0,0 +1,1087 @@ +# mypy: allow-untyped-defs +"""Per-test stdout/stderr capturing mechanism.""" + +from __future__ import annotations + +import abc +import collections +import contextlib +import io +from io import UnsupportedOperation +import os +import sys +from tempfile import TemporaryFile +from types import TracebackType +from typing import Any +from typing import AnyStr +from typing import BinaryIO +from typing import Final +from typing import final +from typing import Generator +from typing import Generic +from typing import Iterable +from typing import Iterator +from typing import Literal +from typing import NamedTuple +from typing import TextIO +from typing import TYPE_CHECKING + + +if TYPE_CHECKING: + from typing_extensions import Self + +from _pytest.config import Config +from _pytest.config import hookimpl +from _pytest.config.argparsing import Parser +from _pytest.deprecated import check_ispytest +from _pytest.fixtures import fixture +from _pytest.fixtures import SubRequest +from _pytest.nodes import Collector +from _pytest.nodes import File +from _pytest.nodes import Item +from _pytest.reports import CollectReport + + +_CaptureMethod = Literal["fd", "sys", "no", "tee-sys"] + + +def pytest_addoption(parser: Parser) -> None: + group = parser.getgroup("general") + group._addoption( + "--capture", + action="store", + default="fd", + metavar="method", + choices=["fd", "sys", "no", "tee-sys"], + help="Per-test capturing method: one of fd|sys|no|tee-sys", + ) + group._addoption( + "-s", + action="store_const", + const="no", + dest="capture", + help="Shortcut for --capture=no", + ) + + +def _colorama_workaround() -> None: + """Ensure colorama is imported so that it attaches to the correct stdio + handles on Windows. + + colorama uses the terminal on import time. So if something does the + first import of colorama while I/O capture is active, colorama will + fail in various ways. + """ + if sys.platform.startswith("win32"): + try: + import colorama # noqa: F401 + except ImportError: + pass + + +def _windowsconsoleio_workaround(stream: TextIO) -> None: + """Workaround for Windows Unicode console handling. + + Python 3.6 implemented Unicode console handling for Windows. This works + by reading/writing to the raw console handle using + ``{Read,Write}ConsoleW``. + + The problem is that we are going to ``dup2`` over the stdio file + descriptors when doing ``FDCapture`` and this will ``CloseHandle`` the + handles used by Python to write to the console. Though there is still some + weirdness and the console handle seems to only be closed randomly and not + on the first call to ``CloseHandle``, or maybe it gets reopened with the + same handle value when we suspend capturing. + + The workaround in this case will reopen stdio with a different fd which + also means a different handle by replicating the logic in + "Py_lifecycle.c:initstdio/create_stdio". + + :param stream: + In practice ``sys.stdout`` or ``sys.stderr``, but given + here as parameter for unittesting purposes. + + See https://github.com/pytest-dev/py/issues/103. + """ + if not sys.platform.startswith("win32") or hasattr(sys, "pypy_version_info"): + return + + # Bail out if ``stream`` doesn't seem like a proper ``io`` stream (#2666). + if not hasattr(stream, "buffer"): # type: ignore[unreachable,unused-ignore] + return + + raw_stdout = stream.buffer.raw if hasattr(stream.buffer, "raw") else stream.buffer + + if not isinstance(raw_stdout, io._WindowsConsoleIO): # type: ignore[attr-defined,unused-ignore] + return + + def _reopen_stdio(f, mode): + if not hasattr(stream.buffer, "raw") and mode[0] == "w": + buffering = 0 + else: + buffering = -1 + + return io.TextIOWrapper( + open(os.dup(f.fileno()), mode, buffering), + f.encoding, + f.errors, + f.newlines, + f.line_buffering, + ) + + sys.stdin = _reopen_stdio(sys.stdin, "rb") + sys.stdout = _reopen_stdio(sys.stdout, "wb") + sys.stderr = _reopen_stdio(sys.stderr, "wb") + + +@hookimpl(wrapper=True) +def pytest_load_initial_conftests(early_config: Config) -> Generator[None]: + ns = early_config.known_args_namespace + if ns.capture == "fd": + _windowsconsoleio_workaround(sys.stdout) + _colorama_workaround() + pluginmanager = early_config.pluginmanager + capman = CaptureManager(ns.capture) + pluginmanager.register(capman, "capturemanager") + + # Make sure that capturemanager is properly reset at final shutdown. + early_config.add_cleanup(capman.stop_global_capturing) + + # Finally trigger conftest loading but while capturing (issue #93). + capman.start_global_capturing() + try: + try: + yield + finally: + capman.suspend_global_capture() + except BaseException: + out, err = capman.read_global_capture() + sys.stdout.write(out) + sys.stderr.write(err) + raise + + +# IO Helpers. + + +class EncodedFile(io.TextIOWrapper): + __slots__ = () + + @property + def name(self) -> str: + # Ensure that file.name is a string. Workaround for a Python bug + # fixed in >=3.7.4: https://bugs.python.org/issue36015 + return repr(self.buffer) + + @property + def mode(self) -> str: + # TextIOWrapper doesn't expose a mode, but at least some of our + # tests check it. + return self.buffer.mode.replace("b", "") + + +class CaptureIO(io.TextIOWrapper): + def __init__(self) -> None: + super().__init__(io.BytesIO(), encoding="UTF-8", newline="", write_through=True) + + def getvalue(self) -> str: + assert isinstance(self.buffer, io.BytesIO) + return self.buffer.getvalue().decode("UTF-8") + + +class TeeCaptureIO(CaptureIO): + def __init__(self, other: TextIO) -> None: + self._other = other + super().__init__() + + def write(self, s: str) -> int: + super().write(s) + return self._other.write(s) + + +class DontReadFromInput(TextIO): + @property + def encoding(self) -> str: + assert sys.__stdin__ is not None + return sys.__stdin__.encoding + + def read(self, size: int = -1) -> str: + raise OSError( + "pytest: reading from stdin while output is captured! Consider using `-s`." + ) + + readline = read + + def __next__(self) -> str: + return self.readline() + + def readlines(self, hint: int | None = -1) -> list[str]: + raise OSError( + "pytest: reading from stdin while output is captured! Consider using `-s`." + ) + + def __iter__(self) -> Iterator[str]: + return self + + def fileno(self) -> int: + raise UnsupportedOperation("redirected stdin is pseudofile, has no fileno()") + + def flush(self) -> None: + raise UnsupportedOperation("redirected stdin is pseudofile, has no flush()") + + def isatty(self) -> bool: + return False + + def close(self) -> None: + pass + + def readable(self) -> bool: + return False + + def seek(self, offset: int, whence: int = 0) -> int: + raise UnsupportedOperation("redirected stdin is pseudofile, has no seek(int)") + + def seekable(self) -> bool: + return False + + def tell(self) -> int: + raise UnsupportedOperation("redirected stdin is pseudofile, has no tell()") + + def truncate(self, size: int | None = None) -> int: + raise UnsupportedOperation("cannot truncate stdin") + + def write(self, data: str) -> int: + raise UnsupportedOperation("cannot write to stdin") + + def writelines(self, lines: Iterable[str]) -> None: + raise UnsupportedOperation("Cannot write to stdin") + + def writable(self) -> bool: + return False + + def __enter__(self) -> Self: + return self + + def __exit__( + self, + type: type[BaseException] | None, + value: BaseException | None, + traceback: TracebackType | None, + ) -> None: + pass + + @property + def buffer(self) -> BinaryIO: + # The str/bytes doesn't actually matter in this type, so OK to fake. + return self # type: ignore[return-value] + + +# Capture classes. + + +class CaptureBase(abc.ABC, Generic[AnyStr]): + EMPTY_BUFFER: AnyStr + + @abc.abstractmethod + def __init__(self, fd: int) -> None: + raise NotImplementedError() + + @abc.abstractmethod + def start(self) -> None: + raise NotImplementedError() + + @abc.abstractmethod + def done(self) -> None: + raise NotImplementedError() + + @abc.abstractmethod + def suspend(self) -> None: + raise NotImplementedError() + + @abc.abstractmethod + def resume(self) -> None: + raise NotImplementedError() + + @abc.abstractmethod + def writeorg(self, data: AnyStr) -> None: + raise NotImplementedError() + + @abc.abstractmethod + def snap(self) -> AnyStr: + raise NotImplementedError() + + +patchsysdict = {0: "stdin", 1: "stdout", 2: "stderr"} + + +class NoCapture(CaptureBase[str]): + EMPTY_BUFFER = "" + + def __init__(self, fd: int) -> None: + pass + + def start(self) -> None: + pass + + def done(self) -> None: + pass + + def suspend(self) -> None: + pass + + def resume(self) -> None: + pass + + def snap(self) -> str: + return "" + + def writeorg(self, data: str) -> None: + pass + + +class SysCaptureBase(CaptureBase[AnyStr]): + def __init__( + self, fd: int, tmpfile: TextIO | None = None, *, tee: bool = False + ) -> None: + name = patchsysdict[fd] + self._old: TextIO = getattr(sys, name) + self.name = name + if tmpfile is None: + if name == "stdin": + tmpfile = DontReadFromInput() + else: + tmpfile = CaptureIO() if not tee else TeeCaptureIO(self._old) + self.tmpfile = tmpfile + self._state = "initialized" + + def repr(self, class_name: str) -> str: + return "<{} {} _old={} _state={!r} tmpfile={!r}>".format( + class_name, + self.name, + hasattr(self, "_old") and repr(self._old) or "", + self._state, + self.tmpfile, + ) + + def __repr__(self) -> str: + return "<{} {} _old={} _state={!r} tmpfile={!r}>".format( + self.__class__.__name__, + self.name, + hasattr(self, "_old") and repr(self._old) or "", + self._state, + self.tmpfile, + ) + + def _assert_state(self, op: str, states: tuple[str, ...]) -> None: + assert ( + self._state in states + ), "cannot {} in state {!r}: expected one of {}".format( + op, self._state, ", ".join(states) + ) + + def start(self) -> None: + self._assert_state("start", ("initialized",)) + setattr(sys, self.name, self.tmpfile) + self._state = "started" + + def done(self) -> None: + self._assert_state("done", ("initialized", "started", "suspended", "done")) + if self._state == "done": + return + setattr(sys, self.name, self._old) + del self._old + self.tmpfile.close() + self._state = "done" + + def suspend(self) -> None: + self._assert_state("suspend", ("started", "suspended")) + setattr(sys, self.name, self._old) + self._state = "suspended" + + def resume(self) -> None: + self._assert_state("resume", ("started", "suspended")) + if self._state == "started": + return + setattr(sys, self.name, self.tmpfile) + self._state = "started" + + +class SysCaptureBinary(SysCaptureBase[bytes]): + EMPTY_BUFFER = b"" + + def snap(self) -> bytes: + self._assert_state("snap", ("started", "suspended")) + self.tmpfile.seek(0) + res = self.tmpfile.buffer.read() + self.tmpfile.seek(0) + self.tmpfile.truncate() + return res + + def writeorg(self, data: bytes) -> None: + self._assert_state("writeorg", ("started", "suspended")) + self._old.flush() + self._old.buffer.write(data) + self._old.buffer.flush() + + +class SysCapture(SysCaptureBase[str]): + EMPTY_BUFFER = "" + + def snap(self) -> str: + self._assert_state("snap", ("started", "suspended")) + assert isinstance(self.tmpfile, CaptureIO) + res = self.tmpfile.getvalue() + self.tmpfile.seek(0) + self.tmpfile.truncate() + return res + + def writeorg(self, data: str) -> None: + self._assert_state("writeorg", ("started", "suspended")) + self._old.write(data) + self._old.flush() + + +class FDCaptureBase(CaptureBase[AnyStr]): + def __init__(self, targetfd: int) -> None: + self.targetfd = targetfd + + try: + os.fstat(targetfd) + except OSError: + # FD capturing is conceptually simple -- create a temporary file, + # redirect the FD to it, redirect back when done. But when the + # target FD is invalid it throws a wrench into this lovely scheme. + # + # Tests themselves shouldn't care if the FD is valid, FD capturing + # should work regardless of external circumstances. So falling back + # to just sys capturing is not a good option. + # + # Further complications are the need to support suspend() and the + # possibility of FD reuse (e.g. the tmpfile getting the very same + # target FD). The following approach is robust, I believe. + self.targetfd_invalid: int | None = os.open(os.devnull, os.O_RDWR) + os.dup2(self.targetfd_invalid, targetfd) + else: + self.targetfd_invalid = None + self.targetfd_save = os.dup(targetfd) + + if targetfd == 0: + self.tmpfile = open(os.devnull, encoding="utf-8") + self.syscapture: CaptureBase[str] = SysCapture(targetfd) + else: + self.tmpfile = EncodedFile( + TemporaryFile(buffering=0), + encoding="utf-8", + errors="replace", + newline="", + write_through=True, + ) + if targetfd in patchsysdict: + self.syscapture = SysCapture(targetfd, self.tmpfile) + else: + self.syscapture = NoCapture(targetfd) + + self._state = "initialized" + + def __repr__(self) -> str: + return ( + f"<{self.__class__.__name__} {self.targetfd} oldfd={self.targetfd_save} " + f"_state={self._state!r} tmpfile={self.tmpfile!r}>" + ) + + def _assert_state(self, op: str, states: tuple[str, ...]) -> None: + assert ( + self._state in states + ), "cannot {} in state {!r}: expected one of {}".format( + op, self._state, ", ".join(states) + ) + + def start(self) -> None: + """Start capturing on targetfd using memorized tmpfile.""" + self._assert_state("start", ("initialized",)) + os.dup2(self.tmpfile.fileno(), self.targetfd) + self.syscapture.start() + self._state = "started" + + def done(self) -> None: + """Stop capturing, restore streams, return original capture file, + seeked to position zero.""" + self._assert_state("done", ("initialized", "started", "suspended", "done")) + if self._state == "done": + return + os.dup2(self.targetfd_save, self.targetfd) + os.close(self.targetfd_save) + if self.targetfd_invalid is not None: + if self.targetfd_invalid != self.targetfd: + os.close(self.targetfd) + os.close(self.targetfd_invalid) + self.syscapture.done() + self.tmpfile.close() + self._state = "done" + + def suspend(self) -> None: + self._assert_state("suspend", ("started", "suspended")) + if self._state == "suspended": + return + self.syscapture.suspend() + os.dup2(self.targetfd_save, self.targetfd) + self._state = "suspended" + + def resume(self) -> None: + self._assert_state("resume", ("started", "suspended")) + if self._state == "started": + return + self.syscapture.resume() + os.dup2(self.tmpfile.fileno(), self.targetfd) + self._state = "started" + + +class FDCaptureBinary(FDCaptureBase[bytes]): + """Capture IO to/from a given OS-level file descriptor. + + snap() produces `bytes`. + """ + + EMPTY_BUFFER = b"" + + def snap(self) -> bytes: + self._assert_state("snap", ("started", "suspended")) + self.tmpfile.seek(0) + res = self.tmpfile.buffer.read() + self.tmpfile.seek(0) + self.tmpfile.truncate() + return res + + def writeorg(self, data: bytes) -> None: + """Write to original file descriptor.""" + self._assert_state("writeorg", ("started", "suspended")) + os.write(self.targetfd_save, data) + + +class FDCapture(FDCaptureBase[str]): + """Capture IO to/from a given OS-level file descriptor. + + snap() produces text. + """ + + EMPTY_BUFFER = "" + + def snap(self) -> str: + self._assert_state("snap", ("started", "suspended")) + self.tmpfile.seek(0) + res = self.tmpfile.read() + self.tmpfile.seek(0) + self.tmpfile.truncate() + return res + + def writeorg(self, data: str) -> None: + """Write to original file descriptor.""" + self._assert_state("writeorg", ("started", "suspended")) + # XXX use encoding of original stream + os.write(self.targetfd_save, data.encode("utf-8")) + + +# MultiCapture + + +# Generic NamedTuple only supported since Python 3.11. +if sys.version_info >= (3, 11) or TYPE_CHECKING: + + @final + class CaptureResult(NamedTuple, Generic[AnyStr]): + """The result of :method:`caplog.readouterr() `.""" + + out: AnyStr + err: AnyStr + +else: + + class CaptureResult( + collections.namedtuple("CaptureResult", ["out", "err"]), # noqa: PYI024 + Generic[AnyStr], + ): + """The result of :method:`caplog.readouterr() `.""" + + __slots__ = () + + +class MultiCapture(Generic[AnyStr]): + _state = None + _in_suspended = False + + def __init__( + self, + in_: CaptureBase[AnyStr] | None, + out: CaptureBase[AnyStr] | None, + err: CaptureBase[AnyStr] | None, + ) -> None: + self.in_: CaptureBase[AnyStr] | None = in_ + self.out: CaptureBase[AnyStr] | None = out + self.err: CaptureBase[AnyStr] | None = err + + def __repr__(self) -> str: + return ( + f"" + ) + + def start_capturing(self) -> None: + self._state = "started" + if self.in_: + self.in_.start() + if self.out: + self.out.start() + if self.err: + self.err.start() + + def pop_outerr_to_orig(self) -> tuple[AnyStr, AnyStr]: + """Pop current snapshot out/err capture and flush to orig streams.""" + out, err = self.readouterr() + if out: + assert self.out is not None + self.out.writeorg(out) + if err: + assert self.err is not None + self.err.writeorg(err) + return out, err + + def suspend_capturing(self, in_: bool = False) -> None: + self._state = "suspended" + if self.out: + self.out.suspend() + if self.err: + self.err.suspend() + if in_ and self.in_: + self.in_.suspend() + self._in_suspended = True + + def resume_capturing(self) -> None: + self._state = "started" + if self.out: + self.out.resume() + if self.err: + self.err.resume() + if self._in_suspended: + assert self.in_ is not None + self.in_.resume() + self._in_suspended = False + + def stop_capturing(self) -> None: + """Stop capturing and reset capturing streams.""" + if self._state == "stopped": + raise ValueError("was already stopped") + self._state = "stopped" + if self.out: + self.out.done() + if self.err: + self.err.done() + if self.in_: + self.in_.done() + + def is_started(self) -> bool: + """Whether actively capturing -- not suspended or stopped.""" + return self._state == "started" + + def readouterr(self) -> CaptureResult[AnyStr]: + out = self.out.snap() if self.out else "" + err = self.err.snap() if self.err else "" + # TODO: This type error is real, need to fix. + return CaptureResult(out, err) # type: ignore[arg-type] + + +def _get_multicapture(method: _CaptureMethod) -> MultiCapture[str]: + if method == "fd": + return MultiCapture(in_=FDCapture(0), out=FDCapture(1), err=FDCapture(2)) + elif method == "sys": + return MultiCapture(in_=SysCapture(0), out=SysCapture(1), err=SysCapture(2)) + elif method == "no": + return MultiCapture(in_=None, out=None, err=None) + elif method == "tee-sys": + return MultiCapture( + in_=None, out=SysCapture(1, tee=True), err=SysCapture(2, tee=True) + ) + raise ValueError(f"unknown capturing method: {method!r}") + + +# CaptureManager and CaptureFixture + + +class CaptureManager: + """The capture plugin. + + Manages that the appropriate capture method is enabled/disabled during + collection and each test phase (setup, call, teardown). After each of + those points, the captured output is obtained and attached to the + collection/runtest report. + + There are two levels of capture: + + * global: enabled by default and can be suppressed by the ``-s`` + option. This is always enabled/disabled during collection and each test + phase. + + * fixture: when a test function or one of its fixture depend on the + ``capsys`` or ``capfd`` fixtures. In this case special handling is + needed to ensure the fixtures take precedence over the global capture. + """ + + def __init__(self, method: _CaptureMethod) -> None: + self._method: Final = method + self._global_capturing: MultiCapture[str] | None = None + self._capture_fixture: CaptureFixture[Any] | None = None + + def __repr__(self) -> str: + return ( + f"" + ) + + def is_capturing(self) -> str | bool: + if self.is_globally_capturing(): + return "global" + if self._capture_fixture: + return f"fixture {self._capture_fixture.request.fixturename}" + return False + + # Global capturing control + + def is_globally_capturing(self) -> bool: + return self._method != "no" + + def start_global_capturing(self) -> None: + assert self._global_capturing is None + self._global_capturing = _get_multicapture(self._method) + self._global_capturing.start_capturing() + + def stop_global_capturing(self) -> None: + if self._global_capturing is not None: + self._global_capturing.pop_outerr_to_orig() + self._global_capturing.stop_capturing() + self._global_capturing = None + + def resume_global_capture(self) -> None: + # During teardown of the python process, and on rare occasions, capture + # attributes can be `None` while trying to resume global capture. + if self._global_capturing is not None: + self._global_capturing.resume_capturing() + + def suspend_global_capture(self, in_: bool = False) -> None: + if self._global_capturing is not None: + self._global_capturing.suspend_capturing(in_=in_) + + def suspend(self, in_: bool = False) -> None: + # Need to undo local capsys-et-al if it exists before disabling global capture. + self.suspend_fixture() + self.suspend_global_capture(in_) + + def resume(self) -> None: + self.resume_global_capture() + self.resume_fixture() + + def read_global_capture(self) -> CaptureResult[str]: + assert self._global_capturing is not None + return self._global_capturing.readouterr() + + # Fixture Control + + def set_fixture(self, capture_fixture: CaptureFixture[Any]) -> None: + if self._capture_fixture: + current_fixture = self._capture_fixture.request.fixturename + requested_fixture = capture_fixture.request.fixturename + capture_fixture.request.raiseerror( + f"cannot use {requested_fixture} and {current_fixture} at the same time" + ) + self._capture_fixture = capture_fixture + + def unset_fixture(self) -> None: + self._capture_fixture = None + + def activate_fixture(self) -> None: + """If the current item is using ``capsys`` or ``capfd``, activate + them so they take precedence over the global capture.""" + if self._capture_fixture: + self._capture_fixture._start() + + def deactivate_fixture(self) -> None: + """Deactivate the ``capsys`` or ``capfd`` fixture of this item, if any.""" + if self._capture_fixture: + self._capture_fixture.close() + + def suspend_fixture(self) -> None: + if self._capture_fixture: + self._capture_fixture._suspend() + + def resume_fixture(self) -> None: + if self._capture_fixture: + self._capture_fixture._resume() + + # Helper context managers + + @contextlib.contextmanager + def global_and_fixture_disabled(self) -> Generator[None]: + """Context manager to temporarily disable global and current fixture capturing.""" + do_fixture = self._capture_fixture and self._capture_fixture._is_started() + if do_fixture: + self.suspend_fixture() + do_global = self._global_capturing and self._global_capturing.is_started() + if do_global: + self.suspend_global_capture() + try: + yield + finally: + if do_global: + self.resume_global_capture() + if do_fixture: + self.resume_fixture() + + @contextlib.contextmanager + def item_capture(self, when: str, item: Item) -> Generator[None]: + self.resume_global_capture() + self.activate_fixture() + try: + yield + finally: + self.deactivate_fixture() + self.suspend_global_capture(in_=False) + + out, err = self.read_global_capture() + item.add_report_section(when, "stdout", out) + item.add_report_section(when, "stderr", err) + + # Hooks + + @hookimpl(wrapper=True) + def pytest_make_collect_report( + self, collector: Collector + ) -> Generator[None, CollectReport, CollectReport]: + if isinstance(collector, File): + self.resume_global_capture() + try: + rep = yield + finally: + self.suspend_global_capture() + out, err = self.read_global_capture() + if out: + rep.sections.append(("Captured stdout", out)) + if err: + rep.sections.append(("Captured stderr", err)) + else: + rep = yield + return rep + + @hookimpl(wrapper=True) + def pytest_runtest_setup(self, item: Item) -> Generator[None]: + with self.item_capture("setup", item): + return (yield) + + @hookimpl(wrapper=True) + def pytest_runtest_call(self, item: Item) -> Generator[None]: + with self.item_capture("call", item): + return (yield) + + @hookimpl(wrapper=True) + def pytest_runtest_teardown(self, item: Item) -> Generator[None]: + with self.item_capture("teardown", item): + return (yield) + + @hookimpl(tryfirst=True) + def pytest_keyboard_interrupt(self) -> None: + self.stop_global_capturing() + + @hookimpl(tryfirst=True) + def pytest_internalerror(self) -> None: + self.stop_global_capturing() + + +class CaptureFixture(Generic[AnyStr]): + """Object returned by the :fixture:`capsys`, :fixture:`capsysbinary`, + :fixture:`capfd` and :fixture:`capfdbinary` fixtures.""" + + def __init__( + self, + captureclass: type[CaptureBase[AnyStr]], + request: SubRequest, + *, + _ispytest: bool = False, + ) -> None: + check_ispytest(_ispytest) + self.captureclass: type[CaptureBase[AnyStr]] = captureclass + self.request = request + self._capture: MultiCapture[AnyStr] | None = None + self._captured_out: AnyStr = self.captureclass.EMPTY_BUFFER + self._captured_err: AnyStr = self.captureclass.EMPTY_BUFFER + + def _start(self) -> None: + if self._capture is None: + self._capture = MultiCapture( + in_=None, + out=self.captureclass(1), + err=self.captureclass(2), + ) + self._capture.start_capturing() + + def close(self) -> None: + if self._capture is not None: + out, err = self._capture.pop_outerr_to_orig() + self._captured_out += out + self._captured_err += err + self._capture.stop_capturing() + self._capture = None + + def readouterr(self) -> CaptureResult[AnyStr]: + """Read and return the captured output so far, resetting the internal + buffer. + + :returns: + The captured content as a namedtuple with ``out`` and ``err`` + string attributes. + """ + captured_out, captured_err = self._captured_out, self._captured_err + if self._capture is not None: + out, err = self._capture.readouterr() + captured_out += out + captured_err += err + self._captured_out = self.captureclass.EMPTY_BUFFER + self._captured_err = self.captureclass.EMPTY_BUFFER + return CaptureResult(captured_out, captured_err) + + def _suspend(self) -> None: + """Suspend this fixture's own capturing temporarily.""" + if self._capture is not None: + self._capture.suspend_capturing() + + def _resume(self) -> None: + """Resume this fixture's own capturing temporarily.""" + if self._capture is not None: + self._capture.resume_capturing() + + def _is_started(self) -> bool: + """Whether actively capturing -- not disabled or closed.""" + if self._capture is not None: + return self._capture.is_started() + return False + + @contextlib.contextmanager + def disabled(self) -> Generator[None]: + """Temporarily disable capturing while inside the ``with`` block.""" + capmanager: CaptureManager = self.request.config.pluginmanager.getplugin( + "capturemanager" + ) + with capmanager.global_and_fixture_disabled(): + yield + + +# The fixtures. + + +@fixture +def capsys(request: SubRequest) -> Generator[CaptureFixture[str]]: + r"""Enable text capturing of writes to ``sys.stdout`` and ``sys.stderr``. + + The captured output is made available via ``capsys.readouterr()`` method + calls, which return a ``(out, err)`` namedtuple. + ``out`` and ``err`` will be ``text`` objects. + + Returns an instance of :class:`CaptureFixture[str] `. + + Example: + + .. code-block:: python + + def test_output(capsys): + print("hello") + captured = capsys.readouterr() + assert captured.out == "hello\n" + """ + capman: CaptureManager = request.config.pluginmanager.getplugin("capturemanager") + capture_fixture = CaptureFixture(SysCapture, request, _ispytest=True) + capman.set_fixture(capture_fixture) + capture_fixture._start() + yield capture_fixture + capture_fixture.close() + capman.unset_fixture() + + +@fixture +def capsysbinary(request: SubRequest) -> Generator[CaptureFixture[bytes]]: + r"""Enable bytes capturing of writes to ``sys.stdout`` and ``sys.stderr``. + + The captured output is made available via ``capsysbinary.readouterr()`` + method calls, which return a ``(out, err)`` namedtuple. + ``out`` and ``err`` will be ``bytes`` objects. + + Returns an instance of :class:`CaptureFixture[bytes] `. + + Example: + + .. code-block:: python + + def test_output(capsysbinary): + print("hello") + captured = capsysbinary.readouterr() + assert captured.out == b"hello\n" + """ + capman: CaptureManager = request.config.pluginmanager.getplugin("capturemanager") + capture_fixture = CaptureFixture(SysCaptureBinary, request, _ispytest=True) + capman.set_fixture(capture_fixture) + capture_fixture._start() + yield capture_fixture + capture_fixture.close() + capman.unset_fixture() + + +@fixture +def capfd(request: SubRequest) -> Generator[CaptureFixture[str]]: + r"""Enable text capturing of writes to file descriptors ``1`` and ``2``. + + The captured output is made available via ``capfd.readouterr()`` method + calls, which return a ``(out, err)`` namedtuple. + ``out`` and ``err`` will be ``text`` objects. + + Returns an instance of :class:`CaptureFixture[str] `. + + Example: + + .. code-block:: python + + def test_system_echo(capfd): + os.system('echo "hello"') + captured = capfd.readouterr() + assert captured.out == "hello\n" + """ + capman: CaptureManager = request.config.pluginmanager.getplugin("capturemanager") + capture_fixture = CaptureFixture(FDCapture, request, _ispytest=True) + capman.set_fixture(capture_fixture) + capture_fixture._start() + yield capture_fixture + capture_fixture.close() + capman.unset_fixture() + + +@fixture +def capfdbinary(request: SubRequest) -> Generator[CaptureFixture[bytes]]: + r"""Enable bytes capturing of writes to file descriptors ``1`` and ``2``. + + The captured output is made available via ``capfd.readouterr()`` method + calls, which return a ``(out, err)`` namedtuple. + ``out`` and ``err`` will be ``byte`` objects. + + Returns an instance of :class:`CaptureFixture[bytes] `. + + Example: + + .. code-block:: python + + def test_system_echo(capfdbinary): + os.system('echo "hello"') + captured = capfdbinary.readouterr() + assert captured.out == b"hello\n" + + """ + capman: CaptureManager = request.config.pluginmanager.getplugin("capturemanager") + capture_fixture = CaptureFixture(FDCaptureBinary, request, _ispytest=True) + capman.set_fixture(capture_fixture) + capture_fixture._start() + yield capture_fixture + capture_fixture.close() + capman.unset_fixture() diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/compat.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/compat.py new file mode 100644 index 0000000..614848e --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/compat.py @@ -0,0 +1,351 @@ +# mypy: allow-untyped-defs +"""Python version compatibility code.""" + +from __future__ import annotations + +import dataclasses +import enum +import functools +import inspect +from inspect import Parameter +from inspect import signature +import os +from pathlib import Path +import sys +from typing import Any +from typing import Callable +from typing import Final +from typing import NoReturn + +import py + + +#: constant to prepare valuing pylib path replacements/lazy proxies later on +# intended for removal in pytest 8.0 or 9.0 + +# fmt: off +# intentional space to create a fake difference for the verification +LEGACY_PATH = py.path. local +# fmt: on + + +def legacy_path(path: str | os.PathLike[str]) -> LEGACY_PATH: + """Internal wrapper to prepare lazy proxies for legacy_path instances""" + return LEGACY_PATH(path) + + +# fmt: off +# Singleton type for NOTSET, as described in: +# https://www.python.org/dev/peps/pep-0484/#support-for-singleton-types-in-unions +class NotSetType(enum.Enum): + token = 0 +NOTSET: Final = NotSetType.token +# fmt: on + + +def is_generator(func: object) -> bool: + genfunc = inspect.isgeneratorfunction(func) + return genfunc and not iscoroutinefunction(func) + + +def iscoroutinefunction(func: object) -> bool: + """Return True if func is a coroutine function (a function defined with async + def syntax, and doesn't contain yield), or a function decorated with + @asyncio.coroutine. + + Note: copied and modified from Python 3.5's builtin coroutines.py to avoid + importing asyncio directly, which in turns also initializes the "logging" + module as a side-effect (see issue #8). + """ + return inspect.iscoroutinefunction(func) or getattr(func, "_is_coroutine", False) + + +def is_async_function(func: object) -> bool: + """Return True if the given function seems to be an async function or + an async generator.""" + return iscoroutinefunction(func) or inspect.isasyncgenfunction(func) + + +def getlocation(function, curdir: str | os.PathLike[str] | None = None) -> str: + function = get_real_func(function) + fn = Path(inspect.getfile(function)) + lineno = function.__code__.co_firstlineno + if curdir is not None: + try: + relfn = fn.relative_to(curdir) + except ValueError: + pass + else: + return "%s:%d" % (relfn, lineno + 1) + return "%s:%d" % (fn, lineno + 1) + + +def num_mock_patch_args(function) -> int: + """Return number of arguments used up by mock arguments (if any).""" + patchings = getattr(function, "patchings", None) + if not patchings: + return 0 + + mock_sentinel = getattr(sys.modules.get("mock"), "DEFAULT", object()) + ut_mock_sentinel = getattr(sys.modules.get("unittest.mock"), "DEFAULT", object()) + + return len( + [ + p + for p in patchings + if not p.attribute_name + and (p.new is mock_sentinel or p.new is ut_mock_sentinel) + ] + ) + + +def getfuncargnames( + function: Callable[..., object], + *, + name: str = "", + cls: type | None = None, +) -> tuple[str, ...]: + """Return the names of a function's mandatory arguments. + + Should return the names of all function arguments that: + * Aren't bound to an instance or type as in instance or class methods. + * Don't have default values. + * Aren't bound with functools.partial. + * Aren't replaced with mocks. + + The cls arguments indicate that the function should be treated as a bound + method even though it's not unless the function is a static method. + + The name parameter should be the original name in which the function was collected. + """ + # TODO(RonnyPfannschmidt): This function should be refactored when we + # revisit fixtures. The fixture mechanism should ask the node for + # the fixture names, and not try to obtain directly from the + # function object well after collection has occurred. + + # The parameters attribute of a Signature object contains an + # ordered mapping of parameter names to Parameter instances. This + # creates a tuple of the names of the parameters that don't have + # defaults. + try: + parameters = signature(function).parameters + except (ValueError, TypeError) as e: + from _pytest.outcomes import fail + + fail( + f"Could not determine arguments of {function!r}: {e}", + pytrace=False, + ) + + arg_names = tuple( + p.name + for p in parameters.values() + if ( + p.kind is Parameter.POSITIONAL_OR_KEYWORD + or p.kind is Parameter.KEYWORD_ONLY + ) + and p.default is Parameter.empty + ) + if not name: + name = function.__name__ + + # If this function should be treated as a bound method even though + # it's passed as an unbound method or function, remove the first + # parameter name. + if ( + # Not using `getattr` because we don't want to resolve the staticmethod. + # Not using `cls.__dict__` because we want to check the entire MRO. + cls + and not isinstance( + inspect.getattr_static(cls, name, default=None), staticmethod + ) + ): + arg_names = arg_names[1:] + # Remove any names that will be replaced with mocks. + if hasattr(function, "__wrapped__"): + arg_names = arg_names[num_mock_patch_args(function) :] + return arg_names + + +def get_default_arg_names(function: Callable[..., Any]) -> tuple[str, ...]: + # Note: this code intentionally mirrors the code at the beginning of + # getfuncargnames, to get the arguments which were excluded from its result + # because they had default values. + return tuple( + p.name + for p in signature(function).parameters.values() + if p.kind in (Parameter.POSITIONAL_OR_KEYWORD, Parameter.KEYWORD_ONLY) + and p.default is not Parameter.empty + ) + + +_non_printable_ascii_translate_table = { + i: f"\\x{i:02x}" for i in range(128) if i not in range(32, 127) +} +_non_printable_ascii_translate_table.update( + {ord("\t"): "\\t", ord("\r"): "\\r", ord("\n"): "\\n"} +) + + +def ascii_escaped(val: bytes | str) -> str: + r"""If val is pure ASCII, return it as an str, otherwise, escape + bytes objects into a sequence of escaped bytes: + + b'\xc3\xb4\xc5\xd6' -> r'\xc3\xb4\xc5\xd6' + + and escapes strings into a sequence of escaped unicode ids, e.g.: + + r'4\nV\U00043efa\x0eMXWB\x1e\u3028\u15fd\xcd\U0007d944' + + Note: + The obvious "v.decode('unicode-escape')" will return + valid UTF-8 unicode if it finds them in bytes, but we + want to return escaped bytes for any byte, even if they match + a UTF-8 string. + """ + if isinstance(val, bytes): + ret = val.decode("ascii", "backslashreplace") + else: + ret = val.encode("unicode_escape").decode("ascii") + return ret.translate(_non_printable_ascii_translate_table) + + +@dataclasses.dataclass +class _PytestWrapper: + """Dummy wrapper around a function object for internal use only. + + Used to correctly unwrap the underlying function object when we are + creating fixtures, because we wrap the function object ourselves with a + decorator to issue warnings when the fixture function is called directly. + """ + + obj: Any + + +def get_real_func(obj): + """Get the real function object of the (possibly) wrapped object by + functools.wraps or functools.partial.""" + start_obj = obj + for i in range(100): + # __pytest_wrapped__ is set by @pytest.fixture when wrapping the fixture function + # to trigger a warning if it gets called directly instead of by pytest: we don't + # want to unwrap further than this otherwise we lose useful wrappings like @mock.patch (#3774) + new_obj = getattr(obj, "__pytest_wrapped__", None) + if isinstance(new_obj, _PytestWrapper): + obj = new_obj.obj + break + new_obj = getattr(obj, "__wrapped__", None) + if new_obj is None: + break + obj = new_obj + else: + from _pytest._io.saferepr import saferepr + + raise ValueError( + f"could not find real function of {saferepr(start_obj)}\nstopped at {saferepr(obj)}" + ) + if isinstance(obj, functools.partial): + obj = obj.func + return obj + + +def get_real_method(obj, holder): + """Attempt to obtain the real function object that might be wrapping + ``obj``, while at the same time returning a bound method to ``holder`` if + the original object was a bound method.""" + try: + is_method = hasattr(obj, "__func__") + obj = get_real_func(obj) + except Exception: # pragma: no cover + return obj + if is_method and hasattr(obj, "__get__") and callable(obj.__get__): + obj = obj.__get__(holder) + return obj + + +def getimfunc(func): + try: + return func.__func__ + except AttributeError: + return func + + +def safe_getattr(object: Any, name: str, default: Any) -> Any: + """Like getattr but return default upon any Exception or any OutcomeException. + + Attribute access can potentially fail for 'evil' Python objects. + See issue #214. + It catches OutcomeException because of #2490 (issue #580), new outcomes + are derived from BaseException instead of Exception (for more details + check #2707). + """ + from _pytest.outcomes import TEST_OUTCOME + + try: + return getattr(object, name, default) + except TEST_OUTCOME: + return default + + +def safe_isclass(obj: object) -> bool: + """Ignore any exception via isinstance on Python 3.""" + try: + return inspect.isclass(obj) + except Exception: + return False + + +def get_user_id() -> int | None: + """Return the current process's real user id or None if it could not be + determined. + + :return: The user id or None if it could not be determined. + """ + # mypy follows the version and platform checking expectation of PEP 484: + # https://mypy.readthedocs.io/en/stable/common_issues.html?highlight=platform#python-version-and-system-platform-checks + # Containment checks are too complex for mypy v1.5.0 and cause failure. + if sys.platform == "win32" or sys.platform == "emscripten": + # win32 does not have a getuid() function. + # Emscripten has a return 0 stub. + return None + else: + # On other platforms, a return value of -1 is assumed to indicate that + # the current process's real user id could not be determined. + ERROR = -1 + uid = os.getuid() + return uid if uid != ERROR else None + + +# Perform exhaustiveness checking. +# +# Consider this example: +# +# MyUnion = Union[int, str] +# +# def handle(x: MyUnion) -> int { +# if isinstance(x, int): +# return 1 +# elif isinstance(x, str): +# return 2 +# else: +# raise Exception('unreachable') +# +# Now suppose we add a new variant: +# +# MyUnion = Union[int, str, bytes] +# +# After doing this, we must remember ourselves to go and update the handle +# function to handle the new variant. +# +# With `assert_never` we can do better: +# +# // raise Exception('unreachable') +# return assert_never(x) +# +# Now, if we forget to handle the new variant, the type-checker will emit a +# compile-time error, instead of the runtime error we would have gotten +# previously. +# +# This also work for Enums (if you use `is` to compare) and Literals. +def assert_never(value: NoReturn) -> NoReturn: + assert False, f"Unhandled value: {value} ({type(value).__name__})" diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/config/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/config/__init__.py new file mode 100644 index 0000000..3cca147 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/config/__init__.py @@ -0,0 +1,1972 @@ +# mypy: allow-untyped-defs +"""Command line options, ini-file and conftest.py processing.""" + +from __future__ import annotations + +import argparse +import collections.abc +import copy +import dataclasses +import enum +from functools import lru_cache +import glob +import importlib.metadata +import inspect +import os +import pathlib +import re +import shlex +import sys +from textwrap import dedent +import types +from types import FunctionType +from typing import Any +from typing import Callable +from typing import cast +from typing import Final +from typing import final +from typing import Generator +from typing import IO +from typing import Iterable +from typing import Iterator +from typing import Sequence +from typing import TextIO +from typing import Type +from typing import TYPE_CHECKING +import warnings + +import pluggy +from pluggy import HookimplMarker +from pluggy import HookimplOpts +from pluggy import HookspecMarker +from pluggy import HookspecOpts +from pluggy import PluginManager + +from .compat import PathAwareHookProxy +from .exceptions import PrintHelp as PrintHelp +from .exceptions import UsageError as UsageError +from .findpaths import determine_setup +from _pytest import __version__ +import _pytest._code +from _pytest._code import ExceptionInfo +from _pytest._code import filter_traceback +from _pytest._code.code import TracebackStyle +from _pytest._io import TerminalWriter +from _pytest.config.argparsing import Argument +from _pytest.config.argparsing import Parser +import _pytest.deprecated +import _pytest.hookspec +from _pytest.outcomes import fail +from _pytest.outcomes import Skipped +from _pytest.pathlib import absolutepath +from _pytest.pathlib import bestrelpath +from _pytest.pathlib import import_path +from _pytest.pathlib import ImportMode +from _pytest.pathlib import resolve_package_path +from _pytest.pathlib import safe_exists +from _pytest.stash import Stash +from _pytest.warning_types import PytestConfigWarning +from _pytest.warning_types import warn_explicit_for + + +if TYPE_CHECKING: + from _pytest.cacheprovider import Cache + from _pytest.terminal import TerminalReporter + + +_PluggyPlugin = object +"""A type to represent plugin objects. + +Plugins can be any namespace, so we can't narrow it down much, but we use an +alias to make the intent clear. + +Ideally this type would be provided by pluggy itself. +""" + + +hookimpl = HookimplMarker("pytest") +hookspec = HookspecMarker("pytest") + + +@final +class ExitCode(enum.IntEnum): + """Encodes the valid exit codes by pytest. + + Currently users and plugins may supply other exit codes as well. + + .. versionadded:: 5.0 + """ + + #: Tests passed. + OK = 0 + #: Tests failed. + TESTS_FAILED = 1 + #: pytest was interrupted. + INTERRUPTED = 2 + #: An internal error got in the way. + INTERNAL_ERROR = 3 + #: pytest was misused. + USAGE_ERROR = 4 + #: pytest couldn't find tests. + NO_TESTS_COLLECTED = 5 + + +class ConftestImportFailure(Exception): + def __init__( + self, + path: pathlib.Path, + *, + cause: Exception, + ) -> None: + self.path = path + self.cause = cause + + def __str__(self) -> str: + return f"{type(self.cause).__name__}: {self.cause} (from {self.path})" + + +def filter_traceback_for_conftest_import_failure( + entry: _pytest._code.TracebackEntry, +) -> bool: + """Filter tracebacks entries which point to pytest internals or importlib. + + Make a special case for importlib because we use it to import test modules and conftest files + in _pytest.pathlib.import_path. + """ + return filter_traceback(entry) and "importlib" not in str(entry.path).split(os.sep) + + +def main( + args: list[str] | os.PathLike[str] | None = None, + plugins: Sequence[str | _PluggyPlugin] | None = None, +) -> int | ExitCode: + """Perform an in-process test run. + + :param args: + List of command line arguments. If `None` or not given, defaults to reading + arguments directly from the process command line (:data:`sys.argv`). + :param plugins: List of plugin objects to be auto-registered during initialization. + + :returns: An exit code. + """ + old_pytest_version = os.environ.get("PYTEST_VERSION") + try: + os.environ["PYTEST_VERSION"] = __version__ + try: + config = _prepareconfig(args, plugins) + except ConftestImportFailure as e: + exc_info = ExceptionInfo.from_exception(e.cause) + tw = TerminalWriter(sys.stderr) + tw.line(f"ImportError while loading conftest '{e.path}'.", red=True) + exc_info.traceback = exc_info.traceback.filter( + filter_traceback_for_conftest_import_failure + ) + exc_repr = ( + exc_info.getrepr(style="short", chain=False) + if exc_info.traceback + else exc_info.exconly() + ) + formatted_tb = str(exc_repr) + for line in formatted_tb.splitlines(): + tw.line(line.rstrip(), red=True) + return ExitCode.USAGE_ERROR + else: + try: + ret: ExitCode | int = config.hook.pytest_cmdline_main(config=config) + try: + return ExitCode(ret) + except ValueError: + return ret + finally: + config._ensure_unconfigure() + except UsageError as e: + tw = TerminalWriter(sys.stderr) + for msg in e.args: + tw.line(f"ERROR: {msg}\n", red=True) + return ExitCode.USAGE_ERROR + finally: + if old_pytest_version is None: + os.environ.pop("PYTEST_VERSION", None) + else: + os.environ["PYTEST_VERSION"] = old_pytest_version + + +def console_main() -> int: + """The CLI entry point of pytest. + + This function is not meant for programmable use; use `main()` instead. + """ + # https://docs.python.org/3/library/signal.html#note-on-sigpipe + try: + code = main() + sys.stdout.flush() + return code + except BrokenPipeError: + # Python flushes standard streams on exit; redirect remaining output + # to devnull to avoid another BrokenPipeError at shutdown + devnull = os.open(os.devnull, os.O_WRONLY) + os.dup2(devnull, sys.stdout.fileno()) + return 1 # Python exits with error code 1 on EPIPE + + +class cmdline: # compatibility namespace + main = staticmethod(main) + + +def filename_arg(path: str, optname: str) -> str: + """Argparse type validator for filename arguments. + + :path: Path of filename. + :optname: Name of the option. + """ + if os.path.isdir(path): + raise UsageError(f"{optname} must be a filename, given: {path}") + return path + + +def directory_arg(path: str, optname: str) -> str: + """Argparse type validator for directory arguments. + + :path: Path of directory. + :optname: Name of the option. + """ + if not os.path.isdir(path): + raise UsageError(f"{optname} must be a directory, given: {path}") + return path + + +# Plugins that cannot be disabled via "-p no:X" currently. +essential_plugins = ( + "mark", + "main", + "runner", + "fixtures", + "helpconfig", # Provides -p. +) + +default_plugins = ( + *essential_plugins, + "python", + "terminal", + "debugging", + "unittest", + "capture", + "skipping", + "legacypath", + "tmpdir", + "monkeypatch", + "recwarn", + "pastebin", + "assertion", + "junitxml", + "doctest", + "cacheprovider", + "freeze_support", + "setuponly", + "setupplan", + "stepwise", + "warnings", + "logging", + "reports", + "python_path", + "unraisableexception", + "threadexception", + "faulthandler", +) + +builtin_plugins = set(default_plugins) +builtin_plugins.add("pytester") +builtin_plugins.add("pytester_assertions") + + +def get_config( + args: list[str] | None = None, + plugins: Sequence[str | _PluggyPlugin] | None = None, +) -> Config: + # subsequent calls to main will create a fresh instance + pluginmanager = PytestPluginManager() + config = Config( + pluginmanager, + invocation_params=Config.InvocationParams( + args=args or (), + plugins=plugins, + dir=pathlib.Path.cwd(), + ), + ) + + if args is not None: + # Handle any "-p no:plugin" args. + pluginmanager.consider_preparse(args, exclude_only=True) + + for spec in default_plugins: + pluginmanager.import_plugin(spec) + + return config + + +def get_plugin_manager() -> PytestPluginManager: + """Obtain a new instance of the + :py:class:`pytest.PytestPluginManager`, with default plugins + already loaded. + + This function can be used by integration with other tools, like hooking + into pytest to run tests into an IDE. + """ + return get_config().pluginmanager + + +def _prepareconfig( + args: list[str] | os.PathLike[str] | None = None, + plugins: Sequence[str | _PluggyPlugin] | None = None, +) -> Config: + if args is None: + args = sys.argv[1:] + elif isinstance(args, os.PathLike): + args = [os.fspath(args)] + elif not isinstance(args, list): + msg = ( # type:ignore[unreachable] + "`args` parameter expected to be a list of strings, got: {!r} (type: {})" + ) + raise TypeError(msg.format(args, type(args))) + + config = get_config(args, plugins) + pluginmanager = config.pluginmanager + try: + if plugins: + for plugin in plugins: + if isinstance(plugin, str): + pluginmanager.consider_pluginarg(plugin) + else: + pluginmanager.register(plugin) + config = pluginmanager.hook.pytest_cmdline_parse( + pluginmanager=pluginmanager, args=args + ) + return config + except BaseException: + config._ensure_unconfigure() + raise + + +def _get_directory(path: pathlib.Path) -> pathlib.Path: + """Get the directory of a path - itself if already a directory.""" + if path.is_file(): + return path.parent + else: + return path + + +def _get_legacy_hook_marks( + method: Any, + hook_type: str, + opt_names: tuple[str, ...], +) -> dict[str, bool]: + if TYPE_CHECKING: + # abuse typeguard from importlib to avoid massive method type union that's lacking an alias + assert inspect.isroutine(method) + known_marks: set[str] = {m.name for m in getattr(method, "pytestmark", [])} + must_warn: list[str] = [] + opts: dict[str, bool] = {} + for opt_name in opt_names: + opt_attr = getattr(method, opt_name, AttributeError) + if opt_attr is not AttributeError: + must_warn.append(f"{opt_name}={opt_attr}") + opts[opt_name] = True + elif opt_name in known_marks: + must_warn.append(f"{opt_name}=True") + opts[opt_name] = True + else: + opts[opt_name] = False + if must_warn: + hook_opts = ", ".join(must_warn) + message = _pytest.deprecated.HOOK_LEGACY_MARKING.format( + type=hook_type, + fullname=method.__qualname__, + hook_opts=hook_opts, + ) + warn_explicit_for(cast(FunctionType, method), message) + return opts + + +@final +class PytestPluginManager(PluginManager): + """A :py:class:`pluggy.PluginManager ` with + additional pytest-specific functionality: + + * Loading plugins from the command line, ``PYTEST_PLUGINS`` env variable and + ``pytest_plugins`` global variables found in plugins being loaded. + * ``conftest.py`` loading during start-up. + """ + + def __init__(self) -> None: + import _pytest.assertion + + super().__init__("pytest") + + # -- State related to local conftest plugins. + # All loaded conftest modules. + self._conftest_plugins: set[types.ModuleType] = set() + # All conftest modules applicable for a directory. + # This includes the directory's own conftest modules as well + # as those of its parent directories. + self._dirpath2confmods: dict[pathlib.Path, list[types.ModuleType]] = {} + # Cutoff directory above which conftests are no longer discovered. + self._confcutdir: pathlib.Path | None = None + # If set, conftest loading is skipped. + self._noconftest = False + + # _getconftestmodules()'s call to _get_directory() causes a stat + # storm when it's called potentially thousands of times in a test + # session (#9478), often with the same path, so cache it. + self._get_directory = lru_cache(256)(_get_directory) + + # plugins that were explicitly skipped with pytest.skip + # list of (module name, skip reason) + # previously we would issue a warning when a plugin was skipped, but + # since we refactored warnings as first citizens of Config, they are + # just stored here to be used later. + self.skipped_plugins: list[tuple[str, str]] = [] + + self.add_hookspecs(_pytest.hookspec) + self.register(self) + if os.environ.get("PYTEST_DEBUG"): + err: IO[str] = sys.stderr + encoding: str = getattr(err, "encoding", "utf8") + try: + err = open( + os.dup(err.fileno()), + mode=err.mode, + buffering=1, + encoding=encoding, + ) + except Exception: + pass + self.trace.root.setwriter(err.write) + self.enable_tracing() + + # Config._consider_importhook will set a real object if required. + self.rewrite_hook = _pytest.assertion.DummyRewriteHook() + # Used to know when we are importing conftests after the pytest_configure stage. + self._configured = False + + def parse_hookimpl_opts( + self, plugin: _PluggyPlugin, name: str + ) -> HookimplOpts | None: + """:meta private:""" + # pytest hooks are always prefixed with "pytest_", + # so we avoid accessing possibly non-readable attributes + # (see issue #1073). + if not name.startswith("pytest_"): + return None + # Ignore names which cannot be hooks. + if name == "pytest_plugins": + return None + + opts = super().parse_hookimpl_opts(plugin, name) + if opts is not None: + return opts + + method = getattr(plugin, name) + # Consider only actual functions for hooks (#3775). + if not inspect.isroutine(method): + return None + # Collect unmarked hooks as long as they have the `pytest_' prefix. + return _get_legacy_hook_marks( # type: ignore[return-value] + method, "impl", ("tryfirst", "trylast", "optionalhook", "hookwrapper") + ) + + def parse_hookspec_opts(self, module_or_class, name: str) -> HookspecOpts | None: + """:meta private:""" + opts = super().parse_hookspec_opts(module_or_class, name) + if opts is None: + method = getattr(module_or_class, name) + if name.startswith("pytest_"): + opts = _get_legacy_hook_marks( # type: ignore[assignment] + method, + "spec", + ("firstresult", "historic"), + ) + return opts + + def register(self, plugin: _PluggyPlugin, name: str | None = None) -> str | None: + if name in _pytest.deprecated.DEPRECATED_EXTERNAL_PLUGINS: + warnings.warn( + PytestConfigWarning( + "{} plugin has been merged into the core, " + "please remove it from your requirements.".format( + name.replace("_", "-") + ) + ) + ) + return None + plugin_name = super().register(plugin, name) + if plugin_name is not None: + self.hook.pytest_plugin_registered.call_historic( + kwargs=dict( + plugin=plugin, + plugin_name=plugin_name, + manager=self, + ) + ) + + if isinstance(plugin, types.ModuleType): + self.consider_module(plugin) + return plugin_name + + def getplugin(self, name: str): + # Support deprecated naming because plugins (xdist e.g.) use it. + plugin: _PluggyPlugin | None = self.get_plugin(name) + return plugin + + def hasplugin(self, name: str) -> bool: + """Return whether a plugin with the given name is registered.""" + return bool(self.get_plugin(name)) + + def pytest_configure(self, config: Config) -> None: + """:meta private:""" + # XXX now that the pluginmanager exposes hookimpl(tryfirst...) + # we should remove tryfirst/trylast as markers. + config.addinivalue_line( + "markers", + "tryfirst: mark a hook implementation function such that the " + "plugin machinery will try to call it first/as early as possible. " + "DEPRECATED, use @pytest.hookimpl(tryfirst=True) instead.", + ) + config.addinivalue_line( + "markers", + "trylast: mark a hook implementation function such that the " + "plugin machinery will try to call it last/as late as possible. " + "DEPRECATED, use @pytest.hookimpl(trylast=True) instead.", + ) + self._configured = True + + # + # Internal API for local conftest plugin handling. + # + def _set_initial_conftests( + self, + args: Sequence[str | pathlib.Path], + pyargs: bool, + noconftest: bool, + rootpath: pathlib.Path, + confcutdir: pathlib.Path | None, + invocation_dir: pathlib.Path, + importmode: ImportMode | str, + *, + consider_namespace_packages: bool, + ) -> None: + """Load initial conftest files given a preparsed "namespace". + + As conftest files may add their own command line options which have + arguments ('--my-opt somepath') we might get some false positives. + All builtin and 3rd party plugins will have been loaded, however, so + common options will not confuse our logic here. + """ + self._confcutdir = ( + absolutepath(invocation_dir / confcutdir) if confcutdir else None + ) + self._noconftest = noconftest + self._using_pyargs = pyargs + foundanchor = False + for initial_path in args: + path = str(initial_path) + # remove node-id syntax + i = path.find("::") + if i != -1: + path = path[:i] + anchor = absolutepath(invocation_dir / path) + + # Ensure we do not break if what appears to be an anchor + # is in fact a very long option (#10169, #11394). + if safe_exists(anchor): + self._try_load_conftest( + anchor, + importmode, + rootpath, + consider_namespace_packages=consider_namespace_packages, + ) + foundanchor = True + if not foundanchor: + self._try_load_conftest( + invocation_dir, + importmode, + rootpath, + consider_namespace_packages=consider_namespace_packages, + ) + + def _is_in_confcutdir(self, path: pathlib.Path) -> bool: + """Whether to consider the given path to load conftests from.""" + if self._confcutdir is None: + return True + # The semantics here are literally: + # Do not load a conftest if it is found upwards from confcut dir. + # But this is *not* the same as: + # Load only conftests from confcutdir or below. + # At first glance they might seem the same thing, however we do support use cases where + # we want to load conftests that are not found in confcutdir or below, but are found + # in completely different directory hierarchies like packages installed + # in out-of-source trees. + # (see #9767 for a regression where the logic was inverted). + return path not in self._confcutdir.parents + + def _try_load_conftest( + self, + anchor: pathlib.Path, + importmode: str | ImportMode, + rootpath: pathlib.Path, + *, + consider_namespace_packages: bool, + ) -> None: + self._loadconftestmodules( + anchor, + importmode, + rootpath, + consider_namespace_packages=consider_namespace_packages, + ) + # let's also consider test* subdirs + if anchor.is_dir(): + for x in anchor.glob("test*"): + if x.is_dir(): + self._loadconftestmodules( + x, + importmode, + rootpath, + consider_namespace_packages=consider_namespace_packages, + ) + + def _loadconftestmodules( + self, + path: pathlib.Path, + importmode: str | ImportMode, + rootpath: pathlib.Path, + *, + consider_namespace_packages: bool, + ) -> None: + if self._noconftest: + return + + directory = self._get_directory(path) + + # Optimization: avoid repeated searches in the same directory. + # Assumes always called with same importmode and rootpath. + if directory in self._dirpath2confmods: + return + + clist = [] + for parent in reversed((directory, *directory.parents)): + if self._is_in_confcutdir(parent): + conftestpath = parent / "conftest.py" + if conftestpath.is_file(): + mod = self._importconftest( + conftestpath, + importmode, + rootpath, + consider_namespace_packages=consider_namespace_packages, + ) + clist.append(mod) + self._dirpath2confmods[directory] = clist + + def _getconftestmodules(self, path: pathlib.Path) -> Sequence[types.ModuleType]: + directory = self._get_directory(path) + return self._dirpath2confmods.get(directory, ()) + + def _rget_with_confmod( + self, + name: str, + path: pathlib.Path, + ) -> tuple[types.ModuleType, Any]: + modules = self._getconftestmodules(path) + for mod in reversed(modules): + try: + return mod, getattr(mod, name) + except AttributeError: + continue + raise KeyError(name) + + def _importconftest( + self, + conftestpath: pathlib.Path, + importmode: str | ImportMode, + rootpath: pathlib.Path, + *, + consider_namespace_packages: bool, + ) -> types.ModuleType: + conftestpath_plugin_name = str(conftestpath) + existing = self.get_plugin(conftestpath_plugin_name) + if existing is not None: + return cast(types.ModuleType, existing) + + # conftest.py files there are not in a Python package all have module + # name "conftest", and thus conflict with each other. Clear the existing + # before loading the new one, otherwise the existing one will be + # returned from the module cache. + pkgpath = resolve_package_path(conftestpath) + if pkgpath is None: + try: + del sys.modules[conftestpath.stem] + except KeyError: + pass + + try: + mod = import_path( + conftestpath, + mode=importmode, + root=rootpath, + consider_namespace_packages=consider_namespace_packages, + ) + except Exception as e: + assert e.__traceback__ is not None + raise ConftestImportFailure(conftestpath, cause=e) from e + + self._check_non_top_pytest_plugins(mod, conftestpath) + + self._conftest_plugins.add(mod) + dirpath = conftestpath.parent + if dirpath in self._dirpath2confmods: + for path, mods in self._dirpath2confmods.items(): + if dirpath in path.parents or path == dirpath: + if mod in mods: + raise AssertionError( + f"While trying to load conftest path {conftestpath!s}, " + f"found that the module {mod} is already loaded with path {mod.__file__}. " + "This is not supposed to happen. Please report this issue to pytest." + ) + mods.append(mod) + self.trace(f"loading conftestmodule {mod!r}") + self.consider_conftest(mod, registration_name=conftestpath_plugin_name) + return mod + + def _check_non_top_pytest_plugins( + self, + mod: types.ModuleType, + conftestpath: pathlib.Path, + ) -> None: + if ( + hasattr(mod, "pytest_plugins") + and self._configured + and not self._using_pyargs + ): + msg = ( + "Defining 'pytest_plugins' in a non-top-level conftest is no longer supported:\n" + "It affects the entire test suite instead of just below the conftest as expected.\n" + " {}\n" + "Please move it to a top level conftest file at the rootdir:\n" + " {}\n" + "For more information, visit:\n" + " https://docs.pytest.org/en/stable/deprecations.html#pytest-plugins-in-non-top-level-conftest-files" + ) + fail(msg.format(conftestpath, self._confcutdir), pytrace=False) + + # + # API for bootstrapping plugin loading + # + # + + def consider_preparse( + self, args: Sequence[str], *, exclude_only: bool = False + ) -> None: + """:meta private:""" + i = 0 + n = len(args) + while i < n: + opt = args[i] + i += 1 + if isinstance(opt, str): + if opt == "-p": + try: + parg = args[i] + except IndexError: + return + i += 1 + elif opt.startswith("-p"): + parg = opt[2:] + else: + continue + parg = parg.strip() + if exclude_only and not parg.startswith("no:"): + continue + self.consider_pluginarg(parg) + + def consider_pluginarg(self, arg: str) -> None: + """:meta private:""" + if arg.startswith("no:"): + name = arg[3:] + if name in essential_plugins: + raise UsageError(f"plugin {name} cannot be disabled") + + # PR #4304: remove stepwise if cacheprovider is blocked. + if name == "cacheprovider": + self.set_blocked("stepwise") + self.set_blocked("pytest_stepwise") + + self.set_blocked(name) + if not name.startswith("pytest_"): + self.set_blocked("pytest_" + name) + else: + name = arg + # Unblock the plugin. + self.unblock(name) + if not name.startswith("pytest_"): + self.unblock("pytest_" + name) + self.import_plugin(arg, consider_entry_points=True) + + def consider_conftest( + self, conftestmodule: types.ModuleType, registration_name: str + ) -> None: + """:meta private:""" + self.register(conftestmodule, name=registration_name) + + def consider_env(self) -> None: + """:meta private:""" + self._import_plugin_specs(os.environ.get("PYTEST_PLUGINS")) + + def consider_module(self, mod: types.ModuleType) -> None: + """:meta private:""" + self._import_plugin_specs(getattr(mod, "pytest_plugins", [])) + + def _import_plugin_specs( + self, spec: None | types.ModuleType | str | Sequence[str] + ) -> None: + plugins = _get_plugin_specs_as_list(spec) + for import_spec in plugins: + self.import_plugin(import_spec) + + def import_plugin(self, modname: str, consider_entry_points: bool = False) -> None: + """Import a plugin with ``modname``. + + If ``consider_entry_points`` is True, entry point names are also + considered to find a plugin. + """ + # Most often modname refers to builtin modules, e.g. "pytester", + # "terminal" or "capture". Those plugins are registered under their + # basename for historic purposes but must be imported with the + # _pytest prefix. + assert isinstance( + modname, str + ), f"module name as text required, got {modname!r}" + if self.is_blocked(modname) or self.get_plugin(modname) is not None: + return + + importspec = "_pytest." + modname if modname in builtin_plugins else modname + self.rewrite_hook.mark_rewrite(importspec) + + if consider_entry_points: + loaded = self.load_setuptools_entrypoints("pytest11", name=modname) + if loaded: + return + + try: + __import__(importspec) + except ImportError as e: + raise ImportError( + f'Error importing plugin "{modname}": {e.args[0]}' + ).with_traceback(e.__traceback__) from e + + except Skipped as e: + self.skipped_plugins.append((modname, e.msg or "")) + else: + mod = sys.modules[importspec] + self.register(mod, modname) + + +def _get_plugin_specs_as_list( + specs: None | types.ModuleType | str | Sequence[str], +) -> list[str]: + """Parse a plugins specification into a list of plugin names.""" + # None means empty. + if specs is None: + return [] + # Workaround for #3899 - a submodule which happens to be called "pytest_plugins". + if isinstance(specs, types.ModuleType): + return [] + # Comma-separated list. + if isinstance(specs, str): + return specs.split(",") if specs else [] + # Direct specification. + if isinstance(specs, collections.abc.Sequence): + return list(specs) + raise UsageError( + f"Plugins may be specified as a sequence or a ','-separated string of plugin names. Got: {specs!r}" + ) + + +class Notset: + def __repr__(self): + return "" + + +notset = Notset() + + +def _iter_rewritable_modules(package_files: Iterable[str]) -> Iterator[str]: + """Given an iterable of file names in a source distribution, return the "names" that should + be marked for assertion rewrite. + + For example the package "pytest_mock/__init__.py" should be added as "pytest_mock" in + the assertion rewrite mechanism. + + This function has to deal with dist-info based distributions and egg based distributions + (which are still very much in use for "editable" installs). + + Here are the file names as seen in a dist-info based distribution: + + pytest_mock/__init__.py + pytest_mock/_version.py + pytest_mock/plugin.py + pytest_mock.egg-info/PKG-INFO + + Here are the file names as seen in an egg based distribution: + + src/pytest_mock/__init__.py + src/pytest_mock/_version.py + src/pytest_mock/plugin.py + src/pytest_mock.egg-info/PKG-INFO + LICENSE + setup.py + + We have to take in account those two distribution flavors in order to determine which + names should be considered for assertion rewriting. + + More information: + https://github.com/pytest-dev/pytest-mock/issues/167 + """ + package_files = list(package_files) + seen_some = False + for fn in package_files: + is_simple_module = "/" not in fn and fn.endswith(".py") + is_package = fn.count("/") == 1 and fn.endswith("__init__.py") + if is_simple_module: + module_name, _ = os.path.splitext(fn) + # we ignore "setup.py" at the root of the distribution + # as well as editable installation finder modules made by setuptools + if module_name != "setup" and not module_name.startswith("__editable__"): + seen_some = True + yield module_name + elif is_package: + package_name = os.path.dirname(fn) + seen_some = True + yield package_name + + if not seen_some: + # At this point we did not find any packages or modules suitable for assertion + # rewriting, so we try again by stripping the first path component (to account for + # "src" based source trees for example). + # This approach lets us have the common case continue to be fast, as egg-distributions + # are rarer. + new_package_files = [] + for fn in package_files: + parts = fn.split("/") + new_fn = "/".join(parts[1:]) + if new_fn: + new_package_files.append(new_fn) + if new_package_files: + yield from _iter_rewritable_modules(new_package_files) + + +@final +class Config: + """Access to configuration values, pluginmanager and plugin hooks. + + :param PytestPluginManager pluginmanager: + A pytest PluginManager. + + :param InvocationParams invocation_params: + Object containing parameters regarding the :func:`pytest.main` + invocation. + """ + + @final + @dataclasses.dataclass(frozen=True) + class InvocationParams: + """Holds parameters passed during :func:`pytest.main`. + + The object attributes are read-only. + + .. versionadded:: 5.1 + + .. note:: + + Note that the environment variable ``PYTEST_ADDOPTS`` and the ``addopts`` + ini option are handled by pytest, not being included in the ``args`` attribute. + + Plugins accessing ``InvocationParams`` must be aware of that. + """ + + args: tuple[str, ...] + """The command-line arguments as passed to :func:`pytest.main`.""" + plugins: Sequence[str | _PluggyPlugin] | None + """Extra plugins, might be `None`.""" + dir: pathlib.Path + """The directory from which :func:`pytest.main` was invoked. :type: pathlib.Path""" + + def __init__( + self, + *, + args: Iterable[str], + plugins: Sequence[str | _PluggyPlugin] | None, + dir: pathlib.Path, + ) -> None: + object.__setattr__(self, "args", tuple(args)) + object.__setattr__(self, "plugins", plugins) + object.__setattr__(self, "dir", dir) + + class ArgsSource(enum.Enum): + """Indicates the source of the test arguments. + + .. versionadded:: 7.2 + """ + + #: Command line arguments. + ARGS = enum.auto() + #: Invocation directory. + INVOCATION_DIR = enum.auto() + INCOVATION_DIR = INVOCATION_DIR # backwards compatibility alias + #: 'testpaths' configuration value. + TESTPATHS = enum.auto() + + # Set by cacheprovider plugin. + cache: Cache + + def __init__( + self, + pluginmanager: PytestPluginManager, + *, + invocation_params: InvocationParams | None = None, + ) -> None: + from .argparsing import FILE_OR_DIR + from .argparsing import Parser + + if invocation_params is None: + invocation_params = self.InvocationParams( + args=(), plugins=None, dir=pathlib.Path.cwd() + ) + + self.option = argparse.Namespace() + """Access to command line option as attributes. + + :type: argparse.Namespace + """ + + self.invocation_params = invocation_params + """The parameters with which pytest was invoked. + + :type: InvocationParams + """ + + _a = FILE_OR_DIR + self._parser = Parser( + usage=f"%(prog)s [options] [{_a}] [{_a}] [...]", + processopt=self._processopt, + _ispytest=True, + ) + self.pluginmanager = pluginmanager + """The plugin manager handles plugin registration and hook invocation. + + :type: PytestPluginManager + """ + + self.stash = Stash() + """A place where plugins can store information on the config for their + own use. + + :type: Stash + """ + # Deprecated alias. Was never public. Can be removed in a few releases. + self._store = self.stash + + self.trace = self.pluginmanager.trace.root.get("config") + self.hook: pluggy.HookRelay = PathAwareHookProxy(self.pluginmanager.hook) # type: ignore[assignment] + self._inicache: dict[str, Any] = {} + self._override_ini: Sequence[str] = () + self._opt2dest: dict[str, str] = {} + self._cleanup: list[Callable[[], None]] = [] + self.pluginmanager.register(self, "pytestconfig") + self._configured = False + self.hook.pytest_addoption.call_historic( + kwargs=dict(parser=self._parser, pluginmanager=self.pluginmanager) + ) + self.args_source = Config.ArgsSource.ARGS + self.args: list[str] = [] + + @property + def rootpath(self) -> pathlib.Path: + """The path to the :ref:`rootdir `. + + :type: pathlib.Path + + .. versionadded:: 6.1 + """ + return self._rootpath + + @property + def inipath(self) -> pathlib.Path | None: + """The path to the :ref:`configfile `. + + .. versionadded:: 6.1 + """ + return self._inipath + + def add_cleanup(self, func: Callable[[], None]) -> None: + """Add a function to be called when the config object gets out of + use (usually coinciding with pytest_unconfigure).""" + self._cleanup.append(func) + + def _do_configure(self) -> None: + assert not self._configured + self._configured = True + with warnings.catch_warnings(): + warnings.simplefilter("default") + self.hook.pytest_configure.call_historic(kwargs=dict(config=self)) + + def _ensure_unconfigure(self) -> None: + if self._configured: + self._configured = False + self.hook.pytest_unconfigure(config=self) + self.hook.pytest_configure._call_history = [] + while self._cleanup: + fin = self._cleanup.pop() + fin() + + def get_terminal_writer(self) -> TerminalWriter: + terminalreporter: TerminalReporter | None = self.pluginmanager.get_plugin( + "terminalreporter" + ) + assert terminalreporter is not None + return terminalreporter._tw + + def pytest_cmdline_parse( + self, pluginmanager: PytestPluginManager, args: list[str] + ) -> Config: + try: + self.parse(args) + except UsageError: + # Handle --version and --help here in a minimal fashion. + # This gets done via helpconfig normally, but its + # pytest_cmdline_main is not called in case of errors. + if getattr(self.option, "version", False) or "--version" in args: + from _pytest.helpconfig import showversion + + showversion(self) + elif ( + getattr(self.option, "help", False) or "--help" in args or "-h" in args + ): + self._parser._getparser().print_help() + sys.stdout.write( + "\nNOTE: displaying only minimal help due to UsageError.\n\n" + ) + + raise + + return self + + def notify_exception( + self, + excinfo: ExceptionInfo[BaseException], + option: argparse.Namespace | None = None, + ) -> None: + if option and getattr(option, "fulltrace", False): + style: TracebackStyle = "long" + else: + style = "native" + excrepr = excinfo.getrepr( + funcargs=True, showlocals=getattr(option, "showlocals", False), style=style + ) + res = self.hook.pytest_internalerror(excrepr=excrepr, excinfo=excinfo) + if not any(res): + for line in str(excrepr).split("\n"): + sys.stderr.write(f"INTERNALERROR> {line}\n") + sys.stderr.flush() + + def cwd_relative_nodeid(self, nodeid: str) -> str: + # nodeid's are relative to the rootpath, compute relative to cwd. + if self.invocation_params.dir != self.rootpath: + base_path_part, *nodeid_part = nodeid.split("::") + # Only process path part + fullpath = self.rootpath / base_path_part + relative_path = bestrelpath(self.invocation_params.dir, fullpath) + + nodeid = "::".join([relative_path, *nodeid_part]) + return nodeid + + @classmethod + def fromdictargs(cls, option_dict, args) -> Config: + """Constructor usable for subprocesses.""" + config = get_config(args) + config.option.__dict__.update(option_dict) + config.parse(args, addopts=False) + for x in config.option.plugins: + config.pluginmanager.consider_pluginarg(x) + return config + + def _processopt(self, opt: Argument) -> None: + for name in opt._short_opts + opt._long_opts: + self._opt2dest[name] = opt.dest + + if hasattr(opt, "default"): + if not hasattr(self.option, opt.dest): + setattr(self.option, opt.dest, opt.default) + + @hookimpl(trylast=True) + def pytest_load_initial_conftests(self, early_config: Config) -> None: + # We haven't fully parsed the command line arguments yet, so + # early_config.args it not set yet. But we need it for + # discovering the initial conftests. So "pre-run" the logic here. + # It will be done for real in `parse()`. + args, args_source = early_config._decide_args( + args=early_config.known_args_namespace.file_or_dir, + pyargs=early_config.known_args_namespace.pyargs, + testpaths=early_config.getini("testpaths"), + invocation_dir=early_config.invocation_params.dir, + rootpath=early_config.rootpath, + warn=False, + ) + self.pluginmanager._set_initial_conftests( + args=args, + pyargs=early_config.known_args_namespace.pyargs, + noconftest=early_config.known_args_namespace.noconftest, + rootpath=early_config.rootpath, + confcutdir=early_config.known_args_namespace.confcutdir, + invocation_dir=early_config.invocation_params.dir, + importmode=early_config.known_args_namespace.importmode, + consider_namespace_packages=early_config.getini( + "consider_namespace_packages" + ), + ) + + def _initini(self, args: Sequence[str]) -> None: + ns, unknown_args = self._parser.parse_known_and_unknown_args( + args, namespace=copy.copy(self.option) + ) + rootpath, inipath, inicfg = determine_setup( + inifile=ns.inifilename, + args=ns.file_or_dir + unknown_args, + rootdir_cmd_arg=ns.rootdir or None, + invocation_dir=self.invocation_params.dir, + ) + self._rootpath = rootpath + self._inipath = inipath + self.inicfg = inicfg + self._parser.extra_info["rootdir"] = str(self.rootpath) + self._parser.extra_info["inifile"] = str(self.inipath) + self._parser.addini("addopts", "Extra command line options", "args") + self._parser.addini("minversion", "Minimally required pytest version") + self._parser.addini( + "required_plugins", + "Plugins that must be present for pytest to run", + type="args", + default=[], + ) + self._override_ini = ns.override_ini or () + + def _consider_importhook(self, args: Sequence[str]) -> None: + """Install the PEP 302 import hook if using assertion rewriting. + + Needs to parse the --assert= option from the commandline + and find all the installed plugins to mark them for rewriting + by the importhook. + """ + ns, unknown_args = self._parser.parse_known_and_unknown_args(args) + mode = getattr(ns, "assertmode", "plain") + if mode == "rewrite": + import _pytest.assertion + + try: + hook = _pytest.assertion.install_importhook(self) + except SystemError: + mode = "plain" + else: + self._mark_plugins_for_rewrite(hook) + self._warn_about_missing_assertion(mode) + + def _mark_plugins_for_rewrite(self, hook) -> None: + """Given an importhook, mark for rewrite any top-level + modules or packages in the distribution package for + all pytest plugins.""" + self.pluginmanager.rewrite_hook = hook + + if os.environ.get("PYTEST_DISABLE_PLUGIN_AUTOLOAD"): + # We don't autoload from distribution package entry points, + # no need to continue. + return + + package_files = ( + str(file) + for dist in importlib.metadata.distributions() + if any(ep.group == "pytest11" for ep in dist.entry_points) + for file in dist.files or [] + ) + + for name in _iter_rewritable_modules(package_files): + hook.mark_rewrite(name) + + def _validate_args(self, args: list[str], via: str) -> list[str]: + """Validate known args.""" + self._parser._config_source_hint = via # type: ignore + try: + self._parser.parse_known_and_unknown_args( + args, namespace=copy.copy(self.option) + ) + finally: + del self._parser._config_source_hint # type: ignore + + return args + + def _decide_args( + self, + *, + args: list[str], + pyargs: bool, + testpaths: list[str], + invocation_dir: pathlib.Path, + rootpath: pathlib.Path, + warn: bool, + ) -> tuple[list[str], ArgsSource]: + """Decide the args (initial paths/nodeids) to use given the relevant inputs. + + :param warn: Whether can issue warnings. + + :returns: The args and the args source. Guaranteed to be non-empty. + """ + if args: + source = Config.ArgsSource.ARGS + result = args + else: + if invocation_dir == rootpath: + source = Config.ArgsSource.TESTPATHS + if pyargs: + result = testpaths + else: + result = [] + for path in testpaths: + result.extend(sorted(glob.iglob(path, recursive=True))) + if testpaths and not result: + if warn: + warning_text = ( + "No files were found in testpaths; " + "consider removing or adjusting your testpaths configuration. " + "Searching recursively from the current directory instead." + ) + self.issue_config_time_warning( + PytestConfigWarning(warning_text), stacklevel=3 + ) + else: + result = [] + if not result: + source = Config.ArgsSource.INVOCATION_DIR + result = [str(invocation_dir)] + return result, source + + def _preparse(self, args: list[str], addopts: bool = True) -> None: + if addopts: + env_addopts = os.environ.get("PYTEST_ADDOPTS", "") + if len(env_addopts): + args[:] = ( + self._validate_args(shlex.split(env_addopts), "via PYTEST_ADDOPTS") + + args + ) + self._initini(args) + if addopts: + args[:] = ( + self._validate_args(self.getini("addopts"), "via addopts config") + args + ) + + self.known_args_namespace = self._parser.parse_known_args( + args, namespace=copy.copy(self.option) + ) + self._checkversion() + self._consider_importhook(args) + self.pluginmanager.consider_preparse(args, exclude_only=False) + if not os.environ.get("PYTEST_DISABLE_PLUGIN_AUTOLOAD"): + # Don't autoload from distribution package entry point. Only + # explicitly specified plugins are going to be loaded. + self.pluginmanager.load_setuptools_entrypoints("pytest11") + self.pluginmanager.consider_env() + + self.known_args_namespace = self._parser.parse_known_args( + args, namespace=copy.copy(self.known_args_namespace) + ) + + self._validate_plugins() + self._warn_about_skipped_plugins() + + if self.known_args_namespace.confcutdir is None: + if self.inipath is not None: + confcutdir = str(self.inipath.parent) + else: + confcutdir = str(self.rootpath) + self.known_args_namespace.confcutdir = confcutdir + try: + self.hook.pytest_load_initial_conftests( + early_config=self, args=args, parser=self._parser + ) + except ConftestImportFailure as e: + if self.known_args_namespace.help or self.known_args_namespace.version: + # we don't want to prevent --help/--version to work + # so just let is pass and print a warning at the end + self.issue_config_time_warning( + PytestConfigWarning(f"could not load initial conftests: {e.path}"), + stacklevel=2, + ) + else: + raise + + @hookimpl(wrapper=True) + def pytest_collection(self) -> Generator[None, object, object]: + # Validate invalid ini keys after collection is done so we take in account + # options added by late-loading conftest files. + try: + return (yield) + finally: + self._validate_config_options() + + def _checkversion(self) -> None: + import pytest + + minver = self.inicfg.get("minversion", None) + if minver: + # Imported lazily to improve start-up time. + from packaging.version import Version + + if not isinstance(minver, str): + raise pytest.UsageError( + f"{self.inipath}: 'minversion' must be a single value" + ) + + if Version(minver) > Version(pytest.__version__): + raise pytest.UsageError( + f"{self.inipath}: 'minversion' requires pytest-{minver}, actual pytest-{pytest.__version__}'" + ) + + def _validate_config_options(self) -> None: + for key in sorted(self._get_unknown_ini_keys()): + self._warn_or_fail_if_strict(f"Unknown config option: {key}\n") + + def _validate_plugins(self) -> None: + required_plugins = sorted(self.getini("required_plugins")) + if not required_plugins: + return + + # Imported lazily to improve start-up time. + from packaging.requirements import InvalidRequirement + from packaging.requirements import Requirement + from packaging.version import Version + + plugin_info = self.pluginmanager.list_plugin_distinfo() + plugin_dist_info = {dist.project_name: dist.version for _, dist in plugin_info} + + missing_plugins = [] + for required_plugin in required_plugins: + try: + req = Requirement(required_plugin) + except InvalidRequirement: + missing_plugins.append(required_plugin) + continue + + if req.name not in plugin_dist_info: + missing_plugins.append(required_plugin) + elif not req.specifier.contains( + Version(plugin_dist_info[req.name]), prereleases=True + ): + missing_plugins.append(required_plugin) + + if missing_plugins: + raise UsageError( + "Missing required plugins: {}".format(", ".join(missing_plugins)), + ) + + def _warn_or_fail_if_strict(self, message: str) -> None: + if self.known_args_namespace.strict_config: + raise UsageError(message) + + self.issue_config_time_warning(PytestConfigWarning(message), stacklevel=3) + + def _get_unknown_ini_keys(self) -> list[str]: + parser_inicfg = self._parser._inidict + return [name for name in self.inicfg if name not in parser_inicfg] + + def parse(self, args: list[str], addopts: bool = True) -> None: + # Parse given cmdline arguments into this config object. + assert ( + self.args == [] + ), "can only parse cmdline args at most once per Config object" + self.hook.pytest_addhooks.call_historic( + kwargs=dict(pluginmanager=self.pluginmanager) + ) + self._preparse(args, addopts=addopts) + self._parser.after_preparse = True # type: ignore + try: + args = self._parser.parse_setoption( + args, self.option, namespace=self.option + ) + self.args, self.args_source = self._decide_args( + args=args, + pyargs=self.known_args_namespace.pyargs, + testpaths=self.getini("testpaths"), + invocation_dir=self.invocation_params.dir, + rootpath=self.rootpath, + warn=True, + ) + except PrintHelp: + pass + + def issue_config_time_warning(self, warning: Warning, stacklevel: int) -> None: + """Issue and handle a warning during the "configure" stage. + + During ``pytest_configure`` we can't capture warnings using the ``catch_warnings_for_item`` + function because it is not possible to have hook wrappers around ``pytest_configure``. + + This function is mainly intended for plugins that need to issue warnings during + ``pytest_configure`` (or similar stages). + + :param warning: The warning instance. + :param stacklevel: stacklevel forwarded to warnings.warn. + """ + if self.pluginmanager.is_blocked("warnings"): + return + + cmdline_filters = self.known_args_namespace.pythonwarnings or [] + config_filters = self.getini("filterwarnings") + + with warnings.catch_warnings(record=True) as records: + warnings.simplefilter("always", type(warning)) + apply_warning_filters(config_filters, cmdline_filters) + warnings.warn(warning, stacklevel=stacklevel) + + if records: + frame = sys._getframe(stacklevel - 1) + location = frame.f_code.co_filename, frame.f_lineno, frame.f_code.co_name + self.hook.pytest_warning_recorded.call_historic( + kwargs=dict( + warning_message=records[0], + when="config", + nodeid="", + location=location, + ) + ) + + def addinivalue_line(self, name: str, line: str) -> None: + """Add a line to an ini-file option. The option must have been + declared but might not yet be set in which case the line becomes + the first line in its value.""" + x = self.getini(name) + assert isinstance(x, list) + x.append(line) # modifies the cached list inline + + def getini(self, name: str): + """Return configuration value from an :ref:`ini file `. + + If a configuration value is not defined in an + :ref:`ini file `, then the ``default`` value provided while + registering the configuration through + :func:`parser.addini ` will be returned. + Please note that you can even provide ``None`` as a valid + default value. + + If ``default`` is not provided while registering using + :func:`parser.addini `, then a default value + based on the ``type`` parameter passed to + :func:`parser.addini ` will be returned. + The default values based on ``type`` are: + ``paths``, ``pathlist``, ``args`` and ``linelist`` : empty list ``[]`` + ``bool`` : ``False`` + ``string`` : empty string ``""`` + + If neither the ``default`` nor the ``type`` parameter is passed + while registering the configuration through + :func:`parser.addini `, then the configuration + is treated as a string and a default empty string '' is returned. + + If the specified name hasn't been registered through a prior + :func:`parser.addini ` call (usually from a + plugin), a ValueError is raised. + """ + try: + return self._inicache[name] + except KeyError: + self._inicache[name] = val = self._getini(name) + return val + + # Meant for easy monkeypatching by legacypath plugin. + # Can be inlined back (with no cover removed) once legacypath is gone. + def _getini_unknown_type(self, name: str, type: str, value: str | list[str]): + msg = f"unknown configuration type: {type}" + raise ValueError(msg, value) # pragma: no cover + + def _getini(self, name: str): + try: + description, type, default = self._parser._inidict[name] + except KeyError as e: + raise ValueError(f"unknown configuration value: {name!r}") from e + override_value = self._get_override_ini_value(name) + if override_value is None: + try: + value = self.inicfg[name] + except KeyError: + return default + else: + value = override_value + # Coerce the values based on types. + # + # Note: some coercions are only required if we are reading from .ini files, because + # the file format doesn't contain type information, but when reading from toml we will + # get either str or list of str values (see _parse_ini_config_from_pyproject_toml). + # For example: + # + # ini: + # a_line_list = "tests acceptance" + # in this case, we need to split the string to obtain a list of strings. + # + # toml: + # a_line_list = ["tests", "acceptance"] + # in this case, we already have a list ready to use. + # + if type == "paths": + dp = ( + self.inipath.parent + if self.inipath is not None + else self.invocation_params.dir + ) + input_values = shlex.split(value) if isinstance(value, str) else value + return [dp / x for x in input_values] + elif type == "args": + return shlex.split(value) if isinstance(value, str) else value + elif type == "linelist": + if isinstance(value, str): + return [t for t in map(lambda x: x.strip(), value.split("\n")) if t] + else: + return value + elif type == "bool": + return _strtobool(str(value).strip()) + elif type == "string": + return value + elif type is None: + return value + else: + return self._getini_unknown_type(name, type, value) + + def _getconftest_pathlist( + self, name: str, path: pathlib.Path + ) -> list[pathlib.Path] | None: + try: + mod, relroots = self.pluginmanager._rget_with_confmod(name, path) + except KeyError: + return None + assert mod.__file__ is not None + modpath = pathlib.Path(mod.__file__).parent + values: list[pathlib.Path] = [] + for relroot in relroots: + if isinstance(relroot, os.PathLike): + relroot = pathlib.Path(relroot) + else: + relroot = relroot.replace("/", os.sep) + relroot = absolutepath(modpath / relroot) + values.append(relroot) + return values + + def _get_override_ini_value(self, name: str) -> str | None: + value = None + # override_ini is a list of "ini=value" options. + # Always use the last item if multiple values are set for same ini-name, + # e.g. -o foo=bar1 -o foo=bar2 will set foo to bar2. + for ini_config in self._override_ini: + try: + key, user_ini_value = ini_config.split("=", 1) + except ValueError as e: + raise UsageError( + f"-o/--override-ini expects option=value style (got: {ini_config!r})." + ) from e + else: + if key == name: + value = user_ini_value + return value + + def getoption(self, name: str, default=notset, skip: bool = False): + """Return command line option value. + + :param name: Name of the option. You may also specify + the literal ``--OPT`` option instead of the "dest" option name. + :param default: Default value if no option of that name exists. + :param skip: If True, raise pytest.skip if option does not exists + or has a None value. + """ + name = self._opt2dest.get(name, name) + try: + val = getattr(self.option, name) + if val is None and skip: + raise AttributeError(name) + return val + except AttributeError as e: + if default is not notset: + return default + if skip: + import pytest + + pytest.skip(f"no {name!r} option found") + raise ValueError(f"no option named {name!r}") from e + + def getvalue(self, name: str, path=None): + """Deprecated, use getoption() instead.""" + return self.getoption(name) + + def getvalueorskip(self, name: str, path=None): + """Deprecated, use getoption(skip=True) instead.""" + return self.getoption(name, skip=True) + + #: Verbosity type for failed assertions (see :confval:`verbosity_assertions`). + VERBOSITY_ASSERTIONS: Final = "assertions" + #: Verbosity type for test case execution (see :confval:`verbosity_test_cases`). + VERBOSITY_TEST_CASES: Final = "test_cases" + _VERBOSITY_INI_DEFAULT: Final = "auto" + + def get_verbosity(self, verbosity_type: str | None = None) -> int: + r"""Retrieve the verbosity level for a fine-grained verbosity type. + + :param verbosity_type: Verbosity type to get level for. If a level is + configured for the given type, that value will be returned. If the + given type is not a known verbosity type, the global verbosity + level will be returned. If the given type is None (default), the + global verbosity level will be returned. + + To configure a level for a fine-grained verbosity type, the + configuration file should have a setting for the configuration name + and a numeric value for the verbosity level. A special value of "auto" + can be used to explicitly use the global verbosity level. + + Example: + + .. code-block:: ini + + # content of pytest.ini + [pytest] + verbosity_assertions = 2 + + .. code-block:: console + + pytest -v + + .. code-block:: python + + print(config.get_verbosity()) # 1 + print(config.get_verbosity(Config.VERBOSITY_ASSERTIONS)) # 2 + """ + global_level = self.getoption("verbose", default=0) + assert isinstance(global_level, int) + if verbosity_type is None: + return global_level + + ini_name = Config._verbosity_ini_name(verbosity_type) + if ini_name not in self._parser._inidict: + return global_level + + level = self.getini(ini_name) + if level == Config._VERBOSITY_INI_DEFAULT: + return global_level + + return int(level) + + @staticmethod + def _verbosity_ini_name(verbosity_type: str) -> str: + return f"verbosity_{verbosity_type}" + + @staticmethod + def _add_verbosity_ini(parser: Parser, verbosity_type: str, help: str) -> None: + """Add a output verbosity configuration option for the given output type. + + :param parser: Parser for command line arguments and ini-file values. + :param verbosity_type: Fine-grained verbosity category. + :param help: Description of the output this type controls. + + The value should be retrieved via a call to + :py:func:`config.get_verbosity(type) `. + """ + parser.addini( + Config._verbosity_ini_name(verbosity_type), + help=help, + type="string", + default=Config._VERBOSITY_INI_DEFAULT, + ) + + def _warn_about_missing_assertion(self, mode: str) -> None: + if not _assertion_supported(): + if mode == "plain": + warning_text = ( + "ASSERTIONS ARE NOT EXECUTED" + " and FAILING TESTS WILL PASS. Are you" + " using python -O?" + ) + else: + warning_text = ( + "assertions not in test modules or" + " plugins will be ignored" + " because assert statements are not executed " + "by the underlying Python interpreter " + "(are you using python -O?)\n" + ) + self.issue_config_time_warning( + PytestConfigWarning(warning_text), + stacklevel=3, + ) + + def _warn_about_skipped_plugins(self) -> None: + for module_name, msg in self.pluginmanager.skipped_plugins: + self.issue_config_time_warning( + PytestConfigWarning(f"skipped plugin {module_name!r}: {msg}"), + stacklevel=2, + ) + + +def _assertion_supported() -> bool: + try: + assert False + except AssertionError: + return True + else: + return False # type: ignore[unreachable] + + +def create_terminal_writer( + config: Config, file: TextIO | None = None +) -> TerminalWriter: + """Create a TerminalWriter instance configured according to the options + in the config object. + + Every code which requires a TerminalWriter object and has access to a + config object should use this function. + """ + tw = TerminalWriter(file=file) + + if config.option.color == "yes": + tw.hasmarkup = True + elif config.option.color == "no": + tw.hasmarkup = False + + if config.option.code_highlight == "yes": + tw.code_highlight = True + elif config.option.code_highlight == "no": + tw.code_highlight = False + + return tw + + +def _strtobool(val: str) -> bool: + """Convert a string representation of truth to True or False. + + True values are 'y', 'yes', 't', 'true', 'on', and '1'; false values + are 'n', 'no', 'f', 'false', 'off', and '0'. Raises ValueError if + 'val' is anything else. + + .. note:: Copied from distutils.util. + """ + val = val.lower() + if val in ("y", "yes", "t", "true", "on", "1"): + return True + elif val in ("n", "no", "f", "false", "off", "0"): + return False + else: + raise ValueError(f"invalid truth value {val!r}") + + +@lru_cache(maxsize=50) +def parse_warning_filter( + arg: str, *, escape: bool +) -> tuple[warnings._ActionKind, str, type[Warning], str, int]: + """Parse a warnings filter string. + + This is copied from warnings._setoption with the following changes: + + * Does not apply the filter. + * Escaping is optional. + * Raises UsageError so we get nice error messages on failure. + """ + __tracebackhide__ = True + error_template = dedent( + f"""\ + while parsing the following warning configuration: + + {arg} + + This error occurred: + + {{error}} + """ + ) + + parts = arg.split(":") + if len(parts) > 5: + doc_url = ( + "https://docs.python.org/3/library/warnings.html#describing-warning-filters" + ) + error = dedent( + f"""\ + Too many fields ({len(parts)}), expected at most 5 separated by colons: + + action:message:category:module:line + + For more information please consult: {doc_url} + """ + ) + raise UsageError(error_template.format(error=error)) + + while len(parts) < 5: + parts.append("") + action_, message, category_, module, lineno_ = (s.strip() for s in parts) + try: + action: warnings._ActionKind = warnings._getaction(action_) # type: ignore[attr-defined] + except warnings._OptionError as e: + raise UsageError(error_template.format(error=str(e))) from None + try: + category: type[Warning] = _resolve_warning_category(category_) + except Exception: + exc_info = ExceptionInfo.from_current() + exception_text = exc_info.getrepr(style="native") + raise UsageError(error_template.format(error=exception_text)) from None + if message and escape: + message = re.escape(message) + if module and escape: + module = re.escape(module) + r"\Z" + if lineno_: + try: + lineno = int(lineno_) + if lineno < 0: + raise ValueError("number is negative") + except ValueError as e: + raise UsageError( + error_template.format(error=f"invalid lineno {lineno_!r}: {e}") + ) from None + else: + lineno = 0 + return action, message, category, module, lineno + + +def _resolve_warning_category(category: str) -> type[Warning]: + """ + Copied from warnings._getcategory, but changed so it lets exceptions (specially ImportErrors) + propagate so we can get access to their tracebacks (#9218). + """ + __tracebackhide__ = True + if not category: + return Warning + + if "." not in category: + import builtins as m + + klass = category + else: + module, _, klass = category.rpartition(".") + m = __import__(module, None, None, [klass]) + cat = getattr(m, klass) + if not issubclass(cat, Warning): + raise UsageError(f"{cat} is not a Warning subclass") + return cast(Type[Warning], cat) + + +def apply_warning_filters( + config_filters: Iterable[str], cmdline_filters: Iterable[str] +) -> None: + """Applies pytest-configured filters to the warnings module""" + # Filters should have this precedence: cmdline options, config. + # Filters should be applied in the inverse order of precedence. + for arg in config_filters: + warnings.filterwarnings(*parse_warning_filter(arg, escape=False)) + + for arg in cmdline_filters: + warnings.filterwarnings(*parse_warning_filter(arg, escape=True)) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/config/argparsing.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/config/argparsing.py new file mode 100644 index 0000000..85aa463 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/config/argparsing.py @@ -0,0 +1,551 @@ +# mypy: allow-untyped-defs +from __future__ import annotations + +import argparse +from gettext import gettext +import os +import sys +from typing import Any +from typing import Callable +from typing import cast +from typing import final +from typing import List +from typing import Literal +from typing import Mapping +from typing import NoReturn +from typing import Sequence + +import _pytest._io +from _pytest.config.exceptions import UsageError +from _pytest.deprecated import check_ispytest + + +FILE_OR_DIR = "file_or_dir" + + +class NotSet: + def __repr__(self) -> str: + return "" + + +NOT_SET = NotSet() + + +@final +class Parser: + """Parser for command line arguments and ini-file values. + + :ivar extra_info: Dict of generic param -> value to display in case + there's an error processing the command line arguments. + """ + + prog: str | None = None + + def __init__( + self, + usage: str | None = None, + processopt: Callable[[Argument], None] | None = None, + *, + _ispytest: bool = False, + ) -> None: + check_ispytest(_ispytest) + self._anonymous = OptionGroup("Custom options", parser=self, _ispytest=True) + self._groups: list[OptionGroup] = [] + self._processopt = processopt + self._usage = usage + self._inidict: dict[str, tuple[str, str | None, Any]] = {} + self._ininames: list[str] = [] + self.extra_info: dict[str, Any] = {} + + def processoption(self, option: Argument) -> None: + if self._processopt: + if option.dest: + self._processopt(option) + + def getgroup( + self, name: str, description: str = "", after: str | None = None + ) -> OptionGroup: + """Get (or create) a named option Group. + + :param name: Name of the option group. + :param description: Long description for --help output. + :param after: Name of another group, used for ordering --help output. + :returns: The option group. + + The returned group object has an ``addoption`` method with the same + signature as :func:`parser.addoption ` but + will be shown in the respective group in the output of + ``pytest --help``. + """ + for group in self._groups: + if group.name == name: + return group + group = OptionGroup(name, description, parser=self, _ispytest=True) + i = 0 + for i, grp in enumerate(self._groups): + if grp.name == after: + break + self._groups.insert(i + 1, group) + return group + + def addoption(self, *opts: str, **attrs: Any) -> None: + """Register a command line option. + + :param opts: + Option names, can be short or long options. + :param attrs: + Same attributes as the argparse library's :meth:`add_argument() + ` function accepts. + + After command line parsing, options are available on the pytest config + object via ``config.option.NAME`` where ``NAME`` is usually set + by passing a ``dest`` attribute, for example + ``addoption("--long", dest="NAME", ...)``. + """ + self._anonymous.addoption(*opts, **attrs) + + def parse( + self, + args: Sequence[str | os.PathLike[str]], + namespace: argparse.Namespace | None = None, + ) -> argparse.Namespace: + from _pytest._argcomplete import try_argcomplete + + self.optparser = self._getparser() + try_argcomplete(self.optparser) + strargs = [os.fspath(x) for x in args] + return self.optparser.parse_args(strargs, namespace=namespace) + + def _getparser(self) -> MyOptionParser: + from _pytest._argcomplete import filescompleter + + optparser = MyOptionParser(self, self.extra_info, prog=self.prog) + groups = [*self._groups, self._anonymous] + for group in groups: + if group.options: + desc = group.description or group.name + arggroup = optparser.add_argument_group(desc) + for option in group.options: + n = option.names() + a = option.attrs() + arggroup.add_argument(*n, **a) + file_or_dir_arg = optparser.add_argument(FILE_OR_DIR, nargs="*") + # bash like autocompletion for dirs (appending '/') + # Type ignored because typeshed doesn't know about argcomplete. + file_or_dir_arg.completer = filescompleter # type: ignore + return optparser + + def parse_setoption( + self, + args: Sequence[str | os.PathLike[str]], + option: argparse.Namespace, + namespace: argparse.Namespace | None = None, + ) -> list[str]: + parsedoption = self.parse(args, namespace=namespace) + for name, value in parsedoption.__dict__.items(): + setattr(option, name, value) + return cast(List[str], getattr(parsedoption, FILE_OR_DIR)) + + def parse_known_args( + self, + args: Sequence[str | os.PathLike[str]], + namespace: argparse.Namespace | None = None, + ) -> argparse.Namespace: + """Parse the known arguments at this point. + + :returns: An argparse namespace object. + """ + return self.parse_known_and_unknown_args(args, namespace=namespace)[0] + + def parse_known_and_unknown_args( + self, + args: Sequence[str | os.PathLike[str]], + namespace: argparse.Namespace | None = None, + ) -> tuple[argparse.Namespace, list[str]]: + """Parse the known arguments at this point, and also return the + remaining unknown arguments. + + :returns: + A tuple containing an argparse namespace object for the known + arguments, and a list of the unknown arguments. + """ + optparser = self._getparser() + strargs = [os.fspath(x) for x in args] + return optparser.parse_known_args(strargs, namespace=namespace) + + def addini( + self, + name: str, + help: str, + type: Literal["string", "paths", "pathlist", "args", "linelist", "bool"] + | None = None, + default: Any = NOT_SET, + ) -> None: + """Register an ini-file option. + + :param name: + Name of the ini-variable. + :param type: + Type of the variable. Can be: + + * ``string``: a string + * ``bool``: a boolean + * ``args``: a list of strings, separated as in a shell + * ``linelist``: a list of strings, separated by line breaks + * ``paths``: a list of :class:`pathlib.Path`, separated as in a shell + * ``pathlist``: a list of ``py.path``, separated as in a shell + + For ``paths`` and ``pathlist`` types, they are considered relative to the ini-file. + In case the execution is happening without an ini-file defined, + they will be considered relative to the current working directory (for example with ``--override-ini``). + + .. versionadded:: 7.0 + The ``paths`` variable type. + + .. versionadded:: 8.1 + Use the current working directory to resolve ``paths`` and ``pathlist`` in the absence of an ini-file. + + Defaults to ``string`` if ``None`` or not passed. + :param default: + Default value if no ini-file option exists but is queried. + + The value of ini-variables can be retrieved via a call to + :py:func:`config.getini(name) `. + """ + assert type in (None, "string", "paths", "pathlist", "args", "linelist", "bool") + if default is NOT_SET: + default = get_ini_default_for_type(type) + + self._inidict[name] = (help, type, default) + self._ininames.append(name) + + +def get_ini_default_for_type( + type: Literal["string", "paths", "pathlist", "args", "linelist", "bool"] | None, +) -> Any: + """ + Used by addini to get the default value for a given ini-option type, when + default is not supplied. + """ + if type is None: + return "" + elif type in ("paths", "pathlist", "args", "linelist"): + return [] + elif type == "bool": + return False + else: + return "" + + +class ArgumentError(Exception): + """Raised if an Argument instance is created with invalid or + inconsistent arguments.""" + + def __init__(self, msg: str, option: Argument | str) -> None: + self.msg = msg + self.option_id = str(option) + + def __str__(self) -> str: + if self.option_id: + return f"option {self.option_id}: {self.msg}" + else: + return self.msg + + +class Argument: + """Class that mimics the necessary behaviour of optparse.Option. + + It's currently a least effort implementation and ignoring choices + and integer prefixes. + + https://docs.python.org/3/library/optparse.html#optparse-standard-option-types + """ + + def __init__(self, *names: str, **attrs: Any) -> None: + """Store params in private vars for use in add_argument.""" + self._attrs = attrs + self._short_opts: list[str] = [] + self._long_opts: list[str] = [] + try: + self.type = attrs["type"] + except KeyError: + pass + try: + # Attribute existence is tested in Config._processopt. + self.default = attrs["default"] + except KeyError: + pass + self._set_opt_strings(names) + dest: str | None = attrs.get("dest") + if dest: + self.dest = dest + elif self._long_opts: + self.dest = self._long_opts[0][2:].replace("-", "_") + else: + try: + self.dest = self._short_opts[0][1:] + except IndexError as e: + self.dest = "???" # Needed for the error repr. + raise ArgumentError("need a long or short option", self) from e + + def names(self) -> list[str]: + return self._short_opts + self._long_opts + + def attrs(self) -> Mapping[str, Any]: + # Update any attributes set by processopt. + attrs = "default dest help".split() + attrs.append(self.dest) + for attr in attrs: + try: + self._attrs[attr] = getattr(self, attr) + except AttributeError: + pass + return self._attrs + + def _set_opt_strings(self, opts: Sequence[str]) -> None: + """Directly from optparse. + + Might not be necessary as this is passed to argparse later on. + """ + for opt in opts: + if len(opt) < 2: + raise ArgumentError( + f"invalid option string {opt!r}: " + "must be at least two characters long", + self, + ) + elif len(opt) == 2: + if not (opt[0] == "-" and opt[1] != "-"): + raise ArgumentError( + f"invalid short option string {opt!r}: " + "must be of the form -x, (x any non-dash char)", + self, + ) + self._short_opts.append(opt) + else: + if not (opt[0:2] == "--" and opt[2] != "-"): + raise ArgumentError( + f"invalid long option string {opt!r}: " + "must start with --, followed by non-dash", + self, + ) + self._long_opts.append(opt) + + def __repr__(self) -> str: + args: list[str] = [] + if self._short_opts: + args += ["_short_opts: " + repr(self._short_opts)] + if self._long_opts: + args += ["_long_opts: " + repr(self._long_opts)] + args += ["dest: " + repr(self.dest)] + if hasattr(self, "type"): + args += ["type: " + repr(self.type)] + if hasattr(self, "default"): + args += ["default: " + repr(self.default)] + return "Argument({})".format(", ".join(args)) + + +class OptionGroup: + """A group of options shown in its own section.""" + + def __init__( + self, + name: str, + description: str = "", + parser: Parser | None = None, + *, + _ispytest: bool = False, + ) -> None: + check_ispytest(_ispytest) + self.name = name + self.description = description + self.options: list[Argument] = [] + self.parser = parser + + def addoption(self, *opts: str, **attrs: Any) -> None: + """Add an option to this group. + + If a shortened version of a long option is specified, it will + be suppressed in the help. ``addoption('--twowords', '--two-words')`` + results in help showing ``--two-words`` only, but ``--twowords`` gets + accepted **and** the automatic destination is in ``args.twowords``. + + :param opts: + Option names, can be short or long options. + :param attrs: + Same attributes as the argparse library's :meth:`add_argument() + ` function accepts. + """ + conflict = set(opts).intersection( + name for opt in self.options for name in opt.names() + ) + if conflict: + raise ValueError(f"option names {conflict} already added") + option = Argument(*opts, **attrs) + self._addoption_instance(option, shortupper=False) + + def _addoption(self, *opts: str, **attrs: Any) -> None: + option = Argument(*opts, **attrs) + self._addoption_instance(option, shortupper=True) + + def _addoption_instance(self, option: Argument, shortupper: bool = False) -> None: + if not shortupper: + for opt in option._short_opts: + if opt[0] == "-" and opt[1].islower(): + raise ValueError("lowercase shortoptions reserved") + if self.parser: + self.parser.processoption(option) + self.options.append(option) + + +class MyOptionParser(argparse.ArgumentParser): + def __init__( + self, + parser: Parser, + extra_info: dict[str, Any] | None = None, + prog: str | None = None, + ) -> None: + self._parser = parser + super().__init__( + prog=prog, + usage=parser._usage, + add_help=False, + formatter_class=DropShorterLongHelpFormatter, + allow_abbrev=False, + fromfile_prefix_chars="@", + ) + # extra_info is a dict of (param -> value) to display if there's + # an usage error to provide more contextual information to the user. + self.extra_info = extra_info if extra_info else {} + + def error(self, message: str) -> NoReturn: + """Transform argparse error message into UsageError.""" + msg = f"{self.prog}: error: {message}" + + if hasattr(self._parser, "_config_source_hint"): + msg = f"{msg} ({self._parser._config_source_hint})" + + raise UsageError(self.format_usage() + msg) + + # Type ignored because typeshed has a very complex type in the superclass. + def parse_args( # type: ignore + self, + args: Sequence[str] | None = None, + namespace: argparse.Namespace | None = None, + ) -> argparse.Namespace: + """Allow splitting of positional arguments.""" + parsed, unrecognized = self.parse_known_args(args, namespace) + if unrecognized: + for arg in unrecognized: + if arg and arg[0] == "-": + lines = [ + "unrecognized arguments: {}".format(" ".join(unrecognized)) + ] + for k, v in sorted(self.extra_info.items()): + lines.append(f" {k}: {v}") + self.error("\n".join(lines)) + getattr(parsed, FILE_OR_DIR).extend(unrecognized) + return parsed + + if sys.version_info < (3, 9): # pragma: no cover + # Backport of https://github.com/python/cpython/pull/14316 so we can + # disable long --argument abbreviations without breaking short flags. + def _parse_optional( + self, arg_string: str + ) -> tuple[argparse.Action | None, str, str | None] | None: + if not arg_string: + return None + if arg_string[0] not in self.prefix_chars: + return None + if arg_string in self._option_string_actions: + action = self._option_string_actions[arg_string] + return action, arg_string, None + if len(arg_string) == 1: + return None + if "=" in arg_string: + option_string, explicit_arg = arg_string.split("=", 1) + if option_string in self._option_string_actions: + action = self._option_string_actions[option_string] + return action, option_string, explicit_arg + if self.allow_abbrev or not arg_string.startswith("--"): + option_tuples = self._get_option_tuples(arg_string) + if len(option_tuples) > 1: + msg = gettext( + "ambiguous option: %(option)s could match %(matches)s" + ) + options = ", ".join(option for _, option, _ in option_tuples) + self.error(msg % {"option": arg_string, "matches": options}) + elif len(option_tuples) == 1: + (option_tuple,) = option_tuples + return option_tuple + if self._negative_number_matcher.match(arg_string): + if not self._has_negative_number_optionals: + return None + if " " in arg_string: + return None + return None, arg_string, None + + +class DropShorterLongHelpFormatter(argparse.HelpFormatter): + """Shorten help for long options that differ only in extra hyphens. + + - Collapse **long** options that are the same except for extra hyphens. + - Shortcut if there are only two options and one of them is a short one. + - Cache result on the action object as this is called at least 2 times. + """ + + def __init__(self, *args: Any, **kwargs: Any) -> None: + # Use more accurate terminal width. + if "width" not in kwargs: + kwargs["width"] = _pytest._io.get_terminal_width() + super().__init__(*args, **kwargs) + + def _format_action_invocation(self, action: argparse.Action) -> str: + orgstr = super()._format_action_invocation(action) + if orgstr and orgstr[0] != "-": # only optional arguments + return orgstr + res: str | None = getattr(action, "_formatted_action_invocation", None) + if res: + return res + options = orgstr.split(", ") + if len(options) == 2 and (len(options[0]) == 2 or len(options[1]) == 2): + # a shortcut for '-h, --help' or '--abc', '-a' + action._formatted_action_invocation = orgstr # type: ignore + return orgstr + return_list = [] + short_long: dict[str, str] = {} + for option in options: + if len(option) == 2 or option[2] == " ": + continue + if not option.startswith("--"): + raise ArgumentError( + f'long optional argument without "--": [{option}]', option + ) + xxoption = option[2:] + shortened = xxoption.replace("-", "") + if shortened not in short_long or len(short_long[shortened]) < len( + xxoption + ): + short_long[shortened] = xxoption + # now short_long has been filled out to the longest with dashes + # **and** we keep the right option ordering from add_argument + for option in options: + if len(option) == 2 or option[2] == " ": + return_list.append(option) + if option[2:] == short_long.get(option.replace("-", "")): + return_list.append(option.replace(" ", "=", 1)) + formatted_action_invocation = ", ".join(return_list) + action._formatted_action_invocation = formatted_action_invocation # type: ignore + return formatted_action_invocation + + def _split_lines(self, text, width): + """Wrap lines after splitting on original newlines. + + This allows to have explicit line breaks in the help text. + """ + import textwrap + + lines = [] + for line in text.splitlines(): + lines.extend(textwrap.wrap(line.strip(), width)) + return lines diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/config/compat.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/config/compat.py new file mode 100644 index 0000000..2856d85 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/config/compat.py @@ -0,0 +1,85 @@ +from __future__ import annotations + +import functools +from pathlib import Path +from typing import Any +from typing import Mapping +import warnings + +import pluggy + +from ..compat import LEGACY_PATH +from ..compat import legacy_path +from ..deprecated import HOOK_LEGACY_PATH_ARG + + +# hookname: (Path, LEGACY_PATH) +imply_paths_hooks: Mapping[str, tuple[str, str]] = { + "pytest_ignore_collect": ("collection_path", "path"), + "pytest_collect_file": ("file_path", "path"), + "pytest_pycollect_makemodule": ("module_path", "path"), + "pytest_report_header": ("start_path", "startdir"), + "pytest_report_collectionfinish": ("start_path", "startdir"), +} + + +def _check_path(path: Path, fspath: LEGACY_PATH) -> None: + if Path(fspath) != path: + raise ValueError( + f"Path({fspath!r}) != {path!r}\n" + "if both path and fspath are given they need to be equal" + ) + + +class PathAwareHookProxy: + """ + this helper wraps around hook callers + until pluggy supports fixingcalls, this one will do + + it currently doesn't return full hook caller proxies for fixed hooks, + this may have to be changed later depending on bugs + """ + + def __init__(self, hook_relay: pluggy.HookRelay) -> None: + self._hook_relay = hook_relay + + def __dir__(self) -> list[str]: + return dir(self._hook_relay) + + def __getattr__(self, key: str) -> pluggy.HookCaller: + hook: pluggy.HookCaller = getattr(self._hook_relay, key) + if key not in imply_paths_hooks: + self.__dict__[key] = hook + return hook + else: + path_var, fspath_var = imply_paths_hooks[key] + + @functools.wraps(hook) + def fixed_hook(**kw: Any) -> Any: + path_value: Path | None = kw.pop(path_var, None) + fspath_value: LEGACY_PATH | None = kw.pop(fspath_var, None) + if fspath_value is not None: + warnings.warn( + HOOK_LEGACY_PATH_ARG.format( + pylib_path_arg=fspath_var, pathlib_path_arg=path_var + ), + stacklevel=2, + ) + if path_value is not None: + if fspath_value is not None: + _check_path(path_value, fspath_value) + else: + fspath_value = legacy_path(path_value) + else: + assert fspath_value is not None + path_value = Path(fspath_value) + + kw[path_var] = path_value + kw[fspath_var] = fspath_value + return hook(**kw) + + fixed_hook.name = hook.name # type: ignore[attr-defined] + fixed_hook.spec = hook.spec # type: ignore[attr-defined] + fixed_hook.__name__ = key + self.__dict__[key] = fixed_hook + return fixed_hook # type: ignore[return-value] diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/config/exceptions.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/config/exceptions.py new file mode 100644 index 0000000..90108ec --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/config/exceptions.py @@ -0,0 +1,13 @@ +from __future__ import annotations + +from typing import final + + +@final +class UsageError(Exception): + """Error in pytest usage or invocation.""" + + +class PrintHelp(Exception): + """Raised when pytest should print its help to skip the rest of the + argument parsing and validation.""" diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/config/findpaths.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/config/findpaths.py new file mode 100644 index 0000000..ce4c990 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/config/findpaths.py @@ -0,0 +1,228 @@ +from __future__ import annotations + +import os +from pathlib import Path +import sys +from typing import Iterable +from typing import Sequence + +import iniconfig + +from .exceptions import UsageError +from _pytest.outcomes import fail +from _pytest.pathlib import absolutepath +from _pytest.pathlib import commonpath +from _pytest.pathlib import safe_exists + + +def _parse_ini_config(path: Path) -> iniconfig.IniConfig: + """Parse the given generic '.ini' file using legacy IniConfig parser, returning + the parsed object. + + Raise UsageError if the file cannot be parsed. + """ + try: + return iniconfig.IniConfig(str(path)) + except iniconfig.ParseError as exc: + raise UsageError(str(exc)) from exc + + +def load_config_dict_from_file( + filepath: Path, +) -> dict[str, str | list[str]] | None: + """Load pytest configuration from the given file path, if supported. + + Return None if the file does not contain valid pytest configuration. + """ + # Configuration from ini files are obtained from the [pytest] section, if present. + if filepath.suffix == ".ini": + iniconfig = _parse_ini_config(filepath) + + if "pytest" in iniconfig: + return dict(iniconfig["pytest"].items()) + else: + # "pytest.ini" files are always the source of configuration, even if empty. + if filepath.name == "pytest.ini": + return {} + + # '.cfg' files are considered if they contain a "[tool:pytest]" section. + elif filepath.suffix == ".cfg": + iniconfig = _parse_ini_config(filepath) + + if "tool:pytest" in iniconfig.sections: + return dict(iniconfig["tool:pytest"].items()) + elif "pytest" in iniconfig.sections: + # If a setup.cfg contains a "[pytest]" section, we raise a failure to indicate users that + # plain "[pytest]" sections in setup.cfg files is no longer supported (#3086). + fail(CFG_PYTEST_SECTION.format(filename="setup.cfg"), pytrace=False) + + # '.toml' files are considered if they contain a [tool.pytest.ini_options] table. + elif filepath.suffix == ".toml": + if sys.version_info >= (3, 11): + import tomllib + else: + import tomli as tomllib + + toml_text = filepath.read_text(encoding="utf-8") + try: + config = tomllib.loads(toml_text) + except tomllib.TOMLDecodeError as exc: + raise UsageError(f"{filepath}: {exc}") from exc + + result = config.get("tool", {}).get("pytest", {}).get("ini_options", None) + if result is not None: + # TOML supports richer data types than ini files (strings, arrays, floats, ints, etc), + # however we need to convert all scalar values to str for compatibility with the rest + # of the configuration system, which expects strings only. + def make_scalar(v: object) -> str | list[str]: + return v if isinstance(v, list) else str(v) + + return {k: make_scalar(v) for k, v in result.items()} + + return None + + +def locate_config( + invocation_dir: Path, + args: Iterable[Path], +) -> tuple[Path | None, Path | None, dict[str, str | list[str]]]: + """Search in the list of arguments for a valid ini-file for pytest, + and return a tuple of (rootdir, inifile, cfg-dict).""" + config_names = [ + "pytest.ini", + ".pytest.ini", + "pyproject.toml", + "tox.ini", + "setup.cfg", + ] + args = [x for x in args if not str(x).startswith("-")] + if not args: + args = [invocation_dir] + found_pyproject_toml: Path | None = None + for arg in args: + argpath = absolutepath(arg) + for base in (argpath, *argpath.parents): + for config_name in config_names: + p = base / config_name + if p.is_file(): + if p.name == "pyproject.toml" and found_pyproject_toml is None: + found_pyproject_toml = p + ini_config = load_config_dict_from_file(p) + if ini_config is not None: + return base, p, ini_config + if found_pyproject_toml is not None: + return found_pyproject_toml.parent, found_pyproject_toml, {} + return None, None, {} + + +def get_common_ancestor( + invocation_dir: Path, + paths: Iterable[Path], +) -> Path: + common_ancestor: Path | None = None + for path in paths: + if not path.exists(): + continue + if common_ancestor is None: + common_ancestor = path + else: + if common_ancestor in path.parents or path == common_ancestor: + continue + elif path in common_ancestor.parents: + common_ancestor = path + else: + shared = commonpath(path, common_ancestor) + if shared is not None: + common_ancestor = shared + if common_ancestor is None: + common_ancestor = invocation_dir + elif common_ancestor.is_file(): + common_ancestor = common_ancestor.parent + return common_ancestor + + +def get_dirs_from_args(args: Iterable[str]) -> list[Path]: + def is_option(x: str) -> bool: + return x.startswith("-") + + def get_file_part_from_node_id(x: str) -> str: + return x.split("::")[0] + + def get_dir_from_path(path: Path) -> Path: + if path.is_dir(): + return path + return path.parent + + # These look like paths but may not exist + possible_paths = ( + absolutepath(get_file_part_from_node_id(arg)) + for arg in args + if not is_option(arg) + ) + + return [get_dir_from_path(path) for path in possible_paths if safe_exists(path)] + + +CFG_PYTEST_SECTION = "[pytest] section in {filename} files is no longer supported, change to [tool:pytest] instead." + + +def determine_setup( + *, + inifile: str | None, + args: Sequence[str], + rootdir_cmd_arg: str | None, + invocation_dir: Path, +) -> tuple[Path, Path | None, dict[str, str | list[str]]]: + """Determine the rootdir, inifile and ini configuration values from the + command line arguments. + + :param inifile: + The `--inifile` command line argument, if given. + :param args: + The free command line arguments. + :param rootdir_cmd_arg: + The `--rootdir` command line argument, if given. + :param invocation_dir: + The working directory when pytest was invoked. + """ + rootdir = None + dirs = get_dirs_from_args(args) + if inifile: + inipath_ = absolutepath(inifile) + inipath: Path | None = inipath_ + inicfg = load_config_dict_from_file(inipath_) or {} + if rootdir_cmd_arg is None: + rootdir = inipath_.parent + else: + ancestor = get_common_ancestor(invocation_dir, dirs) + rootdir, inipath, inicfg = locate_config(invocation_dir, [ancestor]) + if rootdir is None and rootdir_cmd_arg is None: + for possible_rootdir in (ancestor, *ancestor.parents): + if (possible_rootdir / "setup.py").is_file(): + rootdir = possible_rootdir + break + else: + if dirs != [ancestor]: + rootdir, inipath, inicfg = locate_config(invocation_dir, dirs) + if rootdir is None: + rootdir = get_common_ancestor( + invocation_dir, [invocation_dir, ancestor] + ) + if is_fs_root(rootdir): + rootdir = ancestor + if rootdir_cmd_arg: + rootdir = absolutepath(os.path.expandvars(rootdir_cmd_arg)) + if not rootdir.is_dir(): + raise UsageError( + f"Directory '{rootdir}' not found. Check your '--rootdir' option." + ) + assert rootdir is not None + return rootdir, inipath, inicfg or {} + + +def is_fs_root(p: Path) -> bool: + r""" + Return True if the given path is pointing to the root of the + file system ("/" on Unix and "C:\\" on Windows for example). + """ + return os.path.splitdrive(str(p))[1] == os.sep diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/debugging.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/debugging.py new file mode 100644 index 0000000..2dfe321 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/debugging.py @@ -0,0 +1,385 @@ +# mypy: allow-untyped-defs +# ruff: noqa: T100 +"""Interactive debugging with PDB, the Python Debugger.""" + +from __future__ import annotations + +import argparse +import functools +import sys +import types +from typing import Any +from typing import Callable +from typing import Generator +import unittest + +from _pytest import outcomes +from _pytest._code import ExceptionInfo +from _pytest.capture import CaptureManager +from _pytest.config import Config +from _pytest.config import ConftestImportFailure +from _pytest.config import hookimpl +from _pytest.config import PytestPluginManager +from _pytest.config.argparsing import Parser +from _pytest.config.exceptions import UsageError +from _pytest.nodes import Node +from _pytest.reports import BaseReport +from _pytest.runner import CallInfo + + +def _validate_usepdb_cls(value: str) -> tuple[str, str]: + """Validate syntax of --pdbcls option.""" + try: + modname, classname = value.split(":") + except ValueError as e: + raise argparse.ArgumentTypeError( + f"{value!r} is not in the format 'modname:classname'" + ) from e + return (modname, classname) + + +def pytest_addoption(parser: Parser) -> None: + group = parser.getgroup("general") + group._addoption( + "--pdb", + dest="usepdb", + action="store_true", + help="Start the interactive Python debugger on errors or KeyboardInterrupt", + ) + group._addoption( + "--pdbcls", + dest="usepdb_cls", + metavar="modulename:classname", + type=_validate_usepdb_cls, + help="Specify a custom interactive Python debugger for use with --pdb." + "For example: --pdbcls=IPython.terminal.debugger:TerminalPdb", + ) + group._addoption( + "--trace", + dest="trace", + action="store_true", + help="Immediately break when running each test", + ) + + +def pytest_configure(config: Config) -> None: + import pdb + + if config.getvalue("trace"): + config.pluginmanager.register(PdbTrace(), "pdbtrace") + if config.getvalue("usepdb"): + config.pluginmanager.register(PdbInvoke(), "pdbinvoke") + + pytestPDB._saved.append( + (pdb.set_trace, pytestPDB._pluginmanager, pytestPDB._config) + ) + pdb.set_trace = pytestPDB.set_trace + pytestPDB._pluginmanager = config.pluginmanager + pytestPDB._config = config + + # NOTE: not using pytest_unconfigure, since it might get called although + # pytest_configure was not (if another plugin raises UsageError). + def fin() -> None: + ( + pdb.set_trace, + pytestPDB._pluginmanager, + pytestPDB._config, + ) = pytestPDB._saved.pop() + + config.add_cleanup(fin) + + +class pytestPDB: + """Pseudo PDB that defers to the real pdb.""" + + _pluginmanager: PytestPluginManager | None = None + _config: Config | None = None + _saved: list[ + tuple[Callable[..., None], PytestPluginManager | None, Config | None] + ] = [] + _recursive_debug = 0 + _wrapped_pdb_cls: tuple[type[Any], type[Any]] | None = None + + @classmethod + def _is_capturing(cls, capman: CaptureManager | None) -> str | bool: + if capman: + return capman.is_capturing() + return False + + @classmethod + def _import_pdb_cls(cls, capman: CaptureManager | None): + if not cls._config: + import pdb + + # Happens when using pytest.set_trace outside of a test. + return pdb.Pdb + + usepdb_cls = cls._config.getvalue("usepdb_cls") + + if cls._wrapped_pdb_cls and cls._wrapped_pdb_cls[0] == usepdb_cls: + return cls._wrapped_pdb_cls[1] + + if usepdb_cls: + modname, classname = usepdb_cls + + try: + __import__(modname) + mod = sys.modules[modname] + + # Handle --pdbcls=pdb:pdb.Pdb (useful e.g. with pdbpp). + parts = classname.split(".") + pdb_cls = getattr(mod, parts[0]) + for part in parts[1:]: + pdb_cls = getattr(pdb_cls, part) + except Exception as exc: + value = ":".join((modname, classname)) + raise UsageError( + f"--pdbcls: could not import {value!r}: {exc}" + ) from exc + else: + import pdb + + pdb_cls = pdb.Pdb + + wrapped_cls = cls._get_pdb_wrapper_class(pdb_cls, capman) + cls._wrapped_pdb_cls = (usepdb_cls, wrapped_cls) + return wrapped_cls + + @classmethod + def _get_pdb_wrapper_class(cls, pdb_cls, capman: CaptureManager | None): + import _pytest.config + + class PytestPdbWrapper(pdb_cls): + _pytest_capman = capman + _continued = False + + def do_debug(self, arg): + cls._recursive_debug += 1 + ret = super().do_debug(arg) + cls._recursive_debug -= 1 + return ret + + def do_continue(self, arg): + ret = super().do_continue(arg) + if cls._recursive_debug == 0: + assert cls._config is not None + tw = _pytest.config.create_terminal_writer(cls._config) + tw.line() + + capman = self._pytest_capman + capturing = pytestPDB._is_capturing(capman) + if capturing: + if capturing == "global": + tw.sep(">", "PDB continue (IO-capturing resumed)") + else: + tw.sep( + ">", + f"PDB continue (IO-capturing resumed for {capturing})", + ) + assert capman is not None + capman.resume() + else: + tw.sep(">", "PDB continue") + assert cls._pluginmanager is not None + cls._pluginmanager.hook.pytest_leave_pdb(config=cls._config, pdb=self) + self._continued = True + return ret + + do_c = do_cont = do_continue + + def do_quit(self, arg): + """Raise Exit outcome when quit command is used in pdb. + + This is a bit of a hack - it would be better if BdbQuit + could be handled, but this would require to wrap the + whole pytest run, and adjust the report etc. + """ + ret = super().do_quit(arg) + + if cls._recursive_debug == 0: + outcomes.exit("Quitting debugger") + + return ret + + do_q = do_quit + do_exit = do_quit + + def setup(self, f, tb): + """Suspend on setup(). + + Needed after do_continue resumed, and entering another + breakpoint again. + """ + ret = super().setup(f, tb) + if not ret and self._continued: + # pdb.setup() returns True if the command wants to exit + # from the interaction: do not suspend capturing then. + if self._pytest_capman: + self._pytest_capman.suspend_global_capture(in_=True) + return ret + + def get_stack(self, f, t): + stack, i = super().get_stack(f, t) + if f is None: + # Find last non-hidden frame. + i = max(0, len(stack) - 1) + while i and stack[i][0].f_locals.get("__tracebackhide__", False): + i -= 1 + return stack, i + + return PytestPdbWrapper + + @classmethod + def _init_pdb(cls, method, *args, **kwargs): + """Initialize PDB debugging, dropping any IO capturing.""" + import _pytest.config + + if cls._pluginmanager is None: + capman: CaptureManager | None = None + else: + capman = cls._pluginmanager.getplugin("capturemanager") + if capman: + capman.suspend(in_=True) + + if cls._config: + tw = _pytest.config.create_terminal_writer(cls._config) + tw.line() + + if cls._recursive_debug == 0: + # Handle header similar to pdb.set_trace in py37+. + header = kwargs.pop("header", None) + if header is not None: + tw.sep(">", header) + else: + capturing = cls._is_capturing(capman) + if capturing == "global": + tw.sep(">", f"PDB {method} (IO-capturing turned off)") + elif capturing: + tw.sep( + ">", + f"PDB {method} (IO-capturing turned off for {capturing})", + ) + else: + tw.sep(">", f"PDB {method}") + + _pdb = cls._import_pdb_cls(capman)(**kwargs) + + if cls._pluginmanager: + cls._pluginmanager.hook.pytest_enter_pdb(config=cls._config, pdb=_pdb) + return _pdb + + @classmethod + def set_trace(cls, *args, **kwargs) -> None: + """Invoke debugging via ``Pdb.set_trace``, dropping any IO capturing.""" + frame = sys._getframe().f_back + _pdb = cls._init_pdb("set_trace", *args, **kwargs) + _pdb.set_trace(frame) + + +class PdbInvoke: + def pytest_exception_interact( + self, node: Node, call: CallInfo[Any], report: BaseReport + ) -> None: + capman = node.config.pluginmanager.getplugin("capturemanager") + if capman: + capman.suspend_global_capture(in_=True) + out, err = capman.read_global_capture() + sys.stdout.write(out) + sys.stdout.write(err) + assert call.excinfo is not None + + if not isinstance(call.excinfo.value, unittest.SkipTest): + _enter_pdb(node, call.excinfo, report) + + def pytest_internalerror(self, excinfo: ExceptionInfo[BaseException]) -> None: + tb = _postmortem_traceback(excinfo) + post_mortem(tb) + + +class PdbTrace: + @hookimpl(wrapper=True) + def pytest_pyfunc_call(self, pyfuncitem) -> Generator[None, object, object]: + wrap_pytest_function_for_tracing(pyfuncitem) + return (yield) + + +def wrap_pytest_function_for_tracing(pyfuncitem) -> None: + """Change the Python function object of the given Function item by a + wrapper which actually enters pdb before calling the python function + itself, effectively leaving the user in the pdb prompt in the first + statement of the function.""" + _pdb = pytestPDB._init_pdb("runcall") + testfunction = pyfuncitem.obj + + # we can't just return `partial(pdb.runcall, testfunction)` because (on + # python < 3.7.4) runcall's first param is `func`, which means we'd get + # an exception if one of the kwargs to testfunction was called `func`. + @functools.wraps(testfunction) + def wrapper(*args, **kwargs) -> None: + func = functools.partial(testfunction, *args, **kwargs) + _pdb.runcall(func) + + pyfuncitem.obj = wrapper + + +def maybe_wrap_pytest_function_for_tracing(pyfuncitem) -> None: + """Wrap the given pytestfunct item for tracing support if --trace was given in + the command line.""" + if pyfuncitem.config.getvalue("trace"): + wrap_pytest_function_for_tracing(pyfuncitem) + + +def _enter_pdb( + node: Node, excinfo: ExceptionInfo[BaseException], rep: BaseReport +) -> BaseReport: + # XXX we reuse the TerminalReporter's terminalwriter + # because this seems to avoid some encoding related troubles + # for not completely clear reasons. + tw = node.config.pluginmanager.getplugin("terminalreporter")._tw + tw.line() + + showcapture = node.config.option.showcapture + + for sectionname, content in ( + ("stdout", rep.capstdout), + ("stderr", rep.capstderr), + ("log", rep.caplog), + ): + if showcapture in (sectionname, "all") and content: + tw.sep(">", "captured " + sectionname) + if content[-1:] == "\n": + content = content[:-1] + tw.line(content) + + tw.sep(">", "traceback") + rep.toterminal(tw) + tw.sep(">", "entering PDB") + tb = _postmortem_traceback(excinfo) + rep._pdbshown = True # type: ignore[attr-defined] + post_mortem(tb) + return rep + + +def _postmortem_traceback(excinfo: ExceptionInfo[BaseException]) -> types.TracebackType: + from doctest import UnexpectedException + + if isinstance(excinfo.value, UnexpectedException): + # A doctest.UnexpectedException is not useful for post_mortem. + # Use the underlying exception instead: + return excinfo.value.exc_info[2] + elif isinstance(excinfo.value, ConftestImportFailure): + # A config.ConftestImportFailure is not useful for post_mortem. + # Use the underlying exception instead: + assert excinfo.value.cause.__traceback__ is not None + return excinfo.value.cause.__traceback__ + else: + assert excinfo._excinfo is not None + return excinfo._excinfo[2] + + +def post_mortem(t: types.TracebackType) -> None: + p = pytestPDB._init_pdb("post_mortem") + p.reset() + p.interaction(None, t) + if p.quitting: + outcomes.exit("Quitting debugger") diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/deprecated.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/deprecated.py new file mode 100644 index 0000000..a605c24 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/deprecated.py @@ -0,0 +1,91 @@ +"""Deprecation messages and bits of code used elsewhere in the codebase that +is planned to be removed in the next pytest release. + +Keeping it in a central location makes it easy to track what is deprecated and should +be removed when the time comes. + +All constants defined in this module should be either instances of +:class:`PytestWarning`, or :class:`UnformattedWarning` +in case of warnings which need to format their messages. +""" + +from __future__ import annotations + +from warnings import warn + +from _pytest.warning_types import PytestDeprecationWarning +from _pytest.warning_types import PytestRemovedIn9Warning +from _pytest.warning_types import UnformattedWarning + + +# set of plugins which have been integrated into the core; we use this list to ignore +# them during registration to avoid conflicts +DEPRECATED_EXTERNAL_PLUGINS = { + "pytest_catchlog", + "pytest_capturelog", + "pytest_faulthandler", +} + + +# This can be* removed pytest 8, but it's harmless and common, so no rush to remove. +# * If you're in the future: "could have been". +YIELD_FIXTURE = PytestDeprecationWarning( + "@pytest.yield_fixture is deprecated.\n" + "Use @pytest.fixture instead; they are the same." +) + +# This deprecation is never really meant to be removed. +PRIVATE = PytestDeprecationWarning("A private pytest class or function was used.") + + +HOOK_LEGACY_PATH_ARG = UnformattedWarning( + PytestRemovedIn9Warning, + "The ({pylib_path_arg}: py.path.local) argument is deprecated, please use ({pathlib_path_arg}: pathlib.Path)\n" + "see https://docs.pytest.org/en/latest/deprecations.html" + "#py-path-local-arguments-for-hooks-replaced-with-pathlib-path", +) + +NODE_CTOR_FSPATH_ARG = UnformattedWarning( + PytestRemovedIn9Warning, + "The (fspath: py.path.local) argument to {node_type_name} is deprecated. " + "Please use the (path: pathlib.Path) argument instead.\n" + "See https://docs.pytest.org/en/latest/deprecations.html" + "#fspath-argument-for-node-constructors-replaced-with-pathlib-path", +) + +HOOK_LEGACY_MARKING = UnformattedWarning( + PytestDeprecationWarning, + "The hook{type} {fullname} uses old-style configuration options (marks or attributes).\n" + "Please use the pytest.hook{type}({hook_opts}) decorator instead\n" + " to configure the hooks.\n" + " See https://docs.pytest.org/en/latest/deprecations.html" + "#configuring-hook-specs-impls-using-markers", +) + +MARKED_FIXTURE = PytestRemovedIn9Warning( + "Marks applied to fixtures have no effect\n" + "See docs: https://docs.pytest.org/en/stable/deprecations.html#applying-a-mark-to-a-fixture-function" +) + +# You want to make some `__init__` or function "private". +# +# def my_private_function(some, args): +# ... +# +# Do this: +# +# def my_private_function(some, args, *, _ispytest: bool = False): +# check_ispytest(_ispytest) +# ... +# +# Change all internal/allowed calls to +# +# my_private_function(some, args, _ispytest=True) +# +# All other calls will get the default _ispytest=False and trigger +# the warning (possibly error in the future). + + +def check_ispytest(ispytest: bool) -> None: + if not ispytest: + warn(PRIVATE, stacklevel=3) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/doctest.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/doctest.py new file mode 100644 index 0000000..384dea9 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/doctest.py @@ -0,0 +1,755 @@ +# mypy: allow-untyped-defs +"""Discover and run doctests in modules and test files.""" + +from __future__ import annotations + +import bdb +from contextlib import contextmanager +import functools +import inspect +import os +from pathlib import Path +import platform +import sys +import traceback +import types +from typing import Any +from typing import Callable +from typing import Generator +from typing import Iterable +from typing import Pattern +from typing import Sequence +from typing import TYPE_CHECKING +import warnings + +from _pytest import outcomes +from _pytest._code.code import ExceptionInfo +from _pytest._code.code import ReprFileLocation +from _pytest._code.code import TerminalRepr +from _pytest._io import TerminalWriter +from _pytest.compat import safe_getattr +from _pytest.config import Config +from _pytest.config.argparsing import Parser +from _pytest.fixtures import fixture +from _pytest.fixtures import TopRequest +from _pytest.nodes import Collector +from _pytest.nodes import Item +from _pytest.outcomes import OutcomeException +from _pytest.outcomes import skip +from _pytest.pathlib import fnmatch_ex +from _pytest.python import Module +from _pytest.python_api import approx +from _pytest.warning_types import PytestWarning + + +if TYPE_CHECKING: + import doctest + + from typing_extensions import Self + +DOCTEST_REPORT_CHOICE_NONE = "none" +DOCTEST_REPORT_CHOICE_CDIFF = "cdiff" +DOCTEST_REPORT_CHOICE_NDIFF = "ndiff" +DOCTEST_REPORT_CHOICE_UDIFF = "udiff" +DOCTEST_REPORT_CHOICE_ONLY_FIRST_FAILURE = "only_first_failure" + +DOCTEST_REPORT_CHOICES = ( + DOCTEST_REPORT_CHOICE_NONE, + DOCTEST_REPORT_CHOICE_CDIFF, + DOCTEST_REPORT_CHOICE_NDIFF, + DOCTEST_REPORT_CHOICE_UDIFF, + DOCTEST_REPORT_CHOICE_ONLY_FIRST_FAILURE, +) + +# Lazy definition of runner class +RUNNER_CLASS = None +# Lazy definition of output checker class +CHECKER_CLASS: type[doctest.OutputChecker] | None = None + + +def pytest_addoption(parser: Parser) -> None: + parser.addini( + "doctest_optionflags", + "Option flags for doctests", + type="args", + default=["ELLIPSIS"], + ) + parser.addini( + "doctest_encoding", "Encoding used for doctest files", default="utf-8" + ) + group = parser.getgroup("collect") + group.addoption( + "--doctest-modules", + action="store_true", + default=False, + help="Run doctests in all .py modules", + dest="doctestmodules", + ) + group.addoption( + "--doctest-report", + type=str.lower, + default="udiff", + help="Choose another output format for diffs on doctest failure", + choices=DOCTEST_REPORT_CHOICES, + dest="doctestreport", + ) + group.addoption( + "--doctest-glob", + action="append", + default=[], + metavar="pat", + help="Doctests file matching pattern, default: test*.txt", + dest="doctestglob", + ) + group.addoption( + "--doctest-ignore-import-errors", + action="store_true", + default=False, + help="Ignore doctest collection errors", + dest="doctest_ignore_import_errors", + ) + group.addoption( + "--doctest-continue-on-failure", + action="store_true", + default=False, + help="For a given doctest, continue to run after the first failure", + dest="doctest_continue_on_failure", + ) + + +def pytest_unconfigure() -> None: + global RUNNER_CLASS + + RUNNER_CLASS = None + + +def pytest_collect_file( + file_path: Path, + parent: Collector, +) -> DoctestModule | DoctestTextfile | None: + config = parent.config + if file_path.suffix == ".py": + if config.option.doctestmodules and not any( + (_is_setup_py(file_path), _is_main_py(file_path)) + ): + return DoctestModule.from_parent(parent, path=file_path) + elif _is_doctest(config, file_path, parent): + return DoctestTextfile.from_parent(parent, path=file_path) + return None + + +def _is_setup_py(path: Path) -> bool: + if path.name != "setup.py": + return False + contents = path.read_bytes() + return b"setuptools" in contents or b"distutils" in contents + + +def _is_doctest(config: Config, path: Path, parent: Collector) -> bool: + if path.suffix in (".txt", ".rst") and parent.session.isinitpath(path): + return True + globs = config.getoption("doctestglob") or ["test*.txt"] + return any(fnmatch_ex(glob, path) for glob in globs) + + +def _is_main_py(path: Path) -> bool: + return path.name == "__main__.py" + + +class ReprFailDoctest(TerminalRepr): + def __init__( + self, reprlocation_lines: Sequence[tuple[ReprFileLocation, Sequence[str]]] + ) -> None: + self.reprlocation_lines = reprlocation_lines + + def toterminal(self, tw: TerminalWriter) -> None: + for reprlocation, lines in self.reprlocation_lines: + for line in lines: + tw.line(line) + reprlocation.toterminal(tw) + + +class MultipleDoctestFailures(Exception): + def __init__(self, failures: Sequence[doctest.DocTestFailure]) -> None: + super().__init__() + self.failures = failures + + +def _init_runner_class() -> type[doctest.DocTestRunner]: + import doctest + + class PytestDoctestRunner(doctest.DebugRunner): + """Runner to collect failures. + + Note that the out variable in this case is a list instead of a + stdout-like object. + """ + + def __init__( + self, + checker: doctest.OutputChecker | None = None, + verbose: bool | None = None, + optionflags: int = 0, + continue_on_failure: bool = True, + ) -> None: + super().__init__(checker=checker, verbose=verbose, optionflags=optionflags) + self.continue_on_failure = continue_on_failure + + def report_failure( + self, + out, + test: doctest.DocTest, + example: doctest.Example, + got: str, + ) -> None: + failure = doctest.DocTestFailure(test, example, got) + if self.continue_on_failure: + out.append(failure) + else: + raise failure + + def report_unexpected_exception( + self, + out, + test: doctest.DocTest, + example: doctest.Example, + exc_info: tuple[type[BaseException], BaseException, types.TracebackType], + ) -> None: + if isinstance(exc_info[1], OutcomeException): + raise exc_info[1] + if isinstance(exc_info[1], bdb.BdbQuit): + outcomes.exit("Quitting debugger") + failure = doctest.UnexpectedException(test, example, exc_info) + if self.continue_on_failure: + out.append(failure) + else: + raise failure + + return PytestDoctestRunner + + +def _get_runner( + checker: doctest.OutputChecker | None = None, + verbose: bool | None = None, + optionflags: int = 0, + continue_on_failure: bool = True, +) -> doctest.DocTestRunner: + # We need this in order to do a lazy import on doctest + global RUNNER_CLASS + if RUNNER_CLASS is None: + RUNNER_CLASS = _init_runner_class() + # Type ignored because the continue_on_failure argument is only defined on + # PytestDoctestRunner, which is lazily defined so can't be used as a type. + return RUNNER_CLASS( # type: ignore + checker=checker, + verbose=verbose, + optionflags=optionflags, + continue_on_failure=continue_on_failure, + ) + + +class DoctestItem(Item): + def __init__( + self, + name: str, + parent: DoctestTextfile | DoctestModule, + runner: doctest.DocTestRunner, + dtest: doctest.DocTest, + ) -> None: + super().__init__(name, parent) + self.runner = runner + self.dtest = dtest + + # Stuff needed for fixture support. + self.obj = None + fm = self.session._fixturemanager + fixtureinfo = fm.getfixtureinfo(node=self, func=None, cls=None) + self._fixtureinfo = fixtureinfo + self.fixturenames = fixtureinfo.names_closure + self._initrequest() + + @classmethod + def from_parent( # type: ignore[override] + cls, + parent: DoctestTextfile | DoctestModule, + *, + name: str, + runner: doctest.DocTestRunner, + dtest: doctest.DocTest, + ) -> Self: + # incompatible signature due to imposed limits on subclass + """The public named constructor.""" + return super().from_parent(name=name, parent=parent, runner=runner, dtest=dtest) + + def _initrequest(self) -> None: + self.funcargs: dict[str, object] = {} + self._request = TopRequest(self, _ispytest=True) # type: ignore[arg-type] + + def setup(self) -> None: + self._request._fillfixtures() + globs = dict(getfixture=self._request.getfixturevalue) + for name, value in self._request.getfixturevalue("doctest_namespace").items(): + globs[name] = value + self.dtest.globs.update(globs) + + def runtest(self) -> None: + _check_all_skipped(self.dtest) + self._disable_output_capturing_for_darwin() + failures: list[doctest.DocTestFailure] = [] + # Type ignored because we change the type of `out` from what + # doctest expects. + self.runner.run(self.dtest, out=failures) # type: ignore[arg-type] + if failures: + raise MultipleDoctestFailures(failures) + + def _disable_output_capturing_for_darwin(self) -> None: + """Disable output capturing. Otherwise, stdout is lost to doctest (#985).""" + if platform.system() != "Darwin": + return + capman = self.config.pluginmanager.getplugin("capturemanager") + if capman: + capman.suspend_global_capture(in_=True) + out, err = capman.read_global_capture() + sys.stdout.write(out) + sys.stderr.write(err) + + # TODO: Type ignored -- breaks Liskov Substitution. + def repr_failure( # type: ignore[override] + self, + excinfo: ExceptionInfo[BaseException], + ) -> str | TerminalRepr: + import doctest + + failures: ( + Sequence[doctest.DocTestFailure | doctest.UnexpectedException] | None + ) = None + if isinstance( + excinfo.value, (doctest.DocTestFailure, doctest.UnexpectedException) + ): + failures = [excinfo.value] + elif isinstance(excinfo.value, MultipleDoctestFailures): + failures = excinfo.value.failures + + if failures is None: + return super().repr_failure(excinfo) + + reprlocation_lines = [] + for failure in failures: + example = failure.example + test = failure.test + filename = test.filename + if test.lineno is None: + lineno = None + else: + lineno = test.lineno + example.lineno + 1 + message = type(failure).__name__ + # TODO: ReprFileLocation doesn't expect a None lineno. + reprlocation = ReprFileLocation(filename, lineno, message) # type: ignore[arg-type] + checker = _get_checker() + report_choice = _get_report_choice(self.config.getoption("doctestreport")) + if lineno is not None: + assert failure.test.docstring is not None + lines = failure.test.docstring.splitlines(False) + # add line numbers to the left of the error message + assert test.lineno is not None + lines = [ + "%03d %s" % (i + test.lineno + 1, x) for (i, x) in enumerate(lines) + ] + # trim docstring error lines to 10 + lines = lines[max(example.lineno - 9, 0) : example.lineno + 1] + else: + lines = [ + "EXAMPLE LOCATION UNKNOWN, not showing all tests of that example" + ] + indent = ">>>" + for line in example.source.splitlines(): + lines.append(f"??? {indent} {line}") + indent = "..." + if isinstance(failure, doctest.DocTestFailure): + lines += checker.output_difference( + example, failure.got, report_choice + ).split("\n") + else: + inner_excinfo = ExceptionInfo.from_exc_info(failure.exc_info) + lines += [f"UNEXPECTED EXCEPTION: {inner_excinfo.value!r}"] + lines += [ + x.strip("\n") for x in traceback.format_exception(*failure.exc_info) + ] + reprlocation_lines.append((reprlocation, lines)) + return ReprFailDoctest(reprlocation_lines) + + def reportinfo(self) -> tuple[os.PathLike[str] | str, int | None, str]: + return self.path, self.dtest.lineno, f"[doctest] {self.name}" + + +def _get_flag_lookup() -> dict[str, int]: + import doctest + + return dict( + DONT_ACCEPT_TRUE_FOR_1=doctest.DONT_ACCEPT_TRUE_FOR_1, + DONT_ACCEPT_BLANKLINE=doctest.DONT_ACCEPT_BLANKLINE, + NORMALIZE_WHITESPACE=doctest.NORMALIZE_WHITESPACE, + ELLIPSIS=doctest.ELLIPSIS, + IGNORE_EXCEPTION_DETAIL=doctest.IGNORE_EXCEPTION_DETAIL, + COMPARISON_FLAGS=doctest.COMPARISON_FLAGS, + ALLOW_UNICODE=_get_allow_unicode_flag(), + ALLOW_BYTES=_get_allow_bytes_flag(), + NUMBER=_get_number_flag(), + ) + + +def get_optionflags(config: Config) -> int: + optionflags_str = config.getini("doctest_optionflags") + flag_lookup_table = _get_flag_lookup() + flag_acc = 0 + for flag in optionflags_str: + flag_acc |= flag_lookup_table[flag] + return flag_acc + + +def _get_continue_on_failure(config: Config) -> bool: + continue_on_failure: bool = config.getvalue("doctest_continue_on_failure") + if continue_on_failure: + # We need to turn off this if we use pdb since we should stop at + # the first failure. + if config.getvalue("usepdb"): + continue_on_failure = False + return continue_on_failure + + +class DoctestTextfile(Module): + obj = None + + def collect(self) -> Iterable[DoctestItem]: + import doctest + + # Inspired by doctest.testfile; ideally we would use it directly, + # but it doesn't support passing a custom checker. + encoding = self.config.getini("doctest_encoding") + text = self.path.read_text(encoding) + filename = str(self.path) + name = self.path.name + globs = {"__name__": "__main__"} + + optionflags = get_optionflags(self.config) + + runner = _get_runner( + verbose=False, + optionflags=optionflags, + checker=_get_checker(), + continue_on_failure=_get_continue_on_failure(self.config), + ) + + parser = doctest.DocTestParser() + test = parser.get_doctest(text, globs, name, filename, 0) + if test.examples: + yield DoctestItem.from_parent( + self, name=test.name, runner=runner, dtest=test + ) + + +def _check_all_skipped(test: doctest.DocTest) -> None: + """Raise pytest.skip() if all examples in the given DocTest have the SKIP + option set.""" + import doctest + + all_skipped = all(x.options.get(doctest.SKIP, False) for x in test.examples) + if all_skipped: + skip("all tests skipped by +SKIP option") + + +def _is_mocked(obj: object) -> bool: + """Return if an object is possibly a mock object by checking the + existence of a highly improbable attribute.""" + return ( + safe_getattr(obj, "pytest_mock_example_attribute_that_shouldnt_exist", None) + is not None + ) + + +@contextmanager +def _patch_unwrap_mock_aware() -> Generator[None]: + """Context manager which replaces ``inspect.unwrap`` with a version + that's aware of mock objects and doesn't recurse into them.""" + real_unwrap = inspect.unwrap + + def _mock_aware_unwrap( + func: Callable[..., Any], *, stop: Callable[[Any], Any] | None = None + ) -> Any: + try: + if stop is None or stop is _is_mocked: + return real_unwrap(func, stop=_is_mocked) + _stop = stop + return real_unwrap(func, stop=lambda obj: _is_mocked(obj) or _stop(func)) + except Exception as e: + warnings.warn( + f"Got {e!r} when unwrapping {func!r}. This is usually caused " + "by a violation of Python's object protocol; see e.g. " + "https://github.com/pytest-dev/pytest/issues/5080", + PytestWarning, + ) + raise + + inspect.unwrap = _mock_aware_unwrap + try: + yield + finally: + inspect.unwrap = real_unwrap + + +class DoctestModule(Module): + def collect(self) -> Iterable[DoctestItem]: + import doctest + + class MockAwareDocTestFinder(doctest.DocTestFinder): + py_ver_info_minor = sys.version_info[:2] + is_find_lineno_broken = ( + py_ver_info_minor < (3, 11) + or (py_ver_info_minor == (3, 11) and sys.version_info.micro < 9) + or (py_ver_info_minor == (3, 12) and sys.version_info.micro < 3) + ) + if is_find_lineno_broken: + + def _find_lineno(self, obj, source_lines): + """On older Pythons, doctest code does not take into account + `@property`. https://github.com/python/cpython/issues/61648 + + Moreover, wrapped Doctests need to be unwrapped so the correct + line number is returned. #8796 + """ + if isinstance(obj, property): + obj = getattr(obj, "fget", obj) + + if hasattr(obj, "__wrapped__"): + # Get the main obj in case of it being wrapped + obj = inspect.unwrap(obj) + + # Type ignored because this is a private function. + return super()._find_lineno( # type:ignore[misc] + obj, + source_lines, + ) + + if sys.version_info < (3, 10): + + def _find( + self, tests, obj, name, module, source_lines, globs, seen + ) -> None: + """Override _find to work around issue in stdlib. + + https://github.com/pytest-dev/pytest/issues/3456 + https://github.com/python/cpython/issues/69718 + """ + if _is_mocked(obj): + return # pragma: no cover + with _patch_unwrap_mock_aware(): + # Type ignored because this is a private function. + super()._find( # type:ignore[misc] + tests, obj, name, module, source_lines, globs, seen + ) + + if sys.version_info < (3, 13): + + def _from_module(self, module, object): + """`cached_property` objects are never considered a part + of the 'current module'. As such they are skipped by doctest. + Here we override `_from_module` to check the underlying + function instead. https://github.com/python/cpython/issues/107995 + """ + if isinstance(object, functools.cached_property): + object = object.func + + # Type ignored because this is a private function. + return super()._from_module(module, object) # type: ignore[misc] + + try: + module = self.obj + except Collector.CollectError: + if self.config.getvalue("doctest_ignore_import_errors"): + skip(f"unable to import module {self.path!r}") + else: + raise + + # While doctests currently don't support fixtures directly, we still + # need to pick up autouse fixtures. + self.session._fixturemanager.parsefactories(self) + + # Uses internal doctest module parsing mechanism. + finder = MockAwareDocTestFinder() + optionflags = get_optionflags(self.config) + runner = _get_runner( + verbose=False, + optionflags=optionflags, + checker=_get_checker(), + continue_on_failure=_get_continue_on_failure(self.config), + ) + + for test in finder.find(module, module.__name__): + if test.examples: # skip empty doctests + yield DoctestItem.from_parent( + self, name=test.name, runner=runner, dtest=test + ) + + +def _init_checker_class() -> type[doctest.OutputChecker]: + import doctest + import re + + class LiteralsOutputChecker(doctest.OutputChecker): + # Based on doctest_nose_plugin.py from the nltk project + # (https://github.com/nltk/nltk) and on the "numtest" doctest extension + # by Sebastien Boisgerault (https://github.com/boisgera/numtest). + + _unicode_literal_re = re.compile(r"(\W|^)[uU]([rR]?[\'\"])", re.UNICODE) + _bytes_literal_re = re.compile(r"(\W|^)[bB]([rR]?[\'\"])", re.UNICODE) + _number_re = re.compile( + r""" + (?P + (?P + (?P [+-]?\d*)\.(?P\d+) + | + (?P [+-]?\d+)\. + ) + (?: + [Ee] + (?P [+-]?\d+) + )? + | + (?P [+-]?\d+) + (?: + [Ee] + (?P [+-]?\d+) + ) + ) + """, + re.VERBOSE, + ) + + def check_output(self, want: str, got: str, optionflags: int) -> bool: + if super().check_output(want, got, optionflags): + return True + + allow_unicode = optionflags & _get_allow_unicode_flag() + allow_bytes = optionflags & _get_allow_bytes_flag() + allow_number = optionflags & _get_number_flag() + + if not allow_unicode and not allow_bytes and not allow_number: + return False + + def remove_prefixes(regex: Pattern[str], txt: str) -> str: + return re.sub(regex, r"\1\2", txt) + + if allow_unicode: + want = remove_prefixes(self._unicode_literal_re, want) + got = remove_prefixes(self._unicode_literal_re, got) + + if allow_bytes: + want = remove_prefixes(self._bytes_literal_re, want) + got = remove_prefixes(self._bytes_literal_re, got) + + if allow_number: + got = self._remove_unwanted_precision(want, got) + + return super().check_output(want, got, optionflags) + + def _remove_unwanted_precision(self, want: str, got: str) -> str: + wants = list(self._number_re.finditer(want)) + gots = list(self._number_re.finditer(got)) + if len(wants) != len(gots): + return got + offset = 0 + for w, g in zip(wants, gots): + fraction: str | None = w.group("fraction") + exponent: str | None = w.group("exponent1") + if exponent is None: + exponent = w.group("exponent2") + precision = 0 if fraction is None else len(fraction) + if exponent is not None: + precision -= int(exponent) + if float(w.group()) == approx(float(g.group()), abs=10**-precision): + # They're close enough. Replace the text we actually + # got with the text we want, so that it will match when we + # check the string literally. + got = ( + got[: g.start() + offset] + w.group() + got[g.end() + offset :] + ) + offset += w.end() - w.start() - (g.end() - g.start()) + return got + + return LiteralsOutputChecker + + +def _get_checker() -> doctest.OutputChecker: + """Return a doctest.OutputChecker subclass that supports some + additional options: + + * ALLOW_UNICODE and ALLOW_BYTES options to ignore u'' and b'' + prefixes (respectively) in string literals. Useful when the same + doctest should run in Python 2 and Python 3. + + * NUMBER to ignore floating-point differences smaller than the + precision of the literal number in the doctest. + + An inner class is used to avoid importing "doctest" at the module + level. + """ + global CHECKER_CLASS + if CHECKER_CLASS is None: + CHECKER_CLASS = _init_checker_class() + return CHECKER_CLASS() + + +def _get_allow_unicode_flag() -> int: + """Register and return the ALLOW_UNICODE flag.""" + import doctest + + return doctest.register_optionflag("ALLOW_UNICODE") + + +def _get_allow_bytes_flag() -> int: + """Register and return the ALLOW_BYTES flag.""" + import doctest + + return doctest.register_optionflag("ALLOW_BYTES") + + +def _get_number_flag() -> int: + """Register and return the NUMBER flag.""" + import doctest + + return doctest.register_optionflag("NUMBER") + + +def _get_report_choice(key: str) -> int: + """Return the actual `doctest` module flag value. + + We want to do it as late as possible to avoid importing `doctest` and all + its dependencies when parsing options, as it adds overhead and breaks tests. + """ + import doctest + + return { + DOCTEST_REPORT_CHOICE_UDIFF: doctest.REPORT_UDIFF, + DOCTEST_REPORT_CHOICE_CDIFF: doctest.REPORT_CDIFF, + DOCTEST_REPORT_CHOICE_NDIFF: doctest.REPORT_NDIFF, + DOCTEST_REPORT_CHOICE_ONLY_FIRST_FAILURE: doctest.REPORT_ONLY_FIRST_FAILURE, + DOCTEST_REPORT_CHOICE_NONE: 0, + }[key] + + +@fixture(scope="session") +def doctest_namespace() -> dict[str, Any]: + """Fixture that returns a :py:class:`dict` that will be injected into the + namespace of doctests. + + Usually this fixture is used in conjunction with another ``autouse`` fixture: + + .. code-block:: python + + @pytest.fixture(autouse=True) + def add_np(doctest_namespace): + doctest_namespace["np"] = numpy + + For more details: :ref:`doctest_namespace`. + """ + return dict() diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/faulthandler.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/faulthandler.py new file mode 100644 index 0000000..d16aea1 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/faulthandler.py @@ -0,0 +1,105 @@ +from __future__ import annotations + +import os +import sys +from typing import Generator + +from _pytest.config import Config +from _pytest.config.argparsing import Parser +from _pytest.nodes import Item +from _pytest.stash import StashKey +import pytest + + +fault_handler_original_stderr_fd_key = StashKey[int]() +fault_handler_stderr_fd_key = StashKey[int]() + + +def pytest_addoption(parser: Parser) -> None: + help = ( + "Dump the traceback of all threads if a test takes " + "more than TIMEOUT seconds to finish" + ) + parser.addini("faulthandler_timeout", help, default=0.0) + + +def pytest_configure(config: Config) -> None: + import faulthandler + + # at teardown we want to restore the original faulthandler fileno + # but faulthandler has no api to return the original fileno + # so here we stash the stderr fileno to be used at teardown + # sys.stderr and sys.__stderr__ may be closed or patched during the session + # so we can't rely on their values being good at that point (#11572). + stderr_fileno = get_stderr_fileno() + if faulthandler.is_enabled(): + config.stash[fault_handler_original_stderr_fd_key] = stderr_fileno + config.stash[fault_handler_stderr_fd_key] = os.dup(stderr_fileno) + faulthandler.enable(file=config.stash[fault_handler_stderr_fd_key]) + + +def pytest_unconfigure(config: Config) -> None: + import faulthandler + + faulthandler.disable() + # Close the dup file installed during pytest_configure. + if fault_handler_stderr_fd_key in config.stash: + os.close(config.stash[fault_handler_stderr_fd_key]) + del config.stash[fault_handler_stderr_fd_key] + # Re-enable the faulthandler if it was originally enabled. + if fault_handler_original_stderr_fd_key in config.stash: + faulthandler.enable(config.stash[fault_handler_original_stderr_fd_key]) + del config.stash[fault_handler_original_stderr_fd_key] + + +def get_stderr_fileno() -> int: + try: + fileno = sys.stderr.fileno() + # The Twisted Logger will return an invalid file descriptor since it is not backed + # by an FD. So, let's also forward this to the same code path as with pytest-xdist. + if fileno == -1: + raise AttributeError() + return fileno + except (AttributeError, ValueError): + # pytest-xdist monkeypatches sys.stderr with an object that is not an actual file. + # https://docs.python.org/3/library/faulthandler.html#issue-with-file-descriptors + # This is potentially dangerous, but the best we can do. + assert sys.__stderr__ is not None + return sys.__stderr__.fileno() + + +def get_timeout_config_value(config: Config) -> float: + return float(config.getini("faulthandler_timeout") or 0.0) + + +@pytest.hookimpl(wrapper=True, trylast=True) +def pytest_runtest_protocol(item: Item) -> Generator[None, object, object]: + timeout = get_timeout_config_value(item.config) + if timeout > 0: + import faulthandler + + stderr = item.config.stash[fault_handler_stderr_fd_key] + faulthandler.dump_traceback_later(timeout, file=stderr) + try: + return (yield) + finally: + faulthandler.cancel_dump_traceback_later() + else: + return (yield) + + +@pytest.hookimpl(tryfirst=True) +def pytest_enter_pdb() -> None: + """Cancel any traceback dumping due to timeout before entering pdb.""" + import faulthandler + + faulthandler.cancel_dump_traceback_later() + + +@pytest.hookimpl(tryfirst=True) +def pytest_exception_interact() -> None: + """Cancel any traceback dumping due to an interactive exception being + raised.""" + import faulthandler + + faulthandler.cancel_dump_traceback_later() diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/fixtures.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/fixtures.py new file mode 100644 index 0000000..6b882fa --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/fixtures.py @@ -0,0 +1,1932 @@ +# mypy: allow-untyped-defs +from __future__ import annotations + +import abc +from collections import defaultdict +from collections import deque +import dataclasses +import functools +import inspect +import os +from pathlib import Path +import sys +import types +from typing import AbstractSet +from typing import Any +from typing import Callable +from typing import cast +from typing import Dict +from typing import Final +from typing import final +from typing import Generator +from typing import Generic +from typing import Iterable +from typing import Iterator +from typing import Mapping +from typing import MutableMapping +from typing import NoReturn +from typing import Optional +from typing import OrderedDict +from typing import overload +from typing import Sequence +from typing import Tuple +from typing import TYPE_CHECKING +from typing import TypeVar +from typing import Union +import warnings + +import _pytest +from _pytest import nodes +from _pytest._code import getfslineno +from _pytest._code import Source +from _pytest._code.code import FormattedExcinfo +from _pytest._code.code import TerminalRepr +from _pytest._io import TerminalWriter +from _pytest.compat import _PytestWrapper +from _pytest.compat import assert_never +from _pytest.compat import get_real_func +from _pytest.compat import get_real_method +from _pytest.compat import getfuncargnames +from _pytest.compat import getimfunc +from _pytest.compat import getlocation +from _pytest.compat import is_generator +from _pytest.compat import NOTSET +from _pytest.compat import NotSetType +from _pytest.compat import safe_getattr +from _pytest.compat import safe_isclass +from _pytest.config import _PluggyPlugin +from _pytest.config import Config +from _pytest.config import ExitCode +from _pytest.config.argparsing import Parser +from _pytest.deprecated import check_ispytest +from _pytest.deprecated import MARKED_FIXTURE +from _pytest.deprecated import YIELD_FIXTURE +from _pytest.main import Session +from _pytest.mark import Mark +from _pytest.mark import ParameterSet +from _pytest.mark.structures import MarkDecorator +from _pytest.outcomes import fail +from _pytest.outcomes import skip +from _pytest.outcomes import TEST_OUTCOME +from _pytest.pathlib import absolutepath +from _pytest.pathlib import bestrelpath +from _pytest.scope import _ScopeName +from _pytest.scope import HIGH_SCOPES +from _pytest.scope import Scope + + +if sys.version_info < (3, 11): + from exceptiongroup import BaseExceptionGroup + + +if TYPE_CHECKING: + from _pytest.python import CallSpec2 + from _pytest.python import Function + from _pytest.python import Metafunc + + +# The value of the fixture -- return/yield of the fixture function (type variable). +FixtureValue = TypeVar("FixtureValue") +# The type of the fixture function (type variable). +FixtureFunction = TypeVar("FixtureFunction", bound=Callable[..., object]) +# The type of a fixture function (type alias generic in fixture value). +_FixtureFunc = Union[ + Callable[..., FixtureValue], Callable[..., Generator[FixtureValue, None, None]] +] +# The type of FixtureDef.cached_result (type alias generic in fixture value). +_FixtureCachedResult = Union[ + Tuple[ + # The result. + FixtureValue, + # Cache key. + object, + None, + ], + Tuple[ + None, + # Cache key. + object, + # The exception and the original traceback. + Tuple[BaseException, Optional[types.TracebackType]], + ], +] + + +@dataclasses.dataclass(frozen=True) +class PseudoFixtureDef(Generic[FixtureValue]): + cached_result: _FixtureCachedResult[FixtureValue] + _scope: Scope + + +def pytest_sessionstart(session: Session) -> None: + session._fixturemanager = FixtureManager(session) + + +def get_scope_package( + node: nodes.Item, + fixturedef: FixtureDef[object], +) -> nodes.Node | None: + from _pytest.python import Package + + for parent in node.iter_parents(): + if isinstance(parent, Package) and parent.nodeid == fixturedef.baseid: + return parent + return node.session + + +def get_scope_node(node: nodes.Node, scope: Scope) -> nodes.Node | None: + import _pytest.python + + if scope is Scope.Function: + # Type ignored because this is actually safe, see: + # https://github.com/python/mypy/issues/4717 + return node.getparent(nodes.Item) # type: ignore[type-abstract] + elif scope is Scope.Class: + return node.getparent(_pytest.python.Class) + elif scope is Scope.Module: + return node.getparent(_pytest.python.Module) + elif scope is Scope.Package: + return node.getparent(_pytest.python.Package) + elif scope is Scope.Session: + return node.getparent(_pytest.main.Session) + else: + assert_never(scope) + + +def getfixturemarker(obj: object) -> FixtureFunctionMarker | None: + """Return fixturemarker or None if it doesn't exist or raised + exceptions.""" + return cast( + Optional[FixtureFunctionMarker], + safe_getattr(obj, "_pytestfixturefunction", None), + ) + + +# Algorithm for sorting on a per-parametrized resource setup basis. +# It is called for Session scope first and performs sorting +# down to the lower scopes such as to minimize number of "high scope" +# setups and teardowns. + + +@dataclasses.dataclass(frozen=True) +class FixtureArgKey: + argname: str + param_index: int + scoped_item_path: Path | None + item_cls: type | None + + +_V = TypeVar("_V") +OrderedSet = Dict[_V, None] + + +def get_parametrized_fixture_argkeys( + item: nodes.Item, scope: Scope +) -> Iterator[FixtureArgKey]: + """Return list of keys for all parametrized arguments which match + the specified scope.""" + assert scope is not Scope.Function + + try: + callspec: CallSpec2 = item.callspec # type: ignore[attr-defined] + except AttributeError: + return + + item_cls = None + if scope is Scope.Session: + scoped_item_path = None + elif scope is Scope.Package: + # Package key = module's directory. + scoped_item_path = item.path.parent + elif scope is Scope.Module: + scoped_item_path = item.path + elif scope is Scope.Class: + scoped_item_path = item.path + item_cls = item.cls # type: ignore[attr-defined] + else: + assert_never(scope) + + for argname in callspec.indices: + if callspec._arg2scope[argname] != scope: + continue + param_index = callspec.indices[argname] + yield FixtureArgKey(argname, param_index, scoped_item_path, item_cls) + + +def reorder_items(items: Sequence[nodes.Item]) -> list[nodes.Item]: + argkeys_by_item: dict[Scope, dict[nodes.Item, OrderedSet[FixtureArgKey]]] = {} + items_by_argkey: dict[ + Scope, dict[FixtureArgKey, OrderedDict[nodes.Item, None]] + ] = {} + for scope in HIGH_SCOPES: + scoped_argkeys_by_item = argkeys_by_item[scope] = {} + scoped_items_by_argkey = items_by_argkey[scope] = defaultdict(OrderedDict) + for item in items: + argkeys = dict.fromkeys(get_parametrized_fixture_argkeys(item, scope)) + if argkeys: + scoped_argkeys_by_item[item] = argkeys + for argkey in argkeys: + scoped_items_by_argkey[argkey][item] = None + + items_set = dict.fromkeys(items) + return list( + reorder_items_atscope( + items_set, argkeys_by_item, items_by_argkey, Scope.Session + ) + ) + + +def reorder_items_atscope( + items: OrderedSet[nodes.Item], + argkeys_by_item: Mapping[Scope, Mapping[nodes.Item, OrderedSet[FixtureArgKey]]], + items_by_argkey: Mapping[ + Scope, Mapping[FixtureArgKey, OrderedDict[nodes.Item, None]] + ], + scope: Scope, +) -> OrderedSet[nodes.Item]: + if scope is Scope.Function or len(items) < 3: + return items + + scoped_items_by_argkey = items_by_argkey[scope] + scoped_argkeys_by_item = argkeys_by_item[scope] + + ignore: set[FixtureArgKey] = set() + items_deque = deque(items) + items_done: OrderedSet[nodes.Item] = {} + while items_deque: + no_argkey_items: OrderedSet[nodes.Item] = {} + slicing_argkey = None + while items_deque: + item = items_deque.popleft() + if item in items_done or item in no_argkey_items: + continue + argkeys = dict.fromkeys( + k for k in scoped_argkeys_by_item.get(item, ()) if k not in ignore + ) + if not argkeys: + no_argkey_items[item] = None + else: + slicing_argkey, _ = argkeys.popitem() + # We don't have to remove relevant items from later in the + # deque because they'll just be ignored. + matching_items = [ + i for i in scoped_items_by_argkey[slicing_argkey] if i in items + ] + for i in reversed(matching_items): + items_deque.appendleft(i) + # Fix items_by_argkey order. + for other_scope in HIGH_SCOPES: + other_scoped_items_by_argkey = items_by_argkey[other_scope] + for argkey in argkeys_by_item[other_scope].get(i, ()): + other_scoped_items_by_argkey[argkey][i] = None + other_scoped_items_by_argkey[argkey].move_to_end( + i, last=False + ) + break + if no_argkey_items: + reordered_no_argkey_items = reorder_items_atscope( + no_argkey_items, argkeys_by_item, items_by_argkey, scope.next_lower() + ) + items_done.update(reordered_no_argkey_items) + if slicing_argkey is not None: + ignore.add(slicing_argkey) + return items_done + + +@dataclasses.dataclass(frozen=True) +class FuncFixtureInfo: + """Fixture-related information for a fixture-requesting item (e.g. test + function). + + This is used to examine the fixtures which an item requests statically + (known during collection). This includes autouse fixtures, fixtures + requested by the `usefixtures` marker, fixtures requested in the function + parameters, and the transitive closure of these. + + An item may also request fixtures dynamically (using `request.getfixturevalue`); + these are not reflected here. + """ + + __slots__ = ("argnames", "initialnames", "names_closure", "name2fixturedefs") + + # Fixture names that the item requests directly by function parameters. + argnames: tuple[str, ...] + # Fixture names that the item immediately requires. These include + # argnames + fixture names specified via usefixtures and via autouse=True in + # fixture definitions. + initialnames: tuple[str, ...] + # The transitive closure of the fixture names that the item requires. + # Note: can't include dynamic dependencies (`request.getfixturevalue` calls). + names_closure: list[str] + # A map from a fixture name in the transitive closure to the FixtureDefs + # matching the name which are applicable to this function. + # There may be multiple overriding fixtures with the same name. The + # sequence is ordered from furthest to closes to the function. + name2fixturedefs: dict[str, Sequence[FixtureDef[Any]]] + + def prune_dependency_tree(self) -> None: + """Recompute names_closure from initialnames and name2fixturedefs. + + Can only reduce names_closure, which means that the new closure will + always be a subset of the old one. The order is preserved. + + This method is needed because direct parametrization may shadow some + of the fixtures that were included in the originally built dependency + tree. In this way the dependency tree can get pruned, and the closure + of argnames may get reduced. + """ + closure: set[str] = set() + working_set = set(self.initialnames) + while working_set: + argname = working_set.pop() + # Argname may be something not included in the original names_closure, + # in which case we ignore it. This currently happens with pseudo + # FixtureDefs which wrap 'get_direct_param_fixture_func(request)'. + # So they introduce the new dependency 'request' which might have + # been missing in the original tree (closure). + if argname not in closure and argname in self.names_closure: + closure.add(argname) + if argname in self.name2fixturedefs: + working_set.update(self.name2fixturedefs[argname][-1].argnames) + + self.names_closure[:] = sorted(closure, key=self.names_closure.index) + + +class FixtureRequest(abc.ABC): + """The type of the ``request`` fixture. + + A request object gives access to the requesting test context and has a + ``param`` attribute in case the fixture is parametrized. + """ + + def __init__( + self, + pyfuncitem: Function, + fixturename: str | None, + arg2fixturedefs: dict[str, Sequence[FixtureDef[Any]]], + fixture_defs: dict[str, FixtureDef[Any]], + *, + _ispytest: bool = False, + ) -> None: + check_ispytest(_ispytest) + #: Fixture for which this request is being performed. + self.fixturename: Final = fixturename + self._pyfuncitem: Final = pyfuncitem + # The FixtureDefs for each fixture name requested by this item. + # Starts from the statically-known fixturedefs resolved during + # collection. Dynamically requested fixtures (using + # `request.getfixturevalue("foo")`) are added dynamically. + self._arg2fixturedefs: Final = arg2fixturedefs + # The evaluated argnames so far, mapping to the FixtureDef they resolved + # to. + self._fixture_defs: Final = fixture_defs + # Notes on the type of `param`: + # -`request.param` is only defined in parametrized fixtures, and will raise + # AttributeError otherwise. Python typing has no notion of "undefined", so + # this cannot be reflected in the type. + # - Technically `param` is only (possibly) defined on SubRequest, not + # FixtureRequest, but the typing of that is still in flux so this cheats. + # - In the future we might consider using a generic for the param type, but + # for now just using Any. + self.param: Any + + @property + def _fixturemanager(self) -> FixtureManager: + return self._pyfuncitem.session._fixturemanager + + @property + @abc.abstractmethod + def _scope(self) -> Scope: + raise NotImplementedError() + + @property + def scope(self) -> _ScopeName: + """Scope string, one of "function", "class", "module", "package", "session".""" + return self._scope.value + + @abc.abstractmethod + def _check_scope( + self, + requested_fixturedef: FixtureDef[object] | PseudoFixtureDef[object], + requested_scope: Scope, + ) -> None: + raise NotImplementedError() + + @property + def fixturenames(self) -> list[str]: + """Names of all active fixtures in this request.""" + result = list(self._pyfuncitem.fixturenames) + result.extend(set(self._fixture_defs).difference(result)) + return result + + @property + @abc.abstractmethod + def node(self): + """Underlying collection node (depends on current request scope).""" + raise NotImplementedError() + + @property + def config(self) -> Config: + """The pytest config object associated with this request.""" + return self._pyfuncitem.config + + @property + def function(self): + """Test function object if the request has a per-function scope.""" + if self.scope != "function": + raise AttributeError( + f"function not available in {self.scope}-scoped context" + ) + return self._pyfuncitem.obj + + @property + def cls(self): + """Class (can be None) where the test function was collected.""" + if self.scope not in ("class", "function"): + raise AttributeError(f"cls not available in {self.scope}-scoped context") + clscol = self._pyfuncitem.getparent(_pytest.python.Class) + if clscol: + return clscol.obj + + @property + def instance(self): + """Instance (can be None) on which test function was collected.""" + if self.scope != "function": + return None + return getattr(self._pyfuncitem, "instance", None) + + @property + def module(self): + """Python module object where the test function was collected.""" + if self.scope not in ("function", "class", "module"): + raise AttributeError(f"module not available in {self.scope}-scoped context") + mod = self._pyfuncitem.getparent(_pytest.python.Module) + assert mod is not None + return mod.obj + + @property + def path(self) -> Path: + """Path where the test function was collected.""" + if self.scope not in ("function", "class", "module", "package"): + raise AttributeError(f"path not available in {self.scope}-scoped context") + return self._pyfuncitem.path + + @property + def keywords(self) -> MutableMapping[str, Any]: + """Keywords/markers dictionary for the underlying node.""" + node: nodes.Node = self.node + return node.keywords + + @property + def session(self) -> Session: + """Pytest session object.""" + return self._pyfuncitem.session + + @abc.abstractmethod + def addfinalizer(self, finalizer: Callable[[], object]) -> None: + """Add finalizer/teardown function to be called without arguments after + the last test within the requesting test context finished execution.""" + raise NotImplementedError() + + def applymarker(self, marker: str | MarkDecorator) -> None: + """Apply a marker to a single test function invocation. + + This method is useful if you don't want to have a keyword/marker + on all function invocations. + + :param marker: + An object created by a call to ``pytest.mark.NAME(...)``. + """ + self.node.add_marker(marker) + + def raiseerror(self, msg: str | None) -> NoReturn: + """Raise a FixtureLookupError exception. + + :param msg: + An optional custom error message. + """ + raise FixtureLookupError(None, self, msg) + + def getfixturevalue(self, argname: str) -> Any: + """Dynamically run a named fixture function. + + Declaring fixtures via function argument is recommended where possible. + But if you can only decide whether to use another fixture at test + setup time, you may use this function to retrieve it inside a fixture + or test function body. + + This method can be used during the test setup phase or the test run + phase, but during the test teardown phase a fixture's value may not + be available. + + :param argname: + The fixture name. + :raises pytest.FixtureLookupError: + If the given fixture could not be found. + """ + # Note that in addition to the use case described in the docstring, + # getfixturevalue() is also called by pytest itself during item and fixture + # setup to evaluate the fixtures that are requested statically + # (using function parameters, autouse, etc). + + fixturedef = self._get_active_fixturedef(argname) + assert fixturedef.cached_result is not None, ( + f'The fixture value for "{argname}" is not available. ' + "This can happen when the fixture has already been torn down." + ) + return fixturedef.cached_result[0] + + def _iter_chain(self) -> Iterator[SubRequest]: + """Yield all SubRequests in the chain, from self up. + + Note: does *not* yield the TopRequest. + """ + current = self + while isinstance(current, SubRequest): + yield current + current = current._parent_request + + def _get_active_fixturedef( + self, argname: str + ) -> FixtureDef[object] | PseudoFixtureDef[object]: + if argname == "request": + cached_result = (self, [0], None) + return PseudoFixtureDef(cached_result, Scope.Function) + + # If we already finished computing a fixture by this name in this item, + # return it. + fixturedef = self._fixture_defs.get(argname) + if fixturedef is not None: + self._check_scope(fixturedef, fixturedef._scope) + return fixturedef + + # Find the appropriate fixturedef. + fixturedefs = self._arg2fixturedefs.get(argname, None) + if fixturedefs is None: + # We arrive here because of a dynamic call to + # getfixturevalue(argname) which was naturally + # not known at parsing/collection time. + fixturedefs = self._fixturemanager.getfixturedefs(argname, self._pyfuncitem) + if fixturedefs is not None: + self._arg2fixturedefs[argname] = fixturedefs + # No fixtures defined with this name. + if fixturedefs is None: + raise FixtureLookupError(argname, self) + # The are no fixtures with this name applicable for the function. + if not fixturedefs: + raise FixtureLookupError(argname, self) + # A fixture may override another fixture with the same name, e.g. a + # fixture in a module can override a fixture in a conftest, a fixture in + # a class can override a fixture in the module, and so on. + # An overriding fixture can request its own name (possibly indirectly); + # in this case it gets the value of the fixture it overrides, one level + # up. + # Check how many `argname`s deep we are, and take the next one. + # `fixturedefs` is sorted from furthest to closest, so use negative + # indexing to go in reverse. + index = -1 + for request in self._iter_chain(): + if request.fixturename == argname: + index -= 1 + # If already consumed all of the available levels, fail. + if -index > len(fixturedefs): + raise FixtureLookupError(argname, self) + fixturedef = fixturedefs[index] + + # Prepare a SubRequest object for calling the fixture. + try: + callspec = self._pyfuncitem.callspec + except AttributeError: + callspec = None + if callspec is not None and argname in callspec.params: + param = callspec.params[argname] + param_index = callspec.indices[argname] + # The parametrize invocation scope overrides the fixture's scope. + scope = callspec._arg2scope[argname] + else: + param = NOTSET + param_index = 0 + scope = fixturedef._scope + self._check_fixturedef_without_param(fixturedef) + self._check_scope(fixturedef, scope) + subrequest = SubRequest( + self, scope, param, param_index, fixturedef, _ispytest=True + ) + + # Make sure the fixture value is cached, running it if it isn't + fixturedef.execute(request=subrequest) + + self._fixture_defs[argname] = fixturedef + return fixturedef + + def _check_fixturedef_without_param(self, fixturedef: FixtureDef[object]) -> None: + """Check that this request is allowed to execute this fixturedef without + a param.""" + funcitem = self._pyfuncitem + has_params = fixturedef.params is not None + fixtures_not_supported = getattr(funcitem, "nofuncargs", False) + if has_params and fixtures_not_supported: + msg = ( + f"{funcitem.name} does not support fixtures, maybe unittest.TestCase subclass?\n" + f"Node id: {funcitem.nodeid}\n" + f"Function type: {type(funcitem).__name__}" + ) + fail(msg, pytrace=False) + if has_params: + frame = inspect.stack()[3] + frameinfo = inspect.getframeinfo(frame[0]) + source_path = absolutepath(frameinfo.filename) + source_lineno = frameinfo.lineno + try: + source_path_str = str(source_path.relative_to(funcitem.config.rootpath)) + except ValueError: + source_path_str = str(source_path) + location = getlocation(fixturedef.func, funcitem.config.rootpath) + msg = ( + "The requested fixture has no parameter defined for test:\n" + f" {funcitem.nodeid}\n\n" + f"Requested fixture '{fixturedef.argname}' defined in:\n" + f"{location}\n\n" + f"Requested here:\n" + f"{source_path_str}:{source_lineno}" + ) + fail(msg, pytrace=False) + + def _get_fixturestack(self) -> list[FixtureDef[Any]]: + values = [request._fixturedef for request in self._iter_chain()] + values.reverse() + return values + + +@final +class TopRequest(FixtureRequest): + """The type of the ``request`` fixture in a test function.""" + + def __init__(self, pyfuncitem: Function, *, _ispytest: bool = False) -> None: + super().__init__( + fixturename=None, + pyfuncitem=pyfuncitem, + arg2fixturedefs=pyfuncitem._fixtureinfo.name2fixturedefs.copy(), + fixture_defs={}, + _ispytest=_ispytest, + ) + + @property + def _scope(self) -> Scope: + return Scope.Function + + def _check_scope( + self, + requested_fixturedef: FixtureDef[object] | PseudoFixtureDef[object], + requested_scope: Scope, + ) -> None: + # TopRequest always has function scope so always valid. + pass + + @property + def node(self): + return self._pyfuncitem + + def __repr__(self) -> str: + return f"" + + def _fillfixtures(self) -> None: + item = self._pyfuncitem + for argname in item.fixturenames: + if argname not in item.funcargs: + item.funcargs[argname] = self.getfixturevalue(argname) + + def addfinalizer(self, finalizer: Callable[[], object]) -> None: + self.node.addfinalizer(finalizer) + + +@final +class SubRequest(FixtureRequest): + """The type of the ``request`` fixture in a fixture function requested + (transitively) by a test function.""" + + def __init__( + self, + request: FixtureRequest, + scope: Scope, + param: Any, + param_index: int, + fixturedef: FixtureDef[object], + *, + _ispytest: bool = False, + ) -> None: + super().__init__( + pyfuncitem=request._pyfuncitem, + fixturename=fixturedef.argname, + fixture_defs=request._fixture_defs, + arg2fixturedefs=request._arg2fixturedefs, + _ispytest=_ispytest, + ) + self._parent_request: Final[FixtureRequest] = request + self._scope_field: Final = scope + self._fixturedef: Final[FixtureDef[object]] = fixturedef + if param is not NOTSET: + self.param = param + self.param_index: Final = param_index + + def __repr__(self) -> str: + return f"" + + @property + def _scope(self) -> Scope: + return self._scope_field + + @property + def node(self): + scope = self._scope + if scope is Scope.Function: + # This might also be a non-function Item despite its attribute name. + node: nodes.Node | None = self._pyfuncitem + elif scope is Scope.Package: + node = get_scope_package(self._pyfuncitem, self._fixturedef) + else: + node = get_scope_node(self._pyfuncitem, scope) + if node is None and scope is Scope.Class: + # Fallback to function item itself. + node = self._pyfuncitem + assert node, f'Could not obtain a node for scope "{scope}" for function {self._pyfuncitem!r}' + return node + + def _check_scope( + self, + requested_fixturedef: FixtureDef[object] | PseudoFixtureDef[object], + requested_scope: Scope, + ) -> None: + if isinstance(requested_fixturedef, PseudoFixtureDef): + return + if self._scope > requested_scope: + # Try to report something helpful. + argname = requested_fixturedef.argname + fixture_stack = "\n".join( + self._format_fixturedef_line(fixturedef) + for fixturedef in self._get_fixturestack() + ) + requested_fixture = self._format_fixturedef_line(requested_fixturedef) + fail( + f"ScopeMismatch: You tried to access the {requested_scope.value} scoped " + f"fixture {argname} with a {self._scope.value} scoped request object. " + f"Requesting fixture stack:\n{fixture_stack}\n" + f"Requested fixture:\n{requested_fixture}", + pytrace=False, + ) + + def _format_fixturedef_line(self, fixturedef: FixtureDef[object]) -> str: + factory = fixturedef.func + path, lineno = getfslineno(factory) + if isinstance(path, Path): + path = bestrelpath(self._pyfuncitem.session.path, path) + signature = inspect.signature(factory) + return f"{path}:{lineno + 1}: def {factory.__name__}{signature}" + + def addfinalizer(self, finalizer: Callable[[], object]) -> None: + self._fixturedef.addfinalizer(finalizer) + + +@final +class FixtureLookupError(LookupError): + """Could not return a requested fixture (missing or invalid).""" + + def __init__( + self, argname: str | None, request: FixtureRequest, msg: str | None = None + ) -> None: + self.argname = argname + self.request = request + self.fixturestack = request._get_fixturestack() + self.msg = msg + + def formatrepr(self) -> FixtureLookupErrorRepr: + tblines: list[str] = [] + addline = tblines.append + stack = [self.request._pyfuncitem.obj] + stack.extend(map(lambda x: x.func, self.fixturestack)) + msg = self.msg + if msg is not None: + # The last fixture raise an error, let's present + # it at the requesting side. + stack = stack[:-1] + for function in stack: + fspath, lineno = getfslineno(function) + try: + lines, _ = inspect.getsourcelines(get_real_func(function)) + except (OSError, IndexError, TypeError): + error_msg = "file %s, line %s: source code not available" + addline(error_msg % (fspath, lineno + 1)) + else: + addline(f"file {fspath}, line {lineno + 1}") + for i, line in enumerate(lines): + line = line.rstrip() + addline(" " + line) + if line.lstrip().startswith("def"): + break + + if msg is None: + fm = self.request._fixturemanager + available = set() + parent = self.request._pyfuncitem.parent + assert parent is not None + for name, fixturedefs in fm._arg2fixturedefs.items(): + faclist = list(fm._matchfactories(fixturedefs, parent)) + if faclist: + available.add(name) + if self.argname in available: + msg = ( + f" recursive dependency involving fixture '{self.argname}' detected" + ) + else: + msg = f"fixture '{self.argname}' not found" + msg += "\n available fixtures: {}".format(", ".join(sorted(available))) + msg += "\n use 'pytest --fixtures [testpath]' for help on them." + + return FixtureLookupErrorRepr(fspath, lineno, tblines, msg, self.argname) + + +class FixtureLookupErrorRepr(TerminalRepr): + def __init__( + self, + filename: str | os.PathLike[str], + firstlineno: int, + tblines: Sequence[str], + errorstring: str, + argname: str | None, + ) -> None: + self.tblines = tblines + self.errorstring = errorstring + self.filename = filename + self.firstlineno = firstlineno + self.argname = argname + + def toterminal(self, tw: TerminalWriter) -> None: + # tw.line("FixtureLookupError: %s" %(self.argname), red=True) + for tbline in self.tblines: + tw.line(tbline.rstrip()) + lines = self.errorstring.split("\n") + if lines: + tw.line( + f"{FormattedExcinfo.fail_marker} {lines[0].strip()}", + red=True, + ) + for line in lines[1:]: + tw.line( + f"{FormattedExcinfo.flow_marker} {line.strip()}", + red=True, + ) + tw.line() + tw.line("%s:%d" % (os.fspath(self.filename), self.firstlineno + 1)) + + +def call_fixture_func( + fixturefunc: _FixtureFunc[FixtureValue], request: FixtureRequest, kwargs +) -> FixtureValue: + if is_generator(fixturefunc): + fixturefunc = cast( + Callable[..., Generator[FixtureValue, None, None]], fixturefunc + ) + generator = fixturefunc(**kwargs) + try: + fixture_result = next(generator) + except StopIteration: + raise ValueError(f"{request.fixturename} did not yield a value") from None + finalizer = functools.partial(_teardown_yield_fixture, fixturefunc, generator) + request.addfinalizer(finalizer) + else: + fixturefunc = cast(Callable[..., FixtureValue], fixturefunc) + fixture_result = fixturefunc(**kwargs) + return fixture_result + + +def _teardown_yield_fixture(fixturefunc, it) -> None: + """Execute the teardown of a fixture function by advancing the iterator + after the yield and ensure the iteration ends (if not it means there is + more than one yield in the function).""" + try: + next(it) + except StopIteration: + pass + else: + fs, lineno = getfslineno(fixturefunc) + fail( + f"fixture function has more than one 'yield':\n\n" + f"{Source(fixturefunc).indent()}\n" + f"{fs}:{lineno + 1}", + pytrace=False, + ) + + +def _eval_scope_callable( + scope_callable: Callable[[str, Config], _ScopeName], + fixture_name: str, + config: Config, +) -> _ScopeName: + try: + # Type ignored because there is no typing mechanism to specify + # keyword arguments, currently. + result = scope_callable(fixture_name=fixture_name, config=config) # type: ignore[call-arg] + except Exception as e: + raise TypeError( + f"Error evaluating {scope_callable} while defining fixture '{fixture_name}'.\n" + "Expected a function with the signature (*, fixture_name, config)" + ) from e + if not isinstance(result, str): + fail( + f"Expected {scope_callable} to return a 'str' while defining fixture '{fixture_name}', but it returned:\n" + f"{result!r}", + pytrace=False, + ) + return result + + +@final +class FixtureDef(Generic[FixtureValue]): + """A container for a fixture definition. + + Note: At this time, only explicitly documented fields and methods are + considered public stable API. + """ + + def __init__( + self, + config: Config, + baseid: str | None, + argname: str, + func: _FixtureFunc[FixtureValue], + scope: Scope | _ScopeName | Callable[[str, Config], _ScopeName] | None, + params: Sequence[object] | None, + ids: tuple[object | None, ...] | Callable[[Any], object | None] | None = None, + *, + _ispytest: bool = False, + ) -> None: + check_ispytest(_ispytest) + # The "base" node ID for the fixture. + # + # This is a node ID prefix. A fixture is only available to a node (e.g. + # a `Function` item) if the fixture's baseid is a nodeid of a parent of + # node. + # + # For a fixture found in a Collector's object (e.g. a `Module`s module, + # a `Class`'s class), the baseid is the Collector's nodeid. + # + # For a fixture found in a conftest plugin, the baseid is the conftest's + # directory path relative to the rootdir. + # + # For other plugins, the baseid is the empty string (always matches). + self.baseid: Final = baseid or "" + # Whether the fixture was found from a node or a conftest in the + # collection tree. Will be false for fixtures defined in non-conftest + # plugins. + self.has_location: Final = baseid is not None + # The fixture factory function. + self.func: Final = func + # The name by which the fixture may be requested. + self.argname: Final = argname + if scope is None: + scope = Scope.Function + elif callable(scope): + scope = _eval_scope_callable(scope, argname, config) + if isinstance(scope, str): + scope = Scope.from_user( + scope, descr=f"Fixture '{func.__name__}'", where=baseid + ) + self._scope: Final = scope + # If the fixture is directly parametrized, the parameter values. + self.params: Final = params + # If the fixture is directly parametrized, a tuple of explicit IDs to + # assign to the parameter values, or a callable to generate an ID given + # a parameter value. + self.ids: Final = ids + # The names requested by the fixtures. + self.argnames: Final = getfuncargnames(func, name=argname) + # If the fixture was executed, the current value of the fixture. + # Can change if the fixture is executed with different parameters. + self.cached_result: _FixtureCachedResult[FixtureValue] | None = None + self._finalizers: Final[list[Callable[[], object]]] = [] + + @property + def scope(self) -> _ScopeName: + """Scope string, one of "function", "class", "module", "package", "session".""" + return self._scope.value + + def addfinalizer(self, finalizer: Callable[[], object]) -> None: + self._finalizers.append(finalizer) + + def finish(self, request: SubRequest) -> None: + exceptions: list[BaseException] = [] + while self._finalizers: + fin = self._finalizers.pop() + try: + fin() + except BaseException as e: + exceptions.append(e) + node = request.node + node.ihook.pytest_fixture_post_finalizer(fixturedef=self, request=request) + # Even if finalization fails, we invalidate the cached fixture + # value and remove all finalizers because they may be bound methods + # which will keep instances alive. + self.cached_result = None + self._finalizers.clear() + if len(exceptions) == 1: + raise exceptions[0] + elif len(exceptions) > 1: + msg = f'errors while tearing down fixture "{self.argname}" of {node}' + raise BaseExceptionGroup(msg, exceptions[::-1]) + + def execute(self, request: SubRequest) -> FixtureValue: + """Return the value of this fixture, executing it if not cached.""" + # Ensure that the dependent fixtures requested by this fixture are loaded. + # This needs to be done before checking if we have a cached value, since + # if a dependent fixture has their cache invalidated, e.g. due to + # parametrization, they finalize themselves and fixtures depending on it + # (which will likely include this fixture) setting `self.cached_result = None`. + # See #4871 + requested_fixtures_that_should_finalize_us = [] + for argname in self.argnames: + fixturedef = request._get_active_fixturedef(argname) + # Saves requested fixtures in a list so we later can add our finalizer + # to them, ensuring that if a requested fixture gets torn down we get torn + # down first. This is generally handled by SetupState, but still currently + # needed when this fixture is not parametrized but depends on a parametrized + # fixture. + if not isinstance(fixturedef, PseudoFixtureDef): + requested_fixtures_that_should_finalize_us.append(fixturedef) + + # Check for (and return) cached value/exception. + if self.cached_result is not None: + request_cache_key = self.cache_key(request) + cache_key = self.cached_result[1] + try: + # Attempt to make a normal == check: this might fail for objects + # which do not implement the standard comparison (like numpy arrays -- #6497). + cache_hit = bool(request_cache_key == cache_key) + except (ValueError, RuntimeError): + # If the comparison raises, use 'is' as fallback. + cache_hit = request_cache_key is cache_key + + if cache_hit: + if self.cached_result[2] is not None: + exc, exc_tb = self.cached_result[2] + raise exc.with_traceback(exc_tb) + else: + result = self.cached_result[0] + return result + # We have a previous but differently parametrized fixture instance + # so we need to tear it down before creating a new one. + self.finish(request) + assert self.cached_result is None + + # Add finalizer to requested fixtures we saved previously. + # We make sure to do this after checking for cached value to avoid + # adding our finalizer multiple times. (#12135) + finalizer = functools.partial(self.finish, request=request) + for parent_fixture in requested_fixtures_that_should_finalize_us: + parent_fixture.addfinalizer(finalizer) + + ihook = request.node.ihook + try: + # Setup the fixture, run the code in it, and cache the value + # in self.cached_result + result = ihook.pytest_fixture_setup(fixturedef=self, request=request) + finally: + # schedule our finalizer, even if the setup failed + request.node.addfinalizer(finalizer) + + return result + + def cache_key(self, request: SubRequest) -> object: + return getattr(request, "param", None) + + def __repr__(self) -> str: + return f"" + + +def resolve_fixture_function( + fixturedef: FixtureDef[FixtureValue], request: FixtureRequest +) -> _FixtureFunc[FixtureValue]: + """Get the actual callable that can be called to obtain the fixture + value.""" + fixturefunc = fixturedef.func + # The fixture function needs to be bound to the actual + # request.instance so that code working with "fixturedef" behaves + # as expected. + instance = request.instance + if instance is not None: + # Handle the case where fixture is defined not in a test class, but some other class + # (for example a plugin class with a fixture), see #2270. + if hasattr(fixturefunc, "__self__") and not isinstance( + instance, + fixturefunc.__self__.__class__, + ): + return fixturefunc + fixturefunc = getimfunc(fixturedef.func) + if fixturefunc != fixturedef.func: + fixturefunc = fixturefunc.__get__(instance) + return fixturefunc + + +def pytest_fixture_setup( + fixturedef: FixtureDef[FixtureValue], request: SubRequest +) -> FixtureValue: + """Execution of fixture setup.""" + kwargs = {} + for argname in fixturedef.argnames: + kwargs[argname] = request.getfixturevalue(argname) + + fixturefunc = resolve_fixture_function(fixturedef, request) + my_cache_key = fixturedef.cache_key(request) + try: + result = call_fixture_func(fixturefunc, request, kwargs) + except TEST_OUTCOME as e: + if isinstance(e, skip.Exception): + # The test requested a fixture which caused a skip. + # Don't show the fixture as the skip location, as then the user + # wouldn't know which test skipped. + e._use_item_location = True + fixturedef.cached_result = (None, my_cache_key, (e, e.__traceback__)) + raise + fixturedef.cached_result = (result, my_cache_key, None) + return result + + +def wrap_function_to_error_out_if_called_directly( + function: FixtureFunction, + fixture_marker: FixtureFunctionMarker, +) -> FixtureFunction: + """Wrap the given fixture function so we can raise an error about it being called directly, + instead of used as an argument in a test function.""" + name = fixture_marker.name or function.__name__ + message = ( + f'Fixture "{name}" called directly. Fixtures are not meant to be called directly,\n' + "but are created automatically when test functions request them as parameters.\n" + "See https://docs.pytest.org/en/stable/explanation/fixtures.html for more information about fixtures, and\n" + "https://docs.pytest.org/en/stable/deprecations.html#calling-fixtures-directly about how to update your code." + ) + + @functools.wraps(function) + def result(*args, **kwargs): + fail(message, pytrace=False) + + # Keep reference to the original function in our own custom attribute so we don't unwrap + # further than this point and lose useful wrappings like @mock.patch (#3774). + result.__pytest_wrapped__ = _PytestWrapper(function) # type: ignore[attr-defined] + + return cast(FixtureFunction, result) + + +@final +@dataclasses.dataclass(frozen=True) +class FixtureFunctionMarker: + scope: _ScopeName | Callable[[str, Config], _ScopeName] + params: tuple[object, ...] | None + autouse: bool = False + ids: tuple[object | None, ...] | Callable[[Any], object | None] | None = None + name: str | None = None + + _ispytest: dataclasses.InitVar[bool] = False + + def __post_init__(self, _ispytest: bool) -> None: + check_ispytest(_ispytest) + + def __call__(self, function: FixtureFunction) -> FixtureFunction: + if inspect.isclass(function): + raise ValueError("class fixtures not supported (maybe in the future)") + + if getattr(function, "_pytestfixturefunction", False): + raise ValueError( + f"@pytest.fixture is being applied more than once to the same function {function.__name__!r}" + ) + + if hasattr(function, "pytestmark"): + warnings.warn(MARKED_FIXTURE, stacklevel=2) + + function = wrap_function_to_error_out_if_called_directly(function, self) + + name = self.name or function.__name__ + if name == "request": + location = getlocation(function) + fail( + f"'request' is a reserved word for fixtures, use another name:\n {location}", + pytrace=False, + ) + + # Type ignored because https://github.com/python/mypy/issues/2087. + function._pytestfixturefunction = self # type: ignore[attr-defined] + return function + + +@overload +def fixture( + fixture_function: FixtureFunction, + *, + scope: _ScopeName | Callable[[str, Config], _ScopeName] = ..., + params: Iterable[object] | None = ..., + autouse: bool = ..., + ids: Sequence[object | None] | Callable[[Any], object | None] | None = ..., + name: str | None = ..., +) -> FixtureFunction: ... + + +@overload +def fixture( + fixture_function: None = ..., + *, + scope: _ScopeName | Callable[[str, Config], _ScopeName] = ..., + params: Iterable[object] | None = ..., + autouse: bool = ..., + ids: Sequence[object | None] | Callable[[Any], object | None] | None = ..., + name: str | None = None, +) -> FixtureFunctionMarker: ... + + +def fixture( + fixture_function: FixtureFunction | None = None, + *, + scope: _ScopeName | Callable[[str, Config], _ScopeName] = "function", + params: Iterable[object] | None = None, + autouse: bool = False, + ids: Sequence[object | None] | Callable[[Any], object | None] | None = None, + name: str | None = None, +) -> FixtureFunctionMarker | FixtureFunction: + """Decorator to mark a fixture factory function. + + This decorator can be used, with or without parameters, to define a + fixture function. + + The name of the fixture function can later be referenced to cause its + invocation ahead of running tests: test modules or classes can use the + ``pytest.mark.usefixtures(fixturename)`` marker. + + Test functions can directly use fixture names as input arguments in which + case the fixture instance returned from the fixture function will be + injected. + + Fixtures can provide their values to test functions using ``return`` or + ``yield`` statements. When using ``yield`` the code block after the + ``yield`` statement is executed as teardown code regardless of the test + outcome, and must yield exactly once. + + :param scope: + The scope for which this fixture is shared; one of ``"function"`` + (default), ``"class"``, ``"module"``, ``"package"`` or ``"session"``. + + This parameter may also be a callable which receives ``(fixture_name, config)`` + as parameters, and must return a ``str`` with one of the values mentioned above. + + See :ref:`dynamic scope` in the docs for more information. + + :param params: + An optional list of parameters which will cause multiple invocations + of the fixture function and all of the tests using it. The current + parameter is available in ``request.param``. + + :param autouse: + If True, the fixture func is activated for all tests that can see it. + If False (the default), an explicit reference is needed to activate + the fixture. + + :param ids: + Sequence of ids each corresponding to the params so that they are + part of the test id. If no ids are provided they will be generated + automatically from the params. + + :param name: + The name of the fixture. This defaults to the name of the decorated + function. If a fixture is used in the same module in which it is + defined, the function name of the fixture will be shadowed by the + function arg that requests the fixture; one way to resolve this is to + name the decorated function ``fixture_`` and then use + ``@pytest.fixture(name='')``. + """ + fixture_marker = FixtureFunctionMarker( + scope=scope, + params=tuple(params) if params is not None else None, + autouse=autouse, + ids=None if ids is None else ids if callable(ids) else tuple(ids), + name=name, + _ispytest=True, + ) + + # Direct decoration. + if fixture_function: + return fixture_marker(fixture_function) + + return fixture_marker + + +def yield_fixture( + fixture_function=None, + *args, + scope="function", + params=None, + autouse=False, + ids=None, + name=None, +): + """(Return a) decorator to mark a yield-fixture factory function. + + .. deprecated:: 3.0 + Use :py:func:`pytest.fixture` directly instead. + """ + warnings.warn(YIELD_FIXTURE, stacklevel=2) + return fixture( + fixture_function, + *args, + scope=scope, + params=params, + autouse=autouse, + ids=ids, + name=name, + ) + + +@fixture(scope="session") +def pytestconfig(request: FixtureRequest) -> Config: + """Session-scoped fixture that returns the session's :class:`pytest.Config` + object. + + Example:: + + def test_foo(pytestconfig): + if pytestconfig.get_verbosity() > 0: + ... + + """ + return request.config + + +def pytest_addoption(parser: Parser) -> None: + parser.addini( + "usefixtures", + type="args", + default=[], + help="List of default fixtures to be used with this project", + ) + group = parser.getgroup("general") + group.addoption( + "--fixtures", + "--funcargs", + action="store_true", + dest="showfixtures", + default=False, + help="Show available fixtures, sorted by plugin appearance " + "(fixtures with leading '_' are only shown with '-v')", + ) + group.addoption( + "--fixtures-per-test", + action="store_true", + dest="show_fixtures_per_test", + default=False, + help="Show fixtures per test", + ) + + +def pytest_cmdline_main(config: Config) -> int | ExitCode | None: + if config.option.showfixtures: + showfixtures(config) + return 0 + if config.option.show_fixtures_per_test: + show_fixtures_per_test(config) + return 0 + return None + + +def _get_direct_parametrize_args(node: nodes.Node) -> set[str]: + """Return all direct parametrization arguments of a node, so we don't + mistake them for fixtures. + + Check https://github.com/pytest-dev/pytest/issues/5036. + + These things are done later as well when dealing with parametrization + so this could be improved. + """ + parametrize_argnames: set[str] = set() + for marker in node.iter_markers(name="parametrize"): + if not marker.kwargs.get("indirect", False): + p_argnames, _ = ParameterSet._parse_parametrize_args( + *marker.args, **marker.kwargs + ) + parametrize_argnames.update(p_argnames) + return parametrize_argnames + + +def deduplicate_names(*seqs: Iterable[str]) -> tuple[str, ...]: + """De-duplicate the sequence of names while keeping the original order.""" + # Ideally we would use a set, but it does not preserve insertion order. + return tuple(dict.fromkeys(name for seq in seqs for name in seq)) + + +class FixtureManager: + """pytest fixture definitions and information is stored and managed + from this class. + + During collection fm.parsefactories() is called multiple times to parse + fixture function definitions into FixtureDef objects and internal + data structures. + + During collection of test functions, metafunc-mechanics instantiate + a FuncFixtureInfo object which is cached per node/func-name. + This FuncFixtureInfo object is later retrieved by Function nodes + which themselves offer a fixturenames attribute. + + The FuncFixtureInfo object holds information about fixtures and FixtureDefs + relevant for a particular function. An initial list of fixtures is + assembled like this: + + - ini-defined usefixtures + - autouse-marked fixtures along the collection chain up from the function + - usefixtures markers at module/class/function level + - test function funcargs + + Subsequently the funcfixtureinfo.fixturenames attribute is computed + as the closure of the fixtures needed to setup the initial fixtures, + i.e. fixtures needed by fixture functions themselves are appended + to the fixturenames list. + + Upon the test-setup phases all fixturenames are instantiated, retrieved + by a lookup of their FuncFixtureInfo. + """ + + def __init__(self, session: Session) -> None: + self.session = session + self.config: Config = session.config + # Maps a fixture name (argname) to all of the FixtureDefs in the test + # suite/plugins defined with this name. Populated by parsefactories(). + # TODO: The order of the FixtureDefs list of each arg is significant, + # explain. + self._arg2fixturedefs: Final[dict[str, list[FixtureDef[Any]]]] = {} + self._holderobjseen: Final[set[object]] = set() + # A mapping from a nodeid to a list of autouse fixtures it defines. + self._nodeid_autousenames: Final[dict[str, list[str]]] = { + "": self.config.getini("usefixtures"), + } + session.config.pluginmanager.register(self, "funcmanage") + + def getfixtureinfo( + self, + node: nodes.Item, + func: Callable[..., object] | None, + cls: type | None, + ) -> FuncFixtureInfo: + """Calculate the :class:`FuncFixtureInfo` for an item. + + If ``func`` is None, or if the item sets an attribute + ``nofuncargs = True``, then ``func`` is not examined at all. + + :param node: + The item requesting the fixtures. + :param func: + The item's function. + :param cls: + If the function is a method, the method's class. + """ + if func is not None and not getattr(node, "nofuncargs", False): + argnames = getfuncargnames(func, name=node.name, cls=cls) + else: + argnames = () + usefixturesnames = self._getusefixturesnames(node) + autousenames = self._getautousenames(node) + initialnames = deduplicate_names(autousenames, usefixturesnames, argnames) + + direct_parametrize_args = _get_direct_parametrize_args(node) + + names_closure, arg2fixturedefs = self.getfixtureclosure( + parentnode=node, + initialnames=initialnames, + ignore_args=direct_parametrize_args, + ) + + return FuncFixtureInfo(argnames, initialnames, names_closure, arg2fixturedefs) + + def pytest_plugin_registered(self, plugin: _PluggyPlugin, plugin_name: str) -> None: + # Fixtures defined in conftest plugins are only visible to within the + # conftest's directory. This is unlike fixtures in non-conftest plugins + # which have global visibility. So for conftests, construct the base + # nodeid from the plugin name (which is the conftest path). + if plugin_name and plugin_name.endswith("conftest.py"): + # Note: we explicitly do *not* use `plugin.__file__` here -- The + # difference is that plugin_name has the correct capitalization on + # case-insensitive systems (Windows) and other normalization issues + # (issue #11816). + conftestpath = absolutepath(plugin_name) + try: + nodeid = str(conftestpath.parent.relative_to(self.config.rootpath)) + except ValueError: + nodeid = "" + if nodeid == ".": + nodeid = "" + if os.sep != nodes.SEP: + nodeid = nodeid.replace(os.sep, nodes.SEP) + else: + nodeid = None + + self.parsefactories(plugin, nodeid) + + def _getautousenames(self, node: nodes.Node) -> Iterator[str]: + """Return the names of autouse fixtures applicable to node.""" + for parentnode in node.listchain(): + basenames = self._nodeid_autousenames.get(parentnode.nodeid) + if basenames: + yield from basenames + + def _getusefixturesnames(self, node: nodes.Item) -> Iterator[str]: + """Return the names of usefixtures fixtures applicable to node.""" + for mark in node.iter_markers(name="usefixtures"): + yield from mark.args + + def getfixtureclosure( + self, + parentnode: nodes.Node, + initialnames: tuple[str, ...], + ignore_args: AbstractSet[str], + ) -> tuple[list[str], dict[str, Sequence[FixtureDef[Any]]]]: + # Collect the closure of all fixtures, starting with the given + # fixturenames as the initial set. As we have to visit all + # factory definitions anyway, we also return an arg2fixturedefs + # mapping so that the caller can reuse it and does not have + # to re-discover fixturedefs again for each fixturename + # (discovering matching fixtures for a given name/node is expensive). + + fixturenames_closure = list(initialnames) + + arg2fixturedefs: dict[str, Sequence[FixtureDef[Any]]] = {} + lastlen = -1 + while lastlen != len(fixturenames_closure): + lastlen = len(fixturenames_closure) + for argname in fixturenames_closure: + if argname in ignore_args: + continue + if argname in arg2fixturedefs: + continue + fixturedefs = self.getfixturedefs(argname, parentnode) + if fixturedefs: + arg2fixturedefs[argname] = fixturedefs + for arg in fixturedefs[-1].argnames: + if arg not in fixturenames_closure: + fixturenames_closure.append(arg) + + def sort_by_scope(arg_name: str) -> Scope: + try: + fixturedefs = arg2fixturedefs[arg_name] + except KeyError: + return Scope.Function + else: + return fixturedefs[-1]._scope + + fixturenames_closure.sort(key=sort_by_scope, reverse=True) + return fixturenames_closure, arg2fixturedefs + + def pytest_generate_tests(self, metafunc: Metafunc) -> None: + """Generate new tests based on parametrized fixtures used by the given metafunc""" + + def get_parametrize_mark_argnames(mark: Mark) -> Sequence[str]: + args, _ = ParameterSet._parse_parametrize_args(*mark.args, **mark.kwargs) + return args + + for argname in metafunc.fixturenames: + # Get the FixtureDefs for the argname. + fixture_defs = metafunc._arg2fixturedefs.get(argname) + if not fixture_defs: + # Will raise FixtureLookupError at setup time if not parametrized somewhere + # else (e.g @pytest.mark.parametrize) + continue + + # If the test itself parametrizes using this argname, give it + # precedence. + if any( + argname in get_parametrize_mark_argnames(mark) + for mark in metafunc.definition.iter_markers("parametrize") + ): + continue + + # In the common case we only look at the fixture def with the + # closest scope (last in the list). But if the fixture overrides + # another fixture, while requesting the super fixture, keep going + # in case the super fixture is parametrized (#1953). + for fixturedef in reversed(fixture_defs): + # Fixture is parametrized, apply it and stop. + if fixturedef.params is not None: + metafunc.parametrize( + argname, + fixturedef.params, + indirect=True, + scope=fixturedef.scope, + ids=fixturedef.ids, + ) + break + + # Not requesting the overridden super fixture, stop. + if argname not in fixturedef.argnames: + break + + # Try next super fixture, if any. + + def pytest_collection_modifyitems(self, items: list[nodes.Item]) -> None: + # Separate parametrized setups. + items[:] = reorder_items(items) + + def _register_fixture( + self, + *, + name: str, + func: _FixtureFunc[object], + nodeid: str | None, + scope: Scope | _ScopeName | Callable[[str, Config], _ScopeName] = "function", + params: Sequence[object] | None = None, + ids: tuple[object | None, ...] | Callable[[Any], object | None] | None = None, + autouse: bool = False, + ) -> None: + """Register a fixture + + :param name: + The fixture's name. + :param func: + The fixture's implementation function. + :param nodeid: + The visibility of the fixture. The fixture will be available to the + node with this nodeid and its children in the collection tree. + None means that the fixture is visible to the entire collection tree, + e.g. a fixture defined for general use in a plugin. + :param scope: + The fixture's scope. + :param params: + The fixture's parametrization params. + :param ids: + The fixture's IDs. + :param autouse: + Whether this is an autouse fixture. + """ + fixture_def = FixtureDef( + config=self.config, + baseid=nodeid, + argname=name, + func=func, + scope=scope, + params=params, + ids=ids, + _ispytest=True, + ) + + faclist = self._arg2fixturedefs.setdefault(name, []) + if fixture_def.has_location: + faclist.append(fixture_def) + else: + # fixturedefs with no location are at the front + # so this inserts the current fixturedef after the + # existing fixturedefs from external plugins but + # before the fixturedefs provided in conftests. + i = len([f for f in faclist if not f.has_location]) + faclist.insert(i, fixture_def) + if autouse: + self._nodeid_autousenames.setdefault(nodeid or "", []).append(name) + + @overload + def parsefactories( + self, + node_or_obj: nodes.Node, + ) -> None: + raise NotImplementedError() + + @overload + def parsefactories( + self, + node_or_obj: object, + nodeid: str | None, + ) -> None: + raise NotImplementedError() + + def parsefactories( + self, + node_or_obj: nodes.Node | object, + nodeid: str | NotSetType | None = NOTSET, + ) -> None: + """Collect fixtures from a collection node or object. + + Found fixtures are parsed into `FixtureDef`s and saved. + + If `node_or_object` is a collection node (with an underlying Python + object), the node's object is traversed and the node's nodeid is used to + determine the fixtures' visibility. `nodeid` must not be specified in + this case. + + If `node_or_object` is an object (e.g. a plugin), the object is + traversed and the given `nodeid` is used to determine the fixtures' + visibility. `nodeid` must be specified in this case; None and "" mean + total visibility. + """ + if nodeid is not NOTSET: + holderobj = node_or_obj + else: + assert isinstance(node_or_obj, nodes.Node) + holderobj = cast(object, node_or_obj.obj) # type: ignore[attr-defined] + assert isinstance(node_or_obj.nodeid, str) + nodeid = node_or_obj.nodeid + if holderobj in self._holderobjseen: + return + + # Avoid accessing `@property` (and other descriptors) when iterating fixtures. + if not safe_isclass(holderobj) and not isinstance(holderobj, types.ModuleType): + holderobj_tp: object = type(holderobj) + else: + holderobj_tp = holderobj + + self._holderobjseen.add(holderobj) + for name in dir(holderobj): + # The attribute can be an arbitrary descriptor, so the attribute + # access below can raise. safe_getattr() ignores such exceptions. + obj_ub = safe_getattr(holderobj_tp, name, None) + marker = getfixturemarker(obj_ub) + if not isinstance(marker, FixtureFunctionMarker): + # Magic globals with __getattr__ might have got us a wrong + # fixture attribute. + continue + + # OK we know it is a fixture -- now safe to look up on the _instance_. + obj = getattr(holderobj, name) + + if marker.name: + name = marker.name + + # During fixture definition we wrap the original fixture function + # to issue a warning if called directly, so here we unwrap it in + # order to not emit the warning when pytest itself calls the + # fixture function. + func = get_real_method(obj, holderobj) + + self._register_fixture( + name=name, + nodeid=nodeid, + func=func, + scope=marker.scope, + params=marker.params, + ids=marker.ids, + autouse=marker.autouse, + ) + + def getfixturedefs( + self, argname: str, node: nodes.Node + ) -> Sequence[FixtureDef[Any]] | None: + """Get FixtureDefs for a fixture name which are applicable + to a given node. + + Returns None if there are no fixtures at all defined with the given + name. (This is different from the case in which there are fixtures + with the given name, but none applicable to the node. In this case, + an empty result is returned). + + :param argname: Name of the fixture to search for. + :param node: The requesting Node. + """ + try: + fixturedefs = self._arg2fixturedefs[argname] + except KeyError: + return None + return tuple(self._matchfactories(fixturedefs, node)) + + def _matchfactories( + self, fixturedefs: Iterable[FixtureDef[Any]], node: nodes.Node + ) -> Iterator[FixtureDef[Any]]: + parentnodeids = {n.nodeid for n in node.iter_parents()} + for fixturedef in fixturedefs: + if fixturedef.baseid in parentnodeids: + yield fixturedef + + +def show_fixtures_per_test(config: Config) -> int | ExitCode: + from _pytest.main import wrap_session + + return wrap_session(config, _show_fixtures_per_test) + + +_PYTEST_DIR = Path(_pytest.__file__).parent + + +def _pretty_fixture_path(invocation_dir: Path, func) -> str: + loc = Path(getlocation(func, invocation_dir)) + prefix = Path("...", "_pytest") + try: + return str(prefix / loc.relative_to(_PYTEST_DIR)) + except ValueError: + return bestrelpath(invocation_dir, loc) + + +def _show_fixtures_per_test(config: Config, session: Session) -> None: + import _pytest.config + + session.perform_collect() + invocation_dir = config.invocation_params.dir + tw = _pytest.config.create_terminal_writer(config) + verbose = config.get_verbosity() + + def get_best_relpath(func) -> str: + loc = getlocation(func, invocation_dir) + return bestrelpath(invocation_dir, Path(loc)) + + def write_fixture(fixture_def: FixtureDef[object]) -> None: + argname = fixture_def.argname + if verbose <= 0 and argname.startswith("_"): + return + prettypath = _pretty_fixture_path(invocation_dir, fixture_def.func) + tw.write(f"{argname}", green=True) + tw.write(f" -- {prettypath}", yellow=True) + tw.write("\n") + fixture_doc = inspect.getdoc(fixture_def.func) + if fixture_doc: + write_docstring( + tw, + fixture_doc.split("\n\n", maxsplit=1)[0] + if verbose <= 0 + else fixture_doc, + ) + else: + tw.line(" no docstring available", red=True) + + def write_item(item: nodes.Item) -> None: + # Not all items have _fixtureinfo attribute. + info: FuncFixtureInfo | None = getattr(item, "_fixtureinfo", None) + if info is None or not info.name2fixturedefs: + # This test item does not use any fixtures. + return + tw.line() + tw.sep("-", f"fixtures used by {item.name}") + # TODO: Fix this type ignore. + tw.sep("-", f"({get_best_relpath(item.function)})") # type: ignore[attr-defined] + # dict key not used in loop but needed for sorting. + for _, fixturedefs in sorted(info.name2fixturedefs.items()): + assert fixturedefs is not None + if not fixturedefs: + continue + # Last item is expected to be the one used by the test item. + write_fixture(fixturedefs[-1]) + + for session_item in session.items: + write_item(session_item) + + +def showfixtures(config: Config) -> int | ExitCode: + from _pytest.main import wrap_session + + return wrap_session(config, _showfixtures_main) + + +def _showfixtures_main(config: Config, session: Session) -> None: + import _pytest.config + + session.perform_collect() + invocation_dir = config.invocation_params.dir + tw = _pytest.config.create_terminal_writer(config) + verbose = config.get_verbosity() + + fm = session._fixturemanager + + available = [] + seen: set[tuple[str, str]] = set() + + for argname, fixturedefs in fm._arg2fixturedefs.items(): + assert fixturedefs is not None + if not fixturedefs: + continue + for fixturedef in fixturedefs: + loc = getlocation(fixturedef.func, invocation_dir) + if (fixturedef.argname, loc) in seen: + continue + seen.add((fixturedef.argname, loc)) + available.append( + ( + len(fixturedef.baseid), + fixturedef.func.__module__, + _pretty_fixture_path(invocation_dir, fixturedef.func), + fixturedef.argname, + fixturedef, + ) + ) + + available.sort() + currentmodule = None + for baseid, module, prettypath, argname, fixturedef in available: + if currentmodule != module: + if not module.startswith("_pytest."): + tw.line() + tw.sep("-", f"fixtures defined from {module}") + currentmodule = module + if verbose <= 0 and argname.startswith("_"): + continue + tw.write(f"{argname}", green=True) + if fixturedef.scope != "function": + tw.write(f" [{fixturedef.scope} scope]", cyan=True) + tw.write(f" -- {prettypath}", yellow=True) + tw.write("\n") + doc = inspect.getdoc(fixturedef.func) + if doc: + write_docstring( + tw, doc.split("\n\n", maxsplit=1)[0] if verbose <= 0 else doc + ) + else: + tw.line(" no docstring available", red=True) + tw.line() + + +def write_docstring(tw: TerminalWriter, doc: str, indent: str = " ") -> None: + for line in doc.split("\n"): + tw.line(indent + line) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/freeze_support.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/freeze_support.py new file mode 100644 index 0000000..2ba6f9b --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/freeze_support.py @@ -0,0 +1,45 @@ +"""Provides a function to report all internal modules for using freezing +tools.""" + +from __future__ import annotations + +import types +from typing import Iterator + + +def freeze_includes() -> list[str]: + """Return a list of module names used by pytest that should be + included by cx_freeze.""" + import _pytest + + result = list(_iter_all_modules(_pytest)) + return result + + +def _iter_all_modules( + package: str | types.ModuleType, + prefix: str = "", +) -> Iterator[str]: + """Iterate over the names of all modules that can be found in the given + package, recursively. + + >>> import _pytest + >>> list(_iter_all_modules(_pytest)) + ['_pytest._argcomplete', '_pytest._code.code', ...] + """ + import os + import pkgutil + + if isinstance(package, str): + path = package + else: + # Type ignored because typeshed doesn't define ModuleType.__path__ + # (only defined on packages). + package_path = package.__path__ + path, prefix = package_path[0], package.__name__ + "." + for _, name, is_package in pkgutil.iter_modules([path]): + if is_package: + for m in _iter_all_modules(os.path.join(path, name), prefix=name + "."): + yield prefix + m + else: + yield prefix + name diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/helpconfig.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/helpconfig.py new file mode 100644 index 0000000..1886d5c --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/helpconfig.py @@ -0,0 +1,276 @@ +# mypy: allow-untyped-defs +"""Version info, help messages, tracing configuration.""" + +from __future__ import annotations + +from argparse import Action +import os +import sys +from typing import Generator + +from _pytest.config import Config +from _pytest.config import ExitCode +from _pytest.config import PrintHelp +from _pytest.config.argparsing import Parser +from _pytest.terminal import TerminalReporter +import pytest + + +class HelpAction(Action): + """An argparse Action that will raise an exception in order to skip the + rest of the argument parsing when --help is passed. + + This prevents argparse from quitting due to missing required arguments + when any are defined, for example by ``pytest_addoption``. + This is similar to the way that the builtin argparse --help option is + implemented by raising SystemExit. + """ + + def __init__(self, option_strings, dest=None, default=False, help=None): + super().__init__( + option_strings=option_strings, + dest=dest, + const=True, + default=default, + nargs=0, + help=help, + ) + + def __call__(self, parser, namespace, values, option_string=None): + setattr(namespace, self.dest, self.const) + + # We should only skip the rest of the parsing after preparse is done. + if getattr(parser._parser, "after_preparse", False): + raise PrintHelp + + +def pytest_addoption(parser: Parser) -> None: + group = parser.getgroup("debugconfig") + group.addoption( + "--version", + "-V", + action="count", + default=0, + dest="version", + help="Display pytest version and information about plugins. " + "When given twice, also display information about plugins.", + ) + group._addoption( + "-h", + "--help", + action=HelpAction, + dest="help", + help="Show help message and configuration info", + ) + group._addoption( + "-p", + action="append", + dest="plugins", + default=[], + metavar="name", + help="Early-load given plugin module name or entry point (multi-allowed). " + "To avoid loading of plugins, use the `no:` prefix, e.g. " + "`no:doctest`.", + ) + group.addoption( + "--traceconfig", + "--trace-config", + action="store_true", + default=False, + help="Trace considerations of conftest.py files", + ) + group.addoption( + "--debug", + action="store", + nargs="?", + const="pytestdebug.log", + dest="debug", + metavar="DEBUG_FILE_NAME", + help="Store internal tracing debug information in this log file. " + "This file is opened with 'w' and truncated as a result, care advised. " + "Default: pytestdebug.log.", + ) + group._addoption( + "-o", + "--override-ini", + dest="override_ini", + action="append", + help='Override ini option with "option=value" style, ' + "e.g. `-o xfail_strict=True -o cache_dir=cache`.", + ) + + +@pytest.hookimpl(wrapper=True) +def pytest_cmdline_parse() -> Generator[None, Config, Config]: + config = yield + + if config.option.debug: + # --debug | --debug was provided. + path = config.option.debug + debugfile = open(path, "w", encoding="utf-8") + debugfile.write( + "versions pytest-{}, " + "python-{}\ninvocation_dir={}\ncwd={}\nargs={}\n\n".format( + pytest.__version__, + ".".join(map(str, sys.version_info)), + config.invocation_params.dir, + os.getcwd(), + config.invocation_params.args, + ) + ) + config.trace.root.setwriter(debugfile.write) + undo_tracing = config.pluginmanager.enable_tracing() + sys.stderr.write(f"writing pytest debug information to {path}\n") + + def unset_tracing() -> None: + debugfile.close() + sys.stderr.write(f"wrote pytest debug information to {debugfile.name}\n") + config.trace.root.setwriter(None) + undo_tracing() + + config.add_cleanup(unset_tracing) + + return config + + +def showversion(config: Config) -> None: + if config.option.version > 1: + sys.stdout.write( + f"This is pytest version {pytest.__version__}, imported from {pytest.__file__}\n" + ) + plugininfo = getpluginversioninfo(config) + if plugininfo: + for line in plugininfo: + sys.stdout.write(line + "\n") + else: + sys.stdout.write(f"pytest {pytest.__version__}\n") + + +def pytest_cmdline_main(config: Config) -> int | ExitCode | None: + if config.option.version > 0: + showversion(config) + return 0 + elif config.option.help: + config._do_configure() + showhelp(config) + config._ensure_unconfigure() + return 0 + return None + + +def showhelp(config: Config) -> None: + import textwrap + + reporter: TerminalReporter | None = config.pluginmanager.get_plugin( + "terminalreporter" + ) + assert reporter is not None + tw = reporter._tw + tw.write(config._parser.optparser.format_help()) + tw.line() + tw.line( + "[pytest] ini-options in the first " + "pytest.ini|tox.ini|setup.cfg|pyproject.toml file found:" + ) + tw.line() + + columns = tw.fullwidth # costly call + indent_len = 24 # based on argparse's max_help_position=24 + indent = " " * indent_len + for name in config._parser._ininames: + help, type, default = config._parser._inidict[name] + if type is None: + type = "string" + if help is None: + raise TypeError(f"help argument cannot be None for {name}") + spec = f"{name} ({type}):" + tw.write(f" {spec}") + spec_len = len(spec) + if spec_len > (indent_len - 3): + # Display help starting at a new line. + tw.line() + helplines = textwrap.wrap( + help, + columns, + initial_indent=indent, + subsequent_indent=indent, + break_on_hyphens=False, + ) + + for line in helplines: + tw.line(line) + else: + # Display help starting after the spec, following lines indented. + tw.write(" " * (indent_len - spec_len - 2)) + wrapped = textwrap.wrap(help, columns - indent_len, break_on_hyphens=False) + + if wrapped: + tw.line(wrapped[0]) + for line in wrapped[1:]: + tw.line(indent + line) + + tw.line() + tw.line("Environment variables:") + vars = [ + ( + "CI", + "When set (regardless of value), pytest knows it is running in a " + "CI process and does not truncate summary info", + ), + ("BUILD_NUMBER", "Equivalent to CI"), + ("PYTEST_ADDOPTS", "Extra command line options"), + ("PYTEST_PLUGINS", "Comma-separated plugins to load during startup"), + ("PYTEST_DISABLE_PLUGIN_AUTOLOAD", "Set to disable plugin auto-loading"), + ("PYTEST_DEBUG", "Set to enable debug tracing of pytest's internals"), + ] + for name, help in vars: + tw.line(f" {name:<24} {help}") + tw.line() + tw.line() + + tw.line("to see available markers type: pytest --markers") + tw.line("to see available fixtures type: pytest --fixtures") + tw.line( + "(shown according to specified file_or_dir or current dir " + "if not specified; fixtures with leading '_' are only shown " + "with the '-v' option" + ) + + for warningreport in reporter.stats.get("warnings", []): + tw.line("warning : " + warningreport.message, red=True) + + +conftest_options = [("pytest_plugins", "list of plugin names to load")] + + +def getpluginversioninfo(config: Config) -> list[str]: + lines = [] + plugininfo = config.pluginmanager.list_plugin_distinfo() + if plugininfo: + lines.append("registered third-party plugins:") + for plugin, dist in plugininfo: + loc = getattr(plugin, "__file__", repr(plugin)) + content = f"{dist.project_name}-{dist.version} at {loc}" + lines.append(" " + content) + return lines + + +def pytest_report_header(config: Config) -> list[str]: + lines = [] + if config.option.debug or config.option.traceconfig: + lines.append(f"using: pytest-{pytest.__version__}") + + verinfo = getpluginversioninfo(config) + if verinfo: + lines.extend(verinfo) + + if config.option.traceconfig: + lines.append("active plugins:") + items = config.pluginmanager.list_name_plugin() + for name, plugin in items: + if hasattr(plugin, "__file__"): + r = plugin.__file__ + else: + r = repr(plugin) + lines.append(f" {name:<20}: {r}") + return lines diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/hookspec.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/hookspec.py new file mode 100644 index 0000000..0a41b0a --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/hookspec.py @@ -0,0 +1,1333 @@ +# mypy: allow-untyped-defs +# ruff: noqa: T100 +"""Hook specifications for pytest plugins which are invoked by pytest itself +and by builtin plugins.""" + +from __future__ import annotations + +from pathlib import Path +from typing import Any +from typing import Mapping +from typing import Sequence +from typing import TYPE_CHECKING + +from pluggy import HookspecMarker + +from .deprecated import HOOK_LEGACY_PATH_ARG + + +if TYPE_CHECKING: + import pdb + from typing import Literal + import warnings + + from _pytest._code.code import ExceptionInfo + from _pytest._code.code import ExceptionRepr + from _pytest.compat import LEGACY_PATH + from _pytest.config import _PluggyPlugin + from _pytest.config import Config + from _pytest.config import ExitCode + from _pytest.config import PytestPluginManager + from _pytest.config.argparsing import Parser + from _pytest.fixtures import FixtureDef + from _pytest.fixtures import SubRequest + from _pytest.main import Session + from _pytest.nodes import Collector + from _pytest.nodes import Item + from _pytest.outcomes import Exit + from _pytest.python import Class + from _pytest.python import Function + from _pytest.python import Metafunc + from _pytest.python import Module + from _pytest.reports import CollectReport + from _pytest.reports import TestReport + from _pytest.runner import CallInfo + from _pytest.terminal import TerminalReporter + from _pytest.terminal import TestShortLogReport + + +hookspec = HookspecMarker("pytest") + +# ------------------------------------------------------------------------- +# Initialization hooks called for every plugin +# ------------------------------------------------------------------------- + + +@hookspec(historic=True) +def pytest_addhooks(pluginmanager: PytestPluginManager) -> None: + """Called at plugin registration time to allow adding new hooks via a call to + :func:`pluginmanager.add_hookspecs(module_or_class, prefix) `. + + :param pluginmanager: The pytest plugin manager. + + .. note:: + This hook is incompatible with hook wrappers. + + Use in conftest plugins + ======================= + + If a conftest plugin implements this hook, it will be called immediately + when the conftest is registered. + """ + + +@hookspec(historic=True) +def pytest_plugin_registered( + plugin: _PluggyPlugin, + plugin_name: str, + manager: PytestPluginManager, +) -> None: + """A new pytest plugin got registered. + + :param plugin: The plugin module or instance. + :param plugin_name: The name by which the plugin is registered. + :param manager: The pytest plugin manager. + + .. note:: + This hook is incompatible with hook wrappers. + + Use in conftest plugins + ======================= + + If a conftest plugin implements this hook, it will be called immediately + when the conftest is registered, once for each plugin registered thus far + (including itself!), and for all plugins thereafter when they are + registered. + """ + + +@hookspec(historic=True) +def pytest_addoption(parser: Parser, pluginmanager: PytestPluginManager) -> None: + """Register argparse-style options and ini-style config values, + called once at the beginning of a test run. + + :param parser: + To add command line options, call + :py:func:`parser.addoption(...) `. + To add ini-file values call :py:func:`parser.addini(...) + `. + + :param pluginmanager: + The pytest plugin manager, which can be used to install :py:func:`~pytest.hookspec`'s + or :py:func:`~pytest.hookimpl`'s and allow one plugin to call another plugin's hooks + to change how command line options are added. + + Options can later be accessed through the + :py:class:`config ` object, respectively: + + - :py:func:`config.getoption(name) ` to + retrieve the value of a command line option. + + - :py:func:`config.getini(name) ` to retrieve + a value read from an ini-style file. + + The config object is passed around on many internal objects via the ``.config`` + attribute or can be retrieved as the ``pytestconfig`` fixture. + + .. note:: + This hook is incompatible with hook wrappers. + + Use in conftest plugins + ======================= + + If a conftest plugin implements this hook, it will be called immediately + when the conftest is registered. + + This hook is only called for :ref:`initial conftests `. + """ + + +@hookspec(historic=True) +def pytest_configure(config: Config) -> None: + """Allow plugins and conftest files to perform initial configuration. + + .. note:: + This hook is incompatible with hook wrappers. + + :param config: The pytest config object. + + Use in conftest plugins + ======================= + + This hook is called for every :ref:`initial conftest ` file + after command line options have been parsed. After that, the hook is called + for other conftest files as they are registered. + """ + + +# ------------------------------------------------------------------------- +# Bootstrapping hooks called for plugins registered early enough: +# internal and 3rd party plugins. +# ------------------------------------------------------------------------- + + +@hookspec(firstresult=True) +def pytest_cmdline_parse( + pluginmanager: PytestPluginManager, args: list[str] +) -> Config | None: + """Return an initialized :class:`~pytest.Config`, parsing the specified args. + + Stops at first non-None result, see :ref:`firstresult`. + + .. note:: + This hook is only called for plugin classes passed to the + ``plugins`` arg when using `pytest.main`_ to perform an in-process + test run. + + :param pluginmanager: The pytest plugin manager. + :param args: List of arguments passed on the command line. + :returns: A pytest config object. + + Use in conftest plugins + ======================= + + This hook is not called for conftest files. + """ + + +def pytest_load_initial_conftests( + early_config: Config, parser: Parser, args: list[str] +) -> None: + """Called to implement the loading of :ref:`initial conftest files + ` ahead of command line option parsing. + + :param early_config: The pytest config object. + :param args: Arguments passed on the command line. + :param parser: To add command line options. + + Use in conftest plugins + ======================= + + This hook is not called for conftest files. + """ + + +@hookspec(firstresult=True) +def pytest_cmdline_main(config: Config) -> ExitCode | int | None: + """Called for performing the main command line action. + + The default implementation will invoke the configure hooks and + :hook:`pytest_runtestloop`. + + Stops at first non-None result, see :ref:`firstresult`. + + :param config: The pytest config object. + :returns: The exit code. + + Use in conftest plugins + ======================= + + This hook is only called for :ref:`initial conftests `. + """ + + +# ------------------------------------------------------------------------- +# collection hooks +# ------------------------------------------------------------------------- + + +@hookspec(firstresult=True) +def pytest_collection(session: Session) -> object | None: + """Perform the collection phase for the given session. + + Stops at first non-None result, see :ref:`firstresult`. + The return value is not used, but only stops further processing. + + The default collection phase is this (see individual hooks for full details): + + 1. Starting from ``session`` as the initial collector: + + 1. ``pytest_collectstart(collector)`` + 2. ``report = pytest_make_collect_report(collector)`` + 3. ``pytest_exception_interact(collector, call, report)`` if an interactive exception occurred + 4. For each collected node: + + 1. If an item, ``pytest_itemcollected(item)`` + 2. If a collector, recurse into it. + + 5. ``pytest_collectreport(report)`` + + 2. ``pytest_collection_modifyitems(session, config, items)`` + + 1. ``pytest_deselected(items)`` for any deselected items (may be called multiple times) + + 3. ``pytest_collection_finish(session)`` + 4. Set ``session.items`` to the list of collected items + 5. Set ``session.testscollected`` to the number of collected items + + You can implement this hook to only perform some action before collection, + for example the terminal plugin uses it to start displaying the collection + counter (and returns `None`). + + :param session: The pytest session object. + + Use in conftest plugins + ======================= + + This hook is only called for :ref:`initial conftests `. + """ + + +def pytest_collection_modifyitems( + session: Session, config: Config, items: list[Item] +) -> None: + """Called after collection has been performed. May filter or re-order + the items in-place. + + When items are deselected (filtered out from ``items``), + the hook :hook:`pytest_deselected` must be called explicitly + with the deselected items to properly notify other plugins, + e.g. with ``config.hook.pytest_deselected(deselected_items)``. + + :param session: The pytest session object. + :param config: The pytest config object. + :param items: List of item objects. + + Use in conftest plugins + ======================= + + Any conftest plugin can implement this hook. + """ + + +def pytest_collection_finish(session: Session) -> None: + """Called after collection has been performed and modified. + + :param session: The pytest session object. + + Use in conftest plugins + ======================= + + Any conftest plugin can implement this hook. + """ + + +@hookspec( + firstresult=True, + warn_on_impl_args={ + "path": HOOK_LEGACY_PATH_ARG.format( + pylib_path_arg="path", pathlib_path_arg="collection_path" + ), + }, +) +def pytest_ignore_collect( + collection_path: Path, path: LEGACY_PATH, config: Config +) -> bool | None: + """Return ``True`` to ignore this path for collection. + + Return ``None`` to let other plugins ignore the path for collection. + + Returning ``False`` will forcefully *not* ignore this path for collection, + without giving a chance for other plugins to ignore this path. + + This hook is consulted for all files and directories prior to calling + more specific hooks. + + Stops at first non-None result, see :ref:`firstresult`. + + :param collection_path: The path to analyze. + :type collection_path: pathlib.Path + :param path: The path to analyze (deprecated). + :param config: The pytest config object. + + .. versionchanged:: 7.0.0 + The ``collection_path`` parameter was added as a :class:`pathlib.Path` + equivalent of the ``path`` parameter. The ``path`` parameter + has been deprecated. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given collection path, only + conftest files in parent directories of the collection path are consulted + (if the path is a directory, its own conftest file is *not* consulted - a + directory cannot ignore itself!). + """ + + +@hookspec(firstresult=True) +def pytest_collect_directory(path: Path, parent: Collector) -> Collector | None: + """Create a :class:`~pytest.Collector` for the given directory, or None if + not relevant. + + .. versionadded:: 8.0 + + For best results, the returned collector should be a subclass of + :class:`~pytest.Directory`, but this is not required. + + The new node needs to have the specified ``parent`` as a parent. + + Stops at first non-None result, see :ref:`firstresult`. + + :param path: The path to analyze. + :type path: pathlib.Path + + See :ref:`custom directory collectors` for a simple example of use of this + hook. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given collection path, only + conftest files in parent directories of the collection path are consulted + (if the path is a directory, its own conftest file is *not* consulted - a + directory cannot collect itself!). + """ + + +@hookspec( + warn_on_impl_args={ + "path": HOOK_LEGACY_PATH_ARG.format( + pylib_path_arg="path", pathlib_path_arg="file_path" + ), + }, +) +def pytest_collect_file( + file_path: Path, path: LEGACY_PATH, parent: Collector +) -> Collector | None: + """Create a :class:`~pytest.Collector` for the given path, or None if not relevant. + + For best results, the returned collector should be a subclass of + :class:`~pytest.File`, but this is not required. + + The new node needs to have the specified ``parent`` as a parent. + + :param file_path: The path to analyze. + :type file_path: pathlib.Path + :param path: The path to collect (deprecated). + + .. versionchanged:: 7.0.0 + The ``file_path`` parameter was added as a :class:`pathlib.Path` + equivalent of the ``path`` parameter. The ``path`` parameter + has been deprecated. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given file path, only + conftest files in parent directories of the file path are consulted. + """ + + +# logging hooks for collection + + +def pytest_collectstart(collector: Collector) -> None: + """Collector starts collecting. + + :param collector: + The collector. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given collector, only + conftest files in the collector's directory and its parent directories are + consulted. + """ + + +def pytest_itemcollected(item: Item) -> None: + """We just collected a test item. + + :param item: + The item. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given item, only conftest + files in the item's directory and its parent directories are consulted. + """ + + +def pytest_collectreport(report: CollectReport) -> None: + """Collector finished collecting. + + :param report: + The collect report. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given collector, only + conftest files in the collector's directory and its parent directories are + consulted. + """ + + +def pytest_deselected(items: Sequence[Item]) -> None: + """Called for deselected test items, e.g. by keyword. + + Note that this hook has two integration aspects for plugins: + + - it can be *implemented* to be notified of deselected items + - it must be *called* from :hook:`pytest_collection_modifyitems` + implementations when items are deselected (to properly notify other plugins). + + May be called multiple times. + + :param items: + The items. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. + """ + + +@hookspec(firstresult=True) +def pytest_make_collect_report(collector: Collector) -> CollectReport | None: + """Perform :func:`collector.collect() ` and return + a :class:`~pytest.CollectReport`. + + Stops at first non-None result, see :ref:`firstresult`. + + :param collector: + The collector. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given collector, only + conftest files in the collector's directory and its parent directories are + consulted. + """ + + +# ------------------------------------------------------------------------- +# Python test function related hooks +# ------------------------------------------------------------------------- + + +@hookspec( + firstresult=True, + warn_on_impl_args={ + "path": HOOK_LEGACY_PATH_ARG.format( + pylib_path_arg="path", pathlib_path_arg="module_path" + ), + }, +) +def pytest_pycollect_makemodule( + module_path: Path, path: LEGACY_PATH, parent +) -> Module | None: + """Return a :class:`pytest.Module` collector or None for the given path. + + This hook will be called for each matching test module path. + The :hook:`pytest_collect_file` hook needs to be used if you want to + create test modules for files that do not match as a test module. + + Stops at first non-None result, see :ref:`firstresult`. + + :param module_path: The path of the module to collect. + :type module_path: pathlib.Path + :param path: The path of the module to collect (deprecated). + + .. versionchanged:: 7.0.0 + The ``module_path`` parameter was added as a :class:`pathlib.Path` + equivalent of the ``path`` parameter. + + The ``path`` parameter has been deprecated in favor of ``fspath``. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given parent collector, + only conftest files in the collector's directory and its parent directories + are consulted. + """ + + +@hookspec(firstresult=True) +def pytest_pycollect_makeitem( + collector: Module | Class, name: str, obj: object +) -> None | Item | Collector | list[Item | Collector]: + """Return a custom item/collector for a Python object in a module, or None. + + Stops at first non-None result, see :ref:`firstresult`. + + :param collector: + The module/class collector. + :param name: + The name of the object in the module/class. + :param obj: + The object. + :returns: + The created items/collectors. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given collector, only + conftest files in the collector's directory and its parent directories + are consulted. + """ + + +@hookspec(firstresult=True) +def pytest_pyfunc_call(pyfuncitem: Function) -> object | None: + """Call underlying test function. + + Stops at first non-None result, see :ref:`firstresult`. + + :param pyfuncitem: + The function item. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given item, only + conftest files in the item's directory and its parent directories + are consulted. + """ + + +def pytest_generate_tests(metafunc: Metafunc) -> None: + """Generate (multiple) parametrized calls to a test function. + + :param metafunc: + The :class:`~pytest.Metafunc` helper for the test function. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given function definition, + only conftest files in the functions's directory and its parent directories + are consulted. + """ + + +@hookspec(firstresult=True) +def pytest_make_parametrize_id(config: Config, val: object, argname: str) -> str | None: + """Return a user-friendly string representation of the given ``val`` + that will be used by @pytest.mark.parametrize calls, or None if the hook + doesn't know about ``val``. + + The parameter name is available as ``argname``, if required. + + Stops at first non-None result, see :ref:`firstresult`. + + :param config: The pytest config object. + :param val: The parametrized value. + :param argname: The automatic parameter name produced by pytest. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. + """ + + +# ------------------------------------------------------------------------- +# runtest related hooks +# ------------------------------------------------------------------------- + + +@hookspec(firstresult=True) +def pytest_runtestloop(session: Session) -> object | None: + """Perform the main runtest loop (after collection finished). + + The default hook implementation performs the runtest protocol for all items + collected in the session (``session.items``), unless the collection failed + or the ``collectonly`` pytest option is set. + + If at any point :py:func:`pytest.exit` is called, the loop is + terminated immediately. + + If at any point ``session.shouldfail`` or ``session.shouldstop`` are set, the + loop is terminated after the runtest protocol for the current item is finished. + + :param session: The pytest session object. + + Stops at first non-None result, see :ref:`firstresult`. + The return value is not used, but only stops further processing. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. + """ + + +@hookspec(firstresult=True) +def pytest_runtest_protocol(item: Item, nextitem: Item | None) -> object | None: + """Perform the runtest protocol for a single test item. + + The default runtest protocol is this (see individual hooks for full details): + + - ``pytest_runtest_logstart(nodeid, location)`` + + - Setup phase: + - ``call = pytest_runtest_setup(item)`` (wrapped in ``CallInfo(when="setup")``) + - ``report = pytest_runtest_makereport(item, call)`` + - ``pytest_runtest_logreport(report)`` + - ``pytest_exception_interact(call, report)`` if an interactive exception occurred + + - Call phase, if the setup passed and the ``setuponly`` pytest option is not set: + - ``call = pytest_runtest_call(item)`` (wrapped in ``CallInfo(when="call")``) + - ``report = pytest_runtest_makereport(item, call)`` + - ``pytest_runtest_logreport(report)`` + - ``pytest_exception_interact(call, report)`` if an interactive exception occurred + + - Teardown phase: + - ``call = pytest_runtest_teardown(item, nextitem)`` (wrapped in ``CallInfo(when="teardown")``) + - ``report = pytest_runtest_makereport(item, call)`` + - ``pytest_runtest_logreport(report)`` + - ``pytest_exception_interact(call, report)`` if an interactive exception occurred + + - ``pytest_runtest_logfinish(nodeid, location)`` + + :param item: Test item for which the runtest protocol is performed. + :param nextitem: The scheduled-to-be-next test item (or None if this is the end my friend). + + Stops at first non-None result, see :ref:`firstresult`. + The return value is not used, but only stops further processing. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. + """ + + +def pytest_runtest_logstart(nodeid: str, location: tuple[str, int | None, str]) -> None: + """Called at the start of running the runtest protocol for a single item. + + See :hook:`pytest_runtest_protocol` for a description of the runtest protocol. + + :param nodeid: Full node ID of the item. + :param location: A tuple of ``(filename, lineno, testname)`` + where ``filename`` is a file path relative to ``config.rootpath`` + and ``lineno`` is 0-based. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given item, only conftest + files in the item's directory and its parent directories are consulted. + """ + + +def pytest_runtest_logfinish( + nodeid: str, location: tuple[str, int | None, str] +) -> None: + """Called at the end of running the runtest protocol for a single item. + + See :hook:`pytest_runtest_protocol` for a description of the runtest protocol. + + :param nodeid: Full node ID of the item. + :param location: A tuple of ``(filename, lineno, testname)`` + where ``filename`` is a file path relative to ``config.rootpath`` + and ``lineno`` is 0-based. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given item, only conftest + files in the item's directory and its parent directories are consulted. + """ + + +def pytest_runtest_setup(item: Item) -> None: + """Called to perform the setup phase for a test item. + + The default implementation runs ``setup()`` on ``item`` and all of its + parents (which haven't been setup yet). This includes obtaining the + values of fixtures required by the item (which haven't been obtained + yet). + + :param item: + The item. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given item, only conftest + files in the item's directory and its parent directories are consulted. + """ + + +def pytest_runtest_call(item: Item) -> None: + """Called to run the test for test item (the call phase). + + The default implementation calls ``item.runtest()``. + + :param item: + The item. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given item, only conftest + files in the item's directory and its parent directories are consulted. + """ + + +def pytest_runtest_teardown(item: Item, nextitem: Item | None) -> None: + """Called to perform the teardown phase for a test item. + + The default implementation runs the finalizers and calls ``teardown()`` + on ``item`` and all of its parents (which need to be torn down). This + includes running the teardown phase of fixtures required by the item (if + they go out of scope). + + :param item: + The item. + :param nextitem: + The scheduled-to-be-next test item (None if no further test item is + scheduled). This argument is used to perform exact teardowns, i.e. + calling just enough finalizers so that nextitem only needs to call + setup functions. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given item, only conftest + files in the item's directory and its parent directories are consulted. + """ + + +@hookspec(firstresult=True) +def pytest_runtest_makereport(item: Item, call: CallInfo[None]) -> TestReport | None: + """Called to create a :class:`~pytest.TestReport` for each of + the setup, call and teardown runtest phases of a test item. + + See :hook:`pytest_runtest_protocol` for a description of the runtest protocol. + + :param item: The item. + :param call: The :class:`~pytest.CallInfo` for the phase. + + Stops at first non-None result, see :ref:`firstresult`. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given item, only conftest + files in the item's directory and its parent directories are consulted. + """ + + +def pytest_runtest_logreport(report: TestReport) -> None: + """Process the :class:`~pytest.TestReport` produced for each + of the setup, call and teardown runtest phases of an item. + + See :hook:`pytest_runtest_protocol` for a description of the runtest protocol. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given item, only conftest + files in the item's directory and its parent directories are consulted. + """ + + +@hookspec(firstresult=True) +def pytest_report_to_serializable( + config: Config, + report: CollectReport | TestReport, +) -> dict[str, Any] | None: + """Serialize the given report object into a data structure suitable for + sending over the wire, e.g. converted to JSON. + + :param config: The pytest config object. + :param report: The report. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. The exact details may depend + on the plugin which calls the hook. + """ + + +@hookspec(firstresult=True) +def pytest_report_from_serializable( + config: Config, + data: dict[str, Any], +) -> CollectReport | TestReport | None: + """Restore a report object previously serialized with + :hook:`pytest_report_to_serializable`. + + :param config: The pytest config object. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. The exact details may depend + on the plugin which calls the hook. + """ + + +# ------------------------------------------------------------------------- +# Fixture related hooks +# ------------------------------------------------------------------------- + + +@hookspec(firstresult=True) +def pytest_fixture_setup( + fixturedef: FixtureDef[Any], request: SubRequest +) -> object | None: + """Perform fixture setup execution. + + :param fixturedef: + The fixture definition object. + :param request: + The fixture request object. + :returns: + The return value of the call to the fixture function. + + Stops at first non-None result, see :ref:`firstresult`. + + .. note:: + If the fixture function returns None, other implementations of + this hook function will continue to be called, according to the + behavior of the :ref:`firstresult` option. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given fixture, only + conftest files in the fixture scope's directory and its parent directories + are consulted. + """ + + +def pytest_fixture_post_finalizer( + fixturedef: FixtureDef[Any], request: SubRequest +) -> None: + """Called after fixture teardown, but before the cache is cleared, so + the fixture result ``fixturedef.cached_result`` is still available (not + ``None``). + + :param fixturedef: + The fixture definition object. + :param request: + The fixture request object. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given fixture, only + conftest files in the fixture scope's directory and its parent directories + are consulted. + """ + + +# ------------------------------------------------------------------------- +# test session related hooks +# ------------------------------------------------------------------------- + + +def pytest_sessionstart(session: Session) -> None: + """Called after the ``Session`` object has been created and before performing collection + and entering the run test loop. + + :param session: The pytest session object. + + Use in conftest plugins + ======================= + + This hook is only called for :ref:`initial conftests `. + """ + + +def pytest_sessionfinish( + session: Session, + exitstatus: int | ExitCode, +) -> None: + """Called after whole test run finished, right before returning the exit status to the system. + + :param session: The pytest session object. + :param exitstatus: The status which pytest will return to the system. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. + """ + + +def pytest_unconfigure(config: Config) -> None: + """Called before test process is exited. + + :param config: The pytest config object. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. + """ + + +# ------------------------------------------------------------------------- +# hooks for customizing the assert methods +# ------------------------------------------------------------------------- + + +def pytest_assertrepr_compare( + config: Config, op: str, left: object, right: object +) -> list[str] | None: + """Return explanation for comparisons in failing assert expressions. + + Return None for no custom explanation, otherwise return a list + of strings. The strings will be joined by newlines but any newlines + *in* a string will be escaped. Note that all but the first line will + be indented slightly, the intention is for the first line to be a summary. + + :param config: The pytest config object. + :param op: The operator, e.g. `"=="`, `"!="`, `"not in"`. + :param left: The left operand. + :param right: The right operand. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given item, only conftest + files in the item's directory and its parent directories are consulted. + """ + + +def pytest_assertion_pass(item: Item, lineno: int, orig: str, expl: str) -> None: + """Called whenever an assertion passes. + + .. versionadded:: 5.0 + + Use this hook to do some processing after a passing assertion. + The original assertion information is available in the `orig` string + and the pytest introspected assertion information is available in the + `expl` string. + + This hook must be explicitly enabled by the ``enable_assertion_pass_hook`` + ini-file option: + + .. code-block:: ini + + [pytest] + enable_assertion_pass_hook=true + + You need to **clean the .pyc** files in your project directory and interpreter libraries + when enabling this option, as assertions will require to be re-written. + + :param item: pytest item object of current test. + :param lineno: Line number of the assert statement. + :param orig: String with the original assertion. + :param expl: String with the assert explanation. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given item, only conftest + files in the item's directory and its parent directories are consulted. + """ + + +# ------------------------------------------------------------------------- +# Hooks for influencing reporting (invoked from _pytest_terminal). +# ------------------------------------------------------------------------- + + +@hookspec( + warn_on_impl_args={ + "startdir": HOOK_LEGACY_PATH_ARG.format( + pylib_path_arg="startdir", pathlib_path_arg="start_path" + ), + }, +) +def pytest_report_header( # type:ignore[empty-body] + config: Config, start_path: Path, startdir: LEGACY_PATH +) -> str | list[str]: + """Return a string or list of strings to be displayed as header info for terminal reporting. + + :param config: The pytest config object. + :param start_path: The starting dir. + :type start_path: pathlib.Path + :param startdir: The starting dir (deprecated). + + .. note:: + + Lines returned by a plugin are displayed before those of plugins which + ran before it. + If you want to have your line(s) displayed first, use + :ref:`trylast=True `. + + .. versionchanged:: 7.0.0 + The ``start_path`` parameter was added as a :class:`pathlib.Path` + equivalent of the ``startdir`` parameter. The ``startdir`` parameter + has been deprecated. + + Use in conftest plugins + ======================= + + This hook is only called for :ref:`initial conftests `. + """ + + +@hookspec( + warn_on_impl_args={ + "startdir": HOOK_LEGACY_PATH_ARG.format( + pylib_path_arg="startdir", pathlib_path_arg="start_path" + ), + }, +) +def pytest_report_collectionfinish( # type:ignore[empty-body] + config: Config, + start_path: Path, + startdir: LEGACY_PATH, + items: Sequence[Item], +) -> str | list[str]: + """Return a string or list of strings to be displayed after collection + has finished successfully. + + These strings will be displayed after the standard "collected X items" message. + + .. versionadded:: 3.2 + + :param config: The pytest config object. + :param start_path: The starting dir. + :type start_path: pathlib.Path + :param startdir: The starting dir (deprecated). + :param items: List of pytest items that are going to be executed; this list should not be modified. + + .. note:: + + Lines returned by a plugin are displayed before those of plugins which + ran before it. + If you want to have your line(s) displayed first, use + :ref:`trylast=True `. + + .. versionchanged:: 7.0.0 + The ``start_path`` parameter was added as a :class:`pathlib.Path` + equivalent of the ``startdir`` parameter. The ``startdir`` parameter + has been deprecated. + + Use in conftest plugins + ======================= + + Any conftest plugin can implement this hook. + """ + + +@hookspec(firstresult=True) +def pytest_report_teststatus( # type:ignore[empty-body] + report: CollectReport | TestReport, config: Config +) -> TestShortLogReport | tuple[str, str, str | tuple[str, Mapping[str, bool]]]: + """Return result-category, shortletter and verbose word for status + reporting. + + The result-category is a category in which to count the result, for + example "passed", "skipped", "error" or the empty string. + + The shortletter is shown as testing progresses, for example ".", "s", + "E" or the empty string. + + The verbose word is shown as testing progresses in verbose mode, for + example "PASSED", "SKIPPED", "ERROR" or the empty string. + + pytest may style these implicitly according to the report outcome. + To provide explicit styling, return a tuple for the verbose word, + for example ``"rerun", "R", ("RERUN", {"yellow": True})``. + + :param report: The report object whose status is to be returned. + :param config: The pytest config object. + :returns: The test status. + + Stops at first non-None result, see :ref:`firstresult`. + + Use in conftest plugins + ======================= + + Any conftest plugin can implement this hook. + """ + + +def pytest_terminal_summary( + terminalreporter: TerminalReporter, + exitstatus: ExitCode, + config: Config, +) -> None: + """Add a section to terminal summary reporting. + + :param terminalreporter: The internal terminal reporter object. + :param exitstatus: The exit status that will be reported back to the OS. + :param config: The pytest config object. + + .. versionadded:: 4.2 + The ``config`` parameter. + + Use in conftest plugins + ======================= + + Any conftest plugin can implement this hook. + """ + + +@hookspec(historic=True) +def pytest_warning_recorded( + warning_message: warnings.WarningMessage, + when: Literal["config", "collect", "runtest"], + nodeid: str, + location: tuple[str, int, str] | None, +) -> None: + """Process a warning captured by the internal pytest warnings plugin. + + :param warning_message: + The captured warning. This is the same object produced by :class:`warnings.catch_warnings`, + and contains the same attributes as the parameters of :py:func:`warnings.showwarning`. + + :param when: + Indicates when the warning was captured. Possible values: + + * ``"config"``: during pytest configuration/initialization stage. + * ``"collect"``: during test collection. + * ``"runtest"``: during test execution. + + :param nodeid: + Full id of the item. Empty string for warnings that are not specific to + a particular node. + + :param location: + When available, holds information about the execution context of the captured + warning (filename, linenumber, function). ``function`` evaluates to + when the execution context is at the module level. + + .. versionadded:: 6.0 + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. If the warning is specific to a + particular node, only conftest files in parent directories of the node are + consulted. + """ + + +# ------------------------------------------------------------------------- +# Hooks for influencing skipping +# ------------------------------------------------------------------------- + + +def pytest_markeval_namespace( # type:ignore[empty-body] + config: Config, +) -> dict[str, Any]: + """Called when constructing the globals dictionary used for + evaluating string conditions in xfail/skipif markers. + + This is useful when the condition for a marker requires + objects that are expensive or impossible to obtain during + collection time, which is required by normal boolean + conditions. + + .. versionadded:: 6.2 + + :param config: The pytest config object. + :returns: A dictionary of additional globals to add. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given item, only conftest + files in parent directories of the item are consulted. + """ + + +# ------------------------------------------------------------------------- +# error handling and internal debugging hooks +# ------------------------------------------------------------------------- + + +def pytest_internalerror( + excrepr: ExceptionRepr, + excinfo: ExceptionInfo[BaseException], +) -> bool | None: + """Called for internal errors. + + Return True to suppress the fallback handling of printing an + INTERNALERROR message directly to sys.stderr. + + :param excrepr: The exception repr object. + :param excinfo: The exception info. + + Use in conftest plugins + ======================= + + Any conftest plugin can implement this hook. + """ + + +def pytest_keyboard_interrupt( + excinfo: ExceptionInfo[KeyboardInterrupt | Exit], +) -> None: + """Called for keyboard interrupt. + + :param excinfo: The exception info. + + Use in conftest plugins + ======================= + + Any conftest plugin can implement this hook. + """ + + +def pytest_exception_interact( + node: Item | Collector, + call: CallInfo[Any], + report: CollectReport | TestReport, +) -> None: + """Called when an exception was raised which can potentially be + interactively handled. + + May be called during collection (see :hook:`pytest_make_collect_report`), + in which case ``report`` is a :class:`~pytest.CollectReport`. + + May be called during runtest of an item (see :hook:`pytest_runtest_protocol`), + in which case ``report`` is a :class:`~pytest.TestReport`. + + This hook is not called if the exception that was raised is an internal + exception like ``skip.Exception``. + + :param node: + The item or collector. + :param call: + The call information. Contains the exception. + :param report: + The collection or test report. + + Use in conftest plugins + ======================= + + Any conftest file can implement this hook. For a given node, only conftest + files in parent directories of the node are consulted. + """ + + +def pytest_enter_pdb(config: Config, pdb: pdb.Pdb) -> None: + """Called upon pdb.set_trace(). + + Can be used by plugins to take special action just before the python + debugger enters interactive mode. + + :param config: The pytest config object. + :param pdb: The Pdb instance. + + Use in conftest plugins + ======================= + + Any conftest plugin can implement this hook. + """ + + +def pytest_leave_pdb(config: Config, pdb: pdb.Pdb) -> None: + """Called when leaving pdb (e.g. with continue after pdb.set_trace()). + + Can be used by plugins to take special action just after the python + debugger leaves interactive mode. + + :param config: The pytest config object. + :param pdb: The Pdb instance. + + Use in conftest plugins + ======================= + + Any conftest plugin can implement this hook. + """ diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/junitxml.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/junitxml.py new file mode 100644 index 0000000..3a2cb59 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/junitxml.py @@ -0,0 +1,697 @@ +# mypy: allow-untyped-defs +"""Report test results in JUnit-XML format, for use with Jenkins and build +integration servers. + +Based on initial code from Ross Lawley. + +Output conforms to +https://github.com/jenkinsci/xunit-plugin/blob/master/src/main/resources/org/jenkinsci/plugins/xunit/types/model/xsd/junit-10.xsd +""" + +from __future__ import annotations + +from datetime import datetime +from datetime import timezone +import functools +import os +import platform +import re +from typing import Callable +from typing import Match +import xml.etree.ElementTree as ET + +from _pytest import nodes +from _pytest import timing +from _pytest._code.code import ExceptionRepr +from _pytest._code.code import ReprFileLocation +from _pytest.config import Config +from _pytest.config import filename_arg +from _pytest.config.argparsing import Parser +from _pytest.fixtures import FixtureRequest +from _pytest.reports import TestReport +from _pytest.stash import StashKey +from _pytest.terminal import TerminalReporter +import pytest + + +xml_key = StashKey["LogXML"]() + + +def bin_xml_escape(arg: object) -> str: + r"""Visually escape invalid XML characters. + + For example, transforms + 'hello\aworld\b' + into + 'hello#x07world#x08' + Note that the #xABs are *not* XML escapes - missing the ampersand «. + The idea is to escape visually for the user rather than for XML itself. + """ + + def repl(matchobj: Match[str]) -> str: + i = ord(matchobj.group()) + if i <= 0xFF: + return f"#x{i:02X}" + else: + return f"#x{i:04X}" + + # The spec range of valid chars is: + # Char ::= #x9 | #xA | #xD | [#x20-#xD7FF] | [#xE000-#xFFFD] | [#x10000-#x10FFFF] + # For an unknown(?) reason, we disallow #x7F (DEL) as well. + illegal_xml_re = ( + "[^\u0009\u000a\u000d\u0020-\u007e\u0080-\ud7ff\ue000-\ufffd\u10000-\u10ffff]" + ) + return re.sub(illegal_xml_re, repl, str(arg)) + + +def merge_family(left, right) -> None: + result = {} + for kl, vl in left.items(): + for kr, vr in right.items(): + if not isinstance(vl, list): + raise TypeError(type(vl)) + result[kl] = vl + vr + left.update(result) + + +families = {} +families["_base"] = {"testcase": ["classname", "name"]} +families["_base_legacy"] = {"testcase": ["file", "line", "url"]} + +# xUnit 1.x inherits legacy attributes. +families["xunit1"] = families["_base"].copy() +merge_family(families["xunit1"], families["_base_legacy"]) + +# xUnit 2.x uses strict base attributes. +families["xunit2"] = families["_base"] + + +class _NodeReporter: + def __init__(self, nodeid: str | TestReport, xml: LogXML) -> None: + self.id = nodeid + self.xml = xml + self.add_stats = self.xml.add_stats + self.family = self.xml.family + self.duration = 0.0 + self.properties: list[tuple[str, str]] = [] + self.nodes: list[ET.Element] = [] + self.attrs: dict[str, str] = {} + + def append(self, node: ET.Element) -> None: + self.xml.add_stats(node.tag) + self.nodes.append(node) + + def add_property(self, name: str, value: object) -> None: + self.properties.append((str(name), bin_xml_escape(value))) + + def add_attribute(self, name: str, value: object) -> None: + self.attrs[str(name)] = bin_xml_escape(value) + + def make_properties_node(self) -> ET.Element | None: + """Return a Junit node containing custom properties, if any.""" + if self.properties: + properties = ET.Element("properties") + for name, value in self.properties: + properties.append(ET.Element("property", name=name, value=value)) + return properties + return None + + def record_testreport(self, testreport: TestReport) -> None: + names = mangle_test_address(testreport.nodeid) + existing_attrs = self.attrs + classnames = names[:-1] + if self.xml.prefix: + classnames.insert(0, self.xml.prefix) + attrs: dict[str, str] = { + "classname": ".".join(classnames), + "name": bin_xml_escape(names[-1]), + "file": testreport.location[0], + } + if testreport.location[1] is not None: + attrs["line"] = str(testreport.location[1]) + if hasattr(testreport, "url"): + attrs["url"] = testreport.url + self.attrs = attrs + self.attrs.update(existing_attrs) # Restore any user-defined attributes. + + # Preserve legacy testcase behavior. + if self.family == "xunit1": + return + + # Filter out attributes not permitted by this test family. + # Including custom attributes because they are not valid here. + temp_attrs = {} + for key in self.attrs: + if key in families[self.family]["testcase"]: + temp_attrs[key] = self.attrs[key] + self.attrs = temp_attrs + + def to_xml(self) -> ET.Element: + testcase = ET.Element("testcase", self.attrs, time=f"{self.duration:.3f}") + properties = self.make_properties_node() + if properties is not None: + testcase.append(properties) + testcase.extend(self.nodes) + return testcase + + def _add_simple(self, tag: str, message: str, data: str | None = None) -> None: + node = ET.Element(tag, message=message) + node.text = bin_xml_escape(data) + self.append(node) + + def write_captured_output(self, report: TestReport) -> None: + if not self.xml.log_passing_tests and report.passed: + return + + content_out = report.capstdout + content_log = report.caplog + content_err = report.capstderr + if self.xml.logging == "no": + return + content_all = "" + if self.xml.logging in ["log", "all"]: + content_all = self._prepare_content(content_log, " Captured Log ") + if self.xml.logging in ["system-out", "out-err", "all"]: + content_all += self._prepare_content(content_out, " Captured Out ") + self._write_content(report, content_all, "system-out") + content_all = "" + if self.xml.logging in ["system-err", "out-err", "all"]: + content_all += self._prepare_content(content_err, " Captured Err ") + self._write_content(report, content_all, "system-err") + content_all = "" + if content_all: + self._write_content(report, content_all, "system-out") + + def _prepare_content(self, content: str, header: str) -> str: + return "\n".join([header.center(80, "-"), content, ""]) + + def _write_content(self, report: TestReport, content: str, jheader: str) -> None: + tag = ET.Element(jheader) + tag.text = bin_xml_escape(content) + self.append(tag) + + def append_pass(self, report: TestReport) -> None: + self.add_stats("passed") + + def append_failure(self, report: TestReport) -> None: + # msg = str(report.longrepr.reprtraceback.extraline) + if hasattr(report, "wasxfail"): + self._add_simple("skipped", "xfail-marked test passes unexpectedly") + else: + assert report.longrepr is not None + reprcrash: ReprFileLocation | None = getattr( + report.longrepr, "reprcrash", None + ) + if reprcrash is not None: + message = reprcrash.message + else: + message = str(report.longrepr) + message = bin_xml_escape(message) + self._add_simple("failure", message, str(report.longrepr)) + + def append_collect_error(self, report: TestReport) -> None: + # msg = str(report.longrepr.reprtraceback.extraline) + assert report.longrepr is not None + self._add_simple("error", "collection failure", str(report.longrepr)) + + def append_collect_skipped(self, report: TestReport) -> None: + self._add_simple("skipped", "collection skipped", str(report.longrepr)) + + def append_error(self, report: TestReport) -> None: + assert report.longrepr is not None + reprcrash: ReprFileLocation | None = getattr(report.longrepr, "reprcrash", None) + if reprcrash is not None: + reason = reprcrash.message + else: + reason = str(report.longrepr) + + if report.when == "teardown": + msg = f'failed on teardown with "{reason}"' + else: + msg = f'failed on setup with "{reason}"' + self._add_simple("error", bin_xml_escape(msg), str(report.longrepr)) + + def append_skipped(self, report: TestReport) -> None: + if hasattr(report, "wasxfail"): + xfailreason = report.wasxfail + if xfailreason.startswith("reason: "): + xfailreason = xfailreason[8:] + xfailreason = bin_xml_escape(xfailreason) + skipped = ET.Element("skipped", type="pytest.xfail", message=xfailreason) + self.append(skipped) + else: + assert isinstance(report.longrepr, tuple) + filename, lineno, skipreason = report.longrepr + if skipreason.startswith("Skipped: "): + skipreason = skipreason[9:] + details = f"{filename}:{lineno}: {skipreason}" + + skipped = ET.Element( + "skipped", type="pytest.skip", message=bin_xml_escape(skipreason) + ) + skipped.text = bin_xml_escape(details) + self.append(skipped) + self.write_captured_output(report) + + def finalize(self) -> None: + data = self.to_xml() + self.__dict__.clear() + # Type ignored because mypy doesn't like overriding a method. + # Also the return value doesn't match... + self.to_xml = lambda: data # type: ignore[method-assign] + + +def _warn_incompatibility_with_xunit2( + request: FixtureRequest, fixture_name: str +) -> None: + """Emit a PytestWarning about the given fixture being incompatible with newer xunit revisions.""" + from _pytest.warning_types import PytestWarning + + xml = request.config.stash.get(xml_key, None) + if xml is not None and xml.family not in ("xunit1", "legacy"): + request.node.warn( + PytestWarning( + f"{fixture_name} is incompatible with junit_family '{xml.family}' (use 'legacy' or 'xunit1')" + ) + ) + + +@pytest.fixture +def record_property(request: FixtureRequest) -> Callable[[str, object], None]: + """Add extra properties to the calling test. + + User properties become part of the test report and are available to the + configured reporters, like JUnit XML. + + The fixture is callable with ``name, value``. The value is automatically + XML-encoded. + + Example:: + + def test_function(record_property): + record_property("example_key", 1) + """ + _warn_incompatibility_with_xunit2(request, "record_property") + + def append_property(name: str, value: object) -> None: + request.node.user_properties.append((name, value)) + + return append_property + + +@pytest.fixture +def record_xml_attribute(request: FixtureRequest) -> Callable[[str, object], None]: + """Add extra xml attributes to the tag for the calling test. + + The fixture is callable with ``name, value``. The value is + automatically XML-encoded. + """ + from _pytest.warning_types import PytestExperimentalApiWarning + + request.node.warn( + PytestExperimentalApiWarning("record_xml_attribute is an experimental feature") + ) + + _warn_incompatibility_with_xunit2(request, "record_xml_attribute") + + # Declare noop + def add_attr_noop(name: str, value: object) -> None: + pass + + attr_func = add_attr_noop + + xml = request.config.stash.get(xml_key, None) + if xml is not None: + node_reporter = xml.node_reporter(request.node.nodeid) + attr_func = node_reporter.add_attribute + + return attr_func + + +def _check_record_param_type(param: str, v: str) -> None: + """Used by record_testsuite_property to check that the given parameter name is of the proper + type.""" + __tracebackhide__ = True + if not isinstance(v, str): + msg = "{param} parameter needs to be a string, but {g} given" # type: ignore[unreachable] + raise TypeError(msg.format(param=param, g=type(v).__name__)) + + +@pytest.fixture(scope="session") +def record_testsuite_property(request: FixtureRequest) -> Callable[[str, object], None]: + """Record a new ```` tag as child of the root ````. + + This is suitable to writing global information regarding the entire test + suite, and is compatible with ``xunit2`` JUnit family. + + This is a ``session``-scoped fixture which is called with ``(name, value)``. Example: + + .. code-block:: python + + def test_foo(record_testsuite_property): + record_testsuite_property("ARCH", "PPC") + record_testsuite_property("STORAGE_TYPE", "CEPH") + + :param name: + The property name. + :param value: + The property value. Will be converted to a string. + + .. warning:: + + Currently this fixture **does not work** with the + `pytest-xdist `__ plugin. See + :issue:`7767` for details. + """ + __tracebackhide__ = True + + def record_func(name: str, value: object) -> None: + """No-op function in case --junit-xml was not passed in the command-line.""" + __tracebackhide__ = True + _check_record_param_type("name", name) + + xml = request.config.stash.get(xml_key, None) + if xml is not None: + record_func = xml.add_global_property + return record_func + + +def pytest_addoption(parser: Parser) -> None: + group = parser.getgroup("terminal reporting") + group.addoption( + "--junitxml", + "--junit-xml", + action="store", + dest="xmlpath", + metavar="path", + type=functools.partial(filename_arg, optname="--junitxml"), + default=None, + help="Create junit-xml style report file at given path", + ) + group.addoption( + "--junitprefix", + "--junit-prefix", + action="store", + metavar="str", + default=None, + help="Prepend prefix to classnames in junit-xml output", + ) + parser.addini( + "junit_suite_name", "Test suite name for JUnit report", default="pytest" + ) + parser.addini( + "junit_logging", + "Write captured log messages to JUnit report: " + "one of no|log|system-out|system-err|out-err|all", + default="no", + ) + parser.addini( + "junit_log_passing_tests", + "Capture log information for passing tests to JUnit report: ", + type="bool", + default=True, + ) + parser.addini( + "junit_duration_report", + "Duration time to report: one of total|call", + default="total", + ) # choices=['total', 'call']) + parser.addini( + "junit_family", + "Emit XML for schema: one of legacy|xunit1|xunit2", + default="xunit2", + ) + + +def pytest_configure(config: Config) -> None: + xmlpath = config.option.xmlpath + # Prevent opening xmllog on worker nodes (xdist). + if xmlpath and not hasattr(config, "workerinput"): + junit_family = config.getini("junit_family") + config.stash[xml_key] = LogXML( + xmlpath, + config.option.junitprefix, + config.getini("junit_suite_name"), + config.getini("junit_logging"), + config.getini("junit_duration_report"), + junit_family, + config.getini("junit_log_passing_tests"), + ) + config.pluginmanager.register(config.stash[xml_key]) + + +def pytest_unconfigure(config: Config) -> None: + xml = config.stash.get(xml_key, None) + if xml: + del config.stash[xml_key] + config.pluginmanager.unregister(xml) + + +def mangle_test_address(address: str) -> list[str]: + path, possible_open_bracket, params = address.partition("[") + names = path.split("::") + # Convert file path to dotted path. + names[0] = names[0].replace(nodes.SEP, ".") + names[0] = re.sub(r"\.py$", "", names[0]) + # Put any params back. + names[-1] += possible_open_bracket + params + return names + + +class LogXML: + def __init__( + self, + logfile, + prefix: str | None, + suite_name: str = "pytest", + logging: str = "no", + report_duration: str = "total", + family="xunit1", + log_passing_tests: bool = True, + ) -> None: + logfile = os.path.expanduser(os.path.expandvars(logfile)) + self.logfile = os.path.normpath(os.path.abspath(logfile)) + self.prefix = prefix + self.suite_name = suite_name + self.logging = logging + self.log_passing_tests = log_passing_tests + self.report_duration = report_duration + self.family = family + self.stats: dict[str, int] = dict.fromkeys( + ["error", "passed", "failure", "skipped"], 0 + ) + self.node_reporters: dict[tuple[str | TestReport, object], _NodeReporter] = {} + self.node_reporters_ordered: list[_NodeReporter] = [] + self.global_properties: list[tuple[str, str]] = [] + + # List of reports that failed on call but teardown is pending. + self.open_reports: list[TestReport] = [] + self.cnt_double_fail_tests = 0 + + # Replaces convenience family with real family. + if self.family == "legacy": + self.family = "xunit1" + + def finalize(self, report: TestReport) -> None: + nodeid = getattr(report, "nodeid", report) + # Local hack to handle xdist report order. + workernode = getattr(report, "node", None) + reporter = self.node_reporters.pop((nodeid, workernode)) + + for propname, propvalue in report.user_properties: + reporter.add_property(propname, str(propvalue)) + + if reporter is not None: + reporter.finalize() + + def node_reporter(self, report: TestReport | str) -> _NodeReporter: + nodeid: str | TestReport = getattr(report, "nodeid", report) + # Local hack to handle xdist report order. + workernode = getattr(report, "node", None) + + key = nodeid, workernode + + if key in self.node_reporters: + # TODO: breaks for --dist=each + return self.node_reporters[key] + + reporter = _NodeReporter(nodeid, self) + + self.node_reporters[key] = reporter + self.node_reporters_ordered.append(reporter) + + return reporter + + def add_stats(self, key: str) -> None: + if key in self.stats: + self.stats[key] += 1 + + def _opentestcase(self, report: TestReport) -> _NodeReporter: + reporter = self.node_reporter(report) + reporter.record_testreport(report) + return reporter + + def pytest_runtest_logreport(self, report: TestReport) -> None: + """Handle a setup/call/teardown report, generating the appropriate + XML tags as necessary. + + Note: due to plugins like xdist, this hook may be called in interlaced + order with reports from other nodes. For example: + + Usual call order: + -> setup node1 + -> call node1 + -> teardown node1 + -> setup node2 + -> call node2 + -> teardown node2 + + Possible call order in xdist: + -> setup node1 + -> call node1 + -> setup node2 + -> call node2 + -> teardown node2 + -> teardown node1 + """ + close_report = None + if report.passed: + if report.when == "call": # ignore setup/teardown + reporter = self._opentestcase(report) + reporter.append_pass(report) + elif report.failed: + if report.when == "teardown": + # The following vars are needed when xdist plugin is used. + report_wid = getattr(report, "worker_id", None) + report_ii = getattr(report, "item_index", None) + close_report = next( + ( + rep + for rep in self.open_reports + if ( + rep.nodeid == report.nodeid + and getattr(rep, "item_index", None) == report_ii + and getattr(rep, "worker_id", None) == report_wid + ) + ), + None, + ) + if close_report: + # We need to open new testcase in case we have failure in + # call and error in teardown in order to follow junit + # schema. + self.finalize(close_report) + self.cnt_double_fail_tests += 1 + reporter = self._opentestcase(report) + if report.when == "call": + reporter.append_failure(report) + self.open_reports.append(report) + if not self.log_passing_tests: + reporter.write_captured_output(report) + else: + reporter.append_error(report) + elif report.skipped: + reporter = self._opentestcase(report) + reporter.append_skipped(report) + self.update_testcase_duration(report) + if report.when == "teardown": + reporter = self._opentestcase(report) + reporter.write_captured_output(report) + + self.finalize(report) + report_wid = getattr(report, "worker_id", None) + report_ii = getattr(report, "item_index", None) + close_report = next( + ( + rep + for rep in self.open_reports + if ( + rep.nodeid == report.nodeid + and getattr(rep, "item_index", None) == report_ii + and getattr(rep, "worker_id", None) == report_wid + ) + ), + None, + ) + if close_report: + self.open_reports.remove(close_report) + + def update_testcase_duration(self, report: TestReport) -> None: + """Accumulate total duration for nodeid from given report and update + the Junit.testcase with the new total if already created.""" + if self.report_duration in {"total", report.when}: + reporter = self.node_reporter(report) + reporter.duration += getattr(report, "duration", 0.0) + + def pytest_collectreport(self, report: TestReport) -> None: + if not report.passed: + reporter = self._opentestcase(report) + if report.failed: + reporter.append_collect_error(report) + else: + reporter.append_collect_skipped(report) + + def pytest_internalerror(self, excrepr: ExceptionRepr) -> None: + reporter = self.node_reporter("internal") + reporter.attrs.update(classname="pytest", name="internal") + reporter._add_simple("error", "internal error", str(excrepr)) + + def pytest_sessionstart(self) -> None: + self.suite_start_time = timing.time() + + def pytest_sessionfinish(self) -> None: + dirname = os.path.dirname(os.path.abspath(self.logfile)) + # exist_ok avoids filesystem race conditions between checking path existence and requesting creation + os.makedirs(dirname, exist_ok=True) + + with open(self.logfile, "w", encoding="utf-8") as logfile: + suite_stop_time = timing.time() + suite_time_delta = suite_stop_time - self.suite_start_time + + numtests = ( + self.stats["passed"] + + self.stats["failure"] + + self.stats["skipped"] + + self.stats["error"] + - self.cnt_double_fail_tests + ) + logfile.write('') + + suite_node = ET.Element( + "testsuite", + name=self.suite_name, + errors=str(self.stats["error"]), + failures=str(self.stats["failure"]), + skipped=str(self.stats["skipped"]), + tests=str(numtests), + time=f"{suite_time_delta:.3f}", + timestamp=datetime.fromtimestamp(self.suite_start_time, timezone.utc) + .astimezone() + .isoformat(), + hostname=platform.node(), + ) + global_properties = self._get_global_properties_node() + if global_properties is not None: + suite_node.append(global_properties) + for node_reporter in self.node_reporters_ordered: + suite_node.append(node_reporter.to_xml()) + testsuites = ET.Element("testsuites") + testsuites.append(suite_node) + logfile.write(ET.tostring(testsuites, encoding="unicode")) + + def pytest_terminal_summary(self, terminalreporter: TerminalReporter) -> None: + terminalreporter.write_sep("-", f"generated xml file: {self.logfile}") + + def add_global_property(self, name: str, value: object) -> None: + __tracebackhide__ = True + _check_record_param_type("name", name) + self.global_properties.append((name, bin_xml_escape(value))) + + def _get_global_properties_node(self) -> ET.Element | None: + """Return a Junit node containing custom properties, if any.""" + if self.global_properties: + properties = ET.Element("properties") + for name, value in self.global_properties: + properties.append(ET.Element("property", name=name, value=value)) + return properties + return None diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/legacypath.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/legacypath.py new file mode 100644 index 0000000..61476d6 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/legacypath.py @@ -0,0 +1,473 @@ +# mypy: allow-untyped-defs +"""Add backward compatibility support for the legacy py path type.""" + +from __future__ import annotations + +import dataclasses +from pathlib import Path +import shlex +import subprocess +from typing import Final +from typing import final +from typing import TYPE_CHECKING + +from iniconfig import SectionWrapper + +from _pytest.cacheprovider import Cache +from _pytest.compat import LEGACY_PATH +from _pytest.compat import legacy_path +from _pytest.config import Config +from _pytest.config import hookimpl +from _pytest.config import PytestPluginManager +from _pytest.deprecated import check_ispytest +from _pytest.fixtures import fixture +from _pytest.fixtures import FixtureRequest +from _pytest.main import Session +from _pytest.monkeypatch import MonkeyPatch +from _pytest.nodes import Collector +from _pytest.nodes import Item +from _pytest.nodes import Node +from _pytest.pytester import HookRecorder +from _pytest.pytester import Pytester +from _pytest.pytester import RunResult +from _pytest.terminal import TerminalReporter +from _pytest.tmpdir import TempPathFactory + + +if TYPE_CHECKING: + import pexpect + + +@final +class Testdir: + """ + Similar to :class:`Pytester`, but this class works with legacy legacy_path objects instead. + + All methods just forward to an internal :class:`Pytester` instance, converting results + to `legacy_path` objects as necessary. + """ + + __test__ = False + + CLOSE_STDIN: Final = Pytester.CLOSE_STDIN + TimeoutExpired: Final = Pytester.TimeoutExpired + + def __init__(self, pytester: Pytester, *, _ispytest: bool = False) -> None: + check_ispytest(_ispytest) + self._pytester = pytester + + @property + def tmpdir(self) -> LEGACY_PATH: + """Temporary directory where tests are executed.""" + return legacy_path(self._pytester.path) + + @property + def test_tmproot(self) -> LEGACY_PATH: + return legacy_path(self._pytester._test_tmproot) + + @property + def request(self): + return self._pytester._request + + @property + def plugins(self): + return self._pytester.plugins + + @plugins.setter + def plugins(self, plugins): + self._pytester.plugins = plugins + + @property + def monkeypatch(self) -> MonkeyPatch: + return self._pytester._monkeypatch + + def make_hook_recorder(self, pluginmanager) -> HookRecorder: + """See :meth:`Pytester.make_hook_recorder`.""" + return self._pytester.make_hook_recorder(pluginmanager) + + def chdir(self) -> None: + """See :meth:`Pytester.chdir`.""" + return self._pytester.chdir() + + def finalize(self) -> None: + return self._pytester._finalize() + + def makefile(self, ext, *args, **kwargs) -> LEGACY_PATH: + """See :meth:`Pytester.makefile`.""" + if ext and not ext.startswith("."): + # pytester.makefile is going to throw a ValueError in a way that + # testdir.makefile did not, because + # pathlib.Path is stricter suffixes than py.path + # This ext arguments is likely user error, but since testdir has + # allowed this, we will prepend "." as a workaround to avoid breaking + # testdir usage that worked before + ext = "." + ext + return legacy_path(self._pytester.makefile(ext, *args, **kwargs)) + + def makeconftest(self, source) -> LEGACY_PATH: + """See :meth:`Pytester.makeconftest`.""" + return legacy_path(self._pytester.makeconftest(source)) + + def makeini(self, source) -> LEGACY_PATH: + """See :meth:`Pytester.makeini`.""" + return legacy_path(self._pytester.makeini(source)) + + def getinicfg(self, source: str) -> SectionWrapper: + """See :meth:`Pytester.getinicfg`.""" + return self._pytester.getinicfg(source) + + def makepyprojecttoml(self, source) -> LEGACY_PATH: + """See :meth:`Pytester.makepyprojecttoml`.""" + return legacy_path(self._pytester.makepyprojecttoml(source)) + + def makepyfile(self, *args, **kwargs) -> LEGACY_PATH: + """See :meth:`Pytester.makepyfile`.""" + return legacy_path(self._pytester.makepyfile(*args, **kwargs)) + + def maketxtfile(self, *args, **kwargs) -> LEGACY_PATH: + """See :meth:`Pytester.maketxtfile`.""" + return legacy_path(self._pytester.maketxtfile(*args, **kwargs)) + + def syspathinsert(self, path=None) -> None: + """See :meth:`Pytester.syspathinsert`.""" + return self._pytester.syspathinsert(path) + + def mkdir(self, name) -> LEGACY_PATH: + """See :meth:`Pytester.mkdir`.""" + return legacy_path(self._pytester.mkdir(name)) + + def mkpydir(self, name) -> LEGACY_PATH: + """See :meth:`Pytester.mkpydir`.""" + return legacy_path(self._pytester.mkpydir(name)) + + def copy_example(self, name=None) -> LEGACY_PATH: + """See :meth:`Pytester.copy_example`.""" + return legacy_path(self._pytester.copy_example(name)) + + def getnode(self, config: Config, arg) -> Item | Collector | None: + """See :meth:`Pytester.getnode`.""" + return self._pytester.getnode(config, arg) + + def getpathnode(self, path): + """See :meth:`Pytester.getpathnode`.""" + return self._pytester.getpathnode(path) + + def genitems(self, colitems: list[Item | Collector]) -> list[Item]: + """See :meth:`Pytester.genitems`.""" + return self._pytester.genitems(colitems) + + def runitem(self, source): + """See :meth:`Pytester.runitem`.""" + return self._pytester.runitem(source) + + def inline_runsource(self, source, *cmdlineargs): + """See :meth:`Pytester.inline_runsource`.""" + return self._pytester.inline_runsource(source, *cmdlineargs) + + def inline_genitems(self, *args): + """See :meth:`Pytester.inline_genitems`.""" + return self._pytester.inline_genitems(*args) + + def inline_run(self, *args, plugins=(), no_reraise_ctrlc: bool = False): + """See :meth:`Pytester.inline_run`.""" + return self._pytester.inline_run( + *args, plugins=plugins, no_reraise_ctrlc=no_reraise_ctrlc + ) + + def runpytest_inprocess(self, *args, **kwargs) -> RunResult: + """See :meth:`Pytester.runpytest_inprocess`.""" + return self._pytester.runpytest_inprocess(*args, **kwargs) + + def runpytest(self, *args, **kwargs) -> RunResult: + """See :meth:`Pytester.runpytest`.""" + return self._pytester.runpytest(*args, **kwargs) + + def parseconfig(self, *args) -> Config: + """See :meth:`Pytester.parseconfig`.""" + return self._pytester.parseconfig(*args) + + def parseconfigure(self, *args) -> Config: + """See :meth:`Pytester.parseconfigure`.""" + return self._pytester.parseconfigure(*args) + + def getitem(self, source, funcname="test_func"): + """See :meth:`Pytester.getitem`.""" + return self._pytester.getitem(source, funcname) + + def getitems(self, source): + """See :meth:`Pytester.getitems`.""" + return self._pytester.getitems(source) + + def getmodulecol(self, source, configargs=(), withinit=False): + """See :meth:`Pytester.getmodulecol`.""" + return self._pytester.getmodulecol( + source, configargs=configargs, withinit=withinit + ) + + def collect_by_name(self, modcol: Collector, name: str) -> Item | Collector | None: + """See :meth:`Pytester.collect_by_name`.""" + return self._pytester.collect_by_name(modcol, name) + + def popen( + self, + cmdargs, + stdout=subprocess.PIPE, + stderr=subprocess.PIPE, + stdin=CLOSE_STDIN, + **kw, + ): + """See :meth:`Pytester.popen`.""" + return self._pytester.popen(cmdargs, stdout, stderr, stdin, **kw) + + def run(self, *cmdargs, timeout=None, stdin=CLOSE_STDIN) -> RunResult: + """See :meth:`Pytester.run`.""" + return self._pytester.run(*cmdargs, timeout=timeout, stdin=stdin) + + def runpython(self, script) -> RunResult: + """See :meth:`Pytester.runpython`.""" + return self._pytester.runpython(script) + + def runpython_c(self, command): + """See :meth:`Pytester.runpython_c`.""" + return self._pytester.runpython_c(command) + + def runpytest_subprocess(self, *args, timeout=None) -> RunResult: + """See :meth:`Pytester.runpytest_subprocess`.""" + return self._pytester.runpytest_subprocess(*args, timeout=timeout) + + def spawn_pytest(self, string: str, expect_timeout: float = 10.0) -> pexpect.spawn: + """See :meth:`Pytester.spawn_pytest`.""" + return self._pytester.spawn_pytest(string, expect_timeout=expect_timeout) + + def spawn(self, cmd: str, expect_timeout: float = 10.0) -> pexpect.spawn: + """See :meth:`Pytester.spawn`.""" + return self._pytester.spawn(cmd, expect_timeout=expect_timeout) + + def __repr__(self) -> str: + return f"" + + def __str__(self) -> str: + return str(self.tmpdir) + + +class LegacyTestdirPlugin: + @staticmethod + @fixture + def testdir(pytester: Pytester) -> Testdir: + """ + Identical to :fixture:`pytester`, and provides an instance whose methods return + legacy ``LEGACY_PATH`` objects instead when applicable. + + New code should avoid using :fixture:`testdir` in favor of :fixture:`pytester`. + """ + return Testdir(pytester, _ispytest=True) + + +@final +@dataclasses.dataclass +class TempdirFactory: + """Backward compatibility wrapper that implements ``py.path.local`` + for :class:`TempPathFactory`. + + .. note:: + These days, it is preferred to use ``tmp_path_factory``. + + :ref:`About the tmpdir and tmpdir_factory fixtures`. + + """ + + _tmppath_factory: TempPathFactory + + def __init__( + self, tmppath_factory: TempPathFactory, *, _ispytest: bool = False + ) -> None: + check_ispytest(_ispytest) + self._tmppath_factory = tmppath_factory + + def mktemp(self, basename: str, numbered: bool = True) -> LEGACY_PATH: + """Same as :meth:`TempPathFactory.mktemp`, but returns a ``py.path.local`` object.""" + return legacy_path(self._tmppath_factory.mktemp(basename, numbered).resolve()) + + def getbasetemp(self) -> LEGACY_PATH: + """Same as :meth:`TempPathFactory.getbasetemp`, but returns a ``py.path.local`` object.""" + return legacy_path(self._tmppath_factory.getbasetemp().resolve()) + + +class LegacyTmpdirPlugin: + @staticmethod + @fixture(scope="session") + def tmpdir_factory(request: FixtureRequest) -> TempdirFactory: + """Return a :class:`pytest.TempdirFactory` instance for the test session.""" + # Set dynamically by pytest_configure(). + return request.config._tmpdirhandler # type: ignore + + @staticmethod + @fixture + def tmpdir(tmp_path: Path) -> LEGACY_PATH: + """Return a temporary directory path object which is unique to each test + function invocation, created as a sub directory of the base temporary + directory. + + By default, a new base temporary directory is created each test session, + and old bases are removed after 3 sessions, to aid in debugging. If + ``--basetemp`` is used then it is cleared each session. See + :ref:`temporary directory location and retention`. + + The returned object is a `legacy_path`_ object. + + .. note:: + These days, it is preferred to use ``tmp_path``. + + :ref:`About the tmpdir and tmpdir_factory fixtures`. + + .. _legacy_path: https://py.readthedocs.io/en/latest/path.html + """ + return legacy_path(tmp_path) + + +def Cache_makedir(self: Cache, name: str) -> LEGACY_PATH: + """Return a directory path object with the given name. + + Same as :func:`mkdir`, but returns a legacy py path instance. + """ + return legacy_path(self.mkdir(name)) + + +def FixtureRequest_fspath(self: FixtureRequest) -> LEGACY_PATH: + """(deprecated) The file system path of the test module which collected this test.""" + return legacy_path(self.path) + + +def TerminalReporter_startdir(self: TerminalReporter) -> LEGACY_PATH: + """The directory from which pytest was invoked. + + Prefer to use ``startpath`` which is a :class:`pathlib.Path`. + + :type: LEGACY_PATH + """ + return legacy_path(self.startpath) + + +def Config_invocation_dir(self: Config) -> LEGACY_PATH: + """The directory from which pytest was invoked. + + Prefer to use :attr:`invocation_params.dir `, + which is a :class:`pathlib.Path`. + + :type: LEGACY_PATH + """ + return legacy_path(str(self.invocation_params.dir)) + + +def Config_rootdir(self: Config) -> LEGACY_PATH: + """The path to the :ref:`rootdir `. + + Prefer to use :attr:`rootpath`, which is a :class:`pathlib.Path`. + + :type: LEGACY_PATH + """ + return legacy_path(str(self.rootpath)) + + +def Config_inifile(self: Config) -> LEGACY_PATH | None: + """The path to the :ref:`configfile `. + + Prefer to use :attr:`inipath`, which is a :class:`pathlib.Path`. + + :type: Optional[LEGACY_PATH] + """ + return legacy_path(str(self.inipath)) if self.inipath else None + + +def Session_startdir(self: Session) -> LEGACY_PATH: + """The path from which pytest was invoked. + + Prefer to use ``startpath`` which is a :class:`pathlib.Path`. + + :type: LEGACY_PATH + """ + return legacy_path(self.startpath) + + +def Config__getini_unknown_type(self, name: str, type: str, value: str | list[str]): + if type == "pathlist": + # TODO: This assert is probably not valid in all cases. + assert self.inipath is not None + dp = self.inipath.parent + input_values = shlex.split(value) if isinstance(value, str) else value + return [legacy_path(str(dp / x)) for x in input_values] + else: + raise ValueError(f"unknown configuration type: {type}", value) + + +def Node_fspath(self: Node) -> LEGACY_PATH: + """(deprecated) returns a legacy_path copy of self.path""" + return legacy_path(self.path) + + +def Node_fspath_set(self: Node, value: LEGACY_PATH) -> None: + self.path = Path(value) + + +@hookimpl(tryfirst=True) +def pytest_load_initial_conftests(early_config: Config) -> None: + """Monkeypatch legacy path attributes in several classes, as early as possible.""" + mp = MonkeyPatch() + early_config.add_cleanup(mp.undo) + + # Add Cache.makedir(). + mp.setattr(Cache, "makedir", Cache_makedir, raising=False) + + # Add FixtureRequest.fspath property. + mp.setattr(FixtureRequest, "fspath", property(FixtureRequest_fspath), raising=False) + + # Add TerminalReporter.startdir property. + mp.setattr( + TerminalReporter, "startdir", property(TerminalReporter_startdir), raising=False + ) + + # Add Config.{invocation_dir,rootdir,inifile} properties. + mp.setattr(Config, "invocation_dir", property(Config_invocation_dir), raising=False) + mp.setattr(Config, "rootdir", property(Config_rootdir), raising=False) + mp.setattr(Config, "inifile", property(Config_inifile), raising=False) + + # Add Session.startdir property. + mp.setattr(Session, "startdir", property(Session_startdir), raising=False) + + # Add pathlist configuration type. + mp.setattr(Config, "_getini_unknown_type", Config__getini_unknown_type) + + # Add Node.fspath property. + mp.setattr(Node, "fspath", property(Node_fspath, Node_fspath_set), raising=False) + + +@hookimpl +def pytest_configure(config: Config) -> None: + """Installs the LegacyTmpdirPlugin if the ``tmpdir`` plugin is also installed.""" + if config.pluginmanager.has_plugin("tmpdir"): + mp = MonkeyPatch() + config.add_cleanup(mp.undo) + # Create TmpdirFactory and attach it to the config object. + # + # This is to comply with existing plugins which expect the handler to be + # available at pytest_configure time, but ideally should be moved entirely + # to the tmpdir_factory session fixture. + try: + tmp_path_factory = config._tmp_path_factory # type: ignore[attr-defined] + except AttributeError: + # tmpdir plugin is blocked. + pass + else: + _tmpdirhandler = TempdirFactory(tmp_path_factory, _ispytest=True) + mp.setattr(config, "_tmpdirhandler", _tmpdirhandler, raising=False) + + config.pluginmanager.register(LegacyTmpdirPlugin, "legacypath-tmpdir") + + +@hookimpl +def pytest_plugin_registered(plugin: object, manager: PytestPluginManager) -> None: + # pytester is not loaded by default and is commonly loaded from a conftest, + # so checking for it in `pytest_configure` is not enough. + is_pytester = plugin is manager.get_plugin("pytester") + if is_pytester and not manager.is_registered(LegacyTestdirPlugin): + manager.register(LegacyTestdirPlugin, "legacypath-pytester") diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/logging.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/logging.py new file mode 100644 index 0000000..08c826f --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/logging.py @@ -0,0 +1,955 @@ +# mypy: allow-untyped-defs +"""Access and control log capturing.""" + +from __future__ import annotations + +from contextlib import contextmanager +from contextlib import nullcontext +from datetime import datetime +from datetime import timedelta +from datetime import timezone +import io +from io import StringIO +import logging +from logging import LogRecord +import os +from pathlib import Path +import re +from types import TracebackType +from typing import AbstractSet +from typing import Dict +from typing import final +from typing import Generator +from typing import Generic +from typing import List +from typing import Literal +from typing import Mapping +from typing import TYPE_CHECKING +from typing import TypeVar + +from _pytest import nodes +from _pytest._io import TerminalWriter +from _pytest.capture import CaptureManager +from _pytest.config import _strtobool +from _pytest.config import Config +from _pytest.config import create_terminal_writer +from _pytest.config import hookimpl +from _pytest.config import UsageError +from _pytest.config.argparsing import Parser +from _pytest.deprecated import check_ispytest +from _pytest.fixtures import fixture +from _pytest.fixtures import FixtureRequest +from _pytest.main import Session +from _pytest.stash import StashKey +from _pytest.terminal import TerminalReporter + + +if TYPE_CHECKING: + logging_StreamHandler = logging.StreamHandler[StringIO] +else: + logging_StreamHandler = logging.StreamHandler + +DEFAULT_LOG_FORMAT = "%(levelname)-8s %(name)s:%(filename)s:%(lineno)d %(message)s" +DEFAULT_LOG_DATE_FORMAT = "%H:%M:%S" +_ANSI_ESCAPE_SEQ = re.compile(r"\x1b\[[\d;]+m") +caplog_handler_key = StashKey["LogCaptureHandler"]() +caplog_records_key = StashKey[Dict[str, List[logging.LogRecord]]]() + + +def _remove_ansi_escape_sequences(text: str) -> str: + return _ANSI_ESCAPE_SEQ.sub("", text) + + +class DatetimeFormatter(logging.Formatter): + """A logging formatter which formats record with + :func:`datetime.datetime.strftime` formatter instead of + :func:`time.strftime` in case of microseconds in format string. + """ + + def formatTime(self, record: LogRecord, datefmt: str | None = None) -> str: + if datefmt and "%f" in datefmt: + ct = self.converter(record.created) + tz = timezone(timedelta(seconds=ct.tm_gmtoff), ct.tm_zone) + # Construct `datetime.datetime` object from `struct_time` + # and msecs information from `record` + # Using int() instead of round() to avoid it exceeding 1_000_000 and causing a ValueError (#11861). + dt = datetime(*ct[0:6], microsecond=int(record.msecs * 1000), tzinfo=tz) + return dt.strftime(datefmt) + # Use `logging.Formatter` for non-microsecond formats + return super().formatTime(record, datefmt) + + +class ColoredLevelFormatter(DatetimeFormatter): + """A logging formatter which colorizes the %(levelname)..s part of the + log format passed to __init__.""" + + LOGLEVEL_COLOROPTS: Mapping[int, AbstractSet[str]] = { + logging.CRITICAL: {"red"}, + logging.ERROR: {"red", "bold"}, + logging.WARNING: {"yellow"}, + logging.WARN: {"yellow"}, + logging.INFO: {"green"}, + logging.DEBUG: {"purple"}, + logging.NOTSET: set(), + } + LEVELNAME_FMT_REGEX = re.compile(r"%\(levelname\)([+-.]?\d*(?:\.\d+)?s)") + + def __init__(self, terminalwriter: TerminalWriter, *args, **kwargs) -> None: + super().__init__(*args, **kwargs) + self._terminalwriter = terminalwriter + self._original_fmt = self._style._fmt + self._level_to_fmt_mapping: dict[int, str] = {} + + for level, color_opts in self.LOGLEVEL_COLOROPTS.items(): + self.add_color_level(level, *color_opts) + + def add_color_level(self, level: int, *color_opts: str) -> None: + """Add or update color opts for a log level. + + :param level: + Log level to apply a style to, e.g. ``logging.INFO``. + :param color_opts: + ANSI escape sequence color options. Capitalized colors indicates + background color, i.e. ``'green', 'Yellow', 'bold'`` will give bold + green text on yellow background. + + .. warning:: + This is an experimental API. + """ + assert self._fmt is not None + levelname_fmt_match = self.LEVELNAME_FMT_REGEX.search(self._fmt) + if not levelname_fmt_match: + return + levelname_fmt = levelname_fmt_match.group() + + formatted_levelname = levelname_fmt % {"levelname": logging.getLevelName(level)} + + # add ANSI escape sequences around the formatted levelname + color_kwargs = {name: True for name in color_opts} + colorized_formatted_levelname = self._terminalwriter.markup( + formatted_levelname, **color_kwargs + ) + self._level_to_fmt_mapping[level] = self.LEVELNAME_FMT_REGEX.sub( + colorized_formatted_levelname, self._fmt + ) + + def format(self, record: logging.LogRecord) -> str: + fmt = self._level_to_fmt_mapping.get(record.levelno, self._original_fmt) + self._style._fmt = fmt + return super().format(record) + + +class PercentStyleMultiline(logging.PercentStyle): + """A logging style with special support for multiline messages. + + If the message of a record consists of multiple lines, this style + formats the message as if each line were logged separately. + """ + + def __init__(self, fmt: str, auto_indent: int | str | bool | None) -> None: + super().__init__(fmt) + self._auto_indent = self._get_auto_indent(auto_indent) + + @staticmethod + def _get_auto_indent(auto_indent_option: int | str | bool | None) -> int: + """Determine the current auto indentation setting. + + Specify auto indent behavior (on/off/fixed) by passing in + extra={"auto_indent": [value]} to the call to logging.log() or + using a --log-auto-indent [value] command line or the + log_auto_indent [value] config option. + + Default behavior is auto-indent off. + + Using the string "True" or "on" or the boolean True as the value + turns auto indent on, using the string "False" or "off" or the + boolean False or the int 0 turns it off, and specifying a + positive integer fixes the indentation position to the value + specified. + + Any other values for the option are invalid, and will silently be + converted to the default. + + :param None|bool|int|str auto_indent_option: + User specified option for indentation from command line, config + or extra kwarg. Accepts int, bool or str. str option accepts the + same range of values as boolean config options, as well as + positive integers represented in str form. + + :returns: + Indentation value, which can be + -1 (automatically determine indentation) or + 0 (auto-indent turned off) or + >0 (explicitly set indentation position). + """ + if auto_indent_option is None: + return 0 + elif isinstance(auto_indent_option, bool): + if auto_indent_option: + return -1 + else: + return 0 + elif isinstance(auto_indent_option, int): + return int(auto_indent_option) + elif isinstance(auto_indent_option, str): + try: + return int(auto_indent_option) + except ValueError: + pass + try: + if _strtobool(auto_indent_option): + return -1 + except ValueError: + return 0 + + return 0 + + def format(self, record: logging.LogRecord) -> str: + if "\n" in record.message: + if hasattr(record, "auto_indent"): + # Passed in from the "extra={}" kwarg on the call to logging.log(). + auto_indent = self._get_auto_indent(record.auto_indent) + else: + auto_indent = self._auto_indent + + if auto_indent: + lines = record.message.splitlines() + formatted = self._fmt % {**record.__dict__, "message": lines[0]} + + if auto_indent < 0: + indentation = _remove_ansi_escape_sequences(formatted).find( + lines[0] + ) + else: + # Optimizes logging by allowing a fixed indentation. + indentation = auto_indent + lines[0] = formatted + return ("\n" + " " * indentation).join(lines) + return self._fmt % record.__dict__ + + +def get_option_ini(config: Config, *names: str): + for name in names: + ret = config.getoption(name) # 'default' arg won't work as expected + if ret is None: + ret = config.getini(name) + if ret: + return ret + + +def pytest_addoption(parser: Parser) -> None: + """Add options to control log capturing.""" + group = parser.getgroup("logging") + + def add_option_ini(option, dest, default=None, type=None, **kwargs): + parser.addini( + dest, default=default, type=type, help="Default value for " + option + ) + group.addoption(option, dest=dest, **kwargs) + + add_option_ini( + "--log-level", + dest="log_level", + default=None, + metavar="LEVEL", + help=( + "Level of messages to catch/display." + " Not set by default, so it depends on the root/parent log handler's" + ' effective level, where it is "WARNING" by default.' + ), + ) + add_option_ini( + "--log-format", + dest="log_format", + default=DEFAULT_LOG_FORMAT, + help="Log format used by the logging module", + ) + add_option_ini( + "--log-date-format", + dest="log_date_format", + default=DEFAULT_LOG_DATE_FORMAT, + help="Log date format used by the logging module", + ) + parser.addini( + "log_cli", + default=False, + type="bool", + help='Enable log display during test run (also known as "live logging")', + ) + add_option_ini( + "--log-cli-level", dest="log_cli_level", default=None, help="CLI logging level" + ) + add_option_ini( + "--log-cli-format", + dest="log_cli_format", + default=None, + help="Log format used by the logging module", + ) + add_option_ini( + "--log-cli-date-format", + dest="log_cli_date_format", + default=None, + help="Log date format used by the logging module", + ) + add_option_ini( + "--log-file", + dest="log_file", + default=None, + help="Path to a file when logging will be written to", + ) + add_option_ini( + "--log-file-mode", + dest="log_file_mode", + default="w", + choices=["w", "a"], + help="Log file open mode", + ) + add_option_ini( + "--log-file-level", + dest="log_file_level", + default=None, + help="Log file logging level", + ) + add_option_ini( + "--log-file-format", + dest="log_file_format", + default=None, + help="Log format used by the logging module", + ) + add_option_ini( + "--log-file-date-format", + dest="log_file_date_format", + default=None, + help="Log date format used by the logging module", + ) + add_option_ini( + "--log-auto-indent", + dest="log_auto_indent", + default=None, + help="Auto-indent multiline messages passed to the logging module. Accepts true|on, false|off or an integer.", + ) + group.addoption( + "--log-disable", + action="append", + default=[], + dest="logger_disable", + help="Disable a logger by name. Can be passed multiple times.", + ) + + +_HandlerType = TypeVar("_HandlerType", bound=logging.Handler) + + +# Not using @contextmanager for performance reasons. +class catching_logs(Generic[_HandlerType]): + """Context manager that prepares the whole logging machinery properly.""" + + __slots__ = ("handler", "level", "orig_level") + + def __init__(self, handler: _HandlerType, level: int | None = None) -> None: + self.handler = handler + self.level = level + + def __enter__(self) -> _HandlerType: + root_logger = logging.getLogger() + if self.level is not None: + self.handler.setLevel(self.level) + root_logger.addHandler(self.handler) + if self.level is not None: + self.orig_level = root_logger.level + root_logger.setLevel(min(self.orig_level, self.level)) + return self.handler + + def __exit__( + self, + exc_type: type[BaseException] | None, + exc_val: BaseException | None, + exc_tb: TracebackType | None, + ) -> None: + root_logger = logging.getLogger() + if self.level is not None: + root_logger.setLevel(self.orig_level) + root_logger.removeHandler(self.handler) + + +class LogCaptureHandler(logging_StreamHandler): + """A logging handler that stores log records and the log text.""" + + def __init__(self) -> None: + """Create a new log handler.""" + super().__init__(StringIO()) + self.records: list[logging.LogRecord] = [] + + def emit(self, record: logging.LogRecord) -> None: + """Keep the log records in a list in addition to the log text.""" + self.records.append(record) + super().emit(record) + + def reset(self) -> None: + self.records = [] + self.stream = StringIO() + + def clear(self) -> None: + self.records.clear() + self.stream = StringIO() + + def handleError(self, record: logging.LogRecord) -> None: + if logging.raiseExceptions: + # Fail the test if the log message is bad (emit failed). + # The default behavior of logging is to print "Logging error" + # to stderr with the call stack and some extra details. + # pytest wants to make such mistakes visible during testing. + raise # noqa: PLE0704 + + +@final +class LogCaptureFixture: + """Provides access and control of log capturing.""" + + def __init__(self, item: nodes.Node, *, _ispytest: bool = False) -> None: + check_ispytest(_ispytest) + self._item = item + self._initial_handler_level: int | None = None + # Dict of log name -> log level. + self._initial_logger_levels: dict[str | None, int] = {} + self._initial_disabled_logging_level: int | None = None + + def _finalize(self) -> None: + """Finalize the fixture. + + This restores the log levels and the disabled logging levels changed by :meth:`set_level`. + """ + # Restore log levels. + if self._initial_handler_level is not None: + self.handler.setLevel(self._initial_handler_level) + for logger_name, level in self._initial_logger_levels.items(): + logger = logging.getLogger(logger_name) + logger.setLevel(level) + # Disable logging at the original disabled logging level. + if self._initial_disabled_logging_level is not None: + logging.disable(self._initial_disabled_logging_level) + self._initial_disabled_logging_level = None + + @property + def handler(self) -> LogCaptureHandler: + """Get the logging handler used by the fixture.""" + return self._item.stash[caplog_handler_key] + + def get_records( + self, when: Literal["setup", "call", "teardown"] + ) -> list[logging.LogRecord]: + """Get the logging records for one of the possible test phases. + + :param when: + Which test phase to obtain the records from. + Valid values are: "setup", "call" and "teardown". + + :returns: The list of captured records at the given stage. + + .. versionadded:: 3.4 + """ + return self._item.stash[caplog_records_key].get(when, []) + + @property + def text(self) -> str: + """The formatted log text.""" + return _remove_ansi_escape_sequences(self.handler.stream.getvalue()) + + @property + def records(self) -> list[logging.LogRecord]: + """The list of log records.""" + return self.handler.records + + @property + def record_tuples(self) -> list[tuple[str, int, str]]: + """A list of a stripped down version of log records intended + for use in assertion comparison. + + The format of the tuple is: + + (logger_name, log_level, message) + """ + return [(r.name, r.levelno, r.getMessage()) for r in self.records] + + @property + def messages(self) -> list[str]: + """A list of format-interpolated log messages. + + Unlike 'records', which contains the format string and parameters for + interpolation, log messages in this list are all interpolated. + + Unlike 'text', which contains the output from the handler, log + messages in this list are unadorned with levels, timestamps, etc, + making exact comparisons more reliable. + + Note that traceback or stack info (from :func:`logging.exception` or + the `exc_info` or `stack_info` arguments to the logging functions) is + not included, as this is added by the formatter in the handler. + + .. versionadded:: 3.7 + """ + return [r.getMessage() for r in self.records] + + def clear(self) -> None: + """Reset the list of log records and the captured log text.""" + self.handler.clear() + + def _force_enable_logging( + self, level: int | str, logger_obj: logging.Logger + ) -> int: + """Enable the desired logging level if the global level was disabled via ``logging.disabled``. + + Only enables logging levels greater than or equal to the requested ``level``. + + Does nothing if the desired ``level`` wasn't disabled. + + :param level: + The logger level caplog should capture. + All logging is enabled if a non-standard logging level string is supplied. + Valid level strings are in :data:`logging._nameToLevel`. + :param logger_obj: The logger object to check. + + :return: The original disabled logging level. + """ + original_disable_level: int = logger_obj.manager.disable + + if isinstance(level, str): + # Try to translate the level string to an int for `logging.disable()` + level = logging.getLevelName(level) + + if not isinstance(level, int): + # The level provided was not valid, so just un-disable all logging. + logging.disable(logging.NOTSET) + elif not logger_obj.isEnabledFor(level): + # Each level is `10` away from other levels. + # https://docs.python.org/3/library/logging.html#logging-levels + disable_level = max(level - 10, logging.NOTSET) + logging.disable(disable_level) + + return original_disable_level + + def set_level(self, level: int | str, logger: str | None = None) -> None: + """Set the threshold level of a logger for the duration of a test. + + Logging messages which are less severe than this level will not be captured. + + .. versionchanged:: 3.4 + The levels of the loggers changed by this function will be + restored to their initial values at the end of the test. + + Will enable the requested logging level if it was disabled via :func:`logging.disable`. + + :param level: The level. + :param logger: The logger to update. If not given, the root logger. + """ + logger_obj = logging.getLogger(logger) + # Save the original log-level to restore it during teardown. + self._initial_logger_levels.setdefault(logger, logger_obj.level) + logger_obj.setLevel(level) + if self._initial_handler_level is None: + self._initial_handler_level = self.handler.level + self.handler.setLevel(level) + initial_disabled_logging_level = self._force_enable_logging(level, logger_obj) + if self._initial_disabled_logging_level is None: + self._initial_disabled_logging_level = initial_disabled_logging_level + + @contextmanager + def at_level(self, level: int | str, logger: str | None = None) -> Generator[None]: + """Context manager that sets the level for capturing of logs. After + the end of the 'with' statement the level is restored to its original + value. + + Will enable the requested logging level if it was disabled via :func:`logging.disable`. + + :param level: The level. + :param logger: The logger to update. If not given, the root logger. + """ + logger_obj = logging.getLogger(logger) + orig_level = logger_obj.level + logger_obj.setLevel(level) + handler_orig_level = self.handler.level + self.handler.setLevel(level) + original_disable_level = self._force_enable_logging(level, logger_obj) + try: + yield + finally: + logger_obj.setLevel(orig_level) + self.handler.setLevel(handler_orig_level) + logging.disable(original_disable_level) + + @contextmanager + def filtering(self, filter_: logging.Filter) -> Generator[None]: + """Context manager that temporarily adds the given filter to the caplog's + :meth:`handler` for the 'with' statement block, and removes that filter at the + end of the block. + + :param filter_: A custom :class:`logging.Filter` object. + + .. versionadded:: 7.5 + """ + self.handler.addFilter(filter_) + try: + yield + finally: + self.handler.removeFilter(filter_) + + +@fixture +def caplog(request: FixtureRequest) -> Generator[LogCaptureFixture]: + """Access and control log capturing. + + Captured logs are available through the following properties/methods:: + + * caplog.messages -> list of format-interpolated log messages + * caplog.text -> string containing formatted log output + * caplog.records -> list of logging.LogRecord instances + * caplog.record_tuples -> list of (logger_name, level, message) tuples + * caplog.clear() -> clear captured records and formatted log output string + """ + result = LogCaptureFixture(request.node, _ispytest=True) + yield result + result._finalize() + + +def get_log_level_for_setting(config: Config, *setting_names: str) -> int | None: + for setting_name in setting_names: + log_level = config.getoption(setting_name) + if log_level is None: + log_level = config.getini(setting_name) + if log_level: + break + else: + return None + + if isinstance(log_level, str): + log_level = log_level.upper() + try: + return int(getattr(logging, log_level, log_level)) + except ValueError as e: + # Python logging does not recognise this as a logging level + raise UsageError( + f"'{log_level}' is not recognized as a logging level name for " + f"'{setting_name}'. Please consider passing the " + "logging level num instead." + ) from e + + +# run after terminalreporter/capturemanager are configured +@hookimpl(trylast=True) +def pytest_configure(config: Config) -> None: + config.pluginmanager.register(LoggingPlugin(config), "logging-plugin") + + +class LoggingPlugin: + """Attaches to the logging module and captures log messages for each test.""" + + def __init__(self, config: Config) -> None: + """Create a new plugin to capture log messages. + + The formatter can be safely shared across all handlers so + create a single one for the entire test session here. + """ + self._config = config + + # Report logging. + self.formatter = self._create_formatter( + get_option_ini(config, "log_format"), + get_option_ini(config, "log_date_format"), + get_option_ini(config, "log_auto_indent"), + ) + self.log_level = get_log_level_for_setting(config, "log_level") + self.caplog_handler = LogCaptureHandler() + self.caplog_handler.setFormatter(self.formatter) + self.report_handler = LogCaptureHandler() + self.report_handler.setFormatter(self.formatter) + + # File logging. + self.log_file_level = get_log_level_for_setting( + config, "log_file_level", "log_level" + ) + log_file = get_option_ini(config, "log_file") or os.devnull + if log_file != os.devnull: + directory = os.path.dirname(os.path.abspath(log_file)) + if not os.path.isdir(directory): + os.makedirs(directory) + + self.log_file_mode = get_option_ini(config, "log_file_mode") or "w" + self.log_file_handler = _FileHandler( + log_file, mode=self.log_file_mode, encoding="UTF-8" + ) + log_file_format = get_option_ini(config, "log_file_format", "log_format") + log_file_date_format = get_option_ini( + config, "log_file_date_format", "log_date_format" + ) + + log_file_formatter = DatetimeFormatter( + log_file_format, datefmt=log_file_date_format + ) + self.log_file_handler.setFormatter(log_file_formatter) + + # CLI/live logging. + self.log_cli_level = get_log_level_for_setting( + config, "log_cli_level", "log_level" + ) + if self._log_cli_enabled(): + terminal_reporter = config.pluginmanager.get_plugin("terminalreporter") + # Guaranteed by `_log_cli_enabled()`. + assert terminal_reporter is not None + capture_manager = config.pluginmanager.get_plugin("capturemanager") + # if capturemanager plugin is disabled, live logging still works. + self.log_cli_handler: ( + _LiveLoggingStreamHandler | _LiveLoggingNullHandler + ) = _LiveLoggingStreamHandler(terminal_reporter, capture_manager) + else: + self.log_cli_handler = _LiveLoggingNullHandler() + log_cli_formatter = self._create_formatter( + get_option_ini(config, "log_cli_format", "log_format"), + get_option_ini(config, "log_cli_date_format", "log_date_format"), + get_option_ini(config, "log_auto_indent"), + ) + self.log_cli_handler.setFormatter(log_cli_formatter) + self._disable_loggers(loggers_to_disable=config.option.logger_disable) + + def _disable_loggers(self, loggers_to_disable: list[str]) -> None: + if not loggers_to_disable: + return + + for name in loggers_to_disable: + logger = logging.getLogger(name) + logger.disabled = True + + def _create_formatter(self, log_format, log_date_format, auto_indent): + # Color option doesn't exist if terminal plugin is disabled. + color = getattr(self._config.option, "color", "no") + if color != "no" and ColoredLevelFormatter.LEVELNAME_FMT_REGEX.search( + log_format + ): + formatter: logging.Formatter = ColoredLevelFormatter( + create_terminal_writer(self._config), log_format, log_date_format + ) + else: + formatter = DatetimeFormatter(log_format, log_date_format) + + formatter._style = PercentStyleMultiline( + formatter._style._fmt, auto_indent=auto_indent + ) + + return formatter + + def set_log_path(self, fname: str) -> None: + """Set the filename parameter for Logging.FileHandler(). + + Creates parent directory if it does not exist. + + .. warning:: + This is an experimental API. + """ + fpath = Path(fname) + + if not fpath.is_absolute(): + fpath = self._config.rootpath / fpath + + if not fpath.parent.exists(): + fpath.parent.mkdir(exist_ok=True, parents=True) + + # https://github.com/python/mypy/issues/11193 + stream: io.TextIOWrapper = fpath.open(mode=self.log_file_mode, encoding="UTF-8") # type: ignore[assignment] + old_stream = self.log_file_handler.setStream(stream) + if old_stream: + old_stream.close() + + def _log_cli_enabled(self) -> bool: + """Return whether live logging is enabled.""" + enabled = self._config.getoption( + "--log-cli-level" + ) is not None or self._config.getini("log_cli") + if not enabled: + return False + + terminal_reporter = self._config.pluginmanager.get_plugin("terminalreporter") + if terminal_reporter is None: + # terminal reporter is disabled e.g. by pytest-xdist. + return False + + return True + + @hookimpl(wrapper=True, tryfirst=True) + def pytest_sessionstart(self) -> Generator[None]: + self.log_cli_handler.set_when("sessionstart") + + with catching_logs(self.log_cli_handler, level=self.log_cli_level): + with catching_logs(self.log_file_handler, level=self.log_file_level): + return (yield) + + @hookimpl(wrapper=True, tryfirst=True) + def pytest_collection(self) -> Generator[None]: + self.log_cli_handler.set_when("collection") + + with catching_logs(self.log_cli_handler, level=self.log_cli_level): + with catching_logs(self.log_file_handler, level=self.log_file_level): + return (yield) + + @hookimpl(wrapper=True) + def pytest_runtestloop(self, session: Session) -> Generator[None, object, object]: + if session.config.option.collectonly: + return (yield) + + if self._log_cli_enabled() and self._config.get_verbosity() < 1: + # The verbose flag is needed to avoid messy test progress output. + self._config.option.verbose = 1 + + with catching_logs(self.log_cli_handler, level=self.log_cli_level): + with catching_logs(self.log_file_handler, level=self.log_file_level): + return (yield) # Run all the tests. + + @hookimpl + def pytest_runtest_logstart(self) -> None: + self.log_cli_handler.reset() + self.log_cli_handler.set_when("start") + + @hookimpl + def pytest_runtest_logreport(self) -> None: + self.log_cli_handler.set_when("logreport") + + def _runtest_for(self, item: nodes.Item, when: str) -> Generator[None]: + """Implement the internals of the pytest_runtest_xxx() hooks.""" + with catching_logs( + self.caplog_handler, + level=self.log_level, + ) as caplog_handler, catching_logs( + self.report_handler, + level=self.log_level, + ) as report_handler: + caplog_handler.reset() + report_handler.reset() + item.stash[caplog_records_key][when] = caplog_handler.records + item.stash[caplog_handler_key] = caplog_handler + + try: + yield + finally: + log = report_handler.stream.getvalue().strip() + item.add_report_section(when, "log", log) + + @hookimpl(wrapper=True) + def pytest_runtest_setup(self, item: nodes.Item) -> Generator[None]: + self.log_cli_handler.set_when("setup") + + empty: dict[str, list[logging.LogRecord]] = {} + item.stash[caplog_records_key] = empty + yield from self._runtest_for(item, "setup") + + @hookimpl(wrapper=True) + def pytest_runtest_call(self, item: nodes.Item) -> Generator[None]: + self.log_cli_handler.set_when("call") + + yield from self._runtest_for(item, "call") + + @hookimpl(wrapper=True) + def pytest_runtest_teardown(self, item: nodes.Item) -> Generator[None]: + self.log_cli_handler.set_when("teardown") + + try: + yield from self._runtest_for(item, "teardown") + finally: + del item.stash[caplog_records_key] + del item.stash[caplog_handler_key] + + @hookimpl + def pytest_runtest_logfinish(self) -> None: + self.log_cli_handler.set_when("finish") + + @hookimpl(wrapper=True, tryfirst=True) + def pytest_sessionfinish(self) -> Generator[None]: + self.log_cli_handler.set_when("sessionfinish") + + with catching_logs(self.log_cli_handler, level=self.log_cli_level): + with catching_logs(self.log_file_handler, level=self.log_file_level): + return (yield) + + @hookimpl + def pytest_unconfigure(self) -> None: + # Close the FileHandler explicitly. + # (logging.shutdown might have lost the weakref?!) + self.log_file_handler.close() + + +class _FileHandler(logging.FileHandler): + """A logging FileHandler with pytest tweaks.""" + + def handleError(self, record: logging.LogRecord) -> None: + # Handled by LogCaptureHandler. + pass + + +class _LiveLoggingStreamHandler(logging_StreamHandler): + """A logging StreamHandler used by the live logging feature: it will + write a newline before the first log message in each test. + + During live logging we must also explicitly disable stdout/stderr + capturing otherwise it will get captured and won't appear in the + terminal. + """ + + # Officially stream needs to be a IO[str], but TerminalReporter + # isn't. So force it. + stream: TerminalReporter = None # type: ignore + + def __init__( + self, + terminal_reporter: TerminalReporter, + capture_manager: CaptureManager | None, + ) -> None: + super().__init__(stream=terminal_reporter) # type: ignore[arg-type] + self.capture_manager = capture_manager + self.reset() + self.set_when(None) + self._test_outcome_written = False + + def reset(self) -> None: + """Reset the handler; should be called before the start of each test.""" + self._first_record_emitted = False + + def set_when(self, when: str | None) -> None: + """Prepare for the given test phase (setup/call/teardown).""" + self._when = when + self._section_name_shown = False + if when == "start": + self._test_outcome_written = False + + def emit(self, record: logging.LogRecord) -> None: + ctx_manager = ( + self.capture_manager.global_and_fixture_disabled() + if self.capture_manager + else nullcontext() + ) + with ctx_manager: + if not self._first_record_emitted: + self.stream.write("\n") + self._first_record_emitted = True + elif self._when in ("teardown", "finish"): + if not self._test_outcome_written: + self._test_outcome_written = True + self.stream.write("\n") + if not self._section_name_shown and self._when: + self.stream.section("live log " + self._when, sep="-", bold=True) + self._section_name_shown = True + super().emit(record) + + def handleError(self, record: logging.LogRecord) -> None: + # Handled by LogCaptureHandler. + pass + + +class _LiveLoggingNullHandler(logging.NullHandler): + """A logging handler used when live logging is disabled.""" + + def reset(self) -> None: + pass + + def set_when(self, when: str) -> None: + pass + + def handleError(self, record: logging.LogRecord) -> None: + # Handled by LogCaptureHandler. + pass diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/main.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/main.py new file mode 100644 index 0000000..e5534e9 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/main.py @@ -0,0 +1,1072 @@ +"""Core implementation of the testing process: init, session, runtest loop.""" + +from __future__ import annotations + +import argparse +import dataclasses +import fnmatch +import functools +import importlib +import importlib.util +import os +from pathlib import Path +import sys +from typing import AbstractSet +from typing import Callable +from typing import Dict +from typing import final +from typing import Iterable +from typing import Iterator +from typing import Literal +from typing import overload +from typing import Sequence +from typing import TYPE_CHECKING +import warnings + +import pluggy + +from _pytest import nodes +import _pytest._code +from _pytest.config import Config +from _pytest.config import directory_arg +from _pytest.config import ExitCode +from _pytest.config import hookimpl +from _pytest.config import PytestPluginManager +from _pytest.config import UsageError +from _pytest.config.argparsing import Parser +from _pytest.config.compat import PathAwareHookProxy +from _pytest.outcomes import exit +from _pytest.pathlib import absolutepath +from _pytest.pathlib import bestrelpath +from _pytest.pathlib import fnmatch_ex +from _pytest.pathlib import safe_exists +from _pytest.pathlib import scandir +from _pytest.reports import CollectReport +from _pytest.reports import TestReport +from _pytest.runner import collect_one_node +from _pytest.runner import SetupState +from _pytest.warning_types import PytestWarning + + +if TYPE_CHECKING: + from typing_extensions import Self + + from _pytest.fixtures import FixtureManager + + +def pytest_addoption(parser: Parser) -> None: + parser.addini( + "norecursedirs", + "Directory patterns to avoid for recursion", + type="args", + default=[ + "*.egg", + ".*", + "_darcs", + "build", + "CVS", + "dist", + "node_modules", + "venv", + "{arch}", + ], + ) + parser.addini( + "testpaths", + "Directories to search for tests when no files or directories are given on the " + "command line", + type="args", + default=[], + ) + group = parser.getgroup("general", "Running and selection options") + group._addoption( + "-x", + "--exitfirst", + action="store_const", + dest="maxfail", + const=1, + help="Exit instantly on first error or failed test", + ) + group = parser.getgroup("pytest-warnings") + group.addoption( + "-W", + "--pythonwarnings", + action="append", + help="Set which warnings to report, see -W option of Python itself", + ) + parser.addini( + "filterwarnings", + type="linelist", + help="Each line specifies a pattern for " + "warnings.filterwarnings. " + "Processed after -W/--pythonwarnings.", + ) + group._addoption( + "--maxfail", + metavar="num", + action="store", + type=int, + dest="maxfail", + default=0, + help="Exit after first num failures or errors", + ) + group._addoption( + "--strict-config", + action="store_true", + help="Any warnings encountered while parsing the `pytest` section of the " + "configuration file raise errors", + ) + group._addoption( + "--strict-markers", + action="store_true", + help="Markers not registered in the `markers` section of the configuration " + "file raise errors", + ) + group._addoption( + "--strict", + action="store_true", + help="(Deprecated) alias to --strict-markers", + ) + group._addoption( + "-c", + "--config-file", + metavar="FILE", + type=str, + dest="inifilename", + help="Load configuration from `FILE` instead of trying to locate one of the " + "implicit configuration files.", + ) + group._addoption( + "--continue-on-collection-errors", + action="store_true", + default=False, + dest="continue_on_collection_errors", + help="Force test execution even if collection errors occur", + ) + group._addoption( + "--rootdir", + action="store", + dest="rootdir", + help="Define root directory for tests. Can be relative path: 'root_dir', './root_dir', " + "'root_dir/another_dir/'; absolute path: '/home/user/root_dir'; path with variables: " + "'$HOME/root_dir'.", + ) + + group = parser.getgroup("collect", "collection") + group.addoption( + "--collectonly", + "--collect-only", + "--co", + action="store_true", + help="Only collect tests, don't execute them", + ) + group.addoption( + "--pyargs", + action="store_true", + help="Try to interpret all arguments as Python packages", + ) + group.addoption( + "--ignore", + action="append", + metavar="path", + help="Ignore path during collection (multi-allowed)", + ) + group.addoption( + "--ignore-glob", + action="append", + metavar="path", + help="Ignore path pattern during collection (multi-allowed)", + ) + group.addoption( + "--deselect", + action="append", + metavar="nodeid_prefix", + help="Deselect item (via node id prefix) during collection (multi-allowed)", + ) + group.addoption( + "--confcutdir", + dest="confcutdir", + default=None, + metavar="dir", + type=functools.partial(directory_arg, optname="--confcutdir"), + help="Only load conftest.py's relative to specified dir", + ) + group.addoption( + "--noconftest", + action="store_true", + dest="noconftest", + default=False, + help="Don't load any conftest.py files", + ) + group.addoption( + "--keepduplicates", + "--keep-duplicates", + action="store_true", + dest="keepduplicates", + default=False, + help="Keep duplicate tests", + ) + group.addoption( + "--collect-in-virtualenv", + action="store_true", + dest="collect_in_virtualenv", + default=False, + help="Don't ignore tests in a local virtualenv directory", + ) + group.addoption( + "--import-mode", + default="prepend", + choices=["prepend", "append", "importlib"], + dest="importmode", + help="Prepend/append to sys.path when importing test modules and conftest " + "files. Default: prepend.", + ) + parser.addini( + "consider_namespace_packages", + type="bool", + default=False, + help="Consider namespace packages when resolving module names during import", + ) + + group = parser.getgroup("debugconfig", "test session debugging and configuration") + group.addoption( + "--basetemp", + dest="basetemp", + default=None, + type=validate_basetemp, + metavar="dir", + help=( + "Base temporary directory for this test run. " + "(Warning: this directory is removed if it exists.)" + ), + ) + + +def validate_basetemp(path: str) -> str: + # GH 7119 + msg = "basetemp must not be empty, the current working directory or any parent directory of it" + + # empty path + if not path: + raise argparse.ArgumentTypeError(msg) + + def is_ancestor(base: Path, query: Path) -> bool: + """Return whether query is an ancestor of base.""" + if base == query: + return True + return query in base.parents + + # check if path is an ancestor of cwd + if is_ancestor(Path.cwd(), Path(path).absolute()): + raise argparse.ArgumentTypeError(msg) + + # check symlinks for ancestors + if is_ancestor(Path.cwd().resolve(), Path(path).resolve()): + raise argparse.ArgumentTypeError(msg) + + return path + + +def wrap_session( + config: Config, doit: Callable[[Config, Session], int | ExitCode | None] +) -> int | ExitCode: + """Skeleton command line program.""" + session = Session.from_config(config) + session.exitstatus = ExitCode.OK + initstate = 0 + try: + try: + config._do_configure() + initstate = 1 + config.hook.pytest_sessionstart(session=session) + initstate = 2 + session.exitstatus = doit(config, session) or 0 + except UsageError: + session.exitstatus = ExitCode.USAGE_ERROR + raise + except Failed: + session.exitstatus = ExitCode.TESTS_FAILED + except (KeyboardInterrupt, exit.Exception): + excinfo = _pytest._code.ExceptionInfo.from_current() + exitstatus: int | ExitCode = ExitCode.INTERRUPTED + if isinstance(excinfo.value, exit.Exception): + if excinfo.value.returncode is not None: + exitstatus = excinfo.value.returncode + if initstate < 2: + sys.stderr.write(f"{excinfo.typename}: {excinfo.value.msg}\n") + config.hook.pytest_keyboard_interrupt(excinfo=excinfo) + session.exitstatus = exitstatus + except BaseException: + session.exitstatus = ExitCode.INTERNAL_ERROR + excinfo = _pytest._code.ExceptionInfo.from_current() + try: + config.notify_exception(excinfo, config.option) + except exit.Exception as exc: + if exc.returncode is not None: + session.exitstatus = exc.returncode + sys.stderr.write(f"{type(exc).__name__}: {exc}\n") + else: + if isinstance(excinfo.value, SystemExit): + sys.stderr.write("mainloop: caught unexpected SystemExit!\n") + + finally: + # Explicitly break reference cycle. + excinfo = None # type: ignore + os.chdir(session.startpath) + if initstate >= 2: + try: + config.hook.pytest_sessionfinish( + session=session, exitstatus=session.exitstatus + ) + except exit.Exception as exc: + if exc.returncode is not None: + session.exitstatus = exc.returncode + sys.stderr.write(f"{type(exc).__name__}: {exc}\n") + config._ensure_unconfigure() + return session.exitstatus + + +def pytest_cmdline_main(config: Config) -> int | ExitCode: + return wrap_session(config, _main) + + +def _main(config: Config, session: Session) -> int | ExitCode | None: + """Default command line protocol for initialization, session, + running tests and reporting.""" + config.hook.pytest_collection(session=session) + config.hook.pytest_runtestloop(session=session) + + if session.testsfailed: + return ExitCode.TESTS_FAILED + elif session.testscollected == 0: + return ExitCode.NO_TESTS_COLLECTED + return None + + +def pytest_collection(session: Session) -> None: + session.perform_collect() + + +def pytest_runtestloop(session: Session) -> bool: + if session.testsfailed and not session.config.option.continue_on_collection_errors: + raise session.Interrupted( + "%d error%s during collection" + % (session.testsfailed, "s" if session.testsfailed != 1 else "") + ) + + if session.config.option.collectonly: + return True + + for i, item in enumerate(session.items): + nextitem = session.items[i + 1] if i + 1 < len(session.items) else None + item.config.hook.pytest_runtest_protocol(item=item, nextitem=nextitem) + if session.shouldfail: + raise session.Failed(session.shouldfail) + if session.shouldstop: + raise session.Interrupted(session.shouldstop) + return True + + +def _in_venv(path: Path) -> bool: + """Attempt to detect if ``path`` is the root of a Virtual Environment by + checking for the existence of the pyvenv.cfg file. + + [https://peps.python.org/pep-0405/] + + For regression protection we also check for conda environments that do not include pyenv.cfg yet -- + https://github.com/conda/conda/issues/13337 is the conda issue tracking adding pyenv.cfg. + + Checking for the `conda-meta/history` file per https://github.com/pytest-dev/pytest/issues/12652#issuecomment-2246336902. + + """ + try: + return ( + path.joinpath("pyvenv.cfg").is_file() + or path.joinpath("conda-meta", "history").is_file() + ) + except OSError: + return False + + +def pytest_ignore_collect(collection_path: Path, config: Config) -> bool | None: + if collection_path.name == "__pycache__": + return True + + ignore_paths = config._getconftest_pathlist( + "collect_ignore", path=collection_path.parent + ) + ignore_paths = ignore_paths or [] + excludeopt = config.getoption("ignore") + if excludeopt: + ignore_paths.extend(absolutepath(x) for x in excludeopt) + + if collection_path in ignore_paths: + return True + + ignore_globs = config._getconftest_pathlist( + "collect_ignore_glob", path=collection_path.parent + ) + ignore_globs = ignore_globs or [] + excludeglobopt = config.getoption("ignore_glob") + if excludeglobopt: + ignore_globs.extend(absolutepath(x) for x in excludeglobopt) + + if any(fnmatch.fnmatch(str(collection_path), str(glob)) for glob in ignore_globs): + return True + + allow_in_venv = config.getoption("collect_in_virtualenv") + if not allow_in_venv and _in_venv(collection_path): + return True + + if collection_path.is_dir(): + norecursepatterns = config.getini("norecursedirs") + if any(fnmatch_ex(pat, collection_path) for pat in norecursepatterns): + return True + + return None + + +def pytest_collect_directory( + path: Path, parent: nodes.Collector +) -> nodes.Collector | None: + return Dir.from_parent(parent, path=path) + + +def pytest_collection_modifyitems(items: list[nodes.Item], config: Config) -> None: + deselect_prefixes = tuple(config.getoption("deselect") or []) + if not deselect_prefixes: + return + + remaining = [] + deselected = [] + for colitem in items: + if colitem.nodeid.startswith(deselect_prefixes): + deselected.append(colitem) + else: + remaining.append(colitem) + + if deselected: + config.hook.pytest_deselected(items=deselected) + items[:] = remaining + + +class FSHookProxy: + def __init__( + self, + pm: PytestPluginManager, + remove_mods: AbstractSet[object], + ) -> None: + self.pm = pm + self.remove_mods = remove_mods + + def __getattr__(self, name: str) -> pluggy.HookCaller: + x = self.pm.subset_hook_caller(name, remove_plugins=self.remove_mods) + self.__dict__[name] = x + return x + + +class Interrupted(KeyboardInterrupt): + """Signals that the test run was interrupted.""" + + __module__ = "builtins" # For py3. + + +class Failed(Exception): + """Signals a stop as failed test run.""" + + +@dataclasses.dataclass +class _bestrelpath_cache(Dict[Path, str]): + __slots__ = ("path",) + + path: Path + + def __missing__(self, path: Path) -> str: + r = bestrelpath(self.path, path) + self[path] = r + return r + + +@final +class Dir(nodes.Directory): + """Collector of files in a file system directory. + + .. versionadded:: 8.0 + + .. note:: + + Python directories with an `__init__.py` file are instead collected by + :class:`~pytest.Package` by default. Both are :class:`~pytest.Directory` + collectors. + """ + + @classmethod + def from_parent( # type: ignore[override] + cls, + parent: nodes.Collector, + *, + path: Path, + ) -> Self: + """The public constructor. + + :param parent: The parent collector of this Dir. + :param path: The directory's path. + :type path: pathlib.Path + """ + return super().from_parent(parent=parent, path=path) + + def collect(self) -> Iterable[nodes.Item | nodes.Collector]: + config = self.config + col: nodes.Collector | None + cols: Sequence[nodes.Collector] + ihook = self.ihook + for direntry in scandir(self.path): + if direntry.is_dir(): + path = Path(direntry.path) + if not self.session.isinitpath(path, with_parents=True): + if ihook.pytest_ignore_collect(collection_path=path, config=config): + continue + col = ihook.pytest_collect_directory(path=path, parent=self) + if col is not None: + yield col + + elif direntry.is_file(): + path = Path(direntry.path) + if not self.session.isinitpath(path): + if ihook.pytest_ignore_collect(collection_path=path, config=config): + continue + cols = ihook.pytest_collect_file(file_path=path, parent=self) + yield from cols + + +@final +class Session(nodes.Collector): + """The root of the collection tree. + + ``Session`` collects the initial paths given as arguments to pytest. + """ + + Interrupted = Interrupted + Failed = Failed + # Set on the session by runner.pytest_sessionstart. + _setupstate: SetupState + # Set on the session by fixtures.pytest_sessionstart. + _fixturemanager: FixtureManager + exitstatus: int | ExitCode + + def __init__(self, config: Config) -> None: + super().__init__( + name="", + path=config.rootpath, + fspath=None, + parent=None, + config=config, + session=self, + nodeid="", + ) + self.testsfailed = 0 + self.testscollected = 0 + self._shouldstop: bool | str = False + self._shouldfail: bool | str = False + self.trace = config.trace.root.get("collection") + self._initialpaths: frozenset[Path] = frozenset() + self._initialpaths_with_parents: frozenset[Path] = frozenset() + self._notfound: list[tuple[str, Sequence[nodes.Collector]]] = [] + self._initial_parts: list[CollectionArgument] = [] + self._collection_cache: dict[nodes.Collector, CollectReport] = {} + self.items: list[nodes.Item] = [] + + self._bestrelpathcache: dict[Path, str] = _bestrelpath_cache(config.rootpath) + + self.config.pluginmanager.register(self, name="session") + + @classmethod + def from_config(cls, config: Config) -> Session: + session: Session = cls._create(config=config) + return session + + def __repr__(self) -> str: + return "<%s %s exitstatus=%r testsfailed=%d testscollected=%d>" % ( + self.__class__.__name__, + self.name, + getattr(self, "exitstatus", ""), + self.testsfailed, + self.testscollected, + ) + + @property + def shouldstop(self) -> bool | str: + return self._shouldstop + + @shouldstop.setter + def shouldstop(self, value: bool | str) -> None: + # The runner checks shouldfail and assumes that if it is set we are + # definitely stopping, so prevent unsetting it. + if value is False and self._shouldstop: + warnings.warn( + PytestWarning( + "session.shouldstop cannot be unset after it has been set; ignoring." + ), + stacklevel=2, + ) + return + self._shouldstop = value + + @property + def shouldfail(self) -> bool | str: + return self._shouldfail + + @shouldfail.setter + def shouldfail(self, value: bool | str) -> None: + # The runner checks shouldfail and assumes that if it is set we are + # definitely stopping, so prevent unsetting it. + if value is False and self._shouldfail: + warnings.warn( + PytestWarning( + "session.shouldfail cannot be unset after it has been set; ignoring." + ), + stacklevel=2, + ) + return + self._shouldfail = value + + @property + def startpath(self) -> Path: + """The path from which pytest was invoked. + + .. versionadded:: 7.0.0 + """ + return self.config.invocation_params.dir + + def _node_location_to_relpath(self, node_path: Path) -> str: + # bestrelpath is a quite slow function. + return self._bestrelpathcache[node_path] + + @hookimpl(tryfirst=True) + def pytest_collectstart(self) -> None: + if self.shouldfail: + raise self.Failed(self.shouldfail) + if self.shouldstop: + raise self.Interrupted(self.shouldstop) + + @hookimpl(tryfirst=True) + def pytest_runtest_logreport(self, report: TestReport | CollectReport) -> None: + if report.failed and not hasattr(report, "wasxfail"): + self.testsfailed += 1 + maxfail = self.config.getvalue("maxfail") + if maxfail and self.testsfailed >= maxfail: + self.shouldfail = "stopping after %d failures" % (self.testsfailed) + + pytest_collectreport = pytest_runtest_logreport + + def isinitpath( + self, + path: str | os.PathLike[str], + *, + with_parents: bool = False, + ) -> bool: + """Is path an initial path? + + An initial path is a path explicitly given to pytest on the command + line. + + :param with_parents: + If set, also return True if the path is a parent of an initial path. + + .. versionchanged:: 8.0 + Added the ``with_parents`` parameter. + """ + # Optimization: Path(Path(...)) is much slower than isinstance. + path_ = path if isinstance(path, Path) else Path(path) + if with_parents: + return path_ in self._initialpaths_with_parents + else: + return path_ in self._initialpaths + + def gethookproxy(self, fspath: os.PathLike[str]) -> pluggy.HookRelay: + # Optimization: Path(Path(...)) is much slower than isinstance. + path = fspath if isinstance(fspath, Path) else Path(fspath) + pm = self.config.pluginmanager + # Check if we have the common case of running + # hooks with all conftest.py files. + my_conftestmodules = pm._getconftestmodules(path) + remove_mods = pm._conftest_plugins.difference(my_conftestmodules) + proxy: pluggy.HookRelay + if remove_mods: + # One or more conftests are not in use at this path. + proxy = PathAwareHookProxy(FSHookProxy(pm, remove_mods)) # type: ignore[arg-type,assignment] + else: + # All plugins are active for this fspath. + proxy = self.config.hook + return proxy + + def _collect_path( + self, + path: Path, + path_cache: dict[Path, Sequence[nodes.Collector]], + ) -> Sequence[nodes.Collector]: + """Create a Collector for the given path. + + `path_cache` makes it so the same Collectors are returned for the same + path. + """ + if path in path_cache: + return path_cache[path] + + if path.is_dir(): + ihook = self.gethookproxy(path.parent) + col: nodes.Collector | None = ihook.pytest_collect_directory( + path=path, parent=self + ) + cols: Sequence[nodes.Collector] = (col,) if col is not None else () + + elif path.is_file(): + ihook = self.gethookproxy(path) + cols = ihook.pytest_collect_file(file_path=path, parent=self) + + else: + # Broken symlink or invalid/missing file. + cols = () + + path_cache[path] = cols + return cols + + @overload + def perform_collect( + self, args: Sequence[str] | None = ..., genitems: Literal[True] = ... + ) -> Sequence[nodes.Item]: ... + + @overload + def perform_collect( + self, args: Sequence[str] | None = ..., genitems: bool = ... + ) -> Sequence[nodes.Item | nodes.Collector]: ... + + def perform_collect( + self, args: Sequence[str] | None = None, genitems: bool = True + ) -> Sequence[nodes.Item | nodes.Collector]: + """Perform the collection phase for this session. + + This is called by the default :hook:`pytest_collection` hook + implementation; see the documentation of this hook for more details. + For testing purposes, it may also be called directly on a fresh + ``Session``. + + This function normally recursively expands any collectors collected + from the session to their items, and only items are returned. For + testing purposes, this may be suppressed by passing ``genitems=False``, + in which case the return value contains these collectors unexpanded, + and ``session.items`` is empty. + """ + if args is None: + args = self.config.args + + self.trace("perform_collect", self, args) + self.trace.root.indent += 1 + + hook = self.config.hook + + self._notfound = [] + self._initial_parts = [] + self._collection_cache = {} + self.items = [] + items: Sequence[nodes.Item | nodes.Collector] = self.items + try: + initialpaths: list[Path] = [] + initialpaths_with_parents: list[Path] = [] + for arg in args: + collection_argument = resolve_collection_argument( + self.config.invocation_params.dir, + arg, + as_pypath=self.config.option.pyargs, + ) + self._initial_parts.append(collection_argument) + initialpaths.append(collection_argument.path) + initialpaths_with_parents.append(collection_argument.path) + initialpaths_with_parents.extend(collection_argument.path.parents) + self._initialpaths = frozenset(initialpaths) + self._initialpaths_with_parents = frozenset(initialpaths_with_parents) + + rep = collect_one_node(self) + self.ihook.pytest_collectreport(report=rep) + self.trace.root.indent -= 1 + if self._notfound: + errors = [] + for arg, collectors in self._notfound: + if collectors: + errors.append( + f"not found: {arg}\n(no match in any of {collectors!r})" + ) + else: + errors.append(f"found no collectors for {arg}") + + raise UsageError(*errors) + + if not genitems: + items = rep.result + else: + if rep.passed: + for node in rep.result: + self.items.extend(self.genitems(node)) + + self.config.pluginmanager.check_pending() + hook.pytest_collection_modifyitems( + session=self, config=self.config, items=items + ) + finally: + self._notfound = [] + self._initial_parts = [] + self._collection_cache = {} + hook.pytest_collection_finish(session=self) + + if genitems: + self.testscollected = len(items) + + return items + + def _collect_one_node( + self, + node: nodes.Collector, + handle_dupes: bool = True, + ) -> tuple[CollectReport, bool]: + if node in self._collection_cache and handle_dupes: + rep = self._collection_cache[node] + return rep, True + else: + rep = collect_one_node(node) + self._collection_cache[node] = rep + return rep, False + + def collect(self) -> Iterator[nodes.Item | nodes.Collector]: + # This is a cache for the root directories of the initial paths. + # We can't use collection_cache for Session because of its special + # role as the bootstrapping collector. + path_cache: dict[Path, Sequence[nodes.Collector]] = {} + + pm = self.config.pluginmanager + + for collection_argument in self._initial_parts: + self.trace("processing argument", collection_argument) + self.trace.root.indent += 1 + + argpath = collection_argument.path + names = collection_argument.parts + module_name = collection_argument.module_name + + # resolve_collection_argument() ensures this. + if argpath.is_dir(): + assert not names, f"invalid arg {(argpath, names)!r}" + + paths = [argpath] + # Add relevant parents of the path, from the root, e.g. + # /a/b/c.py -> [/, /a, /a/b, /a/b/c.py] + if module_name is None: + # Paths outside of the confcutdir should not be considered. + for path in argpath.parents: + if not pm._is_in_confcutdir(path): + break + paths.insert(0, path) + else: + # For --pyargs arguments, only consider paths matching the module + # name. Paths beyond the package hierarchy are not included. + module_name_parts = module_name.split(".") + for i, path in enumerate(argpath.parents, 2): + if i > len(module_name_parts) or path.stem != module_name_parts[-i]: + break + paths.insert(0, path) + + # Start going over the parts from the root, collecting each level + # and discarding all nodes which don't match the level's part. + any_matched_in_initial_part = False + notfound_collectors = [] + work: list[tuple[nodes.Collector | nodes.Item, list[Path | str]]] = [ + (self, [*paths, *names]) + ] + while work: + matchnode, matchparts = work.pop() + + # Pop'd all of the parts, this is a match. + if not matchparts: + yield matchnode + any_matched_in_initial_part = True + continue + + # Should have been matched by now, discard. + if not isinstance(matchnode, nodes.Collector): + continue + + # Collect this level of matching. + # Collecting Session (self) is done directly to avoid endless + # recursion to this function. + subnodes: Sequence[nodes.Collector | nodes.Item] + if isinstance(matchnode, Session): + assert isinstance(matchparts[0], Path) + subnodes = matchnode._collect_path(matchparts[0], path_cache) + else: + # For backward compat, files given directly multiple + # times on the command line should not be deduplicated. + handle_dupes = not ( + len(matchparts) == 1 + and isinstance(matchparts[0], Path) + and matchparts[0].is_file() + ) + rep, duplicate = self._collect_one_node(matchnode, handle_dupes) + if not duplicate and not rep.passed: + # Report collection failures here to avoid failing to + # run some test specified in the command line because + # the module could not be imported (#134). + matchnode.ihook.pytest_collectreport(report=rep) + if not rep.passed: + continue + subnodes = rep.result + + # Prune this level. + any_matched_in_collector = False + for node in reversed(subnodes): + # Path part e.g. `/a/b/` in `/a/b/test_file.py::TestIt::test_it`. + if isinstance(matchparts[0], Path): + is_match = node.path == matchparts[0] + if sys.platform == "win32" and not is_match: + # In case the file paths do not match, fallback to samefile() to + # account for short-paths on Windows (#11895). + same_file = os.path.samefile(node.path, matchparts[0]) + # We don't want to match links to the current node, + # otherwise we would match the same file more than once (#12039). + is_match = same_file and ( + os.path.islink(node.path) + == os.path.islink(matchparts[0]) + ) + + # Name part e.g. `TestIt` in `/a/b/test_file.py::TestIt::test_it`. + else: + # TODO: Remove parametrized workaround once collection structure contains + # parametrization. + is_match = ( + node.name == matchparts[0] + or node.name.split("[")[0] == matchparts[0] + ) + if is_match: + work.append((node, matchparts[1:])) + any_matched_in_collector = True + + if not any_matched_in_collector: + notfound_collectors.append(matchnode) + + if not any_matched_in_initial_part: + report_arg = "::".join((str(argpath), *names)) + self._notfound.append((report_arg, notfound_collectors)) + + self.trace.root.indent -= 1 + + def genitems(self, node: nodes.Item | nodes.Collector) -> Iterator[nodes.Item]: + self.trace("genitems", node) + if isinstance(node, nodes.Item): + node.ihook.pytest_itemcollected(item=node) + yield node + else: + assert isinstance(node, nodes.Collector) + keepduplicates = self.config.getoption("keepduplicates") + # For backward compat, dedup only applies to files. + handle_dupes = not (keepduplicates and isinstance(node, nodes.File)) + rep, duplicate = self._collect_one_node(node, handle_dupes) + if duplicate and not keepduplicates: + return + if rep.passed: + for subnode in rep.result: + yield from self.genitems(subnode) + if not duplicate: + node.ihook.pytest_collectreport(report=rep) + + +def search_pypath(module_name: str) -> str | None: + """Search sys.path for the given a dotted module name, and return its file + system path if found.""" + try: + spec = importlib.util.find_spec(module_name) + # AttributeError: looks like package module, but actually filename + # ImportError: module does not exist + # ValueError: not a module name + except (AttributeError, ImportError, ValueError): + return None + if spec is None or spec.origin is None or spec.origin == "namespace": + return None + elif spec.submodule_search_locations: + return os.path.dirname(spec.origin) + else: + return spec.origin + + +@dataclasses.dataclass(frozen=True) +class CollectionArgument: + """A resolved collection argument.""" + + path: Path + parts: Sequence[str] + module_name: str | None + + +def resolve_collection_argument( + invocation_path: Path, arg: str, *, as_pypath: bool = False +) -> CollectionArgument: + """Parse path arguments optionally containing selection parts and return (fspath, names). + + Command-line arguments can point to files and/or directories, and optionally contain + parts for specific tests selection, for example: + + "pkg/tests/test_foo.py::TestClass::test_foo" + + This function ensures the path exists, and returns a resolved `CollectionArgument`: + + CollectionArgument( + path=Path("/full/path/to/pkg/tests/test_foo.py"), + parts=["TestClass", "test_foo"], + module_name=None, + ) + + When as_pypath is True, expects that the command-line argument actually contains + module paths instead of file-system paths: + + "pkg.tests.test_foo::TestClass::test_foo" + + In which case we search sys.path for a matching module, and then return the *path* to the + found module, which may look like this: + + CollectionArgument( + path=Path("/home/u/myvenv/lib/site-packages/pkg/tests/test_foo.py"), + parts=["TestClass", "test_foo"], + module_name="pkg.tests.test_foo", + ) + + If the path doesn't exist, raise UsageError. + If the path is a directory and selection parts are present, raise UsageError. + """ + base, squacket, rest = str(arg).partition("[") + strpath, *parts = base.split("::") + if parts: + parts[-1] = f"{parts[-1]}{squacket}{rest}" + module_name = None + if as_pypath: + pyarg_strpath = search_pypath(strpath) + if pyarg_strpath is not None: + module_name = strpath + strpath = pyarg_strpath + fspath = invocation_path / strpath + fspath = absolutepath(fspath) + if not safe_exists(fspath): + msg = ( + "module or package not found: {arg} (missing __init__.py?)" + if as_pypath + else "file or directory not found: {arg}" + ) + raise UsageError(msg.format(arg=arg)) + if parts and fspath.is_dir(): + msg = ( + "package argument cannot contain :: selection parts: {arg}" + if as_pypath + else "directory argument cannot contain :: selection parts: {arg}" + ) + raise UsageError(msg.format(arg=arg)) + return CollectionArgument( + path=fspath, + parts=parts, + module_name=module_name, + ) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/mark/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/mark/__init__.py new file mode 100644 index 0000000..a4f942c --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/mark/__init__.py @@ -0,0 +1,292 @@ +"""Generic mechanism for marking and selecting python functions.""" + +from __future__ import annotations + +import collections +import dataclasses +from typing import AbstractSet +from typing import Collection +from typing import Iterable +from typing import Optional +from typing import TYPE_CHECKING + +from .expression import Expression +from .expression import ParseError +from .structures import EMPTY_PARAMETERSET_OPTION +from .structures import get_empty_parameterset_mark +from .structures import Mark +from .structures import MARK_GEN +from .structures import MarkDecorator +from .structures import MarkGenerator +from .structures import ParameterSet +from _pytest.config import Config +from _pytest.config import ExitCode +from _pytest.config import hookimpl +from _pytest.config import UsageError +from _pytest.config.argparsing import NOT_SET +from _pytest.config.argparsing import Parser +from _pytest.stash import StashKey + + +if TYPE_CHECKING: + from _pytest.nodes import Item + + +__all__ = [ + "MARK_GEN", + "Mark", + "MarkDecorator", + "MarkGenerator", + "ParameterSet", + "get_empty_parameterset_mark", +] + + +old_mark_config_key = StashKey[Optional[Config]]() + + +def param( + *values: object, + marks: MarkDecorator | Collection[MarkDecorator | Mark] = (), + id: str | None = None, +) -> ParameterSet: + """Specify a parameter in `pytest.mark.parametrize`_ calls or + :ref:`parametrized fixtures `. + + .. code-block:: python + + @pytest.mark.parametrize( + "test_input,expected", + [ + ("3+5", 8), + pytest.param("6*9", 42, marks=pytest.mark.xfail), + ], + ) + def test_eval(test_input, expected): + assert eval(test_input) == expected + + :param values: Variable args of the values of the parameter set, in order. + :param marks: A single mark or a list of marks to be applied to this parameter set. + :param id: The id to attribute to this parameter set. + """ + return ParameterSet.param(*values, marks=marks, id=id) + + +def pytest_addoption(parser: Parser) -> None: + group = parser.getgroup("general") + group._addoption( + "-k", + action="store", + dest="keyword", + default="", + metavar="EXPRESSION", + help="Only run tests which match the given substring expression. " + "An expression is a Python evaluable expression " + "where all names are substring-matched against test names " + "and their parent classes. Example: -k 'test_method or test_" + "other' matches all test functions and classes whose name " + "contains 'test_method' or 'test_other', while -k 'not test_method' " + "matches those that don't contain 'test_method' in their names. " + "-k 'not test_method and not test_other' will eliminate the matches. " + "Additionally keywords are matched to classes and functions " + "containing extra names in their 'extra_keyword_matches' set, " + "as well as functions which have names assigned directly to them. " + "The matching is case-insensitive.", + ) + + group._addoption( + "-m", + action="store", + dest="markexpr", + default="", + metavar="MARKEXPR", + help="Only run tests matching given mark expression. " + "For example: -m 'mark1 and not mark2'.", + ) + + group.addoption( + "--markers", + action="store_true", + help="show markers (builtin, plugin and per-project ones).", + ) + + parser.addini("markers", "Register new markers for test functions", "linelist") + parser.addini(EMPTY_PARAMETERSET_OPTION, "Default marker for empty parametersets") + + +@hookimpl(tryfirst=True) +def pytest_cmdline_main(config: Config) -> int | ExitCode | None: + import _pytest.config + + if config.option.markers: + config._do_configure() + tw = _pytest.config.create_terminal_writer(config) + for line in config.getini("markers"): + parts = line.split(":", 1) + name = parts[0] + rest = parts[1] if len(parts) == 2 else "" + tw.write(f"@pytest.mark.{name}:", bold=True) + tw.line(rest) + tw.line() + config._ensure_unconfigure() + return 0 + + return None + + +@dataclasses.dataclass +class KeywordMatcher: + """A matcher for keywords. + + Given a list of names, matches any substring of one of these names. The + string inclusion check is case-insensitive. + + Will match on the name of colitem, including the names of its parents. + Only matches names of items which are either a :class:`Class` or a + :class:`Function`. + + Additionally, matches on names in the 'extra_keyword_matches' set of + any item, as well as names directly assigned to test functions. + """ + + __slots__ = ("_names",) + + _names: AbstractSet[str] + + @classmethod + def from_item(cls, item: Item) -> KeywordMatcher: + mapped_names = set() + + # Add the names of the current item and any parent items, + # except the Session and root Directory's which are not + # interesting for matching. + import pytest + + for node in item.listchain(): + if isinstance(node, pytest.Session): + continue + if isinstance(node, pytest.Directory) and isinstance( + node.parent, pytest.Session + ): + continue + mapped_names.add(node.name) + + # Add the names added as extra keywords to current or parent items. + mapped_names.update(item.listextrakeywords()) + + # Add the names attached to the current function through direct assignment. + function_obj = getattr(item, "function", None) + if function_obj: + mapped_names.update(function_obj.__dict__) + + # Add the markers to the keywords as we no longer handle them correctly. + mapped_names.update(mark.name for mark in item.iter_markers()) + + return cls(mapped_names) + + def __call__(self, subname: str, /, **kwargs: str | int | bool | None) -> bool: + if kwargs: + raise UsageError("Keyword expressions do not support call parameters.") + subname = subname.lower() + names = (name.lower() for name in self._names) + + for name in names: + if subname in name: + return True + return False + + +def deselect_by_keyword(items: list[Item], config: Config) -> None: + keywordexpr = config.option.keyword.lstrip() + if not keywordexpr: + return + + expr = _parse_expression(keywordexpr, "Wrong expression passed to '-k'") + + remaining = [] + deselected = [] + for colitem in items: + if not expr.evaluate(KeywordMatcher.from_item(colitem)): + deselected.append(colitem) + else: + remaining.append(colitem) + + if deselected: + config.hook.pytest_deselected(items=deselected) + items[:] = remaining + + +@dataclasses.dataclass +class MarkMatcher: + """A matcher for markers which are present. + + Tries to match on any marker names, attached to the given colitem. + """ + + __slots__ = ("own_mark_name_mapping",) + + own_mark_name_mapping: dict[str, list[Mark]] + + @classmethod + def from_markers(cls, markers: Iterable[Mark]) -> MarkMatcher: + mark_name_mapping = collections.defaultdict(list) + for mark in markers: + mark_name_mapping[mark.name].append(mark) + return cls(mark_name_mapping) + + def __call__(self, name: str, /, **kwargs: str | int | bool | None) -> bool: + if not (matches := self.own_mark_name_mapping.get(name, [])): + return False + + for mark in matches: + if all(mark.kwargs.get(k, NOT_SET) == v for k, v in kwargs.items()): + return True + + return False + + +def deselect_by_mark(items: list[Item], config: Config) -> None: + matchexpr = config.option.markexpr + if not matchexpr: + return + + expr = _parse_expression(matchexpr, "Wrong expression passed to '-m'") + remaining: list[Item] = [] + deselected: list[Item] = [] + for item in items: + if expr.evaluate(MarkMatcher.from_markers(item.iter_markers())): + remaining.append(item) + else: + deselected.append(item) + if deselected: + config.hook.pytest_deselected(items=deselected) + items[:] = remaining + + +def _parse_expression(expr: str, exc_message: str) -> Expression: + try: + return Expression.compile(expr) + except ParseError as e: + raise UsageError(f"{exc_message}: {expr}: {e}") from None + + +def pytest_collection_modifyitems(items: list[Item], config: Config) -> None: + deselect_by_keyword(items, config) + deselect_by_mark(items, config) + + +def pytest_configure(config: Config) -> None: + config.stash[old_mark_config_key] = MARK_GEN._config + MARK_GEN._config = config + + empty_parameterset = config.getini(EMPTY_PARAMETERSET_OPTION) + + if empty_parameterset not in ("skip", "xfail", "fail_at_collect", None, ""): + raise UsageError( + f"{EMPTY_PARAMETERSET_OPTION!s} must be one of skip, xfail or fail_at_collect" + f" but it is {empty_parameterset!r}" + ) + + +def pytest_unconfigure(config: Config) -> None: + MARK_GEN._config = config.stash.get(old_mark_config_key, None) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/mark/expression.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/mark/expression.py new file mode 100644 index 0000000..89cc0e9 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/mark/expression.py @@ -0,0 +1,333 @@ +r"""Evaluate match expressions, as used by `-k` and `-m`. + +The grammar is: + +expression: expr? EOF +expr: and_expr ('or' and_expr)* +and_expr: not_expr ('and' not_expr)* +not_expr: 'not' not_expr | '(' expr ')' | ident kwargs? + +ident: (\w|:|\+|-|\.|\[|\]|\\|/)+ +kwargs: ('(' name '=' value ( ', ' name '=' value )* ')') +name: a valid ident, but not a reserved keyword +value: (unescaped) string literal | (-)?[0-9]+ | 'False' | 'True' | 'None' + +The semantics are: + +- Empty expression evaluates to False. +- ident evaluates to True or False according to a provided matcher function. +- or/and/not evaluate according to the usual boolean semantics. +- ident with parentheses and keyword arguments evaluates to True or False according to a provided matcher function. +""" + +from __future__ import annotations + +import ast +import dataclasses +import enum +import keyword +import re +import types +from typing import Iterator +from typing import Literal +from typing import Mapping +from typing import NoReturn +from typing import overload +from typing import Protocol +from typing import Sequence + + +__all__ = [ + "Expression", + "ParseError", +] + + +class TokenType(enum.Enum): + LPAREN = "left parenthesis" + RPAREN = "right parenthesis" + OR = "or" + AND = "and" + NOT = "not" + IDENT = "identifier" + EOF = "end of input" + EQUAL = "=" + STRING = "string literal" + COMMA = "," + + +@dataclasses.dataclass(frozen=True) +class Token: + __slots__ = ("type", "value", "pos") + type: TokenType + value: str + pos: int + + +class ParseError(Exception): + """The expression contains invalid syntax. + + :param column: The column in the line where the error occurred (1-based). + :param message: A description of the error. + """ + + def __init__(self, column: int, message: str) -> None: + self.column = column + self.message = message + + def __str__(self) -> str: + return f"at column {self.column}: {self.message}" + + +class Scanner: + __slots__ = ("tokens", "current") + + def __init__(self, input: str) -> None: + self.tokens = self.lex(input) + self.current = next(self.tokens) + + def lex(self, input: str) -> Iterator[Token]: + pos = 0 + while pos < len(input): + if input[pos] in (" ", "\t"): + pos += 1 + elif input[pos] == "(": + yield Token(TokenType.LPAREN, "(", pos) + pos += 1 + elif input[pos] == ")": + yield Token(TokenType.RPAREN, ")", pos) + pos += 1 + elif input[pos] == "=": + yield Token(TokenType.EQUAL, "=", pos) + pos += 1 + elif input[pos] == ",": + yield Token(TokenType.COMMA, ",", pos) + pos += 1 + elif (quote_char := input[pos]) in ("'", '"'): + end_quote_pos = input.find(quote_char, pos + 1) + if end_quote_pos == -1: + raise ParseError( + pos + 1, + f'closing quote "{quote_char}" is missing', + ) + value = input[pos : end_quote_pos + 1] + if (backslash_pos := input.find("\\")) != -1: + raise ParseError( + backslash_pos + 1, + r'escaping with "\" not supported in marker expression', + ) + yield Token(TokenType.STRING, value, pos) + pos += len(value) + else: + match = re.match(r"(:?\w|:|\+|-|\.|\[|\]|\\|/)+", input[pos:]) + if match: + value = match.group(0) + if value == "or": + yield Token(TokenType.OR, value, pos) + elif value == "and": + yield Token(TokenType.AND, value, pos) + elif value == "not": + yield Token(TokenType.NOT, value, pos) + else: + yield Token(TokenType.IDENT, value, pos) + pos += len(value) + else: + raise ParseError( + pos + 1, + f'unexpected character "{input[pos]}"', + ) + yield Token(TokenType.EOF, "", pos) + + @overload + def accept(self, type: TokenType, *, reject: Literal[True]) -> Token: ... + + @overload + def accept( + self, type: TokenType, *, reject: Literal[False] = False + ) -> Token | None: ... + + def accept(self, type: TokenType, *, reject: bool = False) -> Token | None: + if self.current.type is type: + token = self.current + if token.type is not TokenType.EOF: + self.current = next(self.tokens) + return token + if reject: + self.reject((type,)) + return None + + def reject(self, expected: Sequence[TokenType]) -> NoReturn: + raise ParseError( + self.current.pos + 1, + "expected {}; got {}".format( + " OR ".join(type.value for type in expected), + self.current.type.value, + ), + ) + + +# True, False and None are legal match expression identifiers, +# but illegal as Python identifiers. To fix this, this prefix +# is added to identifiers in the conversion to Python AST. +IDENT_PREFIX = "$" + + +def expression(s: Scanner) -> ast.Expression: + if s.accept(TokenType.EOF): + ret: ast.expr = ast.Constant(False) + else: + ret = expr(s) + s.accept(TokenType.EOF, reject=True) + return ast.fix_missing_locations(ast.Expression(ret)) + + +def expr(s: Scanner) -> ast.expr: + ret = and_expr(s) + while s.accept(TokenType.OR): + rhs = and_expr(s) + ret = ast.BoolOp(ast.Or(), [ret, rhs]) + return ret + + +def and_expr(s: Scanner) -> ast.expr: + ret = not_expr(s) + while s.accept(TokenType.AND): + rhs = not_expr(s) + ret = ast.BoolOp(ast.And(), [ret, rhs]) + return ret + + +def not_expr(s: Scanner) -> ast.expr: + if s.accept(TokenType.NOT): + return ast.UnaryOp(ast.Not(), not_expr(s)) + if s.accept(TokenType.LPAREN): + ret = expr(s) + s.accept(TokenType.RPAREN, reject=True) + return ret + ident = s.accept(TokenType.IDENT) + if ident: + name = ast.Name(IDENT_PREFIX + ident.value, ast.Load()) + if s.accept(TokenType.LPAREN): + ret = ast.Call(func=name, args=[], keywords=all_kwargs(s)) + s.accept(TokenType.RPAREN, reject=True) + else: + ret = name + return ret + + s.reject((TokenType.NOT, TokenType.LPAREN, TokenType.IDENT)) + + +BUILTIN_MATCHERS = {"True": True, "False": False, "None": None} + + +def single_kwarg(s: Scanner) -> ast.keyword: + keyword_name = s.accept(TokenType.IDENT, reject=True) + if not keyword_name.value.isidentifier(): + raise ParseError( + keyword_name.pos + 1, + f"not a valid python identifier {keyword_name.value}", + ) + if keyword.iskeyword(keyword_name.value): + raise ParseError( + keyword_name.pos + 1, + f"unexpected reserved python keyword `{keyword_name.value}`", + ) + s.accept(TokenType.EQUAL, reject=True) + + if value_token := s.accept(TokenType.STRING): + value: str | int | bool | None = value_token.value[1:-1] # strip quotes + else: + value_token = s.accept(TokenType.IDENT, reject=True) + if ( + (number := value_token.value).isdigit() + or number.startswith("-") + and number[1:].isdigit() + ): + value = int(number) + elif value_token.value in BUILTIN_MATCHERS: + value = BUILTIN_MATCHERS[value_token.value] + else: + raise ParseError( + value_token.pos + 1, + f'unexpected character/s "{value_token.value}"', + ) + + ret = ast.keyword(keyword_name.value, ast.Constant(value)) + return ret + + +def all_kwargs(s: Scanner) -> list[ast.keyword]: + ret = [single_kwarg(s)] + while s.accept(TokenType.COMMA): + ret.append(single_kwarg(s)) + return ret + + +class MatcherCall(Protocol): + def __call__(self, name: str, /, **kwargs: str | int | bool | None) -> bool: ... + + +@dataclasses.dataclass +class MatcherNameAdapter: + matcher: MatcherCall + name: str + + def __bool__(self) -> bool: + return self.matcher(self.name) + + def __call__(self, **kwargs: str | int | bool | None) -> bool: + return self.matcher(self.name, **kwargs) + + +class MatcherAdapter(Mapping[str, MatcherNameAdapter]): + """Adapts a matcher function to a locals mapping as required by eval().""" + + def __init__(self, matcher: MatcherCall) -> None: + self.matcher = matcher + + def __getitem__(self, key: str) -> MatcherNameAdapter: + return MatcherNameAdapter(matcher=self.matcher, name=key[len(IDENT_PREFIX) :]) + + def __iter__(self) -> Iterator[str]: + raise NotImplementedError() + + def __len__(self) -> int: + raise NotImplementedError() + + +class Expression: + """A compiled match expression as used by -k and -m. + + The expression can be evaluated against different matchers. + """ + + __slots__ = ("code",) + + def __init__(self, code: types.CodeType) -> None: + self.code = code + + @classmethod + def compile(self, input: str) -> Expression: + """Compile a match expression. + + :param input: The input expression - one line. + """ + astexpr = expression(Scanner(input)) + code: types.CodeType = compile( + astexpr, + filename="", + mode="eval", + ) + return Expression(code) + + def evaluate(self, matcher: MatcherCall) -> bool: + """Evaluate the match expression. + + :param matcher: + Given an identifier, should return whether it matches or not. + Should be prepared to handle arbitrary strings as input. + + :returns: Whether the expression matches or not. + """ + ret: bool = bool(eval(self.code, {"__builtins__": {}}, MatcherAdapter(matcher))) + return ret diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/mark/structures.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/mark/structures.py new file mode 100644 index 0000000..92ade55 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/mark/structures.py @@ -0,0 +1,615 @@ +# mypy: allow-untyped-defs +from __future__ import annotations + +import collections.abc +import dataclasses +import inspect +from typing import Any +from typing import Callable +from typing import Collection +from typing import final +from typing import Iterable +from typing import Iterator +from typing import Mapping +from typing import MutableMapping +from typing import NamedTuple +from typing import overload +from typing import Sequence +from typing import TYPE_CHECKING +from typing import TypeVar +from typing import Union +import warnings + +from .._code import getfslineno +from ..compat import ascii_escaped +from ..compat import NOTSET +from ..compat import NotSetType +from _pytest.config import Config +from _pytest.deprecated import check_ispytest +from _pytest.deprecated import MARKED_FIXTURE +from _pytest.outcomes import fail +from _pytest.scope import _ScopeName +from _pytest.warning_types import PytestUnknownMarkWarning + + +if TYPE_CHECKING: + from ..nodes import Node + + +EMPTY_PARAMETERSET_OPTION = "empty_parameter_set_mark" + + +def istestfunc(func) -> bool: + return callable(func) and getattr(func, "__name__", "") != "" + + +def get_empty_parameterset_mark( + config: Config, argnames: Sequence[str], func +) -> MarkDecorator: + from ..nodes import Collector + + fs, lineno = getfslineno(func) + reason = "got empty parameter set %r, function %s at %s:%d" % ( + argnames, + func.__name__, + fs, + lineno, + ) + + requested_mark = config.getini(EMPTY_PARAMETERSET_OPTION) + if requested_mark in ("", None, "skip"): + mark = MARK_GEN.skip(reason=reason) + elif requested_mark == "xfail": + mark = MARK_GEN.xfail(reason=reason, run=False) + elif requested_mark == "fail_at_collect": + f_name = func.__name__ + _, lineno = getfslineno(func) + raise Collector.CollectError( + "Empty parameter set in '%s' at line %d" % (f_name, lineno + 1) + ) + else: + raise LookupError(requested_mark) + return mark + + +class ParameterSet(NamedTuple): + values: Sequence[object | NotSetType] + marks: Collection[MarkDecorator | Mark] + id: str | None + + @classmethod + def param( + cls, + *values: object, + marks: MarkDecorator | Collection[MarkDecorator | Mark] = (), + id: str | None = None, + ) -> ParameterSet: + if isinstance(marks, MarkDecorator): + marks = (marks,) + else: + assert isinstance(marks, collections.abc.Collection) + + if id is not None: + if not isinstance(id, str): + raise TypeError(f"Expected id to be a string, got {type(id)}: {id!r}") + id = ascii_escaped(id) + return cls(values, marks, id) + + @classmethod + def extract_from( + cls, + parameterset: ParameterSet | Sequence[object] | object, + force_tuple: bool = False, + ) -> ParameterSet: + """Extract from an object or objects. + + :param parameterset: + A legacy style parameterset that may or may not be a tuple, + and may or may not be wrapped into a mess of mark objects. + + :param force_tuple: + Enforce tuple wrapping so single argument tuple values + don't get decomposed and break tests. + """ + if isinstance(parameterset, cls): + return parameterset + if force_tuple: + return cls.param(parameterset) + else: + # TODO: Refactor to fix this type-ignore. Currently the following + # passes type-checking but crashes: + # + # @pytest.mark.parametrize(('x', 'y'), [1, 2]) + # def test_foo(x, y): pass + return cls(parameterset, marks=[], id=None) # type: ignore[arg-type] + + @staticmethod + def _parse_parametrize_args( + argnames: str | Sequence[str], + argvalues: Iterable[ParameterSet | Sequence[object] | object], + *args, + **kwargs, + ) -> tuple[Sequence[str], bool]: + if isinstance(argnames, str): + argnames = [x.strip() for x in argnames.split(",") if x.strip()] + force_tuple = len(argnames) == 1 + else: + force_tuple = False + return argnames, force_tuple + + @staticmethod + def _parse_parametrize_parameters( + argvalues: Iterable[ParameterSet | Sequence[object] | object], + force_tuple: bool, + ) -> list[ParameterSet]: + return [ + ParameterSet.extract_from(x, force_tuple=force_tuple) for x in argvalues + ] + + @classmethod + def _for_parametrize( + cls, + argnames: str | Sequence[str], + argvalues: Iterable[ParameterSet | Sequence[object] | object], + func, + config: Config, + nodeid: str, + ) -> tuple[Sequence[str], list[ParameterSet]]: + argnames, force_tuple = cls._parse_parametrize_args(argnames, argvalues) + parameters = cls._parse_parametrize_parameters(argvalues, force_tuple) + del argvalues + + if parameters: + # Check all parameter sets have the correct number of values. + for param in parameters: + if len(param.values) != len(argnames): + msg = ( + '{nodeid}: in "parametrize" the number of names ({names_len}):\n' + " {names}\n" + "must be equal to the number of values ({values_len}):\n" + " {values}" + ) + fail( + msg.format( + nodeid=nodeid, + values=param.values, + names=argnames, + names_len=len(argnames), + values_len=len(param.values), + ), + pytrace=False, + ) + else: + # Empty parameter set (likely computed at runtime): create a single + # parameter set with NOTSET values, with the "empty parameter set" mark applied to it. + mark = get_empty_parameterset_mark(config, argnames, func) + parameters.append( + ParameterSet(values=(NOTSET,) * len(argnames), marks=[mark], id=None) + ) + return argnames, parameters + + +@final +@dataclasses.dataclass(frozen=True) +class Mark: + """A pytest mark.""" + + #: Name of the mark. + name: str + #: Positional arguments of the mark decorator. + args: tuple[Any, ...] + #: Keyword arguments of the mark decorator. + kwargs: Mapping[str, Any] + + #: Source Mark for ids with parametrize Marks. + _param_ids_from: Mark | None = dataclasses.field(default=None, repr=False) + #: Resolved/generated ids with parametrize Marks. + _param_ids_generated: Sequence[str] | None = dataclasses.field( + default=None, repr=False + ) + + def __init__( + self, + name: str, + args: tuple[Any, ...], + kwargs: Mapping[str, Any], + param_ids_from: Mark | None = None, + param_ids_generated: Sequence[str] | None = None, + *, + _ispytest: bool = False, + ) -> None: + """:meta private:""" + check_ispytest(_ispytest) + # Weirdness to bypass frozen=True. + object.__setattr__(self, "name", name) + object.__setattr__(self, "args", args) + object.__setattr__(self, "kwargs", kwargs) + object.__setattr__(self, "_param_ids_from", param_ids_from) + object.__setattr__(self, "_param_ids_generated", param_ids_generated) + + def _has_param_ids(self) -> bool: + return "ids" in self.kwargs or len(self.args) >= 4 + + def combined_with(self, other: Mark) -> Mark: + """Return a new Mark which is a combination of this + Mark and another Mark. + + Combines by appending args and merging kwargs. + + :param Mark other: The mark to combine with. + :rtype: Mark + """ + assert self.name == other.name + + # Remember source of ids with parametrize Marks. + param_ids_from: Mark | None = None + if self.name == "parametrize": + if other._has_param_ids(): + param_ids_from = other + elif self._has_param_ids(): + param_ids_from = self + + return Mark( + self.name, + self.args + other.args, + dict(self.kwargs, **other.kwargs), + param_ids_from=param_ids_from, + _ispytest=True, + ) + + +# A generic parameter designating an object to which a Mark may +# be applied -- a test function (callable) or class. +# Note: a lambda is not allowed, but this can't be represented. +Markable = TypeVar("Markable", bound=Union[Callable[..., object], type]) + + +@dataclasses.dataclass +class MarkDecorator: + """A decorator for applying a mark on test functions and classes. + + ``MarkDecorators`` are created with ``pytest.mark``:: + + mark1 = pytest.mark.NAME # Simple MarkDecorator + mark2 = pytest.mark.NAME(name1=value) # Parametrized MarkDecorator + + and can then be applied as decorators to test functions:: + + @mark2 + def test_function(): + pass + + When a ``MarkDecorator`` is called, it does the following: + + 1. If called with a single class as its only positional argument and no + additional keyword arguments, it attaches the mark to the class so it + gets applied automatically to all test cases found in that class. + + 2. If called with a single function as its only positional argument and + no additional keyword arguments, it attaches the mark to the function, + containing all the arguments already stored internally in the + ``MarkDecorator``. + + 3. When called in any other case, it returns a new ``MarkDecorator`` + instance with the original ``MarkDecorator``'s content updated with + the arguments passed to this call. + + Note: The rules above prevent a ``MarkDecorator`` from storing only a + single function or class reference as its positional argument with no + additional keyword or positional arguments. You can work around this by + using `with_args()`. + """ + + mark: Mark + + def __init__(self, mark: Mark, *, _ispytest: bool = False) -> None: + """:meta private:""" + check_ispytest(_ispytest) + self.mark = mark + + @property + def name(self) -> str: + """Alias for mark.name.""" + return self.mark.name + + @property + def args(self) -> tuple[Any, ...]: + """Alias for mark.args.""" + return self.mark.args + + @property + def kwargs(self) -> Mapping[str, Any]: + """Alias for mark.kwargs.""" + return self.mark.kwargs + + @property + def markname(self) -> str: + """:meta private:""" + return self.name # for backward-compat (2.4.1 had this attr) + + def with_args(self, *args: object, **kwargs: object) -> MarkDecorator: + """Return a MarkDecorator with extra arguments added. + + Unlike calling the MarkDecorator, with_args() can be used even + if the sole argument is a callable/class. + """ + mark = Mark(self.name, args, kwargs, _ispytest=True) + return MarkDecorator(self.mark.combined_with(mark), _ispytest=True) + + # Type ignored because the overloads overlap with an incompatible + # return type. Not much we can do about that. Thankfully mypy picks + # the first match so it works out even if we break the rules. + @overload + def __call__(self, arg: Markable) -> Markable: # type: ignore[overload-overlap] + pass + + @overload + def __call__(self, *args: object, **kwargs: object) -> MarkDecorator: + pass + + def __call__(self, *args: object, **kwargs: object): + """Call the MarkDecorator.""" + if args and not kwargs: + func = args[0] + is_class = inspect.isclass(func) + if len(args) == 1 and (istestfunc(func) or is_class): + store_mark(func, self.mark, stacklevel=3) + return func + return self.with_args(*args, **kwargs) + + +def get_unpacked_marks( + obj: object | type, + *, + consider_mro: bool = True, +) -> list[Mark]: + """Obtain the unpacked marks that are stored on an object. + + If obj is a class and consider_mro is true, return marks applied to + this class and all of its super-classes in MRO order. If consider_mro + is false, only return marks applied directly to this class. + """ + if isinstance(obj, type): + if not consider_mro: + mark_lists = [obj.__dict__.get("pytestmark", [])] + else: + mark_lists = [ + x.__dict__.get("pytestmark", []) for x in reversed(obj.__mro__) + ] + mark_list = [] + for item in mark_lists: + if isinstance(item, list): + mark_list.extend(item) + else: + mark_list.append(item) + else: + mark_attribute = getattr(obj, "pytestmark", []) + if isinstance(mark_attribute, list): + mark_list = mark_attribute + else: + mark_list = [mark_attribute] + return list(normalize_mark_list(mark_list)) + + +def normalize_mark_list( + mark_list: Iterable[Mark | MarkDecorator], +) -> Iterable[Mark]: + """ + Normalize an iterable of Mark or MarkDecorator objects into a list of marks + by retrieving the `mark` attribute on MarkDecorator instances. + + :param mark_list: marks to normalize + :returns: A new list of the extracted Mark objects + """ + for mark in mark_list: + mark_obj = getattr(mark, "mark", mark) + if not isinstance(mark_obj, Mark): + raise TypeError(f"got {mark_obj!r} instead of Mark") + yield mark_obj + + +def store_mark(obj, mark: Mark, *, stacklevel: int = 2) -> None: + """Store a Mark on an object. + + This is used to implement the Mark declarations/decorators correctly. + """ + assert isinstance(mark, Mark), mark + + from ..fixtures import getfixturemarker + + if getfixturemarker(obj) is not None: + warnings.warn(MARKED_FIXTURE, stacklevel=stacklevel) + + # Always reassign name to avoid updating pytestmark in a reference that + # was only borrowed. + obj.pytestmark = [*get_unpacked_marks(obj, consider_mro=False), mark] + + +# Typing for builtin pytest marks. This is cheating; it gives builtin marks +# special privilege, and breaks modularity. But practicality beats purity... +if TYPE_CHECKING: + + class _SkipMarkDecorator(MarkDecorator): + @overload # type: ignore[override,no-overload-impl] + def __call__(self, arg: Markable) -> Markable: ... + + @overload + def __call__(self, reason: str = ...) -> MarkDecorator: ... + + class _SkipifMarkDecorator(MarkDecorator): + def __call__( # type: ignore[override] + self, + condition: str | bool = ..., + *conditions: str | bool, + reason: str = ..., + ) -> MarkDecorator: ... + + class _XfailMarkDecorator(MarkDecorator): + @overload # type: ignore[override,no-overload-impl] + def __call__(self, arg: Markable) -> Markable: ... + + @overload + def __call__( + self, + condition: str | bool = False, + *conditions: str | bool, + reason: str = ..., + run: bool = ..., + raises: None | type[BaseException] | tuple[type[BaseException], ...] = ..., + strict: bool = ..., + ) -> MarkDecorator: ... + + class _ParametrizeMarkDecorator(MarkDecorator): + def __call__( # type: ignore[override] + self, + argnames: str | Sequence[str], + argvalues: Iterable[ParameterSet | Sequence[object] | object], + *, + indirect: bool | Sequence[str] = ..., + ids: Iterable[None | str | float | int | bool] + | Callable[[Any], object | None] + | None = ..., + scope: _ScopeName | None = ..., + ) -> MarkDecorator: ... + + class _UsefixturesMarkDecorator(MarkDecorator): + def __call__(self, *fixtures: str) -> MarkDecorator: # type: ignore[override] + ... + + class _FilterwarningsMarkDecorator(MarkDecorator): + def __call__(self, *filters: str) -> MarkDecorator: # type: ignore[override] + ... + + +@final +class MarkGenerator: + """Factory for :class:`MarkDecorator` objects - exposed as + a ``pytest.mark`` singleton instance. + + Example:: + + import pytest + + + @pytest.mark.slowtest + def test_function(): + pass + + applies a 'slowtest' :class:`Mark` on ``test_function``. + """ + + # See TYPE_CHECKING above. + if TYPE_CHECKING: + skip: _SkipMarkDecorator + skipif: _SkipifMarkDecorator + xfail: _XfailMarkDecorator + parametrize: _ParametrizeMarkDecorator + usefixtures: _UsefixturesMarkDecorator + filterwarnings: _FilterwarningsMarkDecorator + + def __init__(self, *, _ispytest: bool = False) -> None: + check_ispytest(_ispytest) + self._config: Config | None = None + self._markers: set[str] = set() + + def __getattr__(self, name: str) -> MarkDecorator: + """Generate a new :class:`MarkDecorator` with the given name.""" + if name[0] == "_": + raise AttributeError("Marker name must NOT start with underscore") + + if self._config is not None: + # We store a set of markers as a performance optimisation - if a mark + # name is in the set we definitely know it, but a mark may be known and + # not in the set. We therefore start by updating the set! + if name not in self._markers: + for line in self._config.getini("markers"): + # example lines: "skipif(condition): skip the given test if..." + # or "hypothesis: tests which use Hypothesis", so to get the + # marker name we split on both `:` and `(`. + marker = line.split(":")[0].split("(")[0].strip() + self._markers.add(marker) + + # If the name is not in the set of known marks after updating, + # then it really is time to issue a warning or an error. + if name not in self._markers: + if self._config.option.strict_markers or self._config.option.strict: + fail( + f"{name!r} not found in `markers` configuration option", + pytrace=False, + ) + + # Raise a specific error for common misspellings of "parametrize". + if name in ["parameterize", "parametrise", "parameterise"]: + __tracebackhide__ = True + fail(f"Unknown '{name}' mark, did you mean 'parametrize'?") + + warnings.warn( + f"Unknown pytest.mark.{name} - is this a typo? You can register " + "custom marks to avoid this warning - for details, see " + "https://docs.pytest.org/en/stable/how-to/mark.html", + PytestUnknownMarkWarning, + 2, + ) + + return MarkDecorator(Mark(name, (), {}, _ispytest=True), _ispytest=True) + + +MARK_GEN = MarkGenerator(_ispytest=True) + + +@final +class NodeKeywords(MutableMapping[str, Any]): + __slots__ = ("node", "parent", "_markers") + + def __init__(self, node: Node) -> None: + self.node = node + self.parent = node.parent + self._markers = {node.name: True} + + def __getitem__(self, key: str) -> Any: + try: + return self._markers[key] + except KeyError: + if self.parent is None: + raise + return self.parent.keywords[key] + + def __setitem__(self, key: str, value: Any) -> None: + self._markers[key] = value + + # Note: we could've avoided explicitly implementing some of the methods + # below and use the collections.abc fallback, but that would be slow. + + def __contains__(self, key: object) -> bool: + return ( + key in self._markers + or self.parent is not None + and key in self.parent.keywords + ) + + def update( # type: ignore[override] + self, + other: Mapping[str, Any] | Iterable[tuple[str, Any]] = (), + **kwds: Any, + ) -> None: + self._markers.update(other) + self._markers.update(kwds) + + def __delitem__(self, key: str) -> None: + raise ValueError("cannot delete key in keywords dict") + + def __iter__(self) -> Iterator[str]: + # Doesn't need to be fast. + yield from self._markers + if self.parent is not None: + for keyword in self.parent.keywords: + # self._marks and self.parent.keywords can have duplicates. + if keyword not in self._markers: + yield keyword + + def __len__(self) -> int: + # Doesn't need to be fast. + return sum(1 for keyword in self) + + def __repr__(self) -> str: + return f"" diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/monkeypatch.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/monkeypatch.py new file mode 100644 index 0000000..46eb172 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/monkeypatch.py @@ -0,0 +1,415 @@ +# mypy: allow-untyped-defs +"""Monkeypatching and mocking functionality.""" + +from __future__ import annotations + +from contextlib import contextmanager +import os +import re +import sys +from typing import Any +from typing import final +from typing import Generator +from typing import Mapping +from typing import MutableMapping +from typing import overload +from typing import TypeVar +import warnings + +from _pytest.fixtures import fixture +from _pytest.warning_types import PytestWarning + + +RE_IMPORT_ERROR_NAME = re.compile(r"^No module named (.*)$") + + +K = TypeVar("K") +V = TypeVar("V") + + +@fixture +def monkeypatch() -> Generator[MonkeyPatch]: + """A convenient fixture for monkey-patching. + + The fixture provides these methods to modify objects, dictionaries, or + :data:`os.environ`: + + * :meth:`monkeypatch.setattr(obj, name, value, raising=True) ` + * :meth:`monkeypatch.delattr(obj, name, raising=True) ` + * :meth:`monkeypatch.setitem(mapping, name, value) ` + * :meth:`monkeypatch.delitem(obj, name, raising=True) ` + * :meth:`monkeypatch.setenv(name, value, prepend=None) ` + * :meth:`monkeypatch.delenv(name, raising=True) ` + * :meth:`monkeypatch.syspath_prepend(path) ` + * :meth:`monkeypatch.chdir(path) ` + * :meth:`monkeypatch.context() ` + + All modifications will be undone after the requesting test function or + fixture has finished. The ``raising`` parameter determines if a :class:`KeyError` + or :class:`AttributeError` will be raised if the set/deletion operation does not have the + specified target. + + To undo modifications done by the fixture in a contained scope, + use :meth:`context() `. + """ + mpatch = MonkeyPatch() + yield mpatch + mpatch.undo() + + +def resolve(name: str) -> object: + # Simplified from zope.dottedname. + parts = name.split(".") + + used = parts.pop(0) + found: object = __import__(used) + for part in parts: + used += "." + part + try: + found = getattr(found, part) + except AttributeError: + pass + else: + continue + # We use explicit un-nesting of the handling block in order + # to avoid nested exceptions. + try: + __import__(used) + except ImportError as ex: + expected = str(ex).split()[-1] + if expected == used: + raise + else: + raise ImportError(f"import error in {used}: {ex}") from ex + found = annotated_getattr(found, part, used) + return found + + +def annotated_getattr(obj: object, name: str, ann: str) -> object: + try: + obj = getattr(obj, name) + except AttributeError as e: + raise AttributeError( + f"{type(obj).__name__!r} object at {ann} has no attribute {name!r}" + ) from e + return obj + + +def derive_importpath(import_path: str, raising: bool) -> tuple[str, object]: + if not isinstance(import_path, str) or "." not in import_path: + raise TypeError(f"must be absolute import path string, not {import_path!r}") + module, attr = import_path.rsplit(".", 1) + target = resolve(module) + if raising: + annotated_getattr(target, attr, ann=module) + return attr, target + + +class Notset: + def __repr__(self) -> str: + return "" + + +notset = Notset() + + +@final +class MonkeyPatch: + """Helper to conveniently monkeypatch attributes/items/environment + variables/syspath. + + Returned by the :fixture:`monkeypatch` fixture. + + .. versionchanged:: 6.2 + Can now also be used directly as `pytest.MonkeyPatch()`, for when + the fixture is not available. In this case, use + :meth:`with MonkeyPatch.context() as mp: ` or remember to call + :meth:`undo` explicitly. + """ + + def __init__(self) -> None: + self._setattr: list[tuple[object, str, object]] = [] + self._setitem: list[tuple[Mapping[Any, Any], object, object]] = [] + self._cwd: str | None = None + self._savesyspath: list[str] | None = None + + @classmethod + @contextmanager + def context(cls) -> Generator[MonkeyPatch]: + """Context manager that returns a new :class:`MonkeyPatch` object + which undoes any patching done inside the ``with`` block upon exit. + + Example: + + .. code-block:: python + + import functools + + + def test_partial(monkeypatch): + with monkeypatch.context() as m: + m.setattr(functools, "partial", 3) + + Useful in situations where it is desired to undo some patches before the test ends, + such as mocking ``stdlib`` functions that might break pytest itself if mocked (for examples + of this see :issue:`3290`). + """ + m = cls() + try: + yield m + finally: + m.undo() + + @overload + def setattr( + self, + target: str, + name: object, + value: Notset = ..., + raising: bool = ..., + ) -> None: ... + + @overload + def setattr( + self, + target: object, + name: str, + value: object, + raising: bool = ..., + ) -> None: ... + + def setattr( + self, + target: str | object, + name: object | str, + value: object = notset, + raising: bool = True, + ) -> None: + """ + Set attribute value on target, memorizing the old value. + + For example: + + .. code-block:: python + + import os + + monkeypatch.setattr(os, "getcwd", lambda: "/") + + The code above replaces the :func:`os.getcwd` function by a ``lambda`` which + always returns ``"/"``. + + For convenience, you can specify a string as ``target`` which + will be interpreted as a dotted import path, with the last part + being the attribute name: + + .. code-block:: python + + monkeypatch.setattr("os.getcwd", lambda: "/") + + Raises :class:`AttributeError` if the attribute does not exist, unless + ``raising`` is set to False. + + **Where to patch** + + ``monkeypatch.setattr`` works by (temporarily) changing the object that a name points to with another one. + There can be many names pointing to any individual object, so for patching to work you must ensure + that you patch the name used by the system under test. + + See the section :ref:`Where to patch ` in the :mod:`unittest.mock` + docs for a complete explanation, which is meant for :func:`unittest.mock.patch` but + applies to ``monkeypatch.setattr`` as well. + """ + __tracebackhide__ = True + import inspect + + if isinstance(value, Notset): + if not isinstance(target, str): + raise TypeError( + "use setattr(target, name, value) or " + "setattr(target, value) with target being a dotted " + "import string" + ) + value = name + name, target = derive_importpath(target, raising) + else: + if not isinstance(name, str): + raise TypeError( + "use setattr(target, name, value) with name being a string or " + "setattr(target, value) with target being a dotted " + "import string" + ) + + oldval = getattr(target, name, notset) + if raising and oldval is notset: + raise AttributeError(f"{target!r} has no attribute {name!r}") + + # avoid class descriptors like staticmethod/classmethod + if inspect.isclass(target): + oldval = target.__dict__.get(name, notset) + self._setattr.append((target, name, oldval)) + setattr(target, name, value) + + def delattr( + self, + target: object | str, + name: str | Notset = notset, + raising: bool = True, + ) -> None: + """Delete attribute ``name`` from ``target``. + + If no ``name`` is specified and ``target`` is a string + it will be interpreted as a dotted import path with the + last part being the attribute name. + + Raises AttributeError it the attribute does not exist, unless + ``raising`` is set to False. + """ + __tracebackhide__ = True + import inspect + + if isinstance(name, Notset): + if not isinstance(target, str): + raise TypeError( + "use delattr(target, name) or " + "delattr(target) with target being a dotted " + "import string" + ) + name, target = derive_importpath(target, raising) + + if not hasattr(target, name): + if raising: + raise AttributeError(name) + else: + oldval = getattr(target, name, notset) + # Avoid class descriptors like staticmethod/classmethod. + if inspect.isclass(target): + oldval = target.__dict__.get(name, notset) + self._setattr.append((target, name, oldval)) + delattr(target, name) + + def setitem(self, dic: Mapping[K, V], name: K, value: V) -> None: + """Set dictionary entry ``name`` to value.""" + self._setitem.append((dic, name, dic.get(name, notset))) + # Not all Mapping types support indexing, but MutableMapping doesn't support TypedDict + dic[name] = value # type: ignore[index] + + def delitem(self, dic: Mapping[K, V], name: K, raising: bool = True) -> None: + """Delete ``name`` from dict. + + Raises ``KeyError`` if it doesn't exist, unless ``raising`` is set to + False. + """ + if name not in dic: + if raising: + raise KeyError(name) + else: + self._setitem.append((dic, name, dic.get(name, notset))) + # Not all Mapping types support indexing, but MutableMapping doesn't support TypedDict + del dic[name] # type: ignore[attr-defined] + + def setenv(self, name: str, value: str, prepend: str | None = None) -> None: + """Set environment variable ``name`` to ``value``. + + If ``prepend`` is a character, read the current environment variable + value and prepend the ``value`` adjoined with the ``prepend`` + character. + """ + if not isinstance(value, str): + warnings.warn( # type: ignore[unreachable] + PytestWarning( + f"Value of environment variable {name} type should be str, but got " + f"{value!r} (type: {type(value).__name__}); converted to str implicitly" + ), + stacklevel=2, + ) + value = str(value) + if prepend and name in os.environ: + value = value + prepend + os.environ[name] + self.setitem(os.environ, name, value) + + def delenv(self, name: str, raising: bool = True) -> None: + """Delete ``name`` from the environment. + + Raises ``KeyError`` if it does not exist, unless ``raising`` is set to + False. + """ + environ: MutableMapping[str, str] = os.environ + self.delitem(environ, name, raising=raising) + + def syspath_prepend(self, path) -> None: + """Prepend ``path`` to ``sys.path`` list of import locations.""" + if self._savesyspath is None: + self._savesyspath = sys.path[:] + sys.path.insert(0, str(path)) + + # https://github.com/pypa/setuptools/blob/d8b901bc/docs/pkg_resources.txt#L162-L171 + # this is only needed when pkg_resources was already loaded by the namespace package + if "pkg_resources" in sys.modules: + from pkg_resources import fixup_namespace_packages + + fixup_namespace_packages(str(path)) + + # A call to syspathinsert() usually means that the caller wants to + # import some dynamically created files, thus with python3 we + # invalidate its import caches. + # This is especially important when any namespace package is in use, + # since then the mtime based FileFinder cache (that gets created in + # this case already) gets not invalidated when writing the new files + # quickly afterwards. + from importlib import invalidate_caches + + invalidate_caches() + + def chdir(self, path: str | os.PathLike[str]) -> None: + """Change the current working directory to the specified path. + + :param path: + The path to change into. + """ + if self._cwd is None: + self._cwd = os.getcwd() + os.chdir(path) + + def undo(self) -> None: + """Undo previous changes. + + This call consumes the undo stack. Calling it a second time has no + effect unless you do more monkeypatching after the undo call. + + There is generally no need to call `undo()`, since it is + called automatically during tear-down. + + .. note:: + The same `monkeypatch` fixture is used across a + single test function invocation. If `monkeypatch` is used both by + the test function itself and one of the test fixtures, + calling `undo()` will undo all of the changes made in + both functions. + + Prefer to use :meth:`context() ` instead. + """ + for obj, name, value in reversed(self._setattr): + if value is not notset: + setattr(obj, name, value) + else: + delattr(obj, name) + self._setattr[:] = [] + for dictionary, key, value in reversed(self._setitem): + if value is notset: + try: + # Not all Mapping types support indexing, but MutableMapping doesn't support TypedDict + del dictionary[key] # type: ignore[attr-defined] + except KeyError: + pass # Was already deleted, so we have the desired state. + else: + # Not all Mapping types support indexing, but MutableMapping doesn't support TypedDict + dictionary[key] = value # type: ignore[index] + self._setitem[:] = [] + if self._savesyspath is not None: + sys.path[:] = self._savesyspath + self._savesyspath = None + + if self._cwd is not None: + os.chdir(self._cwd) + self._cwd = None diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/nodes.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/nodes.py new file mode 100644 index 0000000..51bc517 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/nodes.py @@ -0,0 +1,766 @@ +# mypy: allow-untyped-defs +from __future__ import annotations + +import abc +from functools import cached_property +from inspect import signature +import os +import pathlib +from pathlib import Path +from typing import Any +from typing import Callable +from typing import cast +from typing import Iterable +from typing import Iterator +from typing import MutableMapping +from typing import NoReturn +from typing import overload +from typing import TYPE_CHECKING +from typing import TypeVar +import warnings + +import pluggy + +import _pytest._code +from _pytest._code import getfslineno +from _pytest._code.code import ExceptionInfo +from _pytest._code.code import TerminalRepr +from _pytest._code.code import Traceback +from _pytest._code.code import TracebackStyle +from _pytest.compat import LEGACY_PATH +from _pytest.config import Config +from _pytest.config import ConftestImportFailure +from _pytest.config.compat import _check_path +from _pytest.deprecated import NODE_CTOR_FSPATH_ARG +from _pytest.mark.structures import Mark +from _pytest.mark.structures import MarkDecorator +from _pytest.mark.structures import NodeKeywords +from _pytest.outcomes import fail +from _pytest.pathlib import absolutepath +from _pytest.pathlib import commonpath +from _pytest.stash import Stash +from _pytest.warning_types import PytestWarning + + +if TYPE_CHECKING: + from typing_extensions import Self + + # Imported here due to circular import. + from _pytest.main import Session + + +SEP = "/" + +tracebackcutdir = Path(_pytest.__file__).parent + + +_T = TypeVar("_T") + + +def _imply_path( + node_type: type[Node], + path: Path | None, + fspath: LEGACY_PATH | None, +) -> Path: + if fspath is not None: + warnings.warn( + NODE_CTOR_FSPATH_ARG.format( + node_type_name=node_type.__name__, + ), + stacklevel=6, + ) + if path is not None: + if fspath is not None: + _check_path(path, fspath) + return path + else: + assert fspath is not None + return Path(fspath) + + +_NodeType = TypeVar("_NodeType", bound="Node") + + +class NodeMeta(abc.ABCMeta): + """Metaclass used by :class:`Node` to enforce that direct construction raises + :class:`Failed`. + + This behaviour supports the indirection introduced with :meth:`Node.from_parent`, + the named constructor to be used instead of direct construction. The design + decision to enforce indirection with :class:`NodeMeta` was made as a + temporary aid for refactoring the collection tree, which was diagnosed to + have :class:`Node` objects whose creational patterns were overly entangled. + Once the refactoring is complete, this metaclass can be removed. + + See https://github.com/pytest-dev/pytest/projects/3 for an overview of the + progress on detangling the :class:`Node` classes. + """ + + def __call__(cls, *k, **kw) -> NoReturn: + msg = ( + "Direct construction of {name} has been deprecated, please use {name}.from_parent.\n" + "See " + "https://docs.pytest.org/en/stable/deprecations.html#node-construction-changed-to-node-from-parent" + " for more details." + ).format(name=f"{cls.__module__}.{cls.__name__}") + fail(msg, pytrace=False) + + def _create(cls: type[_T], *k, **kw) -> _T: + try: + return super().__call__(*k, **kw) # type: ignore[no-any-return,misc] + except TypeError: + sig = signature(getattr(cls, "__init__")) + known_kw = {k: v for k, v in kw.items() if k in sig.parameters} + from .warning_types import PytestDeprecationWarning + + warnings.warn( + PytestDeprecationWarning( + f"{cls} is not using a cooperative constructor and only takes {set(known_kw)}.\n" + "See https://docs.pytest.org/en/stable/deprecations.html" + "#constructors-of-custom-pytest-node-subclasses-should-take-kwargs " + "for more details." + ) + ) + + return super().__call__(*k, **known_kw) # type: ignore[no-any-return,misc] + + +class Node(abc.ABC, metaclass=NodeMeta): + r"""Base class of :class:`Collector` and :class:`Item`, the components of + the test collection tree. + + ``Collector``\'s are the internal nodes of the tree, and ``Item``\'s are the + leaf nodes. + """ + + # Implemented in the legacypath plugin. + #: A ``LEGACY_PATH`` copy of the :attr:`path` attribute. Intended for usage + #: for methods not migrated to ``pathlib.Path`` yet, such as + #: :meth:`Item.reportinfo `. Will be deprecated in + #: a future release, prefer using :attr:`path` instead. + fspath: LEGACY_PATH + + # Use __slots__ to make attribute access faster. + # Note that __dict__ is still available. + __slots__ = ( + "name", + "parent", + "config", + "session", + "path", + "_nodeid", + "_store", + "__dict__", + ) + + def __init__( + self, + name: str, + parent: Node | None = None, + config: Config | None = None, + session: Session | None = None, + fspath: LEGACY_PATH | None = None, + path: Path | None = None, + nodeid: str | None = None, + ) -> None: + #: A unique name within the scope of the parent node. + self.name: str = name + + #: The parent collector node. + self.parent = parent + + if config: + #: The pytest config object. + self.config: Config = config + else: + if not parent: + raise TypeError("config or parent must be provided") + self.config = parent.config + + if session: + #: The pytest session this node is part of. + self.session: Session = session + else: + if not parent: + raise TypeError("session or parent must be provided") + self.session = parent.session + + if path is None and fspath is None: + path = getattr(parent, "path", None) + #: Filesystem path where this node was collected from (can be None). + self.path: pathlib.Path = _imply_path(type(self), path, fspath=fspath) + + # The explicit annotation is to avoid publicly exposing NodeKeywords. + #: Keywords/markers collected from all scopes. + self.keywords: MutableMapping[str, Any] = NodeKeywords(self) + + #: The marker objects belonging to this node. + self.own_markers: list[Mark] = [] + + #: Allow adding of extra keywords to use for matching. + self.extra_keyword_matches: set[str] = set() + + if nodeid is not None: + assert "::()" not in nodeid + self._nodeid = nodeid + else: + if not self.parent: + raise TypeError("nodeid or parent must be provided") + self._nodeid = self.parent.nodeid + "::" + self.name + + #: A place where plugins can store information on the node for their + #: own use. + self.stash: Stash = Stash() + # Deprecated alias. Was never public. Can be removed in a few releases. + self._store = self.stash + + @classmethod + def from_parent(cls, parent: Node, **kw) -> Self: + """Public constructor for Nodes. + + This indirection got introduced in order to enable removing + the fragile logic from the node constructors. + + Subclasses can use ``super().from_parent(...)`` when overriding the + construction. + + :param parent: The parent node of this Node. + """ + if "config" in kw: + raise TypeError("config is not a valid argument for from_parent") + if "session" in kw: + raise TypeError("session is not a valid argument for from_parent") + return cls._create(parent=parent, **kw) + + @property + def ihook(self) -> pluggy.HookRelay: + """fspath-sensitive hook proxy used to call pytest hooks.""" + return self.session.gethookproxy(self.path) + + def __repr__(self) -> str: + return "<{} {}>".format(self.__class__.__name__, getattr(self, "name", None)) + + def warn(self, warning: Warning) -> None: + """Issue a warning for this Node. + + Warnings will be displayed after the test session, unless explicitly suppressed. + + :param Warning warning: + The warning instance to issue. + + :raises ValueError: If ``warning`` instance is not a subclass of Warning. + + Example usage: + + .. code-block:: python + + node.warn(PytestWarning("some message")) + node.warn(UserWarning("some message")) + + .. versionchanged:: 6.2 + Any subclass of :class:`Warning` is now accepted, rather than only + :class:`PytestWarning ` subclasses. + """ + # enforce type checks here to avoid getting a generic type error later otherwise. + if not isinstance(warning, Warning): + raise ValueError( + f"warning must be an instance of Warning or subclass, got {warning!r}" + ) + path, lineno = get_fslocation_from_item(self) + assert lineno is not None + warnings.warn_explicit( + warning, + category=None, + filename=str(path), + lineno=lineno + 1, + ) + + # Methods for ordering nodes. + + @property + def nodeid(self) -> str: + """A ::-separated string denoting its collection tree address.""" + return self._nodeid + + def __hash__(self) -> int: + return hash(self._nodeid) + + def setup(self) -> None: + pass + + def teardown(self) -> None: + pass + + def iter_parents(self) -> Iterator[Node]: + """Iterate over all parent collectors starting from and including self + up to the root of the collection tree. + + .. versionadded:: 8.1 + """ + parent: Node | None = self + while parent is not None: + yield parent + parent = parent.parent + + def listchain(self) -> list[Node]: + """Return a list of all parent collectors starting from the root of the + collection tree down to and including self.""" + chain = [] + item: Node | None = self + while item is not None: + chain.append(item) + item = item.parent + chain.reverse() + return chain + + def add_marker(self, marker: str | MarkDecorator, append: bool = True) -> None: + """Dynamically add a marker object to the node. + + :param marker: + The marker. + :param append: + Whether to append the marker, or prepend it. + """ + from _pytest.mark import MARK_GEN + + if isinstance(marker, MarkDecorator): + marker_ = marker + elif isinstance(marker, str): + marker_ = getattr(MARK_GEN, marker) + else: + raise ValueError("is not a string or pytest.mark.* Marker") + self.keywords[marker_.name] = marker_ + if append: + self.own_markers.append(marker_.mark) + else: + self.own_markers.insert(0, marker_.mark) + + def iter_markers(self, name: str | None = None) -> Iterator[Mark]: + """Iterate over all markers of the node. + + :param name: If given, filter the results by the name attribute. + :returns: An iterator of the markers of the node. + """ + return (x[1] for x in self.iter_markers_with_node(name=name)) + + def iter_markers_with_node( + self, name: str | None = None + ) -> Iterator[tuple[Node, Mark]]: + """Iterate over all markers of the node. + + :param name: If given, filter the results by the name attribute. + :returns: An iterator of (node, mark) tuples. + """ + for node in self.iter_parents(): + for mark in node.own_markers: + if name is None or getattr(mark, "name", None) == name: + yield node, mark + + @overload + def get_closest_marker(self, name: str) -> Mark | None: ... + + @overload + def get_closest_marker(self, name: str, default: Mark) -> Mark: ... + + def get_closest_marker(self, name: str, default: Mark | None = None) -> Mark | None: + """Return the first marker matching the name, from closest (for + example function) to farther level (for example module level). + + :param default: Fallback return value if no marker was found. + :param name: Name to filter by. + """ + return next(self.iter_markers(name=name), default) + + def listextrakeywords(self) -> set[str]: + """Return a set of all extra keywords in self and any parents.""" + extra_keywords: set[str] = set() + for item in self.listchain(): + extra_keywords.update(item.extra_keyword_matches) + return extra_keywords + + def listnames(self) -> list[str]: + return [x.name for x in self.listchain()] + + def addfinalizer(self, fin: Callable[[], object]) -> None: + """Register a function to be called without arguments when this node is + finalized. + + This method can only be called when this node is active + in a setup chain, for example during self.setup(). + """ + self.session._setupstate.addfinalizer(fin, self) + + def getparent(self, cls: type[_NodeType]) -> _NodeType | None: + """Get the closest parent node (including self) which is an instance of + the given class. + + :param cls: The node class to search for. + :returns: The node, if found. + """ + for node in self.iter_parents(): + if isinstance(node, cls): + return node + return None + + def _traceback_filter(self, excinfo: ExceptionInfo[BaseException]) -> Traceback: + return excinfo.traceback + + def _repr_failure_py( + self, + excinfo: ExceptionInfo[BaseException], + style: TracebackStyle | None = None, + ) -> TerminalRepr: + from _pytest.fixtures import FixtureLookupError + + if isinstance(excinfo.value, ConftestImportFailure): + excinfo = ExceptionInfo.from_exception(excinfo.value.cause) + if isinstance(excinfo.value, fail.Exception): + if not excinfo.value.pytrace: + style = "value" + if isinstance(excinfo.value, FixtureLookupError): + return excinfo.value.formatrepr() + + tbfilter: bool | Callable[[ExceptionInfo[BaseException]], Traceback] + if self.config.getoption("fulltrace", False): + style = "long" + tbfilter = False + else: + tbfilter = self._traceback_filter + if style == "auto": + style = "long" + # XXX should excinfo.getrepr record all data and toterminal() process it? + if style is None: + if self.config.getoption("tbstyle", "auto") == "short": + style = "short" + else: + style = "long" + + if self.config.get_verbosity() > 1: + truncate_locals = False + else: + truncate_locals = True + + truncate_args = False if self.config.get_verbosity() > 2 else True + + # excinfo.getrepr() formats paths relative to the CWD if `abspath` is False. + # It is possible for a fixture/test to change the CWD while this code runs, which + # would then result in the user seeing confusing paths in the failure message. + # To fix this, if the CWD changed, always display the full absolute path. + # It will be better to just always display paths relative to invocation_dir, but + # this requires a lot of plumbing (#6428). + try: + abspath = Path(os.getcwd()) != self.config.invocation_params.dir + except OSError: + abspath = True + + return excinfo.getrepr( + funcargs=True, + abspath=abspath, + showlocals=self.config.getoption("showlocals", False), + style=style, + tbfilter=tbfilter, + truncate_locals=truncate_locals, + truncate_args=truncate_args, + ) + + def repr_failure( + self, + excinfo: ExceptionInfo[BaseException], + style: TracebackStyle | None = None, + ) -> str | TerminalRepr: + """Return a representation of a collection or test failure. + + .. seealso:: :ref:`non-python tests` + + :param excinfo: Exception information for the failure. + """ + return self._repr_failure_py(excinfo, style) + + +def get_fslocation_from_item(node: Node) -> tuple[str | Path, int | None]: + """Try to extract the actual location from a node, depending on available attributes: + + * "location": a pair (path, lineno) + * "obj": a Python object that the node wraps. + * "path": just a path + + :rtype: A tuple of (str|Path, int) with filename and 0-based line number. + """ + # See Item.location. + location: tuple[str, int | None, str] | None = getattr(node, "location", None) + if location is not None: + return location[:2] + obj = getattr(node, "obj", None) + if obj is not None: + return getfslineno(obj) + return getattr(node, "path", "unknown location"), -1 + + +class Collector(Node, abc.ABC): + """Base class of all collectors. + + Collector create children through `collect()` and thus iteratively build + the collection tree. + """ + + class CollectError(Exception): + """An error during collection, contains a custom message.""" + + @abc.abstractmethod + def collect(self) -> Iterable[Item | Collector]: + """Collect children (items and collectors) for this collector.""" + raise NotImplementedError("abstract") + + # TODO: This omits the style= parameter which breaks Liskov Substitution. + def repr_failure( # type: ignore[override] + self, excinfo: ExceptionInfo[BaseException] + ) -> str | TerminalRepr: + """Return a representation of a collection failure. + + :param excinfo: Exception information for the failure. + """ + if isinstance(excinfo.value, self.CollectError) and not self.config.getoption( + "fulltrace", False + ): + exc = excinfo.value + return str(exc.args[0]) + + # Respect explicit tbstyle option, but default to "short" + # (_repr_failure_py uses "long" with "fulltrace" option always). + tbstyle = self.config.getoption("tbstyle", "auto") + if tbstyle == "auto": + tbstyle = "short" + + return self._repr_failure_py(excinfo, style=tbstyle) + + def _traceback_filter(self, excinfo: ExceptionInfo[BaseException]) -> Traceback: + if hasattr(self, "path"): + traceback = excinfo.traceback + ntraceback = traceback.cut(path=self.path) + if ntraceback == traceback: + ntraceback = ntraceback.cut(excludepath=tracebackcutdir) + return ntraceback.filter(excinfo) + return excinfo.traceback + + +def _check_initialpaths_for_relpath(session: Session, path: Path) -> str | None: + for initial_path in session._initialpaths: + if commonpath(path, initial_path) == initial_path: + rel = str(path.relative_to(initial_path)) + return "" if rel == "." else rel + return None + + +class FSCollector(Collector, abc.ABC): + """Base class for filesystem collectors.""" + + def __init__( + self, + fspath: LEGACY_PATH | None = None, + path_or_parent: Path | Node | None = None, + path: Path | None = None, + name: str | None = None, + parent: Node | None = None, + config: Config | None = None, + session: Session | None = None, + nodeid: str | None = None, + ) -> None: + if path_or_parent: + if isinstance(path_or_parent, Node): + assert parent is None + parent = cast(FSCollector, path_or_parent) + elif isinstance(path_or_parent, Path): + assert path is None + path = path_or_parent + + path = _imply_path(type(self), path, fspath=fspath) + if name is None: + name = path.name + if parent is not None and parent.path != path: + try: + rel = path.relative_to(parent.path) + except ValueError: + pass + else: + name = str(rel) + name = name.replace(os.sep, SEP) + self.path = path + + if session is None: + assert parent is not None + session = parent.session + + if nodeid is None: + try: + nodeid = str(self.path.relative_to(session.config.rootpath)) + except ValueError: + nodeid = _check_initialpaths_for_relpath(session, path) + + if nodeid and os.sep != SEP: + nodeid = nodeid.replace(os.sep, SEP) + + super().__init__( + name=name, + parent=parent, + config=config, + session=session, + nodeid=nodeid, + path=path, + ) + + @classmethod + def from_parent( + cls, + parent, + *, + fspath: LEGACY_PATH | None = None, + path: Path | None = None, + **kw, + ) -> Self: + """The public constructor.""" + return super().from_parent(parent=parent, fspath=fspath, path=path, **kw) + + +class File(FSCollector, abc.ABC): + """Base class for collecting tests from a file. + + :ref:`non-python tests`. + """ + + +class Directory(FSCollector, abc.ABC): + """Base class for collecting files from a directory. + + A basic directory collector does the following: goes over the files and + sub-directories in the directory and creates collectors for them by calling + the hooks :hook:`pytest_collect_directory` and :hook:`pytest_collect_file`, + after checking that they are not ignored using + :hook:`pytest_ignore_collect`. + + The default directory collectors are :class:`~pytest.Dir` and + :class:`~pytest.Package`. + + .. versionadded:: 8.0 + + :ref:`custom directory collectors`. + """ + + +class Item(Node, abc.ABC): + """Base class of all test invocation items. + + Note that for a single function there might be multiple test invocation items. + """ + + nextitem = None + + def __init__( + self, + name, + parent=None, + config: Config | None = None, + session: Session | None = None, + nodeid: str | None = None, + **kw, + ) -> None: + # The first two arguments are intentionally passed positionally, + # to keep plugins who define a node type which inherits from + # (pytest.Item, pytest.File) working (see issue #8435). + # They can be made kwargs when the deprecation above is done. + super().__init__( + name, + parent, + config=config, + session=session, + nodeid=nodeid, + **kw, + ) + self._report_sections: list[tuple[str, str, str]] = [] + + #: A list of tuples (name, value) that holds user defined properties + #: for this test. + self.user_properties: list[tuple[str, object]] = [] + + self._check_item_and_collector_diamond_inheritance() + + def _check_item_and_collector_diamond_inheritance(self) -> None: + """ + Check if the current type inherits from both File and Collector + at the same time, emitting a warning accordingly (#8447). + """ + cls = type(self) + + # We inject an attribute in the type to avoid issuing this warning + # for the same class more than once, which is not helpful. + # It is a hack, but was deemed acceptable in order to avoid + # flooding the user in the common case. + attr_name = "_pytest_diamond_inheritance_warning_shown" + if getattr(cls, attr_name, False): + return + setattr(cls, attr_name, True) + + problems = ", ".join( + base.__name__ for base in cls.__bases__ if issubclass(base, Collector) + ) + if problems: + warnings.warn( + f"{cls.__name__} is an Item subclass and should not be a collector, " + f"however its bases {problems} are collectors.\n" + "Please split the Collectors and the Item into separate node types.\n" + "Pytest Doc example: https://docs.pytest.org/en/latest/example/nonpython.html\n" + "example pull request on a plugin: https://github.com/asmeurer/pytest-flakes/pull/40/", + PytestWarning, + ) + + @abc.abstractmethod + def runtest(self) -> None: + """Run the test case for this item. + + Must be implemented by subclasses. + + .. seealso:: :ref:`non-python tests` + """ + raise NotImplementedError("runtest must be implemented by Item subclass") + + def add_report_section(self, when: str, key: str, content: str) -> None: + """Add a new report section, similar to what's done internally to add + stdout and stderr captured output:: + + item.add_report_section("call", "stdout", "report section contents") + + :param str when: + One of the possible capture states, ``"setup"``, ``"call"``, ``"teardown"``. + :param str key: + Name of the section, can be customized at will. Pytest uses ``"stdout"`` and + ``"stderr"`` internally. + :param str content: + The full contents as a string. + """ + if content: + self._report_sections.append((when, key, content)) + + def reportinfo(self) -> tuple[os.PathLike[str] | str, int | None, str]: + """Get location information for this item for test reports. + + Returns a tuple with three elements: + + - The path of the test (default ``self.path``) + - The 0-based line number of the test (default ``None``) + - A name of the test to be shown (default ``""``) + + .. seealso:: :ref:`non-python tests` + """ + return self.path, None, "" + + @cached_property + def location(self) -> tuple[str, int | None, str]: + """ + Returns a tuple of ``(relfspath, lineno, testname)`` for this item + where ``relfspath`` is file path relative to ``config.rootpath`` + and lineno is a 0-based line number. + """ + location = self.reportinfo() + path = absolutepath(location[0]) + relfspath = self.session._node_location_to_relpath(path) + assert type(location[2]) is str + return (relfspath, location[1], location[2]) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/outcomes.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/outcomes.py new file mode 100644 index 0000000..5b20803 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/outcomes.py @@ -0,0 +1,318 @@ +"""Exception classes and constants handling test outcomes as well as +functions creating them.""" + +from __future__ import annotations + +import sys +from typing import Any +from typing import Callable +from typing import cast +from typing import NoReturn +from typing import Protocol +from typing import Type +from typing import TypeVar + +from .warning_types import PytestDeprecationWarning + + +class OutcomeException(BaseException): + """OutcomeException and its subclass instances indicate and contain info + about test and collection outcomes.""" + + def __init__(self, msg: str | None = None, pytrace: bool = True) -> None: + if msg is not None and not isinstance(msg, str): + error_msg = ( # type: ignore[unreachable] + "{} expected string as 'msg' parameter, got '{}' instead.\n" + "Perhaps you meant to use a mark?" + ) + raise TypeError(error_msg.format(type(self).__name__, type(msg).__name__)) + super().__init__(msg) + self.msg = msg + self.pytrace = pytrace + + def __repr__(self) -> str: + if self.msg is not None: + return self.msg + return f"<{self.__class__.__name__} instance>" + + __str__ = __repr__ + + +TEST_OUTCOME = (OutcomeException, Exception) + + +class Skipped(OutcomeException): + # XXX hackish: on 3k we fake to live in the builtins + # in order to have Skipped exception printing shorter/nicer + __module__ = "builtins" + + def __init__( + self, + msg: str | None = None, + pytrace: bool = True, + allow_module_level: bool = False, + *, + _use_item_location: bool = False, + ) -> None: + super().__init__(msg=msg, pytrace=pytrace) + self.allow_module_level = allow_module_level + # If true, the skip location is reported as the item's location, + # instead of the place that raises the exception/calls skip(). + self._use_item_location = _use_item_location + + +class Failed(OutcomeException): + """Raised from an explicit call to pytest.fail().""" + + __module__ = "builtins" + + +class Exit(Exception): + """Raised for immediate program exits (no tracebacks/summaries).""" + + def __init__( + self, msg: str = "unknown reason", returncode: int | None = None + ) -> None: + self.msg = msg + self.returncode = returncode + super().__init__(msg) + + +# Elaborate hack to work around https://github.com/python/mypy/issues/2087. +# Ideally would just be `exit.Exception = Exit` etc. + +_F = TypeVar("_F", bound=Callable[..., object]) +_ET = TypeVar("_ET", bound=Type[BaseException]) + + +class _WithException(Protocol[_F, _ET]): + Exception: _ET + __call__: _F + + +def _with_exception(exception_type: _ET) -> Callable[[_F], _WithException[_F, _ET]]: + def decorate(func: _F) -> _WithException[_F, _ET]: + func_with_exception = cast(_WithException[_F, _ET], func) + func_with_exception.Exception = exception_type + return func_with_exception + + return decorate + + +# Exposed helper methods. + + +@_with_exception(Exit) +def exit( + reason: str = "", + returncode: int | None = None, +) -> NoReturn: + """Exit testing process. + + :param reason: + The message to show as the reason for exiting pytest. reason has a default value + only because `msg` is deprecated. + + :param returncode: + Return code to be used when exiting pytest. None means the same as ``0`` (no error), same as :func:`sys.exit`. + + :raises pytest.exit.Exception: + The exception that is raised. + """ + __tracebackhide__ = True + raise Exit(reason, returncode) + + +@_with_exception(Skipped) +def skip( + reason: str = "", + *, + allow_module_level: bool = False, +) -> NoReturn: + """Skip an executing test with the given message. + + This function should be called only during testing (setup, call or teardown) or + during collection by using the ``allow_module_level`` flag. This function can + be called in doctests as well. + + :param reason: + The message to show the user as reason for the skip. + + :param allow_module_level: + Allows this function to be called at module level. + Raising the skip exception at module level will stop + the execution of the module and prevent the collection of all tests in the module, + even those defined before the `skip` call. + + Defaults to False. + + :raises pytest.skip.Exception: + The exception that is raised. + + .. note:: + It is better to use the :ref:`pytest.mark.skipif ref` marker when + possible to declare a test to be skipped under certain conditions + like mismatching platforms or dependencies. + Similarly, use the ``# doctest: +SKIP`` directive (see :py:data:`doctest.SKIP`) + to skip a doctest statically. + """ + __tracebackhide__ = True + raise Skipped(msg=reason, allow_module_level=allow_module_level) + + +@_with_exception(Failed) +def fail(reason: str = "", pytrace: bool = True) -> NoReturn: + """Explicitly fail an executing test with the given message. + + :param reason: + The message to show the user as reason for the failure. + + :param pytrace: + If False, msg represents the full failure information and no + python traceback will be reported. + + :raises pytest.fail.Exception: + The exception that is raised. + """ + __tracebackhide__ = True + raise Failed(msg=reason, pytrace=pytrace) + + +class XFailed(Failed): + """Raised from an explicit call to pytest.xfail().""" + + +@_with_exception(XFailed) +def xfail(reason: str = "") -> NoReturn: + """Imperatively xfail an executing test or setup function with the given reason. + + This function should be called only during testing (setup, call or teardown). + + No other code is executed after using ``xfail()`` (it is implemented + internally by raising an exception). + + :param reason: + The message to show the user as reason for the xfail. + + .. note:: + It is better to use the :ref:`pytest.mark.xfail ref` marker when + possible to declare a test to be xfailed under certain conditions + like known bugs or missing features. + + :raises pytest.xfail.Exception: + The exception that is raised. + """ + __tracebackhide__ = True + raise XFailed(reason) + + +def importorskip( + modname: str, + minversion: str | None = None, + reason: str | None = None, + *, + exc_type: type[ImportError] | None = None, +) -> Any: + """Import and return the requested module ``modname``, or skip the + current test if the module cannot be imported. + + :param modname: + The name of the module to import. + :param minversion: + If given, the imported module's ``__version__`` attribute must be at + least this minimal version, otherwise the test is still skipped. + :param reason: + If given, this reason is shown as the message when the module cannot + be imported. + :param exc_type: + The exception that should be captured in order to skip modules. + Must be :py:class:`ImportError` or a subclass. + + If the module can be imported but raises :class:`ImportError`, pytest will + issue a warning to the user, as often users expect the module not to be + found (which would raise :class:`ModuleNotFoundError` instead). + + This warning can be suppressed by passing ``exc_type=ImportError`` explicitly. + + See :ref:`import-or-skip-import-error` for details. + + + :returns: + The imported module. This should be assigned to its canonical name. + + :raises pytest.skip.Exception: + If the module cannot be imported. + + Example:: + + docutils = pytest.importorskip("docutils") + + .. versionadded:: 8.2 + + The ``exc_type`` parameter. + """ + import warnings + + __tracebackhide__ = True + compile(modname, "", "eval") # to catch syntaxerrors + + # Until pytest 9.1, we will warn the user if we catch ImportError (instead of ModuleNotFoundError), + # as this might be hiding an installation/environment problem, which is not usually what is intended + # when using importorskip() (#11523). + # In 9.1, to keep the function signature compatible, we just change the code below to: + # 1. Use `exc_type = ModuleNotFoundError` if `exc_type` is not given. + # 2. Remove `warn_on_import` and the warning handling. + if exc_type is None: + exc_type = ImportError + warn_on_import_error = True + else: + warn_on_import_error = False + + skipped: Skipped | None = None + warning: Warning | None = None + + with warnings.catch_warnings(): + # Make sure to ignore ImportWarnings that might happen because + # of existing directories with the same name we're trying to + # import but without a __init__.py file. + warnings.simplefilter("ignore") + + try: + __import__(modname) + except exc_type as exc: + # Do not raise or issue warnings inside the catch_warnings() block. + if reason is None: + reason = f"could not import {modname!r}: {exc}" + skipped = Skipped(reason, allow_module_level=True) + + if warn_on_import_error and not isinstance(exc, ModuleNotFoundError): + lines = [ + "", + f"Module '{modname}' was found, but when imported by pytest it raised:", + f" {exc!r}", + "In pytest 9.1 this warning will become an error by default.", + "You can fix the underlying problem, or alternatively overwrite this behavior and silence this " + "warning by passing exc_type=ImportError explicitly.", + "See https://docs.pytest.org/en/stable/deprecations.html#pytest-importorskip-default-behavior-regarding-importerror", + ] + warning = PytestDeprecationWarning("\n".join(lines)) + + if warning: + warnings.warn(warning, stacklevel=2) + if skipped: + raise skipped + + mod = sys.modules[modname] + if minversion is None: + return mod + verattr = getattr(mod, "__version__", None) + if minversion is not None: + # Imported lazily to improve start-up time. + from packaging.version import Version + + if verattr is None or Version(verattr) < Version(minversion): + raise Skipped( + f"module {modname!r} has __version__ {verattr!r}, required is: {minversion!r}", + allow_module_level=True, + ) + return mod diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/pastebin.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/pastebin.py new file mode 100644 index 0000000..69c011e --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/pastebin.py @@ -0,0 +1,113 @@ +# mypy: allow-untyped-defs +"""Submit failure or test session information to a pastebin service.""" + +from __future__ import annotations + +from io import StringIO +import tempfile +from typing import IO + +from _pytest.config import Config +from _pytest.config import create_terminal_writer +from _pytest.config.argparsing import Parser +from _pytest.stash import StashKey +from _pytest.terminal import TerminalReporter +import pytest + + +pastebinfile_key = StashKey[IO[bytes]]() + + +def pytest_addoption(parser: Parser) -> None: + group = parser.getgroup("terminal reporting") + group._addoption( + "--pastebin", + metavar="mode", + action="store", + dest="pastebin", + default=None, + choices=["failed", "all"], + help="Send failed|all info to bpaste.net pastebin service", + ) + + +@pytest.hookimpl(trylast=True) +def pytest_configure(config: Config) -> None: + if config.option.pastebin == "all": + tr = config.pluginmanager.getplugin("terminalreporter") + # If no terminal reporter plugin is present, nothing we can do here; + # this can happen when this function executes in a worker node + # when using pytest-xdist, for example. + if tr is not None: + # pastebin file will be UTF-8 encoded binary file. + config.stash[pastebinfile_key] = tempfile.TemporaryFile("w+b") + oldwrite = tr._tw.write + + def tee_write(s, **kwargs): + oldwrite(s, **kwargs) + if isinstance(s, str): + s = s.encode("utf-8") + config.stash[pastebinfile_key].write(s) + + tr._tw.write = tee_write + + +def pytest_unconfigure(config: Config) -> None: + if pastebinfile_key in config.stash: + pastebinfile = config.stash[pastebinfile_key] + # Get terminal contents and delete file. + pastebinfile.seek(0) + sessionlog = pastebinfile.read() + pastebinfile.close() + del config.stash[pastebinfile_key] + # Undo our patching in the terminal reporter. + tr = config.pluginmanager.getplugin("terminalreporter") + del tr._tw.__dict__["write"] + # Write summary. + tr.write_sep("=", "Sending information to Paste Service") + pastebinurl = create_new_paste(sessionlog) + tr.write_line(f"pastebin session-log: {pastebinurl}\n") + + +def create_new_paste(contents: str | bytes) -> str: + """Create a new paste using the bpaste.net service. + + :contents: Paste contents string. + :returns: URL to the pasted contents, or an error message. + """ + import re + from urllib.parse import urlencode + from urllib.request import urlopen + + params = {"code": contents, "lexer": "text", "expiry": "1week"} + url = "https://bpa.st" + try: + response: str = ( + urlopen(url, data=urlencode(params).encode("ascii")).read().decode("utf-8") + ) + except OSError as exc_info: # urllib errors + return f"bad response: {exc_info}" + m = re.search(r'href="/raw/(\w+)"', response) + if m: + return f"{url}/show/{m.group(1)}" + else: + return "bad response: invalid format ('" + response + "')" + + +def pytest_terminal_summary(terminalreporter: TerminalReporter) -> None: + if terminalreporter.config.option.pastebin != "failed": + return + if "failed" in terminalreporter.stats: + terminalreporter.write_sep("=", "Sending information to Paste Service") + for rep in terminalreporter.stats["failed"]: + try: + msg = rep.longrepr.reprtraceback.reprentries[-1].reprfileloc + except AttributeError: + msg = terminalreporter._getfailureheadline(rep) + file = StringIO() + tw = create_terminal_writer(terminalreporter.config, file) + rep.toterminal(tw) + s = file.getvalue() + assert len(s) + pastebinurl = create_new_paste(s) + terminalreporter.write_line(f"{msg} --> {pastebinurl}") diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/pathlib.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/pathlib.py new file mode 100644 index 0000000..81e52ea --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/pathlib.py @@ -0,0 +1,975 @@ +from __future__ import annotations + +import atexit +import contextlib +from enum import Enum +from errno import EBADF +from errno import ELOOP +from errno import ENOENT +from errno import ENOTDIR +import fnmatch +from functools import partial +from importlib.machinery import ModuleSpec +import importlib.util +import itertools +import os +from os.path import expanduser +from os.path import expandvars +from os.path import isabs +from os.path import sep +from pathlib import Path +from pathlib import PurePath +from posixpath import sep as posix_sep +import shutil +import sys +import types +from types import ModuleType +from typing import Any +from typing import Callable +from typing import Iterable +from typing import Iterator +from typing import TypeVar +import uuid +import warnings + +from _pytest.compat import assert_never +from _pytest.outcomes import skip +from _pytest.warning_types import PytestWarning + + +LOCK_TIMEOUT = 60 * 60 * 24 * 3 + + +_AnyPurePath = TypeVar("_AnyPurePath", bound=PurePath) + +# The following function, variables and comments were +# copied from cpython 3.9 Lib/pathlib.py file. + +# EBADF - guard against macOS `stat` throwing EBADF +_IGNORED_ERRORS = (ENOENT, ENOTDIR, EBADF, ELOOP) + +_IGNORED_WINERRORS = ( + 21, # ERROR_NOT_READY - drive exists but is not accessible + 1921, # ERROR_CANT_RESOLVE_FILENAME - fix for broken symlink pointing to itself +) + + +def _ignore_error(exception: Exception) -> bool: + return ( + getattr(exception, "errno", None) in _IGNORED_ERRORS + or getattr(exception, "winerror", None) in _IGNORED_WINERRORS + ) + + +def get_lock_path(path: _AnyPurePath) -> _AnyPurePath: + return path.joinpath(".lock") + + +def on_rm_rf_error( + func: Callable[..., Any] | None, + path: str, + excinfo: BaseException + | tuple[type[BaseException], BaseException, types.TracebackType | None], + *, + start_path: Path, +) -> bool: + """Handle known read-only errors during rmtree. + + The returned value is used only by our own tests. + """ + if isinstance(excinfo, BaseException): + exc = excinfo + else: + exc = excinfo[1] + + # Another process removed the file in the middle of the "rm_rf" (xdist for example). + # More context: https://github.com/pytest-dev/pytest/issues/5974#issuecomment-543799018 + if isinstance(exc, FileNotFoundError): + return False + + if not isinstance(exc, PermissionError): + warnings.warn( + PytestWarning(f"(rm_rf) error removing {path}\n{type(exc)}: {exc}") + ) + return False + + if func not in (os.rmdir, os.remove, os.unlink): + if func not in (os.open,): + warnings.warn( + PytestWarning( + f"(rm_rf) unknown function {func} when removing {path}:\n{type(exc)}: {exc}" + ) + ) + return False + + # Chmod + retry. + import stat + + def chmod_rw(p: str) -> None: + mode = os.stat(p).st_mode + os.chmod(p, mode | stat.S_IRUSR | stat.S_IWUSR) + + # For files, we need to recursively go upwards in the directories to + # ensure they all are also writable. + p = Path(path) + if p.is_file(): + for parent in p.parents: + chmod_rw(str(parent)) + # Stop when we reach the original path passed to rm_rf. + if parent == start_path: + break + chmod_rw(str(path)) + + func(path) + return True + + +def ensure_extended_length_path(path: Path) -> Path: + """Get the extended-length version of a path (Windows). + + On Windows, by default, the maximum length of a path (MAX_PATH) is 260 + characters, and operations on paths longer than that fail. But it is possible + to overcome this by converting the path to "extended-length" form before + performing the operation: + https://docs.microsoft.com/en-us/windows/win32/fileio/naming-a-file#maximum-path-length-limitation + + On Windows, this function returns the extended-length absolute version of path. + On other platforms it returns path unchanged. + """ + if sys.platform.startswith("win32"): + path = path.resolve() + path = Path(get_extended_length_path_str(str(path))) + return path + + +def get_extended_length_path_str(path: str) -> str: + """Convert a path to a Windows extended length path.""" + long_path_prefix = "\\\\?\\" + unc_long_path_prefix = "\\\\?\\UNC\\" + if path.startswith((long_path_prefix, unc_long_path_prefix)): + return path + # UNC + if path.startswith("\\\\"): + return unc_long_path_prefix + path[2:] + return long_path_prefix + path + + +def rm_rf(path: Path) -> None: + """Remove the path contents recursively, even if some elements + are read-only.""" + path = ensure_extended_length_path(path) + onerror = partial(on_rm_rf_error, start_path=path) + if sys.version_info >= (3, 12): + shutil.rmtree(str(path), onexc=onerror) + else: + shutil.rmtree(str(path), onerror=onerror) + + +def find_prefixed(root: Path, prefix: str) -> Iterator[os.DirEntry[str]]: + """Find all elements in root that begin with the prefix, case-insensitive.""" + l_prefix = prefix.lower() + for x in os.scandir(root): + if x.name.lower().startswith(l_prefix): + yield x + + +def extract_suffixes(iter: Iterable[os.DirEntry[str]], prefix: str) -> Iterator[str]: + """Return the parts of the paths following the prefix. + + :param iter: Iterator over path names. + :param prefix: Expected prefix of the path names. + """ + p_len = len(prefix) + for entry in iter: + yield entry.name[p_len:] + + +def find_suffixes(root: Path, prefix: str) -> Iterator[str]: + """Combine find_prefixes and extract_suffixes.""" + return extract_suffixes(find_prefixed(root, prefix), prefix) + + +def parse_num(maybe_num: str) -> int: + """Parse number path suffixes, returns -1 on error.""" + try: + return int(maybe_num) + except ValueError: + return -1 + + +def _force_symlink(root: Path, target: str | PurePath, link_to: str | Path) -> None: + """Helper to create the current symlink. + + It's full of race conditions that are reasonably OK to ignore + for the context of best effort linking to the latest test run. + + The presumption being that in case of much parallelism + the inaccuracy is going to be acceptable. + """ + current_symlink = root.joinpath(target) + try: + current_symlink.unlink() + except OSError: + pass + try: + current_symlink.symlink_to(link_to) + except Exception: + pass + + +def make_numbered_dir(root: Path, prefix: str, mode: int = 0o700) -> Path: + """Create a directory with an increased number as suffix for the given prefix.""" + for i in range(10): + # try up to 10 times to create the folder + max_existing = max(map(parse_num, find_suffixes(root, prefix)), default=-1) + new_number = max_existing + 1 + new_path = root.joinpath(f"{prefix}{new_number}") + try: + new_path.mkdir(mode=mode) + except Exception: + pass + else: + _force_symlink(root, prefix + "current", new_path) + return new_path + else: + raise OSError( + "could not create numbered dir with prefix " + f"{prefix} in {root} after 10 tries" + ) + + +def create_cleanup_lock(p: Path) -> Path: + """Create a lock to prevent premature folder cleanup.""" + lock_path = get_lock_path(p) + try: + fd = os.open(str(lock_path), os.O_WRONLY | os.O_CREAT | os.O_EXCL, 0o644) + except FileExistsError as e: + raise OSError(f"cannot create lockfile in {p}") from e + else: + pid = os.getpid() + spid = str(pid).encode() + os.write(fd, spid) + os.close(fd) + if not lock_path.is_file(): + raise OSError("lock path got renamed after successful creation") + return lock_path + + +def register_cleanup_lock_removal( + lock_path: Path, register: Any = atexit.register +) -> Any: + """Register a cleanup function for removing a lock, by default on atexit.""" + pid = os.getpid() + + def cleanup_on_exit(lock_path: Path = lock_path, original_pid: int = pid) -> None: + current_pid = os.getpid() + if current_pid != original_pid: + # fork + return + try: + lock_path.unlink() + except OSError: + pass + + return register(cleanup_on_exit) + + +def maybe_delete_a_numbered_dir(path: Path) -> None: + """Remove a numbered directory if its lock can be obtained and it does + not seem to be in use.""" + path = ensure_extended_length_path(path) + lock_path = None + try: + lock_path = create_cleanup_lock(path) + parent = path.parent + + garbage = parent.joinpath(f"garbage-{uuid.uuid4()}") + path.rename(garbage) + rm_rf(garbage) + except OSError: + # known races: + # * other process did a cleanup at the same time + # * deletable folder was found + # * process cwd (Windows) + return + finally: + # If we created the lock, ensure we remove it even if we failed + # to properly remove the numbered dir. + if lock_path is not None: + try: + lock_path.unlink() + except OSError: + pass + + +def ensure_deletable(path: Path, consider_lock_dead_if_created_before: float) -> bool: + """Check if `path` is deletable based on whether the lock file is expired.""" + if path.is_symlink(): + return False + lock = get_lock_path(path) + try: + if not lock.is_file(): + return True + except OSError: + # we might not have access to the lock file at all, in this case assume + # we don't have access to the entire directory (#7491). + return False + try: + lock_time = lock.stat().st_mtime + except Exception: + return False + else: + if lock_time < consider_lock_dead_if_created_before: + # We want to ignore any errors while trying to remove the lock such as: + # - PermissionDenied, like the file permissions have changed since the lock creation; + # - FileNotFoundError, in case another pytest process got here first; + # and any other cause of failure. + with contextlib.suppress(OSError): + lock.unlink() + return True + return False + + +def try_cleanup(path: Path, consider_lock_dead_if_created_before: float) -> None: + """Try to cleanup a folder if we can ensure it's deletable.""" + if ensure_deletable(path, consider_lock_dead_if_created_before): + maybe_delete_a_numbered_dir(path) + + +def cleanup_candidates(root: Path, prefix: str, keep: int) -> Iterator[Path]: + """List candidates for numbered directories to be removed - follows py.path.""" + max_existing = max(map(parse_num, find_suffixes(root, prefix)), default=-1) + max_delete = max_existing - keep + entries = find_prefixed(root, prefix) + entries, entries2 = itertools.tee(entries) + numbers = map(parse_num, extract_suffixes(entries2, prefix)) + for entry, number in zip(entries, numbers): + if number <= max_delete: + yield Path(entry) + + +def cleanup_dead_symlinks(root: Path) -> None: + for left_dir in root.iterdir(): + if left_dir.is_symlink(): + if not left_dir.resolve().exists(): + left_dir.unlink() + + +def cleanup_numbered_dir( + root: Path, prefix: str, keep: int, consider_lock_dead_if_created_before: float +) -> None: + """Cleanup for lock driven numbered directories.""" + if not root.exists(): + return + for path in cleanup_candidates(root, prefix, keep): + try_cleanup(path, consider_lock_dead_if_created_before) + for path in root.glob("garbage-*"): + try_cleanup(path, consider_lock_dead_if_created_before) + + cleanup_dead_symlinks(root) + + +def make_numbered_dir_with_cleanup( + root: Path, + prefix: str, + keep: int, + lock_timeout: float, + mode: int, +) -> Path: + """Create a numbered dir with a cleanup lock and remove old ones.""" + e = None + for i in range(10): + try: + p = make_numbered_dir(root, prefix, mode) + # Only lock the current dir when keep is not 0 + if keep != 0: + lock_path = create_cleanup_lock(p) + register_cleanup_lock_removal(lock_path) + except Exception as exc: + e = exc + else: + consider_lock_dead_if_created_before = p.stat().st_mtime - lock_timeout + # Register a cleanup for program exit + atexit.register( + cleanup_numbered_dir, + root, + prefix, + keep, + consider_lock_dead_if_created_before, + ) + return p + assert e is not None + raise e + + +def resolve_from_str(input: str, rootpath: Path) -> Path: + input = expanduser(input) + input = expandvars(input) + if isabs(input): + return Path(input) + else: + return rootpath.joinpath(input) + + +def fnmatch_ex(pattern: str, path: str | os.PathLike[str]) -> bool: + """A port of FNMatcher from py.path.common which works with PurePath() instances. + + The difference between this algorithm and PurePath.match() is that the + latter matches "**" glob expressions for each part of the path, while + this algorithm uses the whole path instead. + + For example: + "tests/foo/bar/doc/test_foo.py" matches pattern "tests/**/doc/test*.py" + with this algorithm, but not with PurePath.match(). + + This algorithm was ported to keep backward-compatibility with existing + settings which assume paths match according this logic. + + References: + * https://bugs.python.org/issue29249 + * https://bugs.python.org/issue34731 + """ + path = PurePath(path) + iswin32 = sys.platform.startswith("win") + + if iswin32 and sep not in pattern and posix_sep in pattern: + # Running on Windows, the pattern has no Windows path separators, + # and the pattern has one or more Posix path separators. Replace + # the Posix path separators with the Windows path separator. + pattern = pattern.replace(posix_sep, sep) + + if sep not in pattern: + name = path.name + else: + name = str(path) + if path.is_absolute() and not os.path.isabs(pattern): + pattern = f"*{os.sep}{pattern}" + return fnmatch.fnmatch(name, pattern) + + +def parts(s: str) -> set[str]: + parts = s.split(sep) + return {sep.join(parts[: i + 1]) or sep for i in range(len(parts))} + + +def symlink_or_skip( + src: os.PathLike[str] | str, + dst: os.PathLike[str] | str, + **kwargs: Any, +) -> None: + """Make a symlink, or skip the test in case symlinks are not supported.""" + try: + os.symlink(src, dst, **kwargs) + except OSError as e: + skip(f"symlinks not supported: {e}") + + +class ImportMode(Enum): + """Possible values for `mode` parameter of `import_path`.""" + + prepend = "prepend" + append = "append" + importlib = "importlib" + + +class ImportPathMismatchError(ImportError): + """Raised on import_path() if there is a mismatch of __file__'s. + + This can happen when `import_path` is called multiple times with different filenames that has + the same basename but reside in packages + (for example "/tests1/test_foo.py" and "/tests2/test_foo.py"). + """ + + +def import_path( + path: str | os.PathLike[str], + *, + mode: str | ImportMode = ImportMode.prepend, + root: Path, + consider_namespace_packages: bool, +) -> ModuleType: + """ + Import and return a module from the given path, which can be a file (a module) or + a directory (a package). + + :param path: + Path to the file to import. + + :param mode: + Controls the underlying import mechanism that will be used: + + * ImportMode.prepend: the directory containing the module (or package, taking + `__init__.py` files into account) will be put at the *start* of `sys.path` before + being imported with `importlib.import_module`. + + * ImportMode.append: same as `prepend`, but the directory will be appended + to the end of `sys.path`, if not already in `sys.path`. + + * ImportMode.importlib: uses more fine control mechanisms provided by `importlib` + to import the module, which avoids having to muck with `sys.path` at all. It effectively + allows having same-named test modules in different places. + + :param root: + Used as an anchor when mode == ImportMode.importlib to obtain + a unique name for the module being imported so it can safely be stored + into ``sys.modules``. + + :param consider_namespace_packages: + If True, consider namespace packages when resolving module names. + + :raises ImportPathMismatchError: + If after importing the given `path` and the module `__file__` + are different. Only raised in `prepend` and `append` modes. + """ + path = Path(path) + mode = ImportMode(mode) + + if not path.exists(): + raise ImportError(path) + + if mode is ImportMode.importlib: + # Try to import this module using the standard import mechanisms, but + # without touching sys.path. + try: + pkg_root, module_name = resolve_pkg_root_and_module_name( + path, consider_namespace_packages=consider_namespace_packages + ) + except CouldNotResolvePathError: + pass + else: + # If the given module name is already in sys.modules, do not import it again. + with contextlib.suppress(KeyError): + return sys.modules[module_name] + + mod = _import_module_using_spec( + module_name, path, pkg_root, insert_modules=False + ) + if mod is not None: + return mod + + # Could not import the module with the current sys.path, so we fall back + # to importing the file as a single module, not being a part of a package. + module_name = module_name_from_path(path, root) + with contextlib.suppress(KeyError): + return sys.modules[module_name] + + mod = _import_module_using_spec( + module_name, path, path.parent, insert_modules=True + ) + if mod is None: + raise ImportError(f"Can't find module {module_name} at location {path}") + return mod + + try: + pkg_root, module_name = resolve_pkg_root_and_module_name( + path, consider_namespace_packages=consider_namespace_packages + ) + except CouldNotResolvePathError: + pkg_root, module_name = path.parent, path.stem + + # Change sys.path permanently: restoring it at the end of this function would cause surprising + # problems because of delayed imports: for example, a conftest.py file imported by this function + # might have local imports, which would fail at runtime if we restored sys.path. + if mode is ImportMode.append: + if str(pkg_root) not in sys.path: + sys.path.append(str(pkg_root)) + elif mode is ImportMode.prepend: + if str(pkg_root) != sys.path[0]: + sys.path.insert(0, str(pkg_root)) + else: + assert_never(mode) + + importlib.import_module(module_name) + + mod = sys.modules[module_name] + if path.name == "__init__.py": + return mod + + ignore = os.environ.get("PY_IGNORE_IMPORTMISMATCH", "") + if ignore != "1": + module_file = mod.__file__ + if module_file is None: + raise ImportPathMismatchError(module_name, module_file, path) + + if module_file.endswith((".pyc", ".pyo")): + module_file = module_file[:-1] + if module_file.endswith(os.sep + "__init__.py"): + module_file = module_file[: -(len(os.sep + "__init__.py"))] + + try: + is_same = _is_same(str(path), module_file) + except FileNotFoundError: + is_same = False + + if not is_same: + raise ImportPathMismatchError(module_name, module_file, path) + + return mod + + +def _import_module_using_spec( + module_name: str, module_path: Path, module_location: Path, *, insert_modules: bool +) -> ModuleType | None: + """ + Tries to import a module by its canonical name, path to the .py file, and its + parent location. + + :param insert_modules: + If True, will call insert_missing_modules to create empty intermediate modules + for made-up module names (when importing test files not reachable from sys.path). + """ + # Checking with sys.meta_path first in case one of its hooks can import this module, + # such as our own assertion-rewrite hook. + for meta_importer in sys.meta_path: + spec = meta_importer.find_spec( + module_name, [str(module_location), str(module_path)] + ) + if spec_matches_module_path(spec, module_path): + break + else: + spec = importlib.util.spec_from_file_location(module_name, str(module_path)) + + if spec_matches_module_path(spec, module_path): + assert spec is not None + # Attempt to import the parent module, seems is our responsibility: + # https://github.com/python/cpython/blob/73906d5c908c1e0b73c5436faeff7d93698fc074/Lib/importlib/_bootstrap.py#L1308-L1311 + parent_module_name, _, name = module_name.rpartition(".") + parent_module: ModuleType | None = None + if parent_module_name: + parent_module = sys.modules.get(parent_module_name) + if parent_module is None: + # Find the directory of this module's parent. + parent_dir = ( + module_path.parent.parent + if module_path.name == "__init__.py" + else module_path.parent + ) + # Consider the parent module path as its __init__.py file, if it has one. + parent_module_path = ( + parent_dir / "__init__.py" + if (parent_dir / "__init__.py").is_file() + else parent_dir + ) + parent_module = _import_module_using_spec( + parent_module_name, + parent_module_path, + parent_dir, + insert_modules=insert_modules, + ) + + # Find spec and import this module. + mod = importlib.util.module_from_spec(spec) + sys.modules[module_name] = mod + spec.loader.exec_module(mod) # type: ignore[union-attr] + + # Set this module as an attribute of the parent module (#12194). + if parent_module is not None: + setattr(parent_module, name, mod) + + if insert_modules: + insert_missing_modules(sys.modules, module_name) + return mod + + return None + + +def spec_matches_module_path(module_spec: ModuleSpec | None, module_path: Path) -> bool: + """Return true if the given ModuleSpec can be used to import the given module path.""" + if module_spec is None or module_spec.origin is None: + return False + + return Path(module_spec.origin) == module_path + + +# Implement a special _is_same function on Windows which returns True if the two filenames +# compare equal, to circumvent os.path.samefile returning False for mounts in UNC (#7678). +if sys.platform.startswith("win"): + + def _is_same(f1: str, f2: str) -> bool: + return Path(f1) == Path(f2) or os.path.samefile(f1, f2) + +else: + + def _is_same(f1: str, f2: str) -> bool: + return os.path.samefile(f1, f2) + + +def module_name_from_path(path: Path, root: Path) -> str: + """ + Return a dotted module name based on the given path, anchored on root. + + For example: path="projects/src/tests/test_foo.py" and root="/projects", the + resulting module name will be "src.tests.test_foo". + """ + path = path.with_suffix("") + try: + relative_path = path.relative_to(root) + except ValueError: + # If we can't get a relative path to root, use the full path, except + # for the first part ("d:\\" or "/" depending on the platform, for example). + path_parts = path.parts[1:] + else: + # Use the parts for the relative path to the root path. + path_parts = relative_path.parts + + # Module name for packages do not contain the __init__ file, unless + # the `__init__.py` file is at the root. + if len(path_parts) >= 2 and path_parts[-1] == "__init__": + path_parts = path_parts[:-1] + + # Module names cannot contain ".", normalize them to "_". This prevents + # a directory having a "." in the name (".env.310" for example) causing extra intermediate modules. + # Also, important to replace "." at the start of paths, as those are considered relative imports. + path_parts = tuple(x.replace(".", "_") for x in path_parts) + + return ".".join(path_parts) + + +def insert_missing_modules(modules: dict[str, ModuleType], module_name: str) -> None: + """ + Used by ``import_path`` to create intermediate modules when using mode=importlib. + + When we want to import a module as "src.tests.test_foo" for example, we need + to create empty modules "src" and "src.tests" after inserting "src.tests.test_foo", + otherwise "src.tests.test_foo" is not importable by ``__import__``. + """ + module_parts = module_name.split(".") + while module_name: + parent_module_name, _, child_name = module_name.rpartition(".") + if parent_module_name: + parent_module = modules.get(parent_module_name) + if parent_module is None: + try: + # If sys.meta_path is empty, calling import_module will issue + # a warning and raise ModuleNotFoundError. To avoid the + # warning, we check sys.meta_path explicitly and raise the error + # ourselves to fall back to creating a dummy module. + if not sys.meta_path: + raise ModuleNotFoundError + parent_module = importlib.import_module(parent_module_name) + except ModuleNotFoundError: + parent_module = ModuleType( + module_name, + doc="Empty module created by pytest's importmode=importlib.", + ) + modules[parent_module_name] = parent_module + + # Add child attribute to the parent that can reference the child + # modules. + if not hasattr(parent_module, child_name): + setattr(parent_module, child_name, modules[module_name]) + + module_parts.pop(-1) + module_name = ".".join(module_parts) + + +def resolve_package_path(path: Path) -> Path | None: + """Return the Python package path by looking for the last + directory upwards which still contains an __init__.py. + + Returns None if it cannot be determined. + """ + result = None + for parent in itertools.chain((path,), path.parents): + if parent.is_dir(): + if not (parent / "__init__.py").is_file(): + break + if not parent.name.isidentifier(): + break + result = parent + return result + + +def resolve_pkg_root_and_module_name( + path: Path, *, consider_namespace_packages: bool = False +) -> tuple[Path, str]: + """ + Return the path to the directory of the root package that contains the + given Python file, and its module name: + + src/ + app/ + __init__.py + core/ + __init__.py + models.py + + Passing the full path to `models.py` will yield Path("src") and "app.core.models". + + If consider_namespace_packages is True, then we additionally check upwards in the hierarchy + for namespace packages: + + https://packaging.python.org/en/latest/guides/packaging-namespace-packages + + Raises CouldNotResolvePathError if the given path does not belong to a package (missing any __init__.py files). + """ + pkg_root: Path | None = None + pkg_path = resolve_package_path(path) + if pkg_path is not None: + pkg_root = pkg_path.parent + if consider_namespace_packages: + start = pkg_root if pkg_root is not None else path.parent + for candidate in (start, *start.parents): + module_name = compute_module_name(candidate, path) + if module_name and is_importable(module_name, path): + # Point the pkg_root to the root of the namespace package. + pkg_root = candidate + break + + if pkg_root is not None: + module_name = compute_module_name(pkg_root, path) + if module_name: + return pkg_root, module_name + + raise CouldNotResolvePathError(f"Could not resolve for {path}") + + +def is_importable(module_name: str, module_path: Path) -> bool: + """ + Return if the given module path could be imported normally by Python, akin to the user + entering the REPL and importing the corresponding module name directly, and corresponds + to the module_path specified. + + :param module_name: + Full module name that we want to check if is importable. + For example, "app.models". + + :param module_path: + Full path to the python module/package we want to check if is importable. + For example, "/projects/src/app/models.py". + """ + try: + # Note this is different from what we do in ``_import_module_using_spec``, where we explicitly search through + # sys.meta_path to be able to pass the path of the module that we want to import (``meta_importer.find_spec``). + # Using importlib.util.find_spec() is different, it gives the same results as trying to import + # the module normally in the REPL. + spec = importlib.util.find_spec(module_name) + except (ImportError, ValueError, ImportWarning): + return False + else: + return spec_matches_module_path(spec, module_path) + + +def compute_module_name(root: Path, module_path: Path) -> str | None: + """Compute a module name based on a path and a root anchor.""" + try: + path_without_suffix = module_path.with_suffix("") + except ValueError: + # Empty paths (such as Path.cwd()) might break meta_path hooks (like our own assertion rewriter). + return None + + try: + relative = path_without_suffix.relative_to(root) + except ValueError: # pragma: no cover + return None + names = list(relative.parts) + if not names: + return None + if names[-1] == "__init__": + names.pop() + return ".".join(names) + + +class CouldNotResolvePathError(Exception): + """Custom exception raised by resolve_pkg_root_and_module_name.""" + + +def scandir( + path: str | os.PathLike[str], + sort_key: Callable[[os.DirEntry[str]], object] = lambda entry: entry.name, +) -> list[os.DirEntry[str]]: + """Scan a directory recursively, in breadth-first order. + + The returned entries are sorted according to the given key. + The default is to sort by name. + """ + entries = [] + with os.scandir(path) as s: + # Skip entries with symlink loops and other brokenness, so the caller + # doesn't have to deal with it. + for entry in s: + try: + entry.is_file() + except OSError as err: + if _ignore_error(err): + continue + raise + entries.append(entry) + entries.sort(key=sort_key) # type: ignore[arg-type] + return entries + + +def visit( + path: str | os.PathLike[str], recurse: Callable[[os.DirEntry[str]], bool] +) -> Iterator[os.DirEntry[str]]: + """Walk a directory recursively, in breadth-first order. + + The `recurse` predicate determines whether a directory is recursed. + + Entries at each directory level are sorted. + """ + entries = scandir(path) + yield from entries + for entry in entries: + if entry.is_dir() and recurse(entry): + yield from visit(entry.path, recurse) + + +def absolutepath(path: str | os.PathLike[str]) -> Path: + """Convert a path to an absolute path using os.path.abspath. + + Prefer this over Path.resolve() (see #6523). + Prefer this over Path.absolute() (not public, doesn't normalize). + """ + return Path(os.path.abspath(path)) + + +def commonpath(path1: Path, path2: Path) -> Path | None: + """Return the common part shared with the other path, or None if there is + no common part. + + If one path is relative and one is absolute, returns None. + """ + try: + return Path(os.path.commonpath((str(path1), str(path2)))) + except ValueError: + return None + + +def bestrelpath(directory: Path, dest: Path) -> str: + """Return a string which is a relative path from directory to dest such + that directory/bestrelpath == dest. + + The paths must be either both absolute or both relative. + + If no such path can be determined, returns dest. + """ + assert isinstance(directory, Path) + assert isinstance(dest, Path) + if dest == directory: + return os.curdir + # Find the longest common directory. + base = commonpath(directory, dest) + # Can be the case on Windows for two absolute paths on different drives. + # Can be the case for two relative paths without common prefix. + # Can be the case for a relative path and an absolute path. + if not base: + return str(dest) + reldirectory = directory.relative_to(base) + reldest = dest.relative_to(base) + return os.path.join( + # Back from directory to base. + *([os.pardir] * len(reldirectory.parts)), + # Forward from base to dest. + *reldest.parts, + ) + + +def safe_exists(p: Path) -> bool: + """Like Path.exists(), but account for input arguments that might be too long (#11394).""" + try: + return p.exists() + except (ValueError, OSError): + # ValueError: stat: path too long for Windows + # OSError: [WinError 123] The filename, directory name, or volume label syntax is incorrect + return False diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/py.typed b/PyGC/.venv/lib/python3.11/site-packages/_pytest/py.typed new file mode 100644 index 0000000..e69de29 diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/pytester.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/pytester.py new file mode 100644 index 0000000..3f7520e --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/pytester.py @@ -0,0 +1,1766 @@ +# mypy: allow-untyped-defs +"""(Disabled by default) support for testing pytest and pytest plugins. + +PYTEST_DONT_REWRITE +""" + +from __future__ import annotations + +import collections.abc +import contextlib +from fnmatch import fnmatch +import gc +import importlib +from io import StringIO +import locale +import os +from pathlib import Path +import platform +import re +import shutil +import subprocess +import sys +import traceback +from typing import Any +from typing import Callable +from typing import Final +from typing import final +from typing import Generator +from typing import IO +from typing import Iterable +from typing import Literal +from typing import overload +from typing import Sequence +from typing import TextIO +from typing import TYPE_CHECKING +from weakref import WeakKeyDictionary + +from iniconfig import IniConfig +from iniconfig import SectionWrapper + +from _pytest import timing +from _pytest._code import Source +from _pytest.capture import _get_multicapture +from _pytest.compat import NOTSET +from _pytest.compat import NotSetType +from _pytest.config import _PluggyPlugin +from _pytest.config import Config +from _pytest.config import ExitCode +from _pytest.config import hookimpl +from _pytest.config import main +from _pytest.config import PytestPluginManager +from _pytest.config.argparsing import Parser +from _pytest.deprecated import check_ispytest +from _pytest.fixtures import fixture +from _pytest.fixtures import FixtureRequest +from _pytest.main import Session +from _pytest.monkeypatch import MonkeyPatch +from _pytest.nodes import Collector +from _pytest.nodes import Item +from _pytest.outcomes import fail +from _pytest.outcomes import importorskip +from _pytest.outcomes import skip +from _pytest.pathlib import bestrelpath +from _pytest.pathlib import make_numbered_dir +from _pytest.reports import CollectReport +from _pytest.reports import TestReport +from _pytest.tmpdir import TempPathFactory +from _pytest.warning_types import PytestWarning + + +if TYPE_CHECKING: + import pexpect + + +pytest_plugins = ["pytester_assertions"] + + +IGNORE_PAM = [ # filenames added when obtaining details about the current user + "/var/lib/sss/mc/passwd" +] + + +def pytest_addoption(parser: Parser) -> None: + parser.addoption( + "--lsof", + action="store_true", + dest="lsof", + default=False, + help="Run FD checks if lsof is available", + ) + + parser.addoption( + "--runpytest", + default="inprocess", + dest="runpytest", + choices=("inprocess", "subprocess"), + help=( + "Run pytest sub runs in tests using an 'inprocess' " + "or 'subprocess' (python -m main) method" + ), + ) + + parser.addini( + "pytester_example_dir", help="Directory to take the pytester example files from" + ) + + +def pytest_configure(config: Config) -> None: + if config.getvalue("lsof"): + checker = LsofFdLeakChecker() + if checker.matching_platform(): + config.pluginmanager.register(checker) + + config.addinivalue_line( + "markers", + "pytester_example_path(*path_segments): join the given path " + "segments to `pytester_example_dir` for this test.", + ) + + +class LsofFdLeakChecker: + def get_open_files(self) -> list[tuple[str, str]]: + if sys.version_info >= (3, 11): + # New in Python 3.11, ignores utf-8 mode + encoding = locale.getencoding() + else: + encoding = locale.getpreferredencoding(False) + out = subprocess.run( + ("lsof", "-Ffn0", "-p", str(os.getpid())), + stdout=subprocess.PIPE, + stderr=subprocess.DEVNULL, + check=True, + text=True, + encoding=encoding, + ).stdout + + def isopen(line: str) -> bool: + return line.startswith("f") and ( + "deleted" not in line + and "mem" not in line + and "txt" not in line + and "cwd" not in line + ) + + open_files = [] + + for line in out.split("\n"): + if isopen(line): + fields = line.split("\0") + fd = fields[0][1:] + filename = fields[1][1:] + if filename in IGNORE_PAM: + continue + if filename.startswith("/"): + open_files.append((fd, filename)) + + return open_files + + def matching_platform(self) -> bool: + try: + subprocess.run(("lsof", "-v"), check=True) + except (OSError, subprocess.CalledProcessError): + return False + else: + return True + + @hookimpl(wrapper=True, tryfirst=True) + def pytest_runtest_protocol(self, item: Item) -> Generator[None, object, object]: + lines1 = self.get_open_files() + try: + return (yield) + finally: + if hasattr(sys, "pypy_version_info"): + gc.collect() + lines2 = self.get_open_files() + + new_fds = {t[0] for t in lines2} - {t[0] for t in lines1} + leaked_files = [t for t in lines2 if t[0] in new_fds] + if leaked_files: + error = [ + f"***** {len(leaked_files)} FD leakage detected", + *(str(f) for f in leaked_files), + "*** Before:", + *(str(f) for f in lines1), + "*** After:", + *(str(f) for f in lines2), + f"***** {len(leaked_files)} FD leakage detected", + "*** function {}:{}: {} ".format(*item.location), + "See issue #2366", + ] + item.warn(PytestWarning("\n".join(error))) + + +# used at least by pytest-xdist plugin + + +@fixture +def _pytest(request: FixtureRequest) -> PytestArg: + """Return a helper which offers a gethookrecorder(hook) method which + returns a HookRecorder instance which helps to make assertions about called + hooks.""" + return PytestArg(request) + + +class PytestArg: + def __init__(self, request: FixtureRequest) -> None: + self._request = request + + def gethookrecorder(self, hook) -> HookRecorder: + hookrecorder = HookRecorder(hook._pm) + self._request.addfinalizer(hookrecorder.finish_recording) + return hookrecorder + + +def get_public_names(values: Iterable[str]) -> list[str]: + """Only return names from iterator values without a leading underscore.""" + return [x for x in values if x[0] != "_"] + + +@final +class RecordedHookCall: + """A recorded call to a hook. + + The arguments to the hook call are set as attributes. + For example: + + .. code-block:: python + + calls = hook_recorder.getcalls("pytest_runtest_setup") + # Suppose pytest_runtest_setup was called once with `item=an_item`. + assert calls[0].item is an_item + """ + + def __init__(self, name: str, kwargs) -> None: + self.__dict__.update(kwargs) + self._name = name + + def __repr__(self) -> str: + d = self.__dict__.copy() + del d["_name"] + return f"" + + if TYPE_CHECKING: + # The class has undetermined attributes, this tells mypy about it. + def __getattr__(self, key: str): ... + + +@final +class HookRecorder: + """Record all hooks called in a plugin manager. + + Hook recorders are created by :class:`Pytester`. + + This wraps all the hook calls in the plugin manager, recording each call + before propagating the normal calls. + """ + + def __init__( + self, pluginmanager: PytestPluginManager, *, _ispytest: bool = False + ) -> None: + check_ispytest(_ispytest) + + self._pluginmanager = pluginmanager + self.calls: list[RecordedHookCall] = [] + self.ret: int | ExitCode | None = None + + def before(hook_name: str, hook_impls, kwargs) -> None: + self.calls.append(RecordedHookCall(hook_name, kwargs)) + + def after(outcome, hook_name: str, hook_impls, kwargs) -> None: + pass + + self._undo_wrapping = pluginmanager.add_hookcall_monitoring(before, after) + + def finish_recording(self) -> None: + self._undo_wrapping() + + def getcalls(self, names: str | Iterable[str]) -> list[RecordedHookCall]: + """Get all recorded calls to hooks with the given names (or name).""" + if isinstance(names, str): + names = names.split() + return [call for call in self.calls if call._name in names] + + def assert_contains(self, entries: Sequence[tuple[str, str]]) -> None: + __tracebackhide__ = True + i = 0 + entries = list(entries) + # Since Python 3.13, f_locals is not a dict, but eval requires a dict. + backlocals = dict(sys._getframe(1).f_locals) + while entries: + name, check = entries.pop(0) + for ind, call in enumerate(self.calls[i:]): + if call._name == name: + print("NAMEMATCH", name, call) + if eval(check, backlocals, call.__dict__): + print("CHECKERMATCH", repr(check), "->", call) + else: + print("NOCHECKERMATCH", repr(check), "-", call) + continue + i += ind + 1 + break + print("NONAMEMATCH", name, "with", call) + else: + fail(f"could not find {name!r} check {check!r}") + + def popcall(self, name: str) -> RecordedHookCall: + __tracebackhide__ = True + for i, call in enumerate(self.calls): + if call._name == name: + del self.calls[i] + return call + lines = [f"could not find call {name!r}, in:"] + lines.extend([f" {x}" for x in self.calls]) + fail("\n".join(lines)) + + def getcall(self, name: str) -> RecordedHookCall: + values = self.getcalls(name) + assert len(values) == 1, (name, values) + return values[0] + + # functionality for test reports + + @overload + def getreports( + self, + names: Literal["pytest_collectreport"], + ) -> Sequence[CollectReport]: ... + + @overload + def getreports( + self, + names: Literal["pytest_runtest_logreport"], + ) -> Sequence[TestReport]: ... + + @overload + def getreports( + self, + names: str | Iterable[str] = ( + "pytest_collectreport", + "pytest_runtest_logreport", + ), + ) -> Sequence[CollectReport | TestReport]: ... + + def getreports( + self, + names: str | Iterable[str] = ( + "pytest_collectreport", + "pytest_runtest_logreport", + ), + ) -> Sequence[CollectReport | TestReport]: + return [x.report for x in self.getcalls(names)] + + def matchreport( + self, + inamepart: str = "", + names: str | Iterable[str] = ( + "pytest_runtest_logreport", + "pytest_collectreport", + ), + when: str | None = None, + ) -> CollectReport | TestReport: + """Return a testreport whose dotted import path matches.""" + values = [] + for rep in self.getreports(names=names): + if not when and rep.when != "call" and rep.passed: + # setup/teardown passing reports - let's ignore those + continue + if when and rep.when != when: + continue + if not inamepart or inamepart in rep.nodeid.split("::"): + values.append(rep) + if not values: + raise ValueError( + f"could not find test report matching {inamepart!r}: " + "no test reports at all!" + ) + if len(values) > 1: + raise ValueError( + f"found 2 or more testreports matching {inamepart!r}: {values}" + ) + return values[0] + + @overload + def getfailures( + self, + names: Literal["pytest_collectreport"], + ) -> Sequence[CollectReport]: ... + + @overload + def getfailures( + self, + names: Literal["pytest_runtest_logreport"], + ) -> Sequence[TestReport]: ... + + @overload + def getfailures( + self, + names: str | Iterable[str] = ( + "pytest_collectreport", + "pytest_runtest_logreport", + ), + ) -> Sequence[CollectReport | TestReport]: ... + + def getfailures( + self, + names: str | Iterable[str] = ( + "pytest_collectreport", + "pytest_runtest_logreport", + ), + ) -> Sequence[CollectReport | TestReport]: + return [rep for rep in self.getreports(names) if rep.failed] + + def getfailedcollections(self) -> Sequence[CollectReport]: + return self.getfailures("pytest_collectreport") + + def listoutcomes( + self, + ) -> tuple[ + Sequence[TestReport], + Sequence[CollectReport | TestReport], + Sequence[CollectReport | TestReport], + ]: + passed = [] + skipped = [] + failed = [] + for rep in self.getreports( + ("pytest_collectreport", "pytest_runtest_logreport") + ): + if rep.passed: + if rep.when == "call": + assert isinstance(rep, TestReport) + passed.append(rep) + elif rep.skipped: + skipped.append(rep) + else: + assert rep.failed, f"Unexpected outcome: {rep!r}" + failed.append(rep) + return passed, skipped, failed + + def countoutcomes(self) -> list[int]: + return [len(x) for x in self.listoutcomes()] + + def assertoutcome(self, passed: int = 0, skipped: int = 0, failed: int = 0) -> None: + __tracebackhide__ = True + from _pytest.pytester_assertions import assertoutcome + + outcomes = self.listoutcomes() + assertoutcome( + outcomes, + passed=passed, + skipped=skipped, + failed=failed, + ) + + def clear(self) -> None: + self.calls[:] = [] + + +@fixture +def linecomp() -> LineComp: + """A :class: `LineComp` instance for checking that an input linearly + contains a sequence of strings.""" + return LineComp() + + +@fixture(name="LineMatcher") +def LineMatcher_fixture(request: FixtureRequest) -> type[LineMatcher]: + """A reference to the :class: `LineMatcher`. + + This is instantiable with a list of lines (without their trailing newlines). + This is useful for testing large texts, such as the output of commands. + """ + return LineMatcher + + +@fixture +def pytester( + request: FixtureRequest, tmp_path_factory: TempPathFactory, monkeypatch: MonkeyPatch +) -> Pytester: + """ + Facilities to write tests/configuration files, execute pytest in isolation, and match + against expected output, perfect for black-box testing of pytest plugins. + + It attempts to isolate the test run from external factors as much as possible, modifying + the current working directory to ``path`` and environment variables during initialization. + + It is particularly useful for testing plugins. It is similar to the :fixture:`tmp_path` + fixture but provides methods which aid in testing pytest itself. + """ + return Pytester(request, tmp_path_factory, monkeypatch, _ispytest=True) + + +@fixture +def _sys_snapshot() -> Generator[None]: + snappaths = SysPathsSnapshot() + snapmods = SysModulesSnapshot() + yield + snapmods.restore() + snappaths.restore() + + +@fixture +def _config_for_test() -> Generator[Config]: + from _pytest.config import get_config + + config = get_config() + yield config + config._ensure_unconfigure() # cleanup, e.g. capman closing tmpfiles. + + +# Regex to match the session duration string in the summary: "74.34s". +rex_session_duration = re.compile(r"\d+\.\d\ds") +# Regex to match all the counts and phrases in the summary line: "34 passed, 111 skipped". +rex_outcome = re.compile(r"(\d+) (\w+)") + + +@final +class RunResult: + """The result of running a command from :class:`~pytest.Pytester`.""" + + def __init__( + self, + ret: int | ExitCode, + outlines: list[str], + errlines: list[str], + duration: float, + ) -> None: + try: + self.ret: int | ExitCode = ExitCode(ret) + """The return value.""" + except ValueError: + self.ret = ret + self.outlines = outlines + """List of lines captured from stdout.""" + self.errlines = errlines + """List of lines captured from stderr.""" + self.stdout = LineMatcher(outlines) + """:class:`~pytest.LineMatcher` of stdout. + + Use e.g. :func:`str(stdout) ` to reconstruct stdout, or the commonly used + :func:`stdout.fnmatch_lines() ` method. + """ + self.stderr = LineMatcher(errlines) + """:class:`~pytest.LineMatcher` of stderr.""" + self.duration = duration + """Duration in seconds.""" + + def __repr__(self) -> str: + return ( + "" + % (self.ret, len(self.stdout.lines), len(self.stderr.lines), self.duration) + ) + + def parseoutcomes(self) -> dict[str, int]: + """Return a dictionary of outcome noun -> count from parsing the terminal + output that the test process produced. + + The returned nouns will always be in plural form:: + + ======= 1 failed, 1 passed, 1 warning, 1 error in 0.13s ==== + + Will return ``{"failed": 1, "passed": 1, "warnings": 1, "errors": 1}``. + """ + return self.parse_summary_nouns(self.outlines) + + @classmethod + def parse_summary_nouns(cls, lines) -> dict[str, int]: + """Extract the nouns from a pytest terminal summary line. + + It always returns the plural noun for consistency:: + + ======= 1 failed, 1 passed, 1 warning, 1 error in 0.13s ==== + + Will return ``{"failed": 1, "passed": 1, "warnings": 1, "errors": 1}``. + """ + for line in reversed(lines): + if rex_session_duration.search(line): + outcomes = rex_outcome.findall(line) + ret = {noun: int(count) for (count, noun) in outcomes} + break + else: + raise ValueError("Pytest terminal summary report not found") + + to_plural = { + "warning": "warnings", + "error": "errors", + } + return {to_plural.get(k, k): v for k, v in ret.items()} + + def assert_outcomes( + self, + passed: int = 0, + skipped: int = 0, + failed: int = 0, + errors: int = 0, + xpassed: int = 0, + xfailed: int = 0, + warnings: int | None = None, + deselected: int | None = None, + ) -> None: + """ + Assert that the specified outcomes appear with the respective + numbers (0 means it didn't occur) in the text output from a test run. + + ``warnings`` and ``deselected`` are only checked if not None. + """ + __tracebackhide__ = True + from _pytest.pytester_assertions import assert_outcomes + + outcomes = self.parseoutcomes() + assert_outcomes( + outcomes, + passed=passed, + skipped=skipped, + failed=failed, + errors=errors, + xpassed=xpassed, + xfailed=xfailed, + warnings=warnings, + deselected=deselected, + ) + + +class SysModulesSnapshot: + def __init__(self, preserve: Callable[[str], bool] | None = None) -> None: + self.__preserve = preserve + self.__saved = dict(sys.modules) + + def restore(self) -> None: + if self.__preserve: + self.__saved.update( + (k, m) for k, m in sys.modules.items() if self.__preserve(k) + ) + sys.modules.clear() + sys.modules.update(self.__saved) + + +class SysPathsSnapshot: + def __init__(self) -> None: + self.__saved = list(sys.path), list(sys.meta_path) + + def restore(self) -> None: + sys.path[:], sys.meta_path[:] = self.__saved + + +@final +class Pytester: + """ + Facilities to write tests/configuration files, execute pytest in isolation, and match + against expected output, perfect for black-box testing of pytest plugins. + + It attempts to isolate the test run from external factors as much as possible, modifying + the current working directory to :attr:`path` and environment variables during initialization. + """ + + __test__ = False + + CLOSE_STDIN: Final = NOTSET + + class TimeoutExpired(Exception): + pass + + def __init__( + self, + request: FixtureRequest, + tmp_path_factory: TempPathFactory, + monkeypatch: MonkeyPatch, + *, + _ispytest: bool = False, + ) -> None: + check_ispytest(_ispytest) + self._request = request + self._mod_collections: WeakKeyDictionary[Collector, list[Item | Collector]] = ( + WeakKeyDictionary() + ) + if request.function: + name: str = request.function.__name__ + else: + name = request.node.name + self._name = name + self._path: Path = tmp_path_factory.mktemp(name, numbered=True) + #: A list of plugins to use with :py:meth:`parseconfig` and + #: :py:meth:`runpytest`. Initially this is an empty list but plugins can + #: be added to the list. The type of items to add to the list depends on + #: the method using them so refer to them for details. + self.plugins: list[str | _PluggyPlugin] = [] + self._sys_path_snapshot = SysPathsSnapshot() + self._sys_modules_snapshot = self.__take_sys_modules_snapshot() + self._request.addfinalizer(self._finalize) + self._method = self._request.config.getoption("--runpytest") + self._test_tmproot = tmp_path_factory.mktemp(f"tmp-{name}", numbered=True) + + self._monkeypatch = mp = monkeypatch + self.chdir() + mp.setenv("PYTEST_DEBUG_TEMPROOT", str(self._test_tmproot)) + # Ensure no unexpected caching via tox. + mp.delenv("TOX_ENV_DIR", raising=False) + # Discard outer pytest options. + mp.delenv("PYTEST_ADDOPTS", raising=False) + # Ensure no user config is used. + tmphome = str(self.path) + mp.setenv("HOME", tmphome) + mp.setenv("USERPROFILE", tmphome) + # Do not use colors for inner runs by default. + mp.setenv("PY_COLORS", "0") + + @property + def path(self) -> Path: + """Temporary directory path used to create files/run tests from, etc.""" + return self._path + + def __repr__(self) -> str: + return f"" + + def _finalize(self) -> None: + """ + Clean up global state artifacts. + + Some methods modify the global interpreter state and this tries to + clean this up. It does not remove the temporary directory however so + it can be looked at after the test run has finished. + """ + self._sys_modules_snapshot.restore() + self._sys_path_snapshot.restore() + + def __take_sys_modules_snapshot(self) -> SysModulesSnapshot: + # Some zope modules used by twisted-related tests keep internal state + # and can't be deleted; we had some trouble in the past with + # `zope.interface` for example. + # + # Preserve readline due to https://bugs.python.org/issue41033. + # pexpect issues a SIGWINCH. + def preserve_module(name): + return name.startswith(("zope", "readline")) + + return SysModulesSnapshot(preserve=preserve_module) + + def make_hook_recorder(self, pluginmanager: PytestPluginManager) -> HookRecorder: + """Create a new :class:`HookRecorder` for a :class:`PytestPluginManager`.""" + pluginmanager.reprec = reprec = HookRecorder(pluginmanager, _ispytest=True) # type: ignore[attr-defined] + self._request.addfinalizer(reprec.finish_recording) + return reprec + + def chdir(self) -> None: + """Cd into the temporary directory. + + This is done automatically upon instantiation. + """ + self._monkeypatch.chdir(self.path) + + def _makefile( + self, + ext: str, + lines: Sequence[Any | bytes], + files: dict[str, str], + encoding: str = "utf-8", + ) -> Path: + items = list(files.items()) + + if ext is None: + raise TypeError("ext must not be None") + + if ext and not ext.startswith("."): + raise ValueError( + f"pytester.makefile expects a file extension, try .{ext} instead of {ext}" + ) + + def to_text(s: Any | bytes) -> str: + return s.decode(encoding) if isinstance(s, bytes) else str(s) + + if lines: + source = "\n".join(to_text(x) for x in lines) + basename = self._name + items.insert(0, (basename, source)) + + ret = None + for basename, value in items: + p = self.path.joinpath(basename).with_suffix(ext) + p.parent.mkdir(parents=True, exist_ok=True) + source_ = Source(value) + source = "\n".join(to_text(line) for line in source_.lines) + p.write_text(source.strip(), encoding=encoding) + if ret is None: + ret = p + assert ret is not None + return ret + + def makefile(self, ext: str, *args: str, **kwargs: str) -> Path: + r"""Create new text file(s) in the test directory. + + :param ext: + The extension the file(s) should use, including the dot, e.g. `.py`. + :param args: + All args are treated as strings and joined using newlines. + The result is written as contents to the file. The name of the + file is based on the test function requesting this fixture. + :param kwargs: + Each keyword is the name of a file, while the value of it will + be written as contents of the file. + :returns: + The first created file. + + Examples: + + .. code-block:: python + + pytester.makefile(".txt", "line1", "line2") + + pytester.makefile(".ini", pytest="[pytest]\naddopts=-rs\n") + + To create binary files, use :meth:`pathlib.Path.write_bytes` directly: + + .. code-block:: python + + filename = pytester.path.joinpath("foo.bin") + filename.write_bytes(b"...") + """ + return self._makefile(ext, args, kwargs) + + def makeconftest(self, source: str) -> Path: + """Write a conftest.py file. + + :param source: The contents. + :returns: The conftest.py file. + """ + return self.makepyfile(conftest=source) + + def makeini(self, source: str) -> Path: + """Write a tox.ini file. + + :param source: The contents. + :returns: The tox.ini file. + """ + return self.makefile(".ini", tox=source) + + def getinicfg(self, source: str) -> SectionWrapper: + """Return the pytest section from the tox.ini config file.""" + p = self.makeini(source) + return IniConfig(str(p))["pytest"] + + def makepyprojecttoml(self, source: str) -> Path: + """Write a pyproject.toml file. + + :param source: The contents. + :returns: The pyproject.ini file. + + .. versionadded:: 6.0 + """ + return self.makefile(".toml", pyproject=source) + + def makepyfile(self, *args, **kwargs) -> Path: + r"""Shortcut for .makefile() with a .py extension. + + Defaults to the test name with a '.py' extension, e.g test_foobar.py, overwriting + existing files. + + Examples: + + .. code-block:: python + + def test_something(pytester): + # Initial file is created test_something.py. + pytester.makepyfile("foobar") + # To create multiple files, pass kwargs accordingly. + pytester.makepyfile(custom="foobar") + # At this point, both 'test_something.py' & 'custom.py' exist in the test directory. + + """ + return self._makefile(".py", args, kwargs) + + def maketxtfile(self, *args, **kwargs) -> Path: + r"""Shortcut for .makefile() with a .txt extension. + + Defaults to the test name with a '.txt' extension, e.g test_foobar.txt, overwriting + existing files. + + Examples: + + .. code-block:: python + + def test_something(pytester): + # Initial file is created test_something.txt. + pytester.maketxtfile("foobar") + # To create multiple files, pass kwargs accordingly. + pytester.maketxtfile(custom="foobar") + # At this point, both 'test_something.txt' & 'custom.txt' exist in the test directory. + + """ + return self._makefile(".txt", args, kwargs) + + def syspathinsert(self, path: str | os.PathLike[str] | None = None) -> None: + """Prepend a directory to sys.path, defaults to :attr:`path`. + + This is undone automatically when this object dies at the end of each + test. + + :param path: + The path. + """ + if path is None: + path = self.path + + self._monkeypatch.syspath_prepend(str(path)) + + def mkdir(self, name: str | os.PathLike[str]) -> Path: + """Create a new (sub)directory. + + :param name: + The name of the directory, relative to the pytester path. + :returns: + The created directory. + :rtype: pathlib.Path + """ + p = self.path / name + p.mkdir() + return p + + def mkpydir(self, name: str | os.PathLike[str]) -> Path: + """Create a new python package. + + This creates a (sub)directory with an empty ``__init__.py`` file so it + gets recognised as a Python package. + """ + p = self.path / name + p.mkdir() + p.joinpath("__init__.py").touch() + return p + + def copy_example(self, name: str | None = None) -> Path: + """Copy file from project's directory into the testdir. + + :param name: + The name of the file to copy. + :return: + Path to the copied directory (inside ``self.path``). + :rtype: pathlib.Path + """ + example_dir_ = self._request.config.getini("pytester_example_dir") + if example_dir_ is None: + raise ValueError("pytester_example_dir is unset, can't copy examples") + example_dir: Path = self._request.config.rootpath / example_dir_ + + for extra_element in self._request.node.iter_markers("pytester_example_path"): + assert extra_element.args + example_dir = example_dir.joinpath(*extra_element.args) + + if name is None: + func_name = self._name + maybe_dir = example_dir / func_name + maybe_file = example_dir / (func_name + ".py") + + if maybe_dir.is_dir(): + example_path = maybe_dir + elif maybe_file.is_file(): + example_path = maybe_file + else: + raise LookupError( + f"{func_name} can't be found as module or package in {example_dir}" + ) + else: + example_path = example_dir.joinpath(name) + + if example_path.is_dir() and not example_path.joinpath("__init__.py").is_file(): + shutil.copytree(example_path, self.path, symlinks=True, dirs_exist_ok=True) + return self.path + elif example_path.is_file(): + result = self.path.joinpath(example_path.name) + shutil.copy(example_path, result) + return result + else: + raise LookupError( + f'example "{example_path}" is not found as a file or directory' + ) + + def getnode(self, config: Config, arg: str | os.PathLike[str]) -> Collector | Item: + """Get the collection node of a file. + + :param config: + A pytest config. + See :py:meth:`parseconfig` and :py:meth:`parseconfigure` for creating it. + :param arg: + Path to the file. + :returns: + The node. + """ + session = Session.from_config(config) + assert "::" not in str(arg) + p = Path(os.path.abspath(arg)) + config.hook.pytest_sessionstart(session=session) + res = session.perform_collect([str(p)], genitems=False)[0] + config.hook.pytest_sessionfinish(session=session, exitstatus=ExitCode.OK) + return res + + def getpathnode(self, path: str | os.PathLike[str]) -> Collector | Item: + """Return the collection node of a file. + + This is like :py:meth:`getnode` but uses :py:meth:`parseconfigure` to + create the (configured) pytest Config instance. + + :param path: + Path to the file. + :returns: + The node. + """ + path = Path(path) + config = self.parseconfigure(path) + session = Session.from_config(config) + x = bestrelpath(session.path, path) + config.hook.pytest_sessionstart(session=session) + res = session.perform_collect([x], genitems=False)[0] + config.hook.pytest_sessionfinish(session=session, exitstatus=ExitCode.OK) + return res + + def genitems(self, colitems: Sequence[Item | Collector]) -> list[Item]: + """Generate all test items from a collection node. + + This recurses into the collection node and returns a list of all the + test items contained within. + + :param colitems: + The collection nodes. + :returns: + The collected items. + """ + session = colitems[0].session + result: list[Item] = [] + for colitem in colitems: + result.extend(session.genitems(colitem)) + return result + + def runitem(self, source: str) -> Any: + """Run the "test_func" Item. + + The calling test instance (class containing the test method) must + provide a ``.getrunner()`` method which should return a runner which + can run the test protocol for a single item, e.g. + ``_pytest.runner.runtestprotocol``. + """ + # used from runner functional tests + item = self.getitem(source) + # the test class where we are called from wants to provide the runner + testclassinstance = self._request.instance + runner = testclassinstance.getrunner() + return runner(item) + + def inline_runsource(self, source: str, *cmdlineargs) -> HookRecorder: + """Run a test module in process using ``pytest.main()``. + + This run writes "source" into a temporary file and runs + ``pytest.main()`` on it, returning a :py:class:`HookRecorder` instance + for the result. + + :param source: The source code of the test module. + :param cmdlineargs: Any extra command line arguments to use. + """ + p = self.makepyfile(source) + values = [*list(cmdlineargs), p] + return self.inline_run(*values) + + def inline_genitems(self, *args) -> tuple[list[Item], HookRecorder]: + """Run ``pytest.main(['--collect-only'])`` in-process. + + Runs the :py:func:`pytest.main` function to run all of pytest inside + the test process itself like :py:meth:`inline_run`, but returns a + tuple of the collected items and a :py:class:`HookRecorder` instance. + """ + rec = self.inline_run("--collect-only", *args) + items = [x.item for x in rec.getcalls("pytest_itemcollected")] + return items, rec + + def inline_run( + self, + *args: str | os.PathLike[str], + plugins=(), + no_reraise_ctrlc: bool = False, + ) -> HookRecorder: + """Run ``pytest.main()`` in-process, returning a HookRecorder. + + Runs the :py:func:`pytest.main` function to run all of pytest inside + the test process itself. This means it can return a + :py:class:`HookRecorder` instance which gives more detailed results + from that run than can be done by matching stdout/stderr from + :py:meth:`runpytest`. + + :param args: + Command line arguments to pass to :py:func:`pytest.main`. + :param plugins: + Extra plugin instances the ``pytest.main()`` instance should use. + :param no_reraise_ctrlc: + Typically we reraise keyboard interrupts from the child run. If + True, the KeyboardInterrupt exception is captured. + """ + # (maybe a cpython bug?) the importlib cache sometimes isn't updated + # properly between file creation and inline_run (especially if imports + # are interspersed with file creation) + importlib.invalidate_caches() + + plugins = list(plugins) + finalizers = [] + try: + # Any sys.module or sys.path changes done while running pytest + # inline should be reverted after the test run completes to avoid + # clashing with later inline tests run within the same pytest test, + # e.g. just because they use matching test module names. + finalizers.append(self.__take_sys_modules_snapshot().restore) + finalizers.append(SysPathsSnapshot().restore) + + # Important note: + # - our tests should not leave any other references/registrations + # laying around other than possibly loaded test modules + # referenced from sys.modules, as nothing will clean those up + # automatically + + rec = [] + + class Collect: + def pytest_configure(x, config: Config) -> None: + rec.append(self.make_hook_recorder(config.pluginmanager)) + + plugins.append(Collect()) + ret = main([str(x) for x in args], plugins=plugins) + if len(rec) == 1: + reprec = rec.pop() + else: + + class reprec: # type: ignore + pass + + reprec.ret = ret + + # Typically we reraise keyboard interrupts from the child run + # because it's our user requesting interruption of the testing. + if ret == ExitCode.INTERRUPTED and not no_reraise_ctrlc: + calls = reprec.getcalls("pytest_keyboard_interrupt") + if calls and calls[-1].excinfo.type == KeyboardInterrupt: + raise KeyboardInterrupt() + return reprec + finally: + for finalizer in finalizers: + finalizer() + + def runpytest_inprocess( + self, *args: str | os.PathLike[str], **kwargs: Any + ) -> RunResult: + """Return result of running pytest in-process, providing a similar + interface to what self.runpytest() provides.""" + syspathinsert = kwargs.pop("syspathinsert", False) + + if syspathinsert: + self.syspathinsert() + now = timing.time() + capture = _get_multicapture("sys") + capture.start_capturing() + try: + try: + reprec = self.inline_run(*args, **kwargs) + except SystemExit as e: + ret = e.args[0] + try: + ret = ExitCode(e.args[0]) + except ValueError: + pass + + class reprec: # type: ignore + ret = ret + + except Exception: + traceback.print_exc() + + class reprec: # type: ignore + ret = ExitCode(3) + + finally: + out, err = capture.readouterr() + capture.stop_capturing() + sys.stdout.write(out) + sys.stderr.write(err) + + assert reprec.ret is not None + res = RunResult( + reprec.ret, out.splitlines(), err.splitlines(), timing.time() - now + ) + res.reprec = reprec # type: ignore + return res + + def runpytest(self, *args: str | os.PathLike[str], **kwargs: Any) -> RunResult: + """Run pytest inline or in a subprocess, depending on the command line + option "--runpytest" and return a :py:class:`~pytest.RunResult`.""" + new_args = self._ensure_basetemp(args) + if self._method == "inprocess": + return self.runpytest_inprocess(*new_args, **kwargs) + elif self._method == "subprocess": + return self.runpytest_subprocess(*new_args, **kwargs) + raise RuntimeError(f"Unrecognized runpytest option: {self._method}") + + def _ensure_basetemp( + self, args: Sequence[str | os.PathLike[str]] + ) -> list[str | os.PathLike[str]]: + new_args = list(args) + for x in new_args: + if str(x).startswith("--basetemp"): + break + else: + new_args.append( + "--basetemp={}".format(self.path.parent.joinpath("basetemp")) + ) + return new_args + + def parseconfig(self, *args: str | os.PathLike[str]) -> Config: + """Return a new pytest :class:`pytest.Config` instance from given + commandline args. + + This invokes the pytest bootstrapping code in _pytest.config to create a + new :py:class:`pytest.PytestPluginManager` and call the + :hook:`pytest_cmdline_parse` hook to create a new :class:`pytest.Config` + instance. + + If :attr:`plugins` has been populated they should be plugin modules + to be registered with the plugin manager. + """ + import _pytest.config + + new_args = self._ensure_basetemp(args) + new_args = [str(x) for x in new_args] + + config = _pytest.config._prepareconfig(new_args, self.plugins) # type: ignore[arg-type] + # we don't know what the test will do with this half-setup config + # object and thus we make sure it gets unconfigured properly in any + # case (otherwise capturing could still be active, for example) + self._request.addfinalizer(config._ensure_unconfigure) + return config + + def parseconfigure(self, *args: str | os.PathLike[str]) -> Config: + """Return a new pytest configured Config instance. + + Returns a new :py:class:`pytest.Config` instance like + :py:meth:`parseconfig`, but also calls the :hook:`pytest_configure` + hook. + """ + config = self.parseconfig(*args) + config._do_configure() + return config + + def getitem( + self, source: str | os.PathLike[str], funcname: str = "test_func" + ) -> Item: + """Return the test item for a test function. + + Writes the source to a python file and runs pytest's collection on + the resulting module, returning the test item for the requested + function name. + + :param source: + The module source. + :param funcname: + The name of the test function for which to return a test item. + :returns: + The test item. + """ + items = self.getitems(source) + for item in items: + if item.name == funcname: + return item + assert 0, f"{funcname!r} item not found in module:\n{source}\nitems: {items}" + + def getitems(self, source: str | os.PathLike[str]) -> list[Item]: + """Return all test items collected from the module. + + Writes the source to a Python file and runs pytest's collection on + the resulting module, returning all test items contained within. + """ + modcol = self.getmodulecol(source) + return self.genitems([modcol]) + + def getmodulecol( + self, + source: str | os.PathLike[str], + configargs=(), + *, + withinit: bool = False, + ): + """Return the module collection node for ``source``. + + Writes ``source`` to a file using :py:meth:`makepyfile` and then + runs the pytest collection on it, returning the collection node for the + test module. + + :param source: + The source code of the module to collect. + + :param configargs: + Any extra arguments to pass to :py:meth:`parseconfigure`. + + :param withinit: + Whether to also write an ``__init__.py`` file to the same + directory to ensure it is a package. + """ + if isinstance(source, os.PathLike): + path = self.path.joinpath(source) + assert not withinit, "not supported for paths" + else: + kw = {self._name: str(source)} + path = self.makepyfile(**kw) + if withinit: + self.makepyfile(__init__="#") + self.config = config = self.parseconfigure(path, *configargs) + return self.getnode(config, path) + + def collect_by_name(self, modcol: Collector, name: str) -> Item | Collector | None: + """Return the collection node for name from the module collection. + + Searches a module collection node for a collection node matching the + given name. + + :param modcol: A module collection node; see :py:meth:`getmodulecol`. + :param name: The name of the node to return. + """ + if modcol not in self._mod_collections: + self._mod_collections[modcol] = list(modcol.collect()) + for colitem in self._mod_collections[modcol]: + if colitem.name == name: + return colitem + return None + + def popen( + self, + cmdargs: Sequence[str | os.PathLike[str]], + stdout: int | TextIO = subprocess.PIPE, + stderr: int | TextIO = subprocess.PIPE, + stdin: NotSetType | bytes | IO[Any] | int = CLOSE_STDIN, + **kw, + ): + """Invoke :py:class:`subprocess.Popen`. + + Calls :py:class:`subprocess.Popen` making sure the current working + directory is in ``PYTHONPATH``. + + You probably want to use :py:meth:`run` instead. + """ + env = os.environ.copy() + env["PYTHONPATH"] = os.pathsep.join( + filter(None, [os.getcwd(), env.get("PYTHONPATH", "")]) + ) + kw["env"] = env + + if stdin is self.CLOSE_STDIN: + kw["stdin"] = subprocess.PIPE + elif isinstance(stdin, bytes): + kw["stdin"] = subprocess.PIPE + else: + kw["stdin"] = stdin + + popen = subprocess.Popen(cmdargs, stdout=stdout, stderr=stderr, **kw) + if stdin is self.CLOSE_STDIN: + assert popen.stdin is not None + popen.stdin.close() + elif isinstance(stdin, bytes): + assert popen.stdin is not None + popen.stdin.write(stdin) + + return popen + + def run( + self, + *cmdargs: str | os.PathLike[str], + timeout: float | None = None, + stdin: NotSetType | bytes | IO[Any] | int = CLOSE_STDIN, + ) -> RunResult: + """Run a command with arguments. + + Run a process using :py:class:`subprocess.Popen` saving the stdout and + stderr. + + :param cmdargs: + The sequence of arguments to pass to :py:class:`subprocess.Popen`, + with path-like objects being converted to :py:class:`str` + automatically. + :param timeout: + The period in seconds after which to timeout and raise + :py:class:`Pytester.TimeoutExpired`. + :param stdin: + Optional standard input. + + - If it is ``CLOSE_STDIN`` (Default), then this method calls + :py:class:`subprocess.Popen` with ``stdin=subprocess.PIPE``, and + the standard input is closed immediately after the new command is + started. + + - If it is of type :py:class:`bytes`, these bytes are sent to the + standard input of the command. + + - Otherwise, it is passed through to :py:class:`subprocess.Popen`. + For further information in this case, consult the document of the + ``stdin`` parameter in :py:class:`subprocess.Popen`. + :type stdin: _pytest.compat.NotSetType | bytes | IO[Any] | int + :returns: + The result. + + """ + __tracebackhide__ = True + + cmdargs = tuple(os.fspath(arg) for arg in cmdargs) + p1 = self.path.joinpath("stdout") + p2 = self.path.joinpath("stderr") + print("running:", *cmdargs) + print(" in:", Path.cwd()) + + with p1.open("w", encoding="utf8") as f1, p2.open("w", encoding="utf8") as f2: + now = timing.time() + popen = self.popen( + cmdargs, + stdin=stdin, + stdout=f1, + stderr=f2, + close_fds=(sys.platform != "win32"), + ) + if popen.stdin is not None: + popen.stdin.close() + + def handle_timeout() -> None: + __tracebackhide__ = True + + timeout_message = f"{timeout} second timeout expired running: {cmdargs}" + + popen.kill() + popen.wait() + raise self.TimeoutExpired(timeout_message) + + if timeout is None: + ret = popen.wait() + else: + try: + ret = popen.wait(timeout) + except subprocess.TimeoutExpired: + handle_timeout() + + with p1.open(encoding="utf8") as f1, p2.open(encoding="utf8") as f2: + out = f1.read().splitlines() + err = f2.read().splitlines() + + self._dump_lines(out, sys.stdout) + self._dump_lines(err, sys.stderr) + + with contextlib.suppress(ValueError): + ret = ExitCode(ret) + return RunResult(ret, out, err, timing.time() - now) + + def _dump_lines(self, lines, fp): + try: + for line in lines: + print(line, file=fp) + except UnicodeEncodeError: + print(f"couldn't print to {fp} because of encoding") + + def _getpytestargs(self) -> tuple[str, ...]: + return sys.executable, "-mpytest" + + def runpython(self, script: os.PathLike[str]) -> RunResult: + """Run a python script using sys.executable as interpreter.""" + return self.run(sys.executable, script) + + def runpython_c(self, command: str) -> RunResult: + """Run ``python -c "command"``.""" + return self.run(sys.executable, "-c", command) + + def runpytest_subprocess( + self, *args: str | os.PathLike[str], timeout: float | None = None + ) -> RunResult: + """Run pytest as a subprocess with given arguments. + + Any plugins added to the :py:attr:`plugins` list will be added using the + ``-p`` command line option. Additionally ``--basetemp`` is used to put + any temporary files and directories in a numbered directory prefixed + with "runpytest-" to not conflict with the normal numbered pytest + location for temporary files and directories. + + :param args: + The sequence of arguments to pass to the pytest subprocess. + :param timeout: + The period in seconds after which to timeout and raise + :py:class:`Pytester.TimeoutExpired`. + :returns: + The result. + """ + __tracebackhide__ = True + p = make_numbered_dir(root=self.path, prefix="runpytest-", mode=0o700) + args = (f"--basetemp={p}", *args) + plugins = [x for x in self.plugins if isinstance(x, str)] + if plugins: + args = ("-p", plugins[0], *args) + args = self._getpytestargs() + args + return self.run(*args, timeout=timeout) + + def spawn_pytest(self, string: str, expect_timeout: float = 10.0) -> pexpect.spawn: + """Run pytest using pexpect. + + This makes sure to use the right pytest and sets up the temporary + directory locations. + + The pexpect child is returned. + """ + basetemp = self.path / "temp-pexpect" + basetemp.mkdir(mode=0o700) + invoke = " ".join(map(str, self._getpytestargs())) + cmd = f"{invoke} --basetemp={basetemp} {string}" + return self.spawn(cmd, expect_timeout=expect_timeout) + + def spawn(self, cmd: str, expect_timeout: float = 10.0) -> pexpect.spawn: + """Run a command using pexpect. + + The pexpect child is returned. + """ + pexpect = importorskip("pexpect", "3.0") + if hasattr(sys, "pypy_version_info") and "64" in platform.machine(): + skip("pypy-64 bit not supported") + if not hasattr(pexpect, "spawn"): + skip("pexpect.spawn not available") + logfile = self.path.joinpath("spawn.out").open("wb") + + child = pexpect.spawn(cmd, logfile=logfile, timeout=expect_timeout) + self._request.addfinalizer(logfile.close) + return child + + +class LineComp: + def __init__(self) -> None: + self.stringio = StringIO() + """:class:`python:io.StringIO()` instance used for input.""" + + def assert_contains_lines(self, lines2: Sequence[str]) -> None: + """Assert that ``lines2`` are contained (linearly) in :attr:`stringio`'s value. + + Lines are matched using :func:`LineMatcher.fnmatch_lines `. + """ + __tracebackhide__ = True + val = self.stringio.getvalue() + self.stringio.truncate(0) + self.stringio.seek(0) + lines1 = val.split("\n") + LineMatcher(lines1).fnmatch_lines(lines2) + + +class LineMatcher: + """Flexible matching of text. + + This is a convenience class to test large texts like the output of + commands. + + The constructor takes a list of lines without their trailing newlines, i.e. + ``text.splitlines()``. + """ + + def __init__(self, lines: list[str]) -> None: + self.lines = lines + self._log_output: list[str] = [] + + def __str__(self) -> str: + """Return the entire original text. + + .. versionadded:: 6.2 + You can use :meth:`str` in older versions. + """ + return "\n".join(self.lines) + + def _getlines(self, lines2: str | Sequence[str] | Source) -> Sequence[str]: + if isinstance(lines2, str): + lines2 = Source(lines2) + if isinstance(lines2, Source): + lines2 = lines2.strip().lines + return lines2 + + def fnmatch_lines_random(self, lines2: Sequence[str]) -> None: + """Check lines exist in the output in any order (using :func:`python:fnmatch.fnmatch`).""" + __tracebackhide__ = True + self._match_lines_random(lines2, fnmatch) + + def re_match_lines_random(self, lines2: Sequence[str]) -> None: + """Check lines exist in the output in any order (using :func:`python:re.match`).""" + __tracebackhide__ = True + self._match_lines_random(lines2, lambda name, pat: bool(re.match(pat, name))) + + def _match_lines_random( + self, lines2: Sequence[str], match_func: Callable[[str, str], bool] + ) -> None: + __tracebackhide__ = True + lines2 = self._getlines(lines2) + for line in lines2: + for x in self.lines: + if line == x or match_func(x, line): + self._log("matched: ", repr(line)) + break + else: + msg = f"line {line!r} not found in output" + self._log(msg) + self._fail(msg) + + def get_lines_after(self, fnline: str) -> Sequence[str]: + """Return all lines following the given line in the text. + + The given line can contain glob wildcards. + """ + for i, line in enumerate(self.lines): + if fnline == line or fnmatch(line, fnline): + return self.lines[i + 1 :] + raise ValueError(f"line {fnline!r} not found in output") + + def _log(self, *args) -> None: + self._log_output.append(" ".join(str(x) for x in args)) + + @property + def _log_text(self) -> str: + return "\n".join(self._log_output) + + def fnmatch_lines( + self, lines2: Sequence[str], *, consecutive: bool = False + ) -> None: + """Check lines exist in the output (using :func:`python:fnmatch.fnmatch`). + + The argument is a list of lines which have to match and can use glob + wildcards. If they do not match a pytest.fail() is called. The + matches and non-matches are also shown as part of the error message. + + :param lines2: String patterns to match. + :param consecutive: Match lines consecutively? + """ + __tracebackhide__ = True + self._match_lines(lines2, fnmatch, "fnmatch", consecutive=consecutive) + + def re_match_lines( + self, lines2: Sequence[str], *, consecutive: bool = False + ) -> None: + """Check lines exist in the output (using :func:`python:re.match`). + + The argument is a list of lines which have to match using ``re.match``. + If they do not match a pytest.fail() is called. + + The matches and non-matches are also shown as part of the error message. + + :param lines2: string patterns to match. + :param consecutive: match lines consecutively? + """ + __tracebackhide__ = True + self._match_lines( + lines2, + lambda name, pat: bool(re.match(pat, name)), + "re.match", + consecutive=consecutive, + ) + + def _match_lines( + self, + lines2: Sequence[str], + match_func: Callable[[str, str], bool], + match_nickname: str, + *, + consecutive: bool = False, + ) -> None: + """Underlying implementation of ``fnmatch_lines`` and ``re_match_lines``. + + :param Sequence[str] lines2: + List of string patterns to match. The actual format depends on + ``match_func``. + :param match_func: + A callable ``match_func(line, pattern)`` where line is the + captured line from stdout/stderr and pattern is the matching + pattern. + :param str match_nickname: + The nickname for the match function that will be logged to stdout + when a match occurs. + :param consecutive: + Match lines consecutively? + """ + if not isinstance(lines2, collections.abc.Sequence): + raise TypeError(f"invalid type for lines2: {type(lines2).__name__}") + lines2 = self._getlines(lines2) + lines1 = self.lines[:] + extralines = [] + __tracebackhide__ = True + wnick = len(match_nickname) + 1 + started = False + for line in lines2: + nomatchprinted = False + while lines1: + nextline = lines1.pop(0) + if line == nextline: + self._log("exact match:", repr(line)) + started = True + break + elif match_func(nextline, line): + self._log(f"{match_nickname}:", repr(line)) + self._log( + "{:>{width}}".format("with:", width=wnick), repr(nextline) + ) + started = True + break + else: + if consecutive and started: + msg = f"no consecutive match: {line!r}" + self._log(msg) + self._log( + "{:>{width}}".format("with:", width=wnick), repr(nextline) + ) + self._fail(msg) + if not nomatchprinted: + self._log( + "{:>{width}}".format("nomatch:", width=wnick), repr(line) + ) + nomatchprinted = True + self._log("{:>{width}}".format("and:", width=wnick), repr(nextline)) + extralines.append(nextline) + else: + msg = f"remains unmatched: {line!r}" + self._log(msg) + self._fail(msg) + self._log_output = [] + + def no_fnmatch_line(self, pat: str) -> None: + """Ensure captured lines do not match the given pattern, using ``fnmatch.fnmatch``. + + :param str pat: The pattern to match lines. + """ + __tracebackhide__ = True + self._no_match_line(pat, fnmatch, "fnmatch") + + def no_re_match_line(self, pat: str) -> None: + """Ensure captured lines do not match the given pattern, using ``re.match``. + + :param str pat: The regular expression to match lines. + """ + __tracebackhide__ = True + self._no_match_line( + pat, lambda name, pat: bool(re.match(pat, name)), "re.match" + ) + + def _no_match_line( + self, pat: str, match_func: Callable[[str, str], bool], match_nickname: str + ) -> None: + """Ensure captured lines does not have a the given pattern, using ``fnmatch.fnmatch``. + + :param str pat: The pattern to match lines. + """ + __tracebackhide__ = True + nomatch_printed = False + wnick = len(match_nickname) + 1 + for line in self.lines: + if match_func(line, pat): + msg = f"{match_nickname}: {pat!r}" + self._log(msg) + self._log("{:>{width}}".format("with:", width=wnick), repr(line)) + self._fail(msg) + else: + if not nomatch_printed: + self._log("{:>{width}}".format("nomatch:", width=wnick), repr(pat)) + nomatch_printed = True + self._log("{:>{width}}".format("and:", width=wnick), repr(line)) + self._log_output = [] + + def _fail(self, msg: str) -> None: + __tracebackhide__ = True + log_text = self._log_text + self._log_output = [] + fail(log_text) + + def str(self) -> str: + """Return the entire original text.""" + return str(self) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/pytester_assertions.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/pytester_assertions.py new file mode 100644 index 0000000..d543798 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/pytester_assertions.py @@ -0,0 +1,74 @@ +"""Helper plugin for pytester; should not be loaded on its own.""" + +# This plugin contains assertions used by pytester. pytester cannot +# contain them itself, since it is imported by the `pytest` module, +# hence cannot be subject to assertion rewriting, which requires a +# module to not be already imported. +from __future__ import annotations + +from typing import Sequence + +from _pytest.reports import CollectReport +from _pytest.reports import TestReport + + +def assertoutcome( + outcomes: tuple[ + Sequence[TestReport], + Sequence[CollectReport | TestReport], + Sequence[CollectReport | TestReport], + ], + passed: int = 0, + skipped: int = 0, + failed: int = 0, +) -> None: + __tracebackhide__ = True + + realpassed, realskipped, realfailed = outcomes + obtained = { + "passed": len(realpassed), + "skipped": len(realskipped), + "failed": len(realfailed), + } + expected = {"passed": passed, "skipped": skipped, "failed": failed} + assert obtained == expected, outcomes + + +def assert_outcomes( + outcomes: dict[str, int], + passed: int = 0, + skipped: int = 0, + failed: int = 0, + errors: int = 0, + xpassed: int = 0, + xfailed: int = 0, + warnings: int | None = None, + deselected: int | None = None, +) -> None: + """Assert that the specified outcomes appear with the respective + numbers (0 means it didn't occur) in the text output from a test run.""" + __tracebackhide__ = True + + obtained = { + "passed": outcomes.get("passed", 0), + "skipped": outcomes.get("skipped", 0), + "failed": outcomes.get("failed", 0), + "errors": outcomes.get("errors", 0), + "xpassed": outcomes.get("xpassed", 0), + "xfailed": outcomes.get("xfailed", 0), + } + expected = { + "passed": passed, + "skipped": skipped, + "failed": failed, + "errors": errors, + "xpassed": xpassed, + "xfailed": xfailed, + } + if warnings is not None: + obtained["warnings"] = outcomes.get("warnings", 0) + expected["warnings"] = warnings + if deselected is not None: + obtained["deselected"] = outcomes.get("deselected", 0) + expected["deselected"] = deselected + assert obtained == expected diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/python.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/python.py new file mode 100644 index 0000000..3478c34 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/python.py @@ -0,0 +1,1679 @@ +# mypy: allow-untyped-defs +"""Python test discovery, setup and run of test functions.""" + +from __future__ import annotations + +import abc +from collections import Counter +from collections import defaultdict +import dataclasses +import enum +import fnmatch +from functools import partial +import inspect +import itertools +import os +from pathlib import Path +import types +from typing import Any +from typing import Callable +from typing import Dict +from typing import final +from typing import Generator +from typing import Iterable +from typing import Iterator +from typing import Literal +from typing import Mapping +from typing import Pattern +from typing import Sequence +from typing import TYPE_CHECKING +import warnings + +import _pytest +from _pytest import fixtures +from _pytest import nodes +from _pytest._code import filter_traceback +from _pytest._code import getfslineno +from _pytest._code.code import ExceptionInfo +from _pytest._code.code import TerminalRepr +from _pytest._code.code import Traceback +from _pytest._io.saferepr import saferepr +from _pytest.compat import ascii_escaped +from _pytest.compat import get_default_arg_names +from _pytest.compat import get_real_func +from _pytest.compat import getimfunc +from _pytest.compat import is_async_function +from _pytest.compat import is_generator +from _pytest.compat import LEGACY_PATH +from _pytest.compat import NOTSET +from _pytest.compat import safe_getattr +from _pytest.compat import safe_isclass +from _pytest.config import Config +from _pytest.config import hookimpl +from _pytest.config.argparsing import Parser +from _pytest.deprecated import check_ispytest +from _pytest.fixtures import FixtureDef +from _pytest.fixtures import FixtureRequest +from _pytest.fixtures import FuncFixtureInfo +from _pytest.fixtures import get_scope_node +from _pytest.main import Session +from _pytest.mark import MARK_GEN +from _pytest.mark import ParameterSet +from _pytest.mark.structures import get_unpacked_marks +from _pytest.mark.structures import Mark +from _pytest.mark.structures import MarkDecorator +from _pytest.mark.structures import normalize_mark_list +from _pytest.outcomes import fail +from _pytest.outcomes import skip +from _pytest.pathlib import fnmatch_ex +from _pytest.pathlib import import_path +from _pytest.pathlib import ImportPathMismatchError +from _pytest.pathlib import scandir +from _pytest.scope import _ScopeName +from _pytest.scope import Scope +from _pytest.stash import StashKey +from _pytest.warning_types import PytestCollectionWarning +from _pytest.warning_types import PytestReturnNotNoneWarning +from _pytest.warning_types import PytestUnhandledCoroutineWarning + + +if TYPE_CHECKING: + from typing_extensions import Self + + +def pytest_addoption(parser: Parser) -> None: + parser.addini( + "python_files", + type="args", + # NOTE: default is also used in AssertionRewritingHook. + default=["test_*.py", "*_test.py"], + help="Glob-style file patterns for Python test module discovery", + ) + parser.addini( + "python_classes", + type="args", + default=["Test"], + help="Prefixes or glob names for Python test class discovery", + ) + parser.addini( + "python_functions", + type="args", + default=["test"], + help="Prefixes or glob names for Python test function and method discovery", + ) + parser.addini( + "disable_test_id_escaping_and_forfeit_all_rights_to_community_support", + type="bool", + default=False, + help="Disable string escape non-ASCII characters, might cause unwanted " + "side effects(use at your own risk)", + ) + + +def pytest_generate_tests(metafunc: Metafunc) -> None: + for marker in metafunc.definition.iter_markers(name="parametrize"): + metafunc.parametrize(*marker.args, **marker.kwargs, _param_mark=marker) + + +def pytest_configure(config: Config) -> None: + config.addinivalue_line( + "markers", + "parametrize(argnames, argvalues): call a test function multiple " + "times passing in different arguments in turn. argvalues generally " + "needs to be a list of values if argnames specifies only one name " + "or a list of tuples of values if argnames specifies multiple names. " + "Example: @parametrize('arg1', [1,2]) would lead to two calls of the " + "decorated test function, one with arg1=1 and another with arg1=2." + "see https://docs.pytest.org/en/stable/how-to/parametrize.html for more info " + "and examples.", + ) + config.addinivalue_line( + "markers", + "usefixtures(fixturename1, fixturename2, ...): mark tests as needing " + "all of the specified fixtures. see " + "https://docs.pytest.org/en/stable/explanation/fixtures.html#usefixtures ", + ) + + +def async_warn_and_skip(nodeid: str) -> None: + msg = "async def functions are not natively supported and have been skipped.\n" + msg += ( + "You need to install a suitable plugin for your async framework, for example:\n" + ) + msg += " - anyio\n" + msg += " - pytest-asyncio\n" + msg += " - pytest-tornasync\n" + msg += " - pytest-trio\n" + msg += " - pytest-twisted" + warnings.warn(PytestUnhandledCoroutineWarning(msg.format(nodeid))) + skip(reason="async def function and no async plugin installed (see warnings)") + + +@hookimpl(trylast=True) +def pytest_pyfunc_call(pyfuncitem: Function) -> object | None: + testfunction = pyfuncitem.obj + if is_async_function(testfunction): + async_warn_and_skip(pyfuncitem.nodeid) + funcargs = pyfuncitem.funcargs + testargs = {arg: funcargs[arg] for arg in pyfuncitem._fixtureinfo.argnames} + result = testfunction(**testargs) + if hasattr(result, "__await__") or hasattr(result, "__aiter__"): + async_warn_and_skip(pyfuncitem.nodeid) + elif result is not None: + warnings.warn( + PytestReturnNotNoneWarning( + f"Expected None, but {pyfuncitem.nodeid} returned {result!r}, which will be an error in a " + "future version of pytest. Did you mean to use `assert` instead of `return`?" + ) + ) + return True + + +def pytest_collect_directory( + path: Path, parent: nodes.Collector +) -> nodes.Collector | None: + pkginit = path / "__init__.py" + try: + has_pkginit = pkginit.is_file() + except PermissionError: + # See https://github.com/pytest-dev/pytest/issues/12120#issuecomment-2106349096. + return None + if has_pkginit: + return Package.from_parent(parent, path=path) + return None + + +def pytest_collect_file(file_path: Path, parent: nodes.Collector) -> Module | None: + if file_path.suffix == ".py": + if not parent.session.isinitpath(file_path): + if not path_matches_patterns( + file_path, parent.config.getini("python_files") + ): + return None + ihook = parent.session.gethookproxy(file_path) + module: Module = ihook.pytest_pycollect_makemodule( + module_path=file_path, parent=parent + ) + return module + return None + + +def path_matches_patterns(path: Path, patterns: Iterable[str]) -> bool: + """Return whether path matches any of the patterns in the list of globs given.""" + return any(fnmatch_ex(pattern, path) for pattern in patterns) + + +def pytest_pycollect_makemodule(module_path: Path, parent) -> Module: + return Module.from_parent(parent, path=module_path) + + +@hookimpl(trylast=True) +def pytest_pycollect_makeitem( + collector: Module | Class, name: str, obj: object +) -> None | nodes.Item | nodes.Collector | list[nodes.Item | nodes.Collector]: + assert isinstance(collector, (Class, Module)), type(collector) + # Nothing was collected elsewhere, let's do it here. + if safe_isclass(obj): + if collector.istestclass(obj, name): + return Class.from_parent(collector, name=name, obj=obj) + elif collector.istestfunction(obj, name): + # mock seems to store unbound methods (issue473), normalize it. + obj = getattr(obj, "__func__", obj) + # We need to try and unwrap the function if it's a functools.partial + # or a functools.wrapped. + # We mustn't if it's been wrapped with mock.patch (python 2 only). + if not (inspect.isfunction(obj) or inspect.isfunction(get_real_func(obj))): + filename, lineno = getfslineno(obj) + warnings.warn_explicit( + message=PytestCollectionWarning( + f"cannot collect {name!r} because it is not a function." + ), + category=None, + filename=str(filename), + lineno=lineno + 1, + ) + elif getattr(obj, "__test__", True): + if is_generator(obj): + res = Function.from_parent(collector, name=name) + reason = ( + f"yield tests were removed in pytest 4.0 - {name} will be ignored" + ) + res.add_marker(MARK_GEN.xfail(run=False, reason=reason)) + res.warn(PytestCollectionWarning(reason)) + return res + else: + return list(collector._genfunctions(name, obj)) + return None + + +class PyobjMixin(nodes.Node): + """this mix-in inherits from Node to carry over the typing information + + as its intended to always mix in before a node + its position in the mro is unaffected""" + + _ALLOW_MARKERS = True + + @property + def module(self): + """Python module object this node was collected from (can be None).""" + node = self.getparent(Module) + return node.obj if node is not None else None + + @property + def cls(self): + """Python class object this node was collected from (can be None).""" + node = self.getparent(Class) + return node.obj if node is not None else None + + @property + def instance(self): + """Python instance object the function is bound to. + + Returns None if not a test method, e.g. for a standalone test function, + a class or a module. + """ + # Overridden by Function. + return None + + @property + def obj(self): + """Underlying Python object.""" + obj = getattr(self, "_obj", None) + if obj is None: + self._obj = obj = self._getobj() + # XXX evil hack + # used to avoid Function marker duplication + if self._ALLOW_MARKERS: + self.own_markers.extend(get_unpacked_marks(self.obj)) + # This assumes that `obj` is called before there is a chance + # to add custom keys to `self.keywords`, so no fear of overriding. + self.keywords.update((mark.name, mark) for mark in self.own_markers) + return obj + + @obj.setter + def obj(self, value): + self._obj = value + + def _getobj(self): + """Get the underlying Python object. May be overwritten by subclasses.""" + # TODO: Improve the type of `parent` such that assert/ignore aren't needed. + assert self.parent is not None + obj = self.parent.obj # type: ignore[attr-defined] + return getattr(obj, self.name) + + def getmodpath(self, stopatmodule: bool = True, includemodule: bool = False) -> str: + """Return Python path relative to the containing module.""" + parts = [] + for node in self.iter_parents(): + name = node.name + if isinstance(node, Module): + name = os.path.splitext(name)[0] + if stopatmodule: + if includemodule: + parts.append(name) + break + parts.append(name) + parts.reverse() + return ".".join(parts) + + def reportinfo(self) -> tuple[os.PathLike[str] | str, int | None, str]: + # XXX caching? + path, lineno = getfslineno(self.obj) + modpath = self.getmodpath() + return path, lineno, modpath + + +# As an optimization, these builtin attribute names are pre-ignored when +# iterating over an object during collection -- the pytest_pycollect_makeitem +# hook is not called for them. +# fmt: off +class _EmptyClass: pass # noqa: E701 +IGNORED_ATTRIBUTES = frozenset.union( + frozenset(), + # Module. + dir(types.ModuleType("empty_module")), + # Some extra module attributes the above doesn't catch. + {"__builtins__", "__file__", "__cached__"}, + # Class. + dir(_EmptyClass), + # Instance. + dir(_EmptyClass()), +) +del _EmptyClass +# fmt: on + + +class PyCollector(PyobjMixin, nodes.Collector, abc.ABC): + def funcnamefilter(self, name: str) -> bool: + return self._matches_prefix_or_glob_option("python_functions", name) + + def isnosetest(self, obj: object) -> bool: + """Look for the __test__ attribute, which is applied by the + @nose.tools.istest decorator. + """ + # We explicitly check for "is True" here to not mistakenly treat + # classes with a custom __getattr__ returning something truthy (like a + # function) as test classes. + return safe_getattr(obj, "__test__", False) is True + + def classnamefilter(self, name: str) -> bool: + return self._matches_prefix_or_glob_option("python_classes", name) + + def istestfunction(self, obj: object, name: str) -> bool: + if self.funcnamefilter(name) or self.isnosetest(obj): + if isinstance(obj, (staticmethod, classmethod)): + # staticmethods and classmethods need to be unwrapped. + obj = safe_getattr(obj, "__func__", False) + return callable(obj) and fixtures.getfixturemarker(obj) is None + else: + return False + + def istestclass(self, obj: object, name: str) -> bool: + if not (self.classnamefilter(name) or self.isnosetest(obj)): + return False + if inspect.isabstract(obj): + return False + return True + + def _matches_prefix_or_glob_option(self, option_name: str, name: str) -> bool: + """Check if the given name matches the prefix or glob-pattern defined + in ini configuration.""" + for option in self.config.getini(option_name): + if name.startswith(option): + return True + # Check that name looks like a glob-string before calling fnmatch + # because this is called for every name in each collected module, + # and fnmatch is somewhat expensive to call. + elif ("*" in option or "?" in option or "[" in option) and fnmatch.fnmatch( + name, option + ): + return True + return False + + def collect(self) -> Iterable[nodes.Item | nodes.Collector]: + if not getattr(self.obj, "__test__", True): + return [] + + # Avoid random getattrs and peek in the __dict__ instead. + dicts = [getattr(self.obj, "__dict__", {})] + if isinstance(self.obj, type): + for basecls in self.obj.__mro__: + dicts.append(basecls.__dict__) + + # In each class, nodes should be definition ordered. + # __dict__ is definition ordered. + seen: set[str] = set() + dict_values: list[list[nodes.Item | nodes.Collector]] = [] + ihook = self.ihook + for dic in dicts: + values: list[nodes.Item | nodes.Collector] = [] + # Note: seems like the dict can change during iteration - + # be careful not to remove the list() without consideration. + for name, obj in list(dic.items()): + if name in IGNORED_ATTRIBUTES: + continue + if name in seen: + continue + seen.add(name) + res = ihook.pytest_pycollect_makeitem( + collector=self, name=name, obj=obj + ) + if res is None: + continue + elif isinstance(res, list): + values.extend(res) + else: + values.append(res) + dict_values.append(values) + + # Between classes in the class hierarchy, reverse-MRO order -- nodes + # inherited from base classes should come before subclasses. + result = [] + for values in reversed(dict_values): + result.extend(values) + return result + + def _genfunctions(self, name: str, funcobj) -> Iterator[Function]: + modulecol = self.getparent(Module) + assert modulecol is not None + module = modulecol.obj + clscol = self.getparent(Class) + cls = clscol and clscol.obj or None + + definition = FunctionDefinition.from_parent(self, name=name, callobj=funcobj) + fixtureinfo = definition._fixtureinfo + + # pytest_generate_tests impls call metafunc.parametrize() which fills + # metafunc._calls, the outcome of the hook. + metafunc = Metafunc( + definition=definition, + fixtureinfo=fixtureinfo, + config=self.config, + cls=cls, + module=module, + _ispytest=True, + ) + methods = [] + if hasattr(module, "pytest_generate_tests"): + methods.append(module.pytest_generate_tests) + if cls is not None and hasattr(cls, "pytest_generate_tests"): + methods.append(cls().pytest_generate_tests) + self.ihook.pytest_generate_tests.call_extra(methods, dict(metafunc=metafunc)) + + if not metafunc._calls: + yield Function.from_parent(self, name=name, fixtureinfo=fixtureinfo) + else: + # Direct parametrizations taking place in module/class-specific + # `metafunc.parametrize` calls may have shadowed some fixtures, so make sure + # we update what the function really needs a.k.a its fixture closure. Note that + # direct parametrizations using `@pytest.mark.parametrize` have already been considered + # into making the closure using `ignore_args` arg to `getfixtureclosure`. + fixtureinfo.prune_dependency_tree() + + for callspec in metafunc._calls: + subname = f"{name}[{callspec.id}]" + yield Function.from_parent( + self, + name=subname, + callspec=callspec, + fixtureinfo=fixtureinfo, + keywords={callspec.id: True}, + originalname=name, + ) + + +def importtestmodule( + path: Path, + config: Config, +): + # We assume we are only called once per module. + importmode = config.getoption("--import-mode") + try: + mod = import_path( + path, + mode=importmode, + root=config.rootpath, + consider_namespace_packages=config.getini("consider_namespace_packages"), + ) + except SyntaxError as e: + raise nodes.Collector.CollectError( + ExceptionInfo.from_current().getrepr(style="short") + ) from e + except ImportPathMismatchError as e: + raise nodes.Collector.CollectError( + "import file mismatch:\n" + "imported module {!r} has this __file__ attribute:\n" + " {}\n" + "which is not the same as the test file we want to collect:\n" + " {}\n" + "HINT: remove __pycache__ / .pyc files and/or use a " + "unique basename for your test file modules".format(*e.args) + ) from e + except ImportError as e: + exc_info = ExceptionInfo.from_current() + if config.get_verbosity() < 2: + exc_info.traceback = exc_info.traceback.filter(filter_traceback) + exc_repr = ( + exc_info.getrepr(style="short") + if exc_info.traceback + else exc_info.exconly() + ) + formatted_tb = str(exc_repr) + raise nodes.Collector.CollectError( + f"ImportError while importing test module '{path}'.\n" + "Hint: make sure your test modules/packages have valid Python names.\n" + "Traceback:\n" + f"{formatted_tb}" + ) from e + except skip.Exception as e: + if e.allow_module_level: + raise + raise nodes.Collector.CollectError( + "Using pytest.skip outside of a test will skip the entire module. " + "If that's your intention, pass `allow_module_level=True`. " + "If you want to skip a specific test or an entire class, " + "use the @pytest.mark.skip or @pytest.mark.skipif decorators." + ) from e + config.pluginmanager.consider_module(mod) + return mod + + +class Module(nodes.File, PyCollector): + """Collector for test classes and functions in a Python module.""" + + def _getobj(self): + return importtestmodule(self.path, self.config) + + def collect(self) -> Iterable[nodes.Item | nodes.Collector]: + self._register_setup_module_fixture() + self._register_setup_function_fixture() + self.session._fixturemanager.parsefactories(self) + return super().collect() + + def _register_setup_module_fixture(self) -> None: + """Register an autouse, module-scoped fixture for the collected module object + that invokes setUpModule/tearDownModule if either or both are available. + + Using a fixture to invoke this methods ensures we play nicely and unsurprisingly with + other fixtures (#517). + """ + setup_module = _get_first_non_fixture_func( + self.obj, ("setUpModule", "setup_module") + ) + teardown_module = _get_first_non_fixture_func( + self.obj, ("tearDownModule", "teardown_module") + ) + + if setup_module is None and teardown_module is None: + return + + def xunit_setup_module_fixture(request) -> Generator[None]: + module = request.module + if setup_module is not None: + _call_with_optional_argument(setup_module, module) + yield + if teardown_module is not None: + _call_with_optional_argument(teardown_module, module) + + self.session._fixturemanager._register_fixture( + # Use a unique name to speed up lookup. + name=f"_xunit_setup_module_fixture_{self.obj.__name__}", + func=xunit_setup_module_fixture, + nodeid=self.nodeid, + scope="module", + autouse=True, + ) + + def _register_setup_function_fixture(self) -> None: + """Register an autouse, function-scoped fixture for the collected module object + that invokes setup_function/teardown_function if either or both are available. + + Using a fixture to invoke this methods ensures we play nicely and unsurprisingly with + other fixtures (#517). + """ + setup_function = _get_first_non_fixture_func(self.obj, ("setup_function",)) + teardown_function = _get_first_non_fixture_func( + self.obj, ("teardown_function",) + ) + if setup_function is None and teardown_function is None: + return + + def xunit_setup_function_fixture(request) -> Generator[None]: + if request.instance is not None: + # in this case we are bound to an instance, so we need to let + # setup_method handle this + yield + return + function = request.function + if setup_function is not None: + _call_with_optional_argument(setup_function, function) + yield + if teardown_function is not None: + _call_with_optional_argument(teardown_function, function) + + self.session._fixturemanager._register_fixture( + # Use a unique name to speed up lookup. + name=f"_xunit_setup_function_fixture_{self.obj.__name__}", + func=xunit_setup_function_fixture, + nodeid=self.nodeid, + scope="function", + autouse=True, + ) + + +class Package(nodes.Directory): + """Collector for files and directories in a Python packages -- directories + with an `__init__.py` file. + + .. note:: + + Directories without an `__init__.py` file are instead collected by + :class:`~pytest.Dir` by default. Both are :class:`~pytest.Directory` + collectors. + + .. versionchanged:: 8.0 + + Now inherits from :class:`~pytest.Directory`. + """ + + def __init__( + self, + fspath: LEGACY_PATH | None, + parent: nodes.Collector, + # NOTE: following args are unused: + config=None, + session=None, + nodeid=None, + path: Path | None = None, + ) -> None: + # NOTE: Could be just the following, but kept as-is for compat. + # super().__init__(self, fspath, parent=parent) + session = parent.session + super().__init__( + fspath=fspath, + path=path, + parent=parent, + config=config, + session=session, + nodeid=nodeid, + ) + + def setup(self) -> None: + init_mod = importtestmodule(self.path / "__init__.py", self.config) + + # Not using fixtures to call setup_module here because autouse fixtures + # from packages are not called automatically (#4085). + setup_module = _get_first_non_fixture_func( + init_mod, ("setUpModule", "setup_module") + ) + if setup_module is not None: + _call_with_optional_argument(setup_module, init_mod) + + teardown_module = _get_first_non_fixture_func( + init_mod, ("tearDownModule", "teardown_module") + ) + if teardown_module is not None: + func = partial(_call_with_optional_argument, teardown_module, init_mod) + self.addfinalizer(func) + + def collect(self) -> Iterable[nodes.Item | nodes.Collector]: + # Always collect __init__.py first. + def sort_key(entry: os.DirEntry[str]) -> object: + return (entry.name != "__init__.py", entry.name) + + config = self.config + col: nodes.Collector | None + cols: Sequence[nodes.Collector] + ihook = self.ihook + for direntry in scandir(self.path, sort_key): + if direntry.is_dir(): + path = Path(direntry.path) + if not self.session.isinitpath(path, with_parents=True): + if ihook.pytest_ignore_collect(collection_path=path, config=config): + continue + col = ihook.pytest_collect_directory(path=path, parent=self) + if col is not None: + yield col + + elif direntry.is_file(): + path = Path(direntry.path) + if not self.session.isinitpath(path): + if ihook.pytest_ignore_collect(collection_path=path, config=config): + continue + cols = ihook.pytest_collect_file(file_path=path, parent=self) + yield from cols + + +def _call_with_optional_argument(func, arg) -> None: + """Call the given function with the given argument if func accepts one argument, otherwise + calls func without arguments.""" + arg_count = func.__code__.co_argcount + if inspect.ismethod(func): + arg_count -= 1 + if arg_count: + func(arg) + else: + func() + + +def _get_first_non_fixture_func(obj: object, names: Iterable[str]) -> object | None: + """Return the attribute from the given object to be used as a setup/teardown + xunit-style function, but only if not marked as a fixture to avoid calling it twice. + """ + for name in names: + meth: object | None = getattr(obj, name, None) + if meth is not None and fixtures.getfixturemarker(meth) is None: + return meth + return None + + +class Class(PyCollector): + """Collector for test methods (and nested classes) in a Python class.""" + + @classmethod + def from_parent(cls, parent, *, name, obj=None, **kw) -> Self: # type: ignore[override] + """The public constructor.""" + return super().from_parent(name=name, parent=parent, **kw) + + def newinstance(self): + return self.obj() + + def collect(self) -> Iterable[nodes.Item | nodes.Collector]: + if not safe_getattr(self.obj, "__test__", True): + return [] + if hasinit(self.obj): + assert self.parent is not None + self.warn( + PytestCollectionWarning( + f"cannot collect test class {self.obj.__name__!r} because it has a " + f"__init__ constructor (from: {self.parent.nodeid})" + ) + ) + return [] + elif hasnew(self.obj): + assert self.parent is not None + self.warn( + PytestCollectionWarning( + f"cannot collect test class {self.obj.__name__!r} because it has a " + f"__new__ constructor (from: {self.parent.nodeid})" + ) + ) + return [] + + self._register_setup_class_fixture() + self._register_setup_method_fixture() + + self.session._fixturemanager.parsefactories(self.newinstance(), self.nodeid) + + return super().collect() + + def _register_setup_class_fixture(self) -> None: + """Register an autouse, class scoped fixture into the collected class object + that invokes setup_class/teardown_class if either or both are available. + + Using a fixture to invoke this methods ensures we play nicely and unsurprisingly with + other fixtures (#517). + """ + setup_class = _get_first_non_fixture_func(self.obj, ("setup_class",)) + teardown_class = _get_first_non_fixture_func(self.obj, ("teardown_class",)) + if setup_class is None and teardown_class is None: + return + + def xunit_setup_class_fixture(request) -> Generator[None]: + cls = request.cls + if setup_class is not None: + func = getimfunc(setup_class) + _call_with_optional_argument(func, cls) + yield + if teardown_class is not None: + func = getimfunc(teardown_class) + _call_with_optional_argument(func, cls) + + self.session._fixturemanager._register_fixture( + # Use a unique name to speed up lookup. + name=f"_xunit_setup_class_fixture_{self.obj.__qualname__}", + func=xunit_setup_class_fixture, + nodeid=self.nodeid, + scope="class", + autouse=True, + ) + + def _register_setup_method_fixture(self) -> None: + """Register an autouse, function scoped fixture into the collected class object + that invokes setup_method/teardown_method if either or both are available. + + Using a fixture to invoke these methods ensures we play nicely and unsurprisingly with + other fixtures (#517). + """ + setup_name = "setup_method" + setup_method = _get_first_non_fixture_func(self.obj, (setup_name,)) + teardown_name = "teardown_method" + teardown_method = _get_first_non_fixture_func(self.obj, (teardown_name,)) + if setup_method is None and teardown_method is None: + return + + def xunit_setup_method_fixture(request) -> Generator[None]: + instance = request.instance + method = request.function + if setup_method is not None: + func = getattr(instance, setup_name) + _call_with_optional_argument(func, method) + yield + if teardown_method is not None: + func = getattr(instance, teardown_name) + _call_with_optional_argument(func, method) + + self.session._fixturemanager._register_fixture( + # Use a unique name to speed up lookup. + name=f"_xunit_setup_method_fixture_{self.obj.__qualname__}", + func=xunit_setup_method_fixture, + nodeid=self.nodeid, + scope="function", + autouse=True, + ) + + +def hasinit(obj: object) -> bool: + init: object = getattr(obj, "__init__", None) + if init: + return init != object.__init__ + return False + + +def hasnew(obj: object) -> bool: + new: object = getattr(obj, "__new__", None) + if new: + return new != object.__new__ + return False + + +@final +@dataclasses.dataclass(frozen=True) +class IdMaker: + """Make IDs for a parametrization.""" + + __slots__ = ( + "argnames", + "parametersets", + "idfn", + "ids", + "config", + "nodeid", + "func_name", + ) + + # The argnames of the parametrization. + argnames: Sequence[str] + # The ParameterSets of the parametrization. + parametersets: Sequence[ParameterSet] + # Optionally, a user-provided callable to make IDs for parameters in a + # ParameterSet. + idfn: Callable[[Any], object | None] | None + # Optionally, explicit IDs for ParameterSets by index. + ids: Sequence[object | None] | None + # Optionally, the pytest config. + # Used for controlling ASCII escaping, and for calling the + # :hook:`pytest_make_parametrize_id` hook. + config: Config | None + # Optionally, the ID of the node being parametrized. + # Used only for clearer error messages. + nodeid: str | None + # Optionally, the ID of the function being parametrized. + # Used only for clearer error messages. + func_name: str | None + + def make_unique_parameterset_ids(self) -> list[str]: + """Make a unique identifier for each ParameterSet, that may be used to + identify the parametrization in a node ID. + + Format is -...-[counter], where prm_x_token is + - user-provided id, if given + - else an id derived from the value, applicable for certain types + - else + The counter suffix is appended only in case a string wouldn't be unique + otherwise. + """ + resolved_ids = list(self._resolve_ids()) + # All IDs must be unique! + if len(resolved_ids) != len(set(resolved_ids)): + # Record the number of occurrences of each ID. + id_counts = Counter(resolved_ids) + # Map the ID to its next suffix. + id_suffixes: dict[str, int] = defaultdict(int) + # Suffix non-unique IDs to make them unique. + for index, id in enumerate(resolved_ids): + if id_counts[id] > 1: + suffix = "" + if id and id[-1].isdigit(): + suffix = "_" + new_id = f"{id}{suffix}{id_suffixes[id]}" + while new_id in set(resolved_ids): + id_suffixes[id] += 1 + new_id = f"{id}{suffix}{id_suffixes[id]}" + resolved_ids[index] = new_id + id_suffixes[id] += 1 + assert len(resolved_ids) == len( + set(resolved_ids) + ), f"Internal error: {resolved_ids=}" + return resolved_ids + + def _resolve_ids(self) -> Iterable[str]: + """Resolve IDs for all ParameterSets (may contain duplicates).""" + for idx, parameterset in enumerate(self.parametersets): + if parameterset.id is not None: + # ID provided directly - pytest.param(..., id="...") + yield parameterset.id + elif self.ids and idx < len(self.ids) and self.ids[idx] is not None: + # ID provided in the IDs list - parametrize(..., ids=[...]). + yield self._idval_from_value_required(self.ids[idx], idx) + else: + # ID not provided - generate it. + yield "-".join( + self._idval(val, argname, idx) + for val, argname in zip(parameterset.values, self.argnames) + ) + + def _idval(self, val: object, argname: str, idx: int) -> str: + """Make an ID for a parameter in a ParameterSet.""" + idval = self._idval_from_function(val, argname, idx) + if idval is not None: + return idval + idval = self._idval_from_hook(val, argname) + if idval is not None: + return idval + idval = self._idval_from_value(val) + if idval is not None: + return idval + return self._idval_from_argname(argname, idx) + + def _idval_from_function(self, val: object, argname: str, idx: int) -> str | None: + """Try to make an ID for a parameter in a ParameterSet using the + user-provided id callable, if given.""" + if self.idfn is None: + return None + try: + id = self.idfn(val) + except Exception as e: + prefix = f"{self.nodeid}: " if self.nodeid is not None else "" + msg = "error raised while trying to determine id of parameter '{}' at position {}" + msg = prefix + msg.format(argname, idx) + raise ValueError(msg) from e + if id is None: + return None + return self._idval_from_value(id) + + def _idval_from_hook(self, val: object, argname: str) -> str | None: + """Try to make an ID for a parameter in a ParameterSet by calling the + :hook:`pytest_make_parametrize_id` hook.""" + if self.config: + id: str | None = self.config.hook.pytest_make_parametrize_id( + config=self.config, val=val, argname=argname + ) + return id + return None + + def _idval_from_value(self, val: object) -> str | None: + """Try to make an ID for a parameter in a ParameterSet from its value, + if the value type is supported.""" + if isinstance(val, (str, bytes)): + return _ascii_escaped_by_config(val, self.config) + elif val is None or isinstance(val, (float, int, bool, complex)): + return str(val) + elif isinstance(val, Pattern): + return ascii_escaped(val.pattern) + elif val is NOTSET: + # Fallback to default. Note that NOTSET is an enum.Enum. + pass + elif isinstance(val, enum.Enum): + return str(val) + elif isinstance(getattr(val, "__name__", None), str): + # Name of a class, function, module, etc. + name: str = getattr(val, "__name__") + return name + return None + + def _idval_from_value_required(self, val: object, idx: int) -> str: + """Like _idval_from_value(), but fails if the type is not supported.""" + id = self._idval_from_value(val) + if id is not None: + return id + + # Fail. + if self.func_name is not None: + prefix = f"In {self.func_name}: " + elif self.nodeid is not None: + prefix = f"In {self.nodeid}: " + else: + prefix = "" + msg = ( + f"{prefix}ids contains unsupported value {saferepr(val)} (type: {type(val)!r}) at index {idx}. " + "Supported types are: str, bytes, int, float, complex, bool, enum, regex or anything with a __name__." + ) + fail(msg, pytrace=False) + + @staticmethod + def _idval_from_argname(argname: str, idx: int) -> str: + """Make an ID for a parameter in a ParameterSet from the argument name + and the index of the ParameterSet.""" + return str(argname) + str(idx) + + +@final +@dataclasses.dataclass(frozen=True) +class CallSpec2: + """A planned parameterized invocation of a test function. + + Calculated during collection for a given test function's Metafunc. + Once collection is over, each callspec is turned into a single Item + and stored in item.callspec. + """ + + # arg name -> arg value which will be passed to a fixture or pseudo-fixture + # of the same name. (indirect or direct parametrization respectively) + params: dict[str, object] = dataclasses.field(default_factory=dict) + # arg name -> arg index. + indices: dict[str, int] = dataclasses.field(default_factory=dict) + # Used for sorting parametrized resources. + _arg2scope: Mapping[str, Scope] = dataclasses.field(default_factory=dict) + # Parts which will be added to the item's name in `[..]` separated by "-". + _idlist: Sequence[str] = dataclasses.field(default_factory=tuple) + # Marks which will be applied to the item. + marks: list[Mark] = dataclasses.field(default_factory=list) + + def setmulti( + self, + *, + argnames: Iterable[str], + valset: Iterable[object], + id: str, + marks: Iterable[Mark | MarkDecorator], + scope: Scope, + param_index: int, + ) -> CallSpec2: + params = self.params.copy() + indices = self.indices.copy() + arg2scope = dict(self._arg2scope) + for arg, val in zip(argnames, valset): + if arg in params: + raise ValueError(f"duplicate parametrization of {arg!r}") + params[arg] = val + indices[arg] = param_index + arg2scope[arg] = scope + return CallSpec2( + params=params, + indices=indices, + _arg2scope=arg2scope, + _idlist=[*self._idlist, id], + marks=[*self.marks, *normalize_mark_list(marks)], + ) + + def getparam(self, name: str) -> object: + try: + return self.params[name] + except KeyError as e: + raise ValueError(name) from e + + @property + def id(self) -> str: + return "-".join(self._idlist) + + +def get_direct_param_fixture_func(request: FixtureRequest) -> Any: + return request.param + + +# Used for storing pseudo fixturedefs for direct parametrization. +name2pseudofixturedef_key = StashKey[Dict[str, FixtureDef[Any]]]() + + +@final +class Metafunc: + """Objects passed to the :hook:`pytest_generate_tests` hook. + + They help to inspect a test function and to generate tests according to + test configuration or values specified in the class or module where a + test function is defined. + """ + + def __init__( + self, + definition: FunctionDefinition, + fixtureinfo: fixtures.FuncFixtureInfo, + config: Config, + cls=None, + module=None, + *, + _ispytest: bool = False, + ) -> None: + check_ispytest(_ispytest) + + #: Access to the underlying :class:`_pytest.python.FunctionDefinition`. + self.definition = definition + + #: Access to the :class:`pytest.Config` object for the test session. + self.config = config + + #: The module object where the test function is defined in. + self.module = module + + #: Underlying Python test function. + self.function = definition.obj + + #: Set of fixture names required by the test function. + self.fixturenames = fixtureinfo.names_closure + + #: Class object where the test function is defined in or ``None``. + self.cls = cls + + self._arg2fixturedefs = fixtureinfo.name2fixturedefs + + # Result of parametrize(). + self._calls: list[CallSpec2] = [] + + def parametrize( + self, + argnames: str | Sequence[str], + argvalues: Iterable[ParameterSet | Sequence[object] | object], + indirect: bool | Sequence[str] = False, + ids: Iterable[object | None] | Callable[[Any], object | None] | None = None, + scope: _ScopeName | None = None, + *, + _param_mark: Mark | None = None, + ) -> None: + """Add new invocations to the underlying test function using the list + of argvalues for the given argnames. Parametrization is performed + during the collection phase. If you need to setup expensive resources + see about setting indirect to do it rather than at test setup time. + + Can be called multiple times per test function (but only on different + argument names), in which case each call parametrizes all previous + parametrizations, e.g. + + :: + + unparametrized: t + parametrize ["x", "y"]: t[x], t[y] + parametrize [1, 2]: t[x-1], t[x-2], t[y-1], t[y-2] + + :param argnames: + A comma-separated string denoting one or more argument names, or + a list/tuple of argument strings. + + :param argvalues: + The list of argvalues determines how often a test is invoked with + different argument values. + + If only one argname was specified argvalues is a list of values. + If N argnames were specified, argvalues must be a list of + N-tuples, where each tuple-element specifies a value for its + respective argname. + :type argvalues: Iterable[_pytest.mark.structures.ParameterSet | Sequence[object] | object] + :param indirect: + A list of arguments' names (subset of argnames) or a boolean. + If True the list contains all names from the argnames. Each + argvalue corresponding to an argname in this list will + be passed as request.param to its respective argname fixture + function so that it can perform more expensive setups during the + setup phase of a test rather than at collection time. + + :param ids: + Sequence of (or generator for) ids for ``argvalues``, + or a callable to return part of the id for each argvalue. + + With sequences (and generators like ``itertools.count()``) the + returned ids should be of type ``string``, ``int``, ``float``, + ``bool``, or ``None``. + They are mapped to the corresponding index in ``argvalues``. + ``None`` means to use the auto-generated id. + + If it is a callable it will be called for each entry in + ``argvalues``, and the return value is used as part of the + auto-generated id for the whole set (where parts are joined with + dashes ("-")). + This is useful to provide more specific ids for certain items, e.g. + dates. Returning ``None`` will use an auto-generated id. + + If no ids are provided they will be generated automatically from + the argvalues. + + :param scope: + If specified it denotes the scope of the parameters. + The scope is used for grouping tests by parameter instances. + It will also override any fixture-function defined scope, allowing + to set a dynamic scope using test context or configuration. + """ + argnames, parametersets = ParameterSet._for_parametrize( + argnames, + argvalues, + self.function, + self.config, + nodeid=self.definition.nodeid, + ) + del argvalues + + if "request" in argnames: + fail( + "'request' is a reserved name and cannot be used in @pytest.mark.parametrize", + pytrace=False, + ) + + if scope is not None: + scope_ = Scope.from_user( + scope, descr=f"parametrize() call in {self.function.__name__}" + ) + else: + scope_ = _find_parametrized_scope(argnames, self._arg2fixturedefs, indirect) + + self._validate_if_using_arg_names(argnames, indirect) + + # Use any already (possibly) generated ids with parametrize Marks. + if _param_mark and _param_mark._param_ids_from: + generated_ids = _param_mark._param_ids_from._param_ids_generated + if generated_ids is not None: + ids = generated_ids + + ids = self._resolve_parameter_set_ids( + argnames, ids, parametersets, nodeid=self.definition.nodeid + ) + + # Store used (possibly generated) ids with parametrize Marks. + if _param_mark and _param_mark._param_ids_from and generated_ids is None: + object.__setattr__(_param_mark._param_ids_from, "_param_ids_generated", ids) + + # Add funcargs as fixturedefs to fixtureinfo.arg2fixturedefs by registering + # artificial "pseudo" FixtureDef's so that later at test execution time we can + # rely on a proper FixtureDef to exist for fixture setup. + node = None + # If we have a scope that is higher than function, we need + # to make sure we only ever create an according fixturedef on + # a per-scope basis. We thus store and cache the fixturedef on the + # node related to the scope. + if scope_ is not Scope.Function: + collector = self.definition.parent + assert collector is not None + node = get_scope_node(collector, scope_) + if node is None: + # If used class scope and there is no class, use module-level + # collector (for now). + if scope_ is Scope.Class: + assert isinstance(collector, Module) + node = collector + # If used package scope and there is no package, use session + # (for now). + elif scope_ is Scope.Package: + node = collector.session + else: + assert False, f"Unhandled missing scope: {scope}" + if node is None: + name2pseudofixturedef = None + else: + default: dict[str, FixtureDef[Any]] = {} + name2pseudofixturedef = node.stash.setdefault( + name2pseudofixturedef_key, default + ) + arg_directness = self._resolve_args_directness(argnames, indirect) + for argname in argnames: + if arg_directness[argname] == "indirect": + continue + if name2pseudofixturedef is not None and argname in name2pseudofixturedef: + fixturedef = name2pseudofixturedef[argname] + else: + fixturedef = FixtureDef( + config=self.config, + baseid="", + argname=argname, + func=get_direct_param_fixture_func, + scope=scope_, + params=None, + ids=None, + _ispytest=True, + ) + if name2pseudofixturedef is not None: + name2pseudofixturedef[argname] = fixturedef + self._arg2fixturedefs[argname] = [fixturedef] + + # Create the new calls: if we are parametrize() multiple times (by applying the decorator + # more than once) then we accumulate those calls generating the cartesian product + # of all calls. + newcalls = [] + for callspec in self._calls or [CallSpec2()]: + for param_index, (param_id, param_set) in enumerate( + zip(ids, parametersets) + ): + newcallspec = callspec.setmulti( + argnames=argnames, + valset=param_set.values, + id=param_id, + marks=param_set.marks, + scope=scope_, + param_index=param_index, + ) + newcalls.append(newcallspec) + self._calls = newcalls + + def _resolve_parameter_set_ids( + self, + argnames: Sequence[str], + ids: Iterable[object | None] | Callable[[Any], object | None] | None, + parametersets: Sequence[ParameterSet], + nodeid: str, + ) -> list[str]: + """Resolve the actual ids for the given parameter sets. + + :param argnames: + Argument names passed to ``parametrize()``. + :param ids: + The `ids` parameter of the ``parametrize()`` call (see docs). + :param parametersets: + The parameter sets, each containing a set of values corresponding + to ``argnames``. + :param nodeid str: + The nodeid of the definition item that generated this + parametrization. + :returns: + List with ids for each parameter set given. + """ + if ids is None: + idfn = None + ids_ = None + elif callable(ids): + idfn = ids + ids_ = None + else: + idfn = None + ids_ = self._validate_ids(ids, parametersets, self.function.__name__) + id_maker = IdMaker( + argnames, + parametersets, + idfn, + ids_, + self.config, + nodeid=nodeid, + func_name=self.function.__name__, + ) + return id_maker.make_unique_parameterset_ids() + + def _validate_ids( + self, + ids: Iterable[object | None], + parametersets: Sequence[ParameterSet], + func_name: str, + ) -> list[object | None]: + try: + num_ids = len(ids) # type: ignore[arg-type] + except TypeError: + try: + iter(ids) + except TypeError as e: + raise TypeError("ids must be a callable or an iterable") from e + num_ids = len(parametersets) + + # num_ids == 0 is a special case: https://github.com/pytest-dev/pytest/issues/1849 + if num_ids != len(parametersets) and num_ids != 0: + msg = "In {}: {} parameter sets specified, with different number of ids: {}" + fail(msg.format(func_name, len(parametersets), num_ids), pytrace=False) + + return list(itertools.islice(ids, num_ids)) + + def _resolve_args_directness( + self, + argnames: Sequence[str], + indirect: bool | Sequence[str], + ) -> dict[str, Literal["indirect", "direct"]]: + """Resolve if each parametrized argument must be considered an indirect + parameter to a fixture of the same name, or a direct parameter to the + parametrized function, based on the ``indirect`` parameter of the + parametrized() call. + + :param argnames: + List of argument names passed to ``parametrize()``. + :param indirect: + Same as the ``indirect`` parameter of ``parametrize()``. + :returns + A dict mapping each arg name to either "indirect" or "direct". + """ + arg_directness: dict[str, Literal["indirect", "direct"]] + if isinstance(indirect, bool): + arg_directness = dict.fromkeys( + argnames, "indirect" if indirect else "direct" + ) + elif isinstance(indirect, Sequence): + arg_directness = dict.fromkeys(argnames, "direct") + for arg in indirect: + if arg not in argnames: + fail( + f"In {self.function.__name__}: indirect fixture '{arg}' doesn't exist", + pytrace=False, + ) + arg_directness[arg] = "indirect" + else: + fail( + f"In {self.function.__name__}: expected Sequence or boolean" + f" for indirect, got {type(indirect).__name__}", + pytrace=False, + ) + return arg_directness + + def _validate_if_using_arg_names( + self, + argnames: Sequence[str], + indirect: bool | Sequence[str], + ) -> None: + """Check if all argnames are being used, by default values, or directly/indirectly. + + :param List[str] argnames: List of argument names passed to ``parametrize()``. + :param indirect: Same as the ``indirect`` parameter of ``parametrize()``. + :raises ValueError: If validation fails. + """ + default_arg_names = set(get_default_arg_names(self.function)) + func_name = self.function.__name__ + for arg in argnames: + if arg not in self.fixturenames: + if arg in default_arg_names: + fail( + f"In {func_name}: function already takes an argument '{arg}' with a default value", + pytrace=False, + ) + else: + if isinstance(indirect, Sequence): + name = "fixture" if arg in indirect else "argument" + else: + name = "fixture" if indirect else "argument" + fail( + f"In {func_name}: function uses no {name} '{arg}'", + pytrace=False, + ) + + +def _find_parametrized_scope( + argnames: Sequence[str], + arg2fixturedefs: Mapping[str, Sequence[fixtures.FixtureDef[object]]], + indirect: bool | Sequence[str], +) -> Scope: + """Find the most appropriate scope for a parametrized call based on its arguments. + + When there's at least one direct argument, always use "function" scope. + + When a test function is parametrized and all its arguments are indirect + (e.g. fixtures), return the most narrow scope based on the fixtures used. + + Related to issue #1832, based on code posted by @Kingdread. + """ + if isinstance(indirect, Sequence): + all_arguments_are_fixtures = len(indirect) == len(argnames) + else: + all_arguments_are_fixtures = bool(indirect) + + if all_arguments_are_fixtures: + fixturedefs = arg2fixturedefs or {} + used_scopes = [ + fixturedef[-1]._scope + for name, fixturedef in fixturedefs.items() + if name in argnames + ] + # Takes the most narrow scope from used fixtures. + return min(used_scopes, default=Scope.Function) + + return Scope.Function + + +def _ascii_escaped_by_config(val: str | bytes, config: Config | None) -> str: + if config is None: + escape_option = False + else: + escape_option = config.getini( + "disable_test_id_escaping_and_forfeit_all_rights_to_community_support" + ) + # TODO: If escaping is turned off and the user passes bytes, + # will return a bytes. For now we ignore this but the + # code *probably* doesn't handle this case. + return val if escape_option else ascii_escaped(val) # type: ignore + + +class Function(PyobjMixin, nodes.Item): + """Item responsible for setting up and executing a Python test function. + + :param name: + The full function name, including any decorations like those + added by parametrization (``my_func[my_param]``). + :param parent: + The parent Node. + :param config: + The pytest Config object. + :param callspec: + If given, this function has been parametrized and the callspec contains + meta information about the parametrization. + :param callobj: + If given, the object which will be called when the Function is invoked, + otherwise the callobj will be obtained from ``parent`` using ``originalname``. + :param keywords: + Keywords bound to the function object for "-k" matching. + :param session: + The pytest Session object. + :param fixtureinfo: + Fixture information already resolved at this fixture node.. + :param originalname: + The attribute name to use for accessing the underlying function object. + Defaults to ``name``. Set this if name is different from the original name, + for example when it contains decorations like those added by parametrization + (``my_func[my_param]``). + """ + + # Disable since functions handle it themselves. + _ALLOW_MARKERS = False + + def __init__( + self, + name: str, + parent, + config: Config | None = None, + callspec: CallSpec2 | None = None, + callobj=NOTSET, + keywords: Mapping[str, Any] | None = None, + session: Session | None = None, + fixtureinfo: FuncFixtureInfo | None = None, + originalname: str | None = None, + ) -> None: + super().__init__(name, parent, config=config, session=session) + + if callobj is not NOTSET: + self._obj = callobj + self._instance = getattr(callobj, "__self__", None) + + #: Original function name, without any decorations (for example + #: parametrization adds a ``"[...]"`` suffix to function names), used to access + #: the underlying function object from ``parent`` (in case ``callobj`` is not given + #: explicitly). + #: + #: .. versionadded:: 3.0 + self.originalname = originalname or name + + # Note: when FunctionDefinition is introduced, we should change ``originalname`` + # to a readonly property that returns FunctionDefinition.name. + + self.own_markers.extend(get_unpacked_marks(self.obj)) + if callspec: + self.callspec = callspec + self.own_markers.extend(callspec.marks) + + # todo: this is a hell of a hack + # https://github.com/pytest-dev/pytest/issues/4569 + # Note: the order of the updates is important here; indicates what + # takes priority (ctor argument over function attributes over markers). + # Take own_markers only; NodeKeywords handles parent traversal on its own. + self.keywords.update((mark.name, mark) for mark in self.own_markers) + self.keywords.update(self.obj.__dict__) + if keywords: + self.keywords.update(keywords) + + if fixtureinfo is None: + fm = self.session._fixturemanager + fixtureinfo = fm.getfixtureinfo(self, self.obj, self.cls) + self._fixtureinfo: FuncFixtureInfo = fixtureinfo + self.fixturenames = fixtureinfo.names_closure + self._initrequest() + + # todo: determine sound type limitations + @classmethod + def from_parent(cls, parent, **kw) -> Self: + """The public constructor.""" + return super().from_parent(parent=parent, **kw) + + def _initrequest(self) -> None: + self.funcargs: dict[str, object] = {} + self._request = fixtures.TopRequest(self, _ispytest=True) + + @property + def function(self): + """Underlying python 'function' object.""" + return getimfunc(self.obj) + + @property + def instance(self): + try: + return self._instance + except AttributeError: + if isinstance(self.parent, Class): + # Each Function gets a fresh class instance. + self._instance = self._getinstance() + else: + self._instance = None + return self._instance + + def _getinstance(self): + if isinstance(self.parent, Class): + # Each Function gets a fresh class instance. + return self.parent.newinstance() + else: + return None + + def _getobj(self): + instance = self.instance + if instance is not None: + parent_obj = instance + else: + assert self.parent is not None + parent_obj = self.parent.obj # type: ignore[attr-defined] + return getattr(parent_obj, self.originalname) + + @property + def _pyfuncitem(self): + """(compatonly) for code expecting pytest-2.2 style request objects.""" + return self + + def runtest(self) -> None: + """Execute the underlying test function.""" + self.ihook.pytest_pyfunc_call(pyfuncitem=self) + + def setup(self) -> None: + self._request._fillfixtures() + + def _traceback_filter(self, excinfo: ExceptionInfo[BaseException]) -> Traceback: + if hasattr(self, "_obj") and not self.config.getoption("fulltrace", False): + code = _pytest._code.Code.from_function(get_real_func(self.obj)) + path, firstlineno = code.path, code.firstlineno + traceback = excinfo.traceback + ntraceback = traceback.cut(path=path, firstlineno=firstlineno) + if ntraceback == traceback: + ntraceback = ntraceback.cut(path=path) + if ntraceback == traceback: + ntraceback = ntraceback.filter(filter_traceback) + if not ntraceback: + ntraceback = traceback + ntraceback = ntraceback.filter(excinfo) + + # issue364: mark all but first and last frames to + # only show a single-line message for each frame. + if self.config.getoption("tbstyle", "auto") == "auto": + if len(ntraceback) > 2: + ntraceback = Traceback( + ( + ntraceback[0], + *(t.with_repr_style("short") for t in ntraceback[1:-1]), + ntraceback[-1], + ) + ) + + return ntraceback + return excinfo.traceback + + # TODO: Type ignored -- breaks Liskov Substitution. + def repr_failure( # type: ignore[override] + self, + excinfo: ExceptionInfo[BaseException], + ) -> str | TerminalRepr: + style = self.config.getoption("tbstyle", "auto") + if style == "auto": + style = "long" + return self._repr_failure_py(excinfo, style=style) + + +class FunctionDefinition(Function): + """This class is a stop gap solution until we evolve to have actual function + definition nodes and manage to get rid of ``metafunc``.""" + + def runtest(self) -> None: + raise RuntimeError("function definitions are not supposed to be run as tests") + + setup = runtest diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/python_api.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/python_api.py new file mode 100644 index 0000000..4174a55 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/python_api.py @@ -0,0 +1,1020 @@ +# mypy: allow-untyped-defs +from __future__ import annotations + +from collections.abc import Collection +from collections.abc import Sized +from decimal import Decimal +import math +from numbers import Complex +import pprint +import re +from types import TracebackType +from typing import Any +from typing import Callable +from typing import cast +from typing import ContextManager +from typing import final +from typing import Mapping +from typing import overload +from typing import Pattern +from typing import Sequence +from typing import Tuple +from typing import Type +from typing import TYPE_CHECKING +from typing import TypeVar + +import _pytest._code +from _pytest.outcomes import fail + + +if TYPE_CHECKING: + from numpy import ndarray + + +def _compare_approx( + full_object: object, + message_data: Sequence[tuple[str, str, str]], + number_of_elements: int, + different_ids: Sequence[object], + max_abs_diff: float, + max_rel_diff: float, +) -> list[str]: + message_list = list(message_data) + message_list.insert(0, ("Index", "Obtained", "Expected")) + max_sizes = [0, 0, 0] + for index, obtained, expected in message_list: + max_sizes[0] = max(max_sizes[0], len(index)) + max_sizes[1] = max(max_sizes[1], len(obtained)) + max_sizes[2] = max(max_sizes[2], len(expected)) + explanation = [ + f"comparison failed. Mismatched elements: {len(different_ids)} / {number_of_elements}:", + f"Max absolute difference: {max_abs_diff}", + f"Max relative difference: {max_rel_diff}", + ] + [ + f"{indexes:<{max_sizes[0]}} | {obtained:<{max_sizes[1]}} | {expected:<{max_sizes[2]}}" + for indexes, obtained, expected in message_list + ] + return explanation + + +# builtin pytest.approx helper + + +class ApproxBase: + """Provide shared utilities for making approximate comparisons between + numbers or sequences of numbers.""" + + # Tell numpy to use our `__eq__` operator instead of its. + __array_ufunc__ = None + __array_priority__ = 100 + + def __init__(self, expected, rel=None, abs=None, nan_ok: bool = False) -> None: + __tracebackhide__ = True + self.expected = expected + self.abs = abs + self.rel = rel + self.nan_ok = nan_ok + self._check_type() + + def __repr__(self) -> str: + raise NotImplementedError + + def _repr_compare(self, other_side: Any) -> list[str]: + return [ + "comparison failed", + f"Obtained: {other_side}", + f"Expected: {self}", + ] + + def __eq__(self, actual) -> bool: + return all( + a == self._approx_scalar(x) for a, x in self._yield_comparisons(actual) + ) + + def __bool__(self): + __tracebackhide__ = True + raise AssertionError( + "approx() is not supported in a boolean context.\nDid you mean: `assert a == approx(b)`?" + ) + + # Ignore type because of https://github.com/python/mypy/issues/4266. + __hash__ = None # type: ignore + + def __ne__(self, actual) -> bool: + return not (actual == self) + + def _approx_scalar(self, x) -> ApproxScalar: + if isinstance(x, Decimal): + return ApproxDecimal(x, rel=self.rel, abs=self.abs, nan_ok=self.nan_ok) + return ApproxScalar(x, rel=self.rel, abs=self.abs, nan_ok=self.nan_ok) + + def _yield_comparisons(self, actual): + """Yield all the pairs of numbers to be compared. + + This is used to implement the `__eq__` method. + """ + raise NotImplementedError + + def _check_type(self) -> None: + """Raise a TypeError if the expected value is not a valid type.""" + # This is only a concern if the expected value is a sequence. In every + # other case, the approx() function ensures that the expected value has + # a numeric type. For this reason, the default is to do nothing. The + # classes that deal with sequences should reimplement this method to + # raise if there are any non-numeric elements in the sequence. + + +def _recursive_sequence_map(f, x): + """Recursively map a function over a sequence of arbitrary depth""" + if isinstance(x, (list, tuple)): + seq_type = type(x) + return seq_type(_recursive_sequence_map(f, xi) for xi in x) + elif _is_sequence_like(x): + return [_recursive_sequence_map(f, xi) for xi in x] + else: + return f(x) + + +class ApproxNumpy(ApproxBase): + """Perform approximate comparisons where the expected value is numpy array.""" + + def __repr__(self) -> str: + list_scalars = _recursive_sequence_map( + self._approx_scalar, self.expected.tolist() + ) + return f"approx({list_scalars!r})" + + def _repr_compare(self, other_side: ndarray | list[Any]) -> list[str]: + import itertools + import math + + def get_value_from_nested_list( + nested_list: list[Any], nd_index: tuple[Any, ...] + ) -> Any: + """ + Helper function to get the value out of a nested list, given an n-dimensional index. + This mimics numpy's indexing, but for raw nested python lists. + """ + value: Any = nested_list + for i in nd_index: + value = value[i] + return value + + np_array_shape = self.expected.shape + approx_side_as_seq = _recursive_sequence_map( + self._approx_scalar, self.expected.tolist() + ) + + # convert other_side to numpy array to ensure shape attribute is available + other_side_as_array = _as_numpy_array(other_side) + assert other_side_as_array is not None + + if np_array_shape != other_side_as_array.shape: + return [ + "Impossible to compare arrays with different shapes.", + f"Shapes: {np_array_shape} and {other_side_as_array.shape}", + ] + + number_of_elements = self.expected.size + max_abs_diff = -math.inf + max_rel_diff = -math.inf + different_ids = [] + for index in itertools.product(*(range(i) for i in np_array_shape)): + approx_value = get_value_from_nested_list(approx_side_as_seq, index) + other_value = get_value_from_nested_list(other_side_as_array, index) + if approx_value != other_value: + abs_diff = abs(approx_value.expected - other_value) + max_abs_diff = max(max_abs_diff, abs_diff) + if other_value == 0.0: + max_rel_diff = math.inf + else: + max_rel_diff = max(max_rel_diff, abs_diff / abs(other_value)) + different_ids.append(index) + + message_data = [ + ( + str(index), + str(get_value_from_nested_list(other_side_as_array, index)), + str(get_value_from_nested_list(approx_side_as_seq, index)), + ) + for index in different_ids + ] + return _compare_approx( + self.expected, + message_data, + number_of_elements, + different_ids, + max_abs_diff, + max_rel_diff, + ) + + def __eq__(self, actual) -> bool: + import numpy as np + + # self.expected is supposed to always be an array here. + + if not np.isscalar(actual): + try: + actual = np.asarray(actual) + except Exception as e: + raise TypeError(f"cannot compare '{actual}' to numpy.ndarray") from e + + if not np.isscalar(actual) and actual.shape != self.expected.shape: + return False + + return super().__eq__(actual) + + def _yield_comparisons(self, actual): + import numpy as np + + # `actual` can either be a numpy array or a scalar, it is treated in + # `__eq__` before being passed to `ApproxBase.__eq__`, which is the + # only method that calls this one. + + if np.isscalar(actual): + for i in np.ndindex(self.expected.shape): + yield actual, self.expected[i].item() + else: + for i in np.ndindex(self.expected.shape): + yield actual[i].item(), self.expected[i].item() + + +class ApproxMapping(ApproxBase): + """Perform approximate comparisons where the expected value is a mapping + with numeric values (the keys can be anything).""" + + def __repr__(self) -> str: + return f"approx({({k: self._approx_scalar(v) for k, v in self.expected.items()})!r})" + + def _repr_compare(self, other_side: Mapping[object, float]) -> list[str]: + import math + + approx_side_as_map = { + k: self._approx_scalar(v) for k, v in self.expected.items() + } + + number_of_elements = len(approx_side_as_map) + max_abs_diff = -math.inf + max_rel_diff = -math.inf + different_ids = [] + for (approx_key, approx_value), other_value in zip( + approx_side_as_map.items(), other_side.values() + ): + if approx_value != other_value: + if approx_value.expected is not None and other_value is not None: + max_abs_diff = max( + max_abs_diff, abs(approx_value.expected - other_value) + ) + if approx_value.expected == 0.0: + max_rel_diff = math.inf + else: + max_rel_diff = max( + max_rel_diff, + abs( + (approx_value.expected - other_value) + / approx_value.expected + ), + ) + different_ids.append(approx_key) + + message_data = [ + (str(key), str(other_side[key]), str(approx_side_as_map[key])) + for key in different_ids + ] + + return _compare_approx( + self.expected, + message_data, + number_of_elements, + different_ids, + max_abs_diff, + max_rel_diff, + ) + + def __eq__(self, actual) -> bool: + try: + if set(actual.keys()) != set(self.expected.keys()): + return False + except AttributeError: + return False + + return super().__eq__(actual) + + def _yield_comparisons(self, actual): + for k in self.expected.keys(): + yield actual[k], self.expected[k] + + def _check_type(self) -> None: + __tracebackhide__ = True + for key, value in self.expected.items(): + if isinstance(value, type(self.expected)): + msg = "pytest.approx() does not support nested dictionaries: key={!r} value={!r}\n full mapping={}" + raise TypeError(msg.format(key, value, pprint.pformat(self.expected))) + + +class ApproxSequenceLike(ApproxBase): + """Perform approximate comparisons where the expected value is a sequence of numbers.""" + + def __repr__(self) -> str: + seq_type = type(self.expected) + if seq_type not in (tuple, list): + seq_type = list + return f"approx({seq_type(self._approx_scalar(x) for x in self.expected)!r})" + + def _repr_compare(self, other_side: Sequence[float]) -> list[str]: + import math + + if len(self.expected) != len(other_side): + return [ + "Impossible to compare lists with different sizes.", + f"Lengths: {len(self.expected)} and {len(other_side)}", + ] + + approx_side_as_map = _recursive_sequence_map(self._approx_scalar, self.expected) + + number_of_elements = len(approx_side_as_map) + max_abs_diff = -math.inf + max_rel_diff = -math.inf + different_ids = [] + for i, (approx_value, other_value) in enumerate( + zip(approx_side_as_map, other_side) + ): + if approx_value != other_value: + abs_diff = abs(approx_value.expected - other_value) + max_abs_diff = max(max_abs_diff, abs_diff) + if other_value == 0.0: + max_rel_diff = math.inf + else: + max_rel_diff = max(max_rel_diff, abs_diff / abs(other_value)) + different_ids.append(i) + + message_data = [ + (str(i), str(other_side[i]), str(approx_side_as_map[i])) + for i in different_ids + ] + + return _compare_approx( + self.expected, + message_data, + number_of_elements, + different_ids, + max_abs_diff, + max_rel_diff, + ) + + def __eq__(self, actual) -> bool: + try: + if len(actual) != len(self.expected): + return False + except TypeError: + return False + return super().__eq__(actual) + + def _yield_comparisons(self, actual): + return zip(actual, self.expected) + + def _check_type(self) -> None: + __tracebackhide__ = True + for index, x in enumerate(self.expected): + if isinstance(x, type(self.expected)): + msg = "pytest.approx() does not support nested data structures: {!r} at index {}\n full sequence: {}" + raise TypeError(msg.format(x, index, pprint.pformat(self.expected))) + + +class ApproxScalar(ApproxBase): + """Perform approximate comparisons where the expected value is a single number.""" + + # Using Real should be better than this Union, but not possible yet: + # https://github.com/python/typeshed/pull/3108 + DEFAULT_ABSOLUTE_TOLERANCE: float | Decimal = 1e-12 + DEFAULT_RELATIVE_TOLERANCE: float | Decimal = 1e-6 + + def __repr__(self) -> str: + """Return a string communicating both the expected value and the + tolerance for the comparison being made. + + For example, ``1.0 ± 1e-6``, ``(3+4j) ± 5e-6 ∠ ±180°``. + """ + # Don't show a tolerance for values that aren't compared using + # tolerances, i.e. non-numerics and infinities. Need to call abs to + # handle complex numbers, e.g. (inf + 1j). + if (not isinstance(self.expected, (Complex, Decimal))) or math.isinf( + abs(self.expected) + ): + return str(self.expected) + + # If a sensible tolerance can't be calculated, self.tolerance will + # raise a ValueError. In this case, display '???'. + try: + vetted_tolerance = f"{self.tolerance:.1e}" + if ( + isinstance(self.expected, Complex) + and self.expected.imag + and not math.isinf(self.tolerance) + ): + vetted_tolerance += " ∠ ±180°" + except ValueError: + vetted_tolerance = "???" + + return f"{self.expected} ± {vetted_tolerance}" + + def __eq__(self, actual) -> bool: + """Return whether the given value is equal to the expected value + within the pre-specified tolerance.""" + asarray = _as_numpy_array(actual) + if asarray is not None: + # Call ``__eq__()`` manually to prevent infinite-recursion with + # numpy<1.13. See #3748. + return all(self.__eq__(a) for a in asarray.flat) + + # Short-circuit exact equality. + if actual == self.expected: + return True + + # If either type is non-numeric, fall back to strict equality. + # NB: we need Complex, rather than just Number, to ensure that __abs__, + # __sub__, and __float__ are defined. + if not ( + isinstance(self.expected, (Complex, Decimal)) + and isinstance(actual, (Complex, Decimal)) + ): + return False + + # Allow the user to control whether NaNs are considered equal to each + # other or not. The abs() calls are for compatibility with complex + # numbers. + if math.isnan(abs(self.expected)): + return self.nan_ok and math.isnan(abs(actual)) + + # Infinity shouldn't be approximately equal to anything but itself, but + # if there's a relative tolerance, it will be infinite and infinity + # will seem approximately equal to everything. The equal-to-itself + # case would have been short circuited above, so here we can just + # return false if the expected value is infinite. The abs() call is + # for compatibility with complex numbers. + if math.isinf(abs(self.expected)): + return False + + # Return true if the two numbers are within the tolerance. + result: bool = abs(self.expected - actual) <= self.tolerance + return result + + # Ignore type because of https://github.com/python/mypy/issues/4266. + __hash__ = None # type: ignore + + @property + def tolerance(self): + """Return the tolerance for the comparison. + + This could be either an absolute tolerance or a relative tolerance, + depending on what the user specified or which would be larger. + """ + + def set_default(x, default): + return x if x is not None else default + + # Figure out what the absolute tolerance should be. ``self.abs`` is + # either None or a value specified by the user. + absolute_tolerance = set_default(self.abs, self.DEFAULT_ABSOLUTE_TOLERANCE) + + if absolute_tolerance < 0: + raise ValueError( + f"absolute tolerance can't be negative: {absolute_tolerance}" + ) + if math.isnan(absolute_tolerance): + raise ValueError("absolute tolerance can't be NaN.") + + # If the user specified an absolute tolerance but not a relative one, + # just return the absolute tolerance. + if self.rel is None: + if self.abs is not None: + return absolute_tolerance + + # Figure out what the relative tolerance should be. ``self.rel`` is + # either None or a value specified by the user. This is done after + # we've made sure the user didn't ask for an absolute tolerance only, + # because we don't want to raise errors about the relative tolerance if + # we aren't even going to use it. + relative_tolerance = set_default( + self.rel, self.DEFAULT_RELATIVE_TOLERANCE + ) * abs(self.expected) + + if relative_tolerance < 0: + raise ValueError( + f"relative tolerance can't be negative: {relative_tolerance}" + ) + if math.isnan(relative_tolerance): + raise ValueError("relative tolerance can't be NaN.") + + # Return the larger of the relative and absolute tolerances. + return max(relative_tolerance, absolute_tolerance) + + +class ApproxDecimal(ApproxScalar): + """Perform approximate comparisons where the expected value is a Decimal.""" + + DEFAULT_ABSOLUTE_TOLERANCE = Decimal("1e-12") + DEFAULT_RELATIVE_TOLERANCE = Decimal("1e-6") + + +def approx(expected, rel=None, abs=None, nan_ok: bool = False) -> ApproxBase: + """Assert that two numbers (or two ordered sequences of numbers) are equal to each other + within some tolerance. + + Due to the :doc:`python:tutorial/floatingpoint`, numbers that we + would intuitively expect to be equal are not always so:: + + >>> 0.1 + 0.2 == 0.3 + False + + This problem is commonly encountered when writing tests, e.g. when making + sure that floating-point values are what you expect them to be. One way to + deal with this problem is to assert that two floating-point numbers are + equal to within some appropriate tolerance:: + + >>> abs((0.1 + 0.2) - 0.3) < 1e-6 + True + + However, comparisons like this are tedious to write and difficult to + understand. Furthermore, absolute comparisons like the one above are + usually discouraged because there's no tolerance that works well for all + situations. ``1e-6`` is good for numbers around ``1``, but too small for + very big numbers and too big for very small ones. It's better to express + the tolerance as a fraction of the expected value, but relative comparisons + like that are even more difficult to write correctly and concisely. + + The ``approx`` class performs floating-point comparisons using a syntax + that's as intuitive as possible:: + + >>> from pytest import approx + >>> 0.1 + 0.2 == approx(0.3) + True + + The same syntax also works for ordered sequences of numbers:: + + >>> (0.1 + 0.2, 0.2 + 0.4) == approx((0.3, 0.6)) + True + + ``numpy`` arrays:: + + >>> import numpy as np # doctest: +SKIP + >>> np.array([0.1, 0.2]) + np.array([0.2, 0.4]) == approx(np.array([0.3, 0.6])) # doctest: +SKIP + True + + And for a ``numpy`` array against a scalar:: + + >>> import numpy as np # doctest: +SKIP + >>> np.array([0.1, 0.2]) + np.array([0.2, 0.1]) == approx(0.3) # doctest: +SKIP + True + + Only ordered sequences are supported, because ``approx`` needs + to infer the relative position of the sequences without ambiguity. This means + ``sets`` and other unordered sequences are not supported. + + Finally, dictionary *values* can also be compared:: + + >>> {'a': 0.1 + 0.2, 'b': 0.2 + 0.4} == approx({'a': 0.3, 'b': 0.6}) + True + + The comparison will be true if both mappings have the same keys and their + respective values match the expected tolerances. + + **Tolerances** + + By default, ``approx`` considers numbers within a relative tolerance of + ``1e-6`` (i.e. one part in a million) of its expected value to be equal. + This treatment would lead to surprising results if the expected value was + ``0.0``, because nothing but ``0.0`` itself is relatively close to ``0.0``. + To handle this case less surprisingly, ``approx`` also considers numbers + within an absolute tolerance of ``1e-12`` of its expected value to be + equal. Infinity and NaN are special cases. Infinity is only considered + equal to itself, regardless of the relative tolerance. NaN is not + considered equal to anything by default, but you can make it be equal to + itself by setting the ``nan_ok`` argument to True. (This is meant to + facilitate comparing arrays that use NaN to mean "no data".) + + Both the relative and absolute tolerances can be changed by passing + arguments to the ``approx`` constructor:: + + >>> 1.0001 == approx(1) + False + >>> 1.0001 == approx(1, rel=1e-3) + True + >>> 1.0001 == approx(1, abs=1e-3) + True + + If you specify ``abs`` but not ``rel``, the comparison will not consider + the relative tolerance at all. In other words, two numbers that are within + the default relative tolerance of ``1e-6`` will still be considered unequal + if they exceed the specified absolute tolerance. If you specify both + ``abs`` and ``rel``, the numbers will be considered equal if either + tolerance is met:: + + >>> 1 + 1e-8 == approx(1) + True + >>> 1 + 1e-8 == approx(1, abs=1e-12) + False + >>> 1 + 1e-8 == approx(1, rel=1e-6, abs=1e-12) + True + + You can also use ``approx`` to compare nonnumeric types, or dicts and + sequences containing nonnumeric types, in which case it falls back to + strict equality. This can be useful for comparing dicts and sequences that + can contain optional values:: + + >>> {"required": 1.0000005, "optional": None} == approx({"required": 1, "optional": None}) + True + >>> [None, 1.0000005] == approx([None,1]) + True + >>> ["foo", 1.0000005] == approx([None,1]) + False + + If you're thinking about using ``approx``, then you might want to know how + it compares to other good ways of comparing floating-point numbers. All of + these algorithms are based on relative and absolute tolerances and should + agree for the most part, but they do have meaningful differences: + + - ``math.isclose(a, b, rel_tol=1e-9, abs_tol=0.0)``: True if the relative + tolerance is met w.r.t. either ``a`` or ``b`` or if the absolute + tolerance is met. Because the relative tolerance is calculated w.r.t. + both ``a`` and ``b``, this test is symmetric (i.e. neither ``a`` nor + ``b`` is a "reference value"). You have to specify an absolute tolerance + if you want to compare to ``0.0`` because there is no tolerance by + default. More information: :py:func:`math.isclose`. + + - ``numpy.isclose(a, b, rtol=1e-5, atol=1e-8)``: True if the difference + between ``a`` and ``b`` is less that the sum of the relative tolerance + w.r.t. ``b`` and the absolute tolerance. Because the relative tolerance + is only calculated w.r.t. ``b``, this test is asymmetric and you can + think of ``b`` as the reference value. Support for comparing sequences + is provided by :py:func:`numpy.allclose`. More information: + :std:doc:`numpy:reference/generated/numpy.isclose`. + + - ``unittest.TestCase.assertAlmostEqual(a, b)``: True if ``a`` and ``b`` + are within an absolute tolerance of ``1e-7``. No relative tolerance is + considered , so this function is not appropriate for very large or very + small numbers. Also, it's only available in subclasses of ``unittest.TestCase`` + and it's ugly because it doesn't follow PEP8. More information: + :py:meth:`unittest.TestCase.assertAlmostEqual`. + + - ``a == pytest.approx(b, rel=1e-6, abs=1e-12)``: True if the relative + tolerance is met w.r.t. ``b`` or if the absolute tolerance is met. + Because the relative tolerance is only calculated w.r.t. ``b``, this test + is asymmetric and you can think of ``b`` as the reference value. In the + special case that you explicitly specify an absolute tolerance but not a + relative tolerance, only the absolute tolerance is considered. + + .. note:: + + ``approx`` can handle numpy arrays, but we recommend the + specialised test helpers in :std:doc:`numpy:reference/routines.testing` + if you need support for comparisons, NaNs, or ULP-based tolerances. + + To match strings using regex, you can use + `Matches `_ + from the + `re_assert package `_. + + .. warning:: + + .. versionchanged:: 3.2 + + In order to avoid inconsistent behavior, :py:exc:`TypeError` is + raised for ``>``, ``>=``, ``<`` and ``<=`` comparisons. + The example below illustrates the problem:: + + assert approx(0.1) > 0.1 + 1e-10 # calls approx(0.1).__gt__(0.1 + 1e-10) + assert 0.1 + 1e-10 > approx(0.1) # calls approx(0.1).__lt__(0.1 + 1e-10) + + In the second example one expects ``approx(0.1).__le__(0.1 + 1e-10)`` + to be called. But instead, ``approx(0.1).__lt__(0.1 + 1e-10)`` is used to + comparison. This is because the call hierarchy of rich comparisons + follows a fixed behavior. More information: :py:meth:`object.__ge__` + + .. versionchanged:: 3.7.1 + ``approx`` raises ``TypeError`` when it encounters a dict value or + sequence element of nonnumeric type. + + .. versionchanged:: 6.1.0 + ``approx`` falls back to strict equality for nonnumeric types instead + of raising ``TypeError``. + """ + # Delegate the comparison to a class that knows how to deal with the type + # of the expected value (e.g. int, float, list, dict, numpy.array, etc). + # + # The primary responsibility of these classes is to implement ``__eq__()`` + # and ``__repr__()``. The former is used to actually check if some + # "actual" value is equivalent to the given expected value within the + # allowed tolerance. The latter is used to show the user the expected + # value and tolerance, in the case that a test failed. + # + # The actual logic for making approximate comparisons can be found in + # ApproxScalar, which is used to compare individual numbers. All of the + # other Approx classes eventually delegate to this class. The ApproxBase + # class provides some convenient methods and overloads, but isn't really + # essential. + + __tracebackhide__ = True + + if isinstance(expected, Decimal): + cls: type[ApproxBase] = ApproxDecimal + elif isinstance(expected, Mapping): + cls = ApproxMapping + elif _is_numpy_array(expected): + expected = _as_numpy_array(expected) + cls = ApproxNumpy + elif _is_sequence_like(expected): + cls = ApproxSequenceLike + elif isinstance(expected, Collection) and not isinstance(expected, (str, bytes)): + msg = f"pytest.approx() only supports ordered sequences, but got: {expected!r}" + raise TypeError(msg) + else: + cls = ApproxScalar + + return cls(expected, rel, abs, nan_ok) + + +def _is_sequence_like(expected: object) -> bool: + return ( + hasattr(expected, "__getitem__") + and isinstance(expected, Sized) + and not isinstance(expected, (str, bytes)) + ) + + +def _is_numpy_array(obj: object) -> bool: + """ + Return true if the given object is implicitly convertible to ndarray, + and numpy is already imported. + """ + return _as_numpy_array(obj) is not None + + +def _as_numpy_array(obj: object) -> ndarray | None: + """ + Return an ndarray if the given object is implicitly convertible to ndarray, + and numpy is already imported, otherwise None. + """ + import sys + + np: Any = sys.modules.get("numpy") + if np is not None: + # avoid infinite recursion on numpy scalars, which have __array__ + if np.isscalar(obj): + return None + elif isinstance(obj, np.ndarray): + return obj + elif hasattr(obj, "__array__") or hasattr("obj", "__array_interface__"): + return np.asarray(obj) + return None + + +# builtin pytest.raises helper + +E = TypeVar("E", bound=BaseException) + + +@overload +def raises( + expected_exception: type[E] | tuple[type[E], ...], + *, + match: str | Pattern[str] | None = ..., +) -> RaisesContext[E]: ... + + +@overload +def raises( + expected_exception: type[E] | tuple[type[E], ...], + func: Callable[..., Any], + *args: Any, + **kwargs: Any, +) -> _pytest._code.ExceptionInfo[E]: ... + + +def raises( + expected_exception: type[E] | tuple[type[E], ...], *args: Any, **kwargs: Any +) -> RaisesContext[E] | _pytest._code.ExceptionInfo[E]: + r"""Assert that a code block/function call raises an exception type, or one of its subclasses. + + :param expected_exception: + The expected exception type, or a tuple if one of multiple possible + exception types are expected. Note that subclasses of the passed exceptions + will also match. + + :kwparam str | re.Pattern[str] | None match: + If specified, a string containing a regular expression, + or a regular expression object, that is tested against the string + representation of the exception and its :pep:`678` `__notes__` + using :func:`re.search`. + + To match a literal string that may contain :ref:`special characters + `, the pattern can first be escaped with :func:`re.escape`. + + (This is only used when ``pytest.raises`` is used as a context manager, + and passed through to the function otherwise. + When using ``pytest.raises`` as a function, you can use: + ``pytest.raises(Exc, func, match="passed on").match("my pattern")``.) + + Use ``pytest.raises`` as a context manager, which will capture the exception of the given + type, or any of its subclasses:: + + >>> import pytest + >>> with pytest.raises(ZeroDivisionError): + ... 1/0 + + If the code block does not raise the expected exception (:class:`ZeroDivisionError` in the example + above), or no exception at all, the check will fail instead. + + You can also use the keyword argument ``match`` to assert that the + exception matches a text or regex:: + + >>> with pytest.raises(ValueError, match='must be 0 or None'): + ... raise ValueError("value must be 0 or None") + + >>> with pytest.raises(ValueError, match=r'must be \d+$'): + ... raise ValueError("value must be 42") + + The ``match`` argument searches the formatted exception string, which includes any + `PEP-678 `__ ``__notes__``: + + >>> with pytest.raises(ValueError, match=r"had a note added"): # doctest: +SKIP + ... e = ValueError("value must be 42") + ... e.add_note("had a note added") + ... raise e + + The context manager produces an :class:`ExceptionInfo` object which can be used to inspect the + details of the captured exception:: + + >>> with pytest.raises(ValueError) as exc_info: + ... raise ValueError("value must be 42") + >>> assert exc_info.type is ValueError + >>> assert exc_info.value.args[0] == "value must be 42" + + .. warning:: + + Given that ``pytest.raises`` matches subclasses, be wary of using it to match :class:`Exception` like this:: + + with pytest.raises(Exception): # Careful, this will catch ANY exception raised. + some_function() + + Because :class:`Exception` is the base class of almost all exceptions, it is easy for this to hide + real bugs, where the user wrote this expecting a specific exception, but some other exception is being + raised due to a bug introduced during a refactoring. + + Avoid using ``pytest.raises`` to catch :class:`Exception` unless certain that you really want to catch + **any** exception raised. + + .. note:: + + When using ``pytest.raises`` as a context manager, it's worthwhile to + note that normal context manager rules apply and that the exception + raised *must* be the final line in the scope of the context manager. + Lines of code after that, within the scope of the context manager will + not be executed. For example:: + + >>> value = 15 + >>> with pytest.raises(ValueError) as exc_info: + ... if value > 10: + ... raise ValueError("value must be <= 10") + ... assert exc_info.type is ValueError # This will not execute. + + Instead, the following approach must be taken (note the difference in + scope):: + + >>> with pytest.raises(ValueError) as exc_info: + ... if value > 10: + ... raise ValueError("value must be <= 10") + ... + >>> assert exc_info.type is ValueError + + **Using with** ``pytest.mark.parametrize`` + + When using :ref:`pytest.mark.parametrize ref` + it is possible to parametrize tests such that + some runs raise an exception and others do not. + + See :ref:`parametrizing_conditional_raising` for an example. + + .. seealso:: + + :ref:`assertraises` for more examples and detailed discussion. + + **Legacy form** + + It is possible to specify a callable by passing a to-be-called lambda:: + + >>> raises(ZeroDivisionError, lambda: 1/0) + + + or you can specify an arbitrary callable with arguments:: + + >>> def f(x): return 1/x + ... + >>> raises(ZeroDivisionError, f, 0) + + >>> raises(ZeroDivisionError, f, x=0) + + + The form above is fully supported but discouraged for new code because the + context manager form is regarded as more readable and less error-prone. + + .. note:: + Similar to caught exception objects in Python, explicitly clearing + local references to returned ``ExceptionInfo`` objects can + help the Python interpreter speed up its garbage collection. + + Clearing those references breaks a reference cycle + (``ExceptionInfo`` --> caught exception --> frame stack raising + the exception --> current frame stack --> local variables --> + ``ExceptionInfo``) which makes Python keep all objects referenced + from that cycle (including all local variables in the current + frame) alive until the next cyclic garbage collection run. + More detailed information can be found in the official Python + documentation for :ref:`the try statement `. + """ + __tracebackhide__ = True + + if not expected_exception: + raise ValueError( + f"Expected an exception type or a tuple of exception types, but got `{expected_exception!r}`. " + f"Raising exceptions is already understood as failing the test, so you don't need " + f"any special code to say 'this should never raise an exception'." + ) + if isinstance(expected_exception, type): + expected_exceptions: tuple[type[E], ...] = (expected_exception,) + else: + expected_exceptions = expected_exception + for exc in expected_exceptions: + if not isinstance(exc, type) or not issubclass(exc, BaseException): + msg = "expected exception must be a BaseException type, not {}" # type: ignore[unreachable] + not_a = exc.__name__ if isinstance(exc, type) else type(exc).__name__ + raise TypeError(msg.format(not_a)) + + message = f"DID NOT RAISE {expected_exception}" + + if not args: + match: str | Pattern[str] | None = kwargs.pop("match", None) + if kwargs: + msg = "Unexpected keyword arguments passed to pytest.raises: " + msg += ", ".join(sorted(kwargs)) + msg += "\nUse context-manager form instead?" + raise TypeError(msg) + return RaisesContext(expected_exception, message, match) + else: + func = args[0] + if not callable(func): + raise TypeError(f"{func!r} object (type: {type(func)}) must be callable") + try: + func(*args[1:], **kwargs) + except expected_exception as e: + return _pytest._code.ExceptionInfo.from_exception(e) + fail(message) + + +# This doesn't work with mypy for now. Use fail.Exception instead. +raises.Exception = fail.Exception # type: ignore + + +@final +class RaisesContext(ContextManager[_pytest._code.ExceptionInfo[E]]): + def __init__( + self, + expected_exception: type[E] | tuple[type[E], ...], + message: str, + match_expr: str | Pattern[str] | None = None, + ) -> None: + self.expected_exception = expected_exception + self.message = message + self.match_expr = match_expr + self.excinfo: _pytest._code.ExceptionInfo[E] | None = None + if self.match_expr is not None: + re_error = None + try: + re.compile(self.match_expr) + except re.error as e: + re_error = e + if re_error is not None: + fail(f"Invalid regex pattern provided to 'match': {re_error}") + + def __enter__(self) -> _pytest._code.ExceptionInfo[E]: + self.excinfo = _pytest._code.ExceptionInfo.for_later() + return self.excinfo + + def __exit__( + self, + exc_type: type[BaseException] | None, + exc_val: BaseException | None, + exc_tb: TracebackType | None, + ) -> bool: + __tracebackhide__ = True + if exc_type is None: + fail(self.message) + assert self.excinfo is not None + if not issubclass(exc_type, self.expected_exception): + return False + # Cast to narrow the exception type now that it's verified. + exc_info = cast(Tuple[Type[E], E, TracebackType], (exc_type, exc_val, exc_tb)) + self.excinfo.fill_unfilled(exc_info) + if self.match_expr is not None: + self.excinfo.match(self.match_expr) + return True diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/python_path.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/python_path.py new file mode 100644 index 0000000..6e33c8a --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/python_path.py @@ -0,0 +1,26 @@ +from __future__ import annotations + +import sys + +import pytest +from pytest import Config +from pytest import Parser + + +def pytest_addoption(parser: Parser) -> None: + parser.addini("pythonpath", type="paths", help="Add paths to sys.path", default=[]) + + +@pytest.hookimpl(tryfirst=True) +def pytest_load_initial_conftests(early_config: Config) -> None: + # `pythonpath = a b` will set `sys.path` to `[a, b, x, y, z, ...]` + for path in reversed(early_config.getini("pythonpath")): + sys.path.insert(0, str(path)) + + +@pytest.hookimpl(trylast=True) +def pytest_unconfigure(config: Config) -> None: + for path in config.getini("pythonpath"): + path_str = str(path) + if path_str in sys.path: + sys.path.remove(path_str) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/recwarn.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/recwarn.py new file mode 100644 index 0000000..85d8de8 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/recwarn.py @@ -0,0 +1,365 @@ +# mypy: allow-untyped-defs +"""Record warnings during test function execution.""" + +from __future__ import annotations + +from pprint import pformat +import re +from types import TracebackType +from typing import Any +from typing import Callable +from typing import final +from typing import Generator +from typing import Iterator +from typing import overload +from typing import Pattern +from typing import TYPE_CHECKING +from typing import TypeVar + + +if TYPE_CHECKING: + from typing_extensions import Self + +import warnings + +from _pytest.deprecated import check_ispytest +from _pytest.fixtures import fixture +from _pytest.outcomes import Exit +from _pytest.outcomes import fail + + +T = TypeVar("T") + + +@fixture +def recwarn() -> Generator[WarningsRecorder]: + """Return a :class:`WarningsRecorder` instance that records all warnings emitted by test functions. + + See https://docs.pytest.org/en/latest/how-to/capture-warnings.html for information + on warning categories. + """ + wrec = WarningsRecorder(_ispytest=True) + with wrec: + warnings.simplefilter("default") + yield wrec + + +@overload +def deprecated_call(*, match: str | Pattern[str] | None = ...) -> WarningsRecorder: ... + + +@overload +def deprecated_call(func: Callable[..., T], *args: Any, **kwargs: Any) -> T: ... + + +def deprecated_call( + func: Callable[..., Any] | None = None, *args: Any, **kwargs: Any +) -> WarningsRecorder | Any: + """Assert that code produces a ``DeprecationWarning`` or ``PendingDeprecationWarning`` or ``FutureWarning``. + + This function can be used as a context manager:: + + >>> import warnings + >>> def api_call_v2(): + ... warnings.warn('use v3 of this api', DeprecationWarning) + ... return 200 + + >>> import pytest + >>> with pytest.deprecated_call(): + ... assert api_call_v2() == 200 + + It can also be used by passing a function and ``*args`` and ``**kwargs``, + in which case it will ensure calling ``func(*args, **kwargs)`` produces one of + the warnings types above. The return value is the return value of the function. + + In the context manager form you may use the keyword argument ``match`` to assert + that the warning matches a text or regex. + + The context manager produces a list of :class:`warnings.WarningMessage` objects, + one for each warning raised. + """ + __tracebackhide__ = True + if func is not None: + args = (func, *args) + return warns( + (DeprecationWarning, PendingDeprecationWarning, FutureWarning), *args, **kwargs + ) + + +@overload +def warns( + expected_warning: type[Warning] | tuple[type[Warning], ...] = ..., + *, + match: str | Pattern[str] | None = ..., +) -> WarningsChecker: ... + + +@overload +def warns( + expected_warning: type[Warning] | tuple[type[Warning], ...], + func: Callable[..., T], + *args: Any, + **kwargs: Any, +) -> T: ... + + +def warns( + expected_warning: type[Warning] | tuple[type[Warning], ...] = Warning, + *args: Any, + match: str | Pattern[str] | None = None, + **kwargs: Any, +) -> WarningsChecker | Any: + r"""Assert that code raises a particular class of warning. + + Specifically, the parameter ``expected_warning`` can be a warning class or tuple + of warning classes, and the code inside the ``with`` block must issue at least one + warning of that class or classes. + + This helper produces a list of :class:`warnings.WarningMessage` objects, one for + each warning emitted (regardless of whether it is an ``expected_warning`` or not). + Since pytest 8.0, unmatched warnings are also re-emitted when the context closes. + + This function can be used as a context manager:: + + >>> import pytest + >>> with pytest.warns(RuntimeWarning): + ... warnings.warn("my warning", RuntimeWarning) + + In the context manager form you may use the keyword argument ``match`` to assert + that the warning matches a text or regex:: + + >>> with pytest.warns(UserWarning, match='must be 0 or None'): + ... warnings.warn("value must be 0 or None", UserWarning) + + >>> with pytest.warns(UserWarning, match=r'must be \d+$'): + ... warnings.warn("value must be 42", UserWarning) + + >>> with pytest.warns(UserWarning): # catch re-emitted warning + ... with pytest.warns(UserWarning, match=r'must be \d+$'): + ... warnings.warn("this is not here", UserWarning) + Traceback (most recent call last): + ... + Failed: DID NOT WARN. No warnings of type ...UserWarning... were emitted... + + **Using with** ``pytest.mark.parametrize`` + + When using :ref:`pytest.mark.parametrize ref` it is possible to parametrize tests + such that some runs raise a warning and others do not. + + This could be achieved in the same way as with exceptions, see + :ref:`parametrizing_conditional_raising` for an example. + + """ + __tracebackhide__ = True + if not args: + if kwargs: + argnames = ", ".join(sorted(kwargs)) + raise TypeError( + f"Unexpected keyword arguments passed to pytest.warns: {argnames}" + "\nUse context-manager form instead?" + ) + return WarningsChecker(expected_warning, match_expr=match, _ispytest=True) + else: + func = args[0] + if not callable(func): + raise TypeError(f"{func!r} object (type: {type(func)}) must be callable") + with WarningsChecker(expected_warning, _ispytest=True): + return func(*args[1:], **kwargs) + + +class WarningsRecorder(warnings.catch_warnings): # type:ignore[type-arg] + """A context manager to record raised warnings. + + Each recorded warning is an instance of :class:`warnings.WarningMessage`. + + Adapted from `warnings.catch_warnings`. + + .. note:: + ``DeprecationWarning`` and ``PendingDeprecationWarning`` are treated + differently; see :ref:`ensuring_function_triggers`. + + """ + + def __init__(self, *, _ispytest: bool = False) -> None: + check_ispytest(_ispytest) + super().__init__(record=True) + self._entered = False + self._list: list[warnings.WarningMessage] = [] + + @property + def list(self) -> list[warnings.WarningMessage]: + """The list of recorded warnings.""" + return self._list + + def __getitem__(self, i: int) -> warnings.WarningMessage: + """Get a recorded warning by index.""" + return self._list[i] + + def __iter__(self) -> Iterator[warnings.WarningMessage]: + """Iterate through the recorded warnings.""" + return iter(self._list) + + def __len__(self) -> int: + """The number of recorded warnings.""" + return len(self._list) + + def pop(self, cls: type[Warning] = Warning) -> warnings.WarningMessage: + """Pop the first recorded warning which is an instance of ``cls``, + but not an instance of a child class of any other match. + Raises ``AssertionError`` if there is no match. + """ + best_idx: int | None = None + for i, w in enumerate(self._list): + if w.category == cls: + return self._list.pop(i) # exact match, stop looking + if issubclass(w.category, cls) and ( + best_idx is None + or not issubclass(w.category, self._list[best_idx].category) + ): + best_idx = i + if best_idx is not None: + return self._list.pop(best_idx) + __tracebackhide__ = True + raise AssertionError(f"{cls!r} not found in warning list") + + def clear(self) -> None: + """Clear the list of recorded warnings.""" + self._list[:] = [] + + def __enter__(self) -> Self: + if self._entered: + __tracebackhide__ = True + raise RuntimeError(f"Cannot enter {self!r} twice") + _list = super().__enter__() + # record=True means it's None. + assert _list is not None + self._list = _list + warnings.simplefilter("always") + return self + + def __exit__( + self, + exc_type: type[BaseException] | None, + exc_val: BaseException | None, + exc_tb: TracebackType | None, + ) -> None: + if not self._entered: + __tracebackhide__ = True + raise RuntimeError(f"Cannot exit {self!r} without entering first") + + super().__exit__(exc_type, exc_val, exc_tb) + + # Built-in catch_warnings does not reset entered state so we do it + # manually here for this context manager to become reusable. + self._entered = False + + +@final +class WarningsChecker(WarningsRecorder): + def __init__( + self, + expected_warning: type[Warning] | tuple[type[Warning], ...] = Warning, + match_expr: str | Pattern[str] | None = None, + *, + _ispytest: bool = False, + ) -> None: + check_ispytest(_ispytest) + super().__init__(_ispytest=True) + + msg = "exceptions must be derived from Warning, not %s" + if isinstance(expected_warning, tuple): + for exc in expected_warning: + if not issubclass(exc, Warning): + raise TypeError(msg % type(exc)) + expected_warning_tup = expected_warning + elif isinstance(expected_warning, type) and issubclass( + expected_warning, Warning + ): + expected_warning_tup = (expected_warning,) + else: + raise TypeError(msg % type(expected_warning)) + + self.expected_warning = expected_warning_tup + self.match_expr = match_expr + + def matches(self, warning: warnings.WarningMessage) -> bool: + assert self.expected_warning is not None + return issubclass(warning.category, self.expected_warning) and bool( + self.match_expr is None or re.search(self.match_expr, str(warning.message)) + ) + + def __exit__( + self, + exc_type: type[BaseException] | None, + exc_val: BaseException | None, + exc_tb: TracebackType | None, + ) -> None: + super().__exit__(exc_type, exc_val, exc_tb) + + __tracebackhide__ = True + + # BaseExceptions like pytest.{skip,fail,xfail,exit} or Ctrl-C within + # pytest.warns should *not* trigger "DID NOT WARN" and get suppressed + # when the warning doesn't happen. Control-flow exceptions should always + # propagate. + if exc_val is not None and ( + not isinstance(exc_val, Exception) + # Exit is an Exception, not a BaseException, for some reason. + or isinstance(exc_val, Exit) + ): + return + + def found_str() -> str: + return pformat([record.message for record in self], indent=2) + + try: + if not any(issubclass(w.category, self.expected_warning) for w in self): + fail( + f"DID NOT WARN. No warnings of type {self.expected_warning} were emitted.\n" + f" Emitted warnings: {found_str()}." + ) + elif not any(self.matches(w) for w in self): + fail( + f"DID NOT WARN. No warnings of type {self.expected_warning} matching the regex were emitted.\n" + f" Regex: {self.match_expr}\n" + f" Emitted warnings: {found_str()}." + ) + finally: + # Whether or not any warnings matched, we want to re-emit all unmatched warnings. + for w in self: + if not self.matches(w): + warnings.warn_explicit( + message=w.message, + category=w.category, + filename=w.filename, + lineno=w.lineno, + module=w.__module__, + source=w.source, + ) + + # Currently in Python it is possible to pass other types than an + # `str` message when creating `Warning` instances, however this + # causes an exception when :func:`warnings.filterwarnings` is used + # to filter those warnings. See + # https://github.com/python/cpython/issues/103577 for a discussion. + # While this can be considered a bug in CPython, we put guards in + # pytest as the error message produced without this check in place + # is confusing (#10865). + for w in self: + if type(w.message) is not UserWarning: + # If the warning was of an incorrect type then `warnings.warn()` + # creates a UserWarning. Any other warning must have been specified + # explicitly. + continue + if not w.message.args: + # UserWarning() without arguments must have been specified explicitly. + continue + msg = w.message.args[0] + if isinstance(msg, str): + continue + # It's possible that UserWarning was explicitly specified, and + # its first argument was not a string. But that case can't be + # distinguished from an invalid type. + raise TypeError( + f"Warning must be str or Warning, got {msg!r} (type {type(msg).__name__})" + ) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/reports.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/reports.py new file mode 100644 index 0000000..77cbf77 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/reports.py @@ -0,0 +1,636 @@ +# mypy: allow-untyped-defs +from __future__ import annotations + +import dataclasses +from io import StringIO +import os +from pprint import pprint +from typing import Any +from typing import cast +from typing import final +from typing import Iterable +from typing import Iterator +from typing import Literal +from typing import Mapping +from typing import NoReturn +from typing import Sequence +from typing import TYPE_CHECKING + +from _pytest._code.code import ExceptionChainRepr +from _pytest._code.code import ExceptionInfo +from _pytest._code.code import ExceptionRepr +from _pytest._code.code import ReprEntry +from _pytest._code.code import ReprEntryNative +from _pytest._code.code import ReprExceptionInfo +from _pytest._code.code import ReprFileLocation +from _pytest._code.code import ReprFuncArgs +from _pytest._code.code import ReprLocals +from _pytest._code.code import ReprTraceback +from _pytest._code.code import TerminalRepr +from _pytest._io import TerminalWriter +from _pytest.config import Config +from _pytest.nodes import Collector +from _pytest.nodes import Item +from _pytest.outcomes import fail +from _pytest.outcomes import skip + + +if TYPE_CHECKING: + from typing_extensions import Self + + from _pytest.runner import CallInfo + + +def getworkerinfoline(node): + try: + return node._workerinfocache + except AttributeError: + d = node.workerinfo + ver = "{}.{}.{}".format(*d["version_info"][:3]) + node._workerinfocache = s = "[{}] {} -- Python {} {}".format( + d["id"], d["sysplatform"], ver, d["executable"] + ) + return s + + +class BaseReport: + when: str | None + location: tuple[str, int | None, str] | None + longrepr: ( + None | ExceptionInfo[BaseException] | tuple[str, int, str] | str | TerminalRepr + ) + sections: list[tuple[str, str]] + nodeid: str + outcome: Literal["passed", "failed", "skipped"] + + def __init__(self, **kw: Any) -> None: + self.__dict__.update(kw) + + if TYPE_CHECKING: + # Can have arbitrary fields given to __init__(). + def __getattr__(self, key: str) -> Any: ... + + def toterminal(self, out: TerminalWriter) -> None: + if hasattr(self, "node"): + worker_info = getworkerinfoline(self.node) + if worker_info: + out.line(worker_info) + + longrepr = self.longrepr + if longrepr is None: + return + + if hasattr(longrepr, "toterminal"): + longrepr_terminal = cast(TerminalRepr, longrepr) + longrepr_terminal.toterminal(out) + else: + try: + s = str(longrepr) + except UnicodeEncodeError: + s = "" + out.line(s) + + def get_sections(self, prefix: str) -> Iterator[tuple[str, str]]: + for name, content in self.sections: + if name.startswith(prefix): + yield prefix, content + + @property + def longreprtext(self) -> str: + """Read-only property that returns the full string representation of + ``longrepr``. + + .. versionadded:: 3.0 + """ + file = StringIO() + tw = TerminalWriter(file) + tw.hasmarkup = False + self.toterminal(tw) + exc = file.getvalue() + return exc.strip() + + @property + def caplog(self) -> str: + """Return captured log lines, if log capturing is enabled. + + .. versionadded:: 3.5 + """ + return "\n".join( + content for (prefix, content) in self.get_sections("Captured log") + ) + + @property + def capstdout(self) -> str: + """Return captured text from stdout, if capturing is enabled. + + .. versionadded:: 3.0 + """ + return "".join( + content for (prefix, content) in self.get_sections("Captured stdout") + ) + + @property + def capstderr(self) -> str: + """Return captured text from stderr, if capturing is enabled. + + .. versionadded:: 3.0 + """ + return "".join( + content for (prefix, content) in self.get_sections("Captured stderr") + ) + + @property + def passed(self) -> bool: + """Whether the outcome is passed.""" + return self.outcome == "passed" + + @property + def failed(self) -> bool: + """Whether the outcome is failed.""" + return self.outcome == "failed" + + @property + def skipped(self) -> bool: + """Whether the outcome is skipped.""" + return self.outcome == "skipped" + + @property + def fspath(self) -> str: + """The path portion of the reported node, as a string.""" + return self.nodeid.split("::")[0] + + @property + def count_towards_summary(self) -> bool: + """**Experimental** Whether this report should be counted towards the + totals shown at the end of the test session: "1 passed, 1 failure, etc". + + .. note:: + + This function is considered **experimental**, so beware that it is subject to changes + even in patch releases. + """ + return True + + @property + def head_line(self) -> str | None: + """**Experimental** The head line shown with longrepr output for this + report, more commonly during traceback representation during + failures:: + + ________ Test.foo ________ + + + In the example above, the head_line is "Test.foo". + + .. note:: + + This function is considered **experimental**, so beware that it is subject to changes + even in patch releases. + """ + if self.location is not None: + fspath, lineno, domain = self.location + return domain + return None + + def _get_verbose_word_with_markup( + self, config: Config, default_markup: Mapping[str, bool] + ) -> tuple[str, Mapping[str, bool]]: + _category, _short, verbose = config.hook.pytest_report_teststatus( + report=self, config=config + ) + + if isinstance(verbose, str): + return verbose, default_markup + + if isinstance(verbose, Sequence) and len(verbose) == 2: + word, markup = verbose + if isinstance(word, str) and isinstance(markup, Mapping): + return word, markup + + fail( # pragma: no cover + "pytest_report_teststatus() hook (from a plugin) returned " + f"an invalid verbose value: {verbose!r}.\nExpected either a string " + "or a tuple of (word, markup)." + ) + + def _to_json(self) -> dict[str, Any]: + """Return the contents of this report as a dict of builtin entries, + suitable for serialization. + + This was originally the serialize_report() function from xdist (ca03269). + + Experimental method. + """ + return _report_to_json(self) + + @classmethod + def _from_json(cls, reportdict: dict[str, object]) -> Self: + """Create either a TestReport or CollectReport, depending on the calling class. + + It is the callers responsibility to know which class to pass here. + + This was originally the serialize_report() function from xdist (ca03269). + + Experimental method. + """ + kwargs = _report_kwargs_from_json(reportdict) + return cls(**kwargs) + + +def _report_unserialization_failure( + type_name: str, report_class: type[BaseReport], reportdict +) -> NoReturn: + url = "https://github.com/pytest-dev/pytest/issues" + stream = StringIO() + pprint("-" * 100, stream=stream) + pprint(f"INTERNALERROR: Unknown entry type returned: {type_name}", stream=stream) + pprint(f"report_name: {report_class}", stream=stream) + pprint(reportdict, stream=stream) + pprint(f"Please report this bug at {url}", stream=stream) + pprint("-" * 100, stream=stream) + raise RuntimeError(stream.getvalue()) + + +@final +class TestReport(BaseReport): + """Basic test report object (also used for setup and teardown calls if + they fail). + + Reports can contain arbitrary extra attributes. + """ + + __test__ = False + # Defined by skipping plugin. + # xfail reason if xfailed, otherwise not defined. Use hasattr to distinguish. + wasxfail: str + + def __init__( + self, + nodeid: str, + location: tuple[str, int | None, str], + keywords: Mapping[str, Any], + outcome: Literal["passed", "failed", "skipped"], + longrepr: None + | ExceptionInfo[BaseException] + | tuple[str, int, str] + | str + | TerminalRepr, + when: Literal["setup", "call", "teardown"], + sections: Iterable[tuple[str, str]] = (), + duration: float = 0, + start: float = 0, + stop: float = 0, + user_properties: Iterable[tuple[str, object]] | None = None, + **extra, + ) -> None: + #: Normalized collection nodeid. + self.nodeid = nodeid + + #: A (filesystempath, lineno, domaininfo) tuple indicating the + #: actual location of a test item - it might be different from the + #: collected one e.g. if a method is inherited from a different module. + #: The filesystempath may be relative to ``config.rootdir``. + #: The line number is 0-based. + self.location: tuple[str, int | None, str] = location + + #: A name -> value dictionary containing all keywords and + #: markers associated with a test invocation. + self.keywords: Mapping[str, Any] = keywords + + #: Test outcome, always one of "passed", "failed", "skipped". + self.outcome = outcome + + #: None or a failure representation. + self.longrepr = longrepr + + #: One of 'setup', 'call', 'teardown' to indicate runtest phase. + self.when = when + + #: User properties is a list of tuples (name, value) that holds user + #: defined properties of the test. + self.user_properties = list(user_properties or []) + + #: Tuples of str ``(heading, content)`` with extra information + #: for the test report. Used by pytest to add text captured + #: from ``stdout``, ``stderr``, and intercepted logging events. May + #: be used by other plugins to add arbitrary information to reports. + self.sections = list(sections) + + #: Time it took to run just the test. + self.duration: float = duration + + #: The system time when the call started, in seconds since the epoch. + self.start: float = start + #: The system time when the call ended, in seconds since the epoch. + self.stop: float = stop + + self.__dict__.update(extra) + + def __repr__(self) -> str: + return f"<{self.__class__.__name__} {self.nodeid!r} when={self.when!r} outcome={self.outcome!r}>" + + @classmethod + def from_item_and_call(cls, item: Item, call: CallInfo[None]) -> TestReport: + """Create and fill a TestReport with standard item and call info. + + :param item: The item. + :param call: The call info. + """ + when = call.when + # Remove "collect" from the Literal type -- only for collection calls. + assert when != "collect" + duration = call.duration + start = call.start + stop = call.stop + keywords = {x: 1 for x in item.keywords} + excinfo = call.excinfo + sections = [] + if not call.excinfo: + outcome: Literal["passed", "failed", "skipped"] = "passed" + longrepr: ( + None + | ExceptionInfo[BaseException] + | tuple[str, int, str] + | str + | TerminalRepr + ) = None + else: + if not isinstance(excinfo, ExceptionInfo): + outcome = "failed" + longrepr = excinfo + elif isinstance(excinfo.value, skip.Exception): + outcome = "skipped" + r = excinfo._getreprcrash() + assert ( + r is not None + ), "There should always be a traceback entry for skipping a test." + if excinfo.value._use_item_location: + path, line = item.reportinfo()[:2] + assert line is not None + longrepr = os.fspath(path), line + 1, r.message + else: + longrepr = (str(r.path), r.lineno, r.message) + else: + outcome = "failed" + if call.when == "call": + longrepr = item.repr_failure(excinfo) + else: # exception in setup or teardown + longrepr = item._repr_failure_py( + excinfo, style=item.config.getoption("tbstyle", "auto") + ) + for rwhen, key, content in item._report_sections: + sections.append((f"Captured {key} {rwhen}", content)) + return cls( + item.nodeid, + item.location, + keywords, + outcome, + longrepr, + when, + sections, + duration, + start, + stop, + user_properties=item.user_properties, + ) + + +@final +class CollectReport(BaseReport): + """Collection report object. + + Reports can contain arbitrary extra attributes. + """ + + when = "collect" + + def __init__( + self, + nodeid: str, + outcome: Literal["passed", "failed", "skipped"], + longrepr: None + | ExceptionInfo[BaseException] + | tuple[str, int, str] + | str + | TerminalRepr, + result: list[Item | Collector] | None, + sections: Iterable[tuple[str, str]] = (), + **extra, + ) -> None: + #: Normalized collection nodeid. + self.nodeid = nodeid + + #: Test outcome, always one of "passed", "failed", "skipped". + self.outcome = outcome + + #: None or a failure representation. + self.longrepr = longrepr + + #: The collected items and collection nodes. + self.result = result or [] + + #: Tuples of str ``(heading, content)`` with extra information + #: for the test report. Used by pytest to add text captured + #: from ``stdout``, ``stderr``, and intercepted logging events. May + #: be used by other plugins to add arbitrary information to reports. + self.sections = list(sections) + + self.__dict__.update(extra) + + @property + def location( # type:ignore[override] + self, + ) -> tuple[str, int | None, str] | None: + return (self.fspath, None, self.fspath) + + def __repr__(self) -> str: + return f"" + + +class CollectErrorRepr(TerminalRepr): + def __init__(self, msg: str) -> None: + self.longrepr = msg + + def toterminal(self, out: TerminalWriter) -> None: + out.line(self.longrepr, red=True) + + +def pytest_report_to_serializable( + report: CollectReport | TestReport, +) -> dict[str, Any] | None: + if isinstance(report, (TestReport, CollectReport)): + data = report._to_json() + data["$report_type"] = report.__class__.__name__ + return data + # TODO: Check if this is actually reachable. + return None # type: ignore[unreachable] + + +def pytest_report_from_serializable( + data: dict[str, Any], +) -> CollectReport | TestReport | None: + if "$report_type" in data: + if data["$report_type"] == "TestReport": + return TestReport._from_json(data) + elif data["$report_type"] == "CollectReport": + return CollectReport._from_json(data) + assert False, "Unknown report_type unserialize data: {}".format( + data["$report_type"] + ) + return None + + +def _report_to_json(report: BaseReport) -> dict[str, Any]: + """Return the contents of this report as a dict of builtin entries, + suitable for serialization. + + This was originally the serialize_report() function from xdist (ca03269). + """ + + def serialize_repr_entry( + entry: ReprEntry | ReprEntryNative, + ) -> dict[str, Any]: + data = dataclasses.asdict(entry) + for key, value in data.items(): + if hasattr(value, "__dict__"): + data[key] = dataclasses.asdict(value) + entry_data = {"type": type(entry).__name__, "data": data} + return entry_data + + def serialize_repr_traceback(reprtraceback: ReprTraceback) -> dict[str, Any]: + result = dataclasses.asdict(reprtraceback) + result["reprentries"] = [ + serialize_repr_entry(x) for x in reprtraceback.reprentries + ] + return result + + def serialize_repr_crash( + reprcrash: ReprFileLocation | None, + ) -> dict[str, Any] | None: + if reprcrash is not None: + return dataclasses.asdict(reprcrash) + else: + return None + + def serialize_exception_longrepr(rep: BaseReport) -> dict[str, Any]: + assert rep.longrepr is not None + # TODO: Investigate whether the duck typing is really necessary here. + longrepr = cast(ExceptionRepr, rep.longrepr) + result: dict[str, Any] = { + "reprcrash": serialize_repr_crash(longrepr.reprcrash), + "reprtraceback": serialize_repr_traceback(longrepr.reprtraceback), + "sections": longrepr.sections, + } + if isinstance(longrepr, ExceptionChainRepr): + result["chain"] = [] + for repr_traceback, repr_crash, description in longrepr.chain: + result["chain"].append( + ( + serialize_repr_traceback(repr_traceback), + serialize_repr_crash(repr_crash), + description, + ) + ) + else: + result["chain"] = None + return result + + d = report.__dict__.copy() + if hasattr(report.longrepr, "toterminal"): + if hasattr(report.longrepr, "reprtraceback") and hasattr( + report.longrepr, "reprcrash" + ): + d["longrepr"] = serialize_exception_longrepr(report) + else: + d["longrepr"] = str(report.longrepr) + else: + d["longrepr"] = report.longrepr + for name in d: + if isinstance(d[name], os.PathLike): + d[name] = os.fspath(d[name]) + elif name == "result": + d[name] = None # for now + return d + + +def _report_kwargs_from_json(reportdict: dict[str, Any]) -> dict[str, Any]: + """Return **kwargs that can be used to construct a TestReport or + CollectReport instance. + + This was originally the serialize_report() function from xdist (ca03269). + """ + + def deserialize_repr_entry(entry_data): + data = entry_data["data"] + entry_type = entry_data["type"] + if entry_type == "ReprEntry": + reprfuncargs = None + reprfileloc = None + reprlocals = None + if data["reprfuncargs"]: + reprfuncargs = ReprFuncArgs(**data["reprfuncargs"]) + if data["reprfileloc"]: + reprfileloc = ReprFileLocation(**data["reprfileloc"]) + if data["reprlocals"]: + reprlocals = ReprLocals(data["reprlocals"]["lines"]) + + reprentry: ReprEntry | ReprEntryNative = ReprEntry( + lines=data["lines"], + reprfuncargs=reprfuncargs, + reprlocals=reprlocals, + reprfileloc=reprfileloc, + style=data["style"], + ) + elif entry_type == "ReprEntryNative": + reprentry = ReprEntryNative(data["lines"]) + else: + _report_unserialization_failure(entry_type, TestReport, reportdict) + return reprentry + + def deserialize_repr_traceback(repr_traceback_dict): + repr_traceback_dict["reprentries"] = [ + deserialize_repr_entry(x) for x in repr_traceback_dict["reprentries"] + ] + return ReprTraceback(**repr_traceback_dict) + + def deserialize_repr_crash(repr_crash_dict: dict[str, Any] | None): + if repr_crash_dict is not None: + return ReprFileLocation(**repr_crash_dict) + else: + return None + + if ( + reportdict["longrepr"] + and "reprcrash" in reportdict["longrepr"] + and "reprtraceback" in reportdict["longrepr"] + ): + reprtraceback = deserialize_repr_traceback( + reportdict["longrepr"]["reprtraceback"] + ) + reprcrash = deserialize_repr_crash(reportdict["longrepr"]["reprcrash"]) + if reportdict["longrepr"]["chain"]: + chain = [] + for repr_traceback_data, repr_crash_data, description in reportdict[ + "longrepr" + ]["chain"]: + chain.append( + ( + deserialize_repr_traceback(repr_traceback_data), + deserialize_repr_crash(repr_crash_data), + description, + ) + ) + exception_info: ExceptionChainRepr | ReprExceptionInfo = ExceptionChainRepr( + chain + ) + else: + exception_info = ReprExceptionInfo( + reprtraceback=reprtraceback, + reprcrash=reprcrash, + ) + + for section in reportdict["longrepr"]["sections"]: + exception_info.addsection(*section) + reportdict["longrepr"] = exception_info + + return reportdict diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/runner.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/runner.py new file mode 100644 index 0000000..0b60301 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/runner.py @@ -0,0 +1,571 @@ +# mypy: allow-untyped-defs +"""Basic collect and runtest protocol implementations.""" + +from __future__ import annotations + +import bdb +import dataclasses +import os +import sys +import types +from typing import Callable +from typing import cast +from typing import final +from typing import Generic +from typing import Literal +from typing import TYPE_CHECKING +from typing import TypeVar + +from .reports import BaseReport +from .reports import CollectErrorRepr +from .reports import CollectReport +from .reports import TestReport +from _pytest import timing +from _pytest._code.code import ExceptionChainRepr +from _pytest._code.code import ExceptionInfo +from _pytest._code.code import TerminalRepr +from _pytest.config.argparsing import Parser +from _pytest.deprecated import check_ispytest +from _pytest.nodes import Collector +from _pytest.nodes import Directory +from _pytest.nodes import Item +from _pytest.nodes import Node +from _pytest.outcomes import Exit +from _pytest.outcomes import OutcomeException +from _pytest.outcomes import Skipped +from _pytest.outcomes import TEST_OUTCOME + + +if sys.version_info < (3, 11): + from exceptiongroup import BaseExceptionGroup + +if TYPE_CHECKING: + from _pytest.main import Session + from _pytest.terminal import TerminalReporter + +# +# pytest plugin hooks. + + +def pytest_addoption(parser: Parser) -> None: + group = parser.getgroup("terminal reporting", "Reporting", after="general") + group.addoption( + "--durations", + action="store", + type=int, + default=None, + metavar="N", + help="Show N slowest setup/test durations (N=0 for all)", + ) + group.addoption( + "--durations-min", + action="store", + type=float, + default=0.005, + metavar="N", + help="Minimal duration in seconds for inclusion in slowest list. " + "Default: 0.005.", + ) + + +def pytest_terminal_summary(terminalreporter: TerminalReporter) -> None: + durations = terminalreporter.config.option.durations + durations_min = terminalreporter.config.option.durations_min + verbose = terminalreporter.config.get_verbosity() + if durations is None: + return + tr = terminalreporter + dlist = [] + for replist in tr.stats.values(): + for rep in replist: + if hasattr(rep, "duration"): + dlist.append(rep) + if not dlist: + return + dlist.sort(key=lambda x: x.duration, reverse=True) + if not durations: + tr.write_sep("=", "slowest durations") + else: + tr.write_sep("=", f"slowest {durations} durations") + dlist = dlist[:durations] + + for i, rep in enumerate(dlist): + if verbose < 2 and rep.duration < durations_min: + tr.write_line("") + tr.write_line( + f"({len(dlist) - i} durations < {durations_min:g}s hidden. Use -vv to show these durations.)" + ) + break + tr.write_line(f"{rep.duration:02.2f}s {rep.when:<8} {rep.nodeid}") + + +def pytest_sessionstart(session: Session) -> None: + session._setupstate = SetupState() + + +def pytest_sessionfinish(session: Session) -> None: + session._setupstate.teardown_exact(None) + + +def pytest_runtest_protocol(item: Item, nextitem: Item | None) -> bool: + ihook = item.ihook + ihook.pytest_runtest_logstart(nodeid=item.nodeid, location=item.location) + runtestprotocol(item, nextitem=nextitem) + ihook.pytest_runtest_logfinish(nodeid=item.nodeid, location=item.location) + return True + + +def runtestprotocol( + item: Item, log: bool = True, nextitem: Item | None = None +) -> list[TestReport]: + hasrequest = hasattr(item, "_request") + if hasrequest and not item._request: # type: ignore[attr-defined] + # This only happens if the item is re-run, as is done by + # pytest-rerunfailures. + item._initrequest() # type: ignore[attr-defined] + rep = call_and_report(item, "setup", log) + reports = [rep] + if rep.passed: + if item.config.getoption("setupshow", False): + show_test_item(item) + if not item.config.getoption("setuponly", False): + reports.append(call_and_report(item, "call", log)) + # If the session is about to fail or stop, teardown everything - this is + # necessary to correctly report fixture teardown errors (see #11706) + if item.session.shouldfail or item.session.shouldstop: + nextitem = None + reports.append(call_and_report(item, "teardown", log, nextitem=nextitem)) + # After all teardown hooks have been called + # want funcargs and request info to go away. + if hasrequest: + item._request = False # type: ignore[attr-defined] + item.funcargs = None # type: ignore[attr-defined] + return reports + + +def show_test_item(item: Item) -> None: + """Show test function, parameters and the fixtures of the test item.""" + tw = item.config.get_terminal_writer() + tw.line() + tw.write(" " * 8) + tw.write(item.nodeid) + used_fixtures = sorted(getattr(item, "fixturenames", [])) + if used_fixtures: + tw.write(" (fixtures used: {})".format(", ".join(used_fixtures))) + tw.flush() + + +def pytest_runtest_setup(item: Item) -> None: + _update_current_test_var(item, "setup") + item.session._setupstate.setup(item) + + +def pytest_runtest_call(item: Item) -> None: + _update_current_test_var(item, "call") + try: + del sys.last_type + del sys.last_value + del sys.last_traceback + if sys.version_info >= (3, 12, 0): + del sys.last_exc # type:ignore[attr-defined] + except AttributeError: + pass + try: + item.runtest() + except Exception as e: + # Store trace info to allow postmortem debugging + sys.last_type = type(e) + sys.last_value = e + if sys.version_info >= (3, 12, 0): + sys.last_exc = e # type:ignore[attr-defined] + assert e.__traceback__ is not None + # Skip *this* frame + sys.last_traceback = e.__traceback__.tb_next + raise + + +def pytest_runtest_teardown(item: Item, nextitem: Item | None) -> None: + _update_current_test_var(item, "teardown") + item.session._setupstate.teardown_exact(nextitem) + _update_current_test_var(item, None) + + +def _update_current_test_var( + item: Item, when: Literal["setup", "call", "teardown"] | None +) -> None: + """Update :envvar:`PYTEST_CURRENT_TEST` to reflect the current item and stage. + + If ``when`` is None, delete ``PYTEST_CURRENT_TEST`` from the environment. + """ + var_name = "PYTEST_CURRENT_TEST" + if when: + value = f"{item.nodeid} ({when})" + # don't allow null bytes on environment variables (see #2644, #2957) + value = value.replace("\x00", "(null)") + os.environ[var_name] = value + else: + os.environ.pop(var_name) + + +def pytest_report_teststatus(report: BaseReport) -> tuple[str, str, str] | None: + if report.when in ("setup", "teardown"): + if report.failed: + # category, shortletter, verbose-word + return "error", "E", "ERROR" + elif report.skipped: + return "skipped", "s", "SKIPPED" + else: + return "", "", "" + return None + + +# +# Implementation + + +def call_and_report( + item: Item, when: Literal["setup", "call", "teardown"], log: bool = True, **kwds +) -> TestReport: + ihook = item.ihook + if when == "setup": + runtest_hook: Callable[..., None] = ihook.pytest_runtest_setup + elif when == "call": + runtest_hook = ihook.pytest_runtest_call + elif when == "teardown": + runtest_hook = ihook.pytest_runtest_teardown + else: + assert False, f"Unhandled runtest hook case: {when}" + reraise: tuple[type[BaseException], ...] = (Exit,) + if not item.config.getoption("usepdb", False): + reraise += (KeyboardInterrupt,) + call = CallInfo.from_call( + lambda: runtest_hook(item=item, **kwds), when=when, reraise=reraise + ) + report: TestReport = ihook.pytest_runtest_makereport(item=item, call=call) + if log: + ihook.pytest_runtest_logreport(report=report) + if check_interactive_exception(call, report): + ihook.pytest_exception_interact(node=item, call=call, report=report) + return report + + +def check_interactive_exception(call: CallInfo[object], report: BaseReport) -> bool: + """Check whether the call raised an exception that should be reported as + interactive.""" + if call.excinfo is None: + # Didn't raise. + return False + if hasattr(report, "wasxfail"): + # Exception was expected. + return False + if isinstance(call.excinfo.value, (Skipped, bdb.BdbQuit)): + # Special control flow exception. + return False + return True + + +TResult = TypeVar("TResult", covariant=True) + + +@final +@dataclasses.dataclass +class CallInfo(Generic[TResult]): + """Result/Exception info of a function invocation.""" + + _result: TResult | None + #: The captured exception of the call, if it raised. + excinfo: ExceptionInfo[BaseException] | None + #: The system time when the call started, in seconds since the epoch. + start: float + #: The system time when the call ended, in seconds since the epoch. + stop: float + #: The call duration, in seconds. + duration: float + #: The context of invocation: "collect", "setup", "call" or "teardown". + when: Literal["collect", "setup", "call", "teardown"] + + def __init__( + self, + result: TResult | None, + excinfo: ExceptionInfo[BaseException] | None, + start: float, + stop: float, + duration: float, + when: Literal["collect", "setup", "call", "teardown"], + *, + _ispytest: bool = False, + ) -> None: + check_ispytest(_ispytest) + self._result = result + self.excinfo = excinfo + self.start = start + self.stop = stop + self.duration = duration + self.when = when + + @property + def result(self) -> TResult: + """The return value of the call, if it didn't raise. + + Can only be accessed if excinfo is None. + """ + if self.excinfo is not None: + raise AttributeError(f"{self!r} has no valid result") + # The cast is safe because an exception wasn't raised, hence + # _result has the expected function return type (which may be + # None, that's why a cast and not an assert). + return cast(TResult, self._result) + + @classmethod + def from_call( + cls, + func: Callable[[], TResult], + when: Literal["collect", "setup", "call", "teardown"], + reraise: type[BaseException] | tuple[type[BaseException], ...] | None = None, + ) -> CallInfo[TResult]: + """Call func, wrapping the result in a CallInfo. + + :param func: + The function to call. Called without arguments. + :type func: Callable[[], _pytest.runner.TResult] + :param when: + The phase in which the function is called. + :param reraise: + Exception or exceptions that shall propagate if raised by the + function, instead of being wrapped in the CallInfo. + """ + excinfo = None + start = timing.time() + precise_start = timing.perf_counter() + try: + result: TResult | None = func() + except BaseException: + excinfo = ExceptionInfo.from_current() + if reraise is not None and isinstance(excinfo.value, reraise): + raise + result = None + # use the perf counter + precise_stop = timing.perf_counter() + duration = precise_stop - precise_start + stop = timing.time() + return cls( + start=start, + stop=stop, + duration=duration, + when=when, + result=result, + excinfo=excinfo, + _ispytest=True, + ) + + def __repr__(self) -> str: + if self.excinfo is None: + return f"" + return f"" + + +def pytest_runtest_makereport(item: Item, call: CallInfo[None]) -> TestReport: + return TestReport.from_item_and_call(item, call) + + +def pytest_make_collect_report(collector: Collector) -> CollectReport: + def collect() -> list[Item | Collector]: + # Before collecting, if this is a Directory, load the conftests. + # If a conftest import fails to load, it is considered a collection + # error of the Directory collector. This is why it's done inside of the + # CallInfo wrapper. + # + # Note: initial conftests are loaded early, not here. + if isinstance(collector, Directory): + collector.config.pluginmanager._loadconftestmodules( + collector.path, + collector.config.getoption("importmode"), + rootpath=collector.config.rootpath, + consider_namespace_packages=collector.config.getini( + "consider_namespace_packages" + ), + ) + + return list(collector.collect()) + + call = CallInfo.from_call( + collect, "collect", reraise=(KeyboardInterrupt, SystemExit) + ) + longrepr: None | tuple[str, int, str] | str | TerminalRepr = None + if not call.excinfo: + outcome: Literal["passed", "skipped", "failed"] = "passed" + else: + skip_exceptions = [Skipped] + unittest = sys.modules.get("unittest") + if unittest is not None: + skip_exceptions.append(unittest.SkipTest) + if isinstance(call.excinfo.value, tuple(skip_exceptions)): + outcome = "skipped" + r_ = collector._repr_failure_py(call.excinfo, "line") + assert isinstance(r_, ExceptionChainRepr), repr(r_) + r = r_.reprcrash + assert r + longrepr = (str(r.path), r.lineno, r.message) + else: + outcome = "failed" + errorinfo = collector.repr_failure(call.excinfo) + if not hasattr(errorinfo, "toterminal"): + assert isinstance(errorinfo, str) + errorinfo = CollectErrorRepr(errorinfo) + longrepr = errorinfo + result = call.result if not call.excinfo else None + rep = CollectReport(collector.nodeid, outcome, longrepr, result) + rep.call = call # type: ignore # see collect_one_node + return rep + + +class SetupState: + """Shared state for setting up/tearing down test items or collectors + in a session. + + Suppose we have a collection tree as follows: + + + + + + + + The SetupState maintains a stack. The stack starts out empty: + + [] + + During the setup phase of item1, setup(item1) is called. What it does + is: + + push session to stack, run session.setup() + push mod1 to stack, run mod1.setup() + push item1 to stack, run item1.setup() + + The stack is: + + [session, mod1, item1] + + While the stack is in this shape, it is allowed to add finalizers to + each of session, mod1, item1 using addfinalizer(). + + During the teardown phase of item1, teardown_exact(item2) is called, + where item2 is the next item to item1. What it does is: + + pop item1 from stack, run its teardowns + pop mod1 from stack, run its teardowns + + mod1 was popped because it ended its purpose with item1. The stack is: + + [session] + + During the setup phase of item2, setup(item2) is called. What it does + is: + + push mod2 to stack, run mod2.setup() + push item2 to stack, run item2.setup() + + Stack: + + [session, mod2, item2] + + During the teardown phase of item2, teardown_exact(None) is called, + because item2 is the last item. What it does is: + + pop item2 from stack, run its teardowns + pop mod2 from stack, run its teardowns + pop session from stack, run its teardowns + + Stack: + + [] + + The end! + """ + + def __init__(self) -> None: + # The stack is in the dict insertion order. + self.stack: dict[ + Node, + tuple[ + # Node's finalizers. + list[Callable[[], object]], + # Node's exception and original traceback, if its setup raised. + tuple[OutcomeException | Exception, types.TracebackType | None] | None, + ], + ] = {} + + def setup(self, item: Item) -> None: + """Setup objects along the collector chain to the item.""" + needed_collectors = item.listchain() + + # If a collector fails its setup, fail its entire subtree of items. + # The setup is not retried for each item - the same exception is used. + for col, (finalizers, exc) in self.stack.items(): + assert col in needed_collectors, "previous item was not torn down properly" + if exc: + raise exc[0].with_traceback(exc[1]) + + for col in needed_collectors[len(self.stack) :]: + assert col not in self.stack + # Push onto the stack. + self.stack[col] = ([col.teardown], None) + try: + col.setup() + except TEST_OUTCOME as exc: + self.stack[col] = (self.stack[col][0], (exc, exc.__traceback__)) + raise + + def addfinalizer(self, finalizer: Callable[[], object], node: Node) -> None: + """Attach a finalizer to the given node. + + The node must be currently active in the stack. + """ + assert node and not isinstance(node, tuple) + assert callable(finalizer) + assert node in self.stack, (node, self.stack) + self.stack[node][0].append(finalizer) + + def teardown_exact(self, nextitem: Item | None) -> None: + """Teardown the current stack up until reaching nodes that nextitem + also descends from. + + When nextitem is None (meaning we're at the last item), the entire + stack is torn down. + """ + needed_collectors = nextitem and nextitem.listchain() or [] + exceptions: list[BaseException] = [] + while self.stack: + if list(self.stack.keys()) == needed_collectors[: len(self.stack)]: + break + node, (finalizers, _) = self.stack.popitem() + these_exceptions = [] + while finalizers: + fin = finalizers.pop() + try: + fin() + except TEST_OUTCOME as e: + these_exceptions.append(e) + + if len(these_exceptions) == 1: + exceptions.extend(these_exceptions) + elif these_exceptions: + msg = f"errors while tearing down {node!r}" + exceptions.append(BaseExceptionGroup(msg, these_exceptions[::-1])) + + if len(exceptions) == 1: + raise exceptions[0] + elif exceptions: + raise BaseExceptionGroup("errors during test teardown", exceptions[::-1]) + if nextitem is None: + assert not self.stack + + +def collect_one_node(collector: Collector) -> CollectReport: + ihook = collector.ihook + ihook.pytest_collectstart(collector=collector) + rep: CollectReport = ihook.pytest_make_collect_report(collector=collector) + call = rep.__dict__.pop("call", None) + if call and check_interactive_exception(call, rep): + ihook.pytest_exception_interact(node=collector, call=call, report=rep) + return rep diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/scope.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/scope.py new file mode 100644 index 0000000..976a3ba --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/scope.py @@ -0,0 +1,91 @@ +""" +Scope definition and related utilities. + +Those are defined here, instead of in the 'fixtures' module because +their use is spread across many other pytest modules, and centralizing it in 'fixtures' +would cause circular references. + +Also this makes the module light to import, as it should. +""" + +from __future__ import annotations + +from enum import Enum +from functools import total_ordering +from typing import Literal + + +_ScopeName = Literal["session", "package", "module", "class", "function"] + + +@total_ordering +class Scope(Enum): + """ + Represents one of the possible fixture scopes in pytest. + + Scopes are ordered from lower to higher, that is: + + ->>> higher ->>> + + Function < Class < Module < Package < Session + + <<<- lower <<<- + """ + + # Scopes need to be listed from lower to higher. + Function: _ScopeName = "function" + Class: _ScopeName = "class" + Module: _ScopeName = "module" + Package: _ScopeName = "package" + Session: _ScopeName = "session" + + def next_lower(self) -> Scope: + """Return the next lower scope.""" + index = _SCOPE_INDICES[self] + if index == 0: + raise ValueError(f"{self} is the lower-most scope") + return _ALL_SCOPES[index - 1] + + def next_higher(self) -> Scope: + """Return the next higher scope.""" + index = _SCOPE_INDICES[self] + if index == len(_SCOPE_INDICES) - 1: + raise ValueError(f"{self} is the upper-most scope") + return _ALL_SCOPES[index + 1] + + def __lt__(self, other: Scope) -> bool: + self_index = _SCOPE_INDICES[self] + other_index = _SCOPE_INDICES[other] + return self_index < other_index + + @classmethod + def from_user( + cls, scope_name: _ScopeName, descr: str, where: str | None = None + ) -> Scope: + """ + Given a scope name from the user, return the equivalent Scope enum. Should be used + whenever we want to convert a user provided scope name to its enum object. + + If the scope name is invalid, construct a user friendly message and call pytest.fail. + """ + from _pytest.outcomes import fail + + try: + # Holding this reference is necessary for mypy at the moment. + scope = Scope(scope_name) + except ValueError: + fail( + "{} {}got an unexpected scope value '{}'".format( + descr, f"from {where} " if where else "", scope_name + ), + pytrace=False, + ) + return scope + + +_ALL_SCOPES = list(Scope) +_SCOPE_INDICES = {scope: index for index, scope in enumerate(_ALL_SCOPES)} + + +# Ordered list of scopes which can contain many tests (in practice all except Function). +HIGH_SCOPES = [x for x in Scope if x is not Scope.Function] diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/setuponly.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/setuponly.py new file mode 100644 index 0000000..de297f4 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/setuponly.py @@ -0,0 +1,102 @@ +from __future__ import annotations + +from typing import Generator + +from _pytest._io.saferepr import saferepr +from _pytest.config import Config +from _pytest.config import ExitCode +from _pytest.config.argparsing import Parser +from _pytest.fixtures import FixtureDef +from _pytest.fixtures import SubRequest +from _pytest.scope import Scope +import pytest + + +def pytest_addoption(parser: Parser) -> None: + group = parser.getgroup("debugconfig") + group.addoption( + "--setuponly", + "--setup-only", + action="store_true", + help="Only setup fixtures, do not execute tests", + ) + group.addoption( + "--setupshow", + "--setup-show", + action="store_true", + help="Show setup of fixtures while executing tests", + ) + + +@pytest.hookimpl(wrapper=True) +def pytest_fixture_setup( + fixturedef: FixtureDef[object], request: SubRequest +) -> Generator[None, object, object]: + try: + return (yield) + finally: + if request.config.option.setupshow: + if hasattr(request, "param"): + # Save the fixture parameter so ._show_fixture_action() can + # display it now and during the teardown (in .finish()). + if fixturedef.ids: + if callable(fixturedef.ids): + param = fixturedef.ids(request.param) + else: + param = fixturedef.ids[request.param_index] + else: + param = request.param + fixturedef.cached_param = param # type: ignore[attr-defined] + _show_fixture_action(fixturedef, request.config, "SETUP") + + +def pytest_fixture_post_finalizer( + fixturedef: FixtureDef[object], request: SubRequest +) -> None: + if fixturedef.cached_result is not None: + config = request.config + if config.option.setupshow: + _show_fixture_action(fixturedef, request.config, "TEARDOWN") + if hasattr(fixturedef, "cached_param"): + del fixturedef.cached_param + + +def _show_fixture_action( + fixturedef: FixtureDef[object], config: Config, msg: str +) -> None: + capman = config.pluginmanager.getplugin("capturemanager") + if capman: + capman.suspend_global_capture() + + tw = config.get_terminal_writer() + tw.line() + # Use smaller indentation the higher the scope: Session = 0, Package = 1, etc. + scope_indent = list(reversed(Scope)).index(fixturedef._scope) + tw.write(" " * 2 * scope_indent) + tw.write( + "{step} {scope} {fixture}".format( # noqa: UP032 (Readability) + step=msg.ljust(8), # align the output to TEARDOWN + scope=fixturedef.scope[0].upper(), + fixture=fixturedef.argname, + ) + ) + + if msg == "SETUP": + deps = sorted(arg for arg in fixturedef.argnames if arg != "request") + if deps: + tw.write(" (fixtures used: {})".format(", ".join(deps))) + + if hasattr(fixturedef, "cached_param"): + tw.write(f"[{saferepr(fixturedef.cached_param, maxsize=42)}]") + + tw.flush() + + if capman: + capman.resume_global_capture() + + +@pytest.hookimpl(tryfirst=True) +def pytest_cmdline_main(config: Config) -> int | ExitCode | None: + if config.option.setuponly: + config.option.setupshow = True + return None diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/setupplan.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/setupplan.py new file mode 100644 index 0000000..4e124cc --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/setupplan.py @@ -0,0 +1,39 @@ +from __future__ import annotations + +from _pytest.config import Config +from _pytest.config import ExitCode +from _pytest.config.argparsing import Parser +from _pytest.fixtures import FixtureDef +from _pytest.fixtures import SubRequest +import pytest + + +def pytest_addoption(parser: Parser) -> None: + group = parser.getgroup("debugconfig") + group.addoption( + "--setupplan", + "--setup-plan", + action="store_true", + help="Show what fixtures and tests would be executed but " + "don't execute anything", + ) + + +@pytest.hookimpl(tryfirst=True) +def pytest_fixture_setup( + fixturedef: FixtureDef[object], request: SubRequest +) -> object | None: + # Will return a dummy fixture if the setuponly option is provided. + if request.config.option.setupplan: + my_cache_key = fixturedef.cache_key(request) + fixturedef.cached_result = (None, my_cache_key, None) + return fixturedef.cached_result + return None + + +@pytest.hookimpl(tryfirst=True) +def pytest_cmdline_main(config: Config) -> int | ExitCode | None: + if config.option.setupplan: + config.option.setuponly = True + config.option.setupshow = True + return None diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/skipping.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/skipping.py new file mode 100644 index 0000000..9818be2 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/skipping.py @@ -0,0 +1,301 @@ +# mypy: allow-untyped-defs +"""Support for skip/xfail functions and markers.""" + +from __future__ import annotations + +from collections.abc import Mapping +import dataclasses +import os +import platform +import sys +import traceback +from typing import Generator +from typing import Optional + +from _pytest.config import Config +from _pytest.config import hookimpl +from _pytest.config.argparsing import Parser +from _pytest.mark.structures import Mark +from _pytest.nodes import Item +from _pytest.outcomes import fail +from _pytest.outcomes import skip +from _pytest.outcomes import xfail +from _pytest.reports import BaseReport +from _pytest.reports import TestReport +from _pytest.runner import CallInfo +from _pytest.stash import StashKey + + +def pytest_addoption(parser: Parser) -> None: + group = parser.getgroup("general") + group.addoption( + "--runxfail", + action="store_true", + dest="runxfail", + default=False, + help="Report the results of xfail tests as if they were not marked", + ) + + parser.addini( + "xfail_strict", + "Default for the strict parameter of xfail " + "markers when not given explicitly (default: False)", + default=False, + type="bool", + ) + + +def pytest_configure(config: Config) -> None: + if config.option.runxfail: + # yay a hack + import pytest + + old = pytest.xfail + config.add_cleanup(lambda: setattr(pytest, "xfail", old)) + + def nop(*args, **kwargs): + pass + + nop.Exception = xfail.Exception # type: ignore[attr-defined] + setattr(pytest, "xfail", nop) + + config.addinivalue_line( + "markers", + "skip(reason=None): skip the given test function with an optional reason. " + 'Example: skip(reason="no way of currently testing this") skips the ' + "test.", + ) + config.addinivalue_line( + "markers", + "skipif(condition, ..., *, reason=...): " + "skip the given test function if any of the conditions evaluate to True. " + "Example: skipif(sys.platform == 'win32') skips the test if we are on the win32 platform. " + "See https://docs.pytest.org/en/stable/reference/reference.html#pytest-mark-skipif", + ) + config.addinivalue_line( + "markers", + "xfail(condition, ..., *, reason=..., run=True, raises=None, strict=xfail_strict): " + "mark the test function as an expected failure if any of the conditions " + "evaluate to True. Optionally specify a reason for better reporting " + "and run=False if you don't even want to execute the test function. " + "If only specific exception(s) are expected, you can list them in " + "raises, and if the test fails in other ways, it will be reported as " + "a true failure. See https://docs.pytest.org/en/stable/reference/reference.html#pytest-mark-xfail", + ) + + +def evaluate_condition(item: Item, mark: Mark, condition: object) -> tuple[bool, str]: + """Evaluate a single skipif/xfail condition. + + If an old-style string condition is given, it is eval()'d, otherwise the + condition is bool()'d. If this fails, an appropriately formatted pytest.fail + is raised. + + Returns (result, reason). The reason is only relevant if the result is True. + """ + # String condition. + if isinstance(condition, str): + globals_ = { + "os": os, + "sys": sys, + "platform": platform, + "config": item.config, + } + for dictionary in reversed( + item.ihook.pytest_markeval_namespace(config=item.config) + ): + if not isinstance(dictionary, Mapping): + raise ValueError( + f"pytest_markeval_namespace() needs to return a dict, got {dictionary!r}" + ) + globals_.update(dictionary) + if hasattr(item, "obj"): + globals_.update(item.obj.__globals__) + try: + filename = f"<{mark.name} condition>" + condition_code = compile(condition, filename, "eval") + result = eval(condition_code, globals_) + except SyntaxError as exc: + msglines = [ + f"Error evaluating {mark.name!r} condition", + " " + condition, + " " + " " * (exc.offset or 0) + "^", + "SyntaxError: invalid syntax", + ] + fail("\n".join(msglines), pytrace=False) + except Exception as exc: + msglines = [ + f"Error evaluating {mark.name!r} condition", + " " + condition, + *traceback.format_exception_only(type(exc), exc), + ] + fail("\n".join(msglines), pytrace=False) + + # Boolean condition. + else: + try: + result = bool(condition) + except Exception as exc: + msglines = [ + f"Error evaluating {mark.name!r} condition as a boolean", + *traceback.format_exception_only(type(exc), exc), + ] + fail("\n".join(msglines), pytrace=False) + + reason = mark.kwargs.get("reason", None) + if reason is None: + if isinstance(condition, str): + reason = "condition: " + condition + else: + # XXX better be checked at collection time + msg = ( + f"Error evaluating {mark.name!r}: " + + "you need to specify reason=STRING when using booleans as conditions." + ) + fail(msg, pytrace=False) + + return result, reason + + +@dataclasses.dataclass(frozen=True) +class Skip: + """The result of evaluate_skip_marks().""" + + reason: str = "unconditional skip" + + +def evaluate_skip_marks(item: Item) -> Skip | None: + """Evaluate skip and skipif marks on item, returning Skip if triggered.""" + for mark in item.iter_markers(name="skipif"): + if "condition" not in mark.kwargs: + conditions = mark.args + else: + conditions = (mark.kwargs["condition"],) + + # Unconditional. + if not conditions: + reason = mark.kwargs.get("reason", "") + return Skip(reason) + + # If any of the conditions are true. + for condition in conditions: + result, reason = evaluate_condition(item, mark, condition) + if result: + return Skip(reason) + + for mark in item.iter_markers(name="skip"): + try: + return Skip(*mark.args, **mark.kwargs) + except TypeError as e: + raise TypeError(str(e) + " - maybe you meant pytest.mark.skipif?") from None + + return None + + +@dataclasses.dataclass(frozen=True) +class Xfail: + """The result of evaluate_xfail_marks().""" + + __slots__ = ("reason", "run", "strict", "raises") + + reason: str + run: bool + strict: bool + raises: tuple[type[BaseException], ...] | None + + +def evaluate_xfail_marks(item: Item) -> Xfail | None: + """Evaluate xfail marks on item, returning Xfail if triggered.""" + for mark in item.iter_markers(name="xfail"): + run = mark.kwargs.get("run", True) + strict = mark.kwargs.get("strict", item.config.getini("xfail_strict")) + raises = mark.kwargs.get("raises", None) + if "condition" not in mark.kwargs: + conditions = mark.args + else: + conditions = (mark.kwargs["condition"],) + + # Unconditional. + if not conditions: + reason = mark.kwargs.get("reason", "") + return Xfail(reason, run, strict, raises) + + # If any of the conditions are true. + for condition in conditions: + result, reason = evaluate_condition(item, mark, condition) + if result: + return Xfail(reason, run, strict, raises) + + return None + + +# Saves the xfail mark evaluation. Can be refreshed during call if None. +xfailed_key = StashKey[Optional[Xfail]]() + + +@hookimpl(tryfirst=True) +def pytest_runtest_setup(item: Item) -> None: + skipped = evaluate_skip_marks(item) + if skipped: + raise skip.Exception(skipped.reason, _use_item_location=True) + + item.stash[xfailed_key] = xfailed = evaluate_xfail_marks(item) + if xfailed and not item.config.option.runxfail and not xfailed.run: + xfail("[NOTRUN] " + xfailed.reason) + + +@hookimpl(wrapper=True) +def pytest_runtest_call(item: Item) -> Generator[None]: + xfailed = item.stash.get(xfailed_key, None) + if xfailed is None: + item.stash[xfailed_key] = xfailed = evaluate_xfail_marks(item) + + if xfailed and not item.config.option.runxfail and not xfailed.run: + xfail("[NOTRUN] " + xfailed.reason) + + try: + return (yield) + finally: + # The test run may have added an xfail mark dynamically. + xfailed = item.stash.get(xfailed_key, None) + if xfailed is None: + item.stash[xfailed_key] = xfailed = evaluate_xfail_marks(item) + + +@hookimpl(wrapper=True) +def pytest_runtest_makereport( + item: Item, call: CallInfo[None] +) -> Generator[None, TestReport, TestReport]: + rep = yield + xfailed = item.stash.get(xfailed_key, None) + if item.config.option.runxfail: + pass # don't interfere + elif call.excinfo and isinstance(call.excinfo.value, xfail.Exception): + assert call.excinfo.value.msg is not None + rep.wasxfail = "reason: " + call.excinfo.value.msg + rep.outcome = "skipped" + elif not rep.skipped and xfailed: + if call.excinfo: + raises = xfailed.raises + if raises is not None and not isinstance(call.excinfo.value, raises): + rep.outcome = "failed" + else: + rep.outcome = "skipped" + rep.wasxfail = xfailed.reason + elif call.when == "call": + if xfailed.strict: + rep.outcome = "failed" + rep.longrepr = "[XPASS(strict)] " + xfailed.reason + else: + rep.outcome = "passed" + rep.wasxfail = xfailed.reason + return rep + + +def pytest_report_teststatus(report: BaseReport) -> tuple[str, str, str] | None: + if hasattr(report, "wasxfail"): + if report.skipped: + return "xfailed", "x", "XFAIL" + elif report.passed: + return "xpassed", "X", "XPASS" + return None diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/stash.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/stash.py new file mode 100644 index 0000000..6a9ff88 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/stash.py @@ -0,0 +1,116 @@ +from __future__ import annotations + +from typing import Any +from typing import cast +from typing import Generic +from typing import TypeVar + + +__all__ = ["Stash", "StashKey"] + + +T = TypeVar("T") +D = TypeVar("D") + + +class StashKey(Generic[T]): + """``StashKey`` is an object used as a key to a :class:`Stash`. + + A ``StashKey`` is associated with the type ``T`` of the value of the key. + + A ``StashKey`` is unique and cannot conflict with another key. + + .. versionadded:: 7.0 + """ + + __slots__ = () + + +class Stash: + r"""``Stash`` is a type-safe heterogeneous mutable mapping that + allows keys and value types to be defined separately from + where it (the ``Stash``) is created. + + Usually you will be given an object which has a ``Stash``, for example + :class:`~pytest.Config` or a :class:`~_pytest.nodes.Node`: + + .. code-block:: python + + stash: Stash = some_object.stash + + If a module or plugin wants to store data in this ``Stash``, it creates + :class:`StashKey`\s for its keys (at the module level): + + .. code-block:: python + + # At the top-level of the module + some_str_key = StashKey[str]() + some_bool_key = StashKey[bool]() + + To store information: + + .. code-block:: python + + # Value type must match the key. + stash[some_str_key] = "value" + stash[some_bool_key] = True + + To retrieve the information: + + .. code-block:: python + + # The static type of some_str is str. + some_str = stash[some_str_key] + # The static type of some_bool is bool. + some_bool = stash[some_bool_key] + + .. versionadded:: 7.0 + """ + + __slots__ = ("_storage",) + + def __init__(self) -> None: + self._storage: dict[StashKey[Any], object] = {} + + def __setitem__(self, key: StashKey[T], value: T) -> None: + """Set a value for key.""" + self._storage[key] = value + + def __getitem__(self, key: StashKey[T]) -> T: + """Get the value for key. + + Raises ``KeyError`` if the key wasn't set before. + """ + return cast(T, self._storage[key]) + + def get(self, key: StashKey[T], default: D) -> T | D: + """Get the value for key, or return default if the key wasn't set + before.""" + try: + return self[key] + except KeyError: + return default + + def setdefault(self, key: StashKey[T], default: T) -> T: + """Return the value of key if already set, otherwise set the value + of key to default and return default.""" + try: + return self[key] + except KeyError: + self[key] = default + return default + + def __delitem__(self, key: StashKey[T]) -> None: + """Delete the value for key. + + Raises ``KeyError`` if the key wasn't set before. + """ + del self._storage[key] + + def __contains__(self, key: StashKey[T]) -> bool: + """Return whether key was set.""" + return key in self._storage + + def __len__(self) -> int: + """Return how many items exist in the stash.""" + return len(self._storage) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/stepwise.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/stepwise.py new file mode 100644 index 0000000..c786080 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/stepwise.py @@ -0,0 +1,125 @@ +from __future__ import annotations + +from _pytest import nodes +from _pytest.cacheprovider import Cache +from _pytest.config import Config +from _pytest.config.argparsing import Parser +from _pytest.main import Session +from _pytest.reports import TestReport + + +STEPWISE_CACHE_DIR = "cache/stepwise" + + +def pytest_addoption(parser: Parser) -> None: + group = parser.getgroup("general") + group.addoption( + "--sw", + "--stepwise", + action="store_true", + default=False, + dest="stepwise", + help="Exit on test failure and continue from last failing test next time", + ) + group.addoption( + "--sw-skip", + "--stepwise-skip", + action="store_true", + default=False, + dest="stepwise_skip", + help="Ignore the first failing test but stop on the next failing test. " + "Implicitly enables --stepwise.", + ) + + +def pytest_configure(config: Config) -> None: + if config.option.stepwise_skip: + # allow --stepwise-skip to work on its own merits. + config.option.stepwise = True + if config.getoption("stepwise"): + config.pluginmanager.register(StepwisePlugin(config), "stepwiseplugin") + + +def pytest_sessionfinish(session: Session) -> None: + if not session.config.getoption("stepwise"): + assert session.config.cache is not None + if hasattr(session.config, "workerinput"): + # Do not update cache if this process is a xdist worker to prevent + # race conditions (#10641). + return + # Clear the list of failing tests if the plugin is not active. + session.config.cache.set(STEPWISE_CACHE_DIR, []) + + +class StepwisePlugin: + def __init__(self, config: Config) -> None: + self.config = config + self.session: Session | None = None + self.report_status = "" + assert config.cache is not None + self.cache: Cache = config.cache + self.lastfailed: str | None = self.cache.get(STEPWISE_CACHE_DIR, None) + self.skip: bool = config.getoption("stepwise_skip") + + def pytest_sessionstart(self, session: Session) -> None: + self.session = session + + def pytest_collection_modifyitems( + self, config: Config, items: list[nodes.Item] + ) -> None: + if not self.lastfailed: + self.report_status = "no previously failed tests, not skipping." + return + + # check all item nodes until we find a match on last failed + failed_index = None + for index, item in enumerate(items): + if item.nodeid == self.lastfailed: + failed_index = index + break + + # If the previously failed test was not found among the test items, + # do not skip any tests. + if failed_index is None: + self.report_status = "previously failed test not found, not skipping." + else: + self.report_status = f"skipping {failed_index} already passed items." + deselected = items[:failed_index] + del items[:failed_index] + config.hook.pytest_deselected(items=deselected) + + def pytest_runtest_logreport(self, report: TestReport) -> None: + if report.failed: + if self.skip: + # Remove test from the failed ones (if it exists) and unset the skip option + # to make sure the following tests will not be skipped. + if report.nodeid == self.lastfailed: + self.lastfailed = None + + self.skip = False + else: + # Mark test as the last failing and interrupt the test session. + self.lastfailed = report.nodeid + assert self.session is not None + self.session.shouldstop = ( + "Test failed, continuing from this test next run." + ) + + else: + # If the test was actually run and did pass. + if report.when == "call": + # Remove test from the failed ones, if exists. + if report.nodeid == self.lastfailed: + self.lastfailed = None + + def pytest_report_collectionfinish(self) -> str | None: + if self.config.get_verbosity() >= 0 and self.report_status: + return f"stepwise: {self.report_status}" + return None + + def pytest_sessionfinish(self) -> None: + if hasattr(self.config, "workerinput"): + # Do not update cache if this process is a xdist worker to prevent + # race conditions (#10641). + return + self.cache.set(STEPWISE_CACHE_DIR, self.lastfailed) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/terminal.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/terminal.py new file mode 100644 index 0000000..ed267bf --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/terminal.py @@ -0,0 +1,1577 @@ +# mypy: allow-untyped-defs +"""Terminal reporting of the full testing process. + +This is a good source for looking at the various reporting hooks. +""" + +from __future__ import annotations + +import argparse +from collections import Counter +import dataclasses +import datetime +from functools import partial +import inspect +from pathlib import Path +import platform +import sys +import textwrap +from typing import Any +from typing import Callable +from typing import ClassVar +from typing import final +from typing import Generator +from typing import Literal +from typing import Mapping +from typing import NamedTuple +from typing import Sequence +from typing import TextIO +from typing import TYPE_CHECKING +import warnings + +import pluggy + +from _pytest import nodes +from _pytest import timing +from _pytest._code import ExceptionInfo +from _pytest._code.code import ExceptionRepr +from _pytest._io import TerminalWriter +from _pytest._io.wcwidth import wcswidth +import _pytest._version +from _pytest.assertion.util import running_on_ci +from _pytest.config import _PluggyPlugin +from _pytest.config import Config +from _pytest.config import ExitCode +from _pytest.config import hookimpl +from _pytest.config.argparsing import Parser +from _pytest.nodes import Item +from _pytest.nodes import Node +from _pytest.pathlib import absolutepath +from _pytest.pathlib import bestrelpath +from _pytest.reports import BaseReport +from _pytest.reports import CollectReport +from _pytest.reports import TestReport + + +if TYPE_CHECKING: + from _pytest.main import Session + + +REPORT_COLLECTING_RESOLUTION = 0.5 + +KNOWN_TYPES = ( + "failed", + "passed", + "skipped", + "deselected", + "xfailed", + "xpassed", + "warnings", + "error", +) + +_REPORTCHARS_DEFAULT = "fE" + + +class MoreQuietAction(argparse.Action): + """A modified copy of the argparse count action which counts down and updates + the legacy quiet attribute at the same time. + + Used to unify verbosity handling. + """ + + def __init__( + self, + option_strings: Sequence[str], + dest: str, + default: object = None, + required: bool = False, + help: str | None = None, + ) -> None: + super().__init__( + option_strings=option_strings, + dest=dest, + nargs=0, + default=default, + required=required, + help=help, + ) + + def __call__( + self, + parser: argparse.ArgumentParser, + namespace: argparse.Namespace, + values: str | Sequence[object] | None, + option_string: str | None = None, + ) -> None: + new_count = getattr(namespace, self.dest, 0) - 1 + setattr(namespace, self.dest, new_count) + # todo Deprecate config.quiet + namespace.quiet = getattr(namespace, "quiet", 0) + 1 + + +class TestShortLogReport(NamedTuple): + """Used to store the test status result category, shortletter and verbose word. + For example ``"rerun", "R", ("RERUN", {"yellow": True})``. + + :ivar category: + The class of result, for example ``“passed”``, ``“skipped”``, ``“error”``, or the empty string. + + :ivar letter: + The short letter shown as testing progresses, for example ``"."``, ``"s"``, ``"E"``, or the empty string. + + :ivar word: + Verbose word is shown as testing progresses in verbose mode, for example ``"PASSED"``, ``"SKIPPED"``, + ``"ERROR"``, or the empty string. + """ + + category: str + letter: str + word: str | tuple[str, Mapping[str, bool]] + + +def pytest_addoption(parser: Parser) -> None: + group = parser.getgroup("terminal reporting", "Reporting", after="general") + group._addoption( + "-v", + "--verbose", + action="count", + default=0, + dest="verbose", + help="Increase verbosity", + ) + group._addoption( + "--no-header", + action="store_true", + default=False, + dest="no_header", + help="Disable header", + ) + group._addoption( + "--no-summary", + action="store_true", + default=False, + dest="no_summary", + help="Disable summary", + ) + group._addoption( + "--no-fold-skipped", + action="store_false", + dest="fold_skipped", + default=True, + help="Do not fold skipped tests in short summary.", + ) + group._addoption( + "-q", + "--quiet", + action=MoreQuietAction, + default=0, + dest="verbose", + help="Decrease verbosity", + ) + group._addoption( + "--verbosity", + dest="verbose", + type=int, + default=0, + help="Set verbosity. Default: 0.", + ) + group._addoption( + "-r", + action="store", + dest="reportchars", + default=_REPORTCHARS_DEFAULT, + metavar="chars", + help="Show extra test summary info as specified by chars: (f)ailed, " + "(E)rror, (s)kipped, (x)failed, (X)passed, " + "(p)assed, (P)assed with output, (a)ll except passed (p/P), or (A)ll. " + "(w)arnings are enabled by default (see --disable-warnings), " + "'N' can be used to reset the list. (default: 'fE').", + ) + group._addoption( + "--disable-warnings", + "--disable-pytest-warnings", + default=False, + dest="disable_warnings", + action="store_true", + help="Disable warnings summary", + ) + group._addoption( + "-l", + "--showlocals", + action="store_true", + dest="showlocals", + default=False, + help="Show locals in tracebacks (disabled by default)", + ) + group._addoption( + "--no-showlocals", + action="store_false", + dest="showlocals", + help="Hide locals in tracebacks (negate --showlocals passed through addopts)", + ) + group._addoption( + "--tb", + metavar="style", + action="store", + dest="tbstyle", + default="auto", + choices=["auto", "long", "short", "no", "line", "native"], + help="Traceback print mode (auto/long/short/line/native/no)", + ) + group._addoption( + "--xfail-tb", + action="store_true", + dest="xfail_tb", + default=False, + help="Show tracebacks for xfail (as long as --tb != no)", + ) + group._addoption( + "--show-capture", + action="store", + dest="showcapture", + choices=["no", "stdout", "stderr", "log", "all"], + default="all", + help="Controls how captured stdout/stderr/log is shown on failed tests. " + "Default: all.", + ) + group._addoption( + "--fulltrace", + "--full-trace", + action="store_true", + default=False, + help="Don't cut any tracebacks (default is to cut)", + ) + group._addoption( + "--color", + metavar="color", + action="store", + dest="color", + default="auto", + choices=["yes", "no", "auto"], + help="Color terminal output (yes/no/auto)", + ) + group._addoption( + "--code-highlight", + default="yes", + choices=["yes", "no"], + help="Whether code should be highlighted (only if --color is also enabled). " + "Default: yes.", + ) + + parser.addini( + "console_output_style", + help='Console output: "classic", or with additional progress information ' + '("progress" (percentage) | "count" | "progress-even-when-capture-no" (forces ' + "progress even when capture=no)", + default="progress", + ) + Config._add_verbosity_ini( + parser, + Config.VERBOSITY_TEST_CASES, + help=( + "Specify a verbosity level for test case execution, overriding the main level. " + "Higher levels will provide more detailed information about each test case executed." + ), + ) + + +def pytest_configure(config: Config) -> None: + reporter = TerminalReporter(config, sys.stdout) + config.pluginmanager.register(reporter, "terminalreporter") + if config.option.debug or config.option.traceconfig: + + def mywriter(tags, args): + msg = " ".join(map(str, args)) + reporter.write_line("[traceconfig] " + msg) + + config.trace.root.setprocessor("pytest:config", mywriter) + + +def getreportopt(config: Config) -> str: + reportchars: str = config.option.reportchars + + old_aliases = {"F", "S"} + reportopts = "" + for char in reportchars: + if char in old_aliases: + char = char.lower() + if char == "a": + reportopts = "sxXEf" + elif char == "A": + reportopts = "PpsxXEf" + elif char == "N": + reportopts = "" + elif char not in reportopts: + reportopts += char + + if not config.option.disable_warnings and "w" not in reportopts: + reportopts = "w" + reportopts + elif config.option.disable_warnings and "w" in reportopts: + reportopts = reportopts.replace("w", "") + + return reportopts + + +@hookimpl(trylast=True) # after _pytest.runner +def pytest_report_teststatus(report: BaseReport) -> tuple[str, str, str]: + letter = "F" + if report.passed: + letter = "." + elif report.skipped: + letter = "s" + + outcome: str = report.outcome + if report.when in ("collect", "setup", "teardown") and outcome == "failed": + outcome = "error" + letter = "E" + + return outcome, letter, outcome.upper() + + +@dataclasses.dataclass +class WarningReport: + """Simple structure to hold warnings information captured by ``pytest_warning_recorded``. + + :ivar str message: + User friendly message about the warning. + :ivar str|None nodeid: + nodeid that generated the warning (see ``get_location``). + :ivar tuple fslocation: + File system location of the source of the warning (see ``get_location``). + """ + + message: str + nodeid: str | None = None + fslocation: tuple[str, int] | None = None + + count_towards_summary: ClassVar = True + + def get_location(self, config: Config) -> str | None: + """Return the more user-friendly information about the location of a warning, or None.""" + if self.nodeid: + return self.nodeid + if self.fslocation: + filename, linenum = self.fslocation + relpath = bestrelpath(config.invocation_params.dir, absolutepath(filename)) + return f"{relpath}:{linenum}" + return None + + +@final +class TerminalReporter: + def __init__(self, config: Config, file: TextIO | None = None) -> None: + import _pytest.config + + self.config = config + self._numcollected = 0 + self._session: Session | None = None + self._showfspath: bool | None = None + + self.stats: dict[str, list[Any]] = {} + self._main_color: str | None = None + self._known_types: list[str] | None = None + self.startpath = config.invocation_params.dir + if file is None: + file = sys.stdout + self._tw = _pytest.config.create_terminal_writer(config, file) + self._screen_width = self._tw.fullwidth + self.currentfspath: None | Path | str | int = None + self.reportchars = getreportopt(config) + self.foldskipped = config.option.fold_skipped + self.hasmarkup = self._tw.hasmarkup + self.isatty = file.isatty() + self._progress_nodeids_reported: set[str] = set() + self._show_progress_info = self._determine_show_progress_info() + self._collect_report_last_write: float | None = None + self._already_displayed_warnings: int | None = None + self._keyboardinterrupt_memo: ExceptionRepr | None = None + + def _determine_show_progress_info(self) -> Literal["progress", "count", False]: + """Return whether we should display progress information based on the current config.""" + # do not show progress if we are not capturing output (#3038) unless explicitly + # overridden by progress-even-when-capture-no + if ( + self.config.getoption("capture", "no") == "no" + and self.config.getini("console_output_style") + != "progress-even-when-capture-no" + ): + return False + # do not show progress if we are showing fixture setup/teardown + if self.config.getoption("setupshow", False): + return False + cfg: str = self.config.getini("console_output_style") + if cfg in {"progress", "progress-even-when-capture-no"}: + return "progress" + elif cfg == "count": + return "count" + else: + return False + + @property + def verbosity(self) -> int: + verbosity: int = self.config.option.verbose + return verbosity + + @property + def showheader(self) -> bool: + return self.verbosity >= 0 + + @property + def no_header(self) -> bool: + return bool(self.config.option.no_header) + + @property + def no_summary(self) -> bool: + return bool(self.config.option.no_summary) + + @property + def showfspath(self) -> bool: + if self._showfspath is None: + return self.config.get_verbosity(Config.VERBOSITY_TEST_CASES) >= 0 + return self._showfspath + + @showfspath.setter + def showfspath(self, value: bool | None) -> None: + self._showfspath = value + + @property + def showlongtestinfo(self) -> bool: + return self.config.get_verbosity(Config.VERBOSITY_TEST_CASES) > 0 + + def hasopt(self, char: str) -> bool: + char = {"xfailed": "x", "skipped": "s"}.get(char, char) + return char in self.reportchars + + def write_fspath_result(self, nodeid: str, res: str, **markup: bool) -> None: + fspath = self.config.rootpath / nodeid.split("::")[0] + if self.currentfspath is None or fspath != self.currentfspath: + if self.currentfspath is not None and self._show_progress_info: + self._write_progress_information_filling_space() + self.currentfspath = fspath + relfspath = bestrelpath(self.startpath, fspath) + self._tw.line() + self._tw.write(relfspath + " ") + self._tw.write(res, flush=True, **markup) + + def write_ensure_prefix(self, prefix: str, extra: str = "", **kwargs) -> None: + if self.currentfspath != prefix: + self._tw.line() + self.currentfspath = prefix + self._tw.write(prefix) + if extra: + self._tw.write(extra, **kwargs) + self.currentfspath = -2 + + def ensure_newline(self) -> None: + if self.currentfspath: + self._tw.line() + self.currentfspath = None + + def wrap_write( + self, + content: str, + *, + flush: bool = False, + margin: int = 8, + line_sep: str = "\n", + **markup: bool, + ) -> None: + """Wrap message with margin for progress info.""" + width_of_current_line = self._tw.width_of_current_line + wrapped = line_sep.join( + textwrap.wrap( + " " * width_of_current_line + content, + width=self._screen_width - margin, + drop_whitespace=True, + replace_whitespace=False, + ), + ) + wrapped = wrapped[width_of_current_line:] + self._tw.write(wrapped, flush=flush, **markup) + + def write(self, content: str, *, flush: bool = False, **markup: bool) -> None: + self._tw.write(content, flush=flush, **markup) + + def flush(self) -> None: + self._tw.flush() + + def write_line(self, line: str | bytes, **markup: bool) -> None: + if not isinstance(line, str): + line = str(line, errors="replace") + self.ensure_newline() + self._tw.line(line, **markup) + + def rewrite(self, line: str, **markup: bool) -> None: + """Rewinds the terminal cursor to the beginning and writes the given line. + + :param erase: + If True, will also add spaces until the full terminal width to ensure + previous lines are properly erased. + + The rest of the keyword arguments are markup instructions. + """ + erase = markup.pop("erase", False) + if erase: + fill_count = self._tw.fullwidth - len(line) - 1 + fill = " " * fill_count + else: + fill = "" + line = str(line) + self._tw.write("\r" + line + fill, **markup) + + def write_sep( + self, + sep: str, + title: str | None = None, + fullwidth: int | None = None, + **markup: bool, + ) -> None: + self.ensure_newline() + self._tw.sep(sep, title, fullwidth, **markup) + + def section(self, title: str, sep: str = "=", **kw: bool) -> None: + self._tw.sep(sep, title, **kw) + + def line(self, msg: str, **kw: bool) -> None: + self._tw.line(msg, **kw) + + def _add_stats(self, category: str, items: Sequence[Any]) -> None: + set_main_color = category not in self.stats + self.stats.setdefault(category, []).extend(items) + if set_main_color: + self._set_main_color() + + def pytest_internalerror(self, excrepr: ExceptionRepr) -> bool: + for line in str(excrepr).split("\n"): + self.write_line("INTERNALERROR> " + line) + return True + + def pytest_warning_recorded( + self, + warning_message: warnings.WarningMessage, + nodeid: str, + ) -> None: + from _pytest.warnings import warning_record_to_str + + fslocation = warning_message.filename, warning_message.lineno + message = warning_record_to_str(warning_message) + + warning_report = WarningReport( + fslocation=fslocation, message=message, nodeid=nodeid + ) + self._add_stats("warnings", [warning_report]) + + def pytest_plugin_registered(self, plugin: _PluggyPlugin) -> None: + if self.config.option.traceconfig: + msg = f"PLUGIN registered: {plugin}" + # XXX This event may happen during setup/teardown time + # which unfortunately captures our output here + # which garbles our output if we use self.write_line. + self.write_line(msg) + + def pytest_deselected(self, items: Sequence[Item]) -> None: + self._add_stats("deselected", items) + + def pytest_runtest_logstart( + self, nodeid: str, location: tuple[str, int | None, str] + ) -> None: + fspath, lineno, domain = location + # Ensure that the path is printed before the + # 1st test of a module starts running. + if self.showlongtestinfo: + line = self._locationline(nodeid, fspath, lineno, domain) + self.write_ensure_prefix(line, "") + self.flush() + elif self.showfspath: + self.write_fspath_result(nodeid, "") + self.flush() + + def pytest_runtest_logreport(self, report: TestReport) -> None: + self._tests_ran = True + rep = report + + res = TestShortLogReport( + *self.config.hook.pytest_report_teststatus(report=rep, config=self.config) + ) + category, letter, word = res.category, res.letter, res.word + if not isinstance(word, tuple): + markup = None + else: + word, markup = word + self._add_stats(category, [rep]) + if not letter and not word: + # Probably passed setup/teardown. + return + if markup is None: + was_xfail = hasattr(report, "wasxfail") + if rep.passed and not was_xfail: + markup = {"green": True} + elif rep.passed and was_xfail: + markup = {"yellow": True} + elif rep.failed: + markup = {"red": True} + elif rep.skipped: + markup = {"yellow": True} + else: + markup = {} + self._progress_nodeids_reported.add(rep.nodeid) + if self.config.get_verbosity(Config.VERBOSITY_TEST_CASES) <= 0: + self._tw.write(letter, **markup) + # When running in xdist, the logreport and logfinish of multiple + # items are interspersed, e.g. `logreport`, `logreport`, + # `logfinish`, `logfinish`. To avoid the "past edge" calculation + # from getting confused and overflowing (#7166), do the past edge + # printing here and not in logfinish, except for the 100% which + # should only be printed after all teardowns are finished. + if self._show_progress_info and not self._is_last_item: + self._write_progress_information_if_past_edge() + else: + line = self._locationline(rep.nodeid, *rep.location) + running_xdist = hasattr(rep, "node") + if not running_xdist: + self.write_ensure_prefix(line, word, **markup) + if rep.skipped or hasattr(report, "wasxfail"): + reason = _get_raw_skip_reason(rep) + if self.config.get_verbosity(Config.VERBOSITY_TEST_CASES) < 2: + available_width = ( + (self._tw.fullwidth - self._tw.width_of_current_line) + - len(" [100%]") + - 1 + ) + formatted_reason = _format_trimmed( + " ({})", reason, available_width + ) + else: + formatted_reason = f" ({reason})" + + if reason and formatted_reason is not None: + self.wrap_write(formatted_reason) + if self._show_progress_info: + self._write_progress_information_filling_space() + else: + self.ensure_newline() + self._tw.write(f"[{rep.node.gateway.id}]") + if self._show_progress_info: + self._tw.write( + self._get_progress_information_message() + " ", cyan=True + ) + else: + self._tw.write(" ") + self._tw.write(word, **markup) + self._tw.write(" " + line) + self.currentfspath = -2 + self.flush() + + @property + def _is_last_item(self) -> bool: + assert self._session is not None + return len(self._progress_nodeids_reported) == self._session.testscollected + + @hookimpl(wrapper=True) + def pytest_runtestloop(self) -> Generator[None, object, object]: + result = yield + + # Write the final/100% progress -- deferred until the loop is complete. + if ( + self.config.get_verbosity(Config.VERBOSITY_TEST_CASES) <= 0 + and self._show_progress_info + and self._progress_nodeids_reported + ): + self._write_progress_information_filling_space() + + return result + + def _get_progress_information_message(self) -> str: + assert self._session + collected = self._session.testscollected + if self._show_progress_info == "count": + if collected: + progress = len(self._progress_nodeids_reported) + counter_format = f"{{:{len(str(collected))}d}}" + format_string = f" [{counter_format}/{{}}]" + return format_string.format(progress, collected) + return f" [ {collected} / {collected} ]" + else: + if collected: + return ( + f" [{len(self._progress_nodeids_reported) * 100 // collected:3d}%]" + ) + return " [100%]" + + def _write_progress_information_if_past_edge(self) -> None: + w = self._width_of_current_line + if self._show_progress_info == "count": + assert self._session + num_tests = self._session.testscollected + progress_length = len(f" [{num_tests}/{num_tests}]") + else: + progress_length = len(" [100%]") + past_edge = w + progress_length + 1 >= self._screen_width + if past_edge: + main_color, _ = self._get_main_color() + msg = self._get_progress_information_message() + self._tw.write(msg + "\n", **{main_color: True}) + + def _write_progress_information_filling_space(self) -> None: + color, _ = self._get_main_color() + msg = self._get_progress_information_message() + w = self._width_of_current_line + fill = self._tw.fullwidth - w - 1 + self.write(msg.rjust(fill), flush=True, **{color: True}) + + @property + def _width_of_current_line(self) -> int: + """Return the width of the current line.""" + return self._tw.width_of_current_line + + def pytest_collection(self) -> None: + if self.isatty: + if self.config.option.verbose >= 0: + self.write("collecting ... ", flush=True, bold=True) + self._collect_report_last_write = timing.time() + elif self.config.option.verbose >= 1: + self.write("collecting ... ", flush=True, bold=True) + + def pytest_collectreport(self, report: CollectReport) -> None: + if report.failed: + self._add_stats("error", [report]) + elif report.skipped: + self._add_stats("skipped", [report]) + items = [x for x in report.result if isinstance(x, Item)] + self._numcollected += len(items) + if self.isatty: + self.report_collect() + + def report_collect(self, final: bool = False) -> None: + if self.config.option.verbose < 0: + return + + if not final: + # Only write "collecting" report every 0.5s. + t = timing.time() + if ( + self._collect_report_last_write is not None + and self._collect_report_last_write > t - REPORT_COLLECTING_RESOLUTION + ): + return + self._collect_report_last_write = t + + errors = len(self.stats.get("error", [])) + skipped = len(self.stats.get("skipped", [])) + deselected = len(self.stats.get("deselected", [])) + selected = self._numcollected - deselected + line = "collected " if final else "collecting " + line += ( + str(self._numcollected) + " item" + ("" if self._numcollected == 1 else "s") + ) + if errors: + line += " / %d error%s" % (errors, "s" if errors != 1 else "") + if deselected: + line += " / %d deselected" % deselected + if skipped: + line += " / %d skipped" % skipped + if self._numcollected > selected: + line += " / %d selected" % selected + if self.isatty: + self.rewrite(line, bold=True, erase=True) + if final: + self.write("\n") + else: + self.write_line(line) + + @hookimpl(trylast=True) + def pytest_sessionstart(self, session: Session) -> None: + self._session = session + self._sessionstarttime = timing.time() + if not self.showheader: + return + self.write_sep("=", "test session starts", bold=True) + verinfo = platform.python_version() + if not self.no_header: + msg = f"platform {sys.platform} -- Python {verinfo}" + pypy_version_info = getattr(sys, "pypy_version_info", None) + if pypy_version_info: + verinfo = ".".join(map(str, pypy_version_info[:3])) + msg += f"[pypy-{verinfo}-{pypy_version_info[3]}]" + msg += f", pytest-{_pytest._version.version}, pluggy-{pluggy.__version__}" + if ( + self.verbosity > 0 + or self.config.option.debug + or getattr(self.config.option, "pastebin", None) + ): + msg += " -- " + str(sys.executable) + self.write_line(msg) + lines = self.config.hook.pytest_report_header( + config=self.config, start_path=self.startpath + ) + self._write_report_lines_from_hooks(lines) + + def _write_report_lines_from_hooks( + self, lines: Sequence[str | Sequence[str]] + ) -> None: + for line_or_lines in reversed(lines): + if isinstance(line_or_lines, str): + self.write_line(line_or_lines) + else: + for line in line_or_lines: + self.write_line(line) + + def pytest_report_header(self, config: Config) -> list[str]: + result = [f"rootdir: {config.rootpath}"] + + if config.inipath: + result.append("configfile: " + bestrelpath(config.rootpath, config.inipath)) + + if config.args_source == Config.ArgsSource.TESTPATHS: + testpaths: list[str] = config.getini("testpaths") + result.append("testpaths: {}".format(", ".join(testpaths))) + + plugininfo = config.pluginmanager.list_plugin_distinfo() + if plugininfo: + result.append( + "plugins: {}".format(", ".join(_plugin_nameversions(plugininfo))) + ) + return result + + def pytest_collection_finish(self, session: Session) -> None: + self.report_collect(True) + + lines = self.config.hook.pytest_report_collectionfinish( + config=self.config, + start_path=self.startpath, + items=session.items, + ) + self._write_report_lines_from_hooks(lines) + + if self.config.getoption("collectonly"): + if session.items: + if self.config.option.verbose > -1: + self._tw.line("") + self._printcollecteditems(session.items) + + failed = self.stats.get("failed") + if failed: + self._tw.sep("!", "collection failures") + for rep in failed: + rep.toterminal(self._tw) + + def _printcollecteditems(self, items: Sequence[Item]) -> None: + test_cases_verbosity = self.config.get_verbosity(Config.VERBOSITY_TEST_CASES) + if test_cases_verbosity < 0: + if test_cases_verbosity < -1: + counts = Counter(item.nodeid.split("::", 1)[0] for item in items) + for name, count in sorted(counts.items()): + self._tw.line("%s: %d" % (name, count)) + else: + for item in items: + self._tw.line(item.nodeid) + return + stack: list[Node] = [] + indent = "" + for item in items: + needed_collectors = item.listchain()[1:] # strip root node + while stack: + if stack == needed_collectors[: len(stack)]: + break + stack.pop() + for col in needed_collectors[len(stack) :]: + stack.append(col) + indent = (len(stack) - 1) * " " + self._tw.line(f"{indent}{col}") + if test_cases_verbosity >= 1: + obj = getattr(col, "obj", None) + doc = inspect.getdoc(obj) if obj else None + if doc: + for line in doc.splitlines(): + self._tw.line("{}{}".format(indent + " ", line)) + + @hookimpl(wrapper=True) + def pytest_sessionfinish( + self, session: Session, exitstatus: int | ExitCode + ) -> Generator[None]: + result = yield + self._tw.line("") + summary_exit_codes = ( + ExitCode.OK, + ExitCode.TESTS_FAILED, + ExitCode.INTERRUPTED, + ExitCode.USAGE_ERROR, + ExitCode.NO_TESTS_COLLECTED, + ) + if exitstatus in summary_exit_codes and not self.no_summary: + self.config.hook.pytest_terminal_summary( + terminalreporter=self, exitstatus=exitstatus, config=self.config + ) + if session.shouldfail: + self.write_sep("!", str(session.shouldfail), red=True) + if exitstatus == ExitCode.INTERRUPTED: + self._report_keyboardinterrupt() + self._keyboardinterrupt_memo = None + elif session.shouldstop: + self.write_sep("!", str(session.shouldstop), red=True) + self.summary_stats() + return result + + @hookimpl(wrapper=True) + def pytest_terminal_summary(self) -> Generator[None]: + self.summary_errors() + self.summary_failures() + self.summary_xfailures() + self.summary_warnings() + self.summary_passes() + self.summary_xpasses() + try: + return (yield) + finally: + self.short_test_summary() + # Display any extra warnings from teardown here (if any). + self.summary_warnings() + + def pytest_keyboard_interrupt(self, excinfo: ExceptionInfo[BaseException]) -> None: + self._keyboardinterrupt_memo = excinfo.getrepr(funcargs=True) + + def pytest_unconfigure(self) -> None: + if self._keyboardinterrupt_memo is not None: + self._report_keyboardinterrupt() + + def _report_keyboardinterrupt(self) -> None: + excrepr = self._keyboardinterrupt_memo + assert excrepr is not None + assert excrepr.reprcrash is not None + msg = excrepr.reprcrash.message + self.write_sep("!", msg) + if "KeyboardInterrupt" in msg: + if self.config.option.fulltrace: + excrepr.toterminal(self._tw) + else: + excrepr.reprcrash.toterminal(self._tw) + self._tw.line( + "(to show a full traceback on KeyboardInterrupt use --full-trace)", + yellow=True, + ) + + def _locationline( + self, nodeid: str, fspath: str, lineno: int | None, domain: str + ) -> str: + def mkrel(nodeid: str) -> str: + line = self.config.cwd_relative_nodeid(nodeid) + if domain and line.endswith(domain): + line = line[: -len(domain)] + values = domain.split("[") + values[0] = values[0].replace(".", "::") # don't replace '.' in params + line += "[".join(values) + return line + + # fspath comes from testid which has a "/"-normalized path. + if fspath: + res = mkrel(nodeid) + if self.verbosity >= 2 and nodeid.split("::")[0] != fspath.replace( + "\\", nodes.SEP + ): + res += " <- " + bestrelpath(self.startpath, Path(fspath)) + else: + res = "[location]" + return res + " " + + def _getfailureheadline(self, rep): + head_line = rep.head_line + if head_line: + return head_line + return "test session" # XXX? + + def _getcrashline(self, rep): + try: + return str(rep.longrepr.reprcrash) + except AttributeError: + try: + return str(rep.longrepr)[:50] + except AttributeError: + return "" + + # + # Summaries for sessionfinish. + # + def getreports(self, name: str): + return [x for x in self.stats.get(name, ()) if not hasattr(x, "_pdbshown")] + + def summary_warnings(self) -> None: + if self.hasopt("w"): + all_warnings: list[WarningReport] | None = self.stats.get("warnings") + if not all_warnings: + return + + final = self._already_displayed_warnings is not None + if final: + warning_reports = all_warnings[self._already_displayed_warnings :] + else: + warning_reports = all_warnings + self._already_displayed_warnings = len(warning_reports) + if not warning_reports: + return + + reports_grouped_by_message: dict[str, list[WarningReport]] = {} + for wr in warning_reports: + reports_grouped_by_message.setdefault(wr.message, []).append(wr) + + def collapsed_location_report(reports: list[WarningReport]) -> str: + locations = [] + for w in reports: + location = w.get_location(self.config) + if location: + locations.append(location) + + if len(locations) < 10: + return "\n".join(map(str, locations)) + + counts_by_filename = Counter( + str(loc).split("::", 1)[0] for loc in locations + ) + return "\n".join( + "{}: {} warning{}".format(k, v, "s" if v > 1 else "") + for k, v in counts_by_filename.items() + ) + + title = "warnings summary (final)" if final else "warnings summary" + self.write_sep("=", title, yellow=True, bold=False) + for message, message_reports in reports_grouped_by_message.items(): + maybe_location = collapsed_location_report(message_reports) + if maybe_location: + self._tw.line(maybe_location) + lines = message.splitlines() + indented = "\n".join(" " + x for x in lines) + message = indented.rstrip() + else: + message = message.rstrip() + self._tw.line(message) + self._tw.line() + self._tw.line( + "-- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html" + ) + + def summary_passes(self) -> None: + self.summary_passes_combined("passed", "PASSES", "P") + + def summary_xpasses(self) -> None: + self.summary_passes_combined("xpassed", "XPASSES", "X") + + def summary_passes_combined( + self, which_reports: str, sep_title: str, needed_opt: str + ) -> None: + if self.config.option.tbstyle != "no": + if self.hasopt(needed_opt): + reports: list[TestReport] = self.getreports(which_reports) + if not reports: + return + self.write_sep("=", sep_title) + for rep in reports: + if rep.sections: + msg = self._getfailureheadline(rep) + self.write_sep("_", msg, green=True, bold=True) + self._outrep_summary(rep) + self._handle_teardown_sections(rep.nodeid) + + def _get_teardown_reports(self, nodeid: str) -> list[TestReport]: + reports = self.getreports("") + return [ + report + for report in reports + if report.when == "teardown" and report.nodeid == nodeid + ] + + def _handle_teardown_sections(self, nodeid: str) -> None: + for report in self._get_teardown_reports(nodeid): + self.print_teardown_sections(report) + + def print_teardown_sections(self, rep: TestReport) -> None: + showcapture = self.config.option.showcapture + if showcapture == "no": + return + for secname, content in rep.sections: + if showcapture != "all" and showcapture not in secname: + continue + if "teardown" in secname: + self._tw.sep("-", secname) + if content[-1:] == "\n": + content = content[:-1] + self._tw.line(content) + + def summary_failures(self) -> None: + style = self.config.option.tbstyle + self.summary_failures_combined("failed", "FAILURES", style=style) + + def summary_xfailures(self) -> None: + show_tb = self.config.option.xfail_tb + style = self.config.option.tbstyle if show_tb else "no" + self.summary_failures_combined("xfailed", "XFAILURES", style=style) + + def summary_failures_combined( + self, + which_reports: str, + sep_title: str, + *, + style: str, + needed_opt: str | None = None, + ) -> None: + if style != "no": + if not needed_opt or self.hasopt(needed_opt): + reports: list[BaseReport] = self.getreports(which_reports) + if not reports: + return + self.write_sep("=", sep_title) + if style == "line": + for rep in reports: + line = self._getcrashline(rep) + self.write_line(line) + else: + for rep in reports: + msg = self._getfailureheadline(rep) + self.write_sep("_", msg, red=True, bold=True) + self._outrep_summary(rep) + self._handle_teardown_sections(rep.nodeid) + + def summary_errors(self) -> None: + if self.config.option.tbstyle != "no": + reports: list[BaseReport] = self.getreports("error") + if not reports: + return + self.write_sep("=", "ERRORS") + for rep in self.stats["error"]: + msg = self._getfailureheadline(rep) + if rep.when == "collect": + msg = "ERROR collecting " + msg + else: + msg = f"ERROR at {rep.when} of {msg}" + self.write_sep("_", msg, red=True, bold=True) + self._outrep_summary(rep) + + def _outrep_summary(self, rep: BaseReport) -> None: + rep.toterminal(self._tw) + showcapture = self.config.option.showcapture + if showcapture == "no": + return + for secname, content in rep.sections: + if showcapture != "all" and showcapture not in secname: + continue + self._tw.sep("-", secname) + if content[-1:] == "\n": + content = content[:-1] + self._tw.line(content) + + def summary_stats(self) -> None: + if self.verbosity < -1: + return + + session_duration = timing.time() - self._sessionstarttime + (parts, main_color) = self.build_summary_stats_line() + line_parts = [] + + display_sep = self.verbosity >= 0 + if display_sep: + fullwidth = self._tw.fullwidth + for text, markup in parts: + with_markup = self._tw.markup(text, **markup) + if display_sep: + fullwidth += len(with_markup) - len(text) + line_parts.append(with_markup) + msg = ", ".join(line_parts) + + main_markup = {main_color: True} + duration = f" in {format_session_duration(session_duration)}" + duration_with_markup = self._tw.markup(duration, **main_markup) + if display_sep: + fullwidth += len(duration_with_markup) - len(duration) + msg += duration_with_markup + + if display_sep: + markup_for_end_sep = self._tw.markup("", **main_markup) + if markup_for_end_sep.endswith("\x1b[0m"): + markup_for_end_sep = markup_for_end_sep[:-4] + fullwidth += len(markup_for_end_sep) + msg += markup_for_end_sep + + if display_sep: + self.write_sep("=", msg, fullwidth=fullwidth, **main_markup) + else: + self.write_line(msg, **main_markup) + + def short_test_summary(self) -> None: + if not self.reportchars: + return + + def show_simple(lines: list[str], *, stat: str) -> None: + failed = self.stats.get(stat, []) + if not failed: + return + config = self.config + for rep in failed: + color = _color_for_type.get(stat, _color_for_type_default) + line = _get_line_with_reprcrash_message( + config, rep, self._tw, {color: True} + ) + lines.append(line) + + def show_xfailed(lines: list[str]) -> None: + xfailed = self.stats.get("xfailed", []) + for rep in xfailed: + verbose_word, verbose_markup = rep._get_verbose_word_with_markup( + self.config, {_color_for_type["warnings"]: True} + ) + markup_word = self._tw.markup(verbose_word, **verbose_markup) + nodeid = _get_node_id_with_markup(self._tw, self.config, rep) + line = f"{markup_word} {nodeid}" + reason = rep.wasxfail + if reason: + line += " - " + str(reason) + + lines.append(line) + + def show_xpassed(lines: list[str]) -> None: + xpassed = self.stats.get("xpassed", []) + for rep in xpassed: + verbose_word, verbose_markup = rep._get_verbose_word_with_markup( + self.config, {_color_for_type["warnings"]: True} + ) + markup_word = self._tw.markup(verbose_word, **verbose_markup) + nodeid = _get_node_id_with_markup(self._tw, self.config, rep) + line = f"{markup_word} {nodeid}" + reason = rep.wasxfail + if reason: + line += " - " + str(reason) + lines.append(line) + + def show_skipped_folded(lines: list[str]) -> None: + skipped: list[CollectReport] = self.stats.get("skipped", []) + fskips = _folded_skips(self.startpath, skipped) if skipped else [] + if not fskips: + return + verbose_word, verbose_markup = skipped[0]._get_verbose_word_with_markup( + self.config, {_color_for_type["warnings"]: True} + ) + markup_word = self._tw.markup(verbose_word, **verbose_markup) + prefix = "Skipped: " + for num, fspath, lineno, reason in fskips: + if reason.startswith(prefix): + reason = reason[len(prefix) :] + if lineno is not None: + lines.append( + "%s [%d] %s:%d: %s" % (markup_word, num, fspath, lineno, reason) + ) + else: + lines.append("%s [%d] %s: %s" % (markup_word, num, fspath, reason)) + + def show_skipped_unfolded(lines: list[str]) -> None: + skipped: list[CollectReport] = self.stats.get("skipped", []) + + for rep in skipped: + assert rep.longrepr is not None + assert isinstance(rep.longrepr, tuple), (rep, rep.longrepr) + assert len(rep.longrepr) == 3, (rep, rep.longrepr) + + verbose_word, verbose_markup = rep._get_verbose_word_with_markup( + self.config, {_color_for_type["warnings"]: True} + ) + markup_word = self._tw.markup(verbose_word, **verbose_markup) + nodeid = _get_node_id_with_markup(self._tw, self.config, rep) + line = f"{markup_word} {nodeid}" + reason = rep.longrepr[2] + if reason: + line += " - " + str(reason) + lines.append(line) + + def show_skipped(lines: list[str]) -> None: + if self.foldskipped: + show_skipped_folded(lines) + else: + show_skipped_unfolded(lines) + + REPORTCHAR_ACTIONS: Mapping[str, Callable[[list[str]], None]] = { + "x": show_xfailed, + "X": show_xpassed, + "f": partial(show_simple, stat="failed"), + "s": show_skipped, + "p": partial(show_simple, stat="passed"), + "E": partial(show_simple, stat="error"), + } + + lines: list[str] = [] + for char in self.reportchars: + action = REPORTCHAR_ACTIONS.get(char) + if action: # skipping e.g. "P" (passed with output) here. + action(lines) + + if lines: + self.write_sep("=", "short test summary info", cyan=True, bold=True) + for line in lines: + self.write_line(line) + + def _get_main_color(self) -> tuple[str, list[str]]: + if self._main_color is None or self._known_types is None or self._is_last_item: + self._set_main_color() + assert self._main_color + assert self._known_types + return self._main_color, self._known_types + + def _determine_main_color(self, unknown_type_seen: bool) -> str: + stats = self.stats + if "failed" in stats or "error" in stats: + main_color = "red" + elif "warnings" in stats or "xpassed" in stats or unknown_type_seen: + main_color = "yellow" + elif "passed" in stats or not self._is_last_item: + main_color = "green" + else: + main_color = "yellow" + return main_color + + def _set_main_color(self) -> None: + unknown_types: list[str] = [] + for found_type in self.stats: + if found_type: # setup/teardown reports have an empty key, ignore them + if found_type not in KNOWN_TYPES and found_type not in unknown_types: + unknown_types.append(found_type) + self._known_types = list(KNOWN_TYPES) + unknown_types + self._main_color = self._determine_main_color(bool(unknown_types)) + + def build_summary_stats_line(self) -> tuple[list[tuple[str, dict[str, bool]]], str]: + """ + Build the parts used in the last summary stats line. + + The summary stats line is the line shown at the end, "=== 12 passed, 2 errors in Xs===". + + This function builds a list of the "parts" that make up for the text in that line, in + the example above it would be: + + [ + ("12 passed", {"green": True}), + ("2 errors", {"red": True} + ] + + That last dict for each line is a "markup dictionary", used by TerminalWriter to + color output. + + The final color of the line is also determined by this function, and is the second + element of the returned tuple. + """ + if self.config.getoption("collectonly"): + return self._build_collect_only_summary_stats_line() + else: + return self._build_normal_summary_stats_line() + + def _get_reports_to_display(self, key: str) -> list[Any]: + """Get test/collection reports for the given status key, such as `passed` or `error`.""" + reports = self.stats.get(key, []) + return [x for x in reports if getattr(x, "count_towards_summary", True)] + + def _build_normal_summary_stats_line( + self, + ) -> tuple[list[tuple[str, dict[str, bool]]], str]: + main_color, known_types = self._get_main_color() + parts = [] + + for key in known_types: + reports = self._get_reports_to_display(key) + if reports: + count = len(reports) + color = _color_for_type.get(key, _color_for_type_default) + markup = {color: True, "bold": color == main_color} + parts.append(("%d %s" % pluralize(count, key), markup)) + + if not parts: + parts = [("no tests ran", {_color_for_type_default: True})] + + return parts, main_color + + def _build_collect_only_summary_stats_line( + self, + ) -> tuple[list[tuple[str, dict[str, bool]]], str]: + deselected = len(self._get_reports_to_display("deselected")) + errors = len(self._get_reports_to_display("error")) + + if self._numcollected == 0: + parts = [("no tests collected", {"yellow": True})] + main_color = "yellow" + + elif deselected == 0: + main_color = "green" + collected_output = "%d %s collected" % pluralize(self._numcollected, "test") + parts = [(collected_output, {main_color: True})] + else: + all_tests_were_deselected = self._numcollected == deselected + if all_tests_were_deselected: + main_color = "yellow" + collected_output = f"no tests collected ({deselected} deselected)" + else: + main_color = "green" + selected = self._numcollected - deselected + collected_output = f"{selected}/{self._numcollected} tests collected ({deselected} deselected)" + + parts = [(collected_output, {main_color: True})] + + if errors: + main_color = _color_for_type["error"] + parts += [("%d %s" % pluralize(errors, "error"), {main_color: True})] + + return parts, main_color + + +def _get_node_id_with_markup(tw: TerminalWriter, config: Config, rep: BaseReport): + nodeid = config.cwd_relative_nodeid(rep.nodeid) + path, *parts = nodeid.split("::") + if parts: + parts_markup = tw.markup("::".join(parts), bold=True) + return path + "::" + parts_markup + else: + return path + + +def _format_trimmed(format: str, msg: str, available_width: int) -> str | None: + """Format msg into format, ellipsizing it if doesn't fit in available_width. + + Returns None if even the ellipsis can't fit. + """ + # Only use the first line. + i = msg.find("\n") + if i != -1: + msg = msg[:i] + + ellipsis = "..." + format_width = wcswidth(format.format("")) + if format_width + len(ellipsis) > available_width: + return None + + if format_width + wcswidth(msg) > available_width: + available_width -= len(ellipsis) + msg = msg[:available_width] + while format_width + wcswidth(msg) > available_width: + msg = msg[:-1] + msg += ellipsis + + return format.format(msg) + + +def _get_line_with_reprcrash_message( + config: Config, rep: BaseReport, tw: TerminalWriter, word_markup: dict[str, bool] +) -> str: + """Get summary line for a report, trying to add reprcrash message.""" + verbose_word, verbose_markup = rep._get_verbose_word_with_markup( + config, word_markup + ) + word = tw.markup(verbose_word, **verbose_markup) + node = _get_node_id_with_markup(tw, config, rep) + + line = f"{word} {node}" + line_width = wcswidth(line) + + try: + # Type ignored intentionally -- possible AttributeError expected. + msg = rep.longrepr.reprcrash.message # type: ignore[union-attr] + except AttributeError: + pass + else: + if running_on_ci() or config.option.verbose >= 2: + msg = f" - {msg}" + else: + available_width = tw.fullwidth - line_width + msg = _format_trimmed(" - {}", msg, available_width) + if msg is not None: + line += msg + + return line + + +def _folded_skips( + startpath: Path, + skipped: Sequence[CollectReport], +) -> list[tuple[int, str, int | None, str]]: + d: dict[tuple[str, int | None, str], list[CollectReport]] = {} + for event in skipped: + assert event.longrepr is not None + assert isinstance(event.longrepr, tuple), (event, event.longrepr) + assert len(event.longrepr) == 3, (event, event.longrepr) + fspath, lineno, reason = event.longrepr + # For consistency, report all fspaths in relative form. + fspath = bestrelpath(startpath, Path(fspath)) + keywords = getattr(event, "keywords", {}) + # Folding reports with global pytestmark variable. + # This is a workaround, because for now we cannot identify the scope of a skip marker + # TODO: Revisit after marks scope would be fixed. + if ( + event.when == "setup" + and "skip" in keywords + and "pytestmark" not in keywords + ): + key: tuple[str, int | None, str] = (fspath, None, reason) + else: + key = (fspath, lineno, reason) + d.setdefault(key, []).append(event) + values: list[tuple[int, str, int | None, str]] = [] + for key, events in d.items(): + values.append((len(events), *key)) + return values + + +_color_for_type = { + "failed": "red", + "error": "red", + "warnings": "yellow", + "passed": "green", +} +_color_for_type_default = "yellow" + + +def pluralize(count: int, noun: str) -> tuple[int, str]: + # No need to pluralize words such as `failed` or `passed`. + if noun not in ["error", "warnings", "test"]: + return count, noun + + # The `warnings` key is plural. To avoid API breakage, we keep it that way but + # set it to singular here so we can determine plurality in the same way as we do + # for `error`. + noun = noun.replace("warnings", "warning") + + return count, noun + "s" if count != 1 else noun + + +def _plugin_nameversions(plugininfo) -> list[str]: + values: list[str] = [] + for plugin, dist in plugininfo: + # Gets us name and version! + name = f"{dist.project_name}-{dist.version}" + # Questionable convenience, but it keeps things short. + if name.startswith("pytest-"): + name = name[7:] + # We decided to print python package names they can have more than one plugin. + if name not in values: + values.append(name) + return values + + +def format_session_duration(seconds: float) -> str: + """Format the given seconds in a human readable manner to show in the final summary.""" + if seconds < 60: + return f"{seconds:.2f}s" + else: + dt = datetime.timedelta(seconds=int(seconds)) + return f"{seconds:.2f}s ({dt})" + + +def _get_raw_skip_reason(report: TestReport) -> str: + """Get the reason string of a skip/xfail/xpass test report. + + The string is just the part given by the user. + """ + if hasattr(report, "wasxfail"): + reason = report.wasxfail + if reason.startswith("reason: "): + reason = reason[len("reason: ") :] + return reason + else: + assert report.skipped + assert isinstance(report.longrepr, tuple) + _, _, reason = report.longrepr + if reason.startswith("Skipped: "): + reason = reason[len("Skipped: ") :] + elif reason == "Skipped": + reason = "" + return reason diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/threadexception.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/threadexception.py new file mode 100644 index 0000000..c1ed803 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/threadexception.py @@ -0,0 +1,97 @@ +from __future__ import annotations + +import threading +import traceback +from types import TracebackType +from typing import Any +from typing import Callable +from typing import Generator +from typing import TYPE_CHECKING +import warnings + +import pytest + + +if TYPE_CHECKING: + from typing_extensions import Self + + +# Copied from cpython/Lib/test/support/threading_helper.py, with modifications. +class catch_threading_exception: + """Context manager catching threading.Thread exception using + threading.excepthook. + + Storing exc_value using a custom hook can create a reference cycle. The + reference cycle is broken explicitly when the context manager exits. + + Storing thread using a custom hook can resurrect it if it is set to an + object which is being finalized. Exiting the context manager clears the + stored object. + + Usage: + with threading_helper.catch_threading_exception() as cm: + # code spawning a thread which raises an exception + ... + # check the thread exception: use cm.args + ... + # cm.args attribute no longer exists at this point + # (to break a reference cycle) + """ + + def __init__(self) -> None: + self.args: threading.ExceptHookArgs | None = None + self._old_hook: Callable[[threading.ExceptHookArgs], Any] | None = None + + def _hook(self, args: threading.ExceptHookArgs) -> None: + self.args = args + + def __enter__(self) -> Self: + self._old_hook = threading.excepthook + threading.excepthook = self._hook + return self + + def __exit__( + self, + exc_type: type[BaseException] | None, + exc_val: BaseException | None, + exc_tb: TracebackType | None, + ) -> None: + assert self._old_hook is not None + threading.excepthook = self._old_hook + self._old_hook = None + del self.args + + +def thread_exception_runtest_hook() -> Generator[None]: + with catch_threading_exception() as cm: + try: + yield + finally: + if cm.args: + thread_name = ( + "" if cm.args.thread is None else cm.args.thread.name + ) + msg = f"Exception in thread {thread_name}\n\n" + msg += "".join( + traceback.format_exception( + cm.args.exc_type, + cm.args.exc_value, + cm.args.exc_traceback, + ) + ) + warnings.warn(pytest.PytestUnhandledThreadExceptionWarning(msg)) + + +@pytest.hookimpl(wrapper=True, trylast=True) +def pytest_runtest_setup() -> Generator[None]: + yield from thread_exception_runtest_hook() + + +@pytest.hookimpl(wrapper=True, tryfirst=True) +def pytest_runtest_call() -> Generator[None]: + yield from thread_exception_runtest_hook() + + +@pytest.hookimpl(wrapper=True, tryfirst=True) +def pytest_runtest_teardown() -> Generator[None]: + yield from thread_exception_runtest_hook() diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/timing.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/timing.py new file mode 100644 index 0000000..b23c7f6 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/timing.py @@ -0,0 +1,16 @@ +"""Indirection for time functions. + +We intentionally grab some "time" functions internally to avoid tests mocking "time" to affect +pytest runtime information (issue #185). + +Fixture "mock_timing" also interacts with this module for pytest's own tests. +""" + +from __future__ import annotations + +from time import perf_counter +from time import sleep +from time import time + + +__all__ = ["perf_counter", "sleep", "time"] diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/tmpdir.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/tmpdir.py new file mode 100644 index 0000000..de0cbcf --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/tmpdir.py @@ -0,0 +1,322 @@ +# mypy: allow-untyped-defs +"""Support for providing temporary directories to test functions.""" + +from __future__ import annotations + +import dataclasses +import os +from pathlib import Path +import re +from shutil import rmtree +import tempfile +from typing import Any +from typing import Dict +from typing import final +from typing import Generator +from typing import Literal + +from .pathlib import cleanup_dead_symlinks +from .pathlib import LOCK_TIMEOUT +from .pathlib import make_numbered_dir +from .pathlib import make_numbered_dir_with_cleanup +from .pathlib import rm_rf +from _pytest.compat import get_user_id +from _pytest.config import Config +from _pytest.config import ExitCode +from _pytest.config import hookimpl +from _pytest.config.argparsing import Parser +from _pytest.deprecated import check_ispytest +from _pytest.fixtures import fixture +from _pytest.fixtures import FixtureRequest +from _pytest.monkeypatch import MonkeyPatch +from _pytest.nodes import Item +from _pytest.reports import TestReport +from _pytest.stash import StashKey + + +tmppath_result_key = StashKey[Dict[str, bool]]() +RetentionType = Literal["all", "failed", "none"] + + +@final +@dataclasses.dataclass +class TempPathFactory: + """Factory for temporary directories under the common base temp directory. + + The base directory can be configured using the ``--basetemp`` option. + """ + + _given_basetemp: Path | None + # pluggy TagTracerSub, not currently exposed, so Any. + _trace: Any + _basetemp: Path | None + _retention_count: int + _retention_policy: RetentionType + + def __init__( + self, + given_basetemp: Path | None, + retention_count: int, + retention_policy: RetentionType, + trace, + basetemp: Path | None = None, + *, + _ispytest: bool = False, + ) -> None: + check_ispytest(_ispytest) + if given_basetemp is None: + self._given_basetemp = None + else: + # Use os.path.abspath() to get absolute path instead of resolve() as it + # does not work the same in all platforms (see #4427). + # Path.absolute() exists, but it is not public (see https://bugs.python.org/issue25012). + self._given_basetemp = Path(os.path.abspath(str(given_basetemp))) + self._trace = trace + self._retention_count = retention_count + self._retention_policy = retention_policy + self._basetemp = basetemp + + @classmethod + def from_config( + cls, + config: Config, + *, + _ispytest: bool = False, + ) -> TempPathFactory: + """Create a factory according to pytest configuration. + + :meta private: + """ + check_ispytest(_ispytest) + count = int(config.getini("tmp_path_retention_count")) + if count < 0: + raise ValueError( + f"tmp_path_retention_count must be >= 0. Current input: {count}." + ) + + policy = config.getini("tmp_path_retention_policy") + if policy not in ("all", "failed", "none"): + raise ValueError( + f"tmp_path_retention_policy must be either all, failed, none. Current input: {policy}." + ) + + return cls( + given_basetemp=config.option.basetemp, + trace=config.trace.get("tmpdir"), + retention_count=count, + retention_policy=policy, + _ispytest=True, + ) + + def _ensure_relative_to_basetemp(self, basename: str) -> str: + basename = os.path.normpath(basename) + if (self.getbasetemp() / basename).resolve().parent != self.getbasetemp(): + raise ValueError(f"{basename} is not a normalized and relative path") + return basename + + def mktemp(self, basename: str, numbered: bool = True) -> Path: + """Create a new temporary directory managed by the factory. + + :param basename: + Directory base name, must be a relative path. + + :param numbered: + If ``True``, ensure the directory is unique by adding a numbered + suffix greater than any existing one: ``basename="foo-"`` and ``numbered=True`` + means that this function will create directories named ``"foo-0"``, + ``"foo-1"``, ``"foo-2"`` and so on. + + :returns: + The path to the new directory. + """ + basename = self._ensure_relative_to_basetemp(basename) + if not numbered: + p = self.getbasetemp().joinpath(basename) + p.mkdir(mode=0o700) + else: + p = make_numbered_dir(root=self.getbasetemp(), prefix=basename, mode=0o700) + self._trace("mktemp", p) + return p + + def getbasetemp(self) -> Path: + """Return the base temporary directory, creating it if needed. + + :returns: + The base temporary directory. + """ + if self._basetemp is not None: + return self._basetemp + + if self._given_basetemp is not None: + basetemp = self._given_basetemp + if basetemp.exists(): + rm_rf(basetemp) + basetemp.mkdir(mode=0o700) + basetemp = basetemp.resolve() + else: + from_env = os.environ.get("PYTEST_DEBUG_TEMPROOT") + temproot = Path(from_env or tempfile.gettempdir()).resolve() + user = get_user() or "unknown" + # use a sub-directory in the temproot to speed-up + # make_numbered_dir() call + rootdir = temproot.joinpath(f"pytest-of-{user}") + try: + rootdir.mkdir(mode=0o700, exist_ok=True) + except OSError: + # getuser() likely returned illegal characters for the platform, use unknown back off mechanism + rootdir = temproot.joinpath("pytest-of-unknown") + rootdir.mkdir(mode=0o700, exist_ok=True) + # Because we use exist_ok=True with a predictable name, make sure + # we are the owners, to prevent any funny business (on unix, where + # temproot is usually shared). + # Also, to keep things private, fixup any world-readable temp + # rootdir's permissions. Historically 0o755 was used, so we can't + # just error out on this, at least for a while. + uid = get_user_id() + if uid is not None: + rootdir_stat = rootdir.stat() + if rootdir_stat.st_uid != uid: + raise OSError( + f"The temporary directory {rootdir} is not owned by the current user. " + "Fix this and try again." + ) + if (rootdir_stat.st_mode & 0o077) != 0: + os.chmod(rootdir, rootdir_stat.st_mode & ~0o077) + keep = self._retention_count + if self._retention_policy == "none": + keep = 0 + basetemp = make_numbered_dir_with_cleanup( + prefix="pytest-", + root=rootdir, + keep=keep, + lock_timeout=LOCK_TIMEOUT, + mode=0o700, + ) + assert basetemp is not None, basetemp + self._basetemp = basetemp + self._trace("new basetemp", basetemp) + return basetemp + + +def get_user() -> str | None: + """Return the current user name, or None if getuser() does not work + in the current environment (see #1010).""" + try: + # In some exotic environments, getpass may not be importable. + import getpass + + return getpass.getuser() + except (ImportError, OSError, KeyError): + return None + + +def pytest_configure(config: Config) -> None: + """Create a TempPathFactory and attach it to the config object. + + This is to comply with existing plugins which expect the handler to be + available at pytest_configure time, but ideally should be moved entirely + to the tmp_path_factory session fixture. + """ + mp = MonkeyPatch() + config.add_cleanup(mp.undo) + _tmp_path_factory = TempPathFactory.from_config(config, _ispytest=True) + mp.setattr(config, "_tmp_path_factory", _tmp_path_factory, raising=False) + + +def pytest_addoption(parser: Parser) -> None: + parser.addini( + "tmp_path_retention_count", + help="How many sessions should we keep the `tmp_path` directories, according to `tmp_path_retention_policy`.", + default=3, + ) + + parser.addini( + "tmp_path_retention_policy", + help="Controls which directories created by the `tmp_path` fixture are kept around, based on test outcome. " + "(all/failed/none)", + default="all", + ) + + +@fixture(scope="session") +def tmp_path_factory(request: FixtureRequest) -> TempPathFactory: + """Return a :class:`pytest.TempPathFactory` instance for the test session.""" + # Set dynamically by pytest_configure() above. + return request.config._tmp_path_factory # type: ignore + + +def _mk_tmp(request: FixtureRequest, factory: TempPathFactory) -> Path: + name = request.node.name + name = re.sub(r"[\W]", "_", name) + MAXVAL = 30 + name = name[:MAXVAL] + return factory.mktemp(name, numbered=True) + + +@fixture +def tmp_path( + request: FixtureRequest, tmp_path_factory: TempPathFactory +) -> Generator[Path]: + """Return a temporary directory path object which is unique to each test + function invocation, created as a sub directory of the base temporary + directory. + + By default, a new base temporary directory is created each test session, + and old bases are removed after 3 sessions, to aid in debugging. + This behavior can be configured with :confval:`tmp_path_retention_count` and + :confval:`tmp_path_retention_policy`. + If ``--basetemp`` is used then it is cleared each session. See + :ref:`temporary directory location and retention`. + + The returned object is a :class:`pathlib.Path` object. + """ + path = _mk_tmp(request, tmp_path_factory) + yield path + + # Remove the tmpdir if the policy is "failed" and the test passed. + tmp_path_factory: TempPathFactory = request.session.config._tmp_path_factory # type: ignore + policy = tmp_path_factory._retention_policy + result_dict = request.node.stash[tmppath_result_key] + + if policy == "failed" and result_dict.get("call", True): + # We do a "best effort" to remove files, but it might not be possible due to some leaked resource, + # permissions, etc, in which case we ignore it. + rmtree(path, ignore_errors=True) + + del request.node.stash[tmppath_result_key] + + +def pytest_sessionfinish(session, exitstatus: int | ExitCode): + """After each session, remove base directory if all the tests passed, + the policy is "failed", and the basetemp is not specified by a user. + """ + tmp_path_factory: TempPathFactory = session.config._tmp_path_factory + basetemp = tmp_path_factory._basetemp + if basetemp is None: + return + + policy = tmp_path_factory._retention_policy + if ( + exitstatus == 0 + and policy == "failed" + and tmp_path_factory._given_basetemp is None + ): + if basetemp.is_dir(): + # We do a "best effort" to remove files, but it might not be possible due to some leaked resource, + # permissions, etc, in which case we ignore it. + rmtree(basetemp, ignore_errors=True) + + # Remove dead symlinks. + if basetemp.is_dir(): + cleanup_dead_symlinks(basetemp) + + +@hookimpl(wrapper=True, tryfirst=True) +def pytest_runtest_makereport( + item: Item, call +) -> Generator[None, TestReport, TestReport]: + rep = yield + assert rep.when is not None + empty: dict[str, bool] = {} + item.stash.setdefault(tmppath_result_key, empty)[rep.when] = rep.passed + return rep diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/unittest.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/unittest.py new file mode 100644 index 0000000..8cecd4f --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/unittest.py @@ -0,0 +1,435 @@ +# mypy: allow-untyped-defs +"""Discover and run std-library "unittest" style tests.""" + +from __future__ import annotations + +import inspect +import sys +import traceback +import types +from typing import Any +from typing import Callable +from typing import Generator +from typing import Iterable +from typing import Tuple +from typing import Type +from typing import TYPE_CHECKING +from typing import Union + +import _pytest._code +from _pytest.compat import is_async_function +from _pytest.config import hookimpl +from _pytest.fixtures import FixtureRequest +from _pytest.nodes import Collector +from _pytest.nodes import Item +from _pytest.outcomes import exit +from _pytest.outcomes import fail +from _pytest.outcomes import skip +from _pytest.outcomes import xfail +from _pytest.python import Class +from _pytest.python import Function +from _pytest.python import Module +from _pytest.runner import CallInfo +import pytest + + +if sys.version_info[:2] < (3, 11): + from exceptiongroup import ExceptionGroup + +if TYPE_CHECKING: + import unittest + + import twisted.trial.unittest + + +_SysExcInfoType = Union[ + Tuple[Type[BaseException], BaseException, types.TracebackType], + Tuple[None, None, None], +] + + +def pytest_pycollect_makeitem( + collector: Module | Class, name: str, obj: object +) -> UnitTestCase | None: + try: + # Has unittest been imported? + ut = sys.modules["unittest"] + # Is obj a subclass of unittest.TestCase? + # Type ignored because `ut` is an opaque module. + if not issubclass(obj, ut.TestCase): # type: ignore + return None + except Exception: + return None + # Is obj a concrete class? + # Abstract classes can't be instantiated so no point collecting them. + if inspect.isabstract(obj): + return None + # Yes, so let's collect it. + return UnitTestCase.from_parent(collector, name=name, obj=obj) + + +class UnitTestCase(Class): + # Marker for fixturemanger.getfixtureinfo() + # to declare that our children do not support funcargs. + nofuncargs = True + + def newinstance(self): + # TestCase __init__ takes the method (test) name. The TestCase + # constructor treats the name "runTest" as a special no-op, so it can be + # used when a dummy instance is needed. While unittest.TestCase has a + # default, some subclasses omit the default (#9610), so always supply + # it. + return self.obj("runTest") + + def collect(self) -> Iterable[Item | Collector]: + from unittest import TestLoader + + cls = self.obj + if not getattr(cls, "__test__", True): + return + + skipped = _is_skipped(cls) + if not skipped: + self._register_unittest_setup_method_fixture(cls) + self._register_unittest_setup_class_fixture(cls) + self._register_setup_class_fixture() + + self.session._fixturemanager.parsefactories(self.newinstance(), self.nodeid) + + loader = TestLoader() + foundsomething = False + for name in loader.getTestCaseNames(self.obj): + x = getattr(self.obj, name) + if not getattr(x, "__test__", True): + continue + yield TestCaseFunction.from_parent(self, name=name) + foundsomething = True + + if not foundsomething: + runtest = getattr(self.obj, "runTest", None) + if runtest is not None: + ut = sys.modules.get("twisted.trial.unittest", None) + if ut is None or runtest != ut.TestCase.runTest: + yield TestCaseFunction.from_parent(self, name="runTest") + + def _register_unittest_setup_class_fixture(self, cls: type) -> None: + """Register an auto-use fixture to invoke setUpClass and + tearDownClass (#517).""" + setup = getattr(cls, "setUpClass", None) + teardown = getattr(cls, "tearDownClass", None) + if setup is None and teardown is None: + return None + cleanup = getattr(cls, "doClassCleanups", lambda: None) + + def process_teardown_exceptions() -> None: + # tearDown_exceptions is a list set in the class containing exc_infos for errors during + # teardown for the class. + exc_infos = getattr(cls, "tearDown_exceptions", None) + if not exc_infos: + return + exceptions = [exc for (_, exc, _) in exc_infos] + # If a single exception, raise it directly as this provides a more readable + # error (hopefully this will improve in #12255). + if len(exceptions) == 1: + raise exceptions[0] + else: + raise ExceptionGroup("Unittest class cleanup errors", exceptions) + + def unittest_setup_class_fixture( + request: FixtureRequest, + ) -> Generator[None]: + cls = request.cls + if _is_skipped(cls): + reason = cls.__unittest_skip_why__ + raise pytest.skip.Exception(reason, _use_item_location=True) + if setup is not None: + try: + setup() + # unittest does not call the cleanup function for every BaseException, so we + # follow this here. + except Exception: + cleanup() + process_teardown_exceptions() + raise + yield + try: + if teardown is not None: + teardown() + finally: + cleanup() + process_teardown_exceptions() + + self.session._fixturemanager._register_fixture( + # Use a unique name to speed up lookup. + name=f"_unittest_setUpClass_fixture_{cls.__qualname__}", + func=unittest_setup_class_fixture, + nodeid=self.nodeid, + scope="class", + autouse=True, + ) + + def _register_unittest_setup_method_fixture(self, cls: type) -> None: + """Register an auto-use fixture to invoke setup_method and + teardown_method (#517).""" + setup = getattr(cls, "setup_method", None) + teardown = getattr(cls, "teardown_method", None) + if setup is None and teardown is None: + return None + + def unittest_setup_method_fixture( + request: FixtureRequest, + ) -> Generator[None]: + self = request.instance + if _is_skipped(self): + reason = self.__unittest_skip_why__ + raise pytest.skip.Exception(reason, _use_item_location=True) + if setup is not None: + setup(self, request.function) + yield + if teardown is not None: + teardown(self, request.function) + + self.session._fixturemanager._register_fixture( + # Use a unique name to speed up lookup. + name=f"_unittest_setup_method_fixture_{cls.__qualname__}", + func=unittest_setup_method_fixture, + nodeid=self.nodeid, + scope="function", + autouse=True, + ) + + +class TestCaseFunction(Function): + nofuncargs = True + _excinfo: list[_pytest._code.ExceptionInfo[BaseException]] | None = None + + def _getinstance(self): + assert isinstance(self.parent, UnitTestCase) + return self.parent.obj(self.name) + + # Backward compat for pytest-django; can be removed after pytest-django + # updates + some slack. + @property + def _testcase(self): + return self.instance + + def setup(self) -> None: + # A bound method to be called during teardown() if set (see 'runtest()'). + self._explicit_tearDown: Callable[[], None] | None = None + super().setup() + + def teardown(self) -> None: + if self._explicit_tearDown is not None: + self._explicit_tearDown() + self._explicit_tearDown = None + self._obj = None + del self._instance + super().teardown() + + def startTest(self, testcase: unittest.TestCase) -> None: + pass + + def _addexcinfo(self, rawexcinfo: _SysExcInfoType) -> None: + # Unwrap potential exception info (see twisted trial support below). + rawexcinfo = getattr(rawexcinfo, "_rawexcinfo", rawexcinfo) + try: + excinfo = _pytest._code.ExceptionInfo[BaseException].from_exc_info( + rawexcinfo # type: ignore[arg-type] + ) + # Invoke the attributes to trigger storing the traceback + # trial causes some issue there. + _ = excinfo.value + _ = excinfo.traceback + except TypeError: + try: + try: + values = traceback.format_exception(*rawexcinfo) + values.insert( + 0, + "NOTE: Incompatible Exception Representation, " + "displaying natively:\n\n", + ) + fail("".join(values), pytrace=False) + except (fail.Exception, KeyboardInterrupt): + raise + except BaseException: + fail( + "ERROR: Unknown Incompatible Exception " + f"representation:\n{rawexcinfo!r}", + pytrace=False, + ) + except KeyboardInterrupt: + raise + except fail.Exception: + excinfo = _pytest._code.ExceptionInfo.from_current() + self.__dict__.setdefault("_excinfo", []).append(excinfo) + + def addError( + self, testcase: unittest.TestCase, rawexcinfo: _SysExcInfoType + ) -> None: + try: + if isinstance(rawexcinfo[1], exit.Exception): + exit(rawexcinfo[1].msg) + except TypeError: + pass + self._addexcinfo(rawexcinfo) + + def addFailure( + self, testcase: unittest.TestCase, rawexcinfo: _SysExcInfoType + ) -> None: + self._addexcinfo(rawexcinfo) + + def addSkip(self, testcase: unittest.TestCase, reason: str) -> None: + try: + raise pytest.skip.Exception(reason, _use_item_location=True) + except skip.Exception: + self._addexcinfo(sys.exc_info()) + + def addExpectedFailure( + self, + testcase: unittest.TestCase, + rawexcinfo: _SysExcInfoType, + reason: str = "", + ) -> None: + try: + xfail(str(reason)) + except xfail.Exception: + self._addexcinfo(sys.exc_info()) + + def addUnexpectedSuccess( + self, + testcase: unittest.TestCase, + reason: twisted.trial.unittest.Todo | None = None, + ) -> None: + msg = "Unexpected success" + if reason: + msg += f": {reason.reason}" + # Preserve unittest behaviour - fail the test. Explicitly not an XPASS. + try: + fail(msg, pytrace=False) + except fail.Exception: + self._addexcinfo(sys.exc_info()) + + def addSuccess(self, testcase: unittest.TestCase) -> None: + pass + + def stopTest(self, testcase: unittest.TestCase) -> None: + pass + + def addDuration(self, testcase: unittest.TestCase, elapsed: float) -> None: + pass + + def runtest(self) -> None: + from _pytest.debugging import maybe_wrap_pytest_function_for_tracing + + testcase = self.instance + assert testcase is not None + + maybe_wrap_pytest_function_for_tracing(self) + + # Let the unittest framework handle async functions. + if is_async_function(self.obj): + testcase(result=self) + else: + # When --pdb is given, we want to postpone calling tearDown() otherwise + # when entering the pdb prompt, tearDown() would have probably cleaned up + # instance variables, which makes it difficult to debug. + # Arguably we could always postpone tearDown(), but this changes the moment where the + # TestCase instance interacts with the results object, so better to only do it + # when absolutely needed. + # We need to consider if the test itself is skipped, or the whole class. + assert isinstance(self.parent, UnitTestCase) + skipped = _is_skipped(self.obj) or _is_skipped(self.parent.obj) + if self.config.getoption("usepdb") and not skipped: + self._explicit_tearDown = testcase.tearDown + setattr(testcase, "tearDown", lambda *args: None) + + # We need to update the actual bound method with self.obj, because + # wrap_pytest_function_for_tracing replaces self.obj by a wrapper. + setattr(testcase, self.name, self.obj) + try: + testcase(result=self) + finally: + delattr(testcase, self.name) + + def _traceback_filter( + self, excinfo: _pytest._code.ExceptionInfo[BaseException] + ) -> _pytest._code.Traceback: + traceback = super()._traceback_filter(excinfo) + ntraceback = traceback.filter( + lambda x: not x.frame.f_globals.get("__unittest"), + ) + if not ntraceback: + ntraceback = traceback + return ntraceback + + +@hookimpl(tryfirst=True) +def pytest_runtest_makereport(item: Item, call: CallInfo[None]) -> None: + if isinstance(item, TestCaseFunction): + if item._excinfo: + call.excinfo = item._excinfo.pop(0) + try: + del call.result + except AttributeError: + pass + + # Convert unittest.SkipTest to pytest.skip. + # This is actually only needed for nose, which reuses unittest.SkipTest for + # its own nose.SkipTest. For unittest TestCases, SkipTest is already + # handled internally, and doesn't reach here. + unittest = sys.modules.get("unittest") + if unittest and call.excinfo and isinstance(call.excinfo.value, unittest.SkipTest): + excinfo = call.excinfo + call2 = CallInfo[None].from_call( + lambda: pytest.skip(str(excinfo.value)), call.when + ) + call.excinfo = call2.excinfo + + +# Twisted trial support. +classImplements_has_run = False + + +@hookimpl(wrapper=True) +def pytest_runtest_protocol(item: Item) -> Generator[None, object, object]: + if isinstance(item, TestCaseFunction) and "twisted.trial.unittest" in sys.modules: + ut: Any = sys.modules["twisted.python.failure"] + global classImplements_has_run + Failure__init__ = ut.Failure.__init__ + if not classImplements_has_run: + from twisted.trial.itrial import IReporter + from zope.interface import classImplements + + classImplements(TestCaseFunction, IReporter) + classImplements_has_run = True + + def excstore( + self, exc_value=None, exc_type=None, exc_tb=None, captureVars=None + ): + if exc_value is None: + self._rawexcinfo = sys.exc_info() + else: + if exc_type is None: + exc_type = type(exc_value) + self._rawexcinfo = (exc_type, exc_value, exc_tb) + try: + Failure__init__( + self, exc_value, exc_type, exc_tb, captureVars=captureVars + ) + except TypeError: + Failure__init__(self, exc_value, exc_type, exc_tb) + + ut.Failure.__init__ = excstore + try: + res = yield + finally: + ut.Failure.__init__ = Failure__init__ + else: + res = yield + return res + + +def _is_skipped(obj) -> bool: + """Return True if the given object has been marked with @unittest.skip.""" + return bool(getattr(obj, "__unittest_skip__", False)) diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/unraisableexception.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/unraisableexception.py new file mode 100644 index 0000000..77a2de2 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/unraisableexception.py @@ -0,0 +1,100 @@ +from __future__ import annotations + +import sys +import traceback +from types import TracebackType +from typing import Any +from typing import Callable +from typing import Generator +from typing import TYPE_CHECKING +import warnings + +import pytest + + +if TYPE_CHECKING: + from typing_extensions import Self + + +# Copied from cpython/Lib/test/support/__init__.py, with modifications. +class catch_unraisable_exception: + """Context manager catching unraisable exception using sys.unraisablehook. + + Storing the exception value (cm.unraisable.exc_value) creates a reference + cycle. The reference cycle is broken explicitly when the context manager + exits. + + Storing the object (cm.unraisable.object) can resurrect it if it is set to + an object which is being finalized. Exiting the context manager clears the + stored object. + + Usage: + with catch_unraisable_exception() as cm: + # code creating an "unraisable exception" + ... + # check the unraisable exception: use cm.unraisable + ... + # cm.unraisable attribute no longer exists at this point + # (to break a reference cycle) + """ + + def __init__(self) -> None: + self.unraisable: sys.UnraisableHookArgs | None = None + self._old_hook: Callable[[sys.UnraisableHookArgs], Any] | None = None + + def _hook(self, unraisable: sys.UnraisableHookArgs) -> None: + # Storing unraisable.object can resurrect an object which is being + # finalized. Storing unraisable.exc_value creates a reference cycle. + self.unraisable = unraisable + + def __enter__(self) -> Self: + self._old_hook = sys.unraisablehook + sys.unraisablehook = self._hook + return self + + def __exit__( + self, + exc_type: type[BaseException] | None, + exc_val: BaseException | None, + exc_tb: TracebackType | None, + ) -> None: + assert self._old_hook is not None + sys.unraisablehook = self._old_hook + self._old_hook = None + del self.unraisable + + +def unraisable_exception_runtest_hook() -> Generator[None]: + with catch_unraisable_exception() as cm: + try: + yield + finally: + if cm.unraisable: + if cm.unraisable.err_msg is not None: + err_msg = cm.unraisable.err_msg + else: + err_msg = "Exception ignored in" + msg = f"{err_msg}: {cm.unraisable.object!r}\n\n" + msg += "".join( + traceback.format_exception( + cm.unraisable.exc_type, + cm.unraisable.exc_value, + cm.unraisable.exc_traceback, + ) + ) + warnings.warn(pytest.PytestUnraisableExceptionWarning(msg)) + + +@pytest.hookimpl(wrapper=True, tryfirst=True) +def pytest_runtest_setup() -> Generator[None]: + yield from unraisable_exception_runtest_hook() + + +@pytest.hookimpl(wrapper=True, tryfirst=True) +def pytest_runtest_call() -> Generator[None]: + yield from unraisable_exception_runtest_hook() + + +@pytest.hookimpl(wrapper=True, tryfirst=True) +def pytest_runtest_teardown() -> Generator[None]: + yield from unraisable_exception_runtest_hook() diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/warning_types.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/warning_types.py new file mode 100644 index 0000000..4ab14e4 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/warning_types.py @@ -0,0 +1,166 @@ +from __future__ import annotations + +import dataclasses +import inspect +from types import FunctionType +from typing import Any +from typing import final +from typing import Generic +from typing import TypeVar +import warnings + + +class PytestWarning(UserWarning): + """Base class for all warnings emitted by pytest.""" + + __module__ = "pytest" + + +@final +class PytestAssertRewriteWarning(PytestWarning): + """Warning emitted by the pytest assert rewrite module.""" + + __module__ = "pytest" + + +@final +class PytestCacheWarning(PytestWarning): + """Warning emitted by the cache plugin in various situations.""" + + __module__ = "pytest" + + +@final +class PytestConfigWarning(PytestWarning): + """Warning emitted for configuration issues.""" + + __module__ = "pytest" + + +@final +class PytestCollectionWarning(PytestWarning): + """Warning emitted when pytest is not able to collect a file or symbol in a module.""" + + __module__ = "pytest" + + +class PytestDeprecationWarning(PytestWarning, DeprecationWarning): + """Warning class for features that will be removed in a future version.""" + + __module__ = "pytest" + + +class PytestRemovedIn9Warning(PytestDeprecationWarning): + """Warning class for features that will be removed in pytest 9.""" + + __module__ = "pytest" + + +class PytestReturnNotNoneWarning(PytestWarning): + """Warning emitted when a test function is returning value other than None.""" + + __module__ = "pytest" + + +@final +class PytestExperimentalApiWarning(PytestWarning, FutureWarning): + """Warning category used to denote experiments in pytest. + + Use sparingly as the API might change or even be removed completely in a + future version. + """ + + __module__ = "pytest" + + @classmethod + def simple(cls, apiname: str) -> PytestExperimentalApiWarning: + return cls(f"{apiname} is an experimental api that may change over time") + + +@final +class PytestUnhandledCoroutineWarning(PytestReturnNotNoneWarning): + """Warning emitted for an unhandled coroutine. + + A coroutine was encountered when collecting test functions, but was not + handled by any async-aware plugin. + Coroutine test functions are not natively supported. + """ + + __module__ = "pytest" + + +@final +class PytestUnknownMarkWarning(PytestWarning): + """Warning emitted on use of unknown markers. + + See :ref:`mark` for details. + """ + + __module__ = "pytest" + + +@final +class PytestUnraisableExceptionWarning(PytestWarning): + """An unraisable exception was reported. + + Unraisable exceptions are exceptions raised in :meth:`__del__ ` + implementations and similar situations when the exception cannot be raised + as normal. + """ + + __module__ = "pytest" + + +@final +class PytestUnhandledThreadExceptionWarning(PytestWarning): + """An unhandled exception occurred in a :class:`~threading.Thread`. + + Such exceptions don't propagate normally. + """ + + __module__ = "pytest" + + +_W = TypeVar("_W", bound=PytestWarning) + + +@final +@dataclasses.dataclass +class UnformattedWarning(Generic[_W]): + """A warning meant to be formatted during runtime. + + This is used to hold warnings that need to format their message at runtime, + as opposed to a direct message. + """ + + category: type[_W] + template: str + + def format(self, **kwargs: Any) -> _W: + """Return an instance of the warning category, formatted with given kwargs.""" + return self.category(self.template.format(**kwargs)) + + +def warn_explicit_for(method: FunctionType, message: PytestWarning) -> None: + """ + Issue the warning :param:`message` for the definition of the given :param:`method` + + this helps to log warnings for functions defined prior to finding an issue with them + (like hook wrappers being marked in a legacy mechanism) + """ + lineno = method.__code__.co_firstlineno + filename = inspect.getfile(method) + module = method.__module__ + mod_globals = method.__globals__ + try: + warnings.warn_explicit( + message, + type(message), + filename=filename, + module=module, + registry=mod_globals.setdefault("__warningregistry__", {}), + lineno=lineno, + ) + except Warning as w: + # If warnings are errors (e.g. -Werror), location information gets lost, so we add it to the message. + raise type(w)(f"{w}\n at {filename}:{lineno}") from None diff --git a/PyGC/.venv/lib/python3.11/site-packages/_pytest/warnings.py b/PyGC/.venv/lib/python3.11/site-packages/_pytest/warnings.py new file mode 100644 index 0000000..eeb4772 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/_pytest/warnings.py @@ -0,0 +1,151 @@ +# mypy: allow-untyped-defs +from __future__ import annotations + +from contextlib import contextmanager +import sys +from typing import Generator +from typing import Literal +import warnings + +from _pytest.config import apply_warning_filters +from _pytest.config import Config +from _pytest.config import parse_warning_filter +from _pytest.main import Session +from _pytest.nodes import Item +from _pytest.terminal import TerminalReporter +import pytest + + +def pytest_configure(config: Config) -> None: + config.addinivalue_line( + "markers", + "filterwarnings(warning): add a warning filter to the given test. " + "see https://docs.pytest.org/en/stable/how-to/capture-warnings.html#pytest-mark-filterwarnings ", + ) + + +@contextmanager +def catch_warnings_for_item( + config: Config, + ihook, + when: Literal["config", "collect", "runtest"], + item: Item | None, +) -> Generator[None]: + """Context manager that catches warnings generated in the contained execution block. + + ``item`` can be None if we are not in the context of an item execution. + + Each warning captured triggers the ``pytest_warning_recorded`` hook. + """ + config_filters = config.getini("filterwarnings") + cmdline_filters = config.known_args_namespace.pythonwarnings or [] + with warnings.catch_warnings(record=True) as log: + # mypy can't infer that record=True means log is not None; help it. + assert log is not None + + if not sys.warnoptions: + # If user is not explicitly configuring warning filters, show deprecation warnings by default (#2908). + warnings.filterwarnings("always", category=DeprecationWarning) + warnings.filterwarnings("always", category=PendingDeprecationWarning) + + # To be enabled in pytest 9.0.0. + # warnings.filterwarnings("error", category=pytest.PytestRemovedIn9Warning) + + apply_warning_filters(config_filters, cmdline_filters) + + # apply filters from "filterwarnings" marks + nodeid = "" if item is None else item.nodeid + if item is not None: + for mark in item.iter_markers(name="filterwarnings"): + for arg in mark.args: + warnings.filterwarnings(*parse_warning_filter(arg, escape=False)) + + try: + yield + finally: + for warning_message in log: + ihook.pytest_warning_recorded.call_historic( + kwargs=dict( + warning_message=warning_message, + nodeid=nodeid, + when=when, + location=None, + ) + ) + + +def warning_record_to_str(warning_message: warnings.WarningMessage) -> str: + """Convert a warnings.WarningMessage to a string.""" + warn_msg = warning_message.message + msg = warnings.formatwarning( + str(warn_msg), + warning_message.category, + warning_message.filename, + warning_message.lineno, + warning_message.line, + ) + if warning_message.source is not None: + try: + import tracemalloc + except ImportError: + pass + else: + tb = tracemalloc.get_object_traceback(warning_message.source) + if tb is not None: + formatted_tb = "\n".join(tb.format()) + # Use a leading new line to better separate the (large) output + # from the traceback to the previous warning text. + msg += f"\nObject allocated at:\n{formatted_tb}" + else: + # No need for a leading new line. + url = "https://docs.pytest.org/en/stable/how-to/capture-warnings.html#resource-warnings" + msg += "Enable tracemalloc to get traceback where the object was allocated.\n" + msg += f"See {url} for more info." + return msg + + +@pytest.hookimpl(wrapper=True, tryfirst=True) +def pytest_runtest_protocol(item: Item) -> Generator[None, object, object]: + with catch_warnings_for_item( + config=item.config, ihook=item.ihook, when="runtest", item=item + ): + return (yield) + + +@pytest.hookimpl(wrapper=True, tryfirst=True) +def pytest_collection(session: Session) -> Generator[None, object, object]: + config = session.config + with catch_warnings_for_item( + config=config, ihook=config.hook, when="collect", item=None + ): + return (yield) + + +@pytest.hookimpl(wrapper=True) +def pytest_terminal_summary( + terminalreporter: TerminalReporter, +) -> Generator[None]: + config = terminalreporter.config + with catch_warnings_for_item( + config=config, ihook=config.hook, when="config", item=None + ): + return (yield) + + +@pytest.hookimpl(wrapper=True) +def pytest_sessionfinish(session: Session) -> Generator[None]: + config = session.config + with catch_warnings_for_item( + config=config, ihook=config.hook, when="config", item=None + ): + return (yield) + + +@pytest.hookimpl(wrapper=True) +def pytest_load_initial_conftests( + early_config: Config, +) -> Generator[None]: + with catch_warnings_for_item( + config=early_config, ihook=early_config.hook, when="config", item=None + ): + return (yield) diff --git a/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/INSTALLER b/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/LICENSE b/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/LICENSE new file mode 100644 index 0000000..62b076c --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/LICENSE @@ -0,0 +1,20 @@ +This package contains a modified version of ca-bundle.crt: + +ca-bundle.crt -- Bundle of CA Root Certificates + +This is a bundle of X.509 certificates of public Certificate Authorities +(CA). These were automatically extracted from Mozilla's root certificates +file (certdata.txt). This file can be found in the mozilla source tree: +https://hg.mozilla.org/mozilla-central/file/tip/security/nss/lib/ckfw/builtins/certdata.txt +It contains the certificates in PEM format and therefore +can be directly used with curl / libcurl / php_curl, or with +an Apache+mod_ssl webserver for SSL client authentication. +Just configure this file as the SSLCACertificateFile.# + +***** BEGIN LICENSE BLOCK ***** +This Source Code Form is subject to the terms of the Mozilla Public License, +v. 2.0. If a copy of the MPL was not distributed with this file, You can obtain +one at http://mozilla.org/MPL/2.0/. + +***** END LICENSE BLOCK ***** +@(#) $RCSfile: certdata.txt,v $ $Revision: 1.80 $ $Date: 2011/11/03 15:11:58 $ diff --git a/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/METADATA b/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/METADATA new file mode 100644 index 0000000..0a3a772 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/METADATA @@ -0,0 +1,67 @@ +Metadata-Version: 2.1 +Name: certifi +Version: 2024.8.30 +Summary: Python package for providing Mozilla's CA Bundle. +Home-page: https://github.com/certifi/python-certifi +Author: Kenneth Reitz +Author-email: me@kennethreitz.com +License: MPL-2.0 +Project-URL: Source, https://github.com/certifi/python-certifi +Classifier: Development Status :: 5 - Production/Stable +Classifier: Intended Audience :: Developers +Classifier: License :: OSI Approved :: Mozilla Public License 2.0 (MPL 2.0) +Classifier: Natural Language :: English +Classifier: Programming Language :: Python +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3 :: Only +Classifier: Programming Language :: Python :: 3.6 +Classifier: Programming Language :: Python :: 3.7 +Classifier: Programming Language :: Python :: 3.8 +Classifier: Programming Language :: Python :: 3.9 +Classifier: Programming Language :: Python :: 3.10 +Classifier: Programming Language :: Python :: 3.11 +Classifier: Programming Language :: Python :: 3.12 +Requires-Python: >=3.6 +License-File: LICENSE + +Certifi: Python SSL Certificates +================================ + +Certifi provides Mozilla's carefully curated collection of Root Certificates for +validating the trustworthiness of SSL certificates while verifying the identity +of TLS hosts. It has been extracted from the `Requests`_ project. + +Installation +------------ + +``certifi`` is available on PyPI. Simply install it with ``pip``:: + + $ pip install certifi + +Usage +----- + +To reference the installed certificate authority (CA) bundle, you can use the +built-in function:: + + >>> import certifi + + >>> certifi.where() + '/usr/local/lib/python3.7/site-packages/certifi/cacert.pem' + +Or from the command line:: + + $ python -m certifi + /usr/local/lib/python3.7/site-packages/certifi/cacert.pem + +Enjoy! + +.. _`Requests`: https://requests.readthedocs.io/en/master/ + +Addition/Removal of Certificates +-------------------------------- + +Certifi does not support any addition/removal or other modification of the +CA trust store content. This project is intended to provide a reliable and +highly portable root of trust to python deployments. Look to upstream projects +for methods to use alternate trust. diff --git a/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/RECORD b/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/RECORD new file mode 100644 index 0000000..3647e82 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/RECORD @@ -0,0 +1,14 @@ +certifi-2024.8.30.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +certifi-2024.8.30.dist-info/LICENSE,sha256=6TcW2mucDVpKHfYP5pWzcPBpVgPSH2-D8FPkLPwQyvc,989 +certifi-2024.8.30.dist-info/METADATA,sha256=GhBHRVUN6a4ZdUgE_N5wmukJfyuoE-QyIl8Y3ifNQBM,2222 +certifi-2024.8.30.dist-info/RECORD,, +certifi-2024.8.30.dist-info/WHEEL,sha256=UvcQYKBHoFqaQd6LKyqHw9fxEolWLQnlzP0h_LgJAfI,91 +certifi-2024.8.30.dist-info/top_level.txt,sha256=KMu4vUCfsjLrkPbSNdgdekS-pVJzBAJFO__nI8NF6-U,8 +certifi/__init__.py,sha256=p_GYZrjUwPBUhpLlCZoGb0miKBKSqDAyZC5DvIuqbHQ,94 +certifi/__main__.py,sha256=xBBoj905TUWBLRGANOcf7oi6e-3dMP4cEoG9OyMs11g,243 +certifi/__pycache__/__init__.cpython-311.pyc,, +certifi/__pycache__/__main__.cpython-311.pyc,, +certifi/__pycache__/core.cpython-311.pyc,, +certifi/cacert.pem,sha256=lO3rZukXdPyuk6BWUJFOKQliWaXH6HGh9l1GGrUgG0c,299427 +certifi/core.py,sha256=qRDDFyXVJwTB_EmoGppaXU_R9qCZvhl-EzxPMuV3nTA,4426 +certifi/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 diff --git a/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/WHEEL b/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/WHEEL new file mode 100644 index 0000000..57e56b7 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/WHEEL @@ -0,0 +1,5 @@ +Wheel-Version: 1.0 +Generator: setuptools (74.0.0) +Root-Is-Purelib: true +Tag: py3-none-any + diff --git a/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/top_level.txt b/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/top_level.txt new file mode 100644 index 0000000..963eac5 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/certifi-2024.8.30.dist-info/top_level.txt @@ -0,0 +1 @@ +certifi diff --git a/PyGC/.venv/lib/python3.11/site-packages/certifi/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/certifi/__init__.py new file mode 100644 index 0000000..f61d77f --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/certifi/__init__.py @@ -0,0 +1,4 @@ +from .core import contents, where + +__all__ = ["contents", "where"] +__version__ = "2024.08.30" diff --git a/PyGC/.venv/lib/python3.11/site-packages/certifi/__main__.py b/PyGC/.venv/lib/python3.11/site-packages/certifi/__main__.py new file mode 100644 index 0000000..8945b5d --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/certifi/__main__.py @@ -0,0 +1,12 @@ +import argparse + +from certifi import contents, where + +parser = argparse.ArgumentParser() +parser.add_argument("-c", "--contents", action="store_true") +args = parser.parse_args() + +if args.contents: + print(contents()) +else: + print(where()) diff --git a/PyGC/.venv/lib/python3.11/site-packages/certifi/cacert.pem b/PyGC/.venv/lib/python3.11/site-packages/certifi/cacert.pem new file mode 100644 index 0000000..3c165a1 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/certifi/cacert.pem @@ -0,0 +1,4929 @@ + +# 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=Entrust.net Certification Authority (2048) O=Entrust.net OU=www.entrust.net/CPS_2048 incorp. by ref. (limits liab.)/(c) 1999 Entrust.net Limited +# Subject: CN=Entrust.net Certification Authority (2048) O=Entrust.net OU=www.entrust.net/CPS_2048 incorp. by ref. (limits liab.)/(c) 1999 Entrust.net Limited +# Label: "Entrust.net Premium 2048 Secure Server CA" +# Serial: 946069240 +# MD5 Fingerprint: ee:29:31:bc:32:7e:9a:e6:e8:b5:f7:51:b4:34:71:90 +# SHA1 Fingerprint: 50:30:06:09:1d:97:d4:f5:ae:39:f7:cb:e7:92:7d:7d:65:2d:34:31 +# SHA256 Fingerprint: 6d:c4:71:72:e0:1c:bc:b0:bf:62:58:0d:89:5f:e2:b8:ac:9a:d4:f8:73:80:1e:0c:10:b9:c8:37:d2:1e:b1:77 +-----BEGIN CERTIFICATE----- +MIIEKjCCAxKgAwIBAgIEOGPe+DANBgkqhkiG9w0BAQUFADCBtDEUMBIGA1UEChML +RW50cnVzdC5uZXQxQDA+BgNVBAsUN3d3dy5lbnRydXN0Lm5ldC9DUFNfMjA0OCBp +bmNvcnAuIGJ5IHJlZi4gKGxpbWl0cyBsaWFiLikxJTAjBgNVBAsTHChjKSAxOTk5 +IEVudHJ1c3QubmV0IExpbWl0ZWQxMzAxBgNVBAMTKkVudHJ1c3QubmV0IENlcnRp +ZmljYXRpb24gQXV0aG9yaXR5ICgyMDQ4KTAeFw05OTEyMjQxNzUwNTFaFw0yOTA3 +MjQxNDE1MTJaMIG0MRQwEgYDVQQKEwtFbnRydXN0Lm5ldDFAMD4GA1UECxQ3d3d3 +LmVudHJ1c3QubmV0L0NQU18yMDQ4IGluY29ycC4gYnkgcmVmLiAobGltaXRzIGxp +YWIuKTElMCMGA1UECxMcKGMpIDE5OTkgRW50cnVzdC5uZXQgTGltaXRlZDEzMDEG +A1UEAxMqRW50cnVzdC5uZXQgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgKDIwNDgp +MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEArU1LqRKGsuqjIAcVFmQq +K0vRvwtKTY7tgHalZ7d4QMBzQshowNtTK91euHaYNZOLGp18EzoOH1u3Hs/lJBQe +sYGpjX24zGtLA/ECDNyrpUAkAH90lKGdCCmziAv1h3edVc3kw37XamSrhRSGlVuX +MlBvPci6Zgzj/L24ScF2iUkZ/cCovYmjZy/Gn7xxGWC4LeksyZB2ZnuU4q941mVT +XTzWnLLPKQP5L6RQstRIzgUyVYr9smRMDuSYB3Xbf9+5CFVghTAp+XtIpGmG4zU/ +HoZdenoVve8AjhUiVBcAkCaTvA5JaJG/+EfTnZVCwQ5N328mz8MYIWJmQ3DW1cAH +4QIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNV +HQ4EFgQUVeSB0RGAvtiJuQijMfmhJAkWuXAwDQYJKoZIhvcNAQEFBQADggEBADub +j1abMOdTmXx6eadNl9cZlZD7Bh/KM3xGY4+WZiT6QBshJ8rmcnPyT/4xmf3IDExo +U8aAghOY+rat2l098c5u9hURlIIM7j+VrxGrD9cv3h8Dj1csHsm7mhpElesYT6Yf +zX1XEC+bBAlahLVu2B064dae0Wx5XnkcFMXj0EyTO2U87d89vqbllRrDtRnDvV5b +u/8j72gZyxKTJ1wDLW8w0B62GqzeWvfRqqgnpv55gcR5mTNXuhKwqeBCbJPKVt7+ +bYQLCIt+jerXmCHG8+c8eS9enNFMFY3h7CI3zJpDC5fcgJCNs2ebb0gIFVbPv/Er +fF6adulZkMV8gzURZVE= +-----END CERTIFICATE----- + +# Issuer: CN=Baltimore CyberTrust Root O=Baltimore OU=CyberTrust +# Subject: CN=Baltimore CyberTrust Root O=Baltimore OU=CyberTrust +# Label: "Baltimore CyberTrust Root" +# Serial: 33554617 +# MD5 Fingerprint: ac:b6:94:a5:9c:17:e0:d7:91:52:9b:b1:97:06:a6:e4 +# SHA1 Fingerprint: d4:de:20:d0:5e:66:fc:53:fe:1a:50:88:2c:78:db:28:52:ca:e4:74 +# SHA256 Fingerprint: 16:af:57:a9:f6:76:b0:ab:12:60:95:aa:5e:ba:de:f2:2a:b3:11:19:d6:44:ac:95:cd:4b:93:db:f3:f2:6a:eb +-----BEGIN CERTIFICATE----- +MIIDdzCCAl+gAwIBAgIEAgAAuTANBgkqhkiG9w0BAQUFADBaMQswCQYDVQQGEwJJ +RTESMBAGA1UEChMJQmFsdGltb3JlMRMwEQYDVQQLEwpDeWJlclRydXN0MSIwIAYD +VQQDExlCYWx0aW1vcmUgQ3liZXJUcnVzdCBSb290MB4XDTAwMDUxMjE4NDYwMFoX +DTI1MDUxMjIzNTkwMFowWjELMAkGA1UEBhMCSUUxEjAQBgNVBAoTCUJhbHRpbW9y +ZTETMBEGA1UECxMKQ3liZXJUcnVzdDEiMCAGA1UEAxMZQmFsdGltb3JlIEN5YmVy +VHJ1c3QgUm9vdDCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKMEuyKr +mD1X6CZymrV51Cni4eiVgLGw41uOKymaZN+hXe2wCQVt2yguzmKiYv60iNoS6zjr +IZ3AQSsBUnuId9Mcj8e6uYi1agnnc+gRQKfRzMpijS3ljwumUNKoUMMo6vWrJYeK +mpYcqWe4PwzV9/lSEy/CG9VwcPCPwBLKBsua4dnKM3p31vjsufFoREJIE9LAwqSu +XmD+tqYF/LTdB1kC1FkYmGP1pWPgkAx9XbIGevOF6uvUA65ehD5f/xXtabz5OTZy +dc93Uk3zyZAsuT3lySNTPx8kmCFcB5kpvcY67Oduhjprl3RjM71oGDHweI12v/ye +jl0qhqdNkNwnGjkCAwEAAaNFMEMwHQYDVR0OBBYEFOWdWTCCR1jMrPoIVDaGezq1 +BE3wMBIGA1UdEwEB/wQIMAYBAf8CAQMwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3 +DQEBBQUAA4IBAQCFDF2O5G9RaEIFoN27TyclhAO992T9Ldcw46QQF+vaKSm2eT92 +9hkTI7gQCvlYpNRhcL0EYWoSihfVCr3FvDB81ukMJY2GQE/szKN+OMY3EU/t3Wgx +jkzSswF07r51XgdIGn9w/xZchMB5hbgF/X++ZRGjD8ACtPhSNzkE1akxehi/oCr0 +Epn3o0WC4zxe9Z2etciefC7IpJ5OCBRLbf1wbWsaY71k5h+3zvDyny67G7fyUIhz +ksLi4xaNmjICq44Y3ekQEe5+NauQrz4wlHrQMz2nZQ/1/I6eYs9HRCwBXbsdtTLS +R9I4LtD+gdwyah617jzV/OeBHRnDJELqYzmp +-----END CERTIFICATE----- + +# Issuer: CN=Entrust Root Certification Authority O=Entrust, Inc. OU=www.entrust.net/CPS is incorporated by reference/(c) 2006 Entrust, Inc. +# Subject: CN=Entrust Root Certification Authority O=Entrust, Inc. OU=www.entrust.net/CPS is incorporated by reference/(c) 2006 Entrust, Inc. +# Label: "Entrust Root Certification Authority" +# Serial: 1164660820 +# MD5 Fingerprint: d6:a5:c3:ed:5d:dd:3e:00:c1:3d:87:92:1f:1d:3f:e4 +# SHA1 Fingerprint: b3:1e:b1:b7:40:e3:6c:84:02:da:dc:37:d4:4d:f5:d4:67:49:52:f9 +# SHA256 Fingerprint: 73:c1:76:43:4f:1b:c6:d5:ad:f4:5b:0e:76:e7:27:28:7c:8d:e5:76:16:c1:e6:e6:14:1a:2b:2c:bc:7d:8e:4c +-----BEGIN CERTIFICATE----- +MIIEkTCCA3mgAwIBAgIERWtQVDANBgkqhkiG9w0BAQUFADCBsDELMAkGA1UEBhMC +VVMxFjAUBgNVBAoTDUVudHJ1c3QsIEluYy4xOTA3BgNVBAsTMHd3dy5lbnRydXN0 +Lm5ldC9DUFMgaXMgaW5jb3Jwb3JhdGVkIGJ5IHJlZmVyZW5jZTEfMB0GA1UECxMW +KGMpIDIwMDYgRW50cnVzdCwgSW5jLjEtMCsGA1UEAxMkRW50cnVzdCBSb290IENl +cnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTA2MTEyNzIwMjM0MloXDTI2MTEyNzIw +NTM0MlowgbAxCzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1FbnRydXN0LCBJbmMuMTkw +NwYDVQQLEzB3d3cuZW50cnVzdC5uZXQvQ1BTIGlzIGluY29ycG9yYXRlZCBieSBy +ZWZlcmVuY2UxHzAdBgNVBAsTFihjKSAyMDA2IEVudHJ1c3QsIEluYy4xLTArBgNV +BAMTJEVudHJ1c3QgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTCCASIwDQYJ +KoZIhvcNAQEBBQADggEPADCCAQoCggEBALaVtkNC+sZtKm9I35RMOVcF7sN5EUFo +Nu3s/poBj6E4KPz3EEZmLk0eGrEaTsbRwJWIsMn/MYszA9u3g3s+IIRe7bJWKKf4 +4LlAcTfFy0cOlypowCKVYhXbR9n10Cv/gkvJrT7eTNuQgFA/CYqEAOwwCj0Yzfv9 +KlmaI5UXLEWeH25DeW0MXJj+SKfFI0dcXv1u5x609mhF0YaDW6KKjbHjKYD+JXGI +rb68j6xSlkuqUY3kEzEZ6E5Nn9uss2rVvDlUccp6en+Q3X0dgNmBu1kmwhH+5pPi +94DkZfs0Nw4pgHBNrziGLp5/V6+eF67rHMsoIV+2HNjnogQi+dPa2MsCAwEAAaOB +sDCBrTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zArBgNVHRAEJDAi +gA8yMDA2MTEyNzIwMjM0MlqBDzIwMjYxMTI3MjA1MzQyWjAfBgNVHSMEGDAWgBRo +kORnpKZTgMeGZqTx90tD+4S9bTAdBgNVHQ4EFgQUaJDkZ6SmU4DHhmak8fdLQ/uE +vW0wHQYJKoZIhvZ9B0EABBAwDhsIVjcuMTo0LjADAgSQMA0GCSqGSIb3DQEBBQUA +A4IBAQCT1DCw1wMgKtD5Y+iRDAUgqV8ZyntyTtSx29CW+1RaGSwMCPeyvIWonX9t +O1KzKtvn1ISMY/YPyyYBkVBs9F8U4pN0wBOeMDpQ47RgxRzwIkSNcUesyBrJ6Zua +AGAT/3B+XxFNSRuzFVJ7yVTav52Vr2ua2J7p8eRDjeIRRDq/r72DQnNSi6q7pynP +9WQcCk3RvKqsnyrQ/39/2n3qse0wJcGE2jTSW3iDVuycNsMm4hH2Z0kdkquM++v/ +eu6FSqdQgPCnXEqULl8FmTxSQeDNtGPPAUO6nIPcj2A781q0tHuu2guQOHXvgR1m +0vdXcDazv/wor3ElhVsT/h5/WrQ8 +-----END CERTIFICATE----- + +# Issuer: CN=AAA Certificate Services O=Comodo CA Limited +# Subject: CN=AAA Certificate Services O=Comodo CA Limited +# Label: "Comodo AAA Services root" +# Serial: 1 +# MD5 Fingerprint: 49:79:04:b0:eb:87:19:ac:47:b0:bc:11:51:9b:74:d0 +# SHA1 Fingerprint: d1:eb:23:a4:6d:17:d6:8f:d9:25:64:c2:f1:f1:60:17:64:d8:e3:49 +# SHA256 Fingerprint: d7:a7:a0:fb:5d:7e:27:31:d7:71:e9:48:4e:bc:de:f7:1d:5f:0c:3e:0a:29:48:78:2b:c8:3e:e0:ea:69:9e:f4 +-----BEGIN CERTIFICATE----- +MIIEMjCCAxqgAwIBAgIBATANBgkqhkiG9w0BAQUFADB7MQswCQYDVQQGEwJHQjEb +MBkGA1UECAwSR3JlYXRlciBNYW5jaGVzdGVyMRAwDgYDVQQHDAdTYWxmb3JkMRow +GAYDVQQKDBFDb21vZG8gQ0EgTGltaXRlZDEhMB8GA1UEAwwYQUFBIENlcnRpZmlj +YXRlIFNlcnZpY2VzMB4XDTA0MDEwMTAwMDAwMFoXDTI4MTIzMTIzNTk1OVowezEL +MAkGA1UEBhMCR0IxGzAZBgNVBAgMEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UE +BwwHU2FsZm9yZDEaMBgGA1UECgwRQ29tb2RvIENBIExpbWl0ZWQxITAfBgNVBAMM +GEFBQSBDZXJ0aWZpY2F0ZSBTZXJ2aWNlczCCASIwDQYJKoZIhvcNAQEBBQADggEP +ADCCAQoCggEBAL5AnfRu4ep2hxxNRUSOvkbIgwadwSr+GB+O5AL686tdUIoWMQua +BtDFcCLNSS1UY8y2bmhGC1Pqy0wkwLxyTurxFa70VJoSCsN6sjNg4tqJVfMiWPPe +3M/vg4aijJRPn2jymJBGhCfHdr/jzDUsi14HZGWCwEiwqJH5YZ92IFCokcdmtet4 +YgNW8IoaE+oxox6gmf049vYnMlhvB/VruPsUK6+3qszWY19zjNoFmag4qMsXeDZR +rOme9Hg6jc8P2ULimAyrL58OAd7vn5lJ8S3frHRNG5i1R8XlKdH5kBjHYpy+g8cm +ez6KJcfA3Z3mNWgQIJ2P2N7Sw4ScDV7oL8kCAwEAAaOBwDCBvTAdBgNVHQ4EFgQU +oBEKIz6W8Qfs4q8p74Klf9AwpLQwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQF +MAMBAf8wewYDVR0fBHQwcjA4oDagNIYyaHR0cDovL2NybC5jb21vZG9jYS5jb20v +QUFBQ2VydGlmaWNhdGVTZXJ2aWNlcy5jcmwwNqA0oDKGMGh0dHA6Ly9jcmwuY29t +b2RvLm5ldC9BQUFDZXJ0aWZpY2F0ZVNlcnZpY2VzLmNybDANBgkqhkiG9w0BAQUF +AAOCAQEACFb8AvCb6P+k+tZ7xkSAzk/ExfYAWMymtrwUSWgEdujm7l3sAg9g1o1Q +GE8mTgHj5rCl7r+8dFRBv/38ErjHT1r0iWAFf2C3BUrz9vHCv8S5dIa2LX1rzNLz +Rt0vxuBqw8M0Ayx9lt1awg6nCpnBBYurDC/zXDrPbDdVCYfeU0BsWO/8tqtlbgT2 +G9w84FoVxp7Z8VlIMCFlA2zs6SFz7JsDoeA3raAVGI/6ugLOpyypEBMs1OUIJqsi +l2D4kF501KKaU73yqWjgom7C12yxow+ev+to51byrvLjKzg6CYG1a4XXvi3tPxq3 +smPi9WIsgtRqAEFQ8TmDn5XpNpaYbg== +-----END CERTIFICATE----- + +# Issuer: CN=QuoVadis Root CA 2 O=QuoVadis Limited +# Subject: CN=QuoVadis Root CA 2 O=QuoVadis Limited +# Label: "QuoVadis Root CA 2" +# Serial: 1289 +# MD5 Fingerprint: 5e:39:7b:dd:f8:ba:ec:82:e9:ac:62:ba:0c:54:00:2b +# SHA1 Fingerprint: ca:3a:fb:cf:12:40:36:4b:44:b2:16:20:88:80:48:39:19:93:7c:f7 +# SHA256 Fingerprint: 85:a0:dd:7d:d7:20:ad:b7:ff:05:f8:3d:54:2b:20:9d:c7:ff:45:28:f7:d6:77:b1:83:89:fe:a5:e5:c4:9e:86 +-----BEGIN CERTIFICATE----- +MIIFtzCCA5+gAwIBAgICBQkwDQYJKoZIhvcNAQEFBQAwRTELMAkGA1UEBhMCQk0x +GTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMTElF1b1ZhZGlzIFJv +b3QgQ0EgMjAeFw0wNjExMjQxODI3MDBaFw0zMTExMjQxODIzMzNaMEUxCzAJBgNV +BAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMRswGQYDVQQDExJRdW9W +YWRpcyBSb290IENBIDIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCa +GMpLlA0ALa8DKYrwD4HIrkwZhR0In6spRIXzL4GtMh6QRr+jhiYaHv5+HBg6XJxg +Fyo6dIMzMH1hVBHL7avg5tKifvVrbxi3Cgst/ek+7wrGsxDp3MJGF/hd/aTa/55J +WpzmM+Yklvc/ulsrHHo1wtZn/qtmUIttKGAr79dgw8eTvI02kfN/+NsRE8Scd3bB +rrcCaoF6qUWD4gXmuVbBlDePSHFjIuwXZQeVikvfj8ZaCuWw419eaxGrDPmF60Tp ++ARz8un+XJiM9XOva7R+zdRcAitMOeGylZUtQofX1bOQQ7dsE/He3fbE+Ik/0XX1 +ksOR1YqI0JDs3G3eicJlcZaLDQP9nL9bFqyS2+r+eXyt66/3FsvbzSUr5R/7mp/i +Ucw6UwxI5g69ybR2BlLmEROFcmMDBOAENisgGQLodKcftslWZvB1JdxnwQ5hYIiz +PtGo/KPaHbDRsSNU30R2be1B2MGyIrZTHN81Hdyhdyox5C315eXbyOD/5YDXC2Og +/zOhD7osFRXql7PSorW+8oyWHhqPHWykYTe5hnMz15eWniN9gqRMgeKh0bpnX5UH +oycR7hYQe7xFSkyyBNKr79X9DFHOUGoIMfmR2gyPZFwDwzqLID9ujWc9Otb+fVuI +yV77zGHcizN300QyNQliBJIWENieJ0f7OyHj+OsdWwIDAQABo4GwMIGtMA8GA1Ud +EwEB/wQFMAMBAf8wCwYDVR0PBAQDAgEGMB0GA1UdDgQWBBQahGK8SEwzJQTU7tD2 +A8QZRtGUazBuBgNVHSMEZzBlgBQahGK8SEwzJQTU7tD2A8QZRtGUa6FJpEcwRTEL +MAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMT +ElF1b1ZhZGlzIFJvb3QgQ0EgMoICBQkwDQYJKoZIhvcNAQEFBQADggIBAD4KFk2f +BluornFdLwUvZ+YTRYPENvbzwCYMDbVHZF34tHLJRqUDGCdViXh9duqWNIAXINzn +g/iN/Ae42l9NLmeyhP3ZRPx3UIHmfLTJDQtyU/h2BwdBR5YM++CCJpNVjP4iH2Bl +fF/nJrP3MpCYUNQ3cVX2kiF495V5+vgtJodmVjB3pjd4M1IQWK4/YY7yarHvGH5K +WWPKjaJW1acvvFYfzznB4vsKqBUsfU16Y8Zsl0Q80m/DShcK+JDSV6IZUaUtl0Ha +B0+pUNqQjZRG4T7wlP0QADj1O+hA4bRuVhogzG9Yje0uRY/W6ZM/57Es3zrWIozc +hLsib9D45MY56QSIPMO661V6bYCZJPVsAfv4l7CUW+v90m/xd2gNNWQjrLhVoQPR +TUIZ3Ph1WVaj+ahJefivDrkRoHy3au000LYmYjgahwz46P0u05B/B5EqHdZ+XIWD +mbA4CD/pXvk1B+TJYm5Xf6dQlfe6yJvmjqIBxdZmv3lh8zwc4bmCXF2gw+nYSL0Z +ohEUGW6yhhtoPkg3Goi3XZZenMfvJ2II4pEZXNLxId26F0KCl3GBUzGpn/Z9Yr9y +4aOTHcyKJloJONDO1w2AFrR4pTqHTI2KpdVGl/IsELm8VCLAAVBpQ570su9t+Oza +8eOx79+Rj1QqCyXBJhnEUhAFZdWCEOrCMc0u +-----END CERTIFICATE----- + +# Issuer: CN=QuoVadis Root CA 3 O=QuoVadis Limited +# Subject: CN=QuoVadis Root CA 3 O=QuoVadis Limited +# Label: "QuoVadis Root CA 3" +# Serial: 1478 +# MD5 Fingerprint: 31:85:3c:62:94:97:63:b9:aa:fd:89:4e:af:6f:e0:cf +# SHA1 Fingerprint: 1f:49:14:f7:d8:74:95:1d:dd:ae:02:c0:be:fd:3a:2d:82:75:51:85 +# SHA256 Fingerprint: 18:f1:fc:7f:20:5d:f8:ad:dd:eb:7f:e0:07:dd:57:e3:af:37:5a:9c:4d:8d:73:54:6b:f4:f1:fe:d1:e1:8d:35 +-----BEGIN CERTIFICATE----- +MIIGnTCCBIWgAwIBAgICBcYwDQYJKoZIhvcNAQEFBQAwRTELMAkGA1UEBhMCQk0x +GTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMTElF1b1ZhZGlzIFJv +b3QgQ0EgMzAeFw0wNjExMjQxOTExMjNaFw0zMTExMjQxOTA2NDRaMEUxCzAJBgNV +BAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMRswGQYDVQQDExJRdW9W +YWRpcyBSb290IENBIDMwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDM +V0IWVJzmmNPTTe7+7cefQzlKZbPoFog02w1ZkXTPkrgEQK0CSzGrvI2RaNggDhoB +4hp7Thdd4oq3P5kazethq8Jlph+3t723j/z9cI8LoGe+AaJZz3HmDyl2/7FWeUUr +H556VOijKTVopAFPD6QuN+8bv+OPEKhyq1hX51SGyMnzW9os2l2ObjyjPtr7guXd +8lyyBTNvijbO0BNO/79KDDRMpsMhvVAEVeuxu537RR5kFd5VAYwCdrXLoT9Cabwv +vWhDFlaJKjdhkf2mrk7AyxRllDdLkgbvBNDInIjbC3uBr7E9KsRlOni27tyAsdLT +mZw67mtaa7ONt9XOnMK+pUsvFrGeaDsGb659n/je7Mwpp5ijJUMv7/FfJuGITfhe +btfZFG4ZM2mnO4SJk8RTVROhUXhA+LjJou57ulJCg54U7QVSWllWp5f8nT8KKdjc +T5EOE7zelaTfi5m+rJsziO+1ga8bxiJTyPbH7pcUsMV8eFLI8M5ud2CEpukqdiDt +WAEXMJPpGovgc2PZapKUSU60rUqFxKMiMPwJ7Wgic6aIDFUhWMXhOp8q3crhkODZ +c6tsgLjoC2SToJyMGf+z0gzskSaHirOi4XCPLArlzW1oUevaPwV/izLmE1xr/l9A +4iLItLRkT9a6fUg+qGkM17uGcclzuD87nSVL2v9A6wIDAQABo4IBlTCCAZEwDwYD +VR0TAQH/BAUwAwEB/zCB4QYDVR0gBIHZMIHWMIHTBgkrBgEEAb5YAAMwgcUwgZMG +CCsGAQUFBwICMIGGGoGDQW55IHVzZSBvZiB0aGlzIENlcnRpZmljYXRlIGNvbnN0 +aXR1dGVzIGFjY2VwdGFuY2Ugb2YgdGhlIFF1b1ZhZGlzIFJvb3QgQ0EgMyBDZXJ0 +aWZpY2F0ZSBQb2xpY3kgLyBDZXJ0aWZpY2F0aW9uIFByYWN0aWNlIFN0YXRlbWVu +dC4wLQYIKwYBBQUHAgEWIWh0dHA6Ly93d3cucXVvdmFkaXNnbG9iYWwuY29tL2Nw +czALBgNVHQ8EBAMCAQYwHQYDVR0OBBYEFPLAE+CCQz777i9nMpY1XNu4ywLQMG4G +A1UdIwRnMGWAFPLAE+CCQz777i9nMpY1XNu4ywLQoUmkRzBFMQswCQYDVQQGEwJC +TTEZMBcGA1UEChMQUXVvVmFkaXMgTGltaXRlZDEbMBkGA1UEAxMSUXVvVmFkaXMg +Um9vdCBDQSAzggIFxjANBgkqhkiG9w0BAQUFAAOCAgEAT62gLEz6wPJv92ZVqyM0 +7ucp2sNbtrCD2dDQ4iH782CnO11gUyeim/YIIirnv6By5ZwkajGxkHon24QRiSem +d1o417+shvzuXYO8BsbRd2sPbSQvS3pspweWyuOEn62Iix2rFo1bZhfZFvSLgNLd ++LJ2w/w4E6oM3kJpK27zPOuAJ9v1pkQNn1pVWQvVDVJIxa6f8i+AxeoyUDUSly7B +4f/xI4hROJ/yZlZ25w9Rl6VSDE1JUZU2Pb+iSwwQHYaZTKrzchGT5Or2m9qoXadN +t54CrnMAyNojA+j56hl0YgCUyyIgvpSnWbWCar6ZeXqp8kokUvd0/bpO5qgdAm6x +DYBEwa7TIzdfu4V8K5Iu6H6li92Z4b8nby1dqnuH/grdS/yO9SbkbnBCbjPsMZ57 +k8HkyWkaPcBrTiJt7qtYTcbQQcEr6k8Sh17rRdhs9ZgC06DYVYoGmRmioHfRMJ6s +zHXug/WwYjnPbFfiTNKRCw51KBuav/0aQ/HKd/s7j2G4aSgWQgRecCocIdiP4b0j +Wy10QJLZYxkNc91pvGJHvOB0K7Lrfb5BG7XARsWhIstfTsEokt4YutUqKLsRixeT +mJlglFwjz1onl14LBQaTNx47aTbrqZ5hHY8y2o4M1nQ+ewkk2gF3R8Q7zTSMmfXK +4SVhM7JZG+Ju1zdXtg2pEto= +-----END CERTIFICATE----- + +# Issuer: CN=XRamp Global Certification Authority O=XRamp Security Services Inc OU=www.xrampsecurity.com +# Subject: CN=XRamp Global Certification Authority O=XRamp Security Services Inc OU=www.xrampsecurity.com +# Label: "XRamp Global CA Root" +# Serial: 107108908803651509692980124233745014957 +# MD5 Fingerprint: a1:0b:44:b3:ca:10:d8:00:6e:9d:0f:d8:0f:92:0a:d1 +# SHA1 Fingerprint: b8:01:86:d1:eb:9c:86:a5:41:04:cf:30:54:f3:4c:52:b7:e5:58:c6 +# SHA256 Fingerprint: ce:cd:dc:90:50:99:d8:da:df:c5:b1:d2:09:b7:37:cb:e2:c1:8c:fb:2c:10:c0:ff:0b:cf:0d:32:86:fc:1a:a2 +-----BEGIN CERTIFICATE----- +MIIEMDCCAxigAwIBAgIQUJRs7Bjq1ZxN1ZfvdY+grTANBgkqhkiG9w0BAQUFADCB +gjELMAkGA1UEBhMCVVMxHjAcBgNVBAsTFXd3dy54cmFtcHNlY3VyaXR5LmNvbTEk +MCIGA1UEChMbWFJhbXAgU2VjdXJpdHkgU2VydmljZXMgSW5jMS0wKwYDVQQDEyRY +UmFtcCBHbG9iYWwgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDQxMTAxMTcx +NDA0WhcNMzUwMTAxMDUzNzE5WjCBgjELMAkGA1UEBhMCVVMxHjAcBgNVBAsTFXd3 +dy54cmFtcHNlY3VyaXR5LmNvbTEkMCIGA1UEChMbWFJhbXAgU2VjdXJpdHkgU2Vy +dmljZXMgSW5jMS0wKwYDVQQDEyRYUmFtcCBHbG9iYWwgQ2VydGlmaWNhdGlvbiBB +dXRob3JpdHkwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCYJB69FbS6 +38eMpSe2OAtp87ZOqCwuIR1cRN8hXX4jdP5efrRKt6atH67gBhbim1vZZ3RrXYCP +KZ2GG9mcDZhtdhAoWORlsH9KmHmf4MMxfoArtYzAQDsRhtDLooY2YKTVMIJt2W7Q +DxIEM5dfT2Fa8OT5kavnHTu86M/0ay00fOJIYRyO82FEzG+gSqmUsE3a56k0enI4 +qEHMPJQRfevIpoy3hsvKMzvZPTeL+3o+hiznc9cKV6xkmxnr9A8ECIqsAxcZZPRa +JSKNNCyy9mgdEm3Tih4U2sSPpuIjhdV6Db1q4Ons7Be7QhtnqiXtRYMh/MHJfNVi +PvryxS3T/dRlAgMBAAGjgZ8wgZwwEwYJKwYBBAGCNxQCBAYeBABDAEEwCwYDVR0P +BAQDAgGGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFMZPoj0GY4QJnM5i5ASs +jVy16bYbMDYGA1UdHwQvMC0wK6ApoCeGJWh0dHA6Ly9jcmwueHJhbXBzZWN1cml0 +eS5jb20vWEdDQS5jcmwwEAYJKwYBBAGCNxUBBAMCAQEwDQYJKoZIhvcNAQEFBQAD +ggEBAJEVOQMBG2f7Shz5CmBbodpNl2L5JFMn14JkTpAuw0kbK5rc/Kh4ZzXxHfAR +vbdI4xD2Dd8/0sm2qlWkSLoC295ZLhVbO50WfUfXN+pfTXYSNrsf16GBBEYgoyxt +qZ4Bfj8pzgCT3/3JknOJiWSe5yvkHJEs0rnOfc5vMZnT5r7SHpDwCRR5XCOrTdLa +IR9NmXmd4c8nnxCbHIgNsIpkQTG4DmyQJKSbXHGPurt+HBvbaoAPIbzp26a3QPSy +i6mx5O+aGtA9aZnuqCij4Tyz8LIRnM98QObd50N9otg6tamN8jSZxNQQ4Qb9CYQQ +O+7ETPTsJ3xCwnR8gooJybQDJbw= +-----END CERTIFICATE----- + +# Issuer: O=The Go Daddy Group, Inc. OU=Go Daddy Class 2 Certification Authority +# Subject: O=The Go Daddy Group, Inc. OU=Go Daddy Class 2 Certification Authority +# Label: "Go Daddy Class 2 CA" +# Serial: 0 +# MD5 Fingerprint: 91:de:06:25:ab:da:fd:32:17:0c:bb:25:17:2a:84:67 +# SHA1 Fingerprint: 27:96:ba:e6:3f:18:01:e2:77:26:1b:a0:d7:77:70:02:8f:20:ee:e4 +# SHA256 Fingerprint: c3:84:6b:f2:4b:9e:93:ca:64:27:4c:0e:c6:7c:1e:cc:5e:02:4f:fc:ac:d2:d7:40:19:35:0e:81:fe:54:6a:e4 +-----BEGIN CERTIFICATE----- +MIIEADCCAuigAwIBAgIBADANBgkqhkiG9w0BAQUFADBjMQswCQYDVQQGEwJVUzEh +MB8GA1UEChMYVGhlIEdvIERhZGR5IEdyb3VwLCBJbmMuMTEwLwYDVQQLEyhHbyBE +YWRkeSBDbGFzcyAyIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTA0MDYyOTE3 +MDYyMFoXDTM0MDYyOTE3MDYyMFowYzELMAkGA1UEBhMCVVMxITAfBgNVBAoTGFRo +ZSBHbyBEYWRkeSBHcm91cCwgSW5jLjExMC8GA1UECxMoR28gRGFkZHkgQ2xhc3Mg +MiBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTCCASAwDQYJKoZIhvcNAQEBBQADggEN +ADCCAQgCggEBAN6d1+pXGEmhW+vXX0iG6r7d/+TvZxz0ZWizV3GgXne77ZtJ6XCA +PVYYYwhv2vLM0D9/AlQiVBDYsoHUwHU9S3/Hd8M+eKsaA7Ugay9qK7HFiH7Eux6w +wdhFJ2+qN1j3hybX2C32qRe3H3I2TqYXP2WYktsqbl2i/ojgC95/5Y0V4evLOtXi +EqITLdiOr18SPaAIBQi2XKVlOARFmR6jYGB0xUGlcmIbYsUfb18aQr4CUWWoriMY +avx4A6lNf4DD+qta/KFApMoZFv6yyO9ecw3ud72a9nmYvLEHZ6IVDd2gWMZEewo+ +YihfukEHU1jPEX44dMX4/7VpkI+EdOqXG68CAQOjgcAwgb0wHQYDVR0OBBYEFNLE +sNKR1EwRcbNhyz2h/t2oatTjMIGNBgNVHSMEgYUwgYKAFNLEsNKR1EwRcbNhyz2h +/t2oatTjoWekZTBjMQswCQYDVQQGEwJVUzEhMB8GA1UEChMYVGhlIEdvIERhZGR5 +IEdyb3VwLCBJbmMuMTEwLwYDVQQLEyhHbyBEYWRkeSBDbGFzcyAyIENlcnRpZmlj +YXRpb24gQXV0aG9yaXR5ggEAMAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEFBQAD +ggEBADJL87LKPpH8EsahB4yOd6AzBhRckB4Y9wimPQoZ+YeAEW5p5JYXMP80kWNy +OO7MHAGjHZQopDH2esRU1/blMVgDoszOYtuURXO1v0XJJLXVggKtI3lpjbi2Tc7P +TMozI+gciKqdi0FuFskg5YmezTvacPd+mSYgFFQlq25zheabIZ0KbIIOqPjCDPoQ +HmyW74cNxA9hi63ugyuV+I6ShHI56yDqg+2DzZduCLzrTia2cyvk0/ZM/iZx4mER +dEr/VxqHD3VILs9RaRegAhJhldXRQLIQTO7ErBBDpqWeCtWVYpoNz4iCxTIM5Cuf +ReYNnyicsbkqWletNw+vHX/bvZ8= +-----END CERTIFICATE----- + +# Issuer: O=Starfield Technologies, Inc. OU=Starfield Class 2 Certification Authority +# Subject: O=Starfield Technologies, Inc. OU=Starfield Class 2 Certification Authority +# Label: "Starfield Class 2 CA" +# Serial: 0 +# MD5 Fingerprint: 32:4a:4b:bb:c8:63:69:9b:be:74:9a:c6:dd:1d:46:24 +# SHA1 Fingerprint: ad:7e:1c:28:b0:64:ef:8f:60:03:40:20:14:c3:d0:e3:37:0e:b5:8a +# SHA256 Fingerprint: 14:65:fa:20:53:97:b8:76:fa:a6:f0:a9:95:8e:55:90:e4:0f:cc:7f:aa:4f:b7:c2:c8:67:75:21:fb:5f:b6:58 +-----BEGIN CERTIFICATE----- +MIIEDzCCAvegAwIBAgIBADANBgkqhkiG9w0BAQUFADBoMQswCQYDVQQGEwJVUzEl +MCMGA1UEChMcU3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjEyMDAGA1UECxMp +U3RhcmZpZWxkIENsYXNzIDIgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDQw +NjI5MTczOTE2WhcNMzQwNjI5MTczOTE2WjBoMQswCQYDVQQGEwJVUzElMCMGA1UE +ChMcU3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjEyMDAGA1UECxMpU3RhcmZp +ZWxkIENsYXNzIDIgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwggEgMA0GCSqGSIb3 +DQEBAQUAA4IBDQAwggEIAoIBAQC3Msj+6XGmBIWtDBFk385N78gDGIc/oav7PKaf +8MOh2tTYbitTkPskpD6E8J7oX+zlJ0T1KKY/e97gKvDIr1MvnsoFAZMej2YcOadN ++lq2cwQlZut3f+dZxkqZJRRU6ybH838Z1TBwj6+wRir/resp7defqgSHo9T5iaU0 +X9tDkYI22WY8sbi5gv2cOj4QyDvvBmVmepsZGD3/cVE8MC5fvj13c7JdBmzDI1aa +K4UmkhynArPkPw2vCHmCuDY96pzTNbO8acr1zJ3o/WSNF4Azbl5KXZnJHoe0nRrA +1W4TNSNe35tfPe/W93bC6j67eA0cQmdrBNj41tpvi/JEoAGrAgEDo4HFMIHCMB0G +A1UdDgQWBBS/X7fRzt0fhvRbVazc1xDCDqmI5zCBkgYDVR0jBIGKMIGHgBS/X7fR +zt0fhvRbVazc1xDCDqmI56FspGowaDELMAkGA1UEBhMCVVMxJTAjBgNVBAoTHFN0 +YXJmaWVsZCBUZWNobm9sb2dpZXMsIEluYy4xMjAwBgNVBAsTKVN0YXJmaWVsZCBD +bGFzcyAyIENlcnRpZmljYXRpb24gQXV0aG9yaXR5ggEAMAwGA1UdEwQFMAMBAf8w +DQYJKoZIhvcNAQEFBQADggEBAAWdP4id0ckaVaGsafPzWdqbAYcaT1epoXkJKtv3 +L7IezMdeatiDh6GX70k1PncGQVhiv45YuApnP+yz3SFmH8lU+nLMPUxA2IGvd56D +eruix/U0F47ZEUD0/CwqTRV/p2JdLiXTAAsgGh1o+Re49L2L7ShZ3U0WixeDyLJl +xy16paq8U4Zt3VekyvggQQto8PT7dL5WXXp59fkdheMtlb71cZBDzI0fmgAKhynp +VSJYACPq4xJDKVtHCN2MQWplBqjlIapBtJUhlbl90TSrE9atvNziPTnNvT51cKEY +WQPJIrSPnNVeKtelttQKbfi3QBFGmh95DmK/D5fs4C8fF5Q= +-----END CERTIFICATE----- + +# Issuer: CN=DigiCert Assured ID Root CA O=DigiCert Inc OU=www.digicert.com +# Subject: CN=DigiCert Assured ID Root CA O=DigiCert Inc OU=www.digicert.com +# Label: "DigiCert Assured ID Root CA" +# Serial: 17154717934120587862167794914071425081 +# MD5 Fingerprint: 87:ce:0b:7b:2a:0e:49:00:e1:58:71:9b:37:a8:93:72 +# SHA1 Fingerprint: 05:63:b8:63:0d:62:d7:5a:bb:c8:ab:1e:4b:df:b5:a8:99:b2:4d:43 +# SHA256 Fingerprint: 3e:90:99:b5:01:5e:8f:48:6c:00:bc:ea:9d:11:1e:e7:21:fa:ba:35:5a:89:bc:f1:df:69:56:1e:3d:c6:32:5c +-----BEGIN CERTIFICATE----- +MIIDtzCCAp+gAwIBAgIQDOfg5RfYRv6P5WD8G/AwOTANBgkqhkiG9w0BAQUFADBl +MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 +d3cuZGlnaWNlcnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJv +b3QgQ0EwHhcNMDYxMTEwMDAwMDAwWhcNMzExMTEwMDAwMDAwWjBlMQswCQYDVQQG +EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNl +cnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgQ0EwggEi +MA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCtDhXO5EOAXLGH87dg+XESpa7c +JpSIqvTO9SA5KFhgDPiA2qkVlTJhPLWxKISKityfCgyDF3qPkKyK53lTXDGEKvYP +mDI2dsze3Tyoou9q+yHyUmHfnyDXH+Kx2f4YZNISW1/5WBg1vEfNoTb5a3/UsDg+ +wRvDjDPZ2C8Y/igPs6eD1sNuRMBhNZYW/lmci3Zt1/GiSw0r/wty2p5g0I6QNcZ4 +VYcgoc/lbQrISXwxmDNsIumH0DJaoroTghHtORedmTpyoeb6pNnVFzF1roV9Iq4/ +AUaG9ih5yLHa5FcXxH4cDrC0kqZWs72yl+2qp/C3xag/lRbQ/6GW6whfGHdPAgMB +AAGjYzBhMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQW +BBRF66Kv9JLLgjEtUYunpyGd823IDzAfBgNVHSMEGDAWgBRF66Kv9JLLgjEtUYun +pyGd823IDzANBgkqhkiG9w0BAQUFAAOCAQEAog683+Lt8ONyc3pklL/3cmbYMuRC +dWKuh+vy1dneVrOfzM4UKLkNl2BcEkxY5NM9g0lFWJc1aRqoR+pWxnmrEthngYTf +fwk8lOa4JiwgvT2zKIn3X/8i4peEH+ll74fg38FnSbNd67IJKusm7Xi+fT8r87cm +NW1fiQG2SVufAQWbqz0lwcy2f8Lxb4bG+mRo64EtlOtCt/qMHt1i8b5QZ7dsvfPx +H2sMNgcWfzd8qVttevESRmCD1ycEvkvOl77DZypoEd+A5wwzZr8TDRRu838fYxAe ++o0bJW1sj6W3YQGx0qMmoRBxna3iw/nDmVG3KwcIzi7mULKn+gpFL6Lw8g== +-----END CERTIFICATE----- + +# Issuer: CN=DigiCert Global Root CA O=DigiCert Inc OU=www.digicert.com +# Subject: CN=DigiCert Global Root CA O=DigiCert Inc OU=www.digicert.com +# Label: "DigiCert Global Root CA" +# Serial: 10944719598952040374951832963794454346 +# MD5 Fingerprint: 79:e4:a9:84:0d:7d:3a:96:d7:c0:4f:e2:43:4c:89:2e +# SHA1 Fingerprint: a8:98:5d:3a:65:e5:e5:c4:b2:d7:d6:6d:40:c6:dd:2f:b1:9c:54:36 +# SHA256 Fingerprint: 43:48:a0:e9:44:4c:78:cb:26:5e:05:8d:5e:89:44:b4:d8:4f:96:62:bd:26:db:25:7f:89:34:a4:43:c7:01:61 +-----BEGIN CERTIFICATE----- +MIIDrzCCApegAwIBAgIQCDvgVpBCRrGhdWrJWZHHSjANBgkqhkiG9w0BAQUFADBh +MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 +d3cuZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBD +QTAeFw0wNjExMTAwMDAwMDBaFw0zMTExMTAwMDAwMDBaMGExCzAJBgNVBAYTAlVT +MRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5j +b20xIDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IENBMIIBIjANBgkqhkiG +9w0BAQEFAAOCAQ8AMIIBCgKCAQEA4jvhEXLeqKTTo1eqUKKPC3eQyaKl7hLOllsB +CSDMAZOnTjC3U/dDxGkAV53ijSLdhwZAAIEJzs4bg7/fzTtxRuLWZscFs3YnFo97 +nh6Vfe63SKMI2tavegw5BmV/Sl0fvBf4q77uKNd0f3p4mVmFaG5cIzJLv07A6Fpt +43C/dxC//AH2hdmoRBBYMql1GNXRor5H4idq9Joz+EkIYIvUX7Q6hL+hqkpMfT7P +T19sdl6gSzeRntwi5m3OFBqOasv+zbMUZBfHWymeMr/y7vrTC0LUq7dBMtoM1O/4 +gdW7jVg/tRvoSSiicNoxBN33shbyTApOB6jtSj1etX+jkMOvJwIDAQABo2MwYTAO +BgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUA95QNVbR +TLtm8KPiGxvDl7I90VUwHwYDVR0jBBgwFoAUA95QNVbRTLtm8KPiGxvDl7I90VUw +DQYJKoZIhvcNAQEFBQADggEBAMucN6pIExIK+t1EnE9SsPTfrgT1eXkIoyQY/Esr +hMAtudXH/vTBH1jLuG2cenTnmCmrEbXjcKChzUyImZOMkXDiqw8cvpOp/2PV5Adg +06O/nVsJ8dWO41P0jmP6P6fbtGbfYmbW0W5BjfIttep3Sp+dWOIrWcBAI+0tKIJF +PnlUkiaY4IBIqDfv8NZ5YBberOgOzW6sRBc4L0na4UU+Krk2U886UAb3LujEV0ls +YSEY1QSteDwsOoBrp+uvFRTp2InBuThs4pFsiv9kuXclVzDAGySj4dzp30d8tbQk +CAUw7C29C79Fv1C5qfPrmAESrciIxpg0X40KPMbp1ZWVbd4= +-----END CERTIFICATE----- + +# Issuer: CN=DigiCert High Assurance EV Root CA O=DigiCert Inc OU=www.digicert.com +# Subject: CN=DigiCert High Assurance EV Root CA O=DigiCert Inc OU=www.digicert.com +# Label: "DigiCert High Assurance EV Root CA" +# Serial: 3553400076410547919724730734378100087 +# MD5 Fingerprint: d4:74:de:57:5c:39:b2:d3:9c:85:83:c5:c0:65:49:8a +# SHA1 Fingerprint: 5f:b7:ee:06:33:e2:59:db:ad:0c:4c:9a:e6:d3:8f:1a:61:c7:dc:25 +# SHA256 Fingerprint: 74:31:e5:f4:c3:c1:ce:46:90:77:4f:0b:61:e0:54:40:88:3b:a9:a0:1e:d0:0b:a6:ab:d7:80:6e:d3:b1:18:cf +-----BEGIN CERTIFICATE----- +MIIDxTCCAq2gAwIBAgIQAqxcJmoLQJuPC3nyrkYldzANBgkqhkiG9w0BAQUFADBs +MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 +d3cuZGlnaWNlcnQuY29tMSswKQYDVQQDEyJEaWdpQ2VydCBIaWdoIEFzc3VyYW5j +ZSBFViBSb290IENBMB4XDTA2MTExMDAwMDAwMFoXDTMxMTExMDAwMDAwMFowbDEL +MAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IEluYzEZMBcGA1UECxMQd3d3 +LmRpZ2ljZXJ0LmNvbTErMCkGA1UEAxMiRGlnaUNlcnQgSGlnaCBBc3N1cmFuY2Ug +RVYgUm9vdCBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMbM5XPm ++9S75S0tMqbf5YE/yc0lSbZxKsPVlDRnogocsF9ppkCxxLeyj9CYpKlBWTrT3JTW +PNt0OKRKzE0lgvdKpVMSOO7zSW1xkX5jtqumX8OkhPhPYlG++MXs2ziS4wblCJEM +xChBVfvLWokVfnHoNb9Ncgk9vjo4UFt3MRuNs8ckRZqnrG0AFFoEt7oT61EKmEFB +Ik5lYYeBQVCmeVyJ3hlKV9Uu5l0cUyx+mM0aBhakaHPQNAQTXKFx01p8VdteZOE3 +hzBWBOURtCmAEvF5OYiiAhF8J2a3iLd48soKqDirCmTCv2ZdlYTBoSUeh10aUAsg +EsxBu24LUTi4S8sCAwEAAaNjMGEwDgYDVR0PAQH/BAQDAgGGMA8GA1UdEwEB/wQF +MAMBAf8wHQYDVR0OBBYEFLE+w2kD+L9HAdSYJhoIAu9jZCvDMB8GA1UdIwQYMBaA +FLE+w2kD+L9HAdSYJhoIAu9jZCvDMA0GCSqGSIb3DQEBBQUAA4IBAQAcGgaX3Nec +nzyIZgYIVyHbIUf4KmeqvxgydkAQV8GK83rZEWWONfqe/EW1ntlMMUu4kehDLI6z +eM7b41N5cdblIZQB2lWHmiRk9opmzN6cN82oNLFpmyPInngiK3BD41VHMWEZ71jF +hS9OMPagMRYjyOfiZRYzy78aG6A9+MpeizGLYAiJLQwGXFK3xPkKmNEVX58Svnw2 +Yzi9RKR/5CYrCsSXaQ3pjOLAEFe4yHYSkVXySGnYvCoCWw9E1CAx2/S6cCZdkGCe +vEsXCS+0yx5DaMkHJ8HSXPfqIbloEpw8nL+e/IBcm2PN7EeqJSdnoDfzAIJ9VNep ++OkuE6N36B9K +-----END CERTIFICATE----- + +# Issuer: CN=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=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=COMODO ECC Certification Authority O=COMODO CA Limited +# Subject: CN=COMODO ECC Certification Authority O=COMODO CA Limited +# Label: "COMODO ECC Certification Authority" +# Serial: 41578283867086692638256921589707938090 +# MD5 Fingerprint: 7c:62:ff:74:9d:31:53:5e:68:4a:d5:78:aa:1e:bf:23 +# SHA1 Fingerprint: 9f:74:4e:9f:2b:4d:ba:ec:0f:31:2c:50:b6:56:3b:8e:2d:93:c3:11 +# SHA256 Fingerprint: 17:93:92:7a:06:14:54:97:89:ad:ce:2f:8f:34:f7:f0:b6:6d:0f:3a:e3:a3:b8:4d:21:ec:15:db:ba:4f:ad:c7 +-----BEGIN CERTIFICATE----- +MIICiTCCAg+gAwIBAgIQH0evqmIAcFBUTAGem2OZKjAKBggqhkjOPQQDAzCBhTEL +MAkGA1UEBhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UE +BxMHU2FsZm9yZDEaMBgGA1UEChMRQ09NT0RPIENBIExpbWl0ZWQxKzApBgNVBAMT +IkNPTU9ETyBFQ0MgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDgwMzA2MDAw +MDAwWhcNMzgwMTE4MjM1OTU5WjCBhTELMAkGA1UEBhMCR0IxGzAZBgNVBAgTEkdy +ZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UEChMRQ09N +T0RPIENBIExpbWl0ZWQxKzApBgNVBAMTIkNPTU9ETyBFQ0MgQ2VydGlmaWNhdGlv +biBBdXRob3JpdHkwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQDR3svdcmCFYX7deSR +FtSrYpn1PlILBs5BAH+X4QokPB0BBO490o0JlwzgdeT6+3eKKvUDYEs2ixYjFq0J +cfRK9ChQtP6IHG4/bC8vCVlbpVsLM5niwz2J+Wos77LTBumjQjBAMB0GA1UdDgQW +BBR1cacZSBm8nZ3qQUfflMRId5nTeTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/ +BAUwAwEB/zAKBggqhkjOPQQDAwNoADBlAjEA7wNbeqy3eApyt4jf/7VGFAkK+qDm +fQjGGoe9GKhzvSbKYAydzpmfz1wPMOG+FDHqAjAU9JM8SaczepBGR7NjfRObTrdv +GDeAU/7dIOA1mjbRxwG55tzd8/8dLDoWV9mSOdY= +-----END CERTIFICATE----- + +# Issuer: CN=Certigna O=Dhimyotis +# Subject: CN=Certigna O=Dhimyotis +# Label: "Certigna" +# Serial: 18364802974209362175 +# MD5 Fingerprint: ab:57:a6:5b:7d:42:82:19:b5:d8:58:26:28:5e:fd:ff +# SHA1 Fingerprint: b1:2e:13:63:45:86:a4:6f:1a:b2:60:68:37:58:2d:c4:ac:fd:94:97 +# SHA256 Fingerprint: e3:b6:a2:db:2e:d7:ce:48:84:2f:7a:c5:32:41:c7:b7:1d:54:14:4b:fb:40:c1:1f:3f:1d:0b:42:f5:ee:a1:2d +-----BEGIN CERTIFICATE----- +MIIDqDCCApCgAwIBAgIJAP7c4wEPyUj/MA0GCSqGSIb3DQEBBQUAMDQxCzAJBgNV +BAYTAkZSMRIwEAYDVQQKDAlEaGlteW90aXMxETAPBgNVBAMMCENlcnRpZ25hMB4X +DTA3MDYyOTE1MTMwNVoXDTI3MDYyOTE1MTMwNVowNDELMAkGA1UEBhMCRlIxEjAQ +BgNVBAoMCURoaW15b3RpczERMA8GA1UEAwwIQ2VydGlnbmEwggEiMA0GCSqGSIb3 +DQEBAQUAA4IBDwAwggEKAoIBAQDIaPHJ1tazNHUmgh7stL7qXOEm7RFHYeGifBZ4 +QCHkYJ5ayGPhxLGWkv8YbWkj4Sti993iNi+RB7lIzw7sebYs5zRLcAglozyHGxny +gQcPOJAZ0xH+hrTy0V4eHpbNgGzOOzGTtvKg0KmVEn2lmsxryIRWijOp5yIVUxbw +zBfsV1/pogqYCd7jX5xv3EjjhQsVWqa6n6xI4wmy9/Qy3l40vhx4XUJbzg4ij02Q +130yGLMLLGq/jj8UEYkgDncUtT2UCIf3JR7VsmAA7G8qKCVuKj4YYxclPz5EIBb2 +JsglrgVKtOdjLPOMFlN+XPsRGgjBRmKfIrjxwo1p3Po6WAbfAgMBAAGjgbwwgbkw +DwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUGu3+QTmQtCRZvgHyUtVF9lo53BEw +ZAYDVR0jBF0wW4AUGu3+QTmQtCRZvgHyUtVF9lo53BGhOKQ2MDQxCzAJBgNVBAYT +AkZSMRIwEAYDVQQKDAlEaGlteW90aXMxETAPBgNVBAMMCENlcnRpZ25hggkA/tzj +AQ/JSP8wDgYDVR0PAQH/BAQDAgEGMBEGCWCGSAGG+EIBAQQEAwIABzANBgkqhkiG +9w0BAQUFAAOCAQEAhQMeknH2Qq/ho2Ge6/PAD/Kl1NqV5ta+aDY9fm4fTIrv0Q8h +bV6lUmPOEvjvKtpv6zf+EwLHyzs+ImvaYS5/1HI93TDhHkxAGYwP15zRgzB7mFnc +fca5DClMoTOi62c6ZYTTluLtdkVwj7Ur3vkj1kluPBS1xp81HlDQwY9qcEQCYsuu +HWhBp6pX6FOqB9IG9tUUBguRA3UsbHK1YZWaDYu5Def131TN3ubY1gkIl2PlwS6w +t0QmwCbAr1UwnjvVNioZBPRcHv/PLLf/0P2HQBHVESO7SMAhqaQoLf0V+LBOK/Qw +WyH8EZE0vkHve52Xdf+XlcCWWC/qu0bXu+TZLg== +-----END CERTIFICATE----- + +# Issuer: O=Chunghwa Telecom Co., Ltd. OU=ePKI Root Certification Authority +# Subject: O=Chunghwa Telecom Co., Ltd. OU=ePKI Root Certification Authority +# Label: "ePKI Root Certification Authority" +# Serial: 28956088682735189655030529057352760477 +# MD5 Fingerprint: 1b:2e:00:ca:26:06:90:3d:ad:fe:6f:15:68:d3:6b:b3 +# SHA1 Fingerprint: 67:65:0d:f1:7e:8e:7e:5b:82:40:a4:f4:56:4b:cf:e2:3d:69:c6:f0 +# SHA256 Fingerprint: c0:a6:f4:dc:63:a2:4b:fd:cf:54:ef:2a:6a:08:2a:0a:72:de:35:80:3e:2f:f5:ff:52:7a:e5:d8:72:06:df:d5 +-----BEGIN CERTIFICATE----- +MIIFsDCCA5igAwIBAgIQFci9ZUdcr7iXAF7kBtK8nTANBgkqhkiG9w0BAQUFADBe +MQswCQYDVQQGEwJUVzEjMCEGA1UECgwaQ2h1bmdod2EgVGVsZWNvbSBDby4sIEx0 +ZC4xKjAoBgNVBAsMIWVQS0kgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAe +Fw0wNDEyMjAwMjMxMjdaFw0zNDEyMjAwMjMxMjdaMF4xCzAJBgNVBAYTAlRXMSMw +IQYDVQQKDBpDaHVuZ2h3YSBUZWxlY29tIENvLiwgTHRkLjEqMCgGA1UECwwhZVBL +SSBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIICIjANBgkqhkiG9w0BAQEF +AAOCAg8AMIICCgKCAgEA4SUP7o3biDN1Z82tH306Tm2d0y8U82N0ywEhajfqhFAH +SyZbCUNsIZ5qyNUD9WBpj8zwIuQf5/dqIjG3LBXy4P4AakP/h2XGtRrBp0xtInAh +ijHyl3SJCRImHJ7K2RKilTza6We/CKBk49ZCt0Xvl/T29de1ShUCWH2YWEtgvM3X +DZoTM1PRYfl61dd4s5oz9wCGzh1NlDivqOx4UXCKXBCDUSH3ET00hl7lSM2XgYI1 +TBnsZfZrxQWh7kcT1rMhJ5QQCtkkO7q+RBNGMD+XPNjX12ruOzjjK9SXDrkb5wdJ +fzcq+Xd4z1TtW0ado4AOkUPB1ltfFLqfpo0kR0BZv3I4sjZsN/+Z0V0OWQqraffA +sgRFelQArr5T9rXn4fg8ozHSqf4hUmTFpmfwdQcGlBSBVcYn5AGPF8Fqcde+S/uU +WH1+ETOxQvdibBjWzwloPn9s9h6PYq2lY9sJpx8iQkEeb5mKPtf5P0B6ebClAZLS +nT0IFaUQAS2zMnaolQ2zepr7BxB4EW/hj8e6DyUadCrlHJhBmd8hh+iVBmoKs2pH +dmX2Os+PYhcZewoozRrSgx4hxyy/vv9haLdnG7t4TY3OZ+XkwY63I2binZB1NJip +NiuKmpS5nezMirH4JYlcWrYvjB9teSSnUmjDhDXiZo1jDiVN1Rmy5nk3pyKdVDEC +AwEAAaNqMGgwHQYDVR0OBBYEFB4M97Zn8uGSJglFwFU5Lnc/QkqiMAwGA1UdEwQF +MAMBAf8wOQYEZyoHAAQxMC8wLQIBADAJBgUrDgMCGgUAMAcGBWcqAwAABBRFsMLH +ClZ87lt4DJX5GFPBphzYEDANBgkqhkiG9w0BAQUFAAOCAgEACbODU1kBPpVJufGB +uvl2ICO1J2B01GqZNF5sAFPZn/KmsSQHRGoqxqWOeBLoR9lYGxMqXnmbnwoqZ6Yl +PwZpVnPDimZI+ymBV3QGypzqKOg4ZyYr8dW1P2WT+DZdjo2NQCCHGervJ8A9tDkP +JXtoUHRVnAxZfVo9QZQlUgjgRywVMRnVvwdVxrsStZf0X4OFunHB2WyBEXYKCrC/ +gpf36j36+uwtqSiUO1bd0lEursC9CBWMd1I0ltabrNMdjmEPNXubrjlpC2JgQCA2 +j6/7Nu4tCEoduL+bXPjqpRugc6bY+G7gMwRfaKonh+3ZwZCc7b3jajWvY9+rGNm6 +5ulK6lCKD2GTHuItGeIwlDWSXQ62B68ZgI9HkFFLLk3dheLSClIKF5r8GrBQAuUB +o2M3IUxExJtRmREOc5wGj1QupyheRDmHVi03vYVElOEMSyycw5KFNGHLD7ibSkNS +/jQ6fbjpKdx2qcgw+BRxgMYeNkh0IkFch4LoGHGLQYlE535YW6i4jRPpp2zDR+2z +Gp1iro2C6pSe3VkQw63d4k3jMdXH7OjysP6SHhYKGvzZ8/gntsm+HbRsZJB/9OTE +W9c3rkIO3aQab3yIVMUWbuF6aC74Or8NpDyJO3inTmODBCEIZ43ygknQW/2xzQ+D +hNQ+IIX3Sj0rnP0qCglN6oH4EZw= +-----END CERTIFICATE----- + +# Issuer: O=certSIGN OU=certSIGN ROOT CA +# Subject: O=certSIGN OU=certSIGN ROOT CA +# Label: "certSIGN ROOT CA" +# Serial: 35210227249154 +# MD5 Fingerprint: 18:98:c0:d6:e9:3a:fc:f9:b0:f5:0c:f7:4b:01:44:17 +# SHA1 Fingerprint: fa:b7:ee:36:97:26:62:fb:2d:b0:2a:f6:bf:03:fd:e8:7c:4b:2f:9b +# SHA256 Fingerprint: ea:a9:62:c4:fa:4a:6b:af:eb:e4:15:19:6d:35:1c:cd:88:8d:4f:53:f3:fa:8a:e6:d7:c4:66:a9:4e:60:42:bb +-----BEGIN CERTIFICATE----- +MIIDODCCAiCgAwIBAgIGIAYFFnACMA0GCSqGSIb3DQEBBQUAMDsxCzAJBgNVBAYT +AlJPMREwDwYDVQQKEwhjZXJ0U0lHTjEZMBcGA1UECxMQY2VydFNJR04gUk9PVCBD +QTAeFw0wNjA3MDQxNzIwMDRaFw0zMTA3MDQxNzIwMDRaMDsxCzAJBgNVBAYTAlJP +MREwDwYDVQQKEwhjZXJ0U0lHTjEZMBcGA1UECxMQY2VydFNJR04gUk9PVCBDQTCC +ASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALczuX7IJUqOtdu0KBuqV5Do +0SLTZLrTk+jUrIZhQGpgV2hUhE28alQCBf/fm5oqrl0Hj0rDKH/v+yv6efHHrfAQ +UySQi2bJqIirr1qjAOm+ukbuW3N7LBeCgV5iLKECZbO9xSsAfsT8AzNXDe3i+s5d +RdY4zTW2ssHQnIFKquSyAVwdj1+ZxLGt24gh65AIgoDzMKND5pCCrlUoSe1b16kQ +OA7+j0xbm0bqQfWwCHTD0IgztnzXdN/chNFDDnU5oSVAKOp4yw4sLjmdjItuFhwv +JoIQ4uNllAoEwF73XVv4EOLQunpL+943AAAaWyjj0pxzPjKHmKHJUS/X3qwzs08C +AwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAcYwHQYDVR0O +BBYEFOCMm9slSbPxfIbWskKHC9BroNnkMA0GCSqGSIb3DQEBBQUAA4IBAQA+0hyJ +LjX8+HXd5n9liPRyTMks1zJO890ZeUe9jjtbkw9QSSQTaxQGcu8J06Gh40CEyecY +MnQ8SG4Pn0vU9x7Tk4ZkVJdjclDVVc/6IJMCopvDI5NOFlV2oHB5bc0hH88vLbwZ +44gx+FkagQnIl6Z0x2DEW8xXjrJ1/RsCCdtZb3KTafcxQdaIOL+Hsr0Wefmq5L6I +Jd1hJyMctTEHBDa0GpC9oHRxUIltvBTjD4au8as+x6AJzKNI0eDbZOeStc+vckNw +i/nDhDwTqn6Sm1dTk/pwwpEOMfmbZ13pljheX7NzTogVZ96edhBiIL5VaZVDADlN +9u6wWk5JRFRYX0KD +-----END CERTIFICATE----- + +# Issuer: CN=NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny O=NetLock Kft. OU=Tan\xfas\xedtv\xe1nykiad\xf3k (Certification Services) +# Subject: CN=NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny O=NetLock Kft. OU=Tan\xfas\xedtv\xe1nykiad\xf3k (Certification Services) +# Label: "NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny" +# Serial: 80544274841616 +# MD5 Fingerprint: c5:a1:b7:ff:73:dd:d6:d7:34:32:18:df:fc:3c:ad:88 +# SHA1 Fingerprint: 06:08:3f:59:3f:15:a1:04:a0:69:a4:6b:a9:03:d0:06:b7:97:09:91 +# SHA256 Fingerprint: 6c:61:da:c3:a2:de:f0:31:50:6b:e0:36:d2:a6:fe:40:19:94:fb:d1:3d:f9:c8:d4:66:59:92:74:c4:46:ec:98 +-----BEGIN CERTIFICATE----- +MIIEFTCCAv2gAwIBAgIGSUEs5AAQMA0GCSqGSIb3DQEBCwUAMIGnMQswCQYDVQQG +EwJIVTERMA8GA1UEBwwIQnVkYXBlc3QxFTATBgNVBAoMDE5ldExvY2sgS2Z0LjE3 +MDUGA1UECwwuVGFuw7pzw610dsOhbnlraWFkw7NrIChDZXJ0aWZpY2F0aW9uIFNl +cnZpY2VzKTE1MDMGA1UEAwwsTmV0TG9jayBBcmFueSAoQ2xhc3MgR29sZCkgRsWR +dGFuw7pzw610dsOhbnkwHhcNMDgxMjExMTUwODIxWhcNMjgxMjA2MTUwODIxWjCB +pzELMAkGA1UEBhMCSFUxETAPBgNVBAcMCEJ1ZGFwZXN0MRUwEwYDVQQKDAxOZXRM +b2NrIEtmdC4xNzA1BgNVBAsMLlRhbsO6c8OtdHbDoW55a2lhZMOzayAoQ2VydGlm +aWNhdGlvbiBTZXJ2aWNlcykxNTAzBgNVBAMMLE5ldExvY2sgQXJhbnkgKENsYXNz +IEdvbGQpIEbFkXRhbsO6c8OtdHbDoW55MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A +MIIBCgKCAQEAxCRec75LbRTDofTjl5Bu0jBFHjzuZ9lk4BqKf8owyoPjIMHj9DrT +lF8afFttvzBPhCf2nx9JvMaZCpDyD/V/Q4Q3Y1GLeqVw/HpYzY6b7cNGbIRwXdrz +AZAj/E4wqX7hJ2Pn7WQ8oLjJM2P+FpD/sLj916jAwJRDC7bVWaaeVtAkH3B5r9s5 +VA1lddkVQZQBr17s9o3x/61k/iCa11zr/qYfCGSji3ZVrR47KGAuhyXoqq8fxmRG +ILdwfzzeSNuWU7c5d+Qa4scWhHaXWy+7GRWF+GmF9ZmnqfI0p6m2pgP8b4Y9VHx2 +BJtr+UBdADTHLpl1neWIA6pN+APSQnbAGwIDAKiLo0UwQzASBgNVHRMBAf8ECDAG +AQH/AgEEMA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUzPpnk/C2uNClwB7zU/2M +U9+D15YwDQYJKoZIhvcNAQELBQADggEBAKt/7hwWqZw8UQCgwBEIBaeZ5m8BiFRh +bvG5GK1Krf6BQCOUL/t1fC8oS2IkgYIL9WHxHG64YTjrgfpioTtaYtOUZcTh5m2C ++C8lcLIhJsFyUR+MLMOEkMNaj7rP9KdlpeuY0fsFskZ1FSNqb4VjMIDw1Z4fKRzC +bLBQWV2QWzuoDTDPv31/zvGdg73JRm4gpvlhUbohL3u+pRVjodSVh/GeufOJ8z2F +uLjbvrW5KfnaNwUASZQDhETnv0Mxz3WLJdH0pmT1kvarBes96aULNmLazAZfNou2 +XjG4Kvte9nHfRCaexOYNkbQudZWAUWpLMKawYqGT8ZvYzsRjdT9ZR7E= +-----END CERTIFICATE----- + +# Issuer: CN=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=Izenpe.com O=IZENPE S.A. +# Subject: CN=Izenpe.com O=IZENPE S.A. +# Label: "Izenpe.com" +# Serial: 917563065490389241595536686991402621 +# MD5 Fingerprint: a6:b0:cd:85:80:da:5c:50:34:a3:39:90:2f:55:67:73 +# SHA1 Fingerprint: 2f:78:3d:25:52:18:a7:4a:65:39:71:b5:2c:a2:9c:45:15:6f:e9:19 +# SHA256 Fingerprint: 25:30:cc:8e:98:32:15:02:ba:d9:6f:9b:1f:ba:1b:09:9e:2d:29:9e:0f:45:48:bb:91:4f:36:3b:c0:d4:53:1f +-----BEGIN CERTIFICATE----- +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 +-----END CERTIFICATE----- + +# Issuer: CN=Go Daddy Root Certificate Authority - G2 O=GoDaddy.com, Inc. +# Subject: CN=Go Daddy Root Certificate Authority - G2 O=GoDaddy.com, Inc. +# Label: "Go Daddy Root Certificate Authority - G2" +# Serial: 0 +# MD5 Fingerprint: 80:3a:bc:22:c1:e6:fb:8d:9b:3b:27:4a:32:1b:9a:01 +# SHA1 Fingerprint: 47:be:ab:c9:22:ea:e8:0e:78:78:34:62:a7:9f:45:c2:54:fd:e6:8b +# SHA256 Fingerprint: 45:14:0b:32:47:eb:9c:c8:c5:b4:f0:d7:b5:30:91:f7:32:92:08:9e:6e:5a:63:e2:74:9d:d3:ac:a9:19:8e:da +-----BEGIN CERTIFICATE----- +MIIDxTCCAq2gAwIBAgIBADANBgkqhkiG9w0BAQsFADCBgzELMAkGA1UEBhMCVVMx +EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxGjAYBgNVBAoT +EUdvRGFkZHkuY29tLCBJbmMuMTEwLwYDVQQDEyhHbyBEYWRkeSBSb290IENlcnRp +ZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5MDkwMTAwMDAwMFoXDTM3MTIzMTIz +NTk1OVowgYMxCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6b25hMRMwEQYDVQQH +EwpTY290dHNkYWxlMRowGAYDVQQKExFHb0RhZGR5LmNvbSwgSW5jLjExMC8GA1UE +AxMoR28gRGFkZHkgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIw +DQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAL9xYgjx+lk09xvJGKP3gElY6SKD +E6bFIEMBO4Tx5oVJnyfq9oQbTqC023CYxzIBsQU+B07u9PpPL1kwIuerGVZr4oAH +/PMWdYA5UXvl+TW2dE6pjYIT5LY/qQOD+qK+ihVqf94Lw7YZFAXK6sOoBJQ7Rnwy +DfMAZiLIjWltNowRGLfTshxgtDj6AozO091GB94KPutdfMh8+7ArU6SSYmlRJQVh +GkSBjCypQ5Yj36w6gZoOKcUcqeldHraenjAKOc7xiID7S13MMuyFYkMlNAJWJwGR +tDtwKj9useiciAF9n9T521NtYJ2/LOdYq7hfRvzOxBsDPAnrSTFcaUaz4EcCAwEA +AaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYE +FDqahQcQZyi27/a9BUFuIMGU2g/eMA0GCSqGSIb3DQEBCwUAA4IBAQCZ21151fmX +WWcDYfF+OwYxdS2hII5PZYe096acvNjpL9DbWu7PdIxztDhC2gV7+AJ1uP2lsdeu +9tfeE8tTEH6KRtGX+rcuKxGrkLAngPnon1rpN5+r5N9ss4UXnT3ZJE95kTXWXwTr +gIOrmgIttRD02JDHBHNA7XIloKmf7J6raBKZV8aPEjoJpL1E/QYVN8Gb5DKj7Tjo +2GTzLH4U/ALqn83/B2gX2yKQOC16jdFU8WnjXzPKej17CuPKf1855eJ1usV2GDPO +LPAvTK33sefOT6jEm0pUBsV/fdUID+Ic/n4XuKxe9tQWskMJDE32p2u0mYRlynqI +4uJEvlz36hz1 +-----END CERTIFICATE----- + +# Issuer: CN=Starfield Root Certificate Authority - G2 O=Starfield Technologies, Inc. +# Subject: CN=Starfield Root Certificate Authority - G2 O=Starfield Technologies, Inc. +# Label: "Starfield Root Certificate Authority - G2" +# Serial: 0 +# MD5 Fingerprint: d6:39:81:c6:52:7e:96:69:fc:fc:ca:66:ed:05:f2:96 +# SHA1 Fingerprint: b5:1c:06:7c:ee:2b:0c:3d:f8:55:ab:2d:92:f4:fe:39:d4:e7:0f:0e +# SHA256 Fingerprint: 2c:e1:cb:0b:f9:d2:f9:e1:02:99:3f:be:21:51:52:c3:b2:dd:0c:ab:de:1c:68:e5:31:9b:83:91:54:db:b7:f5 +-----BEGIN CERTIFICATE----- +MIID3TCCAsWgAwIBAgIBADANBgkqhkiG9w0BAQsFADCBjzELMAkGA1UEBhMCVVMx +EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoT +HFN0YXJmaWVsZCBUZWNobm9sb2dpZXMsIEluYy4xMjAwBgNVBAMTKVN0YXJmaWVs +ZCBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5MDkwMTAwMDAw +MFoXDTM3MTIzMTIzNTk1OVowgY8xCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6 +b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxTdGFyZmllbGQgVGVj +aG5vbG9naWVzLCBJbmMuMTIwMAYDVQQDEylTdGFyZmllbGQgUm9vdCBDZXJ0aWZp +Y2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC +ggEBAL3twQP89o/8ArFvW59I2Z154qK3A2FWGMNHttfKPTUuiUP3oWmb3ooa/RMg +nLRJdzIpVv257IzdIvpy3Cdhl+72WoTsbhm5iSzchFvVdPtrX8WJpRBSiUZV9Lh1 +HOZ/5FSuS/hVclcCGfgXcVnrHigHdMWdSL5stPSksPNkN3mSwOxGXn/hbVNMYq/N +Hwtjuzqd+/x5AJhhdM8mgkBj87JyahkNmcrUDnXMN/uLicFZ8WJ/X7NfZTD4p7dN +dloedl40wOiWVpmKs/B/pM293DIxfJHP4F8R+GuqSVzRmZTRouNjWwl2tVZi4Ut0 +HZbUJtQIBFnQmA4O5t78w+wfkPECAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAO +BgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFHwMMh+n2TB/xH1oo2Kooc6rB1snMA0G +CSqGSIb3DQEBCwUAA4IBAQARWfolTwNvlJk7mh+ChTnUdgWUXuEok21iXQnCoKjU +sHU48TRqneSfioYmUeYs0cYtbpUgSpIB7LiKZ3sx4mcujJUDJi5DnUox9g61DLu3 +4jd/IroAow57UvtruzvE03lRTs2Q9GcHGcg8RnoNAX3FWOdt5oUwF5okxBDgBPfg +8n/Uqgr/Qh037ZTlZFkSIHc40zI+OIF1lnP6aI+xy84fxez6nH7PfrHxBy22/L/K +pL/QlwVKvOoYKAKQvVR4CSFx09F9HdkWsKlhPdAKACL8x3vLCWRFCztAgfd9fDL1 +mMpYjn0q7pBZc2T5NnReJaH1ZgUufzkVqSr7UIuOhWn0 +-----END CERTIFICATE----- + +# Issuer: CN=Starfield Services Root Certificate Authority - G2 O=Starfield Technologies, Inc. +# Subject: CN=Starfield Services Root Certificate Authority - G2 O=Starfield Technologies, Inc. +# Label: "Starfield Services Root Certificate Authority - G2" +# Serial: 0 +# MD5 Fingerprint: 17:35:74:af:7b:61:1c:eb:f4:f9:3c:e2:ee:40:f9:a2 +# SHA1 Fingerprint: 92:5a:8f:8d:2c:6d:04:e0:66:5f:59:6a:ff:22:d8:63:e8:25:6f:3f +# SHA256 Fingerprint: 56:8d:69:05:a2:c8:87:08:a4:b3:02:51:90:ed:cf:ed:b1:97:4a:60:6a:13:c6:e5:29:0f:cb:2a:e6:3e:da:b5 +-----BEGIN CERTIFICATE----- +MIID7zCCAtegAwIBAgIBADANBgkqhkiG9w0BAQsFADCBmDELMAkGA1UEBhMCVVMx +EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoT +HFN0YXJmaWVsZCBUZWNobm9sb2dpZXMsIEluYy4xOzA5BgNVBAMTMlN0YXJmaWVs +ZCBTZXJ2aWNlcyBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5 +MDkwMTAwMDAwMFoXDTM3MTIzMTIzNTk1OVowgZgxCzAJBgNVBAYTAlVTMRAwDgYD +VQQIEwdBcml6b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxTdGFy +ZmllbGQgVGVjaG5vbG9naWVzLCBJbmMuMTswOQYDVQQDEzJTdGFyZmllbGQgU2Vy +dmljZXMgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZI +hvcNAQEBBQADggEPADCCAQoCggEBANUMOsQq+U7i9b4Zl1+OiFOxHz/Lz58gE20p +OsgPfTz3a3Y4Y9k2YKibXlwAgLIvWX/2h/klQ4bnaRtSmpDhcePYLQ1Ob/bISdm2 +8xpWriu2dBTrz/sm4xq6HZYuajtYlIlHVv8loJNwU4PahHQUw2eeBGg6345AWh1K +Ts9DkTvnVtYAcMtS7nt9rjrnvDH5RfbCYM8TWQIrgMw0R9+53pBlbQLPLJGmpufe +hRhJfGZOozptqbXuNC66DQO4M99H67FrjSXZm86B0UVGMpZwh94CDklDhbZsc7tk +6mFBrMnUVN+HL8cisibMn1lUaJ/8viovxFUcdUBgF4UCVTmLfwUCAwEAAaNCMEAw +DwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFJxfAN+q +AdcwKziIorhtSpzyEZGDMA0GCSqGSIb3DQEBCwUAA4IBAQBLNqaEd2ndOxmfZyMI +bw5hyf2E3F/YNoHN2BtBLZ9g3ccaaNnRbobhiCPPE95Dz+I0swSdHynVv/heyNXB +ve6SbzJ08pGCL72CQnqtKrcgfU28elUSwhXqvfdqlS5sdJ/PHLTyxQGjhdByPq1z +qwubdQxtRbeOlKyWN7Wg0I8VRw7j6IPdj/3vQQF3zCepYoUz8jcI73HPdwbeyBkd +iEDPfUYd/x7H4c7/I9vG+o1VTqkC50cRRj70/b17KSa7qWFiNyi2LSr2EIZkyXCn +0q23KXB56jzaYyWf/Wi3MOxw+3WKt21gZ7IeyLnp2KhvAotnDU0mV3HaIPzBSlCN +sSi6 +-----END CERTIFICATE----- + +# Issuer: CN=AffirmTrust Commercial O=AffirmTrust +# Subject: CN=AffirmTrust Commercial O=AffirmTrust +# Label: "AffirmTrust Commercial" +# Serial: 8608355977964138876 +# MD5 Fingerprint: 82:92:ba:5b:ef:cd:8a:6f:a6:3d:55:f9:84:f6:d6:b7 +# SHA1 Fingerprint: f9:b5:b6:32:45:5f:9c:be:ec:57:5f:80:dc:e9:6e:2c:c7:b2:78:b7 +# SHA256 Fingerprint: 03:76:ab:1d:54:c5:f9:80:3c:e4:b2:e2:01:a0:ee:7e:ef:7b:57:b6:36:e8:a9:3c:9b:8d:48:60:c9:6f:5f:a7 +-----BEGIN CERTIFICATE----- +MIIDTDCCAjSgAwIBAgIId3cGJyapsXwwDQYJKoZIhvcNAQELBQAwRDELMAkGA1UE +BhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVz +dCBDb21tZXJjaWFsMB4XDTEwMDEyOTE0MDYwNloXDTMwMTIzMTE0MDYwNlowRDEL +MAkGA1UEBhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZp +cm1UcnVzdCBDb21tZXJjaWFsMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKC +AQEA9htPZwcroRX1BiLLHwGy43NFBkRJLLtJJRTWzsO3qyxPxkEylFf6EqdbDuKP +Hx6GGaeqtS25Xw2Kwq+FNXkyLbscYjfysVtKPcrNcV/pQr6U6Mje+SJIZMblq8Yr +ba0F8PrVC8+a5fBQpIs7R6UjW3p6+DM/uO+Zl+MgwdYoic+U+7lF7eNAFxHUdPAL +MeIrJmqbTFeurCA+ukV6BfO9m2kVrn1OIGPENXY6BwLJN/3HR+7o8XYdcxXyl6S1 +yHp52UKqK39c/s4mT6NmgTWvRLpUHhwwMmWd5jyTXlBOeuM61G7MGvv50jeuJCqr +VwMiKA1JdX+3KNp1v47j3A55MQIDAQABo0IwQDAdBgNVHQ4EFgQUnZPGU4teyq8/ +nx4P5ZmVvCT2lI8wDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwDQYJ +KoZIhvcNAQELBQADggEBAFis9AQOzcAN/wr91LoWXym9e2iZWEnStB03TX8nfUYG +XUPGhi4+c7ImfU+TqbbEKpqrIZcUsd6M06uJFdhrJNTxFq7YpFzUf1GO7RgBsZNj +vbz4YYCanrHOQnDiqX0GJX0nof5v7LMeJNrjS1UaADs1tDvZ110w/YETifLCBivt +Z8SOyUOyXGsViQK8YvxO8rUzqrJv0wqiUOP2O+guRMLbZjipM1ZI8W0bM40NjD9g +N53Tym1+NH4Nn3J2ixufcv1SNUFFApYvHLKac0khsUlHRUe072o0EclNmsxZt9YC +nlpOZbWUrhvfKbAW8b8Angc6F2S1BLUjIZkKlTuXfO8= +-----END CERTIFICATE----- + +# Issuer: CN=AffirmTrust Networking O=AffirmTrust +# Subject: CN=AffirmTrust Networking O=AffirmTrust +# Label: "AffirmTrust Networking" +# Serial: 8957382827206547757 +# MD5 Fingerprint: 42:65:ca:be:01:9a:9a:4c:a9:8c:41:49:cd:c0:d5:7f +# SHA1 Fingerprint: 29:36:21:02:8b:20:ed:02:f5:66:c5:32:d1:d6:ed:90:9f:45:00:2f +# SHA256 Fingerprint: 0a:81:ec:5a:92:97:77:f1:45:90:4a:f3:8d:5d:50:9f:66:b5:e2:c5:8f:cd:b5:31:05:8b:0e:17:f3:f0:b4:1b +-----BEGIN CERTIFICATE----- +MIIDTDCCAjSgAwIBAgIIfE8EORzUmS0wDQYJKoZIhvcNAQEFBQAwRDELMAkGA1UE +BhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVz +dCBOZXR3b3JraW5nMB4XDTEwMDEyOTE0MDgyNFoXDTMwMTIzMTE0MDgyNFowRDEL +MAkGA1UEBhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZp +cm1UcnVzdCBOZXR3b3JraW5nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKC +AQEAtITMMxcua5Rsa2FSoOujz3mUTOWUgJnLVWREZY9nZOIG41w3SfYvm4SEHi3y +YJ0wTsyEheIszx6e/jarM3c1RNg1lho9Nuh6DtjVR6FqaYvZ/Ls6rnla1fTWcbua +kCNrmreIdIcMHl+5ni36q1Mr3Lt2PpNMCAiMHqIjHNRqrSK6mQEubWXLviRmVSRL +QESxG9fhwoXA3hA/Pe24/PHxI1Pcv2WXb9n5QHGNfb2V1M6+oF4nI979ptAmDgAp +6zxG8D1gvz9Q0twmQVGeFDdCBKNwV6gbh+0t+nvujArjqWaJGctB+d1ENmHP4ndG +yH329JKBNv3bNPFyfvMMFr20FQIDAQABo0IwQDAdBgNVHQ4EFgQUBx/S55zawm6i +QLSwelAQUHTEyL0wDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwDQYJ +KoZIhvcNAQEFBQADggEBAIlXshZ6qML91tmbmzTCnLQyFE2npN/svqe++EPbkTfO +tDIuUFUaNU52Q3Eg75N3ThVwLofDwR1t3Mu1J9QsVtFSUzpE0nPIxBsFZVpikpzu +QY0x2+c06lkh1QF612S4ZDnNye2v7UsDSKegmQGA3GWjNq5lWUhPgkvIZfFXHeVZ +Lgo/bNjR9eUJtGxUAArgFU2HdW23WJZa3W3SAKD0m0i+wzekujbgfIeFlxoVot4u +olu9rxj5kFDNcFn4J2dHy8egBzp90SxdbBk6ZrV9/ZFvgrG+CJPbFEfxojfHRZ48 +x3evZKiT3/Zpg4Jg8klCNO1aAFSFHBY2kgxc+qatv9s= +-----END CERTIFICATE----- + +# Issuer: CN=AffirmTrust Premium O=AffirmTrust +# Subject: CN=AffirmTrust Premium O=AffirmTrust +# Label: "AffirmTrust Premium" +# Serial: 7893706540734352110 +# MD5 Fingerprint: c4:5d:0e:48:b6:ac:28:30:4e:0a:bc:f9:38:16:87:57 +# SHA1 Fingerprint: d8:a6:33:2c:e0:03:6f:b1:85:f6:63:4f:7d:6a:06:65:26:32:28:27 +# SHA256 Fingerprint: 70:a7:3f:7f:37:6b:60:07:42:48:90:45:34:b1:14:82:d5:bf:0e:69:8e:cc:49:8d:f5:25:77:eb:f2:e9:3b:9a +-----BEGIN CERTIFICATE----- +MIIFRjCCAy6gAwIBAgIIbYwURrGmCu4wDQYJKoZIhvcNAQEMBQAwQTELMAkGA1UE +BhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MRwwGgYDVQQDDBNBZmZpcm1UcnVz +dCBQcmVtaXVtMB4XDTEwMDEyOTE0MTAzNloXDTQwMTIzMTE0MTAzNlowQTELMAkG +A1UEBhMCVVMxFDASBgNVBAoMC0FmZmlybVRydXN0MRwwGgYDVQQDDBNBZmZpcm1U +cnVzdCBQcmVtaXVtMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAxBLf +qV/+Qd3d9Z+K4/as4Tx4mrzY8H96oDMq3I0gW64tb+eT2TZwamjPjlGjhVtnBKAQ +JG9dKILBl1fYSCkTtuG+kU3fhQxTGJoeJKJPj/CihQvL9Cl/0qRY7iZNyaqoe5rZ ++jjeRFcV5fiMyNlI4g0WJx0eyIOFJbe6qlVBzAMiSy2RjYvmia9mx+n/K+k8rNrS +s8PhaJyJ+HoAVt70VZVs+7pk3WKL3wt3MutizCaam7uqYoNMtAZ6MMgpv+0GTZe5 +HMQxK9VfvFMSF5yZVylmd2EhMQcuJUmdGPLu8ytxjLW6OQdJd/zvLpKQBY0tL3d7 +70O/Nbua2Plzpyzy0FfuKE4mX4+QaAkvuPjcBukumj5Rp9EixAqnOEhss/n/fauG +V+O61oV4d7pD6kh/9ti+I20ev9E2bFhc8e6kGVQa9QPSdubhjL08s9NIS+LI+H+S +qHZGnEJlPqQewQcDWkYtuJfzt9WyVSHvutxMAJf7FJUnM7/oQ0dG0giZFmA7mn7S +5u046uwBHjxIVkkJx0w3AJ6IDsBz4W9m6XJHMD4Q5QsDyZpCAGzFlH5hxIrff4Ia +C1nEWTJ3s7xgaVY5/bQGeyzWZDbZvUjthB9+pSKPKrhC9IK31FOQeE4tGv2Bb0TX +OwF0lkLgAOIua+rF7nKsu7/+6qqo+Nz2snmKtmcCAwEAAaNCMEAwHQYDVR0OBBYE +FJ3AZ6YMItkm9UWrpmVSESfYRaxjMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/ +BAQDAgEGMA0GCSqGSIb3DQEBDAUAA4ICAQCzV00QYk465KzquByvMiPIs0laUZx2 +KI15qldGF9X1Uva3ROgIRL8YhNILgM3FEv0AVQVhh0HctSSePMTYyPtwni94loMg +Nt58D2kTiKV1NpgIpsbfrM7jWNa3Pt668+s0QNiigfV4Py/VpfzZotReBA4Xrf5B +8OWycvpEgjNC6C1Y91aMYj+6QrCcDFx+LmUmXFNPALJ4fqENmS2NuB2OosSw/WDQ +MKSOyARiqcTtNd56l+0OOF6SL5Nwpamcb6d9Ex1+xghIsV5n61EIJenmJWtSKZGc +0jlzCFfemQa0W50QBuHCAKi4HEoCChTQwUHK+4w1IX2COPKpVJEZNZOUbWo6xbLQ +u4mGk+ibyQ86p3q4ofB4Rvr8Ny/lioTz3/4E2aFooC8k4gmVBtWVyuEklut89pMF +u+1z6S3RdTnX5yTb2E5fQ4+e0BQ5v1VwSJlXMbSc7kqYA5YwH2AG7hsj/oFgIxpH +YoWlzBk0gG+zrBrjn/B7SK3VAdlntqlyk+otZrWyuOQ9PLLvTIzq6we/qzWaVYa8 +GKa1qF60g2xraUDTn9zxw2lrueFtCfTxqlB2Cnp9ehehVZZCmTEJ3WARjQUwfuaO +RtGdFNrHF+QFlozEJLUbzxQHskD4o55BhrwE0GuWyCqANP2/7waj3VjFhT0+j/6e +KeC2uAloGRwYQw== +-----END CERTIFICATE----- + +# Issuer: CN=AffirmTrust Premium ECC O=AffirmTrust +# Subject: CN=AffirmTrust Premium ECC O=AffirmTrust +# Label: "AffirmTrust Premium ECC" +# Serial: 8401224907861490260 +# MD5 Fingerprint: 64:b0:09:55:cf:b1:d5:99:e2:be:13:ab:a6:5d:ea:4d +# SHA1 Fingerprint: b8:23:6b:00:2f:1d:16:86:53:01:55:6c:11:a4:37:ca:eb:ff:c3:bb +# SHA256 Fingerprint: bd:71:fd:f6:da:97:e4:cf:62:d1:64:7a:dd:25:81:b0:7d:79:ad:f8:39:7e:b4:ec:ba:9c:5e:84:88:82:14:23 +-----BEGIN CERTIFICATE----- +MIIB/jCCAYWgAwIBAgIIdJclisc/elQwCgYIKoZIzj0EAwMwRTELMAkGA1UEBhMC +VVMxFDASBgNVBAoMC0FmZmlybVRydXN0MSAwHgYDVQQDDBdBZmZpcm1UcnVzdCBQ +cmVtaXVtIEVDQzAeFw0xMDAxMjkxNDIwMjRaFw00MDEyMzExNDIwMjRaMEUxCzAJ +BgNVBAYTAlVTMRQwEgYDVQQKDAtBZmZpcm1UcnVzdDEgMB4GA1UEAwwXQWZmaXJt +VHJ1c3QgUHJlbWl1bSBFQ0MwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQNMF4bFZ0D +0KF5Nbc6PJJ6yhUczWLznCZcBz3lVPqj1swS6vQUX+iOGasvLkjmrBhDeKzQN8O9 +ss0s5kfiGuZjuD0uL3jET9v0D6RoTFVya5UdThhClXjMNzyR4ptlKymjQjBAMB0G +A1UdDgQWBBSaryl6wBE1NSZRMADDav5A1a7WPDAPBgNVHRMBAf8EBTADAQH/MA4G +A1UdDwEB/wQEAwIBBjAKBggqhkjOPQQDAwNnADBkAjAXCfOHiFBar8jAQr9HX/Vs +aobgxCd05DhT1wV/GzTjxi+zygk8N53X57hG8f2h4nECMEJZh0PUUd+60wkyWs6I +flc9nF9Ca/UHLbXwgpP5WW+uZPpY5Yse42O+tYHNbwKMeQ== +-----END CERTIFICATE----- + +# Issuer: CN=Certum Trusted Network CA O=Unizeto Technologies S.A. OU=Certum Certification Authority +# Subject: CN=Certum Trusted Network CA O=Unizeto Technologies S.A. OU=Certum Certification Authority +# Label: "Certum Trusted Network CA" +# Serial: 279744 +# MD5 Fingerprint: d5:e9:81:40:c5:18:69:fc:46:2c:89:75:62:0f:aa:78 +# SHA1 Fingerprint: 07:e0:32:e0:20:b7:2c:3f:19:2f:06:28:a2:59:3a:19:a7:0f:06:9e +# SHA256 Fingerprint: 5c:58:46:8d:55:f5:8e:49:7e:74:39:82:d2:b5:00:10:b6:d1:65:37:4a:cf:83:a7:d4:a3:2d:b7:68:c4:40:8e +-----BEGIN CERTIFICATE----- +MIIDuzCCAqOgAwIBAgIDBETAMA0GCSqGSIb3DQEBBQUAMH4xCzAJBgNVBAYTAlBM +MSIwIAYDVQQKExlVbml6ZXRvIFRlY2hub2xvZ2llcyBTLkEuMScwJQYDVQQLEx5D +ZXJ0dW0gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkxIjAgBgNVBAMTGUNlcnR1bSBU +cnVzdGVkIE5ldHdvcmsgQ0EwHhcNMDgxMDIyMTIwNzM3WhcNMjkxMjMxMTIwNzM3 +WjB+MQswCQYDVQQGEwJQTDEiMCAGA1UEChMZVW5pemV0byBUZWNobm9sb2dpZXMg +Uy5BLjEnMCUGA1UECxMeQ2VydHVtIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MSIw +IAYDVQQDExlDZXJ0dW0gVHJ1c3RlZCBOZXR3b3JrIENBMIIBIjANBgkqhkiG9w0B +AQEFAAOCAQ8AMIIBCgKCAQEA4/t9o3K6wvDJFIf1awFO4W5AB7ptJ11/91sts1rH +UV+rpDKmYYe2bg+G0jACl/jXaVehGDldamR5xgFZrDwxSjh80gTSSyjoIF87B6LM +TXPb865Px1bVWqeWifrzq2jUI4ZZJ88JJ7ysbnKDHDBy3+Ci6dLhdHUZvSqeexVU +BBvXQzmtVSjF4hq79MDkrjhJM8x2hZ85RdKknvISjFH4fOQtf/WsX+sWn7Et0brM +kUJ3TCXJkDhv2/DM+44el1k+1WBO5gUo7Ul5E0u6SNsv+XLTOcr+H9g0cvW0QM8x +AcPs3hEtF10fuFDRXhmnad4HMyjKUJX5p1TLVIZQRan5SQIDAQABo0IwQDAPBgNV +HRMBAf8EBTADAQH/MB0GA1UdDgQWBBQIds3LB/8k9sXN7buQvOKEN0Z19zAOBgNV +HQ8BAf8EBAMCAQYwDQYJKoZIhvcNAQEFBQADggEBAKaorSLOAT2mo/9i0Eidi15y +sHhE49wcrwn9I0j6vSrEuVUEtRCjjSfeC4Jj0O7eDDd5QVsisrCaQVymcODU0HfL +I9MA4GxWL+FpDQ3Zqr8hgVDZBqWo/5U30Kr+4rP1mS1FhIrlQgnXdAIv94nYmem8 +J9RHjboNRhx3zxSkHLmkMcScKHQDNP8zGSal6Q10tz6XxnboJ5ajZt3hrvJBW8qY +VoNzcOSGGtIxQbovvi0TWnZvTuhOgQ4/WwMioBK+ZlgRSssDxLQqKi2WF+A5VLxI +03YnnZotBqbJ7DnSq9ufmgsnAjUpsUCV5/nonFWIGUbWtzT1fs45mtk48VH3Tyw= +-----END CERTIFICATE----- + +# Issuer: CN=TWCA Root Certification Authority O=TAIWAN-CA OU=Root CA +# Subject: CN=TWCA Root Certification Authority O=TAIWAN-CA OU=Root CA +# Label: "TWCA Root Certification Authority" +# Serial: 1 +# MD5 Fingerprint: aa:08:8f:f6:f9:7b:b7:f2:b1:a7:1e:9b:ea:ea:bd:79 +# SHA1 Fingerprint: cf:9e:87:6d:d3:eb:fc:42:26:97:a3:b5:a3:7a:a0:76:a9:06:23:48 +# SHA256 Fingerprint: bf:d8:8f:e1:10:1c:41:ae:3e:80:1b:f8:be:56:35:0e:e9:ba:d1:a6:b9:bd:51:5e:dc:5c:6d:5b:87:11:ac:44 +-----BEGIN CERTIFICATE----- +MIIDezCCAmOgAwIBAgIBATANBgkqhkiG9w0BAQUFADBfMQswCQYDVQQGEwJUVzES +MBAGA1UECgwJVEFJV0FOLUNBMRAwDgYDVQQLDAdSb290IENBMSowKAYDVQQDDCFU +V0NBIFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDgwODI4MDcyNDMz +WhcNMzAxMjMxMTU1OTU5WjBfMQswCQYDVQQGEwJUVzESMBAGA1UECgwJVEFJV0FO +LUNBMRAwDgYDVQQLDAdSb290IENBMSowKAYDVQQDDCFUV0NBIFJvb3QgQ2VydGlm +aWNhdGlvbiBBdXRob3JpdHkwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB +AQCwfnK4pAOU5qfeCTiRShFAh6d8WWQUe7UREN3+v9XAu1bihSX0NXIP+FPQQeFE +AcK0HMMxQhZHhTMidrIKbw/lJVBPhYa+v5guEGcevhEFhgWQxFnQfHgQsIBct+HH +K3XLfJ+utdGdIzdjp9xCoi2SBBtQwXu4PhvJVgSLL1KbralW6cH/ralYhzC2gfeX +RfwZVzsrb+RH9JlF/h3x+JejiB03HFyP4HYlmlD4oFT/RJB2I9IyxsOrBr/8+7/z +rX2SYgJbKdM1o5OaQ2RgXbL6Mv87BK9NQGr5x+PvI/1ry+UPizgN7gr8/g+YnzAx +3WxSZfmLgb4i4RxYA7qRG4kHAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNV +HRMBAf8EBTADAQH/MB0GA1UdDgQWBBRqOFsmjd6LWvJPelSDGRjjCDWmujANBgkq +hkiG9w0BAQUFAAOCAQEAPNV3PdrfibqHDAhUaiBQkr6wQT25JmSDCi/oQMCXKCeC +MErJk/9q56YAf4lCmtYR5VPOL8zy2gXE/uJQxDqGfczafhAJO5I1KlOy/usrBdls +XebQ79NqZp4VKIV66IIArB6nCWlWQtNoURi+VJq/REG6Sb4gumlc7rh3zc5sH62D +lhh9DrUUOYTxKOkto557HnpyWoOzeW/vtPzQCqVYT0bf+215WfKEIlKuD8z7fDvn +aspHYcN6+NOSBB+4IIThNlQWx0DeO4pz3N/GCUzf7Nr/1FNCocnyYh0igzyXxfkZ +YiesZSLX0zzG5Y6yU8xJzrww/nsOM5D77dIUkR8Hrw== +-----END CERTIFICATE----- + +# Issuer: O=SECOM Trust Systems CO.,LTD. OU=Security Communication RootCA2 +# Subject: O=SECOM Trust Systems CO.,LTD. OU=Security Communication RootCA2 +# Label: "Security Communication RootCA2" +# Serial: 0 +# MD5 Fingerprint: 6c:39:7d:a4:0e:55:59:b2:3f:d6:41:b1:12:50:de:43 +# SHA1 Fingerprint: 5f:3b:8c:f2:f8:10:b3:7d:78:b4:ce:ec:19:19:c3:73:34:b9:c7:74 +# SHA256 Fingerprint: 51:3b:2c:ec:b8:10:d4:cd:e5:dd:85:39:1a:df:c6:c2:dd:60:d8:7b:b7:36:d2:b5:21:48:4a:a4:7a:0e:be:f6 +-----BEGIN CERTIFICATE----- +MIIDdzCCAl+gAwIBAgIBADANBgkqhkiG9w0BAQsFADBdMQswCQYDVQQGEwJKUDEl +MCMGA1UEChMcU0VDT00gVHJ1c3QgU3lzdGVtcyBDTy4sTFRELjEnMCUGA1UECxMe +U2VjdXJpdHkgQ29tbXVuaWNhdGlvbiBSb290Q0EyMB4XDTA5MDUyOTA1MDAzOVoX +DTI5MDUyOTA1MDAzOVowXTELMAkGA1UEBhMCSlAxJTAjBgNVBAoTHFNFQ09NIFRy +dXN0IFN5c3RlbXMgQ08uLExURC4xJzAlBgNVBAsTHlNlY3VyaXR5IENvbW11bmlj +YXRpb24gUm9vdENBMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANAV +OVKxUrO6xVmCxF1SrjpDZYBLx/KWvNs2l9amZIyoXvDjChz335c9S672XewhtUGr +zbl+dp+++T42NKA7wfYxEUV0kz1XgMX5iZnK5atq1LXaQZAQwdbWQonCv/Q4EpVM +VAX3NuRFg3sUZdbcDE3R3n4MqzvEFb46VqZab3ZpUql6ucjrappdUtAtCms1FgkQ +hNBqyjoGADdH5H5XTz+L62e4iKrFvlNVspHEfbmwhRkGeC7bYRr6hfVKkaHnFtWO +ojnflLhwHyg/i/xAXmODPIMqGplrz95Zajv8bxbXH/1KEOtOghY6rCcMU/Gt1SSw +awNQwS08Ft1ENCcadfsCAwEAAaNCMEAwHQYDVR0OBBYEFAqFqXdlBZh8QIH4D5cs +OPEK7DzPMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MA0GCSqGSIb3 +DQEBCwUAA4IBAQBMOqNErLlFsceTfsgLCkLfZOoc7llsCLqJX2rKSpWeeo8HxdpF +coJxDjrSzG+ntKEju/Ykn8sX/oymzsLS28yN/HH8AynBbF0zX2S2ZTuJbxh2ePXc +okgfGT+Ok+vx+hfuzU7jBBJV1uXk3fs+BXziHV7Gp7yXT2g69ekuCkO2r1dcYmh8 +t/2jioSgrGK+KwmHNPBqAbubKVY8/gA3zyNs8U6qtnRGEmyR7jTV7JqR50S+kDFy +1UkC9gLl9B/rfNmWVan/7Ir5mUf/NVoCqgTLiluHcSmRvaS0eg29mvVXIwAHIRc/ +SjnRBUkLp7Y3gaVdjKozXoEofKd9J+sAro03 +-----END CERTIFICATE----- + +# Issuer: CN=Actalis Authentication Root CA O=Actalis S.p.A./03358520967 +# Subject: CN=Actalis Authentication Root CA O=Actalis S.p.A./03358520967 +# Label: "Actalis Authentication Root CA" +# Serial: 6271844772424770508 +# MD5 Fingerprint: 69:c1:0d:4f:07:a3:1b:c3:fe:56:3d:04:bc:11:f6:a6 +# SHA1 Fingerprint: f3:73:b3:87:06:5a:28:84:8a:f2:f3:4a:ce:19:2b:dd:c7:8e:9c:ac +# SHA256 Fingerprint: 55:92:60:84:ec:96:3a:64:b9:6e:2a:be:01:ce:0b:a8:6a:64:fb:fe:bc:c7:aa:b5:af:c1:55:b3:7f:d7:60:66 +-----BEGIN CERTIFICATE----- +MIIFuzCCA6OgAwIBAgIIVwoRl0LE48wwDQYJKoZIhvcNAQELBQAwazELMAkGA1UE +BhMCSVQxDjAMBgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlzIFMucC5BLi8w +MzM1ODUyMDk2NzEnMCUGA1UEAwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290 +IENBMB4XDTExMDkyMjExMjIwMloXDTMwMDkyMjExMjIwMlowazELMAkGA1UEBhMC +SVQxDjAMBgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlzIFMucC5BLi8wMzM1 +ODUyMDk2NzEnMCUGA1UEAwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290IENB +MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAp8bEpSmkLO/lGMWwUKNv +UTufClrJwkg4CsIcoBh/kbWHuUA/3R1oHwiD1S0eiKD4j1aPbZkCkpAW1V8IbInX +4ay8IMKx4INRimlNAJZaby/ARH6jDuSRzVju3PvHHkVH3Se5CAGfpiEd9UEtL0z9 +KK3giq0itFZljoZUj5NDKd45RnijMCO6zfB9E1fAXdKDa0hMxKufgFpbOr3JpyI/ +gCczWw63igxdBzcIy2zSekciRDXFzMwujt0q7bd9Zg1fYVEiVRvjRuPjPdA1Yprb +rxTIW6HMiRvhMCb8oJsfgadHHwTrozmSBp+Z07/T6k9QnBn+locePGX2oxgkg4YQ +51Q+qDp2JE+BIcXjDwL4k5RHILv+1A7TaLndxHqEguNTVHnd25zS8gebLra8Pu2F +be8lEfKXGkJh90qX6IuxEAf6ZYGyojnP9zz/GPvG8VqLWeICrHuS0E4UT1lF9gxe +KF+w6D9Fz8+vm2/7hNN3WpVvrJSEnu68wEqPSpP4RCHiMUVhUE4Q2OM1fEwZtN4F +v6MGn8i1zeQf1xcGDXqVdFUNaBr8EBtiZJ1t4JWgw5QHVw0U5r0F+7if5t+L4sbn +fpb2U8WANFAoWPASUHEXMLrmeGO89LKtmyuy/uE5jF66CyCU3nuDuP/jVo23Eek7 +jPKxwV2dpAtMK9myGPW1n0sCAwEAAaNjMGEwHQYDVR0OBBYEFFLYiDrIn3hm7Ynz +ezhwlMkCAjbQMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUUtiIOsifeGbt +ifN7OHCUyQICNtAwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEBCwUAA4ICAQAL +e3KHwGCmSUyIWOYdiPcUZEim2FgKDk8TNd81HdTtBjHIgT5q1d07GjLukD0R0i70 +jsNjLiNmsGe+b7bAEzlgqqI0JZN1Ut6nna0Oh4lScWoWPBkdg/iaKWW+9D+a2fDz +WochcYBNy+A4mz+7+uAwTc+G02UQGRjRlwKxK3JCaKygvU5a2hi/a5iB0P2avl4V +SM0RFbnAKVy06Ij3Pjaut2L9HmLecHgQHEhb2rykOLpn7VU+Xlff1ANATIGk0k9j +pwlCCRT8AKnCgHNPLsBA2RF7SOp6AsDT6ygBJlh0wcBzIm2Tlf05fbsq4/aC4yyX +X04fkZT6/iyj2HYauE2yOE+b+h1IYHkm4vP9qdCa6HCPSXrW5b0KDtst842/6+Ok +fcvHlXHo2qN8xcL4dJIEG4aspCJTQLas/kx2z/uUMsA1n3Y/buWQbqCmJqK4LL7R +K4X9p2jIugErsWx0Hbhzlefut8cl8ABMALJ+tguLHPPAUJ4lueAI3jZm/zel0btU +ZCzJJ7VLkn5l/9Mt4blOvH+kQSGQQXemOR/qnuOf0GZvBeyqdn6/axag67XH/JJU +LysRJyU3eExRarDzzFhdFPFqSBX/wge2sY0PjlxQRrM9vwGYT7JZVEc+NHt4bVaT +LnPqZih4zR0Uv6CPLy64Lo7yFIrM6bV8+2ydDKXhlg== +-----END CERTIFICATE----- + +# Issuer: CN=Buypass Class 2 Root CA O=Buypass AS-983163327 +# Subject: CN=Buypass Class 2 Root CA O=Buypass AS-983163327 +# Label: "Buypass Class 2 Root CA" +# Serial: 2 +# MD5 Fingerprint: 46:a7:d2:fe:45:fb:64:5a:a8:59:90:9b:78:44:9b:29 +# SHA1 Fingerprint: 49:0a:75:74:de:87:0a:47:fe:58:ee:f6:c7:6b:eb:c6:0b:12:40:99 +# SHA256 Fingerprint: 9a:11:40:25:19:7c:5b:b9:5d:94:e6:3d:55:cd:43:79:08:47:b6:46:b2:3c:df:11:ad:a4:a0:0e:ff:15:fb:48 +-----BEGIN CERTIFICATE----- +MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEd +MBsGA1UECgwUQnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3Mg +Q2xhc3MgMiBSb290IENBMB4XDTEwMTAyNjA4MzgwM1oXDTQwMTAyNjA4MzgwM1ow +TjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1eXBhc3MgQVMtOTgzMTYzMzI3MSAw +HgYDVQQDDBdCdXlwYXNzIENsYXNzIDIgUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEB +BQADggIPADCCAgoCggIBANfHXvfBB9R3+0Mh9PT1aeTuMgHbo4Yf5FkNuud1g1Lr +6hxhFUi7HQfKjK6w3Jad6sNgkoaCKHOcVgb/S2TwDCo3SbXlzwx87vFKu3MwZfPV +L4O2fuPn9Z6rYPnT8Z2SdIrkHJasW4DptfQxh6NR/Md+oW+OU3fUl8FVM5I+GC91 +1K2GScuVr1QGbNgGE41b/+EmGVnAJLqBcXmQRFBoJJRfuLMR8SlBYaNByyM21cHx +MlAQTn/0hpPshNOOvEu/XAFOBz3cFIqUCqTqc/sLUegTBxj6DvEr0VQVfTzh97QZ +QmdiXnfgolXsttlpF9U6r0TtSsWe5HonfOV116rLJeffawrbD02TTqigzXsu8lkB +arcNuAeBfos4GzjmCleZPe4h6KP1DBbdi+w0jpwqHAAVF41og9JwnxgIzRFo1clr +Us3ERo/ctfPYV3Me6ZQ5BL/T3jjetFPsaRyifsSP5BtwrfKi+fv3FmRmaZ9JUaLi +FRhnBkp/1Wy1TbMz4GHrXb7pmA8y1x1LPC5aAVKRCfLf6o3YBkBjqhHk/sM3nhRS +P/TizPJhk9H9Z2vXUq6/aKtAQ6BXNVN48FP4YUIHZMbXb5tMOA1jrGKvNouicwoN +9SG9dKpN6nIDSdvHXx1iY8f93ZHsM+71bbRuMGjeyNYmsHVee7QHIJihdjK4TWxP +AgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFMmAd+BikoL1Rpzz +uvdMw964o605MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAU18h +9bqwOlI5LJKwbADJ784g7wbylp7ppHR/ehb8t/W2+xUbP6umwHJdELFx7rxP462s +A20ucS6vxOOto70MEae0/0qyexAQH6dXQbLArvQsWdZHEIjzIVEpMMpghq9Gqx3t +OluwlN5E40EIosHsHdb9T7bWR9AUC8rmyrV7d35BH16Dx7aMOZawP5aBQW9gkOLo ++fsicdl9sz1Gv7SEr5AcD48Saq/v7h56rgJKihcrdv6sVIkkLE8/trKnToyokZf7 +KcZ7XC25y2a2t6hbElGFtQl+Ynhw/qlqYLYdDnkM/crqJIByw5c/8nerQyIKx+u2 +DISCLIBrQYoIwOula9+ZEsuK1V6ADJHgJgg2SMX6OBE1/yWDLfJ6v9r9jv6ly0Us +H8SIU653DtmadsWOLB2jutXsMq7Aqqz30XpN69QH4kj3Io6wpJ9qzo6ysmD0oyLQ +I+uUWnpp3Q+/QFesa1lQ2aOZ4W7+jQF5JyMV3pKdewlNWudLSDBaGOYKbeaP4NK7 +5t98biGCwWg5TbSYWGZizEqQXsP6JwSxeRV0mcy+rSDeJmAc61ZRpqPq5KM/p/9h +3PFaTWwyI0PurKju7koSCTxdccK+efrCh2gdC/1cacwG0Jp9VJkqyTkaGa9LKkPz +Y11aWOIv4x3kqdbQCtCev9eBCfHJxyYNrJgWVqA= +-----END CERTIFICATE----- + +# Issuer: CN=Buypass Class 3 Root CA O=Buypass AS-983163327 +# Subject: CN=Buypass Class 3 Root CA O=Buypass AS-983163327 +# Label: "Buypass Class 3 Root CA" +# Serial: 2 +# MD5 Fingerprint: 3d:3b:18:9e:2c:64:5a:e8:d5:88:ce:0e:f9:37:c2:ec +# SHA1 Fingerprint: da:fa:f7:fa:66:84:ec:06:8f:14:50:bd:c7:c2:81:a5:bc:a9:64:57 +# SHA256 Fingerprint: ed:f7:eb:bc:a2:7a:2a:38:4d:38:7b:7d:40:10:c6:66:e2:ed:b4:84:3e:4c:29:b4:ae:1d:5b:93:32:e6:b2:4d +-----BEGIN CERTIFICATE----- +MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEd +MBsGA1UECgwUQnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3Mg +Q2xhc3MgMyBSb290IENBMB4XDTEwMTAyNjA4Mjg1OFoXDTQwMTAyNjA4Mjg1OFow +TjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1eXBhc3MgQVMtOTgzMTYzMzI3MSAw +HgYDVQQDDBdCdXlwYXNzIENsYXNzIDMgUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEB +BQADggIPADCCAgoCggIBAKXaCpUWUOOV8l6ddjEGMnqb8RB2uACatVI2zSRHsJ8Y +ZLya9vrVediQYkwiL944PdbgqOkcLNt4EemOaFEVcsfzM4fkoF0LXOBXByow9c3E +N3coTRiR5r/VUv1xLXA+58bEiuPwKAv0dpihi4dVsjoT/Lc+JzeOIuOoTyrvYLs9 +tznDDgFHmV0ST9tD+leh7fmdvhFHJlsTmKtdFoqwNxxXnUX/iJY2v7vKB3tvh2PX +0DJq1l1sDPGzbjniazEuOQAnFN44wOwZZoYS6J1yFhNkUsepNxz9gjDthBgd9K5c +/3ATAOux9TN6S9ZV+AWNS2mw9bMoNlwUxFFzTWsL8TQH2xc519woe2v1n/MuwU8X +KhDzzMro6/1rqy6any2CbgTUUgGTLT2G/H783+9CHaZr77kgxve9oKeV/afmiSTY +zIw0bOIjL9kSGiG5VZFvC5F5GQytQIgLcOJ60g7YaEi7ghM5EFjp2CoHxhLbWNvS +O1UQRwUVZ2J+GGOmRj8JDlQyXr8NYnon74Do29lLBlo3WiXQCBJ31G8JUJc9yB3D +34xFMFbG02SrZvPAXpacw8Tvw3xrizp5f7NJzz3iiZ+gMEuFuZyUJHmPfWupRWgP +K9Dx2hzLabjKSWJtyNBjYt1gD1iqj6G8BaVmos8bdrKEZLFMOVLAMLrwjEsCsLa3 +AgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFEe4zf/lb+74suwv +Tg75JbCOPGvDMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAACAj +QTUEkMJAYmDv4jVM1z+s4jSQuKFvdvoWFqRINyzpkMLyPPgKn9iB5btb2iUspKdV +cSQy9sgL8rxq+JOssgfCX5/bzMiKqr5qb+FJEMwx14C7u8jYog5kV+qi9cKpMRXS +IGrs/CIBKM+GuIAeqcwRpTzyFrNHnfzSgCHEy9BHcEGhyoMZCCxt8l13nIoUE9Q2 +HJLw5QY33KbmkJs4j1xrG0aGQ0JfPgEHU1RdZX33inOhmlRaHylDFCfChQ+1iHsa +O5S3HWCntZznKWlXWpuTekMwGwPXYshApqr8ZORK15FTAaggiG6cX0S5y2CBNOxv +033aSF/rtJC8LakcC6wc1aJoIIAE1vyxjy+7SjENSoYc6+I2KSb12tjE8nVhz36u +dmNKekBlk4f4HoCMhuWG1o8O/FMsYOgWYRqiPkN7zTlgVGr18okmAWiDSKIz6MkE +kbIRNBE+6tBDGR8Dk5AM/1E9V/RBbuHLoL7ryWPNbczk+DaqaJ3tvV2XcEQNtg41 +3OEMXbugUZTLfhbrES+jkkXITHHZvMmZUldGL1DPvTVp9D0VzgalLA8+9oG6lLvD +u79leNKGef9JOxqDDPDeeOzI8k1MGt6CKfjBWtrt7uYnXuhF0J0cUahoq0Tj0Itq +4/g7u9xN12TyUb7mqqta6THuBrxzvxNiCp/HuZc= +-----END CERTIFICATE----- + +# Issuer: CN=T-TeleSec GlobalRoot Class 3 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center +# Subject: CN=T-TeleSec GlobalRoot Class 3 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center +# Label: "T-TeleSec GlobalRoot Class 3" +# Serial: 1 +# MD5 Fingerprint: ca:fb:40:a8:4e:39:92:8a:1d:fe:8e:2f:c4:27:ea:ef +# SHA1 Fingerprint: 55:a6:72:3e:cb:f2:ec:cd:c3:23:74:70:19:9d:2a:be:11:e3:81:d1 +# SHA256 Fingerprint: fd:73:da:d3:1c:64:4f:f1:b4:3b:ef:0c:cd:da:96:71:0b:9c:d9:87:5e:ca:7e:31:70:7a:f3:e9:6d:52:2b:bd +-----BEGIN CERTIFICATE----- +MIIDwzCCAqugAwIBAgIBATANBgkqhkiG9w0BAQsFADCBgjELMAkGA1UEBhMCREUx +KzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAd +BgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNl +YyBHbG9iYWxSb290IENsYXNzIDMwHhcNMDgxMDAxMTAyOTU2WhcNMzMxMDAxMjM1 +OTU5WjCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnBy +aXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50 +ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDMwggEiMA0G +CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC9dZPwYiJvJK7genasfb3ZJNW4t/zN +8ELg63iIVl6bmlQdTQyK9tPPcPRStdiTBONGhnFBSivwKixVA9ZIw+A5OO3yXDw/ +RLyTPWGrTs0NvvAgJ1gORH8EGoel15YUNpDQSXuhdfsaa3Ox+M6pCSzyU9XDFES4 +hqX2iys52qMzVNn6chr3IhUciJFrf2blw2qAsCTz34ZFiP0Zf3WHHx+xGwpzJFu5 +ZeAsVMhg02YXP+HMVDNzkQI6pn97djmiH5a2OK61yJN0HZ65tOVgnS9W0eDrXltM +EnAMbEQgqxHY9Bn20pxSN+f6tsIxO0rUFJmtxxr1XV/6B7h8DR/Wgx6zAgMBAAGj +QjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBS1 +A/d2O2GCahKqGFPrAyGUv/7OyjANBgkqhkiG9w0BAQsFAAOCAQEAVj3vlNW92nOy +WL6ukK2YJ5f+AbGwUgC4TeQbIXQbfsDuXmkqJa9c1h3a0nnJ85cp4IaH3gRZD/FZ +1GSFS5mvJQQeyUapl96Cshtwn5z2r3Ex3XsFpSzTucpH9sry9uetuUg/vBa3wW30 +6gmv7PO15wWeph6KU1HWk4HMdJP2udqmJQV0eVp+QD6CSyYRMG7hP0HHRwA11fXT +91Q+gT3aSWqas+8QPebrb9HIIkfLzM8BMZLZGOMivgkeGj5asuRrDFR6fUNOuIml +e9eiPZaGzPImNC1qkp2aGtAw4l1OBLBfiyB+d8E9lYLRRpo7PHi4b6HQDWSieB4p +TpPDpFQUWw== +-----END CERTIFICATE----- + +# Issuer: CN=D-TRUST Root Class 3 CA 2 2009 O=D-Trust GmbH +# Subject: CN=D-TRUST Root Class 3 CA 2 2009 O=D-Trust GmbH +# Label: "D-TRUST Root Class 3 CA 2 2009" +# Serial: 623603 +# MD5 Fingerprint: cd:e0:25:69:8d:47:ac:9c:89:35:90:f7:fd:51:3d:2f +# SHA1 Fingerprint: 58:e8:ab:b0:36:15:33:fb:80:f7:9b:1b:6d:29:d3:ff:8d:5f:00:f0 +# SHA256 Fingerprint: 49:e7:a4:42:ac:f0:ea:62:87:05:00:54:b5:25:64:b6:50:e4:f4:9e:42:e3:48:d6:aa:38:e0:39:e9:57:b1:c1 +-----BEGIN CERTIFICATE----- +MIIEMzCCAxugAwIBAgIDCYPzMA0GCSqGSIb3DQEBCwUAME0xCzAJBgNVBAYTAkRF +MRUwEwYDVQQKDAxELVRydXN0IEdtYkgxJzAlBgNVBAMMHkQtVFJVU1QgUm9vdCBD +bGFzcyAzIENBIDIgMjAwOTAeFw0wOTExMDUwODM1NThaFw0yOTExMDUwODM1NTha +ME0xCzAJBgNVBAYTAkRFMRUwEwYDVQQKDAxELVRydXN0IEdtYkgxJzAlBgNVBAMM +HkQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgMjAwOTCCASIwDQYJKoZIhvcNAQEB +BQADggEPADCCAQoCggEBANOySs96R+91myP6Oi/WUEWJNTrGa9v+2wBoqOADER03 +UAifTUpolDWzU9GUY6cgVq/eUXjsKj3zSEhQPgrfRlWLJ23DEE0NkVJD2IfgXU42 +tSHKXzlABF9bfsyjxiupQB7ZNoTWSPOSHjRGICTBpFGOShrvUD9pXRl/RcPHAY9R +ySPocq60vFYJfxLLHLGvKZAKyVXMD9O0Gu1HNVpK7ZxzBCHQqr0ME7UAyiZsxGsM +lFqVlNpQmvH/pStmMaTJOKDfHR+4CS7zp+hnUquVH+BGPtikw8paxTGA6Eian5Rp +/hnd2HN8gcqW3o7tszIFZYQ05ub9VxC1X3a/L7AQDcUCAwEAAaOCARowggEWMA8G +A1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFP3aFMSfMN4hvR5COfyrYyNJ4PGEMA4G +A1UdDwEB/wQEAwIBBjCB0wYDVR0fBIHLMIHIMIGAoH6gfIZ6bGRhcDovL2RpcmVj +dG9yeS5kLXRydXN0Lm5ldC9DTj1ELVRSVVNUJTIwUm9vdCUyMENsYXNzJTIwMyUy +MENBJTIwMiUyMDIwMDksTz1ELVRydXN0JTIwR21iSCxDPURFP2NlcnRpZmljYXRl +cmV2b2NhdGlvbmxpc3QwQ6BBoD+GPWh0dHA6Ly93d3cuZC10cnVzdC5uZXQvY3Js +L2QtdHJ1c3Rfcm9vdF9jbGFzc18zX2NhXzJfMjAwOS5jcmwwDQYJKoZIhvcNAQEL +BQADggEBAH+X2zDI36ScfSF6gHDOFBJpiBSVYEQBrLLpME+bUMJm2H6NMLVwMeni +acfzcNsgFYbQDfC+rAF1hM5+n02/t2A7nPPKHeJeaNijnZflQGDSNiH+0LS4F9p0 +o3/U37CYAqxva2ssJSRyoWXuJVrl5jLn8t+rSfrzkGkj2wTZ51xY/GXUl77M/C4K +zCUqNQT4YJEVdT1B/yMfGchs64JTBKbkTCJNjYy6zltz7GRUUG3RnFX7acM2w4y8 +PIWmawomDeCTmGCufsYkl4phX5GOZpIJhzbNi5stPvZR1FDUWSi9g/LMKHtThm3Y +Johw1+qRzT65ysCQblrGXnRl11z+o+I= +-----END CERTIFICATE----- + +# Issuer: CN=D-TRUST Root Class 3 CA 2 EV 2009 O=D-Trust GmbH +# Subject: CN=D-TRUST Root Class 3 CA 2 EV 2009 O=D-Trust GmbH +# Label: "D-TRUST Root Class 3 CA 2 EV 2009" +# Serial: 623604 +# MD5 Fingerprint: aa:c6:43:2c:5e:2d:cd:c4:34:c0:50:4f:11:02:4f:b6 +# SHA1 Fingerprint: 96:c9:1b:0b:95:b4:10:98:42:fa:d0:d8:22:79:fe:60:fa:b9:16:83 +# SHA256 Fingerprint: ee:c5:49:6b:98:8c:e9:86:25:b9:34:09:2e:ec:29:08:be:d0:b0:f3:16:c2:d4:73:0c:84:ea:f1:f3:d3:48:81 +-----BEGIN CERTIFICATE----- +MIIEQzCCAyugAwIBAgIDCYP0MA0GCSqGSIb3DQEBCwUAMFAxCzAJBgNVBAYTAkRF +MRUwEwYDVQQKDAxELVRydXN0IEdtYkgxKjAoBgNVBAMMIUQtVFJVU1QgUm9vdCBD +bGFzcyAzIENBIDIgRVYgMjAwOTAeFw0wOTExMDUwODUwNDZaFw0yOTExMDUwODUw +NDZaMFAxCzAJBgNVBAYTAkRFMRUwEwYDVQQKDAxELVRydXN0IEdtYkgxKjAoBgNV +BAMMIUQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgRVYgMjAwOTCCASIwDQYJKoZI +hvcNAQEBBQADggEPADCCAQoCggEBAJnxhDRwui+3MKCOvXwEz75ivJn9gpfSegpn +ljgJ9hBOlSJzmY3aFS3nBfwZcyK3jpgAvDw9rKFs+9Z5JUut8Mxk2og+KbgPCdM0 +3TP1YtHhzRnp7hhPTFiu4h7WDFsVWtg6uMQYZB7jM7K1iXdODL/ZlGsTl28So/6Z +qQTMFexgaDbtCHu39b+T7WYxg4zGcTSHThfqr4uRjRxWQa4iN1438h3Z0S0NL2lR +p75mpoo6Kr3HGrHhFPC+Oh25z1uxav60sUYgovseO3Dvk5h9jHOW8sXvhXCtKSb8 +HgQ+HKDYD8tSg2J87otTlZCpV6LqYQXY+U3EJ/pure3511H3a6UCAwEAAaOCASQw +ggEgMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFNOUikxiEyoZLsyvcop9Ntea +HNxnMA4GA1UdDwEB/wQEAwIBBjCB3QYDVR0fBIHVMIHSMIGHoIGEoIGBhn9sZGFw +Oi8vZGlyZWN0b3J5LmQtdHJ1c3QubmV0L0NOPUQtVFJVU1QlMjBSb290JTIwQ2xh +c3MlMjAzJTIwQ0ElMjAyJTIwRVYlMjAyMDA5LE89RC1UcnVzdCUyMEdtYkgsQz1E +RT9jZXJ0aWZpY2F0ZXJldm9jYXRpb25saXN0MEagRKBChkBodHRwOi8vd3d3LmQt +dHJ1c3QubmV0L2NybC9kLXRydXN0X3Jvb3RfY2xhc3NfM19jYV8yX2V2XzIwMDku +Y3JsMA0GCSqGSIb3DQEBCwUAA4IBAQA07XtaPKSUiO8aEXUHL7P+PPoeUSbrh/Yp +3uDx1MYkCenBz1UbtDDZzhr+BlGmFaQt77JLvyAoJUnRpjZ3NOhk31KxEcdzes05 +nsKtjHEh8lprr988TlWvsoRlFIm5d8sqMb7Po23Pb0iUMkZv53GMoKaEGTcH8gNF +CSuGdXzfX2lXANtu2KZyIktQ1HWYVt+3GP9DQ1CuekR78HlR10M9p9OB0/DJT7na +xpeG0ILD5EJt/rDiZE4OJudANCa1CInXCGNjOCd1HjPqbqjdn5lPdE2BiYBL3ZqX +KVwvvoFBuYz/6n1gBp7N1z3TLqMVvKjmJuVvw9y4AyHqnxbxLFS1 +-----END CERTIFICATE----- + +# Issuer: CN=CA Disig Root R2 O=Disig a.s. +# Subject: CN=CA Disig Root R2 O=Disig a.s. +# Label: "CA Disig Root R2" +# Serial: 10572350602393338211 +# MD5 Fingerprint: 26:01:fb:d8:27:a7:17:9a:45:54:38:1a:43:01:3b:03 +# SHA1 Fingerprint: b5:61:eb:ea:a4:de:e4:25:4b:69:1a:98:a5:57:47:c2:34:c7:d9:71 +# SHA256 Fingerprint: e2:3d:4a:03:6d:7b:70:e9:f5:95:b1:42:20:79:d2:b9:1e:df:bb:1f:b6:51:a0:63:3e:aa:8a:9d:c5:f8:07:03 +-----BEGIN CERTIFICATE----- +MIIFaTCCA1GgAwIBAgIJAJK4iNuwisFjMA0GCSqGSIb3DQEBCwUAMFIxCzAJBgNV +BAYTAlNLMRMwEQYDVQQHEwpCcmF0aXNsYXZhMRMwEQYDVQQKEwpEaXNpZyBhLnMu +MRkwFwYDVQQDExBDQSBEaXNpZyBSb290IFIyMB4XDTEyMDcxOTA5MTUzMFoXDTQy +MDcxOTA5MTUzMFowUjELMAkGA1UEBhMCU0sxEzARBgNVBAcTCkJyYXRpc2xhdmEx +EzARBgNVBAoTCkRpc2lnIGEucy4xGTAXBgNVBAMTEENBIERpc2lnIFJvb3QgUjIw +ggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCio8QACdaFXS1tFPbCw3Oe +NcJxVX6B+6tGUODBfEl45qt5WDza/3wcn9iXAng+a0EE6UG9vgMsRfYvZNSrXaNH +PWSb6WiaxswbP7q+sos0Ai6YVRn8jG+qX9pMzk0DIaPY0jSTVpbLTAwAFjxfGs3I +x2ymrdMxp7zo5eFm1tL7A7RBZckQrg4FY8aAamkw/dLukO8NJ9+flXP04SXabBbe +QTg06ov80egEFGEtQX6sx3dOy1FU+16SGBsEWmjGycT6txOgmLcRK7fWV8x8nhfR +yyX+hk4kLlYMeE2eARKmK6cBZW58Yh2EhN/qwGu1pSqVg8NTEQxzHQuyRpDRQjrO +QG6Vrf/GlK1ul4SOfW+eioANSW1z4nuSHsPzwfPrLgVv2RvPN3YEyLRa5Beny912 +H9AZdugsBbPWnDTYltxhh5EF5EQIM8HauQhl1K6yNg3ruji6DOWbnuuNZt2Zz9aJ +QfYEkoopKW1rOhzndX0CcQ7zwOe9yxndnWCywmZgtrEE7snmhrmaZkCo5xHtgUUD +i/ZnWejBBhG93c+AAk9lQHhcR1DIm+YfgXvkRKhbhZri3lrVx/k6RGZL5DJUfORs +nLMOPReisjQS1n6yqEm70XooQL6iFh/f5DcfEXP7kAplQ6INfPgGAVUzfbANuPT1 +rqVCV3w2EYx7XsQDnYx5nQIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1Ud +DwEB/wQEAwIBBjAdBgNVHQ4EFgQUtZn4r7CU9eMg1gqtzk5WpC5uQu0wDQYJKoZI +hvcNAQELBQADggIBACYGXnDnZTPIgm7ZnBc6G3pmsgH2eDtpXi/q/075KMOYKmFM +tCQSin1tERT3nLXK5ryeJ45MGcipvXrA1zYObYVybqjGom32+nNjf7xueQgcnYqf +GopTpti72TVVsRHFqQOzVju5hJMiXn7B9hJSi+osZ7z+Nkz1uM/Rs0mSO9MpDpkb +lvdhuDvEK7Z4bLQjb/D907JedR+Zlais9trhxTF7+9FGs9K8Z7RiVLoJ92Owk6Ka ++elSLotgEqv89WBW7xBci8QaQtyDW2QOy7W81k/BfDxujRNt+3vrMNDcTa/F1bal +TFtxyegxvug4BkihGuLq0t4SOVga/4AOgnXmt8kHbA7v/zjxmHHEt38OFdAlab0i +nSvtBfZGR6ztwPDUO+Ls7pZbkBNOHlY667DvlruWIxG68kOGdGSVyCh13x01utI3 +gzhTODY7z2zp+WsO0PsE6E9312UBeIYMej4hYvF/Y3EMyZ9E26gnonW+boE+18Dr +G5gPcFw0sorMwIUY6256s/daoQe/qUKS82Ail+QUoQebTnbAjn39pCXHR+3/H3Os +zMOl6W8KjptlwlCFtaOgUxLMVYdh84GuEEZhvUQhuMI9dM9+JDX6HAcOmz0iyu8x +L4ysEr3vQCj8KWefshNPZiTEUxnpHikV7+ZtsH8tZ/3zbBt1RqPlShfppNcL +-----END CERTIFICATE----- + +# Issuer: CN=ACCVRAIZ1 O=ACCV OU=PKIACCV +# Subject: CN=ACCVRAIZ1 O=ACCV OU=PKIACCV +# Label: "ACCVRAIZ1" +# Serial: 6828503384748696800 +# MD5 Fingerprint: d0:a0:5a:ee:05:b6:09:94:21:a1:7d:f1:b2:29:82:02 +# SHA1 Fingerprint: 93:05:7a:88:15:c6:4f:ce:88:2f:fa:91:16:52:28:78:bc:53:64:17 +# SHA256 Fingerprint: 9a:6e:c0:12:e1:a7:da:9d:be:34:19:4d:47:8a:d7:c0:db:18:22:fb:07:1d:f1:29:81:49:6e:d1:04:38:41:13 +-----BEGIN CERTIFICATE----- +MIIH0zCCBbugAwIBAgIIXsO3pkN/pOAwDQYJKoZIhvcNAQEFBQAwQjESMBAGA1UE +AwwJQUNDVlJBSVoxMRAwDgYDVQQLDAdQS0lBQ0NWMQ0wCwYDVQQKDARBQ0NWMQsw +CQYDVQQGEwJFUzAeFw0xMTA1MDUwOTM3MzdaFw0zMDEyMzEwOTM3MzdaMEIxEjAQ +BgNVBAMMCUFDQ1ZSQUlaMTEQMA4GA1UECwwHUEtJQUNDVjENMAsGA1UECgwEQUND +VjELMAkGA1UEBhMCRVMwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCb +qau/YUqXry+XZpp0X9DZlv3P4uRm7x8fRzPCRKPfmt4ftVTdFXxpNRFvu8gMjmoY +HtiP2Ra8EEg2XPBjs5BaXCQ316PWywlxufEBcoSwfdtNgM3802/J+Nq2DoLSRYWo +G2ioPej0RGy9ocLLA76MPhMAhN9KSMDjIgro6TenGEyxCQ0jVn8ETdkXhBilyNpA +lHPrzg5XPAOBOp0KoVdDaaxXbXmQeOW1tDvYvEyNKKGno6e6Ak4l0Squ7a4DIrhr +IA8wKFSVf+DuzgpmndFALW4ir50awQUZ0m/A8p/4e7MCQvtQqR0tkw8jq8bBD5L/ +0KIV9VMJcRz/RROE5iZe+OCIHAr8Fraocwa48GOEAqDGWuzndN9wrqODJerWx5eH +k6fGioozl2A3ED6XPm4pFdahD9GILBKfb6qkxkLrQaLjlUPTAYVtjrs78yM2x/47 +4KElB0iryYl0/wiPgL/AlmXz7uxLaL2diMMxs0Dx6M/2OLuc5NF/1OVYm3z61PMO +m3WR5LpSLhl+0fXNWhn8ugb2+1KoS5kE3fj5tItQo05iifCHJPqDQsGH+tUtKSpa +cXpkatcnYGMN285J9Y0fkIkyF/hzQ7jSWpOGYdbhdQrqeWZ2iE9x6wQl1gpaepPl +uUsXQA+xtrn13k/c4LOsOxFwYIRKQ26ZIMApcQrAZQIDAQABo4ICyzCCAscwfQYI +KwYBBQUHAQEEcTBvMEwGCCsGAQUFBzAChkBodHRwOi8vd3d3LmFjY3YuZXMvZmls +ZWFkbWluL0FyY2hpdm9zL2NlcnRpZmljYWRvcy9yYWl6YWNjdjEuY3J0MB8GCCsG +AQUFBzABhhNodHRwOi8vb2NzcC5hY2N2LmVzMB0GA1UdDgQWBBTSh7Tj3zcnk1X2 +VuqB5TbMjB4/vTAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFNKHtOPfNyeT +VfZW6oHlNsyMHj+9MIIBcwYDVR0gBIIBajCCAWYwggFiBgRVHSAAMIIBWDCCASIG +CCsGAQUFBwICMIIBFB6CARAAQQB1AHQAbwByAGkAZABhAGQAIABkAGUAIABDAGUA +cgB0AGkAZgBpAGMAYQBjAGkA8wBuACAAUgBhAO0AegAgAGQAZQAgAGwAYQAgAEEA +QwBDAFYAIAAoAEEAZwBlAG4AYwBpAGEAIABkAGUAIABUAGUAYwBuAG8AbABvAGcA +7QBhACAAeQAgAEMAZQByAHQAaQBmAGkAYwBhAGMAaQDzAG4AIABFAGwAZQBjAHQA +cgDzAG4AaQBjAGEALAAgAEMASQBGACAAUQA0ADYAMAAxADEANQA2AEUAKQAuACAA +QwBQAFMAIABlAG4AIABoAHQAdABwADoALwAvAHcAdwB3AC4AYQBjAGMAdgAuAGUA +czAwBggrBgEFBQcCARYkaHR0cDovL3d3dy5hY2N2LmVzL2xlZ2lzbGFjaW9uX2Mu +aHRtMFUGA1UdHwROMEwwSqBIoEaGRGh0dHA6Ly93d3cuYWNjdi5lcy9maWxlYWRt +aW4vQXJjaGl2b3MvY2VydGlmaWNhZG9zL3JhaXphY2N2MV9kZXIuY3JsMA4GA1Ud +DwEB/wQEAwIBBjAXBgNVHREEEDAOgQxhY2N2QGFjY3YuZXMwDQYJKoZIhvcNAQEF +BQADggIBAJcxAp/n/UNnSEQU5CmH7UwoZtCPNdpNYbdKl02125DgBS4OxnnQ8pdp +D70ER9m+27Up2pvZrqmZ1dM8MJP1jaGo/AaNRPTKFpV8M9xii6g3+CfYCS0b78gU +JyCpZET/LtZ1qmxNYEAZSUNUY9rizLpm5U9EelvZaoErQNV/+QEnWCzI7UiRfD+m +AM/EKXMRNt6GGT6d7hmKG9Ww7Y49nCrADdg9ZuM8Db3VlFzi4qc1GwQA9j9ajepD +vV+JHanBsMyZ4k0ACtrJJ1vnE5Bc5PUzolVt3OAJTS+xJlsndQAJxGJ3KQhfnlms +tn6tn1QwIgPBHnFk/vk4CpYY3QIUrCPLBhwepH2NDd4nQeit2hW3sCPdK6jT2iWH +7ehVRE2I9DZ+hJp4rPcOVkkO1jMl1oRQQmwgEh0q1b688nCBpHBgvgW1m54ERL5h +I6zppSSMEYCUWqKiuUnSwdzRp+0xESyeGabu4VXhwOrPDYTkF7eifKXeVSUG7szA +h1xA2syVP1XgNce4hL60Xc16gwFy7ofmXx2utYXGJt/mwZrpHgJHnyqobalbz+xF +d3+YJ5oyXSrjhO7FmGYvliAd3djDJ9ew+f7Zfc3Qn48LFFhRny+Lwzgt3uiP1o2H +pPVWQxaZLPSkVrQ0uGE3ycJYgBugl6H8WY3pEfbRD0tVNEYqi4Y7 +-----END CERTIFICATE----- + +# Issuer: CN=TWCA Global Root CA O=TAIWAN-CA OU=Root CA +# Subject: CN=TWCA Global Root CA O=TAIWAN-CA OU=Root CA +# Label: "TWCA Global Root CA" +# Serial: 3262 +# MD5 Fingerprint: f9:03:7e:cf:e6:9e:3c:73:7a:2a:90:07:69:ff:2b:96 +# SHA1 Fingerprint: 9c:bb:48:53:f6:a4:f6:d3:52:a4:e8:32:52:55:60:13:f5:ad:af:65 +# SHA256 Fingerprint: 59:76:90:07:f7:68:5d:0f:cd:50:87:2f:9f:95:d5:75:5a:5b:2b:45:7d:81:f3:69:2b:61:0a:98:67:2f:0e:1b +-----BEGIN CERTIFICATE----- +MIIFQTCCAymgAwIBAgICDL4wDQYJKoZIhvcNAQELBQAwUTELMAkGA1UEBhMCVFcx +EjAQBgNVBAoTCVRBSVdBTi1DQTEQMA4GA1UECxMHUm9vdCBDQTEcMBoGA1UEAxMT +VFdDQSBHbG9iYWwgUm9vdCBDQTAeFw0xMjA2MjcwNjI4MzNaFw0zMDEyMzExNTU5 +NTlaMFExCzAJBgNVBAYTAlRXMRIwEAYDVQQKEwlUQUlXQU4tQ0ExEDAOBgNVBAsT +B1Jvb3QgQ0ExHDAaBgNVBAMTE1RXQ0EgR2xvYmFsIFJvb3QgQ0EwggIiMA0GCSqG +SIb3DQEBAQUAA4ICDwAwggIKAoICAQCwBdvI64zEbooh745NnHEKH1Jw7W2CnJfF +10xORUnLQEK1EjRsGcJ0pDFfhQKX7EMzClPSnIyOt7h52yvVavKOZsTuKwEHktSz +0ALfUPZVr2YOy+BHYC8rMjk1Ujoog/h7FsYYuGLWRyWRzvAZEk2tY/XTP3VfKfCh +MBwqoJimFb3u/Rk28OKRQ4/6ytYQJ0lM793B8YVwm8rqqFpD/G2Gb3PpN0Wp8DbH +zIh1HrtsBv+baz4X7GGqcXzGHaL3SekVtTzWoWH1EfcFbx39Eb7QMAfCKbAJTibc +46KokWofwpFFiFzlmLhxpRUZyXx1EcxwdE8tmx2RRP1WKKD+u4ZqyPpcC1jcxkt2 +yKsi2XMPpfRaAok/T54igu6idFMqPVMnaR1sjjIsZAAmY2E2TqNGtz99sy2sbZCi +laLOz9qC5wc0GZbpuCGqKX6mOL6OKUohZnkfs8O1CWfe1tQHRvMq2uYiN2DLgbYP +oA/pyJV/v1WRBXrPPRXAb94JlAGD1zQbzECl8LibZ9WYkTunhHiVJqRaCPgrdLQA +BDzfuBSO6N+pjWxnkjMdwLfS7JLIvgm/LCkFbwJrnu+8vyq8W8BQj0FwcYeyTbcE +qYSjMq+u7msXi7Kx/mzhkIyIqJdIzshNy/MGz19qCkKxHh53L46g5pIOBvwFItIm +4TFRfTLcDwIDAQABoyMwITAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB +/zANBgkqhkiG9w0BAQsFAAOCAgEAXzSBdu+WHdXltdkCY4QWwa6gcFGn90xHNcgL +1yg9iXHZqjNB6hQbbCEAwGxCGX6faVsgQt+i0trEfJdLjbDorMjupWkEmQqSpqsn +LhpNgb+E1HAerUf+/UqdM+DyucRFCCEK2mlpc3INvjT+lIutwx4116KD7+U4x6WF +H6vPNOw/KP4M8VeGTslV9xzU2KV9Bnpv1d8Q34FOIWWxtuEXeZVFBs5fzNxGiWNo +RI2T9GRwoD2dKAXDOXC4Ynsg/eTb6QihuJ49CcdP+yz4k3ZB3lLg4VfSnQO8d57+ +nile98FRYB/e2guyLXW3Q0iT5/Z5xoRdgFlglPx4mI88k1HtQJAH32RjJMtOcQWh +15QaiDLxInQirqWm2BJpTGCjAu4r7NRjkgtevi92a6O2JryPA9gK8kxkRr05YuWW +6zRjESjMlfGt7+/cgFhI6Uu46mWs6fyAtbXIRfmswZ/ZuepiiI7E8UuDEq3mi4TW +nsLrgxifarsbJGAzcMzs9zLzXNl5fe+epP7JI8Mk7hWSsT2RTyaGvWZzJBPqpK5j +wa19hAM8EHiGG3njxPPyBJUgriOCxLM6AGK/5jYk4Ve6xx6QddVfP5VhK8E7zeWz +aGHQRiapIVJpLesux+t3zqY6tQMzT3bR51xUAV3LePTJDL/PEo4XLSNolOer/qmy +KwbQBM0= +-----END CERTIFICATE----- + +# Issuer: CN=TeliaSonera Root CA v1 O=TeliaSonera +# Subject: CN=TeliaSonera Root CA v1 O=TeliaSonera +# Label: "TeliaSonera Root CA v1" +# Serial: 199041966741090107964904287217786801558 +# MD5 Fingerprint: 37:41:49:1b:18:56:9a:26:f5:ad:c2:66:fb:40:a5:4c +# SHA1 Fingerprint: 43:13:bb:96:f1:d5:86:9b:c1:4e:6a:92:f6:cf:f6:34:69:87:82:37 +# SHA256 Fingerprint: dd:69:36:fe:21:f8:f0:77:c1:23:a1:a5:21:c1:22:24:f7:22:55:b7:3e:03:a7:26:06:93:e8:a2:4b:0f:a3:89 +-----BEGIN CERTIFICATE----- +MIIFODCCAyCgAwIBAgIRAJW+FqD3LkbxezmCcvqLzZYwDQYJKoZIhvcNAQEFBQAw +NzEUMBIGA1UECgwLVGVsaWFTb25lcmExHzAdBgNVBAMMFlRlbGlhU29uZXJhIFJv +b3QgQ0EgdjEwHhcNMDcxMDE4MTIwMDUwWhcNMzIxMDE4MTIwMDUwWjA3MRQwEgYD +VQQKDAtUZWxpYVNvbmVyYTEfMB0GA1UEAwwWVGVsaWFTb25lcmEgUm9vdCBDQSB2 +MTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMK+6yfwIaPzaSZVfp3F +VRaRXP3vIb9TgHot0pGMYzHw7CTww6XScnwQbfQ3t+XmfHnqjLWCi65ItqwA3GV1 +7CpNX8GH9SBlK4GoRz6JI5UwFpB/6FcHSOcZrr9FZ7E3GwYq/t75rH2D+1665I+X +Z75Ljo1kB1c4VWk0Nj0TSO9P4tNmHqTPGrdeNjPUtAa9GAH9d4RQAEX1jF3oI7x+ +/jXh7VB7qTCNGdMJjmhnXb88lxhTuylixcpecsHHltTbLaC0H2kD7OriUPEMPPCs +81Mt8Bz17Ww5OXOAFshSsCPN4D7c3TxHoLs1iuKYaIu+5b9y7tL6pe0S7fyYGKkm +dtwoSxAgHNN/Fnct7W+A90m7UwW7XWjH1Mh1Fj+JWov3F0fUTPHSiXk+TT2YqGHe +Oh7S+F4D4MHJHIzTjU3TlTazN19jY5szFPAtJmtTfImMMsJu7D0hADnJoWjiUIMu +sDor8zagrC/kb2HCUQk5PotTubtn2txTuXZZNp1D5SDgPTJghSJRt8czu90VL6R4 +pgd7gUY2BIbdeTXHlSw7sKMXNeVzH7RcWe/a6hBle3rQf5+ztCo3O3CLm1u5K7fs +slESl1MpWtTwEhDcTwK7EpIvYtQ/aUN8Ddb8WHUBiJ1YFkveupD/RwGJBmr2X7KQ +arMCpgKIv7NHfirZ1fpoeDVNAgMBAAGjPzA9MA8GA1UdEwEB/wQFMAMBAf8wCwYD +VR0PBAQDAgEGMB0GA1UdDgQWBBTwj1k4ALP1j5qWDNXr+nuqF+gTEjANBgkqhkiG +9w0BAQUFAAOCAgEAvuRcYk4k9AwI//DTDGjkk0kiP0Qnb7tt3oNmzqjMDfz1mgbl +dxSR651Be5kqhOX//CHBXfDkH1e3damhXwIm/9fH907eT/j3HEbAek9ALCI18Bmx +0GtnLLCo4MBANzX2hFxc469CeP6nyQ1Q6g2EdvZR74NTxnr/DlZJLo961gzmJ1Tj +TQpgcmLNkQfWpb/ImWvtxBnmq0wROMVvMeJuScg/doAmAyYp4Db29iBT4xdwNBed +Y2gea+zDTYa4EzAvXUYNR0PVG6pZDrlcjQZIrXSHX8f8MVRBE+LHIQ6e4B4N4cB7 +Q4WQxYpYxmUKeFfyxiMPAdkgS94P+5KFdSpcc41teyWRyu5FrgZLAMzTsVlQ2jqI +OylDRl6XK1TOU2+NSueW+r9xDkKLfP0ooNBIytrEgUy7onOTJsjrDNYmiLbAJM+7 +vVvrdX3pCI6GMyx5dwlppYn8s3CQh3aP0yK7Qs69cwsgJirQmz1wHiRszYd2qReW +t88NkvuOGKmYSdGe/mBEciG5Ge3C9THxOUiIkCR1VBatzvT4aRRkOfujuLpwQMcn +HL/EVlP6Y2XQ8xwOFvVrhlhNGNTkDY6lnVuR3HYkUD/GKvvZt5y11ubQ2egZixVx +SK236thZiNSQvxaz2emsWWFUyBy6ysHK4bkgTI86k4mloMy/0/Z1pHWWbVY= +-----END CERTIFICATE----- + +# Issuer: CN=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 - 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=IdenTrust Commercial Root CA 1 O=IdenTrust +# Subject: CN=IdenTrust Commercial Root CA 1 O=IdenTrust +# Label: "IdenTrust Commercial Root CA 1" +# Serial: 13298821034946342390520003877796839426 +# MD5 Fingerprint: b3:3e:77:73:75:ee:a0:d3:e3:7e:49:63:49:59:bb:c7 +# SHA1 Fingerprint: df:71:7e:aa:4a:d9:4e:c9:55:84:99:60:2d:48:de:5f:bc:f0:3a:25 +# SHA256 Fingerprint: 5d:56:49:9b:e4:d2:e0:8b:cf:ca:d0:8a:3e:38:72:3d:50:50:3b:de:70:69:48:e4:2f:55:60:30:19:e5:28:ae +-----BEGIN CERTIFICATE----- +MIIFYDCCA0igAwIBAgIQCgFCgAAAAUUjyES1AAAAAjANBgkqhkiG9w0BAQsFADBK +MQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0MScwJQYDVQQDEx5JZGVu +VHJ1c3QgQ29tbWVyY2lhbCBSb290IENBIDEwHhcNMTQwMTE2MTgxMjIzWhcNMzQw +MTE2MTgxMjIzWjBKMQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0MScw +JQYDVQQDEx5JZGVuVHJ1c3QgQ29tbWVyY2lhbCBSb290IENBIDEwggIiMA0GCSqG +SIb3DQEBAQUAA4ICDwAwggIKAoICAQCnUBneP5k91DNG8W9RYYKyqU+PZ4ldhNlT +3Qwo2dfw/66VQ3KZ+bVdfIrBQuExUHTRgQ18zZshq0PirK1ehm7zCYofWjK9ouuU ++ehcCuz/mNKvcbO0U59Oh++SvL3sTzIwiEsXXlfEU8L2ApeN2WIrvyQfYo3fw7gp +S0l4PJNgiCL8mdo2yMKi1CxUAGc1bnO/AljwpN3lsKImesrgNqUZFvX9t++uP0D1 +bVoE/c40yiTcdCMbXTMTEl3EASX2MN0CXZ/g1Ue9tOsbobtJSdifWwLziuQkkORi +T0/Br4sOdBeo0XKIanoBScy0RnnGF7HamB4HWfp1IYVl3ZBWzvurpWCdxJ35UrCL +vYf5jysjCiN2O/cz4ckA82n5S6LgTrx+kzmEB/dEcH7+B1rlsazRGMzyNeVJSQjK +Vsk9+w8YfYs7wRPCTY/JTw436R+hDmrfYi7LNQZReSzIJTj0+kuniVyc0uMNOYZK +dHzVWYfCP04MXFL0PfdSgvHqo6z9STQaKPNBiDoT7uje/5kdX7rL6B7yuVBgwDHT +c+XvvqDtMwt0viAgxGds8AgDelWAf0ZOlqf0Hj7h9tgJ4TNkK2PXMl6f+cB7D3hv +l7yTmvmcEpB4eoCHFddydJxVdHixuuFucAS6T6C6aMN7/zHwcz09lCqxC0EOoP5N +iGVreTO01wIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB +/zAdBgNVHQ4EFgQU7UQZwNPwBovupHu+QucmVMiONnYwDQYJKoZIhvcNAQELBQAD +ggIBAA2ukDL2pkt8RHYZYR4nKM1eVO8lvOMIkPkp165oCOGUAFjvLi5+U1KMtlwH +6oi6mYtQlNeCgN9hCQCTrQ0U5s7B8jeUeLBfnLOic7iPBZM4zY0+sLj7wM+x8uwt +LRvM7Kqas6pgghstO8OEPVeKlh6cdbjTMM1gCIOQ045U8U1mwF10A0Cj7oV+wh93 +nAbowacYXVKV7cndJZ5t+qntozo00Fl72u1Q8zW/7esUTTHHYPTa8Yec4kjixsU3 ++wYQ+nVZZjFHKdp2mhzpgq7vmrlR94gjmmmVYjzlVYA211QC//G5Xc7UI2/YRYRK +W2XviQzdFKcgyxilJbQN+QHwotL0AMh0jqEqSI5l2xPE4iUXfeu+h1sXIFRRk0pT +AwvsXcoz7WL9RccvW9xYoIA55vrX/hMUpu09lEpCdNTDd1lzzY9GvlU47/rokTLq +l1gEIt44w8y8bckzOmoKaT+gyOpyj4xjhiO9bTyWnpXgSUyqorkqG5w2gXjtw+hG +4iZZRHUe2XWJUc0QhJ1hYMtd+ZciTY6Y5uN/9lu7rs3KSoFrXgvzUeF0K+l+J6fZ +mUlO+KWA2yUPHGNiiskzZ2s8EIPGrd6ozRaOjfAHN3Gf8qv8QfXBi+wAN10J5U6A +7/qxXDgGpRtK4dw4LTzcqx+QGtVKnO7RcGzM7vRX+Bi6hG6H +-----END CERTIFICATE----- + +# Issuer: CN=IdenTrust Public Sector Root CA 1 O=IdenTrust +# Subject: CN=IdenTrust Public Sector Root CA 1 O=IdenTrust +# Label: "IdenTrust Public Sector Root CA 1" +# Serial: 13298821034946342390521976156843933698 +# MD5 Fingerprint: 37:06:a5:b0:fc:89:9d:ba:f4:6b:8c:1a:64:cd:d5:ba +# SHA1 Fingerprint: ba:29:41:60:77:98:3f:f4:f3:ef:f2:31:05:3b:2e:ea:6d:4d:45:fd +# SHA256 Fingerprint: 30:d0:89:5a:9a:44:8a:26:20:91:63:55:22:d1:f5:20:10:b5:86:7a:ca:e1:2c:78:ef:95:8f:d4:f4:38:9f:2f +-----BEGIN CERTIFICATE----- +MIIFZjCCA06gAwIBAgIQCgFCgAAAAUUjz0Z8AAAAAjANBgkqhkiG9w0BAQsFADBN +MQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0MSowKAYDVQQDEyFJZGVu +VHJ1c3QgUHVibGljIFNlY3RvciBSb290IENBIDEwHhcNMTQwMTE2MTc1MzMyWhcN +MzQwMTE2MTc1MzMyWjBNMQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0 +MSowKAYDVQQDEyFJZGVuVHJ1c3QgUHVibGljIFNlY3RvciBSb290IENBIDEwggIi +MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC2IpT8pEiv6EdrCvsnduTyP4o7 +ekosMSqMjbCpwzFrqHd2hCa2rIFCDQjrVVi7evi8ZX3yoG2LqEfpYnYeEe4IFNGy +RBb06tD6Hi9e28tzQa68ALBKK0CyrOE7S8ItneShm+waOh7wCLPQ5CQ1B5+ctMlS +bdsHyo+1W/CD80/HLaXIrcuVIKQxKFdYWuSNG5qrng0M8gozOSI5Cpcu81N3uURF +/YTLNiCBWS2ab21ISGHKTN9T0a9SvESfqy9rg3LvdYDaBjMbXcjaY8ZNzaxmMc3R +3j6HEDbhuaR672BQssvKplbgN6+rNBM5Jeg5ZuSYeqoSmJxZZoY+rfGwyj4GD3vw +EUs3oERte8uojHH01bWRNszwFcYr3lEXsZdMUD2xlVl8BX0tIdUAvwFnol57plzy +9yLxkA2T26pEUWbMfXYD62qoKjgZl3YNa4ph+bz27nb9cCvdKTz4Ch5bQhyLVi9V +GxyhLrXHFub4qjySjmm2AcG1hp2JDws4lFTo6tyePSW8Uybt1as5qsVATFSrsrTZ +2fjXctscvG29ZV/viDUqZi/u9rNl8DONfJhBaUYPQxxp+pu10GFqzcpL2UyQRqsV +WaFHVCkugyhfHMKiq3IXAAaOReyL4jM9f9oZRORicsPfIsbyVtTdX5Vy7W1f90gD +W/3FKqD2cyOEEBsB5wIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/ +BAUwAwEB/zAdBgNVHQ4EFgQU43HgntinQtnbcZFrlJPrw6PRFKMwDQYJKoZIhvcN +AQELBQADggIBAEf63QqwEZE4rU1d9+UOl1QZgkiHVIyqZJnYWv6IAcVYpZmxI1Qj +t2odIFflAWJBF9MJ23XLblSQdf4an4EKwt3X9wnQW3IV5B4Jaj0z8yGa5hV+rVHV +DRDtfULAj+7AmgjVQdZcDiFpboBhDhXAuM/FSRJSzL46zNQuOAXeNf0fb7iAaJg9 +TaDKQGXSc3z1i9kKlT/YPyNtGtEqJBnZhbMX73huqVjRI9PHE+1yJX9dsXNw0H8G +lwmEKYBhHfpe/3OsoOOJuBxxFcbeMX8S3OFtm6/n6J91eEyrRjuazr8FGF1NFTwW +mhlQBJqymm9li1JfPFgEKCXAZmExfrngdbkaqIHWchezxQMxNRF4eKLg6TCMf4Df +WN88uieW4oA0beOY02QnrEh+KHdcxiVhJfiFDGX6xDIvpZgF5PgLZxYWxoK4Mhn5 ++bl53B/N66+rDt0b20XkeucC4pVd/GnwU2lhlXV5C15V5jgclKlZM57IcXR5f1GJ +tshquDDIajjDbp7hNxbqBWJMWxJH7ae0s1hWx0nzfxJoCTFx8G34Tkf71oXuxVhA +GaQdp/lLQzfcaFpPz+vCZHTetBXZ9FRUGi8c15dxVJCO2SCdUyt/q4/i6jC8UDfv +8Ue1fXwsBOxonbRJRBD0ckscZOf85muQ3Wl9af0AVqW3rLatt8o+Ae+c +-----END CERTIFICATE----- + +# Issuer: CN=Entrust Root Certification Authority - G2 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2009 Entrust, Inc. - for authorized use only +# Subject: CN=Entrust Root Certification Authority - G2 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2009 Entrust, Inc. - for authorized use only +# Label: "Entrust Root Certification Authority - G2" +# Serial: 1246989352 +# MD5 Fingerprint: 4b:e2:c9:91:96:65:0c:f4:0e:5a:93:92:a0:0a:fe:b2 +# SHA1 Fingerprint: 8c:f4:27:fd:79:0c:3a:d1:66:06:8d:e8:1e:57:ef:bb:93:22:72:d4 +# SHA256 Fingerprint: 43:df:57:74:b0:3e:7f:ef:5f:e4:0d:93:1a:7b:ed:f1:bb:2e:6b:42:73:8c:4e:6d:38:41:10:3d:3a:a7:f3:39 +-----BEGIN CERTIFICATE----- +MIIEPjCCAyagAwIBAgIESlOMKDANBgkqhkiG9w0BAQsFADCBvjELMAkGA1UEBhMC +VVMxFjAUBgNVBAoTDUVudHJ1c3QsIEluYy4xKDAmBgNVBAsTH1NlZSB3d3cuZW50 +cnVzdC5uZXQvbGVnYWwtdGVybXMxOTA3BgNVBAsTMChjKSAyMDA5IEVudHJ1c3Qs +IEluYy4gLSBmb3IgYXV0aG9yaXplZCB1c2Ugb25seTEyMDAGA1UEAxMpRW50cnVz +dCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IC0gRzIwHhcNMDkwNzA3MTcy +NTU0WhcNMzAxMjA3MTc1NTU0WjCBvjELMAkGA1UEBhMCVVMxFjAUBgNVBAoTDUVu +dHJ1c3QsIEluYy4xKDAmBgNVBAsTH1NlZSB3d3cuZW50cnVzdC5uZXQvbGVnYWwt +dGVybXMxOTA3BgNVBAsTMChjKSAyMDA5IEVudHJ1c3QsIEluYy4gLSBmb3IgYXV0 +aG9yaXplZCB1c2Ugb25seTEyMDAGA1UEAxMpRW50cnVzdCBSb290IENlcnRpZmlj +YXRpb24gQXV0aG9yaXR5IC0gRzIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEK +AoIBAQC6hLZy254Ma+KZ6TABp3bqMriVQRrJ2mFOWHLP/vaCeb9zYQYKpSfYs1/T +RU4cctZOMvJyig/3gxnQaoCAAEUesMfnmr8SVycco2gvCoe9amsOXmXzHHfV1IWN +cCG0szLni6LVhjkCsbjSR87kyUnEO6fe+1R9V77w6G7CebI6C1XiUJgWMhNcL3hW +wcKUs/Ja5CeanyTXxuzQmyWC48zCxEXFjJd6BmsqEZ+pCm5IO2/b1BEZQvePB7/1 +U1+cPvQXLOZprE4yTGJ36rfo5bs0vBmLrpxR57d+tVOxMyLlbc9wPBr64ptntoP0 +jaWvYkxN4FisZDQSA/i2jZRjJKRxAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAP +BgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBRqciZ60B7vfec7aVHUbI2fkBJmqzAN +BgkqhkiG9w0BAQsFAAOCAQEAeZ8dlsa2eT8ijYfThwMEYGprmi5ZiXMRrEPR9RP/ +jTkrwPK9T3CMqS/qF8QLVJ7UG5aYMzyorWKiAHarWWluBh1+xLlEjZivEtRh2woZ +Rkfz6/djwUAFQKXSt/S1mja/qYh2iARVBCuch38aNzx+LaUa2NSJXsq9rD1s2G2v +1fN2D807iDginWyTmsQ9v4IbZT+mD12q/OWyFcq1rca8PdCE6OoGcrBNOTJ4vz4R +nAuknZoh8/CbCzB428Hch0P+vGOaysXCHMnHjf87ElgI5rY97HosTvuDls4MPGmH +VHOkc8KT/1EQrBVUAdj8BbGJoX90g5pJ19xOe4pIb4tF9g== +-----END CERTIFICATE----- + +# Issuer: CN=Entrust Root Certification Authority - EC1 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2012 Entrust, Inc. - for authorized use only +# Subject: CN=Entrust Root Certification Authority - EC1 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2012 Entrust, Inc. - for authorized use only +# Label: "Entrust Root Certification Authority - EC1" +# Serial: 51543124481930649114116133369 +# MD5 Fingerprint: b6:7e:1d:f0:58:c5:49:6c:24:3b:3d:ed:98:18:ed:bc +# SHA1 Fingerprint: 20:d8:06:40:df:9b:25:f5:12:25:3a:11:ea:f7:59:8a:eb:14:b5:47 +# SHA256 Fingerprint: 02:ed:0e:b2:8c:14:da:45:16:5c:56:67:91:70:0d:64:51:d7:fb:56:f0:b2:ab:1d:3b:8e:b0:70:e5:6e:df:f5 +-----BEGIN CERTIFICATE----- +MIIC+TCCAoCgAwIBAgINAKaLeSkAAAAAUNCR+TAKBggqhkjOPQQDAzCBvzELMAkG +A1UEBhMCVVMxFjAUBgNVBAoTDUVudHJ1c3QsIEluYy4xKDAmBgNVBAsTH1NlZSB3 +d3cuZW50cnVzdC5uZXQvbGVnYWwtdGVybXMxOTA3BgNVBAsTMChjKSAyMDEyIEVu +dHJ1c3QsIEluYy4gLSBmb3IgYXV0aG9yaXplZCB1c2Ugb25seTEzMDEGA1UEAxMq +RW50cnVzdCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IC0gRUMxMB4XDTEy +MTIxODE1MjUzNloXDTM3MTIxODE1NTUzNlowgb8xCzAJBgNVBAYTAlVTMRYwFAYD +VQQKEw1FbnRydXN0LCBJbmMuMSgwJgYDVQQLEx9TZWUgd3d3LmVudHJ1c3QubmV0 +L2xlZ2FsLXRlcm1zMTkwNwYDVQQLEzAoYykgMjAxMiBFbnRydXN0LCBJbmMuIC0g +Zm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxMzAxBgNVBAMTKkVudHJ1c3QgUm9vdCBD +ZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIEVDMTB2MBAGByqGSM49AgEGBSuBBAAi +A2IABIQTydC6bUF74mzQ61VfZgIaJPRbiWlH47jCffHyAsWfoPZb1YsGGYZPUxBt +ByQnoaD41UcZYUx9ypMn6nQM72+WCf5j7HBdNq1nd67JnXxVRDqiY1Ef9eNi1KlH +Bz7MIKNCMEAwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0O +BBYEFLdj5xrdjekIplWDpOBqUEFlEUJJMAoGCCqGSM49BAMDA2cAMGQCMGF52OVC +R98crlOZF7ZvHH3hvxGU0QOIdeSNiaSKd0bebWHvAvX7td/M/k7//qnmpwIwW5nX +hTcGtXsI/esni0qU+eH6p44mCOh8kmhtc9hvJqwhAriZtyZBWyVgrtBIGu4G +-----END CERTIFICATE----- + +# Issuer: CN=CFCA EV ROOT O=China Financial Certification Authority +# Subject: CN=CFCA EV ROOT O=China Financial Certification Authority +# Label: "CFCA EV ROOT" +# Serial: 407555286 +# MD5 Fingerprint: 74:e1:b6:ed:26:7a:7a:44:30:33:94:ab:7b:27:81:30 +# SHA1 Fingerprint: e2:b8:29:4b:55:84:ab:6b:58:c2:90:46:6c:ac:3f:b8:39:8f:84:83 +# SHA256 Fingerprint: 5c:c3:d7:8e:4e:1d:5e:45:54:7a:04:e6:87:3e:64:f9:0c:f9:53:6d:1c:cc:2e:f8:00:f3:55:c4:c5:fd:70:fd +-----BEGIN CERTIFICATE----- +MIIFjTCCA3WgAwIBAgIEGErM1jANBgkqhkiG9w0BAQsFADBWMQswCQYDVQQGEwJD +TjEwMC4GA1UECgwnQ2hpbmEgRmluYW5jaWFsIENlcnRpZmljYXRpb24gQXV0aG9y +aXR5MRUwEwYDVQQDDAxDRkNBIEVWIFJPT1QwHhcNMTIwODA4MDMwNzAxWhcNMjkx +MjMxMDMwNzAxWjBWMQswCQYDVQQGEwJDTjEwMC4GA1UECgwnQ2hpbmEgRmluYW5j +aWFsIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MRUwEwYDVQQDDAxDRkNBIEVWIFJP +T1QwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDXXWvNED8fBVnVBU03 +sQ7smCuOFR36k0sXgiFxEFLXUWRwFsJVaU2OFW2fvwwbwuCjZ9YMrM8irq93VCpL +TIpTUnrD7i7es3ElweldPe6hL6P3KjzJIx1qqx2hp/Hz7KDVRM8Vz3IvHWOX6Jn5 +/ZOkVIBMUtRSqy5J35DNuF++P96hyk0g1CXohClTt7GIH//62pCfCqktQT+x8Rgp +7hZZLDRJGqgG16iI0gNyejLi6mhNbiyWZXvKWfry4t3uMCz7zEasxGPrb382KzRz +EpR/38wmnvFyXVBlWY9ps4deMm/DGIq1lY+wejfeWkU7xzbh72fROdOXW3NiGUgt +hxwG+3SYIElz8AXSG7Ggo7cbcNOIabla1jj0Ytwli3i/+Oh+uFzJlU9fpy25IGvP +a931DfSCt/SyZi4QKPaXWnuWFo8BGS1sbn85WAZkgwGDg8NNkt0yxoekN+kWzqot +aK8KgWU6cMGbrU1tVMoqLUuFG7OA5nBFDWteNfB/O7ic5ARwiRIlk9oKmSJgamNg +TnYGmE69g60dWIolhdLHZR4tjsbftsbhf4oEIRUpdPA+nJCdDC7xij5aqgwJHsfV +PKPtl8MeNPo4+QgO48BdK4PRVmrJtqhUUy54Mmc9gn900PvhtgVguXDbjgv5E1hv +cWAQUhC5wUEJ73IfZzF4/5YFjQIDAQABo2MwYTAfBgNVHSMEGDAWgBTj/i39KNAL +tbq2osS/BqoFjJP7LzAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAd +BgNVHQ4EFgQU4/4t/SjQC7W6tqLEvwaqBYyT+y8wDQYJKoZIhvcNAQELBQADggIB +ACXGumvrh8vegjmWPfBEp2uEcwPenStPuiB/vHiyz5ewG5zz13ku9Ui20vsXiObT +ej/tUxPQ4i9qecsAIyjmHjdXNYmEwnZPNDatZ8POQQaIxffu2Bq41gt/UP+TqhdL +jOztUmCypAbqTuv0axn96/Ua4CUqmtzHQTb3yHQFhDmVOdYLO6Qn+gjYXB74BGBS +ESgoA//vU2YApUo0FmZ8/Qmkrp5nGm9BC2sGE5uPhnEFtC+NiWYzKXZUmhH4J/qy +P5Hgzg0b8zAarb8iXRvTvyUFTeGSGn+ZnzxEk8rUQElsgIfXBDrDMlI1Dlb4pd19 +xIsNER9Tyx6yF7Zod1rg1MvIB671Oi6ON7fQAUtDKXeMOZePglr4UeWJoBjnaH9d +Ci77o0cOPaYjesYBx4/IXr9tgFa+iiS6M+qf4TIRnvHST4D2G0CvOJ4RUHlzEhLN +5mydLIhyPDCBBpEi6lmt2hkuIsKNuYyH4Ga8cyNfIWRjgEj1oDwYPZTISEEdQLpe +/v5WOaHIz16eGWRGENoXkbcFgKyLmZJ956LYBws2J+dIeWCKw9cTXPhyQN9Ky8+Z +AAoACxGV2lZFA4gKn2fQ1XmxqI1AbQ3CekD6819kR5LLU7m7Wc5P/dAVUwHY3+vZ +5nbv0CO7O6l5s9UCKc2Jo5YPSjXnTkLAdc0Hz+Ys63su +-----END CERTIFICATE----- + +# Issuer: CN=OISTE WISeKey Global Root GB CA O=WISeKey OU=OISTE Foundation Endorsed +# Subject: CN=OISTE WISeKey Global Root GB CA O=WISeKey OU=OISTE Foundation Endorsed +# Label: "OISTE WISeKey Global Root GB CA" +# Serial: 157768595616588414422159278966750757568 +# MD5 Fingerprint: a4:eb:b9:61:28:2e:b7:2f:98:b0:35:26:90:99:51:1d +# SHA1 Fingerprint: 0f:f9:40:76:18:d3:d7:6a:4b:98:f0:a8:35:9e:0c:fd:27:ac:cc:ed +# SHA256 Fingerprint: 6b:9c:08:e8:6e:b0:f7:67:cf:ad:65:cd:98:b6:21:49:e5:49:4a:67:f5:84:5e:7b:d1:ed:01:9f:27:b8:6b:d6 +-----BEGIN CERTIFICATE----- +MIIDtTCCAp2gAwIBAgIQdrEgUnTwhYdGs/gjGvbCwDANBgkqhkiG9w0BAQsFADBt +MQswCQYDVQQGEwJDSDEQMA4GA1UEChMHV0lTZUtleTEiMCAGA1UECxMZT0lTVEUg +Rm91bmRhdGlvbiBFbmRvcnNlZDEoMCYGA1UEAxMfT0lTVEUgV0lTZUtleSBHbG9i +YWwgUm9vdCBHQiBDQTAeFw0xNDEyMDExNTAwMzJaFw0zOTEyMDExNTEwMzFaMG0x +CzAJBgNVBAYTAkNIMRAwDgYDVQQKEwdXSVNlS2V5MSIwIAYDVQQLExlPSVNURSBG +b3VuZGF0aW9uIEVuZG9yc2VkMSgwJgYDVQQDEx9PSVNURSBXSVNlS2V5IEdsb2Jh +bCBSb290IEdCIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA2Be3 +HEokKtaXscriHvt9OO+Y9bI5mE4nuBFde9IllIiCFSZqGzG7qFshISvYD06fWvGx +WuR51jIjK+FTzJlFXHtPrby/h0oLS5daqPZI7H17Dc0hBt+eFf1Biki3IPShehtX +1F1Q/7pn2COZH8g/497/b1t3sWtuuMlk9+HKQUYOKXHQuSP8yYFfTvdv37+ErXNk +u7dCjmn21HYdfp2nuFeKUWdy19SouJVUQHMD9ur06/4oQnc/nSMbsrY9gBQHTC5P +99UKFg29ZkM3fiNDecNAhvVMKdqOmq0NpQSHiB6F4+lT1ZvIiwNjeOvgGUpuuy9r +M2RYk61pv48b74JIxwIDAQABo1EwTzALBgNVHQ8EBAMCAYYwDwYDVR0TAQH/BAUw +AwEB/zAdBgNVHQ4EFgQUNQ/INmNe4qPs+TtmFc5RUuORmj0wEAYJKwYBBAGCNxUB +BAMCAQAwDQYJKoZIhvcNAQELBQADggEBAEBM+4eymYGQfp3FsLAmzYh7KzKNbrgh +cViXfa43FK8+5/ea4n32cZiZBKpDdHij40lhPnOMTZTg+XHEthYOU3gf1qKHLwI5 +gSk8rxWYITD+KJAAjNHhy/peyP34EEY7onhCkRd0VQreUGdNZtGn//3ZwLWoo4rO +ZvUPQ82nK1d7Y0Zqqi5S2PTt4W2tKZB4SLrhI6qjiey1q5bAtEuiHZeeevJuQHHf +aPFlTc58Bd9TZaml8LGXBHAVRgOY1NK/VLSgWH1Sb9pWJmLU2NuJMW8c8CLC02Ic +Nc1MaRVUGpCY3useX8p3x8uOPUNpnJpY0CQ73xtAln41rYHHTnG6iBM= +-----END CERTIFICATE----- + +# Issuer: CN=SZAFIR ROOT CA2 O=Krajowa Izba Rozliczeniowa S.A. +# Subject: CN=SZAFIR ROOT CA2 O=Krajowa Izba Rozliczeniowa S.A. +# Label: "SZAFIR ROOT CA2" +# Serial: 357043034767186914217277344587386743377558296292 +# MD5 Fingerprint: 11:64:c1:89:b0:24:b1:8c:b1:07:7e:89:9e:51:9e:99 +# SHA1 Fingerprint: e2:52:fa:95:3f:ed:db:24:60:bd:6e:28:f3:9c:cc:cf:5e:b3:3f:de +# SHA256 Fingerprint: a1:33:9d:33:28:1a:0b:56:e5:57:d3:d3:2b:1c:e7:f9:36:7e:b0:94:bd:5f:a7:2a:7e:50:04:c8:de:d7:ca:fe +-----BEGIN CERTIFICATE----- +MIIDcjCCAlqgAwIBAgIUPopdB+xV0jLVt+O2XwHrLdzk1uQwDQYJKoZIhvcNAQEL +BQAwUTELMAkGA1UEBhMCUEwxKDAmBgNVBAoMH0tyYWpvd2EgSXpiYSBSb3psaWN6 +ZW5pb3dhIFMuQS4xGDAWBgNVBAMMD1NaQUZJUiBST09UIENBMjAeFw0xNTEwMTkw +NzQzMzBaFw0zNTEwMTkwNzQzMzBaMFExCzAJBgNVBAYTAlBMMSgwJgYDVQQKDB9L +cmFqb3dhIEl6YmEgUm96bGljemVuaW93YSBTLkEuMRgwFgYDVQQDDA9TWkFGSVIg +Uk9PVCBDQTIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC3vD5QqEvN +QLXOYeeWyrSh2gwisPq1e3YAd4wLz32ohswmUeQgPYUM1ljj5/QqGJ3a0a4m7utT +3PSQ1hNKDJA8w/Ta0o4NkjrcsbH/ON7Dui1fgLkCvUqdGw+0w8LBZwPd3BucPbOw +3gAeqDRHu5rr/gsUvTaE2g0gv/pby6kWIK05YO4vdbbnl5z5Pv1+TW9NL++IDWr6 +3fE9biCloBK0TXC5ztdyO4mTp4CEHCdJckm1/zuVnsHMyAHs6A6KCpbns6aH5db5 +BSsNl0BwPLqsdVqc1U2dAgrSS5tmS0YHF2Wtn2yIANwiieDhZNRnvDF5YTy7ykHN +XGoAyDw4jlivAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQD +AgEGMB0GA1UdDgQWBBQuFqlKGLXLzPVvUPMjX/hd56zwyDANBgkqhkiG9w0BAQsF +AAOCAQEAtXP4A9xZWx126aMqe5Aosk3AM0+qmrHUuOQn/6mWmc5G4G18TKI4pAZw +8PRBEew/R40/cof5O/2kbytTAOD/OblqBw7rHRz2onKQy4I9EYKL0rufKq8h5mOG +nXkZ7/e7DDWQw4rtTw/1zBLZpD67oPwglV9PJi8RI4NOdQcPv5vRtB3pEAT+ymCP +oky4rc/hkA/NrgrHXXu3UNLUYfrVFdvXn4dRVOul4+vJhaAlIDf7js4MNIThPIGy +d05DpYhfhmehPea0XGG2Ptv+tyjFogeutcrKjSoS75ftwjCkySp6+/NNIxuZMzSg +LvWpCz/UXeHPhJ/iGcJfitYgHuNztw== +-----END CERTIFICATE----- + +# Issuer: CN=Certum Trusted Network CA 2 O=Unizeto Technologies S.A. OU=Certum Certification Authority +# Subject: CN=Certum Trusted Network CA 2 O=Unizeto Technologies S.A. OU=Certum Certification Authority +# Label: "Certum Trusted Network CA 2" +# Serial: 44979900017204383099463764357512596969 +# MD5 Fingerprint: 6d:46:9e:d9:25:6d:08:23:5b:5e:74:7d:1e:27:db:f2 +# SHA1 Fingerprint: d3:dd:48:3e:2b:bf:4c:05:e8:af:10:f5:fa:76:26:cf:d3:dc:30:92 +# SHA256 Fingerprint: b6:76:f2:ed:da:e8:77:5c:d3:6c:b0:f6:3c:d1:d4:60:39:61:f4:9e:62:65:ba:01:3a:2f:03:07:b6:d0:b8:04 +-----BEGIN CERTIFICATE----- +MIIF0jCCA7qgAwIBAgIQIdbQSk8lD8kyN/yqXhKN6TANBgkqhkiG9w0BAQ0FADCB +gDELMAkGA1UEBhMCUEwxIjAgBgNVBAoTGVVuaXpldG8gVGVjaG5vbG9naWVzIFMu +QS4xJzAlBgNVBAsTHkNlcnR1bSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTEkMCIG +A1UEAxMbQ2VydHVtIFRydXN0ZWQgTmV0d29yayBDQSAyMCIYDzIwMTExMDA2MDgz +OTU2WhgPMjA0NjEwMDYwODM5NTZaMIGAMQswCQYDVQQGEwJQTDEiMCAGA1UEChMZ +VW5pemV0byBUZWNobm9sb2dpZXMgUy5BLjEnMCUGA1UECxMeQ2VydHVtIENlcnRp +ZmljYXRpb24gQXV0aG9yaXR5MSQwIgYDVQQDExtDZXJ0dW0gVHJ1c3RlZCBOZXR3 +b3JrIENBIDIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC9+Xj45tWA +DGSdhhuWZGc/IjoedQF97/tcZ4zJzFxrqZHmuULlIEub2pt7uZld2ZuAS9eEQCsn +0+i6MLs+CRqnSZXvK0AkwpfHp+6bJe+oCgCXhVqqndwpyeI1B+twTUrWwbNWuKFB +OJvR+zF/j+Bf4bE/D44WSWDXBo0Y+aomEKsq09DRZ40bRr5HMNUuctHFY9rnY3lE +fktjJImGLjQ/KUxSiyqnwOKRKIm5wFv5HdnnJ63/mgKXwcZQkpsCLL2puTRZCr+E +Sv/f/rOf69me4Jgj7KZrdxYq28ytOxykh9xGc14ZYmhFV+SQgkK7QtbwYeDBoz1m +o130GO6IyY0XRSmZMnUCMe4pJshrAua1YkV/NxVaI2iJ1D7eTiew8EAMvE0Xy02i +sx7QBlrd9pPPV3WZ9fqGGmd4s7+W/jTcvedSVuWz5XV710GRBdxdaeOVDUO5/IOW +OZV7bIBaTxNyxtd9KXpEulKkKtVBRgkg/iKgtlswjbyJDNXXcPiHUv3a76xRLgez +Tv7QCdpw75j6VuZt27VXS9zlLCUVyJ4ueE742pyehizKV/Ma5ciSixqClnrDvFAS +adgOWkaLOusm+iPJtrCBvkIApPjW/jAux9JG9uWOdf3yzLnQh1vMBhBgu4M1t15n +3kfsmUjxpKEV/q2MYo45VU85FrmxY53/twIDAQABo0IwQDAPBgNVHRMBAf8EBTAD +AQH/MB0GA1UdDgQWBBS2oVQ5AsOgP46KvPrU+Bym0ToO/TAOBgNVHQ8BAf8EBAMC +AQYwDQYJKoZIhvcNAQENBQADggIBAHGlDs7k6b8/ONWJWsQCYftMxRQXLYtPU2sQ +F/xlhMcQSZDe28cmk4gmb3DWAl45oPePq5a1pRNcgRRtDoGCERuKTsZPpd1iHkTf +CVn0W3cLN+mLIMb4Ck4uWBzrM9DPhmDJ2vuAL55MYIR4PSFk1vtBHxgP58l1cb29 +XN40hz5BsA72udY/CROWFC/emh1auVbONTqwX3BNXuMp8SMoclm2q8KMZiYcdywm +djWLKKdpoPk79SPdhRB0yZADVpHnr7pH1BKXESLjokmUbOe3lEu6LaTaM4tMpkT/ +WjzGHWTYtTHkpjx6qFcL2+1hGsvxznN3Y6SHb0xRONbkX8eftoEq5IVIeVheO/jb +AoJnwTnbw3RLPTYe+SmTiGhbqEQZIfCn6IENLOiTNrQ3ssqwGyZ6miUfmpqAnksq +P/ujmv5zMnHCnsZy4YpoJ/HkD7TETKVhk/iXEAcqMCWpuchxuO9ozC1+9eB+D4Ko +b7a6bINDd82Kkhehnlt4Fj1F4jNy3eFmypnTycUm/Q1oBEauttmbjL4ZvrHG8hnj +XALKLNhvSgfZyTXaQHXyxKcZb55CEJh15pWLYLztxRLXis7VmFxWlgPF7ncGNf/P +5O4/E2Hu29othfDNrp2yGAlFw5Khchf8R7agCyzxxN5DaAhqXzvwdmP7zAYspsbi +DrW5viSP +-----END CERTIFICATE----- + +# Issuer: CN=Hellenic Academic and Research Institutions RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority +# Subject: CN=Hellenic Academic and Research Institutions RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority +# Label: "Hellenic Academic and Research Institutions RootCA 2015" +# Serial: 0 +# MD5 Fingerprint: ca:ff:e2:db:03:d9:cb:4b:e9:0f:ad:84:fd:7b:18:ce +# SHA1 Fingerprint: 01:0c:06:95:a6:98:19:14:ff:bf:5f:c6:b0:b6:95:ea:29:e9:12:a6 +# SHA256 Fingerprint: a0:40:92:9a:02:ce:53:b4:ac:f4:f2:ff:c6:98:1c:e4:49:6f:75:5e:6d:45:fe:0b:2a:69:2b:cd:52:52:3f:36 +-----BEGIN CERTIFICATE----- +MIIGCzCCA/OgAwIBAgIBADANBgkqhkiG9w0BAQsFADCBpjELMAkGA1UEBhMCR1Ix +DzANBgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNhZGVtaWMgYW5k +IFJlc2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkxQDA+BgNVBAMT +N0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgUm9v +dENBIDIwMTUwHhcNMTUwNzA3MTAxMTIxWhcNNDAwNjMwMTAxMTIxWjCBpjELMAkG +A1UEBhMCR1IxDzANBgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNh +ZGVtaWMgYW5kIFJlc2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkx +QDA+BgNVBAMTN0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1 +dGlvbnMgUm9vdENBIDIwMTUwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoIC +AQDC+Kk/G4n8PDwEXT2QNrCROnk8ZlrvbTkBSRq0t89/TSNTt5AA4xMqKKYx8ZEA +4yjsriFBzh/a/X0SWwGDD7mwX5nh8hKDgE0GPt+sr+ehiGsxr/CL0BgzuNtFajT0 +AoAkKAoCFZVedioNmToUW/bLy1O8E00BiDeUJRtCvCLYjqOWXjrZMts+6PAQZe10 +4S+nfK8nNLspfZu2zwnI5dMK/IhlZXQK3HMcXM1AsRzUtoSMTFDPaI6oWa7CJ06C +ojXdFPQf/7J31Ycvqm59JCfnxssm5uX+Zwdj2EUN3TpZZTlYepKZcj2chF6IIbjV +9Cz82XBST3i4vTwri5WY9bPRaM8gFH5MXF/ni+X1NYEZN9cRCLdmvtNKzoNXADrD +gfgXy5I2XdGj2HUb4Ysn6npIQf1FGQatJ5lOwXBH3bWfgVMS5bGMSF0xQxfjjMZ6 +Y5ZLKTBOhE5iGV48zpeQpX8B653g+IuJ3SWYPZK2fu/Z8VFRfS0myGlZYeCsargq +NhEEelC9MoS+L9xy1dcdFkfkR2YgP/SWxa+OAXqlD3pk9Q0Yh9muiNX6hME6wGko +LfINaFGq46V3xqSQDqE3izEjR8EJCOtu93ib14L8hCCZSRm2Ekax+0VVFqmjZayc +Bw/qa9wfLgZy7IaIEuQt218FL+TwA9MmM+eAws1CoRc0CwIDAQABo0IwQDAPBgNV +HRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUcRVnyMjJvXVd +ctA4GGqd83EkVAswDQYJKoZIhvcNAQELBQADggIBAHW7bVRLqhBYRjTyYtcWNl0I +XtVsyIe9tC5G8jH4fOpCtZMWVdyhDBKg2mF+D1hYc2Ryx+hFjtyp8iY/xnmMsVMI +M4GwVhO+5lFc2JsKT0ucVlMC6U/2DWDqTUJV6HwbISHTGzrMd/K4kPFox/la/vot +9L/J9UUbzjgQKjeKeaO04wlshYaT/4mWJ3iBj2fjRnRUjtkNaeJK9E10A/+yd+2V +Z5fkscWrv2oj6NSU4kQoYsRL4vDY4ilrGnB+JGGTe08DMiUNRSQrlrRGar9KC/ea +j8GsGsVn82800vpzY4zvFrCopEYq+OsS7HK07/grfoxSwIuEVPkvPuNVqNxmsdnh +X9izjFk0WaSrT2y7HxjbdavYy5LNlDhhDgcGH0tGEPEVvo2FXDtKK4F5D7Rpn0lQ +l033DlZdwJVqwjbDG2jJ9SrcR5q+ss7FJej6A7na+RZukYT1HCjI/CbM1xyQVqdf +bzoEvM14iQuODy+jqk+iGxI9FghAD/FGTNeqewjBCvVtJ94Cj8rDtSvK6evIIVM4 +pcw72Hc3MKJP2W/R8kCtQXoXxdZKNYm3QdV8hn9VTYNKpXMgwDqvkPGaJI7ZjnHK +e7iG2rKPmT4dEw0SEe7Uq/DpFXYC5ODfqiAeW2GFZECpkJcNrVPSWh2HagCXZWK0 +vm9qp/UsQu0yrbYhnr68 +-----END CERTIFICATE----- + +# Issuer: CN=Hellenic Academic and Research Institutions ECC RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority +# Subject: CN=Hellenic Academic and Research Institutions ECC RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority +# Label: "Hellenic Academic and Research Institutions ECC RootCA 2015" +# Serial: 0 +# MD5 Fingerprint: 81:e5:b4:17:eb:c2:f5:e1:4b:0d:41:7b:49:92:fe:ef +# SHA1 Fingerprint: 9f:f1:71:8d:92:d5:9a:f3:7d:74:97:b4:bc:6f:84:68:0b:ba:b6:66 +# SHA256 Fingerprint: 44:b5:45:aa:8a:25:e6:5a:73:ca:15:dc:27:fc:36:d2:4c:1c:b9:95:3a:06:65:39:b1:15:82:dc:48:7b:48:33 +-----BEGIN CERTIFICATE----- +MIICwzCCAkqgAwIBAgIBADAKBggqhkjOPQQDAjCBqjELMAkGA1UEBhMCR1IxDzAN +BgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJl +c2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkxRDBCBgNVBAMTO0hl +bGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgRUNDIFJv +b3RDQSAyMDE1MB4XDTE1MDcwNzEwMzcxMloXDTQwMDYzMDEwMzcxMlowgaoxCzAJ +BgNVBAYTAkdSMQ8wDQYDVQQHEwZBdGhlbnMxRDBCBgNVBAoTO0hlbGxlbmljIEFj +YWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgQ2VydC4gQXV0aG9yaXR5 +MUQwQgYDVQQDEztIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0 +dXRpb25zIEVDQyBSb290Q0EgMjAxNTB2MBAGByqGSM49AgEGBSuBBAAiA2IABJKg +QehLgoRc4vgxEZmGZE4JJS+dQS8KrjVPdJWyUWRrjWvmP3CV8AVER6ZyOFB2lQJa +jq4onvktTpnvLEhvTCUp6NFxW98dwXU3tNf6e3pCnGoKVlp8aQuqgAkkbH7BRqNC +MEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFLQi +C4KZJAEOnLvkDv2/+5cgk5kqMAoGCCqGSM49BAMCA2cAMGQCMGfOFmI4oqxiRaep +lSTAGiecMjvAwNW6qef4BENThe5SId6d9SWDPp5YSy/XZxMOIQIwBeF1Ad5o7Sof +TUwJCA3sS61kFyjndc5FZXIhF8siQQ6ME5g4mlRtm8rifOoCWCKR +-----END CERTIFICATE----- + +# Issuer: CN=ISRG Root X1 O=Internet Security Research Group +# Subject: CN=ISRG Root X1 O=Internet Security Research Group +# Label: "ISRG Root X1" +# Serial: 172886928669790476064670243504169061120 +# MD5 Fingerprint: 0c:d2:f9:e0:da:17:73:e9:ed:86:4d:a5:e3:70:e7:4e +# SHA1 Fingerprint: ca:bd:2a:79:a1:07:6a:31:f2:1d:25:36:35:cb:03:9d:43:29:a5:e8 +# SHA256 Fingerprint: 96:bc:ec:06:26:49:76:f3:74:60:77:9a:cf:28:c5:a7:cf:e8:a3:c0:aa:e1:1a:8f:fc:ee:05:c0:bd:df:08:c6 +-----BEGIN CERTIFICATE----- +MIIFazCCA1OgAwIBAgIRAIIQz7DSQONZRGPgu2OCiwAwDQYJKoZIhvcNAQELBQAw +TzELMAkGA1UEBhMCVVMxKTAnBgNVBAoTIEludGVybmV0IFNlY3VyaXR5IFJlc2Vh +cmNoIEdyb3VwMRUwEwYDVQQDEwxJU1JHIFJvb3QgWDEwHhcNMTUwNjA0MTEwNDM4 +WhcNMzUwNjA0MTEwNDM4WjBPMQswCQYDVQQGEwJVUzEpMCcGA1UEChMgSW50ZXJu +ZXQgU2VjdXJpdHkgUmVzZWFyY2ggR3JvdXAxFTATBgNVBAMTDElTUkcgUm9vdCBY +MTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAK3oJHP0FDfzm54rVygc +h77ct984kIxuPOZXoHj3dcKi/vVqbvYATyjb3miGbESTtrFj/RQSa78f0uoxmyF+ +0TM8ukj13Xnfs7j/EvEhmkvBioZxaUpmZmyPfjxwv60pIgbz5MDmgK7iS4+3mX6U +A5/TR5d8mUgjU+g4rk8Kb4Mu0UlXjIB0ttov0DiNewNwIRt18jA8+o+u3dpjq+sW +T8KOEUt+zwvo/7V3LvSye0rgTBIlDHCNAymg4VMk7BPZ7hm/ELNKjD+Jo2FR3qyH +B5T0Y3HsLuJvW5iB4YlcNHlsdu87kGJ55tukmi8mxdAQ4Q7e2RCOFvu396j3x+UC +B5iPNgiV5+I3lg02dZ77DnKxHZu8A/lJBdiB3QW0KtZB6awBdpUKD9jf1b0SHzUv +KBds0pjBqAlkd25HN7rOrFleaJ1/ctaJxQZBKT5ZPt0m9STJEadao0xAH0ahmbWn +OlFuhjuefXKnEgV4We0+UXgVCwOPjdAvBbI+e0ocS3MFEvzG6uBQE3xDk3SzynTn +jh8BCNAw1FtxNrQHusEwMFxIt4I7mKZ9YIqioymCzLq9gwQbooMDQaHWBfEbwrbw +qHyGO0aoSCqI3Haadr8faqU9GY/rOPNk3sgrDQoo//fb4hVC1CLQJ13hef4Y53CI +rU7m2Ys6xt0nUW7/vGT1M0NPAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNV +HRMBAf8EBTADAQH/MB0GA1UdDgQWBBR5tFnme7bl5AFzgAiIyBpY9umbbjANBgkq +hkiG9w0BAQsFAAOCAgEAVR9YqbyyqFDQDLHYGmkgJykIrGF1XIpu+ILlaS/V9lZL +ubhzEFnTIZd+50xx+7LSYK05qAvqFyFWhfFQDlnrzuBZ6brJFe+GnY+EgPbk6ZGQ +3BebYhtF8GaV0nxvwuo77x/Py9auJ/GpsMiu/X1+mvoiBOv/2X/qkSsisRcOj/KK +NFtY2PwByVS5uCbMiogziUwthDyC3+6WVwW6LLv3xLfHTjuCvjHIInNzktHCgKQ5 +ORAzI4JMPJ+GslWYHb4phowim57iaztXOoJwTdwJx4nLCgdNbOhdjsnvzqvHu7Ur +TkXWStAmzOVyyghqpZXjFaH3pO3JLF+l+/+sKAIuvtd7u+Nxe5AW0wdeRlN8NwdC +jNPElpzVmbUq4JUagEiuTDkHzsxHpFKVK7q4+63SM1N95R1NbdWhscdCb+ZAJzVc +oyi3B43njTOQ5yOf+1CceWxG1bQVs5ZufpsMljq4Ui0/1lvh+wjChP4kqKOJ2qxq +4RgqsahDYVvTH9w7jXbyLeiNdd8XM2w9U/t7y0Ff/9yi0GE44Za4rF2LN9d11TPA +mRGunUHBcnWEvgJBQl9nJEiU0Zsnvgc/ubhPgXRR4Xq37Z0j4r7g1SgEEzwxA57d +emyPxgcYxn/eR44/KJ4EBs+lVDR3veyJm+kXQ99b21/+jh5Xos1AnX5iItreGCc= +-----END CERTIFICATE----- + +# Issuer: O=FNMT-RCM OU=AC RAIZ FNMT-RCM +# Subject: O=FNMT-RCM OU=AC RAIZ FNMT-RCM +# Label: "AC RAIZ FNMT-RCM" +# Serial: 485876308206448804701554682760554759 +# MD5 Fingerprint: e2:09:04:b4:d3:bd:d1:a0:14:fd:1a:d2:47:c4:57:1d +# SHA1 Fingerprint: ec:50:35:07:b2:15:c4:95:62:19:e2:a8:9a:5b:42:99:2c:4c:2c:20 +# SHA256 Fingerprint: eb:c5:57:0c:29:01:8c:4d:67:b1:aa:12:7b:af:12:f7:03:b4:61:1e:bc:17:b7:da:b5:57:38:94:17:9b:93:fa +-----BEGIN CERTIFICATE----- +MIIFgzCCA2ugAwIBAgIPXZONMGc2yAYdGsdUhGkHMA0GCSqGSIb3DQEBCwUAMDsx +CzAJBgNVBAYTAkVTMREwDwYDVQQKDAhGTk1ULVJDTTEZMBcGA1UECwwQQUMgUkFJ +WiBGTk1ULVJDTTAeFw0wODEwMjkxNTU5NTZaFw0zMDAxMDEwMDAwMDBaMDsxCzAJ +BgNVBAYTAkVTMREwDwYDVQQKDAhGTk1ULVJDTTEZMBcGA1UECwwQQUMgUkFJWiBG +Tk1ULVJDTTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBALpxgHpMhm5/ +yBNtwMZ9HACXjywMI7sQmkCpGreHiPibVmr75nuOi5KOpyVdWRHbNi63URcfqQgf +BBckWKo3Shjf5TnUV/3XwSyRAZHiItQDwFj8d0fsjz50Q7qsNI1NOHZnjrDIbzAz +WHFctPVrbtQBULgTfmxKo0nRIBnuvMApGGWn3v7v3QqQIecaZ5JCEJhfTzC8PhxF +tBDXaEAUwED653cXeuYLj2VbPNmaUtu1vZ5Gzz3rkQUCwJaydkxNEJY7kvqcfw+Z +374jNUUeAlz+taibmSXaXvMiwzn15Cou08YfxGyqxRxqAQVKL9LFwag0Jl1mpdIC +IfkYtwb1TplvqKtMUejPUBjFd8g5CSxJkjKZqLsXF3mwWsXmo8RZZUc1g16p6DUL +mbvkzSDGm0oGObVo/CK67lWMK07q87Hj/LaZmtVC+nFNCM+HHmpxffnTtOmlcYF7 +wk5HlqX2doWjKI/pgG6BU6VtX7hI+cL5NqYuSf+4lsKMB7ObiFj86xsc3i1w4peS +MKGJ47xVqCfWS+2QrYv6YyVZLag13cqXM7zlzced0ezvXg5KkAYmY6252TUtB7p2 +ZSysV4999AeU14ECll2jB0nVetBX+RvnU0Z1qrB5QstocQjpYL05ac70r8NWQMet +UqIJ5G+GR4of6ygnXYMgrwTJbFaai0b1AgMBAAGjgYMwgYAwDwYDVR0TAQH/BAUw +AwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFPd9xf3E6Jobd2Sn9R2gzL+H +YJptMD4GA1UdIAQ3MDUwMwYEVR0gADArMCkGCCsGAQUFBwIBFh1odHRwOi8vd3d3 +LmNlcnQuZm5tdC5lcy9kcGNzLzANBgkqhkiG9w0BAQsFAAOCAgEAB5BK3/MjTvDD +nFFlm5wioooMhfNzKWtN/gHiqQxjAb8EZ6WdmF/9ARP67Jpi6Yb+tmLSbkyU+8B1 +RXxlDPiyN8+sD8+Nb/kZ94/sHvJwnvDKuO+3/3Y3dlv2bojzr2IyIpMNOmqOFGYM +LVN0V2Ue1bLdI4E7pWYjJ2cJj+F3qkPNZVEI7VFY/uY5+ctHhKQV8Xa7pO6kO8Rf +77IzlhEYt8llvhjho6Tc+hj507wTmzl6NLrTQfv6MooqtyuGC2mDOL7Nii4LcK2N +JpLuHvUBKwrZ1pebbuCoGRw6IYsMHkCtA+fdZn71uSANA+iW+YJF1DngoABd15jm +fZ5nc8OaKveri6E6FO80vFIOiZiaBECEHX5FaZNXzuvO+FB8TxxuBEOb+dY7Ixjp +6o7RTUaN8Tvkasq6+yO3m/qZASlaWFot4/nUbQ4mrcFuNLwy+AwF+mWj2zs3gyLp +1txyM/1d8iC9djwj2ij3+RvrWWTV3F9yfiD8zYm1kGdNYno/Tq0dwzn+evQoFt9B +9kiABdcPUXmsEKvU7ANm5mqwujGSQkBqvjrTcuFqN1W8rB2Vt2lh8kORdOag0wok +RqEIr9baRRmW1FMdW4R58MD3R++Lj8UGrp1MYp3/RgT408m2ECVAdf4WqslKYIYv +uu8wd+RU4riEmViAqhOLUTpPSPaLtrM= +-----END CERTIFICATE----- + +# Issuer: CN=Amazon Root CA 1 O=Amazon +# Subject: CN=Amazon Root CA 1 O=Amazon +# Label: "Amazon Root CA 1" +# Serial: 143266978916655856878034712317230054538369994 +# MD5 Fingerprint: 43:c6:bf:ae:ec:fe:ad:2f:18:c6:88:68:30:fc:c8:e6 +# SHA1 Fingerprint: 8d:a7:f9:65:ec:5e:fc:37:91:0f:1c:6e:59:fd:c1:cc:6a:6e:de:16 +# SHA256 Fingerprint: 8e:cd:e6:88:4f:3d:87:b1:12:5b:a3:1a:c3:fc:b1:3d:70:16:de:7f:57:cc:90:4f:e1:cb:97:c6:ae:98:19:6e +-----BEGIN CERTIFICATE----- +MIIDQTCCAimgAwIBAgITBmyfz5m/jAo54vB4ikPmljZbyjANBgkqhkiG9w0BAQsF +ADA5MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6 +b24gUm9vdCBDQSAxMB4XDTE1MDUyNjAwMDAwMFoXDTM4MDExNzAwMDAwMFowOTEL +MAkGA1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJv +b3QgQ0EgMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALJ4gHHKeNXj +ca9HgFB0fW7Y14h29Jlo91ghYPl0hAEvrAIthtOgQ3pOsqTQNroBvo3bSMgHFzZM +9O6II8c+6zf1tRn4SWiw3te5djgdYZ6k/oI2peVKVuRF4fn9tBb6dNqcmzU5L/qw +IFAGbHrQgLKm+a/sRxmPUDgH3KKHOVj4utWp+UhnMJbulHheb4mjUcAwhmahRWa6 +VOujw5H5SNz/0egwLX0tdHA114gk957EWW67c4cX8jJGKLhD+rcdqsq08p8kDi1L +93FcXmn/6pUCyziKrlA4b9v7LWIbxcceVOF34GfID5yHI9Y/QCB/IIDEgEw+OyQm +jgSubJrIqg0CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC +AYYwHQYDVR0OBBYEFIQYzIU07LwMlJQuCFmcx7IQTgoIMA0GCSqGSIb3DQEBCwUA +A4IBAQCY8jdaQZChGsV2USggNiMOruYou6r4lK5IpDB/G/wkjUu0yKGX9rbxenDI +U5PMCCjjmCXPI6T53iHTfIUJrU6adTrCC2qJeHZERxhlbI1Bjjt/msv0tadQ1wUs +N+gDS63pYaACbvXy8MWy7Vu33PqUXHeeE6V/Uq2V8viTO96LXFvKWlJbYK8U90vv +o/ufQJVtMVT8QtPHRh8jrdkPSHCa2XV4cdFyQzR1bldZwgJcJmApzyMZFo6IQ6XU +5MsI+yMRQ+hDKXJioaldXgjUkK642M4UwtBV8ob2xJNDd2ZhwLnoQdeXeGADbkpy +rqXRfboQnoZsG4q5WTP468SQvvG5 +-----END CERTIFICATE----- + +# Issuer: CN=Amazon Root CA 2 O=Amazon +# Subject: CN=Amazon Root CA 2 O=Amazon +# Label: "Amazon Root CA 2" +# Serial: 143266982885963551818349160658925006970653239 +# MD5 Fingerprint: c8:e5:8d:ce:a8:42:e2:7a:c0:2a:5c:7c:9e:26:bf:66 +# SHA1 Fingerprint: 5a:8c:ef:45:d7:a6:98:59:76:7a:8c:8b:44:96:b5:78:cf:47:4b:1a +# SHA256 Fingerprint: 1b:a5:b2:aa:8c:65:40:1a:82:96:01:18:f8:0b:ec:4f:62:30:4d:83:ce:c4:71:3a:19:c3:9c:01:1e:a4:6d:b4 +-----BEGIN CERTIFICATE----- +MIIFQTCCAymgAwIBAgITBmyf0pY1hp8KD+WGePhbJruKNzANBgkqhkiG9w0BAQwF +ADA5MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6 +b24gUm9vdCBDQSAyMB4XDTE1MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTEL +MAkGA1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJv +b3QgQ0EgMjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAK2Wny2cSkxK +gXlRmeyKy2tgURO8TW0G/LAIjd0ZEGrHJgw12MBvIITplLGbhQPDW9tK6Mj4kHbZ +W0/jTOgGNk3Mmqw9DJArktQGGWCsN0R5hYGCrVo34A3MnaZMUnbqQ523BNFQ9lXg +1dKmSYXpN+nKfq5clU1Imj+uIFptiJXZNLhSGkOQsL9sBbm2eLfq0OQ6PBJTYv9K +8nu+NQWpEjTj82R0Yiw9AElaKP4yRLuH3WUnAnE72kr3H9rN9yFVkE8P7K6C4Z9r +2UXTu/Bfh+08LDmG2j/e7HJV63mjrdvdfLC6HM783k81ds8P+HgfajZRRidhW+me +z/CiVX18JYpvL7TFz4QuK/0NURBs+18bvBt+xa47mAExkv8LV/SasrlX6avvDXbR +8O70zoan4G7ptGmh32n2M8ZpLpcTnqWHsFcQgTfJU7O7f/aS0ZzQGPSSbtqDT6Zj +mUyl+17vIWR6IF9sZIUVyzfpYgwLKhbcAS4y2j5L9Z469hdAlO+ekQiG+r5jqFoz +7Mt0Q5X5bGlSNscpb/xVA1wf+5+9R+vnSUeVC06JIglJ4PVhHvG/LopyboBZ/1c6 ++XUyo05f7O0oYtlNc/LMgRdg7c3r3NunysV+Ar3yVAhU/bQtCSwXVEqY0VThUWcI +0u1ufm8/0i2BWSlmy5A5lREedCf+3euvAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMB +Af8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBSwDPBMMPQFWAJI/TPlUq9LhONm +UjANBgkqhkiG9w0BAQwFAAOCAgEAqqiAjw54o+Ci1M3m9Zh6O+oAA7CXDpO8Wqj2 +LIxyh6mx/H9z/WNxeKWHWc8w4Q0QshNabYL1auaAn6AFC2jkR2vHat+2/XcycuUY ++gn0oJMsXdKMdYV2ZZAMA3m3MSNjrXiDCYZohMr/+c8mmpJ5581LxedhpxfL86kS +k5Nrp+gvU5LEYFiwzAJRGFuFjWJZY7attN6a+yb3ACfAXVU3dJnJUH/jWS5E4ywl +7uxMMne0nxrpS10gxdr9HIcWxkPo1LsmmkVwXqkLN1PiRnsn/eBG8om3zEK2yygm +btmlyTrIQRNg91CMFa6ybRoVGld45pIq2WWQgj9sAq+uEjonljYE1x2igGOpm/Hl +urR8FLBOybEfdF849lHqm/osohHUqS0nGkWxr7JOcQ3AWEbWaQbLU8uz/mtBzUF+ +fUwPfHJ5elnNXkoOrJupmHN5fLT0zLm4BwyydFy4x2+IoZCn9Kr5v2c69BoVYh63 +n749sSmvZ6ES8lgQGVMDMBu4Gon2nL2XA46jCfMdiyHxtN/kHNGfZQIG6lzWE7OE +76KlXIx3KadowGuuQNKotOrN8I1LOJwZmhsoVLiJkO/KdYE+HvJkJMcYr07/R54H +9jVlpNMKVv/1F2Rs76giJUmTtt8AF9pYfl3uxRuw0dFfIRDH+fO6AgonB8Xx1sfT +4PsJYGw= +-----END CERTIFICATE----- + +# Issuer: CN=Amazon Root CA 3 O=Amazon +# Subject: CN=Amazon Root CA 3 O=Amazon +# Label: "Amazon Root CA 3" +# Serial: 143266986699090766294700635381230934788665930 +# MD5 Fingerprint: a0:d4:ef:0b:f7:b5:d8:49:95:2a:ec:f5:c4:fc:81:87 +# SHA1 Fingerprint: 0d:44:dd:8c:3c:8c:1a:1a:58:75:64:81:e9:0f:2e:2a:ff:b3:d2:6e +# SHA256 Fingerprint: 18:ce:6c:fe:7b:f1:4e:60:b2:e3:47:b8:df:e8:68:cb:31:d0:2e:bb:3a:da:27:15:69:f5:03:43:b4:6d:b3:a4 +-----BEGIN CERTIFICATE----- +MIIBtjCCAVugAwIBAgITBmyf1XSXNmY/Owua2eiedgPySjAKBggqhkjOPQQDAjA5 +MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6b24g +Um9vdCBDQSAzMB4XDTE1MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTELMAkG +A1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJvb3Qg +Q0EgMzBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABCmXp8ZBf8ANm+gBG1bG8lKl +ui2yEujSLtf6ycXYqm0fc4E7O5hrOXwzpcVOho6AF2hiRVd9RFgdszflZwjrZt6j +QjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBSr +ttvXBp43rDCGB5Fwx5zEGbF4wDAKBggqhkjOPQQDAgNJADBGAiEA4IWSoxe3jfkr +BqWTrBqYaGFy+uGh0PsceGCmQ5nFuMQCIQCcAu/xlJyzlvnrxir4tiz+OpAUFteM +YyRIHN8wfdVoOw== +-----END CERTIFICATE----- + +# Issuer: CN=Amazon Root CA 4 O=Amazon +# Subject: CN=Amazon Root CA 4 O=Amazon +# Label: "Amazon Root CA 4" +# Serial: 143266989758080763974105200630763877849284878 +# MD5 Fingerprint: 89:bc:27:d5:eb:17:8d:06:6a:69:d5:fd:89:47:b4:cd +# SHA1 Fingerprint: f6:10:84:07:d6:f8:bb:67:98:0c:c2:e2:44:c2:eb:ae:1c:ef:63:be +# SHA256 Fingerprint: e3:5d:28:41:9e:d0:20:25:cf:a6:90:38:cd:62:39:62:45:8d:a5:c6:95:fb:de:a3:c2:2b:0b:fb:25:89:70:92 +-----BEGIN CERTIFICATE----- +MIIB8jCCAXigAwIBAgITBmyf18G7EEwpQ+Vxe3ssyBrBDjAKBggqhkjOPQQDAzA5 +MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6b24g +Um9vdCBDQSA0MB4XDTE1MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTELMAkG +A1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJvb3Qg +Q0EgNDB2MBAGByqGSM49AgEGBSuBBAAiA2IABNKrijdPo1MN/sGKe0uoe0ZLY7Bi +9i0b2whxIdIA6GO9mif78DluXeo9pcmBqqNbIJhFXRbb/egQbeOc4OO9X4Ri83Bk +M6DLJC9wuoihKqB1+IGuYgbEgds5bimwHvouXKNCMEAwDwYDVR0TAQH/BAUwAwEB +/zAOBgNVHQ8BAf8EBAMCAYYwHQYDVR0OBBYEFNPsxzplbszh2naaVvuc84ZtV+WB +MAoGCCqGSM49BAMDA2gAMGUCMDqLIfG9fhGt0O9Yli/W651+kI0rz2ZVwyzjKKlw +CkcO8DdZEv8tmZQoTipPNU0zWgIxAOp1AE47xDqUEpHJWEadIRNyp4iciuRMStuW +1KyLa2tJElMzrdfkviT8tQp21KW8EA== +-----END CERTIFICATE----- + +# Issuer: CN=TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1 O=Turkiye Bilimsel ve Teknolojik Arastirma Kurumu - TUBITAK OU=Kamu Sertifikasyon Merkezi - Kamu SM +# Subject: CN=TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1 O=Turkiye Bilimsel ve Teknolojik Arastirma Kurumu - TUBITAK OU=Kamu Sertifikasyon Merkezi - Kamu SM +# Label: "TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1" +# Serial: 1 +# MD5 Fingerprint: dc:00:81:dc:69:2f:3e:2f:b0:3b:f6:3d:5a:91:8e:49 +# SHA1 Fingerprint: 31:43:64:9b:ec:ce:27:ec:ed:3a:3f:0b:8f:0d:e4:e8:91:dd:ee:ca +# SHA256 Fingerprint: 46:ed:c3:68:90:46:d5:3a:45:3f:b3:10:4a:b8:0d:ca:ec:65:8b:26:60:ea:16:29:dd:7e:86:79:90:64:87:16 +-----BEGIN CERTIFICATE----- +MIIEYzCCA0ugAwIBAgIBATANBgkqhkiG9w0BAQsFADCB0jELMAkGA1UEBhMCVFIx +GDAWBgNVBAcTD0dlYnplIC0gS29jYWVsaTFCMEAGA1UEChM5VHVya2l5ZSBCaWxp +bXNlbCB2ZSBUZWtub2xvamlrIEFyYXN0aXJtYSBLdXJ1bXUgLSBUVUJJVEFLMS0w +KwYDVQQLEyRLYW11IFNlcnRpZmlrYXN5b24gTWVya2V6aSAtIEthbXUgU00xNjA0 +BgNVBAMTLVRVQklUQUsgS2FtdSBTTSBTU0wgS29rIFNlcnRpZmlrYXNpIC0gU3Vy +dW0gMTAeFw0xMzExMjUwODI1NTVaFw00MzEwMjUwODI1NTVaMIHSMQswCQYDVQQG +EwJUUjEYMBYGA1UEBxMPR2ViemUgLSBLb2NhZWxpMUIwQAYDVQQKEzlUdXJraXll +IEJpbGltc2VsIHZlIFRla25vbG9qaWsgQXJhc3Rpcm1hIEt1cnVtdSAtIFRVQklU +QUsxLTArBgNVBAsTJEthbXUgU2VydGlmaWthc3lvbiBNZXJrZXppIC0gS2FtdSBT +TTE2MDQGA1UEAxMtVFVCSVRBSyBLYW11IFNNIFNTTCBLb2sgU2VydGlmaWthc2kg +LSBTdXJ1bSAxMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAr3UwM6q7 +a9OZLBI3hNmNe5eA027n/5tQlT6QlVZC1xl8JoSNkvoBHToP4mQ4t4y86Ij5iySr +LqP1N+RAjhgleYN1Hzv/bKjFxlb4tO2KRKOrbEz8HdDc72i9z+SqzvBV96I01INr +N3wcwv61A+xXzry0tcXtAA9TNypN9E8Mg/uGz8v+jE69h/mniyFXnHrfA2eJLJ2X +YacQuFWQfw4tJzh03+f92k4S400VIgLI4OD8D62K18lUUMw7D8oWgITQUVbDjlZ/ +iSIzL+aFCr2lqBs23tPcLG07xxO9WSMs5uWk99gL7eqQQESolbuT1dCANLZGeA4f +AJNG4e7p+exPFwIDAQABo0IwQDAdBgNVHQ4EFgQUZT/HiobGPN08VFw1+DrtUgxH +V8gwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEL +BQADggEBACo/4fEyjq7hmFxLXs9rHmoJ0iKpEsdeV31zVmSAhHqT5Am5EM2fKifh +AHe+SMg1qIGf5LgsyX8OsNJLN13qudULXjS99HMpw+0mFZx+CFOKWI3QSyjfwbPf +IPP54+M638yclNhOT8NrF7f3cuitZjO1JVOr4PhMqZ398g26rrnZqsZr+ZO7rqu4 +lzwDGrpDxpa5RXI4s6ehlj2Re37AIVNMh+3yC1SVUZPVIqUNivGTDj5UDrDYyU7c +8jEyVupk+eq1nRZmQnLzf9OxMUP8pI4X8W0jq5Rm+K37DwhuJi1/FwcJsoz7UMCf +lo3Ptv0AnVoUmr8CRPXBwp8iXqIPoeM= +-----END CERTIFICATE----- + +# Issuer: CN=GDCA TrustAUTH R5 ROOT O=GUANG DONG CERTIFICATE AUTHORITY CO.,LTD. +# Subject: CN=GDCA TrustAUTH R5 ROOT O=GUANG DONG CERTIFICATE AUTHORITY CO.,LTD. +# Label: "GDCA TrustAUTH R5 ROOT" +# Serial: 9009899650740120186 +# MD5 Fingerprint: 63:cc:d9:3d:34:35:5c:6f:53:a3:e2:08:70:48:1f:b4 +# SHA1 Fingerprint: 0f:36:38:5b:81:1a:25:c3:9b:31:4e:83:ca:e9:34:66:70:cc:74:b4 +# SHA256 Fingerprint: bf:ff:8f:d0:44:33:48:7d:6a:8a:a6:0c:1a:29:76:7a:9f:c2:bb:b0:5e:42:0f:71:3a:13:b9:92:89:1d:38:93 +-----BEGIN CERTIFICATE----- +MIIFiDCCA3CgAwIBAgIIfQmX/vBH6nowDQYJKoZIhvcNAQELBQAwYjELMAkGA1UE +BhMCQ04xMjAwBgNVBAoMKUdVQU5HIERPTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZ +IENPLixMVEQuMR8wHQYDVQQDDBZHRENBIFRydXN0QVVUSCBSNSBST09UMB4XDTE0 +MTEyNjA1MTMxNVoXDTQwMTIzMTE1NTk1OVowYjELMAkGA1UEBhMCQ04xMjAwBgNV +BAoMKUdVQU5HIERPTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZIENPLixMVEQuMR8w +HQYDVQQDDBZHRENBIFRydXN0QVVUSCBSNSBST09UMIICIjANBgkqhkiG9w0BAQEF +AAOCAg8AMIICCgKCAgEA2aMW8Mh0dHeb7zMNOwZ+Vfy1YI92hhJCfVZmPoiC7XJj +Dp6L3TQsAlFRwxn9WVSEyfFrs0yw6ehGXTjGoqcuEVe6ghWinI9tsJlKCvLriXBj +TnnEt1u9ol2x8kECK62pOqPseQrsXzrj/e+APK00mxqriCZ7VqKChh/rNYmDf1+u +KU49tm7srsHwJ5uu4/Ts765/94Y9cnrrpftZTqfrlYwiOXnhLQiPzLyRuEH3FMEj +qcOtmkVEs7LXLM3GKeJQEK5cy4KOFxg2fZfmiJqwTTQJ9Cy5WmYqsBebnh52nUpm +MUHfP/vFBu8btn4aRjb3ZGM74zkYI+dndRTVdVeSN72+ahsmUPI2JgaQxXABZG12 +ZuGR224HwGGALrIuL4xwp9E7PLOR5G62xDtw8mySlwnNR30YwPO7ng/Wi64HtloP +zgsMR6flPri9fcebNaBhlzpBdRfMK5Z3KpIhHtmVdiBnaM8Nvd/WHwlqmuLMc3Gk +L30SgLdTMEZeS1SZD2fJpcjyIMGC7J0R38IC+xo70e0gmu9lZJIQDSri3nDxGGeC +jGHeuLzRL5z7D9Ar7Rt2ueQ5Vfj4oR24qoAATILnsn8JuLwwoC8N9VKejveSswoA +HQBUlwbgsQfZxw9cZX08bVlX5O2ljelAU58VS6Bx9hoh49pwBiFYFIeFd3mqgnkC +AwEAAaNCMEAwHQYDVR0OBBYEFOLJQJ9NzuiaoXzPDj9lxSmIahlRMA8GA1UdEwEB +/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEBCwUAA4ICAQDRSVfg +p8xoWLoBDysZzY2wYUWsEe1jUGn4H3++Fo/9nesLqjJHdtJnJO29fDMylyrHBYZm +DRd9FBUb1Ov9H5r2XpdptxolpAqzkT9fNqyL7FeoPueBihhXOYV0GkLH6VsTX4/5 +COmSdI31R9KrO9b7eGZONn356ZLpBN79SWP8bfsUcZNnL0dKt7n/HipzcEYwv1ry +L3ml4Y0M2fmyYzeMN2WFcGpcWwlyua1jPLHd+PwyvzeG5LuOmCd+uh8W4XAR8gPf +JWIyJyYYMoSf/wA6E7qaTfRPuBRwIrHKK5DOKcFw9C+df/KQHtZa37dG/OaG+svg +IHZ6uqbL9XzeYqWxi+7egmaKTjowHz+Ay60nugxe19CxVsp3cbK1daFQqUBDF8Io +2c9Si1vIY9RCPqAzekYu9wogRlR+ak8x8YF+QnQ4ZXMn7sZ8uI7XpTrXmKGcjBBV +09tL7ECQ8s1uV9JiDnxXk7Gnbc2dg7sq5+W2O3FYrf3RRbxake5TFW/TRQl1brqQ +XR4EzzffHqhmsYzmIGrv/EhOdJhCrylvLmrH+33RZjEizIYAfmaDDEL0vTSSwxrq +T8p+ck0LcIymSLumoRT2+1hEmRSuqguTaaApJUqlyyvdimYHFngVV3Eb7PVHhPOe +MTd61X8kreS8/f3MboPoDKi3QWwH3b08hpcv0g== +-----END CERTIFICATE----- + +# Issuer: CN=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=UCA Global G2 Root O=UniTrust +# Subject: CN=UCA Global G2 Root O=UniTrust +# Label: "UCA Global G2 Root" +# Serial: 124779693093741543919145257850076631279 +# MD5 Fingerprint: 80:fe:f0:c4:4a:f0:5c:62:32:9f:1c:ba:78:a9:50:f8 +# SHA1 Fingerprint: 28:f9:78:16:19:7a:ff:18:25:18:aa:44:fe:c1:a0:ce:5c:b6:4c:8a +# SHA256 Fingerprint: 9b:ea:11:c9:76:fe:01:47:64:c1:be:56:a6:f9:14:b5:a5:60:31:7a:bd:99:88:39:33:82:e5:16:1a:a0:49:3c +-----BEGIN CERTIFICATE----- +MIIFRjCCAy6gAwIBAgIQXd+x2lqj7V2+WmUgZQOQ7zANBgkqhkiG9w0BAQsFADA9 +MQswCQYDVQQGEwJDTjERMA8GA1UECgwIVW5pVHJ1c3QxGzAZBgNVBAMMElVDQSBH +bG9iYWwgRzIgUm9vdDAeFw0xNjAzMTEwMDAwMDBaFw00MDEyMzEwMDAwMDBaMD0x +CzAJBgNVBAYTAkNOMREwDwYDVQQKDAhVbmlUcnVzdDEbMBkGA1UEAwwSVUNBIEds +b2JhbCBHMiBSb290MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAxeYr +b3zvJgUno4Ek2m/LAfmZmqkywiKHYUGRO8vDaBsGxUypK8FnFyIdK+35KYmToni9 +kmugow2ifsqTs6bRjDXVdfkX9s9FxeV67HeToI8jrg4aA3++1NDtLnurRiNb/yzm +VHqUwCoV8MmNsHo7JOHXaOIxPAYzRrZUEaalLyJUKlgNAQLx+hVRZ2zA+te2G3/R +VogvGjqNO7uCEeBHANBSh6v7hn4PJGtAnTRnvI3HLYZveT6OqTwXS3+wmeOwcWDc +C/Vkw85DvG1xudLeJ1uK6NjGruFZfc8oLTW4lVYa8bJYS7cSN8h8s+1LgOGN+jIj +tm+3SJUIsUROhYw6AlQgL9+/V087OpAh18EmNVQg7Mc/R+zvWr9LesGtOxdQXGLY +D0tK3Cv6brxzks3sx1DoQZbXqX5t2Okdj4q1uViSukqSKwxW/YDrCPBeKW4bHAyv +j5OJrdu9o54hyokZ7N+1wxrrFv54NkzWbtA+FxyQF2smuvt6L78RHBgOLXMDj6Dl +NaBa4kx1HXHhOThTeEDMg5PXCp6dW4+K5OXgSORIskfNTip1KnvyIvbJvgmRlld6 +iIis7nCs+dwp4wwcOxJORNanTrAmyPPZGpeRaOrvjUYG0lZFWJo8DA+DuAUlwznP +O6Q0ibd5Ei9Hxeepl2n8pndntd978XplFeRhVmUCAwEAAaNCMEAwDgYDVR0PAQH/ +BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFIHEjMz15DD/pQwIX4wV +ZyF0Ad/fMA0GCSqGSIb3DQEBCwUAA4ICAQATZSL1jiutROTL/7lo5sOASD0Ee/oj +L3rtNtqyzm325p7lX1iPyzcyochltq44PTUbPrw7tgTQvPlJ9Zv3hcU2tsu8+Mg5 +1eRfB70VVJd0ysrtT7q6ZHafgbiERUlMjW+i67HM0cOU2kTC5uLqGOiiHycFutfl +1qnN3e92mI0ADs0b+gO3joBYDic/UvuUospeZcnWhNq5NXHzJsBPd+aBJ9J3O5oU +b3n09tDh05S60FdRvScFDcH9yBIw7m+NESsIndTUv4BFFJqIRNow6rSn4+7vW4LV +PtateJLbXDzz2K36uGt/xDYotgIVilQsnLAXc47QN6MUPJiVAAwpBVueSUmxX8fj +y88nZY41F7dXyDDZQVu5FLbowg+UMaeUmMxq67XhJ/UQqAHojhJi6IjMtX9Gl8Cb +EGY4GjZGXyJoPd/JxhMnq1MGrKI8hgZlb7F+sSlEmqO6SWkoaY/X5V+tBIZkbxqg +DMUIYs6Ao9Dz7GjevjPHF1t/gMRMTLGmhIrDO7gJzRSBuhjjVFc2/tsvfEehOjPI ++Vg7RE+xygKJBJYoaMVLuCaJu9YzL1DV/pqJuhgyklTGW+Cd+V7lDSKb9triyCGy +YiGqhkCyLmTTX8jjfhFnRR8F/uOi77Oos/N9j/gMHyIfLXC0uAE0djAA5SN4p1bX +UB+K+wb1whnw0A== +-----END CERTIFICATE----- + +# Issuer: CN=UCA Extended Validation Root O=UniTrust +# Subject: CN=UCA Extended Validation Root O=UniTrust +# Label: "UCA Extended Validation Root" +# Serial: 106100277556486529736699587978573607008 +# MD5 Fingerprint: a1:f3:5f:43:c6:34:9b:da:bf:8c:7e:05:53:ad:96:e2 +# SHA1 Fingerprint: a3:a1:b0:6f:24:61:23:4a:e3:36:a5:c2:37:fc:a6:ff:dd:f0:d7:3a +# SHA256 Fingerprint: d4:3a:f9:b3:54:73:75:5c:96:84:fc:06:d7:d8:cb:70:ee:5c:28:e7:73:fb:29:4e:b4:1e:e7:17:22:92:4d:24 +-----BEGIN CERTIFICATE----- +MIIFWjCCA0KgAwIBAgIQT9Irj/VkyDOeTzRYZiNwYDANBgkqhkiG9w0BAQsFADBH +MQswCQYDVQQGEwJDTjERMA8GA1UECgwIVW5pVHJ1c3QxJTAjBgNVBAMMHFVDQSBF +eHRlbmRlZCBWYWxpZGF0aW9uIFJvb3QwHhcNMTUwMzEzMDAwMDAwWhcNMzgxMjMx +MDAwMDAwWjBHMQswCQYDVQQGEwJDTjERMA8GA1UECgwIVW5pVHJ1c3QxJTAjBgNV +BAMMHFVDQSBFeHRlbmRlZCBWYWxpZGF0aW9uIFJvb3QwggIiMA0GCSqGSIb3DQEB +AQUAA4ICDwAwggIKAoICAQCpCQcoEwKwmeBkqh5DFnpzsZGgdT6o+uM4AHrsiWog +D4vFsJszA1qGxliG1cGFu0/GnEBNyr7uaZa4rYEwmnySBesFK5pI0Lh2PpbIILvS +sPGP2KxFRv+qZ2C0d35qHzwaUnoEPQc8hQ2E0B92CvdqFN9y4zR8V05WAT558aop +O2z6+I9tTcg1367r3CTueUWnhbYFiN6IXSV8l2RnCdm/WhUFhvMJHuxYMjMR83dk +sHYf5BA1FxvyDrFspCqjc/wJHx4yGVMR59mzLC52LqGj3n5qiAno8geK+LLNEOfi +c0CTuwjRP+H8C5SzJe98ptfRr5//lpr1kXuYC3fUfugH0mK1lTnj8/FtDw5lhIpj +VMWAtuCeS31HJqcBCF3RiJ7XwzJE+oJKCmhUfzhTA8ykADNkUVkLo4KRel7sFsLz +KuZi2irbWWIQJUoqgQtHB0MGcIfS+pMRKXpITeuUx3BNr2fVUbGAIAEBtHoIppB/ +TuDvB0GHr2qlXov7z1CymlSvw4m6WC31MJixNnI5fkkE/SmnTHnkBVfblLkWU41G +sx2VYVdWf6/wFlthWG82UBEL2KwrlRYaDh8IzTY0ZRBiZtWAXxQgXy0MoHgKaNYs +1+lvK9JKBZP8nm9rZ/+I8U6laUpSNwXqxhaN0sSZ0YIrO7o1dfdRUVjzyAfd5LQD +fwIDAQABo0IwQDAdBgNVHQ4EFgQU2XQ65DA9DfcS3H5aBZ8eNJr34RQwDwYDVR0T +AQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAYYwDQYJKoZIhvcNAQELBQADggIBADaN +l8xCFWQpN5smLNb7rhVpLGsaGvdftvkHTFnq88nIua7Mui563MD1sC3AO6+fcAUR +ap8lTwEpcOPlDOHqWnzcSbvBHiqB9RZLcpHIojG5qtr8nR/zXUACE/xOHAbKsxSQ +VBcZEhrxH9cMaVr2cXj0lH2RC47skFSOvG+hTKv8dGT9cZr4QQehzZHkPJrgmzI5 +c6sq1WnIeJEmMX3ixzDx/BR4dxIOE/TdFpS/S2d7cFOFyrC78zhNLJA5wA3CXWvp +4uXViI3WLL+rG761KIcSF3Ru/H38j9CHJrAb+7lsq+KePRXBOy5nAliRn+/4Qh8s +t2j1da3Ptfb/EX3C8CSlrdP6oDyp+l3cpaDvRKS+1ujl5BOWF3sGPjLtx7dCvHaj +2GU4Kzg1USEODm8uNBNA4StnDG1KQTAYI1oyVZnJF+A83vbsea0rWBmirSwiGpWO +vpaQXUJXxPkUAzUrHC1RVwinOt4/5Mi0A3PCwSaAuwtCH60NryZy2sy+s6ODWA2C +xR9GUeOcGMyNm43sSet1UNWMKFnKdDTajAshqx7qG+XH/RU+wBeq+yNuJkbL+vmx +cmtpzyKEC2IPrNkZAJSidjzULZrtBJ4tBmIQN1IchXIbJ+XMxjHsN+xjWZsLHXbM +fjKaiJUINlK73nZfdklJrX+9ZSCyycErdhh2n1ax +-----END CERTIFICATE----- + +# Issuer: CN=Certigna Root CA O=Dhimyotis OU=0002 48146308100036 +# Subject: CN=Certigna Root CA O=Dhimyotis OU=0002 48146308100036 +# Label: "Certigna Root CA" +# Serial: 269714418870597844693661054334862075617 +# MD5 Fingerprint: 0e:5c:30:62:27:eb:5b:bc:d7:ae:62:ba:e9:d5:df:77 +# SHA1 Fingerprint: 2d:0d:52:14:ff:9e:ad:99:24:01:74:20:47:6e:6c:85:27:27:f5:43 +# SHA256 Fingerprint: d4:8d:3d:23:ee:db:50:a4:59:e5:51:97:60:1c:27:77:4b:9d:7b:18:c9:4d:5a:05:95:11:a1:02:50:b9:31:68 +-----BEGIN CERTIFICATE----- +MIIGWzCCBEOgAwIBAgIRAMrpG4nxVQMNo+ZBbcTjpuEwDQYJKoZIhvcNAQELBQAw +WjELMAkGA1UEBhMCRlIxEjAQBgNVBAoMCURoaW15b3RpczEcMBoGA1UECwwTMDAw +MiA0ODE0NjMwODEwMDAzNjEZMBcGA1UEAwwQQ2VydGlnbmEgUm9vdCBDQTAeFw0x +MzEwMDEwODMyMjdaFw0zMzEwMDEwODMyMjdaMFoxCzAJBgNVBAYTAkZSMRIwEAYD +VQQKDAlEaGlteW90aXMxHDAaBgNVBAsMEzAwMDIgNDgxNDYzMDgxMDAwMzYxGTAX +BgNVBAMMEENlcnRpZ25hIFJvb3QgQ0EwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAw +ggIKAoICAQDNGDllGlmx6mQWDoyUJJV8g9PFOSbcDO8WV43X2KyjQn+Cyu3NW9sO +ty3tRQgXstmzy9YXUnIo245Onoq2C/mehJpNdt4iKVzSs9IGPjA5qXSjklYcoW9M +CiBtnyN6tMbaLOQdLNyzKNAT8kxOAkmhVECe5uUFoC2EyP+YbNDrihqECB63aCPu +I9Vwzm1RaRDuoXrC0SIxwoKF0vJVdlB8JXrJhFwLrN1CTivngqIkicuQstDuI7pm +TLtipPlTWmR7fJj6o0ieD5Wupxj0auwuA0Wv8HT4Ks16XdG+RCYyKfHx9WzMfgIh +C59vpD++nVPiz32pLHxYGpfhPTc3GGYo0kDFUYqMwy3OU4gkWGQwFsWq4NYKpkDf +ePb1BHxpE4S80dGnBs8B92jAqFe7OmGtBIyT46388NtEbVncSVmurJqZNjBBe3Yz +IoejwpKGbvlw7q6Hh5UbxHq9MfPU0uWZ/75I7HX1eBYdpnDBfzwboZL7z8g81sWT +Co/1VTp2lc5ZmIoJlXcymoO6LAQ6l73UL77XbJuiyn1tJslV1c/DeVIICZkHJC1k +JWumIWmbat10TWuXekG9qxf5kBdIjzb5LdXF2+6qhUVB+s06RbFo5jZMm5BX7CO5 +hwjCxAnxl4YqKE3idMDaxIzb3+KhF1nOJFl0Mdp//TBt2dzhauH8XwIDAQABo4IB +GjCCARYwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYE +FBiHVuBud+4kNTxOc5of1uHieX4rMB8GA1UdIwQYMBaAFBiHVuBud+4kNTxOc5of +1uHieX4rMEQGA1UdIAQ9MDswOQYEVR0gADAxMC8GCCsGAQUFBwIBFiNodHRwczov +L3d3d3cuY2VydGlnbmEuZnIvYXV0b3JpdGVzLzBtBgNVHR8EZjBkMC+gLaArhilo +dHRwOi8vY3JsLmNlcnRpZ25hLmZyL2NlcnRpZ25hcm9vdGNhLmNybDAxoC+gLYYr +aHR0cDovL2NybC5kaGlteW90aXMuY29tL2NlcnRpZ25hcm9vdGNhLmNybDANBgkq +hkiG9w0BAQsFAAOCAgEAlLieT/DjlQgi581oQfccVdV8AOItOoldaDgvUSILSo3L +6btdPrtcPbEo/uRTVRPPoZAbAh1fZkYJMyjhDSSXcNMQH+pkV5a7XdrnxIxPTGRG +HVyH41neQtGbqH6mid2PHMkwgu07nM3A6RngatgCdTer9zQoKJHyBApPNeNgJgH6 +0BGM+RFq7q89w1DTj18zeTyGqHNFkIwgtnJzFyO+B2XleJINugHA64wcZr+shncB +lA2c5uk5jR+mUYyZDDl34bSb+hxnV29qao6pK0xXeXpXIs/NX2NGjVxZOob4Mkdi +o2cNGJHc+6Zr9UhhcyNZjgKnvETq9Emd8VRY+WCv2hikLyhF3HqgiIZd8zvn/yk1 +gPxkQ5Tm4xxvvq0OKmOZK8l+hfZx6AYDlf7ej0gcWtSS6Cvu5zHbugRqh5jnxV/v +faci9wHYTfmJ0A6aBVmknpjZbyvKcL5kwlWj9Omvw5Ip3IgWJJk8jSaYtlu3zM63 +Nwf9JtmYhST/WSMDmu2dnajkXjjO11INb9I/bbEFa0nOipFGc/T2L/Coc3cOZayh +jWZSaX5LaAzHHjcng6WMxwLkFM1JAbBzs/3GkDpv0mztO+7skb6iQ12LAEpmJURw +3kAP+HwV96LOPNdeE4yBFxgX0b3xdxA61GU5wSesVywlVP+i2k+KYTlerj1KjL0= +-----END CERTIFICATE----- + +# Issuer: CN=emSign Root CA - G1 O=eMudhra Technologies Limited OU=emSign PKI +# Subject: CN=emSign Root CA - G1 O=eMudhra Technologies Limited OU=emSign PKI +# Label: "emSign Root CA - G1" +# Serial: 235931866688319308814040 +# MD5 Fingerprint: 9c:42:84:57:dd:cb:0b:a7:2e:95:ad:b6:f3:da:bc:ac +# SHA1 Fingerprint: 8a:c7:ad:8f:73:ac:4e:c1:b5:75:4d:a5:40:f4:fc:cf:7c:b5:8e:8c +# SHA256 Fingerprint: 40:f6:af:03:46:a9:9a:a1:cd:1d:55:5a:4e:9c:ce:62:c7:f9:63:46:03:ee:40:66:15:83:3d:c8:c8:d0:03:67 +-----BEGIN CERTIFICATE----- +MIIDlDCCAnygAwIBAgIKMfXkYgxsWO3W2DANBgkqhkiG9w0BAQsFADBnMQswCQYD +VQQGEwJJTjETMBEGA1UECxMKZW1TaWduIFBLSTElMCMGA1UEChMcZU11ZGhyYSBU +ZWNobm9sb2dpZXMgTGltaXRlZDEcMBoGA1UEAxMTZW1TaWduIFJvb3QgQ0EgLSBH +MTAeFw0xODAyMTgxODMwMDBaFw00MzAyMTgxODMwMDBaMGcxCzAJBgNVBAYTAklO +MRMwEQYDVQQLEwplbVNpZ24gUEtJMSUwIwYDVQQKExxlTXVkaHJhIFRlY2hub2xv +Z2llcyBMaW1pdGVkMRwwGgYDVQQDExNlbVNpZ24gUm9vdCBDQSAtIEcxMIIBIjAN +BgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAk0u76WaK7p1b1TST0Bsew+eeuGQz +f2N4aLTNLnF115sgxk0pvLZoYIr3IZpWNVrzdr3YzZr/k1ZLpVkGoZM0Kd0WNHVO +8oG0x5ZOrRkVUkr+PHB1cM2vK6sVmjM8qrOLqs1D/fXqcP/tzxE7lM5OMhbTI0Aq +d7OvPAEsbO2ZLIvZTmmYsvePQbAyeGHWDV/D+qJAkh1cF+ZwPjXnorfCYuKrpDhM +tTk1b+oDafo6VGiFbdbyL0NVHpENDtjVaqSW0RM8LHhQ6DqS0hdW5TUaQBw+jSzt +Od9C4INBdN+jzcKGYEho42kLVACL5HZpIQ15TjQIXhTCzLG3rdd8cIrHhQIDAQAB +o0IwQDAdBgNVHQ4EFgQU++8Nhp6w492pufEhF38+/PB3KxowDgYDVR0PAQH/BAQD +AgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQELBQADggEBAFn/8oz1h31x +PaOfG1vR2vjTnGs2vZupYeveFix0PZ7mddrXuqe8QhfnPZHr5X3dPpzxz5KsbEjM +wiI/aTvFthUvozXGaCocV685743QNcMYDHsAVhzNixl03r4PEuDQqqE/AjSxcM6d +GNYIAwlG7mDgfrbESQRRfXBgvKqy/3lyeqYdPV8q+Mri/Tm3R7nrft8EI6/6nAYH +6ftjk4BAtcZsCjEozgyfz7MjNYBBjWzEN3uBL4ChQEKF6dk4jeihU80Bv2noWgby +RQuQ+q7hv53yrlc8pa6yVvSLZUDp/TGBLPQ5Cdjua6e0ph0VpZj3AYHYhX3zUVxx +iN66zB+Afko= +-----END CERTIFICATE----- + +# Issuer: CN=emSign ECC Root CA - G3 O=eMudhra Technologies Limited OU=emSign PKI +# Subject: CN=emSign ECC Root CA - G3 O=eMudhra Technologies Limited OU=emSign PKI +# Label: "emSign ECC Root CA - G3" +# Serial: 287880440101571086945156 +# MD5 Fingerprint: ce:0b:72:d1:9f:88:8e:d0:50:03:e8:e3:b8:8b:67:40 +# SHA1 Fingerprint: 30:43:fa:4f:f2:57:dc:a0:c3:80:ee:2e:58:ea:78:b2:3f:e6:bb:c1 +# SHA256 Fingerprint: 86:a1:ec:ba:08:9c:4a:8d:3b:be:27:34:c6:12:ba:34:1d:81:3e:04:3c:f9:e8:a8:62:cd:5c:57:a3:6b:be:6b +-----BEGIN CERTIFICATE----- +MIICTjCCAdOgAwIBAgIKPPYHqWhwDtqLhDAKBggqhkjOPQQDAzBrMQswCQYDVQQG +EwJJTjETMBEGA1UECxMKZW1TaWduIFBLSTElMCMGA1UEChMcZU11ZGhyYSBUZWNo +bm9sb2dpZXMgTGltaXRlZDEgMB4GA1UEAxMXZW1TaWduIEVDQyBSb290IENBIC0g +RzMwHhcNMTgwMjE4MTgzMDAwWhcNNDMwMjE4MTgzMDAwWjBrMQswCQYDVQQGEwJJ +TjETMBEGA1UECxMKZW1TaWduIFBLSTElMCMGA1UEChMcZU11ZGhyYSBUZWNobm9s +b2dpZXMgTGltaXRlZDEgMB4GA1UEAxMXZW1TaWduIEVDQyBSb290IENBIC0gRzMw +djAQBgcqhkjOPQIBBgUrgQQAIgNiAAQjpQy4LRL1KPOxst3iAhKAnjlfSU2fySU0 +WXTsuwYc58Byr+iuL+FBVIcUqEqy6HyC5ltqtdyzdc6LBtCGI79G1Y4PPwT01xyS +fvalY8L1X44uT6EYGQIrMgqCZH0Wk9GjQjBAMB0GA1UdDgQWBBR8XQKEE9TMipuB +zhccLikenEhjQjAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAKBggq +hkjOPQQDAwNpADBmAjEAvvNhzwIQHWSVB7gYboiFBS+DCBeQyh+KTOgNG3qxrdWB +CUfvO6wIBHxcmbHtRwfSAjEAnbpV/KlK6O3t5nYBQnvI+GDZjVGLVTv7jHvrZQnD ++JbNR6iC8hZVdyR+EhCVBCyj +-----END CERTIFICATE----- + +# Issuer: CN=emSign Root CA - C1 O=eMudhra Inc OU=emSign PKI +# Subject: CN=emSign Root CA - C1 O=eMudhra Inc OU=emSign PKI +# Label: "emSign Root CA - C1" +# Serial: 825510296613316004955058 +# MD5 Fingerprint: d8:e3:5d:01:21:fa:78:5a:b0:df:ba:d2:ee:2a:5f:68 +# SHA1 Fingerprint: e7:2e:f1:df:fc:b2:09:28:cf:5d:d4:d5:67:37:b1:51:cb:86:4f:01 +# SHA256 Fingerprint: 12:56:09:aa:30:1d:a0:a2:49:b9:7a:82:39:cb:6a:34:21:6f:44:dc:ac:9f:39:54:b1:42:92:f2:e8:c8:60:8f +-----BEGIN CERTIFICATE----- +MIIDczCCAlugAwIBAgILAK7PALrEzzL4Q7IwDQYJKoZIhvcNAQELBQAwVjELMAkG +A1UEBhMCVVMxEzARBgNVBAsTCmVtU2lnbiBQS0kxFDASBgNVBAoTC2VNdWRocmEg +SW5jMRwwGgYDVQQDExNlbVNpZ24gUm9vdCBDQSAtIEMxMB4XDTE4MDIxODE4MzAw +MFoXDTQzMDIxODE4MzAwMFowVjELMAkGA1UEBhMCVVMxEzARBgNVBAsTCmVtU2ln +biBQS0kxFDASBgNVBAoTC2VNdWRocmEgSW5jMRwwGgYDVQQDExNlbVNpZ24gUm9v +dCBDQSAtIEMxMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAz+upufGZ +BczYKCFK83M0UYRWEPWgTywS4/oTmifQz/l5GnRfHXk5/Fv4cI7gklL35CX5VIPZ +HdPIWoU/Xse2B+4+wM6ar6xWQio5JXDWv7V7Nq2s9nPczdcdioOl+yuQFTdrHCZH +3DspVpNqs8FqOp099cGXOFgFixwR4+S0uF2FHYP+eF8LRWgYSKVGczQ7/g/IdrvH +GPMF0Ybzhe3nudkyrVWIzqa2kbBPrH4VI5b2P/AgNBbeCsbEBEV5f6f9vtKppa+c +xSMq9zwhbL2vj07FOrLzNBL834AaSaTUqZX3noleoomslMuoaJuvimUnzYnu3Yy1 +aylwQ6BpC+S5DwIDAQABo0IwQDAdBgNVHQ4EFgQU/qHgcB4qAzlSWkK+XJGFehiq +TbUwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEL +BQADggEBAMJKVvoVIXsoounlHfv4LcQ5lkFMOycsxGwYFYDGrK9HWS8mC+M2sO87 +/kOXSTKZEhVb3xEp/6tT+LvBeA+snFOvV71ojD1pM/CjoCNjO2RnIkSt1XHLVip4 +kqNPEjE2NuLe/gDEo2APJ62gsIq1NnpSob0n9CAnYuhNlCQT5AoE6TyrLshDCUrG +YQTlSTR+08TI9Q/Aqum6VF7zYytPT1DU/rl7mYw9wC68AivTxEDkigcxHpvOJpkT ++xHqmiIMERnHXhuBUDDIlhJu58tBf5E7oke3VIAb3ADMmpDqw8NQBmIMMMAVSKeo +WXzhriKi4gp6D/piq1JM4fHfyr6DDUI= +-----END CERTIFICATE----- + +# Issuer: CN=emSign ECC Root CA - C3 O=eMudhra Inc OU=emSign PKI +# Subject: CN=emSign ECC Root CA - C3 O=eMudhra Inc OU=emSign PKI +# Label: "emSign ECC Root CA - C3" +# Serial: 582948710642506000014504 +# MD5 Fingerprint: 3e:53:b3:a3:81:ee:d7:10:f8:d3:b0:1d:17:92:f5:d5 +# SHA1 Fingerprint: b6:af:43:c2:9b:81:53:7d:f6:ef:6b:c3:1f:1f:60:15:0c:ee:48:66 +# SHA256 Fingerprint: bc:4d:80:9b:15:18:9d:78:db:3e:1d:8c:f4:f9:72:6a:79:5d:a1:64:3c:a5:f1:35:8e:1d:db:0e:dc:0d:7e:b3 +-----BEGIN CERTIFICATE----- +MIICKzCCAbGgAwIBAgIKe3G2gla4EnycqDAKBggqhkjOPQQDAzBaMQswCQYDVQQG +EwJVUzETMBEGA1UECxMKZW1TaWduIFBLSTEUMBIGA1UEChMLZU11ZGhyYSBJbmMx +IDAeBgNVBAMTF2VtU2lnbiBFQ0MgUm9vdCBDQSAtIEMzMB4XDTE4MDIxODE4MzAw +MFoXDTQzMDIxODE4MzAwMFowWjELMAkGA1UEBhMCVVMxEzARBgNVBAsTCmVtU2ln +biBQS0kxFDASBgNVBAoTC2VNdWRocmEgSW5jMSAwHgYDVQQDExdlbVNpZ24gRUND +IFJvb3QgQ0EgLSBDMzB2MBAGByqGSM49AgEGBSuBBAAiA2IABP2lYa57JhAd6bci +MK4G9IGzsUJxlTm801Ljr6/58pc1kjZGDoeVjbk5Wum739D+yAdBPLtVb4Ojavti +sIGJAnB9SMVK4+kiVCJNk7tCDK93nCOmfddhEc5lx/h//vXyqaNCMEAwHQYDVR0O +BBYEFPtaSNCAIEDyqOkAB2kZd6fmw/TPMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMB +Af8EBTADAQH/MAoGCCqGSM49BAMDA2gAMGUCMQC02C8Cif22TGK6Q04ThHK1rt0c +3ta13FaPWEBaLd4gTCKDypOofu4SQMfWh0/434UCMBwUZOR8loMRnLDRWmFLpg9J +0wD8ofzkpf9/rdcw0Md3f76BB1UwUCAU9Vc4CqgxUQ== +-----END CERTIFICATE----- + +# Issuer: CN=Hongkong Post Root CA 3 O=Hongkong Post +# Subject: CN=Hongkong Post Root CA 3 O=Hongkong Post +# Label: "Hongkong Post Root CA 3" +# Serial: 46170865288971385588281144162979347873371282084 +# MD5 Fingerprint: 11:fc:9f:bd:73:30:02:8a:fd:3f:f3:58:b9:cb:20:f0 +# SHA1 Fingerprint: 58:a2:d0:ec:20:52:81:5b:c1:f3:f8:64:02:24:4e:c2:8e:02:4b:02 +# SHA256 Fingerprint: 5a:2f:c0:3f:0c:83:b0:90:bb:fa:40:60:4b:09:88:44:6c:76:36:18:3d:f9:84:6e:17:10:1a:44:7f:b8:ef:d6 +-----BEGIN CERTIFICATE----- +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 +mpv0 +-----END CERTIFICATE----- + +# Issuer: CN=Entrust Root Certification Authority - G4 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2015 Entrust, Inc. - for authorized use only +# Subject: CN=Entrust Root Certification Authority - G4 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2015 Entrust, Inc. - for authorized use only +# Label: "Entrust Root Certification Authority - G4" +# Serial: 289383649854506086828220374796556676440 +# MD5 Fingerprint: 89:53:f1:83:23:b7:7c:8e:05:f1:8c:71:38:4e:1f:88 +# SHA1 Fingerprint: 14:88:4e:86:26:37:b0:26:af:59:62:5c:40:77:ec:35:29:ba:96:01 +# SHA256 Fingerprint: db:35:17:d1:f6:73:2a:2d:5a:b9:7c:53:3e:c7:07:79:ee:32:70:a6:2f:b4:ac:42:38:37:24:60:e6:f0:1e:88 +-----BEGIN CERTIFICATE----- +MIIGSzCCBDOgAwIBAgIRANm1Q3+vqTkPAAAAAFVlrVgwDQYJKoZIhvcNAQELBQAw +gb4xCzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1FbnRydXN0LCBJbmMuMSgwJgYDVQQL +Ex9TZWUgd3d3LmVudHJ1c3QubmV0L2xlZ2FsLXRlcm1zMTkwNwYDVQQLEzAoYykg +MjAxNSBFbnRydXN0LCBJbmMuIC0gZm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxMjAw +BgNVBAMTKUVudHJ1c3QgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIEc0 +MB4XDTE1MDUyNzExMTExNloXDTM3MTIyNzExNDExNlowgb4xCzAJBgNVBAYTAlVT +MRYwFAYDVQQKEw1FbnRydXN0LCBJbmMuMSgwJgYDVQQLEx9TZWUgd3d3LmVudHJ1 +c3QubmV0L2xlZ2FsLXRlcm1zMTkwNwYDVQQLEzAoYykgMjAxNSBFbnRydXN0LCBJ +bmMuIC0gZm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxMjAwBgNVBAMTKUVudHJ1c3Qg +Um9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIEc0MIICIjANBgkqhkiG9w0B +AQEFAAOCAg8AMIICCgKCAgEAsewsQu7i0TD/pZJH4i3DumSXbcr3DbVZwbPLqGgZ +2K+EbTBwXX7zLtJTmeH+H17ZSK9dE43b/2MzTdMAArzE+NEGCJR5WIoV3imz/f3E +T+iq4qA7ec2/a0My3dl0ELn39GjUu9CH1apLiipvKgS1sqbHoHrmSKvS0VnM1n4j +5pds8ELl3FFLFUHtSUrJ3hCX1nbB76W1NhSXNdh4IjVS70O92yfbYVaCNNzLiGAM +C1rlLAHGVK/XqsEQe9IFWrhAnoanw5CGAlZSCXqc0ieCU0plUmr1POeo8pyvi73T +DtTUXm6Hnmo9RR3RXRv06QqsYJn7ibT/mCzPfB3pAqoEmh643IhuJbNsZvc8kPNX +wbMv9W3y+8qh+CmdRouzavbmZwe+LGcKKh9asj5XxNMhIWNlUpEbsZmOeX7m640A +2Vqq6nPopIICR5b+W45UYaPrL0swsIsjdXJ8ITzI9vF01Bx7owVV7rtNOzK+mndm +nqxpkCIHH2E6lr7lmk/MBTwoWdPBDFSoWWG9yHJM6Nyfh3+9nEg2XpWjDrk4JFX8 +dWbrAuMINClKxuMrLzOg2qOGpRKX/YAr2hRC45K9PvJdXmd0LhyIRyk0X+IyqJwl +N4y6mACXi0mWHv0liqzc2thddG5msP9E36EYxr5ILzeUePiVSj9/E15dWf10hkNj +c0kCAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYD +VR0OBBYEFJ84xFYjwznooHFs6FRM5Og6sb9nMA0GCSqGSIb3DQEBCwUAA4ICAQAS +5UKme4sPDORGpbZgQIeMJX6tuGguW8ZAdjwD+MlZ9POrYs4QjbRaZIxowLByQzTS +Gwv2LFPSypBLhmb8qoMi9IsabyZIrHZ3CL/FmFz0Jomee8O5ZDIBf9PD3Vht7LGr +hFV0d4QEJ1JrhkzO3bll/9bGXp+aEJlLdWr+aumXIOTkdnrG0CSqkM0gkLpHZPt/ +B7NTeLUKYvJzQ85BK4FqLoUWlFPUa19yIqtRLULVAJyZv967lDtX/Zr1hstWO1uI +AeV8KEsD+UmDfLJ/fOPtjqF/YFOOVZ1QNBIPt5d7bIdKROf1beyAN/BYGW5KaHbw +H5Lk6rWS02FREAutp9lfx1/cH6NcjKF+m7ee01ZvZl4HliDtC3T7Zk6LERXpgUl+ +b7DUUH8i119lAg2m9IUe2K4GS0qn0jFmwvjO5QimpAKWRGhXxNUzzxkvFMSUHHuk +2fCfDrGA4tGeEWSpiBE6doLlYsKA2KSD7ZPvfC+QsDJMlhVoSFLUmQjAJOgc47Ol +IQ6SwJAfzyBfyjs4x7dtOvPmRLgOMWuIjnDrnBdSqEGULoe256YSxXXfW8AKbnuk +5F6G+TaU33fD6Q3AOfF5u0aOq0NZJ7cguyPpVkAh7DE9ZapD8j3fcEThuk0mEDuY +n/PIjhs4ViFqUZPTkcpG2om3PVODLAgfi49T3f+sHw== +-----END CERTIFICATE----- + +# Issuer: CN=Microsoft ECC Root Certificate Authority 2017 O=Microsoft Corporation +# Subject: CN=Microsoft ECC Root Certificate Authority 2017 O=Microsoft Corporation +# Label: "Microsoft ECC Root Certificate Authority 2017" +# Serial: 136839042543790627607696632466672567020 +# MD5 Fingerprint: dd:a1:03:e6:4a:93:10:d1:bf:f0:19:42:cb:fe:ed:67 +# SHA1 Fingerprint: 99:9a:64:c3:7f:f4:7d:9f:ab:95:f1:47:69:89:14:60:ee:c4:c3:c5 +# SHA256 Fingerprint: 35:8d:f3:9d:76:4a:f9:e1:b7:66:e9:c9:72:df:35:2e:e1:5c:fa:c2:27:af:6a:d1:d7:0e:8e:4a:6e:dc:ba:02 +-----BEGIN CERTIFICATE----- +MIICWTCCAd+gAwIBAgIQZvI9r4fei7FK6gxXMQHC7DAKBggqhkjOPQQDAzBlMQsw +CQYDVQQGEwJVUzEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTYwNAYD +VQQDEy1NaWNyb3NvZnQgRUNDIFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5IDIw +MTcwHhcNMTkxMjE4MjMwNjQ1WhcNNDIwNzE4MjMxNjA0WjBlMQswCQYDVQQGEwJV +UzEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTYwNAYDVQQDEy1NaWNy +b3NvZnQgRUNDIFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5IDIwMTcwdjAQBgcq +hkjOPQIBBgUrgQQAIgNiAATUvD0CQnVBEyPNgASGAlEvaqiBYgtlzPbKnR5vSmZR +ogPZnZH6thaxjG7efM3beaYvzrvOcS/lpaso7GMEZpn4+vKTEAXhgShC48Zo9OYb +hGBKia/teQ87zvH2RPUBeMCjVDBSMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8E +BTADAQH/MB0GA1UdDgQWBBTIy5lycFIM+Oa+sgRXKSrPQhDtNTAQBgkrBgEEAYI3 +FQEEAwIBADAKBggqhkjOPQQDAwNoADBlAjBY8k3qDPlfXu5gKcs68tvWMoQZP3zV +L8KxzJOuULsJMsbG7X7JNpQS5GiFBqIb0C8CMQCZ6Ra0DvpWSNSkMBaReNtUjGUB +iudQZsIxtzm6uBoiB078a1QWIP8rtedMDE2mT3M= +-----END CERTIFICATE----- + +# Issuer: CN=Microsoft RSA Root Certificate Authority 2017 O=Microsoft Corporation +# Subject: CN=Microsoft RSA Root Certificate Authority 2017 O=Microsoft Corporation +# Label: "Microsoft RSA Root Certificate Authority 2017" +# Serial: 40975477897264996090493496164228220339 +# MD5 Fingerprint: 10:ff:00:ff:cf:c9:f8:c7:7a:c0:ee:35:8e:c9:0f:47 +# SHA1 Fingerprint: 73:a5:e6:4a:3b:ff:83:16:ff:0e:dc:cc:61:8a:90:6e:4e:ae:4d:74 +# SHA256 Fingerprint: c7:41:f7:0f:4b:2a:8d:88:bf:2e:71:c1:41:22:ef:53:ef:10:eb:a0:cf:a5:e6:4c:fa:20:f4:18:85:30:73:e0 +-----BEGIN CERTIFICATE----- +MIIFqDCCA5CgAwIBAgIQHtOXCV/YtLNHcB6qvn9FszANBgkqhkiG9w0BAQwFADBl +MQswCQYDVQQGEwJVUzEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTYw +NAYDVQQDEy1NaWNyb3NvZnQgUlNBIFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5 +IDIwMTcwHhcNMTkxMjE4MjI1MTIyWhcNNDIwNzE4MjMwMDIzWjBlMQswCQYDVQQG +EwJVUzEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTYwNAYDVQQDEy1N +aWNyb3NvZnQgUlNBIFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5IDIwMTcwggIi +MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDKW76UM4wplZEWCpW9R2LBifOZ +Nt9GkMml7Xhqb0eRaPgnZ1AzHaGm++DlQ6OEAlcBXZxIQIJTELy/xztokLaCLeX0 +ZdDMbRnMlfl7rEqUrQ7eS0MdhweSE5CAg2Q1OQT85elss7YfUJQ4ZVBcF0a5toW1 +HLUX6NZFndiyJrDKxHBKrmCk3bPZ7Pw71VdyvD/IybLeS2v4I2wDwAW9lcfNcztm +gGTjGqwu+UcF8ga2m3P1eDNbx6H7JyqhtJqRjJHTOoI+dkC0zVJhUXAoP8XFWvLJ +jEm7FFtNyP9nTUwSlq31/niol4fX/V4ggNyhSyL71Imtus5Hl0dVe49FyGcohJUc +aDDv70ngNXtk55iwlNpNhTs+VcQor1fznhPbRiefHqJeRIOkpcrVE7NLP8TjwuaG +YaRSMLl6IE9vDzhTyzMMEyuP1pq9KsgtsRx9S1HKR9FIJ3Jdh+vVReZIZZ2vUpC6 +W6IYZVcSn2i51BVrlMRpIpj0M+Dt+VGOQVDJNE92kKz8OMHY4Xu54+OU4UZpyw4K +UGsTuqwPN1q3ErWQgR5WrlcihtnJ0tHXUeOrO8ZV/R4O03QK0dqq6mm4lyiPSMQH ++FJDOvTKVTUssKZqwJz58oHhEmrARdlns87/I6KJClTUFLkqqNfs+avNJVgyeY+Q +W5g5xAgGwax/Dj0ApQIDAQABo1QwUjAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/ +BAUwAwEB/zAdBgNVHQ4EFgQUCctZf4aycI8awznjwNnpv7tNsiMwEAYJKwYBBAGC +NxUBBAMCAQAwDQYJKoZIhvcNAQEMBQADggIBAKyvPl3CEZaJjqPnktaXFbgToqZC +LgLNFgVZJ8og6Lq46BrsTaiXVq5lQ7GPAJtSzVXNUzltYkyLDVt8LkS/gxCP81OC +gMNPOsduET/m4xaRhPtthH80dK2Jp86519efhGSSvpWhrQlTM93uCupKUY5vVau6 +tZRGrox/2KJQJWVggEbbMwSubLWYdFQl3JPk+ONVFT24bcMKpBLBaYVu32TxU5nh +SnUgnZUP5NbcA/FZGOhHibJXWpS2qdgXKxdJ5XbLwVaZOjex/2kskZGT4d9Mozd2 +TaGf+G0eHdP67Pv0RR0Tbc/3WeUiJ3IrhvNXuzDtJE3cfVa7o7P4NHmJweDyAmH3 +pvwPuxwXC65B2Xy9J6P9LjrRk5Sxcx0ki69bIImtt2dmefU6xqaWM/5TkshGsRGR +xpl/j8nWZjEgQRCHLQzWwa80mMpkg/sTV9HB8Dx6jKXB/ZUhoHHBk2dxEuqPiApp +GWSZI1b7rCoucL5mxAyE7+WL85MB+GqQk2dLsmijtWKP6T+MejteD+eMuMZ87zf9 +dOLITzNy4ZQ5bb0Sr74MTnB8G2+NszKTc0QWbej09+CVgI+WXTik9KveCjCHk9hN +AHFiRSdLOkKEW39lt2c0Ui2cFmuqqNh7o0JMcccMyj6D5KbvtwEwXlGjefVwaaZB +RA+GsCyRxj3qrg+E +-----END CERTIFICATE----- + +# Issuer: CN=e-Szigno Root CA 2017 O=Microsec Ltd. +# Subject: CN=e-Szigno Root CA 2017 O=Microsec Ltd. +# Label: "e-Szigno Root CA 2017" +# Serial: 411379200276854331539784714 +# MD5 Fingerprint: de:1f:f6:9e:84:ae:a7:b4:21:ce:1e:58:7d:d1:84:98 +# SHA1 Fingerprint: 89:d4:83:03:4f:9e:9a:48:80:5f:72:37:d4:a9:a6:ef:cb:7c:1f:d1 +# SHA256 Fingerprint: be:b0:0b:30:83:9b:9b:c3:2c:32:e4:44:79:05:95:06:41:f2:64:21:b1:5e:d0:89:19:8b:51:8a:e2:ea:1b:99 +-----BEGIN CERTIFICATE----- +MIICQDCCAeWgAwIBAgIMAVRI7yH9l1kN9QQKMAoGCCqGSM49BAMCMHExCzAJBgNV +BAYTAkhVMREwDwYDVQQHDAhCdWRhcGVzdDEWMBQGA1UECgwNTWljcm9zZWMgTHRk +LjEXMBUGA1UEYQwOVkFUSFUtMjM1ODQ0OTcxHjAcBgNVBAMMFWUtU3ppZ25vIFJv +b3QgQ0EgMjAxNzAeFw0xNzA4MjIxMjA3MDZaFw00MjA4MjIxMjA3MDZaMHExCzAJ +BgNVBAYTAkhVMREwDwYDVQQHDAhCdWRhcGVzdDEWMBQGA1UECgwNTWljcm9zZWMg +THRkLjEXMBUGA1UEYQwOVkFUSFUtMjM1ODQ0OTcxHjAcBgNVBAMMFWUtU3ppZ25v +IFJvb3QgQ0EgMjAxNzBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABJbcPYrYsHtv +xie+RJCxs1YVe45DJH0ahFnuY2iyxl6H0BVIHqiQrb1TotreOpCmYF9oMrWGQd+H +Wyx7xf58etqjYzBhMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0G +A1UdDgQWBBSHERUI0arBeAyxr87GyZDvvzAEwDAfBgNVHSMEGDAWgBSHERUI0arB +eAyxr87GyZDvvzAEwDAKBggqhkjOPQQDAgNJADBGAiEAtVfd14pVCzbhhkT61Nlo +jbjcI4qKDdQvfepz7L9NbKgCIQDLpbQS+ue16M9+k/zzNY9vTlp8tLxOsvxyqltZ ++efcMQ== +-----END CERTIFICATE----- + +# Issuer: O=CERTSIGN SA OU=certSIGN ROOT CA G2 +# Subject: O=CERTSIGN SA OU=certSIGN ROOT CA G2 +# Label: "certSIGN Root CA G2" +# Serial: 313609486401300475190 +# MD5 Fingerprint: 8c:f1:75:8a:c6:19:cf:94:b7:f7:65:20:87:c3:97:c7 +# SHA1 Fingerprint: 26:f9:93:b4:ed:3d:28:27:b0:b9:4b:a7:e9:15:1d:a3:8d:92:e5:32 +# SHA256 Fingerprint: 65:7c:fe:2f:a7:3f:aa:38:46:25:71:f3:32:a2:36:3a:46:fc:e7:02:09:51:71:07:02:cd:fb:b6:ee:da:33:05 +-----BEGIN CERTIFICATE----- +MIIFRzCCAy+gAwIBAgIJEQA0tk7GNi02MA0GCSqGSIb3DQEBCwUAMEExCzAJBgNV +BAYTAlJPMRQwEgYDVQQKEwtDRVJUU0lHTiBTQTEcMBoGA1UECxMTY2VydFNJR04g +Uk9PVCBDQSBHMjAeFw0xNzAyMDYwOTI3MzVaFw00MjAyMDYwOTI3MzVaMEExCzAJ +BgNVBAYTAlJPMRQwEgYDVQQKEwtDRVJUU0lHTiBTQTEcMBoGA1UECxMTY2VydFNJ +R04gUk9PVCBDQSBHMjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMDF +dRmRfUR0dIf+DjuW3NgBFszuY5HnC2/OOwppGnzC46+CjobXXo9X69MhWf05N0Iw +vlDqtg+piNguLWkh59E3GE59kdUWX2tbAMI5Qw02hVK5U2UPHULlj88F0+7cDBrZ +uIt4ImfkabBoxTzkbFpG583H+u/E7Eu9aqSs/cwoUe+StCmrqzWaTOTECMYmzPhp +n+Sc8CnTXPnGFiWeI8MgwT0PPzhAsP6CRDiqWhqKa2NYOLQV07YRaXseVO6MGiKs +cpc/I1mbySKEwQdPzH/iV8oScLumZfNpdWO9lfsbl83kqK/20U6o2YpxJM02PbyW +xPFsqa7lzw1uKA2wDrXKUXt4FMMgL3/7FFXhEZn91QqhngLjYl/rNUssuHLoPj1P +rCy7Lobio3aP5ZMqz6WryFyNSwb/EkaseMsUBzXgqd+L6a8VTxaJW732jcZZroiF +DsGJ6x9nxUWO/203Nit4ZoORUSs9/1F3dmKh7Gc+PoGD4FapUB8fepmrY7+EF3fx +DTvf95xhszWYijqy7DwaNz9+j5LP2RIUZNoQAhVB/0/E6xyjyfqZ90bp4RjZsbgy +LcsUDFDYg2WD7rlcz8sFWkz6GZdr1l0T08JcVLwyc6B49fFtHsufpaafItzRUZ6C +eWRgKRM+o/1Pcmqr4tTluCRVLERLiohEnMqE0yo7AgMBAAGjQjBAMA8GA1UdEwEB +/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBSCIS1mxteg4BXrzkwJ +d8RgnlRuAzANBgkqhkiG9w0BAQsFAAOCAgEAYN4auOfyYILVAzOBywaK8SJJ6ejq +kX/GM15oGQOGO0MBzwdw5AgeZYWR5hEit/UCI46uuR59H35s5r0l1ZUa8gWmr4UC +b6741jH/JclKyMeKqdmfS0mbEVeZkkMR3rYzpMzXjWR91M08KCy0mpbqTfXERMQl +qiCA2ClV9+BB/AYm/7k29UMUA2Z44RGx2iBfRgB4ACGlHgAoYXhvqAEBj500mv/0 +OJD7uNGzcgbJceaBxXntC6Z58hMLnPddDnskk7RI24Zf3lCGeOdA5jGokHZwYa+c +NywRtYK3qq4kNFtyDGkNzVmf9nGvnAvRCjj5BiKDUyUM/FHE5r7iOZULJK2v0ZXk +ltd0ZGtxTgI8qoXzIKNDOXZbbFD+mpwUHmUUihW9o4JFWklWatKcsWMy5WHgUyIO +pwpJ6st+H6jiYoD2EEVSmAYY3qXNL3+q1Ok+CHLsIwMCPKaq2LxndD0UF/tUSxfj +03k9bWtJySgOLnRQvwzZRjoQhsmnP+mg7H/rpXdYaXHmgwo38oZJar55CJD2AhZk +PuXaTH4MNMn5X7azKFGnpyuqSfqNZSlO42sTp5SjLVFteAxEy9/eCG/Oo2Sr05WE +1LlSVHJ7liXMvGnjSG4N0MedJ5qq+BOS3R7fY581qRY27Iy4g/Q9iY/NtBde17MX +QRBdJ3NghVdJIgc= +-----END CERTIFICATE----- + +# Issuer: CN=Trustwave Global Certification Authority O=Trustwave Holdings, Inc. +# Subject: CN=Trustwave Global Certification Authority O=Trustwave Holdings, Inc. +# Label: "Trustwave Global Certification Authority" +# Serial: 1846098327275375458322922162 +# MD5 Fingerprint: f8:1c:18:2d:2f:ba:5f:6d:a1:6c:bc:c7:ab:91:c7:0e +# SHA1 Fingerprint: 2f:8f:36:4f:e1:58:97:44:21:59:87:a5:2a:9a:d0:69:95:26:7f:b5 +# SHA256 Fingerprint: 97:55:20:15:f5:dd:fc:3c:87:88:c0:06:94:45:55:40:88:94:45:00:84:f1:00:86:70:86:bc:1a:2b:b5:8d:c8 +-----BEGIN CERTIFICATE----- +MIIF2jCCA8KgAwIBAgIMBfcOhtpJ80Y1LrqyMA0GCSqGSIb3DQEBCwUAMIGIMQsw +CQYDVQQGEwJVUzERMA8GA1UECAwISWxsaW5vaXMxEDAOBgNVBAcMB0NoaWNhZ28x +ITAfBgNVBAoMGFRydXN0d2F2ZSBIb2xkaW5ncywgSW5jLjExMC8GA1UEAwwoVHJ1 +c3R3YXZlIEdsb2JhbCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0xNzA4MjMx +OTM0MTJaFw00MjA4MjMxOTM0MTJaMIGIMQswCQYDVQQGEwJVUzERMA8GA1UECAwI +SWxsaW5vaXMxEDAOBgNVBAcMB0NoaWNhZ28xITAfBgNVBAoMGFRydXN0d2F2ZSBI +b2xkaW5ncywgSW5jLjExMC8GA1UEAwwoVHJ1c3R3YXZlIEdsb2JhbCBDZXJ0aWZp +Y2F0aW9uIEF1dGhvcml0eTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIB +ALldUShLPDeS0YLOvR29zd24q88KPuFd5dyqCblXAj7mY2Hf8g+CY66j96xz0Xzn +swuvCAAJWX/NKSqIk4cXGIDtiLK0thAfLdZfVaITXdHG6wZWiYj+rDKd/VzDBcdu +7oaJuogDnXIhhpCujwOl3J+IKMujkkkP7NAP4m1ET4BqstTnoApTAbqOl5F2brz8 +1Ws25kCI1nsvXwXoLG0R8+eyvpJETNKXpP7ScoFDB5zpET71ixpZfR9oWN0EACyW +80OzfpgZdNmcc9kYvkHHNHnZ9GLCQ7mzJ7Aiy/k9UscwR7PJPrhq4ufogXBeQotP +JqX+OsIgbrv4Fo7NDKm0G2x2EOFYeUY+VM6AqFcJNykbmROPDMjWLBz7BegIlT1l +RtzuzWniTY+HKE40Cz7PFNm73bZQmq131BnW2hqIyE4bJ3XYsgjxroMwuREOzYfw +hI0Vcnyh78zyiGG69Gm7DIwLdVcEuE4qFC49DxweMqZiNu5m4iK4BUBjECLzMx10 +coos9TkpoNPnG4CELcU9402x/RpvumUHO1jsQkUm+9jaJXLE9gCxInm943xZYkqc +BW89zubWR2OZxiRvchLIrH+QtAuRcOi35hYQcRfO3gZPSEF9NUqjifLJS3tBEW1n +twiYTOURGa5CgNz7kAXU+FDKvuStx8KU1xad5hePrzb7AgMBAAGjQjBAMA8GA1Ud +EwEB/wQFMAMBAf8wHQYDVR0OBBYEFJngGWcNYtt2s9o9uFvo/ULSMQ6HMA4GA1Ud +DwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAmHNw4rDT7TnsTGDZqRKGFx6W +0OhUKDtkLSGm+J1WE2pIPU/HPinbbViDVD2HfSMF1OQc3Og4ZYbFdada2zUFvXfe +uyk3QAUHw5RSn8pk3fEbK9xGChACMf1KaA0HZJDmHvUqoai7PF35owgLEQzxPy0Q +lG/+4jSHg9bP5Rs1bdID4bANqKCqRieCNqcVtgimQlRXtpla4gt5kNdXElE1GYhB +aCXUNxeEFfsBctyV3lImIJgm4nb1J2/6ADtKYdkNy1GTKv0WBpanI5ojSP5RvbbE +sLFUzt5sQa0WZ37b/TjNuThOssFgy50X31ieemKyJo90lZvkWx3SD92YHJtZuSPT +MaCm/zjdzyBP6VhWOmfD0faZmZ26NraAL4hHT4a/RDqA5Dccprrql5gR0IRiR2Qe +qu5AvzSxnI9O4fKSTx+O856X3vOmeWqJcU9LJxdI/uz0UA9PSX3MReO9ekDFQdxh +VicGaeVyQYHTtgGJoC86cnn+OjC/QezHYj6RS8fZMXZC+fc8Y+wmjHMMfRod6qh8 +h6jCJ3zhM0EPz8/8AKAigJ5Kp28AsEFFtyLKaEjFQqKu3R3y4G5OBVixwJAWKqQ9 +EEC+j2Jjg6mcgn0tAumDMHzLJ8n9HmYAsC7TIS+OMxZsmO0QqAfWzJPP29FpHOTK +yeC2nOnOcXHebD8WpHk= +-----END CERTIFICATE----- + +# Issuer: CN=Trustwave Global ECC P256 Certification Authority O=Trustwave Holdings, Inc. +# Subject: CN=Trustwave Global ECC P256 Certification Authority O=Trustwave Holdings, Inc. +# Label: "Trustwave Global ECC P256 Certification Authority" +# Serial: 4151900041497450638097112925 +# MD5 Fingerprint: 5b:44:e3:8d:5d:36:86:26:e8:0d:05:d2:59:a7:83:54 +# SHA1 Fingerprint: b4:90:82:dd:45:0c:be:8b:5b:b1:66:d3:e2:a4:08:26:cd:ed:42:cf +# SHA256 Fingerprint: 94:5b:bc:82:5e:a5:54:f4:89:d1:fd:51:a7:3d:df:2e:a6:24:ac:70:19:a0:52:05:22:5c:22:a7:8c:cf:a8:b4 +-----BEGIN CERTIFICATE----- +MIICYDCCAgegAwIBAgIMDWpfCD8oXD5Rld9dMAoGCCqGSM49BAMCMIGRMQswCQYD +VQQGEwJVUzERMA8GA1UECBMISWxsaW5vaXMxEDAOBgNVBAcTB0NoaWNhZ28xITAf +BgNVBAoTGFRydXN0d2F2ZSBIb2xkaW5ncywgSW5jLjE6MDgGA1UEAxMxVHJ1c3R3 +YXZlIEdsb2JhbCBFQ0MgUDI1NiBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0x +NzA4MjMxOTM1MTBaFw00MjA4MjMxOTM1MTBaMIGRMQswCQYDVQQGEwJVUzERMA8G +A1UECBMISWxsaW5vaXMxEDAOBgNVBAcTB0NoaWNhZ28xITAfBgNVBAoTGFRydXN0 +d2F2ZSBIb2xkaW5ncywgSW5jLjE6MDgGA1UEAxMxVHJ1c3R3YXZlIEdsb2JhbCBF +Q0MgUDI1NiBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTBZMBMGByqGSM49AgEGCCqG +SM49AwEHA0IABH77bOYj43MyCMpg5lOcunSNGLB4kFKA3TjASh3RqMyTpJcGOMoN +FWLGjgEqZZ2q3zSRLoHB5DOSMcT9CTqmP62jQzBBMA8GA1UdEwEB/wQFMAMBAf8w +DwYDVR0PAQH/BAUDAwcGADAdBgNVHQ4EFgQUo0EGrJBt0UrrdaVKEJmzsaGLSvcw +CgYIKoZIzj0EAwIDRwAwRAIgB+ZU2g6gWrKuEZ+Hxbb/ad4lvvigtwjzRM4q3wgh +DDcCIC0mA6AFvWvR9lz4ZcyGbbOcNEhjhAnFjXca4syc4XR7 +-----END CERTIFICATE----- + +# Issuer: CN=Trustwave Global ECC P384 Certification Authority O=Trustwave Holdings, Inc. +# Subject: CN=Trustwave Global ECC P384 Certification Authority O=Trustwave Holdings, Inc. +# Label: "Trustwave Global ECC P384 Certification Authority" +# Serial: 2704997926503831671788816187 +# MD5 Fingerprint: ea:cf:60:c4:3b:b9:15:29:40:a1:97:ed:78:27:93:d6 +# SHA1 Fingerprint: e7:f3:a3:c8:cf:6f:c3:04:2e:6d:0e:67:32:c5:9e:68:95:0d:5e:d2 +# SHA256 Fingerprint: 55:90:38:59:c8:c0:c3:eb:b8:75:9e:ce:4e:25:57:22:5f:f5:75:8b:bd:38:eb:d4:82:76:60:1e:1b:d5:80:97 +-----BEGIN CERTIFICATE----- +MIICnTCCAiSgAwIBAgIMCL2Fl2yZJ6SAaEc7MAoGCCqGSM49BAMDMIGRMQswCQYD +VQQGEwJVUzERMA8GA1UECBMISWxsaW5vaXMxEDAOBgNVBAcTB0NoaWNhZ28xITAf +BgNVBAoTGFRydXN0d2F2ZSBIb2xkaW5ncywgSW5jLjE6MDgGA1UEAxMxVHJ1c3R3 +YXZlIEdsb2JhbCBFQ0MgUDM4NCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0x +NzA4MjMxOTM2NDNaFw00MjA4MjMxOTM2NDNaMIGRMQswCQYDVQQGEwJVUzERMA8G +A1UECBMISWxsaW5vaXMxEDAOBgNVBAcTB0NoaWNhZ28xITAfBgNVBAoTGFRydXN0 +d2F2ZSBIb2xkaW5ncywgSW5jLjE6MDgGA1UEAxMxVHJ1c3R3YXZlIEdsb2JhbCBF +Q0MgUDM4NCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTB2MBAGByqGSM49AgEGBSuB +BAAiA2IABGvaDXU1CDFHBa5FmVXxERMuSvgQMSOjfoPTfygIOiYaOs+Xgh+AtycJ +j9GOMMQKmw6sWASr9zZ9lCOkmwqKi6vr/TklZvFe/oyujUF5nQlgziip04pt89ZF +1PKYhDhloKNDMEEwDwYDVR0TAQH/BAUwAwEB/zAPBgNVHQ8BAf8EBQMDBwYAMB0G +A1UdDgQWBBRVqYSJ0sEyvRjLbKYHTsjnnb6CkDAKBggqhkjOPQQDAwNnADBkAjA3 +AZKXRRJ+oPM+rRk6ct30UJMDEr5E0k9BpIycnR+j9sKS50gU/k6bpZFXrsY3crsC +MGclCrEMXu6pY5Jv5ZAL/mYiykf9ijH3g/56vxC+GCsej/YpHpRZ744hN8tRmKVu +Sw== +-----END CERTIFICATE----- + +# Issuer: CN=NAVER Global Root Certification Authority O=NAVER BUSINESS PLATFORM Corp. +# Subject: CN=NAVER Global Root Certification Authority O=NAVER BUSINESS PLATFORM Corp. +# Label: "NAVER Global Root Certification Authority" +# Serial: 9013692873798656336226253319739695165984492813 +# MD5 Fingerprint: c8:7e:41:f6:25:3b:f5:09:b3:17:e8:46:3d:bf:d0:9b +# SHA1 Fingerprint: 8f:6b:f2:a9:27:4a:da:14:a0:c4:f4:8e:61:27:f9:c0:1e:78:5d:d1 +# SHA256 Fingerprint: 88:f4:38:dc:f8:ff:d1:fa:8f:42:91:15:ff:e5:f8:2a:e1:e0:6e:0c:70:c3:75:fa:ad:71:7b:34:a4:9e:72:65 +-----BEGIN CERTIFICATE----- +MIIFojCCA4qgAwIBAgIUAZQwHqIL3fXFMyqxQ0Rx+NZQTQ0wDQYJKoZIhvcNAQEM +BQAwaTELMAkGA1UEBhMCS1IxJjAkBgNVBAoMHU5BVkVSIEJVU0lORVNTIFBMQVRG +T1JNIENvcnAuMTIwMAYDVQQDDClOQVZFUiBHbG9iYWwgUm9vdCBDZXJ0aWZpY2F0 +aW9uIEF1dGhvcml0eTAeFw0xNzA4MTgwODU4NDJaFw0zNzA4MTgyMzU5NTlaMGkx +CzAJBgNVBAYTAktSMSYwJAYDVQQKDB1OQVZFUiBCVVNJTkVTUyBQTEFURk9STSBD +b3JwLjEyMDAGA1UEAwwpTkFWRVIgR2xvYmFsIFJvb3QgQ2VydGlmaWNhdGlvbiBB +dXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC21PGTXLVA +iQqrDZBbUGOukJR0F0Vy1ntlWilLp1agS7gvQnXp2XskWjFlqxcX0TM62RHcQDaH +38dq6SZeWYp34+hInDEW+j6RscrJo+KfziFTowI2MMtSAuXaMl3Dxeb57hHHi8lE +HoSTGEq0n+USZGnQJoViAbbJAh2+g1G7XNr4rRVqmfeSVPc0W+m/6imBEtRTkZaz +kVrd/pBzKPswRrXKCAfHcXLJZtM0l/aM9BhK4dA9WkW2aacp+yPOiNgSnABIqKYP +szuSjXEOdMWLyEz59JuOuDxp7W87UC9Y7cSw0BwbagzivESq2M0UXZR4Yb8Obtoq +vC8MC3GmsxY/nOb5zJ9TNeIDoKAYv7vxvvTWjIcNQvcGufFt7QSUqP620wbGQGHf +nZ3zVHbOUzoBppJB7ASjjw2i1QnK1sua8e9DXcCrpUHPXFNwcMmIpi3Ua2FzUCaG +YQ5fG8Ir4ozVu53BA0K6lNpfqbDKzE0K70dpAy8i+/Eozr9dUGWokG2zdLAIx6yo +0es+nPxdGoMuK8u180SdOqcXYZaicdNwlhVNt0xz7hlcxVs+Qf6sdWA7G2POAN3a +CJBitOUt7kinaxeZVL6HSuOpXgRM6xBtVNbv8ejyYhbLgGvtPe31HzClrkvJE+2K +AQHJuFFYwGY6sWZLxNUxAmLpdIQM201GLQIDAQABo0IwQDAdBgNVHQ4EFgQU0p+I +36HNLL3s9TsBAZMzJ7LrYEswDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMB +Af8wDQYJKoZIhvcNAQEMBQADggIBADLKgLOdPVQG3dLSLvCkASELZ0jKbY7gyKoN +qo0hV4/GPnrK21HUUrPUloSlWGB/5QuOH/XcChWB5Tu2tyIvCZwTFrFsDDUIbatj +cu3cvuzHV+YwIHHW1xDBE1UBjCpD5EHxzzp6U5LOogMFDTjfArsQLtk70pt6wKGm ++LUx5vR1yblTmXVHIloUFcd4G7ad6Qz4G3bxhYTeodoS76TiEJd6eN4MUZeoIUCL +hr0N8F5OSza7OyAfikJW4Qsav3vQIkMsRIz75Sq0bBwcupTgE34h5prCy8VCZLQe +lHsIJchxzIdFV4XTnyliIoNRlwAYl3dqmJLJfGBs32x9SuRwTMKeuB330DTHD8z7 +p/8Dvq1wkNoL3chtl1+afwkyQf3NosxabUzyqkn+Zvjp2DXrDige7kgvOtB5CTh8 +piKCk5XQA76+AqAF3SAi428diDRgxuYKuQl1C/AH6GmWNcf7I4GOODm4RStDeKLR +LBT/DShycpWbXgnbiUSYqqFJu3FS8r/2/yehNq+4tneI3TqkbZs0kNwUXTC/t+sX +5Ie3cdCh13cV1ELX8vMxmV2b3RZtP+oGI/hGoiLtk/bdmuYqh7GYVPEi92tF4+KO +dh2ajcQGjTa3FPOdVGm3jjzVpG2Tgbet9r1ke8LJaDmgkpzNNIaRkPpkUZ3+/uul +9XXeifdy +-----END CERTIFICATE----- + +# Issuer: CN=AC RAIZ FNMT-RCM SERVIDORES SEGUROS O=FNMT-RCM OU=Ceres +# Subject: CN=AC RAIZ FNMT-RCM SERVIDORES SEGUROS O=FNMT-RCM OU=Ceres +# Label: "AC RAIZ FNMT-RCM SERVIDORES SEGUROS" +# Serial: 131542671362353147877283741781055151509 +# MD5 Fingerprint: 19:36:9c:52:03:2f:d2:d1:bb:23:cc:dd:1e:12:55:bb +# SHA1 Fingerprint: 62:ff:d9:9e:c0:65:0d:03:ce:75:93:d2:ed:3f:2d:32:c9:e3:e5:4a +# SHA256 Fingerprint: 55:41:53:b1:3d:2c:f9:dd:b7:53:bf:be:1a:4e:0a:e0:8d:0a:a4:18:70:58:fe:60:a2:b8:62:b2:e4:b8:7b:cb +-----BEGIN CERTIFICATE----- +MIICbjCCAfOgAwIBAgIQYvYybOXE42hcG2LdnC6dlTAKBggqhkjOPQQDAzB4MQsw +CQYDVQQGEwJFUzERMA8GA1UECgwIRk5NVC1SQ00xDjAMBgNVBAsMBUNlcmVzMRgw +FgYDVQRhDA9WQVRFUy1RMjgyNjAwNEoxLDAqBgNVBAMMI0FDIFJBSVogRk5NVC1S +Q00gU0VSVklET1JFUyBTRUdVUk9TMB4XDTE4MTIyMDA5MzczM1oXDTQzMTIyMDA5 +MzczM1oweDELMAkGA1UEBhMCRVMxETAPBgNVBAoMCEZOTVQtUkNNMQ4wDAYDVQQL +DAVDZXJlczEYMBYGA1UEYQwPVkFURVMtUTI4MjYwMDRKMSwwKgYDVQQDDCNBQyBS +QUlaIEZOTVQtUkNNIFNFUlZJRE9SRVMgU0VHVVJPUzB2MBAGByqGSM49AgEGBSuB +BAAiA2IABPa6V1PIyqvfNkpSIeSX0oNnnvBlUdBeh8dHsVnyV0ebAAKTRBdp20LH +sbI6GA60XYyzZl2hNPk2LEnb80b8s0RpRBNm/dfF/a82Tc4DTQdxz69qBdKiQ1oK +Um8BA06Oi6NCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYD +VR0OBBYEFAG5L++/EYZg8k/QQW6rcx/n0m5JMAoGCCqGSM49BAMDA2kAMGYCMQCu +SuMrQMN0EfKVrRYj3k4MGuZdpSRea0R7/DjiT8ucRRcRTBQnJlU5dUoDzBOQn5IC +MQD6SmxgiHPz7riYYqnOK8LZiqZwMR2vsJRM60/G49HzYqc8/5MuB1xJAWdpEgJy +v+c= +-----END CERTIFICATE----- + +# Issuer: CN=GlobalSign Root R46 O=GlobalSign nv-sa +# Subject: CN=GlobalSign Root R46 O=GlobalSign nv-sa +# Label: "GlobalSign Root R46" +# Serial: 1552617688466950547958867513931858518042577 +# MD5 Fingerprint: c4:14:30:e4:fa:66:43:94:2a:6a:1b:24:5f:19:d0:ef +# SHA1 Fingerprint: 53:a2:b0:4b:ca:6b:d6:45:e6:39:8a:8e:c4:0d:d2:bf:77:c3:a2:90 +# SHA256 Fingerprint: 4f:a3:12:6d:8d:3a:11:d1:c4:85:5a:4f:80:7c:ba:d6:cf:91:9d:3a:5a:88:b0:3b:ea:2c:63:72:d9:3c:40:c9 +-----BEGIN CERTIFICATE----- +MIIFWjCCA0KgAwIBAgISEdK7udcjGJ5AXwqdLdDfJWfRMA0GCSqGSIb3DQEBDAUA +MEYxCzAJBgNVBAYTAkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMRwwGgYD +VQQDExNHbG9iYWxTaWduIFJvb3QgUjQ2MB4XDTE5MDMyMDAwMDAwMFoXDTQ2MDMy +MDAwMDAwMFowRjELMAkGA1UEBhMCQkUxGTAXBgNVBAoTEEdsb2JhbFNpZ24gbnYt +c2ExHDAaBgNVBAMTE0dsb2JhbFNpZ24gUm9vdCBSNDYwggIiMA0GCSqGSIb3DQEB +AQUAA4ICDwAwggIKAoICAQCsrHQy6LNl5brtQyYdpokNRbopiLKkHWPd08EsCVeJ +OaFV6Wc0dwxu5FUdUiXSE2te4R2pt32JMl8Nnp8semNgQB+msLZ4j5lUlghYruQG +vGIFAha/r6gjA7aUD7xubMLL1aa7DOn2wQL7Id5m3RerdELv8HQvJfTqa1VbkNud +316HCkD7rRlr+/fKYIje2sGP1q7Vf9Q8g+7XFkyDRTNrJ9CG0Bwta/OrffGFqfUo +0q3v84RLHIf8E6M6cqJaESvWJ3En7YEtbWaBkoe0G1h6zD8K+kZPTXhc+CtI4wSE +y132tGqzZfxCnlEmIyDLPRT5ge1lFgBPGmSXZgjPjHvjK8Cd+RTyG/FWaha/LIWF +zXg4mutCagI0GIMXTpRW+LaCtfOW3T3zvn8gdz57GSNrLNRyc0NXfeD412lPFzYE ++cCQYDdF3uYM2HSNrpyibXRdQr4G9dlkbgIQrImwTDsHTUB+JMWKmIJ5jqSngiCN +I/onccnfxkF0oE32kRbcRoxfKWMxWXEM2G/CtjJ9++ZdU6Z+Ffy7dXxd7Pj2Fxzs +x2sZy/N78CsHpdlseVR2bJ0cpm4O6XkMqCNqo98bMDGfsVR7/mrLZqrcZdCinkqa +ByFrgY/bxFn63iLABJzjqls2k+g9vXqhnQt2sQvHnf3PmKgGwvgqo6GDoLclcqUC +4wIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNV +HQ4EFgQUA1yrc4GHqMywptWU4jaWSf8FmSwwDQYJKoZIhvcNAQEMBQADggIBAHx4 +7PYCLLtbfpIrXTncvtgdokIzTfnvpCo7RGkerNlFo048p9gkUbJUHJNOxO97k4Vg +JuoJSOD1u8fpaNK7ajFxzHmuEajwmf3lH7wvqMxX63bEIaZHU1VNaL8FpO7XJqti +2kM3S+LGteWygxk6x9PbTZ4IevPuzz5i+6zoYMzRx6Fcg0XERczzF2sUyQQCPtIk +pnnpHs6i58FZFZ8d4kuaPp92CC1r2LpXFNqD6v6MVenQTqnMdzGxRBF6XLE+0xRF +FRhiJBPSy03OXIPBNvIQtQ6IbbjhVp+J3pZmOUdkLG5NrmJ7v2B0GbhWrJKsFjLt +rWhV/pi60zTe9Mlhww6G9kuEYO4Ne7UyWHmRVSyBQ7N0H3qqJZ4d16GLuc1CLgSk +ZoNNiTW2bKg2SnkheCLQQrzRQDGQob4Ez8pn7fXwgNNgyYMqIgXQBztSvwyeqiv5 +u+YfjyW6hY0XHgL+XVAEV8/+LbzvXMAaq7afJMbfc2hIkCwU9D9SGuTSyxTDYWnP +4vkYxboznxSjBF25cfe1lNj2M8FawTSLfJvdkzrnE6JwYZ+vj+vYxXX4M2bUdGc6 +N3ec592kD3ZDZopD8p/7DEJ4Y9HiD2971KE9dJeFt0g5QdYg/NA6s/rob8SKunE3 +vouXsXgxT7PntgMTzlSdriVZzH81Xwj3QEUxeCp6 +-----END CERTIFICATE----- + +# Issuer: CN=GlobalSign Root E46 O=GlobalSign nv-sa +# Subject: CN=GlobalSign Root E46 O=GlobalSign nv-sa +# Label: "GlobalSign Root E46" +# Serial: 1552617690338932563915843282459653771421763 +# MD5 Fingerprint: b5:b8:66:ed:de:08:83:e3:c9:e2:01:34:06:ac:51:6f +# SHA1 Fingerprint: 39:b4:6c:d5:fe:80:06:eb:e2:2f:4a:bb:08:33:a0:af:db:b9:dd:84 +# SHA256 Fingerprint: cb:b9:c4:4d:84:b8:04:3e:10:50:ea:31:a6:9f:51:49:55:d7:bf:d2:e2:c6:b4:93:01:01:9a:d6:1d:9f:50:58 +-----BEGIN CERTIFICATE----- +MIICCzCCAZGgAwIBAgISEdK7ujNu1LzmJGjFDYQdmOhDMAoGCCqGSM49BAMDMEYx +CzAJBgNVBAYTAkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMRwwGgYDVQQD +ExNHbG9iYWxTaWduIFJvb3QgRTQ2MB4XDTE5MDMyMDAwMDAwMFoXDTQ2MDMyMDAw +MDAwMFowRjELMAkGA1UEBhMCQkUxGTAXBgNVBAoTEEdsb2JhbFNpZ24gbnYtc2Ex +HDAaBgNVBAMTE0dsb2JhbFNpZ24gUm9vdCBFNDYwdjAQBgcqhkjOPQIBBgUrgQQA +IgNiAAScDrHPt+ieUnd1NPqlRqetMhkytAepJ8qUuwzSChDH2omwlwxwEwkBjtjq +R+q+soArzfwoDdusvKSGN+1wCAB16pMLey5SnCNoIwZD7JIvU4Tb+0cUB+hflGdd +yXqBPCCjQjBAMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1Ud +DgQWBBQxCpCPtsad0kRLgLWi5h+xEk8blTAKBggqhkjOPQQDAwNoADBlAjEA31SQ +7Zvvi5QCkxeCmb6zniz2C5GMn0oUsfZkvLtoURMMA/cVi4RguYv/Uo7njLwcAjA8 ++RHUjE7AwWHCFUyqqx0LMV87HOIAl0Qx5v5zli/altP+CAezNIm8BZ/3Hobui3A= +-----END CERTIFICATE----- + +# Issuer: CN=ANF Secure Server Root CA O=ANF Autoridad de Certificacion OU=ANF CA Raiz +# Subject: CN=ANF Secure Server Root CA O=ANF Autoridad de Certificacion OU=ANF CA Raiz +# Label: "ANF Secure Server Root CA" +# Serial: 996390341000653745 +# MD5 Fingerprint: 26:a6:44:5a:d9:af:4e:2f:b2:1d:b6:65:b0:4e:e8:96 +# SHA1 Fingerprint: 5b:6e:68:d0:cc:15:b6:a0:5f:1e:c1:5f:ae:02:fc:6b:2f:5d:6f:74 +# SHA256 Fingerprint: fb:8f:ec:75:91:69:b9:10:6b:1e:51:16:44:c6:18:c5:13:04:37:3f:6c:06:43:08:8d:8b:ef:fd:1b:99:75:99 +-----BEGIN CERTIFICATE----- +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 +-----END CERTIFICATE----- + +# Issuer: CN=Certum EC-384 CA O=Asseco Data Systems S.A. OU=Certum Certification Authority +# Subject: CN=Certum EC-384 CA O=Asseco Data Systems S.A. OU=Certum Certification Authority +# Label: "Certum EC-384 CA" +# Serial: 160250656287871593594747141429395092468 +# MD5 Fingerprint: b6:65:b3:96:60:97:12:a1:ec:4e:e1:3d:a3:c6:c9:f1 +# SHA1 Fingerprint: f3:3e:78:3c:ac:df:f4:a2:cc:ac:67:55:69:56:d7:e5:16:3c:e1:ed +# SHA256 Fingerprint: 6b:32:80:85:62:53:18:aa:50:d1:73:c9:8d:8b:da:09:d5:7e:27:41:3d:11:4c:f7:87:a0:f5:d0:6c:03:0c:f6 +-----BEGIN CERTIFICATE----- +MIICZTCCAeugAwIBAgIQeI8nXIESUiClBNAt3bpz9DAKBggqhkjOPQQDAzB0MQsw +CQYDVQQGEwJQTDEhMB8GA1UEChMYQXNzZWNvIERhdGEgU3lzdGVtcyBTLkEuMScw +JQYDVQQLEx5DZXJ0dW0gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkxGTAXBgNVBAMT +EENlcnR1bSBFQy0zODQgQ0EwHhcNMTgwMzI2MDcyNDU0WhcNNDMwMzI2MDcyNDU0 +WjB0MQswCQYDVQQGEwJQTDEhMB8GA1UEChMYQXNzZWNvIERhdGEgU3lzdGVtcyBT +LkEuMScwJQYDVQQLEx5DZXJ0dW0gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkxGTAX +BgNVBAMTEENlcnR1bSBFQy0zODQgQ0EwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAATE +KI6rGFtqvm5kN2PkzeyrOvfMobgOgknXhimfoZTy42B4mIF4Bk3y7JoOV2CDn7Tm +Fy8as10CW4kjPMIRBSqniBMY81CE1700LCeJVf/OTOffph8oxPBUw7l8t1Ot68Kj +QjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFI0GZnQkdjrzife81r1HfS+8 +EF9LMA4GA1UdDwEB/wQEAwIBBjAKBggqhkjOPQQDAwNoADBlAjADVS2m5hjEfO/J +UG7BJw+ch69u1RsIGL2SKcHvlJF40jocVYli5RsJHrpka/F2tNQCMQC0QoSZ/6vn +nvuRlydd3LBbMHHOXjgaatkl5+r3YZJW+OraNsKHZZYuciUvf9/DE8k= +-----END CERTIFICATE----- + +# Issuer: CN=Certum Trusted Root CA O=Asseco Data Systems S.A. OU=Certum Certification Authority +# Subject: CN=Certum Trusted Root CA O=Asseco Data Systems S.A. OU=Certum Certification Authority +# Label: "Certum Trusted Root CA" +# Serial: 40870380103424195783807378461123655149 +# MD5 Fingerprint: 51:e1:c2:e7:fe:4c:84:af:59:0e:2f:f4:54:6f:ea:29 +# SHA1 Fingerprint: c8:83:44:c0:18:ae:9f:cc:f1:87:b7:8f:22:d1:c5:d7:45:84:ba:e5 +# SHA256 Fingerprint: fe:76:96:57:38:55:77:3e:37:a9:5e:7a:d4:d9:cc:96:c3:01:57:c1:5d:31:76:5b:a9:b1:57:04:e1:ae:78:fd +-----BEGIN CERTIFICATE----- +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 +-----END CERTIFICATE----- + +# Issuer: CN=TunTrust Root CA O=Agence Nationale de Certification Electronique +# Subject: CN=TunTrust Root CA O=Agence Nationale de Certification Electronique +# Label: "TunTrust Root CA" +# Serial: 108534058042236574382096126452369648152337120275 +# MD5 Fingerprint: 85:13:b9:90:5b:36:5c:b6:5e:b8:5a:f8:e0:31:57:b4 +# SHA1 Fingerprint: cf:e9:70:84:0f:e0:73:0f:9d:f6:0c:7f:2c:4b:ee:20:46:34:9c:bb +# SHA256 Fingerprint: 2e:44:10:2a:b5:8c:b8:54:19:45:1c:8e:19:d9:ac:f3:66:2c:af:bc:61:4b:6a:53:96:0a:30:f7:d0:e2:eb:41 +-----BEGIN CERTIFICATE----- +MIIFszCCA5ugAwIBAgIUEwLV4kBMkkaGFmddtLu7sms+/BMwDQYJKoZIhvcNAQEL +BQAwYTELMAkGA1UEBhMCVE4xNzA1BgNVBAoMLkFnZW5jZSBOYXRpb25hbGUgZGUg +Q2VydGlmaWNhdGlvbiBFbGVjdHJvbmlxdWUxGTAXBgNVBAMMEFR1blRydXN0IFJv +b3QgQ0EwHhcNMTkwNDI2MDg1NzU2WhcNNDQwNDI2MDg1NzU2WjBhMQswCQYDVQQG +EwJUTjE3MDUGA1UECgwuQWdlbmNlIE5hdGlvbmFsZSBkZSBDZXJ0aWZpY2F0aW9u +IEVsZWN0cm9uaXF1ZTEZMBcGA1UEAwwQVHVuVHJ1c3QgUm9vdCBDQTCCAiIwDQYJ +KoZIhvcNAQEBBQADggIPADCCAgoCggIBAMPN0/y9BFPdDCA61YguBUtB9YOCfvdZ +n56eY+hz2vYGqU8ftPkLHzmMmiDQfgbU7DTZhrx1W4eI8NLZ1KMKsmwb60ksPqxd +2JQDoOw05TDENX37Jk0bbjBU2PWARZw5rZzJJQRNmpA+TkBuimvNKWfGzC3gdOgF +VwpIUPp6Q9p+7FuaDmJ2/uqdHYVy7BG7NegfJ7/Boce7SBbdVtfMTqDhuazb1YMZ +GoXRlJfXyqNlC/M4+QKu3fZnz8k/9YosRxqZbwUN/dAdgjH8KcwAWJeRTIAAHDOF +li/LQcKLEITDCSSJH7UP2dl3RxiSlGBcx5kDPP73lad9UKGAwqmDrViWVSHbhlnU +r8a83YFuB9tgYv7sEG7aaAH0gxupPqJbI9dkxt/con3YS7qC0lH4Zr8GRuR5KiY2 +eY8fTpkdso8MDhz/yV3A/ZAQprE38806JG60hZC/gLkMjNWb1sjxVj8agIl6qeIb +MlEsPvLfe/ZdeikZjuXIvTZxi11Mwh0/rViizz1wTaZQmCXcI/m4WEEIcb9PuISg +jwBUFfyRbVinljvrS5YnzWuioYasDXxU5mZMZl+QviGaAkYt5IPCgLnPSz7ofzwB +7I9ezX/SKEIBlYrilz0QIX32nRzFNKHsLA4KUiwSVXAkPcvCFDVDXSdOvsC9qnyW +5/yeYa1E0wCXAgMBAAGjYzBhMB0GA1UdDgQWBBQGmpsfU33x9aTI04Y+oXNZtPdE +ITAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFAaamx9TffH1pMjThj6hc1m0 +90QhMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAqgVutt0Vyb+z +xiD2BkewhpMl0425yAA/l/VSJ4hxyXT968pk21vvHl26v9Hr7lxpuhbI87mP0zYu +QEkHDVneixCwSQXi/5E/S7fdAo74gShczNxtr18UnH1YeA32gAm56Q6XKRm4t+v4 +FstVEuTGfbvE7Pi1HE4+Z7/FXxttbUcoqgRYYdZ2vyJ/0Adqp2RT8JeNnYA/u8EH +22Wv5psymsNUk8QcCMNE+3tjEUPRahphanltkE8pjkcFwRJpadbGNjHh/PqAulxP +xOu3Mqz4dWEX1xAZufHSCe96Qp1bWgvUxpVOKs7/B9dPfhgGiPEZtdmYu65xxBzn +dFlY7wyJz4sfdZMaBBSSSFCp61cpABbjNhzI+L/wM9VBD8TMPN3pM0MBkRArHtG5 +Xc0yGYuPjCB31yLEQtyEFpslbei0VXF/sHyz03FJuc9SpAQ/3D2gu68zngowYI7b +nV2UqL1g52KAdoGDDIzMMEZJ4gzSqK/rYXHv5yJiqfdcZGyfFoxnNidF9Ql7v/YQ +CvGwjVRDjAS6oz/v4jXH+XTgbzRB0L9zZVcg+ZtnemZoJE6AZb0QmQZZ8mWvuMZH +u/2QeItBcy6vVR/cO5JyboTT0GFMDcx2V+IthSIVNg3rAZ3r2OvEhJn7wAzMMujj +d9qDRIueVSjAi1jTkD5OGwDxFa2DK5o= +-----END CERTIFICATE----- + +# Issuer: CN=HARICA TLS RSA Root CA 2021 O=Hellenic Academic and Research Institutions CA +# Subject: CN=HARICA TLS RSA Root CA 2021 O=Hellenic Academic and Research Institutions CA +# Label: "HARICA TLS RSA Root CA 2021" +# Serial: 76817823531813593706434026085292783742 +# MD5 Fingerprint: 65:47:9b:58:86:dd:2c:f0:fc:a2:84:1f:1e:96:c4:91 +# SHA1 Fingerprint: 02:2d:05:82:fa:88:ce:14:0c:06:79:de:7f:14:10:e9:45:d7:a5:6d +# SHA256 Fingerprint: d9:5d:0e:8e:da:79:52:5b:f9:be:b1:1b:14:d2:10:0d:32:94:98:5f:0c:62:d9:fa:bd:9c:d9:99:ec:cb:7b:1d +-----BEGIN CERTIFICATE----- +MIIFpDCCA4ygAwIBAgIQOcqTHO9D88aOk8f0ZIk4fjANBgkqhkiG9w0BAQsFADBs +MQswCQYDVQQGEwJHUjE3MDUGA1UECgwuSGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJl +c2VhcmNoIEluc3RpdHV0aW9ucyBDQTEkMCIGA1UEAwwbSEFSSUNBIFRMUyBSU0Eg +Um9vdCBDQSAyMDIxMB4XDTIxMDIxOTEwNTUzOFoXDTQ1MDIxMzEwNTUzN1owbDEL +MAkGA1UEBhMCR1IxNzA1BgNVBAoMLkhlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNl +YXJjaCBJbnN0aXR1dGlvbnMgQ0ExJDAiBgNVBAMMG0hBUklDQSBUTFMgUlNBIFJv +b3QgQ0EgMjAyMTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAIvC569l +mwVnlskNJLnQDmT8zuIkGCyEf3dRywQRNrhe7Wlxp57kJQmXZ8FHws+RFjZiPTgE +4VGC/6zStGndLuwRo0Xua2s7TL+MjaQenRG56Tj5eg4MmOIjHdFOY9TnuEFE+2uv +a9of08WRiFukiZLRgeaMOVig1mlDqa2YUlhu2wr7a89o+uOkXjpFc5gH6l8Cct4M +pbOfrqkdtx2z/IpZ525yZa31MJQjB/OCFks1mJxTuy/K5FrZx40d/JiZ+yykgmvw +Kh+OC19xXFyuQnspiYHLA6OZyoieC0AJQTPb5lh6/a6ZcMBaD9YThnEvdmn8kN3b +LW7R8pv1GmuebxWMevBLKKAiOIAkbDakO/IwkfN4E8/BPzWr8R0RI7VDIp4BkrcY +AuUR0YLbFQDMYTfBKnya4dC6s1BG7oKsnTH4+yPiAwBIcKMJJnkVU2DzOFytOOqB +AGMUuTNe3QvboEUHGjMJ+E20pwKmafTCWQWIZYVWrkvL4N48fS0ayOn7H6NhStYq +E613TBoYm5EPWNgGVMWX+Ko/IIqmhaZ39qb8HOLubpQzKoNQhArlT4b4UEV4AIHr +W2jjJo3Me1xR9BQsQL4aYB16cmEdH2MtiKrOokWQCPxrvrNQKlr9qEgYRtaQQJKQ +CoReaDH46+0N0x3GfZkYVVYnZS6NRcUk7M7jAgMBAAGjQjBAMA8GA1UdEwEB/wQF +MAMBAf8wHQYDVR0OBBYEFApII6ZgpJIKM+qTW8VX6iVNvRLuMA4GA1UdDwEB/wQE +AwIBhjANBgkqhkiG9w0BAQsFAAOCAgEAPpBIqm5iFSVmewzVjIuJndftTgfvnNAU +X15QvWiWkKQUEapobQk1OUAJ2vQJLDSle1mESSmXdMgHHkdt8s4cUCbjnj1AUz/3 +f5Z2EMVGpdAgS1D0NTsY9FVqQRtHBmg8uwkIYtlfVUKqrFOFrJVWNlar5AWMxaja +H6NpvVMPxP/cyuN+8kyIhkdGGvMA9YCRotxDQpSbIPDRzbLrLFPCU3hKTwSUQZqP +JzLB5UkZv/HywouoCjkxKLR9YjYsTewfM7Z+d21+UPCfDtcRj88YxeMn/ibvBZ3P +zzfF0HvaO7AWhAw6k9a+F9sPPg4ZeAnHqQJyIkv3N3a6dcSFA1pj1bF1BcK5vZSt +jBWZp5N99sXzqnTPBIWUmAD04vnKJGW/4GKvyMX6ssmeVkjaef2WdhW+o45WxLM0 +/L5H9MG0qPzVMIho7suuyWPEdr6sOBjhXlzPrjoiUevRi7PzKzMHVIf6tLITe7pT +BGIBnfHAT+7hOtSLIBD6Alfm78ELt5BGnBkpjNxvoEppaZS3JGWg/6w/zgH7IS79 +aPib8qXPMThcFarmlwDB31qlpzmq6YR/PFGoOtmUW4y/Twhx5duoXNTSpv4Ao8YW +xw/ogM4cKGR0GQjTQuPOAF1/sdwTsOEFy9EgqoZ0njnnkf3/W9b3raYvAwtt41dU +63ZTGI0RmLo= +-----END CERTIFICATE----- + +# Issuer: CN=HARICA TLS ECC Root CA 2021 O=Hellenic Academic and Research Institutions CA +# Subject: CN=HARICA TLS ECC Root CA 2021 O=Hellenic Academic and Research Institutions CA +# Label: "HARICA TLS ECC Root CA 2021" +# Serial: 137515985548005187474074462014555733966 +# MD5 Fingerprint: ae:f7:4c:e5:66:35:d1:b7:9b:8c:22:93:74:d3:4b:b0 +# SHA1 Fingerprint: bc:b0:c1:9d:e9:98:92:70:19:38:57:e9:8d:a7:b4:5d:6e:ee:01:48 +# SHA256 Fingerprint: 3f:99:cc:47:4a:cf:ce:4d:fe:d5:87:94:66:5e:47:8d:15:47:73:9f:2e:78:0f:1b:b4:ca:9b:13:30:97:d4:01 +-----BEGIN CERTIFICATE----- +MIICVDCCAdugAwIBAgIQZ3SdjXfYO2rbIvT/WeK/zjAKBggqhkjOPQQDAzBsMQsw +CQYDVQQGEwJHUjE3MDUGA1UECgwuSGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJlc2Vh +cmNoIEluc3RpdHV0aW9ucyBDQTEkMCIGA1UEAwwbSEFSSUNBIFRMUyBFQ0MgUm9v +dCBDQSAyMDIxMB4XDTIxMDIxOTExMDExMFoXDTQ1MDIxMzExMDEwOVowbDELMAkG +A1UEBhMCR1IxNzA1BgNVBAoMLkhlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJj +aCBJbnN0aXR1dGlvbnMgQ0ExJDAiBgNVBAMMG0hBUklDQSBUTFMgRUNDIFJvb3Qg +Q0EgMjAyMTB2MBAGByqGSM49AgEGBSuBBAAiA2IABDgI/rGgltJ6rK9JOtDA4MM7 +KKrxcm1lAEeIhPyaJmuqS7psBAqIXhfyVYf8MLA04jRYVxqEU+kw2anylnTDUR9Y +STHMmE5gEYd103KUkE+bECUqqHgtvpBBWJAVcqeht6NCMEAwDwYDVR0TAQH/BAUw +AwEB/zAdBgNVHQ4EFgQUyRtTgRL+BNUW0aq8mm+3oJUZbsowDgYDVR0PAQH/BAQD +AgGGMAoGCCqGSM49BAMDA2cAMGQCMBHervjcToiwqfAircJRQO9gcS3ujwLEXQNw +SaSS6sUUiHCm0w2wqsosQJz76YJumgIwK0eaB8bRwoF8yguWGEEbo/QwCZ61IygN +nxS2PFOiTAZpffpskcYqSUXm7LcT4Tps +-----END CERTIFICATE----- + +# Issuer: CN=Autoridad de Certificacion Firmaprofesional CIF A62634068 +# Subject: CN=Autoridad de Certificacion Firmaprofesional CIF A62634068 +# Label: "Autoridad de Certificacion Firmaprofesional CIF A62634068" +# Serial: 1977337328857672817 +# MD5 Fingerprint: 4e:6e:9b:54:4c:ca:b7:fa:48:e4:90:b1:15:4b:1c:a3 +# SHA1 Fingerprint: 0b:be:c2:27:22:49:cb:39:aa:db:35:5c:53:e3:8c:ae:78:ff:b6:fe +# SHA256 Fingerprint: 57:de:05:83:ef:d2:b2:6e:03:61:da:99:da:9d:f4:64:8d:ef:7e:e8:44:1c:3b:72:8a:fa:9b:cd:e0:f9:b2:6a +-----BEGIN CERTIFICATE----- +MIIGFDCCA/ygAwIBAgIIG3Dp0v+ubHEwDQYJKoZIhvcNAQELBQAwUTELMAkGA1UE +BhMCRVMxQjBABgNVBAMMOUF1dG9yaWRhZCBkZSBDZXJ0aWZpY2FjaW9uIEZpcm1h +cHJvZmVzaW9uYWwgQ0lGIEE2MjYzNDA2ODAeFw0xNDA5MjMxNTIyMDdaFw0zNjA1 +MDUxNTIyMDdaMFExCzAJBgNVBAYTAkVTMUIwQAYDVQQDDDlBdXRvcmlkYWQgZGUg +Q2VydGlmaWNhY2lvbiBGaXJtYXByb2Zlc2lvbmFsIENJRiBBNjI2MzQwNjgwggIi +MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDKlmuO6vj78aI14H9M2uDDUtd9 +thDIAl6zQyrET2qyyhxdKJp4ERppWVevtSBC5IsP5t9bpgOSL/UR5GLXMnE42QQM +cas9UX4PB99jBVzpv5RvwSmCwLTaUbDBPLutN0pcyvFLNg4kq7/DhHf9qFD0sefG +L9ItWY16Ck6WaVICqjaY7Pz6FIMMNx/Jkjd/14Et5cS54D40/mf0PmbR0/RAz15i +NA9wBj4gGFrO93IbJWyTdBSTo3OxDqqHECNZXyAFGUftaI6SEspd/NYrspI8IM/h +X68gvqB2f3bl7BqGYTM+53u0P6APjqK5am+5hyZvQWyIplD9amML9ZMWGxmPsu2b +m8mQ9QEM3xk9Dz44I8kvjwzRAv4bVdZO0I08r0+k8/6vKtMFnXkIoctXMbScyJCy +Z/QYFpM6/EfY0XiWMR+6KwxfXZmtY4laJCB22N/9q06mIqqdXuYnin1oKaPnirja +EbsXLZmdEyRG98Xi2J+Of8ePdG1asuhy9azuJBCtLxTa/y2aRnFHvkLfuwHb9H/T +KI8xWVvTyQKmtFLKbpf7Q8UIJm+K9Lv9nyiqDdVF8xM6HdjAeI9BZzwelGSuewvF +6NkBiDkal4ZkQdU7hwxu+g/GvUgUvzlN1J5Bto+WHWOWk9mVBngxaJ43BjuAiUVh +OSPHG0SjFeUc+JIwuwIDAQABo4HvMIHsMB0GA1UdDgQWBBRlzeurNR4APn7VdMAc +tHNHDhpkLzASBgNVHRMBAf8ECDAGAQH/AgEBMIGmBgNVHSAEgZ4wgZswgZgGBFUd +IAAwgY8wLwYIKwYBBQUHAgEWI2h0dHA6Ly93d3cuZmlybWFwcm9mZXNpb25hbC5j +b20vY3BzMFwGCCsGAQUFBwICMFAeTgBQAGEAcwBlAG8AIABkAGUAIABsAGEAIABC +AG8AbgBhAG4AbwB2AGEAIAA0ADcAIABCAGEAcgBjAGUAbABvAG4AYQAgADAAOAAw +ADEANzAOBgNVHQ8BAf8EBAMCAQYwDQYJKoZIhvcNAQELBQADggIBAHSHKAIrdx9m +iWTtj3QuRhy7qPj4Cx2Dtjqn6EWKB7fgPiDL4QjbEwj4KKE1soCzC1HA01aajTNF +Sa9J8OA9B3pFE1r/yJfY0xgsfZb43aJlQ3CTkBW6kN/oGbDbLIpgD7dvlAceHabJ +hfa9NPhAeGIQcDq+fUs5gakQ1JZBu/hfHAsdCPKxsIl68veg4MSPi3i1O1ilI45P +Vf42O+AMt8oqMEEgtIDNrvx2ZnOorm7hfNoD6JQg5iKj0B+QXSBTFCZX2lSX3xZE +EAEeiGaPcjiT3SC3NL7X8e5jjkd5KAb881lFJWAiMxujX6i6KtoaPc1A6ozuBRWV +1aUsIC+nmCjuRfzxuIgALI9C2lHVnOUTaHFFQ4ueCyE8S1wF3BqfmI7avSKecs2t +CsvMo2ebKHTEm9caPARYpoKdrcd7b/+Alun4jWq9GJAd/0kakFI3ky88Al2CdgtR +5xbHV/g4+afNmyJU72OwFW1TZQNKXkqgsqeOSQBZONXH9IBk9W6VULgRfhVwOEqw +f9DEMnDAGf/JOC0ULGb0QkTmVXYbgBVX/8Cnp6o5qtjTcNAuuuuUavpfNIbnYrX9 +ivAwhZTJryQCL2/W3Wf+47BVTwSYT6RBVuKT0Gro1vP7ZeDOdcQxWQzugsgMYDNK +GbqEZycPvEJdvSRUDewdcAZfpLz6IHxV +-----END CERTIFICATE----- + +# Issuer: CN=vTrus ECC Root CA O=iTrusChina Co.,Ltd. +# Subject: CN=vTrus ECC Root CA O=iTrusChina Co.,Ltd. +# Label: "vTrus ECC Root CA" +# Serial: 630369271402956006249506845124680065938238527194 +# MD5 Fingerprint: de:4b:c1:f5:52:8c:9b:43:e1:3e:8f:55:54:17:8d:85 +# SHA1 Fingerprint: f6:9c:db:b0:fc:f6:02:13:b6:52:32:a6:a3:91:3f:16:70:da:c3:e1 +# SHA256 Fingerprint: 30:fb:ba:2c:32:23:8e:2a:98:54:7a:f9:79:31:e5:50:42:8b:9b:3f:1c:8e:eb:66:33:dc:fa:86:c5:b2:7d:d3 +-----BEGIN CERTIFICATE----- +MIICDzCCAZWgAwIBAgIUbmq8WapTvpg5Z6LSa6Q75m0c1towCgYIKoZIzj0EAwMw +RzELMAkGA1UEBhMCQ04xHDAaBgNVBAoTE2lUcnVzQ2hpbmEgQ28uLEx0ZC4xGjAY +BgNVBAMTEXZUcnVzIEVDQyBSb290IENBMB4XDTE4MDczMTA3MjY0NFoXDTQzMDcz +MTA3MjY0NFowRzELMAkGA1UEBhMCQ04xHDAaBgNVBAoTE2lUcnVzQ2hpbmEgQ28u +LEx0ZC4xGjAYBgNVBAMTEXZUcnVzIEVDQyBSb290IENBMHYwEAYHKoZIzj0CAQYF +K4EEACIDYgAEZVBKrox5lkqqHAjDo6LN/llWQXf9JpRCux3NCNtzslt188+cToL0 +v/hhJoVs1oVbcnDS/dtitN9Ti72xRFhiQgnH+n9bEOf+QP3A2MMrMudwpremIFUd +e4BdS49nTPEQo0IwQDAdBgNVHQ4EFgQUmDnNvtiyjPeyq+GtJK97fKHbH88wDwYD +VR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwCgYIKoZIzj0EAwMDaAAwZQIw +V53dVvHH4+m4SVBrm2nDb+zDfSXkV5UTQJtS0zvzQBm8JsctBp61ezaf9SXUY2sA +AjEA6dPGnlaaKsyh2j/IZivTWJwghfqrkYpwcBE4YGQLYgmRWAD5Tfs0aNoJrSEG +GJTO +-----END CERTIFICATE----- + +# Issuer: CN=vTrus Root CA O=iTrusChina Co.,Ltd. +# Subject: CN=vTrus Root CA O=iTrusChina Co.,Ltd. +# Label: "vTrus Root CA" +# Serial: 387574501246983434957692974888460947164905180485 +# MD5 Fingerprint: b8:c9:37:df:fa:6b:31:84:64:c5:ea:11:6a:1b:75:fc +# SHA1 Fingerprint: 84:1a:69:fb:f5:cd:1a:25:34:13:3d:e3:f8:fc:b8:99:d0:c9:14:b7 +# SHA256 Fingerprint: 8a:71:de:65:59:33:6f:42:6c:26:e5:38:80:d0:0d:88:a1:8d:a4:c6:a9:1f:0d:cb:61:94:e2:06:c5:c9:63:87 +-----BEGIN CERTIFICATE----- +MIIFVjCCAz6gAwIBAgIUQ+NxE9izWRRdt86M/TX9b7wFjUUwDQYJKoZIhvcNAQEL +BQAwQzELMAkGA1UEBhMCQ04xHDAaBgNVBAoTE2lUcnVzQ2hpbmEgQ28uLEx0ZC4x +FjAUBgNVBAMTDXZUcnVzIFJvb3QgQ0EwHhcNMTgwNzMxMDcyNDA1WhcNNDMwNzMx +MDcyNDA1WjBDMQswCQYDVQQGEwJDTjEcMBoGA1UEChMTaVRydXNDaGluYSBDby4s +THRkLjEWMBQGA1UEAxMNdlRydXMgUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEBBQAD +ggIPADCCAgoCggIBAL1VfGHTuB0EYgWgrmy3cLRB6ksDXhA/kFocizuwZotsSKYc +IrrVQJLuM7IjWcmOvFjai57QGfIvWcaMY1q6n6MLsLOaXLoRuBLpDLvPbmyAhykU +AyyNJJrIZIO1aqwTLDPxn9wsYTwaP3BVm60AUn/PBLn+NvqcwBauYv6WTEN+VRS+ +GrPSbcKvdmaVayqwlHeFXgQPYh1jdfdr58tbmnDsPmcF8P4HCIDPKNsFxhQnL4Z9 +8Cfe/+Z+M0jnCx5Y0ScrUw5XSmXX+6KAYPxMvDVTAWqXcoKv8R1w6Jz1717CbMdH +flqUhSZNO7rrTOiwCcJlwp2dCZtOtZcFrPUGoPc2BX70kLJrxLT5ZOrpGgrIDajt +J8nU57O5q4IikCc9Kuh8kO+8T/3iCiSn3mUkpF3qwHYw03dQ+A0Em5Q2AXPKBlim +0zvc+gRGE1WKyURHuFE5Gi7oNOJ5y1lKCn+8pu8fA2dqWSslYpPZUxlmPCdiKYZN +pGvu/9ROutW04o5IWgAZCfEF2c6Rsffr6TlP9m8EQ5pV9T4FFL2/s1m02I4zhKOQ +UqqzApVg+QxMaPnu1RcN+HFXtSXkKe5lXa/R7jwXC1pDxaWG6iSe4gUH3DRCEpHW +OXSuTEGC2/KmSNGzm/MzqvOmwMVO9fSddmPmAsYiS8GVP1BkLFTltvA8Kc9XAgMB +AAGjQjBAMB0GA1UdDgQWBBRUYnBj8XWEQ1iO0RYgscasGrz2iTAPBgNVHRMBAf8E +BTADAQH/MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAKbqSSaet +8PFww+SX8J+pJdVrnjT+5hpk9jprUrIQeBqfTNqK2uwcN1LgQkv7bHbKJAs5EhWd +nxEt/Hlk3ODg9d3gV8mlsnZwUKT+twpw1aA08XXXTUm6EdGz2OyC/+sOxL9kLX1j +bhd47F18iMjrjld22VkE+rxSH0Ws8HqA7Oxvdq6R2xCOBNyS36D25q5J08FsEhvM +Kar5CKXiNxTKsbhm7xqC5PD48acWabfbqWE8n/Uxy+QARsIvdLGx14HuqCaVvIiv +TDUHKgLKeBRtRytAVunLKmChZwOgzoy8sHJnxDHO2zTlJQNgJXtxmOTAGytfdELS +S8VZCAeHvsXDf+eW2eHcKJfWjwXj9ZtOyh1QRwVTsMo554WgicEFOwE30z9J4nfr +I8iIZjs9OXYhRvHsXyO466JmdXTBQPfYaJqT4i2pLr0cox7IdMakLXogqzu4sEb9 +b91fUlV1YvCXoHzXOP0l382gmxDPi7g4Xl7FtKYCNqEeXxzP4padKar9mK5S4fNB +UvupLnKWnyfjqnN9+BojZns7q2WwMgFLFT49ok8MKzWixtlnEjUwzXYuFrOZnk1P +Ti07NEPhmg4NpGaXutIcSkwsKouLgU9xGqndXHt7CMUADTdA43x7VF8vhV929ven +sBxXVsFy6K2ir40zSbofitzmdHxghm+Hl3s= +-----END CERTIFICATE----- + +# Issuer: CN=ISRG Root X2 O=Internet Security Research Group +# Subject: CN=ISRG Root X2 O=Internet Security Research Group +# Label: "ISRG Root X2" +# Serial: 87493402998870891108772069816698636114 +# MD5 Fingerprint: d3:9e:c4:1e:23:3c:a6:df:cf:a3:7e:6d:e0:14:e6:e5 +# SHA1 Fingerprint: bd:b1:b9:3c:d5:97:8d:45:c6:26:14:55:f8:db:95:c7:5a:d1:53:af +# SHA256 Fingerprint: 69:72:9b:8e:15:a8:6e:fc:17:7a:57:af:b7:17:1d:fc:64:ad:d2:8c:2f:ca:8c:f1:50:7e:34:45:3c:cb:14:70 +-----BEGIN CERTIFICATE----- +MIICGzCCAaGgAwIBAgIQQdKd0XLq7qeAwSxs6S+HUjAKBggqhkjOPQQDAzBPMQsw +CQYDVQQGEwJVUzEpMCcGA1UEChMgSW50ZXJuZXQgU2VjdXJpdHkgUmVzZWFyY2gg +R3JvdXAxFTATBgNVBAMTDElTUkcgUm9vdCBYMjAeFw0yMDA5MDQwMDAwMDBaFw00 +MDA5MTcxNjAwMDBaME8xCzAJBgNVBAYTAlVTMSkwJwYDVQQKEyBJbnRlcm5ldCBT +ZWN1cml0eSBSZXNlYXJjaCBHcm91cDEVMBMGA1UEAxMMSVNSRyBSb290IFgyMHYw +EAYHKoZIzj0CAQYFK4EEACIDYgAEzZvVn4CDCuwJSvMWSj5cz3es3mcFDR0HttwW ++1qLFNvicWDEukWVEYmO6gbf9yoWHKS5xcUy4APgHoIYOIvXRdgKam7mAHf7AlF9 +ItgKbppbd9/w+kHsOdx1ymgHDB/qo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0T +AQH/BAUwAwEB/zAdBgNVHQ4EFgQUfEKWrt5LSDv6kviejM9ti6lyN5UwCgYIKoZI +zj0EAwMDaAAwZQIwe3lORlCEwkSHRhtFcP9Ymd70/aTSVaYgLXTWNLxBo1BfASdW +tL4ndQavEi51mI38AjEAi/V3bNTIZargCyzuFJ0nN6T5U6VR5CmD1/iQMVtCnwr1 +/q4AaOeMSQ+2b1tbFfLn +-----END CERTIFICATE----- + +# Issuer: CN=HiPKI Root CA - G1 O=Chunghwa Telecom Co., Ltd. +# Subject: CN=HiPKI Root CA - G1 O=Chunghwa Telecom Co., Ltd. +# Label: "HiPKI Root CA - G1" +# Serial: 60966262342023497858655262305426234976 +# MD5 Fingerprint: 69:45:df:16:65:4b:e8:68:9a:8f:76:5f:ff:80:9e:d3 +# SHA1 Fingerprint: 6a:92:e4:a8:ee:1b:ec:96:45:37:e3:29:57:49:cd:96:e3:e5:d2:60 +# SHA256 Fingerprint: f0:15:ce:3c:c2:39:bf:ef:06:4b:e9:f1:d2:c4:17:e1:a0:26:4a:0a:94:be:1f:0c:8d:12:18:64:eb:69:49:cc +-----BEGIN CERTIFICATE----- +MIIFajCCA1KgAwIBAgIQLd2szmKXlKFD6LDNdmpeYDANBgkqhkiG9w0BAQsFADBP +MQswCQYDVQQGEwJUVzEjMCEGA1UECgwaQ2h1bmdod2EgVGVsZWNvbSBDby4sIEx0 +ZC4xGzAZBgNVBAMMEkhpUEtJIFJvb3QgQ0EgLSBHMTAeFw0xOTAyMjIwOTQ2MDRa +Fw0zNzEyMzExNTU5NTlaME8xCzAJBgNVBAYTAlRXMSMwIQYDVQQKDBpDaHVuZ2h3 +YSBUZWxlY29tIENvLiwgTHRkLjEbMBkGA1UEAwwSSGlQS0kgUm9vdCBDQSAtIEcx +MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA9B5/UnMyDHPkvRN0o9Qw +qNCuS9i233VHZvR85zkEHmpwINJaR3JnVfSl6J3VHiGh8Ge6zCFovkRTv4354twv +Vcg3Px+kwJyz5HdcoEb+d/oaoDjq7Zpy3iu9lFc6uux55199QmQ5eiY29yTw1S+6 +lZgRZq2XNdZ1AYDgr/SEYYwNHl98h5ZeQa/rh+r4XfEuiAU+TCK72h8q3VJGZDnz +Qs7ZngyzsHeXZJzA9KMuH5UHsBffMNsAGJZMoYFL3QRtU6M9/Aes1MU3guvklQgZ +KILSQjqj2FPseYlgSGDIcpJQ3AOPgz+yQlda22rpEZfdhSi8MEyr48KxRURHH+CK +FgeW0iEPU8DtqX7UTuybCeyvQqww1r/REEXgphaypcXTT3OUM3ECoWqj1jOXTyFj +HluP2cFeRXF3D4FdXyGarYPM+l7WjSNfGz1BryB1ZlpK9p/7qxj3ccC2HTHsOyDr +y+K49a6SsvfhhEvyovKTmiKe0xRvNlS9H15ZFblzqMF8b3ti6RZsR1pl8w4Rm0bZ +/W3c1pzAtH2lsN0/Vm+h+fbkEkj9Bn8SV7apI09bA8PgcSojt/ewsTu8mL3WmKgM +a/aOEmem8rJY5AIJEzypuxC00jBF8ez3ABHfZfjcK0NVvxaXxA/VLGGEqnKG/uY6 +fsI/fe78LxQ+5oXdUG+3Se0CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAdBgNV +HQ4EFgQU8ncX+l6o/vY9cdVouslGDDjYr7AwDgYDVR0PAQH/BAQDAgGGMA0GCSqG +SIb3DQEBCwUAA4ICAQBQUfB13HAE4/+qddRxosuej6ip0691x1TPOhwEmSKsxBHi +7zNKpiMdDg1H2DfHb680f0+BazVP6XKlMeJ45/dOlBhbQH3PayFUhuaVevvGyuqc +SE5XCV0vrPSltJczWNWseanMX/mF+lLFjfiRFOs6DRfQUsJ748JzjkZ4Bjgs6Fza +ZsT0pPBWGTMpWmWSBUdGSquEwx4noR8RkpkndZMPvDY7l1ePJlsMu5wP1G4wB9Tc +XzZoZjmDlicmisjEOf6aIW/Vcobpf2Lll07QJNBAsNB1CI69aO4I1258EHBGG3zg +iLKecoaZAeO/n0kZtCW+VmWuF2PlHt/o/0elv+EmBYTksMCv5wiZqAxeJoBF1Pho +L5aPruJKHJwWDBNvOIf2u8g0X5IDUXlwpt/L9ZlNec1OvFefQ05rLisY+GpzjLrF +Ne85akEez3GoorKGB1s6yeHvP2UEgEcyRHCVTjFnanRbEEV16rCf0OY1/k6fi8wr +kkVbbiVghUbN0aqwdmaTd5a+g744tiROJgvM7XpWGuDpWsZkrUx6AEhEL7lAuxM+ +vhV4nYWBSipX3tUZQ9rbyltHhoMLP7YNdnhzeSJesYAfz77RP1YQmCuVh6EfnWQU +YDksswBVLuT1sw5XxJFBAJw/6KXf6vb/yPCtbVKoF6ubYfwSUTXkJf2vqmqGOQ== +-----END CERTIFICATE----- + +# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R4 +# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R4 +# Label: "GlobalSign ECC Root CA - R4" +# Serial: 159662223612894884239637590694 +# MD5 Fingerprint: 26:29:f8:6d:e1:88:bf:a2:65:7f:aa:c4:cd:0f:7f:fc +# SHA1 Fingerprint: 6b:a0:b0:98:e1:71:ef:5a:ad:fe:48:15:80:77:10:f4:bd:6f:0b:28 +# SHA256 Fingerprint: b0:85:d7:0b:96:4f:19:1a:73:e4:af:0d:54:ae:7a:0e:07:aa:fd:af:9b:71:dd:08:62:13:8a:b7:32:5a:24:a2 +-----BEGIN CERTIFICATE----- +MIIB3DCCAYOgAwIBAgINAgPlfvU/k/2lCSGypjAKBggqhkjOPQQDAjBQMSQwIgYD +VQQLExtHbG9iYWxTaWduIEVDQyBSb290IENBIC0gUjQxEzARBgNVBAoTCkdsb2Jh +bFNpZ24xEzARBgNVBAMTCkdsb2JhbFNpZ24wHhcNMTIxMTEzMDAwMDAwWhcNMzgw +MTE5MDMxNDA3WjBQMSQwIgYDVQQLExtHbG9iYWxTaWduIEVDQyBSb290IENBIC0g +UjQxEzARBgNVBAoTCkdsb2JhbFNpZ24xEzARBgNVBAMTCkdsb2JhbFNpZ24wWTAT +BgcqhkjOPQIBBggqhkjOPQMBBwNCAAS4xnnTj2wlDp8uORkcA6SumuU5BwkWymOx +uYb4ilfBV85C+nOh92VC/x7BALJucw7/xyHlGKSq2XE/qNS5zowdo0IwQDAOBgNV +HQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUVLB7rUW44kB/ ++wpu+74zyTyjhNUwCgYIKoZIzj0EAwIDRwAwRAIgIk90crlgr/HmnKAWBVBfw147 +bmF0774BxL4YSFlhgjICICadVGNA3jdgUM/I2O2dgq43mLyjj0xMqTQrbO/7lZsm +-----END CERTIFICATE----- + +# Issuer: CN=GTS Root R1 O=Google Trust Services LLC +# Subject: CN=GTS Root R1 O=Google Trust Services LLC +# Label: "GTS Root R1" +# Serial: 159662320309726417404178440727 +# MD5 Fingerprint: 05:fe:d0:bf:71:a8:a3:76:63:da:01:e0:d8:52:dc:40 +# SHA1 Fingerprint: e5:8c:1c:c4:91:3b:38:63:4b:e9:10:6e:e3:ad:8e:6b:9d:d9:81:4a +# SHA256 Fingerprint: d9:47:43:2a:bd:e7:b7:fa:90:fc:2e:6b:59:10:1b:12:80:e0:e1:c7:e4:e4:0f:a3:c6:88:7f:ff:57:a7:f4:cf +-----BEGIN CERTIFICATE----- +MIIFVzCCAz+gAwIBAgINAgPlk28xsBNJiGuiFzANBgkqhkiG9w0BAQwFADBHMQsw +CQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEU +MBIGA1UEAxMLR1RTIFJvb3QgUjEwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAw +MDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZp +Y2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjEwggIiMA0GCSqGSIb3DQEBAQUA +A4ICDwAwggIKAoICAQC2EQKLHuOhd5s73L+UPreVp0A8of2C+X0yBoJx9vaMf/vo +27xqLpeXo4xL+Sv2sfnOhB2x+cWX3u+58qPpvBKJXqeqUqv4IyfLpLGcY9vXmX7w +Cl7raKb0xlpHDU0QM+NOsROjyBhsS+z8CZDfnWQpJSMHobTSPS5g4M/SCYe7zUjw +TcLCeoiKu7rPWRnWr4+wB7CeMfGCwcDfLqZtbBkOtdh+JhpFAz2weaSUKK0Pfybl +qAj+lug8aJRT7oM6iCsVlgmy4HqMLnXWnOunVmSPlk9orj2XwoSPwLxAwAtcvfaH +szVsrBhQf4TgTM2S0yDpM7xSma8ytSmzJSq0SPly4cpk9+aCEI3oncKKiPo4Zor8 +Y/kB+Xj9e1x3+naH+uzfsQ55lVe0vSbv1gHR6xYKu44LtcXFilWr06zqkUspzBmk +MiVOKvFlRNACzqrOSbTqn3yDsEB750Orp2yjj32JgfpMpf/VjsPOS+C12LOORc92 +wO1AK/1TD7Cn1TsNsYqiA94xrcx36m97PtbfkSIS5r762DL8EGMUUXLeXdYWk70p +aDPvOmbsB4om3xPXV2V4J95eSRQAogB/mqghtqmxlbCluQ0WEdrHbEg8QOB+DVrN +VjzRlwW5y0vtOUucxD/SVRNuJLDWcfr0wbrM7Rv1/oFB2ACYPTrIrnqYNxgFlQID +AQABo0IwQDAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4E +FgQU5K8rJnEaK0gnhS9SZizv8IkTcT4wDQYJKoZIhvcNAQEMBQADggIBAJ+qQibb +C5u+/x6Wki4+omVKapi6Ist9wTrYggoGxval3sBOh2Z5ofmmWJyq+bXmYOfg6LEe +QkEzCzc9zolwFcq1JKjPa7XSQCGYzyI0zzvFIoTgxQ6KfF2I5DUkzps+GlQebtuy +h6f88/qBVRRiClmpIgUxPoLW7ttXNLwzldMXG+gnoot7TiYaelpkttGsN/H9oPM4 +7HLwEXWdyzRSjeZ2axfG34arJ45JK3VmgRAhpuo+9K4l/3wV3s6MJT/KYnAK9y8J +ZgfIPxz88NtFMN9iiMG1D53Dn0reWVlHxYciNuaCp+0KueIHoI17eko8cdLiA6Ef +MgfdG+RCzgwARWGAtQsgWSl4vflVy2PFPEz0tv/bal8xa5meLMFrUKTX5hgUvYU/ +Z6tGn6D/Qqc6f1zLXbBwHSs09dR2CQzreExZBfMzQsNhFRAbd03OIozUhfJFfbdT +6u9AWpQKXCBfTkBdYiJ23//OYb2MI3jSNwLgjt7RETeJ9r/tSQdirpLsQBqvFAnZ +0E6yove+7u7Y/9waLd64NnHi/Hm3lCXRSHNboTXns5lndcEZOitHTtNCjv0xyBZm +2tIMPNuzjsmhDYAPexZ3FL//2wmUspO8IFgV6dtxQ/PeEMMA3KgqlbbC1j+Qa3bb +bP6MvPJwNQzcmRk13NfIRmPVNnGuV/u3gm3c +-----END CERTIFICATE----- + +# Issuer: CN=GTS Root R2 O=Google Trust Services LLC +# Subject: CN=GTS Root R2 O=Google Trust Services LLC +# Label: "GTS Root R2" +# Serial: 159662449406622349769042896298 +# MD5 Fingerprint: 1e:39:c0:53:e6:1e:29:82:0b:ca:52:55:36:5d:57:dc +# SHA1 Fingerprint: 9a:44:49:76:32:db:de:fa:d0:bc:fb:5a:7b:17:bd:9e:56:09:24:94 +# SHA256 Fingerprint: 8d:25:cd:97:22:9d:bf:70:35:6b:da:4e:b3:cc:73:40:31:e2:4c:f0:0f:af:cf:d3:2d:c7:6e:b5:84:1c:7e:a8 +-----BEGIN CERTIFICATE----- +MIIFVzCCAz+gAwIBAgINAgPlrsWNBCUaqxElqjANBgkqhkiG9w0BAQwFADBHMQsw +CQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEU +MBIGA1UEAxMLR1RTIFJvb3QgUjIwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAw +MDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZp +Y2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjIwggIiMA0GCSqGSIb3DQEBAQUA +A4ICDwAwggIKAoICAQDO3v2m++zsFDQ8BwZabFn3GTXd98GdVarTzTukk3LvCvpt +nfbwhYBboUhSnznFt+4orO/LdmgUud+tAWyZH8QiHZ/+cnfgLFuv5AS/T3KgGjSY +6Dlo7JUle3ah5mm5hRm9iYz+re026nO8/4Piy33B0s5Ks40FnotJk9/BW9BuXvAu +MC6C/Pq8tBcKSOWIm8Wba96wyrQD8Nr0kLhlZPdcTK3ofmZemde4wj7I0BOdre7k +RXuJVfeKH2JShBKzwkCX44ofR5GmdFrS+LFjKBC4swm4VndAoiaYecb+3yXuPuWg +f9RhD1FLPD+M2uFwdNjCaKH5wQzpoeJ/u1U8dgbuak7MkogwTZq9TwtImoS1mKPV ++3PBV2HdKFZ1E66HjucMUQkQdYhMvI35ezzUIkgfKtzra7tEscszcTJGr61K8Yzo +dDqs5xoic4DSMPclQsciOzsSrZYuxsN2B6ogtzVJV+mSSeh2FnIxZyuWfoqjx5RW +Ir9qS34BIbIjMt/kmkRtWVtd9QCgHJvGeJeNkP+byKq0rxFROV7Z+2et1VsRnTKa +G73VululycslaVNVJ1zgyjbLiGH7HrfQy+4W+9OmTN6SpdTi3/UGVN4unUu0kzCq +gc7dGtxRcw1PcOnlthYhGXmy5okLdWTK1au8CcEYof/UVKGFPP0UJAOyh9OktwID +AQABo0IwQDAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4E +FgQUu//KjiOfT5nK2+JopqUVJxce2Q4wDQYJKoZIhvcNAQEMBQADggIBAB/Kzt3H +vqGf2SdMC9wXmBFqiN495nFWcrKeGk6c1SuYJF2ba3uwM4IJvd8lRuqYnrYb/oM8 +0mJhwQTtzuDFycgTE1XnqGOtjHsB/ncw4c5omwX4Eu55MaBBRTUoCnGkJE+M3DyC +B19m3H0Q/gxhswWV7uGugQ+o+MePTagjAiZrHYNSVc61LwDKgEDg4XSsYPWHgJ2u +NmSRXbBoGOqKYcl3qJfEycel/FVL8/B/uWU9J2jQzGv6U53hkRrJXRqWbTKH7QMg +yALOWr7Z6v2yTcQvG99fevX4i8buMTolUVVnjWQye+mew4K6Ki3pHrTgSAai/Gev +HyICc/sgCq+dVEuhzf9gR7A/Xe8bVr2XIZYtCtFenTgCR2y59PYjJbigapordwj6 +xLEokCZYCDzifqrXPW+6MYgKBesntaFJ7qBFVHvmJ2WZICGoo7z7GJa7Um8M7YNR +TOlZ4iBgxcJlkoKM8xAfDoqXvneCbT+PHV28SSe9zE8P4c52hgQjxcCMElv924Sg +JPFI/2R80L5cFtHvma3AH/vLrrw4IgYmZNralw4/KBVEqE8AyvCazM90arQ+POuV +7LXTWtiBmelDGDfrs7vRWGJB82bSj6p4lVQgw1oudCvV0b4YacCs1aTPObpRhANl +6WLAYv7YTVWW4tAR+kg0Eeye7QUd5MjWHYbL +-----END CERTIFICATE----- + +# Issuer: CN=GTS Root R3 O=Google Trust Services LLC +# Subject: CN=GTS Root R3 O=Google Trust Services LLC +# Label: "GTS Root R3" +# Serial: 159662495401136852707857743206 +# MD5 Fingerprint: 3e:e7:9d:58:02:94:46:51:94:e5:e0:22:4a:8b:e7:73 +# SHA1 Fingerprint: ed:e5:71:80:2b:c8:92:b9:5b:83:3c:d2:32:68:3f:09:cd:a0:1e:46 +# SHA256 Fingerprint: 34:d8:a7:3e:e2:08:d9:bc:db:0d:95:65:20:93:4b:4e:40:e6:94:82:59:6e:8b:6f:73:c8:42:6b:01:0a:6f:48 +-----BEGIN CERTIFICATE----- +MIICCTCCAY6gAwIBAgINAgPluILrIPglJ209ZjAKBggqhkjOPQQDAzBHMQswCQYD +VQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIG +A1UEAxMLR1RTIFJvb3QgUjMwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAwMDAw +WjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2Vz +IExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjMwdjAQBgcqhkjOPQIBBgUrgQQAIgNi +AAQfTzOHMymKoYTey8chWEGJ6ladK0uFxh1MJ7x/JlFyb+Kf1qPKzEUURout736G +jOyxfi//qXGdGIRFBEFVbivqJn+7kAHjSxm65FSWRQmx1WyRRK2EE46ajA2ADDL2 +4CejQjBAMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQW +BBTB8Sa6oC2uhYHP0/EqEr24Cmf9vDAKBggqhkjOPQQDAwNpADBmAjEA9uEglRR7 +VKOQFhG/hMjqb2sXnh5GmCCbn9MN2azTL818+FsuVbu/3ZL3pAzcMeGiAjEA/Jdm +ZuVDFhOD3cffL74UOO0BzrEXGhF16b0DjyZ+hOXJYKaV11RZt+cRLInUue4X +-----END CERTIFICATE----- + +# Issuer: CN=GTS Root R4 O=Google Trust Services LLC +# Subject: CN=GTS Root R4 O=Google Trust Services LLC +# Label: "GTS Root R4" +# Serial: 159662532700760215368942768210 +# MD5 Fingerprint: 43:96:83:77:19:4d:76:b3:9d:65:52:e4:1d:22:a5:e8 +# SHA1 Fingerprint: 77:d3:03:67:b5:e0:0c:15:f6:0c:38:61:df:7c:e1:3b:92:46:4d:47 +# SHA256 Fingerprint: 34:9d:fa:40:58:c5:e2:63:12:3b:39:8a:e7:95:57:3c:4e:13:13:c8:3f:e6:8f:93:55:6c:d5:e8:03:1b:3c:7d +-----BEGIN CERTIFICATE----- +MIICCTCCAY6gAwIBAgINAgPlwGjvYxqccpBQUjAKBggqhkjOPQQDAzBHMQswCQYD +VQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIG +A1UEAxMLR1RTIFJvb3QgUjQwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAwMDAw +WjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2Vz +IExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjQwdjAQBgcqhkjOPQIBBgUrgQQAIgNi +AATzdHOnaItgrkO4NcWBMHtLSZ37wWHO5t5GvWvVYRg1rkDdc/eJkTBa6zzuhXyi +QHY7qca4R9gq55KRanPpsXI5nymfopjTX15YhmUPoYRlBtHci8nHc8iMai/lxKvR +HYqjQjBAMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQW +BBSATNbrdP9JNqPV2Py1PsVq8JQdjDAKBggqhkjOPQQDAwNpADBmAjEA6ED/g94D +9J+uHXqnLrmvT/aDHQ4thQEd0dlq7A/Cr8deVl5c1RxYIigL9zC2L7F8AjEA8GE8 +p/SgguMh1YQdc4acLa/KNJvxn7kjNuK8YAOdgLOaVsjh4rsUecrNIdSUtUlD +-----END CERTIFICATE----- + +# Issuer: CN=Telia Root CA v2 O=Telia Finland Oyj +# Subject: CN=Telia Root CA v2 O=Telia Finland Oyj +# Label: "Telia Root CA v2" +# Serial: 7288924052977061235122729490515358 +# MD5 Fingerprint: 0e:8f:ac:aa:82:df:85:b1:f4:dc:10:1c:fc:99:d9:48 +# SHA1 Fingerprint: b9:99:cd:d1:73:50:8a:c4:47:05:08:9c:8c:88:fb:be:a0:2b:40:cd +# SHA256 Fingerprint: 24:2b:69:74:2f:cb:1e:5b:2a:bf:98:89:8b:94:57:21:87:54:4e:5b:4d:99:11:78:65:73:62:1f:6a:74:b8:2c +-----BEGIN CERTIFICATE----- +MIIFdDCCA1ygAwIBAgIPAWdfJ9b+euPkrL4JWwWeMA0GCSqGSIb3DQEBCwUAMEQx +CzAJBgNVBAYTAkZJMRowGAYDVQQKDBFUZWxpYSBGaW5sYW5kIE95ajEZMBcGA1UE +AwwQVGVsaWEgUm9vdCBDQSB2MjAeFw0xODExMjkxMTU1NTRaFw00MzExMjkxMTU1 +NTRaMEQxCzAJBgNVBAYTAkZJMRowGAYDVQQKDBFUZWxpYSBGaW5sYW5kIE95ajEZ +MBcGA1UEAwwQVGVsaWEgUm9vdCBDQSB2MjCCAiIwDQYJKoZIhvcNAQEBBQADggIP +ADCCAgoCggIBALLQPwe84nvQa5n44ndp586dpAO8gm2h/oFlH0wnrI4AuhZ76zBq +AMCzdGh+sq/H1WKzej9Qyow2RCRj0jbpDIX2Q3bVTKFgcmfiKDOlyzG4OiIjNLh9 +vVYiQJ3q9HsDrWj8soFPmNB06o3lfc1jw6P23pLCWBnglrvFxKk9pXSW/q/5iaq9 +lRdU2HhE8Qx3FZLgmEKnpNaqIJLNwaCzlrI6hEKNfdWV5Nbb6WLEWLN5xYzTNTOD +n3WhUidhOPFZPY5Q4L15POdslv5e2QJltI5c0BE0312/UqeBAMN/mUWZFdUXyApT +7GPzmX3MaRKGwhfwAZ6/hLzRUssbkmbOpFPlob/E2wnW5olWK8jjfN7j/4nlNW4o +6GwLI1GpJQXrSPjdscr6bAhR77cYbETKJuFzxokGgeWKrLDiKca5JLNrRBH0pUPC +TEPlcDaMtjNXepUugqD0XBCzYYP2AgWGLnwtbNwDRm41k9V6lS/eINhbfpSQBGq6 +WT0EBXWdN6IOLj3rwaRSg/7Qa9RmjtzG6RJOHSpXqhC8fF6CfaamyfItufUXJ63R +DolUK5X6wK0dmBR4M0KGCqlztft0DbcbMBnEWg4cJ7faGND/isgFuvGqHKI3t+ZI +pEYslOqodmJHixBTB0hXbOKSTbauBcvcwUpej6w9GU7C7WB1K9vBykLVAgMBAAGj +YzBhMB8GA1UdIwQYMBaAFHKs5DN5qkWH9v2sHZ7Wxy+G2CQ5MB0GA1UdDgQWBBRy +rOQzeapFh/b9rB2e1scvhtgkOTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUw +AwEB/zANBgkqhkiG9w0BAQsFAAOCAgEAoDtZpwmUPjaE0n4vOaWWl/oRrfxn83EJ +8rKJhGdEr7nv7ZbsnGTbMjBvZ5qsfl+yqwE2foH65IRe0qw24GtixX1LDoJt0nZi +0f6X+J8wfBj5tFJ3gh1229MdqfDBmgC9bXXYfef6xzijnHDoRnkDry5023X4blMM +A8iZGok1GTzTyVR8qPAs5m4HeW9q4ebqkYJpCh3DflminmtGFZhb069GHWLIzoBS +SRE/yQQSwxN8PzuKlts8oB4KtItUsiRnDe+Cy748fdHif64W1lZYudogsYMVoe+K +TTJvQS8TUoKU1xrBeKJR3Stwbbca+few4GeXVtt8YVMJAygCQMez2P2ccGrGKMOF +6eLtGpOg3kuYooQ+BXcBlj37tCAPnHICehIv1aO6UXivKitEZU61/Qrowc15h2Er +3oBXRb9n8ZuRXqWk7FlIEA04x7D6w0RtBPV4UBySllva9bguulvP5fBqnUsvWHMt +Ty3EHD70sz+rFQ47GUGKpMFXEmZxTPpT41frYpUJnlTd0cI8Vzy9OK2YZLe4A5pT +VmBds9hCG1xLEooc6+t9xnppxyd/pPiL8uSUZodL6ZQHCRJ5irLrdATczvREWeAW +ysUsWNc8e89ihmpQfTU2Zqf7N+cox9jQraVplI/owd8k+BsHMYeB2F326CjYSlKA +rBPuUBQemMc= +-----END CERTIFICATE----- + +# Issuer: CN=D-TRUST BR Root CA 1 2020 O=D-Trust GmbH +# Subject: CN=D-TRUST BR Root CA 1 2020 O=D-Trust GmbH +# Label: "D-TRUST BR Root CA 1 2020" +# Serial: 165870826978392376648679885835942448534 +# MD5 Fingerprint: b5:aa:4b:d5:ed:f7:e3:55:2e:8f:72:0a:f3:75:b8:ed +# SHA1 Fingerprint: 1f:5b:98:f0:e3:b5:f7:74:3c:ed:e6:b0:36:7d:32:cd:f4:09:41:67 +# SHA256 Fingerprint: e5:9a:aa:81:60:09:c2:2b:ff:5b:25:ba:d3:7d:f3:06:f0:49:79:7c:1f:81:d8:5a:b0:89:e6:57:bd:8f:00:44 +-----BEGIN CERTIFICATE----- +MIIC2zCCAmCgAwIBAgIQfMmPK4TX3+oPyWWa00tNljAKBggqhkjOPQQDAzBIMQsw +CQYDVQQGEwJERTEVMBMGA1UEChMMRC1UcnVzdCBHbWJIMSIwIAYDVQQDExlELVRS +VVNUIEJSIFJvb3QgQ0EgMSAyMDIwMB4XDTIwMDIxMTA5NDUwMFoXDTM1MDIxMTA5 +NDQ1OVowSDELMAkGA1UEBhMCREUxFTATBgNVBAoTDEQtVHJ1c3QgR21iSDEiMCAG +A1UEAxMZRC1UUlVTVCBCUiBSb290IENBIDEgMjAyMDB2MBAGByqGSM49AgEGBSuB +BAAiA2IABMbLxyjR+4T1mu9CFCDhQ2tuda38KwOE1HaTJddZO0Flax7mNCq7dPYS +zuht56vkPE4/RAiLzRZxy7+SmfSk1zxQVFKQhYN4lGdnoxwJGT11NIXe7WB9xwy0 +QVK5buXuQqOCAQ0wggEJMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFHOREKv/ +VbNafAkl1bK6CKBrqx9tMA4GA1UdDwEB/wQEAwIBBjCBxgYDVR0fBIG+MIG7MD6g +PKA6hjhodHRwOi8vY3JsLmQtdHJ1c3QubmV0L2NybC9kLXRydXN0X2JyX3Jvb3Rf +Y2FfMV8yMDIwLmNybDB5oHegdYZzbGRhcDovL2RpcmVjdG9yeS5kLXRydXN0Lm5l +dC9DTj1ELVRSVVNUJTIwQlIlMjBSb290JTIwQ0ElMjAxJTIwMjAyMCxPPUQtVHJ1 +c3QlMjBHbWJILEM9REU/Y2VydGlmaWNhdGVyZXZvY2F0aW9ubGlzdDAKBggqhkjO +PQQDAwNpADBmAjEAlJAtE/rhY/hhY+ithXhUkZy4kzg+GkHaQBZTQgjKL47xPoFW +wKrY7RjEsK70PvomAjEA8yjixtsrmfu3Ubgko6SUeho/5jbiA1czijDLgsfWFBHV +dWNbFJWcHwHP2NVypw87 +-----END CERTIFICATE----- + +# Issuer: CN=D-TRUST EV Root CA 1 2020 O=D-Trust GmbH +# Subject: CN=D-TRUST EV Root CA 1 2020 O=D-Trust GmbH +# Label: "D-TRUST EV Root CA 1 2020" +# Serial: 126288379621884218666039612629459926992 +# MD5 Fingerprint: 8c:2d:9d:70:9f:48:99:11:06:11:fb:e9:cb:30:c0:6e +# SHA1 Fingerprint: 61:db:8c:21:59:69:03:90:d8:7c:9c:12:86:54:cf:9d:3d:f4:dd:07 +# SHA256 Fingerprint: 08:17:0d:1a:a3:64:53:90:1a:2f:95:92:45:e3:47:db:0c:8d:37:ab:aa:bc:56:b8:1a:a1:00:dc:95:89:70:db +-----BEGIN CERTIFICATE----- +MIIC2zCCAmCgAwIBAgIQXwJB13qHfEwDo6yWjfv/0DAKBggqhkjOPQQDAzBIMQsw +CQYDVQQGEwJERTEVMBMGA1UEChMMRC1UcnVzdCBHbWJIMSIwIAYDVQQDExlELVRS +VVNUIEVWIFJvb3QgQ0EgMSAyMDIwMB4XDTIwMDIxMTEwMDAwMFoXDTM1MDIxMTA5 +NTk1OVowSDELMAkGA1UEBhMCREUxFTATBgNVBAoTDEQtVHJ1c3QgR21iSDEiMCAG +A1UEAxMZRC1UUlVTVCBFViBSb290IENBIDEgMjAyMDB2MBAGByqGSM49AgEGBSuB +BAAiA2IABPEL3YZDIBnfl4XoIkqbz52Yv7QFJsnL46bSj8WeeHsxiamJrSc8ZRCC +/N/DnU7wMyPE0jL1HLDfMxddxfCxivnvubcUyilKwg+pf3VlSSowZ/Rk99Yad9rD +wpdhQntJraOCAQ0wggEJMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFH8QARY3 +OqQo5FD4pPfsazK2/umLMA4GA1UdDwEB/wQEAwIBBjCBxgYDVR0fBIG+MIG7MD6g +PKA6hjhodHRwOi8vY3JsLmQtdHJ1c3QubmV0L2NybC9kLXRydXN0X2V2X3Jvb3Rf +Y2FfMV8yMDIwLmNybDB5oHegdYZzbGRhcDovL2RpcmVjdG9yeS5kLXRydXN0Lm5l +dC9DTj1ELVRSVVNUJTIwRVYlMjBSb290JTIwQ0ElMjAxJTIwMjAyMCxPPUQtVHJ1 +c3QlMjBHbWJILEM9REU/Y2VydGlmaWNhdGVyZXZvY2F0aW9ubGlzdDAKBggqhkjO +PQQDAwNpADBmAjEAyjzGKnXCXnViOTYAYFqLwZOZzNnbQTs7h5kXO9XMT8oi96CA +y/m0sRtW9XLS/BnRAjEAkfcwkz8QRitxpNA7RJvAKQIFskF3UfN5Wp6OFKBOQtJb +gfM0agPnIjhQW+0ZT0MW +-----END CERTIFICATE----- + +# Issuer: CN=DigiCert TLS ECC P384 Root G5 O=DigiCert, Inc. +# Subject: CN=DigiCert TLS ECC P384 Root G5 O=DigiCert, Inc. +# Label: "DigiCert TLS ECC P384 Root G5" +# Serial: 13129116028163249804115411775095713523 +# MD5 Fingerprint: d3:71:04:6a:43:1c:db:a6:59:e1:a8:a3:aa:c5:71:ed +# SHA1 Fingerprint: 17:f3:de:5e:9f:0f:19:e9:8e:f6:1f:32:26:6e:20:c4:07:ae:30:ee +# SHA256 Fingerprint: 01:8e:13:f0:77:25:32:cf:80:9b:d1:b1:72:81:86:72:83:fc:48:c6:e1:3b:e9:c6:98:12:85:4a:49:0c:1b:05 +-----BEGIN CERTIFICATE----- +MIICGTCCAZ+gAwIBAgIQCeCTZaz32ci5PhwLBCou8zAKBggqhkjOPQQDAzBOMQsw +CQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQsIEluYy4xJjAkBgNVBAMTHURp +Z2lDZXJ0IFRMUyBFQ0MgUDM4NCBSb290IEc1MB4XDTIxMDExNTAwMDAwMFoXDTQ2 +MDExNDIzNTk1OVowTjELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDkRpZ2lDZXJ0LCBJ +bmMuMSYwJAYDVQQDEx1EaWdpQ2VydCBUTFMgRUNDIFAzODQgUm9vdCBHNTB2MBAG +ByqGSM49AgEGBSuBBAAiA2IABMFEoc8Rl1Ca3iOCNQfN0MsYndLxf3c1TzvdlHJS +7cI7+Oz6e2tYIOyZrsn8aLN1udsJ7MgT9U7GCh1mMEy7H0cKPGEQQil8pQgO4CLp +0zVozptjn4S1mU1YoI71VOeVyaNCMEAwHQYDVR0OBBYEFMFRRVBZqz7nLFr6ICIS +B4CIfBFqMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MAoGCCqGSM49 +BAMDA2gAMGUCMQCJao1H5+z8blUD2WdsJk6Dxv3J+ysTvLd6jLRl0mlpYxNjOyZQ +LgGheQaRnUi/wr4CMEfDFXuxoJGZSZOoPHzoRgaLLPIxAJSdYsiJvRmEFOml+wG4 +DXZDjC5Ty3zfDBeWUA== +-----END CERTIFICATE----- + +# Issuer: CN=DigiCert TLS RSA4096 Root G5 O=DigiCert, Inc. +# Subject: CN=DigiCert TLS RSA4096 Root G5 O=DigiCert, Inc. +# Label: "DigiCert TLS RSA4096 Root G5" +# Serial: 11930366277458970227240571539258396554 +# MD5 Fingerprint: ac:fe:f7:34:96:a9:f2:b3:b4:12:4b:e4:27:41:6f:e1 +# SHA1 Fingerprint: a7:88:49:dc:5d:7c:75:8c:8c:de:39:98:56:b3:aa:d0:b2:a5:71:35 +# SHA256 Fingerprint: 37:1a:00:dc:05:33:b3:72:1a:7e:eb:40:e8:41:9e:70:79:9d:2b:0a:0f:2c:1d:80:69:31:65:f7:ce:c4:ad:75 +-----BEGIN CERTIFICATE----- +MIIFZjCCA06gAwIBAgIQCPm0eKj6ftpqMzeJ3nzPijANBgkqhkiG9w0BAQwFADBN +MQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQsIEluYy4xJTAjBgNVBAMT +HERpZ2lDZXJ0IFRMUyBSU0E0MDk2IFJvb3QgRzUwHhcNMjEwMTE1MDAwMDAwWhcN +NDYwMTE0MjM1OTU5WjBNMQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQs +IEluYy4xJTAjBgNVBAMTHERpZ2lDZXJ0IFRMUyBSU0E0MDk2IFJvb3QgRzUwggIi +MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCz0PTJeRGd/fxmgefM1eS87IE+ +ajWOLrfn3q/5B03PMJ3qCQuZvWxX2hhKuHisOjmopkisLnLlvevxGs3npAOpPxG0 +2C+JFvuUAT27L/gTBaF4HI4o4EXgg/RZG5Wzrn4DReW+wkL+7vI8toUTmDKdFqgp +wgscONyfMXdcvyej/Cestyu9dJsXLfKB2l2w4SMXPohKEiPQ6s+d3gMXsUJKoBZM +pG2T6T867jp8nVid9E6P/DsjyG244gXazOvswzH016cpVIDPRFtMbzCe88zdH5RD +nU1/cHAN1DrRN/BsnZvAFJNY781BOHW8EwOVfH/jXOnVDdXifBBiqmvwPXbzP6Po +sMH976pXTayGpxi0KcEsDr9kvimM2AItzVwv8n/vFfQMFawKsPHTDU9qTXeXAaDx +Zre3zu/O7Oyldcqs4+Fj97ihBMi8ez9dLRYiVu1ISf6nL3kwJZu6ay0/nTvEF+cd +Lvvyz6b84xQslpghjLSR6Rlgg/IwKwZzUNWYOwbpx4oMYIwo+FKbbuH2TbsGJJvX +KyY//SovcfXWJL5/MZ4PbeiPT02jP/816t9JXkGPhvnxd3lLG7SjXi/7RgLQZhNe +XoVPzthwiHvOAbWWl9fNff2C+MIkwcoBOU+NosEUQB+cZtUMCUbW8tDRSHZWOkPL +tgoRObqME2wGtZ7P6wIDAQABo0IwQDAdBgNVHQ4EFgQUUTMc7TZArxfTJc1paPKv +TiM+s0EwDgYDVR0PAQH/BAQDAgGGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcN +AQEMBQADggIBAGCmr1tfV9qJ20tQqcQjNSH/0GEwhJG3PxDPJY7Jv0Y02cEhJhxw +GXIeo8mH/qlDZJY6yFMECrZBu8RHANmfGBg7sg7zNOok992vIGCukihfNudd5N7H +PNtQOa27PShNlnx2xlv0wdsUpasZYgcYQF+Xkdycx6u1UQ3maVNVzDl92sURVXLF +O4uJ+DQtpBflF+aZfTCIITfNMBc9uPK8qHWgQ9w+iUuQrm0D4ByjoJYJu32jtyoQ +REtGBzRj7TG5BO6jm5qu5jF49OokYTurWGT/u4cnYiWB39yhL/btp/96j1EuMPik +AdKFOV8BmZZvWltwGUb+hmA+rYAQCd05JS9Yf7vSdPD3Rh9GOUrYU9DzLjtxpdRv +/PNn5AeP3SYZ4Y1b+qOTEZvpyDrDVWiakuFSdjjo4bq9+0/V77PnSIMx8IIh47a+ +p6tv75/fTM8BuGJqIz3nCU2AG3swpMPdB380vqQmsvZB6Akd4yCYqjdP//fx4ilw +MUc/dNAUFvohigLVigmUdy7yWSiLfFCSCmZ4OIN1xLVaqBHG5cGdZlXPU8Sv13WF +qUITVuwhd4GTWgzqltlJyqEI8pc7bZsEGCREjnwB8twl2F6GmrE52/WRMmrRpnCK +ovfepEWFJqgejF0pW8hL2JpqA15w8oVPbEtoL8pU9ozaMv7Da4M/OMZ+ +-----END CERTIFICATE----- + +# Issuer: CN=Certainly Root R1 O=Certainly +# Subject: CN=Certainly Root R1 O=Certainly +# Label: "Certainly Root R1" +# Serial: 188833316161142517227353805653483829216 +# MD5 Fingerprint: 07:70:d4:3e:82:87:a0:fa:33:36:13:f4:fa:33:e7:12 +# SHA1 Fingerprint: a0:50:ee:0f:28:71:f4:27:b2:12:6d:6f:50:96:25:ba:cc:86:42:af +# SHA256 Fingerprint: 77:b8:2c:d8:64:4c:43:05:f7:ac:c5:cb:15:6b:45:67:50:04:03:3d:51:c6:0c:62:02:a8:e0:c3:34:67:d3:a0 +-----BEGIN CERTIFICATE----- +MIIFRzCCAy+gAwIBAgIRAI4P+UuQcWhlM1T01EQ5t+AwDQYJKoZIhvcNAQELBQAw +PTELMAkGA1UEBhMCVVMxEjAQBgNVBAoTCUNlcnRhaW5seTEaMBgGA1UEAxMRQ2Vy +dGFpbmx5IFJvb3QgUjEwHhcNMjEwNDAxMDAwMDAwWhcNNDYwNDAxMDAwMDAwWjA9 +MQswCQYDVQQGEwJVUzESMBAGA1UEChMJQ2VydGFpbmx5MRowGAYDVQQDExFDZXJ0 +YWlubHkgUm9vdCBSMTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBANA2 +1B/q3avk0bbm+yLA3RMNansiExyXPGhjZjKcA7WNpIGD2ngwEc/csiu+kr+O5MQT +vqRoTNoCaBZ0vrLdBORrKt03H2As2/X3oXyVtwxwhi7xOu9S98zTm/mLvg7fMbed +aFySpvXl8wo0tf97ouSHocavFwDvA5HtqRxOcT3Si2yJ9HiG5mpJoM610rCrm/b0 +1C7jcvk2xusVtyWMOvwlDbMicyF0yEqWYZL1LwsYpfSt4u5BvQF5+paMjRcCMLT5 +r3gajLQ2EBAHBXDQ9DGQilHFhiZ5shGIXsXwClTNSaa/ApzSRKft43jvRl5tcdF5 +cBxGX1HpyTfcX35pe0HfNEXgO4T0oYoKNp43zGJS4YkNKPl6I7ENPT2a/Z2B7yyQ +wHtETrtJ4A5KVpK8y7XdeReJkd5hiXSSqOMyhb5OhaRLWcsrxXiOcVTQAjeZjOVJ +6uBUcqQRBi8LjMFbvrWhsFNunLhgkR9Za/kt9JQKl7XsxXYDVBtlUrpMklZRNaBA +2CnbrlJ2Oy0wQJuK0EJWtLeIAaSHO1OWzaMWj/Nmqhexx2DgwUMFDO6bW2BvBlyH +Wyf5QBGenDPBt+U1VwV/J84XIIwc/PH72jEpSe31C4SnT8H2TsIonPru4K8H+zMR +eiFPCyEQtkA6qyI6BJyLm4SGcprSp6XEtHWRqSsjAgMBAAGjQjBAMA4GA1UdDwEB +/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBTgqj8ljZ9EXME66C6u +d0yEPmcM9DANBgkqhkiG9w0BAQsFAAOCAgEAuVevuBLaV4OPaAszHQNTVfSVcOQr +PbA56/qJYv331hgELyE03fFo8NWWWt7CgKPBjcZq91l3rhVkz1t5BXdm6ozTaw3d +8VkswTOlMIAVRQdFGjEitpIAq5lNOo93r6kiyi9jyhXWx8bwPWz8HA2YEGGeEaIi +1wrykXprOQ4vMMM2SZ/g6Q8CRFA3lFV96p/2O7qUpUzpvD5RtOjKkjZUbVwlKNrd +rRT90+7iIgXr0PK3aBLXWopBGsaSpVo7Y0VPv+E6dyIvXL9G+VoDhRNCX8reU9di +taY1BMJH/5n9hN9czulegChB8n3nHpDYT3Y+gjwN/KUD+nsa2UUeYNrEjvn8K8l7 +lcUq/6qJ34IxD3L/DCfXCh5WAFAeDJDBlrXYFIW7pw0WwfgHJBu6haEaBQmAupVj +yTrsJZ9/nbqkRxWbRHDxakvWOF5D8xh+UG7pWijmZeZ3Gzr9Hb4DJqPb1OG7fpYn +Kx3upPvaJVQTA945xsMfTZDsjxtK0hzthZU4UHlG1sGQUDGpXJpuHfUzVounmdLy +yCwzk5Iwx06MZTMQZBf9JBeW0Y3COmor6xOLRPIh80oat3df1+2IpHLlOR+Vnb5n +wXARPbv0+Em34yaXOp/SX3z7wJl8OSngex2/DaeP0ik0biQVy96QXr8axGbqwua6 +OV+KmalBWQewLK8= +-----END CERTIFICATE----- + +# Issuer: CN=Certainly Root E1 O=Certainly +# Subject: CN=Certainly Root E1 O=Certainly +# Label: "Certainly Root E1" +# Serial: 8168531406727139161245376702891150584 +# MD5 Fingerprint: 0a:9e:ca:cd:3e:52:50:c6:36:f3:4b:a3:ed:a7:53:e9 +# SHA1 Fingerprint: f9:e1:6d:dc:01:89:cf:d5:82:45:63:3e:c5:37:7d:c2:eb:93:6f:2b +# SHA256 Fingerprint: b4:58:5f:22:e4:ac:75:6a:4e:86:12:a1:36:1c:5d:9d:03:1a:93:fd:84:fe:bb:77:8f:a3:06:8b:0f:c4:2d:c2 +-----BEGIN CERTIFICATE----- +MIIB9zCCAX2gAwIBAgIQBiUzsUcDMydc+Y2aub/M+DAKBggqhkjOPQQDAzA9MQsw +CQYDVQQGEwJVUzESMBAGA1UEChMJQ2VydGFpbmx5MRowGAYDVQQDExFDZXJ0YWlu +bHkgUm9vdCBFMTAeFw0yMTA0MDEwMDAwMDBaFw00NjA0MDEwMDAwMDBaMD0xCzAJ +BgNVBAYTAlVTMRIwEAYDVQQKEwlDZXJ0YWlubHkxGjAYBgNVBAMTEUNlcnRhaW5s +eSBSb290IEUxMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAE3m/4fxzf7flHh4axpMCK ++IKXgOqPyEpeKn2IaKcBYhSRJHpcnqMXfYqGITQYUBsQ3tA3SybHGWCA6TS9YBk2 +QNYphwk8kXr2vBMj3VlOBF7PyAIcGFPBMdjaIOlEjeR2o0IwQDAOBgNVHQ8BAf8E +BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQU8ygYy2R17ikq6+2uI1g4 +hevIIgcwCgYIKoZIzj0EAwMDaAAwZQIxALGOWiDDshliTd6wT99u0nCK8Z9+aozm +ut6Dacpps6kFtZaSF4fC0urQe87YQVt8rgIwRt7qy12a7DLCZRawTDBcMPPaTnOG +BtjOiQRINzf43TNRnXCve1XYAS59BWQOhriR +-----END CERTIFICATE----- + +# Issuer: CN=Security Communication RootCA3 O=SECOM Trust Systems CO.,LTD. +# Subject: CN=Security Communication RootCA3 O=SECOM Trust Systems CO.,LTD. +# Label: "Security Communication RootCA3" +# Serial: 16247922307909811815 +# MD5 Fingerprint: 1c:9a:16:ff:9e:5c:e0:4d:8a:14:01:f4:35:5d:29:26 +# SHA1 Fingerprint: c3:03:c8:22:74:92:e5:61:a2:9c:5f:79:91:2b:1e:44:13:91:30:3a +# SHA256 Fingerprint: 24:a5:5c:2a:b0:51:44:2d:06:17:76:65:41:23:9a:4a:d0:32:d7:c5:51:75:aa:34:ff:de:2f:bc:4f:5c:52:94 +-----BEGIN CERTIFICATE----- +MIIFfzCCA2egAwIBAgIJAOF8N0D9G/5nMA0GCSqGSIb3DQEBDAUAMF0xCzAJBgNV +BAYTAkpQMSUwIwYDVQQKExxTRUNPTSBUcnVzdCBTeXN0ZW1zIENPLixMVEQuMScw +JQYDVQQDEx5TZWN1cml0eSBDb21tdW5pY2F0aW9uIFJvb3RDQTMwHhcNMTYwNjE2 +MDYxNzE2WhcNMzgwMTE4MDYxNzE2WjBdMQswCQYDVQQGEwJKUDElMCMGA1UEChMc +U0VDT00gVHJ1c3QgU3lzdGVtcyBDTy4sTFRELjEnMCUGA1UEAxMeU2VjdXJpdHkg +Q29tbXVuaWNhdGlvbiBSb290Q0EzMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIIC +CgKCAgEA48lySfcw3gl8qUCBWNO0Ot26YQ+TUG5pPDXC7ltzkBtnTCHsXzW7OT4r +CmDvu20rhvtxosis5FaU+cmvsXLUIKx00rgVrVH+hXShuRD+BYD5UpOzQD11EKzA +lrenfna84xtSGc4RHwsENPXY9Wk8d/Nk9A2qhd7gCVAEF5aEt8iKvE1y/By7z/MG +TfmfZPd+pmaGNXHIEYBMwXFAWB6+oHP2/D5Q4eAvJj1+XCO1eXDe+uDRpdYMQXF7 +9+qMHIjH7Iv10S9VlkZ8WjtYO/u62C21Jdp6Ts9EriGmnpjKIG58u4iFW/vAEGK7 +8vknR+/RiTlDxN/e4UG/VHMgly1s2vPUB6PmudhvrvyMGS7TZ2crldtYXLVqAvO4 +g160a75BflcJdURQVc1aEWEhCmHCqYj9E7wtiS/NYeCVvsq1e+F7NGcLH7YMx3we +GVPKp7FKFSBWFHA9K4IsD50VHUeAR/94mQ4xr28+j+2GaR57GIgUssL8gjMunEst ++3A7caoreyYn8xrC3PsXuKHqy6C0rtOUfnrQq8PsOC0RLoi/1D+tEjtCrI8Cbn3M +0V9hvqG8OmpI6iZVIhZdXw3/JzOfGAN0iltSIEdrRU0id4xVJ/CvHozJgyJUt5rQ +T9nO/NkuHJYosQLTA70lUhw0Zk8jq/R3gpYd0VcwCBEF/VfR2ccCAwEAAaNCMEAw +HQYDVR0OBBYEFGQUfPxYchamCik0FW8qy7z8r6irMA4GA1UdDwEB/wQEAwIBBjAP +BgNVHRMBAf8EBTADAQH/MA0GCSqGSIb3DQEBDAUAA4ICAQDcAiMI4u8hOscNtybS +YpOnpSNyByCCYN8Y11StaSWSntkUz5m5UoHPrmyKO1o5yGwBQ8IibQLwYs1OY0PA +FNr0Y/Dq9HHuTofjcan0yVflLl8cebsjqodEV+m9NU1Bu0soo5iyG9kLFwfl9+qd +9XbXv8S2gVj/yP9kaWJ5rW4OH3/uHWnlt3Jxs/6lATWUVCvAUm2PVcTJ0rjLyjQI +UYWg9by0F1jqClx6vWPGOi//lkkZhOpn2ASxYfQAW0q3nHE3GYV5v4GwxxMOdnE+ +OoAGrgYWp421wsTL/0ClXI2lyTrtcoHKXJg80jQDdwj98ClZXSEIx2C/pHF7uNke +gr4Jr2VvKKu/S7XuPghHJ6APbw+LP6yVGPO5DtxnVW5inkYO0QR4ynKudtml+LLf +iAlhi+8kTtFZP1rUPcmTPCtk9YENFpb3ksP+MW/oKjJ0DvRMmEoYDjBU1cXrvMUV +nuiZIesnKwkK2/HmcBhWuwzkvvnoEKQTkrgc4NtnHVMDpCKn3F2SEDzq//wbEBrD +2NCcnWXL0CsnMQMeNuE9dnUM/0Umud1RvCPHX9jYhxBAEg09ODfnRDwYwFMJZI// +1ZqmfHAuc1Uh6N//g7kdPjIe1qZ9LPFm6Vwdp6POXiUyK+OVrCoHzrQoeIY8Laad +TdJ0MN1kURXbg4NR16/9M51NZg== +-----END CERTIFICATE----- + +# Issuer: CN=Security Communication ECC RootCA1 O=SECOM Trust Systems CO.,LTD. +# Subject: CN=Security Communication ECC RootCA1 O=SECOM Trust Systems CO.,LTD. +# Label: "Security Communication ECC RootCA1" +# Serial: 15446673492073852651 +# MD5 Fingerprint: 7e:43:b0:92:68:ec:05:43:4c:98:ab:5d:35:2e:7e:86 +# SHA1 Fingerprint: b8:0e:26:a9:bf:d2:b2:3b:c0:ef:46:c9:ba:c7:bb:f6:1d:0d:41:41 +# SHA256 Fingerprint: e7:4f:bd:a5:5b:d5:64:c4:73:a3:6b:44:1a:a7:99:c8:a6:8e:07:74:40:e8:28:8b:9f:a1:e5:0e:4b:ba:ca:11 +-----BEGIN CERTIFICATE----- +MIICODCCAb6gAwIBAgIJANZdm7N4gS7rMAoGCCqGSM49BAMDMGExCzAJBgNVBAYT +AkpQMSUwIwYDVQQKExxTRUNPTSBUcnVzdCBTeXN0ZW1zIENPLixMVEQuMSswKQYD +VQQDEyJTZWN1cml0eSBDb21tdW5pY2F0aW9uIEVDQyBSb290Q0ExMB4XDTE2MDYx +NjA1MTUyOFoXDTM4MDExODA1MTUyOFowYTELMAkGA1UEBhMCSlAxJTAjBgNVBAoT +HFNFQ09NIFRydXN0IFN5c3RlbXMgQ08uLExURC4xKzApBgNVBAMTIlNlY3VyaXR5 +IENvbW11bmljYXRpb24gRUNDIFJvb3RDQTEwdjAQBgcqhkjOPQIBBgUrgQQAIgNi +AASkpW9gAwPDvTH00xecK4R1rOX9PVdu12O/5gSJko6BnOPpR27KkBLIE+Cnnfdl +dB9sELLo5OnvbYUymUSxXv3MdhDYW72ixvnWQuRXdtyQwjWpS4g8EkdtXP9JTxpK +ULGjQjBAMB0GA1UdDgQWBBSGHOf+LaVKiwj+KBH6vqNm+GBZLzAOBgNVHQ8BAf8E +BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAKBggqhkjOPQQDAwNoADBlAjAVXUI9/Lbu +9zuxNuie9sRGKEkz0FhDKmMpzE2xtHqiuQ04pV1IKv3LsnNdo4gIxwwCMQDAqy0O +be0YottT6SXbVQjgUMzfRGEWgqtJsLKB7HOHeLRMsmIbEvoWTSVLY70eN9k= +-----END CERTIFICATE----- + +# Issuer: CN=BJCA Global Root CA1 O=BEIJING CERTIFICATE AUTHORITY +# Subject: CN=BJCA Global Root CA1 O=BEIJING CERTIFICATE AUTHORITY +# Label: "BJCA Global Root CA1" +# Serial: 113562791157148395269083148143378328608 +# MD5 Fingerprint: 42:32:99:76:43:33:36:24:35:07:82:9b:28:f9:d0:90 +# SHA1 Fingerprint: d5:ec:8d:7b:4c:ba:79:f4:e7:e8:cb:9d:6b:ae:77:83:10:03:21:6a +# SHA256 Fingerprint: f3:89:6f:88:fe:7c:0a:88:27:66:a7:fa:6a:d2:74:9f:b5:7a:7f:3e:98:fb:76:9c:1f:a7:b0:9c:2c:44:d5:ae +-----BEGIN CERTIFICATE----- +MIIFdDCCA1ygAwIBAgIQVW9l47TZkGobCdFsPsBsIDANBgkqhkiG9w0BAQsFADBU +MQswCQYDVQQGEwJDTjEmMCQGA1UECgwdQkVJSklORyBDRVJUSUZJQ0FURSBBVVRI +T1JJVFkxHTAbBgNVBAMMFEJKQ0EgR2xvYmFsIFJvb3QgQ0ExMB4XDTE5MTIxOTAz +MTYxN1oXDTQ0MTIxMjAzMTYxN1owVDELMAkGA1UEBhMCQ04xJjAkBgNVBAoMHUJF +SUpJTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZMR0wGwYDVQQDDBRCSkNBIEdsb2Jh +bCBSb290IENBMTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAPFmCL3Z +xRVhy4QEQaVpN3cdwbB7+sN3SJATcmTRuHyQNZ0YeYjjlwE8R4HyDqKYDZ4/N+AZ +spDyRhySsTphzvq3Rp4Dhtczbu33RYx2N95ulpH3134rhxfVizXuhJFyV9xgw8O5 +58dnJCNPYwpj9mZ9S1WnP3hkSWkSl+BMDdMJoDIwOvqfwPKcxRIqLhy1BDPapDgR +at7GGPZHOiJBhyL8xIkoVNiMpTAK+BcWyqw3/XmnkRd4OJmtWO2y3syJfQOcs4ll +5+M7sSKGjwZteAf9kRJ/sGsciQ35uMt0WwfCyPQ10WRjeulumijWML3mG90Vr4Tq +nMfK9Q7q8l0ph49pczm+LiRvRSGsxdRpJQaDrXpIhRMsDQa4bHlW/KNnMoH1V6XK +V0Jp6VwkYe/iMBhORJhVb3rCk9gZtt58R4oRTklH2yiUAguUSiz5EtBP6DF+bHq/ +pj+bOT0CFqMYs2esWz8sgytnOYFcuX6U1WTdno9uruh8W7TXakdI136z1C2OVnZO +z2nxbkRs1CTqjSShGL+9V/6pmTW12xB3uD1IutbB5/EjPtffhZ0nPNRAvQoMvfXn +jSXWgXSHRtQpdaJCbPdzied9v3pKH9MiyRVVz99vfFXQpIsHETdfg6YmV6YBW37+ +WGgHqel62bno/1Afq8K0wM7o6v0PvY1NuLxxAgMBAAGjQjBAMB0GA1UdDgQWBBTF +7+3M2I0hxkjk49cULqcWk+WYATAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQE +AwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAUoKsITQfI/Ki2Pm4rzc2IInRNwPWaZ+4 +YRC6ojGYWUfo0Q0lHhVBDOAqVdVXUsv45Mdpox1NcQJeXyFFYEhcCY5JEMEE3Kli +awLwQ8hOnThJdMkycFRtwUf8jrQ2ntScvd0g1lPJGKm1Vrl2i5VnZu69mP6u775u ++2D2/VnGKhs/I0qUJDAnyIm860Qkmss9vk/Ves6OF8tiwdneHg56/0OGNFK8YT88 +X7vZdrRTvJez/opMEi4r89fO4aL/3Xtw+zuhTaRjAv04l5U/BXCga99igUOLtFkN +SoxUnMW7gZ/NfaXvCyUeOiDbHPwfmGcCCtRzRBPbUYQaVQNW4AB+dAb/OMRyHdOo +P2gxXdMJxy6MW2Pg6Nwe0uxhHvLe5e/2mXZgLR6UcnHGCyoyx5JO1UbXHfmpGQrI ++pXObSOYqgs4rZpWDW+N8TEAiMEXnM0ZNjX+VVOg4DwzX5Ze4jLp3zO7Bkqp2IRz +znfSxqxx4VyjHQy7Ct9f4qNx2No3WqB4K/TUfet27fJhcKVlmtOJNBir+3I+17Q9 +eVzYH6Eze9mCUAyTF6ps3MKCuwJXNq+YJyo5UOGwifUll35HaBC07HPKs5fRJNz2 +YqAo07WjuGS3iGJCz51TzZm+ZGiPTx4SSPfSKcOYKMryMguTjClPPGAyzQWWYezy +r/6zcCwupvI= +-----END CERTIFICATE----- + +# Issuer: CN=BJCA Global Root CA2 O=BEIJING CERTIFICATE AUTHORITY +# Subject: CN=BJCA Global Root CA2 O=BEIJING CERTIFICATE AUTHORITY +# Label: "BJCA Global Root CA2" +# Serial: 58605626836079930195615843123109055211 +# MD5 Fingerprint: 5e:0a:f6:47:5f:a6:14:e8:11:01:95:3f:4d:01:eb:3c +# SHA1 Fingerprint: f4:27:86:eb:6e:b8:6d:88:31:67:02:fb:ba:66:a4:53:00:aa:7a:a6 +# SHA256 Fingerprint: 57:4d:f6:93:1e:27:80:39:66:7b:72:0a:fd:c1:60:0f:c2:7e:b6:6d:d3:09:29:79:fb:73:85:64:87:21:28:82 +-----BEGIN CERTIFICATE----- +MIICJTCCAaugAwIBAgIQLBcIfWQqwP6FGFkGz7RK6zAKBggqhkjOPQQDAzBUMQsw +CQYDVQQGEwJDTjEmMCQGA1UECgwdQkVJSklORyBDRVJUSUZJQ0FURSBBVVRIT1JJ +VFkxHTAbBgNVBAMMFEJKQ0EgR2xvYmFsIFJvb3QgQ0EyMB4XDTE5MTIxOTAzMTgy +MVoXDTQ0MTIxMjAzMTgyMVowVDELMAkGA1UEBhMCQ04xJjAkBgNVBAoMHUJFSUpJ +TkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZMR0wGwYDVQQDDBRCSkNBIEdsb2JhbCBS +b290IENBMjB2MBAGByqGSM49AgEGBSuBBAAiA2IABJ3LgJGNU2e1uVCxA/jlSR9B +IgmwUVJY1is0j8USRhTFiy8shP8sbqjV8QnjAyEUxEM9fMEsxEtqSs3ph+B99iK+ ++kpRuDCK/eHeGBIK9ke35xe/J4rUQUyWPGCWwf0VHKNCMEAwHQYDVR0OBBYEFNJK +sVF/BvDRgh9Obl+rg/xI1LCRMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQD +AgEGMAoGCCqGSM49BAMDA2gAMGUCMBq8W9f+qdJUDkpd0m2xQNz0Q9XSSpkZElaA +94M04TVOSG0ED1cxMDAtsaqdAzjbBgIxAMvMh1PLet8gUXOQwKhbYdDFUDn9hf7B +43j4ptZLvZuHjw/l1lOWqzzIQNph91Oj9w== +-----END CERTIFICATE----- + +# Issuer: CN=Sectigo Public Server Authentication Root E46 O=Sectigo Limited +# Subject: CN=Sectigo Public Server Authentication Root E46 O=Sectigo Limited +# Label: "Sectigo Public Server Authentication Root E46" +# Serial: 88989738453351742415770396670917916916 +# MD5 Fingerprint: 28:23:f8:b2:98:5c:37:16:3b:3e:46:13:4e:b0:b3:01 +# SHA1 Fingerprint: ec:8a:39:6c:40:f0:2e:bc:42:75:d4:9f:ab:1c:1a:5b:67:be:d2:9a +# SHA256 Fingerprint: c9:0f:26:f0:fb:1b:40:18:b2:22:27:51:9b:5c:a2:b5:3e:2c:a5:b3:be:5c:f1:8e:fe:1b:ef:47:38:0c:53:83 +-----BEGIN CERTIFICATE----- +MIICOjCCAcGgAwIBAgIQQvLM2htpN0RfFf51KBC49DAKBggqhkjOPQQDAzBfMQsw +CQYDVQQGEwJHQjEYMBYGA1UEChMPU2VjdGlnbyBMaW1pdGVkMTYwNAYDVQQDEy1T +ZWN0aWdvIFB1YmxpYyBTZXJ2ZXIgQXV0aGVudGljYXRpb24gUm9vdCBFNDYwHhcN +MjEwMzIyMDAwMDAwWhcNNDYwMzIxMjM1OTU5WjBfMQswCQYDVQQGEwJHQjEYMBYG +A1UEChMPU2VjdGlnbyBMaW1pdGVkMTYwNAYDVQQDEy1TZWN0aWdvIFB1YmxpYyBT +ZXJ2ZXIgQXV0aGVudGljYXRpb24gUm9vdCBFNDYwdjAQBgcqhkjOPQIBBgUrgQQA +IgNiAAR2+pmpbiDt+dd34wc7qNs9Xzjoq1WmVk/WSOrsfy2qw7LFeeyZYX8QeccC +WvkEN/U0NSt3zn8gj1KjAIns1aeibVvjS5KToID1AZTc8GgHHs3u/iVStSBDHBv+ +6xnOQ6OjQjBAMB0GA1UdDgQWBBTRItpMWfFLXyY4qp3W7usNw/upYTAOBgNVHQ8B +Af8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAKBggqhkjOPQQDAwNnADBkAjAn7qRa +qCG76UeXlImldCBteU/IvZNeWBj7LRoAasm4PdCkT0RHlAFWovgzJQxC36oCMB3q +4S6ILuH5px0CMk7yn2xVdOOurvulGu7t0vzCAxHrRVxgED1cf5kDW21USAGKcw== +-----END CERTIFICATE----- + +# Issuer: CN=Sectigo Public Server Authentication Root R46 O=Sectigo Limited +# Subject: CN=Sectigo Public Server Authentication Root R46 O=Sectigo Limited +# Label: "Sectigo Public Server Authentication Root R46" +# Serial: 156256931880233212765902055439220583700 +# MD5 Fingerprint: 32:10:09:52:00:d5:7e:6c:43:df:15:c0:b1:16:93:e5 +# SHA1 Fingerprint: ad:98:f9:f3:e4:7d:75:3b:65:d4:82:b3:a4:52:17:bb:6e:f5:e4:38 +# SHA256 Fingerprint: 7b:b6:47:a6:2a:ee:ac:88:bf:25:7a:a5:22:d0:1f:fe:a3:95:e0:ab:45:c7:3f:93:f6:56:54:ec:38:f2:5a:06 +-----BEGIN CERTIFICATE----- +MIIFijCCA3KgAwIBAgIQdY39i658BwD6qSWn4cetFDANBgkqhkiG9w0BAQwFADBf +MQswCQYDVQQGEwJHQjEYMBYGA1UEChMPU2VjdGlnbyBMaW1pdGVkMTYwNAYDVQQD +Ey1TZWN0aWdvIFB1YmxpYyBTZXJ2ZXIgQXV0aGVudGljYXRpb24gUm9vdCBSNDYw +HhcNMjEwMzIyMDAwMDAwWhcNNDYwMzIxMjM1OTU5WjBfMQswCQYDVQQGEwJHQjEY +MBYGA1UEChMPU2VjdGlnbyBMaW1pdGVkMTYwNAYDVQQDEy1TZWN0aWdvIFB1Ymxp +YyBTZXJ2ZXIgQXV0aGVudGljYXRpb24gUm9vdCBSNDYwggIiMA0GCSqGSIb3DQEB +AQUAA4ICDwAwggIKAoICAQCTvtU2UnXYASOgHEdCSe5jtrch/cSV1UgrJnwUUxDa +ef0rty2k1Cz66jLdScK5vQ9IPXtamFSvnl0xdE8H/FAh3aTPaE8bEmNtJZlMKpnz +SDBh+oF8HqcIStw+KxwfGExxqjWMrfhu6DtK2eWUAtaJhBOqbchPM8xQljeSM9xf +iOefVNlI8JhD1mb9nxc4Q8UBUQvX4yMPFF1bFOdLvt30yNoDN9HWOaEhUTCDsG3X +ME6WW5HwcCSrv0WBZEMNvSE6Lzzpng3LILVCJ8zab5vuZDCQOc2TZYEhMbUjUDM3 +IuM47fgxMMxF/mL50V0yeUKH32rMVhlATc6qu/m1dkmU8Sf4kaWD5QazYw6A3OAS +VYCmO2a0OYctyPDQ0RTp5A1NDvZdV3LFOxxHVp3i1fuBYYzMTYCQNFu31xR13NgE +SJ/AwSiItOkcyqex8Va3e0lMWeUgFaiEAin6OJRpmkkGj80feRQXEgyDet4fsZfu ++Zd4KKTIRJLpfSYFplhym3kT2BFfrsU4YjRosoYwjviQYZ4ybPUHNs2iTG7sijbt +8uaZFURww3y8nDnAtOFr94MlI1fZEoDlSfB1D++N6xybVCi0ITz8fAr/73trdf+L +HaAZBav6+CuBQug4urv7qv094PPK306Xlynt8xhW6aWWrL3DkJiy4Pmi1KZHQ3xt +zwIDAQABo0IwQDAdBgNVHQ4EFgQUVnNYZJX5khqwEioEYnmhQBWIIUkwDgYDVR0P +AQH/BAQDAgGGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEMBQADggIBAC9c +mTz8Bl6MlC5w6tIyMY208FHVvArzZJ8HXtXBc2hkeqK5Duj5XYUtqDdFqij0lgVQ +YKlJfp/imTYpE0RHap1VIDzYm/EDMrraQKFz6oOht0SmDpkBm+S8f74TlH7Kph52 +gDY9hAaLMyZlbcp+nv4fjFg4exqDsQ+8FxG75gbMY/qB8oFM2gsQa6H61SilzwZA +Fv97fRheORKkU55+MkIQpiGRqRxOF3yEvJ+M0ejf5lG5Nkc/kLnHvALcWxxPDkjB +JYOcCj+esQMzEhonrPcibCTRAUH4WAP+JWgiH5paPHxsnnVI84HxZmduTILA7rpX +DhjvLpr3Etiga+kFpaHpaPi8TD8SHkXoUsCjvxInebnMMTzD9joiFgOgyY9mpFui +TdaBJQbpdqQACj7LzTWb4OE4y2BThihCQRxEV+ioratF4yUQvNs+ZUH7G6aXD+u5 +dHn5HrwdVw1Hr8Mvn4dGp+smWg9WY7ViYG4A++MnESLn/pmPNPW56MORcr3Ywx65 +LvKRRFHQV80MNNVIIb/bE/FmJUNS0nAiNs2fxBx1IK1jcmMGDw4nztJqDby1ORrp +0XZ60Vzk50lJLVU3aPAaOpg+VBeHVOmmJ1CJeyAvP/+/oYtKR5j/K3tJPsMpRmAY +QqszKbrAKbkTidOIijlBO8n9pu0f9GBj39ItVQGL +-----END CERTIFICATE----- + +# Issuer: CN=SSL.com TLS RSA Root CA 2022 O=SSL Corporation +# Subject: CN=SSL.com TLS RSA Root CA 2022 O=SSL Corporation +# Label: "SSL.com TLS RSA Root CA 2022" +# Serial: 148535279242832292258835760425842727825 +# MD5 Fingerprint: d8:4e:c6:59:30:d8:fe:a0:d6:7a:5a:2c:2c:69:78:da +# SHA1 Fingerprint: ec:2c:83:40:72:af:26:95:10:ff:0e:f2:03:ee:31:70:f6:78:9d:ca +# SHA256 Fingerprint: 8f:af:7d:2e:2c:b4:70:9b:b8:e0:b3:36:66:bf:75:a5:dd:45:b5:de:48:0f:8e:a8:d4:bf:e6:be:bc:17:f2:ed +-----BEGIN CERTIFICATE----- +MIIFiTCCA3GgAwIBAgIQb77arXO9CEDii02+1PdbkTANBgkqhkiG9w0BAQsFADBO +MQswCQYDVQQGEwJVUzEYMBYGA1UECgwPU1NMIENvcnBvcmF0aW9uMSUwIwYDVQQD +DBxTU0wuY29tIFRMUyBSU0EgUm9vdCBDQSAyMDIyMB4XDTIyMDgyNTE2MzQyMloX +DTQ2MDgxOTE2MzQyMVowTjELMAkGA1UEBhMCVVMxGDAWBgNVBAoMD1NTTCBDb3Jw +b3JhdGlvbjElMCMGA1UEAwwcU1NMLmNvbSBUTFMgUlNBIFJvb3QgQ0EgMjAyMjCC +AiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBANCkCXJPQIgSYT41I57u9nTP +L3tYPc48DRAokC+X94xI2KDYJbFMsBFMF3NQ0CJKY7uB0ylu1bUJPiYYf7ISf5OY +t6/wNr/y7hienDtSxUcZXXTzZGbVXcdotL8bHAajvI9AI7YexoS9UcQbOcGV0ins +S657Lb85/bRi3pZ7QcacoOAGcvvwB5cJOYF0r/c0WRFXCsJbwST0MXMwgsadugL3 +PnxEX4MN8/HdIGkWCVDi1FW24IBydm5MR7d1VVm0U3TZlMZBrViKMWYPHqIbKUBO +L9975hYsLfy/7PO0+r4Y9ptJ1O4Fbtk085zx7AGL0SDGD6C1vBdOSHtRwvzpXGk3 +R2azaPgVKPC506QVzFpPulJwoxJF3ca6TvvC0PeoUidtbnm1jPx7jMEWTO6Af77w +dr5BUxIzrlo4QqvXDz5BjXYHMtWrifZOZ9mxQnUjbvPNQrL8VfVThxc7wDNY8VLS ++YCk8OjwO4s4zKTGkH8PnP2L0aPP2oOnaclQNtVcBdIKQXTbYxE3waWglksejBYS +d66UNHsef8JmAOSqg+qKkK3ONkRN0VHpvB/zagX9wHQfJRlAUW7qglFA35u5CCoG +AtUjHBPW6dvbxrB6y3snm/vg1UYk7RBLY0ulBY+6uB0rpvqR4pJSvezrZ5dtmi2f +gTIFZzL7SAg/2SW4BCUvAgMBAAGjYzBhMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0j +BBgwFoAU+y437uOEeicuzRk1sTN8/9REQrkwHQYDVR0OBBYEFPsuN+7jhHonLs0Z +NbEzfP/UREK5MA4GA1UdDwEB/wQEAwIBhjANBgkqhkiG9w0BAQsFAAOCAgEAjYlt +hEUY8U+zoO9opMAdrDC8Z2awms22qyIZZtM7QbUQnRC6cm4pJCAcAZli05bg4vsM +QtfhWsSWTVTNj8pDU/0quOr4ZcoBwq1gaAafORpR2eCNJvkLTqVTJXojpBzOCBvf +R4iyrT7gJ4eLSYwfqUdYe5byiB0YrrPRpgqU+tvT5TgKa3kSM/tKWTcWQA673vWJ +DPFs0/dRa1419dvAJuoSc06pkZCmF8NsLzjUo3KUQyxi4U5cMj29TH0ZR6LDSeeW +P4+a0zvkEdiLA9z2tmBVGKaBUfPhqBVq6+AL8BQx1rmMRTqoENjwuSfr98t67wVy +lrXEj5ZzxOhWc5y8aVFjvO9nHEMaX3cZHxj4HCUp+UmZKbaSPaKDN7EgkaibMOlq +bLQjk2UEqxHzDh1TJElTHaE/nUiSEeJ9DU/1172iWD54nR4fK/4huxoTtrEoZP2w +AgDHbICivRZQIA9ygV/MlP+7mea6kMvq+cYMwq7FGc4zoWtcu358NFcXrfA/rs3q +r5nsLFR+jM4uElZI7xc7P0peYNLcdDa8pUNjyw9bowJWCZ4kLOGGgYz+qxcs+sji +Mho6/4UIyYOf8kpIEFR3N+2ivEC+5BB09+Rbu7nzifmPQdjH5FCQNYA+HLhNkNPU +98OwoX6EyneSMSy4kLGCenROmxMmtNVQZlR4rmA= +-----END CERTIFICATE----- + +# Issuer: CN=SSL.com TLS ECC Root CA 2022 O=SSL Corporation +# Subject: CN=SSL.com TLS ECC Root CA 2022 O=SSL Corporation +# Label: "SSL.com TLS ECC Root CA 2022" +# Serial: 26605119622390491762507526719404364228 +# MD5 Fingerprint: 99:d7:5c:f1:51:36:cc:e9:ce:d9:19:2e:77:71:56:c5 +# SHA1 Fingerprint: 9f:5f:d9:1a:54:6d:f5:0c:71:f0:ee:7a:bd:17:49:98:84:73:e2:39 +# SHA256 Fingerprint: c3:2f:fd:9f:46:f9:36:d1:6c:36:73:99:09:59:43:4b:9a:d6:0a:af:bb:9e:7c:f3:36:54:f1:44:cc:1b:a1:43 +-----BEGIN CERTIFICATE----- +MIICOjCCAcCgAwIBAgIQFAP1q/s3ixdAW+JDsqXRxDAKBggqhkjOPQQDAzBOMQsw +CQYDVQQGEwJVUzEYMBYGA1UECgwPU1NMIENvcnBvcmF0aW9uMSUwIwYDVQQDDBxT +U0wuY29tIFRMUyBFQ0MgUm9vdCBDQSAyMDIyMB4XDTIyMDgyNTE2MzM0OFoXDTQ2 +MDgxOTE2MzM0N1owTjELMAkGA1UEBhMCVVMxGDAWBgNVBAoMD1NTTCBDb3Jwb3Jh +dGlvbjElMCMGA1UEAwwcU1NMLmNvbSBUTFMgRUNDIFJvb3QgQ0EgMjAyMjB2MBAG +ByqGSM49AgEGBSuBBAAiA2IABEUpNXP6wrgjzhR9qLFNoFs27iosU8NgCTWyJGYm +acCzldZdkkAZDsalE3D07xJRKF3nzL35PIXBz5SQySvOkkJYWWf9lCcQZIxPBLFN +SeR7T5v15wj4A4j3p8OSSxlUgaNjMGEwDwYDVR0TAQH/BAUwAwEB/zAfBgNVHSME +GDAWgBSJjy+j6CugFFR781a4Jl9nOAuc0DAdBgNVHQ4EFgQUiY8vo+groBRUe/NW +uCZfZzgLnNAwDgYDVR0PAQH/BAQDAgGGMAoGCCqGSM49BAMDA2gAMGUCMFXjIlbp +15IkWE8elDIPDAI2wv2sdDJO4fscgIijzPvX6yv/N33w7deedWo1dlJF4AIxAMeN +b0Igj762TVntd00pxCAgRWSGOlDGxK0tk/UYfXLtqc/ErFc2KAhl3zx5Zn6g6g== +-----END CERTIFICATE----- + +# Issuer: CN=Atos TrustedRoot Root CA ECC TLS 2021 O=Atos +# Subject: CN=Atos TrustedRoot Root CA ECC TLS 2021 O=Atos +# Label: "Atos TrustedRoot Root CA ECC TLS 2021" +# Serial: 81873346711060652204712539181482831616 +# MD5 Fingerprint: 16:9f:ad:f1:70:ad:79:d6:ed:29:b4:d1:c5:79:70:a8 +# SHA1 Fingerprint: 9e:bc:75:10:42:b3:02:f3:81:f4:f7:30:62:d4:8f:c3:a7:51:b2:dd +# SHA256 Fingerprint: b2:fa:e5:3e:14:cc:d7:ab:92:12:06:47:01:ae:27:9c:1d:89:88:fa:cb:77:5f:a8:a0:08:91:4e:66:39:88:a8 +-----BEGIN CERTIFICATE----- +MIICFTCCAZugAwIBAgIQPZg7pmY9kGP3fiZXOATvADAKBggqhkjOPQQDAzBMMS4w +LAYDVQQDDCVBdG9zIFRydXN0ZWRSb290IFJvb3QgQ0EgRUNDIFRMUyAyMDIxMQ0w +CwYDVQQKDARBdG9zMQswCQYDVQQGEwJERTAeFw0yMTA0MjIwOTI2MjNaFw00MTA0 +MTcwOTI2MjJaMEwxLjAsBgNVBAMMJUF0b3MgVHJ1c3RlZFJvb3QgUm9vdCBDQSBF +Q0MgVExTIDIwMjExDTALBgNVBAoMBEF0b3MxCzAJBgNVBAYTAkRFMHYwEAYHKoZI +zj0CAQYFK4EEACIDYgAEloZYKDcKZ9Cg3iQZGeHkBQcfl+3oZIK59sRxUM6KDP/X +tXa7oWyTbIOiaG6l2b4siJVBzV3dscqDY4PMwL502eCdpO5KTlbgmClBk1IQ1SQ4 +AjJn8ZQSb+/Xxd4u/RmAo0IwQDAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBR2 +KCXWfeBmmnoJsmo7jjPXNtNPojAOBgNVHQ8BAf8EBAMCAYYwCgYIKoZIzj0EAwMD +aAAwZQIwW5kp85wxtolrbNa9d+F851F+uDrNozZffPc8dz7kUK2o59JZDCaOMDtu +CCrCp1rIAjEAmeMM56PDr9NJLkaCI2ZdyQAUEv049OGYa3cpetskz2VAv9LcjBHo +9H1/IISpQuQo +-----END CERTIFICATE----- + +# Issuer: CN=Atos TrustedRoot Root CA RSA TLS 2021 O=Atos +# Subject: CN=Atos TrustedRoot Root CA RSA TLS 2021 O=Atos +# Label: "Atos TrustedRoot Root CA RSA TLS 2021" +# Serial: 111436099570196163832749341232207667876 +# MD5 Fingerprint: d4:d3:46:b8:9a:c0:9c:76:5d:9e:3a:c3:b9:99:31:d2 +# SHA1 Fingerprint: 18:52:3b:0d:06:37:e4:d6:3a:df:23:e4:98:fb:5b:16:fb:86:74:48 +# SHA256 Fingerprint: 81:a9:08:8e:a5:9f:b3:64:c5:48:a6:f8:55:59:09:9b:6f:04:05:ef:bf:18:e5:32:4e:c9:f4:57:ba:00:11:2f +-----BEGIN CERTIFICATE----- +MIIFZDCCA0ygAwIBAgIQU9XP5hmTC/srBRLYwiqipDANBgkqhkiG9w0BAQwFADBM +MS4wLAYDVQQDDCVBdG9zIFRydXN0ZWRSb290IFJvb3QgQ0EgUlNBIFRMUyAyMDIx +MQ0wCwYDVQQKDARBdG9zMQswCQYDVQQGEwJERTAeFw0yMTA0MjIwOTIxMTBaFw00 +MTA0MTcwOTIxMDlaMEwxLjAsBgNVBAMMJUF0b3MgVHJ1c3RlZFJvb3QgUm9vdCBD +QSBSU0EgVExTIDIwMjExDTALBgNVBAoMBEF0b3MxCzAJBgNVBAYTAkRFMIICIjAN +BgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAtoAOxHm9BYx9sKOdTSJNy/BBl01Z +4NH+VoyX8te9j2y3I49f1cTYQcvyAh5x5en2XssIKl4w8i1mx4QbZFc4nXUtVsYv +Ye+W/CBGvevUez8/fEc4BKkbqlLfEzfTFRVOvV98r61jx3ncCHvVoOX3W3WsgFWZ +kmGbzSoXfduP9LVq6hdKZChmFSlsAvFr1bqjM9xaZ6cF4r9lthawEO3NUDPJcFDs +GY6wx/J0W2tExn2WuZgIWWbeKQGb9Cpt0xU6kGpn8bRrZtkh68rZYnxGEFzedUln +nkL5/nWpo63/dgpnQOPF943HhZpZnmKaau1Fh5hnstVKPNe0OwANwI8f4UDErmwh +3El+fsqyjW22v5MvoVw+j8rtgI5Y4dtXz4U2OLJxpAmMkokIiEjxQGMYsluMWuPD +0xeqqxmjLBvk1cbiZnrXghmmOxYsL3GHX0WelXOTwkKBIROW1527k2gV+p2kHYzy +geBYBr3JtuP2iV2J+axEoctr+hbxx1A9JNr3w+SH1VbxT5Aw+kUJWdo0zuATHAR8 +ANSbhqRAvNncTFd+rrcztl524WWLZt+NyteYr842mIycg5kDcPOvdO3GDjbnvezB +c6eUWsuSZIKmAMFwoW4sKeFYV+xafJlrJaSQOoD0IJ2azsct+bJLKZWD6TWNp0lI +pw9MGZHQ9b8Q4HECAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQU +dEmZ0f+0emhFdcN+tNzMzjkz2ggwDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEB +DAUAA4ICAQAjQ1MkYlxt/T7Cz1UAbMVWiLkO3TriJQ2VSpfKgInuKs1l+NsW4AmS +4BjHeJi78+xCUvuppILXTdiK/ORO/auQxDh1MoSf/7OwKwIzNsAQkG8dnK/haZPs +o0UvFJ/1TCplQ3IM98P4lYsU84UgYt1UU90s3BiVaU+DR3BAM1h3Egyi61IxHkzJ +qM7F78PRreBrAwA0JrRUITWXAdxfG/F851X6LWh3e9NpzNMOa7pNdkTWwhWaJuyw +xfW70Xp0wmzNxbVe9kzmWy2B27O3Opee7c9GslA9hGCZcbUztVdF5kJHdWoOsAgM +rr3e97sPWD2PAzHoPYJQyi9eDF20l74gNAf0xBLh7tew2VktafcxBPTy+av5EzH4 +AXcOPUIjJsyacmdRIXrMPIWo6iFqO9taPKU0nprALN+AnCng33eU0aKAQv9qTFsR +0PXNor6uzFFcw9VUewyu1rkGd4Di7wcaaMxZUa1+XGdrudviB0JbuAEFWDlN5LuY +o7Ey7Nmj1m+UI/87tyll5gfp77YZ6ufCOB0yiJA8EytuzO+rdwY0d4RPcuSBhPm5 +dDTedk+SKlOxJTnbPP/lPqYO5Wue/9vsL3SD3460s6neFE3/MaNFcyT6lSnMEpcE +oji2jbDwN/zIIX8/syQbPYtuzE2wFg2WHYMfRsCbvUOZ58SWLs5fyQ== +-----END CERTIFICATE----- + +# Issuer: CN=TrustAsia Global Root CA G3 O=TrustAsia Technologies, Inc. +# Subject: CN=TrustAsia Global Root CA G3 O=TrustAsia Technologies, Inc. +# Label: "TrustAsia Global Root CA G3" +# Serial: 576386314500428537169965010905813481816650257167 +# MD5 Fingerprint: 30:42:1b:b7:bb:81:75:35:e4:16:4f:53:d2:94:de:04 +# SHA1 Fingerprint: 63:cf:b6:c1:27:2b:56:e4:88:8e:1c:23:9a:b6:2e:81:47:24:c3:c7 +# SHA256 Fingerprint: e0:d3:22:6a:eb:11:63:c2:e4:8f:f9:be:3b:50:b4:c6:43:1b:e7:bb:1e:ac:c5:c3:6b:5d:5e:c5:09:03:9a:08 +-----BEGIN CERTIFICATE----- +MIIFpTCCA42gAwIBAgIUZPYOZXdhaqs7tOqFhLuxibhxkw8wDQYJKoZIhvcNAQEM +BQAwWjELMAkGA1UEBhMCQ04xJTAjBgNVBAoMHFRydXN0QXNpYSBUZWNobm9sb2dp +ZXMsIEluYy4xJDAiBgNVBAMMG1RydXN0QXNpYSBHbG9iYWwgUm9vdCBDQSBHMzAe +Fw0yMTA1MjAwMjEwMTlaFw00NjA1MTkwMjEwMTlaMFoxCzAJBgNVBAYTAkNOMSUw +IwYDVQQKDBxUcnVzdEFzaWEgVGVjaG5vbG9naWVzLCBJbmMuMSQwIgYDVQQDDBtU +cnVzdEFzaWEgR2xvYmFsIFJvb3QgQ0EgRzMwggIiMA0GCSqGSIb3DQEBAQUAA4IC +DwAwggIKAoICAQDAMYJhkuSUGwoqZdC+BqmHO1ES6nBBruL7dOoKjbmzTNyPtxNS +T1QY4SxzlZHFZjtqz6xjbYdT8PfxObegQ2OwxANdV6nnRM7EoYNl9lA+sX4WuDqK +AtCWHwDNBSHvBm3dIZwZQ0WhxeiAysKtQGIXBsaqvPPW5vxQfmZCHzyLpnl5hkA1 +nyDvP+uLRx+PjsXUjrYsyUQE49RDdT/VP68czH5GX6zfZBCK70bwkPAPLfSIC7Ep +qq+FqklYqL9joDiR5rPmd2jE+SoZhLsO4fWvieylL1AgdB4SQXMeJNnKziyhWTXA +yB1GJ2Faj/lN03J5Zh6fFZAhLf3ti1ZwA0pJPn9pMRJpxx5cynoTi+jm9WAPzJMs +hH/x/Gr8m0ed262IPfN2dTPXS6TIi/n1Q1hPy8gDVI+lhXgEGvNz8teHHUGf59gX +zhqcD0r83ERoVGjiQTz+LISGNzzNPy+i2+f3VANfWdP3kXjHi3dqFuVJhZBFcnAv +kV34PmVACxmZySYgWmjBNb9Pp1Hx2BErW+Canig7CjoKH8GB5S7wprlppYiU5msT +f9FkPz2ccEblooV7WIQn3MSAPmeamseaMQ4w7OYXQJXZRe0Blqq/DPNL0WP3E1jA +uPP6Z92bfW1K/zJMtSU7/xxnD4UiWQWRkUF3gdCFTIcQcf+eQxuulXUtgQIDAQAB +o2MwYTAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFEDk5PIj7zjKsK5Xf/Ih +MBY027ySMB0GA1UdDgQWBBRA5OTyI+84yrCuV3/yITAWNNu8kjAOBgNVHQ8BAf8E +BAMCAQYwDQYJKoZIhvcNAQEMBQADggIBACY7UeFNOPMyGLS0XuFlXsSUT9SnYaP4 +wM8zAQLpw6o1D/GUE3d3NZ4tVlFEbuHGLige/9rsR82XRBf34EzC4Xx8MnpmyFq2 +XFNFV1pF1AWZLy4jVe5jaN/TG3inEpQGAHUNcoTpLrxaatXeL1nHo+zSh2bbt1S1 +JKv0Q3jbSwTEb93mPmY+KfJLaHEih6D4sTNjduMNhXJEIlU/HHzp/LgV6FL6qj6j +ITk1dImmasI5+njPtqzn59ZW/yOSLlALqbUHM/Q4X6RJpstlcHboCoWASzY9M/eV +VHUl2qzEc4Jl6VL1XP04lQJqaTDFHApXB64ipCz5xUG3uOyfT0gA+QEEVcys+TIx +xHWVBqB/0Y0n3bOppHKH/lmLmnp0Ft0WpWIp6zqW3IunaFnT63eROfjXy9mPX1on +AX1daBli2MjN9LdyR75bl87yraKZk62Uy5P2EgmVtqvXO9A/EcswFi55gORngS1d +7XB4tmBZrOFdRWOPyN9yaFvqHbgB8X7754qz41SgOAngPN5C8sLtLpvzHzW2Ntjj +gKGLzZlkD8Kqq7HK9W+eQ42EVJmzbsASZthwEPEGNTNDqJwuuhQxzhB/HIbjj9LV ++Hfsm6vxL2PZQl/gZ4FkkfGXL/xuJvYz+NO1+MRiqzFRJQJ6+N1rZdVtTTDIZbpo +FGWsJwt0ivKH +-----END CERTIFICATE----- + +# Issuer: CN=TrustAsia Global Root CA G4 O=TrustAsia Technologies, Inc. +# Subject: CN=TrustAsia Global Root CA G4 O=TrustAsia Technologies, Inc. +# Label: "TrustAsia Global Root CA G4" +# Serial: 451799571007117016466790293371524403291602933463 +# MD5 Fingerprint: 54:dd:b2:d7:5f:d8:3e:ed:7c:e0:0b:2e:cc:ed:eb:eb +# SHA1 Fingerprint: 57:73:a5:61:5d:80:b2:e6:ac:38:82:fc:68:07:31:ac:9f:b5:92:5a +# SHA256 Fingerprint: be:4b:56:cb:50:56:c0:13:6a:52:6d:f4:44:50:8d:aa:36:a0:b5:4f:42:e4:ac:38:f7:2a:f4:70:e4:79:65:4c +-----BEGIN CERTIFICATE----- +MIICVTCCAdygAwIBAgIUTyNkuI6XY57GU4HBdk7LKnQV1tcwCgYIKoZIzj0EAwMw +WjELMAkGA1UEBhMCQ04xJTAjBgNVBAoMHFRydXN0QXNpYSBUZWNobm9sb2dpZXMs +IEluYy4xJDAiBgNVBAMMG1RydXN0QXNpYSBHbG9iYWwgUm9vdCBDQSBHNDAeFw0y +MTA1MjAwMjEwMjJaFw00NjA1MTkwMjEwMjJaMFoxCzAJBgNVBAYTAkNOMSUwIwYD +VQQKDBxUcnVzdEFzaWEgVGVjaG5vbG9naWVzLCBJbmMuMSQwIgYDVQQDDBtUcnVz +dEFzaWEgR2xvYmFsIFJvb3QgQ0EgRzQwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAATx +s8045CVD5d4ZCbuBeaIVXxVjAd7Cq92zphtnS4CDr5nLrBfbK5bKfFJV4hrhPVbw +LxYI+hW8m7tH5j/uqOFMjPXTNvk4XatwmkcN4oFBButJ+bAp3TPsUKV/eSm4IJij +YzBhMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUpbtKl86zK3+kMd6Xg1mD +pm9xy94wHQYDVR0OBBYEFKW7SpfOsyt/pDHel4NZg6ZvccveMA4GA1UdDwEB/wQE +AwIBBjAKBggqhkjOPQQDAwNnADBkAjBe8usGzEkxn0AAbbd+NvBNEU/zy4k6LHiR +UKNbwMp1JvK/kF0LgoxgKJ/GcJpo5PECMFxYDlZ2z1jD1xCMuo6u47xkdUfFVZDj +/bpV6wfEU6s3qe4hsiFbYI89MvHVI5TWWA== +-----END CERTIFICATE----- + +# Issuer: CN=CommScope Public Trust ECC Root-01 O=CommScope +# Subject: CN=CommScope Public Trust ECC Root-01 O=CommScope +# Label: "CommScope Public Trust ECC Root-01" +# Serial: 385011430473757362783587124273108818652468453534 +# MD5 Fingerprint: 3a:40:a7:fc:03:8c:9c:38:79:2f:3a:a2:6c:b6:0a:16 +# SHA1 Fingerprint: 07:86:c0:d8:dd:8e:c0:80:98:06:98:d0:58:7a:ef:de:a6:cc:a2:5d +# SHA256 Fingerprint: 11:43:7c:da:7b:b4:5e:41:36:5f:45:b3:9a:38:98:6b:0d:e0:0d:ef:34:8e:0c:7b:b0:87:36:33:80:0b:c3:8b +-----BEGIN CERTIFICATE----- +MIICHTCCAaOgAwIBAgIUQ3CCd89NXTTxyq4yLzf39H91oJ4wCgYIKoZIzj0EAwMw +TjELMAkGA1UEBhMCVVMxEjAQBgNVBAoMCUNvbW1TY29wZTErMCkGA1UEAwwiQ29t +bVNjb3BlIFB1YmxpYyBUcnVzdCBFQ0MgUm9vdC0wMTAeFw0yMTA0MjgxNzM1NDNa +Fw00NjA0MjgxNzM1NDJaME4xCzAJBgNVBAYTAlVTMRIwEAYDVQQKDAlDb21tU2Nv +cGUxKzApBgNVBAMMIkNvbW1TY29wZSBQdWJsaWMgVHJ1c3QgRUNDIFJvb3QtMDEw +djAQBgcqhkjOPQIBBgUrgQQAIgNiAARLNumuV16ocNfQj3Rid8NeeqrltqLxeP0C +flfdkXmcbLlSiFS8LwS+uM32ENEp7LXQoMPwiXAZu1FlxUOcw5tjnSCDPgYLpkJE +hRGnSjot6dZoL0hOUysHP029uax3OVejQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYD +VR0PAQH/BAQDAgEGMB0GA1UdDgQWBBSOB2LAUN3GGQYARnQE9/OufXVNMDAKBggq +hkjOPQQDAwNoADBlAjEAnDPfQeMjqEI2Jpc1XHvr20v4qotzVRVcrHgpD7oh2MSg +2NED3W3ROT3Ek2DS43KyAjB8xX6I01D1HiXo+k515liWpDVfG2XqYZpwI7UNo5uS +Um9poIyNStDuiw7LR47QjRE= +-----END CERTIFICATE----- + +# Issuer: CN=CommScope Public Trust ECC Root-02 O=CommScope +# Subject: CN=CommScope Public Trust ECC Root-02 O=CommScope +# Label: "CommScope Public Trust ECC Root-02" +# Serial: 234015080301808452132356021271193974922492992893 +# MD5 Fingerprint: 59:b0:44:d5:65:4d:b8:5c:55:19:92:02:b6:d1:94:b2 +# SHA1 Fingerprint: 3c:3f:ef:57:0f:fe:65:93:86:9e:a0:fe:b0:f6:ed:8e:d1:13:c7:e5 +# SHA256 Fingerprint: 2f:fb:7f:81:3b:bb:b3:c8:9a:b4:e8:16:2d:0f:16:d7:15:09:a8:30:cc:9d:73:c2:62:e5:14:08:75:d1:ad:4a +-----BEGIN CERTIFICATE----- +MIICHDCCAaOgAwIBAgIUKP2ZYEFHpgE6yhR7H+/5aAiDXX0wCgYIKoZIzj0EAwMw +TjELMAkGA1UEBhMCVVMxEjAQBgNVBAoMCUNvbW1TY29wZTErMCkGA1UEAwwiQ29t +bVNjb3BlIFB1YmxpYyBUcnVzdCBFQ0MgUm9vdC0wMjAeFw0yMTA0MjgxNzQ0NTRa +Fw00NjA0MjgxNzQ0NTNaME4xCzAJBgNVBAYTAlVTMRIwEAYDVQQKDAlDb21tU2Nv +cGUxKzApBgNVBAMMIkNvbW1TY29wZSBQdWJsaWMgVHJ1c3QgRUNDIFJvb3QtMDIw +djAQBgcqhkjOPQIBBgUrgQQAIgNiAAR4MIHoYx7l63FRD/cHB8o5mXxO1Q/MMDAL +j2aTPs+9xYa9+bG3tD60B8jzljHz7aRP+KNOjSkVWLjVb3/ubCK1sK9IRQq9qEmU +v4RDsNuESgMjGWdqb8FuvAY5N9GIIvejQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYD +VR0PAQH/BAQDAgEGMB0GA1UdDgQWBBTmGHX/72DehKT1RsfeSlXjMjZ59TAKBggq +hkjOPQQDAwNnADBkAjAmc0l6tqvmSfR9Uj/UQQSugEODZXW5hYA4O9Zv5JOGq4/n +ich/m35rChJVYaoR4HkCMHfoMXGsPHED1oQmHhS48zs73u1Z/GtMMH9ZzkXpc2AV +mkzw5l4lIhVtwodZ0LKOag== +-----END CERTIFICATE----- + +# Issuer: CN=CommScope Public Trust RSA Root-01 O=CommScope +# Subject: CN=CommScope Public Trust RSA Root-01 O=CommScope +# Label: "CommScope Public Trust RSA Root-01" +# Serial: 354030733275608256394402989253558293562031411421 +# MD5 Fingerprint: 0e:b4:15:bc:87:63:5d:5d:02:73:d4:26:38:68:73:d8 +# SHA1 Fingerprint: 6d:0a:5f:f7:b4:23:06:b4:85:b3:b7:97:64:fc:ac:75:f5:33:f2:93 +# SHA256 Fingerprint: 02:bd:f9:6e:2a:45:dd:9b:f1:8f:c7:e1:db:df:21:a0:37:9b:a3:c9:c2:61:03:44:cf:d8:d6:06:fe:c1:ed:81 +-----BEGIN CERTIFICATE----- +MIIFbDCCA1SgAwIBAgIUPgNJgXUWdDGOTKvVxZAplsU5EN0wDQYJKoZIhvcNAQEL +BQAwTjELMAkGA1UEBhMCVVMxEjAQBgNVBAoMCUNvbW1TY29wZTErMCkGA1UEAwwi +Q29tbVNjb3BlIFB1YmxpYyBUcnVzdCBSU0EgUm9vdC0wMTAeFw0yMTA0MjgxNjQ1 +NTRaFw00NjA0MjgxNjQ1NTNaME4xCzAJBgNVBAYTAlVTMRIwEAYDVQQKDAlDb21t +U2NvcGUxKzApBgNVBAMMIkNvbW1TY29wZSBQdWJsaWMgVHJ1c3QgUlNBIFJvb3Qt +MDEwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCwSGWjDR1C45FtnYSk +YZYSwu3D2iM0GXb26v1VWvZVAVMP8syMl0+5UMuzAURWlv2bKOx7dAvnQmtVzslh +suitQDy6uUEKBU8bJoWPQ7VAtYXR1HHcg0Hz9kXHgKKEUJdGzqAMxGBWBB0HW0al +DrJLpA6lfO741GIDuZNqihS4cPgugkY4Iw50x2tBt9Apo52AsH53k2NC+zSDO3Oj +WiE260f6GBfZumbCk6SP/F2krfxQapWsvCQz0b2If4b19bJzKo98rwjyGpg/qYFl +P8GMicWWMJoKz/TUyDTtnS+8jTiGU+6Xn6myY5QXjQ/cZip8UlF1y5mO6D1cv547 +KI2DAg+pn3LiLCuz3GaXAEDQpFSOm117RTYm1nJD68/A6g3czhLmfTifBSeolz7p +UcZsBSjBAg/pGG3svZwG1KdJ9FQFa2ww8esD1eo9anbCyxooSU1/ZOD6K9pzg4H/ +kQO9lLvkuI6cMmPNn7togbGEW682v3fuHX/3SZtS7NJ3Wn2RnU3COS3kuoL4b/JO +Hg9O5j9ZpSPcPYeoKFgo0fEbNttPxP/hjFtyjMcmAyejOQoBqsCyMWCDIqFPEgkB +Ea801M/XrmLTBQe0MXXgDW1XT2mH+VepuhX2yFJtocucH+X8eKg1mp9BFM6ltM6U +CBwJrVbl2rZJmkrqYxhTnCwuwwIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4G +A1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUN12mmnQywsL5x6YVEFm45P3luG0wDQYJ +KoZIhvcNAQELBQADggIBAK+nz97/4L1CjU3lIpbfaOp9TSp90K09FlxD533Ahuh6 +NWPxzIHIxgvoLlI1pKZJkGNRrDSsBTtXAOnTYtPZKdVUvhwQkZyybf5Z/Xn36lbQ +nmhUQo8mUuJM3y+Xpi/SB5io82BdS5pYV4jvguX6r2yBS5KPQJqTRlnLX3gWsWc+ +QgvfKNmwrZggvkN80V4aCRckjXtdlemrwWCrWxhkgPut4AZ9HcpZuPN4KWfGVh2v +trV0KnahP/t1MJ+UXjulYPPLXAziDslg+MkfFoom3ecnf+slpoq9uC02EJqxWE2a +aE9gVOX2RhOOiKy8IUISrcZKiX2bwdgt6ZYD9KJ0DLwAHb/WNyVntHKLr4W96ioD +j8z7PEQkguIBpQtZtjSNMgsSDesnwv1B10A8ckYpwIzqug/xBpMu95yo9GA+o/E4 +Xo4TwbM6l4c/ksp4qRyv0LAbJh6+cOx69TOY6lz/KwsETkPdY34Op054A5U+1C0w +lREQKC6/oAI+/15Z0wUOlV9TRe9rh9VIzRamloPh37MG88EU26fsHItdkJANclHn +YfkUyq+Dj7+vsQpZXdxc1+SWrVtgHdqul7I52Qb1dgAT+GhMIbA1xNxVssnBQVoc +icCMb3SgazNNtQEo/a2tiRc7ppqEvOuM6sRxJKi6KfkIsidWNTJf6jn7MZrVGczw +-----END CERTIFICATE----- + +# Issuer: CN=CommScope Public Trust RSA Root-02 O=CommScope +# Subject: CN=CommScope Public Trust RSA Root-02 O=CommScope +# Label: "CommScope Public Trust RSA Root-02" +# Serial: 480062499834624527752716769107743131258796508494 +# MD5 Fingerprint: e1:29:f9:62:7b:76:e2:96:6d:f3:d4:d7:0f:ae:1f:aa +# SHA1 Fingerprint: ea:b0:e2:52:1b:89:93:4c:11:68:f2:d8:9a:ac:22:4c:a3:8a:57:ae +# SHA256 Fingerprint: ff:e9:43:d7:93:42:4b:4f:7c:44:0c:1c:3d:64:8d:53:63:f3:4b:82:dc:87:aa:7a:9f:11:8f:c5:de:e1:01:f1 +-----BEGIN CERTIFICATE----- +MIIFbDCCA1SgAwIBAgIUVBa/O345lXGN0aoApYYNK496BU4wDQYJKoZIhvcNAQEL +BQAwTjELMAkGA1UEBhMCVVMxEjAQBgNVBAoMCUNvbW1TY29wZTErMCkGA1UEAwwi +Q29tbVNjb3BlIFB1YmxpYyBUcnVzdCBSU0EgUm9vdC0wMjAeFw0yMTA0MjgxNzE2 +NDNaFw00NjA0MjgxNzE2NDJaME4xCzAJBgNVBAYTAlVTMRIwEAYDVQQKDAlDb21t +U2NvcGUxKzApBgNVBAMMIkNvbW1TY29wZSBQdWJsaWMgVHJ1c3QgUlNBIFJvb3Qt +MDIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDh+g77aAASyE3VrCLE +NQE7xVTlWXZjpX/rwcRqmL0yjReA61260WI9JSMZNRTpf4mnG2I81lDnNJUDMrG0 +kyI9p+Kx7eZ7Ti6Hmw0zdQreqjXnfuU2mKKuJZ6VszKWpCtYHu8//mI0SFHRtI1C +rWDaSWqVcN3SAOLMV2MCe5bdSZdbkk6V0/nLKR8YSvgBKtJjCW4k6YnS5cciTNxz +hkcAqg2Ijq6FfUrpuzNPDlJwnZXjfG2WWy09X6GDRl224yW4fKcZgBzqZUPckXk2 +LHR88mcGyYnJ27/aaL8j7dxrrSiDeS/sOKUNNwFnJ5rpM9kzXzehxfCrPfp4sOcs +n/Y+n2Dg70jpkEUeBVF4GiwSLFworA2iI540jwXmojPOEXcT1A6kHkIfhs1w/tku +FT0du7jyU1fbzMZ0KZwYszZ1OC4PVKH4kh+Jlk+71O6d6Ts2QrUKOyrUZHk2EOH5 +kQMreyBUzQ0ZGshBMjTRsJnhkB4BQDa1t/qp5Xd1pCKBXbCL5CcSD1SIxtuFdOa3 +wNemKfrb3vOTlycEVS8KbzfFPROvCgCpLIscgSjX74Yxqa7ybrjKaixUR9gqiC6v +wQcQeKwRoi9C8DfF8rhW3Q5iLc4tVn5V8qdE9isy9COoR+jUKgF4z2rDN6ieZdIs +5fq6M8EGRPbmz6UNp2YINIos8wIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4G +A1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUR9DnsSL/nSz12Vdgs7GxcJXvYXowDQYJ +KoZIhvcNAQELBQADggIBAIZpsU0v6Z9PIpNojuQhmaPORVMbc0RTAIFhzTHjCLqB +KCh6krm2qMhDnscTJk3C2OVVnJJdUNjCK9v+5qiXz1I6JMNlZFxHMaNlNRPDk7n3 ++VGXu6TwYofF1gbTl4MgqX67tiHCpQ2EAOHyJxCDut0DgdXdaMNmEMjRdrSzbyme +APnCKfWxkxlSaRosTKCL4BWaMS/TiJVZbuXEs1DIFAhKm4sTg7GkcrI7djNB3Nyq +pgdvHSQSn8h2vS/ZjvQs7rfSOBAkNlEv41xdgSGn2rtO/+YHqP65DSdsu3BaVXoT +6fEqSWnHX4dXTEN5bTpl6TBcQe7rd6VzEojov32u5cSoHw2OHG1QAk8mGEPej1WF +sQs3BWDJVTkSBKEqz3EWnzZRSb9wO55nnPt7eck5HHisd5FUmrh1CoFSl+NmYWvt +PjgelmFV4ZFUjO2MJB+ByRCac5krFk5yAD9UG/iNuovnFNa2RU9g7Jauwy8CTl2d +lklyALKrdVwPaFsdZcJfMw8eD/A7hvWwTruc9+olBdytoptLFwG+Qt81IR2tq670 +v64fG9PiO/yzcnMcmyiQiRM9HcEARwmWmjgb3bHPDcK0RPOWlc4yOo80nOAXx17O +rg3bhzjlP1v9mxnhMUF6cKojawHhRUzNlM47ni3niAIi9G7oyOzWPPO5std3eqx7 +-----END CERTIFICATE----- + +# Issuer: CN=Telekom Security TLS ECC Root 2020 O=Deutsche Telekom Security GmbH +# Subject: CN=Telekom Security TLS ECC Root 2020 O=Deutsche Telekom Security GmbH +# Label: "Telekom Security TLS ECC Root 2020" +# Serial: 72082518505882327255703894282316633856 +# MD5 Fingerprint: c1:ab:fe:6a:10:2c:03:8d:bc:1c:22:32:c0:85:a7:fd +# SHA1 Fingerprint: c0:f8:96:c5:a9:3b:01:06:21:07:da:18:42:48:bc:e9:9d:88:d5:ec +# SHA256 Fingerprint: 57:8a:f4:de:d0:85:3f:4e:59:98:db:4a:ea:f9:cb:ea:8d:94:5f:60:b6:20:a3:8d:1a:3c:13:b2:bc:7b:a8:e1 +-----BEGIN CERTIFICATE----- +MIICQjCCAcmgAwIBAgIQNjqWjMlcsljN0AFdxeVXADAKBggqhkjOPQQDAzBjMQsw +CQYDVQQGEwJERTEnMCUGA1UECgweRGV1dHNjaGUgVGVsZWtvbSBTZWN1cml0eSBH +bWJIMSswKQYDVQQDDCJUZWxla29tIFNlY3VyaXR5IFRMUyBFQ0MgUm9vdCAyMDIw +MB4XDTIwMDgyNTA3NDgyMFoXDTQ1MDgyNTIzNTk1OVowYzELMAkGA1UEBhMCREUx +JzAlBgNVBAoMHkRldXRzY2hlIFRlbGVrb20gU2VjdXJpdHkgR21iSDErMCkGA1UE +AwwiVGVsZWtvbSBTZWN1cml0eSBUTFMgRUNDIFJvb3QgMjAyMDB2MBAGByqGSM49 +AgEGBSuBBAAiA2IABM6//leov9Wq9xCazbzREaK9Z0LMkOsVGJDZos0MKiXrPk/O +tdKPD/M12kOLAoC+b1EkHQ9rK8qfwm9QMuU3ILYg/4gND21Ju9sGpIeQkpT0CdDP +f8iAC8GXs7s1J8nCG6NCMEAwHQYDVR0OBBYEFONyzG6VmUex5rNhTNHLq+O6zd6f +MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMAoGCCqGSM49BAMDA2cA +MGQCMHVSi7ekEE+uShCLsoRbQuHmKjYC2qBuGT8lv9pZMo7k+5Dck2TOrbRBR2Di +z6fLHgIwN0GMZt9Ba9aDAEH9L1r3ULRn0SyocddDypwnJJGDSA3PzfdUga/sf+Rn +27iQ7t0l +-----END CERTIFICATE----- + +# Issuer: CN=Telekom Security TLS RSA Root 2023 O=Deutsche Telekom Security GmbH +# Subject: CN=Telekom Security TLS RSA Root 2023 O=Deutsche Telekom Security GmbH +# Label: "Telekom Security TLS RSA Root 2023" +# Serial: 44676229530606711399881795178081572759 +# MD5 Fingerprint: bf:5b:eb:54:40:cd:48:71:c4:20:8d:7d:de:0a:42:f2 +# SHA1 Fingerprint: 54:d3:ac:b3:bd:57:56:f6:85:9d:ce:e5:c3:21:e2:d4:ad:83:d0:93 +# SHA256 Fingerprint: ef:c6:5c:ad:bb:59:ad:b6:ef:e8:4d:a2:23:11:b3:56:24:b7:1b:3b:1e:a0:da:8b:66:55:17:4e:c8:97:86:46 +-----BEGIN CERTIFICATE----- +MIIFszCCA5ugAwIBAgIQIZxULej27HF3+k7ow3BXlzANBgkqhkiG9w0BAQwFADBj +MQswCQYDVQQGEwJERTEnMCUGA1UECgweRGV1dHNjaGUgVGVsZWtvbSBTZWN1cml0 +eSBHbWJIMSswKQYDVQQDDCJUZWxla29tIFNlY3VyaXR5IFRMUyBSU0EgUm9vdCAy +MDIzMB4XDTIzMDMyODEyMTY0NVoXDTQ4MDMyNzIzNTk1OVowYzELMAkGA1UEBhMC +REUxJzAlBgNVBAoMHkRldXRzY2hlIFRlbGVrb20gU2VjdXJpdHkgR21iSDErMCkG +A1UEAwwiVGVsZWtvbSBTZWN1cml0eSBUTFMgUlNBIFJvb3QgMjAyMzCCAiIwDQYJ +KoZIhvcNAQEBBQADggIPADCCAgoCggIBAO01oYGA88tKaVvC+1GDrib94W7zgRJ9 +cUD/h3VCKSHtgVIs3xLBGYSJwb3FKNXVS2xE1kzbB5ZKVXrKNoIENqil/Cf2SfHV +cp6R+SPWcHu79ZvB7JPPGeplfohwoHP89v+1VmLhc2o0mD6CuKyVU/QBoCcHcqMA +U6DksquDOFczJZSfvkgdmOGjup5czQRxUX11eKvzWarE4GC+j4NSuHUaQTXtvPM6 +Y+mpFEXX5lLRbtLevOP1Czvm4MS9Q2QTps70mDdsipWol8hHD/BeEIvnHRz+sTug +BTNoBUGCwQMrAcjnj02r6LX2zWtEtefdi+zqJbQAIldNsLGyMcEWzv/9FIS3R/qy +8XDe24tsNlikfLMR0cN3f1+2JeANxdKz+bi4d9s3cXFH42AYTyS2dTd4uaNir73J +co4vzLuu2+QVUhkHM/tqty1LkCiCc/4YizWN26cEar7qwU02OxY2kTLvtkCJkUPg +8qKrBC7m8kwOFjQgrIfBLX7JZkcXFBGk8/ehJImr2BrIoVyxo/eMbcgByU/J7MT8 +rFEz0ciD0cmfHdRHNCk+y7AO+oMLKFjlKdw/fKifybYKu6boRhYPluV75Gp6SG12 +mAWl3G0eQh5C2hrgUve1g8Aae3g1LDj1H/1Joy7SWWO/gLCMk3PLNaaZlSJhZQNg ++y+TS/qanIA7AgMBAAGjYzBhMA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUtqeX +gj10hZv3PJ+TmpV5dVKMbUcwDwYDVR0TAQH/BAUwAwEB/zAfBgNVHSMEGDAWgBS2 +p5eCPXSFm/c8n5OalXl1UoxtRzANBgkqhkiG9w0BAQwFAAOCAgEAqMxhpr51nhVQ +pGv7qHBFfLp+sVr8WyP6Cnf4mHGCDG3gXkaqk/QeoMPhk9tLrbKmXauw1GLLXrtm +9S3ul0A8Yute1hTWjOKWi0FpkzXmuZlrYrShF2Y0pmtjxrlO8iLpWA1WQdH6DErw +M807u20hOq6OcrXDSvvpfeWxm4bu4uB9tPcy/SKE8YXJN3nptT+/XOR0so8RYgDd +GGah2XsjX/GO1WfoVNpbOms2b/mBsTNHM3dA+VKq3dSDz4V4mZqTuXNnQkYRIer+ +CqkbGmVps4+uFrb2S1ayLfmlyOw7YqPta9BO1UAJpB+Y1zqlklkg5LB9zVtzaL1t +xKITDmcZuI1CfmwMmm6gJC3VRRvcxAIU/oVbZZfKTpBQCHpCNfnqwmbU+AGuHrS+ +w6jv/naaoqYfRvaE7fzbzsQCzndILIyy7MMAo+wsVRjBfhnu4S/yrYObnqsZ38aK +L4x35bcF7DvB7L6Gs4a8wPfc5+pbrrLMtTWGS9DiP7bY+A4A7l3j941Y/8+LN+lj +X273CXE2whJdV/LItM3z7gLfEdxquVeEHVlNjM7IDiPCtyaaEBRx/pOyiriA8A4Q +ntOoUAw3gi/q4Iqd4Sw5/7W0cwDk90imc6y/st53BIe0o82bNSQ3+pCTE4FCxpgm +dTdmQRCsu/WU48IxK63nI1bMNSWSs1A= +-----END CERTIFICATE----- + +# Issuer: CN=FIRMAPROFESIONAL CA ROOT-A WEB O=Firmaprofesional SA +# Subject: CN=FIRMAPROFESIONAL CA ROOT-A WEB O=Firmaprofesional SA +# Label: "FIRMAPROFESIONAL CA ROOT-A WEB" +# Serial: 65916896770016886708751106294915943533 +# MD5 Fingerprint: 82:b2:ad:45:00:82:b0:66:63:f8:5f:c3:67:4e:ce:a3 +# SHA1 Fingerprint: a8:31:11:74:a6:14:15:0d:ca:77:dd:0e:e4:0c:5d:58:fc:a0:72:a5 +# SHA256 Fingerprint: be:f2:56:da:f2:6e:9c:69:bd:ec:16:02:35:97:98:f3:ca:f7:18:21:a0:3e:01:82:57:c5:3c:65:61:7f:3d:4a +-----BEGIN CERTIFICATE----- +MIICejCCAgCgAwIBAgIQMZch7a+JQn81QYehZ1ZMbTAKBggqhkjOPQQDAzBuMQsw +CQYDVQQGEwJFUzEcMBoGA1UECgwTRmlybWFwcm9mZXNpb25hbCBTQTEYMBYGA1UE +YQwPVkFURVMtQTYyNjM0MDY4MScwJQYDVQQDDB5GSVJNQVBST0ZFU0lPTkFMIENB +IFJPT1QtQSBXRUIwHhcNMjIwNDA2MDkwMTM2WhcNNDcwMzMxMDkwMTM2WjBuMQsw +CQYDVQQGEwJFUzEcMBoGA1UECgwTRmlybWFwcm9mZXNpb25hbCBTQTEYMBYGA1UE +YQwPVkFURVMtQTYyNjM0MDY4MScwJQYDVQQDDB5GSVJNQVBST0ZFU0lPTkFMIENB +IFJPT1QtQSBXRUIwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAARHU+osEaR3xyrq89Zf +e9MEkVz6iMYiuYMQYneEMy3pA4jU4DP37XcsSmDq5G+tbbT4TIqk5B/K6k84Si6C +cyvHZpsKjECcfIr28jlgst7L7Ljkb+qbXbdTkBgyVcUgt5SjYzBhMA8GA1UdEwEB +/wQFMAMBAf8wHwYDVR0jBBgwFoAUk+FDY1w8ndYn81LsF7Kpryz3dvgwHQYDVR0O +BBYEFJPhQ2NcPJ3WJ/NS7Beyqa8s93b4MA4GA1UdDwEB/wQEAwIBBjAKBggqhkjO +PQQDAwNoADBlAjAdfKR7w4l1M+E7qUW/Runpod3JIha3RxEL2Jq68cgLcFBTApFw +hVmpHqTm6iMxoAACMQD94vizrxa5HnPEluPBMBnYfubDl94cT7iJLzPrSA8Z94dG +XSaQpYXFuXqUPoeovQA= +-----END CERTIFICATE----- + +# Issuer: CN=TWCA CYBER Root CA O=TAIWAN-CA OU=Root CA +# Subject: CN=TWCA CYBER Root CA O=TAIWAN-CA OU=Root CA +# Label: "TWCA CYBER Root CA" +# Serial: 85076849864375384482682434040119489222 +# MD5 Fingerprint: 0b:33:a0:97:52:95:d4:a9:fd:bb:db:6e:a3:55:5b:51 +# SHA1 Fingerprint: f6:b1:1c:1a:83:38:e9:7b:db:b3:a8:c8:33:24:e0:2d:9c:7f:26:66 +# SHA256 Fingerprint: 3f:63:bb:28:14:be:17:4e:c8:b6:43:9c:f0:8d:6d:56:f0:b7:c4:05:88:3a:56:48:a3:34:42:4d:6b:3e:c5:58 +-----BEGIN CERTIFICATE----- +MIIFjTCCA3WgAwIBAgIQQAE0jMIAAAAAAAAAATzyxjANBgkqhkiG9w0BAQwFADBQ +MQswCQYDVQQGEwJUVzESMBAGA1UEChMJVEFJV0FOLUNBMRAwDgYDVQQLEwdSb290 +IENBMRswGQYDVQQDExJUV0NBIENZQkVSIFJvb3QgQ0EwHhcNMjIxMTIyMDY1NDI5 +WhcNNDcxMTIyMTU1OTU5WjBQMQswCQYDVQQGEwJUVzESMBAGA1UEChMJVEFJV0FO +LUNBMRAwDgYDVQQLEwdSb290IENBMRswGQYDVQQDExJUV0NBIENZQkVSIFJvb3Qg +Q0EwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDG+Moe2Qkgfh1sTs6P +40czRJzHyWmqOlt47nDSkvgEs1JSHWdyKKHfi12VCv7qze33Kc7wb3+szT3vsxxF +avcokPFhV8UMxKNQXd7UtcsZyoC5dc4pztKFIuwCY8xEMCDa6pFbVuYdHNWdZsc/ +34bKS1PE2Y2yHer43CdTo0fhYcx9tbD47nORxc5zb87uEB8aBs/pJ2DFTxnk684i +JkXXYJndzk834H/nY62wuFm40AZoNWDTNq5xQwTxaWV4fPMf88oon1oglWa0zbfu +j3ikRRjpJi+NmykosaS3Om251Bw4ckVYsV7r8Cibt4LK/c/WMw+f+5eesRycnupf +Xtuq3VTpMCEobY5583WSjCb+3MX2w7DfRFlDo7YDKPYIMKoNM+HvnKkHIuNZW0CP +2oi3aQiotyMuRAlZN1vH4xfyIutuOVLF3lSnmMlLIJXcRolftBL5hSmO68gnFSDA +S9TMfAxsNAwmmyYxpjyn9tnQS6Jk/zuZQXLB4HCX8SS7K8R0IrGsayIyJNN4KsDA +oS/xUgXJP+92ZuJF2A09rZXIx4kmyA+upwMu+8Ff+iDhcK2wZSA3M2Cw1a/XDBzC +kHDXShi8fgGwsOsVHkQGzaRP6AzRwyAQ4VRlnrZR0Bp2a0JaWHY06rc3Ga4udfmW +5cFZ95RXKSWNOkyrTZpB0F8mAwIDAQABo2MwYTAOBgNVHQ8BAf8EBAMCAQYwDwYD +VR0TAQH/BAUwAwEB/zAfBgNVHSMEGDAWgBSdhWEUfMFib5do5E83QOGt4A1WNzAd +BgNVHQ4EFgQUnYVhFHzBYm+XaORPN0DhreANVjcwDQYJKoZIhvcNAQEMBQADggIB +AGSPesRiDrWIzLjHhg6hShbNcAu3p4ULs3a2D6f/CIsLJc+o1IN1KriWiLb73y0t +tGlTITVX1olNc79pj3CjYcya2x6a4CD4bLubIp1dhDGaLIrdaqHXKGnK/nZVekZn +68xDiBaiA9a5F/gZbG0jAn/xX9AKKSM70aoK7akXJlQKTcKlTfjF/biBzysseKNn +TKkHmvPfXvt89YnNdJdhEGoHK4Fa0o635yDRIG4kqIQnoVesqlVYL9zZyvpoBJ7t +RCT5dEA7IzOrg1oYJkK2bVS1FmAwbLGg+LhBoF1JSdJlBTrq/p1hvIbZv97Tujqx +f36SNI7JAG7cmL3c7IAFrQI932XtCwP39xaEBDG6k5TY8hL4iuO/Qq+n1M0RFxbI +Qh0UqEL20kCGoE8jypZFVmAGzbdVAaYBlGX+bgUJurSkquLvWL69J1bY73NxW0Qz +8ppy6rBePm6pUlvscG21h483XjyMnM7k8M4MZ0HMzvaAq07MTFb1wWFZk7Q+ptq4 +NxKfKjLji7gh7MMrZQzvIt6IKTtM1/r+t+FHvpw+PoP7UV31aPcuIYXcv/Fa4nzX +xeSDwWrruoBa3lwtcHb4yOWHh8qgnaHlIhInD0Q9HWzq1MKLL295q39QpsQZp6F6 +t5b5wR9iWqJDB0BeJsas7a5wFsWqynKKTbDPAYsDP27X +-----END CERTIFICATE----- + +# Issuer: CN=SecureSign Root CA12 O=Cybertrust Japan Co., Ltd. +# Subject: CN=SecureSign Root CA12 O=Cybertrust Japan Co., Ltd. +# Label: "SecureSign Root CA12" +# Serial: 587887345431707215246142177076162061960426065942 +# MD5 Fingerprint: c6:89:ca:64:42:9b:62:08:49:0b:1e:7f:e9:07:3d:e8 +# SHA1 Fingerprint: 7a:22:1e:3d:de:1b:06:ac:9e:c8:47:70:16:8e:3c:e5:f7:6b:06:f4 +# SHA256 Fingerprint: 3f:03:4b:b5:70:4d:44:b2:d0:85:45:a0:20:57:de:93:eb:f3:90:5f:ce:72:1a:cb:c7:30:c0:6d:da:ee:90:4e +-----BEGIN CERTIFICATE----- +MIIDcjCCAlqgAwIBAgIUZvnHwa/swlG07VOX5uaCwysckBYwDQYJKoZIhvcNAQEL +BQAwUTELMAkGA1UEBhMCSlAxIzAhBgNVBAoTGkN5YmVydHJ1c3QgSmFwYW4gQ28u +LCBMdGQuMR0wGwYDVQQDExRTZWN1cmVTaWduIFJvb3QgQ0ExMjAeFw0yMDA0MDgw +NTM2NDZaFw00MDA0MDgwNTM2NDZaMFExCzAJBgNVBAYTAkpQMSMwIQYDVQQKExpD +eWJlcnRydXN0IEphcGFuIENvLiwgTHRkLjEdMBsGA1UEAxMUU2VjdXJlU2lnbiBS +b290IENBMTIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC6OcE3emhF +KxS06+QT61d1I02PJC0W6K6OyX2kVzsqdiUzg2zqMoqUm048luT9Ub+ZyZN+v/mt +p7JIKwccJ/VMvHASd6SFVLX9kHrko+RRWAPNEHl57muTH2SOa2SroxPjcf59q5zd +J1M3s6oYwlkm7Fsf0uZlfO+TvdhYXAvA42VvPMfKWeP+bl+sg779XSVOKik71gur +FzJ4pOE+lEa+Ym6b3kaosRbnhW70CEBFEaCeVESE99g2zvVQR9wsMJvuwPWW0v4J +hscGWa5Pro4RmHvzC1KqYiaqId+OJTN5lxZJjfU+1UefNzFJM3IFTQy2VYzxV4+K +h9GtxRESOaCtAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQD +AgEGMB0GA1UdDgQWBBRXNPN0zwRL1SXm8UC2LEzZLemgrTANBgkqhkiG9w0BAQsF +AAOCAQEAPrvbFxbS8hQBICw4g0utvsqFepq2m2um4fylOqyttCg6r9cBg0krY6Ld +mmQOmFxv3Y67ilQiLUoT865AQ9tPkbeGGuwAtEGBpE/6aouIs3YIcipJQMPTw4WJ +mBClnW8Zt7vPemVV2zfrPIpyMpcemik+rY3moxtt9XUa5rBouVui7mlHJzWhhpmA +8zNL4WukJsPvdFlseqJkth5Ew1DgDzk9qTPxpfPSvWKErI4cqc1avTc7bgoitPQV +55FYxTpE05Uo2cBl6XLK0A+9H7MV2anjpEcJnuDLN/v9vZfVvhgaaaI5gdka9at/ +yOPiZwud9AzqVN/Ssq+xIvEg37xEHA== +-----END CERTIFICATE----- + +# Issuer: CN=SecureSign Root CA14 O=Cybertrust Japan Co., Ltd. +# Subject: CN=SecureSign Root CA14 O=Cybertrust Japan Co., Ltd. +# Label: "SecureSign Root CA14" +# Serial: 575790784512929437950770173562378038616896959179 +# MD5 Fingerprint: 71:0d:72:fa:92:19:65:5e:89:04:ac:16:33:f0:bc:d5 +# SHA1 Fingerprint: dd:50:c0:f7:79:b3:64:2e:74:a2:b8:9d:9f:d3:40:dd:bb:f0:f2:4f +# SHA256 Fingerprint: 4b:00:9c:10:34:49:4f:9a:b5:6b:ba:3b:a1:d6:27:31:fc:4d:20:d8:95:5a:dc:ec:10:a9:25:60:72:61:e3:38 +-----BEGIN CERTIFICATE----- +MIIFcjCCA1qgAwIBAgIUZNtaDCBO6Ncpd8hQJ6JaJ90t8sswDQYJKoZIhvcNAQEM +BQAwUTELMAkGA1UEBhMCSlAxIzAhBgNVBAoTGkN5YmVydHJ1c3QgSmFwYW4gQ28u +LCBMdGQuMR0wGwYDVQQDExRTZWN1cmVTaWduIFJvb3QgQ0ExNDAeFw0yMDA0MDgw +NzA2MTlaFw00NTA0MDgwNzA2MTlaMFExCzAJBgNVBAYTAkpQMSMwIQYDVQQKExpD +eWJlcnRydXN0IEphcGFuIENvLiwgTHRkLjEdMBsGA1UEAxMUU2VjdXJlU2lnbiBS +b290IENBMTQwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDF0nqh1oq/ +FjHQmNE6lPxauG4iwWL3pwon71D2LrGeaBLwbCRjOfHw3xDG3rdSINVSW0KZnvOg +vlIfX8xnbacuUKLBl422+JX1sLrcneC+y9/3OPJH9aaakpUqYllQC6KxNedlsmGy +6pJxaeQp8E+BgQQ8sqVb1MWoWWd7VRxJq3qdwudzTe/NCcLEVxLbAQ4jeQkHO6Lo +/IrPj8BGJJw4J+CDnRugv3gVEOuGTgpa/d/aLIJ+7sr2KeH6caH3iGicnPCNvg9J +kdjqOvn90Ghx2+m1K06Ckm9mH+Dw3EzsytHqunQG+bOEkJTRX45zGRBdAuVwpcAQ +0BB8b8VYSbSwbprafZX1zNoCr7gsfXmPvkPx+SgojQlD+Ajda8iLLCSxjVIHvXib +y8posqTdDEx5YMaZ0ZPxMBoH064iwurO8YQJzOAUbn8/ftKChazcqRZOhaBgy/ac +18izju3Gm5h1DVXoX+WViwKkrkMpKBGk5hIwAUt1ax5mnXkvpXYvHUC0bcl9eQjs +0Wq2XSqypWa9a4X0dFbD9ed1Uigspf9mR6XU/v6eVL9lfgHWMI+lNpyiUBzuOIAB +SMbHdPTGrMNASRZhdCyvjG817XsYAFs2PJxQDcqSMxDxJklt33UkN4Ii1+iW/RVL +ApY+B3KVfqs9TC7XyvDf4Fg/LS8EmjijAQIDAQABo0IwQDAPBgNVHRMBAf8EBTAD +AQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUBpOjCl4oaTeqYR3r6/wtbyPk +86AwDQYJKoZIhvcNAQEMBQADggIBAJaAcgkGfpzMkwQWu6A6jZJOtxEaCnFxEM0E +rX+lRVAQZk5KQaID2RFPeje5S+LGjzJmdSX7684/AykmjbgWHfYfM25I5uj4V7Ib +ed87hwriZLoAymzvftAj63iP/2SbNDefNWWipAA9EiOWWF3KY4fGoweITedpdopT +zfFP7ELyk+OZpDc8h7hi2/DsHzc/N19DzFGdtfCXwreFamgLRB7lUe6TzktuhsHS +DCRZNhqfLJGP4xjblJUK7ZGqDpncllPjYYPGFrojutzdfhrGe0K22VoF3Jpf1d+4 +2kd92jjbrDnVHmtsKheMYc2xbXIBw8MgAGJoFjHVdqqGuw6qnsb58Nn4DSEC5MUo +FlkRudlpcyqSeLiSV5sI8jrlL5WwWLdrIBRtFO8KvH7YVdiI2i/6GaX7i+B/OfVy +K4XELKzvGUWSTLNhB9xNH27SgRNcmvMSZ4PPmz+Ln52kuaiWA3rF7iDeM9ovnhp6 +dB7h7sxaOgTdsxoEqBRjrLdHEoOabPXm6RUVkRqEGQ6UROcSjiVbgGcZ3GOTEAtl +Lor6CZpO2oYofaphNdgOpygau1LgePhsumywbrmHXumZNTfxPWQrqaA0k89jL9WB +365jJ6UeTo3cKXhZ+PmhIIynJkBugnLNeLLIjzwec+fBH7/PzqUqm9tEZDKgu39c +JRNItX+S +-----END CERTIFICATE----- + +# Issuer: CN=SecureSign Root CA15 O=Cybertrust Japan Co., Ltd. +# Subject: CN=SecureSign Root CA15 O=Cybertrust Japan Co., Ltd. +# Label: "SecureSign Root CA15" +# Serial: 126083514594751269499665114766174399806381178503 +# MD5 Fingerprint: 13:30:fc:c4:62:a6:a9:de:b5:c1:68:af:b5:d2:31:47 +# SHA1 Fingerprint: cb:ba:83:c8:c1:5a:5d:f1:f9:73:6f:ca:d7:ef:28:13:06:4a:07:7d +# SHA256 Fingerprint: e7:78:f0:f0:95:fe:84:37:29:cd:1a:00:82:17:9e:53:14:a9:c2:91:44:28:05:e1:fb:1d:8f:b6:b8:88:6c:3a +-----BEGIN CERTIFICATE----- +MIICIzCCAamgAwIBAgIUFhXHw9hJp75pDIqI7fBw+d23PocwCgYIKoZIzj0EAwMw +UTELMAkGA1UEBhMCSlAxIzAhBgNVBAoTGkN5YmVydHJ1c3QgSmFwYW4gQ28uLCBM +dGQuMR0wGwYDVQQDExRTZWN1cmVTaWduIFJvb3QgQ0ExNTAeFw0yMDA0MDgwODMy +NTZaFw00NTA0MDgwODMyNTZaMFExCzAJBgNVBAYTAkpQMSMwIQYDVQQKExpDeWJl +cnRydXN0IEphcGFuIENvLiwgTHRkLjEdMBsGA1UEAxMUU2VjdXJlU2lnbiBSb290 +IENBMTUwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQLUHSNZDKZmbPSYAi4Io5GdCx4 +wCtELW1fHcmuS1Iggz24FG1Th2CeX2yF2wYUleDHKP+dX+Sq8bOLbe1PL0vJSpSR +ZHX+AezB2Ot6lHhWGENfa4HL9rzatAy2KZMIaY+jQjBAMA8GA1UdEwEB/wQFMAMB +Af8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBTrQciu/NWeUUj1vYv0hyCTQSvT +9DAKBggqhkjOPQQDAwNoADBlAjEA2S6Jfl5OpBEHvVnCB96rMjhTKkZEBhd6zlHp +4P9mLQlO4E/0BdGF9jVg3PVys0Z9AjBEmEYagoUeYWmJSwdLZrWeqrqgHkHZAXQ6 +bkU6iYAZezKYVWOr62Nuk22rGwlgMU4= +-----END CERTIFICATE----- diff --git a/PyGC/.venv/lib/python3.11/site-packages/certifi/core.py b/PyGC/.venv/lib/python3.11/site-packages/certifi/core.py new file mode 100644 index 0000000..91f538b --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/certifi/core.py @@ -0,0 +1,114 @@ +""" +certifi.py +~~~~~~~~~~ + +This module returns the installation location of cacert.pem or its contents. +""" +import sys +import atexit + +def exit_cacert_ctx() -> None: + _CACERT_CTX.__exit__(None, None, None) # type: ignore[union-attr] + + +if sys.version_info >= (3, 11): + + from importlib.resources import as_file, files + + _CACERT_CTX = None + _CACERT_PATH = None + + def where() -> str: + # This is slightly terrible, but we want to delay extracting the file + # in cases where we're inside of a zipimport situation until someone + # actually calls where(), but we don't want to re-extract the file + # on every call of where(), so we'll do it once then store it in a + # global variable. + global _CACERT_CTX + global _CACERT_PATH + if _CACERT_PATH is None: + # This is slightly janky, the importlib.resources API wants you to + # manage the cleanup of this file, so it doesn't actually return a + # path, it returns a context manager that will give you the path + # when you enter it and will do any cleanup when you leave it. In + # the common case of not needing a temporary file, it will just + # return the file system location and the __exit__() is a no-op. + # + # We also have to hold onto the actual context manager, because + # it will do the cleanup whenever it gets garbage collected, so + # we will also store that at the global level as well. + _CACERT_CTX = as_file(files("certifi").joinpath("cacert.pem")) + _CACERT_PATH = str(_CACERT_CTX.__enter__()) + atexit.register(exit_cacert_ctx) + + return _CACERT_PATH + + def contents() -> str: + return files("certifi").joinpath("cacert.pem").read_text(encoding="ascii") + +elif sys.version_info >= (3, 7): + + from importlib.resources import path as get_path, read_text + + _CACERT_CTX = None + _CACERT_PATH = None + + def where() -> str: + # This is slightly terrible, but we want to delay extracting the + # file in cases where we're inside of a zipimport situation until + # someone actually calls where(), but we don't want to re-extract + # the file on every call of where(), so we'll do it once then store + # it in a global variable. + global _CACERT_CTX + global _CACERT_PATH + if _CACERT_PATH is None: + # This is slightly janky, the importlib.resources API wants you + # to manage the cleanup of this file, so it doesn't actually + # return a path, it returns a context manager that will give + # you the path when you enter it and will do any cleanup when + # you leave it. In the common case of not needing a temporary + # file, it will just return the file system location and the + # __exit__() is a no-op. + # + # We also have to hold onto the actual context manager, because + # it will do the cleanup whenever it gets garbage collected, so + # we will also store that at the global level as well. + _CACERT_CTX = get_path("certifi", "cacert.pem") + _CACERT_PATH = str(_CACERT_CTX.__enter__()) + atexit.register(exit_cacert_ctx) + + return _CACERT_PATH + + def contents() -> str: + return read_text("certifi", "cacert.pem", encoding="ascii") + +else: + import os + import types + from typing import Union + + Package = Union[types.ModuleType, str] + Resource = Union[str, "os.PathLike"] + + # This fallback will work for Python versions prior to 3.7 that lack the + # importlib.resources module but relies on the existing `where` function + # so won't address issues with environments like PyOxidizer that don't set + # __file__ on modules. + def read_text( + package: Package, + resource: Resource, + encoding: str = 'utf-8', + errors: str = 'strict' + ) -> str: + with open(where(), encoding=encoding) as data: + return data.read() + + # If we don't have importlib.resources, then we will just do the old logic + # of assuming we're on the filesystem and munge the path directly. + def where() -> str: + f = os.path.dirname(__file__) + + return os.path.join(f, "cacert.pem") + + def contents() -> str: + return read_text("certifi", "cacert.pem", encoding="ascii") diff --git a/PyGC/.venv/lib/python3.11/site-packages/certifi/py.typed b/PyGC/.venv/lib/python3.11/site-packages/certifi/py.typed new file mode 100644 index 0000000..e69de29 diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/INSTALLER b/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/LICENSE b/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/LICENSE new file mode 100644 index 0000000..29225ee --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/LICENSE @@ -0,0 +1,26 @@ + +Except when otherwise stated (look for LICENSE files in directories or +information at the beginning of each file) all software and +documentation is licensed as follows: + + The MIT License + + Permission is hereby granted, free of charge, to any person + obtaining a copy of this software and associated documentation + files (the "Software"), to deal in the Software without + restriction, including without limitation the rights to use, + copy, modify, merge, publish, distribute, sublicense, and/or + sell copies of the Software, and to permit persons to whom the + Software is furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included + in all copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS + OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + DEALINGS IN THE SOFTWARE. + diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/METADATA b/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/METADATA new file mode 100644 index 0000000..60b0779 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/METADATA @@ -0,0 +1,40 @@ +Metadata-Version: 2.1 +Name: cffi +Version: 1.17.1 +Summary: Foreign Function Interface for Python calling C code. +Home-page: http://cffi.readthedocs.org +Author: Armin Rigo, Maciej Fijalkowski +Author-email: python-cffi@googlegroups.com +License: MIT +Project-URL: Documentation, http://cffi.readthedocs.org/ +Project-URL: Source Code, https://github.com/python-cffi/cffi +Project-URL: Issue Tracker, https://github.com/python-cffi/cffi/issues +Project-URL: Changelog, https://cffi.readthedocs.io/en/latest/whatsnew.html +Project-URL: Downloads, https://github.com/python-cffi/cffi/releases +Project-URL: Contact, https://groups.google.com/forum/#!forum/python-cffi +Classifier: Programming Language :: Python +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3.8 +Classifier: Programming Language :: Python :: 3.9 +Classifier: Programming Language :: Python :: 3.10 +Classifier: Programming Language :: Python :: 3.11 +Classifier: Programming Language :: Python :: 3.12 +Classifier: Programming Language :: Python :: 3.13 +Classifier: Programming Language :: Python :: Implementation :: CPython +Classifier: Programming Language :: Python :: Implementation :: PyPy +Classifier: License :: OSI Approved :: MIT License +Requires-Python: >=3.8 +License-File: LICENSE +Requires-Dist: pycparser + + +CFFI +==== + +Foreign Function Interface for Python calling C code. +Please see the `Documentation `_. + +Contact +------- + +`Mailing list `_ diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/RECORD b/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/RECORD new file mode 100644 index 0000000..7da4b95 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/RECORD @@ -0,0 +1,48 @@ +_cffi_backend.cpython-311-aarch64-linux-gnu.so,sha256=5rCvFVM4c5_YVlbG916uH6AO8Xcf2ReLWqO6WD0vTGs,1187880 +cffi-1.17.1.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +cffi-1.17.1.dist-info/LICENSE,sha256=BLgPWwd7vtaICM_rreteNSPyqMmpZJXFh72W3x6sKjM,1294 +cffi-1.17.1.dist-info/METADATA,sha256=u6nuvP_qPJKu2zvIbi2zkGzVu7KjnnRIYUFyIrOY3j4,1531 +cffi-1.17.1.dist-info/RECORD,, +cffi-1.17.1.dist-info/WHEEL,sha256=wbO1i3AcMQi8f3dFCEBZkYw8Qggr2nZZUFSIRhHanFM,153 +cffi-1.17.1.dist-info/entry_points.txt,sha256=y6jTxnyeuLnL-XJcDv8uML3n6wyYiGRg8MTp_QGJ9Ho,75 +cffi-1.17.1.dist-info/top_level.txt,sha256=rE7WR3rZfNKxWI9-jn6hsHCAl7MDkB-FmuQbxWjFehQ,19 +cffi/__init__.py,sha256=H6t_ebva6EeHpUuItFLW1gbRp94eZRNJODLaWKdbx1I,513 +cffi/__pycache__/__init__.cpython-311.pyc,, +cffi/__pycache__/_imp_emulation.cpython-311.pyc,, +cffi/__pycache__/_shimmed_dist_utils.cpython-311.pyc,, +cffi/__pycache__/api.cpython-311.pyc,, +cffi/__pycache__/backend_ctypes.cpython-311.pyc,, +cffi/__pycache__/cffi_opcode.cpython-311.pyc,, +cffi/__pycache__/commontypes.cpython-311.pyc,, +cffi/__pycache__/cparser.cpython-311.pyc,, +cffi/__pycache__/error.cpython-311.pyc,, +cffi/__pycache__/ffiplatform.cpython-311.pyc,, +cffi/__pycache__/lock.cpython-311.pyc,, +cffi/__pycache__/model.cpython-311.pyc,, +cffi/__pycache__/pkgconfig.cpython-311.pyc,, +cffi/__pycache__/recompiler.cpython-311.pyc,, +cffi/__pycache__/setuptools_ext.cpython-311.pyc,, +cffi/__pycache__/vengine_cpy.cpython-311.pyc,, +cffi/__pycache__/vengine_gen.cpython-311.pyc,, +cffi/__pycache__/verifier.cpython-311.pyc,, +cffi/_cffi_errors.h,sha256=zQXt7uR_m8gUW-fI2hJg0KoSkJFwXv8RGUkEDZ177dQ,3908 +cffi/_cffi_include.h,sha256=Exhmgm9qzHWzWivjfTe0D7Xp4rPUkVxdNuwGhMTMzbw,15055 +cffi/_embedding.h,sha256=EDKw5QrLvQoe3uosXB3H1xPVTYxsn33eV3A43zsA_Fw,18787 +cffi/_imp_emulation.py,sha256=RxREG8zAbI2RPGBww90u_5fi8sWdahpdipOoPzkp7C0,2960 +cffi/_shimmed_dist_utils.py,sha256=Bjj2wm8yZbvFvWEx5AEfmqaqZyZFhYfoyLLQHkXZuao,2230 +cffi/api.py,sha256=alBv6hZQkjpmZplBphdaRn2lPO9-CORs_M7ixabvZWI,42169 +cffi/backend_ctypes.py,sha256=h5ZIzLc6BFVXnGyc9xPqZWUS7qGy7yFSDqXe68Sa8z4,42454 +cffi/cffi_opcode.py,sha256=JDV5l0R0_OadBX_uE7xPPTYtMdmpp8I9UYd6av7aiDU,5731 +cffi/commontypes.py,sha256=7N6zPtCFlvxXMWhHV08psUjdYIK2XgsN3yo5dgua_v4,2805 +cffi/cparser.py,sha256=0qI3mEzZSNVcCangoyXOoAcL-RhpQL08eG8798T024s,44789 +cffi/error.py,sha256=v6xTiS4U0kvDcy4h_BDRo5v39ZQuj-IMRYLv5ETddZs,877 +cffi/ffiplatform.py,sha256=avxFjdikYGJoEtmJO7ewVmwG_VEVl6EZ_WaNhZYCqv4,3584 +cffi/lock.py,sha256=l9TTdwMIMpi6jDkJGnQgE9cvTIR7CAntIJr8EGHt3pY,747 +cffi/model.py,sha256=W30UFQZE73jL5Mx5N81YT77us2W2iJjTm0XYfnwz1cg,21797 +cffi/parse_c_type.h,sha256=OdwQfwM9ktq6vlCB43exFQmxDBtj2MBNdK8LYl15tjw,5976 +cffi/pkgconfig.py,sha256=LP1w7vmWvmKwyqLaU1Z243FOWGNQMrgMUZrvgFuOlco,4374 +cffi/recompiler.py,sha256=sim4Tm7lamt2Jn8uzKN0wMYp6ODByk3g7of47-h9LD4,65367 +cffi/setuptools_ext.py,sha256=-ebj79lO2_AUH-kRcaja2pKY1Z_5tloGwsJgzK8P3Cc,8871 +cffi/vengine_cpy.py,sha256=8UagT6ZEOZf6Dju7_CfNulue8CnsHLEzJYhnqUhoF04,43752 +cffi/vengine_gen.py,sha256=DUlEIrDiVin1Pnhn1sfoamnS5NLqfJcOdhRoeSNeJRg,26939 +cffi/verifier.py,sha256=oX8jpaohg2Qm3aHcznidAdvrVm5N4sQYG0a3Eo5mIl4,11182 diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/WHEEL b/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/WHEEL new file mode 100644 index 0000000..d6e327f --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/WHEEL @@ -0,0 +1,6 @@ +Wheel-Version: 1.0 +Generator: setuptools (74.1.1) +Root-Is-Purelib: false +Tag: cp311-cp311-manylinux_2_17_aarch64 +Tag: cp311-cp311-manylinux2014_aarch64 + diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/entry_points.txt b/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/entry_points.txt new file mode 100644 index 0000000..4b0274f --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/entry_points.txt @@ -0,0 +1,2 @@ +[distutils.setup_keywords] +cffi_modules = cffi.setuptools_ext:cffi_modules diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/top_level.txt b/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/top_level.txt new file mode 100644 index 0000000..f645779 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi-1.17.1.dist-info/top_level.txt @@ -0,0 +1,2 @@ +_cffi_backend +cffi diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/__init__.py new file mode 100644 index 0000000..2e35a38 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/__init__.py @@ -0,0 +1,14 @@ +__all__ = ['FFI', 'VerificationError', 'VerificationMissing', 'CDefError', + 'FFIError'] + +from .api import FFI +from .error import CDefError, FFIError, VerificationError, VerificationMissing +from .error import PkgConfigError + +__version__ = "1.17.1" +__version_info__ = (1, 17, 1) + +# The verifier module file names are based on the CRC32 of a string that +# contains the following version number. It may be older than __version__ +# if nothing is clearly incompatible. +__version_verifier_modules__ = "0.8.6" diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/_cffi_errors.h b/PyGC/.venv/lib/python3.11/site-packages/cffi/_cffi_errors.h new file mode 100644 index 0000000..158e059 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/_cffi_errors.h @@ -0,0 +1,149 @@ +#ifndef CFFI_MESSAGEBOX +# ifdef _MSC_VER +# define CFFI_MESSAGEBOX 1 +# else +# define CFFI_MESSAGEBOX 0 +# endif +#endif + + +#if CFFI_MESSAGEBOX +/* Windows only: logic to take the Python-CFFI embedding logic + initialization errors and display them in a background thread + with MessageBox. The idea is that if the whole program closes + as a result of this problem, then likely it is already a console + program and you can read the stderr output in the console too. + If it is not a console program, then it will likely show its own + dialog to complain, or generally not abruptly close, and for this + case the background thread should stay alive. +*/ +static void *volatile _cffi_bootstrap_text; + +static PyObject *_cffi_start_error_capture(void) +{ + PyObject *result = NULL; + PyObject *x, *m, *bi; + + if (InterlockedCompareExchangePointer(&_cffi_bootstrap_text, + (void *)1, NULL) != NULL) + return (PyObject *)1; + + m = PyImport_AddModule("_cffi_error_capture"); + if (m == NULL) + goto error; + + result = PyModule_GetDict(m); + if (result == NULL) + goto error; + +#if PY_MAJOR_VERSION >= 3 + bi = PyImport_ImportModule("builtins"); +#else + bi = PyImport_ImportModule("__builtin__"); +#endif + if (bi == NULL) + goto error; + PyDict_SetItemString(result, "__builtins__", bi); + Py_DECREF(bi); + + x = PyRun_String( + "import sys\n" + "class FileLike:\n" + " def write(self, x):\n" + " try:\n" + " of.write(x)\n" + " except: pass\n" + " self.buf += x\n" + " def flush(self):\n" + " pass\n" + "fl = FileLike()\n" + "fl.buf = ''\n" + "of = sys.stderr\n" + "sys.stderr = fl\n" + "def done():\n" + " sys.stderr = of\n" + " return fl.buf\n", /* make sure the returned value stays alive */ + Py_file_input, + result, result); + Py_XDECREF(x); + + error: + if (PyErr_Occurred()) + { + PyErr_WriteUnraisable(Py_None); + PyErr_Clear(); + } + return result; +} + +#pragma comment(lib, "user32.lib") + +static DWORD WINAPI _cffi_bootstrap_dialog(LPVOID ignored) +{ + Sleep(666); /* may be interrupted if the whole process is closing */ +#if PY_MAJOR_VERSION >= 3 + MessageBoxW(NULL, (wchar_t *)_cffi_bootstrap_text, + L"Python-CFFI error", + MB_OK | MB_ICONERROR); +#else + MessageBoxA(NULL, (char *)_cffi_bootstrap_text, + "Python-CFFI error", + MB_OK | MB_ICONERROR); +#endif + _cffi_bootstrap_text = NULL; + return 0; +} + +static void _cffi_stop_error_capture(PyObject *ecap) +{ + PyObject *s; + void *text; + + if (ecap == (PyObject *)1) + return; + + if (ecap == NULL) + goto error; + + s = PyRun_String("done()", Py_eval_input, ecap, ecap); + if (s == NULL) + goto error; + + /* Show a dialog box, but in a background thread, and + never show multiple dialog boxes at once. */ +#if PY_MAJOR_VERSION >= 3 + text = PyUnicode_AsWideCharString(s, NULL); +#else + text = PyString_AsString(s); +#endif + + _cffi_bootstrap_text = text; + + if (text != NULL) + { + HANDLE h; + h = CreateThread(NULL, 0, _cffi_bootstrap_dialog, + NULL, 0, NULL); + if (h != NULL) + CloseHandle(h); + } + /* decref the string, but it should stay alive as 'fl.buf' + in the small module above. It will really be freed only if + we later get another similar error. So it's a leak of at + most one copy of the small module. That's fine for this + situation which is usually a "fatal error" anyway. */ + Py_DECREF(s); + PyErr_Clear(); + return; + + error: + _cffi_bootstrap_text = NULL; + PyErr_Clear(); +} + +#else + +static PyObject *_cffi_start_error_capture(void) { return NULL; } +static void _cffi_stop_error_capture(PyObject *ecap) { } + +#endif diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/_cffi_include.h b/PyGC/.venv/lib/python3.11/site-packages/cffi/_cffi_include.h new file mode 100644 index 0000000..908a1d7 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/_cffi_include.h @@ -0,0 +1,389 @@ +#define _CFFI_ + +/* We try to define Py_LIMITED_API before including Python.h. + + Mess: we can only define it if Py_DEBUG, Py_TRACE_REFS and + Py_REF_DEBUG are not defined. This is a best-effort approximation: + we can learn about Py_DEBUG from pyconfig.h, but it is unclear if + the same works for the other two macros. Py_DEBUG implies them, + but not the other way around. + + The implementation is messy (issue #350): on Windows, with _MSC_VER, + we have to define Py_LIMITED_API even before including pyconfig.h. + In that case, we guess what pyconfig.h will do to the macros above, + and check our guess after the #include. + + Note that on Windows, with CPython 3.x, you need >= 3.5 and virtualenv + version >= 16.0.0. With older versions of either, you don't get a + copy of PYTHON3.DLL in the virtualenv. We can't check the version of + CPython *before* we even include pyconfig.h. ffi.set_source() puts + a ``#define _CFFI_NO_LIMITED_API'' at the start of this file if it is + running on Windows < 3.5, as an attempt at fixing it, but that's + arguably wrong because it may not be the target version of Python. + Still better than nothing I guess. As another workaround, you can + remove the definition of Py_LIMITED_API here. + + See also 'py_limited_api' in cffi/setuptools_ext.py. +*/ +#if !defined(_CFFI_USE_EMBEDDING) && !defined(Py_LIMITED_API) +# ifdef _MSC_VER +# if !defined(_DEBUG) && !defined(Py_DEBUG) && !defined(Py_TRACE_REFS) && !defined(Py_REF_DEBUG) && !defined(_CFFI_NO_LIMITED_API) +# define Py_LIMITED_API +# endif +# include + /* sanity-check: Py_LIMITED_API will cause crashes if any of these + are also defined. Normally, the Python file PC/pyconfig.h does not + cause any of these to be defined, with the exception that _DEBUG + causes Py_DEBUG. Double-check that. */ +# ifdef Py_LIMITED_API +# if defined(Py_DEBUG) +# error "pyconfig.h unexpectedly defines Py_DEBUG, but Py_LIMITED_API is set" +# endif +# if defined(Py_TRACE_REFS) +# error "pyconfig.h unexpectedly defines Py_TRACE_REFS, but Py_LIMITED_API is set" +# endif +# if defined(Py_REF_DEBUG) +# error "pyconfig.h unexpectedly defines Py_REF_DEBUG, but Py_LIMITED_API is set" +# endif +# endif +# else +# include +# if !defined(Py_DEBUG) && !defined(Py_TRACE_REFS) && !defined(Py_REF_DEBUG) && !defined(_CFFI_NO_LIMITED_API) +# define Py_LIMITED_API +# endif +# endif +#endif + +#include +#ifdef __cplusplus +extern "C" { +#endif +#include +#include "parse_c_type.h" + +/* this block of #ifs should be kept exactly identical between + c/_cffi_backend.c, cffi/vengine_cpy.py, cffi/vengine_gen.py + and cffi/_cffi_include.h */ +#if defined(_MSC_VER) +# include /* for alloca() */ +# if _MSC_VER < 1600 /* MSVC < 2010 */ + typedef __int8 int8_t; + typedef __int16 int16_t; + typedef __int32 int32_t; + typedef __int64 int64_t; + typedef unsigned __int8 uint8_t; + typedef unsigned __int16 uint16_t; + typedef unsigned __int32 uint32_t; + typedef unsigned __int64 uint64_t; + typedef __int8 int_least8_t; + typedef __int16 int_least16_t; + typedef __int32 int_least32_t; + typedef __int64 int_least64_t; + typedef unsigned __int8 uint_least8_t; + typedef unsigned __int16 uint_least16_t; + typedef unsigned __int32 uint_least32_t; + typedef unsigned __int64 uint_least64_t; + typedef __int8 int_fast8_t; + typedef __int16 int_fast16_t; + typedef __int32 int_fast32_t; + typedef __int64 int_fast64_t; + typedef unsigned __int8 uint_fast8_t; + typedef unsigned __int16 uint_fast16_t; + typedef unsigned __int32 uint_fast32_t; + typedef unsigned __int64 uint_fast64_t; + typedef __int64 intmax_t; + typedef unsigned __int64 uintmax_t; +# else +# include +# endif +# if _MSC_VER < 1800 /* MSVC < 2013 */ +# ifndef __cplusplus + typedef unsigned char _Bool; +# endif +# endif +# define _cffi_float_complex_t _Fcomplex /* include for it */ +# define _cffi_double_complex_t _Dcomplex /* include for it */ +#else +# include +# if (defined (__SVR4) && defined (__sun)) || defined(_AIX) || defined(__hpux) +# include +# endif +# define _cffi_float_complex_t float _Complex +# define _cffi_double_complex_t double _Complex +#endif + +#ifdef __GNUC__ +# define _CFFI_UNUSED_FN __attribute__((unused)) +#else +# define _CFFI_UNUSED_FN /* nothing */ +#endif + +#ifdef __cplusplus +# ifndef _Bool + typedef bool _Bool; /* semi-hackish: C++ has no _Bool; bool is builtin */ +# endif +#endif + +/********** CPython-specific section **********/ +#ifndef PYPY_VERSION + + +#if PY_MAJOR_VERSION >= 3 +# define PyInt_FromLong PyLong_FromLong +#endif + +#define _cffi_from_c_double PyFloat_FromDouble +#define _cffi_from_c_float PyFloat_FromDouble +#define _cffi_from_c_long PyInt_FromLong +#define _cffi_from_c_ulong PyLong_FromUnsignedLong +#define _cffi_from_c_longlong PyLong_FromLongLong +#define _cffi_from_c_ulonglong PyLong_FromUnsignedLongLong +#define _cffi_from_c__Bool PyBool_FromLong + +#define _cffi_to_c_double PyFloat_AsDouble +#define _cffi_to_c_float PyFloat_AsDouble + +#define _cffi_from_c_int(x, type) \ + (((type)-1) > 0 ? /* unsigned */ \ + (sizeof(type) < sizeof(long) ? \ + PyInt_FromLong((long)x) : \ + sizeof(type) == sizeof(long) ? \ + PyLong_FromUnsignedLong((unsigned long)x) : \ + PyLong_FromUnsignedLongLong((unsigned long long)x)) : \ + (sizeof(type) <= sizeof(long) ? \ + PyInt_FromLong((long)x) : \ + PyLong_FromLongLong((long long)x))) + +#define _cffi_to_c_int(o, type) \ + ((type)( \ + sizeof(type) == 1 ? (((type)-1) > 0 ? (type)_cffi_to_c_u8(o) \ + : (type)_cffi_to_c_i8(o)) : \ + sizeof(type) == 2 ? (((type)-1) > 0 ? (type)_cffi_to_c_u16(o) \ + : (type)_cffi_to_c_i16(o)) : \ + sizeof(type) == 4 ? (((type)-1) > 0 ? (type)_cffi_to_c_u32(o) \ + : (type)_cffi_to_c_i32(o)) : \ + sizeof(type) == 8 ? (((type)-1) > 0 ? (type)_cffi_to_c_u64(o) \ + : (type)_cffi_to_c_i64(o)) : \ + (Py_FatalError("unsupported size for type " #type), (type)0))) + +#define _cffi_to_c_i8 \ + ((int(*)(PyObject *))_cffi_exports[1]) +#define _cffi_to_c_u8 \ + ((int(*)(PyObject *))_cffi_exports[2]) +#define _cffi_to_c_i16 \ + ((int(*)(PyObject *))_cffi_exports[3]) +#define _cffi_to_c_u16 \ + ((int(*)(PyObject *))_cffi_exports[4]) +#define _cffi_to_c_i32 \ + ((int(*)(PyObject *))_cffi_exports[5]) +#define _cffi_to_c_u32 \ + ((unsigned int(*)(PyObject *))_cffi_exports[6]) +#define _cffi_to_c_i64 \ + ((long long(*)(PyObject *))_cffi_exports[7]) +#define _cffi_to_c_u64 \ + ((unsigned long long(*)(PyObject *))_cffi_exports[8]) +#define _cffi_to_c_char \ + ((int(*)(PyObject *))_cffi_exports[9]) +#define _cffi_from_c_pointer \ + ((PyObject *(*)(char *, struct _cffi_ctypedescr *))_cffi_exports[10]) +#define _cffi_to_c_pointer \ + ((char *(*)(PyObject *, struct _cffi_ctypedescr *))_cffi_exports[11]) +#define _cffi_get_struct_layout \ + not used any more +#define _cffi_restore_errno \ + ((void(*)(void))_cffi_exports[13]) +#define _cffi_save_errno \ + ((void(*)(void))_cffi_exports[14]) +#define _cffi_from_c_char \ + ((PyObject *(*)(char))_cffi_exports[15]) +#define _cffi_from_c_deref \ + ((PyObject *(*)(char *, struct _cffi_ctypedescr *))_cffi_exports[16]) +#define _cffi_to_c \ + ((int(*)(char *, struct _cffi_ctypedescr *, PyObject *))_cffi_exports[17]) +#define _cffi_from_c_struct \ + ((PyObject *(*)(char *, struct _cffi_ctypedescr *))_cffi_exports[18]) +#define _cffi_to_c_wchar_t \ + ((_cffi_wchar_t(*)(PyObject *))_cffi_exports[19]) +#define _cffi_from_c_wchar_t \ + ((PyObject *(*)(_cffi_wchar_t))_cffi_exports[20]) +#define _cffi_to_c_long_double \ + ((long double(*)(PyObject *))_cffi_exports[21]) +#define _cffi_to_c__Bool \ + ((_Bool(*)(PyObject *))_cffi_exports[22]) +#define _cffi_prepare_pointer_call_argument \ + ((Py_ssize_t(*)(struct _cffi_ctypedescr *, \ + PyObject *, char **))_cffi_exports[23]) +#define _cffi_convert_array_from_object \ + ((int(*)(char *, struct _cffi_ctypedescr *, PyObject *))_cffi_exports[24]) +#define _CFFI_CPIDX 25 +#define _cffi_call_python \ + ((void(*)(struct _cffi_externpy_s *, char *))_cffi_exports[_CFFI_CPIDX]) +#define _cffi_to_c_wchar3216_t \ + ((int(*)(PyObject *))_cffi_exports[26]) +#define _cffi_from_c_wchar3216_t \ + ((PyObject *(*)(int))_cffi_exports[27]) +#define _CFFI_NUM_EXPORTS 28 + +struct _cffi_ctypedescr; + +static void *_cffi_exports[_CFFI_NUM_EXPORTS]; + +#define _cffi_type(index) ( \ + assert((((uintptr_t)_cffi_types[index]) & 1) == 0), \ + (struct _cffi_ctypedescr *)_cffi_types[index]) + +static PyObject *_cffi_init(const char *module_name, Py_ssize_t version, + const struct _cffi_type_context_s *ctx) +{ + PyObject *module, *o_arg, *new_module; + void *raw[] = { + (void *)module_name, + (void *)version, + (void *)_cffi_exports, + (void *)ctx, + }; + + module = PyImport_ImportModule("_cffi_backend"); + if (module == NULL) + goto failure; + + o_arg = PyLong_FromVoidPtr((void *)raw); + if (o_arg == NULL) + goto failure; + + new_module = PyObject_CallMethod( + module, (char *)"_init_cffi_1_0_external_module", (char *)"O", o_arg); + + Py_DECREF(o_arg); + Py_DECREF(module); + return new_module; + + failure: + Py_XDECREF(module); + return NULL; +} + + +#ifdef HAVE_WCHAR_H +typedef wchar_t _cffi_wchar_t; +#else +typedef uint16_t _cffi_wchar_t; /* same random pick as _cffi_backend.c */ +#endif + +_CFFI_UNUSED_FN static uint16_t _cffi_to_c_char16_t(PyObject *o) +{ + if (sizeof(_cffi_wchar_t) == 2) + return (uint16_t)_cffi_to_c_wchar_t(o); + else + return (uint16_t)_cffi_to_c_wchar3216_t(o); +} + +_CFFI_UNUSED_FN static PyObject *_cffi_from_c_char16_t(uint16_t x) +{ + if (sizeof(_cffi_wchar_t) == 2) + return _cffi_from_c_wchar_t((_cffi_wchar_t)x); + else + return _cffi_from_c_wchar3216_t((int)x); +} + +_CFFI_UNUSED_FN static int _cffi_to_c_char32_t(PyObject *o) +{ + if (sizeof(_cffi_wchar_t) == 4) + return (int)_cffi_to_c_wchar_t(o); + else + return (int)_cffi_to_c_wchar3216_t(o); +} + +_CFFI_UNUSED_FN static PyObject *_cffi_from_c_char32_t(unsigned int x) +{ + if (sizeof(_cffi_wchar_t) == 4) + return _cffi_from_c_wchar_t((_cffi_wchar_t)x); + else + return _cffi_from_c_wchar3216_t((int)x); +} + +union _cffi_union_alignment_u { + unsigned char m_char; + unsigned short m_short; + unsigned int m_int; + unsigned long m_long; + unsigned long long m_longlong; + float m_float; + double m_double; + long double m_longdouble; +}; + +struct _cffi_freeme_s { + struct _cffi_freeme_s *next; + union _cffi_union_alignment_u alignment; +}; + +_CFFI_UNUSED_FN static int +_cffi_convert_array_argument(struct _cffi_ctypedescr *ctptr, PyObject *arg, + char **output_data, Py_ssize_t datasize, + struct _cffi_freeme_s **freeme) +{ + char *p; + if (datasize < 0) + return -1; + + p = *output_data; + if (p == NULL) { + struct _cffi_freeme_s *fp = (struct _cffi_freeme_s *)PyObject_Malloc( + offsetof(struct _cffi_freeme_s, alignment) + (size_t)datasize); + if (fp == NULL) + return -1; + fp->next = *freeme; + *freeme = fp; + p = *output_data = (char *)&fp->alignment; + } + memset((void *)p, 0, (size_t)datasize); + return _cffi_convert_array_from_object(p, ctptr, arg); +} + +_CFFI_UNUSED_FN static void +_cffi_free_array_arguments(struct _cffi_freeme_s *freeme) +{ + do { + void *p = (void *)freeme; + freeme = freeme->next; + PyObject_Free(p); + } while (freeme != NULL); +} + +/********** end CPython-specific section **********/ +#else +_CFFI_UNUSED_FN +static void (*_cffi_call_python_org)(struct _cffi_externpy_s *, char *); +# define _cffi_call_python _cffi_call_python_org +#endif + + +#define _cffi_array_len(array) (sizeof(array) / sizeof((array)[0])) + +#define _cffi_prim_int(size, sign) \ + ((size) == 1 ? ((sign) ? _CFFI_PRIM_INT8 : _CFFI_PRIM_UINT8) : \ + (size) == 2 ? ((sign) ? _CFFI_PRIM_INT16 : _CFFI_PRIM_UINT16) : \ + (size) == 4 ? ((sign) ? _CFFI_PRIM_INT32 : _CFFI_PRIM_UINT32) : \ + (size) == 8 ? ((sign) ? _CFFI_PRIM_INT64 : _CFFI_PRIM_UINT64) : \ + _CFFI__UNKNOWN_PRIM) + +#define _cffi_prim_float(size) \ + ((size) == sizeof(float) ? _CFFI_PRIM_FLOAT : \ + (size) == sizeof(double) ? _CFFI_PRIM_DOUBLE : \ + (size) == sizeof(long double) ? _CFFI__UNKNOWN_LONG_DOUBLE : \ + _CFFI__UNKNOWN_FLOAT_PRIM) + +#define _cffi_check_int(got, got_nonpos, expected) \ + ((got_nonpos) == (expected <= 0) && \ + (got) == (unsigned long long)expected) + +#ifdef MS_WIN32 +# define _cffi_stdcall __stdcall +#else +# define _cffi_stdcall /* nothing */ +#endif + +#ifdef __cplusplus +} +#endif diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/_embedding.h b/PyGC/.venv/lib/python3.11/site-packages/cffi/_embedding.h new file mode 100644 index 0000000..94d8b30 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/_embedding.h @@ -0,0 +1,550 @@ + +/***** Support code for embedding *****/ + +#ifdef __cplusplus +extern "C" { +#endif + + +#if defined(_WIN32) +# define CFFI_DLLEXPORT __declspec(dllexport) +#elif defined(__GNUC__) +# define CFFI_DLLEXPORT __attribute__((visibility("default"))) +#else +# define CFFI_DLLEXPORT /* nothing */ +#endif + + +/* There are two global variables of type _cffi_call_python_fnptr: + + * _cffi_call_python, which we declare just below, is the one called + by ``extern "Python"`` implementations. + + * _cffi_call_python_org, which on CPython is actually part of the + _cffi_exports[] array, is the function pointer copied from + _cffi_backend. If _cffi_start_python() fails, then this is set + to NULL; otherwise, it should never be NULL. + + After initialization is complete, both are equal. However, the + first one remains equal to &_cffi_start_and_call_python until the + very end of initialization, when we are (or should be) sure that + concurrent threads also see a completely initialized world, and + only then is it changed. +*/ +#undef _cffi_call_python +typedef void (*_cffi_call_python_fnptr)(struct _cffi_externpy_s *, char *); +static void _cffi_start_and_call_python(struct _cffi_externpy_s *, char *); +static _cffi_call_python_fnptr _cffi_call_python = &_cffi_start_and_call_python; + + +#ifndef _MSC_VER + /* --- Assuming a GCC not infinitely old --- */ +# define cffi_compare_and_swap(l,o,n) __sync_bool_compare_and_swap(l,o,n) +# define cffi_write_barrier() __sync_synchronize() +# if !defined(__amd64__) && !defined(__x86_64__) && \ + !defined(__i386__) && !defined(__i386) +# define cffi_read_barrier() __sync_synchronize() +# else +# define cffi_read_barrier() (void)0 +# endif +#else + /* --- Windows threads version --- */ +# include +# define cffi_compare_and_swap(l,o,n) \ + (InterlockedCompareExchangePointer(l,n,o) == (o)) +# define cffi_write_barrier() InterlockedCompareExchange(&_cffi_dummy,0,0) +# define cffi_read_barrier() (void)0 +static volatile LONG _cffi_dummy; +#endif + +#ifdef WITH_THREAD +# ifndef _MSC_VER +# include + static pthread_mutex_t _cffi_embed_startup_lock; +# else + static CRITICAL_SECTION _cffi_embed_startup_lock; +# endif + static char _cffi_embed_startup_lock_ready = 0; +#endif + +static void _cffi_acquire_reentrant_mutex(void) +{ + static void *volatile lock = NULL; + + while (!cffi_compare_and_swap(&lock, NULL, (void *)1)) { + /* should ideally do a spin loop instruction here, but + hard to do it portably and doesn't really matter I + think: pthread_mutex_init() should be very fast, and + this is only run at start-up anyway. */ + } + +#ifdef WITH_THREAD + if (!_cffi_embed_startup_lock_ready) { +# ifndef _MSC_VER + pthread_mutexattr_t attr; + pthread_mutexattr_init(&attr); + pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_RECURSIVE); + pthread_mutex_init(&_cffi_embed_startup_lock, &attr); +# else + InitializeCriticalSection(&_cffi_embed_startup_lock); +# endif + _cffi_embed_startup_lock_ready = 1; + } +#endif + + while (!cffi_compare_and_swap(&lock, (void *)1, NULL)) + ; + +#ifndef _MSC_VER + pthread_mutex_lock(&_cffi_embed_startup_lock); +#else + EnterCriticalSection(&_cffi_embed_startup_lock); +#endif +} + +static void _cffi_release_reentrant_mutex(void) +{ +#ifndef _MSC_VER + pthread_mutex_unlock(&_cffi_embed_startup_lock); +#else + LeaveCriticalSection(&_cffi_embed_startup_lock); +#endif +} + + +/********** CPython-specific section **********/ +#ifndef PYPY_VERSION + +#include "_cffi_errors.h" + + +#define _cffi_call_python_org _cffi_exports[_CFFI_CPIDX] + +PyMODINIT_FUNC _CFFI_PYTHON_STARTUP_FUNC(void); /* forward */ + +static void _cffi_py_initialize(void) +{ + /* XXX use initsigs=0, which "skips initialization registration of + signal handlers, which might be useful when Python is + embedded" according to the Python docs. But review and think + if it should be a user-controllable setting. + + XXX we should also give a way to write errors to a buffer + instead of to stderr. + + XXX if importing 'site' fails, CPython (any version) calls + exit(). Should we try to work around this behavior here? + */ + Py_InitializeEx(0); +} + +static int _cffi_initialize_python(void) +{ + /* This initializes Python, imports _cffi_backend, and then the + present .dll/.so is set up as a CPython C extension module. + */ + int result; + PyGILState_STATE state; + PyObject *pycode=NULL, *global_dict=NULL, *x; + PyObject *builtins; + + state = PyGILState_Ensure(); + + /* Call the initxxx() function from the present module. It will + create and initialize us as a CPython extension module, instead + of letting the startup Python code do it---it might reimport + the same .dll/.so and get maybe confused on some platforms. + It might also have troubles locating the .dll/.so again for all + I know. + */ + (void)_CFFI_PYTHON_STARTUP_FUNC(); + if (PyErr_Occurred()) + goto error; + + /* Now run the Python code provided to ffi.embedding_init_code(). + */ + pycode = Py_CompileString(_CFFI_PYTHON_STARTUP_CODE, + "", + Py_file_input); + if (pycode == NULL) + goto error; + global_dict = PyDict_New(); + if (global_dict == NULL) + goto error; + builtins = PyEval_GetBuiltins(); + if (builtins == NULL) + goto error; + if (PyDict_SetItemString(global_dict, "__builtins__", builtins) < 0) + goto error; + x = PyEval_EvalCode( +#if PY_MAJOR_VERSION < 3 + (PyCodeObject *) +#endif + pycode, global_dict, global_dict); + if (x == NULL) + goto error; + Py_DECREF(x); + + /* Done! Now if we've been called from + _cffi_start_and_call_python() in an ``extern "Python"``, we can + only hope that the Python code did correctly set up the + corresponding @ffi.def_extern() function. Otherwise, the + general logic of ``extern "Python"`` functions (inside the + _cffi_backend module) will find that the reference is still + missing and print an error. + */ + result = 0; + done: + Py_XDECREF(pycode); + Py_XDECREF(global_dict); + PyGILState_Release(state); + return result; + + error:; + { + /* Print as much information as potentially useful. + Debugging load-time failures with embedding is not fun + */ + PyObject *ecap; + PyObject *exception, *v, *tb, *f, *modules, *mod; + PyErr_Fetch(&exception, &v, &tb); + ecap = _cffi_start_error_capture(); + f = PySys_GetObject((char *)"stderr"); + if (f != NULL && f != Py_None) { + PyFile_WriteString( + "Failed to initialize the Python-CFFI embedding logic:\n\n", f); + } + + if (exception != NULL) { + PyErr_NormalizeException(&exception, &v, &tb); + PyErr_Display(exception, v, tb); + } + Py_XDECREF(exception); + Py_XDECREF(v); + Py_XDECREF(tb); + + if (f != NULL && f != Py_None) { + PyFile_WriteString("\nFrom: " _CFFI_MODULE_NAME + "\ncompiled with cffi version: 1.17.1" + "\n_cffi_backend module: ", f); + modules = PyImport_GetModuleDict(); + mod = PyDict_GetItemString(modules, "_cffi_backend"); + if (mod == NULL) { + PyFile_WriteString("not loaded", f); + } + else { + v = PyObject_GetAttrString(mod, "__file__"); + PyFile_WriteObject(v, f, 0); + Py_XDECREF(v); + } + PyFile_WriteString("\nsys.path: ", f); + PyFile_WriteObject(PySys_GetObject((char *)"path"), f, 0); + PyFile_WriteString("\n\n", f); + } + _cffi_stop_error_capture(ecap); + } + result = -1; + goto done; +} + +#if PY_VERSION_HEX < 0x03080000 +PyAPI_DATA(char *) _PyParser_TokenNames[]; /* from CPython */ +#endif + +static int _cffi_carefully_make_gil(void) +{ + /* This does the basic initialization of Python. It can be called + completely concurrently from unrelated threads. It assumes + that we don't hold the GIL before (if it exists), and we don't + hold it afterwards. + + (What it really does used to be completely different in Python 2 + and Python 3, with the Python 2 solution avoiding the spin-lock + around the Py_InitializeEx() call. However, after recent changes + to CPython 2.7 (issue #358) it no longer works. So we use the + Python 3 solution everywhere.) + + This initializes Python by calling Py_InitializeEx(). + Important: this must not be called concurrently at all. + So we use a global variable as a simple spin lock. This global + variable must be from 'libpythonX.Y.so', not from this + cffi-based extension module, because it must be shared from + different cffi-based extension modules. + + In Python < 3.8, we choose + _PyParser_TokenNames[0] as a completely arbitrary pointer value + that is never written to. The default is to point to the + string "ENDMARKER". We change it temporarily to point to the + next character in that string. (Yes, I know it's REALLY + obscure.) + + In Python >= 3.8, this string array is no longer writable, so + instead we pick PyCapsuleType.tp_version_tag. We can't change + Python < 3.8 because someone might use a mixture of cffi + embedded modules, some of which were compiled before this file + changed. + + In Python >= 3.12, this stopped working because that particular + tp_version_tag gets modified during interpreter startup. It's + arguably a bad idea before 3.12 too, but again we can't change + that because someone might use a mixture of cffi embedded + modules, and no-one reported a bug so far. In Python >= 3.12 + we go instead for PyCapsuleType.tp_as_buffer, which is supposed + to always be NULL. We write to it temporarily a pointer to + a struct full of NULLs, which is semantically the same. + */ + +#ifdef WITH_THREAD +# if PY_VERSION_HEX < 0x03080000 + char *volatile *lock = (char *volatile *)_PyParser_TokenNames; + char *old_value, *locked_value; + + while (1) { /* spin loop */ + old_value = *lock; + locked_value = old_value + 1; + if (old_value[0] == 'E') { + assert(old_value[1] == 'N'); + if (cffi_compare_and_swap(lock, old_value, locked_value)) + break; + } + else { + assert(old_value[0] == 'N'); + /* should ideally do a spin loop instruction here, but + hard to do it portably and doesn't really matter I + think: PyEval_InitThreads() should be very fast, and + this is only run at start-up anyway. */ + } + } +# else +# if PY_VERSION_HEX < 0x030C0000 + int volatile *lock = (int volatile *)&PyCapsule_Type.tp_version_tag; + int old_value, locked_value = -42; + assert(!(PyCapsule_Type.tp_flags & Py_TPFLAGS_HAVE_VERSION_TAG)); +# else + static struct ebp_s { PyBufferProcs buf; int mark; } empty_buffer_procs; + empty_buffer_procs.mark = -42; + PyBufferProcs *volatile *lock = (PyBufferProcs *volatile *) + &PyCapsule_Type.tp_as_buffer; + PyBufferProcs *old_value, *locked_value = &empty_buffer_procs.buf; +# endif + + while (1) { /* spin loop */ + old_value = *lock; + if (old_value == 0) { + if (cffi_compare_and_swap(lock, old_value, locked_value)) + break; + } + else { +# if PY_VERSION_HEX < 0x030C0000 + assert(old_value == locked_value); +# else + /* The pointer should point to a possibly different + empty_buffer_procs from another C extension module */ + assert(((struct ebp_s *)old_value)->mark == -42); +# endif + /* should ideally do a spin loop instruction here, but + hard to do it portably and doesn't really matter I + think: PyEval_InitThreads() should be very fast, and + this is only run at start-up anyway. */ + } + } +# endif +#endif + + /* call Py_InitializeEx() */ + if (!Py_IsInitialized()) { + _cffi_py_initialize(); +#if PY_VERSION_HEX < 0x03070000 + PyEval_InitThreads(); +#endif + PyEval_SaveThread(); /* release the GIL */ + /* the returned tstate must be the one that has been stored into the + autoTLSkey by _PyGILState_Init() called from Py_Initialize(). */ + } + else { +#if PY_VERSION_HEX < 0x03070000 + /* PyEval_InitThreads() is always a no-op from CPython 3.7 */ + PyGILState_STATE state = PyGILState_Ensure(); + PyEval_InitThreads(); + PyGILState_Release(state); +#endif + } + +#ifdef WITH_THREAD + /* release the lock */ + while (!cffi_compare_and_swap(lock, locked_value, old_value)) + ; +#endif + + return 0; +} + +/********** end CPython-specific section **********/ + + +#else + + +/********** PyPy-specific section **********/ + +PyMODINIT_FUNC _CFFI_PYTHON_STARTUP_FUNC(const void *[]); /* forward */ + +static struct _cffi_pypy_init_s { + const char *name; + void *func; /* function pointer */ + const char *code; +} _cffi_pypy_init = { + _CFFI_MODULE_NAME, + _CFFI_PYTHON_STARTUP_FUNC, + _CFFI_PYTHON_STARTUP_CODE, +}; + +extern int pypy_carefully_make_gil(const char *); +extern int pypy_init_embedded_cffi_module(int, struct _cffi_pypy_init_s *); + +static int _cffi_carefully_make_gil(void) +{ + return pypy_carefully_make_gil(_CFFI_MODULE_NAME); +} + +static int _cffi_initialize_python(void) +{ + return pypy_init_embedded_cffi_module(0xB011, &_cffi_pypy_init); +} + +/********** end PyPy-specific section **********/ + + +#endif + + +#ifdef __GNUC__ +__attribute__((noinline)) +#endif +static _cffi_call_python_fnptr _cffi_start_python(void) +{ + /* Delicate logic to initialize Python. This function can be + called multiple times concurrently, e.g. when the process calls + its first ``extern "Python"`` functions in multiple threads at + once. It can also be called recursively, in which case we must + ignore it. We also have to consider what occurs if several + different cffi-based extensions reach this code in parallel + threads---it is a different copy of the code, then, and we + can't have any shared global variable unless it comes from + 'libpythonX.Y.so'. + + Idea: + + * _cffi_carefully_make_gil(): "carefully" call + PyEval_InitThreads() (possibly with Py_InitializeEx() first). + + * then we use a (local) custom lock to make sure that a call to this + cffi-based extension will wait if another call to the *same* + extension is running the initialization in another thread. + It is reentrant, so that a recursive call will not block, but + only one from a different thread. + + * then we grab the GIL and (Python 2) we call Py_InitializeEx(). + At this point, concurrent calls to Py_InitializeEx() are not + possible: we have the GIL. + + * do the rest of the specific initialization, which may + temporarily release the GIL but not the custom lock. + Only release the custom lock when we are done. + */ + static char called = 0; + + if (_cffi_carefully_make_gil() != 0) + return NULL; + + _cffi_acquire_reentrant_mutex(); + + /* Here the GIL exists, but we don't have it. We're only protected + from concurrency by the reentrant mutex. */ + + /* This file only initializes the embedded module once, the first + time this is called, even if there are subinterpreters. */ + if (!called) { + called = 1; /* invoke _cffi_initialize_python() only once, + but don't set '_cffi_call_python' right now, + otherwise concurrent threads won't call + this function at all (we need them to wait) */ + if (_cffi_initialize_python() == 0) { + /* now initialization is finished. Switch to the fast-path. */ + + /* We would like nobody to see the new value of + '_cffi_call_python' without also seeing the rest of the + data initialized. However, this is not possible. But + the new value of '_cffi_call_python' is the function + 'cffi_call_python()' from _cffi_backend. So: */ + cffi_write_barrier(); + /* ^^^ we put a write barrier here, and a corresponding + read barrier at the start of cffi_call_python(). This + ensures that after that read barrier, we see everything + done here before the write barrier. + */ + + assert(_cffi_call_python_org != NULL); + _cffi_call_python = (_cffi_call_python_fnptr)_cffi_call_python_org; + } + else { + /* initialization failed. Reset this to NULL, even if it was + already set to some other value. Future calls to + _cffi_start_python() are still forced to occur, and will + always return NULL from now on. */ + _cffi_call_python_org = NULL; + } + } + + _cffi_release_reentrant_mutex(); + + return (_cffi_call_python_fnptr)_cffi_call_python_org; +} + +static +void _cffi_start_and_call_python(struct _cffi_externpy_s *externpy, char *args) +{ + _cffi_call_python_fnptr fnptr; + int current_err = errno; +#ifdef _MSC_VER + int current_lasterr = GetLastError(); +#endif + fnptr = _cffi_start_python(); + if (fnptr == NULL) { + fprintf(stderr, "function %s() called, but initialization code " + "failed. Returning 0.\n", externpy->name); + memset(args, 0, externpy->size_of_result); + } +#ifdef _MSC_VER + SetLastError(current_lasterr); +#endif + errno = current_err; + + if (fnptr != NULL) + fnptr(externpy, args); +} + + +/* The cffi_start_python() function makes sure Python is initialized + and our cffi module is set up. It can be called manually from the + user C code. The same effect is obtained automatically from any + dll-exported ``extern "Python"`` function. This function returns + -1 if initialization failed, 0 if all is OK. */ +_CFFI_UNUSED_FN +static int cffi_start_python(void) +{ + if (_cffi_call_python == &_cffi_start_and_call_python) { + if (_cffi_start_python() == NULL) + return -1; + } + cffi_read_barrier(); + return 0; +} + +#undef cffi_compare_and_swap +#undef cffi_write_barrier +#undef cffi_read_barrier + +#ifdef __cplusplus +} +#endif diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/_imp_emulation.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/_imp_emulation.py new file mode 100644 index 0000000..136abdd --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/_imp_emulation.py @@ -0,0 +1,83 @@ + +try: + # this works on Python < 3.12 + from imp import * + +except ImportError: + # this is a limited emulation for Python >= 3.12. + # Note that this is used only for tests or for the old ffi.verify(). + # This is copied from the source code of Python 3.11. + + from _imp import (acquire_lock, release_lock, + is_builtin, is_frozen) + + from importlib._bootstrap import _load + + from importlib import machinery + import os + import sys + import tokenize + + SEARCH_ERROR = 0 + PY_SOURCE = 1 + PY_COMPILED = 2 + C_EXTENSION = 3 + PY_RESOURCE = 4 + PKG_DIRECTORY = 5 + C_BUILTIN = 6 + PY_FROZEN = 7 + PY_CODERESOURCE = 8 + IMP_HOOK = 9 + + def get_suffixes(): + extensions = [(s, 'rb', C_EXTENSION) + for s in machinery.EXTENSION_SUFFIXES] + source = [(s, 'r', PY_SOURCE) for s in machinery.SOURCE_SUFFIXES] + bytecode = [(s, 'rb', PY_COMPILED) for s in machinery.BYTECODE_SUFFIXES] + return extensions + source + bytecode + + def find_module(name, path=None): + if not isinstance(name, str): + raise TypeError("'name' must be a str, not {}".format(type(name))) + elif not isinstance(path, (type(None), list)): + # Backwards-compatibility + raise RuntimeError("'path' must be None or a list, " + "not {}".format(type(path))) + + if path is None: + if is_builtin(name): + return None, None, ('', '', C_BUILTIN) + elif is_frozen(name): + return None, None, ('', '', PY_FROZEN) + else: + path = sys.path + + for entry in path: + package_directory = os.path.join(entry, name) + for suffix in ['.py', machinery.BYTECODE_SUFFIXES[0]]: + package_file_name = '__init__' + suffix + file_path = os.path.join(package_directory, package_file_name) + if os.path.isfile(file_path): + return None, package_directory, ('', '', PKG_DIRECTORY) + for suffix, mode, type_ in get_suffixes(): + file_name = name + suffix + file_path = os.path.join(entry, file_name) + if os.path.isfile(file_path): + break + else: + continue + break # Break out of outer loop when breaking out of inner loop. + else: + raise ImportError(name, name=name) + + encoding = None + if 'b' not in mode: + with open(file_path, 'rb') as file: + encoding = tokenize.detect_encoding(file.readline)[0] + file = open(file_path, mode, encoding=encoding) + return file, file_path, (suffix, mode, type_) + + def load_dynamic(name, path, file=None): + loader = machinery.ExtensionFileLoader(name, path) + spec = machinery.ModuleSpec(name=name, loader=loader, origin=path) + return _load(spec) diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/_shimmed_dist_utils.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/_shimmed_dist_utils.py new file mode 100644 index 0000000..c3d2312 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/_shimmed_dist_utils.py @@ -0,0 +1,45 @@ +""" +Temporary shim module to indirect the bits of distutils we need from setuptools/distutils while providing useful +error messages beyond `No module named 'distutils' on Python >= 3.12, or when setuptools' vendored distutils is broken. + +This is a compromise to avoid a hard-dep on setuptools for Python >= 3.12, since many users don't need runtime compilation support from CFFI. +""" +import sys + +try: + # import setuptools first; this is the most robust way to ensure its embedded distutils is available + # (the .pth shim should usually work, but this is even more robust) + import setuptools +except Exception as ex: + if sys.version_info >= (3, 12): + # Python 3.12 has no built-in distutils to fall back on, so any import problem is fatal + raise Exception("This CFFI feature requires setuptools on Python >= 3.12. The setuptools module is missing or non-functional.") from ex + + # silently ignore on older Pythons (support fallback to stdlib distutils where available) +else: + del setuptools + +try: + # bring in just the bits of distutils we need, whether they really came from setuptools or stdlib-embedded distutils + from distutils import log, sysconfig + from distutils.ccompiler import CCompiler + from distutils.command.build_ext import build_ext + from distutils.core import Distribution, Extension + from distutils.dir_util import mkpath + from distutils.errors import DistutilsSetupError, CompileError, LinkError + from distutils.log import set_threshold, set_verbosity + + if sys.platform == 'win32': + try: + # FUTURE: msvc9compiler module was removed in setuptools 74; consider removing, as it's only used by an ancient patch in `recompiler` + from distutils.msvc9compiler import MSVCCompiler + except ImportError: + MSVCCompiler = None +except Exception as ex: + if sys.version_info >= (3, 12): + raise Exception("This CFFI feature requires setuptools on Python >= 3.12. Please install the setuptools package.") from ex + + # anything older, just let the underlying distutils import error fly + raise Exception("This CFFI feature requires distutils. Please install the distutils or setuptools package.") from ex + +del sys diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/api.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/api.py new file mode 100644 index 0000000..5a474f3 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/api.py @@ -0,0 +1,967 @@ +import sys, types +from .lock import allocate_lock +from .error import CDefError +from . import model + +try: + callable +except NameError: + # Python 3.1 + from collections import Callable + callable = lambda x: isinstance(x, Callable) + +try: + basestring +except NameError: + # Python 3.x + basestring = str + +_unspecified = object() + + + +class FFI(object): + r''' + The main top-level class that you instantiate once, or once per module. + + Example usage: + + ffi = FFI() + ffi.cdef(""" + int printf(const char *, ...); + """) + + C = ffi.dlopen(None) # standard library + -or- + C = ffi.verify() # use a C compiler: verify the decl above is right + + C.printf("hello, %s!\n", ffi.new("char[]", "world")) + ''' + + def __init__(self, backend=None): + """Create an FFI instance. The 'backend' argument is used to + select a non-default backend, mostly for tests. + """ + if backend is None: + # You need PyPy (>= 2.0 beta), or a CPython (>= 2.6) with + # _cffi_backend.so compiled. + import _cffi_backend as backend + from . import __version__ + if backend.__version__ != __version__: + # bad version! Try to be as explicit as possible. + if hasattr(backend, '__file__'): + # CPython + raise Exception("Version mismatch: this is the 'cffi' package version %s, located in %r. When we import the top-level '_cffi_backend' extension module, we get version %s, located in %r. The two versions should be equal; check your installation." % ( + __version__, __file__, + backend.__version__, backend.__file__)) + else: + # PyPy + raise Exception("Version mismatch: this is the 'cffi' package version %s, located in %r. This interpreter comes with a built-in '_cffi_backend' module, which is version %s. The two versions should be equal; check your installation." % ( + __version__, __file__, backend.__version__)) + # (If you insist you can also try to pass the option + # 'backend=backend_ctypes.CTypesBackend()', but don't + # rely on it! It's probably not going to work well.) + + from . import cparser + self._backend = backend + self._lock = allocate_lock() + self._parser = cparser.Parser() + self._cached_btypes = {} + self._parsed_types = types.ModuleType('parsed_types').__dict__ + self._new_types = types.ModuleType('new_types').__dict__ + self._function_caches = [] + self._libraries = [] + self._cdefsources = [] + self._included_ffis = [] + self._windows_unicode = None + self._init_once_cache = {} + self._cdef_version = None + self._embedding = None + self._typecache = model.get_typecache(backend) + if hasattr(backend, 'set_ffi'): + backend.set_ffi(self) + for name in list(backend.__dict__): + if name.startswith('RTLD_'): + setattr(self, name, getattr(backend, name)) + # + with self._lock: + self.BVoidP = self._get_cached_btype(model.voidp_type) + self.BCharA = self._get_cached_btype(model.char_array_type) + if isinstance(backend, types.ModuleType): + # _cffi_backend: attach these constants to the class + if not hasattr(FFI, 'NULL'): + FFI.NULL = self.cast(self.BVoidP, 0) + FFI.CData, FFI.CType = backend._get_types() + else: + # ctypes backend: attach these constants to the instance + self.NULL = self.cast(self.BVoidP, 0) + self.CData, self.CType = backend._get_types() + self.buffer = backend.buffer + + def cdef(self, csource, override=False, packed=False, pack=None): + """Parse the given C source. This registers all declared functions, + types, and global variables. The functions and global variables can + then be accessed via either 'ffi.dlopen()' or 'ffi.verify()'. + The types can be used in 'ffi.new()' and other functions. + If 'packed' is specified as True, all structs declared inside this + cdef are packed, i.e. laid out without any field alignment at all. + Alternatively, 'pack' can be a small integer, and requests for + alignment greater than that are ignored (pack=1 is equivalent to + packed=True). + """ + self._cdef(csource, override=override, packed=packed, pack=pack) + + def embedding_api(self, csource, packed=False, pack=None): + self._cdef(csource, packed=packed, pack=pack, dllexport=True) + if self._embedding is None: + self._embedding = '' + + def _cdef(self, csource, override=False, **options): + if not isinstance(csource, str): # unicode, on Python 2 + if not isinstance(csource, basestring): + raise TypeError("cdef() argument must be a string") + csource = csource.encode('ascii') + with self._lock: + self._cdef_version = object() + self._parser.parse(csource, override=override, **options) + self._cdefsources.append(csource) + if override: + for cache in self._function_caches: + cache.clear() + finishlist = self._parser._recomplete + if finishlist: + self._parser._recomplete = [] + for tp in finishlist: + tp.finish_backend_type(self, finishlist) + + def dlopen(self, name, flags=0): + """Load and return a dynamic library identified by 'name'. + The standard C library can be loaded by passing None. + Note that functions and types declared by 'ffi.cdef()' are not + linked to a particular library, just like C headers; in the + library we only look for the actual (untyped) symbols. + """ + if not (isinstance(name, basestring) or + name is None or + isinstance(name, self.CData)): + raise TypeError("dlopen(name): name must be a file name, None, " + "or an already-opened 'void *' handle") + with self._lock: + lib, function_cache = _make_ffi_library(self, name, flags) + self._function_caches.append(function_cache) + self._libraries.append(lib) + return lib + + def dlclose(self, lib): + """Close a library obtained with ffi.dlopen(). After this call, + access to functions or variables from the library will fail + (possibly with a segmentation fault). + """ + type(lib).__cffi_close__(lib) + + def _typeof_locked(self, cdecl): + # call me with the lock! + key = cdecl + if key in self._parsed_types: + return self._parsed_types[key] + # + if not isinstance(cdecl, str): # unicode, on Python 2 + cdecl = cdecl.encode('ascii') + # + type = self._parser.parse_type(cdecl) + really_a_function_type = type.is_raw_function + if really_a_function_type: + type = type.as_function_pointer() + btype = self._get_cached_btype(type) + result = btype, really_a_function_type + self._parsed_types[key] = result + return result + + def _typeof(self, cdecl, consider_function_as_funcptr=False): + # string -> ctype object + try: + result = self._parsed_types[cdecl] + except KeyError: + with self._lock: + result = self._typeof_locked(cdecl) + # + btype, really_a_function_type = result + if really_a_function_type and not consider_function_as_funcptr: + raise CDefError("the type %r is a function type, not a " + "pointer-to-function type" % (cdecl,)) + return btype + + def typeof(self, cdecl): + """Parse the C type given as a string and return the + corresponding object. + It can also be used on 'cdata' instance to get its C type. + """ + if isinstance(cdecl, basestring): + return self._typeof(cdecl) + if isinstance(cdecl, self.CData): + return self._backend.typeof(cdecl) + if isinstance(cdecl, types.BuiltinFunctionType): + res = _builtin_function_type(cdecl) + if res is not None: + return res + if (isinstance(cdecl, types.FunctionType) + and hasattr(cdecl, '_cffi_base_type')): + with self._lock: + return self._get_cached_btype(cdecl._cffi_base_type) + raise TypeError(type(cdecl)) + + def sizeof(self, cdecl): + """Return the size in bytes of the argument. It can be a + string naming a C type, or a 'cdata' instance. + """ + if isinstance(cdecl, basestring): + BType = self._typeof(cdecl) + return self._backend.sizeof(BType) + else: + return self._backend.sizeof(cdecl) + + def alignof(self, cdecl): + """Return the natural alignment size in bytes of the C type + given as a string. + """ + if isinstance(cdecl, basestring): + cdecl = self._typeof(cdecl) + return self._backend.alignof(cdecl) + + def offsetof(self, cdecl, *fields_or_indexes): + """Return the offset of the named field inside the given + structure or array, which must be given as a C type name. + You can give several field names in case of nested structures. + You can also give numeric values which correspond to array + items, in case of an array type. + """ + if isinstance(cdecl, basestring): + cdecl = self._typeof(cdecl) + return self._typeoffsetof(cdecl, *fields_or_indexes)[1] + + def new(self, cdecl, init=None): + """Allocate an instance according to the specified C type and + return a pointer to it. The specified C type must be either a + pointer or an array: ``new('X *')`` allocates an X and returns + a pointer to it, whereas ``new('X[n]')`` allocates an array of + n X'es and returns an array referencing it (which works + mostly like a pointer, like in C). You can also use + ``new('X[]', n)`` to allocate an array of a non-constant + length n. + + The memory is initialized following the rules of declaring a + global variable in C: by default it is zero-initialized, but + an explicit initializer can be given which can be used to + fill all or part of the memory. + + When the returned object goes out of scope, the memory + is freed. In other words the returned object has + ownership of the value of type 'cdecl' that it points to. This + means that the raw data can be used as long as this object is + kept alive, but must not be used for a longer time. Be careful + about that when copying the pointer to the memory somewhere + else, e.g. into another structure. + """ + if isinstance(cdecl, basestring): + cdecl = self._typeof(cdecl) + return self._backend.newp(cdecl, init) + + def new_allocator(self, alloc=None, free=None, + should_clear_after_alloc=True): + """Return a new allocator, i.e. a function that behaves like ffi.new() + but uses the provided low-level 'alloc' and 'free' functions. + + 'alloc' is called with the size as argument. If it returns NULL, a + MemoryError is raised. 'free' is called with the result of 'alloc' + as argument. Both can be either Python function or directly C + functions. If 'free' is None, then no free function is called. + If both 'alloc' and 'free' are None, the default is used. + + If 'should_clear_after_alloc' is set to False, then the memory + returned by 'alloc' is assumed to be already cleared (or you are + fine with garbage); otherwise CFFI will clear it. + """ + compiled_ffi = self._backend.FFI() + allocator = compiled_ffi.new_allocator(alloc, free, + should_clear_after_alloc) + def allocate(cdecl, init=None): + if isinstance(cdecl, basestring): + cdecl = self._typeof(cdecl) + return allocator(cdecl, init) + return allocate + + def cast(self, cdecl, source): + """Similar to a C cast: returns an instance of the named C + type initialized with the given 'source'. The source is + casted between integers or pointers of any type. + """ + if isinstance(cdecl, basestring): + cdecl = self._typeof(cdecl) + return self._backend.cast(cdecl, source) + + def string(self, cdata, maxlen=-1): + """Return a Python string (or unicode string) from the 'cdata'. + If 'cdata' is a pointer or array of characters or bytes, returns + the null-terminated string. The returned string extends until + the first null character, or at most 'maxlen' characters. If + 'cdata' is an array then 'maxlen' defaults to its length. + + If 'cdata' is a pointer or array of wchar_t, returns a unicode + string following the same rules. + + If 'cdata' is a single character or byte or a wchar_t, returns + it as a string or unicode string. + + If 'cdata' is an enum, returns the value of the enumerator as a + string, or 'NUMBER' if the value is out of range. + """ + return self._backend.string(cdata, maxlen) + + def unpack(self, cdata, length): + """Unpack an array of C data of the given length, + returning a Python string/unicode/list. + + If 'cdata' is a pointer to 'char', returns a byte string. + It does not stop at the first null. This is equivalent to: + ffi.buffer(cdata, length)[:] + + If 'cdata' is a pointer to 'wchar_t', returns a unicode string. + 'length' is measured in wchar_t's; it is not the size in bytes. + + If 'cdata' is a pointer to anything else, returns a list of + 'length' items. This is a faster equivalent to: + [cdata[i] for i in range(length)] + """ + return self._backend.unpack(cdata, length) + + #def buffer(self, cdata, size=-1): + # """Return a read-write buffer object that references the raw C data + # pointed to by the given 'cdata'. The 'cdata' must be a pointer or + # an array. Can be passed to functions expecting a buffer, or directly + # manipulated with: + # + # buf[:] get a copy of it in a regular string, or + # buf[idx] as a single character + # buf[:] = ... + # buf[idx] = ... change the content + # """ + # note that 'buffer' is a type, set on this instance by __init__ + + def from_buffer(self, cdecl, python_buffer=_unspecified, + require_writable=False): + """Return a cdata of the given type pointing to the data of the + given Python object, which must support the buffer interface. + Note that this is not meant to be used on the built-in types + str or unicode (you can build 'char[]' arrays explicitly) + but only on objects containing large quantities of raw data + in some other format, like 'array.array' or numpy arrays. + + The first argument is optional and default to 'char[]'. + """ + if python_buffer is _unspecified: + cdecl, python_buffer = self.BCharA, cdecl + elif isinstance(cdecl, basestring): + cdecl = self._typeof(cdecl) + return self._backend.from_buffer(cdecl, python_buffer, + require_writable) + + def memmove(self, dest, src, n): + """ffi.memmove(dest, src, n) copies n bytes of memory from src to dest. + + Like the C function memmove(), the memory areas may overlap; + apart from that it behaves like the C function memcpy(). + + 'src' can be any cdata ptr or array, or any Python buffer object. + 'dest' can be any cdata ptr or array, or a writable Python buffer + object. The size to copy, 'n', is always measured in bytes. + + Unlike other methods, this one supports all Python buffer including + byte strings and bytearrays---but it still does not support + non-contiguous buffers. + """ + return self._backend.memmove(dest, src, n) + + def callback(self, cdecl, python_callable=None, error=None, onerror=None): + """Return a callback object or a decorator making such a + callback object. 'cdecl' must name a C function pointer type. + The callback invokes the specified 'python_callable' (which may + be provided either directly or via a decorator). Important: the + callback object must be manually kept alive for as long as the + callback may be invoked from the C level. + """ + def callback_decorator_wrap(python_callable): + if not callable(python_callable): + raise TypeError("the 'python_callable' argument " + "is not callable") + return self._backend.callback(cdecl, python_callable, + error, onerror) + if isinstance(cdecl, basestring): + cdecl = self._typeof(cdecl, consider_function_as_funcptr=True) + if python_callable is None: + return callback_decorator_wrap # decorator mode + else: + return callback_decorator_wrap(python_callable) # direct mode + + def getctype(self, cdecl, replace_with=''): + """Return a string giving the C type 'cdecl', which may be itself + a string or a object. If 'replace_with' is given, it gives + extra text to append (or insert for more complicated C types), like + a variable name, or '*' to get actually the C type 'pointer-to-cdecl'. + """ + if isinstance(cdecl, basestring): + cdecl = self._typeof(cdecl) + replace_with = replace_with.strip() + if (replace_with.startswith('*') + and '&[' in self._backend.getcname(cdecl, '&')): + replace_with = '(%s)' % replace_with + elif replace_with and not replace_with[0] in '[(': + replace_with = ' ' + replace_with + return self._backend.getcname(cdecl, replace_with) + + def gc(self, cdata, destructor, size=0): + """Return a new cdata object that points to the same + data. Later, when this new cdata object is garbage-collected, + 'destructor(old_cdata_object)' will be called. + + The optional 'size' gives an estimate of the size, used to + trigger the garbage collection more eagerly. So far only used + on PyPy. It tells the GC that the returned object keeps alive + roughly 'size' bytes of external memory. + """ + return self._backend.gcp(cdata, destructor, size) + + def _get_cached_btype(self, type): + assert self._lock.acquire(False) is False + # call me with the lock! + try: + BType = self._cached_btypes[type] + except KeyError: + finishlist = [] + BType = type.get_cached_btype(self, finishlist) + for type in finishlist: + type.finish_backend_type(self, finishlist) + return BType + + def verify(self, source='', tmpdir=None, **kwargs): + """Verify that the current ffi signatures compile on this + machine, and return a dynamic library object. The dynamic + library can be used to call functions and access global + variables declared in this 'ffi'. The library is compiled + by the C compiler: it gives you C-level API compatibility + (including calling macros). This is unlike 'ffi.dlopen()', + which requires binary compatibility in the signatures. + """ + from .verifier import Verifier, _caller_dir_pycache + # + # If set_unicode(True) was called, insert the UNICODE and + # _UNICODE macro declarations + if self._windows_unicode: + self._apply_windows_unicode(kwargs) + # + # Set the tmpdir here, and not in Verifier.__init__: it picks + # up the caller's directory, which we want to be the caller of + # ffi.verify(), as opposed to the caller of Veritier(). + tmpdir = tmpdir or _caller_dir_pycache() + # + # Make a Verifier() and use it to load the library. + self.verifier = Verifier(self, source, tmpdir, **kwargs) + lib = self.verifier.load_library() + # + # Save the loaded library for keep-alive purposes, even + # if the caller doesn't keep it alive itself (it should). + self._libraries.append(lib) + return lib + + def _get_errno(self): + return self._backend.get_errno() + def _set_errno(self, errno): + self._backend.set_errno(errno) + errno = property(_get_errno, _set_errno, None, + "the value of 'errno' from/to the C calls") + + def getwinerror(self, code=-1): + return self._backend.getwinerror(code) + + def _pointer_to(self, ctype): + with self._lock: + return model.pointer_cache(self, ctype) + + def addressof(self, cdata, *fields_or_indexes): + """Return the address of a . + If 'fields_or_indexes' are given, returns the address of that + field or array item in the structure or array, recursively in + case of nested structures. + """ + try: + ctype = self._backend.typeof(cdata) + except TypeError: + if '__addressof__' in type(cdata).__dict__: + return type(cdata).__addressof__(cdata, *fields_or_indexes) + raise + if fields_or_indexes: + ctype, offset = self._typeoffsetof(ctype, *fields_or_indexes) + else: + if ctype.kind == "pointer": + raise TypeError("addressof(pointer)") + offset = 0 + ctypeptr = self._pointer_to(ctype) + return self._backend.rawaddressof(ctypeptr, cdata, offset) + + def _typeoffsetof(self, ctype, field_or_index, *fields_or_indexes): + ctype, offset = self._backend.typeoffsetof(ctype, field_or_index) + for field1 in fields_or_indexes: + ctype, offset1 = self._backend.typeoffsetof(ctype, field1, 1) + offset += offset1 + return ctype, offset + + def include(self, ffi_to_include): + """Includes the typedefs, structs, unions and enums defined + in another FFI instance. Usage is similar to a #include in C, + where a part of the program might include types defined in + another part for its own usage. Note that the include() + method has no effect on functions, constants and global + variables, which must anyway be accessed directly from the + lib object returned by the original FFI instance. + """ + if not isinstance(ffi_to_include, FFI): + raise TypeError("ffi.include() expects an argument that is also of" + " type cffi.FFI, not %r" % ( + type(ffi_to_include).__name__,)) + if ffi_to_include is self: + raise ValueError("self.include(self)") + with ffi_to_include._lock: + with self._lock: + self._parser.include(ffi_to_include._parser) + self._cdefsources.append('[') + self._cdefsources.extend(ffi_to_include._cdefsources) + self._cdefsources.append(']') + self._included_ffis.append(ffi_to_include) + + def new_handle(self, x): + return self._backend.newp_handle(self.BVoidP, x) + + def from_handle(self, x): + return self._backend.from_handle(x) + + def release(self, x): + self._backend.release(x) + + def set_unicode(self, enabled_flag): + """Windows: if 'enabled_flag' is True, enable the UNICODE and + _UNICODE defines in C, and declare the types like TCHAR and LPTCSTR + to be (pointers to) wchar_t. If 'enabled_flag' is False, + declare these types to be (pointers to) plain 8-bit characters. + This is mostly for backward compatibility; you usually want True. + """ + if self._windows_unicode is not None: + raise ValueError("set_unicode() can only be called once") + enabled_flag = bool(enabled_flag) + if enabled_flag: + self.cdef("typedef wchar_t TBYTE;" + "typedef wchar_t TCHAR;" + "typedef const wchar_t *LPCTSTR;" + "typedef const wchar_t *PCTSTR;" + "typedef wchar_t *LPTSTR;" + "typedef wchar_t *PTSTR;" + "typedef TBYTE *PTBYTE;" + "typedef TCHAR *PTCHAR;") + else: + self.cdef("typedef char TBYTE;" + "typedef char TCHAR;" + "typedef const char *LPCTSTR;" + "typedef const char *PCTSTR;" + "typedef char *LPTSTR;" + "typedef char *PTSTR;" + "typedef TBYTE *PTBYTE;" + "typedef TCHAR *PTCHAR;") + self._windows_unicode = enabled_flag + + def _apply_windows_unicode(self, kwds): + defmacros = kwds.get('define_macros', ()) + if not isinstance(defmacros, (list, tuple)): + raise TypeError("'define_macros' must be a list or tuple") + defmacros = list(defmacros) + [('UNICODE', '1'), + ('_UNICODE', '1')] + kwds['define_macros'] = defmacros + + def _apply_embedding_fix(self, kwds): + # must include an argument like "-lpython2.7" for the compiler + def ensure(key, value): + lst = kwds.setdefault(key, []) + if value not in lst: + lst.append(value) + # + if '__pypy__' in sys.builtin_module_names: + import os + if sys.platform == "win32": + # we need 'libpypy-c.lib'. Current distributions of + # pypy (>= 4.1) contain it as 'libs/python27.lib'. + pythonlib = "python{0[0]}{0[1]}".format(sys.version_info) + if hasattr(sys, 'prefix'): + ensure('library_dirs', os.path.join(sys.prefix, 'libs')) + else: + # we need 'libpypy-c.{so,dylib}', which should be by + # default located in 'sys.prefix/bin' for installed + # systems. + if sys.version_info < (3,): + pythonlib = "pypy-c" + else: + pythonlib = "pypy3-c" + if hasattr(sys, 'prefix'): + ensure('library_dirs', os.path.join(sys.prefix, 'bin')) + # On uninstalled pypy's, the libpypy-c is typically found in + # .../pypy/goal/. + if hasattr(sys, 'prefix'): + ensure('library_dirs', os.path.join(sys.prefix, 'pypy', 'goal')) + else: + if sys.platform == "win32": + template = "python%d%d" + if hasattr(sys, 'gettotalrefcount'): + template += '_d' + else: + try: + import sysconfig + except ImportError: # 2.6 + from cffi._shimmed_dist_utils import sysconfig + template = "python%d.%d" + if sysconfig.get_config_var('DEBUG_EXT'): + template += sysconfig.get_config_var('DEBUG_EXT') + pythonlib = (template % + (sys.hexversion >> 24, (sys.hexversion >> 16) & 0xff)) + if hasattr(sys, 'abiflags'): + pythonlib += sys.abiflags + ensure('libraries', pythonlib) + if sys.platform == "win32": + ensure('extra_link_args', '/MANIFEST') + + def set_source(self, module_name, source, source_extension='.c', **kwds): + import os + if hasattr(self, '_assigned_source'): + raise ValueError("set_source() cannot be called several times " + "per ffi object") + if not isinstance(module_name, basestring): + raise TypeError("'module_name' must be a string") + if os.sep in module_name or (os.altsep and os.altsep in module_name): + raise ValueError("'module_name' must not contain '/': use a dotted " + "name to make a 'package.module' location") + self._assigned_source = (str(module_name), source, + source_extension, kwds) + + def set_source_pkgconfig(self, module_name, pkgconfig_libs, source, + source_extension='.c', **kwds): + from . import pkgconfig + if not isinstance(pkgconfig_libs, list): + raise TypeError("the pkgconfig_libs argument must be a list " + "of package names") + kwds2 = pkgconfig.flags_from_pkgconfig(pkgconfig_libs) + pkgconfig.merge_flags(kwds, kwds2) + self.set_source(module_name, source, source_extension, **kwds) + + def distutils_extension(self, tmpdir='build', verbose=True): + from cffi._shimmed_dist_utils import mkpath + from .recompiler import recompile + # + if not hasattr(self, '_assigned_source'): + if hasattr(self, 'verifier'): # fallback, 'tmpdir' ignored + return self.verifier.get_extension() + raise ValueError("set_source() must be called before" + " distutils_extension()") + module_name, source, source_extension, kwds = self._assigned_source + if source is None: + raise TypeError("distutils_extension() is only for C extension " + "modules, not for dlopen()-style pure Python " + "modules") + mkpath(tmpdir) + ext, updated = recompile(self, module_name, + source, tmpdir=tmpdir, extradir=tmpdir, + source_extension=source_extension, + call_c_compiler=False, **kwds) + if verbose: + if updated: + sys.stderr.write("regenerated: %r\n" % (ext.sources[0],)) + else: + sys.stderr.write("not modified: %r\n" % (ext.sources[0],)) + return ext + + def emit_c_code(self, filename): + from .recompiler import recompile + # + if not hasattr(self, '_assigned_source'): + raise ValueError("set_source() must be called before emit_c_code()") + module_name, source, source_extension, kwds = self._assigned_source + if source is None: + raise TypeError("emit_c_code() is only for C extension modules, " + "not for dlopen()-style pure Python modules") + recompile(self, module_name, source, + c_file=filename, call_c_compiler=False, + uses_ffiplatform=False, **kwds) + + def emit_python_code(self, filename): + from .recompiler import recompile + # + if not hasattr(self, '_assigned_source'): + raise ValueError("set_source() must be called before emit_c_code()") + module_name, source, source_extension, kwds = self._assigned_source + if source is not None: + raise TypeError("emit_python_code() is only for dlopen()-style " + "pure Python modules, not for C extension modules") + recompile(self, module_name, source, + c_file=filename, call_c_compiler=False, + uses_ffiplatform=False, **kwds) + + def compile(self, tmpdir='.', verbose=0, target=None, debug=None): + """The 'target' argument gives the final file name of the + compiled DLL. Use '*' to force distutils' choice, suitable for + regular CPython C API modules. Use a file name ending in '.*' + to ask for the system's default extension for dynamic libraries + (.so/.dll/.dylib). + + The default is '*' when building a non-embedded C API extension, + and (module_name + '.*') when building an embedded library. + """ + from .recompiler import recompile + # + if not hasattr(self, '_assigned_source'): + raise ValueError("set_source() must be called before compile()") + module_name, source, source_extension, kwds = self._assigned_source + return recompile(self, module_name, source, tmpdir=tmpdir, + target=target, source_extension=source_extension, + compiler_verbose=verbose, debug=debug, **kwds) + + def init_once(self, func, tag): + # Read _init_once_cache[tag], which is either (False, lock) if + # we're calling the function now in some thread, or (True, result). + # Don't call setdefault() in most cases, to avoid allocating and + # immediately freeing a lock; but still use setdefaut() to avoid + # races. + try: + x = self._init_once_cache[tag] + except KeyError: + x = self._init_once_cache.setdefault(tag, (False, allocate_lock())) + # Common case: we got (True, result), so we return the result. + if x[0]: + return x[1] + # Else, it's a lock. Acquire it to serialize the following tests. + with x[1]: + # Read again from _init_once_cache the current status. + x = self._init_once_cache[tag] + if x[0]: + return x[1] + # Call the function and store the result back. + result = func() + self._init_once_cache[tag] = (True, result) + return result + + def embedding_init_code(self, pysource): + if self._embedding: + raise ValueError("embedding_init_code() can only be called once") + # fix 'pysource' before it gets dumped into the C file: + # - remove empty lines at the beginning, so it starts at "line 1" + # - dedent, if all non-empty lines are indented + # - check for SyntaxErrors + import re + match = re.match(r'\s*\n', pysource) + if match: + pysource = pysource[match.end():] + lines = pysource.splitlines() or [''] + prefix = re.match(r'\s*', lines[0]).group() + for i in range(1, len(lines)): + line = lines[i] + if line.rstrip(): + while not line.startswith(prefix): + prefix = prefix[:-1] + i = len(prefix) + lines = [line[i:]+'\n' for line in lines] + pysource = ''.join(lines) + # + compile(pysource, "cffi_init", "exec") + # + self._embedding = pysource + + def def_extern(self, *args, **kwds): + raise ValueError("ffi.def_extern() is only available on API-mode FFI " + "objects") + + def list_types(self): + """Returns the user type names known to this FFI instance. + This returns a tuple containing three lists of names: + (typedef_names, names_of_structs, names_of_unions) + """ + typedefs = [] + structs = [] + unions = [] + for key in self._parser._declarations: + if key.startswith('typedef '): + typedefs.append(key[8:]) + elif key.startswith('struct '): + structs.append(key[7:]) + elif key.startswith('union '): + unions.append(key[6:]) + typedefs.sort() + structs.sort() + unions.sort() + return (typedefs, structs, unions) + + +def _load_backend_lib(backend, name, flags): + import os + if not isinstance(name, basestring): + if sys.platform != "win32" or name is not None: + return backend.load_library(name, flags) + name = "c" # Windows: load_library(None) fails, but this works + # on Python 2 (backward compatibility hack only) + first_error = None + if '.' in name or '/' in name or os.sep in name: + try: + return backend.load_library(name, flags) + except OSError as e: + first_error = e + import ctypes.util + path = ctypes.util.find_library(name) + if path is None: + if name == "c" and sys.platform == "win32" and sys.version_info >= (3,): + raise OSError("dlopen(None) cannot work on Windows for Python 3 " + "(see http://bugs.python.org/issue23606)") + msg = ("ctypes.util.find_library() did not manage " + "to locate a library called %r" % (name,)) + if first_error is not None: + msg = "%s. Additionally, %s" % (first_error, msg) + raise OSError(msg) + return backend.load_library(path, flags) + +def _make_ffi_library(ffi, libname, flags): + backend = ffi._backend + backendlib = _load_backend_lib(backend, libname, flags) + # + def accessor_function(name): + key = 'function ' + name + tp, _ = ffi._parser._declarations[key] + BType = ffi._get_cached_btype(tp) + value = backendlib.load_function(BType, name) + library.__dict__[name] = value + # + def accessor_variable(name): + key = 'variable ' + name + tp, _ = ffi._parser._declarations[key] + BType = ffi._get_cached_btype(tp) + read_variable = backendlib.read_variable + write_variable = backendlib.write_variable + setattr(FFILibrary, name, property( + lambda self: read_variable(BType, name), + lambda self, value: write_variable(BType, name, value))) + # + def addressof_var(name): + try: + return addr_variables[name] + except KeyError: + with ffi._lock: + if name not in addr_variables: + key = 'variable ' + name + tp, _ = ffi._parser._declarations[key] + BType = ffi._get_cached_btype(tp) + if BType.kind != 'array': + BType = model.pointer_cache(ffi, BType) + p = backendlib.load_function(BType, name) + addr_variables[name] = p + return addr_variables[name] + # + def accessor_constant(name): + raise NotImplementedError("non-integer constant '%s' cannot be " + "accessed from a dlopen() library" % (name,)) + # + def accessor_int_constant(name): + library.__dict__[name] = ffi._parser._int_constants[name] + # + accessors = {} + accessors_version = [False] + addr_variables = {} + # + def update_accessors(): + if accessors_version[0] is ffi._cdef_version: + return + # + for key, (tp, _) in ffi._parser._declarations.items(): + if not isinstance(tp, model.EnumType): + tag, name = key.split(' ', 1) + if tag == 'function': + accessors[name] = accessor_function + elif tag == 'variable': + accessors[name] = accessor_variable + elif tag == 'constant': + accessors[name] = accessor_constant + else: + for i, enumname in enumerate(tp.enumerators): + def accessor_enum(name, tp=tp, i=i): + tp.check_not_partial() + library.__dict__[name] = tp.enumvalues[i] + accessors[enumname] = accessor_enum + for name in ffi._parser._int_constants: + accessors.setdefault(name, accessor_int_constant) + accessors_version[0] = ffi._cdef_version + # + def make_accessor(name): + with ffi._lock: + if name in library.__dict__ or name in FFILibrary.__dict__: + return # added by another thread while waiting for the lock + if name not in accessors: + update_accessors() + if name not in accessors: + raise AttributeError(name) + accessors[name](name) + # + class FFILibrary(object): + def __getattr__(self, name): + make_accessor(name) + return getattr(self, name) + def __setattr__(self, name, value): + try: + property = getattr(self.__class__, name) + except AttributeError: + make_accessor(name) + setattr(self, name, value) + else: + property.__set__(self, value) + def __dir__(self): + with ffi._lock: + update_accessors() + return accessors.keys() + def __addressof__(self, name): + if name in library.__dict__: + return library.__dict__[name] + if name in FFILibrary.__dict__: + return addressof_var(name) + make_accessor(name) + if name in library.__dict__: + return library.__dict__[name] + if name in FFILibrary.__dict__: + return addressof_var(name) + raise AttributeError("cffi library has no function or " + "global variable named '%s'" % (name,)) + def __cffi_close__(self): + backendlib.close_lib() + self.__dict__.clear() + # + if isinstance(libname, basestring): + try: + if not isinstance(libname, str): # unicode, on Python 2 + libname = libname.encode('utf-8') + FFILibrary.__name__ = 'FFILibrary_%s' % libname + except UnicodeError: + pass + library = FFILibrary() + return library, library.__dict__ + +def _builtin_function_type(func): + # a hack to make at least ffi.typeof(builtin_function) work, + # if the builtin function was obtained by 'vengine_cpy'. + import sys + try: + module = sys.modules[func.__module__] + ffi = module._cffi_original_ffi + types_of_builtin_funcs = module._cffi_types_of_builtin_funcs + tp = types_of_builtin_funcs[func] + except (KeyError, AttributeError, TypeError): + return None + else: + with ffi._lock: + return ffi._get_cached_btype(tp) diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/backend_ctypes.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/backend_ctypes.py new file mode 100644 index 0000000..e7956a7 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/backend_ctypes.py @@ -0,0 +1,1121 @@ +import ctypes, ctypes.util, operator, sys +from . import model + +if sys.version_info < (3,): + bytechr = chr +else: + unicode = str + long = int + xrange = range + bytechr = lambda num: bytes([num]) + +class CTypesType(type): + pass + +class CTypesData(object): + __metaclass__ = CTypesType + __slots__ = ['__weakref__'] + __name__ = '' + + def __init__(self, *args): + raise TypeError("cannot instantiate %r" % (self.__class__,)) + + @classmethod + def _newp(cls, init): + raise TypeError("expected a pointer or array ctype, got '%s'" + % (cls._get_c_name(),)) + + @staticmethod + def _to_ctypes(value): + raise TypeError + + @classmethod + def _arg_to_ctypes(cls, *value): + try: + ctype = cls._ctype + except AttributeError: + raise TypeError("cannot create an instance of %r" % (cls,)) + if value: + res = cls._to_ctypes(*value) + if not isinstance(res, ctype): + res = cls._ctype(res) + else: + res = cls._ctype() + return res + + @classmethod + def _create_ctype_obj(cls, init): + if init is None: + return cls._arg_to_ctypes() + else: + return cls._arg_to_ctypes(init) + + @staticmethod + def _from_ctypes(ctypes_value): + raise TypeError + + @classmethod + def _get_c_name(cls, replace_with=''): + return cls._reftypename.replace(' &', replace_with) + + @classmethod + def _fix_class(cls): + cls.__name__ = 'CData<%s>' % (cls._get_c_name(),) + cls.__qualname__ = 'CData<%s>' % (cls._get_c_name(),) + cls.__module__ = 'ffi' + + def _get_own_repr(self): + raise NotImplementedError + + def _addr_repr(self, address): + if address == 0: + return 'NULL' + else: + if address < 0: + address += 1 << (8*ctypes.sizeof(ctypes.c_void_p)) + return '0x%x' % address + + def __repr__(self, c_name=None): + own = self._get_own_repr() + return '' % (c_name or self._get_c_name(), own) + + def _convert_to_address(self, BClass): + if BClass is None: + raise TypeError("cannot convert %r to an address" % ( + self._get_c_name(),)) + else: + raise TypeError("cannot convert %r to %r" % ( + self._get_c_name(), BClass._get_c_name())) + + @classmethod + def _get_size(cls): + return ctypes.sizeof(cls._ctype) + + def _get_size_of_instance(self): + return ctypes.sizeof(self._ctype) + + @classmethod + def _cast_from(cls, source): + raise TypeError("cannot cast to %r" % (cls._get_c_name(),)) + + def _cast_to_integer(self): + return self._convert_to_address(None) + + @classmethod + def _alignment(cls): + return ctypes.alignment(cls._ctype) + + def __iter__(self): + raise TypeError("cdata %r does not support iteration" % ( + self._get_c_name()),) + + def _make_cmp(name): + cmpfunc = getattr(operator, name) + def cmp(self, other): + v_is_ptr = not isinstance(self, CTypesGenericPrimitive) + w_is_ptr = (isinstance(other, CTypesData) and + not isinstance(other, CTypesGenericPrimitive)) + if v_is_ptr and w_is_ptr: + return cmpfunc(self._convert_to_address(None), + other._convert_to_address(None)) + elif v_is_ptr or w_is_ptr: + return NotImplemented + else: + if isinstance(self, CTypesGenericPrimitive): + self = self._value + if isinstance(other, CTypesGenericPrimitive): + other = other._value + return cmpfunc(self, other) + cmp.func_name = name + return cmp + + __eq__ = _make_cmp('__eq__') + __ne__ = _make_cmp('__ne__') + __lt__ = _make_cmp('__lt__') + __le__ = _make_cmp('__le__') + __gt__ = _make_cmp('__gt__') + __ge__ = _make_cmp('__ge__') + + def __hash__(self): + return hash(self._convert_to_address(None)) + + def _to_string(self, maxlen): + raise TypeError("string(): %r" % (self,)) + + +class CTypesGenericPrimitive(CTypesData): + __slots__ = [] + + def __hash__(self): + return hash(self._value) + + def _get_own_repr(self): + return repr(self._from_ctypes(self._value)) + + +class CTypesGenericArray(CTypesData): + __slots__ = [] + + @classmethod + def _newp(cls, init): + return cls(init) + + def __iter__(self): + for i in xrange(len(self)): + yield self[i] + + def _get_own_repr(self): + return self._addr_repr(ctypes.addressof(self._blob)) + + +class CTypesGenericPtr(CTypesData): + __slots__ = ['_address', '_as_ctype_ptr'] + _automatic_casts = False + kind = "pointer" + + @classmethod + def _newp(cls, init): + return cls(init) + + @classmethod + def _cast_from(cls, source): + if source is None: + address = 0 + elif isinstance(source, CTypesData): + address = source._cast_to_integer() + elif isinstance(source, (int, long)): + address = source + else: + raise TypeError("bad type for cast to %r: %r" % + (cls, type(source).__name__)) + return cls._new_pointer_at(address) + + @classmethod + def _new_pointer_at(cls, address): + self = cls.__new__(cls) + self._address = address + self._as_ctype_ptr = ctypes.cast(address, cls._ctype) + return self + + def _get_own_repr(self): + try: + return self._addr_repr(self._address) + except AttributeError: + return '???' + + def _cast_to_integer(self): + return self._address + + def __nonzero__(self): + return bool(self._address) + __bool__ = __nonzero__ + + @classmethod + def _to_ctypes(cls, value): + if not isinstance(value, CTypesData): + raise TypeError("unexpected %s object" % type(value).__name__) + address = value._convert_to_address(cls) + return ctypes.cast(address, cls._ctype) + + @classmethod + def _from_ctypes(cls, ctypes_ptr): + address = ctypes.cast(ctypes_ptr, ctypes.c_void_p).value or 0 + return cls._new_pointer_at(address) + + @classmethod + def _initialize(cls, ctypes_ptr, value): + if value: + ctypes_ptr.contents = cls._to_ctypes(value).contents + + def _convert_to_address(self, BClass): + if (BClass in (self.__class__, None) or BClass._automatic_casts + or self._automatic_casts): + return self._address + else: + return CTypesData._convert_to_address(self, BClass) + + +class CTypesBaseStructOrUnion(CTypesData): + __slots__ = ['_blob'] + + @classmethod + def _create_ctype_obj(cls, init): + # may be overridden + raise TypeError("cannot instantiate opaque type %s" % (cls,)) + + def _get_own_repr(self): + return self._addr_repr(ctypes.addressof(self._blob)) + + @classmethod + def _offsetof(cls, fieldname): + return getattr(cls._ctype, fieldname).offset + + def _convert_to_address(self, BClass): + if getattr(BClass, '_BItem', None) is self.__class__: + return ctypes.addressof(self._blob) + else: + return CTypesData._convert_to_address(self, BClass) + + @classmethod + def _from_ctypes(cls, ctypes_struct_or_union): + self = cls.__new__(cls) + self._blob = ctypes_struct_or_union + return self + + @classmethod + def _to_ctypes(cls, value): + return value._blob + + def __repr__(self, c_name=None): + return CTypesData.__repr__(self, c_name or self._get_c_name(' &')) + + +class CTypesBackend(object): + + PRIMITIVE_TYPES = { + 'char': ctypes.c_char, + 'short': ctypes.c_short, + 'int': ctypes.c_int, + 'long': ctypes.c_long, + 'long long': ctypes.c_longlong, + 'signed char': ctypes.c_byte, + 'unsigned char': ctypes.c_ubyte, + 'unsigned short': ctypes.c_ushort, + 'unsigned int': ctypes.c_uint, + 'unsigned long': ctypes.c_ulong, + 'unsigned long long': ctypes.c_ulonglong, + 'float': ctypes.c_float, + 'double': ctypes.c_double, + '_Bool': ctypes.c_bool, + } + + for _name in ['unsigned long long', 'unsigned long', + 'unsigned int', 'unsigned short', 'unsigned char']: + _size = ctypes.sizeof(PRIMITIVE_TYPES[_name]) + PRIMITIVE_TYPES['uint%d_t' % (8*_size)] = PRIMITIVE_TYPES[_name] + if _size == ctypes.sizeof(ctypes.c_void_p): + PRIMITIVE_TYPES['uintptr_t'] = PRIMITIVE_TYPES[_name] + if _size == ctypes.sizeof(ctypes.c_size_t): + PRIMITIVE_TYPES['size_t'] = PRIMITIVE_TYPES[_name] + + for _name in ['long long', 'long', 'int', 'short', 'signed char']: + _size = ctypes.sizeof(PRIMITIVE_TYPES[_name]) + PRIMITIVE_TYPES['int%d_t' % (8*_size)] = PRIMITIVE_TYPES[_name] + if _size == ctypes.sizeof(ctypes.c_void_p): + PRIMITIVE_TYPES['intptr_t'] = PRIMITIVE_TYPES[_name] + PRIMITIVE_TYPES['ptrdiff_t'] = PRIMITIVE_TYPES[_name] + if _size == ctypes.sizeof(ctypes.c_size_t): + PRIMITIVE_TYPES['ssize_t'] = PRIMITIVE_TYPES[_name] + + + def __init__(self): + self.RTLD_LAZY = 0 # not supported anyway by ctypes + self.RTLD_NOW = 0 + self.RTLD_GLOBAL = ctypes.RTLD_GLOBAL + self.RTLD_LOCAL = ctypes.RTLD_LOCAL + + def set_ffi(self, ffi): + self.ffi = ffi + + def _get_types(self): + return CTypesData, CTypesType + + def load_library(self, path, flags=0): + cdll = ctypes.CDLL(path, flags) + return CTypesLibrary(self, cdll) + + def new_void_type(self): + class CTypesVoid(CTypesData): + __slots__ = [] + _reftypename = 'void &' + @staticmethod + def _from_ctypes(novalue): + return None + @staticmethod + def _to_ctypes(novalue): + if novalue is not None: + raise TypeError("None expected, got %s object" % + (type(novalue).__name__,)) + return None + CTypesVoid._fix_class() + return CTypesVoid + + def new_primitive_type(self, name): + if name == 'wchar_t': + raise NotImplementedError(name) + ctype = self.PRIMITIVE_TYPES[name] + if name == 'char': + kind = 'char' + elif name in ('float', 'double'): + kind = 'float' + else: + if name in ('signed char', 'unsigned char'): + kind = 'byte' + elif name == '_Bool': + kind = 'bool' + else: + kind = 'int' + is_signed = (ctype(-1).value == -1) + # + def _cast_source_to_int(source): + if isinstance(source, (int, long, float)): + source = int(source) + elif isinstance(source, CTypesData): + source = source._cast_to_integer() + elif isinstance(source, bytes): + source = ord(source) + elif source is None: + source = 0 + else: + raise TypeError("bad type for cast to %r: %r" % + (CTypesPrimitive, type(source).__name__)) + return source + # + kind1 = kind + class CTypesPrimitive(CTypesGenericPrimitive): + __slots__ = ['_value'] + _ctype = ctype + _reftypename = '%s &' % name + kind = kind1 + + def __init__(self, value): + self._value = value + + @staticmethod + def _create_ctype_obj(init): + if init is None: + return ctype() + return ctype(CTypesPrimitive._to_ctypes(init)) + + if kind == 'int' or kind == 'byte': + @classmethod + def _cast_from(cls, source): + source = _cast_source_to_int(source) + source = ctype(source).value # cast within range + return cls(source) + def __int__(self): + return self._value + + if kind == 'bool': + @classmethod + def _cast_from(cls, source): + if not isinstance(source, (int, long, float)): + source = _cast_source_to_int(source) + return cls(bool(source)) + def __int__(self): + return int(self._value) + + if kind == 'char': + @classmethod + def _cast_from(cls, source): + source = _cast_source_to_int(source) + source = bytechr(source & 0xFF) + return cls(source) + def __int__(self): + return ord(self._value) + + if kind == 'float': + @classmethod + def _cast_from(cls, source): + if isinstance(source, float): + pass + elif isinstance(source, CTypesGenericPrimitive): + if hasattr(source, '__float__'): + source = float(source) + else: + source = int(source) + else: + source = _cast_source_to_int(source) + source = ctype(source).value # fix precision + return cls(source) + def __int__(self): + return int(self._value) + def __float__(self): + return self._value + + _cast_to_integer = __int__ + + if kind == 'int' or kind == 'byte' or kind == 'bool': + @staticmethod + def _to_ctypes(x): + if not isinstance(x, (int, long)): + if isinstance(x, CTypesData): + x = int(x) + else: + raise TypeError("integer expected, got %s" % + type(x).__name__) + if ctype(x).value != x: + if not is_signed and x < 0: + raise OverflowError("%s: negative integer" % name) + else: + raise OverflowError("%s: integer out of bounds" + % name) + return x + + if kind == 'char': + @staticmethod + def _to_ctypes(x): + if isinstance(x, bytes) and len(x) == 1: + return x + if isinstance(x, CTypesPrimitive): # > + return x._value + raise TypeError("character expected, got %s" % + type(x).__name__) + def __nonzero__(self): + return ord(self._value) != 0 + else: + def __nonzero__(self): + return self._value != 0 + __bool__ = __nonzero__ + + if kind == 'float': + @staticmethod + def _to_ctypes(x): + if not isinstance(x, (int, long, float, CTypesData)): + raise TypeError("float expected, got %s" % + type(x).__name__) + return ctype(x).value + + @staticmethod + def _from_ctypes(value): + return getattr(value, 'value', value) + + @staticmethod + def _initialize(blob, init): + blob.value = CTypesPrimitive._to_ctypes(init) + + if kind == 'char': + def _to_string(self, maxlen): + return self._value + if kind == 'byte': + def _to_string(self, maxlen): + return chr(self._value & 0xff) + # + CTypesPrimitive._fix_class() + return CTypesPrimitive + + def new_pointer_type(self, BItem): + getbtype = self.ffi._get_cached_btype + if BItem is getbtype(model.PrimitiveType('char')): + kind = 'charp' + elif BItem in (getbtype(model.PrimitiveType('signed char')), + getbtype(model.PrimitiveType('unsigned char'))): + kind = 'bytep' + elif BItem is getbtype(model.void_type): + kind = 'voidp' + else: + kind = 'generic' + # + class CTypesPtr(CTypesGenericPtr): + __slots__ = ['_own'] + if kind == 'charp': + __slots__ += ['__as_strbuf'] + _BItem = BItem + if hasattr(BItem, '_ctype'): + _ctype = ctypes.POINTER(BItem._ctype) + _bitem_size = ctypes.sizeof(BItem._ctype) + else: + _ctype = ctypes.c_void_p + if issubclass(BItem, CTypesGenericArray): + _reftypename = BItem._get_c_name('(* &)') + else: + _reftypename = BItem._get_c_name(' * &') + + def __init__(self, init): + ctypeobj = BItem._create_ctype_obj(init) + if kind == 'charp': + self.__as_strbuf = ctypes.create_string_buffer( + ctypeobj.value + b'\x00') + self._as_ctype_ptr = ctypes.cast( + self.__as_strbuf, self._ctype) + else: + self._as_ctype_ptr = ctypes.pointer(ctypeobj) + self._address = ctypes.cast(self._as_ctype_ptr, + ctypes.c_void_p).value + self._own = True + + def __add__(self, other): + if isinstance(other, (int, long)): + return self._new_pointer_at(self._address + + other * self._bitem_size) + else: + return NotImplemented + + def __sub__(self, other): + if isinstance(other, (int, long)): + return self._new_pointer_at(self._address - + other * self._bitem_size) + elif type(self) is type(other): + return (self._address - other._address) // self._bitem_size + else: + return NotImplemented + + def __getitem__(self, index): + if getattr(self, '_own', False) and index != 0: + raise IndexError + return BItem._from_ctypes(self._as_ctype_ptr[index]) + + def __setitem__(self, index, value): + self._as_ctype_ptr[index] = BItem._to_ctypes(value) + + if kind == 'charp' or kind == 'voidp': + @classmethod + def _arg_to_ctypes(cls, *value): + if value and isinstance(value[0], bytes): + return ctypes.c_char_p(value[0]) + else: + return super(CTypesPtr, cls)._arg_to_ctypes(*value) + + if kind == 'charp' or kind == 'bytep': + def _to_string(self, maxlen): + if maxlen < 0: + maxlen = sys.maxsize + p = ctypes.cast(self._as_ctype_ptr, + ctypes.POINTER(ctypes.c_char)) + n = 0 + while n < maxlen and p[n] != b'\x00': + n += 1 + return b''.join([p[i] for i in range(n)]) + + def _get_own_repr(self): + if getattr(self, '_own', False): + return 'owning %d bytes' % ( + ctypes.sizeof(self._as_ctype_ptr.contents),) + return super(CTypesPtr, self)._get_own_repr() + # + if (BItem is self.ffi._get_cached_btype(model.void_type) or + BItem is self.ffi._get_cached_btype(model.PrimitiveType('char'))): + CTypesPtr._automatic_casts = True + # + CTypesPtr._fix_class() + return CTypesPtr + + def new_array_type(self, CTypesPtr, length): + if length is None: + brackets = ' &[]' + else: + brackets = ' &[%d]' % length + BItem = CTypesPtr._BItem + getbtype = self.ffi._get_cached_btype + if BItem is getbtype(model.PrimitiveType('char')): + kind = 'char' + elif BItem in (getbtype(model.PrimitiveType('signed char')), + getbtype(model.PrimitiveType('unsigned char'))): + kind = 'byte' + else: + kind = 'generic' + # + class CTypesArray(CTypesGenericArray): + __slots__ = ['_blob', '_own'] + if length is not None: + _ctype = BItem._ctype * length + else: + __slots__.append('_ctype') + _reftypename = BItem._get_c_name(brackets) + _declared_length = length + _CTPtr = CTypesPtr + + def __init__(self, init): + if length is None: + if isinstance(init, (int, long)): + len1 = init + init = None + elif kind == 'char' and isinstance(init, bytes): + len1 = len(init) + 1 # extra null + else: + init = tuple(init) + len1 = len(init) + self._ctype = BItem._ctype * len1 + self._blob = self._ctype() + self._own = True + if init is not None: + self._initialize(self._blob, init) + + @staticmethod + def _initialize(blob, init): + if isinstance(init, bytes): + init = [init[i:i+1] for i in range(len(init))] + else: + if isinstance(init, CTypesGenericArray): + if (len(init) != len(blob) or + not isinstance(init, CTypesArray)): + raise TypeError("length/type mismatch: %s" % (init,)) + init = tuple(init) + if len(init) > len(blob): + raise IndexError("too many initializers") + addr = ctypes.cast(blob, ctypes.c_void_p).value + PTR = ctypes.POINTER(BItem._ctype) + itemsize = ctypes.sizeof(BItem._ctype) + for i, value in enumerate(init): + p = ctypes.cast(addr + i * itemsize, PTR) + BItem._initialize(p.contents, value) + + def __len__(self): + return len(self._blob) + + def __getitem__(self, index): + if not (0 <= index < len(self._blob)): + raise IndexError + return BItem._from_ctypes(self._blob[index]) + + def __setitem__(self, index, value): + if not (0 <= index < len(self._blob)): + raise IndexError + self._blob[index] = BItem._to_ctypes(value) + + if kind == 'char' or kind == 'byte': + def _to_string(self, maxlen): + if maxlen < 0: + maxlen = len(self._blob) + p = ctypes.cast(self._blob, + ctypes.POINTER(ctypes.c_char)) + n = 0 + while n < maxlen and p[n] != b'\x00': + n += 1 + return b''.join([p[i] for i in range(n)]) + + def _get_own_repr(self): + if getattr(self, '_own', False): + return 'owning %d bytes' % (ctypes.sizeof(self._blob),) + return super(CTypesArray, self)._get_own_repr() + + def _convert_to_address(self, BClass): + if BClass in (CTypesPtr, None) or BClass._automatic_casts: + return ctypes.addressof(self._blob) + else: + return CTypesData._convert_to_address(self, BClass) + + @staticmethod + def _from_ctypes(ctypes_array): + self = CTypesArray.__new__(CTypesArray) + self._blob = ctypes_array + return self + + @staticmethod + def _arg_to_ctypes(value): + return CTypesPtr._arg_to_ctypes(value) + + def __add__(self, other): + if isinstance(other, (int, long)): + return CTypesPtr._new_pointer_at( + ctypes.addressof(self._blob) + + other * ctypes.sizeof(BItem._ctype)) + else: + return NotImplemented + + @classmethod + def _cast_from(cls, source): + raise NotImplementedError("casting to %r" % ( + cls._get_c_name(),)) + # + CTypesArray._fix_class() + return CTypesArray + + def _new_struct_or_union(self, kind, name, base_ctypes_class): + # + class struct_or_union(base_ctypes_class): + pass + struct_or_union.__name__ = '%s_%s' % (kind, name) + kind1 = kind + # + class CTypesStructOrUnion(CTypesBaseStructOrUnion): + __slots__ = ['_blob'] + _ctype = struct_or_union + _reftypename = '%s &' % (name,) + _kind = kind = kind1 + # + CTypesStructOrUnion._fix_class() + return CTypesStructOrUnion + + def new_struct_type(self, name): + return self._new_struct_or_union('struct', name, ctypes.Structure) + + def new_union_type(self, name): + return self._new_struct_or_union('union', name, ctypes.Union) + + def complete_struct_or_union(self, CTypesStructOrUnion, fields, tp, + totalsize=-1, totalalignment=-1, sflags=0, + pack=0): + if totalsize >= 0 or totalalignment >= 0: + raise NotImplementedError("the ctypes backend of CFFI does not support " + "structures completed by verify(); please " + "compile and install the _cffi_backend module.") + struct_or_union = CTypesStructOrUnion._ctype + fnames = [fname for (fname, BField, bitsize) in fields] + btypes = [BField for (fname, BField, bitsize) in fields] + bitfields = [bitsize for (fname, BField, bitsize) in fields] + # + bfield_types = {} + cfields = [] + for (fname, BField, bitsize) in fields: + if bitsize < 0: + cfields.append((fname, BField._ctype)) + bfield_types[fname] = BField + else: + cfields.append((fname, BField._ctype, bitsize)) + bfield_types[fname] = Ellipsis + if sflags & 8: + struct_or_union._pack_ = 1 + elif pack: + struct_or_union._pack_ = pack + struct_or_union._fields_ = cfields + CTypesStructOrUnion._bfield_types = bfield_types + # + @staticmethod + def _create_ctype_obj(init): + result = struct_or_union() + if init is not None: + initialize(result, init) + return result + CTypesStructOrUnion._create_ctype_obj = _create_ctype_obj + # + def initialize(blob, init): + if is_union: + if len(init) > 1: + raise ValueError("union initializer: %d items given, but " + "only one supported (use a dict if needed)" + % (len(init),)) + if not isinstance(init, dict): + if isinstance(init, (bytes, unicode)): + raise TypeError("union initializer: got a str") + init = tuple(init) + if len(init) > len(fnames): + raise ValueError("too many values for %s initializer" % + CTypesStructOrUnion._get_c_name()) + init = dict(zip(fnames, init)) + addr = ctypes.addressof(blob) + for fname, value in init.items(): + BField, bitsize = name2fieldtype[fname] + assert bitsize < 0, \ + "not implemented: initializer with bit fields" + offset = CTypesStructOrUnion._offsetof(fname) + PTR = ctypes.POINTER(BField._ctype) + p = ctypes.cast(addr + offset, PTR) + BField._initialize(p.contents, value) + is_union = CTypesStructOrUnion._kind == 'union' + name2fieldtype = dict(zip(fnames, zip(btypes, bitfields))) + # + for fname, BField, bitsize in fields: + if fname == '': + raise NotImplementedError("nested anonymous structs/unions") + if hasattr(CTypesStructOrUnion, fname): + raise ValueError("the field name %r conflicts in " + "the ctypes backend" % fname) + if bitsize < 0: + def getter(self, fname=fname, BField=BField, + offset=CTypesStructOrUnion._offsetof(fname), + PTR=ctypes.POINTER(BField._ctype)): + addr = ctypes.addressof(self._blob) + p = ctypes.cast(addr + offset, PTR) + return BField._from_ctypes(p.contents) + def setter(self, value, fname=fname, BField=BField): + setattr(self._blob, fname, BField._to_ctypes(value)) + # + if issubclass(BField, CTypesGenericArray): + setter = None + if BField._declared_length == 0: + def getter(self, fname=fname, BFieldPtr=BField._CTPtr, + offset=CTypesStructOrUnion._offsetof(fname), + PTR=ctypes.POINTER(BField._ctype)): + addr = ctypes.addressof(self._blob) + p = ctypes.cast(addr + offset, PTR) + return BFieldPtr._from_ctypes(p) + # + else: + def getter(self, fname=fname, BField=BField): + return BField._from_ctypes(getattr(self._blob, fname)) + def setter(self, value, fname=fname, BField=BField): + # xxx obscure workaround + value = BField._to_ctypes(value) + oldvalue = getattr(self._blob, fname) + setattr(self._blob, fname, value) + if value != getattr(self._blob, fname): + setattr(self._blob, fname, oldvalue) + raise OverflowError("value too large for bitfield") + setattr(CTypesStructOrUnion, fname, property(getter, setter)) + # + CTypesPtr = self.ffi._get_cached_btype(model.PointerType(tp)) + for fname in fnames: + if hasattr(CTypesPtr, fname): + raise ValueError("the field name %r conflicts in " + "the ctypes backend" % fname) + def getter(self, fname=fname): + return getattr(self[0], fname) + def setter(self, value, fname=fname): + setattr(self[0], fname, value) + setattr(CTypesPtr, fname, property(getter, setter)) + + def new_function_type(self, BArgs, BResult, has_varargs): + nameargs = [BArg._get_c_name() for BArg in BArgs] + if has_varargs: + nameargs.append('...') + nameargs = ', '.join(nameargs) + # + class CTypesFunctionPtr(CTypesGenericPtr): + __slots__ = ['_own_callback', '_name'] + _ctype = ctypes.CFUNCTYPE(getattr(BResult, '_ctype', None), + *[BArg._ctype for BArg in BArgs], + use_errno=True) + _reftypename = BResult._get_c_name('(* &)(%s)' % (nameargs,)) + + def __init__(self, init, error=None): + # create a callback to the Python callable init() + import traceback + assert not has_varargs, "varargs not supported for callbacks" + if getattr(BResult, '_ctype', None) is not None: + error = BResult._from_ctypes( + BResult._create_ctype_obj(error)) + else: + error = None + def callback(*args): + args2 = [] + for arg, BArg in zip(args, BArgs): + args2.append(BArg._from_ctypes(arg)) + try: + res2 = init(*args2) + res2 = BResult._to_ctypes(res2) + except: + traceback.print_exc() + res2 = error + if issubclass(BResult, CTypesGenericPtr): + if res2: + res2 = ctypes.cast(res2, ctypes.c_void_p).value + # .value: http://bugs.python.org/issue1574593 + else: + res2 = None + #print repr(res2) + return res2 + if issubclass(BResult, CTypesGenericPtr): + # The only pointers callbacks can return are void*s: + # http://bugs.python.org/issue5710 + callback_ctype = ctypes.CFUNCTYPE( + ctypes.c_void_p, + *[BArg._ctype for BArg in BArgs], + use_errno=True) + else: + callback_ctype = CTypesFunctionPtr._ctype + self._as_ctype_ptr = callback_ctype(callback) + self._address = ctypes.cast(self._as_ctype_ptr, + ctypes.c_void_p).value + self._own_callback = init + + @staticmethod + def _initialize(ctypes_ptr, value): + if value: + raise NotImplementedError("ctypes backend: not supported: " + "initializers for function pointers") + + def __repr__(self): + c_name = getattr(self, '_name', None) + if c_name: + i = self._reftypename.index('(* &)') + if self._reftypename[i-1] not in ' )*': + c_name = ' ' + c_name + c_name = self._reftypename.replace('(* &)', c_name) + return CTypesData.__repr__(self, c_name) + + def _get_own_repr(self): + if getattr(self, '_own_callback', None) is not None: + return 'calling %r' % (self._own_callback,) + return super(CTypesFunctionPtr, self)._get_own_repr() + + def __call__(self, *args): + if has_varargs: + assert len(args) >= len(BArgs) + extraargs = args[len(BArgs):] + args = args[:len(BArgs)] + else: + assert len(args) == len(BArgs) + ctypes_args = [] + for arg, BArg in zip(args, BArgs): + ctypes_args.append(BArg._arg_to_ctypes(arg)) + if has_varargs: + for i, arg in enumerate(extraargs): + if arg is None: + ctypes_args.append(ctypes.c_void_p(0)) # NULL + continue + if not isinstance(arg, CTypesData): + raise TypeError( + "argument %d passed in the variadic part " + "needs to be a cdata object (got %s)" % + (1 + len(BArgs) + i, type(arg).__name__)) + ctypes_args.append(arg._arg_to_ctypes(arg)) + result = self._as_ctype_ptr(*ctypes_args) + return BResult._from_ctypes(result) + # + CTypesFunctionPtr._fix_class() + return CTypesFunctionPtr + + def new_enum_type(self, name, enumerators, enumvalues, CTypesInt): + assert isinstance(name, str) + reverse_mapping = dict(zip(reversed(enumvalues), + reversed(enumerators))) + # + class CTypesEnum(CTypesInt): + __slots__ = [] + _reftypename = '%s &' % name + + def _get_own_repr(self): + value = self._value + try: + return '%d: %s' % (value, reverse_mapping[value]) + except KeyError: + return str(value) + + def _to_string(self, maxlen): + value = self._value + try: + return reverse_mapping[value] + except KeyError: + return str(value) + # + CTypesEnum._fix_class() + return CTypesEnum + + def get_errno(self): + return ctypes.get_errno() + + def set_errno(self, value): + ctypes.set_errno(value) + + def string(self, b, maxlen=-1): + return b._to_string(maxlen) + + def buffer(self, bptr, size=-1): + raise NotImplementedError("buffer() with ctypes backend") + + def sizeof(self, cdata_or_BType): + if isinstance(cdata_or_BType, CTypesData): + return cdata_or_BType._get_size_of_instance() + else: + assert issubclass(cdata_or_BType, CTypesData) + return cdata_or_BType._get_size() + + def alignof(self, BType): + assert issubclass(BType, CTypesData) + return BType._alignment() + + def newp(self, BType, source): + if not issubclass(BType, CTypesData): + raise TypeError + return BType._newp(source) + + def cast(self, BType, source): + return BType._cast_from(source) + + def callback(self, BType, source, error, onerror): + assert onerror is None # XXX not implemented + return BType(source, error) + + _weakref_cache_ref = None + + def gcp(self, cdata, destructor, size=0): + if self._weakref_cache_ref is None: + import weakref + class MyRef(weakref.ref): + def __eq__(self, other): + myref = self() + return self is other or ( + myref is not None and myref is other()) + def __ne__(self, other): + return not (self == other) + def __hash__(self): + try: + return self._hash + except AttributeError: + self._hash = hash(self()) + return self._hash + self._weakref_cache_ref = {}, MyRef + weak_cache, MyRef = self._weakref_cache_ref + + if destructor is None: + try: + del weak_cache[MyRef(cdata)] + except KeyError: + raise TypeError("Can remove destructor only on a object " + "previously returned by ffi.gc()") + return None + + def remove(k): + cdata, destructor = weak_cache.pop(k, (None, None)) + if destructor is not None: + destructor(cdata) + + new_cdata = self.cast(self.typeof(cdata), cdata) + assert new_cdata is not cdata + weak_cache[MyRef(new_cdata, remove)] = (cdata, destructor) + return new_cdata + + typeof = type + + def getcname(self, BType, replace_with): + return BType._get_c_name(replace_with) + + def typeoffsetof(self, BType, fieldname, num=0): + if isinstance(fieldname, str): + if num == 0 and issubclass(BType, CTypesGenericPtr): + BType = BType._BItem + if not issubclass(BType, CTypesBaseStructOrUnion): + raise TypeError("expected a struct or union ctype") + BField = BType._bfield_types[fieldname] + if BField is Ellipsis: + raise TypeError("not supported for bitfields") + return (BField, BType._offsetof(fieldname)) + elif isinstance(fieldname, (int, long)): + if issubclass(BType, CTypesGenericArray): + BType = BType._CTPtr + if not issubclass(BType, CTypesGenericPtr): + raise TypeError("expected an array or ptr ctype") + BItem = BType._BItem + offset = BItem._get_size() * fieldname + if offset > sys.maxsize: + raise OverflowError + return (BItem, offset) + else: + raise TypeError(type(fieldname)) + + def rawaddressof(self, BTypePtr, cdata, offset=None): + if isinstance(cdata, CTypesBaseStructOrUnion): + ptr = ctypes.pointer(type(cdata)._to_ctypes(cdata)) + elif isinstance(cdata, CTypesGenericPtr): + if offset is None or not issubclass(type(cdata)._BItem, + CTypesBaseStructOrUnion): + raise TypeError("unexpected cdata type") + ptr = type(cdata)._to_ctypes(cdata) + elif isinstance(cdata, CTypesGenericArray): + ptr = type(cdata)._to_ctypes(cdata) + else: + raise TypeError("expected a ") + if offset: + ptr = ctypes.cast( + ctypes.c_void_p( + ctypes.cast(ptr, ctypes.c_void_p).value + offset), + type(ptr)) + return BTypePtr._from_ctypes(ptr) + + +class CTypesLibrary(object): + + def __init__(self, backend, cdll): + self.backend = backend + self.cdll = cdll + + def load_function(self, BType, name): + c_func = getattr(self.cdll, name) + funcobj = BType._from_ctypes(c_func) + funcobj._name = name + return funcobj + + def read_variable(self, BType, name): + try: + ctypes_obj = BType._ctype.in_dll(self.cdll, name) + except AttributeError as e: + raise NotImplementedError(e) + return BType._from_ctypes(ctypes_obj) + + def write_variable(self, BType, name, value): + new_ctypes_obj = BType._to_ctypes(value) + ctypes_obj = BType._ctype.in_dll(self.cdll, name) + ctypes.memmove(ctypes.addressof(ctypes_obj), + ctypes.addressof(new_ctypes_obj), + ctypes.sizeof(BType._ctype)) diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/cffi_opcode.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/cffi_opcode.py new file mode 100644 index 0000000..6421df6 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/cffi_opcode.py @@ -0,0 +1,187 @@ +from .error import VerificationError + +class CffiOp(object): + def __init__(self, op, arg): + self.op = op + self.arg = arg + + def as_c_expr(self): + if self.op is None: + assert isinstance(self.arg, str) + return '(_cffi_opcode_t)(%s)' % (self.arg,) + classname = CLASS_NAME[self.op] + return '_CFFI_OP(_CFFI_OP_%s, %s)' % (classname, self.arg) + + def as_python_bytes(self): + if self.op is None and self.arg.isdigit(): + value = int(self.arg) # non-negative: '-' not in self.arg + if value >= 2**31: + raise OverflowError("cannot emit %r: limited to 2**31-1" + % (self.arg,)) + return format_four_bytes(value) + if isinstance(self.arg, str): + raise VerificationError("cannot emit to Python: %r" % (self.arg,)) + return format_four_bytes((self.arg << 8) | self.op) + + def __str__(self): + classname = CLASS_NAME.get(self.op, self.op) + return '(%s %s)' % (classname, self.arg) + +def format_four_bytes(num): + return '\\x%02X\\x%02X\\x%02X\\x%02X' % ( + (num >> 24) & 0xFF, + (num >> 16) & 0xFF, + (num >> 8) & 0xFF, + (num ) & 0xFF) + +OP_PRIMITIVE = 1 +OP_POINTER = 3 +OP_ARRAY = 5 +OP_OPEN_ARRAY = 7 +OP_STRUCT_UNION = 9 +OP_ENUM = 11 +OP_FUNCTION = 13 +OP_FUNCTION_END = 15 +OP_NOOP = 17 +OP_BITFIELD = 19 +OP_TYPENAME = 21 +OP_CPYTHON_BLTN_V = 23 # varargs +OP_CPYTHON_BLTN_N = 25 # noargs +OP_CPYTHON_BLTN_O = 27 # O (i.e. a single arg) +OP_CONSTANT = 29 +OP_CONSTANT_INT = 31 +OP_GLOBAL_VAR = 33 +OP_DLOPEN_FUNC = 35 +OP_DLOPEN_CONST = 37 +OP_GLOBAL_VAR_F = 39 +OP_EXTERN_PYTHON = 41 + +PRIM_VOID = 0 +PRIM_BOOL = 1 +PRIM_CHAR = 2 +PRIM_SCHAR = 3 +PRIM_UCHAR = 4 +PRIM_SHORT = 5 +PRIM_USHORT = 6 +PRIM_INT = 7 +PRIM_UINT = 8 +PRIM_LONG = 9 +PRIM_ULONG = 10 +PRIM_LONGLONG = 11 +PRIM_ULONGLONG = 12 +PRIM_FLOAT = 13 +PRIM_DOUBLE = 14 +PRIM_LONGDOUBLE = 15 + +PRIM_WCHAR = 16 +PRIM_INT8 = 17 +PRIM_UINT8 = 18 +PRIM_INT16 = 19 +PRIM_UINT16 = 20 +PRIM_INT32 = 21 +PRIM_UINT32 = 22 +PRIM_INT64 = 23 +PRIM_UINT64 = 24 +PRIM_INTPTR = 25 +PRIM_UINTPTR = 26 +PRIM_PTRDIFF = 27 +PRIM_SIZE = 28 +PRIM_SSIZE = 29 +PRIM_INT_LEAST8 = 30 +PRIM_UINT_LEAST8 = 31 +PRIM_INT_LEAST16 = 32 +PRIM_UINT_LEAST16 = 33 +PRIM_INT_LEAST32 = 34 +PRIM_UINT_LEAST32 = 35 +PRIM_INT_LEAST64 = 36 +PRIM_UINT_LEAST64 = 37 +PRIM_INT_FAST8 = 38 +PRIM_UINT_FAST8 = 39 +PRIM_INT_FAST16 = 40 +PRIM_UINT_FAST16 = 41 +PRIM_INT_FAST32 = 42 +PRIM_UINT_FAST32 = 43 +PRIM_INT_FAST64 = 44 +PRIM_UINT_FAST64 = 45 +PRIM_INTMAX = 46 +PRIM_UINTMAX = 47 +PRIM_FLOATCOMPLEX = 48 +PRIM_DOUBLECOMPLEX = 49 +PRIM_CHAR16 = 50 +PRIM_CHAR32 = 51 + +_NUM_PRIM = 52 +_UNKNOWN_PRIM = -1 +_UNKNOWN_FLOAT_PRIM = -2 +_UNKNOWN_LONG_DOUBLE = -3 + +_IO_FILE_STRUCT = -1 + +PRIMITIVE_TO_INDEX = { + 'char': PRIM_CHAR, + 'short': PRIM_SHORT, + 'int': PRIM_INT, + 'long': PRIM_LONG, + 'long long': PRIM_LONGLONG, + 'signed char': PRIM_SCHAR, + 'unsigned char': PRIM_UCHAR, + 'unsigned short': PRIM_USHORT, + 'unsigned int': PRIM_UINT, + 'unsigned long': PRIM_ULONG, + 'unsigned long long': PRIM_ULONGLONG, + 'float': PRIM_FLOAT, + 'double': PRIM_DOUBLE, + 'long double': PRIM_LONGDOUBLE, + '_cffi_float_complex_t': PRIM_FLOATCOMPLEX, + '_cffi_double_complex_t': PRIM_DOUBLECOMPLEX, + '_Bool': PRIM_BOOL, + 'wchar_t': PRIM_WCHAR, + 'char16_t': PRIM_CHAR16, + 'char32_t': PRIM_CHAR32, + 'int8_t': PRIM_INT8, + 'uint8_t': PRIM_UINT8, + 'int16_t': PRIM_INT16, + 'uint16_t': PRIM_UINT16, + 'int32_t': PRIM_INT32, + 'uint32_t': PRIM_UINT32, + 'int64_t': PRIM_INT64, + 'uint64_t': PRIM_UINT64, + 'intptr_t': PRIM_INTPTR, + 'uintptr_t': PRIM_UINTPTR, + 'ptrdiff_t': PRIM_PTRDIFF, + 'size_t': PRIM_SIZE, + 'ssize_t': PRIM_SSIZE, + 'int_least8_t': PRIM_INT_LEAST8, + 'uint_least8_t': PRIM_UINT_LEAST8, + 'int_least16_t': PRIM_INT_LEAST16, + 'uint_least16_t': PRIM_UINT_LEAST16, + 'int_least32_t': PRIM_INT_LEAST32, + 'uint_least32_t': PRIM_UINT_LEAST32, + 'int_least64_t': PRIM_INT_LEAST64, + 'uint_least64_t': PRIM_UINT_LEAST64, + 'int_fast8_t': PRIM_INT_FAST8, + 'uint_fast8_t': PRIM_UINT_FAST8, + 'int_fast16_t': PRIM_INT_FAST16, + 'uint_fast16_t': PRIM_UINT_FAST16, + 'int_fast32_t': PRIM_INT_FAST32, + 'uint_fast32_t': PRIM_UINT_FAST32, + 'int_fast64_t': PRIM_INT_FAST64, + 'uint_fast64_t': PRIM_UINT_FAST64, + 'intmax_t': PRIM_INTMAX, + 'uintmax_t': PRIM_UINTMAX, + } + +F_UNION = 0x01 +F_CHECK_FIELDS = 0x02 +F_PACKED = 0x04 +F_EXTERNAL = 0x08 +F_OPAQUE = 0x10 + +G_FLAGS = dict([('_CFFI_' + _key, globals()[_key]) + for _key in ['F_UNION', 'F_CHECK_FIELDS', 'F_PACKED', + 'F_EXTERNAL', 'F_OPAQUE']]) + +CLASS_NAME = {} +for _name, _value in list(globals().items()): + if _name.startswith('OP_') and isinstance(_value, int): + CLASS_NAME[_value] = _name[3:] diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/commontypes.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/commontypes.py new file mode 100644 index 0000000..d4dae35 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/commontypes.py @@ -0,0 +1,82 @@ +import sys +from . import model +from .error import FFIError + + +COMMON_TYPES = {} + +try: + # fetch "bool" and all simple Windows types + from _cffi_backend import _get_common_types + _get_common_types(COMMON_TYPES) +except ImportError: + pass + +COMMON_TYPES['FILE'] = model.unknown_type('FILE', '_IO_FILE') +COMMON_TYPES['bool'] = '_Bool' # in case we got ImportError above +COMMON_TYPES['float _Complex'] = '_cffi_float_complex_t' +COMMON_TYPES['double _Complex'] = '_cffi_double_complex_t' + +for _type in model.PrimitiveType.ALL_PRIMITIVE_TYPES: + if _type.endswith('_t'): + COMMON_TYPES[_type] = _type +del _type + +_CACHE = {} + +def resolve_common_type(parser, commontype): + try: + return _CACHE[commontype] + except KeyError: + cdecl = COMMON_TYPES.get(commontype, commontype) + if not isinstance(cdecl, str): + result, quals = cdecl, 0 # cdecl is already a BaseType + elif cdecl in model.PrimitiveType.ALL_PRIMITIVE_TYPES: + result, quals = model.PrimitiveType(cdecl), 0 + elif cdecl == 'set-unicode-needed': + raise FFIError("The Windows type %r is only available after " + "you call ffi.set_unicode()" % (commontype,)) + else: + if commontype == cdecl: + raise FFIError( + "Unsupported type: %r. Please look at " + "http://cffi.readthedocs.io/en/latest/cdef.html#ffi-cdef-limitations " + "and file an issue if you think this type should really " + "be supported." % (commontype,)) + result, quals = parser.parse_type_and_quals(cdecl) # recursive + + assert isinstance(result, model.BaseTypeByIdentity) + _CACHE[commontype] = result, quals + return result, quals + + +# ____________________________________________________________ +# extra types for Windows (most of them are in commontypes.c) + + +def win_common_types(): + return { + "UNICODE_STRING": model.StructType( + "_UNICODE_STRING", + ["Length", + "MaximumLength", + "Buffer"], + [model.PrimitiveType("unsigned short"), + model.PrimitiveType("unsigned short"), + model.PointerType(model.PrimitiveType("wchar_t"))], + [-1, -1, -1]), + "PUNICODE_STRING": "UNICODE_STRING *", + "PCUNICODE_STRING": "const UNICODE_STRING *", + + "TBYTE": "set-unicode-needed", + "TCHAR": "set-unicode-needed", + "LPCTSTR": "set-unicode-needed", + "PCTSTR": "set-unicode-needed", + "LPTSTR": "set-unicode-needed", + "PTSTR": "set-unicode-needed", + "PTBYTE": "set-unicode-needed", + "PTCHAR": "set-unicode-needed", + } + +if sys.platform == 'win32': + COMMON_TYPES.update(win_common_types()) diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/cparser.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/cparser.py new file mode 100644 index 0000000..eee83ca --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/cparser.py @@ -0,0 +1,1015 @@ +from . import model +from .commontypes import COMMON_TYPES, resolve_common_type +from .error import FFIError, CDefError +try: + from . import _pycparser as pycparser +except ImportError: + import pycparser +import weakref, re, sys + +try: + if sys.version_info < (3,): + import thread as _thread + else: + import _thread + lock = _thread.allocate_lock() +except ImportError: + lock = None + +def _workaround_for_static_import_finders(): + # Issue #392: packaging tools like cx_Freeze can not find these + # because pycparser uses exec dynamic import. This is an obscure + # workaround. This function is never called. + import pycparser.yacctab + import pycparser.lextab + +CDEF_SOURCE_STRING = "" +_r_comment = re.compile(r"/\*.*?\*/|//([^\n\\]|\\.)*?$", + re.DOTALL | re.MULTILINE) +_r_define = re.compile(r"^\s*#\s*define\s+([A-Za-z_][A-Za-z_0-9]*)" + r"\b((?:[^\n\\]|\\.)*?)$", + re.DOTALL | re.MULTILINE) +_r_line_directive = re.compile(r"^[ \t]*#[ \t]*(?:line|\d+)\b.*$", re.MULTILINE) +_r_partial_enum = re.compile(r"=\s*\.\.\.\s*[,}]|\.\.\.\s*\}") +_r_enum_dotdotdot = re.compile(r"__dotdotdot\d+__$") +_r_partial_array = re.compile(r"\[\s*\.\.\.\s*\]") +_r_words = re.compile(r"\w+|\S") +_parser_cache = None +_r_int_literal = re.compile(r"-?0?x?[0-9a-f]+[lu]*$", re.IGNORECASE) +_r_stdcall1 = re.compile(r"\b(__stdcall|WINAPI)\b") +_r_stdcall2 = re.compile(r"[(]\s*(__stdcall|WINAPI)\b") +_r_cdecl = re.compile(r"\b__cdecl\b") +_r_extern_python = re.compile(r'\bextern\s*"' + r'(Python|Python\s*\+\s*C|C\s*\+\s*Python)"\s*.') +_r_star_const_space = re.compile( # matches "* const " + r"[*]\s*((const|volatile|restrict)\b\s*)+") +_r_int_dotdotdot = re.compile(r"(\b(int|long|short|signed|unsigned|char)\s*)+" + r"\.\.\.") +_r_float_dotdotdot = re.compile(r"\b(double|float)\s*\.\.\.") + +def _get_parser(): + global _parser_cache + if _parser_cache is None: + _parser_cache = pycparser.CParser() + return _parser_cache + +def _workaround_for_old_pycparser(csource): + # Workaround for a pycparser issue (fixed between pycparser 2.10 and + # 2.14): "char*const***" gives us a wrong syntax tree, the same as + # for "char***(*const)". This means we can't tell the difference + # afterwards. But "char(*const(***))" gives us the right syntax + # tree. The issue only occurs if there are several stars in + # sequence with no parenthesis inbetween, just possibly qualifiers. + # Attempt to fix it by adding some parentheses in the source: each + # time we see "* const" or "* const *", we add an opening + # parenthesis before each star---the hard part is figuring out where + # to close them. + parts = [] + while True: + match = _r_star_const_space.search(csource) + if not match: + break + #print repr(''.join(parts)+csource), '=>', + parts.append(csource[:match.start()]) + parts.append('('); closing = ')' + parts.append(match.group()) # e.g. "* const " + endpos = match.end() + if csource.startswith('*', endpos): + parts.append('('); closing += ')' + level = 0 + i = endpos + while i < len(csource): + c = csource[i] + if c == '(': + level += 1 + elif c == ')': + if level == 0: + break + level -= 1 + elif c in ',;=': + if level == 0: + break + i += 1 + csource = csource[endpos:i] + closing + csource[i:] + #print repr(''.join(parts)+csource) + parts.append(csource) + return ''.join(parts) + +def _preprocess_extern_python(csource): + # input: `extern "Python" int foo(int);` or + # `extern "Python" { int foo(int); }` + # output: + # void __cffi_extern_python_start; + # int foo(int); + # void __cffi_extern_python_stop; + # + # input: `extern "Python+C" int foo(int);` + # output: + # void __cffi_extern_python_plus_c_start; + # int foo(int); + # void __cffi_extern_python_stop; + parts = [] + while True: + match = _r_extern_python.search(csource) + if not match: + break + endpos = match.end() - 1 + #print + #print ''.join(parts)+csource + #print '=>' + parts.append(csource[:match.start()]) + if 'C' in match.group(1): + parts.append('void __cffi_extern_python_plus_c_start; ') + else: + parts.append('void __cffi_extern_python_start; ') + if csource[endpos] == '{': + # grouping variant + closing = csource.find('}', endpos) + if closing < 0: + raise CDefError("'extern \"Python\" {': no '}' found") + if csource.find('{', endpos + 1, closing) >= 0: + raise NotImplementedError("cannot use { } inside a block " + "'extern \"Python\" { ... }'") + parts.append(csource[endpos+1:closing]) + csource = csource[closing+1:] + else: + # non-grouping variant + semicolon = csource.find(';', endpos) + if semicolon < 0: + raise CDefError("'extern \"Python\": no ';' found") + parts.append(csource[endpos:semicolon+1]) + csource = csource[semicolon+1:] + parts.append(' void __cffi_extern_python_stop;') + #print ''.join(parts)+csource + #print + parts.append(csource) + return ''.join(parts) + +def _warn_for_string_literal(csource): + if '"' not in csource: + return + for line in csource.splitlines(): + if '"' in line and not line.lstrip().startswith('#'): + import warnings + warnings.warn("String literal found in cdef() or type source. " + "String literals are ignored here, but you should " + "remove them anyway because some character sequences " + "confuse pre-parsing.") + break + +def _warn_for_non_extern_non_static_global_variable(decl): + if not decl.storage: + import warnings + warnings.warn("Global variable '%s' in cdef(): for consistency " + "with C it should have a storage class specifier " + "(usually 'extern')" % (decl.name,)) + +def _remove_line_directives(csource): + # _r_line_directive matches whole lines, without the final \n, if they + # start with '#line' with some spacing allowed, or '#NUMBER'. This + # function stores them away and replaces them with exactly the string + # '#line@N', where N is the index in the list 'line_directives'. + line_directives = [] + def replace(m): + i = len(line_directives) + line_directives.append(m.group()) + return '#line@%d' % i + csource = _r_line_directive.sub(replace, csource) + return csource, line_directives + +def _put_back_line_directives(csource, line_directives): + def replace(m): + s = m.group() + if not s.startswith('#line@'): + raise AssertionError("unexpected #line directive " + "(should have been processed and removed") + return line_directives[int(s[6:])] + return _r_line_directive.sub(replace, csource) + +def _preprocess(csource): + # First, remove the lines of the form '#line N "filename"' because + # the "filename" part could confuse the rest + csource, line_directives = _remove_line_directives(csource) + # Remove comments. NOTE: this only work because the cdef() section + # should not contain any string literals (except in line directives)! + def replace_keeping_newlines(m): + return ' ' + m.group().count('\n') * '\n' + csource = _r_comment.sub(replace_keeping_newlines, csource) + # Remove the "#define FOO x" lines + macros = {} + for match in _r_define.finditer(csource): + macroname, macrovalue = match.groups() + macrovalue = macrovalue.replace('\\\n', '').strip() + macros[macroname] = macrovalue + csource = _r_define.sub('', csource) + # + if pycparser.__version__ < '2.14': + csource = _workaround_for_old_pycparser(csource) + # + # BIG HACK: replace WINAPI or __stdcall with "volatile const". + # It doesn't make sense for the return type of a function to be + # "volatile volatile const", so we abuse it to detect __stdcall... + # Hack number 2 is that "int(volatile *fptr)();" is not valid C + # syntax, so we place the "volatile" before the opening parenthesis. + csource = _r_stdcall2.sub(' volatile volatile const(', csource) + csource = _r_stdcall1.sub(' volatile volatile const ', csource) + csource = _r_cdecl.sub(' ', csource) + # + # Replace `extern "Python"` with start/end markers + csource = _preprocess_extern_python(csource) + # + # Now there should not be any string literal left; warn if we get one + _warn_for_string_literal(csource) + # + # Replace "[...]" with "[__dotdotdotarray__]" + csource = _r_partial_array.sub('[__dotdotdotarray__]', csource) + # + # Replace "...}" with "__dotdotdotNUM__}". This construction should + # occur only at the end of enums; at the end of structs we have "...;}" + # and at the end of vararg functions "...);". Also replace "=...[,}]" + # with ",__dotdotdotNUM__[,}]": this occurs in the enums too, when + # giving an unknown value. + matches = list(_r_partial_enum.finditer(csource)) + for number, match in enumerate(reversed(matches)): + p = match.start() + if csource[p] == '=': + p2 = csource.find('...', p, match.end()) + assert p2 > p + csource = '%s,__dotdotdot%d__ %s' % (csource[:p], number, + csource[p2+3:]) + else: + assert csource[p:p+3] == '...' + csource = '%s __dotdotdot%d__ %s' % (csource[:p], number, + csource[p+3:]) + # Replace "int ..." or "unsigned long int..." with "__dotdotdotint__" + csource = _r_int_dotdotdot.sub(' __dotdotdotint__ ', csource) + # Replace "float ..." or "double..." with "__dotdotdotfloat__" + csource = _r_float_dotdotdot.sub(' __dotdotdotfloat__ ', csource) + # Replace all remaining "..." with the same name, "__dotdotdot__", + # which is declared with a typedef for the purpose of C parsing. + csource = csource.replace('...', ' __dotdotdot__ ') + # Finally, put back the line directives + csource = _put_back_line_directives(csource, line_directives) + return csource, macros + +def _common_type_names(csource): + # Look in the source for what looks like usages of types from the + # list of common types. A "usage" is approximated here as the + # appearance of the word, minus a "definition" of the type, which + # is the last word in a "typedef" statement. Approximative only + # but should be fine for all the common types. + look_for_words = set(COMMON_TYPES) + look_for_words.add(';') + look_for_words.add(',') + look_for_words.add('(') + look_for_words.add(')') + look_for_words.add('typedef') + words_used = set() + is_typedef = False + paren = 0 + previous_word = '' + for word in _r_words.findall(csource): + if word in look_for_words: + if word == ';': + if is_typedef: + words_used.discard(previous_word) + look_for_words.discard(previous_word) + is_typedef = False + elif word == 'typedef': + is_typedef = True + paren = 0 + elif word == '(': + paren += 1 + elif word == ')': + paren -= 1 + elif word == ',': + if is_typedef and paren == 0: + words_used.discard(previous_word) + look_for_words.discard(previous_word) + else: # word in COMMON_TYPES + words_used.add(word) + previous_word = word + return words_used + + +class Parser(object): + + def __init__(self): + self._declarations = {} + self._included_declarations = set() + self._anonymous_counter = 0 + self._structnode2type = weakref.WeakKeyDictionary() + self._options = {} + self._int_constants = {} + self._recomplete = [] + self._uses_new_feature = None + + def _parse(self, csource): + csource, macros = _preprocess(csource) + # XXX: for more efficiency we would need to poke into the + # internals of CParser... the following registers the + # typedefs, because their presence or absence influences the + # parsing itself (but what they are typedef'ed to plays no role) + ctn = _common_type_names(csource) + typenames = [] + for name in sorted(self._declarations): + if name.startswith('typedef '): + name = name[8:] + typenames.append(name) + ctn.discard(name) + typenames += sorted(ctn) + # + csourcelines = [] + csourcelines.append('# 1 ""') + for typename in typenames: + csourcelines.append('typedef int %s;' % typename) + csourcelines.append('typedef int __dotdotdotint__, __dotdotdotfloat__,' + ' __dotdotdot__;') + # this forces pycparser to consider the following in the file + # called from line 1 + csourcelines.append('# 1 "%s"' % (CDEF_SOURCE_STRING,)) + csourcelines.append(csource) + csourcelines.append('') # see test_missing_newline_bug + fullcsource = '\n'.join(csourcelines) + if lock is not None: + lock.acquire() # pycparser is not thread-safe... + try: + ast = _get_parser().parse(fullcsource) + except pycparser.c_parser.ParseError as e: + self.convert_pycparser_error(e, csource) + finally: + if lock is not None: + lock.release() + # csource will be used to find buggy source text + return ast, macros, csource + + def _convert_pycparser_error(self, e, csource): + # xxx look for ":NUM:" at the start of str(e) + # and interpret that as a line number. This will not work if + # the user gives explicit ``# NUM "FILE"`` directives. + line = None + msg = str(e) + match = re.match(r"%s:(\d+):" % (CDEF_SOURCE_STRING,), msg) + if match: + linenum = int(match.group(1), 10) + csourcelines = csource.splitlines() + if 1 <= linenum <= len(csourcelines): + line = csourcelines[linenum-1] + return line + + def convert_pycparser_error(self, e, csource): + line = self._convert_pycparser_error(e, csource) + + msg = str(e) + if line: + msg = 'cannot parse "%s"\n%s' % (line.strip(), msg) + else: + msg = 'parse error\n%s' % (msg,) + raise CDefError(msg) + + def parse(self, csource, override=False, packed=False, pack=None, + dllexport=False): + if packed: + if packed != True: + raise ValueError("'packed' should be False or True; use " + "'pack' to give another value") + if pack: + raise ValueError("cannot give both 'pack' and 'packed'") + pack = 1 + elif pack: + if pack & (pack - 1): + raise ValueError("'pack' must be a power of two, not %r" % + (pack,)) + else: + pack = 0 + prev_options = self._options + try: + self._options = {'override': override, + 'packed': pack, + 'dllexport': dllexport} + self._internal_parse(csource) + finally: + self._options = prev_options + + def _internal_parse(self, csource): + ast, macros, csource = self._parse(csource) + # add the macros + self._process_macros(macros) + # find the first "__dotdotdot__" and use that as a separator + # between the repeated typedefs and the real csource + iterator = iter(ast.ext) + for decl in iterator: + if decl.name == '__dotdotdot__': + break + else: + assert 0 + current_decl = None + # + try: + self._inside_extern_python = '__cffi_extern_python_stop' + for decl in iterator: + current_decl = decl + if isinstance(decl, pycparser.c_ast.Decl): + self._parse_decl(decl) + elif isinstance(decl, pycparser.c_ast.Typedef): + if not decl.name: + raise CDefError("typedef does not declare any name", + decl) + quals = 0 + if (isinstance(decl.type.type, pycparser.c_ast.IdentifierType) and + decl.type.type.names[-1].startswith('__dotdotdot')): + realtype = self._get_unknown_type(decl) + elif (isinstance(decl.type, pycparser.c_ast.PtrDecl) and + isinstance(decl.type.type, pycparser.c_ast.TypeDecl) and + isinstance(decl.type.type.type, + pycparser.c_ast.IdentifierType) and + decl.type.type.type.names[-1].startswith('__dotdotdot')): + realtype = self._get_unknown_ptr_type(decl) + else: + realtype, quals = self._get_type_and_quals( + decl.type, name=decl.name, partial_length_ok=True, + typedef_example="*(%s *)0" % (decl.name,)) + self._declare('typedef ' + decl.name, realtype, quals=quals) + elif decl.__class__.__name__ == 'Pragma': + # skip pragma, only in pycparser 2.15 + import warnings + warnings.warn( + "#pragma in cdef() are entirely ignored. " + "They should be removed for now, otherwise your " + "code might behave differently in a future version " + "of CFFI if #pragma support gets added. Note that " + "'#pragma pack' needs to be replaced with the " + "'packed' keyword argument to cdef().") + else: + raise CDefError("unexpected <%s>: this construct is valid " + "C but not valid in cdef()" % + decl.__class__.__name__, decl) + except CDefError as e: + if len(e.args) == 1: + e.args = e.args + (current_decl,) + raise + except FFIError as e: + msg = self._convert_pycparser_error(e, csource) + if msg: + e.args = (e.args[0] + "\n *** Err: %s" % msg,) + raise + + def _add_constants(self, key, val): + if key in self._int_constants: + if self._int_constants[key] == val: + return # ignore identical double declarations + raise FFIError( + "multiple declarations of constant: %s" % (key,)) + self._int_constants[key] = val + + def _add_integer_constant(self, name, int_str): + int_str = int_str.lower().rstrip("ul") + neg = int_str.startswith('-') + if neg: + int_str = int_str[1:] + # "010" is not valid oct in py3 + if (int_str.startswith("0") and int_str != '0' + and not int_str.startswith("0x")): + int_str = "0o" + int_str[1:] + pyvalue = int(int_str, 0) + if neg: + pyvalue = -pyvalue + self._add_constants(name, pyvalue) + self._declare('macro ' + name, pyvalue) + + def _process_macros(self, macros): + for key, value in macros.items(): + value = value.strip() + if _r_int_literal.match(value): + self._add_integer_constant(key, value) + elif value == '...': + self._declare('macro ' + key, value) + else: + raise CDefError( + 'only supports one of the following syntax:\n' + ' #define %s ... (literally dot-dot-dot)\n' + ' #define %s NUMBER (with NUMBER an integer' + ' constant, decimal/hex/octal)\n' + 'got:\n' + ' #define %s %s' + % (key, key, key, value)) + + def _declare_function(self, tp, quals, decl): + tp = self._get_type_pointer(tp, quals) + if self._options.get('dllexport'): + tag = 'dllexport_python ' + elif self._inside_extern_python == '__cffi_extern_python_start': + tag = 'extern_python ' + elif self._inside_extern_python == '__cffi_extern_python_plus_c_start': + tag = 'extern_python_plus_c ' + else: + tag = 'function ' + self._declare(tag + decl.name, tp) + + def _parse_decl(self, decl): + node = decl.type + if isinstance(node, pycparser.c_ast.FuncDecl): + tp, quals = self._get_type_and_quals(node, name=decl.name) + assert isinstance(tp, model.RawFunctionType) + self._declare_function(tp, quals, decl) + else: + if isinstance(node, pycparser.c_ast.Struct): + self._get_struct_union_enum_type('struct', node) + elif isinstance(node, pycparser.c_ast.Union): + self._get_struct_union_enum_type('union', node) + elif isinstance(node, pycparser.c_ast.Enum): + self._get_struct_union_enum_type('enum', node) + elif not decl.name: + raise CDefError("construct does not declare any variable", + decl) + # + if decl.name: + tp, quals = self._get_type_and_quals(node, + partial_length_ok=True) + if tp.is_raw_function: + self._declare_function(tp, quals, decl) + elif (tp.is_integer_type() and + hasattr(decl, 'init') and + hasattr(decl.init, 'value') and + _r_int_literal.match(decl.init.value)): + self._add_integer_constant(decl.name, decl.init.value) + elif (tp.is_integer_type() and + isinstance(decl.init, pycparser.c_ast.UnaryOp) and + decl.init.op == '-' and + hasattr(decl.init.expr, 'value') and + _r_int_literal.match(decl.init.expr.value)): + self._add_integer_constant(decl.name, + '-' + decl.init.expr.value) + elif (tp is model.void_type and + decl.name.startswith('__cffi_extern_python_')): + # hack: `extern "Python"` in the C source is replaced + # with "void __cffi_extern_python_start;" and + # "void __cffi_extern_python_stop;" + self._inside_extern_python = decl.name + else: + if self._inside_extern_python !='__cffi_extern_python_stop': + raise CDefError( + "cannot declare constants or " + "variables with 'extern \"Python\"'") + if (quals & model.Q_CONST) and not tp.is_array_type: + self._declare('constant ' + decl.name, tp, quals=quals) + else: + _warn_for_non_extern_non_static_global_variable(decl) + self._declare('variable ' + decl.name, tp, quals=quals) + + def parse_type(self, cdecl): + return self.parse_type_and_quals(cdecl)[0] + + def parse_type_and_quals(self, cdecl): + ast, macros = self._parse('void __dummy(\n%s\n);' % cdecl)[:2] + assert not macros + exprnode = ast.ext[-1].type.args.params[0] + if isinstance(exprnode, pycparser.c_ast.ID): + raise CDefError("unknown identifier '%s'" % (exprnode.name,)) + return self._get_type_and_quals(exprnode.type) + + def _declare(self, name, obj, included=False, quals=0): + if name in self._declarations: + prevobj, prevquals = self._declarations[name] + if prevobj is obj and prevquals == quals: + return + if not self._options.get('override'): + raise FFIError( + "multiple declarations of %s (for interactive usage, " + "try cdef(xx, override=True))" % (name,)) + assert '__dotdotdot__' not in name.split() + self._declarations[name] = (obj, quals) + if included: + self._included_declarations.add(obj) + + def _extract_quals(self, type): + quals = 0 + if isinstance(type, (pycparser.c_ast.TypeDecl, + pycparser.c_ast.PtrDecl)): + if 'const' in type.quals: + quals |= model.Q_CONST + if 'volatile' in type.quals: + quals |= model.Q_VOLATILE + if 'restrict' in type.quals: + quals |= model.Q_RESTRICT + return quals + + def _get_type_pointer(self, type, quals, declname=None): + if isinstance(type, model.RawFunctionType): + return type.as_function_pointer() + if (isinstance(type, model.StructOrUnionOrEnum) and + type.name.startswith('$') and type.name[1:].isdigit() and + type.forcename is None and declname is not None): + return model.NamedPointerType(type, declname, quals) + return model.PointerType(type, quals) + + def _get_type_and_quals(self, typenode, name=None, partial_length_ok=False, + typedef_example=None): + # first, dereference typedefs, if we have it already parsed, we're good + if (isinstance(typenode, pycparser.c_ast.TypeDecl) and + isinstance(typenode.type, pycparser.c_ast.IdentifierType) and + len(typenode.type.names) == 1 and + ('typedef ' + typenode.type.names[0]) in self._declarations): + tp, quals = self._declarations['typedef ' + typenode.type.names[0]] + quals |= self._extract_quals(typenode) + return tp, quals + # + if isinstance(typenode, pycparser.c_ast.ArrayDecl): + # array type + if typenode.dim is None: + length = None + else: + length = self._parse_constant( + typenode.dim, partial_length_ok=partial_length_ok) + # a hack: in 'typedef int foo_t[...][...];', don't use '...' as + # the length but use directly the C expression that would be + # generated by recompiler.py. This lets the typedef be used in + # many more places within recompiler.py + if typedef_example is not None: + if length == '...': + length = '_cffi_array_len(%s)' % (typedef_example,) + typedef_example = "*" + typedef_example + # + tp, quals = self._get_type_and_quals(typenode.type, + partial_length_ok=partial_length_ok, + typedef_example=typedef_example) + return model.ArrayType(tp, length), quals + # + if isinstance(typenode, pycparser.c_ast.PtrDecl): + # pointer type + itemtype, itemquals = self._get_type_and_quals(typenode.type) + tp = self._get_type_pointer(itemtype, itemquals, declname=name) + quals = self._extract_quals(typenode) + return tp, quals + # + if isinstance(typenode, pycparser.c_ast.TypeDecl): + quals = self._extract_quals(typenode) + type = typenode.type + if isinstance(type, pycparser.c_ast.IdentifierType): + # assume a primitive type. get it from .names, but reduce + # synonyms to a single chosen combination + names = list(type.names) + if names != ['signed', 'char']: # keep this unmodified + prefixes = {} + while names: + name = names[0] + if name in ('short', 'long', 'signed', 'unsigned'): + prefixes[name] = prefixes.get(name, 0) + 1 + del names[0] + else: + break + # ignore the 'signed' prefix below, and reorder the others + newnames = [] + for prefix in ('unsigned', 'short', 'long'): + for i in range(prefixes.get(prefix, 0)): + newnames.append(prefix) + if not names: + names = ['int'] # implicitly + if names == ['int']: # but kill it if 'short' or 'long' + if 'short' in prefixes or 'long' in prefixes: + names = [] + names = newnames + names + ident = ' '.join(names) + if ident == 'void': + return model.void_type, quals + if ident == '__dotdotdot__': + raise FFIError(':%d: bad usage of "..."' % + typenode.coord.line) + tp0, quals0 = resolve_common_type(self, ident) + return tp0, (quals | quals0) + # + if isinstance(type, pycparser.c_ast.Struct): + # 'struct foobar' + tp = self._get_struct_union_enum_type('struct', type, name) + return tp, quals + # + if isinstance(type, pycparser.c_ast.Union): + # 'union foobar' + tp = self._get_struct_union_enum_type('union', type, name) + return tp, quals + # + if isinstance(type, pycparser.c_ast.Enum): + # 'enum foobar' + tp = self._get_struct_union_enum_type('enum', type, name) + return tp, quals + # + if isinstance(typenode, pycparser.c_ast.FuncDecl): + # a function type + return self._parse_function_type(typenode, name), 0 + # + # nested anonymous structs or unions end up here + if isinstance(typenode, pycparser.c_ast.Struct): + return self._get_struct_union_enum_type('struct', typenode, name, + nested=True), 0 + if isinstance(typenode, pycparser.c_ast.Union): + return self._get_struct_union_enum_type('union', typenode, name, + nested=True), 0 + # + raise FFIError(":%d: bad or unsupported type declaration" % + typenode.coord.line) + + def _parse_function_type(self, typenode, funcname=None): + params = list(getattr(typenode.args, 'params', [])) + for i, arg in enumerate(params): + if not hasattr(arg, 'type'): + raise CDefError("%s arg %d: unknown type '%s'" + " (if you meant to use the old C syntax of giving" + " untyped arguments, it is not supported)" + % (funcname or 'in expression', i + 1, + getattr(arg, 'name', '?'))) + ellipsis = ( + len(params) > 0 and + isinstance(params[-1].type, pycparser.c_ast.TypeDecl) and + isinstance(params[-1].type.type, + pycparser.c_ast.IdentifierType) and + params[-1].type.type.names == ['__dotdotdot__']) + if ellipsis: + params.pop() + if not params: + raise CDefError( + "%s: a function with only '(...)' as argument" + " is not correct C" % (funcname or 'in expression')) + args = [self._as_func_arg(*self._get_type_and_quals(argdeclnode.type)) + for argdeclnode in params] + if not ellipsis and args == [model.void_type]: + args = [] + result, quals = self._get_type_and_quals(typenode.type) + # the 'quals' on the result type are ignored. HACK: we absure them + # to detect __stdcall functions: we textually replace "__stdcall" + # with "volatile volatile const" above. + abi = None + if hasattr(typenode.type, 'quals'): # else, probable syntax error anyway + if typenode.type.quals[-3:] == ['volatile', 'volatile', 'const']: + abi = '__stdcall' + return model.RawFunctionType(tuple(args), result, ellipsis, abi) + + def _as_func_arg(self, type, quals): + if isinstance(type, model.ArrayType): + return model.PointerType(type.item, quals) + elif isinstance(type, model.RawFunctionType): + return type.as_function_pointer() + else: + return type + + def _get_struct_union_enum_type(self, kind, type, name=None, nested=False): + # First, a level of caching on the exact 'type' node of the AST. + # This is obscure, but needed because pycparser "unrolls" declarations + # such as "typedef struct { } foo_t, *foo_p" and we end up with + # an AST that is not a tree, but a DAG, with the "type" node of the + # two branches foo_t and foo_p of the trees being the same node. + # It's a bit silly but detecting "DAG-ness" in the AST tree seems + # to be the only way to distinguish this case from two independent + # structs. See test_struct_with_two_usages. + try: + return self._structnode2type[type] + except KeyError: + pass + # + # Note that this must handle parsing "struct foo" any number of + # times and always return the same StructType object. Additionally, + # one of these times (not necessarily the first), the fields of + # the struct can be specified with "struct foo { ...fields... }". + # If no name is given, then we have to create a new anonymous struct + # with no caching; in this case, the fields are either specified + # right now or never. + # + force_name = name + name = type.name + # + # get the type or create it if needed + if name is None: + # 'force_name' is used to guess a more readable name for + # anonymous structs, for the common case "typedef struct { } foo". + if force_name is not None: + explicit_name = '$%s' % force_name + else: + self._anonymous_counter += 1 + explicit_name = '$%d' % self._anonymous_counter + tp = None + else: + explicit_name = name + key = '%s %s' % (kind, name) + tp, _ = self._declarations.get(key, (None, None)) + # + if tp is None: + if kind == 'struct': + tp = model.StructType(explicit_name, None, None, None) + elif kind == 'union': + tp = model.UnionType(explicit_name, None, None, None) + elif kind == 'enum': + if explicit_name == '__dotdotdot__': + raise CDefError("Enums cannot be declared with ...") + tp = self._build_enum_type(explicit_name, type.values) + else: + raise AssertionError("kind = %r" % (kind,)) + if name is not None: + self._declare(key, tp) + else: + if kind == 'enum' and type.values is not None: + raise NotImplementedError( + "enum %s: the '{}' declaration should appear on the first " + "time the enum is mentioned, not later" % explicit_name) + if not tp.forcename: + tp.force_the_name(force_name) + if tp.forcename and '$' in tp.name: + self._declare('anonymous %s' % tp.forcename, tp) + # + self._structnode2type[type] = tp + # + # enums: done here + if kind == 'enum': + return tp + # + # is there a 'type.decls'? If yes, then this is the place in the + # C sources that declare the fields. If no, then just return the + # existing type, possibly still incomplete. + if type.decls is None: + return tp + # + if tp.fldnames is not None: + raise CDefError("duplicate declaration of struct %s" % name) + fldnames = [] + fldtypes = [] + fldbitsize = [] + fldquals = [] + for decl in type.decls: + if (isinstance(decl.type, pycparser.c_ast.IdentifierType) and + ''.join(decl.type.names) == '__dotdotdot__'): + # XXX pycparser is inconsistent: 'names' should be a list + # of strings, but is sometimes just one string. Use + # str.join() as a way to cope with both. + self._make_partial(tp, nested) + continue + if decl.bitsize is None: + bitsize = -1 + else: + bitsize = self._parse_constant(decl.bitsize) + self._partial_length = False + type, fqual = self._get_type_and_quals(decl.type, + partial_length_ok=True) + if self._partial_length: + self._make_partial(tp, nested) + if isinstance(type, model.StructType) and type.partial: + self._make_partial(tp, nested) + fldnames.append(decl.name or '') + fldtypes.append(type) + fldbitsize.append(bitsize) + fldquals.append(fqual) + tp.fldnames = tuple(fldnames) + tp.fldtypes = tuple(fldtypes) + tp.fldbitsize = tuple(fldbitsize) + tp.fldquals = tuple(fldquals) + if fldbitsize != [-1] * len(fldbitsize): + if isinstance(tp, model.StructType) and tp.partial: + raise NotImplementedError("%s: using both bitfields and '...;'" + % (tp,)) + tp.packed = self._options.get('packed') + if tp.completed: # must be re-completed: it is not opaque any more + tp.completed = 0 + self._recomplete.append(tp) + return tp + + def _make_partial(self, tp, nested): + if not isinstance(tp, model.StructOrUnion): + raise CDefError("%s cannot be partial" % (tp,)) + if not tp.has_c_name() and not nested: + raise NotImplementedError("%s is partial but has no C name" %(tp,)) + tp.partial = True + + def _parse_constant(self, exprnode, partial_length_ok=False): + # for now, limited to expressions that are an immediate number + # or positive/negative number + if isinstance(exprnode, pycparser.c_ast.Constant): + s = exprnode.value + if '0' <= s[0] <= '9': + s = s.rstrip('uUlL') + try: + if s.startswith('0'): + return int(s, 8) + else: + return int(s, 10) + except ValueError: + if len(s) > 1: + if s.lower()[0:2] == '0x': + return int(s, 16) + elif s.lower()[0:2] == '0b': + return int(s, 2) + raise CDefError("invalid constant %r" % (s,)) + elif s[0] == "'" and s[-1] == "'" and ( + len(s) == 3 or (len(s) == 4 and s[1] == "\\")): + return ord(s[-2]) + else: + raise CDefError("invalid constant %r" % (s,)) + # + if (isinstance(exprnode, pycparser.c_ast.UnaryOp) and + exprnode.op == '+'): + return self._parse_constant(exprnode.expr) + # + if (isinstance(exprnode, pycparser.c_ast.UnaryOp) and + exprnode.op == '-'): + return -self._parse_constant(exprnode.expr) + # load previously defined int constant + if (isinstance(exprnode, pycparser.c_ast.ID) and + exprnode.name in self._int_constants): + return self._int_constants[exprnode.name] + # + if (isinstance(exprnode, pycparser.c_ast.ID) and + exprnode.name == '__dotdotdotarray__'): + if partial_length_ok: + self._partial_length = True + return '...' + raise FFIError(":%d: unsupported '[...]' here, cannot derive " + "the actual array length in this context" + % exprnode.coord.line) + # + if isinstance(exprnode, pycparser.c_ast.BinaryOp): + left = self._parse_constant(exprnode.left) + right = self._parse_constant(exprnode.right) + if exprnode.op == '+': + return left + right + elif exprnode.op == '-': + return left - right + elif exprnode.op == '*': + return left * right + elif exprnode.op == '/': + return self._c_div(left, right) + elif exprnode.op == '%': + return left - self._c_div(left, right) * right + elif exprnode.op == '<<': + return left << right + elif exprnode.op == '>>': + return left >> right + elif exprnode.op == '&': + return left & right + elif exprnode.op == '|': + return left | right + elif exprnode.op == '^': + return left ^ right + # + raise FFIError(":%d: unsupported expression: expected a " + "simple numeric constant" % exprnode.coord.line) + + def _c_div(self, a, b): + result = a // b + if ((a < 0) ^ (b < 0)) and (a % b) != 0: + result += 1 + return result + + def _build_enum_type(self, explicit_name, decls): + if decls is not None: + partial = False + enumerators = [] + enumvalues = [] + nextenumvalue = 0 + for enum in decls.enumerators: + if _r_enum_dotdotdot.match(enum.name): + partial = True + continue + if enum.value is not None: + nextenumvalue = self._parse_constant(enum.value) + enumerators.append(enum.name) + enumvalues.append(nextenumvalue) + self._add_constants(enum.name, nextenumvalue) + nextenumvalue += 1 + enumerators = tuple(enumerators) + enumvalues = tuple(enumvalues) + tp = model.EnumType(explicit_name, enumerators, enumvalues) + tp.partial = partial + else: # opaque enum + tp = model.EnumType(explicit_name, (), ()) + return tp + + def include(self, other): + for name, (tp, quals) in other._declarations.items(): + if name.startswith('anonymous $enum_$'): + continue # fix for test_anonymous_enum_include + kind = name.split(' ', 1)[0] + if kind in ('struct', 'union', 'enum', 'anonymous', 'typedef'): + self._declare(name, tp, included=True, quals=quals) + for k, v in other._int_constants.items(): + self._add_constants(k, v) + + def _get_unknown_type(self, decl): + typenames = decl.type.type.names + if typenames == ['__dotdotdot__']: + return model.unknown_type(decl.name) + + if typenames == ['__dotdotdotint__']: + if self._uses_new_feature is None: + self._uses_new_feature = "'typedef int... %s'" % decl.name + return model.UnknownIntegerType(decl.name) + + if typenames == ['__dotdotdotfloat__']: + # note: not for 'long double' so far + if self._uses_new_feature is None: + self._uses_new_feature = "'typedef float... %s'" % decl.name + return model.UnknownFloatType(decl.name) + + raise FFIError(':%d: unsupported usage of "..." in typedef' + % decl.coord.line) + + def _get_unknown_ptr_type(self, decl): + if decl.type.type.type.names == ['__dotdotdot__']: + return model.unknown_ptr_type(decl.name) + raise FFIError(':%d: unsupported usage of "..." in typedef' + % decl.coord.line) diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/error.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/error.py new file mode 100644 index 0000000..0a27247 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/error.py @@ -0,0 +1,31 @@ + +class FFIError(Exception): + __module__ = 'cffi' + +class CDefError(Exception): + __module__ = 'cffi' + def __str__(self): + try: + current_decl = self.args[1] + filename = current_decl.coord.file + linenum = current_decl.coord.line + prefix = '%s:%d: ' % (filename, linenum) + except (AttributeError, TypeError, IndexError): + prefix = '' + return '%s%s' % (prefix, self.args[0]) + +class VerificationError(Exception): + """ An error raised when verification fails + """ + __module__ = 'cffi' + +class VerificationMissing(Exception): + """ An error raised when incomplete structures are passed into + cdef, but no verification has been done + """ + __module__ = 'cffi' + +class PkgConfigError(Exception): + """ An error raised for missing modules in pkg-config + """ + __module__ = 'cffi' diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/ffiplatform.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/ffiplatform.py new file mode 100644 index 0000000..adca28f --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/ffiplatform.py @@ -0,0 +1,113 @@ +import sys, os +from .error import VerificationError + + +LIST_OF_FILE_NAMES = ['sources', 'include_dirs', 'library_dirs', + 'extra_objects', 'depends'] + +def get_extension(srcfilename, modname, sources=(), **kwds): + from cffi._shimmed_dist_utils import Extension + allsources = [srcfilename] + for src in sources: + allsources.append(os.path.normpath(src)) + return Extension(name=modname, sources=allsources, **kwds) + +def compile(tmpdir, ext, compiler_verbose=0, debug=None): + """Compile a C extension module using distutils.""" + + saved_environ = os.environ.copy() + try: + outputfilename = _build(tmpdir, ext, compiler_verbose, debug) + outputfilename = os.path.abspath(outputfilename) + finally: + # workaround for a distutils bugs where some env vars can + # become longer and longer every time it is used + for key, value in saved_environ.items(): + if os.environ.get(key) != value: + os.environ[key] = value + return outputfilename + +def _build(tmpdir, ext, compiler_verbose=0, debug=None): + # XXX compact but horrible :-( + from cffi._shimmed_dist_utils import Distribution, CompileError, LinkError, set_threshold, set_verbosity + + dist = Distribution({'ext_modules': [ext]}) + dist.parse_config_files() + options = dist.get_option_dict('build_ext') + if debug is None: + debug = sys.flags.debug + options['debug'] = ('ffiplatform', debug) + options['force'] = ('ffiplatform', True) + options['build_lib'] = ('ffiplatform', tmpdir) + options['build_temp'] = ('ffiplatform', tmpdir) + # + try: + old_level = set_threshold(0) or 0 + try: + set_verbosity(compiler_verbose) + dist.run_command('build_ext') + cmd_obj = dist.get_command_obj('build_ext') + [soname] = cmd_obj.get_outputs() + finally: + set_threshold(old_level) + except (CompileError, LinkError) as e: + raise VerificationError('%s: %s' % (e.__class__.__name__, e)) + # + return soname + +try: + from os.path import samefile +except ImportError: + def samefile(f1, f2): + return os.path.abspath(f1) == os.path.abspath(f2) + +def maybe_relative_path(path): + if not os.path.isabs(path): + return path # already relative + dir = path + names = [] + while True: + prevdir = dir + dir, name = os.path.split(prevdir) + if dir == prevdir or not dir: + return path # failed to make it relative + names.append(name) + try: + if samefile(dir, os.curdir): + names.reverse() + return os.path.join(*names) + except OSError: + pass + +# ____________________________________________________________ + +try: + int_or_long = (int, long) + import cStringIO +except NameError: + int_or_long = int # Python 3 + import io as cStringIO + +def _flatten(x, f): + if isinstance(x, str): + f.write('%ds%s' % (len(x), x)) + elif isinstance(x, dict): + keys = sorted(x.keys()) + f.write('%dd' % len(keys)) + for key in keys: + _flatten(key, f) + _flatten(x[key], f) + elif isinstance(x, (list, tuple)): + f.write('%dl' % len(x)) + for value in x: + _flatten(value, f) + elif isinstance(x, int_or_long): + f.write('%di' % (x,)) + else: + raise TypeError( + "the keywords to verify() contains unsupported object %r" % (x,)) + +def flatten(x): + f = cStringIO.StringIO() + _flatten(x, f) + return f.getvalue() diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/lock.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/lock.py new file mode 100644 index 0000000..db91b71 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/lock.py @@ -0,0 +1,30 @@ +import sys + +if sys.version_info < (3,): + try: + from thread import allocate_lock + except ImportError: + from dummy_thread import allocate_lock +else: + try: + from _thread import allocate_lock + except ImportError: + from _dummy_thread import allocate_lock + + +##import sys +##l1 = allocate_lock + +##class allocate_lock(object): +## def __init__(self): +## self._real = l1() +## def __enter__(self): +## for i in range(4, 0, -1): +## print sys._getframe(i).f_code +## print +## return self._real.__enter__() +## def __exit__(self, *args): +## return self._real.__exit__(*args) +## def acquire(self, f): +## assert f is False +## return self._real.acquire(f) diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/model.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/model.py new file mode 100644 index 0000000..e5f4cae --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/model.py @@ -0,0 +1,618 @@ +import types +import weakref + +from .lock import allocate_lock +from .error import CDefError, VerificationError, VerificationMissing + +# type qualifiers +Q_CONST = 0x01 +Q_RESTRICT = 0x02 +Q_VOLATILE = 0x04 + +def qualify(quals, replace_with): + if quals & Q_CONST: + replace_with = ' const ' + replace_with.lstrip() + if quals & Q_VOLATILE: + replace_with = ' volatile ' + replace_with.lstrip() + if quals & Q_RESTRICT: + # It seems that __restrict is supported by gcc and msvc. + # If you hit some different compiler, add a #define in + # _cffi_include.h for it (and in its copies, documented there) + replace_with = ' __restrict ' + replace_with.lstrip() + return replace_with + + +class BaseTypeByIdentity(object): + is_array_type = False + is_raw_function = False + + def get_c_name(self, replace_with='', context='a C file', quals=0): + result = self.c_name_with_marker + assert result.count('&') == 1 + # some logic duplication with ffi.getctype()... :-( + replace_with = replace_with.strip() + if replace_with: + if replace_with.startswith('*') and '&[' in result: + replace_with = '(%s)' % replace_with + elif not replace_with[0] in '[(': + replace_with = ' ' + replace_with + replace_with = qualify(quals, replace_with) + result = result.replace('&', replace_with) + if '$' in result: + raise VerificationError( + "cannot generate '%s' in %s: unknown type name" + % (self._get_c_name(), context)) + return result + + def _get_c_name(self): + return self.c_name_with_marker.replace('&', '') + + def has_c_name(self): + return '$' not in self._get_c_name() + + def is_integer_type(self): + return False + + def get_cached_btype(self, ffi, finishlist, can_delay=False): + try: + BType = ffi._cached_btypes[self] + except KeyError: + BType = self.build_backend_type(ffi, finishlist) + BType2 = ffi._cached_btypes.setdefault(self, BType) + assert BType2 is BType + return BType + + def __repr__(self): + return '<%s>' % (self._get_c_name(),) + + def _get_items(self): + return [(name, getattr(self, name)) for name in self._attrs_] + + +class BaseType(BaseTypeByIdentity): + + def __eq__(self, other): + return (self.__class__ == other.__class__ and + self._get_items() == other._get_items()) + + def __ne__(self, other): + return not self == other + + def __hash__(self): + return hash((self.__class__, tuple(self._get_items()))) + + +class VoidType(BaseType): + _attrs_ = () + + def __init__(self): + self.c_name_with_marker = 'void&' + + def build_backend_type(self, ffi, finishlist): + return global_cache(self, ffi, 'new_void_type') + +void_type = VoidType() + + +class BasePrimitiveType(BaseType): + def is_complex_type(self): + return False + + +class PrimitiveType(BasePrimitiveType): + _attrs_ = ('name',) + + ALL_PRIMITIVE_TYPES = { + 'char': 'c', + 'short': 'i', + 'int': 'i', + 'long': 'i', + 'long long': 'i', + 'signed char': 'i', + 'unsigned char': 'i', + 'unsigned short': 'i', + 'unsigned int': 'i', + 'unsigned long': 'i', + 'unsigned long long': 'i', + 'float': 'f', + 'double': 'f', + 'long double': 'f', + '_cffi_float_complex_t': 'j', + '_cffi_double_complex_t': 'j', + '_Bool': 'i', + # the following types are not primitive in the C sense + 'wchar_t': 'c', + 'char16_t': 'c', + 'char32_t': 'c', + 'int8_t': 'i', + 'uint8_t': 'i', + 'int16_t': 'i', + 'uint16_t': 'i', + 'int32_t': 'i', + 'uint32_t': 'i', + 'int64_t': 'i', + 'uint64_t': 'i', + 'int_least8_t': 'i', + 'uint_least8_t': 'i', + 'int_least16_t': 'i', + 'uint_least16_t': 'i', + 'int_least32_t': 'i', + 'uint_least32_t': 'i', + 'int_least64_t': 'i', + 'uint_least64_t': 'i', + 'int_fast8_t': 'i', + 'uint_fast8_t': 'i', + 'int_fast16_t': 'i', + 'uint_fast16_t': 'i', + 'int_fast32_t': 'i', + 'uint_fast32_t': 'i', + 'int_fast64_t': 'i', + 'uint_fast64_t': 'i', + 'intptr_t': 'i', + 'uintptr_t': 'i', + 'intmax_t': 'i', + 'uintmax_t': 'i', + 'ptrdiff_t': 'i', + 'size_t': 'i', + 'ssize_t': 'i', + } + + def __init__(self, name): + assert name in self.ALL_PRIMITIVE_TYPES + self.name = name + self.c_name_with_marker = name + '&' + + def is_char_type(self): + return self.ALL_PRIMITIVE_TYPES[self.name] == 'c' + def is_integer_type(self): + return self.ALL_PRIMITIVE_TYPES[self.name] == 'i' + def is_float_type(self): + return self.ALL_PRIMITIVE_TYPES[self.name] == 'f' + def is_complex_type(self): + return self.ALL_PRIMITIVE_TYPES[self.name] == 'j' + + def build_backend_type(self, ffi, finishlist): + return global_cache(self, ffi, 'new_primitive_type', self.name) + + +class UnknownIntegerType(BasePrimitiveType): + _attrs_ = ('name',) + + def __init__(self, name): + self.name = name + self.c_name_with_marker = name + '&' + + def is_integer_type(self): + return True + + def build_backend_type(self, ffi, finishlist): + raise NotImplementedError("integer type '%s' can only be used after " + "compilation" % self.name) + +class UnknownFloatType(BasePrimitiveType): + _attrs_ = ('name', ) + + def __init__(self, name): + self.name = name + self.c_name_with_marker = name + '&' + + def build_backend_type(self, ffi, finishlist): + raise NotImplementedError("float type '%s' can only be used after " + "compilation" % self.name) + + +class BaseFunctionType(BaseType): + _attrs_ = ('args', 'result', 'ellipsis', 'abi') + + def __init__(self, args, result, ellipsis, abi=None): + self.args = args + self.result = result + self.ellipsis = ellipsis + self.abi = abi + # + reprargs = [arg._get_c_name() for arg in self.args] + if self.ellipsis: + reprargs.append('...') + reprargs = reprargs or ['void'] + replace_with = self._base_pattern % (', '.join(reprargs),) + if abi is not None: + replace_with = replace_with[:1] + abi + ' ' + replace_with[1:] + self.c_name_with_marker = ( + self.result.c_name_with_marker.replace('&', replace_with)) + + +class RawFunctionType(BaseFunctionType): + # Corresponds to a C type like 'int(int)', which is the C type of + # a function, but not a pointer-to-function. The backend has no + # notion of such a type; it's used temporarily by parsing. + _base_pattern = '(&)(%s)' + is_raw_function = True + + def build_backend_type(self, ffi, finishlist): + raise CDefError("cannot render the type %r: it is a function " + "type, not a pointer-to-function type" % (self,)) + + def as_function_pointer(self): + return FunctionPtrType(self.args, self.result, self.ellipsis, self.abi) + + +class FunctionPtrType(BaseFunctionType): + _base_pattern = '(*&)(%s)' + + def build_backend_type(self, ffi, finishlist): + result = self.result.get_cached_btype(ffi, finishlist) + args = [] + for tp in self.args: + args.append(tp.get_cached_btype(ffi, finishlist)) + abi_args = () + if self.abi == "__stdcall": + if not self.ellipsis: # __stdcall ignored for variadic funcs + try: + abi_args = (ffi._backend.FFI_STDCALL,) + except AttributeError: + pass + return global_cache(self, ffi, 'new_function_type', + tuple(args), result, self.ellipsis, *abi_args) + + def as_raw_function(self): + return RawFunctionType(self.args, self.result, self.ellipsis, self.abi) + + +class PointerType(BaseType): + _attrs_ = ('totype', 'quals') + + def __init__(self, totype, quals=0): + self.totype = totype + self.quals = quals + extra = " *&" + if totype.is_array_type: + extra = "(%s)" % (extra.lstrip(),) + extra = qualify(quals, extra) + self.c_name_with_marker = totype.c_name_with_marker.replace('&', extra) + + def build_backend_type(self, ffi, finishlist): + BItem = self.totype.get_cached_btype(ffi, finishlist, can_delay=True) + return global_cache(self, ffi, 'new_pointer_type', BItem) + +voidp_type = PointerType(void_type) + +def ConstPointerType(totype): + return PointerType(totype, Q_CONST) + +const_voidp_type = ConstPointerType(void_type) + + +class NamedPointerType(PointerType): + _attrs_ = ('totype', 'name') + + def __init__(self, totype, name, quals=0): + PointerType.__init__(self, totype, quals) + self.name = name + self.c_name_with_marker = name + '&' + + +class ArrayType(BaseType): + _attrs_ = ('item', 'length') + is_array_type = True + + def __init__(self, item, length): + self.item = item + self.length = length + # + if length is None: + brackets = '&[]' + elif length == '...': + brackets = '&[/*...*/]' + else: + brackets = '&[%s]' % length + self.c_name_with_marker = ( + self.item.c_name_with_marker.replace('&', brackets)) + + def length_is_unknown(self): + return isinstance(self.length, str) + + def resolve_length(self, newlength): + return ArrayType(self.item, newlength) + + def build_backend_type(self, ffi, finishlist): + if self.length_is_unknown(): + raise CDefError("cannot render the type %r: unknown length" % + (self,)) + self.item.get_cached_btype(ffi, finishlist) # force the item BType + BPtrItem = PointerType(self.item).get_cached_btype(ffi, finishlist) + return global_cache(self, ffi, 'new_array_type', BPtrItem, self.length) + +char_array_type = ArrayType(PrimitiveType('char'), None) + + +class StructOrUnionOrEnum(BaseTypeByIdentity): + _attrs_ = ('name',) + forcename = None + + def build_c_name_with_marker(self): + name = self.forcename or '%s %s' % (self.kind, self.name) + self.c_name_with_marker = name + '&' + + def force_the_name(self, forcename): + self.forcename = forcename + self.build_c_name_with_marker() + + def get_official_name(self): + assert self.c_name_with_marker.endswith('&') + return self.c_name_with_marker[:-1] + + +class StructOrUnion(StructOrUnionOrEnum): + fixedlayout = None + completed = 0 + partial = False + packed = 0 + + def __init__(self, name, fldnames, fldtypes, fldbitsize, fldquals=None): + self.name = name + self.fldnames = fldnames + self.fldtypes = fldtypes + self.fldbitsize = fldbitsize + self.fldquals = fldquals + self.build_c_name_with_marker() + + def anonymous_struct_fields(self): + if self.fldtypes is not None: + for name, type in zip(self.fldnames, self.fldtypes): + if name == '' and isinstance(type, StructOrUnion): + yield type + + def enumfields(self, expand_anonymous_struct_union=True): + fldquals = self.fldquals + if fldquals is None: + fldquals = (0,) * len(self.fldnames) + for name, type, bitsize, quals in zip(self.fldnames, self.fldtypes, + self.fldbitsize, fldquals): + if (name == '' and isinstance(type, StructOrUnion) + and expand_anonymous_struct_union): + # nested anonymous struct/union + for result in type.enumfields(): + yield result + else: + yield (name, type, bitsize, quals) + + def force_flatten(self): + # force the struct or union to have a declaration that lists + # directly all fields returned by enumfields(), flattening + # nested anonymous structs/unions. + names = [] + types = [] + bitsizes = [] + fldquals = [] + for name, type, bitsize, quals in self.enumfields(): + names.append(name) + types.append(type) + bitsizes.append(bitsize) + fldquals.append(quals) + self.fldnames = tuple(names) + self.fldtypes = tuple(types) + self.fldbitsize = tuple(bitsizes) + self.fldquals = tuple(fldquals) + + def get_cached_btype(self, ffi, finishlist, can_delay=False): + BType = StructOrUnionOrEnum.get_cached_btype(self, ffi, finishlist, + can_delay) + if not can_delay: + self.finish_backend_type(ffi, finishlist) + return BType + + def finish_backend_type(self, ffi, finishlist): + if self.completed: + if self.completed != 2: + raise NotImplementedError("recursive structure declaration " + "for '%s'" % (self.name,)) + return + BType = ffi._cached_btypes[self] + # + self.completed = 1 + # + if self.fldtypes is None: + pass # not completing it: it's an opaque struct + # + elif self.fixedlayout is None: + fldtypes = [tp.get_cached_btype(ffi, finishlist) + for tp in self.fldtypes] + lst = list(zip(self.fldnames, fldtypes, self.fldbitsize)) + extra_flags = () + if self.packed: + if self.packed == 1: + extra_flags = (8,) # SF_PACKED + else: + extra_flags = (0, self.packed) + ffi._backend.complete_struct_or_union(BType, lst, self, + -1, -1, *extra_flags) + # + else: + fldtypes = [] + fieldofs, fieldsize, totalsize, totalalignment = self.fixedlayout + for i in range(len(self.fldnames)): + fsize = fieldsize[i] + ftype = self.fldtypes[i] + # + if isinstance(ftype, ArrayType) and ftype.length_is_unknown(): + # fix the length to match the total size + BItemType = ftype.item.get_cached_btype(ffi, finishlist) + nlen, nrest = divmod(fsize, ffi.sizeof(BItemType)) + if nrest != 0: + self._verification_error( + "field '%s.%s' has a bogus size?" % ( + self.name, self.fldnames[i] or '{}')) + ftype = ftype.resolve_length(nlen) + self.fldtypes = (self.fldtypes[:i] + (ftype,) + + self.fldtypes[i+1:]) + # + BFieldType = ftype.get_cached_btype(ffi, finishlist) + if isinstance(ftype, ArrayType) and ftype.length is None: + assert fsize == 0 + else: + bitemsize = ffi.sizeof(BFieldType) + if bitemsize != fsize: + self._verification_error( + "field '%s.%s' is declared as %d bytes, but is " + "really %d bytes" % (self.name, + self.fldnames[i] or '{}', + bitemsize, fsize)) + fldtypes.append(BFieldType) + # + lst = list(zip(self.fldnames, fldtypes, self.fldbitsize, fieldofs)) + ffi._backend.complete_struct_or_union(BType, lst, self, + totalsize, totalalignment) + self.completed = 2 + + def _verification_error(self, msg): + raise VerificationError(msg) + + def check_not_partial(self): + if self.partial and self.fixedlayout is None: + raise VerificationMissing(self._get_c_name()) + + def build_backend_type(self, ffi, finishlist): + self.check_not_partial() + finishlist.append(self) + # + return global_cache(self, ffi, 'new_%s_type' % self.kind, + self.get_official_name(), key=self) + + +class StructType(StructOrUnion): + kind = 'struct' + + +class UnionType(StructOrUnion): + kind = 'union' + + +class EnumType(StructOrUnionOrEnum): + kind = 'enum' + partial = False + partial_resolved = False + + def __init__(self, name, enumerators, enumvalues, baseinttype=None): + self.name = name + self.enumerators = enumerators + self.enumvalues = enumvalues + self.baseinttype = baseinttype + self.build_c_name_with_marker() + + def force_the_name(self, forcename): + StructOrUnionOrEnum.force_the_name(self, forcename) + if self.forcename is None: + name = self.get_official_name() + self.forcename = '$' + name.replace(' ', '_') + + def check_not_partial(self): + if self.partial and not self.partial_resolved: + raise VerificationMissing(self._get_c_name()) + + def build_backend_type(self, ffi, finishlist): + self.check_not_partial() + base_btype = self.build_baseinttype(ffi, finishlist) + return global_cache(self, ffi, 'new_enum_type', + self.get_official_name(), + self.enumerators, self.enumvalues, + base_btype, key=self) + + def build_baseinttype(self, ffi, finishlist): + if self.baseinttype is not None: + return self.baseinttype.get_cached_btype(ffi, finishlist) + # + if self.enumvalues: + smallest_value = min(self.enumvalues) + largest_value = max(self.enumvalues) + else: + import warnings + try: + # XXX! The goal is to ensure that the warnings.warn() + # will not suppress the warning. We want to get it + # several times if we reach this point several times. + __warningregistry__.clear() + except NameError: + pass + warnings.warn("%r has no values explicitly defined; " + "guessing that it is equivalent to 'unsigned int'" + % self._get_c_name()) + smallest_value = largest_value = 0 + if smallest_value < 0: # needs a signed type + sign = 1 + candidate1 = PrimitiveType("int") + candidate2 = PrimitiveType("long") + else: + sign = 0 + candidate1 = PrimitiveType("unsigned int") + candidate2 = PrimitiveType("unsigned long") + btype1 = candidate1.get_cached_btype(ffi, finishlist) + btype2 = candidate2.get_cached_btype(ffi, finishlist) + size1 = ffi.sizeof(btype1) + size2 = ffi.sizeof(btype2) + if (smallest_value >= ((-1) << (8*size1-1)) and + largest_value < (1 << (8*size1-sign))): + return btype1 + if (smallest_value >= ((-1) << (8*size2-1)) and + largest_value < (1 << (8*size2-sign))): + return btype2 + raise CDefError("%s values don't all fit into either 'long' " + "or 'unsigned long'" % self._get_c_name()) + +def unknown_type(name, structname=None): + if structname is None: + structname = '$%s' % name + tp = StructType(structname, None, None, None) + tp.force_the_name(name) + tp.origin = "unknown_type" + return tp + +def unknown_ptr_type(name, structname=None): + if structname is None: + structname = '$$%s' % name + tp = StructType(structname, None, None, None) + return NamedPointerType(tp, name) + + +global_lock = allocate_lock() +_typecache_cffi_backend = weakref.WeakValueDictionary() + +def get_typecache(backend): + # returns _typecache_cffi_backend if backend is the _cffi_backend + # module, or type(backend).__typecache if backend is an instance of + # CTypesBackend (or some FakeBackend class during tests) + if isinstance(backend, types.ModuleType): + return _typecache_cffi_backend + with global_lock: + if not hasattr(type(backend), '__typecache'): + type(backend).__typecache = weakref.WeakValueDictionary() + return type(backend).__typecache + +def global_cache(srctype, ffi, funcname, *args, **kwds): + key = kwds.pop('key', (funcname, args)) + assert not kwds + try: + return ffi._typecache[key] + except KeyError: + pass + try: + res = getattr(ffi._backend, funcname)(*args) + except NotImplementedError as e: + raise NotImplementedError("%s: %r: %s" % (funcname, srctype, e)) + # note that setdefault() on WeakValueDictionary is not atomic + # and contains a rare bug (http://bugs.python.org/issue19542); + # we have to use a lock and do it ourselves + cache = ffi._typecache + with global_lock: + res1 = cache.get(key) + if res1 is None: + cache[key] = res + return res + else: + return res1 + +def pointer_cache(ffi, BType): + return global_cache('?', ffi, 'new_pointer_type', BType) + +def attach_exception_info(e, name): + if e.args and type(e.args[0]) is str: + e.args = ('%s: %s' % (name, e.args[0]),) + e.args[1:] diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/parse_c_type.h b/PyGC/.venv/lib/python3.11/site-packages/cffi/parse_c_type.h new file mode 100644 index 0000000..84e4ef8 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/parse_c_type.h @@ -0,0 +1,181 @@ + +/* This part is from file 'cffi/parse_c_type.h'. It is copied at the + beginning of C sources generated by CFFI's ffi.set_source(). */ + +typedef void *_cffi_opcode_t; + +#define _CFFI_OP(opcode, arg) (_cffi_opcode_t)(opcode | (((uintptr_t)(arg)) << 8)) +#define _CFFI_GETOP(cffi_opcode) ((unsigned char)(uintptr_t)cffi_opcode) +#define _CFFI_GETARG(cffi_opcode) (((intptr_t)cffi_opcode) >> 8) + +#define _CFFI_OP_PRIMITIVE 1 +#define _CFFI_OP_POINTER 3 +#define _CFFI_OP_ARRAY 5 +#define _CFFI_OP_OPEN_ARRAY 7 +#define _CFFI_OP_STRUCT_UNION 9 +#define _CFFI_OP_ENUM 11 +#define _CFFI_OP_FUNCTION 13 +#define _CFFI_OP_FUNCTION_END 15 +#define _CFFI_OP_NOOP 17 +#define _CFFI_OP_BITFIELD 19 +#define _CFFI_OP_TYPENAME 21 +#define _CFFI_OP_CPYTHON_BLTN_V 23 // varargs +#define _CFFI_OP_CPYTHON_BLTN_N 25 // noargs +#define _CFFI_OP_CPYTHON_BLTN_O 27 // O (i.e. a single arg) +#define _CFFI_OP_CONSTANT 29 +#define _CFFI_OP_CONSTANT_INT 31 +#define _CFFI_OP_GLOBAL_VAR 33 +#define _CFFI_OP_DLOPEN_FUNC 35 +#define _CFFI_OP_DLOPEN_CONST 37 +#define _CFFI_OP_GLOBAL_VAR_F 39 +#define _CFFI_OP_EXTERN_PYTHON 41 + +#define _CFFI_PRIM_VOID 0 +#define _CFFI_PRIM_BOOL 1 +#define _CFFI_PRIM_CHAR 2 +#define _CFFI_PRIM_SCHAR 3 +#define _CFFI_PRIM_UCHAR 4 +#define _CFFI_PRIM_SHORT 5 +#define _CFFI_PRIM_USHORT 6 +#define _CFFI_PRIM_INT 7 +#define _CFFI_PRIM_UINT 8 +#define _CFFI_PRIM_LONG 9 +#define _CFFI_PRIM_ULONG 10 +#define _CFFI_PRIM_LONGLONG 11 +#define _CFFI_PRIM_ULONGLONG 12 +#define _CFFI_PRIM_FLOAT 13 +#define _CFFI_PRIM_DOUBLE 14 +#define _CFFI_PRIM_LONGDOUBLE 15 + +#define _CFFI_PRIM_WCHAR 16 +#define _CFFI_PRIM_INT8 17 +#define _CFFI_PRIM_UINT8 18 +#define _CFFI_PRIM_INT16 19 +#define _CFFI_PRIM_UINT16 20 +#define _CFFI_PRIM_INT32 21 +#define _CFFI_PRIM_UINT32 22 +#define _CFFI_PRIM_INT64 23 +#define _CFFI_PRIM_UINT64 24 +#define _CFFI_PRIM_INTPTR 25 +#define _CFFI_PRIM_UINTPTR 26 +#define _CFFI_PRIM_PTRDIFF 27 +#define _CFFI_PRIM_SIZE 28 +#define _CFFI_PRIM_SSIZE 29 +#define _CFFI_PRIM_INT_LEAST8 30 +#define _CFFI_PRIM_UINT_LEAST8 31 +#define _CFFI_PRIM_INT_LEAST16 32 +#define _CFFI_PRIM_UINT_LEAST16 33 +#define _CFFI_PRIM_INT_LEAST32 34 +#define _CFFI_PRIM_UINT_LEAST32 35 +#define _CFFI_PRIM_INT_LEAST64 36 +#define _CFFI_PRIM_UINT_LEAST64 37 +#define _CFFI_PRIM_INT_FAST8 38 +#define _CFFI_PRIM_UINT_FAST8 39 +#define _CFFI_PRIM_INT_FAST16 40 +#define _CFFI_PRIM_UINT_FAST16 41 +#define _CFFI_PRIM_INT_FAST32 42 +#define _CFFI_PRIM_UINT_FAST32 43 +#define _CFFI_PRIM_INT_FAST64 44 +#define _CFFI_PRIM_UINT_FAST64 45 +#define _CFFI_PRIM_INTMAX 46 +#define _CFFI_PRIM_UINTMAX 47 +#define _CFFI_PRIM_FLOATCOMPLEX 48 +#define _CFFI_PRIM_DOUBLECOMPLEX 49 +#define _CFFI_PRIM_CHAR16 50 +#define _CFFI_PRIM_CHAR32 51 + +#define _CFFI__NUM_PRIM 52 +#define _CFFI__UNKNOWN_PRIM (-1) +#define _CFFI__UNKNOWN_FLOAT_PRIM (-2) +#define _CFFI__UNKNOWN_LONG_DOUBLE (-3) + +#define _CFFI__IO_FILE_STRUCT (-1) + + +struct _cffi_global_s { + const char *name; + void *address; + _cffi_opcode_t type_op; + void *size_or_direct_fn; // OP_GLOBAL_VAR: size, or 0 if unknown + // OP_CPYTHON_BLTN_*: addr of direct function +}; + +struct _cffi_getconst_s { + unsigned long long value; + const struct _cffi_type_context_s *ctx; + int gindex; +}; + +struct _cffi_struct_union_s { + const char *name; + int type_index; // -> _cffi_types, on a OP_STRUCT_UNION + int flags; // _CFFI_F_* flags below + size_t size; + int alignment; + int first_field_index; // -> _cffi_fields array + int num_fields; +}; +#define _CFFI_F_UNION 0x01 // is a union, not a struct +#define _CFFI_F_CHECK_FIELDS 0x02 // complain if fields are not in the + // "standard layout" or if some are missing +#define _CFFI_F_PACKED 0x04 // for CHECK_FIELDS, assume a packed struct +#define _CFFI_F_EXTERNAL 0x08 // in some other ffi.include() +#define _CFFI_F_OPAQUE 0x10 // opaque + +struct _cffi_field_s { + const char *name; + size_t field_offset; + size_t field_size; + _cffi_opcode_t field_type_op; +}; + +struct _cffi_enum_s { + const char *name; + int type_index; // -> _cffi_types, on a OP_ENUM + int type_prim; // _CFFI_PRIM_xxx + const char *enumerators; // comma-delimited string +}; + +struct _cffi_typename_s { + const char *name; + int type_index; /* if opaque, points to a possibly artificial + OP_STRUCT which is itself opaque */ +}; + +struct _cffi_type_context_s { + _cffi_opcode_t *types; + const struct _cffi_global_s *globals; + const struct _cffi_field_s *fields; + const struct _cffi_struct_union_s *struct_unions; + const struct _cffi_enum_s *enums; + const struct _cffi_typename_s *typenames; + int num_globals; + int num_struct_unions; + int num_enums; + int num_typenames; + const char *const *includes; + int num_types; + int flags; /* future extension */ +}; + +struct _cffi_parse_info_s { + const struct _cffi_type_context_s *ctx; + _cffi_opcode_t *output; + unsigned int output_size; + size_t error_location; + const char *error_message; +}; + +struct _cffi_externpy_s { + const char *name; + size_t size_of_result; + void *reserved1, *reserved2; +}; + +#ifdef _CFFI_INTERNAL +static int parse_c_type(struct _cffi_parse_info_s *info, const char *input); +static int search_in_globals(const struct _cffi_type_context_s *ctx, + const char *search, size_t search_len); +static int search_in_struct_unions(const struct _cffi_type_context_s *ctx, + const char *search, size_t search_len); +#endif diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/pkgconfig.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/pkgconfig.py new file mode 100644 index 0000000..5c93f15 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/pkgconfig.py @@ -0,0 +1,121 @@ +# pkg-config, https://www.freedesktop.org/wiki/Software/pkg-config/ integration for cffi +import sys, os, subprocess + +from .error import PkgConfigError + + +def merge_flags(cfg1, cfg2): + """Merge values from cffi config flags cfg2 to cf1 + + Example: + merge_flags({"libraries": ["one"]}, {"libraries": ["two"]}) + {"libraries": ["one", "two"]} + """ + for key, value in cfg2.items(): + if key not in cfg1: + cfg1[key] = value + else: + if not isinstance(cfg1[key], list): + raise TypeError("cfg1[%r] should be a list of strings" % (key,)) + if not isinstance(value, list): + raise TypeError("cfg2[%r] should be a list of strings" % (key,)) + cfg1[key].extend(value) + return cfg1 + + +def call(libname, flag, encoding=sys.getfilesystemencoding()): + """Calls pkg-config and returns the output if found + """ + a = ["pkg-config", "--print-errors"] + a.append(flag) + a.append(libname) + try: + pc = subprocess.Popen(a, stdout=subprocess.PIPE, stderr=subprocess.PIPE) + except EnvironmentError as e: + raise PkgConfigError("cannot run pkg-config: %s" % (str(e).strip(),)) + + bout, berr = pc.communicate() + if pc.returncode != 0: + try: + berr = berr.decode(encoding) + except Exception: + pass + raise PkgConfigError(berr.strip()) + + if sys.version_info >= (3,) and not isinstance(bout, str): # Python 3.x + try: + bout = bout.decode(encoding) + except UnicodeDecodeError: + raise PkgConfigError("pkg-config %s %s returned bytes that cannot " + "be decoded with encoding %r:\n%r" % + (flag, libname, encoding, bout)) + + if os.altsep != '\\' and '\\' in bout: + raise PkgConfigError("pkg-config %s %s returned an unsupported " + "backslash-escaped output:\n%r" % + (flag, libname, bout)) + return bout + + +def flags_from_pkgconfig(libs): + r"""Return compiler line flags for FFI.set_source based on pkg-config output + + Usage + ... + ffibuilder.set_source("_foo", pkgconfig = ["libfoo", "libbar >= 1.8.3"]) + + If pkg-config is installed on build machine, then arguments include_dirs, + library_dirs, libraries, define_macros, extra_compile_args and + extra_link_args are extended with an output of pkg-config for libfoo and + libbar. + + Raises PkgConfigError in case the pkg-config call fails. + """ + + def get_include_dirs(string): + return [x[2:] for x in string.split() if x.startswith("-I")] + + def get_library_dirs(string): + return [x[2:] for x in string.split() if x.startswith("-L")] + + def get_libraries(string): + return [x[2:] for x in string.split() if x.startswith("-l")] + + # convert -Dfoo=bar to list of tuples [("foo", "bar")] expected by distutils + def get_macros(string): + def _macro(x): + x = x[2:] # drop "-D" + if '=' in x: + return tuple(x.split("=", 1)) # "-Dfoo=bar" => ("foo", "bar") + else: + return (x, None) # "-Dfoo" => ("foo", None) + return [_macro(x) for x in string.split() if x.startswith("-D")] + + def get_other_cflags(string): + return [x for x in string.split() if not x.startswith("-I") and + not x.startswith("-D")] + + def get_other_libs(string): + return [x for x in string.split() if not x.startswith("-L") and + not x.startswith("-l")] + + # return kwargs for given libname + def kwargs(libname): + fse = sys.getfilesystemencoding() + all_cflags = call(libname, "--cflags") + all_libs = call(libname, "--libs") + return { + "include_dirs": get_include_dirs(all_cflags), + "library_dirs": get_library_dirs(all_libs), + "libraries": get_libraries(all_libs), + "define_macros": get_macros(all_cflags), + "extra_compile_args": get_other_cflags(all_cflags), + "extra_link_args": get_other_libs(all_libs), + } + + # merge all arguments together + ret = {} + for libname in libs: + lib_flags = kwargs(libname) + merge_flags(ret, lib_flags) + return ret diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/recompiler.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/recompiler.py new file mode 100644 index 0000000..57781a3 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/recompiler.py @@ -0,0 +1,1598 @@ +import os, sys, io +from . import ffiplatform, model +from .error import VerificationError +from .cffi_opcode import * + +VERSION_BASE = 0x2601 +VERSION_EMBEDDED = 0x2701 +VERSION_CHAR16CHAR32 = 0x2801 + +USE_LIMITED_API = (sys.platform != 'win32' or sys.version_info < (3, 0) or + sys.version_info >= (3, 5)) + + +class GlobalExpr: + def __init__(self, name, address, type_op, size=0, check_value=0): + self.name = name + self.address = address + self.type_op = type_op + self.size = size + self.check_value = check_value + + def as_c_expr(self): + return ' { "%s", (void *)%s, %s, (void *)%s },' % ( + self.name, self.address, self.type_op.as_c_expr(), self.size) + + def as_python_expr(self): + return "b'%s%s',%d" % (self.type_op.as_python_bytes(), self.name, + self.check_value) + +class FieldExpr: + def __init__(self, name, field_offset, field_size, fbitsize, field_type_op): + self.name = name + self.field_offset = field_offset + self.field_size = field_size + self.fbitsize = fbitsize + self.field_type_op = field_type_op + + def as_c_expr(self): + spaces = " " * len(self.name) + return (' { "%s", %s,\n' % (self.name, self.field_offset) + + ' %s %s,\n' % (spaces, self.field_size) + + ' %s %s },' % (spaces, self.field_type_op.as_c_expr())) + + def as_python_expr(self): + raise NotImplementedError + + def as_field_python_expr(self): + if self.field_type_op.op == OP_NOOP: + size_expr = '' + elif self.field_type_op.op == OP_BITFIELD: + size_expr = format_four_bytes(self.fbitsize) + else: + raise NotImplementedError + return "b'%s%s%s'" % (self.field_type_op.as_python_bytes(), + size_expr, + self.name) + +class StructUnionExpr: + def __init__(self, name, type_index, flags, size, alignment, comment, + first_field_index, c_fields): + self.name = name + self.type_index = type_index + self.flags = flags + self.size = size + self.alignment = alignment + self.comment = comment + self.first_field_index = first_field_index + self.c_fields = c_fields + + def as_c_expr(self): + return (' { "%s", %d, %s,' % (self.name, self.type_index, self.flags) + + '\n %s, %s, ' % (self.size, self.alignment) + + '%d, %d ' % (self.first_field_index, len(self.c_fields)) + + ('/* %s */ ' % self.comment if self.comment else '') + + '},') + + def as_python_expr(self): + flags = eval(self.flags, G_FLAGS) + fields_expr = [c_field.as_field_python_expr() + for c_field in self.c_fields] + return "(b'%s%s%s',%s)" % ( + format_four_bytes(self.type_index), + format_four_bytes(flags), + self.name, + ','.join(fields_expr)) + +class EnumExpr: + def __init__(self, name, type_index, size, signed, allenums): + self.name = name + self.type_index = type_index + self.size = size + self.signed = signed + self.allenums = allenums + + def as_c_expr(self): + return (' { "%s", %d, _cffi_prim_int(%s, %s),\n' + ' "%s" },' % (self.name, self.type_index, + self.size, self.signed, self.allenums)) + + def as_python_expr(self): + prim_index = { + (1, 0): PRIM_UINT8, (1, 1): PRIM_INT8, + (2, 0): PRIM_UINT16, (2, 1): PRIM_INT16, + (4, 0): PRIM_UINT32, (4, 1): PRIM_INT32, + (8, 0): PRIM_UINT64, (8, 1): PRIM_INT64, + }[self.size, self.signed] + return "b'%s%s%s\\x00%s'" % (format_four_bytes(self.type_index), + format_four_bytes(prim_index), + self.name, self.allenums) + +class TypenameExpr: + def __init__(self, name, type_index): + self.name = name + self.type_index = type_index + + def as_c_expr(self): + return ' { "%s", %d },' % (self.name, self.type_index) + + def as_python_expr(self): + return "b'%s%s'" % (format_four_bytes(self.type_index), self.name) + + +# ____________________________________________________________ + + +class Recompiler: + _num_externpy = 0 + + def __init__(self, ffi, module_name, target_is_python=False): + self.ffi = ffi + self.module_name = module_name + self.target_is_python = target_is_python + self._version = VERSION_BASE + + def needs_version(self, ver): + self._version = max(self._version, ver) + + def collect_type_table(self): + self._typesdict = {} + self._generate("collecttype") + # + all_decls = sorted(self._typesdict, key=str) + # + # prepare all FUNCTION bytecode sequences first + self.cffi_types = [] + for tp in all_decls: + if tp.is_raw_function: + assert self._typesdict[tp] is None + self._typesdict[tp] = len(self.cffi_types) + self.cffi_types.append(tp) # placeholder + for tp1 in tp.args: + assert isinstance(tp1, (model.VoidType, + model.BasePrimitiveType, + model.PointerType, + model.StructOrUnionOrEnum, + model.FunctionPtrType)) + if self._typesdict[tp1] is None: + self._typesdict[tp1] = len(self.cffi_types) + self.cffi_types.append(tp1) # placeholder + self.cffi_types.append('END') # placeholder + # + # prepare all OTHER bytecode sequences + for tp in all_decls: + if not tp.is_raw_function and self._typesdict[tp] is None: + self._typesdict[tp] = len(self.cffi_types) + self.cffi_types.append(tp) # placeholder + if tp.is_array_type and tp.length is not None: + self.cffi_types.append('LEN') # placeholder + assert None not in self._typesdict.values() + # + # collect all structs and unions and enums + self._struct_unions = {} + self._enums = {} + for tp in all_decls: + if isinstance(tp, model.StructOrUnion): + self._struct_unions[tp] = None + elif isinstance(tp, model.EnumType): + self._enums[tp] = None + for i, tp in enumerate(sorted(self._struct_unions, + key=lambda tp: tp.name)): + self._struct_unions[tp] = i + for i, tp in enumerate(sorted(self._enums, + key=lambda tp: tp.name)): + self._enums[tp] = i + # + # emit all bytecode sequences now + for tp in all_decls: + method = getattr(self, '_emit_bytecode_' + tp.__class__.__name__) + method(tp, self._typesdict[tp]) + # + # consistency check + for op in self.cffi_types: + assert isinstance(op, CffiOp) + self.cffi_types = tuple(self.cffi_types) # don't change any more + + def _enum_fields(self, tp): + # When producing C, expand all anonymous struct/union fields. + # That's necessary to have C code checking the offsets of the + # individual fields contained in them. When producing Python, + # don't do it and instead write it like it is, with the + # corresponding fields having an empty name. Empty names are + # recognized at runtime when we import the generated Python + # file. + expand_anonymous_struct_union = not self.target_is_python + return tp.enumfields(expand_anonymous_struct_union) + + def _do_collect_type(self, tp): + if not isinstance(tp, model.BaseTypeByIdentity): + if isinstance(tp, tuple): + for x in tp: + self._do_collect_type(x) + return + if tp not in self._typesdict: + self._typesdict[tp] = None + if isinstance(tp, model.FunctionPtrType): + self._do_collect_type(tp.as_raw_function()) + elif isinstance(tp, model.StructOrUnion): + if tp.fldtypes is not None and ( + tp not in self.ffi._parser._included_declarations): + for name1, tp1, _, _ in self._enum_fields(tp): + self._do_collect_type(self._field_type(tp, name1, tp1)) + else: + for _, x in tp._get_items(): + self._do_collect_type(x) + + def _generate(self, step_name): + lst = self.ffi._parser._declarations.items() + for name, (tp, quals) in sorted(lst): + kind, realname = name.split(' ', 1) + try: + method = getattr(self, '_generate_cpy_%s_%s' % (kind, + step_name)) + except AttributeError: + raise VerificationError( + "not implemented in recompile(): %r" % name) + try: + self._current_quals = quals + method(tp, realname) + except Exception as e: + model.attach_exception_info(e, name) + raise + + # ---------- + + ALL_STEPS = ["global", "field", "struct_union", "enum", "typename"] + + def collect_step_tables(self): + # collect the declarations for '_cffi_globals', '_cffi_typenames', etc. + self._lsts = {} + for step_name in self.ALL_STEPS: + self._lsts[step_name] = [] + self._seen_struct_unions = set() + self._generate("ctx") + self._add_missing_struct_unions() + # + for step_name in self.ALL_STEPS: + lst = self._lsts[step_name] + if step_name != "field": + lst.sort(key=lambda entry: entry.name) + self._lsts[step_name] = tuple(lst) # don't change any more + # + # check for a possible internal inconsistency: _cffi_struct_unions + # should have been generated with exactly self._struct_unions + lst = self._lsts["struct_union"] + for tp, i in self._struct_unions.items(): + assert i < len(lst) + assert lst[i].name == tp.name + assert len(lst) == len(self._struct_unions) + # same with enums + lst = self._lsts["enum"] + for tp, i in self._enums.items(): + assert i < len(lst) + assert lst[i].name == tp.name + assert len(lst) == len(self._enums) + + # ---------- + + def _prnt(self, what=''): + self._f.write(what + '\n') + + def write_source_to_f(self, f, preamble): + if self.target_is_python: + assert preamble is None + self.write_py_source_to_f(f) + else: + assert preamble is not None + self.write_c_source_to_f(f, preamble) + + def _rel_readlines(self, filename): + g = open(os.path.join(os.path.dirname(__file__), filename), 'r') + lines = g.readlines() + g.close() + return lines + + def write_c_source_to_f(self, f, preamble): + self._f = f + prnt = self._prnt + if self.ffi._embedding is not None: + prnt('#define _CFFI_USE_EMBEDDING') + if not USE_LIMITED_API: + prnt('#define _CFFI_NO_LIMITED_API') + # + # first the '#include' (actually done by inlining the file's content) + lines = self._rel_readlines('_cffi_include.h') + i = lines.index('#include "parse_c_type.h"\n') + lines[i:i+1] = self._rel_readlines('parse_c_type.h') + prnt(''.join(lines)) + # + # if we have ffi._embedding != None, we give it here as a macro + # and include an extra file + base_module_name = self.module_name.split('.')[-1] + if self.ffi._embedding is not None: + prnt('#define _CFFI_MODULE_NAME "%s"' % (self.module_name,)) + prnt('static const char _CFFI_PYTHON_STARTUP_CODE[] = {') + self._print_string_literal_in_array(self.ffi._embedding) + prnt('0 };') + prnt('#ifdef PYPY_VERSION') + prnt('# define _CFFI_PYTHON_STARTUP_FUNC _cffi_pypyinit_%s' % ( + base_module_name,)) + prnt('#elif PY_MAJOR_VERSION >= 3') + prnt('# define _CFFI_PYTHON_STARTUP_FUNC PyInit_%s' % ( + base_module_name,)) + prnt('#else') + prnt('# define _CFFI_PYTHON_STARTUP_FUNC init%s' % ( + base_module_name,)) + prnt('#endif') + lines = self._rel_readlines('_embedding.h') + i = lines.index('#include "_cffi_errors.h"\n') + lines[i:i+1] = self._rel_readlines('_cffi_errors.h') + prnt(''.join(lines)) + self.needs_version(VERSION_EMBEDDED) + # + # then paste the C source given by the user, verbatim. + prnt('/************************************************************/') + prnt() + prnt(preamble) + prnt() + prnt('/************************************************************/') + prnt() + # + # the declaration of '_cffi_types' + prnt('static void *_cffi_types[] = {') + typeindex2type = dict([(i, tp) for (tp, i) in self._typesdict.items()]) + for i, op in enumerate(self.cffi_types): + comment = '' + if i in typeindex2type: + comment = ' // ' + typeindex2type[i]._get_c_name() + prnt('/* %2d */ %s,%s' % (i, op.as_c_expr(), comment)) + if not self.cffi_types: + prnt(' 0') + prnt('};') + prnt() + # + # call generate_cpy_xxx_decl(), for every xxx found from + # ffi._parser._declarations. This generates all the functions. + self._seen_constants = set() + self._generate("decl") + # + # the declaration of '_cffi_globals' and '_cffi_typenames' + nums = {} + for step_name in self.ALL_STEPS: + lst = self._lsts[step_name] + nums[step_name] = len(lst) + if nums[step_name] > 0: + prnt('static const struct _cffi_%s_s _cffi_%ss[] = {' % ( + step_name, step_name)) + for entry in lst: + prnt(entry.as_c_expr()) + prnt('};') + prnt() + # + # the declaration of '_cffi_includes' + if self.ffi._included_ffis: + prnt('static const char * const _cffi_includes[] = {') + for ffi_to_include in self.ffi._included_ffis: + try: + included_module_name, included_source = ( + ffi_to_include._assigned_source[:2]) + except AttributeError: + raise VerificationError( + "ffi object %r includes %r, but the latter has not " + "been prepared with set_source()" % ( + self.ffi, ffi_to_include,)) + if included_source is None: + raise VerificationError( + "not implemented yet: ffi.include() of a Python-based " + "ffi inside a C-based ffi") + prnt(' "%s",' % (included_module_name,)) + prnt(' NULL') + prnt('};') + prnt() + # + # the declaration of '_cffi_type_context' + prnt('static const struct _cffi_type_context_s _cffi_type_context = {') + prnt(' _cffi_types,') + for step_name in self.ALL_STEPS: + if nums[step_name] > 0: + prnt(' _cffi_%ss,' % step_name) + else: + prnt(' NULL, /* no %ss */' % step_name) + for step_name in self.ALL_STEPS: + if step_name != "field": + prnt(' %d, /* num_%ss */' % (nums[step_name], step_name)) + if self.ffi._included_ffis: + prnt(' _cffi_includes,') + else: + prnt(' NULL, /* no includes */') + prnt(' %d, /* num_types */' % (len(self.cffi_types),)) + flags = 0 + if self._num_externpy > 0 or self.ffi._embedding is not None: + flags |= 1 # set to mean that we use extern "Python" + prnt(' %d, /* flags */' % flags) + prnt('};') + prnt() + # + # the init function + prnt('#ifdef __GNUC__') + prnt('# pragma GCC visibility push(default) /* for -fvisibility= */') + prnt('#endif') + prnt() + prnt('#ifdef PYPY_VERSION') + prnt('PyMODINIT_FUNC') + prnt('_cffi_pypyinit_%s(const void *p[])' % (base_module_name,)) + prnt('{') + if flags & 1: + prnt(' if (((intptr_t)p[0]) >= 0x0A03) {') + prnt(' _cffi_call_python_org = ' + '(void(*)(struct _cffi_externpy_s *, char *))p[1];') + prnt(' }') + prnt(' p[0] = (const void *)0x%x;' % self._version) + prnt(' p[1] = &_cffi_type_context;') + prnt('#if PY_MAJOR_VERSION >= 3') + prnt(' return NULL;') + prnt('#endif') + prnt('}') + # on Windows, distutils insists on putting init_cffi_xyz in + # 'export_symbols', so instead of fighting it, just give up and + # give it one + prnt('# ifdef _MSC_VER') + prnt(' PyMODINIT_FUNC') + prnt('# if PY_MAJOR_VERSION >= 3') + prnt(' PyInit_%s(void) { return NULL; }' % (base_module_name,)) + prnt('# else') + prnt(' init%s(void) { }' % (base_module_name,)) + prnt('# endif') + prnt('# endif') + prnt('#elif PY_MAJOR_VERSION >= 3') + prnt('PyMODINIT_FUNC') + prnt('PyInit_%s(void)' % (base_module_name,)) + prnt('{') + prnt(' return _cffi_init("%s", 0x%x, &_cffi_type_context);' % ( + self.module_name, self._version)) + prnt('}') + prnt('#else') + prnt('PyMODINIT_FUNC') + prnt('init%s(void)' % (base_module_name,)) + prnt('{') + prnt(' _cffi_init("%s", 0x%x, &_cffi_type_context);' % ( + self.module_name, self._version)) + prnt('}') + prnt('#endif') + prnt() + prnt('#ifdef __GNUC__') + prnt('# pragma GCC visibility pop') + prnt('#endif') + self._version = None + + def _to_py(self, x): + if isinstance(x, str): + return "b'%s'" % (x,) + if isinstance(x, (list, tuple)): + rep = [self._to_py(item) for item in x] + if len(rep) == 1: + rep.append('') + return "(%s)" % (','.join(rep),) + return x.as_python_expr() # Py2: unicode unexpected; Py3: bytes unexp. + + def write_py_source_to_f(self, f): + self._f = f + prnt = self._prnt + # + # header + prnt("# auto-generated file") + prnt("import _cffi_backend") + # + # the 'import' of the included ffis + num_includes = len(self.ffi._included_ffis or ()) + for i in range(num_includes): + ffi_to_include = self.ffi._included_ffis[i] + try: + included_module_name, included_source = ( + ffi_to_include._assigned_source[:2]) + except AttributeError: + raise VerificationError( + "ffi object %r includes %r, but the latter has not " + "been prepared with set_source()" % ( + self.ffi, ffi_to_include,)) + if included_source is not None: + raise VerificationError( + "not implemented yet: ffi.include() of a C-based " + "ffi inside a Python-based ffi") + prnt('from %s import ffi as _ffi%d' % (included_module_name, i)) + prnt() + prnt("ffi = _cffi_backend.FFI('%s'," % (self.module_name,)) + prnt(" _version = 0x%x," % (self._version,)) + self._version = None + # + # the '_types' keyword argument + self.cffi_types = tuple(self.cffi_types) # don't change any more + types_lst = [op.as_python_bytes() for op in self.cffi_types] + prnt(' _types = %s,' % (self._to_py(''.join(types_lst)),)) + typeindex2type = dict([(i, tp) for (tp, i) in self._typesdict.items()]) + # + # the keyword arguments from ALL_STEPS + for step_name in self.ALL_STEPS: + lst = self._lsts[step_name] + if len(lst) > 0 and step_name != "field": + prnt(' _%ss = %s,' % (step_name, self._to_py(lst))) + # + # the '_includes' keyword argument + if num_includes > 0: + prnt(' _includes = (%s,),' % ( + ', '.join(['_ffi%d' % i for i in range(num_includes)]),)) + # + # the footer + prnt(')') + + # ---------- + + def _gettypenum(self, type): + # a KeyError here is a bug. please report it! :-) + return self._typesdict[type] + + def _convert_funcarg_to_c(self, tp, fromvar, tovar, errcode): + extraarg = '' + if isinstance(tp, model.BasePrimitiveType) and not tp.is_complex_type(): + if tp.is_integer_type() and tp.name != '_Bool': + converter = '_cffi_to_c_int' + extraarg = ', %s' % tp.name + elif isinstance(tp, model.UnknownFloatType): + # don't check with is_float_type(): it may be a 'long + # double' here, and _cffi_to_c_double would loose precision + converter = '(%s)_cffi_to_c_double' % (tp.get_c_name(''),) + else: + cname = tp.get_c_name('') + converter = '(%s)_cffi_to_c_%s' % (cname, + tp.name.replace(' ', '_')) + if cname in ('char16_t', 'char32_t'): + self.needs_version(VERSION_CHAR16CHAR32) + errvalue = '-1' + # + elif isinstance(tp, model.PointerType): + self._convert_funcarg_to_c_ptr_or_array(tp, fromvar, + tovar, errcode) + return + # + elif (isinstance(tp, model.StructOrUnionOrEnum) or + isinstance(tp, model.BasePrimitiveType)): + # a struct (not a struct pointer) as a function argument; + # or, a complex (the same code works) + self._prnt(' if (_cffi_to_c((char *)&%s, _cffi_type(%d), %s) < 0)' + % (tovar, self._gettypenum(tp), fromvar)) + self._prnt(' %s;' % errcode) + return + # + elif isinstance(tp, model.FunctionPtrType): + converter = '(%s)_cffi_to_c_pointer' % tp.get_c_name('') + extraarg = ', _cffi_type(%d)' % self._gettypenum(tp) + errvalue = 'NULL' + # + else: + raise NotImplementedError(tp) + # + self._prnt(' %s = %s(%s%s);' % (tovar, converter, fromvar, extraarg)) + self._prnt(' if (%s == (%s)%s && PyErr_Occurred())' % ( + tovar, tp.get_c_name(''), errvalue)) + self._prnt(' %s;' % errcode) + + def _extra_local_variables(self, tp, localvars, freelines): + if isinstance(tp, model.PointerType): + localvars.add('Py_ssize_t datasize') + localvars.add('struct _cffi_freeme_s *large_args_free = NULL') + freelines.add('if (large_args_free != NULL)' + ' _cffi_free_array_arguments(large_args_free);') + + def _convert_funcarg_to_c_ptr_or_array(self, tp, fromvar, tovar, errcode): + self._prnt(' datasize = _cffi_prepare_pointer_call_argument(') + self._prnt(' _cffi_type(%d), %s, (char **)&%s);' % ( + self._gettypenum(tp), fromvar, tovar)) + self._prnt(' if (datasize != 0) {') + self._prnt(' %s = ((size_t)datasize) <= 640 ? ' + '(%s)alloca((size_t)datasize) : NULL;' % ( + tovar, tp.get_c_name(''))) + self._prnt(' if (_cffi_convert_array_argument(_cffi_type(%d), %s, ' + '(char **)&%s,' % (self._gettypenum(tp), fromvar, tovar)) + self._prnt(' datasize, &large_args_free) < 0)') + self._prnt(' %s;' % errcode) + self._prnt(' }') + + def _convert_expr_from_c(self, tp, var, context): + if isinstance(tp, model.BasePrimitiveType): + if tp.is_integer_type() and tp.name != '_Bool': + return '_cffi_from_c_int(%s, %s)' % (var, tp.name) + elif isinstance(tp, model.UnknownFloatType): + return '_cffi_from_c_double(%s)' % (var,) + elif tp.name != 'long double' and not tp.is_complex_type(): + cname = tp.name.replace(' ', '_') + if cname in ('char16_t', 'char32_t'): + self.needs_version(VERSION_CHAR16CHAR32) + return '_cffi_from_c_%s(%s)' % (cname, var) + else: + return '_cffi_from_c_deref((char *)&%s, _cffi_type(%d))' % ( + var, self._gettypenum(tp)) + elif isinstance(tp, (model.PointerType, model.FunctionPtrType)): + return '_cffi_from_c_pointer((char *)%s, _cffi_type(%d))' % ( + var, self._gettypenum(tp)) + elif isinstance(tp, model.ArrayType): + return '_cffi_from_c_pointer((char *)%s, _cffi_type(%d))' % ( + var, self._gettypenum(model.PointerType(tp.item))) + elif isinstance(tp, model.StructOrUnion): + if tp.fldnames is None: + raise TypeError("'%s' is used as %s, but is opaque" % ( + tp._get_c_name(), context)) + return '_cffi_from_c_struct((char *)&%s, _cffi_type(%d))' % ( + var, self._gettypenum(tp)) + elif isinstance(tp, model.EnumType): + return '_cffi_from_c_deref((char *)&%s, _cffi_type(%d))' % ( + var, self._gettypenum(tp)) + else: + raise NotImplementedError(tp) + + # ---------- + # typedefs + + def _typedef_type(self, tp, name): + return self._global_type(tp, "(*(%s *)0)" % (name,)) + + def _generate_cpy_typedef_collecttype(self, tp, name): + self._do_collect_type(self._typedef_type(tp, name)) + + def _generate_cpy_typedef_decl(self, tp, name): + pass + + def _typedef_ctx(self, tp, name): + type_index = self._typesdict[tp] + self._lsts["typename"].append(TypenameExpr(name, type_index)) + + def _generate_cpy_typedef_ctx(self, tp, name): + tp = self._typedef_type(tp, name) + self._typedef_ctx(tp, name) + if getattr(tp, "origin", None) == "unknown_type": + self._struct_ctx(tp, tp.name, approxname=None) + elif isinstance(tp, model.NamedPointerType): + self._struct_ctx(tp.totype, tp.totype.name, approxname=tp.name, + named_ptr=tp) + + # ---------- + # function declarations + + def _generate_cpy_function_collecttype(self, tp, name): + self._do_collect_type(tp.as_raw_function()) + if tp.ellipsis and not self.target_is_python: + self._do_collect_type(tp) + + def _generate_cpy_function_decl(self, tp, name): + assert not self.target_is_python + assert isinstance(tp, model.FunctionPtrType) + if tp.ellipsis: + # cannot support vararg functions better than this: check for its + # exact type (including the fixed arguments), and build it as a + # constant function pointer (no CPython wrapper) + self._generate_cpy_constant_decl(tp, name) + return + prnt = self._prnt + numargs = len(tp.args) + if numargs == 0: + argname = 'noarg' + elif numargs == 1: + argname = 'arg0' + else: + argname = 'args' + # + # ------------------------------ + # the 'd' version of the function, only for addressof(lib, 'func') + arguments = [] + call_arguments = [] + context = 'argument of %s' % name + for i, type in enumerate(tp.args): + arguments.append(type.get_c_name(' x%d' % i, context)) + call_arguments.append('x%d' % i) + repr_arguments = ', '.join(arguments) + repr_arguments = repr_arguments or 'void' + if tp.abi: + abi = tp.abi + ' ' + else: + abi = '' + name_and_arguments = '%s_cffi_d_%s(%s)' % (abi, name, repr_arguments) + prnt('static %s' % (tp.result.get_c_name(name_and_arguments),)) + prnt('{') + call_arguments = ', '.join(call_arguments) + result_code = 'return ' + if isinstance(tp.result, model.VoidType): + result_code = '' + prnt(' %s%s(%s);' % (result_code, name, call_arguments)) + prnt('}') + # + prnt('#ifndef PYPY_VERSION') # ------------------------------ + # + prnt('static PyObject *') + prnt('_cffi_f_%s(PyObject *self, PyObject *%s)' % (name, argname)) + prnt('{') + # + context = 'argument of %s' % name + for i, type in enumerate(tp.args): + arg = type.get_c_name(' x%d' % i, context) + prnt(' %s;' % arg) + # + localvars = set() + freelines = set() + for type in tp.args: + self._extra_local_variables(type, localvars, freelines) + for decl in sorted(localvars): + prnt(' %s;' % (decl,)) + # + if not isinstance(tp.result, model.VoidType): + result_code = 'result = ' + context = 'result of %s' % name + result_decl = ' %s;' % tp.result.get_c_name(' result', context) + prnt(result_decl) + prnt(' PyObject *pyresult;') + else: + result_decl = None + result_code = '' + # + if len(tp.args) > 1: + rng = range(len(tp.args)) + for i in rng: + prnt(' PyObject *arg%d;' % i) + prnt() + prnt(' if (!PyArg_UnpackTuple(args, "%s", %d, %d, %s))' % ( + name, len(rng), len(rng), + ', '.join(['&arg%d' % i for i in rng]))) + prnt(' return NULL;') + prnt() + # + for i, type in enumerate(tp.args): + self._convert_funcarg_to_c(type, 'arg%d' % i, 'x%d' % i, + 'return NULL') + prnt() + # + prnt(' Py_BEGIN_ALLOW_THREADS') + prnt(' _cffi_restore_errno();') + call_arguments = ['x%d' % i for i in range(len(tp.args))] + call_arguments = ', '.join(call_arguments) + prnt(' { %s%s(%s); }' % (result_code, name, call_arguments)) + prnt(' _cffi_save_errno();') + prnt(' Py_END_ALLOW_THREADS') + prnt() + # + prnt(' (void)self; /* unused */') + if numargs == 0: + prnt(' (void)noarg; /* unused */') + if result_code: + prnt(' pyresult = %s;' % + self._convert_expr_from_c(tp.result, 'result', 'result type')) + for freeline in freelines: + prnt(' ' + freeline) + prnt(' return pyresult;') + else: + for freeline in freelines: + prnt(' ' + freeline) + prnt(' Py_INCREF(Py_None);') + prnt(' return Py_None;') + prnt('}') + # + prnt('#else') # ------------------------------ + # + # the PyPy version: need to replace struct/union arguments with + # pointers, and if the result is a struct/union, insert a first + # arg that is a pointer to the result. We also do that for + # complex args and return type. + def need_indirection(type): + return (isinstance(type, model.StructOrUnion) or + (isinstance(type, model.PrimitiveType) and + type.is_complex_type())) + difference = False + arguments = [] + call_arguments = [] + context = 'argument of %s' % name + for i, type in enumerate(tp.args): + indirection = '' + if need_indirection(type): + indirection = '*' + difference = True + arg = type.get_c_name(' %sx%d' % (indirection, i), context) + arguments.append(arg) + call_arguments.append('%sx%d' % (indirection, i)) + tp_result = tp.result + if need_indirection(tp_result): + context = 'result of %s' % name + arg = tp_result.get_c_name(' *result', context) + arguments.insert(0, arg) + tp_result = model.void_type + result_decl = None + result_code = '*result = ' + difference = True + if difference: + repr_arguments = ', '.join(arguments) + repr_arguments = repr_arguments or 'void' + name_and_arguments = '%s_cffi_f_%s(%s)' % (abi, name, + repr_arguments) + prnt('static %s' % (tp_result.get_c_name(name_and_arguments),)) + prnt('{') + if result_decl: + prnt(result_decl) + call_arguments = ', '.join(call_arguments) + prnt(' { %s%s(%s); }' % (result_code, name, call_arguments)) + if result_decl: + prnt(' return result;') + prnt('}') + else: + prnt('# define _cffi_f_%s _cffi_d_%s' % (name, name)) + # + prnt('#endif') # ------------------------------ + prnt() + + def _generate_cpy_function_ctx(self, tp, name): + if tp.ellipsis and not self.target_is_python: + self._generate_cpy_constant_ctx(tp, name) + return + type_index = self._typesdict[tp.as_raw_function()] + numargs = len(tp.args) + if self.target_is_python: + meth_kind = OP_DLOPEN_FUNC + elif numargs == 0: + meth_kind = OP_CPYTHON_BLTN_N # 'METH_NOARGS' + elif numargs == 1: + meth_kind = OP_CPYTHON_BLTN_O # 'METH_O' + else: + meth_kind = OP_CPYTHON_BLTN_V # 'METH_VARARGS' + self._lsts["global"].append( + GlobalExpr(name, '_cffi_f_%s' % name, + CffiOp(meth_kind, type_index), + size='_cffi_d_%s' % name)) + + # ---------- + # named structs or unions + + def _field_type(self, tp_struct, field_name, tp_field): + if isinstance(tp_field, model.ArrayType): + actual_length = tp_field.length + if actual_length == '...': + ptr_struct_name = tp_struct.get_c_name('*') + actual_length = '_cffi_array_len(((%s)0)->%s)' % ( + ptr_struct_name, field_name) + tp_item = self._field_type(tp_struct, '%s[0]' % field_name, + tp_field.item) + tp_field = model.ArrayType(tp_item, actual_length) + return tp_field + + def _struct_collecttype(self, tp): + self._do_collect_type(tp) + if self.target_is_python: + # also requires nested anon struct/unions in ABI mode, recursively + for fldtype in tp.anonymous_struct_fields(): + self._struct_collecttype(fldtype) + + def _struct_decl(self, tp, cname, approxname): + if tp.fldtypes is None: + return + prnt = self._prnt + checkfuncname = '_cffi_checkfld_%s' % (approxname,) + prnt('_CFFI_UNUSED_FN') + prnt('static void %s(%s *p)' % (checkfuncname, cname)) + prnt('{') + prnt(' /* only to generate compile-time warnings or errors */') + prnt(' (void)p;') + for fname, ftype, fbitsize, fqual in self._enum_fields(tp): + try: + if ftype.is_integer_type() or fbitsize >= 0: + # accept all integers, but complain on float or double + if fname != '': + prnt(" (void)((p->%s) | 0); /* check that '%s.%s' is " + "an integer */" % (fname, cname, fname)) + continue + # only accept exactly the type declared, except that '[]' + # is interpreted as a '*' and so will match any array length. + # (It would also match '*', but that's harder to detect...) + while (isinstance(ftype, model.ArrayType) + and (ftype.length is None or ftype.length == '...')): + ftype = ftype.item + fname = fname + '[0]' + prnt(' { %s = &p->%s; (void)tmp; }' % ( + ftype.get_c_name('*tmp', 'field %r'%fname, quals=fqual), + fname)) + except VerificationError as e: + prnt(' /* %s */' % str(e)) # cannot verify it, ignore + prnt('}') + prnt('struct _cffi_align_%s { char x; %s y; };' % (approxname, cname)) + prnt() + + def _struct_ctx(self, tp, cname, approxname, named_ptr=None): + type_index = self._typesdict[tp] + reason_for_not_expanding = None + flags = [] + if isinstance(tp, model.UnionType): + flags.append("_CFFI_F_UNION") + if tp.fldtypes is None: + flags.append("_CFFI_F_OPAQUE") + reason_for_not_expanding = "opaque" + if (tp not in self.ffi._parser._included_declarations and + (named_ptr is None or + named_ptr not in self.ffi._parser._included_declarations)): + if tp.fldtypes is None: + pass # opaque + elif tp.partial or any(tp.anonymous_struct_fields()): + pass # field layout obtained silently from the C compiler + else: + flags.append("_CFFI_F_CHECK_FIELDS") + if tp.packed: + if tp.packed > 1: + raise NotImplementedError( + "%r is declared with 'pack=%r'; only 0 or 1 are " + "supported in API mode (try to use \"...;\", which " + "does not require a 'pack' declaration)" % + (tp, tp.packed)) + flags.append("_CFFI_F_PACKED") + else: + flags.append("_CFFI_F_EXTERNAL") + reason_for_not_expanding = "external" + flags = '|'.join(flags) or '0' + c_fields = [] + if reason_for_not_expanding is None: + enumfields = list(self._enum_fields(tp)) + for fldname, fldtype, fbitsize, fqual in enumfields: + fldtype = self._field_type(tp, fldname, fldtype) + self._check_not_opaque(fldtype, + "field '%s.%s'" % (tp.name, fldname)) + # cname is None for _add_missing_struct_unions() only + op = OP_NOOP + if fbitsize >= 0: + op = OP_BITFIELD + size = '%d /* bits */' % fbitsize + elif cname is None or ( + isinstance(fldtype, model.ArrayType) and + fldtype.length is None): + size = '(size_t)-1' + else: + size = 'sizeof(((%s)0)->%s)' % ( + tp.get_c_name('*') if named_ptr is None + else named_ptr.name, + fldname) + if cname is None or fbitsize >= 0: + offset = '(size_t)-1' + elif named_ptr is not None: + offset = '((char *)&((%s)4096)->%s) - (char *)4096' % ( + named_ptr.name, fldname) + else: + offset = 'offsetof(%s, %s)' % (tp.get_c_name(''), fldname) + c_fields.append( + FieldExpr(fldname, offset, size, fbitsize, + CffiOp(op, self._typesdict[fldtype]))) + first_field_index = len(self._lsts["field"]) + self._lsts["field"].extend(c_fields) + # + if cname is None: # unknown name, for _add_missing_struct_unions + size = '(size_t)-2' + align = -2 + comment = "unnamed" + else: + if named_ptr is not None: + size = 'sizeof(*(%s)0)' % (named_ptr.name,) + align = '-1 /* unknown alignment */' + else: + size = 'sizeof(%s)' % (cname,) + align = 'offsetof(struct _cffi_align_%s, y)' % (approxname,) + comment = None + else: + size = '(size_t)-1' + align = -1 + first_field_index = -1 + comment = reason_for_not_expanding + self._lsts["struct_union"].append( + StructUnionExpr(tp.name, type_index, flags, size, align, comment, + first_field_index, c_fields)) + self._seen_struct_unions.add(tp) + + def _check_not_opaque(self, tp, location): + while isinstance(tp, model.ArrayType): + tp = tp.item + if isinstance(tp, model.StructOrUnion) and tp.fldtypes is None: + raise TypeError( + "%s is of an opaque type (not declared in cdef())" % location) + + def _add_missing_struct_unions(self): + # not very nice, but some struct declarations might be missing + # because they don't have any known C name. Check that they are + # not partial (we can't complete or verify them!) and emit them + # anonymously. + lst = list(self._struct_unions.items()) + lst.sort(key=lambda tp_order: tp_order[1]) + for tp, order in lst: + if tp not in self._seen_struct_unions: + if tp.partial: + raise NotImplementedError("internal inconsistency: %r is " + "partial but was not seen at " + "this point" % (tp,)) + if tp.name.startswith('$') and tp.name[1:].isdigit(): + approxname = tp.name[1:] + elif tp.name == '_IO_FILE' and tp.forcename == 'FILE': + approxname = 'FILE' + self._typedef_ctx(tp, 'FILE') + else: + raise NotImplementedError("internal inconsistency: %r" % + (tp,)) + self._struct_ctx(tp, None, approxname) + + def _generate_cpy_struct_collecttype(self, tp, name): + self._struct_collecttype(tp) + _generate_cpy_union_collecttype = _generate_cpy_struct_collecttype + + def _struct_names(self, tp): + cname = tp.get_c_name('') + if ' ' in cname: + return cname, cname.replace(' ', '_') + else: + return cname, '_' + cname + + def _generate_cpy_struct_decl(self, tp, name): + self._struct_decl(tp, *self._struct_names(tp)) + _generate_cpy_union_decl = _generate_cpy_struct_decl + + def _generate_cpy_struct_ctx(self, tp, name): + self._struct_ctx(tp, *self._struct_names(tp)) + _generate_cpy_union_ctx = _generate_cpy_struct_ctx + + # ---------- + # 'anonymous' declarations. These are produced for anonymous structs + # or unions; the 'name' is obtained by a typedef. + + def _generate_cpy_anonymous_collecttype(self, tp, name): + if isinstance(tp, model.EnumType): + self._generate_cpy_enum_collecttype(tp, name) + else: + self._struct_collecttype(tp) + + def _generate_cpy_anonymous_decl(self, tp, name): + if isinstance(tp, model.EnumType): + self._generate_cpy_enum_decl(tp) + else: + self._struct_decl(tp, name, 'typedef_' + name) + + def _generate_cpy_anonymous_ctx(self, tp, name): + if isinstance(tp, model.EnumType): + self._enum_ctx(tp, name) + else: + self._struct_ctx(tp, name, 'typedef_' + name) + + # ---------- + # constants, declared with "static const ..." + + def _generate_cpy_const(self, is_int, name, tp=None, category='const', + check_value=None): + if (category, name) in self._seen_constants: + raise VerificationError( + "duplicate declaration of %s '%s'" % (category, name)) + self._seen_constants.add((category, name)) + # + prnt = self._prnt + funcname = '_cffi_%s_%s' % (category, name) + if is_int: + prnt('static int %s(unsigned long long *o)' % funcname) + prnt('{') + prnt(' int n = (%s) <= 0;' % (name,)) + prnt(' *o = (unsigned long long)((%s) | 0);' + ' /* check that %s is an integer */' % (name, name)) + if check_value is not None: + if check_value > 0: + check_value = '%dU' % (check_value,) + prnt(' if (!_cffi_check_int(*o, n, %s))' % (check_value,)) + prnt(' n |= 2;') + prnt(' return n;') + prnt('}') + else: + assert check_value is None + prnt('static void %s(char *o)' % funcname) + prnt('{') + prnt(' *(%s)o = %s;' % (tp.get_c_name('*'), name)) + prnt('}') + prnt() + + def _generate_cpy_constant_collecttype(self, tp, name): + is_int = tp.is_integer_type() + if not is_int or self.target_is_python: + self._do_collect_type(tp) + + def _generate_cpy_constant_decl(self, tp, name): + is_int = tp.is_integer_type() + self._generate_cpy_const(is_int, name, tp) + + def _generate_cpy_constant_ctx(self, tp, name): + if not self.target_is_python and tp.is_integer_type(): + type_op = CffiOp(OP_CONSTANT_INT, -1) + else: + if self.target_is_python: + const_kind = OP_DLOPEN_CONST + else: + const_kind = OP_CONSTANT + type_index = self._typesdict[tp] + type_op = CffiOp(const_kind, type_index) + self._lsts["global"].append( + GlobalExpr(name, '_cffi_const_%s' % name, type_op)) + + # ---------- + # enums + + def _generate_cpy_enum_collecttype(self, tp, name): + self._do_collect_type(tp) + + def _generate_cpy_enum_decl(self, tp, name=None): + for enumerator in tp.enumerators: + self._generate_cpy_const(True, enumerator) + + def _enum_ctx(self, tp, cname): + type_index = self._typesdict[tp] + type_op = CffiOp(OP_ENUM, -1) + if self.target_is_python: + tp.check_not_partial() + for enumerator, enumvalue in zip(tp.enumerators, tp.enumvalues): + self._lsts["global"].append( + GlobalExpr(enumerator, '_cffi_const_%s' % enumerator, type_op, + check_value=enumvalue)) + # + if cname is not None and '$' not in cname and not self.target_is_python: + size = "sizeof(%s)" % cname + signed = "((%s)-1) <= 0" % cname + else: + basetp = tp.build_baseinttype(self.ffi, []) + size = self.ffi.sizeof(basetp) + signed = int(int(self.ffi.cast(basetp, -1)) < 0) + allenums = ",".join(tp.enumerators) + self._lsts["enum"].append( + EnumExpr(tp.name, type_index, size, signed, allenums)) + + def _generate_cpy_enum_ctx(self, tp, name): + self._enum_ctx(tp, tp._get_c_name()) + + # ---------- + # macros: for now only for integers + + def _generate_cpy_macro_collecttype(self, tp, name): + pass + + def _generate_cpy_macro_decl(self, tp, name): + if tp == '...': + check_value = None + else: + check_value = tp # an integer + self._generate_cpy_const(True, name, check_value=check_value) + + def _generate_cpy_macro_ctx(self, tp, name): + if tp == '...': + if self.target_is_python: + raise VerificationError( + "cannot use the syntax '...' in '#define %s ...' when " + "using the ABI mode" % (name,)) + check_value = None + else: + check_value = tp # an integer + type_op = CffiOp(OP_CONSTANT_INT, -1) + self._lsts["global"].append( + GlobalExpr(name, '_cffi_const_%s' % name, type_op, + check_value=check_value)) + + # ---------- + # global variables + + def _global_type(self, tp, global_name): + if isinstance(tp, model.ArrayType): + actual_length = tp.length + if actual_length == '...': + actual_length = '_cffi_array_len(%s)' % (global_name,) + tp_item = self._global_type(tp.item, '%s[0]' % global_name) + tp = model.ArrayType(tp_item, actual_length) + return tp + + def _generate_cpy_variable_collecttype(self, tp, name): + self._do_collect_type(self._global_type(tp, name)) + + def _generate_cpy_variable_decl(self, tp, name): + prnt = self._prnt + tp = self._global_type(tp, name) + if isinstance(tp, model.ArrayType) and tp.length is None: + tp = tp.item + ampersand = '' + else: + ampersand = '&' + # This code assumes that casts from "tp *" to "void *" is a + # no-op, i.e. a function that returns a "tp *" can be called + # as if it returned a "void *". This should be generally true + # on any modern machine. The only exception to that rule (on + # uncommon architectures, and as far as I can tell) might be + # if 'tp' were a function type, but that is not possible here. + # (If 'tp' is a function _pointer_ type, then casts from "fn_t + # **" to "void *" are again no-ops, as far as I can tell.) + decl = '*_cffi_var_%s(void)' % (name,) + prnt('static ' + tp.get_c_name(decl, quals=self._current_quals)) + prnt('{') + prnt(' return %s(%s);' % (ampersand, name)) + prnt('}') + prnt() + + def _generate_cpy_variable_ctx(self, tp, name): + tp = self._global_type(tp, name) + type_index = self._typesdict[tp] + if self.target_is_python: + op = OP_GLOBAL_VAR + else: + op = OP_GLOBAL_VAR_F + self._lsts["global"].append( + GlobalExpr(name, '_cffi_var_%s' % name, CffiOp(op, type_index))) + + # ---------- + # extern "Python" + + def _generate_cpy_extern_python_collecttype(self, tp, name): + assert isinstance(tp, model.FunctionPtrType) + self._do_collect_type(tp) + _generate_cpy_dllexport_python_collecttype = \ + _generate_cpy_extern_python_plus_c_collecttype = \ + _generate_cpy_extern_python_collecttype + + def _extern_python_decl(self, tp, name, tag_and_space): + prnt = self._prnt + if isinstance(tp.result, model.VoidType): + size_of_result = '0' + else: + context = 'result of %s' % name + size_of_result = '(int)sizeof(%s)' % ( + tp.result.get_c_name('', context),) + prnt('static struct _cffi_externpy_s _cffi_externpy__%s =' % name) + prnt(' { "%s.%s", %s, 0, 0 };' % ( + self.module_name, name, size_of_result)) + prnt() + # + arguments = [] + context = 'argument of %s' % name + for i, type in enumerate(tp.args): + arg = type.get_c_name(' a%d' % i, context) + arguments.append(arg) + # + repr_arguments = ', '.join(arguments) + repr_arguments = repr_arguments or 'void' + name_and_arguments = '%s(%s)' % (name, repr_arguments) + if tp.abi == "__stdcall": + name_and_arguments = '_cffi_stdcall ' + name_and_arguments + # + def may_need_128_bits(tp): + return (isinstance(tp, model.PrimitiveType) and + tp.name == 'long double') + # + size_of_a = max(len(tp.args)*8, 8) + if may_need_128_bits(tp.result): + size_of_a = max(size_of_a, 16) + if isinstance(tp.result, model.StructOrUnion): + size_of_a = 'sizeof(%s) > %d ? sizeof(%s) : %d' % ( + tp.result.get_c_name(''), size_of_a, + tp.result.get_c_name(''), size_of_a) + prnt('%s%s' % (tag_and_space, tp.result.get_c_name(name_and_arguments))) + prnt('{') + prnt(' char a[%s];' % size_of_a) + prnt(' char *p = a;') + for i, type in enumerate(tp.args): + arg = 'a%d' % i + if (isinstance(type, model.StructOrUnion) or + may_need_128_bits(type)): + arg = '&' + arg + type = model.PointerType(type) + prnt(' *(%s)(p + %d) = %s;' % (type.get_c_name('*'), i*8, arg)) + prnt(' _cffi_call_python(&_cffi_externpy__%s, p);' % name) + if not isinstance(tp.result, model.VoidType): + prnt(' return *(%s)p;' % (tp.result.get_c_name('*'),)) + prnt('}') + prnt() + self._num_externpy += 1 + + def _generate_cpy_extern_python_decl(self, tp, name): + self._extern_python_decl(tp, name, 'static ') + + def _generate_cpy_dllexport_python_decl(self, tp, name): + self._extern_python_decl(tp, name, 'CFFI_DLLEXPORT ') + + def _generate_cpy_extern_python_plus_c_decl(self, tp, name): + self._extern_python_decl(tp, name, '') + + def _generate_cpy_extern_python_ctx(self, tp, name): + if self.target_is_python: + raise VerificationError( + "cannot use 'extern \"Python\"' in the ABI mode") + if tp.ellipsis: + raise NotImplementedError("a vararg function is extern \"Python\"") + type_index = self._typesdict[tp] + type_op = CffiOp(OP_EXTERN_PYTHON, type_index) + self._lsts["global"].append( + GlobalExpr(name, '&_cffi_externpy__%s' % name, type_op, name)) + + _generate_cpy_dllexport_python_ctx = \ + _generate_cpy_extern_python_plus_c_ctx = \ + _generate_cpy_extern_python_ctx + + def _print_string_literal_in_array(self, s): + prnt = self._prnt + prnt('// # NB. this is not a string because of a size limit in MSVC') + if not isinstance(s, bytes): # unicode + s = s.encode('utf-8') # -> bytes + else: + s.decode('utf-8') # got bytes, check for valid utf-8 + try: + s.decode('ascii') + except UnicodeDecodeError: + s = b'# -*- encoding: utf8 -*-\n' + s + for line in s.splitlines(True): + comment = line + if type('//') is bytes: # python2 + line = map(ord, line) # make a list of integers + else: # python3 + # type(line) is bytes, which enumerates like a list of integers + comment = ascii(comment)[1:-1] + prnt(('// ' + comment).rstrip()) + printed_line = '' + for c in line: + if len(printed_line) >= 76: + prnt(printed_line) + printed_line = '' + printed_line += '%d,' % (c,) + prnt(printed_line) + + # ---------- + # emitting the opcodes for individual types + + def _emit_bytecode_VoidType(self, tp, index): + self.cffi_types[index] = CffiOp(OP_PRIMITIVE, PRIM_VOID) + + def _emit_bytecode_PrimitiveType(self, tp, index): + prim_index = PRIMITIVE_TO_INDEX[tp.name] + self.cffi_types[index] = CffiOp(OP_PRIMITIVE, prim_index) + + def _emit_bytecode_UnknownIntegerType(self, tp, index): + s = ('_cffi_prim_int(sizeof(%s), (\n' + ' ((%s)-1) | 0 /* check that %s is an integer type */\n' + ' ) <= 0)' % (tp.name, tp.name, tp.name)) + self.cffi_types[index] = CffiOp(OP_PRIMITIVE, s) + + def _emit_bytecode_UnknownFloatType(self, tp, index): + s = ('_cffi_prim_float(sizeof(%s) *\n' + ' (((%s)1) / 2) * 2 /* integer => 0, float => 1 */\n' + ' )' % (tp.name, tp.name)) + self.cffi_types[index] = CffiOp(OP_PRIMITIVE, s) + + def _emit_bytecode_RawFunctionType(self, tp, index): + self.cffi_types[index] = CffiOp(OP_FUNCTION, self._typesdict[tp.result]) + index += 1 + for tp1 in tp.args: + realindex = self._typesdict[tp1] + if index != realindex: + if isinstance(tp1, model.PrimitiveType): + self._emit_bytecode_PrimitiveType(tp1, index) + else: + self.cffi_types[index] = CffiOp(OP_NOOP, realindex) + index += 1 + flags = int(tp.ellipsis) + if tp.abi is not None: + if tp.abi == '__stdcall': + flags |= 2 + else: + raise NotImplementedError("abi=%r" % (tp.abi,)) + self.cffi_types[index] = CffiOp(OP_FUNCTION_END, flags) + + def _emit_bytecode_PointerType(self, tp, index): + self.cffi_types[index] = CffiOp(OP_POINTER, self._typesdict[tp.totype]) + + _emit_bytecode_ConstPointerType = _emit_bytecode_PointerType + _emit_bytecode_NamedPointerType = _emit_bytecode_PointerType + + def _emit_bytecode_FunctionPtrType(self, tp, index): + raw = tp.as_raw_function() + self.cffi_types[index] = CffiOp(OP_POINTER, self._typesdict[raw]) + + def _emit_bytecode_ArrayType(self, tp, index): + item_index = self._typesdict[tp.item] + if tp.length is None: + self.cffi_types[index] = CffiOp(OP_OPEN_ARRAY, item_index) + elif tp.length == '...': + raise VerificationError( + "type %s badly placed: the '...' array length can only be " + "used on global arrays or on fields of structures" % ( + str(tp).replace('/*...*/', '...'),)) + else: + assert self.cffi_types[index + 1] == 'LEN' + self.cffi_types[index] = CffiOp(OP_ARRAY, item_index) + self.cffi_types[index + 1] = CffiOp(None, str(tp.length)) + + def _emit_bytecode_StructType(self, tp, index): + struct_index = self._struct_unions[tp] + self.cffi_types[index] = CffiOp(OP_STRUCT_UNION, struct_index) + _emit_bytecode_UnionType = _emit_bytecode_StructType + + def _emit_bytecode_EnumType(self, tp, index): + enum_index = self._enums[tp] + self.cffi_types[index] = CffiOp(OP_ENUM, enum_index) + + +if sys.version_info >= (3,): + NativeIO = io.StringIO +else: + class NativeIO(io.BytesIO): + def write(self, s): + if isinstance(s, unicode): + s = s.encode('ascii') + super(NativeIO, self).write(s) + +def _is_file_like(maybefile): + # compare to xml.etree.ElementTree._get_writer + return hasattr(maybefile, 'write') + +def _make_c_or_py_source(ffi, module_name, preamble, target_file, verbose): + if verbose: + print("generating %s" % (target_file,)) + recompiler = Recompiler(ffi, module_name, + target_is_python=(preamble is None)) + recompiler.collect_type_table() + recompiler.collect_step_tables() + if _is_file_like(target_file): + recompiler.write_source_to_f(target_file, preamble) + return True + f = NativeIO() + recompiler.write_source_to_f(f, preamble) + output = f.getvalue() + try: + with open(target_file, 'r') as f1: + if f1.read(len(output) + 1) != output: + raise IOError + if verbose: + print("(already up-to-date)") + return False # already up-to-date + except IOError: + tmp_file = '%s.~%d' % (target_file, os.getpid()) + with open(tmp_file, 'w') as f1: + f1.write(output) + try: + os.rename(tmp_file, target_file) + except OSError: + os.unlink(target_file) + os.rename(tmp_file, target_file) + return True + +def make_c_source(ffi, module_name, preamble, target_c_file, verbose=False): + assert preamble is not None + return _make_c_or_py_source(ffi, module_name, preamble, target_c_file, + verbose) + +def make_py_source(ffi, module_name, target_py_file, verbose=False): + return _make_c_or_py_source(ffi, module_name, None, target_py_file, + verbose) + +def _modname_to_file(outputdir, modname, extension): + parts = modname.split('.') + try: + os.makedirs(os.path.join(outputdir, *parts[:-1])) + except OSError: + pass + parts[-1] += extension + return os.path.join(outputdir, *parts), parts + + +# Aaargh. Distutils is not tested at all for the purpose of compiling +# DLLs that are not extension modules. Here are some hacks to work +# around that, in the _patch_for_*() functions... + +def _patch_meth(patchlist, cls, name, new_meth): + old = getattr(cls, name) + patchlist.append((cls, name, old)) + setattr(cls, name, new_meth) + return old + +def _unpatch_meths(patchlist): + for cls, name, old_meth in reversed(patchlist): + setattr(cls, name, old_meth) + +def _patch_for_embedding(patchlist): + if sys.platform == 'win32': + # we must not remove the manifest when building for embedding! + # FUTURE: this module was removed in setuptools 74; this is likely dead code and should be removed, + # since the toolchain it supports (VS2005-2008) is also long dead. + from cffi._shimmed_dist_utils import MSVCCompiler + if MSVCCompiler is not None: + _patch_meth(patchlist, MSVCCompiler, '_remove_visual_c_ref', + lambda self, manifest_file: manifest_file) + + if sys.platform == 'darwin': + # we must not make a '-bundle', but a '-dynamiclib' instead + from cffi._shimmed_dist_utils import CCompiler + def my_link_shared_object(self, *args, **kwds): + if '-bundle' in self.linker_so: + self.linker_so = list(self.linker_so) + i = self.linker_so.index('-bundle') + self.linker_so[i] = '-dynamiclib' + return old_link_shared_object(self, *args, **kwds) + old_link_shared_object = _patch_meth(patchlist, CCompiler, + 'link_shared_object', + my_link_shared_object) + +def _patch_for_target(patchlist, target): + from cffi._shimmed_dist_utils import build_ext + # if 'target' is different from '*', we need to patch some internal + # method to just return this 'target' value, instead of having it + # built from module_name + if target.endswith('.*'): + target = target[:-2] + if sys.platform == 'win32': + target += '.dll' + elif sys.platform == 'darwin': + target += '.dylib' + else: + target += '.so' + _patch_meth(patchlist, build_ext, 'get_ext_filename', + lambda self, ext_name: target) + + +def recompile(ffi, module_name, preamble, tmpdir='.', call_c_compiler=True, + c_file=None, source_extension='.c', extradir=None, + compiler_verbose=1, target=None, debug=None, + uses_ffiplatform=True, **kwds): + if not isinstance(module_name, str): + module_name = module_name.encode('ascii') + if ffi._windows_unicode: + ffi._apply_windows_unicode(kwds) + if preamble is not None: + if call_c_compiler and _is_file_like(c_file): + raise TypeError("Writing to file-like objects is not supported " + "with call_c_compiler=True") + embedding = (ffi._embedding is not None) + if embedding: + ffi._apply_embedding_fix(kwds) + if c_file is None: + c_file, parts = _modname_to_file(tmpdir, module_name, + source_extension) + if extradir: + parts = [extradir] + parts + ext_c_file = os.path.join(*parts) + else: + ext_c_file = c_file + # + if target is None: + if embedding: + target = '%s.*' % module_name + else: + target = '*' + # + if uses_ffiplatform: + ext = ffiplatform.get_extension(ext_c_file, module_name, **kwds) + else: + ext = None + updated = make_c_source(ffi, module_name, preamble, c_file, + verbose=compiler_verbose) + if call_c_compiler: + patchlist = [] + cwd = os.getcwd() + try: + if embedding: + _patch_for_embedding(patchlist) + if target != '*': + _patch_for_target(patchlist, target) + if compiler_verbose: + if tmpdir == '.': + msg = 'the current directory is' + else: + msg = 'setting the current directory to' + print('%s %r' % (msg, os.path.abspath(tmpdir))) + os.chdir(tmpdir) + outputfilename = ffiplatform.compile('.', ext, + compiler_verbose, debug) + finally: + os.chdir(cwd) + _unpatch_meths(patchlist) + return outputfilename + else: + return ext, updated + else: + if c_file is None: + c_file, _ = _modname_to_file(tmpdir, module_name, '.py') + updated = make_py_source(ffi, module_name, c_file, + verbose=compiler_verbose) + if call_c_compiler: + return c_file + else: + return None, updated + diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/setuptools_ext.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/setuptools_ext.py new file mode 100644 index 0000000..681b49d --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/setuptools_ext.py @@ -0,0 +1,216 @@ +import os +import sys + +try: + basestring +except NameError: + # Python 3.x + basestring = str + +def error(msg): + from cffi._shimmed_dist_utils import DistutilsSetupError + raise DistutilsSetupError(msg) + + +def execfile(filename, glob): + # We use execfile() (here rewritten for Python 3) instead of + # __import__() to load the build script. The problem with + # a normal import is that in some packages, the intermediate + # __init__.py files may already try to import the file that + # we are generating. + with open(filename) as f: + src = f.read() + src += '\n' # Python 2.6 compatibility + code = compile(src, filename, 'exec') + exec(code, glob, glob) + + +def add_cffi_module(dist, mod_spec): + from cffi.api import FFI + + if not isinstance(mod_spec, basestring): + error("argument to 'cffi_modules=...' must be a str or a list of str," + " not %r" % (type(mod_spec).__name__,)) + mod_spec = str(mod_spec) + try: + build_file_name, ffi_var_name = mod_spec.split(':') + except ValueError: + error("%r must be of the form 'path/build.py:ffi_variable'" % + (mod_spec,)) + if not os.path.exists(build_file_name): + ext = '' + rewritten = build_file_name.replace('.', '/') + '.py' + if os.path.exists(rewritten): + ext = ' (rewrite cffi_modules to [%r])' % ( + rewritten + ':' + ffi_var_name,) + error("%r does not name an existing file%s" % (build_file_name, ext)) + + mod_vars = {'__name__': '__cffi__', '__file__': build_file_name} + execfile(build_file_name, mod_vars) + + try: + ffi = mod_vars[ffi_var_name] + except KeyError: + error("%r: object %r not found in module" % (mod_spec, + ffi_var_name)) + if not isinstance(ffi, FFI): + ffi = ffi() # maybe it's a function instead of directly an ffi + if not isinstance(ffi, FFI): + error("%r is not an FFI instance (got %r)" % (mod_spec, + type(ffi).__name__)) + if not hasattr(ffi, '_assigned_source'): + error("%r: the set_source() method was not called" % (mod_spec,)) + module_name, source, source_extension, kwds = ffi._assigned_source + if ffi._windows_unicode: + kwds = kwds.copy() + ffi._apply_windows_unicode(kwds) + + if source is None: + _add_py_module(dist, ffi, module_name) + else: + _add_c_module(dist, ffi, module_name, source, source_extension, kwds) + +def _set_py_limited_api(Extension, kwds): + """ + Add py_limited_api to kwds if setuptools >= 26 is in use. + Do not alter the setting if it already exists. + Setuptools takes care of ignoring the flag on Python 2 and PyPy. + + CPython itself should ignore the flag in a debugging version + (by not listing .abi3.so in the extensions it supports), but + it doesn't so far, creating troubles. That's why we check + for "not hasattr(sys, 'gettotalrefcount')" (the 2.7 compatible equivalent + of 'd' not in sys.abiflags). (http://bugs.python.org/issue28401) + + On Windows, with CPython <= 3.4, it's better not to use py_limited_api + because virtualenv *still* doesn't copy PYTHON3.DLL on these versions. + Recently (2020) we started shipping only >= 3.5 wheels, though. So + we'll give it another try and set py_limited_api on Windows >= 3.5. + """ + from cffi import recompiler + + if ('py_limited_api' not in kwds and not hasattr(sys, 'gettotalrefcount') + and recompiler.USE_LIMITED_API): + import setuptools + try: + setuptools_major_version = int(setuptools.__version__.partition('.')[0]) + if setuptools_major_version >= 26: + kwds['py_limited_api'] = True + except ValueError: # certain development versions of setuptools + # If we don't know the version number of setuptools, we + # try to set 'py_limited_api' anyway. At worst, we get a + # warning. + kwds['py_limited_api'] = True + return kwds + +def _add_c_module(dist, ffi, module_name, source, source_extension, kwds): + # We are a setuptools extension. Need this build_ext for py_limited_api. + from setuptools.command.build_ext import build_ext + from cffi._shimmed_dist_utils import Extension, log, mkpath + from cffi import recompiler + + allsources = ['$PLACEHOLDER'] + allsources.extend(kwds.pop('sources', [])) + kwds = _set_py_limited_api(Extension, kwds) + ext = Extension(name=module_name, sources=allsources, **kwds) + + def make_mod(tmpdir, pre_run=None): + c_file = os.path.join(tmpdir, module_name + source_extension) + log.info("generating cffi module %r" % c_file) + mkpath(tmpdir) + # a setuptools-only, API-only hook: called with the "ext" and "ffi" + # arguments just before we turn the ffi into C code. To use it, + # subclass the 'distutils.command.build_ext.build_ext' class and + # add a method 'def pre_run(self, ext, ffi)'. + if pre_run is not None: + pre_run(ext, ffi) + updated = recompiler.make_c_source(ffi, module_name, source, c_file) + if not updated: + log.info("already up-to-date") + return c_file + + if dist.ext_modules is None: + dist.ext_modules = [] + dist.ext_modules.append(ext) + + base_class = dist.cmdclass.get('build_ext', build_ext) + class build_ext_make_mod(base_class): + def run(self): + if ext.sources[0] == '$PLACEHOLDER': + pre_run = getattr(self, 'pre_run', None) + ext.sources[0] = make_mod(self.build_temp, pre_run) + base_class.run(self) + dist.cmdclass['build_ext'] = build_ext_make_mod + # NB. multiple runs here will create multiple 'build_ext_make_mod' + # classes. Even in this case the 'build_ext' command should be + # run once; but just in case, the logic above does nothing if + # called again. + + +def _add_py_module(dist, ffi, module_name): + from setuptools.command.build_py import build_py + from setuptools.command.build_ext import build_ext + from cffi._shimmed_dist_utils import log, mkpath + from cffi import recompiler + + def generate_mod(py_file): + log.info("generating cffi module %r" % py_file) + mkpath(os.path.dirname(py_file)) + updated = recompiler.make_py_source(ffi, module_name, py_file) + if not updated: + log.info("already up-to-date") + + base_class = dist.cmdclass.get('build_py', build_py) + class build_py_make_mod(base_class): + def run(self): + base_class.run(self) + module_path = module_name.split('.') + module_path[-1] += '.py' + generate_mod(os.path.join(self.build_lib, *module_path)) + def get_source_files(self): + # This is called from 'setup.py sdist' only. Exclude + # the generate .py module in this case. + saved_py_modules = self.py_modules + try: + if saved_py_modules: + self.py_modules = [m for m in saved_py_modules + if m != module_name] + return base_class.get_source_files(self) + finally: + self.py_modules = saved_py_modules + dist.cmdclass['build_py'] = build_py_make_mod + + # distutils and setuptools have no notion I could find of a + # generated python module. If we don't add module_name to + # dist.py_modules, then things mostly work but there are some + # combination of options (--root and --record) that will miss + # the module. So we add it here, which gives a few apparently + # harmless warnings about not finding the file outside the + # build directory. + # Then we need to hack more in get_source_files(); see above. + if dist.py_modules is None: + dist.py_modules = [] + dist.py_modules.append(module_name) + + # the following is only for "build_ext -i" + base_class_2 = dist.cmdclass.get('build_ext', build_ext) + class build_ext_make_mod(base_class_2): + def run(self): + base_class_2.run(self) + if self.inplace: + # from get_ext_fullpath() in distutils/command/build_ext.py + module_path = module_name.split('.') + package = '.'.join(module_path[:-1]) + build_py = self.get_finalized_command('build_py') + package_dir = build_py.get_package_dir(package) + file_name = module_path[-1] + '.py' + generate_mod(os.path.join(package_dir, file_name)) + dist.cmdclass['build_ext'] = build_ext_make_mod + +def cffi_modules(dist, attr, value): + assert attr == 'cffi_modules' + if isinstance(value, basestring): + value = [value] + + for cffi_module in value: + add_cffi_module(dist, cffi_module) diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/vengine_cpy.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/vengine_cpy.py new file mode 100644 index 0000000..eb0b6f7 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/vengine_cpy.py @@ -0,0 +1,1084 @@ +# +# DEPRECATED: implementation for ffi.verify() +# +import sys +from . import model +from .error import VerificationError +from . import _imp_emulation as imp + + +class VCPythonEngine(object): + _class_key = 'x' + _gen_python_module = True + + def __init__(self, verifier): + self.verifier = verifier + self.ffi = verifier.ffi + self._struct_pending_verification = {} + self._types_of_builtin_functions = {} + + def patch_extension_kwds(self, kwds): + pass + + def find_module(self, module_name, path, so_suffixes): + try: + f, filename, descr = imp.find_module(module_name, path) + except ImportError: + return None + if f is not None: + f.close() + # Note that after a setuptools installation, there are both .py + # and .so files with the same basename. The code here relies on + # imp.find_module() locating the .so in priority. + if descr[0] not in so_suffixes: + return None + return filename + + def collect_types(self): + self._typesdict = {} + self._generate("collecttype") + + def _prnt(self, what=''): + self._f.write(what + '\n') + + def _gettypenum(self, type): + # a KeyError here is a bug. please report it! :-) + return self._typesdict[type] + + def _do_collect_type(self, tp): + if ((not isinstance(tp, model.PrimitiveType) + or tp.name == 'long double') + and tp not in self._typesdict): + num = len(self._typesdict) + self._typesdict[tp] = num + + def write_source_to_f(self): + self.collect_types() + # + # The new module will have a _cffi_setup() function that receives + # objects from the ffi world, and that calls some setup code in + # the module. This setup code is split in several independent + # functions, e.g. one per constant. The functions are "chained" + # by ending in a tail call to each other. + # + # This is further split in two chained lists, depending on if we + # can do it at import-time or if we must wait for _cffi_setup() to + # provide us with the objects. This is needed because we + # need the values of the enum constants in order to build the + # that we may have to pass to _cffi_setup(). + # + # The following two 'chained_list_constants' items contains + # the head of these two chained lists, as a string that gives the + # call to do, if any. + self._chained_list_constants = ['((void)lib,0)', '((void)lib,0)'] + # + prnt = self._prnt + # first paste some standard set of lines that are mostly '#define' + prnt(cffimod_header) + prnt() + # then paste the C source given by the user, verbatim. + prnt(self.verifier.preamble) + prnt() + # + # call generate_cpy_xxx_decl(), for every xxx found from + # ffi._parser._declarations. This generates all the functions. + self._generate("decl") + # + # implement the function _cffi_setup_custom() as calling the + # head of the chained list. + self._generate_setup_custom() + prnt() + # + # produce the method table, including the entries for the + # generated Python->C function wrappers, which are done + # by generate_cpy_function_method(). + prnt('static PyMethodDef _cffi_methods[] = {') + self._generate("method") + prnt(' {"_cffi_setup", _cffi_setup, METH_VARARGS, NULL},') + prnt(' {NULL, NULL, 0, NULL} /* Sentinel */') + prnt('};') + prnt() + # + # standard init. + modname = self.verifier.get_module_name() + constants = self._chained_list_constants[False] + prnt('#if PY_MAJOR_VERSION >= 3') + prnt() + prnt('static struct PyModuleDef _cffi_module_def = {') + prnt(' PyModuleDef_HEAD_INIT,') + prnt(' "%s",' % modname) + prnt(' NULL,') + prnt(' -1,') + prnt(' _cffi_methods,') + prnt(' NULL, NULL, NULL, NULL') + prnt('};') + prnt() + prnt('PyMODINIT_FUNC') + prnt('PyInit_%s(void)' % modname) + prnt('{') + prnt(' PyObject *lib;') + prnt(' lib = PyModule_Create(&_cffi_module_def);') + prnt(' if (lib == NULL)') + prnt(' return NULL;') + prnt(' if (%s < 0 || _cffi_init() < 0) {' % (constants,)) + prnt(' Py_DECREF(lib);') + prnt(' return NULL;') + prnt(' }') + prnt(' return lib;') + prnt('}') + prnt() + prnt('#else') + prnt() + prnt('PyMODINIT_FUNC') + prnt('init%s(void)' % modname) + prnt('{') + prnt(' PyObject *lib;') + prnt(' lib = Py_InitModule("%s", _cffi_methods);' % modname) + prnt(' if (lib == NULL)') + prnt(' return;') + prnt(' if (%s < 0 || _cffi_init() < 0)' % (constants,)) + prnt(' return;') + prnt(' return;') + prnt('}') + prnt() + prnt('#endif') + + def load_library(self, flags=None): + # XXX review all usages of 'self' here! + # import it as a new extension module + imp.acquire_lock() + try: + if hasattr(sys, "getdlopenflags"): + previous_flags = sys.getdlopenflags() + try: + if hasattr(sys, "setdlopenflags") and flags is not None: + sys.setdlopenflags(flags) + module = imp.load_dynamic(self.verifier.get_module_name(), + self.verifier.modulefilename) + except ImportError as e: + error = "importing %r: %s" % (self.verifier.modulefilename, e) + raise VerificationError(error) + finally: + if hasattr(sys, "setdlopenflags"): + sys.setdlopenflags(previous_flags) + finally: + imp.release_lock() + # + # call loading_cpy_struct() to get the struct layout inferred by + # the C compiler + self._load(module, 'loading') + # + # the C code will need the objects. Collect them in + # order in a list. + revmapping = dict([(value, key) + for (key, value) in self._typesdict.items()]) + lst = [revmapping[i] for i in range(len(revmapping))] + lst = list(map(self.ffi._get_cached_btype, lst)) + # + # build the FFILibrary class and instance and call _cffi_setup(). + # this will set up some fields like '_cffi_types', and only then + # it will invoke the chained list of functions that will really + # build (notably) the constant objects, as if they are + # pointers, and store them as attributes on the 'library' object. + class FFILibrary(object): + _cffi_python_module = module + _cffi_ffi = self.ffi + _cffi_dir = [] + def __dir__(self): + return FFILibrary._cffi_dir + list(self.__dict__) + library = FFILibrary() + if module._cffi_setup(lst, VerificationError, library): + import warnings + warnings.warn("reimporting %r might overwrite older definitions" + % (self.verifier.get_module_name())) + # + # finally, call the loaded_cpy_xxx() functions. This will perform + # the final adjustments, like copying the Python->C wrapper + # functions from the module to the 'library' object, and setting + # up the FFILibrary class with properties for the global C variables. + self._load(module, 'loaded', library=library) + module._cffi_original_ffi = self.ffi + module._cffi_types_of_builtin_funcs = self._types_of_builtin_functions + return library + + def _get_declarations(self): + lst = [(key, tp) for (key, (tp, qual)) in + self.ffi._parser._declarations.items()] + lst.sort() + return lst + + def _generate(self, step_name): + for name, tp in self._get_declarations(): + kind, realname = name.split(' ', 1) + try: + method = getattr(self, '_generate_cpy_%s_%s' % (kind, + step_name)) + except AttributeError: + raise VerificationError( + "not implemented in verify(): %r" % name) + try: + method(tp, realname) + except Exception as e: + model.attach_exception_info(e, name) + raise + + def _load(self, module, step_name, **kwds): + for name, tp in self._get_declarations(): + kind, realname = name.split(' ', 1) + method = getattr(self, '_%s_cpy_%s' % (step_name, kind)) + try: + method(tp, realname, module, **kwds) + except Exception as e: + model.attach_exception_info(e, name) + raise + + def _generate_nothing(self, tp, name): + pass + + def _loaded_noop(self, tp, name, module, **kwds): + pass + + # ---------- + + def _convert_funcarg_to_c(self, tp, fromvar, tovar, errcode): + extraarg = '' + if isinstance(tp, model.PrimitiveType): + if tp.is_integer_type() and tp.name != '_Bool': + converter = '_cffi_to_c_int' + extraarg = ', %s' % tp.name + elif tp.is_complex_type(): + raise VerificationError( + "not implemented in verify(): complex types") + else: + converter = '(%s)_cffi_to_c_%s' % (tp.get_c_name(''), + tp.name.replace(' ', '_')) + errvalue = '-1' + # + elif isinstance(tp, model.PointerType): + self._convert_funcarg_to_c_ptr_or_array(tp, fromvar, + tovar, errcode) + return + # + elif isinstance(tp, (model.StructOrUnion, model.EnumType)): + # a struct (not a struct pointer) as a function argument + self._prnt(' if (_cffi_to_c((char *)&%s, _cffi_type(%d), %s) < 0)' + % (tovar, self._gettypenum(tp), fromvar)) + self._prnt(' %s;' % errcode) + return + # + elif isinstance(tp, model.FunctionPtrType): + converter = '(%s)_cffi_to_c_pointer' % tp.get_c_name('') + extraarg = ', _cffi_type(%d)' % self._gettypenum(tp) + errvalue = 'NULL' + # + else: + raise NotImplementedError(tp) + # + self._prnt(' %s = %s(%s%s);' % (tovar, converter, fromvar, extraarg)) + self._prnt(' if (%s == (%s)%s && PyErr_Occurred())' % ( + tovar, tp.get_c_name(''), errvalue)) + self._prnt(' %s;' % errcode) + + def _extra_local_variables(self, tp, localvars, freelines): + if isinstance(tp, model.PointerType): + localvars.add('Py_ssize_t datasize') + localvars.add('struct _cffi_freeme_s *large_args_free = NULL') + freelines.add('if (large_args_free != NULL)' + ' _cffi_free_array_arguments(large_args_free);') + + def _convert_funcarg_to_c_ptr_or_array(self, tp, fromvar, tovar, errcode): + self._prnt(' datasize = _cffi_prepare_pointer_call_argument(') + self._prnt(' _cffi_type(%d), %s, (char **)&%s);' % ( + self._gettypenum(tp), fromvar, tovar)) + self._prnt(' if (datasize != 0) {') + self._prnt(' %s = ((size_t)datasize) <= 640 ? ' + 'alloca((size_t)datasize) : NULL;' % (tovar,)) + self._prnt(' if (_cffi_convert_array_argument(_cffi_type(%d), %s, ' + '(char **)&%s,' % (self._gettypenum(tp), fromvar, tovar)) + self._prnt(' datasize, &large_args_free) < 0)') + self._prnt(' %s;' % errcode) + self._prnt(' }') + + def _convert_expr_from_c(self, tp, var, context): + if isinstance(tp, model.PrimitiveType): + if tp.is_integer_type() and tp.name != '_Bool': + return '_cffi_from_c_int(%s, %s)' % (var, tp.name) + elif tp.name != 'long double': + return '_cffi_from_c_%s(%s)' % (tp.name.replace(' ', '_'), var) + else: + return '_cffi_from_c_deref((char *)&%s, _cffi_type(%d))' % ( + var, self._gettypenum(tp)) + elif isinstance(tp, (model.PointerType, model.FunctionPtrType)): + return '_cffi_from_c_pointer((char *)%s, _cffi_type(%d))' % ( + var, self._gettypenum(tp)) + elif isinstance(tp, model.ArrayType): + return '_cffi_from_c_pointer((char *)%s, _cffi_type(%d))' % ( + var, self._gettypenum(model.PointerType(tp.item))) + elif isinstance(tp, model.StructOrUnion): + if tp.fldnames is None: + raise TypeError("'%s' is used as %s, but is opaque" % ( + tp._get_c_name(), context)) + return '_cffi_from_c_struct((char *)&%s, _cffi_type(%d))' % ( + var, self._gettypenum(tp)) + elif isinstance(tp, model.EnumType): + return '_cffi_from_c_deref((char *)&%s, _cffi_type(%d))' % ( + var, self._gettypenum(tp)) + else: + raise NotImplementedError(tp) + + # ---------- + # typedefs: generates no code so far + + _generate_cpy_typedef_collecttype = _generate_nothing + _generate_cpy_typedef_decl = _generate_nothing + _generate_cpy_typedef_method = _generate_nothing + _loading_cpy_typedef = _loaded_noop + _loaded_cpy_typedef = _loaded_noop + + # ---------- + # function declarations + + def _generate_cpy_function_collecttype(self, tp, name): + assert isinstance(tp, model.FunctionPtrType) + if tp.ellipsis: + self._do_collect_type(tp) + else: + # don't call _do_collect_type(tp) in this common case, + # otherwise test_autofilled_struct_as_argument fails + for type in tp.args: + self._do_collect_type(type) + self._do_collect_type(tp.result) + + def _generate_cpy_function_decl(self, tp, name): + assert isinstance(tp, model.FunctionPtrType) + if tp.ellipsis: + # cannot support vararg functions better than this: check for its + # exact type (including the fixed arguments), and build it as a + # constant function pointer (no CPython wrapper) + self._generate_cpy_const(False, name, tp) + return + prnt = self._prnt + numargs = len(tp.args) + if numargs == 0: + argname = 'noarg' + elif numargs == 1: + argname = 'arg0' + else: + argname = 'args' + prnt('static PyObject *') + prnt('_cffi_f_%s(PyObject *self, PyObject *%s)' % (name, argname)) + prnt('{') + # + context = 'argument of %s' % name + for i, type in enumerate(tp.args): + prnt(' %s;' % type.get_c_name(' x%d' % i, context)) + # + localvars = set() + freelines = set() + for type in tp.args: + self._extra_local_variables(type, localvars, freelines) + for decl in sorted(localvars): + prnt(' %s;' % (decl,)) + # + if not isinstance(tp.result, model.VoidType): + result_code = 'result = ' + context = 'result of %s' % name + prnt(' %s;' % tp.result.get_c_name(' result', context)) + prnt(' PyObject *pyresult;') + else: + result_code = '' + # + if len(tp.args) > 1: + rng = range(len(tp.args)) + for i in rng: + prnt(' PyObject *arg%d;' % i) + prnt() + prnt(' if (!PyArg_ParseTuple(args, "%s:%s", %s))' % ( + 'O' * numargs, name, ', '.join(['&arg%d' % i for i in rng]))) + prnt(' return NULL;') + prnt() + # + for i, type in enumerate(tp.args): + self._convert_funcarg_to_c(type, 'arg%d' % i, 'x%d' % i, + 'return NULL') + prnt() + # + prnt(' Py_BEGIN_ALLOW_THREADS') + prnt(' _cffi_restore_errno();') + prnt(' { %s%s(%s); }' % ( + result_code, name, + ', '.join(['x%d' % i for i in range(len(tp.args))]))) + prnt(' _cffi_save_errno();') + prnt(' Py_END_ALLOW_THREADS') + prnt() + # + prnt(' (void)self; /* unused */') + if numargs == 0: + prnt(' (void)noarg; /* unused */') + if result_code: + prnt(' pyresult = %s;' % + self._convert_expr_from_c(tp.result, 'result', 'result type')) + for freeline in freelines: + prnt(' ' + freeline) + prnt(' return pyresult;') + else: + for freeline in freelines: + prnt(' ' + freeline) + prnt(' Py_INCREF(Py_None);') + prnt(' return Py_None;') + prnt('}') + prnt() + + def _generate_cpy_function_method(self, tp, name): + if tp.ellipsis: + return + numargs = len(tp.args) + if numargs == 0: + meth = 'METH_NOARGS' + elif numargs == 1: + meth = 'METH_O' + else: + meth = 'METH_VARARGS' + self._prnt(' {"%s", _cffi_f_%s, %s, NULL},' % (name, name, meth)) + + _loading_cpy_function = _loaded_noop + + def _loaded_cpy_function(self, tp, name, module, library): + if tp.ellipsis: + return + func = getattr(module, name) + setattr(library, name, func) + self._types_of_builtin_functions[func] = tp + + # ---------- + # named structs + + _generate_cpy_struct_collecttype = _generate_nothing + def _generate_cpy_struct_decl(self, tp, name): + assert name == tp.name + self._generate_struct_or_union_decl(tp, 'struct', name) + def _generate_cpy_struct_method(self, tp, name): + self._generate_struct_or_union_method(tp, 'struct', name) + def _loading_cpy_struct(self, tp, name, module): + self._loading_struct_or_union(tp, 'struct', name, module) + def _loaded_cpy_struct(self, tp, name, module, **kwds): + self._loaded_struct_or_union(tp) + + _generate_cpy_union_collecttype = _generate_nothing + def _generate_cpy_union_decl(self, tp, name): + assert name == tp.name + self._generate_struct_or_union_decl(tp, 'union', name) + def _generate_cpy_union_method(self, tp, name): + self._generate_struct_or_union_method(tp, 'union', name) + def _loading_cpy_union(self, tp, name, module): + self._loading_struct_or_union(tp, 'union', name, module) + def _loaded_cpy_union(self, tp, name, module, **kwds): + self._loaded_struct_or_union(tp) + + def _generate_struct_or_union_decl(self, tp, prefix, name): + if tp.fldnames is None: + return # nothing to do with opaque structs + checkfuncname = '_cffi_check_%s_%s' % (prefix, name) + layoutfuncname = '_cffi_layout_%s_%s' % (prefix, name) + cname = ('%s %s' % (prefix, name)).strip() + # + prnt = self._prnt + prnt('static void %s(%s *p)' % (checkfuncname, cname)) + prnt('{') + prnt(' /* only to generate compile-time warnings or errors */') + prnt(' (void)p;') + for fname, ftype, fbitsize, fqual in tp.enumfields(): + if (isinstance(ftype, model.PrimitiveType) + and ftype.is_integer_type()) or fbitsize >= 0: + # accept all integers, but complain on float or double + prnt(' (void)((p->%s) << 1);' % fname) + else: + # only accept exactly the type declared. + try: + prnt(' { %s = &p->%s; (void)tmp; }' % ( + ftype.get_c_name('*tmp', 'field %r'%fname, quals=fqual), + fname)) + except VerificationError as e: + prnt(' /* %s */' % str(e)) # cannot verify it, ignore + prnt('}') + prnt('static PyObject *') + prnt('%s(PyObject *self, PyObject *noarg)' % (layoutfuncname,)) + prnt('{') + prnt(' struct _cffi_aligncheck { char x; %s y; };' % cname) + prnt(' static Py_ssize_t nums[] = {') + prnt(' sizeof(%s),' % cname) + prnt(' offsetof(struct _cffi_aligncheck, y),') + for fname, ftype, fbitsize, fqual in tp.enumfields(): + if fbitsize >= 0: + continue # xxx ignore fbitsize for now + prnt(' offsetof(%s, %s),' % (cname, fname)) + if isinstance(ftype, model.ArrayType) and ftype.length is None: + prnt(' 0, /* %s */' % ftype._get_c_name()) + else: + prnt(' sizeof(((%s *)0)->%s),' % (cname, fname)) + prnt(' -1') + prnt(' };') + prnt(' (void)self; /* unused */') + prnt(' (void)noarg; /* unused */') + prnt(' return _cffi_get_struct_layout(nums);') + prnt(' /* the next line is not executed, but compiled */') + prnt(' %s(0);' % (checkfuncname,)) + prnt('}') + prnt() + + def _generate_struct_or_union_method(self, tp, prefix, name): + if tp.fldnames is None: + return # nothing to do with opaque structs + layoutfuncname = '_cffi_layout_%s_%s' % (prefix, name) + self._prnt(' {"%s", %s, METH_NOARGS, NULL},' % (layoutfuncname, + layoutfuncname)) + + def _loading_struct_or_union(self, tp, prefix, name, module): + if tp.fldnames is None: + return # nothing to do with opaque structs + layoutfuncname = '_cffi_layout_%s_%s' % (prefix, name) + # + function = getattr(module, layoutfuncname) + layout = function() + if isinstance(tp, model.StructOrUnion) and tp.partial: + # use the function()'s sizes and offsets to guide the + # layout of the struct + totalsize = layout[0] + totalalignment = layout[1] + fieldofs = layout[2::2] + fieldsize = layout[3::2] + tp.force_flatten() + assert len(fieldofs) == len(fieldsize) == len(tp.fldnames) + tp.fixedlayout = fieldofs, fieldsize, totalsize, totalalignment + else: + cname = ('%s %s' % (prefix, name)).strip() + self._struct_pending_verification[tp] = layout, cname + + def _loaded_struct_or_union(self, tp): + if tp.fldnames is None: + return # nothing to do with opaque structs + self.ffi._get_cached_btype(tp) # force 'fixedlayout' to be considered + + if tp in self._struct_pending_verification: + # check that the layout sizes and offsets match the real ones + def check(realvalue, expectedvalue, msg): + if realvalue != expectedvalue: + raise VerificationError( + "%s (we have %d, but C compiler says %d)" + % (msg, expectedvalue, realvalue)) + ffi = self.ffi + BStruct = ffi._get_cached_btype(tp) + layout, cname = self._struct_pending_verification.pop(tp) + check(layout[0], ffi.sizeof(BStruct), "wrong total size") + check(layout[1], ffi.alignof(BStruct), "wrong total alignment") + i = 2 + for fname, ftype, fbitsize, fqual in tp.enumfields(): + if fbitsize >= 0: + continue # xxx ignore fbitsize for now + check(layout[i], ffi.offsetof(BStruct, fname), + "wrong offset for field %r" % (fname,)) + if layout[i+1] != 0: + BField = ffi._get_cached_btype(ftype) + check(layout[i+1], ffi.sizeof(BField), + "wrong size for field %r" % (fname,)) + i += 2 + assert i == len(layout) + + # ---------- + # 'anonymous' declarations. These are produced for anonymous structs + # or unions; the 'name' is obtained by a typedef. + + _generate_cpy_anonymous_collecttype = _generate_nothing + + def _generate_cpy_anonymous_decl(self, tp, name): + if isinstance(tp, model.EnumType): + self._generate_cpy_enum_decl(tp, name, '') + else: + self._generate_struct_or_union_decl(tp, '', name) + + def _generate_cpy_anonymous_method(self, tp, name): + if not isinstance(tp, model.EnumType): + self._generate_struct_or_union_method(tp, '', name) + + def _loading_cpy_anonymous(self, tp, name, module): + if isinstance(tp, model.EnumType): + self._loading_cpy_enum(tp, name, module) + else: + self._loading_struct_or_union(tp, '', name, module) + + def _loaded_cpy_anonymous(self, tp, name, module, **kwds): + if isinstance(tp, model.EnumType): + self._loaded_cpy_enum(tp, name, module, **kwds) + else: + self._loaded_struct_or_union(tp) + + # ---------- + # constants, likely declared with '#define' + + def _generate_cpy_const(self, is_int, name, tp=None, category='const', + vartp=None, delayed=True, size_too=False, + check_value=None): + prnt = self._prnt + funcname = '_cffi_%s_%s' % (category, name) + prnt('static int %s(PyObject *lib)' % funcname) + prnt('{') + prnt(' PyObject *o;') + prnt(' int res;') + if not is_int: + prnt(' %s;' % (vartp or tp).get_c_name(' i', name)) + else: + assert category == 'const' + # + if check_value is not None: + self._check_int_constant_value(name, check_value) + # + if not is_int: + if category == 'var': + realexpr = '&' + name + else: + realexpr = name + prnt(' i = (%s);' % (realexpr,)) + prnt(' o = %s;' % (self._convert_expr_from_c(tp, 'i', + 'variable type'),)) + assert delayed + else: + prnt(' o = _cffi_from_c_int_const(%s);' % name) + prnt(' if (o == NULL)') + prnt(' return -1;') + if size_too: + prnt(' {') + prnt(' PyObject *o1 = o;') + prnt(' o = Py_BuildValue("On", o1, (Py_ssize_t)sizeof(%s));' + % (name,)) + prnt(' Py_DECREF(o1);') + prnt(' if (o == NULL)') + prnt(' return -1;') + prnt(' }') + prnt(' res = PyObject_SetAttrString(lib, "%s", o);' % name) + prnt(' Py_DECREF(o);') + prnt(' if (res < 0)') + prnt(' return -1;') + prnt(' return %s;' % self._chained_list_constants[delayed]) + self._chained_list_constants[delayed] = funcname + '(lib)' + prnt('}') + prnt() + + def _generate_cpy_constant_collecttype(self, tp, name): + is_int = isinstance(tp, model.PrimitiveType) and tp.is_integer_type() + if not is_int: + self._do_collect_type(tp) + + def _generate_cpy_constant_decl(self, tp, name): + is_int = isinstance(tp, model.PrimitiveType) and tp.is_integer_type() + self._generate_cpy_const(is_int, name, tp) + + _generate_cpy_constant_method = _generate_nothing + _loading_cpy_constant = _loaded_noop + _loaded_cpy_constant = _loaded_noop + + # ---------- + # enums + + def _check_int_constant_value(self, name, value, err_prefix=''): + prnt = self._prnt + if value <= 0: + prnt(' if ((%s) > 0 || (long)(%s) != %dL) {' % ( + name, name, value)) + else: + prnt(' if ((%s) <= 0 || (unsigned long)(%s) != %dUL) {' % ( + name, name, value)) + prnt(' char buf[64];') + prnt(' if ((%s) <= 0)' % name) + prnt(' snprintf(buf, 63, "%%ld", (long)(%s));' % name) + prnt(' else') + prnt(' snprintf(buf, 63, "%%lu", (unsigned long)(%s));' % + name) + prnt(' PyErr_Format(_cffi_VerificationError,') + prnt(' "%s%s has the real value %s, not %s",') + prnt(' "%s", "%s", buf, "%d");' % ( + err_prefix, name, value)) + prnt(' return -1;') + prnt(' }') + + def _enum_funcname(self, prefix, name): + # "$enum_$1" => "___D_enum____D_1" + name = name.replace('$', '___D_') + return '_cffi_e_%s_%s' % (prefix, name) + + def _generate_cpy_enum_decl(self, tp, name, prefix='enum'): + if tp.partial: + for enumerator in tp.enumerators: + self._generate_cpy_const(True, enumerator, delayed=False) + return + # + funcname = self._enum_funcname(prefix, name) + prnt = self._prnt + prnt('static int %s(PyObject *lib)' % funcname) + prnt('{') + for enumerator, enumvalue in zip(tp.enumerators, tp.enumvalues): + self._check_int_constant_value(enumerator, enumvalue, + "enum %s: " % name) + prnt(' return %s;' % self._chained_list_constants[True]) + self._chained_list_constants[True] = funcname + '(lib)' + prnt('}') + prnt() + + _generate_cpy_enum_collecttype = _generate_nothing + _generate_cpy_enum_method = _generate_nothing + + def _loading_cpy_enum(self, tp, name, module): + if tp.partial: + enumvalues = [getattr(module, enumerator) + for enumerator in tp.enumerators] + tp.enumvalues = tuple(enumvalues) + tp.partial_resolved = True + + def _loaded_cpy_enum(self, tp, name, module, library): + for enumerator, enumvalue in zip(tp.enumerators, tp.enumvalues): + setattr(library, enumerator, enumvalue) + + # ---------- + # macros: for now only for integers + + def _generate_cpy_macro_decl(self, tp, name): + if tp == '...': + check_value = None + else: + check_value = tp # an integer + self._generate_cpy_const(True, name, check_value=check_value) + + _generate_cpy_macro_collecttype = _generate_nothing + _generate_cpy_macro_method = _generate_nothing + _loading_cpy_macro = _loaded_noop + _loaded_cpy_macro = _loaded_noop + + # ---------- + # global variables + + def _generate_cpy_variable_collecttype(self, tp, name): + if isinstance(tp, model.ArrayType): + tp_ptr = model.PointerType(tp.item) + else: + tp_ptr = model.PointerType(tp) + self._do_collect_type(tp_ptr) + + def _generate_cpy_variable_decl(self, tp, name): + if isinstance(tp, model.ArrayType): + tp_ptr = model.PointerType(tp.item) + self._generate_cpy_const(False, name, tp, vartp=tp_ptr, + size_too = tp.length_is_unknown()) + else: + tp_ptr = model.PointerType(tp) + self._generate_cpy_const(False, name, tp_ptr, category='var') + + _generate_cpy_variable_method = _generate_nothing + _loading_cpy_variable = _loaded_noop + + def _loaded_cpy_variable(self, tp, name, module, library): + value = getattr(library, name) + if isinstance(tp, model.ArrayType): # int a[5] is "constant" in the + # sense that "a=..." is forbidden + if tp.length_is_unknown(): + assert isinstance(value, tuple) + (value, size) = value + BItemType = self.ffi._get_cached_btype(tp.item) + length, rest = divmod(size, self.ffi.sizeof(BItemType)) + if rest != 0: + raise VerificationError( + "bad size: %r does not seem to be an array of %s" % + (name, tp.item)) + tp = tp.resolve_length(length) + # 'value' is a which we have to replace with + # a if the N is actually known + if tp.length is not None: + BArray = self.ffi._get_cached_btype(tp) + value = self.ffi.cast(BArray, value) + setattr(library, name, value) + return + # remove ptr= from the library instance, and replace + # it by a property on the class, which reads/writes into ptr[0]. + ptr = value + delattr(library, name) + def getter(library): + return ptr[0] + def setter(library, value): + ptr[0] = value + setattr(type(library), name, property(getter, setter)) + type(library)._cffi_dir.append(name) + + # ---------- + + def _generate_setup_custom(self): + prnt = self._prnt + prnt('static int _cffi_setup_custom(PyObject *lib)') + prnt('{') + prnt(' return %s;' % self._chained_list_constants[True]) + prnt('}') + +cffimod_header = r''' +#include +#include + +/* this block of #ifs should be kept exactly identical between + c/_cffi_backend.c, cffi/vengine_cpy.py, cffi/vengine_gen.py + and cffi/_cffi_include.h */ +#if defined(_MSC_VER) +# include /* for alloca() */ +# if _MSC_VER < 1600 /* MSVC < 2010 */ + typedef __int8 int8_t; + typedef __int16 int16_t; + typedef __int32 int32_t; + typedef __int64 int64_t; + typedef unsigned __int8 uint8_t; + typedef unsigned __int16 uint16_t; + typedef unsigned __int32 uint32_t; + typedef unsigned __int64 uint64_t; + typedef __int8 int_least8_t; + typedef __int16 int_least16_t; + typedef __int32 int_least32_t; + typedef __int64 int_least64_t; + typedef unsigned __int8 uint_least8_t; + typedef unsigned __int16 uint_least16_t; + typedef unsigned __int32 uint_least32_t; + typedef unsigned __int64 uint_least64_t; + typedef __int8 int_fast8_t; + typedef __int16 int_fast16_t; + typedef __int32 int_fast32_t; + typedef __int64 int_fast64_t; + typedef unsigned __int8 uint_fast8_t; + typedef unsigned __int16 uint_fast16_t; + typedef unsigned __int32 uint_fast32_t; + typedef unsigned __int64 uint_fast64_t; + typedef __int64 intmax_t; + typedef unsigned __int64 uintmax_t; +# else +# include +# endif +# if _MSC_VER < 1800 /* MSVC < 2013 */ +# ifndef __cplusplus + typedef unsigned char _Bool; +# endif +# endif +# define _cffi_float_complex_t _Fcomplex /* include for it */ +# define _cffi_double_complex_t _Dcomplex /* include for it */ +#else +# include +# if (defined (__SVR4) && defined (__sun)) || defined(_AIX) || defined(__hpux) +# include +# endif +# define _cffi_float_complex_t float _Complex +# define _cffi_double_complex_t double _Complex +#endif + +#if PY_MAJOR_VERSION < 3 +# undef PyCapsule_CheckExact +# undef PyCapsule_GetPointer +# define PyCapsule_CheckExact(capsule) (PyCObject_Check(capsule)) +# define PyCapsule_GetPointer(capsule, name) \ + (PyCObject_AsVoidPtr(capsule)) +#endif + +#if PY_MAJOR_VERSION >= 3 +# define PyInt_FromLong PyLong_FromLong +#endif + +#define _cffi_from_c_double PyFloat_FromDouble +#define _cffi_from_c_float PyFloat_FromDouble +#define _cffi_from_c_long PyInt_FromLong +#define _cffi_from_c_ulong PyLong_FromUnsignedLong +#define _cffi_from_c_longlong PyLong_FromLongLong +#define _cffi_from_c_ulonglong PyLong_FromUnsignedLongLong +#define _cffi_from_c__Bool PyBool_FromLong + +#define _cffi_to_c_double PyFloat_AsDouble +#define _cffi_to_c_float PyFloat_AsDouble + +#define _cffi_from_c_int_const(x) \ + (((x) > 0) ? \ + ((unsigned long long)(x) <= (unsigned long long)LONG_MAX) ? \ + PyInt_FromLong((long)(x)) : \ + PyLong_FromUnsignedLongLong((unsigned long long)(x)) : \ + ((long long)(x) >= (long long)LONG_MIN) ? \ + PyInt_FromLong((long)(x)) : \ + PyLong_FromLongLong((long long)(x))) + +#define _cffi_from_c_int(x, type) \ + (((type)-1) > 0 ? /* unsigned */ \ + (sizeof(type) < sizeof(long) ? \ + PyInt_FromLong((long)x) : \ + sizeof(type) == sizeof(long) ? \ + PyLong_FromUnsignedLong((unsigned long)x) : \ + PyLong_FromUnsignedLongLong((unsigned long long)x)) : \ + (sizeof(type) <= sizeof(long) ? \ + PyInt_FromLong((long)x) : \ + PyLong_FromLongLong((long long)x))) + +#define _cffi_to_c_int(o, type) \ + ((type)( \ + sizeof(type) == 1 ? (((type)-1) > 0 ? (type)_cffi_to_c_u8(o) \ + : (type)_cffi_to_c_i8(o)) : \ + sizeof(type) == 2 ? (((type)-1) > 0 ? (type)_cffi_to_c_u16(o) \ + : (type)_cffi_to_c_i16(o)) : \ + sizeof(type) == 4 ? (((type)-1) > 0 ? (type)_cffi_to_c_u32(o) \ + : (type)_cffi_to_c_i32(o)) : \ + sizeof(type) == 8 ? (((type)-1) > 0 ? (type)_cffi_to_c_u64(o) \ + : (type)_cffi_to_c_i64(o)) : \ + (Py_FatalError("unsupported size for type " #type), (type)0))) + +#define _cffi_to_c_i8 \ + ((int(*)(PyObject *))_cffi_exports[1]) +#define _cffi_to_c_u8 \ + ((int(*)(PyObject *))_cffi_exports[2]) +#define _cffi_to_c_i16 \ + ((int(*)(PyObject *))_cffi_exports[3]) +#define _cffi_to_c_u16 \ + ((int(*)(PyObject *))_cffi_exports[4]) +#define _cffi_to_c_i32 \ + ((int(*)(PyObject *))_cffi_exports[5]) +#define _cffi_to_c_u32 \ + ((unsigned int(*)(PyObject *))_cffi_exports[6]) +#define _cffi_to_c_i64 \ + ((long long(*)(PyObject *))_cffi_exports[7]) +#define _cffi_to_c_u64 \ + ((unsigned long long(*)(PyObject *))_cffi_exports[8]) +#define _cffi_to_c_char \ + ((int(*)(PyObject *))_cffi_exports[9]) +#define _cffi_from_c_pointer \ + ((PyObject *(*)(char *, CTypeDescrObject *))_cffi_exports[10]) +#define _cffi_to_c_pointer \ + ((char *(*)(PyObject *, CTypeDescrObject *))_cffi_exports[11]) +#define _cffi_get_struct_layout \ + ((PyObject *(*)(Py_ssize_t[]))_cffi_exports[12]) +#define _cffi_restore_errno \ + ((void(*)(void))_cffi_exports[13]) +#define _cffi_save_errno \ + ((void(*)(void))_cffi_exports[14]) +#define _cffi_from_c_char \ + ((PyObject *(*)(char))_cffi_exports[15]) +#define _cffi_from_c_deref \ + ((PyObject *(*)(char *, CTypeDescrObject *))_cffi_exports[16]) +#define _cffi_to_c \ + ((int(*)(char *, CTypeDescrObject *, PyObject *))_cffi_exports[17]) +#define _cffi_from_c_struct \ + ((PyObject *(*)(char *, CTypeDescrObject *))_cffi_exports[18]) +#define _cffi_to_c_wchar_t \ + ((wchar_t(*)(PyObject *))_cffi_exports[19]) +#define _cffi_from_c_wchar_t \ + ((PyObject *(*)(wchar_t))_cffi_exports[20]) +#define _cffi_to_c_long_double \ + ((long double(*)(PyObject *))_cffi_exports[21]) +#define _cffi_to_c__Bool \ + ((_Bool(*)(PyObject *))_cffi_exports[22]) +#define _cffi_prepare_pointer_call_argument \ + ((Py_ssize_t(*)(CTypeDescrObject *, PyObject *, char **))_cffi_exports[23]) +#define _cffi_convert_array_from_object \ + ((int(*)(char *, CTypeDescrObject *, PyObject *))_cffi_exports[24]) +#define _CFFI_NUM_EXPORTS 25 + +typedef struct _ctypedescr CTypeDescrObject; + +static void *_cffi_exports[_CFFI_NUM_EXPORTS]; +static PyObject *_cffi_types, *_cffi_VerificationError; + +static int _cffi_setup_custom(PyObject *lib); /* forward */ + +static PyObject *_cffi_setup(PyObject *self, PyObject *args) +{ + PyObject *library; + int was_alive = (_cffi_types != NULL); + (void)self; /* unused */ + if (!PyArg_ParseTuple(args, "OOO", &_cffi_types, &_cffi_VerificationError, + &library)) + return NULL; + Py_INCREF(_cffi_types); + Py_INCREF(_cffi_VerificationError); + if (_cffi_setup_custom(library) < 0) + return NULL; + return PyBool_FromLong(was_alive); +} + +union _cffi_union_alignment_u { + unsigned char m_char; + unsigned short m_short; + unsigned int m_int; + unsigned long m_long; + unsigned long long m_longlong; + float m_float; + double m_double; + long double m_longdouble; +}; + +struct _cffi_freeme_s { + struct _cffi_freeme_s *next; + union _cffi_union_alignment_u alignment; +}; + +#ifdef __GNUC__ + __attribute__((unused)) +#endif +static int _cffi_convert_array_argument(CTypeDescrObject *ctptr, PyObject *arg, + char **output_data, Py_ssize_t datasize, + struct _cffi_freeme_s **freeme) +{ + char *p; + if (datasize < 0) + return -1; + + p = *output_data; + if (p == NULL) { + struct _cffi_freeme_s *fp = (struct _cffi_freeme_s *)PyObject_Malloc( + offsetof(struct _cffi_freeme_s, alignment) + (size_t)datasize); + if (fp == NULL) + return -1; + fp->next = *freeme; + *freeme = fp; + p = *output_data = (char *)&fp->alignment; + } + memset((void *)p, 0, (size_t)datasize); + return _cffi_convert_array_from_object(p, ctptr, arg); +} + +#ifdef __GNUC__ + __attribute__((unused)) +#endif +static void _cffi_free_array_arguments(struct _cffi_freeme_s *freeme) +{ + do { + void *p = (void *)freeme; + freeme = freeme->next; + PyObject_Free(p); + } while (freeme != NULL); +} + +static int _cffi_init(void) +{ + PyObject *module, *c_api_object = NULL; + + module = PyImport_ImportModule("_cffi_backend"); + if (module == NULL) + goto failure; + + c_api_object = PyObject_GetAttrString(module, "_C_API"); + if (c_api_object == NULL) + goto failure; + if (!PyCapsule_CheckExact(c_api_object)) { + PyErr_SetNone(PyExc_ImportError); + goto failure; + } + memcpy(_cffi_exports, PyCapsule_GetPointer(c_api_object, "cffi"), + _CFFI_NUM_EXPORTS * sizeof(void *)); + + Py_DECREF(module); + Py_DECREF(c_api_object); + return 0; + + failure: + Py_XDECREF(module); + Py_XDECREF(c_api_object); + return -1; +} + +#define _cffi_type(num) ((CTypeDescrObject *)PyList_GET_ITEM(_cffi_types, num)) + +/**********/ +''' diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/vengine_gen.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/vengine_gen.py new file mode 100644 index 0000000..bffc821 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/vengine_gen.py @@ -0,0 +1,679 @@ +# +# DEPRECATED: implementation for ffi.verify() +# +import sys, os +import types + +from . import model +from .error import VerificationError + + +class VGenericEngine(object): + _class_key = 'g' + _gen_python_module = False + + def __init__(self, verifier): + self.verifier = verifier + self.ffi = verifier.ffi + self.export_symbols = [] + self._struct_pending_verification = {} + + def patch_extension_kwds(self, kwds): + # add 'export_symbols' to the dictionary. Note that we add the + # list before filling it. When we fill it, it will thus also show + # up in kwds['export_symbols']. + kwds.setdefault('export_symbols', self.export_symbols) + + def find_module(self, module_name, path, so_suffixes): + for so_suffix in so_suffixes: + basename = module_name + so_suffix + if path is None: + path = sys.path + for dirname in path: + filename = os.path.join(dirname, basename) + if os.path.isfile(filename): + return filename + + def collect_types(self): + pass # not needed in the generic engine + + def _prnt(self, what=''): + self._f.write(what + '\n') + + def write_source_to_f(self): + prnt = self._prnt + # first paste some standard set of lines that are mostly '#include' + prnt(cffimod_header) + # then paste the C source given by the user, verbatim. + prnt(self.verifier.preamble) + # + # call generate_gen_xxx_decl(), for every xxx found from + # ffi._parser._declarations. This generates all the functions. + self._generate('decl') + # + # on Windows, distutils insists on putting init_cffi_xyz in + # 'export_symbols', so instead of fighting it, just give up and + # give it one + if sys.platform == 'win32': + if sys.version_info >= (3,): + prefix = 'PyInit_' + else: + prefix = 'init' + modname = self.verifier.get_module_name() + prnt("void %s%s(void) { }\n" % (prefix, modname)) + + def load_library(self, flags=0): + # import it with the CFFI backend + backend = self.ffi._backend + # needs to make a path that contains '/', on Posix + filename = os.path.join(os.curdir, self.verifier.modulefilename) + module = backend.load_library(filename, flags) + # + # call loading_gen_struct() to get the struct layout inferred by + # the C compiler + self._load(module, 'loading') + + # build the FFILibrary class and instance, this is a module subclass + # because modules are expected to have usually-constant-attributes and + # in PyPy this means the JIT is able to treat attributes as constant, + # which we want. + class FFILibrary(types.ModuleType): + _cffi_generic_module = module + _cffi_ffi = self.ffi + _cffi_dir = [] + def __dir__(self): + return FFILibrary._cffi_dir + library = FFILibrary("") + # + # finally, call the loaded_gen_xxx() functions. This will set + # up the 'library' object. + self._load(module, 'loaded', library=library) + return library + + def _get_declarations(self): + lst = [(key, tp) for (key, (tp, qual)) in + self.ffi._parser._declarations.items()] + lst.sort() + return lst + + def _generate(self, step_name): + for name, tp in self._get_declarations(): + kind, realname = name.split(' ', 1) + try: + method = getattr(self, '_generate_gen_%s_%s' % (kind, + step_name)) + except AttributeError: + raise VerificationError( + "not implemented in verify(): %r" % name) + try: + method(tp, realname) + except Exception as e: + model.attach_exception_info(e, name) + raise + + def _load(self, module, step_name, **kwds): + for name, tp in self._get_declarations(): + kind, realname = name.split(' ', 1) + method = getattr(self, '_%s_gen_%s' % (step_name, kind)) + try: + method(tp, realname, module, **kwds) + except Exception as e: + model.attach_exception_info(e, name) + raise + + def _generate_nothing(self, tp, name): + pass + + def _loaded_noop(self, tp, name, module, **kwds): + pass + + # ---------- + # typedefs: generates no code so far + + _generate_gen_typedef_decl = _generate_nothing + _loading_gen_typedef = _loaded_noop + _loaded_gen_typedef = _loaded_noop + + # ---------- + # function declarations + + def _generate_gen_function_decl(self, tp, name): + assert isinstance(tp, model.FunctionPtrType) + if tp.ellipsis: + # cannot support vararg functions better than this: check for its + # exact type (including the fixed arguments), and build it as a + # constant function pointer (no _cffi_f_%s wrapper) + self._generate_gen_const(False, name, tp) + return + prnt = self._prnt + numargs = len(tp.args) + argnames = [] + for i, type in enumerate(tp.args): + indirection = '' + if isinstance(type, model.StructOrUnion): + indirection = '*' + argnames.append('%sx%d' % (indirection, i)) + context = 'argument of %s' % name + arglist = [type.get_c_name(' %s' % arg, context) + for type, arg in zip(tp.args, argnames)] + tpresult = tp.result + if isinstance(tpresult, model.StructOrUnion): + arglist.insert(0, tpresult.get_c_name(' *r', context)) + tpresult = model.void_type + arglist = ', '.join(arglist) or 'void' + wrappername = '_cffi_f_%s' % name + self.export_symbols.append(wrappername) + if tp.abi: + abi = tp.abi + ' ' + else: + abi = '' + funcdecl = ' %s%s(%s)' % (abi, wrappername, arglist) + context = 'result of %s' % name + prnt(tpresult.get_c_name(funcdecl, context)) + prnt('{') + # + if isinstance(tp.result, model.StructOrUnion): + result_code = '*r = ' + elif not isinstance(tp.result, model.VoidType): + result_code = 'return ' + else: + result_code = '' + prnt(' %s%s(%s);' % (result_code, name, ', '.join(argnames))) + prnt('}') + prnt() + + _loading_gen_function = _loaded_noop + + def _loaded_gen_function(self, tp, name, module, library): + assert isinstance(tp, model.FunctionPtrType) + if tp.ellipsis: + newfunction = self._load_constant(False, tp, name, module) + else: + indirections = [] + base_tp = tp + if (any(isinstance(typ, model.StructOrUnion) for typ in tp.args) + or isinstance(tp.result, model.StructOrUnion)): + indirect_args = [] + for i, typ in enumerate(tp.args): + if isinstance(typ, model.StructOrUnion): + typ = model.PointerType(typ) + indirections.append((i, typ)) + indirect_args.append(typ) + indirect_result = tp.result + if isinstance(indirect_result, model.StructOrUnion): + if indirect_result.fldtypes is None: + raise TypeError("'%s' is used as result type, " + "but is opaque" % ( + indirect_result._get_c_name(),)) + indirect_result = model.PointerType(indirect_result) + indirect_args.insert(0, indirect_result) + indirections.insert(0, ("result", indirect_result)) + indirect_result = model.void_type + tp = model.FunctionPtrType(tuple(indirect_args), + indirect_result, tp.ellipsis) + BFunc = self.ffi._get_cached_btype(tp) + wrappername = '_cffi_f_%s' % name + newfunction = module.load_function(BFunc, wrappername) + for i, typ in indirections: + newfunction = self._make_struct_wrapper(newfunction, i, typ, + base_tp) + setattr(library, name, newfunction) + type(library)._cffi_dir.append(name) + + def _make_struct_wrapper(self, oldfunc, i, tp, base_tp): + backend = self.ffi._backend + BType = self.ffi._get_cached_btype(tp) + if i == "result": + ffi = self.ffi + def newfunc(*args): + res = ffi.new(BType) + oldfunc(res, *args) + return res[0] + else: + def newfunc(*args): + args = args[:i] + (backend.newp(BType, args[i]),) + args[i+1:] + return oldfunc(*args) + newfunc._cffi_base_type = base_tp + return newfunc + + # ---------- + # named structs + + def _generate_gen_struct_decl(self, tp, name): + assert name == tp.name + self._generate_struct_or_union_decl(tp, 'struct', name) + + def _loading_gen_struct(self, tp, name, module): + self._loading_struct_or_union(tp, 'struct', name, module) + + def _loaded_gen_struct(self, tp, name, module, **kwds): + self._loaded_struct_or_union(tp) + + def _generate_gen_union_decl(self, tp, name): + assert name == tp.name + self._generate_struct_or_union_decl(tp, 'union', name) + + def _loading_gen_union(self, tp, name, module): + self._loading_struct_or_union(tp, 'union', name, module) + + def _loaded_gen_union(self, tp, name, module, **kwds): + self._loaded_struct_or_union(tp) + + def _generate_struct_or_union_decl(self, tp, prefix, name): + if tp.fldnames is None: + return # nothing to do with opaque structs + checkfuncname = '_cffi_check_%s_%s' % (prefix, name) + layoutfuncname = '_cffi_layout_%s_%s' % (prefix, name) + cname = ('%s %s' % (prefix, name)).strip() + # + prnt = self._prnt + prnt('static void %s(%s *p)' % (checkfuncname, cname)) + prnt('{') + prnt(' /* only to generate compile-time warnings or errors */') + prnt(' (void)p;') + for fname, ftype, fbitsize, fqual in tp.enumfields(): + if (isinstance(ftype, model.PrimitiveType) + and ftype.is_integer_type()) or fbitsize >= 0: + # accept all integers, but complain on float or double + prnt(' (void)((p->%s) << 1);' % fname) + else: + # only accept exactly the type declared. + try: + prnt(' { %s = &p->%s; (void)tmp; }' % ( + ftype.get_c_name('*tmp', 'field %r'%fname, quals=fqual), + fname)) + except VerificationError as e: + prnt(' /* %s */' % str(e)) # cannot verify it, ignore + prnt('}') + self.export_symbols.append(layoutfuncname) + prnt('intptr_t %s(intptr_t i)' % (layoutfuncname,)) + prnt('{') + prnt(' struct _cffi_aligncheck { char x; %s y; };' % cname) + prnt(' static intptr_t nums[] = {') + prnt(' sizeof(%s),' % cname) + prnt(' offsetof(struct _cffi_aligncheck, y),') + for fname, ftype, fbitsize, fqual in tp.enumfields(): + if fbitsize >= 0: + continue # xxx ignore fbitsize for now + prnt(' offsetof(%s, %s),' % (cname, fname)) + if isinstance(ftype, model.ArrayType) and ftype.length is None: + prnt(' 0, /* %s */' % ftype._get_c_name()) + else: + prnt(' sizeof(((%s *)0)->%s),' % (cname, fname)) + prnt(' -1') + prnt(' };') + prnt(' return nums[i];') + prnt(' /* the next line is not executed, but compiled */') + prnt(' %s(0);' % (checkfuncname,)) + prnt('}') + prnt() + + def _loading_struct_or_union(self, tp, prefix, name, module): + if tp.fldnames is None: + return # nothing to do with opaque structs + layoutfuncname = '_cffi_layout_%s_%s' % (prefix, name) + # + BFunc = self.ffi._typeof_locked("intptr_t(*)(intptr_t)")[0] + function = module.load_function(BFunc, layoutfuncname) + layout = [] + num = 0 + while True: + x = function(num) + if x < 0: break + layout.append(x) + num += 1 + if isinstance(tp, model.StructOrUnion) and tp.partial: + # use the function()'s sizes and offsets to guide the + # layout of the struct + totalsize = layout[0] + totalalignment = layout[1] + fieldofs = layout[2::2] + fieldsize = layout[3::2] + tp.force_flatten() + assert len(fieldofs) == len(fieldsize) == len(tp.fldnames) + tp.fixedlayout = fieldofs, fieldsize, totalsize, totalalignment + else: + cname = ('%s %s' % (prefix, name)).strip() + self._struct_pending_verification[tp] = layout, cname + + def _loaded_struct_or_union(self, tp): + if tp.fldnames is None: + return # nothing to do with opaque structs + self.ffi._get_cached_btype(tp) # force 'fixedlayout' to be considered + + if tp in self._struct_pending_verification: + # check that the layout sizes and offsets match the real ones + def check(realvalue, expectedvalue, msg): + if realvalue != expectedvalue: + raise VerificationError( + "%s (we have %d, but C compiler says %d)" + % (msg, expectedvalue, realvalue)) + ffi = self.ffi + BStruct = ffi._get_cached_btype(tp) + layout, cname = self._struct_pending_verification.pop(tp) + check(layout[0], ffi.sizeof(BStruct), "wrong total size") + check(layout[1], ffi.alignof(BStruct), "wrong total alignment") + i = 2 + for fname, ftype, fbitsize, fqual in tp.enumfields(): + if fbitsize >= 0: + continue # xxx ignore fbitsize for now + check(layout[i], ffi.offsetof(BStruct, fname), + "wrong offset for field %r" % (fname,)) + if layout[i+1] != 0: + BField = ffi._get_cached_btype(ftype) + check(layout[i+1], ffi.sizeof(BField), + "wrong size for field %r" % (fname,)) + i += 2 + assert i == len(layout) + + # ---------- + # 'anonymous' declarations. These are produced for anonymous structs + # or unions; the 'name' is obtained by a typedef. + + def _generate_gen_anonymous_decl(self, tp, name): + if isinstance(tp, model.EnumType): + self._generate_gen_enum_decl(tp, name, '') + else: + self._generate_struct_or_union_decl(tp, '', name) + + def _loading_gen_anonymous(self, tp, name, module): + if isinstance(tp, model.EnumType): + self._loading_gen_enum(tp, name, module, '') + else: + self._loading_struct_or_union(tp, '', name, module) + + def _loaded_gen_anonymous(self, tp, name, module, **kwds): + if isinstance(tp, model.EnumType): + self._loaded_gen_enum(tp, name, module, **kwds) + else: + self._loaded_struct_or_union(tp) + + # ---------- + # constants, likely declared with '#define' + + def _generate_gen_const(self, is_int, name, tp=None, category='const', + check_value=None): + prnt = self._prnt + funcname = '_cffi_%s_%s' % (category, name) + self.export_symbols.append(funcname) + if check_value is not None: + assert is_int + assert category == 'const' + prnt('int %s(char *out_error)' % funcname) + prnt('{') + self._check_int_constant_value(name, check_value) + prnt(' return 0;') + prnt('}') + elif is_int: + assert category == 'const' + prnt('int %s(long long *out_value)' % funcname) + prnt('{') + prnt(' *out_value = (long long)(%s);' % (name,)) + prnt(' return (%s) <= 0;' % (name,)) + prnt('}') + else: + assert tp is not None + assert check_value is None + if category == 'var': + ampersand = '&' + else: + ampersand = '' + extra = '' + if category == 'const' and isinstance(tp, model.StructOrUnion): + extra = 'const *' + ampersand = '&' + prnt(tp.get_c_name(' %s%s(void)' % (extra, funcname), name)) + prnt('{') + prnt(' return (%s%s);' % (ampersand, name)) + prnt('}') + prnt() + + def _generate_gen_constant_decl(self, tp, name): + is_int = isinstance(tp, model.PrimitiveType) and tp.is_integer_type() + self._generate_gen_const(is_int, name, tp) + + _loading_gen_constant = _loaded_noop + + def _load_constant(self, is_int, tp, name, module, check_value=None): + funcname = '_cffi_const_%s' % name + if check_value is not None: + assert is_int + self._load_known_int_constant(module, funcname) + value = check_value + elif is_int: + BType = self.ffi._typeof_locked("long long*")[0] + BFunc = self.ffi._typeof_locked("int(*)(long long*)")[0] + function = module.load_function(BFunc, funcname) + p = self.ffi.new(BType) + negative = function(p) + value = int(p[0]) + if value < 0 and not negative: + BLongLong = self.ffi._typeof_locked("long long")[0] + value += (1 << (8*self.ffi.sizeof(BLongLong))) + else: + assert check_value is None + fntypeextra = '(*)(void)' + if isinstance(tp, model.StructOrUnion): + fntypeextra = '*' + fntypeextra + BFunc = self.ffi._typeof_locked(tp.get_c_name(fntypeextra, name))[0] + function = module.load_function(BFunc, funcname) + value = function() + if isinstance(tp, model.StructOrUnion): + value = value[0] + return value + + def _loaded_gen_constant(self, tp, name, module, library): + is_int = isinstance(tp, model.PrimitiveType) and tp.is_integer_type() + value = self._load_constant(is_int, tp, name, module) + setattr(library, name, value) + type(library)._cffi_dir.append(name) + + # ---------- + # enums + + def _check_int_constant_value(self, name, value): + prnt = self._prnt + if value <= 0: + prnt(' if ((%s) > 0 || (long)(%s) != %dL) {' % ( + name, name, value)) + else: + prnt(' if ((%s) <= 0 || (unsigned long)(%s) != %dUL) {' % ( + name, name, value)) + prnt(' char buf[64];') + prnt(' if ((%s) <= 0)' % name) + prnt(' sprintf(buf, "%%ld", (long)(%s));' % name) + prnt(' else') + prnt(' sprintf(buf, "%%lu", (unsigned long)(%s));' % + name) + prnt(' sprintf(out_error, "%s has the real value %s, not %s",') + prnt(' "%s", buf, "%d");' % (name[:100], value)) + prnt(' return -1;') + prnt(' }') + + def _load_known_int_constant(self, module, funcname): + BType = self.ffi._typeof_locked("char[]")[0] + BFunc = self.ffi._typeof_locked("int(*)(char*)")[0] + function = module.load_function(BFunc, funcname) + p = self.ffi.new(BType, 256) + if function(p) < 0: + error = self.ffi.string(p) + if sys.version_info >= (3,): + error = str(error, 'utf-8') + raise VerificationError(error) + + def _enum_funcname(self, prefix, name): + # "$enum_$1" => "___D_enum____D_1" + name = name.replace('$', '___D_') + return '_cffi_e_%s_%s' % (prefix, name) + + def _generate_gen_enum_decl(self, tp, name, prefix='enum'): + if tp.partial: + for enumerator in tp.enumerators: + self._generate_gen_const(True, enumerator) + return + # + funcname = self._enum_funcname(prefix, name) + self.export_symbols.append(funcname) + prnt = self._prnt + prnt('int %s(char *out_error)' % funcname) + prnt('{') + for enumerator, enumvalue in zip(tp.enumerators, tp.enumvalues): + self._check_int_constant_value(enumerator, enumvalue) + prnt(' return 0;') + prnt('}') + prnt() + + def _loading_gen_enum(self, tp, name, module, prefix='enum'): + if tp.partial: + enumvalues = [self._load_constant(True, tp, enumerator, module) + for enumerator in tp.enumerators] + tp.enumvalues = tuple(enumvalues) + tp.partial_resolved = True + else: + funcname = self._enum_funcname(prefix, name) + self._load_known_int_constant(module, funcname) + + def _loaded_gen_enum(self, tp, name, module, library): + for enumerator, enumvalue in zip(tp.enumerators, tp.enumvalues): + setattr(library, enumerator, enumvalue) + type(library)._cffi_dir.append(enumerator) + + # ---------- + # macros: for now only for integers + + def _generate_gen_macro_decl(self, tp, name): + if tp == '...': + check_value = None + else: + check_value = tp # an integer + self._generate_gen_const(True, name, check_value=check_value) + + _loading_gen_macro = _loaded_noop + + def _loaded_gen_macro(self, tp, name, module, library): + if tp == '...': + check_value = None + else: + check_value = tp # an integer + value = self._load_constant(True, tp, name, module, + check_value=check_value) + setattr(library, name, value) + type(library)._cffi_dir.append(name) + + # ---------- + # global variables + + def _generate_gen_variable_decl(self, tp, name): + if isinstance(tp, model.ArrayType): + if tp.length_is_unknown(): + prnt = self._prnt + funcname = '_cffi_sizeof_%s' % (name,) + self.export_symbols.append(funcname) + prnt("size_t %s(void)" % funcname) + prnt("{") + prnt(" return sizeof(%s);" % (name,)) + prnt("}") + tp_ptr = model.PointerType(tp.item) + self._generate_gen_const(False, name, tp_ptr) + else: + tp_ptr = model.PointerType(tp) + self._generate_gen_const(False, name, tp_ptr, category='var') + + _loading_gen_variable = _loaded_noop + + def _loaded_gen_variable(self, tp, name, module, library): + if isinstance(tp, model.ArrayType): # int a[5] is "constant" in the + # sense that "a=..." is forbidden + if tp.length_is_unknown(): + funcname = '_cffi_sizeof_%s' % (name,) + BFunc = self.ffi._typeof_locked('size_t(*)(void)')[0] + function = module.load_function(BFunc, funcname) + size = function() + BItemType = self.ffi._get_cached_btype(tp.item) + length, rest = divmod(size, self.ffi.sizeof(BItemType)) + if rest != 0: + raise VerificationError( + "bad size: %r does not seem to be an array of %s" % + (name, tp.item)) + tp = tp.resolve_length(length) + tp_ptr = model.PointerType(tp.item) + value = self._load_constant(False, tp_ptr, name, module) + # 'value' is a which we have to replace with + # a if the N is actually known + if tp.length is not None: + BArray = self.ffi._get_cached_btype(tp) + value = self.ffi.cast(BArray, value) + setattr(library, name, value) + type(library)._cffi_dir.append(name) + return + # remove ptr= from the library instance, and replace + # it by a property on the class, which reads/writes into ptr[0]. + funcname = '_cffi_var_%s' % name + BFunc = self.ffi._typeof_locked(tp.get_c_name('*(*)(void)', name))[0] + function = module.load_function(BFunc, funcname) + ptr = function() + def getter(library): + return ptr[0] + def setter(library, value): + ptr[0] = value + setattr(type(library), name, property(getter, setter)) + type(library)._cffi_dir.append(name) + +cffimod_header = r''' +#include +#include +#include +#include +#include /* XXX for ssize_t on some platforms */ + +/* this block of #ifs should be kept exactly identical between + c/_cffi_backend.c, cffi/vengine_cpy.py, cffi/vengine_gen.py + and cffi/_cffi_include.h */ +#if defined(_MSC_VER) +# include /* for alloca() */ +# if _MSC_VER < 1600 /* MSVC < 2010 */ + typedef __int8 int8_t; + typedef __int16 int16_t; + typedef __int32 int32_t; + typedef __int64 int64_t; + typedef unsigned __int8 uint8_t; + typedef unsigned __int16 uint16_t; + typedef unsigned __int32 uint32_t; + typedef unsigned __int64 uint64_t; + typedef __int8 int_least8_t; + typedef __int16 int_least16_t; + typedef __int32 int_least32_t; + typedef __int64 int_least64_t; + typedef unsigned __int8 uint_least8_t; + typedef unsigned __int16 uint_least16_t; + typedef unsigned __int32 uint_least32_t; + typedef unsigned __int64 uint_least64_t; + typedef __int8 int_fast8_t; + typedef __int16 int_fast16_t; + typedef __int32 int_fast32_t; + typedef __int64 int_fast64_t; + typedef unsigned __int8 uint_fast8_t; + typedef unsigned __int16 uint_fast16_t; + typedef unsigned __int32 uint_fast32_t; + typedef unsigned __int64 uint_fast64_t; + typedef __int64 intmax_t; + typedef unsigned __int64 uintmax_t; +# else +# include +# endif +# if _MSC_VER < 1800 /* MSVC < 2013 */ +# ifndef __cplusplus + typedef unsigned char _Bool; +# endif +# endif +# define _cffi_float_complex_t _Fcomplex /* include for it */ +# define _cffi_double_complex_t _Dcomplex /* include for it */ +#else +# include +# if (defined (__SVR4) && defined (__sun)) || defined(_AIX) || defined(__hpux) +# include +# endif +# define _cffi_float_complex_t float _Complex +# define _cffi_double_complex_t double _Complex +#endif +''' diff --git a/PyGC/.venv/lib/python3.11/site-packages/cffi/verifier.py b/PyGC/.venv/lib/python3.11/site-packages/cffi/verifier.py new file mode 100644 index 0000000..e392a2b --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cffi/verifier.py @@ -0,0 +1,306 @@ +# +# DEPRECATED: implementation for ffi.verify() +# +import sys, os, binascii, shutil, io +from . import __version_verifier_modules__ +from . import ffiplatform +from .error import VerificationError + +if sys.version_info >= (3, 3): + import importlib.machinery + def _extension_suffixes(): + return importlib.machinery.EXTENSION_SUFFIXES[:] +else: + import imp + def _extension_suffixes(): + return [suffix for suffix, _, type in imp.get_suffixes() + if type == imp.C_EXTENSION] + + +if sys.version_info >= (3,): + NativeIO = io.StringIO +else: + class NativeIO(io.BytesIO): + def write(self, s): + if isinstance(s, unicode): + s = s.encode('ascii') + super(NativeIO, self).write(s) + + +class Verifier(object): + + def __init__(self, ffi, preamble, tmpdir=None, modulename=None, + ext_package=None, tag='', force_generic_engine=False, + source_extension='.c', flags=None, relative_to=None, **kwds): + if ffi._parser._uses_new_feature: + raise VerificationError( + "feature not supported with ffi.verify(), but only " + "with ffi.set_source(): %s" % (ffi._parser._uses_new_feature,)) + self.ffi = ffi + self.preamble = preamble + if not modulename: + flattened_kwds = ffiplatform.flatten(kwds) + vengine_class = _locate_engine_class(ffi, force_generic_engine) + self._vengine = vengine_class(self) + self._vengine.patch_extension_kwds(kwds) + self.flags = flags + self.kwds = self.make_relative_to(kwds, relative_to) + # + if modulename: + if tag: + raise TypeError("can't specify both 'modulename' and 'tag'") + else: + key = '\x00'.join(['%d.%d' % sys.version_info[:2], + __version_verifier_modules__, + preamble, flattened_kwds] + + ffi._cdefsources) + if sys.version_info >= (3,): + key = key.encode('utf-8') + k1 = hex(binascii.crc32(key[0::2]) & 0xffffffff) + k1 = k1.lstrip('0x').rstrip('L') + k2 = hex(binascii.crc32(key[1::2]) & 0xffffffff) + k2 = k2.lstrip('0').rstrip('L') + modulename = '_cffi_%s_%s%s%s' % (tag, self._vengine._class_key, + k1, k2) + suffix = _get_so_suffixes()[0] + self.tmpdir = tmpdir or _caller_dir_pycache() + self.sourcefilename = os.path.join(self.tmpdir, modulename + source_extension) + self.modulefilename = os.path.join(self.tmpdir, modulename + suffix) + self.ext_package = ext_package + self._has_source = False + self._has_module = False + + def write_source(self, file=None): + """Write the C source code. It is produced in 'self.sourcefilename', + which can be tweaked beforehand.""" + with self.ffi._lock: + if self._has_source and file is None: + raise VerificationError( + "source code already written") + self._write_source(file) + + def compile_module(self): + """Write the C source code (if not done already) and compile it. + This produces a dynamic link library in 'self.modulefilename'.""" + with self.ffi._lock: + if self._has_module: + raise VerificationError("module already compiled") + if not self._has_source: + self._write_source() + self._compile_module() + + def load_library(self): + """Get a C module from this Verifier instance. + Returns an instance of a FFILibrary class that behaves like the + objects returned by ffi.dlopen(), but that delegates all + operations to the C module. If necessary, the C code is written + and compiled first. + """ + with self.ffi._lock: + if not self._has_module: + self._locate_module() + if not self._has_module: + if not self._has_source: + self._write_source() + self._compile_module() + return self._load_library() + + def get_module_name(self): + basename = os.path.basename(self.modulefilename) + # kill both the .so extension and the other .'s, as introduced + # by Python 3: 'basename.cpython-33m.so' + basename = basename.split('.', 1)[0] + # and the _d added in Python 2 debug builds --- but try to be + # conservative and not kill a legitimate _d + if basename.endswith('_d') and hasattr(sys, 'gettotalrefcount'): + basename = basename[:-2] + return basename + + def get_extension(self): + if not self._has_source: + with self.ffi._lock: + if not self._has_source: + self._write_source() + sourcename = ffiplatform.maybe_relative_path(self.sourcefilename) + modname = self.get_module_name() + return ffiplatform.get_extension(sourcename, modname, **self.kwds) + + def generates_python_module(self): + return self._vengine._gen_python_module + + def make_relative_to(self, kwds, relative_to): + if relative_to and os.path.dirname(relative_to): + dirname = os.path.dirname(relative_to) + kwds = kwds.copy() + for key in ffiplatform.LIST_OF_FILE_NAMES: + if key in kwds: + lst = kwds[key] + if not isinstance(lst, (list, tuple)): + raise TypeError("keyword '%s' should be a list or tuple" + % (key,)) + lst = [os.path.join(dirname, fn) for fn in lst] + kwds[key] = lst + return kwds + + # ---------- + + def _locate_module(self): + if not os.path.isfile(self.modulefilename): + if self.ext_package: + try: + pkg = __import__(self.ext_package, None, None, ['__doc__']) + except ImportError: + return # cannot import the package itself, give up + # (e.g. it might be called differently before installation) + path = pkg.__path__ + else: + path = None + filename = self._vengine.find_module(self.get_module_name(), path, + _get_so_suffixes()) + if filename is None: + return + self.modulefilename = filename + self._vengine.collect_types() + self._has_module = True + + def _write_source_to(self, file): + self._vengine._f = file + try: + self._vengine.write_source_to_f() + finally: + del self._vengine._f + + def _write_source(self, file=None): + if file is not None: + self._write_source_to(file) + else: + # Write our source file to an in memory file. + f = NativeIO() + self._write_source_to(f) + source_data = f.getvalue() + + # Determine if this matches the current file + if os.path.exists(self.sourcefilename): + with open(self.sourcefilename, "r") as fp: + needs_written = not (fp.read() == source_data) + else: + needs_written = True + + # Actually write the file out if it doesn't match + if needs_written: + _ensure_dir(self.sourcefilename) + with open(self.sourcefilename, "w") as fp: + fp.write(source_data) + + # Set this flag + self._has_source = True + + def _compile_module(self): + # compile this C source + tmpdir = os.path.dirname(self.sourcefilename) + outputfilename = ffiplatform.compile(tmpdir, self.get_extension()) + try: + same = ffiplatform.samefile(outputfilename, self.modulefilename) + except OSError: + same = False + if not same: + _ensure_dir(self.modulefilename) + shutil.move(outputfilename, self.modulefilename) + self._has_module = True + + def _load_library(self): + assert self._has_module + if self.flags is not None: + return self._vengine.load_library(self.flags) + else: + return self._vengine.load_library() + +# ____________________________________________________________ + +_FORCE_GENERIC_ENGINE = False # for tests + +def _locate_engine_class(ffi, force_generic_engine): + if _FORCE_GENERIC_ENGINE: + force_generic_engine = True + if not force_generic_engine: + if '__pypy__' in sys.builtin_module_names: + force_generic_engine = True + else: + try: + import _cffi_backend + except ImportError: + _cffi_backend = '?' + if ffi._backend is not _cffi_backend: + force_generic_engine = True + if force_generic_engine: + from . import vengine_gen + return vengine_gen.VGenericEngine + else: + from . import vengine_cpy + return vengine_cpy.VCPythonEngine + +# ____________________________________________________________ + +_TMPDIR = None + +def _caller_dir_pycache(): + if _TMPDIR: + return _TMPDIR + result = os.environ.get('CFFI_TMPDIR') + if result: + return result + filename = sys._getframe(2).f_code.co_filename + return os.path.abspath(os.path.join(os.path.dirname(filename), + '__pycache__')) + +def set_tmpdir(dirname): + """Set the temporary directory to use instead of __pycache__.""" + global _TMPDIR + _TMPDIR = dirname + +def cleanup_tmpdir(tmpdir=None, keep_so=False): + """Clean up the temporary directory by removing all files in it + called `_cffi_*.{c,so}` as well as the `build` subdirectory.""" + tmpdir = tmpdir or _caller_dir_pycache() + try: + filelist = os.listdir(tmpdir) + except OSError: + return + if keep_so: + suffix = '.c' # only remove .c files + else: + suffix = _get_so_suffixes()[0].lower() + for fn in filelist: + if fn.lower().startswith('_cffi_') and ( + fn.lower().endswith(suffix) or fn.lower().endswith('.c')): + try: + os.unlink(os.path.join(tmpdir, fn)) + except OSError: + pass + clean_dir = [os.path.join(tmpdir, 'build')] + for dir in clean_dir: + try: + for fn in os.listdir(dir): + fn = os.path.join(dir, fn) + if os.path.isdir(fn): + clean_dir.append(fn) + else: + os.unlink(fn) + except OSError: + pass + +def _get_so_suffixes(): + suffixes = _extension_suffixes() + if not suffixes: + # bah, no C_EXTENSION available. Occurs on pypy without cpyext + if sys.platform == 'win32': + suffixes = [".pyd"] + else: + suffixes = [".so"] + + return suffixes + +def _ensure_dir(filename): + dirname = os.path.dirname(filename) + if dirname and not os.path.isdir(dirname): + os.makedirs(dirname) diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/INSTALLER b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/LICENSE b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/LICENSE similarity index 95% rename from LICENSE rename to PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/LICENSE index 1af74c9..ad82355 100644 --- a/LICENSE +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/LICENSE @@ -1,6 +1,6 @@ MIT License -Copyright (c) 2024 C/A +Copyright (c) 2019 TAHRI Ahmed R. Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal @@ -18,4 +18,4 @@ 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. +SOFTWARE. \ No newline at end of file diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/METADATA b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/METADATA new file mode 100644 index 0000000..822550e --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/METADATA @@ -0,0 +1,683 @@ +Metadata-Version: 2.1 +Name: charset-normalizer +Version: 3.3.2 +Summary: The Real First Universal Charset Detector. Open, modern and actively maintained alternative to Chardet. +Home-page: https://github.com/Ousret/charset_normalizer +Author: Ahmed TAHRI +Author-email: ahmed.tahri@cloudnursery.dev +License: MIT +Project-URL: Bug Reports, https://github.com/Ousret/charset_normalizer/issues +Project-URL: Documentation, https://charset-normalizer.readthedocs.io/en/latest +Keywords: encoding,charset,charset-detector,detector,normalization,unicode,chardet,detect +Classifier: Development Status :: 5 - Production/Stable +Classifier: License :: OSI Approved :: MIT License +Classifier: Intended Audience :: Developers +Classifier: Topic :: Software Development :: Libraries :: Python Modules +Classifier: Operating System :: OS Independent +Classifier: Programming Language :: Python +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3.7 +Classifier: Programming Language :: Python :: 3.8 +Classifier: Programming Language :: Python :: 3.9 +Classifier: Programming Language :: Python :: 3.10 +Classifier: Programming Language :: Python :: 3.11 +Classifier: Programming Language :: Python :: 3.12 +Classifier: Programming Language :: Python :: Implementation :: PyPy +Classifier: Topic :: Text Processing :: Linguistic +Classifier: Topic :: Utilities +Classifier: Typing :: Typed +Requires-Python: >=3.7.0 +Description-Content-Type: text/markdown +License-File: LICENSE +Provides-Extra: unicode_backport + +

Charset Detection, for Everyone 👋

+ +

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

+

+ Featured Packages
+ + Static Badge + + + Static Badge + +

+

+ In other language (unofficial port - by the community)
+ + Static Badge + +

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

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

+ +This project offers you an alternative to **Universal Charset Encoding Detector**, also known as **Chardet**. + +| Feature | [Chardet](https://github.com/chardet/chardet) | Charset Normalizer | [cChardet](https://github.com/PyYoshi/cChardet) | +|--------------------------------------------------|:---------------------------------------------:|:--------------------------------------------------------------------------------------------------:|:-----------------------------------------------:| +| `Fast` | ❌ | ✅ | ✅ | +| `Universal**` | ❌ | ✅ | ❌ | +| `Reliable` **without** distinguishable standards | ❌ | ✅ | ✅ | +| `Reliable` **with** distinguishable standards | ✅ | ✅ | ✅ | +| `License` | LGPL-2.1
_restrictive_ | MIT | MPL-1.1
_restrictive_ | +| `Native Python` | ✅ | ✅ | ❌ | +| `Detect spoken language` | ❌ | ✅ | N/A | +| `UnicodeDecodeError Safety` | ❌ | ✅ | ❌ | +| `Whl Size (min)` | 193.6 kB | 42 kB | ~200 kB | +| `Supported Encoding` | 33 | 🎉 [99](https://charset-normalizer.readthedocs.io/en/latest/user/support.html#supported-encodings) | 40 | + +

+Reading Normalized TextCat Reading Text +

+ +*\*\* : They are clearly using specific code for a specific encoding even if covering most of used one*
+Did you got there because of the logs? See [https://charset-normalizer.readthedocs.io/en/latest/user/miscellaneous.html](https://charset-normalizer.readthedocs.io/en/latest/user/miscellaneous.html) + +## ⚡ Performance + +This package offer better performance than its counterpart Chardet. Here are some numbers. + +| Package | Accuracy | Mean per file (ms) | File per sec (est) | +|-----------------------------------------------|:--------:|:------------------:|:------------------:| +| [chardet](https://github.com/chardet/chardet) | 86 % | 200 ms | 5 file/sec | +| charset-normalizer | **98 %** | **10 ms** | 100 file/sec | + +| Package | 99th percentile | 95th percentile | 50th percentile | +|-----------------------------------------------|:---------------:|:---------------:|:---------------:| +| [chardet](https://github.com/chardet/chardet) | 1200 ms | 287 ms | 23 ms | +| charset-normalizer | 100 ms | 50 ms | 5 ms | + +Chardet's performance on larger file (1MB+) are very poor. Expect huge difference on large payload. + +> Stats are generated using 400+ files using default parameters. More details on used files, see GHA workflows. +> And yes, these results might change at any time. The dataset can be updated to include more files. +> The actual delays heavily depends on your CPU capabilities. The factors should remain the same. +> Keep in mind that the stats are generous and that Chardet accuracy vs our is measured using Chardet initial capability +> (eg. Supported Encoding) Challenge-them if you want. + +## ✨ Installation + +Using pip: + +```sh +pip install charset-normalizer -U +``` + +## 🚀 Basic Usage + +### CLI +This package comes with a CLI. + +``` +usage: normalizer [-h] [-v] [-a] [-n] [-m] [-r] [-f] [-t THRESHOLD] + file [file ...] + +The Real First Universal Charset Detector. Discover originating encoding used +on text file. Normalize text to unicode. + +positional arguments: + files File(s) to be analysed + +optional arguments: + -h, --help show this help message and exit + -v, --verbose Display complementary information about file if any. + Stdout will contain logs about the detection process. + -a, --with-alternative + Output complementary possibilities if any. Top-level + JSON WILL be a list. + -n, --normalize Permit to normalize input file. If not set, program + does not write anything. + -m, --minimal Only output the charset detected to STDOUT. Disabling + JSON output. + -r, --replace Replace file when trying to normalize it instead of + creating a new one. + -f, --force Replace file without asking if you are sure, use this + flag with caution. + -t THRESHOLD, --threshold THRESHOLD + Define a custom maximum amount of chaos allowed in + decoded content. 0. <= chaos <= 1. + --version Show version information and exit. +``` + +```bash +normalizer ./data/sample.1.fr.srt +``` + +or + +```bash +python -m charset_normalizer ./data/sample.1.fr.srt +``` + +🎉 Since version 1.4.0 the CLI produce easily usable stdout result in JSON format. + +```json +{ + "path": "/home/default/projects/charset_normalizer/data/sample.1.fr.srt", + "encoding": "cp1252", + "encoding_aliases": [ + "1252", + "windows_1252" + ], + "alternative_encodings": [ + "cp1254", + "cp1256", + "cp1258", + "iso8859_14", + "iso8859_15", + "iso8859_16", + "iso8859_3", + "iso8859_9", + "latin_1", + "mbcs" + ], + "language": "French", + "alphabets": [ + "Basic Latin", + "Latin-1 Supplement" + ], + "has_sig_or_bom": false, + "chaos": 0.149, + "coherence": 97.152, + "unicode_path": null, + "is_preferred": true +} +``` + +### Python +*Just print out normalized text* +```python +from charset_normalizer import from_path + +results = from_path('./my_subtitle.srt') + +print(str(results.best())) +``` + +*Upgrade your code without effort* +```python +from charset_normalizer import detect +``` + +The above code will behave the same as **chardet**. We ensure that we offer the best (reasonable) BC result possible. + +See the docs for advanced usage : [readthedocs.io](https://charset-normalizer.readthedocs.io/en/latest/) + +## 😇 Why + +When I started using Chardet, I noticed that it was not suited to my expectations, and I wanted to propose a +reliable alternative using a completely different method. Also! I never back down on a good challenge! + +I **don't care** about the **originating charset** encoding, because **two different tables** can +produce **two identical rendered string.** +What I want is to get readable text, the best I can. + +In a way, **I'm brute forcing text decoding.** How cool is that ? 😎 + +Don't confuse package **ftfy** with charset-normalizer or chardet. ftfy goal is to repair unicode string whereas charset-normalizer to convert raw file in unknown encoding to unicode. + +## 🍰 How + + - Discard all charset encoding table that could not fit the binary content. + - Measure noise, or the mess once opened (by chunks) with a corresponding charset encoding. + - Extract matches with the lowest mess detected. + - Additionally, we measure coherence / probe for a language. + +**Wait a minute**, what is noise/mess and coherence according to **YOU ?** + +*Noise :* I opened hundred of text files, **written by humans**, with the wrong encoding table. **I observed**, then +**I established** some ground rules about **what is obvious** when **it seems like** a mess. + I know that my interpretation of what is noise is probably incomplete, feel free to contribute in order to + improve or rewrite it. + +*Coherence :* For each language there is on earth, we have computed ranked letter appearance occurrences (the best we can). So I thought +that intel is worth something here. So I use those records against decoded text to check if I can detect intelligent design. + +## ⚡ Known limitations + + - Language detection is unreliable when text contains two or more languages sharing identical letters. (eg. HTML (english tags) + Turkish content (Sharing Latin characters)) + - Every charset detector heavily depends on sufficient content. In common cases, do not bother run detection on very tiny content. + +## ⚠️ About Python EOLs + +**If you are running:** + +- Python >=2.7,<3.5: Unsupported +- Python 3.5: charset-normalizer < 2.1 +- Python 3.6: charset-normalizer < 3.1 +- Python 3.7: charset-normalizer < 4.0 + +Upgrade your Python interpreter as soon as possible. + +## 👤 Contributing + +Contributions, issues and feature requests are very much welcome.
+Feel free to check [issues page](https://github.com/ousret/charset_normalizer/issues) if you want to contribute. + +## 📝 License + +Copyright © [Ahmed TAHRI @Ousret](https://github.com/Ousret).
+This project is [MIT](https://github.com/Ousret/charset_normalizer/blob/master/LICENSE) licensed. + +Characters frequencies used in this project © 2012 [Denny Vrandečić](http://simia.net/letters/) + +## 💼 For Enterprise + +Professional support for charset-normalizer is available as part of the [Tidelift +Subscription][1]. Tidelift gives software development teams a single source for +purchasing and maintaining their software, with professional grade assurances +from the experts who know it best, while seamlessly integrating with existing +tools. + +[1]: https://tidelift.com/subscription/pkg/pypi-charset-normalizer?utm_source=pypi-charset-normalizer&utm_medium=readme + +# Changelog +All notable changes to charset-normalizer will be documented in this file. This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). +The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/). + +## [3.3.2](https://github.com/Ousret/charset_normalizer/compare/3.3.1...3.3.2) (2023-10-31) + +### Fixed +- Unintentional memory usage regression when using large payload that match several encoding (#376) +- Regression on some detection case showcased in the documentation (#371) + +### Added +- Noise (md) probe that identify malformed arabic representation due to the presence of letters in isolated form (credit to my wife) + +## [3.3.1](https://github.com/Ousret/charset_normalizer/compare/3.3.0...3.3.1) (2023-10-22) + +### Changed +- Optional mypyc compilation upgraded to version 1.6.1 for Python >= 3.8 +- Improved the general detection reliability based on reports from the community + +## [3.3.0](https://github.com/Ousret/charset_normalizer/compare/3.2.0...3.3.0) (2023-09-30) + +### Added +- Allow to execute the CLI (e.g. normalizer) through `python -m charset_normalizer.cli` or `python -m charset_normalizer` +- Support for 9 forgotten encoding that are supported by Python but unlisted in `encoding.aliases` as they have no alias (#323) + +### Removed +- (internal) Redundant utils.is_ascii function and unused function is_private_use_only +- (internal) charset_normalizer.assets is moved inside charset_normalizer.constant + +### Changed +- (internal) Unicode code blocks in constants are updated using the latest v15.0.0 definition to improve detection +- Optional mypyc compilation upgraded to version 1.5.1 for Python >= 3.8 + +### Fixed +- Unable to properly sort CharsetMatch when both chaos/noise and coherence were close due to an unreachable condition in \_\_lt\_\_ (#350) + +## [3.2.0](https://github.com/Ousret/charset_normalizer/compare/3.1.0...3.2.0) (2023-06-07) + +### Changed +- Typehint for function `from_path` no longer enforce `PathLike` as its first argument +- Minor improvement over the global detection reliability + +### Added +- Introduce function `is_binary` that relies on main capabilities, and optimized to detect binaries +- Propagate `enable_fallback` argument throughout `from_bytes`, `from_path`, and `from_fp` that allow a deeper control over the detection (default True) +- Explicit support for Python 3.12 + +### Fixed +- Edge case detection failure where a file would contain 'very-long' camel cased word (Issue #289) + +## [3.1.0](https://github.com/Ousret/charset_normalizer/compare/3.0.1...3.1.0) (2023-03-06) + +### Added +- Argument `should_rename_legacy` for legacy function `detect` and disregard any new arguments without errors (PR #262) + +### Removed +- Support for Python 3.6 (PR #260) + +### Changed +- Optional speedup provided by mypy/c 1.0.1 + +## [3.0.1](https://github.com/Ousret/charset_normalizer/compare/3.0.0...3.0.1) (2022-11-18) + +### Fixed +- Multi-bytes cutter/chunk generator did not always cut correctly (PR #233) + +### Changed +- Speedup provided by mypy/c 0.990 on Python >= 3.7 + +## [3.0.0](https://github.com/Ousret/charset_normalizer/compare/2.1.1...3.0.0) (2022-10-20) + +### Added +- Extend the capability of explain=True when cp_isolation contains at most two entries (min one), will log in details of the Mess-detector results +- Support for alternative language frequency set in charset_normalizer.assets.FREQUENCIES +- Add parameter `language_threshold` in `from_bytes`, `from_path` and `from_fp` to adjust the minimum expected coherence ratio +- `normalizer --version` now specify if current version provide extra speedup (meaning mypyc compilation whl) + +### Changed +- Build with static metadata using 'build' frontend +- Make the language detection stricter +- Optional: Module `md.py` can be compiled using Mypyc to provide an extra speedup up to 4x faster than v2.1 + +### Fixed +- CLI with opt --normalize fail when using full path for files +- TooManyAccentuatedPlugin induce false positive on the mess detection when too few alpha character have been fed to it +- Sphinx warnings when generating the documentation + +### Removed +- Coherence detector no longer return 'Simple English' instead return 'English' +- Coherence detector no longer return 'Classical Chinese' instead return 'Chinese' +- Breaking: Method `first()` and `best()` from CharsetMatch +- UTF-7 will no longer appear as "detected" without a recognized SIG/mark (is unreliable/conflict with ASCII) +- Breaking: Class aliases CharsetDetector, CharsetDoctor, CharsetNormalizerMatch and CharsetNormalizerMatches +- Breaking: Top-level function `normalize` +- Breaking: Properties `chaos_secondary_pass`, `coherence_non_latin` and `w_counter` from CharsetMatch +- Support for the backport `unicodedata2` + +## [3.0.0rc1](https://github.com/Ousret/charset_normalizer/compare/3.0.0b2...3.0.0rc1) (2022-10-18) + +### Added +- Extend the capability of explain=True when cp_isolation contains at most two entries (min one), will log in details of the Mess-detector results +- Support for alternative language frequency set in charset_normalizer.assets.FREQUENCIES +- Add parameter `language_threshold` in `from_bytes`, `from_path` and `from_fp` to adjust the minimum expected coherence ratio + +### Changed +- Build with static metadata using 'build' frontend +- Make the language detection stricter + +### Fixed +- CLI with opt --normalize fail when using full path for files +- TooManyAccentuatedPlugin induce false positive on the mess detection when too few alpha character have been fed to it + +### Removed +- Coherence detector no longer return 'Simple English' instead return 'English' +- Coherence detector no longer return 'Classical Chinese' instead return 'Chinese' + +## [3.0.0b2](https://github.com/Ousret/charset_normalizer/compare/3.0.0b1...3.0.0b2) (2022-08-21) + +### Added +- `normalizer --version` now specify if current version provide extra speedup (meaning mypyc compilation whl) + +### Removed +- Breaking: Method `first()` and `best()` from CharsetMatch +- UTF-7 will no longer appear as "detected" without a recognized SIG/mark (is unreliable/conflict with ASCII) + +### Fixed +- Sphinx warnings when generating the documentation + +## [3.0.0b1](https://github.com/Ousret/charset_normalizer/compare/2.1.0...3.0.0b1) (2022-08-15) + +### Changed +- Optional: Module `md.py` can be compiled using Mypyc to provide an extra speedup up to 4x faster than v2.1 + +### Removed +- Breaking: Class aliases CharsetDetector, CharsetDoctor, CharsetNormalizerMatch and CharsetNormalizerMatches +- Breaking: Top-level function `normalize` +- Breaking: Properties `chaos_secondary_pass`, `coherence_non_latin` and `w_counter` from CharsetMatch +- Support for the backport `unicodedata2` + +## [2.1.1](https://github.com/Ousret/charset_normalizer/compare/2.1.0...2.1.1) (2022-08-19) + +### Deprecated +- Function `normalize` scheduled for removal in 3.0 + +### Changed +- Removed useless call to decode in fn is_unprintable (#206) + +### Fixed +- Third-party library (i18n xgettext) crashing not recognizing utf_8 (PEP 263) with underscore from [@aleksandernovikov](https://github.com/aleksandernovikov) (#204) + +## [2.1.0](https://github.com/Ousret/charset_normalizer/compare/2.0.12...2.1.0) (2022-06-19) + +### Added +- Output the Unicode table version when running the CLI with `--version` (PR #194) + +### Changed +- Re-use decoded buffer for single byte character sets from [@nijel](https://github.com/nijel) (PR #175) +- Fixing some performance bottlenecks from [@deedy5](https://github.com/deedy5) (PR #183) + +### Fixed +- Workaround potential bug in cpython with Zero Width No-Break Space located in Arabic Presentation Forms-B, Unicode 1.1 not acknowledged as space (PR #175) +- CLI default threshold aligned with the API threshold from [@oleksandr-kuzmenko](https://github.com/oleksandr-kuzmenko) (PR #181) + +### Removed +- Support for Python 3.5 (PR #192) + +### Deprecated +- Use of backport unicodedata from `unicodedata2` as Python is quickly catching up, scheduled for removal in 3.0 (PR #194) + +## [2.0.12](https://github.com/Ousret/charset_normalizer/compare/2.0.11...2.0.12) (2022-02-12) + +### Fixed +- ASCII miss-detection on rare cases (PR #170) + +## [2.0.11](https://github.com/Ousret/charset_normalizer/compare/2.0.10...2.0.11) (2022-01-30) + +### Added +- Explicit support for Python 3.11 (PR #164) + +### Changed +- The logging behavior have been completely reviewed, now using only TRACE and DEBUG levels (PR #163 #165) + +## [2.0.10](https://github.com/Ousret/charset_normalizer/compare/2.0.9...2.0.10) (2022-01-04) + +### Fixed +- Fallback match entries might lead to UnicodeDecodeError for large bytes sequence (PR #154) + +### Changed +- Skipping the language-detection (CD) on ASCII (PR #155) + +## [2.0.9](https://github.com/Ousret/charset_normalizer/compare/2.0.8...2.0.9) (2021-12-03) + +### Changed +- Moderating the logging impact (since 2.0.8) for specific environments (PR #147) + +### Fixed +- Wrong logging level applied when setting kwarg `explain` to True (PR #146) + +## [2.0.8](https://github.com/Ousret/charset_normalizer/compare/2.0.7...2.0.8) (2021-11-24) +### Changed +- Improvement over Vietnamese detection (PR #126) +- MD improvement on trailing data and long foreign (non-pure latin) data (PR #124) +- Efficiency improvements in cd/alphabet_languages from [@adbar](https://github.com/adbar) (PR #122) +- call sum() without an intermediary list following PEP 289 recommendations from [@adbar](https://github.com/adbar) (PR #129) +- Code style as refactored by Sourcery-AI (PR #131) +- Minor adjustment on the MD around european words (PR #133) +- Remove and replace SRTs from assets / tests (PR #139) +- Initialize the library logger with a `NullHandler` by default from [@nmaynes](https://github.com/nmaynes) (PR #135) +- Setting kwarg `explain` to True will add provisionally (bounded to function lifespan) a specific stream handler (PR #135) + +### Fixed +- Fix large (misleading) sequence giving UnicodeDecodeError (PR #137) +- Avoid using too insignificant chunk (PR #137) + +### Added +- Add and expose function `set_logging_handler` to configure a specific StreamHandler from [@nmaynes](https://github.com/nmaynes) (PR #135) +- Add `CHANGELOG.md` entries, format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/) (PR #141) + +## [2.0.7](https://github.com/Ousret/charset_normalizer/compare/2.0.6...2.0.7) (2021-10-11) +### Added +- Add support for Kazakh (Cyrillic) language detection (PR #109) + +### Changed +- Further, improve inferring the language from a given single-byte code page (PR #112) +- Vainly trying to leverage PEP263 when PEP3120 is not supported (PR #116) +- Refactoring for potential performance improvements in loops from [@adbar](https://github.com/adbar) (PR #113) +- Various detection improvement (MD+CD) (PR #117) + +### Removed +- Remove redundant logging entry about detected language(s) (PR #115) + +### Fixed +- Fix a minor inconsistency between Python 3.5 and other versions regarding language detection (PR #117 #102) + +## [2.0.6](https://github.com/Ousret/charset_normalizer/compare/2.0.5...2.0.6) (2021-09-18) +### Fixed +- Unforeseen regression with the loss of the backward-compatibility with some older minor of Python 3.5.x (PR #100) +- Fix CLI crash when using --minimal output in certain cases (PR #103) + +### Changed +- Minor improvement to the detection efficiency (less than 1%) (PR #106 #101) + +## [2.0.5](https://github.com/Ousret/charset_normalizer/compare/2.0.4...2.0.5) (2021-09-14) +### Changed +- The project now comply with: flake8, mypy, isort and black to ensure a better overall quality (PR #81) +- The BC-support with v1.x was improved, the old staticmethods are restored (PR #82) +- The Unicode detection is slightly improved (PR #93) +- Add syntax sugar \_\_bool\_\_ for results CharsetMatches list-container (PR #91) + +### Removed +- The project no longer raise warning on tiny content given for detection, will be simply logged as warning instead (PR #92) + +### Fixed +- In some rare case, the chunks extractor could cut in the middle of a multi-byte character and could mislead the mess detection (PR #95) +- Some rare 'space' characters could trip up the UnprintablePlugin/Mess detection (PR #96) +- The MANIFEST.in was not exhaustive (PR #78) + +## [2.0.4](https://github.com/Ousret/charset_normalizer/compare/2.0.3...2.0.4) (2021-07-30) +### Fixed +- The CLI no longer raise an unexpected exception when no encoding has been found (PR #70) +- Fix accessing the 'alphabets' property when the payload contains surrogate characters (PR #68) +- The logger could mislead (explain=True) on detected languages and the impact of one MBCS match (PR #72) +- Submatch factoring could be wrong in rare edge cases (PR #72) +- Multiple files given to the CLI were ignored when publishing results to STDOUT. (After the first path) (PR #72) +- Fix line endings from CRLF to LF for certain project files (PR #67) + +### Changed +- Adjust the MD to lower the sensitivity, thus improving the global detection reliability (PR #69 #76) +- Allow fallback on specified encoding if any (PR #71) + +## [2.0.3](https://github.com/Ousret/charset_normalizer/compare/2.0.2...2.0.3) (2021-07-16) +### Changed +- Part of the detection mechanism has been improved to be less sensitive, resulting in more accurate detection results. Especially ASCII. (PR #63) +- According to the community wishes, the detection will fall back on ASCII or UTF-8 in a last-resort case. (PR #64) + +## [2.0.2](https://github.com/Ousret/charset_normalizer/compare/2.0.1...2.0.2) (2021-07-15) +### Fixed +- Empty/Too small JSON payload miss-detection fixed. Report from [@tseaver](https://github.com/tseaver) (PR #59) + +### Changed +- Don't inject unicodedata2 into sys.modules from [@akx](https://github.com/akx) (PR #57) + +## [2.0.1](https://github.com/Ousret/charset_normalizer/compare/2.0.0...2.0.1) (2021-07-13) +### Fixed +- Make it work where there isn't a filesystem available, dropping assets frequencies.json. Report from [@sethmlarson](https://github.com/sethmlarson). (PR #55) +- Using explain=False permanently disable the verbose output in the current runtime (PR #47) +- One log entry (language target preemptive) was not show in logs when using explain=True (PR #47) +- Fix undesired exception (ValueError) on getitem of instance CharsetMatches (PR #52) + +### Changed +- Public function normalize default args values were not aligned with from_bytes (PR #53) + +### Added +- You may now use charset aliases in cp_isolation and cp_exclusion arguments (PR #47) + +## [2.0.0](https://github.com/Ousret/charset_normalizer/compare/1.4.1...2.0.0) (2021-07-02) +### Changed +- 4x to 5 times faster than the previous 1.4.0 release. At least 2x faster than Chardet. +- Accent has been made on UTF-8 detection, should perform rather instantaneous. +- The backward compatibility with Chardet has been greatly improved. The legacy detect function returns an identical charset name whenever possible. +- The detection mechanism has been slightly improved, now Turkish content is detected correctly (most of the time) +- The program has been rewritten to ease the readability and maintainability. (+Using static typing)+ +- utf_7 detection has been reinstated. + +### Removed +- This package no longer require anything when used with Python 3.5 (Dropped cached_property) +- Removed support for these languages: Catalan, Esperanto, Kazakh, Baque, Volapük, Azeri, Galician, Nynorsk, Macedonian, and Serbocroatian. +- The exception hook on UnicodeDecodeError has been removed. + +### Deprecated +- Methods coherence_non_latin, w_counter, chaos_secondary_pass of the class CharsetMatch are now deprecated and scheduled for removal in v3.0 + +### Fixed +- The CLI output used the relative path of the file(s). Should be absolute. + +## [1.4.1](https://github.com/Ousret/charset_normalizer/compare/1.4.0...1.4.1) (2021-05-28) +### Fixed +- Logger configuration/usage no longer conflict with others (PR #44) + +## [1.4.0](https://github.com/Ousret/charset_normalizer/compare/1.3.9...1.4.0) (2021-05-21) +### Removed +- Using standard logging instead of using the package loguru. +- Dropping nose test framework in favor of the maintained pytest. +- Choose to not use dragonmapper package to help with gibberish Chinese/CJK text. +- Require cached_property only for Python 3.5 due to constraint. Dropping for every other interpreter version. +- Stop support for UTF-7 that does not contain a SIG. +- Dropping PrettyTable, replaced with pure JSON output in CLI. + +### Fixed +- BOM marker in a CharsetNormalizerMatch instance could be False in rare cases even if obviously present. Due to the sub-match factoring process. +- Not searching properly for the BOM when trying utf32/16 parent codec. + +### Changed +- Improving the package final size by compressing frequencies.json. +- Huge improvement over the larges payload. + +### Added +- CLI now produces JSON consumable output. +- Return ASCII if given sequences fit. Given reasonable confidence. + +## [1.3.9](https://github.com/Ousret/charset_normalizer/compare/1.3.8...1.3.9) (2021-05-13) + +### Fixed +- In some very rare cases, you may end up getting encode/decode errors due to a bad bytes payload (PR #40) + +## [1.3.8](https://github.com/Ousret/charset_normalizer/compare/1.3.7...1.3.8) (2021-05-12) + +### Fixed +- Empty given payload for detection may cause an exception if trying to access the `alphabets` property. (PR #39) + +## [1.3.7](https://github.com/Ousret/charset_normalizer/compare/1.3.6...1.3.7) (2021-05-12) + +### Fixed +- The legacy detect function should return UTF-8-SIG if sig is present in the payload. (PR #38) + +## [1.3.6](https://github.com/Ousret/charset_normalizer/compare/1.3.5...1.3.6) (2021-02-09) + +### Changed +- Amend the previous release to allow prettytable 2.0 (PR #35) + +## [1.3.5](https://github.com/Ousret/charset_normalizer/compare/1.3.4...1.3.5) (2021-02-08) + +### Fixed +- Fix error while using the package with a python pre-release interpreter (PR #33) + +### Changed +- Dependencies refactoring, constraints revised. + +### Added +- Add python 3.9 and 3.10 to the supported interpreters + +MIT License + +Copyright (c) 2019 TAHRI Ahmed R. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/RECORD b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/RECORD new file mode 100644 index 0000000..5cf5681 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/RECORD @@ -0,0 +1,35 @@ +../../../bin/normalizer,sha256=EFW7gUReQX9WBBF-pk3jgMcGaSO7THvrKsDu5QKAH0A,257 +charset_normalizer-3.3.2.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +charset_normalizer-3.3.2.dist-info/LICENSE,sha256=6zGgxaT7Cbik4yBV0lweX5w1iidS_vPNcgIT0cz-4kE,1070 +charset_normalizer-3.3.2.dist-info/METADATA,sha256=cfLhl5A6SI-F0oclm8w8ux9wshL1nipdeCdVnYb4AaA,33550 +charset_normalizer-3.3.2.dist-info/RECORD,, +charset_normalizer-3.3.2.dist-info/WHEEL,sha256=vWlGwhdECC9wcTU6fbest1U_zFWdeiQSqPWexEYEoQo,154 +charset_normalizer-3.3.2.dist-info/entry_points.txt,sha256=ADSTKrkXZ3hhdOVFi6DcUEHQRS0xfxDIE_pEz4wLIXA,65 +charset_normalizer-3.3.2.dist-info/top_level.txt,sha256=7ASyzePr8_xuZWJsnqJjIBtyV8vhEo0wBCv1MPRRi3Q,19 +charset_normalizer/__init__.py,sha256=UzI3xC8PhmcLRMzSgPb6minTmRq0kWznnCBJ8ZCc2XI,1577 +charset_normalizer/__main__.py,sha256=JxY8bleaENOFlLRb9HfoeZCzAMnn2A1oGR5Xm2eyqg0,73 +charset_normalizer/__pycache__/__init__.cpython-311.pyc,, +charset_normalizer/__pycache__/__main__.cpython-311.pyc,, +charset_normalizer/__pycache__/api.cpython-311.pyc,, +charset_normalizer/__pycache__/cd.cpython-311.pyc,, +charset_normalizer/__pycache__/constant.cpython-311.pyc,, +charset_normalizer/__pycache__/legacy.cpython-311.pyc,, +charset_normalizer/__pycache__/md.cpython-311.pyc,, +charset_normalizer/__pycache__/models.cpython-311.pyc,, +charset_normalizer/__pycache__/utils.cpython-311.pyc,, +charset_normalizer/__pycache__/version.cpython-311.pyc,, +charset_normalizer/api.py,sha256=WOlWjy6wT8SeMYFpaGbXZFN1TMXa-s8vZYfkL4G29iQ,21097 +charset_normalizer/cd.py,sha256=xwZliZcTQFA3jU0c00PRiu9MNxXTFxQkFLWmMW24ZzI,12560 +charset_normalizer/cli/__init__.py,sha256=D5ERp8P62llm2FuoMzydZ7d9rs8cvvLXqE-1_6oViPc,100 +charset_normalizer/cli/__main__.py,sha256=2F-xURZJzo063Ye-2RLJ2wcmURpbKeAzKwpiws65dAs,9744 +charset_normalizer/cli/__pycache__/__init__.cpython-311.pyc,, +charset_normalizer/cli/__pycache__/__main__.cpython-311.pyc,, +charset_normalizer/constant.py,sha256=p0IsOVcEbPWYPOdWhnhRbjK1YVBy6fs05C5vKC-zoxU,40481 +charset_normalizer/legacy.py,sha256=T-QuVMsMeDiQEk8WSszMrzVJg_14AMeSkmHdRYhdl1k,2071 +charset_normalizer/md.cpython-311-aarch64-linux-gnu.so,sha256=5hU4sWeM3XiR2vLRWyKxBqAMGpadzRWcsPw0feJSHM0,69800 +charset_normalizer/md.py,sha256=NkSuVLK13_a8c7BxZ4cGIQ5vOtGIWOdh22WZEvjp-7U,19624 +charset_normalizer/md__mypyc.cpython-311-aarch64-linux-gnu.so,sha256=fEskVITYbqJTRx9xlK0hNXbNZ5S-Mnbp34ac4a8m-I0,321776 +charset_normalizer/models.py,sha256=I5i0s4aKCCgLPY2tUY3pwkgFA-BUbbNxQ7hVkVTt62s,11624 +charset_normalizer/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +charset_normalizer/utils.py,sha256=teiosMqzKjXyAHXnGdjSBOgnBZwx-SkBbCLrx0UXy8M,11894 +charset_normalizer/version.py,sha256=iHKUfHD3kDRSyrh_BN2ojh43TA5-UZQjvbVIEFfpHDs,79 diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/WHEEL b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/WHEEL new file mode 100644 index 0000000..23c0246 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/WHEEL @@ -0,0 +1,6 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.41.2) +Root-Is-Purelib: false +Tag: cp311-cp311-manylinux_2_17_aarch64 +Tag: cp311-cp311-manylinux2014_aarch64 + diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/entry_points.txt b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/entry_points.txt new file mode 100644 index 0000000..65619e7 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/entry_points.txt @@ -0,0 +1,2 @@ +[console_scripts] +normalizer = charset_normalizer.cli:cli_detect diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/top_level.txt b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/top_level.txt new file mode 100644 index 0000000..66958f0 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer-3.3.2.dist-info/top_level.txt @@ -0,0 +1 @@ +charset_normalizer diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/__init__.py new file mode 100644 index 0000000..55991fc --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/__init__.py @@ -0,0 +1,46 @@ +# -*- coding: utf-8 -*- +""" +Charset-Normalizer +~~~~~~~~~~~~~~ +The Real First Universal Charset Detector. +A library that helps you read text from an unknown charset encoding. +Motivated by chardet, This package is trying to resolve the issue by taking a new approach. +All IANA character set names for which the Python core library provides codecs are supported. + +Basic usage: + >>> from charset_normalizer import from_bytes + >>> results = from_bytes('Bсеки човек има право на образование. Oбразованието!'.encode('utf_8')) + >>> best_guess = results.best() + >>> str(best_guess) + 'Bсеки човек има право на образование. Oбразованието!' + +Others methods and usages are available - see the full documentation +at . +:copyright: (c) 2021 by Ahmed TAHRI +:license: MIT, see LICENSE for more details. +""" +import logging + +from .api import from_bytes, from_fp, from_path, is_binary +from .legacy import detect +from .models import CharsetMatch, CharsetMatches +from .utils import set_logging_handler +from .version import VERSION, __version__ + +__all__ = ( + "from_fp", + "from_path", + "from_bytes", + "is_binary", + "detect", + "CharsetMatch", + "CharsetMatches", + "__version__", + "VERSION", + "set_logging_handler", +) + +# Attach a NullHandler to the top level logger by default +# https://docs.python.org/3.3/howto/logging.html#configuring-logging-for-a-library + +logging.getLogger("charset_normalizer").addHandler(logging.NullHandler()) diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/__main__.py b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/__main__.py new file mode 100644 index 0000000..beae2ef --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/__main__.py @@ -0,0 +1,4 @@ +from .cli import cli_detect + +if __name__ == "__main__": + cli_detect() diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/api.py b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/api.py new file mode 100644 index 0000000..0ba08e3 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/api.py @@ -0,0 +1,626 @@ +import logging +from os import PathLike +from typing import BinaryIO, List, Optional, Set, Union + +from .cd import ( + coherence_ratio, + encoding_languages, + mb_encoding_languages, + merge_coherence_ratios, +) +from .constant import IANA_SUPPORTED, TOO_BIG_SEQUENCE, TOO_SMALL_SEQUENCE, TRACE +from .md import mess_ratio +from .models import CharsetMatch, CharsetMatches +from .utils import ( + any_specified_encoding, + cut_sequence_chunks, + iana_name, + identify_sig_or_bom, + is_cp_similar, + is_multi_byte_encoding, + should_strip_sig_or_bom, +) + +# Will most likely be controversial +# logging.addLevelName(TRACE, "TRACE") +logger = logging.getLogger("charset_normalizer") +explain_handler = logging.StreamHandler() +explain_handler.setFormatter( + logging.Formatter("%(asctime)s | %(levelname)s | %(message)s") +) + + +def from_bytes( + sequences: Union[bytes, bytearray], + steps: int = 5, + chunk_size: int = 512, + threshold: float = 0.2, + cp_isolation: Optional[List[str]] = None, + cp_exclusion: Optional[List[str]] = None, + preemptive_behaviour: bool = True, + explain: bool = False, + language_threshold: float = 0.1, + enable_fallback: bool = True, +) -> CharsetMatches: + """ + Given a raw bytes sequence, return the best possibles charset usable to render str objects. + If there is no results, it is a strong indicator that the source is binary/not text. + By default, the process will extract 5 blocks of 512o each to assess the mess and coherence of a given sequence. + And will give up a particular code page after 20% of measured mess. Those criteria are customizable at will. + + The preemptive behavior DOES NOT replace the traditional detection workflow, it prioritize a particular code page + but never take it for granted. Can improve the performance. + + You may want to focus your attention to some code page or/and not others, use cp_isolation and cp_exclusion for that + purpose. + + This function will strip the SIG in the payload/sequence every time except on UTF-16, UTF-32. + By default the library does not setup any handler other than the NullHandler, if you choose to set the 'explain' + toggle to True it will alter the logger configuration to add a StreamHandler that is suitable for debugging. + Custom logging format and handler can be set manually. + """ + + if not isinstance(sequences, (bytearray, bytes)): + raise TypeError( + "Expected object of type bytes or bytearray, got: {0}".format( + type(sequences) + ) + ) + + if explain: + previous_logger_level: int = logger.level + logger.addHandler(explain_handler) + logger.setLevel(TRACE) + + length: int = len(sequences) + + if length == 0: + logger.debug("Encoding detection on empty bytes, assuming utf_8 intention.") + if explain: + logger.removeHandler(explain_handler) + logger.setLevel(previous_logger_level or logging.WARNING) + return CharsetMatches([CharsetMatch(sequences, "utf_8", 0.0, False, [], "")]) + + if cp_isolation is not None: + logger.log( + TRACE, + "cp_isolation is set. use this flag for debugging purpose. " + "limited list of encoding allowed : %s.", + ", ".join(cp_isolation), + ) + cp_isolation = [iana_name(cp, False) for cp in cp_isolation] + else: + cp_isolation = [] + + if cp_exclusion is not None: + logger.log( + TRACE, + "cp_exclusion is set. use this flag for debugging purpose. " + "limited list of encoding excluded : %s.", + ", ".join(cp_exclusion), + ) + cp_exclusion = [iana_name(cp, False) for cp in cp_exclusion] + else: + cp_exclusion = [] + + if length <= (chunk_size * steps): + logger.log( + TRACE, + "override steps (%i) and chunk_size (%i) as content does not fit (%i byte(s) given) parameters.", + steps, + chunk_size, + length, + ) + steps = 1 + chunk_size = length + + if steps > 1 and length / steps < chunk_size: + chunk_size = int(length / steps) + + is_too_small_sequence: bool = len(sequences) < TOO_SMALL_SEQUENCE + is_too_large_sequence: bool = len(sequences) >= TOO_BIG_SEQUENCE + + if is_too_small_sequence: + logger.log( + TRACE, + "Trying to detect encoding from a tiny portion of ({}) byte(s).".format( + length + ), + ) + elif is_too_large_sequence: + logger.log( + TRACE, + "Using lazy str decoding because the payload is quite large, ({}) byte(s).".format( + length + ), + ) + + prioritized_encodings: List[str] = [] + + specified_encoding: Optional[str] = ( + any_specified_encoding(sequences) if preemptive_behaviour else None + ) + + if specified_encoding is not None: + prioritized_encodings.append(specified_encoding) + logger.log( + TRACE, + "Detected declarative mark in sequence. Priority +1 given for %s.", + specified_encoding, + ) + + tested: Set[str] = set() + tested_but_hard_failure: List[str] = [] + tested_but_soft_failure: List[str] = [] + + fallback_ascii: Optional[CharsetMatch] = None + fallback_u8: Optional[CharsetMatch] = None + fallback_specified: Optional[CharsetMatch] = None + + results: CharsetMatches = CharsetMatches() + + sig_encoding, sig_payload = identify_sig_or_bom(sequences) + + if sig_encoding is not None: + prioritized_encodings.append(sig_encoding) + logger.log( + TRACE, + "Detected a SIG or BOM mark on first %i byte(s). Priority +1 given for %s.", + len(sig_payload), + sig_encoding, + ) + + prioritized_encodings.append("ascii") + + if "utf_8" not in prioritized_encodings: + prioritized_encodings.append("utf_8") + + for encoding_iana in prioritized_encodings + IANA_SUPPORTED: + if cp_isolation and encoding_iana not in cp_isolation: + continue + + if cp_exclusion and encoding_iana in cp_exclusion: + continue + + if encoding_iana in tested: + continue + + tested.add(encoding_iana) + + decoded_payload: Optional[str] = None + bom_or_sig_available: bool = sig_encoding == encoding_iana + strip_sig_or_bom: bool = bom_or_sig_available and should_strip_sig_or_bom( + encoding_iana + ) + + if encoding_iana in {"utf_16", "utf_32"} and not bom_or_sig_available: + logger.log( + TRACE, + "Encoding %s won't be tested as-is because it require a BOM. Will try some sub-encoder LE/BE.", + encoding_iana, + ) + continue + if encoding_iana in {"utf_7"} and not bom_or_sig_available: + logger.log( + TRACE, + "Encoding %s won't be tested as-is because detection is unreliable without BOM/SIG.", + encoding_iana, + ) + continue + + try: + is_multi_byte_decoder: bool = is_multi_byte_encoding(encoding_iana) + except (ModuleNotFoundError, ImportError): + logger.log( + TRACE, + "Encoding %s does not provide an IncrementalDecoder", + encoding_iana, + ) + continue + + try: + if is_too_large_sequence and is_multi_byte_decoder is False: + str( + sequences[: int(50e4)] + if strip_sig_or_bom is False + else sequences[len(sig_payload) : int(50e4)], + encoding=encoding_iana, + ) + else: + decoded_payload = str( + sequences + if strip_sig_or_bom is False + else sequences[len(sig_payload) :], + encoding=encoding_iana, + ) + except (UnicodeDecodeError, LookupError) as e: + if not isinstance(e, LookupError): + logger.log( + TRACE, + "Code page %s does not fit given bytes sequence at ALL. %s", + encoding_iana, + str(e), + ) + tested_but_hard_failure.append(encoding_iana) + continue + + similar_soft_failure_test: bool = False + + for encoding_soft_failed in tested_but_soft_failure: + if is_cp_similar(encoding_iana, encoding_soft_failed): + similar_soft_failure_test = True + break + + if similar_soft_failure_test: + logger.log( + TRACE, + "%s is deemed too similar to code page %s and was consider unsuited already. Continuing!", + encoding_iana, + encoding_soft_failed, + ) + continue + + r_ = range( + 0 if not bom_or_sig_available else len(sig_payload), + length, + int(length / steps), + ) + + multi_byte_bonus: bool = ( + is_multi_byte_decoder + and decoded_payload is not None + and len(decoded_payload) < length + ) + + if multi_byte_bonus: + logger.log( + TRACE, + "Code page %s is a multi byte encoding table and it appear that at least one character " + "was encoded using n-bytes.", + encoding_iana, + ) + + max_chunk_gave_up: int = int(len(r_) / 4) + + max_chunk_gave_up = max(max_chunk_gave_up, 2) + early_stop_count: int = 0 + lazy_str_hard_failure = False + + md_chunks: List[str] = [] + md_ratios = [] + + try: + for chunk in cut_sequence_chunks( + sequences, + encoding_iana, + r_, + chunk_size, + bom_or_sig_available, + strip_sig_or_bom, + sig_payload, + is_multi_byte_decoder, + decoded_payload, + ): + md_chunks.append(chunk) + + md_ratios.append( + mess_ratio( + chunk, + threshold, + explain is True and 1 <= len(cp_isolation) <= 2, + ) + ) + + if md_ratios[-1] >= threshold: + early_stop_count += 1 + + if (early_stop_count >= max_chunk_gave_up) or ( + bom_or_sig_available and strip_sig_or_bom is False + ): + break + except ( + UnicodeDecodeError + ) as e: # Lazy str loading may have missed something there + logger.log( + TRACE, + "LazyStr Loading: After MD chunk decode, code page %s does not fit given bytes sequence at ALL. %s", + encoding_iana, + str(e), + ) + early_stop_count = max_chunk_gave_up + lazy_str_hard_failure = True + + # We might want to check the sequence again with the whole content + # Only if initial MD tests passes + if ( + not lazy_str_hard_failure + and is_too_large_sequence + and not is_multi_byte_decoder + ): + try: + sequences[int(50e3) :].decode(encoding_iana, errors="strict") + except UnicodeDecodeError as e: + logger.log( + TRACE, + "LazyStr Loading: After final lookup, code page %s does not fit given bytes sequence at ALL. %s", + encoding_iana, + str(e), + ) + tested_but_hard_failure.append(encoding_iana) + continue + + mean_mess_ratio: float = sum(md_ratios) / len(md_ratios) if md_ratios else 0.0 + if mean_mess_ratio >= threshold or early_stop_count >= max_chunk_gave_up: + tested_but_soft_failure.append(encoding_iana) + logger.log( + TRACE, + "%s was excluded because of initial chaos probing. Gave up %i time(s). " + "Computed mean chaos is %f %%.", + encoding_iana, + early_stop_count, + round(mean_mess_ratio * 100, ndigits=3), + ) + # Preparing those fallbacks in case we got nothing. + if ( + enable_fallback + and encoding_iana in ["ascii", "utf_8", specified_encoding] + and not lazy_str_hard_failure + ): + fallback_entry = CharsetMatch( + sequences, encoding_iana, threshold, False, [], decoded_payload + ) + if encoding_iana == specified_encoding: + fallback_specified = fallback_entry + elif encoding_iana == "ascii": + fallback_ascii = fallback_entry + else: + fallback_u8 = fallback_entry + continue + + logger.log( + TRACE, + "%s passed initial chaos probing. Mean measured chaos is %f %%", + encoding_iana, + round(mean_mess_ratio * 100, ndigits=3), + ) + + if not is_multi_byte_decoder: + target_languages: List[str] = encoding_languages(encoding_iana) + else: + target_languages = mb_encoding_languages(encoding_iana) + + if target_languages: + logger.log( + TRACE, + "{} should target any language(s) of {}".format( + encoding_iana, str(target_languages) + ), + ) + + cd_ratios = [] + + # We shall skip the CD when its about ASCII + # Most of the time its not relevant to run "language-detection" on it. + if encoding_iana != "ascii": + for chunk in md_chunks: + chunk_languages = coherence_ratio( + chunk, + language_threshold, + ",".join(target_languages) if target_languages else None, + ) + + cd_ratios.append(chunk_languages) + + cd_ratios_merged = merge_coherence_ratios(cd_ratios) + + if cd_ratios_merged: + logger.log( + TRACE, + "We detected language {} using {}".format( + cd_ratios_merged, encoding_iana + ), + ) + + results.append( + CharsetMatch( + sequences, + encoding_iana, + mean_mess_ratio, + bom_or_sig_available, + cd_ratios_merged, + decoded_payload, + ) + ) + + if ( + encoding_iana in [specified_encoding, "ascii", "utf_8"] + and mean_mess_ratio < 0.1 + ): + logger.debug( + "Encoding detection: %s is most likely the one.", encoding_iana + ) + if explain: + logger.removeHandler(explain_handler) + logger.setLevel(previous_logger_level) + return CharsetMatches([results[encoding_iana]]) + + if encoding_iana == sig_encoding: + logger.debug( + "Encoding detection: %s is most likely the one as we detected a BOM or SIG within " + "the beginning of the sequence.", + encoding_iana, + ) + if explain: + logger.removeHandler(explain_handler) + logger.setLevel(previous_logger_level) + return CharsetMatches([results[encoding_iana]]) + + if len(results) == 0: + if fallback_u8 or fallback_ascii or fallback_specified: + logger.log( + TRACE, + "Nothing got out of the detection process. Using ASCII/UTF-8/Specified fallback.", + ) + + if fallback_specified: + logger.debug( + "Encoding detection: %s will be used as a fallback match", + fallback_specified.encoding, + ) + results.append(fallback_specified) + elif ( + (fallback_u8 and fallback_ascii is None) + or ( + fallback_u8 + and fallback_ascii + and fallback_u8.fingerprint != fallback_ascii.fingerprint + ) + or (fallback_u8 is not None) + ): + logger.debug("Encoding detection: utf_8 will be used as a fallback match") + results.append(fallback_u8) + elif fallback_ascii: + logger.debug("Encoding detection: ascii will be used as a fallback match") + results.append(fallback_ascii) + + if results: + logger.debug( + "Encoding detection: Found %s as plausible (best-candidate) for content. With %i alternatives.", + results.best().encoding, # type: ignore + len(results) - 1, + ) + else: + logger.debug("Encoding detection: Unable to determine any suitable charset.") + + if explain: + logger.removeHandler(explain_handler) + logger.setLevel(previous_logger_level) + + return results + + +def from_fp( + fp: BinaryIO, + steps: int = 5, + chunk_size: int = 512, + threshold: float = 0.20, + cp_isolation: Optional[List[str]] = None, + cp_exclusion: Optional[List[str]] = None, + preemptive_behaviour: bool = True, + explain: bool = False, + language_threshold: float = 0.1, + enable_fallback: bool = True, +) -> CharsetMatches: + """ + Same thing than the function from_bytes but using a file pointer that is already ready. + Will not close the file pointer. + """ + return from_bytes( + fp.read(), + steps, + chunk_size, + threshold, + cp_isolation, + cp_exclusion, + preemptive_behaviour, + explain, + language_threshold, + enable_fallback, + ) + + +def from_path( + path: Union[str, bytes, PathLike], # type: ignore[type-arg] + steps: int = 5, + chunk_size: int = 512, + threshold: float = 0.20, + cp_isolation: Optional[List[str]] = None, + cp_exclusion: Optional[List[str]] = None, + preemptive_behaviour: bool = True, + explain: bool = False, + language_threshold: float = 0.1, + enable_fallback: bool = True, +) -> CharsetMatches: + """ + Same thing than the function from_bytes but with one extra step. Opening and reading given file path in binary mode. + Can raise IOError. + """ + with open(path, "rb") as fp: + return from_fp( + fp, + steps, + chunk_size, + threshold, + cp_isolation, + cp_exclusion, + preemptive_behaviour, + explain, + language_threshold, + enable_fallback, + ) + + +def is_binary( + fp_or_path_or_payload: Union[PathLike, str, BinaryIO, bytes], # type: ignore[type-arg] + steps: int = 5, + chunk_size: int = 512, + threshold: float = 0.20, + cp_isolation: Optional[List[str]] = None, + cp_exclusion: Optional[List[str]] = None, + preemptive_behaviour: bool = True, + explain: bool = False, + language_threshold: float = 0.1, + enable_fallback: bool = False, +) -> bool: + """ + Detect if the given input (file, bytes, or path) points to a binary file. aka. not a string. + Based on the same main heuristic algorithms and default kwargs at the sole exception that fallbacks match + are disabled to be stricter around ASCII-compatible but unlikely to be a string. + """ + if isinstance(fp_or_path_or_payload, (str, PathLike)): + guesses = from_path( + fp_or_path_or_payload, + steps=steps, + chunk_size=chunk_size, + threshold=threshold, + cp_isolation=cp_isolation, + cp_exclusion=cp_exclusion, + preemptive_behaviour=preemptive_behaviour, + explain=explain, + language_threshold=language_threshold, + enable_fallback=enable_fallback, + ) + elif isinstance( + fp_or_path_or_payload, + ( + bytes, + bytearray, + ), + ): + guesses = from_bytes( + fp_or_path_or_payload, + steps=steps, + chunk_size=chunk_size, + threshold=threshold, + cp_isolation=cp_isolation, + cp_exclusion=cp_exclusion, + preemptive_behaviour=preemptive_behaviour, + explain=explain, + language_threshold=language_threshold, + enable_fallback=enable_fallback, + ) + else: + guesses = from_fp( + fp_or_path_or_payload, + steps=steps, + chunk_size=chunk_size, + threshold=threshold, + cp_isolation=cp_isolation, + cp_exclusion=cp_exclusion, + preemptive_behaviour=preemptive_behaviour, + explain=explain, + language_threshold=language_threshold, + enable_fallback=enable_fallback, + ) + + return not guesses diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/cd.py b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/cd.py new file mode 100644 index 0000000..4ea6760 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/cd.py @@ -0,0 +1,395 @@ +import importlib +from codecs import IncrementalDecoder +from collections import Counter +from functools import lru_cache +from typing import Counter as TypeCounter, Dict, List, Optional, Tuple + +from .constant import ( + FREQUENCIES, + KO_NAMES, + LANGUAGE_SUPPORTED_COUNT, + TOO_SMALL_SEQUENCE, + ZH_NAMES, +) +from .md import is_suspiciously_successive_range +from .models import CoherenceMatches +from .utils import ( + is_accentuated, + is_latin, + is_multi_byte_encoding, + is_unicode_range_secondary, + unicode_range, +) + + +def encoding_unicode_range(iana_name: str) -> List[str]: + """ + Return associated unicode ranges in a single byte code page. + """ + if is_multi_byte_encoding(iana_name): + raise IOError("Function not supported on multi-byte code page") + + decoder = importlib.import_module( + "encodings.{}".format(iana_name) + ).IncrementalDecoder + + p: IncrementalDecoder = decoder(errors="ignore") + seen_ranges: Dict[str, int] = {} + character_count: int = 0 + + for i in range(0x40, 0xFF): + chunk: str = p.decode(bytes([i])) + + if chunk: + character_range: Optional[str] = unicode_range(chunk) + + if character_range is None: + continue + + if is_unicode_range_secondary(character_range) is False: + if character_range not in seen_ranges: + seen_ranges[character_range] = 0 + seen_ranges[character_range] += 1 + character_count += 1 + + return sorted( + [ + character_range + for character_range in seen_ranges + if seen_ranges[character_range] / character_count >= 0.15 + ] + ) + + +def unicode_range_languages(primary_range: str) -> List[str]: + """ + Return inferred languages used with a unicode range. + """ + languages: List[str] = [] + + for language, characters in FREQUENCIES.items(): + for character in characters: + if unicode_range(character) == primary_range: + languages.append(language) + break + + return languages + + +@lru_cache() +def encoding_languages(iana_name: str) -> List[str]: + """ + Single-byte encoding language association. Some code page are heavily linked to particular language(s). + This function does the correspondence. + """ + unicode_ranges: List[str] = encoding_unicode_range(iana_name) + primary_range: Optional[str] = None + + for specified_range in unicode_ranges: + if "Latin" not in specified_range: + primary_range = specified_range + break + + if primary_range is None: + return ["Latin Based"] + + return unicode_range_languages(primary_range) + + +@lru_cache() +def mb_encoding_languages(iana_name: str) -> List[str]: + """ + Multi-byte encoding language association. Some code page are heavily linked to particular language(s). + This function does the correspondence. + """ + if ( + iana_name.startswith("shift_") + or iana_name.startswith("iso2022_jp") + or iana_name.startswith("euc_j") + or iana_name == "cp932" + ): + return ["Japanese"] + if iana_name.startswith("gb") or iana_name in ZH_NAMES: + return ["Chinese"] + if iana_name.startswith("iso2022_kr") or iana_name in KO_NAMES: + return ["Korean"] + + return [] + + +@lru_cache(maxsize=LANGUAGE_SUPPORTED_COUNT) +def get_target_features(language: str) -> Tuple[bool, bool]: + """ + Determine main aspects from a supported language if it contains accents and if is pure Latin. + """ + target_have_accents: bool = False + target_pure_latin: bool = True + + for character in FREQUENCIES[language]: + if not target_have_accents and is_accentuated(character): + target_have_accents = True + if target_pure_latin and is_latin(character) is False: + target_pure_latin = False + + return target_have_accents, target_pure_latin + + +def alphabet_languages( + characters: List[str], ignore_non_latin: bool = False +) -> List[str]: + """ + Return associated languages associated to given characters. + """ + languages: List[Tuple[str, float]] = [] + + source_have_accents = any(is_accentuated(character) for character in characters) + + for language, language_characters in FREQUENCIES.items(): + target_have_accents, target_pure_latin = get_target_features(language) + + if ignore_non_latin and target_pure_latin is False: + continue + + if target_have_accents is False and source_have_accents: + continue + + character_count: int = len(language_characters) + + character_match_count: int = len( + [c for c in language_characters if c in characters] + ) + + ratio: float = character_match_count / character_count + + if ratio >= 0.2: + languages.append((language, ratio)) + + languages = sorted(languages, key=lambda x: x[1], reverse=True) + + return [compatible_language[0] for compatible_language in languages] + + +def characters_popularity_compare( + language: str, ordered_characters: List[str] +) -> float: + """ + Determine if a ordered characters list (by occurrence from most appearance to rarest) match a particular language. + The result is a ratio between 0. (absolutely no correspondence) and 1. (near perfect fit). + Beware that is function is not strict on the match in order to ease the detection. (Meaning close match is 1.) + """ + if language not in FREQUENCIES: + raise ValueError("{} not available".format(language)) + + character_approved_count: int = 0 + FREQUENCIES_language_set = set(FREQUENCIES[language]) + + ordered_characters_count: int = len(ordered_characters) + target_language_characters_count: int = len(FREQUENCIES[language]) + + large_alphabet: bool = target_language_characters_count > 26 + + for character, character_rank in zip( + ordered_characters, range(0, ordered_characters_count) + ): + if character not in FREQUENCIES_language_set: + continue + + character_rank_in_language: int = FREQUENCIES[language].index(character) + expected_projection_ratio: float = ( + target_language_characters_count / ordered_characters_count + ) + character_rank_projection: int = int(character_rank * expected_projection_ratio) + + if ( + large_alphabet is False + and abs(character_rank_projection - character_rank_in_language) > 4 + ): + continue + + if ( + large_alphabet is True + and abs(character_rank_projection - character_rank_in_language) + < target_language_characters_count / 3 + ): + character_approved_count += 1 + continue + + characters_before_source: List[str] = FREQUENCIES[language][ + 0:character_rank_in_language + ] + characters_after_source: List[str] = FREQUENCIES[language][ + character_rank_in_language: + ] + characters_before: List[str] = ordered_characters[0:character_rank] + characters_after: List[str] = ordered_characters[character_rank:] + + before_match_count: int = len( + set(characters_before) & set(characters_before_source) + ) + + after_match_count: int = len( + set(characters_after) & set(characters_after_source) + ) + + if len(characters_before_source) == 0 and before_match_count <= 4: + character_approved_count += 1 + continue + + if len(characters_after_source) == 0 and after_match_count <= 4: + character_approved_count += 1 + continue + + if ( + before_match_count / len(characters_before_source) >= 0.4 + or after_match_count / len(characters_after_source) >= 0.4 + ): + character_approved_count += 1 + continue + + return character_approved_count / len(ordered_characters) + + +def alpha_unicode_split(decoded_sequence: str) -> List[str]: + """ + Given a decoded text sequence, return a list of str. Unicode range / alphabet separation. + Ex. a text containing English/Latin with a bit a Hebrew will return two items in the resulting list; + One containing the latin letters and the other hebrew. + """ + layers: Dict[str, str] = {} + + for character in decoded_sequence: + if character.isalpha() is False: + continue + + character_range: Optional[str] = unicode_range(character) + + if character_range is None: + continue + + layer_target_range: Optional[str] = None + + for discovered_range in layers: + if ( + is_suspiciously_successive_range(discovered_range, character_range) + is False + ): + layer_target_range = discovered_range + break + + if layer_target_range is None: + layer_target_range = character_range + + if layer_target_range not in layers: + layers[layer_target_range] = character.lower() + continue + + layers[layer_target_range] += character.lower() + + return list(layers.values()) + + +def merge_coherence_ratios(results: List[CoherenceMatches]) -> CoherenceMatches: + """ + This function merge results previously given by the function coherence_ratio. + The return type is the same as coherence_ratio. + """ + per_language_ratios: Dict[str, List[float]] = {} + for result in results: + for sub_result in result: + language, ratio = sub_result + if language not in per_language_ratios: + per_language_ratios[language] = [ratio] + continue + per_language_ratios[language].append(ratio) + + merge = [ + ( + language, + round( + sum(per_language_ratios[language]) / len(per_language_ratios[language]), + 4, + ), + ) + for language in per_language_ratios + ] + + return sorted(merge, key=lambda x: x[1], reverse=True) + + +def filter_alt_coherence_matches(results: CoherenceMatches) -> CoherenceMatches: + """ + We shall NOT return "English—" in CoherenceMatches because it is an alternative + of "English". This function only keeps the best match and remove the em-dash in it. + """ + index_results: Dict[str, List[float]] = dict() + + for result in results: + language, ratio = result + no_em_name: str = language.replace("—", "") + + if no_em_name not in index_results: + index_results[no_em_name] = [] + + index_results[no_em_name].append(ratio) + + if any(len(index_results[e]) > 1 for e in index_results): + filtered_results: CoherenceMatches = [] + + for language in index_results: + filtered_results.append((language, max(index_results[language]))) + + return filtered_results + + return results + + +@lru_cache(maxsize=2048) +def coherence_ratio( + decoded_sequence: str, threshold: float = 0.1, lg_inclusion: Optional[str] = None +) -> CoherenceMatches: + """ + Detect ANY language that can be identified in given sequence. The sequence will be analysed by layers. + A layer = Character extraction by alphabets/ranges. + """ + + results: List[Tuple[str, float]] = [] + ignore_non_latin: bool = False + + sufficient_match_count: int = 0 + + lg_inclusion_list = lg_inclusion.split(",") if lg_inclusion is not None else [] + if "Latin Based" in lg_inclusion_list: + ignore_non_latin = True + lg_inclusion_list.remove("Latin Based") + + for layer in alpha_unicode_split(decoded_sequence): + sequence_frequencies: TypeCounter[str] = Counter(layer) + most_common = sequence_frequencies.most_common() + + character_count: int = sum(o for c, o in most_common) + + if character_count <= TOO_SMALL_SEQUENCE: + continue + + popular_character_ordered: List[str] = [c for c, o in most_common] + + for language in lg_inclusion_list or alphabet_languages( + popular_character_ordered, ignore_non_latin + ): + ratio: float = characters_popularity_compare( + language, popular_character_ordered + ) + + if ratio < threshold: + continue + elif ratio >= 0.8: + sufficient_match_count += 1 + + results.append((language, round(ratio, 4))) + + if sufficient_match_count >= 3: + break + + return sorted( + filter_alt_coherence_matches(results), key=lambda x: x[1], reverse=True + ) diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/cli/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/cli/__init__.py new file mode 100644 index 0000000..d95fedf --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/cli/__init__.py @@ -0,0 +1,6 @@ +from .__main__ import cli_detect, query_yes_no + +__all__ = ( + "cli_detect", + "query_yes_no", +) diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/cli/__main__.py b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/cli/__main__.py new file mode 100644 index 0000000..f4bcbaa --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/cli/__main__.py @@ -0,0 +1,296 @@ +import argparse +import sys +from json import dumps +from os.path import abspath, basename, dirname, join, realpath +from platform import python_version +from typing import List, Optional +from unicodedata import unidata_version + +import charset_normalizer.md as md_module +from charset_normalizer import from_fp +from charset_normalizer.models import CliDetectionResult +from charset_normalizer.version import __version__ + + +def query_yes_no(question: str, default: str = "yes") -> bool: + """Ask a yes/no question via input() and return their answer. + + "question" is a string that is presented to the user. + "default" is the presumed answer if the user just hits . + It must be "yes" (the default), "no" or None (meaning + an answer is required of the user). + + The "answer" return value is True for "yes" or False for "no". + + Credit goes to (c) https://stackoverflow.com/questions/3041986/apt-command-line-interface-like-yes-no-input + """ + valid = {"yes": True, "y": True, "ye": True, "no": False, "n": False} + if default is None: + prompt = " [y/n] " + elif default == "yes": + prompt = " [Y/n] " + elif default == "no": + prompt = " [y/N] " + else: + raise ValueError("invalid default answer: '%s'" % default) + + while True: + sys.stdout.write(question + prompt) + choice = input().lower() + if default is not None and choice == "": + return valid[default] + elif choice in valid: + return valid[choice] + else: + sys.stdout.write("Please respond with 'yes' or 'no' " "(or 'y' or 'n').\n") + + +def cli_detect(argv: Optional[List[str]] = None) -> int: + """ + CLI assistant using ARGV and ArgumentParser + :param argv: + :return: 0 if everything is fine, anything else equal trouble + """ + parser = argparse.ArgumentParser( + description="The Real First Universal Charset Detector. " + "Discover originating encoding used on text file. " + "Normalize text to unicode." + ) + + parser.add_argument( + "files", type=argparse.FileType("rb"), nargs="+", help="File(s) to be analysed" + ) + parser.add_argument( + "-v", + "--verbose", + action="store_true", + default=False, + dest="verbose", + help="Display complementary information about file if any. " + "Stdout will contain logs about the detection process.", + ) + parser.add_argument( + "-a", + "--with-alternative", + action="store_true", + default=False, + dest="alternatives", + help="Output complementary possibilities if any. Top-level JSON WILL be a list.", + ) + parser.add_argument( + "-n", + "--normalize", + action="store_true", + default=False, + dest="normalize", + help="Permit to normalize input file. If not set, program does not write anything.", + ) + parser.add_argument( + "-m", + "--minimal", + action="store_true", + default=False, + dest="minimal", + help="Only output the charset detected to STDOUT. Disabling JSON output.", + ) + parser.add_argument( + "-r", + "--replace", + action="store_true", + default=False, + dest="replace", + help="Replace file when trying to normalize it instead of creating a new one.", + ) + parser.add_argument( + "-f", + "--force", + action="store_true", + default=False, + dest="force", + help="Replace file without asking if you are sure, use this flag with caution.", + ) + parser.add_argument( + "-t", + "--threshold", + action="store", + default=0.2, + type=float, + dest="threshold", + help="Define a custom maximum amount of chaos allowed in decoded content. 0. <= chaos <= 1.", + ) + parser.add_argument( + "--version", + action="version", + version="Charset-Normalizer {} - Python {} - Unicode {} - SpeedUp {}".format( + __version__, + python_version(), + unidata_version, + "OFF" if md_module.__file__.lower().endswith(".py") else "ON", + ), + help="Show version information and exit.", + ) + + args = parser.parse_args(argv) + + if args.replace is True and args.normalize is False: + print("Use --replace in addition of --normalize only.", file=sys.stderr) + return 1 + + if args.force is True and args.replace is False: + print("Use --force in addition of --replace only.", file=sys.stderr) + return 1 + + if args.threshold < 0.0 or args.threshold > 1.0: + print("--threshold VALUE should be between 0. AND 1.", file=sys.stderr) + return 1 + + x_ = [] + + for my_file in args.files: + matches = from_fp(my_file, threshold=args.threshold, explain=args.verbose) + + best_guess = matches.best() + + if best_guess is None: + print( + 'Unable to identify originating encoding for "{}". {}'.format( + my_file.name, + "Maybe try increasing maximum amount of chaos." + if args.threshold < 1.0 + else "", + ), + file=sys.stderr, + ) + x_.append( + CliDetectionResult( + abspath(my_file.name), + None, + [], + [], + "Unknown", + [], + False, + 1.0, + 0.0, + None, + True, + ) + ) + else: + x_.append( + CliDetectionResult( + abspath(my_file.name), + best_guess.encoding, + best_guess.encoding_aliases, + [ + cp + for cp in best_guess.could_be_from_charset + if cp != best_guess.encoding + ], + best_guess.language, + best_guess.alphabets, + best_guess.bom, + best_guess.percent_chaos, + best_guess.percent_coherence, + None, + True, + ) + ) + + if len(matches) > 1 and args.alternatives: + for el in matches: + if el != best_guess: + x_.append( + CliDetectionResult( + abspath(my_file.name), + el.encoding, + el.encoding_aliases, + [ + cp + for cp in el.could_be_from_charset + if cp != el.encoding + ], + el.language, + el.alphabets, + el.bom, + el.percent_chaos, + el.percent_coherence, + None, + False, + ) + ) + + if args.normalize is True: + if best_guess.encoding.startswith("utf") is True: + print( + '"{}" file does not need to be normalized, as it already came from unicode.'.format( + my_file.name + ), + file=sys.stderr, + ) + if my_file.closed is False: + my_file.close() + continue + + dir_path = dirname(realpath(my_file.name)) + file_name = basename(realpath(my_file.name)) + + o_: List[str] = file_name.split(".") + + if args.replace is False: + o_.insert(-1, best_guess.encoding) + if my_file.closed is False: + my_file.close() + elif ( + args.force is False + and query_yes_no( + 'Are you sure to normalize "{}" by replacing it ?'.format( + my_file.name + ), + "no", + ) + is False + ): + if my_file.closed is False: + my_file.close() + continue + + try: + x_[0].unicode_path = join(dir_path, ".".join(o_)) + + with open(x_[0].unicode_path, "w", encoding="utf-8") as fp: + fp.write(str(best_guess)) + except IOError as e: + print(str(e), file=sys.stderr) + if my_file.closed is False: + my_file.close() + return 2 + + if my_file.closed is False: + my_file.close() + + if args.minimal is False: + print( + dumps( + [el.__dict__ for el in x_] if len(x_) > 1 else x_[0].__dict__, + ensure_ascii=True, + indent=4, + ) + ) + else: + for my_file in args.files: + print( + ", ".join( + [ + el.encoding or "undefined" + for el in x_ + if el.path == abspath(my_file.name) + ] + ) + ) + + return 0 + + +if __name__ == "__main__": + cli_detect() diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/constant.py b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/constant.py new file mode 100644 index 0000000..8634904 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/constant.py @@ -0,0 +1,1995 @@ +# -*- coding: utf-8 -*- +from codecs import BOM_UTF8, BOM_UTF16_BE, BOM_UTF16_LE, BOM_UTF32_BE, BOM_UTF32_LE +from encodings.aliases import aliases +from re import IGNORECASE, compile as re_compile +from typing import Dict, List, Set, Union + +# Contain for each eligible encoding a list of/item bytes SIG/BOM +ENCODING_MARKS: Dict[str, Union[bytes, List[bytes]]] = { + "utf_8": BOM_UTF8, + "utf_7": [ + b"\x2b\x2f\x76\x38", + b"\x2b\x2f\x76\x39", + b"\x2b\x2f\x76\x2b", + b"\x2b\x2f\x76\x2f", + b"\x2b\x2f\x76\x38\x2d", + ], + "gb18030": b"\x84\x31\x95\x33", + "utf_32": [BOM_UTF32_BE, BOM_UTF32_LE], + "utf_16": [BOM_UTF16_BE, BOM_UTF16_LE], +} + +TOO_SMALL_SEQUENCE: int = 32 +TOO_BIG_SEQUENCE: int = int(10e6) + +UTF8_MAXIMAL_ALLOCATION: int = 1_112_064 + +# Up-to-date Unicode ucd/15.0.0 +UNICODE_RANGES_COMBINED: Dict[str, range] = { + "Control character": range(32), + "Basic Latin": range(32, 128), + "Latin-1 Supplement": range(128, 256), + "Latin Extended-A": range(256, 384), + "Latin Extended-B": range(384, 592), + "IPA Extensions": range(592, 688), + "Spacing Modifier Letters": range(688, 768), + "Combining Diacritical Marks": range(768, 880), + "Greek and Coptic": range(880, 1024), + "Cyrillic": range(1024, 1280), + "Cyrillic Supplement": range(1280, 1328), + "Armenian": range(1328, 1424), + "Hebrew": range(1424, 1536), + "Arabic": range(1536, 1792), + "Syriac": range(1792, 1872), + "Arabic Supplement": range(1872, 1920), + "Thaana": range(1920, 1984), + "NKo": range(1984, 2048), + "Samaritan": range(2048, 2112), + "Mandaic": range(2112, 2144), + "Syriac Supplement": range(2144, 2160), + "Arabic Extended-B": range(2160, 2208), + "Arabic Extended-A": range(2208, 2304), + "Devanagari": range(2304, 2432), + "Bengali": range(2432, 2560), + "Gurmukhi": range(2560, 2688), + "Gujarati": range(2688, 2816), + "Oriya": range(2816, 2944), + "Tamil": range(2944, 3072), + "Telugu": range(3072, 3200), + "Kannada": range(3200, 3328), + "Malayalam": range(3328, 3456), + "Sinhala": range(3456, 3584), + "Thai": range(3584, 3712), + "Lao": range(3712, 3840), + "Tibetan": range(3840, 4096), + "Myanmar": range(4096, 4256), + "Georgian": range(4256, 4352), + "Hangul Jamo": range(4352, 4608), + "Ethiopic": range(4608, 4992), + "Ethiopic Supplement": range(4992, 5024), + "Cherokee": range(5024, 5120), + "Unified Canadian Aboriginal Syllabics": range(5120, 5760), + "Ogham": range(5760, 5792), + "Runic": range(5792, 5888), + "Tagalog": range(5888, 5920), + "Hanunoo": range(5920, 5952), + "Buhid": range(5952, 5984), + "Tagbanwa": range(5984, 6016), + "Khmer": range(6016, 6144), + "Mongolian": range(6144, 6320), + "Unified Canadian Aboriginal Syllabics Extended": range(6320, 6400), + "Limbu": range(6400, 6480), + "Tai Le": range(6480, 6528), + "New Tai Lue": range(6528, 6624), + "Khmer Symbols": range(6624, 6656), + "Buginese": range(6656, 6688), + "Tai Tham": range(6688, 6832), + "Combining Diacritical Marks Extended": range(6832, 6912), + "Balinese": range(6912, 7040), + "Sundanese": range(7040, 7104), + "Batak": range(7104, 7168), + "Lepcha": range(7168, 7248), + "Ol Chiki": range(7248, 7296), + "Cyrillic Extended-C": range(7296, 7312), + "Georgian Extended": range(7312, 7360), + "Sundanese Supplement": range(7360, 7376), + "Vedic Extensions": range(7376, 7424), + "Phonetic Extensions": range(7424, 7552), + "Phonetic Extensions Supplement": range(7552, 7616), + "Combining Diacritical Marks Supplement": range(7616, 7680), + "Latin Extended Additional": range(7680, 7936), + "Greek Extended": range(7936, 8192), + "General Punctuation": range(8192, 8304), + "Superscripts and Subscripts": range(8304, 8352), + "Currency Symbols": range(8352, 8400), + "Combining Diacritical Marks for Symbols": range(8400, 8448), + "Letterlike Symbols": range(8448, 8528), + "Number Forms": range(8528, 8592), + "Arrows": range(8592, 8704), + "Mathematical Operators": range(8704, 8960), + "Miscellaneous Technical": range(8960, 9216), + "Control Pictures": range(9216, 9280), + "Optical Character Recognition": range(9280, 9312), + "Enclosed Alphanumerics": range(9312, 9472), + "Box Drawing": range(9472, 9600), + "Block Elements": range(9600, 9632), + "Geometric Shapes": range(9632, 9728), + "Miscellaneous Symbols": range(9728, 9984), + "Dingbats": range(9984, 10176), + "Miscellaneous Mathematical Symbols-A": range(10176, 10224), + "Supplemental Arrows-A": range(10224, 10240), + "Braille Patterns": range(10240, 10496), + "Supplemental Arrows-B": range(10496, 10624), + "Miscellaneous Mathematical Symbols-B": range(10624, 10752), + "Supplemental Mathematical Operators": range(10752, 11008), + "Miscellaneous Symbols and Arrows": range(11008, 11264), + "Glagolitic": range(11264, 11360), + "Latin Extended-C": range(11360, 11392), + "Coptic": range(11392, 11520), + "Georgian Supplement": range(11520, 11568), + "Tifinagh": range(11568, 11648), + "Ethiopic Extended": range(11648, 11744), + "Cyrillic Extended-A": range(11744, 11776), + "Supplemental Punctuation": range(11776, 11904), + "CJK Radicals Supplement": range(11904, 12032), + "Kangxi Radicals": range(12032, 12256), + "Ideographic Description Characters": range(12272, 12288), + "CJK Symbols and Punctuation": range(12288, 12352), + "Hiragana": range(12352, 12448), + "Katakana": range(12448, 12544), + "Bopomofo": range(12544, 12592), + "Hangul Compatibility Jamo": range(12592, 12688), + "Kanbun": range(12688, 12704), + "Bopomofo Extended": range(12704, 12736), + "CJK Strokes": range(12736, 12784), + "Katakana Phonetic Extensions": range(12784, 12800), + "Enclosed CJK Letters and Months": range(12800, 13056), + "CJK Compatibility": range(13056, 13312), + "CJK Unified Ideographs Extension A": range(13312, 19904), + "Yijing Hexagram Symbols": range(19904, 19968), + "CJK Unified Ideographs": range(19968, 40960), + "Yi Syllables": range(40960, 42128), + "Yi Radicals": range(42128, 42192), + "Lisu": range(42192, 42240), + "Vai": range(42240, 42560), + "Cyrillic Extended-B": range(42560, 42656), + "Bamum": range(42656, 42752), + "Modifier Tone Letters": range(42752, 42784), + "Latin Extended-D": range(42784, 43008), + "Syloti Nagri": range(43008, 43056), + "Common Indic Number Forms": range(43056, 43072), + "Phags-pa": range(43072, 43136), + "Saurashtra": range(43136, 43232), + "Devanagari Extended": range(43232, 43264), + "Kayah Li": range(43264, 43312), + "Rejang": range(43312, 43360), + "Hangul Jamo Extended-A": range(43360, 43392), + "Javanese": range(43392, 43488), + "Myanmar Extended-B": range(43488, 43520), + "Cham": range(43520, 43616), + "Myanmar Extended-A": range(43616, 43648), + "Tai Viet": range(43648, 43744), + "Meetei Mayek Extensions": range(43744, 43776), + "Ethiopic Extended-A": range(43776, 43824), + "Latin Extended-E": range(43824, 43888), + "Cherokee Supplement": range(43888, 43968), + "Meetei Mayek": range(43968, 44032), + "Hangul Syllables": range(44032, 55216), + "Hangul Jamo Extended-B": range(55216, 55296), + "High Surrogates": range(55296, 56192), + "High Private Use Surrogates": range(56192, 56320), + "Low Surrogates": range(56320, 57344), + "Private Use Area": range(57344, 63744), + "CJK Compatibility Ideographs": range(63744, 64256), + "Alphabetic Presentation Forms": range(64256, 64336), + "Arabic Presentation Forms-A": range(64336, 65024), + "Variation Selectors": range(65024, 65040), + "Vertical Forms": range(65040, 65056), + "Combining Half Marks": range(65056, 65072), + "CJK Compatibility Forms": range(65072, 65104), + "Small Form Variants": range(65104, 65136), + "Arabic Presentation Forms-B": range(65136, 65280), + "Halfwidth and Fullwidth Forms": range(65280, 65520), + "Specials": range(65520, 65536), + "Linear B Syllabary": range(65536, 65664), + "Linear B Ideograms": range(65664, 65792), + "Aegean Numbers": range(65792, 65856), + "Ancient Greek Numbers": range(65856, 65936), + "Ancient Symbols": range(65936, 66000), + "Phaistos Disc": range(66000, 66048), + "Lycian": range(66176, 66208), + "Carian": range(66208, 66272), + "Coptic Epact Numbers": range(66272, 66304), + "Old Italic": range(66304, 66352), + "Gothic": range(66352, 66384), + "Old Permic": range(66384, 66432), + "Ugaritic": range(66432, 66464), + "Old Persian": range(66464, 66528), + "Deseret": range(66560, 66640), + "Shavian": range(66640, 66688), + "Osmanya": range(66688, 66736), + "Osage": range(66736, 66816), + "Elbasan": range(66816, 66864), + "Caucasian Albanian": range(66864, 66928), + "Vithkuqi": range(66928, 67008), + "Linear A": range(67072, 67456), + "Latin Extended-F": range(67456, 67520), + "Cypriot Syllabary": range(67584, 67648), + "Imperial Aramaic": range(67648, 67680), + "Palmyrene": range(67680, 67712), + "Nabataean": range(67712, 67760), + "Hatran": range(67808, 67840), + "Phoenician": range(67840, 67872), + "Lydian": range(67872, 67904), + "Meroitic Hieroglyphs": range(67968, 68000), + "Meroitic Cursive": range(68000, 68096), + "Kharoshthi": range(68096, 68192), + "Old South Arabian": range(68192, 68224), + "Old North Arabian": range(68224, 68256), + "Manichaean": range(68288, 68352), + "Avestan": range(68352, 68416), + "Inscriptional Parthian": range(68416, 68448), + "Inscriptional Pahlavi": range(68448, 68480), + "Psalter Pahlavi": range(68480, 68528), + "Old Turkic": range(68608, 68688), + "Old Hungarian": range(68736, 68864), + "Hanifi Rohingya": range(68864, 68928), + "Rumi Numeral Symbols": range(69216, 69248), + "Yezidi": range(69248, 69312), + "Arabic Extended-C": range(69312, 69376), + "Old Sogdian": range(69376, 69424), + "Sogdian": range(69424, 69488), + "Old Uyghur": range(69488, 69552), + "Chorasmian": range(69552, 69600), + "Elymaic": range(69600, 69632), + "Brahmi": range(69632, 69760), + "Kaithi": range(69760, 69840), + "Sora Sompeng": range(69840, 69888), + "Chakma": range(69888, 69968), + "Mahajani": range(69968, 70016), + "Sharada": range(70016, 70112), + "Sinhala Archaic Numbers": range(70112, 70144), + "Khojki": range(70144, 70224), + "Multani": range(70272, 70320), + "Khudawadi": range(70320, 70400), + "Grantha": range(70400, 70528), + "Newa": range(70656, 70784), + "Tirhuta": range(70784, 70880), + "Siddham": range(71040, 71168), + "Modi": range(71168, 71264), + "Mongolian Supplement": range(71264, 71296), + "Takri": range(71296, 71376), + "Ahom": range(71424, 71504), + "Dogra": range(71680, 71760), + "Warang Citi": range(71840, 71936), + "Dives Akuru": range(71936, 72032), + "Nandinagari": range(72096, 72192), + "Zanabazar Square": range(72192, 72272), + "Soyombo": range(72272, 72368), + "Unified Canadian Aboriginal Syllabics Extended-A": range(72368, 72384), + "Pau Cin Hau": range(72384, 72448), + "Devanagari Extended-A": range(72448, 72544), + "Bhaiksuki": range(72704, 72816), + "Marchen": range(72816, 72896), + "Masaram Gondi": range(72960, 73056), + "Gunjala Gondi": range(73056, 73136), + "Makasar": range(73440, 73472), + "Kawi": range(73472, 73568), + "Lisu Supplement": range(73648, 73664), + "Tamil Supplement": range(73664, 73728), + "Cuneiform": range(73728, 74752), + "Cuneiform Numbers and Punctuation": range(74752, 74880), + "Early Dynastic Cuneiform": range(74880, 75088), + "Cypro-Minoan": range(77712, 77824), + "Egyptian Hieroglyphs": range(77824, 78896), + "Egyptian Hieroglyph Format Controls": range(78896, 78944), + "Anatolian Hieroglyphs": range(82944, 83584), + "Bamum Supplement": range(92160, 92736), + "Mro": range(92736, 92784), + "Tangsa": range(92784, 92880), + "Bassa Vah": range(92880, 92928), + "Pahawh Hmong": range(92928, 93072), + "Medefaidrin": range(93760, 93856), + "Miao": range(93952, 94112), + "Ideographic Symbols and Punctuation": range(94176, 94208), + "Tangut": range(94208, 100352), + "Tangut Components": range(100352, 101120), + "Khitan Small Script": range(101120, 101632), + "Tangut Supplement": range(101632, 101760), + "Kana Extended-B": range(110576, 110592), + "Kana Supplement": range(110592, 110848), + "Kana Extended-A": range(110848, 110896), + "Small Kana Extension": range(110896, 110960), + "Nushu": range(110960, 111360), + "Duployan": range(113664, 113824), + "Shorthand Format Controls": range(113824, 113840), + "Znamenny Musical Notation": range(118528, 118736), + "Byzantine Musical Symbols": range(118784, 119040), + "Musical Symbols": range(119040, 119296), + "Ancient Greek Musical Notation": range(119296, 119376), + "Kaktovik Numerals": range(119488, 119520), + "Mayan Numerals": range(119520, 119552), + "Tai Xuan Jing Symbols": range(119552, 119648), + "Counting Rod Numerals": range(119648, 119680), + "Mathematical Alphanumeric Symbols": range(119808, 120832), + "Sutton SignWriting": range(120832, 121520), + "Latin Extended-G": range(122624, 122880), + "Glagolitic Supplement": range(122880, 122928), + "Cyrillic Extended-D": range(122928, 123024), + "Nyiakeng Puachue Hmong": range(123136, 123216), + "Toto": range(123536, 123584), + "Wancho": range(123584, 123648), + "Nag Mundari": range(124112, 124160), + "Ethiopic Extended-B": range(124896, 124928), + "Mende Kikakui": range(124928, 125152), + "Adlam": range(125184, 125280), + "Indic Siyaq Numbers": range(126064, 126144), + "Ottoman Siyaq Numbers": range(126208, 126288), + "Arabic Mathematical Alphabetic Symbols": range(126464, 126720), + "Mahjong Tiles": range(126976, 127024), + "Domino Tiles": range(127024, 127136), + "Playing Cards": range(127136, 127232), + "Enclosed Alphanumeric Supplement": range(127232, 127488), + "Enclosed Ideographic Supplement": range(127488, 127744), + "Miscellaneous Symbols and Pictographs": range(127744, 128512), + "Emoticons range(Emoji)": range(128512, 128592), + "Ornamental Dingbats": range(128592, 128640), + "Transport and Map Symbols": range(128640, 128768), + "Alchemical Symbols": range(128768, 128896), + "Geometric Shapes Extended": range(128896, 129024), + "Supplemental Arrows-C": range(129024, 129280), + "Supplemental Symbols and Pictographs": range(129280, 129536), + "Chess Symbols": range(129536, 129648), + "Symbols and Pictographs Extended-A": range(129648, 129792), + "Symbols for Legacy Computing": range(129792, 130048), + "CJK Unified Ideographs Extension B": range(131072, 173792), + "CJK Unified Ideographs Extension C": range(173824, 177984), + "CJK Unified Ideographs Extension D": range(177984, 178208), + "CJK Unified Ideographs Extension E": range(178208, 183984), + "CJK Unified Ideographs Extension F": range(183984, 191472), + "CJK Compatibility Ideographs Supplement": range(194560, 195104), + "CJK Unified Ideographs Extension G": range(196608, 201552), + "CJK Unified Ideographs Extension H": range(201552, 205744), + "Tags": range(917504, 917632), + "Variation Selectors Supplement": range(917760, 918000), + "Supplementary Private Use Area-A": range(983040, 1048576), + "Supplementary Private Use Area-B": range(1048576, 1114112), +} + + +UNICODE_SECONDARY_RANGE_KEYWORD: List[str] = [ + "Supplement", + "Extended", + "Extensions", + "Modifier", + "Marks", + "Punctuation", + "Symbols", + "Forms", + "Operators", + "Miscellaneous", + "Drawing", + "Block", + "Shapes", + "Supplemental", + "Tags", +] + +RE_POSSIBLE_ENCODING_INDICATION = re_compile( + r"(?:(?:encoding)|(?:charset)|(?:coding))(?:[\:= ]{1,10})(?:[\"\']?)([a-zA-Z0-9\-_]+)(?:[\"\']?)", + IGNORECASE, +) + +IANA_NO_ALIASES = [ + "cp720", + "cp737", + "cp856", + "cp874", + "cp875", + "cp1006", + "koi8_r", + "koi8_t", + "koi8_u", +] + +IANA_SUPPORTED: List[str] = sorted( + filter( + lambda x: x.endswith("_codec") is False + and x not in {"rot_13", "tactis", "mbcs"}, + list(set(aliases.values())) + IANA_NO_ALIASES, + ) +) + +IANA_SUPPORTED_COUNT: int = len(IANA_SUPPORTED) + +# pre-computed code page that are similar using the function cp_similarity. +IANA_SUPPORTED_SIMILAR: Dict[str, List[str]] = { + "cp037": ["cp1026", "cp1140", "cp273", "cp500"], + "cp1026": ["cp037", "cp1140", "cp273", "cp500"], + "cp1125": ["cp866"], + "cp1140": ["cp037", "cp1026", "cp273", "cp500"], + "cp1250": ["iso8859_2"], + "cp1251": ["kz1048", "ptcp154"], + "cp1252": ["iso8859_15", "iso8859_9", "latin_1"], + "cp1253": ["iso8859_7"], + "cp1254": ["iso8859_15", "iso8859_9", "latin_1"], + "cp1257": ["iso8859_13"], + "cp273": ["cp037", "cp1026", "cp1140", "cp500"], + "cp437": ["cp850", "cp858", "cp860", "cp861", "cp862", "cp863", "cp865"], + "cp500": ["cp037", "cp1026", "cp1140", "cp273"], + "cp850": ["cp437", "cp857", "cp858", "cp865"], + "cp857": ["cp850", "cp858", "cp865"], + "cp858": ["cp437", "cp850", "cp857", "cp865"], + "cp860": ["cp437", "cp861", "cp862", "cp863", "cp865"], + "cp861": ["cp437", "cp860", "cp862", "cp863", "cp865"], + "cp862": ["cp437", "cp860", "cp861", "cp863", "cp865"], + "cp863": ["cp437", "cp860", "cp861", "cp862", "cp865"], + "cp865": ["cp437", "cp850", "cp857", "cp858", "cp860", "cp861", "cp862", "cp863"], + "cp866": ["cp1125"], + "iso8859_10": ["iso8859_14", "iso8859_15", "iso8859_4", "iso8859_9", "latin_1"], + "iso8859_11": ["tis_620"], + "iso8859_13": ["cp1257"], + "iso8859_14": [ + "iso8859_10", + "iso8859_15", + "iso8859_16", + "iso8859_3", + "iso8859_9", + "latin_1", + ], + "iso8859_15": [ + "cp1252", + "cp1254", + "iso8859_10", + "iso8859_14", + "iso8859_16", + "iso8859_3", + "iso8859_9", + "latin_1", + ], + "iso8859_16": [ + "iso8859_14", + "iso8859_15", + "iso8859_2", + "iso8859_3", + "iso8859_9", + "latin_1", + ], + "iso8859_2": ["cp1250", "iso8859_16", "iso8859_4"], + "iso8859_3": ["iso8859_14", "iso8859_15", "iso8859_16", "iso8859_9", "latin_1"], + "iso8859_4": ["iso8859_10", "iso8859_2", "iso8859_9", "latin_1"], + "iso8859_7": ["cp1253"], + "iso8859_9": [ + "cp1252", + "cp1254", + "cp1258", + "iso8859_10", + "iso8859_14", + "iso8859_15", + "iso8859_16", + "iso8859_3", + "iso8859_4", + "latin_1", + ], + "kz1048": ["cp1251", "ptcp154"], + "latin_1": [ + "cp1252", + "cp1254", + "cp1258", + "iso8859_10", + "iso8859_14", + "iso8859_15", + "iso8859_16", + "iso8859_3", + "iso8859_4", + "iso8859_9", + ], + "mac_iceland": ["mac_roman", "mac_turkish"], + "mac_roman": ["mac_iceland", "mac_turkish"], + "mac_turkish": ["mac_iceland", "mac_roman"], + "ptcp154": ["cp1251", "kz1048"], + "tis_620": ["iso8859_11"], +} + + +CHARDET_CORRESPONDENCE: Dict[str, str] = { + "iso2022_kr": "ISO-2022-KR", + "iso2022_jp": "ISO-2022-JP", + "euc_kr": "EUC-KR", + "tis_620": "TIS-620", + "utf_32": "UTF-32", + "euc_jp": "EUC-JP", + "koi8_r": "KOI8-R", + "iso8859_1": "ISO-8859-1", + "iso8859_2": "ISO-8859-2", + "iso8859_5": "ISO-8859-5", + "iso8859_6": "ISO-8859-6", + "iso8859_7": "ISO-8859-7", + "iso8859_8": "ISO-8859-8", + "utf_16": "UTF-16", + "cp855": "IBM855", + "mac_cyrillic": "MacCyrillic", + "gb2312": "GB2312", + "gb18030": "GB18030", + "cp932": "CP932", + "cp866": "IBM866", + "utf_8": "utf-8", + "utf_8_sig": "UTF-8-SIG", + "shift_jis": "SHIFT_JIS", + "big5": "Big5", + "cp1250": "windows-1250", + "cp1251": "windows-1251", + "cp1252": "Windows-1252", + "cp1253": "windows-1253", + "cp1255": "windows-1255", + "cp1256": "windows-1256", + "cp1254": "Windows-1254", + "cp949": "CP949", +} + + +COMMON_SAFE_ASCII_CHARACTERS: Set[str] = { + "<", + ">", + "=", + ":", + "/", + "&", + ";", + "{", + "}", + "[", + "]", + ",", + "|", + '"', + "-", +} + + +KO_NAMES: Set[str] = {"johab", "cp949", "euc_kr"} +ZH_NAMES: Set[str] = {"big5", "cp950", "big5hkscs", "hz"} + +# Logging LEVEL below DEBUG +TRACE: int = 5 + + +# Language label that contain the em dash "—" +# character are to be considered alternative seq to origin +FREQUENCIES: Dict[str, List[str]] = { + "English": [ + "e", + "a", + "t", + "i", + "o", + "n", + "s", + "r", + "h", + "l", + "d", + "c", + "u", + "m", + "f", + "p", + "g", + "w", + "y", + "b", + "v", + "k", + "x", + "j", + "z", + "q", + ], + "English—": [ + "e", + "a", + "t", + "i", + "o", + "n", + "s", + "r", + "h", + "l", + "d", + "c", + "m", + "u", + "f", + "p", + "g", + "w", + "b", + "y", + "v", + "k", + "j", + "x", + "z", + "q", + ], + "German": [ + "e", + "n", + "i", + "r", + "s", + "t", + "a", + "d", + "h", + "u", + "l", + "g", + "o", + "c", + "m", + "b", + "f", + "k", + "w", + "z", + "p", + "v", + "ü", + "ä", + "ö", + "j", + ], + "French": [ + "e", + "a", + "s", + "n", + "i", + "t", + "r", + "l", + "u", + "o", + "d", + "c", + "p", + "m", + "é", + "v", + "g", + "f", + "b", + "h", + "q", + "à", + "x", + "è", + "y", + "j", + ], + "Dutch": [ + "e", + "n", + "a", + "i", + "r", + "t", + "o", + "d", + "s", + "l", + "g", + "h", + "v", + "m", + "u", + "k", + "c", + "p", + "b", + "w", + "j", + "z", + "f", + "y", + "x", + "ë", + ], + "Italian": [ + "e", + "i", + "a", + "o", + "n", + "l", + "t", + "r", + "s", + "c", + "d", + "u", + "p", + "m", + "g", + "v", + "f", + "b", + "z", + "h", + "q", + "è", + "à", + "k", + "y", + "ò", + ], + "Polish": [ + "a", + "i", + "o", + "e", + "n", + "r", + "z", + "w", + "s", + "c", + "t", + "k", + "y", + "d", + "p", + "m", + "u", + "l", + "j", + "ł", + "g", + "b", + "h", + "ą", + "ę", + "ó", + ], + "Spanish": [ + "e", + "a", + "o", + "n", + "s", + "r", + "i", + "l", + "d", + "t", + "c", + "u", + "m", + "p", + "b", + "g", + "v", + "f", + "y", + "ó", + "h", + "q", + "í", + "j", + "z", + "á", + ], + "Russian": [ + "о", + "а", + "е", + "и", + "н", + "с", + "т", + "р", + "в", + "л", + "к", + "м", + "д", + "п", + "у", + "г", + "я", + "ы", + "з", + "б", + "й", + "ь", + "ч", + "х", + "ж", + "ц", + ], + # Jap-Kanji + "Japanese": [ + "人", + "一", + "大", + "亅", + "丁", + "丨", + "竹", + "笑", + "口", + "日", + "今", + "二", + "彳", + "行", + "十", + "土", + "丶", + "寸", + "寺", + "時", + "乙", + "丿", + "乂", + "气", + "気", + "冂", + "巾", + "亠", + "市", + "目", + "儿", + "見", + "八", + "小", + "凵", + "県", + "月", + "彐", + "門", + "間", + "木", + "東", + "山", + "出", + "本", + "中", + "刀", + "分", + "耳", + "又", + "取", + "最", + "言", + "田", + "心", + "思", + "刂", + "前", + "京", + "尹", + "事", + "生", + "厶", + "云", + "会", + "未", + "来", + "白", + "冫", + "楽", + "灬", + "馬", + "尸", + "尺", + "駅", + "明", + "耂", + "者", + "了", + "阝", + "都", + "高", + "卜", + "占", + "厂", + "广", + "店", + "子", + "申", + "奄", + "亻", + "俺", + "上", + "方", + "冖", + "学", + "衣", + "艮", + "食", + "自", + ], + # Jap-Katakana + "Japanese—": [ + "ー", + "ン", + "ス", + "・", + "ル", + "ト", + "リ", + "イ", + "ア", + "ラ", + "ッ", + "ク", + "ド", + "シ", + "レ", + "ジ", + "タ", + "フ", + "ロ", + "カ", + "テ", + "マ", + "ィ", + "グ", + "バ", + "ム", + "プ", + "オ", + "コ", + "デ", + "ニ", + "ウ", + "メ", + "サ", + "ビ", + "ナ", + "ブ", + "ャ", + "エ", + "ュ", + "チ", + "キ", + "ズ", + "ダ", + "パ", + "ミ", + "ェ", + "ョ", + "ハ", + "セ", + "ベ", + "ガ", + "モ", + "ツ", + "ネ", + "ボ", + "ソ", + "ノ", + "ァ", + "ヴ", + "ワ", + "ポ", + "ペ", + "ピ", + "ケ", + "ゴ", + "ギ", + "ザ", + "ホ", + "ゲ", + "ォ", + "ヤ", + "ヒ", + "ユ", + "ヨ", + "ヘ", + "ゼ", + "ヌ", + "ゥ", + "ゾ", + "ヶ", + "ヂ", + "ヲ", + "ヅ", + "ヵ", + "ヱ", + "ヰ", + "ヮ", + "ヽ", + "゠", + "ヾ", + "ヷ", + "ヿ", + "ヸ", + "ヹ", + "ヺ", + ], + # Jap-Hiragana + "Japanese——": [ + "の", + "に", + "る", + "た", + "と", + "は", + "し", + "い", + "を", + "で", + "て", + "が", + "な", + "れ", + "か", + "ら", + "さ", + "っ", + "り", + "す", + "あ", + "も", + "こ", + "ま", + "う", + "く", + "よ", + "き", + "ん", + "め", + "お", + "け", + "そ", + "つ", + "だ", + "や", + "え", + "ど", + "わ", + "ち", + "み", + "せ", + "じ", + "ば", + "へ", + "び", + "ず", + "ろ", + "ほ", + "げ", + "む", + "べ", + "ひ", + "ょ", + "ゆ", + "ぶ", + "ご", + "ゃ", + "ね", + "ふ", + "ぐ", + "ぎ", + "ぼ", + "ゅ", + "づ", + "ざ", + "ぞ", + "ぬ", + "ぜ", + "ぱ", + "ぽ", + "ぷ", + "ぴ", + "ぃ", + "ぁ", + "ぇ", + "ぺ", + "ゞ", + "ぢ", + "ぉ", + "ぅ", + "ゐ", + "ゝ", + "ゑ", + "゛", + "゜", + "ゎ", + "ゔ", + "゚", + "ゟ", + "゙", + "ゕ", + "ゖ", + ], + "Portuguese": [ + "a", + "e", + "o", + "s", + "i", + "r", + "d", + "n", + "t", + "m", + "u", + "c", + "l", + "p", + "g", + "v", + "b", + "f", + "h", + "ã", + "q", + "é", + "ç", + "á", + "z", + "í", + ], + "Swedish": [ + "e", + "a", + "n", + "r", + "t", + "s", + "i", + "l", + "d", + "o", + "m", + "k", + "g", + "v", + "h", + "f", + "u", + "p", + "ä", + "c", + "b", + "ö", + "å", + "y", + "j", + "x", + ], + "Chinese": [ + "的", + "一", + "是", + "不", + "了", + "在", + "人", + "有", + "我", + "他", + "这", + "个", + "们", + "中", + "来", + "上", + "大", + "为", + "和", + "国", + "地", + "到", + "以", + "说", + "时", + "要", + "就", + "出", + "会", + "可", + "也", + "你", + "对", + "生", + "能", + "而", + "子", + "那", + "得", + "于", + "着", + "下", + "自", + "之", + "年", + "过", + "发", + "后", + "作", + "里", + "用", + "道", + "行", + "所", + "然", + "家", + "种", + "事", + "成", + "方", + "多", + "经", + "么", + "去", + "法", + "学", + "如", + "都", + "同", + "现", + "当", + "没", + "动", + "面", + "起", + "看", + "定", + "天", + "分", + "还", + "进", + "好", + "小", + "部", + "其", + "些", + "主", + "样", + "理", + "心", + "她", + "本", + "前", + "开", + "但", + "因", + "只", + "从", + "想", + "实", + ], + "Ukrainian": [ + "о", + "а", + "н", + "і", + "и", + "р", + "в", + "т", + "е", + "с", + "к", + "л", + "у", + "д", + "м", + "п", + "з", + "я", + "ь", + "б", + "г", + "й", + "ч", + "х", + "ц", + "ї", + ], + "Norwegian": [ + "e", + "r", + "n", + "t", + "a", + "s", + "i", + "o", + "l", + "d", + "g", + "k", + "m", + "v", + "f", + "p", + "u", + "b", + "h", + "å", + "y", + "j", + "ø", + "c", + "æ", + "w", + ], + "Finnish": [ + "a", + "i", + "n", + "t", + "e", + "s", + "l", + "o", + "u", + "k", + "ä", + "m", + "r", + "v", + "j", + "h", + "p", + "y", + "d", + "ö", + "g", + "c", + "b", + "f", + "w", + "z", + ], + "Vietnamese": [ + "n", + "h", + "t", + "i", + "c", + "g", + "a", + "o", + "u", + "m", + "l", + "r", + "à", + "đ", + "s", + "e", + "v", + "p", + "b", + "y", + "ư", + "d", + "á", + "k", + "ộ", + "ế", + ], + "Czech": [ + "o", + "e", + "a", + "n", + "t", + "s", + "i", + "l", + "v", + "r", + "k", + "d", + "u", + "m", + "p", + "í", + "c", + "h", + "z", + "á", + "y", + "j", + "b", + "ě", + "é", + "ř", + ], + "Hungarian": [ + "e", + "a", + "t", + "l", + "s", + "n", + "k", + "r", + "i", + "o", + "z", + "á", + "é", + "g", + "m", + "b", + "y", + "v", + "d", + "h", + "u", + "p", + "j", + "ö", + "f", + "c", + ], + "Korean": [ + "이", + "다", + "에", + "의", + "는", + "로", + "하", + "을", + "가", + "고", + "지", + "서", + "한", + "은", + "기", + "으", + "년", + "대", + "사", + "시", + "를", + "리", + "도", + "인", + "스", + "일", + ], + "Indonesian": [ + "a", + "n", + "e", + "i", + "r", + "t", + "u", + "s", + "d", + "k", + "m", + "l", + "g", + "p", + "b", + "o", + "h", + "y", + "j", + "c", + "w", + "f", + "v", + "z", + "x", + "q", + ], + "Turkish": [ + "a", + "e", + "i", + "n", + "r", + "l", + "ı", + "k", + "d", + "t", + "s", + "m", + "y", + "u", + "o", + "b", + "ü", + "ş", + "v", + "g", + "z", + "h", + "c", + "p", + "ç", + "ğ", + ], + "Romanian": [ + "e", + "i", + "a", + "r", + "n", + "t", + "u", + "l", + "o", + "c", + "s", + "d", + "p", + "m", + "ă", + "f", + "v", + "î", + "g", + "b", + "ș", + "ț", + "z", + "h", + "â", + "j", + ], + "Farsi": [ + "ا", + "ی", + "ر", + "د", + "ن", + "ه", + "و", + "م", + "ت", + "ب", + "س", + "ل", + "ک", + "ش", + "ز", + "ف", + "گ", + "ع", + "خ", + "ق", + "ج", + "آ", + "پ", + "ح", + "ط", + "ص", + ], + "Arabic": [ + "ا", + "ل", + "ي", + "م", + "و", + "ن", + "ر", + "ت", + "ب", + "ة", + "ع", + "د", + "س", + "ف", + "ه", + "ك", + "ق", + "أ", + "ح", + "ج", + "ش", + "ط", + "ص", + "ى", + "خ", + "إ", + ], + "Danish": [ + "e", + "r", + "n", + "t", + "a", + "i", + "s", + "d", + "l", + "o", + "g", + "m", + "k", + "f", + "v", + "u", + "b", + "h", + "p", + "å", + "y", + "ø", + "æ", + "c", + "j", + "w", + ], + "Serbian": [ + "а", + "и", + "о", + "е", + "н", + "р", + "с", + "у", + "т", + "к", + "ј", + "в", + "д", + "м", + "п", + "л", + "г", + "з", + "б", + "a", + "i", + "e", + "o", + "n", + "ц", + "ш", + ], + "Lithuanian": [ + "i", + "a", + "s", + "o", + "r", + "e", + "t", + "n", + "u", + "k", + "m", + "l", + "p", + "v", + "d", + "j", + "g", + "ė", + "b", + "y", + "ų", + "š", + "ž", + "c", + "ą", + "į", + ], + "Slovene": [ + "e", + "a", + "i", + "o", + "n", + "r", + "s", + "l", + "t", + "j", + "v", + "k", + "d", + "p", + "m", + "u", + "z", + "b", + "g", + "h", + "č", + "c", + "š", + "ž", + "f", + "y", + ], + "Slovak": [ + "o", + "a", + "e", + "n", + "i", + "r", + "v", + "t", + "s", + "l", + "k", + "d", + "m", + "p", + "u", + "c", + "h", + "j", + "b", + "z", + "á", + "y", + "ý", + "í", + "č", + "é", + ], + "Hebrew": [ + "י", + "ו", + "ה", + "ל", + "ר", + "ב", + "ת", + "מ", + "א", + "ש", + "נ", + "ע", + "ם", + "ד", + "ק", + "ח", + "פ", + "ס", + "כ", + "ג", + "ט", + "צ", + "ן", + "ז", + "ך", + ], + "Bulgarian": [ + "а", + "и", + "о", + "е", + "н", + "т", + "р", + "с", + "в", + "л", + "к", + "д", + "п", + "м", + "з", + "г", + "я", + "ъ", + "у", + "б", + "ч", + "ц", + "й", + "ж", + "щ", + "х", + ], + "Croatian": [ + "a", + "i", + "o", + "e", + "n", + "r", + "j", + "s", + "t", + "u", + "k", + "l", + "v", + "d", + "m", + "p", + "g", + "z", + "b", + "c", + "č", + "h", + "š", + "ž", + "ć", + "f", + ], + "Hindi": [ + "क", + "र", + "स", + "न", + "त", + "म", + "ह", + "प", + "य", + "ल", + "व", + "ज", + "द", + "ग", + "ब", + "श", + "ट", + "अ", + "ए", + "थ", + "भ", + "ड", + "च", + "ध", + "ष", + "इ", + ], + "Estonian": [ + "a", + "i", + "e", + "s", + "t", + "l", + "u", + "n", + "o", + "k", + "r", + "d", + "m", + "v", + "g", + "p", + "j", + "h", + "ä", + "b", + "õ", + "ü", + "f", + "c", + "ö", + "y", + ], + "Thai": [ + "า", + "น", + "ร", + "อ", + "ก", + "เ", + "ง", + "ม", + "ย", + "ล", + "ว", + "ด", + "ท", + "ส", + "ต", + "ะ", + "ป", + "บ", + "ค", + "ห", + "แ", + "จ", + "พ", + "ช", + "ข", + "ใ", + ], + "Greek": [ + "α", + "τ", + "ο", + "ι", + "ε", + "ν", + "ρ", + "σ", + "κ", + "η", + "π", + "ς", + "υ", + "μ", + "λ", + "ί", + "ό", + "ά", + "γ", + "έ", + "δ", + "ή", + "ω", + "χ", + "θ", + "ύ", + ], + "Tamil": [ + "க", + "த", + "ப", + "ட", + "ர", + "ம", + "ல", + "ன", + "வ", + "ற", + "ய", + "ள", + "ச", + "ந", + "இ", + "ண", + "அ", + "ஆ", + "ழ", + "ங", + "எ", + "உ", + "ஒ", + "ஸ", + ], + "Kazakh": [ + "а", + "ы", + "е", + "н", + "т", + "р", + "л", + "і", + "д", + "с", + "м", + "қ", + "к", + "о", + "б", + "и", + "у", + "ғ", + "ж", + "ң", + "з", + "ш", + "й", + "п", + "г", + "ө", + ], +} + +LANGUAGE_SUPPORTED_COUNT: int = len(FREQUENCIES) diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/legacy.py b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/legacy.py new file mode 100644 index 0000000..43aad21 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/legacy.py @@ -0,0 +1,54 @@ +from typing import Any, Dict, Optional, Union +from warnings import warn + +from .api import from_bytes +from .constant import CHARDET_CORRESPONDENCE + + +def detect( + byte_str: bytes, should_rename_legacy: bool = False, **kwargs: Any +) -> Dict[str, Optional[Union[str, float]]]: + """ + chardet legacy method + Detect the encoding of the given byte string. It should be mostly backward-compatible. + Encoding name will match Chardet own writing whenever possible. (Not on encoding name unsupported by it) + This function is deprecated and should be used to migrate your project easily, consult the documentation for + further information. Not planned for removal. + + :param byte_str: The byte sequence to examine. + :param should_rename_legacy: Should we rename legacy encodings + to their more modern equivalents? + """ + if len(kwargs): + warn( + f"charset-normalizer disregard arguments '{','.join(list(kwargs.keys()))}' in legacy function detect()" + ) + + if not isinstance(byte_str, (bytearray, bytes)): + raise TypeError( # pragma: nocover + "Expected object of type bytes or bytearray, got: " + "{0}".format(type(byte_str)) + ) + + if isinstance(byte_str, bytearray): + byte_str = bytes(byte_str) + + r = from_bytes(byte_str).best() + + encoding = r.encoding if r is not None else None + language = r.language if r is not None and r.language != "Unknown" else "" + confidence = 1.0 - r.chaos if r is not None else None + + # Note: CharsetNormalizer does not return 'UTF-8-SIG' as the sig get stripped in the detection/normalization process + # but chardet does return 'utf-8-sig' and it is a valid codec name. + if r is not None and encoding == "utf_8" and r.bom: + encoding += "_sig" + + if should_rename_legacy is False and encoding in CHARDET_CORRESPONDENCE: + encoding = CHARDET_CORRESPONDENCE[encoding] + + return { + "encoding": encoding, + "language": language, + "confidence": confidence, + } diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/md.cpython-311-aarch64-linux-gnu.so b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/md.cpython-311-aarch64-linux-gnu.so new file mode 100755 index 0000000000000000000000000000000000000000..58a0295169a50e683bc7385859121c5df282d677 GIT binary patch literal 69800 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 bool: + """ + Determine if given character should be fed in. + """ + raise NotImplementedError # pragma: nocover + + def feed(self, character: str) -> None: + """ + The main routine to be executed upon character. + Insert the logic in witch the text would be considered chaotic. + """ + raise NotImplementedError # pragma: nocover + + def reset(self) -> None: # pragma: no cover + """ + Permit to reset the plugin to the initial state. + """ + raise NotImplementedError + + @property + def ratio(self) -> float: + """ + Compute the chaos ratio based on what your feed() has seen. + Must NOT be lower than 0.; No restriction gt 0. + """ + raise NotImplementedError # pragma: nocover + + +class TooManySymbolOrPunctuationPlugin(MessDetectorPlugin): + def __init__(self) -> None: + self._punctuation_count: int = 0 + self._symbol_count: int = 0 + self._character_count: int = 0 + + self._last_printable_char: Optional[str] = None + self._frenzy_symbol_in_word: bool = False + + def eligible(self, character: str) -> bool: + return character.isprintable() + + def feed(self, character: str) -> None: + self._character_count += 1 + + if ( + character != self._last_printable_char + and character not in COMMON_SAFE_ASCII_CHARACTERS + ): + if is_punctuation(character): + self._punctuation_count += 1 + elif ( + character.isdigit() is False + and is_symbol(character) + and is_emoticon(character) is False + ): + self._symbol_count += 2 + + self._last_printable_char = character + + def reset(self) -> None: # pragma: no cover + self._punctuation_count = 0 + self._character_count = 0 + self._symbol_count = 0 + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0.0 + + ratio_of_punctuation: float = ( + self._punctuation_count + self._symbol_count + ) / self._character_count + + return ratio_of_punctuation if ratio_of_punctuation >= 0.3 else 0.0 + + +class TooManyAccentuatedPlugin(MessDetectorPlugin): + def __init__(self) -> None: + self._character_count: int = 0 + self._accentuated_count: int = 0 + + def eligible(self, character: str) -> bool: + return character.isalpha() + + def feed(self, character: str) -> None: + self._character_count += 1 + + if is_accentuated(character): + self._accentuated_count += 1 + + def reset(self) -> None: # pragma: no cover + self._character_count = 0 + self._accentuated_count = 0 + + @property + def ratio(self) -> float: + if self._character_count < 8: + return 0.0 + + ratio_of_accentuation: float = self._accentuated_count / self._character_count + return ratio_of_accentuation if ratio_of_accentuation >= 0.35 else 0.0 + + +class UnprintablePlugin(MessDetectorPlugin): + def __init__(self) -> None: + self._unprintable_count: int = 0 + self._character_count: int = 0 + + def eligible(self, character: str) -> bool: + return True + + def feed(self, character: str) -> None: + if is_unprintable(character): + self._unprintable_count += 1 + self._character_count += 1 + + def reset(self) -> None: # pragma: no cover + self._unprintable_count = 0 + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0.0 + + return (self._unprintable_count * 8) / self._character_count + + +class SuspiciousDuplicateAccentPlugin(MessDetectorPlugin): + def __init__(self) -> None: + self._successive_count: int = 0 + self._character_count: int = 0 + + self._last_latin_character: Optional[str] = None + + def eligible(self, character: str) -> bool: + return character.isalpha() and is_latin(character) + + def feed(self, character: str) -> None: + self._character_count += 1 + if ( + self._last_latin_character is not None + and is_accentuated(character) + and is_accentuated(self._last_latin_character) + ): + if character.isupper() and self._last_latin_character.isupper(): + self._successive_count += 1 + # Worse if its the same char duplicated with different accent. + if remove_accent(character) == remove_accent(self._last_latin_character): + self._successive_count += 1 + self._last_latin_character = character + + def reset(self) -> None: # pragma: no cover + self._successive_count = 0 + self._character_count = 0 + self._last_latin_character = None + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0.0 + + return (self._successive_count * 2) / self._character_count + + +class SuspiciousRange(MessDetectorPlugin): + def __init__(self) -> None: + self._suspicious_successive_range_count: int = 0 + self._character_count: int = 0 + self._last_printable_seen: Optional[str] = None + + def eligible(self, character: str) -> bool: + return character.isprintable() + + def feed(self, character: str) -> None: + self._character_count += 1 + + if ( + character.isspace() + or is_punctuation(character) + or character in COMMON_SAFE_ASCII_CHARACTERS + ): + self._last_printable_seen = None + return + + if self._last_printable_seen is None: + self._last_printable_seen = character + return + + unicode_range_a: Optional[str] = unicode_range(self._last_printable_seen) + unicode_range_b: Optional[str] = unicode_range(character) + + if is_suspiciously_successive_range(unicode_range_a, unicode_range_b): + self._suspicious_successive_range_count += 1 + + self._last_printable_seen = character + + def reset(self) -> None: # pragma: no cover + self._character_count = 0 + self._suspicious_successive_range_count = 0 + self._last_printable_seen = None + + @property + def ratio(self) -> float: + if self._character_count <= 24: + return 0.0 + + ratio_of_suspicious_range_usage: float = ( + self._suspicious_successive_range_count * 2 + ) / self._character_count + + return ratio_of_suspicious_range_usage + + +class SuperWeirdWordPlugin(MessDetectorPlugin): + def __init__(self) -> None: + self._word_count: int = 0 + self._bad_word_count: int = 0 + self._foreign_long_count: int = 0 + + self._is_current_word_bad: bool = False + self._foreign_long_watch: bool = False + + self._character_count: int = 0 + self._bad_character_count: int = 0 + + self._buffer: str = "" + self._buffer_accent_count: int = 0 + + def eligible(self, character: str) -> bool: + return True + + def feed(self, character: str) -> None: + if character.isalpha(): + self._buffer += character + if is_accentuated(character): + self._buffer_accent_count += 1 + if ( + self._foreign_long_watch is False + and (is_latin(character) is False or is_accentuated(character)) + and is_cjk(character) is False + and is_hangul(character) is False + and is_katakana(character) is False + and is_hiragana(character) is False + and is_thai(character) is False + ): + self._foreign_long_watch = True + return + if not self._buffer: + return + if ( + character.isspace() or is_punctuation(character) or is_separator(character) + ) and self._buffer: + self._word_count += 1 + buffer_length: int = len(self._buffer) + + self._character_count += buffer_length + + if buffer_length >= 4: + if self._buffer_accent_count / buffer_length > 0.34: + self._is_current_word_bad = True + # Word/Buffer ending with an upper case accentuated letter are so rare, + # that we will consider them all as suspicious. Same weight as foreign_long suspicious. + if ( + is_accentuated(self._buffer[-1]) + and self._buffer[-1].isupper() + and all(_.isupper() for _ in self._buffer) is False + ): + self._foreign_long_count += 1 + self._is_current_word_bad = True + if buffer_length >= 24 and self._foreign_long_watch: + camel_case_dst = [ + i + for c, i in zip(self._buffer, range(0, buffer_length)) + if c.isupper() + ] + probable_camel_cased: bool = False + + if camel_case_dst and (len(camel_case_dst) / buffer_length <= 0.3): + probable_camel_cased = True + + if not probable_camel_cased: + self._foreign_long_count += 1 + self._is_current_word_bad = True + + if self._is_current_word_bad: + self._bad_word_count += 1 + self._bad_character_count += len(self._buffer) + self._is_current_word_bad = False + + self._foreign_long_watch = False + self._buffer = "" + self._buffer_accent_count = 0 + elif ( + character not in {"<", ">", "-", "=", "~", "|", "_"} + and character.isdigit() is False + and is_symbol(character) + ): + self._is_current_word_bad = True + self._buffer += character + + def reset(self) -> None: # pragma: no cover + self._buffer = "" + self._is_current_word_bad = False + self._foreign_long_watch = False + self._bad_word_count = 0 + self._word_count = 0 + self._character_count = 0 + self._bad_character_count = 0 + self._foreign_long_count = 0 + + @property + def ratio(self) -> float: + if self._word_count <= 10 and self._foreign_long_count == 0: + return 0.0 + + return self._bad_character_count / self._character_count + + +class CjkInvalidStopPlugin(MessDetectorPlugin): + """ + GB(Chinese) based encoding often render the stop incorrectly when the content does not fit and + can be easily detected. Searching for the overuse of '丅' and '丄'. + """ + + def __init__(self) -> None: + self._wrong_stop_count: int = 0 + self._cjk_character_count: int = 0 + + def eligible(self, character: str) -> bool: + return True + + def feed(self, character: str) -> None: + if character in {"丅", "丄"}: + self._wrong_stop_count += 1 + return + if is_cjk(character): + self._cjk_character_count += 1 + + def reset(self) -> None: # pragma: no cover + self._wrong_stop_count = 0 + self._cjk_character_count = 0 + + @property + def ratio(self) -> float: + if self._cjk_character_count < 16: + return 0.0 + return self._wrong_stop_count / self._cjk_character_count + + +class ArchaicUpperLowerPlugin(MessDetectorPlugin): + def __init__(self) -> None: + self._buf: bool = False + + self._character_count_since_last_sep: int = 0 + + self._successive_upper_lower_count: int = 0 + self._successive_upper_lower_count_final: int = 0 + + self._character_count: int = 0 + + self._last_alpha_seen: Optional[str] = None + self._current_ascii_only: bool = True + + def eligible(self, character: str) -> bool: + return True + + def feed(self, character: str) -> None: + is_concerned = character.isalpha() and is_case_variable(character) + chunk_sep = is_concerned is False + + if chunk_sep and self._character_count_since_last_sep > 0: + if ( + self._character_count_since_last_sep <= 64 + and character.isdigit() is False + and self._current_ascii_only is False + ): + self._successive_upper_lower_count_final += ( + self._successive_upper_lower_count + ) + + self._successive_upper_lower_count = 0 + self._character_count_since_last_sep = 0 + self._last_alpha_seen = None + self._buf = False + self._character_count += 1 + self._current_ascii_only = True + + return + + if self._current_ascii_only is True and character.isascii() is False: + self._current_ascii_only = False + + if self._last_alpha_seen is not None: + if (character.isupper() and self._last_alpha_seen.islower()) or ( + character.islower() and self._last_alpha_seen.isupper() + ): + if self._buf is True: + self._successive_upper_lower_count += 2 + self._buf = False + else: + self._buf = True + else: + self._buf = False + + self._character_count += 1 + self._character_count_since_last_sep += 1 + self._last_alpha_seen = character + + def reset(self) -> None: # pragma: no cover + self._character_count = 0 + self._character_count_since_last_sep = 0 + self._successive_upper_lower_count = 0 + self._successive_upper_lower_count_final = 0 + self._last_alpha_seen = None + self._buf = False + self._current_ascii_only = True + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0.0 + + return self._successive_upper_lower_count_final / self._character_count + + +class ArabicIsolatedFormPlugin(MessDetectorPlugin): + def __init__(self) -> None: + self._character_count: int = 0 + self._isolated_form_count: int = 0 + + def reset(self) -> None: # pragma: no cover + self._character_count = 0 + self._isolated_form_count = 0 + + def eligible(self, character: str) -> bool: + return is_arabic(character) + + def feed(self, character: str) -> None: + self._character_count += 1 + + if is_arabic_isolated_form(character): + self._isolated_form_count += 1 + + @property + def ratio(self) -> float: + if self._character_count < 8: + return 0.0 + + isolated_form_usage: float = self._isolated_form_count / self._character_count + + return isolated_form_usage + + +@lru_cache(maxsize=1024) +def is_suspiciously_successive_range( + unicode_range_a: Optional[str], unicode_range_b: Optional[str] +) -> bool: + """ + Determine if two Unicode range seen next to each other can be considered as suspicious. + """ + if unicode_range_a is None or unicode_range_b is None: + return True + + if unicode_range_a == unicode_range_b: + return False + + if "Latin" in unicode_range_a and "Latin" in unicode_range_b: + return False + + if "Emoticons" in unicode_range_a or "Emoticons" in unicode_range_b: + return False + + # Latin characters can be accompanied with a combining diacritical mark + # eg. Vietnamese. + if ("Latin" in unicode_range_a or "Latin" in unicode_range_b) and ( + "Combining" in unicode_range_a or "Combining" in unicode_range_b + ): + return False + + keywords_range_a, keywords_range_b = unicode_range_a.split( + " " + ), unicode_range_b.split(" ") + + for el in keywords_range_a: + if el in UNICODE_SECONDARY_RANGE_KEYWORD: + continue + if el in keywords_range_b: + return False + + # Japanese Exception + range_a_jp_chars, range_b_jp_chars = ( + unicode_range_a + in ( + "Hiragana", + "Katakana", + ), + unicode_range_b in ("Hiragana", "Katakana"), + ) + if (range_a_jp_chars or range_b_jp_chars) and ( + "CJK" in unicode_range_a or "CJK" in unicode_range_b + ): + return False + if range_a_jp_chars and range_b_jp_chars: + return False + + if "Hangul" in unicode_range_a or "Hangul" in unicode_range_b: + if "CJK" in unicode_range_a or "CJK" in unicode_range_b: + return False + if unicode_range_a == "Basic Latin" or unicode_range_b == "Basic Latin": + return False + + # Chinese/Japanese use dedicated range for punctuation and/or separators. + if ("CJK" in unicode_range_a or "CJK" in unicode_range_b) or ( + unicode_range_a in ["Katakana", "Hiragana"] + and unicode_range_b in ["Katakana", "Hiragana"] + ): + if "Punctuation" in unicode_range_a or "Punctuation" in unicode_range_b: + return False + if "Forms" in unicode_range_a or "Forms" in unicode_range_b: + return False + if unicode_range_a == "Basic Latin" or unicode_range_b == "Basic Latin": + return False + + return True + + +@lru_cache(maxsize=2048) +def mess_ratio( + decoded_sequence: str, maximum_threshold: float = 0.2, debug: bool = False +) -> float: + """ + Compute a mess ratio given a decoded bytes sequence. The maximum threshold does stop the computation earlier. + """ + + detectors: List[MessDetectorPlugin] = [ + md_class() for md_class in MessDetectorPlugin.__subclasses__() + ] + + length: int = len(decoded_sequence) + 1 + + mean_mess_ratio: float = 0.0 + + if length < 512: + intermediary_mean_mess_ratio_calc: int = 32 + elif length <= 1024: + intermediary_mean_mess_ratio_calc = 64 + else: + intermediary_mean_mess_ratio_calc = 128 + + for character, index in zip(decoded_sequence + "\n", range(length)): + for detector in detectors: + if detector.eligible(character): + detector.feed(character) + + if ( + index > 0 and index % intermediary_mean_mess_ratio_calc == 0 + ) or index == length - 1: + mean_mess_ratio = sum(dt.ratio for dt in detectors) + + if mean_mess_ratio >= maximum_threshold: + break + + if debug: + logger = getLogger("charset_normalizer") + + logger.log( + TRACE, + "Mess-detector extended-analysis start. " + f"intermediary_mean_mess_ratio_calc={intermediary_mean_mess_ratio_calc} mean_mess_ratio={mean_mess_ratio} " + f"maximum_threshold={maximum_threshold}", + ) + + if len(decoded_sequence) > 16: + logger.log(TRACE, f"Starting with: {decoded_sequence[:16]}") + logger.log(TRACE, f"Ending with: {decoded_sequence[-16::]}") + + for dt in detectors: # pragma: nocover + logger.log(TRACE, f"{dt.__class__}: {dt.ratio}") + + return round(mean_mess_ratio, 3) diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/md__mypyc.cpython-311-aarch64-linux-gnu.so b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/md__mypyc.cpython-311-aarch64-linux-gnu.so new file mode 100755 index 0000000000000000000000000000000000000000..a497cad58297194a2298e046cbf2ce1d7f9ece9a GIT binary patch literal 321776 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

QlhO^#3yD^xa|w?56y0NARDGz<)$JsSjKIS^ds$ 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 O5u5(MmB?!_{r?5P5jf)j literal 0 HcmV?d00001 diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/models.py b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/models.py new file mode 100644 index 0000000..a760b9c --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/models.py @@ -0,0 +1,340 @@ +from encodings.aliases import aliases +from hashlib import sha256 +from json import dumps +from typing import Any, Dict, Iterator, List, Optional, Tuple, Union + +from .constant import TOO_BIG_SEQUENCE +from .utils import iana_name, is_multi_byte_encoding, unicode_range + + +class CharsetMatch: + def __init__( + self, + payload: bytes, + guessed_encoding: str, + mean_mess_ratio: float, + has_sig_or_bom: bool, + languages: "CoherenceMatches", + decoded_payload: Optional[str] = None, + ): + self._payload: bytes = payload + + self._encoding: str = guessed_encoding + self._mean_mess_ratio: float = mean_mess_ratio + self._languages: CoherenceMatches = languages + self._has_sig_or_bom: bool = has_sig_or_bom + self._unicode_ranges: Optional[List[str]] = None + + self._leaves: List[CharsetMatch] = [] + self._mean_coherence_ratio: float = 0.0 + + self._output_payload: Optional[bytes] = None + self._output_encoding: Optional[str] = None + + self._string: Optional[str] = decoded_payload + + def __eq__(self, other: object) -> bool: + if not isinstance(other, CharsetMatch): + raise TypeError( + "__eq__ cannot be invoked on {} and {}.".format( + str(other.__class__), str(self.__class__) + ) + ) + return self.encoding == other.encoding and self.fingerprint == other.fingerprint + + def __lt__(self, other: object) -> bool: + """ + Implemented to make sorted available upon CharsetMatches items. + """ + if not isinstance(other, CharsetMatch): + raise ValueError + + chaos_difference: float = abs(self.chaos - other.chaos) + coherence_difference: float = abs(self.coherence - other.coherence) + + # Below 1% difference --> Use Coherence + if chaos_difference < 0.01 and coherence_difference > 0.02: + return self.coherence > other.coherence + elif chaos_difference < 0.01 and coherence_difference <= 0.02: + # When having a difficult decision, use the result that decoded as many multi-byte as possible. + # preserve RAM usage! + if len(self._payload) >= TOO_BIG_SEQUENCE: + return self.chaos < other.chaos + return self.multi_byte_usage > other.multi_byte_usage + + return self.chaos < other.chaos + + @property + def multi_byte_usage(self) -> float: + return 1.0 - (len(str(self)) / len(self.raw)) + + def __str__(self) -> str: + # Lazy Str Loading + if self._string is None: + self._string = str(self._payload, self._encoding, "strict") + return self._string + + def __repr__(self) -> str: + return "".format(self.encoding, self.fingerprint) + + def add_submatch(self, other: "CharsetMatch") -> None: + if not isinstance(other, CharsetMatch) or other == self: + raise ValueError( + "Unable to add instance <{}> as a submatch of a CharsetMatch".format( + other.__class__ + ) + ) + + other._string = None # Unload RAM usage; dirty trick. + self._leaves.append(other) + + @property + def encoding(self) -> str: + return self._encoding + + @property + def encoding_aliases(self) -> List[str]: + """ + Encoding name are known by many name, using this could help when searching for IBM855 when it's listed as CP855. + """ + also_known_as: List[str] = [] + for u, p in aliases.items(): + if self.encoding == u: + also_known_as.append(p) + elif self.encoding == p: + also_known_as.append(u) + return also_known_as + + @property + def bom(self) -> bool: + return self._has_sig_or_bom + + @property + def byte_order_mark(self) -> bool: + return self._has_sig_or_bom + + @property + def languages(self) -> List[str]: + """ + Return the complete list of possible languages found in decoded sequence. + Usually not really useful. Returned list may be empty even if 'language' property return something != 'Unknown'. + """ + return [e[0] for e in self._languages] + + @property + def language(self) -> str: + """ + Most probable language found in decoded sequence. If none were detected or inferred, the property will return + "Unknown". + """ + if not self._languages: + # Trying to infer the language based on the given encoding + # Its either English or we should not pronounce ourselves in certain cases. + if "ascii" in self.could_be_from_charset: + return "English" + + # doing it there to avoid circular import + from charset_normalizer.cd import encoding_languages, mb_encoding_languages + + languages = ( + mb_encoding_languages(self.encoding) + if is_multi_byte_encoding(self.encoding) + else encoding_languages(self.encoding) + ) + + if len(languages) == 0 or "Latin Based" in languages: + return "Unknown" + + return languages[0] + + return self._languages[0][0] + + @property + def chaos(self) -> float: + return self._mean_mess_ratio + + @property + def coherence(self) -> float: + if not self._languages: + return 0.0 + return self._languages[0][1] + + @property + def percent_chaos(self) -> float: + return round(self.chaos * 100, ndigits=3) + + @property + def percent_coherence(self) -> float: + return round(self.coherence * 100, ndigits=3) + + @property + def raw(self) -> bytes: + """ + Original untouched bytes. + """ + return self._payload + + @property + def submatch(self) -> List["CharsetMatch"]: + return self._leaves + + @property + def has_submatch(self) -> bool: + return len(self._leaves) > 0 + + @property + def alphabets(self) -> List[str]: + if self._unicode_ranges is not None: + return self._unicode_ranges + # list detected ranges + detected_ranges: List[Optional[str]] = [ + unicode_range(char) for char in str(self) + ] + # filter and sort + self._unicode_ranges = sorted(list({r for r in detected_ranges if r})) + return self._unicode_ranges + + @property + def could_be_from_charset(self) -> List[str]: + """ + The complete list of encoding that output the exact SAME str result and therefore could be the originating + encoding. + This list does include the encoding available in property 'encoding'. + """ + return [self._encoding] + [m.encoding for m in self._leaves] + + def output(self, encoding: str = "utf_8") -> bytes: + """ + Method to get re-encoded bytes payload using given target encoding. Default to UTF-8. + Any errors will be simply ignored by the encoder NOT replaced. + """ + if self._output_encoding is None or self._output_encoding != encoding: + self._output_encoding = encoding + self._output_payload = str(self).encode(encoding, "replace") + + return self._output_payload # type: ignore + + @property + def fingerprint(self) -> str: + """ + Retrieve the unique SHA256 computed using the transformed (re-encoded) payload. Not the original one. + """ + return sha256(self.output()).hexdigest() + + +class CharsetMatches: + """ + Container with every CharsetMatch items ordered by default from most probable to the less one. + Act like a list(iterable) but does not implements all related methods. + """ + + def __init__(self, results: Optional[List[CharsetMatch]] = None): + self._results: List[CharsetMatch] = sorted(results) if results else [] + + def __iter__(self) -> Iterator[CharsetMatch]: + yield from self._results + + def __getitem__(self, item: Union[int, str]) -> CharsetMatch: + """ + Retrieve a single item either by its position or encoding name (alias may be used here). + Raise KeyError upon invalid index or encoding not present in results. + """ + if isinstance(item, int): + return self._results[item] + if isinstance(item, str): + item = iana_name(item, False) + for result in self._results: + if item in result.could_be_from_charset: + return result + raise KeyError + + def __len__(self) -> int: + return len(self._results) + + def __bool__(self) -> bool: + return len(self._results) > 0 + + def append(self, item: CharsetMatch) -> None: + """ + Insert a single match. Will be inserted accordingly to preserve sort. + Can be inserted as a submatch. + """ + if not isinstance(item, CharsetMatch): + raise ValueError( + "Cannot append instance '{}' to CharsetMatches".format( + str(item.__class__) + ) + ) + # We should disable the submatch factoring when the input file is too heavy (conserve RAM usage) + if len(item.raw) <= TOO_BIG_SEQUENCE: + for match in self._results: + if match.fingerprint == item.fingerprint and match.chaos == item.chaos: + match.add_submatch(item) + return + self._results.append(item) + self._results = sorted(self._results) + + def best(self) -> Optional["CharsetMatch"]: + """ + Simply return the first match. Strict equivalent to matches[0]. + """ + if not self._results: + return None + return self._results[0] + + def first(self) -> Optional["CharsetMatch"]: + """ + Redundant method, call the method best(). Kept for BC reasons. + """ + return self.best() + + +CoherenceMatch = Tuple[str, float] +CoherenceMatches = List[CoherenceMatch] + + +class CliDetectionResult: + def __init__( + self, + path: str, + encoding: Optional[str], + encoding_aliases: List[str], + alternative_encodings: List[str], + language: str, + alphabets: List[str], + has_sig_or_bom: bool, + chaos: float, + coherence: float, + unicode_path: Optional[str], + is_preferred: bool, + ): + self.path: str = path + self.unicode_path: Optional[str] = unicode_path + self.encoding: Optional[str] = encoding + self.encoding_aliases: List[str] = encoding_aliases + self.alternative_encodings: List[str] = alternative_encodings + self.language: str = language + self.alphabets: List[str] = alphabets + self.has_sig_or_bom: bool = has_sig_or_bom + self.chaos: float = chaos + self.coherence: float = coherence + self.is_preferred: bool = is_preferred + + @property + def __dict__(self) -> Dict[str, Any]: # type: ignore + return { + "path": self.path, + "encoding": self.encoding, + "encoding_aliases": self.encoding_aliases, + "alternative_encodings": self.alternative_encodings, + "language": self.language, + "alphabets": self.alphabets, + "has_sig_or_bom": self.has_sig_or_bom, + "chaos": self.chaos, + "coherence": self.coherence, + "unicode_path": self.unicode_path, + "is_preferred": self.is_preferred, + } + + def to_json(self) -> str: + return dumps(self.__dict__, ensure_ascii=True, indent=4) diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/py.typed b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/py.typed new file mode 100644 index 0000000..e69de29 diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/utils.py b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/utils.py new file mode 100644 index 0000000..e5cbbf4 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/utils.py @@ -0,0 +1,421 @@ +import importlib +import logging +import unicodedata +from codecs import IncrementalDecoder +from encodings.aliases import aliases +from functools import lru_cache +from re import findall +from typing import Generator, List, Optional, Set, Tuple, Union + +from _multibytecodec import MultibyteIncrementalDecoder + +from .constant import ( + ENCODING_MARKS, + IANA_SUPPORTED_SIMILAR, + RE_POSSIBLE_ENCODING_INDICATION, + UNICODE_RANGES_COMBINED, + UNICODE_SECONDARY_RANGE_KEYWORD, + UTF8_MAXIMAL_ALLOCATION, +) + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_accentuated(character: str) -> bool: + try: + description: str = unicodedata.name(character) + except ValueError: + return False + return ( + "WITH GRAVE" in description + or "WITH ACUTE" in description + or "WITH CEDILLA" in description + or "WITH DIAERESIS" in description + or "WITH CIRCUMFLEX" in description + or "WITH TILDE" in description + or "WITH MACRON" in description + or "WITH RING ABOVE" in description + ) + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def remove_accent(character: str) -> str: + decomposed: str = unicodedata.decomposition(character) + if not decomposed: + return character + + codes: List[str] = decomposed.split(" ") + + return chr(int(codes[0], 16)) + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def unicode_range(character: str) -> Optional[str]: + """ + Retrieve the Unicode range official name from a single character. + """ + character_ord: int = ord(character) + + for range_name, ord_range in UNICODE_RANGES_COMBINED.items(): + if character_ord in ord_range: + return range_name + + return None + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_latin(character: str) -> bool: + try: + description: str = unicodedata.name(character) + except ValueError: + return False + return "LATIN" in description + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_punctuation(character: str) -> bool: + character_category: str = unicodedata.category(character) + + if "P" in character_category: + return True + + character_range: Optional[str] = unicode_range(character) + + if character_range is None: + return False + + return "Punctuation" in character_range + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_symbol(character: str) -> bool: + character_category: str = unicodedata.category(character) + + if "S" in character_category or "N" in character_category: + return True + + character_range: Optional[str] = unicode_range(character) + + if character_range is None: + return False + + return "Forms" in character_range and character_category != "Lo" + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_emoticon(character: str) -> bool: + character_range: Optional[str] = unicode_range(character) + + if character_range is None: + return False + + return "Emoticons" in character_range or "Pictographs" in character_range + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_separator(character: str) -> bool: + if character.isspace() or character in {"|", "+", "<", ">"}: + return True + + character_category: str = unicodedata.category(character) + + return "Z" in character_category or character_category in {"Po", "Pd", "Pc"} + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_case_variable(character: str) -> bool: + return character.islower() != character.isupper() + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_cjk(character: str) -> bool: + try: + character_name = unicodedata.name(character) + except ValueError: + return False + + return "CJK" in character_name + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_hiragana(character: str) -> bool: + try: + character_name = unicodedata.name(character) + except ValueError: + return False + + return "HIRAGANA" in character_name + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_katakana(character: str) -> bool: + try: + character_name = unicodedata.name(character) + except ValueError: + return False + + return "KATAKANA" in character_name + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_hangul(character: str) -> bool: + try: + character_name = unicodedata.name(character) + except ValueError: + return False + + return "HANGUL" in character_name + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_thai(character: str) -> bool: + try: + character_name = unicodedata.name(character) + except ValueError: + return False + + return "THAI" in character_name + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_arabic(character: str) -> bool: + try: + character_name = unicodedata.name(character) + except ValueError: + return False + + return "ARABIC" in character_name + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_arabic_isolated_form(character: str) -> bool: + try: + character_name = unicodedata.name(character) + except ValueError: + return False + + return "ARABIC" in character_name and "ISOLATED FORM" in character_name + + +@lru_cache(maxsize=len(UNICODE_RANGES_COMBINED)) +def is_unicode_range_secondary(range_name: str) -> bool: + return any(keyword in range_name for keyword in UNICODE_SECONDARY_RANGE_KEYWORD) + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_unprintable(character: str) -> bool: + return ( + character.isspace() is False # includes \n \t \r \v + and character.isprintable() is False + and character != "\x1A" # Why? Its the ASCII substitute character. + and character != "\ufeff" # bug discovered in Python, + # Zero Width No-Break Space located in Arabic Presentation Forms-B, Unicode 1.1 not acknowledged as space. + ) + + +def any_specified_encoding(sequence: bytes, search_zone: int = 8192) -> Optional[str]: + """ + Extract using ASCII-only decoder any specified encoding in the first n-bytes. + """ + if not isinstance(sequence, bytes): + raise TypeError + + seq_len: int = len(sequence) + + results: List[str] = findall( + RE_POSSIBLE_ENCODING_INDICATION, + sequence[: min(seq_len, search_zone)].decode("ascii", errors="ignore"), + ) + + if len(results) == 0: + return None + + for specified_encoding in results: + specified_encoding = specified_encoding.lower().replace("-", "_") + + encoding_alias: str + encoding_iana: str + + for encoding_alias, encoding_iana in aliases.items(): + if encoding_alias == specified_encoding: + return encoding_iana + if encoding_iana == specified_encoding: + return encoding_iana + + return None + + +@lru_cache(maxsize=128) +def is_multi_byte_encoding(name: str) -> bool: + """ + Verify is a specific encoding is a multi byte one based on it IANA name + """ + return name in { + "utf_8", + "utf_8_sig", + "utf_16", + "utf_16_be", + "utf_16_le", + "utf_32", + "utf_32_le", + "utf_32_be", + "utf_7", + } or issubclass( + importlib.import_module("encodings.{}".format(name)).IncrementalDecoder, + MultibyteIncrementalDecoder, + ) + + +def identify_sig_or_bom(sequence: bytes) -> Tuple[Optional[str], bytes]: + """ + Identify and extract SIG/BOM in given sequence. + """ + + for iana_encoding in ENCODING_MARKS: + marks: Union[bytes, List[bytes]] = ENCODING_MARKS[iana_encoding] + + if isinstance(marks, bytes): + marks = [marks] + + for mark in marks: + if sequence.startswith(mark): + return iana_encoding, mark + + return None, b"" + + +def should_strip_sig_or_bom(iana_encoding: str) -> bool: + return iana_encoding not in {"utf_16", "utf_32"} + + +def iana_name(cp_name: str, strict: bool = True) -> str: + cp_name = cp_name.lower().replace("-", "_") + + encoding_alias: str + encoding_iana: str + + for encoding_alias, encoding_iana in aliases.items(): + if cp_name in [encoding_alias, encoding_iana]: + return encoding_iana + + if strict: + raise ValueError("Unable to retrieve IANA for '{}'".format(cp_name)) + + return cp_name + + +def range_scan(decoded_sequence: str) -> List[str]: + ranges: Set[str] = set() + + for character in decoded_sequence: + character_range: Optional[str] = unicode_range(character) + + if character_range is None: + continue + + ranges.add(character_range) + + return list(ranges) + + +def cp_similarity(iana_name_a: str, iana_name_b: str) -> float: + if is_multi_byte_encoding(iana_name_a) or is_multi_byte_encoding(iana_name_b): + return 0.0 + + decoder_a = importlib.import_module( + "encodings.{}".format(iana_name_a) + ).IncrementalDecoder + decoder_b = importlib.import_module( + "encodings.{}".format(iana_name_b) + ).IncrementalDecoder + + id_a: IncrementalDecoder = decoder_a(errors="ignore") + id_b: IncrementalDecoder = decoder_b(errors="ignore") + + character_match_count: int = 0 + + for i in range(255): + to_be_decoded: bytes = bytes([i]) + if id_a.decode(to_be_decoded) == id_b.decode(to_be_decoded): + character_match_count += 1 + + return character_match_count / 254 + + +def is_cp_similar(iana_name_a: str, iana_name_b: str) -> bool: + """ + Determine if two code page are at least 80% similar. IANA_SUPPORTED_SIMILAR dict was generated using + the function cp_similarity. + """ + return ( + iana_name_a in IANA_SUPPORTED_SIMILAR + and iana_name_b in IANA_SUPPORTED_SIMILAR[iana_name_a] + ) + + +def set_logging_handler( + name: str = "charset_normalizer", + level: int = logging.INFO, + format_string: str = "%(asctime)s | %(levelname)s | %(message)s", +) -> None: + logger = logging.getLogger(name) + logger.setLevel(level) + + handler = logging.StreamHandler() + handler.setFormatter(logging.Formatter(format_string)) + logger.addHandler(handler) + + +def cut_sequence_chunks( + sequences: bytes, + encoding_iana: str, + offsets: range, + chunk_size: int, + bom_or_sig_available: bool, + strip_sig_or_bom: bool, + sig_payload: bytes, + is_multi_byte_decoder: bool, + decoded_payload: Optional[str] = None, +) -> Generator[str, None, None]: + if decoded_payload and is_multi_byte_decoder is False: + for i in offsets: + chunk = decoded_payload[i : i + chunk_size] + if not chunk: + break + yield chunk + else: + for i in offsets: + chunk_end = i + chunk_size + if chunk_end > len(sequences) + 8: + continue + + cut_sequence = sequences[i : i + chunk_size] + + if bom_or_sig_available and strip_sig_or_bom is False: + cut_sequence = sig_payload + cut_sequence + + chunk = cut_sequence.decode( + encoding_iana, + errors="ignore" if is_multi_byte_decoder else "strict", + ) + + # multi-byte bad cutting detector and adjustment + # not the cleanest way to perform that fix but clever enough for now. + if is_multi_byte_decoder and i > 0: + chunk_partial_size_chk: int = min(chunk_size, 16) + + if ( + decoded_payload + and chunk[:chunk_partial_size_chk] not in decoded_payload + ): + for j in range(i, i - 4, -1): + cut_sequence = sequences[j:chunk_end] + + if bom_or_sig_available and strip_sig_or_bom is False: + cut_sequence = sig_payload + cut_sequence + + chunk = cut_sequence.decode(encoding_iana, errors="ignore") + + if chunk[:chunk_partial_size_chk] in decoded_payload: + break + + yield chunk diff --git a/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/version.py b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/version.py new file mode 100644 index 0000000..5a4da4f --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/charset_normalizer/version.py @@ -0,0 +1,6 @@ +""" +Expose version +""" + +__version__ = "3.3.2" +VERSION = __version__.split(".") diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/INSTALLER b/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/METADATA b/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/METADATA new file mode 100644 index 0000000..1173bde --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/METADATA @@ -0,0 +1,138 @@ +Metadata-Version: 2.3 +Name: cryptography +Version: 43.0.1 +Classifier: Development Status :: 5 - Production/Stable +Classifier: Intended Audience :: Developers +Classifier: License :: OSI Approved :: Apache Software License +Classifier: License :: OSI Approved :: BSD License +Classifier: Natural Language :: English +Classifier: Operating System :: MacOS :: MacOS X +Classifier: Operating System :: POSIX +Classifier: Operating System :: POSIX :: BSD +Classifier: Operating System :: POSIX :: Linux +Classifier: Operating System :: Microsoft :: Windows +Classifier: Programming Language :: Python +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3 :: Only +Classifier: Programming Language :: Python :: 3.7 +Classifier: Programming Language :: Python :: 3.8 +Classifier: Programming Language :: Python :: 3.9 +Classifier: Programming Language :: Python :: 3.10 +Classifier: Programming Language :: Python :: 3.11 +Classifier: Programming Language :: Python :: 3.12 +Classifier: Programming Language :: Python :: Implementation :: CPython +Classifier: Programming Language :: Python :: Implementation :: PyPy +Classifier: Topic :: Security :: Cryptography +Requires-Dist: cffi >=1.12 ; platform_python_implementation != 'PyPy' +Requires-Dist: bcrypt >=3.1.5 ; extra == 'ssh' +Requires-Dist: nox ; extra == 'nox' +Requires-Dist: cryptography-vectors ==43.0.1 ; extra == 'test' +Requires-Dist: pytest >=6.2.0 ; extra == 'test' +Requires-Dist: pytest-benchmark ; extra == 'test' +Requires-Dist: pytest-cov ; extra == 'test' +Requires-Dist: pytest-xdist ; extra == 'test' +Requires-Dist: pretend ; extra == 'test' +Requires-Dist: certifi ; extra == 'test' +Requires-Dist: pytest-randomly ; extra == 'test-randomorder' +Requires-Dist: sphinx >=5.3.0 ; extra == 'docs' +Requires-Dist: sphinx-rtd-theme >=1.1.1 ; extra == 'docs' +Requires-Dist: pyenchant >=1.6.11 ; extra == 'docstest' +Requires-Dist: readme-renderer ; extra == 'docstest' +Requires-Dist: sphinxcontrib-spelling >=4.0.1 ; extra == 'docstest' +Requires-Dist: build ; extra == 'sdist' +Requires-Dist: ruff ; extra == 'pep8test' +Requires-Dist: mypy ; extra == 'pep8test' +Requires-Dist: check-sdist ; extra == 'pep8test' +Requires-Dist: click ; extra == 'pep8test' +Provides-Extra: ssh +Provides-Extra: nox +Provides-Extra: test +Provides-Extra: test-randomorder +Provides-Extra: docs +Provides-Extra: docstest +Provides-Extra: sdist +Provides-Extra: pep8test +License-File: LICENSE +License-File: LICENSE.APACHE +License-File: LICENSE.BSD +Summary: cryptography is a package which provides cryptographic recipes and primitives to Python developers. +Author: The cryptography developers +Author-email: The Python Cryptographic Authority and individual contributors +License: Apache-2.0 OR BSD-3-Clause +Requires-Python: >=3.7 +Description-Content-Type: text/x-rst; charset=UTF-8 +Project-URL: homepage, https://github.com/pyca/cryptography +Project-URL: documentation, https://cryptography.io/ +Project-URL: source, https://github.com/pyca/cryptography/ +Project-URL: issues, https://github.com/pyca/cryptography/issues +Project-URL: changelog, https://cryptography.io/en/latest/changelog/ + +pyca/cryptography +================= + +.. image:: https://img.shields.io/pypi/v/cryptography.svg + :target: https://pypi.org/project/cryptography/ + :alt: Latest Version + +.. image:: https://readthedocs.org/projects/cryptography/badge/?version=latest + :target: https://cryptography.io + :alt: Latest Docs + +.. image:: https://github.com/pyca/cryptography/workflows/CI/badge.svg?branch=main + :target: https://github.com/pyca/cryptography/actions?query=workflow%3ACI+branch%3Amain + + +``cryptography`` is a package which provides cryptographic recipes and +primitives to Python developers. Our goal is for it to be your "cryptographic +standard library". It supports Python 3.7+ and PyPy3 7.3.11+. + +``cryptography`` includes both high level recipes and low level interfaces to +common cryptographic algorithms such as symmetric ciphers, message digests, and +key derivation functions. For example, to encrypt something with +``cryptography``'s high level symmetric encryption recipe: + +.. code-block:: pycon + + >>> from cryptography.fernet import Fernet + >>> # Put this somewhere safe! + >>> key = Fernet.generate_key() + >>> f = Fernet(key) + >>> token = f.encrypt(b"A really secret message. Not for prying eyes.") + >>> token + b'...' + >>> f.decrypt(token) + b'A really secret message. Not for prying eyes.' + +You can find more information in the `documentation`_. + +You can install ``cryptography`` with: + +.. code-block:: console + + $ pip install cryptography + +For full details see `the installation documentation`_. + +Discussion +~~~~~~~~~~ + +If you run into bugs, you can file them in our `issue tracker`_. + +We maintain a `cryptography-dev`_ mailing list for development discussion. + +You can also join ``#pyca`` on ``irc.libera.chat`` to ask questions or get +involved. + +Security +~~~~~~~~ + +Need to report a security issue? Please consult our `security reporting`_ +documentation. + + +.. _`documentation`: https://cryptography.io/ +.. _`the installation documentation`: https://cryptography.io/en/latest/installation/ +.. _`issue tracker`: https://github.com/pyca/cryptography/issues +.. _`cryptography-dev`: https://mail.python.org/mailman/listinfo/cryptography-dev +.. _`security reporting`: https://cryptography.io/en/latest/security/ + diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/RECORD b/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/RECORD new file mode 100644 index 0000000..87f98ee --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/RECORD @@ -0,0 +1,173 @@ +cryptography-43.0.1.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +cryptography-43.0.1.dist-info/METADATA,sha256=AGSptf0qwYYF5RLvcScxitnPJZ6URUiMFp8jelkGAuE,5440 +cryptography-43.0.1.dist-info/RECORD,, +cryptography-43.0.1.dist-info/WHEEL,sha256=IE7lOdXQgDkYXnHfwkWShgT3mkT2CKPL36OAnIWWnRE,108 +cryptography-43.0.1.dist-info/license_files/LICENSE,sha256=Pgx8CRqUi4JTO6mP18u0BDLW8amsv4X1ki0vmak65rs,197 +cryptography-43.0.1.dist-info/license_files/LICENSE.APACHE,sha256=qsc7MUj20dcRHbyjIJn2jSbGRMaBOuHk8F9leaomY_4,11360 +cryptography-43.0.1.dist-info/license_files/LICENSE.BSD,sha256=YCxMdILeZHndLpeTzaJ15eY9dz2s0eymiSMqtwCPtPs,1532 +cryptography/__about__.py,sha256=pY_pmYXjJTK-LjfCu7ot0NMj0QC2dkD1dCPyV8QjISM,445 +cryptography/__init__.py,sha256=mthuUrTd4FROCpUYrTIqhjz6s6T9djAZrV7nZ1oMm2o,364 +cryptography/__pycache__/__about__.cpython-311.pyc,, +cryptography/__pycache__/__init__.cpython-311.pyc,, +cryptography/__pycache__/exceptions.cpython-311.pyc,, +cryptography/__pycache__/fernet.cpython-311.pyc,, +cryptography/__pycache__/utils.cpython-311.pyc,, +cryptography/exceptions.py,sha256=835EWILc2fwxw-gyFMriciC2SqhViETB10LBSytnDIc,1087 +cryptography/fernet.py,sha256=aPj82w-Z_1GBXUtWRUsZdVbMwRo5Mbjj0wkA9wG4rkw,6696 +cryptography/hazmat/__init__.py,sha256=5IwrLWrVp0AjEr_4FdWG_V057NSJGY_W4egNNsuct0g,455 +cryptography/hazmat/__pycache__/__init__.cpython-311.pyc,, +cryptography/hazmat/__pycache__/_oid.cpython-311.pyc,, +cryptography/hazmat/_oid.py,sha256=e9yLmxtdQtuL94ztQv3SGtt_ea1Mx6aUwGftJsP6EXk,15201 +cryptography/hazmat/backends/__init__.py,sha256=O5jvKFQdZnXhKeqJ-HtulaEL9Ni7mr1mDzZY5kHlYhI,361 +cryptography/hazmat/backends/__pycache__/__init__.cpython-311.pyc,, +cryptography/hazmat/backends/openssl/__init__.py,sha256=p3jmJfnCag9iE5sdMrN6VvVEu55u46xaS_IjoI0SrmA,305 +cryptography/hazmat/backends/openssl/__pycache__/__init__.cpython-311.pyc,, +cryptography/hazmat/backends/openssl/__pycache__/backend.cpython-311.pyc,, +cryptography/hazmat/backends/openssl/backend.py,sha256=pUXUbugLwMm2Gls-h5U5fw2RvepaNjEvnao6CTmL1xQ,9648 +cryptography/hazmat/bindings/__init__.py,sha256=s9oKCQ2ycFdXoERdS1imafueSkBsL9kvbyfghaauZ9Y,180 +cryptography/hazmat/bindings/__pycache__/__init__.cpython-311.pyc,, +cryptography/hazmat/bindings/_rust.abi3.so,sha256=xh40qD5DuWrwVM5cmB7WbrZEPsAxkwYX1Uq25dXRREQ,9866904 +cryptography/hazmat/bindings/_rust/__init__.pyi,sha256=wb1OT76lG19vjq97_q2MM3qdJlQhyloXfVbKFDmRse4,737 +cryptography/hazmat/bindings/_rust/_openssl.pyi,sha256=mpNJLuYLbCVrd5i33FBTmWwL_55Dw7JPkSLlSX9Q7oI,230 +cryptography/hazmat/bindings/_rust/asn1.pyi,sha256=BrGjC8J6nwuS-r3EVcdXJB8ndotfY9mbQYOfpbPG0HA,354 +cryptography/hazmat/bindings/_rust/exceptions.pyi,sha256=exXr2xw_0pB1kk93cYbM3MohbzoUkjOms1ZMUi0uQZE,640 +cryptography/hazmat/bindings/_rust/ocsp.pyi,sha256=R-xJ-XmJZ1lOk-fWHHvRnP3QNTCFnKv-l3xlNWfLVt4,868 +cryptography/hazmat/bindings/_rust/openssl/__init__.pyi,sha256=Lvn250QMdPyeF-hoBF6rkQgHLBJxVauXCb8i8uYTomQ,1368 +cryptography/hazmat/bindings/_rust/openssl/aead.pyi,sha256=i0gA3jUQ4rkJXTGGZrq-AuY-VQLN31lyDeWuDZ0zJYw,2553 +cryptography/hazmat/bindings/_rust/openssl/ciphers.pyi,sha256=iK0ZhQ-WyCQbjaraaFgK6q4PpD-7Rf5RDHkFD3YEW_g,1301 +cryptography/hazmat/bindings/_rust/openssl/cmac.pyi,sha256=nPH0X57RYpsAkRowVpjQiHE566ThUTx7YXrsadmrmHk,564 +cryptography/hazmat/bindings/_rust/openssl/dh.pyi,sha256=Z3TC-G04-THtSdAOPLM1h2G7ml5bda1ElZUcn5wpuhk,1564 +cryptography/hazmat/bindings/_rust/openssl/dsa.pyi,sha256=qBtkgj2albt2qFcnZ9UDrhzoNhCVO7HTby5VSf1EXMI,1299 +cryptography/hazmat/bindings/_rust/openssl/ec.pyi,sha256=zJy0pRa5n-_p2dm45PxECB_-B6SVZyNKfjxFDpPqT38,1691 +cryptography/hazmat/bindings/_rust/openssl/ed25519.pyi,sha256=OJsrblS2nHptZctva-pAKFL5q8yPEAkhmjPZpJ6TA94,493 +cryptography/hazmat/bindings/_rust/openssl/ed448.pyi,sha256=SkPHK2HdbYN02TVQEUOgW3iTdiEY7HBE4DijpdkAzmk,475 +cryptography/hazmat/bindings/_rust/openssl/hashes.pyi,sha256=J8HoN0GdtPcjRAfNHr5Elva_nkmQfq63L75_z9dd8Uc,573 +cryptography/hazmat/bindings/_rust/openssl/hmac.pyi,sha256=ZmLJ73pmxcZFC1XosWEiXMRYtvJJor3ZLdCQOJu85Cw,662 +cryptography/hazmat/bindings/_rust/openssl/kdf.pyi,sha256=wPS5c7NLspM2632II0I4iH1RSxZvSRtBOVqmpyQATfk,544 +cryptography/hazmat/bindings/_rust/openssl/keys.pyi,sha256=JSrlGNaW49ZCZ1hcb-YJdS1EAbsMwRbVEcLL0P9OApA,872 +cryptography/hazmat/bindings/_rust/openssl/poly1305.pyi,sha256=9iogF7Q4i81IkOS-IMXp6HvxFF_3cNy_ucrAjVQnn14,540 +cryptography/hazmat/bindings/_rust/openssl/rsa.pyi,sha256=2OQCNSXkxgc-3uw1xiCCloIQTV6p9_kK79Yu0rhZgPc,1364 +cryptography/hazmat/bindings/_rust/openssl/x25519.pyi,sha256=2BKdbrddM_9SMUpdvHKGhb9MNjURCarPxccbUDzHeoA,484 +cryptography/hazmat/bindings/_rust/openssl/x448.pyi,sha256=AoRMWNvCJTiH5L-lkIkCdPlrPLUdJvvfXpIvf1GmxpM,466 +cryptography/hazmat/bindings/_rust/pkcs12.pyi,sha256=afhB_6M8xI1MIE5vxkaDF1jSxA48ib1--NiOxtf6boM,1394 +cryptography/hazmat/bindings/_rust/pkcs7.pyi,sha256=QCmuA0IgDr4iOecUOXgUUeh3BAjJx8ubjz__EnNbyGY,972 +cryptography/hazmat/bindings/_rust/test_support.pyi,sha256=Xo1Gd7bh9rU4HuIS4pm9UwCY6IS1gInvFwmhABLOVO4,936 +cryptography/hazmat/bindings/_rust/x509.pyi,sha256=WLrGmqmFss8dXKhlG_J9nVhoCcodR72xJdCoxEuBtjY,3551 +cryptography/hazmat/bindings/openssl/__init__.py,sha256=s9oKCQ2ycFdXoERdS1imafueSkBsL9kvbyfghaauZ9Y,180 +cryptography/hazmat/bindings/openssl/__pycache__/__init__.cpython-311.pyc,, +cryptography/hazmat/bindings/openssl/__pycache__/_conditional.cpython-311.pyc,, +cryptography/hazmat/bindings/openssl/__pycache__/binding.cpython-311.pyc,, +cryptography/hazmat/bindings/openssl/_conditional.py,sha256=dkGKGU-22uR2ZKeOOwaSxEJCGaafgUjb2romWcu03QE,5163 +cryptography/hazmat/bindings/openssl/binding.py,sha256=e1gnFAZBPrkJ3CsiZV-ug6kaPdNTAEROaUFiFrUh71M,4042 +cryptography/hazmat/decrepit/__init__.py,sha256=wHCbWfaefa-fk6THSw9th9fJUsStJo7245wfFBqmduA,216 +cryptography/hazmat/decrepit/__pycache__/__init__.cpython-311.pyc,, +cryptography/hazmat/decrepit/ciphers/__init__.py,sha256=wHCbWfaefa-fk6THSw9th9fJUsStJo7245wfFBqmduA,216 +cryptography/hazmat/decrepit/ciphers/__pycache__/__init__.cpython-311.pyc,, +cryptography/hazmat/decrepit/ciphers/__pycache__/algorithms.cpython-311.pyc,, +cryptography/hazmat/decrepit/ciphers/algorithms.py,sha256=HWA4PKDS2w4D2dQoRerpLRU7Kntt5vJeJC7j--AlZVU,2520 +cryptography/hazmat/primitives/__init__.py,sha256=s9oKCQ2ycFdXoERdS1imafueSkBsL9kvbyfghaauZ9Y,180 +cryptography/hazmat/primitives/__pycache__/__init__.cpython-311.pyc,, +cryptography/hazmat/primitives/__pycache__/_asymmetric.cpython-311.pyc,, +cryptography/hazmat/primitives/__pycache__/_cipheralgorithm.cpython-311.pyc,, +cryptography/hazmat/primitives/__pycache__/_serialization.cpython-311.pyc,, +cryptography/hazmat/primitives/__pycache__/cmac.cpython-311.pyc,, +cryptography/hazmat/primitives/__pycache__/constant_time.cpython-311.pyc,, +cryptography/hazmat/primitives/__pycache__/hashes.cpython-311.pyc,, +cryptography/hazmat/primitives/__pycache__/hmac.cpython-311.pyc,, +cryptography/hazmat/primitives/__pycache__/keywrap.cpython-311.pyc,, +cryptography/hazmat/primitives/__pycache__/padding.cpython-311.pyc,, +cryptography/hazmat/primitives/__pycache__/poly1305.cpython-311.pyc,, +cryptography/hazmat/primitives/_asymmetric.py,sha256=RhgcouUB6HTiFDBrR1LxqkMjpUxIiNvQ1r_zJjRG6qQ,532 +cryptography/hazmat/primitives/_cipheralgorithm.py,sha256=gKa0WrLz6K4fqhnGbfBYKDSxgLxsPU0uj_EK2UT47W4,1495 +cryptography/hazmat/primitives/_serialization.py,sha256=qrozc8fw2WZSbjk3DAlSl3ResxpauwJ74ZgGoUL-mj0,5142 +cryptography/hazmat/primitives/asymmetric/__init__.py,sha256=s9oKCQ2ycFdXoERdS1imafueSkBsL9kvbyfghaauZ9Y,180 +cryptography/hazmat/primitives/asymmetric/__pycache__/__init__.cpython-311.pyc,, +cryptography/hazmat/primitives/asymmetric/__pycache__/dh.cpython-311.pyc,, +cryptography/hazmat/primitives/asymmetric/__pycache__/dsa.cpython-311.pyc,, +cryptography/hazmat/primitives/asymmetric/__pycache__/ec.cpython-311.pyc,, +cryptography/hazmat/primitives/asymmetric/__pycache__/ed25519.cpython-311.pyc,, +cryptography/hazmat/primitives/asymmetric/__pycache__/ed448.cpython-311.pyc,, +cryptography/hazmat/primitives/asymmetric/__pycache__/padding.cpython-311.pyc,, +cryptography/hazmat/primitives/asymmetric/__pycache__/rsa.cpython-311.pyc,, +cryptography/hazmat/primitives/asymmetric/__pycache__/types.cpython-311.pyc,, +cryptography/hazmat/primitives/asymmetric/__pycache__/utils.cpython-311.pyc,, +cryptography/hazmat/primitives/asymmetric/__pycache__/x25519.cpython-311.pyc,, +cryptography/hazmat/primitives/asymmetric/__pycache__/x448.cpython-311.pyc,, +cryptography/hazmat/primitives/asymmetric/dh.py,sha256=OOCjMClH1Bf14Sy7jAdwzEeCxFPb8XUe2qePbExvXwc,3420 +cryptography/hazmat/primitives/asymmetric/dsa.py,sha256=xBwdf0pZOgvqjUKcO7Q0L3NxwalYj0SJDUqThemhSmI,3945 +cryptography/hazmat/primitives/asymmetric/ec.py,sha256=lwZmtAwi3PM8lsY1MsNaby_bVi--49OCxwE_1yqKC-A,10428 +cryptography/hazmat/primitives/asymmetric/ed25519.py,sha256=kl63fg7myuMjNTmMoVFeH6iVr0x5FkjNmggxIRTloJk,3423 +cryptography/hazmat/primitives/asymmetric/ed448.py,sha256=2UzEDzzfkPn83UFVFlMZfIMbAixxY09WmQyrwinWTn8,3456 +cryptography/hazmat/primitives/asymmetric/padding.py,sha256=eZcvUqVLbe3u48SunLdeniaPlV4-k6pwBl67OW4jSy8,2885 +cryptography/hazmat/primitives/asymmetric/rsa.py,sha256=nW_Ko7PID9UBJF10GVJOc_1L00ymFsfZDUJYtM5kfGQ,7637 +cryptography/hazmat/primitives/asymmetric/types.py,sha256=LnsOJym-wmPUJ7Knu_7bCNU3kIiELCd6krOaW_JU08I,2996 +cryptography/hazmat/primitives/asymmetric/utils.py,sha256=DPTs6T4F-UhwzFQTh-1fSEpQzazH2jf2xpIro3ItF4o,790 +cryptography/hazmat/primitives/asymmetric/x25519.py,sha256=VGYuRdIYuVBtizpFdNWd2bTrT10JRa1admQdBr08xz8,3341 +cryptography/hazmat/primitives/asymmetric/x448.py,sha256=GKKJBqYLr03VewMF18bXIM941aaWcZIQ4rC02GLLEmw,3374 +cryptography/hazmat/primitives/ciphers/__init__.py,sha256=eyEXmjk6_CZXaOPYDr7vAYGXr29QvzgWL2-4CSolLFs,680 +cryptography/hazmat/primitives/ciphers/__pycache__/__init__.cpython-311.pyc,, +cryptography/hazmat/primitives/ciphers/__pycache__/aead.cpython-311.pyc,, +cryptography/hazmat/primitives/ciphers/__pycache__/algorithms.cpython-311.pyc,, +cryptography/hazmat/primitives/ciphers/__pycache__/base.cpython-311.pyc,, +cryptography/hazmat/primitives/ciphers/__pycache__/modes.cpython-311.pyc,, +cryptography/hazmat/primitives/ciphers/aead.py,sha256=Fzlyx7w8KYQakzDp1zWgJnIr62zgZrgVh1u2h4exB54,634 +cryptography/hazmat/primitives/ciphers/algorithms.py,sha256=QvBMDmphRZfNmykij58L5eDkd_2NnCzIpJpyX2QwMxc,4223 +cryptography/hazmat/primitives/ciphers/base.py,sha256=tg-XNaKUyETBi7ounGDEL1_ICn-s4FF9LR7moV58blI,4211 +cryptography/hazmat/primitives/ciphers/modes.py,sha256=BFpxEGSaxoeZjrQ4sqpyPDvKClrqfDKIBv7kYtFURhE,8192 +cryptography/hazmat/primitives/cmac.py,sha256=sz_s6H_cYnOvx-VNWdIKhRhe3Ymp8z8J0D3CBqOX3gg,338 +cryptography/hazmat/primitives/constant_time.py,sha256=xdunWT0nf8OvKdcqUhhlFKayGp4_PgVJRU2W1wLSr_A,422 +cryptography/hazmat/primitives/hashes.py,sha256=EvDIJBhj83Z7f-oHbsA0TzZLFSDV_Yv8hQRdM4o8FD0,5091 +cryptography/hazmat/primitives/hmac.py,sha256=RpB3z9z5skirCQrm7zQbtnp9pLMnAjrlTUvKqF5aDDc,423 +cryptography/hazmat/primitives/kdf/__init__.py,sha256=4XibZnrYq4hh5xBjWiIXzaYW6FKx8hPbVaa_cB9zS64,750 +cryptography/hazmat/primitives/kdf/__pycache__/__init__.cpython-311.pyc,, +cryptography/hazmat/primitives/kdf/__pycache__/concatkdf.cpython-311.pyc,, +cryptography/hazmat/primitives/kdf/__pycache__/hkdf.cpython-311.pyc,, +cryptography/hazmat/primitives/kdf/__pycache__/kbkdf.cpython-311.pyc,, +cryptography/hazmat/primitives/kdf/__pycache__/pbkdf2.cpython-311.pyc,, +cryptography/hazmat/primitives/kdf/__pycache__/scrypt.cpython-311.pyc,, +cryptography/hazmat/primitives/kdf/__pycache__/x963kdf.cpython-311.pyc,, +cryptography/hazmat/primitives/kdf/concatkdf.py,sha256=bcn4NGXse-EsFl7nlU83e5ilop7TSHcX-CJJS107W80,3686 +cryptography/hazmat/primitives/kdf/hkdf.py,sha256=uhN5L87w4JvtAqQcPh_Ji2TPSc18IDThpaYJiHOWy3A,3015 +cryptography/hazmat/primitives/kdf/kbkdf.py,sha256=eSuLK1sATkamgCAit794jLr7sDNlu5X0USdcWhwJdmk,9146 +cryptography/hazmat/primitives/kdf/pbkdf2.py,sha256=Xj3YIeX30h2BUaoJAtOo1RMXV_em0-eCG0PU_0FHJzM,1950 +cryptography/hazmat/primitives/kdf/scrypt.py,sha256=4QONhjxA_ZtuQtQ7QV3FnbB8ftrFnM52B4HPfV7hFys,2354 +cryptography/hazmat/primitives/kdf/x963kdf.py,sha256=wCpWmwQjZ2vAu2rlk3R_PX0nINl8WGXYBmlyMOC5iPw,1992 +cryptography/hazmat/primitives/keywrap.py,sha256=XV4Pj2fqSeD-RqZVvY2cA3j5_7RwJSFygYuLfk2ujCo,5650 +cryptography/hazmat/primitives/padding.py,sha256=QUq0n-EAgEan9aQzuTsiJYGKbWiK1nSHkcYjDF1L1ok,5518 +cryptography/hazmat/primitives/poly1305.py,sha256=P5EPQV-RB_FJPahpg01u0Ts4S_PnAmsroxIGXbGeRRo,355 +cryptography/hazmat/primitives/serialization/__init__.py,sha256=jyNx_7NcOEbVRBY4nP9ks0IVXBafbcYnTK27vafPLW8,1653 +cryptography/hazmat/primitives/serialization/__pycache__/__init__.cpython-311.pyc,, +cryptography/hazmat/primitives/serialization/__pycache__/base.cpython-311.pyc,, +cryptography/hazmat/primitives/serialization/__pycache__/pkcs12.cpython-311.pyc,, +cryptography/hazmat/primitives/serialization/__pycache__/pkcs7.cpython-311.pyc,, +cryptography/hazmat/primitives/serialization/__pycache__/ssh.cpython-311.pyc,, +cryptography/hazmat/primitives/serialization/base.py,sha256=ikq5MJIwp_oUnjiaBco_PmQwOTYuGi-XkYUYHKy8Vo0,615 +cryptography/hazmat/primitives/serialization/pkcs12.py,sha256=7vVXbiP7qhhvKAHJT_M8-LBZdbpOwrpWRHWxNrNqzXE,4492 +cryptography/hazmat/primitives/serialization/pkcs7.py,sha256=CNzcsuDMyEFMe3EUii4NfJlQzmakB2hLlfRFYObnHRs,11141 +cryptography/hazmat/primitives/serialization/ssh.py,sha256=VKscMrVdYK5B9PQISjjdRMglRvqa_L3sDNm5vdjVHJY,51915 +cryptography/hazmat/primitives/twofactor/__init__.py,sha256=tmMZGB-g4IU1r7lIFqASU019zr0uPp_wEBYcwdDCKCA,258 +cryptography/hazmat/primitives/twofactor/__pycache__/__init__.cpython-311.pyc,, +cryptography/hazmat/primitives/twofactor/__pycache__/hotp.cpython-311.pyc,, +cryptography/hazmat/primitives/twofactor/__pycache__/totp.cpython-311.pyc,, +cryptography/hazmat/primitives/twofactor/hotp.py,sha256=l1YdRMIhfPIuHKkA66keBDHhNbnBAlh6-O44P-OHIK8,2976 +cryptography/hazmat/primitives/twofactor/totp.py,sha256=v0y0xKwtYrP83ypOo5Ofd441RJLOkaFfjmp554jo5F0,1450 +cryptography/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +cryptography/utils.py,sha256=Rp7ppg4XIBVVzNQ6XngGndwkICJoYp6FoFOOgTWLJ7g,3925 +cryptography/x509/__init__.py,sha256=uGdiViR7KFnWGoJFVUStt-e_ufomWc87RQBGAZ7dT-4,7980 +cryptography/x509/__pycache__/__init__.cpython-311.pyc,, +cryptography/x509/__pycache__/base.cpython-311.pyc,, +cryptography/x509/__pycache__/certificate_transparency.cpython-311.pyc,, +cryptography/x509/__pycache__/extensions.cpython-311.pyc,, +cryptography/x509/__pycache__/general_name.cpython-311.pyc,, +cryptography/x509/__pycache__/name.cpython-311.pyc,, +cryptography/x509/__pycache__/ocsp.cpython-311.pyc,, +cryptography/x509/__pycache__/oid.cpython-311.pyc,, +cryptography/x509/__pycache__/verification.cpython-311.pyc,, +cryptography/x509/base.py,sha256=3NbbUn9wPruhmoPO7Cl3trc3SrqV2OFIBBE0P2l05mg,37081 +cryptography/x509/certificate_transparency.py,sha256=6HvzAD0dlSQVxy6tnDhGj0-pisp1MaJ9bxQNRr92inI,2261 +cryptography/x509/extensions.py,sha256=R70KkJ_c5NQ6Kx7Rho0sGJ0Rh-bOuBHjVOFSQGRAFCs,67370 +cryptography/x509/general_name.py,sha256=sP_rV11Qlpsk4x3XXGJY_Mv0Q_s9dtjeLckHsjpLQoQ,7836 +cryptography/x509/name.py,sha256=MYCxCSTQTpzhjxFPZaANqJ9fGrhESH73vPkoay8HSWM,14830 +cryptography/x509/ocsp.py,sha256=P6A02msz5pe-IkUFpvxezHvnEHGvPdXiD3S0wsuf4-I,20003 +cryptography/x509/oid.py,sha256=X8EbhkRTLrGuv9vHZSGqPd9zpvRVsonU_joWAL5LLY8,885 +cryptography/x509/verification.py,sha256=alfx3VaTSb2bMz7_7s788oL90vzgHwBjVINssdz0Gv0,796 diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/WHEEL b/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/WHEEL new file mode 100644 index 0000000..90c3c4b --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/WHEEL @@ -0,0 +1,5 @@ +Wheel-Version: 1.0 +Generator: maturin (1.7.0) +Root-Is-Purelib: false +Tag: cp39-abi3-manylinux_2_28_aarch64 + diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/license_files/LICENSE b/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/license_files/LICENSE new file mode 100644 index 0000000..b11f379 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/license_files/LICENSE @@ -0,0 +1,3 @@ +This software is made available under the terms of *either* of the licenses +found in LICENSE.APACHE or LICENSE.BSD. Contributions to cryptography are made +under the terms of *both* these licenses. diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/license_files/LICENSE.APACHE b/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/license_files/LICENSE.APACHE new file mode 100644 index 0000000..62589ed --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/license_files/LICENSE.APACHE @@ -0,0 +1,202 @@ + + Apache License + Version 2.0, January 2004 + https://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright [yyyy] [name of copyright owner] + + 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 + + https://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. diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/license_files/LICENSE.BSD b/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/license_files/LICENSE.BSD new file mode 100644 index 0000000..ec1a29d --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography-43.0.1.dist-info/license_files/LICENSE.BSD @@ -0,0 +1,27 @@ +Copyright (c) Individual contributors. +All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + + 1. Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer. + + 2. Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + 3. Neither the name of PyCA Cryptography nor the names of its contributors + may be used to endorse or promote products derived from this software + without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND +ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR +ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES +(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON +ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS +SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography/__about__.py b/PyGC/.venv/lib/python3.11/site-packages/cryptography/__about__.py new file mode 100644 index 0000000..d224b2f --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography/__about__.py @@ -0,0 +1,17 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. + +from __future__ import annotations + +__all__ = [ + "__author__", + "__copyright__", + "__version__", +] + +__version__ = "43.0.1" + + +__author__ = "The Python Cryptographic Authority and individual contributors" +__copyright__ = f"Copyright 2013-2024 {__author__}" diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/cryptography/__init__.py new file mode 100644 index 0000000..d374f75 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography/__init__.py @@ -0,0 +1,13 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. + +from __future__ import annotations + +from cryptography.__about__ import __author__, __copyright__, __version__ + +__all__ = [ + "__author__", + "__copyright__", + "__version__", +] diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography/exceptions.py b/PyGC/.venv/lib/python3.11/site-packages/cryptography/exceptions.py new file mode 100644 index 0000000..fe125ea --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography/exceptions.py @@ -0,0 +1,52 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. + +from __future__ import annotations + +import typing + +from cryptography.hazmat.bindings._rust import exceptions as rust_exceptions + +if typing.TYPE_CHECKING: + from cryptography.hazmat.bindings._rust import openssl as rust_openssl + +_Reasons = rust_exceptions._Reasons + + +class UnsupportedAlgorithm(Exception): + def __init__(self, message: str, reason: _Reasons | None = None) -> None: + super().__init__(message) + self._reason = reason + + +class AlreadyFinalized(Exception): + pass + + +class AlreadyUpdated(Exception): + pass + + +class NotYetFinalized(Exception): + pass + + +class InvalidTag(Exception): + pass + + +class InvalidSignature(Exception): + pass + + +class InternalError(Exception): + def __init__( + self, msg: str, err_code: list[rust_openssl.OpenSSLError] + ) -> None: + super().__init__(msg) + self.err_code = err_code + + +class InvalidKey(Exception): + pass diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography/fernet.py b/PyGC/.venv/lib/python3.11/site-packages/cryptography/fernet.py new file mode 100644 index 0000000..35ce113 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography/fernet.py @@ -0,0 +1,215 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. + +from __future__ import annotations + +import base64 +import binascii +import os +import time +import typing + +from cryptography import utils +from cryptography.exceptions import InvalidSignature +from cryptography.hazmat.primitives import hashes, padding +from cryptography.hazmat.primitives.ciphers import Cipher, algorithms, modes +from cryptography.hazmat.primitives.hmac import HMAC + + +class InvalidToken(Exception): + pass + + +_MAX_CLOCK_SKEW = 60 + + +class Fernet: + def __init__( + self, + key: bytes | str, + backend: typing.Any = None, + ) -> None: + try: + key = base64.urlsafe_b64decode(key) + except binascii.Error as exc: + raise ValueError( + "Fernet key must be 32 url-safe base64-encoded bytes." + ) from exc + if len(key) != 32: + raise ValueError( + "Fernet key must be 32 url-safe base64-encoded bytes." + ) + + self._signing_key = key[:16] + self._encryption_key = key[16:] + + @classmethod + def generate_key(cls) -> bytes: + return base64.urlsafe_b64encode(os.urandom(32)) + + def encrypt(self, data: bytes) -> bytes: + return self.encrypt_at_time(data, int(time.time())) + + def encrypt_at_time(self, data: bytes, current_time: int) -> bytes: + iv = os.urandom(16) + return self._encrypt_from_parts(data, current_time, iv) + + def _encrypt_from_parts( + self, data: bytes, current_time: int, iv: bytes + ) -> bytes: + utils._check_bytes("data", data) + + padder = padding.PKCS7(algorithms.AES.block_size).padder() + padded_data = padder.update(data) + padder.finalize() + encryptor = Cipher( + algorithms.AES(self._encryption_key), + modes.CBC(iv), + ).encryptor() + ciphertext = encryptor.update(padded_data) + encryptor.finalize() + + basic_parts = ( + b"\x80" + + current_time.to_bytes(length=8, byteorder="big") + + iv + + ciphertext + ) + + h = HMAC(self._signing_key, hashes.SHA256()) + h.update(basic_parts) + hmac = h.finalize() + return base64.urlsafe_b64encode(basic_parts + hmac) + + def decrypt(self, token: bytes | str, ttl: int | None = None) -> bytes: + timestamp, data = Fernet._get_unverified_token_data(token) + if ttl is None: + time_info = None + else: + time_info = (ttl, int(time.time())) + return self._decrypt_data(data, timestamp, time_info) + + def decrypt_at_time( + self, token: bytes | str, ttl: int, current_time: int + ) -> bytes: + if ttl is None: + raise ValueError( + "decrypt_at_time() can only be used with a non-None ttl" + ) + timestamp, data = Fernet._get_unverified_token_data(token) + return self._decrypt_data(data, timestamp, (ttl, current_time)) + + def extract_timestamp(self, token: bytes | str) -> int: + timestamp, data = Fernet._get_unverified_token_data(token) + # Verify the token was not tampered with. + self._verify_signature(data) + return timestamp + + @staticmethod + def _get_unverified_token_data(token: bytes | str) -> tuple[int, bytes]: + if not isinstance(token, (str, bytes)): + raise TypeError("token must be bytes or str") + + try: + data = base64.urlsafe_b64decode(token) + except (TypeError, binascii.Error): + raise InvalidToken + + if not data or data[0] != 0x80: + raise InvalidToken + + if len(data) < 9: + raise InvalidToken + + timestamp = int.from_bytes(data[1:9], byteorder="big") + return timestamp, data + + def _verify_signature(self, data: bytes) -> None: + h = HMAC(self._signing_key, hashes.SHA256()) + h.update(data[:-32]) + try: + h.verify(data[-32:]) + except InvalidSignature: + raise InvalidToken + + def _decrypt_data( + self, + data: bytes, + timestamp: int, + time_info: tuple[int, int] | None, + ) -> bytes: + if time_info is not None: + ttl, current_time = time_info + if timestamp + ttl < current_time: + raise InvalidToken + + if current_time + _MAX_CLOCK_SKEW < timestamp: + raise InvalidToken + + self._verify_signature(data) + + iv = data[9:25] + ciphertext = data[25:-32] + decryptor = Cipher( + algorithms.AES(self._encryption_key), modes.CBC(iv) + ).decryptor() + plaintext_padded = decryptor.update(ciphertext) + try: + plaintext_padded += decryptor.finalize() + except ValueError: + raise InvalidToken + unpadder = padding.PKCS7(algorithms.AES.block_size).unpadder() + + unpadded = unpadder.update(plaintext_padded) + try: + unpadded += unpadder.finalize() + except ValueError: + raise InvalidToken + return unpadded + + +class MultiFernet: + def __init__(self, fernets: typing.Iterable[Fernet]): + fernets = list(fernets) + if not fernets: + raise ValueError( + "MultiFernet requires at least one Fernet instance" + ) + self._fernets = fernets + + def encrypt(self, msg: bytes) -> bytes: + return self.encrypt_at_time(msg, int(time.time())) + + def encrypt_at_time(self, msg: bytes, current_time: int) -> bytes: + return self._fernets[0].encrypt_at_time(msg, current_time) + + def rotate(self, msg: bytes | str) -> bytes: + timestamp, data = Fernet._get_unverified_token_data(msg) + for f in self._fernets: + try: + p = f._decrypt_data(data, timestamp, None) + break + except InvalidToken: + pass + else: + raise InvalidToken + + iv = os.urandom(16) + return self._fernets[0]._encrypt_from_parts(p, timestamp, iv) + + def decrypt(self, msg: bytes | str, ttl: int | None = None) -> bytes: + for f in self._fernets: + try: + return f.decrypt(msg, ttl) + except InvalidToken: + pass + raise InvalidToken + + def decrypt_at_time( + self, msg: bytes | str, ttl: int, current_time: int + ) -> bytes: + for f in self._fernets: + try: + return f.decrypt_at_time(msg, ttl, current_time) + except InvalidToken: + pass + raise InvalidToken diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/__init__.py new file mode 100644 index 0000000..b9f1187 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/__init__.py @@ -0,0 +1,13 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. + +from __future__ import annotations + +""" +Hazardous Materials + +This is a "Hazardous Materials" module. You should ONLY use it if you're +100% absolutely sure that you know what you're doing because this module +is full of land mines, dragons, and dinosaurs with laser guns. +""" diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/_oid.py b/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/_oid.py new file mode 100644 index 0000000..fd5e37d --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/_oid.py @@ -0,0 +1,313 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. + +from __future__ import annotations + +from cryptography.hazmat.bindings._rust import ( + ObjectIdentifier as ObjectIdentifier, +) +from cryptography.hazmat.primitives import hashes + + +class ExtensionOID: + SUBJECT_DIRECTORY_ATTRIBUTES = ObjectIdentifier("2.5.29.9") + SUBJECT_KEY_IDENTIFIER = ObjectIdentifier("2.5.29.14") + KEY_USAGE = ObjectIdentifier("2.5.29.15") + SUBJECT_ALTERNATIVE_NAME = ObjectIdentifier("2.5.29.17") + ISSUER_ALTERNATIVE_NAME = ObjectIdentifier("2.5.29.18") + BASIC_CONSTRAINTS = ObjectIdentifier("2.5.29.19") + NAME_CONSTRAINTS = ObjectIdentifier("2.5.29.30") + CRL_DISTRIBUTION_POINTS = ObjectIdentifier("2.5.29.31") + CERTIFICATE_POLICIES = ObjectIdentifier("2.5.29.32") + POLICY_MAPPINGS = ObjectIdentifier("2.5.29.33") + AUTHORITY_KEY_IDENTIFIER = ObjectIdentifier("2.5.29.35") + POLICY_CONSTRAINTS = ObjectIdentifier("2.5.29.36") + EXTENDED_KEY_USAGE = ObjectIdentifier("2.5.29.37") + FRESHEST_CRL = ObjectIdentifier("2.5.29.46") + INHIBIT_ANY_POLICY = ObjectIdentifier("2.5.29.54") + ISSUING_DISTRIBUTION_POINT = ObjectIdentifier("2.5.29.28") + AUTHORITY_INFORMATION_ACCESS = ObjectIdentifier("1.3.6.1.5.5.7.1.1") + SUBJECT_INFORMATION_ACCESS = ObjectIdentifier("1.3.6.1.5.5.7.1.11") + OCSP_NO_CHECK = ObjectIdentifier("1.3.6.1.5.5.7.48.1.5") + TLS_FEATURE = ObjectIdentifier("1.3.6.1.5.5.7.1.24") + CRL_NUMBER = ObjectIdentifier("2.5.29.20") + DELTA_CRL_INDICATOR = ObjectIdentifier("2.5.29.27") + PRECERT_SIGNED_CERTIFICATE_TIMESTAMPS = ObjectIdentifier( + "1.3.6.1.4.1.11129.2.4.2" + ) + PRECERT_POISON = ObjectIdentifier("1.3.6.1.4.1.11129.2.4.3") + SIGNED_CERTIFICATE_TIMESTAMPS = ObjectIdentifier("1.3.6.1.4.1.11129.2.4.5") + MS_CERTIFICATE_TEMPLATE = ObjectIdentifier("1.3.6.1.4.1.311.21.7") + + +class OCSPExtensionOID: + NONCE = ObjectIdentifier("1.3.6.1.5.5.7.48.1.2") + ACCEPTABLE_RESPONSES = ObjectIdentifier("1.3.6.1.5.5.7.48.1.4") + + +class CRLEntryExtensionOID: + CERTIFICATE_ISSUER = ObjectIdentifier("2.5.29.29") + CRL_REASON = ObjectIdentifier("2.5.29.21") + INVALIDITY_DATE = ObjectIdentifier("2.5.29.24") + + +class NameOID: + COMMON_NAME = ObjectIdentifier("2.5.4.3") + COUNTRY_NAME = ObjectIdentifier("2.5.4.6") + LOCALITY_NAME = ObjectIdentifier("2.5.4.7") + STATE_OR_PROVINCE_NAME = ObjectIdentifier("2.5.4.8") + STREET_ADDRESS = ObjectIdentifier("2.5.4.9") + ORGANIZATION_IDENTIFIER = ObjectIdentifier("2.5.4.97") + ORGANIZATION_NAME = ObjectIdentifier("2.5.4.10") + ORGANIZATIONAL_UNIT_NAME = ObjectIdentifier("2.5.4.11") + SERIAL_NUMBER = ObjectIdentifier("2.5.4.5") + SURNAME = ObjectIdentifier("2.5.4.4") + GIVEN_NAME = ObjectIdentifier("2.5.4.42") + TITLE = ObjectIdentifier("2.5.4.12") + INITIALS = ObjectIdentifier("2.5.4.43") + GENERATION_QUALIFIER = ObjectIdentifier("2.5.4.44") + X500_UNIQUE_IDENTIFIER = ObjectIdentifier("2.5.4.45") + DN_QUALIFIER = ObjectIdentifier("2.5.4.46") + PSEUDONYM = ObjectIdentifier("2.5.4.65") + USER_ID = ObjectIdentifier("0.9.2342.19200300.100.1.1") + DOMAIN_COMPONENT = ObjectIdentifier("0.9.2342.19200300.100.1.25") + EMAIL_ADDRESS = ObjectIdentifier("1.2.840.113549.1.9.1") + JURISDICTION_COUNTRY_NAME = ObjectIdentifier("1.3.6.1.4.1.311.60.2.1.3") + JURISDICTION_LOCALITY_NAME = ObjectIdentifier("1.3.6.1.4.1.311.60.2.1.1") + JURISDICTION_STATE_OR_PROVINCE_NAME = ObjectIdentifier( + "1.3.6.1.4.1.311.60.2.1.2" + ) + BUSINESS_CATEGORY = ObjectIdentifier("2.5.4.15") + POSTAL_ADDRESS = ObjectIdentifier("2.5.4.16") + POSTAL_CODE = ObjectIdentifier("2.5.4.17") + INN = ObjectIdentifier("1.2.643.3.131.1.1") + OGRN = ObjectIdentifier("1.2.643.100.1") + SNILS = ObjectIdentifier("1.2.643.100.3") + UNSTRUCTURED_NAME = ObjectIdentifier("1.2.840.113549.1.9.2") + + +class SignatureAlgorithmOID: + RSA_WITH_MD5 = ObjectIdentifier("1.2.840.113549.1.1.4") + RSA_WITH_SHA1 = ObjectIdentifier("1.2.840.113549.1.1.5") + # This is an alternate OID for RSA with SHA1 that is occasionally seen + _RSA_WITH_SHA1 = ObjectIdentifier("1.3.14.3.2.29") + RSA_WITH_SHA224 = ObjectIdentifier("1.2.840.113549.1.1.14") + RSA_WITH_SHA256 = ObjectIdentifier("1.2.840.113549.1.1.11") + RSA_WITH_SHA384 = ObjectIdentifier("1.2.840.113549.1.1.12") + RSA_WITH_SHA512 = ObjectIdentifier("1.2.840.113549.1.1.13") + RSA_WITH_SHA3_224 = ObjectIdentifier("2.16.840.1.101.3.4.3.13") + RSA_WITH_SHA3_256 = ObjectIdentifier("2.16.840.1.101.3.4.3.14") + RSA_WITH_SHA3_384 = ObjectIdentifier("2.16.840.1.101.3.4.3.15") + RSA_WITH_SHA3_512 = ObjectIdentifier("2.16.840.1.101.3.4.3.16") + RSASSA_PSS = ObjectIdentifier("1.2.840.113549.1.1.10") + ECDSA_WITH_SHA1 = ObjectIdentifier("1.2.840.10045.4.1") + ECDSA_WITH_SHA224 = ObjectIdentifier("1.2.840.10045.4.3.1") + ECDSA_WITH_SHA256 = ObjectIdentifier("1.2.840.10045.4.3.2") + ECDSA_WITH_SHA384 = ObjectIdentifier("1.2.840.10045.4.3.3") + ECDSA_WITH_SHA512 = ObjectIdentifier("1.2.840.10045.4.3.4") + ECDSA_WITH_SHA3_224 = ObjectIdentifier("2.16.840.1.101.3.4.3.9") + ECDSA_WITH_SHA3_256 = ObjectIdentifier("2.16.840.1.101.3.4.3.10") + ECDSA_WITH_SHA3_384 = ObjectIdentifier("2.16.840.1.101.3.4.3.11") + ECDSA_WITH_SHA3_512 = ObjectIdentifier("2.16.840.1.101.3.4.3.12") + DSA_WITH_SHA1 = ObjectIdentifier("1.2.840.10040.4.3") + DSA_WITH_SHA224 = ObjectIdentifier("2.16.840.1.101.3.4.3.1") + DSA_WITH_SHA256 = ObjectIdentifier("2.16.840.1.101.3.4.3.2") + DSA_WITH_SHA384 = ObjectIdentifier("2.16.840.1.101.3.4.3.3") + DSA_WITH_SHA512 = ObjectIdentifier("2.16.840.1.101.3.4.3.4") + ED25519 = ObjectIdentifier("1.3.101.112") + ED448 = ObjectIdentifier("1.3.101.113") + GOSTR3411_94_WITH_3410_2001 = ObjectIdentifier("1.2.643.2.2.3") + GOSTR3410_2012_WITH_3411_2012_256 = ObjectIdentifier("1.2.643.7.1.1.3.2") + GOSTR3410_2012_WITH_3411_2012_512 = ObjectIdentifier("1.2.643.7.1.1.3.3") + + +_SIG_OIDS_TO_HASH: dict[ObjectIdentifier, hashes.HashAlgorithm | None] = { + SignatureAlgorithmOID.RSA_WITH_MD5: hashes.MD5(), + SignatureAlgorithmOID.RSA_WITH_SHA1: hashes.SHA1(), + SignatureAlgorithmOID._RSA_WITH_SHA1: hashes.SHA1(), + SignatureAlgorithmOID.RSA_WITH_SHA224: hashes.SHA224(), + SignatureAlgorithmOID.RSA_WITH_SHA256: hashes.SHA256(), + SignatureAlgorithmOID.RSA_WITH_SHA384: hashes.SHA384(), + SignatureAlgorithmOID.RSA_WITH_SHA512: hashes.SHA512(), + SignatureAlgorithmOID.RSA_WITH_SHA3_224: hashes.SHA3_224(), + SignatureAlgorithmOID.RSA_WITH_SHA3_256: hashes.SHA3_256(), + SignatureAlgorithmOID.RSA_WITH_SHA3_384: hashes.SHA3_384(), + SignatureAlgorithmOID.RSA_WITH_SHA3_512: hashes.SHA3_512(), + SignatureAlgorithmOID.ECDSA_WITH_SHA1: hashes.SHA1(), + SignatureAlgorithmOID.ECDSA_WITH_SHA224: hashes.SHA224(), + SignatureAlgorithmOID.ECDSA_WITH_SHA256: hashes.SHA256(), + SignatureAlgorithmOID.ECDSA_WITH_SHA384: hashes.SHA384(), + SignatureAlgorithmOID.ECDSA_WITH_SHA512: hashes.SHA512(), + SignatureAlgorithmOID.ECDSA_WITH_SHA3_224: hashes.SHA3_224(), + SignatureAlgorithmOID.ECDSA_WITH_SHA3_256: hashes.SHA3_256(), + SignatureAlgorithmOID.ECDSA_WITH_SHA3_384: hashes.SHA3_384(), + SignatureAlgorithmOID.ECDSA_WITH_SHA3_512: hashes.SHA3_512(), + SignatureAlgorithmOID.DSA_WITH_SHA1: hashes.SHA1(), + SignatureAlgorithmOID.DSA_WITH_SHA224: hashes.SHA224(), + SignatureAlgorithmOID.DSA_WITH_SHA256: hashes.SHA256(), + SignatureAlgorithmOID.ED25519: None, + SignatureAlgorithmOID.ED448: None, + SignatureAlgorithmOID.GOSTR3411_94_WITH_3410_2001: None, + SignatureAlgorithmOID.GOSTR3410_2012_WITH_3411_2012_256: None, + SignatureAlgorithmOID.GOSTR3410_2012_WITH_3411_2012_512: None, +} + + +class PublicKeyAlgorithmOID: + DSA = ObjectIdentifier("1.2.840.10040.4.1") + EC_PUBLIC_KEY = ObjectIdentifier("1.2.840.10045.2.1") + RSAES_PKCS1_v1_5 = ObjectIdentifier("1.2.840.113549.1.1.1") + RSASSA_PSS = ObjectIdentifier("1.2.840.113549.1.1.10") + X25519 = ObjectIdentifier("1.3.101.110") + X448 = ObjectIdentifier("1.3.101.111") + ED25519 = ObjectIdentifier("1.3.101.112") + ED448 = ObjectIdentifier("1.3.101.113") + + +class ExtendedKeyUsageOID: + SERVER_AUTH = ObjectIdentifier("1.3.6.1.5.5.7.3.1") + CLIENT_AUTH = ObjectIdentifier("1.3.6.1.5.5.7.3.2") + CODE_SIGNING = ObjectIdentifier("1.3.6.1.5.5.7.3.3") + EMAIL_PROTECTION = ObjectIdentifier("1.3.6.1.5.5.7.3.4") + TIME_STAMPING = ObjectIdentifier("1.3.6.1.5.5.7.3.8") + OCSP_SIGNING = ObjectIdentifier("1.3.6.1.5.5.7.3.9") + ANY_EXTENDED_KEY_USAGE = ObjectIdentifier("2.5.29.37.0") + SMARTCARD_LOGON = ObjectIdentifier("1.3.6.1.4.1.311.20.2.2") + KERBEROS_PKINIT_KDC = ObjectIdentifier("1.3.6.1.5.2.3.5") + IPSEC_IKE = ObjectIdentifier("1.3.6.1.5.5.7.3.17") + CERTIFICATE_TRANSPARENCY = ObjectIdentifier("1.3.6.1.4.1.11129.2.4.4") + + +class AuthorityInformationAccessOID: + CA_ISSUERS = ObjectIdentifier("1.3.6.1.5.5.7.48.2") + OCSP = ObjectIdentifier("1.3.6.1.5.5.7.48.1") + + +class SubjectInformationAccessOID: + CA_REPOSITORY = ObjectIdentifier("1.3.6.1.5.5.7.48.5") + + +class CertificatePoliciesOID: + CPS_QUALIFIER = ObjectIdentifier("1.3.6.1.5.5.7.2.1") + CPS_USER_NOTICE = ObjectIdentifier("1.3.6.1.5.5.7.2.2") + ANY_POLICY = ObjectIdentifier("2.5.29.32.0") + + +class AttributeOID: + CHALLENGE_PASSWORD = ObjectIdentifier("1.2.840.113549.1.9.7") + UNSTRUCTURED_NAME = ObjectIdentifier("1.2.840.113549.1.9.2") + + +_OID_NAMES = { + NameOID.COMMON_NAME: "commonName", + NameOID.COUNTRY_NAME: "countryName", + NameOID.LOCALITY_NAME: "localityName", + NameOID.STATE_OR_PROVINCE_NAME: "stateOrProvinceName", + NameOID.STREET_ADDRESS: "streetAddress", + NameOID.ORGANIZATION_NAME: "organizationName", + NameOID.ORGANIZATIONAL_UNIT_NAME: "organizationalUnitName", + NameOID.SERIAL_NUMBER: "serialNumber", + NameOID.SURNAME: "surname", + NameOID.GIVEN_NAME: "givenName", + NameOID.TITLE: "title", + NameOID.GENERATION_QUALIFIER: "generationQualifier", + NameOID.X500_UNIQUE_IDENTIFIER: "x500UniqueIdentifier", + NameOID.DN_QUALIFIER: "dnQualifier", + NameOID.PSEUDONYM: "pseudonym", + NameOID.USER_ID: "userID", + NameOID.DOMAIN_COMPONENT: "domainComponent", + NameOID.EMAIL_ADDRESS: "emailAddress", + NameOID.JURISDICTION_COUNTRY_NAME: "jurisdictionCountryName", + NameOID.JURISDICTION_LOCALITY_NAME: "jurisdictionLocalityName", + NameOID.JURISDICTION_STATE_OR_PROVINCE_NAME: ( + "jurisdictionStateOrProvinceName" + ), + NameOID.BUSINESS_CATEGORY: "businessCategory", + NameOID.POSTAL_ADDRESS: "postalAddress", + NameOID.POSTAL_CODE: "postalCode", + NameOID.INN: "INN", + NameOID.OGRN: "OGRN", + NameOID.SNILS: "SNILS", + NameOID.UNSTRUCTURED_NAME: "unstructuredName", + SignatureAlgorithmOID.RSA_WITH_MD5: "md5WithRSAEncryption", + SignatureAlgorithmOID.RSA_WITH_SHA1: "sha1WithRSAEncryption", + SignatureAlgorithmOID.RSA_WITH_SHA224: "sha224WithRSAEncryption", + SignatureAlgorithmOID.RSA_WITH_SHA256: "sha256WithRSAEncryption", + SignatureAlgorithmOID.RSA_WITH_SHA384: "sha384WithRSAEncryption", + SignatureAlgorithmOID.RSA_WITH_SHA512: "sha512WithRSAEncryption", + SignatureAlgorithmOID.RSASSA_PSS: "RSASSA-PSS", + SignatureAlgorithmOID.ECDSA_WITH_SHA1: "ecdsa-with-SHA1", + SignatureAlgorithmOID.ECDSA_WITH_SHA224: "ecdsa-with-SHA224", + SignatureAlgorithmOID.ECDSA_WITH_SHA256: "ecdsa-with-SHA256", + SignatureAlgorithmOID.ECDSA_WITH_SHA384: "ecdsa-with-SHA384", + SignatureAlgorithmOID.ECDSA_WITH_SHA512: "ecdsa-with-SHA512", + SignatureAlgorithmOID.DSA_WITH_SHA1: "dsa-with-sha1", + SignatureAlgorithmOID.DSA_WITH_SHA224: "dsa-with-sha224", + SignatureAlgorithmOID.DSA_WITH_SHA256: "dsa-with-sha256", + SignatureAlgorithmOID.ED25519: "ed25519", + SignatureAlgorithmOID.ED448: "ed448", + SignatureAlgorithmOID.GOSTR3411_94_WITH_3410_2001: ( + "GOST R 34.11-94 with GOST R 34.10-2001" + ), + SignatureAlgorithmOID.GOSTR3410_2012_WITH_3411_2012_256: ( + "GOST R 34.10-2012 with GOST R 34.11-2012 (256 bit)" + ), + SignatureAlgorithmOID.GOSTR3410_2012_WITH_3411_2012_512: ( + "GOST R 34.10-2012 with GOST R 34.11-2012 (512 bit)" + ), + PublicKeyAlgorithmOID.DSA: "dsaEncryption", + PublicKeyAlgorithmOID.EC_PUBLIC_KEY: "id-ecPublicKey", + PublicKeyAlgorithmOID.RSAES_PKCS1_v1_5: "rsaEncryption", + PublicKeyAlgorithmOID.RSASSA_PSS: "rsassaPss", + PublicKeyAlgorithmOID.X25519: "X25519", + PublicKeyAlgorithmOID.X448: "X448", + ExtendedKeyUsageOID.SERVER_AUTH: "serverAuth", + ExtendedKeyUsageOID.CLIENT_AUTH: "clientAuth", + ExtendedKeyUsageOID.CODE_SIGNING: "codeSigning", + ExtendedKeyUsageOID.EMAIL_PROTECTION: "emailProtection", + ExtendedKeyUsageOID.TIME_STAMPING: "timeStamping", + ExtendedKeyUsageOID.OCSP_SIGNING: "OCSPSigning", + ExtendedKeyUsageOID.SMARTCARD_LOGON: "msSmartcardLogin", + ExtendedKeyUsageOID.KERBEROS_PKINIT_KDC: "pkInitKDC", + ExtensionOID.SUBJECT_DIRECTORY_ATTRIBUTES: "subjectDirectoryAttributes", + ExtensionOID.SUBJECT_KEY_IDENTIFIER: "subjectKeyIdentifier", + ExtensionOID.KEY_USAGE: "keyUsage", + ExtensionOID.SUBJECT_ALTERNATIVE_NAME: "subjectAltName", + ExtensionOID.ISSUER_ALTERNATIVE_NAME: "issuerAltName", + ExtensionOID.BASIC_CONSTRAINTS: "basicConstraints", + ExtensionOID.PRECERT_SIGNED_CERTIFICATE_TIMESTAMPS: ( + "signedCertificateTimestampList" + ), + ExtensionOID.SIGNED_CERTIFICATE_TIMESTAMPS: ( + "signedCertificateTimestampList" + ), + ExtensionOID.PRECERT_POISON: "ctPoison", + ExtensionOID.MS_CERTIFICATE_TEMPLATE: "msCertificateTemplate", + CRLEntryExtensionOID.CRL_REASON: "cRLReason", + CRLEntryExtensionOID.INVALIDITY_DATE: "invalidityDate", + CRLEntryExtensionOID.CERTIFICATE_ISSUER: "certificateIssuer", + ExtensionOID.NAME_CONSTRAINTS: "nameConstraints", + ExtensionOID.CRL_DISTRIBUTION_POINTS: "cRLDistributionPoints", + ExtensionOID.CERTIFICATE_POLICIES: "certificatePolicies", + ExtensionOID.POLICY_MAPPINGS: "policyMappings", + ExtensionOID.AUTHORITY_KEY_IDENTIFIER: "authorityKeyIdentifier", + ExtensionOID.POLICY_CONSTRAINTS: "policyConstraints", + ExtensionOID.EXTENDED_KEY_USAGE: "extendedKeyUsage", + ExtensionOID.FRESHEST_CRL: "freshestCRL", + ExtensionOID.INHIBIT_ANY_POLICY: "inhibitAnyPolicy", + ExtensionOID.ISSUING_DISTRIBUTION_POINT: "issuingDistributionPoint", + ExtensionOID.AUTHORITY_INFORMATION_ACCESS: "authorityInfoAccess", + ExtensionOID.SUBJECT_INFORMATION_ACCESS: "subjectInfoAccess", + ExtensionOID.OCSP_NO_CHECK: "OCSPNoCheck", + ExtensionOID.CRL_NUMBER: "cRLNumber", + ExtensionOID.DELTA_CRL_INDICATOR: "deltaCRLIndicator", + ExtensionOID.TLS_FEATURE: "TLSFeature", + AuthorityInformationAccessOID.OCSP: "OCSP", + AuthorityInformationAccessOID.CA_ISSUERS: "caIssuers", + SubjectInformationAccessOID.CA_REPOSITORY: "caRepository", + CertificatePoliciesOID.CPS_QUALIFIER: "id-qt-cps", + CertificatePoliciesOID.CPS_USER_NOTICE: "id-qt-unotice", + OCSPExtensionOID.NONCE: "OCSPNonce", + AttributeOID.CHALLENGE_PASSWORD: "challengePassword", +} diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/backends/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/backends/__init__.py new file mode 100644 index 0000000..b4400aa --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/backends/__init__.py @@ -0,0 +1,13 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. + +from __future__ import annotations + +from typing import Any + + +def default_backend() -> Any: + from cryptography.hazmat.backends.openssl.backend import backend + + return backend diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/backends/openssl/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/backends/openssl/__init__.py new file mode 100644 index 0000000..51b0447 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/backends/openssl/__init__.py @@ -0,0 +1,9 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. + +from __future__ import annotations + +from cryptography.hazmat.backends.openssl.backend import backend + +__all__ = ["backend"] diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/backends/openssl/backend.py b/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/backends/openssl/backend.py new file mode 100644 index 0000000..c87d3e8 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/backends/openssl/backend.py @@ -0,0 +1,291 @@ +# This file is dual licensed under the terms of the Apache License, Version +# 2.0, and the BSD License. See the LICENSE file in the root of this repository +# for complete details. + +from __future__ import annotations + +from cryptography.hazmat.bindings._rust import openssl as rust_openssl +from cryptography.hazmat.bindings.openssl import binding +from cryptography.hazmat.primitives import hashes +from cryptography.hazmat.primitives._asymmetric import AsymmetricPadding +from cryptography.hazmat.primitives.asymmetric import ec +from cryptography.hazmat.primitives.asymmetric import utils as asym_utils +from cryptography.hazmat.primitives.asymmetric.padding import ( + MGF1, + OAEP, + PSS, + PKCS1v15, +) +from cryptography.hazmat.primitives.ciphers import ( + CipherAlgorithm, +) +from cryptography.hazmat.primitives.ciphers.algorithms import ( + AES, +) +from cryptography.hazmat.primitives.ciphers.modes import ( + CBC, + Mode, +) + + +class Backend: + """ + OpenSSL API binding interfaces. + """ + + name = "openssl" + + # TripleDES encryption is disallowed/deprecated throughout 2023 in + # FIPS 140-3. To keep it simple we denylist any use of TripleDES (TDEA). + _fips_ciphers = (AES,) + # Sometimes SHA1 is still permissible. That logic is contained + # within the various *_supported methods. + _fips_hashes = ( + hashes.SHA224, + hashes.SHA256, + hashes.SHA384, + hashes.SHA512, + hashes.SHA512_224, + hashes.SHA512_256, + hashes.SHA3_224, + hashes.SHA3_256, + hashes.SHA3_384, + hashes.SHA3_512, + hashes.SHAKE128, + hashes.SHAKE256, + ) + _fips_ecdh_curves = ( + ec.SECP224R1, + ec.SECP256R1, + ec.SECP384R1, + ec.SECP521R1, + ) + _fips_rsa_min_key_size = 2048 + _fips_rsa_min_public_exponent = 65537 + _fips_dsa_min_modulus = 1 << 2048 + _fips_dh_min_key_size = 2048 + _fips_dh_min_modulus = 1 << _fips_dh_min_key_size + + def __init__(self) -> None: + self._binding = binding.Binding() + self._ffi = self._binding.ffi + self._lib = self._binding.lib + self._fips_enabled = rust_openssl.is_fips_enabled() + + def __repr__(self) -> str: + return ( + f"" + ) + + def openssl_assert(self, ok: bool) -> None: + return binding._openssl_assert(ok) + + def _enable_fips(self) -> None: + # This function enables FIPS mode for OpenSSL 3.0.0 on installs that + # have the FIPS provider installed properly. + rust_openssl.enable_fips(rust_openssl._providers) + assert rust_openssl.is_fips_enabled() + self._fips_enabled = rust_openssl.is_fips_enabled() + + def openssl_version_text(self) -> str: + """ + Friendly string name of the loaded OpenSSL library. This is not + necessarily the same version as it was compiled against. + + Example: OpenSSL 3.2.1 30 Jan 2024 + """ + return rust_openssl.openssl_version_text() + + def openssl_version_number(self) -> int: + return rust_openssl.openssl_version() + + def _evp_md_from_algorithm(self, algorithm: hashes.HashAlgorithm): + if algorithm.name in ("blake2b", "blake2s"): + alg = f"{algorithm.name}{algorithm.digest_size * 8}".encode( + "ascii" + ) + else: + alg = algorithm.name.encode("ascii") + + evp_md = self._lib.EVP_get_digestbyname(alg) + return evp_md + + def hash_supported(self, algorithm: hashes.HashAlgorithm) -> bool: + if self._fips_enabled and not isinstance(algorithm, self._fips_hashes): + return False + + evp_md = self._evp_md_from_algorithm(algorithm) + return evp_md != self._ffi.NULL + + def signature_hash_supported( + self, algorithm: hashes.HashAlgorithm + ) -> bool: + # Dedicated check for hashing algorithm use in message digest for + # signatures, e.g. RSA PKCS#1 v1.5 SHA1 (sha1WithRSAEncryption). + if self._fips_enabled and isinstance(algorithm, hashes.SHA1): + return False + return self.hash_supported(algorithm) + + def scrypt_supported(self) -> bool: + if self._fips_enabled: + return False + else: + return hasattr(rust_openssl.kdf, "derive_scrypt") + + def hmac_supported(self, algorithm: hashes.HashAlgorithm) -> bool: + # FIPS mode still allows SHA1 for HMAC + if self._fips_enabled and isinstance(algorithm, hashes.SHA1): + return True + + return self.hash_supported(algorithm) + + def cipher_supported(self, cipher: CipherAlgorithm, mode: Mode) -> bool: + if self._fips_enabled: + # FIPS mode requires AES. TripleDES is disallowed/deprecated in + # FIPS 140-3. + if not isinstance(cipher, self._fips_ciphers): + return False + + return rust_openssl.ciphers.cipher_supported(cipher, mode) + + def pbkdf2_hmac_supported(self, algorithm: hashes.HashAlgorithm) -> bool: + return self.hmac_supported(algorithm) + + def _consume_errors(self) -> list[rust_openssl.OpenSSLError]: + return rust_openssl.capture_error_stack() + + def _oaep_hash_supported(self, algorithm: hashes.HashAlgorithm) -> bool: + if self._fips_enabled and isinstance(algorithm, hashes.SHA1): + return False + + return isinstance( + algorithm, + ( + hashes.SHA1, + hashes.SHA224, + hashes.SHA256, + hashes.SHA384, + hashes.SHA512, + ), + ) + + def rsa_padding_supported(self, padding: AsymmetricPadding) -> bool: + if isinstance(padding, PKCS1v15): + return True + elif isinstance(padding, PSS) and isinstance(padding._mgf, MGF1): + # SHA1 is permissible in MGF1 in FIPS even when SHA1 is blocked + # as signature algorithm. + if self._fips_enabled and isinstance( + padding._mgf._algorithm, hashes.SHA1 + ): + return True + else: + return self.hash_supported(padding._mgf._algorithm) + elif isinstance(padding, OAEP) and isinstance(padding._mgf, MGF1): + return self._oaep_hash_supported( + padding._mgf._algorithm + ) and self._oaep_hash_supported(padding._algorithm) + else: + return False + + def rsa_encryption_supported(self, padding: AsymmetricPadding) -> bool: + if self._fips_enabled and isinstance(padding, PKCS1v15): + return False + else: + return self.rsa_padding_supported(padding) + + def dsa_supported(self) -> bool: + return ( + not rust_openssl.CRYPTOGRAPHY_IS_BORINGSSL + and not self._fips_enabled + ) + + def dsa_hash_supported(self, algorithm: hashes.HashAlgorithm) -> bool: + if not self.dsa_supported(): + return False + return self.signature_hash_supported(algorithm) + + def cmac_algorithm_supported(self, algorithm) -> bool: + return self.cipher_supported( + algorithm, CBC(b"\x00" * algorithm.block_size) + ) + + def elliptic_curve_supported(self, curve: ec.EllipticCurve) -> bool: + if self._fips_enabled and not isinstance( + curve, self._fips_ecdh_curves + ): + return False + + return rust_openssl.ec.curve_supported(curve) + + def elliptic_curve_signature_algorithm_supported( + self, + signature_algorithm: ec.EllipticCurveSignatureAlgorithm, + curve: ec.EllipticCurve, + ) -> bool: + # We only support ECDSA right now. + if not isinstance(signature_algorithm, ec.ECDSA): + return False + + return self.elliptic_curve_supported(curve) and ( + isinstance(signature_algorithm.algorithm, asym_utils.Prehashed) + or self.hash_supported(signature_algorithm.algorithm) + ) + + def elliptic_curve_exchange_algorithm_supported( + self, algorithm: ec.ECDH, curve: ec.EllipticCurve + ) -> bool: + return self.elliptic_curve_supported(curve) and isinstance( + algorithm, ec.ECDH + ) + + def dh_supported(self) -> bool: + return not rust_openssl.CRYPTOGRAPHY_IS_BORINGSSL + + def dh_x942_serialization_supported(self) -> bool: + return self._lib.Cryptography_HAS_EVP_PKEY_DHX == 1 + + def x25519_supported(self) -> bool: + if self._fips_enabled: + return False + return True + + def x448_supported(self) -> bool: + if self._fips_enabled: + return False + return ( + not rust_openssl.CRYPTOGRAPHY_IS_LIBRESSL + and not rust_openssl.CRYPTOGRAPHY_IS_BORINGSSL + ) + + def ed25519_supported(self) -> bool: + if self._fips_enabled: + return False + return True + + def ed448_supported(self) -> bool: + if self._fips_enabled: + return False + return ( + not rust_openssl.CRYPTOGRAPHY_IS_LIBRESSL + and not rust_openssl.CRYPTOGRAPHY_IS_BORINGSSL + ) + + def ecdsa_deterministic_supported(self) -> bool: + return ( + rust_openssl.CRYPTOGRAPHY_OPENSSL_320_OR_GREATER + and not self._fips_enabled + ) + + def poly1305_supported(self) -> bool: + if self._fips_enabled: + return False + return True + + def pkcs7_supported(self) -> bool: + return not rust_openssl.CRYPTOGRAPHY_IS_BORINGSSL + + +backend = Backend() diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/__init__.py b/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/__init__.py new file mode 100644 index 0000000..b509336 --- /dev/null +++ b/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/__init__.py @@ -0,0 +1,3 @@ +# 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. diff --git a/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust.abi3.so b/PyGC/.venv/lib/python3.11/site-packages/cryptography/hazmat/bindings/_rust.abi3.so new file mode 100755 index 0000000000000000000000000000000000000000..0a89edc30c2353f9d40298bf346acc892c18b732 GIT binary patch literal 9866904 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%0DKhSo>x0D3gqMHd`D0@H(mYg4|6=pzhBD#N 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

Ef2FNC(! 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%0AhOZm@vdD3uS% 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 z z*BJH~_nGOQUWZni_-x*%+?A_(8EZ8Hd=s2fep2%N3Si~LnEwnIMSs`*z7Kc4G4T;M z-2VJWU?rJ^z2v?-SYzngOIF{hF1+-abIc0g#vFa-9HAr7j*i(`;AKCHmaw)?-px7Y zJf~SXIviTUe(sn(Gs#@Z7h7u46KAe|PwttTZ!vi))n*=X&3EEg7o9!L%oMn63w zjAmMQN;40w*S;CnxPSe}E}B!vx8gsi1E)Ip^cU^lY{BU(*uU4&Z|DA1ys*80om}DRdNnqJ1;`CayZN%ZA;+|8J08grCxf z@`%xWkvadpwEt8W?u;_WoE2Wpm`5E0?%buZe+9S``M`xciiu3Xo%dRj<4yd9)*ZzmoIuf69G_FU&WB20UUi!L^w4Ub zm4hPpIb+2EaHkwu#or#c?uJHAF>|(YH*^l~8+or>o(tYLLjUi7J)tr)*JWw#T zuX`kS`oqI`{x&~yg@$(e;QMX#1ATVvaB&}c7dE_Bc=Ns)zEJi>0dzPIeq2WIiG#gY ztYA&|o@#t{Hl&gZ+y8iV*GLGefnLL)~Dai{QQ)w|8!_ei1jpKZHx_i zIrqG}t#?1!dpZhU44E)_%469A@-l)=1<3f!^K-#5t+-9{b7DVf8GZWY`TO)ck6+@v zoqn?~W{)t3>yBaW-$*j|A0J`v4o-Cpe=)?Iw&$-tHCUka1Sc$9=^gwtbI_UzcNNz% zQEO$-MdND(E=Iom5B%Y45BA2+=n0$fnRHgLg!-co^zPTuC%4U+3otC4*u%KKCw8P} zpK(@t4`M;-GrtV`BRF#>_+$1RI41X z*Y{d8v)_B{@9gzjOJB;j_G4FFvtEiP_!93l_npkie_|k{xto3^zVz^E%sp{!i@~8Q z!JkTgiSPc%yS0>W=9jPzpXI+i@rdit2u!sOe>%{$4vB5QLfbX8`!v7AaqeZDrrq4m zA?o*&-^1f+X~M5_affHmvP@%^BM0f8*Mif1D{dlB%iYK>p;Y57*`T-&wPgwQ?@kp> z;=ZXN#toUqz%!>W7NNmlWe-4kP-`xdZ)-x+AY2I@5gic&;y@kBlKk-vuXc zSv3b-Xf7}cWy?sI)KKXdBl`GY@p>PGzVLCY3=Cv}BG4((eGEvilJ z({Beqclqhy)qctbgI681e*3g@H!Bdzf<8)rx$+N|j3ZoWwtY-gzHde` z@!T)17abIi6*K1i06G15SGV6|+PFV^|IkX^n`hEObVAX8)x}@zKEucip4#eJp|c)+ zQ%pY<_!Y{&=ICUi^~XQozOuozv#C#LzIcmG?-Tod$nN)T`n@WlU(HSRH9u!=Cmx~C zefZ5Bsm~~5l^wQgzW(qX^s94|iS${?IhEeypTHdgS>Y!cO9gvt82kL-v+{Sy3Wq7{ z26JKo+%WI>eHYB{IYyXYWzT&%Z4YG}9eqw{)0&#F-k2VIoA(Z^|3dp^z(YQJP5eKX z|23|Bp3QYlD``u%uBCP#-=~ih`taWwXqy5LO=s@nw}*azD96KJ&gY&r*aw>P3(s<= zB{<@YN4x`l-prHh?n^L>vVU@W7<=;B-({T7I50kme#?Mi1?@Uzc`5@}(Em4lf*g0_ z+uUmf?8~X6xfq^_?^W_m!=d=IOH7=yahAFLCu353PFua~ww&j5J=4GOdHh+8(JAlX zTkn34Y15a!qxMBJg;)9L#@=)bmn+P5?ic9uW#17=56vQeMft4c>Iwv$)#EJ`7qx)@ZJmEf6&CIuKC~3I;ma3>0TSx zdhp%7e5dts;?s+5btrz5W$@EFMt9_|}B4>&sg=({PbpKRh<`z&A)VBEJP z^nIiH7VU81n8tCfJ&q>!qy&3eR_%HOO47l(_ z&a4EJc-$AleoYx> zTc>)`Yp(J1tQqzC)~zEew=A!z-?sH0Pe#oG%70Y(+Vau0+qT~Q!q%QfHw0-l?zmw^J^73057%t^P~G%ZH5z+-bG%g>>LH794fpCK$TmX2M~9 za=7i|4Bo+~=TnRoWAUZD@seWn80jn4H>&eA@1A8ZSEu%?xw*s$X79OU$2)HmP;|NqWK-P*I>J0p zd9_F~FS_Hb=tTSoloQ*>T|4k=_NIBhx0f?g1D`Oze8PPASg|(pUHF7}Df!=djDP=` z?8B0yE*pUDm2(%#*b&-{`0&r-do$k7_3ejzD}S=cOe0t)-!#7MuAV``zCW|4BX5_IaH0 zs(ZqZL9aW8r-Vl0b2D;ouOP7lv1aJdpJ@Z#K8Rg(`#rtB5j>UmwGBOkE!ZLFQkK7Q zf^4DN=f5@~crx!^E$bOvfUI*hWgkZ-00YbR`Cqgz+h_A=Bb2fa`wDhs-GgZ9B17Ap zdsjqT{ds{p$-@l=77Uk&mt-1sFTi`N9}E;aWWR53X^Zdf+-E)^l?E%6jA))fEr%^Bj$r z6sjGSnedtKE4+?*M17@)l`o)t|IEoDr@s2xN4xVo=bg>G`-SJ|d(DA4{n9lD`7!UC zaZ#v!k?g)RxUZMH7E4piHC67Z_S@63xgVZ?suM;9HjG%4h_AA!qnELwVluvR%q5$# zv=(@SD_MKta)i3AdVe1JWE%I-Z4ykeO{X!o9L^_zX+Ha_l|8WVf5*9WB0xS3LslSeUmM46QM`DS3WYRrs|PZPk8?0nc6%4W5@?TrE$TKv&h4N{~bJaFaW>{@_ zk)2;#cyt^m=^;I>LCu@_t%4c1BW^rf^u>9^f0-<}D;}f3VHJ>u~?aX;s{cBra zfBp5XKlU6)S+APcYG2#B`-RuHep>nFa{AhO?U|m?qHh?X`mwTm=Z1CuQp4{WPvGZ| zcrscVfzxZ=%$jQ%$0Ejf&w>TFYCJ#n3<)ph{e0eM;IH^~<{~|D5%sn#TyXZt{B5g> zsB<^xWX-@r<9i%9jx^VLmATdn^0%xSNgcsuI_rE8ev)2j1Q!i6VxNOc3&0i1H)vd8 zZ|=6~d+xYD?#pZ`z-~J|J#hbG;JdE3F>C9>1<&8Zn195WU-V?QsOF4`T_(B?|GsaA8 zD|h^KO^#@HT}bf`#@A`|6nC5T>r+u#o){W}gcF6M^rr zeY7{OICLHDZC|*cO}I9aG4BDVb^%k>>E-QZ;^FJ{uW!{pbYT0W=lGi4wcwxUxUB`u z;hJ$C+A%`Tdam6QH}~Z(;Jw>tt*3DCb#Kq`kF^)T!CG*zHvf%Pj4%9%#sf^3fqVDx z-hYJ=6#m7)pOL_H6m>)cRj#tpFPUTO9e#uNwXB22^*HZ#+v`xv+B$2q z5Sp@#b=Ufi@cC@nvx~0gj7?RN<4Iv8ep{u6>!_ zqOzxL9RI4;wFx*n>oA`)g2a8LvJv!|xF6@4>-dkshsMwUc6`v9IQU@EA`1@|vTp@< z!MtW){Mq&3f#Lv98B@LL5#Zd!cj>-B-H*VHC!i&w=_*rviRQeU-zVUt%GF2jMcrxl z7EijlH`ns6=b|p!%~;HRnd=$YqP;G>90^`703W6T^97!PH4DH6hwmQh(Z!eNz8s%* z9Jvt|!Sk*eCw>QQVn5Zw?|zJ3FATq{d41c~^P%~*p3IuN;dhU{ux)ECypVpkE)u^R zXM{%j{3dQGZlGj$eAXg(#&>D2&!Y0SH~3EHj^Y>FXiIg#Z<9_u4*yWQPMhK*;vsK% z`k4E75&Yx3YTw4ymv&m~C7QVlSUuuNH}_CapPPr2n>c5)m}zR)wcMoxxi%Kj0=$+FTj7p%87aCx@q_*Ozpg*+dqJK z+C15Sy*2&;hVo}UtDG}_Px`hwbIDbjY#tl=x_%B~b^K@`zM0ppEWZ3UIuKN{!DjslwyrHu#-}s4!uf@Z8tOZy~T^&n%{`@Kn&VP+(~B3zMMw}6?0Zx*dq}8CO`T39KeTTFfz*R z`05y}{|MiJnyLIoofQaWo)HM0Hla8qc_`!5;!uU>f`b9ig$FavDhZuZSQ0Ap%s7}i zFc3SPU%+$z!Hnxm+fL!PnmT%?GWitw+XICo`4PLgs93bt?jz&kK;3A5b3B=gDs^6b zX>s9beses=^*f1yTg=}U#;o@h!ezdj&hPw-iwm#i_lT$0qI&2|$w}Z4zd1%mOEJ&+ z`RH5x2F&*a$G(H#TP!|SyfW_1Zt)z5&+_uWVi>XQj&k2ie2{yIJFa_Wz1BoAl5OY> z-Sa@Fk>9jSmmA6d`RH|=r{E`DQPkYWApU1b(OVe?dOLddd?UDzHF}-rG2D}}A3dlQ z{Wik+{@$5B?(sUeAOSo4Xz z&tnfqCT^UtmG&aD)!w44lZlsy8mi8#WldUko_>jm6Aj!aC%o7>2A^Bjy=D9rp@3)l!JX>@v6da2fq^%V z-%#3Cd&AT=mFrn}v2)_Ng)J|h$9iX)c(HSSab3%%ViOy_q91DgiGAm};RAH##{#hpJIIx=KR(usqqKEF>8lG8*5^As z-?%rvA!43O5@TJOcGz95dEi5`^0?26ecLx6|6azkZN#SKe}=6NUAR^CuiwB&{=p1E@p8-mulg1uaJSD8HwI#pSi_3e_*g%CR`aTdM`$hf&9Gzgd{#`J{5cZK z;=WYu4SlgUWI;pwK|`~lq5ZMR<7 zvR+!db?5~AZ(xVC69c*s{v);y8*p+U>=lM468xOi;^iiINThEofc%E5W*gSKR zxsN=0p3U=Y>$wtLGnF8cz|X?Pi%eW>z>jI0@+papC#=Onw8sc?5d1OY`vbT$Bf$8V0YN%5RR5-m(Uqu3T8&R>p7W zTu<<)z&c94$-u$*So!7~?CX4f2Rq0^MGSVieaHGn@b)?AOT&K*ddTrjo%6V{!nuDU zvMWC8-Cgl#*O>3KO#i>xyq^mX`W&02(+)Ih*6(P?Z{F2z`M5UV<9fckE$Y16Stl#J zhWD~#l~TvrC$rfHm$4r%Wnauespar@87ekwaKITuz~=W3QsPTz^nzE+HX&szDtTK3P)JXik=`zLFnGRHoA zdV73j#ad#=DI*qiMfI?f+nhQj&=+E#ZabMe4@{fX`K|hptvHYJ{lK^S!mf8ty90SA zn{WsBd^y7Kj zow0IIEB$(D`@@%v>#Nxx)rN6g`l6f9_NS-U7@pksD)6h(T>c!#FQ0L)06$w;n+KEF zus=Iwt&d~t-o(rOen0$oW=E&!SeT)3%$A>hr?Mqopt)XIy(*xAT86Y5>Y^8?t(9e4_sFS^EkA@6Sjj~>J>?ye(TpWNA&&KvrN zOV!q}?)BVlox}TgcgLSyadP)M`)F%yx3(15-yPphIYhi-0&WV=Pv*Ou{KnW9Q@J}9 z{eQ)Khr@7aXWPzsQ1`a8XwV%$`S|#bn*V&JSL-Eg9tM?8+ zpNdiL#Jq-a7#?*IG}Ssw(pivm zMrL>`-geH&jJ%D1b)PD%aD$B@dpiyHCvfI&9w5XMEiB z?R$qgD>sPR%3Uz-?EjZx#QL4hnJKw|99mSp4_?o+a~{@;KG8V`=*63?DRDJVm(Wi} zZ1Ijc*oLN7E?XrV?byl(R;`DZEMV=Ui>(}i&9`vQ>Khx5l=^~A>wLld_QgAN<`zZX zTX7b#MVzfgIn#+=7l>&d|Bsma554_bkU?hcpf5{4J{)FdJb4XglUMhJ)@A`yE4Dlb z_&Iv5cvB8A8~}VBy;gp+)?Bm07ckenKAO7`%;6kOym&SDka3@47~R8!lTR@2ZH&LI z6UGBu@=SY$KPc^xpHZv;ORk3V3YjT(oD zE75rjS=kQ=2G=_R#>`96Z5ffC_5aTY{Y!(E62v6!B$^4nSEuq1op;fJw#vPFN)J| zojnUX#Uq2-<{%^15EFbga$=Pg|7+sYa-DU%a0$Oscl}v&!p{$?pLls)>)7kG>$8CQknMbi-4#jPY$kPe=z>*RKuSpU%3Y z*R)icx`PocnyVZO>}T3t&bgHX!}7~Kg-3e-68TUXu%*bZ$iB&)+`|1s6UbH#mFTgI=z8l6eoQ{299(8uBA(NQkqnb<&fdAsN2(mQ2o; zYPd_w2Olaw(+J(d`O(d0UI6YOL+^CXTNsn61Dosnpuzr6{=U)o+oGnb&E%xDcvACt z_Iha`)>LEEJ`N3NoDpdMeAnvh8Gejc3F=$ejJFd-Nhp1GUi)@O{Y))H(Z@ zIICFmGlA!w{oDu~wTBygON(~GHzM3e)i}dw-#yb{?B2rleW4{!8g;)OjBlAuOQvi6 zeDdc>#eR^69l?)Gk+-d~LTBi=3ED!v_q_D2RkrKH>{&67`zVhe zSkwPfgItT*Va5;(z(cID62Ht?-(akg8)KQ^r1%VHo~w~#bRU`IhzjPWT!7-yFM)%J z@_@smo74E7@oKEijM?PTo8Zv}o-Q6e+K3Gr1CNF`m*X3xylv`te}UwIY+HUJZ{Aqy z(4Hed?awr@0a$zDwmHZw9!pMBT-b+u;wufF_ZJk0V(@;Axq-6~$yrYz5BwUQAHyf{ z56GhX1e;HPu*0!aZFtlm){2-R&Mlz%X3Wr2lwrr|caZxy%^U=LBY(()ze@=s##WU(-k) zNW(Lv=J_p$R=!Yb1gm{HH81)Gx0EBFNq+xDS|Bvu=-*Ps{+?)Lw^Xx!Kd|M`bkC4& z6FoUCYw;IZ=F53(Sb`j$0e(mpKfChoRU`0uF=cVr8YxE}!OG9NVe&l(CX_ocSwxxi zmBGw$U~7ECGkhmr?#xwwg_`F&d!ByoY0=tBhL`-MI}IJ#_*2$jbAMO*2XJ%r56Q@0 z);8cV##wUyboSgd_TE(X;1u@aWb~x-u;p2F%#qvo%{X$s%lE`{$o+R;$!gtM=b^9c z@GkB>l-%D{-aq^~WqITulguNVAGoqX@{88kem)F$PEG=+d=pOC|6bGGm&$R~mpNFu zY5GGq#^Fcj_gigN>;E3cTbjpyWDc#jWXCIpK=a9eC0?MjBukzo=Z(s3d0{T)*8oGw zlRkJs88k*Zp5(~|zf1L-`{v&0?nO|B)BoAL|@Lkrp9NLsjM%>q3M!YXUM!e6K z5%0URtnV?&h$HChXfon+HXexoPl1M5c+k((C#r2c_}yUE%hoF@p}US=aX{rZ9^||9 zicR1_qFzw|t&mQUI}qK3|AhzN5gyriARWWe9YnVq(KXBZR>1o=70vBii9WG}=c*!| zE3@B6m3t*OSh|yR3%6e3;K%LE-O(HVMRW)gKQ1^5ekAA+e>Z-t9(Z*8z<0r<6T**b z{8=6R*k9lcn)p#*1ZM~jJ_uNJLV71|C|Dz zfk(vpCf83LJZc6;4ZfF)b}yGK`BKrYM~g!(@RT*=;FPUo=jcG})5U?hPtfCb;|sio z9Gwm01MQMUo$qA3(RcdZ`A%)PzjeM-8@ro|3!gmGl1IN#cjf$aHThVhS7O(xk?!gZ zh0Y8x);lTRSkzKr5c7%5>AS0_;T-hWiRiCBFZ!$h`R1ja`m2e1PcT=LHX-N4kKM!KBvUkCq3vg>>%W4w9f*kARCoG=!KpofA8SoWY(q;oNgdTp6HqL zzi?}JmTV&6S0*+QWZIp>v5D05sBIX7P2?7E6WwX|W8l@MzX7jg6RF`Y*el_8k6AVm z;nm+@6ESgWpo3FBaH$VJmrbPgZ{l};>>l_A$R;w~wuw9>n@Fl{6G^MRMtHOdd57|j zIsK3+vXL$Nha5Z_FB*p2BYL*kP0!|c(X+wA7n`1Wpj!?-J4fXgzi&vm=va3l4u7}2n-a+e3yV_-; z_J@Q|mx52^-rHo!P1T)rE%|!~pPm6$4t@GUy7tglK-XyFOVhQ7{yw^PD|7wI=-Q?v zbPXGAGP<@o=ji-(rHj9gaN(ouxsLpG%RunXmcQnTzw%CWZKcX>`OD*?YwMEOb!C%D zwCmQ}a+sg97Do;ft#j~Cc3lhiUIF*;Tk;C`>P_ByB%Uc49}7?I$9nuL%4UCIJxx4H zLd(8t*{o2wQ;L7pW1?mKp=CMHvH@RA%bL1)VsrpFV)I0kmf1YfZ{m){6W6$Kr!)yq zTxa8sTQ-|ZnRw!NueNaq-;<5P9e84+^7~&&%;zZi#94f?{F~yD+^Oip|IXXR8)eJ3 zWVFje?T?9;&4!j;Mm(G4C)0&b$=^G)tO8g${P37~V`gf1-uSD(kvHNa7RfvhyC1yq zSJ0+MJ*LdnLX2r+R>g#!*dQX<1{=mBZ=Hj@)x>$ha%_ByEqTizW>dQ0B@RBN!56dm z@qL_cIa{l1-NbnT-#PMbfIJtbK8U=lb2-zWlzr)=E$M~g4~;X#GhQl6q0H0~<f8^Yc^Nh6Gwf!Y;rM%TK--xx%=>=}#>o%j0X&b)W#UuUX(D$3R0dzv_XO_(G z30@++`f!pdQx%&$QvN{Xp;tLMI3;VXp}Yp$K)ENYr4(8tKbKr=Vj*vqdDbMFG!mIV z>X!LMljujelx2^3klapDWEr)$nlr_SZ!@%LOVO5+^V)Vj7pOac?A?NF(%=)16rFmt zs2N!9elbwD6BzB{KF2q(1vF3R|E7|{-OqTQ|75UHcMkH?e%X!eemdqO6U>+a94^Gp za{;oMbp~#(6SjsZ@KWE6^!*y`wVZS5NOGlh_Nl&P^K|MQVC<@=@#vkqzQ*z?^!nPDWsL2kIRB;eOM)=rhI7H?k&@ z<9DJvH2A8~%a;|kAW!aULXUXSsM~`5y4O)~>UrDFpu1Pf(;b}3HgRgb> zt$_|Xcb(w{S06KMwv) zapB)K*|v@W|5VSxKX-jM{vpfPwItx5&OW;1U(ap#B;emkF8s@9Y>D4E_;(H84KiWb zwQpPOeY@)@`?kfkZ#6z=-ztYxvc4Yw2jclI@Vv!^=QFe0SDNcm)+d~Q%W z#;Y>la`X-5d3E%SYL|U&e?huMOW~pM{@|pex5~a|^XOdRy`#6f>}$Rx^4)y)#bJ7@ zXen*2y`)RNtDwv}zrg=>DtXB^VIQu_#24T4sp`N#u-*0#oB~WG%N^;xgPUuB$KS+z zYx;KQz0c;!Z_hzuHax#CwTp*d)1bAUtOfymxS?T$dxBYwM`%UHo_dI$x*F?FQkDt)n)W z{MWK|+^=$5M{RKFsG^mLI%)y_=!rPfVC$&I&9ik>CQg^ zU)uW~9bcYv;medG*vcO7*F|e8UHI~v%AK=Hm%U?C5_~CuSBfvX@uk7Wm))my;Y%^~ z+_thW;{!QGGFHiveIUV~?KIgRZTXF4n|{oW-^kgfZ}myv@ve}cy5keFVo7@N4^ez>mZZN$OvhN= zC7FIiAL9qR{F&kLBft&CJDdJX$nj0{iF-5s)bVk_RO_d z;-{`VqT;5H@p-`FT-(QZQb_l-0Vg|O)Dhst{SIFQuX)D^uk541>nZkAH+T^*_9MY- zt@kU3*U$ce@alxspTECDxa9}8HnM)QI}A8RIBgqsWW4$&^s5`3h>t22oV=d5D!yX8 zn)T0sQxAWQzxj3(R*C!YHF*26?8C)Jf!8}{B;eH&a=v}6edzhh@yh?tfEW2D9J~tH zc(vph;dItf;B;c21iT{OZmr-n%=pUj>Ng{3_a8v7be5Zq53Fdpfgh>%;yJ)(HGZ$R zbkg#imH@tLib+wtgG0+dVeQJXClW6mboOiRg7Icd$|%7%$KnUKU}ubb2ejx6g}wds zOZ|}%K0n-dHpldx9dG*1UXFjY+HQlEN1@}Q=O;k_oAJGUiP&_v|El93IS&6w#jl9Y zcg8Hac!6Sq#0M0wCmyiChUt{P_&LG@G+)KE#PRb*!k@Lp@sI5MF30@tO8dL&Ca zU?4iEwRsmhMsAMrbLme!QgLnbG#1?{t=tmWADlIFuhX4JS*MM(8OZ3~<^`@cCF^T` z<+iQZS^MjbGQW<#%&#*Z37Gwb`E@?`4}Zk-YGeh?Zv|~T^LtqH>(PBIqg-S0psP4> zaq^RN#&W(r7Wtxf;o&$_rl{8ZxXauPvuszJ_?RSx*?1SsbT*?gI=KC+=4UwT*FXFe z^TBs{+`bv-h4NSv$qSMb+U9VVt1T-yGL6brPj#I4tN((maRk|`lQ)Xy+x#(+=Feb` z6~`cZdF?qRmAxh<(0s2i_YYnqM>gA4AJbSry;^=e}GJ} z_vEhtzp9RWSKSclM81kk2138&FFh2!Xdv|Y>+Jo(*QYk;As_7ba@cM>^b;0rqYDg(A<1;+RXp@W>Gnen~>=$!PXE*i(39Kg03TojE{obLnh zk?KtD)ZlKC2jN|2{%3S^(Nwi7elb<+mS>Fr&(5|7v;@e*B3Y$1U*UB}2ROV#O((Rr#=~i!GzgC}*DH z-DXUW;yp_}#0<)AJ)AgG0qp`i@c!$ z?CbbqU#NX?iWMtUKnw=(B%c=dA1GF4P|d(^8KD^CZP1w_XN@LYs;pQUpJ3kK7=I92 ztT>xo&mc2aMsS(qij|p)tTIeFAQNJu$J_I3CQhaM{KhBD58lW8X4v!FEIEVusow(y z-q0NGD>Qi+<9bMYoc3ljkK6@cKl=cBcmw4TWR-_mgUE5L0nb{4e!?f74-}M!4ssr= zF`Kb6O~^OkiDG4>C$By3$YVczZIX{Y&mQ}f-qzTKODkUY$y}yu;Q87AdL-1ESYU6u$ z8o1~g4BsJ(kc;X9WRUZbL6YAyNnZC+%1a%s3WUnr;~RGKzn9p$t{9x0aAt2S z2B)ihKzI;kiop>L^zhUC6no<*SFzSwW7Tt%bHgZOi!x?%IuJ7x2x;6Je{qtr7f~h| zYS)W8bG7U)t+P|GQDLW|J?(GtGSR(EUK}05vLjtCd|;jYij`unW}i0gGWRxP{x9~B+DjHIRbIy4HY7Wq8?t0a z+s0I7*_gV^jpwpv$dtUx`Usg(aJbsb8u}==U?Csb{l1h@tv(+(=nc046Tv4{F{p3C zw~Wu;&SeismbQFzm9J(1c$pJ!g4TQljUBGK%*CnO0L;vG6?5`&vNi@D*2XmnZ4}dn zA0L&ZOBLHNcAJ^%bVUwHE}FiU*CNv)x5Jy^%haj%F$@ue|5F_ zUBB?T;O3h>Wryc}hcU9Frm-%5#-1LUf{rb`$4}eom063tSeZ@oWgBOXftl>R56^L&|4mq=8 z)kO5kdFbnU*XIN7Y^GdzOg~=z^yA3FAojK^$cjK=Zrl9-YtGXch&U|-(mjk7rvdpy0f{sCv&jB zZ6rszzMpD;@8ISdGgn9d@OSNRkJlO#Z=$td0REJv;)hS$|8Bq6ea)@2r-VAjNI#nl zzIlUlUO1E!f!==0tP_Y`$zS1TIrwDW?@V2N#BfvvQdvjz1?n&Kz6+@K}2uXX-Cw{+jt5h@HmYBaM}Fkf)4|eSRb?DAPVP zpMk}0o+HrW7V~dbcw{K$!=JM^g_p_`avwA=H^tba9HkZP-Rg{utJ3e-_)wgf{kiOefp-`W{ikzk2ZsL&U6eeO!5$>fUrRCe6~$^tKQ=pe(4($vGr;xjhJz2Xnp&i-Qw4bBB*l&E-V1MJKemtS>8fd@vpYC*N zLq4yh-`u6fo)Y?fkvu(X_`A_Nutse(`UZuoe#w21z`6UJ`q}& z@0)RcsN)>%&FQS^G}d-1@x|PgUFtK>XH2{=>lge1xaItR3ICh)(vwOKRQx-+KgO^9 zz#hrp*bg{+g7J8dkYw0cM*B)rw#mz;Ts$s2{D$@nb?;oA6>Mk{eDFalFk(&SdJ|i@ zANho5vra{Ju%UoDrN|8S`!e3+AMlj%T1wDtJCYqNMwdK9U;3_uyN^pE6Log?)SYEH zLEY)$e0#CocDFi4KXa{}I#b;J2l`uMY(nR<`w#HmlGpk(rvcnw$30%m$t*K+C>vz* z@-5moKKK|ob@1vG;M;>elggffr}hla}rHyPP?%KSi~qc=-VZen~NAwT^Y-2V$S0r(Wc(+bZd?~-Uq zCx3@GJ=Ve^5nnG8t`>ifQb%;%ZsK6g3y+;h)8=iGD8 zJ(vESVk$mwwjaHr>ZlOYEHpaZ4w%eoCelZ&IB#*~mjB;9#UxU?V%U zwBAfvh^&C`?ANU~<;V)gYoQS-UGw(obwx1$5fvsU&k57*N?lAI9o8?oV9(0 zG~Wuv!wk7FO7{IP@7~(HG{s%3b$-7(E7*zoskPdpwUb@?I|aH@AAR&o-?YAad7jwn z#NPWeaElHfWSz_t9s0l7Jm0BvFp2XVy}=ptO#6Vo$J50Bqj_FI|H=~P`KPR5ZO!u! zUufSvf0KGN&);G^JiJ~N(ejz_vED#ho1Z; zI=k1+{^NAnl!`<7%8Ewtyt(?u)eAb=P@$=bJmb+$5$#E?Eq3WC ze!jj?T-g*@DbTm9C9p2M)R(CM6s$xZMK#uBW72VP=V7>7{ zr|PS+eSLN)u1r7O*`1(YetaKylzor&1lc1nrDO0sz6Xx8Leg<&{nqH0^8$;z2en?* zjkp|scNuMtqV18ua49&sBzAsQXH>Rg+Z*x@`X=(_=|@?E{*p?JEM&Tu6g!*yb?Tv~ zpVamII{Q{Lar8YCD+JGr#)>A-&m#_9pYr-q(%UIaU%{lRk$ z3umPj74++Foi=TTHDv>GY}sAb8`<1FH9`NM;6HJlQuu%0vqNtF%^$5ds%USF-!k(0 z!hu8T!^k)L*$Y0+=d>H&=A*P()lc_VSS+_zhHPhhptT2|^X5|zVCiQ6892re2XS{- zYmLR;_G!ceswEv7E9lnIx+F5NL%~Nqx&MIJQ4xQ>J&e0>*7xK-q)tTzXY#$4@5Hp8 zvb8sIGiS9@uy6A1mcS9#8wDLTcIX$_I=QpP#Z8Z9xVauU!+F-KeJ-4`6D~elFgo_e zx-QlKnGcMSr-p>KGl$9tRu|SXC!&*5LUq%KB{lty!t#M@3uXU~^z9tt{9F_rea)^@ z(n3Yk?<|a-!u<1hDA=FepwD|2`b@iYjpB`?`)t$v z&a^kY4IS{jOX+#+Ba^Q;v5{Wp<8(W33I3=nmt4G z(7Sb-9ZtP1mCM(d_G-Oc|5nQNqFgy+*3ul=4=#6iEn3rTu3)pSq%PU?Jeoa||KDRA zT7t_@{YBkcu74JC?4o0>f<-^#_b=<_Mf0ua(P3h9@{U$u{=AaDrdz8vu!b18Pf8BT zW;9Xr8@rL#kobCj*-Aa{Q%^ber0 z_;Y)>Iv9K&nyGDs&PGCeOQ9d=OE`W1)h?9=U+75jHnHb`sfajSMn2-()yW4IPHhGL zKL`)R25Sj^Gj474LGT~j8vHeF!|&0>ldbgOF5oJ~=BM#d9G1vn;+io&YSXe9n}Cbk zu|0y*87tW}S6kMg8rkgNfzqLGqz>8a!q^$~{%hVfhwSGY7T(9+fXBJZLGEVO72woi;PPY$qIUn&k<2I#GB@9ug9c^7*g4@$2x9!Iz)3G4$80&EW7#(zNcr4j;Ob zbSD;=69=px=ZRzY_Oh?_k1f8+VOqCX`_hZgjy{WirZMVG9lM}u3q9Nam9H}Sm`2Xs zU?18BjaMXLKghOk`8W2}E$4>TOP(S2Vq^s4*$eyZnU)#nGpIv2976p=%5#H}rAfh} za`@{@9fCjI0bkuRJcM1AvYQGc*EN;ZxQ2<5T1#7zEzB+O7p|B~9`1 zS5vLvbKpTZQ|z$=w-T?`jYqZsc}x3};`O-B@yRHK;(e|Ky^bOuB zm~xPX+Mwgbh@iglUFy1Q|^SD>)Q^A^U zk7j&p_^!K!p^KG)#i>TWJebGX-#q#{(<1f|cATZ?nkC4l;HP#xxasQ;-GhvFkaf+w z7dTeO(>d*~IJla73rft;3!yw(&0A<7uYwuwz_o|SV?!V_#F}{Z1?=-!t8S;>dSrkG>^LVOiu*PF^HFNEj}obI(cEmv0~2GZ-kc3XY^+Q%{_1+l~LK=S1o$ zPjl;;5D0EyE_(HtI+k=tR?4!kr7x0IuI8!x?*w-ZZR8fE@IAw>6y3}$UJ<6Rk%2|g z15?vN^;dTe73uspafOO2W)>C^o7BW=S_n?S$9`m~V&+W|=f;=b4^GeLEIE5twWE=R zIw`J0`B@X-$Ngxl3?5uJ;tJ&J(TvySjN4_5pEr-3m<|hx^C|uz7$kf8=?i;y{SVYP zE<7;R!FxS;e<_O?wBT6%>g)FFc%Je7DOG>g!5f$ZHP~eu#$(&VM*ifw0}DT7J{7Sh z6|;T}5l>pkc+d2$DB?_FF|h)+63-dkj5N;q&_)-xjm|t3S5mxOcB30QI=tMG@iOfW zeAgP$(VLIpyYWvBf3xD!_K_wYy`S<)?gaO(@; z&Ib;g?~gY618=B4=}2M5*2>8VMk+eslVSyb!Wc9*CWQ`EU;{>X8KgO|03DmPr;0P1 zi#flkagxj*7&eu zvC+ppQ?CvQ&gl4Sc+yW7)_Yu7Bdm3?a&d50BiC3fvtn>g2hJgFz$xASHed{+AO42t zzo4U7z2f;UJlp$T9ojefn$UJ^e_HpDEjQ=?Z3ugcDLcw#e`s`Zx-Hq@bi4~E^Q}cV z4L)CK!eAUQyKA`FbJy-cj9eps^EPtMag)YAlJ_9LC0Vk>F;ny1>BS z%^uG4HQ;YR?-egmY=qM&mpzbsQ5JAs6gb1s*;xEsJ_e`SXW51f_X+dxF51uC#~nWY z;?NJ=dQW%j9mI1Gw4<1Hiy7-$U{o7n#;FGU2+jsz&JoPOD>w`B5v$6B4sV4g!z-%J zVD2t;`eERidUU9Y82*X;Q@rzopjC;lnq<_?h7bEvf*awh-rjSBIV9VF&0t`p;gm#Gkyv%n$H5{61oh2rt_huXlihcrvvE zxRV&%htsRinvGpmzGmJ$9QohI)n~f=N_(Q`A$v&n)Sjm!qx7)f0XFG{@AAz_>uvvw zv>~KzanoXU8~V42Z=&TIaB#{8jSGK3z74Umnf5xq4KJo^&9DCb6cz#zrILU?caCq=@g7YwV z@c&jh{AGup^rM#Nx8cDrL>(Udj$7|rZoON0{=ekGx6S+JJb1Z*xrhCPp77wu^mKXf zV)Lz=y~sQ>?MHZi7d*Ij!MEeVk)%U;@QuJG9(s3Y@A-4&lq`n@uSZ+*Nb0X&YE)F`Jug&9KBd_tMto#MlZ&< zBu>xV_xhoF=05byQdiF$i=J7Upl9x#WJSm7ZVmLz6y~4w%+hb6XEqLDuLhe-<2Y+) zHS$>F4Ch{?H`&XR{wdqpdiTHVH-B;edwS_MbVBK+qjx)csrtRInO@q%o(_(rZ%^Y% z|2KPj_6zENOfT(jH%vk=9TNz3tUh4Yqf+$JvFN4a;`Gu|#mYHEFYRHMxo!N6=Q89x zWZadB`(MZX4%;BQn)XkSaW@D0bPncsboRjH_cPk9<1(I-<@W&V+t>^=e)HpG#}|Cf zb=~vGFWxa6e&*@FXOpJ+Jv1(DFln0KMX@x;*Qn}0&iq!{c>MfY_(7iwG1muDrm;eP zBwer>bj5aXBzts6gGi-MU*_<5 ze=sr`9g2LPe2#5W`S8cujSluwQqs;U=;5WL4m(TD)4y{p`-;QBYX)}D>xoY%{`288 z4GXIdmTalJnmbRaV?%e>?wN<((bz7s?KAN?RUD@Ez_9xx;xALK9-VkUWo6Sf@BEkU zbR+t+&i}VGeyi?fF903IjNRJK!3o$zv=6B}R%9#M%XsZ&yvn2l(5KyFuBZo71Um9X_=`He9p&g4)1{YF2m0e?tE!8m z=hC-g^tUi~pU?af`gVOwYLUNX>nTHjoIqb9&<*z7mByY6OhvNig7=-D(BG>|LK>Id zoFA+oP!yF6_9pgIJC4?}p*4r5GVG_ok?7%g=;0~S+bMSgbH796?!B(Oa<1(oeEQ+pK5kj&$ldiV*gh=cmif3#%-}k~_Hhz;mhHoW-?e7@ z_!&4l9J$-7D5pJaA2+$Sk4epK9~Zf>Cd%C&oY+1#C)z&zZNRDZ|12|(ee5%NCd%C& zJhFZ4pW4j!v9c}O$8j#4%-?3V4-Za*&jj1YzrO&VZOGl>W1HJPx(aS&r6Uad=$Jeu zcOO9aJir|EY#-+(C%w^#?PKsKzNcTtucW29y!IY!zSwH9H>@=C`NAWDHuE{o-mtl4 zdqW@le@|;3^ssm6iL6_zrz`7zYQAy4fv4gx#@kN>r*ogVV?R0YUX%SqeeJW4GdIUJ z*-yf!H`!0rr^ro5ht#JEo%3mC)9Hmxr?;``$QSMptc9}ataIU7>%#Psd1l%#@@!51 zu9@T5K*F5@E5i7ZZB24)AT>#j4P=f6p;}lAPMd{`_4>{+<;pn`zJByX5bRxU}0zll=W#FO9Lg znKZ4Tx5TAQB~5GS^|{y*54h`vUT6-FlfhZ~^(-&5OhNt@7geH-9r;JQV+oZ_10iJ@L(W z@y5@;o)`PU(Ray0m~Y+e={)~`@!}Gf7nizl{n&-+ z8uQGwuj2V#@Zu+a_w9J`;|CiKu}2RCHu2&?jp&%jxuVmPNfR$V#Z8On#eGem9G*4z z9fubmA1j+_XY*aWI43TxCu!ovy}UHWE|WCz;%;$iN0KIfd6bt1FTR^LJiaJi{7c?j zBa&H?`!C*+OzV zx7&Vj-@jY2g^bN;cO7@MR>vi0w7ZU}E!QzGaO&W8*D)@!4*8MJ<&1v|ex!S$tC$WM zJ~^m!c=8cA8@;Hp(F*{ttcA-4hcm=*ufTdqOGt+*tHF>2pgr`6_dOFPev6(HOUF>b~kR))4M)-QAbA zfpcHp&`|dme>J~HpPT3R>Qgj7zP|a?QAQi`aooKFU6T7t1MJ=Plm8_CF@kmZy$3jd zz&*?C8>@YtT@qZ5PRZReb9HX1$&dCReze{lG&)zFUF`V0WRE3wKYDidbbO=Hvu_}- zwdT@9o}%|LJY}~UTw?76?onzZ#h!C%Aot%70i`k^HS$(~dXuA=A#&9LfRy z@$%8kvg?*|jspELy3H5*&7Th}d>2^|+5C`msQ;P6Sw?V!T)r}JRM((r1i2{M4_k@m zX-j2ZrA#UN!=}uJF0nGhpoa*0u;6O^qvk2+1$fq@FDTB#ety#5_c4xFE$z;k<}7i#C@W&6#%CTxM-=x6Nf&ud}&)bkDc4xxfPswYl{F3|ea2<}xqQ z=2BThf7@YmdAY%(tql88a3p$I&s@3`dT3S7U+4InD0Uil<&{?HslkZ9Q*hgOpX+bZ zF|?QW`V#ERXIRmNH$Wrn9J`BE@j7;wwZ;~;9^O?A4_gZ_832uPW`y(I_=MokA-|Hs zYRURn7@w1HCv?>HWPCGs#lN@dq|;O^>9!Cp(@eY7cmlbBtL zdM)k-GrTrtZ|P`!P2RxgFgydFpsvNy+Vo-r*Lv6AL~wfRZwfeST-Ub0Nvyqr*d1r! zJ2hi=;qK((XkA)ybRYFcsXrdx{lNRh5(nN0d_^|yu^Mj|UhFO_o9r$fgYr3fTt1R6 ztb*HvRrnOV;yoX((0FFp@AKRYpNZ9rAA;bj1t!7P09*%D*B0U}2)2YZtyF7TmOC~} z13|&N&V_dt{wJ||03oVs`_p#t#?S#Qi4R{jV`+-@o3vR*N3;z>K{wE9YO<_;KlK;t{ zo&E@>$mGnBV5-0eW!AwlTZkR7swLQd2y7O<`(`a6211A!2#3H%90cK_u>zm+(N^?* z`J+6`7_vV9)ZnLwJzh_6H&##NfH5XL)4tX`GwiE*`s8zh?^c-eJr+JETXpYJ#n~%r z%=w<7E4FgJM>H2^d{^A9{Z3~-^aoG1e)^wHA4{z0M#jmTe^aru6l!gq+Gk|oh(4EQ zAF!qb@X^bsOuyXq59!SG4E9`F>ihm#>;b2{eP7*`^HJrOKBV<9nR}G}jDPph$TNFc z$J2e$F!x5)#?A2t$vWU9S9EyO6`}3$hT6$j8oRs3wRSST!8fIZwqvXRsdxl^+D^>H zT72N@(>S~3zoO|ZFMh$dJ;6EMbnNk+tU+VDz)#5UobAlEyLTo(yu>>{HeE3u(w#i= zG3{GHi@l|u#;(>N_~P2Dmd|4nw6+Oa zbNhV)eVVO)=B0#cNe}l;4T*jQ`!;k_2Y%JbTuG>p^IQhLMSg2a*^;7yTH<%rbR80s zuj^LU@{jRv{sdS)rEmX*f7IqVXOvU8&s=)h`aiH|6Pw5Fguh0{FOKNBSjj+)o`N!P!F6m39X3 zN^djYf&T>H)}5_-H~fGyvnit(5p&!!UU~)Tz@KqPT>4)4LJeiq_pMtR7oL%1oqh&+ zR7Q0Ua_bh4o=W+Pc)#8)uRi~hwC|BNIj&BvjkVMz8^Z)Q{n%JNJ?ycRQLKw`v3j6A z(oQGsS~pFyw&^2nT*kK==8@KmHPkEL&yjIuFXX%E>LM?VaUVunDrx6=Y0%3nl&$ff z9a_#)d#Cc#QX5{~OGp>3n06Ug`H?-MGH%-s@n5p;Ag@kvax(46MtMpsEfZNc!~Pw4 zr6;H^Z(YtKujK9r;d6Q9Z&h~jrx;(^nCw#Z{a~a7*=4CGyL1Ze<-NWF*=4X5Et`rA z!u%4gwkf-$u|85RT;j+sNBmW?%au*C3-Ua26(UAOHI^Ip>vQ*2sB* zqp%O4o6bUhkzYm*c+Lgisy8O90A~~!jjRHkl2sn`WR-{U@AqVtb&jke7$VnoGqQ@m zp>b4M+&aFTbu4}zKbH5FU`zqVaz}=l7hoM1j1kuI5WdpFL!blaZ8!sloHftvbLFLl z!UM|B`T#j*-=D>Mde{REu6o+1>IoiC(G%Wql1b0B2bgDuozK(AF=r;oG5(>B9OFO7 zkz*LoFk^k|99NEkMvNT8S`!8*T9@MGnAm=iWRG=@?9s4={q$b0>=8Fd4*-|?l_WYE zaAjx*bG!DstD0nw>(cPYO%3fBZ$(ElPMX_0o=ghW_O+t_PGN1IdSy)ZC}!NtkUb)O ztu?bcxUvWN#s59|*)(uQLw)fYFg9QbV;{kTFQt`eI}Wd>6d76u(6BME`{LijgO_{;ni+o!abM zv?iOg`kq{&^I#uq9?>61rsx%uC%*Usd7@WQbd}v;?4?G=p?w3(NNBoZPGJOlmT*zB z78!!PA@WKtSjJOwgOMRLC*cF&(8v%~Zk|W=gqD7pr}A8RBVV2*rAg;Q=|a*q1W*2+39MxM&W_S6{N#wm6(QvYqfI*{+u@ z+WC)YAZ|Qsu!RYK9$g8C|3!xTBRnG>C*Jopl9Ay{^6mateUnUM_yD*mrC*n6{Gv^A zjlOy7ugM2aKd)|*Z@jXXP*(EIrEXa-{e03T-&{bt(zNzUzR{S}(5C%HlYHZSkC$)G zq`c&tLbqOx$LXX=zBwblE#~dh)Ft{m)lF}bZ+hDKl#zVXKUPnMeH>|$Z;p4=$U+WqGR zf+x1yR=yCqsRbX%d4V?uwY!eHTCQVd;Awxm>$suiI#}Pb+g-;`66^4Df8MR#IQNsq z`Ka#rHZ|R&Cw#khf6fM;(aZ;O-#X+xd?4$1{_j`FY*#z>|034aV%AsB{(moH7fFVW z#&--xp0do@z!{Ii|Hx8lS_LU7y1w-_Bh0 z#{%L~6r6cfP(Fv|f7hdeqAT-%+mXSBn|+m4=nH1OZQ&f@iFabFJkpg5etJ}Jf@?Pz zhFl>VwrnH;&Jfna^SkHuG=6dX}Z^j^+Wz_ z%A;5(@_RgvdVB1^?{V_^p@vDEFxaSUJ3H~ikdxCwd&lc6at%++77-UI~3(0iBM< z_l|q5{mvbSF}a&Mu}{vkX1Qm#uxE~?e?`e1RxJON^~#)UR{iY#V4sxFop&yA#NPP* z1N;@2H!PI?`Vr~Q{y`5rlRj%dzoa{QjFpj}>n&+kO>(ESccrWsYnXCLZ&B{LksI{tWSQ{0-;jf5JJmzTMGH zI3G^=2joET+8a4U|D7XTJf$<<8wzWeGM`<$y}`L`_Q0@? zcE$hK@_b%$D{IDl{x^P{aQZ2I(eVAT>A^Xyd2#-cj^0Qt z2lmuMx1u+y{wGYE-R#HQwwLe}zmYsY9hq8t?mBNN|Bmp?k`>{Z$;7ofn_mFCcQLX2z zc6hMth>m{;`af`qE^lW(d1*J1rkJredug=2>oq4nte5AP`uOYTZFg`|H{!?i{aSEv z4Y=T5;aji5SHW3}tB~PzK0T`WI(=i6HRkY zG#o$Y_G->u*CWLJS!T{ zkPaO`&0O-*o+M3k;SaGiXD)Ph=fV>S>781b3lEt-X4pqE7ak&iOouwP{c%msK`v@h zhnmu_-MY(Zt<`ZDu~Cj|t&ZIG`*5Wv*3k|f%J2tb`Nqdri9+L^4)yzAI6PuKGM{H# z^>nC-j9;P-b?U>;{9fNxI+Sz%Bs|l zHZwRoK@XDejr5@Zz}K!q54sILell=m<69)XEPK48mt|M5W)Qb}RF|f+V8h)1(#s0n z|BhVg%paWvd-K1I3me8eF-rDMx*)WO7$wuGSM&1V;|}j_(6gjT7pg}W+Q)1G*C5Ll(xya1Tb(T!K)~)luddBH04dc;OCUp+wxVlO%XXbJebQQ&I z$wgPmL038LPR8jB);Iq@3bkiehF?V~GF0=pEp6*8tmT{I?bV(RcPC?#1HU$7Qk)q) z4__+jaAqvf;mlZ|!#%>B_r_fD(F`9<(0g*wdnRrZPnS;Jr1$79Q%~Yrehx0%q34`ilc?vk zeD16tc#YR{ih$kIb55p?0cnToIgk9kWj*Iw%6fXvRs2uTbDE8x^qg*to%9?tb}jfo zy~8~EIz8vnJHEM|V`!iSAE?@`(7WVRY^yDuJ44Ueoah5J@?HAd4n1f3t|mG;3LHt# znaNrqx@vtNv02O=bYSLpMe}$M-np~UqK^g69^&DgJIi{3a^LXW*?SMdS821Yb7uzE zF+V6L=FacH^Vgj_TmKmI#NW0LlqW-JUU=ucT03{P(uGy~hp}=?I|aS-T+QUXl4PTw z{j?1@rH?EEM%kDj;o07^4xVh+TFjlhTsT`h>(ES&15WK7o+&sFj_-D)7bwv-@4i7@RXh2({UBI=UbgSqfh4C8GZV?b7x&5&bhPWUAXdGm~zb% z|9_s}#aV|*72ocx!^E$gwdo}AiG|8(uLoPOM8nn*-hW}(%@m2(1xc+ zB4dOG@-BEcq^+fsbe$5%+pMs1X?RvtCBYL{L_!IN3 zo4t+a|1VzrI69Ed0Ke?QRqev`SM$uY|HAXT;KhL%-;Nh2?>v+j-v?~6HQ&!Sj~CA) zO}sehrp5E(*``kp&-&j6hZoO`m1U2a@8ZQX;?iy-O}zMaFO9Lgi8S%zo8!`cO`7=S zR4)x4_Bm~Md{Ml3Gw-eO;thO@=f!{H-Q&eC^IvsezMS^Ni$}-OoPIq=Uaw7$ z7oSgF@#3}2f%C~9vz-J_Xt&*CFFd|Q+sPXzx4Vu{TdreeAlR|pb-dMb9qd2%Xm=g2 zB-YVh+euEKne8Ng|M|iRtT9)&fB$*w{f_OV&Hd*gEyTQG|G5V|s9+m+t}y=Q|FSHz z|7`wG$_idHC1!V7*^=Gm?%UB5*?%^?tWWn~ZGzp!+kbwSI3=y^KW}ySpFhIC`s?C!;a_Hwf*ndWk+1%3pbKoP%BhBqF@%ztD zebL+w^CSAB{pZ17dipi@QPSu5{pZujBN{wCmdCNn+`rzj%RCO>IfZYn*=3ylij)@Z zGPjh0k9OE)YTj?RU8Y$)p#M}g*=5#K$KN^~YL_|V<(BO-dnxPLW$O5!V3%n|o01<^ z-WIdVY;Ngn8g`kljR*7t=p+0M;{h3(Xu&R1@gX$Zwq53sctHQ#LVw#~m+1vPdG@;} z!IA7TxzNLtq_?UIu)o!8FRLmQ|8DFupA9EeMOq;QgUuQ3w zI>O_fSjfM7mU1I5X^MsXa4WHpC9B=)mR;u$?xv0#?t^F3=3eTOe|OB@!Mhg=+2GpK z1^kX(CLcUUh?5h>M&8)@KIHTi<3#5Jm>pq^tU09_H zc>DB`I5@G(H0c7sIUSv)@q^aklq^zU#xc`AgQs+XSiRWwJb1SEy^451R}%}FdwQHb zx8}OQUKgiJlMS3XE}Q}40mbTzgVW&C+g}4t*=61moXd!XyaoG|;tGGnSWU&Z+TGi( z!bdo^zs(+Bn&8Ivkz(NQW+(HME};Eo&0XD3(>T|PUc)}N;t%_DW(PVm`}W{c=X<=k zIf{k+q3+G2-rb9wdUxpwes=PdpC$I3W;~#tyJE!${&*|4^)z>VTG7M!T9;|BoH9ks z!(#UHx6`j!>}2|-J{GBu^iTboP3)g4on4zs{5sZE6Fd1~#~(b>_oz_seP*A&#rE%2 z`;L8hbAWw%+Ih}r**vWkpVkfhYZ(=7`lsK`IHU8jzKk?2r zXB6|AyP~7I527~D-Oump?&s&l?dN~excU@#Z$bXG`~K&wX^w7?Y0n0(bAe&b=dQj0 z?01l+^Q(7~=Hscn$GT7HZMX4VKC8ETW!M|KiL}#5yV*^P=@``aE512$d#3&7-y2Qc zzlGm+k;FBFB=D8I2Y zW!it@zx0KRz52*MoHnE{oF7Yb>Uom9iTc7|(}xUuHS=UJ`CH}Jak1-J%Qsu$v_ot+ zUhMiie+J)$j^zK-Ccl0M{!jrQTk7!ZJoec7Q6n#1rDr^VszZ+JIBE@G3CM|9%tCMB9xAPh#wP z?C7z080Gj#B*v~^<-*CHW7GP_Sb1<7e0u!4#NpQy1ZNv|^k)2;b$5~APRBRYz~9Y& zn5X!4Lz?xCV%Ps1ek~ivY`5N-ZoPN%9K@W6w}GpT82|k*=PBSl-z0WDYrwojJJQL& zariI%b{;wk_onv(qBDVk@dJ%VRz zHk-qVUH|ayF8|#I|9uDkdzi87ANuT2n@vAplg%a{-t6$R-gX{oLr6Q$O^fkU`q$g^ zNxZ7JUH&)6X45lPHq*}FyKFX@acNyilg;KxFO7OqNt4YcEiSDiY2uTeyfpaEblULv zp=>ted2h{Ta}D2`cyMv(3f>(a%-Kx-tL`trf!EL4M;so!J(lM5YdCqmHa(lohvb#b zW)!^mL-IG4a3|`BKnS{-7rW=FuNAsbK1o^DnjFa-7O@=0`+^U@h~D!0&``Qt5gh!Fn8Eqr}~lI z50211)=B0b>uKAeFUo)U5l?6_b{~?T`;e$pdRu&bw@}|_T9@UY$bCpJL+9RoNZ)s9 zWD!rv{=&7<8)$o&Y1<0E<;FTW3S2xaT=;$9!f#^A%3t{MD_A3tN0!T1868PJrKQNn zikn)7U+TdTCHQLl4D9CaQ+%rqCfsqXHWP8X=Xv`6x`*3=!6~5w$Owv?N}ny?j#B&- z-+UMvPq79GM?)Di-ILCFt$CW`H~j1DkngOQ&pNgkc?x;5rXnerg#6fez7?&R%RQYH z{uOm2t>_gSp&NZ?o!+W3=Y99pLqm0AxZn9Y>FnwDRn*;YTX%a-Qs&$XUVU@p@aY>D zr1-Kn4)ArGJ7MjHjgx$x=l){)rUjE;{O890zSOzrt=O>f4}FUMHOv>-81SXd?a%kl z)7LKuyt--QdE`$e&j8Xcpq^nbuHQI;{Aq5!pHolStLt0MmrA}9DLafjv#Be8#fAm> z)Da*pfBO23{b&=P%lX_L`E>fJvmeqOZSrZ=US|Fq&?x8K%NV1`2+rEkZ^gXTS+jGW zf^L@$#RvcIh2b>!?k~=3S-ShHg!`>}aTYOl_g6)s&Wy=7u4bLDGM)Cq1O352Ys|ox zcMtM`@$92>7xF>wLiX-Kmd(P@nBNNi$fd2{zza6iLeI4GL(w&SHAdIck!f503t{|k zymr^o?$%c5`nDYo@2ll$+5)ypVB1Fi?WCDIj@|pq#UGscI}l&#fc?&L=$W)~=*;J9 zqO}5Ot%!4m;tTfg&ApBDGVw=VExLzx9w$xuOc(lxPX%|5WtuoyMJAT76+HMl-`^<- zt?yv1ikzapyi%yU?KNM*e*AO&)n}D)C!gw9|K(FuhEDZo>NR(cbKkh`AeV1+v+?BK z8;z&pH$}D(^I@A4$9T&h8Be#JTI6)qrM67H_#P+LxjLyRs&(EOn+*FA+SOR5Gd7P1 zXX}{v@Tj^G-20w@vpKEc?6Zfk^Keh8`gASzm5=iUeVoC)Xd|#uhtdxYfIs3JTsMOL zt@8z^{k|cqS^v0K&Gc^_{Trz}*qr`7to|9ASX(H+7S(fTADuddGp}FQx&8WpIene! zm;a4}oI9-_(;2_kBY>le@#*zwLO%KRc}c-b+&+r`#M8yI^s&h0LB~-yK1lO!`4RE) z{yil67IKKPmhFADwDS6Lf<^k4lNOSZ_*Yr@38d=Q}v%nld#DA~s5YkkBjaMFcE!VF-+*dTp9aGG?o(5-`c6Xjv zdh}h?jr#!Iy9dYng6BZrwM&PEHej2v@b}i8W)W;fp5AzVA|G1T(WP5_!(Q*ixF#81 zbiBruvZjvn5A~U^8*vfibRpw)0epq~m$A8Md^4G=k3+wV+dM1m!1i`dqk$s?04>A+s2sdysyrAo_UU9zYR5b5pS&>3|_=!fw75?^o|bhDNITr~t4 z6Ihl|UT4Ou^aPGadCFIR{r<+)1_t_418$4t<6iXr-~h%b$Gva9Be>(-t+`i-7#sHQ z+`8`JDZN^}Lb`8!p1b&V6L)f|zZJ?)o6~t}t#ahGO#61;yYVi5>ZE1aH|<>AsTaeQtUd=~_2V(l=+F zUTN0pR`~k0E0`aL!PlAZUk=IX-fS(p`ZZ@QDud3&_Z8#MjqrU@W}3wuH7dZX;e9kI~u6D=ga?(>7pW(U3I^$E58!TpAG(IVelSRyc5C7sbca3;s_1X)pr;O25 z${sRCr9GOB(V|zsn=!hAw!Y~YP5uUBq<9717!}aA#^{G}V>E~~jgie<8l*8gR7Q*O zuUvP066M+o#;4qs(dw8><#!c_KK%#u1aECgKFfM2CZ9QcsulTcp!)j_`OW&Y(d|Sj%mond`9;=!?Qn=|XVZ}r6Ac48H0CU&1} zeYyI>p+Odj(i2$s`P~R!BJ_dy8B+p_i=&yo`yLYQ-DdEXXGsV$bzUpIi?wPO`)+R@ z0na7hIi%|zZ0)}(&eafbw2SxC;1QA~*Q2AAvX?QIvtw1*CKh9xkZiK+>Z0hbQ_wBJ zMR>d~cnxxmXz$0W&p)JK7IMAh>M(mIwIdy!H0+;ISc^VdbtHQ6cytnME-}40&W_Wo z+E>Z_nzqhrG~?lY1BQo3Mi7$_7{$LOH(n>&x(*p^#=62<;ED`(bwkdgM39xk;KzD@ zXf#c*0jov1!PSk#15c0}`gS$-@22j^$Rk6`b$$-KjG%sR&r~#2N1GxKhwM-PcH2WPZ_}C(cXCa8A%>ePz#*f`Q;BiCpw(5 zR?T&<$N>u1Qkq6vI^quY0`yPJptV$GsmEDVgrV12Mh_xcSQ3k z(FXpD>z%u;j4brvaX}j&9m$?4{jAUi?1K3Sb6 zP%@EhAhnIY(ClZsR7!`ZUc;jfc0H!PZiFvnbl04e;OX$QbnJf`tKp2Lp-J@DbNOFG zUzMKAd)Zg~&pSh~Foyo+Ca2;G*^hl8X43jZY*1my##7DqEi z6@}7~jg8aK=%+6k zrY{+G7VRL@t_UaV?rbYK`Ktpa7K7TZ!*+TQJiG#9|o5^=gUZ89;9*yeacbR8qsk|uC>O@tCSxFQ;)Es$g?Yl zzmXYC$+V&y^gW;0n$V;v$G%gW<^FeQIoe)ng{@$P*EV*vHtSe?XdQ~PP`zU|*RZ%nYUi??&>a9v=rUe4>rE<_!iGhGmZlSW{%9{iouzq4SM_H|B7LN9kjau|`2>Us}}#!M)pj!3UPM zEF1pgKJ;}X(`48`fF`^$cavZ8PgR^O^B3}3>5^qK?UTs+Cqt{(?FYYm^3+H_w*c*Z^W3f)_H1@m-FXW+%ZWz3P*6zyM($*`s@?rx2$JK5S? zY2-KbE$W_jsqCTGh7N3!E_e;NxEfm*=jlo~f%&xhAjOz0j6|C<{-?0bQV1t(| zz^c;BoW@MDjA0=78maHi`l#C2@$|Lm z{s!bYVjEK)Ic{^j95)I%ZZt4Q`hs)e5;)7pS;58p)?zb>-k9dL9F zX<9S?#eBGibi*scKMEfECzt;Rn)Ah4&4niZKW}))qYvT#P9258qr5s2)`COoc<@l( zYGRRW5ua=xi^SuPceBTQEPGYrkF2SNKQ7M2uTFEQ#Bb)1cZ%ujT+`1$!6{7|}*H$N`}zrtrrd@UD#9AEYW$~t`Q$DspT#Mhh{A_s{f z;>8ci=?y;{&72}8s$^m5#ILJO!Ms$w&C%`Zc>n94;4AQjGVE@NyzLZVx_=1wu{_D# zJ=g7X3Gs|5ce(mZx#g7e^r1b}-P)Xb5T9G42LV_7oC>Kw@CwbTbnq}L%DsSQUODkm z)JMfg@%p#nzJ{#2$?#i^f%q+Rw%T_1?aKzQMFnO4*7@x-%#q!ce~vY%@tsum0J7{^ z9&VTe+Q%{L5PiJK#m!#+uV?SW;~n7{bC{QN3uVh}YmQfHzS7p7*MSu{<-dEMfwh~x zP;IUoS^&*3&o@%vrb5l_`fWoC!lU80U(G5EkA_cvwZ8C{1RgAS?~mib+5SU$@JR9q zucQ3d>KlN=o4z7m}&piJS zKD=s&GiKvx^D5ek`~$v*ty1*n@wK@{&`U{4!7#(uocJ@QzvD{^!ei85)`KzX@5Vye zwr}j}JeyEP)Rf zvSz*?FPu$;HoP`%-r(zT_aI|7F-u)83vl$xl9f9D@7s$BHaF zHv%qYig51o`3LET z;Jci(mSBi1Yh7-d7dN-w1Eyv&PR`M0ZoRhEnMckXl6}Og6t8ZQVetQ_ZOx+}#O7g! z{e99T&kuCdgnP}SUr;{g(*@l9$R~N`QRZDg@)})`^Jnq8-68VFi-*b|IcAR?x_Z`^ z5xAqMei(D~QrfrBpSo5yWE~vyBJ}BFUM7WP=a8PTC@HXmeY#N*=9>Pmh1S#GED9~h zZc%3Dc)D%*2EV-+{cAC6^Ae+L$=))Ay0GbtS-1SJldTMuxep(M(N_7tZk&OQ&ie8z z^>KA4Yvwxzz(wNSjKkcWX=#%Up4P*x#uJPTZnIKlYU%3*vi_m z<3Qu6wFeqmFMnLGa!dHOopBq)8ak^>#$4e}K4iX~w{MAu>jB`3f7g6eKcurxr%kUf z_fnte=SSdQx~9Ha9US}2OzKcM&+ZlAyL_O?Gb-MuCEADpPj*LZXD+f`DgD7FG*33J zFYw{QmJ}^lKi#zLN~7-<>*?q8W$M3*LbDQZKAkc(#JZmm!?|Na8wX6P&#UVlw=VB} zi{5G9+TXZJFfPVFKyb+Z_Rpt$#&(;-*r@&p{T4oQ+4oLLLDmG9!(Dvr(|qEaWb!g# z(0{Kk`4p^i+bLqd&`V!MntTIpWX_aPzsfA9-`;nXd(wqh`0&!7AWdWN0c~DK*?3wN zZK5jX^>|+)< ze8Qu@b&Vg9B&0bd6Q>Xho9sax@g%~_?OftUt#t! zhyihYa0#?Bq_lT%I(E*!HO@YU?#ENVV(SX~8E2V&Gb^~UT5~Ji?!;KmBVXe>{HD*h zuz%yz0ez_4dhoy+vpFA})aF^C2K-sVi@?WHA2L9O?cju1(Ejy>HS(20zUT+fF#Jwu z!|*MWKQ%g{@dwS(Ifl=W!xIn&SP{_8E_ zYMzU$^&dK8BtPAKq$SeXQWtOEbMf|b@V1A1?V+=AD*Jzt&KA*c(b+<`4~|UBTxchq z{f_d+j~e=z;Nq=4bXM%*?vIK1qMp$%zCLDuQe&6{zHH&E4La*i8PS*MO!Vf`m!Y+M zXia=8%$dsXiqd0LpA+*LIY{fV zY(BDCD(@h^i+^q83U0yBl0chESV6%0#%Z8ymQ)n&490jO;kL z0^K>6oP&OXt`z8QMMJcoN}gf9lug;W*3Pt3=RA~sl(lmm>qCF5XwBWgagVR)nU{QN zJCtU|R{Q6a$@gV%>c8{$`S~eD^BeuCJ4(3oX|T!?8?}E~+4FNL`*X@J;;tK|jbz-m zQ}#1{|MNR_z6=eWRQB_m??vXj+c)i*6}hiHWcyO>MYOksZv)DH{)4;uHYxX?4^1R} zhd-tNVBnmTa{HFyxtktJ>s=I8dTMWryMVZZihiZ!=*-cWx6_U*4s{+>6w3FdZu~iC zMONTbcklFnE(mdkWG?4YPV{vlEp6^>&Z0c|;--x&roXx%?Kt-3$)7UF3ORiY#QG?E zNm8_NRND87LtUu%l(Mq=*C;PsZl3_ir+D#kp#usz~>Gy!60V_6bob%#FbG9bLxt@UgEtUKM&h-o+zv@uC z{mG{~(kR3EA5%w5`A#HHK6#aoGdpu9(thC84I9s=t_dqPxo3J(&6%DY&h(gh#9a0E z&ma7Cpt6ej`TX%IhPU6R_r^xE@2@%g^sfUM&F1Nw{e#<>ujBg-2tL7l{d?6h!B5=z zx`chZJD|_kS2WF8#VI<7jc3njKYDzJknUr0_*%d|_}h-sF{aFA4ltkli$96?ygLb= z!Ct~{<~Zv|v}URJK{xv=H-8#(#|@YILXHjVY~$OoXEf)-N*tdL`Lq1IKB+QNQe0n~ zU9@IDE`Lp2dGR^bp?w4C^R3mj9JuR799p0F zj@ff?*9wPkI(0ov8S$_4gIZ6))tDsg6b`PmN3Fhy*FCnE{!|pj?kyV&4v@b%cOhP# zO>Bc~Wa;vwbuYoE{N8;m+2HnkCtvVg$_t;8pQSs$+0j`egm2+p{90!d#ItV@Oytox zDMo%RGJoj_zL5MAJe&#N2geL)hV!m*IBN^%0qT^k*g0qEoR^z+Ps73+-7%F+`!nDb zE)(0)-3;2ZP`^L_z*&Q}-l)u#lo2lL=QS*x0j^uer{BhJ5jym7w!*S6Ou+48aHczh zh2Q1L)@rSfTcJPaJVr);569CIa6Bym$E!LS9M5YB$GyREHTJ2)#qpm6Ydh$=B^;lS zfa4>mt0f#G@2s?D4Upcpc}PxnFqi$wT5v5}dOZH`O~8M2kAwdQ!2hwre+Bg1H3`21 zKjX;V)+6vW_xt)!=ujM*dL+6;fb|6%Tz_bxzmM}Jteb(`ixy17u7?aXYB=fA0bmRv z$Bv(E zz?Zox+te3yJ;!%0fs_?cQ znydw9X{1L649OqtOWWb2o?3ru|M>ppA%j30o2~Nf;Mvfw%D&e^*<5ti__BgQ_ja1H zMLEIKC>xlbYHx>U3XX}uq%(;4o@5@$wqy(IF!|srZ zPM9RT99mZQR2ld`%L^`LJjR#ylKj2-j;fsCR_Yy#4_P>`{H)94=1>IMUSwH2w?XS# z3u^s$KIG7n{9rpk=K<2J==WXv-T|%DGPg}1IK!Ga*RB=p@jO&JDK|7NVBz%g@eI?;G@cbYky;EjDt>ugh-$bxC*mtIbL@pN|sb42sT zqq~;sXg*hZI&;O!4Q>S<&6T^~ckEwUC(m@&MtkMGj=t{5O@?0k|301Zr7ur5qgThK zFMnX^0tsc~Y{e=hSlQQGG@5igR3EJTn15lC$6m1?%yZr~y9l zLdmka%Ot&PpfU_DIXAMZe0x%5RVV8V^~vFvPM%aZPbu*tZz4~5N9&B`$P5l|8S3f< zXTx`!*8jSzi$nJ#b6ml`-$M5Ny1V;+Z?o^W*WLFEC+zz@Q^xwuev;PbnuLA7C;3)m z_WioY_Wi={zTabflkNX4$}R7b$(~F`Y~Sw@zF{vpB)-i3q~~ClnN92o&hV@Z+;eJh zB6^i~7uRxlVSw{(rAg&yl^(0T(U$uuJBxhm`y=0&wW%~WSnU0;&JF&E|K=>7drnfi zfn=DmNxIuB)86!Ur%KU$7(0~CRCm{$+cGSse-yLsil#IdZf$Hdu{+E?zQ(4TVee04 z{HW)(_d8XZF}Ym6sH_ul=LZ$LpoV)_%(!#rP~S>BDW=BXNv|#}P4)ACZQ)k#VgWAx zuPYpv&6E9ESsI7SJKj>&iRwi zkWCyK&ahuKaHreGj`?@$T4XE5=O}y#zl#C*tKruXsTdlnee#^p zub7vrV~}KN+Ujxp+0h4$&s-1NPnuI_5Bo3FiJsJ7^@Z_QQB1Y{)OiAV8ar82a*wb^ z{Tmp5K)*!Ox?gWF_n4NN`7JwdH~ZaG&d}!#4GrdQIQh|p{T+0UJbD%QS^h~ zD%NaU@h3!6w;Y6~kfFRgw=K~XZEiK+yV>dZ^r}CiIbR>Xt#it8Uuyr0RTf#tD_e^H ziz#dJWZF-=WtShJ{SACfp|>(%_k5Bkx_J2n-DxeXKW@3 zX7qB6;rGO2!OzPNI^$dhkMqX)1is-fI?uAQiN)y)E;$nXTsJht8n`Nq4_xF-WE<+5 z@H30~=fn%y0^j1C^1LAy=lv;Dr1&F@*@u7CIoYA1^U|! z_pm2PRwf2P-H6t4HD_)^mgvm~@A3G2i1tNGHPFBGjK6+G-~4A6^kYpat=LpJw&I^= zY_%qoZkts&cH8XOox-By8yI8x4VTUwvSM6z^;weH#~o9C*0}WQvr6xR7bTahD7_2b zL%hb)IldM5ke9i#GH?|4ooBFDuJaV-f#9DWbI$e%SK@om>l_~Oe`Y1(_^Kux|AxA@ za%N~qX}vbmU(7EVmED>mK9v zfpHdY$I^$|yo*D%tdphOL0Y?jI{*cnp@VMFL6%+U(m{Z;mtRi@S@te?ocPpEo*C2? z!B14aj~n(iZqC1?ALkOR5Nq$s!1TP}d5lG*FSd+4_v{&a#I=pY+FS}9GXAr*uHYN| zA$8Tgb7^SLB79poXY(BCW%zb$u4RnkYyvSlyI}({_48<>@F3&_j|b^aLeoZWa`S#rx7XH=#~T(7b^Bp_iNRU9 z`oX;Tt)8OsutVcN>FUxrZ8oFVI2ymt;6KZr?3HCdN^|-$m4(*VM`Rlpzj5en$xhPY zH|seI)E+v!l6rsU^{XbKU*rAs>xj^fo2=++`c*_et-%+#{Ta^F!tddD=x8Ez#QHNY zaQwhvEplEFv=ksd`YdQGzCg8UvFq!cm+7xYvw9^m-+hFK$D!2i_HpO8Q{pW_s^y*`b1REJmewl zX>+zERZ8Zl%A_xDy+=@IJk85*PJCep<;IIPvRE$%7O^kp$O~m%tSC0I=uW;h7=GN- z4wLsb=9Hn`DEt_nYVcW|96Zs(C+(@;lZ8+C?yMb+tM_4JiD-WC?e~9kcw7o=fXCys z28j22>%gDrdwbU{;ot?}l76cB_ZFIV&`Pp)2ZVf+I$yWt=D;6R~B9SWaB9K znZr+}w?6OQ;ohqI%)HC8e@R_?CTksFtf2o>*D+Qji`E3>!yhL%8ri~)RXCZpw~j7a zb%WuYeU&DJE@91$Wt(+5r zuk&vHm!A;)C;#O`W!|fg4`%*5PRC(v&!P`!@ZHgGdfElN7suYS?9+HpjlK7@Pvu=_ z>7D#p_DQ_=_1>YKeBNbS_3AsG_g?P%_3USew%qmO(vN@Q>}^#tZ)+A3BZ0Yw-nc6K zu;Z)xzWe=dzUwTFQ)j?Fk~*8tWo6l&d2c#n)x!?(eq;=WZgvOWb$-Yx-@~?e*Zzn1 z-Z0C-k@KEq*YmD@qF>T(J@{*^z?M2D4H>;Nde;#~@7m?+T7k#ULGQ9`cfFezs2LR8 z{!)@zQ@8g`3GKiJYxrhKQc(A@G0(Yk{j}ism$>WQQqA)Wdk{Y9itjU<{$Kx}qLAjY z7w3n?HdKXd7efAho3%+k$@j(iB+E9j8rwvec~X^No0tm@t6bZ};so2o9ei7y;FDbC z+9q!2n`{&EZ;Mp;n&ceh8Z)&zoE|p<;;bY)a zb4@ai4;t29;+~K2fkl7Qe&Sf#Dn}0Pc8wL1{G+-EQWX^*Bm>3EKULT@s<3OwM$;M| zs^AZacsQ>OJPc_A4`;e~C}X`^ul*O}JKJQZ8OZm#5f?%m#EBb&-J!yn~4*T2w!OCg7&Rym^VtVVP7en=Fom0>J<%sRVN!nhP?@z)w*JAF4$p4 zfKxwZFNQvyG;9)X-fHr;NwZHU&}{K(tvvuzkh4#8MyNb3% zvl&-dA@uvrW%O75&v^tn3pw4RSq?8pMX#dU!=>5Zw}FTI+Q7rTE*@H=*}M4O7R~N4 zG@D`P9VX5Gih4z}LtQ#NCV^&`fK$=zQtI_+_J?lXbn=E98&`6(Zg68=W0u*Qho8tN zM0sUCBg{kFb?`>iTJ_U$P58~caYE*+ck zroo)MqOM_aX`vrEY0HUs>E$~x)JY4(rR^}3F-FvJ>qbhK6v;j9T5BWru(hT!$;AHv2U-s-)7Nw zgU6hcV&DGmev8M!qr`JmJMlPJ=;A6K2ib*(;^0gdf6Lp6gX+e{FRhhl1)-^|rWiJk z-^-uQZX2KRF>K7f1pWmz(2{%sWMd7@rhLT^bRui@LG0w74}k2*>?7k7F5O_d6Hl9U z$#V7_=Zz1WeUy23SSMpUcJ@(z=*|@*Ly*>Qmt#A=7C!yox8TPm#IdoEZ*x1h`wp}3 z?M}Flt)jyl2c~i!drVi>nxyej z@5eXKj#*~*ST6}3n2JvVy7s{_Bfvoi$L7fRhL;i_09{k{4p|Frl@zTR7O+l>utwFL ziwqn0{fF*%Yz3$7=9|i}ZuNiaHQzG(OAb7G2j53GeV@+S z?S8jc6m!Ng?%QJ7cqwzq@g4E2@R>2x8hQrfSetitD4#vMGVV#&S+>0cilW9Jg{R7# zO_@6K&Z7V9!3OKbV4t~~SVH5SIKTh?DQ9<+i&tpf^6(?Qt&V$yTEdTqPn8d&w^*ee zO&p4?eqw_md zGEkh`ZkoO|p$^SQ%fheXdnW|%-PM>CdnZ=h9Nyh|^JQTA;C8n$E}@N9?=~q(HFr_% z@z$2|Lik=FxNVzv7ZrYXyfL+JNLU7+8>A=Q{(XLoyc?Yvml?^)Yy_vY5Cp z;h7hQB43OM-GbgBoj`3b8Da&;T-vy>fxgw#=H9Nw(S7N~(M4IDFXTLQ{g@*{``~S| z%gO&};b)zkn9^oV4Fs*vlPc>eD?YN9^4aVkjb-0vKmMP4;Zd?v{KxeTxEnt4e~3Ht z_^7J$|KG_#GGTE`$iiX*s3h2G6$PT9OafLGm9i)bC_z+$*!o4>ttBB?z*J?FN~^5~ zv4y!dRV!4{S_4>R(TY;F6x5|CAjz;KzxU_ddy|1z*@z;eGFd!`-o$^PUn2}MV+dvQaCF>^LLTI z`T((Gkz0bXZ|zB57J<*s(74Y5FZ3&NeK2-8&(clH7Q9?ozTnS=3pmdNAAd}3sIIaF z8+gC5P<4BCMvxK4Q7+=|WnZXt(Ma0k9+MOwxb?-#7I1a}HiYs8cX1aPXU1ShZ#>oq zzJ0Os1q*n`nFS+!wBh621=;NapSzE#Rz97$sbrQ8yoeX^nhfOqF5=u`1tWxKQE^L`=N(l z(%!SwS4aDM4g}X(*m#=glX&D3;v6>XoEUV+Jvm8?W74|e=#FodpeszXqp z`7HlnKEA;yaYhCXe}4nVwba#79S>4R&86+?!2cI!9Wdp0_X?T51IH`CA^3Ebjx#>J z?D33G%=OjQ5XUDP`Xl*?7Teh+J%(F7B+2DY?EJ8o@x6NVA-SV!? z-QAjhDWOk3OIkMUpRUbx5;Dik&e*{-?PD6j-IH-PF0JF#S4(}n$g}!@Q>Wnt*?i+X z4JWRq=fHn8Q1*qkvZ5=MUD3}ukLY`{pFvl7jEU$nG?o`0%{cV3uL8f1P>*oD9$fBb{?Ekb`vLR+YQds) zgZYDR+J3N}{`k)?*n}NCwsTr||GSstzs<5IQpav=haK?=!CRH$YvmQG60xz73Dw99c$R52T!5p#J30pI+UK4SZ?fWArY^Uxa*|(gxS6>~Q_N zE?lgSw|a2lx4g0)TvxepX@2JIcHxrm61e_@&0jEUe4{6{!KLwiMEGYM))W7*n|b*G zF-k404ZFk_p6_{Go@>ch+{nQQD5qv_`CqCYv?lZ_H7x5#n2==q7@1JMVbDz3@>eju!gS!97JFO|T@PeNk8-9*m;n57f*4D9+Kgy$-c4MP^dmP(lAavlD zo-Z%O(9EHg(9Fzf;V5&lan9x8eP0A)?@_;aekM5jCH)%AvojCm*UYm2y2qIZ^3xxP zn+G8m58}7twfFFxL)qwvWZ5W}I=cm zni$#0{9~N@BR5C324lBUXKc=NVrG$zSWm|DUby%8c6O;1eu(;~_)iM;z`oNPdrvdI z0|)+I2L8ug_@kUH5--EqldO_rRfaZx`b$cO9^ zOBY-LoxcQJg9H~apP`g}e8y)A&NAcX)~I({)@uET$HSH0I3AOThaBp8(%>x1?(Nkn zUn+Gb#nl=8hkQ)pj}Bd25kKVI~~01o>Sqz#Kk?aSO)ihT>$*zBhZBWn!ms)c?86u0@#nmkTh>bEi!$bd z>q^<5(4lm|6BA`v~U%^eoJ}D3d+v9~d5$W&a=F%p8zE6c{f_XkJzfhlK!~*Ei<1L0R@qvy;p1XrSN!JvA6kYs-F_-N{KGDaFPc+NEka|YV z4?gfHydjKiq54j4rSG#tOYnz!b&JjoUAwaGn+F}Ce-GF;!4EuHasBUFCM^YSrIrE|Id4# z%d^q3w6_QU=pvr6#if_&86Rl{&+?I)XMCiuz3JFfu!F;=v+TX)&i#Yl^QSytPJZXP zr~MJnvh{f1qdZHe@t!~6Sw2zo42?y2R^Pnu@AIsEbb3a?T_buFzcap}1I~USbmTRW z7RNXA;N{k`VdRgpRylP9?5)%>G_KB9d6rMq`QFRk$n$qvpR?_kc>b3AtafzQuvgb} ze3SgKSbIT`J=XA?-&!`yev0QltjGlZ{$un_d;ZoX`kKt~&F6pTY z`KDNk{m`H2>ag~pih!{P?ZX~qXd(DrVtbN9yDMCq>inee!Hr3wt)tMD!F>R`Y8f#u zHpr z8<6hdOLlEQ)HSGV*j3WWcR-JGusObgo!GVeRAB>JjXruiW%uvAEPSKvIBFj|>Y2mg zXH(nsv7#xm-QcreEvlt{%@=RK>4|<~yy?dy=!6-)tuuZ@-ktrdGd?C&zT2(9vP~yi z$8$#R+?Zf{`oW%oJN;=bI=4%D9_>l~PDge%{v!EO$aiNQa`!~mPvma#fm*XprQ7>i zBYZQQ{UIMoRwwTb%B!*R@}jRA-fiMmlS3bNrayBo3(LL}n>r*mefUwnM!6qVuYCcB#&H6MTR8mtf1b1;1!oyihzeUhfZ2!&itttUk2r{i9Pt zOW^Sj!h_!F*Ds`Yjo!X!1oa1Fhh}Dn_fG8@&aJ?f!@UrFEAA@H<&Fl$Mn+j55A0y? z8~3K=>aIeK4ejTZKx4BwmkS$CBV&YL$g$yYPmu2UT1^aA6kClMU&dN<!M<4i{?A_9Sb|X>^mlginf1yuS2r|*>^r9M)#8`;Yr}5VLNyH(zh+FU9laP zh4o)&jEcuSLfd96Onhr{XrVh6o4(K*>a=$g4P}^2Yv)XyVxSJ%hb~lq+ZLY?*4sc6Vi5UAh*XeSmy5`U*$a8;fl*I^dH0+cbY@ za~^GWG`43lwz;FMHD=v*Z8^Ye##!TO#y6?I8Q<&ZcSm*frH-2Op}#iz*cNbYI;Q+C z&!*GU9uFL%72R(k`o74;`)YWRhj;N}gV!p>W+#VE6JBRBU+`Cp#zo(s90r!=srYb5 z933pD0gI7Iq>sE9CkL+R9NIHK;Mf*cWrpjKLro0K?#`h_51TPZAL$&LODwwV{ZaT> zu)h_WR|O5tyf_>^hP4i!b>M|yOnsH?^L?MoPoWFxhZlTEpE!RzdYpAuz2+a~!?+lH2HIK#y?!GhWP8=gfA#K(_MeMfz*Q`J5FDE*1j+AC5Qr%C^9-Tie|hs3lIgl};05lmFqho7*|` zs@E>#COX}$b_ZM*u1jHjuyZA>8!5rq4dA)y0ltwxf!M(68Yy_$7I-@jwi$6aX%{#B2M@NYg)?mT2mH$x)hUs%{T%Xs+^|>7#+~)P!N(s$u?Xxo;SF6vg z;eib;YoYI@(nY2-CphPudFbMRxw?}WJMlsBKaE*wmbJ#v3$%RT$LIizo3}>!_;28Q zIu5>~c)pfMFXKJ<$~uS6ZH3PnlVR?dltQPmsh5Ps*Y2Z!=z6KMzalyGXYA^N4SQEB zk5(LJ9r%`RESPi4UoPxh{^!De<=mYN4QYQ=1ixTz`3BzOBN|>dY!|XzWKn0M*Sz1vO*^(u5Y{I`g(>V(2-=k z%Ra_VM*F{`-iDp*S$Z{S>|~30FMN9InBw`E|J&Y4Iw{l>J6Rv>WKYm`Z3;3c;~_r& z-oG3^E*&(Uk1wZg@$d+Fm+^lD_!2H8S9o|Zc4*`a(XxYwR}3BuUciO$B3vw_{5|S3 z{9v((1J1JN^GqD(DI@-J zomwAU^_-}L<=DEgbH|x!_*oB)|(>ytPg?u=`62l%RUCpcSLF!XH zvA%uIH?0#VftSbWV{FI8VZHx|_rIdw{a6pYa*HV^9n*VW$n(iOFQ9+L)|src+J~HF z*1o&x!-;&`&-$YJ^?n}tCHHvcZ{)cL&*rQJXr!)xc6iU>@LC0aT)d8=ZuQ6D)jByO zUDEt7IXQG2bt=xnoI6DR=jn%J0`m+Ud+t2A`~se%(4+G%VE>DE=eOp`vTJ#ko}ll8 zjjk^rLx#DRwbm_%A8t)#Bl@4}VxD<*y+zrxyt<&>zwj)bK0eQ8-s!wrQwA7ie;wdG zGoRM;y?g6(mi;2nvPGEui-NIrJj*{O8AI=67ct*h|DU0*pNlr)WQ=*2S>_B!lLs7x zDc{vA!}G6s7CwIi?o1wF8b&?cTJxmaSMN$jmT}u*EcYHvG3QDDf-=6=_i6V1)TQ|G z0BhF$d~2!T97}%+u~6I}!990okLPY;d(ht-u93byqD|jsz42l%CQ(lbI_*QRCNDEE zxiNYlvd=X7Zrd43ebGT%SmSG1^VP1W*Os<$4hHy-zDMkmVg~s3DlmhWfdjY;=g}nR z?&ND|XYaVt;pTI(txO(8Y?XVCr{V?N{b2#cWQ-tIs#n>tvin${@cC#@a~(3~Vpkt8 zLmyv^KHgDXb;kn7yH>dF*u(IQk~3Rl)Iu)(8eN(`?Z7svu`$o|;X(Q!dOw$Z&bu`G zY=iT3`w8ao*}}P>J0<54gLeI~>{UIEJ*&rqf9HP52r!ttfoAGVs(}47GX`VY#sHhN zHwIt)$Qgrz_%W!kLO;j>*Pde5 zq$|9@uaWXPug~!F0o}r^MUKrybq^^UmZC962bVrx$5^)?x;Wiln~EIU0NrS8SArY`+&|H^ zfHP-)*qSHJE~UTHyZ*`CDdoMnN9T@g_I3B9--&nWL>LqKglfV2e&$T9zd!UUv53)C zlUnDEk2^rUd2_NmZ|1xbXA`5$bHrIjw_ngYZ)Qwn4m``eS?TDg;$7bp{XdJWc7e4< zcPcF*zOre@1>qd|i?DYn|1LMb=FB;6{<7~o`R`QzolgE4ZvNeI`PD{Ww~XqatNfoh z`TM&0K74?nqAAupZpw0(+|l(UcP9=Xro$JRQ3sA5ETI`1PqUru@mT8Iq5 zx1s;guVS?(^Zy|4WCxwZ{{y^JJj!_fH}X#F!A1OUkd6eeS+!s5KnD8K$m*tdyM=R8 zuupeAuR6CYHfzo(h*aELs5rjbihBwp755cJHE*H4hYj6b5*80X_{n5!XleFn&P%_1 zo-aHVnmU^{_KtJzn$kT}`?*K!;Pq2DpW?FC`?L<7iccpFPkAmaZ_?Tmhoi`;!B{PL z=?-5NZce1`2xHY-X-+WKQz?DUQc8a_Oxnv%H)*DQf=M&%<4l@vUrV3co8lcw827tVdiYN7+tz=N`dY0Zm+@x99&9`GgjDCfaw6{W!YvQpsPpcHs(l+yN}lmhP`O`2gpZ_;!-9e8cQN8Wh&elPgo&7-uB zGj3cx*hJ6K2Z1jR-VgK~2X92rE*(_5@cvTm0`Eggf%oT1f%ieBz_3gy@ZPT!c$b2@?0PY28s@cUiCPaW~_FA)5!N1F}{e{cIa;EV6ins)tps$GA68`q!7ZhuMz z7yY?LDgC)hDX?6rl>U?`r9W3Fr9ab5nqf~dX}Y~8p+C%Z`qM@Ip|1G;Ttt8NvF_`M^s*Nu^sBf1GW=eTjZLC@~E^>O=on&73M z-%<)}1C`RxJf-yW6s7d@B&GDTpGh<9T$85Tx6@Dbs6+d@w#|!evWvOxXl>j%nK5JS zjJEF|JUBu*ua9FA`qRt)Ucz&4yEx&wkNsWsC$7Ke=sB*xgZ0eZ-*+3Z)5kBA(#Ow~ z(#KDf(#MaL(#LwG^s&yQ8TN-JO}C5G$3ekE-n>`57xo0=rv`{Ex=58$bJ5$;IAO_bT)>OY6-&g?00c+`ZJbIX$I4PL9p#1oTHoC-7}{ z{Qd_1;8~%wfnPQk=>yU2-NLS35m$$?TRpX~3>n<5<5S8=_cwJ^ofSHXXEzq(Da&FH zKhJI~##2_w*`eM%OJ*lF-`0Bd7WTsb;0wB+_j>2pfh;?VI`yo*KT6exQpG?h_2@+F z=}SM0pX0sl7ZRTP*w6ADPaDtZIgU1-)H7rDLvSyBLG|}`QxA@G_u2dI!K1z^zxt?D zV?Iq|$e2%2%9vlOlrg_VDPulKDPumtq#5@2O`2}oO)1Ns02ij7xVf+>p+CLs3Z6aq zzU#Joj+;u~RQWUA^fWge=%zXwO5Y_jDfRHJao6)#s}Gu%EYu1kHB-BzjWwMzTCsbYlm?9qzsv3i#MQ>iy6yg3@* z_jhP7zVC18+3owCZr|@!AL#o}mD2aSmD2acO6mJgl+yQwO6mIolV;duCQY~BYfM>& zKhwa{Mi0z?wG}rG&+sf=KrsKeQkzl zDxOTw-gq7F_NAX-qA$5h>C1^q=}T{=^rfd#`jVxTzGRq``#(*ZZvT+JNFO$J$H6`} z4sQ(~w3xF&l;?1~OS*w*^57?&hfO}O-+Irtf-IpS<^)cc0t>jP&JWrSzp< zDSfF^N?$%yN?-n^l)mgXDYiwErrYPzmqNGxLlq;#wS$PvVBOq+P8^+mRc*1W*Dp?zN3d69RrXQ?geTF0GwU zC*;qxs}r6x>@d&X+UBLwPg@$0gU~Hk@LfKeOnCB&SI~|5wT$45OZ>FW(=)IoXJY5h zGW(h%>|sVu!1vEt(7b@ys&eJ!@yHJs(qNL_+!Jn(2gcsctMckymFdt5%?zig`~qpNXO!oahJ ziPxsvHz+S-t1~7062E6`me_h`vu{#9mm2ozMY%Isu<9P^NJV8~#?%t6~y*2FTixBIue!(JQ z!8Wt!lY5Xk|8)I=B|LBBnLCNu>%E>memXm~hP{C6*$24dl0(aDu-WQvcbyCMg&FU3 zdzcvy_M6f>5RzVLb*!W*r&JoTgutnpt%zJm^d2C znrrrPlCNC({OH#kgH7Ftlc~=PuERgFF2~oce$NOi#(8z?icD-+w*76&Oew_~(-`&vR^V(m-|Ml3@y!}5jy6EntO#7d}!TI+(*L3b! zd zx0y5L-sW788l7j0U9Lvw9{P)_*K^+CNH!|F-Z+nZ?9AMf}(n`7b|5gmcrIC?6eb zvA;I8z8oKKw108I;-;3fwPp){(Z&|%44jl;>psdGCRoeXK~oWbQYdeC^K!)knZ1_h zx8<2lo>A<%Sc2}8U+xR(Tp!W@Cg85&Y!u;gri;s;gC`G{KjXh}`2eYK86p)f?=#P7 z_C2I~$6aL3mv3O6H%-3)8x`m9Y;?}yabk?q>XXm@`w8ne+ zZ{eHPh+E_G-@rTZ!g=mHtrf~IeyLRJpHrUmR^7f_O&PB*SMt9sne+R1w=6Fq9Y!iU z-d~x6S5RmConL4DH5e9tbmv4)F7X54EdbsE#8LbVyV_*VfO>Gj(cMei1>D!*@2p{5 z*0(zY%FnmM-A#FLymOvTDf}`IT8TgV$h+^$yEpW+@%Tizlft`0SLghc7v2B;E2v|@)K;I&h8^xX~f1u7P*atk3McoyrzSQcSZtln4MLT_oQ!jaj_1?|r!KiaEJUC}C zeo_i~c8qUa^|5BITZF%Z^)WILyTzl#{ky(#v!3D`KU^QZ_M-4BwWV{qqMx|^ zn3)o4qMcj4eh}MW5j*X}|1P|$A3^ubg(z}?`k`2%)96Qpe$>+6wtl3v_Cs@e7C6(o zay6-R28%j<)Ghv7>rbgJXFlp268T$qGX|YF6SeaU{I@!ry1%nd)e=X#mbk#RuN0HF zhkc3}ha96z%FZ8I)YaJdBbD7)JBsn^q_RGY;N09U)r#GU(6^P7IM)PNO^nDQ+H`%T zf;-Z+W>_ibsmc!R$t4=^p|o>2d`dobWQQL1Y2=eV*$IbGwJ4E7^as(c6FF44V|{ z{G#g*6|?_FVcm`|#{*nQ*~Xbu!-`jtPxejLmDZRQ>N@8i#Gt%8rS*IrpZ4SL^o93L zw+zkvVUiT_C3w(lB2Un(`9I^kPlkHo2E!=h7ZF9lx{<3IQB$VAX*)Su1$Kt1icsrWm0 z^rSB0544}*)S6){*w0X<{S44+bZ4)y_TjEzKSP!FGYB`pvUeh5jBT-udDAeHvBA$| z=$8F^5n^Z-b5?frRK6=d#@)}bgmG-y_!avZ(1pDH1>NU4`x(mI{S4*As0a_YE^x-b zl>H11_`DjgpB9#HvvFrI_Iz{6_Md~37cjQ=u5f2I^8wBOCjcHYW8Ci9T+l&mGmVhdRor!z*X%a`!fv@^O0`dIE>) z()q{2SEf4#tC{287)T~FIMv<;@-#LIP!yLui3M!+T^*3pMiDLD=c2}i^>sPt$Qvc`NR|8G3x3hETeXm{mD!l(w z?XH?)_75X7nEtAN;%g1)JzM2(qVFT=yY@)z;kn^q8LI#qK{$ zx#d>udf-&t{0~SCd~Z8(;^x0%_YVW>s~)Vx?mz9p>e9$Ff)yH3?0&;m7lsk+D~p3+ zg<|)&0t4f6kziOJjP1leUZZ$@;CY|_CHlXzQ>ZeMwCwM%xv~2>(486o9`-csaq)b^ z#O^aj^U43Zn?HDBTmEa?cfI(u~(NAa(2;NddHEjE2>_~*R4g#QM< zr{myL?7jzIJNmiOgOAw#3q1JTF}cVclTnJ@=Y9^&Tb-u@y`c+mz6kwzr_tp>irshT zQxKZ2!Va?n8_Z+e9}?wE7Qrt1iKL`dS7EbRfxTweh_Ydi5t|>aB=!nkAQ|;}S~X-Ma21RUMal zb#xH3Z`M1?diALO7pdnR^o52Gd%~Z4IWhC##<{CccY$Wxd(ih9o@ra3S14wlaroBG z#F+WbHIA)8-%jS6XnHbm9ZUaWJK5L9`yAejwnxJMEq9;$3zU;Q?ma)tv*JZd7&ps} zT{r)UUEjjD*4Rht>q>pH`#N!qJ?(R8PrfegJ9gd$?7_S{vo#N~k37qtq3;|pi0z1Y zcI-B?jn}&6;0QWkMe+1QeLqBHkGckYc&-Uqw1?#MOz3Fmkp%N<4NZ>%#{F*Z7LbN|ew zPzy0e#RbT&^Pp>NF2O~`MkkNgO{USlv*vSFAnWu&#U~AD(@o0bbd%MBFNL~jYahQV z?I)sc@uXJ$mUe@j7gDbZ_YyyP!$wC*@D-UY;@GAbL`J{Y2v)RP4yARN|HW zj($RYk&3$ucT~_;MKBhGkJa7sW&K39_J*Aog>RL8Nj$OSM1zx113Yo^MJ86LVcr$_ zjhqMQ%u8b3h)0VOE5D07a{}eP?Ygn(2eXa|2RZLfw$WmLWnq*vPJ`^Xu6xpo9jIU( zF!1<8pL`!YO%*)o1mnO7z8s?yhc`Pt#Gj{J<>aNzUIZPj*RXvXQ#}MqH%g2`PL{OG?JJv%lagv}BKeh+;{a^5_ zCdw!tSbC7`JZ=0;_rd1ar(&~=rL?s_Lplp%(>FrdSz|bJuYH*;`(N>Y1AGTKiZ`Tk4zeuI1^ ztidWT9Gf-4)in&RTXl^db_?VDK6;#JavJpoIYY77zqQb#)fluceOBkz?ZPe|)V}<& ztWm^O%D4YV$~NBN=z9(5fn%wokg;uh=Nl-SdBeQR^SyWSlNy|Yqr13kF*fz0u=?9b z9DIC#AE6%}Z0h%~==UJ%_xSv=$7`D#PFZhah1 z@1l)1{@=r1NE>ZDl>0xxk9g&C)E&<&pXR-I(|kM99-LPdZ+DnIIP<7SHjQ=9 z$I&-5nGD??%^sXZpPSgRSju18_Tc>c6Zsf327Zq_Q@lMmchOEq`(|W6=x7hlqtZDu z8GHDo{3^05h`$&c!%^(Pf%k4x4Ao55V0Yi%(uE~S#6LNE7oGxVt?MxF_P?LF2WKsP zkUw_{`MmXMl8f^#@P$bR=lDxkY7fqr?*xntherL}KeXG~2i4?H3SDi+;rp$2uNBO_ zK|cD3P40Mi945z)17#j(4{ww`OWu5)f!@*bfcDg&&q0&oO^S0rS>x~ke3&vfo!zp0 z|I|_8>F^Kf6v|)g=J)naWyj^8t^CuS{4>a3!yV7BUyqNZTg?#ht<`DDyP+_8F8E$#@yxx%mA-1p zDgSL5!MlTgJF(n7?6XA2tb@9DZ~xRlI65C)S9Y^rHN$+^&1%sXENo|-Wm@gy%-tA# z$-;J)B-@$6cT(u&aoByQPcS~D$haDCBmA&Fx_i?&un0S8dEtw+t2^}$t%UE!-9gyQ z9faQfgMx1n`67(Z)ubi=qSyWuHy^3zHtH7N)7EAZ5 zf4_12Cw!^=Ot<`tl=oz4`Ahd>>yaPPnd_PMW#nt)%Nh2?3C}(3YRZd0OaN}DOqzXx zsXN`?0L@>(`xd{;AEx&}=E*>A&2-`^=5sfcbc4uoA=y}4&x-GA#TsT>p`Q(gU(fX7 zDb8#4XDGgldykO?tk8r@$%7BYi>JUR?Zi`PUa>A5`XRm|>N4>Zyi+`d_{B+#>A#4j zIIqBorN{wh-QU?7OOYlX(iTe*8Nz&h7kQL+C12E>QZ{TT^i-3ywNN(UI^gtt7KyPG zlj-v%hMt?JL&JVAmcqHmQ*z`k?kH)s!KVbOYfjX@2=0;fr?O9C1NX^p#4er8|Cf1} zQayol^lKI<=3;Z<3(%M6*Z2>86%V}%y#MD#t%W}JqjFyb_YBAfSc^YUzPrxC*?{6U z{)=pRmf^qY_S2@0bo)s+{X6OW3EJz)y}kW8SE<6i2cA8A>}@jp2^HHQez&&_{&ipk zZEYyr3;q&(Vs0H?c@O6GF3dxKdA(pB;d^s+OUt&vXZaoaF{1-?zYl)QdFT>3);jqy z|Bp2*!AHB1exGV_R(>*c<}-I;%MWVwftrHQ8@C@KMhU*TQgWvDl&9JIiAC1k3#*Bl z*gNif;pS86>qfV);J^L-3yJf%XUNQB_6BU;D>>#FHze=D@m;XM?T!G?fVY?Odadfj=GNL+ttCma(v4*{X(zx87(`z7C)Ex3@;PL$82*!P{~I`Dvz45%k^g0fgK0-1OaqSwriFoLQ>F~nUYFEar z!jGjhy4vc-_Ceik&*}DYJTIWF);2D6+bC~qV~g6DbwRikpGb#oTod1h?mmofBg1Y? zcuu#!;Q4CWbY-%H@i%vXywQg5H(Whg{W7xfk1|7|1MS83=s;s`=mpvs#DCGnW#C)m zFFFtn7+iptXOOwa#P_$qc*aC{#{}#f+h1>@T(_ zhZ}aLgk$xAa98;AXRK?oGbqMesp6cJO2$zt{ZeULABeR}fFaYKo$#DtU!CxrZqG<~ zPO~rP`Nl8Ri|sQZU$#AwXUSMc2Un(jenR;Sdql!>x;;GMIn6$o=LuheBb&Pq*cK3w*X?7~lxo-Y0 zU#dUD_9f&;R$Cn3zcibGz-7{3633bO-!9)LJbQR(qlYxRj`x!Fa#=g<7mg6;;ZHH= zY|4)6*sA*x-%Csr^1(>>K}$)5Dl0zp#VuB> z=|_~|&K|9KvME=gGbQNo7g^z{Dua!%RQv)Ti7CH3In=bq$JuP$CyT$qYi}R*RxL`d zHoWYDEGM36L~>|7K7()BiSbN=t7<0e>dbO%tWFHd_7rRFaN0Y7>?^tc!1*H!Zt2IG zDwwatCP06FmIchTyP9)w8}8%0mw6My2Y_93FiL**zMX}AacO(|V%jKt>-fPmUh+|3 z@8Z7s!cZ7L{%ZKNH7BZGpQA)T9->%Od7Waa4Tk{7IM;af7q zDc4CCQS8}y@THOPr4jI@Vr;L9L3_o-pa~Bp#qd#Z@m8jT2VzXmR=+oKk7`H#e*1jl z8L`7A^m|ERXbJt^03S1TQlIL4(XEr13sWa_ahCA-KJsBg`GUgGr(W5|oU*@j%a(rO zl+AO?zTUpCYcrem8LqhR&%^V==|8FB*00J4C8^z<0?6m-S@)r!sfBL)-Cxqx&(}ur&?LRoRsz z3N~quOdc1O&+y>&-w)q2hx4y#ci*ZJ1$wuH=d)cnXC}hQ-NFT-CCu9b4^NLd?Vjtl zJL-ckx0~d)8>QVw+Ets<=dY(7*=zE>wt07LT-zhtw_Q+R&Q$E_wY|YiZ=H8M|3PO-fcH`Fw}XK( z`$Zhy<6$_RI<(i`;GMpo8V5t?_AvZnsF@!-fWeG6^*(tzw!i-4jjb@6X2oXcUIUjF zR_hz^$d0I3CIjmNWNN+V>=?b*y)#}PeyR5}o%cS@{xI)p<3YWj<-A`{%#(Tlm=#*8 z_g>rh>Q->Riuty|3N4BMhFxU+3GTOD+-)BJErs)Uv5EexqKKG2f9S)9gPil}-1)v6 z`RW7g@Atos4HZ9vXG85vOhdyR?8#-LYlOZk|C)aQ3u~PERLgh4A^Q5y$@ohqk8icV z)@ET(efOB~W8kogeIF|-wh&jawea946T;C~(Ibe(tHQ3ag1sU89>A8DhRhuomsfU_ z<>JdksN?3;&dcWhFJqaTY5yxI0$Ce5-dOqywzo0J$BrS#)Y z(u=(El)KG*&$e$dX_kGHNi*$vCe5(tDy7`@q>6JAT%waX=6jYs+oYNHER&)KDkc9+ zQtexE@@Lu8-F%n3`KG%0E+h5uDEt4#?)QoA_wl42Ue*5#-S=Zjwa?wuPkZO{EPZy- zbDpg{!!DoQ7Q>>lck}EL-UXIrlog%l5tN z+JnolBagA)AxAg6c003wW07oN*yj3o3hg8P%WbUf6Gw#?OHY}|d`Tu2-?amkU(dj)sUVB3Fi0{bf=Nq*iU)9m4T>io84NOiN2 zEwO*+a-U1x@?dNQ`yHi==**M|x?kP7?6rh1tT6W=t}onku5isabe6jQ_|{J6nf;Lw z;z{<%KFR(``P)|Ljzn-I7$$JvLsimdvxlN?QJddE`cNr))?YtwS)=in{Y7J?G1GYc zyYygYd>@+MmG2`dbQ^uix61C%30P0d=aKrIB@fM~9_~L`D;Zw)YV0DW&bLb)AH!H^ z>+NS-?e$LuYI}t0`hR)fQAhUrh48@yd;JJwvwkXYJmcR%9Ua-dy90X%bu10c7;@Bg z9Bcux+mY=UFE&ar&;CG2siyXN5XAb0IZ|C|EuW?#wPtNux$Ym4bCy6fouE!*N!`C?fk9K>)FI;=+()@Dn$D_RfdS`T8cl;@?51TeBZb$ZBH5wnz zmcj`4G~{%*KGUADGWMv}RS0&)aMu*(mD3(R;OObnt$m?BoFlmx+KJ$oX(UF=p}%qA z=6TSbzmqvrv30KwV|=GM&xZSd;Z+`--vv(j5{E-q&bxHmw-()ic5lG85ru~eo?OK( zGRFiubRJKKc6@ zT4t~D^e)&2y5isH#(itfUN>w)?D^)N_ubrQ?f3TnSm8#VuR9&SIUHZT@oBW}!79Pt zqP^dx*kJaKyMQ{!a-a1W_EJ0hK=5~GIA>?!$)>sV_AM*`o64`f2;9rZ!$)vtjw0xXUnO>w3@?7cjn@_#N~;2WaP za`vVvo{T%YWAoYj+fjY3^r;w&RZd?c^e>8S*z50(+n`VSss5UNJq6sKJUHI_Rdc5VWtBHLGIJ{*9o>_S&o;7OKOi5FmE>R${ucu;Hn$2yvv*$?PE$&CTo{ zj=?JRL9^PlTwx^fhmVMD3&ucIwF z*PqH+3A8($vm|D~>phre^FBJ2vqE_f4aO8l<&2^HHk>WI8Jhy*=h+m>6@SV6RQcMz zw3&h*jB$C1y+A8emiM{z^MzTCe=7VbvI^rNAC-w`gm2bOX1!q?-MF=-I{OPfjkq<= z17rzJ55rF%pcyvqF9gl#z0Zu;=T@GfE^6c436xe@NKuI2vf$Q<|sXVBG+fIhJm zW6;m^$|=9fMU|g&UYY%F8F;8EBYaNojNSmAqkf%%o?!>6r-^)v>5pO@3wieJjZJIZ zGl7$!wTaX%Ie1R{ei{AqsfAVjiT`oVG<%Kpt~DNyzCQm}i#ebDcHTQ{qCa%}cIO;m z=edV{25<$y#oX3BJ?uG*z1Gs}THmGF*BClUx8G+TUBi2GwuXD2hU)V8jr4<`+#ou& zY^_o8JZJ4y@EmgoXS#g~^||u@Hs;;7R{4Jr^S!GNpMO%d&I*z2|HU1W{l|p&@oZ%2 z3gl$|>pYHW(5A@;9oD(|>X4(5SS+Y=sn6bM4oXgx5oFbnfFS0kv#2AEr zdLDAI_zApKyv5`3n%k0#9hro)890|g=P~rV=3r(5&sf#P;TeK!JNJ_Tqj<)5Z)MHt zul8s=Q~D3QG+s9{Ysf{dXFQl#8@F#K)3>@)&x8Nu*!6=(gh$t=+Ixl+hri|Pw&hx1 zm&$v5-7CkwzIDr(@+}YicKvHxs(oE6@8ydc&Na*V?(7zkY!&wQ$TCfJT zKa-#%-QZ4WJ6^7@YH4BrA~OA3&KU>Iy(CW&(*$jbPR%--J5X||kwLzzeObs*dFXxS zn}vVg{Wiq?HVS>ue2cVw`;Pmq6g^M*MJruSW)4snHvZOkubt$)TP=NPk>i6(l=Vi2 zn~^c-yIGUUT3T4c&ke0R68tsaYK8F_7Y<|q2ga&zw|+};zp(~6-^xyF{bsq};$iKc z{oldbJnp4%9ehl(Pu^X@Cf1oXrTv79R6BWF^KvtfkWHG$tzWJ6Hop^RXLZ6(0R3yO zdGDJi{|TAOht8Bl?3K^l+W;@HdqN-b_Y1eR&`FxkiY47Uu829gVfA;RC5NZs12?op zJQ_UaT+x!ByA_aW8zv`HcM9Y0!pYojS;=_|*v)Ghw;<22J(sl1O16f`wz-e-dnqZS zzMOp%o06@ki&@(?@1MVYxGzwjSHAe6RMx?qzSd_w%9lJ8^`C9~4$a^G4r8k`Xc`8< zTaX>qZ~00!hc&l%?1)NLp59SwoahdmHjPvnSYR4Xy=l@upJnZDR2$ue}E^1TAFo^G$qO z!{qM~Pw3v^fW1KRizS?0Q%WptM|o7I#x}mbRn(_3m<*ne2FLg+-x8j!+?vmC_y+O( z($=rWbJru_`Lw7n0ndNwbYwiw_?q#2p^N83(Di?d=d5oK&sQG>o}U)YABLVwwkP8G z#;?G0%GZqNFNQnxyz(gVELtvMUcL0}H^(!&9R-drJpztzdp?n8^!f@M{|=mV#1CX+ z{9kwmm;V`_G3F?7oEyh8uKot`{QE6m%`=)c7KfqbGnRAjTpVv+?>{onnDjN{Iq2f~ zQ)KS{mS=SR2Jw99QQ-OUBj9q(p|98J$dj2={X$^evf57w8fB5G3M)T&c zrspw7!1LRC6Y<>rEAU+PHRJiGE}jd8=Z)5z&Et~7`S4!JB*bIeE$k<#^IM^o0lskU zOv#-A`;PU#WhIh_(76-jA!HfJL$^?8Gv~ZfpOLqvA8I~(a!~v?)zK>dxaDWLFlBmU zKfN=yT1UpjFJ|OdBM;M-WK7AL@iNdE8vhh)NF%bBY_~g;GL5WBjNH@3*gNVvkTo-m ztU1`on(w-@X5$fM%?u-J{@5FTbQ{T4wJ7GBp0SOXK^FNaNg_fj;%;O%9KXN)Ly|O`Fj8OG)XiG=98`TkMJG zQ)dsYWnPMA|L!CH^a#4sbq0^n>SSnjqqn!Gy$qE2y(1c(;^ME%QPOBUzc~3Dq|+N* zTpmd`{gY_C|%Z{M404#|z@|ymiet#}BfO0?$_+0ngDb ziR3h4dVEvSHD{J>3RelU%M)i=l;byGA+;e znsI!gi{nExzMALOfZJZ+HWwRKM?CjRY*=3>&nc(G#9@e*$98u&PK?Yi$~xi1z_W{aa^KM;FE4i?jr8)?oE@?lWCJA=&$T*iV!@XE5r$XY-dIK{QhY41IG414Ej92R=ZR`F+X3<%QJW;zvd$ zK0s$sOGYiz*+y2^&?n?ex71F$?WdiR=rh+g{F^ZpKDWJw``V z9c}HU+taB>@sxdOYX)bFM}a|k(5Z;|OS6{(ht=89H+P)l@S95BCG>mr`3e2rc|}{l ze{huj9_IG@M%7*2uKv#7OQ`?VxcVz_vb|E7NV=RAL!d}-iysV`6zvw{J9 z^uynowC&ut7hhXq{6Ou$ElIK}^L`x+D{i^+#AB94!IykT?epP3oKQ*LYx`Q^*{N2n zOJ`(8u}^uN;(It@9vD>g?;`S%X0k6eFLY57LXQybQ<)5|Aji6FKAhA zzMb?P=Ud=At=}5GZ`?C)%AIsZ>$gw6Z`00nz6EucyHjT!-y-ZQ+eMs^e0W!ODH~S8 z{;|E|MiOJvMmx%%@q)8=KUHIOY|o~H*ZYV^Ng@`=kNv-0gTCp!{8RY8i|?iIWG{{*2=B^cPk1VD>0Bh)1@wI}?WO{+=9TZx)Q7c~ zPW80kPuHCCy{6;NA@;e0y>|MhdEb2OiB0korh%t4+A4jps36eY8lMVJ%vo>E4J4OM z$U9?k&z!I|w}!su{MwqEtMo2wZeQTj+~jOsbHBXdCn?3IUcIkJr&dhFjVCz#VIj6I z12eD--ns(L=6WnC^kehh;YYsy&bMajsV$Jd58lDJ`AmNU246cUCtsl6tNafsuQ-bn zm`{4Aw!M0`kymY&!JFdmQb_w-(D<+APt+N?HTVfjZZB=hWNsX~Tt3oFdq3l`7+w?r z->TEQ%Ru8L_?xG1T>Ts{dhhitoGNBfHYn`Y)Okyj=qXB_2i*GPw^kjhQ}wJeFcRAW zjJ3Z#dN{ZL7jWKtlyLs(2you%!uf6Bd{%HCX3lxIeUN?chn-uj=ld`Edgj(-;5yRW z8pn6dEsdq-jx(0d{!`5(?LpN%(mqs;hxVdseiRv;eR-d1>)gRtFP?HPI!~$AEXGyy znl;e52c_#-*6nM}bBk)BtKTG}7o5c4@$fq*OFTPa@Z`#z{vZjQ( zd>{YF&~Xa*(O&;NcvI;?_bwNYH<71hsI^SzUJHMv;LqV*4(*CBH%tb9^tEYvF?|Df z*Z+C-=R-9woNw{(H9r)eT@J1+zupJne;Sv- zj{*-n=hy}8_bAhRZ11M{yD`$LoH?yItTATZeWp2>QD%iUKF^+H;>Eld}7+j{(BwdObY@aFfE;7`1MI`Tr@ z6NjHSTB`!S`M=kA`540^@$Ixriwytzrsmj>>BEuc*v))5a}3%awO@N5#4o>kj+JU0 zJD3ykxTpo!hohx*@Sr((v&U=Nui@~SU!0g(nfGqn8lHy^t+{aaoZ|5F(7_At8gAx~ zyM}9?IBR&;!+~Is9Ej5xyPnE~3BlZI8>BG@qTjh}!jmbyn;0Ux2s$I;~hM zqhlOX)YO;q7IAhb+;fcXL-?$S`6n8FslflXcz4}~=1i+wFy`qjdUxinzBaz@%27J& z>f@Kz3=+;~Y*_-%0f zAagC#ouh^(u5@H((Wo=uG9MP53Wgc9A)cf8WX9LX%;^R`Z!EpLrY`Ade5b$2+T_|v zTv(#ao&N=v@5aHh$zA6qR|-zSFqrQp;Cm}}q0*k*&kOyhYc2Do*Vi+CDr4mM6J6N= zc_UwC`f+}*%ACU5PTsN5o%&ib5I+yL2Hl;da*|KfmT0+G2YofN@J~jDPv@>6!S(XA zgUd^kN0|AjG0W$@+FD6lCFDEV&G$U{Mv4yIctPp%8Z*_wK3Ql09mAE^4-K}K&0{P? z7a{Y_mD%0ziXYrNIF6p;WcL41R^=X{y?rjd#n=6BzE?pTSGc;sGV+}$xW2|Qe4REt zdg^El|IGK24crgu;$66&4Da%Eq*Q1-fIcMrJK4I`y8jL6%Eq@bn|@{!GC43c(Xs?kvi6qz@5<80uhir5w_^IHHa>@6xAMn0dOpYfzK8FJ zlV5~ePoBefJ4yD2Z$eHDx(D}>WUm{ijQB?S zv-50c-X5+$@ABRBCxdeWk3#O+dNwrDj<1xmMtSm;)~TESi*@Q*7e2{SZS$aGIpnvr z-O)S{t&BU+vU~=(ALZ&n!_k9SPbMJ?t|_5!l9fc$4-0-$GlveNgR4FZz2_X&*)Orq zC#bVrb+YED&PBjq%9`tq`B&*4#%|`x+suhC+0CTee@%9?5*N3JvzuM&jXk(8Z5{is z);q=shsXZ^k-bj^=A)Ipa}At_w{0Hnn0?dw;^$`_Szp}4_y0v-eE%%b{!8p=~w6+B9lS+9m(UvgE zU617B(0!Vz`LZb$8Jm)k*{~h_4!FJV`gT}*Lch+TPo7P*Cm7k0I@KQ|Zz2mm1pZ`G z7&GPI^1rTP4QkatEc=*0JNBpmaLE=Wxg#~hk^dz}%C>s9fk$vS_FBz<$&jWk@~WKI z)_l`ex_vrr#m|{EPv3L-WviZtOdkRN>yhcp(X%Dbi_iRkdYa<(H6zb=z$ei;uQc!_ z>c1VWv!3njNbBltUzh$5{E{CJw+@}ncSFbr;8iA<>mAxkY$LSGoQ59i!JFOCRIvIkU~XcDf>bXEy!ube}_BImSZ$z0$z{cD&EE zxAl)7XV>Y%C?Lk24`Hr*tR%3U}@la$wLTxWgE zKL#Ia>v^HVJlO$lyB>72UbhyQtAihx3oxWu{OUY+l^N8}P&n3S=r|R$e zWvNqV>PIObJsmxbJ1o4ib(H-=`~4rakcr#h=8-r3|-n=MpQwZWrbAev~{Bd(?zL=bmSR=Yl-`XM&62 z!Qk9t@SpdiZWB|FE1Pg5@AJQvJSdRb%j6ryvtnozUl2HvK9Z*kzr63CFerayw?PBR zyNo=lv((MIhq#)XfPXgdD{uWED>N|O8kFzrv9;6}AoeJ|zKf4oAKFzvYWcnkzG3-# zR8~&n&a9;LN@wrnm;0pg*BYn%mG>Q7u6A^*~`8G;WI$HIliR&3b#G4 zt^ae|l6@_qJ$JsTtp>)-YwvouJ@NPds7=>i=C!A`v>#SyEX;7ntS93YKyI6D)`fJt z>Xg94Nj#5N+l-&nE;1N)GtFn!A>R4ce#fq{ee%KOmqR;8)0Wnd0Q^jCt)`u_(KvQ%r$GHBY2(MIR2ol9hATXbG^bWSk#vqy>xq8s6P+yx%t zUa&|C_l8uC}c4#X+kNd+^#_&M$)^SF~k`s#7DfUKn zl;6O48l2@&#u*z6IBUZ{mSoEm;QvA+e~4dtdG;jBpnJj0N`=)>a02zOOLCKA(~WcXP&4W#N?zepnriC(jBN z%!V(0Mw^>BujDv<9eS6_|BrZ=Yt;-JMSaL+!&2REo4Nb+Uwl)(I{w2y&3~OY#(hHR zxt%y~;H2WP)yb+3oRkz^O`iR3p4pr=^A7)`)W6Stm(RO5o&P$+V2v}!efA7&k&4$6 zEd(qpwwQXN@JQf4FRV$$_)S)G-vdo2uZ`TvmnpTZNCyZ=Yi z=Vk8y&AbnJ@2Tfr_x}>!GhU{i(e!<>_nxwM@&88FVDVqY(k#38yqE=V(|mk1DOm8{ zckmUYTWi*P^U-gGIH#JpvEpjw6HT)R+00)<+u)=0OlX@pGTo0QnpQoVsHf%x>Van& z8l@hMi@9fuI-cRY#l@6c3_i*+_wph2Yl7v=ldqwx`mkddQ~udcDnpf!2%E8 z^TAON-dB|7`Gu@dRveCgeho4YI9g2`9kIpq zZ7BR!Z+Pn+*1CMFs9?`CDbEf3ZP3Iqenk9g68ZJ~(H+5csx$h``Olg8@>?t1?KtbX zKqu}qqOVq2d7-atL1Cb`6$^l~RLfVO`L%Z(XULt)KEugl;7y~6cR?QYJLkz6o(KKC z_ZYFNjGuImcln>o9Yh`JDEZ)4@EF?L?F&7M4g^f;CCIKm@4a{=^++e`Lw@nd*Dq#0 z!xtT3T?Lbtd}Ran&H#DwPU=5++xCVlf}E?DV`m== zUc38_`P(kvn?0?}yEk8Z`$6lT{L=!+>b=(cJ}*KRjeMALeeONEr&+7N!~0WCT+JS| zwf(G6(BGr7qcSVtTVEg_5nuUcFJG^_dl73?>aTe(aD2^sqmCU_+1rE6_=O=pO2u?twb~67bioGr4+iO%;rnr9PZm>w6Pl^=Hk*Zbbb{9@70# z4eTKc6k!LMJ`(wN@k9G(jo>Wy;&5I6SFe*ig-mQKRg9m`@i%(Wtj^$wdrl^EehE6# zKEEHiO|qg7c~AVfEx}s$fCpXCq=m@Hyx#+qI^Q&hpB% ze>maba_(~)sC#DN>yz~T?|jcmvF1iIAMKgv4-CxXEKBanHEV}+<{#(%bd3IpvCM;iYi*-k!Dbf+Pr5j$Ce=NCnT#p=X{LCMMPBi5@fz`$*{4Ix z)VYN9JOA(bA)EQGaZ1gz!lTjW^2>*WsGIwW$|h_c=nFe|<_;X{ew;eZ{G!g570&!} z#xB#om+#^sde&T0D!tG7-oyTh3*$nQrr8TjnqfB~lP_Sdibf9I;fIboF`wGgO1r(t z^L^o#{@lMdKPlWlU~zt=_Uz`^3*c8Xe+mt)3Wl%c47D+r4+;f+HN%S5*A#Z)yr&^^ z84F(-&t-*;%-y$pf(O>4;rZ5FozGTBypi6wB&F7u8(qQ*t$l&LKg8#S!C@-pJa#U0;z>im@y~iV@t&d$uRm3>mPxvYMETa^18rpf zPG;@a**t-4*$y~=Gbv+hz?X@h)}wxd+YikJo$qrzcvKnny*w$SQtvEZW~DWrdE)ge zsYj*y7Vu@Y)dAeP)5zqf4wIL@w$+hU`N{V+XE{%d`UCJY-S=0TftKpxi?3$*QNsE&*D-VI!Kxbq+ z#ugjkq!#*}bSyFA*WNNT=WJ_k8N6?2QlI)L?_TovsE=|dLCo+t)6UkR*m(oKZ2FZI zhnsBrm1S?KJh;YR1=hiW6}oEz zuc;oa;L@~B9Sy`+dUWdHT(G7JR?#(i1#90gTDW)G3hg2PgNFa;-sc>1R^ZyCoK_n1 zf7~+ZI=>A60er|DTxwG9la(60VXEm5bIJ zD5eCRBp?AVC{R(bB{5cmv|6NU(fW`OH6U%}RBURkH9-5wjGdNNXlv~yfVHT#VyW6b zKCKg|btbe`%Pqrge(%pd=OiZ))PBF;-|OWc^Ez|R*=O&y*IsMwwbovH?Xt71wXNWy z9=$yQj`ggRXMS0G7} z;P#;mKcUx$9GF~*O&hS&_{oTScL?U_WUUdmOvd&@v;bM>tOa=l|4(}y3NA67k@-)USJ; zYpt<)^%LsXh?u^U9RAjON1NK7D38i#xscqMWdo6|#pGI6A1Xrjr*#G=b+61*y+dQW zkSSgsL)BR-xVcJ>OuB`6a31tB(At6@eIW7ui|Y?(<{G+`ydziY4UEZ`*ca8zy?lm4 z9%QZyMM{1ETvg;Hjeh^DvxSqf=rq}1`+@NtqWeDm6XszvpE4I7Dz=`^Z0H>=yms2L zTIxtP1WE+c3}|Xx^?7z?A$UC7;zR>vGkvCh{>4h#3b%gJ9;Y%-aMma7 zr$MZDlPbajU~$H}Ji91)br2XSrX;yGU>1=%~9^IdP9ou*dhV zn_Wo#Ve|&mM)fCcuU^sP=?z)%>s)Ah4zxWR8ovr!zY>0(1;0Ay;C-uCAi5GbAL(VK z2h+BEF?;7k(hrbRZ}mm&u_b?e73YlAlRvjkIpag+@s-REb>xLlg!Eizdo`454XBE< zR;oFRMPujBB`kit3Ho{ixl_nHjmwLVA8jh)8wbp}v9793>aMm3I+k_3Y1D1Mu3Mk=?JJ{DC;E)0#$`@D1R z-B4f(xbKD2LEzMDPvae1q4S^fV)vp)_oHlPJ3hXW$f2v{4^8A;hW}IkI{bL}LwAQ} z#x?&2@zFZ#F}bm=H<7y)KD$_ZIgp!@JIs|^k`FrY?XGdo2+}<9)LqA$EY?&4oR1f7 zxTHM@JtZ2mIFG!AXIo2?tNG?3;Arg0GuC#HjfvI0;??M9iN@*iWaujFWyeQoa@os2 ziGMJW6N>*tI#brvxbo>r_sG1A-WAGfm(E}*cP~Dei$mePI_KSLl>J{3w>Sg641GxY z@qNtA&KcgsKT;QaZ`Wu~djdVIXx%oGW4a#S<1}!U2yQJ+1welsAZ}LPAlbye*koJzPMV2j`qL?cSBHK32f}<4WFH1 ze>0!4w$O(wJN6G0JQ@Kvvfn=eZ7Y5t%s6)LA8^;5SvNn8_lh47E;qV5M}XKoeR~S; z_RsnZ^!sV(_&Vr$0Wxep`;Z-fYcB1JXN2RQ9FqS&FSZ@tFwda9;pe5v22Yl~-mUM4)K`MMICl5@_b|zqj&1v{+G|}7O>8YoZ|rMr zW}oT1metR`dy%v6IEjBdu_t8T^96Wm!E|!zBMXY*rAwg!oewm@NG^=m7_p<*@uKl*+=}~=`(sv8%rljz_&y=iLNL?>l@OE;ezV~2h z@^!uq^|a0U+s}I14bWW8kX}yie)5(FvDcmj$3wpXUCiVAr?7#Zpx#S?=TWNzu1AG0 zXygI`z3ZZDaDHd!K|i z@LRM3Qzd7l85~vhv(M{>qlv=N!s*dU&5tgQQVqc6;wjaS98#+}--Lc!#1`yf{@31x zBAsg%>R~IsK<)gTwSLK^47g0lr-NSl%~@I#Er=QT{#=&cK|ZTI%9#7DeLLVaaDt<@ zF+-z!cUkEXz`Gh6O+Yv7g;=8)s&^L$*3RWyt<`$cpf>w8N-dtYr= z`Z$2@m8_W_-RSGP*YBlf&dH5EL?4piqmna?g@<}{M&V(diwEwz;NeT)VGMA#KjYC- zPx}C4cU}qh1wOrv)T7+h>o_Mt^pa@o6R$>=7eO;MTx-7Dm1gdRZocwxC(RrX&A4OZ z!FV$;CK!u32gQ>^VmET%j*RXJ9KvCdyXXFKaHw(l4DSz7PIKx4{_Bi1`Lh!`2e}wu zH1bcnh4OBjIcGj|lsQkcYaG$ByMJTW6h#LIF6N9+@YJzB@4_f}$_;!4v52|m$1dXP zwRbpVr4OKICSMM4cB<2+d|#R3LD39!o+&O+9)xr*^tTV5GyI9HY2DrveWRB><4X=+ z6P!VpnvRaBd1em03jGH(*UX_$PZD>a{=A5;2oH&GG^dRKjsw_>@&Q-!Ui@_cyTh~r z{$~7uz2DTUaVug@OJwzqkCk1LH8U>!m^lHtFPXp8_^x``7J0-s%8qTsF9i*mJ=D;R zfwmNuw`>r84}4ck?0}Ob52+bA7e( z+4Qvg5VwfWE1i#SGiuR=7apV?t$j+)9s0GKUy1)(Lx1^S@B`~2t<+)kLB3NvH_(5< zC7izsUA684H?Dkp(!~MyoPW@(0|zUBP4i!ZdDY{m7jF)%eMq?@awBQhPByP(d=k(T z`_A4=h8`YP`}eF18hCcDWZCPT-~E#BG=>{AJ|`K&$?g~~J;@kOaK|u=?9v#PL4O*< zyIuIX?=pt7f#1jjAN-GYgZ~;}eOUdW59-fc?nV1vOiSFJ@Qp!{*9RXi zZ+3BcrCzOd4qe+ju3R&14mOuJn@zXUvk_%qq z-CD06#^|~CGELBZp5%?{5iS!=oie8p97{J8z3aVXV|TgrU+y^l64<38k$>p>+)IZyeP#~Y{;oOuWc*Mc9F_33ACAw`hU{+-4#C+Sj_WAX+pSkTlYFsL ze|=CeK)d4Ka|9=H)^_1t+6~@&DeK1@YiSoO=b2=wWRl?a%cYBG_jd52vxjd3pK7DP zZR1OB8}qxhv6%Y&JbRPcgh%_h*GT#=&%DDIFQ+AA3$LZ#Meyqfl&x`#K zcuRoe*xf(Jhw}bhE16L5SG4A6Y-jvMnc@&@BR#qHie@G==YTt{uU&CHx?Sj6a~^wQ zF*?8-jvbw1y(fW$Z~bI)mzX4c{Z*h?98Fn#^7k-BE5Ti5Bp}$IYaN>X%+Uj=VI5l z0=ENS5Bq9-4as@HH`Urwt9(lM2Nc&OyH37}=Pv^XT+wxRhTlVXrY+IpF-QM3&pO&K z>wm)bXL{||^|vQ>YySeZzu?;F%1CGXTDNi9&yPiE|0r{)Y5!Pf`$xU@dDhYXx)ZlQ z-fKV6-_GmSe!kkDb8WP8N@x3zceI}uTSfb6vrZ)WJ?uu^Cv!_RD;gFL0_v6v`cR(tgkDT&xCb{@r!BilRSHzHrr|M7uXj^ zPtex#4`{18;%iI1KwIL8F74H*y%Dilv?uu|-;mbI)kku-ZI=Jg^lwARe(d+G{X$z+ z_*QE1tt99Z{_ymoi;>-~Pb+aJeXHR4YAgLo>bwftuB6`is++!b^e3I!axJo6{7z6X zyxyO4$l&pYko~D@hlYl;cNzZJ{EqgS-%Y()v*SBP4}UZ@xh%c=(H7zXi7(5#DxN*g zN#Wv#6 zwwG$`uIEg*MJuMYCmMUlHGUe)YHYjRuD>ABm>t)d;fcnX@!j$pYzMynf=lP04MLBe z5l>DI0Q10j`=!`o%aJqSM!dL=bFCXgtZDJX=xeD7 z)Uld%+r1Y4w?6p#E{QJ;W$&$B(X;(}Y>5Q^t1A3gMyGBF*ws%#hm-L2krPJ#uFB%< zM=uUp??r>w?3w7<;|4!I3}5b)#H}q;h`mi)+5BG$Ui)&rlPma4+|6|`S7fc#vu?`s zuVzh>Pjx$edJwB4V{gOZK15}BtM-c|B>199C%1E zX7bk+2DX-t3zWCFp+`!lr;zCbprb_NthoFp!gCTGKXn#(=oO0ZZkQQwWegJX;n9EL zez*MV*l?}baNnd&!TAlr$ru>>4cbaTQ=a|ysWIr1z%4(-S12cWC^#no&xQOdLr!j$ zW^#e;UwCO${?vW*0^=sZmxn1koH(0&>fE1Wr8N(d55!&=D%e|ytvYAU@JE#!3pz4+ zz-oy-lMnFrTa=Sy$oOOM-%)UyCbm?0!G7lY1eF(TNR8tY40reh^B=WB4%}mb+1r!e z9?Bape`Lzkqxwb~n06fLnlEf0ZD^m(P`*u}3%my2_suICr}Zg=7y4oN#|7xQePdG^q-O7zGFHD2JTL^y|b6P%s9AO6nlf;W*F zl6R6Hnc|_2{m47nk1u`4wI6r!4bNoP&HpiU?6V&a@J>9cdDYN5<-ROhf0?*D z$k`7he%<#5ILxV=BEOY)zn{5Z&mO~Pr!&O8=XypwBKqNo*zab_&y*KChHfH%xxWmt zij;x>DdUxI;r~76`N-HW`G1UW6VTt!`44@^j;T%Vf5QDi^Nw`}{_70BL=NXqfxmt5 zc=BoocbadX=O&TuzI6W0vQQ7jwQhUaz62nDIKv zczntm5A22y8jokGr(-;z2mg3{{RHE2vpXI-w{)X$#8`X&nhR+Yy_eh$@6Qu z>3>?!KImX3b+x-PQ1$&<^4^{2Me~~LQ}_@)z561K74rZ4@E3A){8K6q9d_vG#7TH% zC5Mx{GFvvtp8y}$`TYs#4=sC`Bbm?SPe{4*Kmz^hGWm&4GKPOU4H=FeHbP}ifbah` z?|ayPW!_Cbir%%~m5q-_(vOOl`Nr5F*rLC1c~|$9`PP=7aQ|t3N1#bP`y&6p4$=uey=umqhmJp77oOd0lKtOs_{+W_c|v#ZCibIZ%G@0EFk zGNNJiMKt`)6O>s)8INaF?i;>#J$cti8E;(g<-aHI>iI7lVma5jzVE!U%Xt15>;#SV z9sF0^w%6}_dOOd*z;n$NC&qt%Y_ac~OML$??KGkkJx_YpC_!Qm_Vhc_6y_3I4<&x-W-Z)I6kK=u1JiMOEa}QT% z@!!Mi8T^+XGLEZ!5nj7q*}0y)3#U4|VvsVPo+x|>7YS^-0(jw<$a?tg=~|;7!T*&c#aj60muA7qcwWhP zs*J~v%`QJKexj2f|Ip-=ITroLk=Y`)u2R#K}N?9gvZw`zS3om%^* zs+F5~Q@S>xEk2d;OB=O2*FXSNA@N z9&ZwDgqUxaM%wQne(28Y*?%y}S(yS1?j&2U_UnQ6Md(udXI&mWJ_lQoGojnD zR~Q4cx5~g;-3hB%Po>XoV;q=uZqIk%kxH#SyS^)YwsQ~oaC+*!z`W;@Xe~b27U7dI zNU#RbUQC=9xb1>hE8GRIH(*y>0bbj?;nf>I`N+J9h`F9z>Aua4)kC!T)PwI>84&!p#H@C>Q1sCq8Ud4y1-dmq`*Q5Ba82U4knWh%vXjQ#&oi z&UzHIchd1tyUl*xC%0}&75tgVb#$La=ss20z$Y6|wQ1rw;R~CA$_vdU9j9<3T^=X-SA z0H1+_A<%KE_>$-NKtZ?Wtc{aSd9e%6{*aS+i#g9^w z1ec0qYb6dzwn5@-=o%a*hzY7f$F0Vu-vIpkXPuzF-?HCgm^E=Q`-cxa6)e%W-=wUe z`x1PM=w0yQ8mncX{Z^GLW86NxtvD(AkbO9_#ShoLE?l)o*jGaR$mNM!g2T@9>aTO^ zUlX2Io~|9@)?YZteyLmiFMIVL>RSKjy!zYy^$+i;zt*e&s`B*4e7F9(LH3qz_5akX zAHR_w{<&WL2mJMq=&1inul`S$r<26j8~h{&*^hOr|8cMW_qx_!>ec^mr~ZxLhjW6* zZw!t+?*MyFlI}QM;I*@ec8K#e?L>0zhHmZL=eG0wKfAUw+HGg-JKftkrAs>_ymoG< z9b#uqJI%TFqHgUhcH3Fi*0r6m+fH(C_jX2gX(#BlQ%^hS#ikuA&z{w-ovYk-X1v|C zoqsKG=zU`{bH3>GAhh+*OO7`Eq`;a8y^?!@dRZeh^;YHCCEeDZa2ko{e!qL66tn_)DBh(AoEB}|^+5t@F z8}ZNIGn((#gzHcK{b;@)!}q3K>&eRvq1^dixw1hgg{L3oD!g**PF}7D<*xF|1#(YX z-{ES`iSWu*pS;|=lw0DJ+j{bHf2UkMZB{) zf6l}ABdm`Qmt@AjCC`3(VOM$e48DluoJ%m`gL}qF z;m(Ua?!t{Mo)|{HO716r8Z3zb?{3NIr-F7F*L+7uf<{i>_9L_{-?!>GhwrgxCvFV3 z%vT*n)DaxmGGBgF#p3UV4hwlkJiC4Vw~6VOA4u!J_!NzAk>{^`7 zFFqlFpGLZZ=8zN38D2f|H7ufx=9pUiEGH^k$o?|RDzzV2>&>m?p8)G!{L;lCNk&nG@$6w4#I2{pyfQE0IgPSffogl7>S?O%*8-BYLweAbXE&QSEi%RE4Ls4sF-4tuzw$kh= z=rIox5At4PDRG9j*5qn5hS+?`?IC-H@N~C}r}Mzma&o+sT3amk$SNML4`n0$6O)WQ z{t-F~I9m-47ncpT+rU{ZYus%q^>kJjPej9Zwx=mo~0j+2mmAU)?$tN5Vp|ztF5`#eUa$1tAlHg0b67e=f4me z9j?C6J_>BmUObrHGUaZ`a@H0sa!^?BZ7a3*ttgcbu9D{q_$7-2X+xK*$AH>70ruY zpr^mFN2?_Wo*2tx(2Ru-dZlCmI1+w5yYQJfxoW_R@MGbh_V6Q|j1-Q*&$cTV$5%Cu zBVx-$FT|4z_eUlL;Nh2vDUYNl)As|c4|iFM2N%f+o%rbB(`sLTHMaARZ3_Ypj{yI3 z3tidPoNsUP_ZdF@F@5%UWE?Re$v2^S@eg!=#kDSrrNqlRBIE-Cju-*TX_%ZKlnKYZ5};? z`s=qMAGehndU}O3#ehk3goV$>$|mm*bYHa@MPiVJsevF_B;>Az@+)(TG5p||E)X^ zynwIO>)9WO3=B^Iw>gn?8)ZcU`^LC^5r6b8i)*bZ(lZoa4viHmo}uA)*u5{7miO%u zAKfirw}61=z&QDXO!O{oxkt_=UntHrKvfS;H?J$dxtx!ogfw z!!PXFGG!6+FEvK;rf$j~D!|#iNP4HP1(9?y_|cs5JKZ-FaT?3fd=|8ezRVZe*dIYznZ3$C}Qg;P~-C`q&1pqO}cu zjGt)Nr@*Cf1-;3CV0{8QYA7@N>AX6%79iPL%lnn+Yu;Wt$<4u^xJq84 zYi~{<{{!y1HP?>9M*_XrDu>K`P*?i?Rj&K!_fxsnX3gDs%tO*cm$Htrma{SvgV=u^ zJn>l>E6G`^^Kt4}qxIUkn0DR+M=9oMe{6$)Pm=cS2>-VTR_H_a!Xa>QfL}&30X=3c zeNBvq@5ThunKJ^8kBj&6aam2Sj|<)*|DN%2eKpq2$HhC*=$oD_qudWgPw?C>*T=Pw zdL;|Vab=&@;I5hTU+dks?a4G1o{Eo)I*gBt@8sjkqJM%-;~>9TYa9Mw=DBkDsHtn$ zTbZVxg1=NKc+&n~uJJ@yOiggc+>aa02cie6)6) zq+g0Q487b&9v2d0kz|AL$;FB#tXFZB5mAH8;$R4bM9{QJ=Jrb_m8 zgkPCt&t(6lw~utJ_P_e}k;=YO-G)DCTQCYf`RfJWD*R)H-iU#b%)(xD@;gF%W_=ra z{lO{F>Vio6@8!_wyh!?Qx?xNlIube31O_I-9lu?TBU6pPT4dQP_Xy=&?FV-cQ=I%>-UK8Q@i*AOdk&#s~kvwtqa-mRa_FCgEGqnCMSSLJd})G}bbi}gkErrA4J;hbYr z89Fg|ERUgz0W?w&gEekJd9c9mqb85iLVSiQId{Gn?z6@5Q& z{l0_lkYg#yF~-}BJ2db=vZp=T7zu6El%-ceub!OS>3{Fi&MNFE@4d103~#t}y9Byj z@_xEaAj1#9hquy~4}vGRgV#>Z2Z~LxG`G{2Z?oswgGKzNd0MMtKwH^us2=J;V<_Z~jN)P8i$(WU|PBLSUTb(8HT?iDxf-9N;A*mwUR_o6fJ{c7$D+4uY@ zo|$-O~>_hd4>!O&~6T8Bs2BQFE^ha2~Pv#!!C>mb)}w0x1Jieo>uK+ zPE5u|85uhb`$zS??ZT%zJKv9pjpY65ynmDT1_to<=dz zuG)8?HQVm>WmBK}_#*Y4&-E;RqLJFr@~^9`Y^7%Q6g|fJ_PTez%sCJvOpbBR>|8sY zaw;>~y^1z|0xVj~mCr-?*ZVT}TEcaN`(Ja|9B?<$z5k^596GLmjxTWUCG%Cssowig z*uJ3oxQS)|j*EkH-FK(C*Ku4mmdX>LZ>68;D*S#8_`EoH$*eH(sq%k%GV3yp8G6_$ z?id}0CY^6b#Fq1|^o@JCo=D%AqHobRZdbVnBk85OG6yWt75(%*jXyH}^SVdIFV+b=(9wBotSXe!O!Xx619eHy?DL3)Z5$e$ZTyD>$Lu*@B0@?qS{+ zUH_WC&Yq!2ZTC=aUfc4Ve&U)!^ z?3q!4^j>rwOLqVEux)exOcmvDM&3GS8fB zZas^7G*%|guUlN%(IxMnTmQ(~z4Cr1na|AJO5GlvuBXimwp;hOvg4dhdCWb#HQ88J zqJAF&r{SK~#FrzS`J{14J9f7DU+){EF}FHQ9FG?eGR`b_skX`xm3<;&Z4JkKtEHoLy#gwx|BU7=n9^M+}&n>ElMO`&h3v zF!ii3{wwpp)d$}RXvp$lEF5CDVe9&7=pU@5d>9QW_R&v6D`cBMLzURcABBGI0`5xp zJQmq^Pm(+6p?@kCMdxYfLaueQCoxtx(MJyl@?n3D?|!4Pb;k(5$i$m?X8Js^!o(by z|7G;c{{`$x^5Sjmw&o=tSoAXv|8Io~L*w=aOyRzpqF76in3*7nS%aOVN8Ex#l_-NBIjXV2lQ|R!*rD#6NxO8m^2pYQcKGSnW`t z-_N0$_pn>Eu0Kv|M!wht|9m0(IiAp5R}lLOunZE8_t78GT|<_=N#hIM$*-?EytP(8 z%{?S}fp5;_Vs`OxsL{d04(6OBbB|RGE~>FHx2`A+Y;7<&@#Y)h=344#=i4;&HjMoQ z(npe`;4|{R)D{nWG=&bay9R%b+50ln?0s3pUV|Wh9{G?{@)xLW`cc80mx8X$`ib^_ zV|&i%jekmXYv`G=XKwtman-$8sonz)N`4eWg(kBfM}u%U%_?0q={8L$9; z&VnwLvx{6VyUzd@=q;K{cGs{^L^-Up$Vbh3fcDjwfXgH3zsccc>E-OhGJ9W`-+xIg zsM-6%KDfgg>&rXFdS|$3*aymo2RKUx*|yWF8fJg7+gRVhSSN2{O>1il9GA^7UYf9VIB6BGN$LC<~SLHY;$o}5FT&;Bj8goRH%JLKe-@zas9 zE3#(9Q!Y*nPqR;@S^HE%Q{%1RtC@W&>$Fb=JgsM+iZ}lMx`_6G;~%=xej8WeE%_3A zv9(_XIxw~;`36X&xpon7qPGjVa18tZS% zHeend^>@ei^X5veEvpO;Z|v8)(v8S@+bx?%S?!Cyo$J@h&ZazXx?jTmBaD&mWsmAA z+r@c5G!>f`*d*S|U*UbX!PH+6JD2CO z$@E;`IOPjsXYgD+FpjHuAl$<_1J%z1$)VO-!R2pfB;^O|8FJ5SdkD|OmtNcV(zamr zf7hQf!iE34-aPaA3g4Ua#f=_^e*Tc?+o#9<23XAZzCItG;>6rJ?OOJ?uw4}cp!+0x zdnJ8J`1JP8)S+0t8<0CHBRkL7Z*IKq@^5$Ad4KewDv-5pgJ0$lO|F?*3WxsOxI#{1myT=8|`&mx)JB^4&rB zrGWK+`37VoB^ob@XEUdThYlgfnMMAv=_aR{&UtWhn&rj5qWPG<$p=xVyhPYstc`C` zeP@1~wU^@Zl5m!F{_Yi#csur&@ZB10nX;!}%M|SgmOk4`-m=7ltj!+9e+0k%>$~9B z%mthg!q{ouCJ}0xasc?0Gg0}RgahSv%4`TY`__0TAN(jgxVAZLO*)9pz8|pgTuYT3HlA(#Qz_I1K?m(|l?DxT0v@_jl zrvQ9tO>zf&Z4Ey0{dxElt`s+_d_%RsREu0mEWNk1b?JSjRmc~`NQyqMRX^x^n7uBd zwbO-Te65U~y$4+BOcP=o((~xM)|OTV!QmL-P(SG7o8&R8mM@upZulN$fUzSc7Mv(g zg6xK$-{r0s@Lw^pH~uBl#JEgs1sBHe#dorIjtn6u$3sru9>v;Jz5`rM*sgEgwM*~! z@&2T=LS0>AWvACoX+Fl-;g3vFXN>P}#s?rAt@?*kZxQusJ`fy=#qq=PCl{8n*ybtv zF^>Evl2IxrIqJmjFKKVnYlc5z8gHf?qK}u9P~c=E4{B!d91+w4A$1OC!tF))+zFmj3uwn;o{y=>2rk@j9Ej_ zp2#^yk_DsC8#`m~iO0e>k$eN#!q%39lb}y%M?R_bU*b9WYw@RSIqLG*;~hDDEc+eN z6f}q3U=Lqb+OE8Wns+vr($1xk^pCmja{29t{C^+60h{4B^v>@5Rsf z;uzX+>Iye|Cc!R z6Yyld_+U;aPa1y`GFFXT_VE!yO*YkBtJS9?yDL z(b!NI=LIg#-^aslA77;{@$h}{djHj$1IcZ?l=FRV?N5IP(C>lte-J#JYk1h$h48I> zo#U>84~WA|cGG#g&VO^F$Ce^j=gp?BtEltJ=Gw(_U|Ppz_sSRgmR8D_F?8d?Lm8O`Z4mGA|u&5Jjx2}MdzDa@=0h8 z|DO0dHre6tKXTnTp6{~Zl_8V~g`ZqsfQ+ZiOT2r_<;fTLFTU{Re9e)H$1LaB&%cQN zL5}*dIW6al1>x1&2 zOyxWx;ws1`TGiW%tB-399`ZQ%U=CwC+l)*1FCM4mt8Xbe+H_55$ZGXjeEwh5>&f67eB&e;e2{TMHZe{GvCp~V)Z!bbm#M2+z8va_ z82IvIH>*D6#GltkmYMwYoTIlxbFmo*^6!C*YcvjfoN*XNPIHaL#+xtvlKF1;)aYSg z3kQao9PmNb3!HC_`fcywTw;^N^F}V%lSN36Fg*od+`*jYYS04%m?NM=SNre0)qdpZ_68M!h zH{64B1a9Yyh+pzQ94QHxSXYf&XDu1aJ^Zz4Tv4(80B2yGv8?t>GqZD6M>qq^I)^x{ zb6QGw5W5pRXIp9L+-*~ObH#t{-vz6`_cA%c+sTEz=^w zTdWI1R}@{?VHZfw5~J^TV!-Fni<_Unz>DSiSoxV z_f?QX5*+@lhL}iVaTKHZd_UKZJsKa@OlaV%@X_d&DZ6L#o?OdY;l*w2t5aUAf4vUf zmv_dGuluIe5kH=w?y1}r zk9anKXZ)|$|2+PWw3Y<)e+d6MlPofvvig1#&qnZ!|IH0N`-HWmO4n*@N&OFry{uzw z>fEt$$HQWLf{a6e@u*-7G#2IVI0)y$eWi$ak}H8;SyM;cFy?*fdWbz$HN zjg|1OGJ)^Y-iXMtY^xO;_{Q%j-*xqql0(X;kr$hKEYoyl5AdMA0dIZG?OS$mNum04 zZD>hr)a~P2fhG0&ufB0sS&{x1@*g~H-N^q_o#$06_zpZ3>e|;@()t82G}GtikKX4{ zbHy)2cV6FXpf#`m*;58gsHK0xL->2v`GMvS#zE@_U~31qk=AYX`meLrIF}>wh&6Wz zH1Kidm7?!(R;Ko+{)V-fr#RDF`%nu{u}{ZFaMr^V|C|>ai@#vU>_}8`v32mma?MAL zEtA~&chk7rnSW0YlXIE*cXl>$?`}R@_~q}H2G;%++4gb8LEsymv|2^%*7rits>@qN z54-dSEhbhwG#9y_EA&{l7MfcF&8_(lXl~6%qq$lenp^Y1G*`9;*!D+CvZ1?hAbY%M zZ{33~?VSd15HG$Az9SB8lT`(rRV}5#qHR+ouR~SDTEo-5`L^gQqi+c!8)~?ZAg{~d z^YRfjCzRKc)!pT^RaJ3Rvid|aI@^=c@PlMDbIBmCcUjpp?kao0rMUPkXCaZ$eH-cU*+;0ebpH6aJgf)RNk-q7QLyW$Oy(OoYU3_&09r^lx0wIDTAd zt{S;z_-gWkI> zSYh#sfee17=VuJd{89bM=1iCQ~g zK7W|&&p*a^+Ip)sw;p{)^X`-6M@gwRG-7Kk}!FJ;ZTG_v49&KWXuR%C>|3_IH|H|}Qb>G{!-=(tZ= zn_KWZKR@XGd(QFme0=d!ZOx6a)@?O&#vWt(Cvt!9xH=N8oM6`MH@#Yp?H2Ed_t+FJ z8tKDRFuE5UI`KF`dzy!*s*(2D-SBiSc-qm6dOzpjX$N>Rwsx;hTl>b3G2I8Q>72h` zgYLJG5Ax$m^Xq0CxxXg-*^2bW+l<_2&*5*=;w%58#-Tpm|J_$X+o8(d$X@9+2|JJI1%;}Zqb?cvR4de2zvg>2j&+4h2GrJBdPXEHr;Qx((Vf;t%FN`~Ze_<@^ zR?LaAO$)9+PJTAlLeX_o_-o{QT!bG_`ff{a`E^5a>ASn}=Sb(h9zUP_G{0gEa*oEV z({J#R`tniz29?Dh?l&kJjc)7u4Yn4!wi|wfYW{ovlef~DllrLw#2Uy?m89SDWqLkL z`7@9CaANQ=h`fp5qdFgdR&R0vgO?W8yZv|(?%wfz_fc`V7+gw6{vFph`Q8tc-?u8f zSGi@ka{W7H|45roKIUHb*NG*RO(*}F?7GDLz2YlJ<1fA6+0Q3<)JJdqI(q)mrtQ=r zTDb2P*1AF!%PL1%6J_(XtZy;-yz~t@x|UU~cfMooVA)UjhW$((?QR~$w>MTs+rcC2 z2AdPEP5C8!eznAgRjsHmJq@}Sy;aest`BhaXz&+noxR@jCu*;EqF0ajjsj~-qSw^8 z`jF^#dGz!51lJ}mr|w>1_N>S^*26B}nQ8ho^`Zx_NwTIl?%@hg?`5CZ$@Sh>t~7e@ z8moDP{md0zdH9#aAxrOFHOk@P6Y0ILiHAFV7axu8KceqqWzL8DE~)m`8TeDsI z$9JK#XoRCHcV(JZGgkk9!8*3rhr_D#gu268&E7NP;{(~<`cbGn}XKfnFy_&POdrZACGqW{xQ>ZwP>Hc zhSvACO{v09jlZ9`e$I?#ec|A|3f2P3IU~F*n#`JZ)SO%HlNH_h@-EhY#lvst3hqbY z=l+Mg*0+K71;q=jO!e$hz5)^aASKF*?%j;UZaXr9bxv zM^1WqU8-3N8w(sSQnn?C4&6JF{;6Q`;q{Rd;Pt1_ocOq-9`Ze?9?6j#!M7Rfdphi{ zHQ{x`Pil9)&G{-u2TlyPUtt}~ujB6`MoIJ#9@aV6hBcnZ1!CgtS$n|s?8<1Ex!CKs z?6Quz7+XMVMYZ%{1>?k?dt>{z^6hTManJUEJ&*l4>WkJmB$pJgni8a(#m&ZEF z?+MtKo~S(XYimCI2;O!VvlpXRPw0|)Bgi?9t{mI`a#x%M3LTtjy+nBX{hy(!izDeN zq9fwjC+iA~e<5D-ryfpQJMCA`zHf8w{fEKhwTC;$QFC1v`lYVoKV_OCqF0~H9q?u1 zKs0~&WbRwP?+R&5hysr)BuHLkv+*K{)|KGaeH>J;CE7>o^!w-Z+tA$B&iSBw zxyvc{j#sW#@wtw_#3>iHUjUCU;y09? zKChTm_%8{5%z1PpnM>!CJ-w2ccFBRnwwLhH{+=@-D6^pK>8fq+JlxxQ`buzVWTE-C zmpxVaB=jxkcO_Q1-?_Z!$rH(*Cnt~-3LQb??U$w7XuIunWCinhO!;$}$8Xm6%;Pt6 z=C1Ir?;qv+bA98O2nFqrGL{<0))kk;HHI2X)%W&m4sG90ouch~bp=PKL)+rxMy}sN z?o{H-NtR!JGE*$`#PW#-;OJ(l(dC#KjB)w|~$>%MM^{UG<+@9V@G<;8kX*BE$P_lo_})#TWsuTGh8 z?8tdepC6;oqLJfVkwd1e@U;RQDR$YE2RHwK#+G^az`d96Z};85&As;0I`!wp_He(T z<34C##P?o2f#!@ic(0t=raWWuI``TO>wUkA`%ioKjO*|CUVBeGcy@6ADeoS5eoOhQ zeD~YASKbCwp6`D_`5D|RcEYP;D}DCxbf)*5veyVF^!aJ7+IQ^1^aJXYo#)&Wuf)Cf z0PFr7?>RXBF3-n%_l)O1(UTNok4on3@1om(_a$Ct5IG?jH^nJu6Q396JO{;WKXCJ+ z_Lq|Aj_O5uQP=*#PB7T4~S+~Tc(}= zq5i4?*5+3F8>FoAVjn%598=VD=pD*V>Rpo9-kbQzEc?utGEIjTu=ju%v<&+!V`oZwq=$-CecqgX#a<=SnXh96OBs)Op9X;7{?Hl5uML zd$gnd`RxnK(no5@kpP^6qloKcyi2f0KS>|6Z(cP!K@O=!wXxg61FVvbyhnyTotzag zd8H052#}{cKposedx;uw0X{|-TlQ+3b5rT}Zr0QM{k~uIZx7nB?=Uw3+W}(AL=%4a z?x75^Q17jyPl`=eAIU|ORy=2-v7ESmH~%){vY-En#xQaJ75uW}tql==y*TFwA5TM8 zJUH-JlSgl&Q;muI1=2q<6*(Wc@7V%Z8m}YEoxT3L4-|235AEuiWQKXh_#NV2abAVg zzmDI(xYsdjC0lNA3+Y+x%fWs3cZ&}T1BO!XSMLEpX({=DaP!GQg> zZumTp@3hzE^L4H~s|eav%+JdASnEC;6&k#^+0e)B?aG(35c)9tJ%Ft{?oZM9ARm8^ zyt;<(JLJy5(>}7?IgEbaMedyJ9KY@TUpYiP8ggfo6$v0W!uB3y+6~|%Lk`Jf+k4ta zxX+wzrN1iqkwZQlXr;N~h0=B8y?Tc=fqiF3(nraKQAHfeU(O+>K5NGXjxGf+qVpM@ z$;z?Q4FUU$GhMxj^2&*ShhlM;mZcBgNm<6DnZ1(ARU*48wV+otF{+Nen^yWc+Bv8^ zUk%v0e4BH+^s4#M!+RLpc?+Vod|S&mqVs+8vZBd3y`qQtuBZ5Lf)h(-;p5m$Jt~s{ zPT-=?y<~zw3u zQvHR<66@W`CI)slIBf;iW^(L3dJFLbSx%poLo0zDm?V}q1+RSzSPdSx_9iE6f3x0d zbT7Vd8&eS7yWL7pxQy6fWQ_Xs9r`5vR3Qg+?rzid0q7_{_N;k+Ny$oL$(z|Ty3Wnh zt$nY}?Co90-rhvR{p43@G`jfDC@=c^iN14jxAijQz$8Zw2(~W*TYKXrB?gBH2Zw8Y zI1KB|RoY(G4W`>%m>&0FQjTuwsU@FmK6q8!{-}_(WDn<=IJvC`6Z<+WHW=Sz>+-Vn z;k(O>AK)NkbpU*gwK%7k__jKDD*@ezkFV%stu=7fF+Sk_7U1%7>Sen$rrbWVL)tj6 zQZ$x=R_>$ir|C+df zL(i4hHpyJ}S)LhK3Yn9E<)+O@rv3^)pYX9 zblRQe!ZOu^!Nte;j|jt*ZZLTGxKS{SnIBD!!WRo1fb?qdb_TtALlD9}yZt36zj~!1TY=p z{w{O&$B$vU+ma)(6-9L!N3g1>d_F(3Vd^2Bc&au``6z_riy_9XGe)UCj z%5KW-fo?Z_{a8~Qbee*0C0|lc2BRtHSbm>Wu0?#hHP`U?=gFr*e1-X6l+(fQZM)dd z`#Sr1-*ETyHuSSE;LILqid-wml^I>->1ft<)y`qs+!5?1#};?e$3*WuQJ@>?ddddAl`ToG>@lNC+TmqPerUBhMZ-4l>W& zI)HCHom8^e$QNW>r)(J(TL+#7)3#SOTwm7S9HM??Ss}Wn&VJV!FHMw_ewcX>9bvP9P{p9*e7x5QRx`lRN=9nWW)D*4~sSQZ}# zJ)|0Xm1Gyqi)!90B%f}IvjoQ?W0M8p64jm9fV~fW|LNZ2P0i$5P60>$P@UM{`MM%uR(c0*~?B`Uuk`VvtLuR?9s98 z@VeZVQtX4B;rdV7(vJ`41k#6@`(PmmlLGAj z0T&Y(t9dyk)-duD0Aq93%y=!&*Dt`It8tvyuf*!nGu}+Tk>EMh*+YGt5x2rU;_KKe z6R_xO&UEgBl$jQ{dWg?h!=le^;QcT>DLrK&c1b-lMmo3pAiG}r#);-X+5VE_-kg&1 z$qVVj8h4McJzR(ezJHcO12L}oluK=xA62ec!?PA~$iVego%a};A05j+zAkNqI%U$& z(JK?V+Ospv$k*$7qX*NUALGLkZ9F3T4L)3>_88w^Ne|y1vVX{$o$@m#^?hS`R62m< z*=2k$`L+^Yk*<1nAODprY*fJ7TZg~>9@PbW_h=8n8_+5_2qcS=Pn1O^mky)fIeDtF z^Pvyy8vA-|tBGI3wgR@*E^N2Cuq|?7YjR;*>B1(R*@NwL^@};@Gp1}LeH~Z-JR>{7 zKhF$PdF)2zAgZQ4PbaH;ius7Km)zJrp=FBbJ0Ti`Hw)RnwLTPPKUD?v($nO!SRd*Y zf4ncYm`m3QY_V4CFhd)%#kTibIu}?`?T@$W_8M&!@=QK0r=DK+S$rote37fsg^;~o`4=cJ|CVz3wJ4dfHFF;_%m2(JcJ+Gyiw++28QFb<_jD?ZO|cJU3oD->1BAp?mg4 zjvwm1gD1boI}d*GD0==DmC@LG{BS+E(lhPl^7sE6d@Ee5-Zui)1(GfLU&2_5f4;{1 zp#f`>>hgcLlII=pqKnmn&hg2Q&83|7y}bb4&ZTUJKj5m5?hiP~ z*nT8`K*PvajynDT;skpbeQOUow($pqtn^`M`4IP+Ous08$@I$o@G&}y;^m=0 zd|{tsO;wE*@w$dO=5|N+VK1aJ4I@8L_8H&9_F+ah`bQCS*@BAn{)Oc2s;NjHxTzw2 zY_ZA5)8T_i%^QdhVnFm5F#e7HOJ|hMA7PK5vxh!E#`$;Yzwpk;RM!u&o%3hCepli% z^!Iz;QuHdf-@-uzJiES#O~x0oAe7!A-T=;IO~~kz!bxgjD826{?k@_g^~OjzD@1?k z@JUqU8lQyK7>eItX&*zt<1T+2#PuH|+$Qx9% zvNSn{T*>s?dhbE<0a!L5AK$=}W| z*{3$%w4OHjPT;fP{wCp@u{_9FiiWFL6HYRg-*w@hp?c|;2Y0y(_pRpnoRS^*EiCds z1R8dfT5g^+jc;=L98#(|K8=0kD%CiNh7O>gA45MsxSanD{5JH79%~Gw|U4Uv$c-9px?AiVmT9{m^3kW8hEt zx{2@g z9U0p|eTUw3o`Caiiroet#Czs_h1QRF|6mVu=791zia(sP7ukj6*ipFy3$ml5`v&4| zlY;38wvp8nJA*MuPS!o^s@us04{j&C0B$Ec>ms6!)O7Mfy7ZwwuV*iT__^(3#;t;K zk8wStmwc-7N9+u*>*Vt`!A^U7X~S6u9%v8ZTq1aCr3_B?s? zkRl#ttnm|+0iWY9k_=B??8voL@qp+uV9|Y2HV}OlZ6D^EU*x$(~>F>J#gZ|E>FJn&BU-GfYh7nH6D3f?%K6*F470zPGWJW{- zeX>_4Gb5wP4O#ZXkAi1(apT_z1=1;U4`#4!GuX4KT&@M=sEk;f+kT6`k+HdSaCr6D zq7di1Sn0jRoHxa@Liwf&$JhgOCMU8$zWt5m#9qQf2gY}u2mWQw?wen-vYc}_kkPe0 zoSX^;z$rQy+!NY>*WT85+_R_LtmW)+@ALcWeSYjs?)SiZe_J3vmJd#Tx?KEl`LQpL zhW>dbSiJc~{3JeFd5N_}bS8cxzu1qJ8?~@8Cw>5#nhlb_+fojXxlWE|RFAuE|ba zQGZ?cxOE{fsB7oAhoN(PFskd|6Y#dLzT^VtXlPz_rXJ$_x$)#^()_p~m<~4dhzCNn zg-!qb)mA$BWH7yzcxwya$~MIw_d;giKWQOG%EFG^MvT27daSZ3J={=j}uSH?3Zq<2hVY*_>PLK$;9I!G(}hWNG>e8>l+vYrpM<&)Oj z2syem_Y}^9E++&Szp&j}k!{~qr}<}?eWMQ-)nDq4i$EtXo-FT*iw&K)(774vf3;&v z+kMwk_Y>u5leNw=TnjCuEd?t18WllrLk)Xx{_XTJeu##IdHU_e3G~b`fAod#IxdI z{6PoDxjY;wYgfL!f4lb{5C4n%#Dn+=pq; zmg5I{u_wM0XfuR-C~UkmK2~wTMU(8p#_V|b*qb}VyYjanv+yrpfNpBVHehF&IblnO z4|mhd>b~|~blpn%aM5Ry=(s87k_i0J%9vfHGut#LH21Y9v-YQY#5;ywC{xP1XBVCs z0o=glpXbh2jyzWvZDs!7ja{*kavp5|g$>uTz}l?3H7@5OlOmi^$9dW5QUuWBc+_sJ0PWy#DgQo4|>Ja}er+xDOB`UIv z9GHo}LhT&PAkzc%`w(aL5dSOsH9X4P^Rni=Bb*rs&*d(=pgol#?+0bXSLZ(~o*HHs zFU04wxJ)z^-^jZ*>P*!H)AB1v8hgh_hc1t&&XDX2;A6flK6)v#=4|dc?>dAXsPm`b zBa>@#wo8Ax(4%aKE4tC+Owl84I&_%JdJZ{$7=z@z>qQFFV9*FRNTKf(C1Mwc{a@W&-uptz$BKKJKu0HLlv#(edXz0m! zk$?8q-peB3Em4Ckq|Son$D1OJGmQ_toIXnrPUJ}b3@Ay~AorL@EXKZ^{)`RuX-_^m zHCouSr;+Wg{VDe#`qQK3j0HL+w9vL1`pE7Pw;HF#Q={M$#>>JE9(%3@pXy$7!PI#2 zA->Z**rf7|-yX-O{A>9ghl6YA$LNsE_v>0R;+uD^$Z5t;kjFW6o;(agN7C^+*79>Y zZT5d@ZWUgUm9K2qxXv#bOU`tSujVqo}o zgVlEpow}*cFgN-seU{xV{Zui4vJYExuKkN^o@K$YQME%YE*Q3qP|oy ze$rEah254wXSk3U=*0E`_N!buLw$T=d)VIfyG+v^dE{iI9^>ni4Xg8+i6u?F@o5ux zl)`@d4DE?NPIKFpeMWxgAN$)DoW@?G&2_Z-Rh9MiwR=AY^S%pyed8w|<9~!-aI*p2 zXx>V)R;KwW!91Zjr~vY3kz1c1U+RN&dq3Pufjfze_sjP=JskPIn)6^d)`?uZZuLWIgpc#CdU=C}QP0ZLOpznL`?$qz9C&BB&x$E<31Mi0Su~Q;Fr^YK^ znbDrYwohSGMjCs>BR$LGmAiVkZ)8nJYdJ~ToQ=rH?27n|nw<9J#aYWDt3#X@7m1fO zATP7a;*r(JEb&tUegcLFXW(f**iDB{G<{|Oa(QV+VVopht z{A8YQ;zTs)`74aQgj~M{dfR8Avw*vennRJTt^AjrOZ?zk$)*cg&yc>hOfk90a8vF` zXYRpwR1TScocEF)r|F9CegrnC;y3$g45z!_O`?AOtA6IRwFfuMh{_Ic#RflcspGfU z*nodtdh#5n-0PGpAPzo4F7xCQgYDGYx%L5kS(!J3>4ST*NuilY4r?NB4>rD{H7}- zBq$dq7C_Is&`+pSCjUg^O&`42hI=%Qz_5$)x?BFNyPY+&W@4x|jdAA1Ogy@scDuZ5yv)2C&%0K9a9YD#BKmJ|e8GwNnYmZ8N8~!;)78fU z0rWBOlpwC+z^&!!)}`fXVtUtR8-^RY?p1$`oO}3( z)JOD8#WY=AiQY?J4$)uf4YIeAcXL)WaHSS@(x_zIA+^DLDIPhe7wdr&%83ESKdtZ3 z2T~Q~Zd{l1U5Y+v?Ia`|;{ywDokky`s++#*-O}{$HjLXZ92Pqoy{j`$LjHa)lN3; zXx{f=_rvVK>cH)X8N76X*WjRzJk|6?uOXfbVATto1o_&zO9hd&T{U z?({6lSSDPWTLAvex*+tSccKqJeb3>&VsFE4eFwYAu}gX1(H1a0jw}!zsjg;Xc^~Co z`pka;r=Dp&PFJlL>UurbJKg`1hYwQzp+U|ZSxMZxe~vtdwxn0-yVYEWxc~2SulIA! zcK?e%KjX(k|44ei?_RplB>7GXy6QUxv?2Xax{lh>9uQsccCWX(*W0;X&abn*+*rA< zezkv*{~mo&aV-J&d+Edh{9c#1_n-Bi!?#~Wh6%p@lCSXMD(LYX9ZuTx{jw|MRqB-sn+R_}iQRVjZ zvR?)ln&X~Buhks)GwRWrvEcW3;Y4#@BlT#`6Ce5Ys(PM_kMzCP6*T`P#Y^t|x2*g7 zStp+hZ&4e*xv*L52QoQCU;s9V!zo>q5V3iLOTbGgLWpw845gW`G;%>6Zf#0vmWBI)e<3a%e%9* zXOMR*``|kS&w93OWzanH{H4{bnYAutJ|^a9fP5%fj_#n`>8Tv*Vg6i1Jhu2Pta+Y! zN&8sBU!9gdH1E=AJL5PipnQbr0Xf#@{otK-q)p+sde}2K7d?Ec75yghvhz7FB4Yn{ovpZ!#chG&UO z|4pgRiP+6LtJbr%cO}tC{GmA$u%$Gyn!P8iQ|{(Wq*nYXI*)lbv357~aQ4G%pSAX# zXwQl4q?V-T$|`7+Lz?|F+iFF)!)6y~XGN@>`p4^J264b~*VKluP6I@JPpgO4bD$3IxKiB4jkshs!Id+lkv*jIkrhm;S7Ke)aXp$~cA?}Oh5Cw%bx@_`@n{=?w6 zR(v2n)_+L->wAB2`zt=A{p&yEeXvK}AO1h~-aO2SVtxP4WY|$e7*<(AK*SLcTo4f@ z1jOaImgqrIPRO_~D1wN%h0H#KI6)S7hlmIxdPW6AM92iU<2s_Ef?|m17ZnwEP?6tV z=}yvBUDX>i;(J~1A6(jVS5-eDWkZU&DPFazJJUICVGve0#us4Qhn`MLwf z_WE5#hW+6+(cP{x!}@-c{`Q*av_A~5&uy%SP3*&b+qnH4@oY77gWFa6qv#q^ zd|Ff+pWn3qXByXUYkYlvm)ZH37`N{;sUI@YT~XuqT??>Dp0q<+xEzOYIA zK@&Z0a(#Xi`@&6)`zP7lSdW|77d6q7Cc4|?`r;<`C0iQX?=`vpsLA-@H>vM8;U6?< zKWU-|P0sH%;qNuEFKN=g+eD9>*>7TB)WkloiGO%a&L1{Azlk0;Y2R<6$4&Y#Y;t`; z6Fq9ue$=GCJ7gR`?wo4r_?I)?)y_Q*-{Emh{L$x{*_GZ?r0*S4|Lx4)Q{-Z-aO2-h ztW})$mOC$r?-0?y^=c6!C*$~Y9Q$wc-Lnz7>E>(5S$P(Oj^mImU#+BT-maJBm$Yd*9N z=8YTDb@=`_w6~*TFKiv0zX?)Dfs&@?OnU?M!!>E2*8IGf6c3zaeIro6XCzKJoRbn!&ku{=pKMz zKK5k9M(VvrQ)4B5JaK||}vh_PpV~<;M$G+=X zJ&)7Rnat`juKf8^SbYgs{{5+}o_7;_d~Jk1?lXry-pL)0b_IM3o>J3f;;_HoBc`myaV;r#J7u6&3)UdWYynma!ADt3Nx?$PY|t~`xBerYg!y!=G= zc=|nVX1)^Oj*GbCW8P)U*T2dh@40o|QaYEO@_~D9&lcF%-szF9dv2{u%?0Q@Jgr|t z^#k%U-+7k$VcuX&9Qt z(|507%XeAI9^c0K$Hnin`dF_0bGiP0`e(NM)Hk_fuDxY*Slz?5|0j3c)Mom(|g4!m>bhM^$XqqTtMf|>G|}iN8PEpG`;^)=F)jJ^AEwh;&CrX z=f`_)jW5~Q{m)L6^En@|?H6(V*M+;@iyvpp4}F6@K9#HA`BzpS#QE#C7^`2)`QMWX zRv)k;m+?>j{)6^O>i(m1=Kdp}-j4=w@0`B>xE}q*-GAhFT9M23S%;d_&}a01BinE5 zmz1I3-b4Lr!Mz6U&oepu-{<0O)-LvXs<`8pTz{|O^dH`1>&Jd%j}u(|kGT9a^?SDb zy`28$cdQ=bj+b-Sw~RZc>n*AE82pxa+5eRF7kWGq#}hTjIap7*1jp(1nwj|R`a-Ra z^_cTDdM~WUoQq>G)^g~aVj|XG&eR;w#PMmG`Xdj(`VWrN^N)pSe!;Fr!yV>I#xcv7sm+xNU%JcR6d)RpFzL;%)*)#0%8LzX)H*o&!;r!`R z&YrKheA90m+umc`_3YusH-5akn2WFJT>lQ``p?JNTf2@uf6*59_$@Az3wRZq2Ltu?ssM9o0=4j}D%}wm*(LUyFgPel34Iiq&uNv&U z4~}HZkK>L9aqX{prWw=!qW*dV&Z>S8HWGt`&Shv>w+R>v1{sT|M|$ z5b|W!QE?RHgfOCZY)UP+v>!a63 z_mUNOJP}u{UBr7_5gCKF>G(mf&pk-FzInJl*D7=W7{&R=PtP@*8_2Bn=hgH?+lc|# z+xe1zH}#Jk7v5*n1n(EZ9xFQ6qwApb-1OfWy;=Wl>t&C(^<f<9SxSkhnT#w(%_4u;a6YWt% zR-pY^XS4UuFArglhfZYu>CXUryyLH?Og@^|l+|yT&K|qCHX)=x$b=Wd*&~>xi!D$Hp&0_ho*R+M8|yk`wpH3tn~-- zBK>}BI+y<5w-w_K#<+ZXzo3kB>zC~Kk?o)9+u38$c={XiA-(SO{qQy0mA-&InelW( zCw4r23VucNucatS*X&qd9w@-N@Q|kPUmA ze9WG2)h70szn&dj`N7=rCm*u)XK}};e#+_t4rh<&=CjAr{An;>`G$@&ntVa$zjx&8 z^yyao&v$_0e}VRqaDE|q5$(6&u4hL%d;honF825%?)br3tiFTO zceZ5v>zEeoaT#|!oGX824qJXzclP&y;VaqWnQyYk*FMW0Klmzp>{-Mf-~I}FT+Fo} zi?Vv>o7m%#7>n88+ZK4C2V`${=*)h*@Hd)fh)h0JI4O@`~doX zMA@*(v#{nHqW|yeFu6bezncF4waq8LiM>ZL`v1e5O}-ZYpP>JLWz)$A;Q#6KFeBb< zGI<%^hcMz3*JK~o9Vg=1LRYP_7fn0A!M$~DdQEu~a;SFBG2{2Nth>bX-$Oo<%#CAr&zJ##pFjuO~&oz|Y|HteZBPO+!DLnPX} zl3ZiKo=KcN1DCbX@j6XwPoL4&`^R^Ln%D7OlshZPDHiNGowMiiEA;jpsgZZ=)Uv~N@ z)+b|+e^dq8Y{8x_7^}7M{@vwzUe7zV$CI_k?W-WqS+Hj{XU_$*^!ChC?5R)Xp9J0y zWjX(JSNg}*DH8v_oZMrH|o@-GYaoW0k;qhhU1q=49r=`G>Iw?~qHySHKfVz7{5}E!fkB zvuDmcy**zYoQn7Qls~UAp0C25`b_@>Mkw~UdPU+h!{qSwGpo;^&%cl7Yv}gECid{>^O}@5yS|`FeKULFCiTtE@7>4xX7-u2 z?>2efobPY5^YP^y``B&rJ|6!3X7B&u%m3ZSeiMH%;~Ct?`fii=@3;fT`JeAEv+HrY zjNj+Pw`Z3(U!OlVv(KzQ`S!vl{cmX5Zuxz+&u#L)ihb=*v-}n} z>EEDeY5K~>wmNN^O^Za+{C`Hi5@l4gC@G) zL^r)YllQ%u*>Bqa9^-s%%ExRxFo@q@eq{FpxBP?M|1s`o_IMjt{tNE-qaWDzYB~LV z?zoIA|1PJ$#vQ-J9ly*Suj1OP;`HU*@s(WpJ-5D)+27b6d+Vpfdq(K~#`Cdm5+L|? z0p0=n9G-#rd;;E6(b9F?uhd1-|()|J-5D`+E2cY+L!BE5pwT(&gFAO zX17(|A4=ax3j1sBY?8B!UPC?Jr*aR@LHAy6p`Lje{*BUS|n-eKEhqTrID| zQJ3e{r-68R4R{?U;I$UEX?eL}o0L~b-LF#JClZgAk>)7N@Y3ksN6X0G11$3TYos+^ zDCd;d4%i~%m29Jrulu7cuNP65=d}v;8X~?{s!T-j^#abp$JZ3trsXvswrP3w#yWB) zz7kE<^~o-g@UAlQ0LserB=mcrTZ*q{7I~qZQ(ht1BH}eoz$<4a%j;a!<$0aaK)g;j z;B~fu*QOB5D<8H=dEtG$%6fa}NO(#)ITB?VUK%|K{V?eN6kd6-MZ~L>fY&qV6Ky{H zqP3n^0=cCj;%ke_L=<12;~ac^RdT%6!Zs-{Jj<5m<(^(n)}t)LOQQ#&zX075uQ?Xy z8z|>AzLvli5wC~QCv-leop0dXJPfZ}P?wLdsSU*IMgv|q3wSkyZQ6WDV4IXzwYo3c z)g|ITy`20TWf@)?JqrD7=$3eWXOS1mIpsARwupEgCE#`X0+!c-sLS(e(LlVK8SrW? z;ME(pX?cCw%7~X+i7)Ku@xNO}zCl@*S5}Wg{~Wp{USlkdUnu94S3PVI@p=V$l8>*| z5ti3N)a7|Sh$o=jI>8t@Dl1l=&hkkcwxVM=6<<8u*qV4 zp`24*yIP8QeTQ7f$Jawzc>|Ij6j4!4^?`g$2A`?8frC z1a)~{;~I$91qQsv3wX_kZCYMKV4IXzqP03dY#)jDDI_PLEW=Bqdk-xnM?<&7Yr-kk zc%htAULM#Y;?+^WYv~_NnE3jkg`U?Am&iMoE^=X`09eXJg>Y4;?>T8S0@3lP2V(Uc>UO1$7^S1{0d~BcS~MYNq$3F@Dl3& z%PYzE&@J)WbgDI8DCd;dC$L4tYXkBmA7AHw=4N<3iMl+mC8*aB`EaqyM3fJoz&ZGQ zm=D{u@l^ubxcI8i@Jh5%@?i||HLiqIqAYj`b@zoOq!79#UPCO#7s@&1bpvb>@w!~V ztKv6!cG+Q1l#;}^;~&4>MAi-?z3!0W{lcD}Kv zsh-y^#H$)#_4~5E@vF*26kmVf9J=^|ZQA(S2-`SbRT#f&vA$7TP<@y>pU3l4wMAqz z%7T|rk3)YCx+PwIi{lr{Ipr0DEh1hk(IC$d zud893lvik=!pqk$;y$pLT#vF0FO43Aeg$+(yu229p`24*V_}Pk*XaUYe~oL#%nuJm zU7nYxfq3;W;MH5e>qFS4<@Hw+173;r^U>WS(Ps-uF3(G&yO$S|KhTyXUMJzZ;8yOx zP|hi@?XX3}YYXxuA75{s!QL-FkGeds<*3&X`S2N)i6|dFhjZ}xa4~Gt@|wf(`W*Xg zGWjrcj1pgX9><#-CJRtjriY>54c!v2b{69c<(%@m4Yr7Q-6-HS&C9OOpNYCWuTvX{ z*BAp{{}S*z8@6eA^@VNHeCSKRpW*O`za5_cMOh{vYV;`d-q0=a+F)`05apcmY71LL zyqXDkowSo(@7p`L4TUWtUIPWZe!P#(hb>W;=hdWv zc)1ODH5c%D1GZ^-CEYA9#7})@{POiy#;*Y0zci$R{2$87^dR)lpj+bgu*Lf?lyl1K zP1qvh6-S=r<7?zaY1zpRY7Jx(J2!Cx||$@vNAmhy*YFdub;5zL9@P56&Pl5 zKLE-(<@IxpnAg|Hb$on%dOpkRWz^+)#ZXU;uYKaRR%IfJuk|e+zj18@6eA9R=I8ywrTB#8*PyuZH(&1eb=%aVRU(N;q&2&)7bc$iMo7z-PS<7W*G3gQ^0FB zY}4|(2)1c?A%5umP>C;>y8keCcqG|2O#XwiGTnc0nEV^MC0<^O`4Hut@)`|WM7)Lx zcr`th<<$Xod0uTBh*ui}UhM_Eww%K9`fl$Za$eOcuTXv@*da`QLRp5FMvp`P2D&9) zVT<_?<(%^R2)2lLy^TD{$5-TYHXklUU7pt>)N6=*7*&~w^5Nq+2cHkGhHcvT3d1&S zd@=dXlYJj=uty~+MOm31hkhq?OT4)Gp{uq2`N|M|zEU$kTw?HiWlk&o^Oe`a7M@qA z`L5%F=o9))A?@=Hv(IZW7Yy?kV$Z1Zj^~aw!%;tk?=0S-^5yv*qw=HARi?iyBzm^8 zS5w!DSg!JH<#8%2UoQJ><-2?Lb{ejpNBeB$m9Pu^^0#K}%B$%Jy8^Il9Lm#kQ{R)F zKM&7feuTCeX0dL{JvHW#?k~$pJG3X$gV0++r%bia%bLyi8-wSrzr;MhLoVcbUUrV2 z=WD1>dA5@9jG-MGk9K&jM_V+$L_A+Zdz6iq=Lp!v^NhkS%5xjaJL2g%B*WAHK{g`D-6ocLMp_*sU6|9fuO#_s4?KmsKd+K_p$mA{ zr|-v)rO&f->yuKRn)OM$Jlnz!5zl7m2R=UiXQtw_Mw@RFd;Y+8@$zccs{PFKq~ot$ zo}1B@EIt!xkB`r8u#1-0=G)aNyV}>>>y&3q{f!%In89Z%$V#-w@YLvW=ubiaC-8g_ zc8GY+LBH`l-@Qc)B(>c40zJ3TiSU4JS(hpGL{ z^W2H}w;P{y{x6G9I^Od1-dCu z?)N(>PtEUlc6ly`9U`7J=r^9{#BNP=<7W}-)A)Qv?Ps3nZ4P+S`M-=O9q)ObC%`VA z=LFbAc~+ym)%g4zd%rT{XZ27eKJiY}@DX8h5!#dKN$3Q+DNpYHQp!_ve`%Me4|a%n z4naTgJohB@^P#q=Pk9oxpLw1w@OQiM+1h|79q)ObAHpu4=huHIJo}@(Rh~@z`Ba{G z_jj;wCHWHV$@Dn%EznJQ6885ADNmG3uNT3GlcJR5fLJg32~0PI?Y@>Y2=@fTBnBlH{*362Ys8_}Ljk3+v2 zx+zcGA8YqZNO_{1Q=a2shluA{=m(zXi^}|#Sx@MP`jqF@YCrQlJ@~s_p1lot((#_> zxj>oUGV2L$*hP7cMtQ3|nfP<5@4$~85eZKyCx89U#ivG3LjM)IDbF?*d7_+Cp4(uD zi03BcQJ&|0UG?#~9Q7&BUr}BZpUd!fyFC932D131<2}!F3hd(Jb2jXvJnK>3D$mcE z@$-0fe%n8i91G-r#x?f9U`8WqaS#lPoANl-}+FW@(io} z%*W?Y{M|0k6AXCL@t)^d3cGloU11mHc`?e{;JFj?p?a(*)EBtaJ@Kvq5zr(Z(H?jT z^(6E*&;>keHR}oWf5&>lpS#68e?-3Gd7gNIem&t$)TiqSZ6rKjLOXVOzKXVF@kz&f zo@Xc6Mayf~6BeiJYG1P*;qG*rdsnMg*?}u*6ld$`tq~j;bIgQUU z*ddC~I|MvWJEfWKeq|i$)A+n!?Poqd&%xjA@;uLgCmrv3p1olgAD>6TE*hUxQQihm zdcUH?C)VLp&lpt?hbNcnb9}^uEyl2|V*)hlpn@^aCHC-A~r@+_p>M*;nmn zp64gXLw0$7hPGt!NymGh=WnC+JlDc5%G2ePXGncUg7W-tAz6*~7@itE4E-7CraZ^6 z`?sa>iE>Wkvl@1Yc+N+^@jNg2RDb_@1L}v+Z_lXx%=5g`0ncj;c+&Bn=Xo6L;^Xsl z*hP8HLU|kUnH?V!>38M~j6^S}BxBGXcnWp*zbnZ}&`o(x7;Wu-1?8Ob><>FcJiX`# zp66Ge=z0G6o5J%XwV!#OKO_F_#^-NnOBSDWyytnYhh03+jj)UI?Cg|h;6x?gdX9_) z$5)aKXpiBk(c{oxhi=M~+m9uUPtATTyXy(7V26n3Q|LFI=S>2hWvCxQzrC*ZGtV>R zfM=lrPdeW7JkJ*J48ktTa}mlriqF6a3Qv5)*ne^*nSl0Ko>@H#{Q~HwJh|rwr93sy z58CB98g__y4nsfiJU=~CKYr$+KIM6V+Rr@C1Mqjd@p+H|PdeW7JfDMIe0+ZQtHN^- z%G=ISO|1Je$ET%JWo|x52Xt_batnPpB;js66p*y5!+S#EtgAQ>gp%i^%W42zgd% z))Q(26UJDa58>OT>iZt;=G*PCL&S3n@+i;q@X30ft5Bcv{2k>*@mY(%+vWKz7|7z2 zj`uvzT-e3)oCCWk&-YQ@5l>(Goe6^?$tQ})Y_!Ml)ad?YMWh6}AU;{1VT#Qf@(a)NmRdc}`kxh^?Ib*3 zLpyePzJa!6@kz&fp67Y6i|1JbyC}~cC~t!&o$o057T?N9tq*yQiuf-qC5zD>cnb9> z^oOCF^7OOM?@Q-HDCd;tEZ8C985Z!oOX11v2fG;c>H6(33D2<(c>ddfCmrv3o>wS5 znf2QtDZAR&(D}Cwp4ss+G)Un|-+AIGCP$$?CO$QK5PCjzQ=WfAzU>SG-L6AG6*2l{K(K#Pb<&;CbG)O}{^37V1-;Z=*czXP#$~1D>S@ zJn4AP^SlCf@$;d}VOIclEkSu_Jk@sqKsrM_P!y@ss zOUVqh$MDqX-g8RHjnMxIJOi*p#Pb651JCmp0nb6GPkG*`_A?)!{qT3YJdZHoNymGh z=Q{$PtzZ}Bc?QZm;u*;D438}(&CnjhQ==!L|F!dq86 zqx-j&kP7Ig@%cB5pVMK7i032$&$k!r=eMV#K8?=`wV(O;^f}-;%77;w?|Gg}U>83h z^1?0}pO>P%GoC#%<7cpKDd~asSe{uu4!tAve*(`YutUW2cjOm7J}+FL=lTBk3eS!b zo^PTZyYcxB+LFa59q)ObN5d|j=ToqY^4y8?j(Gagzpoq>i62r*YS13TQ=@ykm69m* ze*(`c*dgLsBH;Pef>|AcS?K?RQs9dxef7e zm*@YXEm?fh@t)^-1?=ME^A*@d& z{qqi0s87ew4Jc3hnde#NfM=xvPdeW7Jo8`|<*&V8xjJQ6`JkLD* z-EMq#GT=$ad!Fa#@9OuP{JKMl&!H&qh^KFadcTqvNnTe;enfi=PmS)MR7t*uZp!m- zm=ApfJ48I+MjqvPJ{i={ZJYO0$L9fSHb zKBuYu%*SVc2Rx57;7P}Op65BRiyuGRz^(x7ItS&Q@l?M7hi}fh|5Zp@p*@yoRu4jV zL;ol6-1&`|=aMeWePI{nc_qr*;JGt1A4|~ z(iOTX&%YtxwtyWXo_`^K@bP)mbNYPy(bo#kt`eU0XvZ$k_t2IsKIwSR^E?}N@%i={ z*hP8%jPf>kX75+34_3xcns09|Bu}9|@D%Dn=!>EM6L`*r9U`6;0-jeb)API(^+V{l z#cDtE@p&=+ZkOkO40zJSP!B?13;mzKa~bRq z@rt`jqGCYCrQl zUHH4*_{=rnNymGh=K|Qp$7gc8!m|&`+u&KBiO=-&pT0vP@scvK1?_>SQ1_OWk&Vzz zdG@gQ{0hoB<@plq5b<1%JZy#MT-2vLH=;c4XP)OQ{M|0kyTL$~Z|Qh%h36#L6@Xo} zC~t#jHa=5xBgMQHQyhpzt??HXa zGpP16&$BcBZkOjF20ZC_uj2{3`1t(&{}i6XQQij6Z2ZOgXV!<3ZA>z3Kd6efFuhH{dhWeD}cPKB4&qesVU7nAFfh<1hc+c~E5O(oAOJG+3 zcD;u3j(DcuZ;RhQgI|}DFxq2yYVBXKIJ(> z?Poqd2jTB_c^+-RlaBX1&&LJ(``W=S%5yBrJL2h5pGU%T4c_ldNgK4s@YLvG=*^&; z@|?iVheECN-*-sR?>nGedi-qB%r(|E+!bk$Zx*o^8@1o)xDPgdf_g6W zO#=S~pW4j)C%u0p)-DnpTtps5S(zS(J|DU%Kkogg9@+OfEWRJLm*D#xMX-a9$7=AK zfxhA6ai%Lo=8n=o<8U6@2*LN~sm!$;&rmtin4rJA{B+*PrK0b1jKudj66*Ik&Q3EE ze4k^idJZi!YS$###pl=ouqyz&u16g!G5Mjwv(dDo`0Z@Bc8D=PygLvvI6ZfJT-b0`jgQ2H_r!Q zgNWxG^a0N^CnrRfq2JJ-%$}iZ&_)RT_N3a^TAr8UZ+3ZJVZifR^&Hyxq;{1Ec%BTq zD9=*Vam3S;lZj9F+%Or5_86WTJqZ1H==+;zKiDAR*#mvR^Bjpd7%JfT+ct&g@oHad zdG18~+vWKa+L6WQF0{wTC$+1cfaklgi}GymlxKC8XZ+qUc?<0^JT9=ZQzwXd~2Z*#!&P6M8F zyytn|CYaAofL(X0c0GbRHsX`ciInj(ke$;ee<~#xqD}A=>i(Zg$+^(?H%}jI5b+#> zKHzx{6!2_|`j50yc%G~FwU%cK{LOBBwl?5N$9tY<3jxosKL=0Mt|LzknbXLMI7 z`2uY+JT+M)6-(tadG5fo@XxR z^=|y5^N-eJQsXG|?u7f$RtWiRGwRYl*K(bMzggir6Z2e86Xo7y9yrjvTg}aj-oZTd ze)SyMaa3#H=O?G;N6a3-$*?Z~`<_KzD||n|c^*~P^ptpYrT2tkzI$7kT!;2#dJ_6& z&<**1$9@k|$`|F*`PVMrv9LkJ_jL4ujBgGYpLLXe?`AKwMekAes(r8J+ZBJa%eT7$ zU$1%&5npOwU)V=|L%WA_caqxIzUD*JwaRzBvc{+I^)yk}0J}!w$ujZ_+LP(t&&$ZS z&<*)=>$y_CDCd;#C$K@pcLVaQjPFd$H}9{~@BLev>c702Z%~(y-zffOm+xcXAdBA` z^&BF;)V>>GAJ2DY%D(nB>rvMR-|TpbcO9pGQ=@BwAC;2Z(H{5;^*HpKpzm+Km%;`S z-;2-(GQJ~QhKN_dcW|oz@@l52eXot*eEiKW-vI`Ek5bPe;!ExO{cb(qmMQz%*Zd20 zt@2g#Zxz-fstR1KGkl|63Q1G6C)3?s3(20XEZ=7}&*x)3Lic=rW5n+c*dXGYM6Q+c zJt#zK(0?>W7Y@sQ3-)=mMf39?sLRLiGx(cbzAL~%7Qd_2a|rpuzOaCABxPUwn)guG zDqqBB73RwdUyu6ERm5-n!xC~A+LP(tk4i`}bZz|V_;Sy`Ncn2sFJ^cAoeCR7e6L0y z$oMX78Y0gK_>N5VUtUe2+V|S{9frTz<$Iz5U%z?|5npOwg@A9Dlzr`M#-pxPzHEG| z@2J8vG4VddqyyTM>E1(&$$`+deDe^q;dpN3m+|hUD-p}@#d}76E680M!1s4XU5q$s z={oMW+?<+d@0>`$HDcp0h#yxA*YfGmb8>xidb(Qu(9d9fzZcf`ler!69pl^@%t6SW z#2*WaaK2=2r<$#~oofmMzTLFl>ZZGnn~T5yfc*0t&an}8gogNbyQp@UZ}+pVCUfbz zXJ%rzQ_bsWtB&}0hx2i--NbcV0_X9eJRip~v?=6VFlyW+}PQSUmuACeT-4d^XCh-N` z39mzOej{F8B)m2ssps|MXW->EkFV{>DR$%Q8`xnrz8D^^e#(3W-`sUyTtPmDjbgof zBzZ{%c~`3Ao4u(2Kj{0D*Yh~P5w9oFx1xMlFhI|%1Z~xMeWvksn*&~VI^`9}@`?v4 z$aOrAv>wWjM1vLNGMNtE-ia0D66pJr*O@rK5idI55b-)_nx0ozv{i>VH_L}@9q?-J zlvl!=iLdbB3X;R~(CERVE6DCGT>NSDB^J`7w3%Zl|YKik3@!Es@A&RdjhUw?? z8$Sgvtjn9l*PCe5ZhXB1##ZC&QOpmsywqb12fPYw@WT8r8$StkzJd4%UsgfRg^fZT z`7n4z1vyQoqka0N(^!RY<;ojfgM3UfnI?UtLH(mFcJ-NBs|=TjGW9#~AX0 z?u6INIKL6E=h3&KeE3HnJ+C=vt8U;JQ(k2bcvU*))lHdi;2SaSmPOs+NmH4Q`u@klWY1=cys%DZ7+=tx@cI_#H{!Jw`BD^L>;A1D zzgDBIx;EzbU$tn{Za#b#jIHKFW_Y zZYjPRiPub=--y>u5?%oTud~orT`Ti^INAZPQ=IZjWO>EU!}=f3BdrIHk3`QeCj(?U zczMT`lS83f;)Umi4dV;Cllba@^BeJMDdF|r+4}fOZldFtd3=3@oMSh>Hp31_@fA?t z@rP%AsklAu6N4IbAYl=;4>s_4Rh}X-=m!kMOLBQ)_v{m=i z`KIwT7j4?jhYP^iYCdFmRj2po4U71fm62keM_P{!i+Gk0v{SJ0LfUTe^%-S}Du#x~+B%OjAV;T4}!L7s$- zh(Em!UeTK>$YU~{uJ=x@AP+&e#H*3kH}1mujpA#jgx4P){rbj5Xsd3c`F?}2ElA#^A6jb1pv z5w8vsUWeT1)~z3Y_aS(}ugvC$+mKW2#@GMB4jb{6<>6A}%Qrj{|DcF`02>isdL2BX z9~P0fWIF15Hx`kXq3=&#D{y`zUQ5xpqI~%1WIeAi+OooHx&vOfI^~7m`BT4FqQAqN zu>QyMNbBGg{G^CXlWH@LzCP15 zz7BA}>maAR5(8CU*k5>XG1;?`i?6iq!v3lD#pD;6?&}xvwksyzLbt>V-#sFg+ zPjP-DUhg7bisI`D?A_$|AJ(9)I_#@6%ZJry({4U|6pS6^!@!XWFMQ)N+_9KMcphmT z`_+P-i%GdmNBtz~&xCG?S0lyOWSrlK*JTo3N6**uItgvnwHj;6>lg>Tjx!~az1dCf*!R`Owy174+0dHFhK;w$+~3Au^qk=Bt9lkw|zoZpDoWC^cMc>e@{|8+Xr zs>6MU884p$UZd>s(#+S7R(QoujKoJ2lfeoPy-w%rBa6x5G9C53zGBh~x+PwXG=3e7 z^BeJMD&ckXt$JQtHh`Cf`QiJ>IdG*X(DLDoRemD{5H{x}^gx9Hp-@gW;tvciZv-w6J2fPk*%FEMB;f47`d|)Z* z!1GA!h`;EdQgWb7M}6;+rKBlzOS~FszVS=FF|V(X<3#awMTtJX;%Ljt?_aCXrrmt_ z0vJ2WhrV=t;ePkfQnC~_V!n~hhZ!BeA0Jjq7D{!@S5W^x=$3dj()d-5^Bcw2?Gj$^ z+@$Aq0ot_%-0JW=dp@j6(-D=}EVKkDmuz{|q^!vu1Q-T3+(b~uW!fcm^%;Lu3;zB2MIY-Hjq zt<(L750sJr$#m3DqJACp{mJWToZpDoW9VB^KD=JQ>khPKW&hz+2fS`}$}5rO<$t)0 zT*mWA>vaENbs4!trh``$_0NZHiB}`d4^PJVjd&d|;dS%8rn>cwc4(^(-|sV)+Nko+Li>3$s4{|dS#UiiL};qNKX zo#exhaegCSZy{fb;_HFa_4#ly+Nzsi{`}X2Xwz;!d<2Xg<-^1fb$)nABz$fexeGQj z`7o_}j*JA)!~S2Hj&Cp}QU7-6)_66}_;nr5Z^Ub&gx8(lH`m42Ftk;N?^Kw@*B}SH zj<&&z#?M6j3*cWtKwUpXKJ#}fBfVgwP>*4L*rkkgk?AxaqW;0qwY=WfydMDf%h~q> zG*W!!;QU6senE~C#n%h?-aNnF`}SMlW#RoBFQHAl@%1VgTa7Q4$8nkX@?TI!R=`G~ zPT#*Vu8ce>(-B`$)PD@RHC~MqU-NK&BVOeaUabYs>jlwP9p} z&+kA?+l{a9VTaZDdKCA=nSAJKukz{~3C}DipTb6=?#YV;3(Ls|G9AzRB~kw^==+n` zi#Wd#ucy(sqI`I#fL8_Dva%l_!~! zKH*W{$4!5)d=Kk?uu-hHi-bQYB@wBP-@o23CFRg9@!Ddt9~-)p___t>H{x}jgjep} z`upWEXv+$(;SP9>u*a)DGkzrwQs;*wBJqD0k^u@2y-x3kFDxX7%5>id%pVI$cj%UQ z{be%WfbN9XfjGYruN(=l(!Ton#-`V;<->a9B)jqT9_+9hU(9^M*IeNh!}I3N@cch) z6za&A(H40AU#6qJw|O~v8v6d^wGihw;x!L_E6Rrl9jfOw32oJd&G)li>VVf3j(Ii9 z@bd4$`k#)6s#kZ2c=wi(Gi5q>MN$7`=p3)i^X9l;&OUG6Nbz+n&Tqu)a0#y~`sjJN z(Uz6>_wGVW+l{Y3V29QCQpcxytZ&p8#In5H?sD?g|1#qjtK)rM$=q_XRi=Yi5cNNX zzUS7}OA~lU`6#@Pdk?+|`O|qhOKJXntRN@#Uh`fq7uw3L`Rx$b?nR?=B8y;qpo#04 zd%$xF-ZPFhk@}f<_jmx$UiHR1&t3Rt(842pyS48;kKubd)1b%PzB%jMt$w(&g=_4> zlkn}o)b~t#Wxi+X!S{lmLtXlgaP51~*TK##*N&O@o_lh34WZxur0;%bzhn7I>b>N& z9co+kk-pu%IxF8Tz`96&&nB+HuxTuPXZj-WqwmGnzAt@iZioDb{VnE(hAHn*Pvmy2 zxdS$6-+wAs@U`=>iPcMyPVp+Vej5f^xf(B7HaCcSM1*VT(#d7nWFlK zXZK#_{pl~DJmU`@_4iQxeim8@f~8|7t|ugCxAWR=Syd-iqVh%pvbG z)HBQHdr`(9zUlppGJc2D_pf5VL-4^;^24jC_!jDM=wCrMk8d{<-^*c(Fuog+_dBq& zvEq9<^0X+v+u)f_c1x5_)9t`}mzVECWBTjCFFLVw?>aczsU;k0R8?`_I}JKK2||oS>`%D41L$je=MN(rvFLey*_h49%K2(V7nUc zRqFkCt@eIg%3pIoZkPXN*er^7+x$J5IXiQYwhp;l5c4%NPt^0j7q(FTn@~r@zlx3n z$OA_FJ6YgA8)Yo<5A{@H9{1#KcLfQ-KHRfs{X?S%p-;EV-`9kVe;I%LMr0WO&>hEr zL-Ci~vyBk*&;Jy2I$iv${4bL5Z)<`70+cb0e`Ef&nfQ-opE>ovQ$kz{f1w_QzUw8M z@gHLO$6&iK{*M}C%pbZ_{+nTQgT%jt|2pJMLHy^(`!v__zZbTo;vaQ{@sGco#=iyr z^!~vh{;O2}^#zH(>Y93!Nbu1j5`uk*f1w_SKHWC|rfmGn_~Tn$TvN3`-D-yM58WyM@eRdaGXEPP z;XmUL{rs=9%Kst>|F#zRFF+a7_&4BRsGZ-%)OTFP@SDu0a^ix0GTpnmoa~C*jQ?tu ze+;$@RT8|23KW zf7n9T8ZMIXZ)<`70+cb0e`Ef1epiM2|EdC)`Wrpg_>#XB6PLnYsQY&nlU;R|;=eX? z{~uua$6z~+|0(z#TD||TO5OiABLB^>xk2JzlKamd|0=X) z8vhpf&qf)8_|Ni9U|&Px;D`(Sp9P^41||3gSP%dpHySnf!k*Y@z%&p^k`u75;7-{}%YqMj2WB7bxpL z%KXo#K9i5}Kl&)ff7mC}-HR~(+vV?R$>e{ZjDHW4^*`v2EdLm67sfx{ zO>CI|p*!Wj88$aa{7dG4>yR@=@&C&Mg7}9msrW}7Vf^Fortxoq|7?_z#ebo8ejhtn z&HsHP{^=zo1p8!q6#8_#{9Ucs_?Ph?V>13jcglZ!L-Ci5|6=|%cO5Sn|5g4MN%*(5 zz<&YCn8v>Wf12M%;-3%y3PQuw`#-!h;+8Vvf_*YQ34Pa#mg2uEd;ib!kHK~|{_E-e z|8lGYr0)NRoMRmS(4F$%44WGy{w4W;9df21{%gK`CzJoP^MBZqn*U4qSD`J___x4+ zHpH2X9aTRVhq`ne_~{RJA5a?$elQPZ zT*AEB;@|7`r-EDvF!Uf-{a z$zLyU^8k&Wg#IgZOYvXL@{hr0Vf;5D|IM(qQR5%ETo(UzEkmTaDE?tnD*jPd82|XY zY5ZH@KMQ3H;=ewV|6SQ{zqwl!lRFgtLOlq5npOU;1KIeO@mJS>rSZQH`G0&P^B-Zr zzgG+Jze=C~JF5K0N%*(1z<(afn8v>`|7?Eu9ihZOeg_DzDJ6fc=Hg$YC!zle-BSFA zSpG5CER6p~6Lo^^I=me{!v#L|M7?>A3)~*ucOL;oP>WH3;gGy zjA{H^3GLdee_xE| zobzBS%B0@S^4nf@{V!KJ$N7IL?`An5&3_NO{+B>`b)BD%?>h@(LzVoGcbG-{SCYS; z%gq0k@jtEO-Ad6TD#@<~x*PSsgKjB5RJT>~gX$lva7{x0NY4+f`Uk%KEc1`|kb6b` z@$k*;GrCXW8hHO$g1R&=ZTko8cj_Nczz!$=ai9hNC_;7L&ap0f$m2A%b{EH56{7jf6(}B5dYY8p4317CGn5>lUe^b6xYD}hi55$@cm8+)b~y2mJ+RfxKc-ss zk80IF@Q!EqCd5C_Kdr+*+#eT{2?lx)`UTJ}`A4ih;~z9WIsZ_eKes!+d@c8n6D0mI z=LR-^big(6{?Rt;AN8j1Y17OFZr+FSr9JF$;vY9z@Q)oRV~{`S_)(i$f53Yplzr%V zk@#nb{}q}0531J|WOVFP-%?CA8t7ise;c}if7EBzCtMvE|Df@y`bX7!%Kijr{xMMQ zAI~CRi}Ht;^N+i54ZMGpp{|-g{x<)pgdI-&<6GEjmOn1F>K`uk_bJRj!(Sl&dH!h~ z`6Ilon4D#xC!vplZplCJUX0Z5m+JhK#%F{0$60d!I6~qdBj>XDqbaU|_Yc>8@Q+;B z;lw{Kv)~_}po~HOsLJM#EPsr(>K`t3pPL8o zCM-kz^Ze5~{3BXgOinV;-KakVx+VWe;9C^*{YPs4pz+xt{&CSr>HW(g691TpbtvsS z$9{QM?;kr6%YV0j`~*9k_{aGc{NqiOv6MfmRsRU!UBj~x|F8+`Bia0s*5Mz)yNbz5 z13eD?Dd?8`!_}4X4;r5h;vf0)^^beNSd>4SPGbGzI$Q&vKd#&l{&5ZLaN-|t!B(^U zG1{_!sO#f+7kqFH;$O!{`eerIPs5@E%?V8l(CdQTHK3sFETPKg*x$RRw9C&Oi1PlO6`T8}&OvH}H?z z%>8YGzFR*#|Df^d!|yK_;P(yn{p z1;5YKny#N6;@iEwr*BXCH@s=Mw)8UwEwHy=_Zwbs*X|f%;W=D4y-u3*5{RuFSBUsw zhvG+_@EczCn-A5$?HxinxKN(@u=X9J+H*%?x92zIx4e`u;asWjEZ|&eU+NQs3zo0NV$PNNd<8)BO(>kzCbRwEm*~z6SM|Og?dWn0!LxGbG943(ikm@Du6>U%^jA->ad1aCNT!8z^Vkiqr5U7WeoC4t?CO^1=X$9yn=6> z`^!lg>_T4A>#i=5un+J5G0>CHr$eWHlKv-p{)6!sJXfk6e`tIP{RQ9bqrd;}i@#iA z;4iED>;2_eTua^RvC20~P5dR_iof6*ochaAu*Ipr+ymRp{H2vufAOjB{I2d3@xEL} z{`@cJFKHe3LGgGQ`Po4Ct}i1ypr?JsQhvcVL$v;~9M>lF7j+!k7k_ydc~6#KE;_o2 z?wiC*aV>Rt4lVVKTN8hwMyfli&KC39=4hJ%jH)6C6TYpUqaqU^wtV8j`s(R?!TpioMWIzp`Qxf zg1=N{=DXFbzqHNzOFg}Ro|}GtUH#saC4Z63cL&J*CI8D_dVgt(YpI)HZ9MuN@o(xc zxCW>G;)X3w{iVQyzidJogZxs}3->=Bx{oo`LGhOuzOlNXoV@v@av!bJ@r`i*ymIoA zfgXjv2D&YO@pzf>s0ene`GxhD-)-a9>=NppBO}Q` zCGi;O{)v^OGjv=2;=_C0wd?=5Her6*sJwq;U*<1+ko#o*@@kddUp{yO{(|p1S@D)IfeO_l@{AIF%znmcOm(y@9R@Zk=vf?kAXLjta?~Z{jPW|O^ z*k+brdKmkQCcmir+5(40qQfdlTg4yrI`&QahgOmn26_~_3%V_TNwEI%8m>*4UncGQ zeD@3FK3RSlwnv{|UaYb1FVCQD)BJ*KaGGCM!xpFha)K7VJbjq)Xt>N@dhGlB?? zeXaNluED9l41_IC{pD`hW|m)?8TiX6<^HH1_tW(SE_Gi%{XO7gy#H@$X1>enzGLwI z&@!^qK=*!FMz%vY^A|c6X4YRqtiROa+SL3~tFFJ)r}i(j+xPj)TgZK~{IX!SKEFJM zYpFYHjHUU@{b<`Xzu+32`b!kHIQ5rY3;r?#Wn}q9<1af4s)s1^mqedP{E$j=E$}kN>m()8-u*R$881*;mkYMjiwRTT~VDAg|(v0Qz zJ7AAXe$OVZ!FX;xwcp`M zwEG)yo`hRDPkOJ*1d;!s9NjndA?jEEqU?|OQr-IkrpkB}QpYR&zU2P2jGUqKm#iLy zKH9FoU~f%2zohp|wT7+u_AuR3$Bs$rJ1t@Ye=*xDRSkb(-*-S#`|T#;{it+LOKN|V z`o4pn=nsM4U>{P4{AFir_hWXd+4VU5LbD(9XXF9uCpmWCcYte4=bqO@d+xx>)g134 z5bTxu4K|2!58W%J+b5;jZ+D^UH?&OZeFxNU==%QRQ~otSpN9W4hxISpC> zenad3pW-+58NUhiSMm_vf9CyPDOn2}F|MWcodsz<);AJ;y_BqE_49=8}x z`HZ<;%QtGi&3I)?!M@4ET)V3eM1DtI?VibB7N@zfV@ROcuH#bs|B#zg?{!I!hs{SX zeeFM5|Laim657!EUkr5|zwRAE_k2?S%Iy2p#xqA z=eFsuoif+4@BaET?6>2u+fm-YU#sA+wODtkE%2n@M}&3mX~ksIV<~^t>(qay7LyG! zo$ez-{nuqW_4k{KNgTR?zt(5+YmD{RS-75qEFEk-z%X{2IZS!spki*k{6iv%W*kHE4(4XFQ4W{C!4h{5N|(L%WY!;;Yq? z+>aRHhe_ciMubIE1FVgom+im)5EOQMF zUYK%o_AhQM8dEe{;JpMzTWvoWQI&f{W$91DAQ3t ziuzYWx8$$YtiK*3^H+oUt1iEKm9=51ze0DCUr)w08RggG1^!xvcg*qmwLRLQ{(3&j z^ZE4vEB>mPyV~{Fyv#K;jKA)Ly>|R{8_FB_Yi(ve;7dQp(mfI$TtYTJnwh^U`8BO$ zJP!^kA#cm{0G@|L{a0i<>c>%kEp$u%>dI&GYZi5_z`D=PzT(&--S!cF0ANV$E?5|sqyLf*+qlbR}`U2Xa{<;U{d4FAwznS_g`ogKd zuE|_O!}#mH;AJPj&O&)h`8A>LBcbc&Q_IL5up9oG&A(}#zK`O@GBQo3qka(eC&_fw z_fIJ!mqWMYuQAqN2Q`Ghs`qBn{0iMkejSNxGRm*V3jFoN!}b1p5Za;sdal4nf%J?@Hg)%W#o04PVc8s zKQ7ZzKaBdTp&R&X_W5YcceU$TMYtZCUx%pgTflFL%5(JUZ$p;yEA~jzXJe)Q3f+mn z&cihs`D;1G6h6Oh$2(5>`D+2%q5k?9%Jcd4V*JfCziNIEF~RfI{iHf_1i$VAvGZpmL0tiSe``Kz7vtVYVOC*qon^6OxMzwYqp=L4vB zzV!UHd&K=2zW)Qe;jem~&ObjbC6i=2)?b6Df4NLYegBqHG6A|Je+{wz+OHw}wUOqp z$K#re^6LPBzkZsh_t)lVhx+Sj0)KTivcI;-Ttmb7>o(YH$6r4}d6~cV#=hPh{Bz-7 z0p^LR-?!-ebA2g!{h`$SRjutCm zHNU3b4=^?TJ_$SPuWd~3x1c+j58Q=oGV<4%7*qKC>guAO4~$1U)L$P$c|O06#otWx z>prZ%UYxmxhVj>-HvP4~Re!Bk_q$-9Y5ejs(gSug{+!ma9u>W;jC7RgsPDa^jI@#I zsP9Jm&7fQI*T6t#K2Q%{LVs27p)Ac`y(az&-HE?$ebCrnKS1u{{dMlH=DPX7f6)&0 z*B?-x_tz!(o2kE|FPzR_Ycto-F#b9VyzJ!H5X#H)>nM!(+5DQ`FP$H8-&a9ygxx|N z_fyFQ736A}9?FjdQ9mftQQv=W#sA~(%;Te~&i{WiK?sP7vb*3A+(2tx!L2$Bifh$g zaj9AvlWIY&OI@p0$4P(y{c1*0yXp{^nzY)~f?Hc1qIGGljasq#tvbY3!4+JPsF2_L zx!c@(=bk%DhJJnh{_tg(&pGEl=iJZpInPjD2K2AAiavO6PV9( z_?ofKebArxJd)C%{JA-wCAhJkVB^}?(_Igz^haH|5l`4S`Qv{`=?}PYfBt&PzYn}L zzH;w_>%7_()F)71tvy$z>FdVX?=qh{h4J-AaLuo;Gqx^_2TrCO;p-(hl z^Yu=CE2^*kn1B6^Q-|vCwT1Upj=o+^dX>I<_^9n|@pb=n!`ln=^RYV+XZ|$))&l)( z70!2>y2yWq3MYRX`A-5biLXg7U!#S5HP3dkhfda5OVZbk6c6l4ox=2W#{jpJ|rC|~=rpHOq^P#wPhi#n9U*KX3Q_&ULi2fFFcId@#=%nvkdIalwZ z%>r>bA24jL{)h@E9_S+f{VJUNZRGC&SMgP15a)b>wx>s5FQGn`z8YssnIACuT24G* z-PNPqKLB2dzRsaeVSN1|T=VPeKR+oPZ=FCnN%Zw*();!Gm{R!Kk9c5)Q-|vCb&oRn zx#HTR|DD|jV*eT6!O@%3+Lm!GezKP=?yuP8_Ox{CCEzGnEXsJ_w` zmBz34ICZEFUz>Sf<>>1bqz}>8JRf6YOujPT)Ub5Eehzkf_-f;vCyXzduQ#Z0@^_K{ zR25GCHuCG>CFyI{%hzqI!B=bUOUYO8O8ELU>J-M;@d12o3E=A&x0-zYMgU(wK?gP_ zU%%wpW*w@-*MCxna`^fz=}Y1(JhJcI>$-2g{wQ{P_-f0~b=CKz%J|J@(Zj!pB?SmGJdC>J-M;OW~SdU-!GLFn&FbaztO# zr1$IV5vB08AM3HlJ9VfIUw12$uhDS6%6yg?4@4)LeC7Ut)E)Emt*{%u7UHZ=HMGss zhp2G!_mDrL!pYx7{?BhIk*^6aU!UN81@hI3NlS|dimVs#&7Vs6`Vw^t+ z={(Ft>J-M;?E?7v<(fjies;6T*Zl+dx*8oQ%GZ9ZZ>{6m)r<%JK^@BB>(itU;j8Fp zC-VcHjftHU2D3BMK9*M7{uW}G@y zhp$)jzRJ%IYeeGi=| z%GZAA>nA+Bn(;t4bts3gPmsO@zIHcet?$HeuWiqmX8i%|_VCrl(bulg&H8;_+><{( zwpqX1i+4KZlfRzwZv!uhuL&<-XHlO(eJy8x;I<<31K^eL^@r3cjIZB^Ykqxg9ayNZ zhf|K|>wMDt^)*%sU;8mXaD-Eb>gekZW%6}QX?*Q$Oj`G4WXGrD(I$Nec6<10=L`g6(=zP?6!KVKK|TTy-O$9lmpoH|s8uUGKC%F);JNFSoF`SDi9x-UZ;olbSn z*U!Li_*#fFf7xl=3S$rL3o#$qLz&y`w zjiE}L&nlv?(<{^0@zg1duOkEadgyC~_q%+UHu<_|0AE+46Giz-TjVM{zqOiYS2G@X zmO7Nf*DUE(e62OtTU(hQXl>NSn(=F9+jQICn)LgzI}m3)m3p>G?@;07k383;x2bUQ z_mKZ*;3e@j;pOXhsgLMu0bk3BUoCDc*SEkc(br3_wKVMtoqSLyFfzDDiuT5+Cb zuatf&cGsHmfZ*H@o5v%2rgYtlx4Q8Z`H%AAp8O5ukAs)QSMHs0@7Erx;%hnaz!^pE zdjqe8uiH_lFuraXz}NJfh4H|uX z^|g%iFjp4gD|jV*y@)!6@%1dY=GWIb6AR}D4xt>;*Xu~{*Vp|@;p@Q4&%?x=I#fqr zw=I*e!%E{T^8@z&fywE}^UZn$yS;q1@Yq4=p1(KipI`66J^35R|B)AOb;>7yyt`R{ z2fQS{GB51b*Co8KK)%My*spD^-74c(@JjglXX+Hj*N4$xKVR2vUC7s)C`b7E66yVX z{V~54)mPf0(s*EzQ-|vC^+MiPIr{ot(wC&KnsuIA_E)WF)=$E24_|GZ`Tj_*SwB{V z%X%&Or(5`nZM4-n{%dsQZy^7{;30f{9n)r<$8pbq8m^&!%$_&R~u)!|dj zx{rwc)Tz3KdIxp~;*6IX1})UvRJiQtCjZY=IQhHCeb?Q(ZzMjYXDo0-v zq*v){E#rSjU$y-Hfyivu|FJs|m-YYevHq{Z*+0-g{J-M;!2x_-Gqv#kfj1YLeBCjCum3{-it?4Vs8nD7 z&9kc+4`iuBIecA0`jYsX8DP%8=BA|M&!_aevD?E}8&5>j_1!7`HWg0(HuB%1!pWZ^ z|MlP{@ipe<>nYSHP+!YAZ&<%^?jM*D6;ErE2*7pmUZ>ryGzW(_FUp!#r#HW!x=j$J-aPp_f|BebL ze*^h@z)Rw5(#zN1@V)~1`W3i8>rd1vjIX~#fBk&je_$bB7gCP!^>3v2^R=1Zit1}W z?$7$MQ-|vCbr$cd9DO~V^db7X+KC6yF>`%uw{*kzTl8bG8+|RrIZqfruSK7p$GaK- zcQ?B7cai^K6PI|yi<7^N{FA{|d=;DW=eZB?!~NF<%qssN_xM(?zWNnx{p(b>gemRGWj|noUfvvrv9bLh z#o=51=ZybVxacSO-%{b^Pm%w1@RInN@$&T^-d7-BtuwDBjkj3;3Ei&^UdedtVd@md z*L%@lKVRQFt8ji`9_0vMpCP@UuStF@s;{&~rQ@v@rw-NO>vwry<>>1vq%Tchx3u_r zP`c{}bM>RJ+pDh@F5ln2Xs#Yt;jCZPUp!YoK!uY(Liu}vm&8}?KuycaeWCcu9Osc=>uf^$Fx_ zIq~a8;_I2zDU7ct!Zp9XKG9kD{n)Qlj_B(}r1$IVE~W6bAMxuRP93VFuS3h^s}|1J zPA4AFc69h!zkv1sxdvYgafx5&v;MEbWj&VsJt|z{SMt9KUJ_rkUcTPR`|3AeH_~`( zDRm0tYdiYu=j(`{7xJ}N)z)up7P>;`HaKtLEr8s&Mj0 zel$m4pu)-DL;e(aNqo(C`Fcz>__~qSW4}Y4!ua~F0KR^5a3NoJr5w@M?~~rIuRCmH zzV7DKp*s3nS0-P-q<$fM&Fg1ub2A=bJ+*$uT>XP)pT62Se2bhgSAR=|lRriN*Ht+A z8_2&Lyd=Ixzv0o>4D|`r*K*?5`i--`^*ibm#@D;hU%$Sd_sha~;9ANNzAhuZpRZT& zTTy-OM?8>p>QEiNp3eI!M_-Q*=WAX+a}%uimHpJ0H|ufi_UNmP)1TL0)~p|(!dc&H zBmZ71oct;BPXaHAuSqXoKjD1^^0l1(SsRJ3n^31PzV@PBe!lLID_k#lvB~7?$N;`R zOBqG^+K>HN|KQoxj0ZZYLpglClk_3_+MSO-t^HZ>t>MN6`YqTEUjuNymyuqeU$4Zs zOLvift`cW|7x}LNFNv>NFJF&P@wJ@zbtApJQe!qOCr4;sNr% zs=_56ApZ;CCGjuc+VLVdl8a)hsc zBE6rlm+)IreWfibT`#!WsY7-6dJ6BW9DO||oUfvvt&IO$8?(dAc!2K_MJ|}HAB^4T ztMJ*2YwXAV{(OD13YYI0k$-m;PX74$^Yxv;L-?A%e<0`O>uTPY@OABO+G=Zlz`TFp z1@lZ+Nqk*i!B*Xjx+bPmc&;pt#bb>cqM#2kvfI(^~eCe_Wr$4UnfwG=<8Xe z_v`DnrSKK|E9L7BP93VFuUeUW{e=3d`0CNmoM!Shwof|#rxyLKq)%U6c>Nz+^w&f1 zHu5hI!Bgaa4!k73CcJ$83H1ro*X8Dzza+kHr1hJ-M;U!uQ$eckrEg?zo7a)hrB zlittQ3;C_6zS0(z^7RU*4%Ol74Bl5c`g%mEe9atU%@43Xb;&~g0PObg*~X(I(hV0c z)b~>1vK~wRNh+NDUF5F^FNv=_*S%iw9`7rVuTM@h)&NT4>qa`iwf@?0zOF&L{CvHz zv5>ESr5xewW&wPCf-;KomA0squg^Mls19H6p$_Hn^%tZsO4p}bz$PLn#4%d<|EN8#$bzQaT>~m)9kll>5UnlK^eA;Y8Te2M7jtA}; ztj$<_Fn!N^SKrvzIR3A1)@tcHcGh}xn`uiQByUgc$c`NAZ#7y{{}y!$($~zubyF7c z+{65Q-Qv*p2zIR)nAA7_T4Yi3fLO1F%{j^(M_Iquv?aOP;T;!8V!c~iJYBY%);azO z^s~06qh5>k#s_HWdQIzn47)x)VQTxQr^VYpYn;};{;DVM$=1$Xe!1(e!lxB?!zb&s zr4P|&(njw3Z0FR+%iZj!eUs&R8tH?c`IxlN0JD8w+R*o4Ca$GF$Nt2Iz9qC@$HfC` z)(I!29XtE_Mn5(|>rIeeY&dbfnf?RPOPcJLW}a)wa|h}ENqTtM>cp|yB$KzC^K1L< zJUw@f!P`QddkRzc&C~y>!pR@$oTqoIaPs$%|7mdHt^MEns~%~WcQK8&SZ}<8ns#i< z^Ec_`Z!7iEg7|CAu?F!s>*p``yUG4SC4XJ_zm>z^#ndf`ze$U~H`B*>^mfxj+n2%n z-#%YB20Nd!L~}dIBQe5@a9P^S=JVP7UQ~B!lS*}0o^RI0%iWyC-4VR6TR!fJENk2wFv{ZZw&{kBCVda=4#b(ajkh=H zyQpyPf$JiFRE5hr1Np~*+uW7^EBNc0Kk)K5$9uE%w_D~9_Ob6Lu;yoj_*7y+M1R-($bRReJ66<=>S#*DdZiDr_4hyMnTNlY{?xPfmTj9Iixvf5v+&M}My;y-I&&p1|R6%o>+v`L1!-96gE6fjIN5 z^~>hySEz9Ew~_xs6;A#X`DcNb#ot7YCw|z2dRh8gGJgy7*BYNG`3qhNf2UHnF#X+E z!QW*yN&T8#oppwes1-wOMtP!f$C1xJP8(?PS^9C64qoo!?n*`MkWs`An>%&!a<@|b zeFuBX(cjleuZnv;`Wm&@#YUyOK5EvxulDJ$jl;jTHO>0dDx7gz{m0FER)v#4LirDY zm&Mc3*zsxx}<(v{vJ6; zfA6I{;qQm!^Yiy^ek;mf*VwIG{k_krOLh3WfcI98{$4}+5dAgyYwVlNj5FikY$P2S zJx{+7yS@Cia2bD%oTtxn;r{#$p=d7#J>gn zy`_l$f>*-dJ*ium{_d#Y@0sZD`2qZ0f2GOaLjw4_79A+c-+t)t2A*Bb@!PA^p&b4` zNBUy?HTV^^^jG5?*O<9_7P~$CwQymrTZ8^Sx=UgF@J-4S{k?&Fe*K-kk@E~B`WZVH>hJqknEd^E0Ds>?CyMg7AMwKnJiD6l!(XUFIsAQ; z^dbE1%Y|EJFy%77UI(XA2vt7M}?EWi~JcCF8WRWpMaOeUu~d=zY<@^ z%=HVe{#tWliGcMtjX5G&TYA}Af6H0-e`}I9VEyeg@SOeq7sdKpbPLvteCux)QMaIX zp0(C5&VqBFu@)igfXT_`T3cq&q3wHbS+_`ZSc?1d9=a7Yj6iC>Xa#U9b*%-o$PgtF$x~v*JrK6NqW}d>~)Nx z;XGb#@pyG3-}y4`_sG&;Z^!+gmpgH=8AsT->}S}T`#-$6D?j&%Z_E83A$SA$TVA}| zc|PUGx8eQ|aN)UPeIu{WF)zO*z7FK~=H`8iCGmSJGp&-};0_vu|igFAdEgWomODU9ErqJ=^HKKaW*1^j;QGWcB| zFUs#HD6=TPONpZu`u!|+1l6fhe%~YSuMB?wg7hK$w)GqR+{5HI>%{d>bN&ar;ddb} z=h^ZP`ecx;u{63O81#!WSPrjkx_pg6csNbU~YZ-PFi%*7@!f)Ef@z*l-dxWA+mGXNv z_Ljr%f0JIt@5fF4cEYdD#*B5}Gxyu}Oi1a=Fa6@yK%DazJ<*i@oC+s@q&}rT8G<)} zKdQnhKR!OCKLD=cH!;;}XZ|DW<#$rr$Be&Qt@#i0eg})QCGp$x1tq`Td?XpukbeLC>Oy{>L0QYNqZq$uP-ap6cKd6Y{61Y#r%L&~Uzz;gErj1z{9*Dtv5BeQ z@T=>Mls*o-19AA<^{W6O8K3X_g6-IatY~G`VD_O(L#&gJDB`t9;55bdHUJd9f-5e*LB7`{R|aO{+^lh z^pisHcw(M@tO}?6dh$;PFG;@>UVaa&2ETRlEQyle;7)&D2EWHsr!anxRPg)9n-}u? zgNxxe_gog^_rKARjmhu#up_8WmGb*(+MpbM|B>_|{Fd>h$?s_Xduj1!oAvv!+oRt$ zF6-FOH0yV(aK1O)@Rw%&wh+7v{1z2X`E8VcJ$Om{&UpEKinLEqeDW0-U(TjZL0quo z@9)6HApIV+u5f%gnX*b5U+z{4zxy%1+(%KTO8GskOnwgt=XZCW-+Maa%dY2`|NDW# z??RmMU)Num|MTLj8>3c!#+N+zmk7BcuD-$hIrzW4DU0L z-`1K;N%4u5R;l0MmFV~Hs8blf??T^$`2F*b3*+x=C~FzKET-R=P-ap6cGsuO`1@)_ zohs$`Df0fxh)<3oy-L3yH^-N)j4xXobJjW}{EDB){2z9M3%`9h`=n{kaQ${I+r7-wO-$C%t%gqm5@bO{ZR5pg$Ud_kcg(#ao^H zl;1`9_kowh@8nPqzps$?>92m@Uu1jQR~|A;;-NWXVoQ^@a=C~Fz(>c#kd z3}tRi{hpzyQ>FagqfCD9P%^(Q{bYT-t!IHg3cEe}oyqHK+Zzk?&AmAMw)KB#x+}Lp z9~gqyuVDTE0(JQj@~;Iq`TekQezwtdewLW2`|dkx(x09dX&;~5%;EQ4O*QE|8*9>! z@lIo#Y5TlHjPiT)45AsMSaXEgExr3n*0Q%lWByC_pe!bRinG|6y<@%O|8ZPze79Kd zRMN}d4&h#6b8X2|YoAKS+UFYEobsk{PJEhqPF%{9bK*i#KPSE` z=bB}o3VC}tk7%D0e~P;2{a|FlImJJqnVx-u3lD8yQ9HWhTlL;EiZ@e^|6FY=d4=zb zOFk$5l;@nd)J4uI7Sx5a+S(9vFNt|hJYS!iJoOo!ug@oaljV$f;n{TanU6{P3^dzk zIp=J%oD;v0cbo9XFQhZh*~+ExXFYqUjXP2Uo+;SK%` z-(|kVif4AR;u+2zUO7+KsY4*nd`RSn^Yo*Mqh5b_{`^9Jc$T~s z`Gd7aP>DbM9Xs;%>7PIRhIdc^J#`4gWgp@R zbM(1hyt~oP&ppj?@?Yb{TOFKz;_(yb=$EN**{4YP=YyBz584(5{lk=M`NRKF|8NL( z&-16Sf7n~$4}bRg!)BD@?;q;&{!rpMcB_Brhd*rUsZam>VI}sL;}8ELy~-a>1atQf z@V$F6K9S+SMs2dwKSWNSqyOdm=6p^84qqEiouhZTaAQ8m&QJf)aM~RG5f|<+zk%}a zSK*Z3Mfn}zA^yCI=XEI>wpz5%!%8R~~Pi15WtjCDB@KfVSjva68U_ zdT8)HILR&DF+u(=oa?bS&*A(#Pt>fNEcKB4H-gWen|zZP!?~}AeYkSpNpw@75|AF=h37Qp8J)2{BCz_ z4&nC*hu@Rn_ntPtZ$ZNY_&w>KI{$rZqdG3&Idb>U@5tll_bh%Z#_tbF6UOiFQP+O( zJFoHCT}*yw_DIJcZ`Qws-JU+c#+j3;?`qbMRN>@rBmYztPW}}6_XjV^@940Cct+ym zKz@I2?MYYh8@y8e9*3>fjse39 z_4`4dBl>-F0KYparx?Gd6yf)8!TZ5)L%$7u&Wv?pn6}sF>OaM9kAB-YbL*+s=IUt` zPRt&8W3E15g_FOB{MUgO<#)1>-$zs5Kz`eMzEu2n?RzR$zt6_juM)ravN#dO@BJN{ zL-?)G@127AJ!#944!kQ#k}piZKLf7{zZ3SEBj#}S zou{wBZV$h0oH>@%KJ)ZfRJiba@;v={6;A#h@;?J!l;7L~Z|`Tc=PPfbzW;50--oSL z;*$r^{s4Y=?C@q`{Cxw@5q>{U9zVZZ_^p_JZ&8Hb^T7M5-zI-^*4;kr zS&V!+U%v>uE&cZ4qtiW~&(~)warQit|4b!5ns3g}*S`&3l;6oheos*Gdn3l*2V-m1 z^t%f4Cqqi$_m+;$<@0+3+7ra@ACGt96YE}#Q5`SOGUM;10sQW!oMQYwnS5dT{de$w z@H?;H*=?QqlLl>`{xEiX^xMXXpW}UV_1}4M&P3<)cagu{i*shr!pYx8{>9)$`JF4| z_qo(JP`|Bj!YJnlUEfJ5H~yZBtySZ972*@!;zXE!f7`LSe11e!y= zh<=|*9>0E%DS_X&lO~Mcqx;A2PA5LeY;E$J_#*OtlU{?}@Y}}OGhpG-ap|6SoAloA zdGOT^PW}e+ukqrZ{PFji^i|+R`OQ5T{`mX%w8wv&-_K#|SBc+0vp5mP@5PSI<@5V` zv_D9{pZI1WzrV+Ggx~Gt@$);uZ^iWcZPJACdnR@5hko1qMSrbtB*D+FTIT<-+rw`g zhu>`x=Ks97Cx86_=Ks7n`fZg@{s`so30{=n$wGdAL3;%9dn3-DjKbEc@!Q&Gql~{x zm>=x1I1$G0RcG5ahwxi5f3h5H3*h&ppA2*26KDS9w>(Gqy@ot~e&54y#rXa8BK-ap zct7}U$0v;c>Ye$)uBr3%GDQ@n@<%BDhu}r|O<8{Z zo~GjWMvTADz}Bx4zbBQz?>!xxL-?&2UycjrcSm9~hu=>8{n=S&{QXh@zgMFR#rSM28pfdm;6;^t)Bg^fP~Ap6TC+>z8+9>sN{2Kd?9vrr$qwY!2bKLch<3 zmqGe{PnUD=qNCr3@Ep&WBR@BK>P_hY09;$n7y5&-wwa$@f_jzGvx8}JIQaw^m|YdeqRe-9sRbx zsmuIe+qrY~+1TyXZwt@vlun&9S3gsQ%lzVbbM2`Tc9!Baq+L`3WVztv%6?$(fll_s2eotzRX6-)M0njNdq&)31H#u;jTYsj=sMNCx09H_f+BJPmzBjxPsr^&iIn=tNP>bk7*C# z_XF0Me#V#PdAW_q@6EBbYW%kD%TUe_f)`t#f7Rkd7{6DXY10nz@kx~ZQQu_$A9fR;2>-n}{OmcJ z{eLQ){0-#)p$aE|{Fu4=Mc_sGofuib?*so2_cWg(K-x8mk%l<#?_VC-rS)Zvthy8ylT;db* z4_4viPm#X{yePk8-2cz_(m!jgZMXNw{+0F!)+UyePkuh5R0_;`c_}AGz8JH9kcew5?{1^GGA}U?m%1{&HCefeX$BBf8^8o`cG9j`FqHp1~1BQN$b<^)2MHt zes9G2!OO60Fq zmB8;CNE4>tgZjts*6UcqO!8l&eLg3#W4dPq^MBtl+_#5k0R&66B}{<i`9Bp-{(8zE4_=ht*+PE5OM3+J+ZtbHN;rR6 zw^{K05Lw0j5CgHbYW%j=FB2u)4{@Y*KZG{adq2br7AL~^{mSXK%_02u>37b$AL2lh36UHJrTE%KJ1=|KY-gjHs-lAlgv1rZ@;A;n5SQh?KW=c zyp1zXY*;!^zublU^Y@Vd0vGPj-$nlKflFJM_n|!0eg}7jNKCT6R!e_;LQQ+-&6@PD z9yjlglX-C&XUcd}?vCr7p!N1m)1K$O^yX@7I*7G8$H&H`C(#x;?oG6{J;S#J$NS!8 za&v8laSw>x9cN*3M?%j2UG4|5e&;SZ*eTAq~{VA^EdUq_k~$rD@O zw>0RTUbm)ihVbhcDfde&O~CsdZ>5WqF1y-%{&Lelx}APN8{y0|cHP>fKX{tqAAxxN zPnz`Kg6H{Ncpr*z)>-dKjwy)8FUOWZJs)S@%bZi`Ik>%Ee}qEMwc)|{{oIJn{nc~l z`=HO6c4jsUzVGKVaNExLmY#F}-O`6#_x+qf8%Q4?rsroVY|gmv`|)W&6n@KnKRW$a z!Cj^1oj;R?FDbmQbP~^6hTU>s>52i~?}?t^zW;}Ei|P8WNR#`bZ^^IWnQ{M*+@XkG zefo)Y{||K+UrYFOeG%ycb-mVXyNAIaXYA?lHaEcJZDzl8{KFP~Fm(vTWBa7L-fhuq zR5(9=X>uqw`o5PNll!mSU)K`^-bv#aHb9O1`=KCViDW`}leO@$2Z0nb;xm z{bKSN@%`HT{aB|+zs3EgVRwhUL7EtK{gwEKydUeEwwGG|A>#)lzW>;DKNjiILH+HxuQ)0CZD*SDmVzpWUjn;50L5sn&bNsMK?c5cxRrViku@m`#{$hMtY^vNom z{PnxE=)0?M@<%9tCvY?VG5ZIfKeRgj5F6|C4{m?>fO=T|&}ofn%`^KO(H{n5b5;Cd zgL$8j(jUN``5J{kESLHh@rT#GZQEO+KUlsZv7Ou%XZyqB=wyIDbcjFv>#Rb5_&Iin zKfFdhzdtPEw_^UVO%Z>%3A|E&7(m`Yf8e`?=G}4dZ{&RaO6uV87aNDqT_fh}KTzR( zZy-KuzJ87hCx1QVH-MMq58QcV&tJOzVUqB{>>vJX{%{yJSH&N!c~+%AfEV+Jt)%`% z{9&wPZ*~2l4_#3C!@p-0`oqhonEo&}z#qCPtC&BWOun%G;qTy;`a_Jof&P%$)#@LZ zi)`lpf9l}z2OEdaktXi{SK;h+Op*U?6;A#J^4|t-`a|jCV;L9A7@4@I*BTqQj?axv zH%gthFk&aKZ`^2p2O~D3FfL)QR(>q&8ZYyn&9Uq-ZH9Bdr*-~QlW_@gM8W-@uJfN0 z8EebU)4m>6P?Emik>&ZbTB{x-@PUuNponfH4#UbV;X#D9jJ z8v8n(@wiXVbHqL}7B~*hxyR!f?rZ-y_r1T#*jvWnZ*=%MJf>qOY!OYLMP6fmhx=CL zecAIn<3f3Cj=L|X{q1qkN@6WfY%gP8VwZ$`_mSAeADhba^KFs8pEdbWUy=J+&1cWW zz9?~!jJ1t;(;9=E$UW}zJ~n`h4`tW8Vl3>Dd)N!?Yp85K#DxCZcS4v0nZ98rOW<$d0`z$3366JNcv^I+L}c@lWs`nQN@qV!iPJTDo4-dc(enz&xK} z=kkxtHr!SC^HJek#&h_DjBku@DB$BKtufPYPkO`mn2&Pi+DLZ==?gd{8ext9e{T9% ze$0}!_7Bmgq%LOv4|Vj6X>6Q%-S|c9|54%6C;eca-g}ZFKX@1T8Wm3YZIr)Cg_FMr z`&NM4^8-r%Dco%h=iM^TR3Kc|zgTK+jr_)~^| zP9c3i{Iioeg-&B#Bw@`fYuluIZl9}%~_)cs7#mx^1q$ zWe8qR`GdW!(?(ADv6z5ag$K z{lgy{kL;L9S;qVyd5rlE;y*hsK84?kjqhZ9;O|3EmG%qp(Z4JD&|^s-qj%H=&#lqt94Y9^1wOzG1LuzEyQKd&VFaWQ{e|?vC6zH$^JiE$Y!EHY% z*Ix%>_gATZeStP8=C7}u5Nxx@UpG?!`iS%FV1K<2-462C#EXUf>paR5e|?5Let%8! zTP6OQlJ+aZUoRtlKm4^j@2^9g{x!Ahd_6(kJpC)*x3OA6cIk#m^Y!CH z@GkHpRCso5x{dNU*Fe*ZT@fg>vPVtgZ;G&{R{HfKfh4uuRo_O@z>YLe<<5vy4eCH#ETmE{p^}Sm57`7VY*8__9D|n^;x;u7P&0nh!4}T6% zi}`Df!e)=ZZlrj)=UaAr1^erA^e@O?|9MBDzy6l8#9!Bt$M3KA@LMJR+9B;%hQHoM z`hNOrE92MJ#*Fn1A>z%pC+F)e)Xnl&FV4R5h9~ChNfl21)Su_;SA^g_;1{ZJ%I~85 zSt^|JBTv!)gM0n;A>;ef?)@>u4&A?c)Be76-e2#2oc&^VuwSgHCcTriH*-z}K5MPn zWJedy<*;t*U9;ITU>$<__S_hAZpU1c%g^6T#r7bd4c{+juE$AP&U}-#o|+j}ILBkG z+ko4;Vy~yhWDgr_BldjL=0X0-yo!76WTe7g@mFKbRMu0iHB(vNH@=s+sW!uzi+aGC zzm|P%?00T!%=W5AP@J!g6&evK0l6{}#b=&pf@$PnXt?7JfuIapq&Uk#;*ta>l z;||tP{xhI(eESE=6MtS$KEt2cH)hXAE#Wt{Kb!C7G3<=7rXzMPx7KJLKnD_ho7%HK zm2}3M4jjo2GC6Y6YI9AegY5%Tip!q1?Q`WVfx{W-GIkXGRxhWaTn!cN? zw_;<)l1Fm?FZHy>x`KB%+IViebmVC6|MlXn4le6IM{xhI3eR#s0_FeEi+jp%p!|!x zxTpL!%AXCs{;DGWoZ+r{tN(TT^Ip;hLH=xg<3Q=p);A7}HP|x!`J32V6@RwQZz=s5 zyqG^r{9e%i`uusk!d{O*Tj#gzeH#`ey~Ytkpu zuE{NpF?6@=+xUllZ^EPI`M&6=0FJ^%8O!=PWXGG)5!#H0to@1FyN4O`-8tERJdN>V zQ-1s?Tpt5&pG%#MHaxaBg77=++076b})6qdoDFIWSwhY zg=q`*owE3FY`G(Ei!qj6ewgETb@*MuKD;UHX_hfKdEL)G$a(e{&;G>hz;(v{#694@ zr>|UiSi9^wz5{;lzrlaE)5wlG%9GglDDsIf{oc3lSPStd^Stdd#+l#Cd55;9)dlSn z!4G5)_(S-Cf1YEIr%w63$M~P}T%7yakI_~!+1E^4-NJrj*=O2=-O&v`%_5y~_8nWY zvOgJHMy)r~FDJeDeA3cf<2*9y&$TP1FIC~0DBqJ$>G!Je96m?>yIi=TFHZSW((z>}{g*D>^L)yW zJdx6G1~2O0+|lCn*FOLL4($-=-_y-`oqqfG_GX-{^l$KD{(U+&7W3~$+Ts7ozYleu z9qixx(a);<``%{<`tC*<*)fdr#J_d&1^IU!zpMI7w~t-UJFL{dxA4@dI{y6*c9-Md zuamw~|2~eq!T!CA*?(uYO*cHytpEAwynmbiXW!D`-PcGc_KRbUkUH@>izSM>L z^EZ(HUKP&syLkRxF5F*!it>L6Uev#{YX6q_IBCY@-u~O(i$A8Y|BlMOOV_!8y5RwR zo%9Xc2KNm~Yz~Ualbl-q}Z>TA?_G|%GBQYZv3A(A;#SnGA}OrH z&GAlD=FkG-h%w-{=G`+eplzjZWbf$1zBpo%W1lyMNm_H_vsNYV%bq8H2TdqN zcZ|M$h-v==R($?0w#BU2+&SAtJ)frkmGMhfVgdU0$sd}1`x~Se-_LyDnky&W*{Z%> z&WH29e++&+c{7YJB&{blPfT#;%G)k%)}N&Afw-JS_eb+U_^^;=Xp_Q%g} z)~^Sb_g7Ru_{M`OJ~)xK{BP^Wh1gwH{dmCi$Barpz>Dd}fx_P+`Vm*z{T0!VtsVP< z^<#7VJ4`=P7ZvKqe~v^ySQ98kKVC(@D%Fqw#kO+v@g^o;nWy_u{La=Zk*u{99bO zzx)Quzutv=%E$i5vCaBi6)yU5bhCa9c!++qI`aptF{ECw#q3P6j z@P8L>`nQF14kdCX{_n-n4;v>wIRpQ9;r{Y_DE}H4?kOMrNMZkFDjfT}u>XAUlJp~| z){lK@%m2219FN^q)sHH~AKM6ji|9wa%I>d-etdqo-LAp<@d5f0rXOt=6za#HDYMl0 z;}OcQR6qWJ_LQR^za@R8`Vl2>pnl}6_yPZGI0^r!?jHTHas03C1pMEH8~$zMnL+8U z8Th{oH~ibii9h0};QwBHb)$oGpTddwzYF)5Uk`r13-^?d{ax69whG7o2=<);UXp&q zCMe^N9cjz|wtmF0yQ=z8Z{E?Oj6cAO#UGmre~akHRw}!{BKq;pbh}-H_2YH)FHApn zKdn$dmQvc=qh2J43%KX9(?d-y+f_v(j*?kOMrh|g-) zPg3F7pThoQ!AsJQj9NcN(w3Hf80Xd*znJINH{$&19@t$~{Wz(}{0De3{rCdz7t@c3 z%I>d-e!O~^-LAp<@f`XWrXSG;1F z?{@Nwe(?O0ytt?QHp)NNi|5N1{Wz>ypRU41Kd}E`a8o}XXt(dFZEK9M24L=+xMM;j z{VUc}T#_f>G#J%7)cwQmPL z8+V{(z?{30tA&w$H@=!9ja2 z@^|NMIMnTL`McU;gRHySSl_Vgz_SfI<*s#O-^kHHHcR z^f~o#)<14Ito^Opv6KG8UA6yae^O8F7~?*-uRrcT^Rsow{n#t(uAfkbtbgpy`2~6Z z_WDN$zbpOs+(Ws4>o3N>ialtX40k&#*STD2FXw%W_DWl?qz;P@*3#qOyZXky#_@lB zvx)n`So288UMIL9@7;aZ@7+%O%DQuYjTW8GpWX1?Wnc4Q-;6r!i+*9qw3ggD9r=BWek%1vZ@L{la^Vf&x(a8nbN$j5 z{iqN;1s(@C{k`yfg81&Q@NwgQ>L}m33E2NQg!X`ka^A=rE8O@kV~EuqDCXN9SzQZKf^8cOGQjxiN2xu^$XP zQ{-$@bPM(olGoi14>`~F?z>EWWS(vM4gHR1zX*42w{3A)`?0OHp8M+NQqJ#P-+xGv zPxNUjbL^$vSC>EAlw?7Zv)bN%&N+EBCBUY+$?G{Cv9j`dw*|K)pT`in^~T9A0p zwO$KvPsG2MxiwAhJQV)OdM#WFyw8qzW!#6yJH3hg))+-JVRd6>UsDsJJEc>x7X3up zAQ0yc?)bqi`Zv9Jx063RIo)tbi+-3F@66+zznI#hf5VG=@^_JcUoY;-ABnfD?Z@`$QI4_#^yn@45U5Aid8u509_2)jT<4{ZQ0S4iz4`wA zdQ^kGL3&j7`A6$}KuS#lw{^g;N%r~2=cN8cH0h;yu)VS$+tDQJUOc5Hf!ntDHObzO z{cCI~*pKbgr27@N$bM``ldSVuN=+)^d{&Sq-Q+ymt4W+!Huk8_qn`=Vq}LYv_j-@) zNKlrTK{#uhB z_2T*bvM&5alRn0ad-AuDf0!5dc0=NCGTzz^4+pD5a*1Zo(eRAFVpwcIa z-;3$fy$X9h`efaqsMIId9f~S_YQmOc`m{h{i$|Z9n``AteFCo}W;)k-cCbFpq~8hB zr+XjpkMl-$>_=ImPgjyBNT2rL_e%6>FWRsiecFli8%v+8m`L=AZy=8{V5AQPEb|}%W4dY1 zvxD_%3VmvjK0V)6s87Qv%h>-zQi}XEzqC#;+%oCaPs$%KkLOk`Rl*7 zK!3=Kd+d);ey11Dmyi8j*nbbWSDzkef1J6!pgCsQV|TYT$1LaaK<7)ZNM{ZMd zep$4OShRb5cIWhL-dQpzrn1i9#zeDZUd1(+5taS^t~0nT{{8;bta-?7%z2jK#yn(x z4yu{@1Zh@j`~A&1Qz_FKZ&_z?b8=^;_-Ipp-o==Ya-GE;%$?B2nLxRZhqU&7|Kn(f zm|wem`~6Q++0EF`n1hzR{@a>+45Po7buVYmeBNR0GG8ud2ADJFn^vPc7WNJBol_dq@z%kn zPVGW|(W#Gp!h%#5G3 zUDBy*xdSX{&fBFi6Sp$wymMo*iM00o(qyT>Ut@f8-rrEz>xqwgtnsd#ffj9^ z=F>ZHJ63zfn)6PMF#W}zUmA`r#p0u_6}CuxB;Mt3|#dG@})@q>KlmbhO__-(J-{gJX& zI^>yelC#eAAD-kf?^cVEO_-2cwXHDiLYrg4z(u-zgIae%tZmfsVS07J$ zk51Wh;Br40e7YnEmpO2mBZm(+fTK6vQ<-y$8FS#ntnnOohMd!+FQP31ar7c}R+Ii? z6^EbYi;edrkT!A$UFc&vW4(`+0tZ{NGjKJU>3W zNk3hMQ@?y^wZ9V$~S}QSQke*E)P^f1&QC_KfCjECMdbWTzEl1C; zA^m?v&!Ss8dRBi)lb)b0JbGs1;_v4->8Gf0(US|C^y5{y=*bV7^dnrjp=Wma=vnA+xnJ$h!3M^*8eD^^s+XTQdl zV)5Di3R^t!nPrPIK6BYpPJDKg;@P&I%|rK9de(XTpn~{pCgm;Wo942wx>$TB{dXmL zc9Oi`GUBtNNWT&FY_$`gWv%azu!f(iZ_#(7Eo8hXxS=;To|%-6Z`Y#l;KB_(vGLr5 zbi=q7eOncd-nB(r^bsL=YWo&_Xb9c|K0t-@{4SpV->gZ0K|Cz`Dg*XZcFO$M_{6U1 z4tT^pGqRrOjo;$dx4T5|eDg_3?pctzCuhFLcQdL*zq4P$!(e9=eZ^Qn;t(|Y>W;b1zzt7?X?A^n(cdB)t zg|UBf828Ls_GYXxVNCXios7MYd&j3s!86uAsCJp>I*|Qp>=*q5X)miY?L8NJwK|`@ zq;roEf8enYvHO*$x$Dj|Zfi2ar)nASMqcWc<`>|v!dYN@M);6@CXjjhtEnZ2-*s#DxX@B--N&DXu zgu|yCb7aCN8GANU|J=&HCI95_>-amf%Dflr8vaha)3@XWe!q&plZ>n7TWe@pCtB7G zCz<=&&5GT=mabpltgqSM&TT9nsc>SW`Y)UH6)xOUerC6H>WgOm z6&0T2%ozCdF5Lh89-jY<3g`J<*uN|UPhsD~A$a|UX8m{I>#wS+zO@?q7TrDl19?xT zzIDo7e2h=cv-JNT>f21=TM>Obo3{R{=-b}dTTI^$@Yq|ZZ@beEm!faSyjZAjwUjOT zb{J*&^-cQkYUtY#$NuW;+nd+LSw&^J3j`qs0mSzoNe(YFThpSo~E-|YN6KfbbAPpfdz z*Y}$B`5|}@_FWf(r^x?9@by=fxn3z}Vx|?WSGJDN?4JGx?amlaVm7a)jWhRHB*zhR z_~yhl?%j1_Hu^~W{DOTBCb6}3hD6ry{O4f69=76|=ws%+Vx%|M?;5>v&Hms~D-L^x zbqZOh(zere+ z|C*=Umf5l%LEoR*8e2$vk`)tfg)O-v_n?kd*b*fsbmBekIhAja8Rv}y;?t$Bdr$`t z#TMd;nB2)K@u?N>eJJskKi(sqyIs~!vD-z~HS>CC-;4SVdgIYU_Q1>eojXTQH||IM z-?t0zMqNgkqJy=LGd>|r;y-;$J5%~z;4;oFH~uru3o^zH7~7h$pZ4|i$Fwn=E7Zv|%(FYO zozM*#+fK`CSOShZI_c6vTPGREBqmZO33O90P9OSvY@NQwuXYo9pPKHZ`^I zBW%nJ3D?5j$+mxZ_cG+_tTTb|&ac_pHZIM+$~vpG9d?Q~HRbCoW9R+BZOuM%jH#1} z@$i|n%QrFYd|LRriO)`W@7AWjJ9c_CJ5%e@>}yS15^{$X<7oFdUbJt2aNCwu?6nY` zq%KPzA?;-~rY(12i&o>ag>;h`i;feFdkn+R5t?Jh%i)2oS#`Wuk6+8U6}^aB>#}~$ zTIAH#8`s4?=$pL4uMtuf_GMXrmU_6`EajBrZ8MGiH2%IND|g!m%_X?{mLuzEGsdzB z*)v1h<<_2=Q{?^m_ssa_5@tHKc>9)&bywyI^n;$hWz)mBzdql$$eh9pJNx&%jO>_5 zxzfL!OMdBJ-1pem^ILfTVvX;m|B$nk`0HfrTT&CKlW2U#I^%6?{4GK4PhGRj4@jFl z9)zRuS?m7I@j*CT&ocfOpO^;TjNKagE%#-j&#jE@JJCPBqg-d|H}}IwHl*~=_cip} z##iTY?!v8Y(mzt+$*-p)ktY2eFW&9s=PXu_)};4%anJMH)~EDWy|^ns=O+46`U_q> zZy(QZ;Q4=1;q)&l?CC1R8*7{AWHQu-Go-o%&GCSZy5*ts*YhV@)yxg@ma?eYntk-AK&C{j@peduz0$ zezwBato!ViWlKynnm*9I@6m6|MD{%z=Z@rFW768^NhN-d`p=X4V*F_eTN3WI=nbxY zKEz-CzUwn^Tf?8R?lDfvIa|_B{>0pqBJq2cKEbnJ(ARfG6}D)c<#KeGJ8z8d49ng{ z8E@Q?=a96^Qt*s5r#st<@uTSQgQQ(<-O(%Yd&2sbopVN%zQO&D*6(BU$-6H)^S-sm z5)HEZd-T{i=byCpCBB2!`oA&qANj@zXZr7)66?M7=s~XYu%kM2SDxCX%QhT@PKTzSUBSpU6qMxI}$=^f%1{KcpyLkSoDx7m6ZP>4e;3?{V zlnR%1HtdUommR;$UToH-WR1!nzl)9=bGOMo(zU`7b8nGP%S}HdmM)0jqrQ9Ck01^X zitDn(w-QVEsTXmZ=$m%R#~ zjQMrlr=_d+R@m*)b#uIuv*&J_y!!Ro?$aGx2Fu(Hew36m%lOer);$4FVoS~+NBXq% zZwgzYZe6#|w%oCpvl0E5TI@-3F-u`dCjU(~-+uY}N9e3Fihfj(c_t}r^ zm`b@4pEr?T;`8CGW!dvT2k@IRKA+%Pe?zmQqPh6g+PBR2b0BpR{ZG8*(tpzJ;MZgs zAHnCS^dH0!M+M=uMU*)nX|q2B;czf2_bb5F?*!q(AKBv$f8_pzMbsc`x?kayux()lEQsLO&gZ+=G za5;m`^B)Aa_cZwDd+um5_cPqtXxoVSDVEk`=A2V5xk4pSMEw6o=^cmnQh~2i=hOC)I{I4CPr8VPDp{RMM z5WHP1@iuw=eMXvk1@##TzTKgmhj96hr@ydtF(z~PGB?$jx6_Ed-MVPaujhQ{c)mj$ z6zea(tFW1vEPsy2_l->U&*$g9{%Wo@XtEyzpYzA%W5DgXui4gpSTgtSKF6~+b{3rD z@%1GKICgsHzT_N_vHt{r9&gzx`$~*&ZKK~#%x>M=m6dapGWT_dt37$|OTq1!y}br) zme`Pa8kq~8{E?|+gRztT!mG`st7E>YAhwYFGWSA$cT8XBsYia^Ui;9hhx9X6Jw(H$ z9?Vym_j;jucD(PLLmFhBL;3(slD#s{IV3dyZ8?X;eE(al5BwYbm$OK(yjkPZ{jnX7 z?`i7(Cd53V`!BL@!PfmhQf{fbzd~Yh{31i#uW`TBpD0gsKg#|H8FSh5GJ6N z7S7c#_Tu^H%h_u3pR2;LFMh*Zy-|f@UmNzF2AukxILz9xDA_ zf7Me)+jz8l`f+BgFLB`B*f}9@r=i{8ww)8@d#H?sbL^#)^Dy@LDDmfF`)@zpBiQDQ zd(QYM(-!tLnP;`8#}okl$N;1sWpEq9*notwxK+snDgzo2v8 z7?gXsc8&EW`uc9Q;?52`?!1GtaLPovjPpnGJw$kLk~N2XBk4t}&E_(%qQb#L||%(mnr4=~q)X7vAdN_;%ZyDg6>Jp3krCmG1g?N$d)?KN~tBW&N6G2V)~T?gVp}vtoVU(vNuu3Cc#}o=;GA z(kgo-nksrLWy;?-TjjoK{8rO(9qSO|hYd}~neTo6o12Z;Q2SW>O7!0Neaz7GfL*oD z=ID_0n-jEjuC}hDrzWYNa{OkCHVm4&E?YZudEc~}=QqrZw68t6w*8ai2DE?5`&mnV z*~|Vh>0kS>c9BNC<^D{GarlNYamMx?(tby;u9ZIIqH`nKj5=-g3$t{MG7hDzY3&Z6AAB-q$;W7-v%E ztS)Wc%HgqxXOGezmh#V`ohavFDMz05&WE)l?05V&c1xRmhxhpQwO`!Y_qg`_hT|gb zQm2Q+ZcV%BZ}feJ-ITN8IP8TZw!MeCY!%Ww&EZdYoa`Ve3}Sj6M9$&avKiPr$Z#&AMH9|Fg$o*Ceg| z+^uMzUO+iM-2S^KW^VyL#Rw@9|{Xg*w>nvf(E| z@3Ao5C#3VgLn+Js4)gDCn(>S)UGML5>;1ituU^jk+pxv<>vHgJ{jr-EcIHOkzO}<) z>)i@Io_3J-KkYcu6?w;hb=g?bI}Y)cPk83*OE+1B?=E?I!^{_jhqIV>77kjzGs*Uy zpDZ!!VEawWv1-3*bG3I8ziA2an_FG=k>}ce(_;AzYe|OREPz*(X3Ddvcx7yb6uft;xm*Zd44ZHg9U#HOqZvQ$@+N1>k+R634^Ez4RU)#Fc z&(_Fd{(-vk7y|7a{*M@A39aL1bmOvmEj@rS@zR0Xn&l1jEokYo)Xa6)F=oipkJaOc$86en z>$<+a(JlOY7xL6?Qnyf^8KDpQ1if8*^3?X4H9vZB!=P#Frf%9d+Wt-cEqYU ze_C5J>G4`^5!yFt*1%Zr{DE4!X7)b&%{F{1POP&1qz%|+_Xme)(Tn=F&>rp~|1MV# zJYfdUtlMPky;kn6?Jv4JnszuO7P}~prtfm~&=Up^OX`>K`^4P_?p-%{8zbEj{Cm|D zZU3R9ts9rrCCw22+vWJJ_MUj?(7h*-b`fc$%vo02cMjC{zZCmtW51+*cW*5{X@s`- z#F~+RomErUaY)UGcZbwy``^KHr5-E5d+tf7%$oz4HSU~Hjv87$930is63hIDXK&a!(mr@st##MMo289+ zzt6CAlbo+OWmtOE9a?%I*pt!C(v#rUJbr(>d6*IJ)bsD}^53f8YVGgTazF1e#6HBK z_Pgzy7I}XCRkiJ3UO>F~y-nKJ%^V0X2f_Ec_Wh~<$2?#9%wFQix?0{V?R>xqbw6KA zyS=*u8eHEu$KEDX2!HNUGV1i+U?%0q1{%HUiztF zq>Bxb7@@A?Na8W!gE6+J|zwODt;tR<$y5puzv_&#kwzziNzvi&%2L62tzIbiz z*6*&Z<=j(m-;6{gOFS0qUA4v3`!n=0_v}>Dz9Y|BN&F(;yZz6ho1qoiZ>-of`;B&q zM>mc24%SwGbPF0F=@$<%^GMzIAEefUBZioIApUrdqX#1_Jvf4PKitrRbu*{)E)L_J z$evSTgK3fU{zF6`%rrr`=z`rhy||&z7;C=%bu-Qv{yk^?_KNGbXRP1;!Eb%Fk>@us z|MbamgW4z3zJJ+TTm3O}7Ja|c+GF27Z2fG0lk!(J*6hD(f|ecv-;S!;l=mL#=*cHxhP4oF;8!*f=?S(DxY&aQm<@b*s*kM%yyyL=j6T>666PCWh5tgU3e zl<`1B+Eb^TZ&BXylzSZS^H_9sfKj&@Pe-C|F zIcVzr@a+XDcQ$3d%WumWyWJic_3ko5(?`YQayx~)f2zo&Nn;?`T(vo5%BUh+u#pGo_0*3TaQh!*^jv{&dg zQr8zQJ1NqB+16U`B?GnIC$LNGmNux{QhWYI{;ds)8}<7qJXqOuc>5~q*Fv8r=@NHq z?MtM7wYBLQZScZr5pB`hg~zlT@BE%&X=xYH$Vmg~s~XL|P;8U;b}4qPWgb;*c!R!8 zwB_BMk7)l3silwZforWrNCbb&Yq`@GmG@a$wgyCRkN;ENVt8f|vJsQS8JwEBX1sxvSadVgJ6 zq49`CiZ>I!643gqc(=2zTDRu=+TbUF>OW<5lI~EW+XIs-vRg~}&If!eFsUIsSc+a( z6zdC-78qHP9mMY^Fb;zcb8b%ZJ_0*K1w8g|=b4L<)WiO)R99vR?BE>MToLsCQr-@(8u)}QF3G!^|Ma0r>>Em1+TfZ^!pkfv zt`IVhwufg7UA-wd&g$zP%b62wWymx;77)+hLvxE%?@8uTc)2#`_&B<^Mndbrue5tF zQIuDHu|C`T)fk&ExQBgjx!q@jH`!7LdJAYPI5rylgT>q09pek$p@dZOQk59thxiRG zUVDDr2G-u>l3}jUD0Gguw%WZXlh8+Ge?>lAGQ<@+2i`(^RPS)=4!6d5laUdnjnlL@ z#jSYl?!n$UGFP;tw;k&Zj)ez5S?>D;xh@bDXv!@0NPz`v2bDob#v5SL~g^ zvB+GS&t(`gSCZ$q8Rs?zEyFxP@cI>Ys8hsxpTl1H9K5O%elLBsHxKfjW^88|%Lv|` zjIY13lv{_kKRW4|O+j!L&}bsL?oTt}A#>m#*foPM7BW7Y?~F0V;Mk~s#yO(S&p7d^ zOj&77ZW?Y)_S}K3sTKLhoX=Kc9<{kM=WSWUu7Td4yQR+yf*;cNY-VXSw0n>8n0;cU`vH&VxWJ@98PfSJokZk z?}EsR*)N8zJ4$gy-?RVAEoO$-&L=9O1V(45uHYK8_}))|Df0WE&bc;HM8#e zpXoKbjkdn6UNgyP&(v$W=KUA)lZwqzVUJ*+MUNF-N_erzzYEYW7Vuxp+{<^14zsUR zL?N3<8nTqw|4zxOkB$zNYj&(6)!trExq4GHYb+;K>A1FX z&8AlCwRNfI%MWg2|5$=78H9&RJFToQY%$)$i*#Ky2p{|}_V1uolk46HMj`vcUmqB) z+q_I0vFJA~D_B3PT)qJRB9C{UQ`zsV$c+)mkCDic0~iB*j{Q#Ba-bV^ZzV>An1kW? z5yj6b^4W05w9skbT~C=29}t)SI{G2&_D7}HWqypVf0{n-vLv>{|K|q5qkU*YX4WWW z$UdcW$|>1P$0|2FhAL%;*%L-nZ`%Nub91$|%r;aRf{ZrT7tQ+~Ygsz)=_70z+y^^k z5$SaUUCu(%?i^vyxWqni(&oIWWeUE(H-;!)6J{Pdn((8VgyczYL@VB}t<*Q#TZGOg z{mhzZ%Xnj8Z=J1YyXS7MR?3Ry-)bq#L)NP)x6N@prj)%S&lcrc$L&g)n>pKT9Z{Ns zPAB|Qa4oW-yAxe-jN*Ngc{ms2lKDt-R05B>jz*=dlK;)|t}@Py%oW)rXuTxEHp;cm zR$7v|_jJ@0kp*fT`g{KA_$iyM*h9wa_K=$L0dwYoXU!h+dapfXbDnMwsVUd(ArDh# z^?1V`Lb-h2Ti?{}AvNVgG@FUoI9A^fJ82E&HVVwRORfo0w!|pg_It(I%9x~FKJ&CD zNo*m*nsU@6%?_gN)r?ctpTt4T`XTYr=vp%7W@tdtimk&u@1&jE_^~C)^SH>~=kQIT zmz|zB-B*kr)>$;ouwmQ)-A#r5#5S$#VxnWoTCRlVO`U4}09{7Q!v@k_Ek1xq&6dG> zM>Z6nldWz7JXz@9#=3^S{UVFUQm zB7IndUvyD0iM>|w{t*6fkL*9l7tJxsjuzwtEkAL%mj5f@|Io}wHflMX>kB#98|iy= z!xJB-DHf0H=NU@FiE)a{d1Y$TrgG@iqeid!;m=)X#U_%A-9zjmDmIb5oFQvror|8W zwUef|a~b_8q@C0BjG&EJhNmqscbg^~K0uY`u$8FQO8wr=UwitmxT zRo}{`7T<%jt-g{gB77pF==;WnwvsMvDPl(vJIPstH+}^Di(jRc_n-z-trPxZqb-LT z(JpPKM=A$g@V2#ztsS5F+!^SplO_g^`dp_?4z*SRJU-V^)&-ClyLkOAAfehtKrFe+ggnu3-Q9@AFnu#ULM zR)~(6A$0z4Gy2#H)nTRI##Y#fEiz3R;Tgf4=Ac{r96jI4UX(*0_pwbv+h3_*?799SJaip*&R%7$} zIeab6YHvDav3vF+lb?hJuVXA@D7SjF%QueaH5RwiGeC7NRg}pNQ)r`$S^hriX=A|8;*% zFyh<$WBwL#u|LMHs2<@xmE4&g%UI)(t+1)rtsONj6ayZb1}9Hyvn$?X)|iZ@%axmF zsqsza$WiU8&6CR-7dg^JEaP!&blpwJTtRD0-M~wgA+L0GU)L7tavrL*md!wZ+H<~p zZkwI=Mr)bKQ!_@yWb7YII(+C@oXhzhY44FX6B(;*u;M-Bo?2E3Efc$zcnIFv!1E#1 zQYL)n{l{!`x{;G^WG>^8le&?UwgBgl8dq8Y-4CJ8eG{WI+Ts+i*z1J%x+vS-sFWd_ z&pj09Dsv%sp)V)ChfMU7CHG~%7t&=S^L=J0e##NXBI6U9nMYY{`Av%A@Cbi60?u^) zO01`1Zx0ab83+Cbfbpgmvw?q& zEqRjYvW_a`Kgv5Sma;MM@4=7T=HxuCl*Ll#0C>uo&-lTg!!ocm1$+*t&g_B8kcq&W z2%L$@Lo&kqy9FG{{a`u375wGw*74^U=qgJw@HgmE*Sc4h{72?12L8>0ZZpQ8dwy}>8_6+4*d3c{nrW-)sKJ``{vHuu0q@jEyAy7B~1Gr&n9dtw1HhE6vn19 z#(N*?wTn&`8CA2j>agEtykaAL06kmw+S4LehuLEPlYEh9Bv1O(sQGIW>Pjdt{%Y|_ zlo&qi%WsWKylZY;qKBX8utEoRaJpLdZ}z;dF}r+?_;gZ#G}ilfXyS?5M6bj|RWZgy zY+0t9L75Lyf0(1Cmrc|CkdeR>KjZ>r-PDMYUR~B4>Gk2C{2W++tR3nV|D?zl<5Gud z{>Ti*znJo0%pIx8BYpjlFHO794{5vXLLcaw{J6w$pZv}9;u4c?iA&7p*Vk5bzg4#t z^-aIWNEaKDz4$_3s@~TmuQsMfj4{15QtP`ureWSXaHEZ(K_9~lj7j8K)0euk<M* z=svWwi=&_i?633etdVHn8E_|Z+G&2`YY|x)0ceBxRztj}vQFnjb-pRIAbywc@ylWE z8(0hC(-IoEmNbbY(`}(G6w1~fjeEcrhXqw4O4d^<_d(=)cxu zK0luTpZ(~9`O$qL`WXbVWy##^1dhZKo@P&3Xh~{6j67M1?k(&5=j3%;l;8pBK;u{rRU37C(FBjWUx5csjF#B1t#DV6I;yXpk2f4~{ zuN!;r{ov_RXh_SeNzwCMBfMM4DOBmMMJYptUwrUH zE$70Zze?7C1D+NQJkg`fxts(Xt<73=VU33+)Lm)tKCv6f9J#@x*bPL-Qu*~aZ{^0k zjc49OHzSs%-8x#CJAwZ#@M?6mj5dCi%uRtZX#4I|Wo`!ZZMQ3-0{){@6{lV8)td&R zQy;Mou3IzIm05I3-;+h(D^MKUtH677?W*3ogOwHGb@$~j&CEG(Evu#77-YZAYD{|t zbuzGr2`m*kM)Y-bx9uXcp=*7hq+IH~lX2^9*tb`WLWZDE(U;RNqmSWjOrU;asQV3l zuXofPWo*az9p~4<`bFNjU-X-t0myBv<1%&7_FT^S<_vJ1aP#iJDt69$(}v6$GGLJB z)g|_feW~#o-#=S^@M?8%#uutG<>kmxL*7q)Kl!KZ0~)?K?`2O`cFdq%(QTz)F@iJt z788ayN3_ymK~F2y@Ep5+H+SU-o+@v<4c-N>rRu<@TJU)vaBk#x2pg=6`xeG8y)Uy{aLqZV_e3wZ z3~WzDRv88TtWhG{+a|5qRKT2!e|-3yU7RCYR&se}1NEf;FJmW3W$r#h29)noJNoop z=58bDMd&z{^l>%s{f)z%8*^T6qTJ7^_g?<}nTHr(1$AW%GPVqCpxlGt75b2|ITRUN ztTwha)Vqft?Y&xzUOay3Qf+Lh$hBf?a9E;y#`fN0gXZkADX-pFGCtFV4b^XdY~3!m z(&4u$-UZs2;_9RiW}gIS(y!&D74Y9?9g@L0grp+&0xVy1)6oNV#VW5ZDY+_>yILwYXy&unBfhh<1R^32?)DL-B7bL{r5hmAGF8A=cQ zMEWH7`jmX3u`9#+EA`|)g?;(=Xlt~YKFIuG7s?n-y7WcLjOSU~Pbx2kFX^_D0mAcS zt-3DpmYL5=viH88=TTmbFG`t)WN(R?o-)#VSJ?A1^SNTAx5#`BjP%}VJ~xc=-p;em z7ccQv(4R_vOCC74(f0M@2W6jL!rB)8Eqi0@SL$oXSs6=idFF)uNBf@3IPX4K5E<=p zpL+bDU9mU$*yHvp%5|xOlve{|Hz!M-6yV8!4m2z_WqG$n)@)K$RfCBxFhhxSooHYV zcEf+S5pyN6Q)!CgOd+j^XN7-+f98`* z?#}#dup{&G=NBFb-N{!H!Bvzd!TDj*^3) zc_sbs%mLV1I<^?;zgT$ivsWFNpFMHs!9N1OqtQse=T@!lFXrBKaL__mXU73O{X^RO ztXbeJ&ioT?b#xf%wDp;)IJI=z>WEaF((a&v4WE8ySDfo8{|DOYh*O*gXzRpaNxLia z540ow{v++27^7^yFW)rL?=7ycv;~%#l4Q#x>594*lzSX_*1+Am$#7F7rY9mdiCg zOJAGzy5{8uk5jJjX0lE-9#njVQ6{49FJ^w=GVcU4-z6}pi|zP;nV)i*H;sIqhh9d0 zH2FFo-Afq_ZbfQOy=%<0;xRpGSDCN^sotSxTMd%0+o>-nUmJsaw2`LUrX41%T1l67 zBkGdPG^MxxP}0)A&OMkC;X0x5KH_MEZ)yH0>?3CvTaclx$juSxW0AhN2$wU~=5iu0 zbPR}9H5noI8stgN9%Ym)5jjyi7ur;^G_#yNFn|oVOHn#nIdf5H${Yph?ZWFOKr4~R zUb~ct_I>bCkIa?GL4D-CllZxGo61!Bl85}xxe~+gmD0MBv-qrutChJa!*&10K;-Or z3wCH?ZrAZ#c#TeXHp*nMPUf&K{#3F&v-@jnhk|@Om-TY6XAC)|q zxtaICrOMn}p{YNYJe0YM_XghQ4R$#{E_pcf5bw3T-!|0c{G{ZO%x>N*c)xvw%lY3W zD>5D3){bJ{=Z|tZ|5Ea3W)ANz-j`o}gS*$-R9Juz%d{?Co;{@AI>J`&`R=PoLf2q0cWEeQt3)(mK;C%zMQOce=o47KO9oM%d)Ghzr z(7NR>469qdCaG@u{ln{)&mU2@G&j1gkiCA+`Qn3Z#mdgF5|tH=!S1=ytmPSzF7|>! z?P>HcNA?T;GX}fXT^;FKSBS1qh+ShL>ur}xthixc`66m_viP))SQTg4*WDY(=<;I5 zCHxOkD%K$@*CA8Z4T>(@U#G-0m9dVlQ4~)T`%O9VnQ6pP#3=FGtN5R5iTA9x^sKS6 z0KE7a^uB|vDeztvK<9WCJ;qp5WevPfvqzOKiOLvj z8R&VBwo08tGfGp3Wt7?*<}XLiZ&#ERUm@PDH{>+s*xo^|-gv}Yau zK4dm&%i2k6m9=@jx^W@{J-HNVYQxmr@>USQU8ZexMw`%J96{4(yl zAili^KK&E;1;7^>OJX?0PFG@4o%O`~xX_uJ@r9NQa69umyES~s{69qB&~qt*!mF_S9*%<7^_{&$eC_d4T zWv($`hGd<~TohyTzR3T)Oh3z>)@eQ9IAwiRXxr4&wRoVgb5aeFYP{Hq#a1u=DSTqy z?kM8&qBt)QW$_`KoIiC~ah|GHR-B1p?T%5sjk$`Kdlxna$71J2FAt8J=4-bSd#J_` z3lZayvsxLddZ6gM@~VZg-b`OP2jUFcl*!cLESKAPDoXd`=cqQ#H`)g5bk)|Bk6vWf zUBsG>RaUwxF-IYu5xZFqv7dn{o0GNJwt2+N?a^cCq^)##ip;6_fJ%tH&tShOrA@I( z-?L;%=J)yigtiXR&TsfXPFwPPjQ_Pm<1_q22WD(m<4UDIHe&QrV9}-nI_s}Z@S4%L zAN{3uTl=ps^xGd?!I9vtzq~ZYXg9`btj!Ef=gY%SZTP068Mmy>Q_P$Ak7|)eTen+$ zf{#}2HxXVh=hn0{ZF`gz-CGCv+O|gdy0_YVfmx(iTb!+P)D_*`icikCU5@{iy+`x; z$a=Rydk!_BJ&*Mvut$+EJV5dkV#8{yIKx32vfz$#i`uS=PmVDyC(dT|(vr+*=6)Rb zF9-KC_?J1C=XUF&Q~(bZIkuSLR-PY%&j@u||ZCot%aL8Q-(%bJlTwVOma# z(oxI0%BjHCfsMnC%p`noHTB04i?NkGryN;2n)tI6`d9A877m{vo~`~yx2v--&Q)Jp z8CzFa`Of-cb@B7<)^T;E$n5tFZuqoZ#kM?Z_{=tIh9<`sl2)jygO%G-X092$CRxdx za9@ma#ic^O6|DKIX}1u#F5plnqY(L*I`b(%kg`{sWh=pF4t=VXfBGZ*r!~G}NGvk^ zK;_GI*g0!j~cf|;-m0^IAaGZop!I%89hz6 ze-@CA&qlL_#&Q=xoKi7F*3w$$2AgNbkx6Tl{i*LHZzgsI8+pBd;^t&OV_U1nMfV3! zY^IvbprmW^-NI$(HbRq5+f-tu_}_0;uHDB^J0s0_V;DC++S1rTuFl}3n&eh%T84x1 z6jM%u87YWo?Xc+|#a38LN$Prt@QOSQAa!62`ol zb>~tG&dOa9vUadVi+rT5BRk`a9^~37?b;cyw40u~H`&1$(@0NejOmP#*sjZ=1vvf4cos~%kJc5X{oCbw>N``Q+{ zo#z(!#?J-PME12ek-wu2*#FLcy3>kXl6n#kvyk;R*saUVm6Y8@%%d_^_`oPF?moqc zyFbs~Yim$$cBCt13!(SZtnqD8`0p#i;_hR3Z|IG?w+%Al?&J0S)5r1(pxbSM_|jav9C&dE$|2Nv7``p|5ki&9f`ZQJ(4`c25)k} zm&WjpovJJkf09EX27a*~18?I_fIQ|vi-BLS_S^~JaOpAdHsekJ?nj$#H}3?XTt4ru z8&&;IfFJe7z}vYGAewU30#jn(DO+NcZF^32%DSilUoFhFo%;YJrf>mxmNgn=ZVw|< z%Dm>Y_Z}T{qwmNZSEwy&hHo?W+!%bGweYuNGh89jNpsj=c4Hg*@`ilhan4n?SmT?9 zsDqkBSC+W7_mG#&a#h$;3fMc-uh_RKy*ui7hok`h$<3zLOa za(=!A*&!M~c!ApBWV{n+;L8=i`WDh_+Pfz|&sbZ*$7t{&<#X|$9s$m=8@M+@wY67( zvvrjC7t*OG;q4VO1;a)B%ON}Yum z(`s;3M9f1m^hhkcXEW`+!1t;yTUwkstwhJuW+k#Tz!=k2#UtmRbE$Kfc<(XXt(&4+ zJvxr4Cv7NJ&##s&%3K8AlrM`iH!DhMgH|`*BeG;OXIy0LGTvIwfy@90OIUL=26SGB zjmeo~$g|bRzc(V!=7hRRFEHSmS7{8z2)8OD{#(LoL z1Dnb$%5@!#^#pyc;^(jo-j04TH%}StDHq(b-)_Y(F?DHK=0yCUrK+7KQhm|$+v+UyU<0XI`JLmjby1zepT$gL5x765*G7KkB}=f;bn6qk9=!95Tp`Ao@x10M%D=w}K7B zjMKmHe0<-tk!dPx0J>wpd^)#ctT&~iX48m!H9N}FxeZrfTd~y*HQ!UlYWwM6-qVw#d0fjDG=iqs1c8FWEa4(pwzb_mn2raAtU^#M`UH4`3fi z;~Q_S?3YW?1w5pG=l)4tOPJjM-^_hFEz3}1qZc;Z0#n^#k0uP3!v%$E!nz1IXVTp?<;Q$UIibzesba5_3Ano zrgs&+g*{2XPsp~x?UZwNTNtCzo9LbSjOT${-M&AwhsgaRNin*;!n|ileD!;|XQ+mA zwd!L@&oy8xvS4SO80y+6I(i9uUK(}vyN1lWMZ)eHD%!K{icnYYT|>NUKK}52eH7L& z=DD|Dx!<{8F=oG@!++K+H{jpA>%R%G8o>|by!an|FIO~$)@Y0WlbC;qrCMvd8zEbqAo{+03W{{88d z`__9JoA#q?c#zpWPoam6^Ed5Z^Va_T$maWfqg)@_jJ#;d+bZ|2A4hqCQ6hFA$_b1Z z>LB}TF#0QZC1uhnE9HReSxWo1clYg|0jwqdCi3>~mv+)C_wG-jU5#dD?eY=J{j|_W z3bBL|%bf}?C6;?FI78>#Q6l#;G*9*tgW|V%8?(|VS7K3o?BRaP)0J5z(aid+MvVq# zjir*GQhMPz4^7ujan;MbG>;M4HKDGGvcVXo{x;5*)jaERn&~o^*kqiuC4F6Qy3Btt zN(tRa`m?vXd}et`KSla<(gm)5Zf$5?F7F#yhkeUs^^{BG{1kTw&eGSG+}SmmJuQ5F ziycPx4T;SOK&P#om&cy{hQ!Q&1@91CiH|49-Y9TnFO{>_;?L@0UCy6K3^aT}{l3fh z6}X&a)y~*FE%C$xL+~wq7C2&e6ue&z-WBW(8m@@L6hDuYmH1(yVTu30G5OragT$2{ z1ou7tH~7FQ`Xx49iO>D7rNk-my?c9#=tUNfZMYKh32y;sqVveUG-E=|Cb1uEh5w?% z)=S*gQ~0lTsWI)6CTAjqFB5Osl+p3nx^%m1UAHy5eGGeu==fXNYcfhoc8cHp9_npI zmXz*&_o!=2RlFZmzPG*!cv9ww8oM9+gy*HkclHZx6Yfut?cedgv;RFc ze*YL`*_a6`a1@{5>jln$m~mA{z>DCkg|S?z#CYzNv4fYjOG+MDoBHmiHH@{K{6*wP z|H|r_niCot2fYX7o-SkEnd>MjN!d{Of~u{>7V@pU z*F2wl(K`GOcyPrF7UZ;qI%LreHKTJ^n6Pr0bI!-FSWKB`3a9qeHP_?<((z;OsF~TD zXRh!0VnOmbMgY2abW!mg^kD@w0u3*2Fv0#JSDC=Ou(vnU&8}e*F zyka6{!g|hGXGL#JO%{pV(2uo*tejd@Pwf8#WqgzlrwE zXZglz4Swss7&wqi4D2$i%teTWFm#p9aq4 zF2rGVPYA5h7nTc$^&|5C%(r_sTybHUlfZiL0$7O`%^PRKlA!YoXjABXG4&p_Dc9~I z#y!y1J$J*$7vt~;J+RGv_d=Su71**K!^bCc_P3#7v`qeAc$f7gvBS^y(~g`C3#TC$ z@6UdGu^jNdKIN|Cow3!2w=ZLxK>96z@4l8cd-AG;?;*RSlh>DqWKC9J7ZAF?T>8p+ zT@$9cenx&nJ8uwb+ z%HqAPV^rT>&T-jNGrVHs*v1{ceaby;J21Al+=6tugCWrltY|r7#hT`xPkbxfRjHE2fEOcC3<*ctk?@rrFQ_gd1IZJbB5HKtP^xiBKv*RqE; z#>yRR;?s%H{BPGz<}4ZKjZ7by`TY1&m3vX;PQTu}{928DO>EI_InTCXf;YHGWJ)_{ ze=HfN$5_0NS1B9Vccuilq6gXWld^vXR&jS6d1B{sQBT=0k+E95Zu&JKjy)1vSwmGr zRx7qf!E?aDU2mM1Oa<=&2Y0q%GYcU12e?O)xet|msQQA`72kZrfLwoTxhu3gnLFCP zr-WK5TRgzxmvfK{lPj{943sbXa%yE^i~c@OgRV(u&~ zN`TiV;?o@JTLL|3IvoABeKy{k&Y6xi$k~BK7Vl~9cnpq<_SMlB^KPCg=vHmB_y!Pm zn{DiutNDFGo6ywF>HMPcu{Z{gx<8n-W>W^wIXt)W>_FCVV~4V_pN4=fxVx8kdmQI@ z2P>1^K=pfB&DHN`t!5mp^T63E>><@nS;bFU{DJCs$$KYDaOtDYf+}!Vy+3OS z=TD2*DE?nkKcDngekG%cUuJASBh4oF$V75pfwl4GLYMEq@c{?nSB`qlJTMM5N;yCr znD^Wn&gOByhsf0;i{A#EJE$KVr+isV+>prQBAbgmUU&+5oVynD1@{l42dNF&>Z=V| z@@{F~on1nCMXAVEU#ZB#SCCyiTJ=2$EWuAR?MNFH#HHwG2yJ!$hqQ-~?_F|6Zz+`+aBk#scXF@A?_6;dQ?Nx2I?E4G6{}I5-1+%30b#LPfUt=kp@HwF4TmFTu{l+=l8$<7W1u_kzdX%dfpUH}xS4)iR%J;a1BWBLFAwVNX9N5v zFkrerFd*6=h`xbejKA43m7mSuVwuLz4h`A8TXKmX0>5&W)5o6MI^G=$Ru?#P1h0IL zEQr5Uc-$83!NH^g&6d}|ULmn9oQ=#d)8sDV;8)!Fd#-y&XSXZ#-!fn4T%nQZgA$80 zoI8V8vIjAbb4#jC+ukM56NwQv5>1o}7Ky75Y@-RF=C!!;SXm)4rUQSHPt$tbN63KiOeUfAzubZDF`ACRX9Q;&ygl+{(RV3GBZHP8)$K_^aWp;aTwase!+X`Vap4>wnu< zz4$BPJG`20Gz@<&fN2?Dtju+<$XKLUAdP0hOFGm zHCe7oPu9Y9)jYqGRlM#A%DhYds;s=qnyjgntFvU!T)6JXS;bXPW-VA(k+o=DW!4YZ zRb{E{-!fNw*&n}Rt~j@>(fUyMOQJz<%eix612+8z>^wC+w(OzLRluVJ=Z_mWX{YaP z);O=URZQO((D#M(Q^w=!pl#`Eq{Y90u`Favu1LjSEaS1O{@lo1zpLX9^iA)hD-v0X zaV%g=ZoA80Okbtn3+cBxmkM_H34%ZN@d|Y7@O}I?`cxbbZTxV}>;leMr~mjmZ`xkp z{VCWrkzMQeBBxq98nSDsr(oMO_i_`q8`y#u8}@y{i`eso2lR&*;RF5QB{PgxdgwHa zjwg_Bu6eCJ*1XmpYhG&)n*J{BU1GNP4eKJ2eD)=8e=)M>SN?IE=rRHJkcZBqQ{_Ut zjDH`rsm-UzvBbz70=R}MjjPw*8YFBVqXy!M8M4~3Rn z(eqkY@w39W$LM#dh&({dsXtfE^>d%B->tg*TD{b0WCO+Tf>s07Pi9GebM>mM6xO)F z8qIo7WliTsPW7j-zEdlIn&npWNdHMz+c@Qel**?_TbpIaj#h|V+d9UwqI*V!vk3Wi z-3i^!4}7nMeu&L*N8-7SvJSYfGgR`d>O47X4)@(6?^tztN0EJtvg5*WOZ`f@yBOR~ zVC=sm@1pTH#(M36e_{L!2LA7ipKluV9slfp#{a;#9Dh6aGxpFH<98e5|1#;^#zz_d zd3;}8_`bTU#~tV<9=Msg2y7kbP2D>+R48|%%X{@D-qg+;LeqH<{IxN=`A}naa8F*S z<&(zjKvHFPpoz4RmD$bj^B%?fLGrJ+a6e&Xc1r^9@#L9sel|UHZ5W)dNbi9)$$&LQ zhZS6IA&yyx*F3f|d-?C&p_cKykE_fs={mF*xu~O7^k!fvJKfk!mAVgRaaMx=Qq&+!`x zUZWJh3J+?VqJl?@U$MLW&GEos4cMC_ynz_>^_WKJvoTwRA2mlcW(VL`fsu{qa8G76 zCpBg(@UFmE$zPMzJf<<*0{?26BKZUSfl2(2qmGCDU_AeMynCYj%{joF)0mA-#vhnP z+6|4_DRzs$Wd>!6NJnmHzJtDRhsG9@Z;kT@mhoRo+WYX@!$M#2=mw;%B+aUZ?5Q@d zZ2|YY#|-ob9tOS#n8+c`tAJT9Fo9o9`SsEk&D5O(4OJ)j122-dmG@FL)asG6 zq5i;gq`gksX7)5sqCfC5b@ni3fx8R1Z!&Iy`+L#^CiJ7)+#$tf^QI^{AJ6&V`ahQ} zE$*}-WAx2K7xmb;xO}pAjreoy2KEo`3**}}ePCp;|CLg9DR*X+*g1fT`eGoWUnXSNkRrZbMPb#y;w$k!`W%gm}i;bn@ zOJp+{YZLX~2Unkf7i2J@L&c{0;h)|veE;W-7y)hn0iI{kh5R=Y{)@j$+q;AGNnso% ziOPm6NE-&P*7k4uyNEQgV+;;U^OC%0c{k;Pfkrv=KTti? zdm_C2o&@i)@OSGFZyWD{JnnCof7aRO^3Ps**D&tMU>q0imF@_yz4l+&E1M(#clJv5 z|Gsf9ew_K*4U~c{=lkv{04C^@ooGD`!${{<)6q4EekKdobpk_^zu=x zO(`EUw72}V(?i4}>hM_uHuzcV)&aynps#u6!Rw&QRk!(-NWO)L9wI!iIY#l1h98Q| zmLjrUl$$n$2i~m9dDpu`7WiPxss^18KG(qB0UwN+?H4{MytQ??lv$J2Vx8+(;e|4` zR`_iT{IJ=2t3L?;YOb~c^A`FM^__SI^13JO*E-LL{U~+=eXbKbdS8Cf!!uG9-x7F6 z^grMk!Y71h1i-OI57+9vA~;9zo9J(yr-nvD8yc@z0k0SfudpJ=QoddG^i^~HJ$zy- zdIEgHBaa(!R#$-OC4T-p=rM=;9>rvW}Mzg@$Rj%ZPVM zQ22f`www}d@0^9|@lo55!P6$zBs+ZE^NF75__b2T*ycKZte>kASYrRP(+@MINz=nf z$40wB;z6X$0-lTU%YS6FFJ(n07yVmeq<(o^kAspjO-8*x(?5~#rM_8qJ-8KrXde9! zkA3;yjBR_AHok3a+cN358Ixniwi(|cNCc<)TqV|_KZEzgIyFuo^8(sfj$cs5))X`C-Gf^uh|+7_^ux~IA!FA!!9Jh7Mb@m_6ULBiGENOKG%cvcDMG| zE_3lcV=gqj8~vHAwaNFSfz?GEmVHC6Q)nX{TFJowl0!U0zCkC&;`4(}GeCwp^{azgLnbNvbBWIao|l*d*8?h@;&>3f{asWumS-}~z~ew%*g zg0*hUMFaiR=Gk0};PrRMdgnss;YOJUgJy>HGY`L^d=H+(=3yIs7udIb!#va)`8UZt z7;DCyhl|Dn9l5Y+30(!iz3?M9ezQcaUx{^`i`MKTvgYKTKfw`kG8(Ti*W44dw?kWV z+?5!XCv&IqA=cbV#v(8t(D0L3w~cZY#2rbDj<&`aUwHXtl-K6o_-2UEkJxkMU+PT` zt0!$NGRB<1n19J#uc}d2gKg0Ee4|V>Wdu%m-W>8|ZHv67%^PJrzzM&n+Qi{E(Q=AG z6U7D}-@^L?*g_wG|H~cQ(%$#N`YmT(_4I_geb~;0*9%>nWxZxuqyHK7vE;hEZ`?=v zZNF-Ir?h{o(Z0kRnfR9WCA}DYieE%)e>y%!qpWuBl|GyE94+mCJoUS^Z~4B~{zC@L zv$PZ5zN8oDTD_~y_8)bH%(6F|eKp44c9ixXn*NRLi``eFV*~%H;Qx77=p$(ES)=_= z!`heqMQBH2H6`xz!=qhEQm(iq!h09xdiEdV`=1Z|#uYN*WQ6stFPsM8m}^CNvCwVL zyD^qG8H?~ANw<-<_wjAdC2mo@n@8I;drL9rjt|iX;a$S-B$o3|bgs{f|MzL~nJ}D$ z)8u8O_oc}rW?5q#KbAT9AJU{AZv>rzt8ki(FxwBK$#?p+f0wlXKcvZ9OqfRdLVrS& zf9G7GHvTZ0e90_pjDOlcp~-&NBs3{&(xj!yCQPG!lLp^5+Yh5V?k>^SkJ0|+(*Cgg zZ(I}ow*R5t{%?&nG1P=fwo-Xd|2_CZStyDH5KjpDz)8OZM;GT3;mQ6n)5`RndoT zryo7KkC8r?c4ZDCfYoh{I&i*;*sFQT_-jV`&_`d9^5UBjT~usWqKi(aP6dAW4eall zEJ3`8d{6UMk>gfP^NXMU8RDqW!QexeQxa$MhTm?qu{rj@SzFJYWH>;}ZPg!c&>a5DDKV~V| z7cBU9TdW1x51!1jbrf_y_`Jp0HE%xO^R;3_nBiYCM6GYGj-(%jz>2_!bc26^C4%;* z`AbgNIh(G>tpz;O{UuN0vyG-+bslB(w&iL?*_?@fPW}TdM2mYd{-n;a{4B58J>kC2wad7ymYDa3Nwjl6x>z&;~S%C+*` zVm$A&R?I#mbs}8;w99g}voN;HEWT}&Ict<-Za_L_ayGDFU1M)eslm2lZOzX^e$F)Leq5YuRDeaH8HDuerR-CN| z-JKR&g=RNR`EqxbZG-AmzN{jC$K{WHhkN8AEPne3k(~#DyB8dPVDw31=w6cN%UtOx z6@0()G9^9jS8ktDQITc)6=yx^{~yQ?QfCkUHT6fpK0Go89W=J_ORQNF(}d}PBz8su(_iKA4N1ytF&E&YB1Cg3y-0S@|% zPLJHvY`_s1a*ulr^=iOJg%;oB@^8a8TA{@@x&893vLDgcAbnn8^k4kbxA1HOHxC$T zwirD|(M_DiLL)7max;u)ANBKj-bUJDBW(%Kd1hJg<1*8E&gNNY*JjY}e95D|+az71 z-Hrr6wm+hq~HeEKi8vzy4@OItJfhu1wVV?GOxh1XrjJy)4ObonMH5*G%~Gw~e- zj$H6QcY-olXv4N)=a3(mPDE(wz70_4lWoT=R zXOX+)+0NL+-Y(DSz!P2}&pyi76z)5RzEen(v8NehAIW<c4uA5 znW5H|#Ai4%4ZU(DIzxxs4UV=gD|nC~1b>fE#P4WD=Dv&2QYdDilY7yD}Q z&AxhMo=4I1MgDLSFE@XY9?^Gn*9z`g zS|Rro)nfnIafI(;fHOJs7p%7VnrA^TjBf$ByW%M4wL?+YEjMu7%zX@k<89#Rq=Dm2 z-x9~CT6=N4?X-zw{k*f__$c`=gJWVEk*{oZKcQd6oZS(h!Kb9>!-oX#a=zN6({0B6 zT_v2Kw`p;%y>vP{4BuObll)ikT}uqPhVOqur}(FJI_11y51kSN?@$v<8==cF2L2Wp zG@2$fy69#f-x}Gm!oZ)zlsXL>P3xi2q~}r$8vS(`{?huP(O;7Pd+?;6g})P?a0k3$ zK0M-fVtH=k&M93sO97vqQjU20X5#LN-Fiil*e&AogXP=@AZxLDZx%6JPfH9}bM?Ng z7l>bMsotOUw%or!JeNje)lJBr5ne5p>-S3N1!5T^;a$XVJ*_lc?cKn$F7HHmKR05e zu82o|7kex8=ac)AB3vudS6q5?j#n)kjZH`5p=58WfWOPWB=LN*AKk^+YSAHy<9j8& zd8oH0+ZgC+|pkL}5>p}xpQ#YTL-X%}w=9+WOe>D-&Hs;f7Zb0W6yhN56WPNOEFlHmKw+E;`XIItQxxK4{R^Ck-p?wGIPpxD5{n~(Q1_89T;#%p5_tcugd9`FqGH}4ss zjs3~KW3RULjJ=DqlIM-HlIGZ(8KcM+gUzuYls!@L{?!ATkQ;WU+|ZDHB;Fl*&mEW1%z2RZ zk;G{YYsfx2Be%X|R&M>5l>_UJk8_8PEh=!fy;$TEf2RpUz8Po22}Cz!3k)eEa0I5n zlKSEBOjymFFF0l$n9(stsednZP~Gu7OJ{L3XQR*!OK#=77&6n+D^y?WI9L5W$x3KJ zRdrVB70BGfDzfigsMMF_4(MERpHhDxvCrLm?Ef(Sv=jLQzS(ZK4)e%)vKnH`Wu0t$ z!L`nw(r`k~EG^(XfSh~pyd%>0F?Wz8%UKBKA&{qff3*eq1U@EnkxIGX#%Wqiy$b$i z@7fC=Il261-#PaB|Ahbk(%`?pfd9U=NS6_|_3+>1=V}f9J1wa1Uwo{|f)C5Q%lyl^ zd7%fn^ZFFB>b=x^k^B@nAG0UYJDT$_!8bX>S#9^8A`VN|MGCr2%fl7K=^~p6U9O7p zkG8t~-IG+}2x9$dcd8o#(2mS$a87}(Sg2og0p+aUsRkOjJ;)*>OZlSZ&l1wR@_Y)ZBHq_ z(t83vt?w_~8>jK?Z#a9C7uU01Q`4Xi=tu6blXFye(0(#>bW-HpMZ|%zmXrRSb-K(Q z`kI&w8B-(c)6Bch$U9=@5d+^I&)uQiB_?+%6oG0rM^?lm-OS5*_NEEkUo;1 zX!N7m$XkFcc=Qak#@`uY=84vrz9AuvD%K7$}q4nxWXX|3MzSE(Gx<{&^*>|XXYcAIx ze9;}M;tXi(O5&1OCo*@U|5PByw~T>5R##pI9~?_uVg>74a3(nUN9AR0nB}GJ(d+Z-zs$+2_cAxfna>+vi`sdFdFa?~ zsTaQuyh^_5rmb-k|KpW7ZSOh;ENM^r7T73z#4Y|~#QGoGo?Cx>mKvJ%+6_BTfk!uE zc3FO$_2ouO{mdazJCDC;sTY5M)awuaE$kt}69x8{%qu*}>$2?5ax?y!@U`QcbL(?O z@3ao`yDfjnIyOfM9eXjizPX$}MBU^+zFn!G#dumg!mo(2DsRZX`Wj{D@#hrHMjCvR z`J3Yk1%zg*rz2|+CrX=~m8);Xw%hs~HU{jVssAQp!tVQtTAy}}YiB!gTERnVz0i%y znA-lzT|?}9N1N38Ba5P(cE)DX&D-;#8~Rwuya?^ce6=xO?ciK!MdniW<3RO~vGGD* z22E-7gH4y%{!sfAMO(kkN72PtuW9UI|7ed9T}gOu342g?Ufe(2dt1lSmr3rB;J7UZ zI#`cP0X~jY7di#sGB;b{$NkNZ@b~b!d5LmC(gMH|Tn4YV*7JQ>Z}&3R&`N%*_^szR zCeCT%=SSd2WC>X(Dcr|$9WZJ++paWR>8+U0-D&cia+UW#cn$5*+ME0IX%ywncqq-+z&I}Oi4b3r zsP*gOc&LF|TihQc@;UX)HcWrY0P<^*lkPUgyMuE7MxV_&_-FAF4af%Jac>LIl?2Z} z1^?kOJZ9|A+oX#x+{FK|K4We9?Ayiu{5R#o@r^Brn2*G|C+Pn`>Hq%+u|L26?84X| zVmo?bfAp9cV(|={p6I17Q@+30A0K@e9NkV|d-ADg#%OIZ@^2>JoCooV+0bW~5QBJ8 z{15Ry70|uRgG=Vah%0*lJ9;8KMDVg!Y`grc(6X!xXu;SbHR_vqx?6istQ*Ey``Sf|jJ$aAy7yQQw2raedw!*z zGuhGDK4Q@6`R4V!IP9YXH62!HTd7dIk78dc;l4%jF>K?GFH?6Hn?q{exsAW=T5<4U z?i7%3rk>+Bim~k-s1E%41@%C^W%!!br7ONxo=U%3vk5k;>*PDM+rZ;COT(vvLmPK% zr^V-cZ0hhew)3N&tK^R1JBfqc#y2`_>d-Y6T~XI1GX8S(4w;V>U&=s%Wmg+MbzoaK z#~n85z(|iT@T37lv*UgdwJhbSl&h6(6KMB}OVcdMl=)*6?__JT=daM2v^#^jko#Xw z&YH=%zmM&Eb8=_Vjo@MiI4Q&yRN!kJlYcL`(tLGCqL71^9?7(+ol^o9*Lh`|-VYo7 zkTJxb&pQ}gdQYavJ9coe`n>(QHL1!0&o!=4p^Qy+t>fNiWDS?U%@XZt$9EU-DEiyJl=ZjJz;liOyQ0O z5u4yzd`30M-HW&%qk{F*jr=ci_iFB|*n@u1S6{6pP2$Gq+>QK=J}K~ zAmfSdq}>_9+52YB-Y*jsS;x2;q`dtKF+(lsCL!j;Jw~Ak)|9r74H|I2D z%Q`ckMb>*4Iq1mP8NR@zhV1rISE%h_^h(b4H&?sPA5U`EA44}jiVx*z-c;vtd?@0h zIoglRSBd<6wG!KO1ek#s$MK8uDvlZDu?3KUb|B2$OIoA}$IUeR$bYye@%}(i|58Q9if{xr`9pL}VJn=V2 z9Ozo4ggT4jSTFF1S@FK%(8z7vMJ@NI3csjCoeGBOx=%qyEy93PmGti5J?<)8#2^zgvu^FVJp9aJ18;wFQ8Z7-@ zzvX0W`T#9@Xhbz+ltV5gf4?!?R79W(sm1N zzXQDX>u*VK32Rf@5*gksbB29G%89NcdEw=yFURTM(L3l9eUW}0r(Z&AqT`8-DY}K| z8Db;3*AmktcMcX`YMXhCyO@sdQ94BzG3ln0x$Ij<;G6*urPK=^;_e}Mok=$$W1BRy zSLFNz@W&aAKooonxtn`Y>NQ%z-i>ZhAAH@tvxPYkI%>ne+-$8uXIq`sj$U!(F!qsM zO8q`${i#Az{qUV6jqh;(2Ykn*s~Vv(@moMMr^Z+ey5bvOw?RMHiiJ-!iVX`MFJ%&h zu2vc8(3Q!Ds-c&@e8`HwS@_W2aJs@?A+Sz81Rnwynw(9!0Q{#Jx)FU;^W!pK&F~?K z2MNH7THsUIHF@5{oj0ogoA`~!k1Pr_)IUEm>F6nN)NFk_>*#v?ufRU?qTAQ*;5#hn zxYCa{==pfLtNs}4`lv^#-y(YO6xVtAW|~<~;sd0f)Hmx1jPSZY{shbvl#eT5QCoIb@EMkXJA#XKZWz+!q4R1Dd_S8gO_RN=WEgb z1J*w=4;Jqh?r#tptgTuFu3Y{gJWa-5i*2B}+U?(h4qA&H;e}hpp51$QvG|N--|JYf zY%pc0Zk}u4N1~ImKcRyX10wqH$Kq}#n;=Y3Kf_YdVocu(iS z^YFiYHHYsuL`C=lq&4s1JKhq%wnxsUsoqQFc~ybGWnM$}whyOv`aUe|Y{?NlnzNs) z^8I^1jP4XWZD19=x%x(b^Rk9)XtPXvX88Ag7}439bOU8LbA^2_hx`=TL)qW< z11~U7%1!gvQEoqN1Xgi&%EP(&u??InjR9^Ra4WLwXsd0~&A#?2^N5p*^&iW*%_sUk z-#lq=8$a7up??1?Hden&oq4ux(i~s0I_qrvl-qqSb;jAYt?;me;EOUZ-JjR#zrUbU z(&fDoUus*728VDRs;HB6ofJ9(TRGi~S$Dt}KW=mcze%n-p7isUmji_0ycK z2{$<9y%PT3@-i~nA^je4mG|bqx>)vVXd{-UVE*z*Iql&w8c+s0rw_J?g@YG zJ8GORi5Z`Zc)oRK^Qszr)!Gl#-k%%KciaiE+2`4O5I%PEb&6M{KPCTw{7%4e+u-iy<>6I9M zk-e?m@KatoWymL@{Rj{DDyYn(ywl#*!LHJAxMvlf(HSWJNr4dS3vp7qcQ!seXK?o< z^{IDOI{CJEf71}&#gw~2@7!{nomIJMyko9yK6pu7$bWGll;A=BdB|s%4V|;eRYsl< z$;LF#xOWSg6Y-DbWRH8($t6eqKVm!Ty(=q4zxq+Yf=skJYtPiy+YVlGVJQAgd_bKg zFV~FGd0+Z9_$-4i{+u&S4ywqr7JG@smsavFz4**v4ShGy_J%a)I$e&;i0Z4oeq#H0 zJFcxA_`mHFIZ%6epUCdo_I)B>P%qj>&xg+Pi42AYuAGuRs=bzvD64g_T)4J#Ml9AR z@;>Fi$tUu*f$LD8$a>RPV)!olYR@N9&G%@Z$d4)4G`V#Q{k}CV{Obk(ci}jt|X$etam6HM3|^py^?LmS^I=!mlPY&gYj; z8GX~c3gai#U3E4*S`!M1wVub%T`R@&im&cW-&F^jhZhday=xvn^PTmvh&u-emQ}s8ow4a`f@eSxXz+XT4 z?}zeBW$jN#7Z~TP{ZpgX{(RPc{{rG2`3c@y)_N~?LIyu`hX~Iu{WX5+&|fl9>+{=; zZH31gF$dpDAwQLuK2U&<1z$|l>wMQfqhOT%FWf{wY^fG{GOx@#f1m$9XZ-(Ha>hsV zS0(%s&0pdz@tF8)6#Rq!I6QVvxO^1NcWTGwyG-h(i7&~UUdT^;S;;&u;JjlozjX0! zJMET|54(V0q47nhW)+Y-a1Qyei}+3D-b3YN)H-my+CSJlLTgy&*EW3;)2+B}!LM=DJC`P2@~rCa4kHH{GnYo`;G{ca z=7K{$W2JE@;wLz38H;)7+0wO(;2-f`A@rNaPwQ4KFo!Iq$+Iwl|7VbE!F?{||Eb)GnNDnm&J|_IU&tMPL&cO2vq9#3 zkn{w6cFOUP&hLW*PM_qwE+MY`Nf)Lf<~7gr+~-+*Cr(J`YYdF%^PT4s_nG~`67c6N zri}ypgdU!^k*D93Pv<)^N3-1WKjk~mGu`KGz7wx>v-=$6JI_V#^Id!=@9y>Pa}M8m zW-r)==Vrc>L;O1T`7yrpe3kqB6yKr4_g#28qi5keH)m!v2FS4z=<+?cJo(E#JWp_+ z$MPNj=lSk4X9hex=eWUEpLw0hPx3@< zx%1StF@ZZX@Y80vZCpoQa-L6epZoG1|8AQ5d;;Hj);_qY|4Y6joBO!WBka89KX++x zJ>QYlimx)|Lwx7?7594q-=$-^-)HijXX%5c{KI@lR%Ngz5R;uPc_DpqyW^v>JoAl= zHD%|4Kk_o$ZF?2;;n@#=XTs;gU%ajQu3qWN?H0cabc^-76ghqut*i3A$X=H`j`hD> z%^rx}|A+pU747(6R>b;We)avM_rLtu*J^9YR{FO6FYtM}#?iGeanhB`7vkE3PyN%j z|6g!yIjv8w-$ZNFWB+X5|MCd+qWu9&sW1P_YtTUQU2@%R=RV4+&*8%LhPLtYiQf-| zl8D9C`bkdy-&eqAy;*m)zm$S}Z%XCdfv@+*&a{oJ5BA~zX5!ablP8<;E}Au3_hF{v z6Xc9iQ{SQyqn8b|HqT(pS)b;!PL%a!4_Rd`PoJ`4FMc}KOYNU1FDJn4od1c)QQL zaRPU2XVN}*OtH@$U*^d-(l zdmkA-;$pbl139ue+tYWx;#49%#&7f&j9P3}dN%(ATt_gM|8}r>mFoBLb>AG_#$D*| z#Qvq2GdSIgx0G`JW*&K1(wW~DYZ^IOHo9kNG?wQ6E#$;`(8hi5zBBVb>MqX2zXpgi zvcivn#}uo0%k7*AO0mBDN^7ok+;<0hf)&WTst0C=u>G>pe^%~UuyLG~($K&izSResS60pWVWaA$@@+e~lo~n7esXs|XA|tRi>|(|^L4tP zFv-C0+ z=c?}GNM&Ct9UiKQyLfrsja6f}B~DyUya0KYi^u-E|3$=C`Iko)TTR;%yDa~A|G4Ga z)1Sr}KHWVqy_dE8`hK3}6S|ccYt|HSm1Y|bbTFNDtvy;jq4 zz&s9q{GRHdk4pa^_Y{6t)u}|cHRp;i2<^V+LiQs&2mh`!6PHcqyy2Hyq@T)0(|h~A z%--QG`p*3>E#Ikcf7h9f)bKWPG4&$WKe~;Q-lF??ru{`4k0Fyowd~Def9%LP-K`%V zenoBbEy47i&`@%=`%P`fhjSHE=4TddMa1dd1AVr`S4GcQp&9VjcE)f9dgLt84SMYP5I)*w(_?%LJ!GRr(<2Z=j{^8J znjWKL@#^n>Pr{c-o)K`nQ~VIct2xMA7Z)pr&k8c#`tjj(wH?K0)u*}NY(872n4u^> zt99u81L*ZK>xRz67H%Q`D>SHw2D-a!I5bF`ZUyH}vdS%!ZzPaiO1YYA$Tvc+k-*OR zV>}jlHK*n?avHHoir&yN*s zTGc-aB%#Iq`aNP2##SyYI=#{(5#!_O7`(*)=|7 zN#caBYdDXX#@tW+9dcp`ewRm?2b^)59p{}{@-#l2MDhXfcjVL7h)5Uf2dUW6>z*Rc zPUnZK(}VNz=M258@Xm?xUCRRaa|DZLdEnwg?uWJtJ-4J6dT%LC^-M~CB5hK|iM~n2 zCw89X<$vqUHDf&k3MP36Oq(<);JM|zfcKX4(Y{H!qdQGXe`)5VTz(nEeS$W94o8RDM{K;}t=cWZ+xS{|mo|)?)!-o>)|?iv z-42i4h8&1~H=TEq`ENhzEB`Uy0-RmX;rx3%aa6gSflojth?jK^E5JE;ox{o@#!+|W z1UUDu^H&A%cs?;!@<+M#6P)^8kD~q*>QC(f{pLY$(U-r?+^t$&3cUw1KKvEEbMzNF zd-%&uAQ$_`c#cce+ROTr%6eIa%w^1HdLCrHJG_+ve|!3_8Jq97ZplgWOsa!#w!t5P zPN}!#@-A&a#U$$?#);>ghXziX=C>3}eoH#P@$g(czj|LLcQ9KsvkVVsB`8jbu}aWA zdzEut{<8Tkz2({Fx5_#0cZc6t!#sL-E3(7ac1-da6E-HzIBES9Ej5PmK5~4{$Z9N@ zk=a;-A9)&Mrm@R6f0M#L+q{s|^4!V` zl{2xeZY#d@x_01{9Es*z@vLM*tlT{bxtnL?ZYSifZ<6?XI(+QP-%R+{@bcK6!wUId zawc-KH9|79jd2YqK`Xc5xc%Swi<6ScT*zvBs z;P7}aJHIX7>F2k_yYf8uxfO2@@2b!jzto+b-=Usd9XNKpYtKDA-jT6w@h%wa;_1xq zG469K-Z{K0X1t$|!h3u_V)Val`yl(+@s`ivu=c^ows=>LaPf5Jcgu4t-X+7)tHJxW z?-=i#Gmjnb0{jAp!@Kabws_a#Be3lx8*ljx?B`azt4~3m!{;NvW4ueS-H+8CtQ>N9 zyq67bi+B297f&1S%9GvaR=nBMnjE+aA2+(LJHNjRKCezccD!p-507``#I|@BaEEgA zc$++h#!ha^U4U&XJUY@-3wyN1TmH#tybD^MTk)>$jywl%-FyCB^0{J2jur1p|Kago z7S|TAzoiclN+VxdNd5)e?nJ9l_C4H#eX%*zb$zk2 z^YH%SYZBkf%k9Qnjtp1lD zOTJRGzYF~%v^$=*M1wf^H`=!)KZ@x0oI}5+2Wzoq?J=lk(d?>^vNLd$bf`2CpYzw)e{ ze{P$bcy?hv96w}qzz^DI(f;17eft(_+@EJmzJ_LBU#RoG1N22l! zM7HVNu9IJY{|`)HZoHRg&h-|sw_|@#3ZF2M_Yd0dJ-m0%^?I4R-*oOi5gh9{8(K^L zDD8i`|F@j;fA&1i$o^$a183E?bGEdW+zhpsaL)gCoUgr%^R+rly;Ntft(QzrKk~bq zoPJ%&ZSrN-v4^tt&P$xSdw^2|QRx@UTq;O;zcaG}QK!)sf|#VPX#y?@YtuW?bX z4CQ@z2048sRgt%=p_y^%O1`eH-Iv#<3%es6i?!{bAd#W^p3`fRVzdd?$1<9%pM!?WyN zyYdJJz0Y;T}(RvrqXO?L4E= zxi)Kj?13t8qsc$V*+%3({`EF_4NBnW$n;LZK9{oxIK|$_wutMGhOhqgyt}qT=g26X zi|(?#;?lQ)oty)}^$ajqYrm7>H#iz}W zaGsmJ_GZSRnQ@5R<9YcHYmRGdW(+Ek4?5dz&eWIXk$YbED+J8_3U!>-)>-cm1rmw{C`}Eb`8PqhsS48FIdW&*b0<${?ZcLBXz(eACLhK>IFW+WfuCKQo zS=`@Ol#8af9aEDOej4~Q1pjvs_xH}0ql^1nPx+R(KE~dS>st%#(gSV<)|T(Ys=41^ zalYTkcXu5A)0n@b$;-7ExZRk)*t}fj4s5ZpNk2EZesj#%Z6o)_9eIS1;kUwhQ-Wq+rYSL09byKlXzk{bA)TG5Mp3 zf75xb#%;df-aJq6_zU5i_bzGG3we(|A3RgR zER!GHwIyys|GH7S7B)l?{qDNtYR2X&#^_4y>?t9}%;e6f8D#613B=@YAH;a!BO+$N zdV7rq;sP?i8%ov*QjMXx7fNNZ0$LbBnNU_?n?^Sj; zxZK2dbH@UClD1z0ZC?ny+~CX0evvvh|0IWBy$s%%-RdLJd7IsHWebXTY#+%=m3i=z zP;cXh>D^F58Mpp#<%ih{Z;>Zn=P)ln-YeMC7?#7iCa0qnE5W2o@zj?17sZ;~yz z^E@|>H#vMCeM*+Q{(u|kSMh?~qRPDfsN_Xr_})GH7IxwNA$H{4_{}wOtVv77W3~>y z3;)bso}2fRqYWF|#DRi`Vo=?3jZxpK#iK(m42_`g8geSmBYvfh9MX{=>ui%RSbw^Q z9Ch3uXL4|n^NBpvCYK#~q$AH+O@8u3`B$A3j12WO$v0Q$^DmbV;Lx@@J8gAuZR=LG zMJ^<@)!?*seRNyhme=OR2N#{EJjH(|2k~FHbB^3??_C$F$4*u5Mw4$^xw^^aw`b`O zL$W($UwObwYwPxJusxc|U*E3%h`iWF-p3h?{dDAqu|<5j#umAKpeJPKz zHdIc2GL;bzbyQ9{jtZUpMng{Op7dFI_oT#u-IF-$9Fi}=tm}z7ALI)yMj@k-?KV0U(@ICq}!AGMxQ9uq< z!S^aKfLoK!7Wg;Wy6#K7bMx(p9{vdzHYH6Cgj{-b10GwpC5LmEJEBFU$vtJ~jdf%6 zjZIq>AFPI6Y21qyOPlL~OYJ;Ke}jQ7`pmHU-9x+nlJi^W@cGVt3;%jWAXLq{3CWd# z^sO?*=#(o>|H_}3#F|U||Jyb$@=?3zBHVM#E?kQpxT>LvU`uD6sB&oW7gIkeJPX*| zv0FwT$}MI3rjI{Srj^c#;WHh43aRr|F1fob@()ty)1CXwxiSBJfkw6A=RJ2i?I^(~ zCjL{oZIq!bsd)oUykDtv_`+l9+xD5W*!NF4?`1n_Jk^E^OAp}42M_mIId~F!a*myM zD(k)%FLp98Cx*`f=Dz^5Yr~i}Iius2-Pgk^FMv*x-Q&m^Py_7Mz^Q&@UkFy6LAnFD z%sCC`oV;5{^i{nI>Ipy9Q=J`Z3#E`z3^SxqixOw;h9GN>dWPubk0e7<84`Tx`XeB%psMPe_wft^}pM$#^q_J z&j9ec?|;cV?GaqVIB6_ZNBrb|SG@%e><(=V{AIk;JX=Gb7q>sgrX1(Bk7$e!zIAkC z{MB2w59Jy97oTRp>*8DH_zJ^k+yxkY|I@!IA7JcR`!@OGv$!KEu-s3XLa!An#O|{? zS_SuW1@RT$5FH}D|I~OgR zll_td;yaxf37}#t2uY$ zjA`1*!TXqx_f-uKKEU7C0waRHd@J~Gd;{Wp`Rb1A)xF%!R}v3=`@Z5IU)vmrHoppYe>m$a)=ux2qh5rM z-+e8YHK}*_eBOz#E%ZDOFo~~sUSpx(2eMCxuPd0(@`EVHEqYwjqu_FD?#Lkd63t%U zEXGUg%P`szeP->zMh8auMs(KsQLo43O_bi@>KqpRc<66+fLtTaIx9WpF8syf!AqDM zj(pja9_R+WlEV)iXSMNlRBS)y}1ju}(XJYm|X6DZHFDc@*zmeZiI8 z(u)h27qjd$bV;gn!>KyYY=u`E9FxNPz-<-$mCX1Erae5ndc{U~NAFIcAI(#(m-)^- zy&b$%&a5-edB6x|)wXz{Cv~Lz>$z1nCWR+BIO~0En+2xLXx;_c z5f`d~S8DT^M{9Lgjz8SojJ`>(>JgOR^>!e%yMLhRuZ-=eQ>+C$$w3_XoE$~ySZO?4 z`Ee#k>a*al_mVmJtZ5mH>sIbYvby^x{S_Uy3cuDa@=5NQasm5l=QF;x&;CQN)wHUO zoKFt-1{dwB~ zfBHhtrSNg{T;|;+okLnL-uQxfM*V~A&GX*K-pEqfV^;Wa&R<5@4;c?UksH#l3y{E8SsBTz6>V_(L5V zaeO+k*Eagz3$H*o+Di?uMvofV$y%j& z4c*c67s&@; zFwFc=Kk*q>Xde8RSv@MaI;Oonz=B-M{sVvQ@kue`a|3O$kC{CgSTqK%J-6$U@zDH2 zXpd~X0Xe`v{3#0w(K&Q-X7WV|vvvd+iU5=KfPFn8QBsUl~`) ztv2OkuI&E^A6?_4n7TpFhkKA=OjsLaI&N8%44i7MEtKF{7 zqCWXKYZ!Kot>3O$*7M7KDfbSw*J|;TnIrOP7~LT$d`CB1cWC>b+!(wUe9M6EEa=4D z4Vw=lj~b_TV(dCIU%G_$LKDps?diC3fccYk2E5(KIx72eR}bbocP2ou$u;1!=4XLN zHGh8rob0QdnTDU#;o~OpN)mB$yDot*ko|k`0XI%P4;|fJCk(%0AGoq)591^`^2SE? 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

^HzCnta;11smHCnHp0^jp2E?I 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�&T)}rOeZE$#+X4KV0ZS( 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ℜmuZWBjBy{0 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

2XD-dk_tE_N8SKsX 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%0D|M}$-UF|-EM>^}79`-8-pvME? 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

ZDU$%tn2skCjc!N3N;JO6Z z+W1z_I~Y%B?Wu4uxc?e2s{e}js{aPwmVS`FWt~Sq9_pk+K8K4jG1=op_#XZ{aM4EJ z6LHaUMqG@E{o`qHQFR7fw9@BwgK)8uZ}mJ87Y;rK?}uq|-XC!^^zxzxUCXr80{dB%e}H_?p~u_h)< z*9KZUV_e7HxZhNMW<{}A*=oPhV`?7aEZ!ix!mw9xg!`Sc+3e-0`w;s%zRS1rTQo*! zB5vykrs==~+`a7AVULY(`OHLB??Jwmjcm#vm@|Eua&?Qw+J2jp3qp)DgE1g=1UzQD zY^E)fN87#}8Xo@g@-ph4MBUg?*|{h3ofx^3hvM`__D8beDPXNL^{B7ff7soR@6&V9 ziNxW=dt-grM)rT$t=JDdsJ)3~1CP^gFMP>90_{843xcCG*U3(bZmp$(=q~VFT&(8V&&C4dABoY+|Cov57uJj;>sn zoOWqVIb*LIJjweq@uQcoOlero_vLBxfit^%`PvQj>g)5w8Y+n)Mv2eAPMyND^u);( z&HXx3^pKyjXn4;IM^8AhXG8v@=IOHF1$>brLr&92n=Jc0YdbE0{`omN6dv5R0o@Vu zSldD#4?i!zB!0>KQnvLyYI^^JSW1NPc$j*QBX@yR%wJm$&d= zKGNE@iChx;h^r{*ihY~BzrjDasCkJHd~#fz zS=!Ng_Suhq)}R-MtYuMTOwR?Ebb_PvUbS&nT;N$2U|m)51)gOVdNnf1&d+YY4O}x0 zEPBFI5^X%2Tw9OXSNUV_kws13-|3tA;q~}Pncd6RZLD9xx6*;dKF>16AtN6AgRjE)4YS&F&t0dLi2 zTy6CgWiyGjjV!p&i8VeE476z9j;5d!6HqSH6U2?=H<~HT2lY@V?FVQ}_z|r0fY0z; zdlLPUwhtVzY9nICM{L$(%za`@Sz< z_fUN%I*PSb-HJEPU%$RyvBXzBnfqRe8yZP+*b1Li9*pcu&yFrw|E18wWv{alN^9M zAGq@)4<-<3(feZKyV?3Pa69!bQ=G=BH_xtDz9c%NSIbrf0Vtk{$Es{_Jb9HbxmiRUZ2xPyFShi@4cG$Pvi!Auj2n)So?4CkC@@tts&i0_Yz1HIFECYzz3_V-KlSBs~3?6u>? z=XvZiw2K#5cCL~mQ+u}Ns4RFt3STTHzuU(;@iKUdaWZ@Oj;}>FyQ{DjAhuwQo7xdZ)~8t<$0L9kr z=Tqh_%Dlz*eSD97W9&VBe8}OWgX=$kp#I;->lZ)lvUw)Eb|Y;FM&a-$w4?q%1#k6z zHsZ+r(B^fn^ZG^{VeWpx+Cg51mc&!g?_&|yD6(V-EU_1}Kh=tktfP1ok^3){FB4i-VTRs3!R z)_)q@S7*Fx+s=Cj_4R8BeZ7vdmnD={--6or{ep1m9Xz+<^tIwPvY4_Fn~zxc03S8b zkDb6TdI;W6%OzhvUR_K&V}eC<~F>^5j4Ut2azw3B~&3FSh-TL%3?d@~)|i3T0`W};yk z_-+Efesk7^W#C*gDHsRxP6zz-f1xgLVEgGGetSSCXl$Xqic2PiOV2q?zq@&+a|)x!O>$0ODxn4O{gzje|5uQ|2+xsiTmB<9 z-EwTYolhCjO0;{6?(+-PU3JYafS` zE4JD?SFkDuCw(SArwd!$k)0N0J@XFiOzBQz=+A8VH1XWC*KME16v#Jr;&{F2;d#IU zT?<*|T4ehb^55hymwVWQCpp@HFMDEklJ-HsNAlR?n=bs}%J0(`{O2?I&h^&@qE+}u zAA_SH`xShQ{5FA~CjQ?-Uj@bojw`;7uG-!tJ{Xxcy$M{h_ew0tv&-mL)ey6N7dFd~EsXRjl2VpIt&cs}uj)IVW^XYz5DOx4Q~kB)q)p>3OOH zzeM|RZDf3lL9HqF=5&`aPU*Nj&^r#i3;)bb^$ORYe%qm~O9#5KiB{0@Vck@Ke^(O1b>5l9O03!dsCtZisAkBY0*O)P0OJi z=6R`C{%+_juD`^1nEXLw81LoqPnnL{d>=nUTyi8|SG+EoWhJo>HRs%m#`0A{*wxSk z=9%$*!tkZ)GXci%6Vj&Z``!Z{JAWt}+>P;>+F!uqW64dJz~15~zL{>z%OdZDeGAQ4 z{NZuzWByQmm1jatpU2a^3mww4ZWaD<4*qe@zO+@xHazUjsd+LT|JXaeJA!=t5+0ky zvupVs!)KO%e0(haHU4lJW0Nl6)V>MYpL91d?5X@ZfpHvjoqph~$}uy#=zke7D9@=F zIM}JAcLs2L1D!5Eu8(?;F}B~I!CuP1rn6Y3n+{eT+aQ^Z5YNHy-B--`d^YyB(YD*{ zS&Kiw9wjvk@!Nd(@_v)OuMyZIz|5W{z?@B-A-mg9X8U&o(O*)}lav)KfRV zm|RZLi5PK>;T!gNBWGY-cPsf9 z+50ww(@oT`objE5_q@{bn%xo^jhb&qY)J+bl~_1vpIx36ly4Vd@v+_m3{eLcCt!L4u*Lar0v?WBx& zaW8n7f|04*LF4)rT(7SnVA8tvnmaZ09$a zHyVnsGM|6)N40L-8P5#F-<=p=a%>#>;y|hs3slTmdL=+C$mbo12Oh(Y2G9-qR{LQ4 zCI@<%OKZR7TllZ+eZ2RZw!iYYJtph$);3n#y76(vNqTrE-6(#OUX+gf^|ze!gk=NN zFJ!~kldcVM_Yu&(C-Scq|KE2H&7A#ex2vKE&-+e;;*r1mhUH zk2`sfU)XQ2?xBC3lnW2SOUdeiGC$*;jT6QW!pR+!kxfXPBha{Q*U+9B@=L=W^i;Y- zC#|0u%R9$MvSRY1f3X+bgn5Rn&h0QGr|Z1Bg3N1YC&2^Cjk^qb*?nT}t`&drJ-!d~{|^6&br0r;yjJU{W%L1BjQ)_erX=DQ z*xM=xV851k*#3T+sEiNTk*V(7RK^f=TxU{{3_la~GK^<>UZpdlMwN(t1 zyEtA>V|UTlqTCCVOPnK@ei9w?*$+qf&^(avq1f(!2`Auil|6r~JxT0y+52($F>5bW zM)N-=j>jLx@yD1U?h`xn0WRK%d5qTF#v9iR?PtH8Ni;1yLRps_kQ6t z<@{>~%AMr>V1C(6**{SBSEngkb^k!wKl5IAcJZ}?a?1H=ov8C!#@jgt?zPT|a_093 z;xob}azSpkbMB+gbeG=xD{-D%D-4ZI~u>0@(=&DE9PXV zBeBlG^{L!te6Md+cJ`pM%I}mvrSBw5YEwCqVdfs6V%@#sqtf;Ib<#({Om19DF*&2f zGx_<^ zIk?drE^*8Ce%e_K{D!@Jg|p<<*BdHrj&t61xC0et^! z{7})#mdB2~+5qkNO`zo{@BTu0ca3%%-xu(#g!j@Z;#CWq`X0}KZM5bW68j(?m%SE@ zHv!u!XxapAR|B8gb8w^c2HDeqK5Pa*5r-CW{o(Xew$H{H@e7w0!darNvUvx5!)H#u z4n8rww#!f% zJa(PMS)OH$tTS-Gy{7V5w({5_`iA{y1I!;P52%VY3-Fv|x%5-|L=Mb)>969g>?ta^ z9`~V=eB_L#p=r}Up2*pNobOwQ-3D(e2`lz}}xwi1(VO)=Zy#nLkB3(>CS z&@T4io8(zxw*}7@U{PJcA&l{`E6iO#uDbj_U+v}8r+hW>>vH(@D)>)p%*DfXHt#xX zZ`;Tfsp8#;Q+U_c&%2kxlL4D|5R^b)%;&WJhb_q| zLY zPSImW@;%}9e@fa|UxePruidcq4{^H)&xlWk!Xv_&_Lx_>66RDdA;(g<(7hvfdu-k3 z@Pog$Zk4HJUg7Z_&_ZjtcVFY`t1+>%v~Xz;_xC^(#qthPM}T&;c2RiiBqt;YZGJAA zaBYZF=ONF2z=bjwDnCqVjS4YS%I#VvAqc49I z?czH-ACWmJ8*jn<_&H@`(zIUY;M$RorxOZs5+ZLjOkMGPhu}9r}-r-Eo&4tBFR4uQ24;$5=>f zH1}yeR#S=*f7&)nyz0i+L!4u~o_w#1SZknm{fZCJZk(S_^^t9RHjt0x+D^9*asRS# zY`iaH6Z-Ox)VYVgMA)NtrzdG?b!*r@=VTaT)xGqin)6fgp<^}nWG^{;Npzr+wWY1H z9oV{OmMoe%n{`GzrL2iT#s5g^o(_N#p)LeR240 zz(1CKPJ<-C=TSWY5o& zeFe6!urGsbx?vvfF|F@KRy&9%%l4M>&1_->HyT5{UT4T=aJKQl*?F?z;K#A&Y1ngY zp6t0{pPd1Ib99SrcpG!!5nzl^=L_r)GbR1&)4AV<55LU^ELT$Og%W@e}jXd-)0NJPW4uJY`G<`ADAbZv30sw6WKCYD$K1jtMbJ#hNzd zn5duY#x&Ebd=B{&yZNuQ*fW{=?^dquI+533+3$%F#eHxe|D2Ceq`4N^imnmfXxEoa zUDt@&QPEIzR@o5yHwvcJ^hG#oR-MVUoG zF#g*g=HIRt9pw6x)_Kl(ZQ>t%?ILT6;{#O_KbF1@Qy)IV+U4joPo{KKW^8kwd=tn1 z=kqMWy=V-&) zzV$}m2F7Yd(}-ua0Z$k{kWHFl-~;%gmHNxrYg)eUC|jqQ?RqA?wg_EgkZr?xqSsZB z`vrfvc5yAShqb}L#99-`ubuJ@$L6)g;|PD@UjFI3@iJBH zK{L3_c)ls|of>oNW+LEuBA-=&c>Cf+d;rD$T zZi(j`N{7r$;F~H>j?Fi#fg?a1!Q~s-e}`{o*1WXB;hO=T$?msF8uPm`gXOfp9KH#i zfo~?kH)Utwo2AhGbbRt-p366K`Q&=&&EC7Cm4o5p2jB4}gTLjD|K0n6c#0DX2*~${ zDKkCOe^1|pFZRRQkPDt#@q@g`pa;1v8ybkBq@qESePIzg&X#fHCWPF0h&$vF zcW}pzdMAE50bDbIS-dM=56XYeKo@W?zQ37wCGfC``{h-Pb1$GzD*HjaPx6Oc{p6gZ z>%=c2=%=_1IAwnT`Cjz9)g|3v<4##&GtS1wH-<^@pfmez)4td7o|@EBBZ^KR{rPkC`3$kS%W2_!|3c@o(e#yfAo=zu#=xIZNkj z{QJJOjPd`1N?;4*1dms7t@>_3M@i=vuVw5l7$VlPM*a=DKkVX^vz63G!(4HQah4x^ zl`+oM`ZU$C@%sinj-N@+X_%bTaBld^uTrPmR+zS29&lkZ@Q?%Vy#4*purC4PpXJzp z(IP}nS%_Re*-gW{4)*8LbGv=LOLN-S9E;~X=UQ{B%F*+@?5-)xie0|nzAn_*zKtA2 zm9GM3&9SJyt`VN-ZO~nP>>3e_?p1r(Mva+mc`*h3@{>rvgzR_sptj&Hi`McNfz@mm;6$rp5ZQMQy=)ds`b?@Z!lVRW)FV=fGXbA7LM zTJrB)pZ&YSCC@b%b1KfA_?DA5?+zw0k49?<8>T*?9lVq%&2N@EzKWwTGC2is>Ama&dS@sMwiH~4DkPjK%i zF5cw9SLVA1`QM*zT3+T~eiHNE^Ny{&YrSy!KKu9H!#udwxi#|t1itF^EAPSubN0=c zxMWe!YU6F*y(GWq0Df+e{DErYU9-?6+xzOsPi{*O*zvMG=pMgG%4nmlw?;dBps|kp zB-d^x+V_j%ebgM-H@Lo)^K`4xd&nVk03Oa*hUWBlGX3%q-`ExJ&qMqR{w(G-9Bc*D&2hc$$WQx1>fOe8l>MZZ{gD6QNOSc& z@FlXg3$j>noBQ4ja=PE~>8I zVp5x*VgHvs;p=)#QMf+2ihq;T{DN87vzYI$=lf^F3wyQ{-CbWznLXMghU+AYXJ%+~ zs3NIhamAj7YU+Y_n_Ep@kFKk!*HkU+xxT_QgeqDaRQDF@eI}e|xAT@6((PxDlVDoL zQa`X7#{b#_XAp!{Dydc1l!)CduTVg zxgeQ&D6SXcw*;V1K^l1sjF}fvZ#nh)`8HUzs=nM<%@c>1-T>FKU+;QTY&>cVm5A@J z;wuT?=kqUoAO0KoK1d&g@5B7AkK<+w?Fq++z;P&!Q{b%^F7t@h90b=c9+ORS&6c{m z>z@ISdFZl3;C=~ZLi97qVlT0}YRd7BJ(^5ixL$ZH)0i-h#}05KJi2X*Cc>R)E!=g0 z58=+Gt?(v%*|=5A1v$tEUu6{@aJ9?El^-01idLV3qr>1xym&tTqHr^ef8pjJxVaoY zdvoKP#=qN8Mid%)n=xjESnBA^OQ!DdD*l6+cAipO5}o@$VarCo0+>LcZh! zxHd3IKBTKJ-0_O^zhW+NpCER4jH%n{$?PukjM;b5+V%AoF==>fX(PCJ^s~_Z=*qyl zdC0HyZAWF`XNUOph39t%fZ_V|XX_uSNNw0$F{Gi)lR{3H=~iC&8p`>@FR$1BaLlJI zDEFk+l$(@&NyPQaO=^wk-bMKUw*P9N#bZjH%K0m7M)*sJDtdti_(BeNBANo?)d${I3tUt=D-D(mU))9gnd&epPr< zYyI;4w)#wy8QZ~s9Y4jj(L3veKUZFWW7+wPDJsPi{FmGM$rE#BX6Yau<;sinR2W`7 zIAdeIWXF{m=@RKJ$&Nuc-3>qM8(Y^PKYD)%zA@;dQ{Kh(PzOAej2;r7cTjGy4ziG) za%4wi2kD_8zjNTHIsDYdA-k;s{Zk2V`QrL#4*Ye>H*qcdqo1^!gTkhpt37+TRJE_IKb<-|Yc^_BY_r{l=*$uV*vwp8bLzDF>xGLgW(Ybmy%}GoM!1+Xp(HANTmdfM1I}V_a^-_->VHc=p0oQf zyt%t#SVJ;!9u3tpxvjr^rPHl*l^2-*;g^NA=MfJ?p~nXjOMMtEP4uN{PX6w zsbBDT$%Pc3h)1p{2t=PTsr8c|2uA0@Cto3-`3B*TwpHdGcwrLw5l)4>!|;S?=kk!~ z<>G5{R!LO-yyCGE_%GeYoA_uFvJ#_C(Zr!edh>gflfQHroTy&GF1n-vzg?C-%+29E zNq9l^J8fn(KN|0o!=Jxtm}-d@sm)0_1GJbzJ>t)~6J|%}(Vwq?+myRf;n8Os3g8Eo zb@^2ExQ9BcZT?GX{s6c{7r~Xtr<3YRqT*BWO1T-9fb(=4ACe*AyqSJDIDetxD_bRp zDb0dW?n?8${ ziTXmcbo%zZ%}2ti_+b*?3D0VCGW`@yub`ijLD5tEsy>N^>W@puN$`u_&4W(w0kcET z7wo#_w~3Z|FPWMABZ8(66bqBYMuunT>2ghq!DN{78Bw zt@#Sz7o4J{68Juri=_aI-L6EJ{J5x(BZQk9WGr7+=;UBzv*xXE_C>Ljt&>EPJ&0J zM=#wPj9v*0_hFx^WuNG~XzI{Rd@*33^j!QR`{dy4dAt95?!923Z&yy4ZTC%W$i_Lc znbv$C~*3pmA!UslWbK=a}xGiHdXdoc2%}Y{^DSJ zEm&Q9{lDQu_S)_n_S)6)Q<#@HoxN6Ft{%JzUJ@S4ksH}-**Dp1!Mh23oX%cX53<*` zeE@#x?Re&#_qa0Pddo%+mw=M0d@aPdSmzc z>CLw`z4`x}^v15(^hVFhPt%wyAH2+lC%n))2!GIS)E&dlMvttrdCJ?I41LvJ5d2NX zKM+ry1HAX(*Hz=w1>phLhZCMQZfs#0O;8_nNdC#SPFsHIKsgyC}B_z89|Ytd#CY;AheQdgvPjW<5U)45`pf zG@m1w?_*D7lTts4cCMhmvn31AYfqey_u77Ea`R;HAscoMx*GDfCgk6f!~^S5i*8Uj4Lb z$bA!a??#vIjr$n#qo(4Iq&+Cz?rnY+7=rZI(M3tk;>}0Ei{RZ1UIc^u0^!}o$6m^b zekt&c@bQTJq%_uA07D`^HYdon>Tqb7)Eq^&rFR|M>aqRLDK^hzYp?}V!P~9`n1!p~ z*tkn?PP0;hV*pNvKY$aQoWdVA?%)sj^mF`yE_3-q+Y@J1YYF( z%kBzyTj@s-x{Jn(sYiBxw~f1Gd=$QeKLoGv^8Xpv$eH8?y4Fve5R6Vi7cGv*VT6x^ z@PhdBu+0z2wqDY6jTs~_@&oRsPhH$E;(yZ6+0n`1d`|+NxA492%=j5R%im0Heun!S zprdH7v4n6U9(CoTpGWaa)V^Sx;42gLAoXkQqTV{b>FrP_gg~LsM3m^Ct!pAuULFT=^&BBFr(_-{e zx%3insQx8KFV_Q$?9B zzV9wl#Sy3wXf+=e%@_FuU=zSe?Ti@Bxe#+WQU^K)-M4_mbsxwX4^F8UGc+um5f z`}b$}UYljIB3v7;S8{#I`>e})OWpTe-!}ODw=V6S>%QmuyPta>><#w65BABr~h=_VOP8iGSPwuGcEepI}A@`Tjo2c6w7| zQ-_(+>CZ2k>3RO9nT34c#rI8oA3U*S|6%6cg9+ci8*jt?{=HM`5B;6>U-Ng?|MkDK z{ww~E>sNo3%cs6pgBRiFrr~C^@N*II!TZ4Fs^@N+IVFyta^mExy`1Mlxj83p-@n|G zRQSlTx)huuGnj@N6HqhA@_MJ zZLI$Hg*|27+9^(9ipL zFPx~X)|xkgx4pa*@0EG6e}JM$~7u^LM|;hS%pX?en>IT@@MPdC#(`5xzs4KYP6 z?3Hpcc^DTDW8Vq-P=cJ-h;DqN`wHmLdfVCaJIiw~WN(6{$~iYD%&6dqK#Nt8lDUv) zYnV6Fw^fvjkmn)3e;pqE7@CJ!KTZy0yS?|tMeI)#1Sa67 z^Nm&Wu*a%_*K5Mrfti<%xA}INi7;mae~%wIo_vZ4cHT+=n0Ext)j6}x@5V2g(Q^#G z*-5_BQ06>4z87d|V;w*~eSzEDIhR3eKj$Z9*67<#@_U^9y~f0zLAMxkiIj&X zIPcw|6oiGH+_YbBfsm%^Fk)}gJl7E)&(iMHB5q>6oMRBjCQXdUn@Xgi%U zJ8b-qiQ%)4pe?%Y*1R=Cg~QByXmb{CBs#LkV>HD)iNUSdowWcDxxc zzbsBq!FHy#rJ|u|R)!qo?-}=Jwpt2AiJ8UX%gm5vBWAkW&*v--lTL ztFjS&8}GYoTf^YSBCm_}Fm{fnHPXo!(mu9+&PG=~Z?ca7d7$=LuEL#LRyfj6{vY=9 z@gTYL%GdQrrVgCnHzeHtt4w$cA2+YUMDvI<<>Axk;fv?tXJ`7H+~CAIX~RCtW}tp2 zm-21(hk7h>1&NQ^IhF1lr{HzJ4lB^>)=!$`6OLuAofTaG zd{2M}?MH%M+J1{CrB-#7@l3h!%NHTTw0j|Rs`O;p=TSv?r}9De3-j&?^lnOFe5`s> z*uM-u_~>Mxy_b9^?I^cSd?J4E==|Old$!KV^klj5zQlYx@)AHc8{-?#`YSS$vxo^YgG9$z7 zIplle!#w_)jR*G0^P{gvd+MY&;GgY_3Ii=apgwH#v^Ktxjm&3%ksgzL<4_2()uRSeZ{@$?-iTU;Pak~YMEY26Urf6R;@(Qpq))dZhx**Up z=bEyocbcT7QRKjz!}x=Dev>qB5&y(+<^}QXiC1NKb4-heoI)@08

ZugY7=lOe8J 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]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 AuyFAbbGRNK%A3g7c>h4ZZ$7dgSI?5KIA-09 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

s_%66lR(XBj)V=zAo;41{akZpAV6IA^ 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
o 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

Bg=CJ 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%0AqcE?KNdZ&C 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ɁQb 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

wpJJF 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

pBR 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

  • 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

    B4 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 z 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

    uZ60tm*pRWn;sBH_kE<@5&3=Ot+9@R*+TJrHM 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

    W^`rrWDHu%2>(Rz}U#x%Gk;Hkg&VSFb^@km;uZP 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%0AY0`AN^6E!@LW2!lUpf_{jI~ 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

    aN2MAst6C29ek~8E5PnIKa~U(^IC-; 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�vyOP*4yRLA*f40|gcEzzewq6jVHsQxs7I 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%0Dn=nI{O+`$^BAr9$?D7 zR}0R|syLwH!W_4EP_I1FUXlf>LTNO?vI;WU2l%+t!(HmQl~NqhJtcuC7CW|gtTId1 z$_dc^bZEuSrJygi+O9Y)pRNAFDxqRzG+dwkbs9vDcmh$#Z{;u7&L*AKc2AAShL@J$ z8i3EPrzgYC=WAH7WZ}>u%}g2|_V^>b+Vu@I4Yvkj<4YfyT@F@3NA+ZRet!XXX{7T6 z6w~D`v1q3qB1qBI8n@JQpc3hNm0dfuXN?S^SCt!A9+C5l0@zAqEF$~0m`T+rVGVUz zwJo@G5-`U&Ztw-=<5Z_iFO@SrPs4oLe(11z%KljNmiwF|Y@E*jxzn*L=c`+Pa!_(#w#;?9nrvR(d$BwcN(NXxRoR4tjrI;;V}h25O~MDW0|!t_ z)YiH^wVaE|N|H|?o8)T>$?cFdUr76!+!WQ0$4opvfO$#VELlTmwfGb~Nq&(u)Ki4P zCJB_TB%)u62`u6uJx)?FnO6Hgg8IOY;Y1W0v*tK3M>52PSa{fH6eUpYjgQCgxEBW1 z8%|NjSkv=y@MP5^(R7WqwvF;hjeldnf5MDa217j27v23_Cc~-MYc$z+8ja&Bz;!+MfSsoBX zsLA&at*5yp%CvesRk9*?2?;ia%5plbYL*zFkWUSQHn6xv6YOB)>!z@TBQ(@9Z$RE8 zFE2U+Z=G_)meY*a;rF%rB83Mo&AHh7!0!iExg4de0khuiv=(tXDRm%cl>LKgl`>0C zxN{bun&ZMJ&w?~(+Yi~L!j;XJyWsO<11JLpEK`=%E%|O0Y&qb;q_pfRmS;(X6xUTLQk<`X`|CeJP^&EtdZBoW1Hg{sHkCms~@ zHB^;20u_`TP_)$}!8qA$Zub)WB<-M3$#L&44h@?fjLt0;cj5!ys$>W3I0dH@0bSr{ zkO#qJT4`jMZ%hS0->U8?OQiV6 zTHGw+G%Lz1t8fybRlxz*s-Db=RmGY@6oGqF@i5$njMKr#1;XQXX|3n*vVyjS@@rqNcFc;^Z)+c{gbO?~;zcYbuVU;NP zBhChbL^*xsV3CjC^2R2oGZ>{cKMZ%KE$k?t4HUiEY9i^U(l{3M#q+0#@wU@_%EAEz z@Yw00(Sqb{9d4KLpq>TgjwP|+oEx$7Ej)>~x(BL*iMCb^f6T%xyF)fSKZ>`VE0bxf z9mKO+BUHZ_i(8rqVBUqY8ZSeP2KH4Q8riOWR)>zAuI}8WYuj#~VlUom$nM=IC)avC z4)`4V9TeB)|tNg8nm_zB_<%i6jU7q7D8qg=3^%R^>3WM>Y*LxvKcy7y;456O63 zEJ&T0ilD_>#ZQ}`jMkF8 zq){1`IuaXNlC39KGHBY=vAnlP#zU6(2y_}DD9$vGkK+&diBTuvRD0m#BrO<~)xWg% z253b!4GtDj71H3$S~9~PIPPQLFd&CK!SNoxy6=>;EMLY3)O~y4;d{TZ1+c#(c_EkA zM>;NUAdppYT6jACn1vrJB^(Nu^8ux>3Q?5hF2zQY$iRpBPZ5YnH;ZN991GhAZ>~A& zsh$CLgn(5syHF073UZVr%q~nV;!InjNmgLEQ^aK#DuDx=M1ljZ@#P3v4)Q5Bz?YO+ zkZW>E5^bYWJf4c*9f)B&gx-ivCWw2>$^NMJtxW47KS^Il8BLEgIu?UJW4wR%2EsmW zT*56ZD##v?hnIcTkJmbhF}~B4Nymq0J!HsP4&RA_S*#G6hm2>n@ZsFY@N_WzX(3mE zKa%jllghdn#_3GbAlM;uL&~#lU1^dSalB3e=Wu*Z3Pd%`I>Bkc5^px___&ZLFJ}Os zGf91tLB?_{)-c#E%2_-P3F=cYI3?d(Fj(g4HeEyUNiz`P*S zI$z!Q!#y??=gm05w$OKqZ;o->!$Z)tz&Y47`KGvD)`S<5U461)4~PZ%7Zqj>889SQ zf@FXFc%h1OQt>A9fnU~Be3aMT-FrZh8@vJGC+nxpJ7R&=dY9{~+gbP}i}CvF%TEa9 zK@M2^NP(X($m7bIf~lhTmxt^c&U&MR==wcmo!=+>bh&b!55S#PmfNqSm zFpLvbfqZa4uLF%QTfZ%wh8FqVbBE*?-Oy8^(zOBSskUO7&!Q3xj%A!0Ezg4*oQ9z= zZmc5i*(wl5e^@ux#;8M1J=@% zbRXy)3fs^U*HGjsaYFnyoBVTVi35svBOL3yzl?}i6!IqF5}Xec9>O+o7w~%AZ1drX zIO|-l;i+KCP8)Z2cIvnx6=5<^*X#IFpyn4Gclnz=cx;qs#I3=^>yQ_j>K(~+z-NCa zMeFr`>@w1hI6M^7&%?_qIC-U{3-JCKmSA7L+RVHbm1#~Y&P!Y0*#5^R7;)~1qTIZk z+#KHi-NOsB`{k-0asN)2mxf0@b?WiTK61^p{D7yE%8Idmfal}g1F}0g#Lg+@@e~Z! zmyPa}eEnS{eDY>%XewNnXBIiNJVPDjbzwyfj7uT~e_D-laXDTI z*D0KTu%7Y7l|npV>@FHQR4sZG3}i)lU=SSAP>WYm@rVe1n9iqzv&|w9;piJaJ}Eyp zWH>mBYguXQjVzglV+vosD%NHJ`~l;U^qlayhp!x`*c~91m=|pz^QdG|m{uU05WED= z1!8^L_q!&r@yNP$iG5GLTMy~rQn!C3ayHh%_#zcCE{^&Z94J-bZ6%_2ZR3oc&(S!k zIqLod+r`ikc^6QcnQ$+{LVybBvKIdic*?MxaM$2$mu%#9Z4QrQXONPO*NHaHS{ewDqM7_Qpy5K*POE zUiDVL#Gv7-Kel*5f8^m8RMPa)m{h|$-%_US8=~CN+Jd>kOmg6*kFGb-|JPtmC`lcd$Q|s$@;dFV6+W%P|8(Aeh-pX2PO*Lb* z>sv-&okldiROs!rVm`aPnpV`8Ygu_}ldC9se?|{oe&q?@X!3;glb~!@R8)}rv%c@o zCJG%4fd0YyhQ);M!^nVJzA2^X0Jzn3Dkmi2Y&plrR#b7ub6OHHT#|;-=psQJRTA>G zO#XhBR6eQ0SeB1@^waNk7O>t-ibTJu7u8N_CEnHHhgS10iuYj^S)Shjdw5joBRzAd` z7LeMWikmjp8g{{6tY2?n{L0#AuTRKEoW)C z^q3&cJ1dhtr4trh@__t4T{3V^`%fi3(HX|cKN^lj!cQq^u|T*k29)Zo+;8{X@+VBj)6MuO@y+tlw-a=QN+}Yo5{ioa)uip_(;YH?59Ys#zQSGx_-0hBbjn{!#=^rWJvc zX+_{zPU*pqhjZdf3>+AKP^YwbrY2Cg~>-DPBdcEqjUY|Ox*ON|L>&d2v zmJd2#QMl%rmOQcMhxG#~kmcz_=@0z&n0m%E`ShB7AjKT;k7XUT#hBIu5ER5QRZ=t1 zS3&spiq7XNCDGiFnS#sz@Z{`SX2t0^gAm& z2DUHaDGKbz@|Z89d7KK7-ZwnfiwJfaXM9y(ox2=|4M`eZ4sdz-ML$hw!>#vvb(-z* zPJAjJOooc3;8T~clA67)kBi32v#4_0Pi;pBnCo(I5Ag>W z?1nWQdp~r(u-zWpchq|wDwJQB)03jp>F0W+lgQCyyIdLTt~g-9PGw&XaOC47F)8&_ z2cbLJHx1wIo0|$rjiEMEIQXE^MsOJYQNE! zYWO8wUn#DEAeKaZH4N;6hVj~;+dCdsYYPbiI8xH`Q8k2~xbYfgX<1yB*Rq8B4S!xH zX4;$S^>T<4=1;vN!n>}u)p9ZVp{@KyV=R44rIK(P&$wW?6vu|~#i|4+-8hD6n`^ta z9b|@tBMcQMNSPj3I5aP#Fn5^7i%IqOpbGmd>C7Q zpl#Uj0eu*kauDcMi}6aQzI-o5HidfZ%CSGVT!G8CkSEGrf)a4Br^0 zCF8847p$Nxa&6PQw5Vg9Ar4q?pW%phK=iuW z`-{sX%3#aa92C>0$R}+dPS1sW=iqm_mXj+E_qy1Rt_!0@A7U)aU>(*U%CYuqHcr~6 z2bKr+?FEZ+%3h-FD9LzT1&6edwscF&11<0psjQiN4+&T6ERO_dq`++|OSpUm(%Kwd zknc%jhpMOYwV;xU3O^L0WQDS?Si1tst9xpY!)aTqlGONKliw#pVL>9^drx^6mS3Zj zrg*k)XyylA?GLc#!%nANKeyq!wyuW@^}v$E!}p2#8;06(pv!5J>2&G?smc1d$-{Bu zpbBhRSPXV~*yEk;$oEa8aFos4<@6Njddl98zz=+r##vv%<%xY{~vf;-98J^1V~Z)M{h1=pgx9JyM`4YK_BkcG(J)v_>T_`fI(+VVC8p1)G&f zL1^dO>n~;5*?OIfdqI=BJilmSZ#qsmE^^6-N>umk@|Fy+k5C%Ve}9imDJikE2NCUh ziaAx>w3CjOUj?6S;a$KJw76K0O4sKHd7K_1`5|?Ogp=cAqg~pY6B3>#^LVHdej0hG z^)!FjD=DJWFni&Ylzh~!-0COGAiM93*McjN2yT*Cpsy*uS7O-mnQ@k04_MPae8_+h zhlHENmClfEiGka}-kT`J6>>hxqz@HoDSvn~@X8QaHQNm5Kw*#oA>Vk-%Asq?_EYn5 zqr`((=B0kg)JZ3&x~Hh+wBux8@e6k|h3!+{ZDy&X5SlG{kN5jIIysr2ke3DcJYT{SQcSkv`&Ro##@Ot_w^@%S>Blt&yItk-P1;liQ^NSj#^ zk|?{yY2H!z7AP#QXgvv+cRo4RnSW4@KlUX*+NkyjRUegM=9b1}$F7WZ&61iMm)Nnd zL1B^KfwT>yYDR209~Q$=C=>SmHCaHf&roJ@$X!~JrH{S6^W6RVX5rQGFywYPSmAeL z$at&|PeRKdM}B(R4F!iB`R>@bXi6G$lafZhEtgX2+3l(}Q~r%aB6R1ScT$@+ZRnR@ zexc>dms5)tE$H2M-=)2K_tKs{d+45f?xE|izn(hbV|E7*9;CW;>(a7i%MhHIO;=ud zB^^F|n8uDBOS5Osrrg|IYSN?$J^l34bou3%)1gC$=$v!Tp`k-@=_4Tprk*`}QoDBT=$mi8 zA-CI2qeqXX4?p~n>eQ)27hZTFJ@d>nv}@Nc>e{s{tzW;Mwr}4~{rdHzn{K*^di3Z) zUw!oz8Sn<)c;k(fsgnmBPHRa8{a8E2e9<>lqHa^*@|vSbOh$2a`8Zrw_a8a1LCHEPfoUwlF5 zpMO4$7%_snb?ZhRkB7ed?mN2ZqKl}0{rYtA#TQdnRu-Lm?z!~XV~M*;j?fiXTtTL3Qcg||efsIA^y;gx();hfPp`lJI!%}`fgX6^0czT`DV=%dnRMX5 z0ebGa=V;8BG4#(r|4<+hp#1!NTDo*8ZP~Jg7A{;!x7~IdEn2jQrcRwo#l^)mckWy& zDk`FpBS+GumtIN_J@gR$@WT&;H`mGM^U=0#+o)c>di22uA4s0+-@iXCUc8u&A3sis zM1sEl`fHjtZ5matUY+*s+ebTh?xfnaYg4aYz3AI-zoj{I=FpTWQ)twvQFPZ`cTu%! z)o9bEO*C-eK$&Y5#} zHv!+z?|uK@?~5+;+~+*E&zzY%ckUVO*I$3t9(?dYZOM`)+W!6fwXeSVN*gzBoc6#2 z4`?S&oY1;=@2(v>bV!Sfi_;DsJgD{S*H2rzbg6dlz4vMkheI1RYLwQrX;W?AzI|F= zUY-^f7N&jo-FMpj`SZ0MJ9cQRR;|(=dgvjoq@+aKyLYd)di83pXV0G6rAwEzKmPbb zd-mC9wQx+xbM@*~ZTIfo+T_WTwaUs$ZNr8Qc){tT&6+h!J9FlYHhlPSZO)uI+6ynd zpdCMcTdX5jytqJ|NK)cgD3Fy_0^t#{&_7kGgG^K z`LcHY{CREHu3cI{K!6q-8>^+Hq-ec*_0kFp3$_0J`)l#>@!HQn|Ez7_zFiwUc(4`{ z5~98T{`=a(g$uP8UwlzJeE6_7Y}hdE<(FU9nm2E*ef{;<+7nMapKy8pCJ?9 zf(*PInfGmE+%?FwPGs2MkXau@M%|B0Iu0511TyC#WXyxeluMBz9mtGLkr5GXH}5-S zz#YhZ4Ze+4bWH29Ot~1D3bC9WyBSSro%(N02=?-L~GGw6V zk$Em7S4|nW8x|#1qI2^N^!%4S+gZ>iE`As!ucj`c=3RSO*Ib8x1SaHK8aL_dN9odoBZ1IO7GP803F zb`9YyTfkAaf|KkF2bl!t_!J!DGjNJ);Sl}c40pm2UV#%#hXXtY=eHP+?^Zay^>BDo z;q2~#qjSN@y$1*P8l2lmZRE(`;nY5bLqn_2^a&iIa8(FPzaRIHG-ULSb+~^Wl6}!SUcrt&-JnIG5mT zo`s{i3MVre4rT+K%PcsS;czN1z@c=5GZ_j;vK3C`PdE@?IFC#?j`MID0dN>8a2ADd z6!CBp+uVD z^^&Wks-3EQa(`4UQngR6o|*&MsItgClG`S?OjR~jg;dp26;4$ixlyW~$jy@5Cf7?< zAT?*GS|N8$E|6R=xmKz!sLH3Rn3@sPw4rLBsxGS5sVb%>167+;g;JAYFkCG)HK^*K zYK*EUs)oq@Q&maLBy!PIy;4((+&5KuRP|7`O;svYk5uhYl}t?@a^2L_pk@X&AE-%0 zE}yD)a`RNpQq@b%8)~9abBCHk)HI`NpQ<9NQmERZW))SZ)D$CEPfatblBtTOW(PHW zs98r<8CBg>XOL(M;`0;x$vRXH^asOd<}F={qY zGmx5*RJBr-PE8(a0#GxMsz9plsYyo7FlzEp^-a|)HNmLqLCrX7R#7v6nh4a)q2>WK zJE+>ErW7?#so6?R6KZNwlYpA4)V!ePC^bE(DM!suY9dneiJDu~9HeF)HHoRJr)C&6 zBdBRYO(1IaQFDfx&(vh3W*s$=sfkC;3Tj?c^O%}B)D)v?otj3}w4kOTHB+gnOwBNA zrcrZ)n(S1iQ?r1oacag<^M#s7RJ~I(oSN0tq@rd6Rrl0{qoxiuEvT7IO=4;uBa6l3 z)(=5(YJtl&7cSsqtbR9&TsAJtFDO=J$d<35SUry7az9R~0=Lr#r!x`RXEQGMS`?Yz zaciG}t2m6}wH2qo3fb#DWQR34q~CCBeQ|g@;2wIQXs*U(dkTl1f?M)AvfD7+hG{7B zAK@_HK(QZ)%W?^acqd%ZOt^%Oa5t@ROG{8(YLF$vacRFoQM(DQqXCLl25!Lxw2n6- z``eK1zDE(;26t5rm$M1Q@Ek5t6|z7d6pPu&&O4Efd!vZOq9{FrEc7}q)y;4tqfwlr zQJk(K+ZDhaPC|CM7w#$%Mcp5+i0t$zvRV+b=X_+P#wZ3$;3_(!Xq-WonGE;zC0x!Y zxU~aNL=U03H9@g5!@ZOv3yp{Ch(PhX5$o=35`0j~R1xWh2Gm6wqv4Jhv4qH5>{w>1)O_&&J( z=i$PiMpdy8ZtD-Yf_LC@_oK@B0@cPGxR9Q3EpMZk6v1sZg}cm$3wZ!8IuF&ygK&2T zP!)}WD|!y@>S4I5TT#_y!CgEF*WVIu@*=8~y>J8XqbeJY;(HYCBo4)V23*+)xT1A% zi+{qUUqKO?3OBzV?&oh*4O38!?1EeD54V#FH)BE-(id*xSGe6SaA|u`MNUVRISa-2 zE>xQzz@>G9%T9tD9t-z#5N>EO+2kQ7lPLa=p}JdyB0LY(%>-1-7PyJFaB#@~?*pixiHA1xoFnLqp>I|2JphgIq(9XUrRHv; zQ3f=ko4+BbDB<@t=)&PY9@MS^PL=6fG6^`J zuX-PkuDLt}wB~p6G(tl@W`aWO`geJBc<34|xE{|J`#O4@{x#cizcH+*$7^p4?gdpu=&KB=eIyS-%l=$+@$bJ#6)FIG5pUX4zn4s3bh z!zbZB5B-|{lO28SYCMGGO8xx3-a@&ryxOulPJY*Wz1t?o~4U`EHG~?@iPhyLqqvTsneMM=5t;d+gq& z&TD(_H*Iydhv-I#4L~nw=}bL(n&BHC?C9S)y63{y_oKc)!DpO!|4Lh|%R4bZSano; zzTc!5!T5l-p1<|7D<@W8pbl4a>zo+RBjXXtRDyo*@_f7M#Fu5gA6(9XPYflE-_|1TNPnW z`FNdI6SSh-;3Wh{-jIHAIc8)}j8Eps5d3De-c`eU?y|Xb7@n}0Qbh3q7r$pIcTn^c zdL@hUf%8Q%D{)duL;RO~uS3PycbdHx<3826pn9GH`C83=;Kj?O#76N~mltPNkJo)= zef``LhxhvG)JcRt{r$72o>pV}be>P%^E%nBci&gF8Sw799q}bO56Jetcy~>OPyaAz zzmPsU%vU3id1#B*n-kBn3X`YaZ+ngs@1=SBiszidg!eMFD)fp%@uev3yk&VWUPf<5 zWr8>$8lWzJN{<|a31GdqgK>ix@69nL^(@Y7xW6B?D%vaWy1#SuL|3fa{*XzK;PT|8 zutgbZmqUZh>CG<22gsJy0g9al=km}2S=L{1No)?=4j;Mocd@l zkDcmG(a<+H?)$Bu55BwbkY0PBFK6xaP835F`Iuz|X&%)-<7TRoR) zJ?>0h6}5sl@6Ii}e~;d~X+wIiON-;=!TK~^DsPaMJxv*|$FW(u8hFjmRj1mo=ff>8 zPYzS54Zeaim6~HzUm0Ijc|O{O&V8(sdobW1FYJ+@&~o&;-5MRcw{PJV%(dB0qbkQr z7gt>zy_kD=PeI_D==rXIw@%X{bCH*Dcj_pn}Psf75*!>io5D;jlm>VBVqd_ol% zg;*|BPe1kTb;@8JsrP=}*Nm@{s${Qg*9UFkV7%?_eBgC76(#e^Fy6;~$z|F7p~ycK zvAS#N&ol0?%$<6}PxnKmnEksrhvqLw<4eAd$;BO$;m8;dh7pl8wY@c$zBu5CpY?#e z7@m$nAL`2my*-;(gb>X#UV~S`s3N-dx*d5H^%0%1x+6Nz4$EuGaQF8?s&-qTe2M#V zQ29{1;=|(dfP7NGJW?v4s9EfoZH)rWxyN9TT|!Ez{i`p3yc#Tu)=-X0@XZ0`sREQR zY4r0){VEoLJgVc~SK!$cpZB;U44@R`6;q+&`P;1IPj73^cd1b{oXZLi( z8e{qfQ%!u~)htpM%x$My&0Pt40^wX^cg``YDGStX6R=$}AFblO>@BUsOJo(dz6_sr zQOFD&6&-{3bBo@Bpl_Ynanu`ktlJ&)3a)GS_7AvDg_!K9?gO+u$9n73v9egx%QwEb z!9%HMpfW9Uo)&>zF2tdz%d5LW@hODY3u?X%BN$Qb$Uv%V?0h%XdQ{!$yKy2;U_k{> zv`!CMcuc4IPWuGJ6Sh_VAN2@$93##iFNUs2eRsZHM!PbO_M;-q#8@jvW`p z>(6r_$Rh@md3MO5NBGisuY+6!KdAe6HBK1&7M)u5Y*)`3YhGN4|F) zMC*9{(j=<2G>sxVPEf~+S7`3AX!`ctfgk5aT04f-xd9NQ4H3^Zv-SK{DeK{yj z^y8&|;(~%aPn%Ybmw5GXk4gw)e6L=o$-@1zdJeMAa{INq{G58c>O0d{qhnBd;b{<` zOoDU`FVWtG=W;JY0{K+Dd73#|A1|o*`m_6Z+WYPXzQml7Z0@-pk|o`Iz5XekM=isB zVD4oZ;*7E=Jwm=#jKs(5u@&_GG*8?*wM~v%hm}!H%X}UDT`rxFG}ZBRPs2`S2Wp@6 zutTpI@FXc4#{JU|iIq9rke7yG)M*q#?@Jxvc8D;i%Htp7Q2>6ey=rh(D6| zAMEfB#c1=|DTSd2`nUSJjy|mM-bxWVM$uDHH~0Y7*Ll2R z^2%*)9!>1hItK2?QO_>r$gNyQ&@pm5*_wuE$$HJG&Ww2XT)l9no_>tFWtt)w-~#gJ zvF^NwO-O81ew4S-_Xl;3(ru^4COQ`2E7WdfJ@3+b^sMXQRbJ7b@9O7oo#&i`ZR*Q<4)boO z>UoxSt-9EhH*#Mu+z7?%YkTI`*6T7o7^42!1Jw^IGN?MCJajbDov~Ho0oXeppqj4+ zo!PUwvjAUx@CqoG)RiDSY9D@dqk5qPkr&h(O?+R4E2M(7@x1Z+O7$}bwwRPL#(j@y z2UH)EOz*2!+oErs_#KYB3Xpx!ZZXfAgtYN`(AAGYc}~1|;HCl|A^9xeU)3?z->fEn zl`bDU)_TS78hgFw8~kpG9g!8)X0Wdw_WT~yiP3``Mi1&srfvuFOKOr7^)Tc)aJ@Y9 zebFmXY^M(Ibq95x`(3o? zn%93*t)!@r?oEcdB&Fpl_m}r2dCFJ2y>3o->Ox1s{@r0Cr${6 z5CDo9vJqerfKs;-^@&zpx~%GAsTtnAyMW;WKrur$0xSYhYK*iLaPZ)ugE#)McF!IG zYXyK}hHL~_1fbLyjVR#k*;~#wb-ex8Ujp710E!v15nvI3Qe%{=fLm_qeoN|>rfGUSOP7AV^q0@?!NCH47XXSGvJqerfKp>5set+O|Cs+%)i3wnE8rIa zpqL>W0Tux$HAcG%a5%O&vflYTB0|9D0zffCHUcaHP-={D7O-~hjcc#`G^n^(z#svj zm?0Yh76B+VM(qk1H!gGBW4_xjV{jXT?E*kCLpA~|0#Is<(iM=M{a|*Fs|QAm5O6>M zC}zk;fJFdGjS=Po_U?Ui@2zufeftWq2>`_m*$A)*K&de*UBCkmOn6||+r8uB1oRdF ziW#yIU=e^)W7M;N)vJxG&8rNz-6p^w02DK1Bfug6rN)SN0o%4cyKPSMsqeifV5$I6 z%#e)$ivW}wqtXQg1w{m9_it5HB%qZ5P|T2x0E+;WI!M$-K?@iDywG*qZ!1;^_)P#P zX2?c>MF2{TF98Jf?R&iMGhfcCsuD0u04Qe2Mu0^CN{!L`0@}APZ-3UFcL0Hwy40|LUr_JkGRJ8jr70n-G4 zVuox4SOlQd_##2Ts8Nxlau?j&v!{T21%P6PYy?;Ypw#%W0Tux$HAeIcm^g9B#APk2KlngEwE$4ekc|L~0F)Y|>jgA#KECW0Tux$HNH|1FmK+=^B#Kk{MoYt&IRv!x+{w6ye<-=@E&(M1 zKrur$0xSYhYJ9;U;G1ur{$}BXk2Y-*@R0ye%#e)$ivW}wUxNsE=%L{ct@^l2)20Ht z2mr+l*$A)*K&kQdh=2`_m*$A)*K&kPCgn&;z8S}}edmc?n67Z-1P|T2x0E+;W8eiE6m^5keq(8gWZrv)N zRsbkw$VPxg07{Lop9CB}Y&z`o=AB263b<1MC}zk;fJFdGjjyBx^z6C4XXYK_7A+Dm zP5>xo$VPxg07{K7VFUyOgao8_ZZ>6#fMx7>g zp#V_Kkc|L~0F)YEED5;jrm&l)J>K%;j|H?80E!v15nvI3Qsc`j0WZDu&Pz+3GyC@! zFjD|1X2?c>MF2{TudW14pKhQ2Ud#)3-YMV(0ic*68vzypC^f!@6VRy9;6_#H)-`Jc zSOtJ$hHL~_1fbN7M7^fb#f!gR{MB^H*H^$L0ic*68vzypC^f$J67berfp4`qaQkPU z3AkMVC}zk;fJFdGjW7KK3>TM~{s?y1kfYGzv%)0E!v15nvI3Qsc`<0Yiqg9uhTanbRp? znE+7Ckc|L~0F)YE-wC+=_7=B?J{Y)Thk!rW0Tux$HNJ=xuw%y~JH{F^e)~;8 zh5%5^kc|L~0F)YEj|o`3_`AhN*Zuj_Qv&`J0E!v15nvI3Qsav{0r%Wfa?i=X;!;us z#0db!4A}^<2tcXv<)(lWCq|rD{m>H=CJ1;!04Qe2Mu0^CN{z2M1^o5bTYudi@k42; zfFA^aVuox4SOlQd_@Yn1`STB*?=t7*x8D}D`M+AUkhHL~_1fbOTQc}QYpJjaZ$m$&n z7Yf)R02DK1Bfug6rN$SB0$R45)^g9Nu$meHVFExgLpA~|0#IsvMJr&$2*U{D@YTu5 z0#*wE#SGa9un0h@@ztn+O`C>pT5+;dn>GSE2>`_m*$A)*K&kO{v4A(MF2{@T+}};kB&YPeUq!;*=Ge52mr+l*$A)*K&hie{cLnz-rBrDzZ{%4 zO~63`pqL>W0Tux$HNNN;U^My}8wHq~G!bAH0E!v15nvI3QsWDA0gpX)*JBCsDRMF2{TFMkEhne*|Snw?*L{<(m!1b||OYy?;Ypw#$+UcjM4zK4R3-f{4t zfI9?$Vuox4SOlQd_?lZl>(=?L4=s**_gw)|0zffCHUcaHP-=WREg&T&A*HPJu73Rl z+$8`MGh`#cA^@evm&^h_{&?8OH{V~Al_j7?04Qe2Mu0^CN{z?`0)F}Br(a%e|3_q` zfIkF)Vuox4SOlQd_ySzO*Iz&W^{A1b?%XNhQvsluAsYb}0Vp-T#uhMj>YS-x^?LUC z=LI|~02DK1Bfug6rN-CU0#>eUvohwc27C7kXdnO-Gh`#cA^@dE1ONf|-#_mD?T2~} z94Mft08q@3jR1=Plp2u`1a$Adp?jZwseyq4QU!owhHL~_1fbOTs$M`;)S;+5{>L0HsD000H~W0Tux$H6nQk7&&sl$ORQ^qM`(>5dexAvJqerfKnsMg#ef9Q`h5NzaBqc zz}EsmF+(;2ECNt!M6?jFV8NvYzu$TBjynWg6ab1DvJqerfKnsUh=4U~7Oc7W{eb*@ z0RsepVuox4SOlQdh@2rHD=R1Km4W*nd{DqX0ic*68vzypC^e#|2(VhKtnD`s9xy<_ zU;&_*AsYb}0Vp+w>1+vg+2ML!Nt1zz_kTm?0Yh76B+VqSFZ2z5Dy!hi6nQUM!$O z04Qe2Mu0^CN{#3+0>+OYJ^udIJKuRnz)k_6m?0Yh76B+VqH_qi`|i1SpZliYk|hHA z2>`_m*$A)*K&cV2LqO-wD?2xMEGax(K#~AZ%#e)$ivX0mv#7&6=jY#%@B7`MygUJi z1b||OYy?;Ypwx&mBjD$szyA5tCazw+1h@o%Vuox4SOlQdh*~1R>3r9@f9tnLjtKZx z04Qe2Mu0^CN{#3z0-7`#*<{U>uFIAQ=qdmdGh`#cA^@dER2cz-2e%)bIK67Y0s&P5 zKrur$0xSYhYDD%C;OA%c8ywPTHaQ1m(D>8GPUy?4#yqelyP zTmUF$$VPxg07{K0O#-%T*|#O9W7dHK0eE9dHPlkjDcv1i;X2?c>MF2{T=wSldwk>LV zVqWa4uL_720E!v15nvI3QX`s@fM=dL|IEu%=arWWm?r=fGh`#cA^@d+M%3lc)YRNu z)41obeftCq699@CvJqerfKnrpmw;Kbo|!f8i{tIv3pg$S6fFLwc zUudxT`|ky8766JFvJqerfKnp@lz`-9|KujAw@sWV;5GrEm?0Yh76B+VB2o$X_17PM zeXG@9@$mxw5&()BvJqerfKnqmmVk(e0}&5i$bRAp0oejTF+(;2ECNt!L^Kod(@zil z)VuuE*IpCwssK>Tkc|L~0F)XL#{>)-bY;*tuil6NeG1$t02DK1Bfug6rAE{*0hyU8 znRm5&?2R`BJSG4XGh`#cA^@dE6g2@`w?4IXexu2sekx$H08q@3jR1=Plp0a#1bqMf zo!^^mhrjzyz+nNPm?0Yh76B+VqOA$A*>1HpJoo0TSpwb^0E!v15nvI3QX_JlfEQkP z?}g_J?Ix1|y8uwkkc|L~0F)Zh_5_57?+v%zJ>!NO1k4ZsiW#yIU=e^)Bhs9J0|$B> zNIUc3>eT`s6ab1DvJqerfKnr>oq*3j&-#4d(kSK3{@`u^1y!_EvJF5rv+P|T2x0E+;W8d3ZNj2_){ z^tk-{J9ZRszW`9okc|L~0F)Y05CzsPbJKqDfxX2?c>MF2{T2!R4_yRFG> zT{rkwR}1hL0E!v15nvI3Qr{-(>f4@r>X)bf7(9Q}C;{^YfMSMh1Xu*1)QIFK;M;Ha zf15Y?-J5O_@U8$*%#e)$ivW}wQ3?eF2ge7O#vfMSMh1Xu*1)QA8mpkv2H z9WUn%Jab0CKmnkbAsYb}0Vp*hX9~#8y(c&B_t!Er1-vEz6f$B)lD zetz3CiHQQ95dexAvJqerfKns!p@5w`@88)oYV^{j0!9k}#SGa9un0h@5oJ=qz4zwc z``X3GapMF;3IN3n*$A)*K&cVgQNSO6y!yuji9hA$3iwF?C}zk;fJFdGjfj{6UVlCM z^@88lZ`&qdy#P?mkc|L~0F)Y$CCvRxfNWcvOKrur$0xSYhYD7a7FnRL) z$-h{idi-$#PYD3U4A}^<2tcV3EmFXW6}?uBuWo+qn1JR2Krur$0xSYhYDA_KP*(Oq z*>gKizy7*_(*i&-LpA~|0#NEQQNLc6kZ?NTgU`y&ofA+d02DK1Bfug6rABm90ja5d zQm5o>XwgEz1_7X$AsYb}0Vp*he+rl}!#3m1etXxg6R=kRC}zk;fJFdGji{aiDl4y6 zp1JA5Lk|hKAOI9IWFx>L0HsD$P66@pr{X_5QToj{0!jsdVuox4SOlQdi1aF8)vAD1 z&2F}A*dV|n02DK1Bfug6rAEY20q?$>_wK=`_P1;)V7~xR%#e)$ivW}w(P0HV{BZTd zLjotBJ}qFP08q@3jR1=Plp2v>1$^~Y%~!)lf4pUjfR6=$Vuox4SOlQdh?XiKC+EJL z@XN2Hr3rXN04Qe2Mu0^CN{wi}0-k>Qx2JzjUO059fQ14;F+(;2ECNt!LMF2{T;Qj(Sbg1lb zp`icy^8)${0L2X12(So1sSzPqz_4MBhjkuzb54$cn+1SkhHL~_1fbN2`YYg#H~PIX z_sZQ*J}KaC0ic*68vzypC^aI?3b=CRqbpDM{$|V=0pAD!#SGa9un0h@5iwbS+1$u% zZRXdts{lU%pqL>W0Tux$wOQ0%&11(-9{ZHv)~~-7uvGvkX2?c>MF2{T$jAcjyKlyQ zd*2A})=faT08q@3jR1=Plo}DE1t2>D*bsCjvk*LpA~|0#Is178cN;K}>_f zgf=#tfHnd^F+(;2ECNt!M9~)T=buOaT;BJ)`SS&QCjb;PWFx>L0HsFcX8~V)G4+dQ zS8TJ}1#A-liW#yIU=e^)BLcX98*lvP#*ZGj^5~-it_T3d4A}^<2tcV35n4dku4}pu z*gdj!YXKt#fMSMh1Xu*1)QHe6pkKdp{a*iQ?%#h4m@5DjGh`#cA^@dERA~W^KYs7y zkpo8Ef4_iH0zffCHUcaHP-;XS7x2zI9p4%F?$Qev1S}N*iW#yIU=e^)Bf_vDOY4?) z!|aV_vw)2PKrur$0xSYhYDA0|@Z59XKKJfeXF-7grvOmQkc|L~0F)Y$!Ug>B!|gu= zX1{gnlz_JcfMSMh1Xu*1)QHe6pnv}h{jVOWeEDSol>$I9LpA~|0#Is1Hy5yU>AW0Tux$HKOGUShsH0y5oQM9Xwb-Ujd+)AsYb}0Vp*ho(uT>_rHGs zA?Vk3?F9TP02DK1Bfug6rAE|x0nb1G`SV+5I$E_7;1B?c8L|;z5r9%7y1sy>O;ek0 z$m)Lk?E<_5$92fA;$y z?s?H-5%8h_P|T2x0E+;W8d2N@oH_I2nc36cU$siW`vO2QLpA~|0#Is1mKRV`@^Hz- zw@xM`2skMK6f0E!v15nvI3Qey@O0p;aym*4XI z*{)X2?c>MF2{T**gUM_M7Xsul;{+-dw=X0zffCHUcaHP-@KFAYk}#%kY3< zt5Q=1tP%i<8L|;z5r9%-78U`!cHOqizkBk-4+}^Z0E!v15nvI3Qe#FG0k_`T;nx1^ z8$R=lfQAA!LIr?ghHL~_1fbNIO-4Xs;@QNv z-z)$9cLC)BKrur$0xSYhYRqaQz;1uu?l|_IkB@-&1b||OYy?;YpwyU6M1a44SO1ZH znhY5tposub%#e)$ivX0`U(`eVOG`g1-SNb!k3JG`N&qNk$VPxg07{J+MFc$i>{riz zJbsSDAz+RGP|T2x0E+;W8Z*QQICgC2v3H((sY3?=F9`s}4A}^<2tcVZvx$Hof4uw0 zemB1H;fDg=5CDo9vJqerfKp?27y(C)v^)~_=}ljKCEz9jpqL>W0Tux$HD>-1Fm!11 zp}i)qC@d7PLI5ac$VPxg07{LSjs$GjFlEE;SNep83g{yM6fLR#bE_@~&)%}fFedhq_b$zMtR0uV_kq>hf)@5| zf9j)G!bbf)vH85XZyvgE!zYst_Y8P)^X!{mn%?N*TLUdKPxlyd`;Nu;ocQbfqJqy_ zj@a~OpZ&g1Oj#Z+^LkeHjYtSD&6}T9f~cxAU$Fy0B(o4C-43n@6RQ?wA;1b-)#w2q zzg|n*9nCZ>>r;1md4*cW>fv)L?0Mm{oQ{$#M5&>T;%}P7&zvT4(5Fd&oM{rMVp@S( ze_Cgic8d&)jB`hw0@q0K`oA5T`?v0bh35V`QzvZ>&w;TxXeSXGEcU0|>Dgb2Y%HqT#9xi#HZ z#xXV=B}ujt1ausdpI?^dC?7HxabRfs83>e9n$8@Vr*5{jGhfUDS%TY;B!3U&Ev_UjGd? z(2|vzhFYc;&dW;C(eS-CNK4h)8I~BQVYa*`hCj7E*j}_D*zla;g7&61%P`!q-Eh=! z!0^3conbAm{X)Zsh9IL=8?CJ}^w*jg|1vDs+8O&8KhfqG%e4?gk+wt2H0EiYj0>SY zV*IE7uC-mu)L)kr|D-xxZ%<0+`PZ{<{VmjAuD{oRyG$ALG2=h|cdhMOrvAF5_$Sql zdV5kj&%d5^>u;g{a{ayj+ht7)Yuvc8k7mZdMq}f^#*s!|2yEN{6GjC_1e%eWjXn)E z`aN^CwEZLNAFb@(AG3RH)Arnt1#R-S?z=Q?{kEsJJ&N?v`yZ)UPd^{+MuX?Svsl7p zQuvR!FYs?ut)bX^BCV^A2cy+lUn!=6OT!(aZ9JvTfx78EDGOzvExp+6aRW zZ=bOKJLdL8X{^1`KwI>zOWU2mYw1URzv%R3J;jM?Jv5u!y4H;-2PqXH`qS6B(O@-b z{^sDO;QY;Os{fBa`lj(0OtafT5g%!Z9so_GrM{4tBk?69{-SA4MpDdZokMZLXSBYq zdIr9`z+Vo{T<4{D7FXJe74!ol-<&oknPYW^BEV3IEzvsKR-Qv4{SY6L1Km=LTZ+In z9Ptdt!&xWU%aSQ9YCaM-z(~|<_ zH_LVjv`c0vEdlJ14GrVXDF7Sg$^wJ0}c ztY+=nEF!jh|2BzDTEzr+4(b&@JS=MH$PVq&{ccDd7%~`N?)Vtfl3HjH_GG)=fF^gZ z4w%MoWLm6!)buG>9Mn9oRY9k*c6*bq_My?^!TfiBJsJk}u_sKl+xy$?K5gyUcDso; zD3wb#SF;Q{01Y1PkTw7FLTx?u!PE>TbM0^a# zMDC8faA#Rwcpjz@QMIKrJQwp|*}_Y5=GtfCx`vfGQz%Z89@H?GZi+Lc=YP9T1bDRZ zE}i9N;fUu)(W$Tx>=L6)2)|_aK;h+)xADg3ia+tCR z?FtopD-ofn@~s00Pz+1V7t_5vFZUln@j|cFItmIXB4(!n)(Dcy;(w#2)v*iOa}=fp zD?$;<9%pk_6qP3?s^IS-J+m=00t%Kj8%>aG6;qEJBkrJJHfoyC8Q?Zx177VTMD5DA z@s$hDx0O1>XWEO4?0q7_q7uR)`2JBbMNTTAOZ-1yVZ@3HpNIJMrHEOkZ|^_tmqUj^ zD6PPp+}twTTzvs8F&!dD&7}4rw-xg$vebHNk%I4wg-=7V1knW3w}1koYaDqLPg>tt zoh_G@%=ET-RtL&b_gG)AyzW6r`<0JRKZ|+#VW}f@FRG*TEYhKQFUcXeDbG>4DLyjq zCC|~#b7&JVYuXUZ<3+a~;Xd<6;YaZ#@fC}ULKCJSmyAK73WwiEe0XR2kntn&bW)aN zcg}{tM;6LqKTo0QRY90*Mf=s+Lh6h(Y=i0xuWUuDN70E<){2s>1^-kx6I@rNM~Z_K zv1TbQud_TqF;P_@iHQhdhvV z;QVPeC3}fBE;D0%*3cotMvWggWLPo|-gu2oWMF3Tw-!yG4G9H&u;5?B%=Wz_K$>y74Ap@8~Kjd9APLc@@=9mUL9LmW;iMLp}6N4p~&Mbqx!(uiGQu0#Z> znz2OE1B^4x~8FB9u)BZeMOi0j9Ia$)B53l1HTzQzUUKz=@eA<~t}Z zX`#(tCNaT1vJ^)KwH0&`N~uWd?;SZ1t)HTBdh8GPK6D(0$_RCigXVI;v_a~e%Fs*T ziG7O<#C;r?_dqqH3Nz8FV zdz0YTx<_Gu@3c|&MwbeL{8I^qKY&xTk_#-LxjAS~Hg_YhxT4%vS${uH_``6wCW|&g zw-k3rMXi?I;r_zEdgZdT%v5Xcd<5R+AmX`*Bu;Z)+7bg$`td}Pfh+{?2H#f%FF{jY zq7);`hLYE|&cj?jXgJkzoCBz`%jWqra;!N1T$-ZBz1^^YtSoA9XXV-uem2XA2^xX* zy^0MvzrIDLF_?;&X!;>otpzkKn-$dbfc_Gqci?ral$k}2TvRmNWT&f)h};lLlnAC=FE`?)9tpyj3 zO6#B2(6dTTIfAw#7u)b0#*T|;1aSt`KL*|d#Tv(P40TlY&!1mn9a1uXAg&IF!XDT| z9mH(P2Ibbo0J+QmcrPQf(Y(EOVjrqt5i`BC2$wO(b8`a%)B(`e3((wAJ4;N=DVmov z-pW@gp}{mEU%!6sZ!A*qD`Y7PN9c3 zRr_XoCgIF1K}3ICCR={8qX7LTV+uxdl{<#2+)VB&k;;}T1FC_u%Gfzz+MN2ircNd0 zaH2$pQ??Fw+KLLo(Xv1vdR@ZPzzegcIF->_O!a^*f6#y2I)z8a_PxA1re-A4QLM6b zq7~1BbHfpVn>bJYM{A_yA57Hdt7DRD%CokjvM9#P2R!u!H6Nr%c-6|(FvB5Hvj>sL z;U&-r#1sy^Rmzf>=b^+pZeA+j^|qsGvw5Tp$3#Z9N^I-e{s6l(i{`7ygF6esA(h*% zY2DPh3CeR&)tFP1g(+IF&FlJyYj;F*EAgxxDDc$%Fe-U+Rz`B#_z6Q&ukpeE*;{Z= z04`aMlUfD!PyJu4``@hC>^}DVaIbt>oKxx?MvkPU z2TetSwwpYX)FnNSLiN<@`Ms_fS+OpGNfGk#4#|mTqdku%`n1yaJeh}=+^e9agj%~0 zy=p2*em#Tt)|FI$h~i!cJWYFE$2I09O=}{l{+dotsRx<dir*|3$MS|)4PjX3a@Whe@z%5yncMTPG3*ozJ8p|MDHhQTS;}Dz8&ggpg;Y1 z_4CkqeS12uAHTj`eLMQ~)X!H>_3NkG>z|jtzP^3^JoWw7U)I;xx2JDkKQH~bb)CLl z{do23sq=cOUr&8KJ=M3budnY%x9jJrUl)CQda9p?zO27y(E0SUF4u*xT&^R(yIh~) zcMiY5@N00{AI^yM$lRA1+rb{JP?o4SOuoB>d9x%fhb=zs2~i#P1&bHskj&esu2iqj${oGvQbN zPk-N>G!gD`*!Zl}F~d?Z`ACMoJT7enFK3ph`P-7_WuUfAwCeT=QCZ_BrzgAhSROrO z*tjvUXO7Q8dlPSXsnZY3!-fxm^OtEpusnXqh%9;>LHA>Exh&I6*}9(W1!xa=FXK&0 z7I%nlZh=GD(atZ&e4*$>Qp>0Z9oRaWA8Hv* z3e5VA&J9@~mj@4WXfc&3yAA$0E3XKvsb#)AJllm@#=DX%p8G}YH08Z|4per!TywdR z>RIMv6g}C|XPaf0MGHtJ-G~Sb+hoh^3^K)uyG7Uz+(=DE6vHp-@!;&*H zvPyX>5-d+h$-wXhTy2`r63eMW(ne&Z=QwfE;-fv=OGO`iqSdoJ1ZT(FA2Ti~3r~+( z#W}MabiTBV7g6rzl%z?V)%E=9UdEK9g`VxDmPq;Ia)!){(G)h?o?0%n>&xTnozIx` zEb6nS>$!mP1C~{Okn-ua%X0F_tn}opiXvNXWE5S0wd}07jFui6)|8)>o%;B^m#N#@ zdl}b{rgik3PjX>8^;)E7jLRCHGM3YnaVi}$bUZI-rX_KjF=5#F^pvD=nd8PtIx#tQ zTo(1ktMgIUH9gBVM=j43ekPSCoFCqqs#KOs)GMF=+wT%_JZQRI+bFf=&$NZ1BW-43 zxfPM6=($2)>|>3*R*&KrhUX#l=|i3GELRKH>aMq49$+Q=!p6PcL0tdUmb{HAb8gdK z(pLS4|K8SKf%PJODc4nLTBQ~POEUv)h3erZNL7ohiPoFfQ5@MlEj3j$4IZj$=7o0k zgo=)5bmLbprp~ys5^LxG3vXf_c)jQKGUb1MnFkl-^=9{f-W*=)=af?ZA!m&Kl7Ib{ zle+`-hk5%u?ldY*?8crMm(@bXN6u7TSyHu?hW^ zR_cke_8Ewo;45tD)PTnWcrraedu1hl5s$8QJTT5IqIX)6VNo&sXjx>NnUhD)Yl(@& zLVJb`?BBiD;IMzS=G+LZm0eJb_qx2hY)n#BsNRHN?kiMh@>+|U4%Ew@V^w1E$>RvBPOe`pK6lYbG7sQ9~+GuQ0vs`iHQqos&8~?BzB>#y@Py?w2>&-HeyVF=2hV?3LxrlRi$2Uy?CQ zwB5h(UYk-}HctOWiV?VmdkrrcY=&^-D5J$#Xbdt8!??T*V~qB`ali4b@fU+tyU94r zaMkFqRT}I*^q!dBG0Ph+H9+Qn_ImubDIBdo?l|%~!(#OKF356Jq7996j0=nAQ$!OO z^R?PAkf)4X<-gYBpwZ)*rCxVoMZS0V2NP!*5PaB(55P<`z)XgXv6(EyS}Z<3zP^5b z{{8_0fq_9m_*l3Bo~g{pyFQvPp0xb604-2!pf%JQW5iuct*zEk>w+3DTI;6`(=xO? z&8aQN;J{b4uQj6qSr-3MqPF3S^&4Q#)>XiK%1abQcae}f70difaq3_*rQ zhE^CX7hxD|$kwW~DjYYCpi$!{nxC(~Pk<%R9As)>3^p|Ue_MN`=FG>%VUK%FhSNK} z_=Sm{#i-$rD|oF9T|(h`Jf@_~iFqjb6^wFx^im9uNON&7^VR4BywZR}=O;D{BcK;1 z|DV0~^Bg?tmg^okbzyq)1eZjEhJ+9=A=Ud84vxI)nh|-`)v?)C*Ve{YUG#iSeGJrk z*^15z{hdDE2cURjkbrv_RW{yiqf#iNRv=!w;WeEtKherPT|AVE%Yd~fUd*DWmx=|w zCdsCJVn!Z|!1n3yt`A209KBGLq*a}YoB!&NVeWfIH4aLrHH2Rg>ZMd|o+`PSWvC3P zg-=xlS_fRQP`!zl2{=pzs2;;pnR;8OyB#l^vjU^$&_VoNiS$JWMQRXcU$c`3*dJC*hID2YTs5LrvdNyA66wpXM zYtOK-p?ph5OJ=WsqY`oMS(rc3j*as6>1tA^cp+|>HKaJF(q3FqjE(l>`=Dok_c%YQ z_ro!=pwN*|ZxGbotm7-O2fU`Hv257#HR~gDhI6+rZjDzib#GreO1%2SSQ_3wUXIfr z#?&QF)eHR?e%n}oV4O8O4MR_5V4UZ@U%A!YBktad_iIUR#LywDbHPEgm98{OtUe(( z<_*V~n4FRl3_($^_qWvV6k;^NJv2F^y^+$bavp1MN}e6USvd6M07+< zMBj+mh`5OOh=j-pe7hJG866oD**7vaGA=ScG9fA=DiRU3qoZP?`bNb@#YM$OB}7L= zM@B~>PJT>u-{{!rxaj!kgqVn!$e5^@XhdJ`8xtE77ZV?o&^MxQWZ$U1(S2hur&?^^ zxW4gy6JjG`BV(gtqhn)Y`(mcVxY+pEgt&;f$hfGu=(w1;z8J3>7Z)Fw5FZgA86OoN z9Ul|lH$FB#4pD6q5^#tK*nI*voq*L6KwbAF^+6tJ?5Q%qT^e%l>be7XTQ$mq-kT#o z&cx6F&R(MCH8F+&8H~INdPR7_?JUSks63(8!aT-c^b*4DSQ(n5?6M0y&bsFX=X=jX z&uA`jYU9?GUTBX2x(A>#>oq2H*z#~(9@j)|U>u|7W1v=$(cN z`KYA7Oo@#Q-t*bYg8w59Q(lat9F?o2(4QXTYZPT88u5CMCzktAIEn^cBcRqUJ zWB<4{Yj^qv^cz@Uzw@rfj;#IXf0~ke@ro;B{QVDvh4%=_d~oxYZQFP3eBy<@ulWQ9 zHE*9dD0%E7JC3})*|&9@&fNwMI&Pu0j#bx`IQHE=qw_+G$=t_OU^0YrMD%?9Neqw zF`usHuI3QGn837QOXK`o1o*Y;mz-eA^Yf2rVd-RQYcULtH;=M}n*)6PeFs~6n1lRd zO^KE^zUCm`^pv>h2GPD@egR9nj~mt7uUCsU-P<*5>7RxjBsFO58{jk2uZMp{;Lw4+ zeEL}ee8&11ER9T-s@rorjPwhrdSpiD=)pZ;2W?swzY3RQ@aU>zFd!Jyl z-_ljLnrB-YnEZVk-IYDUzr26dZvjrf(&ob#Gz)4LG||6x)h$a$m~I-{u=$Ggjy^tB zAM~~i>|`kIV`^hIE*;#laiYbr^jNQD-&XzJGu0emHZE_Rlscg5mHs{kbEc(jjB#mj zs5w7qLO@k@eESBWW`AE}uus+f%TJgan;MwrnX`O?%!Y2EGHXq=pqZ>w7I)ZTsjKltdv&&zMRefuN(_P_qd(N8`dx#6X^5599WC2h>a$uqKU zU47@1&px;R<%4g0)VM{)A-K6E&9|-Z zL|>y%%b;}gFjF7+r^Y@FgA&c{yJcC6&9k~y9kMK|HMQ|scGWc5w}pQzf68&Qd;)yh z_)PZgjZg!jW@HXiWMHVdjZdJdY8Oo5k)usj+x_~R8k+k1#{2cQEORw(Mct^ ztA3^cpLoCFenCFvfgMa!%#;1AmbYpb(852}Ty>kzdaB5`(~}{d7kN~$ zmjTV%yb5~W=azFBx*Mt4QKlXoXdpD+!=WvM%4Y$_F7b=b?T)s>{Y{;v4((7aa|jH8TWW_PC|IA zEeR3raz_5zVN2@Zn4I(rv$l*K8Ab+1G;d_EA*UFP26GofhqhA#6EU}UE3?5L zwVI{3slQ(@JlDrz1+yP=gl~Ycy&;iSH~T>nU~GdfwXLaz|hRt z0+l1w*tVa+*A!svVCaW+gRo`@Hjk~EEXbR_#z5XG9TIkGq~&(T1RS5fm-dE{=xD&k z(bX{4VDt_0%QYDN1ASABZLvLrAuiZ}Jz4?{UHuIO)FXlRN^7Ip)X3Zb(8tiwfX)n4 zdt(RuH`r+K^)na){S7D=h6-b6!(5XYla~9KKE*}A(fZOBjeb4>Mngo$NOJ_1Ert+( ze0__PG??OH#EPawOcJ%hWN2XUr5&1#2M240S37B@I}F)Y&Bu<%Vncw{m~Mm%#j&?G zS`6!rZJIPNboXl=7-ovVxnUAQ!!TTVBl@=d4B>`oY}JUqE`y<$(a&(6E*m}PWAaEm zWE;LR++)#9I7@Sg$!vI-9=na{rs08+=7omXhCOkf0j5Z7)7LP-)YW3}8;I|PWBgGs z7_v-sDREH@4;oB<&H2h23@r@7z9!47esnS|>8j#hk7IkC<6>Jz%w& za8oUszrlD3cb=wnUxWRb4c34VAHGvQMpGCrxaNxsVi?x~hk~sv@WBpn&5_$^SLiSZ zG{#sggbY3nH8=~+FvvWXIugQ+Ezz-LGFve1mTw31I+GS>j`G7-(Jd^7hS+Lj-l8Sn zuo>$NFyjjN7W-=1RTngO`xKcF8@}dGr;MtM)wcIztihGxz0xZgXucz|AI2K zHT5g%Xw=RP)3mc=t6h6*j9SsSYS*G$jM`458<3txx*MrAquO;0=`^I1&KtF6Q>tCt zk?zi}c3nWa%3kg2|C3S6FRONS{nDtls;qX!v@>a^k-ipc(yq*}cI9LF(1L2$I;0yH zR=c!5CT+t_uw%LC=4#hPr17^@yVAkOKZxzLH)%nes$Jueo8^)xJV>iHSG!Il zP2E!MYSzJ|wc1+kNF&|dDHX_wNs&*YgdIaeeq?=FRI69lO(vPcM z*+`QbV*5z7Gu5s&;Ey0Zg5~my)vg0r9()PMhcxK7YL~T(Njrfw9qF#$ zt6fz{t1ef&YLTY?f#VLx@f&Jfr?9-nSmSEc6~}L?aScWqVXkqNA~joTT$_;|LwXG9 zMxPp&*3G09`qsE2kjD7cxU!LI{xz;ONRJ~ufOK;}jq3u^qQDxLwL6Y0sK%9!G^jz1 zs|fo|53X@lVYywy8doir*R(~7<@|Oy9;6ZNaXdY6{g4hudZ+`A2kE+wI3A?gRvZt~ z_)ax0I591#bB$|Jl}S5*bUV`WE;X(rNSk%7aa}~Z6Y1{XaePRRAl16nxK1MtMY{VN zvvv~cNu;ISYg}FbG;6z%p15k(Li^OX_V`+~(?}0AvS_Jc;F0b^dKqbGc#SK+sYOeQ zz;Pix7K!6W8WdgQYS+x7HH)cnO+uR5x5ky!+@hUBT7-0CY>jIj(ulYk*V*>iUIMOX z2a8tNzs6OF^wa=s4{7Nj><_7R2(Cv*Y;RbNYb4U+NLL_Tl~jX#XwkBhv0jKpTR9wQ zcZ+ri>BXKF%{&6vrME@vno{Em3A1RsN7cACAYGABd8PZkr zz^4Ukg_XD;!A~i3laW!+`c#-Z!Iv(l9Qfv?D z9;ADa_Ma21oksfF@?b4uA-0R66vnBxDH4!-;ML>Y}5|ji|d8-7vcJ?nwQ% zVgE=cJ&gTz#qy)bmq=SZj_n~Wd;;6+hB~$u_Z{h?r;(qLo_YrPraS7f=dpjJ2VO+E zLfUR0_S3_tt=o_DjzYcm3igNPjc?$*k)At@{UJSj6!|H{sFiN61gmH~Sdn zDjNIw1p5KM<|N7=mPdYu>xXnF(nCmBe2#qG)2LlQ+7)TYDfly_laOA9J?TrFKP@BO zj%JX_Qx_Bfr6YM_P$g>y7L1EzTe59;6X5Ms4L8 z+;60p&tiK>&wU5~1AF}U$j?YOBRz&R^atddP^0!5(hJZ{JBNJP7t2TogJ1I_wuAHl z(p5;$A)N&K@t<%UNP{jQKOsGW)EtZL|AKOkRQnZrq#KcL#(L?OaDTCU;5S@9EcgE% z`7RFah|9>INJIX>{Y1JF=@Fz6f8zf1!TLy3k@o)!_YY~z72F@B=dR-Tk%s<_>l=^z z?}FdMvQ?{fwF`qCX@Br5jJ2*LEc=;iU4=-?&9$ywNLN^DUFVQa@_{}a_rb5$6@he; zKXgbhAYF$vBB0iF0I4~!)^!r;Dx`i9xF12#BfW?;A8Df|wXSmPFQ#R!>oS)2wyAXm zMdG~L*1Gn9-`uX&bp`2>_O-5&3CMreT30Pnzb>^dYa)&-y4F>SbXwn9*KVY>akVb3 zpHb_YRO?Ddx-O;GwVBe?TGwf$m(y!qq5W~6GHYFnkfv7Dy5h0Fh`Bg^q64 zGMUU_%|f<=ShH|OyuZ)$*VF6s{{4EtKBxP5I5lo~K9siKCwdP!>3REm7DJb~_d@fD zGc0n06*i6AhxUVu?Sq>ivTwFrB9Bj!x6ES5u7^ep-GxGGqTe zXGJDHw-^R^@cG4%<>1#ALzVGMo%<=Ce|<3wu{N)r`OEBsg>No~rl+c-%NIi*N4~Wf zrkVe?bFsGITu*cUMdO)RS_}vFKgF!LxNN-lG_tZ7cEn?+7ejlmbFA5~=Yvd%XTIk? z#1$6Bt-p5PFV*iii=iRuT-P`^%beiswsy{6tNmsAUFUop+>uWvf9HPK@%zOPd%64n z!(td=$FBQk-yiLho!7gESIFZHiy_U?s(IP|C;4WLJ%iT&i+kff*ICulB`} zzu6aCZd7Mn=K)9e)#t06=O*W5nR6WbyEpM+^}{6lJn#93yox6| z$#rHtpZuqNu&HL;kosY+-p&m+-C}+Au~&QX--}_2UH`G(Gwhe$Twuxb$l+qx=K$Nz zckk?H|9`Eo-y$c(UH_wah>PM#a2|07OH6Zzvy42`=Tkk_uQzfew29N~;XIpO<8$j) zM?#!q9O4G2*mc&Ckmn(HIdr!EuT|#_#n>t=ideZ|!gLbCW&XxQ})&-d8(k+O)q}9`2`|gZJ0Yo(E`W zd%N}#pNkLF&OJ_W^Fi8~f3WtqxR022jz2^@haRe(y${p=R_|Shb~Zj-JNH@Q)+4mP zO`SbbJ7+t!bK+6jIs9ntqdrd_qn#aH+S&Af+Ic{KE-g}dtacX9)6TiLc1}J{`#bzR zdc1b_JwZD=yS20ViQ3=kJ!TKLpQN3oCu`??kM=R|)l;-5+(TV)?5XOm{+x4cf10}E zHX|3fhhFu@@n;?h!^SOeTAWTC2^F?IOWnN7d>rEBvyX&H{brdHZ!s&ba!cIvoFidD ze8^pP^jYWK`m=)r&pi^xxcr0M=adG0M=4DUvNZ8{chqUj!OuuKlhnIV=n0kfx zmz{(1qrLf+N5Z;zo;%{6*V*@b<>B>5!XPJ^;YjL8*yq8Utbd{UeyjC(_;&C8xVpOF zNJz1oHXo z`H=UX;~zc}wmE#skq~{Zy2;2JyFTK)Z2hS7vEgG!LV=-OKac=Vy+DUN+CDD;{!|yPtJ0-1wY(VgB>--0$AAM?xPb zzi=d^Ir7CLVV(nDQitrGJrWMt{^cVf_5$bs%8@X@15R-JtLlmCbLx=`UsE?PbpA`# zEyus^UN}7OUfA~y_rR{p+#g%Nc_cKx$oX?Vx4FwF1k-P9C82LW9y6M^Qbyt@tFGNd|o|q;<)zrsh<&3?sw z91+LP$fJ0KbK>0htuNl=u6UqKah8#nYG*SGjPa0N6W-Si`(yK!>WSk&)Bj@kv#Boh z+hUR}KbHr_*sXo~Ds{`PU#Kf)w%nKY4c5eCS6k-;@=;MAp7$~--r*!Cey!fw_8axi z5~ClK$7}41k!|(PIZmZ_`5IQu8>DYyRYy

    >I{c{p{?&Oo{x|C~f1|qQ-oE?!nEL*^b8zrxdFRZ5 zx}0+UfA}0=!@s zl5-t!i}SZS8ft7l>u895sQ&MiqoJFvXCDn^{ga#!Px3(A&~P-&h-caLN%=bGXc*%> zH$7ixPTYL!qhVLv#VzpyYvK(yPRswfM?)`X*!W@l;)r-SdNg#1Cpa%YV2`-@Hb=v@ zc%IFlaxV5TciW?3K>Io;#6!0`8VYP^JQ`A-w{e`^-1mHuu}|CA?T>~*ZgE=s0cXUE zcd!oInyl~nC|f_{o;bk1I~@%ho)LY@M7whg)6t&#A{A4NbG&^YgSb`8fB*-N(x(r@D`Z z=$CyiJV~B;@MQPFiKiS5JDhx~d;f~|Ui;$w)9s7NXWAE=o@HNOHQ%$HhogPY!^7t~ z&z#Sb=gTXHUf{mC_d_K_vU3sLz43^KN@D)H>f_? z^eXdy-TVJ)b;QDuy661)N5dX7uQ?hz=lNReGCQoDi?7pOfBt%P_zm~`2Ipm4NV)Zc z$P35bc{H@=oO{fB!WwfNyFfb!)9&eV{VzNkid-L8e{8x)-F!>?``tft6WV!jv3B-+ zQ2V#t=cIO4KBS%PmuTl`M*D)#(T`|n^kdpNFr}SyAJ_gJdH95O#;3J&@>AZcOX~m5 z&`&)58U4PierNP!>~lv$zxE=F;`Xe5oce-(SJ>Yd_2b~|(NJaMm)-B8JbuME_RP5# z<7=E2&wtH(^8@?4^k|r4ikocsy3bGTaYlaVJl~YBdVltdtKTxexb554XOc}v?1SxG z=c0bmD?Bf|ucJr9C_9$C2i#b3Z~8S9)z^>w`)^f!iibGFF-~~CTe3g#+?xG}E8Ju3 zjC1|iy|9dxX(j2p77pn zc(2*TUiNc{BOGUjSoIY+A8CJ2}UGZgP~7Ul`9$E^>&QoaR1DY${rx zoow4Op8Xu<1gE*kMecBuO}{jrJ#0EvXjrXknIlz7HvUNke;w;Cb`8C z?s9^$e|ujUXUEUvGjc49bMjWlLXley$3nxV&#l`X3;jH3JQk*yyZy1SXxtt*c*q?# z-r-nS*IsNo7NS4*Id#`#VSt@?I~FFn!vp==?|v*aow08&dcJTE@m21(?O5pW{D29@ z?{_Q=bDR^L;*fru4>%S|9E%+bjlZz&Lyv_S?fqQj3^!O|l~wlX*ZhcMAQj)fY# zA9E}mYM)@s_tXQsw%kjXeTWyC5>K9IKjJbM#GQ|~FYy>BILR5#FvkiH^;>-6vC#8N z_x@!4*!q-Xq0HP<|x`t%-<*9;vx2kyPkh6jEd8o6z{yi{fXOOXrJt2k-gkxhFkg#y;wdfKL1{NEF`&+ zJQn7deEG4kr{652-*<0pN(w zeB-t1PTVwX-QQT}4bCf`<)FCXP3}#c;3kvYWr{T}a6!MZx5zuwZ#x#cud&Xkb93Y! z$3nAzmy9#U5_`GHlJ@wR^K84X3q0rWyPR8ljuYaccblIB@6rDc<{fwLYt<>6cKuww z$USlW{l`M5=aq}q2dkX+Jn;eJnBzX9A2j}t_Rl`%FF6*{_5Peg;pcnP$oJhR?fS@j7#C&8i<3*!m~qzn~tu$VrZV(Z0F;rDGxT zXY0?JkKbkF;6sXDyQ`(3vl z&$|Z>eM25NeVO-;8{c#f+|8-OdVj|L>RvBbhvL|`eU5OJNzXeL)U|ks8FB49@+aQC z!oGIocTqk(?>%aN;xq@@ckEc0Wn138{7w5w^VHjy&2yu3tXThd>Y-@7xbc+F0rsuB zmwokeMqMzo?*3T)zIwRH=hzSBjl(~YS1xQi7dNhwhrjdJ^3LS0_08Y=$75k$y!B`E zbNX-g;rSMOZnnRhOmV~!~nILiIa(Z$cSfI6X*K#VP3q)#J|+jEAkuOKA8^( z;(l(3XFqKGf8>#^%(IiTm&l9uR7M`oJv-9=5qae($Fxr}Q}4%FE^?7&u5;w0?x)_) z#zUW9AJcC9!c;!=ifbI>d{BU8@dOWz=JvW^l>Hcj#?6L26 z>g`UxH@fS-jO${SRTg=`O-}sL`=;M~)%ok~+!hc2#l4^9{b1*v)$NV;%lN*}C(p;} zyUvjkhuLsbK1?vdSthy2R9)kG{%L-W{LA>eIA6^;#{a7xnf;%9Hmi?Y9S;NCIO}+r zuE%E|4`oKqIUbts>U*x|YUf^5I}5ix?)zfCKY6?3A$m9ay8ZFc%h5X=593_C>0ny8SzZ_@vzImC)%IS&lFpE@TB9Rhmj}S4|h5IQ14fd zag030emKMf*4X|qd3~z>+~g!jo_0Ls8SS-BJ!a=U<%zwVWRlYy;VdUO_H^@ep1YiS z#_8L*vb{ zJBN>l#AB@UI{ReX8;*w^PQKCpyX^N(&dG(5ykaCgT1 zZ1|km^oz$sj*&0P8>i{_l_DLp$9>Pw`s^1^%~?;J?mXOM<2TIv4Ebd*H#o|!%e;S_Vwnd#VBa_G`|xh&_rM9JxyPCM^AqyU9Gxxzh&S-DhG%p)|?!A1r&jTjeca_hP`aDcC%_%N&QhUoU zyk8t)l?QBnj?e8a?+0f&#(mB)`AZr<$qn(q)jn^;HC7q>mAtadhCX#tkxxc{;~Y;` zpB!QTHTL0omGk13ZTqPAyH1(D6d&y7h@L#OZTSgegwk_CzRg>UJl>0cUQn{YC2R zjwix8W6dW**MPdc>xnSQ3FbL|_YoShD$DRlqj6BYHjO*n#2e{8+`gPC97^6x1c>IZwVC;#`#i1VgV&<7ALfgySPvS&q z(SL$noMwV^9ON#O`emPEU!3kg5vq*6^hAii+`Ti!>Ewx!)_;pLY!>1*O;HPue1MN^RkWYuRjsGnPOFY_08^g&^g~~U!LbUF3!L0 zL>R008&wxvV4nNjWY^nIggy2$;&V5{R&FrP$#(jHZ0veapP8 zGR4Vn%TGOKnd=MkVtkE}^Zk7Lj=JU$W1L}k{rPuK_+F>`R$h2 z9DC1R3VSR!FZsO}`Mvv+?>l;b?za>+*?s?|(D)AT&jXf1lBJHNkmLL#mcq3CRCy@w zdh}B0eW$uSZz(Kz-WAs_u0CNYY;)tOOQGy})6u@rX2qZ}2_J$uRbT78}{ zFU~)ADb%?B{H4(9d9;5i#M#I03!LYL_R0Q%rLfM@i;aJmd0)B|65Qhi+h4X6ikx`4 z_IJC#R~XNhS1pAs*I&C7_Bs7V&(rSb&Bn3%R{LekJD0+MbqCq-9{t|66#Cfx9{cuu zf-~a6g-c;de8_6OeR?Uheb_vVzgPQ=dBnxfE`_u>{(0+*3oNrg>%81!>=N}gs~fbH|IF3y?x1f#WUOz&la5TeeRWA96h-dQk>&BXP4az zt2|);igR70UO8)?iK2O!KeZHEKC1onQW#>ju6`q{&dXU&dmdSn2bLK5n9q+h_Q!pW zbK-l>%PsD4X5GG~+y{p_{(bqb$K0sLKQPb7#q8qv5ADAmbCwN1vOf;9@e|JXWBKLA zPprrOpDu+0yME?;Y`9AMC;dC~7xK^6E$<0qzf}M1yxKiXd*6QL9@tY^3Uki4$xROZ z+J4^eJnUruZ`2ECInFBQd3cTbVsd*aG*8IOwM(I&1-4%7=lpNY&xY&VD+`=qaz}pH z_&e_%7ufg#`}n={^MHfQ{b4Cga&Xss%%(re14}&Q(Dh59{e#YVgZF@Wj&YzWZ*2IJ zd#^v|Uj6x>?Q_!n9Cz-*p7%^V{#WC;$+GA3e{=p%nfFHXcs|4uTlekH^AYZew>T{B zzR7*E>+kaVA^T&TlQ*kVR=J}+exUu+#<7Qqe^{3t|8zerv%>Vh%x7GVji0gZE%M62 zf6E_x{-bWVeW+e%tqP$kPM%c=bK;J33SpnSZ2zitZ(RrjT;L=d z&n<*J=ef&H zPUhzj7d_8%o6UFD|LZ=#xmfRamqO?fPjQ4>oab<}{v5e$Aw=iZ|J|(1%H8GHxLk{T zeqKJ<%f@>Y!m#%EJeu!%b@DCycts&BF!O5XVfK9c&~KaLY#*q)@^9P#H^hk_oIF;7Yd=|dFM%W!XECkpABE~^M-BQ zTDG44g;NFJyOQ@+c|GQHZq2^5Z*!C_XXMrM)c4$zc!3Knvc$-`b=bsx4scHY><_#L zO#eup^WNJZdw*E^sXVfG)A?rII~$JcceQ+piyRPdU*o+Iw{5FWao2C%qd3i~xZ{uZ zFOGAXJIr&BWlmr3p1H;7m%Uee=3|~iocX)DIl-IVKlcs_Vb=4`e-uK2J>1|Vt6cx5 z`Sn|@nQuv+ZgH-!SeLy# zFi)O?ta6mCw=pmK8Ci2Lw?7%O;u8DC2hAtLg1FWK~C zQ;%&YL$CI2c8VMCZ#;V+U_FktpA1DVKJa81*KguMCqsdGR=CRpR$?bZbVXhtax%2C z@u4R})wo@@ue+y*nU^yiC&Mg99&S809&s|nzVE!9CqtTpk2)FFnSHeRejqQ8IT`vG z|G$%Anlq0*8Me58o_$-VJAN{ZFvA&ESmgZUPKK5rI{)KOh9vV(kbh>o?MwS1n~FY1 zpLjCF+4Q87A;mFP^lN>Fyp@eloD5?eeU|mLH$Ph*#bbTW&FJ&&<45k{1?Fe^h4Rkf z7u)xbo$n>iV_f{DC&PreoKj!xc&BxL;(biZGs_pMTW*cppZ-JdQ?I9-gE7Y5Z+{$N z%Z77*Kt4J6L3QT&9OuP-8T%7Yb6=dCk`M7LE8O7$_ZdB{?mzCn*vsypI_D>xmz|$c zhisUYrz@TJEAq&VZ&-)PZ`!|cvmD?8Q{3kyBRS{Puj6w2{h53&YG?JhdgaiP{js?q zZ~7-0+mz3f=3{JGKhHWz#J2wRn33OTzt;Q45q2A&WhqEFf07R#uf1Lx#iq_RFE0^fSKm z@ACIc&)Lbu&DLed!O5^&@BdHtc^z-D&wBfRjulI|4!MQwdztwVR*-@uwEr$WN zH7ti|#?D<1yPUk;a_IY=bKP+{WEj8ea@b(YeU^Ry#Qi>CIgGL^wj2ta?pO{TS3B>+ zmqXhh)X}4sLzfcanAlYxPh1X>Uzv{u@l4OM?`hfp zQ|Nh-ed5S7mP1_J$Ucs9lo?L4`g{h@ z4qboJ|IN!`obzv4_Wdj8coAFY=OhPR_o^c-Agl z4keCWv>Y1utv-QKvq4}@!mRSx%T>RK_Sm3}X?310JS`NK`bG{k(!OZ8J zi_>3le>cj{taUj0W%*}fZaGBv?fX*aaIPv7;>nWya*ykrJ+mAR*!ctfZgO6ZaO8*b z#{+J2zbrq0H{XwzLqC&0Sq?Mo-dGNs9RBHYXu8?FS8C_n&(t3iKUaTjzsi0N+}|(k zgCiW|0n;4ZG9SwDWs#lS{Pl7eW|e71ej^WOH$;ZG#R}_xDX; zw_ocVZ2awV$a~(+L-7pD;<@XVLzSC5_VX`!`Mr5L{Ri(iH+PrA7@Mw_A9mcJ{hWqK zs%jqbK3i(e@hA1j^*?)`*m&Ulto_6Jnf{mj-QwQ|x2Pj_{YRad=kR~dDJ};4uG_E@ zI{)qczV%8N;Y@TT%rk%6m9WdL#+A_iAJ6Zw5*CcF+<7Goi!045VUD%Ct%NO3++!s) zAG*(bt%Lz4@3RtSIMb$``}f!WU+X+@B_tS+t%M9m9=hUtJMQ!0E1~Is?)#A|p`VkF zS_#u!e~fk>bghI)P*;z&U-q515{5V)*N^j$TL~rhJaHu)a`Z_np~D}|n|tz#@7**+ zHhWflud5+4@{E-*B_4aGeTo~OwGtLN+h@GzThG_;+=fWk3syps#TTuFS+>4-CG2tJ zr7IyGZHVl?Y9&l^eaOCU<-ZDW{)+GCG(`Fs=QIo2r-xTU!)+QO&2O?Evu~sJZH}^S z)P6Y39CMu4Z~UDrVV_eMIPYy6A}trLgbB`1tb}#_s@!46#m>u7ww%=v$#YY`{Ymld z{Bi0_oP)(rnxC`TmC&W%4*S{u1^3PrGhARzzs4`Ggx*Hy{;G3w>r(S_=NtA{A9tC2 z)yHwWK8`i+v-$Q7k%Pv*Gvl$2hm@^IR`q;$1e}#XL7S7h~+;5M!(7EkA$v-iT8-Tc3HRJm2FCyARxFef&S%vpD)s_0Raf z+{1m;Tg`jSxm&Ey?SH$^X7m2X{cwj|%je4%2VQHw2iWK9i($(6xi=KUdVN0b)aOeT!y!l5au1&~ z>|lurZgSN4!kdes!em-L+U4ba#W2R&Me@g%51NP5lf@8!p!eiM_G5g8qvDmogK%uv&7CvHTeH+<%ju#{P5tU`{3Y;_D366lo!TM%L6A?i(!wuCG}!I zwKMkr82SF5eRH2v>|eJY7rDpU_tla9oj+6uUFx!23m)By)}?2GZ=*%y0$Z~qThhfK2J59%Q9`ED_c zh_jsL0_S<~NACes*E_#{TTF4_2KnYL8y?|(sG64@EPKBGC;NDupKE_J&hys&qVMNf z=kMlc=fCWiO^4pE$NL-))~|cJQ=!1*y-$Vc6a0Iv?Nk_IEp{rD8GFL1(9*4bpLHsv znCR1=js2%W!xMe34(QL(cby6o*3EN4Tz&7UFk9c>g{SK#~3|! zDr6YrEE8O0itEg1vk{M>1;{wYp zvC1t*m)$>OJY<4R&oG|t%rMRz`&i}>s~lr=#r-qJSthv16xW$yg*ooA%*Zp1XEUQk z_sW)?eJ0qDP|s{(iXBX|hZznq%M^1QXMxi! zbDk9zSmg$5++pstd7s5q`(=T{EHljtr*Ys@oRvR}4vn=$S)&W2~(H(Quw2UF}} zngh%*#Vp5}<1`DLXL?PZnPKEP`mvcg##mrC%j{=`!>lsR8mAaNW8Z9Ho-vjg=Qb1E zXOazl_Q@8e*})8ZnB@R-OtHXmmO0G|=UHWeHEuBaJ$Yse4;W+gxz=YZ6YOM?y-YF5 zG)I`>1hbrBjyV=sWSN_+aF$8Pvb}+*pW;wtdQ!H?tWlpogc~)6q zjT?;q(EYQ82aGZLLhG}Y33f8cUZ$92nj_3`f?3Wm#~ceRvdm3ZxXUVQtg-P$)-St% zwy=vaCK%@+6C7odlT0zoG#8j*iCJzj$0`dvWSLC^)@M7bjI+i*Mt|h~*}^f#m|>i= zOmLAYZZgAtX4&v!>#>CecCgGIRye>aQ><~E(I2}Hws4*?78vIS6Wn2v2TU>g66a+r zGwfuRz05Jm0!LWp1S_0jl{wZ}Wb`M_!4~c^#v0>ne5v)>#w5F#VuEQ7GQ&}3ImsNe zEO3EkmRR8ytE{rdLq<2;N7DLiXN+;CImir0ndKyN%(B1*mRVwjTdcCm8V?!$srg@K zezr5lIOFVNnHg3%%PJRH<2s{PdcWDiJ;oS$x$$gff-xr9%@q5Y<}fo%Gs`LFIL89> zEVIlCw^`*rYixLh^?#8(V~mkk zTc6ELFvcXinPNZF9A<`TW;w+i=U8B#(O;OKE!<;_ksgG~NP z-7&=iV-@Flt@YT<1Y=CHn<@4)&0%JkW|mXTagGJ%nfSH+Gs%Wwf8U3w$VGFkz<38hTc!P7Yg*kS!z!5_Ati*mN~`>Gpur!H7+vxd*@&aD~xfEaYo*3T{bhx z7*p(Kn*Gdhm|3Qo;}i>=W0`qYSZ0;mtZ|>wKRCyT_1VH0I~ZpV6C7ZUsrvI>pR+8p z#N;3CmsPgB#lEihInC$|-d|=p%UIR=EbxGdKdH;N+86tn`m_DB#(8G`;&YoVd+L}u z#@=TAzuFJWoM7^AK8IOlh3OleXVm)per_)-5inKceG zbKw18%Rl@aVT_whaF;38m|^2P?2m0Mvx`+G82zX98RIAuoMehwX1Kr{ODuDXRaP1O zm-92mrgu6&+nHpXY4$P8Ar?5sGBd1lmeHDeV~p#Jv%)0zn5O?&g1_&s-k4*IWp=a5 ze%3h5mRsBxaGqrr zSm6e%++mFeZ26CWN4(2<*~$bvnPe|hOft<8W;nqtXP9G-1r}N6Cac_K^w9k?#>RJ> zpKVOBiy0=ErAu4EcaMoDadtAv zUZ$C3mLtq@f(6d7%p5B$vdT@?xXb9-r$db`Y#f(owlU5wCYWH7gG_OhX-+c3EVEo- zjwL3~F)yR%+VA`9Cn^t2-S%{tV@u=dP+|G@r$f_4=DVYH7`v1GvvOy7VWwHW8Nb`< z5PQG<-~DtLV)h=^W#V4W!&<96O<4av^3P=3X@4i$`u9H_7Fl?}=}=|rfzEfa^&c#6 zEXUjj(+@oz%8YfK4v`O7|KX=YoS8>DFXNArM^+#0ewgiY?;o`OV^4>E*3LT}GR!^B z`I&rz^E3KH=btp+lTQ1+5bZtA#q?88heIZM?e|0W^9=c9^_lj;!n54Rhpqn{^E3He z_sQ7v<&Cv|^>B&(zfeAy9Z*k9y~H^gPpZd^^YeUs%K8_m zM@HW*|E#3dGjs2i*N)XvbeLs%%6%~ViPNEd+WOP#jPXyaM@DDV4=bNl&!4jX=hX$%U+_LK@g?{DY3qO4 z`^4&3+#_>y_Qmw2_VpS4=Ix6um)RGq-?T3lF1N24`~0?jG4&n$V&V$>V(f^0ebzpX z*%zyM`(pWoeKB2dPoL9oSvxB$?va^O#xuU^otCOt#{?PuI z{E<3h^e6Vu!iG9y>PmV4g8gr*LzaK;UYP#H>9EJxFWuW0t$+3DFw9KFy)ynApL?uc z#%`U~R|e7IVK>H?!8?l}AReS63|DAkR$wN!_vKFYe*X*56Z?O#e+j z7~5C3tlT7DU$Oqp>YDL?$S14+RQJr* z)@m4Ms$n%0*mCRDaKQ4ptA5YO`nOpPBaGc{HRM=nT=n;vt$&Br&~~Zyn^waht9M!r zS!VCD8n&3Z>uPBEy770{&eT0t!yJ?MGM55hS@$ukq4}Hqztxbed){i8t^2suuv7O5 ztA3w{Ph9nPm-*z?uu%6Yt6{(H(^f;*<$U^TNY{Pls=vR?XRU_FxA>gZ&|CMpt07bO z`Kw{0?h95!)3^De)i6-^#qv@2rK@4P?#twB!MR^yU8Y{?yv)3MHPo0p-+g>X-d}58 zR$u2ljHcxAyT-q1H4HH^;vSfKtNk)FDo^YoJXv4vHY@Say6_o@!{3bc+|aRoP)WK${#CJ?v2q;u7-|d?(I{nVT`HI z$PcrhbuW4Ae}2{90k-}ZR>L$Cv#b8zulBDv|8eoxoS(I?J3n)mIX{z^JO2suFE~F7 z-*tYbjyV64{pFpX)+tLVdYQi z)*B%hFESag&fm&EQNi>?pzA-HS0H*{M}XS-@O#djNh{qn$B3iwG@)f-nZoUKdgWM zlD}JO{q~aI_ptthOCinVLrbB==)+4Px^DePmO?*Mk1mBQTmG*Uc33{Iin!tIX^3(bbb~-?fh5D=VzUt>8$fJ z`6cK7nekt7ezttg`C0qA^Rsf9^KTk|x$`r-;QUNq;rvV7tZ-3=VxN06gHUrSt&Gcd45$X3^M)8QkZ9^QVM&lTvG~N zzx4dNQW$5;A4*}J{jC&cS-GhccA5D{DRlhG{I`_C7-Rn}g(7Q_ zwa`#8zF{r&F&AA6S!Np7!fyR}(^}~KwR^kkS{P^I9&4e@%)Qq_^KZ1@Z_V#HXn)X} zzqe|>hphQ~tJ)v27J9F-&STcX6wBwWg)OGK*Fx*I`|nu`DHfi-=JylyfA(6aG5P$p z&~vSP4y=Vqw!F-G_4rk5q2;$6UJE0vy>ZR&A((%3Ekv%9*9+{QHI6g-uC*}D!h6<2 zg=Oxs!pM$&ymu{haN@$XFu@tlaJ}yDd@p9)zQm31GoCr_dOmWI@yxK5`;7fwzX|89 zw{wKii`PQh^9`1`%PkIlU@b)d;GWpZDRy$}gKJ@!iAnqBAm_Qx5;s1q|E}*FUE-V^ z`IvTge{#*=kM+G3HvG}|YS_YsY5mytDf?iV4cD9Z)AGQk&pJPcIKV11T>t!<-#gGh zyB6X%`2NzD z$IZ>PP~`N_)l1#0*TUG}toti@;B-ZPIk0U#^A7E<`TMT?qdMB>^=n~}Q+w*L?qBVL z1N+v$Nxp8fKmBuzi+lbq-^_4^12?NzHXp2oroa2X7zfz;PwR8BW?x+Yue!Tg-Tu#d zoDasc+;ApTIC+~hp=_Pj+nx!F2fjCTyEEZ{ZH;IA-B;(lk7P-$&Hs9w=X!@7;vh7Uh<^KK8 zgh{qP&_3A1Z7#B*X8&wqg&o{u4eq-urnde-i|Y&z?O%f2~{>c@=Q2ntn*ChzQy;wm}2BnXZ+n(?=2TO_-OlM!(-0) z`=;uRMeei7y6N-IgnjW)-19^A_c(cE>*KA@BoDaH_WwHP6V8M|rn{}@`8emqlTSPo z#_Ro`bSA|9CvQ(a6NWg@x^Un>&?s98_xJ1{y7m}APKE!`R`?q*suAbZ*`yIHWnG z!S1)6@%L{1_pQ0jiBbF0Z<@Qzv&IcJp6$Qy&8Bnw_paZ5Cd9eOQMSBOo;kxd{bt$4 zeJ0s3=Dyi?fjqIq4IZ+}-gnXXk$2nwt?er<4=lb%J=xdnd(VVv@ji>}AGbelUnC#? zyW``u5d=jMR?hd!U%&6X z?|IL8&U2pg_WDG!p0V%DUa5XK`El_ZcbQe~?W@FnUvYjyyj92@N$? znVQmez5Qx&aEl!eFwSS>>3;G&EiP_yfa9MvKWCU{&*#)TD{Q#`2@SKK_dEx))?u8! zFN#BZoMT+z3^%#Vo}B$>hpo}${}`t<#yj^E1s{KS9|Ph>YVel*6(_O zy&SmC`Qij~oMFd<)XCRx52Kv_hV`psDK+~%z7P2Uo?_9VBpOLNY_ zL+rXqA^bie!C>W)cHyWaU7{n>Goy79a4kp=7UeDr4Z$}Z0Mefa1t-hZqz;&{f<;OTx_Ob1dI9;!?^<;H< zSiaa@Qg6(2k-h8IcghJ3yX@l7arf)(4g1W&JLRp_Isd8mFMR+kG&9OQX72LbqvY{t z@~GX)5$%zm+js3{&TF^cEx+1hzq~yxohptk=cY}*|4+P3{7T(&m^l_$V38$maf_90 z^E^g8zqKCDa)Mi2f9wf9r!3#vV-@-06!%=8{JnbAj{HHM9%mj7aqf@miN&fs={N9a z=YqAr+#a&rx8uFY6nFF+V`IB<8RZ;1SY$Uh+0PxO*!WlHime=fg6BBT#=lt)H#p_~ z{NL^C6V>^yb!+E1pxyLO>(}07jf7tgV>pp3J802`wbIfvq@%!!% z<4=|c&a?IY`~5z;b+B2xqiKKWWcC4`XMsDMeV{m=BF^UhVUasbG4f#dxxuy$>w3uk z(C}3C$WBf^bblDCx7q1_Q;T@n#sQ`twm(d9lZ)(rxOnxCK4O2^W+Y12yEybTb^6Ht zVUyF`;{uycbH3UCbm!#c{UO8FQ}&0L>zyoU&$YU*y~GqFkKP}09AlB2tm(JYCcoM( zkJ%qu_Q@CfpK(G%bG!JpJ2|J_^hDRS_i>c{Y<#BtJ$Zka*6!m1M>*hn;;H+?hIWbz z^?s+BN4u9T<{f4y3vBLmuAeR*ET(IBw`r5Ax?bq}5AKo8E zID3(OVb_TGyVTbu`$LlJm#JH(-X%XAd(ZyR@dE2l%QM^FD=+MLpXXjCPh;wh^GtK( z{hnw11M<)A4~k#^er_|#8q4GM$KB$m#OTRyKW99@xqr z#yP;~71qs;E7b!BKEB`o?!dU;RL^X=LEJC$-n?nQ?<+Mf2U)sVU2&ax?%ZO3*?pUH z@e=#}1LLxVbKLo%ymFVj?ESI)_Q>mgaj<_?9kBDDI5>I4{=8J&$K~_o_Wut1pk4mS ze&36!4u5JM*L#0%-P*Hvi$lBc%l$r|E3W?&kM`8I_dvopzfn(|;vlmeYD{@>eACRyXoAMD2~<%2zJsj3Gq z{l)u%xxbo^<-dvlRqpRP-;DiR9ddln{&0fLz2ab;TkPdF2N@0W%2qBg!%g-G1U3mkZmaX8E7 z*BiHaIrMYigO`2JuD^#|XZ)edq2&$YXW95uEz5ql*!$&S%c0x#*@rKOgmzza+3y!y z|0&C1g5#~rp}^@!Er%VZ9=#lz>T#XA?E8e(9fw%tlyNp6v+VnOwI8Qnzx6zRIV8FM z#N{x<;*-S7g{Lh0ysSES>ayPjmgm!~lfC;q_a^Z^!#dd3xg2urdiHXta4s%CZx+w< z9s-%MVx9IEx}@30?diswT0@pk!TUVC&{JZ!$m zID^J#KZh9 zp6h>~{bKj~mqUh)bN5rrVT+MZtK%W-pO!b4u5q7aJJ;Et z^NhzfM!z9%^>$u=4t{GnEHZwB__+0L`*^;(yh;Ap$1Iy~RnHS^W4uiNhny;trK zH}^KgUH4Aw<8;}%_^5b(Zk%E7wasOpEA#v>wl+lf9*Q=wq57sZ^g^jiu_$9 zzTX>%BY#vMZ1|JsE>;ga=H=wy?I(BsA@7{4$-{^|-D983KN;+wcJ5vW!oH8G_sD@T z&TR96uH34}@usM-PM@ww-do?+hF7RQE4cPmeheGTdoD;By7`=}8Ad zS$nzTK!{yd|96u6+>}zIR|{6%DH%+@j3GX<8$OC2g0y%Vy|-lUCzgA zjHli3mIEQH-7#<=R2V(;KY`&}P)4%lN;=kp? z^@TnA@&Wt(KXEYAuo8;gz4uCJ`k;AESP5JD&)#pv=P%Uv16O>{s`(zg66U$kvJ%p+ z&p%=%)U-<{uY_gog;Q5T_qhI#SqT}AJaHwgbKjF!Li9u43r|}KgN!|WCCsw)%$3mc z3F~{#N*H46^H+TDsychYN?6d|dHIU(UG?vUSFD6dMtWC#uEW0@-zZ+~#iY2j^Jlov z*0-$q-c|MR)|D{A0Zwp_%kGy3R>Goo@omPLaPHr3y`NHdXRd@U?ViDv(5Jo0QSJO$ zD`AdZXRm~D*OTWMhtZ*xu*Y$BPC1|F$_E$DGk)FkjeoWLrL4#E8yBpEea_eDJ61x% z^|1?ALP|T&aqY!-u7s(q_C?mMU1pI(7q9p{iTGJ`e`rMe8g0g1@3_Rc+OwC6mqV9{ zmnHVPKQwB7?T&ZZ$1kY2cgu(C(f6!`0^2UP4$i;V`adIoAFx0A4UJom_VPzoLSB34 zij`31=2hnVqH{SVPWNMFXBlHU<8b2qD(FNxz;`^&Z;uK1or@!oEIUpC%~ z=UF`@|DO~0VRfuMc1*ss7w-@!mp9~zrJuOZy*tJGd2yE2FOzo}pP8Sngc%lou8!G$ zxBT0O{$I!gCw?hkoZIr;wf;{3Y9)+u-*2pw$=}H@JO5z*8CKor(x2UD(_iJ4Lw{ch z9ba+o|LHzEYwok}KjLF{ZzZ&TRs8=`pN!mVHB55wKC7Wz_k>lS9}&+@_gxJ+ z4&8s%?|aMJ16D(P*12k44QWn4WHl@>*RmQmziFM1SoJv)`+xFk=()~$Y+d#H-r{`p zs?U*F-(yxo^Vgl5$E}8LENiIEiHDtN`{ME3{@(Wi($MyF6MXOvv|g8sBw!;bJqEm)evLPTUUL4gafN#j_q#~FUQ_4FD$d=27gD+)SpxA;x7Bx zIk*~z>ercOk&~=(mVIZfh5~!ek^dX5cgQ+eInO#+JbyJzvFjb?t+(H~>UX~7^P<(z z_HFOOk<~E3J!ZLhseG_))ctw;`7ZZadAIwla*hMK?z74q8@}Vc!xk=HF3&8D zsROosP@Qm$HBPbRyY+tuikI0BSublJQ4buQFy2k-^P{U_9~-Zb|GF7@V9S-(!;z1R zmo+vlSO;4eyGlMe&mI<;HGGbos3;?US>JL z$T#gP+rPEycck5CHOmmM5Y%W+22f4@Ot?Gjnb}#A2el~yKxn&2(nBWu#ILlEMxXBGR-6n4wWc0`O zjomD;pOHo5FvVFe{lI=R`Xl>tyY;YxtxNL9B*z*1vADU&E%x88|9l`<&wvqX(Uv1M++` zqg_~A^|>N-eZ+av-aWb++E?Y{xOiCMjQc}(s2A-bcUfYj=sw%IZ$tZ_{Qbmwv^O}) z<~!8|d%4UJZgG)G{g;1gJ#4zmezNyxomXp%BI8K+w5eG z2`=0%|J-4Y$zRyFd5v*G`&n~f|p!YZ5CuqHojVGCo7vWu-mfN(N1z(yRc*Y4bT0}I#^+rQ-2p9dv@*bo$Bcy`u#*bG0tZ8vW0_;a+Iyi zu#>awn9Y$BKNq(u@j4-<>$sdNq^=aTntT{>WOVEvzvv76n)N3{vT>yW;tK? zVfx)|JoYp8aQ&F#7&Dw=mb1*WzyeDwa*Ji|vckwOwlVcaEt@2FvEDKdST+(>f$%n@tk7l<0OX|kBfsP z?y~Y+_kU|0&$nIFFXOM3hd=W5#$)o$&LLBrVw$teu)r)!%yWx1HdO6PvKTrz z$8ILiQ1{GpimA8AJDc8G42^#h4?9_WyLjuKX?!LIi=oQsS?ci5+DtHZw*0cl9Lt=q zJ7oU9nD2ab%7K)1vA`Ktxy%~N?7G1COtX2%y4cQ5CK!E({p2u5*mR+NVV0YW4|{L@ zRedqR+{MK($vkHmxkSCNc&YvSn{|#FhnaLSEU@Wv`@|Uc>et!!ckTCyn@LV_lCw;W z$qNhb_a4|a{s;7Daa^2CeaN|C(?^{f);L#hUm;#ruacL4i1$;@1!Gsc&)VmTVTXm! zJ3s$4?ib~WF_xL+9y4tFmwe?s&+?bV#n{*6ucjZ{nP!|>_HvQK+~hbboMw%AW@gn7 zv)pBlk$=l0TUp>f7TLoxlWe_Co*3s8Gn{4W>+)2;{tflX3b$Cy8=sNuy)XV_e;H%^ zo6a34Im#?Eb-!z0?-2(FS>Pzk%&^8hV>cB;k?{rRiwQRE$p_n*Vkgr~u)qPvZ&nZW z>zrVQS(aE}nI%@Z#mFt{`@i;+EsQe8R(3JT0am{!4=fj)um8#at9lT5Me zHg#HWbD0%xv-|_&1@rvKdYNaAWzN^HFX_)1%S^JyBHJ2HY)JmtI+^7#TW?oqEVIH2 z_ZZ!;ZtiuW@2yfdOft?gQyg0sAM;$OUuThp1M+b16B|lwVTCcqR>aK|`xsrdPmC13 zZ`j3crjNLOpA#G6>&9t3(f6VlhiS%`VHX$K#|noya7-Rp;|62Lt%oV@F>!}HpWt~8 za+0Gga=Pw@`PqA?Je_DgKeb;>l*PjW7g%MH(Yu^m_Hu_wHlAcYMww;@^Xz7s{q^fV zGahryvB*Vcer~-HZMLw+IOChnDVy$go><@<=YC;+R=C6HFU@~n@iNLJJD6fO^XzAZ zsrvmb??Yxe$HcGX^?t_X0E--Bl~WwvR_FEmzj0pfZ@k}G2h$bjj1?9c`Mta|$~`9k zU>!}?|3~>|r0O|ta-M}hsZ&;1W%1AU`2phoo4;>NbCSKg>Y4*A*YC5+;eUDmJkUDW z!vd3Bg&&Ws(`Dm}8pr%y5}mmRV$#@e>b*rWXC##>z?7!5YUHi5v`5 zjNMnihpCtQ9SjK;ImX`m9}ET7nmqq-`F+5_(9asD7;P5+BaF{|OtXja2g?VCIm`;j z8GDF)FvUE_xX3KmS>`sI9(pj;7-dt`b8KUcee7+K4bc5ySoAr3RmG$)zk4D(!IiA9#V$vy5c^7w^74Q=|dg%!pad$RR2 z$v$Q|#3Iv-JjMDM+KHpRBtm^Z$H)kbCWez z+4NZR?o%%;bBn2`i~Di*`ja%R2^<$Lj=UQLA%_N7P=ehcI=9u9;V_oX;3ED4k9vJKP z{1fG`$G)?`c^0|MGRus-RQ&8>L(Dm33zLj7!!9nek5vva{xbW=GG|#~fqN`5^9tiV zNxs;^0%I(*i^*5Y1GAi|UuUU){Z-cgWY@WmWe%|PTIZ6fK5;Yh#)F~tDe}dA%qQLF zz+3Gn%V!zCLtM|qy^Omc*2PB6=C{raeL&V1T?=b7^OUhgXw-{-x{!kGH+)PBFeV~mXJ z&kFY#`>^Mp<$XS3e3m)G!bhF^x>v~Kv(1#JkN8V z3FevNBF9+f6f2x%@~hU(&9AA8=Zo(;?-j;5&J1Vk=Dp{-#B;s#!^#cjW9mlnzQA?% zvE$qJlLJgM#mV}8t}`+(kBqX$7@J;bKDIHzP9~XPks~Z~f)!>N`Hu6%D3=)H2D@0{ zCfiQepPj5R!Qt;3k9khi?=#EjO~zxAOU!bE=>_%Ot>4Y^!Ne{4vBoMR-&5Bw@;qA@ zV~lZjF~L42Im8sxOmmVM&M?ab=2>Kcn@kks=f$358`JD$h6xrpzzRngzt#TM?{l8% zMfqm(NA~F@>XaQUvYV+N`}@x5es#jwis$McJm`DJjd$4nx+QsH`l$TY+jppwmwKLQ zW|?J)1;)zq@G|@MOYv}V%X@&e|5I+R~nu*(c1uarl|82OWZU@!Yv;Se)_F&~?D?C-1iH}$~G-@Vs* z<#ktnx%dz9F!E3Lnc*zUHT&{vdHA>Y9%KJ8F3U_ae~~-e%9Sor%UnK9?+SoMHY%*ZahG(xEWUNaRqMX7YZA!g{^kbSN~v zPTn4HD73M_PNp7coVpJ>6y}(1KID6k)x$%K_j>WQxX;+b4uyGUxL$8R{7~4b-)G|+ zv>$OOba9x2Ommcp=%J9WU*{sTT<0RU8GrPl5bGBY2N^llx|wJ{6qXo&!XclF_S{nr zg$-sp4~6bG8UI;_!VvRJGx2QkG5*{`A@XMHe4cnXzyant#zNPjP~sk|ES`QS>`Ut3 zeJCV3#tc(0KIHpz^<&2w?!QVNSm_lPBd-<@bFVoRqHoc^Py8I_C=1Lo@;d9T-)Dub zueXnH6)!uPWP*8)u)qmM-e5h9a+xufndV;oe!sW}+-DDCOmdTBtZ<6CHy-jiYwKi@ ziKKkLO`Pmvo_(C-5OZgUn?=sC@RmcN#`M4;-y`e#+lw zA_o~cM?Tog471F!z(tn1$r|?<9XjOm+xC%NOmcu}jx)k<6f-QRte;&MSPzSgo$bB!4*i(EP`;Rar~PI0BIkfz7wdP9_(u+fVOB1+FC2T9 z`Rdox_F>5L?~^YkKIA!OC*&&wZ^S?gov8uK&qMRC7F z-Q3u`~Jzl<)+`^DCAK)tcd9E&T?FC#_qF?rDQBl;hf zhq`O_f#sv-WB!=?m$-hX{4#l$>+ITe{Zj3_&CBAJ^)US_`^S!L@4w6B=eP1#w<0b^ z|6qQm|9HsvSIYmNI>m0n> zy#MfiV4MR?aHQ_Py!Y$ZYu-ckHY+Ur+jH+RF88s_9#)uSjl+!m$NsR1(~L6D7#A7m zIuqPx`X1w^wf7E%es=sF86n;;c!SWdauJ_gmF%=i&-W($0V1S z=QeAMyjOhpJ{(#Z>PJP+^vPj71KI-uJoB5mxShILt8BbT}-q z$}L78a5(rczZ+s~VS+J6PS&3(E-=j^C%MTyceu#L_luhy%${;M3^LDAmYJ*H=R6~= zhr=?XEHlX}vuyc*^*!ov=;uJ&;jqrwV-JVs59QjGwfiF z-7K)56{gtq(!>7uAD-hBQ_M5-GUI$q9IrSW2AFx3yfD(M{;tsGKE_^c9gH*0Mb6iK zje29W?{MhM$OjY5z25qmXORVNGX4hRUTOX}9S+lszF8cMC*}F$^2J`}Imp;s>_6k& zW`Z>)*>sh0*v2$FImraG9AKU!jJ#F-F~ud82h2BVyff7WvxDMe^la<>guHQtHD)+` zt~`CxIOn;~#QExsX$~>NGz-kK$~i_;heL^7+^Tzldij(%7~>ebm}ehj7djWrywf_S z#Ki&TIl@Iwu_3F~EnlkB*{`Cu0}IW{S- ztazr3$L!VKpGlj@qQ+L7JqGBUo+0OePsMM>Vzd`8Tp<3GWmP& zp;`O#H|O>`^Zd)XWRg`5v*GK;V++fSvBECa*vClCdKhJzaZWPJ8Rogb0*g%iNB)>$ z+c%7VkLS6^44eLIT}*S288+vQ|G&c_&SY?oSZOGQ0yFn1g_i5(qp=ja>z+^wLrk7n z3OVMvTsKk*&EM4jzNL_0H>%^uyU)2Nmck+<9i`CzZTA^x zD|;E|2os#(Ftbc^j(ILIb6P1>SYc#d{@BWdtEUr7*_y2b>d@KWJZA8yC-y_#x+n zm5-D{iG`1rLc@}CaHV=+{3>~5mW@C5{$P~VN%>^z>Qb0z^3$HX-Tr^ZI+*&byfXf| zQpj-Z^YX~vY$@zAdyV<`>(3rmm}K+|>WW#8*Y9(hiJbMZ_GRl@cK=%Eg2@^A;oMi8 z>jUz_eT;q8xXgUbKC;Mp)@IFLzyEdTZH3<`g%q>bmqL;0Z`!YV`&;&T)xTfn#KGPh zJkQvTrLe_4HW%gnyW-^-$Jx3d&&=N9oE(%-_A~oE^;~b?roIk|<979OSbmnp$pS~1 zI-uS;wkE$N{W!|X5&Oa7QS&pqt{&I)J0?!%@34PNZP=$H>iQ?}8sREOU~v|5``=J{RiuS!A+t&F9Rm^Tf4~WA(mkVT+jutc9LCo#O|sg<)2i zE$wFkiM_ZnER4Yhmav z^FMvf=fSP-*=r&BGkNY>3suHmxEA*PT)gb#Fo){x)7QcjJ9^i`$fozQiFXQL0`FyqcQl4j#BXx(@ zLerLfj~IvLOU%dArE9*I)H%3pEp#%*1Q$p3W5>JKLYZYY|H?kSXDzfd%Q#aXTnl6M z>*Mmn8Y?V(*m%D-FB6PStc3}tm}T-~_Mv{Cdn{kI=JUs%`-J=K`lP%v^{KT`<04ys zu2ms;`^U?sOi8<@7*pC~nkCA!tFvBtv3+Dg5b>Ctgb#K-G58_`GACo_jcgB8bzu5XC z^Z(KPAB&5T+vS7#{pywJW$UY2?}0U+I~H$oEo7KEXn$E?nbDGQ{$zf(Gjc@zvv${7 zi2d2RHq|?`zg!DDtZdnbzwnRp$Qqk=)JfHKrkLay)66r+=+0VLs<*kp!mfR)xBqG1 z|0=Hkn3vH#>tL2y*0{vY|Ehy}yYWbv|C{!SN5T$kEl0xk-;L9LBsBcPx*vZe#98G4 zW3eM4%gDYXq5q%yae_t8GV+Wgp~~1ZkA&8LSx4uQkYV%%M?#*-(~tPRPk&!te8lH^ zJ@?WhA;Bt#+4Qm_KF4dl%ro-xBR;?DdG0dK$iKB;c_hTx$}XmvV)E5Td~R32*NKDG z*Sr58_1G_d4!lvkjJ)|sm}8Qq`gLwG%f@@;A$cTpvV4YdS$wN?uy;VdnB+1GtT6ia zBO$uyIrcJh_K`5jL zY3^~7k;{z3C=2Z6CbMj4IH@6ix$zizzjd+vVe{PUBw25z4g1=KHTS|h6LN0 zWSljQF!E{ns^8}v(_H5ycUWLc<4FyhjI*4TALhT{K9gTO6538UsUgKqPBOs~)7;DH zU%&q)adMN<6Sco=zgU|&5}Hmr$@h03@p;sf8e;5bfvNiSuc}9;SzzjG=H(~_l>hq~ zpDm1jOT3J;pDB(q$4veH+>x-zt{bfL{wFmI->4rKnPQP+jDA}kF~c$w^TuyFsbP*i zTx60(4ztX0RyfTX^Nf7Qe2j9PF>W)?8WU`KfPG^dQ|x4#31&FJEJs-81f$=T7v>h6 z2NrIY&-#5fKhSu$$S2c`GxI%pV2!g(6r98Qb?z|B#s`V_R`au!38py00&|Rh-*b#{ zi*fEU!AP@t*~%36v2vR@8Cz7(_4W_N^JL)GK&j)cAz_3>AA z`7m+a<30=AVwnvOKgoX&;61|vQ%wBNJj^v5^}V3_-TP?he8fo&z4tj9Mww)Wu@jDl z9mW}nis!_mz8}tpVfN5dx5uR0pq9%sJZqan%4Yqi^r z(|6SOaas@iS>a6m`Wwv4GFu*RpWk>i^f8}28YWrc9BW)+@VY-XBU^*%Q7d~ z@MO=iokhl3VlOv2$kw;3YxZ)ENiK1K8yseZb8LQ!=h(>#6RdK8dmLfcnMXsG!(3#V z>m1`YCs|{OZ5^It4o|7yw%Pr=(%Q;4#Dh}>r>sjiJF{aqTF?Ml^ zV=Qovn=EpVHMTuX9A{e}qf9W#5oS2e92Zz*nPpZPJ;%PCral?x0F%scj9E^x%mO1r z=4UJSm|)vJ^Rbgz4zS2^ZgPf^bL}&uEHlO`<7{}kaoEBnV@$D&c@DA645R0%8zxw0 zl2xYI@CN!T5#toe6F;$r`h4>+~FZxXB?# zhQ-AM=b7dPbF9^`ztjFc%X3UIa*@0;$r2BjK9ly;4quw=H)(?*~7@Y?K`6!W{l&EbD9a}ndBl< zTxXiw%&^7^qt8{B?5O)5>t-SCd@*^s_XdmHtKVna^X%K0e6aW-WT>_ zILQ%~nPru89Q%m6WMsnrc6l$bos*0+@=@;(mYHFVImSLFzl?L436|^k+57_M`U>N) z!v1>uO8Ka_KQ2!%l!vRm-%i(Nn&r<}f4Aq^!NjyWW0E7xaGGTn82_xenf;vjUS$0o z;U1?M|Ga#&mKDc~t>YT&VVp@OILs8sS>ZHeUvS=;<|Y$gly4^4{1W}x#b{3aOmK+3 zOf$(zW;nz0m(>p=*Q(PV^E1X?b}_|1j&X>KOtZ{MRyo7SjJTL#rS4bd>7~|xopmtJ zaTYnl3Ky9ErggtefA%uZL6$hm3Nvi_mVIS%&imly#$}8}cC&Vaco@0S_;tVS{mdx0 z7~?MEj3nfRtxR$sQ|#d|lgu*BJSSP;42xV~nMGE($r^VUnRkv~VO~ZVV+Z5xW`g~! zd{=!kf3tmirT4@4te5fc`+LXCqW-Tk&kwbk__1~OnrFW{;_$M+|12M{uKIPhyxP1g z&J}B`;;pxfo@atv%pFv3udxpHu*M-K56N@=Itz>))}L|iGQr4e?KfkLl+*{K>|>gv z%&wV_Wp1;=8f$FovyVr-7Z_tF<4iEcVHS?c3ya6i^E%_-p)Q!>2s50hU*GWFVxF6< zvElXN`iVR+${6G9VuF24a)>FWnc*a}oMD~|EU?HTH(BNmD{Op&`50y7PW#I!yBT9Y z<4iHZF(x_16la-cff<&V(4b;&BHnf$vrS>Og^yYkEw z+uo!;*vT{#%>Ki8EdJB`kR_Ix_?Pv(S-+ZkVDdlC88cjDft%dBN8Kbnzh_;{{8t>T z1^dkGz1Bn98QvQwtcPhPPFxR*OmmAxHoisw`>uy!4%~0u=Q`!-LF+!h>G?;j``o7d zbAmO_F&3XOBXBqd|>mkRz=d6bkBXR3sl)H>S*Yjt~ z7kfF!5k{WpIi^@-$Me^HAFcJV?Hv1fx_*puf~jtKVv!Z*UZmfU>n~mpNycBY?sw*` z@e283l1of+gV9&6hsb&Mi=8YpS#S5QhZ$zMzzR1Rf3fb=UtwadLnQOtZ)=H(B5g%WQmyx?z;j z;dQ_3ZawU-w=WhSGna^mipquh{;REv#n0K#5q`ls zF5wsDrS7%X%lM3axzzl5^~3b__MLkyGjfACE_41l%p%8G<}}kcs&i(!SijFrR=LN- zw~aq4Zg#T31k>}*9p^a0rtg@aDP~#a9FsSxKUTQG8Y_$~7@u)Azso!~TPI_;h=(a| zFvl7zjJ?}<-%}?XV;?6u#2nKsbCOlgFj7z_jIziWH(9uKJ+!~a_3t~c?7D3|WLV)c z^NZ`DA*~-b{6W%K3ob-TPU!#QTT#5^}R#|jJF z<06~i>pUH>Z;W%CNlr7(Jjb}mEZ3RiHX|#Zf1m#BW^7e{IL0|94yvay`D20=jxl}M zc#M|3C*JQm6HKhR&m8Aj;}-XhtovSG>o}^;7`;P1Grb{CA9S6AO#H-qkZCS4!wnW$ zW7D0+8CR!Fuu?V;Q+Jt%@t-+YAM&2t^!{P?ZtGy`SN8wI#{ZpqXa4v0^CR|&Bh3H7 zzSP@)^j=_vjT7=xwf}W@-bDvH3$m>Uq&n+hZtIj`Wo?v{YS>+fTuF#KBwl*FM zMdl;NLOLT)_d6D9%rqSfBUj4T1CNCrR-3gyE}n-R3l(m1j}^=Ed*kFN;pV0pl{WQc$qxa{Pp{7$3oX9 zt@AO*!YDU6%gSSqg=+o!_c;9Sc2I zoA2qzLY9SR91BYSZMi-eUH1&6KP!JPI~EFzbDaflv&b52Z2FvjFSky{+06pe zjK0FW%)Le)KkqpvnR%`FSmG=redb|;C8oJmzkinJviALK`_Bp|SYwuvbB={MM!Cco zHyCGyN$#=8eb?9@_AohQeN1tj8BR0LJj*Px!YwAwRS#cqpY4pCXB-Z2m^EgZJ^xr( zW+Ej&EVJ#4>ih!zS>ZV2?=TMw7uv6!IEL*jiyUF>oyWpd{W=%8$8BaW(*H~Pv6In@ z?HgkpVVYSMxWr9vF*zdsFN>csrY_Zwlb4B?>C5fQwc>m4v5;ex^K5;eeP@chOfxbg zUu$j?{A$4*AZkNNzcdj62O8RIVZJ|Z7q z)t*o|pc?^D)f=;~D3U2{z0+UssxsRVJCg%DgOafkhU%$xT+c z!_=gBuhag7c$l4%*RSh;wegt$jD29?v&TZ2(d@C%{|)y!#n?6C;U24ud_g>U+pJHFh(Z^S)z&HM?EO5Gc*|3>4ppOG8AhZ*GnYl^4%yNqz3)VevU5qouUZy$7GAEh1*?D4)>-GEJb8fz) z|E=QZCa1W^Sq|T39ZW9T&+l5-5B!~B(~rDYndLkyOX6jXRpx%IK5tUr>|~V#Y`xvS zvxC#@VxGzUo@Zj&`B@Mz%d6th`Kb!8b&x~(~^Lw8AiTF6iS(aH~zAR4#f0yr)PbN9aGG|$3fsvn? zmmRD!ez$zxsy_#q<_J4};r+%UODuDX74EXe$oGx+OYb*UIKbGi)kppMw(;xNeCwmwGwVtq{QsBflOVfL@$UosE7S!6$Be-l6BoMwV~4(!^eAM4Lf zR@l$nKgGdf&H9-9xAE(3MsGLIf7B&Y_o!QzxX3csS>ZNotTD1D5Bsf?ZH%##2`1R| zU+25t=6wDB|2)rf!|~9)?E1Zqhatx9ecbQG%O{Jh+~>IOgEkLa7->B2_v2mXVEsBr z>(@^>9x{wF#~A0C<_0sYFn*$OR`ib?4+%y&z!*mu=LA!nWts(MSYnMeM(%q&G_87` zZH%##aVD7H08<=ckvYchXI<>#CKKFYhS8$;0XtY^FB1!DMmTV z7z>QE#LB}xcSwAXkRL`l$`~{3VvZRu)r}taIaK+6x~=w!SON7C6TW*SW_X#$IH|=^U_4X^(Q&~N~ z>UfxD=1ua#+MBKSF7YRw6Q<9wkL((d4_4l8-+rcjrtw)Bv=1zvWq+AENBlqc_m3Sc zvajxtcv(5u{xfpk@vz4zn>WSHc4pYi3e)U5-~KYqdB#)XV3|#Kd;S9Zz|6(Y7i(;+LJSgT)5EO$TC>B9bte>DL zh6{pX5Cp{_D2hQ4)ENXpF-PtM!5|2NMNkxrAT({K?Y0eqMNkBbFu(8q_5IAe@4WBx zKF|Bk=03N#$ND?9Gk=#jel4DNJ4b9DmR}a{(ar|j-TT~T$-dv1kGt4mox%I$l_6)C za*6fJ)cv>i9rrNiJ|;|qpqkI1DS09G6_A%=mWy1ZeU2b17 z=L(}My#Lu|{ddOwp!_nKGd^>!vfxIyogJ3!{k`Wn!01EfVfYc}gEbb6=k;fk{eRG( zL+o%bgO92YLr$>9Db{(I84KoIX2DgK++c?tW*@gdHud8HriFdSjBDNdY_s4t8|?d| z`9C2~3^~dg_cP@TGtM(-g9TUE;5wV!V#(l7*2jK!IK<$S*2#iXZ16CfELi)L_Zu^| zIn8b6?EAC7Yq*OA>kJm;iwRR^pZ2-K6}CC{8Fjf}9@ZIs);?mmXgw@HFK?`WLBGGa z{*wEwecAe0=SufJw>aA{|6k4b75kFuSM5iReNA2%F6+;dTdaS>djIA;GiJmI2H&)9 z#z)kTW87fE4oALaA8pCscf`TssQfbfuDt%;c;8niHk#_gHdBT_@VUVn=UC?wN7!Wa zL+{srn1_QbImYxy>cMEmd0_ry^Ks&&y8KiB(lvAL=$QYM_YnJkA#Ub>@*eq@b^OhF z`?ol`hsl<>IKgSAoa^5IyZ12Tf2iw!#QjhEjVTW>{*QID-gB(lvu%8iv%@LIS2|YB zb+5U~!K)ne`@rUB#Pp(L)lp7de5~sEpZr|=Se0|Q?^xB~2v=BelMVJ%;<(PSYJd~m z!zRa>T<=)5%>JFnsx7Xt))V-<>R6RAx$&{;2&cKhCW9*ley9CdHOPYdSikA9YL*i> zJ65f;WN>BoZ*Dx!GU7H9#skJ@!Z}WIi3OW%-{M%+VtUJC)dkLS$5qVF8lzpus)Gz~ zeXJ@t$z|4VYkt;mXZ{^QPyb!b%lMLG)il$mX=m~r<6PA`UVf~a=h$nk=W6bA4|DEk zhchhSaIEUPdeF1UT?`K$tLhBic&r-fUSBGoEZ$^YjNU9CoPLYAxXo48-YSob83e|i zmOswE&2voO;W-BH6KD6DTZ}(wzKa6iD>+t;vGW;qVY6YJiv$1uM4W7X=UBDK>COpDoVy&u&;(DR^nXzE&#cNgXjpXH^ z`I)C{zLzYXH?39MH&*vId+sK#ImU^%h>PvFtyQ&t_qm7ByVk0l?f0xzLpL?=Wov$q z)$_A!es|SAyj=cRTw#6=e|W7bIsK8fs_*9deQd3oV7{pTfPM0XHNS5vZ)~vO21^FF zke?;-GGojJC)wc~lP|7St8B67mg3@07GG8mb{fWI@D=-k{ak0ATg<+u4!6>u2^-&# zZ+5<|?z@cp{k3YD=?~@M*5dlnS~br6$MVkMpXkrtpQ*=fctYH_)vvVASUatr-RpDO zYu5iO`-kC%{dha=9Afcnd13fl^tV<-rp&m> zWp=pA=I_LL2jl);e~$gZ`WbHO&si?A_DA(&&S22}Kdt%RuKj&stvbX8=Q;dW>td7P z9nHf!YkyNWwwST8wN@Qv`FHiYlllL#=J!E8_fPp|+%Xre?Gh~NDjIMON8fU>N23I~_%`xE-Ho3ua z$MI^-NWlfAdJ-v2Y-tvttq89Q8JxXU`2aEp@+?%n;|77t6#u+4dP*kEv*Krm|Lx4fk=v^y8+TBr`-pS!cs0xLj>oGt=IpRw?|t>-0Gr&+k`aqLSuZ=x zncw+%b(Hmc9k1g1$r}%_Ijo+n-^ch&?rT5p;r)+Si!8a$#slov`-}U5$9=!m^Lxd| zN#<;DnZ<*|$CAAdupb|Myc%ZCQAQ6@XLi`^UPtoIm^}|PFL$!Z-K;%S9av|=h?9&t z!-Vrp*4lSj0gHdrj&pKIW#E4^D;WS&EV>%&k%(%gv z9hU5UlyRPKy^Oh+DPv}wV9qHPJj@0QHo44_tE|1i_>9=$CI=qv{tJ!E4pT-4JkOk~ zOkQMPJVrZ*n7-KO5QCSf7kjzDg6nK>i`l{Be&1BTml>BKr#Z+uCOpasmQ16fd+ zW7RvgPS#(gox!V(_c;6IHO6Ce%KL{4ueViGos-{pB`hrJh`=>7dZ`Qq|ruAd~HS?7?GJj(vdkNf>mpDXMevrg{e@)h<0J0Eh6 zpKM(p76%)g;p|834;J&{e2Ta~=058mH$F3#T?^}es<=O4pE3QUaT$EddKhw}>wDL8Vkluzi2;n{jzm;{fhnkba8!Ez1ZXtcDTmc*Sx2={Y~fO8OA-L zo(#Fg8iW1jWj{wa#F%@TFlNdL7M$V=53}|y^D*NEHaYN2dHuHcB0Jx)UZzLA_c;7r z>v@*>zNg;IILn-i-RtighiOwB&vu`CIsF6gCuToXH>N+be-rHtIm{Oc*iP5*IhQ#`2%?@?z~B^3a1Oz7H!87oDh zX4gMa6&$?biE5L};fX4Gxx6#sME{9uSIV26s17k@&WsDpd4vVm*kGGYZnI?HE3AvV z*kPT)%}-P#3^~pk53qmKnYnWxPus z+2$%c++c8P^<>E2SBr}S?7fZrFy{ip+lr3`dtW22+nJBS?d6M`++ul$6V=db&BMLy zFlI1#qMBgHDb{$Hbry`c%$Tc8xWSYiX6&634+mIqHye!D&3%irW|F){mhwm+wZ2n4DRW%728?mQ&!2dgJ*k$kYht?vDYn*WWSzvP79A9X&s#FY{I<5KJ9 zAlux-4)-y5xbYZrk~PjSe}r+_X80!Se5CQ&|0wM&9xeY&9^)Kk`tLIi!^eq>1veNy z-a6l`{fVwwu)_v>-=Z!YV9DKVGh&Bh44$N340(t(=B#sp5sxtD8WXmejfwZI?mt=n znLp)3wZibJ&gZoGIm9OSvSiFQC)nW>hsW(d7HqM>3v4oYoBmG|C&Q=f-@WECYx})t z-mX6*HaW(U2iWEzc9^sEOz#g4CgORAzY93W$>-Sb44y0Q8Rv+5*O^Hd(*?V7t7yu!SUIl+w6-FD8g_G)=OEFZ6Nj##|Te&GUp-{bT9Qg!46*SY-` z=kmSYM{gAeLuRaTmMyk8@^16I&vTq(?XYn;!gc2C&8?Gl=I^zR?lspKzfayS6DJ25 z<@P%#nX%w3OD?m;Rn{(Zj+k@k{d~WCv*Z-B%k3w&IPd}Sf6RESbCwYo8S^L`++vf# ztZ~@SHiy{ZUIrhxKiJC&wmzwj-TR+XM}}Nu&fs$6aCg@Q?*Rs%5kH67VakCk#Ifi+ zG37Lum-J)s74N4HikrhsnK1t9iE5q+8(iiFgJpS~69@Nj7rRaKwA(L)Ond z%s9@12fKdD`;ARDSwCu@eOMki!r;65GylFgxxhI#xWp!#>@?-;Bl7eE`C^R|Oqny| z0%v)I1=rYMn@w)BWZ%5=$z2S8Bu*Aw;^2yX#s+&oYMvjPmkl0Z^b_mnGMlXbRGqu` z8GOw6+|6Xwx|s4H>p!zUIKrdd`#)DNX6*gA^>cvB+{4;2>*ENgnR1R9msoI($qAni zg?1)vluB%%e|^d>w4oo{zqSshzqKzvD_-v6$nX4J!k8%&PBY~kGcGY_lMS|6GFUVZYYcyHot)qS zX3V(Fg6SVT&koz1*!2A8#KjtuKYE_iOc?yhd1HA&p4n!H;a}wW^VY=yCV%(7WXc_1 zFn&ke4E`nV?)AUjUvm8)?+=C?WQ}{6aGW_0a+w*!ZO=31Iw$`t&M(?G9O?Q$^RVO+ z+ibGK7VDMw03-H&Nq)JDDeD~UIay6I;tUhcGh>4VS6FhL+wA$W=dX0K8e(I|$!daa zPOofE~`VcJ-6hB1gE&CVRdjU)MNUjj&|OqE~!u zu)#K07+zC+>|Ez$HT_lB*A)kATw^$lF)#m5UW%FJCWL0C#k?!>kPF5K^Y_S=htcJhN8_5&n8ykluJ4|lk`ESS@hr8bN zWVOuB&5Zv|^WXer6*0Vpe08t6$_BUDV*e52-qQTcIL-zSvdN4kXW8Z=J3PwZRwt{H z5j#xT`z@a@9N_eAPgXHkc!+K0jB4`F39d8eR=1r4-xlxfPFA~FXT+FeY;cAx&a?ma z*29P!%-HuGdFC#btTVWS^|8)z&N63{3mhEuJY#m4vHz&~xQ8noXUUYo9p!^{9^nYr z8MDKTz2DWJyBXX`9$4ojM>xxrM_6!!%iQrjd0>srgiL5?xvBva0@;8C{NW_TCzHud8WQ|@EIlqF}`<{~>h%HXc*&ybs}vF8WY$(@W? zW6WVD9A(P=%$PFgGz-qL!6i1?WXTrWyujMs)cJ?TySKb@fhpU}Ss!*zn6hMXAM^jn zIQKO^^9NYpit7iu=JJE>&mX&fh&r-}4oLkNr$I z#Eg4cFlLhztUbcGtLi^$UdCKv!X{I;*x)u>?E9JgKF0pzFsInyV)y>z<((0Ge(pSR zfNhSl!~Lws_6;Yw#3oCIPq5#PnV&<<8L{L+hEEhHBQ7yzv)j(C?)8(Lvo-BwC#!@p zCs}*4ea$-8m~xBD43FD4Pmx!SaGW_aHpbs*oJ}5N$&9t< zpR9_mFOZ+EFLbULzDWG1)q@E;oMi3A>cNCdOxa|{7Q>f_?~M9$H){v&BTn-Wlb2c- z8!uPCmN;K&9gHWPQ!cZ~+NT#d_J~1jD!4KTO^(9&XO4|1Yff-SWZad&JA= zz3R%0Ww-q@asE<#v+BTJ_WjE9m)p-)R4YJTc}to1E%ie^Ncz<^^tlN}Rv7o(1b? z_-T3MG`Cr>uWh`~h`Z~e`wTv3{NK6$yw4?uUr^uQyJpCeV@#Kf%i@dXWAjVS?H`<@ zhI7Y)C8Mu;FKvpCLoAl%jU{vTe#7T5qi@R3AH{pbeq-}n>eKbx_5p*V>cfyF2f4|T zyZ&UH@0y==PB8wS_?UiQ{u%u6WHtC_{~W{-HaNj1r&#hZ+br1sBY(#*=LW+S`}Bf1 ze=L5kuwe2Npa0C*W`n(dF&+ol;cm|U)O>7lhSRIwC#?V6a~wNn{J&bqn!gt~QHqNh z53_m3zWeBU}_Q${3v0qvHm**M%Tii_kBi{cQe_K0?|7vIRf7;ouv~PR9r>yp}!)dm!R90&& zuUuCB|JDC0WwoCrQ?@zH$sMKNH+HVM#_6k;Rqy}AaW&&H3Ce1Tvlo@V_iKLcW`hx% z9An7?Z1WI1%o$uCfv`IDKk#9;2fJ=Vw+6{y=B#6jTabk z$CZu4kQoPAa1Wc@$2JpoILY9eWi`W)^Q^JKI#(ERofGW2isw1R=(=S!!I)Fbc$f_q z+`gfD>@ZGfTt;j#<_Z(8Gv^kU8C+EyH&SP&9B0OZ%$afdChEr~w^_39YUb;=P6ju% zPKHbv-CVx9-qQG27a#X@y_J3}b{Ut;oMp*HZt^IDTdOBy`m&t=KF$dh6n>F)a zWIeZ2N9NqmO=jKuw^z6BeKy(TCgVG()5Y33$dr4SaUXLgY;clI&alHJ)&`B&y}qOT zF}ag-at-4Q*|*H^>Krh;yLL|A!@25p{XqMQvm?#}n{2c8aO=3HxH-b?5$eg>Bg<-o z(WrBAE#p4Qx>(y+R;!G-!4`L2TfQD^9;QrKdz?6!@hDr|Wbt_Cp-U+SaOMRqAm=d>-p#BGKzlJD!8hvN)h zY@c%ZCC(GWms;me{TXwG(;R!5__@jL?)A&%>-yHoUCdZ#&JmWcFg`mx$oQ4wVuKf$ zyvlpv2IiTxUpW10=cIf68s~&1H<`cIdAp(ODf@!6ueTo(kzMH?e*m;NaWTmk}3Pvd!e}>fLYrcZh>+PO-zo3}(Dvy6s$MjjK$!#gxHK z#mjy!aELALWt(x=cbb>MyVRAv@3tRrCLZo)|9ics*m$3H-dy~-=h);7CoYqBX787e zfs6e2ZPv$dR=$~Wjs=$(T`u2D*>el);Q)gx%*Pr>8FN1qrc61_jB}jj5*uu?$#s_8 zVw=G&jn94tAGCgk+{+r{?)^D=?OxBT4+q(ME9>L{Gwx>2h_f7Hi_;wbsQk0`F?C~| z+w3p&+hrX*!1^cbQzoAjCmZa$wfrr}6EkKkKO_IQ5%;3~$+6FgiwXN~D-W!({&{)o z`UQ1h#CgVSFyRVQt~28n3+}AR7k9JGeGHbw!5R;9j7!W|vS5czhPU$^>kPgqkBm6k zz0U=9c%Jjb!G$;a)jn^R1e#mV~DwR7Sd+V7y9Q*3jN{YS*joVy0y=P0*%fYG9?GB&1LunI5B1~7 zkF5XB#`~#!G5fi37#$NQV+KRkeNz1FE#;9Bo89{i?qZ#%yf4_{0mi5GXLQDVY%;j3 zxH!O0%jY7Kv(5vXEEt?KKQne1p0_{l=9>H1V8ZAZ;@}9I-RoaEf4j}gog8D0^bBj#|_pmPZb9mGF zWbjAlo+F%Q|DU{;P1|F-Fi602KTY{4|VPOPx)e< ztKI94{NBs^nWJ3ber|J``M>mM!BvL;_MZDc@!<~qy&*(dk5&dRuK z^qi_P7FRk|9btauQ&orARZdky!_LEwQ&qy`s;8>ZkmEvv`A3RmAqi zr>YGm*F05?+?UrfF6-AeE^B?Ks%^Hp`+nxV-YLK5Ebg7Be9zrHTxZFhd*uE4#$lT? zjBaqMT4sF1Q&rFXU5BTtI>Q@@kI9WsRr3t`jly-A+|4=663;)gEj-4l}){=a~JU{w$bx+lS@hA)dSMscM|<`<<$m7~J1D z-TT}Td5$6L53oLVn6UXk>tVWAewcHW4Q?=ckh(uqejaR}ae+(B9-rXU4BQ9`~tIW8;X?B>i_mS4k0T$fN1x9RejLSU0 z{7Le{SvFa4o$;9bjaoNr44*6yjGtnEbAl@@c!7iC`aMeBILb}VFnyXhIsFWEe6;@0 zR5zB-v#!Tj&xC%Q<`N4w*zMjU0#{S02<+%RR6!!MMN$Lhxc zj&L_)Moc)yln0pc5Od}%xWERFu*o%+Y_r8}w%PYM>*g+YSZ8uT-k9FHPF0JnzgAsXvi}M0zfL~}uXny#e}nZhIpkbD(K_EK zKP;KBeW|>6@4rbsm~ewBJIvVoB;#^`1$TF^GxKnP2iauC7H7H5Mb_S;PE6Q8=5v%0 zgK7QQ&soNAlRu{KFwc{X_fGF^ZZc>1ZtbkU*Yi)2M@}+)pMAnQ=Q+z38@#}hJD#dP zLpJhLRm|zj><8v7Sa6w5u6D2AFOG3}`GECuni2bF?F(j{VS2gq+HGgaS#ENLeNPkD z73$6SgYwOUlWel+w$C{)Y%qAbe0@lN);Yq6;|x9`PfWSOjO)y~#p!wP!Dm=6_cQva z_?U2!8CO~G0^8iV-?$&MKGwL8btYW-xP8n`2G5k|Pl<;y4>08nCppiI4K~?gu;BCa zS)Sug)>vbm!;Cn}4yU^JKdl~YaD~fUXOmkj89ZCu>}Q8V3_jy?k|AUEbAt8H$}i(Z z=a32e68Ar6ekL4c@kQs1<=5o>ImTPIPUbwwiEpSc%;22-JtnF#95THij_2$D7tgWwSNn>=-|Q>ad7#_QL(G{o-Vz71j(onr z^|pF(`AVm&Wwx(&y4v+Z^Iqe0HN&XybhXXN>zuAe4#*=9vj4iLt68>hbh=vP!c9(B z8!T>ly6S(C=WcbnirL{5^V^)R8r;6E@mL=`UG06bbqt-ZrWxGD{LHz@Hv3-U{@qXe z9=-ebI9*-fVEuHJ9uyxJS>DThFO{!*pRN+ddrnuYOt`_69cJu(nQ=J4;QpumF0|*k zpMy*pbDF&mIPLeKokIpMmml`C$sq<0JYDT$WAACd1FheKQ@xxj6f?0=Gar>VmYij6 z-|1@itJH@vn@kx#&N^A=8e?v8jKQQlvY)e$w_cX9{BZb*>cQ~Ir>i}$mglF~7o29s zg0pOJk)5ZiEAwZZu9~kg4li(X|LH1xt#O`d9jtLLBgRZQ!GhClaE@&*vG#1^GEY1= zB_GeV&lo-LwBLia9&RyV@H*qMpBaakb1w_VY;b~2PO;=+wpp+?p$?3>#R=|wy>VD) z$#DkHKV2PSKj#^-$&44+;LbOAKXNxaj9Gtyd6{sYlRV0TZ8o^g4tE_A&kIji5r>&D z;WP^_v1G|jb{HP8{x^D#LrfSm=Oh<6%aTVJzR0|c*n6pc!9ivmWs@m8oMrEe?N`>h z&XmEM#KS=@bA)XkVC^NRtDG^HIl&fl`k%Y|{}!FDY77o~j{Tfq#2Ln%XU-Kid4VnV zz1edwm0yO881n!#9_B2U*ks9)n+#v3K5sD(>l|auj8p7zf$7VwlO_A!YCW%TP8jhZ zw>i(?mG&h=uCSl$taFPIgK6=xp9zOpa4&1GQXe+B%*jdhf17;2+WU*qYwb_QJi>%) zOxb3}ZRYHIyK%XT4c6J@2uqH$!zl(+^2Cq@Yg}fXtBkn8m>nkUeTR8Dz?^$na332? z*yJQj&almScGzI>I(cHqb=KK4V?OR=%o-C8Gvz2V?q|-F1*h5I97`Ty>-F-%_8YAK zo%$UT7lSw2k1V;$iA$}EE!N&8p3MGX@n-R{_7>xCl7sIy569T%6vMa5A0rmb+3dEn z&HA*u9~L)jY;c%ujQhx{|+I2%0J zZD-bPpAlELolS0Yo9R34zxR4Sag?=piGwi@F=Nh>jc)t9#nEl&X1AR^@6*l!)((q< zvpmQS4|C)_&L2}YS+Lb@=QgAFIuE(`21nWEeunQ;Unb1iV1t9X`5Ck4GI4MxOYUav zGW(E|JlMU@!wlXp53F;U8C%_UZgb=V^6`H4<0#ua!1}DZFymsk{c`)2@fGI%fcZY? zy~7SC*__jl`G?e>*+;Bzmh;{(tbf#a3_oUnvCZIe_dlWT9Q?F(Tp`{?>u2K&`gL7$ zu0QDW_lx3V`3>>2%?n)qrugUN^N9Sh@onqwdQ{z*e@~r0B%j|G2b)dx=wAQ8zGBYa z54+C+hCftKCLCwZgWYy!-S!{JCp$m(Jlj9f|0DA8Q~jB6iUsG`<`I^w);n*UpIHYR zKUZG{$JCc0S6DkC4oe-F7Z@+u7{4|5E+C?F>F45A0`y zLu_&{OU7(-f*nq={ww)q!WB+(lPm1|q|b#7adDVqj5*1Sb8NE74ma8RYxVtP3@Ehx3_FMH>upUNiaGagrsRyGA>i=oie={$GE&G!N`#$6E4(?*{ zckATrKb;eX|FVCXap1GYXPwEvoj>+&>&HQ^vd%UmZZl@zqWo|-mpRUDPBZwgd@$q^ zW3F?Sy`K{g2iV|lhX3M%<#vwf8_ zzNfF>jx$w_H4d}RQAXU)m?;xZGvypJE-`151zT+J0-M~ir2kco%YtJpImxlBov9W% z&9!bjx46mhi{`ufnQAX{CS2w;x4Fc@;Edlr7biPR+5aW;b1&OWxXp~Ui_TOFOt{9J z9WF5ZvbZ?R@M7y`#EfGsm~n+oZn49#q5ju6Q`K4L7*if%!Ggu+TvxxY z*E2p>7%ZD-r+)0e$(d?{@vYBP`Pb$9wr8q!&a&?t*27`ucM@m!np=$Se5M-srg85k ze{9}eU5;4iJufNui<8m4&Q!a;rQf}+j~S=A%tc1S;^=xG@qSx; z>}PPlGu1dl9^@o*=3L+ckFeOI?hNm5p6`h70s1j~pmV{9tKIt#(teZ=HZDsZWcm>G zVf;|}VT<8+<>z5%s;KKFXR0ZNBi6-)8*H%ed-nUo?GuKNIOF^8^1y=iN9xD?F~*uL6bME-Dx-slJ;eE#1^VN+BmpRE*Ho46Xcl|`a7kD3VnhASf=(+BFE^wGf zn7vpWKlS`e)Q$Cn&IKo4Y9FrZpX$eHZZdv_bNDlPdX;_24v#XJR1c=F7VposzsCMy zJ|#X*A3Edv>7KvTdF5ngoh;uXt~K$zO`eY%XU4u~?Va+=I+qx|Tl)$5=Wb^2GtWum zbC6*!Ue-9lh*L~?m>CO(mx+@#Zn91%Aq&baI_Jgu%D($4t9*2R=_Y;%pxk9fbG;kYoE4X&U#OAH-pc}2TNvMKWkqyUNql1dH9_D!4?zNKQB*ge@PzB8~@AV zX4-`4L};^ZD?-%;PLN6pVRH<*0a{2QKUjTwiTbCe6*&lWQV z-;-bVbCJ>a)sHcIel4F(`~Op5s`t%r#P>7jkNs`?ki)-oei(6$ zwci`}xB77>7Z|a@F*bRCB@c1%58~>!|H-&*>-e*Ev*2MiSg^@u4*t!!zq4-cVgHu= zbDOiw|KaoF_ww9Pe-8f3c#QsSe{k|Y*6|1J|Mh-kg9U4q^UA!ZRfU`SU%6H7XNMUZ zJ6eAKTAr@jsy3NltyR_ks2*2uRVh$d^*7sNK9Anro9;Up&_@=FD_uuT3o3(u3+&niIHwSB;+fsjyaG2v9;}jDf zX3ByYm)T&8O|9bw>_CeRj$OqeOahn$yKUN(7v!2J9j~VB?KHhobEPE<-h{ea&6O6+SkFfWN z>e9VtU(dxoohR9UjK}1gC1<-nSzPRWiu^L-z?JmpD1&kPpApxYaEm3wD;w`Q^2@R3 z+viugxM%i&YvwP~kLfF&>m9~>js4Bwwd%@{tE_Q@b#}PP`c?Tl=Zq6?FdnD5!u(Qo zx|;j%uui7$l+UYQ?0cb}WB6YCg~|K8UxJH!wl8TOpx!Jw!;#N>o?~n?`LgkQJ;#GAm@#OW zk2Nkb;!!3nnQ@Z^d#-tL&oXziWR05~X7CktVvPx-ui7VUe$6^LyxgjGT}!{O%MWWD zW%y0!oAD8GcCWu}ylczD_vDMU@2eL_eqdj4_=leF)Bi`-!Gd$Ft*9e|AIr;i-2aJu zbX~PB20ycJx~_Tty6&GaF2j@Z#P%us=z7+5x>ZH2wOUoq4p%vG&iZ#=+|yvlqOC3r z|6#q%u5z}T>fUG01{c|6lO@-g>^NJ6*LR=8tX=i2?|FNkhuCJp=xS%HRVG(ITkX1m zy0OlQ;H>X^n};bI7oGKeZ*g*k^^48Jggb6%+-sbzVoq~{Ij0z1>uj~am`9j#jls3g zR(+vyxSMI8evGbTT$a~8TkW}#xUYA%+Q*a$o1A30^K3Q4;s(~u1-96}q4nO_e&HxP zOjrxgR@02R$O*18Wt+jh&Q?P=5#RsG4;#!G4jaFF|Doby{gSiQ7V~}b+i$*EaWc8$ ztnYoB_k(Av&F=Mw&iWp=_&$8Ln&;rWxNhcoj&kH7g>Bk{0x@V=T_$V^4aPDOU`htAucX_)jD=r&$9I~`KCJFT0R*u<2VZ* zZX0ImV-0;U)*y&sM#6GCu3< z|AlkOoHOkG<=JYP8Qb0a+-9(0o;%z3j2Ll@3!G$=GaUZ4d@$xwuJ8ie+%Y7c->4T; z?&T&AF!-%=!bvVN=TY{yJ-I=8#U!8%ts!usFz=P;)kagNQu z%fsER>mTA`ouf=S$raAB_D^--BwNgQfh`W)!~7ljV96=Ad6*p*4F2VLhFoRD3yitr zo}OpOl!NSWjKROvgCP&G#+-F7Fyax$Tw}sEQ*JY3UtM0fiv{a!aD?Tyb+W}7rvH;i z20iDho_om)cQRs~9Ufq|<6O1Q+huG#k z!)u?bjxyo~a|Xl4>+>9Y88KnP2~M)fIj(St;dRdWzP5A6q5F9LdgrSBESR&yWiIbL zS8X!B{yD!}ZvS&P3&yP7;GFMsi|?yoayIL10tj&PdeEO?L&W^8hnB^TM|Q3iX|fi-S+@3ZzW_wO(7T;>6mJj4!jh7S-g z`}cZ|3Byao!69bc%MKF`KKNW!Fy|VRhni=^`W|L{2A3G0A#>Ka$Uz=uoh2h~a*RC> zw@wbQ!@b?>5&Nrq%|!+e_dGY*{|L`NLOqy0QeIeamJKel+^61;lm{lPKlWTT&5Vm( zA7_4sPY~~@bHpWguAYz9pEb4_vBNQj z`{jf2vy97x7Z^QTeI6rEiS@G1obBhzFFS0rc%J<1)BnZxIb#+KUgAB(kXx+3)VY7G z{qr*GVexY7Wcf$=foj-Vf-fjSbOuisy9|g4lsDD zdARvD&vE4)^8EzkGGU98Y;%Sk&a?JT@o<3yPqc5|?LK=CJMZl03Nv0{hkZ|yulLxG z%(#~YV{S8L{9buu@IH0vwsV_N?p%$zX3Xd^>t~y*%-(POC)>~5#e#JB9N|%>Y;&5ye(T{No7}_T3+82=(;VRfQ?4@S20PsOO#9=D*2{!r zZ1Vu)FF6Oyd4vVm*kGH}4f%bRYaU>SIcr~07Y?(<=GUzM+2UHZ4%XS^2-{5Ao0x|~ zY;Z42#_Vu{#n;uH(KqCuDSMt{pKy?q-xNO=IK>7JGd?13Y=29Bo@>1Ch?Buld11&S zT=}kZ^E`2VPd?cAskkTXqo13P5j#xT|9tD`FdH1_;Botq?GyI<3#{{$^T~+w9ASeA zSD1308Mipi;Dy%7el|G7=6UPxUjI@Y%zvfd0sYv|Huo~zPx)mh63z z_X`IZ{@VFsjr*B0<1`C4xWeqW^7mr%b04F&^T>>IZ15;oxWNvCm&o()#L19DY;Zr@ z%(%^hoj>?|JSg5j**{GGqW?=>|4sf_a+Mu!FxXNLhU|Tr^>Kt_e^(DSd64ygn1`F3 zW${m+Q=IPD&rJSh90vb3&dZ%c4zS5R4E|%iOqh1>bDqQ7o@e|&ai{XYVdflV!ToG7 zWs}nkD|O)*OD5c8!Jb!mzUO?ko3)G2S2+u=cCW8-zS`>Ad%hZYrRO-xoCn$F9P8IS zU#)PG9X7e^Rpz~x{!BQ@1bH3`E;%(1Y z2@_6of-}rG&zubwTw#Oj3~qPc_ovOzm?{hgdMh7yS;V2UL85egrjUTV|vH) zRnHsryVLnBGEAx}&>&Wr~+cu(`N;8B+UCyqGIQ`gU#^~|lVHg{SZ4SQ8b5A&5?dkf& z^Hs|7N%F^N%>H`2@i@fxlbsI+PnB2pa+^8p@6gVK`M7u(Kg~F7K3!gB+<%68Gum%o zv*bFHXRE_I{av5fFASd}KK4G>xbHGQCm24@xC|zo6E@lZZh3jWdNSiAXF05DoM(d#Ho3x*>uht29R{=3eMnpkIm8Qzo2d$~k6SV$LQDw%FhW zmh8LSeB8wj>kQs#|1jh@Ydpw0Ge(?c%tfYLWyTHW?6Ae&EA+qAxGXur_)VT?!6R&N zjZL=M;WlfT_&#V|+{Ki2mKGT~9CEE&AjxN|;_88e)gKSpm; z52jpU!F870Vw=H-^nbg0Gv)|e%$U5xJWN@#!5tqK*E^jnMqJ_oH`ri@@w<%o5zoI{ z91Q-SqC1YSBbyfh9+Y?4EI~2I5)>Cm2eKQm{}IluEezcaU=-J9h7^1%E9?jMww z5879DbK|o5kbHd1`Izy3XUL_e^>ORsAY*Q2!W~Q*GvhdO?qk6N?66?Td3Je}6<66~kFEbwM}_%0#5T7v zWWkBj33qdvQ!JUY%Q;qDV2?{|eat>E;0D_q_@wLqH7|3f z9Q?R_Wx;h07xMin>*Fq#OgQ=pd1cHF6D~623On31=XnO~a+u*KeNHgp9(K5&txw4t zb8h;y_bUTd9A-Et|4f)ND!c4)js1tj_XX=<%9Uf-?*Tu#18}k1J@hljR5i?G* zVEIkwfyuYj-C_3`a+;$oxSMm_%S9ewcC~$Henk9VH14-QD=azg%CoK!DgwO$T0J|#{D zmG>vZ-&;TX|EP|>=03-n{K=8b#3mHGlFH?7peSGndWgBz{XOKh`Z$PGpu z_`3PHg$YBZ9A(Dc%(<5ZGtP5{B@eO7BdpkEk85mQv{Ltd!~ERLtbe86!JIJ*jx)S? zrJiNP!%SFmnQLs{Sey%<;}%8?8FQ2gcQfT)X3Us#h6N9?%OzH<*y9FUH!=P<#mOyf zGi1n7M%>Mqdzmm}${A)n#GFT1u*(kDShDY1=I3TsY_rD^rUUZ8{N~opF4tJG?`m;v z7FXjfR_ZZEw_2$WGG>R}K>SBM&n@gRWdE(j&w#sGaEcWVGP=!5y~uH{FyjU0Y<=7F z9At-ES#k%vj9GD-cwk!1k4zggvMUD@u$M0Atw{z_hd1U+co@2;)Mm)-xtL!rP zu6a1je8@W3<34WOVWnPZuJ7!AX`Z{7pB)}y$u7HGW5vGjiR-TN&zuoUjxlPl`2F1C z}>`|@L-uN-E??W~wK*Z224V=ge|5_4AUu+HS%ms=?1Ae0C*r)!JS>@V^g-rn?vJP!PBZwaygb;xGUr~F%-Q2S+Yhl0#@zHX z^RmqjM_F-#!9&$k)6OGJJ1e%gn`cRXjxghHb~wf0a_=!l>@wvB3l9BU-EaqcjM;wJ zNHWd*(c^++gdm^8HKg9AU(rOt^;` zQx=?N$yruB%+{#)B->nO#B~-N`jzLojTIxd9w#2QIl+iiOqjD|$%@NtJ>GcCx#idP z`3d%kDaYB`DIS(wV#SI*ZZLeJe#^#Z#7QPBIL$>KYTBQqA5(5H~ zRgST>qMh3q#MZ@-W9;w%yDXafPnQ?Qte9|vDF==jhavOl$Uj@V)dvHvvdtb74juO# zcW{n-*k#7xx$?+}OHA2g#{Lufafl^%u*W^zV9M6>><2S;IQe|_%Xtp2$}_jKwMX4^ zE>Ra;zQX>VbpJ|uV8AiPoMOg;Gb~whjlCBc@08ES7mI_FJiyk3c4izpZQow1oy$yF zahl1?#L3Rf<&(uLotw)1ud;t^b3a2KWXeSrT<1Io&KQr|n5F89?w^_2o^ljG7 zb|#QR{@pqlyj}iSvhTdl_jib!!L)P8dCoFau zGG~X$e(Pn%*1G!~WS83+yhndVoaPwknDHocuCmMiKiJ3jI#(RzPDb3zapuf9&w@wU zexG{f^a1<+NA+4{5iILOwFbu#2GMobuUk~t5uWXWY#Z2hM^{Y4xc zV#$>0f5``DxZ2!juetvbpAUca{H(fR%!ABXvfwg1TxZEmJ@GPN^4~tUm~uBOPBHqZ z`PliGy#3AfoO)*WkoEoD^IsGfGwx^3gKT}tKCsKx=K9O>@(*^@Hv^6}e#LoU#hK>% ztKO#!zh=KS%*QRv88Vrd|K^%m(|(ob8FQ&=XT|XA&eQ+7&o;+6!h}1Sae~2ubuwhm zm~%|Izz!>RxxwI@;`yiN88YD*Gfr@h2UxOT|F`6iZLTt6kCPm%jn5IbuQm>Q+{fgI zx?;r@M&DIm%{9Zmi~8cyeC+?8bHaq{oZ;r{T;%U77?;Tp>6fy zxb8*%j)FR6mkBFQa^|RYF#M_KuBSgo+5VaF8FHEtXW6+%yjd9KX6?{44dy z?r+?`zHxqQAGx?9&ukyF?>D%pFF3AF*yb2RPB7(uR_rwGC)72ARp;bitd~33K51Nb zIM3{qyfbHi>!QAbLoB(C6(hDzn~!ZyFya&w=FB+9f(tCU#EKPLl{#UY12@#4TbM9p z#!(jB&60arF=KSbzH^dGY@KyZZ*)=LG`BH0r~Wy^18lF^N6zsA!)wiVk-Tyjqx0hD zA`dhEy*lJFH}{KcUB0-+y-fdLpSZy#W`8vQ#p>)&=4Z}59K2wD7Cgd{KbxNw+cy^X zU(_Gl+{uW0m@s9=X%?Ji{8#U5wtDh*6YJy_wiz!oAFxvEU5nd5G=5sSA#C z(||hQFgLi1$={tbc6o@!KRnM4*PHv?bW?T9fWe0T9OiZwoM_saGx|UEz?>EP|Eb^2 z#K(wjr+6>dILrR)9IJaAzV5Ml=gqBe)3N#h6BbN4&x}Xey1}u!wb^t3a;zR<%$-cR zhdEPrTgUudg1Wllv3m0@#C4-%^$vD8&itZd^&$4S#I*ldz3G;&xsBnCkJT9y&aoIc zRuA0D`fqxy-p=;mv3g73Ifg74vvHpB?rX-P?LEaUSm@-z@KYtj^iK-?4g`A=epk z)9uX9fW`ei&+Y?`)l=*-XAsIOLoRTR7nnX!zHYBBF0-GEnK5{f=U8x^$%yp~8ILiu z2YZek&avbIyIf-Y5c|RLhsxU>oKKFi#|d_}%OATu+}vl$;BxC@$aTitbVqSAV9sH7 zxSd_@Vvh-fhuLR_+~2fwiTw|k*XBM4?<8-JI9Bgw{z&`5_M^Sn?o8cd7?w zTyNT+sNY?^M;I}Al78$xSzOGYVn5k_n*DF9JMLvKwl8cw-8o^KYmC@;H{)|wEV+vn6SiKUzS!n|Mm)%b9cEl)!4;Ogz-6{B^?agUm~)I3rx?D_ zIby*sgDX70RoonA#_cS)izO3Qoa6@gGriKfn|4+V#;xbx;$z5VCX8R?y}%CVS@I}* zyujkc>g_(-8M5RkyWGu+d)Z^g)=Q4nGYoi$Z60CBE@Q4SW#4_RpPSiXn_Z5u$DIr& z)Ez^nj5*Dev&?yz9hU5JnLVyEc&WPErauG59A?Vx>@s2h%Z$sM^BjD+I9YJ;e%{M_ zt(zTAa^w~Ei6xgg`pRQ<|NV`}5stmexn#u|j;HE@J#KLF)#7-7e7(m0bDGl(UTc2N zaEFd=Ob6#MFtp|#OgY0oDgE#mbX2_To_cPxoZ!EdS?2YWCe#u*cRzwZC6J*#3a$x%LtD++5G9XQo_Z#=h<5`ET{g@St@w<-q0U`U=NWz8K68w{ zrk(9as*5jppD;VDE|_zcC66@iU$#yrY&}X|ImnD#nR5pV#_Vvsv17gLa*nO9s7p?> z$C87Q`(N|EVUPPcHm@ESU1i>;{TtdJZC|;!@tfAghzm@(#Ecb7_CH3yZ;6ldoMdpd z&k2sQIiVfGz$!h%OwvdfBVY<*X~joMdkX2do#j0eU0atb2kg_WrrEV zUx>T8=22!{`^(lZ#_Vy5{kJ;q?*eFN z$qv_9a#L*n;CLM}<|vn$vd3wT-P(N2xytr!#QAjdatmYbV8(<|EI52S<1uI7 znD}mgydGxCxVavZH|9LV_8pGb%j~fAEa!}athkjM+`-_E`g54$jJS_uJiwF%m)T`- zC-Xns`-N?0+{t;S>~WUETkIPXu5*ULbBx0sjP88g&)?|JS+4OYusUB(=_ z>+w3{BoDLVDo5M)<+;|$9qe&};oXkcGb~xM%VoCiZv5w22RF0LHbagu;!eig!-OeQ zPBY^y*Lakzdx(R3PW5^Ci+2d}uA84PMFyjnoxW*$)FEjrO_2*^=4>|7V zb&St_oaRAxS+f05aWmz>72@VL2HVvM6Hcte_$Cd`?0jwKh^;}Y9X5I19PFyp{Wt%qA! zF=Vh)-WYLrbNxi?Z`!%Q&Xc@nm_1p1FEidQ`@@8L*x@uw&N7JYwFAdX@3HjUA4${|fPOkR@ZTGvTJxIb*;shuOOFc)gtwcQIwcf|E`AxcOPW zNWHvTKkj73J?t@M>&5cOfU|7#FhiD%xXhUAOt|Sa=3~H|!|ZT7yWGVd69z944@2%} z%!5qXVa`Q%xWXfhoQuX++Bddd z<@~*lspmM)z06+iyfA)^b+Y|h`}unDa|h!|=Zvk_$rC&5u;L{e$Q2Ir0!P@|=e^HCj&Uo;xr398In8m-a3AM*fb%T4$ayaF zDA%~k4ffdoCV6|K`8mX4Ze#jp>tx1R<~+=TB|BVZ$#r(Q=}q#%fISYgH6_msxQlHj z3^~b&`x)~f6Ly$#kr`K*^8yRD-fVsjvgB5Fxq}sB_BhVgTjYf?XPNLYQ#f$ofcx3zL5A!w;v!?NFyRHJY`w+&9AwU|EVzRm#w*ki?3 z=Kaoq18*}gw=ibNl%veKn;q_Dml=DUVes$XQw({8F}qB;#+-h6R9}ai*=3tOjxcz; z_Zma)Va${%r8}BgAzq_8+pW!?8W0xs=oM!MY&o}Kn%$OxpE;HvkJKXek{TZ;w zVFvG3FATYhF%zboWX}EU@F2VFu*XFP`_&6WUSQ1DJM`xub8cmaJJ@B+9>*EHN4+rQ z0mdwta-KPlvcpw&*<+9W)B3+xy)fi9#*CP9j5#OR;S{^f+2b68_o)|#Tw=_MDL0sN z;GOz&3%d;2<0yjz>V+ZqGG@k_g&W@E_t~!8L{-HvfL-h$D<=%*Tq;O#jpP zZ2gyUnRC;7oa2wEBX+op(X6^*@Za*wipx#=|Jbkhn*XE5XM9jRY=2BV%{31-?L5K` zyDa`!zxVlk__%#!tFVt8Va}9uoZ|v3E^+V^_K`6+m~-HO{Ba9|PufSu9A(bkO*{8C z?VqxbP5Yes=H#c<@B78Ym_3d&{EYf#$^%V1i>96PP5WonZ`01zrk%Z}o&6uM{zK}Q zF}E>e#16+;ae~3;teX*YrkrEJ1$Mc_*5|F8Avc(C;Dgr3Ei4(b$5FPwVBL(lml-p5 zIKzsE7#y}QjM!z$H5T+gz5BY{%+?pxFGG$n;ZEkX$JOGh@jPmsxS0 z!I#zBhs@7_DTi5bJG%8`At#w|KXV>r$qsv5Wcw@jmoYCeW9vW6&p}q)%HXT^ zpAloG9B09O?D7CxU$g%VInRVgnRAuFRr2v+*I(Dpc)@%#?te@C>|QM&jK8fu{?qk$ zSB$#j5$6>r?K3)V!zVfxR>8knMBEW4xx056aVd^DtX? zpPfIr|1tUeqxG9;ph20ccT-2ZqK+EpYZoSWtl+o~XMF zH=n56pAz>iPt^Mu1SjeXtZsdxPUehvTjMji53;!Qgr9fwxqokQ9P<1&{g^!9 zgr8^g@8k!bsJDL3d?P37DOL{=H#?V~@N;VZeZ1pDJ;C5n;^ZKg*k;9q8%#Oy1@UqV z3x+H?%1&fn_Bg}p(dKEcxyIIGPSkye&BM)Xv(1PjOt_OBPI8U29DeMH`UqR2`hU^< z9AfKnC+h9&f4q4)$Qcgv5J!20~V^%XQ&SboMW2{47tRJ6=QBN;lNjn&n?UtvfwC7?qOOls%J$3Ti7|W3*#C9=$RQ>#w=Nc(X1G_L7;%X)tET-G>fjst zr}l$AE_3nK&c%XtyjI-IS+K{WOkQWb-{c#dH>R9q#{FF0Ctqy8S-pSDeePs1@(M!`)^YpSIg(y^=E7PM7_d@n~umYhnc?1Swf5&(nVf5Y;^*9U8u=PIsz=RttIs9Gy4ya2;@0T~mTx7x( z&ahQl-;8)0|5N?4_%C^6`Vr4Dnw978IY<93KWzPv`eW~-^1_i%i1YjM|4H%vz&xK( zKb+(e(=Y13==rOh3%0&49}Kv_HkTMKsEZ$(|C{p9_-gmrI$~YTHQPTD_qVmP_>THu z{yp*kSo}=6{C)2~hClLtJ8Hd0?LSjaGUI-Z{KWoq`KRXniE(~*qK+9XdH*)oEZF|J zePj0;^Z(R7aD+YX5PfFgs=)jE);;$$B`#ggaSsAHx&! z!;D9nuZr*I@_$l&uzgBhFZ!-3oeNF--@H$LX`H`%FL3!E*3Z0ewQl{&cpPMhTe-%V(REhq zNoJc?>m#gKarg$S_0X?9&mBx}xLW7z4d}OQ|8Kflk2Bytj1{p7lAC{LpD$UhGX}R`t&g%`kIP$D>w_zv zzw>In$m%ZQK4u(lW9zP~b;J=)FuvPry~5}otM!)St}oS}B^McNH7;j3bi(@YZM`fx z&Mx%;7F zmEpte*D3KmT-?k#&f!PMAInFr)|*cI?{ANhZx)XeU!^XXvh(=W`ViA6n2-HWl>alH zd$M@h;UcGZt=1dNo}&G%ym5@-Q>~B7@oHT%f4Y4#^ng}7pf1IoNVrM zKPw(&j~%wIus#M{VZwoR<8nJ^u9SBUj+?)^|046T^3$Sag7PPQ_eB7w-}Fk zwpx$=)qSSS|6QH2^>*uE$P3N=cNni{9&Y0@BW`ev{nP52gPh_pbB=J15f_+oorCWb z|KG&NU5wr>e=PQ^qrZFZJ@Ub6jx&FsxY)|Y@ej{&7c1`L%!iE6@;~h3hIl?KK1Tmz zT*h2v!WD)eb&mc|I|F71<$*m;GWnRe8GPLH40(a=!a4Y-d@^BcPCEyAfx~Ro*3Cgi z+{&0cm@sC_ah9B6`_uNLY3BuY82By4ozHrn@#oYl3of(A)^+-Q56ONo=kDhE3*MiN zhrLhOVQ}64zWFa&A4~3LmwQ<;V~;azeaSowzHD7=chu+gjQwl&$(vEgPh?a z3$C#Bedp?5`uqAh#E22cIL4F{%s9oIISbCQ!v&UHV($#?#Jr4iQ zxxBId+{w<0x?qnB>^~-N9OtH+SkH0qRYoVQm+e*c!;nXs`|NU_tpR!FAloP9i5Vw2 zdD=SJW=%OAzf;!nnFuDQ&T>+CVOg*YzABa=VNBgg-$ zogHqzrG4(HBW8b-H@5$-ogp{f%K90w^$+8)!+nf5#=4ntV90#8Jy}N#FVW8K?N0i;72>)5$$I1t+PRbS+`}$YMnmRh#*+D+t>cdR zaf;#HPS!_Q-Roq%`A)plIGo$6o&EPc>F-q-hZ|hpcCy~GMf?5C!{Pg%tPe2f0t+s& z!-`30+&g=ZJvvc2KU};_ zo}zBpddA7Rzs+aLEAuh=XTbyPu;Apg#L48@C+nfRIS<^%lo3mgGuW-pns##WyRt9n&*xBvGXSL zvE&SUQ|f7({%=u-EZ*ihR-9xoZ5(#kzMp;^Ve6fq;~@7iWXe%aGvO?k-)-FcTlag6 z$1V?Z@W<`;c?N)`!jWK>cRq znK{R}$O%@Q;s$dD|9P^W<1iQ4`H1{pCQtt@{>J|iALqHjE(acDoR1op`9bx=!H=D+ z7ujWN#Czl8>W)cay^KC#y=;F{-E;a=>ixm;I4581a+(!q8$V;cj6Q3;hd8esW_rjv z7=B)zHrI#k+e7u|FgLzrzUKPN+S&e!^R?ac+{}z2dz@hKRr%oX*Tlzg-h7u^7en@# zFuqE@*kQ@Jugk;3Tz|v9vs^e?ci8==`wtgCw{Y-V#$m`&j&e5>?&Tyi7FXMcrv2N_ zE$6zwy32f2eGWC?a9%J6$%LjWr$YNc+aqSP@Pmk69M{#iGPxgteKg%=w|02Jmp8u=$v%@8p zthmSxMm_m>oPK{d4>M*g`cBn*A1`m$Ipurz@_XG=^$N2aoT_J^pgwt+IZLj!PSwFq z>$=gYdYoDRsd|Bf7oVz^*k#3y8=tB-n)aKXst2CPON_^Yhgq^@#bvf`cdA}z!r)2P z$q}}1ZywHZhT+hudXXjjp3FO(s&}!+y-e?Tsy@_sr&IL>wzr(}eR%!2gArrK9B0CP z%y@tW3znQ`#iNYwe5&qol7mkX?_EySqnzd>gS*Nf3$8S_Pu1I=Dj(d%_-?1_{f&2* zC${b(FHh5tTi9mEkfV&an=$vYHGHZ*$TmAoI~SR7g&8k!oM3^E zVRY%KdW~HUJzd_ojltGab;N>`4DT(EEV;_+KBs*D-E;R9A9H3bS#V?9sk;A}#=GCC zdMAtfpQ@+1_yFr=H`IU3I2>V*JK1{Rsd^6srfhSXA!ix$FmrZUa)WD^>HjS2dyxDv zWX6~?OnHbokFdiogAsM}Z1v79>~a^!9xP9+c$n!!)N$iO#rquba=dZ7aamk0j|?6r zkGsXqZ44PP;uvF2FyRza=8Ze7gT*7Q!^c=ZORh71tonVvaULfgrcZFcai{aKM?dai`-$dle3JcVmqY(5K5k== z5nE5TP6nJ{$SKCmnX_b&K8e z_i&DBbN@>30meMagsV*1;~a-xB7W{*GH&0QzDWL9ajCg}iTa#y{ZjS79uKqiGV9?8 z*I97$OI`1^9}HjN{l?)}%InL-_bU6v?A6}8tX|`DiqWM0>~QGi*7-W;k2&|T^?LC% zzEQpHwSJ~-zsdSI!g-GJC}XZNVUH>MUtxba#Dd#cGGdow9D9rPah!)a$&%At<_y<4 z$4##k&s%+tF?feOvGY#zyvqFVmPd9u%iulY;rRQ^pUTVo)dzdbIP(GVv-+TVf3@}x z*$;M@F!~Sm!-^&QKP(=$X2kIt>tMj%N92w1N5#+Lp!V0g|1sy2YlZuq`Gk6BI;Y+y zJ;$9aIl+qi+4{7+GiSx{Gva@p>(6?hagF;Kd_g=M{<3|4y>UC=gIP_M} z|He2R{H^+9hkbA3@6;LNWA>3H_jB!paT%Rb2bu9X!HTntPaB85%D+ec-E(KuJ#$X5 z;w*!+;^rhP7Uw+ocJ187_L_MabCR8F?LS-R?L%{)8=T{oceww1?^TX*FXMIl&)^T% zGi}}6$_{t4^+)Sz?*B<$a-Qof{w!bb6!%~37YF}pKRM4H^PczByPSu=Ime9t?mfZm z|GdB6Z9V_AJ|?yEwBI#{xO~0S^%#>)r|Yb_&l%=C#PIs3>(%C(Jyslek38JqbR9Ce z$?1BW(alcRYh2{ud+p23PuF|6c#G5ZEH`d>x?W;_tJC%7_Zc@hUB?{dILEk;<2=Ag z7F-)VUH2dGKDy*|J;a3DInN1}oZ{T=#oJu-2(zKn^#%(LykGyjc#b`G*uCrNx?=kt z;`@Mn4vUX5d(0So(0Cl?*gfTm2`89xiWzf;_tKvcD<<6FBnNWq<`(w2lkH1S*LxW< zW5gN8Jj8@Yn6k@^YwR-kki6dKwC^8U-~CS4N7>;jdk;A6dxZA&f#PDtISyZD9EKzE z_+j~Y@aZ~YF)F_QGVkNf&*BNE>lKbY@pQfIBj$V3>3To&r=0dZKlS-E{n(Ag&Gr?i z{XGKnUuhneTwui|_K(X4+uUI5#p>dJTr*|HStb*w>yeL&pA(E#KR#5Z<2o|+|79EbbXK+ zJIuMrd9HAg7Z|)neSE@m+|Di&u5pq*?q}<*#$&_|r@73W>nynGldj)pJdR}QmJ#sU;$y%zhZ%BvbAMXin)^&R!by&EKRZ0c;+@88uDNN> zJPg?7Fe`57{JX@*_Pf^Vk9joT6TPt_~iOQ-9@>~fvy&+Wrk z#K#fF*H|YDPO`)OEP0U8FVr<-cA0RE)9m}I=ee0hZNBE3DdWDXKE#Aan6k^9YYeYb z)xp=?=P;+ao&DFX>Isf;ilfXKbFT4v#^La$svekEha6$foh+CzyuN;1hq_R#ne1=OTODV00t%eBHXZox>MZ{!W5@>aXg8YZq7bJmVW%7jq7L zL;FptdIw`B%sJiMAE@eu<~~=O>zj&a!93i`Y3^c|DU+L-hbiY7+`OvSIme-I+DC5Z z+~%s@$LJQ~XMW4d-y^V&TZ@;i+sYr8xyrS{%HJEXu1mzn$=lm621C}t9@|HZbBC(l z!|;w(JtlLXadN(0)zNqKyIWO{G2$ds&Tx%Ojdz!? z@5;+P#KV#^TpX_I3rz1-`JN^(wQffDv0euE6UX=X0P}N%2N{RPW%)qu-xuFy;$Zus z*56!juj=pz*7;F&!@*Cgm*)C&+SxvA9~bR6w{Y=`=419{>tfllUq3YOSH#VXF*{eO zcZOdVH+yXVNFKkT&RB3ClZC48Fy+yv{hQ9gkF|fx`q|+=PG4QsD-6GFoTK9Uj&s3f z&a?b(RaeYPdHIQTf6w`0&M9`7v&%X5xWMrH*2zh>e(L!jSO>?K+-J%jM}BTyKa=lk zsybux3+Ipdugte(-W7RgeoS4kWZ%!#B{#FjHiP5NDcju1kb9c@C#w1Y3m##*>fEt+ zQogRyeo7vgSN4S_wVjA*l>PWT<1(Z@JsVw_l)01 zZynstj47k*o$-6<&BH@nM z4!F3Y~A&Y-{bE2_L;h3c(*h4(2DhQf}?joQ}5^4J;cEdFR&ao&oS}d>x|#SZatTt zsn;2C({a~Z&(twn_dZh>jJU{{E6mwCVH^%~nWJpo$Gi+U#h7!@jC~zcckRyIgPDx#^^M?r$E(+{tlHFy{dlELiag7!u({8YDc4wV;GFZh(>mDY1S?Ll$DI97v>!}) zw7Ji|HSs*jdRTIlttVRtL*^W1hbfntbDbTwuGNo&Z0$Nz?_kJ;qs*9cju{tNvSN?@ z=f(9D`@oPp8F3FYPP4;9T;x&q*kkLd`v2Z};}9cmXUtv9m@;^p`8mP`MqFYmR$uGp zWt-*G#mz1!89&2$<;=6y1FPrBJIfc?mp|C=7s^ZH71qO)8_YQHNBy{k!&h1tEAHX) zi{z2fi{<}M?!QEy*yAjN32`#zdUK!KE|}+~>VS(p$kCU1FErQO@@L~RWRIh4ykALQ%tpzS@iY5?y6@@FHs?9YiWBV5t(O5iY;%zzR~YdEH$J3}{w7Z!wr-Bkn1>m= z%s*`?zz95uCbuR7;ej~3;uY0!cyY9t(8`nGQ_orX% z^X_b&FyJK1>z}P#*W(S&)*&=_Y$B4y6XX~6D&avbIyIf+$ zial;H=|5X=4bq5^DueZ*?PENUY>cj-p^=E zJ7>7gE`y83`E2ct&#_-OHa<5q+bthl<1WrU&;GIXe9trCJX0QJFA?WW^trqZ~g5!I|+4zdHb&o0gZ)RK$vHMEn zGf2_^j+&`UaEg~*<<#7b#*)Aa+K8%oi~pBM827DjcY$ukGHqZpIZm> zYn&4njG1;l&$(YYC+z;(zO(&XbwA|(@6;W~j;T9FC)F!wPJ2Ia@r?Z4!Ti_SPZsO) z$MjF)<;Y*1BSt;XGq2_Gj^gV(SMOzZ!*g|qt&7gp-RAy{&(*=5^dC4^M=b7iuAXKu zJm>qK_W!bT^#oHMVEmwSzVE63L(chrr}!^FSI@D0g#LHY{>XFn6uUgc)}zkVOU&4J zSNqE?>@i{(o%4IQ)ir0E>qnofkFxa`&$rdlW6#yY3^~e(yV)KUPjk(~&GqBX)fL0X z8~<*ucb=K37i; z%foZd)dj=no~t+AQ`{V3$(_ueubn+EaV*jAUiS5c^2XMc=jvUTUfegyX{O`n>O~H} zNIth}f3a~Gb1%b}$S)%w4#XFVcO^GUEa(t}xnkzV5rfd~q{VwmHoa7Tn3!4bS_% z&*I?L2WY?1dB68r{x3T3`;zj)c?SLG>x!+5Jr|0DQyjkWdB5*jyjBi3>2^YsuDj&hQ_8*d|jtXQ#qThBjO9E=$b8kb|2h?^Z=Xs&N( zyoVT%+n6$9#xdrcVCznvd#HH1gRQoC*k<2$<8w13wprZUc$bU!KIUhe<80m6zOcJZ zf0p+%?!(M`f9vNmQ$`Q)9J^d%D?DHK7;^C8&MQaQ|G@LUKPi9AS#W{TWyWVRB90x# zd5C&rYrFL`;0oKkz>uv+=*L0E+{%PIm@;P0aaP>V_;T|x;Sy6;%(%gv1CO+S4?kaL zOm?V8mR#fDBjx*1#$m#QlT5jv9Uf$lCBsKKM~u17gqtGIGhh*&uS1p`W&D`)^$f$u zSucAWdbB(|US1e8Vb1;Ra)Hqk&eyA4-p!%*QoQ&VRpHl!EW`! zX&zwsTyZnqWBkXN@87JO!3)j%c=_ift1CRmXs>lKdxiBp!T8+HbXcO*C?mrCKX+$qN1dnl5%cRPB%(Y%IQkiDJiFIoj!5>i>D-NH|O! z2(P1juqle4PCno8H?te2Zp0tlyoq>%(VJ<9x6uyc%y%$y3*~{~7;@>Lp7OjKJ?MiQuoD^&G9I8C_CpUGh6$L2u?5-%M*e`^ zh1fqt{KI7!gBx&4_%QQvH|2qK&{!nCU>f$o=zr56Z~@N28k)g!TVR`&>-^Ptcz*u}M9l`~Q(I zOvA<={F;mpn1FE@a2+($Fa$SY7}kD(`oKmQgVzD^+7WVJ#Yg0;WP}vc{qCfLDT3( z?^6Q?t^9z^uqxdfFm#h6EF$qp!b>h>%%YXfN9tZlP6Oj=xI1;&cXm(gc0ca zFUt9xgJv^y!#3!F0qBK2Fbs!a1dhQNoP@J*9(FyK{(_#ygJ$1Hv4as9gK_A2{y{SZ zL$K;n#uN0w4cHF-|9a32!zdhwNtl4ka27^R!7faFpa%|l4w~K2`+|e!C|rg~=zbC9 zfKllA81-txKdgsAn1*98{9?)jV{j9uV8dnDzl8cjKMcVz9D)fLherOu^ur+-f>AgClW-hvz$C1B8TQZ( zT_2}@unxvr4w_vs1qa~JD`-d9^GeDKC*THbJ?)_B{sip`ebDQredIHYK;zX1%?0^< zI&pCY`mdp1p>YO&V93Y#8X*5O@ejRihqKjy5T5nf(ht@(O=RJ!e7yDFmmrfGXsrZll}$b07hUGj>6P^#K$$r=V?cn zet>ew=LfNeZa57${zU$;>CXqv`eEiD*Z~u80D9BZAEy3-pD$wnSH>6Ig#9o&ykf>+ z@=Ggb!AjKDN(x)1pt>|r}h!y&i<$Drr8)C>B5w_?`agx>x1 zCrms*JHiE+g3;eoo-yhN8({)^;Rfu2{ssCChG87W;2ccB6=?hc`>)|2Hp39?fDzaW zV{jO5z$xf`XvJKDez*Z6u;FIrIoJY|i};5da0LdI@cVW0haE8TC)yWAVHA2FT`?D+ zAFe?6UslYvaq9n9`U?i&C=5MD`@ty8z$A2k11{6o({dViDlJcK@UAEunp z59@ECeV`wDR*5qhf@AVILwmv@SQR7R^%c_x6R;149%p>PG+Y$!I%FE(!mi?w*$hK4 z03(%$%z2oCu5S~MRfo(v=s)(5>4E9$Lp+Cw{_%%+{*ZijAL98#(oew8t?2#pA#)5y zU=n&xL=Ka%VFG#GA#)f`J>!s>hBeQm9DDHxJuv;8LuNlTF2fIW!%66YNf?6*u;+68 zLgVA)yN~|*#39oUjVlhBUC<8)VHn2X5KO`ZT!yU!hfMc=^goFmtht(U!Pp4(f{E)6 znYD5H<12^EP8c0MWR64k&Dg`pIQia2zAy+Q-#BEBz=dxfGG}1;FSOrx@B=+?19m{~ zUk{mK7=lA^^lyjE4cK+?5YG)VZ>}6NLof}aa1%~I|Di+X9Bf@9ze)VV2u#CC=zg61 zzKh=t$_0mD8w~vYkl8D&I?Q_)k;4`khJF}rTfz!0pv6F;y8#$W)Z;Q(|$n|xpsoPnW}51Ymmdaxe) zpLf{ogGm^NL(e~KR{fATIOVYEg%Q{VV@-#7K96#|{IEIlBR;?Ku<5#s^TcZ?7fiw! zbf1C$Y1$LEzzx_74Ik|Y-7pG0Z~}VaGz`Hd7=^}FI0#d40vi6q<{YetE3gZ?@5Uc&g)!I#({K>F-$=P(6HLMYT!ta&n!!J8gfZxa zDcA+muot@jo%Vnp7=r;g3qx=bj>4*+Vh`Og1zTYnc0l)=Xn*K|5!eMMUgj>0F1yM7=;6{>FvZ744ub#`Z?+Epnc$G7ySlX-${9Y!Tbb$Fam=x0SDm* zoPeJHq~BmGT!A52cMoy(F7k!OyU7oF;W%uEGcXL(Fac|4sUK{Co3ImlE+jr-5>7$) zd(itOpP^6qem?(-_PLnP(C9sE&O<*;!wu-Zm-hG&?Eq770H)yx^nRG}4a0B|#$eSP z^EqsUY3PT6KI~u$CSc^FwEwSZFW3rWumdJwH%!7XG%jVlz}7Hv07KCD4dwe7<%OQh z4x9Zj+)sPJ#3zv7N4a4$^jtwZz*g7?Q=cS`pz$gCWgb7U4TfO|4#5aCK7;(X$YC1{ z!w?*T5tx7za0AXm&sF$^t6b`@y9Dzv~gWfL?N6@&2@<2DNd4RZv4bTf)pdb2S00v zJ=jC<81}H{YuLk{n;EZg`RnBS5c!PL-f$E4z}N)i2YUC>j}PM?Ho^tyg`WM4dl-R( zFbyXpJQfE86T7MA56n>xB(N;^Ih5ndf^K6!>a%0{02QR2|M5>?1SF# zF+N}qoPr6sB9S71UG&{y_c|?K@LMdrJgYLGy3sQ)C<-_?=Kk7FnSN=gFUn4EBqz$Ka&q^h7s5X z6EFble?@;oKOBY8d&wUzz-1V^kA8g=d)NmfFaq84oH=Kq|a2}@a$M0W|KS23m37vVH(DvCrx|64Oss_4)(1f0P$S;2ccC4VZ>C zhw)dr%JYrHf7Plv4L!%M^4?9_8+O8)e_Az{;qp^f%~*zfPgph6u)cPc=N73y?1sjP ztL7MV!$}y1X_$bu>-1yYs@VoZPhU0rq5m1HyhoGr{mZIZ_c-Nw?y4DqfyPyyE5zUP z@xOt-2fxt!f>m=Krl9e6_`+4w4-?I+<|qumY}H(Vp_i|k?*E0SuJRsC{I#r_Bhdef zRdWtbK-UwbzjD=Vg~n;Cyay9GjKSDzS9wm5`klFIHf$1?um#4>S~a_%ap9`j3;i$( zBXAlfVOr$f)c5}(hhCV5VdxE!Kiq(||HtR|A%|fYgb5gdvmaPBXW`}tS9w1s<@_+^ zFzFBIhbh<#16Qn?3D^T?;V4{$37CNk&~WW`c?Kvy3_w2&!!8(wy)XeIFa<|p8pfgL zle9NX!rEQPVI$nQ52zt@!3@~Df}GeuOdI#0vE1cHA65tM7zV(=T~`8Ch{*(UuX=|@5k)sdvU}w zT(}N7bYH(}uE0oimFEqq_g7cV9_SxM4pTSM-_W?3xIAvRtLdA>he3I7p?q)%_QEL` zh0Aan*2kz1Y=@2iL_J_TjKDq^gQGABXW#-{hQ_xjNA+%(>)XWnt9QG6x1!JIzy$FJ z``{cLh8u7KHXM&1=!c827p}k&XzZmP&2+$H74jU7=gpE<@>||oPssGY3Co%Zm%VO=;d?gox}m3o2Dp_e1>CuHhxI{d~Syc z7=dXRhwc;5{}JVZahOIwbl0jm$mcXnLhm%~at8H*n|${Fc-8dPQvRPXKak!72l>1J z6R`Gf>H(W!{Xg$^O~MWsouU6>0w&?oPpQX=#Pb2{U~Q8AgvQSqFHa?Z*a{baK|8?l zd+0AXHcR}#u3yp~vvBn38FQ?jIQW;0+5K$#zaeAJ!xiW~nf`oE#vFyw=VnY- z1LZ#@V}|iR(3au7le=9bZ^)Pv!nb71q2~~%XJ^b59C~ZUbU&AJpOY~Iu=m`I8HXcp z$L@K=|GP8hFkFEN7{4%MRyERY@5z|$(0Ff#_o>mZ@5`9=uiNeF|3JnZCq45){KN2v zGiDFziR&}w6!eW|c)uF+#T^;5@%fDBA7ps1B<=VM{KL7~jM?(9@Ru3hvxfZM49^GA z4s-Z}vEO8PuNw2teHn8Az3$&-%xRc`8?gTVjM;F?ZdXSNIeOg>;GfTZFvaJgKTz)1 zQ@@8Z<_PJvi
    |98eTJhTgJhAG$$m*Egx`Xl*ZH@TEC>)t@TJc?hq0%wqS{*`*Y zfcATgc7y)qj5!Ev4`$3c=slD%W9Vn#GK?Qa|AqKjCBL(XW7q=|nT**+`V0)hk#))q z-5b;o2L2!N7g3-8%b0zzxnj*s!{9M%W>XXGecYNkiJzFUX7=zobo`o`go966Gy7gl zT%E9H*1eIqs9iI=VAqLj<_hUUaGKAvPhB%>|DE=G`kLu}33Av1`%YRj!=$&k*USX$ zea4y@Aw3D>Fa_sfuJx1?OMCW;T;P zdDa@wLy`|P-a@rp0|(8Ox;Pj_x57_+aHM6yY`t7HG;rtzIX2V-)&pX%5Ubr+({^ECL z&0K(WKchc5U)LX4GrM7XlJ-S!<<`i_FxNg>W5%*7BH@jeW-MTpfd!M#$&P)2!*Lj|bdFG^b(+`8sST~2@G@ODn z&syhwaeV$4(&5a>>t+U4J!jqYUcmYOx#&U9^YI@<&$G_^-IyOt-Jew62>C-HaRGy4f#0bKP{khjx3zx*3M< zH&dSX(obivo8z$a9O``$aq-S|e#e{oz)`pe=V0Fj_zThR&<|6v8*ah@Sa;z%??aI?mF1cu=x9E0;P32UyQJ{MCC*am~c z>*fsXfm0t~e0_1CIMZbssg>9s_Uq^evzUwIm=`B(6f&E{>9vWYz z{Y4-8@aMaMc7p*p3R7@S{KE~{I=XH)UqZXX9+-q9a0R9${ibz(*P8is3_oxj&O_sC z^dlU*nS4IXJTOjs!1iy@UeLH@-K_lx^@i=RD@Hlt#JAS@9clc1n|k&!&ThpXHca3j zw!%>ufHSafANBt){C)>HoQFv`{=Idx>7$H$*a&SMGA^uocrX?HjdCtz@9o!@gt@2B*` zW%S?AC?5_VdG)?ZGiCwr(xGB`N0k7{v`33 zA%0-<8si_%!ciDnr#)fSILeD1Uf!+U)_<`~NBYxnrN!(wF zz3Xw)4;x@F48kFp*!8%XhH2;;q}?kX=l6lBH*AJs=!Y>Fgee$?M&;u?*TOi4F&Ki= zFbY#J30L3-G(JuFsvb8RU;uhy1a`m#48b%UfbL@+=lx;i596?-8vV~uUf2QUU#(DiS-8*Z%HQ~A1U zE8g#O(F z+*n&(*}jXc=70OU`ycv4+ws*EjQyNXZ8@KKX3^!EaJ~f+^DV$ z?b_|@$g!-hWb0#VN_gvMS2ONByIiiW_wO~AIHs&~yV_KXR50yHlT=qoX*l3CquQno zwJvOGF5YWyLTm;qbb|3}8QT*L&F*)5}>$thFH8U{|W?2mR` z?^hpv_?*Y*RR3Oc$nv>T*r#2NN6TT-sT+mDUdE=o%H^uMVy`LvN$eJhi@;VN%=s1f{qgMIy$sacVvIy`TCTdHGv|{ktN&Qy_!?r)>fge$&N27K^GjCg&rc~< z)^U6A1*TZTO46NwPWarb&uxwlOpivJ&rc~@?JA+ z%_9w*4o0f>9DAcd`KqcpEj0MW$Qoa6`vBaV+(7bD~avjdK@qa)fflncvu!FC4GpCy1ZXTZoGz`b2Gc z@`*brvt-UcS!+$(X|i6Ef8u9e{Gcc67Wz)D-5fts<_z*_g>+triSOWK%K&aHK`&v&_XYeBCAn}uRFYI)IRR|%`^ zV%F7!T?D)Ek64FUd8t0DR-Hx|$_$2yT4ExXvL($pQ3an zu^Gy@QDsw0S$l<}Pv0)FYpkIy?&6$Q+%BB0)Kj`jMOx-(d(BBJj<<`WMccUw92!26`&rtu>M2}@{G9Wwa=d$M zTiRWg+s{%4FE%y5wC94h-MQyGmTk2adUSK4zQk z0^1GC)+*l~g9W~vVO%cJNuo3GE6yWUTR1wEEDw~D=EoDr!9Hgh?06_Q zu11n;xmxV`HGV9e+_tEQSq=A)=y}oGL~nMh9;KR6T5^5Zz#lWH%R9f<92C7?ou`_e zMaRb<(*)0+(3ZJncP;~SmcO)2wKEHFtPfl9k;KRJZ&?>wKAgJQbC6hCT_Q&+N;!~W zCG98uX`JA44gYR0_rv+el~UG$k1KKGsYadgY`-;)JtXnyMZe|#z2>sy$3Gb-?WEN_ z!2B#}omm$ux*uw%2u{uwVW-VKs19P6#!ii|9J>m~&@$t_1PvXEb?{kc~%*%lycezEE7& zjjZj9g)&*I$iH2eb+n)3V)yCz(L-Y=sib<@{|a&_@n>+I(m`Js_npg(&%dqntz7oe zXk5G(TwhdVwq93N=U-m9WbTl5pBm>}%D6SI*Le(N_XcEVfNdhC3u}*tS~g3D$iccJ>=W)Eo;s-PSf^29X4vFBW%b=^kuCXLqEu|@lvgC#pHFz5@^;i5ew0m zdZo}`5dCLqeapYnw`Lky=*m16ML)n=dwHvVHs+ma%wAVZJ`$gE*bRJ#y&thVKATU@ z7K@x4?Nzlih_k~_Dk$ygW{q#$zSr!zhFJfmrG7VPyMnoo=v856&vvTS?YU3QNj}Cz6KhSczbWfbwvseq&|K4 z>0=G7V(YQDIsi+>acmse&WAobi3_LiRE4BJHt{iq z54i?2ZqYun_0gf-D^08IS~yP*u?`MO-d7jeb=%t2PVLe2@z;ahBz7^eyFlCJ)!T{! ztEyYe?7=RMk2==dty1RGv=2^K)?WC6-D6U}1$1Lc#**lst#zj>?a5$|aU*jo+dmTF zvP*)EkH0$hW=2>GHDYg^k+s`Zu))eDV&!O+vS%uJ;PCW>>2h>9bFw-ENYC1fG>)=Pos&C$y7^1vtAEMb zn=u~laAK}EXI_*OOqH`@5w~jW+8yCsM@sTlAZjmsjQth% zCkywAeE6$17#AD%y!fbY^SpU+x18+mg%rQbU7G4{XKUZHVN``CJ~z+Shi z+bucm;arkS4W)i#_=;`rHT&o>;}PwvRQ*=i3oBYb@wbA%S!18sE3ti%p2LQ>t}_Ca z+2&VwmFzV~#iUNhmrwrK$60>LKGVhgYCNX>%@rRjn@)J?vC@W*L43q&_nFMur|w2Jvg+;f$(Vakja;eQEPiI{_L;Nd=REDFR9g)nTU{9`c3(vN)w8$b zdj@Oblks=;j{L>($79EZu_fon9{er6YM&XC@qAw=J<7i}eXTFk5o^d}s@d~uZdVO$ zO-dfrV%T<^zRw)s*f^+dgVwYsGl4ZGB%gV7)95zH7<^dk7TI49IsKtB@?l%cz>2<> z>jsGrQ`^QX^5(uhwKp>N)gNQU1N~snpVFV5`0#Qqu^=&V+S{CZ=I@P&i?-ckv{-A! z?ha?Nu|0{OQT)tu-Qkz^x?KC|&F+(07qhY!ve#kOq1|{gNl2ZR#E*ZUy?)Ssa$?@v zd`jDuQSO}b@IlJrp%xjgSLEK0aklm`w|$H*SLn8}V>E!DUi@^ug;O&SW);+fDjcEIxo0{t#vD9-G-`ySi)cpYCysYn>d%o42@th@{^q9VjA|E7n zYT2KOzSVB?)3uMq3hSi9&4ucUSt*xgt>$An?7+4i+wpVuse7ZwDcUx7?zFFyi1FpT ztD=hetqJ%OpJVv!?zDYYK6#%$eDbvtSL56FnSByh+3}HoAC?kX?VleH?fCGr*VB34 zJ~PCeV;s=qq|{uqSY2H?bzG6TLDnh}{PhGGGaMVw()F}rT`t?RCwr^S32wPgnZ~a6 zUHi-_wMNi(_VvEHu&S)HS2)t$)(MmvVJrE%*n=5*_dc^q>`&14@$5Q%ZfC!`RPv+xceuwPd~$pR)Hf_8vPvv-9BMk>b;b?J~9#@3rTF2X&cu zJP%0z&8#!#FS7H$OZzxt{$eX@l*JHx5YpDSYTIF}t*wh-`coF8Te_+f+ZeX#_i=8M zIrVyNyO=v~sC&dz zKJ?1|%}4f`%~GD1>bNO3$NSYvsjYC1_u*#%KkiEzi{j^b+E4DBVNHkXo@QllMRu0Z z&l=3&!++U6b6n=s7nSzG*=BiHo)4L44EBeX`}e7Pd&ZgCN8Gtq;AWDVJMGhgHT$Wd z!Qxd-r1o?yAMhtWyYN|e1^xZBEp;n3M~pqKx{|Lo6|Ns}r}m+mp3ix4-#%0P%N~?I z7dqPlwq7TCGw4a|Y}HfO7{6uv&egzQKYFSCdSA@B7TaU($p7{s(HTQ$105g7__D4K zC0zTgU~M3IM*MtdpY=Rgu1>F|(}+$QofULs{>)kT$bC9C6eUU@Qe~?BSK96N?R_<1 z-Xc2RrN1m+&NZtFQ>ShLbUf(zw(96Tk$Tem(Mf-ApBc1t)P8{4sKtrMN0Cq5vCq2a zW8cS=YZl2vLpDQ6>K<@wX_T}3| z-v5*B{nxYjjUeyODZjdYwA-&0`4aMC^>4tY3%T#_ItH9;XBCxB8x5dSYciMRx=)_^>5%>FGgq=HyZ6LM09c1WqRb)esQ+LvE(Y#lKp}*jN17jHQgm z3t2<%*6p`#8J+ATuU2dlCzPL8A9mr|{pK(}=&QUkN^4q|yiN%vuNXG-*d#5Rt>w#Y z4}0M*@g?&hsLSTy-y^zh1WAOj~*B{jCwJyVYZXG`+P4i*EbNcc$Beu5s$l zbff6bpu3P)2087K_m(oupxf87Grue7HoszLy7dfzbvMwBzG`QF8(++re)Z0DJJ78?eP_D;=+5p?H->Jcb!UF((QSLp&U9Tb zA;4a{Gub9agbk@%NhS2rdv7%e9q4NZlc?M?#^^Qr*iJ@+?j4C zx-;l5=AFBp^@CixIqQc3bi;4kncoR?Ti(7i-4wbjJJhXWfi-d7&ipo`8w%`9w+r3I zckHYkBIu^j-N~A365Wyi*qQDkx*g~5Otu#c2ZN)sK*2Z1vhS3dMy4mMh)Fs$f-3YofJJ7Ag*Ce{5@856AvHX*3!z5{a7w<3n zoYWGs)CY^pT&EGwA1aiI?|Njz$eetH&7=+Gq)Fawq(!#z5kwaLSk{N=_mS2|n(XD# zhWeQ<@jr}gG*5q=w2l5keepGotaG4H=0g@_&!_W~`^-&_jpN&Dfak3M|)*uRqD3*VuEw6fz-46viFq6$ApyO zp!Sj5j@da(HZQHO3@O_sYy-pltY_cuFKTPWg4908mSu~pfxVg~Y*oJZjv~yc2?;N(?FWLECm1nz6dBx6XV*TmZ zePm~LQdS>!4cFTFU65yYgnIU4JB)2o@;|GnZP9*dMn8dV{RsE^#rAY<+ic$tvbI`f zZ`j(#RDH6HP1SY#)cV#qMcV|oO#3pVqjvDg6YltzdV1K;Y5DR#>)Fi{O4#O32iW=f z>&7;L?U0PYC;qL5Bv}KD?JDwokM)J+oTuZRFDhdq^^W6f<9fT^k7!@ME$3rnl9-B>CT?ZMMtbUG03!M9!IfOz%BA2l_Ge$3*|!BKm5!&*~4LzkDNoBl>3*(N}$G={KSi zM}KG!&s~WAsajv%7gJAQqbhnS^kyBsQ;O?xnp7QIbJIREApV}E^_=^O`blK**+dX{ z(N%dLuXVTNEp66`UKqWk_%wYrK;m8dv`(2;oumwd=+}{|FI+M`_OmYY>$ZtwZ1O9 zex@5WDUa+u`O)v=*f>x`Kc~M%e+>O0^ruAs_9FV$)uRkib$@&g{kE^$eRQkV-_l3Y zmmBEC9le{1>q-8y_f$X5Gb57!wOTJ*KXszE+E30S9q13C-yr>Sh1So`%hsA@+@4{T zAzkE(VAt_Y`}w}hi`dB;L!E2YC61bprmz{sCM{*VNZaH*&$9L6MC!95`P^d9FBfVX zt3K*{m7R~&^$&YEedsSq9%pO)?Ak@LuotsbrrLfCK^|*WYo{Rg?wD4*iSk3 zCzo%(h<)%|cK*keZ{I+tR(;#HKX^tB&9L?Q^+@%{KIYipU%veq_U*UY`QKH(z3e@$ zIQF-cZ{NV4&B%nE|25^?2eJ3=we2r0-+m1H1;_q^^6eL~AK*C{6~AYdZ{NVaO(V~~ zDEpU|Zy&@y>DZrCzWo^XJ#jmK^R;Ei-y-(4x7qfOmT%v{-p-_Be{cErviB6=nIF}D zca(2GhW(~ve^dGPi`b9xERo9ps`Bj{Sp2q4+V+=}Zy&@y?bx4JzWo^XLp;Nz%6~@r z_KVmz^L&%CKc#&8hF7tF<=CH4zI_n;Fwak^{2zZ!+3`DueLc@VDf@@Zw_n75+Oa=S zzJ0^1xqjjKDV6{J^6i7z8$Yn^uP@(z4EqVk{)+PL7qRcS)6V~*^6eW=XD`XIKf8SU zAokHIJO9(lw;#j4^@q0o$>rNGV!!CvA6LG81B;-+AKCdIY%M!}gV=lSvhD9L-+m1H zS;zja^6eL~@8$VC6~DKXZ{P45?%VVHp0dBDeET5w3CI4@^6kg4@A`?I{{`jSFJkYy z+qOTeeEWvivj6VbzqEY&Aol(lJO7i)w;#iP*|9fIFFXDgu^;}ao&Tfd+c%uSzR%BW z`+Li`4`QEk?C&VwehmBm19tv5m2ba@eM8c=zp8xu1|Rp19Q#Ykw+~_;`njF|dF9)W zVPEqL+y0F5?H93+JNBoPZ{P55>}T9#=YK-^_Cf479Q(&#U3UDAVLv)+=l^hd_DwG4 ze(VQ+X+7U<9MJYT*Sp!94x(TCI@-(8zx~MiKJ*vSAH~+VN$Y3#SMv5VdeLwHm3=Sr z>LU7i`(tD1&!Zm{|5s}LqUG;GXAb?UdwJejzE5$9)*s9NKF6lD0bzZ0A)fm|ZRoMd zpuW^Fkd?3w#((pfoDY7(_fVufS84y*J<#i`)%z8ky$b8S0culGeN|01YJAv+@e{>Q zO#Ga${p9bH*o9H|L~?J-C?8Y!*mQiHTD}jdk5npnpS{0yy!KI8AJs2*71Tr5>Ncp_ zzmYvWKYo_+!*ZMNl)cJ{bG=XGbgSt0p<6R=?>XLEsOxOWiS8J>jlZ?`NAE7wRkuzk z1!}HY{tKa-kTTqvYDfaFQDRU?Go%h>q zarO50Y)!ZZ&<FJ->GP*?3n$;ML7KC{#{f!#QEDh@Byc7=7d_sojLq2%v+10j&w zr=9~hPSbu0>*^E)6PYKx*o|V>EN%2WZI|=?wUi7U9Umdlf56_iJwxm3=ek8(l%@Sf z(2f1xzV~`wq3(jMD}6PMZuf#cKVG7Br=9PVSvP`Il-SQksOVD1V(&VO{2sRL&n(~G zhkfLaw*5)v+55?U0Q;#&m_LuB9Ut>L<7S}P_iF8XLzOF4)~saTo>5=8l0KQmSIuMg zecEih_3H0PIqzqpp{1QSC2#b*IX1HT)*QsW5OroiSL7ZFn?W}%{rx6g&s^WuKtkVs z$CmXiJ{33W(0T?!$+N26swyOsM<;*7s{2pDIyYXGW$+=F-{H*PKAF<5Sxn-8QYYM+zeAi%% zW8)O<*NREGm*<>FtT%Z`Rb672!EVN}%eG-jJ2|g4y@|h9+4()L$7(QVd|8u=G_e(y zDo?QuVLR;DK3JaZIJOzb_O6}VN?jMR4e-5*F^-L|Yuh8%)!okA>eyYa?T%PinTI;D zZR9%@E}1JX(YCpBMOgJEtt0w_=x5MhlrmnPr!W1ehMsCl>%I2qkMJD`dC#$Nh1TEl z-fru=z-sX+PqN5juF~zik-%EpS(A_@RQHo=-pqNQ?nR$37;y**>s!)g4b&4)NQ8Zqm`s#$Hj~eso)T=3V){ zIKK>A{l?IZJG$BW74 z(ee(Wn{jlXSK4nJ-4M^+tGb<3T6Y261xNSz?R7ipH{%@oj%W1c_X-U2v>K8KD4tQ$ z4;HB#_u1b;kdSq5d|Qv~^{6@BdK6Td*Yf`Yi$@R7O;@QD_M+elX>QWulE!!V?N^t{ zIYGyB-FsNCq0?*WSkEuWdQ9@QHDz{x2)X3bhW--z4WiFKAAbSTR!B=rLgDw3ou!v} zv{!mk5j7y?oT2=V;$!aP`%M{R@=xZZIBB6z?04S9+(7x|CsP=dRuhQB?2AU!g`0Zc zfRu9?+u19!<&-qndubz{A8(Lj{z+OLX%jhV^`v=78~EgYepi-%p{?JQ7aKqF=1*n6 z_bh2$;)k>bj^&@E^^(>;xK(eEw2@D5O^cE?nwK^~TI*F=e~tK?Cav$Y`<-_(SbgOT zU%Qh;FO6RKbNkI6j_D6uugmJx9KG6$DD#m14uqvAO-sW%ecp@2X z*&H&@HnL@8{vxsld>SG8#T|Fv`|OO10juU#Ovm5G8kRAwo_{*f;*8Vjym4AFEH#!W zrWLG3sWmWtgas*1F`KSwU4u7}p zRWO z^D%{wjvm{`MMvkubv~z}57<7=IyxV1`0(=GHY+}k&PN0vO_$g{jw|1XoZDvc(a^hJ z{SJun=*yh=aLyxgX~pTl+P~dEH;Qgd&O7&N-Hu{=8FD@7VbM{`_vlLP1EZC$(0 zV;}sl{nj(v=kLT`t@%{j$hxBLoy-}I{ps4i*sjz6 z>@wJOirvG-?Zki0e{!$+QrrK1#r2Ans|~w($L@}u+x27D9JbyIW89$abemaAG3w$3 z2W6DDp2RMKovP1Og?7>uviy@+T0}RFZk%J|(n4M9d0nSF)uK@cle9_01;o_H?Ca$7 z3+>g~O3ZuhOtBHW0Cr>8jZ3~~720L<%~nqAhOukA%;UimF0^yvC)ZBmuIXLu zD{$TC6}zho?VR$e{ztbN-H_;BUZ|_{$WA>fwui9`V%IKq7Zln#@z#WV3f%#8gQ9!3 z*4-K__B_0`i+&^5`oogXorU^NeCCd4sY_Ki^FDS1Vs}fSoih*n zkT;_{hpzm-j&Xz5ZPwqrv%cREkt*4jpDMzwV{7fvhmWx^6RuOFrT#?hZa zU)AeUt*`sBSiQtf_MYn5=a}KxxUkS}yEv1*rxZuSc~n`f+kG=iU|;r;6Oag9f`pS<>&I%50Cd1?_~V_&q}`a$h$OPNx-Br^D{ zFHSdOTOVTWb1i$fQlH0)+p0OyF1z$c2R1b$c6)AH_Q`D7)d|fS05X>jV;{JVwT0xF zEw4S+)o*+9TfWSExxeih%>5L|`M}u3=Mp}rzs&q0J`WVH$GB7T?2X&puY#-jwdsA> zN9}90JG39`nn`ZSM8%2pt#fv_`mMg~~F|W&^+E7K7lp}_1|4nu|Zql}8mqTJSgRiME?(<4}T&;a=?GJq~Px`Y* zl}b89%F=Q%F?zFImMgS<*=3Rb9Kcuf>vn%$tbJ|UpOXJ1HlcCW6H@*QwM}0BM~)}) z?d!nN z`;s|e5MT4(b>?*KYfFsg&gn9TC9oO)p8c%Kt=dMPi~6LOB#^Tk4c&H<%ZL32_P#sp zJg?XGxzG2g%Mvv#iZrQ|p|w{EV$bJSYaeqvS$jzt`mqmvpY^$n&8xJ1PP|zc6IS0^ z_p+>ZuXSbdQ*|K#SMt$)r0?ZGyQZQ#fI%~_6(N3`vj^Sfvg!cu#c( zaCEOJt?TKdeSc>Ay|T1!C%PMs?xm%52hfcku>D?KT6Y3nZ_?JiptNoZ-ISwyZfV`B z|Dt_=Zu>oJdtD!~)r_wD7uGw_jnlPmPK@exYwlyv)-s*|Y{y3*K1T7eDY1Hz_K|(3 zgqrp&Kh~_LUqdHj){1;<3RH9X4F3H0aJ?x0R$o|b++;^w_DC00=5phs?6KfuMvm{* zKC)$!%V2Btsdbihr6`Bip1dD>|E#?iyIC(&}#BSy9fV$=tj{^SCH4OT6bXU zHMdnzm6`oBSJtsLjTRo~=x596A`Dzhn~%z{ex|PM)~$# z*tb1o+dr>-`%&yW9=7d|E8l(r`>sXX{xSIlJN^}1&ul;b>Mv(~`ro$wz2)0?Vc+*h z+y3_Q?MJcqE!pukYua|7Y9&g7WRVu-|ype*XH*?d)@|ne*pA z>>K`K+n-Xt{Q~y>zuNZ4mv3MHah{cY%(g#x$~N&+y!^5z?ZUqC=3A|MviIfK+Yb`h zt8sO&CxULzvVE`WF0GrhuCUhtoF`iFoj`vXeYJ=6b*-N>H>z`5_6tSWwPLq|-SFS` zn*li|-K6aXia*D(VV~-(=Qx_MZ~g@LCs*uycb95=pIs$=J%Orv)^uT*>%_zRt=}iI z(^g0uS>Kvg^+jUk@7BFl$JR|+{r_%FYa-1@nzVtV=OZncr`Ji^5YL8sbM!)_Wu6i@ z-8pIfq-~H^XQzqZVbVe;#LM~}Bk`HUF8#E)^}9nn-@2!Y6~#l=^P)>7WUeo5Z&zPJ z<}D%XEFtSHAsZ?oi;S#cu z60&#+*=z|}x`eDMx_#XnO2}GE$O0u~eI;bW+sNuU$4%I>W;tJ4?{wW$B|FQU=R`h> ze1mh~cJgK9#?!Z#*L;QZWeIr`a!(0)J92Lcc@J`b3HcE6KneK-@=yu+Eb?#(`7-iI z33<&|*&8V#Z$cg`A#X>XC?W4bo-83BLY^uipFo~2A)iIQQ9{0q+&HO3|KC9WmykCh z_mq&gBlnh&_aOI|kPjgbl#ov#50#M5A`h34FC&kXkk^dT|0U#2$YUks?Z^`)guDm2zl3}Ud7y-R z0(q!}d=`1QgnSu!q=dX?5B*<4-h@0>Lf(!%Q9|B>JXu0MggjM3K7l-4LOzRpqlA1J zx$%q={eKhvUqar5+*3l{j@(;9-hCY6`??RSF z=9FLj_lo{ih58~JLN@ie;<6aB_Rkl}#PqVC9KPvir3iT!LNo0wy6_?G4-FTr) zd@oBr$eer>ze$_qq>2AJ(n8z#XhzmCk@X?^ZKSo6*2Zyu%mk73<>~j4RuwPQmwjv5 zd-8DKsheZtmVb8kz4i0<&b?gO5B8xOL^mk9*XQY~N1m-seK~`OelPmN=(7yuT_RdP z``!IE*>bkdH|^-i-cvL8u)J01U!wKrioVOHVoL82Ig zpPA>L%c8XR&D? z=_fjIwOF(-D{J%{%hXGSsw=zlUsNRRJ&n%=?k}kJxJvu{hxBJF{u|h{Szg<3eMjvk z?O%@tRd>R**mu-qECsPoJ#O8@FmBl1UUY}hT|!sd%DB2vSGHMXXozkCU1MXvIUu^1 z7wS4=RCJfn?Lt@TV_Z_G8_4ln8>OEd-3zwYm9Z>)PyOgN@51ldTGxJVQJ%_7*`AqC z(C-m_xyK{=7i;~Z?|_V=8{wW#tLR=?sJnn?XHJpG^IyN0$sY4pw1*Z=A{hIggn%p`_nHt%% zX{oi#l=B5xmU(pA}8IR zfz&v(`cCwHcy9b>#sg3PqxluTkAZYQ@3oLr7UsmyPg?0Gjjeq zRo7>_V*B5ct4w7lPFZ>e+F#LwsFP+Si`C8{O5F!CX(OQc|Y2QOgS8s? zxm){LEY&`(RfX*%aXO5zO;6nVp4nYbbRm(^qv)S$5P{(!O2TPruA= z-&3`H(Y`9xzT@~ww#3cYvDE8Q?Pso3`%V^#KWX0;d^MgPH^VCap61kPprC!76_C}u z*7u*-y9u_&t#{cyPupha*>-6~8HD}z0qaBZ?8eUbnz$L4aejifD|nY6??^oHM&6QG zpA%&gWD;XBd`z6dJ$V^}Cue<>YJ<5PKh79z!dC`g^=;OBmW->luUsiBDJK&_XoZypV{o9l3LnNz( ze~Ixp{zuM=n^ni*|NLxOO2qhZ74Ma;C=%mc_;Za>zq9S~9?<^&A?1~R3*z5+Yup@{ ze!D^YA1>8z+s&P__Y{0v+>A=>9@M^azbE0m1yZ%1b>`rZa&+^zjQz-YakEM0yGOPC zK<>LFt(Uj6+P#yja3sp}Kk$8_#@UXm(nRSI3zW^CuN?Ytmvy~i|L&&5*jF*R zFL8Un&Tp>pxu6?PlsB0sb(?U0qX-h4?f9s>FmAoa^fB#Y`e@%{Dtk}!?_oZdGG$|P zEdP4JX~))_@hws*ICECpE^lDWbMatW5#;d z?2I#3$yvXlTFsu)pCSCTUu>V(9@OPH;(1NR&^WejABdZVjG=5h43ru}4LLF8%zbV6 zTEUl#Ju+3FQ=ab3|7F+5JI=aD{ayFOx{N3yY9@;oAOJ%L>ldw2^R z=ZxQyalMF*`@f!CT+80m@}>W{xbDN>#AQz|t`qq1ef;R-dINjecYLyO?PDLQap36U zx*yy6Pn8$f#x`-C#8>LmPd=_|Z(-hLzf`S{%8cuFY+EAb$Mqm~Ri7;{t`pd-VB@c3 zEM({Ff#UC-ZpfV()%j57>rH%k*^5>0oz9+5k7~YF^M8!CyC!ZXWv;zP&v9Gc)y(;I z_l>;w-dXdcWTLLFT-K)(`Apel?jFTo@0aWt&(4`Up1T*YZyB*;B5PmvT-W$5&Zq1p zt9M`At?PBfxx0-z1hF-)x680!+m>C17=AoaJ1(!+evUZb%DHC=+wQN}ae1Y-Ejiy} zruJ+`rkD| zu2`u#nQs~zb;i?-ryD03ZsQroGmU2%^~SS}e=+>V8{0XPPTS{I`$GCy|FLf*!&Yf)@@@M* zD4!)QMp|cH+7xO2+qRZrjx_J>adQqE%CPmlSn?AJx%Y%Q=c!P#2V>>oIllJ{t%%t2w(l)-EeeSu1v_A1o8eO*4w{>|k zYBze;J?}$qLUjVWf$zoD`>Ckg)^|KE!*ufDeyz`v6Zs+^tJul$6$NbLQ2eLxSy?Tk|tRN80| z{l1@X?Z+r-UB6(Cm3ZC~OZFGisB3k_obtq>8ZWch^xngsf#jRDvHDCJhT4j5J>m^? z{j!i$X0qZo^__3>_1W*h zk{xF&t|dOK6P=0_tNW$*>0ACbu%D>8t>B)W$m)I~d(OpW&B(g`xwxzyS^A{nvJkRb zccDzhKQb>eIhKFIC}}M@X=?nF)>?m?xhP6)ydPd~nhZ!IQ91h;4G@d|0{R^dx2gAU zsJ?OZ?Qf=tff~CHS#45tH*xx$!ZJ#mc#zdUw@@Z!Z9~?EEVujt(tJ5-;-iPO*b54M zh%ADv>0QNTqi zjxFD19N{M-6k-pF7#g#K*nb zM}9embIPIG*(ry#nI|FhC-*?b#|_$tRSr8lrx+3s0rYFRb_t9ARa#$& zljPt0eb&ABF{DqQRp=-Cs$!>x)?P*ky9n1?{ZekT+UZB#9){iT6&x?kEfCFSHgO+9OIKpxLi zU&_)g`rqf;R*eJQX1Xj3R`J!C9!7Wm2VAR)?n||9hhC3c*NtkinH!%;?2>oJ)o=Y6 zr)azEJw0bKpgdBC4fI=oWS>K_`c{8fbAXz%oH@XAC(kONukJlPRr{Z=vkg zV`Tewy6|3&xE!sLK%%XzFL7fpV`l>&o87mX3Av|ym+r%{QrAwCIi8$*3gWA6iu)TE z-)fGDuUmHJYj7K1!}yx|(5+_5z}Gc9^EG>HwuZUoTELh8GTYasNAF9TCV$j736ic zwz03Ztl(6$gL>k~`jtyLlzC3}p6c#po{;ruHotgwJ*oy!Ww#S(GH>YLO_dkiutvm> z>^*t7wqKOE{r{}J4_xKfS?5m%lH5)(!DejO4K;MbZqVSC-)6LE&|D2#{DrmbmNnF1 ziyJg(u|b0k8nkF|!~Tj5KZ_O(P3~@Siw+uQh8eI$gLd4G1}!zz(1s?r4H|0DVuKbf zdiVV~|GwXQ@Aooy(&hC^=6lb1p3iyCInQ~{bDnd)=X+a_VX!kE(!=Mh^scS>z%cPQ zc)Q?Tdxm*gyl)P?CE~WLq4P{A*o9V1B**RH&4RbJ!M?5VZoU-WULIa6@@&I@@l%Y! zD)_Gs{HyUjJQtU)?Dp+q0@K!ZHxQ@UBsS2l@fMZ8UKne)dx+b4<)iQaAFRQbh{+uX z>&?L?9knLSTzR~*>FR_vsqorX@$5-0o!eA%xNJ2gvi!Hm00< zF~~DoxNh|O&?llE{ET4aGxdY9n_I{=s*PR<7z@ScZgyO!+0if;|5bV5k&SfH?NxAB zs!qGPHTanM@vDpl(NMR+78`?9TUY!cbJSI*b2Dn6s{?=b2)%L!$4n^R+?u&tv8RR9 zX}i98Ce$$&BU+Fkkr+J5W{tsj@%U-`jnAh8pPjp{xwHPL;SAGq?0z*nPS=EU&FNg7 z>hjTmleGU-8TFCv=pN)y?5V!ybgozYX9IuXS(wV^&hqi0~f?_8L8Xt3b7eR^ z-kAVr=8$RdX8zOZT($gwvt{9B8Nnl0CIG6wJHmV0>D;Jn-ksqL=TY_D18?A}1U$`; zi_bFG{_trVyKcKSlic>P*-=doUk(55!Mplnj9H%br?e^@iyhKVm=v2<>(Z33Kjk%% zwhf*1siKQ-XFgtK(%VR{dFN@nFVhpH_mJL}kUm8EFzIoeejq1EANUE{oqnYM;%BRl z%|yCsLI&3T7>iP;qel~fumllpc%uD)KcKAUcc0G9ViPHgcL~iITxmRmT>p&Ne^jy= z2N-Al%P=!PDJ1sO6FXix60zKV$KxP8QM*lcKRs}pO?8O&ACcG?^}?r#LqBxdf4_9{ zipQ&t&5>J6HP*;mAWv;cotnw&6{GTY$U7{NSM?d@`H^J4dh({o8?l(Y52l+KEoLiu z`{d2pyg~A?_BOAZywRUU=Oeyh8 z6zy}A-c#LxXK?Iv-d#&Oq;))kZmCTEq}PX}wUO3hQfykybF{^O&!=l3ZQ{N8X)UCU z#nRGXbdWYe+K%udS$(X9wn>V$pei=m$TSJY{x9W^#aWl8e$=02UncFKfNssDc{;UU zmb63YX2lqnNxr`wJ_`FfA?$wLi7m$A`%c^UY+*aee~qM#la}E*568IlJ-!a?s0{jN z8-s_hchcF0GWKjIp&x;MBC#B|w`K0X%x|}g@TI0AnbYuZk=8(3HW7>Q7P=$$936r+ z^{&Toj?OUOC1OOC4Nb@%vf8~HzD@W>3i;ITuDRmv-UQtQJatc;&h3jQVc&SmNvwTi z(XT+iJ9paL@mAa?Hd^ZA6zaoW=+nPx=Wg)*SaSLq9k53(ER}5>=~4sbO`mdehOw2# z1Q{np3w(w^B;#fY_!zc&F`F=Xc@k; z%Fe($^Z97*sV8lbv?0P?I=<~p@Ez(&Yay+Tw23SD5%qy{O03@W z2=n%QzCqGvN!x}k#&>MP^+7wywV%XR-+kJi8-M7kYLP-);*5$pTCxyZW`%XJ{Odlj zHh%zJKSmwj9I!@9tg$(zaw6JlR^*0tpJbW`C-sB)bJRC=L%>-rfn$V

    0Bn@I!*q8MuoZEPdOB5BvY)8EahqIk#+a=9T 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

  • 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