]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/grob-info.cc
Fix some bugs in the dynamic engraver and PostScript backend
[lilypond.git] / lily / grob-info.cc
index 809fdd54a4c3c17b7cc7e7d4cfd98034da3ed8ca..a8f3f4c7b1c5320b1cfa34a2ddb9381fee193c5a 100644 (file)
@@ -3,38 +3,80 @@
 
   source file of the GNU LilyPond music typesetter
 
-  (c) 1997--2004 Han-Wen Nienhuys <hanwen@cs.uu.nl>
+  (c) 1997--2006 Han-Wen Nienhuys <hanwen@xs4all.nl>
 */
 
-#include "grob.hh"
 #include "grob-info.hh"
+#include "grob.hh"
 #include "music.hh"
 #include "translator-group.hh"
 #include "context.hh"
+#include "spanner.hh"
+#include "item.hh"
+
+Grob_info::Grob_info (Translator *t, Grob *g)
+{
+  origin_trans_ = t;
+  grob_ = g;
+  start_end_ = START;
+}
 
 Grob_info::Grob_info ()
 {
   grob_ = 0;
+  start_end_ = START;
   origin_trans_ = 0;
 }
 
-Music*
-Grob_info::music_cause ()
+Music *
+Grob_info::music_cause () const
 {
-  SCM cause = grob_->get_property ("cause"); 
+  SCM cause = grob_->get_property ("cause");
   return unsmob_music (cause);
 }
 
-Link_array<Context>
-Grob_info::origin_contexts (Translatorend) const
+vector<Context*>
+Grob_info::origin_contexts (Translator *end) const
 {
-  Context * t = origin_trans_->daddy_context_;
-  Link_array<Context> r;
-  do {
-    r.push (t);
-    t = t->daddy_context_;
-  } while (t && t != end->daddy_context_);
-  
+  Context *t = origin_trans_->context ();
+  vector<Context*> r;
+  do
+    {
+      r.push_back (t);
+      t = t->get_parent_context ();
+    }
+  while (t && t != end->context ());
+
   return r;
 }
-  
+
+Context *
+Grob_info::context () const
+{
+  return origin_trans_->context ();
+}
+
+Spanner *
+Grob_info::spanner () const
+{
+  return dynamic_cast<Spanner *> (grob_);
+}
+
+Item *
+Grob_info::item () const
+{
+  return dynamic_cast<Item *> (grob_);
+}
+
+Music *
+Grob_info::ultimate_music_cause () const
+{
+  SCM cause = grob_->self_scm ();
+  while (unsmob_grob (cause))
+    {
+      cause = unsmob_grob (cause)->get_property ("cause");
+    }
+
+  return unsmob_music (cause);
+}
+