Title: | Call Functions Without Commas Between Arguments |
Version: | 0.2.0 |
Description: | Provides the "comma-free call" operator: '%(%'. Use it to call a function without commas between the arguments. Just replace the '(' with '%(%' in a function call, supply your arguments as standard R expressions enclosed by '{ }', and be free of commas (for that call). |
License: | GPL (≥ 3) |
Encoding: | UTF-8 |
RoxygenNote: | 7.2.1 |
URL: | https://github.com/t-kalinowski/commafree |
BugReports: | https://github.com/t-kalinowski/commafree/issues |
NeedsCompilation: | no |
Packaged: | 2024-04-19 12:48:16 UTC; tomasz |
Author: | Tomasz Kalinowski [aut, cre] |
Maintainer: | Tomasz Kalinowski <kalinowskit@gmail.com> |
Repository: | CRAN |
Date/Publication: | 2024-04-19 13:12:43 UTC |
Call a function
Description
This allows you to call a function with expressions for arguments. It is especially useful for long, multi-line function calls with many arguments (e.g., a shiny UI definition, an R6 class definition, ...)
Usage
fn %(% args
Arguments
fn |
A function |
args |
A set of expressions grouped by |
Details
This (%(%
) merely performs a syntax transformation, so all the same
semantics with regards to lazy argument evaluation apply. For any
function call, replace (
with %(%
and be free of the need for
commas between arguments in that call.
fn %(% { a b c }
Is syntactically equivalent to writing:
func( a, b, c )
Value
Whatever fn()
called with args
returns.
Note
You can produce a missing argument with the special token ,,
, or
foo = `,`
for a named missing arguments (see examples).
Examples
mean %(% {
1:3
na.rm = TRUE
}
writeLines(c %(% {
"Hello"
"Goodbye"
})
# setup helper demonstrating missing arguments
fn <- function(x, y) {
if(missing(y))
print("y was missing")
else
print(y)
}
# How to add a named missing argument
fn %(% {
y = `,`
}
# How to add a positional missing argument
fn %(% {
1
`,,`
}
fn %(% { 1; `,,` }
rm(fn) # cleanup