exprToFunction
exprToFunction(expr, env = parent.frame(2), quoted = FALSE,
caller_offset = 1)
Arguments
expr | A quoted or unquoted expression, or a function. |
---|---|
env | The desired environment for the function. Defaults to the calling environment two steps back. |
quoted | Is the expression quoted? |
caller_offset | If specified, the offset in the callstack of the functiont to be treated as the caller. |
Description
This is to be called from another function, because it will attempt to get an unquoted expression from two calls back.
Details
If expr is a quoted expression, then this just converts it to a function. If expr is a function, then this simply returns expr (and prints a deprecation message). If expr was a non-quoted expression from two calls back, then this will quote the original expression and convert it to a function.
Examples
# Example of a new renderer, similar to renderText
# This is something that toolkit authors will do
renderTriple <- function(expr, env=parent.frame(), quoted=FALSE) {
# Convert expr to a function
func <- shiny::exprToFunction(expr, env, quoted)
function() {
value <- func()
paste(rep(value, 3), collapse=", ")
}
}
# Example of using the renderer.
# This is something that app authors will do.
values <- reactiveValues(A="text")
## Not run: ------------------------------------
# # Create an output object
# output$tripleA <- renderTriple({
# values$A
# })
## ---------------------------------------------
# At the R console, you can experiment with the renderer using isolate()
tripleA <- renderTriple({
values$A
})
isolate(tripleA())
[1] "text, text, text"
# "text, text, text"