summaryrefslogtreecommitdiffstats
path: root/Lib/tkinter/_fix.py
diff options
context:
space:
mode:
authorMartin v. Löwis <martin@v.loewis.de>2009-01-24 16:19:45 (GMT)
committerMartin v. Löwis <martin@v.loewis.de>2009-01-24 16:19:45 (GMT)
commitacbf461fe5d1f5f7516dd2cbbf3c1185ab3ec2b7 (patch)
tree9f0f17e721eaf1a0fa0bd7051449dcf0b8764633 /Lib/tkinter/_fix.py
parent17e5587693420b33ad7b9bacb732bb74f7596af6 (diff)
downloadcpython-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/_fix.py')
-rw-r--r--Lib/tkinter/_fix.py35
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"):