From 2fe13ccca8802113bbd3baf2b208d911db0dbcbc Mon Sep 17 00:00:00 2001 From: David Robillard Date: Sat, 2 Feb 2013 18:06:06 +0000 Subject: Fix strange bug where canvas stops updating entirely on node removal. git-svn-id: http://svn.drobilla.net/lad/trunk/ganv@5025 a436a847-0d15-0410-975c-d299462d15a1 --- src/canvas-base.c | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) (limited to 'src/canvas-base.c') diff --git a/src/canvas-base.c b/src/canvas-base.c index 653ebf2..59ed3de 100644 --- a/src/canvas-base.c +++ b/src/canvas-base.c @@ -249,22 +249,22 @@ ganv_item_dispose(GObject* object) /* Make the canvas forget about us */ - if (item->canvas && ( item == item->canvas->current_item) ) { + if (item->canvas && item == item->canvas->current_item) { item->canvas->current_item = NULL; item->canvas->need_repick = TRUE; } - if (item->canvas && ( item == item->canvas->new_current_item) ) { + if (item->canvas && item == item->canvas->new_current_item) { item->canvas->new_current_item = NULL; item->canvas->need_repick = TRUE; } - if (item->canvas && ( item == item->canvas->grabbed_item) ) { + if (item->canvas && item == item->canvas->grabbed_item) { item->canvas->grabbed_item = NULL; gdk_pointer_ungrab(GDK_CURRENT_TIME); } - if (item->canvas && ( item == item->canvas->focused_item) ) { + if (item->canvas && item == item->canvas->focused_item) { item->canvas->focused_item = NULL; } @@ -750,9 +750,13 @@ ganv_item_get_bounds(GanvItem* item, double* x1, double* y1, double* x2, double* void ganv_item_request_update(GanvItem* item) { + /* FIXME: For some reason, if this short-circuit is enabled, the canvas + stops updating items entirely when connected modules are removed. */ + /* if (item->object.flags & GANV_ITEM_NEED_UPDATE) { return; } + */ item->object.flags |= GANV_ITEM_NEED_UPDATE; -- cgit v1.2.1