Commit 9713321f authored by Petri Lehtinen's avatar Petri Lehtinen

Document absoluteness of sys.executable

Closes #13402.
parent 03c29f90
...@@ -202,8 +202,10 @@ always available. ...@@ -202,8 +202,10 @@ always available.
.. data:: executable .. data:: executable
A string giving the name of the executable binary for the Python interpreter, on A string giving the absolute path of the executable binary for the Python
systems where this makes sense. interpreter, on systems where this makes sense. If Python is unable to retrieve
the real path to its executable, :data:`sys.executable` will be an empty string
or ``None``.
.. function:: exit([arg]) .. function:: exit([arg])
......
...@@ -532,6 +532,9 @@ class SysModuleTest(unittest.TestCase): ...@@ -532,6 +532,9 @@ class SysModuleTest(unittest.TestCase):
self.assertEqual(out, b'?') self.assertEqual(out, b'?')
def test_executable(self): def test_executable(self):
# sys.executable should be absolute
self.assertEqual(os.path.abspath(sys.executable), sys.executable)
# Issue #7774: Ensure that sys.executable is an empty string if argv[0] # Issue #7774: Ensure that sys.executable is an empty string if argv[0]
# has been set to an non existent program name and Python is unable to # has been set to an non existent program name and Python is unable to
# retrieve the real program name # retrieve the real program name
......
...@@ -454,6 +454,8 @@ Extension Modules ...@@ -454,6 +454,8 @@ Extension Modules
Documentation Documentation
------------- -------------
- Issue #13402: Document absoluteness of sys.executable.
- Issue #13883: PYTHONCASEOK also used on OS X and OS/2. - Issue #13883: PYTHONCASEOK also used on OS X and OS/2.
- Issue #12949: Document the kwonlyargcount argument for the PyCode_New - Issue #12949: Document the kwonlyargcount argument for the PyCode_New
......
...@@ -1263,7 +1263,7 @@ version_info -- version information as a named tuple\n\ ...@@ -1263,7 +1263,7 @@ version_info -- version information as a named tuple\n\
hexversion -- version information encoded as a single integer\n\ hexversion -- version information encoded as a single integer\n\
copyright -- copyright notice pertaining to this interpreter\n\ copyright -- copyright notice pertaining to this interpreter\n\
platform -- platform identifier\n\ platform -- platform identifier\n\
executable -- pathname of this Python interpreter\n\ executable -- absolute path of the executable binary of the Python interpreter\n\
prefix -- prefix used to find the Python library\n\ prefix -- prefix used to find the Python library\n\
exec_prefix -- prefix used to find the machine-specific Python library\n\ exec_prefix -- prefix used to find the machine-specific Python library\n\
float_repr_style -- string indicating the style of repr() output for floats\n\ float_repr_style -- string indicating the style of repr() output for floats\n\
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment