X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fdispatcher-scheme.cc;h=3fd4decc42b28640ce77f2a76d7ca968e7d909ec;hb=4d405ef96a8a62771d7d9a283ff5369a772e89d8;hp=f6ef23d120279e8ded3b0e6678c10c899940be7d;hpb=0b544cfb7332615ef809b71b57ab656741311ae1;p=lilypond.git diff --git a/lily/dispatcher-scheme.cc b/lily/dispatcher-scheme.cc index f6ef23d120..3fd4decc42 100644 --- a/lily/dispatcher-scheme.cc +++ b/lily/dispatcher-scheme.cc @@ -1,7 +1,7 @@ /* This file is part of LilyPond, the GNU music typesetter. - Copyright (C) 2006--2014 Erik Sandberg + Copyright (C) 2006--2015 Erik Sandberg LilyPond is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -30,8 +30,8 @@ LY_DEFINE (ly_connect_dispatchers, "ly:connect-dispatchers", 2, 0, 0, (SCM to, SCM from), "Make the dispatcher @var{to} listen to events from @var{from}.") { - Dispatcher *t = unsmob_dispatcher (to); - Dispatcher *f = unsmob_dispatcher (from); + Dispatcher *t = unsmob (to); + Dispatcher *f = unsmob (from); LY_ASSERT_SMOB (Dispatcher, to, 1); LY_ASSERT_SMOB (Dispatcher, from, 2); @@ -41,23 +41,37 @@ LY_DEFINE (ly_connect_dispatchers, "ly:connect-dispatchers", return SCM_UNSPECIFIED; } +LY_DEFINE (ly_disconnect_dispatchers, "ly:disconnect-dispatchers", + 2, 0, 0, (SCM to, SCM from), + "Stop the dispatcher @var{to} listening to events from @var{from}.") +{ + Dispatcher *t = unsmob (to); + Dispatcher *f = unsmob (from); + + LY_ASSERT_SMOB (Dispatcher, to, 1); + LY_ASSERT_SMOB (Dispatcher, from, 2); + + t->unregister_as_listener (f); + + return SCM_UNSPECIFIED; +} + LY_DEFINE (ly_add_listener, "ly:add-listener", - 2, 0, 1, (SCM list, SCM disp, SCM cl), - "Add the listener @var{list} to the dispatcher @var{disp}." - " Whenever @var{disp} hears an event of class @var{cl}," - " it is forwarded to @var{list}.") + 2, 0, 1, (SCM callback, SCM disp, SCM cl), + "Add the single-argument procedure @var{callback} as listener" + " to the dispatcher @var{disp}. Whenever @var{disp} hears" + " an event of class @var{cl}, it calls @var{callback} with it.") { - Listener *l = unsmob_listener (list); - Dispatcher *d = unsmob_dispatcher (disp); + Dispatcher *d = unsmob (disp); - LY_ASSERT_SMOB (Listener, list, 1); + LY_ASSERT_TYPE (ly_is_procedure, callback, 1); LY_ASSERT_SMOB (Dispatcher, disp, 2); for (int arg = SCM_ARG3; scm_is_pair (cl); cl = scm_cdr (cl), arg++) { SCM sym = scm_car (cl); SCM_ASSERT_TYPE (scm_is_symbol (sym), sym, arg, __FUNCTION__, "symbol"); - d->add_listener (*l, sym); + d->add_listener (callback, sym); } return SCM_UNSPECIFIED; @@ -70,7 +84,7 @@ LY_DEFINE (ly_listened_event_types, "ly:listened-event-types", { LY_ASSERT_SMOB (Dispatcher, disp, 1); - SCM result = unsmob_dispatcher (disp)->listened_types (); + SCM result = unsmob (disp)->listened_types (); scm_remember_upto_here_1 (disp); @@ -85,7 +99,7 @@ LY_DEFINE (ly_listened_event_class_p, "ly:listened-event-class?", LY_ASSERT_SMOB (Dispatcher, disp, 1); LY_ASSERT_TYPE (scm_is_pair, cl, 2); - bool result = unsmob_dispatcher (disp)->is_listened_class (cl); + bool result = unsmob (disp)->is_listened_class (cl); scm_remember_upto_here_1 (disp); @@ -96,8 +110,8 @@ LY_DEFINE (ly_broadcast, "ly:broadcast", 2, 0, 0, (SCM disp, SCM ev), "Send the stream event @var{ev} to the dispatcher @var{disp}.") { - Dispatcher *d = unsmob_dispatcher (disp); - Stream_event *e = unsmob_stream_event (ev); + Dispatcher *d = unsmob (disp); + Stream_event *e = unsmob (ev); LY_ASSERT_SMOB (Dispatcher, disp, 1);