summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMiguel Sofer <miguel.sofer@gmail.com>2004-05-16 20:23:00 (GMT)
committerMiguel Sofer <miguel.sofer@gmail.com>2004-05-16 20:23:00 (GMT)
commit761df1dd737fda3e0bda124509e81dd92ff72e84 (patch)
tree0f8f6d076a0483dc37aec2b6f8ce11c3f0e4fb67
parenta76b6923bb681fdc5ed9f24e8ab74c40dfd2fca9 (diff)
downloadtcl-761df1dd737fda3e0bda124509e81dd92ff72e84.zip
tcl-761df1dd737fda3e0bda124509e81dd92ff72e84.tar.gz
tcl-761df1dd737fda3e0bda124509e81dd92ff72e84.tar.bz2
* generic/tclBasic.c (Tcl_DeleteInterp):
* generic/tclExecute.c (INST_START_CMD): interp deletion now modifies the compileEpoch, eliminating the need for the check for interp deletion in INST_START_CMD.
-rw-r--r--ChangeLog9
-rw-r--r--generic/tclBasic.c5
-rw-r--r--generic/tclExecute.c11
3 files changed, 20 insertions, 5 deletions
diff --git a/ChangeLog b/ChangeLog
index 47c4e11..729a0ca 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,12 @@
2004-05-16 Miguel Sofer <msofer@users.sf.net>
+ * generic/tclBasic.c (Tcl_DeleteInterp):
+ * generic/tclExecute.c (INST_START_CMD): interp deletion now
+ modifies the compileEpoch, eliminating the need for the check for
+ interp deletion in INST_START_CMD.
+
+2004-05-16 Miguel Sofer <msofer@users.sf.net>
+
* generic/tclCompile.h:
* generic/tclCompile.c:
* generic/tclExecute.c: changed implementation of {expand}, last
@@ -45,7 +52,7 @@
2004-05-14 Miguel Sofer <msofer@users.sf.net>
- * generic/tclExecute.h:
+ * generic/tclExecute.c:
* generic/tclCompile.h: the math functions receive a pointer to
top of the stack (tosPtr) instead of the execution environment
(eePtr). First step towards a change in the execution stack
diff --git a/generic/tclBasic.c b/generic/tclBasic.c
index 71f377d..3054f98 100644
--- a/generic/tclBasic.c
+++ b/generic/tclBasic.c
@@ -13,7 +13,7 @@
* See the file "license.terms" for information on usage and redistribution
* of this file, and for a DISCLAIMER OF ALL WARRANTIES.
*
- * RCS: @(#) $Id: tclBasic.c,v 1.100 2004/05/13 12:59:21 dkf Exp $
+ * RCS: @(#) $Id: tclBasic.c,v 1.101 2004/05/16 20:23:01 msofer Exp $
*/
#include "tclInt.h"
@@ -918,9 +918,12 @@ Tcl_DeleteInterp(interp)
/*
* Mark the interpreter as deleted. No further evals will be allowed.
+ * Increase the compileEpoch as a signal to compiled bytecodes.
*/
iPtr->flags |= DELETED;
+ iPtr->compileEpoch++;
+
/*
* Ensure that the interpreter is eventually deleted.
diff --git a/generic/tclExecute.c b/generic/tclExecute.c
index 6c29150..41e155e 100644
--- a/generic/tclExecute.c
+++ b/generic/tclExecute.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: tclExecute.c,v 1.128 2004/05/16 17:25:49 msofer Exp $
+ * RCS: @(#) $Id: tclExecute.c,v 1.129 2004/05/16 20:23:01 msofer Exp $
*/
#include "tclInt.h"
@@ -1336,8 +1336,13 @@ TclExecuteByteCode(interp, codePtr)
}
case INST_START_CMD:
- if ((!(iPtr->flags & DELETED)
- && (codeCompileEpoch == iPtr->compileEpoch)
+ /*
+ * Remark that if the interpreter is marked for deletion
+ * its compileEpoch is modified, so that the epoch
+ * check also verifies that the interp is not deleted.
+ */
+
+ if (((codeCompileEpoch == iPtr->compileEpoch)
&& (codeNsEpoch == namespacePtr->resolverEpoch))
|| codePrecompiled) {
NEXT_INST_F(5, 0, 0);