summaryrefslogtreecommitdiff
path: root/src/actions.cc
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2002-12-30 22:27:46 +0000
committerDana Jansens <danakj@orodu.net>2002-12-30 22:27:46 +0000
commitd7a30f93b517ac76816d0acea92e9c56ad5d6594 (patch)
treee6453231346cea176c4ea49c2f5edd408f0400a8 /src/actions.cc
parentdb1fb534b8f5a1f19710ac77ef2ce85c4c1270ec (diff)
so close to keybindings. wont link for now.
Diffstat (limited to 'src/actions.cc')
-rw-r--r--src/actions.cc25
1 files changed, 18 insertions, 7 deletions
diff --git a/src/actions.cc b/src/actions.cc
index 716b033b..cbce4f12 100644
--- a/src/actions.cc
+++ b/src/actions.cc
@@ -9,6 +9,7 @@
#include "openbox.hh"
#include "client.hh"
#include "python.hh"
+#include "bindings.hh"
#include "otk/display.hh"
#include <stdio.h>
@@ -41,6 +42,9 @@ void OBActions::buttonPressHandler(const XButtonEvent &e)
python_callback(Action_ButtonPress, e.window,
(OBWidget::WidgetType)(w ? w->type():-1),
e.state, e.button, e.x_root, e.y_root, e.time);
+ if (w && w->type() == OBWidget::Type_Frame) // a binding
+ Openbox::instance->bindings()->fire(Action_ButtonPress, e.window,
+ e.state, e.button, e.time);
if (_button) return; // won't count toward CLICK events
@@ -59,6 +63,9 @@ void OBActions::buttonReleaseHandler(const XButtonEvent &e)
python_callback(Action_ButtonRelease, e.window,
(OBWidget::WidgetType)(w ? w->type():-1),
e.state, e.button, e.x_root, e.y_root, e.time);
+ if (w && w->type() == OBWidget::Type_Frame) // a binding
+ Openbox::instance->bindings()->fire(Action_ButtonRelease, e.window,
+ e.state, e.button, e.time);
// not for the button we're watching?
if (_button != e.button) return;
@@ -78,6 +85,9 @@ void OBActions::buttonReleaseHandler(const XButtonEvent &e)
python_callback(Action_Click, e.window,
(OBWidget::WidgetType)(w ? w->type():-1),
e.state, e.button, e.time);
+ if (w && w->type() == OBWidget::Type_Frame) // a binding
+ Openbox::instance->bindings()->fire(Action_Click, e.window,
+ e.state, e.button, e.time);
if (e.time - _release.time < DOUBLECLICKDELAY &&
_release.win == e.window && _release.button == e.button) {
@@ -86,7 +96,10 @@ void OBActions::buttonReleaseHandler(const XButtonEvent &e)
python_callback(Action_DoubleClick, e.window,
(OBWidget::WidgetType)(w ? w->type():-1),
e.state, e.button, e.time);
-
+ if (w && w->type() == OBWidget::Type_Frame) // a binding
+ Openbox::instance->bindings()->fire(Action_DoubleClick, e.window,
+ e.state, e.button, e.time);
+
// reset so you cant triple click for 2 doubleclicks
_release.win = 0;
_release.button = 0;
@@ -128,13 +141,11 @@ void OBActions::leaveHandler(const XCrossingEvent &e)
void OBActions::keyPressHandler(const XKeyEvent &e)
{
- OBWidget *w = dynamic_cast<OBWidget*>
- (Openbox::instance->findHandler(e.window));
+// OBWidget *w = dynamic_cast<OBWidget*>
+// (Openbox::instance->findHandler(e.window));
- // run the KEY guile hook
- python_callback(Action_KeyPress, e.window,
- (OBWidget::WidgetType)(w ? w->type():-1),
- e.state, e.keycode);
+ Openbox::instance->bindings()->fire(Action_KeyPress, e.window,
+ e.state, e.keycode, e.time);
}