[Rd] [External] API for converting LANGSXP to LISTSXP?
iuke-tier@ey m@iii@g oii uiow@@edu
iuke-tier@ey m@iii@g oii uiow@@edu
Sat Jul 6 15:59:11 CEST 2024
We have long been discouraging the use of pairlists. So no, we will
not do anything to facilitate this conversion; if anything the
opposite. SET_TYPEOF is used more than it should be in the sources.
It is something I would like us to fix sometime, but isn't high
priority.
Best,
luke
On Fri, 5 Jul 2024, Kevin Ushey wrote:
> Hi,
>
> A common idiom in the R sources is to convert objects between LANGSXP
> and LISTSXP by using SET_TYPEOF. However, this is soon going to be
> disallowed in packages. From what I can see, there isn't currently a
> direct way to convert between these two object types using the
> available API. At the R level, one can convert calls to pairlists
> with:
>
>> as.call(pairlist(as.symbol("rnorm"), 42))
> rnorm(42)
>
> However, the reverse is not possible:
>
>> as.pairlist(call("rnorm", 42))
> Error in as.pairlist(call("rnorm", 42)) :
> 'language' object cannot be coerced to type 'pairlist'
>
> One can do such a conversion via conversion to e.g. an intermediate R
> list (VECSXP), but that seems wasteful. Would it make sense to permit
> this coercion? Or, is there some other relevant API I'm missing?
>
> For completeness, Rf_coerceVector() also emits the same error above
> since it uses the same code path.
>
> Thanks,
> Kevin
>
> ______________________________________________
> R-devel using r-project.org mailing list
> https://stat.ethz.ch/mailman/listinfo/r-devel
>
--
Luke Tierney
Ralph E. Wareham Professor of Mathematical Sciences
University of Iowa Phone: 319-335-3386
Department of Statistics and Fax: 319-335-3017
Actuarial Science
241 Schaeffer Hall email: luke-tierney using uiowa.edu
Iowa City, IA 52242 WWW: http://www.stat.uiowa.edu/
More information about the R-devel
mailing list