diff options
author | dkf <donal.k.fellows@manchester.ac.uk> | 2007-03-01 10:16:09 (GMT) |
---|---|---|
committer | dkf <donal.k.fellows@manchester.ac.uk> | 2007-03-01 10:16:09 (GMT) |
commit | 44ebec67f366b1da8cc1609b93847b2c6a590749 (patch) | |
tree | 3a2cdb549c109b3cc5f7794e2dcfb3988d7f35da /generic/tclCompCmds.c | |
parent | 4ced9366453c96f6237ff479dff2fc80bd0e18d9 (diff) | |
download | tcl-44ebec67f366b1da8cc1609b93847b2c6a590749.zip tcl-44ebec67f366b1da8cc1609b93847b2c6a590749.tar.gz tcl-44ebec67f366b1da8cc1609b93847b2c6a590749.tar.bz2 |
Fix [Bug 1671138]
Diffstat (limited to 'generic/tclCompCmds.c')
-rw-r--r-- | generic/tclCompCmds.c | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/generic/tclCompCmds.c b/generic/tclCompCmds.c index 0737ab2..9c20bac 100644 --- a/generic/tclCompCmds.c +++ b/generic/tclCompCmds.c @@ -11,7 +11,7 @@ * See the file "license.terms" for information on usage and redistribution * of this file, and for a DISCLAIMER OF ALL WARRANTIES. * - * RCS: @(#) $Id: tclCompCmds.c,v 1.39.2.4 2006/11/28 22:20:00 andreas_kupries Exp $ + * RCS: @(#) $Id: tclCompCmds.c,v 1.39.2.5 2007/03/01 10:16:10 dkf Exp $ */ #include "tclInt.h" @@ -894,6 +894,18 @@ TclCompileForeachCmd(interp, parsePtr, envPtr) goto done; } numVars = varcList[loopIndex]; + + /* + * If the variable list is empty, we can enter an infinite + * loop when the interpreted version would not. Take care to + * ensure this does not happen. [Bug 1671138] + */ + + if (numVars == 0) { + code = TCL_ERROR; + goto done; + } + for (j = 0; j < numVars; j++) { CONST char *varName = varvList[loopIndex][j]; if (!TclIsLocalScalar(varName, (int) strlen(varName))) { |