1997-07-19 16:25:33 -03:00
|
|
|
/* Minimal main program -- everything is loaded from the library */
|
|
|
|
|
1998-08-08 17:01:22 -03:00
|
|
|
#include "Python.h"
|
2008-04-05 17:41:37 -03:00
|
|
|
#include <locale.h>
|
1998-08-08 17:01:22 -03:00
|
|
|
|
2002-12-28 17:56:08 -04:00
|
|
|
#ifdef __FreeBSD__
|
|
|
|
#include <floatingpoint.h>
|
|
|
|
#endif
|
|
|
|
|
2008-04-05 17:41:37 -03:00
|
|
|
#ifdef MS_WINDOWS
|
|
|
|
int
|
|
|
|
wmain(int argc, wchar_t **argv)
|
|
|
|
{
|
2010-05-09 12:52:27 -03:00
|
|
|
return Py_Main(argc, argv);
|
2008-04-05 17:41:37 -03:00
|
|
|
}
|
|
|
|
#else
|
2009-05-05 01:43:17 -03:00
|
|
|
|
2010-10-20 19:58:25 -03:00
|
|
|
#ifdef __APPLE__
|
|
|
|
extern wchar_t* _Py_DecodeUTF8_surrogateescape(const char *s, Py_ssize_t size);
|
|
|
|
#endif
|
|
|
|
|
1997-08-14 23:52:08 -03:00
|
|
|
int
|
2000-07-09 17:35:15 -03:00
|
|
|
main(int argc, char **argv)
|
1997-07-19 16:25:33 -03:00
|
|
|
{
|
2012-03-26 10:05:22 -03:00
|
|
|
wchar_t **argv_copy = (wchar_t **)PyMem_Malloc(sizeof(wchar_t*)*(argc+1));
|
2010-05-09 12:52:27 -03:00
|
|
|
/* We need a second copies, as Python might modify the first one. */
|
2012-03-26 10:05:22 -03:00
|
|
|
wchar_t **argv_copy2 = (wchar_t **)PyMem_Malloc(sizeof(wchar_t*)*(argc+1));
|
2010-05-09 12:52:27 -03:00
|
|
|
int i, res;
|
|
|
|
char *oldloc;
|
|
|
|
/* 754 requires that FP exceptions run in "no stop" mode by default,
|
|
|
|
* and until C vendors implement C99's ways to control FP exceptions,
|
|
|
|
* Python requires non-stop mode. Alas, some platforms enable FP
|
|
|
|
* exceptions by default. Here we disable them.
|
|
|
|
*/
|
2002-12-28 17:56:08 -04:00
|
|
|
#ifdef __FreeBSD__
|
2010-05-09 12:52:27 -03:00
|
|
|
fp_except_t m;
|
2002-12-28 17:56:08 -04:00
|
|
|
|
2010-05-09 12:52:27 -03:00
|
|
|
m = fpgetmask();
|
|
|
|
fpsetmask(m & ~FP_X_OFL);
|
2002-12-28 17:56:08 -04:00
|
|
|
#endif
|
2010-05-09 12:52:27 -03:00
|
|
|
if (!argv_copy || !argv_copy2) {
|
|
|
|
fprintf(stderr, "out of memory\n");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
oldloc = strdup(setlocale(LC_ALL, NULL));
|
|
|
|
setlocale(LC_ALL, "");
|
|
|
|
for (i = 0; i < argc; i++) {
|
2010-10-20 19:58:25 -03:00
|
|
|
#ifdef __APPLE__
|
|
|
|
argv_copy[i] = _Py_DecodeUTF8_surrogateescape(argv[i], strlen(argv[i]));
|
|
|
|
#else
|
2010-10-16 20:16:16 -03:00
|
|
|
argv_copy[i] = _Py_char2wchar(argv[i], NULL);
|
2010-10-20 19:58:25 -03:00
|
|
|
#endif
|
2011-12-16 18:48:31 -04:00
|
|
|
if (!argv_copy[i]) {
|
2012-06-25 17:25:28 -03:00
|
|
|
free(oldloc);
|
2011-12-16 18:48:31 -04:00
|
|
|
fprintf(stderr, "Fatal Python error: "
|
|
|
|
"unable to decode the command line argument #%i\n",
|
|
|
|
i + 1);
|
2010-05-09 12:52:27 -03:00
|
|
|
return 1;
|
2011-12-16 18:48:31 -04:00
|
|
|
}
|
2010-10-13 20:24:06 -03:00
|
|
|
argv_copy2[i] = argv_copy[i];
|
2010-05-09 12:52:27 -03:00
|
|
|
}
|
2012-03-26 10:05:22 -03:00
|
|
|
argv_copy2[argc] = argv_copy[argc] = NULL;
|
|
|
|
|
2010-05-09 12:52:27 -03:00
|
|
|
setlocale(LC_ALL, oldloc);
|
|
|
|
free(oldloc);
|
|
|
|
res = Py_Main(argc, argv_copy);
|
|
|
|
for (i = 0; i < argc; i++) {
|
|
|
|
PyMem_Free(argv_copy2[i]);
|
|
|
|
}
|
|
|
|
PyMem_Free(argv_copy);
|
|
|
|
PyMem_Free(argv_copy2);
|
|
|
|
return res;
|
1997-07-19 16:25:33 -03:00
|
|
|
}
|
2008-04-05 17:41:37 -03:00
|
|
|
#endif
|