R/cmethods.R

# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
setGeneric( "setCMethod", function(f, sig, body, ...) standardGeneric("setCMethod") )

# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
setMethod( "setCMethod", signature(f="character", sig="list", body="list"),
  function(f, sig, body, includes="", otherdefs="",
           language=c("C++", "C", "Fortran", "F95", "ObjectiveC", "ObjectiveC++"),
           verbose=FALSE, convention=c(".Call", ".C", ".Fortran"),
           where=topenv(.GlobalEnv), ...) {
    if ( length(f) != length(sig) || length(sig) != length(body) )
      stop("number of signatures does not correspond to the number of code chunks")

    names(sig) <- f
    fns <- cfunction(sig, body, includes, otherdefs, language, verbose, convention)

    if ( verbose )
      cat("\nThe following methods are now defined:\n")
    ## Let's try to create generics
    for ( i in 1:length(f) ) {
      generic <- paste( "setGeneric(\"", f[i], "\", function(",
                        paste(names(sig[[i]]),collapse=", "), ") standardGeneric(\"",
                        f[i], "\"),where=where )", sep="")
      eval(parse(text=generic))
      setMethod(f[i], sig[[i]], fns[[i]], where=where)
      if ( verbose ) showMethods(f[i])
    }
  }
)

# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
setMethod( "setCMethod", signature(f="character", sig="character", body="character"),
  function(f, sig, body, includes="", otherdefs="", language=c("C++", "C", "Fortran", "F95", "ObjectiveC", "ObjectiveC++"),
                      verbose=FALSE, convention=c(".Call", ".C", ".Fortran"), where=topenv(.GlobalEnv), ...)
    setCMethod(f, list(sig), list(body), includes, otherdefs, language, verbose, convention, where=topenv(.GlobalEnv), ...)
)
eddelbuettel/inline documentation built on Feb. 2, 2024, 9:26 p.m.