On 03/14/2013 07:16 AM, Joern Toedling wrote:
Hello,

thanks for following up on this, Martin. Indeed the problem was the missing S4
generic for "plot" was the problem. For some reason, the most recent version of
R requires to declare this explicitly or to import the generic "plot" from
another package. While before, I think that such a generic was created
automatically when one defined a "plot" method for a S4 class.

The previous example:
library("girafe")
example(plotAligned)

actually works if you add a 'setGeneric("plot")' before calling
'example(plotAligned)'.

I have added this to the development version of 'girafe'. It's unfortunate that
such changes to R can also break the release version but since the release
package is there from previous build versions and the next release will be soon,
it's probably not worth to make any major efforts there.

Hi Joern --

I did follow up with this on R-devel

  https://stat.ethz.ch/pipermail/r-devel/2013-March/066111.html

A change in 'intervals' triggered this problem (exporting an S4 method and hence generic for plot), not a change in R.

The problem was that setMethod finds the S4 generic 'plot' on the search path, rather than the S3 plot imported in your name space (I personally think this is not correct behaviour); your namespace then exports the unmodified S3 generic, masking the S4 generic on the search path that your method was added to.

A better work-around is to importFrom(intervals, plot); this avoids creating another S4 generic 'plot'. Experience has shown that having multiple generics of the same function creates problems as additional packages enter the picture; this is what motivates the BiocGenerics package.

An additional enhancement, not under your control, would be for intervals to reuse the S4 plot generic from stats4 -- importFrom (stats4, plot) -- and for your package too to importFrom(stats4, plot); the packages would then be adding methods to the same generic, and could do so independently of what packages (other than stats4) were doing.

Martin


Cheers,
Joern

On 03/13/2013 08:32 PM, Martin Morgan wrote:
On 03/13/2013 04:02 AM, Joern Toedling wrote:
Hello,

I have encountered a strange issue with the plotting function in my package
"girafe" that I need some help with. I haven't changed anything in the plot
methods or the NAMESPACE of the package recently, and it worked before, yet I
observe the following error now.

When calling the "plot" method for objects of the class
"AlignedGenomeIntervals", rather than using the appropriate S4 method and
calling another function (plotAligned), R falls back to the S3 method
"plot.Intervals_full" (Intervals_full is the class that AlignedGenomeIntervals
indirectly inherits from). Please see below for the sessionInfo() output.

Has anybody encountered the same behaviour or any insights what might be going
on? I'm grateful for any suggestions what I could fix in the method definition
and/or the NAMESPACE. I guess as a workaround I could add an S3 plot method for
the "AlignedGenomeIntervals" calls but that would be rather ugly.

I think this is a bug in S4, triggered by complex relations between the
intervals and girafe package. I'll pursue this on R-devel.

I can reproduce this with a PkgA that has DESCRIPTION with

Depends: intervals
Imports: graphics

NAMESPACE:

importFrom(graphics, "plot")
export("plot")
exportMethods("plot")

R/tmp.R

setClass("A")
setMethod("plot", "A", function(x, y, ...) {})


and then

> library(PkgA)
Loading required package: intervals
> plot
function (x, y, ...)
UseMethod("plot")
<environment: namespace:graphics>

notice that 'plot' is reported as an S3 generic, but should be an S4 generic.

Removing Depends: intervals or changing to importsFrom(intervals, "plot")
recovers S4 export

> library(PkgA)
Loading required package: intervals
> plot
standardGeneric for "plot" defined from package "graphics"

function (x, y, ...)
standardGeneric("plot")
<environment: 0x60aea90>
Methods may be defined for arguments: x, y
Use  showMethods("plot")  for currently available ones.


The 'intervals' package Depends: on methods but nothing else. It defines S3
and S4 methods on plot, creating an implicit S4 generic in the process. It's
NAMESPACE has

S3method( "plot", "Intervals" )
S3method( "plot", "Intervals_full" )
exportMethods("plot")

and we have

> library(intervals)
> plot
standardGeneric for "plot" defined from package "graphics"

function (x, y, ...)
standardGeneric("plot")
<environment: 0x68cdc78>
Methods may be defined for arguments: x, y
Use  showMethods("plot")  for currently available ones.






Thanks in advance,
Joern


 > sessionInfo()
R Under development (unstable) (2013-03-12 r62224)
Platform: x86_64-unknown-linux-gnu (64-bit)
...
other attached packages:
  [1] org.Mm.eg.db_2.9.0     RSQLite_0.11.2 DBI_0.2-5
  [4] AnnotationDbi_1.21.13  Biobase_2.19.3 girafe_1.11.2
  [7] genomeIntervals_1.15.1 intervals_0.14.0 ShortRead_1.17.10
[10] latticeExtra_0.6-24    RColorBrewer_1.0-5 lattice_0.20-13
[13] Rsamtools_1.11.21      Biostrings_2.27.11 GenomicRanges_1.11.36
[16] IRanges_1.17.37        BiocGenerics_0.5.6 BiocInstaller_1.9.7

loaded via a namespace (and not attached):
[1] bitops_1.0-5    BSgenome_1.27.1 hwriter_1.3     stats4_3.1.0
[5] tcltk_3.1.0     tools_3.1.0     zlibbioc_1.5.0


Example producing the error:

library("girafe")
example("plotAligned")



--
Computational Biology / Fred Hutchinson Cancer Research Center
1100 Fairview Ave. N.
PO Box 19024 Seattle, WA 98109

Location: Arnold Building M1 B861
Phone: (206) 667-2793

_______________________________________________
Bioc-devel@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/bioc-devel

Reply via email to