X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Factions.hh;h=2b68153ab57c3d9c9908283af27a6ec177ccc158;hb=ca3e463057ebf8a7a48a5997aedc062cdac72f3f;hp=1a8d02c4c8e04195aea8e347d6e17d10dca29878;hpb=3827c1a76e27865a9e2cc9da43c42399ea354e18;p=chaz%2Fopenbox diff --git a/src/actions.hh b/src/actions.hh index 1a8d02c4..2b68153a 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,14 +6,18 @@ @brief The action interface for user-available actions */ +#include "widget.hh" #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 @@ -23,13 +27,12 @@ namespace ob { */ 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_EnterWindow, Action_LeaveWindow, - Action_KeyPress, - Action_MouseMotion, + Action_NewWindow, + Action_CloseWindow, NUM_ACTIONS }; @@ -39,14 +42,14 @@ 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; @@ -61,14 +64,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; - //! Insert a button/position in the _posqueue + void insertPress(const XButtonEvent &e); - //! Remove a button/position from the _posqueue void removePress(const XButtonEvent &e); + typedef std::multimap CallbackMap; + typedef std::pair CallbackMapPair; + CallbackMap _callbacks; + + void doCallback(ActionType action, Window window, OBWidget::WidgetType type, + unsigned int state, unsigned int button, + int xroot, int yroot, Time time); + public: //! Constructs an OBActions object OBActions(); @@ -84,6 +92,23 @@ 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); + + //! Add a callback funtion to the back of the hook list + /*! + Registering functions for KeyPress events is pointless. Use + OBSCript::bindKey instead to do this. + */ + bool registerCallback(ActionType action, PyObject *func, bool atfront); + + //! Remove a callback function from the hook list + bool unregisterCallback(ActionType action, PyObject *func); + + //! Remove all callback functions from the hook list + bool unregisterAllCallbacks(ActionType action); }; }