SILENT KILLERPanel

Current Path: > > opt > alt > python311 > lib > python3.11 > 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 ]

Files and Folders in: //opt/alt/python311/lib/python3.11/site-packages/pip/_internal/utils

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
__init__.py File 0 bytes November 13 2023 22:00:31.
_log.py File 1015 bytes November 13 2023 22:00:31.
appdirs.py File 1665 bytes November 13 2023 22:00:31.
compat.py File 1884 bytes November 13 2023 22:00:31.
compatibility_tags.py File 5377 bytes November 13 2023 22:00:31.
datetime.py File 242 bytes November 13 2023 22:00:31.
deprecation.py File 3627 bytes November 13 2023 22:00:31.
direct_url_helpers.py File 3206 bytes November 13 2023 22:00:31.
distutils_args.py File 1249 bytes November 13 2023 22:00:31.
egg_link.py File 2203 bytes November 13 2023 22:00:31.
encoding.py File 1169 bytes November 13 2023 22:00:31.
entrypoints.py File 1130 bytes November 13 2023 22:00:31.
filesystem.py File 5893 bytes November 13 2023 22:00:31.
filetypes.py File 716 bytes November 13 2023 22:00:31.
glibc.py File 3110 bytes November 13 2023 22:00:31.
hashes.py File 4811 bytes November 13 2023 22:00:31.
inject_securetransport.py File 795 bytes November 13 2023 22:00:31.
logging.py File 11532 bytes November 13 2023 22:00:31.
misc.py File 20778 bytes November 13 2023 22:00:31.
models.py File 1193 bytes November 13 2023 22:00:31.
packaging.py File 2952 bytes November 13 2023 22:00:31.
parallel.py File 3196 bytes November 13 2023 22:00:31.
pkg_resources.py File 987 bytes November 13 2023 22:00:31.
setuptools_build.py File 4697 bytes November 13 2023 22:00:31.
subprocess.py File 10058 bytes November 13 2023 22:00:31.
temp_dir.py File 7662 bytes November 13 2023 22:00:31.
unpacking.py File 8906 bytes November 13 2023 22:00:31.
urls.py File 1759 bytes November 13 2023 22:00:31.
virtualenv.py File 3459 bytes November 13 2023 22:00:31.
wheel.py File 6163 bytes November 13 2023 22:00:31.

Reading File: //opt/alt/python311/lib/python3.11/site-packages/pip/_internal/utils/direct_url_helpers.py

from typing import Optional

from pip._internal.models.direct_url import ArchiveInfo, DirectUrl, DirInfo, VcsInfo
from pip._internal.models.link import Link
from pip._internal.utils.urls import path_to_url
from pip._internal.vcs import vcs


def direct_url_as_pep440_direct_reference(direct_url: DirectUrl, name: str) -> str:
    """Convert a DirectUrl to a pip requirement string."""
    direct_url.validate()  # if invalid, this is a pip bug
    requirement = name + " @ "
    fragments = []
    if isinstance(direct_url.info, VcsInfo):
        requirement += "{}+{}@{}".format(
            direct_url.info.vcs, direct_url.url, direct_url.info.commit_id
        )
    elif isinstance(direct_url.info, ArchiveInfo):
        requirement += direct_url.url
        if direct_url.info.hash:
            fragments.append(direct_url.info.hash)
    else:
        assert isinstance(direct_url.info, DirInfo)
        requirement += direct_url.url
    if direct_url.subdirectory:
        fragments.append("subdirectory=" + direct_url.subdirectory)
    if fragments:
        requirement += "#" + "&".join(fragments)
    return requirement


def direct_url_for_editable(source_dir: str) -> DirectUrl:
    return DirectUrl(
        url=path_to_url(source_dir),
        info=DirInfo(editable=True),
    )


def direct_url_from_link(
    link: Link, source_dir: Optional[str] = None, link_is_in_wheel_cache: bool = False
) -> DirectUrl:
    if link.is_vcs:
        vcs_backend = vcs.get_backend_for_scheme(link.scheme)
        assert vcs_backend
        url, requested_revision, _ = vcs_backend.get_url_rev_and_auth(
            link.url_without_fragment
        )
        # For VCS links, we need to find out and add commit_id.
        if link_is_in_wheel_cache:
            # If the requested VCS link corresponds to a cached
            # wheel, it means the requested revision was an
            # immutable commit hash, otherwise it would not have
            # been cached. In that case we don't have a source_dir
            # with the VCS checkout.
            assert requested_revision
            commit_id = requested_revision
        else:
            # If the wheel was not in cache, it means we have
            # had to checkout from VCS to build and we have a source_dir
            # which we can inspect to find out the commit id.
            assert source_dir
            commit_id = vcs_backend.get_revision(source_dir)
        return DirectUrl(
            url=url,
            info=VcsInfo(
                vcs=vcs_backend.name,
                commit_id=commit_id,
                requested_revision=requested_revision,
            ),
            subdirectory=link.subdirectory_fragment,
        )
    elif link.is_existing_dir():
        return DirectUrl(
            url=link.url_without_fragment,
            info=DirInfo(),
            subdirectory=link.subdirectory_fragment,
        )
    else:
        hash = None
        hash_name = link.hash_name
        if hash_name:
            hash = f"{hash_name}={link.hash}"
        return DirectUrl(
            url=link.url_without_fragment,
            info=ArchiveInfo(hash=hash),
            subdirectory=link.subdirectory_fragment,
        )

SILENT KILLER Tool