Document absoluteness of sys.executable

Closes #13402.
This commit is contained in:
Petri Lehtinen 2012-02-02 20:59:48 +02:00
parent 03c29f90c3
commit 9713321f46
4 changed files with 10 additions and 3 deletions

View File

@ -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])

View File

@ -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

View File

@ -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

View File

@ -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\