diff options
| author | mig <mig> | 2012-10-18 17:38:19 (GMT) |
|---|---|---|
| committer | mig <mig> | 2012-10-18 17:38:19 (GMT) |
| commit | 5df58158a461f3054d66e9973bd6c08a1b8acd16 (patch) | |
| tree | 4d14ef0085efe55df8224932282b1f1c6e5ce5c8 /generic/tclBasic.c | |
| parent | 52fd0ba94b36e5f21e5eac6e8f64bd20b216579d (diff) | |
| download | tcl-5df58158a461f3054d66e9973bd6c08a1b8acd16.zip tcl-5df58158a461f3054d66e9973bd6c08a1b8acd16.tar.gz tcl-5df58158a461f3054d66e9973bd6c08a1b8acd16.tar.bz2 | |
* generic/tclBasic.c (TclNRCoroutineObjCmd): insure that numlevels
are properly set, fix bug discovered by dkf and reported at http://code.activestate.com/lists/tcl-core/12213/
Diffstat (limited to 'generic/tclBasic.c')
| -rw-r--r-- | generic/tclBasic.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/generic/tclBasic.c b/generic/tclBasic.c index 7c08f2f..3848d5b 100644 --- a/generic/tclBasic.c +++ b/generic/tclBasic.c @@ -9028,7 +9028,6 @@ TclNRCoroutineObjCmd( corPtr->running.lineLABCPtr = corPtr->lineLABCPtr; corPtr->stackLevel = NULL; corPtr->auxNumLevels = 0; - iPtr->numLevels--; /* * Create the coro's execEnv, switch to it to push the exit and coro @@ -9047,16 +9046,17 @@ TclNRCoroutineObjCmd( TclNRAddCallback(interp, NRCoroutineExitCallback, corPtr, NULL, NULL, NULL); + /* insure that the command is looked up in the correct namespace */ iPtr->lookupNsPtr = lookupNsPtr; Tcl_NREvalObj(interp, Tcl_NewListObj(objc-2, objv+2), 0); + iPtr->numLevels--; SAVE_CONTEXT(corPtr->running); RESTORE_CONTEXT(corPtr->caller); iPtr->execEnvPtr = corPtr->callerEEPtr; /* - * Now just resume the coroutine. Take care to insure that the command is - * looked up in the correct namespace. + * Now just resume the coroutine. */ TclNRAddCallback(interp, NRCoroutineActivateCallback, corPtr, |
