X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Fbindings.hh;h=2b2260e26aeeb40602a169e73a0caa110dbcc3d7;hb=5face4c6f35172761367f63ac0b6eaf62d84e532;hp=9d55b7512c2b58ce4ea539ed88565988eb9c7971;hpb=66a26917a0631463df7f72c34cbeb39df466918a;p=chaz%2Fopenbox diff --git a/src/bindings.hh b/src/bindings.hh index 9d55b751..2b2260e2 100644 --- a/src/bindings.hh +++ b/src/bindings.hh @@ -2,11 +2,12 @@ #ifndef __binding_hh #define __binding_hh -/*! @file binding.hh +/*! @file bindings.hh @brief I dunno.. some binding stuff? */ #include "actions.hh" +#include "python.hh" #include "otk/timer.hh" extern "C" { @@ -19,7 +20,9 @@ extern "C" { namespace ob { -class OBClient; +class Client; + +typedef std::list CallbackList; typedef struct Binding { unsigned int modifiers; @@ -32,72 +35,114 @@ typedef struct Binding { Binding(unsigned int mod, unsigned int k) { modifiers = mod; key = k; } } Binding; -typedef struct BindingTree { +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 BindingTree *next_sibling; // the next binding in the tree at the same + struct KeyBindingTree *next_sibling; // the next binding in the tree at the same // level - struct BindingTree *first_child; // the first child of this binding (next + struct KeyBindingTree *first_child; // the first child of this binding (next // binding in a chained sequence). - BindingTree(PyObject *callback) : binding(0, 0) { - this->callback = callback; chain = true; next_sibling = first_child = 0; - } - BindingTree() : binding(0, 0) { - this->callback = 0; chain = true; next_sibling = first_child = 0; + KeyBindingTree() : binding(0, 0) { + chain = true; next_sibling = first_child = 0; } -} BindingTree; +} KeyBindingTree; + +typedef struct ButtonBinding { + Binding binding; + CallbackList callbacks[MouseAction::NUM_MOUSE_ACTION]; + ButtonBinding() : binding(0, 0) {} +}; -class OBBindings { +class Bindings { public: //! A list of strings typedef std::vector StringVect; private: - BindingTree _tree; // root node of the tree (this doesn't have siblings!) - BindingTree *_curpos; // position in the keytree + // root node of the tree (this doesn't have siblings!) + KeyBindingTree _keytree; + KeyBindingTree *_curpos; // position in the keytree Binding _resetkey; // the key which resets the key chain status - otk::OBTimer _timer; + otk::Timer *_timer; - PyObject *find(BindingTree *search, bool *conflict) const; - bool translate(const std::string &str, Binding &b) const; - BindingTree *buildtree(const StringVect &keylist, PyObject *callback) const; - void assimilate(BindingTree *node); + KeyBindingTree *find(KeyBindingTree *search, bool *conflict) const; + KeyBindingTree *buildtree(const StringVect &keylist, + PyObject *callback) const; + void assimilate(KeyBindingTree *node); - static void reset(OBBindings *self); // the timer's timeout function + static void resetChains(Bindings *self); // the timer's timeout function + typedef std::list ButtonBindingList; + ButtonBindingList _buttons[MouseContext::NUM_MOUSE_CONTEXT]; + + void grabButton(bool grab, const Binding &b, MouseContext::MC context, + Client *client); + + CallbackList _eventlist[EventAction::NUM_EVENTS]; + + PyObject *_keybgrab_callback; + public: - //! Initializes an OBBinding object - OBBindings(); - //! Destroys the OBBinding object - virtual ~OBBindings(); + //! Initializes an Bindings object + Bindings(); + //! Destroys the Bindings object + virtual ~Bindings(); + //! Translates a binding string into the actual Binding + bool translate(const std::string &str, Binding &b, bool askey = true) const; + //! Adds a new key binding /*! A binding will fail to be added if the binding already exists (as part of 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, + KeyAction::KA action); void setResetKey(const std::string &key); void grabKeys(bool grab); + + bool grabKeyboard(int screen, PyObject *callback); + void ungrabKeyboard(); + + bool addButton(const std::string &but, MouseContext::MC context, + MouseAction::MA action, PyObject *callback); + + void grabButtons(bool grab, Client *client); + + //! Removes all button bindings + void removeAllButtons(); + + void fireButton(MouseData *data); + + //! Bind a callback for an event + bool addEvent(EventAction::EA action, PyObject *callback); + + //! Unbind the callback function from an event + bool removeEvent(EventAction::EA action, PyObject *callback); + + //! Remove all callback functions + void removeAllEvents(); + + void fireEvent(EventData *data); }; }