R/utils.R

Defines functions list_col_names_and_types invert pacta_loanbook_packages inform_startup

Documented in pacta_loanbook_packages

inform_startup <- function(msg, ...) {
  if (is.null(msg)) {
    return()
  }
  if (isTRUE(getOption("pacta_loanbook.quiet"))) {
    return()
  }

  rlang::inform(msg, ..., class = "packageStartupMessage")
}

#' List all packages in `{pacta.loanbook}`
#'
#' @param include_self Include `{pacta.loanbook}` in the list?
#'
#' @family utility functions
#'
#' @export
#'
#' @return a character vector containing the names of packages imported by
#'   `{pacta.loanbook}`.
#'
#' @examples
#' pacta_loanbook_packages()

pacta_loanbook_packages <- function(include_self = TRUE) {
  raw <- utils::packageDescription("pacta.loanbook")$Imports
  imports <- strsplit(raw, ",")[[1]]
  parsed <- gsub("^\\s+|\\s+$", "", imports)
  names <- vapply(strsplit(parsed, "\\s+"), "[[", 1, FUN.VALUE = character(1))

  if (include_self) {
    names <- c(names, "pacta.loanbook")
  }

  names
}

invert <- function(x) {
  if (length(x) == 0) return()
  stacked <- utils::stack(x)
  tapply(as.character(stacked$ind), stacked$values, list)
}

list_col_names_and_types <- function(dataset) {
  cat(
    cli::ansi_html(
      paste0(
        "- ",
        lapply(names(dataset), function(x) cli::format_inline("{.var {x}}")),
        ": ",
        lapply(dataset, function(x) cli::format_inline("{.cls {class(x)}}")),
        collapse = "\n"
      )
    )
  )
}

Try the pacta.loanbook package in your browser

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

pacta.loanbook documentation built on April 3, 2025, 10:37 p.m.