Current Path: > > opt > > hc_python > > lib > python3.12 > site-packages > pip > _internal > utils
Operation : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
__pycache__ | Directory | - | - | |
__init__.py | File | 0 bytes | May 23 2025 10:34:25. | |
_jaraco_text.py | File | 3350 bytes | May 23 2025 10:34:25. | |
_log.py | File | 1015 bytes | May 23 2025 10:34:25. | |
appdirs.py | File | 1705 bytes | May 23 2025 10:34:25. | |
compat.py | File | 2399 bytes | May 23 2025 10:34:25. | |
compatibility_tags.py | File | 6662 bytes | May 23 2025 10:34:25. | |
datetime.py | File | 241 bytes | May 23 2025 10:34:25. | |
deprecation.py | File | 3707 bytes | May 23 2025 10:34:25. | |
direct_url_helpers.py | File | 3196 bytes | May 23 2025 10:34:25. | |
egg_link.py | File | 2463 bytes | May 23 2025 10:34:25. | |
entrypoints.py | File | 3325 bytes | May 23 2025 10:34:25. | |
filesystem.py | File | 4950 bytes | May 23 2025 10:34:25. | |
filetypes.py | File | 715 bytes | May 23 2025 10:34:25. | |
glibc.py | File | 3734 bytes | May 23 2025 10:34:25. | |
hashes.py | File | 4972 bytes | May 23 2025 10:34:25. | |
logging.py | File | 12076 bytes | May 23 2025 10:34:25. | |
misc.py | File | 23450 bytes | May 23 2025 10:34:25. | |
packaging.py | File | 1603 bytes | May 23 2025 10:34:25. | |
retry.py | File | 1392 bytes | May 23 2025 10:34:25. | |
setuptools_build.py | File | 4482 bytes | May 23 2025 10:34:25. | |
subprocess.py | File | 8988 bytes | May 23 2025 10:34:25. | |
temp_dir.py | File | 9310 bytes | May 23 2025 10:34:25. | |
unpacking.py | File | 11926 bytes | May 23 2025 10:34:25. | |
urls.py | File | 1599 bytes | May 23 2025 10:34:25. | |
virtualenv.py | File | 3456 bytes | May 23 2025 10:34:25. | |
wheel.py | File | 4493 bytes | May 23 2025 10:34:25. |
""" A module that implements tooling to enable easy warnings about deprecations. """ import logging import warnings from typing import Any, Optional, TextIO, Type, Union from pip._vendor.packaging.version import parse from pip import __version__ as current_version # NOTE: tests patch this name. DEPRECATION_MSG_PREFIX = "DEPRECATION: " class PipDeprecationWarning(Warning): pass _original_showwarning: Any = None # Warnings <-> Logging Integration def _showwarning( message: Union[Warning, str], category: Type[Warning], filename: str, lineno: int, file: Optional[TextIO] = None, line: Optional[str] = None, ) -> None: if file is not None: if _original_showwarning is not None: _original_showwarning(message, category, filename, lineno, file, line) elif issubclass(category, PipDeprecationWarning): # We use a specially named logger which will handle all of the # deprecation messages for pip. logger = logging.getLogger("pip._internal.deprecations") logger.warning(message) else: _original_showwarning(message, category, filename, lineno, file, line) def install_warning_logger() -> None: # Enable our Deprecation Warnings warnings.simplefilter("default", PipDeprecationWarning, append=True) global _original_showwarning if _original_showwarning is None: _original_showwarning = warnings.showwarning warnings.showwarning = _showwarning def deprecated( *, reason: str, replacement: Optional[str], gone_in: Optional[str], feature_flag: Optional[str] = None, issue: Optional[int] = None, ) -> None: """Helper to deprecate existing functionality. reason: Textual reason shown to the user about why this functionality has been deprecated. Should be a complete sentence. replacement: Textual suggestion shown to the user about what alternative functionality they can use. gone_in: The version of pip does this functionality should get removed in. Raises an error if pip's current version is greater than or equal to this. feature_flag: Command-line flag of the form --use-feature={feature_flag} for testing upcoming functionality. issue: Issue number on the tracker that would serve as a useful place for users to find related discussion and provide feedback. """ # Determine whether or not the feature is already gone in this version. is_gone = gone_in is not None and parse(current_version) >= parse(gone_in) message_parts = [ (reason, f"{DEPRECATION_MSG_PREFIX}{{}}"), ( gone_in, ( "pip {} will enforce this behaviour change." if not is_gone else "Since pip {}, this is no longer supported." ), ), ( replacement, "A possible replacement is {}.", ), ( feature_flag, ( "You can use the flag --use-feature={} to test the upcoming behaviour." if not is_gone else None ), ), ( issue, "Discussion can be found at https://github.com/pypa/pip/issues/{}", ), ] message = " ".join( format_str.format(value) for value, format_str in message_parts if format_str is not None and value is not None ) # Raise as an error if this behaviour is deprecated. if is_gone: raise PipDeprecationWarning(message) warnings.warn(message, category=PipDeprecationWarning, stacklevel=2)
SILENT KILLER Tool