X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Fpython.hh;h=2bf656d8620a4696f27c54350d1c74772636dba9;hb=a0350e27b311db5cab49035752d3852ee68bf8a2;hp=7fc178eb72be9b44219cfd017a62c7e4a15fe133;hpb=3827c1a76e27865a9e2cc9da43c42399ea354e18;p=chaz%2Fopenbox diff --git a/src/python.hh b/src/python.hh index 7fc178eb..2bf656d8 100644 --- a/src/python.hh +++ b/src/python.hh @@ -6,21 +6,135 @@ @brief wee */ -#include "actions.hh" -#include "widget.hh" +#include "otk/point.hh" +#include "otk/rect.hh" extern "C" { +#include #include } +#include +#include + namespace ob { -bool python_register(int action, PyObject *callback); -bool python_unregister(int action, PyObject *callback); +enum MouseContext { + MC_Frame, + MC_Titlebar, + MC_Handle, + MC_Window, + MC_MaximizeButton, + MC_CloseButton, + MC_IconifyButton, + MC_StickyButton, + MC_Grip, + MC_Root, + MC_MenuItem, + NUM_MOUSE_CONTEXT +}; + +enum MouseAction { + MousePress, + MouseClick, + MouseDoubleClick, + MouseMotion, + NUM_MOUSE_ACTION +}; + +enum KeyContext { + KC_Menu, + KC_All, + NUM_KEY_CONTEXT +}; + +enum EventAction { + EventEnterWindow, + EventLeaveWindow, + EventNewWindow, + EventCloseWindow, + NUM_EVENTS +}; + +#ifndef SWIG + +// *** MotionData can be (and is) cast ButtonData!! (in actions.cc) *** // +typedef struct { + PyObject_HEAD; + Window window; + Time time; + unsigned int state; + unsigned int button; + MouseContext context; + MouseAction action; + int xroot; + int yroot; + int pressx; + int pressy; + int press_clientx; + int press_clienty; + int press_clientwidth; + int press_clientheight; +} MotionData; + +// *** MotionData can be (and is) cast ButtonData!! (in actions.cc) *** // +typedef struct { + PyObject_HEAD; + Window window; + Time time; + unsigned int state; + unsigned int button; + MouseContext context; + MouseAction action; +} ButtonData; + +typedef struct { + PyObject_HEAD; + Window window; + unsigned int state; + EventAction action; +} EventData; + +typedef struct { + PyObject_HEAD; + Window window; + Time time; + unsigned int state; + unsigned int key; +} KeyData; + +void python_init(char *argv0); +void python_destroy(); +bool python_exec(const std::string &path); + +MotionData *new_motion_data(Window window, Time time, unsigned int state, + unsigned int button, MouseContext context, + MouseAction action, int xroot, int yroot, + const otk::Point &initpos, + const otk::Rect &initarea); +ButtonData *new_button_data(Window window, Time time, unsigned int state, + unsigned int button, MouseContext context, + MouseAction action); +EventData *new_event_data(Window window, EventAction action, + unsigned int state); +KeyData *new_key_data(Window window, Time time, unsigned int state, + unsigned int key); + +void python_callback(PyObject *func, PyObject *data); + +bool python_get_long(const char *name, long *value); +bool python_get_string(const char *name, std::string *value); +bool python_get_stringlist(const char *name, std::vector *value); +#endif + +PyObject *mbind(const std::string &button, ob::MouseContext context, + ob::MouseAction action, PyObject *func); + +PyObject *kbind(PyObject *keylist, ob::KeyContext context, PyObject *func); + +PyObject *ebind(ob::EventAction action, PyObject *func); -void python_callback(OBActions::ActionType action, Window window, - OBWidget::WidgetType type, unsigned int state, - long d1 = 0, long d2 = 0); +void set_reset_key(const std::string &key); }