From c530dac47e9976a8f1a0744728c2d4f4fb9e451e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jonathan=20Pich=C3=A9?= Date: Fri, 13 May 2022 17:22:55 -0400 Subject: [PATCH] Update repositories.md Clarifies default vs secondary (see discussion in #3855) --- docs/repositories.md | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) diff --git a/docs/repositories.md b/docs/repositories.md index 490d78bf785..e3af4b485cd 100644 --- a/docs/repositories.md +++ b/docs/repositories.md @@ -94,7 +94,7 @@ when publishing a package. ### Project Configuration -These package sources maybe managed using the [`source`]({{< relref "cli#source" >}}) command for +These package sources may be managed using the [`source`]({{< relref "cli#source" >}}) command for your project. ```bash @@ -112,9 +112,27 @@ default = false secondary = false ``` +When a package source is defined like this, it takes precedence over [PyPI](https://pypi.org). + +To ignore [PyPI](https://pypi.org) completely, use `default = true`. + +To target a package source only on specific packages, use `secondary = true` on the package source, and specify the `source` when adding the dependency. +In the example below, `my-lib` will be obtained from the custom package source and `urllib3` will use the [PyPI](https://pypi.org) source. + +```toml +[tool.poetry.requirements] +my-lib = { version = "*", source = "foo" } +urllib3 = "*" + +[[tool.poetry.source]] +name = "foo" +url = "https://foo.bar/simple/" +secondary = true +``` + {{% warning %}} -If package sources are defined for a project, these will take precedence over +Reminder: If package sources are defined for a project, these will take precedence over [PyPI](https://pypi.org). If you do not want this to be the case, you should declare **all** package sources to be [secondary](#secondary-package-sources).