]> granicus.if.org Git - python/commitdiff
Document absoluteness of sys.executable
authorPetri Lehtinen <petri@digip.org>
Thu, 2 Feb 2012 18:59:48 +0000 (20:59 +0200)
committerPetri Lehtinen <petri@digip.org>
Thu, 2 Feb 2012 18:59:50 +0000 (20:59 +0200)
Closes #13402.

Doc/library/sys.rst
Lib/test/test_sys.py
Misc/NEWS
Python/sysmodule.c

index 18f916bcefbaee1e5da81de20480e836da37fd76..d611acf74ac33e97e501caf25acfbe34abd6ebf8 100644 (file)
@@ -202,8 +202,10 @@ always available.
 
 .. data:: executable
 
-   A string giving the name of the executable binary for the Python interpreter, on
-   systems where this makes sense.
+   A string giving the absolute path of the executable binary for the Python
+   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])
index db27cdf347c7a9824af96be4cf52f0af1fc569bd..5d3404f75e086cb32698dab68045c5d6fcccac6a 100644 (file)
@@ -532,6 +532,9 @@ class SysModuleTest(unittest.TestCase):
         self.assertEqual(out, b'?')
 
     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]
         # has been set to an non existent program name and Python is unable to
         # retrieve the real program name
index aa05096592f8c8b81a22663a65153025ab466001..0f0479c14f68a78841368dd00e5f468e06d0301a 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -454,6 +454,8 @@ Extension Modules
 Documentation
 -------------
 
+- Issue #13402: Document absoluteness of sys.executable.
+
 - Issue #13883: PYTHONCASEOK also used on OS X and OS/2.
 
 - Issue #12949: Document the kwonlyargcount argument for the PyCode_New
index 73dc0dd59238c075c6cf83e0beffd4fff152b52f..8a659c5e460a6cbe578a7876608e2e49ffe6d380 100644 (file)
@@ -1263,7 +1263,7 @@ version_info -- version information as a named tuple\n\
 hexversion -- version information encoded as a single integer\n\
 copyright -- copyright notice pertaining to this interpreter\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\
 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\