wok-6.x diff python/stuff/python-2.7.3-xcompile.patch @ rev 16594

Up: speedcrunch; slitaz-tools-boxes: fix typo
author Aleksej Bobylev <al.bobylev@gmail.com>
date Wed May 07 04:14:35 2014 +0300 (2014-05-07)
parents
children
line diff
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/python/stuff/python-2.7.3-xcompile.patch	Wed May 07 04:14:35 2014 +0300
     1.3 @@ -0,0 +1,264 @@
     1.4 +diff -ur Python-2.7.3.orig/configure Python-2.7.3-Source/configure
     1.5 +--- Python-2.7.3.orig/configure	2012-04-09 19:07:36.000000000 -0400
     1.6 ++++ Python-2.7.3-Source/configure	2012-10-23 14:10:45.305220393 -0400
     1.7 +@@ -13697,7 +13697,7 @@
     1.8 +   $as_echo_n "(cached) " >&6
     1.9 + else
    1.10 +   if test "$cross_compiling" = yes; then :
    1.11 +-  ac_cv_have_long_long_format=no
    1.12 ++  ac_cv_have_long_long_format="cross -- assuming yes"
    1.13 + else
    1.14 +   cat confdefs.h - <<_ACEOF >conftest.$ac_ext
    1.15 + /* end confdefs.h.  */
    1.16 +@@ -13749,7 +13749,7 @@
    1.17 + $as_echo "$ac_cv_have_long_long_format" >&6; }
    1.18 + fi
    1.19 + 
    1.20 +-if test "$ac_cv_have_long_long_format" = yes
    1.21 ++if test "$ac_cv_have_long_long_format" != no
    1.22 + then
    1.23 + 
    1.24 + $as_echo "#define PY_FORMAT_LONG_LONG \"ll\"" >>confdefs.h
    1.25 +diff -ur Python-2.7.3.orig/Makefile.pre.in Python-2.7.3-Source/Makefile.pre.in
    1.26 +--- Python-2.7.3.orig/Makefile.pre.in	2012-04-09 19:07:33.000000000 -0400
    1.27 ++++ Python-2.7.3-Source/Makefile.pre.in	2012-10-23 14:10:45.305220393 -0400
    1.28 +@@ -182,6 +182,7 @@
    1.29 + 
    1.30 + PYTHON=		python$(EXE)
    1.31 + BUILDPYTHON=	python$(BUILDEXE)
    1.32 ++HOSTPYTHON=     ./$(BUILDPYTHON)
    1.33 + 
    1.34 + # The task to run while instrument when building the profile-opt target
    1.35 + PROFILE_TASK=	$(srcdir)/Tools/pybench/pybench.py -n 2 --with-gc --with-syscheck
    1.36 +@@ -215,6 +216,8 @@
    1.37 + # Parser
    1.38 + PGEN=		Parser/pgen$(EXE)
    1.39 + 
    1.40 ++HOSTPGEN=   $(PGEN)
    1.41 ++
    1.42 + POBJS=		\
    1.43 + 		Parser/acceler.o \
    1.44 + 		Parser/grammar1.o \
    1.45 +@@ -408,8 +411,8 @@
    1.46 + # Build the shared modules
    1.47 + sharedmods: $(BUILDPYTHON)
    1.48 + 	@case $$MAKEFLAGS in \
    1.49 +-	*s*) $(RUNSHARED) CC='$(CC)' LDSHARED='$(BLDSHARED)' OPT='$(OPT)' ./$(BUILDPYTHON) -E $(srcdir)/setup.py -q build;; \
    1.50 +-	*) $(RUNSHARED) CC='$(CC)' LDSHARED='$(BLDSHARED)' OPT='$(OPT)' ./$(BUILDPYTHON) -E $(srcdir)/setup.py build;; \
    1.51 ++	*s*) $(RUNSHARED) CC='$(CC)' LDSHARED='$(BLDSHARED)' OPT='$(OPT)' PYTHONXCPREFIX='$(DESTDIR)$(prefix)' $(HOSTPYTHON) -E $(srcdir)/setup.py -q build;; \
    1.52 ++	*) $(RUNSHARED) CC='$(CC)' LDSHARED='$(BLDSHARED)' OPT='$(OPT)' PYTHONXCPREFIX='$(DESTDIR)$(prefix)' $(HOSTPYTHON) -E $(srcdir)/setup.py build;; \
    1.53 + 	esac
    1.54 + 
    1.55 + # Build static library
    1.56 +@@ -543,7 +546,7 @@
    1.57 + $(GRAMMAR_H) $(GRAMMAR_C): Parser/pgen.stamp
    1.58 + Parser/pgen.stamp: $(PGEN) $(GRAMMAR_INPUT)
    1.59 + 		-@$(INSTALL) -d Include
    1.60 +-		$(PGEN) $(GRAMMAR_INPUT) $(GRAMMAR_H) $(GRAMMAR_C)
    1.61 ++		-$(HOSTPGEN) $(GRAMMAR_INPUT) $(GRAMMAR_H) $(GRAMMAR_C)
    1.62 + 		-touch Parser/pgen.stamp
    1.63 + 
    1.64 + $(PGEN):	$(PGENOBJS)
    1.65 +@@ -938,26 +941,26 @@
    1.66 + 		$(INSTALL_DATA) $(srcdir)/Modules/xxmodule.c \
    1.67 + 			$(DESTDIR)$(LIBDEST)/distutils/tests ; \
    1.68 + 	fi
    1.69 +-	PYTHONPATH=$(DESTDIR)$(LIBDEST)  $(RUNSHARED) \
    1.70 +-		./$(BUILDPYTHON) -Wi -tt $(DESTDIR)$(LIBDEST)/compileall.py \
    1.71 ++	-PYTHONPATH=$(DESTDIR)$(LIBDEST)  $(RUNSHARED) \
    1.72 ++		./$(HOSTPYTHON) -Wi -tt $(DESTDIR)$(LIBDEST)/compileall.py \
    1.73 + 		-d $(LIBDEST) -f \
    1.74 + 		-x 'bad_coding|badsyntax|site-packages|lib2to3/tests/data' \
    1.75 + 		$(DESTDIR)$(LIBDEST)
    1.76 +-	PYTHONPATH=$(DESTDIR)$(LIBDEST) $(RUNSHARED) \
    1.77 +-		./$(BUILDPYTHON) -Wi -tt -O $(DESTDIR)$(LIBDEST)/compileall.py \
    1.78 ++	-PYTHONPATH=$(DESTDIR)$(LIBDEST) $(RUNSHARED) \
    1.79 ++		./$(HOSTPYTHON) -Wi -tt -O $(DESTDIR)$(LIBDEST)/compileall.py \
    1.80 + 		-d $(LIBDEST) -f \
    1.81 + 		-x 'bad_coding|badsyntax|site-packages|lib2to3/tests/data' \
    1.82 + 		$(DESTDIR)$(LIBDEST)
    1.83 + 	-PYTHONPATH=$(DESTDIR)$(LIBDEST)  $(RUNSHARED) \
    1.84 +-		./$(BUILDPYTHON) -Wi -t $(DESTDIR)$(LIBDEST)/compileall.py \
    1.85 ++		./$(HOSTPYTHON) -Wi -t $(DESTDIR)$(LIBDEST)/compileall.py \
    1.86 + 		-d $(LIBDEST)/site-packages -f \
    1.87 + 		-x badsyntax $(DESTDIR)$(LIBDEST)/site-packages
    1.88 + 	-PYTHONPATH=$(DESTDIR)$(LIBDEST) $(RUNSHARED) \
    1.89 +-		./$(BUILDPYTHON) -Wi -t -O $(DESTDIR)$(LIBDEST)/compileall.py \
    1.90 ++		./$(HOSTPYTHON) -Wi -t -O $(DESTDIR)$(LIBDEST)/compileall.py \
    1.91 + 		-d $(LIBDEST)/site-packages -f \
    1.92 + 		-x badsyntax $(DESTDIR)$(LIBDEST)/site-packages
    1.93 + 	-PYTHONPATH=$(DESTDIR)$(LIBDEST) $(RUNSHARED) \
    1.94 +-		./$(BUILDPYTHON) -Wi -t -c "import lib2to3.pygram, lib2to3.patcomp;lib2to3.patcomp.PatternCompiler()"
    1.95 ++		./$(HOSTPYTHON) -Wi -t -c "import lib2to3.pygram, lib2to3.patcomp;lib2to3.patcomp.PatternCompiler()"
    1.96 + 
    1.97 + # Create the PLATDIR source directory, if one wasn't distributed..
    1.98 + $(srcdir)/Lib/$(PLATDIR):
    1.99 +@@ -1062,7 +1065,9 @@
   1.100 + # Install the dynamically loadable modules
   1.101 + # This goes into $(exec_prefix)
   1.102 + sharedinstall: sharedmods
   1.103 +-	$(RUNSHARED) ./$(BUILDPYTHON) -E $(srcdir)/setup.py install \
   1.104 ++	CC='$(CC)' LDSHARED='$(BLDSHARED)' OPT='$(OPT)' \
   1.105 ++	$(RUNSHARED) $(HOSTPYTHON) -E $(srcdir)/setup.py install \
   1.106 ++		--skip-build \
   1.107 + 	   	--prefix=$(prefix) \
   1.108 + 		--install-scripts=$(BINDIR) \
   1.109 + 		--install-platlib=$(DESTSHARED) \
   1.110 +diff -ur Python-2.7.3.orig/setup.py Python-2.7.3-Source/setup.py
   1.111 +--- Python-2.7.3.orig/setup.py	2012-04-09 19:07:36.000000000 -0400
   1.112 ++++ Python-2.7.3-Source/setup.py	2012-10-23 14:10:56.085220237 -0400
   1.113 +@@ -145,6 +145,7 @@
   1.114 +     def __init__(self, dist):
   1.115 +         build_ext.__init__(self, dist)
   1.116 +         self.failed = []
   1.117 ++        self.cross_compile = os.environ.get('CROSS_COMPILE_TARGET') == 'yes'
   1.118 + 
   1.119 +     def build_extensions(self):
   1.120 + 
   1.121 +@@ -278,6 +279,14 @@
   1.122 +                           (ext.name, sys.exc_info()[1]))
   1.123 +             self.failed.append(ext.name)
   1.124 +             return
   1.125 ++
   1.126 ++        # Import check will not work when cross-compiling.
   1.127 ++        if os.environ.has_key('PYTHONXCPREFIX'):
   1.128 ++            self.announce(
   1.129 ++                'WARNING: skipping import check for cross-compiled: "%s"' %
   1.130 ++                ext.name)
   1.131 ++            return
   1.132 ++
   1.133 +         # Workaround for Mac OS X: The Carbon-based modules cannot be
   1.134 +         # reliably imported into a command-line Python
   1.135 +         if 'Carbon' in ext.extra_link_args:
   1.136 +@@ -369,9 +378,10 @@
   1.137 + 
   1.138 +     def detect_modules(self):
   1.139 +         # Ensure that /usr/local is always used
   1.140 +-        add_dir_to_list(self.compiler.library_dirs, '/usr/local/lib')
   1.141 +-        add_dir_to_list(self.compiler.include_dirs, '/usr/local/include')
   1.142 +-        self.add_multiarch_paths()
   1.143 ++        if not self.cross_compile:
   1.144 ++            add_dir_to_list(self.compiler.library_dirs, '/usr/local/lib')
   1.145 ++            add_dir_to_list(self.compiler.include_dirs, '/usr/local/include')
   1.146 ++            self.add_multiarch_paths()
   1.147 + 
   1.148 +         # Add paths specified in the environment variables LDFLAGS and
   1.149 +         # CPPFLAGS for header and library files.
   1.150 +@@ -408,7 +418,8 @@
   1.151 +                         add_dir_to_list(dir_list, directory)
   1.152 + 
   1.153 +         if os.path.normpath(sys.prefix) != '/usr' \
   1.154 +-                and not sysconfig.get_config_var('PYTHONFRAMEWORK'):
   1.155 ++                and not sysconfig.get_config_var('PYTHONFRAMEWORK') \
   1.156 ++                and not self.cross_compile:
   1.157 +             # OSX note: Don't add LIBDIR and INCLUDEDIR to building a framework
   1.158 +             # (PYTHONFRAMEWORK is set) to avoid # linking problems when
   1.159 +             # building a framework with different architectures than
   1.160 +@@ -426,11 +437,23 @@
   1.161 +         # lib_dirs and inc_dirs are used to search for files;
   1.162 +         # if a file is found in one of those directories, it can
   1.163 +         # be assumed that no additional -I,-L directives are needed.
   1.164 +-        lib_dirs = self.compiler.library_dirs + [
   1.165 +-            '/lib64', '/usr/lib64',
   1.166 +-            '/lib', '/usr/lib',
   1.167 +-            ]
   1.168 +-        inc_dirs = self.compiler.include_dirs + ['/usr/include']
   1.169 ++        lib_dirs = self.compiler.library_dirs
   1.170 ++        inc_dirs = self.compiler.include_dirs
   1.171 ++        if not self.cross_compile:
   1.172 ++            lib_dirs += [
   1.173 ++                '/lib64', '/usr/lib64',
   1.174 ++                '/lib', '/usr/lib',
   1.175 ++                ]
   1.176 ++            inc_dirs += ['/usr/include']
   1.177 ++        else:
   1.178 ++            # The common install prefix of 3rd party libraries used during
   1.179 ++            # cross compilation
   1.180 ++            mydir = os.environ.get('PYTHON_XCOMPILE_DEPENDENCIES_PREFIX')
   1.181 ++            if mydir:
   1.182 ++                inc_dirs += [mydir + '/include' ]
   1.183 ++                inc_dirs += [mydir + '/lib/libffi-3.0.10/include']
   1.184 ++                lib_dirs += [mydir + '/lib' ]
   1.185 ++
   1.186 +         exts = []
   1.187 +         missing = []
   1.188 + 
   1.189 +@@ -1004,13 +1027,24 @@
   1.190 +         # We hunt for #define SQLITE_VERSION "n.n.n"
   1.191 +         # We need to find >= sqlite version 3.0.8
   1.192 +         sqlite_incdir = sqlite_libdir = None
   1.193 +-        sqlite_inc_paths = [ '/usr/include',
   1.194 +-                             '/usr/include/sqlite',
   1.195 +-                             '/usr/include/sqlite3',
   1.196 +-                             '/usr/local/include',
   1.197 +-                             '/usr/local/include/sqlite',
   1.198 +-                             '/usr/local/include/sqlite3',
   1.199 +-                           ]
   1.200 ++
   1.201 ++        if not self.cross_compile:
   1.202 ++            sqlite_inc_paths = [ '/usr/include',
   1.203 ++                                 '/usr/include/sqlite',
   1.204 ++                                 '/usr/include/sqlite3',
   1.205 ++                                 '/usr/local/include',
   1.206 ++                                 '/usr/local/include/sqlite',
   1.207 ++                                 '/usr/local/include/sqlite3',
   1.208 ++                                ]
   1.209 ++        else:
   1.210 ++            # The common install prefix of 3rd party headers used during
   1.211 ++            # cross compilation
   1.212 ++            mydir = os.environ.get('PYTHON_XCOMPILE_DEPENDENCIES_PREFIX')
   1.213 ++            if mydir:
   1.214 ++                sqlite_inc_paths = [mydir + '/include' ]
   1.215 ++            else:
   1.216 ++                sqlite_inc_paths = []
   1.217 ++
   1.218 +         MIN_SQLITE_VERSION_NUMBER = (3, 0, 8)
   1.219 +         MIN_SQLITE_VERSION = ".".join([str(x)
   1.220 +                                     for x in MIN_SQLITE_VERSION_NUMBER])
   1.221 +@@ -1050,12 +1084,22 @@
   1.222 +                     print "sqlite: %s had no SQLITE_VERSION"%(f,)
   1.223 + 
   1.224 +         if sqlite_incdir:
   1.225 +-            sqlite_dirs_to_check = [
   1.226 +-                os.path.join(sqlite_incdir, '..', 'lib64'),
   1.227 +-                os.path.join(sqlite_incdir, '..', 'lib'),
   1.228 +-                os.path.join(sqlite_incdir, '..', '..', 'lib64'),
   1.229 +-                os.path.join(sqlite_incdir, '..', '..', 'lib'),
   1.230 +-            ]
   1.231 ++            if not self.cross_compile:
   1.232 ++                sqlite_dirs_to_check = [
   1.233 ++                    os.path.join(sqlite_incdir, '..', 'lib64'),
   1.234 ++                    os.path.join(sqlite_incdir, '..', 'lib'),
   1.235 ++                    os.path.join(sqlite_incdir, '..', '..', 'lib64'),
   1.236 ++                    os.path.join(sqlite_incdir, '..', '..', 'lib'),
   1.237 ++                ]
   1.238 ++            else:
   1.239 ++                # The common install prefix of 3rd party headers used during
   1.240 ++                # cross compilation
   1.241 ++                mydir = os.environ.get('PYTHON_XCOMPILE_DEPENDENCIES_PREFIX')
   1.242 ++                if mydir:
   1.243 ++                    sqlite_dirs_to_check = [mydir + '/lib' ]
   1.244 ++                else:
   1.245 ++                    sqlite_dirs_to_check = []
   1.246 ++
   1.247 +             sqlite_libfile = self.compiler.find_library_file(
   1.248 +                                 sqlite_dirs_to_check + lib_dirs, 'sqlite3')
   1.249 +             if sqlite_libfile:
   1.250 +@@ -1864,8 +1908,15 @@
   1.251 + 
   1.252 +                 # Pass empty CFLAGS because we'll just append the resulting
   1.253 +                 # CFLAGS to Python's; -g or -O2 is to be avoided.
   1.254 +-                cmd = "cd %s && env CFLAGS='' '%s/configure' %s" \
   1.255 +-                      % (ffi_builddir, ffi_srcdir, " ".join(config_args))
   1.256 ++                if self.cross_compile:
   1.257 ++                    cmd = "cd %s && env CFLAGS='' %s/configure --host=%s --build=%s %s" \
   1.258 ++                          % (ffi_builddir, ffi_srcdir,
   1.259 ++                             os.environ.get('HOSTARCH'),
   1.260 ++                             os.environ.get('BUILDARCH'),
   1.261 ++                             " ".join(config_args))
   1.262 ++                else:
   1.263 ++                    cmd = "cd %s && env CFLAGS='' '%s/configure' %s" \
   1.264 ++                          % (ffi_builddir, ffi_srcdir, " ".join(config_args))
   1.265 + 
   1.266 +                 res = os.system(cmd)
   1.267 +                 if res or not os.path.exists(ffi_configfile):