X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Fbindings.hh;h=021014044152fd410515059cf96ae79748584c6f;hb=0b12453cf633b914f6712315dfc2c0171d2bb574;hp=1ca46df72e8d2d19cca99d5e99377a6022f17323;hpb=7db3ffecc980821ada3e805e2471716896e2410a;p=chaz%2Fopenbox diff --git a/src/bindings.hh b/src/bindings.hh index 1ca46df7..02101404 100644 --- a/src/bindings.hh +++ b/src/bindings.hh @@ -2,7 +2,7 @@ #ifndef __binding_hh #define __binding_hh -/*! @file binding.hh +/*! @file bindings.hh @brief I dunno.. some binding stuff? */ @@ -22,6 +22,8 @@ namespace ob { class OBClient; +typedef std::list CallbackList; + typedef struct Binding { unsigned int modifiers; unsigned int key; @@ -35,27 +37,22 @@ typedef struct Binding { typedef struct KeyBindingTree { Binding binding; - PyObject *callback; // the callback given for the binding in add() + CallbackList callbacks; // the callbacks given for the binding in add() bool chain; // true if this is a chain to another key (not an action) struct KeyBindingTree *next_sibling; // the next binding in the tree at the same // level struct KeyBindingTree *first_child; // the first child of this binding (next // binding in a chained sequence). - KeyBindingTree(PyObject *callback) : binding(0, 0) { - this->callback = callback; chain = true; next_sibling = first_child = 0; - } KeyBindingTree() : binding(0, 0) { - this->callback = 0; chain = true; next_sibling = first_child = 0; + chain = true; next_sibling = first_child = 0; } } KeyBindingTree; typedef struct ButtonBinding { Binding binding; - PyObject *callback[NUM_MOUSE_ACTION]; - ButtonBinding() : binding(0, 0) { - for(int i=0; i ButtonBindingList; ButtonBindingList _buttons[NUM_MOUSE_CONTEXT]; + void grabButton(bool grab, const Binding &b, MouseContext context, + OBClient *client); + + CallbackList _eventlist[NUM_EVENTS]; + public: //! Initializes an OBBindings object OBBindings(); @@ -97,19 +99,19 @@ public: a chain or not), or if any of the strings in the keylist are invalid. @return true if the binding could be added; false if it could not. */ - bool add(const StringVect &keylist, PyObject *callback); + bool addKey(const StringVect &keylist, PyObject *callback); //! Removes a key binding /*! @return The callbackid of the binding, or '< 0' if there was no binding to be removed. */ - bool remove(const StringVect &keylist); + bool removeKey(const StringVect &keylist, PyObject *callback); //! Removes all key bindings - void removeAll(); + void removeAllKeys(); - void fire(unsigned int modifiers,unsigned int key, Time time); + void fireKey(int screen, unsigned int modifiers,unsigned int key, Time time); void setResetKey(const std::string &key); @@ -120,7 +122,21 @@ public: void grabButtons(bool grab, OBClient *client); - void fire(ButtonData *data); + //! Removes all button bindings + void removeAllButtons(); + + void fireButton(MouseData *data); + + //! Bind a callback for an event + bool addEvent(EventAction action, PyObject *callback); + + //! Unbind the callback function from an event + bool removeEvent(EventAction action, PyObject *callback); + + //! Remove all callback functions + void removeAllEvents(); + + void fireEvent(EventData *data); }; }