[Rd] Missing argument vs. empty argument

Renaud Gaujoux renaud at mancala.cbio.uct.ac.za
Tue Jan 25 12:01:38 CET 2011


My purpose is indeed to write a '[' method.
I will go for the `[.data.frame` solution then.
Thank you.


On 25/01/2011 12:53, Prof Brian Ripley wrote:
> On Tue, 25 Jan 2011, Renaud Gaujoux wrote:
>
>> Hi,
>>
>> is there an easy, robust, and/or recommended way to distinguish a 
>> missing argument from an empty argument as in:
>
> An empty argument is a missing argument when argument matching is 
> done, e.g.
>
>> foo <- function(i,j) match.call()
>> foo(i)
> foo(i = i)
>> foo(i,)
> foo(i = i)
>> foo(,j)
> foo(j = j)
>
> It is rather against the spirit of R to use the actual call rather 
> than the matched call.  Unless you are doing this to write a '[' 
> method I would suggest you find a different convention, e.g. 
> distinguish f(i) and f(i, NULL).  For the exception, look at 
> `[.data.frame`, which does use nargs().
>
> (NB: what I have said does not apply to primitives like '[' itself, 
> which do not do standard argument matching.)
>
>
>>
>> foo <- function(i, j){
>>    print(missing(j))
>>    print(nargs())
>> }
>>
>> foo(i)  # TRUE, 1
>> foo(i,) # TRUE, 2
>>
>> I know I can work around with nargs, the list of arguments and the 
>> names of the passed arguments, but I wish there is something already 
>> in place for this.
>> This is specially important for '['-like methods where x[i,] is not 
>> the same as x[i].
>> What I am looking for is a function that tells me if an argument has 
>> actually been passed empty:
>>
>> foo <- function(i, j, k){
>>    print( empty.arg(j) )
>>    print(nargs())
>> }
>>
>> would result in:
>>
>> foo(i) # FALSE, 1
>> foo(i, ) # TRUE, 2
>> foo(i, j) # FALSE, 2
>> foo(i, k=2) # FALSE, 2
>> foo(i, k=2, ) # TRUE, 3
>>
>> Thank you for any help or pointer.
>>
>> Bests,
>> Renaud
>>
>>
>>
>>
>> ###
>> UNIVERSITY OF CAPE TOWN This e-mail is subject to the UCT ICT 
>> policies and e-mai...{{dropped:5}}
>>
>> ______________________________________________
>> R-devel at r-project.org mailing list
>> https://stat.ethz.ch/mailman/listinfo/r-devel
>>
>

 

###
UNIVERSITY OF CAPE TOWN 

This e-mail is subject to the UCT ICT policies and e-mai...{{dropped:5}}



More information about the R-devel mailing list