R/class-data-frame.R

Defines functions handleable_column_name wk_handle_slice.data.frame wk_translate.tbl_df wk_translate.data.frame wk_restore.tbl_df wk_restore.data.frame wk_set_geodesic.data.frame wk_is_geodesic.data.frame wk_set_crs.data.frame wk_crs.data.frame wk_writer.data.frame wk_handle.data.frame

Documented in wk_handle.data.frame wk_handle_slice.data.frame wk_restore.data.frame wk_restore.tbl_df wk_translate.data.frame wk_translate.tbl_df

#' Use data.frame with wk
#'
#' @inheritParams wk_handle
#' @inheritParams wk_crs
#' @inheritParams wk_translate
#' @inheritParams wk_identity
#' @inheritParams wk_is_geodesic
#'
#' @export
#'
#' @examples
#' wk_handle(data.frame(a = wkt("POINT (0 1)")), wkb_writer())
#' wk_translate(wkt("POINT (0 1)"), data.frame(col_name = wkb()))
#' wk_translate(data.frame(a = wkt("POINT (0 1)")), data.frame(wkb()))
#'
wk_handle.data.frame <- function(handleable, handler, ...) {
  col <- handleable_column_name(handleable)
  wk_handle(handleable[[col]], handler, ...)
}

#' @export
wk_writer.data.frame <- function(handleable, ...) {
  col <- handleable_column_name(handleable)
  wk_writer(handleable[[col]], ...)
}

#' @export
wk_crs.data.frame <- function(x) {
  col <- handleable_column_name(x)
  wk_crs(x[[col]])
}

#' @export
wk_set_crs.data.frame <- function(x, crs) {
  col <- handleable_column_name(x)
  x[[col]] <- wk_set_crs(x[[col]], crs)
  x
}

#' @export
wk_is_geodesic.data.frame <- function(x) {
  col <- handleable_column_name(x)
  wk_is_geodesic(x[[col]])
}

#' @export
wk_set_geodesic.data.frame <- function(x, geodesic) {
  col <- handleable_column_name(x)
  x[[col]] <- wk_set_geodesic(x[[col]], geodesic)
  x
}

#' @rdname wk_handle.data.frame
#' @export
wk_restore.data.frame <- function(handleable, result, ...) {
  col <- handleable_column_name(handleable)
  if(nrow(handleable) == length(result)) {
    handleable[[col]] <- result
    handleable
  } else if (nrow(handleable) == 1) {
    handleable <- handleable[rep(1L, length(result)), , drop = FALSE]
    handleable[[col]] <- result
    handleable
  } else {
    stop(
      sprintf(
        "Can't assign result of length %d to data frame with %d rows",
        length(result), nrow(handleable)
      ),
      call. = FALSE
    )
  }
}

#' @rdname wk_handle.data.frame
#' @export
wk_restore.tbl_df <- function(handleable, result, ...) {
  tibble::as_tibble(wk_restore.data.frame(handleable, result, ...))
}

#' @rdname wk_handle.data.frame
#' @export
wk_translate.data.frame <- function(handleable, to, ...) {
  col <- handleable_column_name(to)
  col_value <- wk_translate(handleable, to[[col]], ...)

  if (inherits(handleable, "data.frame")) {
    handleable_col <- handleable_column_name(handleable)
    attributes(handleable) <- list(names = names(handleable))
    handleable[handleable_col] <- list(col_value)
    new_data_frame(handleable)
  } else {
    df_raw <- list(col_value)
    names(df_raw) <- col
    new_data_frame(df_raw)
  }
}

#' @rdname wk_handle.data.frame
#' @export
wk_translate.tbl_df <- function(handleable, to, ...) {
  tibble::as_tibble(wk_translate.data.frame(handleable, to, ...))
}

#' @rdname wk_handle_slice
#' @export
wk_handle_slice.data.frame <- function(handleable, handler,
                                       from = NULL, to = NULL, ...) {
  handleable_col <- handleable_column_name(handleable)
  wk_handle_slice(
    handleable[[handleable_col]], handler,
    from = from,
    to = to,
    ...
  )
}

handleable_column_name <- function(df) {
  has_method <- vapply(df, is_handleable, FUN.VALUE = logical(1))

  if (!any(has_method)) {
    stop(
      "To be used with wk_handle(), a data.frame must have at least one handleable column.",
      call. = FALSE
    )
  }

  names(df)[which(has_method)[1L]]
}

Try the wk package in your browser

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

wk documentation built on Oct. 22, 2023, 9:07 a.m.