summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2003-02-16 16:33:37 +0000
committerDana Jansens <danakj@orodu.net>2003-02-16 16:33:37 +0000
commitc8789ccdbf40c8f0730cbe4c68b8f43b2d9a7f85 (patch)
treec67a66db24bf141754b8786bac3335c78d3e82b2 /src
parent8ed79248e79cede45b6972f3ab007add1dd55956 (diff)
execute files such that i can track if an exception was thrown in it
Diffstat (limited to 'src')
-rw-r--r--src/python.cc25
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;
}
}