@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 <X11/Xlib.h>
+#include <Python.h>
}
+#include <map>
+
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 : public otk::OtkEventHandler {
+class Actions : public otk::EventHandler {
public:
- // 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
- };
-
+#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 {
+ 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
unsigned int _button;
//! The last button release processed for CLICKs
ButtonReleaseAction _release;
+ //! The point where the mouse was when each mouse button was pressed
+ /*!
+ Used for motion events as the starting position.
+ */
+ ButtonPressAction *_posqueue[BUTTONS];
+ //! 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;
+
+
+ void insertPress(const XButtonEvent &e);
+ 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);
virtual void mapRequestHandler(const XMapRequestEvent &e);
virtual void unmapHandler(const XUnmapEvent &e);
virtual void destroyHandler(const XDestroyWindowEvent &e);
+
+#ifdef XKB
+ virtual void xkbHandler(const XkbEvent &e);
+#endif // XKB
+
};
}