tests/globalsOf,tweaks.R

source("incl/start.R")
library("globals")


message("*** tweakExpression() ...")

expr <- substitute({ a <<- 1; b <- 2; 3 ->> c }, env = list())
print(expr)
exprT <- tweakExpression(expr)
print(exprT)


b <- 2
exprs <- list(
  A = substitute({ a <- b; }, env = list()),
  B = substitute({ a <- b; b <- 1 }, env = list()),
  C = substitute({ a <- 1; a <- 2 }, env = list()),
  D = substitute({ a <<- 1; a <- 2 }, env = list()),
  E = substitute({ a <<- 1 }, env = list())
)

truth <- list(
  A = "b",
  B = "b",
  C = character(0L),
  D = character(0L),
  E = character(0L)
)


for (kk in seq_along(exprs)) {
  name <- names(exprs)[kk]
  expr <- exprs[[kk]]
  cat(sprintf("Expression #%d ('%s'):", kk, name))
  print(expr)
  globals <- globalsOf(expr, tweak = tweakExpression, recursive = TRUE)
  globals <- cleanup(globals)
  str(globals)
  stopifnot(identical(names(globals), truth[[name]]))
}

message("*** tweakExpression() ... DONE")

source("incl/end.R")

Try the future package in your browser

Any scripts or data that you put into this service are public.

future documentation built on Sept. 11, 2024, 7:35 p.m.