#' @include RNAmodR.R
NULL
# construct GRanges object from found modifications ----------------------------
#' @rdname RNAmodR-development
setMethod(f = "constructModRanges",
signature = c(range = "GRanges", data = "DataFrame"),
function(range, data, modType, scoreFun, source, type) {
if(nrow(data) == 0L) {
return(GenomicRanges::GRanges())
}
if(!.is_non_empty_string(modType)){
stop("'modType' must be single non empty character value.",
call. = FALSE)
}
if(!.is_function(scoreFun)){
stop("'scoreFun' must be a function.", call. = FALSE)
}
if(!.is_non_empty_string(source)){
stop("'source' must be single non empty character value.",
call. = FALSE)
}
if(!.is_non_empty_string(type)){
stop("'type' must be single non empty character value.",
call. = FALSE)
}
if(!.is_valid_modType(modType)){
stop("Modification '",modType,"' not found in the short name ",
"alphabet from the Modstrings package. ",
"'shortName(ModRNAString())' or 'shortName(ModDNAString())'",
call. = FALSE)
}
positions <- as.integer(rownames(data))
scores <- do.call(scoreFun,
list(data))
if(!is.list(scores)){
stop("result of 'scoreFun' must be a list.")
}
data_length <- unique(vapply(scores, length, integer(1)))
if(any(length(positions) != data_length)){
stop("Number of positions and scores do not match.")
}
seqnames_unique <- unique(GenomeInfoDb::seqnames(range))
ranges <- IRanges::IRanges(start = positions,
width = 1L)
strand <- unique(BiocGenerics::strand(range))
mranges <-
GenomicRanges::GRanges(seqnames = seqnames_unique,
ranges = ranges,
strand = strand,
seqinfo = GenomeInfoDb::seqinfo(range),
mod = rep(modType, data_length),
source = source,
type = type,
scores)
mranges
}
)
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.