R/step-setnames.R

Defines functions step_setnames

step_setnames <- function(x, old, new, in_place, rename_groups = FALSE) {
  stopifnot(is_step(x))
  stopifnot(is.character(old) || is.integer(old))
  stopifnot(is.character(new))
  stopifnot(length(old) == length(new))
  stopifnot(is_bool(in_place))
  stopifnot(is_bool(rename_groups))

  if (is.integer(old)) {
    locs <- old
  } else {
    locs <- vctrs::vec_match(old, x$vars)
  }

  name_changed <- x$vars[locs] != new
  old <- old[name_changed]
  new <- new[name_changed]
  locs <- locs[name_changed]

  if (length(old) == 0) {
    return(x)
  }

  new_vars <- x$vars
  new_vars[locs] <- new
  out <- step_call(x,
    "setnames",
    args = list(old, new),
    vars = new_vars,
    in_place = in_place
  )

  if (rename_groups) {
    groups <- rename_groups(x$groups, set_names(old, new))
    out <- step_group(out, groups)
  }

  out
}
hadley/dtplyr documentation built on Feb. 22, 2024, 4:40 a.m.