getPackageName            package:methods            R Documentation

_T_h_e _N_a_m_e _a_s_s_o_c_i_a_t_e_d _w_i_t_h _a _G_i_v_e_n _P_a_c_k_a_g_e

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

     The functions below produce the package associated with a
     particular environment or position on the search list, or of the
     package containing a particular function.  They are primarily used
     to support computations that need to differentiate objects on
     multiple packages.

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

     getPackageName(where, create = TRUE)
     setPackageName(pkg, env)

     packageSlot(object)
     packageSlot(object) <- value

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

   where: the environment or position on the search list associated
          with the desired package.

  object: object providing a character string name, plus the package in
          which this object is to be found.

   value: the name of the package.

  create: flag, should a package name be created if none can be
          inferred?  If 'TRUE' and no non-empty package name is found,
          the current date and time are used as a package name, and a
          warning is issued. The created name is stored in the
          environment if that environment is not locked.

pkg, env: make the string in 'pkg' the internal package name for all
          computations that set class and method definitions in
          environment 'env'.

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

     Package names are normally installed during loading of the
     package, by the INSTALL script or by the 'library' function. 
     (Currently, the name is stored as the object '.packageName' but
     don't trust this for the future.)

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

     'packageName' returns the character-string name of the package
     (without the extraneous '"package:"' found in the search list).

     'packageSlot' returns or sets the package name slot (currently an
     attribute, not a formal slot, but this may change someday).

     'setPackageName' can be used to establish a package name in an
     environment that would otherwise not have one.  This allows you to
     create classes and/or methods in an arbitrary environment, but it
     is usually preferable to create packages by the standard R
     programming tools ('package.skeleton', etc.)

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

     'search'

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

     ## all the following usually return "base"
     getPackageName(length(search()))
     getPackageName(baseenv())
     getPackageName(asNamespace("base"))
     getPackageName("package:base")

