Initial release
This commit is contained in:
		
							
								
								
									
										194
									
								
								hlp/en/tcl/Tcl.htm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										194
									
								
								hlp/en/tcl/Tcl.htm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,194 @@ | ||||
| <HTML><HEAD><TITLE>Tcl Built-In Commands - Tcl manual page</TITLE></HEAD><BODY> | ||||
| <DL> | ||||
| <DD><A HREF="Tcl.htm#M2" NAME="L2">NAME</A> | ||||
| <DL><DD>Tcl - Summary of Tcl language syntax.</DL> | ||||
| <DD><A HREF="Tcl.htm#M3" NAME="L3">DESCRIPTION</A> | ||||
| <DL> | ||||
| <DL> | ||||
| <DD><A HREF="Tcl.htm#M4" NAME="L4"><B>$</B><I>name</I></A> | ||||
| <DD><A HREF="Tcl.htm#M5" NAME="L5"><B>$</B><I>name</I><B>(</B><I>index</I><B>)</B></A> | ||||
| <DD><A HREF="Tcl.htm#M6" NAME="L6"><B>${</B><I>name</I><B>}</B></A> | ||||
| </DL> | ||||
| <DL> | ||||
| <DD><A HREF="Tcl.htm#M7" NAME="L7">\<B>a</B></A> | ||||
| <DD><A HREF="Tcl.htm#M8" NAME="L8">\<B>b</B></A> | ||||
| <DD><A HREF="Tcl.htm#M9" NAME="L9">\<B>f</B></A> | ||||
| <DD><A HREF="Tcl.htm#M10" NAME="L10">\<B>n</B></A> | ||||
| <DD><A HREF="Tcl.htm#M11" NAME="L11">\<B>r</B></A> | ||||
| <DD><A HREF="Tcl.htm#M12" NAME="L12">\<B>t</B></A> | ||||
| <DD><A HREF="Tcl.htm#M13" NAME="L13">\<B>v</B></A> | ||||
| <DD><A HREF="Tcl.htm#M14" NAME="L14">\<B><newline></B><I>whiteSpace</I></A> | ||||
| <DD><A HREF="Tcl.htm#M15" NAME="L15">\\</A> | ||||
| <DD><A HREF="Tcl.htm#M16" NAME="L16">\<I>ooo</I></A> | ||||
| <DD><A HREF="Tcl.htm#M17" NAME="L17">\<B>x</B><I>hh</I></A> | ||||
| <DD><A HREF="Tcl.htm#M18" NAME="L18">\<B>u</B><I>hhhh</I></A> | ||||
| </DL> | ||||
| </DL> | ||||
| </DL><HR> | ||||
| <H3><A NAME="M2">NAME</A></H3> | ||||
| Tcl - Summary of Tcl language syntax. | ||||
| <H3><A NAME="M3">DESCRIPTION</A></H3> | ||||
| The following rules define the syntax and semantics of the Tcl language: | ||||
| <P> | ||||
| <DL> | ||||
| <P><DT>[1]<DD> | ||||
| A Tcl script is a string containing one or more commands. | ||||
| Semi-colons and newlines are command separators unless quoted as | ||||
| described below. | ||||
| Close brackets are command terminators during command substitution | ||||
| (see below) unless quoted. | ||||
| <P><DT>[2]<DD> | ||||
| A command is evaluated in two steps. | ||||
| First, the Tcl interpreter breaks the command into <I>words</I> | ||||
| and performs substitutions as described below. | ||||
| These substitutions are performed in the same way for all | ||||
| commands. | ||||
| The first word is used to locate a command procedure to | ||||
| carry out the command, then all of the words of the command are | ||||
| passed to the command procedure. | ||||
| The command procedure is free to interpret each of its words | ||||
| in any way it likes, such as an integer, variable name, list, | ||||
| or Tcl script. | ||||
| Different commands interpret their words differently. | ||||
| <P><DT>[3]<DD> | ||||
| Words of a command are separated by white space (except for | ||||
| newlines, which are command separators). | ||||
| <P><DT>[4]<DD> | ||||
| If the first character of a word is double-quote (``"'') then | ||||
| the word is terminated by the next double-quote character. | ||||
| If semi-colons, close brackets, or white space characters | ||||
| (including newlines) appear between the quotes then they are treated | ||||
| as ordinary characters and included in the word. | ||||
| Command substitution, variable substitution, and backslash substitution | ||||
| are performed on the characters between the quotes as described below. | ||||
| The double-quotes are not retained as part of the word. | ||||
| <P><DT>[5]<DD> | ||||
| If the first character of a word is an open brace (``{'') then | ||||
| the word is terminated by the matching close brace (``}''). | ||||
| Braces nest within the word: for each additional open | ||||
| brace there must be an additional close brace (however, | ||||
| if an open brace or close brace within the word is | ||||
| quoted with a backslash then it is not counted in locating the | ||||
| matching close brace). | ||||
| No substitutions are performed on the characters between the | ||||
| braces except for backslash-newline substitutions described | ||||
| below, nor do semi-colons, newlines, close brackets, | ||||
| or white space receive any special interpretation. | ||||
| The word will consist of exactly the characters between the | ||||
| outer braces, not including the braces themselves. | ||||
| <P><DT>[6]<DD> | ||||
| If a word contains an open bracket (``['') then Tcl performs | ||||
| <I>command substitution</I>. | ||||
| To do this it invokes the Tcl interpreter recursively to process | ||||
| the characters following the open bracket as a Tcl script. | ||||
| The script may contain any number of commands and must be terminated | ||||
| by a close bracket (``]''). | ||||
| The result of the script (i.e. the result of its last command) is | ||||
| substituted into the word in place of the brackets and all of the | ||||
| characters between them. | ||||
| There may be any number of command substitutions in a single word. | ||||
| Command substitution is not performed on words enclosed in braces. | ||||
| <P><DT>[7]<DD> | ||||
| If a word contains a dollar-sign (``$'') then Tcl performs <I>variable | ||||
| substitution</I>:  the dollar-sign and the following characters are | ||||
| replaced in the word by the value of a variable. | ||||
| Variable substitution may take any of the following forms: | ||||
| <P> | ||||
| <DL> | ||||
| <P><DT><A NAME="M4"><B>$</B><I>name</I></A><DD> | ||||
| <I>Name</I> is the name of a scalar variable;  the name is terminated | ||||
| by any character that isn't a letter, digit, or underscore. | ||||
| <P><DT><A NAME="M5"><B>$</B><I>name</I><B>(</B><I>index</I><B>)</B></A><DD> | ||||
| <I>Name</I> gives the name of an array variable and <I>index</I> gives | ||||
| the name of an element within that array. | ||||
| <I>Name</I> must contain only letters, digits, and underscores. | ||||
| Command substitutions, variable substitutions, and backslash | ||||
| substitutions are performed on the characters of <I>index</I>. | ||||
| <P><DT><A NAME="M6"><B>${</B><I>name</I><B>}</B></A><DD> | ||||
| <I>Name</I> is the name of a scalar variable.  It may contain any | ||||
| characters whatsoever except for close braces. | ||||
| </DL><P>There may be any number of variable substitutions in a single word. | ||||
| Variable substitution is not performed on words enclosed in braces.<DL> | ||||
| <P></DL> | ||||
| <P><DT>[8]<DD> | ||||
| If a backslash (``\'') appears within a word then | ||||
| <I>backslash substitution</I> occurs. | ||||
| In all cases but those described below the backslash is dropped and | ||||
| the following character is treated as an ordinary | ||||
| character and included in the word. | ||||
| This allows characters such as double quotes, close brackets, | ||||
| and dollar signs to be included in words without triggering | ||||
| special processing. | ||||
| The following table lists the backslash sequences that are | ||||
| handled specially, along with the value that replaces each sequence. | ||||
| <P> | ||||
| <DL> | ||||
| <P><DT><A NAME="M7">\<B>a</B></A><DD> | ||||
| Audible alert (bell) (0x7). | ||||
| <P><DT><A NAME="M8">\<B>b</B></A><DD> | ||||
| Backspace (0x8). | ||||
| <P><DT><A NAME="M9">\<B>f</B></A><DD> | ||||
| Form feed (0xc). | ||||
| <P><DT><A NAME="M10">\<B>n</B></A><DD> | ||||
| Newline (0xa). | ||||
| <P><DT><A NAME="M11">\<B>r</B></A><DD> | ||||
| Carriage-return (0xd). | ||||
| <P><DT><A NAME="M12">\<B>t</B></A><DD> | ||||
| Tab (0x9). | ||||
| <P><DT><A NAME="M13">\<B>v</B></A><DD> | ||||
| Vertical tab (0xb). | ||||
| <P><DT><A NAME="M14">\<B><newline></B><I>whiteSpace</I></A><DD> | ||||
| A single space character replaces the backslash, newline, and all spaces | ||||
| and tabs after the newline.  This backslash sequence is unique in that it | ||||
| is replaced in a separate pre-pass before the command is actually parsed. | ||||
| This means that it will be replaced even when it occurs between braces, | ||||
| and the resulting space will be treated as a word separator if it isn't | ||||
| in braces or quotes. | ||||
| <P><DT><A NAME="M15">\\</A><DD> | ||||
| Backslash (``\''). | ||||
| <P><DT><A NAME="M16">\<I>ooo</I></A><DD> | ||||
| The digits <I>ooo</I> (one, two, or three of them) give an eight-bit octal  | ||||
| value for the Unicode character that will be inserted.  The upper bits of the | ||||
| Unicode character will be 0. | ||||
| <P><DT><A NAME="M17">\<B>x</B><I>hh</I></A><DD> | ||||
| The hexadecimal digits <I>hh</I> give an eight-bit hexadecimal value for the | ||||
| Unicode character that will be inserted.  Any number of hexadecimal digits | ||||
| may be present; however, all but the last two are ignored (the result is | ||||
| always a one-byte quantity).  The upper bits of the Unicode character will | ||||
| be 0. | ||||
| <P><DT><A NAME="M18">\<B>u</B><I>hhhh</I></A><DD> | ||||
| The hexadecimal digits <I>hhhh</I> (one, two, three, or four of them) give a | ||||
| sixteen-bit hexadecimal value for the Unicode character that will be | ||||
| inserted. | ||||
| </DL><P>Backslash substitution is not performed on words enclosed in braces, | ||||
| except for backslash-newline as described above.<DL> | ||||
| <P></DL> | ||||
| <P><DT>[9]<DD> | ||||
| If a hash character (``#'') appears at a point where Tcl is | ||||
| expecting the first character of the first word of a command, | ||||
| then the hash character and the characters that follow it, up | ||||
| through the next newline, are treated as a comment and ignored. | ||||
| The comment character only has significance when it appears | ||||
| at the beginning of a command. | ||||
| <P><DT>[10]<DD> | ||||
| Each character is processed exactly once by the Tcl interpreter | ||||
| as part of creating the words of a command. | ||||
| For example, if variable substitution occurs then no further | ||||
| substitutions are performed on the value of the variable;  the | ||||
| value is inserted into the word verbatim. | ||||
| If command substitution occurs then the nested command is | ||||
| processed entirely by the recursive call to the Tcl interpreter; | ||||
| no substitutions are performed before making the recursive | ||||
| call and no additional substitutions are performed on the result | ||||
| of the nested script. | ||||
| <P><DT>[11]<DD> | ||||
| Substitutions do not affect the word boundaries of a command. | ||||
| For example, during variable substitution the entire value of | ||||
| the variable becomes part of a single word, even if the variable's | ||||
| value contains spaces. | ||||
| <P></DL> | ||||
| <HR><PRE> | ||||
| <A HREF="../copyright.htm">Copyright</A> © 1993 The Regents of the University of California. | ||||
| <A HREF="../copyright.htm">Copyright</A> © 1994-1996 Sun Microsystems, Inc. | ||||
| <A HREF="../copyright.htm">Copyright</A> © 1995-1997 Roger E. Critchlow Jr.</PRE> | ||||
| </BODY></HTML> | ||||
		Reference in New Issue
	
	Block a user
	 unknown
					unknown