# ==========================================================================
# Functions to operate with the environment:
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
# .initContents; .buildBiobaseOpts;
# multiassign; copyEnv
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
.initContents <- function() {
makeG = TRUE
if( isGeneric("contents", where = .GlobalEnv ) )
if( identical(names(formals(contents)), c("object", "all.names")) )
makeG = FALSE
if(makeG)
setGeneric("contents", function(object, all.names)
standardGeneric("contents"))
setMethod("contents", "environment",
function(object, all.names) {
if (missing(all.names))
all.names <- FALSE
as.list(object, all.names=all.names)
}
)
}
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
.buildBiobaseOpts <- function() {
BioC <- getOption("BioC")
if (is.null(BioC)) {
BioC <- list()
class(BioC) <- "BioCOptions"
}
Base <- BioC$Base
if (is.null(Base)) {
Base <- list()
class(Base) <- "BioCPkg"
}
if (is.null(Base$urls))
Base$urls <- list( bioc = "http://bioconductor.org")
##RI: I added this to make my life easier. Should it be TRUE?
##AJR: NO. I've run across a few cases when it would completely
## break functionality, i.e. when tcltk isn't part of the R
## package (on weird, and development-based machines
if (is.null(Base$use.widgets))
Base$use.widgets <- FALSE
BioC$Base <- Base
options("BioC"=BioC)
}
# ==========================================================================
# RG:
# multiput and multiget
# ideally these will be internalized at some point
# FIXME: I think Luke's Dynamic variables should be used rather than
# the on.exit kludge
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
multiassign <- function (x, value, envir = parent.frame(), inherits = FALSE) {
if( ! is.environment(envir) )
stop("envir argument is not an environment")
if( missing(value) ) {
nx <- names(x)
if( any(nchar(nx) == 0) )
stop("value is missing and x does not have named components")
value <- x
x <- nx
}
lenx <- length(x)
for(i in 1:lenx) {
i2 <- (i-1)%%lenx+1
if( is.list(x) ) {
if( is.list(value) )
assign(x[[i]], value[[i2]], envir=envir, inherits=inherits)
else
assign(x[[i]], value[i2], envir=envir, inherits=inherits)
}
else {
if( is.list(value) )
assign(x[i], value[[i2]], envir=envir, inherits=inherits)
else
assign(x[i], value[i2], envir=envir, inherits=inherits)
}
}
}
#### Functions for lists and environments
listLen <- function(x)
lengths(x)
.new_env_size <- function(n) {
## helper function returns suggested size for new environments that
## will be used as hashtables given expected number of elements 'n'.
max(29L, as.integer(n * 1.20))
}
copyEnv <- function(oldEnv, newEnv, all.names=FALSE) {
if (missing(newEnv))
newEnv <- new.env(hash=TRUE,
parent=parent.env(oldEnv),
size=.new_env_size(length(oldEnv)))
nms <- ls(oldEnv, all.names = all.names)
for (nm in nms)
newEnv[[nm]] <- oldEnv[[nm]]
newEnv
}
## Deprecated in v 2.11.2
l2e <- function(vals, envir) {
.Defunct("list2env", package="base")
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.