X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Factions.hh;h=c2de2b683a99ad582812de60baee019f8787993f;hb=7c32ac2b3f0bfd02a1efea1d67e5ad1c3c5be93f;hp=7168fce459a95c1c58a30ab56b9b781d4dbab952;hpb=38f8155bf50af2a2bf13e8767236dae924abb157;p=chaz%2Fopenbox diff --git a/src/actions.hh b/src/actions.hh index 7168fce4..c2de2b68 100644 --- a/src/actions.hh +++ b/src/actions.hh @@ -1,4 +1,4 @@ -// -*- mode: C++; indent-tabs-mode: nil; -*- +// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*- #ifndef __actions_hh #define __actions_hh @@ -12,8 +12,11 @@ extern "C" { #include +#include } +#include + namespace ob { //! The action interface for user-available actions @@ -21,25 +24,26 @@ namespace ob { When these actions are fired, hooks to the guile engine are fired so that guile code is run. */ -class OBActions : public otk::OtkEventHandler { +class Actions : public otk::EventHandler { public: +#ifndef SWIG // get rid of a swig warning struct ButtonReleaseAction { Window win; unsigned int button; Time time; ButtonReleaseAction() { win = 0; button = 0; time = 0; } }; - + struct ButtonPressAction { + Window win; unsigned int button; otk::Point pos; otk::Rect clientarea; ButtonPressAction() { button = 0; } }; - +#endif // SWIG 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 @@ -51,19 +55,19 @@ private: Used for motion events as the starting position. */ ButtonPressAction *_posqueue[BUTTONS]; - //! The delta x/y of the last motion sequence - int _dx, _dy; + //! This is set to true once a drag has started and false when done to make + //! sure the threshold isnt checked anymore once a drag is underway + bool _dragging; - //! 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(); + //! Constructs an Actions object + Actions(); + //! Destroys the Actions object + virtual ~Actions(); virtual void buttonPressHandler(const XButtonEvent &e); virtual void buttonReleaseHandler(const XButtonEvent &e); @@ -72,8 +76,14 @@ public: virtual void leaveHandler(const XCrossingEvent &e); virtual void keyPressHandler(const XKeyEvent &e); + virtual void keyReleaseHandler(const XKeyEvent &e); virtual void motionHandler(const XMotionEvent &e); + +#ifdef XKB + virtual void xkbHandler(const XkbEvent &e); +#endif // XKB + }; }