[Rd] Silently loading and Depends: versus NAMESPACE imports

Uwe Ligges ligges at statistik.tu-dortmund.de
Thu Feb 23 10:59:31 CET 2012



On 23.02.2012 06:40, Suraj Gupta wrote:
> Dirk - I'm having the same issue.  Could you provide the details of your
> solution?

By moving the startup message generation to .onAttach?

Uwe Ligges


>
> On Sat, Jan 28, 2012 at 11:15 AM, Dirk Eddelbuettel<edd at debian.org>  wrote:
>
>>
>> On 28 January 2012 at 16:52, Uwe Ligges wrote:
>> |
>> |
>> | On 27.01.2012 15:57, Dirk Eddelbuettel wrote:
>> |>
>> |>  On 12 January 2012 at 12:12, Hervé Pagès wrote:
>> |>  | Hi Dirk,
>> |>  |
>> |>  | On 01/11/2012 11:42 AM, Dirk Eddelbuettel wrote:
>> |>  |>
>> |>  |>   R CMD check really hates it when my .onLoad() function contains
>> |>  |>        suppressMessages(library(foo))
>> |>  |
>> |>  | Note that you can always fool 'R CMD check' by doing something like:
>> |>  |
>> |>  |      sillyname<- library
>> |>  |      suppressMessages(sillyname("foo"))
>> |>  |
>> |>  | Also isn't suppressPackageStartupMessages() more appropriate?
>> |>  |
>> |>  |>
>> |>  |>   However, _and for non-public packages not going to CRAN_ I prefer
>> doing this
>> |>  |>   over using explicit Depends or import statements in the NAMESPACE
>> file as the
>> |>  |>   latter do not give me an ability to make the loading less verbose.
>>   With the
>> |>  |>   R universe of packages being as vast as at is, a simple
>> (non-public) package
>> |>  |>   I have loads about five or six other packages explicitly, each of
>> which loads
>> |>  |>   even more.  The net result is totally intimidating _sixty lines
>> full_ of
>> |>  |>   verbose noise that is meaningful to me as an R programmer, but not
>> for the
>> |>  |>   colleagues expected to use the packages. It looks rather
>> uninviting, frankly.
>> |>  |>
>> |>  |>   How do I use imports via NAMESPACE, and yet keep the noise level
>> down to zero?
>> |>  |
>> |>  | If you only need to import foo (i.e. and actually don't need to
>> attach
>> |>  | it to the search path) then putting foo in Imports and using import
>> |>  | statements in NAMESPACE will keep the noise level down to zero.
>> |>
>> |>  I don't think so.
>> |>
>> |>  I have an internal package, call it fooUtils, that (among other
>> things) needs
>> |>  to figure at startup whether it runs on this or that OS.
>> |>
>> |>  So that package fooUtils does
>> |>
>> |>       .onLoad<- function(libname, pkgname) {
>> |>
>> |>           if (.Platform$OS.type == "windows") {
>> |>               packageStartupMessage("Running on Windows")
>> |>              # [... more stuff here ... ]
>> |>           } else if (.Platform$OS.type == "unix") {
>> |>               packageStartupMessage("Running on Linux")
>> |>              # [... more stuff here ... ]
>> |>           } else {
>> |>               warning("Platform ", .Platform$OS.type, " not recognised")
>> |>               drives<- NULL
>> |>           }
>> |>
>> |>           # ....
>> |>
>> |>       }
>> |
>> | Are you sure you want the messages in .onLoad rather than .onAttach?
>>
>> Thanks Uwe -- looks like that was exactly the hint I needed.
>>
>> By splitting the task across onLoad and onAttach I seem to be able to get
>> want I need even if the package is "tickled" via NAMESPACE's importFrom.
>>
>> Dirk
>>
>> | See ?.onLoad and its "Good practice" section:
>> |
>> | "Loading a namespace should where possible be silent, with startup
>> | messages given by .onAttach. These messages (and any essential ones from
>> | .onLoad) should use packageStartupMessage so they can be silenced where
>> | they would be a distraction."
>> |
>> | Best,
>> | Uwe
>> |
>> |
>> |
>> |>
>> |>  and contrary to your claim, this is not silent as soon as I do
>> |>
>> |>
>> |>      importFrom(fooUtils, someThing)
>> |>
>> |>
>> |>  the messages above pop up. While I can suppress them for 'normal'
>> loads via
>> |>
>> |>      suppressMessages(library(fooUtils))
>> |>
>> |>  or
>> |>
>> |>      suppressPackageStartupMessages(library(fooUtils))
>> |>
>> |>
>> |>  I cannot suppress them via NAMESPACE imports.
>> |>
>> |>  Dirk
>> |>
>> |>  | So I guess your question is: how do we suppress package startup
>> messages
>> |>  | for packages listed in Depends?
>> |>  |
>> |>  | Cheers,
>> |>  | H.
>> |>  |
>> |>  |>
>> |>  |>   Dirk
>> |>  |>
>> |>  |
>> |>  |
>> |>  | --
>> |>  | Hervé Pagès
>> |>  |
>> |>  | Program in Computational Biology
>> |>  | Division of Public Health Sciences
>> |>  | Fred Hutchinson Cancer Research Center
>> |>  | 1100 Fairview Ave. N, M1-B514
>> |>  | P.O. Box 19024
>> |>  | Seattle, WA 98109-1024
>> |>  |
>> |>  | E-mail: hpages at fhcrc.org
>> |>  | Phone:  (206) 667-5791
>> |>  | Fax:    (206) 667-1319
>> |>
>>
>> --
>> "Outside of a dog, a book is a man's best friend. Inside of a dog, it is
>> too
>> dark to read." -- Groucho Marx
>>
>> ______________________________________________
>> R-devel at r-project.org mailing list
>> https://stat.ethz.ch/mailman/listinfo/r-devel
>>
>



More information about the R-devel mailing list