X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;f=src%2Fpython.hh;h=b97987817bd95869340fa55f2425cdfe26437138;hb=28b8f67562bb7eb15134f2bf7a8394f0a009b9ba;hp=7566f817bdea3862480966a753d573e700884a8c;hpb=745e840547b5443ecfb9b6f0a4f14b0d035d59c2;p=chaz%2Fopenbox diff --git a/src/python.hh b/src/python.hh index 7566f817..b9798781 100644 --- a/src/python.hh +++ b/src/python.hh @@ -6,64 +6,191 @@ @brief wee */ -#include "actions.hh" -#include "widget.hh" -#include "bindings.hh" +#include "otk/point.hh" +#include "otk/rect.hh" +#include "otk/property.hh" +#include "otk/display.hh" +#include "otk/ustring.hh" extern "C" { +#include #include } #include +#include namespace ob { +class Client; + +enum MouseContext { + MC_Frame, + MC_Titlebar, + MC_Handle, + MC_Window, + MC_MaximizeButton, + MC_CloseButton, + MC_IconifyButton, + MC_AllDesktopsButton, + 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, + EventPlaceWindow, + EventNewWindow, + EventCloseWindow, + EventStartup, + EventShutdown, + EventFocus, + EventBell, + NUM_EVENTS +}; + +class MouseData { +public: + int screen; + Client *client; + 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; + + MouseData(int screen, Client *client, Time time, unsigned int state, + unsigned int button, MouseContext context, MouseAction action, + int xroot, int yroot, const otk::Point &initpos, + const otk::Rect &initarea) { + this->screen = screen; + this->client = client; + this->time = time; + this->state = state; + this->button = button; + this->context= context; + this->action = action; + this->xroot = xroot; + this->yroot = yroot; + this->pressx = initpos.x(); + this->pressy = initpos.y(); + this->press_clientx = initarea.x(); + this->press_clienty = initarea.y(); + this->press_clientwidth = initarea.width(); + this->press_clientheight = initarea.height(); + } + MouseData(int screen, Client *client, Time time, unsigned int state, + unsigned int button, MouseContext context, MouseAction action) { + this->screen = screen; + this->client = client; + this->time = time; + this->state = state; + this->button = button; + this->context= context; + this->action = action; + this->xroot = xroot; + this->yroot = yroot; + this->pressx = 0; + this->pressy = 0; + this->press_clientx = 0; + this->press_clienty = 0; + this->press_clientwidth = 0; + this->press_clientheight = 0; + } +}; + +class EventData { +public: + int screen; + Client *client; + unsigned int state; + EventAction action; + + EventData(int screen, Client *client, EventAction action, + unsigned int state) { + this->screen = screen; + this->client = client; + this->action = action; + this->state = state; + } +}; + +class KeyData { +public: + int screen; + Client *client; + Time time; + unsigned int state; + std::string key; + + KeyData(int screen, Client *client, Time time, unsigned int state, + unsigned int key) { + this->screen = screen; + this->client = client; + this->time = time; + this->state = state; + this->key = XKeysymToString(XKeycodeToKeysym(**otk::display, + key, 0)); + } +}; + +#ifndef SWIG + void python_init(char *argv0); -bool python_exec(const char *file); -bool python_get_string(const char *name, std::string *value); +void python_destroy(); +bool python_exec(const std::string &path); -//! Add a python callback funtion to the back of the hook list -/*! - Registering functions for KeyPress events is pointless. Use python_bind - instead to do this. -*/ -bool python_register(int action, PyObject *callback); -//! Add a python callback funtion to the front of the hook list -/*! - Registering functions for KeyPress events is pointless. Use python_bind - instead to do this. -*/ -bool python_preregister(int action, PyObject *callback); -//! Remove a python callback function from the hook list -bool python_unregister(int action, PyObject *callback); - -//! Removes all python callback functions from the hook list -bool python_unregister_all(int action); - -//! Add a keybinding -/*! - @param keylist A python list of modifier/key/buttons, in the form: - "C-A-space" or "A-Button1" etc. - @param callback A python function to call when the binding is used. -*/ -bool python_bind(PyObject *keylist, PyObject *callback); +bool python_get_long(const char *name, long *value); +bool python_get_string(const char *name, otk::ustring *value); +bool python_get_stringlist(const char *name, std::vector *value); + +/*********************************************** + * These are found in openbox.i, not python.cc * + ***********************************************/ +void python_callback(PyObject *func, MouseData *data); +void python_callback(PyObject *func, EventData *data); +void python_callback(PyObject *func, KeyData *data); -bool python_unbind(PyObject *keylist); +#endif // SWIG -void python_set_reset_key(const std::string &key); +PyObject *mbind(const std::string &button, ob::MouseContext context, + ob::MouseAction action, PyObject *func); -void python_unbind_all(); +PyObject *kbind(PyObject *keylist, ob::KeyContext context, PyObject *func); -//! Fire a python callback function -void python_callback(OBActions::ActionType action, Window window, - OBWidget::WidgetType type, unsigned int state, - long d1 = LONG_MIN, long d2 = LONG_MIN, - long d3 = LONG_MIN, long d4 = LONG_MIN); +PyObject *ebind(ob::EventAction action, PyObject *func); -//! Fire a python callback function for a key binding -void python_callback_binding(int id, Window window, unsigned int state, - unsigned int keybutton, Time time); +void set_reset_key(const std::string &key); +PyObject *send_client_msg(Window target, Atom type, Window about, + long data, long data1 = 0, long data2 = 0, + long data3 = 0, long data4 = 0); } + #endif // __python_hh