diff options
author | Victor Stinner <victor.stinner@gmail.com> | 2013-07-26 23:04:56 (GMT) |
---|---|---|
committer | Victor Stinner <victor.stinner@gmail.com> | 2013-07-26 23:04:56 (GMT) |
commit | 36577e4e8cf967083dea762407ba9d9d28de5b8a (patch) | |
tree | b29158e419a563838c38deb008732636187fe20e /Python | |
parent | 70c94e7896bc46c81e7b9648bde4745ce874f552 (diff) | |
download | cpython-36577e4e8cf967083dea762407ba9d9d28de5b8a.zip cpython-36577e4e8cf967083dea762407ba9d9d28de5b8a.tar.gz cpython-36577e4e8cf967083dea762407ba9d9d28de5b8a.tar.bz2 |
Issue #15893: frozenmain.c now handles PyMem_Malloc() failure
Diffstat (limited to 'Python')
-rw-r--r-- | Python/frozenmain.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/Python/frozenmain.c b/Python/frozenmain.c index f08caf2..98f46eb 100644 --- a/Python/frozenmain.c +++ b/Python/frozenmain.c @@ -20,9 +20,16 @@ Py_FrozenMain(int argc, char **argv) int inspect = 0; int unbuffered = 0; char *oldloc; - wchar_t **argv_copy = PyMem_Malloc(sizeof(wchar_t*)*argc); + wchar_t **argv_copy; /* We need a second copies, as Python might modify the first one. */ - wchar_t **argv_copy2 = PyMem_Malloc(sizeof(wchar_t*)*argc); + wchar_t **argv_copy2; + + argv_copy = PyMem_Malloc(sizeof(wchar_t*)*argc); + argv_copy2 = PyMem_Malloc(sizeof(wchar_t*)*argc); + if (!argv_copy || !argv_copy2) { + fprintf(stderr, "out of memory\n"); + return 1; + } Py_FrozenFlag = 1; /* Suppress errors from getpath.c */ |