]> git.donarmstrong.com Git - lilypond.git/blob - lily/stream-event.cc
e9fe80a22fa17d60269c418763029f41a370fca5
[lilypond.git] / lily / stream-event.cc
1 /*
2   stream-event.cc -- implement Stream_event
3
4   source file of the GNU LilyPond music typesetter
5
6   (c) 2005-2006 Erik Sandberg  <mandolaerik@gmail.com>
7 */
8
9 #include "stream-event.hh"
10
11 #include "ly-smobs.icc"
12 #include "context.hh"
13 #include "input.hh"
14 #include "input-smob.hh"
15
16 Stream_event::Stream_event ()
17   : Prob (ly_symbol2scm ("Stream_event"), SCM_EOL)
18 {
19 }
20
21 Stream_event::Stream_event (SCM event_class, SCM mutable_props)
22   : Prob (ly_symbol2scm ("Stream_event"),
23           scm_list_1 (scm_cons (ly_symbol2scm ("class"), event_class)))
24 {
25   mutable_property_alist_ = mutable_props;
26 }
27
28 Stream_event::Stream_event (SCM property_alist)
29   : Prob (ly_symbol2scm ("Stream_event"), SCM_EOL)
30 {
31   mutable_property_alist_ = property_alist;
32 }
33
34 Stream_event::Stream_event (SCM class_name, Input *origin)
35   : Prob (ly_symbol2scm ("Stream_event"),
36           scm_list_1 (scm_cons (ly_symbol2scm ("class"), class_name)))
37 {
38   if (origin)
39     set_spot (origin);
40 }
41
42 Stream_event::Stream_event (Stream_event *ev)
43   : Prob (ly_symbol2scm ("Stream_event"), SCM_EOL)
44 {
45   mutable_property_alist_ = scm_copy_tree (ev->mutable_property_alist_);
46   immutable_property_alist_ = ev->immutable_property_alist_;
47 }
48
49 Input *
50 Stream_event::origin () const
51 {
52   Input *i = unsmob_input (get_property ("origin"));
53   return i ? i : &dummy_input_global;
54 }
55
56 void Stream_event::set_spot (Input *i)
57 {
58   set_property ("origin", make_input (*i));
59 }
60
61 IMPLEMENT_TYPE_P (Stream_event, "ly:stream-event?");
62
63 MAKE_SCHEME_CALLBACK (Stream_event, undump, 1);
64 MAKE_SCHEME_CALLBACK (Stream_event, dump, 1);
65
66 SCM
67 Stream_event::dump (SCM self)
68 {
69   Stream_event *ev = unsmob_stream_event (self);
70   // Reversed alists look prettier.
71   return scm_cons (scm_reverse (ev->immutable_property_alist_),
72                    scm_reverse (ev->mutable_property_alist_));
73 }
74
75 SCM
76 Stream_event::undump (SCM data)
77 {
78   Stream_event *obj = new Stream_event ();
79   obj->immutable_property_alist_ = scm_reverse (scm_car (data));
80   obj->mutable_property_alist_ = scm_reverse (scm_cdr (data));
81   return obj->unprotect ();
82 }
83
84 Stream_event *
85 unsmob_stream_event (SCM m)
86 {
87   return dynamic_cast<Stream_event*> (unsmob_prob (m));
88 }