Manual Pages for UNIX Darwin command on man unknown
MyWebUniversity

Manual Pages for UNIX Darwin command on man unknown

unknown(n) Tcl Built-In Commands unknown(n)

NAME

unknown - Handle attempts to use non-existent commands

SYNOPSIS

uunnkknnoowwnn cmdName ?arg arg ...?

DESCRIPTION

This command is invoked by the Tcl interpreter whenever a script tries to invoke a command that doesn't exist. The default implementation of

uunnkknnoowwnn is a library procedure defined when Tcl initializes an inter-

preter. You can override the default uunnkknnoowwnn to change its functional-

ity. Note that there is no default implementation of uunnkknnoowwnn in a safe interpreter. 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 uunnkknnoowwnn. If there is no such command, then the interpreter returns an

error. If the uunnkknnoowwnn command exists, then it is invoked with argu-

ments consisting of the fully-substituted name and arguments for the

original non-existent command. The uunnkknnoowwnn command typically does

things like searching through library directories for a command proce-

dure with the name cmdName, or expanding abbreviated command names to

full-length, or automatically executing unknown commands as sub-pro-

cesses. In some cases (such as expanding abbreviations) uunnkknnoowwnn will

change the original command slightly and then (re-)execute it. The

result of the uunnkknnoowwnn command is used as the result for the original

non-existent command.

The default implementation of uunnkknnoowwnn behaves as follows. It first calls the aauuttoollooaadd library procedure to load the command. If this

succeeds, then it executes the original command with its original argu-

ments. If the auto-load fails then uunnkknnoowwnn calls aauuttooeexxeeccookk to see if

there is an executable file by the name cmd. If so, it invokes the Tcl eexxeecc command with cmd and all the args as arguments. If cmd can't be

auto-executed, uunnkknnoowwnn checks to see if the command was invoked at top-

level and outside of any script. If so, then uunnkknnoowwnn takes two addi-

tional steps. First, it sees if cmd has one of the following three forms: !!!!, !!event, or ^^old^^new?^^?. If so, then uunnkknnoowwnn carries out

history substitution in the same way that ccsshh would for these con-

structs. Finally, uunnkknnoowwnn checks to see if cmd is a unique abbrevia-

tion 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, uunnkknnoowwnn generates an error return. If the global variable aauuttoonnoollooaadd is defined, then

the auto-load step is skipped. If the global variable aauuttoonnooeexxeecc is

defined then the auto-exec step is skipped. Under normal circumstances

the return value from uunnkknnoowwnn is the return value from the command that was eventually executed.

SEE ALSO

info(n), proc(n), interp(n), library(n) KKEEYYWWOORRDDSS

error, non-existent command

Tcl unknown(n)




Contact us      |      About us      |      Term of use      |       Copyright © 2000-2019 MyWebUniversity.com ™