ADC Home > Reference Library > Reference > Mac OS X > Mac OS X Man Pages

 

This document is a Mac OS X manual page. Manual pages are a command-line technology for providing documentation. You can view these manual pages locally using the man(1) command. These manual pages come from many different sources, and thus, have a variety of writing styles.

For more information about the manual page format, see the manual page for manpages(5).



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.

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

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

       CONST char         *destName        (in)      Name of destination variable, 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 dest-Name destName
                                                     Name is a global variable;  otherwise it is a local  to
                                                     the  current  procedure  (or  global if no procedure is
                                                     active).

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

       CONST 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  trans-parently transparently
       parently  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 sep-arated separated
       arated  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  inter-preter's interpreter's
       preter'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 destination 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)

Did this document help you?
Yes: Tell us what works for you.
It’s good, but: Report typos, inaccuracies, and so forth.
It wasn’t helpful: Tell us what would have helped.