X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Factions.hh;h=98325e874e93d0560650949eddee96df9eb5974c;hb=4721c53868187d10e3732cea63efa9fbd352178d;hp=4c001be716aab2feb49745f896bcffa55f0aac14;hpb=4f01802c8cd0e0efc26896cf80e69dd9b6c06ec1;p=chaz%2Fopenbox diff --git a/src/actions.hh b/src/actions.hh index 4c001be7..98325e87 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,9 +6,17 @@ @brief The action interface for user-available actions */ -#include "otk/display.hh" +#include "widget.hh" #include "otk/point.hh" #include "otk/rect.hh" +#include "otk/eventhandler.hh" + +extern "C" { +#include +#include +} + +#include namespace ob { @@ -17,86 +25,79 @@ namespace ob { When these actions are fired, hooks to the guile engine are fired so that guile code is run. */ -class OBActions { +class OBActions : public otk::OtkEventHandler { public: - struct MousePressAction { + // update the same enum in openbox.i when making changes to this + enum ActionType { + Action_ButtonPress, + 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; - MousePressAction() { win = 0; button = 0; time = 0; } + ButtonReleaseAction() { win = 0; button = 0; time = 0; } }; - + private: // milliseconds XXX: config option - static const unsigned int DOUBLECLICKDELAY = 200; + static const unsigned int DOUBLECLICKDELAY; - //! The last 2 button presses processed for CLICKs - /*! - Inserted such that index 0 is the latest action. - */ - MousePressAction *_presses[2]; //! The mouse button currently being watched from a press for a CLICK unsigned int _button; - //! The window the last enter action occured on (where the mouse is located) - Window _enter_win; + //! The last button release processed for CLICKs + ButtonReleaseAction _release; - void insertPress(Window win, unsigned int button, Time time); + 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(); + //! Destroys the OBActions object virtual ~OBActions(); - //! Notify that a mouse button press has occured on a window. - /*! - @param win The window on which the action was performed. - @param modifiers The modifier state for the action. - @param button The mouse button the action is for. - @param time The time at which the event occured (from the XEvent). - */ - void bpress(Window win, unsigned int modifiers, unsigned int button, - Time time); + virtual void buttonPressHandler(const XButtonEvent &e); + virtual void buttonReleaseHandler(const XButtonEvent &e); + + virtual void enterHandler(const XCrossingEvent &e); + virtual void leaveHandler(const XCrossingEvent &e); - //! Notify that a mouse button release has occured on a window. - /*! - @param win The window on which the action was performed. - @param area The area of the window on which the action was performed. - @param mpos The position of the mouse pointer relative to the root window. - @param modifiers The modifier state for the action. - @param button The mouse button the action is for. - @param time The time at which the event occured (from the XEvent). - */ - void brelease(Window win, const otk::Rect &area, const otk::Point &mpos, - unsigned int modifiers, unsigned int button, Time time); + virtual void keyPressHandler(const XKeyEvent &e); - //! Notify that a mouse enter action has occured on a window. - /*! - @param win The window on which the action was performed. - @param modifiers The modifier state for the action. - */ - void enter(Window win, unsigned int modifiers); + virtual void motionHandler(const XMotionEvent &e); - //! Notify that a mouse leave action has occured on a window. - /*! - @param modifiers The modifier state for the action. - */ - void leave(unsigned int modifiers); + virtual void mapRequestHandler(const XMapRequestEvent &e); + virtual void unmapHandler(const XUnmapEvent &e); + virtual void destroyHandler(const XDestroyWindowEvent &e); - //! Notify that a mouse drag is taking place. - /*! - @param win The window the drag is on - @param delta The change in position of the mouse pointer - @param modifiers The modifier state during the drag. - */ - void drag(Window win, otk::Point delta, unsigned int modifiers, - unsigned int button, Time time); - //! Notify that a key press has occured on a window. + //! Add a callback funtion to the back of the hook list /*! - @param win The window the key press was on - @param modifiers The modifier state for the action. - @param keycode The keycode of the key pressed. + Registering functions for KeyPress events is pointless. Use + OBSCript::bindKey instead to do this. */ - void key(Window win, unsigned int modifiers, unsigned int keycode); + 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); }; }