Calls to APIs often require a string argument. This function ensures that
those arguments are length-1, non-NA
character vectors, or length-1,
non-NA
vectors that can be coerced to character vectors. This is intended
to ensure that calls to the API will not fail with predictable errors, thus
avoiding unnecessary internet traffic.
Usage
stabilize_string(
x,
...,
regex = NULL,
arg = rlang::caller_arg(x),
call = rlang::caller_env()
)
Arguments
- x
The argument to stabilize.
- ...
Arguments passed on to
stbl::stabilize_chr_scalar
x_class
Character. The class name of
x
to use in error messages. Use this if you remove a special class fromx
before checking its coercion, but want the error message to match the original class.
- regex
Character scalar. An optional regex pattern to compare the value(s) of
x
against. If a complex regex pattern throws an error, try installing the stringi package withinstall.packages("stringi")
.- arg
An argument name as a string. This argument will be mentioned in error messages as the input that is at the origin of a problem.
- call
The execution environment of a currently running function, e.g.
caller_env()
. The function will be mentioned in error messages as the source of the error. See thecall
argument ofabort()
for more information.
Examples
stabilize_string("a")
#> [1] "a"
stabilize_string(1.1)
#> [1] "1.1"
x <- letters
try(stabilize_string(x))
#> Error in eval(expr, envir) :
#> `x` must be a single <character>.
#> ✖ `x` has 26 values.
x <- NULL
try(stabilize_string(x))
#> Error in eval(expr, envir) : `x` must not be <NULL>.
x <- character()
try(stabilize_string(x))
#> Error in eval(expr, envir) :
#> `x` must be a single <character (non-empty)>.
#> ✖ `x` has no values.
x <- NA
try(stabilize_string(x))
#> Error in eval(expr, envir) : `x` must not contain NA values.
#> • NA locations: 1