This issue tracker has been migrated to GitHub ,
and is currently read-only.
For more information,
see the GitHub FAQs in the Python's Developer Guide.
Created on 2003年12月12日 10:24 by nijel, last changed 2022年04月11日 14:56 by admin. This issue is now closed.
| Files | ||||
|---|---|---|---|---|
| File name | Uploaded | Description | Edit | |
| Python-2.3.2-dirs.patch | nijel, 2003年12月12日 10:24 | |||
| Messages (20) | |||
|---|---|---|---|
| msg45042 - (view) | Author: Michal Čihař (nijel) * | Date: 2003年12月12日 10:24 | |
Current Makefile.pre.in contains paths like $(exec_prefix)/lib, which bad especially for mixed 32-bit and 64-bit systems, where 64-bit things should go to /lib64. Attached patch changes these paths to @libdir@ (and does also simmilar changes for other paths), which is usually outputed from configure. |
|||
| msg45043 - (view) | Author: Matejcik (spektrum) | Date: 2006年09月11日 17:44 | |
Logged In: YES user_id=631694 this patch confuses the python 2.5 build process in a very mysterious way - setup.py ends up using -L/usr/lib/python2.5/config instead of -L. for libpython2.5.so, which is obviously wrong. |
|||
| msg45045 - (view) | Author: Michal Čihař (nijel) * | Date: 2006年09月11日 18:07 | |
Logged In: YES user_id=192186 That doesn't surprise me, it was written in times of python 2.3... |
|||
| msg45046 - (view) | Author: Matejcik (spektrum) | Date: 2006年09月11日 20:12 | |
Logged In: YES user_id=631694 well obviously, but if you look at the patch, there is exactly -nothing- wrong with it. actually, i'm surprised that it didn't get into 2.4 release. but what's more, it should have no effect on setup.py at all |
|||
| msg65368 - (view) | Author: Sérgio Durigan Júnior (sergiodj) | Date: 2008年04月11日 19:48 | |
Hi, Continuing with my effort to improve Python's build system, I'd really like to know why this issue has not been solved yet. I mean, apparently this problem is still present in Python 2.5, since I can't change the library's path with --libdir configure's flag. Any news about it? |
|||
| msg73812 - (view) | Author: Joseph Rothrock (rothrock) | Date: 2008年09月25日 20:38 | |
Hi, This problem still exists in 2.5.2. Setting the libdir argument doesn't correctly set LIBDIR in the Makefile. [rothrock@su1 Python-2.5.2]$ ./configure --prefix=/home/y --libdir=/home/y/lib64 ... [rothrock@su1 Python-2.5.2]$ cat Makefile | grep LIBDIR= LIBDIR= $(exec_prefix)/lib |
|||
| msg76707 - (view) | Author: Roumen Petrov (rpetrov) * | Date: 2008年12月01日 21:41 | |
The complete patch require redesign of python-distutils ;) |
|||
| msg83076 - (view) | Author: jan matejek (matejcik) * | Date: 2009年03月03日 17:34 | |
well, seeing as redesign of distutils probably won't happen anytime soon... why don't we fix the obvious bug (broken configure) now and redesign distutils later? |
|||
| msg83077 - (view) | Author: jan matejek (matejcik) * | Date: 2009年03月03日 17:36 | |
...the patch is absolutely trivial, doesn't have any deep consequences and applies cleanly to head and all branches i know of. ...i wonder if the patch-fasttracking offer still applies... |
|||
| msg87857 - (view) | Author: (soundmurderer) | Date: 2009年05月16日 05:02 | |
I can confirm that --bindir and --libdir are broken in Python 2.6.2,
despite the fact that ./configure --help lists them as helpful options.
At the very least, ./configure should complain if you're using options
that don't do anything! That would be the easy fix.
Here is what I am doing:
./configure \
--prefix=/home/soundmurderer \
--bindir=/home/soundmurderer/bin/x86_64/Python-2.6.2 \
--libdir=/home/soundmurderer/lib/x86_64
OK, now let's see the relevant section of the generated Makefile:
# Install prefix for architecture-independent files
prefix= /home/soundmurderer/auzilov
# Install prefix for architecture-dependent files
exec_prefix= ${prefix}
# Install prefix for data files
datarootdir= ${prefix}/share
# Expanded directories
BINDIR= $(exec_prefix)/bin
LIBDIR= $(exec_prefix)/lib
MANDIR= ${datarootdir}/man
INCLUDEDIR= ${prefix}/include
CONFINCLUDEDIR= $(exec_prefix)/include
SCRIPTDIR= $(prefix)/lib
# Detailed destination directories
BINLIBDEST= $(LIBDIR)/python$(VERSION)
LIBDEST= $(SCRIPTDIR)/python$(VERSION)
INCLUDEPY= $(INCLUDEDIR)/python$(VERSION)
CONFINCLUDEPY= $(CONFINCLUDEDIR)/python$(VERSION)
LIBP= $(LIBDIR)/python$(VERSION)
So, the --libdir and --bindir flags had no effect on LIBDIR and BINDIR,
and I wind up editing the Makefile by hand to get desired behavior.
|
|||
| msg87858 - (view) | Author: (soundmurderer) | Date: 2009年05月16日 05:56 | |
I tried applying nijel's 2.3.2 patch to Python 2.6.2 Makefile.pre.in, then configure/make/install with --bindir and --libdir flags to ./configure. It works in terms of producing the correct Makefile with LIBDIR and BINDIR that I want, but I get problems after the "make install" step when I launch the Python interpreter. This is what happens: Could not find platform independent libraries <prefix> Could not find platform dependent libraries <exec_prefix> Consider setting $PYTHONHOME to <prefix>[:<exec_prefix>] 'import site' failed; use -v for traceback Python 2.6.2 (r262:71600, May 15 2009, 22:46:19) [GCC 4.1.2 20080704 (Red Hat 4.1.2-44)] on linux2 Type "help", "copyright", "credits" or "license" for more information. I can work around bad imports and "could not find libraries" by adding various subdirs of my desired LIBDIR to PYTHONHOME and PYTHONPATH. But the point is -- I thought that a *properly* installed Python distribution should know where to find its own standard libraries?? I should not have to hack PYTHONHOME and PYTHONPATH to get my local install to work... right? Once upon a time in 2.5.x days, I was able to do a local install using only ./configure --prefix, and that's it. No hacking PYTHONHOME or PYTHONPATH that I recall. How is the path to stuff like site.py getting encoded in the Python installation? Because I suspect that although nijel's patch may work for generating makefiles that put binaries/libs in the right place, that encoding step is still getting botched, requiring to manually set PYTHONHOME and PYTHONPATH as a workaround. Or maybe I am just confused. |
|||
| msg88065 - (view) | Author: (soundmurderer) | Date: 2009年05月19日 05:42 | |
OK, I am now convinced that even with this patch, the Python build process still won't work correctly because --libdir (post-patch) will not correctly set the default PYTHONHOME. Moreover, the very way that PYTHONHOME gets used needs to change. PYTHONHOME specifies "prefix" and/or "exec_prefix", but the problem is that to find the lib dir, Python tacks "lib/pythonX.X" onto the ends of these paths! More info here: http://docs.python.org/using/unix.html#python-related-paths-and-files http://docs.python.org/using/cmdline.html#envvar-PYTHONHOME So, even with this patch, I still can't install, for example, to: /home/soundmurderer/lib/x86_64/python2.6 I am forced to install to a location that ends with "lib/python2.6", e.g.: /home/soundmurderer/x86_64/lib/python2.6 or else hack some stuff together with symlinks to make PYTHONHOME go to the right place. This seems to be a problem more fundamental than just incomplete "./configure" in the build process and I think it warrants another ticket, which I'm about to open. Now, in regards to --libdir, even though the patch makes the installation put the files in the expected location, Python will probably not find it. |
|||
| msg88067 - (view) | Author: (soundmurderer) | Date: 2009年05月19日 05:53 | |
OK done, opened a feature request for this pet peeve of mine. ;-) Maybe someday I'll complain about something substantial... See: http://bugs.python.org/issue6060 |
|||
| msg112209 - (view) | Author: Éric Araujo (eric.araujo) * (Python committer) | Date: 2010年07月31日 21:17 | |
FYI, disutils is being improved as a new package named distutils2. It is not a complete redesign, but we break backward compatibility when required, so there’s hope. |
|||
| msg114578 - (view) | Author: Éric Araujo (eric.araujo) * (Python committer) | Date: 2010年08月21日 22:25 | |
About lib vs. lib64 vs. lib32, see also http://bugs.python.org/issue1294959#msg94941 |
|||
| msg114580 - (view) | Author: Éric Araujo (eric.araujo) * (Python committer) | Date: 2010年08月21日 22:29 | |
I don’t know much about Makefile.pre.in, so I can’t say anything about the patch. Martin, could you maybe comment? |
|||
| msg114581 - (view) | Author: Éric Araujo (eric.araujo) * (Python committer) | Date: 2010年08月21日 22:33 | |
From http://bugs.python.org/issue1294959#msg94986 "The main problem is that Python's configuration system is not geared up to having the lib directories for platform dependent and platform independent parts use different names. It currently only supports using different path *prefixes* for such setups (--prefix and --exec-prefix), e.g. /usr and /usr64 would work just fine. It doesn't follow --libdir." So I don’t know whether there can be a simple fix for this or if we have to wait for the new sysconfig module (see http://bitbucket.org/tarek/distutils2/src/tip/docs/design/wiki.rst) |
|||
| msg114585 - (view) | Author: Martin v. Löwis (loewis) * (Python committer) | Date: 2010年08月21日 22:44 | |
I don't think anything in distutils can solve whatever the problem is that people perceive. All I can say about the patch is that it apparently doesn't do any harm. I expect that, if it is accepted, people continue complain that "it doesn't work". Unfortunately, Michal Čihař never indicated what *specific* problem this patch is supposed to solve, so it is difficult to tell whether it actually achieves that objective (the literal description "64-bit things should go to /lib64" is not achieved by the patch - it never mentions "lib64". |
|||
| msg114715 - (view) | Author: jan matejek (matejcik) * | Date: 2010年08月22日 22:57 | |
the problem this patch was solving is "python libraries install into "prefix/lib" regardless of what is the correct local LIBDIR" - which is obviously broken on systems where LIBDIR is something other than "prefix/lib", most notable example being "prefix/lib64" on current 64bit linuxes. but as far i can tell, this problem was fixed (to an extent) in 2.7 by partially applying this patch. SCRIPTDIR is still prefix/lib, but the correctness of that is up for a long and winded debate. |
|||
| msg361843 - (view) | Author: STINNER Victor (vstinner) * (Python committer) | Date: 2020年02月12日 00:53 | |
Start of this issue: "Current Makefile.pre.in contains paths like $(exec_prefix)/lib, which bad especially for mixed 32-bit and 64-bit systems, where 64-bit things should go to /lib64." That's a duplicate of bpo-1294959. This issue discuss also modifying distutils but there is no clear plan on how it should behave or not. My PR 18381 of bpo-1294959 updates sysconfig and distutils to support $prefix/$python_libdir/ path. |
|||
| History | |||
|---|---|---|---|
| Date | User | Action | Args |
| 2022年04月11日 14:56:01 | admin | set | github: 39699 |
| 2020年02月12日 00:53:00 | vstinner | set | status: open -> closed superseder: Add sys.platlibdir and configure --with-platlibdir to use /usr/lib64 on Fedora and SuSE nosy: + vstinner messages: + msg361843 resolution: duplicate stage: needs patch -> resolved |
| 2011年03月16日 13:55:16 | andybuckley | set | nosy:
+ andybuckley |
| 2010年08月22日 22:57:33 | matejcik | set | messages: + msg114715 |
| 2010年08月21日 22:44:56 | loewis | set | messages: + msg114585 |
| 2010年08月21日 22:33:12 | eric.araujo | set | messages: + msg114581 |
| 2010年08月21日 22:29:23 | eric.araujo | set | nosy:
+ loewis messages: + msg114580 |
| 2010年08月21日 22:25:44 | eric.araujo | set | messages: - msg45044 |
| 2010年08月21日 22:25:15 | eric.araujo | set | messages: + msg114578 |
| 2010年08月11日 05:49:28 | eric.araujo | link | issue1019715 superseder |
| 2010年07月31日 21:17:29 | eric.araujo | set | messages:
+ msg112209 versions: + Python 3.2, - Python 2.6, Python 3.1 |
| 2010年05月15日 23:46:07 | eric.araujo | set | messages: - msg105838 |
| 2010年05月15日 23:45:51 | eric.araujo | set | assignee: skrah -> tarek messages: + msg105838 nosy: - skrah |
| 2010年05月15日 23:44:53 | eric.araujo | set | assignee: tarek -> skrah nosy: + skrah, eric.araujo |
| 2009年11月06日 16:46:11 | Arfrever | set | nosy:
+ Arfrever |
| 2009年05月19日 23:38:14 | ajaksu2 | set | nosy:
+ tarek versions: + Python 3.1, - Python 2.5, Python 3.0, Python 2.7 assignee: tarek components: + Distutils type: behavior stage: needs patch |
| 2009年05月19日 05:53:33 | soundmurderer | set | messages: + msg88067 |
| 2009年05月19日 05:43:34 | soundmurderer | set | messages: + msg88065 |
| 2009年05月16日 05:56:17 | soundmurderer | set | messages: + msg87858 |
| 2009年05月16日 05:02:34 | soundmurderer | set | nosy:
+ soundmurderer messages: + msg87857 |
| 2009年03月03日 17:36:02 | matejcik | set | messages: + msg83077 |
| 2009年03月03日 17:34:04 | matejcik | set | messages: + msg83076 |
| 2009年03月03日 16:20:49 | matejcik | set | nosy: + matejcik |
| 2008年12月10日 09:09:09 | loewis | set | versions: - Python 2.5.3 |
| 2008年12月01日 21:41:13 | rpetrov | set | nosy:
+ rpetrov messages: + msg76707 |
| 2008年12月01日 17:00:05 | akitada | set | versions: + Python 2.6, Python 3.0, Python 2.7, Python 2.5.3 |
| 2008年09月25日 20:38:48 | rothrock | set | nosy:
+ rothrock messages: + msg73812 versions: + Python 2.5, - Python 2.3 |
| 2008年04月11日 19:49:00 | sergiodj | set | nosy:
+ sergiodj messages: + msg65368 |
| 2003年12月12日 10:24:30 | nijel | create | |