R/assertions.R

Defines functions is.sod has_na is.null_or_na is.tsProfile is.tsMSdata is.tsLib is.tsRim is.tsSample

# assertions for checking object types

is.tsSample <- function(x) is(x, 'tsSample')
on_failure(is.tsSample) <- function(call, env) {
    paste0(deparse(call$x), " is not a `tsSample` object")
}

is.tsRim <- function(x) is(x, 'tsRim')
on_failure(is.tsRim) <- function(call, env) {
    paste0(deparse(call$x), " is not a `tsRim` object")
}

is.tsLib <- function(x) is(x, 'tsLib')
on_failure(is.tsLib) <- function(call, env) {
    paste0(deparse(call$x), " is not a `tsLib` object")
}

is.tsMSdata <- function(x) is(x, 'tsMSdata')
on_failure(is.tsMSdata) <- function(call, env) {
    paste0(deparse(call$x), " is not a `tsMSdata` object")
}

is.tsProfile <- function(x) is(x, 'tsProfile')
on_failure(is.tsProfile) <- function(call, env) {
    paste0(deparse(call$x), " is not a `tsProfile` object")
}

# useful assertions
# check if a variable is NULL or is a scalar set to NA
is.null_or_na <- function(x) is.null(x) || (is.scalar(x) && is.na(x))
on_failure(is.null_or_na) <- function(call, env) {
    paste0(deparse(call$x), " is neither NULL nor a scalar equal to NA")
}

# return TRUE if x has a NA value. if x is TRUE them it returns FALSE
has_na <- function(x) any(is.na(x))

is.sod <- function(x) length(x) == 1 || length(x) == 2
on_failure(is.sod) <- function(call, env) {
    paste0(deparse(call$x), " is neither a scalar nor its length is equal to 2")
}
acinostroza/TargetSearch documentation built on Nov. 22, 2024, 3:31 p.m.