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
     'classRepresentation'.  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:

     Chambers, John M. (2008) _Software for Data Analysis: Programming
     with R_ Springer.  (For the R version.)

     Chambers, John M. (1998) _Programming with Data_ Springer (For the
     original S4 version.)

_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:
     utils::str(cld)
     ## Whereas these generate errors:
     try(getClass("thisIsAnUndefinedClass"))
     try(getClassDef("thisIsAnUndefinedClass"))

