R/share-commonFuncs.R

Defines functions doAttributes doEnvironment doS4 doList

doList <- function(func,tryFunc, x, ...){
    options <- completeOptions(...)
    ## We do not create a new list unless
    ## there exists any sharable elements
    for(i in seq_along(x)){
        Elt <- func(x[[i]],...)
        if(!C_isSameObject(x[[i]],Elt)){
            x[[i]] <- Elt
        }
    }
    if(options$sharedAttributes){
        ## share attributes
        oldAttrs <- attributes(x)
        if(!is.null(oldAttrs)){
            ## Exclude names and class attributes.
            ## If attributes(x) contains the names attribute,
            ## attributes(attributes(x)) still contains the names attributes
            ## and will cause an infinit loop. We must ignore it.
            ## The later one is not worthy to share
            if(!all(names(oldAttrs) %in% c("class","names"))){
                attrs <- doAttributes(tryFunc, oldAttrs, ...)
                ## set the attributes only when it is different from the old one
                if(!C_isSameObject(oldAttrs,attrs)){
                    attributes(x) <- attrs
                }
            }
        }
    }
    x
}
doS4 <- function(func, x, ...){
    ## If the object is an S4SXP,
    ## share its slots
    if(isSharableAtomic(x)||isSEXPList(x)){
        ## If the object is not an S4SXP,
        ## Calling the right share method
        C_UNSETS4(x)
        if(isS4(x))
            stop("Unexpected error, cannot convert an S4 object to a non-S4 object")
        result <- func(x,...)
        C_SETS4(x)
        C_SETS4(result)
    }else{
        result <- x
        slots <- slotNames(result)
        for(i in slots){
            slot(result, i, check = FALSE) <- func(slot(x, i), ...)
        }
    }
    validObject(result)
    result
}

doEnvironment <- function(func,tryFunc, x, ...){
    options <- completeOptions(...)
    for(i in names(x)){
        x[[i]] <- func(x[[i]],...)
    }
    if(options$sharedAttributes){
        attributes(x) <- tryFunc(attributes(x),...)
    }
    x
}



doAttributes<-function(tryFunc, attrs, ...){
    attrNames <- names(attrs)
    idx <- which(!attrNames%in%c("class","names","levels"))
    for(i in idx){
        newAttri <- tryFunc(attrs[[i]], ...)
        if(!C_isSameObject(newAttri,attrs[[i]])){
            attrs[[i]] <- newAttri
        }
    }
    attrs
}
Jiefei-Wang/SharedObject documentation built on Aug. 19, 2023, 5:47 p.m.