summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorMichael W. Hudson <mwh@python.net>2002-02-25 10:56:25 (GMT)
committerMichael W. Hudson <mwh@python.net>2002-02-25 10:56:25 (GMT)
commitc44f7f7835be82bd73e24c394cfcae0557729656 (patch)
tree1ab25ec9f100d250f0cce1d796c502611994c4a8 /Lib
parentd61d2d2e11775314e3f6a4e2e9e74db224d2bb9b (diff)
downloadcpython-c44f7f7835be82bd73e24c394cfcae0557729656.zip
cpython-c44f7f7835be82bd73e24c394cfcae0557729656.tar.gz
cpython-c44f7f7835be82bd73e24c394cfcae0557729656.tar.bz2
backport loewis' checkin of
revision 1.6 of FixTk.py Set TCL_LIBRARY before import _tkinter. Suggested by Kirill Simonov. Fixes #418173 and #219960. 2.2.1 candidate.
Diffstat (limited to 'Lib')
-rw-r--r--Lib/lib-tk/FixTk.py41
1 files changed, 31 insertions, 10 deletions
diff --git a/Lib/lib-tk/FixTk.py b/Lib/lib-tk/FixTk.py
index 029e7cd..765e639 100644
--- a/Lib/lib-tk/FixTk.py
+++ b/Lib/lib-tk/FixTk.py
@@ -1,11 +1,32 @@
-import sys, os, _tkinter
+import sys, os
-ver = str(_tkinter.TCL_VERSION)
-for t in "tcl", "tk", "tix":
- key = t.upper() + "_LIBRARY"
- try:
- v = os.environ[key]
- except KeyError:
- v = os.path.join(sys.prefix, "tcl", t+ver)
- if os.path.exists(os.path.join(v, "tclIndex")):
- os.environ[key] = v
+# Delay import _tkinter until we have set TCL_LIBRARY,
+# so that Tcl_FindExecutable has a chance to locate its
+# encoding directory.
+
+# Unfortunately, we cannot know the TCL_LIBRARY directory
+# if we don't know the tcl version, which we cannot find out
+# without import Tcl. Fortunately, Tcl will itself look in
+# <TCL_LIBRARY>\..\tcl<TCL_VERSION>, so anything close to
+# the real Tcl library will do.
+
+prefix = os.path.join(sys.prefix,"tcl")
+# if this does not exist, no further search is needed
+if os.path.exists(prefix):
+ if not os.environ.has_key("TCL_LIBRARY"):
+ for name in os.listdir(prefix):
+ if name.startswith("tcl"):
+ tcldir = os.path.join(prefix,name)
+ if os.path.isdir(tcldir):
+ os.environ["TCL_LIBRARY"] = tcldir
+ # Now set the other variables accordingly
+ import _tkinter
+ ver = str(_tkinter.TCL_VERSION)
+ for t in "tk", "tix":
+ key = t.upper() + "_LIBRARY"
+ try:
+ v = os.environ[key]
+ except KeyError:
+ v = os.path.join(sys.prefix, "tcl", t+ver)
+ if os.path.exists(os.path.join(v, "tclIndex")):
+ os.environ[key] = v