summaryrefslogtreecommitdiffstats
path: root/Python/frozenmain.c
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2013-07-27 00:39:09 (GMT)
committerVictor Stinner <victor.stinner@gmail.com>2013-07-27 00:39:09 (GMT)
commitc588feeea94788e164286dbd757e34829a2eefb5 (patch)
tree4568eb715f50b0d45d3e7b9fd63b420b6e86ffe7 /Python/frozenmain.c
parent739cf4e3e6d7370ab6ddfc96637218eadfe81a13 (diff)
downloadcpython-c588feeea94788e164286dbd757e34829a2eefb5.zip
cpython-c588feeea94788e164286dbd757e34829a2eefb5.tar.gz
cpython-c588feeea94788e164286dbd757e34829a2eefb5.tar.bz2
Issue #15893: Improve error handling in main() and Py_FrozenMain()
* handle _PyMem_RawStrdup() failure * Py_FrozenMain() releases memory on error * Py_FrozenMain() duplicates the old locale, as done in main()
Diffstat (limited to 'Python/frozenmain.c')
-rw-r--r--Python/frozenmain.c39
1 files changed, 23 insertions, 16 deletions
diff --git a/Python/frozenmain.c b/Python/frozenmain.c
index f628ddc..55d05fc 100644
--- a/Python/frozenmain.c
+++ b/Python/frozenmain.c
@@ -16,19 +16,19 @@ int
Py_FrozenMain(int argc, char **argv)
{
char *p;
- int i, n, sts;
+ int i, n, sts = 1;
int inspect = 0;
int unbuffered = 0;
- char *oldloc;
- wchar_t **argv_copy;
+ char *oldloc = NULL;
+ wchar_t **argv_copy = NULL;
/* We need a second copies, as Python might modify the first one. */
- wchar_t **argv_copy2;
+ wchar_t **argv_copy2 = NULL;
- argv_copy = PyMem_RawMalloc(sizeof(wchar_t*)*argc);
- argv_copy2 = PyMem_RawMalloc(sizeof(wchar_t*)*argc);
+ argv_copy = PyMem_RawMalloc(sizeof(wchar_t*) * argc);
+ argv_copy2 = PyMem_RawMalloc(sizeof(wchar_t*) * argc);
if (!argv_copy || !argv_copy2) {
fprintf(stderr, "out of memory\n");
- return 1;
+ goto error;
}
Py_FrozenFlag = 1; /* Suppress errors from getpath.c */
@@ -44,23 +44,26 @@ Py_FrozenMain(int argc, char **argv)
setbuf(stderr, (char *)NULL);
}
- if (!argv_copy) {
+ oldloc = _PyMem_RawStrdup(setlocale(LC_ALL, NULL));
+ if (!oldloc) {
fprintf(stderr, "out of memory\n");
- return 1;
+ goto error;
}
- oldloc = setlocale(LC_ALL, NULL);
setlocale(LC_ALL, "");
for (i = 0; i < argc; i++) {
argv_copy[i] = _Py_char2wchar(argv[i], NULL);
+ argv_copy2[i] = argv_copy[i];
if (!argv_copy[i]) {
fprintf(stderr, "Unable to decode the command line argument #%i\n",
i + 1);
- return 1;
+ argc = i;
+ goto error;
}
- argv_copy2[i] = argv_copy[i];
}
setlocale(LC_ALL, oldloc);
+ PyMem_RawFree(oldloc);
+ oldloc = NULL;
#ifdef MS_WINDOWS
PyInitFrozenExtensions();
@@ -94,10 +97,14 @@ Py_FrozenMain(int argc, char **argv)
PyWinFreeze_ExeTerm();
#endif
Py_Finalize();
- for (i = 0; i < argc; i++) {
- PyMem_RawFree(argv_copy2[i]);
- }
+
+error:
PyMem_RawFree(argv_copy);
- PyMem_RawFree(argv_copy2);
+ if (argv_copy2) {
+ for (i = 0; i < argc; i++)
+ PyMem_RawFree(argv_copy2[i]);
+ PyMem_RawFree(argv_copy2);
+ }
+ PyMem_RawFree(oldloc);
return sts;
}