summaryrefslogtreecommitdiffstats
path: root/src/libs/gui/PatchCanvas.cpp
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2008-06-09 19:58:15 +0000
committerDavid Robillard <d@drobilla.net>2008-06-09 19:58:15 +0000
commit2b662dd993c1cce712148765c953dfaf92390a01 (patch)
tree57d422f94026cc45507ab44948032c93a7f7bf37 /src/libs/gui/PatchCanvas.cpp
parentdf38131db2c4eb5c83655d848a9776faa79331ca (diff)
downloadingen-2b662dd993c1cce712148765c953dfaf92390a01.tar.gz
ingen-2b662dd993c1cce712148765c953dfaf92390a01.tar.bz2
ingen-2b662dd993c1cce712148765c953dfaf92390a01.zip
Fix Ctrl 'editable' patch modifier (for control twiddling) ceasing to work in various scenarios (ticket #120).
git-svn-id: http://svn.drobilla.net/lad/ingen@1259 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/libs/gui/PatchCanvas.cpp')
-rw-r--r--src/libs/gui/PatchCanvas.cpp48
1 files changed, 36 insertions, 12 deletions
diff --git a/src/libs/gui/PatchCanvas.cpp b/src/libs/gui/PatchCanvas.cpp
index b26c5737..a787b1ae 100644
--- a/src/libs/gui/PatchCanvas.cpp
+++ b/src/libs/gui/PatchCanvas.cpp
@@ -447,7 +447,7 @@ PatchCanvas::canvas_event(GdkEvent* event)
{
assert(event);
- static bool control_modded = false;
+ bool ret = false;
switch (event->type) {
@@ -456,34 +456,58 @@ PatchCanvas::canvas_event(GdkEvent* event)
_last_click_x = (int)event->button.x;
_last_click_y = (int)event->button.y;
show_menu(event);
+ ret = true;
}
break;
case GDK_KEY_PRESS:
- if (event->key.keyval == GDK_Delete) {
+ case GDK_KEY_RELEASE:
+ ret = canvas_key_event(&event->key);
+
+ default:
+ break;
+ }
+
+ return (ret ? true : Canvas::canvas_event(event));
+}
+
+
+bool
+PatchCanvas::canvas_key_event(GdkEventKey* event)
+{
+ static bool control_modded = false;
+
+ switch (event->type) {
+ case GDK_KEY_PRESS:
+ switch (event->keyval) {
+ case GDK_Delete:
destroy_selection();
- } else if (event->key.keyval == GDK_Control_L || event->key.keyval == GDK_Control_R) {
+ return true;
+ case GDK_Control_L:
+ case GDK_Control_R:
if (_patch->get_editable() == true) {
control_modded = true;
_patch->set_editable(false);
}
+ return true;
+ default:
+ return false;
}
- break;
-
case GDK_KEY_RELEASE:
- if (event->key.keyval == GDK_Control_L || event->key.keyval == GDK_Control_R) {
- if (_patch->get_editable() == false &&control_modded) {
+ switch (event->keyval) {
+ case GDK_Control_L:
+ case GDK_Control_R:
+ if (_patch->get_editable() == false && control_modded) {
control_modded = false;
_patch->set_editable(true);
}
+ return true;
+ default:
+ return false;
}
- break;
-
default:
- break;
+ return false;
}
-
- return Canvas::canvas_event(event);
}