[Rd] attach() outputs messages to stdout - should it be stderr?
Martin Maechler
maechler at stat.math.ethz.ch
Mon Apr 7 10:40:11 CEST 2014
>>>>> Henrik Bengtsson <hb at biostat.ucsf.edu>
>>>>> on Sun, 6 Apr 2014 21:33:15 -0700 writes:
> Contrary to other functions in 'base', attach() output
> messages to stdout instead of stdout, e.g.
>> a <- 1 capture.output(attach(list(a=1)))
> [1] "The following object is masked _by_ .GlobalEnv:"
> [2] ""
> [3] " a"
> Shouldn't this message go to stderr?
well, it this is changed... it should be changed to use
message() really -- as library() does.
Then, it will not only go to stderr, but also be something you can
e.g. use suppressMessages( . ) with.
I tend to agree to change this from cat() to message(),
and will do so after a bit of waiting..
Martin
> Here's a patch for the local function checkConflicts() of
> base::attach(), cf. ditto for base::library() that outputs
> to stderr:
> Index: library/base/R/attach.R
> ===================================================================
> --- library/base/R/attach.R (revision 65344)
> +++ library/base/R/attach.R (working copy)
> @@ -73,7 +73,7 @@
> "The following objects
> are masked %s %s:\n\n%s\n"),
> if (i < db.pos) "_by_" else "from",
> pkg, paste(objs, collapse="\n"))
> - cat(msg)
> + cat(msg, file = stderr())
> }
> }
> }
> /Henrik
More information about the R-devel
mailing list