callNextMethod            package:methods            R Documentation

_C_a_l_l _a_n _I_n_h_e_r_i_t_e_d _M_e_t_h_o_d

_D_e_s_c_r_i_p_t_i_o_n:

     A call to `callNextMethod' can only appear inside a method
     definition.  It then results in a call to the first inherited
     method after the current method, with the arguments to the current
     method passed down to the next method.  The value of that method
     call is the value of `callNextMethod'.

_U_s_a_g_e:

     callNextMethod()

_D_e_t_a_i_l_s:

     The definition of the first inherited method is that is the method
     which would have been called if the current method did not exist.
     This is more-or-less literally what happens: The current method is
     deleted from a copy of the methods for the current generic, and
     `selectMethod' is called to find the next method (the result is
     cached in a special object, so the search only typically happens
     once per session per combination of argument classes).

     It is also legal, and often useful, for the method called by
     `callNextMethod' to itself have a call to `callNextMethod'.  This
     works the same way, except that now two methods are deleted before
     selecting the next method, and so on for further nested calls to
     `callNextMethod'.

     The statement that the method is called with the current arguments
     is more precisely as follows.  Arguments that were missing in the
     current call are still missing (remember that `"missing"' is a
     valid class in a method signature).  For a formal argument, say
     `x', that appears in the original call, there is a corresponding
     argument in the next method call equivalent to ```x = x'''.  In
     effect, this means that the next method sees the same actual
     arguments, but arguments are evaluated only once.

_V_a_l_u_e:

     The value returned by the selected method.

_A_u_t_h_o_r(_s):

     John Chambers

_R_e_f_e_r_e_n_c_e_s:

     The web page <URL: http://www.omegahat.org/RSMethods/index.html>
     is the primary documentation.

     The functions in this package implement a facility for classes and
     methods as described in Programming with Data (John M. Chambers,
     Springer, 1998).  See this book for further details and examples.

_S_e_e _A_l_s_o:

     Methods for the general behavior of method dispatch

_E_x_a_m_p_l_e_s:

     ## some class definitions with simple inheritance
     setClass("B0" , representation(b0 = "numeric"))

     setClass("B1", "B0")

     setClass("B2", representation("B1", b2 = "logical"))

     ## and a rather silly function to illustrate callNextMethod

     f <- function(x) class(x)

     setMethod("f", "B0", function(x) c(x@b0, callNextMethod()))

     setMethod("f", "B2", function(x) c(x@b2, callNextMethod()))

     b2 <- new("B2", b2 = FALSE, b0 = 10)

     b1 <- new("B1", b0 = 2)

     f(b2)

     f(b1)

