Intended audience: end-users only
The default is to present progress via utils::txtProgressBar(),
which is available on all R installations.  It presents itself as an
ASCII-based horizontal progress bar in the R terminal. This is
rendered as:
We can tweak this "txtprogressbar" handler to use red hearts for the bar, e.g.
handlers(handler_txtprogressbar(char = cli::col_red(cli::symbol$heart)))
which results in:
Another example is:
handlers(handler_pbcol(
      adjust = 1.0,
    complete = function(s) cli::bg_red(cli::col_black(s)),
  incomplete = function(s) cli::bg_cyan(cli::col_black(s))
))
which results in:
To change the default, to, say, cli_progress_bar() by the cli
package, set:
handlers("cli")
This progress handler will present itself as:
To instead use progress_bar() by the progress package, set:
handlers("progress")
This progress handler will present itself as:
Progress updates do not have to be presented visually. They can equally well be communicated via audio. For example, using:
handlers("beepr")
will present itself as sounds played at the beginning, while progressing, and at the end (using different beepr sounds). There will be no output written to the terminal;
> y <- slow_sum(1:10)
> y
[1] 55
>
It is possible to have multiple progress handlers presenting progress updates at the same time. For example, to get both visual and auditory updates, use:
handlers("txtprogressbar", "beepr")
To silence all progress updates, use:
handlers("void")
Above we have seen examples where the handlers() takes one or more
strings as input, e.g. handlers(c("progress", "beepr")).  This is
short for a more flexible specification where we can pass a list of
handler functions, e.g.
handlers(list(
  handler_progress(),
  handler_beepr()
))
With this construct, we can make adjustments to the default behavior
of these progress handlers.  For example, we can configure the
format, width, and complete arguments of
progress::progress_bar$new(), and tell beepr to use a different
finish sound and generate sounds at most every two seconds by
setting:
handlers(list(
  handler_progress(
    format   = ":spin :current/:total (:message) [:bar] :percent in :elapsed ETA: :eta",
    width    = 60,
    complete = "+"
  ),
  handler_beepr(
    finish   = "wilhelm",
    interval = 2.0
  )
))
To set the default progress handler, or handlers, in all your R
sessions, call progressr::handlers(...) in your
~/.Rprofile startup file.  For example,
if (requireNamespace("progressr", quietly = TRUE)) {
  progressr::handlers(global = TRUE)
  if (requireNamespace("cli", quietly = TRUE)) {
    progressr::handlers("cli")
  }
}