diff options
author | dgp <dgp@users.sourceforge.net> | 2013-03-11 12:55:29 (GMT) |
---|---|---|
committer | dgp <dgp@users.sourceforge.net> | 2013-03-11 12:55:29 (GMT) |
commit | df4d161b0f8447292465330d03550426006fd13c (patch) | |
tree | c0d4f0ded6d161132b16a0b6ec9e31db28a0b8a9 /generic/tclLiteral.c | |
parent | a1f9566f74e6769c201e4040540880eb58e0767c (diff) | |
parent | 53d74314391e46506521ca790914b8610611c095 (diff) | |
download | tcl-df4d161b0f8447292465330d03550426006fd13c.zip tcl-df4d161b0f8447292465330d03550426006fd13c.tar.gz tcl-df4d161b0f8447292465330d03550426006fd13c.tar.bz2 |
3607246,3607372 Unbalanced refcounts of literals in the global literal table.
Diffstat (limited to 'generic/tclLiteral.c')
-rw-r--r-- | generic/tclLiteral.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/generic/tclLiteral.c b/generic/tclLiteral.c index ce258cf..11da6f8 100644 --- a/generic/tclLiteral.c +++ b/generic/tclLiteral.c @@ -1010,8 +1010,13 @@ TclInvalidateCmdLiteral( Tcl_Obj *literalObjPtr = TclCreateLiteral(iPtr, (char *) name, strlen(name), -1, NULL, nsPtr, 0, NULL); - if (literalObjPtr != NULL && literalObjPtr->typePtr == &tclCmdNameType) { - TclFreeIntRep(literalObjPtr); + if (literalObjPtr != NULL) { + if (literalObjPtr->typePtr == &tclCmdNameType) { + TclFreeIntRep(literalObjPtr); + } + /* Balance the refcount effects of TclCreateLiteral() above */ + Tcl_IncrRefCount(literalObjPtr); + TclReleaseLiteral(interp, literalObjPtr); } } |