R/settings.R

Defines functions .norm_settings .test_setting .get_name_in_parent_list .empty_character .not_colours .are_colours .is_not_GRanges_or_GRangesList .not_integer_bigger_equal_than_one_nor_na .not_integer_bigger_equal_than_zero_nor_na .not_integer_bigger_equal_than_one .not_integer_bigger_equal_than_zero .not_integer_bigger_than_zero .not_integer_bigger_than_10 .not_single_integer .not_single_integer_or_na .not_numeric_bigger_zero .not_numeric_between_0_1 .not_numeric_between_0_100 .not_single_numeric_or_na .not_logical_operator .test_test_FALSE .test_test_TRUE .is_valid_nucleotide_seqtype .is_valid_DNAmodType .is_valid_RNAmodType .is_valid_modType

#' @include RNAmodR.R
NULL

# Biostrings/Modstrings related helper functions -------------------------------

.is_valid_modType <- function(modType, seqtype = NA){
  if(is.na(seqtype)){
    return(.is_valid_RNAmodType(modType) | .is_valid_DNAmodType(modType))
  }
  if(seqtype == seqtype(RNAString())){
    .is_valid_RNAmodType(modType)
  } else if(seqtype == seqtype(DNAString())){
    .is_valid_DNAmodType(modType)
  } else {
    stop("")
  }
}

.is_valid_RNAmodType <- function(modType){
  modType %in% Modstrings::shortName(Modstrings::ModRNAString())
}

.is_valid_DNAmodType <- function(modType){
  modType %in% Modstrings::shortName(Modstrings::ModDNAString())
}

.is_valid_nucleotide_seqtype <- function(seqtype){
  seqtype %in% c(seqtype(RNAString()),seqtype(DNAString()))
}

# testthat

.test_test_TRUE <- function(x){TRUE}
.test_test_FALSE <- function(x){FALSE}

# tests ------------------------------------------------------------------------

.not_logical_operator <- function(x){
  .empty_character(x) | !(x %in% c("|","&"))
}

.not_single_numeric_or_na <- function(x){
  !is.numeric(x) | length(x) != 1 | is.na(x)
}
.not_numeric_between_0_100 <- function(x){
  .not_single_numeric_or_na(x) | x < 0 | x > 100
}
.not_numeric_between_0_1 <- function(x){
  .not_single_numeric_or_na(x) | x < 0 | x > 1
}
.not_numeric_bigger_zero <- function(x){
  .not_single_numeric_or_na(x) | x < 0
}

.not_single_integer_or_na <- function(x){
  !is.integer(x) | length(x) != 1 | is.na(x)
}
.not_single_integer <- function(x){
  !is.integer(x) | length(x) != 1
}
.not_integer_bigger_than_10 <- function(x){
  .not_single_integer_or_na(x) | x <= 10L
}
.not_integer_bigger_than_zero <- function(x){
  .not_single_integer_or_na(x) | x <= 0L
}
.not_integer_bigger_equal_than_zero <- function(x){
  .not_single_integer_or_na(x) | x < 0L
}
.not_integer_bigger_equal_than_one <- function(x){
  .not_single_integer_or_na(x) | x <= 1L
}
.not_integer_bigger_equal_than_zero_nor_na <- function(x){
  if(.not_single_integer(x)){
    return(TRUE)
  }
  if(!is.na(x)){
    if(x <= 0L){
      return(TRUE)
    }
  }
  return(FALSE)
}
.not_integer_bigger_equal_than_one_nor_na <- function(x){
  if(.not_single_integer(x)){
    return(TRUE)
  }
  if(!is.na(x)){
    if(x <= 1L){
      return(TRUE)
    }
  }
  return(FALSE)
}

.is_not_GRanges_or_GRangesList <- function(x){
  !is(x,"GRanges") && !is(x,"GRangesList")
}

#' @importFrom grDevices col2rgb
.are_colours <- function(x) {
  vapply(x,
         function(z) {
           tryCatch(is.matrix(grDevices::col2rgb(z)),
                    error = function(e) FALSE)
         },
         logical(1))
}
.not_colours <- function(x){
  !is.character(x) | any(!.are_colours(x))
}

.empty_character <- function(x){
  if(!is.character(x) | is.na(x)){
    return(TRUE)
  }
  width(x) == 0L
}


# testing settings -------------------------------------------------------------

.get_name_in_parent_list <- function(...){
  xnames <- .get_name_in_parent(list(...))
  xnames <- gsub("list\\(","",gsub("\\)","",xnames))
  xnames <- strsplit(xnames,", ")[[1]]
  xnames
}

.test_setting <- function(xname, settings, defaults, input){
  if(!is.list(input)){
    input <- as.list(input)
  }
  test <- settings$variable == xname
  FUN <- as.character(settings[test,"testFUN"])
  default <- defaults[[xname]]
  input <- input[[xname]]
  if(is.null(input)){
    return(default)
  }
  FUN <- get(FUN)
  if(FUN(input) == settings[test,"errorValue"]){
    stop(as.character(settings[test,"errorMessage"]), call. = FALSE)
  }
  input
}

.norm_settings <- function(input, settings, ...){
  if(!all(c("variable","testFUN","errorValue","errorMessage") %in% colnames(settings))){
    stop("Invalid columns in settings test definition.", call. = FALSE)
  }
  if(any(duplicated(settings$variable))){
    stop("Duplicated variable names in settings test definition.",
         call. = FALSE)
  }
  xnames <- .get_name_in_parent_list(...)
  defaults <- list(...)
  names(defaults) <- xnames
  f <- xnames %in% settings$variable
  if(!all(f)){
    stop("Test for variables '",
         paste(xnames[!f],collapse = "', '"),
         "' not found.", call. = FALSE)
  }
  args <- lapply(xnames, .test_setting, settings, defaults, input)
  names(args) <- xnames
  args
}

Try the RNAmodR package in your browser

Any scripts or data that you put into this service are public.

RNAmodR documentation built on Dec. 15, 2020, 2 a.m.