[Rd] Generalised piping into operators

Dominick Samperi dj@@mper| @end|ng |rom gm@||@com
Sat Apr 22 03:23:44 CEST 2023


A few years ago there was a post by the author of pipeR suggesting improvements in efficiency and reliability. Is there collaboration between these various pipe projects?

Sent from my iPhone

> On Apr 21, 2023, at 1:01 PM, Duncan Murdoch <murdoch.duncan using gmail.com> wrote:
> 
> On 21/04/2023 12:16 p.m., Michael Milton wrote:
>> I'm afraid I don't understand. I know that parsing `+`(1, 1) returns a result equivalent to `1 + 1`, but why does that impose a restriction on parsing the pipe operator? What is the downside of allowing arbitrary RHS functions?
> 
> I thought the decision to exclude "_ + 1" happens after enough parsing has happened so that the code making the decision can't tell the difference between "_ + 1" and "`+`(_, 1)".  I might be wrong about that, but this suggests it:
> 
>  > quote(_ + 1)
>  Error in quote("_" + 1) : invalid use of pipe placeholder (<input>:1:0)
>  > quote(`+`(_,  1))
>  Error in quote("_" + 1) : invalid use of pipe placeholder (<input>:1:0)
> 
> On the other hand, this works:
> 
>  > quote(x |> `+`(e1 = _, 1))
>  x + 1
> 
> So maybe `+`() is fine after all.
> 
> Duncan Murdoch
> 
> ______________________________________________
> R-devel using r-project.org mailing list
> https://stat.ethz.ch/mailman/listinfo/r-devel



More information about the R-devel mailing list