mirror of
https://github.com/rstudio/shiny.git
synced 2026-02-01 18:24:54 -05:00
73 lines
2.0 KiB
R
73 lines
2.0 KiB
R
\name{exprToFunction}
|
|
\alias{exprToFunction}
|
|
\title{Convert an expression or quoted expression to a function}
|
|
\usage{
|
|
exprToFunction(expr, env = parent.frame(2),
|
|
quoted = FALSE, caller_offset = 1)
|
|
}
|
|
\arguments{
|
|
\item{expr}{A quoted or unquoted expression, or a
|
|
function.}
|
|
|
|
\item{env}{The desired environment for the function.
|
|
Defaults to the calling environment two steps back.}
|
|
|
|
\item{quoted}{Is the expression quoted?}
|
|
|
|
\item{caller_offset}{The offset in the callstack of the function to be
|
|
considered the caller. Defaults to the direct 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.
|
|
}
|
|
\note{
|
|
exprToFunction does not set debug hooks in the function it creates, so it is
|
|
not possible to set breakpoints in the original expressions and hit them during
|
|
Shiny application runtime. Use \code{\link{installExprFunction}} instead if you
|
|
need debug support.
|
|
}
|
|
\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")
|
|
|
|
\dontrun{
|
|
# 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())
|
|
# "text, text, text"
|
|
}
|
|
|