cli-ih 0.6.3.1__py3-none-any.whl → 0.7.1__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- cli_ih/__init__.py +1 -0
- cli_ih/asyncClient.py +109 -10
- cli_ih/client.py +110 -18
- cli_ih/utils.py +51 -0
- cli_ih-0.7.1.dist-info/METADATA +100 -0
- cli_ih-0.7.1.dist-info/RECORD +9 -0
- {cli_ih-0.6.3.1.dist-info → cli_ih-0.7.1.dist-info}/top_level.txt +0 -1
- cli_ih-0.6.3.1.dist-info/METADATA +0 -86
- cli_ih-0.6.3.1.dist-info/RECORD +0 -425
- venv/Lib/site-packages/__editable___cli_ih_0_6_3_1_finder.py +0 -85
- venv/Lib/site-packages/pip/__init__.py +0 -13
- venv/Lib/site-packages/pip/__main__.py +0 -24
- venv/Lib/site-packages/pip/__pip-runner__.py +0 -50
- venv/Lib/site-packages/pip/_internal/__init__.py +0 -18
- venv/Lib/site-packages/pip/_internal/build_env.py +0 -349
- venv/Lib/site-packages/pip/_internal/cache.py +0 -291
- venv/Lib/site-packages/pip/_internal/cli/__init__.py +0 -3
- venv/Lib/site-packages/pip/_internal/cli/autocompletion.py +0 -184
- venv/Lib/site-packages/pip/_internal/cli/base_command.py +0 -244
- venv/Lib/site-packages/pip/_internal/cli/cmdoptions.py +0 -1138
- venv/Lib/site-packages/pip/_internal/cli/command_context.py +0 -28
- venv/Lib/site-packages/pip/_internal/cli/index_command.py +0 -175
- venv/Lib/site-packages/pip/_internal/cli/main.py +0 -80
- venv/Lib/site-packages/pip/_internal/cli/main_parser.py +0 -134
- venv/Lib/site-packages/pip/_internal/cli/parser.py +0 -298
- venv/Lib/site-packages/pip/_internal/cli/progress_bars.py +0 -151
- venv/Lib/site-packages/pip/_internal/cli/req_command.py +0 -351
- venv/Lib/site-packages/pip/_internal/cli/spinners.py +0 -235
- venv/Lib/site-packages/pip/_internal/cli/status_codes.py +0 -6
- venv/Lib/site-packages/pip/_internal/commands/__init__.py +0 -139
- venv/Lib/site-packages/pip/_internal/commands/cache.py +0 -231
- venv/Lib/site-packages/pip/_internal/commands/check.py +0 -66
- venv/Lib/site-packages/pip/_internal/commands/completion.py +0 -135
- venv/Lib/site-packages/pip/_internal/commands/configuration.py +0 -288
- venv/Lib/site-packages/pip/_internal/commands/debug.py +0 -203
- venv/Lib/site-packages/pip/_internal/commands/download.py +0 -145
- venv/Lib/site-packages/pip/_internal/commands/freeze.py +0 -107
- venv/Lib/site-packages/pip/_internal/commands/hash.py +0 -58
- venv/Lib/site-packages/pip/_internal/commands/help.py +0 -40
- venv/Lib/site-packages/pip/_internal/commands/index.py +0 -159
- venv/Lib/site-packages/pip/_internal/commands/inspect.py +0 -92
- venv/Lib/site-packages/pip/_internal/commands/install.py +0 -798
- venv/Lib/site-packages/pip/_internal/commands/list.py +0 -400
- venv/Lib/site-packages/pip/_internal/commands/lock.py +0 -170
- venv/Lib/site-packages/pip/_internal/commands/search.py +0 -178
- venv/Lib/site-packages/pip/_internal/commands/show.py +0 -231
- venv/Lib/site-packages/pip/_internal/commands/uninstall.py +0 -113
- venv/Lib/site-packages/pip/_internal/commands/wheel.py +0 -181
- venv/Lib/site-packages/pip/_internal/configuration.py +0 -397
- venv/Lib/site-packages/pip/_internal/distributions/__init__.py +0 -21
- venv/Lib/site-packages/pip/_internal/distributions/base.py +0 -55
- venv/Lib/site-packages/pip/_internal/distributions/installed.py +0 -33
- venv/Lib/site-packages/pip/_internal/distributions/sdist.py +0 -165
- venv/Lib/site-packages/pip/_internal/distributions/wheel.py +0 -44
- venv/Lib/site-packages/pip/_internal/exceptions.py +0 -881
- venv/Lib/site-packages/pip/_internal/index/__init__.py +0 -1
- venv/Lib/site-packages/pip/_internal/index/collector.py +0 -489
- venv/Lib/site-packages/pip/_internal/index/package_finder.py +0 -1059
- venv/Lib/site-packages/pip/_internal/index/sources.py +0 -287
- venv/Lib/site-packages/pip/_internal/locations/__init__.py +0 -441
- venv/Lib/site-packages/pip/_internal/locations/_distutils.py +0 -173
- venv/Lib/site-packages/pip/_internal/locations/_sysconfig.py +0 -215
- venv/Lib/site-packages/pip/_internal/locations/base.py +0 -82
- venv/Lib/site-packages/pip/_internal/main.py +0 -12
- venv/Lib/site-packages/pip/_internal/metadata/__init__.py +0 -164
- venv/Lib/site-packages/pip/_internal/metadata/_json.py +0 -87
- venv/Lib/site-packages/pip/_internal/metadata/base.py +0 -685
- venv/Lib/site-packages/pip/_internal/metadata/importlib/__init__.py +0 -6
- venv/Lib/site-packages/pip/_internal/metadata/importlib/_compat.py +0 -87
- venv/Lib/site-packages/pip/_internal/metadata/importlib/_dists.py +0 -223
- venv/Lib/site-packages/pip/_internal/metadata/importlib/_envs.py +0 -143
- venv/Lib/site-packages/pip/_internal/metadata/pkg_resources.py +0 -298
- venv/Lib/site-packages/pip/_internal/models/__init__.py +0 -1
- venv/Lib/site-packages/pip/_internal/models/candidate.py +0 -25
- venv/Lib/site-packages/pip/_internal/models/direct_url.py +0 -227
- venv/Lib/site-packages/pip/_internal/models/format_control.py +0 -78
- venv/Lib/site-packages/pip/_internal/models/index.py +0 -28
- venv/Lib/site-packages/pip/_internal/models/installation_report.py +0 -57
- venv/Lib/site-packages/pip/_internal/models/link.py +0 -613
- venv/Lib/site-packages/pip/_internal/models/pylock.py +0 -188
- venv/Lib/site-packages/pip/_internal/models/scheme.py +0 -25
- venv/Lib/site-packages/pip/_internal/models/search_scope.py +0 -126
- venv/Lib/site-packages/pip/_internal/models/selection_prefs.py +0 -53
- venv/Lib/site-packages/pip/_internal/models/target_python.py +0 -122
- venv/Lib/site-packages/pip/_internal/models/wheel.py +0 -141
- venv/Lib/site-packages/pip/_internal/network/__init__.py +0 -1
- venv/Lib/site-packages/pip/_internal/network/auth.py +0 -564
- venv/Lib/site-packages/pip/_internal/network/cache.py +0 -133
- venv/Lib/site-packages/pip/_internal/network/download.py +0 -342
- venv/Lib/site-packages/pip/_internal/network/lazy_wheel.py +0 -213
- venv/Lib/site-packages/pip/_internal/network/session.py +0 -528
- venv/Lib/site-packages/pip/_internal/network/utils.py +0 -98
- venv/Lib/site-packages/pip/_internal/network/xmlrpc.py +0 -61
- venv/Lib/site-packages/pip/_internal/operations/__init__.py +0 -0
- venv/Lib/site-packages/pip/_internal/operations/build/__init__.py +0 -0
- venv/Lib/site-packages/pip/_internal/operations/build/build_tracker.py +0 -140
- venv/Lib/site-packages/pip/_internal/operations/build/metadata.py +0 -38
- venv/Lib/site-packages/pip/_internal/operations/build/metadata_editable.py +0 -41
- venv/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py +0 -73
- venv/Lib/site-packages/pip/_internal/operations/build/wheel.py +0 -38
- venv/Lib/site-packages/pip/_internal/operations/build/wheel_editable.py +0 -47
- venv/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py +0 -119
- venv/Lib/site-packages/pip/_internal/operations/check.py +0 -175
- venv/Lib/site-packages/pip/_internal/operations/freeze.py +0 -259
- venv/Lib/site-packages/pip/_internal/operations/install/__init__.py +0 -1
- venv/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py +0 -48
- venv/Lib/site-packages/pip/_internal/operations/install/wheel.py +0 -746
- venv/Lib/site-packages/pip/_internal/operations/prepare.py +0 -742
- venv/Lib/site-packages/pip/_internal/pyproject.py +0 -182
- venv/Lib/site-packages/pip/_internal/req/__init__.py +0 -105
- venv/Lib/site-packages/pip/_internal/req/constructors.py +0 -562
- venv/Lib/site-packages/pip/_internal/req/req_dependency_group.py +0 -75
- venv/Lib/site-packages/pip/_internal/req/req_file.py +0 -620
- venv/Lib/site-packages/pip/_internal/req/req_install.py +0 -937
- venv/Lib/site-packages/pip/_internal/req/req_set.py +0 -81
- venv/Lib/site-packages/pip/_internal/req/req_uninstall.py +0 -639
- venv/Lib/site-packages/pip/_internal/resolution/__init__.py +0 -0
- venv/Lib/site-packages/pip/_internal/resolution/base.py +0 -20
- venv/Lib/site-packages/pip/_internal/resolution/legacy/__init__.py +0 -0
- venv/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py +0 -598
- venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__init__.py +0 -0
- venv/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py +0 -142
- venv/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py +0 -582
- venv/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py +0 -814
- venv/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py +0 -166
- venv/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py +0 -276
- venv/Lib/site-packages/pip/_internal/resolution/resolvelib/reporter.py +0 -85
- venv/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py +0 -247
- venv/Lib/site-packages/pip/_internal/resolution/resolvelib/resolver.py +0 -336
- venv/Lib/site-packages/pip/_internal/self_outdated_check.py +0 -254
- venv/Lib/site-packages/pip/_internal/utils/__init__.py +0 -0
- venv/Lib/site-packages/pip/_internal/utils/_jaraco_text.py +0 -109
- venv/Lib/site-packages/pip/_internal/utils/_log.py +0 -38
- venv/Lib/site-packages/pip/_internal/utils/appdirs.py +0 -52
- venv/Lib/site-packages/pip/_internal/utils/compat.py +0 -85
- venv/Lib/site-packages/pip/_internal/utils/compatibility_tags.py +0 -201
- venv/Lib/site-packages/pip/_internal/utils/datetime.py +0 -10
- venv/Lib/site-packages/pip/_internal/utils/deprecation.py +0 -126
- venv/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py +0 -87
- venv/Lib/site-packages/pip/_internal/utils/egg_link.py +0 -81
- venv/Lib/site-packages/pip/_internal/utils/entrypoints.py +0 -88
- venv/Lib/site-packages/pip/_internal/utils/filesystem.py +0 -152
- venv/Lib/site-packages/pip/_internal/utils/filetypes.py +0 -24
- venv/Lib/site-packages/pip/_internal/utils/glibc.py +0 -102
- venv/Lib/site-packages/pip/_internal/utils/hashes.py +0 -150
- venv/Lib/site-packages/pip/_internal/utils/logging.py +0 -364
- venv/Lib/site-packages/pip/_internal/utils/misc.py +0 -765
- venv/Lib/site-packages/pip/_internal/utils/packaging.py +0 -44
- venv/Lib/site-packages/pip/_internal/utils/retry.py +0 -45
- venv/Lib/site-packages/pip/_internal/utils/setuptools_build.py +0 -149
- venv/Lib/site-packages/pip/_internal/utils/subprocess.py +0 -248
- venv/Lib/site-packages/pip/_internal/utils/temp_dir.py +0 -294
- venv/Lib/site-packages/pip/_internal/utils/unpacking.py +0 -337
- venv/Lib/site-packages/pip/_internal/utils/urls.py +0 -55
- venv/Lib/site-packages/pip/_internal/utils/virtualenv.py +0 -105
- venv/Lib/site-packages/pip/_internal/utils/wheel.py +0 -132
- venv/Lib/site-packages/pip/_internal/vcs/__init__.py +0 -15
- venv/Lib/site-packages/pip/_internal/vcs/bazaar.py +0 -130
- venv/Lib/site-packages/pip/_internal/vcs/git.py +0 -571
- venv/Lib/site-packages/pip/_internal/vcs/mercurial.py +0 -186
- venv/Lib/site-packages/pip/_internal/vcs/subversion.py +0 -335
- venv/Lib/site-packages/pip/_internal/vcs/versioncontrol.py +0 -693
- venv/Lib/site-packages/pip/_internal/wheel_builder.py +0 -334
- venv/Lib/site-packages/pip/_vendor/__init__.py +0 -117
- venv/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py +0 -29
- venv/Lib/site-packages/pip/_vendor/cachecontrol/_cmd.py +0 -70
- venv/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py +0 -168
- venv/Lib/site-packages/pip/_vendor/cachecontrol/cache.py +0 -75
- venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/__init__.py +0 -8
- venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py +0 -145
- venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py +0 -48
- venv/Lib/site-packages/pip/_vendor/cachecontrol/controller.py +0 -511
- venv/Lib/site-packages/pip/_vendor/cachecontrol/filewrapper.py +0 -119
- venv/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py +0 -157
- venv/Lib/site-packages/pip/_vendor/cachecontrol/py.typed +0 -0
- venv/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py +0 -146
- venv/Lib/site-packages/pip/_vendor/cachecontrol/wrapper.py +0 -43
- venv/Lib/site-packages/pip/_vendor/certifi/__init__.py +0 -4
- venv/Lib/site-packages/pip/_vendor/certifi/__main__.py +0 -12
- venv/Lib/site-packages/pip/_vendor/certifi/core.py +0 -83
- venv/Lib/site-packages/pip/_vendor/certifi/py.typed +0 -0
- venv/Lib/site-packages/pip/_vendor/dependency_groups/__init__.py +0 -13
- venv/Lib/site-packages/pip/_vendor/dependency_groups/__main__.py +0 -65
- venv/Lib/site-packages/pip/_vendor/dependency_groups/_implementation.py +0 -209
- venv/Lib/site-packages/pip/_vendor/dependency_groups/_lint_dependency_groups.py +0 -59
- venv/Lib/site-packages/pip/_vendor/dependency_groups/_pip_wrapper.py +0 -62
- venv/Lib/site-packages/pip/_vendor/dependency_groups/_toml_compat.py +0 -9
- venv/Lib/site-packages/pip/_vendor/dependency_groups/py.typed +0 -0
- venv/Lib/site-packages/pip/_vendor/distlib/__init__.py +0 -33
- venv/Lib/site-packages/pip/_vendor/distlib/compat.py +0 -1137
- venv/Lib/site-packages/pip/_vendor/distlib/resources.py +0 -358
- venv/Lib/site-packages/pip/_vendor/distlib/scripts.py +0 -447
- venv/Lib/site-packages/pip/_vendor/distlib/util.py +0 -1984
- venv/Lib/site-packages/pip/_vendor/distro/__init__.py +0 -54
- venv/Lib/site-packages/pip/_vendor/distro/__main__.py +0 -4
- venv/Lib/site-packages/pip/_vendor/distro/distro.py +0 -1403
- venv/Lib/site-packages/pip/_vendor/distro/py.typed +0 -0
- venv/Lib/site-packages/pip/_vendor/idna/__init__.py +0 -45
- venv/Lib/site-packages/pip/_vendor/idna/codec.py +0 -122
- venv/Lib/site-packages/pip/_vendor/idna/compat.py +0 -15
- venv/Lib/site-packages/pip/_vendor/idna/core.py +0 -437
- venv/Lib/site-packages/pip/_vendor/idna/idnadata.py +0 -4243
- venv/Lib/site-packages/pip/_vendor/idna/intranges.py +0 -57
- venv/Lib/site-packages/pip/_vendor/idna/package_data.py +0 -1
- venv/Lib/site-packages/pip/_vendor/idna/py.typed +0 -0
- venv/Lib/site-packages/pip/_vendor/idna/uts46data.py +0 -8681
- venv/Lib/site-packages/pip/_vendor/msgpack/__init__.py +0 -55
- venv/Lib/site-packages/pip/_vendor/msgpack/exceptions.py +0 -48
- venv/Lib/site-packages/pip/_vendor/msgpack/ext.py +0 -170
- venv/Lib/site-packages/pip/_vendor/msgpack/fallback.py +0 -929
- venv/Lib/site-packages/pip/_vendor/packaging/__init__.py +0 -15
- venv/Lib/site-packages/pip/_vendor/packaging/_elffile.py +0 -109
- venv/Lib/site-packages/pip/_vendor/packaging/_manylinux.py +0 -262
- venv/Lib/site-packages/pip/_vendor/packaging/_musllinux.py +0 -85
- venv/Lib/site-packages/pip/_vendor/packaging/_parser.py +0 -353
- venv/Lib/site-packages/pip/_vendor/packaging/_structures.py +0 -61
- venv/Lib/site-packages/pip/_vendor/packaging/_tokenizer.py +0 -195
- venv/Lib/site-packages/pip/_vendor/packaging/licenses/__init__.py +0 -145
- venv/Lib/site-packages/pip/_vendor/packaging/licenses/_spdx.py +0 -759
- venv/Lib/site-packages/pip/_vendor/packaging/markers.py +0 -362
- venv/Lib/site-packages/pip/_vendor/packaging/metadata.py +0 -862
- venv/Lib/site-packages/pip/_vendor/packaging/py.typed +0 -0
- venv/Lib/site-packages/pip/_vendor/packaging/requirements.py +0 -91
- venv/Lib/site-packages/pip/_vendor/packaging/specifiers.py +0 -1019
- venv/Lib/site-packages/pip/_vendor/packaging/tags.py +0 -656
- venv/Lib/site-packages/pip/_vendor/packaging/utils.py +0 -163
- venv/Lib/site-packages/pip/_vendor/packaging/version.py +0 -582
- venv/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py +0 -3676
- venv/Lib/site-packages/pip/_vendor/platformdirs/__init__.py +0 -631
- venv/Lib/site-packages/pip/_vendor/platformdirs/__main__.py +0 -55
- venv/Lib/site-packages/pip/_vendor/platformdirs/android.py +0 -249
- venv/Lib/site-packages/pip/_vendor/platformdirs/api.py +0 -299
- venv/Lib/site-packages/pip/_vendor/platformdirs/macos.py +0 -144
- venv/Lib/site-packages/pip/_vendor/platformdirs/py.typed +0 -0
- venv/Lib/site-packages/pip/_vendor/platformdirs/unix.py +0 -272
- venv/Lib/site-packages/pip/_vendor/platformdirs/version.py +0 -21
- venv/Lib/site-packages/pip/_vendor/platformdirs/windows.py +0 -272
- venv/Lib/site-packages/pip/_vendor/pygments/__init__.py +0 -82
- venv/Lib/site-packages/pip/_vendor/pygments/__main__.py +0 -17
- venv/Lib/site-packages/pip/_vendor/pygments/console.py +0 -70
- venv/Lib/site-packages/pip/_vendor/pygments/filter.py +0 -70
- venv/Lib/site-packages/pip/_vendor/pygments/filters/__init__.py +0 -940
- venv/Lib/site-packages/pip/_vendor/pygments/formatter.py +0 -129
- venv/Lib/site-packages/pip/_vendor/pygments/formatters/__init__.py +0 -157
- venv/Lib/site-packages/pip/_vendor/pygments/formatters/_mapping.py +0 -23
- venv/Lib/site-packages/pip/_vendor/pygments/lexer.py +0 -963
- venv/Lib/site-packages/pip/_vendor/pygments/lexers/__init__.py +0 -362
- venv/Lib/site-packages/pip/_vendor/pygments/lexers/_mapping.py +0 -602
- venv/Lib/site-packages/pip/_vendor/pygments/lexers/python.py +0 -1201
- venv/Lib/site-packages/pip/_vendor/pygments/modeline.py +0 -43
- venv/Lib/site-packages/pip/_vendor/pygments/plugin.py +0 -72
- venv/Lib/site-packages/pip/_vendor/pygments/regexopt.py +0 -91
- venv/Lib/site-packages/pip/_vendor/pygments/scanner.py +0 -104
- venv/Lib/site-packages/pip/_vendor/pygments/sphinxext.py +0 -247
- venv/Lib/site-packages/pip/_vendor/pygments/style.py +0 -203
- venv/Lib/site-packages/pip/_vendor/pygments/styles/__init__.py +0 -61
- venv/Lib/site-packages/pip/_vendor/pygments/styles/_mapping.py +0 -54
- venv/Lib/site-packages/pip/_vendor/pygments/token.py +0 -214
- venv/Lib/site-packages/pip/_vendor/pygments/unistring.py +0 -153
- venv/Lib/site-packages/pip/_vendor/pygments/util.py +0 -324
- venv/Lib/site-packages/pip/_vendor/pyproject_hooks/__init__.py +0 -31
- venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_impl.py +0 -410
- venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/__init__.py +0 -21
- venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py +0 -389
- venv/Lib/site-packages/pip/_vendor/pyproject_hooks/py.typed +0 -0
- venv/Lib/site-packages/pip/_vendor/requests/__init__.py +0 -179
- venv/Lib/site-packages/pip/_vendor/requests/__version__.py +0 -14
- venv/Lib/site-packages/pip/_vendor/requests/_internal_utils.py +0 -50
- venv/Lib/site-packages/pip/_vendor/requests/adapters.py +0 -719
- venv/Lib/site-packages/pip/_vendor/requests/api.py +0 -157
- venv/Lib/site-packages/pip/_vendor/requests/auth.py +0 -314
- venv/Lib/site-packages/pip/_vendor/requests/certs.py +0 -17
- venv/Lib/site-packages/pip/_vendor/requests/compat.py +0 -90
- venv/Lib/site-packages/pip/_vendor/requests/cookies.py +0 -561
- venv/Lib/site-packages/pip/_vendor/requests/exceptions.py +0 -151
- venv/Lib/site-packages/pip/_vendor/requests/help.py +0 -127
- venv/Lib/site-packages/pip/_vendor/requests/hooks.py +0 -33
- venv/Lib/site-packages/pip/_vendor/requests/models.py +0 -1039
- venv/Lib/site-packages/pip/_vendor/requests/packages.py +0 -25
- venv/Lib/site-packages/pip/_vendor/requests/sessions.py +0 -831
- venv/Lib/site-packages/pip/_vendor/requests/status_codes.py +0 -128
- venv/Lib/site-packages/pip/_vendor/requests/structures.py +0 -99
- venv/Lib/site-packages/pip/_vendor/requests/utils.py +0 -1086
- venv/Lib/site-packages/pip/_vendor/resolvelib/__init__.py +0 -27
- venv/Lib/site-packages/pip/_vendor/resolvelib/providers.py +0 -196
- venv/Lib/site-packages/pip/_vendor/resolvelib/py.typed +0 -0
- venv/Lib/site-packages/pip/_vendor/resolvelib/reporters.py +0 -55
- venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/__init__.py +0 -27
- venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/abstract.py +0 -47
- venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/criterion.py +0 -48
- venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/exceptions.py +0 -57
- venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/resolution.py +0 -622
- venv/Lib/site-packages/pip/_vendor/resolvelib/structs.py +0 -209
- venv/Lib/site-packages/pip/_vendor/rich/__init__.py +0 -177
- venv/Lib/site-packages/pip/_vendor/rich/__main__.py +0 -245
- venv/Lib/site-packages/pip/_vendor/rich/_cell_widths.py +0 -454
- venv/Lib/site-packages/pip/_vendor/rich/_emoji_codes.py +0 -3610
- venv/Lib/site-packages/pip/_vendor/rich/_emoji_replace.py +0 -32
- venv/Lib/site-packages/pip/_vendor/rich/_export_format.py +0 -76
- venv/Lib/site-packages/pip/_vendor/rich/_extension.py +0 -10
- venv/Lib/site-packages/pip/_vendor/rich/_fileno.py +0 -24
- venv/Lib/site-packages/pip/_vendor/rich/_inspect.py +0 -268
- venv/Lib/site-packages/pip/_vendor/rich/_log_render.py +0 -94
- venv/Lib/site-packages/pip/_vendor/rich/_loop.py +0 -43
- venv/Lib/site-packages/pip/_vendor/rich/_null_file.py +0 -69
- venv/Lib/site-packages/pip/_vendor/rich/_palettes.py +0 -309
- venv/Lib/site-packages/pip/_vendor/rich/_pick.py +0 -17
- venv/Lib/site-packages/pip/_vendor/rich/_ratio.py +0 -153
- venv/Lib/site-packages/pip/_vendor/rich/_spinners.py +0 -482
- venv/Lib/site-packages/pip/_vendor/rich/_stack.py +0 -16
- venv/Lib/site-packages/pip/_vendor/rich/_timer.py +0 -19
- venv/Lib/site-packages/pip/_vendor/rich/_win32_console.py +0 -661
- venv/Lib/site-packages/pip/_vendor/rich/_windows.py +0 -71
- venv/Lib/site-packages/pip/_vendor/rich/_windows_renderer.py +0 -56
- venv/Lib/site-packages/pip/_vendor/rich/_wrap.py +0 -93
- venv/Lib/site-packages/pip/_vendor/rich/abc.py +0 -33
- venv/Lib/site-packages/pip/_vendor/rich/align.py +0 -306
- venv/Lib/site-packages/pip/_vendor/rich/ansi.py +0 -241
- venv/Lib/site-packages/pip/_vendor/rich/bar.py +0 -93
- venv/Lib/site-packages/pip/_vendor/rich/box.py +0 -474
- venv/Lib/site-packages/pip/_vendor/rich/cells.py +0 -174
- venv/Lib/site-packages/pip/_vendor/rich/color.py +0 -621
- venv/Lib/site-packages/pip/_vendor/rich/color_triplet.py +0 -38
- venv/Lib/site-packages/pip/_vendor/rich/columns.py +0 -187
- venv/Lib/site-packages/pip/_vendor/rich/console.py +0 -2680
- venv/Lib/site-packages/pip/_vendor/rich/constrain.py +0 -37
- venv/Lib/site-packages/pip/_vendor/rich/containers.py +0 -167
- venv/Lib/site-packages/pip/_vendor/rich/control.py +0 -219
- venv/Lib/site-packages/pip/_vendor/rich/default_styles.py +0 -193
- venv/Lib/site-packages/pip/_vendor/rich/diagnose.py +0 -39
- venv/Lib/site-packages/pip/_vendor/rich/emoji.py +0 -91
- venv/Lib/site-packages/pip/_vendor/rich/errors.py +0 -34
- venv/Lib/site-packages/pip/_vendor/rich/file_proxy.py +0 -57
- venv/Lib/site-packages/pip/_vendor/rich/filesize.py +0 -88
- venv/Lib/site-packages/pip/_vendor/rich/highlighter.py +0 -232
- venv/Lib/site-packages/pip/_vendor/rich/json.py +0 -139
- venv/Lib/site-packages/pip/_vendor/rich/jupyter.py +0 -101
- venv/Lib/site-packages/pip/_vendor/rich/layout.py +0 -442
- venv/Lib/site-packages/pip/_vendor/rich/live.py +0 -400
- venv/Lib/site-packages/pip/_vendor/rich/live_render.py +0 -106
- venv/Lib/site-packages/pip/_vendor/rich/logging.py +0 -297
- venv/Lib/site-packages/pip/_vendor/rich/markup.py +0 -251
- venv/Lib/site-packages/pip/_vendor/rich/measure.py +0 -151
- venv/Lib/site-packages/pip/_vendor/rich/padding.py +0 -141
- venv/Lib/site-packages/pip/_vendor/rich/pager.py +0 -34
- venv/Lib/site-packages/pip/_vendor/rich/palette.py +0 -100
- venv/Lib/site-packages/pip/_vendor/rich/panel.py +0 -317
- venv/Lib/site-packages/pip/_vendor/rich/pretty.py +0 -1016
- venv/Lib/site-packages/pip/_vendor/rich/progress.py +0 -1715
- venv/Lib/site-packages/pip/_vendor/rich/progress_bar.py +0 -223
- venv/Lib/site-packages/pip/_vendor/rich/prompt.py +0 -400
- venv/Lib/site-packages/pip/_vendor/rich/protocol.py +0 -42
- venv/Lib/site-packages/pip/_vendor/rich/py.typed +0 -0
- venv/Lib/site-packages/pip/_vendor/rich/region.py +0 -10
- venv/Lib/site-packages/pip/_vendor/rich/repr.py +0 -149
- venv/Lib/site-packages/pip/_vendor/rich/rule.py +0 -130
- venv/Lib/site-packages/pip/_vendor/rich/scope.py +0 -86
- venv/Lib/site-packages/pip/_vendor/rich/screen.py +0 -54
- venv/Lib/site-packages/pip/_vendor/rich/segment.py +0 -752
- venv/Lib/site-packages/pip/_vendor/rich/spinner.py +0 -132
- venv/Lib/site-packages/pip/_vendor/rich/status.py +0 -131
- venv/Lib/site-packages/pip/_vendor/rich/style.py +0 -796
- venv/Lib/site-packages/pip/_vendor/rich/styled.py +0 -42
- venv/Lib/site-packages/pip/_vendor/rich/syntax.py +0 -985
- venv/Lib/site-packages/pip/_vendor/rich/table.py +0 -1006
- venv/Lib/site-packages/pip/_vendor/rich/terminal_theme.py +0 -153
- venv/Lib/site-packages/pip/_vendor/rich/text.py +0 -1361
- venv/Lib/site-packages/pip/_vendor/rich/theme.py +0 -115
- venv/Lib/site-packages/pip/_vendor/rich/themes.py +0 -5
- venv/Lib/site-packages/pip/_vendor/rich/traceback.py +0 -899
- venv/Lib/site-packages/pip/_vendor/rich/tree.py +0 -257
- venv/Lib/site-packages/pip/_vendor/tomli/__init__.py +0 -8
- venv/Lib/site-packages/pip/_vendor/tomli/_parser.py +0 -770
- venv/Lib/site-packages/pip/_vendor/tomli/_re.py +0 -112
- venv/Lib/site-packages/pip/_vendor/tomli/_types.py +0 -10
- venv/Lib/site-packages/pip/_vendor/tomli/py.typed +0 -1
- venv/Lib/site-packages/pip/_vendor/tomli_w/__init__.py +0 -4
- venv/Lib/site-packages/pip/_vendor/tomli_w/_writer.py +0 -229
- venv/Lib/site-packages/pip/_vendor/tomli_w/py.typed +0 -1
- venv/Lib/site-packages/pip/_vendor/truststore/__init__.py +0 -36
- venv/Lib/site-packages/pip/_vendor/truststore/_api.py +0 -333
- venv/Lib/site-packages/pip/_vendor/truststore/_macos.py +0 -571
- venv/Lib/site-packages/pip/_vendor/truststore/_openssl.py +0 -66
- venv/Lib/site-packages/pip/_vendor/truststore/_ssl_constants.py +0 -31
- venv/Lib/site-packages/pip/_vendor/truststore/_windows.py +0 -567
- venv/Lib/site-packages/pip/_vendor/truststore/py.typed +0 -0
- venv/Lib/site-packages/pip/_vendor/urllib3/__init__.py +0 -102
- venv/Lib/site-packages/pip/_vendor/urllib3/_collections.py +0 -355
- venv/Lib/site-packages/pip/_vendor/urllib3/_version.py +0 -2
- venv/Lib/site-packages/pip/_vendor/urllib3/connection.py +0 -572
- venv/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py +0 -1140
- venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__init__.py +0 -0
- venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py +0 -36
- venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.py +0 -0
- venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py +0 -519
- venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py +0 -397
- venv/Lib/site-packages/pip/_vendor/urllib3/contrib/appengine.py +0 -314
- venv/Lib/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py +0 -130
- venv/Lib/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py +0 -518
- venv/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py +0 -920
- venv/Lib/site-packages/pip/_vendor/urllib3/contrib/socks.py +0 -216
- venv/Lib/site-packages/pip/_vendor/urllib3/exceptions.py +0 -323
- venv/Lib/site-packages/pip/_vendor/urllib3/fields.py +0 -274
- venv/Lib/site-packages/pip/_vendor/urllib3/filepost.py +0 -98
- venv/Lib/site-packages/pip/_vendor/urllib3/packages/__init__.py +0 -0
- venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__init__.py +0 -0
- venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py +0 -51
- venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/weakref_finalize.py +0 -155
- venv/Lib/site-packages/pip/_vendor/urllib3/packages/six.py +0 -1076
- venv/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py +0 -540
- venv/Lib/site-packages/pip/_vendor/urllib3/request.py +0 -191
- venv/Lib/site-packages/pip/_vendor/urllib3/response.py +0 -879
- venv/Lib/site-packages/pip/_vendor/urllib3/util/__init__.py +0 -49
- venv/Lib/site-packages/pip/_vendor/urllib3/util/connection.py +0 -149
- venv/Lib/site-packages/pip/_vendor/urllib3/util/proxy.py +0 -57
- venv/Lib/site-packages/pip/_vendor/urllib3/util/queue.py +0 -22
- venv/Lib/site-packages/pip/_vendor/urllib3/util/request.py +0 -137
- venv/Lib/site-packages/pip/_vendor/urllib3/util/response.py +0 -107
- venv/Lib/site-packages/pip/_vendor/urllib3/util/retry.py +0 -622
- venv/Lib/site-packages/pip/_vendor/urllib3/util/ssl_.py +0 -504
- venv/Lib/site-packages/pip/_vendor/urllib3/util/ssl_match_hostname.py +0 -159
- venv/Lib/site-packages/pip/_vendor/urllib3/util/ssltransport.py +0 -221
- venv/Lib/site-packages/pip/_vendor/urllib3/util/timeout.py +0 -271
- venv/Lib/site-packages/pip/_vendor/urllib3/util/url.py +0 -435
- venv/Lib/site-packages/pip/_vendor/urllib3/util/wait.py +0 -152
- venv/Lib/site-packages/pip/py.typed +0 -4
- {cli_ih-0.6.3.1.dist-info → cli_ih-0.7.1.dist-info}/WHEEL +0 -0
|
@@ -1,364 +0,0 @@
|
|
|
1
|
-
from __future__ import annotations
|
|
2
|
-
|
|
3
|
-
import contextlib
|
|
4
|
-
import errno
|
|
5
|
-
import logging
|
|
6
|
-
import logging.handlers
|
|
7
|
-
import os
|
|
8
|
-
import sys
|
|
9
|
-
import threading
|
|
10
|
-
from collections.abc import Generator
|
|
11
|
-
from dataclasses import dataclass
|
|
12
|
-
from io import TextIOWrapper
|
|
13
|
-
from logging import Filter
|
|
14
|
-
from typing import Any, ClassVar
|
|
15
|
-
|
|
16
|
-
from pip._vendor.rich.console import (
|
|
17
|
-
Console,
|
|
18
|
-
ConsoleOptions,
|
|
19
|
-
ConsoleRenderable,
|
|
20
|
-
RenderableType,
|
|
21
|
-
RenderResult,
|
|
22
|
-
RichCast,
|
|
23
|
-
)
|
|
24
|
-
from pip._vendor.rich.highlighter import NullHighlighter
|
|
25
|
-
from pip._vendor.rich.logging import RichHandler
|
|
26
|
-
from pip._vendor.rich.segment import Segment
|
|
27
|
-
from pip._vendor.rich.style import Style
|
|
28
|
-
|
|
29
|
-
from pip._internal.utils._log import VERBOSE, getLogger
|
|
30
|
-
from pip._internal.utils.compat import WINDOWS
|
|
31
|
-
from pip._internal.utils.deprecation import DEPRECATION_MSG_PREFIX
|
|
32
|
-
from pip._internal.utils.misc import ensure_dir
|
|
33
|
-
|
|
34
|
-
_log_state = threading.local()
|
|
35
|
-
_stdout_console = None
|
|
36
|
-
_stderr_console = None
|
|
37
|
-
subprocess_logger = getLogger("pip.subprocessor")
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
class BrokenStdoutLoggingError(Exception):
|
|
41
|
-
"""
|
|
42
|
-
Raised if BrokenPipeError occurs for the stdout stream while logging.
|
|
43
|
-
"""
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
def _is_broken_pipe_error(exc_class: type[BaseException], exc: BaseException) -> bool:
|
|
47
|
-
if exc_class is BrokenPipeError:
|
|
48
|
-
return True
|
|
49
|
-
|
|
50
|
-
# On Windows, a broken pipe can show up as EINVAL rather than EPIPE:
|
|
51
|
-
# https://bugs.python.org/issue19612
|
|
52
|
-
# https://bugs.python.org/issue30418
|
|
53
|
-
if not WINDOWS:
|
|
54
|
-
return False
|
|
55
|
-
|
|
56
|
-
return isinstance(exc, OSError) and exc.errno in (errno.EINVAL, errno.EPIPE)
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
@contextlib.contextmanager
|
|
60
|
-
def indent_log(num: int = 2) -> Generator[None, None, None]:
|
|
61
|
-
"""
|
|
62
|
-
A context manager which will cause the log output to be indented for any
|
|
63
|
-
log messages emitted inside it.
|
|
64
|
-
"""
|
|
65
|
-
# For thread-safety
|
|
66
|
-
_log_state.indentation = get_indentation()
|
|
67
|
-
_log_state.indentation += num
|
|
68
|
-
try:
|
|
69
|
-
yield
|
|
70
|
-
finally:
|
|
71
|
-
_log_state.indentation -= num
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
def get_indentation() -> int:
|
|
75
|
-
return getattr(_log_state, "indentation", 0)
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
class IndentingFormatter(logging.Formatter):
|
|
79
|
-
default_time_format = "%Y-%m-%dT%H:%M:%S"
|
|
80
|
-
|
|
81
|
-
def __init__(
|
|
82
|
-
self,
|
|
83
|
-
*args: Any,
|
|
84
|
-
add_timestamp: bool = False,
|
|
85
|
-
**kwargs: Any,
|
|
86
|
-
) -> None:
|
|
87
|
-
"""
|
|
88
|
-
A logging.Formatter that obeys the indent_log() context manager.
|
|
89
|
-
|
|
90
|
-
:param add_timestamp: A bool indicating output lines should be prefixed
|
|
91
|
-
with their record's timestamp.
|
|
92
|
-
"""
|
|
93
|
-
self.add_timestamp = add_timestamp
|
|
94
|
-
super().__init__(*args, **kwargs)
|
|
95
|
-
|
|
96
|
-
def get_message_start(self, formatted: str, levelno: int) -> str:
|
|
97
|
-
"""
|
|
98
|
-
Return the start of the formatted log message (not counting the
|
|
99
|
-
prefix to add to each line).
|
|
100
|
-
"""
|
|
101
|
-
if levelno < logging.WARNING:
|
|
102
|
-
return ""
|
|
103
|
-
if formatted.startswith(DEPRECATION_MSG_PREFIX):
|
|
104
|
-
# Then the message already has a prefix. We don't want it to
|
|
105
|
-
# look like "WARNING: DEPRECATION: ...."
|
|
106
|
-
return ""
|
|
107
|
-
if levelno < logging.ERROR:
|
|
108
|
-
return "WARNING: "
|
|
109
|
-
|
|
110
|
-
return "ERROR: "
|
|
111
|
-
|
|
112
|
-
def format(self, record: logging.LogRecord) -> str:
|
|
113
|
-
"""
|
|
114
|
-
Calls the standard formatter, but will indent all of the log message
|
|
115
|
-
lines by our current indentation level.
|
|
116
|
-
"""
|
|
117
|
-
formatted = super().format(record)
|
|
118
|
-
message_start = self.get_message_start(formatted, record.levelno)
|
|
119
|
-
formatted = message_start + formatted
|
|
120
|
-
|
|
121
|
-
prefix = ""
|
|
122
|
-
if self.add_timestamp:
|
|
123
|
-
prefix = f"{self.formatTime(record)} "
|
|
124
|
-
prefix += " " * get_indentation()
|
|
125
|
-
formatted = "".join([prefix + line for line in formatted.splitlines(True)])
|
|
126
|
-
return formatted
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
@dataclass
|
|
130
|
-
class IndentedRenderable:
|
|
131
|
-
renderable: RenderableType
|
|
132
|
-
indent: int
|
|
133
|
-
|
|
134
|
-
def __rich_console__(
|
|
135
|
-
self, console: Console, options: ConsoleOptions
|
|
136
|
-
) -> RenderResult:
|
|
137
|
-
segments = console.render(self.renderable, options)
|
|
138
|
-
lines = Segment.split_lines(segments)
|
|
139
|
-
for line in lines:
|
|
140
|
-
yield Segment(" " * self.indent)
|
|
141
|
-
yield from line
|
|
142
|
-
yield Segment("\n")
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
class PipConsole(Console):
|
|
146
|
-
def on_broken_pipe(self) -> None:
|
|
147
|
-
# Reraise the original exception, rich 13.8.0+ exits by default
|
|
148
|
-
# instead, preventing our handler from firing.
|
|
149
|
-
raise BrokenPipeError() from None
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
def get_console(*, stderr: bool = False) -> Console:
|
|
153
|
-
if stderr:
|
|
154
|
-
assert _stderr_console is not None, "stderr rich console is missing!"
|
|
155
|
-
return _stderr_console
|
|
156
|
-
else:
|
|
157
|
-
assert _stdout_console is not None, "stdout rich console is missing!"
|
|
158
|
-
return _stdout_console
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
class RichPipStreamHandler(RichHandler):
|
|
162
|
-
KEYWORDS: ClassVar[list[str] | None] = []
|
|
163
|
-
|
|
164
|
-
def __init__(self, console: Console) -> None:
|
|
165
|
-
super().__init__(
|
|
166
|
-
console=console,
|
|
167
|
-
show_time=False,
|
|
168
|
-
show_level=False,
|
|
169
|
-
show_path=False,
|
|
170
|
-
highlighter=NullHighlighter(),
|
|
171
|
-
)
|
|
172
|
-
|
|
173
|
-
# Our custom override on Rich's logger, to make things work as we need them to.
|
|
174
|
-
def emit(self, record: logging.LogRecord) -> None:
|
|
175
|
-
style: Style | None = None
|
|
176
|
-
|
|
177
|
-
# If we are given a diagnostic error to present, present it with indentation.
|
|
178
|
-
if getattr(record, "rich", False):
|
|
179
|
-
assert isinstance(record.args, tuple)
|
|
180
|
-
(rich_renderable,) = record.args
|
|
181
|
-
assert isinstance(
|
|
182
|
-
rich_renderable, (ConsoleRenderable, RichCast, str)
|
|
183
|
-
), f"{rich_renderable} is not rich-console-renderable"
|
|
184
|
-
|
|
185
|
-
renderable: RenderableType = IndentedRenderable(
|
|
186
|
-
rich_renderable, indent=get_indentation()
|
|
187
|
-
)
|
|
188
|
-
else:
|
|
189
|
-
message = self.format(record)
|
|
190
|
-
renderable = self.render_message(record, message)
|
|
191
|
-
if record.levelno is not None:
|
|
192
|
-
if record.levelno >= logging.ERROR:
|
|
193
|
-
style = Style(color="red")
|
|
194
|
-
elif record.levelno >= logging.WARNING:
|
|
195
|
-
style = Style(color="yellow")
|
|
196
|
-
|
|
197
|
-
try:
|
|
198
|
-
self.console.print(renderable, overflow="ignore", crop=False, style=style)
|
|
199
|
-
except Exception:
|
|
200
|
-
self.handleError(record)
|
|
201
|
-
|
|
202
|
-
def handleError(self, record: logging.LogRecord) -> None:
|
|
203
|
-
"""Called when logging is unable to log some output."""
|
|
204
|
-
|
|
205
|
-
exc_class, exc = sys.exc_info()[:2]
|
|
206
|
-
# If a broken pipe occurred while calling write() or flush() on the
|
|
207
|
-
# stdout stream in logging's Handler.emit(), then raise our special
|
|
208
|
-
# exception so we can handle it in main() instead of logging the
|
|
209
|
-
# broken pipe error and continuing.
|
|
210
|
-
if (
|
|
211
|
-
exc_class
|
|
212
|
-
and exc
|
|
213
|
-
and self.console.file is sys.stdout
|
|
214
|
-
and _is_broken_pipe_error(exc_class, exc)
|
|
215
|
-
):
|
|
216
|
-
raise BrokenStdoutLoggingError()
|
|
217
|
-
|
|
218
|
-
return super().handleError(record)
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
class BetterRotatingFileHandler(logging.handlers.RotatingFileHandler):
|
|
222
|
-
def _open(self) -> TextIOWrapper:
|
|
223
|
-
ensure_dir(os.path.dirname(self.baseFilename))
|
|
224
|
-
return super()._open()
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
class MaxLevelFilter(Filter):
|
|
228
|
-
def __init__(self, level: int) -> None:
|
|
229
|
-
self.level = level
|
|
230
|
-
|
|
231
|
-
def filter(self, record: logging.LogRecord) -> bool:
|
|
232
|
-
return record.levelno < self.level
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
class ExcludeLoggerFilter(Filter):
|
|
236
|
-
"""
|
|
237
|
-
A logging Filter that excludes records from a logger (or its children).
|
|
238
|
-
"""
|
|
239
|
-
|
|
240
|
-
def filter(self, record: logging.LogRecord) -> bool:
|
|
241
|
-
# The base Filter class allows only records from a logger (or its
|
|
242
|
-
# children).
|
|
243
|
-
return not super().filter(record)
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
def setup_logging(verbosity: int, no_color: bool, user_log_file: str | None) -> int:
|
|
247
|
-
"""Configures and sets up all of the logging
|
|
248
|
-
|
|
249
|
-
Returns the requested logging level, as its integer value.
|
|
250
|
-
"""
|
|
251
|
-
|
|
252
|
-
# Determine the level to be logging at.
|
|
253
|
-
if verbosity >= 2:
|
|
254
|
-
level_number = logging.DEBUG
|
|
255
|
-
elif verbosity == 1:
|
|
256
|
-
level_number = VERBOSE
|
|
257
|
-
elif verbosity == -1:
|
|
258
|
-
level_number = logging.WARNING
|
|
259
|
-
elif verbosity == -2:
|
|
260
|
-
level_number = logging.ERROR
|
|
261
|
-
elif verbosity <= -3:
|
|
262
|
-
level_number = logging.CRITICAL
|
|
263
|
-
else:
|
|
264
|
-
level_number = logging.INFO
|
|
265
|
-
|
|
266
|
-
level = logging.getLevelName(level_number)
|
|
267
|
-
|
|
268
|
-
# The "root" logger should match the "console" level *unless* we also need
|
|
269
|
-
# to log to a user log file.
|
|
270
|
-
include_user_log = user_log_file is not None
|
|
271
|
-
if include_user_log:
|
|
272
|
-
additional_log_file = user_log_file
|
|
273
|
-
root_level = "DEBUG"
|
|
274
|
-
else:
|
|
275
|
-
additional_log_file = "/dev/null"
|
|
276
|
-
root_level = level
|
|
277
|
-
|
|
278
|
-
# Disable any logging besides WARNING unless we have DEBUG level logging
|
|
279
|
-
# enabled for vendored libraries.
|
|
280
|
-
vendored_log_level = "WARNING" if level in ["INFO", "ERROR"] else "DEBUG"
|
|
281
|
-
|
|
282
|
-
# Shorthands for clarity
|
|
283
|
-
handler_classes = {
|
|
284
|
-
"stream": "pip._internal.utils.logging.RichPipStreamHandler",
|
|
285
|
-
"file": "pip._internal.utils.logging.BetterRotatingFileHandler",
|
|
286
|
-
}
|
|
287
|
-
handlers = ["console", "console_errors", "console_subprocess"] + (
|
|
288
|
-
["user_log"] if include_user_log else []
|
|
289
|
-
)
|
|
290
|
-
global _stdout_console, stderr_console
|
|
291
|
-
_stdout_console = PipConsole(file=sys.stdout, no_color=no_color, soft_wrap=True)
|
|
292
|
-
_stderr_console = PipConsole(file=sys.stderr, no_color=no_color, soft_wrap=True)
|
|
293
|
-
|
|
294
|
-
logging.config.dictConfig(
|
|
295
|
-
{
|
|
296
|
-
"version": 1,
|
|
297
|
-
"disable_existing_loggers": False,
|
|
298
|
-
"filters": {
|
|
299
|
-
"exclude_warnings": {
|
|
300
|
-
"()": "pip._internal.utils.logging.MaxLevelFilter",
|
|
301
|
-
"level": logging.WARNING,
|
|
302
|
-
},
|
|
303
|
-
"restrict_to_subprocess": {
|
|
304
|
-
"()": "logging.Filter",
|
|
305
|
-
"name": subprocess_logger.name,
|
|
306
|
-
},
|
|
307
|
-
"exclude_subprocess": {
|
|
308
|
-
"()": "pip._internal.utils.logging.ExcludeLoggerFilter",
|
|
309
|
-
"name": subprocess_logger.name,
|
|
310
|
-
},
|
|
311
|
-
},
|
|
312
|
-
"formatters": {
|
|
313
|
-
"indent": {
|
|
314
|
-
"()": IndentingFormatter,
|
|
315
|
-
"format": "%(message)s",
|
|
316
|
-
},
|
|
317
|
-
"indent_with_timestamp": {
|
|
318
|
-
"()": IndentingFormatter,
|
|
319
|
-
"format": "%(message)s",
|
|
320
|
-
"add_timestamp": True,
|
|
321
|
-
},
|
|
322
|
-
},
|
|
323
|
-
"handlers": {
|
|
324
|
-
"console": {
|
|
325
|
-
"level": level,
|
|
326
|
-
"class": handler_classes["stream"],
|
|
327
|
-
"console": _stdout_console,
|
|
328
|
-
"filters": ["exclude_subprocess", "exclude_warnings"],
|
|
329
|
-
"formatter": "indent",
|
|
330
|
-
},
|
|
331
|
-
"console_errors": {
|
|
332
|
-
"level": "WARNING",
|
|
333
|
-
"class": handler_classes["stream"],
|
|
334
|
-
"console": _stderr_console,
|
|
335
|
-
"filters": ["exclude_subprocess"],
|
|
336
|
-
"formatter": "indent",
|
|
337
|
-
},
|
|
338
|
-
# A handler responsible for logging to the console messages
|
|
339
|
-
# from the "subprocessor" logger.
|
|
340
|
-
"console_subprocess": {
|
|
341
|
-
"level": level,
|
|
342
|
-
"class": handler_classes["stream"],
|
|
343
|
-
"console": _stderr_console,
|
|
344
|
-
"filters": ["restrict_to_subprocess"],
|
|
345
|
-
"formatter": "indent",
|
|
346
|
-
},
|
|
347
|
-
"user_log": {
|
|
348
|
-
"level": "DEBUG",
|
|
349
|
-
"class": handler_classes["file"],
|
|
350
|
-
"filename": additional_log_file,
|
|
351
|
-
"encoding": "utf-8",
|
|
352
|
-
"delay": True,
|
|
353
|
-
"formatter": "indent_with_timestamp",
|
|
354
|
-
},
|
|
355
|
-
},
|
|
356
|
-
"root": {
|
|
357
|
-
"level": root_level,
|
|
358
|
-
"handlers": handlers,
|
|
359
|
-
},
|
|
360
|
-
"loggers": {"pip._vendor": {"level": vendored_log_level}},
|
|
361
|
-
}
|
|
362
|
-
)
|
|
363
|
-
|
|
364
|
-
return level_number
|