traceback {base} | R Documentation |
By default, traceback()
prints the call stack of the last
uncaught error, i.e., the sequence of calls that lead to the error.
This is useful when an error occurs with an unidentifiable error
message. It can also be used to print arbitrary lists of deparsed
calls.
traceback(x = NULL)
x |
NULL (default), or a list or pairlist of deparsed
calls. |
The stack of the last uncaught error is stored as a list of deparsed
calls in .Traceback
, which traceback
prints in a
user-friendly format. The stack of deparsed calls always contains all
function calls and (as from R 2.3.0) all foreign function calls (such
as .Call
): if profiling is in progress it will include
all other calls to primitive functions.
Errors which are caught via try
or
tryCatch
do not generate a traceback, so what is printed
is the call sequence for the last uncaught error, and not necessarily
the last error.
traceback()
returns nothing, but prints the deparsed call stack
deepest call first. The calls may print on more than one line, and
the first line for each call is labelled by the frame number. The
number of lines printed per call can be limited by setting
options(deparse.max.lines)
.
Becker, R. A., Chambers, J. M. and Wilks, A. R. (1988) The New S Language. Wadsworth & Brooks/Cole.
foo <- function(x) { print(1); bar(2) } bar <- function(x) { x + a.variable.which.does.not.exist } ## Not run: foo(2) # gives a strange error traceback() ## End(Not run) ## 2: bar(2) ## 1: foo(2) bar ## Ah, this is the culprit ...