[Rd] Using substitute to access the expression related to a promise

Duncan Murdoch murdoch.duncan at gmail.com
Mon May 2 16:10:26 CEST 2011


On 02/05/2011 9:53 AM, Hadley Wickham wrote:
> Hi all,
>
> The help for delayedAssign suggests that you can use substitute to
> access the expression associated with a promise, and the help for
> substitute says: "If it is a promise object, i.e., a formal argument
> to a function or explicitly created using ‘delayedAssign()’, the
> expression slot of the promise replaces the symbol.
>
> But this doesn't seem to work:
>
> >  a<- 1
> >  b<- 2
> >  delayedAssign("x", {message("assigning..."); a + b})
> >  substitute(x)
> x
> >  x
> [1] 3
>
> Is this a bug in substitute?
>

I think it is a design flaw rather than a bug:  the global environment 
is handled specially.  If you put those lines into a function you'll see 
different behaviour.  I think if you really carefully read the 
documentation you'll find it says this.

I suggested regularizing this several years ago, but there were worries 
that it would break some common usage.

Duncan Murdoch

> >  sessionInfo()
> R version 2.13.0 (2011-04-13)
> Platform: x86_64-apple-darwin9.8.0/x86_64 (64-bit)
> ...
>
> Hadley
>



More information about the R-devel mailing list