Nothing
#' Interpolate a formula
#'
#' Interpolation replaces sub-expressions of the form \code{uq(x)} with
#' the evaluated value of \code{x}, and inlines sub-expressions of
#' the form \code{uqs(x)}.
#'
#' @section Theory:
#' Formally, \code{f_interp} is a quasiquote function, \code{uq()} is the
#' unquote operator, and \code{uqs()} is the unquote splice operator.
#' These terms have a rich history in LISP, and live on in modern languages
#' like \href{Julia}{http://docs.julialang.org/en/release-0.1/manual/metaprogramming/}
#' and \href{Racket}{https://docs.racket-lang.org/reference/quasiquote.html}.
#'
#' @param f A one-sided formula.
#' @param x For \code{uq} and \code{uqf}, a formula. For \code{uqs}, a
#' a vector.
#' @param data When called from inside \code{f_eval}, this is used to pass on
#' the data so that nested formulas are evaluated in the correct environment.
#' @export
#' @aliases uq uqs
#' @examples
#' f_interp(x ~ 1 + uq(1 + 2 + 3) + 10)
#'
#' # Use uqs() if you want to add multiple arguments to a function
#' # It must evaluate to a list
#' args <- list(1:10, na.rm = TRUE)
#' f_interp(~ mean( uqs(args) ))
#'
#' # You can combine the two
#' var <- quote(xyz)
#' extra_args <- list(trim = 0.9)
#' f_interp(~ mean( uq(var) , uqs(extra_args) ))
#'
#' foo <- function(n) {
#' ~ 1 + uq(n)
#' }
#' f <- foo(10)
#' f
#' f_interp(f)
f_interp <- function(f, data = NULL) {
f_rhs(f) <- .Call(lazyeval_interp_, f_rhs(f), f_env(f), data)
f
}
#' @export
#' @rdname f_interp
uq <- function(x, data = NULL) {
if (is_formula(x)) {
if (is.null(data)) {
f_rhs(f_interp(x))
} else {
f_eval(x, data = data)
}
} else {
x
}
}
#' @export
#' @rdname f_interp
uqf <- function(x) {
if (!is_formula(x))
stop("`x` must be a formula", call. = FALSE)
x
}
#' @export
#' @rdname f_interp
uqs <- function(x) {
if (!is_vector(x)) {
stop("`x` must be a vector")
}
as.pairlist(x)
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.