[Bioc-devel] Problem with generic methods name conflicts
Martin Morgan
mtmorgan at fhcrc.org
Thu Oct 13 18:52:45 CEST 2011
On 10/13/2011 08:04 AM, Herb Holyst wrote:
> Hi,
>
> I am hoping someone can point me in the right direction. I received a courtesy message from the Marc Carlson the our package flowFP had compilation errors, and after a bit of poking I discovered the Biobase added a new generic method called 'counts' which we had previously defined in flowFP. Since our package depends on Biobase we have a name collision.
>
> Here is the definition of our 'counts' generic out of flowFP's AllGenerics.R file:
> ## =========================================================================
> ## counts Methods.
> ## - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> if (!isGeneric("counts")) {
> setGeneric("counts", function(object, ...) standardGeneric("counts"))
> }
I think that this construct pre-dates name spaces; it's weird (to me) to
define a method on a generic that one doesn't know about, e.g., maybe
'counts' is documented to return a vector of European nobleman. It also
implies that 'counts' is found on the user search path rather than in
the package name space, so sometimes the intended counts is found,
sometimes not.
These days I think that one would importFrom(Biobase, counts) and then
setMethod on the known generic (if Biobase has an appropriate counts
generic) or create a new generic (which I think would not normally be
the case).
A secondary question that quickly comes up is how to make the user aware
of the generic 'counts'.
On the one hand (I think this is the usual solution) it might be
appropriate to (in the DESCRIPTION file)
Depends: Biobase
Imports: Biobase
and (in the NAMESPACE file)
importFrom(Biobase, counts)
exportMethods(counts)
which arranges for the counts generic from Biobase to be available to
you for attaching methods, and to the user via the standard search path,
and for the methods defined in your package to be associated with that
generic.
On a second hand one might think that, while your package has a use for
some-of-Biobase, the user does not have a use for all-of-Biobase so
Imports: Biobase
and
importFrom(Biobase, counts)
export(counts)
which allows you to add your methods to Biobase::counts, then passes
Biobase::counts through to be visible to the user. This seems awkward;
it requires that you document the 'counts' generic (you're the one
making it available to the user) even though the generic is in Biobase.
The motivation for not attaching Biobase to the search path is probably
part of the motivation for a BiocGenerics class -- too much clutter for
the user.
On the third hand one might forgo Biobase entirely (neither Depends: nor
Imports:), define a generic counts in your own package and export that.
Let the user disambiguate if they happen to load Biobase in addition to
your package. For disparate data types and questions this might be
appropriate, but for data types shared by different packages it
unfortunately leads to a multiplication of classes and a confusion of
interfaces.
On the fourth hand, perhaps your package has a use for some of Biobase
but the user does not. So Imports: and importFrom, with no exports.
There are likely to be other hands.
Martin
>
> setMethod("counts",
> signature=signature(object="flowFP"),
> definition=getFPCounts)
>
> setMethod("counts",
> signature=signature(object="flowFPPlex"),
> definition=function(object, ...) {
> cnts = matrix(0, nrow=nInstances(object), ncol=0)
> for(fp in object at fingerprints)
> cnts = cbind(cnts, counts(fp, ...))
> return(cnts)
> }
> )
>
> With my limited knowledge the only solution I come up with is to change flowFP's method name from 'counts' to something else like 'nCounts'. This is unsettling, and I would think there must be a way to tell the dispatcher how to differentiate the two calls by code signature, but so far I am finding nothing that talks about this, at least in terms that I can comprehend.
>
> Can anyone suggest a possible solution or work around for this issue?
>
> Here is the output of my attempt to build flowFP with the latest version of Biobase. (Renaming the 'counts' method results in a error free build.)
>
> [devel]$ R CMD build flowFP
> [1] "en_US.iso885915"
> Thu Oct 13 10:51:56 2011
> Hello Herb!
> * checking for file 'flowFP/DESCRIPTION' ... OK
> * preparing 'flowFP':
> * checking DESCRIPTION meta-information ... OK
> * cleaning src
> * running 'cleanup'
> * installing the package to re-build vignettes
> -----------------------------------
> [1] "en_US.iso885915"
> Thu Oct 13 10:51:57 2011
> Hello Herb!
> * installing *source* package 'flowFP' ...
> configure: creating ./config.status
> config.status: creating src/Makevars
> ** libs
> gcc -std=gnu99 -I/usr/local/lib64/R/include -I/usr/local/include -fpic -g -O2 -c flowFP.c -o flowFP.o
> gcc -std=gnu99 -I/usr/local/lib64/R/include -I/usr/local/include -fpic -g -O2 -c init.c -o init.o
> gcc -std=gnu99 -I/usr/local/lib64/R/include -I/usr/local/include -fpic -g -O2 -c split_utils.c -o split_utils.o
> gcc -std=gnu99 -shared -L/usr/local/lib64 -o flowFP.so flowFP.o init.o split_utils.o
> installing to /tmp/RtmpNOOuIP/Rinst594ef86a/flowFP/libs
> ** R
> ** data
> ** inst
> ** preparing package for lazy loading
> Scalable Robust Estimators with High Breakdown Point (version 1.3-01)
> Warning: replacing previous import '.__C__character' when loading 'methods'
> Error in match.call(definition, call, expand.dots) :
> unused argument(s) (object = c("flowFP", "flowFP"))
> Error : unable to load R code in package 'flowFP'
> ERROR: lazy loading failed for package 'flowFP'
> * removing '/tmp/RtmpNOOuIP/Rinst594ef86a/flowFP'
> -----------------------------------
> ERROR: package installation failed
>
>
> Thanks in advance,
> Herb
>
> Herb Holyst
> Path BioResearch
> University of Pennsylvania
>
>
> [[alternative HTML version deleted]]
>
> _______________________________________________
> Bioc-devel at r-project.org mailing list
> https://stat.ethz.ch/mailman/listinfo/bioc-devel
--
Computational Biology
Fred Hutchinson Cancer Research Center
1100 Fairview Ave. N. PO Box 19024 Seattle, WA 98109
Location: M1-B861
Telephone: 206 667-2793
More information about the Bioc-devel
mailing list