text
and condition
arguments are the same as those
that can be supplied via a call to browser
. They can be retrieved
by the user once the browser has been entered, and provide a mechanism to
allow users to identify which breakpoint has been activated.debug(fun, text = "", condition = NULL, signature = NULL)
debugonce(fun, text = "", condition = NULL, signature = NULL)
undebug(fun, signature = NULL)
isdebugged(fun, signature = NULL)
debuggingState(on = NULL)
debuggingState
returns TRUE
if debugging is globally
turned on, FALSE
otherwise. An argument of one or the other
of those values sets the state. If the debugging state is
FALSE
, none of the debugging actions will occur (but explicit
browser
calls in functions will continue to work).debug
and undebug
invisibly return NULL
. isdebugged
returns TRUE
if the function or method is
marked for debugging, and FALSE
otherwise.browser
help topic. To debug a function which is defined inside another function,
single-step though to the end of its definition, and then call
debug
on its name. If you want to debug a function not starting at the very beginning,
use trace(..., at = *)
or setBreakpoint
. Using debug
is persistent, and unless debugging is turned off
the debugger will be entered on every invocation (note that if the
function is removed and replaced the debug state is not preserved).
Use debugonce
to enter the debugger only the next time the
function is invoked. To debug an S4 method by explicit signature, use
signature
. When specified, signature indicates the method of
fun
to be debugged. Note that debugging is implemented slightly
differently for this case, as it uses the trace machinery, rather than
the debugging bit. As such, text
and condition
cannot be
specified in combination with a non-null signature
. For methods
which implement the .local
rematching mechanism, the
.local
closure itself is the one that will be ultimately
debugged (see isRematched
). isdebugged
returns TRUE
if a) signature
is NULL
and the closure fun
has been debugged, or b) signature
is not
NULL
, fun
is an S4 generic, and the method of fun
for that signature has been debugged. In all other cases, it returns
FALSE
. The number of lines printed for the deparsed call when a function is
entered for debugging can be limited by setting
options(deparse.max.lines)
. When debugging is enabled on a byte compiled function then the
interpreted version of the function will be used until debugging is
disabled.debugcall
for conveniently debugging methods,
browser
, trace
;
traceback
to see the stack after an Error: …
message; recover
for another debugging approach.## Not run: ------------------------------------
# debug(library)
# library(methods)
## ---------------------------------------------
## Not run: ------------------------------------
# debugonce(sample)
# ## only the first call will be debugged
# sampe(10, 1)
# sample(10, 1)
## ---------------------------------------------
Run the code above in your browser using DataLab