piptools.repositories package#

Submodules#

Module contents#

class piptools.repositories.LocalRequirementsRepository(existing_pins: Mapping[str, InstallationCandidate], proxied_repository: PyPIRepository, reuse_hashes: bool = True)#

Bases: BaseRepository

The LocalRequirementsRepository proxied the _real_ repository by first checking if a requirement can be satisfied by existing pins (i.e. the result of a previous compile step).

In effect, if a requirement can be satisfied with a version pinned in the requirements file, we prefer that version over the best match found in PyPI. This keeps updates to the requirements.txt down to a minimum.

_abc_impl = <_abc._abc_data object>#
allow_all_wheels() Iterator[None]#

Monkey patches pip.Wheel to allow wheels from all platforms and Python versions.

clear_caches() None#

Should clear any caches used by the implementation.

property command: InstallCommand#

Return an install command instance.

find_best_match(ireq: InstallRequirement, prereleases: bool | None = None) InstallationCandidate#

Returns a pinned InstallRequirement object that indicates the best match for the given InstallRequirement according to the external repository.

property finder: PackageFinder#

Returns a package finder to interact with simple repository API (PEP 503)

get_dependencies(ireq: InstallRequirement) set[InstallRequirement]#

Given a pinned, URL, or editable InstallRequirement, returns a set of dependencies (also InstallRequirements, but not necessarily pinned). They indicate the secondary dependencies for the given requirement.

get_hashes(ireq: InstallRequirement) set[str]#

Given a pinned InstallRequirement, returns a set of hashes that represent all of the files for a given requirement. It is not acceptable for an editable or unpinned requirement to be passed to this function.

property options: Values#

Returns parsed pip options

property session: PipSession#

Returns a session to make requests

class piptools.repositories.PyPIRepository(pip_args: list[str], cache_dir: str)#

Bases: BaseRepository

HASHABLE_PACKAGE_TYPES = {'bdist_wheel', 'sdist'}#

The PyPIRepository will use the provided Finder instance to lookup packages. Typically, it looks up packages on PyPI (the default implicit config), but any other PyPI mirror can be used if index_urls is changed/configured on the Finder.

_abc_impl = <_abc._abc_data object>#
_get_download_path(ireq: InstallRequirement) str#

Determine the download dir location in a way which avoids name collisions.

_get_file_hash(link: Link) str#
_get_hashes_from_pypi(ireq: InstallRequirement) dict[str, str]#

Builds a mapping from the release URLs to their hashes as reported by the PyPI JSON API for a given InstallRequirement.

_get_matching_candidates(ireq: InstallRequirement) set[InstallationCandidate]#

Returns all candidates that satisfy the given InstallRequirement.

_get_project(ireq: InstallRequirement) Any#

Return a dict of a project info from PyPI JSON API for a given InstallRequirement. Return None on HTTP/JSON error or if a package is not found on PyPI server.

API reference: https://warehouse.readthedocs.io/api-reference/json/

_get_req_hashes(ireq: InstallRequirement) set[str]#

Collects the hashes for all candidates satisfying the given InstallRequirement. Computes the hashes for the candidates that don’t have one reported by their index.

allow_all_wheels() Iterator[None]#

Monkey patches pip.Wheel to allow wheels from all platforms and Python versions.

This also saves the candidate cache and set a new one, or else the results from the previous non-patched calls will interfere.

clear_caches() None#

Should clear any caches used by the implementation.

property command: InstallCommand#

Return an install command instance.

find_all_candidates(req_name: str) list[InstallationCandidate]#
find_best_match(ireq: InstallRequirement, prereleases: bool | None = None) InstallRequirement#

Returns a pinned InstallRequirement object that indicates the best match for the given InstallRequirement according to the external repository.

property finder: PackageFinder#

Returns a package finder to interact with simple repository API (PEP 503)

get_dependencies(ireq: InstallRequirement) set[InstallRequirement]#

Given a pinned, URL, or editable InstallRequirement, returns a set of dependencies (also InstallRequirements, but not necessarily pinned). They indicate the secondary dependencies for the given requirement.

get_hashes(ireq: InstallRequirement) set[str]#

Given an InstallRequirement, return a set of hashes that represent all of the files for a given requirement. Unhashable requirements return an empty set. Unpinned requirements raise a TypeError.

property options: Values#

Returns parsed pip options

resolve_reqs(download_dir: str | None, ireq: InstallRequirement, wheel_cache: WheelCache) set[InstallationCandidate]#
property session: PipSession#

Returns a session to make requests