R/convert.R

Defines functions core_df collapse_mcf mcf_df mgmt_df build_df

# Build data.frame for core report
core_df <- function(x) {
    res <- as.data.frame(x$rows, stringsAsFactors = FALSE)
    colnames(res) <- x$columnHeaders$name
    return(res)
}

# Collpase node values
collapse_mcf <- function(x) {
    if (is.list(x) && !is.data.frame(x))
        vapply(x, collapse_mcf, character(1))
    else
        paste(x$nodeValue, collapse = " > ")
}

# Build data.frame for mcf report
mcf_df <- function(x) {
    col_names <- x$columnHeaders$name
    ind <- grep("MCF_SEQUENCE", x$columnHeaders$dataType, fixed = TRUE)
    if (length(ind)) {
        primitive <- lapply(x$rows, function(i) .subset2(i, "primitiveValue")[-ind])
        primitive <- do.call(rbind, primitive)
        colnames(primitive) <- col_names[-ind]
        conversion <- lapply(x$rows, function(i) .subset2(i, "conversionPathValue")[ind])
        conversion <- lapply(conversion, collapse_mcf)
        conversion <- do.call(rbind, conversion)
        colnames(conversion) <- col_names[ind]
        res <- as.data.frame(cbind(primitive, conversion), stringsAsFactors = FALSE)[, col_names]
    } else {
        res <- as.data.frame(do.call(rbind, unlist(x$rows, recursive = FALSE, use.names = FALSE)), stringsAsFactors = FALSE)
        colnames(res) <- col_names
    }
    return(res)
}

# Build data.frame for mgmt data
mgmt_df <- function(x) {
    res <- x$items
    res <- res[!grepl("Link|kind", colnames(res))]
    if (!is.null(res$permissions.effective)) {
        names(res) <- gsub(".effective", "", names(res), fixed = TRUE)
        res$permissions <- vapply(res$permissions, paste, collapse = ",", FUN.VALUE = character(1))
    }
    ind <- vapply(res, is.list, logical(1))
    if (any(ind)) {
        nrows <- nrow(res)
        unnest <- function(x) {
            x[lengths(x) == 0] <- NA
            do.call(rbind, x)
        }
        res <- c(res[!ind], unlist(lapply(res[ind], unnest), recursive = FALSE))
        class(res) <- "data.frame"
        row.names(res) <- seq_len(nrows)
    }
    return(res)
}

# Build a data.frame for GA report data
#' @importFrom utils type.convert
#' @include utils.R
build_df <- function(x) {
    if (!is.null(x$columnHeaders)) {
        x$columnHeaders$name <- gsub("^.*:", "", x$columnHeaders$name)
        if (grepl("mcfData", x$kind, fixed = TRUE))
            res <- mcf_df(x)
        else
            res <- core_df(x)
        toconvert <- x$columnHeaders$columnType == "METRIC" & x$columnHeaders$dataType != "STRING"
        res[toconvert] <- lapply(res[toconvert], type.convert, as.is = TRUE)
    } else
        res <- mgmt_df(x)
    colnames(res) <- rename_params(colnames(res))
    rownames(res) <- NULL
    class(res) <- c("tbl_df", "tbl", "data.frame")
    return(res)
}

Try the RGA package in your browser

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

RGA documentation built on May 2, 2019, 6:47 a.m.