R/traceback.R

Defines functions unitizer_traceback

# Copyright (C) Brodie Gaslam
#
# This file is part of "unitizer - Interactive R Unit Tests"
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# Go to <https://www.r-project.org/Licenses/GPL-2> for a copy of the license.

# Code in this file is adapted from the R functions `traceback` and
# `.traceback` in the base R package.  Original copyright notice:
#
#  File src/library/base/R/traceback.R
#  Part of the R package, https://www.R-project.org
#
#  Copyright (C) 1995-2019 The R Core Team
#
#  This program is free software; you can redistribute it and/or modify
#  it under the terms of the GNU General Public License as published by
#  the Free Software Foundation; either version 2 of the License, or
#  (at your option) any later version.
#
#  This program is distributed in the hope that it will be useful,
#  but WITHOUT ANY WARRANTY; without even the implied warranty of
#  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
#  GNU General Public License for more details.
#
#  A copy of the GNU General Public License is available at
#  https://www.R-project.org/Licenses/

unitizer_traceback <-  function(
  x = NULL, max.lines = getOption("traceback.max.lines", 
  getOption("deparse.max.lines", -1L))
) {
  n <- length(x <- unitizer_dottraceback(x, max.lines = max.lines))
  if (n == 0L) 
      cat(gettext("No traceback available"), "\n")
  else {
    for (i in 1L:n) {
      xi <- x[[i]]
      label <- paste0(n - i + 1L, ": ")
      m <- length(xi)
      srcloc <- if (!is.null(srcref <- attr(xi, "srcref"))) {
        srcfile <- attr(srcref, "srcfile")
        paste0(" at ", basename(srcfile$filename), "#", srcref[1L])
      }
      if (isTRUE(attr(xi, "truncated"))) {
        xi <- c(xi, " ...")
        m <- length(xi)
      }
      if (!is.null(srcloc)) {
        xi[m] <- paste0(xi[m], srcloc)
      }
      if (m > 1) 
        label <- c(
          label, 
          rep(substr("          ", 1L, nchar(label, type = "w")), m - 1L)
        )
      cat(paste0(label, xi), sep = "\n")
    }
  }
  invisible(x)
}
unitizer_dottraceback <- function (
  x = NULL, max.lines = getOption("traceback.max.lines", 
  getOption("deparse.max.lines", -1L))
) {
    if(!is.null(x))
      stop(
        "You are using an overloaded `.traceback` that requires `x` to be ",
        "NULL; you can use standard `traceback` with `base::traceback`."
      )
    stopifnot(length(max.lines) <= 1)
    .is.positive.intlike <- function(x) 
      is.numeric(x) && length(x) == 1L && !is.na(x) && as.integer(x) >= 0L

    if (is.null(x) && !is.null(x <- .global$traceback)) {
      valid.max.lines <- .is.positive.intlike(max.lines)
      nlines <- if (valid.max.lines) max.lines + 1L
      else max.lines
      for (i in seq_along(x)) {
        srcref <- attr(x[[i]], "srcref")
        # unitizer's own traceback used the "keepInteger" control prior to
        # change in 1.4.13.
        if (typeof(x[[i]]) == "language") 
            x[[i]] <- deparse(x[[i]], nlines = nlines, control="keepInteger")
        if (valid.max.lines && length(x[[i]]) > max.lines) {
            x[[i]] <- x[[i]][seq_len(max.lines)]
            attr(x[[i]], "truncated") <- TRUE
        }
        attr(x[[i]], "srcref") <- srcref
      }
    }
    x
}

Try the unitizer package in your browser

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

unitizer documentation built on Oct. 8, 2023, 5:06 p.m.