R/hasAssay.R

Defines functions hasAssay

Documented in hasAssay

#' Checking assay method for any class
#'
#' The `hasAssay` function is intended for developers who would like to
#' include new classes into a `MultiAssayExperiment` instance.
#' It checks the methods tables of the `assay` function for the
#' specified class of the argument.
#'
#' @param object A `MultiAssayExperiment` or \code{named list}
#'     object instance
#' @return A `logical` value indicating method availability
#'
#' @examples
#' lst <- structure(list(), .Names=character())
#' hasAssay(lst)
#'
#' @export hasAssay
hasAssay <- function(object) {
    if (is(object, "MultiAssayExperiment"))
        applyFun <- experiments
    else
        applyFun <- ExperimentList
    validClasses <- vapply(X = getElement(findMethods("assay"), "signatures"),
                           FUN = "[",
                           FUN.VALUE = character(1), ... = 1L)
    validClasses <- unique(validClasses)
    all(vapply(applyFun(object), FUN = function(element) {
        any(vapply(validClasses, FUN = function(cl) {
            is(element, cl)
        }, FUN.VALUE = logical(1)))
    }, FUN.VALUE = logical(1)))
}
waldronlab/MultiAssayExperiment documentation built on May 6, 2024, 8:34 p.m.