X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Factions.hh;h=4165dd2ef310e7ba844b1c157ae7c578f9625111;hb=7d215bd255d0744101b9ceb52c235bdc985fa034;hp=1013e527b8b2a47c5c92f9c924e35de4999c7b42;hpb=23a7f188297ba3cef1bf13f1be9407ff6eb9bd62;p=chaz%2Fopenbox diff --git a/src/actions.hh b/src/actions.hh index 1013e527..4165dd2e 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 @@ -6,20 +6,72 @@ @brief The action interface for user-available actions */ +#include "otk/point.hh" +#include "otk/rect.hh" +#include "otk/eventhandler.hh" + +extern "C" { +#include +#include +} + +#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 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: + //! The last button release processed for CLICKs + ButtonReleaseAction _release; + //! The last button press processed for CLICKs + ButtonPressAction _press; + //! 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; public: - OBActions(); - 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); + virtual void enterHandler(const XCrossingEvent &e); + 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 + }; }