summaryrefslogtreecommitdiffstats
path: root/generic/tclLiteral.c
diff options
context:
space:
mode:
authordgp <dgp@users.sourceforge.net>2013-03-11 12:55:29 (GMT)
committerdgp <dgp@users.sourceforge.net>2013-03-11 12:55:29 (GMT)
commitdf4d161b0f8447292465330d03550426006fd13c (patch)
treec0d4f0ded6d161132b16a0b6ec9e31db28a0b8a9 /generic/tclLiteral.c
parenta1f9566f74e6769c201e4040540880eb58e0767c (diff)
parent53d74314391e46506521ca790914b8610611c095 (diff)
downloadtcl-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.c9
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);
}
}