[Rd] match.arg confusion (PR#921)
maechler@stat.math.ethz.ch
maechler@stat.math.ethz.ch
Tue, 9 Apr 2002 09:07:48 +0200 (MET DST)
>>>>> "PD" == p dalgaard <p.dalgaard@biostat.ku.dk> writes:
PD> [sys.function fails sometimes (sorry, our mail system
PD> decide to throw away the original mail)]
PD> Yes, I bumped into something similar recently. The
PD> problem is that we only actually store the call in the
PD> context structure, not the function, so sys.function has
PD> to grab the call, take the 1st element, and reevaluate
PD> it in the parent frame. It is quite easy to think up
PD> examples where a second evaluation does not give the
PD> same value as the first.
PD> Your particular case is of a slightly different natur
PD> and should be easily fixable by replacing findVar in
PD> R_sysfunction by findVar1 and looking specifically for
PD> objects of mode "function", but the basic problem
PD> persists. I don't think I want to risk fixing this (and
PD> maybe unfixing something else) for 1.2.3 tomorrow
PD> though.
and Peter *did* implement the ``stop gap'' fix above for 1.5.0,
but the proper fix (for the more general problem) is still to be
done.
Martin
JonR> From: J.C.Rougier@durham.ac.uk
JonR> Date: Wed, 25 Apr 2001 13:23:09 +0200 (MET DST)
...
JonR> This one may not strictly be a bug, and it was
JonR> certainly my fault, but it took me a while to track it
JonR> down and it is rather strange:
(it *is* bug)
funOne <- function(x) { funTwo <- 1:10 ; funTwo(x) }
funTwo <- function(v) 2*v
funOne(5) # answer is 10 as expected
# now a different definition for funTwo with a match.arg
funTwo <- function(v, foo=c("small", "large")) {
foo <- match.arg(foo); print(foo); 2*v }
funOne(5) # answer is 10, but foo is NULL
JonR> What happens is that in funOne I mask funTwo with a
JonR> vector, but that doesn't matter as the call to funTwo
JonR> specifies mode="function" (or something similar). But
JonR> what happens when funTwo includes a match.arg? In
JonR> this case match.arg fails, and the reason it fails is
JonR> that sys.function(sys.parent()) in match.arg evaluates
JonR> to 1:10. If there is a bug here it is the failure of
JonR> sys.function to grab a function, with the result that
JonR> formal.args in match.fun is NULL.
-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-
r-devel mailing list -- Read http://www.ci.tuwien.ac.at/~hornik/R/R-FAQ.html
Send "info", "help", or "[un]subscribe"
(in the "body", not the subject !) To: r-devel-request@stat.math.ethz.ch
_._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._