Patrick Aboyoun
2009-Jun-18  23:42 UTC
[Rd] validObject throws non-caught error when slot doesn't exist
I have been retooling an S4 class definition to include another slot and 
have found that the methods::validObject function (defined in 
methods/R/SClasses.R) in R-devel throws an error that isn't caught 
internally (and thus not controllable by 'test' argument) when 
retrieving a non-existent slot. The offending line of code is shown below:
 > validObject
function (object, test = FALSE, complete = FALSE)
{
...
    for (i in seq_along(slotTypes)) {
        classi <- slotTypes[[i]]
        sloti <- slot(object, slotNames[[i]]) # offending line of code
One potential patch is to substitute the offending line with
        sloti <- try(slot(object, slotNames[[i]]), silent = TRUE)
        if (class(sloti) == "try-error") {
            errors <- c(errors, paste("missing slot \"",
slotNames[[i]],
                "\"", sep = ""))
            next
        }
Here is a reproduce and an example using vaildObject2 that substitutes 
the offending line with the code given above:
 > setClass("Foo", representation(bar = "character"))
[1] "Foo"
 > a <- new("Foo", bar = letters)
 > setClass("Foo", representation(bar = "character", star
= "numeric"))
[1] "Foo"
 > validObject(a, test = TRUE)
Error in slot(object, slotNames[[i]]) :
  no slot of name "star" for this object of class "Foo"
 > validObject2(a, test = TRUE)
[1] "missing slot \"star\""
 > sessionInfo()
R version 2.10.0 Under development (unstable) (2009-06-12 r48755)
i386-apple-darwin9.6.0
locale:
[1] en_US.UTF-8/en_US.UTF-8/C/C/en_US.UTF-8/en_US.UTF-8
attached base packages:
[1] stats     graphics  grDevices utils     datasets  methods   base     
Patrick
John Chambers
2009-Jun-19  14:15 UTC
[Rd] validObject throws non-caught error when slot doesn't exist
Patrick, Thanks for the bug report and the proposed patch. There are some related ways that validObject can fail (e.g., if the revised class definition extends one of the object types or if the object is an S3 object), so the patch needs to be a little more general, but I will commit something to the 2.10 development version and send mail). John Patrick Aboyoun wrote:> I have been retooling an S4 class definition to include another slot > and have found that the methods::validObject function (defined in > methods/R/SClasses.R) in R-devel throws an error that isn't caught > internally (and thus not controllable by 'test' argument) when > retrieving a non-existent slot. The offending line of code is shown > below: > > > validObject > function (object, test = FALSE, complete = FALSE) > { > ... > for (i in seq_along(slotTypes)) { > classi <- slotTypes[[i]] > sloti <- slot(object, slotNames[[i]]) # offending line of code > > One potential patch is to substitute the offending line with > > sloti <- try(slot(object, slotNames[[i]]), silent = TRUE) > if (class(sloti) == "try-error") { > errors <- c(errors, paste("missing slot \"", slotNames[[i]], > "\"", sep = "")) > next > } > > Here is a reproduce and an example using vaildObject2 that substitutes > the offending line with the code given above: > > > setClass("Foo", representation(bar = "character")) > [1] "Foo" > > a <- new("Foo", bar = letters) > > setClass("Foo", representation(bar = "character", star = "numeric")) > [1] "Foo" > > validObject(a, test = TRUE) > Error in slot(object, slotNames[[i]]) : > no slot of name "star" for this object of class "Foo" > > validObject2(a, test = TRUE) > [1] "missing slot \"star\"" > > sessionInfo() > R version 2.10.0 Under development (unstable) (2009-06-12 r48755) > i386-apple-darwin9.6.0 > > locale: > [1] en_US.UTF-8/en_US.UTF-8/C/C/en_US.UTF-8/en_US.UTF-8 > > attached base packages: > [1] stats graphics grDevices utils datasets methods base > > > Patrick > > ______________________________________________ > R-devel at r-project.org mailing list > https://stat.ethz.ch/mailman/listinfo/r-devel >