Blame 00102-lib64.patch

001857d
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
213569f
From: David Malcolm <dmalcolm@redhat.com>
213569f
Date: Wed, 13 Jan 2010 21:25:18 +0000
213569f
Subject: [PATCH] 00102: Change the various install paths to use /usr/lib64/
213569f
 instead or /usr/lib/
213569f
MIME-Version: 1.0
213569f
Content-Type: text/plain; charset=UTF-8
213569f
Content-Transfer-Encoding: 8bit
213569f
213569f
Only used when "%{_lib}" == "lib64".
213569f
213569f
Co-authored-by: David Malcolm <dmalcolm@redhat.com>
213569f
Co-authored-by: Thomas Spura <tomspur@fedoraproject.org>
213569f
Co-authored-by: Slavek Kabrda <bkabrda@redhat.com>
213569f
Co-authored-by: Matej Stuchlik <mstuchli@redhat.com>
213569f
Co-authored-by: Tomas Orsava <torsava@redhat.com>
213569f
Co-authored-by: Charalampos Stratakis <cstratak@redhat.com>
213569f
Co-authored-by: Petr Viktorin <pviktori@redhat.com>
213569f
Co-authored-by: Miro HronĨok <miro@hroncok.cz>
213569f
Co-authored-by: Iryna Shcherbina <shcherbina.iryna@gmail.com>
213569f
---
213569f
 Lib/distutils/command/install.py    |  4 ++--
213569f
 Lib/distutils/sysconfig.py          |  6 +++++-
213569f
 Lib/distutils/tests/test_install.py |  3 ++-
213569f
 Lib/site.py                         |  4 ++++
213569f
 Lib/sysconfig.py                    | 12 ++++++------
213569f
 Lib/test/test_site.py               |  4 ++--
213569f
 Makefile.pre.in                     |  2 +-
213569f
 Modules/getpath.c                   |  6 +++---
213569f
 configure.ac                        |  4 ++--
213569f
 setup.py                            |  6 +++---
213569f
 10 files changed, 30 insertions(+), 21 deletions(-)
213569f
490fd61
diff --git a/Lib/distutils/command/install.py b/Lib/distutils/command/install.py
213569f
index 0258d3deae..4b969bf809 100644
490fd61
--- a/Lib/distutils/command/install.py
490fd61
+++ b/Lib/distutils/command/install.py
490fd61
@@ -30,14 +30,14 @@ WINDOWS_SCHEME = {
490fd61
 INSTALL_SCHEMES = {
490fd61
     'unix_prefix': {
490fd61
         'purelib': '$base/lib/python$py_version_short/site-packages',
490fd61
-        'platlib': '$platbase/lib/python$py_version_short/site-packages',
490fd61
+        'platlib': '$platbase/lib64/python$py_version_short/site-packages',
490fd61
         'headers': '$base/include/python$py_version_short$abiflags/$dist_name',
490fd61
         'scripts': '$base/bin',
490fd61
         'data'   : '$base',
490fd61
         },
490fd61
     'unix_home': {
490fd61
         'purelib': '$base/lib/python',
490fd61
-        'platlib': '$base/lib/python',
490fd61
+        'platlib': '$base/lib64/python',
490fd61
         'headers': '$base/include/python/$dist_name',
490fd61
         'scripts': '$base/bin',
490fd61
         'data'   : '$base',
490fd61
diff --git a/Lib/distutils/sysconfig.py b/Lib/distutils/sysconfig.py
213569f
index 0a034ee09b..3ce0dc1645 100644
490fd61
--- a/Lib/distutils/sysconfig.py
490fd61
+++ b/Lib/distutils/sysconfig.py
3141f16
@@ -147,8 +147,12 @@ def get_python_lib(plat_specific=0, standard_lib=0, prefix=None):
490fd61
             prefix = plat_specific and EXEC_PREFIX or PREFIX
490fd61
 
490fd61
     if os.name == "posix":
490fd61
+        if plat_specific or standard_lib:
490fd61
+            lib = "lib64"
490fd61
+        else:
490fd61
+            lib = "lib"
490fd61
         libpython = os.path.join(prefix,
490fd61
-                                 "lib", "python" + get_python_version())
490fd61
+                                 lib, "python" + get_python_version())
490fd61
         if standard_lib:
490fd61
             return libpython
490fd61
         else:
490fd61
diff --git a/Lib/distutils/tests/test_install.py b/Lib/distutils/tests/test_install.py
213569f
index 287ab1989e..d4c05e0ab1 100644
490fd61
--- a/Lib/distutils/tests/test_install.py
490fd61
+++ b/Lib/distutils/tests/test_install.py
490fd61
@@ -57,8 +57,9 @@ class InstallTestCase(support.TempdirManager,
490fd61
             self.assertEqual(got, expected)
490fd61
 
490fd61
         libdir = os.path.join(destination, "lib", "python")
490fd61
+        platlibdir = os.path.join(destination, "lib64", "python")
490fd61
         check_path(cmd.install_lib, libdir)
490fd61
-        check_path(cmd.install_platlib, libdir)
490fd61
+        check_path(cmd.install_platlib, platlibdir)
490fd61
         check_path(cmd.install_purelib, libdir)
490fd61
         check_path(cmd.install_headers,
490fd61
                    os.path.join(destination, "include", "python", "foopkg"))
490fd61
diff --git a/Lib/site.py b/Lib/site.py
213569f
index 878658827c..78bb7905f2 100644
490fd61
--- a/Lib/site.py
490fd61
+++ b/Lib/site.py
490fd61
@@ -334,11 +334,15 @@ def getsitepackages(prefixes=None):
490fd61
         seen.add(prefix)
490fd61
 
490fd61
         if os.sep == '/':
490fd61
+            sitepackages.append(os.path.join(prefix, "lib64",
490fd61
+                                        "python" + sys.version[:3],
490fd61
+                                        "site-packages"))
490fd61
             sitepackages.append(os.path.join(prefix, "lib",
490fd61
                                         "python%d.%d" % sys.version_info[:2],
490fd61
                                         "site-packages"))
490fd61
         else:
490fd61
             sitepackages.append(prefix)
490fd61
+            sitepackages.append(os.path.join(prefix, "lib64", "site-packages"))
490fd61
             sitepackages.append(os.path.join(prefix, "lib", "site-packages"))
490fd61
     return sitepackages
490fd61
 
490fd61
diff --git a/Lib/sysconfig.py b/Lib/sysconfig.py
213569f
index d15cec8dbf..159c78bb99 100644
490fd61
--- a/Lib/sysconfig.py
490fd61
+++ b/Lib/sysconfig.py
490fd61
@@ -20,10 +20,10 @@ __all__ = [
490fd61
 
490fd61
 _INSTALL_SCHEMES = {
490fd61
     'posix_prefix': {
490fd61
-        'stdlib': '{installed_base}/lib/python{py_version_short}',
490fd61
-        'platstdlib': '{platbase}/lib/python{py_version_short}',
490fd61
+        'stdlib': '{installed_base}/lib64/python{py_version_short}',
490fd61
+        'platstdlib': '{platbase}/lib64/python{py_version_short}',
490fd61
         'purelib': '{base}/lib/python{py_version_short}/site-packages',
490fd61
-        'platlib': '{platbase}/lib/python{py_version_short}/site-packages',
490fd61
+        'platlib': '{platbase}/lib64/python{py_version_short}/site-packages',
490fd61
         'include':
490fd61
             '{installed_base}/include/python{py_version_short}{abiflags}',
490fd61
         'platinclude':
490fd61
@@ -62,10 +62,10 @@ _INSTALL_SCHEMES = {
490fd61
         'data': '{userbase}',
490fd61
         },
490fd61
     'posix_user': {
490fd61
-        'stdlib': '{userbase}/lib/python{py_version_short}',
490fd61
-        'platstdlib': '{userbase}/lib/python{py_version_short}',
490fd61
+        'stdlib': '{userbase}/lib64/python{py_version_short}',
490fd61
+        'platstdlib': '{userbase}/lib64/python{py_version_short}',
490fd61
         'purelib': '{userbase}/lib/python{py_version_short}/site-packages',
490fd61
-        'platlib': '{userbase}/lib/python{py_version_short}/site-packages',
490fd61
+        'platlib': '{userbase}/lib64/python{py_version_short}/site-packages',
490fd61
         'include': '{userbase}/include/python{py_version_short}',
490fd61
         'scripts': '{userbase}/bin',
490fd61
         'data': '{userbase}',
490fd61
diff --git a/Lib/test/test_site.py b/Lib/test/test_site.py
213569f
index 6def4e59f4..6e427bf6e2 100644
490fd61
--- a/Lib/test/test_site.py
490fd61
+++ b/Lib/test/test_site.py
213569f
@@ -270,8 +270,8 @@ class HelperFunctionsTests(unittest.TestCase):
490fd61
         dirs = site.getsitepackages()
490fd61
         if os.sep == '/':
490fd61
             # OS X, Linux, FreeBSD, etc
490fd61
-            self.assertEqual(len(dirs), 1)
490fd61
-            wanted = os.path.join('xoxo', 'lib',
490fd61
+            self.assertEqual(len(dirs), 2)
490fd61
+            wanted = os.path.join('xoxo', 'lib64',
490fd61
                                   'python%d.%d' % sys.version_info[:2],
490fd61
                                   'site-packages')
490fd61
             self.assertEqual(dirs[0], wanted)
490fd61
diff --git a/Makefile.pre.in b/Makefile.pre.in
213569f
index 35ca1a8684..78152c1e2f 100644
490fd61
--- a/Makefile.pre.in
490fd61
+++ b/Makefile.pre.in
3141f16
@@ -144,7 +144,7 @@ LIBDIR=		@libdir@
490fd61
 MANDIR=		@mandir@
490fd61
 INCLUDEDIR=	@includedir@
490fd61
 CONFINCLUDEDIR=	$(exec_prefix)/include
490fd61
-SCRIPTDIR=	$(prefix)/lib
490fd61
+SCRIPTDIR=	$(prefix)/lib64
490fd61
 ABIFLAGS=	@ABIFLAGS@
490fd61
 
490fd61
 # Detailed destination directories
490fd61
diff --git a/Modules/getpath.c b/Modules/getpath.c
213569f
index ba8d74b4a0..198e8f086e 100644
490fd61
--- a/Modules/getpath.c
490fd61
+++ b/Modules/getpath.c
3141f16
@@ -535,7 +535,7 @@ calculate_exec_prefix(const _PyCoreConfig *core_config,
490fd61
                 "Could not find platform dependent libraries <exec_prefix>\n");
490fd61
         }
490fd61
         wcsncpy(exec_prefix, calculate->exec_prefix, MAXPATHLEN);
490fd61
-        joinpath(exec_prefix, L"lib/lib-dynload");
490fd61
+        joinpath(exec_prefix, L"lib64/lib-dynload");
490fd61
     }
490fd61
     /* If we found EXEC_PREFIX do *not* reduce it!  (Yet.) */
490fd61
 }
3141f16
@@ -787,7 +787,7 @@ calculate_zip_path(PyCalculatePath *calculate, const wchar_t *prefix)
490fd61
     else {
490fd61
         wcsncpy(calculate->zip_path, calculate->prefix, MAXPATHLEN);
490fd61
     }
490fd61
-    joinpath(calculate->zip_path, L"lib/python00.zip");
490fd61
+    joinpath(calculate->zip_path, L"lib64/python00.zip");
490fd61
 
490fd61
     /* Replace "00" with version */
490fd61
     size_t bufsz = wcslen(calculate->zip_path);
3141f16
@@ -912,7 +912,7 @@ calculate_init(PyCalculatePath *calculate,
3141f16
     if (!calculate->exec_prefix) {
490fd61
         return DECODE_LOCALE_ERR("EXEC_PREFIX define", len);
490fd61
     }
490fd61
-    calculate->lib_python = Py_DecodeLocale("lib/python" VERSION, &len;;
490fd61
+    calculate->lib_python = Py_DecodeLocale("lib64/python" VERSION, &len;;
490fd61
     if (!calculate->lib_python) {
490fd61
         return DECODE_LOCALE_ERR("EXEC_PREFIX define", len);
490fd61
     }
213569f
diff --git a/configure.ac b/configure.ac
213569f
index 805c0bba08..6f11a6df5b 100644
213569f
--- a/configure.ac
213569f
+++ b/configure.ac
213569f
@@ -4772,9 +4772,9 @@ AC_MSG_RESULT($LDVERSION)
213569f
 dnl define LIBPL after ABIFLAGS and LDVERSION is defined.
213569f
 AC_SUBST(PY_ENABLE_SHARED)
213569f
 if test x$PLATFORM_TRIPLET = x; then
213569f
-  LIBPL='$(prefix)'"/lib/python${VERSION}/config-${LDVERSION}"
213569f
+  LIBPL='$(prefix)'"/lib64/python${VERSION}/config-${LDVERSION}"
213569f
 else
213569f
-  LIBPL='$(prefix)'"/lib/python${VERSION}/config-${LDVERSION}-${PLATFORM_TRIPLET}"
213569f
+  LIBPL='$(prefix)'"/lib64/python${VERSION}/config-${LDVERSION}-${PLATFORM_TRIPLET}"
213569f
 fi
213569f
 AC_SUBST(LIBPL)
213569f
 
490fd61
diff --git a/setup.py b/setup.py
213569f
index bf90600eaa..8070b86c2f 100644
490fd61
--- a/setup.py
490fd61
+++ b/setup.py
3141f16
@@ -585,7 +585,7 @@ class PyBuildExt(build_ext):
490fd61
         # directories (i.e. '.' and 'Include') must be first.  See issue
490fd61
         # 10520.
490fd61
         if not cross_compiling:
490fd61
-            add_dir_to_list(self.compiler.library_dirs, '/usr/local/lib')
490fd61
+            add_dir_to_list(self.compiler.library_dirs, '/usr/local/lib64')
490fd61
             add_dir_to_list(self.compiler.include_dirs, '/usr/local/include')
490fd61
         # only change this for cross builds for 3.3, issues on Mageia
490fd61
         if cross_compiling:
3141f16
@@ -891,11 +891,11 @@ class PyBuildExt(build_ext):
490fd61
             elif curses_library:
490fd61
                 readline_libs.append(curses_library)
490fd61
             elif self.compiler.find_library_file(lib_dirs +
490fd61
-                                                     ['/usr/lib/termcap'],
490fd61
+                                                     ['/usr/lib64/termcap'],
490fd61
                                                      'termcap'):
490fd61
                 readline_libs.append('termcap')
490fd61
             exts.append( Extension('readline', ['readline.c'],
490fd61
-                                   library_dirs=['/usr/lib/termcap'],
490fd61
+                                   library_dirs=['/usr/lib64/termcap'],
490fd61
                                    extra_link_args=readline_extra_link_args,
490fd61
                                    libraries=readline_libs) )
490fd61
         else: