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.

classification
Title: sys.path is incorrect when prefix is ""
Type: behavior Stage: resolved
Components: Interpreter Core Versions: Python 2.6
process
Status: closed Resolution: out of date
Dependencies: Superseder:
Assigned To: Nosy List: christian.heimes, msmith@cbnco.com, numerodix, pconnell, r.david.murray, sunfinite
Priority: normal Keywords: patch

Created on 2010-01-22 16:46 by msmith@cbnco.com, last changed 2022-04-11 14:56 by admin. This issue is now closed.

Files
File name Uploaded Description Edit
getpath.patch sunfinite, 2013-10-22 07:37 Correct prefix when python is built with prefix=" " review
Messages (6)
msg98152 - (view) Author: Michael Smith (msmith@cbnco.com) Date: 2010-01-22 16:46
I've built Python 2.6.2 with a prefix of "" for an embedded system, so it's installed into /bin/python, /lib/python2.6/, etc.

If I run a script with "python /tmp/script.py" or by putting in a #!/bin/python and executing it directly, sys.path is missing the leading slashes:

['/tmp', 'lib/python26.zip', 'lib/python2.6/', 'lib/python2.6/plat-linux2', 'lib/python2.6/lib-tk', 'lib/python2.6/lib-old', 'lib/lib-dynload']

This causes all module imports to fail. I can work around this by making /usr a symlink to / and running the script as "/usr/bin/python /tmp/script.py", or by setting PYTHONHOME=/ before starting Python.

In Modules/getpath.c, search_for_prefix() calls reduce() on argv0_path at the end of a do-while loop, so "/bin" becomes "" and the loop terminates. Then there's a call to joinpath(PREFIX, "lib/python2.6"), where PREFIX is "", and this fails (no leading slash).

calculate_path() warns:

Could not find platform independent libraries <prefix>

and falls back to joinpath(PREFIX, "lib/python2.6") again, which still fails.

I was thinking I could work around it by building with prefix="/" instead of "", but the behaviour is the same - I don't know why, yet.
msg98155 - (view) Author: R. David Murray (r.david.murray) * (Python committer) Date: 2010-01-22 17:45
I thought I remembered a bug that mentioned prefix="/".  What I found was Issue1676135, which might have something to do with your last question.
msg98290 - (view) Author: Michael Smith (msmith@cbnco.com) Date: 2010-01-25 15:47
Yes, that does look related. The fix from Issue1676135 seems to handle --prefix="/" properly, and from what I can tell PREFIX does get set to "/".

There is also code in getpath.c to set sys.prefix to "/" if it's "".

The correct prefix for configure is actually "", not "/", to avoid double-slashes - but neither one seems to work at the moment.
msg189979 - (view) Author: Mark Lawrence (BreamoreBoy) * Date: 2013-05-25 16:33
There's so much detail provided that I think this should be easy for someone who understands C code.
msg200887 - (view) Author: Sunny K (sunfinite) * Date: 2013-10-22 07:37
I took a shot at this. Build is successful and imports happen. Tests are ok except test_sysconfig, and that is because of sys.prefix being set to '/'. I've raised issue19340 for that.

About the patch, i'm not sure how to completely test for false positives(joinpath now returns <SEP><suffix> if <prefix> is null). I could not think of any issues from the current calls to joinpath.
msg404442 - (view) Author: Christian Heimes (christian.heimes) * (Python committer) Date: 2021-10-20 12:48
This is a very old bug report. Python has changed a lot in the past decade. Please reopen the bug if you still can reproduce the issue with Python 3.9 or newer.
History
Date User Action Args
2022-04-11 14:56:56adminsetgithub: 52005
2021-10-20 12:48:52christian.heimessetstatus: open -> closed

nosy: + christian.heimes
messages: + msg404442

resolution: out of date
stage: resolved
2014-04-24 05:49:02pconnellsetnosy: + pconnell
2014-02-03 15:50:32BreamoreBoysetnosy: - BreamoreBoy
2013-10-22 07:37:50sunfinitesetfiles: + getpath.patch

nosy: + sunfinite
messages: + msg200887

keywords: + patch
2013-10-20 18:21:42numerodixsetnosy: + numerodix
2013-05-25 16:33:41BreamoreBoysetnosy: + BreamoreBoy
messages: + msg189979
2010-01-25 15:47:50msmith@cbnco.comsetmessages: + msg98290
2010-01-22 17:45:36r.david.murraysetpriority: normal
nosy: + r.david.murray
messages: + msg98155

2010-01-22 16:46:14msmith@cbnco.comcreate