inst/scripts/desc.R

nroots = function(x) {
 obs <- if (is.null(x$obsolete)) 
        rep(FALSE, length(x$id))
    else x$obsolete
    roots <- x$id[!obs & sapply(x$parents, length) == 0]
length(roots)
}

#funcs = grep("^get", ls("package:ontoProc"), value=TRUE)

library(S4Vectors)
library(dplyr)
library(ontoProc)
select <- dplyr::select

vn = valid_ontonames()[-4] # cellosaurus is too big for this report
yrs = rep("2023", length(vn))
names(yrs) = vn
yrs["caro"] = "2022"
yrs["cellLineOnto"] = "2022"
yrs["mondo"] = "2022"
yrs["Pronto"] = "2021"
if (!exists("ontos")) {
   ontos = lapply(seq_len(length(vn)), function(x) {cat(vn[x], "\n"); getOnto(vn[x], year_added=yrs[x])})
}
names(ontos) = vn
ontos = lapply(seq_len(length(ontos)), function(i) {attr(ontos[[i]], "oname") <- names(ontos)[i]; ontos[[i]]})

desc = function(x) {
  ona = function(x) if(length(x)==0 || nchar(x)==0) NA else x
  dsub = function(x) sub("data-version: ", "", x)
  fsub = function(x) sub("format-version: ", "", x)
  #ont = do.call(x, list()); 
   ont = x
  nm = attr(ont, "oname")
   dv = grep("^data-version", attr(ont, "version"), value=TRUE)
   fv = grep("^format-version", attr(ont, "version"), value=TRUE)
   data.frame(name=nm, nclass=length(ont$name), nprop=length(names(ont)), nroots=nroots(ont), datav=ona(dsub(dv)), fmtv=ona(fsub(fv))) #, stringsAsFactors=FALSE)
}
#packdesc = do.call(rbind, lapply(funcs, desc))
packdesc = do.call(rbind, lapply(ontos, desc))
write.csv(packdesc, file="packdesc2023.csv")
vjcitn/ontoProc documentation built on March 23, 2024, 7:23 a.m.