[ Avaa Bypassed ]




Upload:

Command:

hmhc3928@3.145.96.78: ~ $
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

Filemanager

Name Type Size Permission Actions
__pycache__ Folder 0755
.__init__.pyo.40009 File 164 B 0644
.appdirs.pyo.40009 File 1.78 KB 0644
.compat.pyo.40009 File 8.62 KB 0644
.compatibility_tags.pyo.40009 File 4.45 KB 0644
.datetime.pyo.40009 File 625 B 0644
.deprecation.pyo.40009 File 3.44 KB 0644
.distutils_args.pyo.40009 File 1.6 KB 0644
.entrypoints.pyo.40009 File 1.47 KB 0644
.filetypes.pyo.40009 File 792 B 0644
.glibc.pyo.40009 File 2.19 KB 0644
.hashes.pyo.40009 File 5.68 KB 0644
.inject_securetransport.pyo.40009 File 1.07 KB 0644
.logging.pyo.40009 File 11.6 KB 0644
.misc.pyo.40009 File 32.2 KB 0644
.models.pyo.40009 File 2.55 KB 0644
.packaging.pyo.40009 File 3.27 KB 0644
.parallel.pyo.40009 File 3.62 KB 0644
.pkg_resources.pyo.40009 File 2.39 KB 0644
.typing.pyo.40009 File 1.52 KB 0644
.virtualenv.pyo.40009 File 4.11 KB 0644
.wheel.pyo.40009 File 7.27 KB 0644
__init__.py File 0 B 0644
__init__.pyc File 164 B 0644
__init__.pyo File 164 B 0644
appdirs.py File 1.32 KB 0644
appdirs.pyc File 1.78 KB 0644
appdirs.pyo File 1.78 KB 0644
compat.py File 9.27 KB 0644
compat.pyc File 8.62 KB 0644
compat.pyo File 8.62 KB 0644
compatibility_tags.py File 5.31 KB 0644
compatibility_tags.pyc File 4.45 KB 0644
compatibility_tags.pyo File 4.45 KB 0644
datetime.py File 295 B 0644
datetime.pyc File 625 B 0644
datetime.pyo File 625 B 0644
deprecation.py File 3.24 KB 0644
deprecation.pyc File 3.44 KB 0644
deprecation.pyo File 3.44 KB 0644
direct_url_helpers.py File 4.26 KB 0644
direct_url_helpers.pyc File 3.37 KB 0644
direct_url_helpers.pyo File 3.24 KB 0644
distutils_args.py File 1.32 KB 0644
distutils_args.pyc File 1.6 KB 0644
distutils_args.pyo File 1.6 KB 0644
encoding.py File 1.25 KB 0644
encoding.pyc File 1.61 KB 0644
encoding.pyo File 1.56 KB 0644
entrypoints.py File 1.19 KB 0644
entrypoints.pyc File 1.47 KB 0644
entrypoints.pyo File 1.47 KB 0644
filesystem.py File 6.78 KB 0644
filesystem.pyc File 7.4 KB 0644
filesystem.pyo File 7.35 KB 0644
filetypes.py File 571 B 0644
filetypes.pyc File 792 B 0644
filetypes.pyo File 792 B 0644
glibc.py File 3.22 KB 0644
glibc.pyc File 2.19 KB 0644
glibc.pyo File 2.19 KB 0644
hashes.py File 4.57 KB 0644
hashes.pyc File 5.68 KB 0644
hashes.pyo File 5.68 KB 0644
inject_securetransport.py File 810 B 0644
inject_securetransport.pyc File 1.07 KB 0644
inject_securetransport.pyo File 1.07 KB 0644
logging.py File 12.79 KB 0644
logging.pyc File 11.6 KB 0644
logging.pyo File 11.6 KB 0644
misc.py File 27.67 KB 0644
misc.pyc File 32.2 KB 0644
misc.pyo File 32.2 KB 0644
models.py File 1.17 KB 0644
models.pyc File 2.55 KB 0644
models.pyo File 2.55 KB 0644
packaging.py File 2.96 KB 0644
packaging.pyc File 3.27 KB 0644
packaging.pyo File 3.27 KB 0644
parallel.py File 3.32 KB 0644
parallel.pyc File 3.62 KB 0644
parallel.pyo File 3.62 KB 0644
pkg_resources.py File 1.22 KB 0644
pkg_resources.pyc File 2.39 KB 0644
pkg_resources.pyo File 2.39 KB 0644
setuptools_build.py File 4.94 KB 0644
setuptools_build.pyc File 3.83 KB 0644
setuptools_build.pyo File 3.75 KB 0644
subprocess.py File 9.69 KB 0644
subprocess.pyc File 6.77 KB 0644
subprocess.pyo File 6.69 KB 0644
temp_dir.py File 8.18 KB 0644
temp_dir.pyc File 8.75 KB 0644
temp_dir.pyo File 8.62 KB 0644
typing.py File 1.37 KB 0644
typing.pyc File 1.52 KB 0644
typing.pyo File 1.52 KB 0644
unpacking.py File 9.27 KB 0644
unpacking.pyc File 7.83 KB 0644
unpacking.pyo File 7.79 KB 0644
urls.py File 1.49 KB 0644
urls.pyc File 1.94 KB 0644
urls.pyo File 1.8 KB 0644
virtualenv.py File 3.62 KB 0644
virtualenv.pyc File 4.11 KB 0644
virtualenv.pyo File 4.11 KB 0644
wheel.py File 7.13 KB 0644
wheel.pyc File 7.27 KB 0644
wheel.pyo File 7.27 KB 0644