On 06/11/2013 11:36, Duncan Murdoch wrote:
On 13-11-06 5:26 AM, Renaud Gaujoux wrote:
Hi,
it seems that the package hooks .onLoad and its C++ pendant
R_unload_mylib are actually not called when R quits, but only when
explicitly calling detach('package:mylib', unload = TRUE).
Maybe this is platform specific, I'm on Ubuntu 13.10 - R 3.0.2 (see
below).
No, this is by design. See ?setHook.
* is there a mechanism that a package can use to effectively do some
cleanup on standard exit, such as calling cleaning up routines of a
loaded third-party library? I tried .onDetach but it did not work
either.
Yes, you can set a finalizer. See ?reg.finalizer.
RODBC is one example.
* by curiosity, in what kind of practical situation would a user
want to call detach(..., unload = TRUE)?
An example is when you want a different version of a package. (That
might now work and probably will not if the package does not unload its
DLL.)
* is there a reason why the hooks are not called on quit?
They are slow to run, and are usually not needed. Finalizers handle the
rare cases where you really do need something to happen.
Or to put it another way, the OS will do most of the unloading when it
terminates the process, more efficiently than the process itself can.
That includes 'unloading' DLLs and freeing memory.
Duncan Murdoch
Thank you.
Bests,
Renaud
###
Sys.info()
sysname release
version
"Linux"
"3.11.0-12-generic" "#19-Ubuntu SMP Wed Oct 9 16:20:46 UTC 2013"
nodename
machine login
"XXXXX"
"x86_64" "renaud"
user
effective_user
"renaud"
"renaud"
sessionInfo()
R version 3.0.2 (2013-09-25)
Platform: x86_64-pc-linux-gnu (64-bit)
locale:
[1] LC_CTYPE=en_US.UTF-8 LC_NUMERIC=C
LC_TIME=en_US.UTF-8 LC_COLLATE=en_US.UTF-8
LC_MONETARY=en_US.UTF-8
[6] LC_MESSAGES=en_US.UTF-8 LC_PAPER=en_US.UTF-8 LC_NAME=C
LC_ADDRESS=C LC_TELEPHONE=C
[11] LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C
attached base packages:
[1] stats graphics grDevices utils datasets methods base
______________________________________________
R-devel@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-devel
______________________________________________
R-devel@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-devel
--
Brian D. Ripley, rip...@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
______________________________________________
R-devel@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-devel