R/check-scalar-hasElements.R

Defines functions nElements hasElements

Documented in hasElements nElements

#' Does the input have elements?
#'
#' @name check-scalar-hasElements
#' @note Updated 2023-09-29.
#'
#' @inherit check
#' @inheritParams AcidRoxygen::params
#'
#' @seealso
#' - `prod()`, which returns the product of all values in its arguments. This
#' is called internally to check the number of elements.
#' - `assertive.properties::has_elements()`.
#' - `assertive.properties::is_of_dimension()`.
#' - `assertive.properties:::n_elements()`.
#'
#' @examples
#' ## TRUE ====
#' hasElements("hello")
#' hasElements("hello", n = 1)
#' hasElements(list(a = 1, b = 2), n = 2)
#'
#' ## FALSE ====
#' hasElements(NULL)
#' hasElements(list(), n = 1)
NULL



#' @rdname check-scalar-hasElements
#' @export
hasElements <- function(x, n = NULL) {
    nElementsX <- nElements(x)
    if (is.null(n)) {
        if (identical(nElementsX, 0L)) {
            return(false("{.var %s} has 0 elements.", .toName(x)))
        } else {
            return(TRUE)
        }
    }
    ## We're using `prod()` here to check vector n input (e.g. `c(nrow, ncol)`).
    nElementsN <- prod(n)
    if (nElementsX != nElementsN) {
        return(false(
            ngettext(
                nElementsX,
                "{.var %s} has %d element, not %d.",
                "{.var %s} has %d elements, not %d."
            ),
            .toName(x),
            nElementsX,
            nElementsN
        ))
    }
    TRUE
}



#' @describeIn check-scalar-hasElements Return the number of elements in object.
#' @export
nElements <- function(x) {
    if (is.recursive(x)) {
        sum(vapply(x, nElements, integer(1L)))
    } else {
        as.integer(prod(.dim(x)))
    }
}
steinbaugh/goalie documentation built on Jan. 17, 2024, 5:16 p.m.