R/development.R

Defines functions version_tooltip check_mode dev_mode_auto dev_mode meta_development

meta_development <- function(meta, version, bs_version = 3) {
  development <- purrr::pluck(meta, "development", .default = list())

  destination <- purrr::pluck(development, "destination", .default = "dev")

  mode <- dev_mode(version, development)

  version_label <- purrr::pluck(development, "version_label")
  if (is.null(version_label)) {
    if (mode %in% c("release", "default")) {
      version_label <- if (bs_version == 3) "default" else "muted"
    } else {
      version_label <- "danger"
    }
  }
  in_dev <- mode == "devel"

  list(
    destination = destination,
    mode = mode,
    version_label = version_label,
    in_dev = in_dev
  )
}

dev_mode <- function(version, development) {
  mode <- Sys.getenv("PKGDOWN_DEV_MODE")
  if (identical(mode, "")) {
    mode <- purrr::pluck(development, "mode", .default = "default")
  }

  if (mode == "auto") {
    mode <- dev_mode_auto(version)
  }
  check_mode(mode)

  mode
}

dev_mode_auto <- function(version) {
  version <- unclass(package_version(version))[[1]]

  if (length(version) < 3) {
    "release"
  } else if (length(version) == 3) {
    if (version[3] >= 9000) {
      "devel"
    } else {
      "release"
    }
  } else if (identical(version[1:3], c(0L, 0L, 0L))) {
    "unreleased"
  } else {
    "devel"
  }
}

check_mode <- function(mode) {
  valid_mode <- c("auto", "default", "release", "devel", "unreleased")
  if (!mode %in% valid_mode) {
    abort(paste0(
      "`development.mode` in `_pkgdown.yml` must be one of ",
      paste(valid_mode, collapse = ", ")
    ))
  }
}

# Called in render_page() so that LANG env var set up
version_tooltip <- function(mode) {
  switch(mode,
    default = "",
    release = tr_("Released version"),
    devel = tr_("In-development version"),
    unreleased = tr_("Unreleased version")
  )
}

Try the pkgdown package in your browser

Any scripts or data that you put into this service are public.

pkgdown documentation built on Dec. 28, 2022, 1:37 a.m.