]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/stream-event-scheme.cc
Run `make grand-replace'.
[lilypond.git] / lily / stream-event-scheme.cc
index ce337d5472a990b8e0b549527e5cb6bdfff31111..3b08add66fa0d54552ab865348548b7a4f5f2cc6 100644 (file)
@@ -3,28 +3,64 @@
 
   source file of the GNU LilyPond music typesetter
 
-  (c) 2006 Erik Sandberg  <mandolaerik@gmail.com>
+  (c) 2006--2008 Erik Sandberg  <mandolaerik@gmail.com>
 */
 
 #include "stream-event.hh"
 
 LY_DEFINE (ly_make_stream_event, "ly:make-stream-event",
-          1, 0, 0, (SCM proplist),
-          "Creates a stream event, with the given property list.\n" )
+          1, 1, 0, (SCM cl, SCM proplist),
+          "Create a stream event of class @var{cl} with the given"
+          " mutable property list.")
 {
-  SCM_ASSERT_TYPE (scm_list_p (proplist), proplist, SCM_ARG1, __FUNCTION__, "association list");
-  Stream_event *e = new Stream_event (proplist);
+  LY_ASSERT_TYPE (ly_is_symbol, cl, 1);
+
+  /* should be scm_list_p, but scm_list_p is expensive. */
+  LY_ASSERT_TYPE (scm_is_pair, proplist, 2);
+  
+  if (proplist == SCM_UNDEFINED)
+    proplist = SCM_EOL;
+
+  Stream_event *e = new Stream_event (cl, proplist);
   return e->unprotect ();
 }
 
 LY_DEFINE (ly_event_property, "ly:event-property", 
            2, 0, 0, (SCM sev, SCM sym),
-          "Get the property @var{sym} of stream event @var{mus}.\n"
-          "If @var{sym} is undefined, return @code{' ()}.\n")
+          "Get the property @var{sym} of stream event @var{mus}."
+          "  If @var{sym} is undefined, return @code{'()}.")
 {
+  LY_ASSERT_SMOB (Stream_event, sev, 1);
+  LY_ASSERT_TYPE (ly_is_symbol, sym, 2);
+
   Stream_event *e = unsmob_stream_event (sev);
-  SCM_ASSERT_TYPE (e, sev, SCM_ARG1, __FUNCTION__, "stream event");
-  SCM_ASSERT_TYPE (scm_is_symbol (sym), sym, SCM_ARG2, __FUNCTION__, "symbol");
 
   return e->internal_get_property (sym);
 }
+
+LY_DEFINE (ly_event_set_property_x, "ly:event-set-property!",
+           3, 0, 0, (SCM ev, SCM sym, SCM val),
+           "Set property @var{sym} in event @var{ev} to @var{val}.")
+{
+  LY_ASSERT_SMOB (Stream_event, ev, 1);
+  LY_ASSERT_TYPE (ly_is_symbol, sym, 2);
+  
+  return ly_prob_set_property_x (ev, sym, val);
+}
+
+LY_DEFINE (ly_event_deep_copy, "ly:event-deep-copy",
+          1, 0, 0, (SCM m),
+          "Copy @var{m} and all sub expressions of@tie{}@var{m}.")
+{
+  SCM copy = m;
+  if (Stream_event *ev = unsmob_stream_event (m))
+    {
+      ev = ev->clone ();
+      copy = ev->unprotect ();
+    }
+  else if (scm_is_pair (m))
+    copy = scm_cons (ly_event_deep_copy (scm_car (m)),
+                    ly_event_deep_copy (scm_cdr (m)));
+
+  return copy;
+}