stacktrace
captureStackTraces(expr)
withLogErrors(expr, full = getOption("shiny.fullstacktrace", FALSE),
  offset = getOption("shiny.stacktraceoffset", TRUE))
printError(cond, full = getOption("shiny.fullstacktrace", FALSE),
  offset = getOption("shiny.stacktraceoffset", TRUE))
printStackTrace(cond, full = getOption("shiny.fullstacktrace", FALSE),
  offset = getOption("shiny.stacktraceoffset", TRUE))
extractStackTrace(calls, full = getOption("shiny.fullstacktrace", FALSE),
  offset = getOption("shiny.stacktraceoffset", TRUE))
formatStackTrace(calls, indent = "    ",
  full = getOption("shiny.fullstacktrace", FALSE),
  offset = getOption("shiny.stacktraceoffset", TRUE))
conditionStackTrace(cond)
conditionStackTrace(cond) <- value
..stacktraceon..(expr)
..stacktraceoff..(expr)Arguments
| expr | The expression to wrap. | 
|---|---|
| full | If TRUE, then every element ofsys.calls()will be
included in the stack trace. By default (FALSE), calls that Shiny
deems uninteresting will be hidden. | 
| offset | If TRUE(the default), srcrefs will be reassigned from
the calls they originated from, to the destinations of those calls. If
you're used to stack traces from other languages, this feels more
intuitive, as the definition of the function indicated in the call and the
location specified by the srcref match up. IfFALSE, srcrefs will be
left alone (traditional R treatment where the srcref is of the callsite). | 
| cond | An condition object (generally, an error). | 
| indent | A string to prefix every line of the stack trace. | 
| value | The stack trace value to assign to the condition. | 
| cond | A condition that may have previously been annotated by captureStackTraces(orwithLogErrors). | 
Value
printError and printStackTrace return
  invisible(). The other functions pass through the results of
  expr.
Description
Advanced (borderline internal) functions for capturing, printing, and manipulating stack traces.
Details
captureStackTraces runs the given expr and if any
  uncaught errors occur, annotates them with stack trace info for use
  by printError and printStackTrace. It is not necessary to use
  captureStackTraces around the same expression as
  withLogErrors, as the latter includes a call to the former. Note
  that if expr contains calls (either directly or indirectly) to
  try, or tryCatch with an error handler, stack traces therein
  cannot be captured unless another captureStackTraces call is
  inserted in the interior of the try or tryCatch. This is
  because these calls catch the error and prevent it from traveling up to the
  condition handler installed by captureStackTraces.
withLogErrors captures stack traces and logs errors that
  occur in expr, but does allow errors to propagate beyond this point
  (i.e. it doesn't catch the error). The same caveats that apply to
  captureStackTraces with regard to try/tryCatch apply
  to withLogErrors.
printError prints the error and stack trace (if any) using
  warning(immediate.=TRUE). printStackTrace prints the stack
  trace only.
extractStackTrace takes a list of calls (e.g. as returned
  from conditionStackTrace(cond)) and returns a data frame with one
  row for each stack frame and the columns num (stack frame number),
  call (a function name or similar), and loc (source file path
  and line number, if available).
formatStackTrace is similar to extractStackTrace, but
  it returns a preformatted character vector instead of a data frame.
conditionStackTrace and conditionStackTrace<- are
  accessor functions for getting/setting stack traces on conditions.
The two functions ..stacktraceon.. and
  ..stacktraceoff.. have no runtime behavior during normal execution;
  they exist only to create artifacts on the stack trace (sys.call()) that
  instruct the stack trace pretty printer what parts of the stack trace are
  interesting or not. The initial state is 1 and we walk from the outermost
  call inwards. Each ..stacktraceoff.. decrements the state by one, and each
  ..stacktraceon.. increments the state by one. Any stack trace frame whose
  value is less than 1 is hidden, and finally, the ..stacktraceon.. and
  ..stacktraceoff.. calls themselves are hidden too.
Examples
# Keeps tryCatch and withVisible related calls off the
# pretty-printed stack trace
visibleFunction1 <- function() {
  stop("Kaboom!")
}
visibleFunction2 <- function() {
  visibleFunction1()
}
hiddenFunction <- function(expr) {
  expr
}
# An example without ..stacktraceon/off.. manipulation.
# The outer "try" is just to prevent example() from stopping.
try({
  # The withLogErrors call ensures that stack traces are captured
  # and that errors that bubble up are logged using warning().
  withLogErrors({
    # tryCatch and withVisible are just here to add some noise to
    # the stack trace.
    tryCatch(
      withVisible({
        hiddenFunction(visibleFunction2())
      })
    )
  })
})
Warning message:
Error in visibleFunction1: Kaboom!
Stack trace (innermost first):
    33: visibleFunction1 [<text>#5]
    32: visibleFunction2 [<text>#9]
    31: hiddenFunction [<text>#13]
    30: withVisible [<text>#26]
    29: tryCatchList
    28: tryCatch
    27: withCallingHandlers [<text>#24]
    26: captureStackTraces [/Users/winston/Dropbox/Projects/shiny/R/conditions.R#108]
    25: withCallingHandlers
    24: withLogErrors [/Users/winston/Dropbox/Projects/shiny/R/conditions.R#130]
    23: doTryCatch [<text>#21]
    22: tryCatchOne
    21: tryCatchList
    20: tryCatch
    19: try
    18: eval
    17: eval
    16: withVisible [/private/var/folders/vd/0_g4hj6d7kq_fw5gd_r0ml5w0000gn/T/Rtmpj3EF7l/devtools4458685dc6cb/hadley-evaluate-5caf634/R/eval.r#186]
    15: withCallingHandlers [/private/var/folders/vd/0_g4hj6d7kq_fw5gd_r0ml5w0000gn/T/Rtmpj3EF7l/devtools4458685dc6cb/hadley-evaluate-5caf634/R/eval.r#186]
    14: doTryCatch [/private/var/folders/vd/0_g4hj6d7kq_fw5gd_r0ml5w0000gn/T/Rtmpj3EF7l/devtools4458685dc6cb/hadley-evaluate-5caf634/R/eval.r#186]
    13: tryCatchOne
    12: tryCatchList
    11: tryCatch
    10: try
     9: handle [/private/var/folders/vd/0_g4hj6d7kq_fw5gd_r0ml5w0000gn/T/Rtmpj3EF7l/devtools4458685dc6cb/hadley-evaluate-5caf634/R/eval.r#163]
     8: timing_fn [/private/var/folders/vd/0_g4hj6d7kq_fw5gd_r0ml5w0000gn/T/Rtmpj3EF7l/devtools4458685dc6cb/hadley-evaluate-5caf634/R/eval.r#186]
     7: evaluate_call [/private/var/folders/vd/0_g4hj6d7kq_fw5gd_r0ml5w0000gn/T/Rtmpj3EF7l/devtools4458685dc6cb/hadley-evaluate-5caf634/R/eval.r#186]
     6: evaluate [/private/var/folders/vd/0_g4hj6d7kq_fw5gd_r0ml5w0000gn/T/Rtmpj3EF7l/devtools4458685dc6cb/hadley-evaluate-5caf634/R/eval.r#73]
     5: to_html.examples
     4: to_html
     3: to_html.Rd_doc
     2: build_topics
     1: build_site
# Now the same example, but with ..stacktraceon/off.. to hide some
# of the less-interesting bits (tryCatch and withVisible).
..stacktraceoff..({
  try({
    withLogErrors({
      tryCatch(
        withVisible(
          hiddenFunction(
            ..stacktraceon..(visibleFunction2())
          )
        )
      )
    })
  })
})
Warning message:
Error in visibleFunction1: Kaboom!
Stack trace (innermost first):
    35: visibleFunction1 [<text>#5]
    34: visibleFunction2 [<text>#9]
    18: eval
    17: eval
    16: withVisible [/private/var/folders/vd/0_g4hj6d7kq_fw5gd_r0ml5w0000gn/T/Rtmpj3EF7l/devtools4458685dc6cb/hadley-evaluate-5caf634/R/eval.r#186]
    15: withCallingHandlers [/private/var/folders/vd/0_g4hj6d7kq_fw5gd_r0ml5w0000gn/T/Rtmpj3EF7l/devtools4458685dc6cb/hadley-evaluate-5caf634/R/eval.r#186]
    14: doTryCatch [/private/var/folders/vd/0_g4hj6d7kq_fw5gd_r0ml5w0000gn/T/Rtmpj3EF7l/devtools4458685dc6cb/hadley-evaluate-5caf634/R/eval.r#186]
    13: tryCatchOne
    12: tryCatchList
    11: tryCatch
    10: try
     9: handle [/private/var/folders/vd/0_g4hj6d7kq_fw5gd_r0ml5w0000gn/T/Rtmpj3EF7l/devtools4458685dc6cb/hadley-evaluate-5caf634/R/eval.r#163]
     8: timing_fn [/private/var/folders/vd/0_g4hj6d7kq_fw5gd_r0ml5w0000gn/T/Rtmpj3EF7l/devtools4458685dc6cb/hadley-evaluate-5caf634/R/eval.r#186]
     7: evaluate_call [/private/var/folders/vd/0_g4hj6d7kq_fw5gd_r0ml5w0000gn/T/Rtmpj3EF7l/devtools4458685dc6cb/hadley-evaluate-5caf634/R/eval.r#186]
     6: evaluate [/private/var/folders/vd/0_g4hj6d7kq_fw5gd_r0ml5w0000gn/T/Rtmpj3EF7l/devtools4458685dc6cb/hadley-evaluate-5caf634/R/eval.r#73]
     5: to_html.examples
     4: to_html
     3: to_html.Rd_doc
     2: build_topics
     1: build_site