I have written a package using S4 classes and would like to use the functions rbind, cbind with these defined classes.
Since it does not seem to be possible to define rbind and cbind directly as S4 methods I defined rbind2 and cbind2 instead:
setMethod("rbind2", signature(x="ClassA", y = "ANY"), 
    function(x, y) {
      # Do stuff ...
})
setMethod("cbind2", signature(x="ClassA", y = "ANY"), 
    function(x, y) {
      # Do stuff ...
})
From ?cbind2 I learned that these functions need to be activated using methods:::bind_activation to replace rbind and cbind from base.
I included the call in the package file R/zzz.R using the .onLoad function:
.onLoad <- function(...) {
  # Bind activation of cbind(2) and rbind(2) for S4 classes
  methods:::bind_activation(TRUE)
}
This works as expected. However, running R CMD check I am now getting the following note since I am using an unexported function in methods:
* checking dependencies in R code ... NOTE
Unexported object imported by a ':::' call: 'methods:::bind_activation'
  See the note in ?`:::` about the use of this operator.
How can I get rid of the NOTE and what is the proper way to define the methods cbind and rbind for S4 classes in a package?
I think basically the cBind help page in the Matrix package was accurate historically, but not recently. Here's a class
.A = setClass("A", representation(x="numeric"))
There's no generic, so create one, dispatching on the '...' argument (see ?setMethod and ?dotsMethods)
getGeneric("cbind")
## NULL
setGeneric("cbind", signature="...")
## Creating a new generic function for 'cbind' in the global environment
Then implement a method
setMethod("cbind", "A", function(..., deparse.level=1) "cbind,A-method")
## [1] "cbind"
And finally use it
> cbind(.A(), .A())
[1] "cbind,A-method"
This is fine so long as the '...' arguments are the same (possibly derived) class, which is often good enough.
> cbind(.A(), integer())
     [,1]
[1,] ?  
I believe that bind_activation() has global effects, not just on dispatch in your package; it should be avoided (it is no longer used in the Matrix package, for instance).
Also, I think that this has been updated in R-devel
r67699 | lawrence | 2015-02-01 10:13:23 -0800 (Sun, 01 Feb 2015) | 4 lines
cbind/rbind now delegate recursively to cbind2 (rbind2) when at least one argument is an S4 object and S3 dispatch fails; also consider S4 inheritance during S3 dispatch in the *bind functions.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With