Tcl_SubstObj(3) Tcl Library Procedures Tcl_SubstObj(3)

____________________________________________________________________________

NAME


Tcl_SubstObj - perform substitutions on Tcl values

SYNOPSIS


#include <tcl.h>

Tcl_Obj *
Tcl_SubstObj(interp, objPtr, flags)

ARGUMENTS


Tcl_Interp *interp (in) Interpreter in which to execute
Tcl scripts and lookup variables.
If an error occurs, the
interpreter's result is modified
to hold an error message.

Tcl_Obj *objPtr (in) A Tcl value containing the string
to perform substitutions on.

int flags (in) OR'ed combination of flag bits
that specify which substitutions
to perform. The flags
TCL_SUBST_COMMANDS,
TCL_SUBST_VARIABLES and
TCL_SUBST_BACKSLASHES are
currently supported, and
TCL_SUBST_ALL is provided as a
convenience for the common case
where all substitutions are
desired.
____________________________________________________________________________

DESCRIPTION


The Tcl_SubstObj function is used to perform substitutions on strings
in the fashion of the subst command. It gets the value of the string
contained in objPtr and scans it, copying characters and performing
the chosen substitutions as it goes to an output value which is
returned as the result of the function. In the event of an error
occurring during the execution of a command or variable substitution,
the function returns NULL and an error message is left in interp's
result.

Three kinds of substitutions are supported. When the
TCL_SUBST_BACKSLASHES bit is set in flags, sequences that look like
backslash substitutions for Tcl commands are replaced by their
corresponding character.

When the TCL_SUBST_VARIABLES bit is set in flags, sequences that look
like variable substitutions for Tcl commands are replaced by the
contents of the named variable.

When the TCL_SUBST_COMMANDS bit is set in flags, sequences that look
like command substitutions for Tcl commands are replaced by the
result of evaluating that script. Where an uncaught "continue
exception" occurs during the evaluation of a command substitution, an
empty string is substituted for the command. Where an uncaught
"break exception" occurs during the evaluation of a command
substitution, the result of the whole substitution on objPtr will be
truncated at the point immediately before the start of the command
substitution, and no characters will be added to the result or
substitutions performed after that point.

SEE ALSO


subst(n)

KEYWORDS


backslash substitution, command substitution, variable substitution

Tcl 8.4 Tcl_SubstObj(3)

tribblix@gmail.com :: GitHub :: Privacy