From d6e536eefc43b1a25db1451b5b3ab6d8f7f62e4c Mon Sep 17 00:00:00 2001 From: Carl Suster Date: Mon, 16 Dec 2024 12:15:18 +1100 Subject: [PATCH] Fix default follow.scale inconsistency --- R/stat-bin.R | 24 +++++++++--------------- man/geom_histogram.Rd | 8 ++++++-- 2 files changed, 15 insertions(+), 17 deletions(-) diff --git a/R/stat-bin.R b/R/stat-bin.R index e1aa9bf2a6..bb3970f27e 100644 --- a/R/stat-bin.R +++ b/R/stat-bin.R @@ -24,10 +24,10 @@ #' and `boundary`. Can also be a function that takes group-wise values as input and returns bin boundaries. #' @param follow.scale Alternatively, the bin edges can be copied from the scale #' breaks, either `"major"` or `"minor"`. Ignored when `"off"`. Note that if -#. the scale's limits are updated by other layers or expansions then its -#. breaks are recomputed and might end up different to the value copied for -#. the bin edges. This is not an issue when the scale uses a fixed breaks -#. vector. +#' the scale's limits are updated by other layers or expansions then its +#' breaks are recomputed and might end up different to the value copied for +#' the bin edges. This is not an issue when the scale uses a fixed breaks +#' vector. #' @param closed One of `"right"` or `"left"` indicating whether right #' or left edges of bins are included in the bin. #' @param pad If `TRUE`, adds empty bins at either end of x. This ensures @@ -64,7 +64,7 @@ stat_bin <- function(mapping = NULL, data = NULL, breaks = NULL, closed = c("right", "left"), pad = FALSE, - follow.scale = c("off", "minor", "major"), + follow.scale = "off", na.rm = FALSE, keep.zeroes = "all", orientation = NA, @@ -144,15 +144,9 @@ StatBin <- ggproto("StatBin", Stat, cli::cli_abort("Only one of {.arg boundary} and {.arg center} may be specified in {.fn {snake_class(self)}}.") } - if (!is.null(params$follow.scale)) { - params$follow.scale <- match.arg(params$follow.scale, c("off", "minor", "major")) - if (params$follow.scale == "off") params$follow.scale <- NULL - } - if (!is.null(params$follow.scale) && !is.null(params$breaks)) { - cli::cli_abort("Only one of {.arg follow.scale} and {.arg breaks} may be specified in {.fn {snake_class(self)}}.") - } + params$follow.scale <- match.arg(params$follow.scale, c("off", "minor", "major")) - if (is.null(params$breaks) && is.null(params$binwidth) && is.null(params$bins) && is.null(params$follow.scale)) { + if (is.null(params$breaks) && is.null(params$binwidth) && is.null(params$bins) && (params$follow.scale == "off")) { cli::cli_inform("{.fn {snake_class(self)}} using {.code bins = 30}. Pick better value with {.arg binwidth}.") params$bins <- 30 } @@ -166,12 +160,12 @@ StatBin <- ggproto("StatBin", Stat, center = NULL, boundary = NULL, closed = c("right", "left"), pad = FALSE, breaks = NULL, flipped_aes = FALSE, keep.zeroes = "all", - follow.scale = NULL, + follow.scale = "off", # The following arguments are not used, but must # be listed so parameters are computed correctly origin = NULL, right = NULL, drop = NULL) { x <- flipped_names(flipped_aes)$x - if (!is.null(follow.scale)) { + if (follow.scale != "off") { breaks <- switch(follow.scale, minor = scales[[x]]$get_breaks_minor(), major = scales[[x]]$get_breaks()) diff --git a/man/geom_histogram.Rd b/man/geom_histogram.Rd index eeed9fa4f8..94ea8be60b 100644 --- a/man/geom_histogram.Rd +++ b/man/geom_histogram.Rd @@ -45,7 +45,7 @@ stat_bin( breaks = NULL, closed = c("right", "left"), pad = FALSE, - follow.scale = c("off", "minor", "major"), + follow.scale = "off", na.rm = FALSE, keep.zeroes = "all", orientation = NA, @@ -176,7 +176,11 @@ or left edges of bins are included in the bin.} frequency polygons touch 0. Defaults to \code{FALSE}.} \item{follow.scale}{Alternatively, the bin edges can be copied from the scale -breaks, either \code{"major"} or \code{"minor"}. Ignored when \code{"off"}. Note that if} +breaks, either \code{"major"} or \code{"minor"}. Ignored when \code{"off"}. Note that if +the scale's limits are updated by other layers or expansions then its +breaks are recomputed and might end up different to the value copied for +the bin edges. This is not an issue when the scale uses a fixed breaks +vector.} \item{keep.zeroes}{Treatment of zero count bins. If \code{"all"} (default), such bins are kept as-is. If \code{"none"}, all zero count bins are filtered out.