R/step-subset-arrange.R

Defines functions is_simple_arrange is_copied arrange.dtplyr_step

Documented in arrange.dtplyr_step

#' Arrange rows by column values
#'
#' This is a method for dplyr generic [arrange()]. It is translated to
#' an [order()] call in the `i` argument of `[.data.table`.
#'
#' @param .data A [lazy_dt()].
#' @inheritParams dplyr::arrange
#' @importFrom dplyr arrange
#' @export
#' @examples
#' library(dplyr, warn.conflicts = FALSE)
#'
#' dt <- lazy_dt(mtcars)
#' dt %>% arrange(vs, cyl)
#' dt %>% arrange(desc(vs), cyl)
#' dt %>% arrange(across(mpg:disp))
arrange.dtplyr_step <- function(.data, ..., .by_group = FALSE) {
  dots <- capture_dots(.data, ..., .j = FALSE)
  if (.by_group) {
    dots <- c(syms(.data$groups), dots)
  }

  if (length(dots) == 0) {
    return(.data)
  }

  no_transmute <- all(map_lgl(dots, is_simple_arrange))
  # Order without grouping then restore
  dots <- set_names(dots, NULL)
  if (is_copied(.data) && no_transmute) {
    dots <- c(dots, na.last = TRUE)
    step <- step_call(.data, "setorder", dots)
  } else {
    step <- step_subset(.data, i = call2("order", !!!dots), groups = character())
  }
  step_group(step, groups = .data$groups)
}

is_copied <- function(x) {
  x$implicit_copy || x$needs_copy
}

is_simple_arrange <- function(x) {
  out <- FALSE
  if (is_symbol(x)) {
    out <- TRUE
  } else if (is_call(x, "-", 1)) {
    if (is_symbol(x[[2]])) {
      out <- TRUE
    }
  }
  out
}

Try the dtplyr package in your browser

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

dtplyr documentation built on March 31, 2023, 9:13 p.m.