getClass               package:methods               R Documentation

_G_e_t _C_l_a_s_s _D_e_f_i_n_i_t_i_o_n

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

     Get the definition of a class.

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

     getClass(Class, .Force = FALSE, where)
     getClassDef(Class, where, package)

_A_r_g_u_m_e_n_t_s:

   Class: the character-string name of the class.

  .Force: if 'TRUE', return 'NULL' if the class is undefined;
          otherwise, an undefined class results in an error.

   where: environment from which to begin the search for the
          definition; by default, start at the top-level (global)
          environment and proceed through the search list.

 package: the name of the package asserted to hold the definition. 
          Supplied instead of 'where', with the distinction that the
          package need not be currently attached.

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

     A call to 'getClass' returns the complete definition of the class
     supplied as a string, including all slots, etc. in classes that
     this class extends.  A call to 'getClassDef' returns the
     definition of the class from the environment 'where', unadorned. 
     It's usually 'getClass' you want.

     If you really want to know whether a class is formally defined,
     call 'isClass'.

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

     The object defining the class.  This is an object of class
     '"classRepEnvironment"'.  However, _do not_ deal with the contents
     of the object directly unless you are very sure you know what
     you're doing.  Even then, it is nearly always better practice to
     use functions such as 'setClass' and 'setIs'. Messing up a class
     object will cause great confusion.

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

     The R package 'methods' implements, with a few exceptions, the
     programming interface for classes and methods in the book
     _Programming with Data_ (John M. Chambers, Springer, 1998), in
     particular sections 1.6, 2.7, 2.8, and chapters 7 and 8.

     While the programming interface for the methods package follows
     the reference, the R software is an original implementation, so
     details in the reference that reflect the S4 implementation may
     appear differently in R.  Also, there are extensions to the
     programming interface developed more recently than the reference. 
     For a discussion of details and ongoing development, see the web
     page <URL: http://developer.r-project.org/methodsPackage.html> and
     the pointers from that page.

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

     Classes, 'setClass', 'isClass'.

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

     getClass("numeric") ## a built in class

     cld <- getClass("thisIsAnUndefinedClass", .Force = TRUE)
     cld ## a NULL prototype
     ## If you are really curious:
     str(cld)
     ## Whereas these generate errors:
     try(getClass("thisIsAnUndefinedClass"))
     try(getClassDef("thisIsAnUndefinedClass"))

