X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Factions.hh;h=e57593f78f6fbecdd1f792dc74bc129b793c92fc;hb=4e0b5fdef451c605f563d137b024134a68c6d6de;hp=1013e527b8b2a47c5c92f9c924e35de4999c7b42;hpb=23a7f188297ba3cef1bf13f1be9407ff6eb9bd62;p=chaz%2Fopenbox diff --git a/src/actions.hh b/src/actions.hh index 1013e527..e57593f7 100644 --- a/src/actions.hh +++ b/src/actions.hh @@ -6,20 +6,70 @@ @brief The action interface for user-available actions */ +#include "otk/point.hh" +#include "otk/eventhandler.hh" + +extern "C" { +#include +} + namespace ob { //! The action interface for user-available actions /*! + When these actions are fired, hooks to the guile engine are fired so that + guile code is run. */ -class OBActions { +class OBActions : public otk::OtkEventHandler { public: + struct ButtonReleaseAction { + Window win; + unsigned int button; + Time time; + ButtonReleaseAction() { win = 0; button = 0; time = 0; } + }; + + struct ButtonPressAction { + unsigned int button; + otk::Point pos; + ButtonPressAction() { button = 0; } + }; private: + // milliseconds XXX: config option + static const unsigned int DOUBLECLICKDELAY; + static const int BUTTONS = 5; + + //! The mouse button currently being watched from a press for a CLICK + unsigned int _button; + //! The last button release processed for CLICKs + ButtonReleaseAction _release; + //! The point where the mouse was when each mouse button was pressed + /*! + Used for motion events as the starting position. + */ + ButtonPressAction *_posqueue[BUTTONS]; + //! Insert a button/position in the _posqueue + void insertPress(const XButtonEvent &e); + //! Remove a button/position from the _posqueue + void removePress(const XButtonEvent &e); + public: + //! Constructs an OBActions object OBActions(); + //! Destroys the OBActions object virtual ~OBActions(); + + virtual void buttonPressHandler(const XButtonEvent &e); + virtual void buttonReleaseHandler(const XButtonEvent &e); + virtual void enterHandler(const XCrossingEvent &e); + virtual void leaveHandler(const XCrossingEvent &e); + + virtual void keyPressHandler(const XKeyEvent &e); + + virtual void motionHandler(const XMotionEvent &e); }; }