diff options
| author | Dana Jansens <danakj@orodu.net> | 2003-02-16 16:33:37 +0000 |
|---|---|---|
| committer | Dana Jansens <danakj@orodu.net> | 2003-02-16 16:33:37 +0000 |
| commit | c8789ccdbf40c8f0730cbe4c68b8f43b2d9a7f85 (patch) | |
| tree | c67a66db24bf141754b8786bac3335c78d3e82b2 /src/python.cc | |
| parent | 8ed79248e79cede45b6972f3ab007add1dd55956 (diff) | |
execute files such that i can track if an exception was thrown in it
Diffstat (limited to 'src/python.cc')
| -rw-r--r-- | src/python.cc | 25 |
1 files changed, 22 insertions, 3 deletions
diff --git a/src/python.cc b/src/python.cc index 08f8f506..eb08775e 100644 --- a/src/python.cc +++ b/src/python.cc @@ -10,6 +10,9 @@ extern "C" { #include <Python.h> + +#include "gettext.h" +#define _(str) gettext(str) } namespace ob { @@ -36,12 +39,28 @@ bool python_exec(const std::string &path) { FILE *rcpyfd = fopen(path.c_str(), "r"); if (!rcpyfd) { - printf("Failed to load python file %s\n", path.c_str()); + fprintf(stderr, _("Unabled to open python file %s\n"), path.c_str()); return false; } - PyRun_SimpleFile(rcpyfd, const_cast<char*>(path.c_str())); + + //PyRun_SimpleFile(rcpyfd, const_cast<char*>(path.c_str())); + + PyObject *module = PyImport_AddModule("__main__"); + assert(module); + PyObject *dict = PyModule_GetDict(module); + assert(dict); + PyObject *result = PyRun_File(rcpyfd, const_cast<char*>(path.c_str()), + Py_file_input, dict, dict); + bool ret = result != NULL; + if (result == NULL) + PyErr_Print(); + + Py_XDECREF(result); + + Py_DECREF(dict); + fclose(rcpyfd); - return true; + return ret; } } |
