X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Factions.hh;h=2b68153ab57c3d9c9908283af27a6ec177ccc158;hb=ca3e463057ebf8a7a48a5997aedc062cdac72f3f;hp=50df838b22dd3eada79ba6f8f416b0d2b333a904;hpb=66a26917a0631463df7f72c34cbeb39df466918a;p=chaz%2Fopenbox diff --git a/src/actions.hh b/src/actions.hh index 50df838b..2b68153a 100644 --- a/src/actions.hh +++ b/src/actions.hh @@ -29,14 +29,8 @@ class OBActions : public otk::OtkEventHandler { public: // update the same enum in openbox.i when making changes to this enum ActionType { - Action_ButtonPress, - Action_ButtonRelease, - Action_Click, - Action_DoubleClick, Action_EnterWindow, Action_LeaveWindow, - Action_KeyPress, - Action_MouseMotion, Action_NewWindow, Action_CloseWindow, NUM_ACTIONS @@ -48,16 +42,33 @@ public: Time time; ButtonReleaseAction() { win = 0; button = 0; time = 0; } }; + + struct ButtonPressAction { + unsigned int button; + otk::Point pos; + otk::Rect clientarea; + 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]; + + void insertPress(const XButtonEvent &e); + void removePress(const XButtonEvent &e); + typedef std::multimap CallbackMap; typedef std::pair CallbackMapPair; CallbackMap _callbacks; @@ -86,7 +97,6 @@ public: virtual void unmapHandler(const XUnmapEvent &e); virtual void destroyHandler(const XDestroyWindowEvent &e); - //! Add a callback funtion to the back of the hook list /*! Registering functions for KeyPress events is pointless. Use