futureverse / progressr

三 R package: An Inclusive, Unifying API for Progress Updates
https://progressr.futureverse.org
281 stars 12 forks source link

Suggestion: include a function decorator that works with progressr #122

Open tanho63 opened 3 years ago

tanho63 commented 3 years ago

I was wondering if it would make sense to have a function decorator explicitly for (simple) progress updates, so that I can extend the behaviour of pre-existing functions - something like:

progressively <- function(f, p = NULL){
  if(is.null(p)) p <- function(...) NULL
  force(f)

  function(...){
    on.exit(p("loading..."))
    f(...)
  }

}

which then could be called like:

read_rosters <- function(){
  urls <- c("https://github.com/nflverse/nflfastR-roster/raw/master/data/seasons/roster_2020.csv", "https://github.com/nflverse/nflfastR-roster/raw/master/data/seasons/roster_2021.csv")
  p <- progressor(along = urls)
  purrr::map_dfr(urls, progressively(read.csv, p))
}

x <- with_progress(read_rosters())

This is inspired by Hadley's notes on function operators in Advanced R, and purrr's quietly/safely set of decorators