X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fdispatcher-scheme.cc;h=307152e23c8146ac730a5361d111c0e5f10c636b;hb=5b4b0d6e9a197e8f9eb085b7c2ad78b8be3e5cfc;hp=9e491e0a9abc185795c01e1c1be5091dd32998da;hpb=a276a19dc6bd57832db3107f2f2cbb04cb4677b6;p=lilypond.git diff --git a/lily/dispatcher-scheme.cc b/lily/dispatcher-scheme.cc index 9e491e0a9a..307152e23c 100644 --- a/lily/dispatcher-scheme.cc +++ b/lily/dispatcher-scheme.cc @@ -3,26 +3,28 @@ source file of the GNU LilyPond music typesetter - (c) 2006--2007 Erik Sandberg + (c) 2006--2008 Erik Sandberg */ #include "dispatcher.hh" LY_DEFINE (ly_make_dispatcher, "ly:make-dispatcher", 0, 0, 0, (), - "Returns a newly created dispatcher.") + "Return a newly created dispatcher.") { return (new Dispatcher ())->unprotect (); } -LY_DEFINE (ly_register_dispatcher, "ly:connect-dispatchers", +LY_DEFINE (ly_connect_dispatchers, "ly:connect-dispatchers", 2, 0, 0, (SCM to, SCM from), - "Makes the dispatcher @var{to} listen to events from @var{from}." ) + "Make the dispatcher @var{to} listen to events from @var{from}.") { Dispatcher *t = unsmob_dispatcher (to); Dispatcher *f = unsmob_dispatcher (from); - SCM_ASSERT_TYPE (t, from, SCM_ARG1, __FUNCTION__, "dispatcher"); - SCM_ASSERT_TYPE (f, to, SCM_ARG2, __FUNCTION__, "dispatcher"); + + LY_ASSERT_SMOB (Dispatcher, to, 1); + LY_ASSERT_SMOB (Dispatcher, from, 2); + t->register_as_listener (f); return SCM_UNDEFINED; @@ -30,13 +32,15 @@ LY_DEFINE (ly_register_dispatcher, "ly:connect-dispatchers", LY_DEFINE (ly_add_listener, "ly:add-listener", 2, 0, 1, (SCM list, SCM disp, SCM cl), - "Adds the listener @var{list} to the dispatcher @var{disp}.\n" - " Whenever @var{disp} hears an event of class @var{cl}, it will be forwarded to @var{list}.\n" ) + "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}.") { Listener *l = unsmob_listener (list); Dispatcher *d = unsmob_dispatcher (disp); - SCM_ASSERT_TYPE (l, list, SCM_ARG1, __FUNCTION__, "listener"); - SCM_ASSERT_TYPE (d, disp, SCM_ARG2, __FUNCTION__, "dispatcher"); + + LY_ASSERT_SMOB (Listener, list, 1); + LY_ASSERT_SMOB (Dispatcher, disp, 2); for (int arg = SCM_ARG3; scm_is_pair (cl); cl = scm_cdr (cl), arg++) { @@ -50,13 +54,14 @@ LY_DEFINE (ly_add_listener, "ly:add-listener", LY_DEFINE (ly_broadcast, "ly:broadcast", 2, 0, 0, (SCM disp, SCM ev), - "Sends the stream event @var{ev} to the dispatcher\n" - "@var{disp}.") + "Send the stream event @var{ev} to the dispatcher @var{disp}.") { Dispatcher *d = unsmob_dispatcher (disp); Stream_event *e = unsmob_stream_event (ev); - SCM_ASSERT_TYPE (d, disp, SCM_ARG1, __FUNCTION__, "dispatcher"); - SCM_ASSERT_TYPE (e, ev, SCM_ARG2, __FUNCTION__, "stream event"); + + LY_ASSERT_SMOB (Dispatcher, disp, 1); + + LY_ASSERT_SMOB (Stream_event, ev, 2); d->broadcast (e); return SCM_UNDEFINED; }