diff options
author | Michael W. Hudson <mwh@python.net> | 2002-02-25 10:56:25 (GMT) |
---|---|---|
committer | Michael W. Hudson <mwh@python.net> | 2002-02-25 10:56:25 (GMT) |
commit | c44f7f7835be82bd73e24c394cfcae0557729656 (patch) | |
tree | 1ab25ec9f100d250f0cce1d796c502611994c4a8 /Lib | |
parent | d61d2d2e11775314e3f6a4e2e9e74db224d2bb9b (diff) | |
download | cpython-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.py | 41 |
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 |