]> git.donarmstrong.com Git - lilypond.git/commitdiff
* lily/include/grob-info.hh (class Grob_info): make data member
authorHan-Wen Nienhuys <hanwen@xs4all.nl>
Sun, 8 May 2005 23:30:51 +0000 (23:30 +0000)
committerHan-Wen Nienhuys <hanwen@xs4all.nl>
Sun, 8 May 2005 23:30:51 +0000 (23:30 +0000)
private. Changes throughout.

* lily/vertical-align-engraver.cc (acknowledge_grob): read
alignAboveContext and alignBelowContext

70 files changed:
ChangeLog
lily/accidental-engraver.cc
lily/ambitus-engraver.cc
lily/arpeggio-engraver.cc
lily/auto-beam-engraver.cc
lily/axis-group-engraver.cc
lily/bar-number-engraver.cc
lily/beam-engraver.cc
lily/break-align-engraver.cc
lily/chord-tremolo-engraver.cc
lily/clef-engraver.cc
lily/cluster-engraver.cc
lily/coherent-ligature-engraver.cc
lily/collision-engraver.cc
lily/custos-engraver.cc
lily/dot-column-engraver.cc
lily/drum-note-engraver.cc
lily/dynamic-engraver.cc
lily/engraver-group-engraver.cc
lily/engraver.cc
lily/extender-engraver.cc
lily/fingering-engraver.cc
lily/font-size-engraver.cc
lily/glissando-engraver.cc
lily/gregorian-ligature-engraver.cc
lily/grid-line-span-engraver.cc
lily/grob-pq-engraver.cc
lily/horizontal-bracket-engraver.cc
lily/hyphen-engraver.cc
lily/include/grob-info.hh
lily/instrument-name-engraver.cc
lily/key-engraver.cc
lily/ledger-line-engraver.cc
lily/ligature-bracket-engraver.cc
lily/ligature-engraver.cc
lily/mark-engraver.cc
lily/measure-grouping-engraver.cc
lily/mensural-ligature-engraver.cc
lily/new-fingering-engraver.cc
lily/note-head-line-engraver.cc
lily/ottava-engraver.cc
lily/output-property-engraver.cc
lily/part-combine-engraver.cc
lily/phrasing-slur-engraver.cc
lily/piano-pedal-engraver.cc
lily/pitch-squash-engraver.cc
lily/rest-collision-engraver.cc
lily/rhythmic-column-engraver.cc
lily/score-engraver.cc
lily/script-column-engraver.cc
lily/script-engraver.cc
lily/separating-line-group-engraver.cc
lily/slur-engraver.cc
lily/spacing-engraver.cc
lily/span-arpeggio-engraver.cc
lily/span-bar-engraver.cc
lily/staff-collecting-engraver.cc
lily/staff-symbol-engraver.cc
lily/stanza-number-align-engraver.cc
lily/stanza-number-engraver.cc
lily/stem-engraver.cc
lily/system-start-delimiter-engraver.cc
lily/text-engraver.cc
lily/text-spanner-engraver.cc
lily/tie-engraver.cc
lily/trill-spanner-engraver.cc
lily/tuplet-engraver.cc
lily/vaticana-ligature-engraver.cc
lily/vertical-align-engraver.cc
lily/volta-engraver.cc

index 141a16a40f8a55eead54ba9508b03bd8bd5c0dc9..988738e479a1636b9332c19fde61375f639252d3 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
 2005-05-09  Han-Wen Nienhuys  <hanwen@xs4all.nl>
 
+       * lily/include/grob-info.hh (class Grob_info): make data member
+       private. Changes throughout.
+
        * input/regression/alignment-order.ly: new file. 
 
        * lily/vertical-align-engraver.cc (acknowledge_grob): read
index 8a47a9cae1b992605aa53375ecd95a9a0721f05d..259e340d04dbda171f7dc0a86346a838ef5f52ba 100644 (file)
@@ -483,15 +483,15 @@ Accidental_engraver::acknowledge_grob (Grob_info info)
 
   if (note
       && note->is_mus_type ("note-event")
-      && Rhythmic_head::has_interface (info.grob_))
+      && Rhythmic_head::has_interface (info.grob ()))
     {
       if (to_boolean (get_property ("harmonicAccidentals"))
-         || !ly_c_equal_p (info.grob_->get_property ("style"),
+         || !ly_c_equal_p (info.grob ()->get_property ("style"),
                            ly_symbol2scm ("harmonic")))
        {
 
          Accidental_entry entry;
-         entry.head_ = info.grob_;
+         entry.head_ = info.grob ();
          entry.origin_trans_ = dynamic_cast<Engraver *> (info.origin_translator ());
          entry.origin_ = entry.origin_trans_->context ();
          entry.melodic_ = note;
@@ -499,13 +499,13 @@ Accidental_engraver::acknowledge_grob (Grob_info info)
          accidentals_.push (entry);
        }
     }
-  else if (Tie::has_interface (info.grob_))
-    ties_.push (dynamic_cast<Spanner *> (info.grob_));
-  else if (Arpeggio::has_interface (info.grob_))
-    left_objects_.push (info.grob_);
-  else if (info.grob_
+  else if (Tie::has_interface (info.grob ()))
+    ties_.push (dynamic_cast<Spanner *> (info.grob ()));
+  else if (Arpeggio::has_interface (info.grob ()))
+    left_objects_.push (info.grob ());
+  else if (info.grob ()
           ->internal_has_interface (ly_symbol2scm ("finger-interface")))
-    left_objects_.push (info.grob_);
+    left_objects_.push (info.grob ());
 }
 
 void
index 12402a3100fbfba53f815d361b4e2d4c1328d274..f48668e75521dbd47f32558700e80a3f9755d6ad 100644 (file)
@@ -114,10 +114,10 @@ Ambitus_engraver::stop_translation_timestep ()
 void
 Ambitus_engraver::acknowledge_grob (Grob_info info)
 {
-  Item *item = dynamic_cast<Item *> (info.grob_);
+  Item *item = dynamic_cast<Item *> (info.grob ());
   if (item)
     {
-      if (Note_head::has_interface (info.grob_))
+      if (Note_head::has_interface (info.grob ()))
        {
          Music *nr = info.music_cause ();
          if (nr && nr->is_mus_type ("note-event"))
index 08682dd674cace34696059191bd66f56422a64a8..61dbe54f324232ee314f9fadb2172eb54f39e5c8 100644 (file)
@@ -50,27 +50,27 @@ Arpeggio_engraver::acknowledge_grob (Grob_info info)
 {
   if (arpeggio_)
     {
-      if (Stem::has_interface (info.grob_))
+      if (Stem::has_interface (info.grob ()))
        {
          if (!arpeggio_->get_parent (Y_AXIS))
-           arpeggio_->set_parent (info.grob_, Y_AXIS);
+           arpeggio_->set_parent (info.grob (), Y_AXIS);
 
          Pointer_group_interface::add_grob (arpeggio_,
                                             ly_symbol2scm ("stems"),
-                                            info.grob_);
+                                            info.grob ());
        }
 
       /*
        We can't catch local key items (accidentals) from Voice context,
        see Local_key_engraver
       */
-      else if (Rhythmic_head::has_interface (info.grob_))
+      else if (Rhythmic_head::has_interface (info.grob ()))
        {
-         Side_position_interface::add_support (arpeggio_, info.grob_);
+         Side_position_interface::add_support (arpeggio_, info.grob ());
        }
-      else if (Note_column::has_interface (info.grob_))
+      else if (Note_column::has_interface (info.grob ()))
        {
-         info.grob_->set_property ("arpeggio", arpeggio_->self_scm ());
+         info.grob ()->set_property ("arpeggio", arpeggio_->self_scm ());
        }
     }
 }
index e4d71d0754e4ba6814f3b003078e19d67ebb7a3b..a4d8025704f3dc8a41493d8ae67914ae8983944e 100644 (file)
@@ -287,23 +287,23 @@ Auto_beam_engraver::acknowledge_grob (Grob_info info)
 
   if (stems_)
     {
-      if (Beam::has_interface (info.grob_))
+      if (Beam::has_interface (info.grob ()))
        {
          end_beam ();
        }
-      else if (Bar_line::has_interface (info.grob_))
+      else if (Bar_line::has_interface (info.grob ()))
        {
          end_beam ();
        }
-      else if (Rest::has_interface (info.grob_))
+      else if (Rest::has_interface (info.grob ()))
        {
          end_beam ();
        }
     }
 
-  if (Stem::has_interface (info.grob_))
+  if (Stem::has_interface (info.grob ()))
     {
-      Item *stem = dynamic_cast<Item *> (info.grob_);
+      Item *stem = dynamic_cast<Item *> (info.grob ());
       Music *m = info.music_cause ();
       if (!m->is_mus_type ("rhythmic-event"))
        {
index 6d74ade67cf497ed6671d5c80b300c605c1caca5..eac9299877da21bcbf60e6f0bf9b6bddf1d86ffc 100644 (file)
@@ -89,7 +89,7 @@ Axis_group_engraver::finalize ()
 void
 Axis_group_engraver::acknowledge_grob (Grob_info i)
 {
-  elts_.push (i.grob_);
+  elts_.push (i.grob ());
 }
 
 /*
@@ -191,8 +191,8 @@ Hara_kiri_engraver::acknowledge_grob (Grob_info i)
     {
       for (SCM s = interesting_; scm_is_pair (s); s = scm_cdr (s))
        {
-         if (i.grob_->internal_has_interface (scm_car (s)))
-           Hara_kiri_group_spanner::add_interesting_item (staffline_, i.grob_);
+         if (i.grob ()->internal_has_interface (scm_car (s)))
+           Hara_kiri_group_spanner::add_interesting_item (staffline_, i.grob ());
        }
     }
 }
index 4e9cc302f7a377abeba125440cc99372eb1e8c9f..b6940890944166a28957ce0e1ad492af76bf6edb 100644 (file)
@@ -64,7 +64,7 @@ Bar_number_engraver::Bar_number_engraver ()
 void
 Bar_number_engraver::acknowledge_grob (Grob_info inf)
 {
-  Grob *s = inf.grob_;
+  Grob *s = inf.grob ();
   if (text_
       && dynamic_cast<Item *> (s)
       && s->get_property ("break-align-symbol") == ly_symbol2scm ("left-edge"))
index 7e3a898dd34f89ccbcaef675a50d7dbd67f7ce6d..917d2db3c1193b258892b7d42d4976f85ee153be 100644 (file)
@@ -217,18 +217,18 @@ Beam_engraver::acknowledge_grob (Grob_info info)
 {
   if (beam_)
     {
-      if (Rest::has_interface (info.grob_))
+      if (Rest::has_interface (info.grob ()))
        {
-         info.grob_->add_offset_callback (Beam::rest_collision_callback_proc, Y_AXIS);
+         info.grob ()->add_offset_callback (Beam::rest_collision_callback_proc, Y_AXIS);
        }
-      else if (Stem::has_interface (info.grob_))
+      else if (Stem::has_interface (info.grob ()))
        {
          Moment now = now_mom ();
 
          if (!valid_start_point ())
            return;
 
-         Item *stem = dynamic_cast<Item *> (info.grob_);
+         Item *stem = dynamic_cast<Item *> (info.grob ());
          if (Stem::get_beam (stem))
            return;
 
index a9787ef377b48e9492f8f747569f93974592fcd9..2897a1aaa8b570998a9f6e00e975d9266fc5fe7a 100644 (file)
@@ -67,7 +67,7 @@ Break_align_engraver::derived_mark () const
 void
 Break_align_engraver::acknowledge_grob (Grob_info inf)
 {
-  if (Item *item = dynamic_cast<Item *> (inf.grob_))
+  if (Item *item = dynamic_cast<Item *> (inf.grob ()))
     {
       /*
        Removed check for item->empty (X_AXIS). --hwn 20/1/04
index 50d4e382cd6f0ab3b4be1cd451847bf57e4b66aa..363d756537a5231d496ede5b392d6d4a82b0abc6 100644 (file)
@@ -142,9 +142,9 @@ Chord_tremolo_engraver::typeset_beam ()
 void
 Chord_tremolo_engraver::acknowledge_grob (Grob_info info)
 {
-  if (beam_ && Stem::has_interface (info.grob_))
+  if (beam_ && Stem::has_interface (info.grob ()))
     {
-      Grob *s = info.grob_;
+      Grob *s = info.grob ();
 
       if (start_mom_ == now_mom ())
        Stem::set_beaming (s, flags_, RIGHT);
@@ -170,14 +170,14 @@ Chord_tremolo_engraver::acknowledge_grob (Grob_info info)
        }
     }
   else if (repeat_
-          && flags_ && !body_is_sequential_ && Stem::has_interface (info.grob_))
+          && flags_ && !body_is_sequential_ && Stem::has_interface (info.grob ()))
     {
       stem_tremolo_ = make_item ("StemTremolo", repeat_->self_scm ());
       stem_tremolo_->set_property ("flag-count",
                                   scm_int2num (flags_));
       stem_tremolo_->set_property ("stem",
-                                  info.grob_->self_scm ());
-      stem_tremolo_->set_parent (info.grob_, X_AXIS);
+                                  info.grob ()->self_scm ());
+      stem_tremolo_->set_parent (info.grob (), X_AXIS);
     }
 }
 
index bed486a45e8b0bb12db2dd5bf8802e9d4e507f29..e7a0d003045da9accfed077dc02c672bd29388f0 100644 (file)
@@ -71,10 +71,10 @@ Clef_engraver::set_glyph ()
 void
 Clef_engraver::acknowledge_grob (Grob_info info)
 {
-  Item *item = dynamic_cast<Item *> (info.grob_);
+  Item *item = dynamic_cast<Item *> (info.grob ());
   if (item)
     {
-      if (Bar_line::has_interface (info.grob_)
+      if (Bar_line::has_interface (info.grob ())
          && scm_is_string (get_property ("clefGlyph")))
        create_clef ();
     }
index c6ea93dc8694370fb44001d4f3fa4cb9de0057bd..565754199e79be00ce23f968299d26cd2377ae89 100644 (file)
@@ -117,7 +117,7 @@ Cluster_spanner_engraver::stop_translation_timestep ()
 void
 Cluster_spanner_engraver::acknowledge_grob (Grob_info info)
 {
-  if (!beacon_ && Note_column::has_interface (info.grob_))
+  if (!beacon_ && Note_column::has_interface (info.grob ()))
     {
       finished_spanner_ = spanner_;
       spanner_ = 0;
index 71995b18bbca1d3f8240d6cf13b7341e3bc305da..0ed1405afa9ba09b579b5dc01902c90b8c48f66c 100644 (file)
@@ -177,7 +177,7 @@ compute_delta_pitches (Array<Grob_info> primitives)
   Item *prev_primitive = 0, *primitive = 0;
   for (int i = 0; i < primitives.size (); i++)
     {
-      primitive = dynamic_cast<Item *> (primitives[i].grob_);
+      primitive = dynamic_cast<Item *> (primitives[i].grob ());
       Music *music_cause = primitives[i].music_cause ();
       int pitch
        = unsmob_pitch (music_cause->get_property ("pitch"))->steps ();
index 13edfdd486bee94df2fbf744f1f60850c590f7df..66813fb37ce70629dd7e0b374cd9be5e87b391a2 100644 (file)
@@ -42,13 +42,13 @@ Collision_engraver::process_acknowledged_grobs ()
 void
 Collision_engraver::acknowledge_grob (Grob_info i)
 {
-  if (Note_column::has_interface (i.grob_))
+  if (Note_column::has_interface (i.grob ()))
     {
       /*should check Y axis? */
-      if (Note_column::has_rests (i.grob_) || i.grob_->get_parent (X_AXIS))
+      if (Note_column::has_rests (i.grob ()) || i.grob ()->get_parent (X_AXIS))
        return;
 
-      note_columns_.push (i.grob_);
+      note_columns_.push (i.grob ());
     }
 }
 
index 0c5157d599c976e620a7e11747e360cf0ac14b51..2e232ea8ca683f139f64987f1fb83fc50cbe4064 100644 (file)
@@ -62,13 +62,13 @@ Custos_engraver::start_translation_timestep ()
 void
 Custos_engraver::acknowledge_grob (Grob_info info)
 {
-  Item *item = dynamic_cast<Item *> (info.grob_);
+  Item *item = dynamic_cast<Item *> (info.grob ());
   if (item)
     {
       Music *m = info.music_cause ();
-      if (Bar_line::has_interface (info.grob_))
+      if (Bar_line::has_interface (info.grob ()))
        custos_permitted = true;
-      else if (Note_head::has_interface (info.grob_)
+      else if (Note_head::has_interface (info.grob ())
               && m
               && m->is_mus_type ("note-event"))
        {
index 2bd44f58afe410059f32e336b29fdb1e319f5b0d..0b1a5b3a858c5bdd3cf17e705d172a680bfedaa8 100644 (file)
@@ -50,7 +50,7 @@ Dot_column_engraver::stop_translation_timestep ()
 void
 Dot_column_engraver::acknowledge_grob (Grob_info info)
 {
-  Grob *d = unsmob_grob (info.grob_->get_property ("dot"));
+  Grob *d = unsmob_grob (info.grob ()->get_property ("dot"));
   if (d)
     {
       if (!dotcol_)
@@ -58,11 +58,11 @@ Dot_column_engraver::acknowledge_grob (Grob_info info)
          dotcol_ = make_item ("DotColumn", SCM_EOL);
        }
 
-      Dot_column::add_head (dotcol_, info.grob_);
+      Dot_column::add_head (dotcol_, info.grob ());
     }
-  else if (Stem::has_interface (info.grob_))
+  else if (Stem::has_interface (info.grob ()))
     {
-      stem_ = info.grob_;
+      stem_ = info.grob ();
     }
 }
 
index c73cbf979102d7335674c283aadb42b205b32204..2d19c7d4bf699a5420b9f68488b6d234a58ed81a 100644 (file)
@@ -121,23 +121,23 @@ Drum_notes_engraver::process_music ()
 void
 Drum_notes_engraver::acknowledge_grob (Grob_info inf)
 {
-  if (Stem::has_interface (inf.grob_))
+  if (Stem::has_interface (inf.grob ()))
     {
       for (int i = 0; i < scripts_.size (); i++)
        {
          Grob *e = scripts_[i];
 
          if (to_dir (e->get_property ("side-relative-direction")))
-           e->set_property ("direction-source", inf.grob_->self_scm ());
+           e->set_property ("direction-source", inf.grob ()->self_scm ());
 
          /*
            add dep ?
          */
-         e->add_dependency (inf.grob_);
-         Side_position_interface::add_support (e, inf.grob_);
+         e->add_dependency (inf.grob ());
+         Side_position_interface::add_support (e, inf.grob ());
        }
     }
-  else if (Note_column::has_interface (inf.grob_))
+  else if (Note_column::has_interface (inf.grob ()))
     {
       for (int i = 0; i < scripts_.size (); i++)
        {
@@ -146,7 +146,7 @@ Drum_notes_engraver::acknowledge_grob (Grob_info inf)
          if (!e->get_parent (X_AXIS)
              && Side_position_interface::get_axis (e) == Y_AXIS)
            {
-             e->set_parent (inf.grob_, X_AXIS);
+             e->set_parent (inf.grob (), X_AXIS);
            }
        }
     }
index dd7e8ad4fbf5c4254c860a627bf7d6718c5d6e55..843573fdb3dba434f24a3464ddea064dab28cc44 100644 (file)
@@ -368,19 +368,19 @@ Dynamic_engraver::acknowledge_grob (Grob_info info)
   if (!line_spanner_)
     return;
 
-  if (Note_column::has_interface (info.grob_))
+  if (Note_column::has_interface (info.grob ()))
     {
       if (line_spanner_
          /* Don't refill killed spanner */
          && line_spanner_->is_live ())
        {
-         Side_position_interface::add_support (line_spanner_, info.grob_);
-         add_bound_item (line_spanner_, dynamic_cast<Item *> (info.grob_));
+         Side_position_interface::add_support (line_spanner_, info.grob ());
+         add_bound_item (line_spanner_, dynamic_cast<Item *> (info.grob ()));
        }
 
       if (script_ && !script_->get_parent (X_AXIS))
        {
-         SCM head = scm_last_pair (info.grob_->get_property ("note-heads"));
+         SCM head = scm_last_pair (info.grob ()->get_property ("note-heads"));
          if (scm_is_pair (head))
            script_->set_parent (unsmob_grob (scm_car (head)), X_AXIS);
        }
@@ -389,20 +389,20 @@ Dynamic_engraver::acknowledge_grob (Grob_info info)
        {
          if (!cresc_->get_bound (LEFT))
            {
-             cresc_->set_bound (LEFT, info.grob_);
+             cresc_->set_bound (LEFT, info.grob ());
              add_bound_item (line_spanner_, cresc_->get_bound (LEFT));
            }
        }
 
       if (finished_cresc_ && !finished_cresc_->get_bound (RIGHT))
        {
-         finished_cresc_->set_bound (RIGHT, info.grob_);
+         finished_cresc_->set_bound (RIGHT, info.grob ());
        }
     }
   
-  else if (Script_interface::has_interface (info.grob_) && script_)
+  else if (Script_interface::has_interface (info.grob ()) && script_)
     {
-      SCM p = info.grob_->get_property ("script-priority");
+      SCM p = info.grob ()->get_property ("script-priority");
 
       /*
        UGH.
@@ -412,7 +412,7 @@ Dynamic_engraver::acknowledge_grob (Grob_info info)
       if (scm_is_number (p)
          && scm_to_int (p)
          < scm_to_int (script_->get_property ("script-priority")))
-       Side_position_interface::add_support (line_spanner_, info.grob_);
+       Side_position_interface::add_support (line_spanner_, info.grob ());
     }
 }
 
index 5270d7121ce13126e168c6fd85f7d9d652064949..d68e0579c15e4d0e2918e36a45f3b304666bf9e4 100644 (file)
@@ -38,7 +38,7 @@ Engraver_group_engraver::acknowledge_grobs ()
     {
       Grob_info info = announce_infos_[j];
 
-      SCM meta = info.grob_->internal_get_property (meta_sym);
+      SCM meta = info.grob ()->internal_get_property (meta_sym);
       SCM nm = scm_assoc (name_sym, meta);
       if (scm_is_pair (nm))
        nm = scm_cdr (nm);
index 88985792dc877ef119b6b27f0d8d63bc58e3cf20..b7bc326c1506e23763cce11847ed3c1c94f6f815 100644 (file)
@@ -39,10 +39,7 @@ Engraver::announce_grob (Grob *e, SCM cause)
   if (unsmob_music (cause) || unsmob_grob (cause))
     e->set_property ("cause", cause);
 
-  Grob_info i;
-  i.grob_ = e;
-  if (!i.origin_trans_)
-    i.origin_trans_ = this;
+  Grob_info i (this, e);
 
   Engraver *g = get_daddy_engraver ();
   if (g)
index 6058843e875a1f2de716214b78de8af13cc09cbe..ac03f5c67f6a26d52149f7d13880b5b368103e30 100644 (file)
@@ -63,7 +63,7 @@ Extender_engraver::process_music ()
 void
 Extender_engraver::acknowledge_grob (Grob_info i)
 {
-  Item *item = dynamic_cast<Item *> (i.grob_);
+  Item *item = dynamic_cast<Item *> (i.grob ());
 
   if (item
       && item->internal_has_interface (ly_symbol2scm ("lyric-syllable-interface")))
index 59570ba4a8e3326d68d8b553ceb15b8f41bf76c3..00e468a7816d0b6c529e0813effbe2ab643f771b 100644 (file)
@@ -44,21 +44,21 @@ Fingering_engraver::try_music (Music *m)
 void
 Fingering_engraver::acknowledge_grob (Grob_info inf)
 {
-  if (Stem::has_interface (inf.grob_))
+  if (Stem::has_interface (inf.grob ()))
     {
       for (int i = 0; i < fingerings_.size (); i++)
        {
-         Side_position_interface::add_support (fingerings_[i], inf.grob_);
+         Side_position_interface::add_support (fingerings_[i], inf.grob ());
        }
     }
-  else if (Rhythmic_head::has_interface (inf.grob_))
+  else if (Rhythmic_head::has_interface (inf.grob ()))
     {
       for (int i = 0; i < fingerings_.size (); i++)
        {
          Grob *t = fingerings_[i];
-         Side_position_interface::add_support (t, inf.grob_);
+         Side_position_interface::add_support (t, inf.grob ());
          if (!t->get_parent (X_AXIS))
-           t->set_parent (inf.grob_, X_AXIS);
+           t->set_parent (inf.grob (), X_AXIS);
        }
     }
 }
index bc372a6a43e03481c6e387cdc286733c3d752792..d1ac0e634b5cbce42ec98a4dcb02707b3836ac0e 100644 (file)
@@ -37,8 +37,8 @@ Font_size_engraver::acknowledge_grob (Grob_info gi)
     {
       Real font_size = scm_to_double (sz);
 
-      font_size += robust_scm2double (gi.grob_->get_property ("font-size"), 0);
-      gi.grob_->set_property ("font-size", scm_make_real (font_size));
+      font_size += robust_scm2double (gi.grob ()->get_property ("font-size"), 0);
+      gi.grob ()->set_property ("font-size", scm_make_real (font_size));
     }
 }
 
index 21baa4f15001183bceb3b6155e4c1c28a5ff8ee1..c1288efaf352a7c6aa9e6572efb8947e4e3af56a 100644 (file)
@@ -61,9 +61,9 @@ Glissando_engraver::process_music ()
 void
 Glissando_engraver::acknowledge_grob (Grob_info info)
 {
-  if (Rhythmic_head::has_interface (info.grob_))
+  if (Rhythmic_head::has_interface (info.grob ()))
     {
-      Grob *g = info.grob_;
+      Grob *g = info.grob ();
       if (line_)
        line_->set_bound (LEFT, g);
 
index d1bd875f67034032eb3ec73fb1495b189b6c39e8..7af8430ade27393fc6be2993f0f93383cb4b80d7 100644 (file)
@@ -87,7 +87,7 @@ void check_and_fix_all_prefixes (Array<Grob_info> primitives)
   /* Check for illegal head modifier combinations */
   for (int i = 0; i < primitives.size (); i++)
     {
-      Grob *primitive = primitives[i].grob_;
+      Grob *primitive = primitives[i].grob ();
 
       /* compute head prefix set by inspecting primitive grob properties */
       int prefix_set
@@ -201,7 +201,7 @@ provide_context_info (Array<Grob_info> primitives)
   int prev_pitch = 0;
   for (int i = 0; i < primitives.size (); i++)
     {
-      Grob *primitive = primitives[i].grob_;
+      Grob *primitive = primitives[i].grob ();
       Music *music_cause = primitives[i].music_cause ();
       int context_info = 0;
       int pitch = unsmob_pitch (music_cause->get_property ("pitch"))->steps ();
index e138dca2a48d9154a10a42c2fe1e4d676b8c7db0..5ad0bed8a0b2b8acba8aeddb13fb8dcc8925984e 100644 (file)
@@ -32,9 +32,9 @@ void
 Grid_line_span_engraver::acknowledge_grob (Grob_info i)
 {
   int depth = i.origin_contexts (this).size ();
-  if (depth && i.grob_->internal_has_interface (ly_symbol2scm ("grid-point-interface")))
+  if (depth && i.grob ()->internal_has_interface (ly_symbol2scm ("grid-point-interface")))
     {
-      Item *it = dynamic_cast<Item *> (i.grob_);
+      Item *it = dynamic_cast<Item *> (i.grob ());
       lines_.push (it);
 
       if (lines_.size () >= 2 && !spanline_)
index 10644e7775c47754bc756361b31378a28538d8af..542880c184d6808d185e9ae82a692440add911a0 100644 (file)
@@ -49,7 +49,7 @@ Grob_pq_engraver::acknowledge_grob (Grob_info gi)
   Music *m = gi.music_cause ();
 
   if (m
-      && !gi.grob_->internal_has_interface (ly_symbol2scm ("multi-measure-interface")))
+      && !gi.grob ()->internal_has_interface (ly_symbol2scm ("multi-measure-interface")))
     {
       Moment n = now_mom ();
       Moment l = m->get_length ();
@@ -65,7 +65,7 @@ Grob_pq_engraver::acknowledge_grob (Grob_info gi)
 
       Moment end = n + l;
       SCM lst = scm_acons (end.smobbed_copy (),
-                          gi.grob_->self_scm (),
+                          gi.grob ()->self_scm (),
                           SCM_EOL);
 
       SCM busy = get_property ("busyGrobs");
index 74938b2fa74c29087ba32197b96c8aa362751bfb..2c5f39bbbac46c60d7d3568af3f2a9419a1d9789 100644 (file)
@@ -71,15 +71,15 @@ Horizontal_bracket_engraver::try_music (Music *m)
 void
 Horizontal_bracket_engraver::acknowledge_grob (Grob_info gi)
 {
-  if (Note_column::has_interface (gi.grob_))
+  if (Note_column::has_interface (gi.grob ()))
     {
       for (int i = 0; i < bracket_stack_.size (); i++)
        {
-         Side_position_interface::add_support (bracket_stack_[i], gi.grob_);
+         Side_position_interface::add_support (bracket_stack_[i], gi.grob ());
          Pointer_group_interface::add_grob (bracket_stack_[i],
-                                            ly_symbol2scm ("columns"), gi.grob_);
+                                            ly_symbol2scm ("columns"), gi.grob ());
          add_bound_item (bracket_stack_[i],
-                         gi.grob_);
+                         gi.grob ());
        }
     }
 }
index 2f314f00062b7eef4c0babaee031346903c37765..99612587295acca798c4e65c2081844e7092ff43 100644 (file)
@@ -40,7 +40,7 @@ Hyphen_engraver::Hyphen_engraver ()
 void
 Hyphen_engraver::acknowledge_grob (Grob_info i)
 {
-  Item *item = dynamic_cast<Item *> (i.grob_);
+  Item *item = dynamic_cast<Item *> (i.grob ());
   // -> Text_item
   if (item && item->internal_has_interface (ly_symbol2scm ("lyric-syllable-interface")))
     {
index 06b48ab89b72b8aac42f70feb5eccfd0e27c13ca..25b3d717740a6324e3f547ab985bb8140c0b2544 100644 (file)
@@ -20,11 +20,13 @@ class Grob_info
 {
   Translator *origin_trans_;
   friend class Engraver;
+  Grob *grob_;
 
 public:
-  Grob *grob_;
-  Context *context () const; 
+  Grob *grob () const { return grob_; }
   Translator *origin_translator () const { return origin_trans_; } 
+
+  Context *context () const; 
   Music *music_cause ();
   Link_array<Context> origin_contexts (Translator *) const;
   Grob_info (Translator *, Grob *);
index 2a20e73fce8531c4cb90bbd05ab0a4269532fded..34fcca0c2268c419aef40c123e799716e24119c4 100644 (file)
@@ -78,7 +78,7 @@ Instrument_name_engraver::create_text ()
 void
 Instrument_name_engraver::acknowledge_grob (Grob_info i)
 {
-  if (Bar_line::has_interface (i.grob_))
+  if (Bar_line::has_interface (i.grob ()))
     {
       create_text ();
     }
@@ -86,9 +86,9 @@ Instrument_name_engraver::acknowledge_grob (Grob_info i)
   /*
     Ugh - typechecking for pedal and dynamic sucks.
   */
-  if (dynamic_cast<Spanner *> (i.grob_)
-      && (i.grob_->internal_has_interface (ly_symbol2scm ("dynamic-interface"))
-         || i.grob_->internal_has_interface (ly_symbol2scm ("piano-pedal-interface"))))
+  if (dynamic_cast<Spanner *> (i.grob ())
+      && (i.grob ()->internal_has_interface (ly_symbol2scm ("dynamic-interface"))
+         || i.grob ()->internal_has_interface (ly_symbol2scm ("piano-pedal-interface"))))
     return;
 
   /*
@@ -100,12 +100,12 @@ Instrument_name_engraver::acknowledge_grob (Grob_info i)
     We could also just use stavesFound, but lets keep this working
     without staffs as well.
   */
-  if (dynamic_cast<Spanner *> (i.grob_)
-      && ((Axis_group_interface::has_interface (i.grob_)
-          && Axis_group_interface::has_axis (i.grob_, Y_AXIS)))
-      && !Align_interface::has_interface (i.grob_))
+  if (dynamic_cast<Spanner *> (i.grob ())
+      && ((Axis_group_interface::has_interface (i.grob ())
+          && Axis_group_interface::has_axis (i.grob (), Y_AXIS)))
+      && !Align_interface::has_interface (i.grob ()))
     {
-      SCM nl = scm_cons (i.grob_->self_scm (),
+      SCM nl = scm_cons (i.grob ()->self_scm (),
                         get_property ("instrumentSupport"));
 
       context ()->set_property ("instrumentSupport", nl);
index 8a178f02b0d8849202b48db9659c667f79c7156b..e8ad6ab2b3bf9e55a8f20eb10c9e8ed446d22409 100644 (file)
@@ -104,7 +104,7 @@ Key_engraver::try_music (Music *ev)
 void
 Key_engraver::acknowledge_grob (Grob_info info)
 {
-  if (Clef::has_interface (info.grob_))
+  if (Clef::has_interface (info.grob ()))
     {
       SCM c = get_property ("createKeyOnClefChange");
       if (to_boolean (c))
@@ -112,7 +112,7 @@ Key_engraver::acknowledge_grob (Grob_info info)
          create_key (false);
        }
     }
-  else if (Bar_line::has_interface (info.grob_)
+  else if (Bar_line::has_interface (info.grob ())
           && scm_is_pair (get_property ("keySignature")))
     {
       create_key (true);
index c2a8335e6f9f639a9b8cbf8d1685c54d324707a7..c4ebc455d560fe8727b4cf4863d0e74a61d39ea3 100644 (file)
@@ -52,9 +52,9 @@ Ledger_line_engraver::finalize ()
 void
 Ledger_line_engraver::acknowledge_grob (Grob_info s)
 {
-  if (!to_boolean (s.grob_->get_property ("no-ledgers")))
+  if (!to_boolean (s.grob ()->get_property ("no-ledgers")))
     Pointer_group_interface::add_grob (span_, ly_symbol2scm ("note-heads"),
-                                      s.grob_);
+                                      s.grob ());
 }
 ADD_TRANSLATOR (Ledger_line_engraver,
                "Creates the spanner to draw ledger lines, and notices objects that need ledger lines",
index eec8ff0cfa8b3b9a6dd3b26e688f15c8b463b79d..9eddeb71daf22f3bb5958a45364c24a080546c21 100644 (file)
@@ -41,10 +41,10 @@ Ligature_bracket_engraver::acknowledge_grob (Grob_info info)
 {
   if (current_ligature ())
     {
-      if (Note_column::has_interface (info.grob_))
+      if (Note_column::has_interface (info.grob ()))
        {
          Tuplet_bracket::add_column (current_ligature (),
-                                     dynamic_cast<Item *> (info.grob_));
+                                     dynamic_cast<Item *> (info.grob ()));
        }
       else Ligature_engraver::acknowledge_grob (info);
     }
index 609978af4a65a604528c8bcabcfff7d6233a4b21..70f490e3b48ea7df52e6be95c0f7d3acb5c75ec2 100644 (file)
@@ -269,13 +269,13 @@ Ligature_engraver::acknowledge_grob (Grob_info info)
 {
   if (ligature_)
     {
-      if (Note_head::has_interface (info.grob_))
+      if (Note_head::has_interface (info.grob ()))
        {
          primitives_.push (info);
-         info.grob_->set_property ("print-function",
+         info.grob ()->set_property ("print-function",
                                    brew_ligature_primitive_proc);
        }
-      if (Rest::has_interface (info.grob_))
+      if (Rest::has_interface (info.grob ()))
        {
          info.music_cause ()->origin ()->warning (_ ("ignoring rest: ligature may not contain rest"));
          prev_start_req_->origin ()->warning (_ ("ligature was started here"));
index 4e843841f94c74fe68fc1c09a222465b32fdc6b9..03748d10b5ecbb2fa7938351a2ed86c70e4b59b3 100644 (file)
@@ -45,7 +45,7 @@ Mark_engraver::Mark_engraver ()
 void
 Mark_engraver::acknowledge_grob (Grob_info inf)
 {
-  Grob *s = inf.grob_;
+  Grob *s = inf.grob ();
   if (text_ && Bar_line::has_interface (s))
     {
       /*
index 9ae9fb818360c57608f1aa6ff22098469036dd69..f44a8b3b5b2a7115f44b479a6f4949610809a2da 100644 (file)
@@ -41,7 +41,7 @@ Measure_grouping_engraver::acknowledge_grob (Grob_info gi)
 {
   if (grouping_)
     {
-      Side_position_interface::add_support (grouping_, gi.grob_);
+      Side_position_interface::add_support (grouping_, gi.grob ());
     }
 }
 
index 12840db59e7cf947d1a635cada2ce5a7a250edad..59c65531fea618bcf50e6bd0124ccec9ca9a63a4 100644 (file)
@@ -87,7 +87,7 @@ Mensural_ligature_engraver::transform_heads (Array<Grob_info> primitives)
   for (int i = 0, s = primitives.size (); i < s; i++)
     {
       Grob_info info = primitives[i];
-      Item *primitive = dynamic_cast<Item *> (info.grob_);
+      Item *primitive = dynamic_cast<Item *> (info.grob ());
       int duration_log = Note_head::get_balltype (primitive);
 
       Music *nr = info.music_cause ();
@@ -315,7 +315,7 @@ Mensural_ligature_engraver::propagate_properties (Spanner *ligature,
 
   for (int i = 0; i < primitives.size (); i++)
     {
-      Item *primitive = dynamic_cast<Item *> (primitives[i].grob_);
+      Item *primitive = dynamic_cast<Item *> (primitives[i].grob ());
       int output = scm_to_int (primitive->get_property ("primitive"));
       primitive->set_property ("thickness",
                               scm_make_real (thickness));
@@ -355,7 +355,7 @@ Mensural_ligature_engraver::fold_up_primitives (Array<Grob_info> primitives)
   Real distance = 0;
   for (int i = 0; i < primitives.size (); i++)
     {
-      Item *current = dynamic_cast<Item *> (primitives[i].grob_);
+      Item *current = dynamic_cast<Item *> (primitives[i].grob ());
       if (i == 0)
        {
          first = current;
index 728d5643a492a239d3d865ee59b7717be563601b..7ae551bd825d0e1cc0fa65c118211b9e0bb531c4 100644 (file)
@@ -60,7 +60,7 @@ protected:
 void
 New_fingering_engraver::acknowledge_grob (Grob_info inf)
 {
-  if (Rhythmic_head::has_interface (inf.grob_))
+  if (Rhythmic_head::has_interface (inf.grob ()))
     {
       Music *note_ev = inf.music_cause ();
       if (!note_ev)
@@ -77,7 +77,7 @@ New_fingering_engraver::acknowledge_grob (Grob_info inf)
 
          if (m->is_mus_type ("fingering-event"))
            {
-             add_fingering (inf.grob_, m, note_ev);
+             add_fingering (inf.grob (), m, note_ev);
            }
          else if (m->is_mus_type ("text-script-event"))
            {
@@ -85,26 +85,26 @@ New_fingering_engraver::acknowledge_grob (Grob_info inf)
            }
          else if (m->is_mus_type ("script-event"))
            {
-             add_script (inf.grob_, m, note_ev);
+             add_script (inf.grob (), m, note_ev);
            }
          else if (m->is_mus_type ("string-number-event"))
            {
-             add_string (inf.grob_, m, note_ev);
+             add_string (inf.grob (), m, note_ev);
            }
          else if (m->is_mus_type ("harmonic-event"))
            {
-             inf.grob_->set_property ("style", ly_symbol2scm ("harmonic"));
-             Grob *d = unsmob_grob (inf.grob_->get_property ("dot"));
+             inf.grob ()->set_property ("style", ly_symbol2scm ("harmonic"));
+             Grob *d = unsmob_grob (inf.grob ()->get_property ("dot"));
              if (d)
                d->suicide ();
            }
        }
 
-      heads_.push (inf.grob_);
+      heads_.push (inf.grob ());
     }
-  else if (Stem::has_interface (inf.grob_))
+  else if (Stem::has_interface (inf.grob ()))
     {
-      stem_ = inf.grob_;
+      stem_ = inf.grob ();
     }
 }
 
index 12fd61e212e673a01f58b061aa10702c3919daa2..36af9534d26f65eab698be3e0f4f4ce78c1bec9f 100644 (file)
@@ -50,9 +50,9 @@ Note_head_line_engraver::Note_head_line_engraver ()
 void
 Note_head_line_engraver::acknowledge_grob (Grob_info info)
 {
-  if (Rhythmic_head::has_interface (info.grob_))
+  if (Rhythmic_head::has_interface (info.grob ()))
     {
-      head_ = info.grob_;
+      head_ = info.grob ();
       if (to_boolean (get_property ("followVoice")))
        {
          Context *tr = context ();
index 1975eb0ca7ae469bc40c2734647b78224e3254a9..f4da2e415312ecd155b471833696f213f9a337e8 100644 (file)
@@ -68,8 +68,8 @@ Ottava_spanner_engraver::process_music ()
 void
 Ottava_spanner_engraver::acknowledge_grob (Grob_info info)
 {
-  Item *it = dynamic_cast<Item *> (info.grob_);
-  if (span_ && it && Note_column::has_interface (info.grob_))
+  Item *it = dynamic_cast<Item *> (info.grob ());
+  if (span_ && it && Note_column::has_interface (info.grob ()))
     {
       Side_position_interface::add_support (span_, it);
 
index dc7207a3ed155b0b3d0f195b3d9b576335d37be4..c80cc9c051cd6ad23e0d843300a36fef6d972247 100644 (file)
@@ -49,12 +49,12 @@ Output_property_engraver::acknowledge_grob (Grob_info inf)
          /*
            should typecheck pred. 
          */
-         SCM result = scm_call_1 (pred, inf.grob_->self_scm ());
+         SCM result = scm_call_1 (pred, inf.grob ()->self_scm ());
          if (to_boolean (result))
            {
              SCM sym = o->get_property ("grob-property");
              SCM val = o->get_property ("grob-value");
-             inf.grob_->internal_set_property (sym, val);
+             inf.grob ()->internal_set_property (sym, val);
            }
        }
       else
@@ -62,7 +62,7 @@ Output_property_engraver::acknowledge_grob (Grob_info inf)
          Context * d = inf.context ();
          SCM proc = o->get_property ("procedure");
          scm_call_3 (proc,
-                     inf.grob_->self_scm (),
+                     inf.grob ()->self_scm (),
                      d->self_scm (), 
                      context ()->self_scm ());
        }
index 9e10ff3e12026539f72ea6a6ed3bedac267e7c49..9bd1a12085dc46c10b88b872b1fb195a9dc5c201 100644 (file)
@@ -70,17 +70,17 @@ Part_combine_engraver::acknowledge_grob (Grob_info i)
 {
   if (text_)
     {
-      if (Note_head::has_interface (i.grob_))
+      if (Note_head::has_interface (i.grob ()))
        {
          Grob *t = text_;
-         Side_position_interface::add_support (t, i.grob_);
+         Side_position_interface::add_support (t, i.grob ());
          if (Side_position_interface::get_axis (t) == X_AXIS
              && !t->get_parent (Y_AXIS))
-           t->set_parent (i.grob_, Y_AXIS);
+           t->set_parent (i.grob (), Y_AXIS);
        }
-      if (Stem::has_interface (i.grob_))
+      if (Stem::has_interface (i.grob ()))
        {
-         Side_position_interface::add_support (text_, i.grob_);
+         Side_position_interface::add_support (text_, i.grob ());
        }
     }
 }
index 318e8da6db85b66cda5d3accccf4a9e5f9c5c02e..5af17ec462a74444a7e96d862d3d96e0ba4cd374 100644 (file)
@@ -70,8 +70,8 @@ Phrasing_slur_engraver::try_music (Music *m)
 void
 Phrasing_slur_engraver::acknowledge_grob (Grob_info info)
 {
-  Grob *e = info.grob_;
-  if (Note_column::has_interface (info.grob_))
+  Grob *e = info.grob ();
+  if (Note_column::has_interface (info.grob ()))
     {
       for (int i = slurs_.size (); i--;)
        Slur::add_column (slurs_[i], e);
index eb46d8e4336923f75ffad6e45b57f4b294f617ae..835d6b1f59375957af9f4b5e7fa35a88fd2c5b4d 100644 (file)
@@ -131,17 +131,17 @@ Piano_pedal_engraver::acknowledge_grob (Grob_info info)
 {
   for (Pedal_info *p = info_list_; p && p->name_; p++)
     {
-      if (Note_column::has_interface (info.grob_))
+      if (Note_column::has_interface (info.grob ()))
        {
          if (p->line_spanner_)
            {
-             Side_position_interface::add_support (p->line_spanner_, info.grob_);
-             add_bound_item (p->line_spanner_, info.grob_);
+             Side_position_interface::add_support (p->line_spanner_, info.grob ());
+             add_bound_item (p->line_spanner_, info.grob ());
            }
          if (p->bracket_)
-           add_bound_item (p->bracket_, info.grob_);
+           add_bound_item (p->bracket_, info.grob ());
          if (p->finished_bracket_)
-           add_bound_item (p->finished_bracket_, info.grob_);
+           add_bound_item (p->finished_bracket_, info.grob ());
        }
     }
 }
index 0ccf797d46a679f129b55a4dfb96130a990e4a64..870a5a93154ba82ddc0db33b087af1feae9b18a7 100644 (file)
@@ -22,9 +22,9 @@ Pitch_squash_engraver::acknowledge_grob (Grob_info i)
 {
   SCM newpos = get_property ("squashedPosition");
   if (scm_is_number (newpos)
-      && Note_head::has_interface (i.grob_))
+      && Note_head::has_interface (i.grob ()))
     {
-      i.grob_->set_property ("staff-position", newpos);
+      i.grob ()->set_property ("staff-position", newpos);
     }
 }
 
index 0a1af49d7a49c5315abfcaa5c91fd7a7c9ba96a5..2d718092f0d26dbabc42fc6ffcdb6b4e3bb0e4c7 100644 (file)
@@ -49,10 +49,10 @@ Rest_collision_engraver::process_acknowledged_grobs ()
 void
 Rest_collision_engraver::acknowledge_grob (Grob_info i)
 {
-  if (Note_column::has_interface (i.grob_))
+  if (Note_column::has_interface (i.grob ()))
     {
-      note_columns_.push (i.grob_);
-      if (Note_column::has_rests (i.grob_))
+      note_columns_.push (i.grob ());
+      if (Note_column::has_rests (i.grob ()))
        rest_count_++;
     }
 }
index f726dc88ab5c4533b026824412419386eb707740..af4f263aa15e29b0283d11c17581bd31d1daa4d8 100644 (file)
@@ -113,7 +113,7 @@ Rhythmic_column_engraver::process_acknowledged_grobs ()
 void
 Rhythmic_column_engraver::acknowledge_grob (Grob_info i)
 {
-  Item *item = dynamic_cast<Item *> (i.grob_);
+  Item *item = dynamic_cast<Item *> (i.grob ());
   if (!item || item->get_parent (X_AXIS))
     return;
   if (Stem::has_interface (item))
index 0f01110780f582f50138ee58ddd92a71c207e452..08be7890d5b468138655a0f5c3cc7789aca16670 100644 (file)
@@ -149,8 +149,8 @@ void
 Score_engraver::announce_grob (Grob_info info)
 {
   announce_infos_.push (info);
-  pscore_->root_system ()->typeset_grob (info.grob_);
-  elems_.push (info.grob_);
+  pscore_->root_system ()->typeset_grob (info.grob ());
+  elems_.push (info.grob ());
 }
 
 void
@@ -268,21 +268,21 @@ Score_engraver::forbid_breaks ()
 void
 Score_engraver::acknowledge_grob (Grob_info gi)
 {
-  if (Staff_spacing::has_interface (gi.grob_))
+  if (Staff_spacing::has_interface (gi.grob ()))
     {
       Pointer_group_interface::add_grob (command_column_,
                                         ly_symbol2scm ("spacing-wishes"),
-                                        gi.grob_);
+                                        gi.grob ());
     }
-  if (Note_spacing::has_interface (gi.grob_))
+  if (Note_spacing::has_interface (gi.grob ()))
     {
       Pointer_group_interface::add_grob (musical_column_,
                                         ly_symbol2scm ("spacing-wishes"),
-                                        gi.grob_);
+                                        gi.grob ());
     }
 
-  if (Axis_group_interface::has_interface (gi.grob_)
-      && gi.grob_->internal_has_interface (ly_symbol2scm ("vertically-spaceable-interface")))
+  if (Axis_group_interface::has_interface (gi.grob ())
+      && gi.grob ()->internal_has_interface (ly_symbol2scm ("vertically-spaceable-interface")))
     {
       SCM spaceable = get_property ("verticallySpacedContexts");
       Context *orig = gi.origin_contexts (this)[0];
@@ -292,7 +292,7 @@ Score_engraver::acknowledge_grob (Grob_info gi)
        {
          Pointer_group_interface::add_grob (system_,
                                             ly_symbol2scm ("spaceable-staves"),
-                                            gi.grob_);
+                                            gi.grob ());
        }
     }
 }
index 7e027aacfc11e6f2894b2bb36cc562466f99b014..a7ae23ec4a94042cdbb0c3b91b133cd6c734a12f 100644 (file)
@@ -41,11 +41,11 @@ Script_column_engraver::stop_translation_timestep ()
 void
 Script_column_engraver::acknowledge_grob (Grob_info inf)
 {
-  Item *thing = dynamic_cast<Item *> (inf.grob_);
-  if (thing && Side_position_interface::has_interface (inf.grob_)) // ugh FIXME
+  Item *thing = dynamic_cast<Item *> (inf.grob ());
+  if (thing && Side_position_interface::has_interface (inf.grob ())) // ugh FIXME
     {
       if (!Item::is_breakable (thing)
-         && Side_position_interface::get_axis (inf.grob_) == Y_AXIS)
+         && Side_position_interface::get_axis (inf.grob ()) == Y_AXIS)
        {
          scripts_.push (thing);
        }
index afeb0fe621cda7b452e06d0c3278ee31c16cb2d5..bc001d68a7665e95842e520534a74e62735ef5ee 100644 (file)
@@ -170,21 +170,21 @@ void
 Script_engraver::acknowledge_grob (Grob_info info)
 {
   int script_count = scripts_.size ();
-  if (Stem::has_interface (info.grob_))
+  if (Stem::has_interface (info.grob ()))
     {
       for (int i = 0; i < script_count; i++)
        {
          Grob *e = scripts_[i].script_;
 
          if (to_dir (e->get_property ("side-relative-direction")))
-           e->set_property ("direction-source", info.grob_->self_scm ());
+           e->set_property ("direction-source", info.grob ()->self_scm ());
 
          /* FIXME: add dependency */
-         e->add_dependency (info.grob_);
-         Side_position_interface::add_support (e, info.grob_);
+         e->add_dependency (info.grob ());
+         Side_position_interface::add_support (e, info.grob ());
        }
     }
-  else if (Rhythmic_head::has_interface (info.grob_)
+  else if (Rhythmic_head::has_interface (info.grob ())
           && info.music_cause ())
     {
       for (int i = 0; i < script_count; i++)
@@ -194,13 +194,13 @@ Script_engraver::acknowledge_grob (Grob_info info)
          if (Side_position_interface::get_axis (e) == X_AXIS
              && !e->get_parent (Y_AXIS))
            {
-             e->set_parent (info.grob_, Y_AXIS);
-             e->add_dependency (info.grob_);
+             e->set_parent (info.grob (), Y_AXIS);
+             e->add_dependency (info.grob ());
            }
-         Side_position_interface::add_support (e, info.grob_);
+         Side_position_interface::add_support (e, info.grob ());
        }
     }
-  else if (Note_column::has_interface (info.grob_))
+  else if (Note_column::has_interface (info.grob ()))
     {
       /* Make note column the parent of the script.  That is not
         correct, but due to seconds in a chord, noteheads may be
@@ -214,11 +214,11 @@ Script_engraver::acknowledge_grob (Grob_info info)
 
          if (!e->get_parent (X_AXIS)
              && Side_position_interface::get_axis (e) == Y_AXIS)
-           e->set_parent (info.grob_, X_AXIS);
+           e->set_parent (info.grob (), X_AXIS);
        }
     }
-  else if (Slur::has_interface (info.grob_))
-    slur_ = dynamic_cast<Spanner *> (info.grob_);
+  else if (Slur::has_interface (info.grob ()))
+    slur_ = dynamic_cast<Spanner *> (info.grob ());
 }
 
 void
index 3d28bb3c4fe9d92f4d5bdfb20d692b3be347d1fb..50648340d2b7edfef46feb1b80eb4aae75aed86f 100644 (file)
@@ -105,7 +105,7 @@ Separating_line_group_engraver::finalize ()
 void
 Separating_line_group_engraver::acknowledge_grob (Grob_info i)
 {
-  Item *it = dynamic_cast<Item *> (i.grob_);
+  Item *it = dynamic_cast<Item *> (i.grob ());
   if (!it)
     return;
   if (it->get_parent (X_AXIS)
index d0629b97005aa404453c737931830c8152200487..2cdf5289c6dbbc03e8a84f1373f9b8627c312a50 100644 (file)
@@ -72,8 +72,8 @@ Slur_engraver::set_melisma (bool m)
 void
 Slur_engraver::acknowledge_grob (Grob_info info)
 {
-  Grob *e = info.grob_;
-  if (Note_column::has_interface (info.grob_))
+  Grob *e = info.grob ();
+  if (Note_column::has_interface (info.grob ()))
     {
       for (int i = slurs_.size (); i--;)
        Slur::add_column (slurs_[i], e);
index 2c7f59360ee61da4ec5afe6cfc3b5d99d944a315..4aeebc586a74437cb19134e810808aaa32b542f7 100644 (file)
@@ -96,13 +96,13 @@ Spacing_engraver::finalize ()
 void
 Spacing_engraver::acknowledge_grob (Grob_info i)
 {
-  if (Note_spacing::has_interface (i.grob_) || Staff_spacing::has_interface (i.grob_))
+  if (Note_spacing::has_interface (i.grob ()) || Staff_spacing::has_interface (i.grob ()))
     {
-      Pointer_group_interface::add_grob (spacing_, ly_symbol2scm ("wishes"), i.grob_);
+      Pointer_group_interface::add_grob (spacing_, ly_symbol2scm ("wishes"), i.grob ());
     }
 
-  if (i.grob_->internal_has_interface (ly_symbol2scm ("lyric-syllable-interface"))
-      || i.grob_->internal_has_interface (ly_symbol2scm ("multi-measure-event")))
+  if (i.grob ()->internal_has_interface (ly_symbol2scm ("lyric-syllable-interface"))
+      || i.grob ()->internal_has_interface (ly_symbol2scm ("multi-measure-event")))
     return;
 
   /*
index 79dbbd0dc218d37dd375af15470275fb5d484794..8495a2f5fecb594beb2942e07d3a26cd5d509dfd 100644 (file)
@@ -41,10 +41,10 @@ Span_arpeggio_engraver::Span_arpeggio_engraver ()
 void
 Span_arpeggio_engraver::acknowledge_grob (Grob_info info)
 {
-  if (Arpeggio::has_interface (info.grob_)
+  if (Arpeggio::has_interface (info.grob ())
       && info.origin_contexts (this).size ()) // huh? what's this test for? 
     {
-      arpeggios_.push (info.grob_);
+      arpeggios_.push (info.grob ());
     }
 }
 
index db6baa0ffa94516144d8db61b29bdb8bbb9960d3..a3d1fc4887b4cee567150b5d9410c97dbb0dabd7 100644 (file)
@@ -40,9 +40,9 @@ void
 Span_bar_engraver::acknowledge_grob (Grob_info i)
 {
   int depth = i.origin_contexts (this).size ();
-  if (depth && Bar_line::has_interface (i.grob_))
+  if (depth && Bar_line::has_interface (i.grob ()))
     {
-      Item *it = dynamic_cast<Item *> (i.grob_);
+      Item *it = dynamic_cast<Item *> (i.grob ());
       bars_.push (it);
 
       if (bars_.size () >= 2 && !spanbar_)
index 095bfe11156a1b6e4be7242dce44416193ee4747..f9b97e4c67ff70b0dde52a9c8cc3a5721323ceac 100644 (file)
@@ -25,10 +25,10 @@ Staff_collecting_engraver::Staff_collecting_engraver ()
 void
 Staff_collecting_engraver::acknowledge_grob (Grob_info gi)
 {
-  if (Staff_symbol::has_interface (gi.grob_))
+  if (Staff_symbol::has_interface (gi.grob ()))
     {
       SCM staffs = get_property ("stavesFound");
-      staffs = scm_cons (gi.grob_->self_scm (), staffs);
+      staffs = scm_cons (gi.grob ()->self_scm (), staffs);
 
       context ()->set_property ("stavesFound", staffs);
     }
index 73c63f1dd739cab00e8b0c722591b6771c6d4943..61d3955384daa1ff2695e5890c9283f1b6262765 100644 (file)
@@ -108,7 +108,7 @@ Staff_symbol_engraver::acknowledge_grob (Grob_info s)
     symbol?
    */
   if (span_)
-    s.grob_->set_property ("staff-symbol", span_->self_scm ());
+    s.grob ()->set_property ("staff-symbol", span_->self_scm ());
 }
 
 ADD_TRANSLATOR (Staff_symbol_engraver,
index 16d2e073d230111b2275eb93ca26d0fa598c0208..52b18cbe1159e866de529bdd1eb5a8357faf0455 100644 (file)
@@ -33,7 +33,7 @@ Stanza_number_align_engraver::Stanza_number_align_engraver ()
 void
 Stanza_number_align_engraver::acknowledge_grob (Grob_info gi)
 {
-  Grob *h = gi.grob_;
+  Grob *h = gi.grob ();
 
   if (h->internal_has_interface (ly_symbol2scm ("lyric-syllable-interface")))
     lyrics_.push (h);
index 2f77b5d4f74e1c8f286162cea87ca0f66c4305c4..d74f0d8bcb5dbbb978e80c3d6c7f3aa9057c4742 100644 (file)
@@ -55,9 +55,9 @@ void
 Stanza_number_engraver::acknowledge_grob (Grob_info inf)
 {
   if (text_
-      && inf.grob_->internal_has_interface (ly_symbol2scm ("lyric-syllable-interface")))
+      && inf.grob ()->internal_has_interface (ly_symbol2scm ("lyric-syllable-interface")))
     {
-      Side_position_interface::add_support (text_, inf.grob_);
+      Side_position_interface::add_support (text_, inf.grob ());
     }
 }
 
index d665a96d068d45588ae0545b0037910665912e64..a8a7f6681589a55ad6301e1bef439c1c4bc6f9b0 100644 (file)
@@ -106,9 +106,9 @@ Stem_engraver::make_stem (Grob_info gi)
 void
 Stem_engraver::acknowledge_grob (Grob_info gi)
 {
-  if (Rhythmic_head::has_interface (gi.grob_))
+  if (Rhythmic_head::has_interface (gi.grob ()))
     {
-      if (Rhythmic_head::get_stem (gi.grob_))
+      if (Rhythmic_head::get_stem (gi.grob ()))
        return;
 
       Music *cause = gi.music_cause ();
@@ -126,7 +126,7 @@ Stem_engraver::acknowledge_grob (Grob_info gi)
          gi.music_cause ()->origin ()->warning (_f ("maybe input should specify polyphonic voices"));
        }
 
-      Stem::add_head (stem_, gi.grob_);
+      Stem::add_head (stem_, gi.grob ());
     }
 }
 
index a5f3624d28aa47fac75ba6cafc5239e3fdf5ffcb..55ef8fd32cfae271563f2dac8af6acacba999587 100644 (file)
@@ -29,17 +29,17 @@ protected:
 void
 System_start_delimiter_engraver::acknowledge_grob (Grob_info inf)
 {
-  if (Staff_symbol::has_interface (inf.grob_))
+  if (Staff_symbol::has_interface (inf.grob ()))
     {
       /*
        don't add as Axis_group_interface::add_element (delim_, ),
        because that would set the parent as well */
 
-      Pointer_group_interface::add_grob (delim_, ly_symbol2scm ("elements"), inf.grob_);
+      Pointer_group_interface::add_grob (delim_, ly_symbol2scm ("elements"), inf.grob ());
     }
-  else if (System_start_delimiter::has_interface (inf.grob_))
+  else if (System_start_delimiter::has_interface (inf.grob ()))
     {
-      SCM gl = inf.grob_->get_property ("glyph");
+      SCM gl = inf.grob ()->get_property ("glyph");
       SCM my_gl = delim_->get_property ("glyph");
 
       /*
@@ -47,13 +47,13 @@ System_start_delimiter_engraver::acknowledge_grob (Grob_info inf)
       */
       if (scm_is_string (gl) && ly_c_equal_p (gl, scm_makfrom0str ("brace"))
          && scm_is_string (my_gl) && ly_c_equal_p (my_gl, scm_makfrom0str ("bracket")))
-       inf.grob_->translate_axis (-0.8, X_AXIS); // ugh
+       inf.grob ()->translate_axis (-0.8, X_AXIS); // ugh
       else if (scm_is_string (gl) && ly_c_equal_p (gl, scm_makfrom0str ("bracket"))
               && scm_is_string (my_gl) && ly_c_equal_p (my_gl, scm_makfrom0str ("bracket")))
        {
-         inf.grob_->translate_axis (-0.8, X_AXIS); // ugh
-         inf.grob_->set_property ("arch-height",
-                                  scm_make_real (scm_to_double (inf.grob_->get_property
+         inf.grob ()->translate_axis (-0.8, X_AXIS); // ugh
+         inf.grob ()->set_property ("arch-height",
+                                  scm_make_real (scm_to_double (inf.grob ()->get_property
                                                                 ("arch-height")) + 0.5));
        }
     }
index 9569f3d24ba09b71354ac9d5b58d1d9271889102..f1d83168f1f698d1eff74668dfd2e6253f5ac596 100644 (file)
@@ -43,30 +43,30 @@ Text_engraver::try_music (Music *m)
 void
 Text_engraver::acknowledge_grob (Grob_info inf)
 {
-  if (Rhythmic_head::has_interface (inf.grob_))
+  if (Rhythmic_head::has_interface (inf.grob ()))
     {
       for (int i = 0; i < texts_.size (); i++)
        {
          Grob *t = texts_[i];
-         Side_position_interface::add_support (t, inf.grob_);
+         Side_position_interface::add_support (t, inf.grob ());
 
          /*
            ugh.
          */
          if (Side_position_interface::get_axis (t) == X_AXIS
              && !t->get_parent (Y_AXIS))
-           t->set_parent (inf.grob_, Y_AXIS);
+           t->set_parent (inf.grob (), Y_AXIS);
          else if (Side_position_interface::get_axis (t) == Y_AXIS
                   && !t->get_parent (X_AXIS))
-           t->set_parent (inf.grob_, X_AXIS);
+           t->set_parent (inf.grob (), X_AXIS);
        }
     }
 
-  if (Stem::has_interface (inf.grob_))
+  if (Stem::has_interface (inf.grob ()))
     {
       for (int i = 0; i < texts_.size (); i++)
        {
-         Side_position_interface::add_support (texts_[i], inf.grob_);
+         Side_position_interface::add_support (texts_[i], inf.grob ());
        }
     }
 }
index 0001365823ff5f0d6183d6908da9ff6dd03dbe47..5c177c5a96ae10ecf59a4fcb955ca47b8429bdd5 100644 (file)
@@ -91,10 +91,10 @@ Text_spanner_engraver::acknowledge_grob (Grob_info info)
   Spanner *spans[2] ={span_, finished_};
   for (int i = 0; i < 2; i++)
     {
-      if (spans[i] && Note_column::has_interface (info.grob_))
+      if (spans[i] && Note_column::has_interface (info.grob ()))
        {
-         Side_position_interface::add_support (spans[i], info.grob_);
-         add_bound_item (spans[i], dynamic_cast<Item *> (info.grob_));
+         Side_position_interface::add_support (spans[i], info.grob ());
+         add_bound_item (spans[i], dynamic_cast<Item *> (info.grob ()));
        }
     }
 }
index 4cb3ec1df5a3dfa28d4f34856ac0cd7671e1b28a..2e9ce6c1969920f79a726b4982ab011e3ab45182 100644 (file)
@@ -101,9 +101,9 @@ Tie_engraver::process_music ()
 void
 Tie_engraver::acknowledge_grob (Grob_info i)
 {
-  if (Note_head::has_interface (i.grob_))
+  if (Note_head::has_interface (i.grob ()))
     {
-      Grob *h = i.grob_;
+      Grob *h = i.grob ();
       now_heads_.push (h);
       for (int i = heads_to_tie_.size (); i--;)
        {
index fd93042b283c42f4c7a812877c1bc04ff1648623..ddb283ea48ad59e017daecfebac852445388b86c 100644 (file)
@@ -97,10 +97,10 @@ Trill_spanner_engraver::acknowledge_grob (Grob_info info)
   Spanner *spans[2] ={span_, finished_};
   for (int i = 0; i < 2; i++)
     {
-      if (spans[i] && Note_column::has_interface (info.grob_))
+      if (spans[i] && Note_column::has_interface (info.grob ()))
        {
-         Side_position_interface::add_support (spans[i], info.grob_);
-         add_bound_item (spans[i], dynamic_cast<Item *> (info.grob_));
+         Side_position_interface::add_support (spans[i], info.grob ());
+         add_bound_item (spans[i], dynamic_cast<Item *> (info.grob ()));
        }
     }
 }
index c2ca198984426f9d896815e73349f7f7601614de..bf82dc093103b9b581e718d837dc7c98d527d5d5 100644 (file)
@@ -87,12 +87,12 @@ Tuplet_engraver::process_music ()
 void
 Tuplet_engraver::acknowledge_grob (Grob_info i)
 {
-  if (Note_column::has_interface (i.grob_))
+  if (Note_column::has_interface (i.grob ()))
     {
       for (int j = 0; j < tuplets_.size (); j++)
        if (tuplets_[j].spanner_)
          Tuplet_bracket::add_column (tuplets_[j].spanner_,
-                                     dynamic_cast<Item *> (i.grob_));
+                                     dynamic_cast<Item *> (i.grob ()));
     }
 }
 
index aef60cb2da400902eba969c13b2d5b75fbb1782a..e6b0f002b87730f9311a81e6bf0e2b24ab5a9547 100644 (file)
@@ -154,7 +154,7 @@ Vaticana_ligature_engraver::align_heads (Array<Grob_info> primitives,
    * The paper column where we put the whole ligature into.
    */
   Paper_column *column
-    = dynamic_cast<Item *> (primitives[0].grob_)->get_column ();
+    = dynamic_cast<Item *> (primitives[0].grob ())->get_column ();
 
   Real join_thickness
     = thickness * column->get_layout ()->get_dimension (ly_symbol2scm ("linethickness"));
@@ -176,7 +176,7 @@ Vaticana_ligature_engraver::align_heads (Array<Grob_info> primitives,
   int prev_prefix_set = 0;
   for (int i = 0; i < primitives.size (); i++)
     {
-      Item *primitive = dynamic_cast<Item *> (primitives[i].grob_);
+      Item *primitive = dynamic_cast<Item *> (primitives[i].grob ());
       int prefix_set
        = scm_to_int (primitive->get_property ("prefix-set"));
       int context_info
@@ -362,7 +362,7 @@ Vaticana_ligature_engraver::transform_heads (Spanner *ligature,
   String prev_glyph_name = "";
   for (int i = 0; i < primitives.size (); i++)
     {
-      Item *primitive = dynamic_cast<Item *> (primitives[i].grob_);
+      Item *primitive = dynamic_cast<Item *> (primitives[i].grob ());
 
       int delta_pitch;
       SCM delta_pitch_scm = primitive->get_property ("delta-pitch");
@@ -584,7 +584,7 @@ Vaticana_ligature_engraver::transform_heads (Spanner *ligature,
 #if 0 // experimental code to collapse spacing after ligature
   /* TODO: set to max (old/new spacing-increment), since other
      voices/staves also may want to set this property. */
-  Item *first_primitive = dynamic_cast<Item *> (primitives[0].grob_);
+  Item *first_primitive = dynamic_cast<Item *> (primitives[0].grob ());
   Paper_column *paper_column = first_primitive->get_column ();
   paper_column->warning (_f ("Vaticana_ligature_engraver: "
                             "setting `spacing-increment = %f': ptr =%ul",
index 3e1838ae1f7cd669d0b71d5ffa3b5b4d02d982ab..7b0b9900f69ab5808d0aebc08c8a2558ad1f83a1 100644 (file)
@@ -86,8 +86,8 @@ Vertical_align_engraver::qualifies (Grob_info i) const
 {
   int sz = i.origin_contexts ((Translator *)this).size ();
 
-  return sz > 0 && Axis_group_interface::has_interface (i.grob_)
-    && !i.grob_->get_parent (Y_AXIS) && Axis_group_interface::has_axis (i.grob_, Y_AXIS);
+  return sz > 0 && Axis_group_interface::has_interface (i.grob ())
+    && !i.grob ()->get_parent (Y_AXIS) && Axis_group_interface::has_axis (i.grob (), Y_AXIS);
 }
 
 void
@@ -98,7 +98,7 @@ Vertical_align_engraver::acknowledge_grob (Grob_info i)
       String id = i.context ()->id_string ();
 
       scm_hash_set_x (id_to_group_hashtab_, scm_makfrom0str (id.to_str0 ()),
-                     i.grob_->self_scm ());
+                     i.grob ()->self_scm ());
 
 
       SCM before_id = i.context ()->get_property ("alignAboveContext");
@@ -108,7 +108,7 @@ Vertical_align_engraver::acknowledge_grob (Grob_info i)
       SCM after = scm_hash_ref (id_to_group_hashtab_,  after_id, SCM_BOOL_F);
 
 
-      Align_interface::add_element (valign_, i.grob_,
+      Align_interface::add_element (valign_, i.grob (),
                                    get_property ("verticalAlignmentChildCallback"));
 
       if (unsmob_grob (before) || unsmob_grob (after))
@@ -121,12 +121,12 @@ Vertical_align_engraver::acknowledge_grob (Grob_info i)
            {
              if (scm_car (s) == after)
                {
-                 *current = scm_cons (i.grob_->self_scm(), s);
+                 *current = scm_cons (i.grob ()->self_scm(), s);
                  break;
                }
              else if (scm_car (s) == before)
                {
-                 scm_set_cdr_x (s, scm_cons (i.grob_->self_scm (),
+                 scm_set_cdr_x (s, scm_cons (i.grob ()->self_scm (),
                                              scm_cdr (s)));
                  break;
                }
index 91d0f87bf1a1baa7119fee399296edd5dc5da639..03e940650d32e43ac20ee09c4758b4a255b9e60b 100644 (file)
@@ -161,7 +161,7 @@ Volta_engraver::process_music ()
 void
 Volta_engraver::acknowledge_grob (Grob_info i)
 {
-  if (Item *item = dynamic_cast<Item *> (i.grob_))
+  if (Item *item = dynamic_cast<Item *> (i.grob ()))
     {
       if (Note_column::has_interface (item))
        {
@@ -176,7 +176,7 @@ Volta_engraver::acknowledge_grob (Grob_info i)
            Volta_bracket_interface::add_bar (end_volta_span_, item);
        }
     }
-  else if (Staff_symbol::has_interface (i.grob_))
+  else if (Staff_symbol::has_interface (i.grob ()))
     {
       /*
        We only want to know about a single staff: then we add to the
@@ -185,7 +185,7 @@ Volta_engraver::acknowledge_grob (Grob_info i)
        staff_ = SCM_UNDEFINED;
 
       if (staff_ != SCM_UNDEFINED)
-       staff_ = i.grob_->self_scm ();
+       staff_ = i.grob ()->self_scm ();
     }
 }