This is equivalent to base::match.arg() with a few differences:

  • Partial matches trigger an error.

  • Error messages are a bit more informative and obey the tidyverse standards.

arg_match() derives the possible values from the caller frame.

arg_match0() is a bare-bones version if performance is at a premium. It requires a string as arg and explicit values. For convenience, arg may also be a character vector containing every element of values, possibly permuted. In this case, the first element of arg is used.

arg_match(arg, values = NULL)

arg_match0(arg, values, arg_nm = as_label(substitute(arg)))

Arguments

arg

A symbol referring to an argument accepting strings.

values

The possible values that arg can take.

arg_nm

The label to be used for arg in error messages.

Value

The string supplied to arg.

Examples

fn <- function(x = c("foo", "bar")) arg_match(x) fn("bar")
#> [1] "bar"
# Throws an informative error for mismatches: try(fn("b"))
#> Error : `x` must be one of "foo" or "bar". #> Did you mean "bar"?
try(fn("baz"))
#> Error : `x` must be one of "foo" or "bar". #> Did you mean "bar"?
# Use the bare-bones version with explicit values for speed: arg_match0("bar", c("foo", "bar", "baz"))
#> [1] "bar"
# For convenience: fn1 <- function(x = c("bar", "baz", "foo")) fn3(x) fn2 <- function(x = c("baz", "bar", "foo")) fn3(x) fn3 <- function(x) arg_match0(x, c("foo", "bar", "baz")) fn1()
#> [1] "bar"
fn2("bar")
#> [1] "bar"
try(fn3("zoo"))
#> Error : `x` must be one of "foo", "bar", or "baz". #> Did you mean "foo"?