X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Fopenbox.i;h=5419832585bdb6292877110c1df73b01e574eb0d;hb=7fe3301e7ea905a8a76d54c22751f3d8a346e28b;hp=b914ce9c52bd4d4ee0a3386bb79b06ef77a6e792;hpb=4c768d5d63154e416e1282396dc48492d0585d42;p=chaz%2Fopenbox diff --git a/src/openbox.i b/src/openbox.i index b914ce9c..54198325 100644 --- a/src/openbox.i +++ b/src/openbox.i @@ -1,37 +1,104 @@ // -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*- -%module openbox +%module ob %{ #ifdef HAVE_CONFIG_H # include "../config.h" #endif +#include "frame.hh" #include "openbox.hh" #include "screen.hh" #include "client.hh" #include "bindings.hh" #include "actions.hh" +#include "python.hh" +#include "otk/otk.hh" %} %include "stl.i" //%include std_list.i -//%template(ClientList) std::list; +//%template(ClientList) std::list; -%ignore ob::Openbox::instance; +%ignore ob::openbox; %inline %{ - ob::Openbox *Openbox_instance() { return ob::Openbox::instance; } + ob::Openbox *Openbox_instance() { return ob::openbox; } %}; -%ignore ob::OBScreen::clients; +%{ +namespace ob { +void python_callback(PyObject *func, MouseData *data) +{ + PyObject *arglist, *result, *pdata; + + pdata = SWIG_NewPointerObj((void *) data, SWIGTYPE_p_ob__MouseData, 0); + arglist = Py_BuildValue("(O)", pdata); + Py_DECREF(pdata); + + // call the callback + result = PyEval_CallObject(func, arglist); + if (!result || PyErr_Occurred()) { + // an exception occured in the script, display it + PyErr_Print(); + } + + Py_XDECREF(result); + Py_DECREF(arglist); +} + +void python_callback(PyObject *func, EventData *data) +{ + PyObject *arglist, *result, *pdata; + + pdata = SWIG_NewPointerObj((void *) data, SWIGTYPE_p_ob__EventData, 0); + arglist = Py_BuildValue("(O)", pdata); + Py_DECREF(pdata); + + // call the callback + result = PyEval_CallObject(func, arglist); + if (!result || PyErr_Occurred()) { + // an exception occured in the script, display it + PyErr_Print(); + } + + Py_XDECREF(result); + Py_DECREF(arglist); +} + +void python_callback(PyObject *func, KeyData *data) +{ + PyObject *arglist, *result, *pdata; + + pdata = SWIG_NewPointerObj((void *) data, SWIGTYPE_p_ob__KeyData, 0); + arglist = Py_BuildValue("(O)", pdata); + Py_DECREF(pdata); + + // call the callback + result = PyEval_CallObject(func, arglist); + if (!result || PyErr_Occurred()) { + // an exception occured in the script, display it + PyErr_Print(); + } + + Py_XDECREF(result); + Py_DECREF(arglist); +} + +} +%} + +#ignore ob::openbox; + +%ignore ob::Screen::clients; %{ #include %} -%extend ob::OBScreen { - OBClient *client(int i) { - if (i >= (int)self->clients.size()) +%extend ob::Screen { + Client *client(int i) { + if (i < 0 || i >= (int)self->clients.size()) return NULL; - ob::OBClient::List::iterator it = self->clients.begin(); + ob::Client::List::iterator it = self->clients.begin(); std::advance(it,i); return *it; } @@ -40,14 +107,40 @@ } }; -%import "../otk/eventdispatcher.hh" -%import "../otk/eventhandler.hh" -%import "widget.hh" +/* +%include "../otk/ustring.i" + +%ignore otk::display; +%inline %{ + otk::Display *Display_instance() { return otk::display; } +%}; + +%ignore otk::Property::atoms; +%inline %{ + const otk::Atoms& Property_atoms() { return otk::Property::atoms; } +%}; + +%include "../otk/display.hh" +%include "../otk/point.hh" +%include "../otk/property.hh" +%include "../otk/rect.hh" +%include "../otk/screeninfo.hh" +%include "../otk/strut.hh" + +%include "../otk/eventhandler.hh" +%include "../otk/eventdispatcher.hh" + +%import "../otk/widget.hh" +*/ +%import "../otk/otk.i" + +%import "widgetbase.hh" %import "actions.hh" %include "openbox.hh" %include "screen.hh" %include "client.hh" +%include "frame.hh" %include "python.hh" // for Mod1Mask etc