bindenv                 package:base                 R Documentation

_B_i_n_d_i_n_g _a_n_d _E_n_v_i_r_o_n_m_e_n_t _A_d_j_u_s_t_m_e_n_t_s

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

     These functions represent an experimental interface for
     adjustments to environments and bindings within environments. 
     They allow for locking environments as well as individual
     bindings, and for linking a variable to a function.

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

     lockEnvironment(env, bindings = FALSE)
     environmentIsLocked(env)
     lockBinding(sym, env)
     unlockBinding(sym, env)
     bindingIsLocked(sym, env)
     makeActiveBinding(sym, fun, env)
     bindingIsActive(sym, env)

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

     env: an environment.

bindings: logical specifying whether bindings should be locked.

     sym: a name object or character string

     fun: a function taking zero or one arguments

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

     The function 'lockEnvironment' locks its environment argument,
     which must be a normal environment (not base).  (Locking the base
     environment and name space may be supported later.)  Locking the
     environment prevents adding or removing variable bindings from the
     environment. Changing the value of a variable is still possible
     unless the binding has been locked.  The name space environments
     of packages with name spaces are locked when loaded.

     'lockBinding' locks individual bindings in the specified
     environment.  The value of a locked binding cannot be changed.
     Locked bindings may be removed from an environment unless the
     environment is locked.

     'makeActiveBinding' installs 'fun' so that getting the value of
     'sym' calls 'fun' with no arguments, and assigning to 'sym' calls
     'fun' with one argument, the value to be assigned.  This allows
     the implementation of things like C variables linked to R
     variables and variables linked to databases.  It may also be
     useful for making thread-safe versions of some system globals.

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

     The '*isLocked' funtions return a length-one logical vector.  The
     remaining functions return 'NULL', invisibly.

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

     Luke Tierney

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

     # locking environments
     e <- new.env()
     assign("x", 1, envir = e)
     get("x", envir = e)
     lockEnvironment(e)
     get("x", envir = e)
     assign("x", 2, envir = e)
     try(assign("y", 2, envir = e)) # error

     # locking bindings
     e <- new.env()
     assign("x", 1, envir = e)
     get("x", envir = e)
     lockBinding("x", e)
     try(assign("x", 2, envir = e)) # error
     unlockBinding("x", e)
     assign("x", 2, envir = e)
     get("x", envir = e)

     # active bindings
     f <- local( {
         x <- 1
         function(v) {
            if (missing(v))
                cat("get\n")
            else {
                cat("set\n")
                x <<- v
            }
            x
         }
     })
     makeActiveBinding("fred", f, .GlobalEnv)
     bindingIsActive("fred", .GlobalEnv)
     fred
     fred <- 2
     fred

