2 stream-event.cc -- implement Scheme bindings for Stream_event
4 source file of the GNU LilyPond music typesetter
6 (c) 2006--2007 Erik Sandberg <mandolaerik@gmail.com>
9 #include "stream-event.hh"
11 LY_DEFINE (ly_make_stream_event, "ly:make-stream-event",
12 1, 1, 0, (SCM cl, SCM proplist),
13 "Creates a stream event of class @var{cl} with the given mutable property list.\n" )
15 SCM_ASSERT_TYPE (scm_is_symbol (cl), cl, SCM_ARG1, __FUNCTION__, "symbol");
17 /* should be scm_list_p, but scm_list_p is expensive. */
18 SCM_ASSERT_TYPE (scm_is_pair (proplist), proplist, SCM_ARG2, __FUNCTION__, "association list");
20 if (proplist == SCM_UNDEFINED)
23 Stream_event *e = new Stream_event (cl, proplist);
24 return e->unprotect ();
27 LY_DEFINE (ly_event_property, "ly:event-property",
28 2, 0, 0, (SCM sev, SCM sym),
29 "Get the property @var{sym} of stream event @var{mus}.\n"
30 "If @var{sym} is undefined, return @code{'()}.\n")
32 Stream_event *e = unsmob_stream_event (sev);
33 SCM_ASSERT_TYPE (e, sev, SCM_ARG1, __FUNCTION__, "stream event");
34 SCM_ASSERT_TYPE (scm_is_symbol (sym), sym, SCM_ARG2, __FUNCTION__, "symbol");
36 return e->internal_get_property (sym);
39 LY_DEFINE (ly_event_set_property_x, "ly:event-set-property!",
40 3, 0, 0, (SCM ev, SCM sym, SCM val),
41 "Set property @var{sym} in event @var{ev} to @var{val}."){
42 Stream_event *sc = unsmob_stream_event (ev);
43 SCM_ASSERT_TYPE (sc, ev, SCM_ARG1, __FUNCTION__, "event");
44 return ly_prob_set_property_x (ev, sym, val);
47 LY_DEFINE (ly_event_deep_copy, "ly:event-deep-copy",
49 "Copy @var{m} and all sub expressions of @var{m}")
52 if (Stream_event *ev = unsmob_stream_event (m))
55 copy = ev->unprotect ();
57 else if (scm_is_pair (m))
58 copy = scm_cons (ly_event_deep_copy (scm_car (m)),
59 ly_event_deep_copy (scm_cdr (m)));