R/nexmlTree.R

Defines functions nexmlTree

setClass("phyloS4", 
         slots = c(edge = "matrix",
                        Nnode = "integer",
                        tip.label = "character",
                        edge.length = "numeric"))
setOldClass("phylo", S4Class="phyloS4")

## multiPhylo and multiPhyloList are used in other files, but perhaps it is
## best to keep the definitions all here
setOldClass("multiPhylo")
setOldClass("multiPhyloList")

setClass("nexmlTree", slots = c(nexml = "nexml"), contains="phylo")
setMethod("show", "nexmlTree", function(object) print.phylo(object))
# callNextMethod(object) ## callNextMethod might have been an option, but it looks for 'show' method, not print method?? 

## constructor function
nexmlTree <- function(object){
  if(is(object, "nexml")){
    phylo <- as(object, "phylo")
  }
  new("nexmlTree", nexml = object, phylo)
}

## Coercions between classes
setAs("XMLInternalElementNode", "nexmlTree", function(from)
      nexmlTree(as(from, "nexml")))
setAs("nexmlTree", "XMLInternalElementNode", function(from)
      as(from@nexml, "XMLInternalElementNode"))
setAs("XMLInternalNode", "nexmlTree", function(from)
      nexmlTree(as(from, "nexml")))
setAs("nexmlTree", "XMLInternalNode", function(from)
      as(from@nexml, "XMLInternalNode"))
setAs("phylo", "nexmlTree", function(from)
      nexmlTree(as(from, "nexml")))
setAs("nexmlTree", "phylo", function(from)
      as(from@nexml, "phylo"))
setAs("nexml", "nexmlTree", function(from)
      nexmlTree(from))
setAs("nexmlTree", "nexml", function(from)
      from@nexml)



### Testing 
# a <- new("phylo", bird.orders)
# expect_is(a, "phylo")
# a 
# plot(a)
# 
# b <- new("nexmlTree", bird.orders, nexml = as(bird.orders, "nexml"))
# expect_is(b, "phylo")
# b
# plot(b) 
# 
# Some ape functions don't check class properly.  i.e. class(b) == "phylo" is FALSE, but is(b, "phylo") is TRUE.  

# Don't really need these, but here they are mapping between S3 and S4 
setAs("phyloS4", "phylo", function(from){
      out <- list(edge = from@edge,
                  Nnode = from@Nnode,
                  tip.label = from@tip.label,
                  edge.length = from@edge.length)
      class(out) <- "phylo"
      out
})
setAs("phylo", "phyloS4", function(from)
      new("phyloS4", 
          edge = from$edge,
          Nnode = from$Nnode,
          tip.label = from$tip.label,
          edge.length = from$edge.length))

Try the RNeXML package in your browser

Any scripts or data that you put into this service are public.

RNeXML documentation built on Feb. 16, 2023, 6:56 p.m.