Initial release
This commit is contained in:
		
							
								
								
									
										67
									
								
								hlp/en/tcl/unknown.htm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								hlp/en/tcl/unknown.htm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | ||||
| <HTML><HEAD><TITLE>Built-In Commands - unknown manual page</TITLE></HEAD><BODY> | ||||
| <H3><A NAME="M2">NAME</A></H3> | ||||
| unknown - Handle attempts to use non-existent commands | ||||
| <H3><A NAME="M3">SYNOPSIS</A></H3> | ||||
| <B>unknown </B><I>cmdName </I>?<I>arg arg ...</I>?<BR> | ||||
| <H3><A NAME="M4">DESCRIPTION</A></H3> | ||||
| This command is invoked by the Tcl interpreter whenever a script | ||||
| tries to invoke a command that doesn't exist.  The implementation | ||||
| of <B>unknown</B> isn't part of the Tcl core;  instead, it is a | ||||
| library procedure defined by default when Tcl starts up.  You | ||||
| can override the default <B>unknown</B> to change its functionality. | ||||
| <P> | ||||
| If the Tcl interpreter encounters a command name for which there | ||||
| is not a defined command, then Tcl checks for the existence of | ||||
| a command named <B>unknown</B>. | ||||
| If there is no such command, then the interpreter returns an | ||||
| error. | ||||
| If the <B>unknown</B> command exists, then it is invoked with | ||||
| arguments consisting of the fully-substituted name and arguments | ||||
| for the original non-existent command. | ||||
| The <B>unknown</B> command typically does things like searching | ||||
| through library directories for a command procedure with the name | ||||
| <I>cmdName</I>, or expanding abbreviated command names to full-length, | ||||
| or automatically executing unknown commands as sub-processes. | ||||
| In some cases (such as expanding abbreviations) <B>unknown</B> will | ||||
| change the original command slightly and then (re-)execute it. | ||||
| The result of the <B>unknown</B> command is used as the result for | ||||
| the original non-existent command. | ||||
| <P> | ||||
| The default implementation of <B>unknown</B> behaves as follows. | ||||
| It first calls the <B><A HREF="../TkCmd/library.htm">auto_load</A></B> library procedure to load the command. | ||||
| If this succeeds, then it executes the original command with its | ||||
| original arguments. | ||||
| If the auto-load fails then <B>unknown</B> calls <B><A HREF="../TkCmd/library.htm">auto_execok</A></B> | ||||
| to see if there is an executable file by the name <I>cmd</I>. | ||||
| If so, it invokes the Tcl <B><A HREF="../TkCmd/exec.htm">exec</A></B> command | ||||
| with <I>cmd</I> and all the <I>args</I> as arguments. | ||||
| If <I>cmd</I> can't be auto-executed, <B>unknown</B> checks to | ||||
| see if the command was invoked at top-level and outside of any | ||||
| script.  If so, then <B>unknown</B> takes two additional steps. | ||||
| First, it sees if <I>cmd</I> has one of the following three forms: | ||||
| <B>!!</B>, <B>!</B><I>event</I>, or <B>^</B><I>old</I><B>^</B><I>new</I>?<B>^</B>?. | ||||
| If so, then <B>unknown</B> carries out history substitution | ||||
| in the same way that <B>csh</B> would for these constructs. | ||||
| Finally, <B>unknown</B> checks to see if <I>cmd</I> is | ||||
| a unique abbreviation for an existing Tcl command. | ||||
| If so, it expands the command name and executes the command with | ||||
| the original arguments. | ||||
| If none of the above efforts has been able to execute | ||||
| the command, <B>unknown</B> generates an error return. | ||||
| If the global variable <B>auto_noload</B> is defined, then the auto-load | ||||
| step is skipped. | ||||
| If the global variable <B>auto_noexec</B> is defined then the | ||||
| auto-exec step is skipped. | ||||
| Under normal circumstances the return value from <B>unknown</B> | ||||
| is the return value from the command that was eventually | ||||
| executed. | ||||
|  | ||||
| <H3><A NAME="M5">SEE ALSO</A></H3> | ||||
| <B><A HREF="../TkCmd/info.htm">info</A></B>, <B><A HREF="../TkCmd/proc.htm">proc</A></B> | ||||
| <H3><A NAME="M6">KEYWORDS</A></H3> | ||||
| <A href="../Keywords/E.htm#error">error</A>, <A href="../Keywords/N.htm#non-existent command">non-existent command</A> | ||||
| <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