R/str_data.R

Defines functions str_data

Documented in str_data

str_data <- function(pkgs, filterFUN, ...)
{
    ## Purpose: str(.) of all datasets in a package
    ## ----------------------------------------------------------------------
    ## Arguments: pkgs : character vector of names of R packages
    ##		  ... : potential further arguments to be passed to str()
    ## ----------------------------------------------------------------------
    ## Author: Martin Maechler, Date: 17 Jun 2005, 09:04
    stopifnot(is.character(pkgs))
    ans <- as.list(pkgs); names(ans) <- pkgs
    if(hasFilter <- !missing(filterFUN)) {
	stopifnot(is.function(filterFUN))
	filtName <- deparse(substitute(filterFUN))
    }
    for(pkg in pkgs) {
	cat("\nAll data sets in R package '",pkg,"' ",
	    if(hasFilter)
		paste0(" filtered by ", paste(filtName, collapse=" "),"()"),
	    ":\n--------------------------","  ", rep("=", nchar(pkg)),
	    "\n\n", sep='')
	dd <- data(package = pkg)
	items <- unique( dd$results[,"Item"] ) # unique(): bug in data(), R <= 3.2.2
	## not those that are part of "another" (multi-object) one:
	if(length(i <- grep(".*\\(.*\\)$", items)) > 0)
	    items <- items[- i]
	its <- vector("list", length=length(items)); names(its) <- items
	##
	## TODO Gabor's wishes (2005-03-25):
	##    1) allow filtering on class(),
	##    2) sorting according to size -- that needs 2 passes through...
        ## MM: [optionally?] *return* class; also *return* dim(), length()
	dat.env <- new.env()
	for(n in items) {
	    data(list = n, package = pkg, envir = dat.env)
	    nm0 <- ls(envir = dat.env, all.names=TRUE)## all objects created from above data(.)
	    nms <- if(hasFilter)
		       nm0[vapply(nm0, function(n) filterFUN(get(n, envir = dat.env)), TRUE)]
		   else nm0
	    if(length(nms)) {
		cat(n, ": ")
		if(length(nms) == 1) { ## one data set == normal case
		    if(nms != n) cat(nms, ": ")
		    ob <- get(nms, envir = dat.env)
		    str(ob, ...)
		}
		else { ## more than one data set
		    cat("\n")
		    for(nn in nms) {
			cat(" ", nn, ": ")
			str(get(nn, envir=dat.env), indent.str = paste(" ", ''), ...)
		    }
		}
		cat("--------------\n")
		its[[n]] <- nms
	    }
	    else {
		if(!hasFilter) warning(gettextf("no objects found from data(\"%s\")", n))
		its[n] <- NULL # delete that list entry
	    }
	    rm(list = nm0, envir = dat.env)
	}
	ans[[pkg]] <- its
    }
    invisible(ans)
}
mmaechler/sfsmisc documentation built on April 29, 2024, 5:20 p.m.