--- title: "Auto-linking" output: rmarkdown::html_vignette description: > Learn how pkgdown's automatic linking works, and how you can customise it. vignette: > %\VignetteIndexEntry{Auto-linking} %\VignetteEngine{knitr::rmarkdown} %\VignetteEncoding{UTF-8} --- ```{r, include = FALSE} knitr::opts_chunk$set( collapse = TRUE, comment = "#>" ) ``` ## Within a package pkgdown will automatically link to documentation and articles wherever it's possible to do unambiguously. This includes: * Bare function calls, like `build_site()`. * Calls to `?`, like `?build_site` or `package?pkgdown`. * Calls to `help()`, like `help("pkgdown")`. * Calls to `vignette()`, like `vignette("pkgdown")`. ## Across packages Linking to documentation in another package is straightforward. Just adapt the call in the usual way: * `purrr::map()`, `MASS::addterm()`. * `?purrr::map`, `?MASS::addterm`. * `vignette("other-langs", package = "purrr")`, `vignette("longintro", package = "rpart")` * `{purrr}` If pkgdown can find a pkgdown site for the remote package, it will link to it; otherwise, it will link to for documentation and CRAN for vignettes. In order for a pkgdown site to be findable, it needs to be listed in two places: * In the `URL` field in the `DESCRIPTION`, as in [dplyr](https://github.com/tidyverse/dplyr/blob/85faf79c1fd74f4b4f95319e5be6a124a8075502/DESCRIPTION#L15): ``` URL: https://dplyr.tidyverse.org, https://github.com/tidyverse/dplyr ``` * In the `url` field in `_pkgdown.yml`, as in [dplyr](https://github.com/tidyverse/dplyr/blob/master/_pkgdown.yml#L1) ```yaml url: https://dplyr.tidyverse.org ``` When this field is defined, pkgdown generates a public facing [`pkgdown.yml` file](https://dplyr.tidyverse.org/pkgdown.yml) that provides metadata about the site: ```yaml pandoc: '2.2' pkgdown: 1.3.0 pkgdown_sha: ~ articles: compatibility: compatibility.html dplyr: dplyr.html dplyr_0.8.0: future/dplyr_0.8.0.html dplyr_0.8.0_new_hybrid: future/dplyr_0.8.0_new_hybrid.html programming: programming.html two-table: two-table.html window-functions: window-functions.html urls: reference: https://dplyr.tidyverse.org/reference article: https://dplyr.tidyverse.org/articles ``` Now, when you build a pkgdown site for a package that links to the dplyr documentation (e.g., `dplyr::mutate()`), pkgdown looks first in dplyr's `DESCRIPTION` to find its website, then it looks for `pkgdown.yml`, and uses the metadata to generate the correct links. To allow your package to be linked by other locally installed packages, even if your website is not reachable at build time, the following option needs to be set in `_pkgdown.yml`: ```yaml deploy: install_metadata: true ``` This allows locally installed packages to access package index metadata from the locally installed copy, which may be useful if your website require auth, or you build behind a firewall.