[Rd] possible bug in formals

Josef Leydold leydold at statmath.wu.ac.at
Mon May 24 15:44:42 CEST 2010


Dear Brian and Uwe,

Thanks a lot for the clarification.
I made the naive assumption that numeric constants in R are similar to
those in C. 

Two questions still remain:

(1) when I have a function 

    f<- function(a=1,b=-1) { a+b }

    is it safe to use 

    val <- as.character(deparse(formals(f)$b))

    to obtain a string that contains the default value for
    argument "b". (Does is also work for other arguments with some 
    default of arbitrary class?)

(2) I have seen that packages like gWidget (in function ggenericwidget)
    use a statement like

    switch(class(formals(f)$b),
	numeric = { .... },
        character = { .... },
        class = { .... }, ....

    for automatically processing function arguments.
    in the case of "b=-1" this procedure obviously fails.
    (I found this behavior of 'formals' while playing around with 
    packages "gWidgets" and "fgui" from CRAN).

    Is there a safe workaround for this problem?

    That is, is there a safe function that returns class
    "numeric" for an exresion like "-1" or "-Inf"?

Josef


On Sun, May 23, 2010 at 03:52:00PM +0100, Prof Brian Ripley wrote:
> Documented too: from ?NumericConstants
> 
>       Note that a leading plus or minus is not regarded by the parser as
>       part of a numeric constant but as a unary operator applied to the
>       constant.
> 
> 
> 
> On Sun, 23 May 2010, Uwe Ligges wrote:
> 
> >
> >
> > On 23.05.2010 16:14, Josef Leydold wrote:
> >> Hi,
> >> 
> >> I am a little bit surprised by the following output of
> >> 'formals'. Is this the intended behavior?
> >> 
> >>> f<- function(a=1,b=-1) { a+b }
> >>> class(formals(f)$a)
> >> [1] "numeric"
> >>> class(formals(f)$b)
> >> [1] "call"
> >> 
> >> 
> >> Josef
> >> 
> >> 
> >
> >
> > Yes, the arguments have not yet been evaluated, hence -1 is still a language 
> > object.
> >
> > Try to write
> > f<- function(a= +1, b= -1) { a+b }
> > and you will find that this is a fascinating feature.
> >
> > Uwe Ligges
> >
> > ______________________________________________
> > R-devel at r-project.org mailing list
> > https://stat.ethz.ch/mailman/listinfo/r-devel
> >
> 
> -- 
> Brian D. Ripley,                  ripley at stats.ox.ac.uk
> Professor of Applied Statistics,  http://www.stats.ox.ac.uk/~ripley/
> University of Oxford,             Tel:  +44 1865 272861 (self)
> 1 South Parks Road,                     +44 1865 272866 (PA)
> Oxford OX1 3TG, UK                Fax:  +44 1865 272595
> 

-- 


-----------------------------------------------------------------------------
Josef Leydold   |  WU (Vienna University of Economics and Business)
                |  Institute for Statistics and Mathematics
-----------------------------------------------------------------------------
Augasse 2-6     |  Tel.   +43 1 31336 4695
A-1090 Vienna   |  FAX    +43 1 31336 774
European Union  |  email  josef.leydold at wu.ac.at
-----------------------------------------------------------------------------
Alles Unglueck kam daher, dass die Denkenden nicht mehr handeln konnten,
und die Handelnden keine Zeit mehr fanden zu denken.       (Marlen Haushofer)



More information about the R-devel mailing list