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; }
};
-
-private:
- // milliseconds XXX: config option
- static const unsigned int DOUBLECLICKDELAY;
- //! The mouse button currently being watched from a press for a CLICK
- unsigned int _button;
+ 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:
- //! 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 leaveHandler(const XCrossingEvent &e);
virtual void keyPressHandler(const XKeyEvent &e);
+ virtual void keyReleaseHandler(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);
+#ifdef XKB
+ virtual void xkbHandler(const XkbEvent &e);
+#endif // XKB
+
};
}