summaryrefslogtreecommitdiffstats
path: root/generic
diff options
context:
space:
mode:
authordgp <dgp@users.sourceforge.net>2015-12-22 20:49:19 (GMT)
committerdgp <dgp@users.sourceforge.net>2015-12-22 20:49:19 (GMT)
commit36189b7eca7e68a19d5e4d9cdf712f3aef322398 (patch)
tree69feb1d982e3e0d1ae6f036033c4a32ebb2a3ed2 /generic
parent8d9d336b0c2d9142cf90919d36ef75acc1627bc8 (diff)
parent003b3000368a5f8752fcee1444cf4ec1cee6fe62 (diff)
downloadtcl-36189b7eca7e68a19d5e4d9cdf712f3aef322398.zip
tcl-36189b7eca7e68a19d5e4d9cdf712f3aef322398.tar.gz
tcl-36189b7eca7e68a19d5e4d9cdf712f3aef322398.tar.bz2
merge 8.5
Diffstat (limited to 'generic')
-rw-r--r--generic/tclClock.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/generic/tclClock.c b/generic/tclClock.c
index 3ec94fb..32ba145 100644
--- a/generic/tclClock.c
+++ b/generic/tclClock.c
@@ -1994,22 +1994,23 @@ ClockSecondsObjCmd(
static void
TzsetIfNecessary(void)
{
- static char* tzWas = NULL; /* Previous value of TZ, protected by
+ static char* tzWas = INT2PTR(-1); /* Previous value of TZ, protected by
* clockMutex. */
const char* tzIsNow; /* Current value of TZ */
Tcl_MutexLock(&clockMutex);
tzIsNow = getenv("TZ");
- if (tzIsNow != NULL && (tzWas == NULL || strcmp(tzIsNow, tzWas) != 0)) {
+ if (tzIsNow != NULL && (tzWas == NULL || tzWas == INT2PTR(-1)
+ || strcmp(tzIsNow, tzWas) != 0)) {
tzset();
- if (tzWas != NULL) {
+ if (tzWas != NULL && tzWas != INT2PTR(-1)) {
ckfree(tzWas);
}
tzWas = ckalloc(strlen(tzIsNow) + 1);
strcpy(tzWas, tzIsNow);
} else if (tzIsNow == NULL && tzWas != NULL) {
tzset();
- ckfree(tzWas);
+ if (tzWas != INT2PTR(-1)) ckfree(tzWas);
tzWas = NULL;
}
Tcl_MutexUnlock(&clockMutex);