mirror of https://github.com/python/cpython
This fixes issue5143 and includes a test.
Issue5143 notes that getpath.c and main.c pass a 'char*' where a 'wchar_t*' is expected on OSX.
This commit is contained in:
parent
50987bce06
commit
3e264e13ed
|
@ -0,0 +1,34 @@
|
||||||
|
"""
|
||||||
|
Test suite for OS X interpreter environment variables.
|
||||||
|
"""
|
||||||
|
|
||||||
|
from test.support import EnvironmentVarGuard, run_unittest
|
||||||
|
import subprocess
|
||||||
|
import sys
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
class OSXEnvironmentVariableTestCase(unittest.TestCase):
|
||||||
|
def _check_sys(self, ev, cond, sv, val = '/some/path/to/python'):
|
||||||
|
with EnvironmentVarGuard() as evg:
|
||||||
|
subpc = [str(sys.executable), '-c',
|
||||||
|
'import sys; sys.exit(2 if "%s" %s %s else 3)' % (val, cond, sv)]
|
||||||
|
# ensure environment variable does not exist
|
||||||
|
evg.unset(ev)
|
||||||
|
# test that test on sys.xxx normally fails
|
||||||
|
rc = subprocess.call(subpc)
|
||||||
|
self.assertEqual(rc, 3, "expected %s not %s %s" % (ev, cond, sv))
|
||||||
|
# set environ variable
|
||||||
|
evg.set(ev, val)
|
||||||
|
# test that sys.xxx has been influenced by the environ value
|
||||||
|
rc = subprocess.call(subpc)
|
||||||
|
self.assertEqual(rc, 2, "expected %s %s %s" % (ev, cond, sv))
|
||||||
|
|
||||||
|
def test_pythonexecutable_sets_sys_executable(self):
|
||||||
|
self._check_sys('PYTHONEXECUTABLE', '==', 'sys.executable')
|
||||||
|
|
||||||
|
def test_main():
|
||||||
|
if sys.platform == 'darwin':
|
||||||
|
run_unittest(OSXEnvironmentVariableTestCase)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
test_main()
|
|
@ -457,6 +457,7 @@ calculate_path(void)
|
||||||
#else
|
#else
|
||||||
unsigned long nsexeclength = MAXPATHLEN;
|
unsigned long nsexeclength = MAXPATHLEN;
|
||||||
#endif
|
#endif
|
||||||
|
char execpath[MAXPATHLEN+1];
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (_path) {
|
if (_path) {
|
||||||
|
@ -486,8 +487,13 @@ calculate_path(void)
|
||||||
* will fail if a relative path was used. but in that case,
|
* will fail if a relative path was used. but in that case,
|
||||||
* absolutize() should help us out below
|
* absolutize() should help us out below
|
||||||
*/
|
*/
|
||||||
else if(0 == _NSGetExecutablePath(progpath, &nsexeclength) && progpath[0] == SEP)
|
else if(0 == _NSGetExecutablePath(execpath, &nsexeclength) && execpath[0] == SEP) {
|
||||||
;
|
size_t r = mbstowcs(progpath, execpath, MAXPATHLEN+1);
|
||||||
|
if (r == (size_t)-1 || r > MAXPATHLEN) {
|
||||||
|
/* Could not convert execpath, or it's too long. */
|
||||||
|
progpath[0] = '\0';
|
||||||
|
}
|
||||||
|
}
|
||||||
#endif /* __APPLE__ */
|
#endif /* __APPLE__ */
|
||||||
else if (path) {
|
else if (path) {
|
||||||
while (1) {
|
while (1) {
|
||||||
|
|
|
@ -487,10 +487,23 @@ Py_Main(int argc, wchar_t **argv)
|
||||||
so the actual executable path is passed in an environment variable.
|
so the actual executable path is passed in an environment variable.
|
||||||
See Lib/plat-mac/bundlebuiler.py for details about the bootstrap
|
See Lib/plat-mac/bundlebuiler.py for details about the bootstrap
|
||||||
script. */
|
script. */
|
||||||
if ((p = Py_GETENV("PYTHONEXECUTABLE")) && *p != '\0')
|
if ((p = Py_GETENV("PYTHONEXECUTABLE")) && *p != '\0') {
|
||||||
Py_SetProgramName(p);
|
wchar_t* buffer;
|
||||||
else
|
size_t len = strlen(p);
|
||||||
|
size_t r;
|
||||||
|
|
||||||
|
buffer = malloc(len * sizeof(wchar_t));
|
||||||
|
if (buffer == NULL) {
|
||||||
|
Py_FatalError(
|
||||||
|
"not enough memory to copy PYTHONEXECUTABLE");
|
||||||
|
}
|
||||||
|
|
||||||
|
r = mbstowcs(buffer, p, len);
|
||||||
|
Py_SetProgramName(buffer);
|
||||||
|
/* buffer is now handed off - do not free */
|
||||||
|
} else {
|
||||||
Py_SetProgramName(argv[0]);
|
Py_SetProgramName(argv[0]);
|
||||||
|
}
|
||||||
#else
|
#else
|
||||||
Py_SetProgramName(argv[0]);
|
Py_SetProgramName(argv[0]);
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue