DOC HOME SITE MAP MAN PAGES GNU INFO SEARCH
 

set(n)




______________________________________________________________________________


NAME

       set - Read and write variables


SYNOPSIS

       set varName ?value?
_________________________________________________________________


DESCRIPTION

       Returns the value of variable varName.  If value is specified, then set
       the value of varName to value, creating a new variable if  one  doesn't
       already  exist,  and  return  its  value.   If varName contains an open
       parenthesis and ends with a close parenthesis, then  it  refers  to  an
       array  element:   the  characters before the first open parenthesis are
       the name of the array, and the characters between the  parentheses  are
       the index within the array.  Otherwise varName refers to a scalar vari-
       able.

       If varName includes namespace qualifiers  (in  the  array  name  if  it
       refers  to  an  array  element), or if varName is unqualified (does not
       include the names of any containing namespaces)  but  no  procedure  is
       active,  varName  refers  to a namespace variable resolved according to
       the rules described under NAME RESOLUTION in the namespace manual page.

       If  a  procedure  is  active  and  varName is unqualified, then varName
       refers to a parameter or local variable of the procedure,  unless  var-
       Name  was  declared  to  resolve differently through one of the global,
       variable or upvar commands.


EXAMPLES

       Store a random number in the variable r:
              set r [expr rand()]

       Store a short message in an array element:
              set anAry(msg) "Hello, World!"

       Store a short message in an array element specified by a variable:
              set elemName "msg"
              set anAry($elemName) "Hello, World!"

       Copy a value into the variable out from a variable whose name is stored
       in  the  vbl  (note  that  it is often easier to use arrays in practice
       instead of doing double-dereferencing):
              set in0 "small random"
              set in1 "large random"
              set vbl in[expr {rand() >= 0.5}]
              set out [set $vbl]


SEE ALSO

       expr(n),  global(n),   namespace(n),   proc(n),   trace(n),   unset(n),
       upvar(n), variable(n)


KEYWORDS

       read, write, variable

Tcl                                                                     set(n)

Man(1) output converted with man2html