From 7dea85ad096c4c492d7f7ee109aed064c87fc3a8 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Catalina=20Ca=C3=B1izares?=
<88352293+ccani007@users.noreply.github.com>
Date: Tue, 20 Aug 2024 13:32:55 -0700
Subject: [PATCH] Updated reduce documentation (#1146)
Fixes #1103.
---
R/reduce.R | 17 ++++++++++++++++-
man/reduce.Rd | 8 ++++----
man/reduce_right.Rd | 8 ++++----
3 files changed, 24 insertions(+), 9 deletions(-)
diff --git a/R/reduce.R b/R/reduce.R
index d491ae1c..89c8996b 100644
--- a/R/reduce.R
+++ b/R/reduce.R
@@ -8,7 +8,22 @@
#' `f` over `1:3` computes the value `f(f(1, 2), 3)`.
#'
#' @inheritParams map
-#' @param .y For `reduce2()` and `accumulate2()`, an additional
+#' @param ... Additional arguments passed on to the reduce function.
+#'
+#' We now generally recommend against using `...` to pass additional
+#' (constant) arguments to `.f`. Instead use a shorthand anonymous function:
+#'
+#' ```R
+#' # Instead of
+#' x |> reduce(f, 1, 2, collapse = ",")
+#' # do:
+#' x |> reduce(\(x, y) f(x, y, 1, 2, collapse = ","))
+#' ```
+#'
+#' This makes it easier to understand which arguments belong to which
+#' function and will tend to yield better error messages.
+#'
+#' @param .y For `reduce2()` an additional
#' argument that is passed to `.f`. If `init` is not set, `.y`
#' should be 1 element shorter than `.x`.
#' @param .f For `reduce()`, a 2-argument function. The function will be passed
diff --git a/man/reduce.Rd b/man/reduce.Rd
index 69ea6388..470f5f73 100644
--- a/man/reduce.Rd
+++ b/man/reduce.Rd
@@ -23,15 +23,15 @@ second argument, and the next value of \code{.y} as the third argument.
The reduction terminates early if \code{.f} returns a value wrapped in
a \code{\link[=done]{done()}}.}
-\item{...}{Additional arguments passed on to the mapped function.
+\item{...}{Additional arguments passed on to the reduce function.
We now generally recommend against using \code{...} to pass additional
(constant) arguments to \code{.f}. Instead use a shorthand anonymous function:
\if{html}{\out{
}}\preformatted{# Instead of
-x |> map(f, 1, 2, collapse = ",")
+x |> reduce(f, 1, 2, collapse = ",")
# do:
-x |> map(\\(x) f(x, 1, 2, collapse = ","))
+x |> reduce(\\(x, y) f(x, y, 1, 2, collapse = ","))
}\if{html}{\out{
}}
This makes it easier to understand which arguments belong to which
@@ -46,7 +46,7 @@ is empty. If missing, and \code{.x} is empty, will throw an error.}
\code{"forward"} (the default) or \code{"backward"}. See the section about
direction below.}
-\item{.y}{For \code{reduce2()} and \code{accumulate2()}, an additional
+\item{.y}{For \code{reduce2()} an additional
argument that is passed to \code{.f}. If \code{init} is not set, \code{.y}
should be 1 element shorter than \code{.x}.}
}
diff --git a/man/reduce_right.Rd b/man/reduce_right.Rd
index f3478e4f..8d80bcd8 100644
--- a/man/reduce_right.Rd
+++ b/man/reduce_right.Rd
@@ -26,15 +26,15 @@ second argument, and the next value of \code{.y} as the third argument.
The reduction terminates early if \code{.f} returns a value wrapped in
a \code{\link[=done]{done()}}.}
-\item{...}{Additional arguments passed on to the mapped function.
+\item{...}{Additional arguments passed on to the reduce function.
We now generally recommend against using \code{...} to pass additional
(constant) arguments to \code{.f}. Instead use a shorthand anonymous function:
\if{html}{\out{}}\preformatted{# Instead of
-x |> map(f, 1, 2, collapse = ",")
+x |> reduce(f, 1, 2, collapse = ",")
# do:
-x |> map(\\(x) f(x, 1, 2, collapse = ","))
+x |> reduce(\\(x, y) f(x, y, 1, 2, collapse = ","))
}\if{html}{\out{
}}
This makes it easier to understand which arguments belong to which
@@ -45,7 +45,7 @@ the accumulation, rather than using \code{.x[[1]]}. This is useful if
you want to ensure that \code{reduce} returns a correct value when \code{.x}
is empty. If missing, and \code{.x} is empty, will throw an error.}
-\item{.y}{For \code{reduce2()} and \code{accumulate2()}, an additional
+\item{.y}{For \code{reduce2()} an additional
argument that is passed to \code{.f}. If \code{init} is not set, \code{.y}
should be 1 element shorter than \code{.x}.}
}