R/unnest.R

Defines functions unnest_df unnest_list_of_df unnest_col c_list_of

c_list_of <- function(x) {
  if (length(x) == 0) {
    # vctrs internals
    return(attr(x, "ptype"))
  }

  vec_c(!!!x, .name_spec = zap())
}

unnest_col <- function(x, col, ptype) {
  col_data <- x[[col]]
  out <- x[rep(seq_len(nrow(x)), lengths(col_data)), ]

  if (length(col_data) > 0) {
    col_data <- unlist(col_data, recursive = FALSE, use.names = FALSE)
    if (!identical(col_data[0], ptype)) {
      abort(paste0(
        "Internal: unnest_col() ptype mismatch, must be ",
        class(ptype)[[1]],
        ", not ",
        class(col_data[0])[[1]]
      ))
    }
  } else {
    col_data <- ptype
  }

  out[[col]] <- col_data
  out
}

unnest_list_of_df <- function(x, col) {
  col_data <- x[[col]]
  stopifnot(is_list_of(col_data))

  out <- x[rep(seq_len(nrow(x)), map_int(col_data, vec_size)), setdiff(names(x), col)]
  out <- vec_cbind(out, c_list_of(col_data))
  out
}

unnest_df <- function(x, col, ptype) {
  col_data <- x[[col]]

  out <- x[rep(seq_len(nrow(x)), map_int(col_data, vec_size)), setdiff(names(x), col)]

  if (length(col_data) > 0) {
    col_data <- vec_rbind(!!!col_data)
    if (!identical(col_data[0, ], ptype)) {
      abort(paste0(
        "Internal: unnest_df() ptype mismatch."
        # "Internal: unnest_df() ptype mismatch, must be ",
        # commas(map(ptype, class), Inf),
        # ", not ",
        # commas(map(col_data, class), Inf)
      ))
    }
  } else {
    col_data <- ptype
  }

  out <- vec_cbind(out, col_data)
  out
}

Try the dm package in your browser

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

dm documentation built on Nov. 2, 2023, 6:07 p.m.