diff options
author | Martin v. Löwis <martin@v.loewis.de> | 2009-01-24 16:19:45 (GMT) |
---|---|---|
committer | Martin v. Löwis <martin@v.loewis.de> | 2009-01-24 16:19:45 (GMT) |
commit | acbf461fe5d1f5f7516dd2cbbf3c1185ab3ec2b7 (patch) | |
tree | 9f0f17e721eaf1a0fa0bd7051449dcf0b8764633 /Lib/tkinter | |
parent | 17e5587693420b33ad7b9bacb732bb74f7596af6 (diff) | |
download | cpython-acbf461fe5d1f5f7516dd2cbbf3c1185ab3ec2b7.zip cpython-acbf461fe5d1f5f7516dd2cbbf3c1185ab3ec2b7.tar.gz cpython-acbf461fe5d1f5f7516dd2cbbf3c1185ab3ec2b7.tar.bz2 |
Merged revisions 68893 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r68893 | martin.v.loewis | 2009-01-24 16:47:27 +0100 (Sa, 24 Jan 2009) | 3 lines
Issue #3881: Help Tcl to load even when started through the
unreadable local symlink to "Program Files" on Vista.
........
Diffstat (limited to 'Lib/tkinter')
-rw-r--r-- | Lib/tkinter/_fix.py | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/Lib/tkinter/_fix.py b/Lib/tkinter/_fix.py index 8820cba..c11d663 100644 --- a/Lib/tkinter/_fix.py +++ b/Lib/tkinter/_fix.py @@ -10,6 +10,40 @@ import sys, os # <TCL_LIBRARY>\..\tcl<TCL_VERSION>, so anything close to # the real Tcl library will do. +# Expand symbolic links on Vista +try: + import ctypes + ctypes.windll.kernel32.GetFinalPathNameByHandleW +except (ImportError, AttributeError): + def convert_path(s): + return s +else: + def convert_path(s): + if isinstance(s, bytes): + s = s.decode("mbcs") + hdir = ctypes.windll.kernel32.\ + CreateFileW(s, 0x80, # FILE_READ_ATTRIBUTES + 1, # FILE_SHARE_READ + None, 3, # OPEN_EXISTING + 0x02000000, # FILE_FLAG_BACKUP_SEMANTICS + None) + if hdir == -1: + # Cannot open directory, give up + return s + buf = ctypes.create_unicode_buffer("", 32768) + res = ctypes.windll.kernel32.\ + GetFinalPathNameByHandleW(hdir, buf, len(buf), + 0) # VOLUME_NAME_DOS + ctypes.windll.kernel32.CloseHandle(hdir) + if res == 0: + # Conversion failed (e.g. network location) + return s + s = buf[:res] + # Ignore leading \\?\ + if s.startswith("\\\\?\\"): + s = s[4:] + return s + prefix = os.path.join(sys.prefix,"tcl") if not os.path.exists(prefix): # devdir/../tcltk/lib @@ -17,6 +51,7 @@ if not os.path.exists(prefix): prefix = os.path.abspath(prefix) # if this does not exist, no further search is needed if os.path.exists(prefix): + prefix = convert_path(prefix) if "TCL_LIBRARY" not in os.environ: for name in os.listdir(prefix): if name.startswith("tcl"): |