R/assertions.R

Defines functions is_renderer is_function is_logger is_error_handler is_handler has_file not_missing valid_path

valid_path <- function(x) {
  if(missing(x)) 
    return(FALSE)

  if(!inherits(x, "character")) 
    return(FALSE)

  return(TRUE)
}

assertthat::on_failure(valid_path) <- function(call, env) {
  paste0(deparse(call$x), " is not valid")
}

not_missing <- function(x){
  !missing(x)
}

assertthat::on_failure(not_missing) <- function(call, env){
  paste("Missing", deparse(call$x))
}

has_file <- function(x){
  fs::file_exists(x)
}

assertthat::on_failure(has_file) <- function(call, env){
  paste("Cannot find", deparse(call$x))
}

is_handler <- function(x){
  is_fun <- is.function(x)
  has_args <- length(formalArgs(x)) == 2

  all(is_fun, has_args)
}

assertthat::on_failure(is_handler) <- function(call, env){
  paste("`handler` must be a function that accepts: `req`, and `res`")
}

is_error_handler <- function(x) {
  is_fun <- is.function(x)
  has_args <- length(formalArgs(x)) == 3

  all(is_fun, has_args)
}

assertthat::on_failure(is_error_handler) <- function(call, env) {
  "`handler` must be a function that accepts: `req`, `res` and `error`"
}

is_logger <- function(x){
  inherits(x, "Logger")
}

assertthat::on_failure(is_logger) <- function(call, env){
  sprintf(
    "%s must be an object of class `Logger` from the `log` package",
    deparse(call$x)
  )
}

is_function <- function(x){
  is.function(x)
}

assertthat::on_failure(is_function) <- function(call, env){
  sprintf(
    "`%s` is not a function",
    deparse(call$x)
  )
}

is_renderer <- function(x){
  length(formalArgs) != 2L
}

assertthat::on_failure(is_renderer) <- function(call, env){
  sprintf(
    "`%s` must accept two arguments: `file` and `data`",
    deparse(call$x)
  )
}
JohnCoene/ambiorix documentation built on Jan. 17, 2025, 11:11 p.m.