Martin Maechler <[EMAIL PROTECTED]> a écrit :
"CG" == Christophe Genolini <[EMAIL PROTECTED]>
on Sun, 27 Jul 2008 09:27:34 +0200 writes:
CG> Martin Maechler <[EMAIL PROTECTED]> a écrit :
>>>>>>> "CG" == Christophe Genolini <[EMAIL PROTECTED]>
>>>>>>> on Sat, 26 Jul 2008 12:12:12 +0200 writes:
>>
CG> Martin Maechler <[EMAIL PROTECTED]> a écrit :
>> >>>>>>> "CG" == Christophe Genolini <[EMAIL PROTECTED]>
>> >>>>>>> on Tue, 22 Jul 2008 19:04:37 +0200 writes:
>> >>
CG> Prof Brian Ripley <[EMAIL PROTECTED]> a écrit :
>> >> >> On Tue, 22 Jul 2008, [EMAIL PROTECTED] wrote:
>> >> >>
>> >> >>> Hi the list (well, half of the list, only the one who
>> >> >>> are not on holidays...)
>> >> >>>
>> >> >>> I am trying to make an S4 package. When I run it on a
>> >> >>> console, everything seems ok. When I run R CMD check, I
>> >> >>> got an error --- 8<
>> >> >>> ----------------------
>> >> >>> Error in setMethod("plot", "ClassX", function(x, y) { :
>> >> >>> no existing definition for function "plot" --- 8<
>> >> >>> ----------------------
>> >> >>>
>> >> >>> If I add
>> >> >>> setGeneric("plot",function(x,y,...){standardGeneric("plot")})
>> >> >>> in my code, then everything is OK.
>> >> >>>
>> >> >>> This is a surprise for me since I taught that we do not
>> >> >>> need to redefine as generic the function that are
>> >> >>> already generic, like "plot". Am I wrong ?
>> >> >>
>> >> >> Yes. And do read the error message. It says
>> >> >>
>> >> >> no existing definition for function "plot"
>> >> >>
>> >> >> so this is not if the function is S3 or S4 generic, but
>> >> >> that no such function is visible.
>> >> >>
>> >> >> Looks like you forgot to declare a dependence on (or
>> >> >> import) package graphics.
>> >>
CG> I would have forgot if I knew that I have to declare
CG> such a dependence... Do we have to declare all the
CG> depence to all the package ? To base ? To stats ?
>> >>
>> >> not to base, but to all other packages (since R can be loaded
>> >> without any packages but base).
>> >>
CG> I thaught that the package that are include in R when we
CG> start it had not to be include.
>> >>
>> >> You thought wrongly, and all our documentation mentions that you
>> >> need to use 'Depends:' correctly (and 'Imports(..)' in
>> >> NAMESPACE if you make use of one).
>> >>
>> >> {and please strongly note the correct spelling of "thought" !}
>> >>
>> >> Martin
>>
CG> I correct DESCRIPTION and NAMESPACE adding Depends and import.
CG> But I still get the message :
>>
CG> checking for missing documentation entries ... WARNING
CG> Undocumented S4 methods:
CG> generic 'plot' and siglist 'ClassX'
>>
CG> I can't find what is wrong...
>>
>> well, it's a message about *documentation*
>> and therefore not related to DESCRIPTION
>> and not much related to NAMESPACE.
>>
>> It tells you that you don't have correct documentation for the
>> plot method for ClassX.
CG> What if I don't want to document this method? I did not put ClassX in
CG> the export, I do not want the user to acces to it.
CG> I want :
CG> plot,ClassX-method -> private
CG> ClassY-class -> public
CG> plot,ClassY-method -> public
CG> Is it possible ?
Yes, it is.
Excuse me not having read your previous posting in full detail.
So what you see is a warning in 'R CMD check' that is a so
called "false positive", i.e. warning in a case it should not.
Indeed, we have to acknowledge that the "R CMD check"ing code
in the context of "S4 + NAMESPACE" has not been perfect
recently... and the above is a good test case for improving the
"checking code".
BTW: I have recently started to look into using a few dummy
packages as part of the R-internal 'make check' checks.
Consequently, I'd be quite happy if you could provide (me or
R-devel) with the full packS4_0.5.tar.gz example package
{and maybe other versions of that}.
Merci, Christophe, for your perseverance!
Martin
Thanks for your explanation.
About "packS4", I am curently writing a tutorial on S4 packaging (I am
adding a part on "S4 package" to the tutorial "A (Not So) Short
Introduction to S4" already on the net).
packS4 comes as an illustrative example for this tutorial. The tutorial
is almost over, I just need to understand what is wrong with my tests
files and I post it. Do you want it now (with bugs in the tests
directory) or do you want the final version ?
Christophe
CG> Christophe
--> "Writing R Extensions",
>> section 2.1.3 'Documenting S4 classes and methods'
>>
>> Regards,
>> Martin
>>
CG> ----- DESCRIPTION ----- Package: packS4
CG> Type: Package
CG> Title: Toy example of S4 package
CG> Version: 0.5
CG> Date: 2008-07-22
CG> Author: Christophe Genolini / INSERM U669
CG> Maintainer: <[EMAIL PROTECTED]>
CG> Description: Package built to illustration package
>> construction with S4
CG> License: GPL (>=2)
CG> LazyLoad: yes
CG> Depends: methods, graphics
CG> Collate: global.R ClassX.R ClassY.R ClassX-ClassY.R ClassZ.R
>>
>>
CG> ------ NAMESPACE ------
CG> export(
CG> "classZ",
CG> "functionClassicA"
CG> )
CG> exportMethods(
CG> "getZ1",
CG> "setZ1<-",
CG> "publicA",
CG> "plot"
CG> )
CG> exportClasses(
CG> "ClassY",
CG> "ClassZ"
CG> )
>>
CG> import(graphics)
>>
CG> Christophe
>>
>>
>>
>>
CG> ----------------------------------------------------------------
CG> Ce message a ete envoye par IMP, grace a l'Universite Paris 10
>> Nanterre
>>
>>
>>
CG> ______________________________________________
CG> R-help@r-project.org mailing list
CG> https://stat.ethz.ch/mailman/listinfo/r-help
CG> PLEASE do read the posting guide
http://www.R-project.org/posting-guide.html
CG> and provide commented, minimal, self-contained, reproducible code.
______________________________________________
R-help@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.