Skip to contents

Check that arguments with defaults come last in all function declarations, as per the tidyverse design guide.

Changing the argument order can be a breaking change. An alternative to changing the argument order is to instead set the default for such arguments to NULL.

Usage

function_argument_linter()

See also

Examples

# will produce lints
lint(
  text = "function(y = 1, z = 2, x) {}",
  linters = function_argument_linter()
)
#> <text>:1:24: style: [function_argument_linter] Arguments without defaults should come before arguments with defaults.
#> function(y = 1, z = 2, x) {}
#>                        ^

lint(
  text = "function(x, y, z = 1, ..., w) {}",
  linters = function_argument_linter()
)
#> <text>:1:28: style: [function_argument_linter] Arguments without defaults should come before arguments with defaults.
#> function(x, y, z = 1, ..., w) {}
#>                            ^

# okay
lint(
  text = "function(x, y = 1, z = 2) {}",
  linters = function_argument_linter()
)
#>  No lints found.

lint(
  text = "function(x, y, w, z = 1, ...) {}",
  linters = function_argument_linter()
)
#>  No lints found.

lint(
  text = "function(y = 1, z = 2, x = NULL) {}",
  linters = function_argument_linter()
)
#>  No lints found.

lint(
  text = "function(x, y, z = 1, ..., w = NULL) {}",
  linters = function_argument_linter()
)
#>  No lints found.