R/indexed.r

Defines functions print.indexed as.list.indexed names.indexed length.indexed

#' @export
length.indexed <- function(x) length(x$index)

#' @export
names.indexed <- function(x) {
  labels <- attr(x, "split_labels")
  labels[] <- lapply(labels, as.character)

  do.call(paste, c(labels, list(sep = ".")))
}

#' @export
as.list.indexed <- function(x, ...) {
  n <- length(x)
  out <- vector("list", n)
  for (i in seq_len(n)) {
    out[[i]] <- x[[i]]
  }
  names(out) <- names(x)
  class(out) <- c("split", "list")
  out
}

#' @export
print.indexed <- function(x, ...) {
  print(as.list(x))
}

#' @export
"[.indexed" <- function(x, ...) {
  as.list(x)[...]
}
hadley/plyr documentation built on Oct. 15, 2023, 8:20 a.m.