diff options
author | dgp <dgp@users.sourceforge.net> | 2011-07-15 17:50:20 (GMT) |
---|---|---|
committer | dgp <dgp@users.sourceforge.net> | 2011-07-15 17:50:20 (GMT) |
commit | a5cd0c254693b12d78c39cc4cddc07745e121668 (patch) | |
tree | 8c97671615ef0ff14a25f3d36beda514f6319c5e /generic/tclCompile.c | |
parent | 965e4bbab2201076c8c2bc6ae5baca705ab889b0 (diff) | |
download | tcl-a5cd0c254693b12d78c39cc4cddc07745e121668.zip tcl-a5cd0c254693b12d78c39cc4cddc07745e121668.tar.gz tcl-a5cd0c254693b12d78c39cc4cddc07745e121668.tar.bz2 |
Avoid segfaults when RecordByteCodeStats() is called in a deleted interp.
Diffstat (limited to 'generic/tclCompile.c')
-rw-r--r-- | generic/tclCompile.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/generic/tclCompile.c b/generic/tclCompile.c index f29c54e..e281a0a 100644 --- a/generic/tclCompile.c +++ b/generic/tclCompile.c @@ -4012,6 +4012,11 @@ RecordByteCodeStats(codePtr) Interp *iPtr = (Interp *) *codePtr->interpHandle; register ByteCodeStats *statsPtr = &(iPtr->stats); + if (iPtr == NULL) { + /* Avoid segfaulting in case we're called in a deleted interp */ + return; + } + statsPtr->numCompilations++; statsPtr->totalSrcBytes += (double) codePtr->numSrcBytes; statsPtr->totalByteCodeBytes += (double) codePtr->structureSize; |