R/vars.R

Defines functions setPackageVariable isPackageVariableDefined getPackageVariable addPackageVariables initPackageVariables

#
#   P A C K A G E   V A R I A B L E S
#
#
# package veriages are a useful thing to have if 
# you want to cache something on a global level and 
# access whenever needed, plus it provides an easy
# trace means when you need to check all places a 
# variable is read or written to, plus it doesn't 
# overlap with local vars, minus it makes the code a 
# little ugly and hard to read.
#
# access to global environment variables is a very 
# bad thing, completely untrackable, prone to errors 
# and should preferably be avioded.
#
#

defaultVariables <- NULL

initPackageVariables <- function() {
    variables <- list(
        trace.level = 0,
        trace.step = "--"
    )
    
    defaultVariables <<- addPackageVariables(emptyenv(), variables)
}

addPackageVariables <- function(variables, new) {
    if (! is.null(new)) {
        variables <- new.env(parent = variables)
        names <- names(new)
        for (i in seq(along = new))
        assign(names[i], new[[i]], env = variables)
    }
    variables
}

getPackageVariable <- function(name, variables = defaultVariables) {
    
    if (exists(name, envir=variables)) {
        return(get(name, env = variables));
    } else {
        return(NULL)
    }
}

isPackageVariableDefined <- function(name, variables = defaultVariables) {
    return(exists(name, envir=variables))
}

setPackageVariable <- function(...) {
    list <- list(...)
    names <- names(list)
    for (i in seq(along = list))
    assign(names[i], list[[i]], env = defaultVariables)
}

Try the ArrayExpressHTS package in your browser

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

ArrayExpressHTS documentation built on Nov. 8, 2020, 7:50 p.m.