ABCDEFGHIJKLMNOPQRSTUVWXYZ

UpVar

Tcl_UpVar(3)                Tcl Library Procedures                Tcl_UpVar(3)



______________________________________________________________________________

NAME
       Tcl_UpVar, Tcl_UpVar2 - link one variable to another

SYNOPSIS
       #include <tcl.h>

       int
       Tcl_UpVar(interp, frameName, sourceName, destName, flags)

       int
       Tcl_UpVar2(interp, frameName, name1, name2, destName, flags)

ARGUMENTS
       Tcl_Interp         *interp          (in)      Interpreter    containing
                                                     variables;  also used for
                                                     error reporting.

       char               *frameName       (in)      Identifies    the   stack
                                                     frame  containing  source
                                                     variable.   May  have any
                                                     of the forms accepted  by
                                                     the  upvar  command, such
                                                     as #0 or 1.

       char               *sourceName      (in)      Name of source  variable,
                                                     in  the  frame  given  by
                                                     frameName.  May refer  to
                                                     a  scalar  variable or to
                                                     an array variable with  a
                                                     parenthesized index.

       char               *destName        (in)      Name of destination vari-
                                                     able,  which  is  to   be
                                                     linked to source variable
                                                     so  that  references   to
                                                     destName   refer  to  the
                                                     other variable.  Must not
                                                     currently exist except as
                                                     an upvar-ed variable.

       int                flags            (in)      Either TCL_GLOBAL_ONLY or
                                                     0;    if  non-zero,  then
                                                     destName  is   a   global
                                                     variable;   otherwise  it
                                                     is a local to the current
                                                     procedure  (or  global if
                                                     no procedure is  active).

       char               *name1           (in)      First   part   of  source
                                                     variable's  name  (scalar
                                                     name,  or  name  of array
                                                     without array index).

       char               *name2           (in)      If source variable is  an
                                                     element   of   an  array,
                                                     gives the  index  of  the
                                                     element.     For   scalar
                                                     source   variables,    is
                                                     NULL.
_________________________________________________________________


DESCRIPTION
       Tcl_UpVar  and  Tcl_UpVar2  provide the same functionality as the upvar
       command:  they make a link from a  source  variable  to  a  destination
       variable,  so  that  references to the destination are passed transpar-
       ently through to the source.  The name of the source  variable  may  be
       specified  either  as  a single string such as xyx or a(24) (by calling
       Tcl_UpVar) or in two parts where the array name has been separated from
       the  element  name  (by  calling Tcl_UpVar2).  The destination variable
       name is specified in a single string;  it may not be an array  element.

       Both  procedures  return  either TCL_OK or TCL_ERROR, and they leave an
       error message in the interpreter's result if an error occurs.

       As with the upvar command, the source variable need not  exist;  if  it
       does exist, unsetting it later does not destroy the link.  The destina-
       tion variable may exist at the time of the call,  but  if  so  it  must
       exist as a linked variable.


KEYWORDS
       linked variable, upvar, variable



Tcl                                   7.4                         Tcl_UpVar(3)