Update Py_FrozenMain to work with Python 3.2

This commit is contained in:
rdb 2016-12-06 02:14:39 +01:00
parent f001bd20d7
commit 4335e3759a
2 changed files with 24 additions and 46 deletions

View File

@ -251,6 +251,10 @@ frozenMainCode = """
#if PY_MAJOR_VERSION >= 3
#include <locale.h>
#if PY_MINOR_VERSION < 5
#define Py_DecodeLocale _Py_char2wchar
#endif
#endif
#ifdef MS_WINDOWS
@ -272,18 +276,14 @@ Py_FrozenMain(int argc, char **argv)
#if PY_MAJOR_VERSION >= 3
int i;
char *oldloc = NULL;
char *oldloc;
wchar_t **argv_copy = NULL;
/* We need a second copies, as Python might modify the first one. */
wchar_t **argv_copy2 = NULL;
if (argc > 0) {
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\");
goto error;
}
argv_copy = (wchar_t **)alloca(sizeof(wchar_t *) * argc);
argv_copy2 = (wchar_t **)alloca(sizeof(wchar_t *) * argc);
}
#endif
@ -303,12 +303,7 @@ Py_FrozenMain(int argc, char **argv)
}
#if PY_MAJOR_VERSION >= 3
oldloc = _PyMem_RawStrdup(setlocale(LC_ALL, NULL));
if (!oldloc) {
fprintf(stderr, \"out of memory\\n\");
goto error;
}
oldloc = setlocale(LC_ALL, NULL);
setlocale(LC_ALL, \"\");
for (i = 0; i < argc; i++) {
argv_copy[i] = Py_DecodeLocale(argv[i], NULL);
@ -321,8 +316,6 @@ Py_FrozenMain(int argc, char **argv)
}
}
setlocale(LC_ALL, oldloc);
PyMem_RawFree(oldloc);
oldloc = NULL;
#endif
#ifdef MS_WINDOWS
@ -372,13 +365,15 @@ Py_FrozenMain(int argc, char **argv)
#if PY_MAJOR_VERSION >= 3
error:
PyMem_RawFree(argv_copy);
if (argv_copy2) {
for (i = 0; i < argc; i++)
for (i = 0; i < argc; i++) {
#if PY_MINOR_VERSION >= 4
PyMem_RawFree(argv_copy2[i]);
PyMem_RawFree(argv_copy2);
#else
PyMem_Free(argv_copy2[i]);
#endif
}
}
PyMem_RawFree(oldloc);
#endif
return sts;
}

View File

@ -32,18 +32,14 @@ Py_FrozenMain(int argc, char **argv)
#if PY_MAJOR_VERSION >= 3
int i;
char *oldloc = NULL;
char *oldloc;
wchar_t **argv_copy = NULL;
/* We need a second copies, as Python might modify the first one. */
wchar_t **argv_copy2 = NULL;
if (argc > 0) {
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");
goto error;
}
argv_copy = (wchar_t **)alloca(sizeof(wchar_t *) * argc);
argv_copy2 = (wchar_t **)alloca(sizeof(wchar_t *) * argc);
}
#endif
@ -63,12 +59,7 @@ Py_FrozenMain(int argc, char **argv)
}
#if PY_MAJOR_VERSION >= 3
oldloc = _PyMem_RawStrdup(setlocale(LC_ALL, NULL));
if (!oldloc) {
fprintf(stderr, "out of memory\n");
goto error;
}
oldloc = setlocale(LC_ALL, NULL);
setlocale(LC_ALL, "");
for (i = 0; i < argc; i++) {
argv_copy[i] = Py_DecodeLocale(argv[i], NULL);
@ -81,8 +72,6 @@ Py_FrozenMain(int argc, char **argv)
}
}
setlocale(LC_ALL, oldloc);
PyMem_RawFree(oldloc);
oldloc = NULL;
#endif
#ifdef MS_WINDOWS
@ -122,14 +111,6 @@ Py_FrozenMain(int argc, char **argv)
else
sts = 0;
#if PY_MAJOR_VERSION >= 3
n = PyImport_ImportFrozenModule("_frozen_importlib");
if (n == 0)
Py_FatalError("_frozen_importlib not frozen");
if (n < 0)
PyErr_Print();
#endif
if (inspect && isatty((int)fileno(stdin)))
sts = PyRun_AnyFile(stdin, "<stdin>") != 0;
@ -140,13 +121,15 @@ Py_FrozenMain(int argc, char **argv)
#if PY_MAJOR_VERSION >= 3
error:
PyMem_RawFree(argv_copy);
if (argv_copy2) {
for (i = 0; i < argc; i++)
for (i = 0; i < argc; i++) {
#if PY_MINOR_VERSION >= 4
PyMem_RawFree(argv_copy2[i]);
PyMem_RawFree(argv_copy2);
#else
PyMem_Free(argv_copy2[i]);
#endif
}
}
PyMem_RawFree(oldloc);
#endif
return sts;
}