WrongNumArgs
Tcl_WrongNumArgs(3) Tcl Library Procedures Tcl_WrongNumArgs(3)
______________________________________________________________________________
NAME
Tcl_WrongNumArgs - generate standard error message for wrong number of
arguments
SYNOPSIS
#include <tcl.h>
Tcl_WrongNumArgs(interp, objc, objv, message)
ARGUMENTS
Tcl_Interp interp (in) Interpreter in which error will
be reported: error message gets
stored in its result object.
int objc (in) Number of leading arguments from
objv to include in error mes-
sage.
Tcl_Obj *CONST objv[] (in) Arguments to command that had
the wrong number of arguments.
char *message (in) Additional error information to
print after leading arguments
from objv. This typically gives
the acceptable syntax of the
command. This argument may be
NULL.
_________________________________________________________________
DESCRIPTION
Tcl_WrongNumArgs is a utility procedure that is invoked by command pro-
cedures when they discover that they have received the wrong number of
arguments. Tcl_WrongNumArgs generates a standard error message and
stores it in the result object of interp. The message includes the
objc initial elements of objv plus message. For example, if objv con-
sists of the values foo and bar, objc is 1, and message is ``fileName
count'' then interp's result object will be set to the following
string:
wrong # args: should be "foo fileName count"
If objc is 2, the result will be set to the following string:
wrong # args: should be "foo bar fileName count"
Objc is usually 1, but may be 2 or more for commands like string and
the Tk widget commands, which use the first argument as a subcommand.
Some of the objects in the objv array may be abbreviations for a sub-
command. The command Tcl_GetIndexFromObj will convert the abbreviated
string object into an indexObject. If an error occurs in the parsing
of the subcommand we would like to use the full subcommand name rather
than the abbreviation. If the Tcl_WrongNumArgs command finds any
indexObjects in the objv array it will use the full subcommand name in
the error message instead of the abbreviated name that was origionally
passed in. Using the above example, lets assume that bar is actually
an abbreviation for barfly and the object is now an indexObject becasue
it was passed to Tcl_GetIndexFromObj. In this case the error message
would be:
wrong # args: should be "foo barfly fileName count"
SEE ALSO
Tcl_GetIndexFromObj
KEYWORDS
command, error message, wrong number of arguments
Tcl 8.0 Tcl_WrongNumArgs(3)