-
Notifications
You must be signed in to change notification settings - Fork 275
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Guidelines/best practices on exporting adverb-wrapped functions from packages #668
Comments
The main thing is to avoid assigning the functions in your namespace at build time. If you assign at build time, this might cause issues when purrr is updated and your package isn't. The functions you have created in the package will contain the old source code, and might even refer to functions that no longer exist in the purrr namespace. To assign the functions when the package is loaded in memory, do it from the #' My function
#' @export
insist_my_function <- function(...) "dummy"
my_function <- function(...) {
# Implementation
}
.onLoad <- function(lib, pkg) {
insist_my_function <<- purrr::insistently(my_function)
} |
Thank you, this is very clear! Using .onLoad for patterns like this is a useful concept in general. |
@lionel- In your snippet above, why do you define Also, if I wanted to add additional functionality to the insistently version of a function, e.g. a tryCatch that logs an error, is it still recommended to define this function in the .onLoad <- function(lib, pkg) {
# define insistent version of a function
insist_s3write_using_func <-purrr::insistently(f = aws.s3::s3write_using)
# wrap function in a trycatch and make it global
insist_s3write_using <<- function(x, FUN, bucket, object) {
file <- tryCatch({
insist_s3write_using_func(x = x,
FUN = FUN,
bucket = bucket,
object = object
)
}, error = function(e) {
print(paste("Unable to write file ", e))
})
return(file)
}
} |
The dummy definition is a place for the roxygen2 documentation. It also allows some rudimentary static analysis, if only by the readers of the code.
You can put your wrapper outside of |
Thanks @lionel-, that's very helpful. |
insistently()
andsafely()
have been lifesavers for my team, particularly in solving problems where low failure rates over large-scale API call queues and read/write operations would break long-running processes. Interacting with AWS S3 from R is much easier now.Are there any recommendations/best practices for including adverb-wrapped functions in packages? Since the release of
insistently()
I’ve never called (eg) theaws.s3::put_object()
function directly. Every script starts with creating wrappers forinsist_*
. I’d like to move the wrapped functions to an internal package, and maybe propose to include an insistent option in the main package. However, I haven’t seen any packages that export safe_* or insistent_* function variants to date, and that’s a good sign I'm planning to do something without full understanding of the side effects.(First time filing an issue here -- thank you!
purrr
is the single largest productivity boost I've had in >10 years of writing R code...)The text was updated successfully, but these errors were encountered: