The CRAN version of the R package wrapr package now includes a concise anonymous function constructor: l().
To use it please do the following: attach wrapr and ask it to place a definition for l() in your environment:
##  [1] "LEFT_NAME"      "OTHER_SYMBOL"   "X"              "Y"             
##  [5] "d"              "d2"             "df"             "exp_step"      
##  [9] "f"              "f5"             "inputs"         "l"             
## [13] "model"          "model_f"        "model_o"        "model_p"       
## [17] "pipeable"       "pred_step"      "right_arg_name" "s4"            
## [21] "s5"             "x"Note: throughout this document we are using the letter “l” as a stand-in for the Greek letter lambda, as this non-ASCII character can cause formatting problems in some situations.
You can use l() to define functions. The syntax is: l(arg [, arg]*, body [, env=env]). That is we write a l()-call (which you can do by cutting and pasting) and list the desired function arguments and then the function body. For example the function that squares numbers is:
## function (x) 
## x^2We can use such a function to square the first four positive integers as follows:
## [1]  1  4  9 16Dot-pipe style notation does not need the l() factory as it treats pipe stages as expressions parameterized over the variable “.”:
## [1]  1  4  9 16If you do want an operator notation for function construction you can also use on of the variations of the named map builder:
## [1]  1  4  9 16And we can build functions that take more than one argument as follows:
## function (x, y) 
## x + 3 * y