summaryrefslogtreecommitdiffstats
path: root/generic/tclBasic.c
diff options
context:
space:
mode:
authorandreas_kupries <akupries@shaw.ca>2008-07-28 20:00:57 (GMT)
committerandreas_kupries <akupries@shaw.ca>2008-07-28 20:00:57 (GMT)
commit24cd37cd688085d4c016ab87e112add167d69173 (patch)
treec9ae4bdded6df431ec80cf526bc7ebae73c19e7a /generic/tclBasic.c
parentc5be2d186c8738b465587c5433f3f4c422c95313 (diff)
downloadtcl-24cd37cd688085d4c016ab87e112add167d69173.zip
tcl-24cd37cd688085d4c016ab87e112add167d69173.tar.gz
tcl-24cd37cd688085d4c016ab87e112add167d69173.tar.bz2
* generic/tclBasic.c: Added missing release of extended command
word index when deleting an interpreter (DeleteInterpProc). Added missing ref count when creating an empty string as path (EvalEx). * generic/tclCompile.c (TclInitCompileEnv): Made same change to control flow as in TclEvalObjEx. Not needed while uplevel and siblings go through the eval-direct code path, however if that changes (like it did in 8.5+) better to have this in place instead of re-searching why certain places are without absolute locations. * tests/info.test: Added tests 38.*, exactly testing the tracking of location for uplevel scripts, and made the testsuite fully usable with and without -singleproc 1.
Diffstat (limited to 'generic/tclBasic.c')
-rw-r--r--generic/tclBasic.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/generic/tclBasic.c b/generic/tclBasic.c
index c91fdc1..4ce4590 100644
--- a/generic/tclBasic.c
+++ b/generic/tclBasic.c
@@ -14,7 +14,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.75.2.32 2008/07/23 20:45:16 andreas_kupries Exp $
+ * RCS: @(#) $Id: tclBasic.c,v 1.75.2.33 2008/07/28 20:01:07 andreas_kupries Exp $
*/
#include "tclInt.h"
@@ -1202,6 +1202,10 @@ DeleteInterpProc(interp)
ckfree ((char*) eclPtr->loc);
}
+ if (eclPtr->eiloc != NULL) {
+ ckfree ((char*) eclPtr->eiloc);
+ }
+
ckfree ((char*) eclPtr);
Tcl_DeleteHashEntry (hPtr);
}
@@ -3906,10 +3910,10 @@ EvalEx(interp, script, numBytes, flags, line)
return TCL_ERROR;
}
eeFrame.data.eval.path = norm;
- Tcl_IncrRefCount (eeFrame.data.eval.path);
} else {
eeFrame.data.eval.path = Tcl_NewStringObj ("",-1);
}
+ Tcl_IncrRefCount (eeFrame.data.eval.path);
} else {
/* Set up for plain eval */