On 12/11/2018 8:32 AM, Duncan Murdoch wrote:
On 12/11/2018 8:09 AM, Thomas Lin Pedersen wrote:
I have a couple of packages (‘fiery’ and ‘reqres') that uses a mock of a rook
request for their examples. The mock is an R6 object containing a
rawConnection, along with a finalizer that closes this connection when the
object is removed. So far so good. I’ve recently been getting CRAN errors due
to the rawConnection not being closed in examples
cleanEx()
Error: connections left open:
content (rawConnection)
and the only way to remove this is by removing the objects and calling gc() as
part of the example code. While it is possible to hide all that inside a
\dontshow{} block, it appears to me that it would be better if cleanEx() did a
cleaning of the environment along with a single gc call prior to performing any
checks on the end state. Is this something you would consider?
Wouldn't it be possible for you to add a way to explicitly request the
connection be closed? Then the finalizer would only need to close it if
you forgot.
After some private messages, it appears that having the example code
explicitly remove the object is enough to satisfy the check. Presumably
this is because a garbage collection is happening before the error is
issued, and it triggers the finalizer.
Duncan Murdoch
______________________________________________
R-devel@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-devel