all repos — openbox @ c8789ccdbf40c8f0730cbe4c68b8f43b2d9a7f85

openbox fork - make it a bit more like ryudo

execute files such that i can track if an exception was thrown in it
Dana Jansens danakj@orodu.net
commit

c8789ccdbf40c8f0730cbe4c68b8f43b2d9a7f85

parent

8ed79248e79cede45b6972f3ab007add1dd55956

1 files changed, 22 insertions(+), 3 deletions(-)

jump to
M src/python.ccsrc/python.cc

@@ -10,6 +10,9 @@ #include "otk/util.hh"

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; } }