aboutsummaryrefslogtreecommitdiff
path: root/lang/tcl83
diff options
context:
space:
mode:
authorDirk Meyer <dinoex@FreeBSD.org>2003-04-22 18:14:06 +0000
committerDirk Meyer <dinoex@FreeBSD.org>2003-04-22 18:14:06 +0000
commitd024ce9c403101180c25cca7cdefbb74f84a0200 (patch)
tree6d68188d328727374ea4c8b909d99e5813be7528 /lang/tcl83
parent960cd205ac04aa174021a97cfc8c001b819ca53a (diff)
downloadports-d024ce9c403101180c25cca7cdefbb74f84a0200.tar.gz
ports-d024ce9c403101180c25cca7cdefbb74f84a0200.zip
Notes
Diffstat (limited to 'lang/tcl83')
-rw-r--r--lang/tcl83/Makefile2
-rw-r--r--lang/tcl83/files/patch-tclEncoding.c30
2 files changed, 31 insertions, 1 deletions
diff --git a/lang/tcl83/Makefile b/lang/tcl83/Makefile
index 1e79381e95ac..0b9388b46dd5 100644
--- a/lang/tcl83/Makefile
+++ b/lang/tcl83/Makefile
@@ -7,7 +7,7 @@
PORTNAME= tcl
PORTVERSION= 8.3.5
-PORTREVISION= 1
+PORTREVISION= 2
CATEGORIES= lang tcl83
MASTER_SITES= ${MASTER_SITE_SOURCEFORGE}
MASTER_SITE_SUBDIR= tcl
diff --git a/lang/tcl83/files/patch-tclEncoding.c b/lang/tcl83/files/patch-tclEncoding.c
new file mode 100644
index 000000000000..3250bffa568c
--- /dev/null
+++ b/lang/tcl83/files/patch-tclEncoding.c
@@ -0,0 +1,30 @@
+--- ../generic/tclEncoding.c.orig Thu Apr 5 13:28:52 2001
++++ ../generic/tclEncoding.c Thu Apr 10 00:49:34 2003
+@@ -310,19 +310,19 @@
+ {
+ Tcl_HashSearch search;
+ Tcl_HashEntry *hPtr;
+- Encoding *encodingPtr;
+
+ Tcl_MutexLock(&encodingMutex);
+ encodingsInitialized = 0;
+ hPtr = Tcl_FirstHashEntry(&encodingTable, &search);
+ while (hPtr != NULL) {
+- encodingPtr = (Encoding *) Tcl_GetHashValue(hPtr);
+- if (encodingPtr->freeProc != NULL) {
+- (*encodingPtr->freeProc)(encodingPtr->clientData);
+- }
+- ckfree((char *) encodingPtr->name);
+- ckfree((char *) encodingPtr);
+- hPtr = Tcl_NextHashEntry(&search);
++ /*
++ * Call FreeEncoding instead of doing it directly to handle refcounts
++ * like escape encodings use. [Bug #524674]
++ * Make sure to call Tcl_FirstHashEntry repeatedly so that all
++ * encodings are eventually cleaned up.
++ */
++ FreeEncoding((Tcl_Encoding) Tcl_GetHashValue(hPtr));
++ hPtr = Tcl_FirstHashEntry(&encodingTable, &search);
+ }
+ Tcl_DeleteHashTable(&encodingTable);
+ Tcl_MutexUnlock(&encodingMutex);