From efd95201fd9c368eef6a4986e7c3bfe260da7e2c Mon Sep 17 00:00:00 2001 From: Tilman Sauerbeck Date: Tue, 14 Feb 2006 19:06:43 +0000 Subject: [PATCH] Reworked on_ecore_event(). If one event handler's block returns false, don't call neither the other C handlers nor the other Ruby handlers. --- src/ecore/rb_event_handler.c | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/src/ecore/rb_event_handler.c b/src/ecore/rb_event_handler.c index f296ae2..a360ef7 100644 --- a/src/ecore/rb_event_handler.c +++ b/src/ecore/rb_event_handler.c @@ -1,5 +1,5 @@ /* - * $Id: rb_event_handler.c 363 2006-02-14 19:02:53Z tilman $ + * $Id: rb_event_handler.c 364 2006-02-14 19:06:43Z tilman $ * * Copyright (C) 2004 ruby-ecore team (see AUTHORS) * @@ -130,7 +130,7 @@ static int on_ecore_event (void *data, int type, void *event) { RbEventHandler *h = NULL; VALUE handler, klass, obj, tmp, res; - int handler_type, len, i; + int handler_type, len, ret = 1, i; /* instantiate the event object * first, find the class we're gonna use @@ -157,13 +157,14 @@ static int on_ecore_event (void *data, int type, void *event) /* if the block returned false, don't call the other * event handlers */ - if (res == Qfalse) + if (res == Qfalse) { + ret = 0; break; + } } } - /* call other event handlers, too */ - return 1; + return ret; } VALUE c_ev_generic_init (VALUE self, VALUE event) -- 2.30.2