X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Factions.hh;h=8b6633be5e66d1a861fc0d1c4d612ee986a9e925;hb=745e840547b5443ecfb9b6f0a4f14b0d035d59c2;hp=3df4fe4aa392a793c16074b9e9b59b7173eb4dbc;hpb=143d2df034e1304c1d9672226bd71f01533a1a63;p=chaz%2Fopenbox diff --git a/src/actions.hh b/src/actions.hh index 3df4fe4a..8b6633be 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,11 +6,14 @@ @brief The action interface for user-available actions */ -#include "otk/display.hh" #include "otk/point.hh" #include "otk/rect.hh" #include "otk/eventhandler.hh" +extern "C" { +#include +} + namespace ob { //! The action interface for user-available actions @@ -20,26 +23,41 @@ namespace ob { */ class OBActions : public otk::OtkEventHandler { public: - struct MouseButtonAction { + // 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 + }; + + struct ButtonReleaseAction { Window win; unsigned int button; Time time; - MouseButtonAction() { win = 0; button = 0; time = 0; } + ButtonReleaseAction() { win = 0; button = 0; time = 0; } }; - + private: // milliseconds XXX: config option static const unsigned int DOUBLECLICKDELAY; - //! The last 2 button release processed for CLICKs - MouseButtonAction _release; //! The mouse button currently being watched from a press for a CLICK unsigned int _button; + //! The last button release processed for CLICKs + ButtonReleaseAction _release; - void insertPress(Window win, unsigned int button, Time time); - public: + //! Constructs an OBActions object OBActions(); + //! Destroys the OBActions object virtual ~OBActions(); virtual void buttonPressHandler(const XButtonEvent &e); @@ -51,6 +69,10 @@ public: virtual void keyPressHandler(const XKeyEvent &e); virtual void motionHandler(const XMotionEvent &e); + + virtual void mapRequestHandler(const XMapRequestEvent &e); + virtual void unmapHandler(const XUnmapEvent &e); + virtual void destroyHandler(const XDestroyWindowEvent &e); }; }