Files
MINGW-packages/mingw-w64-python2/0060-mingw-static-tcltk.patch
Ray Donnelly d81e579c18 python 2(+3): patches for dirsep as / and sysconfig
0530-msys-mingw-prefer-unix-sep-if-MSYSTEM.patch
0535-msys-cygwin-semi-native-build-sysconfig.patch

Add a bug-fix from Arch Linux mingw-w64-python 2.7.6
for a memory stomp.

Fix python{3.3m}-config.sh to return correct values.

Tidy up the PKGBUILD files.
2014-01-29 02:08:31 +00:00

74 lines
3.5 KiB
Diff

diff -urN a/setup.py b/setup.py
--- a/setup.py 2014-01-22 20:57:31.362293882 +0000
+++ b/setup.py 2014-01-22 20:57:31.855634832 +0000
@@ -565,7 +565,7 @@
if host_platform == 'hp-ux11':
lib_dirs += ['/usr/lib/hpux64', '/usr/lib/hpux32']
- if host_platform == 'darwin':
+ if host_platform in ['darwin', 'mingw', 'win32']:
# This should work on any unixy platform ;-)
# If the user has bothered specifying additional -I and -L flags
# in OPT and LDFLAGS we might as well use them here.
@@ -575,6 +575,8 @@
# FIXME: Why LDFLAGS again ?
cflags, ldflags = sysconfig.get_config_vars(
'CFLAGS', 'LDFLAGS')
+ cflags = cflags + ' ' + ('',os.environ.get('CC'))[os.environ.get('CC') != None]
+ ldflags = ldflags + ' ' + ('',os.environ.get('LDSHARED'))[os.environ.get('LDSHARED') != None]
for item in cflags.split():
if item.startswith('-I'):
inc_dirs.append(item[2:])
@@ -1965,14 +1967,19 @@
# The versions with dots are used on Unix, and the versions without
# dots on Windows, for detection by cygwin.
tcllib = tklib = tcl_includes = tk_includes = None
- for version in ['8.6', '86', '8.5', '85', '8.4', '84', '8.3', '83',
- '8.2', '82', '8.1', '81', '8.0', '80']:
- tklib = self.compiler.find_library_file(lib_dirs,
- 'tk' + version)
- tcllib = self.compiler.find_library_file(lib_dirs,
- 'tcl' + version)
- if tklib and tcllib:
- # Exit the loop when we've found the Tcl/Tk libraries
+ tcltk_suffix = None
+ for suffix in ['', 's']:
+ for version in ['8.6', '86', '8.5', '85', '8.4', '84', '8.3', '83',
+ '8.2', '82', '8.1', '81', '8.0', '80', '']:
+ tklib = self.compiler.find_library_file(lib_dirs,
+ 'tk' + version + suffix)
+ tcllib = self.compiler.find_library_file(lib_dirs,
+ 'tcl' + version + suffix)
+ if tklib and tcllib:
+ # Exit the loop when we've found the Tcl/Tk libraries
+ tcltk_suffix = suffix
+ break
+ if tcltk_suffix != None:
break
# Now check for the header files
@@ -2041,15 +2048,21 @@
libs.append('BLT')
# Add the Tcl/Tk libraries
- libs.append('tk'+ version)
- libs.append('tcl'+ version)
+ libs.append('tk'+ version + tcltk_suffix)
+ libs.append('tcl'+ version + tcltk_suffix)
+ if host_platform == 'win32':
+ for winlib in ['ws2_32','gdi32','comctl32','comdlg32','imm32','uuid','oleaut32','ole32']:
+ libs.append( winlib )
if host_platform in ['aix3', 'aix4']:
libs.append('ld')
# Finally, link with the X11 libraries (not appropriate on cygwin, mingw)
+ # ...on those platforms, define STATIC_BUILD if linking to static tcl/tk.
if not host_platform in ['cygwin', 'mingw', 'win32']:
libs.append('X11')
+ elif tcllib.endswith('s.a'):
+ defs.append( ('STATIC_BUILD',1) )
ext = Extension('_tkinter', ['_tkinter.c', 'tkappinit.c'],
define_macros=[('WITH_APPINIT', 1)] + defs,