GRAYBYTE WORDPRESS FILE MANAGER3700

Server IP : 198.54.121.189 / Your IP : 216.73.216.112
System : Linux premium69.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
PHP Version : 7.4.33
Disable Function : NONE
cURL : ON | WGET : ON | Sudo : OFF | Pkexec : OFF
Directory : /opt/alt/python37/lib/python3.7/site-packages/pip/_internal/utils/
Upload Files :
Current_dir [ Not Writeable ] Document_root [ Writeable ]

Command :


Current File : /opt/alt/python37/lib/python3.7/site-packages/pip/_internal/utils//direct_url_helpers.py
import logging

from pip._internal.models.direct_url import (
    DIRECT_URL_METADATA_NAME,
    ArchiveInfo,
    DirectUrl,
    DirectUrlValidationError,
    DirInfo,
    VcsInfo,
)
from pip._internal.utils.typing import MYPY_CHECK_RUNNING
from pip._internal.vcs import vcs

try:
    from json import JSONDecodeError
except ImportError:
    # PY2
    JSONDecodeError = ValueError  # type: ignore

if MYPY_CHECK_RUNNING:
    from typing import Optional

    from pip._internal.models.link import Link

    from pip._vendor.pkg_resources import Distribution

logger = logging.getLogger(__name__)


def direct_url_as_pep440_direct_reference(direct_url, name):
    # type: (DirectUrl, 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)
        # pip should never reach this point for editables, since
        # pip freeze inspects the editable project location to produce
        # the requirement string
        assert not direct_url.info.editable
        requirement += direct_url.url
    if direct_url.subdirectory:
        fragments.append("subdirectory=" + direct_url.subdirectory)
    if fragments:
        requirement += "#" + "&".join(fragments)
    return requirement


def direct_url_from_link(link, source_dir=None, link_is_in_wheel_cache=False):
    # type: (Link, Optional[str], bool) -> 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 = "{}={}".format(hash_name, link.hash)
        return DirectUrl(
            url=link.url_without_fragment,
            info=ArchiveInfo(hash=hash),
            subdirectory=link.subdirectory_fragment,
        )


def dist_get_direct_url(dist):
    # type: (Distribution) -> Optional[DirectUrl]
    """Obtain a DirectUrl from a pkg_resource.Distribution.

    Returns None if the distribution has no `direct_url.json` metadata,
    or if `direct_url.json` is invalid.
    """
    if not dist.has_metadata(DIRECT_URL_METADATA_NAME):
        return None
    try:
        return DirectUrl.from_json(dist.get_metadata(DIRECT_URL_METADATA_NAME))
    except (
        DirectUrlValidationError,
        JSONDecodeError,
        UnicodeDecodeError
    ) as e:
        logger.warning(
            "Error parsing %s for %s: %s",
            DIRECT_URL_METADATA_NAME,
            dist.project_name,
            e,
        )
        return None

[ Back ]
Name
Size
Last Modified
Owner / Group
Permissions
Options
..
--
March 03 2024 22:57:12
root / linksafe
0755
__pycache__
--
March 03 2024 22:57:12
root / linksafe
0755
__init__.py
0 KB
November 13 2023 21:31:06
root / linksafe
0644
appdirs.py
1.317 KB
November 13 2023 21:31:06
root / linksafe
0644
compat.py
9.267 KB
November 13 2023 21:31:06
root / linksafe
0644
compatibility_tags.py
5.312 KB
November 13 2023 21:31:06
root / linksafe
0644
datetime.py
0.288 KB
November 13 2023 21:31:06
root / linksafe
0644
deprecation.py
3.24 KB
November 13 2023 21:31:06
root / linksafe
0644
direct_url_helpers.py
4.257 KB
November 13 2023 21:31:06
root / linksafe
0644
distutils_args.py
1.318 KB
November 13 2023 21:31:06
root / linksafe
0644
encoding.py
1.254 KB
November 13 2023 21:31:06
root / linksafe
0644
entrypoints.py
1.19 KB
November 13 2023 21:31:06
root / linksafe
0644
filesystem.py
6.78 KB
November 13 2023 21:31:06
root / linksafe
0644
filetypes.py
0.558 KB
November 13 2023 21:31:06
root / linksafe
0644
glibc.py
3.22 KB
November 13 2023 21:31:06
root / linksafe
0644
hashes.py
4.568 KB
November 13 2023 21:31:06
root / linksafe
0644
inject_securetransport.py
0.791 KB
November 13 2023 21:31:06
root / linksafe
0644
logging.py
12.786 KB
November 13 2023 21:31:06
root / linksafe
0644
misc.py
27.667 KB
November 13 2023 21:31:06
root / linksafe
0644
models.py
1.173 KB
November 13 2023 21:31:06
root / linksafe
0644
packaging.py
2.964 KB
November 13 2023 21:31:06
root / linksafe
0644
parallel.py
3.324 KB
November 13 2023 21:31:06
root / linksafe
0644
pkg_resources.py
1.225 KB
November 13 2023 21:31:06
root / linksafe
0644
setuptools_build.py
4.939 KB
November 13 2023 21:31:06
root / linksafe
0644
subprocess.py
9.691 KB
November 13 2023 21:31:06
root / linksafe
0644
temp_dir.py
8.182 KB
November 13 2023 21:31:06
root / linksafe
0644
typing.py
1.368 KB
November 13 2023 21:31:06
root / linksafe
0644
unpacking.py
9.266 KB
November 13 2023 21:31:06
root / linksafe
0644
urls.py
1.491 KB
November 13 2023 21:31:06
root / linksafe
0644
virtualenv.py
3.619 KB
November 13 2023 21:31:06
root / linksafe
0644
wheel.py
7.132 KB
November 13 2023 21:31:06
root / linksafe
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025
CONTACT ME
Static GIF